@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Salesforce-style deep blue palette */
  --brand:#0176D3;--brand-dark:#014486;--brand-darker:#032D60;
  --brand-mid:#1B96FF;--brand-light:#E8F4FD;--brand-glow:rgba(1,118,211,.15);

  /* Semantic */
  --danger:#BA0517;--danger-light:#FEF1EE;--danger-border:#FEB8B0;
  --warn:#DD7A01;--warn-light:#FEF6E5;--warn-border:#FDD89A;
  --success:#2E844A;--success-light:#EEF4EF;--success-border:#A9D4B0;
  --info:#0176D3;--info-light:#E8F4FD;

  /* Neutrals */
  --ink:#032D60;--ink2:#16325C;
  --text:#181818;--text-2:#3E3E3C;--text-muted:#706E6B;--text-hint:#9EA0A5;
  --border:#DDDBDA;--border-light:#F3F2F2;
  --bg:#F3F2F2;--surface:#FFFFFF;--surface-2:#FAFAF9;--surface-3:#F3F2F2;

  /* Glass */
  --glass:rgba(255,255,255,0.72);--glass-border:rgba(255,255,255,0.8);
  --glass-shadow:0 8px 32px rgba(1,118,211,.08),0 2px 8px rgba(0,0,0,.04);

  /* Layout */
  --sidebar-w:64px;--sidebar-open:240px;
  --r:6px;--r-lg:12px;--r-xl:18px;--r-2xl:24px;

  /* Shadows */
  --shadow:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --shadow-md:0 4px 16px rgba(0,0,0,.08),0 2px 4px rgba(0,0,0,.04);
  --shadow-lg:0 12px 40px rgba(0,0,0,.10),0 4px 12px rgba(0,0,0,.06);
  --shadow-xl:0 24px 64px rgba(0,0,0,.12),0 8px 24px rgba(0,0,0,.06);
  --shadow-brand:0 4px 24px rgba(1,118,211,.25);
}

html{scroll-behavior:smooth}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  background:var(--bg);color:var(--text);font-size:13px;
  line-height:1.6;-webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(ellipse 80% 50% at 100% 0%, rgba(1,118,211,.06) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 0% 100%, rgba(1,118,211,.04) 0%, transparent 50%);
  background-attachment:fixed;
}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}

/* ── Layout ── */
.layout{display:flex;min-height:100vh}
.main{flex:1;min-width:0;display:flex;flex-direction:column;margin-left:var(--sidebar-w);transition:margin-left .25s cubic-bezier(.4,0,.2,1)}
.content-wrap{padding:28px 32px;flex:1}

/* ── Sidebar ── */
.sidebar{
  width:var(--sidebar-w);
  background:var(--brand-darker);
  display:flex;flex-direction:column;
  position:fixed;top:0;left:0;height:100vh;
  overflow:hidden;
  transition:width .25s cubic-bezier(.4,0,.2,1);
  z-index:100;
  box-shadow:4px 0 24px rgba(3,45,96,.2);
}
.sidebar:hover{width:var(--sidebar-open)}
.sidebar:hover~.main{margin-left:var(--sidebar-open)}

.sidebar-header{
  height:64px;display:flex;align-items:center;
  padding:0 16px;gap:12px;flex-shrink:0;
  border-bottom:1px solid rgba(255,255,255,.08);
  overflow:hidden;white-space:nowrap;
  background:rgba(0,0,0,.15);
}
.logo-mark{
  width:32px;height:32px;border-radius:8px;
  background:linear-gradient(135deg,var(--brand-mid),var(--brand));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:15px;font-weight:800;flex-shrink:0;
  box-shadow:0 2px 8px rgba(1,118,211,.4);
}
.logo-name{font-size:13px;font-weight:700;color:#fff;opacity:0;transition:opacity .15s .06s;white-space:nowrap}
.sidebar:hover .logo-name{opacity:1}

.sidebar-search{padding:10px 10px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}
.sidebar-search input{
  width:100%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);
  border-radius:7px;padding:7px 10px;font-size:12px;color:#fff;
  outline:none;opacity:0;transition:opacity .15s;font-family:inherit;
}
.sidebar:hover .sidebar-search input{opacity:1}
.sidebar-search input::placeholder{color:rgba(255,255,255,.4)}
.sidebar-search input:focus{border-color:rgba(27,150,255,.5);background:rgba(255,255,255,.1)}

