/* =========================================================
   Bellissimo Home — styles.css
   Hero: Archiesta (cinematic) · Blocks: Madera (editorial)
   Palette: deep green / ivory / sage / taupe / brown
   ========================================================= */

:root{
  --green:#1C4220;
  --green-deep:#142f17;
  --sage:#A1B296;
  --ivory:#FFFFF5;
  --ivory-2:#F6F2E6;
  --taupe:#8C7D5B;
  --brown:#5E4537;

  --ink:#22301f;
  --muted:#6f6a56;
  --line:rgba(92,69,55,.16);
  --line-2:rgba(28,66,32,.12);

  --maxw:1600px;
  --gutter:90px;
  --radius:16px;
  --radius-lg:26px;

  --ff-display:'Cormorant','Cormorant Garamond',Georgia,serif;
  --ff-serif:'Lora',Georgia,serif;
  --ff-sans:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;

  --ease:cubic-bezier(.16,1,.3,1);
  --shadow:0 30px 70px -34px rgba(28,66,32,.3);
  --shadow-soft:0 20px 44px -26px rgba(28,66,32,.24);

  /* ---- Preloader (tweak freely) ---- */
  --pre-bg:#142f17;        /* panel background */
  --pre-ink:#FFFFF5;       /* logo + wordmark color */
  --pre-accent:#A1B296;    /* sweeping light accent */
  --pre-size:clamp(66px,9vw,104px); /* logo size */
  --pre-speed:1;           /* animation speed multiplier (2 = twice as fast) */
  --pre-exit:.9s;          /* exit (curtain lift) duration */
}

*{box-sizing:border-box}
[hidden]{display:none !important}
html{-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:no-preference){html{scroll-behavior:smooth}}
body{margin:0;background:var(--ivory);color:var(--ink);font-family:var(--ff-sans);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
h1,h2,h3,h4{margin:0;font-weight:400}
p{margin:0}
ul,dl{margin:0;padding:0;list-style:none}
:focus-visible{outline:2px solid var(--green);outline-offset:3px;border-radius:4px}
.skip-link{position:absolute;left:-999px;top:0;z-index:1000;background:var(--green);color:var(--ivory);padding:.7rem 1.1rem}
.skip-link:focus{left:0}

.container-fluid{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}

/* ---------------- Preloader (brand "sun etch") ---------------- */
html.is-preloading{overflow:hidden}
.preloader{position:fixed;inset:0;z-index:1000;display:grid;place-items:center;background:var(--pre-bg);color:var(--pre-ink);transition:transform var(--pre-exit) cubic-bezier(.76,0,.24,1) .2s,opacity calc(var(--pre-exit)*.5) ease}
.preloader__inner{display:flex;flex-direction:column;align-items:center;gap:clamp(1.1rem,2.6vw,1.7rem);padding:2rem;transition:opacity .4s ease,transform .55s var(--ease)}
.preloader__mark{width:var(--pre-size);height:var(--pre-size);opacity:0;transform:scale(.82);animation:preIn calc(.85s / var(--pre-speed)) var(--ease) forwards,preBreathe calc(3.6s / var(--pre-speed)) ease-in-out calc(1.15s / var(--pre-speed)) infinite}
.preloader__sun{display:block;width:100%;height:100%;background:var(--pre-ink);-webkit-mask:url("assets/preloader-symbol.svg") center/contain no-repeat;mask:url("assets/preloader-symbol.svg") center/contain no-repeat;animation:preSpin calc(22s / var(--pre-speed)) linear .25s infinite}
.preloader__word{font-family:var(--ff-display);font-weight:300;font-size:clamp(1.5rem,4vw,2.15rem);letter-spacing:.02em;line-height:1;color:var(--pre-ink);opacity:0;clip-path:inset(0 100% 0 0);animation:preWord calc(.9s / var(--pre-speed)) var(--ease) calc(.55s / var(--pre-speed)) both}
.preloader__bar{position:relative;width:clamp(108px,16vw,168px);height:1px;margin-top:.3rem;background:rgba(255,255,245,.15);overflow:hidden}
.preloader__bar i{position:absolute;inset:0 auto 0 0;width:38%;background:linear-gradient(90deg,transparent,var(--pre-accent),transparent);animation:preBar calc(1.6s / var(--pre-speed)) cubic-bezier(.65,0,.35,1) calc(.8s / var(--pre-speed)) infinite}
.preloader.is-done{transform:translateY(-101%)}
.preloader.is-done .preloader__inner{opacity:0;transform:translateY(-12px) scale(1.04)}
@keyframes preIn{to{opacity:1;transform:scale(1)}}
@keyframes preSpin{to{transform:rotate(360deg)}}
@keyframes preBreathe{0%,100%{transform:scale(1)}50%{transform:scale(1.028)}}
@keyframes preWord{0%{opacity:0;clip-path:inset(0 100% 0 0);transform:translateY(7px)}100%{opacity:1;clip-path:inset(0 0 0 0);transform:translateY(0)}}
@keyframes preBar{0%{transform:translateX(-130%)}100%{transform:translateX(360%)}}
@media (prefers-reduced-motion:reduce){
  .preloader__mark,.preloader__sun,.preloader__word,.preloader__bar i{animation:none!important}
  .preloader__mark{opacity:1;transform:none}
  .preloader__word{opacity:1;clip-path:none;transform:none}
  .preloader__bar{display:none}
  .preloader,.preloader__inner{transition:opacity .35s ease}
  .preloader.is-done{transform:none;opacity:0}
  .preloader.is-done .preloader__inner{transform:none}
}

/* ---------------- Typo helpers ---------------- */
.eyebrow{display:flex;align-items:center;gap:.7rem;font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--taupe);font-weight:500;margin:0 0 1.4rem}
.eyebrow--light{color:var(--sage)}
.eyebrow__mark{width:20px;height:20px;color:var(--sage);flex:0 0 auto}
.eyebrow__mark svg{width:100%;height:100%}

.display{font-family:var(--ff-display);font-weight:300;color:var(--green);line-height:1.02;letter-spacing:-.01em;font-size:clamp(2.3rem,5.2vw,4.4rem)}

/* ---------------- Buttons ---------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;font-family:var(--ff-sans);font-size:.86rem;font-weight:500;letter-spacing:.02em;padding:1.05rem 2rem;border-radius:999px;line-height:1;transition:transform .25s var(--ease),background .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease)}
.btn:active{transform:translateY(1px) scale(.99)}
.btn--solid{background:var(--green);color:var(--ivory)}
.btn--solid:hover{background:var(--green-deep)}
.btn--ivory{background:var(--ivory);color:var(--green)}
.btn--ivory:hover{background:#fff}
.btn--line{background:transparent;color:var(--green);border:1px solid rgba(28,66,32,.35)}
.btn--line:hover{background:rgba(28,66,32,.06);border-color:var(--green)}
.btn--ghost-light{background:transparent;color:var(--ivory);border:1px solid rgba(255,255,245,.5)}
.btn--ghost-light:hover{background:rgba(255,255,245,.12)}
.btn--glass{background:rgba(255,255,245,.14);-webkit-backdrop-filter:blur(12px) saturate(150%);backdrop-filter:blur(12px) saturate(150%);border:1px solid rgba(255,255,245,.45);color:var(--ivory)}
.btn--glass:hover{background:rgba(255,255,245,.3);border-color:var(--ivory)}
.btn--block{width:100%}

/* ---------------- Header (minimal bar) ---------------- */
.bar{position:fixed;top:0;left:0;right:0;z-index:100;transition:transform .45s var(--ease),background .4s var(--ease),box-shadow .4s var(--ease)}
.bar__inner{display:flex;align-items:center;justify-content:space-between;height:88px;gap:1.5rem}
.bar[data-state="scrolled"]{background:rgba(255,255,245,.9);backdrop-filter:saturate(140%) blur(14px);-webkit-backdrop-filter:saturate(140%) blur(14px);box-shadow:0 10px 30px -24px rgba(28,66,32,.32)}
.bar[data-state="scrolled"] .bar__inner{height:72px}
.bar.is-hidden{transform:translateY(-100%)}
.bar__logo img{height:44px;width:auto;transition:height .35s var(--ease)}
.bar[data-state="scrolled"] .bar__logo img{height:38px}
.bar[data-state="hero"] .bar__logo img{filter:brightness(0) invert(1)}
.bar[data-state="hero"]{background:transparent}
.bar__right{display:flex;align-items:center;gap:1.2rem}
.bar__phone{font-size:.86rem;color:var(--ink);transition:color .25s}
.bar[data-state="hero"] .bar__phone{color:var(--ivory)}
.bar__phone:hover{color:var(--green)}
.bar__cta{padding:.72rem 1.4rem;font-size:.8rem;background:var(--green);color:var(--ivory);border:1px solid var(--green);transition:background .3s var(--ease),border-color .3s var(--ease),color .3s var(--ease)}
.bar__cta:hover{background:var(--green-deep);border-color:var(--green-deep)}
.bar[data-state="hero"] .bar__cta{background:rgba(255,255,245,.14);-webkit-backdrop-filter:blur(12px) saturate(150%);backdrop-filter:blur(12px) saturate(150%);border:1px solid rgba(255,255,245,.45);color:var(--ivory)}
.bar[data-state="hero"] .bar__cta:hover{background:rgba(255,255,245,.28);border-color:var(--ivory)}
.menu-toggle{display:inline-flex;align-items:center;gap:.6rem;color:var(--ink);transition:opacity .25s var(--ease)}
.menu-toggle:hover{opacity:.78}
.bar[data-state="hero"] .menu-toggle{color:var(--ivory)}
.menu-toggle__lines{display:flex;flex-direction:column;gap:5px;width:24px;flex:0 0 auto}
.menu-toggle__lines i{display:block;height:1.5px;width:100%;background:currentColor;transition:width .3s var(--ease),transform .3s var(--ease)}
.menu-toggle:hover .menu-toggle__lines i:nth-child(2){width:64%}
.menu-toggle em{font-style:normal;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase}

