/* =========================================================
   美想道 MXD · Shared Stylesheet
   Editorial elegance — burgundy / taupe / cream / gold
   ========================================================= */

:root{
  /* Brand */
  --burgundy-900:#3D0F1E;
  --burgundy-800:#4A1424;
  --burgundy-700:#5C1A2C;          /* primary */
  --burgundy-600:#7A2638;
  --burgundy-500:#8B3A4F;
  --burgundy-200:#E7CFCB;
  --burgundy-100:#F2DCD7;

  --taupe-800:#7B6A55;
  --taupe-700:#9C8870;
  --taupe-500:#B5A089;
  --taupe-300:#D4C5B0;
  --taupe-200:#E5DBC8;
  --taupe-100:#EFE6D5;

  --cream-50:#FAF6EF;
  --cream-100:#F7F1E8;
  --cream-200:#F0E8DA;

  --gold-700:#A98452;
  --gold-500:#C9A87A;
  --gold-300:#E1C99E;

  --ink-900:#2A1518;               /* near-black brown for text */
  --ink-700:#4A3133;
  --ink-500:#7B5F62;
  --ink-300:#B4A0A2;

  /* Roles */
  --bg:var(--cream-100);
  --bg-alt:var(--cream-50);
  --surface:#ffffff;
  --text:var(--ink-900);
  --text-muted:var(--ink-500);
  --primary:var(--burgundy-700);
  --primary-deep:var(--burgundy-900);
  --accent:var(--gold-500);
  --line:rgba(60, 26, 31, 0.12);

  /* Type */
  --font-serif:"Noto Serif TC","Cormorant Garamond","Songti SC",serif;
  --font-display:"Cormorant Garamond","Noto Serif TC",serif;
  --font-sans:"Noto Sans TC","Inter","Helvetica Neue",sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,monospace;

  /* Layout */
  --container:1240px;
  --gutter:clamp(20px, 4vw, 56px);
  --radius-sm:4px;
  --radius:10px;
  --radius-lg:18px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--font-sans);
  color:var(--text);
  background:var(--bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"palt";
}
img,svg{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;padding:0}
a{color:inherit;text-decoration:none;transition:color .2s ease,opacity .2s ease}
a:hover{color:var(--primary)}
h1,h2,h3,h4,h5{font-family:var(--font-serif);font-weight:500;letter-spacing:.02em;line-height:1.25;margin:0;color:var(--ink-900);text-wrap:balance}
p{margin:0;text-wrap:pretty}

