:root{
  /* Primary Blue & White Color Scheme */
  --color-blue-600:#2563eb;
  --color-blue-700:#1d4ed8;
  --color-blue-500:#3b82f6;
  --color-blue-400:#60a5fa;
  --color-blue-50:#eff6ff;
  --color-blue-100:#dbeafe;

  /* Grays for text and borders */
  --gray-900:#111827;
  --gray-800:#1f2937;
  --gray-700:#374151;
  --gray-600:#4b5563;
  --gray-500:#6b7280;
  --gray-400:#9ca3af;
  --gray-300:#d1d5db;
  --gray-200:#e5e7eb;
  --gray-100:#f3f4f6;
  --gray-50:#f9fafb;

  /* Semantic colors */
  --gold:#f59e0b;--gold2:#fbbf24;--red:#dc2626;--orange:#ea580c;--green:#059669;--purple:#7c3aed;--slate:#6b7280;

  /* Legacy support */
  --pb0:var(--gray-900);--pb1:var(--gray-800);--pb2:var(--gray-700);--pb3:var(--gray-600);--pb4:var(--gray-500);--pb5:var(--gray-400);
  --primary:var(--color-blue-600);--primary-dark:var(--color-blue-700);--primary-light:var(--color-blue-500);

  /* Gradients with blue */
  --gh:linear-gradient(135deg,var(--color-blue-700) 0%,var(--color-blue-600) 50%,var(--color-blue-500) 100%);
  --ghead:linear-gradient(90deg,var(--color-blue-700) 0%,var(--color-blue-600) 100%);
  --ggold:linear-gradient(135deg,#f59e0b,#fbbf24);
  --ggreen:linear-gradient(135deg,#059669,#10b981);
  --gred:linear-gradient(135deg,#dc2626,#ea580c);
  --gpurple:linear-gradient(135deg,#7c3aed,#8b5cf6);

  /* Shadows */
  --s1:0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06);--s2:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);--s3:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05);

  /* Fonts & Sizes */
  --fd:'DM Serif Display',Georgia,serif;--fb:'DM Sans',system-ui,sans-serif;--fm:'JetBrains Mono',monospace;
  --r:6px;--rm:10px;--rl:16px;--uf:var(--fb);--us:13px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--uf);font-size:var(--us);background:white;color:var(--gray-900);min-height:100vh;overflow-x:hidden}

/* HEADER */
.ah{background:white;padding:0 24px;height:64px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:200;box-shadow:0 1px 3px rgba(0,0,0,.1);border-bottom:1px solid var(--gray-200)}
.alo{display:flex;align-items:center;gap:16px}
.alm{display:flex;align-items:center;justify-content:center;flex-shrink:0}
.alt{font-family:var(--fd);font-size:17px;color:var(--gray-900);letter-spacing:.02em;line-height:1.2;font-weight:600}
.als{font-size:10px;font-weight:500;color:var(--color-blue-600);letter-spacing:.12em;text-transform:uppercase}
.hn{display:flex;gap:6px}
.nt{padding:8px 18px;border-radius:8px;border:1px solid transparent;background:transparent;color:var(--gray-600);font-family:var(--fb);font-size:13px;font-weight:500;cursor:pointer;transition:all .18s;letter-spacing:.01em}
.nt:hover{background:var(--color-blue-50);color:var(--color-blue-600)}
.nt.active{background:var(--color-blue-600);border-color:var(--color-blue-600);color:white;box-shadow:0 2px 4px rgba(37,99,235,.2)}
.ht{display:flex;align-items:center;gap:8px}
.hs{background:white;border:1px solid var(--gray-300);border-radius:6px;color:var(--gray-900);font-family:var(--fb);font-size:11.5px;padding:5px 8px;cursor:pointer;outline:none}
.hs option{background:white}
.bs{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;border:1px solid var(--gray-300);background:white;color:var(--gray-700);font-family:var(--fb);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}
.bs:hover{background:var(--gray-50);border-color:var(--gray-400)}
.bs.gd{background:var(--color-blue-600);border-color:var(--color-blue-600);color:white;box-shadow:0 2px 4px rgba(37,99,235,.2)}
.bs.gd:hover{background:var(--color-blue-700);transform:translateY(-1px);box-shadow:0 4px 8px rgba(37,99,235,.25)}

