/* ════════ THEME TOKENS ════════ */
:root[data-theme="dark"]{
  --bg:#080808; --bg-grad:radial-gradient(120% 90% at 85% -10%,#C9A84C18 0%,transparent 45%),radial-gradient(90% 80% at -5% 0%,#C4748A10 0%,transparent 50%);
  --panel:#141210; --panel-2:#1a1714; --elev:#1f1b17;
  --line:#2a2521; --line-2:#3a332c;
  --ink:#F0E8DC; --ink-soft:#b8ad9c; --ink-dim:#857a6b;
  --accent:#C9A84C; --accent-2:#a8893a; --accent-glow:#C9A84C2e;
  --amber:#C08552; --rose:#C4748A; --green:#9caf88; --slate:#A89070; --violet:#9a7d82;
  --rail:#050505; --on-accent:#1a1206;
  --shadow:0 1px 0 rgba(255,255,255,.02),0 14px 40px rgba(0,0,0,.6);
  --glass:rgba(20,18,16,.74);
}
:root[data-theme="light"]{
  --bg:#F0E8DC; --bg-grad:radial-gradient(120% 90% at 85% -10%,#C9A84C14 0%,transparent 45%);
  --panel:#FBF7F0; --panel-2:#F3ECE0; --elev:#ffffff;
  --line:#E6DCCB; --line-2:#D6CAB4;
  --ink:#1c1813; --ink-soft:#6b6155; --ink-dim:#9a8e7d;
  --accent:#9c7d2e; --accent-2:#806527; --accent-glow:#C9A84C2a;
  --amber:#a86a3c; --rose:#a8576d; --green:#6f8456; --slate:#7d6c52; --violet:#7d6168;
  --rail:#100e0b; --on-accent:#1a1206;
  --shadow:0 1px 2px rgba(28,22,15,.06),0 10px 30px rgba(28,22,15,.09);
  --glass:rgba(251,247,240,.78);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:"Montserrat",ui-sans-serif,system-ui,sans-serif;background:var(--bg);background-image:var(--bg-grad);background-attachment:fixed;color:var(--ink);font-size:14px;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:"Cormorant Garamond",Georgia,serif;font-weight:600;letter-spacing:-.015em}
.hidden{display:none!important}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit;font-size:14px;color:var(--ink)}
kbd{font-family:"JetBrains Mono",monospace;font-size:10.5px;background:var(--line);border:1px solid var(--line-2);border-radius:5px;padding:1px 5px;color:var(--ink-soft)}
.s16{width:16px;height:16px;fill:currentColor}.s18{width:18px;height:18px;fill:currentColor}.s20{width:20px;height:20px;fill:currentColor}
::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:6px}::-webkit-scrollbar-track{background:transparent}

/* ════════ BUTTONS ════════ */
.btn-accent{background:linear-gradient(180deg,var(--accent),var(--accent-2));color:var(--on-accent);padding:9px 16px;border-radius:10px;font-weight:700;font-size:13px;box-shadow:0 4px 14px var(--accent-glow);transition:transform .12s,box-shadow .15s,filter .15s}
.btn-accent:hover{transform:translateY(-1px);filter:brightness(1.06);box-shadow:0 6px 20px var(--accent-glow)}
.btn-accent.lg{width:100%;padding:13px;font-size:14px}
.btn-ghost{padding:10px 16px;border-radius:10px;color:var(--ink-soft);font-weight:600}.btn-ghost:hover{background:var(--line)}
.btn-danger{color:var(--rose);font-weight:700;padding:10px 14px;border-radius:10px}.btn-danger:hover{background:color-mix(in srgb,var(--rose) 14%,transparent)}
.icon-btn{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;color:var(--ink-soft);transition:background .14s,color .14s}
.icon-btn:hover{background:var(--line);color:var(--ink)}
.link{color:var(--accent);text-decoration:none;font-weight:700;border-bottom:1px solid color-mix(in srgb,var(--accent) 40%,transparent)}

