/*
Theme Name: Asma English
Theme URI: https://asma-english.example
Author: Asma
Author URI: https://asma-english.example
Description: A warm, custom English-learning theme for Asma. Podcasts, IELTS and special courses, built for the Taiwan market. Hand-coded so WordPress updates never overwrite your work.
Version: 1.2.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: asma-english
*/


:root{
  --green:#A8DF8E; --cream:#F0FFDF; --pink-soft:#FFD8DF; --pink:#FFAAB8;
  --ink:#1E2B22; --ink-60:rgba(30,43,34,.62); --ink-40:rgba(30,43,34,.40);
  --white:#FFFFFF; --line:rgba(30,43,34,.12);
  --display:"Fraunces",Georgia,serif;
  --body:"Plus Jakarta Sans","Noto Sans TC",system-ui,sans-serif;
  --tc:"Noto Sans TC","Plus Jakarta Sans",sans-serif;
  --radius:22px; --shadow:0 18px 50px -22px rgba(30,43,34,.35);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--cream);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}
a{color:inherit;text-decoration:none}
.tc{font-family:var(--tc)}
.eyebrow{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;color:var(--ink-60);display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--green);border-radius:2px}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.94rem;padding:12px 22px;border-radius:999px;cursor:pointer;border:none;font-family:var(--body);transition:transform .18s ease,box-shadow .2s ease,background .2s ease}
.btn-primary{background:var(--ink);color:var(--cream)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 28px -12px rgba(30,43,34,.55)}
.btn-ghost{background:var(--white);color:var(--ink);box-shadow:inset 0 0 0 1px var(--line)}
.btn-ghost:hover{transform:translateY(-2px);background:var(--pink-soft)}
.btn-green{background:var(--green);color:var(--ink)}
.btn-green:hover{transform:translateY(-2px);background:var(--pink)}
.btn-block{width:100%;justify-content:center}

/* nav */
header{position:sticky;top:0;z-index:50;backdrop-filter:saturate(160%) blur(12px);background:rgba(240,255,223,.78);border-bottom:1px solid var(--line)}
nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--display);font-weight:600;font-size:1.5rem;letter-spacing:.02em}
.brand .dot{width:34px;height:34px;border-radius:11px;display:grid;place-items:center;background:var(--green);box-shadow:inset 0 0 0 2px rgba(255,255,255,.5)}
.nav-links{display:flex;gap:34px;align-items:center}
.nav-links a{font-size:.94rem;font-weight:500;color:var(--ink-60);transition:color .2s;position:relative}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--green);border-radius:2px}
.nav-right{display:flex;align-items:center;gap:16px}
.lang{display:flex;border:1px solid var(--line);border-radius:999px;overflow:hidden;font-size:.8rem;font-weight:600}
.lang button{background:none;border:none;font:inherit;cursor:pointer;padding:7px 13px;color:var(--ink-40)}
.lang button.on{background:var(--green);color:var(--ink)}
.menu-toggle{display:none;background:none;border:none;cursor:pointer}

/* generic section */
section{padding:88px 0}
.sec-head{max-width:42em;margin-bottom:46px}
.sec-head h2{font-family:var(--display);font-weight:600;font-size:clamp(2rem,3.6vw,2.9rem);line-height:1.08;letter-spacing:-.01em;margin:14px 0 0}
.sec-head p{color:var(--ink-60);margin-top:14px;font-size:1.05rem}

/* breadcrumb */
.crumb{padding:26px 0 0;font-size:.85rem;color:var(--ink-60);display:flex;gap:8px;align-items:center}
.crumb a:hover{color:var(--ink)}
.crumb span{color:var(--ink-40)}

/* waveform */
.wave{display:flex;align-items:flex-end;gap:4px;height:58px}
.wave span{flex:1;background:linear-gradient(var(--green),var(--pink));border-radius:6px;transform-origin:bottom;animation:bar 1.5s ease-in-out infinite}
@keyframes bar{0%,100%{transform:scaleY(.28)}50%{transform:scaleY(1)}}

