/* ============================================================
   English Lab — design system
   Ported from the "English Lab Vivid" + "Free Materials" Claude Design
   handoff. Loaded site-wide via functions.php.
   ============================================================ */

:root{
  --bg: oklch(0.99 0.004 250);
  --surface: oklch(1 0 0);
  --panel: oklch(0.971 0.006 255);
  --ink: oklch(0.205 0.02 264);
  --muted: oklch(0.5 0.016 264);
  --faint: oklch(0.64 0.014 264);
  --line: oklch(0.91 0.008 258);
  --line-strong: oklch(0.85 0.012 258);
  --accent: oklch(0.55 0.198 262);
  --accent-2: oklch(0.5 0.205 272);
  --accent-ink: oklch(0.46 0.2 262);
  --accent-soft: oklch(0.955 0.04 262);
  --lime: oklch(0.84 0.185 140);
  --lime-ink: oklch(0.52 0.13 144);
  --lime-soft: oklch(0.93 0.1 140);
  --wrong: oklch(0.62 0.19 25);
  --wrong-ink: oklch(0.52 0.17 25);
  --wrong-soft: oklch(0.945 0.04 25);
  --sans: "Onest", system-ui, sans-serif;
}

/* Base ---------------------------------------------------- */
body.fel-design{font-family:var(--sans);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.5}
/* :where() keeps this at zero specificity so component link colors
   (.btn-primary, .chip, .fpill, .see-all …) always win over inherit. */
:where(.fel-design a){color:inherit;text-decoration:none}
.fel-design *{box-sizing:border-box}

/* Layout container.  !important to win over TT5 constrained layout.
   Use logical inline props only — a `padding` shorthand here would zero the
   vertical padding of co-classed elements (.sec, .results, .fbar-in, …). */
.fel-design .wrap{max-width:1160px !important;margin-inline:auto;padding-inline:60px}

/* Placeholder tile (used for cards with no cover image) */
.ph{background-color:var(--panel);background-image:repeating-linear-gradient(135deg, var(--line) 0 1px, transparent 1px 13px);display:flex;align-items:center;justify-content:center;border:1px solid var(--line)}
.ph span{font-family:ui-monospace,"SF Mono",Menlo,monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);background:var(--bg);padding:5px 10px;border:1px solid var(--line)}

/* ── Brand: "First English Lab" eyebrow lockup (FEL-3) ──
   Self-contained brand hexes so the mark stays exact regardless of
   the page palette.  Sizing is em-based — set font-size on .logo. */
.fel-design{--logo-accent:#3a51d6;--logo-accent2:#4b34cf;--logo-ink:#1b2150;
  --logo-lime:#9be23f;--logo-lime2:#bdf06a;--logo-lime-ink:#4f8a16}
.logo{font-size:26px;display:inline-flex;align-items:center;color:var(--logo-ink);white-space:nowrap;line-height:1}
.logo.rev{color:#fff}
.logo .stack{display:flex;flex-direction:column;line-height:.95}
.logo .s1{font-size:.4em;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--logo-accent);margin-bottom:.18em;margin-left:.04em}
.logo.lime .s1{color:var(--logo-lime-ink)}
.logo.rev .s1{color:var(--logo-lime)}
.logo .s2{font-size:1em;font-weight:800;letter-spacing:-.025em;display:inline-flex;align-items:center;gap:.22em}
.logo .cell{position:relative;display:inline-flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--logo-accent),var(--logo-accent2));color:#fff;font-weight:800;letter-spacing:-.02em;
  padding:.14em .32em .18em;border-radius:.3em;box-shadow:0 .2em .5em -.16em rgba(58,81,214,.7)}
