/* =====================================================
   ROOT VARIABLES
===================================================== */
:root {
  --coral:      #F4845F;
  --coral-lt:   #FDEEE8;
  --coral-dk:   #C45A35;
  --teal:       #3BBFA3;
  --teal-lt:    #E1F5F0;
  --teal-dk:    #1D9E75;
  --amber:      #F6C244;
  --amber-lt:   #FEF6DC;
  --lavender:   #9B8FD6;
  --lav-lt:     #EEEDFE;
  --sage:       #4CAF8B;
  --sage-lt:    #E2F4ED;
  --sage-dk:    #2E7D5E;
  --blush-lt:   #FBEAF0;
  --cream:      #FDF8F2;
  --dark:       #3D2C2C;
  --mid:        #7A5C5C;
  --light:      #B89898;
  --white:      #FFFFFF;
  --text:       #2D1F1F;
  --sh-sm:      0 2px 8px rgba(61,44,44,.08);
  --sh-md:      0 6px 24px rgba(61,44,44,.10);
  --sh-lg:      0 12px 40px rgba(61,44,44,.15);
  --r-sm:       12px;
  --r-md:       20px;
  --r-lg:       28px;
  --ease:       0.25s cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Nunito',sans-serif;background:var(--cream);color:var(--text);overflow-x:hidden;line-height:1.6;overflow-wrap:anywhere;word-break:break-word}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;font-family:'Nunito',sans-serif}

/* =====================================================
   NAVBAR
===================================================== */
nav{
  background:rgba(253,248,242,.96);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  padding:0 3rem;
  display:flex;align-items:center;justify-content:space-between;
  height:70px;
  box-shadow:0 1px 0 rgba(244,132,95,.12),var(--sh-sm);
  position:sticky;top:0;z-index:1000;
  transition:box-shadow var(--ease);
}
nav.scrolled{box-shadow:0 3px 24px rgba(61,44,44,.13)}

.nav-logo{
  font-family:'Playfair Display',serif;font-size:1.25rem;
  color:var(--coral-dk);display:flex;align-items:center;gap:10px;font-weight:700;
}
.nav-logo .dot{
  width:10px;height:10px;background:var(--amber);border-radius:50%;flex-shrink:0;
  animation:pulse-dot 2.5s ease-in-out infinite;
}
@keyframes pulse-dot{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.35);opacity:.65}}

.nav-links{display:flex;gap:1.7rem;align-items:center}
.nav-links a{
  color:var(--mid);font-weight:600;font-size:.92rem;
  position:relative;padding-bottom:2px;transition:color var(--ease);
}
.nav-links a::after{
  content:'';position:absolute;bottom:-4px;left:0;
  width:0;height:2px;background:var(--coral);border-radius:2px;
  transition:width var(--ease);
}
.nav-links a:hover{color:var(--coral)}
.nav-links a:hover::after{width:100%}

.nav-cta{
  background:var(--coral)!important;color:var(--white)!important;
  padding:9px 20px!important;border-radius:50px!important;font-weight:700!important;
  box-shadow:0 3px 12px rgba(244,132,95,.32);
  transition:background var(--ease),transform var(--ease),box-shadow var(--ease)!important;
}
.nav-cta:hover{background:var(--coral-dk)!important;transform:translateY(-2px)!important;box-shadow:0 6px 20px rgba(244,132,95,.44)!important}
.nav-cta::after{display:none!important}

/* hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:6px;z-index:1001}
.hamburger span{display:block;width:24px;height:2px;background:var(--mid);border-radius:2px;transition:var(--ease)}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

.mobile-nav{
  display:none;position:fixed;top:70px;left:0;right:0;
  background:var(--cream);padding:1.5rem 2rem 2rem;
  box-shadow:var(--sh-lg);z-index:99999;flex-direction:column;gap:1.1rem;
  opacity:0;transform:translateY(-16px);pointer-events:none;
  transition:opacity .3s ease,transform .3s ease;
  border-bottom: 2px solid var(--coral);
  height: auto;
}
.mobile-nav.open{opacity:1;transform:translateY(0);pointer-events:all}
.mobile-nav a{
  color:var(--mid);font-weight:600;font-size:1.05rem;
  padding:.5rem 0;border-bottom:1px solid var(--coral-lt);transition:color var(--ease);
}
.mobile-nav a:hover{color:var(--coral)}
.mobile-nav .mob-cta{
  margin-top:.4rem;background:var(--coral);color:var(--white)!important;
  padding:12px 24px;border-radius:50px;text-align:center;border-bottom:none;font-weight:700;
}

/* =====================================================
   HERO
===================================================== */
.hero{
  display:grid;grid-template-columns:1fr 1fr;
  align-items:center;min-height:calc(100vh - 70px);
  padding:5rem 5rem;gap:4rem;
  position:relative;overflow:hidden;
}
.hero-bg1{
  position:absolute;top:-130px;right:-130px;width:560px;height:560px;
  background:radial-gradient(circle,var(--teal-lt) 0%,transparent 70%);
  border-radius:50%;z-index:0;opacity:.65;
  animation:flt 9s ease-in-out infinite;
}
.hero-bg2{
  position:absolute;bottom:-110px;left:-90px;width:420px;height:420px;
  background:radial-gradient(circle,var(--blush-lt) 0%,transparent 70%);
  border-radius:50%;z-index:0;opacity:.75;
  animation:flt 11s ease-in-out infinite reverse;
}
@keyframes flt{0%,100%{transform:translate(0,0)}50%{transform:translate(18px,-18px)}}

.hero-text{position:relative;z-index:1}

/* ── BADGE (change 5) ── */
.hero-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--amber-lt);color:var(--coral-dk);
  font-size:.73rem;font-weight:800;
  padding:7px 18px;border-radius:50px;
  margin-bottom:1.4rem;
  letter-spacing:.07em;text-transform:uppercase;
  border:1px solid rgba(246,194,68,.32);
}

.hero h1{
  font-family:'Playfair Display',serif;
  font-size:3.7rem;line-height:1.1;
  color:var(--dark);margin-bottom:1.4rem;letter-spacing:-.01em;
}
.hero h1 em{font-style:italic;color:var(--coral)}

/* ── HERO SUB (change 4) ── */
.hero-sub{
  font-size:1.08rem;color:var(--mid);
  line-height:1.92;margin-bottom:2.3rem;max-width:510px;
}

.hero-btns{display:flex;gap:1rem;flex-wrap:wrap}

/* buttons */
.btn{
  padding:14px 32px;border-radius:50px;
  font-family:'Nunito',sans-serif;font-weight:700;font-size:.98rem;
  cursor:pointer;border:none;
  display:inline-flex;align-items:center;gap:6px;
  transition:transform var(--ease),box-shadow var(--ease),background var(--ease);
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--coral);color:var(--white);box-shadow:0 4px 14px rgba(244,132,95,.35)}
.btn-primary:hover{background:var(--coral-dk);box-shadow:0 8px 24px rgba(244,132,95,.46)}
.btn-outline{background:var(--white);color:var(--coral);border:2px solid var(--coral);box-shadow:var(--sh-sm)}
.btn-outline:hover{background:var(--coral-lt);box-shadow:var(--sh-md)}

/* =====================================================
   HERO CARDS — clean 2×2 grid, all cards equally visible
===================================================== */
.hero-visual{
  position:relative;z-index:1;
  display:flex;justify-content:center;align-items:center;
}

/* 2×2 CSS grid — no absolute positioning, no overlap issues */
.card-stack{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  width:380px;
}

.hcard{
  border-radius:20px;
  padding:1.4rem 1.5rem;
  transition:transform .3s ease, box-shadow .3s ease;
  position:relative; /* normal flow, no absolute */
}

/* Alternate slight tilt for visual interest — but readable always */
.hcard:nth-child(odd) { transform:rotate(-1.5deg); }
.hcard:nth-child(even){ transform:rotate(1.5deg);  }
.hcard:hover{
  transform:rotate(0deg) translateY(-6px) scale(1.03)!important;
  box-shadow:0 20px 48px rgba(0,0,0,.16)!important;
  z-index:2;
}