/* ---------- Utilities ---------- */
.container{max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.eyebrow{font-family:var(--font-display);font-style:italic;font-size:14px;letter-spacing:.32em;text-transform:uppercase;color:var(--burgundy-700);font-weight:500}
.eyebrow::before{content:"";display:inline-block;width:28px;height:1px;background:var(--burgundy-700);vertical-align:middle;margin-right:14px;transform:translateY(-3px)}
.section{padding:clamp(64px,9vw,128px) 0}
.section-tight{padding:clamp(48px,6vw,80px) 0}
.divider{height:1px;background:var(--line);width:100%}
.text-center{text-align:center}
.muted{color:var(--text-muted)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 28px;
  font-family:var(--font-sans);font-size:15px;font-weight:500;letter-spacing:.12em;
  border-radius:999px;
  transition:transform .25s ease,background .25s ease,color .25s ease,box-shadow .25s ease;
  cursor:pointer;white-space:nowrap;
}
.btn-primary{background:var(--burgundy-700);color:var(--cream-50)}
.btn-primary:hover{background:var(--burgundy-900);color:var(--cream-50);transform:translateY(-1px)}
.btn-outline{border:1px solid var(--burgundy-700);color:var(--burgundy-700);background:transparent}
.btn-outline:hover{background:var(--burgundy-700);color:var(--cream-50)}
.btn-ghost{color:var(--burgundy-700);padding:14px 0;border-radius:0;border-bottom:1px solid currentColor;letter-spacing:.18em}
.btn-ghost:hover{color:var(--burgundy-900)}
.btn-gold{background:var(--gold-500);color:var(--burgundy-900)}
.btn-gold:hover{background:var(--gold-700);color:var(--cream-50)}
.btn .arr{transition:transform .25s ease}
.btn:hover .arr{transform:translateX(4px)}

/* ---------- Navigation ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(247,241,232,.88);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(60,26,31,.08);
}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;height:104px}
.nav-logo{display:flex;align-items:center;gap:4px;color:var(--burgundy-900)}
.nav-logo img{width:80px;height:80px;object-fit:contain;margin-right:-4px}
.nav-logo-text{display:flex;flex-direction:column;line-height:1}
.nav-logo-text .zh{font-family:var(--font-serif);font-size:18px;letter-spacing:.22em;font-weight:500}
.nav-logo-text .en{font-family:var(--font-display);font-size:11px;letter-spacing:.32em;color:var(--burgundy-700);margin-top:5px;text-transform:uppercase}

.nav-list{display:flex;gap:4px;list-style:none;padding:0;margin:0;align-items:center}
.nav-list a{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 16px;font-size:14.5px;color:var(--ink-900);
  letter-spacing:.08em;font-weight:500;border-radius:999px;
  position:relative;
}
.nav-list a:hover{color:var(--burgundy-700)}
.nav-list a.active{color:var(--burgundy-700)}
.nav-list a.active::after{
  content:"";position:absolute;bottom:2px;left:50%;transform:translateX(-50%);
  width:18px;height:1px;background:var(--burgundy-700);
}
.nav-item{position:relative}
.nav-item .caret{width:8px;height:8px;border-right:1.2px solid currentColor;border-bottom:1.2px solid currentColor;transform:rotate(45deg);margin-top:-3px;opacity:.6}
.dropdown{
  position:absolute;top:calc(100% + 4px);left:50%;transform:translateX(-50%) translateY(6px);
  background:var(--cream-50);
  border:1px solid var(--line);
  border-radius:14px;
  padding:14px;
  min-width:240px;
  display:flex;flex-direction:column;gap:2px;
  opacity:0;visibility:hidden;
  transition:opacity .2s ease,transform .2s ease,visibility .2s;
  box-shadow:0 24px 48px -20px rgba(60,26,31,.18);
}
.nav-item:hover .dropdown,.nav-item:focus-within .dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dropdown a{padding:12px 16px;border-radius:10px;font-size:14px}
.dropdown a:hover{background:var(--cream-200);color:var(--burgundy-700)}
.dropdown a small{display:block;color:var(--text-muted);font-size:12px;margin-top:3px;letter-spacing:.04em;font-weight:400}

.nav-cta{display:flex;align-items:center;gap:14px}
.nav-cta .ico-line{
  width:38px;height:38px;border-radius:999px;display:grid;place-items:center;
  background:var(--burgundy-700);color:var(--cream-50);
}
.nav-toggle{display:none;width:42px;height:42px;align-items:center;justify-content:center;border-radius:8px}
.nav-toggle span{display:block;width:22px;height:1.5px;background:var(--ink-900);position:relative}
.nav-toggle span::before,.nav-toggle span::after{content:"";position:absolute;left:0;width:22px;height:1.5px;background:var(--ink-900)}
.nav-toggle span::before{top:-7px}.nav-toggle span::after{top:7px}

/* ---------- Hero ---------- */
.hero{position:relative;padding:clamp(40px,6vw,80px) 0 clamp(60px,8vw,120px);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);align-items:center}
.hero-eyebrow{font-family:var(--font-display);font-style:italic;font-size:18px;letter-spacing:.34em;text-transform:uppercase;color:var(--burgundy-700)}
.hero h1{
  font-family:var(--font-serif);font-weight:500;
  font-size:clamp(40px,5.6vw,76px);line-height:1.15;letter-spacing:.04em;
  margin:24px 0 20px;color:var(--burgundy-900)
}
.hero h1 em{font-family:var(--font-display);font-style:italic;font-weight:400;color:var(--burgundy-700)}
.hero-sub{font-size:18px;line-height:1.9;color:var(--ink-700);max-width:540px}
.hero-meta{display:flex;gap:32px;margin-top:36px;flex-wrap:wrap}
.hero-meta>div{border-left:1px solid var(--line);padding-left:16px}
.hero-meta .k{font-family:var(--font-display);font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}
.hero-meta .v{font-family:var(--font-serif);font-size:22px;color:var(--burgundy-700)}
.hero-actions{display:flex;gap:14px;margin-top:40px;flex-wrap:wrap}
.hero-art{position:relative}
.hero-art .frame{
  position:relative;aspect-ratio:4/5;border-radius:6px;overflow:hidden;
  background:var(--taupe-300);
}
.hero-art .frame img{width:100%;height:100%;object-fit:cover}
.hero-art .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(60,15,30,.18))}
.hero-art .tag{
  position:absolute;left:-24px;bottom:36px;
  background:var(--cream-50);padding:18px 24px;border-radius:4px;
  font-family:var(--font-serif);letter-spacing:.2em;color:var(--burgundy-900);
  box-shadow:0 20px 40px -18px rgba(60,26,31,.25);
}
.hero-art .tag .big{font-size:30px;font-weight:500}
.hero-art .tag .small{font-family:var(--font-display);font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--burgundy-700);margin-top:4px}
.hero-art .badge{
  position:absolute;top:24px;right:-12px;
  width:108px;height:108px;border-radius:50%;
  background:var(--burgundy-700);color:var(--cream-50);
  display:grid;place-items:center;text-align:center;
  font-family:var(--font-display);font-style:italic;letter-spacing:.16em;
  font-size:13px;line-height:1.4;
  box-shadow:0 18px 36px -14px rgba(60,15,30,.45);
  animation:rotateSlow 24s linear infinite;
}
@keyframes rotateSlow{from{transform:rotate(0)}to{transform:rotate(360deg)}}

