/* east-beach-13.css — 勇気のスピーチ塾 */

@import url('https://fonts.googleapis.com/css2?family=Arimo:wght@100;300;400;500;600;700&family=Noto+Serif:ital,wght@0,400;0,500;0,600;0,700;1,500&family=Source+Sans+3:wght@200..900&family=Roboto:ital,wght@0,300;0,400;0,700;1,400&display=swap');

/* ===== RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Source Sans 3',Arial,sans-serif;font-size:1em;font-weight:400;line-height:1.6;color:#000;background:#fff}
img{display:block;max-width:100%;height:auto;image-rendering:crisp-edges}
a{text-decoration:none;color:inherit}
ul{list-style:none}

/* ===== COLORS ===== */
:root{
  --dk-base:#1F3F36;
  --lt-base:#E2FBF7;
  --accent:#E67210;
  --white:#fff;
  --black:#000;
  --text-gray:#666;
  --footer-gray:#747474;
  --border-gray:#979797;
  --bg-lt-gray:#f4f4f4;
  --sale-red:#af1c3c;
}

/* ===== TYPOGRAPHY ===== */
h1,h2,h3{font-family:'Noto Serif',serif;line-height:1.1em;font-weight:700}
h1{font-size:clamp(2rem,5vw,3.5rem)}
h2{font-size:clamp(1.6rem,3.5vw,2.8rem)}
h3{font-size:clamp(1.2rem,2.5vw,1.8rem)}
p{margin-bottom:1rem;line-height:1.65}
.arimo{font-family:Arimo,sans-serif}
.noto{font-family:'Noto Serif',serif}
.upper{text-transform:uppercase}
.fw400{font-weight:400}
.fw500{font-weight:500}
.fw600{font-weight:600}
.fw700{font-weight:700}
.ls2{letter-spacing:.02em}
.ls4{letter-spacing:.04em}

/* ===== LAYOUT ===== */
.rw{margin:0 auto;max-width:1240px;padding:0 20px;width:100%}
.section{padding:60px 0}
.section-sm{padding:40px 0}
.flex{display:flex}
.flex-wrap{flex-wrap:wrap}
.flex-col{flex-direction:column}
.items-center{align-items:center}
.justify-center{justify-content:center}
.justify-between{justify-content:space-between}
.text-center{text-align:center}
.relative{position:relative}

/* ===== BUTTONS ===== */
.btn{display:inline-block;padding:.75em 2em;font-family:Arimo,sans-serif;font-weight:700;font-size:1rem;letter-spacing:.04em;text-transform:uppercase;border:1px solid transparent;cursor:pointer;transition:.15s;line-height:1.2}
.btn-primary{background-color:var(--dk-base);color:var(--white)}
.btn-primary:hover{background-color:var(--white);color:var(--dk-base);border-color:var(--dk-base)}
.btn-accent{background-color:var(--accent);color:var(--white)}
.btn-accent:hover{background-color:var(--white);color:var(--accent);border-color:var(--accent)}
.btn-outline{background-color:transparent;border:2px solid var(--dk-base);color:var(--dk-base)}
.btn-outline:hover{background-color:var(--dk-base);color:var(--white)}
.btn-white{background-color:var(--white);color:var(--dk-base)}
.btn-white:hover{background-color:var(--dk-base);color:var(--white)}
.btn-lg{padding:1em 2.5em;font-size:1.1rem}

/* ===== HEADER ===== */
.site-header{background-color:var(--dk-base);position:sticky;top:0;z-index:1000;box-shadow:0 2px 8px rgba(0,0,0,.25)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:0 20px;max-width:1240px;margin:0 auto;height:70px}
.logo-wrap{display:flex;align-items:center;gap:12px;text-decoration:none}
.logo-svg{width:44px;height:44px;flex-shrink:0}
.logo-text{font-family:'Noto Serif',serif;font-size:1.25rem;font-weight:700;color:var(--white);line-height:1.15}
.logo-text span{display:block;font-size:.75em;font-weight:400;color:var(--lt-base);font-family:'Source Sans 3',sans-serif}