/* Card 1 — Teal — Child Psychology */
.hc1{
  background:var(--teal);color:var(--white);
  box-shadow:0 8px 24px rgba(59,191,163,.35);
}
/* Card 2 — Coral/Salmon — Books */
.hc2{
  background:var(--coral);color:var(--white);
  box-shadow:0 8px 24px rgba(244,132,95,.35);
}
/* Card 3 — Amber — Relationships */
.hc3{
  background:var(--amber);color:var(--dark);
  box-shadow:0 8px 24px rgba(246,194,68,.40);
}
/* Card 4 — Violet/Purple — Personal Growth (distinct, different from all others) */
.hc4{
  background:linear-gradient(135deg,#7C5CBF 0%,#A67DD4 100%);
  color:var(--white);
  box-shadow:0 8px 24px rgba(124,92,191,.38);
}

.hc-icon{font-size:1.9rem;margin-bottom:.45rem;display:block;line-height:1}
.hc-title{font-family:'Playfair Display',serif;font-size:.98rem;margin-bottom:5px;line-height:1.3;font-weight:700}
.hc-desc{font-size:.78rem;opacity:.9;font-weight:500;line-height:1.5}

/* scroll cue */
.scroll-cue{
  position:absolute;bottom:1.8rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:5px;
  opacity:.4;animation:bounce-y 2s ease-in-out infinite;z-index:1;
}
.scroll-cue span{font-size:.72rem;color:var(--mid);font-weight:600}
.scroll-cue svg{width:20px;height:20px;stroke:var(--coral)}
@keyframes bounce-y{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(7px)}}

/* =====================================================
   SECTIONS
===================================================== */
.section{padding:6rem 5rem}
.sec-alt{background:var(--white)}

.sec-label{
  font-size:.74rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  color:var(--teal-dk);margin-bottom:.7rem;display:flex;align-items:center;gap:8px;
}
.sec-label::before{content:'';display:inline-block;width:24px;height:2px;background:var(--teal);border-radius:2px}

.sec-title{font-family:'Playfair Display',serif;font-size:2.55rem;color:var(--dark);margin-bottom:1rem;line-height:1.2}
.sec-sub{color:var(--mid);font-size:1.04rem;line-height:1.88;max-width:640px;margin-bottom:3rem}

/* =====================================================
   TOPICS — 4-column grid  (change 2 & 6)
===================================================== */
.topics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}

.topic-card{border-radius:var(--r-md);padding:2rem 1.75rem;transition:transform var(--ease),box-shadow var(--ease)}
.topic-card:hover{transform:translateY(-7px);box-shadow:var(--sh-lg)}

.tc-books        {background:var(--coral-lt)}
.tc-children     {background:var(--teal-lt)}
.tc-relations    {background:var(--lav-lt)}
.tc-growth       {background:var(--sage-lt)}

.t-icon{
  width:54px;height:54px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;font-size:1.55rem;margin-bottom:1.15rem;
}
.ti-books        {background:var(--coral)}
.ti-children     {background:var(--teal)}
.ti-relations    {background:var(--lavender)}
.ti-growth       {background:var(--sage)}

.topic-card h3{font-family:'Playfair Display',serif;font-size:1.18rem;color:var(--dark);margin-bottom:.6rem;line-height:1.3}
.topic-card p{color:var(--mid);font-size:.9rem;line-height:1.75}
.t-tag{
  display:inline-block;margin-top:1rem;
  font-size:.7rem;font-weight:700;padding:4px 12px;border-radius:20px;
  background:rgba(255,255,255,.68);color:var(--dark);letter-spacing:.02em;
}

/* =====================================================
   BLOG GRID
===================================================== */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:2.5rem}

.blog-card{
  background:var(--white);border-radius:var(--r-md);overflow:hidden;
  box-shadow:var(--sh-sm);cursor:pointer;
  border:1px solid rgba(244,132,95,.08);
  transition:transform var(--ease),box-shadow var(--ease);
}
.blog-card:hover{transform:translateY(-7px);box-shadow:var(--sh-lg)}

