/* ═══════════════════════════════════════════════════════════════════════════
   OpenSesame — common.css  (shared across all app pages)
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── STAGING BANNER — disabled ── */

/* ── REDUCED MOTION ── */
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.01ms!important;transition-duration:0.01ms!important}}

/* ── OS SPLASH — pre-boot branded splash, shown before any JS runs, removed by _hideSplash() ── */
#os-splash{position:fixed;inset:0;z-index:2147483000;background:#0E1F3A;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .35s ease;font-family:system-ui,-apple-system,"Segoe UI",sans-serif;color:#E8ECF5}
#os-splash .os-splash-logo{width:140px;height:auto;opacity:.95;margin-bottom:28px;filter:drop-shadow(0 0 18px rgba(232,108,31,.35))}
#os-splash .os-splash-spin{width:44px;height:44px;border-radius:50%;border:3px solid rgba(232,108,31,.22);border-top-color:#E86C1F;animation:os-splash-spin 1s linear infinite}
#os-splash .os-splash-msg{margin-top:22px;color:#A0B0C7;font-size:.85rem;letter-spacing:.5px;text-align:center;padding:0 24px;max-width:320px;line-height:1.45}
#os-splash.hide{opacity:0;pointer-events:none}
@keyframes os-splash-spin{to{transform:rotate(360deg)}}

