/* =========================================================
   Kidz Distrikt — design system
   Paleta extrasa din logo (culorile alese de client)
   ========================================================= */
:root{
  --blue:        #184878;   /* bleumarin primar (wordmark) */
  --blue-deep:   #0c3c78;   /* hover / accente adanci */
  --blue-ink:    #12324f;   /* text titluri */
  --sky:         #a8c0e4;   /* bleu periwinkle */
  --sky-soft:    #a8ccd8;   /* bleu-gri soft */
  --sand:        #e4c084;   /* auriu-nisip */
  --peach:       #efc3a0;   /* piersica */
  --cream:       #fbf6ee;   /* fundal cald */
  --cream-2:     #f5ece0;   /* fundal cald 2 */
  --white:       #ffffff;
  --text:        #33414f;   /* corp text */
  --muted:       #6b7683;

  --maxw: 1180px;
  --radius: 28px;
  --radius-sm: 16px;
  --shadow: 0 18px 50px -24px rgba(18,50,79,.35);
  --shadow-soft: 0 10px 30px -18px rgba(18,50,79,.30);
  --ease: cubic-bezier(.22,.61,.36,1);

  --font-display: "Fredoka", system-ui, sans-serif;
  --font-body: "Nunito", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--text);
  background:var(--cream);
  line-height:1.7;
  font-size:clamp(16px,1.02vw,18px);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:var(--blue); text-decoration:none; }

h1,h2,h3,h4{
  font-family:var(--font-display);
  color:var(--blue-ink);
  line-height:1.12;
  margin:0 0 .5em;
  font-weight:600;
}
h2{ font-size:clamp(1.9rem,3.6vw,2.9rem); }
h3{ font-size:clamp(1.25rem,2vw,1.6rem); }
.eyebrow{
  font-family:var(--font-display);
  font-weight:600;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-size:.78rem;
  color:var(--blue);
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  margin-bottom:1rem;
}
.eyebrow::before{ content:""; width:26px; height:2px; background:var(--sand); border-radius:2px; }

