/* ============================================================
   Simply Suj — SujFromScratch
   "Fresh Market editorial" design system
   ============================================================ */

/* ---------- Fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700;9..144,900&family=Hanken+Grotesk:wght@400;500;600;700;800&family=Space+Mono:wght@400;700&display=swap');

/* ---------- Tokens ---------- */
:root{
  --paper:#FCF9F2;
  --paper-2:#F4EEE0;
  --card:#FFFFFF;
  --ink:#232A20;
  --ink-soft:#5C6151;
  --green:#3A6B45;
  --green-deep:#2A4F33;
  --persimmon:#E0592A;
  --honey:#E7A93B;
  --berry:#97304C;
  --line:rgba(35,42,32,.12);
  --line-strong:rgba(35,42,32,.22);

  --shadow-sm:0 1px 2px rgba(35,42,32,.06), 0 4px 14px rgba(35,42,32,.06);
  --shadow-md:0 8px 30px rgba(35,42,32,.10);
  --shadow-lg:0 24px 60px rgba(35,42,32,.14);

  --r-sm:10px;
  --r-md:18px;
  --r-lg:28px;
  --r-pill:999px;

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

  --display:'Fraunces',Georgia,serif;
  --body:'Hanken Grotesk',system-ui,sans-serif;
  --mono:'Space Mono',ui-monospace,monospace;

  --ease:cubic-bezier(.2,.7,.2,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  font-size:clamp(16px,1.05vw,17.5px);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
:focus-visible{outline:3px solid var(--persimmon);outline-offset:3px;border-radius:4px}

/* ---------- Type ---------- */
h1,h2,h3{font-family:var(--display);font-weight:600;line-height:1.04;letter-spacing:-.01em;margin:0}
h1{font-size:clamp(2.7rem,7vw,5.4rem);font-weight:600;letter-spacing:-.025em}
h2{font-size:clamp(2rem,4.4vw,3.4rem)}
h3{font-size:clamp(1.25rem,2vw,1.6rem)}
p{margin:0 0 1.1em}

.eyebrow{
  font-family:var(--mono);
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--green);
  font-weight:700;
  display:inline-flex;align-items:center;gap:.6em;
  margin:0;
}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--persimmon);display:inline-block}
.eyebrow.center::after{content:"";width:26px;height:1.5px;background:var(--persimmon);display:inline-block}

/* ---------- Layout ---------- */
.wrap{width:min(var(--wrap),100% - (var(--gut)*2));margin-inline:auto}
.section{padding:clamp(64px,9vw,128px) 0}
.section--tight{padding:clamp(48px,6vw,80px) 0}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--green);--fg:#fff;
  display:inline-flex;align-items:center;gap:.55em;
  background:var(--bg);color:var(--fg);
  font-weight:700;font-size:.97rem;
  padding:.92em 1.5em;border-radius:var(--r-pill);
  border:1.5px solid var(--bg);
  cursor:pointer;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .2s;
  box-shadow:var(--shadow-sm);
}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn--persimmon{--bg:var(--persimmon)}
.btn--ink{--bg:var(--ink)}
.btn--ghost{--bg:transparent;--fg:var(--ink);border-color:var(--line-strong);box-shadow:none}
.btn--ghost:hover{border-color:var(--ink);background:rgba(35,42,32,.04)}
.btn svg{width:1.05em;height:1.05em}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:60;
  background:color-mix(in srgb,var(--paper) 82%,transparent);
  backdrop-filter:blur(12px) saturate(1.4);
  -webkit-backdrop-filter:blur(12px) saturate(1.4);
  border-bottom:1px solid transparent;
  transition:border-color .3s,background .3s;
}
.site-header.scrolled{border-bottom-color:var(--line);background:color-mix(in srgb,var(--paper) 94%,transparent)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;height:74px}
.brand{display:flex;align-items:center;gap:.7rem;font-family:var(--display);font-weight:600;font-size:1.32rem;letter-spacing:-.01em;color:var(--green-deep)}
.brand img{width:42px;height:42px;border-radius:50%;object-fit:cover;box-shadow:var(--shadow-sm)}
.brand small{font-family:var(--mono);font-size:.58rem;letter-spacing:.2em;color:var(--persimmon);text-transform:uppercase;display:block;font-weight:700;margin-top:2px}
.nav-links{display:flex;align-items:center;gap:2rem;list-style:none;margin:0;padding:0}
.nav-links a{font-weight:600;font-size:.97rem;position:relative;padding:.3em 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--persimmon);transition:width .25s var(--ease)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:.8rem}
.nav-toggle{display:none;background:none;border:1.5px solid var(--line-strong);border-radius:var(--r-sm);width:46px;height:42px;cursor:pointer;align-items:center;justify-content:center}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{content:"";display:block;width:20px;height:2px;background:var(--ink);transition:.3s var(--ease);position:relative}
.nav-toggle span::before{position:absolute;top:-6px}
.nav-toggle span::after{position:absolute;top:6px}
.nav-toggle[aria-expanded="true"] span{background:transparent}
.nav-toggle[aria-expanded="true"] span::before{top:0;transform:rotate(45deg)}
.nav-toggle[aria-expanded="true"] span::after{top:0;transform:rotate(-45deg)}

