
:root{
  --ink:#12151c;
  --ink-2:#1b202b;
  --ink-3:#232a37;
  --line:#2c3342;
  --text:#eef0f4;
  --text-soft:#9aa2b4;
  --brass:#c6a15b;
  --brass-bright:#e2c07f;
  --verified:#3fa787;
  --verified-bg:#173229;
  --alert:#d5715a;
  --alert-bg:#3a2320;
  --paper:#f7f3e8;
  --paper-line:#ded5be;
  --paper-ink:#20231d;
  --radius:14px;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  background:var(--ink);
  color:var(--text);
  font-family:"Public Sans",system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
}
h1,h2,h3,.display{
  font-family:"Fraunces",serif;
  font-weight:600;
  letter-spacing:-0.01em;
  margin:0;
}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;}
.mono{font-family:"IBM Plex Mono",monospace;}

/* ===== Topbar ===== */
.topbar{
  position:sticky;top:0;z-index:50;
  background:rgba(18,21,28,0.88);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{
  max-width:1120px;margin:0 auto;padding:16px 24px;
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;
}
.brand{
  display:flex;align-items:center;gap:10px;
  font-family:"Fraunces",serif;font-weight:600;font-size:20px;
}
.brand .mark{
  width:30px;height:30px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%, var(--brass-bright), var(--brass) 55%, #8a6c31 100%);
  box-shadow:0 0 0 1px rgba(198,161,91,0.4), 0 0 14px rgba(198,161,91,0.35);
  flex-shrink:0;
}
.brand span{color:var(--brass-bright);}
.navlinks{display:flex;gap:4px;flex-wrap:wrap;}
.navlinks a{
  padding:8px 14px;border-radius:999px;font-size:14px;font-weight:500;
  color:var(--text-soft); transition:all .15s ease;
}
.navlinks a:hover{color:var(--text);background:var(--ink-3);}
.navlinks a.active{color:var(--ink);background:var(--brass-bright);}

/* ===== Layout shells ===== */
.page{max-width:1120px;margin:0 auto;padding:56px 24px 96px;}
.page.narrow{max-width:640px;}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--brass-bright);font-weight:600;margin-bottom:14px;
}
.eyebrow::before{content:"";width:16px;height:1px;background:var(--brass-bright);}

/* ===== Hero ===== */
.hero{
  display:grid;grid-template-columns:1.1fr 0.9fr;gap:56px;align-items:center;
  padding:64px 24px 40px;max-width:1120px;margin:0 auto;
}
.hero h1{font-size:44px;line-height:1.08;margin-bottom:18px;}
.hero p.lead{color:var(--text-soft);font-size:17px;line-height:1.6;max-width:46ch;margin-bottom:30px;}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;}

.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 22px;border-radius:10px;border:1px solid transparent;
  font-size:14.5px;font-weight:600;transition:transform .12s ease, filter .12s ease;
}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--brass-bright);color:#1a1200;}
.btn-primary:hover{filter:brightness(1.06);}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--text);}
.btn-ghost:hover{background:var(--ink-3);}
.btn-full{width:100%;justify-content:center;}
.btn[disabled]{opacity:.5;cursor:not-allowed;}