.container{ width:min(100% - 2.4rem, var(--maxw)); margin-inline:auto; }
.section{ padding:clamp(4rem,9vw,7.5rem) 0; position:relative; }
.section--tint{ background:var(--cream-2); }
.lead{ font-size:clamp(1.05rem,1.5vw,1.2rem); color:var(--muted); }
.center{ text-align:center; }
.center .eyebrow{ justify-content:center; }
.mx-narrow{ max-width:720px; margin-inline:auto; }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--blue); --fg:#fff;
  display:inline-flex; align-items:center; gap:.55rem;
  background:var(--bg); color:var(--fg);
  font-family:var(--font-display); font-weight:500; font-size:1rem;
  padding:.85rem 1.5rem; border-radius:100px; border:2px solid var(--bg);
  cursor:pointer; transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .2s;
  box-shadow:0 10px 24px -14px rgba(24,72,120,.9);
}
.btn:hover{ transform:translateY(-3px); box-shadow:0 16px 30px -14px rgba(24,72,120,.9); background:var(--blue-deep); border-color:var(--blue-deep); }
.btn--ghost{ --bg:transparent; --fg:var(--blue); box-shadow:none; }
.btn--ghost:hover{ background:var(--blue); --fg:#fff; }
.btn--sand{ --bg:var(--sand); --fg:var(--blue-ink); box-shadow:0 10px 24px -14px rgba(228,192,132,1); }
.btn--sand:hover{ background:#d9b06a; border-color:#d9b06a; }
.btn--lg{ padding:1rem 1.9rem; font-size:1.08rem; }

/* ---------- Header ---------- */
.header{
  position:fixed; inset:0 0 auto 0; z-index:50;
  transition:background .3s, box-shadow .3s, padding .3s;
  padding:1.1rem 0;
}
.header.scrolled{ background:rgba(251,246,238,.9); backdrop-filter:blur(12px); box-shadow:0 6px 24px -18px rgba(18,50,79,.5); padding:.6rem 0; }
.nav{ display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.brand{ display:flex; align-items:center; gap:.6rem; }
.brand img{ height:46px; width:auto; transition:height .3s; }
.header.scrolled .brand img{ height:40px; }
.nav-links{ display:flex; align-items:center; gap:.35rem; list-style:none; margin:0; padding:0; }
.nav-links a{
  font-family:var(--font-display); font-weight:500; color:var(--blue-ink);
  padding:.5rem .8rem; border-radius:100px; font-size:.98rem; transition:background .2s,color .2s;
}
.nav-links a:hover{ background:var(--white); color:var(--blue); }
.nav-cta{ margin-left:.4rem; }
.burger{ display:none; background:none; border:0; cursor:pointer; padding:.4rem; }
.burger span{ display:block; width:26px; height:2.5px; background:var(--blue-ink); border-radius:3px; margin:5px 0; transition:.3s; }

/* ---------- Hero ---------- */
.hero{ position:relative; padding:clamp(7rem,14vw,10rem) 0 clamp(3rem,7vw,6rem); overflow:hidden; }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.hero h1{ font-size:clamp(2.6rem,6vw,4.4rem); font-weight:600; letter-spacing:-.01em; }
.hero h1 .accent{ position:relative; white-space:nowrap; }
.hero h1 .accent::after{
  content:""; position:absolute; left:-2%; right:-2%; bottom:.06em; height:.32em; z-index:-1;
  background:var(--sand); border-radius:100px; opacity:.65;
}
.hero p{ font-size:clamp(1.08rem,1.6vw,1.28rem); color:var(--muted); max-width:34ch; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:.8rem; margin-top:1.8rem; }
.hero-badges{ display:flex; gap:1.4rem; margin-top:2.2rem; flex-wrap:wrap; }
.hero-badges .b{ display:flex; align-items:center; gap:.5rem; font-weight:700; color:var(--blue-ink); font-size:.95rem; }
.hero-badges .b svg{ width:22px; height:22px; color:var(--blue); flex:0 0 auto; }

.hero-visual{ position:relative; }
.hero-photo{
  position:relative; border-radius:46% 54% 58% 42%/48% 44% 56% 52%;
  overflow:hidden; box-shadow:var(--shadow); aspect-ratio:4/4.4;
  animation:morph 14s ease-in-out infinite alternate;
}
.hero-photo img{ width:100%; height:100%; object-fit:cover; }
@keyframes morph{
  0%{ border-radius:46% 54% 58% 42%/48% 44% 56% 52%; }
  100%{ border-radius:58% 42% 46% 54%/56% 58% 42% 44%; }
}
.blob{ position:absolute; border-radius:50%; filter:blur(2px); opacity:.55; z-index:-1; }
.blob-1{ width:200px; height:200px; background:var(--sky); top:-30px; right:-20px; }
.blob-2{ width:150px; height:150px; background:var(--peach); bottom:-20px; left:-30px; }
.float-chip{
  position:absolute; background:var(--white); border-radius:18px; padding:.6rem .9rem;
  box-shadow:var(--shadow-soft); font-family:var(--font-display); font-weight:600; color:var(--blue-ink);
  display:flex; align-items:center; gap:.5rem; font-size:.9rem; animation:floaty 5s ease-in-out infinite;
}
.float-chip .dot{ width:12px; height:12px; border-radius:50%; }
.chip-a{ top:8%; left:-6%; } .chip-a .dot{ background:var(--sand); }
.chip-b{ bottom:12%; right:-8%; animation-delay:1.5s; } .chip-b .dot{ background:var(--sky-soft); }
@keyframes floaty{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-12px); } }

/* wave divider */
.wave{ display:block; width:100%; height:auto; margin-bottom:-6px; }

/* ---------- Cards: cele 3 relatii ---------- */
.cards-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; margin-top:2.5rem; }
.rel-card{
  background:var(--white); border-radius:var(--radius); padding:2rem 1.7rem;
  box-shadow:var(--shadow-soft); border:1px solid rgba(24,72,120,.06);
  transition:transform .3s var(--ease), box-shadow .3s;
}
.rel-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.rel-icon{ width:58px; height:58px; border-radius:18px; display:grid; place-items:center; margin-bottom:1.1rem; }
.rel-icon svg{ width:30px; height:30px; color:var(--blue); }
.i-sky{ background:#e6eefa; } .i-peach{ background:#faece0; } .i-sand{ background:#f7edd6; }
.rel-card h3{ margin-bottom:.3rem; }
.rel-card p{ margin:0; color:var(--muted); font-size:.98rem; }

/* ---------- Despre split ---------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
.split--rev .split-media{ order:2; }
.split-media{ position:relative; }
.split-media img{ border-radius:var(--radius); box-shadow:var(--shadow); width:100%; aspect-ratio:4/3.4; object-fit:cover; }
.split-media .tag{
  position:absolute; bottom:-18px; left:-18px; background:var(--sand); color:var(--blue-ink);
  font-family:var(--font-display); font-weight:600; padding:.7rem 1.1rem; border-radius:16px; box-shadow:var(--shadow-soft);
}
.pill-list{ list-style:none; padding:0; margin:1.6rem 0 0; display:grid; gap:1rem; }
.pill-list li{ display:flex; gap:.9rem; align-items:flex-start; }
.pill-list .num{
  flex:0 0 auto; width:38px; height:38px; border-radius:12px; background:var(--white); color:var(--blue);
  font-family:var(--font-display); font-weight:600; display:grid; place-items:center; box-shadow:var(--shadow-soft);
}
.pill-list h4{ margin:.15rem 0 .1rem; font-size:1.08rem; }
.pill-list p{ margin:0; color:var(--muted); font-size:.96rem; }

/* ---------- Abordare / modele ---------- */
.models{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.4rem; margin-top:2.2rem; }
.model-card{
  background:var(--white); border-radius:var(--radius); padding:2rem; box-shadow:var(--shadow-soft);
  border-top:5px solid var(--sand);
}
.model-card:nth-child(2){ border-top-color:var(--sky); }
.model-card h3{ display:flex; align-items:center; gap:.6rem; }
.model-card p{ margin:.4rem 0 0; color:var(--muted); }
.wheel-wrap{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,4vw,3.5rem); align-items:center; margin-top:3rem; }
.wheel-wrap img{ border-radius:var(--radius); }

