/* =========================================================
   EuroKidsGhorahi — stylesheet
   Design language: hand-cut paper collage, Dang valley skyline
   ========================================================= */

:root{
  --paper:      #FFF6E8;
  --paper-2:    #FFEFD6;
  --ink:        #232042;
  --ink-soft:   #4A4768;
  --marigold:   #FFB627;
  --marigold-d: #E89A0C;
  --sky:        #3AAFDD;
  --sky-d:      #2892C1;
  --coral:      #FF6F59;
  --leaf:       #4C9A6A;
  --card:       #FFFFFF;
  --line:       rgba(35,32,66,0.10);
  --shadow:     0 18px 40px -18px rgba(35,32,66,0.35);
  --radius-lg:  28px;
  --radius-md:  18px;
  --radius-sm:  10px;

  --font-display: "Baloo 2", "Segoe UI", sans-serif;
  --font-body:    "Nunito Sans", "Segoe UI", sans-serif;
  --font-mono:    "DM Mono", "Courier New", monospace;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4{ font-family:var(--font-display); margin:0; line-height:1.15; font-weight:700; }
p{ margin:0; }

.container{ width:min(1180px, 92%); margin-inline:auto; }

.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-mono); font-size:0.78rem; letter-spacing:.14em;
  text-transform:uppercase; color:var(--coral); font-weight:600;
  margin-bottom:10px;
}
.eyebrow::before{
  content:""; width:22px; height:2px; background:var(--coral); display:inline-block;
}

.section-head{ max-width:640px; margin-bottom:44px; }
.section-head.center{ margin-inline:auto; text-align:center; }
.section-head h2{ font-size:clamp(1.7rem, 3vw, 2.5rem); color:var(--ink); }
.section-head p{ margin-top:14px; color:var(--ink-soft); font-size:1.02rem; line-height:1.7; }

