/* =============================================================
   Eduventure — "Press Start" design system
   Warm paper canvas · adventure-navy dark · a green→teal→sky
   launch gradient + arcade accent pops. Fredoka + Inter.
   Playful, energetic, but credible for school/edtech buyers.
   ============================================================= */

:root {
  --canvas:   #f6f5f1;
  --canvas-2: #eceae2;
  --card:     #ffffff;

  --navy:   #161331;
  --navy-2: #221d44;
  --navy-3: #322a5e;

  --ink:    #1c1a2e;
  --ink-2:  #4a4660;
  --ink-3:  #67627e;
  --muted:  #67627e;
  --line:   #e6e2d9;
  --line-2: #d9d4c9;

  --green:      #15b866;
  --green-deep: #0f9a54;
  --green-ink:  #0b7a42;
  --green-soft: rgba(21,184,102,0.12);
  --green-faint:rgba(21,184,102,0.07);

  --sky:    #2aa8f5;  --sky-ink:#0a66a8;
  --coral:  #ff5d5d;  --coral-ink:#c0271f;
  --gold:   #f5a623;  --gold-ink:#b9760a;
  --violet: #7b61ff;  --violet-ink:#5a3ff0;
  --teal:   #1ec8b0;  --teal-ink:#0e8d7c;

  --grad: linear-gradient(100deg, #1fbf6a 0%, #1ec8b0 52%, #3db4ff 100%);
  --grad-soft: linear-gradient(100deg, rgba(31,191,106,0.16), rgba(30,200,176,0.14) 52%, rgba(61,180,255,0.14));

  --font-display: 'Fredoka', system-ui, sans-serif;
  --font-body:    'Inter', system-ui, -apple-system, sans-serif;

  --radius-1: 12px;
  --radius-2: 18px;
  --radius-3: 26px;
  --ease: cubic-bezier(.2,.7,.2,1);
  --transition: 240ms var(--ease);
  --container: 1160px;
  --measure: 690px;
  --shadow-1: 0 2px 14px rgba(22,19,49,0.07);
  --shadow-2: 0 18px 46px rgba(22,19,49,0.16);
  --shadow-glow: 0 12px 26px rgba(15,154,84,0.30);
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin:0; background:var(--canvas); color:var(--ink-2); font-family:var(--font-body); font-size:17px; line-height:1.65; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; overflow-x:hidden; }
img, svg { max-width:100%; height:auto; display:block; }
a { color:var(--green-ink); text-decoration:none; transition:color var(--transition); }
a:hover { color:var(--green-deep); }
:where(a,button,input,select,textarea,[tabindex]):focus-visible { outline:3px solid var(--green); outline-offset:2px; border-radius:5px; }
.section--navy :where(a,button):focus-visible, .cta-band :where(a,button):focus-visible { outline-color:#5fe0a0; }

h1,h2,h3,h4 { font-family:var(--font-display); font-weight:600; color:var(--ink); letter-spacing:-0.01em; line-height:1.08; margin:0 0 0.5em; }
h1 { font-size:clamp(2.6rem,5.6vw,4.2rem); font-weight:700; line-height:1.0; }
h2 { font-size:clamp(2rem,3.8vw,3rem); font-weight:600; }
h3 { font-size:1.4rem; }
p { margin:0 0 1.1em; }
strong { color:var(--ink); font-weight:600; }
.muted { color:var(--muted); }
.lede { font-size:1.24rem; line-height:1.55; color:var(--ink-2); }
::selection { background:var(--green); color:#fff; }
.grad-text { background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }

.container { width:100%; max-width:var(--container); margin:0 auto; padding:0 24px; }
.container--narrow { max-width:var(--measure); }
.section { padding:clamp(54px,7.5vw,104px) 0; position:relative; }
.section--tight { padding:clamp(40px,5vw,68px) 0; }
.section--alt { background:var(--canvas-2); }
.section--navy { background:var(--navy); color:#c7c2e0; }
.section--navy h1,.section--navy h2,.section--navy h3 { color:#fff; }
.section__header { max-width:var(--measure); margin-bottom:clamp(32px,4.5vw,50px); }
.section__header.is-center { margin-left:auto; margin-right:auto; text-align:center; }
.section__header p { color:var(--ink-3); font-size:1.1rem; margin-bottom:0; }
.section--navy .section__header p { color:#a9a3c8; }

.eyebrow { font-family:var(--font-body); font-size:0.74rem; font-weight:700; letter-spacing:0.16em; text-transform:uppercase; color:var(--green-ink); display:inline-flex; align-items:center; gap:9px; margin-bottom:14px; }
.eyebrow::before { content:''; width:18px; height:8px; border-radius:2px; background:var(--grad); }
.is-center .eyebrow { justify-content:center; }
.eyebrow--on-dark { color:#74e8a8; }
.eyebrow--coral { color:var(--coral-ink); } .eyebrow--violet { color:var(--violet-ink); } .eyebrow--sky { color:var(--sky-ink); }
.sticker { display:inline-flex; align-items:center; gap:8px; font-size:0.8rem; font-weight:600; padding:7px 15px; border-radius:999px; margin-bottom:18px; background:var(--green-soft); color:var(--green-ink); border:1px solid var(--line-2); }
.sticker--on-dark { background:rgba(255,255,255,0.08); color:#74e8a8; border-color:rgba(255,255,255,0.16); }

.visually-hidden,.skip-link { position:absolute; left:-9999px; }
.skip-link:focus { position:fixed; left:16px; top:16px; z-index:9999; background:var(--green); color:#0b2; color:#08331c; padding:10px 16px; font-weight:700; border-radius:var(--radius-1); }

.brandbar { height:4px; background:var(--grad); }

/* ── quest-path divider ── */
.questpath { height:18px; background:
  radial-gradient(circle at center, var(--green) 3px, transparent 3.4px) 0 50%/22px 18px repeat-x;
  opacity:0.6; }

/* ── header ── */
.site-header { position:sticky; top:0; z-index:50; padding:14px 0 2px; background:linear-gradient(var(--canvas) 66%, transparent); }
.site-header__inner { display:flex; align-items:center; justify-content:space-between; gap:20px; background:var(--card); border:1px solid var(--line); border-radius:16px; padding:9px 12px 9px 16px; box-shadow:0 8px 26px rgba(22,19,49,0.09); }
.brand { display:inline-flex; align-items:center; gap:12px; color:var(--ink); }
.brand:hover { color:var(--ink); }
.brand__mark { display:inline-flex; transition:transform var(--transition); }
.brand:hover .brand__mark { transform:rotate(-6deg) scale(1.06); }
.brand__word { font-family:var(--font-display); font-weight:700; font-size:1.42rem; letter-spacing:-0.01em; line-height:0.95; }
.brand__word b { font-weight:700; color:var(--green-ink); }
.brand__sub { display:block; font-family:var(--font-body); font-weight:600; font-size:0.56rem; letter-spacing:0.18em; text-transform:uppercase; color:var(--ink-3); margin-top:3px; }
.site-nav__list { display:flex; align-items:center; gap:4px; list-style:none; margin:0; padding:0; }
.site-nav__list > li > a { color:var(--ink-2); font-weight:600; font-size:0.94rem; padding:9px 15px; border-radius:10px; display:block; transition:background var(--transition), color var(--transition); }
.site-nav__list > li > a:hover { color:var(--green-ink); background:var(--canvas-2); }
.site-nav__list > li > a.is-active { color:var(--green-ink); background:var(--green-soft); }
.site-nav__cta > a { color:#0d2c1a; }
.site-nav__toggle { display:none; width:46px; height:46px; background:var(--card); border:1px solid var(--line); border-radius:12px; flex-direction:column; align-items:center; justify-content:center; gap:4px; cursor:pointer; }
.site-nav__toggle-bar { width:18px; height:2px; border-radius:2px; background:var(--navy); }
@media (max-width:880px){
  .site-nav__toggle { display:inline-flex; }
  .site-nav__pill { position:fixed; inset:0; background:var(--canvas); padding:96px 24px 40px; transform:translateY(-110%); visibility:hidden; transition:transform var(--transition), visibility var(--transition); overflow-y:auto; }
  .site-nav.is-open .site-nav__pill { transform:none; visibility:visible; }
  .site-nav__list { flex-direction:column; align-items:stretch; gap:6px; }
  .site-nav__list > li > a { font-family:var(--font-display); font-size:1.5rem; padding:12px 18px; border-radius:var(--radius-2); background:var(--card); border:1px solid var(--line); }
  .site-nav__cta { margin-top:12px; } .site-nav__cta > a { width:100%; justify-content:center; }
}

/* buttons */
.btn { display:inline-flex; align-items:center; gap:9px; padding:13px 24px; font-family:var(--font-display); font-weight:600; font-size:1rem; background:transparent; color:var(--ink); border:2px solid var(--line-2); border-radius:12px; cursor:pointer; transition:all var(--transition); }
.btn--primary { background:var(--grad); border:0; color:#0d2c1a; box-shadow:var(--shadow-glow); padding:14px 26px; font-weight:700; }
.btn--primary:hover { filter:brightness(1.05); transform:translateY(-2px); color:#0d2c1a; }
.btn--navy { background:var(--navy); border-color:var(--navy); color:#fff; }
.btn--navy:hover { background:var(--navy-2); border-color:var(--navy-2); color:#fff; transform:translateY(-2px); }
.btn--ghost { border-color:var(--line-2); color:var(--ink); }
.btn--ghost:hover { border-color:var(--green); color:var(--green-ink); transform:translateY(-2px); }
.btn--ghost-light { border-color:rgba(255,255,255,0.35); color:#fff; }
.btn--ghost-light:hover { border-color:#fff; background:rgba(255,255,255,0.08); color:#fff; }
.btn--lg { padding:16px 32px; font-size:1.08rem; }
.btn--sm { padding:9px 18px; font-size:0.9rem; border-radius:10px; }
.btn .arrow { transition:transform var(--transition); }
.btn:hover .arrow { transform:translateX(3px); }

/* ── hero (navy, key-art screen) ── */
.hero { background:var(--navy); color:#c7c2e0; position:relative; overflow:hidden; }
.hero::before { content:''; position:absolute; inset:0; background:
  radial-gradient(50% 50% at 88% 6%, rgba(61,180,255,0.20), transparent 70%),
  radial-gradient(46% 50% at 4% 100%, rgba(31,191,106,0.18), transparent 70%); }
.hero__inner { position:relative; display:grid; grid-template-columns:1.02fr 0.98fr; gap:clamp(30px,4vw,60px); align-items:center; padding:clamp(44px,6vw,92px) 0 clamp(48px,7vw,96px); }
.hero__copy { max-width:580px; }
.hero h1 { color:#fff; margin-bottom:0; }
.hero__lede { margin-top:22px; font-size:1.24rem; color:#bcb6d8; }
.hero__actions { margin-top:30px; display:flex; gap:14px; flex-wrap:wrap; }
.hero__trust { margin-top:24px; font-size:0.9rem; color:#a9a3c8; font-weight:500; display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.hero__screen { position:relative; border-radius:var(--radius-3); overflow:hidden; border:3px solid rgba(255,255,255,0.1); box-shadow:var(--shadow-2); background:var(--navy-2); }
.hero__screen::before { content:''; position:absolute; top:0; left:0; right:0; height:5px; background:var(--grad); z-index:2; }
.hero__screen img { width:100%; aspect-ratio:16/10; object-fit:cover; display:block; }
.hero__chip { position:absolute; z-index:3; background:var(--card); color:var(--ink); border-radius:12px; padding:9px 14px; box-shadow:var(--shadow-2); font-weight:600; font-size:0.84rem; display:flex; align-items:center; gap:8px; }
.hero__chip--a { left:-10px; bottom:24px; }
.hero__chip--b { right:-8px; top:22px; }
.hero__chip .dot { width:9px; height:9px; border-radius:50%; background:var(--green); box-shadow:0 0 0 4px var(--green-soft); }
@media (max-width:880px){ .hero__inner { grid-template-columns:1fr; gap:40px; } .hero__screen { order:-1; max-width:520px; margin:0 auto; } }

/* ── stat band ── */
.stat-band { background:var(--card); border:1px solid var(--line); border-radius:var(--radius-3); box-shadow:var(--shadow-1); display:grid; grid-template-columns:repeat(auto-fit,minmax(min(200px,100%),1fr)); overflow:hidden; }
.stat-cell { padding:26px 24px; text-align:center; border-right:1px solid var(--line); }
.stat-cell:last-child { border-right:0; }
.stat-cell__num { font-family:var(--font-display); font-size:clamp(1.5rem,2.4vw,1.9rem); font-weight:700; color:var(--green-ink); line-height:1.1; }
.stat-cell__label { margin-top:6px; font-weight:600; color:var(--ink); font-family:var(--font-display); }
.stat-cell__sub { margin-top:4px; font-size:0.84rem; color:var(--ink-3); }
@media (max-width:680px){ .stat-cell { border-right:0; border-bottom:1px solid var(--line); } .stat-cell:last-child { border-bottom:0; } }

/* ── service cards ── */
.service-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(min(330px,100%),1fr)); gap:22px; }
.service { background:var(--card); border:1px solid var(--line); border-radius:var(--radius-3); padding:30px 28px; box-shadow:var(--shadow-1); scroll-margin-top:90px; transition:transform var(--transition), box-shadow var(--transition); display:flex; flex-direction:column; }
.service:hover { transform:translateY(-4px); box-shadow:var(--shadow-2); }
.service__icon { width:54px; height:54px; border-radius:14px; display:inline-flex; align-items:center; justify-content:center; margin-bottom:16px; }
.service__icon svg { width:27px; height:27px; }
.service h3 { font-size:1.4rem; margin-bottom:6px; }
.service__tagline { color:var(--ink); font-weight:600; font-size:1rem; margin:0 0 10px; }
.service p { color:var(--ink-3); font-size:0.97rem; margin:0; }
.service__features { list-style:none; padding:0; margin:16px 0 0; }
.service__features li { position:relative; padding-left:24px; margin-bottom:7px; color:var(--ink-2); font-size:0.92rem; }
.service__features li::before { content:''; position:absolute; left:0; top:8px; width:8px; height:8px; border-radius:2px; background:var(--green); }

/* ── work / achievement cards ── */
.work-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(min(360px,100%),1fr)); gap:26px; }
.work { background:var(--card); border:1px solid var(--line); border-radius:var(--radius-3); overflow:hidden; box-shadow:var(--shadow-1); display:flex; flex-direction:column; scroll-margin-top:90px; transition:transform var(--transition), box-shadow var(--transition); }
.work:hover { transform:translateY(-5px); box-shadow:var(--shadow-2); }
.work__media { position:relative; aspect-ratio:16/9; overflow:hidden; background:var(--canvas-2); }
.work__media img { width:100%; height:100%; object-fit:cover; transition:transform 600ms var(--ease); }
.work:hover .work__media img { transform:scale(1.04); }
.work__badge { position:absolute; top:12px; left:12px; display:inline-flex; align-items:center; gap:7px; font-weight:700; font-size:0.66rem; letter-spacing:0.05em; text-transform:uppercase; color:#fff; background:rgba(22,19,49,0.82); backdrop-filter:blur(3px); padding:6px 11px; border-radius:999px; box-shadow:var(--shadow-1); }
.work__badge::before { content:''; width:7px; height:7px; border-radius:50%; background:var(--dot,#fff); flex:none; }
.work__plat { position:absolute; bottom:12px; right:12px; font-weight:600; font-size:0.7rem; color:#fff; background:rgba(22,19,49,0.66); backdrop-filter:blur(3px); padding:5px 11px; border-radius:999px; }
.work__body { padding:22px 24px 24px; display:flex; flex-direction:column; flex:1; }
.work__title { font-family:var(--font-display); font-size:1.55rem; font-weight:600; color:var(--ink); line-height:1.05; }
.work__tagline { color:var(--ink); font-weight:600; font-size:0.98rem; margin:6px 0 0; }
.work__blurb { color:var(--ink-3); font-size:0.95rem; margin:12px 0 0; }
.work__outcome { margin-top:16px; font-size:0.8rem; font-weight:600; color:var(--ink-2); background:var(--canvas-2); border:1px solid var(--line); border-radius:999px; padding:6px 13px; align-self:flex-start; }

/* ── sectors ── */
.sector-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(min(260px,100%),1fr)); gap:18px; }
.sector { background:var(--card); border:1px solid var(--line); border-radius:var(--radius-2); padding:24px 24px; box-shadow:var(--shadow-1); display:flex; gap:14px; }
.sector__icon { flex:none; width:46px; height:46px; border-radius:12px; background:var(--green-soft); color:var(--green-deep); display:inline-flex; align-items:center; justify-content:center; }
.sector__icon svg { width:24px; height:24px; }
.sector:nth-child(3n+2) .sector__icon { background:rgba(123,97,255,0.13); color:var(--violet-ink); }
.sector:nth-child(3n+3) .sector__icon { background:rgba(42,168,245,0.13); color:var(--sky-ink); }
.sector h3 { font-size:1.12rem; margin:2px 0 4px; }
.sector p { color:var(--ink-3); font-size:0.92rem; margin:0; }

/* ── pillars (with XP bar) ── */
.pillar-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(min(280px,100%),1fr)); gap:20px; }
.pillar { background:var(--navy-2); border:1px solid var(--navy-3); border-radius:var(--radius-2); padding:26px 26px; }
.pillar__icon { width:46px; height:46px; border-radius:12px; background:rgba(31,191,106,0.16); color:#5fe0a0; display:inline-flex; align-items:center; justify-content:center; margin-bottom:14px; }
.pillar__icon svg { width:25px; height:25px; }
.pillar:nth-child(3n+2) .pillar__icon { background:rgba(123,97,255,0.2); color:#b3a4ff; }
.pillar:nth-child(3n+3) .pillar__icon { background:rgba(61,180,255,0.18); color:#8fd3ff; }
.pillar h3 { color:#fff; font-size:1.25rem; margin-bottom:6px; }
.pillar p { color:#a9a3c8; font-size:0.95rem; margin:0; }

/* ── process (levels) ── */
.level-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(min(200px,100%),1fr)); gap:18px; counter-reset:lvl; }
.level { counter-increment:lvl; background:var(--card); border:1px solid var(--line); border-radius:var(--radius-2); padding:24px 22px; box-shadow:var(--shadow-1); position:relative; }
.level::before { content:'LVL ' counter(lvl); font-family:var(--font-display); font-weight:700; font-size:0.7rem; letter-spacing:0.06em; color:var(--green-ink); background:var(--green-soft); padding:4px 10px; border-radius:999px; display:inline-block; margin-bottom:12px; }
.level h3 { font-size:1.2rem; margin-bottom:5px; }
.level p { color:var(--ink-3); font-size:0.93rem; margin:0; }

/* ── split feature ── */
.split { display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,60px); align-items:center; }
.split--flip .split__media { order:2; }
.split__media img { width:100%; aspect-ratio:16/10; object-fit:cover; border-radius:var(--radius-3); box-shadow:var(--shadow-2); }
.split__body { max-width:520px; }
@media (max-width:820px){ .split { grid-template-columns:1fr; gap:28px; } .split--flip .split__media { order:-1; } }

/* ── testimonials ── */
.quote-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(min(280px,100%),1fr)); gap:22px; }
.quote { background:var(--card); border:1px solid var(--line); border-radius:var(--radius-2); padding:28px 28px 24px; box-shadow:var(--shadow-1); }
.quote__stars { color:var(--gold); letter-spacing:2px; font-size:0.9rem; margin-bottom:12px; }
.quote__text { font-family:var(--font-display); font-weight:500; font-size:1.22rem; line-height:1.4; color:var(--ink); margin:0; }
.quote__who { margin-top:18px; }
.quote__name { font-weight:700; color:var(--ink); font-size:0.92rem; }
.quote__role { font-size:0.82rem; color:var(--ink-3); }

/* ── team ── */
.team-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(min(240px,100%),1fr)); gap:20px; }
.team-card { background:var(--card); border:1px solid var(--line); border-radius:var(--radius-2); padding:28px 24px; box-shadow:var(--shadow-1); text-align:center; }
.team-card__avatar { width:74px; height:74px; border-radius:18px; margin:0 auto 14px; display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-weight:700; font-size:1.7rem; }
.avatar--green { background:var(--green-soft); color:var(--green-deep); }
.avatar--violet { background:rgba(123,97,255,0.13); color:var(--violet-ink); }
.avatar--sky { background:rgba(42,168,245,0.13); color:var(--sky-ink); }
.avatar--coral { background:rgba(255,93,93,0.13); color:var(--coral-ink); }
.team-card__name { font-family:var(--font-display); font-size:1.25rem; font-weight:600; color:var(--ink); }
.team-card__role { font-weight:600; font-size:0.78rem; text-transform:uppercase; letter-spacing:0.06em; color:var(--green-ink); margin:3px 0 12px; }
.team-card__bio { color:var(--ink-3); font-size:0.93rem; margin:0; }

/* ── page head ── */
.page-head { padding:clamp(38px,5vw,66px) 0 clamp(20px,3vw,32px); }
.page-head--alt { background:var(--canvas-2); }
.page-head--navy { background:var(--navy); }
.page-head--navy .page-head__lede { color:#bcb6d8; }
.page-head--navy .crumbs, .page-head--navy .crumbs a { color:#8e88ad; }
.page-head--navy .crumbs span { color:#fff; }
.page-head__inner { max-width:740px; }
.page-head__lede { font-size:1.2rem; color:var(--ink-2); margin:14px 0 0; }
.crumbs { font-size:0.8rem; color:var(--muted); margin-bottom:14px; }
.crumbs a { color:var(--ink-3); } .crumbs a:hover { color:var(--green-ink); } .crumbs span { color:var(--ink); }

/* ── prose ── */
.prose { max-width:var(--measure); }
.prose > * + * { margin-top:1.05em; }
.prose h2 { margin-top:1.4em; margin-bottom:0.3em; }
.prose p, .prose li { color:var(--ink-2); }
.prose a { text-decoration:underline; text-decoration-color:rgba(21,184,102,0.45); text-underline-offset:2px; }
.prose ul { list-style:none; padding-left:0; }
.prose ul > li { position:relative; padding-left:1.5em; margin-bottom:0.5em; }
.prose ul > li::before { content:''; position:absolute; left:2px; top:0.55em; width:8px; height:8px; border-radius:2px; background:var(--green); }

/* ── FAQ ── */
.faq { max-width:800px; }
.faq__item { border-bottom:1px solid var(--line); }
.faq__q { width:100%; text-align:left; background:none; border:0; cursor:pointer; padding:22px 44px 22px 0; position:relative; font-family:var(--font-display); font-size:1.25rem; font-weight:600; color:var(--ink); }
.faq__q::after { content:'+'; position:absolute; right:6px; top:50%; transform:translateY(-50%); font-size:1.5rem; color:var(--green); transition:transform var(--transition); }
.faq__item.is-open .faq__q::after { transform:translateY(-50%) rotate(45deg); }
.faq__a { max-height:0; overflow:hidden; transition:max-height 320ms var(--ease); }
.faq__a-inner { padding:0 0 22px; color:var(--ink-2); }
.faq__a-inner p { margin:0; }

/* ── forms ── */
.form-wrap { background:var(--card); border:1px solid var(--line); border-radius:var(--radius-3); padding:clamp(26px,4vw,42px); box-shadow:var(--shadow-2); }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.field { display:flex; flex-direction:column; gap:7px; }
.field--full { grid-column:1/-1; }
.field label { font-weight:600; font-size:0.86rem; color:var(--ink); }
.field label .req { color:var(--coral-ink); }
.field input,.field select,.field textarea { font-family:var(--font-body); font-size:1rem; color:var(--ink); background:var(--canvas); border:1px solid var(--line-2); border-radius:var(--radius-1); padding:12px 14px; transition:border-color var(--transition), box-shadow var(--transition); width:100%; }
.field textarea { min-height:140px; resize:vertical; }
.field input:focus,.field select:focus,.field textarea:focus { outline:none; border-color:var(--green); box-shadow:0 0 0 3px var(--green-soft); }
.field__hint { font-size:0.8rem; color:var(--ink-3); }
.hp-field { position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.form-note { font-size:0.86rem; color:var(--ink-3); margin:4px 0 0; }
.form-status { padding:14px 18px; border-radius:var(--radius-1); font-weight:600; margin-bottom:18px; display:none; }
.form-status.is-show { display:block; }
.form-status--ok { background:var(--green-soft); color:var(--green-ink); border:1px solid rgba(21,184,102,0.4); }
.form-status--err { background:rgba(255,93,93,0.1); color:var(--coral-ink); border:1px solid var(--coral); }
@media (max-width:600px){ .form-grid { grid-template-columns:1fr; } }
.contact-card { background:var(--card); border:1px solid var(--line); border-radius:var(--radius-2); padding:24px; box-shadow:var(--shadow-1); }
.contact-card h3 { font-size:1.2rem; margin-bottom:4px; }
.contact-card a { font-weight:600; }

/* ── CTA band ── */
.cta-band { background:var(--navy); color:#c7c2e0; position:relative; overflow:hidden; }
.cta-band::before { content:''; position:absolute; width:440px; height:440px; border-radius:50%; background:var(--grad); opacity:0.5; filter:blur(80px); top:-180px; right:-90px; }
.cta-band__inner { position:relative; display:flex; align-items:center; justify-content:space-between; gap:28px; padding:clamp(46px,6vw,76px) 0; flex-wrap:wrap; }
.cta-band h2 { color:#fff; margin-bottom:8px; }
.cta-band p { color:#a9a3c8; margin:0; max-width:460px; }
.cta-band__actions { display:flex; gap:14px; flex-wrap:wrap; }

.panel { background:var(--card); border:1px solid var(--line); border-radius:var(--radius-3); padding:clamp(26px,4vw,44px); box-shadow:var(--shadow-1); }
.panel--soft { background:var(--green-faint); border-color:rgba(21,184,102,0.25); }

/* ── footer ── */
.site-footer { background:var(--navy); color:#a9a3c8; padding-top:54px; }
.site-footer a { color:#c7c2e0; } .site-footer a:hover { color:#fff; }
.site-footer__inner { display:grid; grid-template-columns:1.8fr 1fr 1fr 1fr; gap:36px; padding-bottom:40px; }
@media (max-width:860px){ .site-footer__inner { grid-template-columns:1fr 1fr; gap:30px; } }
@media (max-width:480px){ .site-footer__inner { grid-template-columns:1fr; } }
.site-footer .brand__word { color:#fff; } .site-footer .brand__word b { color:#74e8a8; }
.site-footer__tag { color:#8e88ad; margin-top:12px; font-size:0.94rem; max-width:340px; }
.site-footer h3 { font-size:0.72rem; letter-spacing:0.1em; text-transform:uppercase; color:#8e88ad; font-weight:700; margin-bottom:12px; }
.link-list { list-style:none; padding:0; margin:0; } .link-list li { padding:5px 0; }
.link-list a { color:#c7c2e0; font-size:0.95rem; } .link-list a:hover { color:#fff; }
.site-footer__base { border-top:1px solid var(--navy-3); padding:20px 0; }
.site-footer__base-inner { display:flex; justify-content:space-between; flex-wrap:wrap; gap:8px; font-size:0.84rem; color:#8e88ad; }
.site-footer__base p { margin:0; }

/* utilities */
.center { text-align:center; }
.mt-s{margin-top:14px;} .mt-m{margin-top:26px;} .mt-l{margin-top:42px;}
.reveal { opacity:0; transform:translateY(16px); transition:opacity 600ms var(--ease), transform 600ms var(--ease); }
.reveal.is-in { opacity:1; transform:none; }
.reveal[data-delay="1"]{transition-delay:80ms;} .reveal[data-delay="2"]{transition-delay:160ms;} .reveal[data-delay="3"]{transition-delay:240ms;}
@media (prefers-reduced-motion: reduce){ *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;} .reveal{opacity:1;transform:none;} html{scroll-behavior:auto;} }
