
  :root{
    --paper:#FAF8F2;
    --blush:#E8EEDD;
    --blush-2:#D5E0C4;
    --petal:#A8C58A;
    --rose:#5A7C3C;
    --rose-deep:#5A7C3C99;
    --berry:#3E5A2C;
    --berry-soft:#4F7239;
    --mauve:#897C6B;
    --ink:#2D3326;
    --ink-soft:#5A5A4C;

    --maxw:1180px;
    --gut:clamp(20px,5vw,64px);

    --f-display:"Fraunces",Georgia,serif;
    --f-body:"Manrope",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;

    --ease:cubic-bezier(.22,.61,.36,1);
  }

  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    font-family:var(--f-body);
    background:var(--paper);
    color:var(--ink);
    line-height:1.6;
    font-size:17px;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  img{max-width:100%;display:block}
  a{color:inherit;text-decoration:none}
  ::selection{background:var(--petal);color:var(--berry)}

  /* ---------- Type ---------- */
  h1,h2,h3{font-family:var(--f-display);font-weight:500;line-height:1.04;letter-spacing:-.01em}
  .eyebrow{
    font-family:var(--f-body);
    font-weight:600;
    font-size:.74rem;
    letter-spacing:.22em;
    text-transform:uppercase;
    color:var(--rose);
    display:inline-flex;
    align-items:center;
    gap:.6em;
  }
  .eyebrow::before{
    content:"";width:26px;height:1.5px;background:var(--petal);display:inline-block;
  }
  .display-xl{font-size:clamp(2.7rem,7.4vw,5.4rem)}
  .ital{font-style:italic;font-weight:400;color:var(--berry)}

  /* ---------- Layout ---------- */
  .wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--gut);padding-right:var(--gut)}
  section{position:relative}

  /* ---------- Buttons ---------- */
  .btn{
    display:inline-flex;align-items:center;gap:.55em;
    font-weight:600;font-size:.95rem;letter-spacing:.01em;
    padding:.95em 1.7em;border-radius:100px;
    transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .35s var(--ease);
    cursor:pointer;border:none;
  }
  .btn-primary{
    background:var(--berry);color:#fff;
    box-shadow:0 10px 30px -10px rgba(74,82,54,.55);
  }
  .btn-primary:hover{transform:translateY(-3px);box-shadow:0 18px 40px -12px rgba(74,82,54,.6);background:var(--berry-soft)}
  .btn-ghost{
    background:transparent;color:var(--berry);border:1.5px solid var(--blush-2);
  }
  .btn-ghost:hover{transform:translateY(-3px);border-color:var(--rose);background:#fff}
  .btn .arr{transition:transform .35s var(--ease)}
  .btn:hover .arr{transform:translateX(4px)}

  /* ---------- Nav ---------- */
  header{
    position:fixed;top:0;left:0;right:0;z-index:50;
    transition:background .4s var(--ease),box-shadow .4s var(--ease),padding .4s var(--ease);
    padding:22px 0;
  }
  header.scrolled{
    background:rgba(250,248,242,.85);
    backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
    box-shadow:0 1px 0 rgba(74,82,54,.07);
    padding:14px 0;
  }
  .nav{display:flex;align-items:center;justify-content:space-between}
  .brand{font-family:var(--f-display);font-weight:600;font-size:1.32rem;letter-spacing:-.02em;color:var(--berry);display:flex;align-items:center;gap:.5em}
  .brand .dot{width:9px;height:9px;border-radius:50%;background:var(--rose);box-shadow:0 0 0 4px var(--blush)}
  .brand .logo{height:46px;width:auto;display:block;transition:height .4s var(--ease)}
  header.scrolled .brand .logo{height:38px}
  .nav-links{display:flex;align-items:center;gap:34px}
  .nav-links a.lnk{font-size:.92rem;font-weight:500;color:var(--ink-soft);position:relative;transition:color .3s}
  .nav-links a.lnk::after{content:"";position:absolute;left:0;bottom:-6px;height:1.5px;width:0;background:var(--rose);transition:width .35s var(--ease)}
  .nav-links a.lnk:hover{color:var(--berry)}
  .nav-links a.lnk:hover::after{width:100%}
  .burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;z-index:60}
  .burger span{width:24px;height:2px;background:var(--berry);border-radius:2px;transition:.35s var(--ease)}
  .burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .burger.open span:nth-child(2){opacity:0}
  .burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .nav-social{display:flex;align-items:center;gap:14px}
  .nav-social a{color:var(--ink-soft);display:inline-flex;transition:color .3s,transform .3s}
  .nav-social a:hover{color:var(--berry);transform:translateY(-2px)}

  /* ---------- Hero ---------- */
  .hero{padding:138px 0 80px;position:relative;overflow:hidden}
  .hero-bg{position:absolute;inset:0;z-index:-2;overflow:hidden}
  .blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.6;animation:drift 18s var(--ease) infinite alternate}
  .blob.b1{width:520px;height:520px;background:radial-gradient(circle,var(--petal),transparent 70%);top:-160px;right:-120px}
  .blob.b2{width:440px;height:440px;background:radial-gradient(circle,var(--blush-2),transparent 70%);bottom:-120px;left:-100px;animation-delay:-6s}
  .blob.b3{width:360px;height:360px;background:radial-gradient(circle,#CFE0B8,transparent 70%);top:40%;left:42%;animation-delay:-11s;opacity:.5}
  @keyframes drift{to{transform:translate(40px,-30px) scale(1.12)}}

  .hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,70px);align-items:center}
  .hero h1{margin:.28em 0 .5em}
  .hero p.lede{font-size:1.16rem;color:var(--ink-soft);max-width:30ch;margin-bottom:2em}
  .hero-ctas{display:flex;gap:14px;flex-wrap:wrap}

  /* photo frame */
  .portrait{position:relative;display:flex;flex-direction:column;align-items:center;gap:26px;justify-self:center}
  .pmedia{position:relative;width:fit-content}
  .portrait .frame{
    position:relative;
    width:clamp(260px,34vw,420px);aspect-ratio:4/5;overflow:hidden;
    border-radius:54% 46% 47% 53% / 38% 41% 59% 62%;
    box-shadow:0 40px 80px -30px rgba(74,82,54,.45);
    background:linear-gradient(150deg,var(--blush) 0%,var(--petal) 100%);
    animation:morph 14s ease-in-out infinite;
  }
  .portrait .frame .monogram{
    position:absolute;inset:0;display:grid;place-items:center;text-align:center;
    font-family:var(--f-display);font-style:italic;color:var(--berry);
    line-height:.9;
  }
  .portrait .frame .monogram b{display:block;font-size:clamp(3.2rem,7vw,5rem);font-weight:500}
  .portrait .frame .monogram small{display:block;font-family:var(--f-body);font-style:normal;font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--berry-soft);margin-top:.9em;opacity:.8}
  .portrait .frame img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 18%;transition:opacity .6s var(--ease)}
  @keyframes morph{
    0%,100%{border-radius:54% 46% 47% 53% / 38% 41% 59% 62%}
    50%{border-radius:44% 56% 58% 42% / 52% 45% 55% 48%}
  }
  /* little about card */
  .meet{
    background:#fff;border:1px solid var(--blush-2);border-radius:22px;
    padding:22px 26px;max-width:clamp(280px,32vw,400px);text-align:left;
    box-shadow:0 24px 50px -34px rgba(74,82,54,.4);
  }
  .meet .eyebrow{margin-bottom:.7em}
  .meet p{font-size:.96rem;color:var(--ink-soft);line-height:1.55}
  @keyframes spin{to{transform:rotate(360deg)}}
  .badge{
    position:absolute;background:#fff;border-radius:18px;padding:13px 17px;
    box-shadow:0 18px 40px -16px rgba(74,82,54,.4);display:flex;gap:11px;align-items:center;
  }
  .badge .ic{width:34px;height:34px;border-radius:11px;background:var(--blush);display:grid;place-items:center;color:var(--berry)}
  .badge small{display:block;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mauve);font-weight:600}
  .badge strong{font-size:.92rem;color:var(--ink)}
  .badge.top{top:8%;left:-26px}
  .badge.bot{bottom:9%;right:-22px}

  /* marquee */
  .marquee{margin-top:64px;overflow:hidden;-webkit-mask:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent)}
  .marquee-track{display:flex;gap:54px;width:max-content;animation:slide 26s linear infinite}
  .marquee span{font-family:var(--f-display);font-style:italic;font-size:1.5rem;color:var(--mauve);white-space:nowrap;display:flex;align-items:center;gap:54px}
  .marquee span::after{content:"✦";color:var(--petal);font-style:normal;font-size:.9rem}
  @keyframes slide{to{transform:translateX(-50%)}}

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

  /* ---------- About ---------- */
  .about{background:linear-gradient(180deg,var(--blush),var(--paper) 62%)}
  .about-intro{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(34px,5vw,72px);align-items:center}
  .about-photo{position:relative;width:100%;max-width:560px;aspect-ratio:900/510;overflow:hidden;justify-self:center;
    border-radius:30px;background:linear-gradient(150deg,var(--blush),var(--petal));
    box-shadow:0 40px 80px -30px rgba(74,82,54,.45), inset 0 0 0 6px rgba(255,255,255,.6)}
  .about-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}
  .about-lead h1{font-family:var(--f-display);font-weight:500;font-size:clamp(2.1rem,4.5vw,3rem);color:var(--ink);margin:.12em 0 .2em;line-height:1.04}
  .about-quote{font-family:var(--f-display);font-style:italic;font-size:clamp(1.3rem,2.4vw,1.7rem);color:var(--berry);margin-bottom:.7em}
  .about-lead p{color:var(--ink-soft);margin-bottom:1em;line-height:1.62}
  .about-lead p strong{color:var(--ink);font-weight:600}
  .about-lead .sign{font-family:var(--f-display);font-style:italic;font-size:1.25rem;color:var(--berry);margin:.1em 0 1.3em}
  .about-highlights{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin:clamp(40px,6vw,72px) 0;
    background:#fff;border:1px solid var(--blush-2);border-radius:22px;padding:30px 26px;box-shadow:0 30px 60px -42px rgba(74,82,54,.45)}
  .about-highlights .hl{text-align:center;padding:4px 6px}
  .about-highlights .hl b{display:block;font-family:var(--f-display);font-size:1.22rem;color:var(--berry);margin-bottom:4px}
  .about-highlights .hl small{color:var(--mauve);font-size:.84rem;line-height:1.3;display:block}
  .about-values .sec-head{text-align:center;max-width:640px;margin:0 auto 38px}
  .about-values .sec-head .eyebrow{justify-content:center}
  .about-values .sec-head h2{font-family:var(--f-display);font-weight:500;font-size:clamp(1.8rem,3.5vw,2.6rem);color:var(--ink);margin-top:.2em}
  .values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
  .value{background:#fff;border:1px solid var(--blush-2);border-radius:22px;padding:28px 24px;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
  .value:hover{transform:translateY(-6px);box-shadow:0 30px 60px -30px rgba(74,82,54,.4)}
  .value .vic{display:grid;place-items:center;width:50px;height:50px;border-radius:14px;background:var(--blush);color:var(--berry);font-size:23px;margin-bottom:16px}
  .value h3{font-size:1.18rem;color:var(--berry);margin-bottom:.4em}
  .value p{color:var(--ink-soft);font-size:.93rem;line-height:1.55}
  .sign{font-family:var(--f-display);font-style:italic;font-size:1.5rem;color:var(--rose);margin-top:.3em}

  /* ---------- Section heads ---------- */
  .sec-head{max-width:640px;margin-bottom:56px}
  .sec-head h2{font-size:clamp(2rem,4.6vw,3.3rem);margin:.32em 0 .4em}
  .sec-head p{color:var(--ink-soft);font-size:1.08rem}
  .pad{padding:96px 0}

  /* first content section on inner pages must clear the fixed ~97px header */
  #hdr + section:not(.hero){padding-top:120px}

  /* ---------- Train cards ---------- */
  .train-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
  .card{
    position:relative;background:#fff;border-radius:26px;padding:34px 30px 30px;
    border:1px solid var(--blush-2);overflow:hidden;
    transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .45s var(--ease);
    display:flex;flex-direction:column;
  }
  .card:hover{transform:translateY(-8px);box-shadow:0 30px 60px -28px rgba(74,82,54,.4);border-color:var(--petal)}
  .card .num{font-family:var(--f-display);font-style:italic;font-size:1.1rem;color:var(--petal)}
  .card h3{font-size:1.5rem;margin:.5em 0 .45em;color:var(--berry)}
  .card p{color:var(--ink-soft);font-size:.98rem;flex-grow:1;margin-bottom:1.5em}
  .card .meta{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--mauve);font-weight:600;margin-bottom:1.4em;display:flex;align-items:center;gap:.5em}
  .card .meta::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--rose)}
  .card .go{font-weight:600;color:var(--berry);display:inline-flex;align-items:center;gap:.5em;font-size:.95rem}
  .card .go .arr{transition:transform .35s var(--ease)}
  .card:hover .go .arr{transform:translateX(5px)}
  .card .glow{position:absolute;top:-60px;right:-60px;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,var(--blush),transparent 70%);opacity:0;transition:opacity .45s}
  .card:hover .glow{opacity:1}

  /* ---------- Shop / fuel ---------- */
  .fuel{background:linear-gradient(180deg,var(--paper),var(--blush) 60%)}
  .feature{
    display:grid;grid-template-columns:1fr 1fr;gap:0;border-radius:30px;overflow:hidden;
    background:var(--berry);color:#fff;margin-bottom:46px;box-shadow:0 40px 80px -36px rgba(74,82,54,.6);
  }
  .feature .ftxt{padding:clamp(32px,4vw,52px);display:flex;flex-direction:column;justify-content:center}
  .feature .eyebrow{color:var(--petal)}
  .feature .eyebrow::before{background:var(--rose)}
  .feature h3{font-size:clamp(1.8rem,3.5vw,2.6rem);margin:.4em 0 .5em}
  .feature p{color:#DCE8C8;margin-bottom:1.8em;font-size:1.02rem}
  .feature .btn-primary{background:#fff;color:var(--berry);align-self:flex-start;box-shadow:0 12px 30px -12px rgba(0,0,0,.4)}
  .feature .btn-primary:hover{background:var(--blush)}
  .feature .fart{position:relative;background:
      radial-gradient(circle at 70% 30%,var(--rose-deep),transparent 55%),
      radial-gradient(circle at 30% 80%,#9CB87A66,transparent 55%),
      var(--berry-soft);
    min-height:240px;display:grid;place-items:center;overflow:hidden}
  .feature .fart .lift{font-family:var(--f-display);font-style:italic;font-size:clamp(2.4rem,5vw,4rem);color:#fff;opacity:.92;text-align:center;line-height:1.05;padding:30px}
  .feature .fart .lift small{display:block;font-style:normal;font-family:var(--f-body);font-size:.8rem;letter-spacing:.24em;text-transform:uppercase;color:var(--petal);margin-top:1em}

  .prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
  .prod{
    background:#fff;border:1px solid var(--blush-2);border-radius:20px;padding:24px 22px;
    transition:transform .4s var(--ease),box-shadow .4s var(--ease);display:flex;flex-direction:column;gap:10px;min-height:170px;
  }
  .prod:hover{transform:translateY(-6px);box-shadow:0 24px 48px -24px rgba(74,82,54,.4)}
  .prod .tag{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--rose);font-weight:700}
  .prod h4{font-family:var(--f-body);font-weight:700;font-size:1.05rem;color:var(--ink);line-height:1.25}
  .prod p{font-size:.86rem;color:var(--ink-soft);flex-grow:1}
  .prod .shop{font-size:.82rem;font-weight:600;color:var(--berry);display:flex;align-items:center;gap:.4em;margin-top:auto}
  .prod:hover .shop .arr{transform:translateX(4px)}
  .prod .shop .arr{transition:transform .3s var(--ease)}

  /* ---------- Lifestyle ---------- */
  .life-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
  .life{
    position:relative;border-radius:24px;padding:32px 30px;overflow:hidden;min-height:180px;
    display:flex;flex-direction:column;justify-content:flex-end;
    transition:transform .4s var(--ease);
  }
  .life:hover{transform:translateY(-6px)}
  .life.l1{background:linear-gradient(135deg,#E4EBD7,#CADFAE)}
  .life.l2{background:linear-gradient(135deg,#ECE6D9,#CFC2AE)}
  .life.l3{background:linear-gradient(135deg,#EEF1E6,#C6D8A8)}
  .life .eyebrow{color:var(--berry)}
  .life .eyebrow::before{background:var(--berry)}
  .life h3{font-size:1.5rem;color:var(--berry);margin:.5em 0 .35em}
  .life p{font-size:.92rem;color:var(--ink-soft);margin-bottom:1.1em}
  .life .go{font-weight:600;color:var(--berry);font-size:.9rem;display:inline-flex;gap:.4em}
  .life:hover .go .arr{transform:translateX(4px)}
  .life .go .arr{transition:transform .3s var(--ease)}

  /* ---------- Testimonials ---------- */
  .stories{background:var(--blush)}
  .stories .sec-head{margin-left:auto;margin-right:auto;text-align:center}
  .stories .sec-head .eyebrow{justify-content:center}
  .t-grid{columns:3;column-gap:22px}
  .t-card{
    break-inside:avoid;margin-bottom:22px;background:var(--paper);
    border:1px solid var(--blush-2);border-radius:24px;padding:30px 28px;
    box-shadow:0 20px 50px -36px rgba(74,82,54,.45);position:relative;
    transition:transform .4s var(--ease),box-shadow .4s var(--ease);
  }
  .t-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(74,82,54,.5)}
  .t-card .quote-mark{font-family:var(--f-display);font-style:italic;font-size:2.6rem;line-height:.6;color:var(--petal);display:block;margin-bottom:.15em}
  .t-card .stars{color:var(--sage,#84A86C);letter-spacing:2px;font-size:.85rem;margin-bottom:.9em;color:var(--berry-soft)}
  .t-card p{color:var(--ink);font-size:1rem;line-height:1.62;margin-bottom:1.4em}
  .t-who{display:flex;align-items:center;gap:13px}
  .t-who .av{width:44px;height:44px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;font-family:var(--f-display);font-weight:600;color:#fff;font-size:1.05rem;background:var(--berry-soft)}
  .t-who .av.v2{background:var(--mauve)}
  .t-who .av.v3{background:var(--sage,#84A86C);background:#84A86C}
  .t-who b{display:block;font-family:var(--f-body);font-weight:700;font-size:.95rem;color:var(--ink)}
  .t-who small{display:block;font-size:.78rem;color:var(--mauve);font-weight:600;letter-spacing:.04em}


  .cta{background:var(--berry);color:#fff;text-align:center;padding:110px 0;position:relative;overflow:hidden}
  .cta .blob{opacity:.4}
  .cta .blob.c1{width:480px;height:480px;background:radial-gradient(circle,var(--rose),transparent 70%);top:-160px;left:-100px}
  .cta .blob.c2{width:420px;height:420px;background:radial-gradient(circle,var(--berry-soft),transparent 70%);bottom:-160px;right:-80px}
  .cta .eyebrow{color:var(--petal)}
  .cta .eyebrow::before{background:var(--rose)}
  .cta h2{font-size:clamp(2.2rem,5.5vw,4rem);margin:.3em auto .4em;max-width:16ch}
  .cta p{color:#DCE8C8;max-width:46ch;margin:0 auto 2.4em;font-size:1.12rem}
  .cta .hero-ctas{justify-content:center}
  .cta .btn-primary{background:#fff;color:var(--berry)}
  .cta .btn-primary:hover{background:var(--blush)}
  .cta .btn-ghost{color:#fff;border-color:rgba(255,255,255,.4)}
  .cta .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}

  /* ---------- Contact ---------- */
  .contact{background:linear-gradient(180deg,var(--blush),var(--paper) 70%)}
  .contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(34px,5vw,72px);align-items:start}
  .contact-info h2{margin:.2em 0 .5em}
  .contact-info p.lead{color:var(--ink-soft);font-size:1.08rem;max-width:34ch;margin-bottom:1.8em}
  .contact-points{list-style:none;display:flex;flex-direction:column;gap:16px}
  .contact-points li{display:flex;gap:13px;align-items:flex-start;color:var(--ink)}
  .contact-points .ic{width:38px;height:38px;flex:0 0 auto;border-radius:12px;background:#fff;display:grid;place-items:center;color:var(--berry);box-shadow:0 12px 28px -16px rgba(74,82,54,.4)}
  .contact-points b{display:block;font-size:.96rem}
  .contact-points small{color:var(--mauve);font-size:.86rem}
  .form-card{
    background:#fff;border:1px solid var(--blush-2);border-radius:26px;
    padding:clamp(26px,3vw,40px);box-shadow:0 36px 70px -40px rgba(74,82,54,.5);
  }
  .form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
  .field{margin-bottom:18px;display:flex;flex-direction:column}
  .field > label{font-size:.82rem;font-weight:600;color:var(--ink);margin-bottom:7px;letter-spacing:.01em}
  .field label .req{color:var(--rose)}
  .field input,.field select,.field textarea{
    font-family:var(--f-body);font-size:.98rem;color:var(--ink);background:var(--paper);
    border:1.5px solid var(--blush-2);border-radius:13px;padding:12px 15px;transition:border-color .25s,box-shadow .25s;width:100%;
  }
  .field textarea{resize:vertical;min-height:120px}
  .field input:focus,.field select:focus,.field textarea:focus{
    outline:none;border-color:var(--petal);box-shadow:0 0 0 4px rgba(168,197,138,.22);
  }
  .form-card .btn-primary{width:100%;justify-content:center;margin-top:6px;border:none;cursor:pointer;font-family:var(--f-body)}
  .form-card .btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}
  .form-note{font-size:.8rem;color:var(--mauve);text-align:center;margin-top:14px}
  .hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
  .form-status{display:none;border-radius:14px;padding:14px 16px;font-size:.94rem;margin-bottom:18px}
  .form-status.show{display:block}
  .form-status.ok{background:var(--blush);color:var(--berry);border:1px solid var(--petal)}
  .form-status.err{background:#F7E7E7;color:#9B3B3B;border:1px solid #E3B7B7}

  /* ---------- Apply / Application form ---------- */
  .apply{background:linear-gradient(180deg,var(--blush),var(--paper) 55%)}
  .apply-head{text-align:center;max-width:660px;margin:0 auto 38px}
  .apply-head .eyebrow{justify-content:center}
  .apply-head h1{font-family:var(--f-display);font-weight:500;font-size:clamp(2.1rem,5vw,3.1rem);line-height:1.05;color:var(--ink);margin:.18em 0 .45em}
  .apply-head .lead{color:var(--ink-soft);font-size:1.04rem;line-height:1.6}
  .apply-card{max-width:720px;margin:0 auto}
  .form-section{font-family:var(--f-display);font-size:1.18rem;font-weight:600;color:var(--berry);margin-bottom:14px}
  .form-block{margin-top:30px;padding-top:26px;border-top:1px solid var(--blush-2)}
  .form-block:first-of-type{margin-top:2px;padding-top:0;border-top:0}
  .field .hint{font-size:.8rem;color:var(--mauve);margin:-3px 0 9px;font-weight:400;letter-spacing:0}
  .pillset{display:flex;flex-wrap:wrap;gap:9px}
  .pill{display:inline-flex;margin:0}
  .pill input{position:absolute;opacity:0;width:0;height:0}
  .pill span{display:inline-block;padding:9px 15px;border:1.5px solid var(--blush-2);border-radius:999px;font-size:.9rem;color:var(--ink);background:var(--paper);cursor:pointer;transition:background .2s,border-color .2s,color .2s}
  .pill input:checked + span{background:var(--petal);border-color:var(--rose);color:var(--berry);font-weight:600}
  .pill input:focus-visible + span{box-shadow:0 0 0 4px rgba(168,197,138,.3)}
  .pillset.nums .pill span{min-width:44px;text-align:center;padding:9px 0}


  /* ---------- Follow / social ---------- */
  .follow{background:linear-gradient(180deg,var(--paper),var(--blush))}
  .follow-inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,64px);align-items:center}
  .follow-copy h2{font-family:var(--f-display);font-weight:500;font-size:clamp(2rem,4vw,2.9rem);color:var(--ink);line-height:1.05;margin:.15em 0 .5em}
  .follow-copy p{color:var(--ink-soft);font-size:1.05rem;line-height:1.6;max-width:42ch}
  .follow-cards{display:flex;flex-direction:column;gap:14px}
  .fcard{display:flex;align-items:center;gap:16px;background:#fff;border:1px solid var(--blush-2);border-radius:18px;padding:16px 20px;box-shadow:0 20px 44px -32px rgba(74,82,54,.5);transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s}
  .fcard:hover{transform:translateY(-4px);box-shadow:0 30px 60px -34px rgba(74,82,54,.55);border-color:var(--petal)}
  .fcard .fic{display:grid;place-items:center;width:46px;height:46px;border-radius:12px;flex:0 0 auto;color:#fff}
  .fcard.ig .fic{background:linear-gradient(45deg,#F58529,#DD2A7B,#8134AF)}
  .fcard.tt .fic{background:#111}
  .fcard.lt .fic{background:var(--rose)}
  .fcard .ftxt{flex:1}
  .fcard .ftxt b{display:block;color:var(--ink);font-size:1.02rem}
  .fcard .ftxt small{color:var(--mauve);font-size:.86rem}
  .fcard .arr{color:var(--berry);font-weight:600;transition:transform .35s var(--ease)}
  .fcard:hover .arr{transform:translateX(5px)}

  /* ---------- Footer ---------- */
  footer{background:var(--ink);color:#E7E3D6;padding:64px 0 36px}
  .foot-top{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1)}
  footer .brand{color:#fff}
  footer .ftag{color:var(--mauve);max-width:34ch;margin-top:1em;font-size:.95rem}
  .foot-links{display:flex;gap:60px;flex-wrap:wrap}
  .foot-col h5{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--petal);margin-bottom:14px;font-weight:700}
  .foot-col a{display:block;color:#CFC9BA;font-size:.93rem;margin-bottom:9px;transition:color .3s}
  .foot-col a:hover{color:#fff}
  .foot-bot{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;padding-top:28px;font-size:.82rem;color:var(--mauve)}
  .foot-bot a{color:var(--mauve)}
  .foot-bot a:hover{color:#fff}

  /* ---------- reveal (progressive enhancement: only hide when JS is present) ---------- */
  .js .reveal{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
  .js .reveal.in{opacity:1;transform:none}
  .js .reveal[data-d="1"]{transition-delay:.08s}
  .js .reveal[data-d="2"]{transition-delay:.16s}
  .js .reveal[data-d="3"]{transition-delay:.24s}
  .js .reveal[data-d="4"]{transition-delay:.32s}

  /* ---------- responsive ---------- */
  @media(max-width:920px){
    .hero-grid{grid-template-columns:1fr;text-align:center}
    .hero p.lede{margin-left:auto;margin-right:auto}
    .hero-ctas{justify-content:center}
    .portrait{margin-top:46px;order:-1}
    .about-intro{grid-template-columns:1fr;gap:30px;text-align:center}
    .about-photo{order:-1}
    .about-lead .eyebrow{justify-content:center}
    .about-lead .btn{margin:0 auto}
    .about-highlights{grid-template-columns:repeat(2,1fr);gap:24px 18px}
    .values-grid{grid-template-columns:repeat(2,1fr)}
    .follow-inner{grid-template-columns:1fr;gap:30px}
    .feature{grid-template-columns:1fr}
    .feature .fart{order:-1;min-height:200px}
    .prod-grid{grid-template-columns:repeat(2,1fr)}
    .train-grid{grid-template-columns:repeat(2,1fr)}
    .life-grid{grid-template-columns:1fr}
    .t-grid{columns:2}
    .contact-grid{grid-template-columns:1fr}
    .meet{max-width:min(92vw,440px);text-align:center}
    .meet .eyebrow{justify-content:center}
  }
  @media(max-width:680px){
    .nav-links{
      position:fixed;inset:0 0 0 auto;width:min(78vw,320px);
      background:var(--paper);flex-direction:column;align-items:flex-start;justify-content:center;
      padding:0 40px;gap:26px;transform:translateX(100%);transition:transform .45s var(--ease);
      box-shadow:-20px 0 60px -20px rgba(74,82,54,.3);
    }
    .nav-links.open{transform:translateX(0)}
    .nav-links a.lnk{font-size:1.3rem;font-family:var(--f-display)}
    .nav-links .btn{margin-top:8px}
    .burger{display:flex}
    .badge.top{top:-14px;left:-6px}
    .badge.bot{bottom:-12px;right:-2px}
    .t-grid{columns:1}
    .train-grid{grid-template-columns:1fr}
    .form-row{grid-template-columns:1fr;gap:0}
    .values-grid{grid-template-columns:1fr}
    .nav-links .nav-social{margin-top:10px;gap:22px}
    .nav-links .nav-social svg{width:26px;height:26px}
  }

  @media(prefers-reduced-motion:reduce){
    *{animation:none!important;transition-duration:.01ms!important;scroll-behavior:auto}
    .reveal{opacity:1;transform:none}
  }

  /* ---------- active nav (multi-page) ---------- */
  .nav-links a.lnk.active{color:var(--berry)}
  .nav-links a.lnk.active::after{width:100%}