.logo .cell.lime{background:linear-gradient(135deg,var(--logo-lime),#7bc62f);color:#1f3a07;box-shadow:0 .2em .5em -.16em rgba(123,198,47,.55)}
.logo .tile{position:relative;display:inline-flex;align-items:center;justify-content:center;width:1.55em;height:1.55em;
  border-radius:24%;font-weight:900;color:#fff;letter-spacing:-.04em;
  background:linear-gradient(135deg,var(--logo-accent),var(--logo-accent2));box-shadow:0 .18em .46em -.14em rgba(58,81,214,.65)}
.logo .tile.lime{background:linear-gradient(135deg,var(--logo-lime),#7bc62f);color:#1f3a07;box-shadow:0 .18em .46em -.14em rgba(123,198,47,.5)}
.logo .fizz{position:absolute;top:-.16em;right:-.14em;display:flex;gap:.06em;align-items:flex-start}
.logo .fizz i{width:.19em;height:.19em;border-radius:50%;background:var(--logo-lime);box-shadow:0 0 0 .05em var(--ring,#fff)}
.logo .fizz i:nth-child(2){width:.14em;height:.14em;background:var(--logo-lime2);margin-top:-.07em}
.logo .fizz i:nth-child(3){width:.1em;height:.1em;background:var(--logo-lime);margin-top:.05em}
.logo .fizz.blue i{background:var(--logo-accent)}
.logo .fizz.blue i:nth-child(2){background:var(--logo-accent2)}
.logo .fizz.blue i:nth-child(3){background:var(--logo-accent)}

/* Header -------------------------------------------------- */
.fel-site-header{position:sticky;top:0;z-index:30;background:color-mix(in oklab,var(--bg) 80%, transparent);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);margin:0}
.fel-site-header .nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.fel-site-header .nav-links{display:flex;gap:32px;list-style:none;margin:0;padding:0}
.fel-site-header .nav-links li{margin:0}
.fel-site-header .nav-links a{font-size:15px;font-weight:500;color:var(--muted);transition:color .15s;white-space:nowrap}
.fel-site-header .nav-links a:hover,.fel-site-header .nav-links a.active,.fel-site-header .nav-links .current-menu-item a{color:var(--ink)}
.fel-site-header .nav-links a.active,.fel-site-header .nav-links .current-menu-item a{font-weight:700}
.nav-cta{display:flex;align-items:center;gap:20px}
.nav-cta .login,.nav-cta .login a{font-size:15px;font-weight:600;white-space:nowrap;color:var(--ink)}

/* Buttons ------------------------------------------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--sans);font-weight:600;font-size:15px;cursor:pointer;transition:all .15s;white-space:nowrap;border:none;text-decoration:none}
.btn-primary{background:var(--accent);color:#fff;padding:11px 20px;border-radius:10px;box-shadow:0 8px 20px -8px var(--accent)}
.btn-primary:hover{background:var(--accent-ink);box-shadow:0 10px 24px -8px var(--accent);transform:translateY(-1px);color:#fff}
.btn-ghost{background:var(--surface);color:var(--ink);padding:11px 20px;border-radius:10px;border:1px solid var(--line-strong)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent-ink)}
.btn-lg{padding:15px 28px;font-size:16px;border-radius:12px}

/* Hide the signup CTA once logged in (login link becomes Log out) */
body.logged-in .fel-signup{display:none}

/* Hero ---------------------------------------------------- */
.hero{position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(46% 50% at 88% -6%, color-mix(in oklab,var(--accent) 22%, transparent), transparent 70%),
    radial-gradient(40% 46% at 6% 108%, color-mix(in oklab,var(--lime) 26%, transparent), transparent 70%)}
.hero-in{position:relative;z-index:1;padding:96px 0 84px;display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.pill{display:inline-flex;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--line-strong);color:var(--ink);font-size:13.5px;font-weight:600;padding:7px 15px 7px 11px;border-radius:999px;margin-bottom:26px;box-shadow:0 4px 14px -8px var(--accent)}
.pill .d{width:18px;height:18px;border-radius:50%;background:var(--lime-soft);display:flex;align-items:center;justify-content:center}
.pill .d::after{content:"";width:7px;height:7px;border-radius:50%;background:var(--lime-ink)}
.hero h1{font-size:62px;font-weight:900;line-height:1.06;letter-spacing:-.035em;margin-bottom:26px;text-wrap:balance;color:var(--ink)}
.accent{color:var(--accent)}
.uline{color:var(--accent);background-image:linear-gradient(transparent 80%, color-mix(in oklab,var(--lime) 85%, transparent) 80% 96%, transparent 96%);-webkit-box-decoration-break:clone;box-decoration-break:clone;padding:0 1px}
.hero p.lede{font-size:19px;color:var(--muted);line-height:1.58;max-width:42ch;margin-bottom:32px;text-wrap:pretty}
.hero-cta{display:flex;gap:13px;align-items:center}
.hero-meta{margin-top:34px;display:flex;gap:30px}
.hmeta b{display:flex;align-items:center;gap:7px;font-size:25px;font-weight:800;letter-spacing:-.02em}
.hmeta b .tick{width:9px;height:9px;border-radius:50%;background:var(--lime)}
.hmeta span{font-size:14px;color:var(--faint)}

/* hero quiz card */
.hero-visual{position:relative}
.hero-visual .glow{position:absolute;inset:-30px;background:radial-gradient(circle at 60% 40%, color-mix(in oklab,var(--accent) 30%, transparent), transparent 68%);filter:blur(10px);z-index:0}
.hero-card{position:relative;z-index:1;background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:24px;box-shadow:0 40px 70px -42px oklch(0.4 0.12 262 / .6),0 2px 0 0 oklch(1 0 0)}
.hc-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.hc-tag{font-size:12px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--accent-ink);background:var(--accent-soft);padding:6px 11px;border-radius:7px}
.hc-prog{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--faint)}
.hc-prog .bar{width:64px;height:6px;border-radius:3px;background:var(--panel);overflow:hidden}
.hc-prog .bar i{display:block;height:100%;width:39%;background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:3px}
.hc-q{font-size:19px;font-weight:700;margin-bottom:18px;line-height:1.32;letter-spacing:-.01em}
.opt{display:flex;align-items:center;gap:12px;padding:14px 15px;border:1.5px solid var(--line);border-radius:13px;margin-bottom:10px;font-size:15px;font-weight:600;transition:all .15s}
.opt .box{width:22px;height:22px;border-radius:7px;border:1.5px solid var(--line-strong);flex-shrink:0}
.opt.correct{border-color:var(--lime-ink);background:var(--lime-soft);color:var(--lime-ink)}
.opt.correct .box{background:var(--lime-ink);border-color:var(--lime-ink);position:relative}
.opt.correct .box::after{content:"";position:absolute;left:7px;top:3px;width:5px;height:10px;border:solid #fff;border-width:0 2.5px 2.5px 0;transform:rotate(42deg)}
.hc-foot{display:flex;align-items:center;justify-content:space-between;margin-top:18px;padding-top:16px;border-top:1px solid var(--line);font-size:13px;color:var(--faint);font-weight:500}
.hc-foot .score{display:inline-flex;align-items:center;gap:7px;color:var(--lime-ink);font-weight:800}
.hc-foot .score .dot{width:7px;height:7px;border-radius:50%;background:var(--lime)}

/* Levels strip ------------------------------------------- */
.strip{position:relative;z-index:2;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--surface)}
.strip-in{display:flex;align-items:center;gap:16px;padding:24px 0;flex-wrap:wrap}
.strip-label{font-size:13px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--faint);margin-right:6px}
.chip{font-size:14px;font-weight:800;color:var(--accent-ink);background:var(--accent-soft);border:1px solid color-mix(in oklab,var(--accent) 22%, transparent);border-radius:9px;padding:8px 16px;transition:all .15s}
.chip:hover{background:var(--accent);color:#fff;transform:translateY(-2px)}

/* Section ------------------------------------------------- */
.sec{padding:104px 0}
.sec-head{margin-bottom:48px}
.kicker{display:inline-flex;align-items:center;gap:9px;font-size:13px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.kicker::before{content:"";width:18px;height:18px;border-radius:50%;background:var(--lime-soft);position:relative;display:inline-block;box-shadow:inset 0 0 0 5px var(--lime)}
.sec-head h2{font-size:43px;font-weight:900;letter-spacing:-.035em;line-height:1.04;margin-bottom:14px;color:var(--ink)}
.sec-head p{font-size:17px;color:var(--muted);max-width:46ch}
.sec-head.row{display:flex;align-items:flex-end;justify-content:space-between;gap:30px}
.sec-head.row .sec-head-l{margin-bottom:0}
.see-all{font-size:15px;font-weight:700;color:var(--accent);white-space:nowrap;display:inline-flex;align-items:center;gap:6px;transition:gap .15s}
.see-all:hover{gap:10px}

/* Material cards ----------------------------------------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;list-style:none;margin:0;padding:0}
.cards li{margin:0}
.card{background:var(--surface);border:1px solid var(--line);border-radius:18px;overflow:hidden;display:flex;flex-direction:column;transition:all .18s;height:100%}
.card:hover{transform:translateY(-4px);box-shadow:0 26px 50px -32px oklch(0.4 0.1 262 / .55);border-color:color-mix(in oklab,var(--accent) 30%, var(--line))}
.card-img{height:152px;position:relative;overflow:hidden;background:var(--panel) center/cover no-repeat}
/* Featured image, when set, fills the cover and wins over the assigned cover art */
.card-img .wp-block-post-featured-image{position:absolute;inset:0;margin:0;z-index:1}
.card-img .wp-block-post-featured-image img,.card-img img{width:100%;height:100%;object-fit:cover;display:block}

/* Cover art — real cover PNGs from the design bundle, rotated across cards
   so each gets a different one. A set featured image still overrides this. */
.cards .card:nth-child(12n+1) .card-img{background-image:url('covers/grammar-1.png')}
.cards .card:nth-child(12n+2) .card-img{background-image:url('covers/vocab-1.png')}
.cards .card:nth-child(12n+3) .card-img{background-image:url('covers/reading-1.png')}
.cards .card:nth-child(12n+4) .card-img{background-image:url('covers/listening-1.png')}
.cards .card:nth-child(12n+5) .card-img{background-image:url('covers/writing-1.png')}
.cards .card:nth-child(12n+6) .card-img{background-image:url('covers/grammar-2.png')}
.cards .card:nth-child(12n+7) .card-img{background-image:url('covers/speaking-1.png')}
.cards .card:nth-child(12n+8) .card-img{background-image:url('covers/vocab-2.png')}
.cards .card:nth-child(12n+9) .card-img{background-image:url('covers/progress-1.png')}
.cards .card:nth-child(12n+10) .card-img{background-image:url('covers/grammar-3.png')}
.cards .card:nth-child(12n+11) .card-img{background-image:url('covers/listening-2.png')}
.cards .card:nth-child(12n+12) .card-img{background-image:url('covers/flask-1.png')}
.card-img .lvl{position:absolute;top:12px;left:12px;font-size:12px;font-weight:800;letter-spacing:.03em;color:#fff;background:var(--accent);padding:5px 10px;border-radius:7px;box-shadow:0 6px 14px -6px var(--accent);z-index:2}
.card-img .access{position:absolute;top:12px;right:12px;font-size:11px;font-weight:700;letter-spacing:.03em;color:var(--lime-ink);background:var(--lime-soft);padding:5px 9px;border-radius:7px;z-index:2}
.card-body{padding:21px 21px 23px;flex:1;display:flex;flex-direction:column}
.card-tag{font-size:12px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--accent-ink);margin-bottom:11px}
.card h3{font-size:20px;font-weight:800;letter-spacing:-.015em;line-height:1.2;margin-bottom:8px;color:var(--ink)}
.card h3 a{color:inherit}
.card p{font-size:14.5px;color:var(--muted);line-height:1.55;margin-bottom:18px}
.card-meta{margin-top:auto;display:flex;align-items:center;gap:12px;font-size:13px;color:var(--faint);font-weight:600}
.card-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--faint)}

/* Features ------------------------------------------------ */
.feat{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.fcard{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:30px 28px;overflow:hidden;transition:all .18s}
.fcard:hover{transform:translateY(-3px);box-shadow:0 22px 44px -32px oklch(0.4 0.1 262 / .5);border-color:color-mix(in oklab,var(--accent) 26%, var(--line))}
.fcard .ic{width:48px;height:48px;border-radius:13px;background:linear-gradient(135deg,var(--accent-soft),color-mix(in oklab,var(--lime) 24%, var(--surface)));color:var(--accent-ink);display:flex;align-items:center;justify-content:center;margin-bottom:20px;border:1px solid color-mix(in oklab,var(--accent) 16%, transparent)}
.fcard h3{font-size:19px;font-weight:800;letter-spacing:-.015em;margin-bottom:9px;color:var(--ink)}
.fcard p{font-size:15px;color:var(--muted);line-height:1.6}

/* CTA ----------------------------------------------------- */
.cta{position:relative;overflow:hidden;border-radius:26px;padding:74px 60px;text-align:center;color:#fff;margin:40px 0;
  background:linear-gradient(135deg,oklch(0.36 0.14 266),var(--accent))}
.cta::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(38% 60% at 84% 120%, color-mix(in oklab,var(--lime) 60%, transparent), transparent 70%),
    radial-gradient(30% 50% at 12% -10%, color-mix(in oklab,#fff 22%, transparent), transparent 70%)}
.cta .bubbles{position:absolute;inset:0;pointer-events:none}
.cta .bubbles i{position:absolute;border-radius:50%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.14)}
.cta-in{position:relative;z-index:1}
.cta h2{font-size:47px;font-weight:900;letter-spacing:-.035em;line-height:1.05;max-width:18ch;margin:0 auto 18px;text-wrap:balance;color:#fff}
.cta p{font-size:18px;color:oklch(0.92 0.03 262);max-width:44ch;margin:0 auto 34px}
.cta-cta{display:flex;gap:13px;justify-content:center}
.cta .btn-primary{background:#fff;color:var(--accent-ink);box-shadow:0 12px 30px -12px rgba(0,0,0,.5)}
.cta .btn-primary:hover{background:var(--lime-soft);color:var(--lime-ink)}
.cta .btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.35)}
.cta .btn-ghost:hover{border-color:#fff;color:#fff}

/* Footer -------------------------------------------------- */
.fel-site-footer{border-top:1px solid var(--line);padding:60px 0 46px;margin:0}
.foot{display:flex;justify-content:space-between;gap:40px}
.foot-brand{max-width:30ch}
.foot-brand p{font-size:14px;color:var(--muted);margin-top:14px;line-height:1.6}
.foot-cols{display:flex;gap:64px}
.foot-col h4{font-size:13px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--faint);margin-bottom:16px}
.foot-col a{display:block;font-size:15px;color:var(--muted);margin-bottom:11px;transition:color .15s}
.foot-col a:hover{color:var(--accent-ink)}
.foot-base{margin-top:50px;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;font-size:13.5px;color:var(--faint)}

/* ── Free Materials page ── */
.intro{position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.intro::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(44% 70% at 90% -20%, color-mix(in oklab,var(--accent) 16%, transparent), transparent 70%),
             radial-gradient(34% 60% at 4% 120%, color-mix(in oklab,var(--lime) 20%, transparent), transparent 70%)}
.intro-in{position:relative;z-index:1;padding:64px 0 40px}
.intro h1{font-size:50px;font-weight:900;letter-spacing:-.04em;line-height:1.02;margin-bottom:14px;color:var(--ink)}
.intro p{font-size:18px;color:var(--muted);max-width:54ch}
.searchbar{margin-top:30px;display:flex;align-items:center;gap:12px;max-width:520px;background:var(--surface);border:1px solid var(--line-strong);border-radius:13px;padding:5px 6px 5px 16px;box-shadow:0 10px 30px -22px var(--accent)}
.searchbar svg{flex-shrink:0;color:var(--faint)}
.searchbar input{flex:1;border:none;outline:none;font-family:var(--sans);font-size:16px;color:var(--ink);background:transparent;padding:10px 0}
.searchbar input::placeholder{color:var(--faint)}
.searchbar .btn-primary{padding:10px 18px}

.fbar{position:sticky;top:74px;z-index:20;background:color-mix(in oklab,var(--bg) 86%, transparent);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.fbar-in{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:16px 0}
.fpill{font-size:14px;font-weight:700;color:var(--muted);background:var(--surface);border:1px solid var(--line-strong);border-radius:999px;padding:9px 16px;cursor:pointer;transition:all .14s;white-space:nowrap}
.fpill:hover{border-color:var(--accent);color:var(--accent-ink)}
.fpill.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 8px 18px -9px var(--accent)}
.fbar-sep{width:1px;height:24px;background:var(--line);margin:0 6px}
.lvls{display:flex;gap:7px;flex-wrap:wrap}
.lchip{font-size:13px;font-weight:800;color:var(--accent-ink);background:var(--accent-soft);border:1px solid color-mix(in oklab,var(--accent) 20%, transparent);border-radius:8px;padding:8px 13px;cursor:pointer;transition:all .14s}
.lchip:hover{transform:translateY(-1px)}
.lchip.active{background:var(--accent);color:#fff;border-color:var(--accent)}

.results{padding:34px 0 100px}
.results-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;gap:20px}
.count{font-size:15px;color:var(--muted);font-weight:600}
.count b{color:var(--ink);font-weight:800}
.sort{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--faint);font-weight:600}
.sort select{font-family:var(--sans);font-size:14px;font-weight:700;color:var(--ink);border:1px solid var(--line-strong);background:var(--surface);border-radius:9px;padding:8px 12px;cursor:pointer}
.access.link{color:var(--muted);background:var(--panel)}
.access.account{color:var(--accent-ink);background:var(--accent-soft)}
.empty{display:none;text-align:center;padding:70px 0;color:var(--muted)}
.empty.show{display:block}
.empty h3{font-size:22px;font-weight:800;color:var(--ink);margin-bottom:8px}
.loadmore{display:flex;justify-content:center;margin-top:44px}
.loadmore .wp-block-query-pagination{justify-content:center}

/* ── LifterLMS account / forms (/my-account/) ── */
.fel-design .llms-person-login-form-wrapper,
.fel-design .llms-new-person-form-wrapper{
  max-width:680px;margin:0 auto 28px;background:var(--surface);
  border:1px solid var(--line);border-radius:18px;padding:32px 34px;
  box-shadow:0 26px 50px -40px oklch(0.4 0.1 262 / .5)}
.fel-design .llms-form-heading{font-size:19px;font-weight:800;letter-spacing:-.015em;color:var(--ink);margin:0 0 18px;line-height:1.15}
.fel-design .llms-form-fields{display:block}
.fel-design .llms-field{margin-bottom:16px}
.fel-design .llms-field label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:6px}
/* Required-field asterisk — brand lime (the bright fizz lime) */
.fel-design .llms-required{color:var(--lime);font-weight:800;margin-left:3px}
/* Inputs */
.fel-design .llms-field-input{width:100%;font-family:var(--sans);font-size:15px;color:var(--ink);
  background:var(--surface);border:1px solid var(--line-strong);border-radius:11px;padding:12px 14px;
  transition:border-color .15s,box-shadow .15s}
.fel-design .llms-field-input:focus{outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px color-mix(in oklab,var(--accent) 18%, transparent)}
.fel-design .llms-field-input::placeholder{color:var(--faint)}
.fel-design .llms-field input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px;vertical-align:-2px;margin-right:7px}
.fel-design .llms-field-checkbox label,.fel-design label[for="llms_remember"]{display:inline-block;font-weight:600;color:var(--muted)}
/* Primary submit buttons (Login / Register) */
.fel-design .llms-button-action{display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--sans);font-weight:600;font-size:15px;color:#fff;background:var(--accent);border:none;
  border-radius:10px;padding:13px 26px;cursor:pointer;box-shadow:0 8px 20px -8px var(--accent);transition:all .15s}