/* ════════ GATE ════════ */
.gate{position:fixed;inset:0;display:grid;place-items:center;z-index:50;overflow:hidden}
.gate-bg{position:absolute;inset:0;background:#050505;background-image:radial-gradient(70% 60% at 50% 18%,#1c150a 0%,#0a0807 55%,#050505 100%);animation:hue 18s ease-in-out infinite alternate}
@keyframes hue{from{filter:brightness(1)}to{filter:brightness(1.12)}}
.gate-bg::after{content:"";position:absolute;inset:0;background:radial-gradient(55% 45% at 80% 88%,#C9A84C14,transparent 60%),radial-gradient(45% 40% at 15% 90%,#C4748A12,transparent 60%)}
.gate-card{position:relative;width:min(92vw,430px);background:var(--glass);backdrop-filter:blur(18px);border:1px solid var(--line-2);border-radius:22px;padding:42px 36px;box-shadow:0 40px 100px rgba(0,0,0,.65);text-align:center;animation:rise .6s cubic-bezier(.2,.85,.2,1)}
@keyframes rise{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.gate-mark{font-size:34px;color:var(--accent);filter:drop-shadow(0 0 16px var(--accent-glow))}
.gate-card h1{font-family:"Italiana",serif;font-weight:400;letter-spacing:.06em;font-size:44px;margin:10px 0 6px;color:#F0E8DC}
.gate-sub{color:#a7a39b;font-size:13.5px;line-height:1.55;margin-bottom:22px}
.gate-card input{width:100%;padding:14px 16px;border:1.5px solid var(--line-2);border-radius:12px;background:rgba(0,0,0,.25);outline:none;color:#f3f1ec;font-size:15px}
.gate-card input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow)}
.gate-colors{display:flex;gap:9px;justify-content:center;margin:18px 0 24px}
.swatch{width:28px;height:28px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform .12s,box-shadow .12s}
.swatch:hover{transform:scale(1.15)}
.swatch.sel{border-color:#fff;transform:scale(1.15);box-shadow:0 0 0 4px rgba(255,255,255,.12)}
.gate-foot{position:absolute;bottom:26px;left:0;right:0;text-align:center;color:#6b675f;font-size:11.5px;letter-spacing:.06em;text-transform:uppercase}

/* ════════ SHELL ════════ */
.app{display:grid;grid-template-columns:236px 1fr;height:100vh}
.rail{background:var(--rail);border-right:1px solid var(--line);display:flex;flex-direction:column;padding:18px 12px}
.brand{display:flex;align-items:center;gap:10px;padding:6px 10px 22px}
.brand-mark{color:var(--accent);font-size:17px;filter:drop-shadow(0 0 10px var(--accent-glow))}
.brand-name{font-family:"Italiana",serif;font-size:19px;font-weight:400;letter-spacing:.04em;color:var(--ink)}
.nav{display:flex;flex-direction:column;gap:3px}
.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;color:var(--ink-soft);font-weight:600;font-size:13.5px;text-align:left;transition:background .14s,color .14s;position:relative}
.nav-item .ni{width:18px;height:18px;fill:currentColor;opacity:.85}
.nav-item:hover{background:color-mix(in srgb,var(--ink) 7%,transparent);color:var(--ink)}
.nav-item.active{background:color-mix(in srgb,var(--accent) 16%,transparent);color:var(--accent)}
.nav-item.active::before{content:"";position:absolute;left:-12px;top:9px;bottom:9px;width:3px;border-radius:0 3px 3px 0;background:var(--accent)}
.badge{margin-left:auto;background:var(--rose);color:#fff;font-size:10.5px;font-style:normal;border-radius:20px;padding:1px 7px;font-weight:800}
.rail-foot{margin-top:auto;border-top:1px solid var(--line);padding-top:14px}
.presence-label{text-transform:uppercase;letter-spacing:.09em;font-size:9.5px;color:var(--ink-dim);margin-bottom:10px;padding-left:4px}
.presence{display:flex;flex-direction:column;gap:7px;max-height:220px;overflow:auto}
.pres-item{display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--ink-soft);padding:2px 4px}
.pres-item .pa{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:9.5px;font-weight:800;flex:0 0 auto}
.pres-item .pdot{width:7px;height:7px;border-radius:50%;background:var(--green);margin-left:auto;box-shadow:0 0 0 3px color-mix(in srgb,var(--green) 25%,transparent)}

.main{display:flex;flex-direction:column;overflow:hidden}
.topbar{height:64px;flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;padding:0 26px;border-bottom:1px solid var(--line);background:var(--glass);backdrop-filter:blur(12px)}
.tb-title{display:flex;align-items:baseline;gap:12px}
.tb-title h2{font-size:21px}
.tb-sub{color:var(--ink-dim);font-size:12.5px}
.tb-actions{display:flex;align-items:center;gap:12px}
.cmdk-trigger{display:flex;align-items:center;gap:8px;padding:7px 12px 7px 11px;border:1px solid var(--line-2);border-radius:10px;color:var(--ink-soft);font-size:12.5px;font-weight:500;background:var(--panel);transition:border-color .14s}
.cmdk-trigger:hover{border-color:var(--accent)}
.cmdk-trigger .s16{width:14px;height:14px}
.cmdk-trigger kbd{margin-left:4px}
.presence-stack{display:flex;align-items:center}
.presence-stack .pa{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:11px;font-weight:800;border:2px solid var(--bg);margin-left:-8px;box-shadow:0 1px 4px rgba(0,0,0,.3)}
.presence-stack .pa:first-child{margin-left:0}
.me-chip{display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:20px;background:var(--panel);border:1px solid var(--line);font-weight:600;font-size:13px}
.me-dot{width:9px;height:9px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}

/* attendance presence toggle */
.att-toggle{display:flex;align-items:center;gap:8px;padding:5px 12px 5px 7px;border-radius:20px;background:var(--panel);border:1px solid var(--line);font-weight:700;font-size:12px;color:var(--ink-soft);transition:color .14s,border-color .14s}
.att-toggle .att-track{position:relative;width:34px;height:18px;border-radius:20px;background:var(--line);transition:background .18s}
.att-toggle .att-knob{position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;transition:left .18s;box-shadow:0 1px 2px rgba(0,0,0,.35)}
.att-toggle.on{color:#16c784;border-color:color-mix(in srgb,#16c784 45%,transparent)}
.att-toggle.on .att-track{background:#16c784}
.att-toggle.on .att-knob{left:18px}
.att-toggle:not(.readonly){cursor:pointer}
.att-toggle.readonly{cursor:default;opacity:.95}
.att-toggle.busy{opacity:.5;pointer-events:none}

.stage{flex:1;overflow:auto;padding:26px}
.view{animation:fade .35s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.view-bar{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.search-inline{flex:1;max-width:340px;padding:10px 14px;border:1.5px solid var(--line-2);border-radius:11px;background:var(--panel);outline:none}
.search-inline:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow)}

/* ════════ STAT CARDS ════════ */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(168px,1fr));gap:14px;margin-bottom:18px}
.stat{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:18px;overflow:hidden;box-shadow:var(--shadow)}
.stat::after{content:"";position:absolute;right:-30px;top:-30px;width:90px;height:90px;border-radius:50%;background:var(--accent-glow);filter:blur(20px)}
.stat .k{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);display:flex;align-items:center;gap:6px}
.stat .v{font-family:"Cormorant Garamond",serif;font-size:30px;margin-top:8px;line-height:1;font-weight:600}
.stat .sub{font-size:11.5px;color:var(--ink-dim);margin-top:6px}
.stat.accent .v{color:var(--accent)}

.dash-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.span2{grid-column:span 2}.span3{grid-column:span 3}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:var(--shadow)}
.panel-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.panel-h h3{font-size:16px}
.panel-tag{font-size:9.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);background:var(--accent-glow);padding:3px 8px;border-radius:6px;font-weight:700}

/* funnel */
.funnel{display:flex;flex-direction:column;gap:10px}
.fn-row{display:grid;grid-template-columns:96px 1fr;align-items:center;gap:12px}
.fn-row .fl{font-size:12.5px;color:var(--ink-soft);font-weight:600}
.fn-bar{height:30px;border-radius:8px;display:flex;align-items:center;padding:0 12px;color:#fff;font-weight:700;font-size:12.5px;min-width:fit-content;transition:width .6s cubic-bezier(.2,.8,.2,1);position:relative;overflow:hidden}
.fn-bar span{position:relative;z-index:1;white-space:nowrap}
.fn-bar .fv{margin-left:auto;opacity:.85;font-weight:600;font-size:11.5px}

/* donut */
.donut-wrap{display:flex;flex-direction:column;align-items:center;gap:14px}
.donut{position:relative}
.donut .center{position:absolute;inset:0;display:grid;place-items:center;text-align:center}
.donut .center .dn{font-family:"Cormorant Garamond",serif;font-size:26px}
.donut .center .dl{font-size:10px;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-soft)}
.donut-legend{display:flex;gap:16px;font-size:12px}
.donut-legend i{display:inline-block;width:9px;height:9px;border-radius:3px;margin-right:5px}

/* feed */
.feed{display:flex;flex-direction:column;gap:2px}
.feed-item{display:flex;gap:12px;align-items:flex-start;padding:11px 8px;border-radius:10px;transition:background .12s}
.feed-item:hover{background:var(--panel-2)}
.feed-tag{flex:0 0 auto;font-size:9.5px;text-transform:uppercase;letter-spacing:.05em;padding:3px 8px;border-radius:6px;font-weight:700}
.tag-note{background:color-mix(in srgb,var(--slate) 20%,transparent);color:var(--slate)}
.tag-call{background:color-mix(in srgb,var(--green) 20%,transparent);color:var(--green)}
.tag-email{background:color-mix(in srgb,var(--accent) 20%,transparent);color:var(--accent)}
.tag-meeting{background:color-mix(in srgb,var(--amber) 20%,transparent);color:var(--amber)}
.tag-task{background:color-mix(in srgb,var(--violet) 20%,transparent);color:var(--violet)}
.feed-item .ft{font-size:11px;color:var(--ink-dim);margin-top:3px}

/* ════════ TABLE ════════ */
.table-wrap{background:var(--panel);border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:var(--shadow)}
.grid{width:100%;border-collapse:collapse}
.grid th{text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-dim);padding:14px 16px;border-bottom:1px solid var(--line);font-weight:700}
.grid td{padding:13px 16px;border-bottom:1px solid var(--line);font-size:13.5px;vertical-align:middle}
.grid tr:last-child td{border-bottom:none}
.grid tbody tr{transition:background .1s}
.grid tbody tr:hover td{background:var(--panel-2)}
.grid .nm{font-weight:700;display:flex;align-items:center;gap:10px}
.grid .av-sm{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:10.5px;font-weight:800;flex:0 0 auto}
.pill{font-size:10.5px;padding:3px 10px;border-radius:20px;font-weight:700;text-transform:capitalize}
.pill.active{background:color-mix(in srgb,var(--green) 18%,transparent);color:var(--green)}
.pill.inactive{background:var(--line);color:var(--ink-soft)}
.row-act{display:flex;gap:4px;justify-content:flex-end;opacity:0;transition:opacity .12s}
tr:hover .row-act{opacity:1}
.ico{padding:6px;border-radius:8px;font-size:12px;color:var(--ink-soft);display:grid;place-items:center}
.ico:hover{background:var(--line);color:var(--ink)}.ico svg{width:15px;height:15px;fill:currentColor}

/* ════════ BOARD ════════ */
.pipe-summary{display:flex;gap:22px;font-size:13px}
.pipe-summary b{font-family:"Cormorant Garamond",serif;font-size:18px;font-weight:600}
.pipe-summary .lbl{color:var(--ink-soft);font-size:11px;text-transform:uppercase;letter-spacing:.05em;display:block}
.board{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(248px,1fr);gap:14px;overflow-x:auto;padding-bottom:12px;align-items:start}
.col{background:var(--panel);border:1px solid var(--line);border-radius:14px;display:flex;flex-direction:column;transition:box-shadow .15s}
.col.drag-over{box-shadow:0 0 0 2px var(--accent),0 0 24px var(--accent-glow)}
.col-head{padding:13px 14px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.col-head .cn{font-weight:800;font-size:11px;text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:7px}
.col-head .cdot{width:8px;height:8px;border-radius:50%}
.col-head .ct{font-size:11px;color:var(--ink-soft);font-family:"JetBrains Mono",monospace}
.col-body{padding:10px;display:flex;flex-direction:column;gap:9px;min-height:60px}
.card{background:var(--elev);border:1px solid var(--line);border-radius:11px;padding:12px;cursor:grab;box-shadow:0 1px 3px rgba(0,0,0,.18);transition:box-shadow .14s,transform .14s,border-color .14s}
.card:hover{box-shadow:var(--shadow);transform:translateY(-2px);border-color:var(--line-2)}
.card.dragging{opacity:.4;transform:scale(.97)}
.card .ct{font-weight:700;font-size:13.5px;margin-bottom:5px}
.card .cmeta{display:flex;align-items:center;gap:7px;font-size:11.5px;color:var(--ink-soft);margin-bottom:9px}
.card .cbot{display:flex;align-items:center;justify-content:space-between}
.card .cv{font-family:"Cormorant Garamond",serif;font-size:16px;font-weight:600}
.card .av-sm{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:9.5px;font-weight:800}
.ring{--p:50;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:conic-gradient(var(--accent) calc(var(--p)*1%),var(--line) 0);font-size:9px;font-weight:800;color:var(--ink-soft)}
.ring i{width:22px;height:22px;border-radius:50%;background:var(--elev);display:grid;place-items:center;font-style:normal}
.card .duedate{font-size:10.5px;color:var(--ink-dim);font-family:"JetBrains Mono",monospace}

/* ════════ FILES ════════ */
.dropzone{border:2px dashed var(--line-2);border-radius:16px;padding:40px;text-align:center;background:var(--panel);transition:border-color .15s,background .15s;margin-bottom:18px}
.dropzone.over{border-color:var(--accent);background:var(--accent-glow)}
.dz-ico{width:34px;height:34px;fill:var(--ink-dim);margin-bottom:10px}
.dropzone p{font-size:15px}.dropzone .hint{color:var(--ink-dim);font-size:12px}
.upload-queue{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
.uq{background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:11px 14px}
.uq .uqn{font-size:12.5px;font-weight:600;margin-bottom:7px;display:flex;justify-content:space-between}
.uq .uqbar{height:6px;background:var(--line);border-radius:4px;overflow:hidden}
.uq .uqfill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:4px;width:0;transition:width .2s}
.file-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:13px}
.file{background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:transform .14s,box-shadow .14s}
.file:hover{transform:translateY(-2px)}
.file .thumb{height:120px;background:var(--panel-2);display:grid;place-items:center;border-bottom:1px solid var(--line);overflow:hidden}
.file .thumb img{width:100%;height:100%;object-fit:cover}
.file .thumb .fi{font-size:34px}
.file .fb{padding:13px;display:flex;flex-direction:column;gap:5px}
.file .fn{font-weight:700;font-size:12.5px;word-break:break-word;line-height:1.3}
.file .fm{font-size:11px;color:var(--ink-dim)}
.file .fa{display:flex;gap:7px;margin-top:6px}
.file .fa a,.file .fa button{font-size:11.5px;font-weight:700;padding:6px 11px;border-radius:8px}
.file .fa a{background:var(--accent);color:var(--on-accent);text-decoration:none}
.file .fa button{background:var(--line);color:var(--ink-soft)}.file .fa button:hover{color:var(--rose)}

/* ════════ CHAT ════════ */
.chat-view{display:flex;flex-direction:column;height:100%;min-height:0;overflow:hidden;padding-bottom:0}
.chat-log{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:14px;padding:8px 4px 16px}
.msg{display:flex;gap:11px;max-width:74%;animation:pop .25s ease}
@keyframes pop{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.msg.mine{align-self:flex-end;flex-direction:row-reverse}
.msg .av{width:34px;height:34px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;color:#fff;font-weight:800;font-size:12.5px}
.bubble{background:var(--panel);border:1px solid var(--line);border-radius:15px;border-top-left-radius:5px;padding:10px 14px;box-shadow:0 1px 3px rgba(0,0,0,.15)}
.msg.mine .bubble{background:linear-gradient(180deg,var(--accent),var(--accent-2));color:var(--on-accent);border:none;border-radius:15px;border-top-right-radius:5px}
.bubble .who{font-size:11.5px;font-weight:800;margin-bottom:3px}
.msg.mine .bubble .who{display:none}
.bubble .tx{font-size:13.5px;line-height:1.5;white-space:pre-wrap;word-break:break-word}
.bubble .tm{font-size:11px;opacity:.82;margin-top:5px;text-align:right;font-family:"JetBrains Mono",monospace}
.msg.mine .bubble .tm{opacity:.9}
.filechip{display:flex;align-items:center;gap:9px;margin-top:7px;padding:9px 11px;background:rgba(127,127,127,.14);border-radius:10px;text-decoration:none;color:inherit}
.msg.mine .filechip{background:rgba(0,0,0,.16)}
.filechip svg{width:18px;height:18px;fill:currentColor;flex:0 0 auto}
.filechip .fn{font-size:12.5px;font-weight:700}.filechip .fs{font-size:10px;opacity:.7}
.edited{font-style:italic;opacity:.7}
/* Action buttons are a real flex sibling beside the bubble — always present and
   always clickable (dim by default, full on hover). No hover-gap to fall into. */
.msg-acts{display:flex;flex-direction:column;gap:6px;align-self:center;opacity:.4;transition:opacity .12s}
.msg:hover .msg-acts,.msg-acts:hover{opacity:1}
.msg-act{width:30px;height:30px;display:grid;place-items:center;border:1px solid var(--line-2);background:var(--panel);border-radius:9px;cursor:pointer;color:var(--ink-soft);box-shadow:0 1px 4px rgba(0,0,0,.18)}
.msg-act:hover{color:var(--accent);border-color:var(--accent);background:var(--panel)}
.msg-act[data-act="del"]:hover{color:var(--rose);border-color:var(--rose)}
.msg-act svg{width:15px;height:15px;fill:currentColor}
.edit-box{margin-top:7px}
.edit-input{width:100%;min-width:220px;padding:8px 11px;border:1.5px solid var(--line-2);border-radius:9px;background:var(--panel);color:var(--ink);outline:none;font-size:13.5px}
.edit-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.edit-btns{display:flex;gap:7px;margin-top:7px;justify-content:flex-end}
.edit-btns button{padding:6px 13px;font-size:12px;border-radius:8px;cursor:pointer}
/* ── Chat: conversation pane (Team + private DMs) ── */
.chat-shell{display:flex;flex:1;height:100%;min-height:0}
.conv-pane{width:212px;flex:0 0 auto;border-right:1px solid var(--line);display:flex;flex-direction:column;overflow:hidden}
.conv-pane-h{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);padding:8px 12px;font-weight:700}
.conv-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:2px;padding:0 8px 10px}
.conv{display:flex;align-items:center;gap:9px;width:100%;text-align:left;padding:8px 9px;border:none;background:transparent;border-radius:10px;cursor:pointer;color:var(--ink);position:relative}
.conv:hover{background:rgba(127,127,127,.11)}
.conv.active{background:color-mix(in srgb,var(--accent) 16%,transparent)}
.conv-av{width:30px;height:30px;flex:0 0 auto;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:800;font-size:12px}
.conv-mid{flex:1;min-width:0;display:flex;flex-direction:column}
.conv-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.conv-sub{font-size:10.5px;color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.conv-dot{position:absolute;right:11px;bottom:8px;width:8px;height:8px;border-radius:50%;background:var(--line-2)}
.conv-dot.on{background:var(--green)}
.conv-badge{position:absolute;right:9px;top:7px;min-width:17px;height:17px;padding:0 5px;border-radius:9px;background:var(--accent);color:var(--on-accent);font-size:10.5px;font-weight:800;display:grid;place-items:center}
.icon-btn.muted:hover{opacity:.85}
.chat-main{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column;padding-left:14px}
.chat-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:2px 2px 9px;border-bottom:1px solid var(--line);margin-bottom:6px}
.chat-head-t{display:flex;flex-direction:column;min-width:0}
#chatTitle{font-weight:800;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-sub{font-size:11px;color:var(--ink-soft)}
.icon-btn.muted{opacity:.5}
.pres-item.clickable{cursor:pointer;border-radius:8px;transition:background .12s}
.pres-item.clickable:hover{background:rgba(127,127,127,.12)}
/* ── Workspace: shared folders & files (append-only) ── */
.ws-crumb{display:flex;align-items:center;gap:3px;flex-wrap:wrap}
.crumb{border:none;background:transparent;color:var(--ink-soft);cursor:pointer;padding:4px 8px;border-radius:7px;font-size:13.5px;font-weight:600}
.crumb:hover{background:rgba(127,127,127,.12);color:var(--ink)}
.crumb.active{color:var(--accent)}
.crumb-sep{color:var(--ink-soft);opacity:.55}
.ws-note{font-size:11.5px;color:var(--ink-soft);margin:0 0 14px}
.ws-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(152px,1fr));gap:14px}
.ws-item{display:flex;flex-direction:column;gap:6px;padding:14px;border:1px solid var(--line);border-radius:14px;background:var(--panel);text-decoration:none;color:inherit;cursor:pointer;transition:transform .12s,box-shadow .15s,border-color .15s}
.ws-item:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(0,0,0,.16);border-color:var(--accent)}
.ws-folder .ws-ico{font-size:36px;line-height:1}
.ws-thumb{height:84px;border-radius:9px;overflow:hidden;display:grid;place-items:center;background:rgba(127,127,127,.1)}
.ws-thumb img{width:100%;height:100%;object-fit:cover}
.ws-thumb .ws-ico{font-size:34px}
.ws-name{font-size:13px;font-weight:700;word-break:break-word;line-height:1.3}
.ws-meta{font-size:10.5px;color:var(--ink-soft)}
/* ── Calendar / events ── */
.cal-nav{display:flex;align-items:center;gap:10px}
.cal-nav h3{min-width:148px;text-align:center;font-size:16px}
.cal-wrap{display:flex;gap:18px;align-items:flex-start}
.cal-grid-wrap{flex:1;min-width:0}
.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:6px}
.cal-dow span{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);text-align:center}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-cell{min-height:96px;border:1px solid var(--line);border-radius:11px;background:var(--panel);padding:6px;display:flex;flex-direction:column;gap:3px;cursor:pointer;transition:border-color .12s,box-shadow .12s}
.cal-cell:hover{border-color:var(--accent);box-shadow:0 3px 12px rgba(0,0,0,.12)}
.cal-cell.empty{background:transparent;border:none;cursor:default;box-shadow:none}
.cal-cell.today{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.cal-d{font-size:12px;font-weight:700;color:var(--ink-soft)}
.cal-cell.today .cal-d{color:var(--accent)}
.cal-chip{font-size:10.5px;background:var(--accent-glow);color:var(--ink);border-radius:6px;padding:2px 5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-left:3px solid var(--accent)}
.cal-chip b{font-weight:800}
.cal-chip:hover{filter:brightness(1.08)}
.cal-more{font-size:10px;color:var(--ink-soft);padding-left:3px}
.cal-side{width:268px;flex:0 0 auto;border:1px solid var(--line);border-radius:14px;background:var(--panel);padding:14px;max-height:calc(100vh - 200px);overflow-y:auto}
.cal-upcoming{display:flex;flex-direction:column;gap:9px;margin-top:6px}
.up-item{padding:10px;border:1px solid var(--line);border-radius:11px;cursor:pointer;transition:border-color .12s,transform .12s}
.up-item:hover{border-color:var(--accent);transform:translateY(-1px)}
.up-when{font-size:11px;font-weight:700;color:var(--accent)}
.up-title{font-size:13.5px;font-weight:700;margin:2px 0;word-break:break-word}
.up-meta{font-size:10.5px;color:var(--ink-soft)}
.up-att{display:flex;gap:4px;margin-top:6px}
.att-list{display:flex;flex-wrap:wrap;gap:8px;max-height:120px;overflow-y:auto;padding:4px 0}
.att-pick{display:flex;align-items:center;gap:6px;font-size:12.5px;padding:5px 9px;border:1px solid var(--line-2);border-radius:9px;cursor:pointer}
.att-pick input{margin:0}
.ann{display:flex;align-items:center;gap:8px;font-size:13px;margin:4px 0 2px;cursor:pointer}
.reminders{position:fixed;top:16px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;gap:8px;z-index:200;width:min(380px,92vw)}
.remind-card{display:flex;align-items:center;gap:11px;background:var(--panel);border:1px solid var(--accent);border-radius:13px;padding:11px 13px;box-shadow:0 10px 30px rgba(0,0,0,.28);animation:pop .25s ease}
.rc-ico{font-size:22px}
.rc-main{flex:1;min-width:0;cursor:pointer}
.rc-t{font-size:13.5px;font-weight:700;word-break:break-word}
.rc-s{font-size:11px;color:var(--ink-soft)}
.rc-x{border:none;background:transparent;color:var(--ink-soft);cursor:pointer;font-size:14px;padding:2px 6px;border-radius:6px}
.rc-x:hover{background:rgba(127,127,127,.15)}
/* ── Auth gate + Admin ── */
.auth-form{display:flex;flex-direction:column;gap:10px;width:100%}
.auth-form input{padding:12px 14px;border:1.5px solid var(--line-2);border-radius:11px;background:var(--panel);color:var(--ink);outline:none;font-size:14px}
.auth-form input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow)}
.auth-form .btn-accent{margin-top:2px}
.auth-err{font-size:12.5px;color:var(--rose);background:rgba(224,104,90,.13);border-radius:8px;padding:8px 11px}
.auth-switch{font-size:12.5px;color:var(--ink-soft);text-align:center;margin-top:4px}
.admin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:start}
.admin-grid .span2{grid-column:span 2}
.admin-grid .span3{grid-column:span 3}
.btn-line.sm{padding:5px 10px;font-size:12px}
.typing{height:18px;font-size:11.5px;color:var(--ink-soft);font-style:italic;padding-left:8px}
.composer{display:flex;gap:9px;align-items:center;border-top:1px solid var(--line);padding:14px 0}
.composer input{flex:1;padding:13px 16px;border:1.5px solid var(--line-2);border-radius:12px;background:var(--panel);outline:none}
.composer input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow)}
.attach{width:46px;height:46px;border-radius:12px;background:var(--panel);border:1.5px solid var(--line-2);color:var(--ink-soft);display:grid;place-items:center}
.attach:hover{border-color:var(--accent);color:var(--accent)}

