/* ============================================================
   ARCHIVUM SALEJKO — Dark Luxury Theme
   Navy #0e1421 + Gold #c9a84c
   ============================================================ */
:root {
  --navy:        #0e1421;
  --navy-2:      #131c2e;
  --navy-3:      #1a2535;
  --navy-4:      #1f2f45;
  --navy-5:      #2a3a50;
  --gold:        #c9a84c;
  --gold-2:      #e0c060;
  --gold-light:  #f5e6b0;
  --gold-bg:     rgba(201,168,76,.08);
  --teal:        #2dd4bf;
  --teal-bg:     rgba(45,212,191,.08);
  --text:        #e2e8f0;
  --text-2:      #b8ccd8;
  --muted:       #8fa3b1;
  --muted-2:     #5c7a8a;
  --border:      #2a3a50;
  --border-2:    #1f2f45;
  --red:         #f87171;
  --red-bg:      rgba(248,113,113,.1);
  --green:       #34d399;
  --green-bg:    rgba(52,211,153,.1);
  --amber:       #fbbf24;
  --amber-bg:    rgba(251,191,36,.1);
  --shadow:      0 4px 12px rgba(0,0,0,.4);
  --shadow-lg:   0 12px 32px rgba(0,0,0,.5);
  --radius-sm:   6px;
  --radius:      10px;
  --radius-lg:   14px;
  --sidebar-w:   256px;
  --topnav-h:    56px;
  --font:        'Inter', system-ui, sans-serif;
}

/* ── Reset ───────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:14px;scroll-behavior:smooth}
body{font-family:var(--font);background:var(--navy);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;line-height:1.5}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button,input,select,textarea{font:inherit}
svg{width:1rem;height:1rem;display:block;flex:none}

/* ── App Wrapper ─────────────────────────────────────────────── */
.app-wrapper{display:flex;min-height:100vh}
.page-right{flex:1;display:flex;flex-direction:column;min-width:0}

/* ── Sidebar ─────────────────────────────────────────────────── */
.sidebar{
  width:var(--sidebar-w);background:var(--navy-2);
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;
  position:sticky;top:0;height:100vh;
  overflow-y:auto;overflow-x:hidden;
  flex-shrink:0;z-index:200;transition:width .25s;
}
.sidebar--collapsed{width:58px}
.sidebar--collapsed .sb-user-info,
.sidebar--collapsed .sb-brand span,
.sidebar--collapsed .sb-section,
.sidebar--collapsed .sb-item span,
.sidebar--collapsed .sb-badge,
.sidebar--collapsed .sb-logout span{display:none}
.sidebar--collapsed .sb-item{justify-content:center;padding:10px}

/* User top */
.sb-user-top{display:flex;align-items:center;gap:10px;padding:18px 14px 14px;border-bottom:1px solid var(--border)}
.sb-avatar{
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),#e0b84a);
  color:var(--navy);display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:.85rem;flex-shrink:0;
}
.sb-user-info{min-width:0}
.sb-user-name{font-weight:600;font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-user-role{font-size:.72rem;color:var(--gold);text-transform:uppercase;letter-spacing:.08em;margin-top:1px}

/* Brand */
.sb-brand{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;border-bottom:1px solid var(--border);
}
.sb-logo{height:28px;width:auto;object-fit:contain;object-position:left;filter:brightness(1.1)}
.sb-brand span{font-weight:700;font-size:.88rem;color:var(--text-2);white-space:nowrap}

/* Nav */
.sb-nav{flex:1;padding:6px 0;overflow-y:auto}
.sb-section{padding:10px 14px 3px;font-size:.67rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2)}
.sb-item{
  display:flex;align-items:center;gap:9px;padding:9px 14px;
  color:var(--text-2);font-size:.86rem;font-weight:500;
  transition:.15s;position:relative;
}
.sb-item svg{width:.95rem;height:.95rem;flex-shrink:0;color:var(--muted)}
.sb-item:hover{background:var(--navy-3);color:var(--text)}
.sb-item:hover svg{color:var(--gold)}
.sb-item--active{color:var(--gold);background:var(--gold-bg);font-weight:600}
.sb-item--active svg{color:var(--gold)}
.sb-item--active::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--gold)}
.sb-badge{
  margin-left:auto;min-width:20px;text-align:center;
  padding:2px 7px;border-radius:999px;
  background:var(--gold);color:var(--navy);
  font-size:.68rem;font-weight:800;flex-shrink:0;
}