/* ---------- Sections (re-usable) ---------- */
.section-head{display:grid;grid-template-columns:1fr 1.4fr;gap:48px;align-items:end;margin-bottom:64px}
.section-head h2{font-size:clamp(32px,4vw,52px);color:var(--burgundy-900)}
.section-head .h-side{color:var(--ink-700);font-size:16px;line-height:1.85;max-width:560px}

@media (max-width:880px){.section-head{grid-template-columns:1fr;gap:20px}}

/* ---------- Five Elements ---------- */
.elements{background:var(--cream-50)}
.element-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.el-card{
  position:relative;aspect-ratio:.74;
  border-radius:6px;overflow:hidden;padding:24px;
  display:flex;flex-direction:column;justify-content:space-between;
  color:#fff;transition:transform .4s ease;
  background-size:cover;background-position:center;
}
.el-card::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05) 0%,rgba(0,0,0,.55) 100%)}
.el-card>*{position:relative;z-index:1}
.el-card:hover{transform:translateY(-6px)}
.el-card .glyph{font-family:var(--font-serif);font-size:64px;line-height:1;letter-spacing:0;font-weight:400}
.el-card .en{font-family:var(--font-display);font-style:italic;font-size:14px;letter-spacing:.32em;text-transform:uppercase;opacity:.85;margin-top:8px}
.el-card .body{font-size:13px;line-height:1.7;opacity:.9}
.el-card .colors{display:flex;gap:6px;margin-top:12px}
.el-card .colors span{width:14px;height:14px;border-radius:50%;border:1px solid rgba(255,255,255,.4)}