/* footer */
footer{padding:70px 0 40px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:30px;margin-bottom:46px}
.foot-brand p{color:var(--ink-60);max-width:24em;margin-top:16px;font-size:.95rem}
.foot-col h5{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-40);margin-bottom:16px}
.foot-col a{display:block;color:var(--ink-60);font-size:.94rem;margin-bottom:11px;transition:color .2s}
.foot-col a:hover{color:var(--ink)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);padding-top:24px;font-size:.86rem;color:var(--ink-60);flex-wrap:wrap;gap:12px}
.socials{display:flex;gap:12px}
.socials a{width:38px;height:38px;border-radius:50%;background:var(--white);border:1px solid var(--line);display:grid;place-items:center;transition:background .2s,transform .18s}
.socials a:hover{background:var(--green);transform:translateY(-2px)}

@media(max-width:920px){
  .nav-links{display:none}.menu-toggle{display:block}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){.wrap{padding:0 20px}.foot-grid{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){*{animation:none!important;scroll-behavior:auto!important}}
:focus-visible{outline:3px solid var(--pink);outline-offset:3px;border-radius:8px}

.hero{position:relative;padding:78px 0 70px}
.hero::before{content:"";position:absolute;inset:0;z-index:-1;background:radial-gradient(620px 360px at 88% 8%,var(--pink-soft),transparent 70%),radial-gradient(560px 420px at 6% 92%,rgba(168,223,142,.55),transparent 65%)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.hero h1{font-family:var(--display);font-weight:600;line-height:1.02;letter-spacing:-.015em;font-size:clamp(2.6rem,5.2vw,4.3rem);margin:20px 0 0}
.hero h1 em{font-style:italic;position:relative}
.hero h1 em::after{content:"";position:absolute;left:0;right:0;bottom:.06em;height:.32em;z-index:-1;background:var(--green);border-radius:6px;opacity:.85}
.hero p.lede{font-size:1.12rem;color:var(--ink-60);max-width:30em;margin:22px 0 30px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-stats{display:flex;gap:34px;margin-top:38px}
.hero-stats .s b{font-family:var(--display);font-size:1.7rem;font-weight:600;display:block;line-height:1}
.hero-stats .s span{font-size:.82rem;color:var(--ink-60)}
.player{background:var(--white);border-radius:28px;padding:26px;box-shadow:var(--shadow);position:relative;border:1px solid rgba(255,255,255,.7)}
.player::before{content:"";position:absolute;inset:-1px;border-radius:29px;z-index:-1;background:linear-gradient(135deg,var(--green),var(--pink));opacity:.5}
.player .top{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.player .cover{width:62px;height:62px;border-radius:18px;flex:none;display:grid;place-items:center;background:linear-gradient(140deg,var(--green),var(--pink-soft));font-family:var(--display);font-size:1.5rem;font-weight:600}
.player .now{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--pink);font-weight:700}
.player .ep-title{font-family:var(--display);font-size:1.18rem;font-weight:600;line-height:1.2;margin-top:2px}
.player .ep-sub{font-size:.84rem;color:var(--ink-60)}
.player .wave{margin:6px 0 18px}
.player .controls{display:flex;align-items:center;gap:16px}
.play{width:50px;height:50px;border-radius:50%;border:none;cursor:pointer;flex:none;background:var(--ink);color:var(--cream);display:grid;place-items:center;transition:transform .18s}
.play:hover{transform:scale(1.06)}
.timeline{flex:1;height:6px;border-radius:6px;background:var(--cream);position:relative;overflow:hidden}
.timeline i{position:absolute;left:0;top:0;bottom:0;width:38%;background:var(--green);border-radius:6px}
.time{font-size:.78rem;color:var(--ink-60);font-variant-numeric:tabular-nums}
.ticker{background:var(--ink);color:var(--cream);overflow:hidden;padding:14px 0}
.ticker-track{display:flex;gap:40px;white-space:nowrap;animation:scroll 26s linear infinite;width:max-content}
.ticker-track span{font-family:var(--display);font-size:1.05rem;font-weight:500;display:inline-flex;align-items:center;gap:40px}
.ticker-track span::after{content:"✦";color:var(--green)}
@keyframes scroll{to{transform:translateX(-50%)}}
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.pillar{border-radius:var(--radius);padding:30px 28px;position:relative;overflow:hidden;transition:transform .22s ease;border:1px solid var(--line)}
.pillar:hover{transform:translateY(-6px)}
.pillar:nth-child(1){background:var(--green)}
.pillar:nth-child(2){background:var(--pink-soft)}
.pillar:nth-child(3){background:var(--white)}
.pillar .ic{width:50px;height:50px;border-radius:14px;background:rgba(255,255,255,.6);display:grid;place-items:center;margin-bottom:20px}
.pillar h3{font-family:var(--display);font-size:1.45rem;font-weight:600;margin-bottom:10px}
.pillar p{font-size:.95rem;color:var(--ink-60)}
.pillar .more{display:inline-flex;align-items:center;gap:7px;margin-top:18px;font-weight:600;font-size:.9rem}
.pillar .more svg{transition:transform .2s}.pillar:hover .more svg{transform:translateX(4px)}
.courses{background:var(--white)}
.course-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.course{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--cream);display:flex;flex-direction:column;transition:transform .22s,box-shadow .22s}
.course:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.course .thumb{height:150px;position:relative;display:grid;place-items:center}
.course:nth-child(1) .thumb{background:linear-gradient(135deg,var(--green),var(--cream))}
.course:nth-child(2) .thumb{background:linear-gradient(135deg,var(--pink),var(--pink-soft))}
.course:nth-child(3) .thumb{background:linear-gradient(135deg,var(--pink-soft),var(--green))}
.course:nth-child(4) .thumb{background:linear-gradient(135deg,var(--cream),var(--pink-soft))}
.course:nth-child(5) .thumb{background:linear-gradient(135deg,var(--green),var(--pink))}
.course:nth-child(6) .thumb{background:linear-gradient(135deg,var(--pink-soft),var(--cream))}
.course .thumb b{font-family:var(--display);font-size:2.4rem;font-weight:600;opacity:.55}
.course .tag{position:absolute;top:14px;left:14px;background:var(--white);font-size:.72rem;font-weight:700;padding:5px 11px;border-radius:999px;letter-spacing:.04em}
.course .body{padding:22px;display:flex;flex-direction:column;gap:8px;flex:1}
.course h4{font-family:var(--display);font-size:1.22rem;font-weight:600;line-height:1.2}
.course .desc{font-size:.9rem;color:var(--ink-60);flex:1}
.course .foot{display:flex;align-items:center;justify-content:space-between;margin-top:8px;padding-top:16px;border-top:1px solid var(--line)}
.course .price{font-family:var(--display);font-weight:600;font-size:1.2rem}
.course .price small{font-size:.78rem;color:var(--ink-40);font-weight:400}
.course .lvl{font-size:.8rem;color:var(--ink-60);display:flex;align-items:center;gap:6px}
.course .lvl::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green)}
.about-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:56px;align-items:center}
.portrait{aspect-ratio:4/5;border-radius:28px;position:relative;overflow:hidden;background:linear-gradient(160deg,var(--green),var(--pink-soft));box-shadow:var(--shadow);display:grid;place-items:center}
.portrait .initials{font-family:var(--display);font-size:8rem;font-weight:600;color:rgba(255,255,255,.85)}
.portrait .badge{position:absolute;bottom:20px;left:20px;right:20px;background:rgba(255,255,255,.92);backdrop-filter:blur(6px);border-radius:18px;padding:16px 18px;display:flex;align-items:center;gap:13px}
.portrait .badge .av{width:42px;height:42px;border-radius:50%;background:var(--ink);color:var(--cream);display:grid;place-items:center;font-weight:700}
.portrait .badge b{font-family:var(--display);font-size:1rem;display:block}
.portrait .badge span{font-size:.8rem;color:var(--ink-60)}
.about-text h2{font-family:var(--display);font-size:clamp(2rem,3.4vw,2.8rem);font-weight:600;line-height:1.1;margin:14px 0 18px}
.about-text p{color:var(--ink-60);font-size:1.05rem;margin-bottom:16px}
.about-text .chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.chip{background:var(--cream);border:1px solid var(--line);border-radius:999px;padding:8px 16px;font-size:.86rem;font-weight:500}
.cta-band{background:var(--ink);color:var(--cream);border-radius:32px;padding:62px 56px;position:relative;overflow:hidden;margin:0 28px}
.cta-band::after{content:"";position:absolute;right:-60px;top:-60px;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,var(--pink),transparent 70%);opacity:.45}
.cta-band h2{font-family:var(--display);font-size:clamp(2rem,3.6vw,3rem);font-weight:600;line-height:1.08;max-width:14em}
.cta-band p{color:rgba(240,255,223,.72);margin:16px 0 30px;max-width:34em;font-size:1.05rem}
.signup{display:flex;gap:12px;max-width:480px;flex-wrap:wrap}
.signup input{flex:1;min-width:220px;border:none;border-radius:999px;padding:14px 22px;font:inherit;background:rgba(240,255,223,.12);color:var(--cream)}
.signup input::placeholder{color:rgba(240,255,223,.5)}
@media(max-width:920px){.hero-grid,.about-grid{grid-template-columns:1fr;gap:40px}.pillars,.course-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.pillars,.course-grid{grid-template-columns:1fr}.hero-stats{gap:24px;flex-wrap:wrap}.cta-band{padding:44px 28px;margin:0 20px}.signup input{min-width:100%}}

