/* ============================================================
   Compliments for Change — Master Design System
   "The happiest place on the internet."
   Brand: Navy + Red anchor  ·  Joyful accent palette
   ============================================================ */

/* ---------- Design Tokens ---------- */
:root{
  /* Brand anchors (from the logo) */
  --navy:#16335b;
  --navy-700:#1e3f6f;
  --navy-500:#2a538c;
  --red:#e0313f;
  --red-600:#c9202e;

  /* Joyful accent palette */
  --sunshine:#ffc23c;
  --sunshine-soft:#ffe08a;
  --sky:#4cc9f0;
  --sky-soft:#bdeafc;
  --mint:#25c9a0;
  --mint-soft:#b6efdd;
  --coral:#ff7a68;
  --coral-soft:#ffc7bd;
  --peach:#ffb27a;
  --lavender:#a78be0;
  --lavender-soft:#e2d7fb;
  --pink:#ff8fb1;

  /* Neutrals */
  --ink:#22314a;          /* primary text */
  --ink-soft:#54627a;     /* secondary text */
  --ink-faint:#8a97ab;
  --cream:#fff9f0;
  --paper:#ffffff;
  --line:#eef1f6;

  /* Surfaces / gradients */
  --sky-wash:linear-gradient(180deg,#eaf7ff 0%, #fff6ef 55%, #fff9f0 100%);
  --sunrise:linear-gradient(135deg,#ffe08a 0%, #ffb27a 45%, #ff8fb1 100%);
  --dawn:linear-gradient(120deg,#4cc9f0 0%, #a78be0 55%, #ff8fb1 100%);
  --brand-grad:linear-gradient(120deg,var(--navy) 0%, var(--navy-500) 100%);

  /* Type */
  --font-display:'Fredoka', 'Trebuchet MS', system-ui, sans-serif;
  --font-body:'Nunito', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-hand:'Caveat', 'Comic Sans MS', cursive;

  /* Shape & depth */
  --r-sm:12px;
  --r-md:20px;
  --r-lg:30px;
  --r-xl:44px;
  --r-pill:999px;
  --shadow-sm:0 4px 16px rgba(22,51,91,.07);
  --shadow-md:0 14px 40px rgba(22,51,91,.10);
  --shadow-lg:0 30px 70px rgba(22,51,91,.16);
  --shadow-glow:0 18px 50px rgba(255,138,101,.28);
  --ring:0 0 0 4px rgba(76,201,240,.35);

  --wrap:1180px;
  --gap:clamp(1.2rem,3vw,2.2rem);
  --ease:cubic-bezier(.22,.9,.3,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-size:clamp(1rem,.55vw + .9rem,1.12rem);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none}
ul{margin:0;padding:0;list-style:none}
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.08;margin:0;color:var(--navy);font-weight:600;letter-spacing:-.01em}
p{margin:0 0 1rem}
:focus-visible{outline:none;box-shadow:var(--ring);border-radius:8px}
::selection{background:var(--sunshine-soft);color:var(--navy)}

/* ---------- Layout helpers ---------- */
.wrap{width:min(var(--wrap),92vw);margin-inline:auto}
.narrow{width:min(760px,92vw);margin-inline:auto}
.section{padding:clamp(3.5rem,7vw,6.5rem) 0;position:relative}
.center{text-align:center}
.stack>*+*{margin-top:1rem}
.grid{display:grid;gap:var(--gap)}
.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--font-display);font-weight:600;font-size:.82rem;
  letter-spacing:.14em;text-transform:uppercase;color:var(--red);
  background:#fff;border:1px solid var(--line);padding:.45rem 1rem;
  border-radius:var(--r-pill);box-shadow:var(--shadow-sm);
}
.eyebrow.on-dark{color:var(--sunshine);background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.18)}
.section-title{font-size:clamp(2rem,4.4vw,3.3rem);margin:1rem 0 .6rem}
.section-lead{font-size:clamp(1.05rem,1.4vw,1.3rem);color:var(--ink-soft);max-width:60ch}
.center .section-lead{margin-inline:auto}
.text-grad{background:var(--sunrise);-webkit-background-clip:text;background-clip:text;color:transparent}
.hand{font-family:var(--font-hand);color:var(--coral);font-weight:700}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--red);--fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--font-display);font-weight:600;font-size:1.02rem;
  padding:.9rem 1.7rem;border-radius:var(--r-pill);
  background:var(--bg);color:var(--fg);
  box-shadow:0 10px 24px rgba(224,49,63,.28);
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .2s;
  will-change:transform;
}
.btn:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 18px 34px rgba(224,49,63,.34)}
.btn:active{transform:translateY(-1px) scale(.99)}
.btn .btn-emoji{font-size:1.15em;line-height:1}
.btn-sun{--bg:linear-gradient(120deg,var(--sunshine),var(--peach));--fg:var(--navy);box-shadow:0 10px 24px rgba(255,178,122,.4)}
.btn-sun:hover{box-shadow:0 18px 34px rgba(255,178,122,.5)}
.btn-navy{--bg:var(--brand-grad);box-shadow:0 10px 24px rgba(22,51,91,.28)}
.btn-navy:hover{box-shadow:0 18px 34px rgba(22,51,91,.34)}
.btn-ghost{--bg:#fff;--fg:var(--navy);border:2px solid var(--line);box-shadow:var(--shadow-sm)}
.btn-ghost:hover{border-color:var(--sky);box-shadow:var(--shadow-md)}
.btn-lg{font-size:1.12rem;padding:1.05rem 2.1rem}
.btn-sm{font-size:.9rem;padding:.6rem 1.1rem}
.btn-white{--bg:#fff;--fg:var(--navy)}

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky;top:0;z-index:200;
  transition:background .3s,box-shadow .3s,backdrop-filter .3s;
}
.site-header.scrolled{background:rgba(255,255,255,.86);backdrop-filter:blur(14px);box-shadow:0 6px 30px rgba(22,51,91,.08)}
.nav{display:flex;align-items:center;gap:1.4rem;padding:.7rem 0;min-height:74px}
.brand{display:flex;align-items:center;gap:.7rem;margin-right:auto}
.brand .logo-mark{width:46px;height:46px;flex:none;filter:drop-shadow(0 4px 8px rgba(22,51,91,.18))}
.brand .brand-text{display:flex;flex-direction:column;line-height:1}
.brand .brand-name{font-family:var(--font-display);font-weight:700;font-size:1.18rem;color:var(--navy)}
.brand .brand-tag{font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;color:var(--red);font-weight:700;margin-top:2px}
.nav-links{display:flex;align-items:center;gap:.35rem}
.nav-links a{
  font-family:var(--font-display);font-weight:500;font-size:1rem;color:var(--navy);
  padding:.5rem .85rem;border-radius:var(--r-pill);position:relative;transition:color .2s,background .2s;
}
.nav-links a:hover{background:var(--sky-soft);color:var(--navy)}
.nav-links a.active{color:var(--red)}
.nav-links a.active::after{content:"";position:absolute;left:50%;bottom:2px;transform:translateX(-50%);width:6px;height:6px;border-radius:50%;background:var(--red)}
.nav-cta{margin-left:.4rem}
.nav-toggle{display:none;width:46px;height:46px;border-radius:14px;background:#fff;box-shadow:var(--shadow-sm);align-items:center;justify-content:center}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{content:"";display:block;width:22px;height:2.5px;border-radius:2px;background:var(--navy);transition:.3s}
.nav-toggle span::before{transform:translateY(-7px)}.nav-toggle span::after{transform:translateY(4.5px)}

/* dropdown */
.has-drop{position:relative}
.drop-panel{
  position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(8px);
  background:#fff;border-radius:var(--r-md);box-shadow:var(--shadow-lg);padding:.6rem;
  min-width:240px;opacity:0;visibility:hidden;transition:.25s var(--ease);border:1px solid var(--line);
}
.has-drop:hover .drop-panel,.has-drop:focus-within .drop-panel{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.drop-panel a{display:flex;gap:.7rem;align-items:center;padding:.7rem .8rem;border-radius:14px;font-weight:600}
.drop-panel a:hover{background:var(--cream)}
.drop-ic{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-size:1.1rem;flex:none}

/* ---------- Floating ambient scene ---------- */
.sky-scene{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.sky-scene .float{position:absolute;pointer-events:auto;cursor:pointer;transition:transform .3s}
.sky-scene .drift{animation:drift linear infinite}
@keyframes drift{0%{transform:translateY(0) translateX(0)}50%{transform:translateY(-24px) translateX(14px)}100%{transform:translateY(0) translateX(0)}}
.bubble{border-radius:50%;background:radial-gradient(circle at 32% 28%,#fff,rgba(255,255,255,.25) 60%,rgba(76,201,240,.18));box-shadow:inset 0 0 18px rgba(255,255,255,.6),0 8px 20px rgba(76,201,240,.18)}
@media (prefers-reduced-motion:reduce){.drift,.spin,.floaty,.pulse,.blob{animation:none!important}}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:var(--sky-wash);padding-top:clamp(2rem,5vw,4rem);padding-bottom:clamp(3rem,7vw,6rem)}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center}
.hero-copy h1{font-size:clamp(2.4rem,5.6vw,4.3rem);font-weight:700;letter-spacing:-.02em}
.hero-copy .lead{font-size:clamp(1.1rem,1.6vw,1.4rem);color:var(--ink-soft);max-width:52ch;margin-top:1.1rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.8rem}
.hero-trust{display:flex;align-items:center;gap:1rem;margin-top:1.8rem;flex-wrap:wrap;color:var(--ink-soft);font-weight:600;font-size:.95rem}
.avatars{display:flex}
.avatars span{width:38px;height:38px;border-radius:50%;margin-left:-10px;border:3px solid #fff;display:grid;place-items:center;font-size:1.1rem;box-shadow:var(--shadow-sm)}
.avatars span:first-child{margin-left:0}

/* Daily compliment card */
.daily-card{
  position:relative;background:#fff;border-radius:var(--r-xl);padding:clamp(1.6rem,3vw,2.6rem);
  box-shadow:var(--shadow-lg);border:1px solid var(--line);
}
.daily-card::before{content:"";position:absolute;inset:-2px;border-radius:inherit;padding:2px;background:var(--dawn);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:.55;pointer-events:none}
.daily-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.daily-badge{display:inline-flex;align-items:center;gap:.5rem;background:var(--sunrise);color:var(--navy);font-family:var(--font-display);font-weight:600;font-size:.8rem;letter-spacing:.05em;padding:.4rem .9rem;border-radius:var(--r-pill);text-transform:uppercase}
.daily-date{font-size:.85rem;color:var(--ink-faint);font-weight:700}
.daily-quote{font-family:var(--font-display);font-weight:500;font-size:clamp(1.4rem,2.4vw,2rem);color:var(--navy);line-height:1.25}
[data-daily]{transition:opacity .2s ease}
.daily-mark{font-size:2.4rem;color:var(--coral);line-height:0;font-family:Georgia,serif}
.daily-foot{display:flex;align-items:center;justify-content:space-between;margin-top:1.5rem;gap:1rem;flex-wrap:wrap}
.daily-react{display:flex;gap:.4rem}
.react-btn{width:44px;height:44px;border-radius:50%;background:var(--cream);display:grid;place-items:center;font-size:1.15rem;box-shadow:var(--shadow-sm);transition:transform .2s,background .2s}
.react-btn:hover{transform:translateY(-3px) scale(1.08);background:var(--sunshine-soft)}
.react-btn.pop{animation:pop .4s var(--ease)}
@keyframes pop{40%{transform:scale(1.4)}100%{transform:scale(1)}}

/* ---------- Cards ---------- */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease);overflow:hidden}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.card-pad{padding:clamp(1.4rem,2.4vw,2rem)}
.card-ic{width:64px;height:64px;border-radius:20px;display:grid;place-items:center;font-size:1.8rem;margin-bottom:1.1rem;box-shadow:var(--shadow-sm)}
.card h3{font-size:1.4rem;margin-bottom:.5rem}
.card p{color:var(--ink-soft);margin:0}
.card-link{display:inline-flex;align-items:center;gap:.4rem;margin-top:1rem;font-family:var(--font-display);font-weight:600;color:var(--red)}
.card-link .arw{transition:transform .25s}
.card:hover .card-link .arw{transform:translateX(5px)}

/* tint utilities */
.t-sun{background:var(--sunshine-soft);color:#a86a00}
.t-sky{background:var(--sky-soft);color:#0a6a8f}
.t-mint{background:var(--mint-soft);color:#0a7d61}
.t-coral{background:var(--coral-soft);color:#b23a2a}
.t-lav{background:var(--lavender-soft);color:#6a45b8}
.t-pink{background:#ffd9e6;color:#b23a63}
.t-navy{background:var(--navy);color:#fff}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap)}
.stat{text-align:center;padding:1.4rem 1rem;background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.stat .num{font-family:var(--font-display);font-weight:700;font-size:clamp(2rem,3.4vw,2.8rem);line-height:1}
.stat .lbl{color:var(--ink-soft);font-weight:600;font-size:.95rem;margin-top:.35rem}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap);counter-reset:step}
.step{position:relative;background:#fff;border-radius:var(--r-lg);padding:2rem 1.6rem 1.6rem;box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.step .step-n{position:absolute;top:-22px;left:1.6rem;width:46px;height:46px;border-radius:50%;background:var(--brand-grad);color:#fff;font-family:var(--font-display);font-weight:700;display:grid;place-items:center;box-shadow:var(--shadow-md)}
.step .step-ic{font-size:2rem;margin:.4rem 0 .8rem}
.step h3{font-size:1.3rem;margin-bottom:.4rem}
.step p{color:var(--ink-soft);margin:0}

/* ---------- Compliment Wall ---------- */
.wall-tools{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-bottom:2rem}
.chip{font-family:var(--font-display);font-weight:500;font-size:.92rem;padding:.5rem 1.1rem;border-radius:var(--r-pill);background:#fff;border:1.5px solid var(--line);color:var(--navy);box-shadow:var(--shadow-sm);transition:.2s}
.chip:hover{border-color:var(--sky)}
.chip.active{background:var(--brand-grad);color:#fff;border-color:transparent}
.masonry{columns:3;column-gap:var(--gap)}
.note{
  break-inside:avoid;margin-bottom:var(--gap);position:relative;
  border-radius:var(--r-md);padding:1.5rem 1.4rem 1.2rem;box-shadow:var(--shadow-md);
  transition:transform .3s var(--ease);
}
.note:hover{transform:translateY(-5px) rotate(-.6deg)}
.note::after{content:"";position:absolute;top:12px;left:50%;transform:translateX(-50%);width:46px;height:16px;background:rgba(255,255,255,.55);border-radius:4px;box-shadow:0 3px 6px rgba(0,0,0,.06)}
.note-body{font-family:var(--font-display);font-weight:500;font-size:1.15rem;color:var(--navy);margin:.6rem 0 1rem}
.note-meta{display:flex;align-items:center;justify-content:space-between;font-size:.85rem;color:var(--ink-soft);font-weight:700}
.note-from{display:flex;align-items:center;gap:.5rem}
.note-av{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-size:.95rem;background:#fff;box-shadow:var(--shadow-sm)}
.note-tag{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;background:rgba(255,255,255,.6);padding:.2rem .6rem;border-radius:var(--r-pill)}
.note-reacts{display:flex;gap:.3rem;margin-top:.8rem}
.mini-react{display:inline-flex;align-items:center;gap:.25rem;background:rgba(255,255,255,.65);border-radius:var(--r-pill);padding:.22rem .6rem;font-size:.85rem;font-weight:700;color:var(--navy);transition:.2s}
.mini-react:hover{background:#fff;transform:translateY(-2px)}
.n-sun{background:linear-gradient(160deg,#fff3cf,#ffe8a8)}
.n-sky{background:linear-gradient(160deg,#dff4ff,#c4e9fb)}
.n-mint{background:linear-gradient(160deg,#d6f7ec,#bdefdd)}
.n-coral{background:linear-gradient(160deg,#ffe1da,#ffcabf)}
.n-lav{background:linear-gradient(160deg,#ece2fd,#ddcefb)}
.n-pink{background:linear-gradient(160deg,#ffe0ec,#ffcbde)}

/* ---------- Composer ---------- */
.composer{background:#fff;border-radius:var(--r-xl);box-shadow:var(--shadow-lg);border:1px solid var(--line);padding:clamp(1.5rem,3vw,2.4rem)}
.field{margin-bottom:1.1rem}
.field label{display:block;font-family:var(--font-display);font-weight:600;color:var(--navy);margin-bottom:.4rem;font-size:.98rem}
.input,.textarea,.select{
  width:100%;font-family:var(--font-body);font-size:1rem;color:var(--ink);
  background:var(--cream);border:1.5px solid var(--line);border-radius:var(--r-sm);
  padding:.85rem 1rem;transition:.2s;
}
.input:focus,.textarea:focus,.select:focus{border-color:var(--sky);background:#fff;outline:none;box-shadow:var(--ring)}
.textarea{min-height:120px;resize:vertical}
.row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.hint{font-size:.85rem;color:var(--ink-faint)}
.pick-tags{display:flex;flex-wrap:wrap;gap:.5rem}
.pick{font-size:.88rem;font-weight:600;padding:.4rem .9rem;border-radius:var(--r-pill);background:var(--cream);border:1.5px solid var(--line);color:var(--navy);transition:.2s}
.pick.active{background:var(--sunrise);border-color:transparent;color:var(--navy)}
.checkbox{display:flex;gap:.6rem;align-items:flex-start;font-size:.95rem;color:var(--ink-soft)}
.checkbox input{margin-top:.25rem;width:18px;height:18px;accent-color:var(--red)}

/* ---------- Library ---------- */
.search-bar{display:flex;gap:.6rem;background:#fff;border:1.5px solid var(--line);border-radius:var(--r-pill);padding:.5rem .6rem .5rem 1.2rem;box-shadow:var(--shadow-md);max-width:640px;margin:0 auto 1.4rem;align-items:center}
.search-bar input{flex:1;border:0;background:none;font-size:1.05rem;font-family:var(--font-body);color:var(--ink)}
.search-bar input:focus{outline:none}
.lib-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.lib-item{display:flex;gap:1rem;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:1.1rem 1.2rem;box-shadow:var(--shadow-sm);transition:.25s}
.lib-item:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.lib-text{flex:1;font-weight:600;color:var(--navy)}
.lib-cat{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-faint);font-weight:800;margin-bottom:.2rem;display:block}
.copy-btn{flex:none;width:42px;height:42px;border-radius:12px;background:var(--cream);display:grid;place-items:center;font-size:1rem;transition:.2s;color:var(--navy)}
.copy-btn:hover{background:var(--sky-soft)}
.copy-btn.done{background:var(--mint);color:#fff}

/* ---------- Feature split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center}
.split.rev .split-media{order:2}
.media-card{position:relative;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/3;background:var(--dawn)}
.feature-list{display:grid;gap:1rem;margin-top:1.4rem}
.feature-list li{display:flex;gap:.9rem;align-items:flex-start}
.feature-list .fic{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;font-size:1.15rem;flex:none;box-shadow:var(--shadow-sm)}
.feature-list b{display:block;color:var(--navy);font-family:var(--font-display)}
.feature-list span{color:var(--ink-soft)}

/* ---------- Testimonials ---------- */
.quote-card{background:#fff;border-radius:var(--r-lg);padding:1.8rem;box-shadow:var(--shadow-sm);border:1px solid var(--line);position:relative}
.quote-card .stars{color:var(--sunshine);font-size:1.05rem;letter-spacing:2px;margin-bottom:.6rem}
.quote-card p{font-size:1.08rem;color:var(--ink);font-weight:600}
.quote-who{display:flex;align-items:center;gap:.7rem;margin-top:1rem}
.quote-who .av{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;font-size:1.2rem;box-shadow:var(--shadow-sm)}
.quote-who b{color:var(--navy);font-family:var(--font-display);display:block}
.quote-who small{color:var(--ink-faint)}

/* ---------- Big CTA band ---------- */
.cta-band{position:relative;overflow:hidden;background:var(--brand-grad);border-radius:var(--r-xl);padding:clamp(2.5rem,6vw,4.5rem);text-align:center;color:#fff;box-shadow:var(--shadow-lg)}
.cta-band h2{color:#fff;font-size:clamp(2rem,4.4vw,3.2rem)}
.cta-band p{color:rgba(255,255,255,.85);font-size:1.2rem;max-width:52ch;margin:1rem auto 1.8rem}
.cta-band .btn-row{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;position:relative;z-index:2}

/* ---------- Ad slots (ties to advertising network) ---------- */
.ad-slot{position:relative;border:1.5px dashed #dfe6f0;border-radius:var(--r-md);background:linear-gradient(120deg,#fbfdff,#fff);padding:1rem;display:grid;place-items:center;text-align:center;color:var(--ink-faint)}
.ad-leader{min-height:96px;max-width:970px;margin:0 auto}
.ad-tag{position:absolute;top:8px;left:12px;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);font-weight:800}
.ad-sponsor{display:flex;align-items:center;gap:1rem;justify-content:center}
.ad-sponsor .ad-logo{width:56px;height:56px;border-radius:14px;background:var(--sunrise);display:grid;place-items:center;font-size:1.5rem}
.ad-sponsor b{color:var(--navy);font-family:var(--font-display)}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy);color:#cdd8ea;padding:clamp(3rem,6vw,4.5rem) 0 2rem;position:relative;overflow:hidden}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2rem;position:relative;z-index:2}
.site-footer h4{color:#fff;font-size:1.05rem;margin-bottom:1rem;letter-spacing:.02em}
.site-footer a{color:#b7c5dc;transition:color .2s;display:inline-block;padding:.2rem 0}
.site-footer a:hover{color:var(--sunshine)}
.foot-brand .brand-name{color:#fff}
.foot-brand p{color:#9fb0cc;max-width:34ch;margin-top:1rem}
.foot-social{display:flex;gap:.6rem;margin-top:1.2rem}
.foot-social a{width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.08);display:grid;place-items:center;font-size:1.1rem;padding:0}
.foot-social a:hover{background:var(--red);color:#fff;transform:translateY(-3px)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:2.5rem;padding-top:1.5rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.9rem;color:#8ea0be;position:relative;z-index:2}
.newsletter{display:flex;gap:.5rem;margin-top:1rem;max-width:320px}
.newsletter input{flex:1;border:0;border-radius:var(--r-pill);padding:.7rem 1rem;font-family:var(--font-body)}
.newsletter button{border-radius:var(--r-pill);padding:.7rem 1.1rem;background:var(--red);color:#fff;font-family:var(--font-display);font-weight:600}

/* ---------- Page hero (interior) ---------- */
.page-hero{position:relative;overflow:hidden;background:var(--sky-wash);padding:clamp(3rem,7vw,5.5rem) 0 clamp(2.5rem,5vw,4rem);text-align:center}
.page-hero h1{font-size:clamp(2.2rem,5vw,3.8rem);font-weight:700}
.page-hero .lead{font-size:clamp(1.05rem,1.5vw,1.3rem);color:var(--ink-soft);max-width:58ch;margin:1rem auto 0}
.breadcrumb{display:flex;gap:.5rem;justify-content:center;font-size:.9rem;color:var(--ink-faint);font-weight:700;margin-bottom:1rem}
.breadcrumb a:hover{color:var(--red)}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* ---------- Toast ---------- */
.toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%) translateY(30px);background:var(--navy);color:#fff;padding:.9rem 1.4rem;border-radius:var(--r-pill);box-shadow:var(--shadow-lg);font-family:var(--font-display);font-weight:600;z-index:400;opacity:0;transition:.4s var(--ease);display:flex;gap:.6rem;align-items:center;pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ---------- Confetti canvas ---------- */
#confetti{position:fixed;inset:0;pointer-events:none;z-index:350}

/* ---------- Badges (achievements) ---------- */
.badge-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}
.badge{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:1.4rem 1rem;text-align:center;box-shadow:var(--shadow-sm);transition:.25s}
.badge:hover{transform:translateY(-5px) rotate(-2deg);box-shadow:var(--shadow-md)}
.badge .badge-ic{width:66px;height:66px;border-radius:50%;margin:0 auto .7rem;display:grid;place-items:center;font-size:1.8rem;box-shadow:var(--shadow-sm)}
.badge b{color:var(--navy);font-family:var(--font-display);display:block}
.badge small{color:var(--ink-faint)}
.badge.locked{opacity:.55;filter:grayscale(.5)}

/* ---------- Article cards ---------- */
.article{display:flex;flex-direction:column;height:100%}
.article .art-top{aspect-ratio:16/9;position:relative;display:grid;place-items:center;font-size:3rem}
.article .art-body{padding:1.4rem 1.5rem 1.6rem;flex:1;display:flex;flex-direction:column}
.article .art-cat{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;font-weight:800;color:var(--red);margin-bottom:.5rem}
.article h3{font-size:1.25rem;margin-bottom:.5rem}
.article p{color:var(--ink-soft);font-size:.98rem}
.article .art-foot{margin-top:auto;padding-top:1rem;font-weight:700;color:var(--ink-faint);font-size:.85rem;display:flex;justify-content:space-between}

/* ---------- Programs / audience blocks ---------- */
.audience{position:relative;border-radius:var(--r-xl);overflow:hidden;color:#fff;min-height:280px;display:flex;align-items:flex-end;padding:1.8rem;box-shadow:var(--shadow-md);transition:.3s}
.audience:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.audience h3{color:#fff;font-size:1.6rem}
.audience p{color:rgba(255,255,255,.9);margin:.3rem 0 0}
.audience .aud-inner{position:relative;z-index:2}
.audience::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(10,20,40,.55));z-index:1}

/* ---------- Network tiles (advertise) ---------- */
.net-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1rem}
.net-tile{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:1.5rem;box-shadow:var(--shadow-sm);transition:.3s;cursor:pointer}
.net-tile:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.net-logo{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;font-size:1.4rem;color:#fff;margin-bottom:.9rem;font-family:var(--font-display);font-weight:700}
.net-tile h3{font-size:1.15rem}
.net-tile .net-desc{color:var(--ink-soft);font-size:.92rem;margin-top:.3rem}
.net-tile .net-stats{display:flex;gap:1rem;margin-top:1rem;font-size:.82rem;color:var(--ink-faint);font-weight:700}
.net-tile.featured{border-color:var(--sunshine);box-shadow:0 0 0 2px var(--sunshine-soft),var(--shadow-md)}

/* placement previews */
.place-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}
.place{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:1.2rem;box-shadow:var(--shadow-sm);text-align:center}
.place .frame{border:2px dashed #d7deea;border-radius:12px;background:var(--cream);color:var(--ink-faint);font-weight:800;font-size:.8rem;display:grid;place-items:center;margin-bottom:.8rem}
.place b{color:var(--navy);font-family:var(--font-display)}
.place small{color:var(--ink-faint);display:block}

/* pricing */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}
.price{background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);padding:2rem;box-shadow:var(--shadow-sm);position:relative;transition:.3s}
.price:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.price.pop{border-color:var(--red);box-shadow:0 0 0 2px rgba(224,49,63,.15),var(--shadow-md)}
.price .pop-tag{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--red);color:#fff;font-family:var(--font-display);font-weight:600;font-size:.78rem;padding:.3rem 1rem;border-radius:var(--r-pill)}
.price h3{font-size:1.3rem}
.price .amt{font-family:var(--font-display);font-weight:700;font-size:2.6rem;color:var(--navy);margin:.5rem 0}
.price .amt small{font-size:1rem;color:var(--ink-faint);font-weight:600}
.price ul{margin:1.2rem 0;display:grid;gap:.6rem}
.price li{display:flex;gap:.6rem;color:var(--ink-soft)}
.price li::before{content:"✓";color:var(--mint);font-weight:900}

/* ---------- Divider wave ---------- */
.wave{display:block;width:100%;height:auto;line-height:0}

/* ---------- Utility ---------- */
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.pill-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}
.pill-list li{background:#fff;border:1px solid var(--line);border-radius:var(--r-pill);padding:.4rem 1rem;font-weight:700;color:var(--navy);font-size:.9rem;box-shadow:var(--shadow-sm)}
.hr{height:1px;background:var(--line);border:0;margin:2.5rem 0}

/* ---------- Responsive ---------- */
@media (max-width:960px){
  .hero-inner{grid-template-columns:1fr;text-align:center}
  .hero-copy .lead{margin-inline:auto}
  .hero-actions,.hero-trust{justify-content:center}
  .split{grid-template-columns:1fr}
  .split.rev .split-media{order:0}
  .stats{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:1fr}
  .masonry{columns:2}
  .lib-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .price-grid{grid-template-columns:1fr}
  .nav-links{
    position:fixed;inset:0 0 0 auto;width:min(340px,86vw);background:#fff;flex-direction:column;
    align-items:stretch;padding:6rem 1.4rem 2rem;gap:.3rem;box-shadow:var(--shadow-lg);
    transform:translateX(100%);transition:transform .35s var(--ease);z-index:150;overflow-y:auto;
  }
  .nav-links.open{transform:translateX(0)}
  .nav-links a{font-size:1.15rem;padding:.8rem 1rem}
  .nav-toggle{display:grid}
  .nav-toggle.open span{background:transparent}
  .nav-toggle.open span::before{transform:rotate(45deg)}
  .nav-toggle.open span::after{transform:rotate(-45deg)}
  .drop-panel{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;padding:.2rem 0 .2rem 1rem;min-width:0}
  .has-drop::after{content:none}
  .nav-cta{margin:.6rem 0 0}
}
@media (max-width:560px){
  .stats{grid-template-columns:1fr 1fr}
  .masonry{columns:1}
  .foot-grid{grid-template-columns:1fr}
  .row{grid-template-columns:1fr}
  .daily-foot{flex-direction:column;align-items:stretch}
  .brand .brand-tag{display:none}
}
