/* ===== RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:80px;overflow-x:hidden}
body{font-family:'Segoe UI',Tahoma,Geneva,Verdana,sans-serif;line-height:1.72;color:#2e2e2e;background:#fefcfa;-webkit-font-smoothing:antialiased;overflow-x:hidden;position:relative}

/* ===== SCROLL LOCK ===== */
body.no-scroll{overflow:hidden;height:100%;touch-action:none}
body.no-scroll .site-header{position:fixed}

/* ===== SKIP LINK ===== */
.skip-link{position:absolute;top:-100%;left:16px;background:#5b4a8a;color:#fff;padding:8px 18px;border-radius:0 0 8px 8px;z-index:9999;font-size:.95rem;text-decoration:none;transition:top .3s ease}
.skip-link:focus{top:0}

/* ===== COLORS / TOKENS ===== */
:root{
  --clr-bg:#fefcfa;
  --clr-surface:#fff;
  --clr-surface-alt:#fdf6ef;
  --clr-primary:#6b52a3;
  --clr-primary-dark:#4a3878;
  --clr-primary-light:#ece5f6;
  --clr-accent:#f09a5e;
  --clr-accent-light:#fef0df;
  --clr-teal:#4eb5a5;
  --clr-teal-light:#ddf5f0;
  --clr-rose:#e06878;
  --clr-rose-light:#fde7ea;
  --clr-yellow:#f5c842;
  --clr-yellow-light:#fef8e0;
  --clr-text:#2a2a2e;
  --clr-text-mid:#555;
  --clr-text-light:#888;
  --clr-border:#ebe3da;
  --radius:16px;
  --radius-sm:10px;
  --shadow:0 4px 20px rgba(107,82,163,.07);
  --shadow-lg:0 12px 40px rgba(107,82,163,.12);
  --max-w:1120px;
  --header-h:64px;
  --transition:all .4s cubic-bezier(.25,.8,.25,1);
}

/* ===== TYPOGRAPHY ===== */
h1,h2,h3,h4{font-weight:700;color:var(--clr-primary);line-height:1.22}
h1{font-size:clamp(2rem,5vw,3rem)}
h2{font-size:clamp(1.5rem,3.5vw,2.2rem);margin-bottom:.6em}
h3{font-size:clamp(1.05rem,2vw,1.35rem);margin-bottom:.4em}
p{margin-bottom:1em;color:var(--clr-text-mid)}
a{color:var(--clr-primary);text-decoration:none;transition:var(--transition)}
a:hover{color:var(--clr-accent)}
strong{color:var(--clr-text)}
ul,ol{padding-left:1.4em;margin-bottom:1em}
li{margin-bottom:.35em}

/* ===== FOCUS ===== */
:focus-visible{outline:3px solid var(--clr-accent);outline-offset:3px;border-radius:6px}

/* ===== LAYOUT ===== */
.container{width:92%;max-width:var(--max-w);margin:0 auto}

/* ===== FLOATING CONFETTI (CSS only) ===== */
body::before,body::after{content:'';position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0}
body::before{
  background:
    radial-gradient(3px 3px at 10% 15%, var(--clr-accent) 50%, transparent 50%),
    radial-gradient(2px 2px at 25% 35%, var(--clr-rose) 50%, transparent 50%),
    radial-gradient(3px 3px at 40% 8%, var(--clr-teal) 50%, transparent 50%),
    radial-gradient(2px 2px at 55% 45%, var(--clr-yellow) 50%, transparent 50%),
    radial-gradient(3px 3px at 70% 20%, var(--clr-primary-light) 50%, transparent 50%),
    radial-gradient(2px 2px at 85% 55%, var(--clr-rose) 50%, transparent 50%),
    radial-gradient(2px 2px at 15% 70%, var(--clr-accent) 50%, transparent 50%),
    radial-gradient(3px 3px at 90% 85%, var(--clr-teal) 50%, transparent 50%);
  background-size:100% 100%;
  opacity:.3;
  animation:confettiDrift 25s linear infinite alternate;
}
@keyframes confettiDrift{
  from{transform:translateY(0) rotate(0)}
  to{transform:translateY(-30px) rotate(1deg)}
}

/* ===== HEADER (FIXED) ===== */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:500;
  height:var(--header-h);
  display:flex;align-items:center;
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(107,82,163,.08);
  box-shadow:0 2px 20px rgba(107,82,163,.06);
  transition:background .4s ease,box-shadow .4s ease;
}
.site-header.scrolled{
  background:rgba(255,255,255,.96);
  box-shadow:0 4px 30px rgba(107,82,163,.1);
}
.site-header .container{display:flex;align-items:center;justify-content:space-between}
.logo{font-size:1.25rem;font-weight:800;color:var(--clr-primary);letter-spacing:-.02em;position:relative;z-index:2;flex-shrink:0}
.logo span{color:var(--clr-accent);transition:var(--transition)}
.logo:hover span{color:var(--clr-rose)}

