/* ============================================================
   THE TONE DOCTRINE  —  styles.css
   Built from Figma "The Tone Doctrine" (fileKey 3njAlgrzGJSspLn0AP2w7B)
   Two explicit layouts: mobile-first base + desktop at min-width 769px.
   TTD's own brand identity — not Syntri Labs tokens.
   ============================================================ */

/* ---------- Self-hosted fonts (see fonts/, font-display: swap) ---------- */
@font-face{
  font-family:"Fraunces";
  src:url("../fonts/fraunces-var-latin.woff2") format("woff2");
  font-weight:100 900; font-style:normal; font-stretch:normal; font-display:swap;
}
@font-face{
  font-family:"Fraunces";
  src:url("../fonts/fraunces-var-latin-italic.woff2") format("woff2");
  font-weight:100 900; font-style:italic; font-stretch:normal; font-display:swap;
}
@font-face{
  font-family:"Manrope";
  src:url("../fonts/manrope-var-latin.woff2") format("woff2");
  font-weight:200 800; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Alex Brush";
  src:url("../fonts/alex-brush-latin-400.woff2") format("woff2");
  font-weight:400; font-style:normal; font-display:swap;
}

/* ---------- Design tokens ---------- */
:root{
  /* colour */
  --cream:#F7F2EC;
  --cream-panel:#FFFFFF;
  --cream-tint:#FBF7F1;
  --ink:#2A2522;
  --accent:#D07E6A;
  --accent-ink:#2A2522;         /* text on accent buttons */
  --text:#574F47;               /* body copy on cream */
  --text-muted:#9A8F84;         /* captions / meta */
  --on-dark:#F7F2EC;            /* text on ink */
  --on-dark-dim:#C7BDB5;        /* subcopy on ink */
  --line:#E7DDD1;               /* hairlines on cream */
  --line-dark:rgba(247,242,236,0.14);
  --placeholder:#E7DED4;
  --wm-light:rgba(42,37,34,0.045);   /* watermark word on cream */
  --wm-dark:rgba(247,242,236,0.05);  /* watermark word on ink */

  /* type */
  --font-display:"Fraunces", Georgia, "Times New Roman", serif;
  --font-body:"Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --font-script:"Alex Brush", "Snell Roundhand", cursive;

  /* rhythm */
  --wrap:1120px;
  --gutter:clamp(20px, 5vw, 40px);
  --section-y:clamp(64px, 8vw, 104px);
  --radius:26px;

  --shadow-soft:0 18px 50px -24px rgba(42,37,34,0.30);
  --shadow-bar:0 -8px 30px -18px rgba(42,37,34,0.45);
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.6;
  color:var(--text);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{margin:0;padding:0;list-style:none}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}

/* ---------- Layout ---------- */
.wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:var(--gutter)}
.section{position:relative;padding-block:var(--section-y);overflow:hidden}
.section--ink{background:var(--ink);color:var(--on-dark)}
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* ---------- Typography ---------- */
.eyebrow{
  font-family:var(--font-display);
  font-style:italic;
  font-weight:400;
  color:var(--accent);
  font-size:clamp(1.15rem,1rem + 1vw,1.625rem);
  letter-spacing:.01em;
  margin:0 0 .6rem;
  font-variation-settings:"opsz" 30,"SOFT" 0,"WONK" 1;
}
.h2{
  font-family:var(--font-display);
  font-weight:400;
  font-size:clamp(1.9rem,1.4rem + 2.2vw,2.375rem);
  line-height:1.12;
  letter-spacing:-0.02em;
  color:var(--ink);
  margin:0;
  font-variation-settings:"opsz" 40,"SOFT" 0,"WONK" 1;
}
.section--ink .h2{color:var(--on-dark)}
.h3{
  font-family:var(--font-display);
  font-weight:400;
  font-size:1.375rem;
  line-height:1.3;
  letter-spacing:-0.01em;
  color:var(--ink);
  margin:0;
  font-variation-settings:"opsz" 24,"SOFT" 0,"WONK" 1;
}
.h2 em,.hero__title em,.display em{font-style:italic;font-variation-settings:"opsz" 40,"SOFT" 0,"WONK" 1}
.lead{font-size:clamp(1rem,.95rem + .4vw,1.125rem);line-height:1.65}
.meta{
  font-family:var(--font-body);
  font-weight:600;
  font-size:.75rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--text-muted);
}
.section-head{max-width:640px;margin-bottom:clamp(32px,4vw,56px)}
.section-head .h2{margin-top:.1rem}