/* ---------- Domenii (5) ---------- */
.domenii{ display:grid; grid-template-columns:repeat(auto-fit,minmax(190px,1fr)); gap:1.2rem; margin-top:2.5rem; }
.dom{
  background:var(--white); border-radius:var(--radius-sm); padding:1.7rem 1.4rem; box-shadow:var(--shadow-soft);
  transition:transform .3s var(--ease); position:relative; overflow:hidden;
}
.dom:hover{ transform:translateY(-5px); }
.dom .n{ font-family:var(--font-display); font-weight:600; color:var(--sky); font-size:2.2rem; line-height:1; opacity:.55; }
.dom h4{ margin:.6rem 0 .35rem; font-size:1.12rem; }
.dom p{ margin:0; font-size:.92rem; color:var(--muted); }

/* ---------- Program & taxe ---------- */
.prog-grid{ display:grid; grid-template-columns:1fr 1fr; gap:1.4rem; margin-top:2.5rem; }
.grup-card{ background:var(--white); border-radius:var(--radius); padding:2rem; box-shadow:var(--shadow-soft); }
.grup-card .age{ font-family:var(--font-display); font-weight:600; color:var(--blue); font-size:1.05rem; }
.grup-card h3{ margin:.2rem 0 .8rem; }
.grup-card .hours{ display:inline-flex; align-items:center; gap:.5rem; background:var(--cream-2); padding:.4rem .9rem; border-radius:100px; font-weight:700; color:var(--blue-ink); font-size:.95rem; }
.tax-wrap{ margin-top:2.5rem; background:var(--blue); color:#fff; border-radius:var(--radius); padding:clamp(1.8rem,4vw,2.8rem); box-shadow:var(--shadow); }
.tax-wrap h3{ color:#fff; }
.tax-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; margin-top:1.4rem; }
.tax{ background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.16); border-radius:var(--radius-sm); padding:1.5rem; text-align:center; transition:transform .3s var(--ease), background .3s; }
.tax:hover{ transform:translateY(-5px); background:rgba(255,255,255,.14); }
.tax .name{ font-family:var(--font-display); font-weight:500; opacity:.9; }
.tax .price{ font-family:var(--font-display); font-weight:600; font-size:2.4rem; margin:.3rem 0; }
.tax .price small{ font-size:1rem; opacity:.8; font-weight:400; }
.tax-note{ margin-top:1.4rem; font-size:.9rem; opacity:.85; }
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; margin-top:2.5rem; counter-reset:s; }
.step{ text-align:center; padding:1.5rem; }
.step .circle{ width:64px; height:64px; margin:0 auto 1rem; border-radius:50%; background:var(--peach); color:var(--blue-ink); font-family:var(--font-display); font-weight:600; font-size:1.5rem; display:grid; place-items:center; }
.step:nth-child(2) .circle{ background:var(--sky); } .step:nth-child(3) .circle{ background:var(--sand); }
.step h4{ margin:.2rem 0 .3rem; } .step p{ margin:0; color:var(--muted); font-size:.95rem; }

