/* ============================================ */
/*  SprintPilot — Premium Sprint Command Center */
/* ============================================ */
:root {
    --bg: #f8fafb; --bg2: #ffffff; --bg3: #f1f5f9;
    --tx: #0f172a; --tx2: #475569; --tx3: #94a3b8;
    --bd: #e2e8f0; --bd2: #f1f5f9;
    --accent: #0d9488; --accent-h: #0f766e; --accent-l: #ccfbf1; --accent-bg: rgba(13,148,136,0.08);
    --green: #10b981; --green-l: #d1fae5;
    --amber: #f59e0b; --amber-l: #fef3c7;
    --red: #ef4444; --red-l: #fee2e2;
    --blue: #3b82f6; --blue-l: #dbeafe;
    --purple: #8b5cf6; --purple-l: #ede9fe;
    --shadow: 0 1px 3px rgba(0,0,0,0.04), 0 1px 2px rgba(0,0,0,0.06);
    --shadow-md: 0 4px 6px -1px rgba(0,0,0,0.07), 0 2px 4px -2px rgba(0,0,0,0.05);
    --shadow-lg: 0 10px 25px -5px rgba(0,0,0,0.08), 0 8px 10px -6px rgba(0,0,0,0.04);
    --r: 10px; --r-lg: 14px; --r-xl: 18px;
    --sidebar-w: 260px; --topbar-h: 60px;
    --transition: 0.2s cubic-bezier(.4,0,.2,1);
}
[data-theme="dark"] {
    --bg: #0c1222; --bg2: #131b2e; --bg3: #1a2340;
    --tx: #e2e8f0; --tx2: #94a3b8; --tx3: #64748b;
    --bd: #1e293b; --bd2: #1a2340;
    --accent-l: #042f2e; --accent-bg: rgba(13,148,136,0.15);
    --green-l: #064e3b; --amber-l: #78350f; --red-l: #7f1d1d; --blue-l: #1e3a5f; --purple-l: #4c1d95;
    --shadow: 0 1px 3px rgba(0,0,0,0.3); --shadow-md: 0 4px 6px rgba(0,0,0,0.4); --shadow-lg: 0 10px 25px rgba(0,0,0,0.5);
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Inter',-apple-system,sans-serif;background:var(--bg);color:var(--tx);line-height:1.5;overflow:hidden;height:100vh}
::selection{background:var(--accent);color:#fff}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bd);border-radius:3px}

/* ============ LAYOUT ============ */
.app{display:flex;height:100vh}
.sidebar{width:var(--sidebar-w);background:var(--bg2);border-right:1px solid var(--bd);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:50;transition:transform .3s}
.main{flex:1;margin-left:var(--sidebar-w);display:flex;flex-direction:column;height:100vh;overflow:hidden}
.content{flex:1;overflow:auto;padding:24px;background:var(--bg)}

/* ============ SIDEBAR ============ */
.sidebar-brand{display:flex;align-items:center;gap:12px;padding:20px 20px 16px}
.brand-icon{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--accent),#14b8a6);display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px}
.brand-name{font-size:17px;font-weight:700;color:var(--tx);display:block;line-height:1.2}
.brand-tag{font-size:11px;color:var(--tx3);font-weight:500}
.sidebar-search{display:flex;align-items:center;gap:8px;margin:0 16px 12px;padding:8px 12px;background:var(--bg);border:1px solid var(--bd);border-radius:var(--r);color:var(--tx3);font-size:13px;cursor:pointer;transition:var(--transition)}
.sidebar-search:hover{border-color:var(--accent);color:var(--tx2)}
.sidebar-search kbd{margin-left:auto;font-size:10px;background:var(--bg3);padding:2px 6px;border-radius:4px;font-family:inherit;color:var(--tx3)}
.sidebar-nav{flex:1;overflow-y:auto;padding:0 12px}
.nav-section{margin-bottom:16px}
.nav-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--tx3);padding:8px 12px 4px;display:block}
.nav-link{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--r);color:var(--tx2);text-decoration:none;font-size:13px;font-weight:500;transition:var(--transition);position:relative}
.nav-link:hover{background:var(--bg);color:var(--tx)}
.nav-link.active{background:var(--accent-bg);color:var(--accent);font-weight:600}
.nav-link i{width:18px;text-align:center;font-size:14px}
.nav-badge{margin-left:auto;background:var(--accent-l);color:var(--accent);font-size:11px;font-weight:600;padding:1px 7px;border-radius:10px}
.nav-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);margin-left:auto}
.nav-dot.pulse{animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.sidebar-footer{padding:16px;border-top:1px solid var(--bd)}
.theme-switch{display:flex;align-items:center;gap:8px;justify-content:center;color:var(--tx3);cursor:pointer;margin-bottom:10px}
.theme-track{width:40px;height:22px;background:var(--bg3);border-radius:11px;position:relative;transition:var(--transition)}
.theme-thumb{width:16px;height:16px;background:#fff;border-radius:50%;position:absolute;top:3px;left:3px;transition:var(--transition);box-shadow:var(--shadow)}
[data-theme="dark"] .theme-track{background:var(--accent)}[data-theme="dark"] .theme-thumb{left:21px}
.sprint-meta{text-align:center}
.sprint-meta-label{font-size:13px;font-weight:600;color:var(--tx);display:block}
.sprint-meta-dates{font-size:11px;color:var(--tx3)}

/* ============ TOPBAR ============ */
.topbar{height:var(--topbar-h);background:var(--bg2);border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;padding:0 24px;flex-shrink:0}
.topbar-left{display:flex;align-items:center;gap:12px}
.hamburger{display:none;background:none;border:none;font-size:18px;color:var(--tx2);cursor:pointer;padding:4px}
.topbar-title h1{font-size:18px;font-weight:700;line-height:1.2}
.topbar-breadcrumb{font-size:12px;color:var(--tx3)}
.topbar-right{display:flex;align-items:center;gap:10px}
.health-badge{display:flex;align-items:center;gap:6px;padding:5px 12px;background:var(--green-l);color:var(--green);border-radius:20px;font-size:12px;font-weight:600}
.health-dot{width:7px;height:7px;border-radius:50%;background:var(--green);animation:pulse 2s infinite}
.health-badge.at-risk{background:var(--amber-l);color:var(--amber)}.health-badge.at-risk .health-dot{background:var(--amber)}
.health-badge.critical{background:var(--red-l);color:var(--red)}.health-badge.critical .health-dot{background:var(--red)}

/* ============ BUTTONS ============ */
.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border:none;border-radius:var(--r);font-size:13px;font-weight:500;cursor:pointer;transition:var(--transition);font-family:inherit}
.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-h);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-ghost{background:transparent;color:var(--tx2)}.btn-ghost:hover{background:var(--bg);color:var(--tx)}
.btn-sm{padding:5px 10px;font-size:12px}
.btn-danger{background:var(--red-l);color:var(--red)}.btn-danger:hover{background:var(--red);color:#fff}

/* ============ INPUTS ============ */
.input{width:100%;padding:8px 12px;border:1px solid var(--bd);border-radius:var(--r);font-family:inherit;font-size:13px;background:var(--bg);color:var(--tx);transition:var(--transition)}
.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}
.textarea{min-height:80px;resize:vertical;line-height:1.6}
select.input{cursor:pointer}
.form-group{margin-bottom:12px}.form-group label{display:block;font-size:12px;font-weight:500;color:var(--tx2);margin-bottom:4px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:12px}
.form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}

