/* Shiny English — site-wide additions (homepage + direction pages)
   Builds on styles.css tokens & components. Bento, warm, coral thread. */

/* ---------- Hero (hub) ---------- */
.home-hero{padding-top:60px;padding-bottom:44px;position:relative;overflow:hidden}
.home-hero .glow{position:absolute;top:-180px;left:46%;transform:translateX(-50%);width:820px;height:620px;background:radial-gradient(closest-side,rgba(255,92,57,.16),transparent);pointer-events:none;z-index:0}
.home-hero .wrap{position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:54px;align-items:center}
.hero-grid .display{font-size:clamp(2.2rem,4.7vw,3.7rem);margin:18px 0 16px}
.hero-grid .lead{margin-bottom:26px;font-size:1.18rem;max-width:46ch}

/* quick format chooser */
.chooser-label{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--color-ink-soft);margin-bottom:12px}
.chooser{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:30px}
.chooser a{display:inline-flex;align-items:center;gap:9px;padding:11px 17px;border-radius:var(--radius-pill);background:var(--color-surface);border:1px solid var(--color-line);box-shadow:var(--shadow-card);font-weight:500;font-size:.96rem;transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.chooser a:hover{transform:translateY(-2px);box-shadow:var(--shadow-lift)}
.chooser a .dot{width:9px;height:9px;border-radius:50%;flex:none}
.dot-coral{background:var(--color-coral)} .dot-sky{background:var(--color-sky)} .dot-mint{background:var(--color-mint)} .dot-violet{background:var(--color-violet)} .dot-sun{background:var(--color-sun)}

.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.hero-media{position:relative}
.hero-media .hero-video{border-radius:var(--radius-xl);box-shadow:var(--shadow-lift);aspect-ratio:16/9;border:1px solid var(--color-line);overflow:hidden;background:#000}
.hero-media .hero-video iframe{display:block;width:100%;height:100%;border:0}
.hero-media .float{position:absolute;background:var(--color-surface);border:1px solid var(--color-line);box-shadow:var(--shadow-lift);border-radius:var(--radius-lg);padding:14px 18px;display:flex;align-items:center;gap:12px}
.hero-media .float .n{font-family:var(--font-display);font-weight:800;font-size:1.5rem;line-height:1}
.hero-media .float .l{font-size:.82rem;color:var(--color-ink-soft);line-height:1.25;max-width:14ch}
.hero-media .float.tl{top:18px;left:-26px}
.hero-media .float.br{bottom:22px;right:-22px}

/* ---------- Trust stat strip ---------- */
.statstrip{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:14px}
.stat-card{background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-lg);padding:24px 26px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:4px}
.stat-card .n{font-family:var(--font-display);font-weight:800;font-size:2.3rem;line-height:1}
.stat-card .l{color:var(--color-ink-soft);font-size:.95rem}
.stat-card.c-coral .n{color:var(--color-action)} .stat-card.c-sky .n{color:var(--color-sky)}
.stat-card.c-mint .n{color:var(--color-mint)} .stat-card.c-violet .n{color:var(--color-violet)} .stat-card.c-sun .n{color:#d39e00}

/* ---------- Directions bento ---------- */
.dir-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.dir-card{grid-column:span 3;display:flex;flex-direction:column;gap:14px;min-height:230px;text-decoration:none;color:inherit;position:relative}
.dir-card.flagship{grid-column:span 6;grid-row:span 2}
.dir-card .top{display:flex;align-items:center;justify-content:space-between;gap:12px}
.dir-card h3{font-family:var(--font-display);font-weight:700;font-size:1.24rem;line-height:1.16}
.dir-card.flagship h3{font-size:clamp(1.6rem,2.4vw,2.1rem);line-height:1.08}
.dir-card p{color:var(--color-ink-soft);font-size:1rem}
.dir-card.flagship p{font-size:1.1rem;max-width:36ch}
.dir-card .dir-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.dir-card .dir-cta{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:var(--color-action)}
.dir-card .dir-cta .arr{transition:transform var(--dur) var(--ease)}
.dir-card:hover .dir-cta .arr{transform:translateX(5px)}
.dir-card .price{font-family:var(--font-display);font-weight:800;font-size:1.5rem}
.dir-card .price .u{font-size:.62em;color:var(--color-ink-soft);font-weight:600}
.dir-card.flagship .dir-cta{color:#fff}
.dir-card.flagship .price{color:#fff}
.dir-card.flagship .price .u{color:rgba(255,255,255,.8)}

/* ---------- Method journey ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.step{background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-xl);padding:28px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:12px;transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.step:hover{transform:translateY(-4px);box-shadow:var(--shadow-lift)}
.step .sn{font-family:var(--font-mono);font-size:.8125rem;letter-spacing:.08em;text-transform:uppercase}
.step h3{font-family:var(--font-display);font-weight:700;font-size:1.22rem;line-height:1.16}
.step p{color:var(--color-ink-soft);font-size:1rem}
.step.s-coral .sn{color:var(--color-action)} .step.s-sun .sn{color:#d39e00}
.step.s-sky .sn{color:var(--color-sky)} .step.s-mint .sn{color:var(--color-mint)} .step.s-violet .sn{color:var(--color-violet)}

/* before / after */
.ba{display:grid;grid-template-columns:1fr 64px 1fr;gap:14px;align-items:stretch;margin-top:22px}
.ba .ba-card{border-radius:var(--radius-xl);padding:32px 34px;display:flex;flex-direction:column;gap:14px;justify-content:center}
.ba .was{background:var(--color-surface);border:1px solid var(--color-line)}
.ba .now{background:var(--color-coral);color:#fff;position:relative;overflow:hidden}
.ba .now::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 0 0,rgba(255,255,255,.22),transparent 55%);pointer-events:none}
.ba .ba-card .t{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--color-ink-soft)}
.ba .now .t{color:rgba(255,255,255,.85)}
.ba .ba-card ul{list-style:none;display:grid;gap:10px}
.ba .ba-card li{display:flex;gap:11px;align-items:flex-start;font-weight:500}
.ba .ba-card li .mk{flex:none;width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-size:.78rem;margin-top:1px}
.ba .was li .mk{background:var(--color-bg);color:var(--color-ink-soft)}
.ba .now li .mk{background:rgba(255,255,255,.22);color:#fff}
.ba .ba-arrow{display:grid;place-items:center;color:var(--color-coral)}

/* ---------- Reviews (video + text slots) ---------- */
.rev-videos{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:18px}
.rev-videos video-slot{aspect-ratio:424/680;border-radius:var(--radius-lg);box-shadow:var(--shadow-card)}
.rev-videos.two{grid-template-columns:repeat(2,minmax(0,300px));justify-content:center;margin-bottom:28px}
.vid-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-card);aspect-ratio:9/16;background:#000;border:1px solid var(--color-line)}
.vid-card iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.rev-texts{align-items:start}
.review-ph .stars{color:var(--color-sun);font-size:1rem;letter-spacing:2px;height:18px}
.review-ph p{font-size:.98rem;line-height:1.6}
.rev-texts{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.review-ph{background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);min-height:220px;display:flex;flex-direction:column;gap:14px;padding:30px}
.review-ph .quote-mark{font-family:var(--font-display);font-size:2.6rem;line-height:.6;color:var(--color-coral);height:24px}
.review-ph p{color:var(--color-ink-soft)}
.review-ph .who{margin-top:auto;display:flex;align-items:center;gap:12px}
.review-ph .who .avatar{width:44px;height:44px;border-radius:50%;background:repeating-linear-gradient(135deg,rgba(26,22,19,.05) 0 8px,rgba(26,22,19,.09) 8px 16px);flex:none}
.review-ph .who .nm{font-weight:600;color:var(--color-ink);font-size:.95rem}
.review-ph .who .rl{font-size:.82rem;color:var(--color-ink-soft)}

/* ---------- Telegram band reuse (.tg-band already in styles.css) ---------- */
.tg-band .tg-deco{position:absolute;right:-40px;bottom:-50px;width:220px;height:220px;opacity:.12;pointer-events:none}

/* ---------- Closing + contact ---------- */
.final-band{background:var(--color-blush);border-radius:var(--radius-xl);padding:64px 48px;text-align:center;position:relative;overflow:hidden}
.final-band .glow-c{position:absolute;top:-120px;left:50%;transform:translateX(-50%);width:560px;height:420px;background:radial-gradient(closest-side,rgba(255,92,57,.28),transparent);pointer-events:none}
.final-band>*{position:relative}
.final-band .h2{margin:12px auto 14px;max-width:24ch}
.final-band .lead{margin:0 auto 28px;max-width:52ch}
.final-band .ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.final-band .reassure{display:flex;gap:10px 22px;justify-content:center;flex-wrap:wrap;margin-top:24px}
.final-band .reassure .r{display:inline-flex;align-items:center;gap:9px;font-size:.95rem;color:var(--color-ink-soft);font-weight:500}
.final-band .reassure svg{color:var(--color-mint);flex:none}

.contact-band{display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;background:var(--color-ink);color:#fff;border-radius:var(--radius-xl);padding:54px 56px;position:relative;overflow:hidden}
.contact-band::before{content:"";position:absolute;top:-80px;right:-60px;width:340px;height:280px;background:radial-gradient(closest-side,rgba(255,92,57,.35),transparent);pointer-events:none}
.contact-band .h2{color:#fff;position:relative;max-width:18ch}
.contact-band .socials{position:relative}
.socials{display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.socials a{width:60px;height:60px;border-radius:50%;background:var(--color-surface);border:1px solid var(--color-line);box-shadow:var(--shadow-card);display:grid;place-items:center;transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.socials a:hover{transform:translateY(-3px);box-shadow:var(--shadow-lift)}
.socials img{width:32px;height:32px;object-fit:contain}
footer .f-legal{font-size:.8rem;color:rgba(255,255,255,.45);line-height:1.7}

/* ---------- Checkout / оплата ---------- */
.checkout{padding-top:48px;padding-bottom:56px;position:relative;overflow:hidden}
.checkout .glow{position:absolute;top:-160px;left:50%;transform:translateX(-50%);width:740px;height:520px;background:radial-gradient(closest-side,rgba(255,92,57,.13),transparent);pointer-events:none;z-index:0}
.checkout .wrap{position:relative;z-index:1}
.co-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:36px;align-items:start}

/* order summary (left) */
.co-summary{background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);padding:34px}
.co-summary h2{font-family:var(--font-display);font-weight:700;font-size:1.5rem;margin:8px 0 6px}
.co-summary .co-sub{color:var(--color-ink-soft);margin-bottom:22px}
.co-incl{list-style:none;display:grid;gap:13px;margin:0 0 24px}
.co-incl li{display:flex;gap:12px;align-items:flex-start;font-weight:500}
.co-incl li .mk{flex:none;width:26px;height:26px;border-radius:50%;background:var(--color-blush);color:var(--color-action);display:grid;place-items:center;font-size:.78rem;margin-top:1px}
.co-guarantee{display:flex;gap:13px;align-items:center;background:var(--color-mint-50);border-radius:var(--radius-lg);padding:16px 18px}
.co-guarantee svg{color:var(--color-mint);flex:none}
.co-guarantee .g-t{font-weight:600}
.co-guarantee .g-s{font-size:.88rem;color:var(--color-ink-soft)}

/* payment panel (right) */
.co-pay{background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-xl);box-shadow:var(--shadow-lift);padding:34px;position:sticky;top:96px}
.co-pay h3{font-family:var(--font-display);font-weight:700;font-size:1.25rem;margin-bottom:4px}
.co-field{margin-bottom:18px}
.co-field > label{display:block;font-weight:600;font-size:.92rem;margin-bottom:9px}
.co-field .hint{font-size:.82rem;color:var(--color-ink-soft);margin-top:7px}

/* region segmented control */
.region{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.region label{cursor:pointer}
.region input{position:absolute;opacity:0;pointer-events:none}
.region .opt{display:flex;flex-direction:column;gap:3px;border:1.5px solid var(--color-line);border-radius:var(--radius-lg);padding:14px 16px;transition:border-color var(--dur) var(--ease),background var(--dur) var(--ease)}
.region .opt .r-top{display:flex;align-items:center;gap:9px;font-weight:600}
.region .opt .r-sub{font-size:.82rem;color:var(--color-ink-soft)}
.region input:checked + .opt{border-color:var(--color-action);background:var(--color-blush)}
.region .opt .flag{font-size:1.2rem;line-height:1}

/* email + total */
.co-input{width:100%;font:inherit;padding:13px 15px;border:1.5px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-bg);transition:border-color var(--dur) var(--ease)}
.co-input:focus{outline:none;border-color:var(--color-sky)}
.co-total{display:flex;align-items:baseline;justify-content:space-between;padding:18px 0;border-top:1px solid var(--color-line);border-bottom:1px solid var(--color-line);margin:20px 0}
.co-total .lbl{color:var(--color-ink-soft);font-weight:500}
.co-total .amt{font-family:var(--font-display);font-weight:800;font-size:2rem;line-height:1}
.co-method{font-size:.86rem;color:var(--color-ink-soft);margin:-8px 0 18px;display:flex;align-items:center;gap:7px}
.co-pay .btn{width:100%;justify-content:center}
.co-consent{display:flex;gap:10px;align-items:flex-start;font-size:.85rem;color:var(--color-ink-soft);margin:16px 0 0;line-height:1.5}
.co-consent input{margin-top:3px;flex:none;width:17px;height:17px;accent-color:var(--color-action)}
.co-consent a{color:var(--color-ink);text-decoration:underline}
.co-secure{display:flex;align-items:center;justify-content:center;gap:8px;font-size:.82rem;color:var(--color-ink-soft);margin-top:16px}
.co-secure svg{color:var(--color-mint)}

@media(max-width:860px){
  .co-grid{grid-template-columns:1fr}
  .co-pay{position:static;order:-1}
}

/* ---------- KIDS — game / quest motif ---------- */
.game-hero{background:var(--color-ink);color:#fff;border-radius:var(--radius-xl);padding:0;overflow:hidden;position:relative}
.quest-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.quest{grid-column:span 4;background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-xl);padding:28px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:14px;transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.quest:hover{transform:translateY(-4px);box-shadow:var(--shadow-lift)}
.quest .level-pill{align-self:flex-start;display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;padding:6px 13px;border-radius:var(--radius-pill);font-weight:500}
.quest h3{font-family:var(--font-display);font-weight:700;font-size:1.2rem;line-height:1.16}
.quest p{color:var(--color-ink-soft);font-size:.98rem}
.lv-coral{background:var(--color-blush);color:var(--color-action)} .lv-sun{background:var(--color-sun-50);color:#9a7a00}
.lv-sky{background:var(--color-sky-50);color:#1c4fd6} .lv-mint{background:var(--color-mint-50);color:#0a7d42} .lv-violet{background:var(--color-violet-50);color:#5a3fd6}

/* XP bar */
.xp{display:flex;flex-direction:column;gap:7px;margin-top:auto}
.xp .xp-top{display:flex;align-items:center;justify-content:space-between;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.05em;text-transform:uppercase;color:var(--color-ink-soft)}
.xp .xp-track{height:10px;border-radius:999px;background:var(--color-bg);overflow:hidden}
.xp .xp-fill{height:100%;border-radius:999px}
.xp-fill.f-coral{background:var(--color-coral)} .xp-fill.f-sun{background:var(--color-sun)} .xp-fill.f-sky{background:var(--color-sky)} .xp-fill.f-mint{background:var(--color-mint)} .xp-fill.f-violet{background:var(--color-violet)}

/* achievement badges */
.achv-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:4px}
.achv{display:inline-flex;align-items:center;gap:10px;background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-pill);padding:10px 18px;box-shadow:var(--shadow-card);font-weight:600;font-size:.95rem}
.achv .badge-ic{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;font-size:18px;flex:none}

/* ---------- Generic page hero (direction pages) ---------- */
.page-hero{padding-top:56px;padding-bottom:40px;position:relative;overflow:hidden}
.page-hero .glow{position:absolute;top:-160px;left:50%;transform:translateX(-50%);width:760px;height:560px;background:radial-gradient(closest-side,rgba(255,92,57,.14),transparent);pointer-events:none;z-index:0}
.page-hero .wrap{position:relative;z-index:1}
.ph-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
.ph-grid .display{font-size:clamp(2.1rem,4.5vw,3.4rem);margin:18px 0 16px}
.ph-grid .lead{margin-bottom:26px}
.ph-feats{list-style:none;display:grid;gap:12px;margin:0 0 28px}
.ph-feats li{display:flex;gap:12px;align-items:flex-start;font-weight:500;font-size:1.08rem}
.ph-feats .mk{flex:none;width:28px;height:28px;border-radius:50%;background:var(--color-blush);display:grid;place-items:center;color:var(--color-action);margin-top:1px;font-size:.82rem}
.ph-media{border-radius:var(--radius-xl);box-shadow:var(--shadow-lift);aspect-ratio:4/5;border:1px solid var(--color-line)}

/* author photo */
.author-photo{width:100%;display:block}

/* hero price (direction pages) */
.ph-price{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin:0 0 24px}
.ph-price .big{font-family:var(--font-display);font-weight:800;font-size:2.2rem;line-height:1}
.ph-price .u{color:var(--color-ink-soft);font-weight:500}
.ph-price .usd{font-family:var(--font-mono);font-size:.8rem;color:var(--color-ink-soft);background:var(--color-bg);border:1px solid var(--color-line);border-radius:var(--radius-pill);padding:4px 10px}

/* enroll / format cards */
.enroll{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.enroll .e-card .price{font-family:var(--font-display);font-weight:800;font-size:1.85rem;line-height:1}
.enroll .e-card .price .u{font-size:.5em;color:var(--color-ink-soft);font-weight:600;font-family:var(--font-body)}
.enroll .e-card{background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-xl);padding:32px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:14px}
.enroll .e-card.featured{box-shadow:var(--shadow-lift)}
.enroll .e-card h3{font-family:var(--font-display);font-weight:700;font-size:1.3rem}
.enroll .e-card .meta{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--color-ink-soft)}
.enroll .e-card ul{list-style:none;display:grid;gap:10px}
.enroll .e-card li{display:flex;gap:10px;align-items:flex-start;color:var(--color-ink-soft)}
.enroll .e-card li::before{content:"✦";color:var(--color-coral);flex:none}
.enroll .e-card .btn{margin-top:auto}

/* breadcrumb back link */
.crumbs{display:flex;align-items:center;gap:8px;font-size:.92rem;color:var(--color-ink-soft);margin-bottom:6px}
.crumbs a{color:var(--color-ink-soft)}
.crumbs a:hover{color:var(--color-ink)}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .hero-grid,.ph-grid{grid-template-columns:1fr}
  .hero-media{order:-1;width:100%;max-width:560px;margin:0 auto}
  .hero-media .hero-video{aspect-ratio:16/9}
  .ph-media{aspect-ratio:16/10}
  .hero-media .float{display:none}
  .statstrip{grid-template-columns:1fr 1fr}
  .dir-card,.dir-card.flagship{grid-column:span 6;grid-row:auto}
  .steps{grid-template-columns:1fr 1fr}
  .ba{grid-template-columns:1fr}
  .ba .ba-arrow{transform:rotate(90deg);padding:6px 0}
  .rev-videos{grid-template-columns:1fr 1fr}
  .rev-texts{grid-template-columns:1fr}
  .quest{grid-column:span 6}
  .enroll{grid-template-columns:1fr}
}
@media(max-width:640px){
  .statstrip{grid-template-columns:1fr 1fr}
  .dir-card,.dir-card.flagship{grid-column:1/-1}
  .steps{grid-template-columns:1fr}
  .rev-videos{grid-template-columns:1fr}
  .quest{grid-column:1/-1}
  .contact-band,.final-band{padding:40px 26px}
  .tg-band{padding:34px 26px}
}
/* ---------- Status pages (thank-you / fail) ---------- */
.status-wrap{min-height:68vh;display:grid;place-items:center;text-align:center;padding:72px 0}
.status{max-width:720px;margin:0 auto}
.status .icon{width:92px;height:92px;border-radius:50%;display:grid;place-items:center;margin:0 auto 24px}
.status .icon.ok{background:var(--color-mint-50);color:var(--color-mint)}
.status .icon.err{background:var(--color-blush);color:var(--color-action)}
.status .display{font-size:clamp(2.1rem,4.6vw,3.4rem);margin:14px 0 16px}
.status .lead{margin:0 auto 30px;max-width:50ch}
.status .ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.status .next{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:48px;text-align:left}
@media(max-width:760px){.status .next{grid-template-columns:1fr}}

@media(prefers-reduced-motion:reduce){
  .step:hover,.quest:hover,.chooser a:hover,.socials a:hover{transform:none}
}