/* Big faint watermark words */
.watermark{
  position:absolute;
  font-family:var(--font-display);
  font-weight:400;
  font-style:normal;
  line-height:1;
  letter-spacing:-0.03em;
  color:var(--wm-light);
  pointer-events:none;
  user-select:none;
  z-index:0;
  white-space:nowrap;
  font-size:clamp(120px,26vw,360px);
  font-variation-settings:"opsz" 144,"SOFT" 0,"WONK" 0;
}
.section--ink .watermark{color:var(--wm-dark)}
.wrap,.section-head,.about__grid,.pillars,.services__grid,.whyme__grid,
.portfolio-inner,.reviews-inner,.pricing-inner,.faq,.booking__grid,.ig-inner,.footer__row{position:relative;z-index:1}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--font-body);font-weight:600;font-size:.9375rem;
  letter-spacing:.08em;text-transform:uppercase;
  padding:16px 28px;border-radius:var(--radius);
  transition:transform .2s ease,background-color .2s ease,color .2s ease,opacity .2s ease;
  line-height:1;white-space:nowrap;
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn--primary{background:var(--ink);color:var(--on-dark)}
.btn--primary:hover{background:#3a332e}
.btn--accent{background:var(--accent);color:var(--accent-ink)}
.btn--accent:hover{background:#d98a76}
.btn--outline{background:transparent;color:var(--on-dark);border:1px solid var(--on-dark)}
.btn--outline:hover{background:var(--on-dark);color:var(--ink)}
.btn--outline-ink{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.btn--outline-ink:hover{background:var(--ink);color:var(--on-dark)}
.btn--sm{padding:13px 22px;font-size:.8125rem}
.btn--full{width:100%}

/* ============================================================
   HEADER  (transparent over hero)
   ============================================================ */
.site-header{
  position:absolute;top:0;left:0;right:0;z-index:20;
}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;padding-block:26px}
.wordmark{
  font-family:var(--font-script);
  font-size:clamp(1.75rem,1.4rem + 1.6vw,2.25rem);
  color:var(--on-dark);
  line-height:1;letter-spacing:.01em;
}
.nav{display:flex;align-items:center;gap:12px}
.nav a{font-size:.875rem;color:var(--on-dark);opacity:.9;transition:opacity .2s}
.nav a:hover{opacity:1}
.nav a:not(.header-book){display:none}       /* mobile: hide text links, keep Book */
.nav .btn{margin-left:4px}
.header-book{padding:12px 22px;border-radius:20px;font-size:.8125rem}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;color:var(--on-dark);overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img,.hero__media video{width:100%;height:100%;object-fit:cover}
.hero__scrim{position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(90deg, rgba(20,17,15,.72) 0%, rgba(20,17,15,.42) 42%, rgba(20,17,15,.12) 100%),
    linear-gradient(180deg, rgba(20,17,15,.35) 0%, rgba(20,17,15,0) 30%, rgba(20,17,15,.35) 100%);
}
.hero .wrap{position:relative;z-index:2;width:100%;padding-block:clamp(120px,18vh,160px) clamp(96px,14vh,120px)}
.hero__inner{max-width:820px}
.hero__kicker{
  font-family:var(--font-display);font-style:italic;color:var(--accent);
  font-size:clamp(1.15rem,1rem + 1vw,1.625rem);margin:0 0 1rem;
  font-variation-settings:"opsz" 28,"SOFT" 0,"WONK" 1;
}
.hero__title{
  font-family:var(--font-display);font-weight:300;
  font-size:clamp(2.6rem,1.3rem + 6.2vw,4.875rem);
  line-height:1.04;letter-spacing:-0.02em;margin:0;color:var(--on-dark);
  text-shadow:0 2px 16px rgba(0,0,0,.35);
  font-variation-settings:"opsz" 72,"SOFT" 0,"WONK" 1;
}
.hero__title em{font-weight:300;font-style:italic}
.hero__sub{font-size:clamp(1.05rem,1rem + .4vw,1.125rem);line-height:1.6;margin:1.4rem 0 0;max-width:34ch;text-shadow:0 1px 10px rgba(0,0,0,.3)}
.hero__creds{font-size:.875rem;opacity:.82;margin:1.1rem 0 0;letter-spacing:.01em}
.hero__ctas{display:flex;flex-direction:column;gap:12px;margin-top:2rem}
.hero__play{
  position:absolute;z-index:3;right:var(--gutter);bottom:clamp(96px,14vh,120px);
  width:56px;height:56px;border-radius:50%;
  display:none;align-items:center;justify-content:center;
  background:rgba(247,242,236,.16);backdrop-filter:blur(6px);
  border:1px solid rgba(247,242,236,.5);color:var(--on-dark);
}
.hero__play svg{width:20px;height:20px}

/* ============================================================
   ABOUT
   ============================================================ */
.about{background:var(--cream)}
.about .eyebrow{text-align:left}
.about__head{text-align:center;margin-bottom:clamp(28px,3vw,40px)}
.about__grid{display:grid;grid-template-columns:1fr;gap:clamp(28px,4vw,56px);align-items:start}
.portrait{position:relative}
.portrait__frame{position:relative;border-radius:8px;overflow:hidden;box-shadow:var(--shadow-soft)}
.portrait__frame img{width:100%;aspect-ratio:46/56;object-fit:cover}
.portrait__block{position:absolute;left:-14px;bottom:-18px;width:70%;height:60%;background:#E4D4C1;border-radius:8px;z-index:-1}
.about__body p{color:var(--text)}
.about__body .h2{margin-bottom:1rem}
.pullquote{
  font-family:var(--font-display);font-style:italic;font-size:clamp(1.15rem,1rem + .8vw,1.375rem);
  line-height:1.4;color:var(--ink);margin:1.6rem 0;position:relative;padding-top:1.6rem;
  font-variation-settings:"opsz" 28,"SOFT" 0,"WONK" 1;
}
.pullquote::before{content:"\201C";position:absolute;top:-.3rem;left:0;font-size:2.4rem;color:var(--accent);line-height:1}
.credentials .meta{display:block;margin-bottom:.9rem}
.pills{display:flex;flex-wrap:wrap;gap:10px}
.pill{border:1px solid var(--line);border-radius:20px;padding:8px 16px;font-size:.875rem;color:var(--text)}

/* how i work */
.about__divider{height:1px;background:var(--line);margin-block:clamp(48px,6vw,72px)}
.pillars{display:grid;grid-template-columns:1fr;gap:clamp(28px,4vw,40px);margin-top:clamp(28px,3vw,44px)}
.pillar__rule{width:40px;height:2px;background:var(--accent);margin-bottom:1rem}
.pillar .h3{margin-bottom:.6rem}
.pillar p{margin:0;color:var(--text);font-size:.9375rem}

/* ============================================================
   SERVICES
   ============================================================ */
.services__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2.4vw,30px)}
.service-card{display:flex;flex-direction:column}
.service-card__img{border-radius:6px;overflow:hidden;margin-bottom:1rem}
.service-card__img img{width:100%;aspect-ratio:250/300;object-fit:cover;transition:transform .5s ease}
.service-card:hover .service-card__img img{transform:scale(1.04)}
.service-card__no{color:var(--accent);font-size:.75rem;letter-spacing:.12em;margin-bottom:.4rem}
.service-card .h3{margin-bottom:.5rem;font-size:1.125rem}
.service-card p{margin:0 0 1rem;font-size:.875rem;color:var(--text)}
.service-card__price{margin-top:auto;color:var(--accent);font-weight:600;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase}

/* ============================================================
   WHY ME  (ink band)
   ============================================================ */
.whyme__grid{display:grid;grid-template-columns:1fr;gap:clamp(32px,5vw,64px)}
.whyme__intro .h2{margin:.4rem 0 1rem}
.whyme__intro p{color:var(--on-dark-dim);max-width:44ch}
.checklist li{display:flex;gap:16px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--line-dark)}
.checklist li:last-child{border-bottom:none}
.checklist svg{flex:none;width:20px;height:20px;color:var(--accent);margin-top:2px}
.checklist span{color:var(--on-dark);font-size:.9375rem}