/* ============ VIEWS ============ */
.view{display:none}.view.active{display:block}

/* ============ DASHBOARD ============ */
.dash-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.dash-card{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow)}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.card-header h3{font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px}
.card-desc{font-size:13px;color:var(--tx2);margin-bottom:14px;line-height:1.5}
.card-actions{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--tx3)}
.legend-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:2px}
.legend-dot.ideal{background:var(--tx3)}.legend-dot.actual{background:var(--accent)}
.wide{grid-column:span 2}

/* Hero Card */
.hero-card{display:flex;align-items:center;justify-content:space-between;grid-column:span 4;background:linear-gradient(135deg,var(--accent),#14b8a6);color:#fff;border:none}
.hero-score{font-size:56px;font-weight:800;line-height:1}
.hero-label{font-size:14px;font-weight:500;opacity:.9;margin-top:4px}
.hero-sub{font-size:13px;opacity:.75;margin-top:6px}
.hero-right canvas{filter:brightness(2) saturate(0)}

/* Stat Cards */
.stat-card{display:flex;align-items:center;gap:14px}
.stat-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px}
.stat-icon.teal{background:var(--accent-l);color:var(--accent)}
.stat-icon.amber{background:var(--amber-l);color:var(--amber)}
.stat-icon.green{background:var(--green-l);color:var(--green)}
.stat-icon.red{background:var(--red-l);color:var(--red)}
.stat-value{font-size:24px;font-weight:700;display:block;line-height:1}
.stat-label{font-size:12px;color:var(--tx3)}

/* Chart Card */
.chart-card canvas{max-height:220px;width:100%!important}

/* Risk List */
.risk-list,.quickwins-list{display:flex;flex-direction:column;gap:8px}
.risk-item,.qw-item{display:flex;align-items:center;gap:10px;padding:10px;background:var(--bg);border-radius:var(--r);font-size:13px}
.risk-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.risk-dot.high{background:var(--red)}.risk-dot.medium{background:var(--amber)}.risk-dot.low{background:var(--green)}
.risk-item-text,.qw-item-text{flex:1}
.qw-pts{font-size:11px;font-weight:600;background:var(--accent-l);color:var(--accent);padding:2px 7px;border-radius:6px}

/* Activity Feed */
.activity-feed{display:flex;flex-direction:column;gap:0}
.activity-item{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid var(--bd2);font-size:13px}
.activity-item:last-child{border:none}
.activity-icon{width:28px;height:28px;border-radius:50%;background:var(--accent-l);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0}
.activity-text{flex:1;color:var(--tx2)}.activity-text strong{color:var(--tx)}
.activity-time{font-size:11px;color:var(--tx3);white-space:nowrap}

/* ============ BOARD ============ */
.board{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;height:calc(100vh - var(--topbar-h) - 48px)}
.board-col{background:var(--bg3);border-radius:var(--r-lg);display:flex;flex-direction:column;overflow:hidden}
.board-col-head{padding:12px 14px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--bd)}
.col-dot{width:9px;height:9px;border-radius:50%}
.col-dot.todo{background:var(--tx3)}.col-dot.progress{background:var(--amber)}.col-dot.review{background:var(--purple)}.col-dot.done{background:var(--green)}
.col-name{font-size:13px;font-weight:600}.col-count{font-size:11px;background:var(--bg2);padding:1px 7px;border-radius:8px;color:var(--tx3);font-weight:600;margin-left:auto}
.board-col-body{flex:1;overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:8px;min-height:60px}

