/* ===== LBV Ticketsysteem, huisstijl (premium) ===== */
:root{
  --green:#b9d637; --green-deep:#a3bf2a; --green-soft:#eef4d2; --green-glow:rgba(185,214,55,.5);
  --ink:#151a21; --black:#0a0a0a; --white:#fff;
  --ink900:#0a0d12; --ink800:#11161e; --ink700:#1b212b; --ink-line:rgba(255,255,255,.10);
  --mist:#f0f2f6; --mist2:#e7eaf0; --line:#e4e7ee; --muted:#6b7480;
  --warn:#e8a33d; --warn-soft:#fdf2e1; --danger:#e0512f; --danger-soft:#fdece5;
  --display:"Barlow Condensed",Arial,Helvetica,sans-serif;
  --body:"Barlow Semi Condensed","Barlow",Arial,Helvetica,sans-serif;
  --r:14px; --shadow:0 24px 60px -22px rgba(15,23,32,.45); --shadow-sm:0 6px 20px -10px rgba(15,23,32,.30);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--mist);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased}
button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}
svg{display:block}
::placeholder{color:#9aa3ad}
[hidden]{display:none!important}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--display);font-weight:700;text-transform:uppercase;letter-spacing:.02em;font-size:16px;padding:10px 18px;border-radius:10px;border:2px solid transparent;cursor:pointer;transition:background-color .18s,color .18s,border-color .18s,transform .18s,box-shadow .18s;min-height:44px;white-space:nowrap}
.btn svg{width:17px;height:17px}
.btn-green{background:var(--green);color:var(--black);box-shadow:0 8px 20px -10px var(--green-glow)}
.btn-green:hover{background:var(--green-deep);transform:translateY(-1px)}
.btn-dark{background:var(--black);color:#fff}
.btn-dark:hover{background:#000;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{background:var(--mist);border-color:var(--ink)}
.btn-sm{font-size:14px;padding:8px 14px;min-height:38px}
.iconbtn{display:grid;place-items:center;width:38px;height:38px;border-radius:9px;border:0;background:transparent;cursor:pointer;color:inherit;transition:background .18s}
.iconbtn:hover{background:rgba(0,0,0,.07)}
.iconbtn svg{width:20px;height:20px}
:focus-visible{outline:3px solid var(--green);outline-offset:2px}

/* premium selects: native pijl weg, eigen chevron via los bestand */
select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}
select::-ms-expand{display:none}

/* ---- app bar ---- */
.appbar{position:sticky;top:0;z-index:60;display:flex;align-items:center;gap:20px;background:rgba(255,255,255,.88);backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid var(--line);padding:0 22px;min-height:68px}
.brand{display:flex;align-items:center;gap:13px;flex:0 0 auto}
.brand-logo{height:36px;width:auto}
.brand-div{width:1px;height:28px;background:var(--line)}
.brand-name{font-family:var(--display);text-transform:uppercase;font-weight:700;font-size:20px;letter-spacing:.02em}
.search{flex:1 1 auto;max-width:440px;display:flex;align-items:center;gap:10px;background:var(--mist);border:1px solid transparent;border-radius:11px;padding:0 14px;height:44px;transition:border-color .18s,background .18s,box-shadow .18s}
.search:focus-within{background:#fff;border-color:var(--green);box-shadow:0 0 0 4px rgba(185,214,55,.18)}
.search svg{width:18px;height:18px;color:var(--muted);flex:0 0 auto}
.search input{flex:1;border:0;background:transparent;outline:none;height:100%}
.appbar-right{display:flex;align-items:center;gap:14px;flex:0 0 auto}
.me{width:40px;height:40px;border-radius:50%;background:var(--black);color:#fff;display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:15px}

/* ===== login (demo-gate) ===== */
.login{position:fixed;inset:0;z-index:200;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--ink900);color:#e8edf3;padding:24px;overflow:hidden}
.login::before{content:"";position:absolute;top:-25%;left:50%;transform:translateX(-50%);width:90%;height:120%;background:radial-gradient(closest-side,rgba(185,214,55,.20),transparent 70%);pointer-events:none}
.login-card{position:relative;z-index:1;background:#fff;color:var(--ink);width:404px;max-width:100%;border-radius:18px;padding:38px 36px 34px;box-shadow:0 44px 90px -32px rgba(0,0,0,.7);text-align:center}
.login-logo{height:52px;width:auto;margin:0 auto 16px}
.login-app{font-family:var(--display);text-transform:uppercase;font-weight:700;font-size:25px;letter-spacing:.02em}
.login-sub{color:var(--muted);margin:5px 0 24px;font-size:15px}
.login form{display:flex;flex-direction:column;gap:14px;text-align:left}
.lfld{display:flex;flex-direction:column;gap:6px;font-family:var(--display);text-transform:uppercase;font-size:12px;letter-spacing:.05em;color:var(--muted);font-weight:600}
.lfld input{font-family:var(--body);text-transform:none;letter-spacing:0;color:var(--ink);font-weight:500;font-size:16px;background:var(--mist);border:1px solid transparent;border-radius:10px;padding:12px 14px;min-height:48px}
.lfld input:focus{outline:none;background:#fff;border-color:var(--green);box-shadow:0 0 0 4px rgba(185,214,55,.18)}
.login-err{background:var(--danger-soft);color:var(--danger);border-radius:9px;padding:9px 12px;font-size:14px;font-weight:500}
.login-btn{width:100%;justify-content:center;margin-top:4px;font-size:17px}
.login-foot{position:relative;z-index:1;margin-top:22px;display:flex;align-items:center;gap:9px;color:#8a93a0;font-family:var(--display);text-transform:uppercase;letter-spacing:.04em;font-size:13px}
.login-foot .stripe{width:22px;height:6px;background:var(--green);transform:skewX(-18deg)}

/* ===== AI command center (donker) ===== */
.cmd{background:var(--ink900);color:#e8edf3;padding:22px 22px 24px;position:relative;overflow:hidden}
.cmd::before{content:"";position:absolute;top:-60%;right:-5%;width:50%;height:200%;background:radial-gradient(closest-side,rgba(185,214,55,.16),transparent 70%);pointer-events:none}
.cmd::after{content:"";position:absolute;inset:0;opacity:.5;mix-blend-mode:overlay;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E")}
.cmd-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:16px}
.cmd-brief{display:flex;flex-direction:column}
.cc-eyebrow{display:flex;align-items:center;gap:9px;font-family:var(--display);text-transform:uppercase;letter-spacing:.08em;font-weight:700;font-size:14px;color:var(--green)}
.cc-eyebrow .spark{width:9px;height:9px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 var(--green-glow);animation:pulse 2.4s ease-out infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 var(--green-glow)}70%{box-shadow:0 0 0 11px rgba(185,214,55,0)}100%{box-shadow:0 0 0 0 rgba(185,214,55,0)}}
.cc-date{color:#8a93a0;font-weight:600}
.cc-headline{font-family:var(--display);font-weight:600;font-size:clamp(24px,2.6vw,34px);line-height:1.12;margin:14px 0 16px;color:#fff;max-width:20em}
.cc-headline b{color:var(--green);font-weight:700}
.cc-headline .crit{color:#ff8a6b;font-weight:700}
.cc-chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:auto}
.cc-chip{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.06);border:1px solid var(--ink-line);border-radius:9px;padding:8px 12px;font-size:14px;font-weight:500}
.cc-chip b{font-family:var(--display);font-size:18px;font-weight:800}
.cc-chip .d{width:8px;height:8px;border-radius:50%}

.cmd-panel{position:relative;z-index:1;background:rgba(255,255,255,.045);border:1px solid var(--ink-line);border-radius:var(--r);padding:15px 17px}
.cc-title{font-family:var(--display);text-transform:uppercase;letter-spacing:.05em;font-weight:600;font-size:13px;color:#9aa3b0;margin-bottom:12px}
.radar{display:flex;align-items:center;gap:16px}
.radar svg{flex:0 0 auto}
.radar-leg{list-style:none;display:flex;flex-direction:column;gap:8px;font-size:14px}
.radar-leg li{display:flex;align-items:center;gap:8px;color:#cfd5de}
.radar-leg .d{width:9px;height:9px;border-radius:3px;transform:skewX(-12deg)}
.radar-leg b{font-family:var(--display);font-weight:800;color:#fff;margin-left:2px}
.workload{display:flex;flex-direction:column;gap:11px}
.wl{display:flex;align-items:center;gap:10px}
.wl .av{width:26px;height:26px;font-size:11px}
.wl .nm{font-size:14px;color:#cfd5de;width:42px;flex:0 0 auto;font-weight:500}
.wl .track{flex:1;height:8px;border-radius:6px;background:rgba(255,255,255,.09);overflow:hidden}
.wl .track i{display:block;height:100%;border-radius:6px;background:var(--green)}
.wl .track i.hot{background:var(--warn)}
.wl .n{font-family:var(--display);font-weight:700;font-size:14px;color:#aeb6c2;width:18px;text-align:right}

/* AI insight */
.insight{position:relative;z-index:1;width:100%;text-align:left;margin-top:16px;display:flex;align-items:center;gap:16px;background:linear-gradient(100deg,rgba(185,214,55,.14),rgba(185,214,55,.04));border:1px solid rgba(185,214,55,.34);border-radius:var(--r);padding:16px 20px;cursor:pointer;color:#eef3df;transition:border-color .2s,transform .2s,box-shadow .2s}
.insight:hover{border-color:var(--green);transform:translateY(-2px);box-shadow:0 16px 36px -18px var(--green-glow)}
.insight .ai-ico{flex:0 0 auto;width:42px;height:42px;border-radius:11px;background:var(--green);color:#0a0a0a;display:grid;place-items:center}
.insight .ai-ico svg{width:23px;height:23px}
.insight .it{flex:1}
.insight .it .lab{font-family:var(--display);text-transform:uppercase;letter-spacing:.06em;font-weight:700;font-size:12px;color:var(--green);margin-bottom:3px}
.insight .it .tx{font-size:16px;color:#f0f3e8;line-height:1.4}
.insight .it .tx b{color:#fff;font-weight:700}
.insight .go{flex:0 0 auto;display:inline-flex;align-items:center;gap:7px;font-family:var(--display);text-transform:uppercase;font-weight:700;font-size:14px;color:var(--green)}
.insight .go svg{width:18px;height:18px}

/* ---- toolbar ---- */
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 22px 6px;flex-wrap:wrap}
.filters{display:flex;align-items:flex-end;gap:13px;flex-wrap:wrap}
.filters label{display:flex;flex-direction:column;font-family:var(--display);text-transform:uppercase;font-size:12px;letter-spacing:.05em;color:var(--muted);font-weight:600;gap:4px}
.filters select{font-family:var(--body);text-transform:none;letter-spacing:0;color:var(--ink);font-weight:500;font-size:15px;background:#fff url(chevron.svg) no-repeat right 12px center;border:1px solid var(--line);border-radius:9px;padding:9px 34px 9px 12px;min-height:40px;cursor:pointer;transition:border-color .15s}
.filters select:hover{border-color:var(--ink)}
.chip-reset{background:none;border:0;color:var(--danger);font-weight:600;cursor:pointer;padding:9px 4px;font-size:14px}
.chip-reset:hover{text-decoration:underline}
.viewtoggle{display:flex;background:#fff;border:1px solid var(--line);border-radius:11px;padding:4px;gap:2px}
.viewtoggle button{display:inline-flex;align-items:center;gap:7px;font-family:var(--display);text-transform:uppercase;font-weight:600;font-size:15px;letter-spacing:.02em;border:0;background:transparent;color:var(--muted);padding:8px 16px;border-radius:8px;cursor:pointer;transition:background .18s,color .18s}
.viewtoggle button svg{width:17px;height:17px}
.viewtoggle button.active{background:var(--black);color:#fff}

/* ---- board ---- */
.main{padding:14px 22px 44px}
.board{display:grid;grid-template-columns:repeat(4,minmax(272px,1fr));gap:16px;align-items:start}
.col{background:#f6f8fb;border:1px solid var(--line);border-radius:var(--r);display:flex;flex-direction:column;min-height:150px;transition:border-color .15s,background .15s}
.col.dragover{border-color:var(--green);background:var(--green-soft);box-shadow:0 0 0 3px rgba(185,214,55,.25) inset}
.col-head{display:flex;align-items:center;gap:9px;padding:15px 15px 11px}
.col-dot{width:11px;height:11px;border-radius:3px;transform:skewX(-12deg);flex:0 0 auto}
.col-head h3{font-family:var(--display);text-transform:uppercase;font-weight:700;font-size:16px;letter-spacing:.02em}
.col-head .cnt{margin-left:auto;font-family:var(--display);font-weight:700;font-size:13px;color:var(--muted);background:#fff;border:1px solid var(--line);border-radius:20px;padding:1px 10px;min-width:26px;text-align:center}
.col-body{display:flex;flex-direction:column;gap:11px;padding:3px 11px 13px;min-height:40px}
.col-empty{font-size:14px;color:#aab1ba;text-align:center;padding:16px 0;font-style:italic}

/* ---- ticket card ---- */
.card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:13px 15px;cursor:pointer;transition:box-shadow .18s,border-color .18s,transform .12s;position:relative;overflow:hidden}
.card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--green);opacity:0;transition:opacity .18s}
.card:hover{box-shadow:var(--shadow-sm);border-color:#d3d9e2;transform:translateY(-2px)}
.card:hover::before{opacity:1}
.card.risk-kritiek::before,.card.risk-laat::before{background:var(--danger);opacity:1}
.card.risk-krap::before{background:var(--warn);opacity:1}
.card.dragging{opacity:.45;transform:rotate(1.5deg)}
.card .ctop{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:9px}
.card .cid{font-family:var(--display);font-weight:600;font-size:13px;color:var(--muted);letter-spacing:.03em}
.card .ctitle{font-weight:600;font-size:16.5px;line-height:1.32;color:var(--ink);margin-bottom:11px}
.card .cmeta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:11px}
.card .cfoot{display:flex;align-items:center;gap:10px}
.card .cfoot+.cfoot{margin-top:10px}

/* badges */
.tbadge{display:inline-flex;align-items:center;gap:6px;font-family:var(--display);text-transform:uppercase;font-weight:600;font-size:12px;letter-spacing:.03em;background:var(--mist);color:#3b424b;padding:4px 9px;border-radius:6px}
.tbadge .d{width:8px;height:8px;border-radius:50%;flex:0 0 auto}
.prio{display:inline-flex;align-items:center;gap:5px;font-family:var(--display);text-transform:uppercase;font-weight:700;font-size:12px;letter-spacing:.04em}
.prio .b{width:7px;height:7px;border-radius:50%}
.prio.laag{color:#8a929c}.prio.laag .b{background:#aab1ba}
.prio.normaal{color:#5c636d}.prio.normaal .b{background:#7d8590}
.prio.hoog{color:#b9791f}.prio.hoog .b{background:var(--warn)}
.prio.urgent{color:var(--danger)}.prio.urgent .b{background:var(--danger)}
.av{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:12px;color:#fff;flex:0 0 auto}
.av.lg{width:40px;height:40px;font-size:15px}
.runtime{display:inline-flex;align-items:center;gap:5px;font-size:13px;color:var(--muted);font-weight:500}
.runtime svg{width:14px;height:14px}
.runtime.late{color:var(--danger);font-weight:600}
.prog{display:flex;align-items:center;gap:9px;flex:1}
.prog .bar{flex:1;height:6px;border-radius:6px;background:var(--mist2);overflow:hidden}
.prog .bar i{display:block;height:100%;background:var(--green);border-radius:6px;transition:width .3s}
.prog .pct{font-family:var(--display);font-weight:700;font-size:12px;color:var(--muted);min-width:30px;text-align:right}
.cflag{margin-left:auto;display:inline-flex;align-items:center;gap:5px;font-family:var(--display);text-transform:uppercase;font-weight:700;font-size:11px;letter-spacing:.03em;color:#5f7012;background:var(--green-soft);border:1px solid #d8e4a6;padding:2px 8px;border-radius:20px}
.cflag svg{width:12px;height:12px}

/* ---- list ---- */
.listwrap{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm)}
.ttable{width:100%;border-collapse:collapse}
.ttable th{font-family:var(--display);text-transform:uppercase;font-size:13px;letter-spacing:.04em;color:var(--muted);font-weight:600;text-align:left;padding:13px 16px;border-bottom:2px solid var(--line);cursor:pointer;user-select:none;white-space:nowrap}
.ttable th:hover{color:var(--ink)}
.ttable th[aria-sort]{color:var(--ink)}
.ttable td{padding:11px 16px;border-bottom:1px solid var(--line);vertical-align:middle}
.ttable tbody tr{cursor:pointer;transition:background .14s}
.ttable tbody tr:hover{background:var(--mist)}
.ttable .c-title{font-weight:600;max-width:300px}
.ttable .c-id{font-family:var(--display);font-weight:600;color:var(--muted);font-size:14px;white-space:nowrap}
.ttable .who{display:flex;align-items:center;gap:8px;white-space:nowrap}
.ttable .prog{min-width:120px}
.spill{display:inline-flex;align-items:center;gap:7px;font-family:var(--display);text-transform:uppercase;font-weight:700;font-size:13px;letter-spacing:.03em;padding:5px 11px;border-radius:20px;white-space:nowrap}
.spill .d{width:9px;height:9px;border-radius:3px;transform:skewX(-12deg)}

/* ---- detailpaneel ---- */
.detail{position:fixed;top:0;right:0;height:100%;width:460px;max-width:94vw;background:#fff;z-index:80;box-shadow:var(--shadow);transform:translateX(100%);transition:transform .34s cubic-bezier(.2,.7,.2,1);display:flex;flex-direction:column;overflow:hidden}
.detail.open{transform:none}
.dt-head{padding:20px 22px 16px;border-bottom:1px solid var(--line)}
.dt-head .row1{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:9px}
.dt-head .cid{font-family:var(--display);font-weight:600;color:var(--muted);letter-spacing:.04em;font-size:15px}
.dt-head h2{font-family:var(--display);font-weight:700;font-size:25px;line-height:1.14;margin-top:9px}
.dt-body{padding:18px 22px 30px;overflow-y:auto;flex:1}

/* AI-blok */
.aibox{background:linear-gradient(180deg,#10151c,#0a0d12);color:#e8edf3;border-radius:13px;padding:17px 18px;margin-bottom:20px;position:relative;overflow:hidden}
.aibox::before{content:"";position:absolute;top:-50%;right:-10%;width:55%;height:200%;background:radial-gradient(closest-side,rgba(185,214,55,.18),transparent 70%)}
.aibox>*{position:relative;z-index:1}
.aibox .ah{display:flex;align-items:center;gap:9px;font-family:var(--display);text-transform:uppercase;letter-spacing:.06em;font-weight:700;font-size:13px;color:var(--green);margin-bottom:11px}
.aibox .ah svg{width:18px;height:18px}
.aibox .asum{font-size:15px;color:#dfe5ec;line-height:1.5;margin-bottom:14px}
.ai-metrics{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.ai-m{background:rgba(255,255,255,.05);border:1px solid var(--ink-line);border-radius:10px;padding:10px 12px}
.ai-m .k{font-family:var(--display);text-transform:uppercase;font-size:11px;letter-spacing:.04em;color:#9aa3b0}
.ai-m .v{font-family:var(--display);font-weight:800;font-size:21px;color:#fff;margin-top:2px}
.ai-m .v small{font-size:13px;color:#aeb6c2;font-weight:600}
.ai-m .mini{height:5px;border-radius:5px;background:rgba(255,255,255,.1);margin-top:7px;overflow:hidden}
.ai-m .mini i{display:block;height:100%;background:var(--green);border-radius:5px}
.deadline-meter{display:flex;align-items:center;gap:8px;margin-bottom:14px;font-size:14px;color:#cfd5de}
.deadline-meter .pill{font-family:var(--display);text-transform:uppercase;font-weight:700;font-size:12px;letter-spacing:.03em;padding:3px 9px;border-radius:20px}
.dm-optijd{background:rgba(185,214,55,.18);color:#cfe06a}
.dm-krap{background:rgba(232,163,61,.18);color:#f0bd72}
.dm-kritiek{background:rgba(224,81,47,.2);color:#ff9c80}
.ai-actions{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:15px}
.ai-actions li{display:flex;align-items:flex-start;gap:9px;font-size:14.5px;color:#dfe5ec}
.ai-actions li svg{width:16px;height:16px;color:var(--green);flex:0 0 auto;margin-top:3px}
.ai-cta{display:flex;gap:9px;flex-wrap:wrap}
.ai-cta .btn-green{box-shadow:none}
.ai-cta .btn-ai{background:rgba(255,255,255,.08);color:#fff;border:1px solid var(--ink-line)}
.ai-cta .btn-ai:hover{background:rgba(255,255,255,.14)}
.concept{margin-top:13px;background:#fff;color:#2b333d;border-radius:10px;padding:15px 16px;font-size:14.5px;line-height:1.55;border:1px solid rgba(255,255,255,.2);animation:rise .3s ease backwards}
.concept h5{font-family:var(--display);text-transform:uppercase;font-size:13px;letter-spacing:.04em;color:var(--muted);margin-bottom:8px;display:flex;align-items:center;gap:7px}
.concept h5 svg{width:15px;height:15px;flex:0 0 auto;color:var(--green-deep)}
.concept p{margin-bottom:8px}
.concept .sig{color:var(--muted)}

.dt-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 18px;margin-bottom:20px}
.dt-fld{display:flex;flex-direction:column;gap:6px}
.dt-fld.full{grid-column:1/-1}
.dt-fld .k{font-family:var(--display);text-transform:uppercase;font-size:12px;letter-spacing:.05em;color:var(--muted);font-weight:600}
.dt-fld .v{font-weight:500}
.dt-fld select{background:#fff url(chevron.svg) no-repeat right 12px center;border:1px solid var(--line);border-radius:9px;padding:9px 34px 9px 11px;cursor:pointer;font-weight:500;min-height:40px}
.dt-fld select:hover{border-color:var(--ink)}
.dt-sec-title{font-family:var(--display);text-transform:uppercase;font-weight:700;font-size:15px;letter-spacing:.04em;margin:4px 0 13px;display:flex;align-items:center;gap:9px}
.dt-sec-title::before{content:"";width:22px;height:6px;background:var(--green);transform:skewX(-18deg)}
.phases{display:flex;gap:6px;margin-bottom:10px}
.phase{flex:1;text-align:center}
.phase .pl{height:7px;border-radius:5px;background:var(--mist2);margin-bottom:7px}
.phase.done .pl,.phase.active .pl{background:var(--green)}
.phase .pn{font-family:var(--display);text-transform:uppercase;font-size:11px;letter-spacing:.02em;font-weight:600;color:var(--muted)}
.phase.active .pn{color:var(--ink)}
.range{display:flex;align-items:center;gap:12px;margin:6px 0 4px}
.range input[type=range]{flex:1;accent-color:var(--green)}
.range .rv{font-family:var(--display);font-weight:800;font-size:20px;min-width:54px;text-align:right}
.desc{background:var(--mist);border-radius:10px;padding:14px 16px;font-size:15.5px;color:#39414b;margin-bottom:20px;line-height:1.55}
.timeline{display:flex;flex-direction:column}
.tl{display:grid;grid-template-columns:auto 1fr;gap:13px;padding-bottom:16px;position:relative}
.tl::before{content:"";position:absolute;left:14px;top:28px;bottom:0;width:2px;background:var(--line)}
.tl:last-child::before{display:none}
.tl .dot{width:28px;height:28px;border-radius:50%;background:var(--green-soft);display:grid;place-items:center;z-index:1}
.tl .dot svg{width:15px;height:15px;color:#7b8a30}
.tl .tc .tt{color:var(--ink);font-size:15px}
.tl .tc .td{font-size:12.5px;color:var(--muted);font-family:var(--display);letter-spacing:.02em;text-transform:uppercase;margin-top:2px}
.actadd{display:flex;gap:9px;margin-bottom:16px}
.actadd input{flex:1;background:#fff;border:1px solid var(--line);border-radius:9px;padding:10px 12px;min-height:42px;font-size:15px}
.actadd input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 4px rgba(185,214,55,.16)}
.actadd .btn{flex:0 0 auto}
.ai-note{font-size:14px;color:#cfd5de;margin-bottom:13px}
.ai-note b{color:#fff}
.taakcount{margin-left:auto;font-family:var(--display);font-size:13px;font-weight:700;color:var(--muted);background:var(--mist);border-radius:20px;padding:2px 11px}
.todo{list-style:none;display:flex;flex-direction:column;margin-bottom:12px}
.todo li{display:flex;align-items:flex-start;gap:11px;padding:9px 0;border-bottom:1px solid var(--line)}
.todo li:last-child{border-bottom:0}
.tcheck{flex:0 0 auto;width:22px;height:22px;border-radius:6px;border:2px solid #cfd5dd;background:#fff;cursor:pointer;display:grid;place-items:center;margin-top:1px;padding:0;transition:background .15s,border-color .15s}
.tcheck:hover{border-color:var(--green)}
.tcheck svg{width:13px;height:13px;color:#0a0a0a;opacity:0;transition:opacity .15s}
.todo li.done .tcheck{background:var(--green);border-color:var(--green)}
.todo li.done .tcheck svg{opacity:1}
.todo li span{font-size:15px;color:var(--ink);line-height:1.45;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.todo li.done span{color:var(--muted);text-decoration:line-through}
.aitag{font-family:var(--display);font-style:normal;font-weight:700;font-size:10px;letter-spacing:.06em;color:#5f7012;background:var(--green-soft);border:1px solid #d8e4a6;border-radius:5px;padding:1px 5px;text-decoration:none}
.todo li.done .aitag{opacity:.5}
.todoadd{display:flex;gap:9px;margin:0 0 20px}
.todoadd input{flex:1;background:#fff;border:1px solid var(--line);border-radius:9px;padding:10px 12px;min-height:42px;font-size:15px}
.todoadd input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 4px rgba(185,214,55,.16)}
.todoadd .btn{flex:0 0 auto}

/* ---- modal ---- */
.modal{position:fixed;inset:0;z-index:90;display:none;align-items:flex-start;justify-content:center;padding:6vh 20px}
.modal.open{display:flex}
.modal-card{background:#fff;border-radius:16px;width:580px;max-width:100%;box-shadow:var(--shadow);overflow:hidden;animation:pop .25s cubic-bezier(.2,.7,.2,1)}
@keyframes pop{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line)}
.modal-head h2{font-family:var(--display);text-transform:uppercase;font-weight:700;font-size:22px}
.modal-body{padding:20px 22px 22px;display:grid;grid-template-columns:1fr 1fr;gap:14px 16px}
.fld{display:flex;flex-direction:column;gap:6px;font-family:var(--display);text-transform:uppercase;font-size:12px;letter-spacing:.05em;color:var(--muted);font-weight:600}
.fld.full{grid-column:1/-1}
.fld input,.fld select,.fld textarea{font-family:var(--body);text-transform:none;letter-spacing:0;color:var(--ink);font-weight:500;font-size:15.5px;background:#fff;border:1px solid var(--line);border-radius:9px;padding:10px 12px;min-height:42px}
.fld select{background:#fff url(chevron.svg) no-repeat right 12px center;padding-right:34px}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 4px rgba(185,214,55,.16)}
.fld textarea{resize:vertical;min-height:74px}
.ai-preview{grid-column:1/-1;background:var(--ink900);color:#e8edf3;border-radius:11px;padding:13px 15px;display:flex;align-items:center;gap:11px;font-size:14.5px;animation:rise .3s ease}
.ai-preview .ai-ico{width:34px;height:34px;border-radius:9px;background:var(--green);color:#0a0a0a;display:grid;place-items:center;flex:0 0 auto}
.ai-preview .ai-ico svg{width:19px;height:19px}
.ai-preview b{color:var(--green)}
.modal-foot{grid-column:1/-1;display:flex;justify-content:flex-end;gap:10px;margin-top:6px}
.overlay{position:fixed;inset:0;background:rgba(10,13,18,.55);z-index:70;backdrop-filter:blur(3px)}

/* ---- entrance ---- */
.card,.cmd-panel,.insight{animation:rise .42s cubic-bezier(.2,.7,.2,1) backwards}
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ---- responsive ---- */
@media(max-width:1100px){.cmd-grid{grid-template-columns:1fr 1fr}.cmd-brief{grid-column:1/-1}}
@media(max-width:980px){
  .board{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:14px}
  .col{flex:0 0 282px;scroll-snap-align:start}
}
@media(max-width:760px){
  .appbar{flex-wrap:wrap;gap:12px;padding:12px 16px;min-height:0}
  .search{order:3;max-width:none;flex-basis:100%}
  .cmd-grid{grid-template-columns:1fr}
  .insight{flex-wrap:wrap}.insight .go{width:100%}
  .stats{padding:16px}.main{padding:12px 16px 32px}.toolbar{padding:14px 16px 4px}
  .modal-body{grid-template-columns:1fr}
  .ttable th:nth-child(3),.ttable td:nth-child(3),.ttable th:nth-child(6),.ttable td:nth-child(6){display:none}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