.chero{padding:30px 0 70px;position:relative}
.chero::before{content:"";position:absolute;inset:0;z-index:-1;background:radial-gradient(700px 380px at 80% 0%,var(--pink-soft),transparent 70%)}
.chero-grid{display:grid;grid-template-columns:1.35fr .65fr;gap:48px;align-items:start;margin-top:18px}
.chero .tagrow{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap}
.pill{background:var(--white);border:1px solid var(--line);border-radius:999px;padding:6px 14px;font-size:.78rem;font-weight:600}
.pill.accent{background:var(--green);border-color:transparent}
.chero h1{font-family:var(--display);font-weight:600;font-size:clamp(2.3rem,4.4vw,3.5rem);line-height:1.04;letter-spacing:-.01em}
.chero .sub{font-size:1.12rem;color:var(--ink-60);max-width:32em;margin:18px 0 24px}
.meta-row{display:flex;gap:28px;flex-wrap:wrap;margin-top:8px}
.meta-row .m{display:flex;align-items:center;gap:9px;font-size:.92rem;color:var(--ink-60)}
.meta-row .m b{color:var(--ink);font-weight:600}
/* sticky buy card */
.buy{position:sticky;top:96px;background:var(--white);border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:var(--shadow)}
.buy .vid{height:170px;background:linear-gradient(140deg,var(--green),var(--pink-soft));display:grid;place-items:center;position:relative}
.buy .vid .pbtn{width:56px;height:56px;border-radius:50%;background:rgba(255,255,255,.92);display:grid;place-items:center}
.buy .vid .free{position:absolute;bottom:12px;left:12px;background:var(--ink);color:var(--cream);font-size:.74rem;font-weight:600;padding:5px 12px;border-radius:999px}
.buy .pad{padding:24px}
.buy .pr{display:flex;align-items:baseline;gap:10px;margin-bottom:4px}
.buy .pr b{font-family:var(--display);font-size:2rem;font-weight:600}
.buy .pr s{color:var(--ink-40);font-size:1rem}
.buy .pr .off{background:var(--pink-soft);color:var(--ink);font-size:.74rem;font-weight:700;padding:3px 9px;border-radius:6px}
.buy .note{font-size:.84rem;color:var(--ink-60);margin-bottom:18px}
.buy .incl{list-style:none;margin-top:18px;display:grid;gap:11px}
.buy .incl li{display:flex;gap:10px;font-size:.9rem;color:var(--ink-60)}
.buy .incl svg{flex:none;margin-top:2px}
.learn-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 30px}
.learn-grid li{list-style:none;display:flex;gap:12px;font-size:1rem}
.learn-grid svg{flex:none;margin-top:3px}
.learn-wrap{background:var(--white)}
/* curriculum */
.mod{border:1px solid var(--line);border-radius:16px;margin-bottom:12px;background:var(--white);overflow:hidden}
.mod summary{list-style:none;cursor:pointer;padding:20px 24px;display:flex;align-items:center;gap:16px;font-weight:600}
.mod summary::-webkit-details-marker{display:none}
.mod summary .n{font-family:var(--display);font-size:1.1rem;color:var(--ink-40);width:34px}
.mod summary .t{flex:1}
.mod summary .t h4{font-family:var(--display);font-size:1.12rem;font-weight:600}
.mod summary .t span{font-size:.82rem;color:var(--ink-60);font-weight:400}
.mod summary .chev{transition:transform .2s}
.mod[open] summary .chev{transform:rotate(180deg)}
.mod .lessons{padding:0 24px 18px 74px;display:grid;gap:10px}
.mod .lessons div{display:flex;align-items:center;gap:10px;font-size:.92rem;color:var(--ink-60)}
/* pricing */
.pricing{background:linear-gradient(180deg,var(--cream),var(--pink-soft))}
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch}
.tier{background:var(--white);border:1px solid var(--line);border-radius:24px;padding:30px 28px;display:flex;flex-direction:column}
.tier.feat{border:2px solid var(--ink);position:relative;transform:translateY(-8px)}
.tier .badge2{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--ink);color:var(--cream);font-size:.74rem;font-weight:700;padding:5px 14px;border-radius:999px}
.tier h3{font-family:var(--display);font-size:1.35rem;font-weight:600}
.tier .who{font-size:.88rem;color:var(--ink-60);margin:6px 0 18px;min-height:2.6em}
.tier .amt{font-family:var(--display);font-size:2.4rem;font-weight:600;line-height:1}
.tier .amt small{font-size:.9rem;color:var(--ink-40);font-weight:400}
.tier ul{list-style:none;margin:20px 0 24px;display:grid;gap:12px;flex:1}
.tier li{display:flex;gap:10px;font-size:.92rem;color:var(--ink-60)}
.tier li svg{flex:none;margin-top:2px}
.pay-row{display:flex;align-items:center;justify-content:center;gap:20px;margin-top:34px;flex-wrap:wrap;color:var(--ink-60);font-size:.86rem}
.pay-row .badges{display:flex;gap:10px}
.pay-row .badges span{background:var(--white);border:1px solid var(--line);border-radius:8px;padding:7px 12px;font-weight:600;font-size:.8rem}
/* reviews */
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rev{background:var(--white);border:1px solid var(--line);border-radius:20px;padding:26px}
.rev .stars{color:var(--pink);font-size:.95rem;letter-spacing:2px;margin-bottom:12px}
.rev p{font-size:.96rem;margin-bottom:18px}
.rev .who{display:flex;align-items:center;gap:11px}
.rev .who .av{width:38px;height:38px;border-radius:50%;background:var(--green);display:grid;place-items:center;font-weight:700;font-size:.9rem}
.rev .who b{font-size:.9rem;display:block}.rev .who span{font-size:.8rem;color:var(--ink-60)}
/* faq */
.faq{max-width:780px;margin:0 auto}
.faq details{border-bottom:1px solid var(--line);padding:4px 0}
.faq summary{list-style:none;cursor:pointer;padding:20px 0;font-family:var(--display);font-size:1.12rem;font-weight:600;display:flex;justify-content:space-between;gap:20px}
.faq summary::-webkit-details-marker{display:none}
.faq summary .chev{transition:transform .2s;flex:none}
.faq details[open] summary .chev{transform:rotate(45deg)}
.faq p{padding:0 0 22px;color:var(--ink-60)}
@media(max-width:920px){.chero-grid{grid-template-columns:1fr}.buy{position:static}.tiers,.rev-grid{grid-template-columns:1fr}.tier.feat{transform:none}.learn-grid{grid-template-columns:1fr}}