/* Story Cards */
.story-card{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r);padding:12px;cursor:grab;transition:var(--transition)}
.story-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px);border-color:var(--accent)}
.story-card.sortable-ghost{opacity:.3}
.story-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:6px}
.story-card-title{font-size:13px;font-weight:600;line-height:1.4;flex:1}
.story-card-btns{display:flex;gap:2px;opacity:0;transition:var(--transition)}
.story-card:hover .story-card-btns{opacity:1}
.story-card-btns button{background:none;border:none;color:var(--tx3);cursor:pointer;padding:2px 4px;font-size:11px;border-radius:4px}
.story-card-btns button:hover{background:var(--bg);color:var(--tx)}
.story-card-desc{font-size:12px;color:var(--tx3);margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.story-card-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.tag{padding:2px 7px;border-radius:5px;font-size:10px;font-weight:600}
.tag-critical{background:var(--red-l);color:var(--red)}.tag-high{background:var(--amber-l);color:var(--amber)}.tag-medium{background:var(--blue-l);color:var(--blue)}.tag-low{background:var(--green-l);color:var(--green)}.tag-epic{background:var(--purple-l);color:var(--purple)}
.story-card-foot{display:flex;align-items:center;justify-content:space-between;margin-top:8px;padding-top:8px;border-top:1px solid var(--bd2)}
.story-pts{font-size:11px;font-weight:700;background:var(--accent-l);color:var(--accent);padding:2px 8px;border-radius:6px}
.story-assign{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--tx3)}
.story-avatar{width:20px;height:20px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700}

/* ============ TIMELINE ============ */
.timeline-container{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r-lg);overflow:hidden}
.timeline-header{display:flex;border-bottom:1px solid var(--bd);overflow-x:auto}
.timeline-dates{display:flex;min-width:max-content}
.timeline-day{min-width:80px;padding:10px;text-align:center;font-size:12px;font-weight:600;color:var(--tx3);border-right:1px solid var(--bd2)}
.timeline-day.today{background:var(--accent-l);color:var(--accent)}
.timeline-body{padding:12px;display:flex;flex-direction:column;gap:6px;max-height:500px;overflow-y:auto}
.timeline-row{display:flex;align-items:center;gap:8px;padding:6px 0}
.timeline-label{width:180px;font-size:12px;font-weight:500;color:var(--tx);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.timeline-bar-wrap{flex:1;height:24px;position:relative}
.timeline-bar{position:absolute;height:20px;border-radius:5px;font-size:10px;color:#fff;display:flex;align-items:center;padding:0 8px;font-weight:600;white-space:nowrap}

/* ============ BACKLOG ============ */
.backlog-wrap{max-width:900px}
.backlog-toolbar{display:flex;gap:12px;margin-bottom:16px}
.backlog-toolbar .input{max-width:300px}
.backlog-list{display:flex;flex-direction:column;gap:6px}
.backlog-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r);transition:var(--transition)}
.backlog-item:hover{box-shadow:var(--shadow)}
.backlog-item-pts{font-size:12px;font-weight:700;background:var(--accent-l);color:var(--accent);padding:3px 10px;border-radius:6px;min-width:36px;text-align:center}
.backlog-item-info{flex:1}.backlog-item-title{font-size:13px;font-weight:600}.backlog-item-desc{font-size:12px;color:var(--tx3);margin-top:2px}
.backlog-item-actions{display:flex;gap:6px}

