/* ====================================================
   Roblox เด็กเทพสอบเข้า ม.1 — Kawaii Pastel Blue + Gold
   ==================================================== */
:root{
  --bg:#EAF2FB; --bg-mist:#F4F8FE; --paper:#FFFFFF; --cream:#FFFBF0;
  --ink:#1F3654; --ink-soft:#5C7595; --ink-faint:#8FA1BA;
  --gold:#C9A66B; --gold-deep:#9C7E48; --gold-bright:#E8C875;
  --gold-soft:#F5E8C8; --gold-paper:#FAF1DB;
  --blue:#7BA7E1; --blue-deep:#3D6FB0; --blue-soft:#C9DEF5; --blue-mist:#E6EFFB;
  --pink:#E4B0C3; --pink-soft:#F5DCE5;
  --mint:#9FCCC5; --mint-soft:#D7EDE9;
  --peach:#F5C9A8; --peach-soft:#FBE8D7;
  --shadow-sm:0 2px 8px rgba(80,110,160,.06);
  --shadow:0 6px 20px rgba(80,110,160,.08), 0 16px 40px -14px rgba(80,110,160,.16);
  --shadow-gold:0 0 0 1px rgba(201,166,107,.35), 0 8px 24px -8px rgba(201,166,107,.30);
  --radius:22px; --radius-sm:14px; --radius-pill:999px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{height:100%}
body{
  font-family:'Sarabun', system-ui, -apple-system, sans-serif;
  background:var(--bg); color:var(--ink);
  font-size:16px; line-height:1.65;
  -webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(ellipse 600px 380px at 8% -4%, #E0D2A8 0%, transparent 55%),
    radial-gradient(ellipse 700px 460px at 95% 6%, #C9DEF5 0%, transparent 55%),
    radial-gradient(ellipse 540px 420px at 92% 96%, #F5E8C8 0%, transparent 60%),
    radial-gradient(ellipse 540px 380px at 4% 90%, #D7E5F8 0%, transparent 60%);
  background-attachment:fixed;
}
img{display:block;max-width:100%;height:auto}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
a{color:var(--blue-deep);text-decoration:none;transition:color .15s}
a:hover{color:var(--gold-deep)}
.container{max-width:1200px;margin:0 auto;padding:0 26px}
@media (max-width:680px){.container{padding:0 16px}}

/* Sparkles bg */
.bg-deco{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.bg-deco svg{position:absolute;opacity:.55;animation:twinkle 3.6s ease-in-out infinite}
.bg-deco .s1{top:14%;left:6%;width:14px;height:14px}
.bg-deco .s2{top:8%;right:10%;width:22px;height:22px;animation-delay:.6s}
.bg-deco .s3{top:42%;left:3%;width:16px;height:16px;animation-delay:1.4s}
.bg-deco .s4{top:58%;right:4%;width:18px;height:18px;animation-delay:2s}
.bg-deco .s5{bottom:18%;left:14%;width:20px;height:20px;animation-delay:1s}
.bg-deco .s6{bottom:8%;right:18%;width:14px;height:14px;animation-delay:2.6s}
@keyframes twinkle{0%,100%{opacity:.25;transform:scale(.85) rotate(0deg)}50%{opacity:.85;transform:scale(1.1) rotate(20deg)}}
@keyframes float-cloud{0%,100%{transform:translateY(0) translateX(0)}50%{transform:translateY(-6px) translateX(4px)}}
@keyframes heartbeat{0%,100%{transform:scale(1)}20%{transform:scale(1.15)}40%{transform:scale(.95)}60%{transform:scale(1.08)}}
@keyframes pop{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ============ HEADER ============ */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(234,242,251,.82);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(201,166,107,.22);
}
.header-inner{
  display:flex;align-items:center;gap:18px;
  padding:14px 0;
}
.brand{display:flex;align-items:center;gap:13px;text-decoration:none;color:var(--ink)}
.brand:hover{color:var(--ink)}
.brand-mark{
  position:relative;width:50px;height:50px;
  background:linear-gradient(155deg,#FFFFFF 0%, #F4F8FE 60%, #E6EFFB 100%);
  border-radius:18px;border:1.5px solid var(--gold);
  display:grid;place-items:center;
  box-shadow:0 4px 12px -4px rgba(125,160,210,.4);
  overflow:hidden;flex-shrink:0;
}
.brand-mark::after{
  content:"";position:absolute;top:-4px;right:-4px;
  width:14px;height:14px;background:var(--gold-bright);
  clip-path:polygon(50% 0%, 60% 40%, 100% 50%, 60% 60%, 50% 100%, 40% 60%, 0% 50%, 40% 40%);
  z-index:2;
}
.brand-mark img{width:100%;height:100%;object-fit:cover}
.brand-mark .fb-text{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:'Press Start 2P',monospace;font-size:.65rem;
  color:var(--blue-deep);background:var(--blue-mist);letter-spacing:-.5px;
}
.brand-text{
  font-family:'Mali',sans-serif;font-weight:600;
  font-size:1.05rem;color:var(--ink);line-height:1.1;
}
.brand-text .game-tag{
  display:inline-block;
  font-family:'Press Start 2P',monospace;font-size:.55rem;
  color:var(--paper);background:var(--blue-deep);
  padding:3px 6px;border-radius:5px;
  margin-right:6px;letter-spacing:0;vertical-align:1px;
  border:1px solid var(--gold-bright);
}
.brand-text small{
  display:block;
  font-family:'Fraunces',serif;font-style:italic;font-weight:400;
  font-size:.7rem;color:var(--gold-deep);
  letter-spacing:1.3px;margin-top:5px;text-transform:uppercase;
}
.nav{display:flex;gap:6px;margin-left:auto;align-items:center}
.nav a{
  font-family:'Mali',sans-serif;font-size:.92rem;font-weight:500;
  color:var(--ink-soft);
  padding:8px 14px;border-radius:var(--radius-pill);
  transition:all .15s;
}
.nav a:hover{background:var(--gold-paper);color:var(--gold-deep)}
.btn-cta{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 20px;
  background:linear-gradient(135deg, var(--gold), var(--gold-bright));
  color:#fff!important;
  font-family:'Mali',sans-serif;font-weight:600;font-size:.92rem;
  border-radius:var(--radius-pill);
  border:1.5px solid var(--gold-deep);
  box-shadow:0 4px 14px -4px rgba(156,126,72,.5);
  transition:all .18s;
}
.btn-cta:hover{transform:translateY(-2px);box-shadow:0 8px 20px -4px rgba(156,126,72,.6);color:#fff}
.btn-cta::before{
  content:"";width:8px;height:8px;background:#fff;
  clip-path:polygon(50% 0%, 60% 40%, 100% 50%, 60% 60%, 50% 100%, 40% 60%, 0% 50%, 40% 40%);
}
.menu-toggle{display:none;font-size:1.4rem;color:var(--blue-deep);padding:8px}
@media (max-width:880px){
  .nav{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;
    background:var(--paper);padding:14px 22px;border-bottom:1px solid var(--blue-soft);gap:4px}
  .nav.open{display:flex}
  .nav a{padding:10px 14px}
  .btn-cta{padding:9px 16px;font-size:.85rem}
  .menu-toggle{display:inline-flex;margin-left:auto;background:var(--blue-mist);border-radius:50%;width:40px;height:40px;align-items:center;justify-content:center}
}

/* ============ HERO ============ */
.hero{padding:60px 0 40px;position:relative;z-index:1}
.hero-clouds{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.hero-clouds svg{position:absolute;animation:float-cloud 8s ease-in-out infinite}
.hero-clouds .c1{top:8%;right:6%;width:130px;opacity:.55}
.hero-clouds .c2{top:38%;right:22%;width:80px;opacity:.7;animation-delay:1.5s}
.hero-clouds .c3{top:18%;right:38%;width:60px;opacity:.45;animation-delay:3s}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Mali',sans-serif;font-weight:500;
  font-size:.85rem;letter-spacing:.5px;color:var(--gold-deep);
  padding:6px 16px;background:var(--gold-paper);
  border:1px solid var(--gold);border-radius:var(--radius-pill);
  margin-bottom:22px;
}
.eyebrow::before, .eyebrow::after{
  content:"";width:8px;height:8px;background:var(--gold);
  clip-path:polygon(50% 0%, 60% 40%, 100% 50%, 60% 60%, 50% 100%, 40% 60%, 0% 50%, 40% 40%);
}
.hero h1{
  font-family:'Mali',sans-serif;font-weight:600;
  font-size:clamp(2rem,4.8vw,3.2rem);line-height:1.18;
  letter-spacing:-.3px;max-width:880px;color:var(--ink);
}
.hero h1 .accent{
  position:relative;display:inline-block;
  font-family:'Fraunces',serif;font-style:italic;font-weight:500;
  color:var(--gold-deep);
}
.hero h1 .accent::after{
  content:"";position:absolute;left:0;right:0;bottom:.05em;
  height:.4em;background:var(--gold-soft);z-index:-1;border-radius:6px;
}
.hero h1 .heart{
  display:inline-block;color:var(--pink);font-size:.75em;
  vertical-align:middle;animation:heartbeat 1.6s ease-in-out infinite;
}
.hero-sub{
  margin-top:18px;color:var(--ink-soft);
  max-width:680px;font-size:1.05rem;line-height:1.75;
}
.hero-sub strong{color:var(--gold-deep);font-weight:600}
.hero-buttons{margin-top:30px;display:flex;flex-wrap:wrap;gap:12px}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 26px;border-radius:var(--radius-pill);
  font-family:'Mali',sans-serif;font-weight:600;font-size:1rem;
  transition:all .18s;border:1.5px solid transparent;cursor:pointer;
}
.btn-primary{
  background:linear-gradient(135deg, var(--gold), var(--gold-bright));
  color:#fff!important;border-color:var(--gold-deep);
  box-shadow:0 6px 18px -4px rgba(156,126,72,.5);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 24px -4px rgba(156,126,72,.6);color:#fff}
.btn-secondary{
  background:var(--paper);color:var(--blue-deep)!important;
  border-color:var(--blue-soft);
}
.btn-secondary:hover{border-color:var(--gold);background:var(--gold-paper);color:var(--gold-deep)!important;transform:translateY(-2px)}
.btn::before{
  content:"";width:9px;height:9px;background:currentColor;opacity:.85;
  clip-path:polygon(50% 0%, 60% 40%, 100% 50%, 60% 60%, 50% 100%, 40% 60%, 0% 50%, 40% 40%);
}
.hero-stats{
  margin-top:36px;display:grid;
  grid-template-columns:repeat(auto-fit, minmax(140px, 1fr));
  gap:14px;max-width:760px;
}
.stat{
  background:var(--paper);border:1.5px solid var(--blue-soft);
  border-radius:var(--radius-sm);padding:16px 18px;position:relative;
}
.stat::before{
  content:"";position:absolute;top:-6px;right:14px;
  width:14px;height:14px;background:var(--gold-bright);
  clip-path:polygon(50% 0%, 60% 40%, 100% 50%, 60% 60%, 50% 100%, 40% 60%, 0% 50%, 40% 40%);
}
.stat-num{display:block;font-family:'Mali',sans-serif;font-weight:600;
  font-size:1.85rem;color:var(--blue-deep);line-height:1;
  font-variant-numeric:tabular-nums}
.stat-lbl{display:block;margin-top:6px;font-size:.82rem;color:var(--ink-soft)}

/* ============ SECTIONS ============ */
.section{padding:64px 0;position:relative;z-index:1}
.section-head{text-align:center;margin-bottom:40px}
.section-eyebrow{
  display:inline-block;font-family:'Mali',sans-serif;
  font-size:.82rem;letter-spacing:1.5px;color:var(--gold-deep);
  text-transform:uppercase;margin-bottom:8px;font-weight:500;
}
.section h2{
  font-family:'Mali',sans-serif;font-weight:600;
  font-size:clamp(1.6rem,3.2vw,2.2rem);line-height:1.25;color:var(--ink);
  max-width:780px;margin:0 auto;
}
.section h2 .accent{
  font-family:'Fraunces',serif;font-style:italic;color:var(--gold-deep);font-weight:500;
}
.section-lead{max-width:640px;margin:14px auto 0;color:var(--ink-soft);font-size:1.02rem}

/* ============ FEATURE CARDS ============ */
.features{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:18px;
}
.feature{
  background:var(--paper);
  border:1.5px solid var(--blue-soft);
  border-radius:var(--radius);
  padding:24px 22px;position:relative;
  transition:all .22s ease;
  animation:pop .4s ease both;
}
.feature::before{
  content:"";position:absolute;top:14px;right:14px;
  width:14px;height:14px;background:var(--gold-bright);
  clip-path:polygon(50% 0%, 60% 40%, 100% 50%, 60% 60%, 50% 100%, 40% 60%, 0% 50%, 40% 40%);
  opacity:.7;
}
.feature:hover{transform:translateY(-4px);border-color:var(--gold);box-shadow:var(--shadow-gold)}
.feature-icon{
  width:54px;height:54px;border-radius:18px;
  background:var(--blue-mist);color:var(--blue-deep);
  display:grid;place-items:center;margin-bottom:14px;
  border:1.5px solid var(--gold);
}
.feature-icon svg{width:28px;height:28px}
.feature:nth-child(2) .feature-icon{background:var(--gold-paper);color:var(--gold-deep)}
.feature:nth-child(3) .feature-icon{background:var(--mint-soft);color:#3F8B82}
.feature:nth-child(4) .feature-icon{background:var(--pink-soft);color:#9C5C82}
.feature h3{
  font-family:'Mali',sans-serif;font-weight:600;
  font-size:1.1rem;color:var(--ink);margin-bottom:8px;
}
.feature p{font-size:.94rem;color:var(--ink-soft);line-height:1.65}

/* ============ SUBJECTS ============ */
.subjects{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
  gap:18px;
}
.subject-card{
  background:var(--paper);
  border:1.5px solid var(--blue-soft);
  border-radius:var(--radius);
  padding:24px;display:flex;gap:16px;align-items:flex-start;
  transition:all .22s ease;animation:pop .4s ease both;
}
.subject-card:hover{transform:translateY(-3px);border-color:var(--gold);box-shadow:var(--shadow)}
.subject-card-icon{
  width:50px;height:50px;border-radius:14px;flex-shrink:0;
  display:grid;place-items:center;border:1.5px solid var(--gold);
}
.subject-card-icon svg{width:26px;height:26px}
.subject-card[data-c="b"] .subject-card-icon{background:var(--blue-mist);color:var(--blue-deep)}
.subject-card[data-c="g"] .subject-card-icon{background:var(--mint-soft);color:#3F8B82}
.subject-card[data-c="p"] .subject-card-icon{background:var(--pink-soft);color:#9C5C82}
.subject-card[data-c="o"] .subject-card-icon{background:var(--peach-soft);color:#B86E3D}
.subject-card[data-c="y"] .subject-card-icon{background:var(--gold-paper);color:var(--gold-deep)}
.subject-card[data-c="v"] .subject-card-icon{background:#EDE5F5;color:#7659A8}
.subject-card h3{
  font-family:'Mali',sans-serif;font-weight:600;
  font-size:1.15rem;color:var(--ink);margin-bottom:6px;
}
.subject-card p{font-size:.92rem;color:var(--ink-soft);line-height:1.6}

/* ============ IMAGE GRID ============ */
.image-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
  gap:14px;
}
.image-grid a{
  display:block;border-radius:var(--radius-sm);overflow:hidden;
  border:1.5px solid var(--blue-soft);background:var(--paper);
  transition:all .22s ease;position:relative;
}
.image-grid a::before{
  content:"";position:absolute;top:8px;right:8px;
  width:14px;height:14px;background:var(--gold-bright);
  clip-path:polygon(50% 0%, 60% 40%, 100% 50%, 60% 60%, 50% 100%, 40% 60%, 0% 50%, 40% 40%);
  z-index:2;opacity:0;transform:scale(.5);
  transition:all .3s;
}
.image-grid a:hover{border-color:var(--gold);transform:translateY(-3px);box-shadow:var(--shadow-gold)}
.image-grid a:hover::before{opacity:1;transform:scale(1)}
.image-grid img{
  width:100%;aspect-ratio:1/1;object-fit:cover;display:block;
  transition:transform .35s ease;background:var(--bg-mist);
}
.image-grid a:hover img{transform:scale(1.05)}

/* ============ SCHOOLS GRID ============ */
.schools-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:14px;
}
.school-card{
  background:var(--paper);
  border:1.5px solid var(--blue-soft);
  border-radius:var(--radius-sm);
  padding:18px 20px;
  display:flex;align-items:center;gap:14px;
  transition:all .2s ease;color:var(--ink);
  position:relative;
}
.school-card:hover{
  border-color:var(--gold);transform:translateY(-2px);
  box-shadow:var(--shadow-gold);color:var(--ink);
}
.school-card-num{
  width:38px;height:38px;border-radius:50%;flex-shrink:0;
  display:grid;place-items:center;
  background:var(--gold-paper);color:var(--gold-deep);
  font-family:'Fraunces',serif;font-style:italic;font-weight:500;
  font-size:1.05rem;border:1.5px solid var(--gold);
}
.school-card-body{flex:1;min-width:0}
.school-card-name{
  font-family:'Mali',sans-serif;font-weight:500;font-size:.98rem;
  color:var(--ink);line-height:1.3;
}
.school-card-region{
  font-size:.78rem;color:var(--ink-soft);margin-top:3px;
  display:flex;align-items:center;gap:5px;
}
.school-card-region::before{
  content:"";width:5px;height:5px;border-radius:50%;background:var(--gold);
}
.school-card-arrow{color:var(--gold-deep);font-size:1.1rem;flex-shrink:0;transition:transform .2s}
.school-card:hover .school-card-arrow{transform:translateX(4px)}

/* ============ REVIEWS ============ */
.reviews-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
  gap:14px;
}
.reviews-grid a{
  display:block;border-radius:var(--radius-sm);overflow:hidden;
  border:1.5px solid var(--blue-soft);background:var(--paper);
  transition:all .22s ease;position:relative;
}
.reviews-grid a:hover{border-color:var(--gold);transform:translateY(-3px);box-shadow:var(--shadow-gold)}
.reviews-grid img{width:100%;display:block;background:var(--bg-mist)}
.review-tag{
  position:absolute;top:10px;left:10px;
  background:rgba(255,255,255,.92);
  color:var(--gold-deep);font-family:'Mali',sans-serif;font-weight:500;
  font-size:.72rem;padding:4px 10px;border-radius:var(--radius-pill);
  border:1px solid var(--gold);
  display:flex;align-items:center;gap:5px;
}
.review-tag::before{content:"";width:8px;height:8px;background:var(--gold-bright);
  clip-path:polygon(50% 0%, 60% 40%, 100% 50%, 60% 60%, 50% 100%, 40% 60%, 0% 50%, 40% 40%)}

/* ============ FAQ ============ */
.faq{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.faq details{
  background:var(--paper);
  border:1.5px solid var(--blue-soft);
  border-radius:var(--radius-sm);
  overflow:hidden;transition:border-color .2s;
}
.faq details[open]{border-color:var(--gold);box-shadow:var(--shadow-sm)}
.faq summary{
  padding:18px 22px;cursor:pointer;
  font-family:'Mali',sans-serif;font-weight:500;font-size:1rem;
  color:var(--ink);
  display:flex;align-items:center;gap:14px;
  list-style:none;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{
  content:"";width:14px;height:14px;background:var(--gold-bright);
  clip-path:polygon(50% 0%, 60% 40%, 100% 50%, 60% 60%, 50% 100%, 40% 60%, 0% 50%, 40% 40%);
  flex-shrink:0;transition:transform .2s;
}
.faq details[open] summary::before{transform:rotate(90deg)}
.faq summary::after{content:"+";margin-left:auto;font-size:1.4rem;color:var(--gold-deep);font-weight:500}
.faq details[open] summary::after{content:"−"}
.faq .answer{padding:0 22px 22px;color:var(--ink-soft);line-height:1.75}
.faq .answer a{color:var(--gold-deep);font-weight:500;border-bottom:1px dashed var(--gold)}

/* ============ CTA BANNER ============ */
.cta-banner{
  background:linear-gradient(135deg, var(--blue-mist) 0%, var(--gold-paper) 100%);
  border:1.5px solid var(--gold);
  border-radius:var(--radius);padding:36px;
  text-align:center;position:relative;overflow:hidden;
}
.cta-banner::before, .cta-banner::after{
  content:"";position:absolute;width:80px;height:80px;
  background:radial-gradient(circle, var(--gold-bright) 0%, transparent 70%);opacity:.4;
}
.cta-banner::before{top:-30px;left:-30px}
.cta-banner::after{bottom:-30px;right:-30px}
.cta-banner h3{
  font-family:'Mali',sans-serif;font-weight:600;font-size:1.5rem;
  color:var(--ink);margin-bottom:8px;position:relative;z-index:1;
}
.cta-banner p{color:var(--ink-soft);margin-bottom:20px;position:relative;z-index:1}
.cta-banner .btn{position:relative;z-index:1}

/* ============ BREADCRUMB ============ */
.breadcrumb{
  font-size:.85rem;color:var(--ink-soft);
  padding:18px 0;display:flex;align-items:center;gap:6px;flex-wrap:wrap;
}
.breadcrumb a{color:var(--ink-soft)}
.breadcrumb a:hover{color:var(--gold-deep)}
.breadcrumb span.sep{color:var(--gold);margin:0 4px}
.breadcrumb .current{color:var(--ink);font-weight:500}

/* ============ SCHOOL PAGE CONTENT ============ */
.school-intro{
  background:var(--paper);border:1.5px solid var(--blue-soft);
  border-radius:var(--radius);padding:28px 30px;
  display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:start;
}
@media (max-width:680px){.school-intro{grid-template-columns:1fr;padding:22px}}
.school-intro-icon{
  width:84px;height:84px;border-radius:24px;flex-shrink:0;
  background:linear-gradient(135deg,var(--blue-mist),var(--gold-paper));
  border:1.5px solid var(--gold);
  display:grid;place-items:center;
  font-family:'Fraunces',serif;font-style:italic;font-weight:500;
  font-size:2rem;color:var(--gold-deep);position:relative;
}
.school-intro-icon::after{
  content:"";position:absolute;top:-6px;right:-6px;
  width:18px;height:18px;background:var(--gold-bright);
  clip-path:polygon(50% 0%, 60% 40%, 100% 50%, 60% 60%, 50% 100%, 40% 60%, 0% 50%, 40% 40%);
}
.school-intro-body p{color:var(--ink-soft);line-height:1.75;font-size:1rem}
.school-intro-body p + p{margin-top:10px}

/* Subject details on school page */
.subject-detail{
  background:var(--paper);border:1.5px solid var(--blue-soft);
  border-radius:var(--radius);padding:24px 26px;margin-bottom:16px;
  position:relative;
}
.subject-detail::before{
  content:"";position:absolute;top:50%;left:-7px;transform:translateY(-50%);
  width:14px;height:14px;background:var(--gold-bright);
  border:1.5px solid var(--gold);border-radius:50%;
}
.subject-detail-head{
  display:flex;align-items:center;gap:14px;margin-bottom:16px;
}
.subject-detail-head .subject-card-icon{margin:0}
.subject-detail-head h3{
  font-family:'Mali',sans-serif;font-weight:600;font-size:1.25rem;color:var(--ink);
}
.subject-detail-head h3 small{
  display:block;font-family:'Fraunces',serif;font-style:italic;font-weight:400;
  font-size:.78rem;color:var(--gold-deep);letter-spacing:1px;text-transform:uppercase;margin-top:3px;
}
.topic-list{
  list-style:none;display:grid;gap:8px;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
}
.topic-list li{
  padding:10px 14px 10px 30px;background:var(--bg-mist);
  border-radius:var(--radius-sm);font-size:.94rem;color:var(--ink);
  position:relative;border:1px solid var(--blue-soft);
}
.topic-list li::before{
  content:"";position:absolute;left:11px;top:50%;transform:translateY(-50%);
  width:8px;height:8px;background:var(--gold-bright);
  clip-path:polygon(50% 0%, 60% 40%, 100% 50%, 60% 60%, 50% 100%, 40% 60%, 0% 50%, 40% 40%);
}

/* Tips list */
.tips-list{
  display:grid;gap:14px;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
}
.tip{
  background:var(--paper);border:1.5px solid var(--blue-soft);
  border-radius:var(--radius-sm);padding:18px 20px;display:flex;gap:14px;
}
.tip-num{
  width:32px;height:32px;border-radius:50%;flex-shrink:0;
  background:var(--gold);color:#fff;
  display:grid;place-items:center;
  font-family:'Mali',sans-serif;font-weight:600;font-size:.95rem;
}
.tip h4{font-family:'Mali',sans-serif;font-weight:600;font-size:1rem;color:var(--ink);margin-bottom:4px}
.tip p{font-size:.9rem;color:var(--ink-soft);line-height:1.6}

/* ============ FOOTER ============ */
.site-foot{
  margin-top:60px;padding:40px 0 28px;
  border-top:1px dashed var(--gold);
  position:relative;z-index:1;background:rgba(255,255,255,.4);
}
.foot-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:32px;
  margin-bottom:30px;
}
@media (max-width:680px){.foot-grid{grid-template-columns:1fr;gap:22px}}
.foot-brand{display:flex;align-items:flex-start;gap:14px}
.foot-brand-text p{font-size:.9rem;color:var(--ink-soft);margin-top:8px;line-height:1.7;max-width:340px}
.foot-col h4{font-family:'Mali',sans-serif;font-weight:600;font-size:1rem;color:var(--ink);margin-bottom:12px}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:7px}
.foot-col a{font-size:.9rem;color:var(--ink-soft);transition:color .15s}
.foot-col a:hover{color:var(--gold-deep)}
.foot-bar{
  border-top:1px solid var(--blue-soft);padding-top:18px;
  display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;
  font-size:.82rem;color:var(--ink-soft);
}
.foot-bar strong{color:var(--gold-deep);font-family:'Mali',sans-serif}

/* Topic intro section heading variant for small */
.topic-intro h2{font-size:1.4rem!important;text-align:left;margin:0}