/* ============================================================
   TICKER
   ============================================================ */
.ticker{background:var(--cream);border-block:1px solid var(--line);overflow:hidden;padding-block:18px}
.ticker__track{display:flex;width:max-content;gap:0;animation:ticker 38s linear infinite}
.ticker__track span{
  font-family:var(--font-body);font-size:.8125rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--text);padding-inline:0;white-space:nowrap;
}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.ticker__track{animation:none;justify-content:center}}

/* ============================================================
   PORTFOLIO
   ============================================================ */
.portfolio{background:var(--cream)}
.sub-label{font-family:var(--font-display);font-style:italic;color:var(--ink);
  font-size:clamp(1.1rem,1rem + .6vw,1.4rem);margin:0 0 1.4rem;
  font-variation-settings:"opsz" 24,"SOFT" 0,"WONK" 1;}
.portfolio-block{margin-top:clamp(40px,5vw,64px)}
.portfolio-block:first-child{margin-top:0}

/* Before/After — interactive comparison slider (drag to reveal; 3:4 = photos shown whole at the edges) */
.ba-grid{display:grid;grid-template-columns:1fr;gap:clamp(20px,3vw,40px)}
.ba{margin:0}
.ba__slider{position:relative;width:100%;aspect-ratio:3/4;border-radius:8px;overflow:hidden;
  user-select:none;touch-action:pan-y;background:var(--placeholder);cursor:ew-resize}