/* ---------- Seal / signature stamp ---------- */
.seal{width:var(--seal,148px);height:var(--seal,148px);position:relative;display:grid;place-items:center}
.seal svg{width:100%;height:100%;animation:spin 26s linear infinite}
.seal .seal-core{
  position:absolute;inset:0;margin:auto;width:42%;height:42%;
  display:grid;place-items:center;border-radius:50%;
  background:var(--persimmon);color:#fff;
}
.seal .seal-core svg{width:54%;height:54%;animation:none}
@keyframes spin{to{transform:rotate(-360deg)}}

/* ---------- Hero ---------- */
.hero{position:relative;padding-top:clamp(40px,6vw,72px);padding-bottom:clamp(56px,8vw,104px);overflow:hidden}
.hero::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(60% 50% at 88% 8%,rgba(231,169,59,.16),transparent 70%),
    radial-gradient(50% 45% at 8% 92%,rgba(58,107,69,.10),transparent 70%);
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,56px);align-items:center}
.hero-copy h1{margin:.28em 0 .42em}
.hero-copy h1 em{font-style:italic;color:var(--persimmon);font-weight:500}
.hero-lead{font-size:clamp(1.05rem,1.5vw,1.22rem);color:var(--ink-soft);max-width:34ch;margin-bottom:1.7em}
.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem;align-items:center}
.hero-meta{margin-top:1.9em;display:flex;gap:1.4rem;flex-wrap:wrap;font-family:var(--mono);font-size:.74rem;letter-spacing:.06em;color:var(--ink-soft)}
.hero-meta b{color:var(--ink)}

/* hero visual */
.hero-visual{position:relative}
.media-frame{
  position:relative;aspect-ratio:4/5;border-radius:var(--r-lg);
  background:
    repeating-linear-gradient(135deg,rgba(58,107,69,.05) 0 14px,transparent 14px 28px),
    var(--paper-2);
  border:2px dashed var(--line-strong);
  display:grid;place-items:center;text-align:center;padding:1.4rem;
  box-shadow:var(--shadow-md);
  overflow:hidden;
}
.media-frame .ph{font-family:var(--mono);font-size:.78rem;letter-spacing:.04em;color:var(--ink-soft);max-width:24ch;line-height:1.5}
.media-frame .ph b{display:block;font-size:1.6rem;color:var(--green);margin-bottom:.4em}
.hero-visual .seal{position:absolute;left:-34px;bottom:-30px;--seal:152px;filter:drop-shadow(0 10px 22px rgba(35,42,32,.18))}

/* marquee strip */
.strip{background:var(--green-deep);color:#fff;overflow:hidden;border-block:1px solid rgba(255,255,255,.08)}
.strip-track{display:flex;gap:3rem;white-space:nowrap;padding:.9rem 0;font-family:var(--mono);font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;animation:slide 32s linear infinite}
.strip-track span{display:inline-flex;align-items:center;gap:3rem;opacity:.92}
.strip-track .dot{width:6px;height:6px;border-radius:50%;background:var(--honey);display:inline-block}
@keyframes slide{to{transform:translateX(-50%)}}

/* ---------- Pillars ---------- */
.section-head{max-width:60ch}
.section-head.center{margin-inline:auto;text-align:center}
.section-head h2{margin:.4em 0 .35em}
.section-head p{color:var(--ink-soft);font-size:1.08rem}

.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;margin-top:clamp(32px,4vw,56px)}
.pillar{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);
  padding:1.6rem 1.4rem 1.7rem;position:relative;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;
}
.pillar:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:transparent}
.pillar .tag{
  font-family:var(--mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--persimmon);font-weight:700;
  position:absolute;top:1.1rem;right:1.2rem;
}
.pillar-ic{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;background:rgba(58,107,69,.10);color:var(--green);margin-bottom:1rem}
.pillar-ic svg{width:24px;height:24px}
.pillar h3{font-size:1.18rem;margin-bottom:.4em}
.pillar p{font-size:.95rem;color:var(--ink-soft);margin:0}

