/* ==========================================================================
   Willow & Stone Interiors - Proposed website preview
   Design system: warm Midwest luxury / editorial / sage + clay + ivory
   Built by Design Growth Hub. Vanilla CSS, no framework.
   ========================================================================== */

/* ----------------------------- Fonts ----------------------------- */
@font-face{font-family:'Inter';font-weight:300;font-style:normal;font-display:swap;src:url('../fonts/inter-300.woff2') format('woff2');}
@font-face{font-family:'Inter';font-weight:400;font-style:normal;font-display:swap;src:url('../fonts/inter-400.woff2') format('woff2');}
@font-face{font-family:'Inter';font-weight:500;font-style:normal;font-display:swap;src:url('../fonts/inter-500.woff2') format('woff2');}
@font-face{font-family:'Inter';font-weight:600;font-style:normal;font-display:swap;src:url('../fonts/inter-600.woff2') format('woff2');}
@font-face{font-family:'Inter';font-weight:700;font-style:normal;font-display:swap;src:url('../fonts/inter-700.woff2') format('woff2');}
@font-face{font-family:'Inter';font-weight:800;font-style:normal;font-display:swap;src:url('../fonts/inter-800.woff2') format('woff2');}
@font-face{font-family:'Fraunces';font-weight:400;font-style:normal;font-display:swap;src:url('../fonts/fraunces-400.woff2') format('woff2');}
@font-face{font-family:'Fraunces';font-weight:500;font-style:normal;font-display:swap;src:url('../fonts/fraunces-500.woff2') format('woff2');}
@font-face{font-family:'Fraunces';font-weight:600;font-style:normal;font-display:swap;src:url('../fonts/fraunces-600.woff2') format('woff2');}
@font-face{font-family:'Fraunces';font-weight:700;font-style:normal;font-display:swap;src:url('../fonts/fraunces-700.woff2') format('woff2');}
@font-face{font-family:'Fraunces';font-weight:900;font-style:normal;font-display:swap;src:url('../fonts/fraunces-900.woff2') format('woff2');}
@font-face{font-family:'Fraunces';font-weight:500;font-style:italic;font-display:swap;src:url('../fonts/fraunces-500-italic.woff2') format('woff2');}
@font-face{font-family:'Fraunces';font-weight:600;font-style:italic;font-display:swap;src:url('../fonts/fraunces-600-italic.woff2') format('woff2');}

/* ----------------------------- Tokens ----------------------------- */
:root{
  --ivory:#FBF8F1; --paper:#FFFDF8; --cream:#F5EDDF; --cream-2:#F0E7D6;
  --sand:#EFE6D5; --stone:#E5DBC8; --taupe:#CBBDA4; --taupe-l:#DBCFB8;
  --sage:#7E8A6A; --sage-2:#929B79; --sage-deep:#586245; --sage-ink:#3C4531;
  --clay:#BD7B52; --clay-deep:#9F6038; --clay-soft:#D89E78; --clay-tint:#F2E1D2;
  --gold:#C2A35E; --gold-soft:#D8C190;
  --ink:#2E2B24; --ink-2:#5B554A; --ink-3:#8C8576;
  --line:rgba(46,43,37,.13); --line-soft:rgba(46,43,37,.07); --line-cream:rgba(255,253,248,.18);
  --sh-1:0 2px 10px -4px rgba(60,52,40,.18);
  --sh-2:0 22px 48px -28px rgba(60,52,40,.42), 0 6px 18px -10px rgba(60,52,40,.16);
  --sh-3:0 50px 90px -45px rgba(50,42,30,.55), 0 14px 32px -16px rgba(50,42,30,.24);
  --r-s:10px; --r:16px; --r-l:24px; --r-xl:34px; --r-pill:999px;
  --serif:'Fraunces','Cormorant Garamond',Georgia,'Times New Roman',serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,Arial,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1); --ease-out:cubic-bezier(.16,.84,.44,1);
  --header-h:78px;
}