.el-mu  {background-color:#2F4D3A; background-image:linear-gradient(180deg,rgba(47,77,58,.5),rgba(20,40,28,.95))}
.el-huo {background-color:#7E1D2A; background-image:linear-gradient(180deg,rgba(126,29,42,.4),rgba(60,12,18,.95))}
.el-tu  {background-color:#9A7547; background-image:linear-gradient(180deg,rgba(154,117,71,.35),rgba(72,52,28,.95))}
.el-jin {background-color:#C9C0B0; color:var(--ink-900); background-image:linear-gradient(180deg,rgba(201,192,176,.2),rgba(170,158,140,.85))}
.el-jin::before{background:linear-gradient(180deg,rgba(0,0,0,.0),rgba(60,26,31,.18))}
.el-shui{background-color:#1F2540; background-image:linear-gradient(180deg,rgba(31,37,64,.4),rgba(12,16,32,.95))}

@media (max-width:780px){.element-grid{grid-template-columns:repeat(2,1fr)}}

/* ---------- Quote / Pull ---------- */
.pull{
  padding:clamp(64px,9vw,120px) 0;
  background:var(--burgundy-900);color:var(--cream-100);
  position:relative;overflow:hidden;
}
.pull::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 20% 20%,rgba(201,168,122,.12),transparent 40%),radial-gradient(circle at 80% 80%,rgba(201,168,122,.08),transparent 50%)}
.pull-inner{position:relative;display:grid;grid-template-columns:1.2fr .8fr;gap:64px;align-items:center}
.pull blockquote{margin:0;font-family:var(--font-serif);font-size:clamp(28px,3.6vw,44px);line-height:1.45;font-weight:400;letter-spacing:.04em;color:#fff}
.pull blockquote em{font-family:var(--font-display);font-style:italic;color:var(--gold-300)}
.pull cite{display:block;margin-top:32px;font-style:normal;font-family:var(--font-display);letter-spacing:.3em;font-size:13px;color:var(--gold-300);text-transform:uppercase}
.pull-portrait{aspect-ratio:3/4;border-radius:6px;overflow:hidden;background:var(--taupe-300)}
.pull-portrait img{width:100%;height:100%;object-fit:cover;filter:saturate(.9) contrast(1.02)}
@media (max-width:880px){.pull-inner{grid-template-columns:1fr}}

/* ---------- Course Card ---------- */
.course-card{
  display:grid;grid-template-columns:.9fr 1.1fr;gap:0;
  background:var(--surface);border-radius:6px;overflow:hidden;
  box-shadow:0 30px 60px -36px rgba(60,26,31,.3);
}
.course-card .img{aspect-ratio:4/5;background:var(--taupe-300);background-size:cover;background-position:center}
.course-card .body{padding:clamp(28px,4vw,56px);display:flex;flex-direction:column;justify-content:center}
.course-card h3{font-size:clamp(28px,3.4vw,42px);color:var(--burgundy-900);margin-bottom:18px}
.course-card .lead{font-size:16px;line-height:1.85;color:var(--ink-700)}
.course-card .stats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:28px 0;padding:20px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.course-card .stats .k{font-family:var(--font-display);font-style:italic;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--text-muted)}
.course-card .stats .v{font-family:var(--font-serif);font-size:18px;color:var(--burgundy-700);margin-top:2px}
@media (max-width:780px){.course-card{grid-template-columns:1fr}.course-card .img{aspect-ratio:16/10}}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.step{padding:36px 32px;background:var(--surface);border-radius:6px;border:1px solid var(--line);position:relative}
.step .num{font-family:var(--font-display);font-style:italic;font-size:64px;line-height:1;color:var(--gold-500);letter-spacing:.02em}
.step h3{font-size:22px;margin:16px 0 12px;color:var(--burgundy-900)}
.step p{font-size:15px;line-height:1.8;color:var(--ink-700)}
@media (max-width:880px){.steps{grid-template-columns:1fr}}

/* ---------- News / Blog cards ---------- */
.news-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.nc{display:block;background:var(--surface);border-radius:6px;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}
.nc:hover{transform:translateY(-4px);box-shadow:0 24px 48px -28px rgba(60,26,31,.3)}
.nc-img{aspect-ratio:4/3;background:var(--taupe-300);background-size:cover;background-position:center}
.nc-body{padding:22px}
.nc-cat{font-family:var(--font-display);font-style:italic;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--burgundy-700)}
.nc h3{font-size:18px;line-height:1.5;margin:10px 0 12px;color:var(--ink-900)}
.nc p{font-size:14px;color:var(--text-muted);line-height:1.7;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.nc-date{margin-top:14px;padding-top:14px;border-top:1px solid var(--line);font-size:12px;color:var(--text-muted);letter-spacing:.12em}
@media (max-width:980px){.news-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.news-grid{grid-template-columns:1fr}}

/* ---------- Footer ---------- */
.site-footer{background:var(--burgundy-900);color:var(--cream-100);padding:80px 0 36px;position:relative;overflow:hidden}
.site-footer::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 0%,rgba(201,168,122,.08),transparent 50%)}
.footer-grid{position:relative;display:grid;grid-template-columns:1.4fr .8fr .8fr 1fr;gap:48px;margin-bottom:56px}
.footer-brand .lg{display:flex;align-items:center;gap:16px;margin-bottom:20px}
.footer-brand .lg img{width:64px;height:64px;filter:brightness(0) invert(1) brightness(.95)}
.footer-brand .lg .zh{font-family:var(--font-serif);font-size:17px;letter-spacing:.22em}
.footer-brand p{font-size:14px;line-height:1.85;opacity:.7;max-width:340px}
.footer-col h4{font-family:var(--font-display);font-style:italic;font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-300);margin-bottom:22px;font-weight:500}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}
.footer-col a{font-size:14px;opacity:.78}
.footer-col a:hover{opacity:1;color:var(--gold-300)}
.footer-social{display:flex;gap:10px;margin-top:18px}
.footer-social a{width:38px;height:38px;border-radius:999px;border:1px solid rgba(255,255,255,.2);display:grid;place-items:center;opacity:.8}
.footer-social a:hover{background:var(--gold-500);color:var(--burgundy-900);border-color:var(--gold-500);opacity:1}
.footer-bottom{position:relative;border-top:1px solid rgba(255,255,255,.12);padding-top:24px;display:flex;justify-content:space-between;align-items:center;font-size:12px;letter-spacing:.12em;opacity:.6;flex-wrap:wrap;gap:12px}