/* ---------------- Fullscreen menu overlay ---------------- */
.menu{position:fixed;inset:0;z-index:300;visibility:hidden;pointer-events:none}
.menu.is-open{visibility:visible;pointer-events:auto}
.menu__bg{position:absolute;inset:0;background:var(--green);opacity:0;transition:opacity .5s var(--ease)}
.menu.is-open .menu__bg{opacity:1}
.menu__inner{position:absolute;inset:0;display:flex;flex-direction:column;color:var(--ivory);opacity:0;transform:translateY(20px);transition:opacity .5s var(--ease) .08s,transform .6s var(--ease) .08s;overflow-y:auto}
.menu.is-open .menu__inner{opacity:1;transform:none}
.menu__head{display:flex;align-items:center;justify-content:space-between;height:88px;flex:0 0 auto}
.menu__eyebrow{font-family:var(--ff-display);font-style:italic;font-size:1.15rem;color:var(--sage)}
.menu__close{color:var(--ivory);font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;display:flex;gap:.5rem;align-items:center}
.menu__body{flex:1;display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center;padding-block:2rem}
.menu__nav{display:flex;flex-direction:column}
.menu__nav a{font-family:var(--ff-display);font-weight:300;font-size:clamp(2rem,4.4vw,3.5rem);color:var(--ivory);line-height:1.25;padding:.25rem 0;display:flex;align-items:baseline;gap:1rem;transition:color .3s var(--ease),padding-left .3s var(--ease);border-bottom:1px solid rgba(255,255,245,.1)}
.menu__nav a:hover{color:var(--sage);padding-left:1rem}
.menu__no{font-family:var(--ff-sans);font-size:.7rem;letter-spacing:.2em;color:var(--sage);opacity:.7}
.menu__aside{display:flex;flex-direction:column;gap:1.6rem}
.menu__card{background:rgba(255,255,245,.06);border:1px solid rgba(255,255,245,.14);border-radius:var(--radius-lg);overflow:hidden}
.menu__card img{width:100%;height:200px;object-fit:cover}
.menu__card-body{padding:1.4rem}
.menu__card-body p{font-family:var(--ff-serif);color:rgba(255,255,245,.85);margin-bottom:1.1rem;font-size:1rem}
.menu__contact{display:flex;flex-direction:column;gap:1.4rem}
.menu__group{display:flex;flex-direction:column;gap:.45rem}
.menu__group:not(:last-child){border-bottom:1px solid rgba(255,255,245,.12);padding-bottom:1.4rem}
.menu__label{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--sage);font-weight:500;margin:0}
.menu__phone{font-family:var(--ff-display);font-size:1.6rem;color:var(--ivory);transition:color .25s var(--ease)}
.menu__phone:hover{color:var(--sage)}
.menu__addr{margin:0;font-size:1rem;line-height:1.45;color:rgba(255,255,245,.82)}
.menu__links{display:flex;flex-direction:column;gap:.5rem}
.menu__links a{font-size:1rem;color:rgba(255,255,245,.8);transition:color .25s var(--ease)}
.menu__links a:hover{color:#F6F1E8}

/* ---------------- Sections ---------------- */
.section{padding:clamp(4.5rem,9vw,9rem) 0}
.section--soft{background:var(--ivory-2)}
.section__cta{margin-top:clamp(2.6rem,5vw,4rem);display:flex;justify-content:center}

.split-head{margin-bottom:clamp(2.6rem,5vw,4.5rem)}
.split-head--center{text-align:center}
.split-head--center .eyebrow{justify-content:center}
.split-head__row{display:flex;flex-direction:column;gap:.1rem}
.display--left{align-self:flex-start}
.display--right{align-self:flex-end;text-align:right;display:flex;align-items:center;gap:1rem}
.display__mark{width:.7em;height:.7em;color:var(--sage)}
.display__mark svg{width:100%;height:100%}
.split-head__lead{font-family:var(--ff-serif);color:var(--muted);font-size:clamp(1.02rem,1.4vw,1.2rem);max-width:58ch;margin-top:1.6rem;line-height:1.6}

/* ---------------- HERO (cinematic) ---------------- */
.hero{position:relative;min-height:100dvh;display:flex;align-items:flex-end;overflow:hidden;color:var(--ivory)}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,30,20,.55) 0%,rgba(20,30,20,.2) 35%,rgba(20,47,23,.78) 100%),linear-gradient(90deg,rgba(20,47,23,.55),transparent 60%)}
.hero__inner{position:relative;z-index:2;padding-bottom:clamp(6rem,24vh,20rem);padding-top:clamp(5.5rem,11vh,7rem);width:100%}
.hero__eyebrow{color:var(--sage)}
.hero__title{font-family:var(--ff-display);font-weight:300;font-size:clamp(2.4rem,5.4vw,4.9rem);line-height:1.08;letter-spacing:-.015em;margin-bottom:1.1rem}
.hero__subtitle{font-family:var(--ff-serif);font-size:clamp(1.05rem,1.5vw,1.3rem);line-height:1.6;color:rgba(255,255,245,.88);max-width:60ch;margin-bottom:1.7rem}
.hero__cta{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:0}
.hero__trust{display:flex;flex-wrap:wrap;gap:.7rem 2rem;max-width:760px}
.hero__trust li{font-size:.88rem;color:rgba(255,255,245,.9);padding-left:1.3rem;position:relative}
.hero__trust li::before{content:"";position:absolute;left:0;top:.5em;width:7px;height:7px;border-radius:50%;background:var(--sage)}
/* hero reel (auto-scrolling realizations) */
.hero__reel{position:absolute;right:clamp(1.25rem,6vw,90px);bottom:6vh;z-index:3;width:clamp(240px,29vw,400px);padding:5px;border:1px solid rgba(255,255,245,.55);border-radius:14px;background:rgba(255,255,245,.08);-webkit-backdrop-filter:blur(10px) saturate(140%);backdrop-filter:blur(10px) saturate(140%);box-shadow:0 24px 50px -28px rgba(0,0,0,.5);transition:transform .4s var(--ease),border-color .3s var(--ease)}
.hero__reel:hover{transform:translateY(-3px);border-color:rgba(255,255,245,.8)}
.hero__reel-viewport{overflow:hidden;border-radius:10px;-webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent)}
.hero__reel-track{display:flex;gap:5px;width:max-content;animation:reel 28s linear infinite}
.hero__reel-track img{flex:0 0 auto;width:clamp(94px,7.6vw,116px);height:clamp(122px,10vw,150px);object-fit:cover;border-radius:8px}
.hero__reel:hover .hero__reel-track{animation-play-state:paused}
@keyframes reel{to{transform:translateX(calc(-50% - 2.5px))}}
.hero__reel-label{position:absolute;top:-.95rem;left:14px;font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ivory);background:var(--green);padding:.25rem .6rem;border-radius:999px}
@media (prefers-reduced-motion:reduce){.hero__reel-track{animation:none}}