/* Bottom logout */
.sb-bottom{padding:10px 8px;border-top:1px solid var(--border);margin-top:auto}
.sb-logout{
  display:flex;align-items:center;gap:9px;width:100%;
  padding:9px 8px;background:none;border:none;cursor:pointer;
  color:var(--muted);font-size:.86rem;font-weight:500;
  border-radius:var(--radius-sm);transition:.15s;
}
.sb-logout:hover{background:var(--red-bg);color:var(--red)}

/* ── Top Nav ─────────────────────────────────────────────────── */
.topnav{
  height:var(--topnav-h);background:var(--navy-3);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;padding:0 20px;gap:12px;
  flex-shrink:0;position:sticky;top:0;z-index:100;
}
.topnav-toggle{
  background:var(--navy-4);border:1px solid var(--border);
  width:34px;height:34px;border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--muted);transition:.15s;flex-shrink:0;
}
.topnav-toggle:hover{background:var(--navy-5);color:var(--text)}
.topnav-right{display:flex;align-items:center;gap:10px;margin-left:auto}
.topnav-avatar{
  width:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),#e0b84a);
  color:var(--navy);display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:.78rem;
}

/* ── Page Content ────────────────────────────────────────────── */
.page-content{flex:1;padding:22px;display:flex;flex-direction:column;gap:18px;min-width:0}

/* ── Page Header ─────────────────────────────────────────────── */
.topbar,.page-header{
  display:flex;justify-content:space-between;align-items:flex-start;
  gap:16px;flex-wrap:wrap;padding-bottom:16px;
  border-bottom:1px solid var(--border);margin-bottom:2px;
}
.topbar-kicker,.page-kicker{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:var(--gold);margin-bottom:4px}
.topbar-title,.page-title{font-size:1.45rem;font-weight:700;letter-spacing:-.02em;line-height:1.2;color:var(--text)}
.topbar-sub,.page-sub{margin-top:4px;color:var(--muted);font-size:.86rem}
.topbar-actions,.page-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center;flex-shrink:0}

/* ── Cards ───────────────────────────────────────────────────── */
.card,.glass-card{
  background:var(--navy-3);border:1px solid var(--border);
  border-radius:var(--radius-lg);box-shadow:var(--shadow);
}

