/* ------------------------------------------------------------------
  LEO Network – Public Front-End Base Styles (LE palette + Dark mode)
  File: /assets-2026-revamp/css/leo-css.css
------------------------------------------------------------------- */

/* ===== Base color tokens (Light) ===== */
:root{
  /* LE palette */
  --brand:#0b1f4b;          /* deep navy */
  --brand-ink:#0b1f4b;
  --brand-contrast:#ffffff;
  --accent:#caa133;         /* badge gold */
  --accent-ink:#332800;

  /* UI */
  --bg:#f6f7fb;
  --surface:#ffffff;
  --card:#ffffff;
  --ink:#0a0a0a;
  --muted:#667085;
  --line:#e5e7eb;
  --btn:#f2f4f7;
  --focus:#1e90ff;

  /* States */
  --success:#108a55;
  --warn:#f4b400;
  --danger:#d93025;

  /* Elevation */
  --shadow:0 1px 2px rgba(0,0,0,.06), 0 8px 24px rgba(0,0,0,.06);
}

/* ===== Dark scheme (auto via OS) ===== 
CHAT GPT IM TEMPORARILY DISABLYING THIS UNTIL YOU GIVE ME A TOGGLE
@media (prefers-color-scheme: dark){
  :root{
    --bg:#0b0f1a;
    --surface:#0f1524;
    --card:#121a2b;
    --ink:#eef2ff;
    --muted:#9aa6c1;
    --line:#1e2a44;
    --btn:#162038;
    --focus:#63a3ff;

    --brand:#0e2a66;
    --brand-ink:#c9d6ff;
    --brand-contrast:#eaf1ff;
    --accent:#d1b14a;
    --accent-ink:#201a08;

    --success:#1fb37a;
    --warn:#ffd465;
    --danger:#ff6b6b;
    --shadow:0 2px 10px rgba(0,0,0,.35);
  }
}
*/

/* ===== Manual theme override (data-theme) ===== 
CHAT GPT IM TEMPORARILY DISABLYING THIS UNTIL YOU GIVE ME A TOGGLE
html[data-theme="dark"]{
  --bg:#0b0f1a;
  --surface:#0f1524;
  --card:#121a2b;
  --ink:#eef2ff;
  --muted:#9aa6c1;
  --line:#1e2a44;
  --btn:#162038;
  --focus:#63a3ff;

  --brand:#0e2a66;
  --brand-ink:#c9d6ff;
  --brand-contrast:#eaf1ff;
  --accent:#d1b14a;
  --accent-ink:#201a08;

  --success:#1fb37a;
  --warn:#ffd465;
  --danger:#ff6b6b;
  --shadow:0 2px 10px rgba(0,0,0,.35);
}
*/
html[data-theme="light"]{
  /* no-op: stays with root (light) */
}

/* ===== Resets / base ===== */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){ html{scroll-behavior:auto} }
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font:16px/1.55 system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

/* Links / Focus */
a{color:var(--brand-ink);text-decoration:none}
a:hover{text-decoration:underline}
:focus-visible{outline:2px solid var(--focus);outline-offset:2px}
::selection{background:color-mix(in oklab, var(--brand) 30%, #fff);color:#000}

/* ===== Utilities ===== */
.container{max-width:1200px;margin:0 auto;padding:0 16px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.center{text-align:center}
.right{text-align:right}
.muted{color:var(--muted)}
.tiny{font-size:.875rem}

.mt-0{margin-top:0}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:1rem}.mt-4{margin-top:1.5rem}
.mb-0{margin-bottom:0}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:1rem}.mb-4{margin-bottom:1.5rem}
.p-0{padding:0}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:1rem}.p-4{padding:1.5rem}
.hide{display:none}

/* ===== Headings ===== */
h1{font-size:1.875rem;line-height:1.2;margin:.5rem 0;color:var(--ink);font-weight:700}
h2{font-size:1.375rem;margin:1.2rem 0 .4rem}
h3{font-size:1.125rem;margin:1rem 0 .25rem}

/* ===== Main wrapper ===== */
.site-main{padding:16px 0}
@media (min-width:900px){ .site-main{padding:24px 0} }

/* ===== Layout primitives ===== */
.stack{display:flex;flex-direction:column;gap:0.75rem}
.stack--xs{gap:0.5rem}
.stack--sm{gap:0.75rem}
.stack--md{gap:1rem}
.stack--lg{gap:1.25rem}

.grid{display:grid;gap:0.75rem} /* new default gap */
.grid.fit{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}
.grid--4{grid-template-columns:repeat(4,minmax(0,1fr))}
.grid--3{grid-template-columns:repeat(3,minmax(0,1fr))}
.gap--md{gap:1rem}
.col-span-3{grid-column:span 3 / span 3}

