/* ============ invty.app — Live-Demo · light glass · Inter ============ */
@font-face{
  font-family:'Inter';font-style:normal;font-weight:400 800;font-display:swap;
  src:url('fonts/inter-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
:root{
  --ink:#0e1525; --ink-2:#27314a; --text:#27314a; --muted:#737d96; --muted-2:#9aa2b8;
  --line:rgba(20,28,50,.08); --border:rgba(20,28,50,.10);
  --bg:#f5f7fc; --card:#ffffff;
  --glass:rgba(255,255,255,.62); --glass-strong:rgba(255,255,255,.82); --glass-brd:rgba(255,255,255,.8);
  --blur:saturate(180%) blur(20px);
  --orange:#ef7d00; --orange-dark:#cf6c00; --orange-soft:#fff4e6;
  --yellow:#f5b40a; --red:#e23b34; --red-soft:#fdeceb; --green:#12a45c; --green-soft:#e7f7ee;
  --brand:#6D5EF6; --brand-soft:#eeecfe; --grad:linear-gradient(120deg,#FF7A1A 0%,#F0476B 52%,#6D5EF6 100%);
  --radius:16px; --radius-sm:11px; --gap:16px;
  --shadow-sm:0 1px 2px rgba(20,28,50,.04),0 8px 24px -16px rgba(20,28,50,.22);
  --shadow:0 2px 6px rgba(20,28,50,.05),0 20px 50px -24px rgba(20,28,50,.30);
  --font:'Inter',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --sidebar:252px;
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font-size:15px;line-height:1.5;position:relative;overflow-x:hidden}
body::before{content:"";position:fixed;inset:0;z-index:-1;background:
  radial-gradient(32% 38% at 8% 6%,rgba(255,122,26,.12),transparent 60%),
  radial-gradient(34% 40% at 94% 4%,rgba(109,94,246,.13),transparent 62%),
  radial-gradient(40% 44% at 88% 96%,rgba(240,71,107,.09),transparent 60%),
  linear-gradient(#f5f7fc,#eef1f8)}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
h1,h2,h3,h4{margin:0;color:var(--ink);letter-spacing:-.02em}
.ic-svg{display:inline-block;vertical-align:middle}
.ic{display:inline-flex;align-items:center;justify-content:center}

/* demo banner */
.demo-banner{display:flex;align-items:center;justify-content:space-between;gap:14px;
  background:var(--glass-strong);backdrop-filter:var(--blur);border-bottom:1px solid var(--glass-brd);
  padding:8px 18px;font-size:13.5px;flex-wrap:wrap;position:sticky;top:0;z-index:80}
.demo-banner .lft{display:flex;align-items:center;gap:10px;flex-wrap:wrap;color:var(--muted)}
.demo-banner .badge{background:var(--grad);color:#fff;font-weight:700;padding:3px 11px;border-radius:999px;font-size:11.5px;letter-spacing:.04em}
.demo-banner b{color:var(--ink-2)}
.demo-banner a.back{color:var(--ink-2);font-weight:600;display:inline-flex;align-items:center;gap:6px;
  border:1px solid var(--border);padding:5px 13px;border-radius:999px;background:rgba(255,255,255,.6)}
.demo-banner a.back:hover{background:#fff}
.demo-banner a.back .ic-svg{width:15px;height:15px}

/* embed mode (iframe inside marketing device mockups) */
body.embed .demo-banner{display:none}
body.embed .role-switch{display:none}
body.embed .shell{min-height:100vh}
body.embed .sidebar{top:0;height:100vh}
body.embed .topbar{top:0}
body.embed .backdrop{top:0}
body.embed{overflow:hidden}

/* shell */
.shell{display:grid;grid-template-columns:var(--sidebar) 1fr;min-height:calc(100vh - 39px)}
.sidebar{padding:16px 14px;display:flex;flex-direction:column;gap:4px;position:sticky;top:39px;height:calc(100vh - 39px);overflow:auto;
  background:var(--glass);backdrop-filter:var(--blur);border-right:1px solid var(--glass-brd)}
.sb-brand{display:flex;align-items:center;gap:0;padding:6px 8px 14px;font-weight:800;font-size:19px;color:var(--ink);letter-spacing:-.03em}
.sb-brand .mk{width:30px;height:30px;border-radius:9px;background:var(--ink);display:grid;place-items:center;flex:none;margin-right:10px}
.sb-brand .mk .ic-svg{width:17px;height:17px;color:#fff}
.sb-brand .dot{font-weight:600;margin-left:-1px;
  background:linear-gradient(90deg,#FF7A1A,#F0476B,#6D5EF6,#F0476B,#FF7A1A);
  background-size:200% auto;-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  animation:appflow 4s linear infinite}
@keyframes appflow{to{background-position:200% center}}
@media(prefers-reduced-motion:reduce){.sb-brand .dot{animation:none;background-position:0 center}}
.sb-sec{font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-2);padding:14px 10px 5px}
.nav-item{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:10px;color:var(--ink-2);
  font-size:14px;font-weight:500;cursor:pointer;border:none;background:none;width:100%;text-align:left;transition:background .12s,color .12s}
.nav-item .ic-svg{width:19px;height:19px;color:var(--muted);flex:none;transition:color .12s}
.nav-item:hover{background:rgba(255,255,255,.6)}
.nav-item.active{background:var(--orange-soft);color:var(--orange-dark);font-weight:600}
.nav-item.active .ic-svg{color:var(--orange)}
.nav-item .count{margin-left:auto;background:var(--red-soft);color:var(--red);font-size:11px;font-weight:700;padding:1px 8px;border-radius:999px}
.nav-item.locked{opacity:.45;cursor:not-allowed}
.nav-item .lk{margin-left:auto;color:var(--muted-2)}.nav-item .lk .ic-svg{width:14px;height:14px}

/* role switcher */
.role-switch{margin-top:auto;padding-top:14px;border-top:1px solid var(--line)}
.role-switch .lab{font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted-2);padding:0 8px 8px}
.role-card{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:11px;background:rgba(255,255,255,.6);border:1px solid var(--glass-brd)}
.role-card .av{width:34px;height:34px;border-radius:50%;background:var(--grad);color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px;flex:none}
.role-card .nm{font-weight:600;color:var(--ink);font-size:13px;line-height:1.2}
.role-card .rl{font-size:11.5px;color:var(--muted)}
.role-seg{display:flex;gap:4px;margin-top:9px;background:rgba(20,28,50,.05);padding:3px;border-radius:10px}
.role-seg button{flex:1;border:none;background:none;font-size:11.5px;font-weight:600;color:var(--muted);padding:6px 4px;border-radius:8px;cursor:pointer;transition:.12s}
.role-seg button.on{background:#fff;color:var(--ink);box-shadow:var(--shadow-sm)}

/* main */
.main{min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;gap:14px;padding:13px 24px;position:sticky;top:39px;z-index:20;flex-wrap:wrap;
  background:var(--glass);backdrop-filter:var(--blur);border-bottom:1px solid var(--glass-brd)}
.topbar .menu{display:none;width:38px;height:38px;border:1px solid var(--border);border-radius:9px;background:rgba(255,255,255,.6);cursor:pointer;color:var(--ink)}
.topbar .menu .ic-svg{width:20px;height:20px}
.page-title{font-size:18px;font-weight:800}
.topbar .grow{flex:1}
.search{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.6);border:1px solid var(--border);border-radius:10px;padding:8px 12px;min-width:210px}
.search .ic-svg{width:17px;height:17px;color:var(--muted)}
.search input{border:none;background:none;outline:none;font-size:14px;width:100%;color:var(--ink);font-family:inherit}
.locsel{display:flex;align-items:center;gap:7px;background:rgba(255,255,255,.6);border:1px solid var(--border);border-radius:10px;padding:7px 11px;font-size:14px;font-weight:600}
.locsel .ic-svg{width:16px;height:16px;color:var(--orange)}
.locsel select{border:none;background:none;font:inherit;font-weight:600;color:var(--ink);outline:none;cursor:pointer}
.avatar{width:36px;height:36px;border-radius:50%;background:var(--grad);color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px;flex:none}
.content{padding:24px;max-width:1240px;width:100%}

/* cards / grid */
.grid{display:grid;gap:var(--gap)}
.cols-4{grid-template-columns:repeat(4,1fr)}.cols-3{grid-template-columns:repeat(3,1fr)}.cols-2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--glass);backdrop-filter:var(--blur);border:1px solid var(--glass-brd);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.card-pad{padding:18px}
.card-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--line)}
.card-head h3{font-size:15px;display:flex;align-items:center;gap:9px}
.card-head h3 .ic-svg{width:18px;height:18px;color:var(--orange)}
.card-head .lnk{font-size:13px;color:var(--orange-dark);font-weight:600;cursor:pointer}

/* stat */
.stat{background:var(--glass);backdrop-filter:var(--blur);border:1px solid var(--glass-brd);border-radius:var(--radius);padding:17px;box-shadow:var(--shadow-sm);position:relative}
.stat .k{font-size:12px;color:var(--muted);font-weight:500}
.stat .v{font-size:27px;font-weight:800;color:var(--ink);margin-top:7px;letter-spacing:-.02em}
.stat .v.warn{color:var(--orange)}.stat .v.bad{color:var(--red)}.stat .v.good{color:var(--green)}
.stat .sub{font-size:12.5px;color:var(--muted);margin-top:3px}
.stat .ic{position:absolute;top:15px;right:15px;width:34px;height:34px;border-radius:10px;display:grid;place-items:center}
.stat .ic .ic-svg{width:18px;height:18px}
.ic-o{background:var(--orange-soft);color:var(--orange)}.ic-g{background:var(--green-soft);color:var(--green)}
.ic-r{background:var(--red-soft);color:var(--red)}.ic-b{background:var(--brand-soft);color:var(--brand)}

/* table */
.table-wrap{overflow-x:auto}
.tbl{width:100%;border-collapse:collapse;font-size:14px}
.tbl th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted-2);font-weight:700;padding:11px 16px;border-bottom:1px solid var(--line);white-space:nowrap}
.tbl td{padding:11px 16px;border-bottom:1px solid var(--line);color:var(--ink-2);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:rgba(255,255,255,.4)}
.tbl .name{font-weight:600;color:var(--ink)}
.tbl .mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;color:var(--muted)}
.tbl .num{text-align:right;font-variant-numeric:tabular-nums;font-weight:600}