/* ---------------- Two-column section header (Madera "about") ---------------- */
.head2{display:grid;grid-template-columns:1fr .96fr;gap:clamp(1.6rem,3vw,3rem);align-items:start;margin-bottom:clamp(2.6rem,5vw,4.5rem)}
.head2__title{font-family:var(--ff-display);font-weight:300;color:var(--green);font-size:clamp(2.3rem,5vw,4.3rem);line-height:1.04;letter-spacing:-.012em}
.head2__title--tight{font-size:clamp(2rem,3.3vw,3.05rem);line-height:1.08;white-space:nowrap}
.head2__aside{justify-self:end;max-width:54ch;padding-top:.7rem;display:flex;flex-direction:column;gap:1.4rem}
.head2__lead{font-family:var(--ff-serif);color:var(--muted);font-size:clamp(.95rem,1.15vw,1.05rem);line-height:1.6}
.head2__cta{align-self:flex-start;margin-top:clamp(.4rem,.8vw,.7rem)}
.head2__cta{align-self:start;margin-top:.4rem}
.drag-hint{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--taupe);display:inline-flex;align-items:center;gap:.5rem}
.drag-hint em{font-style:normal;font-size:1rem}

.section__cta--right{justify-content:flex-end}

/* ---------------- Services list (Madera, faithful) ---------------- */
.svc{border-top:1px solid var(--line)}
.svc__row{position:relative;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:clamp(1.2rem,2.5vw,2.2rem);padding:clamp(2rem,3.1vw,2.9rem) .2rem;border-bottom:1px solid var(--line);transition:padding-left .4s var(--ease)}
.svc__row:hover{padding-left:1rem}
.svc__tag{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--ff-sans);font-size:.78rem;letter-spacing:.02em;color:var(--ivory);background:var(--green);border:1px solid var(--green);transition:background .4s var(--ease),color .4s var(--ease),border-color .4s var(--ease)}
.section--soft .svc__tag{background:var(--green)}
.svc__row:hover .svc__tag{background:var(--sage);border-color:var(--sage);color:var(--green-deep)}
.svc__body{display:flex;flex-direction:column;gap:.55rem;min-width:0}
.svc__title{font-family:var(--ff-display);font-weight:300;font-size:clamp(1.6rem,3vw,2.6rem);color:var(--green);line-height:1.05}
.svc__desc{font-size:.96rem;color:var(--muted);max-width:52ch;line-height:1.5}
.svc__media{position:absolute;top:50%;right:clamp(4rem,7vw,6.5rem);width:clamp(290px,26vw,400px);aspect-ratio:4/3;border-radius:.7rem;overflow:hidden;transform:translateY(-50%) scale(.6);opacity:0;pointer-events:none;box-shadow:var(--shadow);transition:opacity .5s var(--ease),transform .6s var(--ease);z-index:4}
.svc__media img{width:100%;height:100%;object-fit:cover}
.svc__row:hover .svc__media{opacity:1;transform:translateY(-50%) scale(1)}
.svc__arrow{justify-self:end;font-size:1.5rem;color:var(--green);transition:transform .35s var(--ease)}
.svc__row:hover .svc__arrow{transform:translate(5px,-5px)}
.svc__row--feature .svc__title{font-size:clamp(1.8rem,3.4vw,2.9rem)}

/* ---------------- Works reel (premium horizontal scroll) ---------------- */
.wreel-wrap{position:relative}
.wreel{overflow-x:auto;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;scrollbar-width:none;cursor:grab;padding-block:.5rem;touch-action:pan-x;user-select:none;-webkit-user-select:none}
.wreel::-webkit-scrollbar{display:none}
.wreel.is-grabbing{cursor:grabbing}
.wreel img{-webkit-user-drag:none;user-select:none;-webkit-user-select:none}
.wreel__track{display:flex;gap:clamp(1rem,1.8vw,1.6rem);width:max-content;padding-inline:var(--gutter)}
.wcard{flex:0 0 auto;width:clamp(280px,29vw,420px);margin:0;scroll-snap-align:start}
.wcard__media{position:relative;aspect-ratio:4/5;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-soft)}
.wcard__media img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease);filter:saturate(.97) contrast(1.02)}
.wcard:hover .wcard__media img{transform:scale(1.06)}
.wcard__num{position:absolute;top:1rem;left:1rem;z-index:2;color:var(--ivory);font-size:.72rem;letter-spacing:.14em;background:rgba(20,30,20,.45);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,245,.25);padding:.32rem .7rem;border-radius:999px}
.wcard figcaption{padding:1.1rem .2rem 0}
.wcard__tag{display:block;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--taupe);margin-bottom:.35rem}
.wcard__title{font-family:var(--ff-display);font-weight:300;font-size:clamp(1.4rem,2.2vw,1.95rem);color:var(--green);line-height:1.1}

/* ---------------- Horizontal scroll strip ---------------- */
.hscroll{margin:clamp(2.5rem,5vw,4.5rem) 0;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;cursor:grab}
.hscroll::-webkit-scrollbar{display:none}
.hscroll.is-grabbing{cursor:grabbing}
.hscroll__track{display:flex;gap:clamp(.9rem,1.5vw,1.4rem);padding-inline:var(--gutter);width:max-content}
.hscroll__item{margin:0;flex:0 0 auto;width:clamp(280px,40vw,520px);scroll-snap-align:center;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-soft)}
.hscroll__item img{width:100%;height:clamp(320px,46vh,560px);object-fit:cover}

/* ---------------- Works (editorial rows) ---------------- */
.works{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.2rem,3vw,2.4rem)}
.work{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-soft);background:#000}
.work__media{aspect-ratio:4/3;overflow:hidden}
.work:nth-child(odd){margin-top:0}
.work:nth-child(even){margin-top:clamp(0px,5vw,5rem)}
.work__media img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease);filter:saturate(.97) contrast(1.02)}
.work:hover .work__media img{transform:scale(1.05)}
.work__info{position:absolute;left:0;right:0;bottom:0;padding:1.6rem 1.8rem;color:var(--ivory);background:linear-gradient(to top,rgba(20,30,20,.82),transparent)}
.work__tag{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--sage)}
.work__title{font-family:var(--ff-display);font-weight:300;font-size:clamp(1.5rem,2.6vw,2.1rem);margin-top:.4rem}

/* ---------------- Cinematic band ---------------- */
.band{position:relative;background:var(--green);color:var(--ivory);overflow:hidden;padding:clamp(4.5rem,9vw,8rem) 0;text-align:center}
.band__inner{max-width:1240px;margin-inline:auto;position:relative;z-index:2}
.band__title{font-family:var(--ff-display);font-weight:300;font-size:clamp(2.1rem,4.4vw,3.45rem);line-height:1.05;letter-spacing:-.01em;max-width:1100px;margin:0 auto 1.3rem;text-wrap:balance}
@media(min-width:1280px){.band__title{white-space:nowrap;max-width:none;text-wrap:nowrap}}
.band__lead{font-family:var(--ff-serif);font-size:clamp(1.04rem,1.45vw,1.2rem);color:rgba(255,255,245,.76);max-width:880px;margin:0 auto 1rem;line-height:1.55}
.band__lead br{display:none}
@media(min-width:721px){.band__lead br{display:inline}}
.band__note{font-size:.86rem;color:var(--sage);margin-bottom:2rem;letter-spacing:.02em}
.band__symbol{position:absolute;width:clamp(220px,24vw,360px);height:auto;opacity:.06;pointer-events:none;z-index:1}
.band__symbol--tl{top:-70px;left:-70px}
.band__symbol--br{bottom:-90px;right:-70px}
.band__symbol--c{top:-80px;right:-80px;width:clamp(240px,26vw,400px)}
.band__mark{position:absolute;color:var(--ivory);opacity:.07;pointer-events:none}
.band__mark svg{width:100%;height:100%}
.band__mark--a{width:360px;height:360px;left:-130px;top:-130px}
.band__mark--b{width:300px;height:300px;right:-100px;bottom:-120px}
.band__mark--c{width:420px;height:420px;right:-150px;top:-150px}