.fel-design .llms-button-action:hover{background:var(--accent-ink);box-shadow:0 10px 24px -8px var(--accent);transform:translateY(-1px);color:#fff}
.fel-design .llms-button-secondary{background:var(--surface);color:var(--ink);border:1px solid var(--line-strong);border-radius:10px;padding:13px 26px;font-weight:600;box-shadow:none}
.fel-design .llms-button-secondary:hover{border-color:var(--accent);color:var(--accent-ink)}
/* Links inside the forms (lost password, etc.) */
.fel-design .llms-person-login-form-wrapper a,
.fel-design .llms-new-person-form-wrapper a{color:var(--accent-ink);font-weight:600}
.fel-design .llms-person-login-form-wrapper a:hover,
.fel-design .llms-new-person-form-wrapper a:hover{color:var(--accent)}
/* Validation / error states */
.fel-design .llms-field-input.error,.fel-design .llms-field-input[aria-invalid="true"]{border-color:var(--wrong);box-shadow:0 0 0 3px color-mix(in oklab,var(--wrong) 16%, transparent)}
.fel-design .llms-error,.fel-design .llms-notice.llms-error{color:var(--wrong-ink)}

/* Responsive --------------------------------------------- */
@media (max-width:1000px){
  .fel-design .wrap{padding-inline:36px}
  .fel-site-header .nav-links{display:none}
  .hero-in{grid-template-columns:1fr;gap:44px;padding:64px 0 64px}
  .hero h1{font-size:54px}
  .hero-visual{max-width:440px}
  .cards,.feat,.grid{grid-template-columns:1fr 1fr;gap:18px}
  .sec{padding:72px 0}
  .cta{padding:56px 36px}
  .cta h2,.sec-head h2{font-size:36px}
  .intro h1{font-size:40px}
  .fbar{top:0}
}
@media (max-width:640px){
  .fel-design .wrap{padding-inline:22px}
  .nav-cta .login{display:none}
  .hero h1{font-size:42px}
  .hero-meta{flex-wrap:wrap;gap:20px}
  .cards,.feat,.grid{grid-template-columns:1fr}
  .foot{flex-direction:column;gap:32px}
  .foot-cols{gap:40px;flex-wrap:wrap}
  .cta h2,.sec-head h2{font-size:30px}
  .intro h1{font-size:32px}
}

/* ── 404 page (scoped to body.error404 / .e404) ── */
body.error404 .wp-site-blocks{display:flex;flex-direction:column;min-height:100vh}
main.e404{flex:1;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;text-align:center}
main.e404::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(42% 55% at 84% -10%, color-mix(in oklab,var(--accent) 20%, transparent), transparent 70%),
    radial-gradient(40% 52% at 10% 112%, color-mix(in oklab,var(--lime) 24%, transparent), transparent 70%)}