.sidebar-nav{flex:1;padding:8px 8px;overflow-y:auto;overflow-x:hidden}
.sidebar-nav::-webkit-scrollbar{width:3px}
.sidebar-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:2px}

.nav-group-label{
  font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.35);padding:12px 8px 4px;
  white-space:nowrap;overflow:hidden;
  opacity:0;height:0;transition:opacity .15s;
}
.sidebar:hover .nav-group-label{opacity:1;height:auto}

.nav-item{
  display:flex;align-items:center;gap:10px;
  padding:0 8px;height:36px;border-radius:7px;
  color:rgba(255,255,255,.65);font-size:12px;font-weight:500;
  transition:all .12s;white-space:nowrap;overflow:hidden;
  cursor:pointer;margin-bottom:1px;
}
.nav-item:hover{background:rgba(255,255,255,.1);color:#fff;text-decoration:none}
.nav-item.active{background:rgba(27,150,255,.25);color:#fff;font-weight:600}
.nav-item.active .nav-icon{color:var(--brand-mid)}
.nav-icon{
  width:30px;height:30px;display:flex;align-items:center;justify-content:center;
  border-radius:6px;font-size:15px;flex-shrink:0;transition:background .12s;
}
.nav-item:hover .nav-icon{background:rgba(255,255,255,.08)}
.nav-item.active .nav-icon{background:rgba(27,150,255,.2)}
.nav-text{opacity:0;transition:opacity .15s .06s}
.sidebar:hover .nav-text{opacity:1}

.sidebar-footer{
  border-top:1px solid rgba(255,255,255,.08);
  padding:12px 10px;flex-shrink:0;
  background:rgba(0,0,0,.1);
}
.user-card{display:flex;align-items:center;gap:10px;overflow:hidden;white-space:nowrap}
.user-avatar{
  width:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg,var(--brand-mid),var(--brand));
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;flex-shrink:0;
  box-shadow:0 2px 6px rgba(1,118,211,.3);
}
.user-info{opacity:0;transition:opacity .15s .06s;overflow:hidden}
.sidebar:hover .user-info{opacity:1}
.user-name{font-size:12px;font-weight:600;color:#fff}
.user-role{font-size:11px;color:rgba(255,255,255,.45)}
.user-btns{display:flex;gap:4px;margin-top:8px;opacity:0;transition:opacity .15s;overflow:hidden}
.sidebar:hover .user-btns{opacity:1}
.user-btn{
  flex:1;display:flex;align-items:center;justify-content:center;gap:4px;
  padding:5px;border-radius:6px;font-size:11px;font-weight:500;
  color:rgba(255,255,255,.6);
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);
  transition:all .12s;text-decoration:none;
}
.user-btn:hover{background:rgba(255,255,255,.14);color:#fff;text-decoration:none}

/* ── Topbar ── */
.topbar{
  display:flex;align-items:center;gap:12px;
  background:var(--glass);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--glass-border);
  padding:0 32px;height:60px;
  position:sticky;top:0;z-index:40;
  box-shadow:0 1px 0 rgba(0,0,0,.06);
}
.topbar-title{font-size:15px;font-weight:700;color:var(--ink);flex:1}
.topbar-actions{display:flex;gap:8px;align-items:center}
.topbar-toggle{display:none;background:none;border:none;font-size:18px;cursor:pointer;color:var(--text-muted);padding:6px;border-radius:6px}
.topbar-toggle:hover{background:var(--surface-3)}

/* ── Glass Cards ── */
.card{
  background:var(--glass);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:1px solid var(--glass-border);
  border-radius:var(--r-xl);
  box-shadow:var(--glass-shadow);
  margin-bottom:20px;overflow:hidden;
  transition:box-shadow .2s,transform .2s;
}
.card:hover{box-shadow:0 12px 40px rgba(1,118,211,.1),0 2px 8px rgba(0,0,0,.05)}
.card-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;border-bottom:1px solid var(--border-light);gap:12px;
  background:rgba(255,255,255,.5);
}
.card-header h3{font-size:13px;font-weight:700;color:var(--ink);margin:0}
.card-footer{padding:12px 20px;border-top:1px solid var(--border-light);font-size:12px;color:var(--text-muted);background:rgba(255,255,255,.4)}
.card--danger{border-color:var(--danger-border)}
.card--danger .card-header{background:var(--danger-light)}
.card--warn{border-color:var(--warn-border)}

