:root{
  --bg:#f8fbff;
  --bg-ink:#0d1433;
  --bg-grad:radial-gradient(1040px 560px at 92% -14%, rgba(37,99,235,0.10), transparent 64%),
    radial-gradient(900px 500px at -10% 0%, rgba(20,184,166,0.12), transparent 60%),
    linear-gradient(180deg, #ffffff 0%, #f8fbff 54%, #f4f9ff 100%);
  --surface:#ffffff;
  --surface-2:#f5f9ff;
  --surface-3:#f0fbf8;
  --ink:#0d1433;
  --muted:#5f6f88;
  --line:rgba(37,99,235,0.10);
  --accent:#2563eb;
  --accent-2:#3b82f6;
  --accent-3:#14b8a6;
  --accent-4:#e8b84c;
  --accent-5:#0ea5e9;
  --success:#2fbf71;
  --warning:#ff9f1c;
  --danger:#ef476f;
  --shadow:0 26px 64px rgba(37, 99, 235, 0.10);
  --shadow-soft:0 16px 38px rgba(37, 99, 235, 0.07);
  --radius-lg:20px;
  --radius-md:16px;
  --radius-sm:12px;
  --font-base:"Segoe UI",Arial,sans-serif;
  --font-display:"Segoe UI",Arial,sans-serif;

  --panel:var(--surface);
  --text:var(--ink);
  --accent-strong:#1d4ed8;
  --accent-weak:rgba(37,99,235,0.10);
  --font-size-base:16px;
  --line-height-base:1.6;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--font-base);
  font-size:var(--font-size-base);
  line-height:var(--line-height-base);
  background:var(--bg);
  color:var(--ink);
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  background:var(--bg-grad);
  z-index:-2;
}
body::after{
  content:none;
}

