/* ═══ FORM FIELDS ═══ */
.field{display:flex;flex-direction:column;gap:4px}
.fl{font-size:11px;font-weight:600;color:var(--t2);display:flex;justify-content:space-between;align-items:center}
.fl .hint{font-weight:400;color:var(--t3);font-size:10.5px}
.iw{position:relative}
.isfx{position:absolute;top:50%;transform:translateY(-50%);right:10px;font-size:11px;color:var(--t3);pointer-events:none;font-family:var(--mono)}
input[type=number],input[type=text],input[type=tel],input[type=email],input[type=password],input[type=date],input[type=time],select,textarea{background:var(--s2);border:1px solid var(--b2);border-radius:var(--r);padding:8px 11px;color:var(--t1);font-family:var(--font);font-size:13px;font-weight:500;width:100%;outline:none;transition:var(--tr);-moz-appearance:textfield}
input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none}
input:focus,select:focus,textarea:focus{border-color:var(--np);box-shadow:0 0 0 3px rgba(200,149,90,.12);background:var(--s3)}
input.hp{padding-right:32px}
textarea{resize:vertical;min-height:54px}
select option{background:var(--s2);color:var(--t1)}
[data-theme=light] select option{background:#fff;color:#111}

/* ═══ BUTTONS ═══ */
.btn{display:inline-flex;align-items:center;gap:6px;font-family:var(--font);font-size:12px;font-weight:600;border-radius:var(--r);padding:7px 14px;cursor:pointer;transition:var(--tr);border:1px solid transparent;white-space:nowrap}
.btn svg{width:13px;height:13px;flex-shrink:0}
.btn-p{background:linear-gradient(135deg,var(--np),var(--ngold2));color:#fff;border-color:rgba(200,149,90,.5);box-shadow:0 4px 14px rgba(200,149,90,.3)}
.btn-p:hover{transform:translateY(-1px);box-shadow:0 4px 22px rgba(200,149,90,.45)}
.btn-b{background:linear-gradient(135deg,var(--nb),#2474dc);color:#fff;box-shadow:0 4px 12px rgba(59,158,255,.25)}
.btn-b:hover{transform:translateY(-1px)}
.btn-g{background:rgba(200,149,90,.1);color:var(--np);border-color:rgba(200,149,90,.25)}
.btn-g:hover{background:rgba(200,149,90,.18)}
.btn-gb{background:rgba(59,158,255,.1);color:var(--nb);border-color:rgba(59,158,255,.25)}
.btn-gb:hover{background:rgba(59,158,255,.18)}
.btn-d{background:rgba(220,60,60,.07);color:#d94040;border-color:rgba(220,60,60,.22)}
.btn-d:hover{background:rgba(220,60,60,.15)}
.btn-n{background:var(--s3);color:var(--t2);border-color:var(--b2)}
.btn-n:hover{border-color:var(--b3);color:var(--t1)}
.btn-sm{padding:5px 10px;font-size:11px;border-radius:7px}
.btn-ico{width:30px;height:30px;padding:0;border-radius:8px;justify-content:center}
.btn-ico svg{width:14px;height:14px}
.btn-full{width:100%;justify-content:center}
.btn-toggle{padding:7px 14px;border-radius:100px;font-size:12px;font-weight:700;cursor:pointer;transition:var(--tr);border:1px solid var(--b2);background:var(--s3);color:var(--t3)}
.btn-toggle.on{background:rgba(200,149,90,.15);border-color:rgba(200,149,90,.35);color:var(--np)}

/* Interval buttons */
.iv-row{display:flex;gap:7px;flex-wrap:wrap}
.ivbtn{padding:7px 10px;border-radius:9px;border:1px solid var(--b2);background:var(--s2);color:var(--t3);font-family:var(--font);font-size:11px;font-weight:700;cursor:pointer;text-align:center;transition:var(--tr);min-width:58px}
.ivbtn:hover{border-color:var(--np);color:var(--np)}
.ivbtn.sel{background:rgba(200,149,90,.12);border-color:rgba(200,149,90,.4);color:var(--np)}
.ivbtn .ivn{font-size:15px;font-weight:800;display:block}

/* Treat-Mat input group */
.treat-mat-wrap{margin-left:22px;margin-top:4px;margin-bottom:3px;display:none;align-items:center;gap:8px}
.treat-mat-wrap.show{display:flex}
.treat-mat-input{width:88px!important}

/* ═══ KPI CARDS ═══ */
.kgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:10px;margin-bottom:13px}
.kpi{background:var(--s1);border:1px solid var(--b1);border-radius:var(--r3);padding:14px 15px;position:relative;overflow:hidden;transition:var(--tr)}
.kpi:hover{transform:translateY(-2px);box-shadow:var(--sh)}
.kg{position:absolute;bottom:-28px;right:-28px;width:90px;height:90px;border-radius:50%;filter:blur(26px);pointer-events:none}
.ks{position:absolute;top:0;left:0;right:0;height:2px}
.ktag{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:2px 8px;border-radius:100px;margin-bottom:5px}
.klbl{font-size:11px;color:var(--t3);margin-bottom:4px;line-height:1.4}
.kval{font-size:19px;font-weight:800;line-height:1;letter-spacing:-.02em}
.ksub{font-size:11px;color:var(--t3);margin-top:4px}
.vb{--c:var(--nb);--ca:rgba(59,158,255,.12);--cb:rgba(59,158,255,.2)}
.vg{--c:var(--ng);--ca:rgba(29,217,122,.12);--cb:rgba(29,217,122,.2)}
.vp{--c:var(--np);--ca:rgba(200,149,90,.12);--cb:rgba(200,149,90,.2)}
.va{--c:var(--na);--ca:rgba(255,170,44,.12);--cb:rgba(255,170,44,.2)}
.vv{--c:var(--nv);--ca:rgba(168,85,247,.12);--cb:rgba(168,85,247,.2)}
.vc{--c:var(--nc);--ca:rgba(6,214,245,.12);--cb:rgba(6,214,245,.2)}
.vgr{--c:var(--t3);--ca:rgba(255,255,255,.05);--cb:rgba(255,255,255,.08)}
[data-theme=light] .vgr{--ca:rgba(0,0,0,.04);--cb:rgba(0,0,0,.07)}
[class*=v] .kg{background:var(--cb)}[class*=v] .ks{background:var(--c);box-shadow:0 0 10px var(--c)}
[class*=v] .ktag{background:var(--ca);color:var(--c);border:1px solid var(--cb)}
[class*=v] .kval{color:var(--c);text-shadow:0 0 20px var(--c)}
[data-theme=light] [class*=v] .kval{text-shadow:none}

/* ═══ PROGRESS BARS ═══ */
.prog{background:var(--s1);border:1px solid var(--b1);border-radius:var(--r3);padding:14px 16px;margin-bottom:13px}
.ptrack{background:var(--s4);border-radius:100px;height:8px;overflow:hidden;margin:8px 0 6px;border:1px solid var(--b1)}
.pfill{height:100%;border-radius:100px;transition:width .6s cubic-bezier(.4,0,.2,1),background .3s}
.mtrack{background:var(--s4);border-radius:100px;height:5px;overflow:hidden}
.mfill{height:100%;border-radius:100px;transition:width .5s,background .3s}

/* ═══ TABLE ═══ */
.tscroll{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
table{width:100%;border-collapse:collapse}
thead th{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--t3);padding:9px 10px;text-align:left;white-space:nowrap;border-bottom:1px solid var(--b2);background:rgba(255,255,255,.015)}
[data-theme=light] thead th{background:rgba(0,0,0,.02)}
.thsub{font-size:9px;font-weight:400;letter-spacing:0;text-transform:none;display:block;margin-top:1px;opacity:.7}
td{padding:7px 10px;border-bottom:1px solid rgba(255,255,255,.04);vertical-align:middle}
[data-theme=light] td{border-bottom:1px solid rgba(0,0,0,.05)}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover td{background:rgba(200,149,90,.03)}
tfoot td{border-top:1px solid var(--b2)!important;font-weight:700;font-size:13px;padding:9px 10px}
.ti{background:var(--s2);border:1px solid var(--b2);border-radius:7px;padding:5px 8px;color:var(--t1);font-family:var(--font);font-size:12.5px;font-weight:500;outline:none;width:100%;transition:var(--tr);-moz-appearance:textfield}
.ti::-webkit-outer-spin-button,.ti::-webkit-inner-spin-button{-webkit-appearance:none}
.ti:focus{border-color:var(--np);box-shadow:0 0 0 2px rgba(200,149,90,.1)}
.ti[readonly]{background:rgba(29,217,122,.06);border-color:rgba(29,217,122,.28);color:var(--ng);cursor:not-allowed}
.ti[readonly]:focus{box-shadow:none;border-color:rgba(29,217,122,.28)}
.tv{font-size:12.5px;color:var(--t2);white-space:nowrap;font-weight:500}
.tv.main{color:var(--t1);font-weight:700}.tv.pos{color:var(--ng);font-weight:600}.tv.neg{color:var(--np);font-weight:600}.tv.dim{color:var(--t3)}
.pill{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:3px 9px;border-radius:100px}
.pok{background:rgba(29,217,122,.12);border:1px solid rgba(29,217,122,.28);color:var(--ng)}
.perr{background:rgba(200,149,90,.12);border:1px solid rgba(200,149,90,.28);color:var(--np)}

/* ═══ INFO BOXES & RECOMMENDATIONS ═══ */
.ibox{border-radius:9px;padding:9px 12px;font-size:11.5px;line-height:1.7;margin-bottom:9px}
.ib-b{background:rgba(59,158,255,.07);border:1px solid rgba(59,158,255,.2);color:var(--t2)}
.ib-a{background:rgba(255,170,44,.07);border:1px solid rgba(255,170,44,.2);color:var(--t2)}
.ib-g{background:rgba(29,217,122,.07);border:1px solid rgba(29,217,122,.2);color:var(--t2)}
.ib-r{background:rgba(200,149,90,.07);border:1px solid rgba(200,149,90,.2);color:var(--t2)}
.ib-warn{background:rgba(255,170,44,.09);border:1px solid rgba(255,170,44,.3);color:var(--t2)}
.ibox strong{font-weight:700;color:var(--t1)}
.slbl{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--t3);display:flex;align-items:center;gap:7px;margin-bottom:8px}
.slbl::before{content:'';display:block;width:3px;height:12px;border-radius:2px;background:var(--np);box-shadow:0 0 7px var(--np)}
.live{display:inline-flex;align-items:center;gap:6px;background:rgba(29,217,122,.09);border:1px solid rgba(29,217,122,.22);border-radius:100px;padding:3px 10px;font-size:10px;font-weight:700;color:var(--ng);letter-spacing:.08em}
.ldot{width:6px;height:6px;border-radius:50%;background:var(--ng);box-shadow:0 0 6px var(--ng);animation:blink 1.8s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.25;transform:scale(.8)}}
.rec{background:var(--s1);border:1px solid var(--b1);border-radius:var(--r3);padding:14px 16px;display:flex;gap:11px;align-items:flex-start;margin-top:12px}
.riw{width:38px;height:38px;border-radius:11px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.rtip{background:rgba(59,158,255,.12)}.rok{background:rgba(29,217,122,.12)}.rwarn{background:rgba(255,170,44,.12)}
.rtt{font-size:13px;font-weight:700;color:var(--t1);margin-bottom:3px}
.rtx{font-size:11.5px;color:var(--t2);line-height:1.75}
.hl{color:var(--t1);font-weight:600}.hb{color:var(--nb);font-weight:600}.hg{color:var(--ng);font-weight:600}.hr{color:var(--np);font-weight:600}.ha{color:var(--na);font-weight:600}

/* ═══ MODAL BASE ═══ */
.mbg{display:none;position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.78);backdrop-filter:blur(8px);align-items:center;justify-content:center;padding:18px}
.mbg.open{display:flex;animation:fi .2s ease}
@keyframes fi{from{opacity:0}to{opacity:1}}
.modal{background:var(--s1);border:1px solid var(--b2);border-radius:20px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 80px rgba(0,0,0,.6);animation:mi .22s cubic-bezier(.34,1.56,.64,1)}
@keyframes mi{from{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:none}}
.modal-sm{max-width:440px}
.mhd{padding:16px 18px 12px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--b1);position:sticky;top:0;background:var(--s1);z-index:1}
.mtt{font-size:15px;font-weight:700;color:var(--t1)}
.mclose{background:var(--s3);border:1px solid var(--b2);border-radius:8px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--t2);transition:var(--tr)}
.mclose:hover{background:rgba(200,149,90,.12);color:var(--np)}
.mbody{padding:17px;display:flex;flex-direction:column;gap:12px}
.mfoot{padding:11px 17px;border-top:1px solid var(--b1);display:flex;justify-content:flex-end;gap:8px;position:sticky;bottom:0;background:var(--s1)}