/* ---------- Meet Suj / stats ---------- */
.meet{background:var(--paper-2)}
.meet-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(32px,5vw,72px);align-items:center}
.meet-portrait .media-frame{aspect-ratio:3/4}
.meet-copy h2{margin-bottom:.45em}
.meet-copy p{color:var(--ink-soft);font-size:1.08rem;max-width:46ch}
.stats{display:grid;grid-template-columns:repeat(5,1fr);gap:.7rem;margin:1.8rem 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:1.4rem 0}
.stat{text-align:center}
.stat b{display:block;font-family:var(--display);font-size:clamp(1.9rem,3vw,2.6rem);font-weight:600;color:var(--green);line-height:1}
.stat small{font-family:var(--mono);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin-top:.5em;display:block}
.stat:nth-child(odd) b{color:var(--persimmon)}

/* ---------- Feed grid ---------- */
.feed-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:clamp(32px,4vw,52px)}
.reel{
  aspect-ratio:9/16;border-radius:var(--r-md);overflow:hidden;position:relative;
  background:var(--paper-2);border:2px dashed var(--line-strong);
  display:grid;place-items:center;text-align:center;padding:1.2rem;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.reel:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.reel .ph{font-family:var(--mono);font-size:.72rem;color:var(--ink-soft);letter-spacing:.03em;line-height:1.5}
.reel .ph .play{width:48px;height:48px;border-radius:50%;background:var(--persimmon);color:#fff;display:grid;place-items:center;margin:0 auto .8em}
.reel .ph .play svg{width:20px;height:20px}
.reel .badge{position:absolute;top:.7rem;left:.7rem;font-family:var(--mono);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;background:var(--ink);color:#fff;padding:.3em .7em;border-radius:var(--r-pill)}
.feed-cta{text-align:center;margin-top:2.2rem;display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}

/* ---------- For Brands one-sheet ---------- */
.brands{background:var(--green-deep);color:#fff;position:relative;overflow:hidden}
.brands::before{content:"";position:absolute;inset:0;background:radial-gradient(50% 60% at 85% 10%,rgba(231,169,59,.18),transparent 70%);z-index:0}
.brands .wrap{position:relative;z-index:1}
.brands .eyebrow{color:var(--honey)}
.brands .eyebrow::before{background:var(--honey)}
.brands h2{color:#fff;max-width:18ch}
.brands-lead{color:rgba(255,255,255,.78);font-size:1.12rem;max-width:48ch;margin-top:.7em}
.brands-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,56px);margin-top:clamp(36px,4vw,56px);align-items:start}
.offer-list{list-style:none;margin:0;padding:0;display:grid;gap:.2rem}
.offer-list li{display:flex;gap:.9rem;align-items:flex-start;padding:.85rem 0;border-bottom:1px solid rgba(255,255,255,.12)}
.offer-list li:last-child{border-bottom:0}
.offer-list .num{font-family:var(--mono);font-size:.72rem;color:var(--honey);padding-top:.25em;min-width:2.2em}
.offer-list b{display:block;font-size:1.05rem}
.offer-list span{color:rgba(255,255,255,.72);font-size:.92rem}
.fit-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:var(--r-lg);padding:clamp(24px,3vw,38px)}
.fit-card h3{color:#fff;font-size:1.3rem;margin-bottom:.7em}
.chips{display:flex;flex-wrap:wrap;gap:.55rem;margin-bottom:1.6rem}
.chip{font-family:var(--mono);font-size:.72rem;letter-spacing:.04em;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);color:#fff;padding:.5em .9em;border-radius:var(--r-pill)}
.fit-card .btn{width:100%;justify-content:center}
.fit-note{font-family:var(--mono);font-size:.7rem;color:rgba(255,255,255,.55);margin-top:1rem;text-align:center;letter-spacing:.04em}

/* ---------- Subscribe / footer ---------- */
.subscribe{text-align:center}
.subscribe .card{
  max-width:640px;margin:0 auto;background:var(--card);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:clamp(32px,5vw,56px);box-shadow:var(--shadow-sm);position:relative
}
.subscribe .seal{position:absolute;top:-40px;right:-22px;--seal:96px}
.sub-form{display:flex;gap:.6rem;max-width:430px;margin:1.5rem auto 0;flex-wrap:wrap}
.sub-form input{
  flex:1;min-width:200px;padding:.9em 1.1em;border-radius:var(--r-pill);border:1.5px solid var(--line-strong);
  font-family:inherit;font-size:1rem;background:var(--paper)
}
.sub-form input:focus{outline:none;border-color:var(--green)}
.sub-note{font-family:var(--mono);font-size:.68rem;color:var(--ink-soft);margin-top:1rem;letter-spacing:.03em}

.site-footer{background:var(--ink);color:rgba(255,255,255,.82);padding:clamp(56px,7vw,88px) 0 2rem}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.12)}
.footer-brand{display:flex;align-items:center;gap:.7rem;font-family:var(--display);font-size:1.3rem;color:#fff;margin-bottom:1rem}
.footer-brand img{width:44px;height:44px;border-radius:50%;object-fit:cover}
.footer-blurb{color:rgba(255,255,255,.6);font-size:.95rem;max-width:34ch}
.footer-col h4{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--honey);margin:0 0 1rem}
.footer-col ul{list-style:none;margin:0;padding:0;display:grid;gap:.7rem}
.footer-col a{color:rgba(255,255,255,.78);font-size:.95rem}
.footer-col a:hover{color:#fff}
.socials{display:flex;gap:.6rem;margin-top:.4rem}
.socials a{width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.08);display:grid;place-items:center;transition:background .25s,transform .25s}
.socials a:hover{background:var(--persimmon);transform:translateY(-3px)}
.socials svg{width:19px;height:19px;fill:#fff}
.footer-bottom{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding-top:1.6rem;font-family:var(--mono);font-size:.72rem;letter-spacing:.04em;color:rgba(255,255,255,.5)}
.footer-bottom a{color:rgba(255,255,255,.7)}

/* ---------- About page ---------- */
.about-hero{padding:clamp(48px,7vw,92px) 0 clamp(32px,4vw,48px);position:relative;overflow:hidden}
.about-hero::before{content:"";position:absolute;inset:0;z-index:-1;background:radial-gradient(55% 60% at 80% 0%,rgba(231,169,59,.14),transparent 70%)}
.about-hero .eyebrow{margin-bottom:1.2em}
.about-hero h1{max-width:16ch}
.about-hero .lead{font-size:clamp(1.15rem,1.8vw,1.4rem);color:var(--green-deep);font-family:var(--display);font-style:italic;font-weight:400;max-width:42ch;margin-top:.6em}
.about-body{max-width:720px;margin:0 auto}
.about-body .media-frame{aspect-ratio:16/10;margin-bottom:clamp(32px,4vw,52px)}
.about-body p{font-size:1.12rem;color:#33392d;margin-bottom:1.3em}
.about-body p:first-of-type::first-letter{
  font-family:var(--display);font-size:3.4em;line-height:.74;float:left;
  padding:.06em .12em 0 0;color:var(--persimmon);font-weight:600
}
.about-body .pull{
  font-family:var(--display);font-size:clamp(1.4rem,2.4vw,1.9rem);line-height:1.3;color:var(--green-deep);
  border-left:3px solid var(--persimmon);padding:.2em 0 .2em 1.1em;margin:2em 0;font-weight:500
}
.about-body .ps{margin-top:2.5em;padding-top:1.8em;border-top:1px solid var(--line)}
.about-body .ps b.label{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--green);display:block;margin-bottom:.6em}
.about-body strong{color:var(--green-deep)}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:2.5rem}
  .hero-visual{max-width:440px;margin:0 auto;width:100%}
  .pillars{grid-template-columns:1fr 1fr}
  .meet-grid{grid-template-columns:1fr;gap:2.5rem}
  .meet-portrait{max-width:380px;margin:0 auto;width:100%}
  .brands-grid{grid-template-columns:1fr}
  .feed-grid{grid-template-columns:1fr 1fr}
  .footer-top{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .nav-links,.nav-cta .btn{display:none}
  .nav-toggle{display:flex}
  .mobile-menu{
    position:fixed;inset:74px 0 auto 0;background:var(--paper);
    border-bottom:1px solid var(--line);box-shadow:var(--shadow-lg);
    transform:translateY(-120%);transition:transform .35s var(--ease);z-index:55;
    padding:1.4rem var(--gut) 2rem
  }
  .mobile-menu.open{transform:translateY(0)}
  .mobile-menu ul{list-style:none;margin:0 0 1.4rem;padding:0;display:grid;gap:.2rem}
  .mobile-menu a{display:block;padding:.85rem 0;font-family:var(--display);font-size:1.5rem;border-bottom:1px solid var(--line)}
  .mobile-menu .btn{width:100%;justify-content:center}
  .stats{grid-template-columns:repeat(3,1fr);gap:1.2rem .7rem}
  .feed-grid{grid-template-columns:1fr 1fr}
  .hero-visual .seal{--seal:108px;left:-14px;bottom:-18px}
  .footer-top{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:.5rem}
}
@media(min-width:681px){.mobile-menu{display:none}}

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

/* ============================================================
   ADDITIONS — alert, real images, hire, contact, legal, 404
   ============================================================ */

/* ---------- Newsletter alert bar ---------- */
.alert{background:var(--green-deep);color:#fff;font-size:.9rem}
.alert.hidden{display:none}
.alert-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:46px;padding:.5rem 0}
.alert-inner p{margin:0;color:rgba(255,255,255,.92)}
.alert-inner strong{color:#fff}
.alert-tag{font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;background:var(--honey);color:var(--ink);font-weight:700;padding:.3em .7em;border-radius:var(--r-pill);margin-right:.7em}
.alert-x{background:none;border:0;color:rgba(255,255,255,.7);font-size:1.5rem;line-height:1;cursor:pointer;padding:.1em .3em;border-radius:6px;flex-shrink:0}
.alert-x:hover{color:#fff}

/* ---------- Real images in frames ---------- */
.media-frame.has-img{border:0;padding:0;background:var(--paper-2)}
.media-frame.has-img img{width:100%;height:100%;object-fit:cover}

/* ---------- Coming-soon subscribe ---------- */
.subscribe .card.coming .cs-badge{
  display:inline-block;font-family:var(--mono);font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--persimmon);font-weight:700;border:1.5px solid var(--persimmon);border-radius:var(--r-pill);
  padding:.4em .9em;margin-bottom:1rem
}
.subscribe .card .feed-cta{margin-top:1.6rem}

/* ---------- Page hero (shared, secondary pages) ---------- */
.page-hero{padding:clamp(44px,6vw,84px) 0 clamp(28px,3vw,44px);position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;z-index:-1;background:radial-gradient(55% 60% at 82% 0%,rgba(231,169,59,.14),transparent 70%)}
.page-hero .eyebrow{margin-bottom:1.1em}
.page-hero h1{max-width:16ch;font-size:clamp(2.4rem,5.5vw,4.2rem)}
.page-hero .lead{font-size:clamp(1.08rem,1.6vw,1.32rem);color:var(--ink-soft);max-width:48ch;margin-top:.7em}

/* ---------- HIRE page ---------- */
.hire-intro{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(32px,5vw,64px);align-items:center}
.hire-intro .media-frame{aspect-ratio:4/5}
.hire-intro h2{margin-bottom:.4em}
.hire-intro p{color:var(--ink-soft);font-size:1.08rem;max-width:46ch}
.hire-points{list-style:none;padding:0;margin:1.4rem 0 0;display:grid;gap:.7rem}
.hire-points li{display:flex;gap:.7rem;align-items:flex-start;font-weight:600}
.hire-points svg{width:22px;height:22px;color:var(--green);flex-shrink:0;margin-top:2px}

.deliverables{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;margin-top:clamp(32px,4vw,52px)}
.deliv{background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);padding:1.6rem 1.4rem}
.deliv .num{font-family:var(--mono);font-size:.72rem;color:var(--persimmon);font-weight:700;letter-spacing:.1em}
.deliv h3{font-size:1.15rem;margin:.5em 0 .3em}
.deliv p{font-size:.94rem;color:var(--ink-soft);margin:0}

.process{background:var(--paper-2)}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;margin-top:clamp(32px,4vw,52px);counter-reset:step}
.pstep{position:relative;padding-top:3.2rem}
.pstep::before{counter-increment:step;content:counter(step,decimal-leading-zero);position:absolute;top:0;left:0;font-family:var(--display);font-size:2.4rem;font-weight:600;color:var(--green);opacity:.9}
.pstep::after{content:"";position:absolute;top:1.5rem;left:3.4rem;right:-.55rem;height:1.5px;background:var(--line-strong)}
.process-steps .pstep:last-child::after{display:none}
.pstep h3{font-size:1.1rem;margin-bottom:.3em}
.pstep p{font-size:.92rem;color:var(--ink-soft);margin:0}