section{ padding:88px 0; position:relative; }
.bg-cream{ background:var(--paper); }
.bg-white{ background:var(--card); }
.bg-navy{ background:var(--ink); color:#fff; }
.bg-navy .ink-soft-alt{ color:#C6C3E0; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-display); font-weight:600; font-size:0.98rem;
  padding:14px 28px; border-radius:999px; border:2px solid transparent;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.btn-primary{ background:var(--coral); color:#fff; box-shadow:0 12px 24px -10px rgba(255,111,89,0.6); }
.btn-primary:hover{ transform:translateY(-3px); box-shadow:0 16px 30px -10px rgba(255,111,89,0.7); }
.btn-outline{ background:transparent; border-color:var(--ink); color:var(--ink); }
.btn-outline:hover{ background:var(--ink); color:#fff; transform:translateY(-3px); }
.btn-outline.on-dark{ border-color:#fff; color:#fff; }
.btn-outline.on-dark:hover{ background:#fff; color:var(--ink); }
.btn-sm{ padding:10px 20px; font-size:0.85rem; }

/* ---------- topbar ---------- */
.topbar{
  background:var(--ink); color:#EDEBFA; font-family:var(--font-mono); font-size:0.78rem;
  padding:9px 0;
}
.topbar .container{ display:flex; justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap; }
.topbar .topbar-items{ display:flex; gap:26px; flex-wrap:wrap; }
.topbar .topbar-items li{ display:flex; align-items:center; gap:7px; }
.topbar svg{ width:14px; height:14px; flex:none; }
.topbar .topbar-social{ display:flex; gap:14px; }
.topbar .topbar-social a{ width:26px; height:26px; border-radius:50%; border:1px solid rgba(255,255,255,0.25);
  display:flex; align-items:center; justify-content:center; transition:background .2s; }
.topbar .topbar-social a:hover{ background:var(--coral); border-color:var(--coral); }
.topbar .topbar-social svg{ width:13px; height:13px; }

/* ---------- header / nav ---------- */
.site-header{
  background:var(--paper); position:sticky; top:0; z-index:60;
  border-bottom:1px solid var(--line);
}
.site-header .container{ display:flex; align-items:center; justify-content:space-between; padding:16px 0; gap:20px; }

.logo{ display:flex; align-items:center; gap:10px; }
.logo .mark{ width:46px; height:46px; }
.logo .word{ font-family:var(--font-display); font-size:1.28rem; font-weight:800; color:var(--ink); line-height:1; }
.logo .word span{ color:var(--coral); }
.logo .sub{ font-family:var(--font-mono); font-size:0.62rem; letter-spacing:.12em; color:var(--ink-soft); text-transform:uppercase; }

.main-nav{ display:flex; align-items:center; gap:34px; }
.main-nav a{
  font-family:var(--font-display); font-weight:600; font-size:0.98rem; color:var(--ink);
  position:relative; padding:6px 0;
}
.main-nav a.active,
.main-nav a:hover{ color:var(--coral); }
.main-nav a.active::after{
  content:""; position:absolute; left:0; right:0; bottom:-2px; height:3px; border-radius:2px;
  background:var(--marigold);
}

.header-cta{ display:flex; align-items:center; gap:14px; }
.nav-toggle{
  display:none; flex-direction:column; gap:5px; background:none; border:none; padding:8px;
}
.nav-toggle span{ width:26px; height:3px; background:var(--ink); border-radius:2px; }

/* ---------- hero ---------- */
.hero{
  position:relative; overflow:hidden; padding-top:64px; padding-bottom:0;
  background:linear-gradient(180deg,#FFF6E8 0%, #FFEAC7 100%);
}
.hero .container{
  display:grid; grid-template-columns: 1.05fr 0.95fr; gap:40px; align-items:center;
  padding-bottom:70px; position:relative; z-index:3;
}
.hero-eyebrow-row{ display:flex; align-items:center; gap:10px; margin-bottom:18px; }
.hero-badge{
  font-family:var(--font-mono); font-size:0.75rem; letter-spacing:.1em; text-transform:uppercase;
  background:#fff; border:1px solid var(--line); padding:7px 14px; border-radius:999px; color:var(--ink-soft);
}
.hero h1{
  font-size:clamp(2.4rem, 4.6vw, 3.6rem); color:var(--ink); letter-spacing:-0.01em;
}
.hero h1 .underline{
  position:relative; display:inline-block; color:var(--coral);
}
.hero h1 .underline svg{ position:absolute; left:0; bottom:-10px; width:100%; height:14px; }
.hero p.lead{ margin-top:22px; font-size:1.08rem; color:var(--ink-soft); line-height:1.75; max-width:520px; }
.hero-actions{ margin-top:32px; display:flex; gap:16px; flex-wrap:wrap; }

.hero-stats{ display:flex; gap:34px; margin-top:46px; flex-wrap:wrap; }
.hero-stats .stat b{ display:block; font-family:var(--font-display); font-size:1.7rem; color:var(--ink); }
.hero-stats .stat span{ font-size:0.85rem; color:var(--ink-soft); }

.hero-art{ position:relative; height:460px; }
.hero-art .paper-card{
  position:absolute; background:var(--card); border-radius:var(--radius-md); box-shadow:var(--shadow);
  padding:16px 20px; display:flex; align-items:center; gap:12px; font-family:var(--font-display); font-weight:700;
}
.hero-art .card-one{ top:8%; left:0%; }
.hero-art .card-two{ bottom:12%; right:2%; }
.hero-art .paper-card .ico{
  width:42px; height:42px; border-radius:12px; display:flex; align-items:center; justify-content:center; flex:none;
}
.hero-art .card-one .ico{ background:#FFE3B0; }
.hero-art .card-two .ico{ background:#CDEFE0; }
.hero-art .paper-card small{ display:block; font-family:var(--font-body); font-weight:400; color:var(--ink-soft); font-size:0.78rem; }
.hero-art .sun{ position:absolute; top:0; right:10%; width:120px; height:120px; }
.hero-art .kid-shape{ position:absolute; inset:0; }

.skyline{ position:relative; z-index:2; line-height:0; }
.skyline svg{ width:100%; display:block; height:auto; }

/* ---------- top features (4 cards overlapping hero) ---------- */
.features-strip{ padding:0; margin-top:-64px; position:relative; z-index:10; }
.features-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:22px;
}
.feature-card{
  background:var(--card); border-radius:var(--radius-md); padding:28px 24px; box-shadow:var(--shadow);
  transition:transform .25s ease;
}
.feature-card:hover{ transform:translateY(-8px) rotate(-1deg); }
.feature-card .ico{
  width:58px; height:58px; border-radius:16px; display:flex; align-items:center; justify-content:center; margin-bottom:16px;
}
.feature-card:nth-child(1) .ico{ background:#FFE3B0; }
.feature-card:nth-child(2) .ico{ background:#CDEFE0; }
.feature-card:nth-child(3) .ico{ background:#D6EBFA; }
.feature-card:nth-child(4) .ico{ background:#FFD9D2; }
.feature-card h4{ font-size:1.08rem; margin-bottom:8px; }
.feature-card p{ color:var(--ink-soft); font-size:0.92rem; line-height:1.6; }

/* ---------- about ---------- */
.about-section{ padding-top:130px; }
.about-grid{ display:grid; grid-template-columns:0.9fr 1.1fr; gap:60px; align-items:center; }
.about-art{ position:relative; }
.about-art .frame{ border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow); }
.about-art .badge-float{
  position:absolute; bottom:-24px; left:-24px; background:var(--marigold); color:var(--ink);
  border-radius:var(--radius-md); padding:18px 22px; box-shadow:var(--shadow);
  font-family:var(--font-display);
}
.about-art .badge-float b{ display:block; font-size:1.8rem; }
.about-art .badge-float span{ font-size:0.78rem; font-weight:600; }
.about-copy p{ color:var(--ink-soft); line-height:1.8; margin-bottom:16px; }
.about-actions{ display:flex; gap:16px; margin-top:26px; flex-wrap:wrap; }
.about-checks{ margin-top:24px; display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.about-checks li{ display:flex; align-items:center; gap:10px; font-weight:700; font-family:var(--font-display); font-size:0.95rem; }
.about-checks svg{ width:22px; height:22px; flex:none; color:var(--leaf); }

/* ---------- stats band ---------- */
.stats-band{ background:var(--ink); color:#fff; padding:60px 0; }
.stats-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; text-align:center; }
.stats-grid .stat .ico{ width:52px; height:52px; margin:0 auto 14px; }
.stats-grid .stat b{ display:block; font-family:var(--font-display); font-size:2.2rem; color:var(--marigold); }
.stats-grid .stat span{ font-size:0.86rem; color:#C6C3E0; }

/* ---------- classes ---------- */
.class-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.class-card{
  background:var(--card); border-radius:var(--radius-md); overflow:hidden; box-shadow:var(--shadow);
  transition:transform .25s ease;
}
.class-card:hover{ transform:translateY(-8px); }
.class-thumb{ height:170px; position:relative; display:flex; align-items:center; justify-content:center; }
.class-thumb svg{ width:78px; height:78px; }
.class-card:nth-child(1) .class-thumb{ background:linear-gradient(135deg,#FFDCA8,#FFB627); }
.class-card:nth-child(2) .class-thumb{ background:linear-gradient(135deg,#B7E6D8,#4C9A6A); }
.class-card:nth-child(3) .class-thumb{ background:linear-gradient(135deg,#AFE0F2,#3AAFDD); }
.class-card:nth-child(4) .class-thumb{ background:linear-gradient(135deg,#FFC9BE,#FF6F59); }
.class-body{ padding:24px; }
.class-meta{ display:flex; gap:14px; flex-wrap:wrap; margin-bottom:14px; }
.class-meta span{
  font-family:var(--font-mono); font-size:0.72rem; letter-spacing:.03em; color:var(--ink-soft);
  background:var(--paper-2); border-radius:999px; padding:5px 11px;
}
.class-body h4{ font-size:1.18rem; margin-bottom:8px; }
.class-body p{ color:var(--ink-soft); font-size:0.92rem; line-height:1.6; margin-bottom:14px; }
.class-time{ font-family:var(--font-mono); font-size:0.78rem; color:var(--coral); font-weight:600; }
.class-link{ margin-top:14px; display:inline-flex; align-items:center; gap:6px; font-family:var(--font-display); font-weight:700; color:var(--ink); }
.class-link svg{ width:16px; height:16px; transition:transform .2s; }
.class-link:hover svg{ transform:translateX(4px); }

/* ---------- teachers ---------- */
.teacher-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.teacher-card{ text-align:center; }
.teacher-photo{
  width:100%; aspect-ratio:1/1.05; border-radius:var(--radius-md); position:relative; overflow:hidden;
  display:flex; align-items:center; justify-content:center; box-shadow:var(--shadow);
}
.teacher-photo svg{ width:62%; height:62%; }
.teacher-card:nth-child(4n+1) .teacher-photo{ background:linear-gradient(160deg,#FFE3B0,#FFB627); }
.teacher-card:nth-child(4n+2) .teacher-photo{ background:linear-gradient(160deg,#CDEFE0,#4C9A6A); }
.teacher-card:nth-child(4n+3) .teacher-photo{ background:linear-gradient(160deg,#D6EBFA,#3AAFDD); }
.teacher-card:nth-child(4n+4) .teacher-photo{ background:linear-gradient(160deg,#FFD9D2,#FF6F59); }
.teacher-card h4{ margin-top:16px; font-size:1.08rem; }
.teacher-card span{ color:var(--ink-soft); font-size:0.86rem; }

/* ---------- why choose ---------- */
.why-grid{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:0; align-items:center; }
.why-col{ display:flex; flex-direction:column; gap:30px; }
.why-item{ display:flex; gap:16px; }
.why-item.right{ flex-direction:row-reverse; text-align:right; }
.why-item .ico{ width:54px; height:54px; border-radius:14px; flex:none; display:flex; align-items:center; justify-content:center; }
.why-item:nth-child(1) .ico{ background:#FFE3B0; }
.why-item:nth-child(2) .ico{ background:#CDEFE0; }
.why-item:nth-child(3) .ico{ background:#D6EBFA; }
.why-item h4{ font-size:1.02rem; margin-bottom:6px; }
.why-item p{ font-size:0.88rem; color:var(--ink-soft); line-height:1.6; }
.why-center{ display:flex; justify-content:center; }
.why-center .frame{ width:100%; max-width:320px; border-radius:50%; aspect-ratio:1/1; box-shadow:var(--shadow);
  background:conic-gradient(from 210deg, #FFB627, #FF6F59, #3AAFDD, #4C9A6A, #FFB627);
  display:flex; align-items:center; justify-content:center; padding:14px; }
.why-center .frame .inner{ width:100%; height:100%; border-radius:50%; background:var(--paper); display:flex; align-items:center; justify-content:center; }
.why-center svg{ width:52%; height:52%; }

/* ---------- gallery ---------- */
.gallery-grid{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:150px; gap:14px; }
.gallery-item{
  border-radius:var(--radius-sm); position:relative; overflow:hidden; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
}
.gallery-item svg{ width:40%; height:40%; opacity:.85; }
.gallery-item::after{
  content:""; position:absolute; inset:0; background:rgba(35,32,66,0); transition:background .25s;
}
.gallery-item:hover::after{ background:rgba(35,32,66,0.35); }
.gallery-item .zoom{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  opacity:0; transition:opacity .25s; color:#fff;
}
.gallery-item:hover .zoom{ opacity:1; }
.gallery-item.g1{ grid-column:span 2; grid-row:span 2; background:linear-gradient(150deg,#FFDCA8,#FFB627); }
.gallery-item.g2{ background:linear-gradient(150deg,#CDEFE0,#4C9A6A); }
.gallery-item.g3{ background:linear-gradient(150deg,#D6EBFA,#3AAFDD); }
.gallery-item.g4{ background:linear-gradient(150deg,#FFC9BE,#FF6F59); }
.gallery-item.g5{ background:linear-gradient(150deg,#E7D9F7,#8B6FD6); }
.gallery-item.g6{ background:linear-gradient(150deg,#FFE7A0,#E89A0C); grid-column:span 2; }

/* ---------- testimonials ---------- */
.testi-wrap{ position:relative; max-width:760px; margin-inline:auto; text-align:center; }
.testi-slide{ display:none; }
.testi-slide.active{ display:block; animation:fadeUp .5s ease; }
@keyframes fadeUp{ from{opacity:0; transform:translateY(14px);} to{opacity:1; transform:translateY(0);} }
.testi-quote{ font-size:1.2rem; line-height:1.75; color:var(--ink); font-family:var(--font-display); font-weight:500; }
.testi-person{ margin-top:26px; display:flex; align-items:center; justify-content:center; gap:14px; }
.testi-avatar{ width:52px; height:52px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  background:var(--marigold); font-family:var(--font-display); font-weight:800; color:var(--ink); }
.testi-person b{ display:block; font-family:var(--font-display); }
.testi-person span{ font-size:0.82rem; color:var(--ink-soft); }
.testi-dots{ display:flex; justify-content:center; gap:10px; margin-top:30px; }
.testi-dots button{ width:10px; height:10px; border-radius:50%; background:var(--line); border:none; padding:0; }
.testi-dots button.active{ background:var(--coral); width:26px; border-radius:6px; transition:width .25s; }

/* ---------- blog ---------- */
.blog-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.blog-card{ background:var(--card); border-radius:var(--radius-md); overflow:hidden; box-shadow:var(--shadow); }
.blog-thumb{ height:170px; display:flex; align-items:center; justify-content:center; }
.blog-thumb svg{ width:56px; height:56px; }
.blog-card:nth-child(1) .blog-thumb{ background:linear-gradient(135deg,#FFDCA8,#FFB627); }
.blog-card:nth-child(2) .blog-thumb{ background:linear-gradient(135deg,#D6EBFA,#3AAFDD); }
.blog-card:nth-child(3) .blog-thumb{ background:linear-gradient(135deg,#CDEFE0,#4C9A6A); }
.blog-body{ padding:22px 24px; }
.blog-date{ font-family:var(--font-mono); font-size:0.72rem; color:var(--coral); letter-spacing:.05em; }
.blog-body h4{ margin-top:10px; font-size:1.08rem; line-height:1.4; }
.blog-body p{ margin-top:8px; color:var(--ink-soft); font-size:0.9rem; line-height:1.6; }

/* ---------- CTA band ---------- */
.cta-band{
  background:linear-gradient(120deg,var(--coral),var(--marigold));
  border-radius:var(--radius-lg); padding:56px 60px; display:flex; justify-content:space-between; align-items:center;
  gap:30px; flex-wrap:wrap; color:#fff;
}
.cta-band h3{ font-size:clamp(1.5rem,2.6vw,2.1rem); max-width:480px; }
.cta-band p{ margin-top:10px; color:rgba(255,255,255,0.9); max-width:460px; }
.cta-band .btn-primary{ background:var(--ink); box-shadow:none; }
.cta-band .btn-primary:hover{ background:#000; }

/* ---------- footer ---------- */
.site-footer{ background:var(--ink); color:#C6C3E0; padding-top:80px; }
.footer-grid{ display:grid; grid-template-columns:1.3fr 1fr 1fr 1.2fr; gap:40px; padding-bottom:50px; border-bottom:1px solid rgba(255,255,255,0.1); }
.footer-logo{ display:flex; align-items:center; gap:10px; margin-bottom:16px; }
.footer-logo .word{ font-family:var(--font-display); font-size:1.2rem; color:#fff; font-weight:800; }
.footer-col p{ line-height:1.7; font-size:0.9rem; }
.footer-col h5{ color:#fff; font-family:var(--font-display); font-size:1rem; margin-bottom:18px; }
.footer-col ul li{ margin-bottom:12px; font-size:0.9rem; }
.footer-col ul li a:hover{ color:var(--marigold); }
.footer-contact li{ display:flex; gap:10px; align-items:flex-start; }
.footer-contact svg{ width:17px; height:17px; flex:none; margin-top:2px; color:var(--marigold); }
.footer-social{ display:flex; gap:10px; margin-top:18px; }
.footer-social a{ width:34px; height:34px; border-radius:50%; border:1px solid rgba(255,255,255,0.2);
  display:flex; align-items:center; justify-content:center; transition:background .2s; }
.footer-social a:hover{ background:var(--coral); border-color:var(--coral); }
.footer-social svg{ width:15px; height:15px; }
.newsletter{ display:flex; margin-top:14px; border-radius:999px; overflow:hidden; background:rgba(255,255,255,0.08); padding:5px; }
.newsletter input{ flex:1; background:none; border:none; padding:10px 14px; color:#fff; font-family:var(--font-body); }
.newsletter input::placeholder{ color:#9A96BE; }
.newsletter button{ background:var(--coral); color:#fff; border:none; border-radius:999px; padding:0 20px; font-family:var(--font-display); font-weight:700; }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; padding:26px 0; font-size:0.82rem; flex-wrap:wrap; gap:10px; }
.footer-bottom a{ color:var(--marigold); }

/* ---------- back to top ---------- */
.to-top{
  position:fixed; right:26px; bottom:26px; width:48px; height:48px; border-radius:50%;
  background:var(--coral); color:#fff; display:flex; align-items:center; justify-content:center;
  border:none; box-shadow:var(--shadow); opacity:0; pointer-events:none; transition:opacity .25s, transform .25s;
  z-index:80;
}
.to-top.show{ opacity:1; pointer-events:auto; }
.to-top:hover{ transform:translateY(-4px); }
.to-top svg{ width:20px; height:20px; }

/* ---------- inner page hero ---------- */
.page-hero{
  padding:60px 0 70px; background:linear-gradient(180deg,#FFF6E8 0%, #FFEAC7 100%); text-align:center; position:relative; overflow:hidden;
}
.page-hero h1{ font-size:clamp(2rem,4vw,2.8rem); }
.breadcrumb{ margin-top:14px; font-family:var(--font-mono); font-size:0.82rem; color:var(--ink-soft); }
.breadcrumb a{ color:var(--coral); }

/* ---------- contact page ---------- */
.contact-grid{ display:grid; grid-template-columns:0.9fr 1.1fr; gap:50px; }
.contact-info-card{ background:var(--card); border-radius:var(--radius-md); box-shadow:var(--shadow); padding:30px; }
.contact-info-card li{ display:flex; gap:14px; padding:14px 0; border-bottom:1px dashed var(--line); }
.contact-info-card li:last-child{ border-bottom:none; }
.contact-info-card .ico{ width:44px; height:44px; border-radius:12px; background:var(--paper-2); display:flex; align-items:center; justify-content:center; flex:none; }
.contact-info-card b{ display:block; font-family:var(--font-display); font-size:0.98rem; }
.contact-info-card span{ font-size:0.87rem; color:var(--ink-soft); }
.contact-form{ background:var(--card); border-radius:var(--radius-md); box-shadow:var(--shadow); padding:36px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-bottom:18px; }
.form-field{ display:flex; flex-direction:column; gap:8px; }
.form-field.full{ grid-column:1/-1; }
.form-field label{ font-family:var(--font-display); font-size:0.85rem; font-weight:700; }
.form-field input, .form-field select, .form-field textarea{
  border:1px solid var(--line); border-radius:var(--radius-sm); padding:12px 14px; font-family:var(--font-body);
  background:var(--paper); font-size:0.95rem;
}
.form-field textarea{ resize:vertical; min-height:120px; }
.form-field input:focus, .form-field select:focus, .form-field textarea:focus{ outline:2px solid var(--sky); outline-offset:1px; }
.form-note{ font-size:0.82rem; color:var(--ink-soft); margin-top:12px; }
.map-frame{ border-radius:var(--radius-md); overflow:hidden; box-shadow:var(--shadow); margin-top:60px; height:360px; }
.map-frame iframe{ width:100%; height:100%; border:0; }

/* ---------- admissions steps (about/classes pages) ---------- */
.steps-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; counter-reset:step; }
.step-card{ background:var(--card); border-radius:var(--radius-md); padding:26px; box-shadow:var(--shadow); position:relative; }
.step-card .num{ font-family:var(--font-display); font-size:2.4rem; color:var(--paper-2); font-weight:800; -webkit-text-stroke:2px var(--marigold); }
.step-card h4{ margin-top:10px; font-size:1.02rem; }
.step-card p{ margin-top:8px; font-size:0.86rem; color:var(--ink-soft); line-height:1.6; }

/* ---------- fade in on scroll ---------- */
.reveal{ opacity:0; transform:translateY(24px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in{ opacity:1; transform:translateY(0); }

/* ==========================================================
   Responsive
   ========================================================== */
@media (max-width: 1080px){
  .features-grid{ grid-template-columns:repeat(2,1fr); }
  .stats-grid{ grid-template-columns:repeat(2,1fr); gap:34px; }
  .class-grid, .teacher-grid, .blog-grid{ grid-template-columns:repeat(2,1fr); }
  .why-grid{ grid-template-columns:1fr; }
  .why-center{ order:-1; margin-bottom:20px; }
  .why-item.right{ flex-direction:row; text-align:left; }
  .about-grid, .contact-grid{ grid-template-columns:1fr; }
  .steps-grid{ grid-template-columns:repeat(2,1fr); }
  .footer-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width: 860px){
  .topbar .topbar-items li:nth-child(3){ display:none; }
  .main-nav{ position:fixed; inset:0 0 0 auto; top:0; height:100vh; width:78%; max-width:340px;
    background:var(--paper); flex-direction:column; align-items:flex-start; padding:100px 30px 30px; gap:22px;
    transform:translateX(100%); transition:transform .3s ease; box-shadow:-10px 0 30px rgba(0,0,0,0.15); }
  .main-nav.open{ transform:translateX(0); }
  .nav-toggle{ display:flex; }
  .hero .container{ grid-template-columns:1fr; }
  .hero-art{ height:340px; }
  .hero-actions{ justify-content:flex-start; }
  .features-strip{ margin-top:20px; }
  .about-section{ padding-top:88px; }
}
@media (max-width: 620px){
  section{ padding:64px 0; }
  .features-grid, .class-grid, .teacher-grid, .blog-grid, .gallery-grid, .steps-grid{ grid-template-columns:1fr 1fr; }
  .gallery-item.g1, .gallery-item.g6{ grid-column:span 2; }
  .stats-grid{ grid-template-columns:1fr 1fr; }
  .footer-grid{ grid-template-columns:1fr; }
  .cta-band{ padding:40px 26px; text-align:center; justify-content:center; }
  .form-row{ grid-template-columns:1fr; }
  .topbar .container{ justify-content:center; text-align:center; }
}
