/*
Theme Name: SaBoNa
Theme URI: https://sabona.ua/
Author: SaBoNa
Description: Кастомная тема SaBoNa — «нова філософія пакування». Яркая айдентика из логотипа на тёплой бумажной базе, премиальная типографика (Cormorant Garamond + Inter), WooCommerce-ready. Украинский основной язык.
Version: 0.1.0
Requires at least: 6.4
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: sabona
Tags: custom-colors, custom-menu, custom-logo, featured-images, translation-ready, e-commerce
*/

/* ============================================================
   sabona — design tokens (vibrant, logo-driven)
   ============================================================ */
:root{
  --paper:#F5F1E8;
  --oat:#ECE6D8;
  --offwhite:#FCFAF5;
  --ink:#17130F;
  --ink-2:#100D0B;
  --stone:#6E665E;
  --hairline:#E2DACA;

  --paper-dim:#B9B0A6;
  --line-dark:rgba(255,255,255,.14);

  --pink:#EC008C;
  --red:#F0323C;
  --orange:#F7941E;
  --yellow:#FFC400;
  --lime:#8CC63F;
  --green:#1FAE4D;
  --cyan:#00AEEF;
  --blue:#2C5BD6;
  --violet:#9B2D90;

  --brand:#EC008C;
  --brand-strong:#C8017C;
  --accent-dark:#33C0F5;

  --rainbow:linear-gradient(90deg,#EC008C 0%,#F0323C 15%,#F7941E 30%,#FFC400 44%,#8CC63F 58%,#00AEEF 74%,#2C5BD6 88%,#9B2D90 100%);

  --display:'Exo','Inter Tight',sans-serif;
  --serif:'Fira Sans Condensed','Helvetica Neue',Arial,sans-serif;
  --sans:'Inter Tight',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;

  --sp-section:clamp(3.75rem,8vw,8rem);
  --gutter:clamp(1.25rem,5vw,4rem);
  --container:1800px;

  --r:8px;
  --shadow:0 1px 2px rgba(23,19,15,.05), 0 12px 30px -18px rgba(23,19,15,.22);
  --shadow-lift:0 2px 6px rgba(23,19,15,.06), 0 26px 50px -24px rgba(23,19,15,.34);
}

/* ============================================================
   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(--sans);
  font-size:clamp(1rem,.55vw + .9rem,1.075rem);line-height:1.65;
  color:var(--ink);background:var(--paper);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:clip;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
h1,h2,h3,h4,p{margin:0}
ul{margin:0;padding:0;list-style:none}

/* subtle paper grain */
body::after{
  content:"";position:fixed;inset:0;z-index:200;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.03;mix-blend-mode:multiply;
}

/* accessibility */
:focus-visible{outline:2px solid var(--brand);outline-offset:3px;border-radius:3px}
.on-dark :focus-visible{outline-color:var(--accent-dark)}
.skip{position:absolute;left:-9999px;top:0;z-index:300;background:var(--ink-2);color:#fff;padding:.75rem 1.25rem;border-radius:0 0 var(--r) 0}
.skip:focus{left:0}
.screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}

/* admin bar offset for sticky header */
.admin-bar .site-header{top:32px}
@media (max-width:782px){.admin-bar .site-header{top:46px}}

/* ============================================================
   layout primitives
   ============================================================ */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:var(--sp-section);position:relative}
.section--tight{padding-block:clamp(2.5rem,5vw,4rem)}
.divider{height:1px;background:var(--hairline);border:0;margin:0}
.rainbow{height:4px;background:var(--rainbow);border:0}

.eyebrow{
  display:inline-flex;align-items:center;gap:.7em;
  font-size:.72rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--brand-strong);margin:0 0 1.25rem;
}
.eyebrow::before{content:"";width:30px;height:3px;border-radius:2px;background:var(--rainbow);flex:none}
.eyebrow--center{justify-content:center}
.on-dark .eyebrow{color:var(--accent-dark)}

.h-display{font-family:var(--serif);font-weight:500;font-size:clamp(2.4rem,1.4rem + 4.4vw,4.6rem);line-height:1.04;letter-spacing:-.01em}
.h-section{font-family:var(--serif);font-weight:500;font-size:clamp(2rem,1.3rem + 2.6vw,3.25rem);line-height:1.08;letter-spacing:-.005em}
.h-section--sm{font-size:clamp(1.7rem,1.05rem + 2.1vw,2.65rem)}
.h-card{font-family:var(--serif);font-weight:500;font-size:clamp(1.5rem,1.2rem + 1vw,2rem);line-height:1.12}
/* headings in uppercase */
h1,h2,h3,h4,h5,h6,.h-display,.h-section,.h-card{text-transform:uppercase}
.lead{font-size:clamp(1.05rem,.9rem + .6vw,1.3rem);line-height:1.6;color:var(--stone);max-width:60ch}
.why-note{margin-top:.95rem;font-size:1rem;line-height:1.62;color:var(--stone);max-width:60ch}
.hl{color:var(--brand)}
.on-dark .hl{color:var(--accent-dark)}
.hl--rainbow{background:var(--rainbow);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.muted{color:var(--stone)}
.section-head{max-width:66ch}
.section-head--center{margin-inline:auto;text-align:center}

/* ============================================================
   logo wordmark — colourful "sabona." mark (assets/images/logo.svg)
   ============================================================ */
.logo{display:inline-flex;align-items:center;line-height:0;flex-shrink:0}
.logo .logo-mark{display:block;width:150px;height:55px;max-width:none;transition:opacity .2s}
.logo:hover .logo-mark,.logo:focus-visible .logo-mark{opacity:.82}
@media (max-width:560px){.logo .logo-mark{width:122px;height:45px}}
.brand-tagline{font-size:.66rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--paper-dim);margin-top:.6rem}

/* ============================================================
   buttons & links
   ============================================================ */
.btn{
  --btn-bg:var(--brand-strong);--btn-fg:#fff;--btn-bd:var(--brand-strong);
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  font-size:.95rem;font-weight:600;letter-spacing:.01em;line-height:1;
  padding:1.05em 1.7em;border-radius:6px;cursor:pointer;text-align:center;
  background:var(--btn-bg);color:var(--btn-fg);border:1px solid var(--btn-bd);
  transition:background .25s,color .25s,border-color .25s,transform .25s,box-shadow .25s;
}
.btn .ar{transition:transform .25s}
.btn:hover .ar{transform:translateX(3px)}
.btn--primary:hover{--btn-bg:var(--ink);--btn-bd:var(--ink);transform:translateY(-2px);box-shadow:var(--shadow)}
.btn--ghost{--btn-bg:transparent;--btn-fg:var(--ink);--btn-bd:var(--ink)}
.btn--ghost:hover{--btn-bg:var(--ink);--btn-fg:var(--paper);transform:translateY(-2px)}
.btn--sm{padding:.7em 1.15em;font-size:.85rem;border-radius:5px}