.ba__img{position:absolute;inset:0;width:100%;height:100%}
.ba__img img{width:100%;height:100%;object-fit:cover;object-position:center;pointer-events:none}
.ba__after{clip-path:inset(0 0 0 50%)}
.ba__divider{position:absolute;top:0;bottom:0;left:50%;width:2px;background:var(--cream);transform:translateX(-1px);z-index:3;box-shadow:0 0 8px rgba(0,0,0,.25)}
.ba__handle{position:absolute;top:50%;left:50%;width:44px;height:44px;border-radius:50%;
  transform:translate(-50%,-50%);background:var(--cream);box-shadow:0 2px 12px rgba(0,0,0,.4);
  display:flex;align-items:center;justify-content:center;z-index:4;color:var(--ink);
  animation:baPulse 2.2s ease-in-out infinite}
.ba__handle svg{width:20px;height:20px}
.ba__range{position:absolute;inset:0;width:100%;height:100%;margin:0;opacity:0;cursor:ew-resize;z-index:5}
.ba__tag{position:absolute;top:14px;font-size:.625rem;font-weight:600;letter-spacing:.1em;
  text-transform:uppercase;background:rgba(42,37,34,.7);color:var(--on-dark);padding:5px 8px;border-radius:4px;z-index:2}
.ba__tag--before{left:14px}
.ba__tag--after{right:14px}
.ba__hint{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);z-index:4;pointer-events:none;
  display:flex;align-items:center;gap:6px;white-space:nowrap;
  background:rgba(42,37,34,.72);color:var(--on-dark);padding:8px 14px;border-radius:22px;
  font-family:var(--font-body);font-weight:600;font-size:.6875rem;letter-spacing:.09em;text-transform:uppercase;
  transition:opacity .4s ease;backdrop-filter:blur(2px)}
.ba__hint svg{width:15px;height:15px}
.ba--used .ba__hint{opacity:0}
.ba--used .ba__handle{animation:none}
@keyframes baPulse{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.14)}}
@media (prefers-reduced-motion:reduce){.ba__handle{animation:none}}
.ba figcaption{margin-top:.9rem;font-size:.8125rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}

/* Editorial works grid */
.works{display:grid;grid-template-columns:1fr 1fr;gap:clamp(14px,2vw,20px)}
.works figure{margin:0}
.works__img{border-radius:6px;overflow:hidden}
.works__img img{width:100%;height:100%;object-fit:cover;aspect-ratio:1/1;transition:transform .6s ease}
.works figure:hover .works__img img{transform:scale(1.04)}
.works figcaption{margin-top:.8rem;font-size:.8125rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}