.phero{padding:30px 0 50px;position:relative}
.phero::before{content:"";position:absolute;inset:0;z-index:-1;background:radial-gradient(640px 360px at 85% 0%,var(--green),transparent 70%)}
.phero-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;margin-top:14px}
.phero h1{font-family:var(--display);font-weight:600;font-size:clamp(2.4rem,4.6vw,3.6rem);line-height:1.04;margin:14px 0 0}
.phero p{font-size:1.12rem;color:var(--ink-60);max-width:30em;margin:18px 0 26px}
.subscribe{display:flex;gap:12px;flex-wrap:wrap}
.subscribe a{display:inline-flex;align-items:center;gap:9px;background:var(--white);border:1px solid var(--line);border-radius:999px;padding:11px 18px;font-weight:600;font-size:.9rem;transition:transform .18s,background .2s}
.subscribe a:hover{transform:translateY(-2px);background:var(--pink-soft)}
.feature{background:var(--white);border:1px solid var(--line);border-radius:28px;padding:30px;box-shadow:var(--shadow)}
.feature .lbl{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--pink);font-weight:700}
.feature h3{font-family:var(--display);font-size:1.6rem;font-weight:600;line-height:1.15;margin:8px 0 6px}
.feature .epmeta{font-size:.88rem;color:var(--ink-60);margin-bottom:18px}
.feature .wave{margin:0 0 20px;height:64px}
.feature .row{display:flex;align-items:center;gap:16px}
.bigplay{width:56px;height:56px;border-radius:50%;background:var(--ink);color:var(--cream);border:none;cursor:pointer;display:grid;place-items:center;flex:none;transition:transform .18s}
.bigplay:hover{transform:scale(1.06)}
.feature .tl{flex:1;height:6px;border-radius:6px;background:var(--cream);position:relative;overflow:hidden}
.feature .tl i{position:absolute;inset:0 62% 0 0;background:var(--green);border-radius:6px}
.feature .t{font-size:.82rem;color:var(--ink-60);font-variant-numeric:tabular-nums}
.eplist{background:var(--white)}
.ep{display:grid;grid-template-columns:auto 1fr auto auto;gap:22px;align-items:center;background:var(--cream);border-radius:18px;padding:18px 24px;margin-bottom:14px;border:1px solid var(--line);transition:transform .18s}
.ep:hover{transform:translateX(6px)}
.ep .num{font-family:var(--display);font-size:1.3rem;font-weight:600;color:var(--ink-40);width:46px}
.ep .info h4{font-family:var(--display);font-size:1.12rem;font-weight:600}
.ep .info p{font-size:.86rem;color:var(--ink-60)}
.ep .info .tags{margin-top:6px;display:flex;gap:6px}
.ep .info .tags span{font-size:.7rem;font-weight:600;background:var(--pink-soft);padding:3px 9px;border-radius:999px}
.ep .mini-wave{display:flex;gap:3px;align-items:flex-end;height:26px}
.ep .mini-wave i{width:3px;background:var(--green);border-radius:3px}
.ep .len{font-size:.85rem;color:var(--ink-60);font-variant-numeric:tabular-nums}
.ep .ep-play{width:42px;height:42px;border-radius:50%;background:var(--pink-soft);border:none;cursor:pointer;display:grid;place-items:center;transition:background .2s,transform .18s}
.ep .ep-play:hover{background:var(--green);transform:scale(1.07)}
.promo{background:linear-gradient(135deg,var(--green),var(--pink-soft));border-radius:28px;padding:46px;display:grid;grid-template-columns:1.3fr .7fr;gap:30px;align-items:center}
.promo h3{font-family:var(--display);font-size:1.9rem;font-weight:600;line-height:1.1}
.promo p{color:var(--ink-60);margin-top:10px}
@media(max-width:920px){.phero-grid{grid-template-columns:1fr;gap:32px}.promo{grid-template-columns:1fr}}
@media(max-width:600px){.ep{grid-template-columns:auto 1fr auto}.ep .mini-wave{display:none}}