/* ════════ COMMAND PALETTE ════════ */
.cmdk{position:fixed;inset:0;background:rgba(0,0,0,.45);backdrop-filter:blur(4px);z-index:60;display:flex;justify-content:center;padding-top:14vh;animation:fade .15s}
.cmdk-card{width:min(94vw,580px);height:fit-content;max-height:64vh;background:var(--panel);border:1px solid var(--line-2);border-radius:16px;box-shadow:0 40px 100px rgba(0,0,0,.6);overflow:hidden;display:flex;flex-direction:column;animation:rise .2s}
.cmdk-input-wrap{display:flex;align-items:center;gap:11px;padding:16px 18px;border-bottom:1px solid var(--line)}
.cmdk-input-wrap svg{fill:var(--ink-dim)}
.cmdk-input-wrap input{flex:1;border:none;background:none;outline:none;font-size:16px}
.cmdk-list{overflow-y:auto;padding:8px}
.cmdk-item{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:10px;cursor:pointer}
.cmdk-item.sel{background:var(--accent-glow)}
.cmdk-item .ci-ico{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;background:var(--panel-2);color:var(--accent);flex:0 0 auto;font-size:13px}
.cmdk-item .ci-ico .av-sm{width:30px;height:30px}
.cmdk-item .ci-main{flex:1;min-width:0}
.cmdk-item .ci-t{font-size:13.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cmdk-item .ci-s{font-size:11.5px;color:var(--ink-dim)}
.cmdk-item .ci-kind{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-dim);font-weight:700}
.cmdk-foot{padding:10px 16px;border-top:1px solid var(--line);font-size:11px;color:var(--ink-dim)}
.cmdk-empty{padding:30px;text-align:center;color:var(--ink-dim);font-size:13px}

