/* ============================================================
   FLEXING DATA — Shared site stylesheet
   Used by: index.html, story/index.html, bootcamp/index.html,
            faq/index.html, community/index.html, challenge/index.html
   ============================================================ */
:root{
  --paper:#fffaf4; --paper-2:#fff3e9; --white:#ffffff;
  --ink:#18222f; --ink-2:#44515f; --muted:#6c7785;
  --line:rgba(24,34,47,.09); --line-soft:rgba(24,34,47,.06);
  --brand:#0a96c7; --brand-deep:#0a7ba6; --brand-soft:#e4f4fb;
  --coral:#ff7a59; --coral-soft:#fff0eb; --amber:#f5a623; --amber-soft:#fff5e1;
  --mint:#18a37b; --mint-soft:#e6f7f0; --violet:#7c5cff; --violet-soft:#efeaff;
  --shadow-sm:0 4px 14px -6px rgba(15,42,64,.18);
  --shadow:0 22px 48px -22px rgba(15,42,64,.30);
  --shadow-lg:0 40px 80px -30px rgba(15,42,64,.35);
  --radius:22px; --radius-sm:14px; --maxw:1160px;
}
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; scroll-padding-top:84px; }
body{ margin:0; background:var(--paper); color:var(--ink-2); font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif; font-size:17px; line-height:1.7; -webkit-font-smoothing:antialiased; overflow-x:hidden; }
h1,h2,h3,h4{ font-family:'Plus Jakarta Sans',system-ui,sans-serif; color:var(--ink); line-height:1.14; margin:0 0 .5em; font-weight:800; letter-spacing:-.02em; }
p{ margin:0 0 1em; } a{ color:var(--brand-deep); text-decoration:none; } img{ max-width:100%; display:block; }
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 22px; position:relative; z-index:1; }
.section{ padding:clamp(56px,7vw,104px) 0; position:relative; }
.tint-peach{ background:linear-gradient(180deg,var(--paper-2),var(--paper)); } .tint-white{ background:var(--white); }
.center{ text-align:center; } .narrow{ max-width:720px; margin-left:auto; margin-right:auto; }
.eyebrow{ display:inline-flex; align-items:center; gap:7px; font-family:'Plus Jakarta Sans',sans-serif; font-weight:700; font-size:12.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--brand-deep); background:var(--brand-soft); padding:7px 15px; border-radius:99px; margin-bottom:18px; }
.eyebrow.coral{ color:#d4502b; background:var(--coral-soft); } .eyebrow.mint{ color:#0c7a5a; background:var(--mint-soft); }
.eyebrow.amber{ color:#9a6206; background:var(--amber-soft); } .eyebrow.violet{ color:#5a3fd6; background:var(--violet-soft); }
.h-lead{ font-size:clamp(29px,4.4vw,46px); } .lede{ font-size:clamp(16px,2vw,19px); color:var(--ink-2); }
.src{ font-size:12px; color:var(--muted); margin-top:8px; } .src a{ color:var(--brand-deep); text-decoration:underline; }
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:9px; font-family:'Plus Jakarta Sans',sans-serif; font-weight:700; font-size:16px; padding:15px 26px; border-radius:13px; cursor:pointer; border:1.5px solid transparent; transition:transform .16s, box-shadow .16s, background .16s, color .16s; min-height:54px; white-space:nowrap; }
.btn-primary{ background:linear-gradient(135deg,var(--brand),var(--brand-deep)); color:#fff; box-shadow:0 12px 26px -10px rgba(10,150,199,.6); }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 18px 34px -10px rgba(10,150,199,.7); color:#fff; }
.btn-warm{ background:linear-gradient(135deg,#ff8a63,var(--coral)); color:#fff; box-shadow:0 12px 26px -10px rgba(255,122,89,.6); }
.btn-warm:hover{ transform:translateY(-2px); box-shadow:0 18px 34px -10px rgba(255,122,89,.7); color:#fff; }
.btn-ghost{ background:var(--white); color:var(--ink); border-color:var(--line); box-shadow:var(--shadow-sm); }
.btn-ghost:hover{ transform:translateY(-2px); border-color:var(--brand); color:var(--brand-deep); }
.btn-linkedin{ background:#0a66c2; color:#fff; border:none; box-shadow:0 8px 20px -8px rgba(10,102,194,.55); }
.btn-linkedin:hover{ background:#004182; color:#fff; transform:translateY(-2px); box-shadow:0 14px 28px -8px rgba(10,102,194,.65); }
.btn-linkedin svg{ fill:#fff; flex-shrink:0; }
.btn-lg{ padding:18px 32px; font-size:17px; min-height:60px; }

/* header */
.hdr{ position:sticky; top:0; z-index:50; background:rgba(255,250,244,.82); backdrop-filter:saturate(180%) blur(14px); -webkit-backdrop-filter:saturate(180%) blur(14px); border-bottom:1px solid var(--line-soft); }
.hdr-in{ display:flex; align-items:center; justify-content:space-between; height:72px; }
/* Image logo — used in header */
.logo{ display:flex; align-items:center; flex-shrink:0; }
.logo img{ height:36px; width:auto; display:block; }
/* Text logo fallback — footer uses this */
.logo-text{ font-family:'Plus Jakarta Sans',sans-serif; font-weight:800; font-size:23px; letter-spacing:-.03em; color:var(--ink); }
.logo-text b{ color:var(--brand); }
.nav{ display:flex; align-items:center; gap:24px; }
.nav a.lnk{ font-weight:600; font-size:15px; color:var(--ink-2); white-space:nowrap; padding:4px 2px; }
.nav a.lnk:hover{ color:var(--brand-deep); }
.nav a.lnk.active{ color:var(--brand-deep); border-bottom:2px solid var(--brand); }
.hdr-cta{ display:flex; align-items:center; gap:12px; flex-shrink:0; }
.hdr-cta .btn{ font-size:14px; padding:11px 18px; min-height:44px; white-space:nowrap; }
.hamb{ display:none; flex-direction:column; justify-content:center; align-items:center; gap:5px; width:44px; height:44px; background:none; border:0; cursor:pointer; flex-shrink:0; }
.hamb span{ width:24px; height:2px; background:var(--ink); border-radius:2px; }
.mobile-nav{ display:none; flex-direction:column; gap:2px; padding:10px 22px 20px; background:var(--paper); border-bottom:1px solid var(--line); }
.mobile-nav a{ padding:12px 8px; font-weight:600; font-size:15px; color:var(--ink); border-bottom:1px solid var(--line-soft); }
.mobile-nav .btn{ margin-top:12px; }
@media(max-width:1080px){ .nav{ display:none; } .hamb{ display:flex; } .mobile-nav.open{ display:flex; } }

/* hero */
.hero{ position:relative; overflow:hidden; padding:clamp(50px,7vw,90px) 0 clamp(56px,7vw,98px); background:radial-gradient(60% 70% at 82% 8%, rgba(255,122,89,.13), transparent 60%), radial-gradient(55% 60% at 8% 30%, rgba(10,150,199,.12), transparent 60%), linear-gradient(180deg,var(--paper-2),var(--paper)); }
.hero::after{ content:""; position:absolute; inset:0; background-image:radial-gradient(rgba(10,150,199,.10) 1.2px, transparent 1.2px); background-size:28px 28px; animation:gridmove 20s linear infinite; opacity:.55; pointer-events:none; z-index:0; }
@keyframes gridmove{ from{ background-position:0 0; } to{ background-position:28px 28px; } }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:54px; align-items:center; }
.hero h1{ font-size:clamp(32px,5.2vw,57px); }
.hero h1 .hl{ position:relative; color:var(--brand-deep); white-space:nowrap; }
.hero h1 .hl::after{ content:""; position:absolute; left:0; right:0; bottom:.06em; height:.34em; background:linear-gradient(90deg,rgba(255,122,89,.45),rgba(245,166,35,.4)); border-radius:6px; z-index:-1; }
.hero .sub{ font-size:clamp(16px,2.1vw,20px); color:var(--ink-2); max-width:560px; margin:18px 0 26px; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; margin-bottom:20px; }
.hero-trust{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; color:var(--muted); font-size:14.5px; }
.hero-trust .stars{ color:var(--amber); letter-spacing:1px; } .hero-trust b{ color:var(--ink); }
.avatars{ display:flex; } .avatars span{ width:34px; height:34px; border-radius:50%; border:2px solid var(--paper); margin-left:-10px; font-size:13px; font-weight:700; color:#fff; display:flex; align-items:center; justify-content:center; } .avatars span:first-child{ margin-left:0; }
.hero-art{ position:relative; }
.hero-card{ background:var(--white); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); padding:22px; position:relative; z-index:2; }
.hero-card .bars{ display:flex; align-items:flex-end; gap:10px; height:128px; margin:6px 4px 14px; }
.hero-card .bars i{ flex:1; border-radius:7px 7px 4px 4px; background:linear-gradient(180deg,var(--brand),#7fd0ea); opacity:.92; animation:grow 1.4s ease both, pulseBar 3.2s ease-in-out infinite; transform-origin:bottom; }
.hero-card .bars i:nth-child(2){ background:linear-gradient(180deg,var(--coral),#ffb59f); animation-delay:.08s,.4s; }
.hero-card .bars i:nth-child(3){ background:linear-gradient(180deg,var(--amber),#ffd98a); animation-delay:.16s,.8s; }
.hero-card .bars i:nth-child(4){ background:linear-gradient(180deg,var(--mint),#7fe0c1); animation-delay:.24s,1.2s; }
.hero-card .bars i:nth-child(5){ background:linear-gradient(180deg,var(--violet),#bcacff); animation-delay:.32s,1.6s; }
@keyframes grow{ from{ transform:scaleY(.05); opacity:0; } to{ transform:scaleY(1); opacity:.92; } }
@keyframes pulseBar{ 0%,100%{ transform:scaleY(1); } 50%{ transform:scaleY(.9); } }
.hero-card .row{ display:flex; align-items:center; justify-content:space-between; font-size:13px; color:var(--muted); padding:4px 4px 0; }
.float-chip{ position:absolute; background:#fff; border:1px solid var(--line); border-radius:12px; padding:8px 13px; font-family:'Plus Jakarta Sans',sans-serif; font-weight:700; font-size:13px; color:var(--ink); box-shadow:var(--shadow); z-index:3; animation:floaty 5.5s ease-in-out infinite; }
.float-chip .e{ margin-right:5px; }
@keyframes floaty{ 0%,100%{ transform:translateY(0) } 50%{ transform:translateY(-12px) } }
.fc1{ top:-18px; left:-20px; animation-delay:0s; } .fc2{ top:40%; right:-26px; animation-delay:1.1s; } .fc3{ bottom:-16px; left:8%; animation-delay:2.2s; } .fc4{ top:-10px; right:6%; animation-delay:1.7s; }
@media(max-width:920px){ .hero-grid{ grid-template-columns:1fr; gap:44px; } .hero-art{ max-width:430px; margin:0 auto; } .fc1{ left:-6px } .fc2{ right:-8px } }
@media(max-width:480px){ .float-chip{ font-size:12px; padding:6px 10px; } }

.shead{ max-width:680px; margin-bottom:46px; } .shead.center{ margin-left:auto; margin-right:auto; }

/* page hero (subpages) */
.page-hero{ background:linear-gradient(135deg,var(--paper-2),var(--paper)); padding:clamp(40px,6vw,72px) 0 clamp(32px,4vw,56px); border-bottom:1px solid var(--line); }
.page-hero .eyebrow{ margin-bottom:14px; }
.page-hero h1{ font-size:clamp(28px,4.5vw,48px); margin-bottom:16px; }
.page-hero .sub{ font-size:clamp(16px,2vw,19px); color:var(--ink-2); max-width:640px; margin-bottom:0; }

/* breadcrumb */
.breadcrumb{ font-size:14px; color:var(--muted); margin-bottom:20px; display:flex; align-items:center; gap:7px; flex-wrap:wrap; }
.breadcrumb a{ color:var(--brand-deep); } .breadcrumb span{ color:var(--muted); }

/* founder */
.founder-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:54px; align-items:start; }
.founder-photo img{ border-radius:24px; width:100%; box-shadow:var(--shadow-lg); display:block; }
.founder-cap{ display:flex; align-items:center; gap:12px; margin-top:16px; background:var(--white); border:1px solid var(--line); border-radius:16px; padding:14px 16px; box-shadow:var(--shadow-sm); }
.founder-cap .ic{ width:42px; height:42px; border-radius:50%; background:linear-gradient(135deg,var(--brand),var(--brand-deep)); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:800; flex-shrink:0; }
.founder-cap .nm{ font-family:'Plus Jakarta Sans',sans-serif; font-weight:800; color:var(--ink); font-size:15px; } .founder-cap .rl{ font-size:13px; color:var(--muted); }
.founder-quote{ font-family:'Plus Jakarta Sans',sans-serif; font-size:clamp(20px,2.7vw,28px); font-weight:800; color:var(--ink); line-height:1.32; margin:0 0 18px; } .founder-quote em{ color:var(--brand-deep); font-style:normal; }
.cred-row{ display:flex; flex-wrap:wrap; gap:8px; margin:22px 0 18px; }
.cred{ font-size:13px; font-weight:600; color:var(--ink-2); background:var(--white); border:1px solid var(--line); border-radius:99px; padding:7px 14px; box-shadow:var(--shadow-sm); } .cred b{ color:var(--brand-deep); }
.timeline{ margin-top:24px; border-left:2px dashed var(--line); padding-left:26px; }
.tl{ position:relative; padding-bottom:22px; } .tl:last-child{ padding-bottom:0; }
.tl::before{ content:""; position:absolute; left:-34px; top:2px; width:15px; height:15px; border-radius:50%; background:var(--brand); border:3px solid var(--paper); box-shadow:0 0 0 2px var(--brand); }
.tl.c::before{ background:var(--coral); box-shadow:0 0 0 2px var(--coral); } .tl.m::before{ background:var(--mint); box-shadow:0 0 0 2px var(--mint); } .tl.v::before{ background:var(--violet); box-shadow:0 0 0 2px var(--violet); }
.tl .yr{ font-family:'Plus Jakarta Sans',sans-serif; font-weight:800; font-size:13px; letter-spacing:.05em; text-transform:uppercase; color:var(--muted); }
.tl h4{ margin:2px 0 4px; font-size:17px; } .tl p{ margin:0; font-size:14.5px; color:var(--ink-2); }
@media(max-width:860px){ .founder-grid{ grid-template-columns:1fr; gap:30px; } .founder-photo{ max-width:360px; } }

/* generic cards */
.cards-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; } .cards-4{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
@media(max-width:900px){ .cards-3,.cards-4{ grid-template-columns:1fr 1fr; } } @media(max-width:560px){ .cards-3,.cards-4{ grid-template-columns:1fr; } }
.card{ background:var(--white); border:1px solid var(--line); border-radius:var(--radius); padding:28px; box-shadow:var(--shadow-sm); transition:transform .2s, box-shadow .2s; height:100%; }
.card:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
.card .ic{ width:52px; height:52px; border-radius:15px; display:flex; align-items:center; justify-content:center; font-size:24px; margin-bottom:16px; }
.card h3{ font-size:19px; margin-bottom:8px; } .card p{ font-size:15px; color:var(--ink-2); margin:0; }
.card .out{ display:block; margin-top:14px; font-size:13.5px; font-weight:600; color:var(--brand-deep); }
.ic.cyan{ background:var(--brand-soft); } .ic.coral{ background:var(--coral-soft); } .ic.amber{ background:var(--amber-soft); } .ic.mint{ background:var(--mint-soft); } .ic.violet{ background:var(--violet-soft); }
.stat-inline{ font-family:'Plus Jakarta Sans',sans-serif; font-weight:800; color:var(--ink); font-size:15px; }

/* who cards */
.who-card{ display:block; text-decoration:none; cursor:pointer; }
.who-card:hover{ transform:translateY(-6px) scale(1.03); box-shadow:var(--shadow-lg); border-color:var(--brand); }
.who-card .go{ display:inline-block; margin-top:12px; font-size:13px; font-weight:700; color:var(--brand-deep); opacity:0; transform:translateY(4px); transition:.2s; }
.who-card:hover .go{ opacity:1; transform:none; }

/* network */
.net{ background:linear-gradient(135deg,#11212e,#16344a); color:#dceaf2; border-radius:30px; padding:clamp(30px,5vw,56px); box-shadow:var(--shadow-lg); overflow:hidden; position:relative; }
.net h2{ color:#fff; } .net .lede{ color:#bcd3e0; } .net .eyebrow{ background:rgba(255,255,255,.12); color:#bfe6f4; }
.net-co{ display:flex; flex-wrap:wrap; gap:10px; margin:24px 0 26px; }
.net-co span{ font-family:'Plus Jakarta Sans',sans-serif; font-weight:700; font-size:14.5px; color:#fff; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.16); border-radius:12px; padding:10px 16px; }
.net-roles{ display:flex; flex-wrap:wrap; gap:10px; } .net-roles span{ font-size:13.5px; color:#cfe0ea; background:rgba(255,255,255,.06); border-radius:99px; padding:7px 14px; }

/* roadmap */
.road{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; } @media(max-width:860px){ .road{ grid-template-columns:1fr; gap:18px; } }
.road-step{ background:var(--white); border:1px solid var(--line); border-radius:var(--radius); padding:30px 26px; box-shadow:var(--shadow-sm); position:relative; overflow:hidden; }
.road-step::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:5px; }
.road-step.s1::before{ background:var(--brand); } .road-step.s2::before{ background:var(--coral); } .road-step.s3::before{ background:var(--mint); }
.road-month{ font-family:'Plus Jakarta Sans',sans-serif; font-weight:800; font-size:13px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); }
.road-step h3{ font-size:22px; margin:6px 0 14px; }
.road-list{ list-style:none; padding:0; margin:0; } .road-list li{ font-size:14.5px; padding:7px 0 7px 26px; position:relative; color:var(--ink-2); } .road-list li::before{ content:"✓"; position:absolute; left:0; font-weight:800; color:var(--mint); }
.road-num{ position:absolute; right:22px; top:22px; font-family:'Plus Jakarta Sans',sans-serif; font-weight:800; font-size:46px; line-height:1; color:var(--line); }
.addons-head{ display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; margin:40px 0 18px; }
.addons-head h3{ font-size:24px; margin:0; }
.addons-head .tagfree{ font-family:'Plus Jakarta Sans',sans-serif; font-weight:800; font-size:12.5px; letter-spacing:.05em; color:#0c7a5a; background:var(--mint-soft); border:1px solid #b8ead4; border-radius:99px; padding:8px 16px; }
.addons{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; } @media(max-width:860px){ .addons{ grid-template-columns:1fr 1fr; } } @media(max-width:520px){ .addons{ grid-template-columns:1fr; } }
.addon{ background:var(--white); border:1px solid var(--line); border-radius:18px; padding:22px; box-shadow:var(--shadow-sm); transition:transform .2s, box-shadow .2s; position:relative; }
.addon:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
.addon .ic{ width:48px; height:48px; border-radius:13px; display:flex; align-items:center; justify-content:center; font-size:23px; margin-bottom:12px; }
.addon h4{ font-size:16px; margin:0 0 4px; } .addon p{ font-size:13.5px; color:var(--ink-2); margin:0; }
.addon .inb{ position:absolute; top:16px; right:16px; font-size:10.5px; font-weight:800; letter-spacing:.04em; color:#0c7a5a; background:var(--mint-soft); border-radius:99px; padding:4px 9px; }

/* marquee */
.marq{ overflow:hidden; -webkit-mask:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); mask:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); }
.marq-drag{ cursor:grab; touch-action:pan-y; -webkit-user-select:none; user-select:none; will-change:transform; }
.marq-drag:active{ cursor:grabbing; }
.marq-track{ display:flex; align-items:stretch; width:max-content; animation:marqueeX linear infinite; }
.marq-track.spd-tools{ animation-duration:50s; }
.marq:hover .marq-track, .marq.dragging .marq-track{ animation-play-state:paused; }
@keyframes marqueeX{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
.tool-card{ flex:0 0 auto; width:152px; height:98px; margin-right:22px; background:var(--white); border:1px solid var(--line); border-radius:18px; box-shadow:var(--shadow-sm); display:flex; align-items:center; justify-content:center; padding:18px; }
.tool-card img{ max-height:54px; max-width:112px; width:auto; object-fit:contain; pointer-events:none; -webkit-user-drag:none; }

/* assessment */
.assess{ background:radial-gradient(60% 80% at 85% 15%, rgba(10,150,199,.16), transparent 60%), radial-gradient(50% 70% at 10% 90%, rgba(124,92,255,.12), transparent 60%), linear-gradient(135deg,#0e2233,#143a52); color:#eaf3f8; border-radius:30px; padding:clamp(30px,5vw,64px); box-shadow:var(--shadow-lg); overflow:hidden; position:relative; }
.assess-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center; }
.assess h2{ color:#fff; font-size:clamp(26px,3.6vw,40px); } .assess p{ color:#bcd3e0; } .assess .eyebrow{ background:rgba(255,255,255,.12); color:#bfe6f4; }
.assess-list{ list-style:none; padding:0; margin:18px 0 30px; display:grid; grid-template-columns:1fr 1fr; gap:12px 22px; }
.assess-list li{ font-size:15px; color:#dceaf2; padding-left:28px; position:relative; } .assess-list li::before{ content:"→"; position:absolute; left:0; color:var(--coral); font-weight:800; }
.assess-panel{ background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.16); border-radius:var(--radius); padding:26px; backdrop-filter:blur(6px); }
.assess-panel .score{ display:flex; align-items:baseline; gap:8px; } .assess-panel .score .n{ font-family:'Plus Jakarta Sans',sans-serif; font-weight:800; font-size:58px; color:#fff; line-height:1; } .assess-panel .score .p{ color:#9fd9ec; font-weight:700; }
.meter{ height:9px; border-radius:99px; background:rgba(255,255,255,.14); overflow:hidden; margin:8px 0 4px; } .meter i{ display:block; height:100%; border-radius:99px; background:linear-gradient(90deg,var(--coral),var(--amber)); }
.assess-panel .lbl{ display:flex; justify-content:space-between; font-size:12.5px; color:#9fb8c6; margin-bottom:16px; }
.skillbar{ margin:12px 0; } .skillbar .t{ display:flex; justify-content:space-between; font-size:13px; color:#dceaf2; margin-bottom:5px; } .skillbar .track{ height:7px; border-radius:99px; background:rgba(255,255,255,.13); overflow:hidden; } .skillbar .track i{ display:block; height:100%; border-radius:99px; background:linear-gradient(90deg,#37b6db,#7fd0ea); }
.assess-after{ display:flex; flex-wrap:wrap; gap:10px; margin-top:8px; } .assess-after span{ font-size:13px; color:#bcd3e0; }
@media(max-width:860px){ .assess-grid{ grid-template-columns:1fr; gap:34px; } .assess-list{ grid-template-columns:1fr; } }

/* mentorship panels */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:22px; } @media(max-width:820px){ .split{ grid-template-columns:1fr; } }
.panel{ border-radius:var(--radius); padding:34px; box-shadow:var(--shadow-sm); border:1px solid var(--line); background:var(--white); position:relative; overflow:hidden; }
.panel.warm{ background:linear-gradient(140deg,#fff6ef,#ffeadf); border-color:#ffd9c7; } .panel.cool{ background:linear-gradient(140deg,#eef8fc,#e2f1f9); border-color:#cfe9f4; }
.panel h3{ font-size:23px; margin-bottom:8px; }
.panel .when{ display:inline-flex; align-items:center; gap:8px; font-weight:700; font-size:14px; color:var(--brand-deep); background:var(--white); border:1px solid var(--line); border-radius:99px; padding:7px 14px; margin-bottom:14px; } .panel.warm .when{ color:#d4502b; }
.panel .scarce{ display:inline-flex; align-items:center; gap:6px; font-size:12.5px; font-weight:700; color:#9a6206; background:var(--amber-soft); border:1px solid #f5deb0; border-radius:99px; padding:5px 12px; margin:0 0 14px 8px; }
.panel p{ font-size:15px; }
.chips{ display:flex; flex-wrap:wrap; gap:12px; justify-content:center; }
.chip{ display:inline-flex; align-items:center; gap:9px; background:var(--white); border:1px solid var(--line); border-radius:14px; padding:12px 18px; font-weight:600; font-size:15px; color:var(--ink); box-shadow:var(--shadow-sm); } .chip .e{ font-size:18px; }

/* community */
.comm-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; } @media(max-width:860px){ .comm-grid{ grid-template-columns:1fr; } }
.comm{ border-radius:var(--radius); padding:30px 28px; color:#fff; position:relative; overflow:hidden; box-shadow:var(--shadow); }
.comm h3{ color:#fff; font-size:21px; margin-bottom:6px; } .comm p{ color:rgba(255,255,255,.92); font-size:14.5px; margin-bottom:20px; }
.comm .brandic{ width:46px; height:46px; border-radius:13px; background:rgba(255,255,255,.16); display:flex; align-items:center; justify-content:center; margin-bottom:14px; } .comm .brandic svg{ width:26px; height:26px; fill:#fff; }
.comm a{ display:inline-flex; align-items:center; gap:8px; background:rgba(255,255,255,.18); color:#fff; font-weight:700; padding:11px 20px; border-radius:11px; font-size:14.5px; backdrop-filter:blur(4px); transition:background .16s; } .comm a:hover{ background:rgba(255,255,255,.3); }
.comm.discord{ background:linear-gradient(140deg,#5865F2,#7d5bf0); } .comm.whatsapp{ background:linear-gradient(140deg,#1faa53,#25D366); } .comm.linkedin{ background:linear-gradient(140deg,#0a66c2,#3b8fd6); }
.flexy{ display:flex; align-items:center; gap:16px; flex-wrap:wrap; justify-content:center; margin-top:28px; background:var(--violet-soft); border:1px solid #ddd3ff; border-radius:18px; padding:18px 22px; }
.flexy .ava{ width:52px; height:52px; border-radius:50%; background:linear-gradient(135deg,#b78cff,#7c5cff); display:flex; align-items:center; justify-content:center; font-size:26px; flex-shrink:0; box-shadow:var(--shadow-sm); } .flexy b{ color:var(--ink); }

/* team */
.team-grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:18px; } @media(max-width:900px){ .team-grid{ grid-template-columns:repeat(3,1fr); } } @media(max-width:560px){ .team-grid{ grid-template-columns:repeat(2,1fr); } }
.team-card{ background:var(--white); border:1px solid var(--line); border-radius:22px; padding:24px 16px 20px; text-align:center; box-shadow:var(--shadow-sm); transition:transform .22s, box-shadow .22s; }
.team-card:hover{ transform:translateY(-7px) scale(1.04); box-shadow:var(--shadow-lg); }
.team-ring{ width:122px; height:122px; margin:0 auto 14px; border-radius:50%; padding:4px; background:linear-gradient(135deg,var(--coral),var(--brand),var(--violet)); }
.team-card img{ width:100%; height:100%; border-radius:50%; object-fit:cover; border:3px solid #fff; background:var(--paper-2); }
.team-card .nm{ font-family:'Plus Jakarta Sans',sans-serif; font-weight:700; color:var(--ink); font-size:15.5px; }
.team-card .rl{ font-size:12.5px; color:var(--muted); margin-top:4px; min-height:34px; }
.team-card a.li{ display:inline-flex; margin-top:10px; width:32px; height:32px; border-radius:9px; background:var(--brand-soft); color:var(--brand-deep); align-items:center; justify-content:center; } .team-card a.li svg{ width:16px; height:16px; fill:currentColor; } .team-card a.li:hover{ background:var(--brand); color:#fff; }

/* testimonials */
.stat-strip{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-bottom:40px; } @media(max-width:700px){ .stat-strip{ grid-template-columns:1fr 1fr; } }
.stat{ text-align:center; background:var(--white); border:1px solid var(--line); border-radius:var(--radius-sm); padding:24px 12px; box-shadow:var(--shadow-sm); }
.stat .n{ font-family:'Plus Jakarta Sans',sans-serif; font-weight:800; font-size:clamp(28px,4vw,40px); color:var(--brand-deep); line-height:1; } .stat .l{ font-size:12.5px; text-transform:uppercase; letter-spacing:.05em; color:var(--muted); margin-top:8px; }
.tmarq{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; max-height:600px; overflow:hidden; position:relative; -webkit-mask:linear-gradient(180deg,transparent,#000 11%,#000 89%,transparent); mask:linear-gradient(180deg,transparent,#000 11%,#000 89%,transparent); }
.tcol{ display:flex; flex-direction:column; gap:18px; animation:tscroll 46s linear infinite; } .tcol.c2{ animation-duration:60s; } .tcol.c3{ animation-duration:52s; } .tcol.rev{ animation-direction:reverse; }
.tmarq:hover .tcol, .tmarq.focusing .tcol{ animation-play-state:paused; }
@keyframes tscroll{ from{ transform:translateY(0); } to{ transform:translateY(-50%); } }
.tcard{ background:var(--white); border:1px solid var(--line); border-radius:var(--radius); padding:22px; box-shadow:var(--shadow-sm); border-top:4px solid var(--brand); cursor:pointer; transition:transform .25s, box-shadow .25s, filter .25s, opacity .25s; }
.tcard.c{ border-top-color:var(--coral); } .tcard.m{ border-top-color:var(--mint); } .tcard.v{ border-top-color:var(--violet); } .tcard.a{ border-top-color:var(--amber); }
.tcard .stars{ color:var(--amber); font-size:13px; margin-bottom:8px; } .tcard p{ font-size:14.5px; color:var(--ink); line-height:1.6; margin:0 0 14px; }
.tcard .who{ display:flex; align-items:center; gap:11px; } .tcard .av{ width:38px; height:38px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:800; color:#fff; font-size:15px; } .tcard .nm{ font-family:'Plus Jakarta Sans',sans-serif; font-weight:700; color:var(--ink); font-size:14px; }
.tcard.focused{ transform:scale(1.06); box-shadow:var(--shadow-lg); border-color:var(--brand); position:relative; z-index:6; }
.tmarq.focusing .tcard:not(.focused){ filter:blur(2.5px); opacity:.45; }
.testi-foot{ text-align:center; margin-top:30px; } .testi-foot .ask{ font-family:'Plus Jakarta Sans',sans-serif; font-weight:700; color:var(--ink); font-size:18px; margin-bottom:14px; }
@media(max-width:820px){ .tmarq{ grid-template-columns:repeat(2,1fr); } .tcol.c3{ display:none; } } @media(max-width:540px){ .tmarq{ grid-template-columns:1fr; max-height:560px; } .tcol.c2{ display:none; } }

/* bootcamp */
.bc-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:44px; align-items:start; } @media(max-width:940px){ .bc-grid{ grid-template-columns:1fr; gap:32px; } }
.facts{ display:flex; flex-wrap:wrap; gap:8px; margin:18px 0; } .fact{ font-size:13.5px; font-weight:600; color:var(--ink-2); background:var(--white); border:1px solid var(--line); border-radius:99px; padding:8px 14px; box-shadow:var(--shadow-sm); } .fact b{ color:var(--brand-deep); }
.price-row{ display:flex; align-items:baseline; gap:12px; margin-bottom:18px; } .price-now{ font-family:'Plus Jakarta Sans',sans-serif; font-weight:800; font-size:38px; color:var(--ink); } .price-was{ font-size:19px; color:var(--muted); text-decoration:line-through; } .price-off{ font-size:13px; font-weight:700; color:#0c7a5a; background:var(--mint-soft); padding:4px 11px; border-radius:99px; }
.batch-line{ margin-top:14px; font-size:14px; color:var(--muted); } .batch-line b{ color:var(--coral); }
.enroll-card{ background:var(--white); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-lg); padding:26px; }
.enroll-card h3{ font-size:20px; margin-bottom:4px; } .enroll-card .seats{ display:inline-flex; align-items:center; gap:7px; font-size:13px; font-weight:700; color:#d4502b; background:var(--coral-soft); border-radius:99px; padding:6px 13px; margin-bottom:16px; }
.inc{ list-style:none; padding:0; margin:0 0 20px; } .inc li{ font-size:14.5px; color:var(--ink-2); padding:8px 0 8px 28px; position:relative; } .inc li::before{ content:"✓"; position:absolute; left:0; color:var(--mint); font-weight:800; }
.video-frame{ position:relative; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-lg); border:1px solid var(--line); aspect-ratio:16/9; background:#000; margin-top:36px; } .video-frame iframe{ width:100%; height:100%; border:0; display:block; }
.curri{ max-width:880px; margin:36px auto 0; }
.wk{ background:var(--white); border:1px solid var(--line); border-radius:var(--radius-sm); margin-bottom:12px; box-shadow:var(--shadow-sm); overflow:hidden; }
.wk-head{ display:flex; align-items:center; gap:14px; padding:16px 20px; cursor:pointer; list-style:none; } .wk-head::-webkit-details-marker{ display:none; }
.wk-tag{ flex-shrink:0; width:52px; height:52px; border-radius:13px; display:flex; flex-direction:column; align-items:center; justify-content:center; font-family:'Plus Jakarta Sans',sans-serif; font-weight:800; background:var(--brand-soft); color:var(--brand-deep); line-height:1; } .wk-tag small{ font-size:9px; font-weight:700; letter-spacing:.05em; opacity:.8; } .wk-tag b{ font-size:20px; }
.wk-title{ flex:1; } .wk-title .t{ font-family:'Plus Jakarta Sans',sans-serif; font-weight:700; color:var(--ink); font-size:16px; } .wk-title .s{ font-size:13px; color:var(--muted); margin-top:2px; }
.wk-state{ flex-shrink:0; font-size:12px; font-weight:700; } .wk-free{ color:#0c7a5a; background:var(--mint-soft); border-radius:99px; padding:5px 12px; } .wk-lock{ color:var(--muted); }
.wk-plus{ color:var(--brand); font-size:22px; transition:transform .2s; } details[open] .wk-plus{ transform:rotate(45deg); }
.wk-body{ padding:0 20px 8px; } .day{ border-top:1px solid var(--line-soft); padding:16px 0; } .day .dt{ font-family:'Plus Jakarta Sans',sans-serif; font-weight:700; color:var(--ink); font-size:15px; margin-bottom:8px; }
.day ul{ margin:0; padding-left:4px; list-style:none; } .day li{ font-size:14px; color:var(--ink-2); padding:5px 0 5px 24px; position:relative; } .day li::before{ content:"▸"; position:absolute; left:0; color:var(--brand); } .day li .ai{ font-weight:700; color:var(--violet); }
.wk.locked{ background:linear-gradient(180deg,#fbfaf8,#f6f4f1); } .wk.locked .wk-tag{ background:#edeef1; color:var(--muted); }
.wk-locked-body{ padding:2px 20px 16px; } .wk-locked-days{ display:flex; flex-wrap:wrap; gap:8px; filter:saturate(.6); } .wk-locked-days span{ font-size:13px; color:var(--ink-2); background:var(--white); border:1px solid var(--line); border-radius:10px; padding:7px 12px; }

/* certificate */
.cert-show{ margin-top:48px; } .cert-head{ max-width:680px; margin:0 auto 30px; }
.cert-frame{ max-width:840px; margin:0 auto; background:var(--white); border:1px solid var(--line); border-radius:24px; padding:14px; box-shadow:var(--shadow-lg); } .cert-frame img{ width:100%; border-radius:14px; display:block; }
.cert-badges{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-top:22px; } .cert-badges span{ font-size:13.5px; font-weight:600; color:var(--ink-2); background:var(--white); border:1px solid var(--line); border-radius:99px; padding:8px 16px; box-shadow:var(--shadow-sm); }

/* value */
.value-grid{ display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; } @media(max-width:820px){ .value-grid{ grid-template-columns:1fr; gap:28px; } }
.guar{ background:var(--white); border:1px solid var(--line); border-radius:var(--radius); padding:30px; box-shadow:var(--shadow); }
.guar h3{ font-size:20px; margin-bottom:14px; }
.guar ul{ list-style:none; padding:0; margin:0; } .guar li{ font-size:15px; color:var(--ink-2); padding:9px 0 9px 30px; position:relative; } .guar li::before{ content:"🤝"; position:absolute; left:0; }
.guar .cant{ margin-top:16px; padding-top:16px; border-top:1px dashed var(--line); font-size:14px; color:var(--muted); }
.compare{ display:flex; gap:14px; flex-wrap:wrap; margin-top:18px; } .compare div{ flex:1; min-width:150px; border:1px solid var(--line); border-radius:14px; padding:16px; } .compare .them{ background:#f7f7f8; } .compare .us{ background:var(--mint-soft); border-color:#b8ead4; } .compare .lab{ font-size:12px; text-transform:uppercase; letter-spacing:.04em; color:var(--muted); } .compare .val{ font-family:'Plus Jakarta Sans',sans-serif; font-weight:800; color:var(--ink); font-size:18px; margin-top:4px; }

/* 3 ways / challenge */
.ways{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:8px; } @media(max-width:860px){ .ways{ grid-template-columns:1fr; } }
.way{ border-radius:var(--radius); padding:30px 26px; border:1px solid rgba(255,255,255,.16); background:rgba(255,255,255,.06); backdrop-filter:blur(4px); position:relative; }
.way.feat{ border-color:rgba(255,122,89,.6); box-shadow:0 0 0 2px rgba(255,122,89,.4); }
.way .tg{ font-family:'Plus Jakarta Sans',sans-serif; font-weight:800; font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--coral); }
.way h3{ color:#fff; font-size:22px; margin:6px 0 6px; } .way .pr{ color:#ffd9cb; font-weight:700; font-size:15px; margin-bottom:14px; }
.way ul{ list-style:none; padding:0; margin:0 0 20px; } .way li{ color:rgba(255,255,255,.85); font-size:14px; padding:6px 0 6px 24px; position:relative; } .way li::before{ content:"›"; position:absolute; left:0; color:var(--coral); font-weight:800; }
.way .btn{ width:100%; }
.challenge{ position:relative; overflow:hidden; color:#fff; background:radial-gradient(50% 80% at 12% 10%, rgba(255,122,89,.5), transparent 60%), radial-gradient(60% 90% at 90% 90%, rgba(124,92,255,.45), transparent 60%), linear-gradient(135deg,#16121f,#241433); }
.challenge .eyebrow{ background:rgba(255,255,255,.14); color:#ffd9cb; } .challenge h2{ color:#fff; font-size:clamp(30px,5vw,52px); } .challenge .lede{ color:rgba(255,255,255,.85); }

/* faq + final */
.faq{ max-width:820px; margin:0 auto; } .faq details{ background:var(--white); border:1px solid var(--line); border-radius:var(--radius-sm); margin-bottom:12px; box-shadow:var(--shadow-sm); overflow:hidden; }
.faq summary{ list-style:none; cursor:pointer; padding:20px 24px; font-family:'Plus Jakarta Sans',sans-serif; font-weight:700; color:var(--ink); font-size:16px; display:flex; justify-content:space-between; align-items:center; gap:16px; } .faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; color:var(--brand); font-size:24px; font-weight:400; transition:transform .2s; } .faq details[open] summary::after{ transform:rotate(45deg); } .faq .a{ padding:0 24px 20px; color:var(--ink-2); font-size:15px; line-height:1.7; }
.final{ text-align:center; background:radial-gradient(60% 100% at 50% 0%, rgba(255,122,89,.14), transparent 60%), linear-gradient(180deg,var(--paper),var(--paper-2)); }
.final-photo{ width:96px; height:96px; border-radius:50%; object-fit:cover; margin:0 auto 18px; border:4px solid #fff; box-shadow:var(--shadow); }
.final h2{ font-size:clamp(30px,4.6vw,46px); }

/* footer */
.ftr{ background:#12202c; color:#aebcc7; padding:64px 0 30px; }
.ftr-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:34px; margin-bottom:42px; } @media(max-width:820px){ .ftr-grid{ grid-template-columns:1fr 1fr; gap:30px; } } @media(max-width:520px){ .ftr-grid{ grid-template-columns:1fr; } }
/* footer logo is always text-based (image logo is light-themed, doesn't work on dark bg) */
.ftr .logo{ font-family:'Plus Jakarta Sans',sans-serif; font-weight:800; font-size:24px; letter-spacing:-.03em; color:#fff; display:inline-flex; align-items:center; }
.ftr .logo b{ color:var(--brand); } .ftr p{ font-size:14.5px; color:#94a6b3; max-width:320px; }
.ftr h4{ color:#fff; font-size:13px; letter-spacing:.06em; text-transform:uppercase; margin-bottom:16px; } .ftr a{ color:#aebcc7; font-size:14.5px; display:block; padding:5px 0; } .ftr a:hover{ color:#fff; }
.ftr-social{ display:flex; gap:12px; margin-top:18px; } .ftr-social a{ width:40px; height:40px; border-radius:11px; background:rgba(255,255,255,.08); display:flex; align-items:center; justify-content:center; padding:0; } .ftr-social a svg{ width:18px; height:18px; fill:#cdd8e0; } .ftr-social a:hover{ background:var(--brand); } .ftr-social a:hover svg{ fill:#fff; } .ftr-social a[aria-label="WhatsApp"]:hover{ background:#25D366; }
.ftr-bot{ border-top:1px solid rgba(255,255,255,.1); padding-top:22px; text-align:center; font-size:13px; color:#7c8d9a; } .ftr-bot a{ display:inline; color:var(--brand); }

/* floating buttons */
.wa-float{ position:fixed; bottom:22px; right:22px; z-index:60; background:#25D366; color:#fff; padding:13px 20px; border-radius:99px; font-weight:700; font-size:15px; display:flex; align-items:center; gap:9px; box-shadow:0 14px 30px -10px rgba(37,211,102,.7); transition:transform .16s; } .wa-float:hover{ transform:translateY(-2px) scale(1.02); color:#fff; } .wa-float svg{ width:20px; height:20px; fill:#fff; }
@media(max-width:560px){ .wa-float span{ display:none; } .wa-float{ padding:15px; border-radius:50%; } }
#back-top{ position:fixed; bottom:82px; right:22px; z-index:59; width:44px; height:44px; border-radius:50%; border:none; background:var(--ink); color:#fff; font-size:20px; line-height:1; cursor:pointer; display:flex; align-items:center; justify-content:center; box-shadow:0 4px 14px rgba(15,42,64,.30); opacity:0; transform:translateY(10px); transition:opacity .24s, transform .24s, background .16s; pointer-events:none; }
#back-top.show{ opacity:1; transform:none; pointer-events:auto; }
#back-top:hover{ background:var(--brand-deep); }
#back-top:focus-visible{ outline:2px solid var(--brand); outline-offset:3px; }
@media(max-width:560px){ #back-top{ bottom:90px; right:14px; } }

/* mobile polish */
html,body{ overflow-x:hidden; max-width:100%; }
@media(max-width:920px){ .float-chip{ display:none !important; } }
@media(max-width:600px){
  .btn{ white-space:normal; text-align:center; }
  .hero-cta{ flex-direction:column; align-items:stretch; }
  .hero-cta .btn{ width:100%; }
  .ftr a{ padding:9px 0; }
  .h-lead{ font-size:clamp(26px,7vw,34px); }
  .section{ padding:48px 0; }
}

/* accessibility */
.btn:focus-visible{ outline:2px solid var(--brand); outline-offset:3px; }
.hamb:focus-visible{ outline:2px solid var(--brand); outline-offset:3px; border-radius:6px; }
.faq details summary:focus-visible{ outline:2px solid var(--brand); outline-offset:2px; }
.yt-modal-close:focus-visible{ outline:2px solid #fff; outline-offset:2px; }
.wa-float:focus-visible{ outline:2px solid #25d366; outline-offset:3px; border-radius:99px; }
button, a, summary{ touch-action:manipulation; }
@media(max-width:1080px){ .mobile-nav a{ min-height:48px; display:flex; align-items:center; } .hdr-cta .btn{ min-height:48px; } }

/* reveal animation */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .6s ease, transform .6s ease; } .reveal.in{ opacity:1; transform:none; }
@media(prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; transition:none; } }

/* founder video button */
.btn-watch{ background:linear-gradient(135deg,#ff8a63,var(--coral)); color:#fff; box-shadow:0 12px 26px -10px rgba(255,122,89,.45); margin-bottom:22px; border:none; }
.btn-watch:hover{ transform:translateY(-2px); box-shadow:0 18px 34px -10px rgba(255,122,89,.65); color:#fff; }
.btn-watch-play{ width:30px; height:30px; background:rgba(255,255,255,.22); border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-left:-2px; }
.btn-watch-play svg{ width:10px; height:12px; fill:#fff; margin-left:2px; }

/* YouTube modal */
.yt-modal{ display:none; position:fixed; inset:0; z-index:9999; background:rgba(16,24,32,.82); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); align-items:center; justify-content:center; padding:20px; }
.yt-modal.open{ display:flex; }
.yt-modal-card{ position:relative; width:100%; max-width:860px; background:var(--ink); border-radius:20px; overflow:hidden; box-shadow:0 32px 80px rgba(0,0,0,.55); animation:yt-pop .22s cubic-bezier(.22,1,.36,1); }
@keyframes yt-pop{ from{ opacity:0; transform:scale(.93) translateY(18px); } to{ opacity:1; transform:scale(1) translateY(0); } }
.yt-modal-close{ position:absolute; top:12px; right:12px; z-index:2; width:36px; height:36px; border-radius:50%; border:none; cursor:pointer; background:rgba(255,244,233,.14); color:#fff; font-size:18px; line-height:1; display:flex; align-items:center; justify-content:center; transition:background .15s; }
.yt-modal-close:hover{ background:rgba(255,244,233,.28); }
.yt-modal-frame{ position:relative; padding-bottom:56.25%; height:0; }
.yt-modal-frame iframe{ position:absolute; top:0; left:0; width:100%; height:100%; border:none; }