.ahero{padding:40px 0 50px}
.ahero-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.ahero .portrait{aspect-ratio:4/5;border-radius:30px;position:relative;overflow:hidden;background:linear-gradient(160deg,var(--green),var(--pink-soft));box-shadow:var(--shadow);display:grid;place-items:center}
.ahero .portrait .initials{font-family:var(--display);font-size:9rem;font-weight:600;color:rgba(255,255,255,.85)}
.ahero h1{font-family:var(--display);font-weight:600;font-size:clamp(2.4rem,4.6vw,3.6rem);line-height:1.05;margin:14px 0 18px}
.ahero p{font-size:1.1rem;color:var(--ink-60);margin-bottom:16px}
.stat-band{background:var(--ink);color:var(--cream)}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.stat-grid b{font-family:var(--display);font-size:2.6rem;font-weight:600;display:block;line-height:1}
.stat-grid span{font-size:.9rem;color:rgba(240,255,223,.7)}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.val{border-radius:var(--radius);padding:30px 28px;border:1px solid var(--line)}
.val:nth-child(1){background:var(--green)}.val:nth-child(2){background:var(--pink-soft)}.val:nth-child(3){background:var(--white)}
.val .ic{width:48px;height:48px;border-radius:14px;background:rgba(255,255,255,.6);display:grid;place-items:center;margin-bottom:18px}
.val h3{font-family:var(--display);font-size:1.3rem;font-weight:600;margin-bottom:8px}
.val p{font-size:.95rem;color:var(--ink-60)}
.timeline2{max-width:760px;margin:0 auto;position:relative;padding-left:34px}
.timeline2::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:var(--line)}
.tl-item{position:relative;padding-bottom:34px}
.tl-item::before{content:"";position:absolute;left:-34px;top:4px;width:16px;height:16px;border-radius:50%;background:var(--green);border:3px solid var(--cream)}
.tl-item .yr{font-family:var(--display);font-weight:600;color:var(--ink-40);font-size:.9rem}
.tl-item h4{font-family:var(--display);font-size:1.2rem;font-weight:600;margin:2px 0 4px}
.tl-item p{color:var(--ink-60);font-size:.96rem}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rev{background:var(--white);border:1px solid var(--line);border-radius:20px;padding:26px}
.rev .stars{color:var(--pink);letter-spacing:2px;margin-bottom:12px}
.rev p{font-size:.96rem;margin-bottom:18px}
.rev .who{display:flex;align-items:center;gap:11px}
.rev .who .av{width:38px;height:38px;border-radius:50%;background:var(--green);display:grid;place-items:center;font-weight:700;font-size:.9rem}
.rev .who b{font-size:.9rem;display:block}.rev .who span{font-size:.8rem;color:var(--ink-60)}
@media(max-width:920px){.ahero-grid,.values,.rev-grid{grid-template-columns:1fr}.stat-grid{grid-template-columns:1fr 1fr;gap:30px 20px}}