/* ════════ MODAL ════════ */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);display:grid;place-items:center;z-index:55;animation:fade .15s}
.modal-card{width:min(94vw,560px);max-height:90vh;overflow:auto;background:var(--panel);border:1px solid var(--line-2);border-radius:18px;box-shadow:0 40px 100px rgba(0,0,0,.55);animation:rise .25s}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--panel);z-index:1}
.modal-head h3{font-size:21px}
.modal-body{padding:22px 24px}
.field{margin-bottom:15px}
.field label{display:block;font-size:11px;font-weight:700;color:var(--ink-soft);margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em}
.field input,.field select,.field textarea{width:100%;padding:11px 13px;border:1.5px solid var(--line-2);border-radius:10px;background:var(--elev);outline:none}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow)}
.field textarea{min-height:76px;resize:vertical}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field-row.thirds{grid-template-columns:1fr 1fr 1fr}
.prob-wrap{display:flex;align-items:center;gap:12px}
.prob-wrap input[type=range]{flex:1;accent-color:var(--accent)}
.prob-val{font-family:"Cormorant Garamond",serif;font-size:18px;min-width:46px;text-align:right}
.weighted-note{font-size:12px;color:var(--ink-soft);margin-top:-6px;margin-bottom:14px}
.weighted-note b{color:var(--accent);font-family:"JetBrains Mono",monospace}
.modal-foot{display:flex;justify-content:space-between;gap:10px;margin-top:6px;align-items:center}
.modal-foot .right{display:flex;gap:8px}