/* ---------------- Metrics bento (Decorist) ---------------- */
.metrics-label{display:flex;justify-content:space-between;align-items:center;font-family:var(--ff-sans);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--taupe);margin-bottom:clamp(2.4rem,5vw,4rem)}
.metrics-title{text-align:center;font-family:var(--ff-display);font-style:italic;font-weight:300;color:var(--green);font-size:clamp(2.4rem,6vw,4.6rem);line-height:1.02;margin-bottom:clamp(2.6rem,5vw,4.2rem)}
/* Metrics bento — Decorist-exact: 3 flex rows, horizontal lines + inner vertical dividers, NO outer side borders */
.metrics{display:flex;flex-direction:column}
.kmrow{display:flex;align-items:center}
.kmrow--top{border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.kmrow--center{border-bottom:1px solid var(--line)}
.kmrow--bottom{border-bottom:1px solid var(--line);justify-content:space-between}
.kmstat{display:flex;align-items:center;gap:24px}
.kmstat--bd{width:520px;padding:24px 40px 24px 80px;border-right:1px solid var(--line)}
.kmstat--bl{width:90%;padding:24px 40px 24px 80px;border-left:1px solid var(--line)}
.kmstat__v{font-family:var(--ff-sans);font-weight:400;font-size:clamp(2.8rem,4.4vw,4rem);color:var(--green);line-height:1.2;letter-spacing:-.01em;white-space:nowrap}
.kmstat__l{font-family:var(--ff-sans);font-size:clamp(.95rem,1.05vw,1.05rem);color:var(--muted);line-height:1.35;width:50%;max-width:160px;margin:0}
.kmicon{flex:1;padding-left:200px}
.kmicon__sun{display:inline-flex;width:70px;height:70px;color:var(--sage)}
.kmicon__sun svg{width:100%;height:100%}
.kmimg{width:80%;height:120px;padding-left:200px;display:flex;align-items:center}
.kmpic{width:240px;height:120px;overflow:hidden}
.kmpic--wide{width:317px}
.kmpic img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .9s var(--ease)}
.kmpic:hover img{transform:scale(1.04)}
.kmlet{display:flex;align-items:center;justify-content:space-between;width:65%;max-width:700px;padding:18px 80px;border-right:1px solid var(--line)}
.kmstat--inline{flex:1}
.kmstat--textonly{gap:0}
.kmstat__l--lg{font-size:clamp(1.05rem,1.25vw,1.25rem);color:var(--green);max-width:none}
.kmimg-right{display:flex;align-items:center;justify-content:flex-end;width:30%;height:120px;padding-right:40px}
.kmimg-right .kmpic{width:317px}

/* ---------------- Numbers ---------------- */
.numbers{display:grid;grid-template-columns:repeat(5,1fr)}
.numbers__item{padding:clamp(1.4rem,3vw,2.4rem) 1.4rem;border-left:1px solid var(--line);text-align:left}
.numbers__item:first-child{border-left:none;padding-left:0}
.numbers__v{display:block;font-family:var(--ff-display);font-weight:300;color:var(--green);font-size:clamp(2.6rem,5vw,4rem);line-height:1;letter-spacing:-.01em}
.numbers__l{display:block;margin-top:.8rem;font-size:.85rem;color:var(--muted);line-height:1.4}

/* ---------------- Architects (cinematic split) ---------------- */
.archi{position:relative;display:grid;grid-template-columns:1fr 1.05fr;background:var(--green);color:var(--ivory);overflow:hidden}
.archi__symbol{position:absolute;right:-50px;top:-50px;width:clamp(170px,16vw,250px);height:auto;opacity:.05;pointer-events:none;z-index:1}
.archi__media{position:relative;min-height:460px}
.archi__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.archi__media::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 55%,rgba(20,47,23,.55))}
.archi__content{position:relative;z-index:2;padding:clamp(3rem,6vw,6rem) clamp(1.5rem,5vw,5.5rem)}
.archi__title{font-family:var(--ff-display);font-weight:300;font-size:clamp(1.95rem,3.4vw,2.8rem);line-height:1.16;margin-bottom:1.3rem;max-width:none;text-wrap:nowrap}
.archi__lead{font-family:var(--ff-serif);color:rgba(255,255,245,.85);font-size:1.1rem;line-height:1.6;margin-bottom:2rem;max-width:52ch}
.archi__list{display:flex;flex-direction:column;margin-bottom:2.4rem;border-top:1px solid rgba(255,255,245,.18)}
.archi__list li{display:flex;align-items:baseline;gap:1.1rem;padding:.95rem 0;border-bottom:1px solid rgba(255,255,245,.18);color:rgba(255,255,245,.92);font-size:1.02rem}
.archi__n{font-family:var(--ff-sans);font-size:.72rem;letter-spacing:.12em;color:var(--sage);flex:0 0 auto;min-width:1.7rem}