/* ── Buttons ─────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:7px;padding:8px 16px;border:1px solid transparent;
  border-radius:var(--radius);font-size:.84rem;font-weight:600;
  cursor:pointer;transition:.15s;white-space:nowrap;line-height:1;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{
  background:var(--gold);color:var(--navy);border-color:var(--gold);
  font-weight:700;box-shadow:0 4px 12px rgba(201,168,76,.3);
}
.btn-primary:hover{background:var(--gold-2);border-color:var(--gold-2)}
.btn-secondary{background:var(--navy-4);color:var(--text-2);border-color:var(--border);box-shadow:none}
.btn-secondary:hover{background:var(--navy-5);color:var(--text)}
.btn-danger{background:var(--red-bg);color:var(--red);border-color:rgba(248,113,113,.3)}
.btn-danger:hover{background:rgba(248,113,113,.2)}
.btn-ghost{background:transparent;color:var(--muted);border-color:var(--border)}
.btn-ghost:hover{background:var(--navy-4);color:var(--text)}
.btn-sm{padding:5px 11px;font-size:.78rem;border-radius:var(--radius-sm)}
.btn-block{width:100%}
.btn-login-xl{padding:12px 20px;font-size:.95rem}
.btn-logout,.btn-icon{
  width:34px;height:34px;border-radius:var(--radius-sm);
  border:1px solid var(--border);background:var(--navy-4);
  color:var(--muted);display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:.15s;
}
.btn-logout:hover{background:var(--red-bg);color:var(--red)}
.btn-icon:hover{background:var(--navy-5);color:var(--text)}
.btn-icon.del:hover{background:var(--red-bg);color:var(--red)}

/* ── Badges ──────────────────────────────────────────────────── */
.badge{
  display:inline-flex;align-items:center;justify-content:center;
  padding:3px 9px;border-radius:999px;font-size:.74rem;font-weight:600;
  border:1px solid transparent;background:var(--navy-4);color:var(--text-2);
}
.soft-badge{background:var(--navy-4);color:var(--muted);border-color:var(--border)}
.imp-1{background:var(--navy-4);color:var(--muted-2)}
.imp-2{background:rgba(45,212,191,.1);color:var(--teal);border-color:rgba(45,212,191,.2)}
.imp-3{background:var(--amber-bg);color:var(--amber);border-color:rgba(251,191,36,.2)}
.imp-4{background:rgba(251,146,60,.1);color:#fb923c;border-color:rgba(251,146,60,.2)}
.imp-5{background:var(--red-bg);color:var(--red);border-color:rgba(248,113,113,.2)}
.badge-green{background:var(--green-bg);color:var(--green);border-color:rgba(52,211,153,.2)}
.badge-red{background:var(--red-bg);color:var(--red);border-color:rgba(248,113,113,.2)}
.badge-amber{background:var(--amber-bg);color:var(--amber);border-color:rgba(251,191,36,.2)}
.badge-gold{background:var(--gold-bg);color:var(--gold);border-color:rgba(201,168,76,.25)}
.badge-teal{background:var(--teal-bg);color:var(--teal);border-color:rgba(45,212,191,.2)}

/* ── Tables ──────────────────────────────────────────────────── */
.doc-list-wrap{padding:0;overflow:hidden;background:var(--navy-3);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow)}
.doc-list-table{width:100%;border-collapse:collapse;font-size:.84rem}
.doc-list-table thead th{padding:10px 14px;text-align:left;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted-2);background:var(--navy-2);border-bottom:1px solid var(--border);white-space:nowrap}
.doc-list-row td{padding:11px 14px;border-bottom:1px solid var(--border-2);vertical-align:middle}
.doc-list-row:last-child td{border-bottom:none}
.doc-list-row:hover td{background:var(--navy-4)}
.doc-list-icon{width:30px;height:30px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}
.doc-list-icon svg{width:.85rem;height:.85rem}
.doc-list-icon-cell{padding-right:8px!important}
.doc-list-title{font-weight:600;color:var(--text);line-height:1.3;font-size:.86rem}
.doc-list-issuer{font-size:.76rem;color:var(--muted);margin-top:2px}
.doc-list-title-cell{max-width:280px}
.doc-list-muted{color:var(--muted);font-size:.78rem;white-space:nowrap}