.cta-band{background:var(--green-deep);color:#fff;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(50% 70% at 50% 0%,rgba(231,169,59,.16),transparent 70%)}
.cta-band .wrap{position:relative;z-index:1}
.cta-band h2{color:#fff;max-width:20ch;margin:0 auto .5em}
.cta-band p{color:rgba(255,255,255,.78);max-width:46ch;margin:0 auto 1.8rem}
.cta-band .feed-cta{margin-top:0}

/* ---------- CONTACT page ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem;margin-top:clamp(28px,3vw,44px)}
.contact-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(26px,3vw,38px);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.contact-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.contact-card .ic{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;background:rgba(58,107,69,.10);color:var(--green);margin-bottom:1rem}
.contact-card .ic svg{width:26px;height:26px}
.contact-card.biz .ic{background:rgba(224,89,42,.12);color:var(--persimmon)}
.contact-card h3{font-size:1.3rem;margin-bottom:.3em}
.contact-card p{color:var(--ink-soft);margin-bottom:1rem}
.contact-card .email-link{font-family:var(--mono);font-size:1rem;font-weight:700;color:var(--ink);display:inline-flex;align-items:center;gap:.5em}
.contact-card .email-link:hover{color:var(--persimmon)}
.contact-socials{display:flex;gap:.7rem;justify-content:center;margin-top:clamp(32px,4vw,48px);flex-wrap:wrap}
.contact-socials a{display:inline-flex;align-items:center;gap:.55em;font-weight:600;border:1.5px solid var(--line-strong);padding:.7em 1.2em;border-radius:var(--r-pill);transition:border-color .2s,transform .2s,background .2s}
.contact-socials a:hover{border-color:var(--ink);transform:translateY(-2px);background:rgba(35,42,32,.03)}
.contact-socials svg{width:18px;height:18px}

/* ---------- LEGAL pages ---------- */
.legal{max-width:760px;margin:0 auto}
.legal .updated{font-family:var(--mono);font-size:.74rem;letter-spacing:.06em;color:var(--ink-soft);margin-bottom:2.4rem;padding-bottom:1.4rem;border-bottom:1px solid var(--line)}
.legal h2{font-size:clamp(1.4rem,2.4vw,1.9rem);margin:2.2em 0 .5em}
.legal h2:first-of-type{margin-top:0}
.legal h3{font-size:1.15rem;margin:1.6em 0 .4em}
.legal p,.legal li{color:#33392d;font-size:1.02rem}
.legal ul{padding-left:1.2rem;margin:0 0 1.2em}
.legal li{margin-bottom:.5em}
.legal a{color:var(--green);text-decoration:underline;text-underline-offset:2px}
.legal .note{background:var(--paper-2);border-left:3px solid var(--honey);border-radius:0 var(--r-sm) var(--r-sm) 0;padding:1rem 1.3rem;font-size:.95rem;color:var(--ink-soft);margin:1.6em 0}

/* ---------- 404 ---------- */
.nf{min-height:62vh;display:grid;place-items:center;text-align:center;padding:4rem 0}
.nf .big{font-family:var(--display);font-size:clamp(5rem,18vw,11rem);line-height:.9;color:var(--green);font-weight:600}
.nf .big em{color:var(--persimmon);font-style:italic}
.nf p{color:var(--ink-soft);font-size:1.1rem;max-width:40ch;margin:1rem auto 1.8rem}

/* ---------- responsive additions ---------- */
@media(max-width:980px){
  .hire-intro{grid-template-columns:1fr;gap:2.2rem}
  .hire-intro .media-frame{max-width:420px;margin:0 auto;width:100%;aspect-ratio:4/3}
  .deliverables{grid-template-columns:1fr 1fr}
  .process-steps{grid-template-columns:1fr 1fr;gap:2rem 1.1rem}
  .pstep::after{display:none}
  .contact-grid{grid-template-columns:1fr}
}
@media(max-width:680px){
  .alert-inner p{font-size:.82rem}
  .deliverables{grid-template-columns:1fr}
  .process-steps{grid-template-columns:1fr}
}
