:root{--bg:#f6fef8;--panel:#ffffff;--primary:#22c55e;--primary-600:#16a34a;--primary-700:#0f7a37;--text:#0f172a;--muted:#64748b;--border:#e5e7eb;--card:#ffffff;--success:#16a34a;--danger:#dc2626;--warn:#f59e0b;--shadow:0 8px 24px rgba(2, 6, 23, .08);--ring:0 0 0 3px rgba(22,101,52,.15)}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.6}
.layout{min-height:100vh;display:flex}
.sidebar{width:260px;background:var(--panel);border-right:1px solid var(--border);padding:20px;position:sticky;top:0;height:100vh;height:100dvh;display:flex;flex-direction:column;box-shadow:var(--shadow);z-index:40}
.brand{font-weight:800;font-size:20px;margin-bottom:18px;color:var(--text);letter-spacing:.2px;flex-shrink:0}
.user-pill{font-size:12px;color:var(--muted);margin-bottom:18px}
.nav{display:flex;flex-direction:column;gap:6px;flex:1;overflow-y:auto;padding-right:10px;margin-right:-10px;-webkit-overflow-scrolling:touch}
.nav::-webkit-scrollbar{width:6px}
.nav::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}
.nav-group-title{font-size:11px;color:#6b7280;margin:18px 0 8px;padding-top:10px;border-top:1px solid var(--border);text-transform:uppercase;letter-spacing:.6px;display:flex;align-items:center;justify-content:space-between;user-select:none;flex-shrink:0}
.nav-group-title .nav-caret{font-size:12px;color:#94a3b8}
.nav-group-title.collapsed .nav-caret{transform:rotate(0deg)}
.nav-group{display:flex;flex-direction:column;gap:6px;overflow:hidden;transition:height .2s ease;flex-shrink:0}
.sidebar-controls{display:flex;gap:8px;margin-bottom:10px}
.btn.small{padding:6px 10px;font-size:12px;border-radius:10px}
.nav .nav-group-title:first-of-type{border-top:none;padding-top:0;margin-top:0}
.nav a{display:flex;align-items:center;gap:10px;padding:10px 12px;margin:2px 0;border-radius:12px;color:var(--text);text-decoration:none;border:1px solid var(--border);background:#fff;transition:all .15s ease;flex-shrink:0}
.nav a:hover{background:#ecfdf5;border-color:#bbf7d0;transform:translateY(-1px)}
.nav a.active{background:#ecfdf5;border-color:#86efac;box-shadow:0 2px 8px rgba(34,197,94,.12)}
.sidebar-bottom{margin-top:12px;border-top:1px solid var(--border);padding-top:12px;flex-shrink:0}
.sidebar-bottom .muted{font-size:12px;color:var(--muted);margin-bottom:8px}
.content{flex:1;padding:24px;background:var(--bg)}
.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.card{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:18px;box-shadow:var(--shadow);transition:transform .15s ease, box-shadow .15s ease}
.card:hover{transform:translateY(-1px)}
.grid{display:grid;gap:12px}
.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid.resp{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
label{display:block;font-size:12px;color:var(--muted);margin-bottom:6px;font-weight:600}
input,select,textarea{width:100%;padding:12px;background:#fff;color:var(--text);border:1px solid var(--border);border-radius:12px;outline:none;transition:border-color .15s ease, box-shadow .15s ease}
input::placeholder,textarea::placeholder{color:#94a3b8}
input:focus,select:focus,textarea:focus{border-color:#166534;box-shadow:var(--ring)}
.input-error{border-color:#dc2626}
.cbt-choices{display:grid;gap:6px}
.cbt-choice{display:inline-flex;align-items:center;gap:6px;margin:0;padding:0;cursor:pointer}
input[type=radio],input[type=checkbox]{width:auto;height:auto;padding:0;margin:0;appearance:auto;-webkit-appearance:auto;vertical-align:middle;box-shadow:none}
input[type=radio]{accent-color:var(--primary-600)}
.cbt-layout{display:grid;grid-template-columns:3fr 1fr;gap:18px}
.cbt-nav .btn{padding:6px;border-radius:8px;font-size:12px}
@media (max-width: 700px){
  .cbt-layout{grid-template-columns:3fr 1fr}
  #q-nav{grid-template-columns:repeat(4,1fr) !important}
}
.row{display:flex;gap:12px;align-items:center}
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:12px;border:1px solid transparent;background:var(--primary);color:#fff;text-decoration:none;cursor:pointer;transition:transform .12s ease, box-shadow .12s ease, background .12s ease}
.btn:hover{background:var(--primary-600);transform:translateY(-1px);box-shadow:0 6px 16px rgba(34,197,94,.2)}
.btn.secondary{background:#fff;border-color:var(--border);color:var(--text)}
.btn.success{background:var(--success)}
.btn.danger{background:var(--danger)}
.btn.warn{background:var(--warn);color:#000}
.btn.outline{background:transparent;color:var(--primary);border-color:#86efac}
.btn.outline:hover{background:#ecfdf5}
.toolbar{display:flex;gap:10px;flex-wrap:wrap}
.table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border:1px solid var(--border);border-radius:12px;overflow:hidden}
.table th,.table td{border-bottom:1px solid var(--border);padding:12px}
.table th{color:var(--muted);font-weight:700;background:#f8fafc;position:sticky;top:0;z-index:1}
.table tr:hover td{background:#f9fafb}
.avatar{width:96px;height:96px;border-radius:12px;object-fit:cover;border:1px solid var(--border);background:#f8fafc}
.toast{position:fixed;top:16px;right:16px;z-index:1000;display:none;max-width:360px}
.toast.show{display:block}
.toast .item{background:#fff;border:1px solid var(--border);border-left:4px solid var(--danger);padding:12px 14px;border-radius:12px;color:var(--text);box-shadow:var(--shadow)}
.toast .item.success{border-left-color:var(--success)}
.toast .item.warn{border-left-color:var(--warn)}
.section-title{font-size:16px;color:#1f2937;margin:8px 0;font-weight:700}
.hero{padding:18px;border-radius:12px;background:#ecfdf5;border:1px solid #bbf7d0}
.split{display:grid;grid-template-columns:240px 1fr;gap:18px}
/* Sidebar dynamic */
.sidebar-hidden .sidebar{display:none}
@media (max-width: 900px){
  .layout{display:block}
  .sidebar{position:fixed;left:0;top:0;bottom:0;transform:translateX(-100%);transition:transform .2s ease-in-out;z-index:50}
  .sidebar.open{transform:translateX(0)}
  .content{padding:18px}
  .split{grid-template-columns:1fr}
}
/* Tabs */
.tabs{display:flex;gap:8px;border-bottom:1px solid var(--border);overflow:auto;padding-bottom:4px}
.tab{padding:10px 12px;border:1px solid var(--border);border-bottom:none;background:#f8fafc;color:var(--text);border-radius:12px 12px 0 0;cursor:pointer;white-space:nowrap;transition:background .12s ease}
.tab:hover{background:#ecfdf5}
.tab.active{background:#fff;border-color:#86efac}
.tab-panels{padding-top:12px}
.panel{display:none}
.panel.active{display:block}
.mood-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.mood-grid input[type=radio]{position:absolute;opacity:0;width:0;height:0}
.mood-option{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:14px;border:2px solid var(--border);border-radius:16px;background:#fff;cursor:pointer;font-weight:600;color:#374151;font-size:14px;transition:border-color .12s ease, background .12s ease, transform .12s ease}
.mood-option:hover{border-color:#86efac;background:#f0fdf4}
.mood-option .emoji{font-size:44px;line-height:1}
.mood-grid input[type=radio]:checked + .mood-option{border-color:#34d399;background:#ecfdf5;box-shadow:0 0 0 2px #bbf7d0 inset}
.icon{display:inline-flex;align-items:center;justify-content:center;width:20px}
.menu-label{display:flex;align-items:center;gap:8px}
.field-inline{position:relative;display:inline-block}
.field-inline input[type=date]{padding-right:120px}
.inline-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:6px;font-size:12px;color:#334155;user-select:none}
/* Responsive tables */
.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
.table.wide{min-width:960px}
.nowrap{white-space:nowrap}
@media (max-width: 600px){
  .table.wide{min-width:640px}
  .table th,.table td{padding:10px}
}
@media (min-width: 1200px){
  .table.wide{min-width:1100px}
}
.dashboard-hero{padding:22px;border-radius:16px;background:linear-gradient(135deg,#ecfdf5,#ffffff);border:1px solid #bbf7d0;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;box-shadow:var(--shadow)}
.dashboard-hero .title{font-size:22px;font-weight:800;color:#166534}
.dashboard-hero .subtitle{color:#334155}
.kpi-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.kpi-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.kpi{background:#fff;border:1px solid var(--border);border-radius:16px;padding:14px;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow)}
.kpi .meta{display:flex;flex-direction:column;gap:4px}
.kpi .label{color:#64748b;font-size:12px}
.kpi .value{font-size:28px;font-weight:800;color:#166534}
.kpi .icon{width:36px;height:36px;border-radius:12px;background:#ecfdf5;border:1px solid #bbf7d0}
.dashboard-columns{display:grid;grid-template-columns:2fr 1fr;gap:12px}
.mini-list{display:flex;flex-direction:column;gap:8px}
.mini-item{display:flex;justify-content:space-between;gap:10px;padding:10px;border:1px solid var(--border);border-radius:12px;background:#fff;box-shadow:var(--shadow)}
.badge{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;background:#ecfdf5;color:#166534;border:1px solid #bbf7d0;font-size:12px}
.progress{height:8px;background:#f1f5f9;border-radius:999px;overflow:hidden}
.progress > div{height:100%;background:#34d399}
@media (max-width: 900px){
  .kpi-cards{grid-template-columns:repeat(2,minmax(0,1fr))}
  .dashboard-columns{grid-template-columns:1fr}
  .quick-actions .btn{margin:4px 0 !important}
}
.avatar-lg{width:96px;height:96px;border-radius:16px;object-fit:cover;border:1px solid var(--border);background:#f8fafc}
.quick-actions{display:flex;flex-wrap:wrap;gap:10px}
.quick-actions .btn{width:auto;justify-content:center;margin:0;white-space:nowrap}
.dashboard-hero{gap:16px}
@media (max-width: 900px){
  .quick-actions{gap:12px}
  .quick-actions .btn{margin:12px 0}
}
@media (max-width: 600px){
  .content{padding:14px}
  .card{padding:14px}
  .dashboard-hero{flex-direction:column;align-items:flex-start}
  .dashboard-hero .title{font-size:18px}
  .avatar-lg{width:72px;height:72px}
  .kpi-cards{grid-template-columns:1fr;gap:12px}
  .kpi .value{font-size:22px}
  .quick-actions{gap:10px !important;flex-direction:column !important}
  .quick-actions .btn{width:100% !important; margin:4px 0 !important}
  .grid.resp{grid-template-columns:1fr !important}
  .mini-item{flex-direction:column;align-items:flex-start;gap:6px}
  .table th,.table td{font-size:13px}
}
.card + .card{margin-top:12px}
.kpi-cards + .card{margin-top:12px}
.row{gap:12px}
.rating-group{display:flex;gap:6px;align-items:center}
.rating-group label{display:inline-flex;align-items:center;gap:4px}