/* ── Stat Cards ──────────────────────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.stats-grid-3{grid-template-columns:repeat(3,1fr)}
.stats-grid-5{grid-template-columns:repeat(5,1fr)}
.stats-grid-6,.stats-grid-six{grid-template-columns:repeat(6,1fr)}
.stat-card{background:var(--navy-3);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:6px}
.stat-icon{width:36px;height:36px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;margin-bottom:6px;border:1px solid rgba(201,168,76,.15)}
.stat-icon svg{width:1rem;height:1rem}
.stat-num{font-size:1.55rem;font-weight:800;letter-spacing:-.04em;line-height:1}
.stat-lbl{font-size:.76rem;color:var(--muted);font-weight:500}
.stat-blue .stat-icon{background:rgba(37,99,235,.15);color:#60a5fa}
.stat-green .stat-icon{background:var(--green-bg);color:var(--green)}
.stat-red .stat-icon{background:var(--red-bg);color:var(--red)}
.stat-amber .stat-icon,.stat-gold .stat-icon{background:var(--gold-bg);color:var(--gold)}
.stat-violet .stat-icon{background:rgba(124,58,237,.15);color:#a78bfa}
.stat-pink .stat-icon{background:rgba(219,39,119,.15);color:#f472b6}
.stat-cyan .stat-icon,.stat-teal .stat-icon{background:var(--teal-bg);color:var(--teal)}
.stat-slate .stat-icon{background:rgba(71,85,105,.3);color:#94a3b8}

/* Compact stat bar */
.stat-bar{display:flex;align-items:stretch;overflow:hidden;background:var(--navy-3);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow)}
.stat-bar-item{display:flex;align-items:center;gap:8px;flex:1;padding:12px 14px;text-decoration:none;color:var(--text);border-right:1px solid var(--border);transition:.15s;min-width:0}
.stat-bar-item:last-child{border-right:none}
.stat-bar-item:hover{background:var(--navy-4)}
.stat-bar-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.stat-bar-num{font-size:1.05rem;font-weight:800;letter-spacing:-.03em;flex-shrink:0}
.stat-bar-lbl{font-size:.73rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ── Alerts ──────────────────────────────────────────────────── */
.alert{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:var(--radius);border:1px solid;font-size:.86rem;font-weight:500}
.alert-success{background:var(--green-bg);border-color:rgba(52,211,153,.25);color:var(--green)}
.alert-error{background:var(--red-bg);border-color:rgba(248,113,113,.25);color:var(--red)}
.alert-warning{background:var(--amber-bg);border-color:rgba(251,191,36,.25);color:var(--amber)}

/* ── Forms ───────────────────────────────────────────────────── */
input[type=text],input[type=email],input[type=password],input[type=number],
input[type=date],select,textarea{
  width:100%;padding:9px 12px;background:var(--navy-2);
  border:1px solid var(--border);border-radius:var(--radius);
  font-size:.86rem;color:var(--text);outline:none;transition:.15s;
}
input:focus,select:focus,textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,168,76,.12)}
input::placeholder,textarea::placeholder{color:var(--muted-2)}
select option{background:var(--navy-3)}
textarea{min-height:110px;resize:vertical}
.field-group{margin-bottom:14px}
.field-group label{display:block;font-weight:600;font-size:.8rem;color:var(--text-2);margin-bottom:5px}
.field-wrap{position:relative}
.field-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--muted-2);display:flex;pointer-events:none}
.field-icon svg{width:.9rem;height:.9rem}
.field-wrap input{padding-left:36px}
.search-input,.filter-select{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:.84rem;color:var(--text);background:var(--navy-2);outline:none}
.search-input:focus,.filter-select:focus{border-color:var(--gold)}
.filter-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.search-wrap{display:flex;align-items:center;gap:8px;background:var(--navy-2);border:1px solid var(--border);padding:0 12px;border-radius:var(--radius);flex:1;min-width:200px}
.search-wrap svg{color:var(--muted-2);flex-shrink:0}
.search-wrap .search-input{border:none;box-shadow:none;padding:9px 0;background:transparent;width:100%}
.notes-area{min-height:120px}

/* ── Upload / Camera ─────────────────────────────────────────── */
.upload-zone{
  border:2px dashed var(--border);border-radius:var(--radius-lg);
  padding:36px 24px;text-align:center;cursor:pointer;
  background:var(--navy-2);transition:.2s;position:relative;
}
.upload-zone.drag{border-color:var(--gold);background:var(--gold-bg)}
.upload-zone input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.upload-zone-icon{width:56px;height:56px;margin:0 auto 12px;border-radius:var(--radius-lg);background:var(--gold-bg);border:1px solid rgba(201,168,76,.2);display:flex;align-items:center;justify-content:center}
.upload-zone-icon svg{width:1.4rem;height:1.4rem;color:var(--gold)}
.upload-zone h3{font-size:.95rem;font-weight:700;color:var(--text);margin-bottom:6px}
.upload-zone p{color:var(--muted);font-size:.84rem}