/* ---------------- Advantages ---------------- */
.adv{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1rem,1.5vw,1.4rem)}
.adv__item{position:relative;overflow:hidden;background:var(--ivory-2);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.7rem,2.2vw,2.3rem);min-height:clamp(220px,18vw,280px);display:flex;flex-direction:column;justify-content:flex-end;transition:transform .45s var(--ease),box-shadow .45s var(--ease),background .45s var(--ease)}
.adv__item::before{content:"";position:absolute;left:0;right:0;top:0;height:2px;background:var(--sage);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.adv__item:hover{transform:translateY(-6px);box-shadow:var(--shadow);background:#fff}
.adv__item:hover::before{transform:scaleX(1)}
.adv__no{position:absolute;top:.2rem;right:1rem;font-family:var(--ff-display);font-weight:300;font-size:clamp(4.2rem,6vw,6.5rem);line-height:1;color:var(--green);opacity:.07;pointer-events:none;transition:opacity .45s var(--ease)}
.adv__item:hover .adv__no{opacity:.13}
.adv__body{position:relative;min-width:0}
.adv__item h3{font-family:var(--ff-display);font-weight:400;font-size:clamp(1.32rem,1.55vw,1.6rem);color:var(--green);line-height:1.16;margin-bottom:.6rem}
.adv__item p{font-size:.93rem;color:var(--muted);line-height:1.55}

/* ---------------- Producers (editorial header + marquee) ---------------- */
.brands{position:relative;margin-top:clamp(3.6rem,6vw,6rem)}
.brands__symbol{position:absolute;right:0;top:38%;transform:translateY(-50%);width:clamp(160px,14vw,230px);height:auto;opacity:.05;pointer-events:none;z-index:0}
.brands__head{position:relative;z-index:1;margin-bottom:clamp(1.8rem,3vw,2.6rem)}
.brands__title{font-family:var(--ff-display);font-weight:300;color:var(--green);font-size:clamp(1.9rem,3.2vw,2.8rem);line-height:1.05;letter-spacing:-.012em;white-space:nowrap;margin-bottom:.9rem}
.brands__intro{font-family:var(--ff-serif);color:var(--muted);font-size:clamp(.98rem,1.1vw,1.08rem);line-height:1.55;max-width:78ch;margin:0}
.brands__marquee{position:relative;z-index:1;overflow:hidden;padding-block:clamp(14px,1.8vw,22px);-webkit-mask-image:linear-gradient(90deg,transparent,#000 3%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 3%,#000 92%,transparent)}
.brands__track{display:flex;gap:1rem;width:max-content;animation:bmarquee 50s linear infinite}
@keyframes bmarquee{to{transform:translateX(calc(-50% - .5rem))}}
.brands__marquee:hover .brands__track{animation-play-state:paused}
.bcard{flex:0 0 auto;display:inline-flex;align-items:center;white-space:nowrap;padding:.95rem 1.7rem;border-radius:999px;border:1px solid rgba(140,125,91,.25);background:#FBF8F1;font-family:var(--ff-display);font-weight:400;font-size:clamp(1.2rem,1.6vw,1.5rem);color:var(--green);transition:background .4s var(--ease),color .4s var(--ease),border-color .4s var(--ease),transform .4s var(--ease),box-shadow .4s var(--ease)}
.bcard:hover{background:var(--green);color:var(--ivory);border-color:var(--green);transform:translateY(-3px);box-shadow:0 16px 34px -18px rgba(20,47,23,.45)}
@media(prefers-reduced-motion:reduce){.brands__track{animation:none;width:auto;flex-wrap:wrap}.bcard[aria-hidden]{display:none}}

/* ---------------- Testimonials (Madera) ---------------- */
.testi{display:grid;grid-template-columns:44% 56%;gap:clamp(1.6rem,3vw,3rem);align-items:center}
.testi__left{max-width:600px}
.testi__heading{font-size:clamp(1.8rem,2.6vw,2.65rem);white-space:nowrap;margin-bottom:1rem}
.testi__text{font-family:var(--ff-serif);color:var(--muted);max-width:48ch;line-height:1.6;margin-bottom:2rem}
.testi__controls{display:flex;align-items:center;gap:.8rem}
.testi__arrow{width:54px;height:54px;border:1px solid var(--line);border-radius:50%;color:var(--green);font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:all .3s var(--ease)}
.testi__arrow:hover{background:var(--green);color:var(--ivory);border-color:var(--green)}
.testi__count{margin-left:.6rem;font-family:var(--ff-sans);font-size:.85rem;letter-spacing:.12em;color:var(--taupe)}
.testi__count b{color:var(--green);font-weight:600}
.testi__viewport{overflow:hidden}
.testi__track{display:flex;gap:20px;transition:transform .6s cubic-bezier(.22,1,.36,1);will-change:transform}
.tcard{flex:0 0 65%;max-width:500px;display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.4rem,2vw,1.9rem);box-shadow:0 8px 20px rgba(20,40,25,.045)}
.tcard__rating{display:flex;gap:.4rem;margin-bottom:1rem}
.tcard__star{width:17px;height:17px;color:var(--taupe)}
.tcard__star svg{width:100%;height:100%}
.tcard p{font-family:var(--ff-serif);font-size:clamp(1rem,1.2vw,1.12rem);line-height:1.55;color:var(--ink);margin-bottom:1.4rem}
.tcard footer{display:flex;align-items:center;gap:.9rem;margin-top:auto}
.tcard__badge{display:flex;align-items:center;justify-content:center;width:44px;height:44px;flex:0 0 auto;border-radius:50%;background:var(--green);color:var(--ivory);font-family:var(--ff-display);font-size:1.2rem;font-weight:500}
.tcard__who{display:flex;flex-direction:column;gap:.15rem}
.tcard__who strong{font-family:var(--ff-display);font-weight:500;font-size:1.12rem;color:var(--green)}
.tcard__who>span{font-size:.78rem;letter-spacing:.04em;color:var(--taupe);text-transform:uppercase}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ---------------- FAQ ---------------- */
.faq{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(2rem,5vw,5rem);align-items:start}
.faq__intro{position:sticky;top:110px}
.faq__title{font-size:clamp(2rem,3.6vw,3rem);margin-bottom:1.1rem}
.faq__sub{font-family:var(--ff-serif);color:var(--muted);font-size:clamp(1.02rem,1.3vw,1.18rem);line-height:1.6;max-width:38ch;margin-bottom:2rem}
.faq__list{margin-bottom:2rem;border-top:1px solid var(--line)}
.faq__item{border-bottom:1px solid var(--line)}
.faq__q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;text-align:left;padding:1.35rem 0;color:var(--green);font-family:var(--ff-display);font-weight:400;font-size:clamp(1.15rem,1.9vw,1.5rem);line-height:1.2}
.faq__icon{position:relative;width:16px;height:16px;flex:0 0 auto}
.faq__icon::before,.faq__icon::after{content:"";position:absolute;background:var(--taupe);transition:transform .3s var(--ease)}
.faq__icon::before{left:0;top:50%;width:100%;height:1.5px;transform:translateY(-50%)}
.faq__icon::after{top:0;left:50%;width:1.5px;height:100%;transform:translateX(-50%)}
.faq__item.is-open .faq__icon::after{transform:translateX(-50%) scaleY(0)}
.faq__a{overflow:hidden;max-height:0;transition:max-height .4s var(--ease)}
.faq__a p{padding:0 0 1.35rem;color:var(--muted);font-size:1rem;line-height:1.65;max-width:64ch}

/* ---------------- Showroom ---------------- */
.showroom{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2rem,4vw,4rem);align-items:center}
.showroom__title{font-size:clamp(2rem,4vw,3rem);margin-bottom:1.2rem}
.showroom__text{font-family:var(--ff-serif);color:var(--muted);line-height:1.65;margin-bottom:1.8rem;max-width:54ch}
.showroom__info{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem 2rem;margin-bottom:2.2rem;list-style:none}
.showroom__info li{display:flex;align-items:center;gap:.95rem}
.showroom__ico{flex:0 0 auto;width:44px;height:44px;border-radius:50%;border:1px solid rgba(20,65,34,.12);display:flex;align-items:center;justify-content:center;color:var(--green);background:#F3EEE3;transition:background .35s var(--ease),color .35s var(--ease),border-color .35s var(--ease)}
.showroom__info li:hover .showroom__ico{background:var(--green);color:var(--ivory);border-color:var(--green)}
.showroom__ico svg{width:21px;height:21px}
.showroom__pair{display:flex;flex-direction:column;gap:.2rem;min-width:0}
.showroom__k{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--taupe)}
.showroom__v{font-size:1rem;color:var(--ink);transition:color .3s var(--ease)}
a.showroom__v:hover{color:var(--green)}
.showroom__cta{display:flex;flex-wrap:wrap;gap:1rem}
.showroom__map{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);min-height:420px}
.showroom__map iframe{width:100%;height:100%;min-height:460px;border:0;display:block;filter:saturate(.85)}

/* ---------------- Contact ---------------- */
.band--contact{text-align:left}
.contact{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2.5rem,5vw,5rem);align-items:center;position:relative;z-index:2}
.contact__title{font-family:var(--ff-display);font-weight:300;font-size:clamp(2.2rem,4.6vw,3.6rem);line-height:1.04;margin-bottom:1.1rem}
.contact__lead{font-family:var(--ff-serif);color:rgba(255,255,245,.85);font-size:1.12rem;line-height:1.6;margin-bottom:1.4rem;max-width:46ch}
.contact__channels{list-style:none;display:flex;flex-direction:column;gap:1.1rem;margin-top:1.8rem}
.contact__channels li{display:flex;align-items:center;gap:.9rem}
.contact__ico{flex:0 0 auto;width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,245,.3);display:flex;align-items:center;justify-content:center;color:var(--sage);transition:background .35s var(--ease),color .35s var(--ease),border-color .35s var(--ease)}
.contact__ico svg{width:21px;height:21px}
.contact__channels li:hover .contact__ico{background:rgba(246,241,232,.14);color:#F6F1E8;border-color:rgba(246,241,232,.55)}
.contact__pair{display:flex;flex-direction:column;gap:.15rem;min-width:0}
.contact__k{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sage)}
.contact__v{font-size:1.05rem;color:var(--ivory);transition:color .3s var(--ease)}
a.contact__v:hover{color:var(--sage)}