/* ---------- Galerie ---------- */
.gallery{ columns:3; column-gap:1rem; margin-top:2.5rem; }
.gallery figure{ margin:0 0 1rem; break-inside:avoid; border-radius:var(--radius-sm); overflow:hidden; box-shadow:var(--shadow-soft); cursor:pointer; position:relative; }
.gallery img{ width:100%; transition:transform .6s var(--ease); }
.gallery figure:hover img{ transform:scale(1.06); }
.gallery figure::after{ content:"⤢"; position:absolute; inset:auto .7rem .6rem auto; color:#fff; opacity:0; transition:.3s; font-size:1.2rem; text-shadow:0 2px 8px rgba(0,0,0,.5); }
.gallery figure:hover::after{ opacity:1; }

/* ---------- Instagram ---------- */
.ig-head{ display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap; }
.ig-handle{ display:inline-flex; align-items:center; gap:.6rem; font-family:var(--font-display); font-weight:600; color:var(--blue-ink); font-size:1.15rem; }
.ig-handle svg{ width:26px; height:26px; }
.ig-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:.8rem; margin-top:2rem; }
.ig-grid a{ position:relative; border-radius:var(--radius-sm); overflow:hidden; aspect-ratio:1; box-shadow:var(--shadow-soft); }
.ig-grid img{ width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); }
.ig-grid a:hover img{ transform:scale(1.08); }
.ig-grid a::before{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 55%,rgba(24,72,120,.55)); opacity:0; transition:.3s; z-index:1; }
.ig-grid a::after{
  content:""; position:absolute; inset:auto .6rem .6rem auto; width:22px; height:22px; z-index:2; opacity:0; transition:.3s;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='white' viewBox='0 0 24 24'%3E%3Cpath d='M7 2h10a5 5 0 0 1 5 5v10a5 5 0 0 1-5 5H7a5 5 0 0 1-5-5V7a5 5 0 0 1 5-5zm0 2a3 3 0 0 0-3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3-3V7a3 3 0 0 0-3-3H7zm5 3.5A4.5 4.5 0 1 1 7.5 12 4.5 4.5 0 0 1 12 7.5zm0 2A2.5 2.5 0 1 0 14.5 12 2.5 2.5 0 0 0 12 9.5zM17.5 6a1 1 0 1 1-1 1 1 1 0 0 1 1-1z'/%3E%3C/svg%3E") center/contain no-repeat;
}
.ig-grid a:hover::before, .ig-grid a:hover::after{ opacity:1; }
.ig-note{ margin-top:1.5rem; text-align:center; font-size:.9rem; color:var(--muted); }