/* Camera button - most important on mobile */
.camera-btn{
  display:flex;align-items:center;justify-content:center;gap:10px;
  width:100%;padding:16px;margin-bottom:12px;
  background:linear-gradient(135deg,var(--gold),#e0b84a);
  color:var(--navy);border:none;border-radius:var(--radius-lg);
  font-size:1rem;font-weight:800;cursor:pointer;
  box-shadow:0 6px 20px rgba(201,168,76,.4);transition:.15s;
}
.camera-btn:hover,.camera-btn:active{background:linear-gradient(135deg,var(--gold-2),var(--gold));transform:translateY(-1px)}
.camera-btn svg{width:1.4rem;height:1.4rem}
.camera-input{display:none}

.processing-card,.result-card{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:12px 14px;border-radius:var(--radius-lg);
  background:var(--navy-3);border:1px solid var(--border);box-shadow:var(--shadow);
}
.processing-status{color:var(--muted);font-size:.84rem;margin-top:2px}
.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}

/* ── Document Detail ─────────────────────────────────────────── */
.doc-detail{display:grid;grid-template-columns:minmax(0,1.7fr) 330px;gap:18px;align-items:start}
.detail-sidebar{display:flex;flex-direction:column;gap:12px}
.detail-card{background:var(--navy-3);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}
.detail-card h3{font-size:.92rem;font-weight:700;color:var(--text);margin:0}
.detail-card-head{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:13px 15px;border-bottom:1px solid var(--border)}
.detail-row{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:9px 15px;border-bottom:1px solid var(--border-2)}
.detail-row:last-child{border-bottom:none}
.detail-lbl{color:var(--muted);font-size:.78rem;font-weight:500;white-space:nowrap}
.detail-val{font-size:.84rem;font-weight:600;text-align:right;color:var(--text);word-break:break-word}
.detail-tag-list{display:flex;flex-wrap:wrap;gap:5px;padding:10px 15px;border-top:1px solid var(--border-2)}
.detail-preview{background:var(--navy-3);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:14px}
.text-muted{color:var(--muted)!important;font-weight:400!important}
.danger-text{color:var(--red)!important}
.break-word{word-break:break-word}
.mono{font-family:ui-monospace,monospace;font-size:.82rem}
.fallback-preview{min-height:280px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--muted)}

/* ── Empty state ─────────────────────────────────────────────── */
.empty-state{text-align:center;padding:44px 24px;background:var(--navy-3);border:1px solid var(--border);border-radius:var(--radius-lg)}
.empty-icon{width:60px;height:60px;margin:0 auto 12px;border-radius:var(--radius-lg);background:var(--gold-bg);border:1px solid rgba(201,168,76,.15);display:flex;align-items:center;justify-content:center}
.empty-icon svg{width:1.6rem;height:1.6rem;color:var(--gold)}
.empty-state h3{font-size:.95rem;font-weight:700;color:var(--text);margin-bottom:5px}
.empty-state p{color:var(--muted);font-size:.84rem}

/* ── Chips ───────────────────────────────────────────────────── */
.ai-chip-row{display:flex;flex-wrap:wrap;gap:7px;padding:12px 14px;background:var(--navy-3);border:1px solid var(--border);border-radius:var(--radius-lg)}
.ai-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:999px;text-decoration:none;color:var(--text-2);background:var(--navy-4);border:1px solid var(--border);font-size:.78rem;font-weight:500;transition:.15s}
.ai-chip:hover{background:var(--navy-5);color:var(--text)}
.ai-chip.active{background:var(--gold-bg);border-color:rgba(201,168,76,.3);color:var(--gold)}
.ai-chip-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.ai-chip strong{padding:1px 6px;border-radius:999px;background:var(--gold);color:var(--navy);font-size:.68rem;margin-left:2px}