/* NAV */
.main-nav{display:flex;align-items:center;gap:3px}
.main-nav a{
  font-size:.76rem;padding:6px 10px;border-radius:20px;font-weight:500;
  color:var(--clr-text-mid);white-space:nowrap;position:relative;
  transition:var(--transition);
}
.main-nav a::after{
  content:'';position:absolute;bottom:2px;left:50%;width:0;height:2px;
  background:var(--clr-accent);border-radius:2px;
  transition:width .35s cubic-bezier(.25,.8,.25,1),left .35s cubic-bezier(.25,.8,.25,1);
}
.main-nav a:hover::after,.main-nav a.active::after{width:60%;left:20%}
.main-nav a:hover{color:var(--clr-primary);background:var(--clr-primary-light)}
.main-nav a.active{color:var(--clr-primary);font-weight:700;background:var(--clr-primary-light)}
.main-nav a[data-page]{margin-left:6px;padding-left:14px;border-left:2px solid var(--clr-border)}
.main-nav a[data-page].active{background:var(--clr-accent);color:#fff;border-left-color:var(--clr-accent);border-radius:20px}
.main-nav a[data-page].active::after{background:transparent}

/* BURGER */
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;z-index:600;position:relative}
.burger span{display:block;width:22px;height:2px;background:var(--clr-primary);border-radius:2px;transition:var(--transition)}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);background:var(--clr-rose)}
.burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);background:var(--clr-rose)}

/* MOBILE OVERLAY */
.nav-overlay{
  position:fixed;top:0;left:0;right:0;bottom:0;
  background:rgba(42,42,46,.4);z-index:498;
  opacity:0;visibility:hidden;
  transition:opacity .4s ease,visibility .4s ease;
  backdrop-filter:blur(4px);
}
.nav-overlay.visible{opacity:1;visibility:visible}

/* BODY SPACER for fixed header */
main{padding-top:var(--header-h)}

/* ===== HERO ===== */
.hero{
  padding:70px 0 60px;text-align:center;position:relative;overflow:hidden;
  background:linear-gradient(170deg,#fef8f2 0%,#ece5f6 40%,#ddf5f0 70%,#fef0df 100%);
}
.hero::before{
  content:'';position:absolute;top:-80px;right:-60px;width:300px;height:300px;
  border-radius:50%;opacity:.3;z-index:0;
  background:radial-gradient(circle,var(--clr-accent-light) 0%,transparent 70%);
  animation:floatBubble 8s ease-in-out infinite;
}
.hero::after{
  content:'';position:absolute;bottom:-50px;left:-40px;width:240px;height:240px;
  border-radius:50%;opacity:.35;z-index:0;
  background:radial-gradient(circle,var(--clr-teal-light) 0%,transparent 70%);
  animation:floatBubble 10s ease-in-out infinite reverse;
}
@keyframes floatBubble{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(15px,-20px) scale(1.05)}
  66%{transform:translate(-10px,10px) scale(.97)}
}
.hero .container{position:relative;z-index:1}
.hero h1{margin-bottom:.3em;animation:fadeSlideUp .8s ease both}
.hero h1 .accent{color:var(--clr-accent);display:inline-block;animation:gentleBounce 3s ease-in-out infinite}
.hero .subtitle{font-size:clamp(1rem,2vw,1.15rem);color:var(--clr-text-mid);max-width:640px;margin:0 auto 1.5em;animation:fadeSlideUp .8s .15s ease both}
@keyframes gentleBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
@keyframes fadeSlideUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