/* Reels strip */
.reels{display:flex;gap:16px;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.reels::-webkit-scrollbar{height:6px}
.reels::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}
.reel{position:relative;flex:0 0 200px;scroll-snap-align:start;border-radius:8px;overflow:hidden;aspect-ratio:220/391}
.reel img{width:100%;height:100%;object-fit:cover}
.reel__play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(42,37,34,.18)}
.reel__play span{width:52px;height:52px;border-radius:50%;background:rgba(247,242,236,.85);display:flex;align-items:center;justify-content:center;color:var(--ink)}
.reel__play svg{width:18px;height:18px;margin-left:2px}
.portfolio__note{margin-top:1rem;font-size:.8125rem;color:var(--text-muted)}
.portfolio__cta{margin-top:clamp(32px,4vw,48px)}

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews{background:var(--cream);text-align:left}
.featured-quote{text-align:center;max-width:920px;margin:clamp(24px,3vw,40px) auto clamp(40px,5vw,56px)}
.featured-quote__mark{font-family:var(--font-display);color:var(--accent);font-size:3rem;line-height:1}
.featured-quote blockquote{
  font-family:var(--font-display);font-style:italic;font-weight:400;
  font-size:clamp(1.6rem,1.1rem + 2.4vw,2.5rem);line-height:1.16;color:var(--ink);margin:.4rem 0 1.2rem;
  font-variation-settings:"opsz" 48,"SOFT" 0,"WONK" 1;
}
.featured-quote cite{font-style:normal;font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted)}
.review-grid{display:grid;grid-template-columns:1fr;gap:clamp(16px,2vw,24px)}
.review-card{background:var(--cream-panel);border:1px solid var(--line);border-radius:8px;padding:28px}
.review-card__stars{color:var(--accent);letter-spacing:.2em;font-size:.875rem;margin-bottom:1rem}
.review-card p{color:var(--ink);margin:0 0 1.4rem;font-size:.9375rem}
.review-card cite{font-style:normal;font-size:.8125rem;color:var(--text-muted)}
.reviews__note{margin-top:clamp(28px,3vw,40px);font-size:.8125rem;color:var(--text-muted)}

/* ============================================================
   PRICING
   ============================================================ */
.pricing{background:var(--cream)}
.price-table{margin-top:8px}
.price-row{display:flex;justify-content:space-between;align-items:baseline;gap:16px;
  padding:18px 0;border-bottom:1px solid var(--line)}
.price-row__name{color:var(--ink);font-size:clamp(.95rem,.9rem + .3vw,1.0625rem)}
.price-row__price{color:var(--ink);font-weight:500;white-space:nowrap;font-size:clamp(.95rem,.9rem + .3vw,1.0625rem)}
.pricing__cta{margin-top:clamp(32px,4vw,44px);display:flex;flex-direction:column;gap:16px;align-items:flex-start}
.pricing__gst{font-size:.8125rem;color:var(--text-muted)}

/* ============================================================
   REFERRAL
   ============================================================ */
.referral{background:var(--cream);padding-block:clamp(32px,4vw,48px)}
.referral__band{background:var(--cream-panel);border:1px solid var(--line);border-radius:12px;
  text-align:center;padding:clamp(32px,4vw,44px) clamp(20px,4vw,40px)}
.referral__band .eyebrow{text-align:center}
.referral__band .h3{margin:.2rem 0 .6rem;font-size:1.5rem}
.referral__band p{margin:0;color:var(--text)}

/* ============================================================
   FAQ
   ============================================================ */
.faq{max-width:860px}
.faq__item{border-top:1px solid var(--line);padding:clamp(24px,3vw,32px) 0}
.faq__item:last-child{border-bottom:1px solid var(--line)}
.faq__item h3{font-family:var(--font-display);font-weight:400;font-size:1.25rem;color:var(--ink);margin:0 0 .7rem;
  font-variation-settings:"opsz" 24,"SOFT" 0,"WONK" 1;}
.faq__item p{margin:0;color:var(--text)}

/* ============================================================
   BOOKING  (ink band)
   ============================================================ */
.booking__grid{display:grid;grid-template-columns:1fr;gap:clamp(32px,5vw,64px);align-items:center}
.booking__copy .eyebrow{color:var(--accent)}
.booking__copy .h2{margin:.4rem 0 1rem}
.booking__copy p{color:var(--on-dark-dim);margin:0 0 1.6rem}
.details{display:grid;gap:22px}
.detail__label{color:var(--accent);font-weight:600;font-size:.75rem;letter-spacing:.09em;text-transform:uppercase;margin-bottom:.35rem}
.detail__value{color:var(--on-dark);font-size:1rem}

/* ============================================================
   INSTAGRAM
   ============================================================ */