/* ---------------- Forms ---------------- */
.form{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem 1.2rem}
.contact__form{background:var(--ivory);color:var(--ink);border-radius:var(--radius-lg);padding:clamp(1.8rem,3vw,2.6rem);box-shadow:var(--shadow)}
.popup .form,.modal .form{grid-template-columns:1fr}
.field{display:flex;flex-direction:column;gap:.45rem;min-width:0}
.field--full{grid-column:1 / -1}
.field label{font-size:.78rem;letter-spacing:.06em;color:var(--taupe);text-transform:uppercase;font-weight:500}
.field input,.field select,.field textarea{font-family:var(--ff-sans);font-size:.95rem;color:var(--ink);background:var(--ivory-2);border:1px solid var(--line);border-radius:8px;padding:.6rem .85rem;width:100%;transition:border-color .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease)}
.field input:hover,.field select:hover,.field textarea:hover{background-color:#fbf9f2}
.field select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:46px;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none' stroke='%231C4220' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M1 1.5 6 6.5 11 1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 18px center;background-size:12px 8px}
.field textarea{resize:vertical;min-height:66px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(28,66,32,.12)}
.field.has-error input,.field.has-error select{border-color:#9a2f2f;box-shadow:0 0 0 3px rgba(154,47,47,.1)}
.field__error{font-size:.78rem;color:#9a2f2f;display:none}
.field.has-error .field__error{display:block}
.check{display:flex;align-items:flex-start;gap:.6rem;cursor:pointer;text-transform:none;letter-spacing:0}
.check input{appearance:none;-webkit-appearance:none;box-sizing:border-box;width:19px;height:19px;min-width:19px;padding:0;flex:0 0 auto;margin-top:.12rem;border-radius:50%;border:1.5px solid rgba(20,65,34,.3);background:var(--ivory-2);cursor:pointer;display:grid;place-items:center;transition:background .25s var(--ease),border-color .25s var(--ease)}
.check input::after{content:"";width:7px;height:7px;border-radius:50%;background:var(--ivory);transform:scale(0);transition:transform .25s var(--ease)}
.check input:checked{background:var(--green);border-color:var(--green)}
.check input:checked::after{transform:scale(1)}
.check input:focus-visible{outline:2px solid var(--green);outline-offset:2px}
.check span{font-size:.74rem;color:var(--muted);line-height:1.4;font-weight:400;text-transform:none;letter-spacing:0}
.field--check{gap:.35rem}
.form__success{grid-column:1 / -1;background:rgba(161,178,150,.2);border:1px solid var(--sage);color:var(--green);border-radius:10px;padding:1rem 1.1rem;font-size:.95rem;font-family:var(--ff-serif)}

/* ---------------- Footer (big wordmark) ---------------- */
.footer{background:var(--green-deep);color:rgba(255,255,245,.78);padding:clamp(3.5rem,6vw,5.5rem) 0 2rem}
.footer__top{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.4rem 2rem}
.footer__logo{height:clamp(40px,4.6vw,58px);width:auto;opacity:.96}
.footer__social{display:flex;gap:1.6rem;font-size:.92rem}
.footer__social a{color:rgba(255,255,245,.78);transition:color .25s}
.footer__social a:hover{color:var(--ivory)}
.footer__divider{height:1px;background:rgba(255,255,245,.14);margin:clamp(2rem,4vw,3rem) 0}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1.1fr 1.4fr;gap:clamp(2rem,4vw,3.5rem)}
.footer__map h4{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--sage);margin-bottom:.9rem;font-weight:500}
.footer__map-frame{border-radius:24px;overflow:hidden;border:1px solid rgba(245,241,229,.12);height:clamp(200px,16vw,250px);max-width:460px}
.footer__map-frame iframe{width:100%;height:100%;border:0;display:block;filter:grayscale(.3) contrast(.92) brightness(.92);opacity:.9}
.footer__legal{display:flex;gap:1.4rem;flex-wrap:wrap}
.footer__legal a{color:rgba(255,255,245,.55);transition:color .25s}
.footer__legal a:hover{color:var(--ivory)}
.footer__desc{font-family:var(--ff-serif);font-size:1.05rem;line-height:1.6;max-width:34ch;color:rgba(255,255,245,.82)}
.footer__phrase{font-family:var(--ff-display);font-style:italic;font-size:1.25rem;color:var(--sage);margin:1rem 0 1.6rem}
.footer__col{display:flex;flex-direction:column;gap:.65rem}
.footer__col h4{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--sage);margin-bottom:.6rem;font-weight:500}
.footer__col a,.footer__col span{font-size:.92rem;color:rgba(255,255,245,.78);transition:color .25s}
.footer__col a:hover{color:var(--ivory)}
.footer__bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-top:clamp(2.5rem,5vw,4rem);padding-top:1.6rem;border-top:1px solid rgba(255,255,245,.14);font-size:.8rem;color:rgba(255,255,245,.55)}

/* ---------------- Sticky CTA + widget ---------------- */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:90;display:none;gap:.7rem;padding:.7rem clamp(.9rem,4vw,1.2rem) calc(.7rem + env(safe-area-inset-bottom));background:rgba(255,255,245,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--line);transform:translateY(120%);transition:transform .45s var(--ease)}
.sticky-cta.is-visible{transform:translateY(0)}
.sticky-cta__call{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;width:52px;height:52px;border-radius:14px;background:var(--green);color:var(--ivory)}
.sticky-cta__call svg{width:20px;height:20px;fill:currentColor}
.widget{position:fixed;right:24px;bottom:24px;z-index:90;display:flex;flex-direction:column;align-items:flex-end;gap:.6rem;opacity:0;transform:translateY(12px);pointer-events:none;transition:opacity .4s var(--ease),transform .4s var(--ease)}
.widget.is-visible{opacity:1;transform:none;pointer-events:auto}
.widget__toggle{display:inline-flex;align-items:center;gap:.6rem;background:var(--green);color:var(--ivory);padding:.85rem 1.3rem;border-radius:999px;box-shadow:var(--shadow);font-size:.86rem;font-weight:500;transition:background .3s var(--ease),transform .25s var(--ease)}
.widget__toggle:hover{background:var(--green-deep);transform:translateY(-1px)}
.widget__mark{width:22px;height:22px;color:var(--sage)}
.widget__mark svg{width:100%;height:100%}
.widget__menu{display:flex;flex-direction:column;gap:.5rem;background:var(--ivory);border:1px solid var(--line);border-radius:16px;padding:.6rem;box-shadow:var(--shadow);min-width:230px}
.widget__item{text-align:left;padding:.75rem .9rem;border-radius:10px;font-size:.9rem;color:var(--green);transition:background .25s}
.widget__item:hover{background:rgba(28,66,32,.07)}

/* ---------------- Modals ---------------- */
.modal{position:fixed;inset:0;z-index:400;visibility:hidden;pointer-events:none}
.modal.is-open{visibility:visible;pointer-events:auto}
.modal__scrim{position:absolute;inset:0;background:rgba(15,24,15,.55);opacity:0;transition:opacity .4s var(--ease);backdrop-filter:blur(2px)}
.modal.is-open .modal__scrim{opacity:1}
.modal__dialog{position:relative;z-index:2;background:var(--ivory);width:min(540px,calc(100vw - 2rem));max-height:90dvh;overflow:hidden;margin:1rem auto;top:50%;transform:translateY(-50%) scale(.96);opacity:0;border-radius:var(--radius-lg);box-shadow:var(--shadow);transition:transform .45s var(--ease),opacity .4s var(--ease);display:flex;flex-direction:column}
.modal.is-open .modal__dialog{transform:translateY(-50%) scale(1);opacity:1}
.modal__dialog--quiz{width:min(680px,calc(100vw - 2rem))}
.modal__body{flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden;padding:clamp(1.6rem,3.4vw,2.6rem);-webkit-overflow-scrolling:touch}
.modal__close{position:absolute;top:.85rem;right:1rem;font-size:1.8rem;line-height:1;color:var(--taupe);width:38px;height:38px;z-index:5;background:var(--ivory);border-radius:50%}
.modal__close:hover{color:var(--green)}
.modal__mark{position:absolute;right:-60px;bottom:-60px;width:190px;height:190px;color:var(--sage);opacity:.07;pointer-events:none;z-index:0}
.modal__mark svg{width:100%;height:100%}
.popup,.quiz,.quiz-success{position:relative;z-index:1}
.popup__title{font-family:var(--ff-display);font-weight:400;color:var(--green);font-size:clamp(1.55rem,2.6vw,2.05rem);line-height:1.12;margin-bottom:.6rem}
.popup__lead{font-family:var(--ff-serif);color:var(--muted);margin-bottom:1.3rem;font-size:.96rem;line-height:1.5}