/* ── CSS VARIABLES ── */
:root{
  --pr:#1a1a2e;--ac:#f37006;--ac2:#f37006;
  --bg:#eef1f7;--card:#ffffff;--tx:#1e2229;--mu:#6b7280;--bd:#dde1e7;
  --ok:#2ecc71;--rad:12px;
  --sh:0 2px 10px rgba(0,0,0,.09),0 1px 3px rgba(0,0,0,.06);
  --sh-md:0 6px 20px rgba(0,0,0,.12),0 2px 6px rgba(0,0,0,.07);
  --tr:background .18s ease,color .18s ease,border-color .18s ease;
  --grad:linear-gradient(160deg,#e8edf6 0%,#eef1f7 45%,#e4eaf5 100%);
}
html[data-theme="dark"]{
  --bg:#272a33;--card:#30333d;--tx:#e8ecf5;--mu:#a0aac0;--bd:#3e4251;
  --pr:#272a33;--ac:#f37006;--ac2:#7aa8f8;--ok:#4caf7d;
  --input:#3a3d48;
  --sh:0 2px 10px rgba(0,0,0,.3),0 1px 3px rgba(0,0,0,.2);
  --sh-md:0 6px 24px rgba(0,0,0,.38),0 2px 8px rgba(0,0,0,.22);
  --grad:linear-gradient(160deg,#21242d 0%,#272a33 45%,#232730 100%);
  color-scheme:dark;
}
html[data-theme="dark"] ::-webkit-scrollbar{width:6px;height:6px}
html[data-theme="dark"] ::-webkit-scrollbar-track{background:transparent}
html[data-theme="dark"] ::-webkit-scrollbar-thumb{background:#4a4f62;border-radius:3px}
html[data-theme="dark"] ::-webkit-scrollbar-thumb:hover{background:#5c6278}
html[data-theme="dark"]{scrollbar-width:thin;scrollbar-color:#4a4f62 transparent}
html[data-theme="dark"] input:-webkit-autofill,
html[data-theme="dark"] input:-webkit-autofill:hover,
html[data-theme="dark"] input:-webkit-autofill:focus,
html[data-theme="dark"] textarea:-webkit-autofill {
  -webkit-box-shadow: 0 0 0 30px #3a3d48 inset !important;
  -webkit-text-fill-color: #dde1ea !important;
  caret-color: #dde1ea;
}

/* ── CONFIRM DIALOG ── */
.os-confirm-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:10010;display:flex;align-items:center;justify-content:center;animation:osFadeIn .15s}
@keyframes osFadeIn{from{opacity:0}to{opacity:1}}
.os-confirm{background:var(--card);border-radius:var(--rad);padding:24px;max-width:360px;width:90%;box-shadow:var(--sh-md)}
.os-confirm h4{margin:0 0 10px;font-size:1.05rem;color:var(--tx)}
.os-confirm p{margin:0 0 20px;font-size:.92rem;color:var(--mu);line-height:1.45;white-space:pre-line}
.os-confirm-actions{display:flex;gap:10px;justify-content:flex-end}
.os-confirm-btn{border:none;padding:9px 18px;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .15s}
.os-confirm-btn.cancel{background:var(--bd);color:var(--tx)}
.os-confirm-btn.danger{background:#e74c3c;color:#fff}
.os-confirm-btn.action{background:var(--ac);color:#fff}
.os-confirm-btn:hover{opacity:.85}

/* ── RESET ── */
*{box-sizing:border-box;margin:0;padding:0}
:focus-visible{outline:2px solid var(--ac);outline-offset:2px}
:focus:not(:focus-visible){outline:none}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--grad,var(--bg)) fixed;color:var(--tx);min-height:100vh;transition:var(--tr);overscroll-behavior-y:none;overflow-x:hidden}
html{scroll-padding-top:190px;scrollbar-gutter:auto}

/* ── BIG TEXT ── */
html.bigtext{font-size:22px}
html.bigtext .content{max-width:1440px}
html.bigtext .tabs{padding-left:max(16px,calc(50% - 704px + var(--cshift,0px)));padding-right:max(16px,calc(50% - 704px - var(--cshift,0px)))}
html.bigtext #proj-bar-inner{padding:7px max(16px,calc(50% - 684px - var(--cshift,0px))) 7px max(16px,calc(50% - 684px + var(--cshift,0px)))}
@media(max-width:600px){html.bigtext{font-size:20px}}

/* ── THEME FADE TRANSITION ── */
html.theme-transitioning *,
html.theme-transitioning *::before,
html.theme-transitioning *::after {
  transition:
    background-color 0.28s ease,
    background 0.28s ease,
    color 0.28s ease,
    border-color 0.28s ease,
    box-shadow 0.28s ease !important;
}

/* ── CAPACITOR (ANDROID APP) STATUS BAR / NAV BAR SPACERS ── */
html.capacitor-app{--cap-inset:var(--status-bar-h, max(env(safe-area-inset-top,48px),48px));--cap-bottom:max(env(safe-area-inset-bottom,24px),24px);--cap-inset-bottom:env(safe-area-inset-bottom,0px)}
html.capacitor-app .app-header::before{content:'';display:block;height:var(--cap-inset);background:#1a1a2e;width:100%;flex-shrink:0}
html[data-theme="dark"].capacitor-app .app-header::before{background:#30333d}
html.capacitor-app #app::after{content:'';display:block;height:var(--cap-bottom);background:var(--bg);width:100%;flex-shrink:0}

/* ── APP SHELL ── */
#app{display:none;flex-direction:column;height:100vh;height:100dvh;overflow:hidden;opacity:0;transform:translateY(8px);transition:opacity .34s ease,transform .34s ease}

/* ── HEADER ── */
.app-header{position:sticky;top:0;z-index:100;overflow:visible;box-shadow:0 4px 18px rgba(0,0,0,.11),0 1px 4px rgba(0,0,0,.06)}
html[data-theme="dark"] .app-header{box-shadow:0 4px 22px rgba(0,0,0,.32),0 1px 6px rgba(0,0,0,.18)}
.app-header::after{content:'';position:absolute;bottom:-22px;left:0;right:0;height:22px;background:linear-gradient(to bottom,var(--bg),transparent);pointer-events:none;z-index:99}
html[data-theme="dark"] .app-header::after{background:linear-gradient(to bottom,var(--bg),transparent)}
.header-strip{background:#fff;border-bottom:1px solid rgba(0,0,0,.07);display:flex;align-items:center;padding:6px 16px;transition:background .18s}
html[data-theme="dark"] .header-strip{background:var(--bg);border-bottom-color:transparent}
.trgt{display:flex;align-items:center;gap:8px}
.rpill{font-size:.72rem;font-weight:500;background:transparent;border:1px solid rgba(0,0,0,.15);color:#6b7280;padding:4px 11px;border-radius:6px;letter-spacing:.2px;line-height:1;display:inline-flex;align-items:center}
.lbtn{background:transparent;border:1px solid rgba(0,0,0,.15);color:#6b7280;padding:4px 11px;border-radius:6px;cursor:pointer;font-size:.72rem;font-weight:500;transition:all .15s;line-height:1;display:inline-flex;align-items:center;gap:5px}
.lbtn:hover{background:rgba(0,0,0,.05);border-color:rgba(0,0,0,.28);color:#374151}
html[data-theme="dark"] .rpill{background:transparent;border-color:rgba(255,255,255,.15);color:#8891a8}
html[data-theme="dark"] .lbtn{background:transparent;border-color:rgba(255,255,255,.15);color:#8891a8}
html[data-theme="dark"] .lbtn:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.28);color:#c0c8d8}

/* App switch dropdown */
.app-switch-wrap{position:relative;display:inline-flex;align-items:center;vertical-align:middle}
.app-switch-btn{background:transparent;border:1px solid rgba(0,0,0,.15);color:#6b7280;padding:4px 11px;border-radius:6px;cursor:pointer;font-size:.72rem;font-weight:500;transition:all .15s;line-height:1;display:inline-flex;align-items:center;gap:5px;font-family:inherit;margin:0;box-sizing:border-box;letter-spacing:.2px}
.app-switch-btn:hover{background:rgba(0,0,0,.05);border-color:rgba(0,0,0,.28);color:#374151}
.app-switch-btn .fa-chevron-down{font-size:.55rem;transition:transform .2s}
.app-switch-wrap.open .app-switch-btn .fa-chevron-down{transform:rotate(180deg)}
.app-switch-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:180px;background:#fff;border:1px solid rgba(0,0,0,.1);border-radius:10px;box-shadow:0 8px 28px rgba(0,0,0,.14);z-index:9999;padding:6px;opacity:0;transform:translateY(-8px) scale(.96);pointer-events:none;transition:opacity .18s ease,transform .18s ease}
.app-switch-wrap.open .app-switch-menu{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.app-switch-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:7px;cursor:pointer;font-size:.82rem;font-weight:500;color:var(--tx,#333);transition:background .12s;border:none;background:none;width:100%;text-align:left;font-family:inherit}
.app-switch-item:hover{background:rgba(0,0,0,.05)}
.app-switch-item.active{background:var(--ac,#e65100);color:#fff;font-weight:600;cursor:default}
.app-switch-item.active:hover{background:var(--ac,#e65100)}
.app-switch-item i{width:18px;text-align:center;font-size:.85rem}
.app-switch-sep{height:1px;background:var(--bd,#e5e7eb);margin:4px 8px}
html[data-theme="dark"] .app-switch-btn{border-color:rgba(255,255,255,.15);color:#8891a8}
html[data-theme="dark"] .app-switch-btn:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.28);color:#c0c8d8}
html[data-theme="dark"] .app-switch-menu{background:#1e2128;border-color:rgba(255,255,255,.1);box-shadow:0 8px 28px rgba(0,0,0,.4)}
html[data-theme="dark"] .app-switch-item:hover{background:rgba(255,255,255,.07)}
html[data-theme="dark"] .app-switch-item.active{background:var(--ac,#e65100);color:#fff}

/* Usage bar */
#usage-bar-wrap{display:none;flex:1;max-width:170px;margin:0 14px}
#usage-bar-track{height:3px;background:var(--bd);border-radius:2px;overflow:hidden}
#usage-bar-fill{height:100%;width:0%;background:var(--ok);border-radius:2px;transition:width .5s ease,background .5s ease}
#usage-bar-wrap.capped #usage-bar-fill{background:#e53935}
#usage-bar-labels{display:flex;justify-content:space-between;align-items:center;margin-bottom:3px}
#usage-bar-label{font-size:.62rem;font-weight:600;color:var(--mu);text-transform:uppercase;letter-spacing:.4px}
#usage-bar-pct{font-size:.62rem;color:var(--mu)}

/* Topbar / logo area */
.topbar{background:var(--pr);height:80px;position:relative;z-index:1;transition:var(--tr)}
html[data-theme="dark"] .topbar{background:#1e2128}
.header-badge{height:175px;width:auto;object-fit:contain;filter:drop-shadow(0 4px 14px rgba(0,0,0,.38));z-index:2}
.logo-link{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:3;pointer-events:none}
.logo-link::after{content:'';position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:110px;height:130px;pointer-events:auto;cursor:pointer;z-index:4}
@media(max-width:600px){
  .topbar{height:60px}
  .header-badge{height:130px}
  .logo-link::after{width:82px;height:97px}
  .header-strip{padding:5px 12px;position:relative}
  .header-strip .rpill{position:absolute;left:12px;top:50%;transform:translateY(-50%)}
  .tg-gap{flex:0 0 120px}
  .tab{padding:13px 4px;font-size:.76rem;min-height:48px;box-sizing:border-box}
}

/* ── TABS ── */
.tabs{display:flex;align-items:stretch;background:var(--bg);border-bottom:2px solid var(--bd);padding-left:max(12px,calc(50% - 585px + var(--cshift,0px)));padding-right:max(12px,calc(50% - 585px - var(--cshift,0px)));transition:padding-left .25s ease,padding-right .25s ease;flex-wrap:nowrap}
.tg-left,.tg-right{display:flex;flex:1;min-width:0}
.tg-gap{flex:0 0 clamp(80px, 16vw, 200px);order:0}
.tg-left{order:-1}.tg-right{order:1}
.tab{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;text-align:center;padding:10px 8px;font-size:clamp(.74rem, 1.1vw, .82rem);font-weight:600;cursor:pointer;color:#6b7280;border-bottom:3px solid transparent;margin-bottom:-2px;white-space:nowrap;position:relative;transition:color .15s;user-select:none;min-width:0}
.tab span{overflow:hidden;text-overflow:ellipsis}
.tab:hover{color:var(--tx)}
.tab.active{color:#f37006;border-bottom-color:#f37006}
.tab.disabled{opacity:.5;cursor:not-allowed}
.bdg{position:absolute;top:2px;right:2px;background:#f37006;color:#fff;font-size:.58rem;font-weight:700;border-radius:10px;padding:1px 5px}
@media(max-width:600px){.bdg{position:static;display:inline-block;margin-left:3px;vertical-align:middle}}
html[data-theme="dark"] .tabs{background:var(--bg);border-bottom-color:var(--bd)}
html[data-theme="dark"] .tab{color:#8891a8}
html[data-theme="dark"] .tab:hover{color:#c0c8d8}
html[data-theme="dark"] .tab.active{color:var(--ac);border-bottom-color:var(--ac)}
@media(max-width:500px){.tg-gap{flex:0 0 64px}.tg-left,.tg-right{flex:1;min-width:0;border-bottom:none}.tabs{padding-left:6px;padding-right:6px}.tab{padding:12px 3px;font-size:.72rem;gap:3px;min-height:48px;box-sizing:border-box}.tab i{font-size:.72rem}}

/* ── INNER TABS (sub-tabs) — unified sales style ── */
.itabs{display:flex;background:var(--card);border-bottom:2px solid var(--bd);margin-bottom:16px;gap:0;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.itabs::-webkit-scrollbar{display:none}
.tc > .itabs{border:1px solid var(--bd);border-bottom:1px solid var(--bd);border-radius:var(--rad) var(--rad) 0 0;box-shadow:var(--sh);margin-bottom:0}
.tc > .itabs .itab{margin-bottom:0}
.tc > .itabs .itab:first-child{border-top-left-radius:calc(var(--rad) - 1px)}
.tc > .itabs .itab:last-of-type{border-top-right-radius:calc(var(--rad) - 1px)}
.tc > .itabs ~ * > .card:first-child,.tc > .itabs ~ .card:not(.no-merge){border-top:none;border-top-left-radius:0;border-top-right-radius:0;margin-top:0}
.tc > .itabs ~ .content{padding-top:0}
html[data-theme="dark"] .tc > .itabs{border-color:var(--bd)}
.itab{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:11px 8px;text-align:center;font-size:.8rem;font-weight:600;cursor:pointer;color:var(--mu);border:none;background:none;border-bottom:2px solid transparent;margin-bottom:-2px;font-family:inherit;transition:all .18s;white-space:nowrap}
.itab:hover{color:var(--tx);background:var(--bg)}
.itab.active{color:var(--ac);border-bottom-color:var(--ac);background:none}
html[data-theme="dark"] .itab{color:var(--mu)}
html[data-theme="dark"] .itab:hover{color:var(--tx)}
@media(max-width:520px){.itab{flex-direction:column;gap:3px;padding:10px 4px;font-size:.70rem;white-space:normal;min-height:48px;box-sizing:border-box}.itab i{font-size:1rem}.itab span{font-size:.67rem;line-height:1.2}}

/* Document sub-tabs (alias for itabs in sales context) */
.doc-stab{flex:1;padding:11px 8px;border:none;background:none;cursor:pointer;font-size:.8rem;font-weight:600;color:var(--mu);border-bottom:2px solid transparent;transition:all .18s;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:6px}
.doc-stab:hover{color:var(--tx);background:var(--bg)}
.doc-stab.active{color:var(--ac);border-bottom-color:var(--ac);background:none}

/* ── BUTTONS ── */
.bsm{padding:6px 14px;border:none;border-radius:7px;font-size:.82rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:5px;transition:all .15s;background:var(--ac);color:#fff}
.bsm:hover:not(:disabled){filter:brightness(1.08);transform:translateY(-1px)}
.bsm:active:not(:disabled){transform:translateY(0)}
.bsm:disabled{opacity:.5;cursor:not-allowed}
.bsm.bsm-xs{font-size:.72rem;padding:4px 10px}
.bsm.bsm-ghost{background:#f0f2f5;color:var(--mu)}
html[data-theme="dark"] .bsm.bsm-ghost{background:#3a3d47;color:var(--mu)}
.bsm.bred{background:#e53935}
.blg{padding:12px 22px;border:none;border-radius:9px;font-size:.95rem;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:all .18s;background:var(--ac);color:#fff}
.blg:hover:not(:disabled){filter:brightness(1.08);transform:translateY(-1px);box-shadow:var(--sh-md)}
.blg:active:not(:disabled){transform:translateY(0);filter:brightness(.96)}
.blg:disabled{opacity:.5;cursor:not-allowed}
.blg.blg-ghost{background:#f0f2f5;color:var(--mu)}
html[data-theme="dark"] .blg.blg-ghost{background:#3a3d47;color:var(--mu)}
.bred{background:var(--ac);color:#fff}
@media(max-width:600px){.bsm{padding:10px 14px;min-height:44px;box-sizing:border-box}.blg{padding:14px 22px;min-height:48px;box-sizing:border-box}}
.bblue{background:var(--ac2);color:#fff}
.bgrn{background:var(--ok);color:#fff}
.bpr{width:100%;padding:13px;border:none;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;background:var(--ac);color:#fff;margin-top:6px;transition:filter .15s}
.bpr:hover{filter:brightness(1.08)}

/* ── LAYOUT ── */
#app-body{display:flex;flex:1;overflow:hidden;position:relative}
#main-content{flex:1;overflow-y:auto;min-width:0}
.content{padding:22px 16px 8px;max-width:1203px;margin:0 auto;width:100%}
.tc{display:none}.tc.active{display:block;animation:pgFade .22s ease}
.itc{display:none}.itc.active{display:block;animation:pgFade .18s ease}
@keyframes pgFade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.subtab-enter{animation:pgFade .2s ease both}

/* ── CARDS ── */
.card{background:var(--card);border-radius:var(--rad);padding:18px;margin-bottom:14px;box-shadow:var(--sh);border:1px solid var(--bd);border-top:1px solid rgba(255,255,255,0.82);transition:var(--tr)}
.card:last-child{margin-bottom:10px}
.ctitle{font-size:.9rem;font-weight:700;color:var(--tx);margin-bottom:14px;display:flex;align-items:center;gap:7px}
html[data-theme="dark"] .card{border-top-color:rgba(255,255,255,0.05)}
html[data-theme="dark"] .ctitle{color:var(--tx)}

/* ── STAT CARDS ── */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}
@media(max-width:800px){.stat-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.stat-grid{grid-template-columns:repeat(2,1fr)}}
.stat-card{background:var(--bg);border:1px solid var(--bd);border-radius:10px;padding:12px 14px;text-align:center}
.stat-card .sv{font-size:1.6rem;font-weight:800;color:var(--ac);line-height:1.1}
.stat-card .sl{font-size:.7rem;font-weight:600;color:var(--mu);text-transform:uppercase;letter-spacing:.5px;margin-top:3px}
.stat-card.fault .sv{color:#e53935}
.stat-card.ok .sv{color:var(--ok)}
.stat-card.blue .sv{color:var(--ac2)}
html[data-theme="dark"] .stat-card{background:var(--card)}

/* ── FORMS ── */
.fi{margin-bottom:14px}
.fi label{display:block;font-size:.78rem;font-weight:600;color:var(--mu);margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px}
.fi input,.fi select,.fi textarea{width:100%;padding:11px 14px;border:1.5px solid var(--bd);border-radius:8px;font-size:.95rem;font-family:inherit;outline:none;transition:border .2s,box-shadow .18s;background:#fafafa}
.fi input:focus,.fi select:focus,.fi textarea:focus{border-color:var(--ac);background:#fff;box-shadow:0 0 0 3px rgba(243,112,6,.12)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:10px}
html[data-theme="dark"] .fi input,
html[data-theme="dark"] .fi select,
html[data-theme="dark"] .fi textarea{background:var(--input);color:var(--tx);border-color:var(--bd)}
html[data-theme="dark"] .fi input:focus,
html[data-theme="dark"] .fi select:focus,
html[data-theme="dark"] .fi textarea:focus{background:var(--input)}

/* ── CHAT SIDEBAR ── */
#chat-sidebar{width:340px;flex-shrink:0;background:var(--card);display:flex;flex-direction:column;transition:width .25s ease,opacity .25s ease,margin .25s ease;overflow:hidden;border:1px solid var(--bd);border-radius:var(--rad);box-shadow:var(--sh-md);margin:22px 0 22px 28px}
#chat-sidebar.collapsed{width:0;border:none;opacity:0;margin:0}
.chat-header{padding:12px 14px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;font-size:.85rem;font-weight:700;color:var(--tx)}
.chat-wrap{display:flex;flex-direction:column;flex:1;overflow:hidden;padding:0 10px 10px}
.chat-msgs{flex:1;overflow-y:auto;padding:12px 0;display:flex;flex-direction:column;gap:10px}
.chat-bubble{max-width:85%;padding:10px 14px;border-radius:14px;font-size:.85rem;line-height:1.6}
.chat-bubble.user{background:var(--ac2);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.chat-bubble.ai{background:#f0f2f5;color:var(--tx);align-self:flex-start;border-bottom-left-radius:4px}
.chat-bubble.ai strong{color:var(--pr)}
.chat-typing{display:flex;align-items:center;gap:6px;padding:10px 14px;background:#f0f2f5;border-radius:14px;border-bottom-left-radius:4px;align-self:flex-start;font-size:.82rem;color:var(--mu)}
.chat-input-row{display:flex;gap:8px;padding-top:10px;border-top:1px solid var(--bd);margin-top:8px}
.chat-input-row textarea{flex:1;padding:10px 12px;border:1.5px solid var(--bd);border-radius:8px;font-size:.88rem;font-family:inherit;resize:none;outline:none;max-height:100px}
.chat-input-row textarea:focus{border-color:var(--ac)}
.chat-img-btn{padding:8px 10px;background:none;border:1.5px solid var(--bd);border-radius:8px;cursor:pointer;color:var(--mu);font-size:1rem;flex-shrink:0;transition:border-color .2s,color .2s}
.chat-img-btn:hover{border-color:var(--ac);color:var(--ac)}
.chat-send{padding:10px 16px;background:var(--ac);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:700;font-size:.88rem;flex-shrink:0}
.chat-send:disabled{opacity:.5;cursor:not-allowed}
.chat-bubble img.chat-attached-img{max-width:100%;max-height:240px;border-radius:8px;margin-bottom:6px;display:block}
html[data-theme="dark"] .chat-bubble.ai{background:#3a3d47;color:var(--tx)}
html[data-theme="dark"] .chat-bubble.ai h3{color:var(--ac)}
html[data-theme="dark"] .chat-bubble.ai strong{color:var(--ac)}
html[data-theme="dark"] .chat-typing{background:#3a3d47;color:var(--mu)}
html[data-theme="dark"] .chat-input-row textarea{background:var(--input);color:var(--tx);border-color:var(--bd)}
html[data-theme="dark"] .chat-img-btn{border-color:var(--bd);color:var(--mu)}
html[data-theme="dark"] .chat-bubble.user{background:var(--ac)}
@media(max-width:860px){
  #chat-sidebar{position:fixed;left:0;top:0;bottom:0;z-index:150;width:calc(100vw - 40px);max-width:320px;box-shadow:var(--sh-md);margin:0}
  #chat-sidebar.collapsed{width:0}
}
/* Chat sidebar edge tab — floating orange strip */
#chat-sidebar-tab{position:fixed;left:0;top:calc(var(--header-h, 166px) + 22px);bottom:22px;z-index:98;background:var(--ac);color:#fff;border:1px solid rgba(0,0,0,.12);border-left:none;border-radius:0 8px 8px 0;width:18px;padding:0;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;box-shadow:2px 0 10px rgba(243,112,6,.3);transition:background .2s,box-shadow .2s,top .2s;user-select:none}
#chat-sidebar-tab:hover{background:hsl(26,95%,42%);box-shadow:3px 0 14px rgba(243,112,6,.48)}
#chat-sidebar-tab .tab-icon{font-size:.72rem;transform:rotate(90deg);display:block}
#chat-sidebar-tab .tab-label{writing-mode:vertical-rl;text-orientation:mixed;font-size:.62rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
/* Chat context bar (tech troubleshoot) */
.chat-ctx{padding:8px 12px;background:#e3f2fd;border:1px solid #90caf9;border-radius:8px;font-size:.75rem;color:#0d47a1;margin-bottom:10px}
html[data-theme="dark"] .chat-ctx{background:#2f3a4a;border-color:#3d5a7a;color:#a0c4e8}

/* ── TYPE BADGES ── */
.tbadge{font-size:.65rem;padding:2px 7px;border-radius:10px;font-weight:700;display:inline-block}
.ti{background:#d4edda;color:#155724}.tt{background:#fff3cd;color:#856404}
.tp{background:#d1ecf1;color:#0c5460}.tq{background:#fce4ec;color:#880e4f}
.tw{background:#e8d5f5;color:#5b2d8e}.tex{background:#f0f0f0;color:#555}
.tcustom{background:#e3f2fd;color:#0d47a1}

/* ── DOCUMENT LIBRARY TREE ── */
.brand-group{margin-bottom:8px;border:1.5px solid var(--bd);border-radius:10px;overflow:hidden}
.brand-hdr{background:#e8ecf0;padding:11px 14px;font-weight:700;font-size:.88rem;cursor:pointer;display:flex;align-items:center;justify-content:space-between;user-select:none;gap:8px}
.brand-hdr:hover{background:#dde2e9}
.brand-body{display:none}.brand-body.open{display:block}
.model-group{border-top:1px solid var(--bd)}
.model-hdr{padding:9px 14px 9px 28px;font-weight:600;font-size:.83rem;cursor:pointer;display:flex;align-items:center;justify-content:space-between;background:#f2f4f7}
.model-hdr:hover{background:#eaecf1}
.model-body{display:none}.model-body.open{display:block}
.submodel-group{border-top:1px solid var(--bd)}
.submodel-hdr{padding:8px 14px 8px 46px;font-weight:600;font-size:.83rem;cursor:pointer;display:flex;align-items:center;justify-content:space-between;background:#f7f8fa}
.submodel-hdr:hover{background:#eaecf1}
.submodel-body{display:none}.submodel-body.open{display:block}
.lib-doc-item{padding:9px 14px 9px 46px;border-top:1px solid #e2e5e9;background:#fff;display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:.82rem}
.lib-doc-item:hover{background:#f4f6f9}
.lib-doc-info{flex:1;min-width:0}
.lib-doc-name{font-weight:600;font-size:.83rem}
.lib-doc-meta{font-size:.72rem;color:var(--mu);margin-top:2px}
.doc-item{padding:9px 14px 9px 40px;border-top:1px solid #e2e5e9;background:#fff;display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:.82rem}
.doc-item.sub-indent{padding-left:60px}
.doc-item:hover{background:#f4f6f9}
.doc-info{flex:1;min-width:0}
.doc-name{font-weight:600;font-size:.83rem}
.doc-meta{font-size:.72rem;color:var(--mu);margin-top:2px}
.doc-actions{display:flex;gap:6px;flex-shrink:0}
.doc-item-icon{width:34px;height:34px;border-radius:8px;background:#fff3e0;color:var(--ac);display:flex;align-items:center;justify-content:center;font-size:.95rem;flex-shrink:0}
html[data-theme="dark"] .doc-item-icon{background:rgba(243,112,6,.18)}
.pnd-btns{margin-top:8px;display:flex;gap:6px;flex-wrap:wrap}
.pip-panel-hdr{padding:10px 14px;font-weight:600;font-size:.84rem;cursor:pointer;display:flex;align-items:center;justify-content:space-between;background:var(--card);user-select:none;gap:8px}
.pip-panel-hdr:hover{background:var(--bg)}
@media(max-width:540px){.doc-actions{flex-basis:100%;flex-shrink:1;margin-top:6px}.doc-actions .bsm,.doc-actions a.bsm{flex:1;text-align:center;justify-content:center}}
@media(max-width:600px){
  .doc-item{flex-wrap:wrap;align-items:flex-start}
  .pnd-btns .bsm{flex:1;text-align:center}
}
html[data-theme="dark"] .brand-hdr{background:#3a3d47;color:var(--tx)}
html[data-theme="dark"] .brand-hdr:hover{background:#44475a}
html[data-theme="dark"] .model-hdr{background:#353840;color:var(--tx)}
html[data-theme="dark"] .model-hdr:hover{background:#3a3d47}
html[data-theme="dark"] .submodel-hdr{background:#2d3038;color:var(--tx)}
html[data-theme="dark"] .submodel-hdr:hover{background:#353840}
html[data-theme="dark"] .lib-doc-item{background:var(--card)}
html[data-theme="dark"] .lib-doc-item:hover{background:#3a3d47}
html[data-theme="dark"] .doc-item{background:var(--card);border-top-color:#2a2d35}
html[data-theme="dark"] .doc-item:hover{background:#35383f}
html[data-theme="dark"] .doc-meta{color:var(--mu)}
html[data-theme="dark"] .pip-panel-hdr{background:var(--card)}
html[data-theme="dark"] .pip-panel-hdr:hover{background:#2a2d36}

/* ── DOOR ID PHOTO THUMBNAILS ── */
.dlib-thumb{position:relative;width:80px;height:80px;border-radius:8px;overflow:hidden;cursor:pointer;border:1.5px solid var(--bd);transition:transform .15s,box-shadow .15s;flex-shrink:0}
.dlib-thumb:hover{transform:scale(1.05);box-shadow:0 2px 8px rgba(0,0,0,.15)}
.dlib-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.dlib-thumb-label{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.65));color:#fff;font-size:.62rem;padding:2px 5px 3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dlib-thumb-del{position:absolute;top:2px;right:2px;background:rgba(0,0,0,.5);color:#fff;border:none;border-radius:50%;width:18px;height:18px;font-size:.72rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}
.dlib-thumb:hover .dlib-thumb-del{opacity:1}
.dlib-thumb-del:hover{background:rgba(220,40,40,.8)}
html[data-theme="dark"] .dlib-thumb{border-color:#444}
@media(max-width:600px){.dlib-thumb{width:64px;height:64px}}

/* ── SEARCH BAR (manual library) ── */
.search-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.search-bar input,.search-bar select{flex:1;min-width:100px;padding:9px 12px;border:1.5px solid var(--bd);border-radius:7px;font-size:.85rem;background:#fff;outline:none}
.search-bar input:focus,.search-bar select:focus{border-color:var(--ac);box-shadow:0 0 0 3px rgba(243,112,6,.12)}
html[data-theme="dark"] .search-bar input,
html[data-theme="dark"] .search-bar select{background:var(--input);color:var(--tx);border-color:var(--bd)}

/* ── UPLOAD ZONE (sales visual style as standard) ── */
.upload-zone{border:2px dashed var(--bd);border-radius:10px;padding:24px;text-align:center;cursor:pointer;transition:all .2s;background:var(--card);margin-bottom:0}
.upload-zone:hover,.upload-zone.drag{border-color:var(--ac);background:#fff5f6}
.upload-zone.drag{border-style:solid;background:#fff0e6}
.upload-zone i{font-size:2rem;color:var(--mu);margin-bottom:6px;display:block}
.upload-zone p{color:var(--mu);font-size:.88rem;margin:0}
.upload-zone strong{color:var(--ac)}
/* Tech upload zone (upzone alias) */
.upzone{border:2px dashed var(--bd);border-radius:10px;padding:24px;text-align:center;cursor:pointer;transition:all .2s;margin-bottom:14px}
.upzone:hover,.upzone.drag-over{border-color:var(--ac);background:#fff5f6}
.upzone.drag-over{border-style:solid;background:#fff0e6}
.upicon{font-size:2rem;margin-bottom:6px}
html[data-theme="dark"] .upload-zone{background:var(--card);border-color:var(--bd)}
html[data-theme="dark"] .upload-zone:hover,html[data-theme="dark"] .upload-zone.drag{border-color:var(--ac);background:rgba(243,112,6,.08)}
html[data-theme="dark"] .upzone{border-color:var(--bd)}
html[data-theme="dark"] .upzone:hover,html[data-theme="dark"] .upzone.drag-over{border-color:var(--ac);background:rgba(243,112,6,.08)}

/* Doc chips */
.doc-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:6px;background:#f0f2f5;border:1px solid var(--bd);font-size:.78rem;font-weight:500;color:var(--tx)}
.doc-chip button{background:none;border:none;cursor:pointer;color:var(--mu);font-size:.8rem;padding:0;display:flex;align-items:center}
.doc-chip button:hover{color:#e53935}
html[data-theme="dark"] .doc-chip{background:#3a3d47;border-color:var(--bd)}

/* ── DOOR FINDER TYPE GRID ── */
.df-type-grid{display:flex;flex-wrap:wrap;gap:6px}
.df-type-chip{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;border-radius:16px;font-size:.75rem;font-weight:600;border:1.5px solid var(--bd);background:var(--bg);cursor:pointer;user-select:none;transition:all .15s;color:var(--tx)}
.df-type-chip:hover{border-color:var(--ac);background:rgba(243,112,6,.06)}
.df-type-chip.active{background:var(--ac);color:#fff;border-color:var(--ac)}
html[data-theme="dark"] .df-type-chip{background:var(--card);border-color:var(--bd)}
html[data-theme="dark"] .df-type-chip.active{background:var(--ac);color:#fff;border-color:var(--ac)}

/* ── BRAND DIRECTORY ── */
.bdir-row{border:1.5px solid var(--bd);border-radius:10px;margin-bottom:8px;overflow:hidden}
.bdir-hdr{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;background:#e8ecf0;cursor:pointer;gap:8px;user-select:none}
.bdir-hdr:hover{background:#dde2e9}
.bdir-name{display:flex;align-items:center;gap:8px;flex:1;min-width:0;font-weight:700;font-size:.88rem}
.bdir-name .chevron{width:1.2em;text-align:center;transition:transform .2s;font-size:.65rem;color:var(--mu)}
.bdir-name .chevron.open{transform:rotate(90deg)}
.bdir-body{border-top:1px solid var(--bd);display:none}
.bdir-body.open{display:block}
.bdir-section{border-top:1px solid var(--bd)}
.bdir-section:first-child{border-top:none}
.bdir-section-hdr{padding:9px 14px 9px 28px;font-weight:600;font-size:.83rem;display:flex;align-items:center;gap:6px;background:#f2f4f7;color:var(--tx)}
.bdir-section-hdr:hover{background:#eaecf1}
.bdir-section-acts{padding:6px 14px 10px 40px;display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.bdir-section-acts input{width:100%;padding:6px 10px;border:1.5px solid var(--bd);border-radius:7px;font-size:.82rem;background:var(--bg);color:var(--tx);outline:none}
.bdir-section-acts input:focus{border-color:var(--ac)}
.bdir-loading-msg{display:block;font-size:.78rem;color:var(--mu);padding:8px 14px 8px 36px}
.bdir-contact-card{border:none;border-radius:0;border-top:1px solid #e2e5e9;padding:9px 14px 9px 40px;background:#fff;margin-bottom:0;display:flex;gap:8px;align-items:flex-start}
.bdir-contact-card:first-child{border-top:none}
.bdir-contact-card:hover{background:#f4f6f9}
.bdir-contact-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}
.bdir-contact-info .lbl{font-weight:500;font-size:.83rem;color:var(--tx)}
.bdir-contact-info .det{font-size:.78rem;color:var(--mu)}
.bdir-contact-info a{color:var(--ac);text-decoration:none}
.bdir-contact-info a:hover{text-decoration:underline}
.bdir-contact-info i{font-size:.75rem;width:1em;text-align:center}
/* Brand directory notes: pill toggle (More/Less) */
.bdir-notes-wrap{margin-top:6px}
.bdir-notes-preview{font-size:.76rem;color:var(--mu);font-style:italic;line-height:1.4}
.bdir-notes-detail{display:none;font-size:.76rem;color:var(--mu);font-style:italic;line-height:1.5;background:var(--bg);padding:8px 10px;border-radius:6px;white-space:pre-wrap;margin-top:4px}
.bdir-notes-pill{display:inline-flex;align-items:center;gap:4px;min-height:32px;padding:4px 12px;border:1px solid var(--bd);border-radius:16px;background:var(--bg);color:var(--ac);font-size:.72rem;font-weight:600;cursor:pointer;margin-top:6px;transition:background .15s;font-family:inherit;-webkit-tap-highlight-color:transparent}
.bdir-notes-pill:hover{background:rgba(243,112,6,.06)}
.bdir-notes-pill:active{background:rgba(243,112,6,.12)}
.bdir-contact-form{background:var(--card);border:1px dashed var(--bd);border-radius:8px;padding:10px 12px;margin:4px 14px 8px 40px}
.bdir-contact-form .frow{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:6px}
.bdir-contact-form input{width:100%;padding:7px 10px;border:1.5px solid var(--bd);border-radius:7px;font-size:.82rem;background:var(--bg);color:var(--tx);outline:none;font-family:inherit}
.bdir-contact-form input:focus{border-color:var(--ac)}
.bdir-model-chip{display:inline-flex;align-items:center;gap:5px;background:var(--card);border:1px solid var(--bd);border-radius:20px;padding:3px 10px;font-size:.78rem;margin:2px}
.bdir-model-chip button{background:none;border:none;cursor:pointer;color:var(--mu);font-size:.8rem;padding:0;line-height:1}
.bdir-add-row{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}
.bdir-add-row input{flex:1;min-width:80px;padding:7px 10px;border:1.5px solid var(--bd);border-radius:7px;font-size:.83rem;background:var(--bg);color:var(--tx);outline:none}
.bdir-add-row input:focus{border-color:var(--ac)}
.bdir-search-bar{height:3px;background:transparent;overflow:hidden;position:relative;transition:background .2s}
.bdir-search-bar.scanning{background:var(--bd)}
.bdir-search-bar.scanning::after{content:'';position:absolute;top:0;left:-40%;width:40%;height:100%;background:var(--ac);animation:bdir-scan 1.4s ease-in-out infinite}
@keyframes bdir-scan{from{left:-40%}to{left:100%}}
html[data-theme="dark"] .bdir-hdr{background:#3a3d47;color:var(--tx)}
html[data-theme="dark"] .bdir-hdr:hover{background:#44475a}
html[data-theme="dark"] .bdir-section-hdr{background:#353840;color:var(--tx)}
html[data-theme="dark"] .bdir-section-hdr:hover{background:#3a3d47}
html[data-theme="dark"] .bdir-contact-card{background:var(--card);border-top-color:#2a2d35}
html[data-theme="dark"] .bdir-contact-card:hover{background:#35383f}
@media(max-width:480px){.bdir-contact-form .frow{grid-template-columns:1fr}}

/* ── APP BANNER (unified push-down notification bar) ── */
#app-banner{display:none;width:100%;padding:10px 16px;font-size:.82rem;font-weight:600;text-align:center;align-items:center;justify-content:center;gap:10px;box-shadow:0 2px 8px rgba(0,0,0,.18);z-index:101;color:#fff;animation:appBannerIn .3s ease}
#app-banner.show{display:flex}
#app-banner.offline{background:#c62828}
#app-banner.slow{background:#e65100}
#app-banner.retrying{background:#1565c0}
#app-banner.back{background:#2e7d32}
#app-banner.restore{background:#2e7d32}
#app-banner.update{background:linear-gradient(135deg,#1565c0,#1976d2)}
#app-banner .ab-btn{background:#fff;border:none;padding:4px 14px;border-radius:4px;font-weight:600;cursor:pointer;font-size:.82rem}
#app-banner .ab-btn.offline{color:#c62828}
#app-banner .ab-btn.back{color:#2e7d32}
#app-banner .ab-btn.update{color:#1565c0}
#app-banner .ab-btn.retrying{color:#1565c0}
#app-banner .ab-dismiss{background:none;border:none;color:#fff;cursor:pointer;font-size:18px;padding:0 4px;opacity:.7}
#app-banner .ab-dismiss:hover{opacity:1}
#app-banner.hiding{animation:appBannerOut .3s ease forwards}
@keyframes appBannerIn{from{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}
@keyframes appBannerOut{from{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-100%)}}
/* Legacy conn-banner — hidden, replaced by #app-banner */
#conn-banner{display:none!important}

/* ── MODAL ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:200;display:flex;align-items:center;justify-content:center;padding:16px}
.modal{background:#fff;border-radius:var(--rad);max-width:540px;width:100%;max-height:85vh;overflow-y:auto;box-shadow:0 8px 40px rgba(0,0,0,.3);transition:var(--tr)}
.modal.modal-wide{max-width:900px}
html[data-theme="dark"] .modal{background:var(--card)}
.modal-hdr{padding:16px 18px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:#fff;z-index:1}
html[data-theme="dark"] .modal-hdr{background:var(--card);border-bottom-color:var(--bd)}
.modal-hdr h3{font-size:.95rem;color:var(--pr)}
html[data-theme="dark"] .modal-hdr h3{color:var(--tx)}
.modal-close{background:none;border:none;font-size:1.3rem;cursor:pointer;color:var(--mu);padding:2px 6px}
html[data-theme="dark"] .modal-close{color:var(--mu)}
html[data-theme="dark"] .modal-close:hover{color:var(--tx)}
.modal-body{padding:18px}

/* ── TOAST ── */
#toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%);background:var(--toast-bg,#323232);color:#fff;padding:10px 22px;border-radius:8px;font-size:.85rem;font-weight:600;z-index:650;pointer-events:none;opacity:0;transition:opacity .22s ease;max-width:calc(100vw - 32px);text-align:center;line-height:1.35}
#toast.show{opacity:1}

/* ── MISC SHARED ── */
.empty{text-align:center;padding:24px;color:var(--mu);font-size:.85rem}
.shead{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--mu);margin:16px 0 8px}
html[data-theme="dark"] .shead{color:var(--mu)}
.hidden{display:none!important}
textarea{resize:vertical}
.loading{text-align:center;padding:28px;color:var(--mu)}
.spin{width:32px;height:32px;border:3px solid var(--bd);border-top-color:var(--ac);border-radius:50%;animation:sp .8s linear infinite;margin:0 auto 12px}
.mspin{width:16px;height:16px;border:2px solid #90caf9;border-top-color:#0d47a1;border-radius:50%;animation:sp .8s linear infinite;flex-shrink:0}
@keyframes sp{to{transform:rotate(360deg)}}
.emsg{color:#e53935;font-size:.82rem;margin-top:8px;text-align:center}

/* Source badges */
.sb{display:inline-block;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:10px;margin:2px}
.bman{background:#d4edda;color:#155724}.bweb{background:#d1ecf1;color:#0c5460}
.bpnd{background:#f0f2f5;color:#555}.bai{background:#f0e6ff;color:#4a1070}
.berr{background:#f8d7da;color:#721c24}.bwrn{background:#fce4ec;color:#880e4f}
html[data-theme="dark"] .bman{background:#1a3828;color:#7dc47d}
html[data-theme="dark"] .bweb{background:#1e2f42;color:#a0c4e8}
html[data-theme="dark"] .bpnd{background:#2a2d31;color:#aaa}
html[data-theme="dark"] .bai{background:#2a1e3e;color:#c0a0e0}
html[data-theme="dark"] .berr{background:#3a1f1f;color:#e09090}
html[data-theme="dark"] .bwrn{background:#3a1f2a;color:#e0a0b0}

/* ── NOTES / ALERTS ── */
.note{padding:10px 14px;border-radius:8px;font-size:.84rem;line-height:1.5;display:flex;align-items:flex-start;gap:8px}
.note i{margin-top:1px;flex-shrink:0}
.nok{background:#e8f5e9;color:#1b5e20;border:1px solid #a5d6a7}
.nerr{background:#ffebee;color:#b71c1c;border:1px solid #ef9a9a}
.nwarn{background:#fff8e1;color:#e65100;border:1px solid #ffe082}
.ninfo{background:#e3f2fd;border:1px solid #90caf9;color:#0d47a1}
html[data-theme="dark"] .nok{background:rgba(46,125,50,.18);color:#81c784;border-color:rgba(46,125,50,.4)}
html[data-theme="dark"] .nerr{background:rgba(183,28,28,.18);color:#ef9a9a;border-color:rgba(183,28,28,.4)}
html[data-theme="dark"] .nwarn{background:rgba(230,81,0,.15);color:#ffb74d;border-color:rgba(230,81,0,.35)}
html[data-theme="dark"] .ninfo{background:#1e2f42;border-color:#2d5070;color:#a0c4e8}

/* ── THEME SELECTOR ── */
.theme-seg{display:flex;background:var(--bg);border:1.5px solid var(--bd);border-radius:8px;overflow:hidden}
.tseg-btn{flex:1;padding:5px 14px;background:transparent;border:none;cursor:pointer;font-size:.8rem;font-weight:600;color:var(--mu);transition:all .15s;white-space:nowrap}
.tseg-btn:hover{color:var(--tx);background:rgba(0,0,0,.04)}
.tseg-btn.tseg-active{background:var(--ac);color:#fff}
.tseg-btn + .tseg-btn{border-left:1.5px solid var(--bd)}

/* ── ACTIVITY LOG ── */
.log-filter-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.log-filter-row input,.log-filter-row select{flex:1;min-width:90px;padding:7px 10px;border:1.5px solid var(--bd);border-radius:7px;font-size:.82rem;outline:none;background:var(--card);color:var(--tx)}
.log-filter-row input:focus,.log-filter-row select:focus{border-color:var(--ac)}
.log-tbl{width:100%;border-collapse:collapse;font-size:.78rem}
.log-tbl th{background:var(--bg);padding:7px 10px;text-align:left;font-size:.68rem;text-transform:uppercase;color:var(--mu);white-space:nowrap;position:sticky;top:0;z-index:1}
.log-tbl td{padding:7px 10px;border-bottom:1px solid var(--bd);vertical-align:top}
.log-tbl tr:hover td{background:var(--bg)}
.log-tbl .lt{white-space:nowrap;color:var(--mu);font-size:.72rem}
.log-tbl .lu{font-weight:600;color:var(--tx)}
.log-tbl .ld{color:var(--mu);font-size:.72rem;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.log-wrap{max-height:420px;overflow:auto;border:1px solid var(--bd);border-radius:8px}
.log-summary-box{background:var(--bg);border:1px solid var(--bd);border-radius:8px;padding:14px 16px;font-size:.85rem;line-height:1.7;color:var(--tx);white-space:pre-wrap;margin-top:10px}
html[data-theme="dark"] .log-summary-box{background:var(--card);border-color:var(--bd)}
.log-breakdown-wrap{display:flex;flex-direction:column;gap:6px}
.lb-row{display:flex;align-items:center;gap:8px;font-size:.78rem}
.lb-bar-bg{flex:1;height:8px;background:var(--bd);border-radius:4px;overflow:hidden}
.lb-bar-fill{height:100%;background:var(--ac);border-radius:4px;transition:width .4s ease}
.lb-cnt{font-size:.75rem;font-weight:700;color:var(--mu);min-width:28px;text-align:right}
html[data-theme="dark"] .log-filter-row input,html[data-theme="dark"] .log-filter-row select{background:var(--input);border-color:var(--bd)}
html[data-theme="dark"] .log-tbl th{background:var(--bg)}
html[data-theme="dark"] .log-wrap{border-color:var(--bd)}

/* Event pills */
.ev-pill{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:10px;white-space:nowrap}
.ev-login{background:#e3f2fd;color:#0d47a1}.ev-upload{background:#e8f5e9;color:#1b5e20}
.ev-analysis{background:#e3f2fd;color:#1565c0}.ev-success{background:#e8f5e9;color:#1b5e20}
.ev-fault{background:#fdecea;color:#b71c1c}.ev-warn{background:#fff8e1;color:#e65100}
.ev-job{background:#f3e8ff;color:#4a148c}.ev-view{background:#e0f2f1;color:#004d40}
.ev-user{background:#fce4ec;color:#880e4f}.ev-default{background:#f0f2f5;color:#455a64}

/* ── BUG REPORTS ── */
.br-card{border:1px solid var(--bd);border-radius:10px;overflow:hidden;margin-bottom:12px;background:var(--card)}
.br-hdr{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:var(--bg);border-bottom:1px solid var(--bd)}
.br-meta{flex:1;min-width:0}
.br-user{font-weight:700;font-size:.85rem;color:var(--tx)}
.br-time{font-size:.72rem;color:var(--mu);margin-top:1px}
.br-badge{font-size:.68rem;font-weight:700;padding:2px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}
.br-badge.open{background:#fff3e0;color:#e65100}
.br-badge.resolved{background:#e8f5e9;color:#2e7d32}
.br-badge.wontfix{background:#f5f5f5;color:#9e9e9e}
.br-badge.critical{background:#fdecea;color:#b71c1c}
.br-badge.high{background:#fff3e0;color:#e65100}
.br-badge.medium{background:#fff8e1;color:#f57f17}
.br-badge.low{background:#e8f5e9;color:#2e7d32}
.br-body{padding:12px 14px;display:flex;flex-direction:column;gap:10px}
.br-desc{font-size:.84rem;color:var(--tx);line-height:1.5;white-space:pre-wrap}
.br-screenshot{max-width:100%;max-height:340px;border-radius:7px;border:1px solid var(--bd);cursor:pointer;display:block;object-fit:contain}
.br-analysis{background:var(--bg);border:1px solid var(--bd);border-radius:8px;padding:11px 13px;font-size:.8rem;line-height:1.6}
.br-analysis .ba-row{display:grid;grid-template-columns:110px 1fr;gap:3px 10px;margin-bottom:3px}
.br-analysis .ba-lbl{font-weight:700;color:var(--mu);font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;padding-top:2px}
.br-analysis .ba-val{color:var(--tx)}
.br-actions{display:flex;gap:6px;flex-wrap:wrap;padding:10px 14px;border-top:1px solid var(--bd);background:var(--bg)}
.br-sshot-modal{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.82);display:flex;align-items:center;justify-content:center;cursor:zoom-out}
.br-sshot-modal img{max-width:94vw;max-height:92vh;border-radius:8px;box-shadow:0 8px 40px rgba(0,0,0,.5)}
html[data-theme="dark"] .br-badge.resolved{background:rgba(27,94,32,.2);color:#81c784}
html[data-theme="dark"] .br-badge.open{background:rgba(230,81,0,.67);color:#ffcc80}

/* ── VERSION BADGE ── */
#ver-badge{position:fixed;bottom:10px;left:12px;font-size:.65rem;color:var(--mu);opacity:.55;pointer-events:none;z-index:999;font-family:monospace;letter-spacing:.3px}

/* ── DARK MODE CATCH-ALL INPUT FIX ── */
html[data-theme="dark"] input:not([type="checkbox"]):not([type="radio"]):not([type="range"]):not([type="file"]):not([type="color"]),
html[data-theme="dark"] select,
html[data-theme="dark"] textarea{background:var(--input)!important;color:var(--tx)!important;border-color:var(--bd)!important}
html[data-theme="dark"] select option{background:var(--card);color:var(--tx)}

/* ── CAPPED STATE ── */
body.usage-capped #chat-send-btn{opacity:.45;cursor:not-allowed;pointer-events:none}
#cap-notice{display:none;padding:12px 14px;background:#fff3e0;border:1px solid #ffb74d;border-radius:10px;font-size:.82rem;color:#bf360c;text-align:center;margin:8px 0}
html[data-theme="dark"] #cap-notice{background:#3e2723;border-color:#bf360c;color:#ff8a65}

/* ── PDF VIEWER OVERLAY (Capacitor / Android) ── */
#pdf-viewer-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;background:#525659;flex-direction:column}
#pdf-viewer-overlay.open{display:flex}
#pdf-viewer-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:#1a1a2e;flex-shrink:0}
html.capacitor-app #pdf-viewer-bar{padding-top:calc(var(--cap-inset,0px) + 10px)}
#pdf-viewer-bar .pvb-title{color:#fff;font-size:.85rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;margin-right:12px}
#pdf-viewer-bar .pvb-actions{display:flex;gap:8px;flex-shrink:0}
#pdf-viewer-bar button{background:var(--ac);color:#fff;border:none;border-radius:8px;padding:8px 14px;font-size:.82rem;font-weight:600;cursor:pointer}
#pdf-viewer-bar button.pvb-dl{background:rgba(255,255,255,.15)}
#pdf-viewer-pages{flex:1;overflow:auto;-webkit-overflow-scrolling:touch;touch-action:pan-x pan-y pinch-zoom}
#pdf-viewer-pages-inner{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 0;transform-origin:0 0;min-width:100%}
#pdf-viewer-pages canvas{display:block;max-width:100%;box-shadow:0 2px 8px rgba(0,0,0,.3)}
#pdf-viewer-loading{color:#fff;font-size:.9rem;text-align:center;padding:40px 20px}
#pdf-viewer-loading .spinner{display:inline-block;width:24px;height:24px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:pdfspin .8s linear infinite;margin-bottom:12px}
@keyframes pdfspin{to{transform:rotate(360deg)}}
#pdf-viewer-page-ind{color:rgba(255,255,255,.7);font-size:.75rem;margin-right:8px;white-space:nowrap}
#pdf-viewer-thumbs{display:none;flex-shrink:0;background:#1a1a2e;padding:6px 8px;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap;gap:6px;border-top:1px solid rgba(255,255,255,.15)}
#pdf-viewer-thumbs.visible{display:flex}
html.capacitor-app #pdf-viewer-thumbs{padding-bottom:calc(var(--cap-inset-bottom,0px) + 6px)}
#pdf-viewer-thumbs canvas{display:inline-block;height:64px;width:auto;border-radius:4px;border:2px solid transparent;cursor:pointer;opacity:.6;transition:opacity .15s,border-color .15s;flex-shrink:0}
#pdf-viewer-thumbs canvas.active{border-color:var(--ac);opacity:1}
#pdf-viewer-thumbs canvas:hover{opacity:.9}
#pdf-thumb-toggle{background:rgba(255,255,255,.15);font-size:.72rem;padding:6px 10px}

/* ── OFFLINE UPLOAD QUEUE ── */
#upload-queue-badge{display:none;background:var(--ac);color:#fff;font-size:.7rem;font-weight:700;padding:2px 6px;border-radius:10px;margin-left:6px;vertical-align:middle}

/* ── BACKUP FAIL BANNER ── */
#backup-fail-banner{display:none;margin:8px 16px 0;padding:8px 14px;background:#fdecea;border:1px solid #ef9a9a;border-radius:8px;font-size:.82rem;color:#b71c1c;text-align:center}
html[data-theme="dark"] #backup-fail-banner{background:rgba(183,28,28,.18);color:#ef9a9a;border-color:rgba(183,28,28,.4)}

/* ── SKELETON LOADING ── */
@keyframes skel-shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}

/* (Pull-to-refresh removed) */
.skel{border-radius:6px;background:linear-gradient(90deg,var(--bg) 25%,rgba(0,0,0,.06) 37%,var(--bg) 63%);background-size:800px 100%;animation:skel-shimmer 1.4s ease infinite}
html[data-theme="dark"] .skel{background:linear-gradient(90deg,var(--card) 25%,rgba(255,255,255,.06) 37%,var(--card) 63%);background-size:800px 100%}
.skel-card{height:90px;margin:8px 0;border-radius:12px}
.skel-line{height:14px;margin:6px 0;border-radius:4px}
.skel-line.w60{width:60%}.skel-line.w40{width:40%}.skel-line.w80{width:80%}.skel-line.w50{width:50%}
.skel-circle{width:36px;height:36px;border-radius:50%}
.skel-wrap{padding:12px 16px}

/* ── MOBILE HEADER BAR (hidden on desktop) ── */
.mobile-hdr{display:none}

/* ── BOTTOM NAV (mobile <600px) ── */
.bottom-nav{display:none}
@media(max-width:600px){
  /* Hide top tab bar, app switch, topbar (logo), and its fade on mobile */
  .tabs{display:none !important}
  .app-switch-wrap{display:none !important}
  .topbar{display:none !important}
  .app-header::after{display:none !important}
  /* Hide desktop header strip — replaced by mobile-hdr */
  .header-strip{display:none !important}
  /* Mobile header bar — thin blue strip matching desktop topbar */
  .mobile-hdr{display:flex;align-items:center;gap:10px;padding:0 12px;height:36px;background:var(--pr);position:sticky;top:0;z-index:100;overflow:visible}
  .mobile-hdr::before{content:'';position:absolute;top:-16px;left:0;right:0;height:16px;background:var(--bg);z-index:-1}
  .mobile-hdr::after{content:'';position:absolute;bottom:-18px;left:0;right:0;height:18px;background:linear-gradient(to bottom,var(--bg),transparent);pointer-events:none;z-index:1}
  html[data-theme="dark"] .mobile-hdr::after{background:linear-gradient(to bottom,var(--bg),transparent)}
  .mobile-hdr{margin-top:16px}
  .mhdr-logo{flex-shrink:0;display:flex;align-items:center;position:relative;z-index:2;width:52px;height:36px}
  .mhdr-logo img{height:68px;width:auto;object-fit:contain;filter:drop-shadow(0 2px 8px rgba(0,0,0,.3));position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}
  .mhdr-info{flex:1;min-width:0;overflow:hidden;display:flex;align-items:center}
  .mhdr-title{font-size:.82rem;font-weight:700;color:#fff;display:flex;align-items:center;gap:5px}
  .mhdr-title i{font-size:.7rem;color:var(--ac)}
  .mhdr-ctx{display:none}
  .mhdr-right{display:flex;align-items:center;gap:6px;flex-shrink:0}
  .mhdr-btn{flex-shrink:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.2);border-radius:8px;background:none;color:rgba(255,255,255,.7);cursor:pointer;font-size:.75rem;transition:all .15s}
  .mhdr-btn:hover{color:#fff;border-color:rgba(255,255,255,.5)}
  html[data-theme="dark"] .mobile-hdr{background:#1e2128}
  /* Show bottom nav */
  .bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:120;background:var(--card);border-top:1px solid var(--bd);padding-bottom:max(10px, env(safe-area-inset-bottom, 10px));box-shadow:0 -2px 12px rgba(0,0,0,.08)}
  .bottom-nav .bnav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:10px 2px 4px;font-size:.62rem;font-weight:600;color:var(--mu);cursor:pointer;user-select:none;transition:color .15s;min-height:52px;box-sizing:border-box;text-decoration:none;border:none;background:none;font-family:inherit}
  .bottom-nav .bnav-item:hover{color:var(--tx)}
  .bottom-nav .bnav-item.active{color:#f37006}
  .bottom-nav .bnav-item+.bnav-item::before{content:'';position:absolute;left:0;top:25%;height:50%;width:1px;background:rgba(0,0,0,.1)}
  .bottom-nav .bnav-item{position:relative}
  html[data-theme="dark"] .bottom-nav .bnav-item+.bnav-item::before{background:rgba(255,255,255,.1)}
  .bottom-nav .bnav-item i{font-size:1.1rem}
  .bottom-nav .bnav-item span{line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
  html[data-theme="dark"] .bottom-nav{background:var(--card);border-top-color:var(--bd);box-shadow:0 -2px 12px rgba(0,0,0,.3)}
  html[data-theme="dark"] .bottom-nav .bnav-item.active{color:var(--ac)}
  /* ── Bottom gap: scroll container padding is the ONLY source of the gap ── */
  /* Bottom nav is ~62px; 80px padding gives a consistent ~18px visible gap */
  #main-content{padding-bottom:80px !important}
  .admin-body,.settings-body{padding-bottom:80px !important}
  /* Inner containers: flex-column + gap replaces margin-based spacing.           */
  /* This guarantees the gap after the LAST VISIBLE child is always 0px,          */
  /* because hidden (display:none) children don't participate in flex layout.     */
  /* :last-child selectors can't do this — they match hidden structural children. */
  .content,.tc.active,.itc.active,.atc.active,.settings-content,.admin-content{display:flex !important;flex-direction:column !important;gap:14px;padding-bottom:0 !important}
  .content>*,.tc.active>*,.itc.active>*,.atc.active>*,.settings-content>*,.admin-content>*{margin-top:0 !important;margin-bottom:0 !important;flex-shrink:0}
  /* Unified tab bar + card: cancel the 14px gap so .itabs merges with content below */
  .tc.active>.itabs~*,.itc.active>.itabs~*,.content>.itabs~*{margin-top:-14px !important}
  /* Toast: lift above bottom nav */
  #toast{bottom:72px}
  /* Version badge: lift above bottom nav */
  #ver-badge{bottom:72px}
  /* Chat sidebar tab: top aligned below header (dynamic — accounts for session bar), above bottom nav */
  #chat-sidebar-tab{top:calc(var(--header-h, 52px) + 22px);bottom:calc(62px + 22px)}
  /* Hide role badge on mobile — redundant with bottom nav */
  .rpill{display:none}
  /* Slim down Sign Out button */
  .lbtn{font-size:.72rem;padding:3px 8px}
  /* Action button row: sits normally at bottom of card (no sticky) */
  .mobile-sticky-action button,.mobile-sticky-action .blg{width:auto}
  .mobile-sticky-action .blg{padding:10px 16px;font-size:.82rem;border-radius:8px}
}

/* ── CAPACITOR SAFE AREA — Android status bar + bottom inset ─────────────── */
/* App banner: push below status bar so Refresh button is tappable */
html.capacitor-app #app-banner{padding-top:calc(var(--cap-inset,48px) + 10px)}
/* Chat sidebar tab: account for taller header (status bar spacer) and bottom nav inset */
html.capacitor-app #chat-sidebar-tab{top:calc(var(--header-h,166px) + var(--cap-inset,48px) + 22px);bottom:calc(62px + var(--cap-bottom,24px) + 22px)}
@media(max-width:600px){
  html.capacitor-app #chat-sidebar-tab{top:calc(var(--header-h, 52px) + var(--cap-inset,48px) + 22px);bottom:calc(62px + var(--cap-bottom,24px) + 22px)}
}
/* Form renderer panel: pad top so header isn't behind status bar, and paint a
   dark strip under the status bar area so the phone's white system icons stay
   readable against our light form background. Mirrors .app-header::before. */
@media(max-width:600px){
  html.capacitor-app .fr-panel{top:0;padding-top:var(--cap-inset,48px)}
  html.capacitor-app .fr-panel::before{content:'';position:absolute;top:0;left:0;right:0;height:var(--cap-inset,48px);background:#1a1a2e;z-index:1;pointer-events:none}
  html[data-theme="dark"].capacitor-app .fr-panel::before{background:#30333d}
}
/* Modal overlays: ensure content isn't hidden behind status bar */
html.capacitor-app .modal-overlay{padding-top:calc(var(--cap-inset,48px) + 16px)}

/* ══════════════════════════════════════════════════════════════════════════
   NOTIFICATION BELL + DROPDOWN + TEAM CHAT PANEL
   Desktop bell lives in .tabs; mobile bell lives in .bottom-nav. Same dropdown.
   ══════════════════════════════════════════════════════════════════════════ */

.notif-bell{position:relative;background:transparent;border:none;cursor:pointer;color:var(--mu);transition:color .15s,transform .15s,background .15s;padding:8px;border-radius:10px}
.notif-bell i{font-size:1.05rem}
.notif-bell:hover{color:var(--ac);background:rgba(0,0,0,.03)}
.notif-bell.flash{animation:notifFlash .6s ease-out}
@keyframes notifFlash{0%{transform:scale(1)}30%{transform:scale(1.25);color:var(--ac)}100%{transform:scale(1)}}
html[data-theme="dark"] .notif-bell:hover{background:rgba(255,255,255,.05)}

.notif-bell-top{display:none;order:999;margin-left:auto;align-self:center;padding:10px 14px}
.notif-bell-top i{font-size:1.1rem}
@media(min-width:601px){.notif-bell-top{display:inline-flex;align-items:center}}

/* Mobile bell uses the .bnav-item family styles (inherited from common.css bottom-nav
   block). These overrides strip the notif-bell's padding/border so the bnav-item layout
   wins and the button aligns with its siblings. */
.notif-bell-bottom{padding:0;border-radius:0;background:none}
.notif-bell-bottom:hover{background:none}
@media(min-width:601px){.notif-bell-bottom{display:none !important}}

.notif-pill{position:absolute;top:4px;right:14%;min-width:16px;height:16px;border-radius:8px;background:#e74c3c;color:#fff;font-size:.62rem;font-weight:800;display:flex;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 1px 3px rgba(0,0,0,.2);pointer-events:none;line-height:1}
.notif-pill.hidden{display:none}
.notif-bell-top .notif-pill{top:2px;right:2px}

/* Dropdown */
/* z-index sits BELOW .bottom-nav (120) so the mobile dropdown slides up from
   behind the tab bar and back down behind it — the tab bar stays visible on top.
   Still above .app-header (100) and #app-banner (101) for the desktop case. */
.notif-dropdown{position:fixed;z-index:119;background:var(--card);border:1px solid var(--bd);border-radius:12px;box-shadow:0 10px 40px rgba(0,0,0,.18);max-height:70vh;overflow:hidden;display:flex;flex-direction:column;opacity:0;transform:translateY(-10px);transition:opacity .22s ease,transform .28s cubic-bezier(.4,0,.2,1);pointer-events:none}
/* Mobile: full bottom-sheet slide-up like the forms modal. The calc() clears the
   bottom tab bar so the dropdown starts below the viewport, not at the tab bar. */
.notif-dropdown.from-bottom{transform:translateY(calc(100% + 80px));opacity:1;transition:transform .3s cubic-bezier(.4,0,.2,1)}
.notif-dropdown.open{opacity:1;transform:translateY(0);pointer-events:auto}
html[data-theme="dark"] .notif-dropdown{box-shadow:0 10px 40px rgba(0,0,0,.5)}
.notif-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--bd);font-size:.82rem;font-weight:700;color:var(--tx)}
.notif-clear{background:none;border:none;color:var(--mu);cursor:pointer;font-size:.72rem;font-weight:600}
.notif-clear:hover{color:var(--ac)}

.notif-chat-row{display:flex;align-items:center;gap:10px;padding:10px 14px;width:100%;border:none;border-bottom:1px solid var(--bd);background:rgba(231,110,48,.06);cursor:pointer;text-align:left;transition:background .15s}
.notif-chat-row:hover{background:rgba(231,110,48,.12)}
.notif-chat-row.disabled{cursor:default;background:transparent;opacity:.6}
.notif-chat-row.disabled:hover{background:transparent}
.notif-chat-row.has-unread{background:rgba(231,110,48,.14)}
.notif-chat-row i{font-size:1rem;color:var(--ac);flex-shrink:0}
.notif-chat-row-text{flex:1;min-width:0}
.notif-chat-row-title{font-size:.86rem;font-weight:700;color:var(--tx)}
.notif-chat-row-sub{font-size:.72rem;color:var(--mu);margin-top:2px}
.notif-mini-pill{min-width:20px;height:20px;border-radius:10px;background:#e74c3c;color:#fff;font-size:.68rem;font-weight:800;display:flex;align-items:center;justify-content:center;padding:0 6px;flex-shrink:0}

.notif-list{overflow-y:auto;flex:1;min-height:0}
.notif-empty{padding:28px 14px;text-align:center;font-size:.82rem;color:var(--mu)}
.notif-item{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;width:100%;border:none;border-bottom:1px solid var(--bd);background:transparent;cursor:pointer;text-align:left;transition:background .15s;position:relative}
.notif-item:hover{background:rgba(0,0,0,.03)}
html[data-theme="dark"] .notif-item:hover{background:rgba(255,255,255,.04)}
.notif-item:last-child{border-bottom:none}
.notif-item.unread{background:rgba(231,110,48,.04);font-weight:600}
.notif-item.unread::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--ac)}
.notif-item i{font-size:.92rem;color:var(--mu);flex-shrink:0;margin-top:2px;width:18px;text-align:center}
.notif-item.unread i{color:var(--ac)}
.notif-item-body{flex:1;min-width:0}
.notif-item-title{font-size:.82rem;color:var(--tx);line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.notif-item-sub{font-size:.72rem;color:var(--mu);margin-top:2px;line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.notif-item-time{font-size:.68rem;color:var(--mu);flex-shrink:0;align-self:flex-start;margin-top:2px}

/* Chat panel — slides DOWN from below the app header, same full-page feel as the form modal.
   top:var(--header-h) keeps the header + bell + tabs visible; translateY(-100%) parks it
   above the viewport when closed so opening looks like an expand from the tab bar. */
.chat-panel{position:fixed;top:var(--header-h,166px);right:0;bottom:0;width:50vw;max-width:640px;background:var(--card);border-left:1px solid var(--bd);box-shadow:-6px 0 24px rgba(0,0,0,.12),0 6px 24px rgba(0,0,0,.18);z-index:9600;display:flex;flex-direction:column;transform:translateY(calc(-100% - var(--header-h,166px)));transition:transform .3s cubic-bezier(.4,0,.2,1);will-change:transform}
.chat-panel.open{transform:translateY(0)}
html[data-theme="dark"] .chat-panel{box-shadow:-6px 0 24px rgba(0,0,0,.3),0 6px 24px rgba(0,0,0,.5)}
/* Mobile: full width, leave room for the bottom nav, same as the form modal */
@media(max-width:600px){
  .chat-panel{width:auto;left:0;max-width:none;border-left:none;box-shadow:0 6px 24px rgba(0,0,0,.18);bottom:calc(52px + max(10px, env(safe-area-inset-bottom, 10px)))}
}
html.capacitor-app .chat-panel{top:calc(var(--header-h,166px) + var(--cap-inset,48px))}

.chat-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--bd);font-size:.92rem;color:var(--tx)}
.chat-close{background:none;border:none;cursor:pointer;color:var(--mu);font-size:1.1rem;padding:6px;border-radius:6px}
.chat-close:hover{color:var(--tx);background:rgba(0,0,0,.06)}
html[data-theme="dark"] .chat-close:hover{background:rgba(255,255,255,.06)}

.chat-msgs{flex:1;min-height:0;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:10px}
.chat-loading,.chat-empty{text-align:center;color:var(--mu);font-size:.82rem;padding:20px 0}
.chat-msg{max-width:86%;align-self:flex-start;background:var(--bg);border:1px solid var(--bd);border-radius:14px;padding:8px 12px}
.chat-msg.mine{align-self:flex-end;background:rgba(231,110,48,.12);border-color:rgba(231,110,48,.2)}
.chat-msg-head{display:flex;gap:8px;align-items:baseline;margin-bottom:3px}
.chat-msg-name{font-size:.72rem;font-weight:700;color:var(--tx)}
.chat-msg.mine .chat-msg-name{color:var(--ac)}
.chat-msg-time{font-size:.66rem;color:var(--mu)}
.chat-msg-body{font-size:.86rem;color:var(--tx);white-space:pre-wrap;word-wrap:break-word;line-height:1.4}
.chat-msg-img{margin-top:6px}
.chat-msg-img img{max-width:min(100%,280px);max-height:280px;border-radius:8px;display:block;cursor:pointer;transition:filter .15s}
.chat-msg-img img:hover{filter:brightness(1.05)}

/* Full-screen image viewer for chat pictures. Sits above the app header (10001)
   so the close button and image edges aren't clipped by the nav. */
.chat-img-viewer{position:fixed;inset:0;background:rgba(0,0,0,.95);z-index:10050;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease;user-select:none}
.chat-img-viewer.open{opacity:1}
.chat-img-viewer img{max-width:92vw;max-height:88vh;object-fit:contain;border-radius:6px;box-shadow:0 4px 32px rgba(0,0,0,.5)}
.civ-close{position:absolute;top:18px;right:18px;width:44px;height:44px;border:none;border-radius:50%;background:rgba(255,255,255,.15);color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}
.civ-close:hover{background:rgba(255,255,255,.3)}
.chat-mention{background:rgba(231,110,48,.18);color:var(--ac);padding:1px 4px;border-radius:4px;font-weight:600}

.chat-input-row{display:flex;align-items:flex-end;gap:6px;padding:10px 12px;border-top:1px solid var(--bd);background:var(--card)}
.chat-image-btn{width:36px;height:36px;border-radius:8px;background:var(--bg);border:1px solid var(--bd);color:var(--mu);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}
.chat-image-btn:hover{border-color:var(--ac);color:var(--ac)}
.chat-input{flex:1;min-height:36px;max-height:120px;resize:none;border:1px solid var(--bd);border-radius:10px;padding:8px 12px;font-family:inherit;font-size:.86rem;background:var(--bg);color:var(--tx);line-height:1.4;outline:none}
.chat-input:focus{border-color:var(--ac)}
.chat-input:disabled{opacity:.6;cursor:not-allowed}
.chat-send{width:36px;height:36px;border-radius:8px;background:var(--ac);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.chat-send:disabled{opacity:.4;cursor:not-allowed}
.chat-send:hover:not(:disabled){filter:brightness(1.1)}

.chat-image-preview{position:relative;padding:8px 12px;border-top:1px solid var(--bd);background:var(--card)}
.chat-image-preview img{max-width:120px;max-height:120px;border-radius:6px;border:1px solid var(--bd);display:block}
.chat-image-remove{position:absolute;top:4px;right:4px;background:rgba(0,0,0,.6);color:#fff;border:none;width:22px;height:22px;border-radius:50%;cursor:pointer;font-size:.9rem;line-height:1}

.mention-suggest{position:fixed;z-index:9700;list-style:none;margin:0;padding:4px 0;background:var(--card);border:1px solid var(--bd);border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,.12);max-height:240px;overflow-y:auto;min-width:200px}
.mention-suggest li{padding:8px 12px;cursor:pointer;font-size:.82rem;color:var(--tx)}
.mention-suggest li:hover{background:rgba(0,0,0,.04)}
.mention-suggest li strong{font-weight:700}
.mention-suggest li span{color:var(--mu);font-size:.78rem}
html[data-theme="dark"] .mention-suggest li:hover{background:rgba(255,255,255,.06)}

/* ══════════════════════════════════════════════════════════════════════
   TUTORIAL OVERLAY + SPOTLIGHT + CARD (shared by all app tutorials)
   Wired by the engine in common.js. See osTutorial() there for usage.
   ══════════════════════════════════════════════════════════════════════ */
#os-tut-overlay{position:fixed;inset:0;z-index:10100;pointer-events:auto}
#os-tut-spotlight{position:fixed;background:transparent;border-radius:8px;box-shadow:0 0 0 9999px rgba(0,0,0,.55);transition:top .3s cubic-bezier(.4,0,.2,1),left .3s cubic-bezier(.4,0,.2,1),width .3s cubic-bezier(.4,0,.2,1),height .3s cubic-bezier(.4,0,.2,1);pointer-events:none}
/* When no target (or target off-screen): fill the viewport so background darkens uniformly */
#os-tut-spotlight.os-tut-no-target{top:-10px;left:-10px;width:1px;height:1px}
#os-tut-card{position:fixed;max-width:360px;width:calc(100vw - 32px);background:var(--card);border:1px solid var(--bd);border-radius:14px;box-shadow:0 10px 40px rgba(0,0,0,.3);padding:18px;z-index:10101;transition:top .3s cubic-bezier(.4,0,.2,1),left .3s cubic-bezier(.4,0,.2,1);font-size:.86rem}
html[data-theme="dark"] #os-tut-card{box-shadow:0 10px 40px rgba(0,0,0,.6)}
#os-tut-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
#os-tut-step-label{font-size:.7rem;color:var(--mu);font-weight:700;letter-spacing:.03em;text-transform:uppercase}
#os-tut-close{background:none;border:none;color:var(--mu);font-size:1.35rem;line-height:1;cursor:pointer;padding:0 4px;border-radius:4px;transition:color .15s}
#os-tut-close:hover{color:var(--tx)}
#os-tut-title{font-size:1.02rem;font-weight:700;color:var(--tx);margin:0 0 8px;line-height:1.3}
#os-tut-body{font-size:.86rem;color:var(--tx);line-height:1.5;max-height:40vh;overflow-y:auto}
#os-tut-body strong{color:var(--tx);font-weight:700}
#os-tut-body i.fa-solid,#os-tut-body i.fa-regular{color:var(--ac)}
#os-tut-footer{display:flex;align-items:center;justify-content:space-between;margin-top:14px;gap:8px}
#os-tut-dots{display:flex;gap:5px;flex:1;justify-content:center}
.os-tut-dot{width:7px;height:7px;border-radius:50%;background:var(--bd);transition:background .2s,transform .2s}
.os-tut-dot.active{background:var(--ac);transform:scale(1.3)}
#os-tut-prev,#os-tut-next{padding:7px 14px;font-size:.82rem}
#os-tut-prev[data-hidden="1"]{visibility:hidden}
@media(max-width:600px){
  #os-tut-card{max-width:calc(100vw - 20px);padding:14px;border-radius:12px}
  #os-tut-title{font-size:.95rem}
  #os-tut-body{font-size:.82rem;max-height:35vh}
  #os-tut-prev,#os-tut-next{padding:8px 12px;font-size:.78rem;min-height:36px}
}