/* VIEWS */
.vw{display:none!important}.vw.active{display:flex!important;flex-direction:column;width:100%;height:calc(100vh - 64px);position:relative}

/* SPLIT */
.sl{display:flex;height:calc(100vh - 64px);overflow:hidden}
.lp{width:440px;flex-shrink:0;background:white;border-right:1px solid var(--gray-200);overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column}
.lp::-webkit-scrollbar{width:4px}.lp::-webkit-scrollbar-thumb{background:var(--color-blue-600);border-radius:2px}
.ph{background:var(--gh);padding:16px 20px 14px;flex-shrink:0}
.pt{font-family:var(--fd);font-size:17px;color:#fff;margin-bottom:3px}
.ps{font-size:11px;color:rgba(148,210,189,.8);letter-spacing:.08em;text-transform:uppercase}
.fb{padding:18px 20px;flex:1}
.fs{margin-bottom:20px;border:1px solid var(--gray-200);border-radius:var(--rm);overflow:hidden}
.fsh{background:var(--color-blue-50);padding:8px 14px;font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--color-blue-600);border-bottom:1px solid var(--gray-200)}
.fsb{padding:14px;display:flex;flex-direction:column;gap:10px}
.fr{display:flex;gap:10px}.fr .fw{flex:1}
.fw{display:flex;flex-direction:column;gap:4px}
.fl{font-size:10px;font-weight:600;color:var(--color-blue-600);letter-spacing:.08em;text-transform:uppercase}
.fi,.fse,.fta{width:100%;background:white;border:1.5px solid var(--gray-300);border-radius:var(--r);padding:8px 10px;font-family:var(--uf);font-size:12.5px;color:var(--gray-900);outline:none;transition:all .16s}
.fi:focus,.fse:focus,.fta:focus{border-color:var(--color-blue-600);background:white;box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.fta{resize:vertical;line-height:1.55}.fse{cursor:pointer}

/* AP CARD */
.apc{background:white;border:1.5px solid var(--gray-200);border-radius:var(--rm);padding:12px 14px;position:relative;animation:si .2s ease}
@keyframes si{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.apn{position:absolute;top:-10px;left:12px;width:20px;height:20px;background:var(--gh);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:#fff;font-family:var(--fm)}
.apg{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px}
/* Finance follow-up tabs */
.fu-tab-bar{display:flex;gap:4px;flex-wrap:wrap;padding:10px 14px 0;border-bottom:2px solid var(--gray-200);background:var(--gray-50)}
.fu-tab{padding:5px 12px;border-radius:6px 6px 0 0;border:1.5px solid transparent;font-size:11.5px;font-weight:500;color:var(--gray-600);cursor:pointer;transition:all .15s;background:transparent;font-family:var(--fb);white-space:nowrap}
.fu-tab.active{background:white;border-color:var(--gray-300);border-bottom-color:white;color:var(--color-blue-600);font-weight:600;margin-bottom:-2px}
.fu-tab:hover:not(.active){background:white;color:var(--color-blue-600)}
.fu-tab-pane{display:none}.fu-tab-pane.active{display:block}
.fu-entry{display:flex;gap:8px;align-items:flex-start;padding:8px 0;border-bottom:1px solid #f0f6f8}
.fu-dot{width:8px;height:8px;border-radius:50%;background:var(--pb4);flex-shrink:0;margin-top:4px}
.fu-date-badge{font-size:9px;font-weight:700;color:var(--pb3);font-family:var(--fm);background:#e0f4f7;padding:2px 7px;border-radius:10px;flex-shrink:0;white-space:nowrap;margin-top:2px}
.apf{grid-column:1/-1}
.apb{display:flex;gap:8px;align-items:center;margin-top:8px;padding-top:8px;border-top:1px solid var(--gray-200)}
.apb .fw{flex:1}
.ct{display:flex;align-items:center;gap:6px;cursor:pointer;user-select:none}
.tt{width:36px;height:20px;background:var(--gray-300);border-radius:10px;position:relative;transition:background .2s;flex-shrink:0}
.tt.on{background:var(--green)}
.th{position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 4px rgba(0,0,0,.2)}
.tt.on .th{transform:translateX(16px)}
.tl{font-size:10.5px;font-weight:500;color:var(--gray-600)}
.bra{position:absolute;top:8px;right:8px;width:22px;height:22px;background:rgba(224,54,54,.1);border:1px solid rgba(224,54,54,.2);border-radius:4px;color:var(--red);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .15s}
.bra:hover{background:rgba(224,54,54,.2)}
.baa{display:flex;align-items:center;gap:7px;width:100%;padding:9px 14px;background:white;border:1.5px dashed var(--color-blue-600);border-radius:var(--rm);color:var(--color-blue-600);font-family:var(--fb);font-size:12.5px;font-weight:500;cursor:pointer;transition:all .16s}
.baa:hover{background:var(--color-blue-50);border-color:var(--color-blue-700)}
.bsm{width:100%;padding:10px 18px;background:var(--color-blue-600);border:none;border-radius:8px;color:white;font-family:var(--fb);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;letter-spacing:.01em;box-shadow:0 1px 3px rgba(37,99,235,.15)}
.bsm:hover{background:var(--color-blue-700);transform:translateY(-1px);box-shadow:0 2px 6px rgba(37,99,235,.25)}
.asb{display:flex;align-items:center;gap:8px;padding:8px 20px;background:white;border-top:1px solid var(--gray-200);font-size:11px;color:var(--gray-600);flex-shrink:0}
.asd{width:7px;height:7px;border-radius:50%;background:#94a3b8;transition:background .3s;flex-shrink:0}
.asd.saved{background:var(--green)}.asd.saving{background:var(--gold);animation:pu .8s infinite}
@keyframes pu{0%,100%{opacity:1}50%{opacity:.4}}

/* PREVIEW */
.rp{flex:1;background:var(--gray-50);overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;align-items:center}
.rp::-webkit-scrollbar{width:5px}.rp::-webkit-scrollbar-thumb{background:var(--color-blue-600);border-radius:3px}
.pvt{position:sticky;top:0;z-index:50;width:100%;background:white;backdrop-filter:blur(12px);padding:10px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--gray-200)}
.pvl{font-size:11px;font-weight:600;color:var(--gray-600);letter-spacing:.1em;text-transform:uppercase}
.bpr{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--color-blue-600);border:none;border-radius:8px;color:white;font-family:var(--fb);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;box-shadow:0 2px 4px rgba(37,99,235,.2)}
.bpr:hover{background:var(--color-blue-700);transform:translateY(-1px);box-shadow:0 4px 8px rgba(37,99,235,.25)}
.pva{padding:20px 20px 40px;width:100%}

/* A4 DOC */
.a4{width:794px;max-width:100%;margin:0 auto;background:#fff;box-shadow:0 8px 40px rgba(0,30,50,.2);border-radius:3px;overflow:hidden;position:relative}
.a4::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:var(--gh)}
.db{padding:32px 38px 36px}
.dh{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;padding-bottom:10px;border-bottom:2px solid var(--gray-200)}
.don{font-size:9.5px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--color-blue-600);margin-bottom:4px}
.dtit{font-family:var(--fd);font-size:22px;color:var(--gray-900);line-height:1.2}
.dm{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:3px}
.ddb{background:var(--color-blue-50);border:1px solid var(--color-blue-600);border-radius:5px;padding:4px 10px;font-size:11px;font-weight:600;color:var(--color-blue-600)}
.dml{font-size:10.5px;color:var(--gray-600)}
.dgl{height:1px;background:linear-gradient(90deg,var(--gold),var(--gold2),transparent);margin-bottom:14px}
.dcw{column-count:1;column-gap:18px}
.dcw.c2{column-count:2;column-gap:16px}.dcw.c3{column-count:3;column-gap:12px}
.mg{break-inside:avoid;page-break-inside:avoid;margin-bottom:8px;display:inline-block;width:100%}
.ar{display:flex;align-items:flex-start;gap:8px;padding:4px 0;border-bottom:1px solid #f0f4f6}
.ar:last-child{border-bottom:none}
.atb{flex-shrink:0;font-size:8px;font-weight:700;padding:2px 5px;border-radius:3px;letter-spacing:.04em;white-space:nowrap}
.atb.im{background:rgba(244,114,43,.12);color:#c05018;border:1px solid rgba(244,114,43,.25)}
.atb.lt{background:rgba(124,92,191,.1);color:#5a3fa0;border:1px solid rgba(124,92,191,.2)}
.at{flex:1;font-size:11px;color:var(--gray-900);line-height:1.45}
.aps{flex-shrink:0;display:flex;flex-direction:column;gap:2px;align-items:flex-end}
.ap{font-size:8px;font-weight:600;padding:1px 5px;border-radius:10px;white-space:nowrap}
.ap.pc{background:rgba(224,54,54,.12);color:#b91c1c}
.ap.ph{background:rgba(244,114,43,.12);color:#b94a10}
.ap.pm{background:rgba(201,168,76,.15);color:#8b6914}
.ap.pl{background:rgba(26,158,92,.1);color:#127548}
.ap.so{background:rgba(10,147,150,.1);color:var(--pb2)}
.ap.si{background:rgba(124,92,191,.12);color:#5a3fa0}
.ap.sd{background:rgba(26,158,92,.1);color:#127548}
.ap.sr{background:rgba(224,54,54,.12);color:#b91c1c}
.ap.dn{background:rgba(26,158,92,.1);color:#127548}
.aa{font-size:9px;color:var(--gray-600);margin-top:1px;font-style:italic}
.dfl{margin-top:20px;padding-top:8px;border-top:1px solid var(--gray-200);display:flex;justify-content:space-between;font-size:9px;color:var(--gray-600)}
.de{padding:60px 40px;text-align:center}
.dei{font-size:48px;margin-bottom:12px}
.det{font-family:var(--fd);font-size:18px;color:var(--pb5);font-style:italic}

/* SEARCH */
#vs{padding:72px 32px 48px;gap:20px;height:100%;overflow-y:auto;position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;box-sizing:border-box}
.sbi{flex:1;background:white;border:1.5px solid var(--gray-300);border-radius:8px;padding:12px 16px;font-family:var(--fb);font-size:14px;color:var(--gray-900);outline:none;transition:all .16s;box-shadow:var(--s1)}
.sbi:focus{border-color:var(--color-blue-600);background:white;box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.fcp{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;padding-bottom:8px;border-bottom:1px solid var(--gray-200)}
.fc{padding:5px 12px;border-radius:20px;border:1.5px solid var(--gray-300);background:white;font-size:11.5px;font-weight:500;color:var(--gray-600);cursor:pointer;transition:all .14s}
.fc:hover{border-color:var(--color-blue-600);color:var(--color-blue-600)}.fc.active{background:var(--color-blue-600);border-color:var(--color-blue-600);color:white}
.src{display:flex;flex-direction:column;gap:12px;margin-top:20px}
.src-c{background:white;border:1px solid var(--gray-200);border-radius:var(--rm);padding:14px 18px;box-shadow:var(--s1);cursor:pointer;transition:all .15s;border-left:4px solid var(--color-blue-600)}
.src-c:hover{box-shadow:var(--s2);transform:translateX(2px)}

/* SUMMARY */
#vsum{padding:72px 32px 48px;gap:28px;height:100%;overflow-y:auto;position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;box-sizing:border-box}
.sg{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:24px;align-items:start}
.mc{background:white;border:1px solid var(--gray-200);border-radius:12px;overflow:visible;box-shadow:var(--s1);cursor:pointer;transition:all .18s;display:flex;flex-direction:column}
.mc:hover{box-shadow:var(--s2);transform:translateY(-2px)}
.mch{background:var(--color-blue-600);padding:16px 18px;flex-shrink:0}
.mct{font-family:var(--fd);font-size:16px;color:white;margin-bottom:4px;font-weight:600;line-height:1.3}
.mcm{display:flex;gap:10px;font-size:11px;color:rgba(255,255,255,.85);font-weight:500;flex-wrap:wrap}
.mcb{padding:16px 18px;flex:1;display:flex;flex-direction:column;gap:12px}
.mcs{display:flex;gap:12px}
.mcst{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;padding:12px 10px;background:var(--gray-50);border-radius:8px;border:1px solid var(--gray-200);min-height:70px}
.mcsn{font-family:var(--fd);font-size:24px;color:var(--color-blue-600);font-weight:700;margin-bottom:4px;line-height:1}
.mcsl{font-size:10px;font-weight:600;color:var(--gray-600);text-transform:uppercase;letter-spacing:.08em;text-align:center}
.mcp{font-size:12px;color:var(--gray-700);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}
.mcf{padding:12px 18px;border-top:1px solid var(--gray-200);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;margin-top:auto}
.mci{font-size:11px;color:var(--gray-600);font-family:var(--fm);font-weight:500}
.bi{width:28px;height:28px;background:white;border:1px solid var(--gray-300);border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:13px;transition:all .14s}
.bi:hover{background:var(--gray-50);border-color:var(--gray-400)}

/* ANALYTICS */
#va{padding:0;gap:0;height:100%;overflow-y:auto;display:flex;flex-direction:column;background:var(--gray-50);position:absolute;top:0;left:0;right:0;bottom:0}
#va::-webkit-scrollbar{width:5px}#va::-webkit-scrollbar-thumb{background:var(--color-blue-600);border-radius:3px}
.kpr{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.kpc{background:white;border:1px solid var(--gray-200);border-radius:12px;padding:20px;box-shadow:var(--s1);position:relative;overflow:hidden;cursor:pointer;transition:all .15s}
.kpc:hover{box-shadow:var(--s2);transform:translateY(-2px)}
.kpc::before{content:'';position:absolute;top:0;left:0;right:0;height:0}
.kpc.t::before{background:var(--gh)}.kpc.go::before{background:var(--ggold)}
.kpc.gr::before{background:var(--ggreen)}.kpc.rd::before{background:var(--gred)}.kpc.pu::before{background:var(--gpurple)}
.kpi{font-size:32px;margin-bottom:12px;filter:grayscale(0.3)}
.kpv{font-family:var(--fd);font-size:36px;color:var(--color-blue-600);line-height:1;margin-bottom:8px;font-weight:700}
.kpl{font-size:13px;color:var(--gray-600);font-weight:500}
.kpt{position:absolute;top:16px;right:16px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:12px}
.kpt.up{background:rgba(26,158,92,.1);color:var(--green)}.kpt.dn{background:rgba(224,54,54,.1);color:var(--red)}
.ag{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.ag.w{grid-template-columns:2fr 1fr}.ag.f{grid-template-columns:1fr}
.cc{background:white;border:1px solid var(--gray-200);border-radius:12px;padding:20px;box-shadow:var(--s1)}
.cct{font-size:12px;font-weight:700;color:var(--color-blue-600);letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px}
.ccs{font-size:13px;color:var(--gray-600);margin-bottom:16px;font-weight:400}
.cw{position:relative;height:175px}.cw.tl{height:230px}
.al{display:flex;flex-direction:column;gap:7px;max-height:240px;overflow-y:auto}
.ai{display:flex;align-items:flex-start;gap:9px;padding:7px 11px;border-radius:var(--r);border:1px solid transparent;cursor:pointer;transition:all .14s}
.ai:hover{transform:translateX(2px)}
.ai.ov{background:rgba(224,54,54,.06);border-color:rgba(224,54,54,.2)}
.ai.up{background:rgba(201,168,76,.08);border-color:rgba(201,168,76,.25)}
.aico{font-size:13px;flex-shrink:0;margin-top:1px}
.ait{font-size:11px;color:var(--gray-900);line-height:1.5;flex:1}
.ait strong{color:var(--gray-900)}
.aib{font-size:9.5px;font-weight:600;padding:2px 7px;border-radius:10px;flex-shrink:0}
.aib.ov{background:rgba(224,54,54,.12);color:var(--red)}.aib.up{background:rgba(201,168,76,.15);color:#8b6914}
.wt{width:100%;border-collapse:collapse}
.wt th{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--gray-600);padding:6px 10px;border-bottom:2px solid var(--gray-200);text-align:left}
.wt td{font-size:12px;color:var(--gray-900);padding:6px 10px;border-bottom:1px solid var(--gray-100)}
.wt tr:last-child td{border-bottom:none}.wt tr:hover td{background:var(--color-blue-50)}
.wb{width:70px;height:5px;background:var(--gray-200);border-radius:3px;overflow:hidden}
.wbf{height:100%;background:var(--gh);border-radius:3px;transition:width .5s}
.ct2{width:100%;border-collapse:collapse}
.ct2 th{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--gray-600);padding:6px 10px;border-bottom:2px solid var(--gray-200);text-align:center}
.ct2 th:first-child{text-align:left}
.ct2 td{font-size:11px;color:var(--gray-900);padding:6px 10px;border-bottom:1px solid var(--gray-100);text-align:center}
.ct2 td:first-child{text-align:left;font-weight:500}
.ct2 tr:hover td{background:var(--color-blue-50)}
.rp2{display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;padding:2px 7px;border-radius:10px}

/* DRILL */
.dro{position:fixed;inset:0;background:rgba(0,20,30,.55);backdrop-filter:blur(6px);z-index:900;display:none;align-items:center;justify-content:center}
.dro.show{display:flex}
.drm{background:#fff;border-radius:var(--rl);padding:24px;width:580px;max-width:92vw;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,20,30,.4)}
.drt{font-family:var(--fd);font-size:18px;color:var(--gray-900);margin-bottom:3px}
.drs{font-size:12px;color:var(--gray-600);margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--gray-200)}
.drc{float:right;background:none;border:none;font-size:20px;cursor:pointer;color:var(--gray-600);line-height:1}
.dri{display:flex;flex-direction:column;gap:7px}
.dric{background:white;border:1px solid var(--gray-200);border-radius:var(--r);padding:9px 13px}
.drit{font-weight:600;font-size:12px;color:var(--gray-900);margin-bottom:3px}
.drim{font-size:11px;color:var(--gray-600)}

/* TOAST */
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(60px);background:rgba(0,20,30,.95);border:1px solid rgba(148,210,189,.35);border-radius:10px;padding:10px 20px;color:#fff;font-size:13px;font-weight:500;backdrop-filter:blur(12px);z-index:9999;transition:transform .3s cubic-bezier(.34,1.56,.64,1);pointer-events:none;white-space:nowrap}
.toast.show{transform:translateX(-50%) translateY(0)}

/* Import mode tabs */
.imp-mode-btn{flex:1;padding:11px 8px;border:none;border-bottom:2px solid transparent;background:transparent;font-family:var(--fb);font-size:12px;font-weight:600;color:var(--gray-600);cursor:pointer;transition:all .18s;line-height:1.4;display:flex;flex-direction:column;align-items:center;gap:3px}
.imp-mode-btn:hover{background:var(--gray-50);color:var(--color-blue-600)}
.imp-mode-btn.active{color:var(--color-blue-600);border-bottom-color:var(--color-blue-600);background:white}
/* PRINT */
@media print{
  @page{size:A4 portrait;margin:10mm 12mm}
  body{background:none!important}
  .ah,.lp,.pvt,#vs,#va,#vsum{display:none!important}
  .sl{display:block!important;height:auto!important}
  .rp{background:none!important;display:block!important;overflow:visible!important;padding:0!important}
  .pva{padding:0!important}
  .a4{box-shadow:none!important;border-radius:0!important;width:100%!important}
  .a4::before{display:none!important}
  .db{padding:0!important}
  .dcw.c2{column-count:2;column-gap:8mm}
  .dcw.c3{column-count:3;column-gap:6mm}
  .mg{break-inside:avoid}
}
@media(max-width:900px){
  .sl{flex-direction:column;height:auto}.lp{width:100%;max-height:55vh}
  .kpr{grid-template-columns:repeat(2,1fr)}.ag{grid-template-columns:1fr}.ag.w{grid-template-columns:1fr}
}
/* GROUP VIEW BUTTONS */
.grp-btn{padding:7px 14px;border-radius:20px;border:1.5px solid var(--gray-300);background:white;font-family:var(--fb);font-size:11.5px;font-weight:500;color:var(--gray-600);cursor:pointer;transition:all .15s;white-space:nowrap}
.grp-btn:hover{border-color:var(--color-blue-600);color:var(--color-blue-600);background:var(--color-blue-50)}
.grp-btn.active{background:var(--color-blue-600);border-color:transparent;color:white;box-shadow:0 2px 8px rgba(37,99,235,.25)}

/* PROFILE DROPDOWN */
.profile-wrapper{position:relative}
.profile-btn{width:40px;height:40px;border-radius:50%;background:var(--color-blue-50);border:2px solid var(--color-blue-600);color:var(--color-blue-600);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;padding:0}
.profile-btn:hover{background:var(--color-blue-600);color:white;transform:scale(1.05)}
.profile-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:white;border:1px solid var(--gray-200);border-radius:12px;box-shadow:0 10px 40px rgba(0,0,0,.15);min-width:280px;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .2s;z-index:1000}
.profile-dropdown.show{opacity:1;visibility:visible;transform:translateY(0)}
.profile-header{padding:16px;display:flex;gap:12px;align-items:center;border-bottom:1px solid var(--gray-200)}
.profile-avatar{width:48px;height:48px;border-radius:50%;background:var(--color-blue-50);border:2px solid var(--color-blue-600);color:var(--color-blue-600);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.profile-info{flex:1;min-width:0}
.profile-name{font-size:14px;font-weight:600;color:var(--gray-900);margin-bottom:2px;font-family:var(--fb)}
.profile-email{font-size:11px;color:var(--gray-600);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.profile-divider{height:1px;background:var(--gray-200);margin:8px 0}
.profile-item{display:flex;align-items:center;gap:10px;padding:10px 16px;color:var(--gray-700);font-size:13px;font-family:var(--fb);font-weight:500;text-decoration:none;transition:all .15s;cursor:pointer}
.profile-item:hover{background:var(--color-blue-50);color:var(--color-blue-600)}
.profile-item svg{flex-shrink:0}
.profile-logout{color:var(--red)}
.profile-logout:hover{background:rgba(220,38,38,.05);color:var(--red)}

/* LOGIN PAGE */
#vlogin{padding:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-blue-50) 0%,white 100%);position:fixed;inset:0;z-index:1000}
.login-container{width:100%;max-width:420px;padding:20px}
.login-card{background:white;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.1);overflow:hidden}
.login-header{background:var(--gh);padding:32px 28px;text-align:center}
.login-logo{width:80px;height:80px;margin:0 auto 16px;background:white;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(0,0,0,.1)}
.login-logo img{width:60px;height:60px;object-fit:contain}
.login-title{font-family:var(--fd);font-size:22px;color:white;margin-bottom:4px;font-weight:600}
.login-subtitle{font-size:12px;color:rgba(255,255,255,.85);letter-spacing:.08em;text-transform:uppercase}
.login-body{padding:32px 28px}
.login-form{display:flex;flex-direction:column;gap:20px}
.login-field{display:flex;flex-direction:column;gap:6px}
.login-label{font-size:11px;font-weight:600;color:var(--color-blue-600);letter-spacing:.08em;text-transform:uppercase;font-family:var(--fb)}
.login-input{width:100%;background:white;border:1.5px solid var(--gray-300);border-radius:8px;padding:12px 14px;font-family:var(--fb);font-size:13px;color:var(--gray-900);outline:none;transition:all .16s}
.login-input:focus{border-color:var(--color-blue-600);background:white;box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.login-checkbox{display:flex;align-items:center;gap:8px;cursor:pointer;user-select:none}
.login-checkbox input{width:16px;height:16px;cursor:pointer}
.login-checkbox label{font-size:12px;color:var(--gray-700);cursor:pointer;font-family:var(--fb)}
.login-btn{width:100%;padding:14px 20px;background:var(--color-blue-600);border:none;border-radius:8px;color:white;font-family:var(--fb);font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;letter-spacing:.01em;box-shadow:0 2px 6px rgba(37,99,235,.2)}
.login-btn:hover{background:var(--color-blue-700);transform:translateY(-1px);box-shadow:0 4px 12px rgba(37,99,235,.3)}
.login-footer{padding:20px 28px;background:var(--gray-50);border-top:1px solid var(--gray-200);text-align:center}
.login-footer-text{font-size:11px;color:var(--gray-600);font-family:var(--fb)}
.login-error{background:rgba(220,38,38,.05);border:1px solid rgba(220,38,38,.2);border-radius:8px;padding:12px 14px;color:var(--red);font-size:12px;font-family:var(--fb);display:none}
.login-error.show{display:block}
