/* =================================================================
   MPG — Marshal Paragon Global Ent-Attainment
   Design system: premium light, sports-federation feel
   ================================================================= */
:root{
  --primary:#0f766e; --primary-dark:#0b5e58; --primary-light:#14b8a6; --primary-50:#f0fdfa;
  --secondary:#f59e0b; --secondary-dark:#d97706; --secondary-50:#fffbeb;
  --bg:#f8fafc; --card:#ffffff; --text:#0f172a; --muted:#64748b; --border:#e2e8f0;
  --danger:#dc2626; --success:#16a34a; --info:#2563eb;
  --radius:16px; --radius-sm:10px; --radius-lg:24px;
  --shadow-sm:0 1px 2px rgba(15,23,42,.06);
  --shadow:0 1px 3px rgba(15,23,42,.07),0 10px 30px rgba(15,23,42,.07);
  --shadow-lg:0 20px 50px rgba(15,23,42,.14);
  --font-head:'Poppins',system-ui,sans-serif; --font-body:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.6;font-size:16px}
h1,h2,h3,h4,h5{font-family:var(--font-head);line-height:1.2;color:var(--text);font-weight:700}
a{color:var(--primary);text-decoration:none;transition:color .2s}
a:hover{color:var(--primary-dark)}
img{max-width:100%;display:block}
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 18px}
section{padding:56px 0}
.section-head{text-align:center;max-width:680px;margin:0 auto 36px}
.section-head .eyebrow{display:inline-block;font-family:var(--font-head);font-weight:600;color:var(--secondary-dark);letter-spacing:.12em;text-transform:uppercase;font-size:.78rem;margin-bottom:10px}
.section-head h2{font-size:clamp(1.6rem,4vw,2.3rem)}
.section-head p{color:var(--muted);margin-top:10px}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-head);font-weight:600;font-size:.95rem;padding:12px 22px;border-radius:999px;border:1px solid transparent;cursor:pointer;transition:all .2s;white-space:nowrap;line-height:1}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-dark);color:#fff}
.btn-secondary{background:var(--secondary);color:#fff}
.btn-secondary:hover{background:var(--secondary-dark);color:#fff}
.btn-ghost{background:transparent;color:var(--text);border-color:var(--border)}
.btn-ghost:hover{background:var(--bg);border-color:var(--primary);color:var(--primary)}
.btn-light{background:#fff;color:var(--primary)}
.btn-light:hover{background:#f1f5f9}
.btn-outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn-outline-light:hover{background:rgba(255,255,255,.15);color:#fff}
.btn-block{width:100%}
.btn-sm{padding:9px 16px;font-size:.85rem}
.btn-lg{padding:15px 30px;font-size:1.05rem}

/* ---------- Header / Nav ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}
.nav-bar{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{display:flex;align-items:center;gap:11px;color:var(--text)}
.brand-mark{background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;font-family:var(--font-head);font-weight:800;border-radius:10px;width:42px;height:42px;display:grid;place-items:center;font-size:1rem;letter-spacing:.02em;box-shadow:var(--shadow-sm)}
.brand-text strong{display:block;font-family:var(--font-head);font-size:.98rem;line-height:1.1}
.brand-text small{display:block;color:var(--muted);font-size:.72rem}
.brand-sm strong{font-family:var(--font-head)}
.nav-menu{display:flex;align-items:center;gap:18px}
.nav-links{display:flex;align-items:center;gap:4px;list-style:none}
.nav-links a{display:block;padding:9px 13px;border-radius:8px;color:var(--text);font-weight:500;font-size:.94rem}
.nav-links a:hover{color:var(--primary);background:var(--primary-50)}
.nav-links a.is-active{color:var(--primary);background:var(--primary-50);font-weight:600}
.nav-actions{display:flex;align-items:center;gap:10px}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:24px;height:2px;background:var(--text);border-radius:2px;transition:.25s}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-account{position:relative}
.account-btn{display:flex;align-items:center;gap:8px}
.avatar{width:30px;height:30px;border-radius:50%;background:var(--primary);color:#fff;display:grid;place-items:center;font-weight:700;font-size:.82rem;font-family:var(--font-head)}
.account-menu{position:absolute;right:0;top:calc(100% + 10px);background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-lg);min-width:190px;padding:7px;display:none;flex-direction:column}
.account-menu.open{display:flex}
.account-menu a{padding:10px 13px;border-radius:8px;color:var(--text);font-size:.9rem;font-weight:500}
.account-menu a:hover{background:var(--bg);color:var(--primary)}
.account-menu .admin-link{color:var(--secondary-dark);font-weight:600}
.account-menu .logout-link{color:var(--danger)}

/* ---------- Cards ---------- */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:transform .25s,box-shadow .25s}
.cards-grid{display:grid;grid-template-columns:1fr;gap:20px}
.contestant-card:hover,.contest-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.contestant-photo{position:relative;display:block;aspect-ratio:3/4;overflow:hidden;border-radius:var(--radius) var(--radius) 0 0;background:var(--bg)}
.contestant-photo img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.contestant-card:hover .contestant-photo img{transform:scale(1.05)}
.contestant-no{position:absolute;left:10px;bottom:10px;background:rgba(15,23,42,.7);color:#fff;font-family:var(--font-head);font-weight:700;padding:4px 11px;border-radius:999px;font-size:.8rem}
.rank-badge{position:absolute;right:10px;top:10px;font-size:1.4rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}
.contestant-body{padding:16px}
.contestant-body h3{font-size:1.05rem;margin-bottom:8px}
.contestant-body h3 a{color:var(--text)}
.contestant-meta{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.chip{font-size:.74rem;background:var(--bg);border:1px solid var(--border);padding:3px 9px;border-radius:999px;color:var(--muted);font-weight:500}
.chip-amber{background:var(--secondary-50);border-color:#fde68a;color:var(--secondary-dark)}
.contestant-votes{display:flex;align-items:baseline;gap:6px;margin-bottom:13px;padding:10px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.vote-count{font-family:var(--font-head);font-weight:800;font-size:1.35rem;color:var(--primary)}
.vote-label{font-size:.82rem;color:var(--muted)}

/* contest card */
.contest-card{display:block;overflow:hidden;color:var(--text)}
.contest-banner{position:relative;aspect-ratio:16/9;overflow:hidden}
.contest-banner img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.contest-card:hover .contest-banner img{transform:scale(1.05)}
.status-badge{position:absolute;top:10px;left:10px;font-size:.72rem;font-weight:700;padding:4px 11px;border-radius:999px;text-transform:uppercase;letter-spacing:.05em;color:#fff}
.status-active{background:var(--success)}
.status-upcoming{background:var(--secondary)}
.status-ended{background:var(--muted)}
.prize-tag{position:absolute;bottom:10px;right:10px;background:rgba(15,23,42,.75);color:#fff;font-weight:700;font-size:.8rem;padding:5px 11px;border-radius:999px}
.contest-body{padding:16px}
.contest-body h3{font-size:1.1rem;margin-bottom:6px}
.contest-body p{color:var(--muted);font-size:.9rem;margin-bottom:12px}
.contest-link{color:var(--primary);font-weight:600;font-size:.88rem}

/* ---------- Hero ---------- */
.hero{position:relative;color:#fff;padding:0;overflow:hidden;background:#0b5e58}
.hero-bg{position:absolute;inset:0;background:linear-gradient(120deg,#0f766e 0%,#0b5e58 45%,#0e4f54 100%)}
.hero-bg::after{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 80% 20%,rgba(245,158,11,.25),transparent 40%),radial-gradient(circle at 10% 90%,rgba(20,184,166,.3),transparent 45%)}
.hero-inner{position:relative;z-index:2;padding:64px 0 70px}
.hero .eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);padding:7px 15px;border-radius:999px;font-size:.8rem;font-weight:600;letter-spacing:.05em;margin-bottom:18px}
.hero h1{font-size:clamp(2rem,6vw,3.6rem);font-weight:800;line-height:1.08;max-width:780px}
.hero p.lead{font-size:clamp(1.05rem,2.5vw,1.3rem);color:rgba(255,255,255,.9);margin:16px 0 28px;max-width:600px}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px}

/* ---------- Stats ---------- */
.stats-strip{position:relative;z-index:3;margin-top:-38px}
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow)}
.stat{display:flex;flex-direction:column;align-items:center;text-align:center;padding:8px}
.stat-num{font-family:var(--font-head);font-weight:800;font-size:clamp(1.4rem,4vw,2rem);color:var(--primary);line-height:1}
.stat-lbl{color:var(--muted);font-size:.82rem;margin-top:5px;font-weight:500}

/* ---------- How voting works ---------- */
.steps-grid{display:grid;grid-template-columns:1fr;gap:18px}
.step{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:24px;position:relative}
.step .num{width:42px;height:42px;border-radius:12px;background:var(--primary-50);color:var(--primary);font-family:var(--font-head);font-weight:800;display:grid;place-items:center;margin-bottom:14px;font-size:1.1rem}
.step h3{font-size:1.08rem;margin-bottom:6px}
.step p{color:var(--muted);font-size:.92rem}

/* ---------- Packages ---------- */
.pkg-grid{display:grid;grid-template-columns:1fr;gap:18px}
.pkg{background:#fff;border:2px solid var(--border);border-radius:var(--radius);padding:26px 22px;text-align:center;position:relative;transition:.2s}
.pkg:hover{border-color:var(--primary-light);transform:translateY(-3px)}
.pkg.featured{border-color:var(--secondary);box-shadow:var(--shadow)}
.pkg-tag{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--secondary);color:#fff;font-size:.72rem;font-weight:700;padding:4px 14px;border-radius:999px;text-transform:uppercase}
.pkg-votes{font-family:var(--font-head);font-weight:800;font-size:2.2rem;color:var(--primary)}
.pkg-votes small{font-size:.9rem;color:var(--muted);font-weight:500}
.pkg-price{font-size:1.3rem;font-weight:700;margin:6px 0 16px}

/* ---------- Countdown ---------- */
.countdown{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.cd-unit{background:linear-gradient(135deg,#0f766e,#0e4f54);color:#fff;border-radius:14px;padding:14px 8px;min-width:72px;text-align:center;box-shadow:var(--shadow-sm)}
.cd-num{font-family:var(--font-head);font-weight:800;font-size:1.7rem;line-height:1}
.cd-lbl{font-size:.7rem;opacity:.85;text-transform:uppercase;letter-spacing:.08em;margin-top:5px}

/* ---------- Leaderboard ---------- */
.lb{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.lb-row{display:grid;grid-template-columns:46px 1fr auto;gap:12px;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border)}
.lb-row:last-child{border-bottom:0}
.lb-row .pos{font-family:var(--font-head);font-weight:800;font-size:1.1rem;color:var(--muted)}
.lb-row.top-1 .pos,.lb-row.top-2 .pos,.lb-row.top-3 .pos{color:var(--primary)}
.lb-row .who{display:flex;align-items:center;gap:11px;min-width:0}
.lb-row .who img{width:42px;height:42px;border-radius:50%;object-fit:cover}
.lb-row .who b{display:block;font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lb-row .who span{font-size:.78rem;color:var(--muted)}
.lb-row .total{font-family:var(--font-head);font-weight:800;color:var(--primary)}

/* ---------- Forms ---------- */
.form-grid{display:grid;grid-template-columns:1fr;gap:14px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-label{font-weight:600;font-size:.88rem;color:var(--text)}
.form-label .req{color:var(--danger)}
.form-control,.form-select,.form-textarea{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.95rem;background:#fff;transition:.2s;color:var(--text)}
.form-control:focus,.form-select:focus,.form-textarea:focus{outline:0;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-50)}
.form-textarea{resize:vertical;min-height:120px}
.form-hint{font-size:.78rem;color:var(--muted)}
.field-row{display:grid;grid-template-columns:1fr;gap:14px}

/* multi-step */
.auth-card{max-width:640px;margin:0 auto;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:30px 26px}
.steps-bar{display:flex;gap:6px;margin-bottom:26px;counter-reset:s}
.steps-bar .s{flex:1;height:5px;background:var(--border);border-radius:999px;position:relative}
.steps-bar .s.done{background:var(--primary)}
.steps-bar .s.active{background:var(--secondary)}
.step-panel{display:none;animation:fade .3s ease}
.step-panel.is-active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.steps-actions{display:flex;justify-content:space-between;gap:10px;margin-top:22px}
.helper-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:14px;font-size:.88rem;color:var(--muted)}

/* ---------- Flash ---------- */
.flash-wrap{margin-top:14px}
.flash{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 16px;border-radius:12px;margin-bottom:10px;font-size:.92rem;font-weight:500;border:1px solid transparent}
.flash-success{background:#f0fdf4;color:#166534;border-color:#bbf7d0}
.flash-error{background:#fef2f2;color:#991b1b;border-color:#fecaca}
.flash-info{background:#eff6ff;color:#1e40af;border-color:#bfdbfe}
.flash-warning{background:#fffbeb;color:#92400e;border-color:#fde68a}
.flash-close{background:none;border:0;font-size:1.3rem;line-height:1;cursor:pointer;color:inherit;opacity:.6}
.flash-close:hover{opacity:1}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(120deg,var(--primary),var(--primary-dark));color:#fff}
.cta-inner{display:flex;flex-direction:column;gap:20px;text-align:center;padding:48px 0}
.cta-inner h2{color:#fff;font-size:clamp(1.5rem,4vw,2.1rem)}
.cta-inner p{color:rgba(255,255,255,.9);margin-top:6px}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ---------- Footer ---------- */
.site-footer{background:#0f172a;color:#cbd5e1;padding:0}
.footer-grid{display:grid;grid-template-columns:1fr;gap:30px;padding:48px 0 30px}
.footer-about .brand-mark{display:inline-grid;margin-bottom:12px}
.footer-col h4{color:#fff;font-size:1.05rem;margin-bottom:6px}
.footer-col h5{color:#fff;font-size:.95rem;margin-bottom:12px;font-family:var(--font-head)}
.footer-col a{display:block;color:#cbd5e1;padding:5px 0;font-size:.9rem}
.footer-col a:hover{color:#fff}
.footer-about p{font-size:.9rem;margin-top:6px}
.footer-contact{margin-top:10px;color:var(--secondary);font-weight:600}
.newsletter{display:flex;gap:8px;margin-top:8px}
.newsletter input{flex:1;padding:11px 13px;border-radius:10px;border:1px solid #334155;background:#1e293b;color:#fff}
.newsletter input::placeholder{color:#94a3b8}
.footer-bottom{border-top:1px solid #1e293b;padding:16px 0}
.footer-bottom .container{display:flex;flex-direction:column;gap:8px;align-items:center;text-align:center;font-size:.84rem;color:#94a3b8}
.pay-badges{color:#64748b}

/* ---------- Badges / pills ---------- */
.pill{display:inline-flex;align-items:center;gap:6px;background:var(--primary-50);color:var(--primary-dark);font-weight:600;font-size:.78rem;padding:5px 12px;border-radius:999px}
.badge-amber{background:var(--secondary-50);color:var(--secondary-dark)}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{background:linear-gradient(120deg,var(--primary),var(--primary-dark));color:#fff;padding:46px 0}
.page-hero h1{color:#fff;font-size:clamp(1.6rem,4.5vw,2.4rem)}
.page-hero p{color:rgba(255,255,255,.9);margin-top:8px;max-width:620px}
.breadcrumb{font-size:.84rem;color:rgba(255,255,255,.8);margin-bottom:10px}
.breadcrumb a{color:#fff;text-decoration:underline}

/* ---------- Tables ---------- */
.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);background:#fff}
table.data{width:100%;border-collapse:collapse;font-size:.9rem;min-width:560px}
table.data th,table.data td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--border)}
table.data th{background:var(--bg);font-family:var(--font-head);font-weight:600;color:var(--muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.04em}
table.data tr:last-child td{border-bottom:0}
table.data tr:hover td{background:var(--primary-50)}

/* ---------- Sponsors ---------- */
.sponsors{display:flex;flex-wrap:wrap;gap:14px 26px;align-items:center;justify-content:center}
.sponsor{background:#fff;border:1px solid var(--border);border-radius:12px;padding:14px 22px;font-family:var(--font-head);font-weight:700;color:var(--muted);opacity:.8;font-size:1rem}

/* ---------- Gallery ---------- */
.gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.gallery-grid .g{overflow:hidden;border-radius:12px;aspect-ratio:1}
.gallery-grid .g img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gallery-grid .g:hover img{transform:scale(1.08)}

/* ---------- Admin ---------- */
.admin-body{background:#f1f5f9}
.admin-topbar{background:#0f172a;color:#fff;position:sticky;top:0;z-index:50}
.admin-topbar-inner{display:flex;align-items:center;justify-content:space-between;height:60px}
.admin-topbar .brand-mark{width:36px;height:36px;font-size:.85rem}
.admin-topbar .brand{color:#fff;gap:9px}
.admin-topbar .brand strong{font-size:.95rem}
.admin-nav{display:flex;align-items:center;gap:6px}
.admin-nav a{color:#cbd5e1;padding:8px 13px;border-radius:8px;font-size:.88rem;font-weight:500}
.admin-nav a:hover,.admin-nav a.is-active{background:rgba(255,255,255,.1);color:#fff}
.admin-nav .admin-ext{margin-left:8px;color:var(--secondary)}
.admin-wrap{padding:26px 18px}
.page-title{font-size:1.5rem;margin-bottom:20px}
.admin-grid-stats{display:grid;grid-template-columns:1fr;gap:14px;margin-bottom:26px}
.stat-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:18px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow-sm)}
.stat-icon{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:var(--primary-50);color:var(--primary)}
.stat-value{font-family:var(--font-head);font-weight:800;font-size:1.5rem;line-height:1}
.stat-label{color:var(--muted);font-size:.82rem}
.panel{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:20px;box-shadow:var(--shadow-sm)}
.panel h3{font-size:1.1rem;margin-bottom:14px}
.admin-cols{display:grid;grid-template-columns:1fr;gap:20px}

/* utilities */
.muted{color:var(--muted)}
.center{text-align:center}
.mt{margin-top:20px}.mt-lg{margin-top:34px}.mb{margin-bottom:20px}
.gap{gap:12px}.flex{display:flex}.between{justify-content:space-between}.wrap{flex-wrap:wrap}.aic{align-items:center}
.hidden{display:none!important}
.text-danger{color:var(--danger)}.text-success{color:var(--success)}.text-primary{color:var(--primary)}
.empty-state{text-align:center;padding:50px 20px;color:var(--muted)}
.empty-state .big{font-size:2.6rem;margin-bottom:10px}
.divider{height:1px;background:var(--border);margin:24px 0}
.note{font-size:.84rem;color:var(--muted);background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:10px 14px}

/* ---------- Responsive ---------- */
@media (min-width:640px){
  .cards-grid{grid-template-columns:repeat(2,1fr)}
  .pkg-grid{grid-template-columns:repeat(2,1fr)}
  .steps-grid{grid-template-columns:repeat(2,1fr)}
  .field-row{grid-template-columns:1fr 1fr}
  .form-grid-2{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(4,1fr)}
  .admin-grid-stats{grid-template-columns:repeat(2,1fr)}
  .footer-bottom .container{flex-direction:row;justify-content:space-between}
}
@media (min-width:900px){
  .cta-inner{flex-direction:row;text-align:left;align-items:center;justify-content:space-between}
  .cta-btns{justify-content:flex-end}
  .steps-grid{grid-template-columns:repeat(4,1fr)}
  .gallery-grid{grid-template-columns:repeat(4,1fr)}
  .footer-grid{grid-template-columns:2fr 1fr 1fr 1.5fr}
  .admin-grid-stats{grid-template-columns:repeat(4,1fr)}
  .admin-cols{grid-template-columns:1.4fr 1fr}
}
@media (min-width:1024px){
  .cards-grid{grid-template-columns:repeat(3,1fr)}
}
@media (min-width:1200px){
  .cards-grid{grid-template-columns:repeat(4,1fr)}
}

/* ---------- Mobile nav (<900px) ---------- */
@media (max-width:899px){
  .nav-toggle{display:flex}
  .nav-menu{position:fixed;inset:70px 0 auto 0;background:#fff;flex-direction:column;align-items:stretch;gap:0;padding:14px;border-bottom:1px solid var(--border);box-shadow:var(--shadow-lg);transform:translateY(-130%);transition:transform .3s ease;max-height:calc(100vh - 70px);overflow:auto}
  .nav-menu.open{transform:translateY(0)}
  .nav-links{flex-direction:column;align-items:stretch;gap:2px;border-bottom:1px solid var(--border);padding-bottom:10px;margin-bottom:10px}
  .nav-links a{padding:12px 13px}
  .nav-actions{flex-direction:column;align-items:stretch;gap:8px}
  .nav-actions .btn{width:100%}
  .account-menu{position:static;box-shadow:none;border:0;display:flex;padding:0;margin-top:6px}
  .nav-account{width:100%}
  .account-btn{width:100%;justify-content:flex-start}
  .admin-toggle{display:flex}
  .admin-nav{position:fixed;inset:60px 0 auto 0;flex-direction:column;align-items:stretch;background:#0f172a;padding:12px;border-top:1px solid #1e293b;transform:translateY(-200%);transition:transform .3s;z-index:40}
  .admin-nav.open{transform:translateY(0)}
  .admin-nav .admin-ext{margin-left:0}
}
@media (min-width:900px){ .admin-toggle{display:none} }

/* ---------- Checkout ---------- */
.checkout-grid{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:900px){.checkout-grid{grid-template-columns:.9fr 1.1fr}}
.gw-list{display:flex;flex-direction:column;gap:10px}
.gw-card{display:flex;align-items:flex-start;gap:12px;border:1.5px solid var(--border);border-radius:12px;padding:13px 15px;cursor:pointer;transition:.2s;background:#fff}
.gw-card:hover{border-color:var(--primary-light)}
.gw-card input{accent-color:var(--primary);width:18px;height:18px;margin-top:2px;flex-shrink:0}
.gw-card.is-default{border-color:var(--primary);background:var(--primary-50);box-shadow:var(--shadow-sm)}
.gw-info{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.gw-name{font-family:var(--font-head);font-weight:700;font-size:.98rem}
.gw-badge{font-size:.66rem;font-weight:700;background:var(--primary);color:#fff;padding:2px 9px;border-radius:999px;text-transform:uppercase;letter-spacing:.06em}
.gw-desc{width:100%;color:var(--muted);font-size:.8rem}
