/* ===== dashboard v0.4 ===== */
.topbar{display:flex;align-items:center;gap:13px;margin-bottom:20px;flex-wrap:wrap}
.search{flex:1;min-width:200px;max-width:520px;display:flex;align-items:center;gap:10px;background:var(--chip);border:1.5px solid var(--line2);border-radius:13px;padding:10px 15px;transition:border-color .2s}
.search:focus-within{border-color:var(--cyan)}
.search svg.i{width:17px;height:17px;color:var(--tx3)}
.search input{flex:1;background:none;border:0;outline:0;color:var(--tx);font:500 .92rem 'Inter';padding:0}
.qadd{margin-left:auto;display:flex;align-items:center;gap:9px;border:0;border-radius:12px;padding:11px 17px;background:linear-gradient(135deg,#ffd98a,var(--gold));color:#3a2a08;font:700 .85rem 'Inter';cursor:pointer;transition:.15s}
.qadd:hover{transform:translateY(-1px)}
.qadd svg.i{width:15px;height:15px;stroke-width:2.4}
.avatar{width:40px;height:40px;border-radius:50%;background:var(--grad);display:grid;place-items:center;color:#fff;font:700 1rem 'Inter';flex:none;box-shadow:0 0 0 2px var(--bg),0 0 0 3px rgba(0,183,255,.55)}
.bell{position:relative;width:40px;height:40px;border-radius:12px;background:var(--chip);border:1px solid var(--line2);display:grid;place-items:center;color:var(--tx2);cursor:pointer;flex:none}
.bell b{position:absolute;top:-4px;right:-4px;width:17px;height:17px;border-radius:50%;background:linear-gradient(135deg,#ffd98a,var(--gold));color:#3a2a08;font:700 .62rem 'Inter';display:grid;place-items:center}

.greetrow{display:flex;align-items:flex-end;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.greetrow h2{font-size:1.75rem;font-weight:800;letter-spacing:-.03em}
.greetrow p{color:var(--gold);font-size:.9rem;font-weight:600;margin-top:4px}
.greetrow .modes{margin-left:auto}

.vall{display:inline-flex;align-items:center;gap:6px;margin-top:13px;color:var(--cyan);font:600 .8rem 'Inter';cursor:pointer}
.vall::after{content:"\2192"}

/* hour rail schedule */
.sched{display:flex;flex-direction:column;gap:8px}
.ev{display:flex;gap:12px;align-items:stretch}
.ev time{width:48px;flex:none;color:var(--tx3);font:600 .74rem 'Inter';padding-top:10px}
.ev .blk{flex:1;border-radius:11px;padding:9px 13px;border:1px solid var(--line2);border-left:3.5px solid var(--c,var(--cyan));background:var(--chip);display:flex;align-items:center;gap:10px}
.ev .blk b{font-size:.86rem;display:block}
.ev .blk small{color:var(--tx3);font-size:.72rem}
.ev .blk .avs{margin-left:auto;display:flex}
.ev .blk .avs .av{width:24px;height:24px;font-size:.62rem;margin-left:-6px}

/* member rows + status chips */
.mem{display:flex;align-items:center;gap:12px;padding:9px 0;border-bottom:1px solid var(--line2)}
.mem:last-child{border:0}
.mem .av{width:34px;height:34px;border-radius:50%;background:var(--grad);color:#fff;font:700 .8rem 'Inter';display:grid;place-items:center;flex:none}
.mem b{display:block;font-size:.88rem}
.mem small{color:var(--tx3);font-size:.72rem}
.chip{margin-left:auto;font:700 .66rem 'Inter';padding:3px 11px;border-radius:99px;flex:none}
.chip.g{color:#3ddc97;background:rgba(61,220,151,.1);border:1px solid rgba(61,220,151,.3)}
.chip.b{color:var(--cyan);background:rgba(0,183,255,.08);border:1px solid var(--line)}
.chip.a{color:var(--gold);background:rgba(245,184,76,.1);border:1px solid rgba(245,184,76,.3)}

/* events list */
.evt{display:flex;align-items:center;gap:12px;padding:9px 0;border-bottom:1px solid var(--line2);font-size:.88rem}
.evt:last-child{border:0}
.evt .ico{width:34px;height:34px;border-radius:10px;background:var(--chip);border:1px solid var(--line2);display:grid;place-items:center;color:var(--cyan);flex:none}
.evt .ico svg.i{width:16px;height:16px}
.evt .when{margin-left:auto;text-align:right;color:var(--tx3);font:600 .72rem 'Inter';line-height:1.4;flex:none}

/* alerts */
.alert{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--line2);font-size:.86rem}
.alert:last-child{border:0}
.alert .wic{width:30px;height:30px;border-radius:50%;flex:none;display:grid;place-items:center;color:var(--gold);background:rgba(245,184,76,.12);border:1px solid rgba(245,184,76,.3)}
.alert .wic svg.i{width:15px;height:15px}
.alert.ok .wic{color:#3ddc97;background:rgba(61,220,151,.1);border-color:rgba(61,220,151,.3)}
.alert small{display:block;color:var(--tx3);font-size:.72rem;margin-top:2px}
.sbtn{margin-left:auto;border:0;border-radius:9px;padding:7px 14px;font:700 .74rem 'Inter';cursor:pointer;transition:.15s;flex:none}
.sbtn.solid{background:var(--grad);color:#fff}
.sbtn.line{background:transparent;color:var(--tx2);border:1.5px solid var(--line2)}
.sbtn:hover{transform:translateY(-1px)}

/* tasks */
.pbar{height:7px;background:var(--line2);border-radius:9px;overflow:hidden;margin:12px 0 6px}
.pbar i{display:block;height:100%;background:var(--grad);border-radius:9px;transition:width .5s ease}
.pmeta{display:flex;justify-content:space-between;font-size:.78rem;color:var(--tx3)}
.task{display:flex;gap:12px;align-items:center;padding:10px 0;border-bottom:1px solid var(--line2);font-size:.9rem;cursor:pointer}
.task:last-child{border:0}
.task .cb{width:21px;height:21px;border-radius:7px;border:2px solid var(--tx3);flex:none;display:grid;place-items:center;transition:.15s}
.task.done .cb{background:var(--grad);border-color:transparent}
.task.done .cb::after{content:"";width:11px;height:11px;background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="3.4" stroke-linecap="round" stroke-linejoin="round"><path d="M4 12.5l4.5 4.5L20 6.5"/></svg>') center/contain no-repeat}
.task.done span.tt{text-decoration:line-through;color:var(--tx3)}
.task time{margin-left:auto;color:var(--tx3);font:600 .72rem 'Inter';flex:none}
.prio{margin-left:auto;font:700 .66rem 'Inter';padding:3px 10px;border-radius:99px;flex:none}
.prio.hi{color:#ff7d90;background:rgba(255,90,110,.12);border:1px solid rgba(255,90,110,.3)}
.prio.md{color:var(--gold);background:rgba(245,184,76,.1);border:1px solid rgba(245,184,76,.28)}
.prio.lo{color:var(--cyan);background:rgba(0,183,255,.08);border:1px solid var(--line)}
[data-theme="light"] .prio.hi{color:#d43a52}[data-theme="light"] .prio.md{color:#a06b10}

/* capture */
.cap{display:flex;gap:9px;margin-top:4px}
.cap input{flex:1;background:var(--chip);border:1.5px solid var(--line2);border-radius:12px;color:var(--tx);padding:12px 14px;font:500 .9rem 'Inter';outline:0;min-width:0}
.cap input:focus{border-color:var(--cyan)}
.cap button{border:0;border-radius:12px;padding:0 18px;background:var(--grad);color:#fff;font:700 .85rem 'Inter';cursor:pointer}
.chiprow{display:flex;gap:7px;margin-top:11px;flex-wrap:wrap}
.chiprow span{font:600 .72rem 'Inter';color:var(--tx2);border:1px solid var(--line2);border-radius:99px;padding:4px 12px}

/* stats */
.stats{grid-column:span 12;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;background:none;border:0;box-shadow:none;padding:0;backdrop-filter:none}
.stat{background:var(--card);backdrop-filter:blur(14px);border:1px solid var(--line2);border-radius:16px;padding:16px 18px;box-shadow:var(--shadow)}
.stat b{display:block;font-size:1.5rem;font-weight:800;letter-spacing:-.03em}
.stat span{color:var(--tx2);font-size:.76rem}
.stat .up{color:#3ddc97;font:600 .7rem 'Inter'}

/* approvals */
.appr{display:flex;flex-direction:column;gap:10px}
.appr .ap{display:flex;align-items:center;gap:12px;background:var(--chip);border:1px solid var(--line2);border-radius:13px;padding:12px 14px;font-size:.86rem;flex-wrap:wrap}
.appr .ap .src{font:600 .68rem 'Inter';color:var(--tx3);border:1px solid var(--line2);border-radius:99px;padding:2px 9px}
.appr .ap .bts{margin-left:auto;display:flex;gap:7px}
.appr .ap.doneA{opacity:.75}
.appr .ap .rc{margin-left:auto;font:600 .74rem 'Inter';color:#3ddc97}
.appr .ap .rc.rej{color:#ff7d90}

/* hub */
.hub{text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px}
.hub .halo{width:110px;height:110px;border-radius:50%;display:grid;place-items:center;margin-bottom:8px;
  background:radial-gradient(circle,rgba(0,183,255,.09),transparent 68%);
  box-shadow:0 0 0 1px var(--line),0 0 22px rgba(0,183,255,.09),inset 0 0 18px rgba(0,183,255,.05)}
.hub .halo img{width:64px;filter:drop-shadow(0 0 8px rgba(0,183,255,.4))}
.hub b{font-size:.98rem}
.hub .gold{color:var(--gold);font-weight:700;font-size:.9rem}
.hub p{color:var(--tx2);font-size:.8rem}

/* plan timeline */
.plan{display:flex;flex-direction:column}
.plan .pi{display:flex;align-items:center;gap:11px;padding:8px 0;border-bottom:1px solid var(--line2);font-size:.86rem}
.plan .pi:last-child{border:0}
.plan .pi .dot{width:9px;height:9px;border-radius:50%;background:var(--c,var(--cyan));flex:none;box-shadow:0 0 8px var(--c,var(--cyan))}
.plan .pi time{margin-left:auto;color:var(--tx3);font:600 .72rem 'Inter'}

.ring{width:64px;height:64px;border-radius:50%;background:conic-gradient(var(--cyan) calc(var(--p)*1%),var(--line2) 0);display:grid;place-items:center;flex:none}
.ring::after{content:attr(data-t);width:50px;height:50px;border-radius:50%;background:var(--solid);display:grid;place-items:center;font:700 .78rem 'Inter'}
.lrow{display:flex;align-items:center;gap:16px}
.w.hide{display:none}
.w .why{position:absolute;top:16px;right:18px;font:600 .66rem 'Inter';color:var(--tx3);border:1px solid var(--line2);border-radius:99px;padding:2px 9px;cursor:help}
.w.span3{grid-column:span 3}.w.span4{grid-column:span 4}.w.span5{grid-column:span 5}
@media(max-width:1240px){.w.span3,.w.span4{grid-column:span 6}.w.span5{grid-column:span 6}}
@media(max-width:680px){.w.span3,.w.span4,.w.span5{grid-column:span 12}}

/* ===== conversational dump overlay ===== */
#dumpOv{position:fixed;inset:0;z-index:60;display:none;background:rgba(4,8,18,.78);backdrop-filter:blur(14px)}
#dumpOv.open{display:flex;align-items:center;justify-content:center}
.dwrap{width:min(640px,94vw);max-height:92vh;display:flex;flex-direction:column;align-items:center;gap:10px;background:var(--solid);border:1px solid var(--line);border-radius:24px;padding:28px 26px;box-shadow:0 40px 120px rgba(0,0,0,.5);position:relative}
.dclose{position:absolute;top:16px;right:18px;border:1px solid var(--line2);background:transparent;color:var(--tx2);border-radius:10px;padding:7px 14px;font:600 .78rem 'Inter';cursor:pointer}
.dbrain{width:130px;height:130px;border-radius:50%;display:grid;place-items:center;transition:.3s;
  background:radial-gradient(circle,rgba(0,183,255,.18),transparent 70%);
  box-shadow:0 0 0 1px var(--line),0 0 50px rgba(0,183,255,.2)}
.dbrain img{width:78px;filter:drop-shadow(0 0 16px rgba(0,183,255,.8))}
.dbrain.talking{animation:dpulse 1s ease-in-out infinite}
.dbrain.listening{box-shadow:0 0 0 2px var(--cyan),0 0 60px rgba(0,183,255,.4)}
@keyframes dpulse{0%,100%{transform:scale(1)}50%{transform:scale(1.06)}}
.dstate{font:700 .68rem 'Inter';text-transform:uppercase;letter-spacing:.16em;color:var(--cyan)}
.dchat{width:100%;flex:1;min-height:160px;max-height:300px;overflow-y:auto;display:flex;flex-direction:column;gap:9px;padding:6px 2px}
.bub{max-width:82%;padding:11px 15px;border-radius:16px;font-size:.92rem;line-height:1.5}
.bub.os{align-self:flex-start;background:var(--chip);border:1px solid var(--line2);border-bottom-left-radius:5px}
.bub.me{align-self:flex-end;background:var(--grad);color:#fff;border-bottom-right-radius:5px}
.drow{width:100%;display:flex;gap:9px}
.drow input{flex:1;background:var(--chip);border:1.5px solid var(--line2);border-radius:13px;color:var(--tx);padding:13px 15px;font:500 .92rem 'Inter';outline:0;min-width:0}
.drow input:focus{border-color:var(--cyan)}
.dmic{width:48px;height:48px;flex:none;border:1.5px solid var(--line2);background:var(--chip);color:var(--tx2);border-radius:13px;cursor:pointer;display:grid;place-items:center}
.dmic.live{border-color:var(--cyan);color:var(--cyan);box-shadow:0 0 18px rgba(0,183,255,.35)}
.dsend{border:0;border-radius:13px;padding:0 20px;background:var(--grad);color:#fff;font:700 .88rem 'Inter';cursor:pointer}
.dnote{font-size:.74rem;color:var(--tx3)}
.twhen{color:var(--gold);font-weight:700;margin-left:6px}

@media(min-width:1900px){.main{max-width:1720px;margin-left:auto;margin-right:auto;padding-left:264px}}

/* ===== customise mode + plans + toast ===== */
.editw{outline:1.5px dashed var(--line);cursor:grab}
.editw.ghost{opacity:.4}
.editw.dragging{opacity:.5}
.editw.dover{outline:2px solid var(--cyan)}
.ebar{display:flex;align-items:center;justify-content:space-between;margin:-6px 0 10px}
.ebar .grip{display:flex;align-items:center;gap:6px;font:600 .7rem 'Inter';color:var(--tx3);text-transform:uppercase;letter-spacing:.1em}
.ebar .ehide{border:1px solid var(--line2);background:transparent;color:var(--tx2);border-radius:8px;padding:4px 12px;font:600 .72rem 'Inter';cursor:pointer}
#custBtn{display:flex;align-items:center;gap:8px;border:1px solid var(--line2);background:var(--chip);color:var(--tx2);height:40px;padding:0 15px;border-radius:12px;cursor:pointer;font:600 .8rem 'Inter';flex:none}
#custBtn.on{border-color:var(--cyan);color:var(--cyan)}
#toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);background:var(--solid);border:1px solid var(--line);color:var(--tx);padding:13px 22px;border-radius:14px;font:600 .86rem 'Inter';box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:.25s;z-index:80;max-width:90vw}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.plgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:11px}
.pl{background:var(--chip);border:1px solid var(--line2);border-radius:14px;padding:14px;display:flex;flex-direction:column;gap:3px}
.pl.cur{border-color:var(--cyan)}
.pl b{font-size:.95rem}
.pl span{font-size:.76rem;color:var(--tx2)}
.pl small{font-size:.7rem;color:var(--tx3)}
.pl em{font:700 .68rem 'Inter';color:var(--cyan);font-style:normal;margin-top:8px}