@media (max-width:880px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr}}

/* ---------- Floating LINE button ---------- */
.line-float{
  position:fixed;right:24px;bottom:24px;z-index:60;
  width:60px;height:60px;border-radius:999px;
  background:#06C755;color:#fff;display:grid;place-items:center;
  box-shadow:0 16px 32px -10px rgba(6,199,85,.5),0 0 0 6px rgba(6,199,85,.12);
  transition:transform .3s ease;
}
.line-float:hover{transform:scale(1.06) translateY(-2px);color:#fff}
.line-float svg{width:30px;height:30px}

/* ---------- Page banner (inner pages) ---------- */
.page-banner{padding:clamp(80px,10vw,140px) 0 clamp(60px,7vw,100px);background:linear-gradient(180deg,var(--cream-50),var(--cream-100));position:relative;overflow:hidden}
.page-banner::after{content:"";position:absolute;right:-60px;bottom:-60px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,var(--taupe-200),transparent 70%);opacity:.6}
.banner-inner{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:center}
.banner-inner h1{font-size:clamp(40px,5.4vw,72px);color:var(--burgundy-900);margin:18px 0 22px}
.banner-inner h1 em{font-family:var(--font-display);font-style:italic;color:var(--burgundy-700)}
.banner-inner p{font-size:17px;line-height:1.9;color:var(--ink-700);max-width:520px}
.banner-art{aspect-ratio:4/5;border-radius:6px;overflow:hidden;background:var(--taupe-300);position:relative}
.banner-art img{width:100%;height:100%;object-fit:cover}
@media (max-width:880px){.banner-inner{grid-template-columns:1fr}.banner-art{aspect-ratio:4/3;order:-1}}