/* pills */
.pill{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;padding:3px 10px;border-radius:999px;white-space:nowrap}
.pill.ok{background:var(--green-soft);color:var(--green)}
.pill.low{background:var(--orange-soft);color:var(--orange-dark)}
.pill.out{background:var(--red-soft);color:var(--red)}
.pill.in{background:var(--green-soft);color:var(--green)}
.pill.muted{background:rgba(20,28,50,.06);color:var(--muted)}
.pill.role{background:var(--brand-soft);color:#5648d6}
.pill.role.super{background:#fde7f0;color:#c01f63}
.pill.role.staff{background:rgba(20,28,50,.06);color:var(--muted)}
.pill.st-angefragt{background:var(--orange-soft);color:var(--orange-dark)}
.pill.st-unterwegs{background:var(--brand-soft);color:#5648d6}
.pill.st-abgeschlossen{background:var(--green-soft);color:var(--green)}
.tag{display:inline-block;font-size:12px;background:rgba(255,255,255,.6);border:1px solid var(--border);color:var(--ink-2);padding:2px 9px;border-radius:7px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:7px;font-weight:600;font-size:14px;padding:9px 15px;border-radius:10px;cursor:pointer;border:1px solid transparent;transition:transform .12s,box-shadow .15s,background .15s}
.btn .ic-svg{width:16px;height:16px}
.btn:active{transform:translateY(1px)}
.btn-o{background:var(--orange);color:#fff}.btn-o:hover{background:var(--orange-dark)}
.btn-light{background:rgba(255,255,255,.7);border-color:var(--border);color:var(--ink)}.btn-light:hover{background:#fff}
.btn-sm{padding:6px 12px;font-size:13px}

/* filters */
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;align-items:center}
.chip{font-size:13px;font-weight:500;padding:7px 13px;border-radius:999px;border:1px solid var(--border);background:rgba(255,255,255,.6);color:var(--ink-2);cursor:pointer}
.chip.on{background:var(--ink);color:#fff;border-color:var(--ink)}

.row-between{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px;flex-wrap:wrap}
.sec-sub{color:var(--muted);font-size:13.5px;margin-top:2px}
.empty{padding:38px;text-align:center;color:var(--muted)}

/* list rows */
.list-row{display:flex;align-items:center;gap:12px;padding:11px 18px;border-bottom:1px solid var(--line)}
.list-row:last-child{border-bottom:none}
.list-row .dot{width:8px;height:8px;border-radius:50%;flex:none}
.dot.in{background:var(--green)}.dot.out{background:var(--orange)}
.list-row .mn{flex:1;min-width:0}
.list-row .mn .t{font-weight:600;color:var(--ink);font-size:14px}
.list-row .mn .s{font-size:12.5px;color:var(--muted)}
.list-row .rt{text-align:right;font-size:12.5px;color:var(--muted);white-space:nowrap}

/* AI insight */
.ai-insight{background:linear-gradient(120deg,#fff4ea,#fdeef2 55%,#efeefe);border:1px solid var(--glass-brd);border-radius:var(--radius);padding:18px;display:flex;gap:14px;box-shadow:var(--shadow-sm)}
.ai-insight .ico{width:40px;height:40px;border-radius:11px;background:var(--grad);color:#fff;display:grid;place-items:center;flex:none}
.ai-insight .ico .ic-svg{width:21px;height:21px}
.ai-insight h3{font-size:15px;display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.ai-insight .ai-tag{font-size:10px;font-weight:700;letter-spacing:.05em;background:#fff;border:1px solid var(--border);color:var(--brand);padding:2px 8px;border-radius:999px}
.ai-insight p{margin:7px 0 0;font-size:13.5px;color:var(--ink-2)}
.ai-insight .acts{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}

/* scanner */
.scanner{max-width:520px;margin:0 auto;text-align:center}
.scan-frame{position:relative;aspect-ratio:4/3;background:#0e1320;border-radius:18px;overflow:hidden;display:grid;place-items:center;box-shadow:var(--shadow)}
.scan-frame .reticle{width:60%;height:46%;border:2px solid rgba(255,255,255,.5);border-radius:14px;position:relative}
.scan-frame .reticle::before,.scan-frame .reticle::after{content:"";position:absolute;left:-2px;right:-2px;height:30%;border:3px solid var(--orange);border-radius:14px}
.scan-frame .reticle::before{top:-2px;border-bottom:none}.scan-frame .reticle::after{bottom:-2px;border-top:none}
.scan-laser{position:absolute;left:19%;right:19%;height:2px;background:linear-gradient(90deg,transparent,#ff7a1a,transparent);animation:scan 2.4s ease-in-out infinite}
@keyframes scan{0%,100%{top:30%}50%{top:68%}}
.scan-hint{color:#aeb4ce;font-size:13px;position:absolute;bottom:14px;left:0;right:0}
.ro-note{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);background:rgba(255,255,255,.6);border:1px solid var(--border);padding:4px 11px;border-radius:999px}
.ro-note .ic-svg{width:13px;height:13px}

/* generic inline row (used outside .room too) */
.ritem{display:flex;align-items:center;gap:10px}
.ritem .nm{flex:1}

/* rooms (Behandlungszimmer) */
.rooms-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.room{padding:0;overflow:hidden}
.room .rh{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:16px 18px;border-bottom:1px solid var(--line)}
.room .rh .ti{font-weight:700;color:var(--ink);font-size:15.5px;display:flex;align-items:center;gap:9px}
.room .rh .ti .ic-svg{width:18px;height:18px;color:var(--orange)}
.room .rh .meta{font-size:12.5px;color:var(--muted);margin-top:3px}
.room .ritem{display:flex;align-items:center;gap:10px;padding:9px 18px;border-bottom:1px solid var(--line);font-size:13.5px}
.room .ritem:last-child{border-bottom:none}
.room .ritem .nm{flex:1;color:var(--ink-2)}
.room .ritem .qt{font-variant-numeric:tabular-nums;font-weight:600;color:var(--ink)}

/* messages */
.msg-item{display:flex;gap:13px;padding:15px 18px;border-bottom:1px solid var(--line);cursor:default}
.msg-item:last-child{border-bottom:none}
.msg-item.unread{background:rgba(255,122,26,.05)}
.msg-item .rt{width:38px;height:38px;border-radius:10px;background:var(--orange-soft);color:var(--orange-dark);display:grid;place-items:center;font-weight:700;font-size:13px;flex:none}
.msg-item .bd{flex:1;min-width:0}
.msg-item .route{font-size:12.5px;color:var(--muted);display:flex;align-items:center;gap:6px;margin-bottom:3px}
.msg-item .route .ic-svg{width:13px;height:13px}
.msg-item .route b{color:var(--ink-2);font-weight:600}
.msg-item .subj{font-weight:600;color:var(--ink);font-size:14.5px}
.msg-item .txt{color:var(--muted);font-size:13.5px;margin-top:2px}
.msg-item .when{font-size:12px;color:var(--muted-2);white-space:nowrap}
.unread-dot{width:8px;height:8px;border-radius:50%;background:var(--orange);flex:none;margin-top:6px}

/* settings */
.set-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 18px;border-bottom:1px solid var(--line)}
.set-row:last-child{border-bottom:none}
.set-row .lab{font-weight:600;color:var(--ink)}
.set-row .desc{font-size:12.5px;color:var(--muted);margin-top:2px}
.toggle{width:44px;height:26px;border-radius:999px;background:#d3d8e2;position:relative;flex:none;opacity:.75;cursor:not-allowed}
.toggle.on{background:var(--green)}
.toggle::after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:left .15s;box-shadow:0 1px 2px #0003}
.toggle.on::after{left:21px}
.inp-ro{background:rgba(255,255,255,.6);border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:14px;color:var(--muted);min-width:210px}

/* progress bar */
.bar{height:7px;background:rgba(20,28,50,.07);border-radius:999px;overflow:hidden}
.bar > span{display:block;height:100%;border-radius:999px}

/* toast */
.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;
  padding:11px 18px;border-radius:12px;font-size:14px;font-weight:600;box-shadow:0 12px 30px -8px rgba(20,28,50,.5);opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;z-index:200;display:flex;align-items:center;gap:9px}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast .ic-svg{width:16px;height:16px}

@media(max-width:900px){
  :root{--sidebar:0px}
  .shell{grid-template-columns:1fr}
  .sidebar{position:fixed;left:0;top:39px;bottom:0;width:268px;z-index:60;transform:translateX(-100%);transition:transform .22s;box-shadow:var(--shadow)}
  .sidebar.open{transform:none}
  .backdrop{position:fixed;inset:39px 0 0;background:rgba(20,28,50,.4);z-index:55;opacity:0;pointer-events:none;transition:opacity .2s}
  .backdrop.show{opacity:1;pointer-events:auto}
  .topbar .menu{display:grid;place-items:center}
  .cols-4{grid-template-columns:repeat(2,1fr)}
  .cols-3,.cols-2,.rooms-grid{grid-template-columns:1fr}
  .search{min-width:0;flex:1}
}
@media(max-width:520px){.cols-4{grid-template-columns:1fr}.content{padding:16px}.page-title{font-size:16px}}