/* ---------------- Quiz ---------------- */
.quiz__head{margin-bottom:1.1rem}
.quiz__title{font-family:var(--ff-display);font-weight:400;color:var(--green);font-size:clamp(1.4rem,2.4vw,1.95rem);line-height:1.12;margin-bottom:1rem}
.quiz__progress{display:flex;align-items:center;gap:1rem}
.quiz__progress-bar{flex:1;height:3px;background:var(--line);border-radius:3px;overflow:hidden}
.quiz__progress-bar span{display:block;height:100%;width:12.5%;background:var(--green);border-radius:3px;transition:width .45s var(--ease)}
.quiz__progress-label{font-size:.78rem;letter-spacing:.1em;color:var(--taupe);white-space:nowrap}
.quiz__step-q{font-family:var(--ff-display);font-size:clamp(1.25rem,2.1vw,1.6rem);color:var(--green);font-weight:400;line-height:1.18;margin-bottom:.35rem}
.quiz__step-hint{font-size:.84rem;color:var(--taupe);margin-bottom:1rem}
.quiz__options{display:grid;grid-template-columns:1fr 1fr;gap:.55rem}
.quiz__options--single{grid-template-columns:1fr}
.quiz__option{display:flex;align-items:center;gap:.65rem;text-align:left;border:1px solid var(--line);border-radius:11px;padding:.7rem .85rem;font-size:.9rem;color:var(--ink);transition:all .25s var(--ease);background:#fff}
.quiz__option:hover{border-color:rgba(28,66,32,.4);background:var(--ivory)}
.quiz__option.is-selected{border-color:var(--green);background:rgba(28,66,32,.07);color:var(--green)}
.quiz__option .tick{width:18px;height:18px;border:1px solid var(--line);border-radius:5px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;transition:all .2s var(--ease)}
.quiz__option.is-selected .tick{background:var(--green);border-color:var(--green)}
.quiz__option.is-selected .tick::after{content:"";width:9px;height:5px;border-left:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(-45deg) translateY(-1px)}
.quiz__nav{display:flex;justify-content:space-between;gap:1rem;margin-top:1.2rem}
.quiz__nav .btn{min-width:120px}
.quiz__error{color:#9a2f2f;font-size:.85rem;margin-top:.8rem;display:none}
.quiz__error.is-visible{display:block}
.quiz-success{text-align:center;padding:1.5rem 0}
.quiz-success__mark{display:inline-block;width:64px;height:64px;color:var(--sage);margin-bottom:1.2rem}
.quiz-success__mark svg{width:100%;height:100%}
.quiz-success h2{font-family:var(--ff-display);font-weight:400;color:var(--green);font-size:2.2rem;margin-bottom:.8rem}
.quiz-success p{font-family:var(--ff-serif);color:var(--muted);max-width:46ch;margin:0 auto .6rem;line-height:1.6}
.quiz-success__sub{font-size:.9rem;color:var(--taupe)}
.quiz-success .btn{margin-top:1.4rem}

/* ---------------- Reveal ---------------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.is-in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}
body.is-locked{overflow:hidden}

/* ===================== RESPONSIVE ===================== */
@media (max-width:1080px){
  :root{--gutter:48px}
  .svc__row{gap:1.2rem}
  .svc__media{display:none}
  .head2{grid-template-columns:1fr;gap:1.3rem}
  .head2__aside{justify-self:start;max-width:60ch;padding-top:0}
  .head2__cta{align-self:stretch;margin-top:.6rem}
  .head2__cta .btn{width:100%}
  .adv{grid-template-columns:repeat(2,1fr)}
  .brands__marquee{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-webkit-mask-image:none;mask-image:none}
  .brands__marquee::-webkit-scrollbar{display:none}
  .brands__track{animation:none}
  .bcard[aria-hidden]{display:none}
  .numbers{grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border-block:1px solid var(--line)}
  .numbers__item{background:var(--ivory);border-left:none;padding:1.6rem 1.2rem}
  .section--soft .numbers__item{background:var(--ivory-2)}
  .works,.testi,.faq,.showroom,.contact,.archi{grid-template-columns:1fr}
  .archi__media{min-height:320px}
  .archi__title{text-wrap:wrap}
  .work:nth-child(even){margin-top:0}
  .faq__intro{position:relative;top:auto}
  .menu__body{grid-template-columns:1fr;align-items:start;gap:2rem}
  .hero__reel{display:none}
  .hero__inner{padding-bottom:clamp(3rem,8vh,5rem)}
  .kmstat--bd{width:auto;flex:1;padding:24px 32px}
  .kmstat--bl{padding:24px 32px}
  .kmicon{padding-left:48px}
  .kmimg{padding-left:48px}
  .kmlet{padding:24px 32px}
  .kmstat__l{max-width:200px}
}
@media (max-width:760px){
  :root{--gutter:24px}
  .testi{overflow:hidden}
  .testi__right{width:100%;max-width:100%;min-width:0}
  .testi__viewport{width:100%;max-width:100%;overflow:hidden}
  .testi__track{gap:16px}
  .tcard{flex:0 0 100%;min-width:100%;max-width:100%;margin:0;box-sizing:border-box}
  .testi__heading{white-space:normal}
  .brands__title{white-space:normal}
  .head2__title--tight{white-space:normal}
  .head2__lead br{display:none}
  .bar__phone{display:none}
  .bar__cta{display:none}
  .hero__title{font-size:clamp(2.2rem,8vw,3.2rem)}
  .form{grid-template-columns:1fr}
  .field--full{grid-column:auto}
  .sticky-cta{display:flex}
  .widget{display:none}
  .footer__grid{grid-template-columns:1fr 1fr}
  .display--right{text-align:left;align-self:flex-start}
  .split-head__row{gap:0}
}
@media (max-width:520px){
  body{font-size:15.5px}
  .bar__inner{height:66px}
  .menu-toggle em{display:none}
  .numbers{grid-template-columns:1fr}
  .kmrow{flex-direction:column;align-items:stretch}
  .kmstat--bd,.kmstat--bl{width:100%;padding:24px;border-right:none;border-left:none;border-bottom:1px solid var(--line)}
  .kmicon{padding:24px;flex:none;border-bottom:1px solid var(--line)}
  .kmimg{width:100%;padding:24px;border-bottom:1px solid var(--line);justify-content:center}
  .kmlet{width:100%;padding:24px;border-right:none;border-bottom:1px solid var(--line)}
  .kmimg-right{width:100%;padding:24px;justify-content:center}
  .kmpic,.kmpic--wide,.kmimg-right .kmpic{width:100%;max-width:340px}
  .adv{grid-template-columns:1fr}
  .adv__item{min-height:0}
  .showroom__info{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr}
  .footer__map-frame{max-width:none}
  .btn{width:100%}
  .hero__cta .btn,.showroom__cta .btn,.quiz__nav .btn,.modal .btn{width:100%}
  .svc__row{grid-template-columns:auto 1fr auto}
  .testi__heading,.faq__title,.showroom__title{font-size:clamp(1.8rem,7vw,2.4rem)}
}

/* ===================== NEW COMPONENTS (all viewports) ===================== */
/* controlled line-break helpers: br--d desktop-only, br--m mobile-only */
.br--m{display:none}

/* hero mobile gallery + architects mobile image: hidden by default (desktop) */
.hero__gallery{display:none}
.archi__media-m{display:none}

/* realizacje — progress indicator + CTA below carousel */
.wreel-foot{margin-top:clamp(1.6rem,2.6vw,2.2rem)}
.wreel__progress{position:relative;height:4px;border-radius:999px;background:rgba(140,125,91,.22);cursor:pointer}
.wreel__progress-thumb{position:absolute;left:0;top:0;height:100%;width:30%;border-radius:999px;background:var(--green);cursor:grab}
.wreel__progress-thumb:active{cursor:grabbing}

/* realizacje — card is clickable (opens lightbox) with delicate hover hint */
.wcard{cursor:pointer}
.wcard__media::before{content:"";position:absolute;inset:0;z-index:2;background:rgba(20,30,20,0);transition:background .4s var(--ease);pointer-events:none}
.wcard:hover .wcard__media::before{background:rgba(20,30,20,.28)}
.wcard__media::after{content:"Zobacz";position:absolute;z-index:3;left:50%;top:50%;transform:translate(-50%,-50%) scale(.9);padding:.5rem 1.1rem;border-radius:999px;background:rgba(255,255,245,.94);color:var(--green);font-family:var(--ff-sans);font-size:.72rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;opacity:0;transition:opacity .35s var(--ease),transform .35s var(--ease);pointer-events:none}
.wcard:hover .wcard__media::after{opacity:1;transform:translate(-50%,-50%) scale(1)}
@media (hover:none){.wcard__media::before,.wcard__media::after{display:none}}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:500;display:flex;align-items:center;justify-content:center;visibility:hidden;opacity:0;pointer-events:none;transition:opacity .35s var(--ease),visibility .35s var(--ease)}
.lightbox.is-open{visibility:visible;opacity:1;pointer-events:auto}
.lightbox__scrim{position:absolute;inset:0;background:rgba(10,16,10,.9);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.lightbox__stage{position:relative;z-index:2;margin:0;max-width:min(92vw,1100px);max-height:86vh;display:flex;flex-direction:column;align-items:center;gap:1rem;transform:scale(.96);transition:transform .35s var(--ease)}
.lightbox.is-open .lightbox__stage{transform:scale(1)}
.lightbox__stage img{max-width:100%;max-height:78vh;width:auto;height:auto;object-fit:contain;border-radius:14px;box-shadow:0 40px 90px -30px rgba(0,0,0,.7)}
.lightbox__stage figcaption{color:rgba(255,255,245,.92);font-family:var(--ff-display);font-weight:300;font-size:1.25rem;text-align:center}
.lightbox__close{position:absolute;top:18px;right:20px;z-index:3;width:46px;height:46px;border-radius:50%;background:rgba(255,255,245,.12);color:var(--ivory);font-size:1.7rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .3s var(--ease)}
.lightbox__close:hover{background:rgba(255,255,245,.26)}
.lightbox__nav{position:absolute;z-index:3;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;background:rgba(255,255,245,.12);color:var(--ivory);font-size:2rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .3s var(--ease)}
.lightbox__nav:hover{background:rgba(255,255,245,.26)}
.lightbox__nav--prev{left:20px}
.lightbox__nav--next{right:20px}

/* ===================== MOBILE OVERRIDES (≤760px) ===================== */
@media (max-width:760px){
  /* controlled line breaks */
  .br--m{display:inline}
  .br--d{display:none}

  /* --- Task 1: hero --- */
  .hero__inner{padding-top:clamp(3.8rem,8vh,5.4rem);padding-bottom:14px}
  .hero__title{font-size:clamp(1.7rem,8.2vw,2.55rem);line-height:1.14}
  .hero__subtitle{font-size:clamp(.98rem,3.5vw,1.08rem);margin-bottom:1.05rem}
  .hero__gallery{display:block;margin-top:2.4rem;padding:5px;background:rgba(245,241,229,.14);border:1px solid rgba(245,241,229,.25);-webkit-backdrop-filter:blur(8px) saturate(140%);backdrop-filter:blur(8px) saturate(140%);border-radius:14px;box-shadow:0 18px 40px -26px rgba(0,0,0,.55);max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;scroll-behavior:auto}
  .hero__gallery::-webkit-scrollbar{display:none}
  .hero__gallery-track{display:flex;gap:8px;width:max-content}
  .hero__gallery-track img{flex:0 0 auto;width:122px;height:90px;object-fit:cover;border-radius:9px;-webkit-user-drag:none;user-select:none}

  /* --- Task 2 + 6: tight section titles --- */
  .head2__title--tight{font-size:clamp(1.6rem,6.1vw,2.2rem)}

  /* --- Task 2: services as stacked sticky cards --- */
  .svc{border-top:none;padding-top:.3rem}
  .svc__row{position:sticky;top:78px;background:var(--ivory-2);border:1px solid var(--line);border-radius:22px;padding:1.25rem 1.15rem;margin-bottom:14px;box-shadow:0 14px 32px -22px rgba(20,47,23,.42);transition:none}
  .svc__row:last-child{margin-bottom:0}
  .svc__row:hover{padding-left:1.15rem}
  .svc__title{font-size:clamp(1.45rem,6vw,1.9rem)}
  .svc__desc{font-size:.9rem}
  .section__cta--right{justify-content:stretch}
  .section__cta--right .btn{width:100%}

  /* --- Task 3: realizacje progress + cta --- */
  .wreel-foot{margin-top:1.3rem}

  /* --- Task 4: liczby compact 2-col grid --- */
  .metrics{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  .kmrow{display:contents}
  .kmstat--bd,.kmstat--bl{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:.4rem;width:auto;flex:initial;padding:16px 14px;border-bottom:1px solid var(--line)}
  .kmstat--bd{border-right:1px solid var(--line)}
  .kmstat--bl{border-left:none}
  .kmstat__v{font-size:clamp(2.2rem,8.4vw,2.9rem);white-space:nowrap}
  .kmstat__l{width:auto;max-width:none;font-size:.82rem;line-height:1.3}
  .kmicon{flex:initial;padding:0;display:flex;align-items:center;justify-content:center;min-height:88px;border-bottom:1px solid var(--line)}
  .kmicon__sun{width:44px;height:44px}
  .kmimg{width:auto;height:auto;padding:0;display:block;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
  .kmimg .kmpic{width:100%;height:138px;max-width:none}
  .kmlet{width:auto;max-width:none;grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:16px 14px;border-right:none;border-bottom:1px solid var(--line)}
  .kmlet .kmicon__sun{width:42px;height:42px;flex:0 0 auto}
  .kmstat__l--lg{font-size:1.02rem}
  .kmimg-right{width:auto;height:auto;grid-column:1 / -1;padding:0;display:block;justify-content:stretch}
  .kmimg-right .kmpic{width:100%;height:178px;max-width:none}
  .kmpic img{object-position:center}

  /* --- Task 5: architects reorder --- */
  .archi__media{display:none}
  .archi__media-m{display:block;margin:.2rem 0 1.6rem;border-radius:22px;overflow:hidden}
  .archi__media-m img{width:100%;height:clamp(200px,52vw,260px);object-fit:cover;display:block}

  /* --- Task 6: advantages as stacked sticky cards --- */
  .adv{display:flex;flex-direction:column;gap:0}
  .adv__item{position:sticky;top:84px;margin-bottom:14px;min-height:0;background:var(--ivory-2)}
  .adv__item:last-child{margin-bottom:0}

  /* --- brands: decorative icon fully visible (no crop), top-right corner --- */
  .brands{overflow:visible}
  .brands__symbol{top:20px;right:12px;transform:none;width:clamp(84px,22vw,112px);opacity:.05}

  /* --- brands: real horizontal carousel (auto-scroll marquee + manual swipe) --- */
  .brands__marquee{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-block:6px;-webkit-mask-image:linear-gradient(90deg,transparent,#000 4%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 4%,#000 92%,transparent)}
  .brands__marquee::-webkit-scrollbar{display:none}
  .brands__track{animation:none;gap:14px;width:max-content;padding-right:0}
  .bcard{font-size:1.25rem;padding:.85rem 1.5rem}
  .bcard[aria-hidden]{display:inline-flex} /* keep duplicates for a seamless loop */

  /* burger menu — more compact card image */
  .menu__card img{height:150px;object-position:center}

  /* --- Task 8: faq button at the end --- */
  .faq__cta{display:flex;width:100%;margin-top:2rem}

  /* --- Task 9: footer centered + bigger logo --- */
  .footer__logo{height:clamp(54px,12vw,66px)}
  .footer__top{flex-direction:column;align-items:center;text-align:center;gap:1.2rem}
  .footer__social{justify-content:center;flex-wrap:wrap}
  .footer__grid{text-align:center}
  .footer__about{display:flex;flex-direction:column;align-items:center}
  .footer__desc{margin-inline:auto}
  .footer__col{align-items:center}
  .footer__map{display:flex;flex-direction:column;align-items:center}
  .footer__btn{width:100%;max-width:320px}
  .footer__map-frame{margin-inline:auto;width:100%}
  .footer__bottom{flex-direction:column;align-items:center;text-align:center;gap:.6rem}
  .footer__legal{justify-content:center}

  /* lightbox on small screens */
  .lightbox__stage{max-width:94vw}
  .lightbox__stage img{max-height:72vh}
  .lightbox__stage figcaption{font-size:1.05rem}
  .lightbox__nav{width:42px;height:42px;font-size:1.6rem}
  .lightbox__nav--prev{left:8px}
  .lightbox__nav--next{right:8px}
  .lightbox__close{top:12px;right:12px;width:42px;height:42px}
}