/* ---- Blog / article ---- */
.article{max-width:760px;margin:0 auto}
.article .eyebrow{margin-bottom:14px}
.article-title{font-family:var(--display);font-weight:600;font-size:clamp(2rem,4vw,3rem);line-height:1.08;letter-spacing:-.01em}
.article .meta{color:var(--ink-60);font-size:.9rem;margin:14px 0 24px;display:flex;gap:14px;align-items:center}
.article .feat{width:100%;height:auto;border-radius:var(--radius);margin:0 0 28px;display:block}
.article-body{font-size:1.08rem;color:var(--ink)}
.article-body p{margin:0 0 18px}
.article-body h2{font-family:var(--display);font-size:1.6rem;font-weight:600;margin:32px 0 12px}
.article-body h3{font-family:var(--display);font-size:1.3rem;font-weight:600;margin:26px 0 10px}
.article-body a{color:var(--ink);text-decoration:underline;text-decoration-color:var(--green);text-decoration-thickness:2px}
.article-body img{max-width:100%;height:auto;border-radius:14px}
.article-body ul,.article-body ol{margin:0 0 18px 20px}
.article-body li{margin-bottom:8px}
.article-body blockquote{border-left:3px solid var(--green);margin:20px 0;padding:4px 0 4px 20px;color:var(--ink-60);font-style:italic;border-radius:0}
.video-embed{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:18px;margin:24px 0;background:var(--ink)}
.video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.article-cta{margin:44px 0 0;background:linear-gradient(135deg,var(--green),var(--pink-soft));border-radius:24px;padding:34px;text-align:center}
.article-cta h3{font-family:var(--display);font-size:1.5rem;font-weight:600;margin-bottom:14px}
.pagination{display:flex;gap:10px;justify-content:center;margin-top:36px;flex-wrap:wrap}
.pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 12px;border-radius:999px;border:1px solid var(--line);font-weight:600;font-size:.9rem;background:var(--white)}
.pagination .page-numbers.current{background:var(--green);border-color:transparent}
.pagination a.page-numbers:hover{background:var(--pink-soft)}

/* ---- About this course (richer block) ---- */
.about-course{display:grid;grid-template-columns:.8fr 1.2fr;gap:48px;align-items:start;background:linear-gradient(135deg,var(--cream),var(--pink-soft));border:1px solid var(--line);border-radius:28px;padding:44px}
.about-course .ac-left h2{font-family:var(--display);font-size:1.9rem;font-weight:600;line-height:1.12;margin-top:14px}
.about-course .ac-tag{display:inline-flex;align-items:center;gap:8px;margin-top:18px;background:var(--white);border:1px solid var(--line);border-radius:999px;padding:8px 16px;font-size:.85rem;font-weight:600}
.about-course .ac-body{font-size:1.08rem;color:var(--ink)}
.about-course .ac-body p:last-child{margin-bottom:0}
.about-course .ac-body p:first-child::first-letter{font-family:var(--display);font-size:3.1rem;font-weight:600;float:left;line-height:.8;margin:6px 12px 0 0;color:var(--ink)}
@media(max-width:760px){.about-course{grid-template-columns:1fr;gap:24px;padding:28px}.about-course .ac-body p:first-child::first-letter{font-size:2.6rem}}