/* ── Hero banner ─────────────────────────────────────────────── */
.hero-banner{
  background:linear-gradient(135deg,var(--navy-3),var(--navy-4));
  border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:22px 26px;display:flex;justify-content:space-between;
  align-items:center;gap:16px;box-shadow:var(--shadow);
}
.hero-kicker{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:6px}
.hero-banner h1{font-size:1.3rem;font-weight:800;letter-spacing:-.02em;margin-bottom:8px}
.hero-banner p{color:var(--muted);font-size:.86rem;line-height:1.5}
.hero-actions{display:flex;gap:8px;flex-wrap:wrap}
.mini-pill{display:inline-flex;align-items:center;padding:5px 11px;border-radius:999px;background:rgba(201,168,76,.12);border:1px solid rgba(201,168,76,.2);font-weight:600;color:var(--gold);font-size:.78rem}

/* ── Expiry alert ────────────────────────────────────────────── */
.expiry-alert{background:rgba(251,191,36,.06);border:1px solid rgba(251,191,36,.2);border-radius:var(--radius-lg);padding:13px 16px}
.expiry-alert-head{display:flex;align-items:center;gap:9px;font-size:.86rem;color:var(--amber);font-weight:600;margin-bottom:10px}
.expiry-list{display:flex;flex-direction:column;gap:4px}
.expiry-item{display:flex;align-items:center;gap:9px;padding:6px 9px;border-radius:var(--radius-sm);text-decoration:none;color:var(--text);transition:.12s;background:rgba(255,255,255,.03)}
.expiry-item:hover{background:rgba(255,255,255,.06)}
.expiry-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.expiry-title{flex:1;font-size:.84rem;font-weight:500}
.expiry-days{font-size:.78rem;font-weight:700;white-space:nowrap}
.expiry-orange{color:var(--amber)}
.expiry-red{color:var(--red)}

/* ── Charts ──────────────────────────────────────────────────── */
.charts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.chart-card{background:var(--navy-3);border:1px solid var(--border);border-radius:var(--radius-lg);padding:17px 18px;box-shadow:var(--shadow)}
.chart-wide{grid-column:span 2}
.chart-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.chart-head strong{font-size:.88rem;font-weight:700}
.chart-head span{font-size:.76rem;color:var(--muted)}
canvas{max-height:240px}

/* ── Wages/Bills ─────────────────────────────────────────────── */
.wages-layout{display:grid;grid-template-columns:300px 1fr;gap:16px;align-items:start}
.wf-row,.ef-row{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}
.wf-row label,.ef-lbl{font-size:.76rem;font-weight:700;color:var(--text-2);text-transform:uppercase;letter-spacing:.05em}
.wf-input,.wf-select,.ef-sel,.ef-input{padding:8px 11px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.85rem;background:var(--navy-2);color:var(--text);outline:none;transition:.15s;box-sizing:border-box;width:100%}
.wf-input:focus,.wf-select:focus,.ef-sel:focus,.ef-input:focus{border-color:var(--gold)}

