/*
Theme Name: Sri Nidhi Edu
Theme URI: https://srinidhiedu.com
Author: Sri Nidhi Educational Trust
Author URI: https://srinidhiedu.com
Description: Custom theme for Sri Nidhi Edu — A Futuron Preschool in Palamaner. German Kita-inspired play-based learning.
Version: 1.0
Template: astra
Text Domain: srinidhi
*/

/* --- DESIGN TOKENS --- */
:root{--sn-gold:#F6A623;--sn-teal:#4ECDC4;--sn-coral:#FF6B6B;--sn-lavender:#A78BFA;--sn-green:#22C55E;--sn-navy:#1E293B;--sn-plum:#2E2233;--sn-cream:#FFF9F0;--sn-sand:#F5F0E8;--sn-gray:#6B7280;--sn-white:#FFFFFF;--sn-font1:'Trebuchet MS','Nunito',sans-serif;--sn-font2:'Quicksand',sans-serif;--sn-radius:14px;--sn-radius-btn:50px;--sn-radius-card:20px}

/* --- RESET --- */
*,*::before,*::after{box-sizing:border-box}
body{font-family:var(--sn-font2);color:var(--sn-navy);background:var(--sn-white);-webkit-font-smoothing:antialiased;line-height:1.6;margin:0}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
::selection{background:rgba(246,166,35,0.19)}

/* --- TYPOGRAPHY --- */
h1,h2,h3,h4{font-family:var(--sn-font1);color:var(--sn-navy);font-weight:800;line-height:1.2}
h1{font-size:clamp(30px,5vw,52px)}
h2{font-size:clamp(22px,4vw,36px)}
h3{font-size:clamp(18px,3vw,24px)}
p{font-family:var(--sn-font2);color:var(--sn-gray);line-height:1.8}
.sn-subtitle{font-family:var(--sn-font2);font-size:13px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--sn-gold);margin-bottom:8px}
.sn-dots{display:flex;gap:5px;margin:12px 0 24px}
.sn-dots.centered{justify-content:center}
.sn-dots span{width:6px;height:6px;border-radius:50%}
.sn-dots span:nth-child(1){background:var(--sn-gold)}.sn-dots span:nth-child(2){background:var(--sn-coral)}.sn-dots span:nth-child(3){background:var(--sn-teal)}.sn-dots span:nth-child(4){background:var(--sn-lavender)}

/* --- BUTTONS --- */
.sn-btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--sn-font2);font-weight:700;font-size:15px;padding:14px 32px;border-radius:var(--sn-radius-btn);border:none;cursor:pointer;transition:all .3s;text-decoration:none}
.sn-btn-primary{background:linear-gradient(135deg,var(--sn-gold),var(--sn-coral));color:#fff}
.sn-btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(246,166,35,.3)}
.sn-btn-outline{background:transparent;border:2px solid var(--sn-sand);color:var(--sn-navy)}
.sn-btn-outline:hover{border-color:var(--sn-gold);color:var(--sn-gold)}
.sn-btn-white{background:#fff;color:var(--sn-navy)}
.sn-btn-gold-outline{background:transparent;border:2px solid rgba(255,255,255,.35);color:#fff}

/* --- HEADER --- */
.sn-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(255,255,255,.95);backdrop-filter:blur(12px);border-bottom:1px solid rgba(0,0,0,.04);transition:all .3s}
.sn-header.scrolled{box-shadow:0 2px 20px rgba(0,0,0,.06)}
.sn-header-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:14px 24px}
.sn-logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.sn-logo-text{font-family:var(--sn-font1);font-size:18px;font-weight:800;color:var(--sn-navy);line-height:1.1}
.sn-logo-edu{font-family:var(--sn-font1);font-size:13px;font-weight:800;color:var(--sn-teal);line-height:1}
.sn-nav{display:flex;align-items:center;gap:6px}
.sn-nav a{font-family:var(--sn-font2);font-size:14px;font-weight:600;color:var(--sn-navy);padding:8px 16px;border-radius:22px;transition:all .2s}
.sn-nav a:hover,.sn-nav a.active{background:rgba(246,166,35,.08);color:var(--sn-gold)}
.sn-nav .sn-btn{padding:10px 24px;font-size:13px}
.sn-hamburger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:8px}
.sn-hamburger span{width:22px;height:2px;background:var(--sn-navy);border-radius:1px;transition:all .3s}
.sn-mobile-menu{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(255,255,255,.98);z-index:999;flex-direction:column;align-items:center;justify-content:center;gap:16px}
.sn-mobile-menu.open{display:flex}
.sn-mobile-menu a{font-family:var(--sn-font2);font-size:18px;font-weight:600;color:var(--sn-navy);padding:12px 24px}
.sn-mobile-menu .sn-close{position:absolute;top:20px;right:20px;background:none;border:none;font-size:28px;cursor:pointer;color:var(--sn-navy)}