/* ----------------------------- Reset ----------------------------- */
*,*::before,*::after{box-sizing:border-box;}
*{margin:0;padding:0;}
html{font-size:17px;-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}
body{
  font-family:var(--sans);font-weight:400;line-height:1.7;color:var(--ink);
  background:var(--ivory);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,picture,svg,video{display:block;max-width:100%;height:auto;}
a{color:inherit;text-decoration:none;}
button,input,select,textarea{font:inherit;color:inherit;}
ul,ol{list-style:none;}
h1,h2,h3,h4{line-height:1.1;font-weight:500;color:var(--ink);text-wrap:balance;}
::selection{background:var(--sage);color:#fff;}
:focus-visible{outline:2.5px solid var(--gold);outline-offset:3px;border-radius:4px;}
.skip-link{position:absolute;left:-999px;top:0;background:var(--sage-ink);color:#fff;padding:12px 18px;z-index:200;border-radius:0 0 10px 0;}
.skip-link:focus{left:0;}

/* ----------------------------- Layout ----------------------------- */
.container{width:100%;max-width:1500px;margin-inline:auto;padding-inline:clamp(24px,4vw,80px);}
.container-wide{max-width:1720px;}
.container-narrow{max-width:820px;}
.section{padding-block:clamp(64px,9vw,128px);position:relative;}
.section-sm{padding-block:clamp(48px,6vw,84px);}
.bg-ivory{background:var(--ivory);} .bg-paper{background:var(--paper);}
.bg-cream{background:linear-gradient(180deg,var(--cream),var(--cream-2));}
.bg-sand{background:linear-gradient(170deg,var(--sand),#E9DECB);}
.bg-sage{background:linear-gradient(160deg,#7E8A6A,#5A6446);color:#F4EFE3;}
.bg-deep{background:radial-gradient(120% 130% at 15% 10%,#444C36 0%,#333A28 55%,#272B1E 100%);color:#F1ECDE;}
.relative{position:relative;} .ov-hidden{overflow:hidden;}

/* ----------------------------- Type utilities ----------------------------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.7em;font-family:var(--sans);
  font-size:.8rem;font-weight:700;letter-spacing:.26em;text-transform:uppercase;
  color:var(--clay-deep);
}
.eyebrow.center{justify-content:center;}
.eyebrow.on-dark{color:var(--gold-soft);}
.display{font-family:var(--serif);font-weight:500;letter-spacing:-.01em;line-height:1.04;}
.display-1{font-family:var(--serif);font-weight:500;font-size:clamp(2.7rem,6.4vw,5.1rem);line-height:1.0;letter-spacing:-.015em;}
.display-2{font-family:var(--serif);font-weight:500;font-size:clamp(2.15rem,4.4vw,3.5rem);line-height:1.05;letter-spacing:-.01em;}
.display-3{font-family:var(--serif);font-weight:500;font-size:clamp(1.7rem,3vw,2.4rem);line-height:1.12;}
.display em,.display-1 em,.display-2 em,.display-3 em{font-style:italic;color:var(--clay);font-weight:600;}
.display .soft,.display-2 .soft{color:var(--sage-deep);}
.lead{font-size:clamp(1.12rem,1.5vw,1.32rem);line-height:1.62;color:var(--ink-2);font-weight:400;}
.muted{color:var(--ink-2);} .muted-3{color:var(--ink-3);}
p{color:var(--ink-2);} p+p{margin-top:1.05em;}
.text-center{text-align:center;} .mx-auto{margin-inline:auto;}
.measure{max-width:62ch;} .measure-sm{max-width:48ch;}
.serif-quote{font-family:var(--serif);font-weight:500;font-style:italic;font-size:clamp(1.5rem,2.8vw,2.3rem);line-height:1.3;color:var(--sage-ink);}

.section-head{max-width:760px;}
.section-head.center{margin-inline:auto;text-align:center;}
.section-head .eyebrow{margin-bottom:1.1rem;}
.section-head .lead{margin-top:1.15rem;}

/* ----------------------------- Buttons ----------------------------- */
.btn{
  --bg:var(--clay);--fg:#fff;
  position:relative;display:inline-flex;align-items:center;gap:.65em;
  font-family:var(--sans);font-weight:600;font-size:.96rem;letter-spacing:.01em;
  padding:1em 1.7em;border-radius:var(--r-pill);background:var(--bg);color:var(--fg);
  border:1.5px solid transparent;cursor:pointer;overflow:hidden;isolation:isolate;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),background-color .4s var(--ease),color .4s var(--ease);
  box-shadow:0 12px 24px -14px rgba(159,96,56,.7);
}
.btn .arr{transition:transform .5s var(--ease);}
.btn:hover{transform:translateY(-3px);box-shadow:0 22px 34px -16px rgba(159,96,56,.7);}
.btn:hover .arr{transform:translateX(4px);}
.btn::after{content:"";position:absolute;inset:0;z-index:-1;background:var(--clay-deep);transform:translateY(101%);transition:transform .5s var(--ease);}
.btn:hover::after{transform:translateY(0);}
.btn-sage{--bg:var(--sage-deep);box-shadow:0 12px 24px -14px rgba(58,69,49,.7);}
.btn-sage::after{background:var(--sage-ink);}
.btn-sage:hover{box-shadow:0 22px 34px -16px rgba(58,69,49,.7);}
.btn-ghost{--bg:transparent;--fg:var(--ink);border-color:var(--line);box-shadow:none;}
.btn-ghost::after{background:var(--ink);}
.btn-ghost:hover{--fg:#fff;color:#fff;border-color:transparent;box-shadow:0 18px 30px -18px rgba(46,43,37,.5);}
.btn-ghost.on-dark{--fg:#F4EFE3;border-color:var(--line-cream);}
.btn-ghost.on-dark::after{background:#F4EFE3;}
.btn-ghost.on-dark:hover{--fg:var(--sage-ink);color:var(--sage-ink);}
.btn-light{--bg:#F7F2E9;--fg:var(--sage-ink);box-shadow:0 14px 26px -16px rgba(0,0,0,.4);}
.btn-light::after{background:#fff;}
.link-arrow{
  display:inline-flex;align-items:center;gap:.5em;font-weight:600;font-size:.96rem;color:var(--clay-deep);
  border-bottom:1.5px solid transparent;padding-bottom:2px;transition:gap .4s var(--ease),border-color .4s var(--ease),color .3s;
}
.link-arrow .arr{transition:transform .4s var(--ease);}
.link-arrow:hover{gap:.85em;border-color:var(--clay);} .link-arrow:hover .arr{transform:translateX(3px);}
.link-arrow.on-dark{color:var(--gold-soft);} .link-arrow.on-dark:hover{border-color:var(--gold);}
.btn-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center;}

/* ----------------------------- Header ----------------------------- */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:100;height:var(--header-h);
  display:flex;align-items:center;
  transition:background-color .5s var(--ease),box-shadow .5s var(--ease),height .4s var(--ease),border-color .5s;
  border-bottom:1px solid transparent;
}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:24px;width:100%;}
.site-header.scrolled,.site-header.solid{
  background:rgba(251,248,241,.86);backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  box-shadow:0 8px 30px -22px rgba(60,52,40,.5);border-bottom-color:var(--line-soft);height:66px;
}
.brand{display:inline-flex;align-items:center;gap:12px;z-index:2;}
.brand img{height:48px;width:auto;transition:height .4s var(--ease);}
.brand .logo-light{display:none;}
.site-header.scrolled .brand img,.site-header.solid .brand img{height:42px;}
.brand .brand-text{display:flex;flex-direction:column;line-height:1;}
.brand .bt-name{font-family:var(--serif);font-weight:600;font-size:1.32rem;color:var(--sage-ink);letter-spacing:.01em;}
.brand .bt-sub{font-family:var(--sans);font-weight:600;font-size:.58rem;letter-spacing:.36em;text-transform:uppercase;color:var(--clay);margin-top:3px;}
.nav{display:flex;align-items:center;gap:clamp(18px,2vw,30px);}
.nav a{font-size:.94rem;font-weight:500;color:var(--ink);position:relative;padding:6px 0;transition:color .3s;}
.nav a::after{content:"";position:absolute;left:0;bottom:0;height:1.5px;width:0;background:var(--clay);transition:width .4s var(--ease);}
.nav a:hover{color:var(--clay-deep);} .nav a:hover::after{width:100%;}
.nav a.active{color:var(--sage-deep);} .nav a.active::after{width:100%;background:var(--sage);}
.header-cta{display:inline-flex;align-items:center;}
.header-actions{display:flex;align-items:center;gap:20px;}
.header-actions .btn{padding:.72em 1.3em;font-size:.9rem;}
.nav-toggle{display:none;}
.mobile-drawer{display:none;} /* enabled only at mobile breakpoint below */

/* hero header transparency (page sets .header-over) */
.header-over .site-header:not(.scrolled){color:#F4EFE3;}
.header-over .site-header:not(.scrolled) .nav a{color:#F1ECDE;}
.header-over .site-header:not(.scrolled) .nav a.active{color:#fff;}
.header-over .site-header:not(.scrolled) .bt-name{color:#F6F1E6;}
.header-over .site-header:not(.scrolled) .brand .logo-dark{display:none;}
.header-over .site-header:not(.scrolled) .brand .logo-light{display:block;}

/* mobile drawer */
@media (max-width:960px){
  .nav,.header-cta{display:none;}
  .nav-toggle{
    display:inline-flex;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;
    border:1px solid var(--line);border-radius:12px;background:rgba(255,253,248,.7);cursor:pointer;align-items:center;z-index:120;
  }
  .header-over .site-header:not(.scrolled) .nav-toggle{border-color:var(--line-cream);background:rgba(255,255,255,.12);}
  .nav-toggle span{width:20px;height:2px;background:var(--ink);border-radius:2px;transition:transform .4s var(--ease),opacity .3s;}
  .header-over .site-header:not(.scrolled) .nav-toggle span{background:#F4EFE3;}
  .nav-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg);background:var(--ink);}
  .nav-open .nav-toggle span:nth-child(2){opacity:0;}
  .nav-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg);background:var(--ink);}
  .mobile-drawer{
    position:fixed;inset:0;z-index:110;background:linear-gradient(160deg,#FBF8F1,#F1E7D6);
    display:flex;flex-direction:column;justify-content:center;padding:90px clamp(28px,8vw,64px) 48px;
    transform:translateX(100%);transition:transform .55s var(--ease);visibility:hidden;
  }
  .nav-open .mobile-drawer{transform:translateX(0);visibility:visible;}
  .mobile-drawer .m-eyebrow{font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--clay);font-weight:600;margin-bottom:20px;}
  .mobile-drawer a.m-link{font-family:var(--serif);font-size:clamp(1.9rem,7vw,2.6rem);font-weight:500;color:var(--sage-ink);padding:9px 0;border-bottom:1px solid var(--line-soft);
    opacity:0;transform:translateY(14px);transition:opacity .5s var(--ease),transform .5s var(--ease),color .3s;}
  .nav-open .mobile-drawer a.m-link{opacity:1;transform:none;transition-delay:calc(.18s + var(--i,0)*.05s);}
  .mobile-drawer a.m-link:hover{color:var(--clay-deep);}
  .mobile-drawer .m-foot{margin-top:34px;display:flex;flex-direction:column;gap:14px;}
  .mobile-drawer .m-foot .btn{align-self:flex-start;}
  .mobile-drawer .m-contact{font-size:.95rem;color:var(--ink-2);}
  .mobile-drawer .m-contact a{color:var(--clay-deep);font-weight:600;}
}
body.nav-open{overflow:hidden;}

/* ----------------------------- Hero ----------------------------- */
.hero{position:relative;min-height:min(94vh,860px);display:flex;align-items:flex-end;overflow:hidden;isolation:isolate;}
.hero-media{position:absolute;inset:0;z-index:-2;}
.hero-media img{width:100%;height:100%;object-fit:cover;object-position:center 40%;transform:scale(1.08);}
.hero-media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(30,27,20,.42) 0%,rgba(30,27,20,.12) 32%,rgba(30,27,20,.18) 60%,rgba(28,25,18,.74) 100%);}
.hero-inner{padding-bottom:clamp(48px,8vh,96px);padding-top:calc(var(--header-h) + 40px);color:#F6F1E6;width:100%;}
.hero h1{font-family:var(--serif);font-weight:500;color:#FCF8EF;font-size:clamp(2.7rem,6.6vw,5.4rem);line-height:1.0;letter-spacing:-.015em;max-width:16ch;text-shadow:0 2px 30px rgba(20,16,10,.35);}
.hero h1 em{font-style:italic;color:var(--gold-soft);font-weight:600;}
.hero .hero-sub{margin-top:1.5rem;max-width:60ch;font-size:clamp(1.05rem,1.5vw,1.28rem);line-height:1.6;color:#ECE6D8;}
.hero .btn-row{margin-top:2.2rem;}
.hero .eyebrow{color:var(--gold-soft);margin-bottom:1.5rem;}
.scroll-cue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:8px;color:#EBE5D6;font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;opacity:.85;}
.scroll-cue .line{width:1.5px;height:46px;background:linear-gradient(var(--gold-soft),transparent);overflow:hidden;position:relative;}
.scroll-cue .line::after{content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--gold-soft);animation:scrollcue 2.2s var(--ease) infinite;}
@keyframes scrollcue{0%{top:-55%}60%,100%{top:110%}}

/* floating location chips */
.chips{display:flex;flex-wrap:wrap;gap:9px;}
.chip{
  display:inline-flex;align-items:center;gap:.5em;padding:.5em 1em;border-radius:var(--r-pill);
  font-size:.82rem;font-weight:600;letter-spacing:.02em;
  background:rgba(255,253,248,.14);color:#F4EFE3;border:1px solid rgba(255,253,248,.28);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.chip .dot{width:5px;height:5px;border-radius:50%;background:var(--gold-soft);}
.hero-chips{margin-top:2rem;}
.chips.on-light .chip{background:rgba(126,138,106,.1);color:var(--sage-ink);border-color:rgba(126,138,106,.28);backdrop-filter:none;}
.chips.on-light .chip .dot{background:var(--clay);}

/* ----------------------------- Split / feature rows ----------------------------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,80px);align-items:center;}
.split.ratio-6040{grid-template-columns:1.1fr .9fr;}
.split.ratio-4060{grid-template-columns:.9fr 1.1fr;}
.split.top{align-items:flex-start;}
.split .stack>*+*{margin-top:1.1rem;}
@media (max-width:860px){.split,.split.ratio-6040,.split.ratio-4060{grid-template-columns:1fr;gap:clamp(28px,7vw,46px);}.split.reverse-m>.media{order:-1;}.split .stack[style*="sticky"]{position:static!important;top:auto!important;}}

.figure{position:relative;border-radius:var(--r-l);overflow:hidden;box-shadow:var(--sh-2);}
.figure img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease);}
.figure.tall{aspect-ratio:4/5;} .figure.wide{aspect-ratio:7/5;} .figure.square{aspect-ratio:1/1;}
.figure:hover img{transform:scale(1.05);}
.figure .tag{position:absolute;left:18px;bottom:18px;background:rgba(247,242,233,.92);color:var(--sage-ink);
  padding:.55em 1.05em;border-radius:var(--r-pill);font-size:.78rem;font-weight:600;letter-spacing:.04em;box-shadow:var(--sh-1);}
.figure-stack{position:relative;}
.figure-stack .f-back{border-radius:var(--r-l);overflow:hidden;box-shadow:var(--sh-2);}
.figure-stack .f-front{position:absolute;right:-6%;bottom:-10%;width:46%;border-radius:var(--r);overflow:hidden;
  box-shadow:var(--sh-3);border:6px solid var(--paper);}
.figure-stack .f-badge{position:absolute;left:-22px;top:28px;background:var(--clay);color:#fff;border-radius:var(--r);
  padding:14px 18px;box-shadow:var(--sh-2);max-width:170px;}
.figure-stack .f-badge .n{font-family:var(--serif);font-size:2.1rem;line-height:1;font-weight:600;}
.figure-stack .f-badge .l{font-size:.74rem;letter-spacing:.04em;margin-top:4px;color:#F6E7DA;}
@media (max-width:860px){
  .figure-stack{max-width:420px;margin-inline:auto;}
  .figure-stack .f-front{position:relative;right:0;bottom:0;width:60%;margin:-18% 8px 0 auto;}
  .figure-stack .f-badge{left:6px;top:14px;}
}

/* ----------------------------- Value list (editorial, no boxes) ----------------------------- */
.value-list{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid var(--line);}
.value-list .v{padding:26px 28px 26px 0;border-bottom:1px solid var(--line);}
.value-list .v:nth-child(odd){padding-right:36px;border-right:1px solid var(--line);}
.value-list .v:nth-child(even){padding-left:36px;}
.value-list .v .vh{display:flex;align-items:center;gap:12px;}
.value-list .v .vi{color:var(--clay-deep);flex:none;}
.value-list .v h3{font-family:var(--serif);font-size:1.4rem;font-weight:600;}
.value-list .v p{margin-top:.5rem;font-size:.98rem;}
@media (max-width:680px){.value-list{grid-template-columns:1fr;}.value-list .v,.value-list .v:nth-child(odd){padding:22px 0;border-right:none;}}

.stat-ribbon{display:flex;flex-wrap:wrap;gap:clamp(24px,5vw,64px);align-items:flex-start;}
.stat-ribbon .s .n{font-family:var(--serif);font-size:clamp(2.4rem,4vw,3.4rem);font-weight:600;color:var(--sage-deep);line-height:1;}
.stat-ribbon .s .l{margin-top:.5rem;font-size:.9rem;color:var(--ink-2);max-width:20ch;}
.bg-deep .stat-ribbon .s .n,.bg-sage .stat-ribbon .s .n{color:var(--gold-soft);}

/* ----------------------------- Editorial service index (NOT cards) ----------------------------- */
.service-index{border-top:1px solid var(--line);}
.service-row{
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:clamp(18px,3vw,44px);
  padding:clamp(22px,3vw,34px) 0;border-bottom:1px solid var(--line);position:relative;
  transition:padding-left .5s var(--ease);
}
.service-row .num{font-family:var(--serif);font-size:1.25rem;color:var(--clay);font-weight:600;font-feature-settings:"tnum";}
.service-row .s-main{display:flex;flex-direction:column;gap:.35rem;}
.service-row h3{font-family:var(--serif);font-size:clamp(1.6rem,2.8vw,2.3rem);font-weight:500;color:var(--ink);transition:color .4s;}
.service-row .s-desc{font-size:1rem;color:var(--ink-2);max-width:64ch;}
.service-row .s-go{width:50px;height:50px;border-radius:50%;border:1.5px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--sage-deep);transition:all .5s var(--ease);flex:none;}
.service-row::before{content:"";position:absolute;left:-24px;top:0;bottom:0;width:3px;background:var(--clay);transform:scaleY(0);transform-origin:top;transition:transform .5s var(--ease);border-radius:3px;}
.service-row:hover{padding-left:18px;}
.service-row:hover::before{transform:scaleY(1);}
.service-row:hover h3{color:var(--clay-deep);}
.service-row:hover .s-go{background:var(--clay);border-color:var(--clay);color:#fff;transform:rotate(-45deg);}
@media (max-width:680px){.service-row{grid-template-columns:auto 1fr;}.service-row .s-go{display:none;}}

/* ----------------------------- Soft cards (used sparingly) ----------------------------- */
.card-grid{display:grid;gap:clamp(18px,2.5vw,30px);}
.cols-3{grid-template-columns:repeat(3,1fr);} .cols-2{grid-template-columns:repeat(2,1fr);}
.cols-4{grid-template-columns:repeat(4,1fr);}
@media (max-width:980px){.cols-3,.cols-4{grid-template-columns:repeat(2,1fr);}}
@media (max-width:620px){.cols-2,.cols-3,.cols-4{grid-template-columns:1fr;}}
.card{
  background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-l);padding:30px 28px;
  box-shadow:var(--sh-1);transition:transform .55s var(--ease),box-shadow .55s var(--ease),border-color .4s;position:relative;overflow:hidden;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--sh-2);border-color:var(--line);}
.card .c-ic{width:54px;height:54px;border-radius:15px;display:flex;align-items:center;justify-content:center;margin-bottom:18px;
  background:linear-gradient(155deg,#EEF0E5,#E2E6D2);color:var(--sage-deep);}
.card.clay .c-ic{background:linear-gradient(155deg,#F4E5D7,#EFD7C2);color:var(--clay-deep);}
.card h3{font-family:var(--serif);font-size:1.5rem;font-weight:600;margin-bottom:.4rem;}
.card p{font-size:.98rem;}
.card .c-go{margin-top:16px;}

/* journal cards */
.journal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(22px,2.5vw,34px);}
@media (max-width:920px){.journal-grid{grid-template-columns:1fr;max-width:560px;margin-inline:auto;}}
.j-card{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-l);overflow:hidden;box-shadow:var(--sh-1);
  transition:transform .55s var(--ease),box-shadow .55s var(--ease);}
.j-card:hover{transform:translateY(-6px);box-shadow:var(--sh-2);}
.j-card .j-img{aspect-ratio:3/2;overflow:hidden;}
.j-card .j-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease);}
.j-card:hover .j-img img{transform:scale(1.06);}
.j-card .j-body{padding:24px 26px 28px;display:flex;flex-direction:column;flex:1;}
.j-card .j-cat{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--clay-deep);font-weight:600;}
.j-card h3{font-family:var(--serif);font-size:1.4rem;font-weight:600;line-height:1.16;margin:.5rem 0 .6rem;}
.j-card p{font-size:.95rem;flex:1;}
.j-card .link-arrow{margin-top:16px;}

/* ----------------------------- Process timeline ----------------------------- */
.timeline{position:relative;}
.timeline::before{content:"";position:absolute;left:23px;top:10px;bottom:10px;width:2px;background:linear-gradient(var(--sage),var(--clay-soft));opacity:.45;}
.t-step{position:relative;padding-left:74px;padding-block:clamp(18px,2.4vw,30px);}
.t-step .t-node{position:absolute;left:0;top:clamp(18px,2.4vw,30px);width:48px;height:48px;border-radius:50%;background:var(--paper);
  border:2px solid var(--sage);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:600;font-size:1.2rem;color:var(--sage-deep);box-shadow:var(--sh-1);z-index:1;}
.t-step:hover .t-node{background:var(--sage);color:#fff;border-color:var(--sage);}
.t-step h3{font-family:var(--serif);font-size:clamp(1.4rem,2.4vw,1.9rem);font-weight:500;}
.t-step p{margin-top:.5rem;max-width:58ch;}
.t-step .t-meta{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--clay-deep);font-weight:600;margin-bottom:.3rem;}
/* horizontal timeline (home teaser) */
.timeline-h{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;position:relative;}
.timeline-h .th{position:relative;padding-top:54px;}
.timeline-h::before{content:"";position:absolute;top:23px;left:6%;right:6%;height:2px;background:linear-gradient(90deg,var(--sage),var(--clay-soft));opacity:.5;}
.timeline-h .th .dot{position:absolute;top:0;left:0;width:46px;height:46px;border-radius:50%;background:var(--paper);border:2px solid var(--sage);
  display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:600;color:var(--sage-deep);box-shadow:var(--sh-1);}
.timeline-h .th h4{font-family:var(--serif);font-size:1.3rem;font-weight:600;}
.timeline-h .th p{font-size:.9rem;margin-top:.3rem;}
@media (max-width:820px){.timeline-h{grid-template-columns:1fr 1fr;}.timeline-h::before{display:none;}}
@media (max-width:460px){.timeline-h{grid-template-columns:1fr;}}

/* ----------------------------- Portfolio editorial ----------------------------- */
.pf-editorial{display:flex;flex-direction:column;gap:clamp(40px,7vw,110px);}
.pf-item{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,72px);align-items:center;}
.pf-item.reverse .pf-media{order:2;}
.pf-media{position:relative;border-radius:var(--r-l);overflow:hidden;box-shadow:var(--sh-2);}
.pf-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3;transition:transform 1.5s var(--ease);}
.pf-item:hover .pf-media img{transform:scale(1.05);}
.pf-item.tall .pf-media img{aspect-ratio:4/5;}
.pf-num{font-family:var(--serif);font-size:clamp(2.4rem,5vw,3.6rem);color:var(--taupe);font-weight:500;line-height:1;}
.pf-cat{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--clay-deep);font-weight:600;margin:14px 0 10px;}
.pf-text h3{font-family:var(--serif);font-size:clamp(1.8rem,3.4vw,2.8rem);font-weight:500;line-height:1.08;}
.pf-text p{margin-top:1rem;max-width:50ch;}
.pf-meta{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px;}
.pf-meta .m{font-size:.8rem;font-weight:600;color:var(--sage-deep);background:rgba(126,138,106,.12);border-radius:var(--r-pill);padding:.45em 1em;}
@media (max-width:820px){.pf-item,.pf-item.reverse .pf-media{grid-template-columns:1fr;order:0;}}

/* gallery mosaic */
.mosaic{display:grid;grid-template-columns:repeat(6,1fr);gap:clamp(12px,1.4vw,18px);}
.mosaic .m{border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-1);position:relative;}
.mosaic .m img{width:100%;height:100%;object-fit:cover;transition:transform 1.3s var(--ease);}
.mosaic .m:hover img{transform:scale(1.07);}
.mosaic .m.span3{grid-column:span 3;aspect-ratio:3/2;}
.mosaic .m.span2{grid-column:span 2;aspect-ratio:1/1;}
.mosaic .m.span4{grid-column:span 4;aspect-ratio:16/9;}
@media (max-width:760px){.mosaic{grid-template-columns:repeat(2,1fr);}.mosaic .m.span3,.mosaic .m.span2,.mosaic .m.span4{grid-column:span 1;aspect-ratio:4/3;}}

/* ----------------------------- Statement / quote band ----------------------------- */
.statement{position:relative;text-align:center;max-width:960px;margin-inline:auto;}
.statement .q{font-family:var(--serif);font-style:italic;font-weight:500;font-size:clamp(1.7rem,3.6vw,2.9rem);line-height:1.28;color:var(--sage-ink);}
.bg-deep .statement .q,.bg-sage .statement .q{color:#F4EFE3;}
.statement .qmark{font-family:var(--serif);font-size:5rem;line-height:.4;color:var(--clay);opacity:.5;}
.statement .by{margin-top:1.6rem;font-size:.9rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);font-weight:600;}
.bg-deep .statement .by{color:var(--gold-soft);}

/* ----------------------------- CTA band ----------------------------- */
.cta-band{position:relative;overflow:hidden;border-radius:clamp(20px,3vw,40px);padding:clamp(44px,7vw,92px) clamp(28px,6vw,80px);text-align:center;}
.cta-band .display-2{max-width:18ch;margin-inline:auto;}
.cta-band .lead{margin:1.2rem auto 0;max-width:54ch;}
.cta-band .btn-row{justify-content:center;margin-top:2.2rem;}
.cta-band .motif{position:absolute;inset:0;z-index:0;opacity:.5;pointer-events:none;}
.cta-band>*{position:relative;z-index:1;}

/* ----------------------------- FAQ accordion ----------------------------- */
.faq{border-top:1px solid var(--line);max-width:880px;}
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:24px;text-align:left;background:none;border:none;cursor:pointer;
  padding:clamp(20px,2.4vw,28px) 0;font-family:var(--serif);font-size:clamp(1.2rem,2vw,1.55rem);font-weight:600;color:var(--ink);transition:color .3s;}
.faq-q:hover{color:var(--clay-deep);}
.faq-icon{flex:none;width:34px;height:34px;border-radius:50%;border:1.5px solid var(--line);position:relative;transition:all .4s var(--ease);}
.faq-icon::before,.faq-icon::after{content:"";position:absolute;background:var(--sage-deep);border-radius:2px;top:50%;left:50%;transition:transform .4s var(--ease),background .3s;}
.faq-icon::before{width:13px;height:1.8px;transform:translate(-50%,-50%);}
.faq-icon::after{width:1.8px;height:13px;transform:translate(-50%,-50%);}
.faq-item.open .faq-icon{background:var(--clay);border-color:var(--clay);}
.faq-item.open .faq-icon::before,.faq-item.open .faq-icon::after{background:#fff;}
.faq-item.open .faq-icon::after{transform:translate(-50%,-50%) scaleY(0);}
.faq-a{overflow:hidden;max-height:0;transition:max-height .5s var(--ease);}
.faq-a-inner{padding-bottom:clamp(20px,2.4vw,28px);max-width:70ch;color:var(--ink-2);}
.faq-a-inner a{color:var(--clay-deep);font-weight:600;border-bottom:1px solid var(--clay-soft);}

/* ----------------------------- Breadcrumb / page hero ----------------------------- */
.page-hero{position:relative;padding-top:calc(var(--header-h) + clamp(40px,7vw,84px));padding-bottom:clamp(34px,5vw,64px);overflow:hidden;}
.page-hero .breadcrumb{margin-bottom:1.5rem;}
.breadcrumb{display:flex;flex-wrap:wrap;gap:.5em;font-size:.82rem;color:var(--ink-3);font-weight:500;}
.breadcrumb a{color:var(--ink-2);transition:color .3s;}.breadcrumb a:hover{color:var(--clay-deep);}
.breadcrumb .sep{color:var(--taupe);}
.page-hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(2.4rem,5.4vw,4.3rem);line-height:1.02;letter-spacing:-.015em;max-width:18ch;}
.page-hero h1 em{font-style:italic;color:var(--clay);}
.page-hero .lead{margin-top:1.3rem;max-width:60ch;}
.page-hero.with-media{min-height:min(62vh,600px);display:flex;align-items:flex-end;color:#F6F1E6;}
.page-hero.with-media .breadcrumb{color:#E2DCCD;}.page-hero.with-media .breadcrumb a{color:#EFE9DA;}
.page-hero.with-media h1{color:#FCF8EF;} .page-hero.with-media h1 em{color:var(--gold-soft);}
.page-hero.with-media .lead{color:#ECE6D8;}
.page-hero .media-bg{position:absolute;inset:0;z-index:-2;}
.page-hero .media-bg img{width:100%;height:100%;object-fit:cover;}
.page-hero .media-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(28,25,18,.42),rgba(28,25,18,.2) 45%,rgba(28,25,18,.72));}

/* ----------------------------- Article (journal) ----------------------------- */
.article{font-size:1.13rem;line-height:1.8;color:var(--ink-2);}
.article>*+*{margin-top:1.3em;}
.article h2{font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.3rem);font-weight:600;color:var(--ink);margin-top:2.2em;line-height:1.14;}
.article h3{font-family:var(--serif);font-size:clamp(1.35rem,2.2vw,1.7rem);font-weight:600;color:var(--ink);margin-top:1.6em;}
.article p>strong{color:var(--ink);font-weight:700;}
.article a{color:var(--clay-deep);font-weight:600;border-bottom:1px solid var(--clay-soft);transition:border-color .3s;}
.article a:hover{border-color:var(--clay);}
.article ul.bul{margin-left:0;display:flex;flex-direction:column;gap:.7em;}
.article ul.bul li{position:relative;padding-left:34px;}
.article ul.bul li::before{content:"";position:absolute;left:6px;top:.62em;width:9px;height:9px;border-radius:50%;background:var(--clay);box-shadow:0 0 0 4px var(--clay-tint);}
.article blockquote{margin:1.6em 0;padding:6px 0 6px 30px;border-left:3px solid var(--sage);
  font-family:var(--serif);font-style:italic;font-size:1.5rem;line-height:1.34;color:var(--sage-ink);}
.article .pullquote{font-family:var(--serif);font-style:italic;font-size:clamp(1.5rem,2.6vw,2rem);line-height:1.3;color:var(--sage-ink);text-align:center;padding:1.2em 0;}
.article figure{margin:1.8em 0;border-radius:var(--r-l);overflow:hidden;box-shadow:var(--sh-2);}
.article figure img{width:100%;}
.article figcaption{font-size:.85rem;color:var(--ink-3);text-align:center;margin-top:.7em;}
.article-meta{display:flex;flex-wrap:wrap;gap:18px;align-items:center;font-size:.85rem;color:var(--ink-3);}
.article-meta .pill{background:rgba(126,138,106,.12);color:var(--sage-deep);font-weight:600;padding:.4em 1em;border-radius:var(--r-pill);}
.toc{background:var(--cream);border:1px solid var(--line-soft);border-radius:var(--r-l);padding:24px 28px;}
.toc .t-lab{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--clay-deep);font-weight:700;margin-bottom:12px;}
.toc a{display:block;padding:7px 0;border-bottom:1px solid var(--line-soft);font-weight:500;color:var(--ink-2);transition:color .3s,padding-left .3s;}
.toc a:hover{color:var(--clay-deep);padding-left:6px;}

.author-row{display:flex;align-items:center;gap:16px;}
.author-row .av{width:58px;height:58px;border-radius:50%;background:linear-gradient(150deg,var(--sage),var(--sage-deep));color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1.5rem;font-weight:600;flex:none;}
.author-row .an{font-weight:700;color:var(--ink);} .author-row .ad{font-size:.88rem;color:var(--ink-3);}

/* ----------------------------- Contact form ----------------------------- */
.form-wrap{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-xl);padding:clamp(28px,4vw,48px);box-shadow:var(--sh-2);}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px 22px;}
.field{display:flex;flex-direction:column;gap:8px;}
.field.full{grid-column:1/-1;}
.field label{font-size:.82rem;font-weight:600;letter-spacing:.04em;color:var(--ink);text-transform:uppercase;}
.field label .req{color:var(--clay);}
.field input,.field select,.field textarea{
  width:100%;padding:.92em 1.05em;border:1.5px solid var(--line);border-radius:var(--r-s);background:var(--ivory);
  font-size:1rem;color:var(--ink);transition:border-color .3s,box-shadow .3s,background .3s;
}
.field textarea{min-height:130px;resize:vertical;line-height:1.6;}
.field select{appearance:none;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='%23586245' stroke-width='2.5' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1.05em center;padding-right:2.6em;cursor:pointer;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--sage);background:#fff;box-shadow:0 0 0 4px rgba(126,138,106,.16);}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-3);}
.consent{display:flex;align-items:flex-start;gap:12px;font-size:.9rem;color:var(--ink-2);}
.consent input{width:20px;height:20px;margin-top:3px;accent-color:var(--sage);flex:none;}
.form-note{font-size:.82rem;color:var(--ink-3);margin-top:6px;}
.form-wrap .btn{width:100%;justify-content:center;margin-top:4px;}
@media (max-width:640px){.form-grid{grid-template-columns:1fr;}}

.contact-aside{display:flex;flex-direction:column;gap:22px;}
.contact-line{display:flex;gap:14px;align-items:flex-start;}
.contact-line .ci{width:46px;height:46px;border-radius:13px;background:linear-gradient(150deg,#EEF0E5,#E2E6D2);color:var(--sage-deep);display:flex;align-items:center;justify-content:center;flex:none;}
.contact-line .cl-lab{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);font-weight:600;}
.contact-line .cl-val{font-weight:600;color:var(--ink);font-size:1.05rem;}
.contact-line a.cl-val:hover{color:var(--clay-deep);}

/* ----------------------------- Footer ----------------------------- */
.site-footer{background:radial-gradient(120% 140% at 12% 0%,#3D4634 0%,#303825 40%,#262B1D 100%);background-color:#272C1E;color:#D9D3C4;position:relative;overflow:hidden;}
.site-footer .f-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:clamp(28px,4vw,56px);padding-block:clamp(56px,7vw,86px);}
.site-footer .f-brand .fb-name{font-family:var(--serif);font-size:1.9rem;font-weight:600;color:#F6F1E6;line-height:1;}
.site-footer .f-brand .fb-sub{font-size:.6rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-soft);font-weight:600;margin-top:6px;}
.site-footer .f-brand p{margin-top:18px;color:#C8C2B2;max-width:34ch;font-size:.96rem;}
.site-footer .f-social{display:flex;gap:12px;margin-top:22px;}
.site-footer .f-social a{width:42px;height:42px;border-radius:12px;border:1px solid var(--line-cream);display:flex;align-items:center;justify-content:center;color:#E6E0D0;transition:all .4s var(--ease);}
.site-footer .f-social a:hover{background:var(--gold);color:#2A2A1E;border-color:var(--gold);transform:translateY(-3px);}
.site-footer .f-col h4{font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-soft);font-weight:600;margin-bottom:18px;}
.site-footer .f-col a,.site-footer .f-col p{display:block;color:#CDC7B7;font-size:.96rem;padding:5px 0;transition:color .3s,padding-left .3s;}
.site-footer .f-col a:hover{color:#F6F1E6;padding-left:5px;}
.site-footer .f-area p{color:#C8C2B2;font-size:.95rem;line-height:1.65;padding:0;}
.site-footer .f-contact a{color:#F0EAD9;font-weight:600;}
.site-footer .f-bottom{border-top:1px solid var(--line-cream);padding-block:24px;display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;font-size:.84rem;color:#B0AA9A;}
.site-footer .f-bottom a:hover{color:#F6F1E6;}
.site-footer .f-bottom .made{color:#9F9A8A;}
.site-footer .f-motif{position:absolute;right:-40px;bottom:-40px;width:340px;opacity:.1;pointer-events:none;}
@media (max-width:900px){.site-footer .f-top{grid-template-columns:1fr 1fr;gap:36px 28px;}.site-footer .f-brand{grid-column:1/-1;}}
@media (max-width:560px){.site-footer .f-top{grid-template-columns:1fr;}}

/* sticky mobile CTA */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:80;display:none;padding:12px 16px calc(12px + env(safe-area-inset-bottom));
  background:rgba(251,248,241,.92);backdrop-filter:blur(12px);border-top:1px solid var(--line);box-shadow:0 -8px 24px -18px rgba(60,52,40,.5);}
.sticky-cta .btn{width:100%;justify-content:center;}
@media (max-width:720px){.sticky-cta{display:block;}}

/* ----------------------------- Decorative motifs ----------------------------- */
.motif-shape{position:absolute;z-index:0;pointer-events:none;}
.motif-leaf{color:var(--sage);opacity:.16;}
.motif-arch-line{color:var(--clay);opacity:.5;}
.divider-mark{display:flex;align-items:center;justify-content:center;gap:16px;color:var(--clay);}
.divider-mark .ln{height:1px;width:min(120px,18vw);background:linear-gradient(90deg,transparent,var(--gold));}
.divider-mark .ln.r{background:linear-gradient(90deg,var(--gold),transparent);}
.divider-mark svg{width:30px;height:30px;color:var(--sage);}
.section-num{font-family:var(--serif);font-size:clamp(3rem,7vw,5.5rem);color:var(--taupe);opacity:.5;font-weight:500;line-height:1;}
.grain{position:absolute;inset:0;pointer-events:none;opacity:.4;mix-blend-mode:multiply;z-index:0;
  background-image:radial-gradient(rgba(120,105,80,.05) 1px,transparent 1px);background-size:4px 4px;}

.kicker-num{display:inline-flex;align-items:baseline;gap:10px;}
.kicker-num .kn{font-family:var(--serif);color:var(--clay);font-size:1.1rem;font-weight:600;}

.pill-list{display:flex;flex-wrap:wrap;gap:10px;}
.pill-list .p{font-size:.86rem;font-weight:600;color:var(--sage-deep);background:var(--paper);border:1px solid var(--line);border-radius:var(--r-pill);padding:.55em 1.1em;
  transition:transform .4s var(--ease),background .3s,color .3s,border-color .3s;}
.pill-list .p:hover{background:var(--sage);color:#fff;border-color:var(--sage);transform:translateY(-2px);}

.tick-list{display:flex;flex-direction:column;gap:13px;}
.tick-list li{display:flex;gap:13px;align-items:flex-start;font-size:1.02rem;color:var(--ink);}
.tick-list li .tk{flex:none;width:26px;height:26px;border-radius:8px;background:rgba(126,138,106,.16);color:var(--sage-deep);display:flex;align-items:center;justify-content:center;margin-top:1px;}
.tick-list.clay li .tk{background:var(--clay-tint);color:var(--clay-deep);}
.tick-list.two{display:grid;grid-template-columns:1fr 1fr;gap:13px 30px;}
@media (max-width:640px){.tick-list.two{grid-template-columns:1fr;}}

/* ----------------------------- Reveal animations ----------------------------- */
/* Entrance animations engage ONLY when JS confirms it is working, via
   body.anim-ready. Without that class (JS disabled or errored), everything is
   fully visible by default. The .is-visible class is added by main.js on scroll. */
body.anim-ready [data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out);transition-delay:var(--d,0ms);will-change:opacity,transform;}
body.anim-ready [data-reveal="fade"]{transform:none;}
body.anim-ready [data-reveal="left"]{transform:translateX(-30px);}
body.anim-ready [data-reveal="right"]{transform:translateX(30px);}
body.anim-ready [data-reveal="scale"]{transform:scale(.94);}
body.anim-ready [data-reveal].is-visible{opacity:1;transform:none;}
body.anim-ready [data-reveal-mask]{clip-path:inset(0 0 100% 0);transition:clip-path 1.1s var(--ease);transition-delay:var(--d,0ms);}
body.anim-ready [data-reveal-mask].is-visible{clip-path:inset(0 0 0 0);}
.reveal-img{overflow:hidden;}
body.anim-ready .reveal-img img{transform:scale(1.16);transition:transform 1.5s var(--ease);}
body.anim-ready .reveal-img.is-visible img{transform:scale(1);}
body.anim-ready .hero h1,body.anim-ready .hero .hero-sub,body.anim-ready .hero .btn-row,body.anim-ready .hero .eyebrow,body.anim-ready .hero-chips{opacity:0;transform:translateY(24px);animation:heroUp 1s var(--ease-out) forwards;}
.hero .eyebrow{animation-delay:.15s;}
.hero h1{animation-delay:.3s;}
.hero .hero-sub{animation-delay:.55s;}
.hero .btn-row{animation-delay:.75s;}
.hero-chips{animation-delay:.95s;}
@keyframes heroUp{to{opacity:1;transform:none;}}
.page-fade{opacity:0;transition:opacity .6s ease;}
.loaded .page-fade{opacity:1;}

@keyframes floaty{0%,100%{transform:translateY(0) rotate(var(--rot,0deg));}50%{transform:translateY(-18px) rotate(var(--rot,0deg));}}
.floaty{animation:floaty 9s ease-in-out infinite;}
.floaty.slow{animation-duration:13s;}
@keyframes drift{0%,100%{transform:translate(0,0);}50%{transform:translate(14px,-10px);}}
.drift{animation:drift 16s ease-in-out infinite;}

.aurora{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden;}
.aurora::before{content:"";position:absolute;width:60vw;height:60vw;left:-10%;top:-20%;border-radius:50%;
  background:radial-gradient(circle,rgba(126,138,106,.16),transparent 62%);animation:auroraMove 22s ease-in-out infinite;}
.aurora::after{content:"";position:absolute;width:50vw;height:50vw;right:-12%;bottom:-22%;border-radius:50%;
  background:radial-gradient(circle,rgba(189,123,82,.13),transparent 62%);animation:auroraMove 26s ease-in-out infinite reverse;}
@keyframes auroraMove{0%,100%{transform:translate(0,0) scale(1);}50%{transform:translate(40px,30px) scale(1.1);}}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important;}
  [data-reveal],[data-reveal-mask]{opacity:1!important;transform:none!important;clip-path:none!important;}
  .reveal-img img,.hero-media img{transform:none!important;}
  .hero h1,.hero .hero-sub,.hero .btn-row,.hero .eyebrow,.hero-chips{opacity:1;transform:none;animation:none;}
}

/* ----------------------------- Helpers ----------------------------- */
.mt-0{margin-top:0;}.mt-1{margin-top:1rem;}.mt-2{margin-top:1.6rem;}.mt-3{margin-top:2.4rem;}.mt-4{margin-top:3.2rem;}
.mb-1{margin-bottom:1rem;}.mb-2{margin-bottom:1.6rem;}.mb-3{margin-bottom:2.4rem;}
.gap-sm{gap:14px;}.flex{display:flex;}.flex-col{flex-direction:column;}.items-center{align-items:center;}.justify-between{justify-content:space-between;}.wrap{flex-wrap:wrap;}
.grid{display:grid;} .hidden{display:none;}
.tint-panel{background:var(--cream);border:1px solid var(--line-soft);border-radius:var(--r-xl);padding:clamp(28px,4vw,52px);}
.tint-panel.sage{background:linear-gradient(160deg,#EBEEE1,#E0E5D2);}
.tint-panel.clay{background:linear-gradient(160deg,#F5E7DA,#F0DAC8);}
.overline-tiny{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:var(--clay-deep);}
.serif{font-family:var(--serif);} .ital{font-style:italic;}
.badge-soft{display:inline-flex;align-items:center;gap:.5em;font-size:.8rem;font-weight:600;color:var(--sage-deep);background:rgba(126,138,106,.13);border-radius:var(--r-pill);padding:.5em 1.1em;}
.badge-soft.clay{color:var(--clay-deep);background:var(--clay-tint);}

/* ----------------------------- Immersive gallery (Portfolio) ----------------------------- */
.gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(14px,1.5vw,24px);}
.gtile{position:relative;overflow:hidden;border-radius:var(--r-l);box-shadow:var(--sh-2);display:block;}
.gtile img{width:100%;height:100%;object-fit:cover;transition:transform 1.5s var(--ease);}
.gtile:hover img{transform:scale(1.06);}
.gtile::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(26,23,16,.62) 0%,rgba(26,23,16,.12) 42%,transparent 68%);transition:opacity .5s var(--ease);}
.gtile .gcap{position:absolute;left:clamp(18px,2vw,30px);right:clamp(18px,2vw,30px);bottom:clamp(18px,2vw,28px);z-index:2;transform:translateY(6px);transition:transform .5s var(--ease);}
.gtile:hover .gcap{transform:translateY(0);}
.gtile .gcap .gc-cat{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-soft);font-weight:700;}
.gtile .gcap h3{font-family:var(--serif);font-size:clamp(1.3rem,1.9vw,1.85rem);font-weight:600;color:#FCF8EF;margin-top:6px;line-height:1.1;}
.gtile .gcap .gc-loc{font-size:.82rem;color:#E2DCCD;margin-top:5px;opacity:0;max-height:0;transition:opacity .5s var(--ease),max-height .5s var(--ease);}
.gtile:hover .gcap .gc-loc{opacity:1;max-height:40px;}
.g-12{grid-column:span 12;} .g-8{grid-column:span 8;} .g-7{grid-column:span 7;}
.g-6{grid-column:span 6;} .g-5{grid-column:span 5;} .g-4{grid-column:span 4;}
.gtile.tall{aspect-ratio:4/5;} .gtile.std{aspect-ratio:4/3;} .gtile.wide{aspect-ratio:16/10;} .gtile.pano{aspect-ratio:21/9;}
@media (max-width:860px){
  .gallery{grid-template-columns:1fr 1fr;}
  .g-12,.g-8,.g-7,.g-6,.g-5,.g-4{grid-column:span 1;}
  .gtile.tall,.gtile.std,.gtile.wide,.gtile.pano{aspect-ratio:4/3;}
  .gtile .gcap .gc-loc{opacity:1;max-height:40px;}
}
/* full-bleed feature band */
.feature-bleed{position:relative;min-height:min(70vh,640px);display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;color:#F6F1E6;}
.feature-bleed img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;}
.feature-bleed::after{content:"";position:absolute;inset:0;background:rgba(26,23,16,.5);z-index:-1;}
.feature-bleed .fb-inner{max-width:780px;padding:40px clamp(24px,5vw,60px);}
.feature-bleed .fb-inner .q{font-family:var(--serif);font-style:italic;font-weight:500;font-size:clamp(1.6rem,3.4vw,2.7rem);line-height:1.28;color:#FCF8EF;}