/* ============ AI PLANNER ============ */
.planner-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.planner-card.wide{grid-column:span 2}
.ai-result{margin-top:14px;display:none}
.ai-result.show{display:block;padding:16px;background:var(--accent-l);border:1px solid var(--accent);border-radius:var(--r)}
.ai-result h4{font-size:14px;font-weight:600;color:var(--accent);margin-bottom:8px}
.ai-big{font-size:40px;font-weight:800;color:var(--accent);display:block;margin:6px 0}
.ai-row{display:flex;gap:16px;font-size:13px;margin:6px 0}
.ai-suggest-item{display:flex;align-items:center;justify-content:space-between;padding:10px;background:var(--bg2);border-radius:var(--r);margin-top:6px;font-size:13px}

/* Vote List */
.vote-list{display:flex;flex-direction:column;gap:8px}
.vote-item{display:flex;align-items:center;gap:10px;padding:10px;background:var(--bg);border-radius:var(--r)}
.vote-item-title{flex:1;font-size:13px;font-weight:500}
.vote-btns{display:flex;gap:4px}
.vote-btn{background:var(--bg2);border:1px solid var(--bd);border-radius:6px;padding:4px 10px;font-size:12px;cursor:pointer;transition:var(--transition);font-family:inherit}
.vote-btn:hover{border-color:var(--accent);color:var(--accent)}
.vote-btn.voted{background:var(--accent);color:#fff;border-color:var(--accent)}
.vote-count{font-size:12px;font-weight:600;color:var(--accent);min-width:20px;text-align:center}

/* ============ RISK RADAR ============ */
.risk-wrap{max-width:1000px}
.risk-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}
.risk-summary-card{padding:16px;border-radius:var(--r-lg);text-align:center}
.risk-summary-card.good{background:var(--green-l);color:var(--green)}.risk-summary-card.warn{background:var(--amber-l);color:var(--amber)}.risk-summary-card.bad{background:var(--red-l);color:var(--red)}
.risk-summary-num{font-size:32px;font-weight:800;display:block}
.risk-summary-label{font-size:12px;font-weight:500}
.risk-table-wrap{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r-lg);overflow:hidden}
.risk-table{width:100%;border-collapse:collapse;font-size:13px}
.risk-table th{text-align:left;padding:10px 14px;background:var(--bg3);font-weight:600;font-size:12px;color:var(--tx3)}
.risk-table td{padding:10px 14px;border-top:1px solid var(--bd2)}
.risk-level{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:5px;font-size:11px;font-weight:600}

/* ============ STANDUP ============ */
.standup-wrap{max-width:700px}
.standup-card{min-height:300px}
.standup-output{margin-top:16px;display:none}
.standup-output.show{display:block;padding:20px;background:var(--bg);border-radius:var(--r);font-size:14px;line-height:1.8}
.standup-output h4{font-size:15px;font-weight:600;margin-bottom:10px;color:var(--accent)}
.standup-output .standup-section{margin-bottom:12px}
.standup-output .standup-label{font-weight:600;font-size:12px;text-transform:uppercase;color:var(--tx3);margin-bottom:4px}