/* ── Buttons ── */
.btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 16px;border-radius:var(--r);font-size:12px;font-weight:600;
  border:1px solid transparent;cursor:pointer;
  transition:all .15s;text-decoration:none!important;white-space:nowrap;
  font-family:inherit;letter-spacing:.01em;
}
.btn-primary{
  background:linear-gradient(135deg,var(--brand-mid),var(--brand));
  color:#fff;border-color:var(--brand);
  box-shadow:var(--shadow-brand);
}
.btn-primary:hover{background:linear-gradient(135deg,#0095FF,var(--brand-mid));transform:translateY(-1px);box-shadow:0 6px 28px rgba(1,118,211,.35)}
.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}
.btn-danger:hover{background:#9E0418}
.btn-success{background:var(--success);color:#fff;border-color:var(--success)}
.btn-outline{
  background:var(--glass);color:var(--text-2);border-color:var(--border);
  backdrop-filter:blur(8px);box-shadow:var(--shadow);
}
.btn-outline:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-light)}
.btn-ghost{background:transparent;color:var(--text-muted);border-color:transparent}
.btn-ghost:hover{background:var(--surface-3);color:var(--text)}
.btn-sm{padding:4px 10px;font-size:11px;border-radius:5px}
.btn-lg{padding:11px 22px;font-size:14px;border-radius:8px}
.btn-full{width:100%;justify-content:center}

/* ── Stats ── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:24px}
.stat-card{
  background:var(--glass);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:1px solid var(--glass-border);
  border-radius:var(--r-xl);padding:18px 20px;
  display:flex;align-items:center;gap:14px;
  box-shadow:var(--glass-shadow);
  transition:all .2s;position:relative;overflow:hidden;
}
.stat-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--brand-mid),var(--brand));
  opacity:0;transition:opacity .2s;
}
.stat-card:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(1,118,211,.12)}
.stat-card:hover::before{opacity:1}
.stat-icon{font-size:24px;flex-shrink:0}
.stat-value{font-size:28px;font-weight:800;line-height:1;color:var(--ink);letter-spacing:-0.5px}
.stat-label{font-size:11px;color:var(--text-muted);margin-top:3px;font-weight:500}
.stat-card--warn{border-color:var(--warn-border);background:var(--warn-light)}
.stat-card--danger{border-color:var(--danger-border);background:var(--danger-light)}

/* ── Dashboard ── */
.dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:960px){.dash-grid{grid-template-columns:1fr}}
.quick-links{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:16px}
.quick-link{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  padding:14px 8px;border-radius:var(--r-lg);
  border:1px solid var(--border);
  background:var(--glass);backdrop-filter:blur(8px);
  font-size:11px;font-weight:600;color:var(--text-muted);
  transition:all .18s;text-align:center;cursor:pointer;
}
.quick-link span:first-child{font-size:20px}
.quick-link:hover{
  background:linear-gradient(135deg,var(--brand-light),rgba(27,150,255,.08));
  border-color:var(--brand);color:var(--brand);text-decoration:none;
  transform:translateY(-2px);box-shadow:var(--shadow-brand);
}
.quick-link--warn:hover{background:var(--warn-light);border-color:var(--warn);color:var(--warn);box-shadow:0 4px 16px rgba(221,122,1,.2)}

/* ── Tables ── */
.table{width:100%;border-collapse:collapse}
.table th{
  text-align:left;padding:10px 16px;
  font-size:11px;font-weight:700;color:var(--text-muted);
  border-bottom:1px solid var(--border);
  white-space:nowrap;text-transform:uppercase;letter-spacing:.06em;
  background:rgba(255,255,255,.6);backdrop-filter:blur(4px);
}
.table td{padding:11px 16px;border-bottom:1px solid var(--border-light);font-size:12px;vertical-align:middle}
.table-hover tbody tr{transition:background .1s}
.table-hover tbody tr:hover{background:rgba(1,118,211,.03)}
.table-sm th,.table-sm td{padding:8px 14px}
.table-scroll{overflow-x:auto}
.empty-state{padding:48px 20px;text-align:center;color:var(--text-muted);font-size:13px}
.row-danger td{background:rgba(186,5,23,.04)!important}
.row-warn td{background:rgba(221,122,1,.04)!important}