.app-shell{
  display:grid;
  grid-template-columns:260px 1fr;
  min-height:100dvh;
}
.app-side{
  position:sticky;
  top:0;
  height:100dvh;
  padding:20px 16px;
  display:flex;
  flex-direction:column;
  gap:18px;
  border-right:1px solid var(--line);
  background:rgba(255,255,255,0.86);
  backdrop-filter:blur(12px);
}
.app-brand{
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 14px;
  border-radius:var(--radius-md);
  background:linear-gradient(135deg, rgba(28,107,255,0.12), rgba(23,195,178,0.12));
  border:1px solid rgba(28,107,255,0.16);
  text-decoration:none;
  color:var(--ink);
}
.app-brand-logo{
  width:46px;
  height:46px;
  object-fit:contain;
}
.app-brand-text{
  display:flex;
  flex-direction:column;
  gap:2px;
}
.app-brand-title{
  font-family:var(--font-display);
  font-size:1.05rem;
  letter-spacing:.01em;
}
.app-brand-sub{
  font-size:.7rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted);
}
.app-nav{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.app-nav a{
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
  color:var(--ink);
  padding:12px 14px;
  border-radius:var(--radius-sm);
  border:1px solid transparent;
  background:linear-gradient(180deg, #ffffff, #f7f9ff);
  box-shadow:0 1px 0 rgba(14,20,43,0.05);
  font-size:0.98rem;
  line-height:1.2;
  font-weight:500;
  transition:box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.app-nav a:hover{
  border-color:rgba(28,107,255,0.25);
  box-shadow:0 10px 20px rgba(28,107,255,0.15);
}
.app-nav a.active{
  background:linear-gradient(135deg, var(--accent), #458cff);
  color:#fff;
  border-color:transparent;
  box-shadow:0 14px 26px rgba(28,107,255,0.3);
}
.app-nav a span{
  font-weight:500;
  letter-spacing:.01em;
}
.app-nav a svg{
  width:24px;
  height:24px;
  padding:6px;
  border-radius:10px;
  background:rgba(28,107,255,0.12);
  color:#1f4b82;
  flex-shrink:0;
  box-shadow:inset 0 0 0 1px rgba(28,107,255,0.12);
}
.app-nav a.active svg{
  background:rgba(255,255,255,0.25);
  color:#fff;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,0.35);
}
.app-side-footer{
  margin-top:auto;
  font-size:12px;
  color:var(--muted);
}

.app-body{
  display:flex;
  flex-direction:column;
  min-height:100dvh;
}
.app-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:22px 28px;
  background:rgba(255,255,255,0.9);
  border-bottom:1px solid var(--line);
  position:sticky;
  top:0;
  z-index:3;
  backdrop-filter:blur(8px);
}
.app-header-left h1{
  margin:0;
  font-size:1.8rem;
  font-family:var(--font-display);
  letter-spacing:.01em;
}
.app-header-left p{
  margin:6px 0 0;
  color:var(--muted);
  font-size:.98rem;
}
.app-header-right{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.app-actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.app-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  font-size:.86rem;
  background:var(--surface-3);
  border:1px solid rgba(246,189,96,0.35);
  color:#9a5b1f;
  font-weight:600;
}
.app-pill.app-pill-neutral{
  background:var(--surface-2);
  border-color:var(--line);
  color:var(--ink);
}
.app-button{
  border:none;
  padding:10px 14px;
  border-radius:12px;
  font-weight:700;
  cursor:pointer;
  font-family:var(--font-base);
}
.app-button.primary{
  background:linear-gradient(135deg, var(--accent-2), var(--accent-5));
  color:#fff;
  box-shadow:0 12px 24px rgba(37,99,235,0.18);
}
.app-button.secondary{
  background:#fff;
  border:1px solid var(--line);
  color:var(--ink);
}

.app-timeslicer{
  padding:18px 28px 0;
}
.timeslicer-card{
  border:1px solid var(--line);
  border-radius:var(--radius-md);
  background:rgba(255,255,255,0.9);
  backdrop-filter:blur(8px);
  box-shadow:var(--shadow-soft);
  padding:16px 18px;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.timeslicer-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.timeslicer-title{
  font-family:var(--font-display);
  font-size:1.1rem;
}
.timeslicer-sub{
  color:var(--muted);
  font-size:.9rem;
}
.timeslicer-pill{
  padding:6px 12px;
  border-radius:999px;
  background:var(--surface-2);
  border:1px solid var(--line);
  font-weight:700;
  font-size:.82rem;
}
.timeslicer-controls{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:12px;
}
.timeslicer-buttons{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.timeslicer-btn{
  border:1px solid var(--line);
  background:#fff;
  color:var(--ink);
  padding:8px 12px;
  border-radius:999px;
  font-weight:600;
  cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.timeslicer-btn:hover{
  border-color:rgba(28,107,255,0.25);
  box-shadow:0 8px 16px rgba(28,107,255,0.15);
}
.timeslicer-btn.active{
  background:linear-gradient(135deg, var(--accent), #458cff);
  color:#fff;
  border-color:transparent;
  box-shadow:0 12px 24px rgba(28,107,255,0.25);
}
.timeslicer-custom{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  color:var(--muted);
  font-size:.9rem;
}
.timeslicer-custom input{
  padding:7px 10px;
  border:1px solid var(--line);
  border-radius:10px;
  font:inherit;
  background:#fff;
  color:var(--ink);
}

.app-main{
  flex:1;
  width:100%;
}
.app-main .card{
  background:var(--surface);
  border-radius:var(--radius-md);
  border:1px solid var(--line);
  box-shadow:var(--shadow-soft);
}

/* Legacy shell layout (GFO pages) */
.shell{
  display:grid;
  grid-template-columns:240px 1fr;
  min-height:100dvh;
}
.side{
  position:sticky;
  top:0;
  height:100dvh;
  padding:16px 14px;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:12px;
  border-right:1px solid var(--line);
  background:#fff;
  backdrop-filter:none;
  box-shadow:none;
}
.side-head{
  display:grid;
  grid-template-columns:minmax(0, 1fr) 38px;
  align-items:center;
  gap:8px;
  width:100%;
}
.brand{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:0;
  width:100%;
  border-radius:0;
  background:transparent;
  border:none;
  box-shadow:none;
  text-decoration:none;
}
.brand img{
  width:176px;
  max-width:100%;
  height:auto;
  object-fit:contain;
  filter:none;
  opacity:1;
}
.side-collapse{
  width:38px;
  height:38px;
  border-radius:10px;
  border:1px solid rgba(37,99,235,0.16);
  background:linear-gradient(135deg, #ffffff, #eef7ff);
  color:#1d4ed8;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  box-shadow:0 8px 18px rgba(37,99,235,0.09);
}
.side-collapse svg{
  width:20px;
  height:20px;
  transition:transform .18s ease;
}
.side-footer{
  margin-top:auto;
  font-size:12px;
  color:var(--muted);
}
.app-version{
  display:flex;
  flex-direction:column;
  gap:2px;
  color:var(--muted);
  font-family:var(--font-base);
  line-height:1.35;
}
.app-version span{
  font-size:0.68rem;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.app-version strong{
  color:#334155;
  font-size:0.78rem;
  font-weight:700;
}
.app-version-sidebar{
  margin-top:auto;
  width:100%;
  padding:12px 10px 4px;
  border-top:1px solid rgba(37,99,235,0.10);
}
.app-version-page{
  display:none;
  margin-top:6px;
  padding-top:12px;
  border-top:1px solid rgba(37,99,235,0.10);
}
.nav{
  display:flex;
  flex-direction:column;
  gap:8px;
  width:100%;
  margin-top:6px;
}
.nav a{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  color:var(--ink, var(--text));
  width:100%;
  padding:10px 13px;
  border-radius:10px;
  border:1px solid rgba(15,23,42,0.08);
  background:#fff;
  box-shadow:none;
  font-size:0.94rem;
  line-height:1.2;
  font-weight:500;
  transition:box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.nav a:hover{
  border-color:rgba(28,107,255,0.28);
  box-shadow:none;
  background:#f8fafc;
}
.nav a.active{
  background:#eff6ff;
  color:#1d4ed8;
  border-color:#bfdbfe;
  box-shadow:none;
}
.nav a span{
  font-weight:500;
  letter-spacing:.01em;
}
.nav a svg{
  width:22px;
  height:22px;
  padding:5px;
  border-radius:10px;
  background:rgba(28,107,255,0.12);
  color:#1f4b82;
  flex-shrink:0;
  box-shadow:inset 0 0 0 1px rgba(28,107,255,0.12);
}
.nav a.active svg{
  background:#dbeafe;
  color:#1d4ed8;
  box-shadow:none;
}
.nav-group{
  width:100%;
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:4px 0 0;
}
.nav-group-title{
  padding-left:6px;
  font-size:0.68rem;
  text-transform:uppercase;
  letter-spacing:.16em;
  color:var(--muted);
}
.nav-sub{
  display:none;
  flex-direction:column;
  gap:8px;
  margin:0;
  padding-left:0;
}
.nav-sub.open{
  display:flex;
}
.nav-sub a{
  border-radius:16px;
  padding:10px 14px;
}
.nav-sub a svg{
  width:22px;
  height:22px;
  padding:5px;
  border-radius:9px;
}
header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:20px 24px;
  background:rgba(255,255,255,0.9);
  border:1px solid var(--line);
  border-radius:14px;
  margin:16px 20px 0;
  width:calc(100% - 40px);
  box-shadow:none;
  position:sticky;
  top:16px;
  z-index:2;
  backdrop-filter:blur(8px);
}
.topbar-left h1{
  margin:0;
  font-size:1.9rem;
  font-family:var(--font-display);
  letter-spacing:.01em;
}
.topbar-left p{
  margin:6px 0 0;
  color:var(--muted);
  font-size:1rem;
}
.topbar-actions{
  display:flex;
  align-items:center;
  gap:10px;
}
.timestamp-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  font-size:.86rem;
  background:var(--surface-2);
  border:1px solid var(--line);
  color:var(--muted);
  font-weight:600;
}
@media (max-width: 960px){
  .shell{grid-template-columns:1fr;}
  .side{
    position:relative;
    height:auto;
  }
  header{
    position:sticky;
    top:12px;
    margin:12px 14px 0;
    width:calc(100% - 28px);
  }
}

@media (max-width: 1200px){
  .app-shell{grid-template-columns:1fr;}
  .app-side{
    position:relative;
    height:auto;
    flex-direction:row;
    flex-wrap:wrap;
    justify-content:space-between;
  }
  .app-nav{flex-direction:row; flex-wrap:wrap;}
}
@media (max-width: 900px){
  .app-header{flex-direction:column; align-items:flex-start;}
  .app-timeslicer{padding:16px 20px 0;}
}
@media (max-width: 600px){
  .app-header{padding:18px 20px;}
  .timeslicer-card{padding:14px;}
}

.name-pair{display:flex; gap:8px;}
.name-pair input{flex:1; min-width:0;}
.action-icons{display:flex; align-items:center; justify-content:center; gap:8px;}
.action-copy{width:34px; height:34px; border-radius:8px; border:1px solid var(--line); background:linear-gradient(135deg, var(--accent-3), var(--accent-5)); color:#fff; font-weight:700; font-size:0.95rem;}
.action-copy:hover{box-shadow:0 8px 16px rgba(28,107,255,0.15);}
.row-hint{font-size:0.74rem; color:var(--muted);}
.month-input{
  width:58px;
  padding:6px 4px;
  border-radius:6px;
  font-size:0.85rem;
  text-align:center;
}
.qual-select{
  min-width:180px;
  border-radius:8px;
  border:1px solid var(--line);
  background:#fff;
  padding:6px 8px;
  font:inherit;
}
.action-icons{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:6px;
}
.action-icons button{
  width:34px;
  height:34px;
  border-radius:8px;
  border:none;
  font-size:1rem;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.action-icons button.action-hide{background:#eef2ff; color:#0f63ff;}
.action-icons button.action-trash{background:#fee2e2; color:#dc2626;}
.action-icons button.action-copy{background:linear-gradient(135deg, #0ea5e9, #14b8a6); color:#fff;}
.action-icons button:hover{opacity:0.85;}

/* Clinicon app unification layer */
.clinicon-app-light{
  background:var(--bg);
  color:var(--ink);
}
.clinicon-app-light .shell{
  grid-template-columns:272px minmax(0, 1fr);
  transition:grid-template-columns .18s ease;
}
.clinicon-app-light .side{
  width:auto;
  padding:18px 14px;
  background:
    linear-gradient(180deg, #ffffff 0, #ffffff 112px, rgba(248,252,255,0.97) 112px, rgba(248,252,255,0.97) 100%),
    radial-gradient(260px 220px at 18% 38%, rgba(59,130,246,0.12), transparent 62%),
    radial-gradient(240px 220px at 95% 78%, rgba(20,184,166,0.13), transparent 62%);
  border-right:1px solid rgba(37,99,235,0.09);
  box-shadow:10px 0 34px rgba(37,99,235,0.06);
  overflow:hidden;
}
.clinicon-app-light .side-head{
  background:#fff;
  border-radius:0 0 18px 18px;
  margin:-18px -14px 0;
  padding:18px 14px 12px;
  border-bottom:1px solid rgba(37,99,235,0.06);
}
.clinicon-app-light .brand{
  background:#fff;
}
.clinicon-app-light header{
  margin:16px 20px 0;
  width:calc(100% - 40px);
  border:1px solid rgba(37,99,235,0.10);
  border-radius:18px;
  box-shadow:0 16px 36px rgba(37,99,235,0.07);
  background:rgba(255,255,255,0.94);
}
.clinicon-app-light main,
.clinicon-app-light .page-wrap{
  width:100%;
  max-width:none;
  padding:24px;
  gap:18px;
}
.clinicon-app-light .card,
.clinicon-app-light .hero,
.clinicon-app-light .kpi-card,
.clinicon-app-light .status-grid,
.clinicon-app-light .quick-actions,
.clinicon-app-light .chart,
.clinicon-app-light .badge-rect,
.clinicon-app-light .timeslicer-card{
  background:rgba(255,255,255,0.94) !important;
  border:1px solid rgba(37,99,235,0.09) !important;
  border-radius:18px !important;
  box-shadow:0 18px 42px rgba(37,99,235,0.065) !important;
}
.clinicon-app-light .hero{
  background:linear-gradient(135deg, rgba(37,99,235,0.09), rgba(20,184,166,0.11) 72%, rgba(232,184,76,0.08)) !important;
}
.clinicon-app-light .nav a,
.clinicon-app-light .nav-toggle,
.clinicon-app-light .quick-links a{
  border:1px solid rgba(37,99,235,0.11);
  background:linear-gradient(135deg, rgba(255,255,255,0.96), rgba(248,252,255,0.94));
  border-radius:14px;
  transform:translateY(0);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.clinicon-app-light .side .nav{
  flex:0 0 auto;
  min-height:0;
  overflow-y:visible;
  overscroll-behavior:auto;
  padding-right:0;
}
.clinicon-app-light .app-version-sidebar{
  flex:0 0 auto;
  margin-top:0;
}
.clinicon-app-light .nav a:hover,
.clinicon-app-light .nav-toggle:hover,
.clinicon-app-light .quick-links a:hover{
  transform:translateY(-2px);
  border-color:rgba(37,99,235,0.24);
  box-shadow:0 14px 28px rgba(37,99,235,0.10);
  background:linear-gradient(135deg, rgba(239,246,255,0.98), rgba(236,253,245,0.92));
}
.clinicon-app-light .nav a.active{
  background:linear-gradient(135deg, rgba(37,99,235,0.18), rgba(14,165,233,0.15) 55%, rgba(20,184,166,0.16));
  color:#0f4bd8;
  border-color:rgba(37,99,235,0.28);
  box-shadow:0 15px 30px rgba(37,99,235,0.14);
}
.clinicon-app-light .nav a svg,
.clinicon-app-light .nav-toggle svg:not(.nav-caret){
  background:linear-gradient(135deg, #dbeafe, #ecfeff);
  color:#2563eb;
  box-shadow:inset 0 0 0 1px rgba(37,99,235,0.12);
}
.clinicon-app-light .nav a:nth-of-type(2) svg{background:linear-gradient(135deg,#e0f2fe,#eef2ff);color:#3b82f6;}
.clinicon-app-light .nav a:nth-of-type(3) svg{background:linear-gradient(135deg,#dbeafe,#ccfbf1);color:#2563eb;}
.clinicon-app-light .nav a:nth-of-type(4) svg{background:linear-gradient(135deg,#e0f2fe,#fef3c7);color:#0ea5e9;}
.clinicon-app-light .nav a:nth-of-type(5) svg{background:linear-gradient(135deg,#eef2ff,#dbeafe);color:#4f46e5;}
.clinicon-app-light .nav a:nth-of-type(6) svg{background:linear-gradient(135deg,#dcfce7,#e0f2fe);color:#0f766e;}
.clinicon-app-light .nav a:nth-of-type(7) svg{background:linear-gradient(135deg,#e0f2fe,#fef3c7);color:#0284c7;}
.clinicon-app-light .nav a:nth-of-type(8) svg{background:linear-gradient(135deg,#eef2ff,#e0f2fe);color:#2563eb;}
.clinicon-app-light .nav a:nth-of-type(9) svg{background:linear-gradient(135deg,#dbeafe,#f0fdf4);color:#0ea5e9;}
.clinicon-app-light .nav a.active svg{
  background:linear-gradient(135deg, #2563eb, #0ea5e9 58%, #14b8a6);
  color:#fff;
  box-shadow:0 8px 18px rgba(37,99,235,0.18), inset 0 1px 0 rgba(255,255,255,0.32);
}
.clinicon-app-light .nav-toggle{
  color:var(--ink);
}
.clinicon-app-light .nav-toggle[aria-expanded="true"]{
  background:linear-gradient(135deg, rgba(37,99,235,0.14), rgba(20,184,166,0.13));
  border-color:rgba(37,99,235,0.24);
}
.clinicon-app-light .button,
.clinicon-app-light .btn,
.clinicon-app-light .app-button,
.clinicon-app-light .controls button,
.clinicon-app-light .tabbar button{
  font-family:var(--font-base);
  border-radius:14px;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.clinicon-app-light .button:hover,
.clinicon-app-light .btn:hover,
.clinicon-app-light .app-button:hover,
.clinicon-app-light .controls button:hover,
.clinicon-app-light .tabbar button:hover{
  transform:translateY(-2px);
  box-shadow:0 16px 30px rgba(37,99,235,0.16);
}
.clinicon-app-light .button.primary,
.clinicon-app-light .btn:not(.secondary),
.clinicon-app-light .app-button.primary,
.clinicon-app-light .controls button{
  background:linear-gradient(135deg, #2563eb, #0ea5e9 58%, #14b8a6) !important;
  color:#fff !important;
  border:1px solid rgba(255,255,255,0.22) !important;
  box-shadow:0 14px 30px rgba(37,99,235,0.18), inset 0 1px 0 rgba(255,255,255,0.35) !important;
}

.clinicon-app-light.nav-collapsed .shell{
  grid-template-columns:76px minmax(0, 1fr);
}
.clinicon-app-light.nav-collapsed .side{
  padding-left:12px;
  padding-right:12px;
  align-items:center;
}
.clinicon-app-light.nav-collapsed .side-head{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.clinicon-app-light.nav-collapsed .brand img{
  width:42px;
}
.clinicon-app-light.nav-collapsed .side-collapse svg{
  transform:rotate(180deg);
}
.clinicon-app-light.nav-collapsed .nav a,
.clinicon-app-light.nav-collapsed .nav-toggle{
  width:46px;
  height:46px;
  padding:10px;
  justify-content:center;
}
.clinicon-app-light.nav-collapsed .nav a span,
.clinicon-app-light.nav-collapsed .nav-toggle span,
.clinicon-app-light.nav-collapsed .nav-caret,
.clinicon-app-light.nav-collapsed .nav-sub{
  display:none !important;
}
.clinicon-app-light.nav-collapsed .nav a svg,
.clinicon-app-light.nav-collapsed .nav-toggle svg:not(.nav-caret){
  margin:0;
}
.clinicon-app-light.nav-collapsed .app-version-sidebar{
  align-items:center;
  width:46px;
  padding:10px 0 0;
}
.clinicon-app-light.nav-collapsed .app-version-sidebar span{
  display:none;
}
.clinicon-app-light.nav-collapsed .app-version-sidebar strong{
  font-size:0;
}
.clinicon-app-light.nav-collapsed .app-version-sidebar strong::after{
  content:"v";
  font-size:0.78rem;
  color:var(--muted);
}
.clinicon-app-light .button.secondary,
.clinicon-app-light .btn.secondary,
.clinicon-app-light .app-button.secondary{
  background:linear-gradient(135deg, #eff6ff, #ecfeff) !important;
  color:#1d4ed8 !important;
  border:1px solid rgba(37,99,235,0.18) !important;
  box-shadow:0 10px 22px rgba(37,99,235,0.08) !important;
}
.clinicon-app-light .button.secondary:hover,
.clinicon-app-light .btn.secondary:hover,
.clinicon-app-light .app-button.secondary:hover{
  background:linear-gradient(135deg, #dbeafe, #ccfbf1) !important;
  border-color:rgba(37,99,235,0.28) !important;
}
.clinicon-app-light input,
.clinicon-app-light select,
.clinicon-app-light textarea{
  border:1px solid rgba(37,99,235,0.13);
  border-radius:12px;
  background:#fff;
  color:var(--ink);
  box-shadow:inset 0 1px 0 rgba(37,99,235,0.025);
}
.clinicon-app-light input:focus,
.clinicon-app-light select:focus,
.clinicon-app-light textarea:focus{
  outline:none;
  border-color:rgba(37,99,235,0.48);
  box-shadow:0 0 0 4px rgba(37,99,235,0.12);
}
.clinicon-app-light .table-wrap,
.clinicon-app-light .qual-table-wrap,
.app-table-scroll{
  width:100%;
  overflow:auto;
  border-radius:18px;
  border:1px solid rgba(37,99,235,0.09);
  background:#fff;
  -webkit-overflow-scrolling:touch;
  min-height:168px;
}
.clinicon-app-light .table-wrap table,
.clinicon-app-light .qual-table-wrap table,
.app-table-scroll table{
  min-width:760px;
}
.clinicon-app-light .section-hidden{
  display:none !important;
}
.clinicon-app-light .controls,
.clinicon-app-light .plan-actions,
.clinicon-app-light .topbar-actions{
  min-height:42px;
}
.clinicon-app-light .table-empty-row td,
.clinicon-app-light .app-empty-row td{
  height:86px;
  color:#64748b;
  background:linear-gradient(180deg, #fbfdff, #f7fafc) !important;
  text-align:center;
  font-weight:600;
}
.clinicon-app-light .app-placeholder-col{
  min-width:140px;
}
.clinicon-app-light thead th{
  background:linear-gradient(180deg, #f8fbff, #eef6ff) !important;
  color:#20304a;
}
.clinicon-app-light tbody tr:hover td{
  background:#f7fbff;
}
.clinicon-app-light .badge.ok,
.clinicon-app-light .status-ok{
  background:rgba(22,163,74,0.12);
  color:#137b3d;
}
.clinicon-app-light .badge.warn,
.clinicon-app-light .status-warn{
  background:rgba(244,183,64,0.18);
  color:#94600d;
}
.clinicon-app-light .badge.bad,
.clinicon-app-light .status-bad{
  background:rgba(239,71,111,0.13);
  color:#b91c1c;
}
.amchart-compat{
  min-height:180px;
}
.assistant-prep{
  display:grid;
  gap:14px;
  min-height:210px;
}
.assistant-prep__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}
.assistant-prep__head h3{
  margin:0 0 4px;
  font-family:var(--font-display);
}
.assistant-prep__head p{
  margin:0;
  color:var(--muted);
}
.assistant-prep__mic{
  width:52px;
  height:52px;
  border:0;
  border-radius:18px;
  color:#fff;
  background:linear-gradient(135deg, #2563eb, #0ea5e9 58%, #14b8a6);
  box-shadow:0 16px 30px rgba(37,99,235,0.18), inset 0 1px 0 rgba(255,255,255,0.35);
  cursor:pointer;
}
.assistant-prep__mic svg{
  width:24px;
  height:24px;
}
.assistant-prep__input{
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  gap:10px;
}
.assistant-prep__input input{
  min-width:0;
  padding:12px 14px;
}
.assistant-prep__answer{
  min-height:54px;
  border-radius:16px;
  border:1px solid rgba(37,99,235,0.12);
  background:linear-gradient(135deg, rgba(37,99,235,0.06), rgba(20,184,166,0.07));
  padding:14px;
  color:#46556d;
}
.clinicon-app-light #insightsDebug{
  max-height:120px;
  overflow:auto;
  padding:10px 12px;
  border-radius:12px;
  background:rgba(239,71,111,0.06);
  border:1px solid rgba(239,71,111,0.12);
}
.mobile-bottom-nav{
  display:none;
}
@media (max-width: 960px){
  .clinicon-app-light .shell{grid-template-columns:1fr;}
  .clinicon-app-light .side{
    display:none;
  }
  .clinicon-app-light header{
    top:10px;
    margin:12px;
    width:calc(100% - 24px);
    flex-wrap:wrap;
    align-items:flex-start;
    background:
      linear-gradient(135deg, rgba(255,255,255,0.98), rgba(239,246,255,0.94)),
      radial-gradient(260px 120px at 100% 0%, rgba(20,184,166,0.12), transparent 70%);
  }
  .clinicon-app-light .topbar-actions{
    flex:1 1 280px;
    justify-content:flex-end;
    min-width:0;
  }
  .clinicon-app-light .user-menu-btn{
    background:linear-gradient(135deg, #ffffff, #eff6ff);
    border-color:rgba(37,99,235,0.16);
  }
  .clinicon-app-light main,
  .clinicon-app-light .page-wrap{
    padding:18px 14px 92px;
  }
  .app-version-page{
    display:flex;
  }
  .mobile-bottom-nav{
    position:fixed;
    left:10px;
    right:10px;
    bottom:10px;
    z-index:20;
    display:grid;
    grid-template-columns:repeat(5, minmax(0, 1fr));
    gap:6px;
    padding:8px;
    border:1px solid rgba(15,23,42,0.10);
    border-radius:22px;
    background:rgba(255,255,255,0.94);
    box-shadow:0 18px 40px rgba(15,23,42,0.18);
    backdrop-filter:blur(14px);
  }
  .mobile-bottom-nav a{
    min-width:0;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:4px;
    text-decoration:none;
    color:#5f6f88;
    border-radius:16px;
    padding:8px 4px;
    font-size:0.68rem;
    line-height:1.1;
  }
  .mobile-bottom-nav a.active{
    color:#fff;
    background:linear-gradient(135deg, #2563eb, #14b8a6);
  }
  .mobile-bottom-nav svg{
    width:20px;
    height:20px;
    padding:3px;
  }
  .mobile-bottom-nav span{
    max-width:100%;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }
}
@media (max-width: 640px){
  .clinicon-app-light header{
    display:grid;
    grid-template-columns:1fr;
    align-items:start;
    gap:12px;
    border-radius:20px;
    padding:16px;
  }
  .clinicon-app-light .topbar-left h1{
    font-size:1.38rem;
  }
  .clinicon-app-light .topbar-left p{
    font-size:0.9rem;
    line-height:1.45;
  }
  .clinicon-app-light .topbar-actions{
    width:100%;
    display:grid;
    grid-template-columns:minmax(0, 1fr) auto;
    gap:10px;
    align-items:center;
  }
  .clinicon-app-light #refreshButton{
    display:none !important;
  }
  .clinicon-app-light .topbar-actions .app-button.primary{
    width:100%;
    min-height:44px;
    justify-content:center;
    padding:10px 14px;
    border-radius:14px;
  }
  .clinicon-app-light .user-menu-btn{
    width:54px;
    height:44px;
    justify-content:center;
    gap:0;
    padding:4px;
    border-radius:16px;
    background:linear-gradient(135deg, #dbeafe, #ccfbf1);
    box-shadow:0 12px 24px rgba(37,99,235,0.12);
  }
  .clinicon-app-light .user-menu-btn .user-text{
    display:none !important;
  }
  .clinicon-app-light .user-avatar{
    width:34px;
    height:34px;
  }
  .clinicon-app-light .user-caret{
    display:none;
  }
  .clinicon-app-light .kpi-grid,
  .clinicon-app-light .status-grid,
  .clinicon-app-light .grid-two,
  .clinicon-app-light .grid-three,
  .clinicon-app-light .table-grid,
  .clinicon-app-light .spotlight-row,
  .assistant-prep__input{
    grid-template-columns:1fr !important;
  }
  .assistant-prep__input .app-button{
    width:100%;
  }
}

@media (max-width: 420px){
  .clinicon-app-light .topbar-left p{
    display:none;
  }
  .clinicon-app-light .topbar-actions .app-button.primary{
    font-size:0;
  }
  .clinicon-app-light .topbar-actions .app-button.primary::after{
    content:"Export";
    font-size:0.92rem;
  }
}

/* Mobile app consolidation */
@media (max-width: 960px){
  html,
  body{
    max-width:100%;
  }
  body.clinicon-app-light{
    overflow-x:hidden;
  }
  .clinicon-app-light .shell{
    display:block;
    width:100%;
    min-width:0;
  }
  .clinicon-app-light .shell > div,
  .clinicon-app-light main,
  .clinicon-app-light .page-wrap,
  .clinicon-app-light section,
  .clinicon-app-light .card,
  .clinicon-app-light .hero,
  .clinicon-app-light .page-header,
  .clinicon-app-light .home-panel,
  .clinicon-app-light .table-card,
  .clinicon-app-light .insights-tab,
  .clinicon-app-light .insights-section{
    max-width:100%;
    min-width:0;
  }
  .clinicon-app-light header{
    z-index:30;
  }
  .clinicon-app-light h1,
  .clinicon-app-light h2,
  .clinicon-app-light h3,
  .clinicon-app-light p,
  .clinicon-app-light label,
  .clinicon-app-light .card-sub,
  .clinicon-app-light .hint{
    overflow-wrap:anywhere;
  }
  .clinicon-app-light .home-grid,
  .clinicon-app-light .lower-grid,
  .clinicon-app-light .actions-layout,
  .clinicon-app-light .grid-two,
  .clinicon-app-light .grid-three,
  .clinicon-app-light .table-grid,
  .clinicon-app-light .qual-visual-grid,
  .clinicon-app-light .hero-grid,
  .clinicon-app-light .insights-workspace-hero{
    grid-template-columns:minmax(0, 1fr) !important;
  }
  .clinicon-app-light .table-wrap,
  .clinicon-app-light .qual-table-wrap,
  .clinicon-app-light .dept-table-wrap,
  .clinicon-app-light .app-table-scroll,
  .clinicon-app-light [style*="overflow-x:auto"],
  .clinicon-app-light [style*="overflow-x: auto"]{
    width:100%;
    max-width:100%;
    overflow-x:auto !important;
    overflow-y:visible;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior-x:contain;
    scrollbar-width:thin;
  }
  .clinicon-app-light .table-wrap table,
  .clinicon-app-light .qual-table-wrap table,
  .clinicon-app-light .dept-table-wrap table,
  .clinicon-app-light .app-table-scroll table,
  .clinicon-app-light [style*="overflow-x:auto"] table,
  .clinicon-app-light [style*="overflow-x: auto"] table{
    width:max-content;
    max-width:none;
    table-layout:auto;
  }
  .clinicon-app-light .table-wrap::-webkit-scrollbar,
  .clinicon-app-light .qual-table-wrap::-webkit-scrollbar,
  .clinicon-app-light .dept-table-wrap::-webkit-scrollbar,
  .clinicon-app-light .app-table-scroll::-webkit-scrollbar{
    display:block;
    height:10px;
  }
  .clinicon-app-light .table-wrap::-webkit-scrollbar-thumb,
  .clinicon-app-light .qual-table-wrap::-webkit-scrollbar-thumb,
  .clinicon-app-light .dept-table-wrap::-webkit-scrollbar-thumb,
  .clinicon-app-light .app-table-scroll::-webkit-scrollbar-thumb{
    background:#c7d7ff;
    border-radius:999px;
  }
}

@media (max-width: 640px){
  .clinicon-app-light main,
  .clinicon-app-light .page-wrap{
    padding:16px 14px 104px !important;
  }
  .clinicon-app-light header{
    position:sticky;
    top:10px;
    width:calc(100% - 24px) !important;
    margin:12px !important;
    padding:16px !important;
    display:grid !important;
    grid-template-columns:minmax(0, 1fr);
    gap:12px;
  }
  .clinicon-app-light .topbar-left,
  .clinicon-app-light .topbar-actions,
  .clinicon-app-light .home-toolbar,
  .clinicon-app-light .home-title,
  .clinicon-app-light .home-controls,
  .clinicon-app-light .controls,
  .clinicon-app-light .plan-actions,
  .clinicon-app-light .filter-chip-row,
  .clinicon-app-light .tabbar,
  .clinicon-app-light .timeslicer-controls,
  .clinicon-app-light .timeslicer-buttons,
  .clinicon-app-light .timeslicer-custom,
  .clinicon-app-light .hero-meta,
  .clinicon-app-light .header-row,
  .clinicon-app-light .table-head,
  .clinicon-app-light .panel-head,
  .clinicon-app-light .edit-actions,
  .clinicon-app-light .modal-actions{
    width:100%;
    min-width:0;
  }
  .clinicon-app-light .home-toolbar,
  .clinicon-app-light .panel-head,
  .clinicon-app-light .table-head,
  .clinicon-app-light .header-row,
  .clinicon-app-light .hero-top,
  .clinicon-app-light .timeslicer-head{
    align-items:flex-start;
    flex-direction:column;
  }
  .clinicon-app-light .home-controls,
  .clinicon-app-light .controls,
  .clinicon-app-light .plan-actions,
  .clinicon-app-light .edit-actions,
  .clinicon-app-light .modal-actions{
    display:grid !important;
    grid-template-columns:minmax(0, 1fr);
    gap:10px;
    justify-content:stretch;
  }
  .clinicon-app-light .controls label,
  .clinicon-app-light .home-controls label,
  .clinicon-app-light .timeslicer-custom label{
    min-width:0 !important;
    width:100%;
  }
  .clinicon-app-light .controls input,
  .clinicon-app-light .controls select,
  .clinicon-app-light .controls button,
  .clinicon-app-light .home-select,
  .clinicon-app-light .home-button,
  .clinicon-app-light .plan-actions .btn,
  .clinicon-app-light .plan-actions .button,
  .clinicon-app-light .plan-actions button,
  .clinicon-app-light .filter-chip,
  .clinicon-app-light .tabbar button,
  .clinicon-app-light .timeslicer-btn,
  .clinicon-app-light .timeslicer-custom input,
  .clinicon-app-light .timeslicer-custom select,
  .clinicon-app-light .modal-actions .btn,
  .clinicon-app-light .edit-actions button{
    width:100%;
    max-width:100%;
    min-width:0 !important;
    justify-content:center;
  }
  .clinicon-app-light .home-button,
  .clinicon-app-light .controls button,
  .clinicon-app-light .plan-actions button,
  .clinicon-app-light .tabbar button{
    min-height:44px;
    white-space:normal;
  }
  .clinicon-app-light .home-kpis,
  .clinicon-app-light .kpi-grid,
  .clinicon-app-light .summary-grid,
  .clinicon-app-light .actions-kpis,
  .clinicon-app-light .status-grid,
  .clinicon-app-light .risk-breakdown,
  .clinicon-app-light .action-metrics,
  .clinicon-app-light .ai-grid,
  .clinicon-app-light .form-grid,
  .clinicon-app-light .profile-wrap,
  .clinicon-app-light .profil-wrap,
  .clinicon-app-light .hero-context-grid,
  .clinicon-app-light .hero-filter-grid,
  .clinicon-app-light .qual-row,
  .clinicon-app-light .trend-summary{
    grid-template-columns:minmax(0, 1fr) !important;
  }
  body[data-app-page="profil"] .profil-wrap,
  body[data-app-page="profil"] .profil-wrap > *,
  body[data-app-page="profil"] .profil-wrap > div,
  body[data-app-page="profil"] .info-grid,
  body[data-app-page="profil"] .info-row,
  body[data-app-page="profil"] .info-row-body{
    min-width:0 !important;
    max-width:100%;
  }
  body[data-app-page="profil"] .info-row{
    flex-wrap:wrap;
  }
  body[data-app-page="profil"] .info-row-body{
    flex:1 1 0;
  }
  body[data-app-page="profil"] .info-label,
  body[data-app-page="profil"] .info-value,
  body[data-app-page="profil"] .info-muted,
  body[data-app-page="profil"] .profile-name,
  body[data-app-page="profil"] .profile-email,
  body[data-app-page="profil"] .tenant-name,
  body[data-app-page="profil"] .tenant-code{
    max-width:100%;
    overflow-wrap:anywhere;
    word-break:break-word;
  }
  body[data-app-page="profil"] .btn-edit{
    width:100%;
    justify-content:center;
    margin-left:30px;
  }
  body[data-app-page="profil"] .toast{
    bottom:96px;
    max-width:calc(100vw - 28px);
    white-space:normal;
    text-align:center;
  }
  .clinicon-app-light .card,
  .clinicon-app-light .hero,
  .clinicon-app-light .home-panel{
    padding:18px !important;
  }
  .clinicon-app-light .hero h1,
  .clinicon-app-light .hero h2,
  .clinicon-app-light main h1,
  .clinicon-app-light main h2{
    font-size:clamp(1.45rem, 8vw, 2rem);
    line-height:1.15;
  }
  .clinicon-app-light .trend-chart,
  .clinicon-app-light .radar-wrap,
  .clinicon-app-light .chart,
  .clinicon-app-light .central-overview-chart,
  .clinicon-app-light .line-wide{
    max-width:100%;
    min-width:0;
  }
  .clinicon-app-light .radar-table{
    min-width:720px;
  }
  .clinicon-app-light .table-wrap table,
  .clinicon-app-light .app-table-scroll table{
    min-width:920px;
  }
  body[data-app-page="stellenplan"] .table-wrap table{
    min-width:1120px;
  }
  body[data-app-page^="stellenplan-dienstart"] .table-wrap table{
    min-width:1180px;
  }
  body[data-app-page="stellenplan-gesamt"] .dept-table-wrap table,
  body[data-app-page="stellenplan-gesamt"] .app-table-scroll table{
    min-width:1120px;
  }
  body[data-app-page="stellenplan-insights"] .qual-table-wrap table,
  body[data-app-page="stellenplan-insights"] .app-table-scroll table{
    min-width:760px;
  }
  body[data-app-page^="stellenplan-dienstart"] #planTable th:first-child,
  body[data-app-page^="stellenplan-dienstart"] #planTable td:first-child,
  body[data-app-page^="stellenplan-dienstart"] #extrasTable th:first-child,
  body[data-app-page^="stellenplan-dienstart"] #extrasTable td:first-child{
    position:sticky;
    left:0;
    z-index:4;
    min-width:100px;
    background:#fff;
  }
  body[data-app-page^="stellenplan-dienstart"] #planTable th:nth-child(2),
  body[data-app-page^="stellenplan-dienstart"] #planTable td:nth-child(2),
  body[data-app-page^="stellenplan-dienstart"] #extrasTable th:nth-child(2),
  body[data-app-page^="stellenplan-dienstart"] #extrasTable td:nth-child(2){
    position:sticky;
    left:100px;
    z-index:4;
    min-width:170px;
    background:#fff;
    box-shadow:1px 0 0 rgba(13,20,51,0.08);
  }
  body[data-app-page^="stellenplan-dienstart"] #planTable th:first-child,
  body[data-app-page^="stellenplan-dienstart"] #planTable th:nth-child(2),
  body[data-app-page^="stellenplan-dienstart"] #extrasTable th:first-child,
  body[data-app-page^="stellenplan-dienstart"] #extrasTable th:nth-child(2){
    z-index:6;
  }
  .mobile-bottom-nav{
    left:10px;
    right:10px;
    bottom:10px;
    z-index:1000;
    grid-template-columns:repeat(5, minmax(0, 1fr));
  }
  .mobile-bottom-nav a,
  .mobile-bottom-nav button{
    min-width:0;
    border:0;
    background:transparent;
    font:inherit;
    cursor:pointer;
  }
  .mobile-bottom-nav button{
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:4px;
    color:#5f6f88;
    border-radius:16px;
    padding:8px 4px;
    font-size:0.68rem;
    line-height:1.1;
  }
  .mobile-bottom-nav button.active,
  .mobile-bottom-nav button[aria-expanded="true"]{
    color:#fff;
    background:linear-gradient(135deg, #2563eb, #14b8a6);
  }
  .mobile-bottom-nav button svg{
    width:20px;
    height:20px;
    padding:3px;
  }
  .mobile-more-panel{
    position:fixed;
    left:10px;
    right:10px;
    bottom:92px;
    z-index:1001;
    max-height:calc(100dvh - 128px);
    overflow:auto;
    padding:10px;
    border:1px solid rgba(15,23,42,0.10);
    border-radius:20px;
    background:rgba(255,255,255,0.98);
    box-shadow:0 24px 58px rgba(15,23,42,0.20);
    backdrop-filter:blur(14px);
  }
  .mobile-more-panel[hidden]{
    display:none;
  }
  .mobile-more-panel a{
    display:flex;
    align-items:center;
    gap:10px;
    width:100%;
    padding:11px 12px;
    border-radius:14px;
    text-decoration:none;
    color:#1f2a44;
    font-weight:700;
  }
  .mobile-more-panel a.active{
    background:linear-gradient(135deg, rgba(37,99,235,0.14), rgba(20,184,166,0.12));
    color:#1d4ed8;
  }
  .mobile-more-panel a svg{
    width:20px;
    height:20px;
    flex:0 0 auto;
    color:#2563eb;
  }
  .mobile-more-dot{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:20px;
    height:20px;
    color:#2563eb;
    flex:0 0 auto;
  }
  .mobile-more-dot::before{
    content:"";
    width:6px;
    height:6px;
    border-radius:999px;
    background:currentColor;
  }
}

@media (max-width: 380px){
  .clinicon-app-light main,
  .clinicon-app-light .page-wrap{
    padding-left:10px !important;
    padding-right:10px !important;
  }
  .clinicon-app-light header{
    margin-left:10px !important;
    margin-right:10px !important;
    width:calc(100% - 20px) !important;
  }
  .mobile-bottom-nav,
  .mobile-more-panel{
    left:6px;
    right:6px;
  }
  .mobile-bottom-nav span{
    font-size:0.64rem;
  }
}

@media (prefers-reduced-motion: reduce){
  *,
  *::before,
  *::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    scroll-behavior:auto !important;
    transition-duration:.01ms !important;
  }
}