/* ============ CHARTS ============ */
.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* ============ WORKLOAD ============ */
.workload-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.workload-card{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r-lg);padding:20px}
.workload-header{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.workload-avatar{width:40px;height:40px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700}
.workload-name{font-size:14px;font-weight:600}.workload-role{font-size:12px;color:var(--tx3)}
.workload-bar-wrap{height:8px;background:var(--bg3);border-radius:4px;margin-bottom:8px;overflow:hidden}
.workload-bar{height:100%;border-radius:4px;transition:width .5s}
.workload-bar.ok{background:var(--green)}.workload-bar.warn{background:var(--amber)}.workload-bar.over{background:var(--red)}
.workload-stats{display:flex;justify-content:space-between;font-size:12px;color:var(--tx3)}
.workload-stories{margin-top:10px;display:flex;flex-direction:column;gap:4px}
.workload-story{font-size:12px;padding:6px 8px;background:var(--bg);border-radius:var(--r);display:flex;align-items:center;justify-content:space-between}

/* ============ RETRO ============ */
.retro-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.retro-col{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column}
.retro-head{padding:12px 14px;font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px}
.retro-head.good{background:var(--green-l);color:var(--green)}.retro-head.bad{background:var(--amber-l);color:var(--amber)}.retro-head.action{background:var(--blue-l);color:var(--blue)}
.retro-body{flex:1;padding:10px;display:flex;flex-direction:column;gap:6px;min-height:200px;overflow-y:auto}
.retro-note{padding:10px;background:var(--bg);border-radius:var(--r);font-size:13px;display:flex;align-items:flex-start;gap:8px}
.retro-note-text{flex:1}
.retro-note-actions{display:flex;align-items:center;gap:4px}
.retro-note-actions button{background:none;border:none;color:var(--tx3);cursor:pointer;font-size:11px;padding:2px}
.retro-note-actions button:hover{color:var(--tx)}
.retro-vote{font-size:11px;color:var(--accent);font-weight:600;display:flex;align-items:center;gap:3px}
.retro-col .btn{margin:8px 10px 10px}

/* ============ MODALS ============ */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.4);backdrop-filter:blur(4px);z-index:200;align-items:center;justify-content:center}
.modal-overlay.open{display:flex}
.modal{background:var(--bg2);border-radius:var(--r-xl);width:90%;max-width:520px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg)}
.modal-sm{max-width:400px}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--bd)}
.modal-head h2{font-size:16px;font-weight:600}
.modal form{padding:20px}

/* ============ SIDE PANEL ============ */
.side-panel{position:fixed;top:0;right:-420px;width:400px;height:100vh;background:var(--bg2);border-left:1px solid var(--bd);box-shadow:var(--shadow-lg);z-index:60;transition:right .3s;display:flex;flex-direction:column}
.side-panel.open{right:0}
.panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--bd)}
.panel-header h2{font-size:16px;font-weight:600}
.panel-body{flex:1;overflow-y:auto;padding:20px}

/* ============ COMMAND PALETTE ============ */
.command-palette-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);backdrop-filter:blur(4px);z-index:300;align-items:flex-start;justify-content:center;padding-top:20vh}
.command-palette-overlay.open{display:flex}
.command-palette{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r-xl);width:90%;max-width:560px;box-shadow:var(--shadow-lg);overflow:hidden}
.command-input-wrap{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--bd)}
.command-input-wrap i{color:var(--tx3);font-size:16px}
.command-input-wrap input{flex:1;border:none;background:none;font-size:15px;color:var(--tx);font-family:inherit;outline:none}
.command-input-wrap kbd{font-size:11px;background:var(--bg3);padding:2px 6px;border-radius:4px;color:var(--tx3);font-family:inherit}
.command-results{max-height:300px;overflow-y:auto;padding:8px}
.command-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--r);cursor:pointer;font-size:13px;color:var(--tx2);transition:var(--transition)}
.command-item:hover,.command-item.selected{background:var(--accent-bg);color:var(--accent)}
.command-item i{width:18px;text-align:center;font-size:13px}

/* ============ TOAST ============ */
.toast{position:fixed;bottom:24px;right:24px;background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r);box-shadow:var(--shadow-lg);padding:12px 18px;display:flex;align-items:center;gap:8px;transform:translateY(80px);opacity:0;transition:.3s;z-index:400;font-size:13px;font-weight:500}
.toast.show{transform:translateY(0);opacity:1}
.toast i{color:var(--green);font-size:16px}

/* ============ RESPONSIVE ============ */
@media(max-width:1024px){
    .board{grid-template-columns:repeat(2,1fr)}
    .dash-grid{grid-template-columns:repeat(2,1fr)}
    .hero-card{grid-column:span 2}
    .wide{grid-column:span 2}
    .charts-grid,.planner-grid{grid-template-columns:1fr}
    .planner-card.wide,.wide{grid-column:span 1}
    .retro-grid{grid-template-columns:1fr}
    .form-grid{grid-template-columns:repeat(2,1fr)}
    .risk-summary{grid-template-columns:1fr}
}
@media(max-width:768px){
    .sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}
    .main{margin-left:0}
    .hamburger{display:block}
    .board{grid-template-columns:1fr}
    .topbar-right .health-badge{display:none}
}