/* Appointment feasibility panel */
.apt-feas{display:flex;flex-direction:column;gap:6px;margin-top:2px}
.apt-feas-row{display:flex;gap:9px;align-items:flex-start;padding:9px 11px;border-radius:10px;font-size:11.5px;line-height:1.55;border:1px solid var(--b1);background:var(--s2)}
.apt-feas-row strong{color:var(--t1);font-weight:700}
.apt-feas-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:5px;background:var(--t3)}
.apt-feas-neutral{color:var(--t3)}
.apt-feas-ok{background:rgba(29,217,122,.08);border-color:rgba(29,217,122,.24);color:var(--t2)}
.apt-feas-ok .apt-feas-dot{background:var(--ng);box-shadow:0 0 8px var(--ng)}
.apt-feas-warn{background:rgba(255,170,44,.09);border-color:rgba(255,170,44,.3);color:var(--t2)}
.apt-feas-warn .apt-feas-dot{background:var(--na);box-shadow:0 0 8px var(--na)}
.apt-feas-err{background:rgba(220,60,60,.09);border-color:rgba(220,60,60,.3);color:var(--t2)}
.apt-feas-err .apt-feas-dot{background:#d94040;box-shadow:0 0 8px #d94040}

/* Checklist items (legacy; some modals) */
.cklist{display:flex;flex-direction:column;gap:2px;max-height:200px;overflow-y:auto}
.ckitem{display:flex;align-items:center;gap:8px;padding:6px 9px;border-radius:8px;cursor:pointer;transition:var(--tr);border:1px solid transparent}
.ckitem:hover{background:var(--s3);border-color:var(--b1)}
.ckitem input{width:14px;height:14px;accent-color:var(--np);cursor:pointer;flex-shrink:0}
.ckl{font-size:12.5px;color:var(--t2);flex:1}.ckp{font-size:11px;font-weight:600;color:var(--t3);font-family:var(--mono)}

/* ═══ MOBILE COMPONENTS ═══ */
@media(max-width:640px){
  .btn{padding:10px 16px;font-size:13px;min-height:44px;touch-action:manipulation}
  .btn-sm{padding:8px 12px;font-size:12px;min-height:36px;touch-action:manipulation}
  .btn-ico{width:38px;height:38px}
  .btn-ico svg{width:15px;height:15px}
  .fl{font-size:12px}
  .fl .hint{font-size:11px}
  /* font-size:16px verhindert iOS-Zoom beim Antippen von Inputs */
  input[type=number],input[type=text],input[type=tel],input[type=email],input[type=password],input[type=date],input[type=time],select,textarea{padding:11px 13px;font-size:16px;min-height:44px}
  /* Suffix-Padding wiederherstellen (überschreibt obige padding-Kurzform) */
  input.hp{padding-right:36px}
  /* Tabellen-Inputs bleiben kompakt – sie liegen im horizontalen Scroll-Container */
  .ti{font-size:13px;min-height:32px;padding:5px 8px}
  textarea{min-height:80px}
  .kgrid{grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:8px}
  .kpi{padding:12px 13px}
  .kval{font-size:17px}
  .modal{border-radius:16px;max-height:94vh}
  .modal-sm{max-width:100%}
  .mbg{padding:10px}
  .mhd{padding:13px 15px 10px}
  .mbody{padding:13px;gap:10px}
  .mfoot{padding:10px 13px;gap:7px}
  .mclose{width:34px;height:34px}
  .ibox{font-size:12px}
}
@media(max-width:480px){
  .mbg{padding:0;align-items:flex-end}
  .modal{border-radius:20px 20px 0 0;max-height:92vh}
  .modal-sm{border-radius:20px 20px 0 0}
}

/* ═══ CUSTOM DIALOG (replaces browser confirm/alert) ═══ */
.dlg-bg{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.72);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:20px;animation:fi .15s ease}
.dlg-box{background:var(--s1);border:1px solid var(--b2);border-radius:16px;max-width:420px;width:100%;box-shadow:0 24px 64px rgba(0,0,0,.55);animation:mi .18s cubic-bezier(.34,1.56,.64,1)}
.dlg-body{padding:22px 22px 12px;font-size:13.5px;line-height:1.7;color:var(--t1);word-break:break-word}
.dlg-foot{padding:10px 18px 16px;display:flex;justify-content:flex-end;gap:8px}
@media(max-width:480px){.dlg-bg{padding:0;align-items:flex-end}.dlg-box{border-radius:20px 20px 0 0;max-width:100%}}