.instagram{background:var(--cream)}
.ig-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:12px;margin-bottom:clamp(24px,3vw,32px)}
.ig-head__handle{color:var(--accent);font-size:1.05rem}
.ig-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(10px,1.4vw,16px)}
.ig-cell{position:relative;display:block;border-radius:6px;overflow:hidden;aspect-ratio:1/1;background:var(--placeholder)}
.ig-cell img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.ig-cell:hover img{transform:scale(1.05)}
.ig-cta{margin-top:clamp(24px,3vw,32px)}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--cream);border-top:1px solid var(--line);padding-block:clamp(40px,5vw,56px) clamp(96px,10vw,64px)}
.footer__row{display:flex;flex-direction:column;gap:24px;justify-content:space-between}
.footer__wordmark{font-family:var(--font-script);font-size:2rem;color:var(--ink);line-height:1;margin-bottom:.5rem}
.footer p{margin:.2rem 0;font-size:.875rem;color:var(--text-muted)}
.footer__links{display:flex;gap:18px;flex-wrap:wrap}
.footer__links a{font-size:.875rem;color:var(--ink)}
.footer__links a:hover{color:var(--accent)}

/* ============================================================
   STICKY CTA BAR  (fixed bottom, appears after hero)
   ============================================================ */
.sticky-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:40;
  background:var(--cream);border-top:1px solid var(--line);box-shadow:var(--shadow-bar);
  transform:translateY(110%);transition:transform .35s ease;
  padding:12px var(--gutter);
}
.sticky-cta.is-visible{transform:translateY(0)}
.sticky-cta__inner{max-width:var(--wrap);margin-inline:auto;display:flex;align-items:center;justify-content:space-between;gap:12px}
.sticky-cta__label{display:none;font-family:var(--font-display);font-style:italic;color:var(--ink);font-size:1.1rem}
.sticky-cta__actions{display:flex;align-items:center;gap:10px;flex:1;justify-content:flex-end}
.sticky-cta .btn{flex:1;max-width:280px}
.ig-icon-btn{flex:none;width:48px;height:48px;border-radius:50%;border:1px solid var(--ink);
  display:flex;align-items:center;justify-content:center;color:var(--ink);transition:background-color .2s,color .2s}
.ig-icon-btn:hover{background:var(--ink);color:var(--on-dark)}
.ig-icon-btn svg{width:20px;height:20px}
body{padding-bottom:0}

/* ============================================================
   DESKTOP LAYOUT  (min-width 769px)
   ============================================================ */
@media (min-width:769px){
  .nav{gap:28px}
  .nav a:not(.header-book){display:inline-flex}
  .header-book{display:inline-flex}
  .hero__play{display:flex}
  .hero__ctas{flex-direction:row}
  .hero__ctas .btn{width:auto}

  .about__head{text-align:center}
  .about__grid{grid-template-columns:minmax(0,460px) 1fr;gap:clamp(48px,6vw,80px)}
  .portrait__frame img{aspect-ratio:460/560}
  .pillars{grid-template-columns:repeat(3,1fr);gap:40px}

  .services__grid{grid-template-columns:repeat(4,1fr)}

  .whyme__grid{grid-template-columns:520px 1fr;gap:80px;align-items:start}

  .ba-grid{grid-template-columns:1fr 1fr}

  .works{grid-template-columns:repeat(3,1fr);grid-auto-rows:1fr}
  .works figure{display:flex;flex-direction:column}
  .works__img{flex:1}
  .works figure:nth-child(1){grid-column:span 2;grid-row:span 2}
  .works figure:nth-child(1) .works__img img,
  .works figure:nth-child(2) .works__img img,
  .works figure:nth-child(3) .works__img img{aspect-ratio:auto;height:100%}

  .reel{flex-basis:220px}

  .review-grid{grid-template-columns:repeat(3,1fr)}

  .pricing-inner{max-width:1120px}

  .booking__grid{grid-template-columns:1fr 1fr;gap:80px}
  .details{grid-template-columns:1fr;gap:24px}

  .ig-grid{grid-template-columns:repeat(6,1fr)}

  .footer__row{flex-direction:row;align-items:flex-end}
  .footer__right{text-align:right}
  .footer__links{justify-content:flex-end}

  .sticky-cta__label{display:block}
  .sticky-cta__actions{flex:none}
  .sticky-cta .btn{flex:none;width:auto}
  body{padding-bottom:0}
}

/* Tablet: keep works readable between breakpoints */
@media (min-width:481px) and (max-width:768px){
  .review-grid{grid-template-columns:1fr 1fr}
  .ba-grid{grid-template-columns:1fr 1fr}
}