/* --- SECTIONS --- */
.sn-section{padding:90px 24px}
.sn-section-cream{background:var(--sn-cream)}
.sn-section-sand{background:var(--sn-sand)}
.sn-section-white{background:var(--sn-white)}
.sn-section-plum{background:var(--sn-plum);color:#fff}
.sn-container{max-width:1200px;margin:0 auto}
.sn-container-sm{max-width:800px;margin:0 auto}
.sn-container-md{max-width:1000px;margin:0 auto}
.sn-text-center{text-align:center}
.sn-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center}
.sn-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.sn-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}

/* --- HERO --- */
.sn-hero{padding:140px 24px 90px;background:linear-gradient(160deg,var(--sn-cream),#FFF5E6,#E8F8F5);position:relative;overflow:hidden}
.sn-hero .sn-container{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.sn-hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(246,166,35,.1);border-radius:50px;padding:6px 18px;margin-bottom:16px}
.sn-hero-badge span{font-family:var(--sn-font2);font-size:12px;font-weight:700;color:var(--sn-gold);letter-spacing:1.5px}
.sn-hero h1 em{color:var(--sn-gold);font-style:normal}
.sn-hero p{font-size:17px;margin:16px 0 28px}
.sn-hero-btns{display:flex;gap:12px;flex-wrap:wrap}
.sn-hero-stats{display:flex;gap:28px;margin-top:36px;padding-top:28px;border-top:1px solid rgba(0,0,0,.06)}
.sn-stat-num{font-family:var(--sn-font1);font-size:26px;font-weight:800;color:var(--sn-gold)}
.sn-stat-label{font-family:var(--sn-font2);font-size:12px;color:var(--sn-gray)}
.sn-hero-img{position:relative;width:100%;aspect-ratio:4/3;border-radius:24px;overflow:hidden;background:linear-gradient(135deg,rgba(246,166,35,.1),rgba(78,205,196,.1));display:flex;flex-direction:column;align-items:center;justify-content:center;border:2px dashed rgba(246,166,35,.2)}
.sn-hero-img img{width:100%;height:100%;object-fit:cover;border-radius:24px}

/* --- CARDS --- */
.sn-card{background:#fff;border-radius:var(--sn-radius-card);padding:32px 24px;box-shadow:0 2px 16px rgba(0,0,0,.04);transition:all .3s;text-align:center}
.sn-card:hover{transform:translateY(-4px);box-shadow:0 8px 32px rgba(0,0,0,.08)}
.sn-card-icon{font-size:36px;margin-bottom:16px}
.sn-card h3{font-size:18px;margin-bottom:8px}
.sn-card p{font-size:14px}

/* --- COUNTDOWN --- */
.sn-countdown-boxes{display:flex;justify-content:center;gap:12px;margin:24px 0}
.sn-cd-box{background:#fff;border-radius:16px;padding:16px 24px;min-width:80px;box-shadow:0 2px 12px rgba(0,0,0,.04);text-align:center}
.sn-cd-box .num{font-family:var(--sn-font1);font-size:28px;font-weight:800;color:var(--sn-coral)}
.sn-cd-box .lbl{font-family:var(--sn-font2);font-size:11px;color:var(--sn-gray);text-transform:uppercase}

/* --- TIMELINE --- */
.sn-timeline{position:relative;padding-left:0}
.sn-tl-item{display:grid;grid-template-columns:74px 14px 1fr;gap:14px;align-items:start;padding:14px 0;position:relative}
.sn-tl-time{font-family:var(--sn-font1);font-size:13px;font-weight:700;color:var(--sn-navy);text-align:right;line-height:1.2;padding-top:2px}
.sn-tl-dot-wrap{display:flex;flex-direction:column;align-items:center;align-self:stretch;position:relative;padding-top:3px}
.sn-tl-dot{width:14px;height:14px;border-radius:50%;background:#fff;border:3px solid var(--sn-gold);flex-shrink:0;z-index:1}
.sn-tl-item:not(:last-child) .sn-tl-dot-wrap::after{content:'';position:absolute;top:19px;left:50%;width:2px;bottom:-15px;background:var(--sn-gold);opacity:0.25;transform:translateX(-50%);border-radius:1px}
.sn-tl-content{padding-top:0}
.sn-tl-content h4{font-size:16px;font-weight:700;margin:0 0 2px;line-height:1.2}
.sn-tl-content p{font-size:13px;margin:0}

/* --- STORY --- */
.sn-story-quote{border-left:3px solid var(--sn-gold);padding-left:20px;font-style:italic;font-size:16px;line-height:1.8;color:var(--sn-navy)}
.sn-story-pullquote{border-left:3px solid var(--sn-teal);padding:20px 20px 20px 24px;background:rgba(78,205,196,.06);border-radius:0 16px 16px 0;margin:28px 0}
.sn-story-pullquote p{font-style:italic;font-size:17px;color:var(--sn-navy);line-height:1.8;margin:0}
.sn-story-body{border-left:3px solid var(--sn-gold);padding-left:24px}
.sn-story-body p{font-size:16px;color:var(--sn-navy);line-height:1.9;margin-bottom:20px}
.sn-author-sig{display:flex;align-items:center;gap:14px;margin-top:32px;padding-top:24px;border-top:1px solid var(--sn-sand)}
.sn-avatar{width:48px;height:48px;border-radius:50%;background:rgba(246,166,35,.12);display:flex;align-items:center;justify-content:center;font-family:var(--sn-font1);font-size:20px;font-weight:700;color:var(--sn-gold);flex-shrink:0}

/* --- FORM --- */
.sn-form input,.sn-form select,.sn-form textarea{width:100%;padding:14px 18px;font-family:var(--sn-font2);font-size:15px;border:2px solid var(--sn-sand);border-radius:var(--sn-radius);background:var(--sn-sand);transition:all .2s;color:var(--sn-navy)}
.sn-form input:focus,.sn-form select:focus,.sn-form textarea:focus{border-color:var(--sn-gold);background:#fff;outline:none;box-shadow:0 0 0 3px rgba(246,166,35,.08)}
.sn-form label{font-family:var(--sn-font2);font-size:13px;font-weight:600;color:var(--sn-navy);display:block;margin-bottom:6px}
.sn-form-group{margin-bottom:18px}
.sn-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* --- FOOTER --- */
.sn-footer{background:var(--sn-plum);color:rgba(255,255,255,.7);padding:60px 24px 24px}
.sn-footer h4{color:#fff;font-size:16px;margin-bottom:16px}
.sn-footer p{font-size:14px;line-height:1.7;color:rgba(255,255,255,.5)}
.sn-footer a{color:rgba(255,255,255,.7);transition:color .2s}
.sn-footer a:hover{color:var(--sn-gold)}
.sn-footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.sn-footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:20px;display:flex;justify-content:space-between;align-items:center}
.sn-footer-bottom p{font-size:13px;color:rgba(255,255,255,.3)}
.sn-footer .sn-logo-text{color:#fff}

/* --- WHATSAPP --- */
.sn-whatsapp{position:fixed;bottom:24px;right:24px;z-index:900;width:56px;height:56px;border-radius:50%;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(37,211,102,.35);animation:snWa 2s ease-in-out infinite;text-decoration:none}
.sn-whatsapp svg{width:28px;height:28px;fill:#fff}
@keyframes snWa{0%,100%{transform:scale(1)}50%{transform:scale(1.06)}}

/* --- SCROLL REVEAL --- */
.sn-reveal{opacity:0;transform:translateY(32px);transition:opacity .7s ease,transform .7s ease}
.sn-reveal.visible{opacity:1;transform:translateY(0)}

/* --- GALLERY --- */
.sn-gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}
.sn-gallery-item{border-radius:16px;overflow:hidden;aspect-ratio:4/3;background:var(--sn-sand)}
.sn-gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.sn-gallery-item:hover img{transform:scale(1.05)}

/* --- STEPS --- */
.sn-steps{display:flex;gap:20px}
.sn-step{flex:1;text-align:center;padding:24px 16px}
.sn-step-num{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--sn-gold),var(--sn-coral));color:#fff;font-family:var(--sn-font1);font-size:20px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}

/* --- CONTACT --- */
.sn-contact-card{display:flex;align-items:flex-start;gap:16px;padding:20px;background:#fff;border-radius:var(--sn-radius);margin-bottom:16px}
.sn-contact-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}

/* --- ASTRA OVERRIDES --- */
.ast-container{max-width:100%;padding:0}
.site-content{margin-top:0}
.entry-content{margin-top:0}
#page{overflow-x:hidden}
.ast-above-header-wrap,.ast-below-header-wrap,.ast-header-break-point .ast-mobile-header-wrap{display:none}
#masthead,.ast-primary-header-bar{display:none}
.ast-footer-overlay,#colophon{display:none}
.hentry .entry-header{display:none}

/* --- RESPONSIVE --- */
@media(max-width:768px){
.sn-hero .sn-container{grid-template-columns:1fr;text-align:center}
.sn-hero-img{display:none}
.sn-hero-btns{justify-content:center}
.sn-hero-stats{justify-content:center}
.sn-nav{display:none}
.sn-hamburger{display:flex}
.sn-grid-2{grid-template-columns:1fr}
.sn-grid-3{grid-template-columns:1fr}
.sn-grid-4{grid-template-columns:1fr 1fr}
.sn-form-row{grid-template-columns:1fr}
.sn-steps{flex-direction:column}
.sn-footer-grid{grid-template-columns:1fr;gap:28px}
.sn-footer-bottom{flex-direction:column;gap:8px;text-align:center}
.sn-tl-item{grid-template-columns:58px 14px 1fr;gap:10px}
.sn-tl-item:not(:last-child) .sn-tl-dot-wrap::after{bottom:-15px}
.sn-tl-time{font-size:11px}
.sn-tl-content h4{font-size:14px}
.sn-tl-content p{font-size:12px}
.sn-section{padding:60px 16px}
.sn-hero{padding:120px 16px 60px}
}

/* --- LOGO ANIMATION --- */
@keyframes sn-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.06)}}
@keyframes sn-ring-pulse{0%,100%{opacity:.3;r:56}50%{opacity:.15;r:62}}
@keyframes sn-ray-spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}
@keyframes sn-dot-pop{0%{transform:scale(0);opacity:0}100%{transform:scale(1);opacity:1}}
@keyframes sn-dot-bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-2px)}}
@keyframes sn-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-2px)}}