.act-log{margin-top:20px;border-top:1px solid var(--line);padding-top:18px}
.act-add{display:flex;gap:8px;margin-bottom:14px}
.act-add input{flex:1}.act-add select{width:118px}
.act-item{display:flex;gap:10px;font-size:13px;padding:10px 0;border-bottom:1px dashed var(--line);line-height:1.45}
.act-item:last-child{border-bottom:none}
.act-item .am{font-size:10.5px;color:var(--ink-dim);margin-top:2px}

.empty{padding:34px;text-align:center;color:var(--ink-dim);font-size:13px}

/* ════════ TOAST ════════ */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--elev);color:var(--ink);border:1px solid var(--line-2);padding:12px 22px;border-radius:12px;font-size:13px;font-weight:600;box-shadow:0 16px 40px rgba(0,0,0,.4);z-index:70;animation:rise .25s}

@media(max-width:900px){
  .app{grid-template-columns:1fr}
  .rail{flex-direction:row;align-items:center;overflow-x:auto;padding:8px;border-right:none;border-bottom:1px solid var(--line)}
  .rail-foot,.brand{display:none}.nav{flex-direction:row}
  .dash-grid{grid-template-columns:1fr}.span2,.span3{grid-column:span 1}
  .cmdk-trigger span{display:none}.tb-sub{display:none}
}