/* ===== NAV ===== */
.main-nav ul{display:flex;gap:4px;align-items:center}
.main-nav a{font-family:Arimo,sans-serif;font-size:.9rem;font-weight:600;letter-spacing:.04em;color:var(--white);padding:.5em .85em;border-radius:2px;transition:.15s;text-transform:uppercase}
.main-nav a:hover,.main-nav a.active{background-color:rgba(226,251,247,.15);color:var(--lt-base)}
.nav-cta{background-color:var(--accent)!important;color:var(--white)!important;border-radius:2px}
.nav-cta:hover{background-color:#c95e00!important}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.burger span{display:block;width:25px;height:2px;background:var(--white);transition:.3s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:768px){
  .main-nav{display:none;position:absolute;top:70px;left:0;right:0;background:var(--dk-base);padding:10px 20px 20px;border-top:1px solid rgba(255,255,255,.1)}
  .main-nav.open{display:block}
  .main-nav ul{flex-direction:column;gap:2px}
  .main-nav a{display:block;padding:.7em 1em}
  .burger{display:flex}
}

/* ===== ANNOUNCEMENT BAR ===== */
.announce-bar{background-color:var(--lt-base);color:var(--dk-base);text-align:center;padding:.55em 1em;font-family:Arimo,sans-serif;font-size:.875rem;font-weight:600;letter-spacing:.01em}

/* ===== HERO ===== */
.hero{position:relative;min-height:580px;display:flex;align-items:center;overflow:hidden;background-color:var(--dk-base)}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.35}
.hero-inner{position:relative;z-index:2;display:flex;align-items:center;width:100%;max-width:1240px;margin:0 auto;padding:80px 20px;gap:40px}
.hero-content{flex:1;max-width:640px}
.hero-eyebrow{font-family:Arimo,sans-serif;font-size:.875rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--lt-base);margin-bottom:1rem}
.hero-title{font-family:'Noto Serif',serif;font-size:clamp(2.2rem,5vw,3.8rem);font-weight:700;color:var(--white);line-height:1.1;margin-bottom:1.2rem}
.hero-title em{font-style:normal;color:var(--accent)}
.hero-sub{font-size:1.15rem;color:rgba(255,255,255,.88);line-height:1.65;margin-bottom:2rem}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.hero-badge{background-color:var(--accent);color:var(--white);font-family:Arimo,sans-serif;font-size:.8rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:.35em .9em;display:inline-block;margin-bottom:1rem}

.hero-stats{display:flex;gap:32px;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.2)}
.hero-stat-num{font-family:'Noto Serif',serif;font-size:2rem;font-weight:700;color:var(--lt-base);display:block;line-height:1}
.hero-stat-label{font-size:.85rem;color:rgba(255,255,255,.7);margin-top:.2em}

.hero-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.15);padding:32px;flex:0 0 320px;backdrop-filter:blur(4px)}
.hero-card h3{font-family:'Noto Serif',serif;font-size:1.3rem;color:var(--white);margin-bottom:1rem}
.hero-card ul{display:flex;flex-direction:column;gap:.6rem}
.hero-card ul li{color:rgba(255,255,255,.85);font-size:.95rem;padding-left:1.4em;position:relative}
.hero-card ul li::before{content:'\f00c';font-family:'Font Awesome 6 Free';font-weight:900;position:absolute;left:0;color:var(--accent);font-size:.8em;top:.15em}

@media(max-width:900px){.hero-card{display:none}}
@media(max-width:600px){
  .hero-inner{padding:60px 20px}
  .hero-stats{gap:20px}
}

/* ===== TRUST RAIL ===== */
.trust-rail{background-color:var(--bg-lt-gray);border-bottom:1px solid #e0e0e0}
.trust-rail-inner{display:flex;justify-content:space-around;align-items:center;max-width:1240px;margin:0 auto;padding:18px 20px;gap:20px;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:10px;font-family:Arimo,sans-serif;font-size:.875rem;font-weight:600;color:var(--dk-base)}
.trust-item i{font-size:1.3rem;color:var(--accent)}

/* ===== PROBLEM SECTION ===== */
.problem-section{background-color:var(--white)}
.problem-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.problem-tag{font-family:Arimo,sans-serif;font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem}
.problem-photo{width:100%;aspect-ratio:4/3;object-fit:cover}
.problem-list{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}
.problem-item{display:flex;align-items:flex-start;gap:12px;padding:1rem;background:var(--bg-lt-gray);border-left:3px solid var(--accent)}
.problem-item i{font-size:1.1rem;color:var(--accent);flex-shrink:0;margin-top:.1em}
.problem-item p{font-size:.95rem;margin:0;line-height:1.5}

@media(max-width:768px){.problem-grid{grid-template-columns:1fr;gap:32px}}

/* ===== FEATURES SECTION ===== */
.features-section{background-color:var(--lt-base)}
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:48px}
.feature-card{background:var(--white);padding:32px 28px;border-top:3px solid var(--dk-base);transition:.2s}
.feature-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.1)}
.feature-icon{width:52px;height:52px;background-color:var(--dk-base);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem}
.feature-icon i{font-size:1.4rem;color:var(--white)}
.feature-card h3{font-size:1.2rem;margin-bottom:.75rem;color:var(--dk-base)}
.feature-card p{font-size:.95rem;color:var(--text-gray);margin:0;line-height:1.6}