/* ===== GARLAND decoration ===== */
.garland-deco{
  position:absolute;top:0;left:0;right:0;height:32px;z-index:2;pointer-events:none;overflow:hidden;
}
.garland-deco svg{width:100%;height:32px}

/* ===== SECTIONS ===== */
.section{padding:72px 0;position:relative}
.section:nth-child(even){background:linear-gradient(180deg,var(--clr-surface-alt) 0%,#fefcfa 100%)}
.section:nth-child(odd){background:linear-gradient(180deg,#fefcfa 0%,var(--clr-surface-alt) 100%)}
.section-header{text-align:center;margin-bottom:2.8em}
.section-header h2{position:relative;display:inline-block}
.section-header h2::after{
  content:'';display:block;width:50px;height:4px;
  background:linear-gradient(90deg,var(--clr-accent),var(--clr-rose));
  border-radius:4px;margin:12px auto 0;
  transition:width .5s cubic-bezier(.25,.8,.25,1);
}
.section-header h2:hover::after{width:90px}
.section-header p{max-width:600px;margin:0 auto}

/* ===== TEXT + IMAGE LAYOUT ===== */
.text-with-image{display:flex;gap:32px;align-items:center;margin:2em 0}
.text-with-image--reverse{flex-direction:row-reverse}
.text-with-image .text-side{flex:1;min-width:0}
.text-with-image .image-side{flex:0 0 280px;max-width:280px}
.text-with-image .image-side img{width:100%;height:auto;border-radius:var(--radius);display:block;box-shadow:var(--shadow);transition:var(--transition)}
.text-with-image .image-side img:hover{transform:scale(1.03);box-shadow:var(--shadow-lg)}

/* ===== CONTACT PAGE SECTION ===== */
.contact-section{padding:100px 0 50px}
.contact-intro{text-align:center;margin-bottom:2.5em}
.contact-intro h1{margin-bottom:.4em}
.contact-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}

/* FORM AS STANDALONE ELEMENT */
.contact-form-section{padding:60px 0 80px;background:linear-gradient(170deg,var(--clr-surface-alt) 0%,#fefcfa 100%)}
.form-wrapper{
  max-width:640px;margin:0 auto;
  background:var(--clr-surface);
  border:1px solid var(--clr-border);
  border-radius:var(--radius);
  padding:44px 40px;
  box-shadow:var(--shadow-lg);
  position:relative;overflow:hidden;
}
.form-wrapper::before{
  content:'';position:absolute;top:0;left:0;right:0;height:5px;
  background:linear-gradient(90deg,var(--clr-primary),var(--clr-accent),var(--clr-teal));
}
.form-header{text-align:center;margin-bottom:2em}
.form-header h2{margin-bottom:.3em}
.form-header p{max-width:440px;margin:0 auto;font-size:.92rem}
@media(max-width:600px){
  .form-wrapper{padding:30px 22px}
}

/* ===== PLACEHOLDER ILLUSTRATIONS ===== */
.illust-panel{
  width:100%;max-width:480px;margin:2em auto;aspect-ratio:16/9;
  background:linear-gradient(135deg,var(--clr-primary-light),var(--clr-accent-light),var(--clr-teal-light));
  border-radius:var(--radius);display:flex;align-items:center;justify-content:center;
  overflow:hidden;position:relative;
  box-shadow:var(--shadow);transition:var(--transition);
}
.illust-panel:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.illust-panel svg{width:60%;height:60%;opacity:.5;transition:var(--transition)}
.illust-panel:hover svg{opacity:.7;transform:scale(1.05)}

/* ===== CARD GRID ===== */
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.card{
  background:var(--clr-surface);border:1px solid var(--clr-border);
  border-radius:var(--radius);padding:28px 24px;position:relative;overflow:hidden;
  transition:var(--transition);
}
.card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--clr-primary),var(--clr-accent),var(--clr-teal));
  transform:scaleX(0);transform-origin:left;
  transition:transform .5s cubic-bezier(.25,.8,.25,1);
}
.card:hover::before{transform:scaleX(1)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.card h3{display:flex;align-items:center;gap:10px}
.card-icon{
  width:40px;height:40px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:var(--transition);
}
.card:hover .card-icon{transform:rotate(-8deg) scale(1.1)}
.card-icon svg{width:18px;height:18px}
.card-icon--purple{background:var(--clr-primary-light)}
.card-icon--orange{background:var(--clr-accent-light)}
.card-icon--teal{background:var(--clr-teal-light)}
.card-icon--rose{background:var(--clr-rose-light)}

/* ===== AGE TABS ===== */
.age-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:2em;justify-content:center}
.age-tab{
  padding:10px 24px;border:2px solid var(--clr-border);border-radius:28px;
  background:var(--clr-surface);cursor:pointer;font-size:.9rem;font-weight:600;
  color:var(--clr-text-mid);transition:var(--transition);
}
.age-tab:hover{border-color:var(--clr-primary);transform:translateY(-2px);color:var(--clr-primary)}
.age-tab[aria-selected="true"]{background:var(--clr-primary);color:#fff;border-color:var(--clr-primary);box-shadow:0 4px 15px rgba(107,82,163,.25)}
.age-content{display:none}
.age-content.active{display:block;animation:fadeSlideUp .5s ease}

/* ===== SCENARIO BUILDER ===== */
.builder{
  background:linear-gradient(145deg,#fff,var(--clr-primary-light));
  border:2px solid var(--clr-border);border-radius:var(--radius);
  padding:40px 36px;max-width:760px;margin:2em auto 0;
  box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.builder::before{
  content:'';position:absolute;top:-30px;right:-30px;width:120px;height:120px;
  background:var(--clr-accent-light);border-radius:50%;opacity:.5;
}
.builder::after{
  content:'';position:absolute;bottom:-20px;left:-20px;width:80px;height:80px;
  background:var(--clr-teal-light);border-radius:50%;opacity:.4;
}
.builder>*{position:relative;z-index:1}
.builder-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.builder label{display:block;font-weight:600;font-size:.88rem;margin-bottom:6px;color:var(--clr-text)}
.builder select,.builder input[type="number"]{
  width:100%;padding:11px 14px;border:2px solid var(--clr-border);
  border-radius:var(--radius-sm);font-size:.95rem;background:#fff;color:var(--clr-text);
  transition:var(--transition);
}
.builder select:focus,.builder input:focus{border-color:var(--clr-primary);outline:none;box-shadow:0 0 0 4px rgba(107,82,163,.12)}
.builder-btn{
  display:inline-block;padding:13px 36px;
  background:linear-gradient(135deg,var(--clr-primary),var(--clr-primary-dark));
  color:#fff;border:none;border-radius:28px;font-size:1rem;font-weight:600;cursor:pointer;
  transition:var(--transition);box-shadow:0 4px 15px rgba(107,82,163,.25);
}
.builder-btn:hover{transform:translateY(-3px);box-shadow:0 8px 25px rgba(107,82,163,.3)}
.builder-btn:active{transform:translateY(0)}
.builder-result{
  margin-top:24px;padding:24px;
  background:rgba(255,255,255,.9);border-radius:var(--radius-sm);
  border-left:4px solid var(--clr-accent);display:none;
}
.builder-result.visible{display:block;animation:fadeSlideUp .5s ease}
.builder-result h4{color:var(--clr-accent);margin-bottom:.6em}

/* ===== FAQ ===== */
.faq-list{max-width:760px;margin:0 auto}
.faq-item{
  border:1px solid var(--clr-border);border-radius:var(--radius-sm);
  margin-bottom:10px;overflow:hidden;background:var(--clr-surface);
  transition:var(--transition);
}
.faq-item:hover{border-color:var(--clr-primary-light);box-shadow:var(--shadow)}
.faq-btn{
  width:100%;text-align:left;padding:18px 22px;background:none;border:none;
  cursor:pointer;font-size:1rem;font-weight:600;color:var(--clr-text);
  display:flex;justify-content:space-between;align-items:center;
  transition:var(--transition);
}
.faq-btn:hover{background:var(--clr-primary-light);color:var(--clr-primary)}
.faq-btn::after{
  content:'+';font-size:1.4rem;color:var(--clr-primary);font-weight:300;
  display:flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:50%;background:var(--clr-primary-light);
  transition:var(--transition);flex-shrink:0;
}
.faq-item.open .faq-btn::after{transform:rotate(45deg);background:var(--clr-rose-light);color:var(--clr-rose)}
.faq-answer{max-height:0;overflow:hidden;padding:0 22px;transition:max-height .45s cubic-bezier(.25,.8,.25,1),padding-top .45s ease,padding-bottom .45s ease}
.faq-item.open .faq-answer{padding:4px 22px 18px}
.faq-item.open{border-color:var(--clr-primary);box-shadow:var(--shadow)}
.faq-answer p{margin-bottom:.5em}

/* ===== SENSITIVITY SECTION ===== */
.info-box{
  display:flex;gap:20px;padding:26px;
  background:linear-gradient(135deg,var(--clr-teal-light),rgba(255,255,255,.6));
  border-radius:var(--radius);margin-bottom:20px;align-items:flex-start;
  border:1px solid rgba(78,181,165,.15);
  transition:var(--transition);
}
.info-box:hover{transform:translateX(6px);box-shadow:var(--shadow)}
.info-box-icon{
  width:46px;height:46px;border-radius:14px;
  background:linear-gradient(135deg,var(--clr-teal),#3aa08f);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  box-shadow:0 4px 12px rgba(78,181,165,.25);
}
.info-box-icon svg{width:20px;height:20px;fill:#fff}

/* ===== FOOTER ===== */
.site-footer{
  background:linear-gradient(170deg,#2e2a3a 0%,#1e1a2a 100%);
  color:#bbb;padding:52px 0 24px;position:relative;overflow:hidden;
}
.site-footer::before{
  content:'';position:absolute;top:-50px;right:-50px;width:200px;height:200px;
  background:radial-gradient(circle,rgba(107,82,163,.1),transparent 70%);border-radius:50%;
}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-col h4{color:#fff;font-size:.95rem;margin-bottom:1em;text-transform:uppercase;letter-spacing:.06em}
.footer-col p{font-size:.88rem;line-height:1.65}
.footer-col a{color:#b8b0d0;font-size:.88rem;display:block;margin-bottom:.6em;transition:var(--transition);padding-left:0}
.footer-col a:hover{color:#fff;padding-left:6px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:20px;text-align:center;font-size:.82rem;color:#666}

/* ===== COOKIE BANNER ===== */
.cookie-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:9000;
  background:rgba(255,255,255,.96);backdrop-filter:blur(12px);
  border-top:1px solid var(--clr-border);
  box-shadow:0 -6px 30px rgba(0,0,0,.08);
  padding:20px 0;
  transform:translateY(100%);transition:transform .5s cubic-bezier(.25,.8,.25,1);
  display:none;
}
.cookie-banner.visible{display:block;transform:translateY(0)}
.cookie-banner .container{display:flex;flex-wrap:wrap;align-items:center;gap:16px}
.cookie-text{flex:1;min-width:240px;font-size:.88rem;color:var(--clr-text-mid)}
.cookie-text a{text-decoration:underline}
.cookie-actions{display:flex;flex-wrap:wrap;gap:8px}
.cookie-btn{
  padding:10px 22px;border-radius:24px;font-size:.85rem;font-weight:600;cursor:pointer;
  border:1px solid var(--clr-border);transition:var(--transition);
  background:var(--clr-surface);color:var(--clr-text);
}
.cookie-btn--accept{background:linear-gradient(135deg,var(--clr-primary),var(--clr-primary-dark));color:#fff;border-color:var(--clr-primary)}
.cookie-btn--accept:hover{transform:translateY(-2px);box-shadow:0 4px 15px rgba(107,82,163,.2)}
.cookie-btn--reject:hover,.cookie-btn--settings:hover{background:var(--clr-surface-alt);transform:translateY(-2px)}

/* COOKIE SETTINGS PANEL */
.cookie-settings{display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:9500;background:rgba(0,0,0,.45);backdrop-filter:blur(4px)}
.cookie-settings.visible{display:flex;align-items:center;justify-content:center}
.cookie-panel{background:var(--clr-surface);border-radius:var(--radius);padding:32px;max-width:520px;width:92%;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:fadeSlideUp .4s ease}
.cookie-panel h3{margin-bottom:1em}
.cookie-category{padding:16px 0;border-bottom:1px solid var(--clr-border)}
.cookie-category:last-child{border-bottom:none}
.cookie-cat-header{display:flex;justify-content:space-between;align-items:center}
.cookie-cat-header strong{font-size:.95rem}
.cookie-toggle{position:relative;width:48px;height:26px;border-radius:13px;background:var(--clr-border);cursor:pointer;border:none;transition:var(--transition)}
.cookie-toggle.active{background:var(--clr-primary)}
.cookie-toggle::after{content:'';position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 4px rgba(0,0,0,.15);transition:var(--transition)}
.cookie-toggle.active::after{transform:translateX(22px)}
.cookie-toggle.disabled{opacity:.5;cursor:default}
.cookie-cat-desc{font-size:.82rem;color:var(--clr-text-light);margin-top:4px}
.cookie-panel-actions{display:flex;gap:10px;margin-top:20px;justify-content:flex-end}

/* ===== FORM ===== */
.contact-form{max-width:580px;margin:0 auto}
.form-group{margin-bottom:22px}
.form-group label{display:block;font-weight:600;font-size:.9rem;margin-bottom:8px;color:var(--clr-text)}
.form-group input,.form-group textarea{
  width:100%;padding:13px 18px;border:2px solid var(--clr-border);
  border-radius:var(--radius-sm);font-size:.95rem;font-family:inherit;
  transition:var(--transition);background:var(--clr-surface);
}
.form-group input:focus,.form-group textarea:focus{border-color:var(--clr-primary);outline:none;box-shadow:0 0 0 4px rgba(107,82,163,.1)}
.form-group textarea{min-height:130px;resize:vertical}
.form-group .error-msg{font-size:.82rem;color:var(--clr-rose);margin-top:4px;display:none}
.form-group.has-error input,.form-group.has-error textarea{border-color:var(--clr-rose)}
.form-group.has-error .error-msg{display:block}
.consent-group{display:flex;gap:10px;align-items:flex-start;margin-bottom:20px}
.consent-group input[type="checkbox"]{margin-top:4px;width:18px;height:18px;accent-color:var(--clr-primary);flex-shrink:0}
.consent-group label{font-size:.85rem;color:var(--clr-text-mid);font-weight:400}
.form-response{margin-top:16px;padding:16px 20px;border-radius:var(--radius-sm);font-size:.9rem;display:none;animation:fadeSlideUp .4s ease}
.form-response.success{display:block;background:var(--clr-teal-light);color:#2a7a6c;border:1px solid var(--clr-teal)}
.form-response.error{display:block;background:var(--clr-rose-light);color:#a04450;border:1px solid var(--clr-rose)}
.hn-field{position:absolute;left:-9999px;opacity:0;height:0;width:0;overflow:hidden;tab-index:-1}

/* SUBMIT BTN */
.submit-btn{
  display:inline-block;padding:13px 40px;
  background:linear-gradient(135deg,var(--clr-primary),var(--clr-primary-dark));
  color:#fff;border:none;border-radius:28px;font-size:1rem;font-weight:600;cursor:pointer;
  transition:var(--transition);box-shadow:0 4px 15px rgba(107,82,163,.2);
}
.submit-btn:hover{transform:translateY(-3px);box-shadow:0 8px 25px rgba(107,82,163,.3)}
.submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}

/* ===== LEGAL PAGES ===== */
.legal-page{padding:100px 0 60px}
.legal-page h1{margin-bottom:1em}
.legal-page h2{font-size:1.3rem;margin-top:2em;margin-bottom:.5em}
.legal-page p,.legal-page li{font-size:.95rem;line-height:1.7}

/* ===== SITE MAP PAGE ===== */
.sitemap-list{list-style:none;padding:0}
.sitemap-list li{margin-bottom:.6em}
.sitemap-list a{font-size:1.05rem;font-weight:500;transition:var(--transition)}
.sitemap-list a:hover{padding-left:8px;color:var(--clr-accent)}

/* ===== 404 ===== */
.page-404{min-height:70vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:60px 20px}
.page-404 h1{font-size:clamp(3rem,8vw,6rem);color:var(--clr-accent);margin-bottom:.2em}
.page-404 p{font-size:1.1rem;margin-bottom:1.5em}
.btn-home{
  display:inline-block;padding:13px 32px;
  background:linear-gradient(135deg,var(--clr-primary),var(--clr-primary-dark));
  color:#fff;border-radius:28px;font-weight:600;
  transition:var(--transition);box-shadow:0 4px 15px rgba(107,82,163,.2);
}
.btn-home:hover{transform:translateY(-3px);box-shadow:0 8px 25px rgba(107,82,163,.3);color:#fff}

/* ===== REVEAL ANIMATIONS ===== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s cubic-bezier(.25,.8,.25,1),transform .7s cubic-bezier(.25,.8,.25,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-40px);transition:opacity .7s cubic-bezier(.25,.8,.25,1),transform .7s cubic-bezier(.25,.8,.25,1)}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(40px);transition:opacity .7s cubic-bezier(.25,.8,.25,1),transform .7s cubic-bezier(.25,.8,.25,1)}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-scale{opacity:0;transform:scale(.92);transition:opacity .6s ease,transform .6s cubic-bezier(.25,.8,.25,1)}
.reveal-scale.visible{opacity:1;transform:scale(1)}

/* stagger children */
.card-grid .card:nth-child(1){transition-delay:.05s}
.card-grid .card:nth-child(2){transition-delay:.15s}
.card-grid .card:nth-child(3){transition-delay:.25s}

/* ===== REDUCED MOTION ===== */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.15s !important;scroll-behavior:auto !important}
  .reveal,.reveal-left,.reveal-right,.reveal-scale{opacity:1;transform:none}
  body::before{animation:none;opacity:.15}
}

/* ===== RESPONSIVE ===== */
@media(max-width:900px){
  .footer-grid{grid-template-columns:1fr}
  .builder-row{grid-template-columns:1fr}
}

@media(max-width:768px){
  .main-nav{
    position:fixed;top:0;right:0;width:280px;height:100vh;height:100dvh;
    background:rgba(255,255,255,.98);backdrop-filter:blur(16px);
    flex-direction:column;padding:calc(var(--header-h) + 20px) 28px 28px;
    box-shadow:-10px 0 40px rgba(0,0,0,.1);
    transform:translateX(100%);
    transition:transform .45s cubic-bezier(.25,.8,.25,1);
    z-index:499;overflow-y:auto;gap:4px;
  }
  .main-nav.open{transform:translateX(0)}
  .main-nav a{font-size:.95rem;padding:10px 14px;border-radius:var(--radius-sm)}
  .main-nav a::after{display:none}
  .main-nav a[data-page]{border-left:none;margin-left:0;padding-left:14px;border-top:1px solid var(--clr-border);margin-top:10px;padding-top:14px}
  .burger{display:flex}
  .hero{padding:50px 0 40px}
  .section{padding:48px 0}
  .cookie-banner .container{flex-direction:column;text-align:center}
  .text-with-image,.text-with-image--reverse{flex-direction:column}
  .text-with-image .image-side{flex:none;max-width:240px;margin:0 auto}
}

@media(max-width:480px){
  .builder{padding:24px 18px}
  .card{padding:22px 18px}
  .hero h1{font-size:1.8rem}
  .main-nav{width:100%}
}