/* ── Misc helpers ────────────────────────────────────────────── */
.fade-in{animation:fadeIn .3s ease}
.page-body{display:flex;flex-direction:column;gap:16px}
.nav-badge,.sb-badge{margin-left:auto;min-width:20px;text-align:center;padding:2px 6px;border-radius:999px;background:var(--gold);color:var(--navy);font-size:.68rem;font-weight:800;flex-shrink:0}
.side-mini-card,.sidebar-logo,.brand-logo,.logo-kicker,.logo-name,.sidebar-nav,.sidebar-user,.user-avatar,.user-copy,.user-name,.user-role,.logout-form{display:none}
.bulk-ai-status{padding:13px 15px;background:var(--navy-3);border:1px solid var(--border);border-radius:var(--radius-lg)}
.bulk-ai-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px}
.bulk-ai-progress{height:5px;border-radius:999px;background:var(--border);overflow:hidden}
.bulk-ai-progress span{display:block;width:0;height:100%;background:var(--gold);transition:width .3s}
.bulk-ai-text{margin-top:7px;color:var(--muted);font-size:.8rem}
.admin-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:20px;align-items:start}
.admin-grid>*{min-width:0}
.security-panel{padding:24px 26px}
.add-user-panel{padding:24px 26px}
.security-copy{margin:0 0 16px;font-size:.85rem;color:var(--muted);line-height:1.5}
.user-list{display:flex;flex-direction:column;gap:9px}
.user-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--navy-3);box-shadow:var(--shadow)}
.user-card summary{display:flex;justify-content:space-between;gap:10px;align-items:center;padding:13px 15px;cursor:pointer;list-style:none}
.user-card summary::-webkit-details-marker{display:none}
.user-card-right{display:flex;gap:7px;flex-wrap:wrap}
.user-edit-form{padding:0 16px 16px;display:flex;flex-direction:column;gap:12px}
.form-grid-two{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.stack-form{display:flex;flex-direction:column;gap:13px}
.stack-form label,.user-edit-form label{display:block;font-weight:600;font-size:.8rem;margin-bottom:5px;color:var(--text-2)}
.checkbox-row{display:flex;align-items:center;gap:8px;font-weight:500}
.inline-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}
.security-box{margin-top:20px;padding:14px 16px;border-radius:var(--radius-lg);background:var(--navy-2);border:1px solid var(--border)}
.security-box h4{margin:0 0 10px;font-size:.88rem;font-weight:700;color:var(--text)}
.security-box ul{margin:0;padding-left:16px;color:var(--muted);display:flex;flex-direction:column;gap:6px;font-size:.82rem;line-height:1.4}