.on-dark .btn--primary{--btn-bg:var(--brand-strong);--btn-fg:#fff;--btn-bd:var(--brand-strong)}
.on-dark .btn--primary:hover{--btn-bg:#fff;--btn-fg:var(--ink);--btn-bd:#fff}
.on-dark .btn--ghost{--btn-fg:#fff;--btn-bd:rgba(255,255,255,.45)}
.on-dark .btn--ghost:hover{--btn-bg:#fff;--btn-fg:var(--ink);--btn-bd:#fff}

.tlink{
  display:inline-flex;align-items:center;gap:.5em;font-weight:600;font-size:.95rem;
  color:var(--brand-strong);padding-bottom:2px;border-bottom:2px solid transparent;
  transition:color .2s,border-color .2s;
}
.tlink .ar{transition:transform .25s}
.tlink:hover{border-color:var(--brand)}
.tlink:hover .ar{transform:translateX(3px)}
.on-dark .tlink{color:var(--accent-dark)}
.on-dark .tlink:hover{border-color:var(--accent-dark)}

/* ============================================================
   placeholders (until real photos / featured images)
   ============================================================ */
.ph{
  position:relative;overflow:hidden;border-radius:var(--r);
  background:var(--oat);border:1px solid var(--hairline);
  display:flex;align-items:flex-end;min-height:220px;
  color:var(--stone);--frame:rgba(23,19,15,.14);
}
.ph::before{content:"";position:absolute;inset:14px;border:1px solid var(--frame);border-radius:4px;opacity:.8;pointer-events:none}
.ph::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;background:radial-gradient(120% 90% at 78% 16%,rgba(255,255,255,.4),transparent 55%),radial-gradient(100% 80% at 12% 94%,rgba(23,19,15,.06),transparent 60%)}
.ph__mark{position:relative;z-index:1;margin:auto;display:flex;flex-direction:column;align-items:center;gap:.65rem;padding:1.5rem;text-align:center}
.ph__mark svg{width:34px;height:34px;stroke:currentColor;opacity:.6}
.ph__cap{
  position:absolute;left:14px;bottom:14px;z-index:1;display:inline-flex;align-items:center;gap:.5em;
  font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:inherit;
  background:rgba(252,250,245,.8);padding:.4em .7em;border-radius:4px;backdrop-filter:blur(2px);
}
.ph__cap::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
.ph--t-pink{background:#FBE0EF;color:#B0006E}
.ph--t-cyan{background:#DCF1FC;color:#0A6E96}
.ph--t-violet{background:#F1DEF0;color:#7A2374}
.ph--t-green{background:#DCF2E3;color:#177A37}
.ph--t-orange{background:#FDEBD6;color:#9C5A0E}
.ph--t-blue{background:#E0E8FB;color:#23408F}
.ph--solid-pink{background:var(--brand);color:#fff;border-color:var(--brand);--frame:rgba(255,255,255,.4)}
.ph--solid-pink .ph__cap{background:rgba(0,0,0,.22)}
.ph--ink{background:var(--ink-2);color:var(--accent-dark);border-color:#2a2521;--frame:rgba(255,255,255,.16)}
.ph--ink .ph__cap{background:rgba(0,0,0,.45)}
/* real photos inside placeholders */
.ph__img,.ph__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;display:block}
.ph.has-photo{color:#fff;background:var(--ink-2)}
.ph.has-photo::before{border-color:rgba(255,255,255,.4);z-index:1}
.ph.has-photo::after{opacity:1;z-index:1;background:linear-gradient(180deg,rgba(16,13,11,.04),rgba(16,13,11,.28))}
.ph.has-photo .ph__mark{display:none}
.ph.has-photo .ph__cap{z-index:2;background:rgba(16,13,11,.55);color:#fff;backdrop-filter:blur(3px)}
.ph.has-photo .ph__cap::before{background:var(--brand)}
.hero-tag{z-index:3}

/* ============================================================
   header / nav — sits ON the hero (transparent, blends with the paper base)
   ============================================================ */
.site-header{position:sticky;top:0;z-index:100;background:transparent;transition:box-shadow .3s,background .3s,-webkit-backdrop-filter .3s,backdrop-filter .3s}
.site-header.scrolled{background:rgba(245,241,232,.82);-webkit-backdrop-filter:blur(14px) saturate(140%);backdrop-filter:blur(14px) saturate(140%);box-shadow:0 10px 30px -18px rgba(23,19,15,.18)}
@media (prefers-reduced-motion:reduce){.site-header{transition:box-shadow .3s,background .3s}}
.header-inner{display:flex;align-items:center;gap:1.5rem;min-height:74px}
/* nudge the logo to optically centre with the menu */
.site-header .logo{transform:translateY(0)}
.site-nav{display:none;margin-left:1.5rem}
.site-nav ul{display:flex;gap:1.85rem}
.site-nav a{font-size:1rem;font-weight:500;text-transform:uppercase;letter-spacing:.06em;color:var(--stone);position:relative;padding:.4em 0;transition:color .2s;display:inline-block}
.site-nav a::after{content:"";position:absolute;left:0;right:100%;bottom:.05em;height:2px;background:var(--rainbow);transition:right .25s}
.site-nav a:hover,.site-nav .current-menu-item > a{color:var(--ink)}
.site-nav a:hover::after,.site-nav .current-menu-item > a::after{right:0}
.header-cta{display:none;margin-left:auto;align-items:center;gap:.75rem}
.header-phone{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border:1px solid var(--hairline);border-radius:50%;color:var(--ink);transition:color .2s,border-color .2s,background .2s}
.header-phone svg{width:19px;height:19px;display:block}
.header-phone:hover{color:var(--brand-strong);border-color:var(--brand-strong);background:rgba(236,0,140,.06)}
.header-quote{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:var(--brand-strong);color:#fff;transition:background .2s,transform .2s,box-shadow .2s}
.header-quote svg{width:19px;height:19px;display:block}
.header-quote:hover{background:var(--ink);transform:translateY(-2px);box-shadow:var(--shadow)}
.nav-toggle{margin-left:auto;width:44px;height:44px;border:1px solid var(--hairline);border-radius:6px;background:transparent;display:inline-flex;flex-direction:column;gap:5px;align-items:center;justify-content:center;cursor:pointer}
.nav-toggle span{width:18px;height:1.5px;background:var(--ink);transition:transform .25s,opacity .2s}
[data-nav-open] .nav-toggle span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
[data-nav-open] .nav-toggle span:nth-child(2){opacity:0}
[data-nav-open] .nav-toggle span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.mobile-nav{display:none;border-top:1px solid var(--hairline);background:rgba(245,241,232,.98);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}
[data-nav-open] .mobile-nav{display:block}
.mobile-nav .container{padding-block:1.25rem 1.75rem;display:flex;flex-direction:column;gap:.25rem}
.mobile-nav ul{display:flex;flex-direction:column}
.mobile-nav a{padding:.85rem .25rem;font-size:1.05rem;color:var(--ink);border-bottom:1px solid var(--hairline);display:block}
.mobile-nav .m-phone{margin-top:1rem;font-weight:500;color:var(--stone);border:0}
.mobile-nav .btn{margin-top:1rem}

/* ============================================================
   hero
   ============================================================ */
.hero{padding-block:clamp(1.5rem,3vw,2.75rem) clamp(2.5rem,5vw,4rem);background:var(--ink-2);color:#fff}
.hero-grid{display:grid;gap:clamp(2.5rem,5vw,4rem);align-items:center}
.hero-copy{max-width:none}
.hero h1{margin-bottom:1.5rem}
.hero .lead{margin-bottom:2.25rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:.85rem}
.hero-meta{display:flex;flex-wrap:wrap;gap:1rem 1.75rem;margin-top:2.5rem;padding-top:1.75rem;border-top:1px solid var(--line-dark)}
.hero-meta li{display:flex;align-items:center;gap:.55em;font-size:.86rem;color:var(--paper-dim);font-weight:500}
.hero-meta li svg{width:18px;height:18px;flex:none}
.hero-meta li:nth-child(1) svg{stroke:var(--pink)}
.hero-meta li:nth-child(2) svg{stroke:var(--cyan)}
.hero-meta li:nth-child(3) svg{stroke:var(--green)}
.hero-visual{position:relative}
.hero-visual .ph--main{min-height:clamp(360px,54vw,600px);aspect-ratio:3/4;max-height:700px;margin-inline:auto}
.hero-visual .ph--detail{position:absolute;left:-6%;bottom:-7%;width:46%;min-height:150px;aspect-ratio:1/1;box-shadow:var(--shadow-lift)}
.hero-tag{position:absolute;top:1.1rem;right:1.1rem;z-index:2;display:inline-flex;align-items:center;gap:.5em;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;background:var(--brand-strong);color:#fff;padding:.5em .85em;border-radius:5px}
.hero-tag::before{content:"";width:6px;height:6px;border-radius:50%;background:#fff}

/* dark hero + dark header on dark-hero pages (front page + niche hubs); the sticky header stays pinned and turns to dark glass once you scroll past the top (see .scrolled rule below) */
.hero .lead{color:var(--paper-dim)}
body.has-dark-hero .site-header{position:sticky;top:0;background:var(--ink-2)}
/* dark glass: at the top it stays solid (seamless with the hero), but once scrolled it goes translucent so the content frosts through the blur beneath it */
body.has-dark-hero .site-header.scrolled{background:rgba(16,13,11,.7);-webkit-backdrop-filter:blur(16px) saturate(140%);backdrop-filter:blur(16px) saturate(140%)}
body.has-dark-hero .site-header .logo-mark{width:160px;height:auto}
body.has-dark-hero .site-header .site-nav a{color:rgba(255,255,255,.78)}
body.has-dark-hero .site-header .site-nav a:hover,
body.has-dark-hero .site-header .site-nav .current-menu-item>a{color:#fff}
body.has-dark-hero .site-header .header-phone{color:#fff;border-color:rgba(255,255,255,.32)}
body.has-dark-hero .site-header .header-phone:hover{border-color:#fff;background:rgba(255,255,255,.08)}
body.has-dark-hero .site-header .nav-toggle{border-color:rgba(255,255,255,.32)}
body.has-dark-hero .site-header .nav-toggle span{background:#fff}
/* mobile dropdown menu — dark on dark-hero pages */
body.has-dark-hero .mobile-nav{background:var(--ink-2);border-top-color:var(--line-dark)}
body.has-dark-hero .mobile-nav ul a{color:#fff;border-bottom-color:var(--line-dark)}
body.has-dark-hero .mobile-nav .m-phone{color:var(--paper-dim)}

/* ============================================================
   client logos
   ============================================================ */
.logos{background:var(--offwhite);border-block:1px solid var(--hairline)}
.logos .container{display:flex;flex-direction:column;align-items:center;gap:1.75rem}
.logo-row{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:1.5rem 2.5rem;width:100%}
.logo-row li{font-family:var(--serif);font-weight:600;font-size:clamp(1.15rem,1rem + .8vw,1.6rem);letter-spacing:.02em;color:var(--stone);transition:color .25s;white-space:nowrap}
.logo-row li:hover{color:var(--ink)}
/* client logos marquee (monochrome, auto-scroll) */
.logos-marquee{width:100%;overflow:hidden;display:flex;flex-direction:column;gap:clamp(1.1rem,2.4vw,2.1rem);-webkit-mask:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.logos-track{display:flex;width:max-content;animation:logos-scroll 50s linear infinite}
.logos-track--reverse{animation-duration:58s;animation-direction:reverse}
.logos-marquee:hover .logos-track{animation-play-state:paused}
.logos-set{display:flex;align-items:center;gap:clamp(2.25rem,4.5vw,4rem);padding-right:clamp(2.25rem,4.5vw,4rem)}
.client-logo{height:clamp(82px,9vw,120px);width:auto;flex:none;filter:grayscale(1);opacity:.6;transition:opacity .25s}
.client-logo:hover{opacity:.95}
@keyframes logos-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){
  .logos-track{animation:none;flex-wrap:wrap;justify-content:center;width:auto}
  .logos-set{flex-wrap:wrap;justify-content:center;padding-right:0;row-gap:clamp(1.25rem,3vw,2rem)}
  .logos-set[aria-hidden="true"]{display:none}
}

/* ============================================================
   two paths
   ============================================================ */
.paths-grid{display:grid;gap:1.5rem;margin-top:clamp(2rem,4vw,3.25rem)}
.path-card{position:relative;border-radius:var(--r);padding:clamp(1.75rem,3.5vw,2.75rem);border:1px solid var(--hairline);background:var(--offwhite);display:flex;flex-direction:column;overflow:hidden;transition:transform .3s,box-shadow .3s}
.path-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--cyan)}
.path-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lift)}
.path-card .idx{font-family:var(--serif);font-size:clamp(3.5rem,8vw,5rem);line-height:1;color:var(--hairline);position:absolute;top:1.1rem;right:1.5rem;pointer-events:none}
.path-card .eyebrow{margin-bottom:1.5rem}
.path-card h3{margin-bottom:.85rem;max-width:18ch}
.path-card p{color:var(--stone);margin-bottom:.85rem;max-width:34ch}
.path-card .feat{font-size:.9rem;color:var(--stone);margin-bottom:1.75rem}
.path-card .btn{margin-top:auto;align-self:flex-start}
.path-card--dark{background:var(--ink-2);border-color:var(--ink-2);color:#fff}
.path-card--dark::before{background:var(--rainbow)}
.path-card--dark .idx{color:rgba(255,255,255,.1)}
.path-card--dark h3{color:#fff}
.path-card--dark p,.path-card--dark .feat{color:var(--paper-dim)}
.path-card--dark .eyebrow{color:var(--accent-dark)}
/* dark branding band (full-width dark section) */
.section--band{background:var(--ink-2);color:#fff}
.section--band::before{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:var(--rainbow)}
.section--band h2{color:#fff}
.section--band .lead{color:var(--paper-dim);margin-top:1.25rem}
.band-inner{display:flex;flex-direction:column;gap:1.75rem;align-items:flex-start}
@media (min-width:820px){
  .band-inner{flex-direction:row;align-items:center;justify-content:space-between;gap:clamp(2rem,5vw,4.5rem)}
  .band-copy{max-width:64ch}
  .band-inner .btn{flex:none}
}

/* ============================================================
   why us
   ============================================================ */
.why{background:var(--oat)}
.why-top{display:grid;gap:1.5rem;align-items:end;margin-bottom:clamp(2.5rem,5vw,4rem)}
.why-tiles{display:grid;gap:0;border-top:1px solid var(--hairline)}
.tile{padding:clamp(1.75rem,3vw,2.5rem) 0;border-bottom:1px solid var(--hairline);display:flex;flex-direction:column;align-items:center;text-align:center;gap:1rem;--acc:var(--brand)}
.tile:nth-child(1){--acc:var(--pink)}
.tile:nth-child(2){--acc:var(--orange)}
.tile:nth-child(3){--acc:var(--cyan)}
.tile:nth-child(4){--acc:var(--green)}
.tile .ic{width:38px;height:38px;stroke:var(--acc);stroke-width:1.5;fill:none}
.tile h3{font-family:var(--serif);font-weight:500;font-size:1.4rem;line-height:1.15}
.tile p{color:var(--stone);font-size:.95rem;max-width:34ch;margin-inline:auto}

/* ============================================================
   niches
   ============================================================ */
.niches-head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:end;gap:1.5rem;margin-bottom:clamp(2rem,4vw,3rem)}
.niches-grid{display:grid;gap:1.25rem}
.niche{position:relative;border:1px solid var(--hairline);border-radius:var(--r);background:var(--tint,var(--offwhite));padding:clamp(1.5rem,2.5vw,2rem);display:flex;flex-direction:column;gap:.9rem;min-height:200px;transition:transform .3s,box-shadow .3s,border-color .3s;--acc:var(--brand)}
.niche:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--acc)}
.niche .ic{width:32px;height:32px;stroke:var(--acc);stroke-width:1.5;fill:none}
.niche h3{font-family:var(--serif);font-weight:500;font-size:1.45rem;line-height:1.1}
.niche p{color:var(--stone);font-size:.93rem;flex:1}
.niche .go{display:inline-flex;align-items:center;gap:.5em;font-size:.85rem;font-weight:600;color:var(--acc)}
.niche .go .ar{transition:transform .25s}
.niche:hover .go .ar{transform:translateX(3px)}
.niche--orange{--acc:#C56A0A;--tint:#FDEBD6}
.niche--violet{--acc:#7A2374;--tint:#F1DEF0}
.niche--cyan{--acc:#0A6E96;--tint:#DCF1FC}
.niche--green{--acc:#177A37;--tint:#DCF2E3}
.niche--blue{--acc:#23408F;--tint:#E0E8FB}
.niche--flag{background:var(--ink-2);border-color:var(--ink-2);color:#fff;justify-content:space-between;--acc:var(--accent-dark)}
.niche--flag::after{content:"";position:absolute;left:0;right:0;bottom:0;height:5px;background:var(--rainbow)}
.niche--flag .ic{stroke:var(--accent-dark)}
.niche--flag h3{color:#fff;font-size:clamp(1.6rem,1.3rem + 1.2vw,2.3rem)}
.niche--flag p{color:var(--paper-dim);font-size:1rem;flex:none}
.niche--flag .go{color:var(--accent-dark)}
.flag-badge{position:absolute;top:clamp(1.5rem,2.5vw,2rem);right:clamp(1.5rem,2.5vw,2rem);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:#fff;background:var(--brand);padding:.45em .75em;border-radius:5px}

/* Niche solutions — category switchers + photo carousel */
.niche-switch{display:none;flex-wrap:wrap;gap:.6rem;margin-bottom:clamp(1.75rem,3.5vw,2.75rem)}
.js .niche-switch{display:flex}
.niche-tab{--acc:var(--brand-strong);font:inherit;font-weight:600;font-size:.92rem;line-height:1;letter-spacing:.01em;padding:.7em 1.1em;border-radius:999px;cursor:pointer;color:var(--ink);background:var(--offwhite);border:1px solid var(--hairline);transition:color .2s,background .2s,border-color .2s,transform .2s}
.niche-tab[data-acc=orange]{--acc:#C56A0A}
.niche-tab[data-acc=violet]{--acc:#7A2374}
.niche-tab[data-acc=cyan]{--acc:#0A6E96}
.niche-tab[data-acc=green]{--acc:#177A37}
.niche-tab[data-acc=blue]{--acc:#23408F}
.niche-tab:hover{border-color:var(--acc);color:var(--acc);transform:translateY(-1px)}
.niche-tab.is-active{background:var(--acc);border-color:var(--acc);color:#fff}

.niche-panel{--acc:var(--brand-strong)}
.niche-panel[data-acc=orange]{--acc:#C56A0A}
.niche-panel[data-acc=violet]{--acc:#7A2374}
.niche-panel[data-acc=cyan]{--acc:#0A6E96}
.niche-panel[data-acc=green]{--acc:#177A37}
.niche-panel[data-acc=blue]{--acc:#23408F}
.niche-panel + .niche-panel{margin-top:clamp(2.5rem,5vw,4rem)}
.js .niche-panel{display:none}
.js .niche-panel + .niche-panel{margin-top:0}
.js .niche-panel.is-active{display:block;animation:nfade .4s ease}
@keyframes nfade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

.ncar{position:relative}
.ncar-viewport{overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;-webkit-mask:linear-gradient(90deg,transparent,#000 2%,#000 98%,transparent);mask:linear-gradient(90deg,transparent,#000 2%,#000 98%,transparent)}
.ncar-viewport::-webkit-scrollbar{display:none}
.ncar-track{display:flex;gap:1.25rem;list-style:none;margin:0;padding:.25rem .35rem 1rem}
.ncar-slide{flex:0 0 80%;max-width:340px;scroll-snap-align:start}
.ncar-card{margin:0;display:flex;flex-direction:column;gap:1rem;height:100%}
.ncar-card .ph{aspect-ratio:4/5;min-height:0}
.ncar-card .ph__mark svg{width:30px;height:30px;opacity:.55}
.ncar-meta h3{font-family:var(--serif);font-weight:500;font-size:1.2rem;line-height:1.12;color:var(--ink)}
.ncar-meta p{color:var(--stone);font-size:.9rem;line-height:1.5;margin-top:.4rem}

.ncar-arrow{position:absolute;top:38%;transform:translateY(-50%);z-index:3;width:44px;height:44px;border-radius:50%;display:grid;place-items:center;cursor:pointer;background:#fff;color:var(--ink);border:1px solid var(--hairline);box-shadow:var(--shadow);transition:color .2s,border-color .2s,transform .2s}
.ncar-arrow svg{width:22px;height:22px}
.ncar-arrow:hover{color:var(--acc);border-color:var(--acc);transform:translateY(-50%) scale(1.06)}
.ncar-arrow--prev{left:-6px}
.ncar-arrow--next{right:-6px}
.ncar-arrow[hidden]{display:none}

.niche-panel-foot{margin-top:1.5rem}

@media (min-width:680px){
  .ncar-slide{flex-basis:42%}
}
@media (min-width:1000px){
  .ncar-slide{flex-basis:calc((100% - 2 * 1.25rem) / 3)}
  .ncar-arrow--prev{left:-22px}
  .ncar-arrow--next{right:-22px}
}
@media (min-width:1400px){
  .ncar-slide{flex-basis:calc((100% - 3 * 1.25rem) / 4)}
}
@media (hover:none){.ncar-arrow{display:none}}
@media (prefers-reduced-motion:reduce){.js .niche-panel.is-active{animation:none}}

/* Niche-page formats — per-category photo gallery (switchers open a category's gallery) */
.gal-intro{color:var(--stone);max-width:62ch;margin:0 0 clamp(1.25rem,3vw,2.25rem);font-size:1.05rem;line-height:1.6}
.gal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,240px),1fr));gap:1.25rem}
.gal-item{margin:0;display:flex;flex-direction:column;gap:.9rem}
.gal-item[hidden]{display:none}
.gal-item .ph{aspect-ratio:4/5;min-height:0}
.gal-item .ph__mark svg{width:30px;height:30px;opacity:.55}
.gal-item h3{font-family:var(--serif);font-weight:500;font-size:1.2rem;line-height:1.12;color:var(--ink)}
.gal-item p{color:var(--stone);font-size:.9rem;line-height:1.5;margin-top:.35rem}

/* ============================================================
   process — how we work (linear stepper)
   ============================================================ */
.process-flow{list-style:none;margin:clamp(2rem,4vw,3rem) 0 0;padding:0;display:grid;gap:0}
.process-step{position:relative;display:grid;grid-template-columns:auto 1fr;gap:1.25rem;padding-bottom:clamp(1.75rem,3.5vw,2.5rem);--acc:var(--brand)}
.process-step:last-child{padding-bottom:0}
.process-step:nth-child(1){--acc:var(--pink)}
.process-step:nth-child(2){--acc:var(--orange)}
.process-step:nth-child(3){--acc:var(--cyan)}
.process-step:nth-child(4){--acc:var(--green)}
.process-step:not(:last-child)::before{content:"";position:absolute;left:1.4rem;top:2.85rem;bottom:0;width:2px;background:linear-gradient(var(--acc),var(--hairline) 70%);transform:translateX(-1px)}
.process-num{position:relative;z-index:1;align-self:start;width:2.8rem;height:2.8rem;display:grid;place-items:center;border-radius:50%;background:var(--acc);color:var(--ink);font-family:var(--display);font-weight:800;font-size:1.05rem;line-height:1}
.process-body{display:grid;gap:.5rem;align-content:start;padding-top:.35rem}
.process-body h3{font-family:var(--serif);font-weight:500;font-size:1.3rem;line-height:1.15}
.process-body p{color:var(--stone);font-size:.93rem;line-height:1.55;max-width:48ch}
.process-note{font-size:.85rem;color:var(--stone);padding-left:.85rem;border-left:2px solid var(--acc)}

/* ============================================================
   production (dark)
   ============================================================ */
.production{background:var(--ink-2);color:#fff}
.prod-grid{display:grid;gap:clamp(2.5rem,5vw,4rem);align-items:center}
.prod-copy h2{color:#fff;margin-bottom:1.5rem}
.prod-copy .lead{color:var(--paper-dim);margin-bottom:2rem}
.prod-list{display:grid;gap:1rem;margin-bottom:2.5rem}
.prod-list li{display:flex;gap:.85rem;align-items:flex-start;font-size:.97rem;color:#fff}
.prod-list svg{width:22px;height:22px;stroke-width:1.6;fill:none;flex:none;margin-top:1px}
.prod-list li:nth-child(1) svg{stroke:var(--pink)}
.prod-list li:nth-child(2) svg{stroke:var(--orange)}
.prod-list li:nth-child(3) svg{stroke:var(--accent-dark)}
.prod-list li:nth-child(4) svg{stroke:var(--lime)}
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line-dark);border:1px solid var(--line-dark);border-radius:var(--r);overflow:hidden}
.stat{background:var(--ink-2);padding:1.4rem 1.25rem}
.stat b{display:block;font-family:var(--display);font-weight:800;font-size:clamp(1.7rem,1.4rem + 1.5vw,2.5rem);line-height:1}
.stat:nth-child(1) b{color:var(--pink)}
.stat:nth-child(2) b{color:var(--orange)}
.stat:nth-child(3) b{color:var(--accent-dark)}
.stat:nth-child(4) b{color:var(--lime)}
.stat span{font-size:.83rem;color:var(--paper-dim);margin-top:.4rem;display:block}
.prod-visual{display:flex;justify-content:center}
.prod-visual .ph--main{flex:none;width:min(100%,460px);aspect-ratio:4/5;max-height:600px;min-height:clamp(320px,45vw,520px)}

/* ============================================================
   cases
   ============================================================ */
.cases-head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:end;gap:1.5rem;margin-bottom:clamp(2rem,4vw,3rem)}
.cases-grid{display:grid;gap:clamp(1.25rem,2.5vw,2rem)}
.case figure{margin:0;display:flex;flex-direction:column;gap:1rem}
.case .ph{aspect-ratio:16/11;min-height:0;transition:transform .3s,box-shadow .3s}
.case:hover .ph{box-shadow:var(--shadow);transform:translateY(-3px)}
.case figcaption{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;padding-bottom:.9rem;border-bottom:1px solid var(--hairline)}
.case .brand{font-family:var(--serif);font-weight:500;font-size:1.4rem;line-height:1.1}
.case .niche-tag{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--stone);white-space:nowrap;font-weight:600}

/* ============================================================
   final CTA (dark)
   ============================================================ */
.cta{background:var(--ink-2);color:#fff;text-align:center;position:relative}
.cta::before{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:var(--rainbow)}
.cta-inner{max-width:48ch;margin-inline:auto}
.cta h2{color:#fff;margin-bottom:1.25rem}
.cta p{color:var(--paper-dim);margin-bottom:2.25rem;font-size:1.1rem}
.cta-actions{display:flex;flex-wrap:wrap;gap:.85rem;justify-content:center}
.cta-grid{max-width:1180px;margin-inline:auto}
.cta-copy{max-width:48ch;margin-inline:auto}

/* final CTA — quote-request form (on dark) */
.cta-form{max-width:560px;margin:2.5rem auto 0;text-align:left}
.cta-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.cta-form .field{margin:0 0 1.1rem;font-size:1rem;color:#fff}
.cta-form label{display:block;font-size:.82rem;font-weight:600;letter-spacing:.01em;color:#fff;margin-bottom:.45rem}
.cta-form .req{color:var(--accent-dark)}
.cta-form input,.cta-form select,.cta-form textarea{
  width:100%;font:inherit;font-size:.95rem;line-height:1.4;color:#fff;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.18);
  border-radius:6px;padding:.75em .9em;transition:border-color .2s,background .2s;
}
.cta-form textarea{resize:vertical;min-height:104px}
.cta-form input::placeholder,.cta-form textarea::placeholder{color:var(--paper-dim)}
.cta-form select{
  appearance:none;-webkit-appearance:none;cursor:pointer;padding-right:2.5em;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23B9B0A6' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right .9em center;
}
.cta-form select option{color:var(--ink)}
.cta-form input:focus,.cta-form select:focus,.cta-form textarea:focus{
  outline:none;border-color:var(--accent-dark);background:rgba(255,255,255,.07);
}
.cta-form .btn{width:100%;margin-top:.4rem}
.cta-form .form-fine{font-size:.78rem;line-height:1.5;color:var(--paper-dim);margin:.9rem 0 0;text-align:center}
.cta-form .hp-field{position:absolute !important;left:-9999px;width:1px;height:1px;overflow:hidden}
.cta .form-note{max-width:560px;margin:0 auto 1.5rem;padding:.85em 1.1em;border-radius:8px;font-size:.95rem;line-height:1.5;text-align:left}
.cta .form-note--ok{background:rgba(31,174,77,.14);border:1px solid rgba(31,174,77,.5);color:#d7f6e1}
.cta .form-note--err{background:rgba(240,50,60,.12);border:1px solid rgba(240,50,60,.5);color:#ffd7da}
.cta .cta-alt{margin:1.75rem 0 0;font-size:1rem;text-align:center}
@media (max-width:560px){
  .cta-form{margin-top:2rem}
  .cta-form .form-row{grid-template-columns:1fr;gap:0}
}
/* large screens: copy (title + text) left, form right */
@media (min-width:1100px){
  .cta-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2.5rem,4vw,5rem);align-items:center;text-align:left}
  .cta-copy{max-width:none;margin-inline:0}
  .cta-grid .cta-form{margin-top:0}
}

/* ============================================================
   footer (dark)
   ============================================================ */
.site-footer{background:var(--ink-2);color:var(--paper-dim);position:relative}
.site-footer::before{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:var(--rainbow)}
.footer-grid{display:grid;gap:2.5rem;padding-block:clamp(3rem,5vw,4.5rem)}
.footer-brand .logo .logo-mark{width:176px;height:44px}
.footer-brand p.about{margin-top:1rem;max-width:30ch;font-size:.92rem;color:var(--paper-dim)}
.foot-col h4{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-dark);font-weight:600;margin-bottom:1.1rem}
.foot-col ul{display:grid;gap:.7rem}
.foot-col a,.foot-col li{font-size:.93rem;color:var(--paper-dim);transition:color .2s}
.foot-col a:hover{color:#fff}
.foot-contacts a{display:block}
.socials{display:flex;gap:.6rem;margin-top:1.5rem}
.socials a{width:40px;height:40px;border:1px solid var(--line-dark);border-radius:6px;display:inline-flex;align-items:center;justify-content:center;transition:border-color .2s,background .2s,transform .2s}
.socials a:hover{transform:translateY(-2px)}
.socials a:nth-child(1):hover{border-color:var(--pink);background:rgba(236,0,140,.15)}
.socials a:nth-child(2):hover{border-color:var(--cyan);background:rgba(0,174,239,.15)}
.socials svg{width:19px;height:19px;stroke:#fff;stroke-width:1.5;fill:none}
.footer-bottom{border-top:1px solid var(--line-dark);padding-block:1.5rem;display:flex;flex-wrap:wrap;gap:.75rem 1.5rem;justify-content:space-between;align-items:center;font-size:.83rem;color:var(--stone)}
.footer-bottom .links{display:flex;gap:1.25rem;flex-wrap:wrap}
.footer-bottom a:hover{color:#fff}

/* ============================================================
   blog / content (index, single, page)
   ============================================================ */
.page-hero{padding-block:clamp(2.5rem,5vw,4rem) clamp(1.5rem,3vw,2.5rem)}
.page-hero .eyebrow{margin-bottom:1rem}
.posts-grid{display:grid;gap:clamp(1.5rem,3vw,2.25rem)}
.post-card{display:flex;flex-direction:column;gap:1rem}
.post-card .ph{aspect-ratio:16/10;min-height:0}
.post-card .meta{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--stone);font-weight:600}
.post-card h2,.post-card h3{font-family:var(--serif);font-weight:500;font-size:1.5rem;line-height:1.15}
.post-card p{color:var(--stone);font-size:.95rem}
.entry{max-width:72ch;margin-inline:auto}
.entry-header{margin-bottom:2rem}
.entry-header h1{font-family:var(--serif);font-weight:500;font-size:clamp(2rem,1.4rem + 2.4vw,3rem);line-height:1.1;margin-bottom:1rem}
.entry-meta{font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--stone);font-weight:600}
.entry-content{font-size:1.075rem;line-height:1.75}
.entry-content > * + *{margin-top:1.2rem}
.entry-content h2{font-family:var(--serif);font-weight:500;font-size:1.9rem;line-height:1.15;margin-top:2.2rem}
.entry-content h3{font-family:var(--serif);font-weight:500;font-size:1.5rem;line-height:1.2;margin-top:1.8rem}
.entry-content a{color:var(--brand-strong);border-bottom:1px solid var(--hairline);transition:border-color .2s}
.entry-content a:hover{border-color:var(--brand)}
.entry-content ul,.entry-content ol{padding-left:1.3rem;display:grid;gap:.5rem}
.entry-content ul{list-style:disc}
.entry-content ol{list-style:decimal}
.entry-content img{border-radius:var(--r)}
.entry-content blockquote{border-left:3px solid var(--brand);padding-left:1.25rem;font-family:var(--serif);font-size:1.4rem;font-style:italic;color:var(--ink)}
.entry-content figure{margin:0}

/* page "in development" placeholder (template-wip.php) */
.wip{min-height:58vh;display:grid;place-items:center;text-align:center}
.wip-card{max-width:34rem;margin-inline:auto;display:flex;flex-direction:column;align-items:center;gap:1.1rem}
.wip-icon{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;background:var(--oat);color:var(--brand-strong);border:1px solid var(--hairline)}
.wip-icon svg{width:30px;height:30px}
.wip-card .lead{margin:0 auto}
.wip-actions{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;margin-top:.5rem}
.alignwide{width:min(1100px,100%)}
.alignfull{width:100vw;margin-left:calc(50% - 50vw)}
.aligncenter{margin-inline:auto;display:block}
.pagination{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:3rem}
.pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 .6rem;border:1px solid var(--hairline);border-radius:6px;font-weight:600;font-size:.9rem}
.pagination .page-numbers.current{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.pagination a.page-numbers:hover{border-color:var(--brand);color:var(--brand-strong)}

/* 404 / not found */
.notfound{text-align:center;padding-block:clamp(4rem,10vw,8rem)}
.notfound .code{font-family:var(--display);font-weight:800;font-size:clamp(4rem,18vw,9rem);line-height:1;background:var(--rainbow);-webkit-background-clip:text;background-clip:text;color:transparent}
.notfound h1{font-family:var(--serif);font-weight:500;font-size:clamp(1.8rem,1.4rem+1.6vw,2.6rem);margin:1rem 0 .75rem}
.notfound p{color:var(--stone);margin-bottom:2rem}

/* ============================================================
   WooCommerce (minimal v1 — full templates next step)
   ============================================================ */
.woocommerce a.button,.woocommerce button.button,.woocommerce .button,.woocommerce #respond input#submit{
  background:var(--brand-strong);color:#fff;border-radius:6px;font-weight:600;padding:.9em 1.5em;border:1px solid var(--brand-strong);transition:background .25s,transform .25s;
}
.woocommerce a.button:hover,.woocommerce button.button:hover,.woocommerce .button:hover{background:var(--ink);border-color:var(--ink);transform:translateY(-2px)}
.woocommerce .price{color:var(--ink);font-weight:600}
.woocommerce ul.products li.product{background:var(--offwhite);border:1px solid var(--hairline);border-radius:var(--r);padding:1rem;transition:transform .3s,box-shadow .3s}
.woocommerce ul.products li.product:hover{transform:translateY(-3px);box-shadow:var(--shadow)}

/* ============================================================
   niche hub: breadcrumb, subcat accent, FAQ
   ============================================================ */
.niche--pink{--acc:#C2017A;--tint:#FBE0EF}

.breadcrumb{font-size:.82rem;color:var(--stone);margin-bottom:1.25rem;display:flex;gap:.5em;flex-wrap:wrap;font-weight:500}
.breadcrumb a{color:var(--stone)}
.breadcrumb a:hover{color:var(--brand-strong)}
.breadcrumb span[aria-hidden]{color:var(--hairline)}

.faq-section{background:var(--offwhite)}
.faq{max-width:80ch;margin-top:clamp(2rem,4vw,3rem);margin-inline:auto;border-top:1px solid var(--hairline)}
.faq-item{border-bottom:1px solid var(--hairline)}
.faq-item summary{cursor:pointer;list-style:none;padding:1.3rem 0;font-family:var(--serif);font-weight:500;font-size:clamp(1.2rem,1rem + .6vw,1.5rem);line-height:1.25;display:flex;justify-content:space-between;gap:1.5rem;align-items:baseline;color:var(--ink)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-family:var(--display);font-weight:800;color:var(--brand);flex:none;font-size:1.3rem;line-height:1}
.faq-item[open] summary::after{content:"–"}
.faq-a{padding:0 0 1.4rem;color:var(--stone);max-width:72ch}
.faq-a p{margin:0}
.faq-a ul{display:grid;gap:.5rem;margin:0;padding-left:1.3rem;list-style:disc}
.faq-a p + ul{margin-top:.7rem}
.faq-a li{margin:0}

/* ============================================================
   scroll reveal (progressive enhancement)
   ============================================================ */
.js .reveal{opacity:0;transform:translateY(18px);transition:opacity .7s,transform .7s}
.js .reveal.in{opacity:1;transform:none}
.js .r-stagger > *{opacity:0;transform:translateY(18px);transition:opacity .6s,transform .6s}
.js .r-stagger.in > *{opacity:1;transform:none}
.js .r-stagger.in > *:nth-child(2){transition-delay:.07s}
.js .r-stagger.in > *:nth-child(3){transition-delay:.14s}
.js .r-stagger.in > *:nth-child(4){transition-delay:.21s}
.js .r-stagger.in > *:nth-child(5){transition-delay:.28s}
.js .r-stagger.in > *:nth-child(6){transition-delay:.35s}
@media (prefers-reduced-motion:reduce){.js .reveal,.js .r-stagger > *{opacity:1;transform:none;transition:none}}

/* ============================================================
   responsive
   ============================================================ */
@media (min-width:600px){
  .why-tiles{grid-template-columns:repeat(2,1fr);column-gap:clamp(2rem,4vw,3.5rem)}
  .niches-grid{grid-template-columns:repeat(2,1fr)}
  .niche--flag{grid-column:span 2}
  .stats{grid-template-columns:repeat(4,1fr)}
  .cases-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
  .posts-grid{grid-template-columns:repeat(2,1fr)}
}
@media (min-width:900px){
  .site-nav{display:block}
  .header-cta{display:flex}
  .nav-toggle{display:none}
  .mobile-nav{display:none !important}
  .hero-grid{grid-template-columns:1.5fr 1fr}
  .paths-grid{grid-template-columns:repeat(2,1fr)}
  .why-top{grid-template-columns:1.1fr .9fr}
  .why-tiles{grid-template-columns:repeat(4,1fr)}
  .niches-grid{grid-template-columns:repeat(3,1fr);grid-auto-flow:dense}
  .niche--flag{grid-column:span 2;grid-row:span 2}
  .process-flow{--pflow-gap:clamp(1.5rem,3vw,2.75rem);grid-template-columns:repeat(4,1fr);gap:var(--pflow-gap)}
  .process-step{grid-template-columns:1fr;gap:1.1rem;padding-bottom:0}
  .process-num{justify-self:start}
  .process-body{padding-top:0}
  .process-step:not(:last-child)::before{top:1.4rem;left:1.4rem;bottom:auto;width:calc(100% + var(--pflow-gap));height:2px;background:linear-gradient(90deg,var(--acc),var(--hairline) 70%);transform:translateY(-1px)}
  .prod-grid{grid-template-columns:1fr 1fr}
  .prod-visual{justify-content:flex-end}
  .cases-grid{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1.4fr 1fr 1fr 1.3fr}
  .posts-grid{grid-template-columns:repeat(3,1fr)}
}
@media (min-width:1100px){
  .case--wide{grid-column:span 2;grid-row:span 2}
  .case--wide figure{height:100%}
  .case--wide .ph{aspect-ratio:auto;flex:1;min-height:0}
}
@media (min-width:600px) and (max-width:899px){.case--wide{grid-column:1/-1}}

/* ============================================================
   Case gallery — clickable cover cue + lightbox (images & video)
   ============================================================ */
a.ph{cursor:pointer;text-decoration:none;color:inherit;-webkit-tap-highlight-color:transparent}
a.ph:focus-visible{outline:3px solid var(--brand);outline-offset:3px}
.case-gallery{display:none}
.case-open .ph__img{transition:transform .5s ease}
.case-open:hover .ph__img{transform:scale(1.04)}
.case-open__cue{
  position:absolute;right:14px;bottom:14px;z-index:3;display:inline-flex;align-items:center;gap:.45em;
  font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:#fff;
  background:var(--brand);padding:.5em .85em;border-radius:999px;
  box-shadow:0 6px 18px -8px rgba(236,0,140,.75);transition:transform .25s,box-shadow .25s,background .25s
}
.case-open__cue svg{width:15px;height:15px;stroke:currentColor}
.case-open:hover .case-open__cue,.case-open:focus-visible .case-open__cue{transform:translateY(-2px);background:var(--brand-strong);box-shadow:0 10px 24px -8px rgba(236,0,140,.85)}

/* Lightbox overlay */
.lbx{position:fixed;inset:0;z-index:1000;display:flex}
.lbx[hidden]{display:none}
.lbx__backdrop{position:absolute;inset:0;background:rgba(12,10,8,.88);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;transition:opacity .3s}
.lbx.is-open .lbx__backdrop{opacity:1}
.lbx__panel{
  position:relative;z-index:1;margin:auto;width:min(1180px,100%);height:100%;
  display:grid;grid-template-rows:1fr auto;gap:clamp(.6rem,1.6vw,1rem);
  padding:clamp(1rem,3vw,2.2rem);box-sizing:border-box;
  opacity:0;transform:scale(.985);transition:opacity .3s,transform .3s
}
.lbx.is-open .lbx__panel{opacity:1;transform:none}
.lbx__stage{position:relative;grid-row:1;margin:0;min-height:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.lbx__media{flex:1;min-height:0;width:100%;display:flex;align-items:center;justify-content:center}
.lbx__img,.lbx__vid{max-width:100%;max-height:100%;width:auto;height:auto;border-radius:var(--r);box-shadow:var(--shadow-lift);background:#000;object-fit:contain}
.lbx__cap{flex:none;margin:.85rem 0 0;display:flex;gap:1rem;align-items:baseline;justify-content:center;flex-wrap:wrap;color:#fff;text-align:center}
.lbx__cap [data-cap]{font-family:var(--serif);font-size:1.05rem;font-weight:500}
.lbx__count{font-size:.75rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:rgba(255,255,255,.6);white-space:nowrap}
.lbx__btn{
  position:absolute;z-index:2;display:inline-flex;align-items:center;justify-content:center;
  color:#fff;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:50%;
  cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background .2s,transform .2s
}
.lbx__btn:hover{background:rgba(255,255,255,.22)}
.lbx__btn:focus-visible{outline:3px solid var(--brand);outline-offset:2px}
.lbx__btn svg{width:24px;height:24px}
.lbx__close{position:fixed;top:clamp(1rem,3vw,2rem);right:clamp(1rem,3vw,2rem);width:46px;height:46px}
.lbx__nav{top:50%;transform:translateY(-50%);width:48px;height:48px}
.lbx__nav:hover{transform:translateY(-50%) scale(1.06)}
.lbx__prev{left:clamp(-.2rem,1vw,.6rem)}
.lbx__next{right:clamp(-.2rem,1vw,.6rem)}
.lbx__next svg{transform:scaleX(-1)}
.lbx__strip{grid-row:2;list-style:none;margin:0;padding:.15rem;display:flex;gap:.55rem;overflow-x:auto;scroll-snap-type:x proximity;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.3) transparent;justify-content:safe center}
.lbx__strip::-webkit-scrollbar{height:6px}
.lbx__strip::-webkit-scrollbar-thumb{background:rgba(255,255,255,.28);border-radius:99px}
.lbx__strip li{flex:0 0 auto;scroll-snap-align:center}
.lbx__strip button{position:relative;display:block;width:78px;height:56px;padding:0;border:2px solid transparent;border-radius:6px;overflow:hidden;cursor:pointer;background:#222;opacity:.5;transition:opacity .2s,border-color .2s}
.lbx__strip button:hover{opacity:.85}
.lbx__strip li.is-active button{opacity:1;border-color:var(--brand)}
.lbx__strip button:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
.lbx__strip img{width:100%;height:100%;object-fit:cover;display:block}
.lbx__play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;background:rgba(0,0,0,.28)}
.lbx__play svg{width:18px;height:18px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.6))}
html.lbx-open{overflow:hidden}
@media (max-width:640px){
  .lbx__nav{width:40px;height:40px}
  .lbx__nav svg,.lbx__btn svg{width:20px;height:20px}
  .lbx__strip button{width:62px;height:46px}
  .lbx__cap [data-cap]{font-size:.95rem}
}
@media (prefers-reduced-motion:reduce){
  .lbx__backdrop,.lbx__panel,.case-open .ph__img,.case-open__cue,.lbx__btn{transition:none}
}
/* Multi-cuisine brand label — dim the " | " separators so the cuisines read as a set */
.case .brand .brand-sep{color:var(--paper-dim);font-weight:400}
/* Hover-to-play cover video — fades in over the static cover image, played by app.js */
.ph__video--hover{opacity:0;transition:opacity .45s ease}
.case-open--video:hover .ph__video--hover,.case-open--video:focus-within .ph__video--hover{opacity:1}
@media (prefers-reduced-motion:reduce){.ph__video--hover{display:none}}

/* ============================================================
   reviews (Google) — curated social proof above the final CTA
   ============================================================ */
.reviews-badge{display:flex;width:-moz-fit-content;width:fit-content;align-items:center;gap:.55rem;margin:clamp(1.4rem,3vw,2rem) auto 0;padding:.55rem 1.05rem;background:var(--offwhite);border:1px solid var(--hairline);border-radius:999px;box-shadow:var(--shadow);color:var(--ink);font-size:.95rem;transition:transform .2s,box-shadow .2s}
.reviews-badge:hover{transform:translateY(-2px);box-shadow:var(--shadow-lift)}
.reviews-badge > svg{width:20px;height:20px;flex:none}
.reviews-badge__score{font-family:var(--display);font-weight:800;font-size:1.05rem}
.reviews-badge__stars{display:inline-flex;gap:1px}
.reviews-badge__stars svg{width:15px;height:15px;fill:var(--yellow)}
.reviews-badge__meta{color:var(--stone)}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2vw,1.5rem);margin-top:clamp(2rem,4vw,3rem)}
.review{display:flex;flex-direction:column;gap:.85rem;padding:clamp(1.3rem,2vw,1.7rem);background:var(--offwhite);border:1px solid var(--hairline);border-radius:var(--r);box-shadow:var(--shadow)}
.review__head{display:flex;align-items:center;gap:.7rem}
.review__avatar{flex:none;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;font-family:var(--display);font-weight:800;font-size:1.1rem;color:#fff;background:var(--brand);text-transform:uppercase}
.review__id{display:flex;flex-direction:column;line-height:1.25;margin-right:auto;min-width:0}
.review__name{font-weight:600;color:var(--ink)}
.review__date{font-size:.82rem;color:var(--stone)}
.review__g{flex:none;display:inline-flex}
.review__g svg{width:18px;height:18px}
.review__stars{display:inline-flex;gap:2px}
.review__stars svg{width:17px;height:17px;fill:var(--yellow)}
.review__text{margin:0;color:var(--stone);font-size:.97rem}
.review:nth-child(6n+1) .review__avatar{background:var(--pink)}
.review:nth-child(6n+2) .review__avatar{background:var(--orange)}
.review:nth-child(6n+3) .review__avatar{background:var(--cyan)}
.review:nth-child(6n+4) .review__avatar{background:var(--violet)}
.review:nth-child(6n+5) .review__avatar{background:var(--green)}
.review:nth-child(6n+6) .review__avatar{background:var(--blue)}
.reviews-cta{text-align:center;margin-top:clamp(1.75rem,3vw,2.5rem)}
@media (max-width:900px){.reviews-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.reviews-grid{grid-template-columns:1fr}}

/* ============================================================
   Mobile menu — floating button + fullscreen overlay (≤899px)
   ------------------------------------------------------------
   On phones the header bar is no longer pinned: it scrolls away
   with the page, leaving only the menu icon as a floating button.
   Tapping it opens a fullscreen menu with the nav links and two
   quick actions — call (phone icon) and cost quote (calculator).
   Desktop keeps the sticky bar; this whole block stays off there.
   ============================================================ */
@media (max-width:899px){
  /* Bar scrolls away with the page — only the floating icon stays. */
  .site-header,
  body.has-dark-hero .site-header{position:static}
  .header-inner{min-height:60px;gap:1rem}

  /* The lone menu icon: a floating button pinned top-right, legible
     over any section (translucent dark disc with white bars). */
  .site-header .nav-toggle{
    position:fixed;
    top:max(.6rem,env(safe-area-inset-top));
    right:clamp(1rem,5vw,1.5rem);
    z-index:130;width:46px;height:46px;border-radius:50%;
    background:rgba(16,13,11,.62);
    -webkit-backdrop-filter:blur(10px) saturate(140%);
    backdrop-filter:blur(10px) saturate(140%);
    border:1px solid rgba(255,255,255,.22);
    box-shadow:0 10px 30px -12px rgba(0,0,0,.55);
  }
  .site-header .nav-toggle span{background:#fff}
  .admin-bar .site-header .nav-toggle{top:calc(46px + .6rem)}

  /* Fullscreen menu overlay. */
  .mobile-nav{
    position:fixed;inset:0;z-index:120;max-height:none;border-top:0;
    overflow-y:auto;-webkit-overflow-scrolling:touch;
  }
  .admin-bar .mobile-nav{top:46px}
  [data-nav-open] .mobile-nav{display:flex;flex-direction:column}
  :root[data-nav-open]{overflow:hidden}
  .mobile-nav .container{
    flex:1;min-height:100%;justify-content:center;gap:1.5rem;
    padding-block:clamp(4.5rem,14vw,6rem) clamp(2rem,8vw,3rem);
  }

  /* Nav links — bigger, centred, no dividers. */
  .mobile-nav ul{gap:.15rem}
  .mobile-nav ul a{
    border-bottom:0;text-align:center;font-weight:500;
    font-size:clamp(1.3rem,5.5vw,1.7rem);padding:.55rem .5rem;
  }

  /* Quick actions: call + cost quote, as icon buttons. */
  .mobile-nav .m-actions{
    display:flex;justify-content:center;gap:clamp(1.75rem,9vw,3rem);
    margin-top:auto;padding-top:1.5rem;
  }
  .mobile-nav .m-action{
    display:flex;flex-direction:column;align-items:center;gap:.55rem;
    border:0;padding:0;color:var(--ink);text-align:center;
  }
  .m-action__icon{
    display:inline-flex;align-items:center;justify-content:center;
    width:58px;height:58px;border-radius:50%;
    transition:transform .2s,background .2s,border-color .2s;
  }
  .m-action__icon svg{width:24px;height:24px;display:block}
  .m-action--call .m-action__icon{border:1px solid var(--hairline);color:var(--ink)}
  .m-action--quote .m-action__icon{background:var(--brand-strong);color:#fff}
  .m-action:active .m-action__icon{transform:scale(.94)}
  .m-action__label{font-size:.92rem;font-weight:500;letter-spacing:.01em}

  /* Dark-hero pages: overlay is dark → light text/icon. */
  body.has-dark-hero .mobile-nav .m-action{color:#fff}
  body.has-dark-hero .m-action--call .m-action__icon{border-color:rgba(255,255,255,.32);color:#fff}
}

/* ============================================================
   "Wow" motion layer — GSAP ScrollTrigger + Lenis smooth scroll.
   Progressive enhancement driven by assets/js/motion.js. The .gsap-on
   hook is added only once the libraries initialise (never under reduced
   motion), so without JS nothing here alters the base layout.
   ============================================================ */
.gsap-on .ph.has-photo .ph__img,
.gsap-on .hero-visual,
.gsap-on .hero-copy{will-change:transform}

/* Brand-gradient reading-progress bar pinned to the very top. */
.scroll-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:210;pointer-events:none}
.scroll-progress > i{display:block;height:100%;transform:scaleX(0);transform-origin:0 50%;background:var(--rainbow,linear-gradient(90deg,var(--brand),var(--accent-dark)))}

/* Lenis smooth-scroll plumbing (the library's recommended base styles). */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto !important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:hidden}

@media (prefers-reduced-motion:reduce){.scroll-progress{display:none}}