/* floating decorative bubbles */
.e404 .bubbles{position:absolute;inset:0;z-index:0;pointer-events:none}
.e404 .bubbles i{position:absolute;border-radius:50%;opacity:.5}
@media (prefers-reduced-motion: no-preference){ .e404 .bubbles i{animation:fel-rise linear infinite} }
@keyframes fel-rise{0%{transform:translateY(0) scale(1);opacity:0}10%{opacity:.6}100%{transform:translateY(-130px) scale(1.15);opacity:0}}

.e404-in{position:relative;z-index:1;padding:60px 32px;max-width:760px}
.e404 .chip{display:inline-flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line-strong);
  color:var(--ink);font-size:13.5px;font-weight:700;padding:8px 16px 8px 12px;border-radius:999px;margin-bottom:34px;
  box-shadow:0 6px 18px -10px var(--accent)}
.e404 .chip:hover{background:var(--surface);color:var(--ink);transform:none}
.e404 .chip .blip{width:9px;height:9px;border-radius:50%;background:var(--wrong);box-shadow:0 0 0 4px color-mix(in oklab,var(--wrong) 22%, transparent)}

/* 404 centerpiece */
.e404 .big{display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:8px}
.e404 .big .d{font-size:230px;line-height:.9;font-weight:900;letter-spacing:-.05em;
  background:linear-gradient(150deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.e404 .flask{height:248px;width:auto;display:block;margin-bottom:6px}
.e404 .flask .glass{fill:none;stroke:var(--accent-ink);stroke-width:7;stroke-linejoin:round;stroke-linecap:round}
.e404 .flask .lid{stroke:var(--accent-ink);stroke-width:7;stroke-linecap:round}
.e404 .flask .fluid{fill:url(#limegrad)}
.e404 .flask .fb{fill:#fff;opacity:.85}
.e404 .flask .spark{fill:var(--lime)}

.e404 h1{font-size:40px;font-weight:800;letter-spacing:-.03em;line-height:1.06;margin:18px auto 16px;max-width:18ch;text-wrap:balance;color:var(--ink)}
.e404 .lead{font-size:18px;color:var(--muted);line-height:1.6;max-width:52ch;margin:0 auto 34px;text-wrap:pretty}
.e404-cta{display:flex;gap:13px;justify-content:center;flex-wrap:wrap}

.e404 .suggest{margin-top:38px;padding-top:26px;border-top:1px solid var(--line)}
.e404 .lab2{font-size:12px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--faint);margin-bottom:16px}
.e404 .chips{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;list-style:none;margin:0;padding:0}
.e404 .chips li{margin:0}
.e404 .scrap{display:inline-flex;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--line);border-radius:11px;
  padding:11px 15px;font-size:14px;font-weight:600;color:var(--ink);transition:all .15s}
.e404 .scrap:hover{border-color:var(--accent);color:var(--accent-ink);transform:translateY(-2px)}
.e404 .scrap .wp-block-post-title{font-size:14px;font-weight:600;margin:0;letter-spacing:0;line-height:1.2}
.e404 .scrap .lv,.e404 .scrap .wp-block-post-terms{font-size:11px;font-weight:800;color:#fff;background:var(--accent);padding:3px 7px;border-radius:6px;line-height:1.3}

@media (max-width:640px){
  .e404 .big .d{font-size:140px} .e404 .flask{height:152px} .e404 h1{font-size:30px} .e404 .lead{font-size:16px}
}
