:root{
  --green:#1E9E4A; --green-bright:#27B257; --green-deep:#15793A; --green-soft:#BBE6C7;
  --gold:#C2871C; --gold-deep:#9E6E14; --gold-bg:#FBF4E0; --gold-line:#EAD6A2;
  --yellow:#E6BE0C;
  --card:#FFFFFF; --card-soft:#F6FBF3; --line:#D3E3CC; --line-soft:#E2ECDC;
  --ink:#14271B; --body:#2C3F31; --mut:#5F7065; --mut-2:#8A998A;
  --pct:#0E140E;
  --shadow:0 16px 42px -24px rgba(20,55,28,.40);
  --r:18px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Poppins',system-ui,sans-serif; color:var(--body);
  background:
    radial-gradient(900px 520px at 82% -12%, #D2EBCB99, transparent 60%),
    radial-gradient(760px 600px at -6% 112%, #E5F0D6, transparent 55%),
    linear-gradient(170deg,#EFF6EA,#E5F0DE 58%,#DCEAD3);
  background-attachment:fixed; min-height:100vh; line-height:1.55; -webkit-font-smoothing:antialiased;
  overflow-x:hidden; overflow-wrap:break-word; word-break:break-word;
}
.wrap{max-width:1120px;margin:0 auto;padding:0 30px}

/* ── Top bar ── */
.ringbar{height:5px;display:flex}
.ringbar i{flex:1;font-style:normal}
.ringbar i:nth-child(1){background:var(--green)}
.ringbar i:nth-child(2){background:var(--gold)}
.ringbar i:nth-child(3){background:var(--yellow)}

header{position:sticky;top:0;z-index:30;backdrop-filter:blur(12px);
background:#f3f9efe8;border-bottom:1px solid var(--line);padding:0 30px}
.toprow{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 0 8px;flex-wrap:wrap}
.brand{display:flex;align-items:baseline;gap:11px;min-width:0}
.brand .word{font-weight:700;letter-spacing:.5px;color:var(--green);font-size:20px;white-space:nowrap}
.brand .word .tm{font-size:.55em;vertical-align:super;font-weight:600;letter-spacing:0;color:var(--mut)}
.brand .word .prof{font-weight:400;letter-spacing:0}
.subbrand{font-size:clamp(8.5px,2.7vw,11px);letter-spacing:1px;text-transform:uppercase;color:var(--mut);text-align:left;padding:0 0 10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

nav{display:flex;gap:6px;background:#e7f1e1;border:1px solid var(--line);padding:5px;border-radius:999px}
nav button{font-family:inherit;font-size:13px;font-weight:500;color:var(--mut);background:none;border:0;
padding:9px 16px;border-radius:999px;cursor:pointer;transition:.2s;white-space:nowrap}
nav button[aria-selected="true"]{background:var(--green);color:#fff;font-weight:600}
nav button:focus-visible{outline:2px solid var(--green);outline-offset:2px}

/* ── Typography ── */
.eyebrow{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);font-weight:600}
h1{font-weight:300;font-size:clamp(28px,5.5vw,54px);margin:.12em 0 .14em;letter-spacing:-1px;color:var(--ink);line-height:1.1;text-align:left;text-wrap:balance}
h1 b{font-weight:700;color:var(--green)}
.lede{color:var(--mut);max-width:60ch;font-weight:300;font-size:clamp(14px,2.5vw,16px)}

/* ── Cards ── */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:24px;box-shadow:var(--shadow);overflow-wrap:break-word}

/* ── Buttons ── */
.btn{font-family:inherit;font-weight:600;font-size:14px;border:0;border-radius:12px;padding:13px 18px;cursor:pointer;transition:.2s;display:inline-flex;align-items:center;justify-content:center;gap:8px;text-decoration:none;word-break:break-word}
.btn-primary{background:var(--green);color:#fff;width:100%;margin-top:14px}
.btn-primary:hover{background:var(--green-bright)}
.btn-primary:disabled{background:#C7D8C0;color:#7E8E7C;cursor:not-allowed}
.btn-ghost{background:#fff;color:var(--green-deep);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--green)}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{background:var(--gold-deep)}
.subnote{font-size:11px;color:var(--mut-2);margin-top:10px;font-style:italic}

/* ── Intro card ── */
.intro{margin-bottom:20px;border-left:3px solid var(--gold);background:var(--card-soft)}
.intro p{margin:0;color:var(--body);font-weight:300}
.intro .g{color:var(--green-deep);font-weight:600}
.intro .y{color:var(--gold-deep);font-weight:600}

/* ── Domain sections ── */
.domain{margin-bottom:18px}
.domain-head{display:flex;align-items:center;gap:12px;margin:0 2px 8px}
.domain-head .glyph{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;font-weight:700;color:#143019;background:var(--green);flex-shrink:0}
.domain-head h3{margin:0;font-size:17px;font-weight:600;color:var(--ink);min-width:0}
.domain-head .done{margin-left:auto;font-size:11px;color:var(--green);opacity:0;transition:.3s;font-weight:600;letter-spacing:1px;flex-shrink:0}

/* ── Questions ── */
.q{padding:13px 0;border-top:1px solid var(--line-soft)}
.q p{margin:0 0 11px;font-size:14.5px;color:var(--body);font-weight:400;overflow-wrap:break-word}
.q .qn{color:var(--mut-2);font-weight:600;margin-right:8px}

/* ── Scale / Likert ── */
.scale{display:grid;grid-template-columns:repeat(5,1fr);gap:7px}
.scale button{font-family:inherit;font-size:12px;font-weight:500;color:var(--mut);background:var(--card-soft);
border:1px solid var(--line);border-radius:10px;padding:9px 4px;cursor:pointer;transition:.18s;line-height:1.25;min-height:44px}
.scale button:hover{border-color:var(--dc,var(--green));color:var(--ink)}
.scale button[aria-pressed="true"]{background:var(--dc,var(--green));color:var(--dct,#fff);border-color:var(--dc,var(--green));font-weight:600}
.scale button:focus-visible{outline:2px solid var(--green);outline-offset:2px}

/* ── Staff grid (two-column on desktop) ── */
.staff-grid{display:grid;grid-template-columns:340px 1fr;gap:26px;margin-top:26px;align-items:start}
.flowerpanel{position:sticky;top:92px;align-self:start}
.flowerpanel .card{padding:22px 18px;text-align:center}

/* ── Flower ── */
.flower-wrap{position:relative;width:240px;height:240px;margin:6px auto 4px;max-width:100%}
.pct{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none;z-index:5}
.pct b{font-size:32px;font-weight:700;color:var(--pct);line-height:1;text-shadow:0 1px 5px #ffffffcc}
.pct span{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--mut);text-shadow:0 1px 4px #fff}
.letters{display:flex;justify-content:center;gap:7px;margin-top:8px}
.letters span{font-weight:700;font-size:15px;color:#BACDB4;transition:.35s}
.letters span.on{color:var(--green)}
.legend{margin-top:14px;text-align:left;display:grid;gap:7px}
.legend .row{display:flex;align-items:center;gap:9px;font-size:13px}
.legend .dot{width:9px;height:9px;border-radius:50%;background:#C5D6BF;flex:none;transition:.3s}
.legend .dot.on{background:var(--green);box-shadow:0 0 0 3px #1e9e4a22}
.legend .nm{color:var(--mut);min-width:0} .legend .nm b{color:var(--ink);font-weight:500}
.legend .sc{margin-left:auto;color:var(--mut-2);font-variant-numeric:tabular-nums;font-size:12px}

/* ── Toast ── */
.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(160%);
background:#E7F7EC;border:1px solid var(--green);color:var(--green-deep);padding:13px 20px;border-radius:13px;
font-size:14px;font-weight:500;box-shadow:var(--shadow);transition:.4s;z-index:60}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ── Confirmation overlay ── */
.overlay{position:fixed;inset:0;background:#0e2014cc;backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:80;padding:22px}
.overlay.show{display:flex;animation:fade .35s ease}
.confirm{max-width:520px;width:100%;text-align:center;background:var(--card);border:1px solid var(--line);border-radius:22px;padding:38px 32px;box-shadow:0 30px 70px -20px rgba(10,40,18,.5)}
.confirm .spark{font-size:30px;color:var(--gold);line-height:1}
.confirm h2{font-weight:600;font-size:24px;color:var(--ink);margin:10px 0 14px}
.confirm p{font-weight:300;color:var(--body);margin:0 0 14px}
.confirm .tag{font-weight:600;color:var(--green-deep);margin:18px 0 4px}
.confirm .acts{display:flex;gap:12px;justify-content:center;margin-top:18px;flex-wrap:wrap}

/* ── Leadership gate ── */
.gate{max-width:440px;margin:7vh auto;text-align:center;width:100%}
.gate h2{font-weight:600;font-size:26px;margin:0 0 6px;color:var(--ink)}
.gate p{color:var(--mut);font-weight:300;margin:0 0 18px}
.gate .acts{display:flex;gap:12px;margin-top:14px;flex-wrap:wrap}
.gate .acts .btn{flex:1;min-width:0}
.gate .default{margin-top:16px;font-size:12px;color:var(--mut-2)}
.gate .err{color:#C0392B;font-size:13px;min-height:18px;margin-top:10px}

/* ── Report ── */
.report{display:none} .report.active{display:block}
.seatstrip{display:flex;flex-wrap:wrap;gap:10px 26px;align-items:center;background:var(--card-soft);border:1px solid var(--line);border-radius:14px;padding:14px 20px;margin-bottom:24px}
.seatstrip .it{font-size:13px;color:var(--mut)} .seatstrip .it b{color:var(--ink);font-weight:600;font-variant-numeric:tabular-nums}
.seatstrip .bar{flex:1;min-width:120px;height:8px;border-radius:6px;background:#E2EDDC;overflow:hidden}
.seatstrip .bar i{display:block;height:100%;background:linear-gradient(90deg,var(--green-deep),var(--green));font-style:normal}

.rep-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:24px;align-items:start}
.bigflower{display:flex;flex-direction:column;align-items:center;text-align:center}
.bigflower .flower-wrap{width:300px;height:300px}
.bigflower .pct b{font-size:42px}
.scorelist{display:grid;gap:11px;margin-top:6px}
.scoreline{display:grid;grid-template-columns:120px 1fr 40px;align-items:center;gap:12px}
.scoreline .lab{font-size:13px;color:var(--mut)} .scoreline .lab b{color:var(--ink);font-weight:500}
.scoreline .track{height:9px;border-radius:6px;background:#E2EDDC;overflow:hidden}
.scoreline .track i{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,var(--green-deep),var(--green));transition:width 1s cubic-bezier(.2,.8,.2,1);font-style:normal}
.scoreline.gap .track i{background:linear-gradient(90deg,var(--gold-deep),var(--gold))}
.scoreline .val{text-align:right;font-variant-numeric:tabular-nums;font-weight:600;font-size:14px;color:var(--ink)}
.scoreline.gap .val{color:var(--gold-deep)}

/* ── Panel / Gap cards ── */
.panel{margin-top:24px}
.panel h3{font-size:13px;letter-spacing:2px;text-transform:uppercase;color:var(--mut);font-weight:600;margin:0 0 14px}
.gaps{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.gapcard{background:var(--gold-bg);border:1px solid var(--gold-line);border-radius:14px;padding:16px}
.gapcard .rk{font-size:11px;letter-spacing:1px;color:var(--gold-deep);font-weight:600;text-transform:uppercase}
.gapcard .nm{font-size:18px;font-weight:600;margin:4px 0 2px;color:var(--ink)}
.gapcard .vv{font-size:12px;color:var(--mut)}

/* ── Respondent chips ── */
.resp{display:flex;flex-wrap:wrap;gap:8px}
.chip{font-size:12px;background:var(--card-soft);border:1px solid var(--line);color:var(--mut);padding:6px 12px;border-radius:999px;display:inline-flex;align-items:center;gap:6px;flex-wrap:wrap}
.chip b{color:var(--ink);font-weight:500}
.chiptitle{font-size:11px;letter-spacing:.5px;text-transform:uppercase;color:var(--mut-2);font-weight:600}
.chipval{font-size:16px;font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums}

/* ── Mix (nation/sector) ── */
.mix{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.mixbox h4{margin:0 0 10px;font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--mut);font-weight:600}
.mixrow{display:grid;grid-template-columns:130px 1fr 30px;align-items:center;gap:10px;margin-bottom:8px;font-size:13px}
.mixrow .ml{color:var(--ink)} .mixrow .mt{height:8px;border-radius:5px;background:#E2EDDC;overflow:hidden}
.mixrow .mt i{display:block;height:100%;background:linear-gradient(90deg,var(--green-deep),var(--green-bright));font-style:normal}
.mixrow .mv{text-align:right;color:var(--mut);font-variant-numeric:tabular-nums}

/* ── Pathway rings ── */
.pathway{background:#E9F4E3;border:1px solid var(--line);border-radius:16px;padding:24px;margin-top:24px}
.rings{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:18px 0}
.ring{position:relative;background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;text-align:center}
.ring .ico{width:46px;height:46px;border-radius:50%;margin:0 auto 10px;display:grid;place-items:center;border:5px solid var(--green)}
.ring .ico b{width:18px;height:18px;border-radius:50%;font-weight:700;display:block}
.ring.green .ico b{background:transparent}
.ring.orange .ico b{background:var(--gold)}
.ring.yellow .ico b{background:var(--yellow)}
.ring .rl{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;font-weight:600}
.ring.green .rl{color:var(--green-deep)} .ring.orange .rl{color:var(--gold-deep)} .ring.yellow .rl{color:#9a7e08}
.ring .rt{font-size:14px;font-weight:600;margin:3px 0 0;color:var(--ink)}
.ring .rd{font-size:11.5px;color:var(--mut);margin-top:5px;font-weight:300}
.ring.here::after{content:"YOU ARE HERE";position:absolute;top:-9px;left:50%;transform:translateX(-50%);
background:var(--green);color:#fff;font-size:9px;font-weight:700;letter-spacing:1px;padding:3px 9px;border-radius:999px;white-space:nowrap}
.ring.next{border-color:var(--gold)}
.cta{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:14px;margin-top:6px}
.cta p{margin:0;font-weight:300;color:var(--body);max-width:50ch}
.cta p b{color:var(--gold-deep);font-weight:600}

/* ── Empty state ── */
.empty{text-align:center;padding:56px 20px;color:var(--mut)}
.empty .ring0{width:64px;height:64px;border-radius:50%;border:3px solid var(--line);margin:0 auto 18px;box-shadow:0 0 0 7px #1e9e4a0f}
.empty h2{color:var(--ink);font-weight:600;font-size:24px;margin:0 0 8px}
.empty p{font-weight:300;max-width:42ch;margin:0 auto 20px}

/* ── Footer ── */
footer{border-top:1px solid var(--line);color:var(--mut-2);font-size:12px;padding:22px 0;text-align:center}
footer b{color:var(--mut);font-weight:600}

/* ── Form fields ── */
input[type=text],input[type=email],input[type=password],input[type=number],select,textarea{
width:100%;font-family:inherit;font-size:14px;color:var(--ink);background:#fff;
border:1px solid var(--line);border-radius:11px;padding:11px 13px;appearance:none;outline:none;min-height:44px}
textarea{resize:vertical}
input::placeholder,textarea::placeholder{color:#9CAE97}
input:focus,select:focus,textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px #1e9e4a1f}

/* ── Error messages ── */
.err{color:#C0392B;font-size:13px;margin-top:6px}

/* ── Scroll wrapper for tables ── */
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}

/* ── Animations ── */
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ── Print ── */
@media print{
  header,.no-print{display:none!important}
  body{background:#fff}
}

/* ── Tablet: 768px–1024px ── */
@media(min-width:768px) and (max-width:1024px){
  .wrap{max-width:900px;padding:0 28px}
  header{padding:0 28px}
  .card{padding:24px 22px}
}

/* ── Tablet: 860px and below ── */
@media(max-width:860px){
  .staff-grid{grid-template-columns:1fr}
  .flowerpanel{position:static;order:-1}
  .rep-grid{grid-template-columns:1fr}
  .gaps,.rings,.mix{grid-template-columns:1fr}
  nav button{padding:9px 12px}
  .card{padding:22px 20px}
  .bigflower .flower-wrap{width:260px;height:260px}
  .bigflower .pct b{font-size:36px}
  .pathway{padding:20px}
  .pathway .rings{grid-template-columns:1fr;gap:12px}
  .hero h1{text-align:center}
  .hero .lede{text-align:center}
}

/* ── Mobile: 560px and below ── */
@media(max-width:560px){
  .wrap{padding:0 16px}
  header{padding:0 16px}
  h1{font-size:28px;letter-spacing:-0.5px}
  .eyebrow{letter-spacing:2px}
  .lede{font-size:14px}
  .card{padding:18px 16px}
  .btn{padding:12px 16px;font-size:13px}

  /* Scale / Likert buttons */
  .scale{gap:5px}
  .scale button{padding:8px 2px;font-size:11px;min-height:40px}

  /* Score lines */
  .scoreline{grid-template-columns:84px 1fr 34px;gap:8px}
  .scoreline .lab,.legend .nm{min-width:0}

  /* Mix rows */
  .mixrow{grid-template-columns:92px 1fr 26px}

  /* Seat strip */
  .seatstrip{gap:8px 18px;padding:13px 16px}

  /* Gate / Login */
  .gate{margin:4vh auto;padding:0 4px}
  .gate h2{font-size:22px}
  .gate .acts{flex-direction:column}
  .gate .acts .btn{width:100%}

  /* Confirm overlay */
  .confirm{padding:28px 20px;border-radius:18px}
  .confirm h2{font-size:20px}
  .confirm .acts{flex-direction:column}
  .confirm .acts .btn,.confirm .acts .btn{width:100%}

  /* Flower */
  .flower-wrap{width:200px;height:200px}
  .bigflower .flower-wrap{width:220px;height:220px}
  .bigflower .pct b{font-size:30px}
  .letters span{font-size:13px}

  /* Pathway */
  .pathway{padding:18px 14px}
  .pathway .rings{gap:10px}
  .ring{padding:14px 12px}

  /* Hero */
  .hero h1{text-align:center;font-size:clamp(24px,5vw,36px)}
  .hero .lede{text-align:center}
  .hero-ctas .btn{min-width:140px;font-size:13px}

  /* Steps */
  .step{padding:22px 18px}
  .step::before{width:32px;height:32px;font-size:14px}

  /* Questionnaire form grid */
  .domain form > div[style*="grid-template-columns:1fr 2fr"]{grid-template-columns:1fr !important}
}

/* ── Extra small: 400px and below ── */
@media(max-width:400px){
  .scale{grid-template-columns:repeat(5,1fr);gap:4px}
  .scale button{padding:7px 1px;font-size:10px;min-height:38px}
  .scoreline{grid-template-columns:72px 1fr 30px;gap:6px}
  .mixrow{grid-template-columns:80px 1fr 24px;font-size:12px}
  .seatstrip .it{font-size:12px}
  .bigflower .flower-wrap{width:180px;height:180px}
}

@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ══════════════════════════════════════════════════
   ADMIN PANEL — 3-Zone Layout
   ══════════════════════════════════════════════════ */

/* ── NUCLEAR RESET: Override ALL blloom.css conflicts ── */
body.admin-layout,
body.admin-layout *,
body.admin-layout *::before,
body.admin-layout *::after {
  background-image: none !important;
  transform: none !important;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
}

body.admin-layout {
  background: #f4f6f9 !important;
  background-attachment: scroll !important;
  overflow-x: auto !important;
}

body.admin-layout .ringbar { display: none !important; }
body.admin-layout header { display: none !important; }

/* ── Layout Shell ── */
body.admin-layout {
  display: flex;
  min-height: 100vh;
  font-family: 'Poppins', system-ui, sans-serif;
  color: #2C3F31;
  line-height: 1.55;
}

/* ══════════════════════════════════════════
   SIDEBAR — Solid dark, horizontal text
   ══════════════════════════════════════════ */
.admin-sidebar {
  width: 260px !important;
  min-width: 260px !important;
  max-width: 260px !important;
  background: #14271B !important;
  color: #94a3b8 !important;
  display: flex !important;
  flex-direction: column !important;
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  bottom: 0 !important;
  z-index: 40 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  text-align: left !important;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
}

/* Sidebar Brand */
.admin-sidebar-brand {
  padding: 24px 24px 20px !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  border: none !important;
  border-radius: 0 !important;
  background: transparent !important;
}
.admin-sidebar-brand .brand-icon {
  width: 36px !important;
  height: 36px !important;
  border-radius: 10px !important;
  background: #1E9E4A !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
}
.admin-sidebar-brand .brand-icon svg {
  width: 22px !important;
  height: 22px !important;
  color: #fff !important;
}
.admin-sidebar-brand .brand-text {
  font-weight: 700 !important;
  font-size: 18px !important;
  color: #fff !important;
  letter-spacing: .3px !important;
  writing-mode: horizontal-tb !important;
}
.admin-sidebar-brand .brand-tm {
  font-size: .5em !important;
  vertical-align: super !important;
  font-weight: 500 !important;
  color: #64748b !important;
}

/* ══════════════════════════════════════════
   SIDEBAR NAV — Each item is icon + text, horizontal
   ══════════════════════════════════════════ */
.admin-sidebar nav.admin-sidebar-nav {
  flex: 1 !important;
  padding: 8px 12px !important;
  display: block !important;
  flex-direction: unset !important;
  gap: 0 !important;
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  margin: 0 !important;
  writing-mode: horizontal-tb !important;
}

.admin-sidebar nav.admin-sidebar-nav a {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 10px 12px !important;
  color: #94a3b8 !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  text-decoration: none !important;
  transition: background .15s, color .15s !important;
  border-radius: 8px !important;
  margin-bottom: 2px !important;
  border-left: 3px solid transparent !important;
  border-right: none !important;
  border-top: none !important;
  border-bottom: none !important;
  width: 100% !important;
  box-sizing: border-box !important;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
  white-space: nowrap !important;
  text-align: left !important;
  flex-wrap: nowrap !important;
}
.admin-sidebar nav.admin-sidebar-nav a:hover {
  background: rgba(255,255,255,.06) !important;
  color: #e2e8f0 !important;
}
.admin-sidebar nav.admin-sidebar-nav a.active {
  background: rgba(30,158,74,.15) !important;
  color: #1E9E4A !important;
  border-left-color: #C2871C !important;
  font-weight: 600 !important;
}
.admin-sidebar nav.admin-sidebar-nav a svg {
  width: 20px !important;
  height: 20px !important;
  flex-shrink: 0 !important;
  opacity: .6 !important;
}
.admin-sidebar nav.admin-sidebar-nav a.active svg {
  opacity: 1 !important;
  color: #1E9E4A !important;
}

/* Sidebar Footer */
.admin-sidebar-footer {
  padding: 12px !important;
  border-top: 1px solid #1e293b !important;
  margin-top: auto !important;
}
.admin-sidebar-footer form {
  margin: 0 !important;
}
.admin-sidebar-footer button {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  width: 100% !important;
  padding: 10px 12px !important;
  color: #94a3b8 !important;
  font-family: inherit !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  background: transparent !important;
  border: none !important;
  cursor: pointer !important;
  text-align: left !important;
  transition: background .15s, color .15s !important;
  border-radius: 8px !important;
  writing-mode: horizontal-tb !important;
}
.admin-sidebar-footer button:hover {
  background: rgba(255,255,255,.06) !important;
  color: #e2e8f0 !important;
}
.admin-sidebar-footer button svg {
  width: 20px !important;
  height: 20px !important;
  flex-shrink: 0 !important;
  opacity: .6 !important;
}

/* ══════════════════════════════════════════
   MAIN AREA — Right of sidebar
   ══════════════════════════════════════════ */
.admin-main {
  flex: 1 !important;
  margin-left: 260px !important;
  display: flex !important;
  flex-direction: column !important;
  min-height: 100vh !important;
}

/* ── Topbar ── */
.admin-topbar {
  background: #fff !important;
  border-bottom: 1px solid #D3E3CC !important;
  padding: 0 32px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  height: 60px !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 30 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}
.admin-topbar-left {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
}
.admin-topbar-title {
  font-size: 16px !important;
  font-weight: 600 !important;
  color: #14271B !important;
}
.admin-topbar-right {
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
}
.admin-topbar-user {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  font-size: 14px !important;
  color: #2C3F31 !important;
  font-weight: 500 !important;
}
.admin-topbar-user .avatar {
  width: 36px !important;
  height: 36px !important;
  border-radius: 50% !important;
  background: #1E9E4A !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #fff !important;
  font-size: 14px !important;
  font-weight: 600 !important;
}
.admin-topbar-logout {
  font-family: inherit !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  color: #5F7065 !important;
  background: transparent !important;
  border: 1px solid #D3E3CC !important;
  padding: 7px 14px !important;
  border-radius: 8px !important;
  cursor: pointer !important;
  transition: background .15s, color .15s !important;
  text-decoration: none !important;
}
.admin-topbar-logout:hover {
  background: #F6FBF3 !important;
  color: #14271B !important;
  border-color: #cbd5e1 !important;
}

/* ── Mobile Toggle ── */
.admin-toggle {
  display: none !important;
  align-items: center !important;
  justify-content: center !important;
  background: transparent !important;
  border: none !important;
  color: #14271B !important;
  font-size: 20px !important;
  cursor: pointer !important;
  padding: 10px !important;
  border-radius: 8px !important;
  line-height: 1 !important;
  width: 44px !important;
  height: 44px !important;
  flex-shrink: 0 !important;
}
.admin-toggle:hover {
  background: #F6FBF3 !important;
}
.admin-toggle svg {
  width: 22px !important;
  height: 22px !important;
}
.admin-overlay {
  display: none !important;
  position: fixed !important;
  inset: 0 !important;
  background: rgba(0,0,0,.5) !important;
  z-index: 39 !important;
  backdrop-filter: blur(2px) !important;
}

/* ══════════════════════════════════════════
   CONTENT AREA
   ══════════════════════════════════════════ */
.admin-body {
  flex: 1 !important;
  padding: 28px 32px !important;
  width: 100% !important;
  max-width: 1400px !important;
}
.admin-body h1 {
  font-weight: 300 !important;
  font-size: clamp(22px,3.5vw,32px) !important;
  margin: 0 0 6px !important;
  letter-spacing: -0.5px !important;
  color: #14271B !important;
  line-height: 1.2 !important;
}
.admin-body h1 b {
  font-weight: 700 !important;
  color: #1E9E4A !important;
}
.admin-body .subtitle {
  color: #5F7065 !important;
  font-size: 14px !important;
  margin: 0 0 24px !important;
}

/* ── Admin Table ── */
.admin-table { width: 100%; border-collapse: collapse; }
.admin-table th {
  text-align: left; font-size: 11px; letter-spacing: 1px;
  text-transform: uppercase; color: #5F7065; font-weight: 600;
  padding: 0 14px 10px; border-bottom: 1px solid #D3E3CC;
}
.admin-table td {
  padding: 12px 14px; border-bottom: 1px solid #E2ECDC;
  font-size: 14px; color: #2C3F31; vertical-align: middle;
}
.admin-table tr:hover td { background: #F6FBF3; }
.admin-table .name { font-weight: 600; color: #14271B; }
.admin-table .code { font-family: monospace; font-size: 15px; font-weight: 600; color: #1E9E4A; letter-spacing: 1px; }
.admin-table .actions { display: flex; gap: 6px; flex-wrap: wrap; }
.admin-table .actions a, .admin-table .actions button {
  font-family: inherit; font-size: 12px; font-weight: 600;
  padding: 6px 12px; border-radius: 8px; cursor: pointer;
  transition: .15s; text-decoration: none; border: 0;
}
.admin-table .edit-btn { background: #E7F1E1; color: #15793A; border: 1px solid #D3E3CC; }
.admin-table .edit-btn:hover { border-color: #1E9E4A; }
.admin-table .toggle-btn { background: #FBF4E0; color: #9E6E14; border: 1px solid #EAD6A2; }
.admin-table .toggle-btn:hover { background: #F5ECD0; }
.admin-table .toggle-btn.inactive { background: #FDE8E8; color: #C0392B; border: 1px solid #F0C0C0; }
.admin-table .regen-btn { background: #F0F0F0; color: #555; border: 1px solid #DDD; }
.admin-table .regen-btn:hover { background: #E8E8E8; }

/* ── Status Badges ── */
.status-active { display: inline-flex; align-items: center; gap: 5px; font-size: 12px; font-weight: 600; color: #15793A; }
.status-active::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: #1E9E4A; }
.status-inactive { display: inline-flex; align-items: center; gap: 5px; font-size: 12px; font-weight: 600; color: #C0392B; }
.status-inactive::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: #C0392B; }

/* ── Admin Card ── */
.admin-card {
  background: #fff !important;
  border: 1px solid #D3E3CC !important;
  border-radius: 12px !important;
  padding: 24px !important;
  box-shadow: 0 1px 3px rgba(0,0,0,.04) !important;
}
.admin-card h2 { font-size: 16px; font-weight: 600; color: #14271B; margin: 0 0 16px; }

/* ── Admin Forms ── */
.field { margin-bottom: 16px; }
.field label { display: block; font-size: 12px; font-weight: 600; color: #5F7065; letter-spacing: .5px; margin-bottom: 5px; }
.field input, .field select { width: 100%; }
.flash-success { background: #E7F7EC; border: 1px solid #1E9E4A; color: #15793A; padding: 12px 18px; border-radius: 12px; font-size: 14px; font-weight: 500; margin-bottom: 20px; }
.flash-error { background: #FDE8E8; border: 1px solid #E0A0A0; color: #C0392B; padding: 12px 18px; border-radius: 12px; font-size: 14px; font-weight: 500; margin-bottom: 20px; }
.btn-row { display: flex; gap: 10px; margin-top: 18px; }
.btn-sm { font-size: 13px; padding: 10px 18px; border-radius: 10px; }
.code-display { background: #F6FBF3; border: 2px dashed #1E9E4A; border-radius: 14px; padding: 24px; text-align: center; margin: 20px 0; }
.code-display .label { font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; color: #5F7065; font-weight: 600; margin-bottom: 8px; }
.code-display .code { font-family: monospace; font-size: 32px; font-weight: 700; color: #1E9E4A; letter-spacing: 3px; }
.code-display .hint { font-size: 12px; color: #5F7065; margin-top: 8px; font-style: italic; }
.detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.detail-item .label { font-size: 11px; letter-spacing: 1px; text-transform: uppercase; color: #5F7065; font-weight: 600; margin-bottom: 3px; }
.detail-item .value { font-size: 15px; font-weight: 600; color: #14271B; }

/* ══════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════ */

/* Tablet — sidebar visible, content pushed right */
@media(max-width:1024px){
  .admin-sidebar { width: 260px !important; min-width: 260px !important; max-width: 260px !important; left: 0 !important; }
  .admin-main { margin-left: 260px !important; }
  .admin-body { padding: 24px 20px !important; }
  .admin-toggle { display: none !important; }
}

/* Mobile — sidebar hidden, hamburger toggle visible */
@media(max-width:768px){
  .admin-sidebar {
    left: -280px !important;
    transition: left .3s ease !important;
  }
  .admin-sidebar.open { left: 0 !important; }
  .admin-overlay.show { display: block !important; }
  .admin-toggle { display: flex !important; align-items: center !important; justify-content: center !important; width: 44px !important; height: 44px !important; }
  .admin-main { margin-left: 0 !important; }
  .admin-topbar { padding: 0 16px !important; }
  .admin-body { padding: 20px 16px !important; }
  .admin-table { font-size: 13px; }
  .admin-table td, .admin-table th { padding: 10px 8px; }
  .detail-grid { grid-template-columns: 1fr; }
  .code-display .code { font-size: 22px; }
}

@media(max-width:480px){
  .admin-body { padding: 16px 12px !important; }
  .admin-card { padding: 16px !important; }
  .btn-row { flex-direction: column; }
  .btn-row .btn { width: 100%; }
}