/* ── Badges ── */
.badge{display:inline-flex;align-items:center;font-size:11px;font-weight:600;padding:3px 9px;border-radius:99px;white-space:nowrap}
.badge-success{background:#D4EDDA;color:#1D6330}
.badge-danger{background:#FFDEDE;color:#8E0000}
.badge-warn{background:#FFF0CC;color:#7A4700}
.badge-info{background:#D0E9FF;color:#004F9A}
.badge-lg{font-size:12px;padding:4px 12px}

/* ── Alerts ── */
.alert{
  display:flex;align-items:center;justify-content:space-between;
  padding:11px 16px;border-radius:var(--r-lg);margin-bottom:16px;
  font-size:12px;font-weight:500;
  backdrop-filter:blur(8px);
}
.alert-success{background:var(--success-light);color:#1D6330;border:1px solid var(--success-border)}
.alert-danger{background:var(--danger-light);color:#8E0000;border:1px solid var(--danger-border)}
.alert-warning,.alert-warn{background:var(--warn-light);color:#7A4700;border:1px solid var(--warn-border)}
.alert-info{background:var(--info-light);color:#004F9A;border:1px solid #A8D0FF}
.alert-close{background:none;border:none;cursor:pointer;font-size:14px;opacity:.5;padding:0 4px}
.alert-close:hover{opacity:1}

/* ── Forms ── */
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:11px;font-weight:700;color:var(--text-muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:.05em}
.form-control{
  width:100%;padding:9px 12px;
  border:1px solid var(--border);border-radius:var(--r);
  font-size:12px;color:var(--text);
  background:rgba(255,255,255,.8);backdrop-filter:blur(4px);
  transition:all .15s;outline:none;font-family:inherit;
}
.form-control:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(1,118,211,.1);background:#fff}
.form-control:hover:not(:focus){border-color:#B0ADAB}
textarea.form-control{resize:vertical;min-height:72px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-actions{display:flex;gap:10px;margin-top:22px;padding-top:16px;border-top:1px solid var(--border-light)}
.form-card{padding:24px}
.form-card--sm{max-width:480px}
.form-section{
  border:1px solid var(--border);border-radius:var(--r-xl);
  padding:20px;margin-bottom:20px;
  background:var(--glass);backdrop-filter:blur(8px);
}
.form-section-title{font-size:13px;font-weight:700;margin-bottom:16px;display:flex;align-items:center;gap:8px;color:var(--ink)}
.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:12px;font-weight:500;color:var(--text-2)}
.checkbox-label input{width:14px;height:14px;cursor:pointer;accent-color:var(--brand)}
.checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px}
.filter-form{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:16px}
.form-control--sm{padding:5px 8px;font-size:11px}

/* ── Profile ── */
.profile-grid{display:grid;grid-template-columns:1fr 272px;gap:20px}
@media(max-width:900px){.profile-grid{grid-template-columns:1fr}}
.dl-grid{display:grid;grid-template-columns:130px 1fr;gap:8px 16px;padding:16px 20px;font-size:12px}
.dl-grid dt{font-weight:700;color:var(--text-muted);font-size:11px;text-transform:uppercase;letter-spacing:.04em;padding-top:1px}
.dl-grid dd{color:var(--text-2)}
.parent-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:14px 20px}
.parent-card{border:1px solid var(--border);border-radius:var(--r-lg);padding:12px;font-size:12px;background:rgba(255,255,255,.6);backdrop-filter:blur(4px)}
.parent-name{font-weight:700;margin-bottom:4px;color:var(--ink)}
.action-list{display:flex;flex-direction:column}
.action-item{padding:10px 16px;border-bottom:1px solid var(--border-light);font-size:12px;font-weight:500;color:var(--text-2);transition:background .1s}
.action-item:hover{background:var(--brand-light);text-decoration:none;color:var(--brand)}
.action-item--danger{color:var(--danger)}
.action-item--danger:hover{background:var(--danger-light);color:var(--danger)}
.consent-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}

/* ── Login ── */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}
.login-card{
  background:var(--glass);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border:1px solid var(--glass-border);
  border-radius:var(--r-2xl);padding:40px;width:100%;max-width:400px;
  box-shadow:var(--shadow-xl);
}
.login-logo{font-size:40px;text-align:center;margin-bottom:8px}
.login-title{text-align:center;font-size:20px;font-weight:800;margin-bottom:4px;color:var(--ink)}
.login-sub{text-align:center;color:var(--text-muted);font-size:12px;margin-bottom:24px}

/* ── Chat ── */
.chat-msg{display:flex;margin-bottom:2px}
.chat-msg--user{justify-content:flex-end}
.chat-bubble{max-width:82%;padding:10px 14px;border-radius:12px;font-size:12px;line-height:1.6;white-space:pre-wrap}
.chat-bubble--ai{background:var(--glass);border:1px solid var(--border);backdrop-filter:blur(8px)}
.chat-bubble--user{background:linear-gradient(135deg,var(--brand-mid),var(--brand));color:#fff}
.chat-bubble--error{background:var(--danger-light);border:1px solid var(--danger-border);color:var(--danger)}

/* ── Misc ── */
.text-muted{color:var(--text-muted)}
.mt-2{margin-top:12px}.mb-4{margin-bottom:20px}
.fee-summary{background:var(--brand-light);border-radius:var(--r-lg);padding:12px 16px;margin-bottom:20px;font-size:12px;display:flex;gap:20px;flex-wrap:wrap;border:1px solid rgba(1,118,211,.2)}
.scr-table{min-width:700px}.scr-cell{text-align:center}
.incident-text{padding:16px 20px;font-size:13px;line-height:1.7;white-space:pre-wrap;color:var(--text-2)}
.medical-warning{background:var(--warn-light);border:1px solid var(--warn-border);border-radius:var(--r-lg);padding:11px 14px;font-size:12px;margin-bottom:16px;color:#7A4700}
.checklist{list-style:none;padding:14px 20px}
.checklist li{padding:7px 0;border-bottom:1px solid var(--border-light);font-size:12px;display:flex;align-items:center;gap:8px;color:var(--text-2)}
.checklist li:last-child{border-bottom:none}
.check-pass::before{content:'✅'}.check-fail::before{content:'❌'}.check-warn::before{content:'⚠️'}.check-info::before{content:'📄'}
.sub-item{padding-left:24px;font-size:11px}
.file-current{background:var(--glass);border:1px solid var(--border);border-radius:var(--r);padding:9px 12px;font-size:12px;display:flex;align-items:center;gap:8px;margin-bottom:8px;backdrop-filter:blur(4px)}

/* ── Animations ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideIn{from{opacity:0;transform:translateX(-12px)}to{opacity:1;transform:translateX(0)}}
@keyframes scaleIn{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
.content-wrap>*{animation:fadeUp .4s ease both}
.content-wrap>*:nth-child(2){animation-delay:.06s}
.content-wrap>*:nth-child(3){animation-delay:.12s}
.content-wrap>*:nth-child(4){animation-delay:.18s}

/* ── Mobile ── */
@media(max-width:768px){
  .sidebar{transform:translateX(-100%);width:var(--sidebar-open)!important;transition:transform .25s}
  .sidebar.open{transform:translateX(0)}
  .main{margin-left:0!important}
  .topbar-toggle{display:block}
  .sidebar .logo-name,.sidebar .nav-text,.sidebar .nav-group-label,
  .sidebar .sidebar-search input,.sidebar .user-info,.sidebar .user-btns{opacity:1!important;height:auto!important}
  .form-row,.consent-grid,.parent-grid{grid-template-columns:1fr}
  .content-wrap{padding:16px}
  .topbar{padding:0 16px;height:52px}
  .stats-grid{grid-template-columns:1fr 1fr}
  .dash-grid{grid-template-columns:1fr}
}