.blog-thumb{height:148px;display:flex;align-items:center;justify-content:center;font-size:2.9rem}
.bt1{background:linear-gradient(135deg,#FDEEE8,#FBD5C5)}
.bt2{background:linear-gradient(135deg,#E1F5F0,#C5EDE4)}
.bt3{background:linear-gradient(135deg,#FEF6DC,#FCEDB5)}
.bt4{background:linear-gradient(135deg,#EEEDFE,#DAD9FD)}
.bt5{background:linear-gradient(135deg,#FBEAF0,#F5CCDE)}
.bt6{background:linear-gradient(135deg,#E1F5F0,#C5EDE4)}
.bt7{background:linear-gradient(135deg,#E2F4ED,#B5DFD0)}
.bt8{background:linear-gradient(135deg,#DFFAF1,#A8D8C5)}

.blog-body{padding:1.4rem}
.b-cat{
  font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.09em;
  display:inline-block;padding:4px 11px;border-radius:20px;margin-bottom:.55rem;
}
.bc-books{background:var(--coral-lt);color:var(--coral-dk)}
.bc-child{background:var(--teal-lt);color:var(--teal-dk)}
.bc-rel  {background:var(--lav-lt);color:#4A3FA0}
.bc-grow {background:var(--sage-lt);color:var(--sage-dk)}

.blog-card h4{font-family:'Playfair Display',serif;font-size:1.03rem;color:var(--dark);margin-bottom:.5rem;line-height:1.43}
.blog-card p{font-size:.87rem;color:var(--mid);line-height:1.65;margin-bottom:.95rem}
.b-meta{font-size:.76rem;color:var(--light);display:flex;align-items:center;gap:7px}
.b-meta .d{width:3px;height:3px;background:var(--light);border-radius:50%}

.blog-center{text-align:center;padding-top:.5rem}

/* =====================================================
   WRITE FOR US
===================================================== */
.upload-wrap{padding:0 5rem 5rem}

.upload-box{
  background:linear-gradient(135deg,#F4845F 0%,#F2A7C3 55%,#F6C244 100%);
  border-radius:var(--r-lg);padding:3.5rem 4rem;color:var(--white);
  display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:start;
  box-shadow:0 20px 60px rgba(244,132,95,.26);position:relative;overflow:hidden;
}
.upload-box::before{content:'';position:absolute;top:-60px;right:-60px;width:200px;height:200px;background:rgba(255,255,255,.1);border-radius:50%}
.upload-box::after{content:'';position:absolute;bottom:-40px;left:30%;width:150px;height:150px;background:rgba(255,255,255,.07);border-radius:50%}

.ul-text h2{font-family:'Playfair Display',serif;font-size:2.1rem;margin-bottom:1rem;line-height:1.2}
.ul-text p{opacity:.92;line-height:1.75;margin-bottom:1rem;font-size:.96rem}

.ul-perks{display:flex;flex-direction:column;gap:.6rem;margin-top:1.4rem}
.ul-perk{display:flex;align-items:center;gap:10px;font-size:.87rem;font-weight:600;opacity:.92}
.ul-perk-icon{width:28px;height:28px;background:rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.78rem;flex-shrink:0}

.ul-form-wrap{
  background:var(--white);
  border-radius:var(--r-md);padding:2.2rem;border:1px solid rgba(244,132,95,.15);
  position:relative;z-index:1;box-shadow:var(--sh-md);
}
.fg{margin-bottom:1.1rem}
.fg label{display:block;font-size:.82rem;font-weight:700;margin-bottom:.42rem;color:var(--dark);}
.fg input,.fg select,.fg textarea{
  width:100%;padding:11px 14px;border-radius:var(--r-sm);
  border:1.5px solid rgba(244,132,95,.15);
  background:var(--cream);color:var(--dark);
  font-family:'Nunito',sans-serif;font-size:.9rem;outline:none;
  transition:border-color var(--ease),background var(--ease),box-shadow var(--ease);
}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--coral);background:var(--white);box-shadow:0 0 0 4px rgba(244,132,95,.12);}
.fg input::placeholder,.fg textarea::placeholder{color:var(--light);}
.fg select{cursor:pointer}
.fg select option{color:var(--dark);background:var(--white)}
.fg textarea{height:82px;resize:none}

.drop-zone{
  border:2px dashed rgba(244,132,95,.3);border-radius:var(--r-sm);
  padding:1.25rem;text-align:center;font-size:.84rem;font-weight:600;
  color:var(--dark);background:var(--cream);margin-bottom:1.1rem;cursor:pointer;line-height:1.8;
  transition:background var(--ease),border-color var(--ease);
}
.drop-zone:hover{background:rgba(244,132,95,.05);border-color:var(--coral);}
.drop-zone.over{background:rgba(244,132,95,.1);border-color:var(--coral-dk);}

.btn-white{
  background:var(--coral);color:var(--white);width:100%;
  padding:13px;border-radius:50px;font-weight:800;
  cursor:pointer;border:none;font-family:'Nunito',sans-serif;font-size:1rem;
  box-shadow:0 4px 16px rgba(244,132,95,.35);
  transition:transform var(--ease),box-shadow var(--ease),background var(--ease);
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(244,132,95,.46);background:var(--coral-dk);}

/* =====================================================
   ABOUT
===================================================== */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}

.about-avatar{
  width:260px;height:260px;
  border-radius:40% 60% 60% 40%/40% 40% 60% 60%;
  background:linear-gradient(135deg,var(--teal-lt),var(--coral-lt));
  display:flex;align-items:center;justify-content:center;font-size:6rem;
  animation:morph 9s ease-in-out infinite;box-shadow:var(--sh-md);
}
@keyframes morph{
  0%,100%{border-radius:40% 60% 60% 40%/40% 40% 60% 60%}
  25%     {border-radius:55% 45% 45% 55%/50% 55% 45% 50%}
  50%     {border-radius:60% 40% 40% 60%/60% 60% 40% 40%}
  75%     {border-radius:45% 55% 55% 45%/45% 45% 55% 55%}
}

.about-visual{display:flex;flex-direction:column;align-items:center;gap:2rem}

.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;width:100%}

.stat-box{
  background:var(--cream);border-radius:var(--r-md);padding:1.4rem;text-align:center;
  border:1px solid rgba(244,132,95,.10);transition:transform var(--ease),box-shadow var(--ease);
}
.stat-box:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
.stat-n{font-family:'Playfair Display',serif;font-size:2.1rem;color:var(--coral);font-weight:700;line-height:1}
.stat-l{font-size:.8rem;color:var(--mid);margin-top:4px;font-weight:600}

.about-content p{color:var(--mid);line-height:1.87;margin-bottom:1.3rem;font-size:1rem}

/* =====================================================
   NEWSLETTER
===================================================== */
.newsletter{
  text-align:center;padding:6rem 5rem;background:var(--cream);
  position:relative;overflow:hidden;
}
.newsletter::before{
  content:'';position:absolute;top:-80px;left:50%;transform:translateX(-50%);
  width:600px;height:600px;background:radial-gradient(circle,rgba(244,132,95,.06) 0%,transparent 70%);pointer-events:none;
}
.nl-box{max-width:580px;margin:0 auto;position:relative;z-index:1}
.nl-icon{font-size:3.5rem;margin-bottom:1rem;animation:wiggle 3.5s ease-in-out infinite}
@keyframes wiggle{0%,100%{transform:rotate(-6deg)}50%{transform:rotate(6deg)}}

.nl-form{display:flex;gap:.8rem;margin-top:1.8rem;max-width:480px;margin-left:auto;margin-right:auto}
.nl-form input{
  flex:1;padding:14px 22px;border-radius:50px;
  border:2px solid var(--coral-lt);background:var(--white);
  font-family:'Nunito',sans-serif;font-size:.98rem;outline:none;color:var(--text);
  transition:border-color var(--ease),box-shadow var(--ease);
}
.nl-form input:focus{border-color:var(--coral);box-shadow:0 0 0 4px rgba(244,132,95,.12)}
.nl-form input::placeholder{color:var(--light)}
.nl-note{font-size:.79rem;color:var(--light);margin-top:1rem}

/* =====================================================
   FOOTER
===================================================== */
footer{background:var(--dark);color:rgba(255,255,255,.62);padding:4rem 5rem 2.5rem}

.ft-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:3rem;margin-bottom:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.08)}

.ft-brand{font-family:'Playfair Display',serif;font-size:1.35rem;color:var(--white);margin-bottom:.9rem;font-weight:700}
.ft-tagline{font-size:.88rem;line-height:1.75;margin-bottom:1.5rem}

.ft-social{display:flex;gap:.8rem}
.soc-btn{
  width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;font-size:1rem;cursor:pointer;
  transition:background var(--ease),transform var(--ease);
}
.soc-btn:hover{background:var(--coral);transform:translateY(-2px)}

.ft-col h4{color:var(--white);font-size:.83rem;font-weight:800;margin-bottom:1.1rem;text-transform:uppercase;letter-spacing:.1em}
.ft-col li{margin-bottom:.65rem}
.ft-col a{color:rgba(255,255,255,.52);font-size:.88rem;font-weight:500;transition:color var(--ease)}
.ft-col a:hover{color:var(--coral)}

.ft-bottom{text-align:center;font-size:.83rem;color:rgba(255,255,255,.38)}
.ft-heart{color:var(--coral)}

/* =====================================================
   TOAST
===================================================== */
.toast{
  position:fixed;bottom:2rem;right:2rem;
  background:var(--dark);color:var(--white);
  padding:1rem 1.5rem;border-radius:var(--r-sm);
  box-shadow:var(--sh-lg);font-weight:600;font-size:.91rem;z-index:9999;
  display:flex;align-items:center;gap:10px;max-width:320px;
  transform:translateX(calc(100% + 3rem));
  opacity:0;
  pointer-events:none;
  transition:transform .4s cubic-bezier(.34,1.56,.64,1), opacity .4s ease;
}
.toast.show{
  transform:translateX(0);
  opacity:1;
  pointer-events:auto;
}
.toast.ok {border-left:4px solid var(--teal)}
.toast.err{border-left:4px solid var(--coral)}

/* =====================================================
   BACK TO TOP
===================================================== */
.back-top{
  position:fixed;bottom:2rem;left:2rem;
  width:44px;height:44px;background:var(--coral);color:var(--white);
  border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;box-shadow:var(--sh-md);cursor:pointer;
  opacity:0;transform:translateY(20px);
  transition:opacity var(--ease),transform var(--ease),background var(--ease);z-index:500;
}
.back-top.visible{opacity:1;transform:translateY(0)}
.back-top:hover{background:var(--coral-dk)}

/* =====================================================
   SCROLL REVEAL
===================================================== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

.hero-text   {animation:fadeUp .9s cubic-bezier(.4,0,.2,1) both}
.hero-visual {animation:fadeUp .9s cubic-bezier(.4,0,.2,1) .18s both}
@keyframes fadeUp{from{opacity:0;transform:translateY(38px)}to{opacity:1;transform:translateY(0)}}

/* =====================================================
   RESPONSIVE
===================================================== */
@media(max-width:1200px){
  .topics-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:1024px){
  .hero{padding:4rem 3rem;gap:3rem}
  .hero h1{font-size:3rem}
  .section{padding:5rem 3rem}
  .upload-wrap{padding:0 3rem 4rem}
  .upload-box{padding:3rem;gap:2.5rem}
  footer{padding:3rem 3rem 2rem}
  .newsletter{padding:5rem 3rem}
}
@media(max-width:900px){
  nav{padding:0 1.5rem}
  .nav-links{display:none}
  .hamburger{display:flex}
  .mobile-nav{display:flex}

  .hero{grid-template-columns:1fr;padding:3rem 2rem 4rem;min-height:auto;gap:2rem;}
  .hero-visual{display:flex; margin-top:2rem;}
  .hero-bg1,.hero-bg2{display:none}
  .hero h1{font-size:2.55rem}

  .blog-grid{grid-template-columns:1fr 1fr}
  .section{padding:4rem 2rem}
  .sec-title{font-size:2rem}
  .upload-wrap{padding:0 2rem 3rem}
  .upload-box{grid-template-columns:1fr;padding:2.5rem 2rem;gap:2rem}
  .about-grid{grid-template-columns:1fr}
  .about-visual{order:-1}
  .ft-grid{grid-template-columns:1fr;gap:2rem}
  footer{padding:3rem 2rem 2rem}
  .newsletter{padding:4rem 2rem}
  .nl-form{flex-direction:column}
  .scroll-cue{display:none}
}
@media(max-width:600px){
  .hero h1{font-size:2.1rem}
  .hero-sub{font-size:.98rem}
  
  /* Hero Badge Fix */
  .hero-badge{
    font-size:0.6rem;
    padding:6px 10px;
    white-space:nowrap;
    width:100%;
    justify-content:center;
    letter-spacing:0;
  }
  
  /* Hero Buttons Fix */
  .hero-btns{
    flex-wrap:nowrap;
    gap:0.6rem;
    width:100%;
  }
  .hero-btns .btn{
    flex:1;
    padding:12px 5px;
    font-size:0.85rem;
    justify-content:center;
  }

  /* Hero Cards Fix */
  .hero-visual { margin-top: 2rem; width: 100%; }
  .card-stack{
    display: grid;
    grid-template-columns: 1fr 1fr;
    width:100%;
    max-width: 100%;
    gap:10px;
  }
  .hcard{
    padding:1.1rem 0.8rem;
    transform: none !important;
  }
  .hcard:hover {
    transform: translateY(-4px) !important;
  }
  .hc-icon{font-size:1.5rem;margin-bottom:0.3rem;}
  .hc-title{font-size:0.85rem; line-height:1.2;}
  .hc-desc{font-size:0.75rem;line-height:1.3;}
  
  .blog-grid{grid-template-columns:1fr}
  .topics-grid{grid-template-columns:1fr}
  .stat-grid{grid-template-columns:1fr 1fr}
  .section{padding:3rem 1.5rem}
  .upload-wrap{padding:0 1.5rem 3rem}
  footer{padding:2.5rem 1.5rem 2rem}
  .newsletter{padding:3rem 1.5rem}
  .toast{left:1rem;right:1rem;bottom:1rem}
  .back-top{bottom:1rem;left:1rem}
}

/* -- BANNER BACKGROUNDS -- */
.banner-books { background: linear-gradient(rgba(61,44,44,0.6), rgba(61,44,44,0.6)), url('images/books_banner.png') center/cover no-repeat; color: white !important; }
.banner-child { background: linear-gradient(rgba(61,44,44,0.5), rgba(61,44,44,0.5)), url('images/child_psychology_banner.png') center/cover no-repeat; color: white !important; }
.banner-relationships { background: linear-gradient(rgba(61,44,44,0.6), rgba(61,44,44,0.6)), url('images/relationships_banner.png') center/cover no-repeat; color: white !important; }
.banner-growth { background: linear-gradient(rgba(61,44,44,0.5), rgba(61,44,44,0.5)), url('images/personal_growth_banner.png') center/cover no-repeat; color: white !important; }
.banner-all { background: linear-gradient(rgba(61,44,44,0.5), rgba(61,44,44,0.5)), url('images/all_blogs_banner.png') center/cover no-repeat; color: white !important; }

.archive-header.has-banner .sec-label { color: rgba(255,255,255,0.9); }
.archive-header.has-banner .sec-title { color: white; }
.archive-header.has-banner .sec-sub { color: rgba(255,255,255,0.85); text-shadow: 0 2px 4px rgba(0,0,0,0.5); }



/* =====================================================
   GLOBAL LOADER (FRONTEND)
===================================================== */
.site-loader {
  position: fixed;
  top: 0; left: 0; width: 100%; height: 100%;
  background: rgba(253, 248, 242, 0.75);
  backdrop-filter: blur(4px);
  z-index: 999999;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  transition: opacity 0.4s ease, visibility 0.4s ease;
}
.site-loader.hidden {
  opacity: 0;
  visibility: hidden;
}
.site-loader-spinner {
  width: 48px;
  height: 48px;
  margin: auto;
  position: relative;
}
.site-loader-spinner:before {
  content: '';
  width: 48px;
  height: 5px;
  background: #f0808050;
  position: absolute;
  top: 60px;
  left: 0;
  border-radius: 50%;
  animation: shadow324 0.5s linear infinite;
}
.site-loader-spinner:after {
  content: '';
  width: 100%;
  height: 100%;
  background: #f08080;
  position: absolute;
  top: 0;
  left: 0;
  border-radius: 4px;
  animation: jump7456 0.5s linear infinite;
}
@keyframes jump7456 {
  15% { border-bottom-right-radius: 3px; }
  25% { transform: translateY(9px) rotate(22.5deg); }
  50% { transform: translateY(18px) scale(1, .9) rotate(45deg); border-bottom-right-radius: 40px; }
  75% { transform: translateY(9px) rotate(67.5deg); }
  100% { transform: translateY(0) rotate(90deg); }
}
@keyframes shadow324 {
  0%, 100% { transform: scale(1, 1); }
  50% { transform: scale(1.2, 1); }
}
.site-loader-text {
  margin-top: 20px;
  font-family: 'Playfair Display', serif;
  color: var(--dark);
  font-size: 1.2rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  animation: fade-text 1.5s ease-in-out infinite alternate;
}
@keyframes fade-text {
  0% { opacity: 0.6; }
  100% { opacity: 1; }
}

.banner-contact { background: linear-gradient(rgba(61,44,44,0.5), rgba(61,44,44,0.5)), url('images/contact_banner.png') center/cover no-repeat; color: white !important; }