@media (max-width:960px){
  .grid--4{grid-template-columns:repeat(2,minmax(0,1fr))}
  .grid--3{grid-template-columns:repeat(2,minmax(0,1fr))}
  .col-span-3{grid-column:span 2 / span 2}
}
@media (max-width:640px){
  .grid--4,.grid--3{grid-template-columns:1fr}
  .col-span-3{grid-column:auto}
}

/* ===== Cards ===== */
.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:12px;
  padding:16px;
  box-shadow:var(--shadow);
}
.card--padded{padding:1rem}
.card--event{padding:1rem 1.15rem} /* slightly more premium padding */
.card h3{margin:.25rem 0 .5rem}
.card-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}

/* ===== Buttons (legacy + BEM; both supported) ===== */
.btn{
  display:inline-block;background:var(--btn);border:1px solid var(--line);color:var(--ink);
  padding:8px 12px;border-radius:8px;text-decoration:none;transition:filter .15s,transform .02s;cursor:pointer;
}
.btn:hover{filter:brightness(.98)}
.btn:active{transform:translateY(1px)}
.btn.primary{background:var(--brand);color:var(--brand-contrast);border-color:transparent}
.btn.primary:hover{filter:brightness(1.05)}
.btn.ghost{background:var(--surface);border:1px solid var(--line)}
.btn.danger{background:color-mix(in oklab, var(--danger) 10%, #fff);border-color:color-mix(in oklab, var(--danger) 30%, #fff);color:#7a0b0b}
.button-row{display:flex;gap:.5rem;flex-wrap:wrap}

.btn--primary{display:inline-flex;align-items:center;justify-content:center;border-radius:10px;padding:.55rem .9rem;font-weight:600;border:1px solid transparent;cursor:pointer;text-decoration:none;color:#fff;background:var(--brand);border-color:var(--brand)}
.btn--primary:hover{filter:brightness(.96)}
.btn--subtle{display:inline-flex;align-items:center;justify-content:center;border-radius:10px;padding:.55rem .9rem;font-weight:600;border:1px solid var(--line);background:var(--btn);color:var(--ink)}

/* Accent (gold) chip for small highlights */
.badge{display:inline-block;font-size:.8rem;padding:.2rem .5rem;border-radius:.5rem;background:color-mix(in oklab, var(--accent) 8%, #fff);border:1px solid color-mix(in oklab, var(--accent) 35%, #fff);color:#3a2f0a}
.badge.soft{background:#f6f7f9}
.badge.danger{background:#fee;color:#900;border:1px solid #fbb}

/* ===== Breadcrumbs (legacy + BEM) ===== */
.breadcrumbs{
  font-size:.9rem;
  margin:8px 0 12px;
  color:var(--ink); /* darker, more confident */
}
.breadcrumbs ol{list-style:none;padding:0;margin:0;display:flex;gap:.5rem;flex-wrap:wrap}
.breadcrumbs li::after{content:"/";margin:0 .5rem;color:var(--muted)}
.breadcrumbs li:last-child::after{content:""}
.breadcrumbs [aria-current="page"]{font-weight:600}

.breadcrumbs__list{list-style:none;display:flex;gap:.5rem;padding:0;margin:0 0 .5rem}
.breadcrumbs__item a{color:inherit;text-decoration:none}
.breadcrumbs__item a:hover{text-decoration:underline}

/* ===== Pagination (legacy + BEM) ===== */
.pagination{text-align:center;margin:20px 0;display:flex;gap:12px;justify-content:center;align-items:center;flex-wrap:wrap}
.pagination a,.pagination span{
  display:inline-block;padding:6px 10px;margin:0 2px;border:1px solid var(--line);border-radius:8px;text-decoration:none;color:var(--ink);background:var(--surface)
}
.pagination span{background:color-mix(in oklab, var(--brand) 4%, var(--surface))}

.pagination__page{display:inline-flex;min-width:36px;height:36px;align-items:center;justify-content:center;padding:0 .5rem;border:1px solid var(--line);border-radius:8px;text-decoration:none;color:var(--ink);background:var(--surface)}
.pagination__page:hover{background:color-mix(in oklab, var(--brand) 4%, var(--surface))}
.pagination__page.is-active{background:var(--brand);border-color:var(--brand);color:var(--brand-contrast)}

/* ===== Tables ===== */
.table{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--surface)}
.table th,.table td{padding:10px;border-bottom:1px solid var(--line);text-align:left}
.table th{background:color-mix(in oklab, var(--brand) 5%, var(--surface));font-weight:600}
.table tr:last-child td{border-bottom:none}

/* ===== Forms ===== */
.input, select, textarea{
  width:100%;padding:8px 10px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--ink)
}
label{display:block;margin:.5rem 0 .25rem}
.form-row{display:grid;gap:12px}
@media (min-width:700px){ .form-row.two{grid-template-columns:1fr 1fr} }

/* ===== Notices / Alerts ===== */
.notice{border:1px solid var(--line);background:var(--surface);border-radius:10px;padding:12px}
.notice.cta{max-width:1000px;margin:8px auto;text-align:center}
.notice .btn-row{margin-top:8px;display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.alert{border-left:4px solid var(--warn);background:color-mix(in oklab, var(--warn) 10%, var(--surface));padding:10px;border-radius:8px;border:1px solid color-mix(in oklab, var(--warn) 30%, var(--surface))}
.alert.success{border-left-color:var(--success);background:color-mix(in oklab, var(--success) 8%, var(--surface));border-color:color-mix(in oklab, var(--success) 30%, var(--surface))}
.alert.danger{border-left-color:var(--danger);background:color-mix(in oklab, var(--danger) 10%, var(--surface));border-color:color-mix(in oklab, var(--danger) 35%, var(--surface))}

/* ===== Header / Nav (hamburger ready) ===== */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:var(--brand);
  color:var(--brand-contrast);
  border-bottom:1px solid rgba(0,0,0,.35);
  box-shadow:0 2px 8px rgba(0,0,0,.28);
}
.site-header .container{
  min-height:64px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}
.brand{display:flex;align-items:center;gap:10px}
.brand .logo{display:inline-flex;line-height:0}
.brand .logo img{height:36px;width:auto}

/* Desktop nav */
.site-nav ul{display:flex;align-items:center;gap:8px;list-style:none;margin:0;padding:0}
.site-nav a{
  display:inline-block;
  padding:10px 12px;
  border-radius:8px;
  text-decoration:none;
  color:var(--brand-contrast);
}
.site-nav a:hover{
  background:color-mix(in oklab, var(--brand-contrast) 16%, var(--brand));
}

/* Hamburger (checkbox pattern; requires .nav-toggle + .hamburger + .site-nav siblings) */
.nav-toggle{position:absolute;left:-9999px}
.hamburger{display:none;cursor:pointer;width:36px;height:28px;position:relative}
.hamburger span{
  position:absolute;
  left:0;
  right:0;
  height:3px;
  background:var(--brand-contrast);
  border-radius:4px;
  transition:transform .2s,opacity .2s,top .2s;
}
.hamburger span:nth-child(1){top:2px}
.hamburger span:nth-child(2){top:12px}
.hamburger span:nth-child(3){top:22px}

@media (max-width:920px){
  .hamburger{display:block}
  .site-nav{
    position:fixed;
    inset:64px 0 0 auto;
    max-width:320px;
    background:var(--brand);
    border-left:1px solid rgba(0,0,0,.4);
    transform:translateX(110%);
    transition:transform .25s ease;
    box-shadow:var(--shadow);
  }
  .site-nav ul{flex-direction:column;align-items:flex-start;padding:16px;gap:6px}
  .site-nav a{display:block;width:100%;border-radius:10px}
  .nav-toggle:checked ~ .hamburger span:nth-child(1){transform:translateY(10px) rotate(45deg)}
  .nav-toggle:checked ~ .hamburger span:nth-child(2){opacity:0}
  .nav-toggle:checked ~ .hamburger span:nth-child(3){transform:translateY(-10px) rotate(-45deg)}
  .nav-toggle:checked ~ .site-nav{transform:translateX(0)}
}

/* ===== Footer ===== */
.site-footer{
  margin-top:40px;
  padding:28px 0;
  border-top:1px solid var(--line);
  background:var(--surface);
}
.site-footer .container{
  display:flex;
  align-items:flex-start;
  gap:32px;
  justify-content:space-between;
  flex-wrap:wrap;
}
.footer-links{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.footer-links a{color:var(--ink)}
.footer-links a:hover{text-decoration:underline}
.copy{font-size:.9rem;color:var(--muted)}

/* Optional premium bottom band (Option 3) */
.footer-bottom{
  margin-top:16px;
  background:var(--brand);
  color:var(--brand-contrast);
  padding:12px 0;
}
.footer-bottom .container{
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
  font-size:.85rem;
}
.footer-bottom a{
  color:var(--brand-contrast);
  text-decoration:none;
}
.footer-bottom a:hover{
  text-decoration:underline;
}

/* ===== Page Title / Lede ===== */
.page-title{
  text-align:center;
  font-size:clamp(1.5rem,2.5vw,2rem);
  margin:16px auto 8px;
  color:var(--ink);
  font-weight:700;
}
.lede{max-width:1000px;margin:8px auto 24px;line-height:1.6;color:var(--muted)}

/* ===== Actions row ===== */
.actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.5rem}
.btn.outline{background:var(--surface);border:1px solid var(--line)}

/* ===== Modal (native <dialog>) ===== */
dialog.modal{border:none;padding:0;border-radius:12px;width:min(720px, 92%)}
dialog::backdrop{background:rgba(0,0,0,.35)}
.modal-content{background:var(--surface);border-radius:12px;overflow:hidden}
.modal-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--line)}
.modal-body{padding:16px}
.modal-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:12px}
.close{background:none;border:none;font-size:1.5rem;line-height:1;cursor:pointer;color:var(--ink)}

/* ===== Media / Images ===== */
.img-cover{width:100%;height:100%;object-fit:cover;border-radius:10px}
.media{display:flex;gap:12px;align-items:flex-start}

/* ===== Code blocks ===== */
pre,code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace}
pre{background:#0a0a0a;color:#f5f5f5;padding:12px;border-radius:10px;overflow:auto}
code{background:color-mix(in oklab, var(--brand) 8%, #f3f4f6);padding:.15rem .35rem;border-radius:6px}

/* ===== Print basics ===== */
@media print{
  .site-header,.site-footer,.breadcrumbs,.pagination{display:none !important}
  body{background:#fff;color:#000}
  .card{box-shadow:none;border-color:#ddd}
}

/* ===== Event cards list ===== */
.cards{list-style:none;margin:0;padding:0}
.cards--events{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:1.15rem; /* more vertical breathing room */
}
.card__link{display:block;text-decoration:none;color:inherit}
.card__title{font-weight:600;margin-bottom:.2rem}
.card__meta{font-size:.95rem;color:var(--muted)}
@media (max-width:900px){ .cards--events{grid-template-columns:1fr} }

/* ===== FAQ ===== */
.faq__answer{margin:0 0 .75rem}
.faq-list{margin:0;padding:0}
.faq-list dt{margin:0 0 .25rem}
.faq-list dd{margin:0 0 .75rem;color:var(--muted)}

/* ===== Sections / home hooks (from earlier block, merged cleanly) ===== */
.section{padding:28px 0;border-top:1px solid var(--line)}
.section.hero{border-top:0}
.section .container{max-width:1200px;margin:0 auto;padding:0 16px}

/* semantic hooks (for future styling) */
.value-props{}
.hubs{}
.reviews{}
.how-it-works{}

/* ===== Chips (for filters, tags, etc.) ===== */
.chip-row{display:flex;flex-wrap:wrap;gap:10px}
.chip{
  display:inline-block;
  padding:8px 12px;
  border:1px solid var(--line);
  border-radius:999px;
  text-decoration:none;
  color:var(--ink);
  background:var(--surface);
  transition:background .15s ease,border-color .15s ease;
  font-size:.9rem;
}
.chip:hover{
  background:color-mix(in oklab, var(--brand) 4%, var(--surface));
  border-color:color-mix(in oklab, var(--brand) 20%, var(--line));
}

/* ===== Sponsors rail ===== */
.sponsors .grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.sponsor-card{text-align:center}
.sponsor-card img{max-width:70%;height:auto}

/* ===== Spotlight review ===== */
.spotlight-review .card{}

/* ===== Extra utility ===== */
.text-center{text-align:center}
@media (max-width:640px){
  .section{padding:24px 0}
}

/* === Flash Messages === */
.pag-flash-wrap {
    margin: 16px auto;
    max-width: 1000px;
}

.pag-flash {
    padding: 12px 16px;
    border-radius: 10px;
    margin-bottom: 12px;
    font-size: .95rem;
    border: 1px solid var(--line);
    background: var(--surface);
    box-shadow: var(--shadow);
}

/* Success */
.pag-flash--success {
    border-color: color-mix(in oklab, var(--success) 40%, transparent);
    background: color-mix(in oklab, var(--success) 10%, var(--surface));
    color: var(--success);
    font-weight: 600;
}

/* Error */
.pag-flash--error {
    border-color: color-mix(in oklab, var(--danger) 40%, transparent);
    background: color-mix(in oklab, var(--danger) 10%, var(--surface));
    color: var(--danger);
    font-weight: 600;
}

/* Info */
.pag-flash--info {
    border-color: color-mix(in oklab, var(--brand) 30%, transparent);
    background: color-mix(in oklab, var(--brand) 8%, var(--surface));
    color: var(--brand);
}

/* Warning */
.pag-flash--warning {
    border-color: color-mix(in oklab, var(--warn) 40%, transparent);
    background: color-mix(in oklab, var(--warn) 10%, var(--surface));
    color: var(--warn);
    font-weight: 600;
}

/* =========================================================
   Event detail page layout & tweaks
   ======================================================= */

.event-page-shell {
  padding-left: 0.75rem;
  padding-right: 0.75rem;
}

@media (min-width: 768px) {
  .event-page-shell {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}

/* Vertical spacing between major cards on the event page */
.event-page-section + .event-page-section {
  margin-top: 1.5rem;
}

/* Reviews grid: 1-up on small, 2-up on wider screens */
.event-reviews-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  margin-top: 1rem;
}

@media (min-width: 900px) {
  .event-reviews-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* Small text utilities scoped to event page */
.event-instructor-note {
  font-size: 0.9rem;
}

.event-review-meta {
  font-size: 0.85rem;
}

.event-review-footer {
  font-size: 0.8rem;
  margin-top: 0.35rem;
}

/* Local spacing helpers for this page */
.event-categories {
  margin-top: 1.25rem;
}

.event-primary-buttons {
  margin-top: 1.25rem;
}

.event-title-dates-btnrow {
  margin-top: 0.75rem;
}


/* ===== State & Category Trending blocks ===== */

.state-trending {
    margin-top: 2.5rem;
    padding: 1.5rem;
    background: #ffffff;
    border-radius: 12px;
    border: 1px solid #e4e8f0;
}

.state-trending-title {
    margin: 0 0 1.5rem;
    font-size: 1.6rem;
    font-weight: 700;
    color: #0b1724;
}

.trending-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1.75rem;
}

.trending-block h3 {
    margin-bottom: 0.75rem;
    font-size: 1.1rem;
    font-weight: 600;
    color: #13243b;
}

.trending-block ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.trending-block li {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.35rem 0;
    font-size: 0.95rem;
}

.trending-block a {
    color: #0a4db3;
    font-weight: 500;
    text-decoration: none;
}

.trending-block a:hover {
    text-decoration: underline;
}

.trend-count {
    color: #67758a;
    font-size: 0.85rem;
}

.trending-box {
    background: var(--surface);
    border: 1px solid var(--line);
    padding: 20px;
    border-radius: 12px;
}

.trending-grid {
    display: grid;
    gap: 20px;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.trending-section h3 {
    margin-bottom: 10px;
    font-size: 1.1rem;
}

.trending-section ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.trending-section li {
    margin-bottom: 6px;
}

.trending-section a {
    color: var(--brand);
    text-decoration: none;
    font-weight: 500;
}

.trending-section .views {
    color: var(--muted);
    margin-left: 6px;
}

/* Mobile breadcrumb padding — premium spacing */
@media (max-width: 720px) {
  .breadcrumbs,
  .breadcrumbs__list {
    padding-left: 12px;
    padding-right: 12px;
  }
}
/* UNIVERSAL REVIEW BAR SYSTEM */
.review-bar-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.review-bar-label {
  width: 2.3rem;
  font-size: 0.85rem;
  color: var(--muted);
}
.review-bar-track {
  flex: 1;
  height: 7px;
  background: rgba(15,23,42,0.08);
  border-radius: 999px;
  overflow: hidden;
}
.review-bar-fill {
  height: 100%;
  background: linear-gradient(90deg,#caa133,#f4b400);
  border-radius: 999px;
}
.review-bar-count {
  width: 2rem;
  text-align: right;
  font-size: 0.85rem;
  color: var(--muted);
}
.reviews-summary-unified {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.reviews-summary-headline {
  display: flex;
  align-items: baseline;
  gap: 0.35rem;
}
.reviews-summary-headline strong {
  font-size: 2rem;
  font-weight: 700;
  color: #111;
}

.rating-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin: 4px 0;
}

.rating-row__label {
  width: 60px;
  font-size: 0.85rem;
  color: #888;
}

.rating-row__bar-track {
  flex: 1;
  height: 8px;
  background: #eee;
  border-radius: 3px;
  overflow: hidden;
}

.rating-row__bar-fill {
  height: 100%;
  background: #3b82f6;
  border-radius: 3px;
}

.rating-row__count {
  width: 40px;
  text-align: right;
  font-size: 0.85rem;
  color: #666;
}

/* -------- Contact Page -------- */
.contact-page {
  max-width: 900px;
  margin: 0 auto;
  padding-bottom: 3rem;
}

.contact-page h1 {
  margin-bottom: 0.25rem;
}

.intro-text {
  margin-bottom: 1.5rem;
  font-size: 1.14rem;
}

/* -------- Card -------- */
.contact-card {
  background: #fff;
  padding: 2.2rem 2.4rem;
  border-radius: 14px;
  box-shadow: 0 6px 28px rgba(0,0,0,0.08);
  border: 1px solid #e7e7e7;
}

.card-title {
  font-size: 1.3rem;
  font-weight: 700;
  margin-bottom: 1.5rem;
}

/* -------- Form Grid -------- */
.form-grid-2col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.35rem 1.75rem;
}

.form-grid-full {
  margin-top: 1.35rem;
}

/* -------- Input Groups -------- */
.form-field label {
  display: block;
  font-weight: 600;
  margin-bottom: 0.45rem;
  font-size: 0.95rem;
}

.form-field span {
  color: #d33;
  font-weight: bold;
}

.form-field input,
.form-field select,
.form-field textarea {
  width: 100%;
  border: 1px solid #cfcfcf;
  background: #fafafa;
  padding: 0.70rem 0.85rem;
  border-radius: 9px;
  font-size: 1rem;
  transition: border-color 0.15s ease;
}

.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
  background: #fff;
  border-color: #2463eb;
  outline: none;
}

/* -------- Submit Button -------- */
.btn-submit {
  width: 100%;
  padding: 0.95rem;
  font-size: 1.1rem;
  border-radius: 9px;
}

/* -------- Alerts -------- */
.alert {
  padding: 1rem 1.25rem;
  border-radius: 10px;
  margin-bottom: 1.4rem;
}

.alert--success {
  background: #eaf9ef;
  color: #1b6e3a;
}

.alert--error {
  background: #fcebea;
  color: #a82424;
}

/* -------- Honeypot -------- */
.hp-field {
  display:none;
}

/* -------- Responsive -------- */
@media (max-width: 780px) {
  .form-grid-2col {
    grid-template-columns: 1fr;
  }
}


/* =========================================================
   PREMIUM CERTIFICATE STATUS CARDS  (FULL REQUIRED BLOCK)
   ======================================================= */

/* Outer container */
.cert-status-container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px;
}

/* List wrapper (responsive grid) */
.cert-list {
  list-style: none;
  padding: 0;
  margin: 2rem 0;
  display: grid;
  gap: 1.75rem;
  grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
}

/* Card wrapper */
.cert-card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 1.5rem 1.75rem;
  box-shadow: var(--shadow);
  transition: transform .18s ease, box-shadow .18s ease;
}

/* Hover elevation (premium lift effect) */
.cert-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 36px rgba(0,0,0,0.12);
}

/* Title */
.cert-card-title {
  margin: 0 0 .25rem;
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--ink);
  line-height: 1.3;
}

/* Meta row (date & location) */
.cert-card-meta {
  font-size: .95rem;
  color: var(--muted);
  display: flex;
  gap: .75rem;
  flex-wrap: wrap;
  margin-bottom: 1rem;
}

/* Status container */
.cert-card-status {
  margin-top: .5rem;
}

/* Status pill base */
.status-pill {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .45rem .85rem;
  font-size: .95rem;
  border-radius: 999px;
  font-weight: 600;
  border: 1px solid transparent;
  white-space: nowrap;
}

/* Issued */
.status-pill--success {
  background: color-mix(in oklab, var(--success) 12%, #fff);
  color: var(--success);
  border-color: color-mix(in oklab, var(--success) 35%, #fff);
}

/* Not issued */
.status-pill--warning {
  background: color-mix(in oklab, var(--warn) 12%, #fff);
  color: var(--warn);
  border-color: color-mix(in oklab, var(--warn) 35%, #fff);
}

/* Icons inside pills */
.status-pill .icon {
  width: 18px;
  height: 18px;
  fill: currentColor;
  flex-shrink: 0;
  display: inline-block;
}

/* Empty state style */
.empty-block {
  padding: 2rem;
  text-align: center;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: var(--shadow);
  max-width: 600px;
  margin: 2rem auto;
  font-size: 1.05rem;
  line-height: 1.55;
  color: var(--ink);
}

/* Mobile spacing tweak */
@media (max-width: 640px) {
  .cert-status-container {
    padding: 0 12px;
  }
}

/* =========================================================
   HOW-TO PAGE (2026 REVAMP)
   Premium layout + sidebar + accordion stack
   ======================================================= */

/* ---- Hero Section ---- */

.howto-hero {
  text-align: center;
  padding: 3.5rem 1.25rem 2rem;
  max-width: 860px;
  margin: 0 auto;
}

.howto-hero h1 {
  font-size: 2.4rem;
  font-weight: 800;
  margin-bottom: .75rem;
  color: var(--ink);
}

.howto-hero .lede {
  font-size: 1.15rem;
  color: var(--muted);
  max-width: 700px;
  margin: 0 auto;
  line-height: 1.55;
}

/* ---- Page Layout ---- */

.howto-layout {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 2.5rem;
  max-width: 1300px;
  margin: 2rem auto 4rem;
  padding: 0 1.25rem;
}

@media (max-width: 900px) {
  .howto-layout {
    grid-template-columns: 1fr;
  }
}

/* ---- Sidebar Navigation ---- */

.howto-nav {
  position: sticky;
  top: 110px;
  height: max-content;
}

.howto-nav h3 {
  margin: 0 0 .75rem;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: .2px;
}

.howto-nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.howto-nav li {
  margin: 0;
}

.howto-nav a {
  display: block;
  padding: .55rem .4rem;
  border-left: 3px solid transparent;
  text-decoration: none;
  color: var(--muted);
  font-size: .96rem;
  transition: all .15s ease;
  border-radius: 4px;
}

.howto-nav a:hover {
  color: var(--ink);
  background: var(--surface);
}

.howto-nav a.active {
  color: var(--brand);
  font-weight: 600;
  border-left-color: var(--brand);
  background: color-mix(in oklab, var(--brand) 8%, transparent);
}

/* ---- Accordion Stack ---- */

.accordion-stack {
  display: flex;
  flex-direction: column;
  gap: 1.3rem;
}

/* ---- Accordion Item ---- */

.accordion-item {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: var(--shadow);
  overflow: hidden;
  transition: box-shadow .2s ease;
}

.accordion-item.open {
  box-shadow: 0 12px 30px rgba(0,0,0,0.10);
}

/* ---- Accordion Trigger ---- */

.accordion-trigger {
  width: 100%;
  text-align: left;
  padding: 1.25rem 1.5rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  border: none;
  background: transparent;
  color: var(--ink);
  font-size: 1.1rem;
  font-weight: 700;
}

.accordion-trigger:hover {
  background: var(--surface);
}

.accordion-icon {
  width: 20px;
  height: 20px;
  fill: var(--muted);
  transition: transform .25s ease;
}

.accordion-item.open .accordion-icon {
  transform: rotate(180deg);
}

/* ---- Accordion Panel ---- */

.accordion-panel {
  max-height: 0;
  overflow: hidden;
  transition: max-height .35s ease, padding .35s ease;
}

.accordion-item.open .accordion-panel {
  padding: 0 1.5rem 1.5rem;
  max-height: 1500px; /* intentionally large for content blocks */
}

/* ---- Accordion Content ---- */

/* ---- Links inside content ---- */

.accordion-content a {
  color: var(--brand);
  font-weight: 600;
  text-decoration: none;
}

.accordion-content a:hover {
  text-decoration: underline;
}

.accordion-content ul {
  padding-left: 1.25rem;
  margin: .75rem 0;
}

.accordion-content li {
  margin-bottom: .4rem;
}

/* ---- Responsive Improvements ---- */

@media (max-width: 700px) {
  .accordion-trigger {
    font-size: 1rem;
    padding: 1rem 1.1rem;
  }
}

/* ---- Links inside content ---- */

.accordion-content a {
  color: var(--primary);
  font-weight: 600;
  text-decoration: none;
}

.accordion-content a:hover {
  text-decoration: underline;
}


/* How-To Home Page — Premium Cards Grid */
.howto-card-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
    margin-top: 48px;
}

@media (max-width: 980px) {
    .howto-card-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .howto-card-grid {
        grid-template-columns: repeat(1, 1fr);
    }
}

.howto-card {
    display: block;
    background: #ffffff;
    border: 1px solid #e5e5e5;
    padding: 28px;
    border-radius: 12px;
    text-decoration: none;
    color: #222;
    transition: all 0.20s ease;
}

.howto-card:hover {
    border-color: #c8c8c8;
    transform: translateY(-4px);
    box-shadow: 0 6px 16px rgba(0,0,0,0.06);
}

.howto-card h3 {
    font-size: 1.2rem;
    margin-bottom: 8px;
    font-weight: 600;
}

.howto-card p {
    font-size: 0.95rem;
    margin: 0;
    color: #555;
}

/* ---- Mobile Fix: Normalize Sidebar Navigation ---- */
@media (max-width: 900px) {
  .howto-nav {
    position: static;          /* remove sticky */
    top: auto;
    width: 100%;               /* ensure full width */
    background: var(--card);   /* prevent 'light/overlap' look */
    padding: 1rem 0;
    border: 1px solid var(--line);
    border-radius: 10px;
  }

  .howto-nav h3 {
    padding-left: 1rem;
    padding-right: 1rem;  
    font-size: 1rem;
    margin-bottom: .5rem;
  }

  .howto-nav a {
    padding: .6rem 1rem;
    border-left-width: 0;      /* no left border highlight on mobile */
    border-radius: 6px;
  }

  .howto-nav a.active {
    background: color-mix(in oklab, var(--brand) 10%, transparent);
    border-left-color: transparent;
  }
}

.visually-hidden {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

/* Certificate grid layout */
.cert-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

/* tablet */
@media (max-width: 980px) {
    .cert-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* mobile */
@media (max-width: 640px) {
    .cert-grid {
        grid-template-columns: 1fr;
    }
}

/* optional: ensure uniform height */
.cert-card .card {
    height: 100%;
}

/* Remove outer border from certificate cards inside the grid */
.cert-grid .card {
    border: none !important;
    box-shadow: var(--shadow); /* keeps the premium card look */
}

/* Give breathing room below the certificate grid */
.cert-grid {
    margin-bottom: 2rem;
}
/* ─────────────────────────────────────────────── */
/*  SPONSOR BAR (Tier-1)                           */
/* ─────────────────────────────────────────────── */
.sponsor-bar {
    display: flex;
    gap: 1rem;
    padding: 1rem;
    overflow-x: auto;
    background: #f8f9fc;
    border-bottom: 1px solid #e1e4ea;
    scrollbar-width: thin;

    justify-content: center; /* NEW: center logos when fewer than full row */
}

/* NEW: if there is only one sponsor, scale it slightly and center it cleanly */
.sponsor-bar.single {
    justify-content: center;
    overflow-x: visible; /* no scroll bar for 1 sponsor */
}

/* Sponsor item appearance */
.sponsor-bar-item {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    background: white;
    border-radius: 10px;
    padding: .5rem 1rem;
    height: 60px;
    min-width: 100px;

    transition: transform .15s ease, opacity .15s ease;
}

/* NEW: subtle “premium hover” */
.sponsor-bar-item:hover {
    transform: scale(1.05);
    opacity: 1;
}

/* When only one sponsor, make the logo slightly larger */
.sponsor-bar.single .sponsor-bar-item {
    min-width: 140px;
    height: 70px;
}

/* image sizing */
.sponsor-bar-item img {
    max-height: 40px;
    width: auto;
    object-fit: contain;
}

/* Single-sponsor enhanced image size */
.sponsor-bar.single .sponsor-bar-item img {
    max-height: 50px;
}

/* Mobile behavior */
@media (max-width: 600px) {
    .sponsor-bar {
        gap: .75rem;
        padding: .75rem;
    }
    .sponsor-bar-item {
        height: 50px;
        min-width: 90px;
    }
    .sponsor-bar-item img {
        max-height: 35px;
    }

    /* Single sponsor on mobile */
    .sponsor-bar.single .sponsor-bar-item {
        height: 55px;
        min-width: 110px;
    }
    .sponsor-bar.single .sponsor-bar-item img {
        max-height: 42px;
    }
}

.sponsor-bar-label {
    text-align: center;
    font-size: 13px;
    font-weight: 600;
    color: #6b7280;
    margin-top: 6px;
}

/* ─────────────────────────────────────────────── */
/*  SPONSOR SIDEBAR (Tier-2)                       */
/* ─────────────────────────────────────────────── */
.sponsor-sidebar {
    margin: 2rem 0 2rem; /* top | left/right | bottom */
    padding: .5rem 1rem 1rem;
    background: #f9fafc;
    border: 1px solid #e2e5ea;
    border-radius: 12px;
}
.sponsor-sidebar-title {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 1rem;
}
.sponsor-sidebar-item {
    display: block;
    padding: .75rem;
    background: white;
    border: 1px solid #e1e4ea;
    border-radius: 10px;
    margin-bottom: .75rem;
    text-align: center;
}
.sponsor-sidebar-logo img {
    max-width: 100%;
    max-height: 60px;
    object-fit: contain;
}

/* Tablet/mobile: move sidebar below content */
@media (max-width: 900px) {
    .sponsor-sidebar {
        margin-top: 2rem;
    }
}

/* === SPONSOR SIDEBAR LAYOUT WRAPPER === */

.page-with-sidebar {
    display: grid;
    grid-template-columns: 1fr 280px; /* main content | sidebar */
    gap: 2rem;
    align-items: start;
}

.main-content {
    width: 100%;
}

.sidebar-column {
    position: sticky;
    top: 20px; /* sidebar sticks on desktop */
}

/* Mobile: sidebar goes below content */
@media (max-width: 900px) {
    .page-with-sidebar {
        grid-template-columns: 1fr;
    }
    .sidebar-column {
        position: static;
        margin-top: 2rem;
    }
}

/* ─────────────────────────────────────────────── */
/*  SPONSOR GRID (Tier-3)                          */
/* ─────────────────────────────────────────────── */
.sponsor-grid-section {
    padding: 2.5rem 1rem;
    background: #f8f9fc;
    margin-top: 3rem;
}
.sponsor-grid-title {
    text-align: center;
    font-size: 1.6rem;
    margin-bottom: 2rem;
}
.sponsor-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 1.5rem;
}
.sponsor-grid-item {
    display: flex;
    justify-content: center;
    align-items: center;
    background: white;
    border: 1px solid #e1e4ea;
    border-radius: 12px;
    padding: 1rem;
    height: 100px;
}
.sponsor-grid-logo img {
    max-height: 70px;
    width: auto;
    object-fit: contain;
}

/* Mobile resizing */
@media (max-width: 600px) {
    .sponsor-grid {
        gap: 1rem;
    }
    .sponsor-grid-item {
        height: 80px;
    }
    .sponsor-grid-logo img {
        max-height: 55px;
    }
}