/* ---------- Breadcrumb ---------- */
.breadcrumb{font-family:var(--font-display);font-style:italic;font-size:13px;letter-spacing:.2em;color:var(--text-muted);text-transform:uppercase}
.breadcrumb a{color:var(--text-muted)}
.breadcrumb a:hover{color:var(--burgundy-700)}
.breadcrumb .sep{margin:0 10px;opacity:.5}

/* ---------- Two-column editorial ---------- */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:center}
.two-col.flip>:first-child{order:2}
.two-col .col-img{aspect-ratio:4/5;border-radius:6px;overflow:hidden;background:var(--taupe-300)}
.two-col .col-img img{width:100%;height:100%;object-fit:cover}
.two-col h2{font-size:clamp(30px,4vw,48px);color:var(--burgundy-900);margin:16px 0 22px}
.two-col p{font-size:16px;line-height:1.9;color:var(--ink-700)}
.two-col p+p{margin-top:14px}
@media (max-width:880px){.two-col{grid-template-columns:1fr}.two-col.flip>:first-child{order:0}}

/* ---------- Bento grid ---------- */
.bento{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;grid-auto-rows:120px}
.bento .b{border-radius:8px;overflow:hidden;background:var(--surface);position:relative;display:flex;align-items:flex-end;padding:22px;color:#fff}
.bento .b::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.55))}
.bento .b>*{position:relative;z-index:1}
.bento .b img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.bento h4{font-family:var(--font-serif);font-size:18px;font-weight:500}
.bento small{display:block;font-family:var(--font-display);font-style:italic;font-size:11px;letter-spacing:.28em;text-transform:uppercase;opacity:.85;margin-bottom:6px}

/* ---------- Mobile nav ---------- */
@media (max-width:980px){
  .nav-list,.nav-cta .btn{display:none}
  .nav-toggle{display:inline-flex}
}
.mobile-menu{
  position:fixed;inset:0;background:var(--cream-50);z-index:100;
  padding:90px var(--gutter) 32px;
  display:flex;flex-direction:column;gap:6px;
  transform:translateY(-100%);transition:transform .35s ease;
  overflow-y:auto;
}
.mobile-menu.open{transform:translateY(0)}
.mobile-menu a{
  display:block;padding:18px 0;font-family:var(--font-serif);
  font-size:24px;letter-spacing:.06em;color:var(--ink-900);
  border-bottom:1px solid var(--line);
}
.mobile-menu a small{display:block;font-family:var(--font-sans);font-size:11px;letter-spacing:.28em;color:var(--text-muted);text-transform:uppercase;margin-top:4px}
.mobile-menu .close{position:absolute;top:22px;right:var(--gutter);font-size:24px;color:var(--ink-900);width:42px;height:42px;display:grid;place-items:center}
.mobile-menu .cta-stack{margin-top:30px;display:flex;flex-direction:column;gap:12px}
.mobile-menu .mm-secondary{margin-top:24px;display:flex;gap:20px;flex-wrap:wrap;padding-top:16px;border-top:1px dashed var(--line)}
.mobile-menu .mm-secondary a{padding:8px 0;font-family:var(--font-sans);font-size:14px;letter-spacing:.14em;border:0;color:var(--text-muted)}
.mobile-menu .mm-secondary a:hover{color:var(--burgundy-700)}

/* ---------- Hero mobile ---------- */
@media (max-width:880px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-art .badge{width:88px;height:88px;font-size:11px;right:-4px;top:14px}
  .hero-art .tag{left:0;bottom:18px;padding:14px 18px}
}

