
/* style.css - Magical, dreamy, child-friendly and professional */
/* Fonts: Nunito (friendly) and Poppins (professional) */
/* Keep styles lightweight and well-commented for customization */

:root{
  --bg1: #f7f5ff;
  --accent1: #c8a2ff;
  --accent2: #aee2ff;
  --accent3: #ffd7e2;
  --soft: #f2f6ff;
  --muted: #6b6b7a;
  --glass: rgba(255,255,255,0.55);
  --card-shadow: 0 8px 20px rgba(18,12,48,0.06);
  --glass-border: rgba(255,255,255,0.7);
  --max-width: 1200px;
  --radius: 14px;
}

/* GLOBAL */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: 'Nunito', system-ui, -apple-system, 'Segoe UI', Roboto, 'Poppins', sans-serif;
  background: linear-gradient(180deg, #fdfcfb 0%, #f1f7ff 100%);
  color:#232129;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}

/* CONTAINER */
.container{
  width:calc(100% - 40px);
  max-width:var(--max-width);
  margin:0 auto;
  padding:60px 20px;
}

/* HEADER */
.site-header{
  position:sticky;
  top:0;
  z-index:60;
  backdrop-filter: blur(6px);
  background:linear-gradient(90deg, rgba(255,255,255,0.6), rgba(255,255,255,0.35));
  border-bottom:1px solid rgba(200,200,255,0.08);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:12px 20px;
}
.brand a{font-weight:700; text-decoration:none; color:#262233; font-family:'Poppins'; display:flex; align-items:center; gap:8px;}
.logo-star{transform:rotate(-10deg); font-size:20px; filter:drop-shadow(0 4px 8px rgba(198,162,255,0.25));}
.main-nav{display:flex; gap:12px; align-items:center;}
.main-nav a{color:var(--muted); text-decoration:none; padding:8px 12px; border-radius:10px; font-weight:600;}
.main-nav a.cta{background:linear-gradient(90deg,var(--accent1),var(--accent2)); color:white; box-shadow:0 6px 18px rgba(160,120,245,0.18); padding:10px 14px;}
#nav-toggle{display:none; background:none; border:none; font-size:20px;}

/* HERO */
.hero{position:relative; min-height:70vh; display:flex; align-items:center; justify-content:center; padding:0; overflow:hidden;}
.hero-bg{
  position:absolute; inset:0;
  background:linear-gradient(135deg, rgba(199,156,255,0.12), rgba(174,226,255,0.08));
  animation: bgShift 12s ease-in-out infinite alternate;
  filter:blur(18px) saturate(105%);
  z-index:0;
}
@keyframes bgShift{
  0%{transform:translateY(0) scale(1)}
  100%{transform:translateY(-20px) scale(1.02)}
}
.hero-content{position:relative; z-index:2; text-align:center; padding:80px 20px; color:#1f1830;}
.hero-title{font-family:'Poppins'; font-size:clamp(26px,5vw,44px); margin:0 0 12px; line-height:1.05;}
.typewriter{display:inline-block; position:relative; white-space:nowrap; overflow:hidden; border-right:3px solid rgba(0,0,0,0.08); animation: typing 4s steps(48,end), blink 800ms steps(1,end) infinite;}
@keyframes typing{from{width:0} to{width:100%}}
@keyframes blink{50%{border-color:transparent}}
.hero-sub{color:var(--muted); margin-bottom:22px; max-width:760px; margin-left:auto; margin-right:auto;}
.hero-actions{display:flex; gap:12px; justify-content:center; margin-top:12px;}
.btn{display:inline-flex; align-items:center; gap:8px; padding:12px 18px; border-radius:12px; text-decoration:none; font-weight:700; cursor:pointer; transition:transform .18s ease, box-shadow .18s ease; box-shadow:var(--card-shadow);}
.btn.primary{background:linear-gradient(90deg,var(--accent1),var(--accent2)); color:white; border:none;}
.btn.ghost{background:transparent; border:1px solid rgba(10,10,20,0.04); color:var(--muted);}
.btn.soft{background:linear-gradient(90deg,#fffdf8,#f8fbff); color:#2b2540;}

/* Magical CTA pulse on hover */
.btn-magic{position:relative; overflow:visible;}
.btn-magic::after{content:''; position:absolute; inset:-6px; border-radius:14px; background:radial-gradient(circle at 20% 20%, rgba(255,255,255,0.06), transparent 30%), radial-gradient(circle at 80% 80%, rgba(255,255,255,0.04), transparent 35%); opacity:0; transform:scale(0.9); transition:opacity .25s ease, transform .25s ease;}
.btn-magic:hover::after{opacity:1; transform:scale(1);}
.btn-magic:active{transform:translateY(1px);}

/* Floating icons */
.floating-icons{position:absolute; inset:auto 10% 10% auto; display:flex; gap:12px; z-index:3; pointer-events:none;}
.float{font-size:26px; transform-origin:center; animation: floaty 6s ease-in-out infinite; opacity:.9;}
.float:nth-child(2){animation-duration:5s; transform:translateY(4px) rotate(6deg) scale(.95);}
@keyframes floaty{0%{transform:translateY(0)}50%{transform:translateY(-12px)}100%{transform:translateY(0)}}

/* SECTIONS */
.section{padding:80px 0;}

/* About */
.about-grid{display:grid; grid-template-columns:1fr 1.3fr; gap:24px; align-items:center;}
.about-image .portrait{width:180px; height:180px; border-radius:20px; background:linear-gradient(180deg,#fff,#fff5ff); display:flex; align-items:center; justify-content:center; font-size:54px; box-shadow:var(--card-shadow); border:1px solid var(--glass-border);}
.about-text h2{margin-top:0;}
.about-text p{color:var(--muted); line-height:1.6;}

/* CARDS GRID */
.cards-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:18px; margin-top:26px;}
.card{background:linear-gradient(180deg, rgba(255,255,255,0.8), rgba(255,255,255,0.65)); padding:20px; border-radius:14px; box-shadow:var(--card-shadow); transition:transform .25s ease, box-shadow .25s ease, filter .25s ease; border:1px solid rgba(255,255,255,0.6); position:relative; overflow:hidden;}
.card:hover{transform:translateY(-8px) scale(1.02); box-shadow:0 18px 40px rgba(18,12,48,0.09); filter:drop-shadow(0 6px 18px rgba(160,120,245,0.06));}
.card .card-emoji{font-size:28px; margin-bottom:8px; display:inline-block;}
.card h3{margin:0 0 6px;font-size:18px;}
.card p{margin:0; color:var(--muted)}

/* Pricing Grid */
.pricing-grid{display:flex; gap:18px; flex-wrap:wrap; margin-top:18px;}
.price-card{flex:1 1 200px; padding:22px; border-radius:14px; background:linear-gradient(180deg,#fff,#fffefb); box-shadow:var(--card-shadow); border:1px solid rgba(200,180,255,0.12); text-align:center; position:relative; transition:transform .2s ease;}
.price-card:hover{transform:translateY(-6px);}
.badge{position:absolute; top:12px; right:12px; background:linear-gradient(90deg,var(--accent3),var(--accent1)); color:#2b1e34; padding:6px 10px; border-radius:999px; font-weight:700; font-size:13px; box-shadow:0 6px 16px rgba(160,120,245,0.08);}
.badge.sale{background:linear-gradient(90deg,#fff2f9,#ffd7e2); color:#6b2460;}
.price-card.highlight{border:2px solid rgba(166,102,255,0.18); box-shadow:0 20px 40px rgba(166,102,255,0.06); transform:none;}
.price-card.glow{box-shadow:0 18px 40px rgba(255,200,220,0.08), 0 6px 12px rgba(180,100,255,0.06);}

/* Reviews carousel */
.review-carousel{display:flex; gap:12px; align-items:center; position:relative; margin-top:20px;}
.reviews-track{flex:1; display:flex; gap:14px; overflow:hidden;}
.review-card{min-width:100%; flex-shrink:0; padding:20px; border-radius:12px; background:linear-gradient(180deg,#fff,#fbfbff); box-shadow:var(--card-shadow); border:1px solid rgba(200,200,255,0.06); transition:transform .3s ease;}
.review-card .quote{font-style:italic; color:#341b4a;}
.review-card .meta{margin-top:12px; color:var(--muted); font-weight:700; display:flex; justify-content:space-between; align-items:center;}
.review-nav{background:transparent; border:none; font-size:28px; cursor:pointer; padding:6px 12px; opacity:.9;}
.review-card:hover{transform:translateY(-6px)}

/* CONTACT FORM */
.contact-form{max-width:820px; margin-top:18px;}
.form-row{display:flex; flex-direction:column; gap:8px; margin-bottom:14px;}
.form-row label{font-weight:700; font-size:14px;}
.form-row input, .form-row textarea, .form-row select{padding:12px 14px; border-radius:10px; border:1px solid rgba(10,10,20,0.06); outline:none; font-size:15px; background:linear-gradient(180deg,#fff,#fffefa); transition:box-shadow .18s ease, transform .12s ease;}

/* focus glow */
.form-row input:focus, .form-row textarea:focus, .form-row select:focus{box-shadow:0 8px 30px rgba(160,120,245,0.12); transform:translateY(-2px); border-color:rgba(160,120,245,0.22);}

/* Submit sparkle */
.submit-row .btn-magic{position:relative;}
.submit-row .btn-magic::before{content:''; position:absolute; top:-8px; right:-8px; width:10px; height:10px; border-radius:3px; background:linear-gradient(90deg,#fff,#ffd7e2); transform:rotate(25deg); opacity:.9; filter:blur(6px);}

/* FOOTER */
.site-footer{padding:22px 0; background:linear-gradient(180deg,#fff,#f8f8ff); border-top:1px solid rgba(200,200,255,0.06);}
.footer-inner{display:flex; gap:12px; justify-content:space-between; align-items:center; font-size:14px; color:var(--muted)}

/* Reveal animation utility */
.reveal{opacity:0; transform:translateY(16px); transition:opacity .6s ease, transform .6s ease;}
.reveal.revealed{opacity:1; transform:none;}

/* RESPONSIVE */
@media (max-width:900px){
  .about-grid{grid-template-columns:1fr; text-align:center}
  .floating-icons{display:none}
  .main-nav{display:none}
  #nav-toggle{display:block}
}
@media (max-width:520px){
  .hero-content{padding:40px 18px}
  .container{padding:40px 16px}
}


/* FIXED REVIEW CAROUSEL */
.reviews-carousel {
  overflow: hidden;
  width: 100%;
}

.reviews-track {
  display: flex;
  flex-wrap: nowrap;
  transition: transform 0.6s ease;
}

.review-card {
  min-width: 100%;
  box-sizing: border-box;
}


/* ✨ Magical Sparkle Overlay */
.reviews-carousel {
  position: relative;
}
.reviews-carousel::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: radial-gradient(circle, rgba(255,255,255,0.7) 0%, transparent 60%);
  background-size: 6px 6px;
  animation: sparkle-move 6s linear infinite;
  opacity: 0.4;
}

@keyframes sparkle-move {
  0% { background-position: 0 0; }
  100% { background-position: 200px 200px; }
}

/* ✨ Fade + Slide hybrid animation */
.reviews-track {
  transition: transform 0.8s ease, opacity 0.8s ease;
}
.review-card {
  min-width: 100%;
  opacity: 0;
  transition: opacity 0.8s ease;
}
.review-card.active {
  opacity: 1;
}

/* Slight glowing border for magic */
.review-card {
  border-radius: 14px;
  border: 2px solid rgba(255,255,255,0.3);
  box-shadow: 0 0 20px rgba(255,255,255,0.3);
}


/* 🌟 Star Cursor */
body {
  cursor: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" height="32" width="32"><text y="50%" x="50%" text-anchor="middle" dominant-baseline="middle" font-size="24">✨</text></svg>') 16 16, auto;
}

/* ☁ Floating dreamy clouds in background */
.magic-clouds {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  pointer-events: none;
  z-index: -1;
  background-image: url('https://i.imgur.com/IEpYt8F.png');
  background-size: cover;
  opacity: 0.18;
  animation: cloudFloat 40s linear infinite;
}

@keyframes cloudFloat {
  0% { transform: translateX(0); }
  100% { transform: translateX(-300px); }
}

/* ✨ Card hover starburst */
.review-card:hover {
  box-shadow: 0 0 30px rgba(255,255,255,0.6);
  position: relative;
}

.review-card:hover::after {
  content: "✨";
  position: absolute;
  top: -10px;
  right: -10px;
  font-size: 24px;
  animation: sparklePop 0.6s ease forwards;
}

@keyframes sparklePop {
  0% { opacity: 0; transform: scale(0.2) rotate(0deg); }
  100% { opacity: 1; transform: scale(1.4) rotate(25deg); }
}


/* ⭐ Magical Cursor Trail */
body {
  cursor: url('https://cur.cursors-4u.net/symbols/sym-9/sym899.cur'), auto;
}

/* Floating Stars */
.floating-star {
  position: fixed;
  width: 8px;
  height: 8px;
  background: radial-gradient(circle, #fff, rgba(255,255,255,0));
  border-radius: 50%;
  pointer-events: none;
  animation: starFloat 6s linear infinite;
  z-index: 9999;
  opacity: 0.7;
}

@keyframes starFloat {
  0% { transform: translateY(0) scale(1); opacity: 0.7; }
  100% { transform: translateY(-200px) scale(0.3); opacity: 0; }
}

/* Soft Cloud Background behind reviews */
.reviews-section {
  position: relative;
  overflow: visible;
}

.reviews-section::before {
  content: "";
  position: absolute;
  top: -50px;
  left: 0;
  right: 0;
  height: 180px;
  background: url('https://i.ibb.co/SVfJLTx/clouds-soft.png') repeat-x;
  background-size: contain;
  opacity: 0.35;
  animation: cloudsMove 40s linear infinite;
  pointer-events: none;
}

@keyframes cloudsMove {
  from { background-position: 0 0; }
  to { background-position: 1000px 0; }
}

/* Confetti sparkle on hover */
.review-card:hover {
  box-shadow: 0 0 30px rgba(255,255,255,0.6), 0 0 60px rgba(255,200,255,0.4);
}