/* Seal mockup */
.seal-stage{
  position:relative;display:flex;align-items:center;justify-content:center;
  min-height:340px;
}
.cert-mock{
  width:300px;background:var(--paper);color:var(--paper-ink);
  border-radius:10px;padding:28px 26px;
  box-shadow:0 30px 60px -20px rgba(0,0,0,0.6), 0 0 0 1px rgba(0,0,0,0.04);
  transform:rotate(-4deg);
  position:relative;
}
.cert-mock .cm-title{font-family:"Fraunces",serif;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:#6b6250;margin-bottom:4px;}
.cert-mock .cm-name{font-family:"Fraunces",serif;font-size:20px;font-weight:600;margin-bottom:18px;}
.cert-mock .cm-row{display:flex;justify-content:space-between;font-size:11.5px;padding:7px 0;border-top:1px dashed var(--paper-line);color:#5a5346;}
.cert-mock .cm-row b{color:#26231b;font-weight:600;}
.seal-badge{
  position:absolute;top:-26px;right:-22px;width:92px;height:92px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%, var(--brass-bright), var(--brass) 55%, #8a6c31 100%);
  display:flex;align-items:center;justify-content:center;text-align:center;
  box-shadow:0 0 0 4px var(--paper), 0 0 24px rgba(198,161,91,0.55);
  transform:rotate(8deg);
  animation:pulse 3.2s ease-in-out infinite;
}
.seal-badge span{
  font-family:"Fraunces",serif;font-weight:700;font-size:10.5px;color:#241a03;
  letter-spacing:.03em;line-height:1.25;
}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 4px var(--paper), 0 0 20px rgba(198,161,91,0.45);}
  50%{box-shadow:0 0 0 4px var(--paper), 0 0 34px rgba(198,161,91,0.75);}
}
@media (prefers-reduced-motion:reduce){ .seal-badge{animation:none;} }

/* ===== Feature grid ===== */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:8px;}
.feature-card{
  background:var(--ink-2);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;transition:border-color .15s ease, transform .15s ease;
}
.feature-card:hover{border-color:#3a4256;transform:translateY(-2px);}
.feature-num{
  font-family:"IBM Plex Mono",monospace;font-size:12px;color:var(--brass-bright);
  margin-bottom:14px;display:block;
}
.feature-card h3{font-size:18px;margin-bottom:8px;}
.feature-card p{color:var(--text-soft);font-size:14px;line-height:1.55;margin:0 0 18px;}
.feature-card a.link{
  font-size:13.5px;font-weight:600;color:var(--brass-bright);
  display:inline-flex;align-items:center;gap:6px;
}
.feature-card a.link .arrow{transition:transform .15s ease;}
.feature-card a.link:hover .arrow{transform:translateX(3px);}

/* ===== Cards / forms ===== */
.card{
  background:var(--ink-2);border:1px solid var(--line);border-radius:var(--radius);
  padding:32px;
}
.card + .card{margin-top:20px;}
.card h2{font-size:24px;margin-bottom:6px;}
.card .sub{color:var(--text-soft);font-size:14px;margin-bottom:26px;}

.field{margin-bottom:18px;}
.field label{display:block;font-size:13px;font-weight:600;color:var(--text-soft);margin-bottom:7px;}
.field .hint{font-size:12px;color:var(--text-soft);margin-top:6px;}
.input, select, textarea{
  width:100%;background:var(--ink);border:1px solid var(--line);color:var(--text);
  padding:12px 14px;border-radius:9px;font-size:14.5px;font-family:inherit;
  transition:border-color .12s ease, box-shadow .12s ease;
}
.input:focus, select:focus, textarea:focus{
  outline:none;border-color:var(--brass);box-shadow:0 0 0 3px rgba(198,161,91,0.18);
}
textarea{resize:vertical;min-height:90px;}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media (max-width:640px){ .row2{grid-template-columns:1fr;} }

.alert{border-radius:10px;padding:14px 16px;font-size:14px;margin-bottom:20px;display:flex;gap:10px;align-items:flex-start;}
.alert-error{background:var(--alert-bg);color:#f2b9a9;border:1px solid #5b3229;}
.alert-success{background:var(--verified-bg);color:#a9e0c9;border:1px solid #2c5c48;}

/* ===== Verify result / certificate ===== */
.result-badge{
  display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:999px;
  font-size:12.5px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;
}
.result-badge.ok{background:var(--verified-bg);color:#8fe0bf;}
.result-badge.bad{background:var(--alert-bg);color:#f0a793;}

.cert-wrap{display:flex;justify-content:center;}
.certificate{
  width:100%;max-width:620px;background:var(--paper);color:var(--paper-ink);
  border-radius:16px;padding:44px 42px;position:relative;
  box-shadow:0 40px 80px -30px rgba(0,0,0,0.65);
}
.certificate .top{text-align:center;margin-bottom:28px;}
.certificate .top .kicker{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#8a7d5f;margin-bottom:10px;}
.certificate .top h1{font-size:28px;color:#20231d;}
.certificate .top p{color:#736a56;font-size:13.5px;margin-top:8px;}
.cert-seal{
  width:112px;height:112px;border-radius:50%;margin:0 auto 22px;
  background:radial-gradient(circle at 35% 30%, var(--brass-bright), var(--brass) 55%, #8a6c31 100%);
  display:flex;align-items:center;justify-content:center;text-align:center;
  box-shadow:0 0 0 6px #fff, 0 0 0 7px var(--paper-line);
}
.cert-seal span{font-family:"Fraunces",serif;font-weight:700;font-size:12px;color:#241a03;line-height:1.3;}
.cert-table{width:100%;border-collapse:collapse;margin-top:8px;}
.cert-table tr{border-top:1px dashed var(--paper-line);}
.cert-table tr:first-child{border-top:none;}
.cert-table th{
  text-align:left;padding:11px 0;font-size:12px;color:#8a7d5f;font-weight:600;
  width:38%;vertical-align:top;letter-spacing:.02em;
}
.cert-table td{padding:11px 0;font-size:14.5px;color:#26231b;font-weight:500;}
.cert-foot{text-align:center;margin-top:26px;font-size:12px;color:#8a7d5f;}
.cert-actions{display:flex;justify-content:center;gap:12px;margin-top:26px;}

/* ===== Steps ===== */
.steps{display:flex;gap:10px;margin-bottom:28px;flex-wrap:wrap;}
.step{
  display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-soft);
  padding:8px 14px;border:1px solid var(--line);border-radius:999px;
}
.step .dot{width:6px;height:6px;border-radius:50%;background:var(--line);}
.step.active{color:var(--text);border-color:var(--brass);}
.step.active .dot{background:var(--brass-bright);}
.step.done{color:var(--verified);}
.step.done .dot{background:var(--verified);}

/* ===== Stat cards (admin) ===== */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;}
@media (max-width:800px){.stat-grid{grid-template-columns:repeat(2,1fr);}}
.stat{background:var(--ink-2);border:1px solid var(--line);border-radius:12px;padding:20px;}
.stat .n{font-family:"Fraunces",serif;font-size:32px;font-weight:600;}
.stat .l{font-size:12.5px;color:var(--text-soft);margin-top:4px;}

table.data{width:100%;border-collapse:collapse;font-size:13.5px;}
table.data th{
  text-align:left;padding:10px 12px;color:var(--text-soft);font-weight:600;
  font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;
  border-bottom:1px solid var(--line);
}
table.data td{padding:12px;border-bottom:1px solid var(--line);}
table.data tr:last-child td{border-bottom:none;}
.badge-pill{padding:4px 10px;border-radius:999px;font-size:11.5px;font-weight:600;}
.badge-pill.active{background:var(--verified-bg);color:#8fe0bf;}
.badge-pill.open{background:#3a3620;color:#e0d18f;}
.tabbar{display:flex;gap:8px;margin-bottom:22px;border-bottom:1px solid var(--line);}
.tabbtn{padding:10px 4px;margin-right:20px;font-size:14px;font-weight:600;color:var(--text-soft);border-bottom:2px solid transparent;}
.tabbtn.active{color:var(--text);border-color:var(--brass-bright);}

.footer{
  border-top:1px solid var(--line);padding:30px 24px;text-align:center;
  color:var(--text-soft);font-size:13px;
}
.icon{width:18px;height:18px;flex-shrink:0;}
@media (max-width:860px){
  .hero{grid-template-columns:1fr;padding-top:40px;}
  .seal-stage{order:-1;min-height:260px;}
  .grid3{grid-template-columns:1fr;}
  .stat-grid{grid-template-columns:1fr 1fr;}
  .hero h1{font-size:34px;}
}

.logo-word{letter-spacing:.02em}.qrbox{width:116px;height:116px;background:#fff;color:#111;display:grid;place-items:center;border:1px solid var(--paper-line);font-size:10px;text-align:center}.admin-shell{display:grid;grid-template-columns:220px 1fr;gap:24px}.sidebar{background:var(--ink-2);border:1px solid var(--line);border-radius:var(--radius);padding:14px}.sidebar a{display:block;padding:11px 12px;border-radius:9px;color:var(--text-soft);font-weight:600;font-size:14px}.sidebar a:hover,.sidebar a.active{background:var(--ink-3);color:var(--brass-bright)}@media(max-width:860px){.admin-shell{grid-template-columns:1fr}.navlinks{display:none}}@media print{.topbar,.footer,.cert-actions{display:none}.page{padding:0}.certificate{box-shadow:none;max-width:100%;}}

/* ===== Admin v5: Control-room interface ===== */
.btn-sm{padding:10px 14px;font-size:13px;border-radius:9px;}
.tiny-label{font-family:"IBM Plex Mono",monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--brass-bright);display:block;margin-bottom:7px;}
.admin-body{background:linear-gradient(135deg,#0f1218 0%,#141820 46%,#0f1218 100%);overflow-x:hidden;}
.admin-app{min-height:100vh;display:grid;grid-template-columns:280px minmax(0,1fr);}
.admin-sidebar{position:sticky;top:0;height:100vh;padding:20px 18px;background:rgba(18,21,28,.96);border-right:1px solid var(--line);display:flex;flex-direction:column;gap:18px;z-index:80;box-shadow:14px 0 40px rgba(0,0,0,.15);}
.admin-sidebar-head{padding:4px 4px 12px;border-bottom:1px solid var(--line);}
.admin-brand{display:flex;align-items:center;gap:12px;}
.admin-brand .mark{width:36px;height:36px;border-radius:50%;background:radial-gradient(circle at 35% 30%, var(--brass-bright), var(--brass) 55%, #8a6c31 100%);box-shadow:0 0 0 1px rgba(226,192,127,.35),0 0 18px rgba(198,161,91,.25);flex-shrink:0;}
.admin-brand b{font-family:"Fraunces",serif;font-size:22px;line-height:1;color:var(--text);}
.admin-brand small{display:block;margin-top:3px;color:var(--text-soft);font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;}
.admin-menu{display:flex;flex-direction:column;gap:7px;}
.admin-menu a{display:flex;gap:11px;align-items:flex-start;padding:13px 12px;border-radius:13px;color:var(--text-soft);border:1px solid transparent;transition:.15s ease;}
.admin-menu a:hover{background:var(--ink-2);color:var(--text);border-color:var(--line);}
.admin-menu a.active{background:linear-gradient(135deg,rgba(226,192,127,.16),rgba(198,161,91,.05));color:var(--text);border-color:rgba(226,192,127,.34);box-shadow:inset 0 0 0 1px rgba(226,192,127,.05);}
.admin-menu a b{display:block;font-size:14px;margin-bottom:3px;}
.admin-menu a small{display:block;font-size:11.5px;color:var(--text-soft);font-weight:500;}
.nav-dot{width:9px;height:9px;border-radius:50%;background:var(--line);margin-top:5px;box-shadow:0 0 0 4px rgba(255,255,255,.02);flex-shrink:0;}
.admin-menu a.active .nav-dot{background:var(--brass-bright);box-shadow:0 0 0 4px rgba(226,192,127,.15),0 0 14px rgba(226,192,127,.35);}
.admin-sidebar-card{margin-top:auto;background:var(--ink-2);border:1px solid var(--line);border-radius:16px;padding:16px;}
.admin-sidebar-card strong{display:block;margin-bottom:10px;font-size:14px;}
.admin-sidebar-card a{font-size:13px;color:var(--brass-bright);font-weight:700;}
.admin-main{min-width:0;}
.admin-topbar{position:sticky;top:0;z-index:60;display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:94px;padding:24px 32px;background:rgba(15,18,24,.78);backdrop-filter:blur(14px);border-bottom:1px solid rgba(44,51,66,.85);}
.admin-heading h1{font-size:31px;line-height:1.1;}
.admin-eyebrow{margin-bottom:8px;}
.admin-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end;}
.admin-content{max-width:1320px;margin:0 auto;padding:30px 32px 70px;}
.admin-menu-toggle{display:none;background:var(--ink-2);border:1px solid var(--line);color:var(--text);border-radius:10px;padding:10px 12px;font-size:18px;}
.dashboard-hero{display:grid;grid-template-columns:1fr 280px;gap:22px;background:radial-gradient(circle at 12% 10%,rgba(226,192,127,.18),transparent 28%),linear-gradient(135deg,var(--ink-2),#171c26);border:1px solid var(--line);border-radius:24px;padding:28px;margin-bottom:22px;box-shadow:0 22px 60px rgba(0,0,0,.17);}
.dashboard-hero h2{font-size:32px;margin-bottom:10px;}
.dashboard-hero p{color:var(--text-soft);margin:0;line-height:1.65;max-width:70ch;}
.hero-mini-card{background:rgba(0,0,0,.17);border:1px solid rgba(226,192,127,.20);border-radius:18px;padding:20px;display:flex;flex-direction:column;justify-content:center;gap:8px;}
.hero-mini-card span{color:var(--text-soft);font-size:12px;text-transform:uppercase;letter-spacing:.1em;}
.hero-mini-card strong{font-family:"IBM Plex Mono",monospace;color:var(--brass-bright);font-size:16px;}
.hero-mini-card a{font-weight:700;font-size:13px;color:var(--text);}
.admin-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:22px;}
.admin-kpi{background:var(--ink-2);border:1px solid var(--line);border-radius:18px;padding:20px;display:flex;align-items:center;gap:14px;transition:.15s ease;}
.admin-kpi:hover{transform:translateY(-2px);border-color:rgba(226,192,127,.35);}
.kpi-icon{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:rgba(226,192,127,.12);border:1px solid rgba(226,192,127,.20);color:var(--brass-bright);font-weight:800;font-size:19px;}
.admin-kpi b{font-family:"Fraunces",serif;font-size:31px;display:block;line-height:1;}
.admin-kpi small{display:block;color:var(--text-soft);font-size:12.5px;margin-top:4px;}
.admin-grid-two{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(320px,.8fr);gap:22px;margin-bottom:22px;}
.admin-grid-form{display:grid;grid-template-columns:380px minmax(0,1fr);gap:22px;align-items:start;}
.admin-card{background:rgba(27,32,43,.94);border:1px solid var(--line);border-radius:20px;padding:22px;box-shadow:0 18px 48px rgba(0,0,0,.12);}
.admin-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px;}
.admin-card-head h3{font-size:20px;margin-bottom:4px;}
.admin-card-head p{margin:0;color:var(--text-soft);font-size:13.5px;}
.admin-card-head a,.admin-link{color:var(--brass-bright);font-size:13px;font-weight:800;}
.responsive-table{overflow:auto;border:1px solid var(--line);border-radius:15px;background:rgba(0,0,0,.08);}
table.admin-data th{background:rgba(15,18,24,.72);white-space:nowrap;}
table.admin-data td{vertical-align:top;}
table.admin-data tr:hover td{background:rgba(255,255,255,.018);}
.table-sub{display:block;color:var(--text-soft);font-size:12px;margin-top:4px;font-weight:500;}
.badge-pill.danger{background:var(--alert-bg);color:#f0a793;}
.badge-pill.neutral{background:var(--ink-3);color:var(--text-soft);}
.admin-search{display:grid;grid-template-columns:1fr auto auto;gap:10px;margin-bottom:16px;align-items:center;}
.quick-actions{display:grid;gap:10px;}
.quick-actions a{display:block;padding:16px;border:1px solid var(--line);border-radius:15px;background:rgba(18,21,28,.55);transition:.15s ease;}
.quick-actions a:hover{border-color:rgba(226,192,127,.35);transform:translateY(-1px);}
.quick-actions b{display:block;margin-bottom:4px;}
.quick-actions span{display:block;color:var(--text-soft);font-size:13px;line-height:1.45;}
.bar-list{display:grid;gap:16px;}
.bar-label{display:flex;justify-content:space-between;gap:12px;font-size:13px;margin-bottom:7px;color:var(--text-soft);}
.bar-label b{color:var(--text);}
.bar-track{height:9px;border-radius:999px;background:var(--ink);overflow:hidden;border:1px solid var(--line);}
.bar-track span{height:100%;display:block;border-radius:999px;background:linear-gradient(90deg,var(--brass),var(--brass-bright));min-width:2px;}
.ticket-list{display:grid;gap:9px;}
.ticket-list a{display:grid;grid-template-columns:1fr auto;gap:4px 12px;align-items:center;padding:13px;border:1px solid var(--line);border-radius:14px;background:rgba(18,21,28,.45);}
.ticket-list strong{font-size:14px;}
.ticket-list em{font-style:normal;color:var(--text-soft);font-size:12px;}
.admin-empty{text-align:center;padding:34px 20px;color:var(--text-soft);}
.admin-empty .empty-orb{width:62px;height:62px;margin:0 auto 14px;border-radius:50%;display:grid;place-items:center;background:rgba(226,192,127,.12);border:1px solid rgba(226,192,127,.22);color:var(--brass-bright);font-family:"IBM Plex Mono",monospace;font-weight:700;}
.admin-empty h3{color:var(--text);font-size:18px;margin-bottom:8px;}
.admin-empty p{margin:0;font-size:13.5px;}
.mini-copy{background:rgba(226,192,127,.11);border:1px solid rgba(226,192,127,.28);color:var(--brass-bright);border-radius:8px;padding:7px 9px;font-weight:800;font-size:12px;margin-right:8px;}
.ticket-cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;}
.ticket-card{background:rgba(18,21,28,.56);border:1px solid var(--line);border-radius:18px;padding:18px;}
.ticket-card-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:12px;}
.ticket-card-top h3{font-size:17px;margin-top:5px;}
.ticket-card p{color:var(--text-soft);font-size:13.5px;line-height:1.55;margin:0 0 16px;}
.ticket-meta{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:14px;}
.ticket-meta span{background:rgba(0,0,0,.12);border:1px solid var(--line);border-radius:12px;padding:10px;font-size:13px;}
.ticket-meta b{display:block;color:var(--text-soft);font-size:11px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:3px;}
.ticket-status-form{display:flex;gap:10px;align-items:center;}
.ticket-status-form select{flex:1;}
.dealer-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;}
.dealer-card{background:rgba(18,21,28,.56);border:1px solid var(--line);border-radius:18px;padding:18px;display:grid;gap:20px;}
.dealer-card h3{font-size:18px;}
.dealer-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.dealer-stats span{background:rgba(0,0,0,.13);border:1px solid var(--line);border-radius:14px;padding:13px;}
.dealer-stats b{font-family:"Fraunces",serif;font-size:25px;display:block;}
.dealer-stats small{display:block;color:var(--text-soft);font-size:12px;}
.admin-login-body{background:radial-gradient(circle at 20% 10%,rgba(226,192,127,.18),transparent 28%),linear-gradient(135deg,#0f1218,#171c26 52%,#0f1218);min-height:100vh;display:grid;place-items:center;padding:28px;}
.login-shell{width:min(1080px,100%);display:grid;grid-template-columns:1.08fr .92fr;background:rgba(27,32,43,.75);border:1px solid var(--line);border-radius:28px;overflow:hidden;box-shadow:0 35px 90px rgba(0,0,0,.35);}
.login-showcase{padding:42px;min-height:620px;display:flex;flex-direction:column;justify-content:space-between;background:radial-gradient(circle at 20% 18%,rgba(226,192,127,.18),transparent 36%),linear-gradient(135deg,rgba(18,21,28,.3),rgba(18,21,28,.84));}
.login-showcase h1{font-size:40px;line-height:1.08;margin-bottom:18px;}
.login-showcase p{color:var(--text-soft);line-height:1.65;font-size:16px;max-width:54ch;}
.login-feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}
.login-feature-grid div{border:1px solid var(--line);border-radius:16px;padding:15px;background:rgba(0,0,0,.12);}
.login-feature-grid strong{display:block;margin-bottom:5px;}
.login-feature-grid span{display:block;color:var(--text-soft);font-size:12.5px;line-height:1.45;}
.login-card{background:var(--ink-2);padding:42px;display:flex;flex-direction:column;justify-content:center;}
.login-card-head{margin-bottom:24px;}
.login-card-head h2{font-size:30px;margin-bottom:7px;}
.login-card-head p,.login-help{color:var(--text-soft);font-size:13.5px;}
.login-help{text-align:center;margin-top:18px;}
.login-brand{align-self:flex-start;}
@media(max-width:1100px){.admin-app{grid-template-columns:240px minmax(0,1fr)}.admin-grid-form,.admin-grid-two{grid-template-columns:1fr}.admin-kpi-grid{grid-template-columns:repeat(2,1fr)}.dealer-grid,.ticket-cards{grid-template-columns:1fr 1fr}}
@media(max-width:760px){.admin-app{display:block}.admin-sidebar{position:fixed;left:-290px;transition:.2s ease;width:280px}.admin-sidebar.open{left:0}.admin-menu-toggle{display:inline-flex}.admin-topbar{padding:18px;align-items:flex-start}.admin-actions{width:100%;justify-content:flex-start}.admin-content{padding:20px 18px 56px}.admin-kpi-grid,.ticket-cards,.dealer-grid{grid-template-columns:1fr}.dashboard-hero{grid-template-columns:1fr;padding:22px}.admin-heading h1{font-size:25px}.admin-search{grid-template-columns:1fr}.login-shell{grid-template-columns:1fr}.login-showcase{min-height:auto;padding:28px}.login-showcase h1{font-size:31px}.login-feature-grid{grid-template-columns:1fr}.login-card{padding:28px}.ticket-meta{grid-template-columns:1fr}}


/* ===== v5.1 readability fix: warranty verification result table ===== */
.verify-result-card .cert-table th{
  color:var(--brass-bright);
  font-size:13px;
  opacity:1;
}
.verify-result-card .cert-table td{
  color:var(--text);
  font-size:15.5px;
  font-weight:700;
  letter-spacing:.01em;
}
.verify-result-card .cert-table tr{
  border-top:1px dashed rgba(238,240,244,.42);
}
.verify-result-card .mono{
  color:#ffffff;
}
.verify-result-card{
  border-color:rgba(226,192,127,.24);
}

/* ===== Next-level inventory / portal login upgrade ===== */
.brand-logo{gap:12px;}
.brand-logo img{height:40px;width:auto;max-width:148px;object-fit:contain;border-radius:8px;background:#fff;padding:3px;}
.brand-logo .brand-text{font-family:"Fraunces",serif;color:var(--brass-bright);font-weight:700;font-size:18px;}
.portal-dashboard-head{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;flex-wrap:wrap;margin-bottom:26px;}
.public-kpi{margin-bottom:24px;}
.secondary-kpis{margin-top:22px;}
.verify-table{width:100%;border-collapse:collapse;margin-top:8px;}
.verify-table tr{border-top:1px dashed rgba(255,255,255,.35);}
.verify-table tr:first-child{border-top:none;}
.verify-table th{width:38%;text-align:left;padding:13px 0;color:var(--brass-bright);font-size:13px;letter-spacing:.02em;vertical-align:top;}
.verify-table td{padding:13px 0;color:var(--text);font-size:15px;font-weight:600;vertical-align:top;}
.verify-result-card .mono{color:#fff;}
.site-certificate .cert-seal span{font-size:11px;}
.admin-logo-img{width:46px;height:46px;object-fit:contain;background:#fff;border-radius:12px;padding:4px;box-shadow:0 0 0 1px rgba(255,255,255,.15);}
.admin-brand{align-items:center;}
.admin-brand .mark{display:none;}
.admin-menu a small{line-height:1.1;}
input[type="file"].input{padding:10px;background:var(--ink);}
.admin-empty .empty-orb{margin:0 auto 12px;}
@media (max-width:760px){
  .brand-logo img{height:34px;max-width:118px;}
  .brand-logo .brand-text{font-size:15px;}
  .navlinks a{font-size:12px;padding:7px 9px;}
  .portal-dashboard-head .btn{width:100%;justify-content:center;}
}


/* ===== v5.3 Logo Size Fix =====
   Prevents the uploaded Lit4Ever logo JPG from expanding to full page width.
   Applies to public header, admin header, upgrade page and any generic logo image. */
.topbar {
  min-height: 72px;
}
.nav {
  min-height: 72px;
}
.brand-logo {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  max-width: 220px !important;
  overflow: hidden !important;
}
.brand-logo img,
img.lit4ever-logo,
.logo-img,
.site-logo,
.admin-logo-img {
  display: block !important;
  width: auto !important;
  height: 42px !important;
  max-width: 155px !important;
  max-height: 42px !important;
  object-fit: contain !important;
  background: #fff !important;
  border-radius: 10px !important;
  padding: 4px !important;
}
.hero-logo,
.page-logo,
.upgrade-logo,
.login-logo {
  display: block !important;
  width: auto !important;
  height: 76px !important;
  max-width: 260px !important;
  max-height: 76px !important;
  object-fit: contain !important;
  margin: 0 auto 22px !important;
  background: #fff !important;
  border-radius: 14px !important;
  padding: 8px !important;
}
.logo-preview,
.logo-preview img {
  width: auto !important;
  height: 64px !important;
  max-width: 220px !important;
  max-height: 64px !important;
  object-fit: contain !important;
}
@media (max-width: 760px) {
  .brand-logo img,
  img.lit4ever-logo,
  .logo-img,
  .site-logo,
  .admin-logo-img {
    height: 34px !important;
    max-height: 34px !important;
    max-width: 120px !important;
  }
  .hero-logo,
  .page-logo,
  .upgrade-logo,
  .login-logo {
    height: 58px !important;
    max-height: 58px !important;
    max-width: 200px !important;
  }
}


/* ===== v5.4 Multi Item Site Warranty UI ===== */
.multi-item-box{display:flex;flex-direction:column;gap:14px;margin:10px 0 18px;}
.multi-item-row{display:grid;grid-template-columns:minmax(0,1fr) 130px auto;gap:12px;align-items:end;background:rgba(18,21,28,.55);border:1px solid var(--line);border-radius:14px;padding:14px;}
.multi-item-row .field{margin-bottom:0;}
.multi-item-row .remove-item{height:44px;white-space:nowrap;}
.item-stock-hint{font-size:12px;color:var(--text-soft);margin-top:7px;line-height:1.45;}
.items-toolbar{display:flex;justify-content:space-between;gap:12px;align-items:center;flex-wrap:wrap;margin-top:10px;}
.total-preview{font-size:13px;color:var(--brass-bright);font-weight:700;}
.covered-items{margin-top:22px;border:1px solid var(--paper-line);border-radius:12px;overflow:hidden;}
.covered-items-title{font-family:"Fraunces",serif;font-size:17px;font-weight:700;padding:14px 16px;background:#efe6ce;color:#2b261a;border-bottom:1px solid var(--paper-line);}
.covered-items table{width:100%;border-collapse:collapse;}
.covered-items th{font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:#786b4d;background:#f7f0dd;text-align:left;padding:10px;border-bottom:1px solid var(--paper-line);}
.covered-items td{font-size:12.5px;color:#2b261a;padding:10px;border-bottom:1px dashed var(--paper-line);vertical-align:top;}
.covered-items tr:last-child td{border-bottom:none;}
.covered-items .mono{font-size:11.5px;}
.verify-items-list{margin:14px 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px;}
.verify-items-list li{display:flex;justify-content:space-between;gap:12px;border:1px solid var(--line);border-radius:10px;padding:10px 12px;background:rgba(18,21,28,.35);font-size:13px;color:var(--text);}
.verify-items-list small{display:block;color:var(--text-soft);margin-top:3px;}
@media(max-width:760px){.multi-item-row{grid-template-columns:1fr}.multi-item-row .remove-item{width:100%;justify-content:center}}


/* ===== v5.5 Change Password UX ===== */
.form-card .btn + .btn,
.card form .btn + .btn {
  margin-left: 10px;
}
.security-action,
.password-action {
  display:inline-flex;
  align-items:center;
  gap:8px;
}
@media(max-width:640px){
  .form-card .btn + .btn,
  .card form .btn + .btn {
    margin-left:0;
    margin-top:10px;
  }
  .card form .btn {
    width:100%;
    justify-content:center;
  }
}


/* ===== v5.6 Mandatory Fields + Installation Date Validation ===== */
.required-star {
  color: #e2c07f;
  font-weight: 800;
}
#installDateHint strong {
  color: var(--brass-bright);
}
.input:required:invalid,
textarea:required:invalid,
select:required:invalid {
  box-shadow: none;
}


/* ===== v5.7 Admin Approval Workflow ===== */
.result-badge.pending {
  background:#3a3620;
  color:#e0d18f;
}
.badge-pill.pending,
.badge-pill.pending_approval {
  background:#3a3620;
  color:#e0d18f;
}
.approval-status-card .verify-table th,
.approval-status-card .verify-table td {
  color: var(--text);
}
.approval-actions {
  display:flex;
  flex-direction:column;
  gap:8px;
  min-width:160px;
}
.reject-box {
  border:1px solid var(--line);
  border-radius:10px;
  padding:8px;
  background:rgba(255,255,255,.02);
}
.reject-box summary {
  cursor:pointer;
  color:#f0a793;
  font-weight:700;
  font-size:12px;
}
.reject-box textarea {
  width:100%;
  min-height:72px;
  margin:8px 0;
  font-size:12px;
}
.admin-search select.input {
  min-height:42px;
}
@media(max-width:760px){
  .approval-actions { min-width:0; }
}


/* ===== v5.7.1 Admin Sidebar Scroll Fix =====
   Keeps the left admin menu visible and scrollable when menu items exceed screen height. */
.admin-sidebar,
.sidebar {
  max-height: calc(100vh - 28px) !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  position: sticky !important;
  top: 14px !important;
  scrollbar-width: thin;
  scrollbar-color: rgba(226,192,127,.65) rgba(255,255,255,.06);
}
.admin-sidebar::-webkit-scrollbar,
.sidebar::-webkit-scrollbar {
  width: 7px;
}
.admin-sidebar::-webkit-scrollbar-track,
.sidebar::-webkit-scrollbar-track {
  background: rgba(255,255,255,.06);
  border-radius: 999px;
}
.admin-sidebar::-webkit-scrollbar-thumb,
.sidebar::-webkit-scrollbar-thumb {
  background: rgba(226,192,127,.65);
  border-radius: 999px;
}
.admin-sidebar::-webkit-scrollbar-thumb:hover,
.sidebar::-webkit-scrollbar-thumb:hover {
  background: rgba(226,192,127,.95);
}
.admin-sidebar nav,
.sidebar nav {
  padding-bottom: 18px;
}
@media(max-width: 860px) {
  .admin-sidebar,
  .sidebar {
    position: relative !important;
    top: auto !important;
    max-height: none !important;
    overflow: visible !important;
  }
}