/* ---------- Tag chips ---------- */
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:999px;background:var(--cream-200);border:1px solid var(--line);color:var(--burgundy-800);font-size:13px;letter-spacing:.08em;cursor:pointer;transition:all .2s ease}
.chip:hover,.chip.active{background:var(--burgundy-700);color:var(--cream-50);border-color:var(--burgundy-700)}

/* ---------- Numbered list ---------- */
.numbered-list{list-style:none;padding:0;margin:0;counter-reset:n}
.numbered-list li{
  counter-increment:n;display:grid;grid-template-columns:48px 1fr;gap:24px;
  padding:28px 0;border-bottom:1px solid var(--line);align-items:start;
}
.numbered-list li::before{
  content:counter(n,decimal-leading-zero);
  font-family:var(--font-display);font-style:italic;font-size:22px;color:var(--gold-700);
  letter-spacing:.05em;line-height:1.6;
}
.numbered-list h4{font-size:20px;color:var(--burgundy-900);margin-bottom:8px;font-weight:500}
.numbered-list p{font-size:15px;color:var(--ink-700);line-height:1.8}

/* ---------- Accordion (QA / FAQ) ---------- */
.qa-list{display:flex;flex-direction:column;gap:0}
.qa-item{border-bottom:1px solid var(--line);padding:24px 0}
.qa-q{
  display:flex;justify-content:space-between;align-items:flex-start;gap:24px;
  cursor:pointer;padding:0;width:100%;text-align:left;
}
.qa-q .q-text{font-family:var(--font-serif);font-size:20px;color:var(--burgundy-900);line-height:1.5;font-weight:500;letter-spacing:.02em;flex:1}
.qa-q .q-num{font-family:var(--font-display);font-style:italic;font-size:14px;color:var(--gold-700);letter-spacing:.2em;margin-top:6px}
.qa-q .q-toggle{width:32px;height:32px;border-radius:999px;border:1px solid var(--line);display:grid;place-items:center;flex-shrink:0;transition:all .25s ease}
.qa-q .q-toggle::before,.qa-q .q-toggle::after{content:"";width:12px;height:1px;background:var(--ink-900);position:absolute}
.qa-q .q-toggle::after{transform:rotate(90deg);transition:transform .25s ease}
.qa-item.open .q-toggle{background:var(--burgundy-700);border-color:var(--burgundy-700)}
.qa-item.open .q-toggle::before,.qa-item.open .q-toggle::after{background:#fff}
.qa-item.open .q-toggle::after{transform:rotate(0)}
.qa-a{max-height:0;overflow:hidden;transition:max-height .35s ease;color:var(--ink-700);font-size:15px;line-height:1.9}
.qa-a-inner{padding:18px 56px 6px 0}
.qa-item.open .qa-a{max-height:600px}

/* ---------- Form ---------- */
.form{display:grid;gap:18px}
.form label{display:flex;flex-direction:column;gap:8px;font-size:13px;letter-spacing:.16em;color:var(--text-muted);text-transform:uppercase;font-family:var(--font-display);font-style:italic}
.form input,.form textarea,.form select{
  font-family:var(--font-sans);font-size:15px;
  padding:14px 18px;border:1px solid var(--line);background:var(--surface);
  border-radius:4px;color:var(--text);transition:border-color .2s ease;
}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--burgundy-700)}
.form textarea{min-height:140px;resize:vertical}

/* ---------- Tiny utilities ---------- */
.glyph-divider{display:flex;align-items:center;justify-content:center;gap:18px;margin:24px 0;color:var(--burgundy-700)}
.glyph-divider::before,.glyph-divider::after{content:"";flex:1;max-width:80px;height:1px;background:currentColor;opacity:.4}
.glyph-divider .g{font-family:var(--font-serif);letter-spacing:.6em;font-size:13px}

/* ---------- Responsive type ---------- */
@media (max-width:560px){
  .section-head{margin-bottom:40px}
  .hero-meta{gap:20px}
  .hero-meta>div{padding-left:14px}
  .course-card .stats{grid-template-columns:1fr}
}
