@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

:root{color-scheme:light;--accent:#10b981;--accent-hover:#059669;--accent-ink:#047857;--accent-soft:#ecfdf5;--accent-wash:rgba(16,185,129,.1);--accent-border:rgba(16,185,129,.25);--ink:#18181b;--muted:#71717a;--line:#e4e4e7;--panel:#fff;--soft:#f4f4f5;--paper:#fafaf9;--amber:#f59e0b;--cyan:#0891b2;--shell-wash:rgba(16,185,129,.06);--sidebar-bg:rgba(255,255,255,.78);--topbar-bg:rgba(248,250,252,.84);--dock-bg:rgba(255,255,255,.94);--shadow-sm:rgba(15,23,42,.04);--shadow-md:rgba(15,23,42,.08);--shadow-lg:rgba(15,23,42,.16);--success-soft:#ecfdf5;--success-ink:#047857;--danger-soft:#fef2f2;--danger-ink:#b91c1c;--danger-border:#fecaca;--warning-soft:rgba(245,158,11,.12);--warning-ink:#b45309;--info-soft:rgba(8,145,178,.08);--blue-soft:rgba(37,99,235,.11);--blue-ink:#1d4ed8}
html[data-theme="nord"]{color-scheme:dark;--accent:#88c0d0;--accent-hover:#81a1c1;--accent-ink:#8fbcbb;--accent-soft:rgba(136,192,208,.16);--accent-wash:rgba(136,192,208,.13);--accent-border:rgba(136,192,208,.34);--ink:#eceff4;--muted:#d8dee9;--line:#4c566a;--panel:#3b4252;--soft:#434c5e;--paper:#2e3440;--amber:#ebcb8b;--cyan:#8fbcbb;--shell-wash:rgba(136,192,208,.08);--sidebar-bg:rgba(46,52,64,.88);--topbar-bg:rgba(46,52,64,.9);--dock-bg:rgba(46,52,64,.95);--shadow-sm:rgba(0,0,0,.12);--shadow-md:rgba(0,0,0,.24);--shadow-lg:rgba(0,0,0,.34);--success-soft:rgba(163,190,140,.16);--success-ink:#a3be8c;--danger-soft:rgba(191,97,106,.18);--danger-ink:#bf616a;--danger-border:rgba(191,97,106,.38);--warning-soft:rgba(235,203,139,.16);--warning-ink:#ebcb8b;--info-soft:rgba(136,192,208,.14);--blue-soft:rgba(129,161,193,.16);--blue-ink:#81a1c1}
html[data-theme="dracula"]{color-scheme:dark;--accent:#bd93f9;--accent-hover:#a87ff0;--accent-ink:#bd93f9;--accent-soft:rgba(189,147,249,.17);--accent-wash:rgba(189,147,249,.13);--accent-border:rgba(189,147,249,.34);--ink:#f8f8f2;--muted:#c8c8d4;--line:#4c4f63;--panel:#343746;--soft:#44475a;--paper:#282a36;--amber:#f1fa8c;--cyan:#8be9fd;--shell-wash:rgba(189,147,249,.08);--sidebar-bg:rgba(40,42,54,.9);--topbar-bg:rgba(40,42,54,.9);--dock-bg:rgba(40,42,54,.95);--shadow-sm:rgba(0,0,0,.14);--shadow-md:rgba(0,0,0,.28);--shadow-lg:rgba(0,0,0,.38);--success-soft:rgba(80,250,123,.16);--success-ink:#50fa7b;--danger-soft:rgba(255,85,85,.17);--danger-ink:#ff6e6e;--danger-border:rgba(255,85,85,.38);--warning-soft:rgba(241,250,140,.14);--warning-ink:#f1fa8c;--info-soft:rgba(139,233,253,.13);--blue-soft:rgba(139,233,253,.14);--blue-ink:#8be9fd}
html[data-theme="one-dark"]{color-scheme:dark;--accent:#61afef;--accent-hover:#528bff;--accent-ink:#61afef;--accent-soft:rgba(97,175,239,.16);--accent-wash:rgba(97,175,239,.12);--accent-border:rgba(97,175,239,.34);--ink:#abb2bf;--muted:#8b93a5;--line:#4b5263;--panel:#2f343d;--soft:#3a404c;--paper:#282c34;--amber:#e5c07b;--cyan:#56b6c2;--shell-wash:rgba(97,175,239,.07);--sidebar-bg:rgba(40,44,52,.9);--topbar-bg:rgba(40,44,52,.9);--dock-bg:rgba(40,44,52,.95);--shadow-sm:rgba(0,0,0,.14);--shadow-md:rgba(0,0,0,.26);--shadow-lg:rgba(0,0,0,.38);--success-soft:rgba(152,195,121,.16);--success-ink:#98c379;--danger-soft:rgba(224,108,117,.16);--danger-ink:#e06c75;--danger-border:rgba(224,108,117,.36);--warning-soft:rgba(229,192,123,.14);--warning-ink:#e5c07b;--info-soft:rgba(86,182,194,.13);--blue-soft:rgba(97,175,239,.14);--blue-ink:#61afef}
html[data-theme="tokyo-night"]{color-scheme:dark;--accent:#7aa2f7;--accent-hover:#2ac3de;--accent-ink:#7dcfff;--accent-soft:rgba(122,162,247,.16);--accent-wash:rgba(122,162,247,.12);--accent-border:rgba(122,162,247,.34);--ink:#c0caf5;--muted:#9aa5ce;--line:#414868;--panel:#24283b;--soft:#2f3549;--paper:#1a1b26;--amber:#e0af68;--cyan:#7dcfff;--shell-wash:rgba(122,162,247,.07);--sidebar-bg:rgba(26,27,38,.9);--topbar-bg:rgba(26,27,38,.9);--dock-bg:rgba(26,27,38,.95);--shadow-sm:rgba(0,0,0,.14);--shadow-md:rgba(0,0,0,.28);--shadow-lg:rgba(0,0,0,.4);--success-soft:rgba(158,206,106,.16);--success-ink:#9ece6a;--danger-soft:rgba(247,118,142,.16);--danger-ink:#f7768e;--danger-border:rgba(247,118,142,.36);--warning-soft:rgba(224,175,104,.14);--warning-ink:#e0af68;--info-soft:rgba(125,207,255,.13);--blue-soft:rgba(122,162,247,.14);--blue-ink:#7aa2f7}
html[data-theme="gruvbox"]{color-scheme:dark;--accent:#b8bb26;--accent-hover:#98971a;--accent-ink:#b8bb26;--accent-soft:rgba(184,187,38,.16);--accent-wash:rgba(184,187,38,.12);--accent-border:rgba(184,187,38,.34);--ink:#ebdbb2;--muted:#a89984;--line:#665c54;--panel:#3c3836;--soft:#504945;--paper:#282828;--amber:#fabd2f;--cyan:#83a598;--shell-wash:rgba(184,187,38,.07);--sidebar-bg:rgba(40,40,40,.9);--topbar-bg:rgba(40,40,40,.9);--dock-bg:rgba(40,40,40,.95);--shadow-sm:rgba(0,0,0,.14);--shadow-md:rgba(0,0,0,.28);--shadow-lg:rgba(0,0,0,.4);--success-soft:rgba(184,187,38,.16);--success-ink:#b8bb26;--danger-soft:rgba(251,73,52,.16);--danger-ink:#fb4934;--danger-border:rgba(251,73,52,.36);--warning-soft:rgba(250,189,47,.15);--warning-ink:#fabd2f;--info-soft:rgba(131,165,152,.13);--blue-soft:rgba(131,165,152,.14);--blue-ink:#83a598}
*{box-sizing:border-box}
body{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-size:14px;letter-spacing:0;background:var(--paper);color:var(--ink);overflow-x:hidden}
button,input,textarea,select{font:inherit}
label{display:block;margin-bottom:6px;font-size:11px;font-weight:700;text-transform:uppercase;color:var(--muted)}
input,textarea,select{width:100%;border:1px solid var(--line);border-radius:8px;background:var(--panel);color:var(--ink);padding:10px 12px;outline:none}
input[type="range"]{accent-color:var(--accent);padding:0;background:transparent}
input[type="checkbox"]{width:auto;accent-color:var(--accent)}
textarea{resize:vertical}
input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 22%,transparent)}
.hidden{display:none!important}
.auth-shell{min-height:100vh;display:grid;place-items:center;padding:16px}
.auth-card{width:min(calc(100vw - 32px),280px);background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:24px;box-shadow:0 20px 50px var(--shadow-md)}
.brand-lockup{display:flex;align-items:center;gap:12px;margin-bottom:26px}
.brand-lockup h1{margin:0;font-size:17px;font-weight:800;line-height:1}
.brand-lockup p{margin:4px 0 0;color:var(--muted);font-size:12px}
.brand-mark{width:38px;height:38px;border-radius:8px;background:var(--accent);color:white;display:grid;place-items:center;box-shadow:0 12px 24px color-mix(in srgb,var(--accent) 24%,transparent)}
.brand-mark svg{width:20px;height:20px}
.quiet-link{display:block;margin:18px auto 0;color:var(--muted);font-size:13px}
.form-error{font-size:13px;color:#dc2626}
.app-shell{min-height:100vh;display:grid;grid-template-columns:240px minmax(0,1fr) 360px;background:linear-gradient(180deg,var(--shell-wash),transparent 260px),var(--paper)}
.sidebar{position:sticky;top:0;height:100vh;border-right:1px solid var(--line);background:var(--sidebar-bg);backdrop-filter:blur(18px);padding:18px 14px;display:flex;flex-direction:column;z-index:20}
.dark .sidebar{background:var(--sidebar-bg)}
.sidebar-brand{margin:0 4px 22px}
.nav-list{display:grid;gap:4px}
.nav-item{display:flex;align-items:center;gap:10px;padding:8px 9px;border-radius:8px;color:var(--muted);font-weight:700}
.nav-icon{width:30px;height:30px;border:1px solid transparent;border-radius:8px;display:grid;place-items:center;color:var(--muted);background:transparent;transition:.15s ease}
.nav-icon svg{width:16px;height:16px;stroke-width:2.15}
.nav-item.active,.nav-item:hover{background:var(--accent-wash);color:var(--accent-ink)}
.nav-item.active .nav-icon,.nav-item:hover .nav-icon{background:var(--panel);border-color:var(--accent-border);color:var(--accent-ink);box-shadow:0 8px 18px var(--shadow-sm)}
.mobile-dock{display:none}
.sidebar-footer{margin-top:auto;display:grid;gap:6px;border-top:1px solid var(--line);padding-top:12px}
.main-shell{min-width:0}
.topbar{position:sticky;top:0;z-index:10;height:66px;display:flex;align-items:center;gap:12px;justify-content:space-between;padding:12px clamp(24px,2vw,44px);border-bottom:1px solid var(--line);background:var(--topbar-bg);backdrop-filter:blur(18px)}
.dark .topbar{background:var(--topbar-bg)}
.view{width:100%;max-width:none;margin:0;padding:24px clamp(24px,2vw,44px) 56px}
.topbar-actions{display:flex;gap:8px}
.primary-btn,.secondary-btn,.ghost-btn,.icon-btn,.command-btn{border-radius:8px;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:38px;font-weight:700;transition:.15s ease}
.primary-btn{background:var(--accent);color:white;padding:0 14px}
.primary-btn:hover{background:var(--accent-hover)}
.secondary-btn{border:1px solid var(--line);background:var(--panel);padding:0 13px;color:var(--ink)}
.ghost-btn{color:var(--muted);padding:0 10px;justify-content:flex-start}
.ghost-btn:hover,.secondary-btn:hover,.icon-btn:hover{background:var(--soft)}
.icon-btn{width:38px;border:1px solid var(--line);background:var(--panel)}
.primary-btn svg,.secondary-btn svg,.ghost-btn svg,.icon-btn svg{width:16px;height:16px;stroke-width:2.15}
.command-btn{border:1px solid var(--line);background:var(--panel);color:var(--muted);padding:0 10px;justify-content:flex-start;width:min(100%,430px)}
.command-btn kbd{margin-left:auto;font-size:11px;background:var(--soft);border-radius:5px;padding:2px 6px;color:var(--muted)}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:22px}
.page-head h1{font-size:32px;line-height:1.05;font-weight:800;margin:0;color:var(--ink)}
.page-head p{margin:8px 0 0;color:var(--muted);max-width:680px;font-size:14px;line-height:1.5}
.dashboard-hero{display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:18px;margin-bottom:18px;align-items:stretch}
.hero-copy,.hero-score{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:22px;box-shadow:0 18px 50px var(--shadow-sm)}
.hero-copy{display:grid;align-content:center;min-height:230px}
.eyebrow{font-size:11px;font-weight:800;text-transform:uppercase;color:var(--accent-ink);margin-bottom:10px}
.hero-copy h1{font-size:42px;line-height:1.02;font-weight:800;max-width:620px;margin:0;color:var(--ink)}
.hero-copy p{margin:12px 0 0;color:var(--muted);font-size:15px;line-height:1.55;max-width:640px}
.hero-actions{display:flex;gap:10px;margin-top:20px;flex-wrap:wrap}
.hero-score{display:grid;grid-template-columns:112px minmax(0,1fr);gap:18px;align-items:center}
.score-orbit{width:112px;height:112px;border-radius:50%;display:grid;place-items:center;background:conic-gradient(var(--accent) calc(var(--score,0)*1%),var(--soft) 0)}
.score-orbit span{width:80px;height:80px;border-radius:50%;display:grid;place-items:center;background:var(--panel);font-size:30px;font-weight:800}
.hero-score strong{font-size:18px}
.hero-score p{margin:6px 0 12px;color:var(--muted);line-height:1.45}
.hero-mini{display:grid;gap:6px;font-size:12px;color:var(--muted)}
.section-title{display:flex;align-items:end;justify-content:space-between;gap:16px;margin:8px 0 12px}
.section-title h2{font-size:18px;font-weight:800;margin:0;color:var(--ink)}
.section-title p{margin:4px 0 0;color:var(--muted);font-size:13px}
.grid{display:grid;gap:14px}
.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.card{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:16px;box-shadow:0 10px 30px var(--shadow-sm)}
.card h3{font-weight:800;margin:0 0 6px;font-size:15px;color:var(--ink)}
.muted{color:var(--muted)}
.stat{font-size:28px;font-weight:800;line-height:1}
.stat-card{min-height:116px}
.stat-card p{margin:8px 0 0;color:var(--muted);font-size:12px}
.stat-strip .card:nth-child(2) i{color:var(--cyan)}
.stat-strip .card:nth-child(4) i{color:var(--amber)}
.area-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}
.area-card{position:relative;overflow:hidden;cursor:pointer}
.area-card:hover{transform:translateY(-2px);box-shadow:0 18px 38px var(--shadow-md)}
.area-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--area-color,var(--accent))}
.area-card-main{display:block;width:100%;padding:0;text-align:left}
.area-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.area-icon{width:38px;height:38px;border:1px solid color-mix(in srgb,var(--area-color,var(--accent)) 24%,var(--line));border-radius:9px;display:grid;place-items:center;background:linear-gradient(135deg,color-mix(in srgb,var(--area-color,var(--accent)) 18%,transparent),color-mix(in srgb,var(--area-color,var(--accent)) 7%,var(--panel)));color:var(--area-color,var(--accent));box-shadow:inset 0 1px 0 rgba(255,255,255,.28)}
.area-icon svg{width:18px;height:18px;stroke-width:2.15}
.score-ring{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;background:conic-gradient(var(--area-color,var(--accent)) calc(var(--score,50)*1%),var(--soft) 0);font-size:11px;font-weight:800}
.score-ring span{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:var(--panel)}
.score-ring.xl{width:92px;height:92px;margin:14px 0;background:conic-gradient(var(--accent) calc(var(--score,50)*1%),var(--soft) 0)}
.score-ring.xl span{width:66px;height:66px;font-size:24px}
.area-heading{display:flex;align-items:center;justify-content:space-between;gap:8px}
.area-heading span{font-size:11px;font-weight:800;color:var(--area-color,var(--accent))}
.area-meta{display:flex;gap:7px;margin-top:14px;flex-wrap:wrap;align-items:center}
.area-meta .compact{margin-left:auto;width:30px;min-height:30px;border-radius:8px}
.score-summary{display:grid;align-content:start}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px}
.list-card .row:first-of-type{padding-top:4px}
.row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid var(--line)}
.row:last-child{border-bottom:0}
.pill{display:inline-flex;align-items:center;gap:5px;border-radius:999px;padding:3px 8px;font-size:11px;font-weight:750;background:var(--soft);color:var(--muted)}
.pill.green{background:var(--success-soft);color:var(--success-ink)}.dark .pill.green{background:var(--success-soft);color:var(--success-ink)}
.pill.red{background:var(--danger-soft);color:var(--danger-ink)}.dark .pill.red{background:var(--danger-soft);color:var(--danger-ink)}
.calendar{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}
.day{min-height:112px;background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:9px}
.day-num{font-size:12px;font-weight:800;color:var(--muted);margin-bottom:8px}
.event{font-size:11px;line-height:1.25;padding:5px 6px;border-radius:6px;margin-bottom:4px;background:var(--accent-wash);color:var(--accent-ink)}
.drawer,.modal{position:fixed;inset:0;z-index:90;background:rgba(0,0,0,.38);display:flex;justify-content:flex-end}
.drawer-body{height:100%;width:min(100%,520px);background:var(--panel);border-left:1px solid var(--line);padding:22px;overflow:auto}
.modal{align-items:center;justify-content:center;padding:18px}
.modal-body{width:min(100%,520px);max-height:90vh;overflow:auto;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:22px}
.ai-panel{position:sticky;top:0;height:100vh;border-left:1px solid var(--line);background:var(--panel);display:flex;flex-direction:column;min-width:0}
.panel-head{display:flex;justify-content:space-between;gap:14px;padding:18px;border-bottom:1px solid var(--line)}
.panel-head h2{margin:0;font-size:16px;font-weight:800}
.panel-head p{margin:4px 0 0;font-size:12px;color:var(--muted)}
.ai-messages{flex:1;overflow:auto;padding:14px;display:flex;flex-direction:column;gap:10px}
.msg{border:1px solid var(--line);border-radius:8px;padding:10px 12px;line-height:1.45;white-space:pre-wrap}
.msg.user{background:var(--soft)}
.msg.ai{background:var(--accent-wash);border-color:var(--accent-border)}
.ai-form{border-top:1px solid var(--line);padding:14px;display:grid;gap:10px}
.toasts{position:fixed;right:18px;bottom:18px;z-index:100;display:grid;gap:8px}
.toast{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:10px 12px;box-shadow:0 15px 40px var(--shadow-lg);font-weight:650}
.evidence-thumb{aspect-ratio:4/3;border-radius:8px;object-fit:cover;border:1px solid var(--line);background:var(--soft)}
.empty{border:1px dashed var(--line);border-radius:8px;padding:22px;text-align:center;color:var(--muted)}
.score-field{display:grid;grid-template-columns:1fr 82px;gap:10px;align-items:center;border:1px solid var(--line);border-radius:8px;padding:14px;background:var(--soft)}
.score-field-head{grid-column:1/-1;display:flex;align-items:center;justify-content:space-between}
.score-field output{font-size:22px;font-weight:800;color:var(--ink)}
.score-field label{margin:0}
.score-field p{grid-column:1/-1;margin:0}
.score-number{text-align:center;font-weight:800}
.theme-modal{width:min(100%,760px)}
.theme-picker-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}
.theme-picker-head h2{font-size:20px;font-weight:850;margin:0;color:var(--ink)}
.theme-picker-head p{margin:5px 0 0;color:var(--muted);font-size:13px;line-height:1.45}
.theme-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.theme-card{border:1px solid var(--line);border-radius:8px;background:var(--panel);padding:12px;text-align:left;display:grid;gap:10px;color:var(--ink);transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}
.theme-card:hover,.theme-card.active{border-color:var(--accent-border);box-shadow:0 14px 32px var(--shadow-md);transform:translateY(-1px)}
.theme-card.active{background:var(--accent-wash)}
.theme-swatch{height:58px;border:1px solid var(--line);border-radius:7px;padding:7px;display:grid;grid-template-columns:1fr 1.6fr;gap:6px;background:var(--theme-paper)}
.theme-swatch span{display:block;border-radius:5px}
.theme-swatch span:nth-child(1){background:var(--theme-panel)}
.theme-swatch span:nth-child(2){background:linear-gradient(135deg,var(--theme-soft),var(--theme-accent))}
.theme-card strong{font-size:14px;font-weight:850;color:var(--ink)}
.theme-card small{display:block;margin-top:3px;font-size:12px;color:var(--muted);line-height:1.35}
.theme-card-footer{display:flex;align-items:center;justify-content:space-between;gap:10px}
.theme-card .pill{background:var(--soft)}
.vision-hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,.75fr);gap:16px;align-items:stretch;margin-bottom:16px;border:1px solid var(--accent-border);border-radius:8px;padding:20px;background:linear-gradient(135deg,var(--accent-wash),var(--panel) 52%)}
.vision-hero h2{font-size:34px;line-height:1.05;font-weight:850;margin:0 0 10px;color:var(--ink)}
.vision-hero p{max-width:640px;margin:0;color:var(--muted);line-height:1.55}
.vision-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.vision-stat{border:1px solid var(--line);border-radius:8px;background:var(--panel);padding:12px;display:grid;gap:6px}
.vision-stat i{width:18px;height:18px;color:var(--accent)}
.vision-stat span{font-size:11px;font-weight:800;text-transform:uppercase;color:var(--muted)}
.vision-stat strong{font-size:24px;line-height:1;color:var(--ink)}
.vision-filter-note{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:-4px 0 16px;border:1px solid var(--line);border-radius:8px;background:var(--panel);padding:10px 12px;color:var(--muted);font-size:12px;font-weight:750}
.vision-filter-note svg{width:16px;height:16px;color:var(--muted)}
.vision-sections{display:grid;gap:16px}
.vision-section{border:1px solid var(--line);border-radius:8px;background:var(--panel);overflow:hidden;box-shadow:0 14px 38px var(--shadow-sm)}
.vision-section-head{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:15px 16px;border-bottom:1px solid var(--line);background:linear-gradient(90deg,color-mix(in srgb,var(--area-color,var(--accent)) 12%,transparent),transparent 64%)}
.vision-section-title{display:flex;align-items:center;gap:11px;min-width:0}
.vision-section-icon{width:38px;height:38px;border-radius:8px;display:grid;place-items:center;flex:0 0 auto;background:color-mix(in srgb,var(--area-color,var(--accent)) 15%,transparent);color:var(--area-color,var(--accent))}
.vision-section-icon svg{width:18px;height:18px}
.vision-section-title h3{margin:0;font-size:17px;font-weight:850;color:var(--ink)}
.vision-section-title p{margin:4px 0 0;color:var(--muted);font-size:12px;line-height:1.35;overflow-wrap:anywhere}
.vision-section-actions{display:flex;align-items:center;justify-content:flex-end;gap:7px;flex-wrap:wrap;flex:0 0 auto}
.vision-section-body{padding:14px;background:color-mix(in srgb,var(--soft) 18%,var(--panel))}
.vision-board{columns:3 230px;column-gap:12px}
.vision-section-empty{min-height:150px;border:1px dashed var(--line);border-radius:8px;display:grid;place-items:center;align-content:center;gap:8px;text-align:center;color:var(--muted);padding:20px;background:var(--panel)}
.vision-section-empty i{width:24px;height:24px;color:var(--area-color,var(--accent))}
.vision-section-empty strong{font-size:14px;font-weight:850;color:var(--ink)}
.vision-section-empty span{max-width:320px;font-size:12px;line-height:1.45}
.vision-card{break-inside:avoid;margin:0 0 14px;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:var(--panel);box-shadow:0 12px 34px var(--shadow-sm);transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}
.vision-card:hover{border-color:color-mix(in srgb,var(--area-color,var(--accent)) 42%,transparent);box-shadow:0 18px 44px var(--shadow-md);transform:translateY(-1px)}
.vision-preview{display:block;width:100%;max-height:360px;object-fit:cover;background:var(--soft)}
.vision-preview-icon{height:170px;display:grid;place-items:center;gap:8px;color:var(--area-color,var(--accent));background:linear-gradient(135deg,color-mix(in srgb,var(--area-color,var(--accent)) 15%,transparent),var(--soft))}
.vision-preview-icon i{width:32px;height:32px}
.vision-preview-icon span{font-size:12px;font-weight:850;color:var(--muted)}
.vision-card-body{padding:14px}
.vision-card-meta{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.vision-card h3{margin:0 0 7px;font-size:17px;font-weight:850;color:var(--ink)}
.vision-card p{margin:0;color:var(--muted);line-height:1.45}
.vision-card-actions{display:flex;gap:7px;flex-wrap:wrap;margin-top:13px}
.tiny-btn.danger:hover{background:var(--danger-soft);color:var(--danger-ink);border-color:var(--danger-border)}
.vision-filter-modal{width:min(100%,720px)}
.vision-filter-actions{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.vision-filter-list{display:grid;gap:9px}
.vision-filter-row{display:grid;grid-template-columns:auto auto minmax(0,1fr);align-items:center;gap:10px;margin:0;border:1px solid var(--line);border-radius:8px;background:var(--panel);padding:11px;color:var(--ink);text-transform:none;cursor:pointer}
.vision-filter-row:hover{border-color:var(--accent-border);background:var(--accent-wash)}
.vision-filter-row input{margin:0}
.vision-filter-row strong{display:block;font-size:14px;font-weight:850;color:var(--ink)}
.vision-filter-row small{display:block;margin-top:3px;font-size:12px;line-height:1.35;color:var(--muted);font-weight:750}
.habit-good{border-color:color-mix(in srgb,var(--success-ink) 38%,var(--line))}
.habit-ok{border-color:color-mix(in srgb,var(--amber) 38%,var(--line))}
.habit-bad{border-color:color-mix(in srgb,var(--danger-ink) 35%,var(--line))}
.habit-scoreline{display:grid;grid-template-columns:auto minmax(0,1fr);gap:10px;align-items:center;margin:12px 0}
.habit-scoreline strong{font-size:28px;line-height:1;color:var(--ink)}
.habit-scoreline span{color:var(--muted);font-size:12px;font-weight:750}
.progress-track.good span,.mini-bar.good span{background:var(--success-ink)}
.progress-track.ok span,.mini-bar.ok span{background:var(--amber)}
.progress-track.bad span,.mini-bar.bad span{background:var(--danger-ink)}
.habit-trend{display:grid;grid-template-columns:repeat(35,minmax(0,1fr));gap:3px;margin:14px 0 2px}
.habit-trend span{height:18px;border-radius:4px;border:1px solid var(--line);background:var(--soft)}
.habit-good .habit-trend span.on{background:var(--success-ink);border-color:var(--success-ink)}
.habit-ok .habit-trend span.on{background:var(--amber);border-color:var(--amber)}
.habit-bad .habit-trend span.on{background:var(--danger-ink);border-color:var(--danger-ink)}
@media(max-width:1360px){.area-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}
@media(max-width:1280px){.app-shell{grid-template-columns:220px minmax(0,1fr)}.ai-panel{position:fixed;right:0;top:0;width:min(100%,380px);z-index:40;transform:translateX(100%);transition:.18s ease}.ai-panel.open{transform:translateX(0)}}
@media(max-width:1024px){.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;transform:translateX(-100%);transition:.18s ease;width:260px}.sidebar.open{transform:translateX(0)}.view{padding:18px}.topbar{padding:10px 14px}.grid.cols-3,.grid.cols-4{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-hero{grid-template-columns:1fr}.area-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:720px){.grid.cols-2,.grid.cols-3,.area-grid{grid-template-columns:1fr}.grid.cols-4{grid-template-columns:repeat(2,minmax(0,1fr))}.page-head,.section-title{display:block}.section-title .secondary-btn{margin-top:12px}.dashboard-hero{gap:12px}.hero-copy,.hero-score{padding:18px}.hero-copy h1{font-size:32px}.hero-score{grid-template-columns:86px minmax(0,1fr)}.score-orbit{width:86px;height:86px}.score-orbit span{width:62px;height:62px;font-size:24px}.topbar-actions .secondary-btn span,.command-btn kbd{display:none}.calendar{grid-template-columns:1fr}.day{min-height:auto}.page-head h1{font-size:28px}}
@media(max-width:430px){.auth-card{padding:24px 18px}.auth-shell{place-items:center start;overflow-x:hidden}.primary-btn{padding:0 12px}}

button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.head-actions{display:flex;gap:8px;align-items:center;justify-content:flex-end;flex-wrap:wrap}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:16px;min-width:0}
.panel h3{font-weight:800;margin:0 0 8px;font-size:15px;color:var(--ink)}
.span-2{grid-column:span 2}
.command-center{display:grid;grid-template-columns:minmax(0,1.8fr) minmax(280px,.9fr);gap:14px;align-items:stretch}
.today-hero{border:1px solid var(--accent-border);background:linear-gradient(135deg,var(--accent-wash),var(--panel) 48%);border-radius:8px;padding:22px;display:flex;flex-direction:column;justify-content:space-between;min-height:210px}
.today-hero h2{font-size:34px;line-height:1.05;font-weight:850;margin:10px 0;color:var(--ink)}
.today-hero p{max-width:560px;color:var(--muted);line-height:1.55}
.eyebrow{font-size:11px;font-weight:800;text-transform:uppercase;color:var(--accent-ink);letter-spacing:.08em}
.hero-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:20px}
.revenue-strip{border:1px solid var(--line);border-radius:8px;padding:18px;background:var(--panel);display:flex;flex-direction:column;justify-content:center}
.revenue-strip h3{font-size:22px;line-height:1.15;font-weight:850;margin:12px 0 8px}
.pill.strong{background:var(--success-soft);color:var(--success-ink)}.dark .pill.strong{background:var(--success-soft);color:var(--success-ink)}
.stat-tile{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:15px;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;text-align:left}
.stat-tile.editable-stat{cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}
.stat-tile.editable-stat:hover{border-color:var(--accent-border);box-shadow:0 14px 36px var(--shadow-md);transform:translateY(-1px)}
.stat-tile span{display:block;color:var(--muted);font-size:12px;font-weight:750;margin-bottom:8px}
.stat-tile strong{display:block;font-size:25px;line-height:1;font-weight:850;color:var(--ink)}
.stat-icon{width:34px;height:34px;border:1px solid var(--accent-border);border-radius:9px;display:grid;place-items:center;flex:0 0 auto;background:var(--accent-wash);color:var(--accent-ink)}
.stat-tile svg{width:17px;height:17px;color:currentColor;stroke-width:2.15}
.section-title{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}
.tiny-btn{min-height:28px;border:1px solid var(--line);border-radius:7px;padding:0 9px;font-size:12px;font-weight:800;color:var(--muted);background:var(--panel)}
.tiny-btn:hover,.tiny-btn.active{background:var(--accent-wash);color:var(--accent-ink);border-color:var(--accent-border)}
.area-card,.goal-card,.habit-card{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:16px;position:relative;overflow:hidden;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}
.area-card:hover,.goal-card:hover,.habit-card:hover{transform:translateY(-1px);border-color:var(--accent-border);box-shadow:0 14px 36px var(--shadow-md)}
.goal-card h3,.habit-card h3{font-size:17px;font-weight:850;margin:0 0 8px}
.goal-meta{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:7px;margin-top:14px}
.goal-meta span{border-radius:7px;background:var(--soft);padding:7px 8px;font-size:11px;font-weight:750;color:var(--muted);text-align:center}
.filter-bar{display:flex;gap:7px;flex-wrap:wrap}
.filter-bar button{border:1px solid var(--line);border-radius:8px;background:var(--panel);min-height:34px;padding:0 12px;font-weight:800;color:var(--muted)}
.filter-bar button.active,.filter-bar button:hover{background:var(--accent-wash);color:var(--accent-ink);border-color:var(--accent-border)}
.action-list{padding:4px 14px}
.action-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:center;padding:14px 0;border-bottom:1px solid var(--line)}
.action-item:last-child{border-bottom:0}
.action-item strong{display:block;font-size:15px;margin-bottom:4px}
.action-notes{margin-top:8px;color:var(--muted);line-height:1.45}
.action-controls,.row-actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.icon-btn.danger:hover{background:var(--danger-soft);color:var(--danger-ink);border-color:var(--danger-border)}.dark .icon-btn.danger:hover{background:var(--danger-soft);color:var(--danger-ink);border-color:var(--danger-border)}
.habit-mini{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center;padding:10px 0;border-bottom:1px solid var(--line)}
.habit-mini:last-child{border-bottom:0}
.mini-bar,.progress-track{grid-column:1/-1;height:7px;border-radius:999px;background:var(--soft);overflow:hidden}
.mini-bar span,.progress-track span{display:block;height:100%;background:var(--accent);border-radius:inherit}
.progress-track{height:9px;margin:14px 0}
.habit-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.log-dots{display:flex;gap:5px;margin-top:14px}
.log-dots span{width:9px;height:9px;border-radius:50%;background:var(--soft);border:1px solid var(--line)}
.log-dots span.on{background:var(--accent);border-color:var(--accent)}
.detail-block{margin:0 0 14px}
.detail-block:last-child{margin-bottom:0}
.calendar-title{font-size:20px;font-weight:850;margin:0 0 14px;color:var(--ink)}
.day{cursor:pointer;text-align:left;transition:border-color .15s ease,transform .15s ease}
.day:hover{transform:translateY(-1px);border-color:var(--accent-border)}
.day.today{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent-border)}
.event.goal{background:var(--blue-soft);color:var(--blue-ink)}
.event.milestone{background:var(--warning-soft);color:var(--warning-ink)}
.event.action{background:var(--accent-wash);color:var(--accent-ink)}
.event.notification{background:rgba(113,113,122,.14);color:#52525b}
.more-events{font-size:11px;font-weight:800;color:var(--muted);padding:3px 6px}
.review-summary h3{font-size:19px;font-weight:850;margin:12px 0}
.drawer-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px}
.drawer-head h2{font-size:20px;font-weight:850;margin:0}
.ai-conversations{border-bottom:1px solid var(--line);padding:10px 12px;display:flex;gap:6px;overflow:auto}
.ai-conversations button{flex:0 0 auto;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border:1px solid var(--line);border-radius:999px;background:var(--panel);color:var(--muted);padding:5px 9px;font-size:11px;font-weight:800}
.ai-conversations button.active,.ai-conversations button:hover{background:var(--accent-wash);color:var(--accent-ink);border-color:var(--accent-border)}
.ai-capabilities{border-bottom:1px solid var(--line);padding:10px 12px;display:grid;gap:8px}
.ai-capability-head{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:12px}
.ai-capability-head strong{font-weight:850}.ai-capability-head span{color:var(--muted);font-size:11px;font-weight:800}
.ai-capability-pills{display:flex;gap:5px;overflow:auto}
.ai-capability-pills span{flex:0 0 auto;border-radius:999px;background:var(--soft);color:var(--muted);padding:3px 7px;font-size:10px;font-weight:800}
.ai-tool-activity{border-bottom:1px solid var(--line);padding:10px 12px;display:grid;gap:6px;font-size:11px}
.ai-tool-activity strong{font-size:12px}.ai-tool-activity div{display:flex;align-items:center;justify-content:space-between;gap:8px;border:1px solid var(--line);border-radius:7px;padding:5px 7px;background:var(--soft)}.ai-tool-activity em{font-style:normal;color:var(--muted);font-weight:800}
.capability-grid{display:flex;gap:6px;flex-wrap:wrap}
.ai-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.timebox-dashboard{display:grid;grid-template-columns:clamp(260px,20%,340px) minmax(280px,1fr) clamp(280px,22%,360px);gap:0;min-height:max(720px,calc(100vh - 150px));border:1px solid var(--line);border-radius:8px;overflow:hidden;background:var(--panel);box-shadow:0 18px 50px var(--shadow-sm)}
.timebox-queue,.timebox-calendar,.timebox-coach{min-width:0}
.timebox-queue,.timebox-coach{padding:18px;background:var(--panel)}
.timebox-queue{border-right:1px solid var(--line)}
.timebox-coach{border-left:1px solid var(--line);display:grid;align-content:start;gap:12px;background:color-mix(in srgb,var(--soft) 42%,var(--panel))}
.timebox-calendar{padding:22px;background:linear-gradient(180deg,var(--info-soft),transparent 230px),var(--paper)}
.brand-mini{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.brand-mini strong{display:block;font-size:14px;color:var(--ink)}
.brand-mini span{display:block;margin-top:2px;font-size:12px;color:var(--muted)}
.brand-mark.mini{width:34px;height:34px;border-radius:8px;box-shadow:none}
.brand-mark.mini svg{width:17px;height:17px}
.workload-card{border:1px solid var(--line);border-radius:8px;padding:14px;margin-bottom:16px;background:color-mix(in srgb,var(--cyan) 8%,var(--panel))}
.workload{height:11px;border-radius:999px;background:var(--soft);overflow:hidden;margin:10px 0}
.workload span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--accent),var(--cyan))}
.section-title.compact{margin:0 0 10px}
.section-title.compact h3{font-size:14px;margin:0}
.section-title.compact span{font-size:12px;font-weight:850;color:var(--muted)}
.timebox-task-list{display:grid;gap:9px}
.timebox-task{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:start;width:100%;padding:12px;border:1px solid var(--line);border-radius:8px;background:var(--panel);text-align:left}
.timebox-task:hover,.timebox-task.active{border-color:var(--accent-border);background:var(--accent-wash)}
.timebox-task strong{display:block;font-size:13px;color:var(--ink);line-height:1.3}
.timebox-task small{display:block;margin-top:4px;color:var(--muted);font-size:11px;line-height:1.35}
.timebox-check{width:22px;height:22px;border-radius:7px;display:grid;place-items:center;background:var(--accent-wash);color:var(--accent-ink);margin-top:1px}
.timebox-check svg{width:13px;height:13px}
.timebox-topline{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:18px}
.timebox-topline h2{font-size:30px;line-height:1.05;font-weight:850;margin:6px 0 8px;color:var(--ink);max-width:640px}
.timebox-topline p{margin:0;color:var(--muted);line-height:1.5;max-width:650px}
.timegrid{display:grid;grid-template-columns:64px minmax(0,1fr);gap:8px}
.hour{color:var(--muted);font-size:12px;font-weight:800;padding-top:15px;text-align:right}
.time-block{min-height:76px;border:1px solid var(--line);border-radius:8px;padding:13px 14px;background:var(--panel);display:grid;align-content:center;text-align:left;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}
.time-block:hover{transform:translateY(-1px);border-color:color-mix(in srgb,var(--cyan) 42%,transparent);box-shadow:0 12px 28px var(--shadow-sm)}
.time-block.focus{background:var(--accent-wash);border-color:var(--accent-border)}
.time-block.risk{background:var(--warning-soft);border-color:color-mix(in srgb,var(--amber) 36%,transparent)}
.time-block strong{font-size:14px;color:var(--ink)}
.time-block span{margin-top:5px;color:var(--muted);font-size:12px}
.coach-card{display:grid;grid-template-columns:34px minmax(0,1fr);gap:11px;border:1px solid var(--line);border-radius:8px;background:var(--panel);padding:13px}
.coach-card i{width:18px;height:18px;color:var(--accent)}
.coach-card>div{width:34px;height:34px;border-radius:8px;display:grid;place-items:center;background:var(--accent-wash)}
.coach-card h3{font-size:14px;font-weight:850;margin:0 0 5px;color:var(--ink)}
.coach-card p{font-size:12px;line-height:1.45;margin:0;color:var(--muted)}
.mini-panel{box-shadow:none}
@media(max-width:1280px){.command-center{grid-template-columns:1fr}.span-2{grid-column:auto}}
@media(max-width:1540px){.timebox-dashboard{grid-template-columns:280px minmax(0,1fr)}.timebox-coach{grid-column:1/-1;border-left:0;border-top:1px solid var(--line);grid-template-columns:repeat(3,minmax(0,1fr));align-items:start}.timebox-coach>.section-title{grid-column:1/-1}.timebox-coach .mini-panel{min-height:100%}}
@media(max-width:720px){
  body{font-size:15px}
  button,input,textarea,select{font-size:16px}
  input,textarea,select{min-height:44px}
  .app-shell{display:block;min-height:100dvh;padding-bottom:82px}
  .main-shell,.view{width:100%;max-width:100vw;overflow-x:hidden}
  .view{padding:16px 14px 104px}
  .topbar{height:58px;padding:8px 12px;gap:8px}
  .icon-btn,.tiny-btn,.primary-btn,.secondary-btn,.ghost-btn{min-height:44px}
  .command-btn{min-width:0;flex:1;width:auto;height:44px}
  .topbar-actions{display:none}
  .mobile-dock{position:fixed;left:0;right:0;bottom:0;z-index:42;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:4px;padding:7px max(8px,env(safe-area-inset-left)) calc(7px + env(safe-area-inset-bottom)) max(8px,env(safe-area-inset-right));border-top:1px solid var(--line);background:var(--dock-bg);backdrop-filter:blur(18px);box-shadow:0 -16px 36px var(--shadow-md)}
  .dark .mobile-dock{background:var(--dock-bg)}
  .mobile-dock-item{min-width:0;min-height:54px;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--muted);font-size:11px;font-weight:800}
  .mobile-dock-item svg{width:18px;height:18px}
  .mobile-dock-item.active{background:var(--accent-wash);color:var(--accent-ink)}
  .mobile-dock-item.capture{background:var(--accent);color:#fff;box-shadow:0 10px 24px color-mix(in srgb,var(--accent) 28%,transparent)}
  body.overlay-open .mobile-dock{pointer-events:none}
  .sidebar{z-index:60;width:min(86vw,300px)}
  .page-head p,.panel p,.revenue-strip p,.timebox-topline p{max-width:100%;overflow-wrap:anywhere}
  .head-actions{display:grid;grid-template-columns:1fr;width:100%;justify-content:stretch;margin-top:12px}
  .head-actions .primary-btn,.head-actions .secondary-btn{width:100%;min-width:0}
  .panel,.today-hero,.revenue-strip,.stat-tile,.command-center>*,.timebox-dashboard>*{min-width:0;max-width:100%}
  .vision-hero{grid-template-columns:1fr;padding:16px}
  .vision-hero h2{font-size:27px}
  .vision-stats{grid-template-columns:repeat(2,minmax(0,1fr))}
  .vision-section-head{display:block;padding:14px}
  .vision-section-actions{justify-content:flex-start;margin-top:12px}
  .vision-section-actions .tiny-btn{min-height:38px}
  .vision-section-body{padding:12px}
  .vision-filter-actions{display:grid;grid-template-columns:1fr}
  .vision-board{columns:1}
  .habit-trend{gap:2px}
  .habit-trend span{height:14px}
  .timebox-dashboard{display:grid;grid-template-columns:1fr;min-height:auto}
  .timebox-queue,.timebox-coach{border:0;border-bottom:1px solid var(--line);padding:14px}
  .timebox-calendar{padding:14px}
  .timebox-topline{display:block}
  .timebox-topline h2{font-size:26px}
  .timebox-topline .hero-actions{display:grid;grid-template-columns:1fr;margin-top:14px}
  .timegrid{grid-template-columns:48px minmax(0,1fr)}
  .hour{text-align:left;font-size:11px}
  .timebox-task{grid-template-columns:auto minmax(0,1fr);align-items:start}
  .timebox-task .pill{grid-column:2}
  .timebox-coach{display:grid;grid-template-columns:1fr}
  .stat-tile{padding:14px;min-height:86px}
  .stat-tile strong{font-size:22px}
  .today-hero h2{font-size:27px}
  .command-center{gap:10px}
  .action-item{grid-template-columns:1fr}
  .action-controls{justify-content:flex-start}
  .action-controls .icon-btn,.row-actions .icon-btn{width:44px}
  .filter-bar{flex-wrap:nowrap;overflow-x:auto;padding-bottom:3px;scrollbar-width:none}
  .filter-bar::-webkit-scrollbar{display:none}
  .filter-bar button{flex:0 0 auto;min-height:40px}
  .drawer{align-items:flex-end;justify-content:center}
  .drawer-body{width:100%;height:auto;max-height:92dvh;border-left:0;border-top:1px solid var(--line);border-radius:14px 14px 0 0;padding:18px;box-shadow:0 -18px 46px var(--shadow-lg)}
  .drawer-head{position:sticky;top:-18px;z-index:1;background:var(--panel);padding-top:4px;padding-bottom:12px}
  .modal{align-items:flex-end;padding:12px}
  .modal-body{width:100%;border-radius:14px;padding:18px}
  .theme-grid{grid-template-columns:1fr}
  .calendar{display:grid;grid-template-columns:1fr}
  .ai-panel{position:fixed;inset:0;width:100%;height:100dvh;z-index:55;transform:translateX(100%);transition:.18s ease}
  .ai-panel.open{transform:translateX(0)}
  .ai-form{padding-bottom:calc(14px + env(safe-area-inset-bottom))}
  .ai-form-grid{grid-template-columns:1fr}
  .goal-meta{grid-template-columns:1fr}
  .toasts{left:12px;right:12px;bottom:calc(86px + env(safe-area-inset-bottom))}
}
