:root{
    /* palette pulled directly from the logo */
    --red:#c0301c;
    --sky:#1878a8;
    --orange:#d87800;
    --green:#18a860;
    --royal:#1848a8;
    --yellow:#f0c000;
    --pink:#d83090;
    --purple:#8a3fa6;
    --teal:#009078;
    --ink:#21303a;
    --paper:#fbfaf5;
    --cloud:#eef4f7;
    --line:#e3e7d9;
    --shadow:0 14px 40px -18px rgba(33,48,58,.35);
    --r:22px;
  }
  *{box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    margin:0;font-family:'Nunito',sans-serif;color:var(--ink);
    background:var(--paper);line-height:1.65;-webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  h1,h2,h3,.display{font-family:'Fredoka',sans-serif;line-height:1.08;margin:0}
  a{color:inherit}
  img{max-width:100%;display:block}
  .wrap{max-width:1120px;margin:0 auto;padding:0 24px}

  /* rainbow thread — the signature divider */
  .thread{height:8px;width:100%;border:0;margin:0;
    background:linear-gradient(90deg,
      var(--red) 0 11.1%,var(--orange) 11.1% 22.2%,var(--yellow) 22.2% 33.3%,
      var(--green) 33.3% 44.4%,var(--teal) 44.4% 55.5%,var(--sky) 55.5% 66.6%,
      var(--royal) 66.6% 77.7%,var(--purple) 77.7% 88.8%,var(--pink) 88.8% 100%);
  }

  /* ---- NAV ---- */
  header.nav{position:sticky;top:0;z-index:50;background:rgba(251,250,245,.92);
    backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
  .nav-inner{display:flex;align-items:center;justify-content:space-between;
    gap:14px;padding:8px 28px;max-width:1320px;margin:0 auto}
  .brand{display:flex;align-items:center;gap:12px;text-decoration:none;font-weight:800;flex:0 0 auto}
  .brand img{height:74px;width:auto}
  .brand span{font-family:'Fredoka';font-size:1.02rem;color:var(--ink);line-height:1.05;max-width:180px}
  .menu{display:flex;gap:2px;align-items:center;flex-wrap:nowrap}
  .menu a{text-decoration:none;font-weight:700;font-size:.92rem;padding:9px 12px;white-space:nowrap;
    border-radius:999px;transition:background .2s,color .2s}
  .menu a:hover{background:var(--cloud)}
  .menu a.cta{background:var(--green);color:#fff}
  .menu a.cta:hover{background:#13905090;background:#137d49}
  .burger{display:none;background:none;border:0;cursor:pointer;padding:8px;font-size:1.6rem;color:var(--ink)}

  /* ---- HERO ---- */
  .hero{position:relative;isolation:isolate;color:#fff;overflow:hidden}
  .hero-bg{position:absolute;inset:0;z-index:-2;
    background:url('building.jpg') center 38%/cover no-repeat;transform:scale(1.03)}
  .hero-bg::after{content:"";position:absolute;inset:0;
    background:linear-gradient(180deg,rgba(20,40,52,.42) 0%,rgba(16,52,60,.55) 45%,rgba(13,40,45,.82) 100%)}
  .hero-inner{position:relative;z-index:1;max-width:1120px;margin:0 auto;
    padding:78px 24px 96px;display:grid;gap:26px;max-width:none}
  .hero-grid{max-width:1120px;margin:0 auto;padding:78px 24px 96px}
  .eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:'Fredoka';
    font-weight:600;letter-spacing:.04em;font-size:.82rem;text-transform:uppercase;
    background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.28);
    padding:7px 15px;border-radius:999px;backdrop-filter:blur(4px)}
  .dot{width:9px;height:9px;border-radius:50%;background:var(--yellow);box-shadow:0 0 0 3px rgba(240,192,0,.3)}
  .hero h1{font-size:clamp(2.5rem,6vw,4.5rem);font-weight:700;max-width:15ch;
    margin:18px 0 0;text-shadow:0 2px 30px rgba(0,0,0,.35)}
  .hero h1 .line2{display:block}
  /* word-by-word reveal on load */
  .reveal .w{display:inline-block;opacity:0;transform:translateY(22px) rotate(2deg);
    animation:rise .6s cubic-bezier(.2,.7,.3,1) forwards}
  .reveal .w:nth-child(1){animation-delay:.15s}
  .reveal .w:nth-child(2){animation-delay:.28s}
  .reveal .w:nth-child(3){animation-delay:.41s}
  .reveal .line2 .w:nth-child(1){animation-delay:.6s}
  .reveal .line2 .w:nth-child(2){animation-delay:.72s}
  .reveal .line2 .w:nth-child(3){animation-delay:.84s}
  .reveal .line2 .w:nth-child(4){animation-delay:.96s}
  @keyframes rise{to{opacity:1;transform:translateY(0) rotate(0)}}
  /* hand-drawn underline that draws itself under one word */
  .underline-word{position:relative}
  .underline-word::after{content:"";position:absolute;left:-2%;right:-2%;bottom:-.12em;height:.42em;
    background:no-repeat center/100% 100%;
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 24' preserveAspectRatio='none'><path d='M3 16 C 40 6, 80 6, 110 12 S 170 20, 197 9' fill='none' stroke='%23f0c000' stroke-width='6' stroke-linecap='round' pathLength='1' stroke-dasharray='1' stroke-dashoffset='1'><animate attributeName='stroke-dashoffset' from='1' to='0' dur='.7s' begin='1.15s' fill='freeze' calcMode='spline' keySplines='.4 0 .2 1'/></path></svg>")}
  .lede{font-size:clamp(1.05rem,2vw,1.3rem);max-width:48ch;font-weight:600;
    color:#f4f7f3;text-shadow:0 1px 14px rgba(0,0,0,.4)}
  .hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:8px}
  .btn{font-family:'Fredoka';font-weight:600;text-decoration:none;padding:14px 26px;
    border-radius:999px;font-size:1.02rem;transition:transform .15s,box-shadow .2s,background .2s;
    display:inline-flex;align-items:center;gap:9px}
  .btn:hover{transform:translateY(-2px)}
  .btn-sun{background:var(--yellow);color:#5a4500;box-shadow:0 10px 26px -10px rgba(240,192,0,.8)}
  .btn-ghost{background:rgba(255,255,255,.14);color:#fff;border:1.5px solid rgba(255,255,255,.55)}
  .btn-ghost:hover{background:rgba(255,255,255,.24)}
  .hero-stats{display:flex;gap:30px;flex-wrap:wrap;margin-top:20px}
  .stat b{font-family:'Fredoka';font-weight:700;font-size:1.7rem;display:block;line-height:1}
  .stat span{font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;opacity:.85}

  /* floating crayon people in hero corner */
  .crew{position:absolute;right:-10px;bottom:-6px;z-index:0;display:flex;gap:0;opacity:.95;pointer-events:none}
  @media(max-width:760px){.crew{display:none}}

  /* ---- SECTIONS ---- */
  section{padding:74px 0}
  .kicker{font-family:'Fredoka';font-weight:600;text-transform:uppercase;letter-spacing:.08em;
    font-size:.8rem;color:var(--green);display:flex;align-items:center;gap:10px;margin-bottom:14px}
  .kicker::before{content:"";width:26px;height:4px;border-radius:3px;background:var(--green)}
  h2.title{font-size:clamp(1.9rem,4vw,2.8rem);font-weight:700;max-width:18ch}
  .sub{font-size:1.08rem;max-width:60ch;margin-top:14px;color:#46555e}

  /* welcome */
  .welcome{display:grid;grid-template-columns:1.1fr .9fr;gap:54px;align-items:center}
  .welcome .photo{position:relative}
  .welcome .photo img{border-radius:var(--r);box-shadow:var(--shadow);width:100%}
  .quote-badge{position:absolute;left:-18px;bottom:24px;background:#fff;border-radius:18px;
    padding:14px 18px;box-shadow:var(--shadow);max-width:230px;border-left:6px solid var(--pink)}
  .quote-badge p{margin:0;font-family:'Fredoka';font-weight:500;font-size:.95rem;color:var(--ink)}
  @media(max-width:820px){
    .welcome{grid-template-columns:1fr;gap:36px}
    .quote-badge{position:static;margin-top:16px;max-width:none;padding:18px 22px}
    .quote-badge p{font-size:1rem;line-height:1.5}
  }

  /* program cards */
  .cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:42px}
  .card{background:#fff;border-radius:var(--r);padding:30px 26px;box-shadow:var(--shadow);
    border-top:6px solid var(--c);transition:transform .2s}
  .card:hover{transform:translateY(-6px)}
  .card .ic{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;
    background:color-mix(in srgb,var(--c) 16%,#fff);margin-bottom:16px}
  .card h3{font-size:1.28rem;font-weight:600;margin-bottom:8px}
  .card p{margin:0;color:#516069;font-size:.98rem}
  @media(max-width:820px){.cards{grid-template-columns:1fr}}

  /* who we serve — chips */
  .serve{background:var(--cloud)}
  .chips{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
  .chip{background:#fff;border-radius:999px;padding:13px 22px;font-family:'Fredoka';
    font-weight:500;box-shadow:0 6px 18px -12px rgba(33,48,58,.4);display:flex;align-items:center;gap:11px}
  .chip i{width:13px;height:13px;border-radius:50%;background:var(--c);display:inline-block}
  .serve-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
  .serve-grid .col p{color:#46555e}
  .ages{display:flex;gap:18px;margin-top:24px;flex-wrap:wrap}
  .age-pill{background:#fff;border-radius:18px;padding:18px 24px;box-shadow:var(--shadow);text-align:center}
  .age-pill b{font-family:'Fredoka';font-weight:700;font-size:2rem;display:block;color:var(--royal)}
  .age-pill span{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#6a7882}
  @media(max-width:820px){.serve-grid{grid-template-columns:1fr;gap:32px}}

  /* approach values */
  .values{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:42px}
  .value{text-align:left}
  .value .num{font-family:'Fredoka';font-weight:700;font-size:.9rem;color:#fff;
    width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:var(--c);margin-bottom:12px}
  .value h3{font-size:1.1rem;font-weight:600;margin-bottom:6px}
  .value p{margin:0;font-size:.95rem;color:#516069}
  @media(max-width:820px){.values{grid-template-columns:1fr 1fr}}
  @media(max-width:520px){.values{grid-template-columns:1fr}}

  /* director */
  .director{background:#fff}
  .director-head{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;margin-bottom:48px}
  .director-head .lead-photo img{border-radius:var(--r);box-shadow:var(--shadow)}
  .signoff{font-family:'Fredoka';font-weight:500;font-size:1.15rem;color:var(--ink);margin-top:18px}
  .signoff b{color:var(--green)}
  @media(max-width:820px){.director-head{grid-template-columns:1fr;gap:30px}}

  .gallery-note{display:flex;align-items:center;gap:10px;font-weight:700;color:var(--pink);
    font-size:.95rem;margin-bottom:18px;justify-content:center}

  /* visit / map / contact */
  .visit{background:linear-gradient(180deg,var(--cloud),#fff)}
  .visit-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:40px;align-items:stretch}
  .info-card{background:#fff;border-radius:var(--r);padding:34px 32px;box-shadow:var(--shadow)}
  .info-row{display:flex;gap:16px;align-items:flex-start;padding:16px 0;border-bottom:1px solid var(--line)}
  .info-row:last-child{border-bottom:0}
  .info-row .ic{width:44px;height:44px;border-radius:13px;flex:0 0 44px;display:grid;place-items:center;color:#fff}
  .info-row h4{margin:0 0 2px;font-family:'Fredoka';font-weight:600;font-size:1rem}
  .info-row a,.info-row p{margin:0;color:#4a5860;text-decoration:none;font-weight:600}
  .info-row a:hover{color:var(--green)}
  .map-frame{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);min-height:380px;border:5px solid #fff}
  .map-frame iframe{width:100%;height:100%;min-height:380px;border:0;display:block}
  @media(max-width:820px){.visit-grid{grid-template-columns:1fr}}

  /* gallery */
  .gallery{background:var(--cloud)}
  .gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:36px}
  .g-item{position:relative;border-radius:18px;overflow:hidden;box-shadow:var(--shadow);
    aspect-ratio:4/3;background:#dfe6ea}
  .g-item img,.g-item iframe{width:100%;height:100%;object-fit:cover;border:0;display:block}
  .g-item.video{aspect-ratio:16/9}
  .g-empty{grid-column:1/-1;text-align:center;padding:46px 20px;border:2px dashed #c4cfd6;
    border-radius:18px;color:#6a7882;font-weight:600;background:#fff}
  @media(max-width:820px){.gallery-grid{grid-template-columns:1fr 1fr}}
  @media(max-width:520px){.gallery-grid{grid-template-columns:1fr}}

  /* testimonials */
  .tg{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:36px}
  .t-card{background:#fff;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
  .t-video{aspect-ratio:16/9;background:#0d1418}
  .t-video iframe{width:100%;height:100%;border:0;display:block}
  .t-body{padding:20px 24px}
  .t-body p{margin:0 0 10px;color:#46555e;font-size:1rem;font-style:italic}
  .t-name{font-family:'Fredoka';font-weight:600;color:var(--ink);font-style:normal}
  .t-quote{background:#fff;border-radius:var(--r);box-shadow:var(--shadow);padding:28px 30px;
    border-left:6px solid var(--c,var(--green))}
  .t-quote p{margin:0 0 12px;font-size:1.1rem;color:#36454e}
  @media(max-width:820px){.tg{grid-template-columns:1fr}}

  /* footer */
  footer{background:var(--ink);color:#dfe7ea;padding:54px 0 0}
  .foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px}
  .foot-brand img{height:auto;width:230px;max-width:100%;background:#fff;border-radius:14px;padding:10px}
  .foot-brand p{margin:16px 0 0;max-width:34ch;color:#aebac0;font-size:.95rem}
  footer h5{font-family:'Fredoka';font-weight:600;color:#fff;font-size:1.05rem;margin:0 0 14px}
  footer ul{list-style:none;margin:0;padding:0;display:grid;gap:10px}
  footer a{text-decoration:none;color:#bfcace;font-weight:600;font-size:.95rem}
  footer a:hover{color:var(--yellow)}
  .foot-bottom{margin-top:46px;border-top:1px solid rgba(255,255,255,.12);
    padding:20px 0;text-align:center;color:#8b999f;font-size:.86rem}
  @media(max-width:820px){.foot-grid{grid-template-columns:1fr;gap:30px}}

  /* mobile menu */
  @media(max-width:1080px){
    .burger{display:block}
    .menu{position:fixed;inset:90px 0 auto 0;flex-direction:column;background:var(--paper);
      border-bottom:1px solid var(--line);padding:14px 24px;gap:4px;
      transform:translateY(-130%);transition:transform .3s;box-shadow:var(--shadow);align-items:stretch}
    .menu.open{transform:translateY(0)}
    .menu a{padding:13px 14px}
  }

  @media (prefers-reduced-motion:reduce){
    *{animation:none!important;transition:none!important;scroll-behavior:auto}
  }
/* ============ SUB-PAGE STYLES ============ */
.page-hero{position:relative;isolation:isolate;color:#fff;overflow:hidden;
  padding:64px 0 70px;text-align:center}
.page-hero::before{content:"";position:absolute;inset:0;z-index:-2;
  background:url('building.jpg') center 40%/cover no-repeat}
.page-hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(16,52,60,.72),rgba(13,40,45,.82))}
.page-hero .kicker{justify-content:center;color:#ffe27a}
.page-hero .kicker::before{background:#ffe27a}
.page-hero h1{font-family:'Fredoka';font-weight:700;font-size:clamp(2.2rem,5vw,3.4rem);
  margin:6px 0 12px;text-shadow:0 2px 24px rgba(0,0,0,.4)}
.page-hero p{max-width:54ch;margin:0 auto;font-size:1.1rem;color:#eef4f3;font-weight:600}
.crumb{padding:16px 0;font-size:.92rem;font-weight:700;color:#6a7882}
.crumb a{color:var(--green);text-decoration:none}
.crumb a:hover{text-decoration:underline}

/* apply page */
.apply-wrap{max-width:760px;margin:0 auto;padding:56px 24px 80px}
.apply-card{background:#fff;border-radius:var(--r);box-shadow:var(--shadow);padding:40px 38px}
.apply-card h2{font-family:'Fredoka';font-weight:600;font-size:1.7rem;margin:0 0 10px}
.apply-card p{color:#46555e;margin:0 0 18px}
.form-soon{border:2px dashed #c4cfd6;border-radius:18px;padding:40px 26px;text-align:center;
  color:#6a7882;font-weight:600;background:var(--cloud)}
.apply-contact{display:flex;flex-wrap:wrap;gap:14px;margin-top:26px}
.apply-contact a{display:inline-flex;align-items:center;gap:9px;text-decoration:none;
  font-family:'Fredoka';font-weight:500;background:var(--cloud);padding:12px 20px;border-radius:999px;color:var(--ink)}
.apply-contact a:hover{background:#e2eaee}

/* gallery page reuse .gallery-grid/.g-item already in main css */
.section-pad{padding:60px 0}

/* gallery placeholder tile */
.g-ph{width:100%;height:100%;display:grid;place-items:center;color:#9fb0b8;
  font-family:'Fredoka';font-weight:500;background:
  repeating-linear-gradient(45deg,#eef2f4,#eef2f4 12px,#e7edef 12px,#e7edef 24px)}

/* ============ GALLERY (masonry + lightbox) ============ */
.masonry{columns:3 280px;column-gap:16px;margin-top:8px}
.masonry .g-item{display:block;width:100%;margin:0 0 16px;break-inside:avoid;padding:0;border:0;
  cursor:pointer;border-radius:16px;overflow:hidden;box-shadow:var(--shadow);background:#e7edef;
  transition:transform .18s,box-shadow .2s;outline:none}
.masonry .g-item img{width:100%;height:auto;display:block;transition:transform .35s}
.masonry .g-item:hover{transform:translateY(-3px)}
.masonry .g-item:hover img{transform:scale(1.04)}
.masonry .g-item:focus-visible{box-shadow:0 0 0 4px var(--yellow),var(--shadow)}
@media(max-width:560px){.masonry{columns:2 150px;column-gap:12px}.masonry .g-item{margin-bottom:12px}}

/* lightbox */
.lb{position:fixed;inset:0;z-index:200;background:rgba(13,24,28,.92);display:none;
  align-items:center;justify-content:center;padding:24px}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:86vh;border-radius:10px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.lb-close,.lb-nav{position:absolute;background:rgba(255,255,255,.14);border:0;color:#fff;
  cursor:pointer;border-radius:999px;display:grid;place-items:center;transition:background .2s}
.lb-close:hover,.lb-nav:hover{background:rgba(255,255,255,.28)}
.lb-close{top:18px;right:20px;width:48px;height:48px;font-size:1.6rem}
.lb-nav{top:50%;transform:translateY(-50%);width:52px;height:52px;font-size:1.8rem}
.lb-prev{left:16px}.lb-next{right:16px}
.lb-count{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);color:#dfe7ea;
  font-weight:700;font-size:.9rem;background:rgba(0,0,0,.4);padding:6px 14px;border-radius:999px}
@media(max-width:560px){.lb-nav{width:42px;height:42px}}

/* ============ SOCIAL ICONS ============ */
.socials{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.socials a{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;
  transition:transform .18s,box-shadow .2s,opacity .2s;color:#fff}
.socials a:hover{transform:translateY(-3px)}
.socials a svg{width:21px;height:21px}
.soc-fb{background:#1877f2}
.soc-ig{background:radial-gradient(circle at 30% 110%,#fdf497 0%,#fd5949 45%,#d6249f 70%,#285AEB 100%)}
.soc-tt{background:#010101}
.socials a.soon{position:relative;opacity:.55;cursor:default}
.socials a.soon::after{content:"soon";position:absolute;bottom:-16px;left:50%;transform:translateX(-50%);
  font-size:.6rem;font-weight:800;letter-spacing:.03em;color:#9aa7ad;text-transform:uppercase}
/* hero socials sit on the dark mural */
.hero-socials{margin-top:22px}
.hero-socials .label{font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.05em;
  color:rgba(255,255,255,.85);margin-bottom:10px;display:block}
.footer-socials{margin-top:18px;margin-bottom:22px}

/* ============ APPLICATION FORM ============ */
.appform{max-width:920px;margin:0 auto}
.form-intro{background:var(--cloud);border-radius:var(--r);padding:22px 26px;margin-bottom:26px;
  border-left:6px solid var(--green)}
.form-intro p{margin:0;color:#46555e;font-weight:600}
.fs{background:#fff;border-radius:var(--r);box-shadow:var(--shadow);padding:30px 30px;margin-bottom:22px}
.fs > h3{font-family:'Fredoka';font-weight:600;font-size:1.3rem;margin:0 0 4px;color:var(--ink);
  display:flex;align-items:center;gap:10px}
.fs > h3 .n{width:30px;height:30px;border-radius:50%;background:var(--c,var(--green));color:#fff;
  font-size:.9rem;display:grid;place-items:center;flex:0 0 30px}
.fs > .hint{color:#6a7882;font-size:.9rem;margin:0 0 18px 40px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:2px}
.field.full{grid-column:1/-1}
.field label{font-weight:700;font-size:.86rem;color:#3a4750}
.field label .req{color:var(--red)}
.field input,.field select,.field textarea{font-family:'Nunito';font-size:.98rem;padding:11px 13px;
  border:1.5px solid var(--line);border-radius:12px;background:#fdfdfb;color:var(--ink);width:100%;
  transition:border-color .15s,box-shadow .15s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green);
  box-shadow:0 0 0 3px rgba(24,168,96,.14)}
.field textarea{resize:vertical;min-height:70px}
.field.err input,.field.err select,.field.err textarea{border-color:var(--red)}
.subhead{font-family:'Fredoka';font-weight:600;color:var(--ink);margin:18px 0 10px;font-size:1.02rem}
/* demographics table-like rows */
.demo-row{display:grid;grid-template-columns:110px 1fr 1fr 1fr;gap:12px;align-items:end;margin-bottom:12px}
.demo-row .who{font-weight:700;color:var(--ink);padding-bottom:11px}
@media(max-width:720px){
  .grid2,.grid3,.grid4{grid-template-columns:1fr}
  .demo-row{grid-template-columns:1fr;gap:8px;padding:14px;background:var(--cloud);border-radius:12px}
  .demo-row .who{padding-bottom:0}
}
.form-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin-top:8px}
.form-note{font-size:.85rem;color:#6a7882;margin-top:14px}
.form-msg{padding:14px 18px;border-radius:12px;font-weight:700;margin-top:16px;display:none}
.form-msg.show{display:block}
.form-msg.ok{background:#e6f6ee;color:#137d49}
.form-msg.bad{background:#fdecea;color:#b5361f}
.btn[disabled]{opacity:.6;cursor:not-allowed;transform:none}

/* ============ TESTIMONIALS — portrait video support + more-coming ============ */
/* portrait video card: constrain width so a 9:16 clip isn't giant */
.t-card.portrait{max-width:360px;margin:0 auto;width:100%}
.t-card.portrait .t-video{aspect-ratio:9/16;background:#0d1418}
.tg.tg-center{align-items:start;justify-items:center}
/* "more coming" reveal */
.more-coming{max-width:640px;margin:48px auto 0;text-align:center;padding:34px 28px;
  border:2px dashed #c4cfd6;border-radius:var(--r);background:#fff;
  opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.more-coming.in{opacity:1;transform:translateY(0)}
.more-coming .mc-emoji{font-size:1.8rem;display:block;margin-bottom:8px}
.more-coming h3{font-family:'Fredoka';font-weight:600;color:var(--ink);font-size:1.3rem;margin:0 0 6px}
.more-coming p{margin:0;color:#6a7882;font-weight:600}
@media(prefers-reduced-motion:reduce){
  .more-coming{opacity:1;transform:none;transition:none}
}