@media(max-width:900px){.features-grid{grid-template-columns:1fr 1fr}}
@media(max-width:580px){.features-grid{grid-template-columns:1fr}}

/* ===== STEPS SECTION ===== */
.steps-section{background-color:var(--dk-base);color:var(--white)}
.steps-section h2{color:var(--white)}
.steps-section .section-sub{color:rgba(255,255,255,.75)}
.steps-layout{display:flex;gap:48px;align-items:center;margin-top:48px}
.steps-list{flex:1;min-width:0;display:flex;flex-direction:column;gap:0}
.step-item{display:flex;gap:20px;padding:24px 0;border-bottom:1px solid rgba(255,255,255,.1);align-items:flex-start}
.step-item:last-child{border-bottom:none}
.step-num{width:48px;height:48px;min-width:48px;background-color:var(--accent);display:flex;align-items:center;justify-content:center;font-family:'Noto Serif',serif;font-size:1.3rem;font-weight:700;color:var(--white);flex-shrink:0}
.step-content{flex:1;min-width:0}
.step-content h3{font-size:1.1rem;color:var(--lt-base);margin-bottom:.4rem}
.step-content p{font-size:.95rem;color:rgba(255,255,255,.75);margin:0;line-height:1.55}
.steps-photo{flex:0 0 42%;min-width:0;aspect-ratio:4/3;object-fit:cover}

@media(max-width:900px){.steps-layout{flex-direction:column}.steps-photo{width:100%;flex:none}}

/* ===== TESTIMONIALS ===== */
.testimonials-section{background-color:var(--white)}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.testimonial-card{padding:28px;border:1px solid #e8e8e8;border-top:3px solid var(--accent);position:relative}
.testimonial-stars{color:var(--accent);font-size:1rem;margin-bottom:.75rem;letter-spacing:.1em}
.testimonial-text{font-size:.95rem;line-height:1.65;color:#333;margin-bottom:1.25rem;font-style:italic}
.testimonial-author{display:flex;align-items:center;gap:12px}
.testimonial-avatar{width:42px;height:42px;border-radius:50%;background-color:var(--lt-base);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--dk-base)}
.testimonial-name{font-family:Arimo,sans-serif;font-size:.9rem;font-weight:700;color:var(--dk-base)}
.testimonial-role{font-size:.8rem;color:var(--text-gray)}

@media(max-width:900px){.testimonials-grid{grid-template-columns:1fr 1fr}}
@media(max-width:580px){.testimonials-grid{grid-template-columns:1fr}}

/* ===== PRICING PREVIEW ===== */
.pricing-section{background-color:var(--bg-lt-gray)}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.price-card{background:var(--white);padding:36px 28px;text-align:center;position:relative;border:2px solid transparent;transition:.2s}
.price-card.featured{border-color:var(--dk-base);transform:translateY(-8px)}
.price-badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--accent);color:var(--white);font-family:Arimo,sans-serif;font-size:.75rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:.3em 1em;white-space:nowrap}
.price-plan{font-family:Arimo,sans-serif;font-size:.85rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-gray);margin-bottom:.75rem}
.price-amount{font-family:'Noto Serif',serif;font-size:2.8rem;font-weight:700;color:var(--dk-base);line-height:1;margin-bottom:.4rem}
.price-amount sup{font-size:1.3rem;vertical-align:top;margin-top:.5rem;display:inline-block}
.price-period{font-size:.85rem;color:var(--text-gray);margin-bottom:1.5rem}
.price-features{text-align:left;margin-bottom:1.75rem;display:flex;flex-direction:column;gap:.6rem}
.price-features li{font-size:.9rem;padding-left:1.4em;position:relative;color:#333}
.price-features li::before{content:'\f00c';font-family:'Font Awesome 6 Free';font-weight:900;position:absolute;left:0;color:var(--dk-base);font-size:.75em;top:.2em}

@media(max-width:900px){.pricing-grid{grid-template-columns:1fr;max-width:440px;margin-left:auto;margin-right:auto}.price-card.featured{transform:none}}
/* ===== SECTION HEADERS ===== */
.section-header{text-align:center;max-width:720px;margin:0 auto 48px}
.section-tag{font-family:Arimo,sans-serif;font-size:.8rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:.6rem;display:block}
.section-title{margin-bottom:1rem}
.section-sub{font-size:1.05rem;color:var(--text-gray);line-height:1.65;margin:0}

/* ===== CTA BANNER ===== */
.cta-banner{background-color:var(--dk-base);color:var(--white);text-align:center;padding:70px 20px}
.cta-banner h2{color:var(--white);margin-bottom:1rem}
.cta-banner p{color:rgba(255,255,255,.8);font-size:1.1rem;max-width:600px;margin:0 auto 2rem}
.cta-banner-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ===== CONTACT FORM ===== */
.contact-section{background-color:var(--white)}
.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.contact-info h2{margin-bottom:1rem}
.contact-detail{display:flex;gap:14px;align-items:flex-start;margin-bottom:1.25rem}
.contact-detail i{font-size:1.1rem;color:var(--accent);margin-top:.2em;flex-shrink:0;width:20px}
.contact-detail p{font-size:.95rem;margin:0;line-height:1.55}
.contact-form-wrap{background:var(--bg-lt-gray);padding:36px}
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-family:Arimo,sans-serif;font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--dk-base);margin-bottom:.45rem}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:.75em 1em;border:1px solid #ccc;font-family:'Source Sans 3',sans-serif;font-size:1rem;background:var(--white);transition:.15s}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--dk-base)}
.form-group textarea{min-height:130px;resize:vertical}
.form-note{font-size:.82rem;color:var(--text-gray);margin-top:.35rem}