/* ════════ EXPORT BTN + TOOLBAR RIGHT ════════ */
.bar-right{display:flex;gap:9px;align-items:center}
.btn-line{padding:9px 14px;border:1px solid var(--line-2);border-radius:10px;color:var(--ink-soft);font-weight:600;font-size:12.5px;background:var(--panel);transition:border-color .14s,color .14s}
.btn-line:hover{border-color:var(--accent);color:var(--accent)}

/* ════════ CONNECT VIEW ════════ */
.connect-grid{display:grid;grid-template-columns:300px 1fr;gap:18px;align-items:start}
.connect-qr{display:flex;flex-direction:column;align-items:center;gap:14px;padding:26px}
.qr-box{width:220px;height:220px;background:#F0E8DC;border-radius:16px;padding:14px;display:grid;place-items:center;box-shadow:inset 0 0 0 1px var(--line)}
.qr-box svg{width:100%;height:100%}
.qr-cap{font-size:12.5px;color:var(--ink-soft);text-align:center;max-width:220px}
.steps{margin:0 0 20px;padding-left:20px;display:flex;flex-direction:column;gap:9px;font-size:13.5px;line-height:1.5}
.steps li::marker{color:var(--accent);font-weight:700}
.addr-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-dim);font-weight:700;margin-bottom:10px}
.addr-list{display:flex;flex-direction:column;gap:9px;margin-bottom:18px}
.addr-row{display:flex;align-items:center;gap:10px;background:var(--elev);border:1px solid var(--line);border-radius:11px;padding:11px 14px}
.addr-row .url{font-family:"JetBrains Mono",monospace;font-size:13.5px;color:var(--accent);flex:1;word-break:break-all}
.addr-row .copy{padding:6px 12px;border-radius:8px;background:var(--accent);color:var(--on-accent);font-weight:700;font-size:11.5px;flex:0 0 auto}
.addr-row .copy:hover{filter:brightness(1.07)}
.connect-note{font-size:12.5px;color:var(--ink-soft);line-height:1.55;border-top:1px solid var(--line);padding-top:14px}
@media(max-width:900px){.connect-grid{grid-template-columns:1fr}}
