/* ------------------------------------------------------------------
  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(--surface);border-bottom:1px solid var(--line)}
.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(--ink)}
.site-nav a:hover{background:color-mix(in oklab, var(--brand) 6%, var(--surface))}

/* 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(--ink);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(--surface);
    border-left:1px solid var(--line);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)}

/* ===== Page Title / Lede ===== */
.page-title{
  text-align:center;
  font-size:clamp(1.5rem,2.5vw,2rem);
  margin:16px auto 8px;
  color:var(--ink);      /* darker, premium */
  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-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;
}