/* ---------- Contact ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,4vw,3.5rem); margin-top:2.5rem; align-items:start; }
.contact-info{ display:grid; gap:1.2rem; }
.ci{ display:flex; gap:1rem; align-items:flex-start; }
.ci .ic{ flex:0 0 auto; width:48px; height:48px; border-radius:14px; background:var(--white); display:grid; place-items:center; box-shadow:var(--shadow-soft); }
.ci .ic svg{ width:24px; height:24px; color:var(--blue); }
.ci h4{ margin:0 0 .1rem; font-size:1.05rem; }
.ci a,.ci p{ margin:0; color:var(--muted); }
.ci a:hover{ color:var(--blue); }
.map-frame{ border:0; width:100%; height:100%; min-height:340px; border-radius:var(--radius); box-shadow:var(--shadow); }
.contact-form{ display:grid; gap:1rem; background:var(--white); padding:clamp(1.6rem,3vw,2.4rem); border-radius:var(--radius); box-shadow:var(--shadow-soft); }
.field{ display:grid; gap:.35rem; }
.field label{ font-family:var(--font-display); font-weight:500; font-size:.92rem; color:var(--blue-ink); }
.field input,.field textarea{ font-family:var(--font-body); font-size:1rem; padding:.8rem 1rem; border:1.5px solid #e4dccf; border-radius:12px; background:var(--cream); color:var(--text); transition:border .2s; }
.field input:focus,.field textarea:focus{ outline:0; border-color:var(--blue); }
.form-2{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }

/* ---------- CTA band ---------- */
.cta-band{ background:linear-gradient(135deg,var(--blue),var(--blue-deep)); color:#fff; border-radius:var(--radius); padding:clamp(2.5rem,6vw,4rem); text-align:center; box-shadow:var(--shadow); position:relative; overflow:hidden; }
.cta-band h2{ color:#fff; }
.cta-band p{ color:rgba(255,255,255,.85); max-width:50ch; margin-inline:auto; }
.cta-band .btn{ margin-top:1.5rem; }
.cta-band .deco{ position:absolute; border-radius:50%; opacity:.14; }
.cta-band .d1{ width:220px; height:220px; background:var(--sand); top:-60px; left:-40px; }
.cta-band .d2{ width:180px; height:180px; background:var(--sky); bottom:-50px; right:-30px; }

/* ---------- Footer ---------- */
.footer{ background:var(--blue-ink); color:#cdd7e2; padding:clamp(3rem,6vw,4.5rem) 0 2rem; }
.footer-grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:2.5rem; }
.footer h4{ color:#fff; font-size:1.05rem; margin-bottom:1rem; }
.footer a{ color:#cdd7e2; }
.footer a:hover{ color:var(--sand); }
.footer ul{ list-style:none; padding:0; margin:0; display:grid; gap:.5rem; }
.footer .brand-f img{ height:52px; margin-bottom:1rem; background:#fff; padding:.4rem .7rem; border-radius:14px; }
.footer .socials{ display:flex; gap:.7rem; margin-top:1rem; }
.footer .socials a{ width:42px; height:42px; border-radius:12px; background:rgba(255,255,255,.08); display:grid; place-items:center; transition:.2s; }
.footer .socials a:hover{ background:var(--sand); }
.footer .socials svg{ width:20px; height:20px; color:#fff; }
.footer-bottom{ margin-top:2.5rem; padding-top:1.5rem; border-top:1px solid rgba(255,255,255,.1); font-size:.88rem; display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; color:#9fb0c2; }

/* ---------- Lightbox ---------- */
.lb{ position:fixed; inset:0; z-index:100; background:rgba(12,24,40,.92); display:none; place-items:center; padding:2rem; }
.lb.open{ display:grid; }
.lb img{ max-width:92vw; max-height:88vh; border-radius:12px; box-shadow:0 30px 80px rgba(0,0,0,.6); }
.lb .close{ position:absolute; top:1.2rem; right:1.5rem; background:none; border:0; color:#fff; font-size:2.4rem; cursor:pointer; line-height:1; }
.lb .nav-btn{ position:absolute; top:50%; transform:translateY(-50%); background:rgba(255,255,255,.12); border:0; color:#fff; width:52px; height:52px; border-radius:50%; font-size:1.6rem; cursor:pointer; transition:.2s; }
.lb .nav-btn:hover{ background:rgba(255,255,255,.25); }
.lb .prev{ left:1.5rem; } .lb .next{ right:1.5rem; }

/* ---------- Reveal on scroll ---------- */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.1s; }
.reveal[data-d="2"]{ transition-delay:.2s; }
.reveal[data-d="3"]{ transition-delay:.3s; }

/* ---------- Responsive ---------- */
@media (max-width:960px){
  .hero-grid{ grid-template-columns:1fr; }
  .hero-visual{ max-width:460px; margin:0 auto; }
  .hero p{ max-width:none; }
  .split{ grid-template-columns:1fr; }
  .split--rev .split-media{ order:0; }
  .cards-3,.models,.prog-grid,.tax-grid,.steps,.contact-grid,.wheel-wrap,.footer-grid{ grid-template-columns:1fr; }
  .gallery{ columns:2; }
  .ig-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:720px){
  .nav-links{
    position:fixed; inset:0 0 0 auto; width:min(80vw,320px); background:var(--cream);
    flex-direction:column; align-items:stretch; justify-content:center; gap:.4rem; padding:2rem;
    transform:translateX(100%); transition:transform .35s var(--ease); box-shadow:-10px 0 40px -20px rgba(0,0,0,.4);
  }
  .nav-links.open{ transform:none; }
  .nav-links a{ font-size:1.15rem; padding:.7rem 1rem; }
  .burger{ display:block; z-index:60; }
  .nav-open .burger span:nth-child(1){ transform:translateY(7.5px) rotate(45deg); }
  .nav-open .burger span:nth-child(2){ opacity:0; }
  .nav-open .burger span:nth-child(3){ transform:translateY(-7.5px) rotate(-45deg); }
  .tax-grid{ grid-template-columns:1fr; }
  .form-2{ grid-template-columns:1fr; }
  .footer-bottom{ flex-direction:column; }
}
@media (max-width:460px){
  .gallery{ columns:1; }
  .ig-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; scroll-behavior:auto; }
  .reveal{ opacity:1; transform:none; }
}