@media(max-width:768px){.contact-layout{grid-template-columns:1fr}}

/* ===== FOOTER ===== */
.site-footer{background-color:#1a1a1a;color:var(--footer-gray)}
.footer-top{padding:56px 0 40px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;max-width:1240px;margin:0 auto;padding-left:20px;padding-right:20px}
.footer-brand .logo-text{color:var(--white)}
.footer-brand .logo-text span{color:#aaa}
.footer-desc{font-size:.9rem;line-height:1.6;margin-top:1rem;margin-bottom:1.25rem;color:#999}
.footer-socials{display:flex;gap:8px}
.footer-social-link{width:36px;height:36px;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;color:#aaa;font-size:1rem;transition:.15s}
.footer-social-link:hover{background:var(--accent);color:var(--white)}
.footer-col h4{font-family:Arimo,sans-serif;font-size:.85rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--white);margin-bottom:1.1rem}
.footer-col ul{display:flex;flex-direction:column;gap:.6rem}
.footer-col ul a{font-size:.9rem;color:#999;transition:.15s}
.footer-col ul a:hover{color:var(--lt-base)}
.footer-col .contact-line{display:flex;gap:8px;align-items:flex-start;font-size:.88rem;color:#999;margin-bottom:.7rem}
.footer-col .contact-line i{color:var(--accent);flex-shrink:0;margin-top:.15em;font-size:.9rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:18px 20px;max-width:1240px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.footer-bottom p{font-size:.83rem;color:#777}
.footer-bottom-links{display:flex;gap:20px}
.footer-bottom-links a{font-size:.83rem;color:#777;transition:.15s}
.footer-bottom-links a:hover{color:var(--lt-base)}

@media(max-width:900px){.footer-top{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:580px){.footer-top{grid-template-columns:1fr}.footer-bottom{flex-direction:column;text-align:center}}

/* ===== COOKIES GDPR ===== */
#cookie-bar{position:fixed;bottom:0;left:0;right:0;background:rgba(31,63,54,.97);color:var(--white);z-index:9999;padding:16px 20px;display:flex;gap:16px;align-items:center;justify-content:space-between;flex-wrap:wrap;transform:translateY(100%);transition:.35s}
#cookie-bar.visible{transform:translateY(0)}
#cookie-bar p{font-size:.9rem;line-height:1.5;color:rgba(255,255,255,.88);margin:0;flex:1;min-width:200px}
#cookie-bar a{color:var(--lt-base);text-decoration:underline}
.cookie-btns{display:flex;gap:8px;flex-shrink:0}
#cookie-accept{background:var(--accent);color:var(--white);border:none;padding:.55em 1.4em;font-family:Arimo,sans-serif;font-weight:700;font-size:.875rem;cursor:pointer;text-transform:uppercase;letter-spacing:.04em;transition:.15s}
#cookie-accept:hover{background:#c95e00}
#cookie-decline{background:transparent;color:rgba(255,255,255,.7);border:1px solid rgba(255,255,255,.25);padding:.55em 1.1em;font-family:Arimo,sans-serif;font-size:.875rem;cursor:pointer;transition:.15s}
#cookie-decline:hover{color:var(--white);border-color:rgba(255,255,255,.5)}

/* ===== PAGE HERO (Inner pages) ===== */
.page-hero{background-color:var(--dk-base);padding:60px 20px;text-align:center;color:var(--white)}
.page-hero h1{color:var(--white);margin-bottom:.75rem}
.page-hero p{color:rgba(255,255,255,.75);font-size:1.05rem;max-width:600px;margin:0 auto}
.breadcrumb{display:flex;justify-content:center;gap:.5em;font-family:Arimo,sans-serif;font-size:.8rem;color:rgba(255,255,255,.5);margin-bottom:1rem;text-transform:uppercase;letter-spacing:.06em}
.breadcrumb a{color:rgba(255,255,255,.6);transition:.15s}
.breadcrumb a:hover{color:var(--lt-base)}
.breadcrumb span{color:rgba(255,255,255,.35)}

/* ===== CONTENT PAGES ===== */
.content-section{padding:60px 0}
.content-body{max-width:820px;margin:0 auto;padding:0 20px}
.content-body h2{font-size:1.7rem;margin-top:2.5rem;margin-bottom:.75rem;color:var(--dk-base)}
.content-body h3{font-size:1.3rem;margin-top:2rem;margin-bottom:.6rem;color:var(--dk-base)}
.content-body p{font-size:1rem;line-height:1.7;margin-bottom:1rem}
.content-body ul{margin-bottom:1rem;padding-left:1.5rem}
.content-body ul li{margin-bottom:.5rem;font-size:1rem;line-height:1.65}
.content-body a{color:var(--dk-base);text-decoration:underline}

/* ===== ABOUT PAGE ===== */
.about-split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.about-photo{width:100%;aspect-ratio:4/3;object-fit:cover}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}
.team-card{text-align:center}
.team-photo{width:100%;aspect-ratio:1;object-fit:cover;margin-bottom:1rem}
.team-name{font-family:Arimo,sans-serif;font-weight:700;color:var(--dk-base)}
.team-role{font-size:.85rem;color:var(--text-gray)}

@media(max-width:768px){.about-split{grid-template-columns:1fr}.team-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.team-grid{grid-template-columns:1fr}}

/* ===== EASY STEPS PAGE ===== */
.big-steps-list{display:flex;flex-direction:column;gap:0;counter-reset:step}
.big-step{display:grid;grid-template-columns:80px 1fr;gap:32px;padding:40px 0;border-bottom:1px solid #e8e8e8;align-items:start}
.big-step:last-child{border-bottom:none}
.big-step-num{width:70px;height:70px;background:var(--dk-base);display:flex;align-items:center;justify-content:center;font-family:'Noto Serif',serif;font-size:1.8rem;font-weight:700;color:var(--white);flex-shrink:0}
.big-step-content h2{font-size:1.5rem;color:var(--dk-base);margin-bottom:.6rem}
.big-step-content p{font-size:1rem;color:#444;line-height:1.7;margin-bottom:.75rem}
.big-step-duration{font-family:Arimo,sans-serif;font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--accent)}

/* ===== REACH US PAGE ===== */
.map-placeholder{width:100%;aspect-ratio:16/5;background:var(--bg-lt-gray);display:flex;align-items:center;justify-content:center;border:1px solid #e0e0e0;margin-bottom:40px}
.map-placeholder i{font-size:3rem;color:#ccc}

/* ===== UTILITY ===== */
.mt1{margin-top:1rem}
.mt2{margin-top:2rem}
.mb1{margin-bottom:1rem}
.mb2{margin-bottom:2rem}
.text-accent{color:var(--accent)}
.text-dk{color:var(--dk-base)}
.bg-lt{background-color:var(--lt-base)}
.bg-dk{background-color:var(--dk-base)}

/* ===== PRINT / MINIMAL MEDIA ===== */
@media(max-width:480px){
  .section{padding:40px 0}
  .hero{min-height:auto}
  .hero-inner{padding:50px 16px}
  .hero-stats{flex-direction:column;gap:12px}
}