/* ── LOGIN PAGE ──────────────────────────────────────────────── */
body.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;background:var(--navy);overflow:hidden;position:relative}
body.login-page .app-wrapper{display:contents}
.login-bg{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.login-noise{position:absolute;inset:0;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.login-glow-a{position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(201,168,76,.12),transparent 70%);top:-200px;left:-150px}
.login-glow-b{position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(45,212,191,.06),transparent 70%);bottom:-150px;right:-100px}
.login-wrap{position:relative;z-index:1;width:100%;max-width:400px;padding:16px}
.login-card{
  background:rgba(26,37,53,.96);
  border:1px solid rgba(201,168,76,.18);
  border-radius:20px;padding:36px 30px;
  box-shadow:0 40px 80px rgba(0,0,0,.6),0 0 0 1px rgba(201,168,76,.08),inset 0 1px 0 rgba(255,255,255,.04);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
}
.login-logo-wrap{text-align:center;margin-bottom:20px}
.login-logo-img{
  height:120px;width:120px;border-radius:50%;
  object-fit:cover;margin:0 auto;
  border:2px solid rgba(201,168,76,.35);
  box-shadow:0 8px 32px rgba(0,0,0,.5),0 0 0 4px rgba(201,168,76,.08);
  background:#1a2535;
}
.login-brand{text-align:center;margin-bottom:26px}
.login-brand-name{
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:1.7rem;font-weight:600;
  letter-spacing:.04em;color:var(--gold);
  margin-bottom:3px;
}
.login-brand-sub{font-size:.76rem;color:var(--muted);letter-spacing:.06em;text-transform:uppercase}
.login-error{padding:10px 13px;border-radius:9px;background:var(--red-bg);border:1px solid rgba(248,113,113,.25);color:var(--red);font-size:.83rem;margin-bottom:14px}
.login-form{display:flex;flex-direction:column;gap:12px}
.lf-group{display:flex;flex-direction:column;gap:4px}
.lf-label{color:rgba(182,198,216,.5);font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.lf-wrap{position:relative}
.lf-ico{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:rgba(143,163,177,.4);display:flex;pointer-events:none}
.lf-ico svg{width:15px;height:15px}
.lf-input{
  width:100%;padding:12px 12px 12px 38px;
  background:rgba(255,255,255,.04);border:1px solid rgba(201,168,76,.15);
  border-radius:10px;color:var(--text);font-size:.9rem;
  font-family:var(--font);outline:none;transition:.18s;box-sizing:border-box;-webkit-appearance:none;
}
.lf-input::placeholder{color:rgba(143,163,177,.35)}
.lf-input:focus{border-color:var(--gold);background:rgba(201,168,76,.05);box-shadow:0 0 0 3px rgba(201,168,76,.1)}
.login-btn{
  width:100%;padding:13px;border:none;border-radius:10px;
  background:linear-gradient(135deg,var(--gold),#e0b84a);
  color:var(--navy);font-size:.92rem;font-weight:800;
  cursor:pointer;transition:.18s;font-family:var(--font);letter-spacing:.02em;
  box-shadow:0 6px 20px rgba(201,168,76,.35);margin-top:4px;
}
.login-btn:hover{transform:translateY(-1px);box-shadow:0 10px 28px rgba(201,168,76,.45)}
.login-footer{display:flex;align-items:center;gap:7px;margin-top:18px;padding-top:16px;border-top:1px solid rgba(255,255,255,.05);color:rgba(143,163,177,.4);font-size:.73rem;line-height:1.4}
.login-footer-dot{width:5px;height:5px;border-radius:50%;background:rgba(201,168,76,.4);flex-shrink:0}

/* ── PDF Preview ─────────────────────────────────────────────── */
.pdf-preview-shell{display:flex;flex-direction:column;gap:13px}
.pdf-preview-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;padding-bottom:12px;border-bottom:1px solid var(--border)}
.pdf-preview-toolbar strong{font-size:.88rem;font-weight:700;display:block}
.pdf-preview-toolbar span{font-size:.8rem;color:var(--muted)}
.pdf-preview-actions{display:flex;gap:8px;flex-wrap:wrap}

/* ── Animations ──────────────────────────────────────────────── */
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* ── MOBILE FIRST ────────────────────────────────────────────── */
@media(max-width:1200px){
  .stats-grid-six,.stats-grid-6{grid-template-columns:repeat(3,1fr)}
  .charts-grid{grid-template-columns:repeat(2,1fr)}
  .chart-wide{grid-column:span 2}
  .doc-detail{grid-template-columns:1fr}
}
@media(max-width:900px){
  :root{--sidebar-w:220px}
  .admin-grid,.wages-layout{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid-six,.stats-grid-6{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:680px){
  .sidebar{
    position:fixed;left:0;z-index:300;height:100vh;
    transform:translateX(calc(-1 * var(--sidebar-w)));transition:transform .25s;
  }
  .sidebar.sidebar--open{transform:translateX(0)}
  .page-right{margin-left:0}
  .page-content{padding:14px}
  .topbar,.page-header{flex-direction:column;align-items:flex-start}
  .stats-grid,.stats-grid-six,.stats-grid-6{grid-template-columns:1fr 1fr}
  .charts-grid{grid-template-columns:1fr}
  .chart-wide{grid-column:span 1}
  .doc-detail{grid-template-columns:1fr}
  .stat-bar{flex-wrap:wrap}
  .stat-bar-item{flex:0 0 50%}
  /* Camera button bigger on mobile */
  .camera-btn{padding:20px;font-size:1.1rem}
  .upload-zone{padding:28px 16px}
}
@media(max-width:420px){
  .stats-grid,.stats-grid-six,.stats-grid-6{grid-template-columns:1fr}
  .login-card{padding:28px 18px}
  .login-logo-img{height:76px;width:76px}
}