/* Always-on subtle pulse — visible on mobile and desktop */
.sn-logo svg{animation:sn-pulse 3s ease-in-out infinite;transition:transform .3s}
.sn-logo .sn-sun-rays{transition:transform .3s;transform-origin:80px 84px}

/* Hover — desktop enhancement */
.sn-logo:hover svg{animation:sn-pulse 1.5s ease-in-out infinite}
.sn-logo:hover .sn-sun-rays{animation:sn-ray-spin 6s linear infinite;transform-origin:80px 84px}
.sn-logo:hover .sn-sun-face{animation:sn-float 1.2s ease-in-out infinite}
.sn-logo:hover .sn-logo-text{color:var(--sn-gold)}
.sn-logo .sn-logo-text,.sn-logo .sn-logo-edu{transition:color .3s}

/* Brand dots — pop in on load, then gentle bounce loop */
.sn-logo .sn-dots span{animation:sn-dot-pop .4s ease-out both,sn-dot-bounce 2s ease-in-out infinite 1s}
.sn-logo .sn-dots span:nth-child(1){animation-delay:.1s,.1s}
.sn-logo .sn-dots span:nth-child(2){animation-delay:.2s,.2s}
.sn-logo .sn-dots span:nth-child(3){animation-delay:.3s,.3s}
.sn-logo .sn-dots span:nth-child(4){animation-delay:.4s,.4s}

@media(prefers-reduced-motion:reduce){
.sn-logo svg{animation:none}
.sn-logo .sn-dots span{animation:none;opacity:1;transform:scale(1)}
}

/* --- BREADCRUMBS --- */
.sn-breadcrumbs{max-width:1200px;margin:0 auto;padding:12px 24px}
.sn-breadcrumbs-wrap{font-family:var(--sn-font2);font-size:13px;color:var(--sn-gray);display:flex;align-items:center;flex-wrap:wrap;gap:4px}
.sn-breadcrumbs-wrap a{color:var(--sn-navy);font-weight:600;text-decoration:none;transition:color .2s}
.sn-breadcrumbs-wrap a:hover{color:var(--sn-gold)}
.sn-breadcrumbs-wrap .separator{color:var(--sn-sand);margin:0 2px}
.sn-breadcrumbs-wrap .last{color:var(--sn-gold);font-weight:600}
