/* =========================================================
   MyOffice — Landing Page
   Fonts · Tokens · Base · Components · Sections · Responsive
   ========================================================= */

/* ---------- FONTS ---------- */
/* Embedded (base64) in css/fonts.css so they load over file:// too. */

/* ---------- TOKENS ---------- */
:root{
  --ink:#0e0e0e;
  --ink-soft:#1a1a1a;
  --cream:#f3f0ea;
  --cream-2:#efece5;
  --paper:#ffffff;
  --muted:#7c7a76;
  --muted-light:rgba(255,255,255,.72);
  --line:rgba(14,14,14,.14);
  --line-light:rgba(255,255,255,.30);
  --gold:#c2a15e;
  /* bronze hot-stamp — metallic foil gradient (refined, chic) */
  --bronze:#9c7a4a;
  --bronze-3:#cba877;
  /* subtle, refined bronze sheen — low contrast, narrow highlight (not a loud foil) */
  --bronze-foil:linear-gradient(115deg,#8a6c41 0%,#a98a55 42%,#cdb079 50%,#9c7c4a 58%,#7e6038 100%);
  --ease:cubic-bezier(.16,1,.3,1);
  --ease-soft:cubic-bezier(.4,0,.2,1);
  --pad:clamp(20px,5vw,80px);
  --maxw:1320px;
}

/* ---------- RESET / BASE ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
/* Lenis smooth-scroll (inertial). Native smooth-behavior is OFF so they don't fight. */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:hidden}
body{
  font-family:"Neue Montreal",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  background:var(--cream);
  color:var(--ink);
  line-height:1.5;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-weight:400;letter-spacing:-.02em;line-height:1.04}
::selection{background:var(--ink);color:var(--cream)}

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

/* ---------- SCROLL PROGRESS ---------- */
.scroll-progress{
  position:fixed;top:0;left:0;height:2px;width:0;z-index:120;
  background:linear-gradient(90deg,var(--gold),rgba(194,161,94,.4));
}

/* ---------- REVEAL ANIMATIONS ---------- */
/* GSAP owns the motion (js/animations.js). We only pre-hide to avoid a flash,
   and ONLY when JS is present — so no-JS / GSAP-fail still shows everything. */
.js [data-reveal]{opacity:0}
.no-anim [data-reveal]{opacity:1!important;transform:none!important;filter:none!important;visibility:visible!important}
.img-zoom{overflow:hidden}
.img-zoom img{transform:scale(1.14)}
.no-anim .img-zoom img{transform:scale(1)!important}

/* =========================================================
   NAV
   ========================================================= */
.nav{position:fixed;top:0;left:0;width:100%;z-index:100;transition:background .5s var(--ease-soft),box-shadow .5s var(--ease-soft)}
.nav__inner{
  max-width:none;margin-inline:auto;padding:22px clamp(24px,6vw,110px);
  display:flex;align-items:center;gap:32px;
}
.brand{
  display:inline-flex;flex-direction:column;line-height:1;color:#fff;
  transition:color .5s var(--ease-soft)
}
.brand__name{font-weight:500;font-size:22px;letter-spacing:-.02em}
.brand__tag{font-size:9.5px;font-weight:400;letter-spacing:.32em;text-transform:lowercase;opacity:.78;margin-top:6px}
.brand__logo{display:block;width:auto;height:clamp(31px,3vw,41px);transition:opacity .4s var(--ease)}
.brand__logo path{fill:currentColor}
.brand:hover .brand__logo{opacity:.82}
.nav__links{display:flex;gap:44px;margin-left:auto;font-size:16px;color:rgba(255,255,255,.86)}
.nav__links a{position:relative;padding:4px 0;transition:color .3s}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:currentColor;transition:width .4s var(--ease)}
.nav__links a:hover::after{width:100%}
.nav__cta{
  font-size:16px;color:#fff;padding:11px 26px;border:1px solid rgba(255,255,255,.4);
  border-radius:40px;transition:.4s var(--ease);position:relative;white-space:nowrap;flex:0 0 auto;
}
.nav__cta:hover{background:#fff;color:var(--ink);border-color:#fff}
/* minimalist nav: centred slogan between brand and CTA */
.nav__slogan{flex:1;text-align:center;font-size:14px;font-weight:400;letter-spacing:.01em;
  color:rgba(255,255,255,.78);transition:color .5s var(--ease-soft);margin:0}
.nav.scrolled .nav__slogan{color:rgba(14,14,14,.6)}

/* scrolled state */
.nav.scrolled{background:rgba(243,240,234,.86);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line)}
.nav.scrolled .brand{color:var(--ink)}
.nav.scrolled .nav__links{color:rgba(14,14,14,.74)}
.nav.scrolled .nav__cta{color:var(--ink);border-color:var(--line)}
.nav.scrolled .nav__cta::before{background:var(--line)}
.nav.scrolled .nav__cta:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.nav.scrolled .nav__toggle span{background:var(--ink)}

/* hide-on-scroll-down */
.nav.hidden{transform:translateY(-100%);transition:transform .5s var(--ease-soft),background .5s}

.nav__toggle{display:none;flex-direction:column;gap:6px;background:none;border:0;cursor:pointer;padding:6px;margin-left:auto}
.nav__toggle span{width:26px;height:2px;background:#fff;transition:.4s var(--ease)}

/* mobile menu */
.mobile-menu{
  position:fixed;inset:0;z-index:99;background:var(--ink);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:opacity .5s var(--ease),visibility .5s;
}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu__links{display:flex;flex-direction:column;gap:8px;text-align:center}
.mobile-menu__links a{color:#fff;font-size:28px;font-weight:400;padding:10px;opacity:0;transform:translateY(20px);transition:.6s var(--ease)}
.mobile-menu.open .mobile-menu__links a{opacity:1;transform:none}
.mobile-menu.open .mobile-menu__links a:nth-child(1){transition-delay:.1s}
.mobile-menu.open .mobile-menu__links a:nth-child(2){transition-delay:.16s}
.mobile-menu.open .mobile-menu__links a:nth-child(3){transition-delay:.22s}
.mobile-menu.open .mobile-menu__links a:nth-child(4){transition-delay:.28s}
.mobile-menu__cta{margin-top:18px;border:1px solid rgba(255,255,255,.4);border-radius:40px;font-size:18px!important}

/* =========================================================
   BUTTONS / PLAY
   ========================================================= */
.btn{
  display:inline-flex;align-items:center;gap:12px;font-size:15px;
  padding:15px 30px;border-radius:48px;cursor:pointer;
  transition:.45s var(--ease);white-space:nowrap;
}
.btn--ghost-light{border:1px solid rgba(255,255,255,.5);color:#fff;background:rgba(255,255,255,.02)}
.btn--ghost-light:hover{background:#fff;color:var(--ink);transform:translateY(-2px)}
.btn--solid-light{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.45);color:#fff;backdrop-filter:blur(6px)}
.btn--solid-light:hover{background:#fff;color:var(--ink);transform:translateY(-2px)}

.play{
  display:grid;place-items:center;border:0;cursor:pointer;border-radius:50%;
  width:74px;height:74px;background:rgba(255,255,255,.14);backdrop-filter:blur(4px);
  position:relative;transition:.5s var(--ease)
}
.play::before{content:"";position:absolute;inset:0;border-radius:50%;border:1px solid rgba(255,255,255,.6)}
.play::after{content:"";position:absolute;inset:-1px;border-radius:50%;border:1px solid rgba(255,255,255,.4);animation:pulse 2.6s var(--ease) infinite}
.play svg{width:24px;height:24px;fill:#fff;margin-left:3px}
.play:hover{background:#fff;transform:scale(1.06)}
.play:hover svg{fill:var(--ink)}
.play:hover::before{border-color:#fff}
@keyframes pulse{0%{transform:scale(1);opacity:.7}70%{transform:scale(1.5);opacity:0}100%{opacity:0}}

/* =========================================================
   1 · HERO
   ========================================================= */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-start;overflow:hidden;color:#fff}
.hero__bg{
  position:absolute;inset:-8% 0;background:#0d1014;
  background-image:url("../assets/img/hero-lounge.jpg");
  background-size:cover;background-position:center;will-change:transform;
}
.hero__marble{
  position:absolute;top:0;bottom:0;left:0;z-index:2;width:clamp(220px,26vw,520px);
  background:#0d0f12 url("../assets/img/hero-marble.webp") center/cover;
  box-shadow:36px 0 90px 10px rgba(8,11,16,.7);
}
.hero__scrim{position:absolute;inset:0;z-index:1;background:
  linear-gradient(90deg,rgba(8,11,16,.88) 0%,rgba(8,11,16,.74) 32%,rgba(8,11,16,.4) 55%,rgba(8,11,16,.08) 80%,rgba(8,11,16,0) 100%),
  linear-gradient(180deg,rgba(8,11,16,.35) 0%,rgba(8,11,16,0) 28%,rgba(8,11,16,0) 70%,rgba(8,11,16,.5) 100%)}
.hero__content{position:relative;z-index:3;max-width:1500px;padding:clamp(150px,40vh,460px) 0 0 clamp(24px,6vw,110px)}
.hero__title{font-size:clamp(34px,4.4vw,92px);font-weight:500;letter-spacing:-.02em;margin-bottom:30px;white-space:nowrap}
.hero__title .line{display:block;overflow:hidden;padding-bottom:.16em;margin-bottom:-.12em}
.hero__title .line span{display:block;transform:translateY(110%);transition:transform 1.1s var(--ease)}
.hero.loaded .hero__title .line:nth-child(1) span{transition-delay:.15s}
.hero.loaded .hero__title .line:nth-child(2) span{transition-delay:.28s}
.hero.loaded .hero__title .line span{transform:none}
.hero__sub{max-width:520px;font-size:clamp(16px,1.6vw,22px);color:rgba(255,255,255,.85);font-weight:400;margin-bottom:40px;line-height:1.58}
/* contained rectangle button (not a full-bleed band) */
.hero__cta{
  display:inline-flex;align-items:center;gap:14px;width:fit-content;
  border:1px solid rgba(255,255,255,.45);border-radius:3px;
  background:rgba(255,255,255,.12);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  padding:16px 30px;font-size:clamp(15px,1.2vw,18px);font-weight:400;
  letter-spacing:.004em;color:#fff;
  transition:background .45s var(--ease),border-color .45s var(--ease),transform .45s var(--ease);
}
.hero__cta::after{content:"→";font-size:1.05em;transition:transform .45s var(--ease)}
.hero__cta:hover{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.8);transform:translateY(-2px)}
.hero__cta:hover::after{transform:translateX(4px)}
.play--hero{position:absolute;left:62%;right:auto;top:50%;transform:translate(-50%,-50%)}
.hero__mouse{position:absolute;left:50%;bottom:32px;z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:8px;
  background:none;border:0;cursor:pointer;padding:6px 10px;
  transform:translateX(-50%);opacity:.82;
  transition:opacity .4s var(--ease);
  animation:mouseFloat 2.6s var(--ease) infinite}
.hero__mouse:hover{opacity:1}
@keyframes mouseFloat{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(5px)}}
.hero__mouse svg{display:block;width:22px}
.hero__mouse-dot{animation:mouseDot 1.9s var(--ease) infinite}
@keyframes mouseDot{0%{transform:translateY(0);opacity:0}18%{opacity:1}55%{transform:translateY(8px);opacity:0}100%{opacity:0}}
.hero__mouse-chevron{width:8px;height:8px;border-right:1.6px solid #fff;border-bottom:1.6px solid #fff;transform:rotate(45deg);animation:chevDown 1.9s var(--ease) infinite}
@keyframes chevDown{0%{opacity:0;transform:translateY(-2px) rotate(45deg)}50%{opacity:.8}100%{opacity:0;transform:translateY(3px) rotate(45deg)}}
.hero__slider{position:absolute;left:0;right:0;bottom:0;height:2px;background:rgba(255,255,255,.18);z-index:2}
.hero__slider::before{content:"";position:absolute;left:0;top:0;height:100%;width:28%;background:rgba(255,255,255,.55)}
.hero__knob{position:absolute;left:28%;top:50%;transform:translate(-50%,-50%);width:11px;height:11px;border-radius:50%;background:#fff;box-shadow:0 0 0 5px rgba(255,255,255,.1)}

/* =========================================================
   2 · DIFERENCIAIS (expanding vertical columns / accordion)
   ========================================================= */
.cols-sec{background:var(--ink);padding:clamp(8px,1vw,14px)}
.cols{display:flex;gap:clamp(8px,1vw,14px);height:clamp(440px,62vh,640px)}
.col{position:relative;overflow:hidden;cursor:pointer;border-radius:2px;
  flex:1 1 0;min-width:0;outline:none;
  transition:flex-grow .9s var(--ease)}
/* one column open at a time: hovered/focused/default-open grows, others shrink */
.col.is-open{flex-grow:3.4}
.cols:hover .col.is-open:not(:hover){flex-grow:1}
.col:hover,.col:focus-visible{flex-grow:3.4}
.col__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;
  transform:scale(1.06);transition:transform 1.6s var(--ease),filter 1s var(--ease-soft);will-change:transform}
.col__scrim{position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(8,10,12,.12) 30%,rgba(8,10,12,.82) 100%);transition:opacity .6s var(--ease)}
.col:hover .col__img,.col.is-open .col__img,.col:focus-visible .col__img{transform:scale(1.02)}
.col__content{position:absolute;left:0;bottom:0;z-index:2;display:flex;flex-direction:column;
  padding:clamp(20px,1.8vw,30px);width:max(100%,320px)}
.col__idx{font-size:12px;letter-spacing:.22em;color:rgba(255,255,255,.6);margin-bottom:10px}
.col__label{font-size:clamp(17px,1.5vw,23px);font-weight:500;color:#fff;letter-spacing:-.01em;line-height:1.15;
  text-shadow:0 2px 22px rgba(0,0,0,.5)}
.col__desc{margin-top:12px;font-size:clamp(13px,1vw,15px);color:rgba(255,255,255,.82);line-height:1.55;max-width:330px;
  opacity:0;transform:translateY(8px);transition:opacity .55s var(--ease),transform .55s var(--ease);
  transition-delay:0s}
.col:hover .col__desc,.col.is-open .col__desc,.col:focus-visible .col__desc{opacity:1;transform:none;transition-delay:.12s}
.cols:hover .col.is-open:not(:hover) .col__desc{opacity:0;transform:translateY(8px)}
@media (max-width:820px){
  .cols{flex-direction:column;height:auto}
  .col{flex:none;height:clamp(180px,40vw,260px)}
  .col.is-open,.col:hover,.col:focus-visible{flex-grow:0}
  /* mobile: only index + title show; description reveals on tap (is-open) */
  .col__desc{display:none;opacity:1;transform:none;transition:none}
  .col.is-open .col__desc{display:block}
}

/* =========================================================
   3 · SHOWCASE (wood office)
   ========================================================= */
.showcase{position:relative;min-height:100vh;display:flex;align-items:flex-end;overflow:hidden;color:#fff}
.showcase__scrim{position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(180deg,rgba(0,0,0,.05) 40%,rgba(0,0,0,.6) 100%)}

/* draggable full-bleed slider */
.slider{position:absolute;inset:0;z-index:0;overflow:hidden;cursor:grab;touch-action:pan-y}
.slider.grabbing{cursor:grabbing}
.slider__track{display:flex;height:100%;will-change:transform}
.slide{position:relative;flex:0 0 100%;height:100%;overflow:hidden}
.slide__img{position:absolute;inset:0;background-size:cover;background-position:center bottom;transform:scale(1.005)}
.slider__nav{position:absolute;z-index:3;top:46%;transform:translateY(-50%);
  width:clamp(54px,4.6vw,72px);height:clamp(54px,4.6vw,72px);border-radius:50%;
  border:1px solid rgba(255,255,255,.45);background:rgba(0,0,0,.12);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
  color:#fff;cursor:pointer;display:grid;place-items:center;
  transition:background .45s var(--ease),border-color .45s var(--ease),transform .45s var(--ease)}
.slider__nav svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round}
.slider__nav--prev{left:clamp(16px,2.4vw,40px)}
.slider__nav--next{right:clamp(16px,2.4vw,40px)}
.slider__nav:hover{background:rgba(255,255,255,.16);border-color:#fff;transform:translateY(-50%) scale(1.06)}
.showcase__hint{display:block;margin-top:18px;font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.showcase__hint::after{content:" ↔"}

/* full-bleed foot: meter spans the whole width, title left / copy right below it */
.showcase__foot{position:relative;z-index:2;width:100%;padding:0 clamp(24px,5.8vw,96px) clamp(40px,6vw,78px)}

.showcase__meter{display:flex;align-items:center;gap:clamp(16px,2vw,30px);width:100%;margin-bottom:clamp(40px,6vw,82px);color:#fff}
.showcase__num{font-size:clamp(15px,1.25vw,20px);font-weight:300;letter-spacing:.12em}
.showcase__track{position:relative;flex:1;height:1px;background:rgba(255,255,255,.42)}
.showcase__track b{position:absolute;left:0;top:50%;height:2px;transform:translateY(-50%);width:11%;background:#fff;transition:width .8s var(--ease)}

.showcase__row{display:flex;justify-content:space-between;align-items:flex-start;gap:clamp(30px,5vw,80px)}
.showcase__title{font-size:clamp(26px,3.1vw,46px);font-weight:500;line-height:1.05;white-space:nowrap}
.showcase__copy{font-size:clamp(13px,1vw,15px);color:rgba(255,255,255,.82);max-width:560px;line-height:1.6}

/* =========================================================
   4 · PROBLEM (cream)
   ========================================================= */
.problem{background:var(--cream);padding-bottom:clamp(70px,9vw,140px)}
.problem__media{width:100%;height:clamp(280px,42vw,560px);overflow:hidden;background:#ddd}
.problem__media .img-zoom{width:100%;height:100%}
.problem__media img{width:100%;height:100%;object-fit:cover;object-position:center 30%;filter:grayscale(1) contrast(1.02)}
.problem__body{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(40px,7vw,120px);padding-top:clamp(50px,7vw,110px)}
.problem__title{font-size:clamp(30px,4.2vw,60px);font-weight:400;letter-spacing:-.02em}
.problem__text{font-size:clamp(13px,1vw,15px);color:#55524d;line-height:1.75;max-width:520px;align-self:end;text-align:justify}
.problem__highlight{margin-top:26px;font-weight:500;color:var(--ink);font-size:clamp(15px,1.2vw,17px)}

/* =========================================================
   5 · STATEMENT (man window)
   ========================================================= */
.statement{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;color:#fff;padding-block:clamp(80px,12vh,140px)}
.statement__bg{position:absolute;inset:-8% 0;background-size:cover;background-position:center 30%;will-change:transform}
.statement__scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,10,16,.55),rgba(6,10,16,.35) 50%,rgba(6,10,16,.78))}
.statement__content{position:relative;z-index:2}
.statement__title{font-size:clamp(24px,3vw,46px);font-weight:300;max-width:900px}
.play--center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:2}
.statement__copy{position:relative;z-index:2;font-size:clamp(15px,1.3vw,19px);color:rgba(255,255,255,.82);max-width:820px;line-height:1.78}

/* =========================================================
   6 · RESULTS (green office + diagram + logos)
   ========================================================= */
.results{position:relative;overflow:hidden;color:#fff}
.results__bg{position:absolute;inset:-8% 0;background-size:cover;background-position:center;will-change:transform}
.results__scrim{position:absolute;inset:0;background:linear-gradient(110deg,rgba(8,12,12,.9) 0%,rgba(8,12,12,.62) 50%,rgba(8,12,12,.6) 100%)}
.results__inner{position:relative;z-index:2;min-height:84vh;display:grid;grid-template-columns:1.32fr .85fr;align-items:center;gap:clamp(30px,4vw,64px);padding-block:clamp(70px,9vw,120px)}
.results__title{font-size:clamp(24px,3vw,44px);font-weight:400;line-height:1.18;letter-spacing:-.01em}
.results__title strong{font-weight:500}

/* circular diagram */
.diagram{position:relative;justify-self:center;width:min(46vw,475px);aspect-ratio:1}
/* dark halo so the white cycle reads cleanly over the busy photo */
.diagram::before{content:"";position:absolute;inset:-16%;z-index:-1;border-radius:50%;
  background:radial-gradient(circle,rgba(6,10,10,.6) 35%,rgba(6,10,10,.25) 60%,transparent 75%)}
.diagram__svg{position:absolute;inset:0;width:100%;height:100%;overflow:visible}
.diagram__ring{fill:none;stroke:rgba(255,255,255,.24);stroke-width:1.1}
.diagram__seg{fill:none;stroke:rgba(255,255,255,.92);stroke-width:1.7;stroke-linecap:round}
.diagram__dot{fill:#fff}
.diagram__center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);text-align:center;font-size:clamp(15px,1.3vw,19px);font-weight:500;line-height:1.3;width:48%}
.diagram__node{position:absolute;font-size:clamp(11px,1vw,13.5px);letter-spacing:.13em;text-transform:uppercase;color:rgba(255,255,255,.92);max-width:44%;line-height:1.3}
.diagram__node--tl{top:2%;right:54%;text-align:right}
.diagram__node--tr{top:2%;left:54%;text-align:left}
.diagram__node--bl{bottom:2%;right:54%;text-align:right}
.diagram__node--br{bottom:2%;left:54%;text-align:left}
/* rotating flow arrows (the cycle spins continuously) */
.diagram__cycle{transform-box:view-box;transform-origin:center;animation:diagSpin 44s linear infinite;animation-play-state:paused}
.diagram.is-drawn .diagram__cycle{animation-play-state:running}
@keyframes diagSpin{to{transform:rotate(360deg)}}
.no-anim .diagram__cycle{animation:none}
.no-anim .diagram__seg,.no-anim .diagram__ring{stroke-dashoffset:0!important}
.no-anim .diagram__node,.no-anim .diagram__dot,.no-anim .diagram__center{opacity:1!important;visibility:visible!important}

/* logo bar — single-line auto-scrolling marquee carousel (~4 per view on phones) */
.logobar{position:relative;z-index:2;background:rgba(10,14,14,.34);-webkit-backdrop-filter:blur(9px);backdrop-filter:blur(9px);
  border-top:1px solid rgba(255,255,255,.10);padding-block:clamp(22px,2.6vw,36px)}
.logobar__viewport{overflow:hidden;width:100%;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.logobar__track{display:flex;align-items:center;width:max-content;list-style:none;
  animation:logoMarquee 38s linear infinite;will-change:transform}
.logobar__track:hover{animation-play-state:paused}
.no-anim .logobar__track{animation:none}
/* fixed slots (no gap → translateX(-50%) lands exactly on the duplicate) */
.logobar__track li{flex:0 0 clamp(104px,24vw,196px);display:flex;align-items:center;justify-content:center;
  height:clamp(46px,5vw,64px);padding-inline:clamp(10px,1.5vw,24px)}
.logobar__track img{max-height:100%;max-width:100%;width:auto;height:auto;object-fit:contain;
  opacity:.95;transition:opacity .45s var(--ease)}
.logobar__track img.logo--wide{max-width:clamp(110px,12vw,160px)}
.logobar__track img.logo--sq{max-height:78%;max-width:clamp(50px,6vw,80px)}
.logobar__track img.logo--spfc{max-height:96%;max-width:clamp(58px,6.8vw,92px)}
.logobar__track li:hover img{opacity:1}
@keyframes logoMarquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
/* Desktop: all logos fit on one line → show each ONCE, no scrolling carousel.
   The duplicate set (only needed for the seamless mobile marquee) is hidden. */
@media (min-width:821px){
  .logobar__viewport{-webkit-mask-image:none;mask-image:none}
  .logobar__track{animation:none;width:100%;max-width:var(--maxw);margin-inline:auto;
    padding-inline:var(--pad);justify-content:space-between;gap:clamp(16px,2vw,40px)}
  .logobar__track li[aria-hidden="true"]{display:none}
  .logobar__track li{flex:0 1 auto;padding-inline:0}
}

/* =========================================================
   2.5 · JOURNEY (vertical timeline, line fills on scroll)
   ========================================================= */
.journey{background:var(--cream-2);padding:clamp(80px,11vw,160px) 0 clamp(36px,5vw,68px)}
.journey__head{max-width:720px;margin-bottom:clamp(48px,7vw,90px)}
.journey__eyebrow{display:inline-block;font-size:11.5px;letter-spacing:.24em;text-transform:uppercase;margin-bottom:18px;
  background:var(--bronze-foil);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:var(--bronze)}
.journey__title{font-size:clamp(30px,4.4vw,60px);font-weight:500;letter-spacing:-.02em;margin-bottom:22px}
.journey__lead{font-size:clamp(14px,1.1vw,17px);color:#5e5c57;line-height:1.7;max-width:620px}

.timeline{position:relative;list-style:none;max-width:1200px;margin-inline:auto}
.timeline__track,.timeline__fill{position:absolute;left:50%;margin-left:-1px;width:2px;top:0;bottom:0}
.timeline__track{background:rgba(14,14,14,.14)}
.timeline__fill{background:var(--ink);transform:scaleY(0);transform-origin:top;will-change:transform}
.no-anim .timeline__fill{transform:scaleY(1)}

.tl-step{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,96px);
  align-items:center;padding-block:clamp(28px,4vw,56px)}
.tl-step__media{position:relative;overflow:hidden;border-radius:5px;aspect-ratio:4/3;margin:0;
  box-shadow:0 30px 70px -34px rgba(0,0,0,.45)}
.tl-step__media img{width:100%;height:100%;object-fit:cover;
  filter:grayscale(.45) brightness(.97);transform:scale(1.06);
  transition:filter 1s var(--ease),transform 1.5s var(--ease)}
.tl-step.is-active .tl-step__media img,.tl-step__media:hover img{filter:grayscale(0) brightness(1);transform:scale(1)}
.tl-step__body{max-width:430px}
.tl-step:nth-of-type(even) .tl-step__media{order:2}
.tl-step:nth-of-type(even) .tl-step__body{order:1;justify-self:end;text-align:right}
.tl-step__num{display:block;font-size:clamp(40px,4.6vw,72px);font-weight:300;line-height:1;
  color:rgba(14,14,14,.12);margin-bottom:12px;transition:color .6s var(--ease)}
.tl-step.is-active .tl-step__num{color:rgba(14,14,14,.24)}
.tl-step__title{font-size:clamp(19px,1.9vw,27px);font-weight:500;letter-spacing:-.01em;margin-bottom:12px;color:var(--ink)}
.tl-step__text{font-size:clamp(13px,1vw,15px);color:#5e5c57;line-height:1.72}
.tl-step__dot{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) scale(1);
  width:11px;height:11px;border-radius:50%;background:var(--cream-2);
  border:1.5px solid rgba(14,14,14,.34);z-index:2;
  transition:background .5s var(--ease),border-color .5s var(--ease),transform .5s var(--ease),box-shadow .5s var(--ease)}
.tl-step.is-active .tl-step__dot{background:var(--bronze);border-color:var(--bronze-3);
  transform:translate(-50%,-50%) scale(1.18);
  box-shadow:0 0 0 4px rgba(156,122,74,.12)}
.tl-step.is-active .tl-step__num{
  background:var(--bronze-foil);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:var(--bronze)}

/* =========================================================
   7 · SERVICES (cream)
   ========================================================= */
.services{background:var(--cream);padding-block:clamp(70px,9vw,140px)}
.services__title{font-size:clamp(28px,3.6vw,52px);font-weight:400;letter-spacing:-.02em;margin-bottom:clamp(50px,7vw,96px)}
.services__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(36px,4vw,64px) clamp(36px,5vw,90px)}
.service{max-width:360px}
.service__ic{height:48px;width:auto;margin-bottom:26px;opacity:.9}
.service h3{font-size:clamp(16px,1.35vw,20px);font-weight:500;margin-bottom:12px;letter-spacing:-.01em}
.service p{font-size:clamp(14px,1.05vw,15.5px);color:#6a6862;line-height:1.72}

/* =========================================================
   8 · EXPERIENCE (people walking)
   ========================================================= */
.experience{position:relative;min-height:96vh;display:flex;align-items:flex-end;overflow:hidden;color:#fff}
.experience__bg{position:absolute;inset:-8% 0;background-size:cover;background-position:center;filter:grayscale(1);will-change:transform}
.experience__scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.15) 30%,rgba(0,0,0,.82) 100%)}
.experience__inner{position:relative;z-index:2;width:100%;display:grid;grid-template-columns:1.5fr 1fr;align-items:end;gap:40px;padding-bottom:clamp(50px,7vw,90px)}
.experience__title{font-size:clamp(34px,5vw,72px);font-weight:500;letter-spacing:-.02em;margin-bottom:24px}
.experience__copy{font-size:clamp(12px,.95vw,14px);color:rgba(255,255,255,.72);max-width:560px;line-height:1.7}
.experience__cta{justify-self:end;padding:18px 40px}

/* =========================================================
   5 · ENTREGÁVEIS (deliverables, cream) + SHOWROOM
   ========================================================= */
.deliver{background:var(--cream);padding-block:clamp(80px,11vw,150px) 0}
.deliver__inner{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(40px,6vw,110px);align-items:start}
.deliver__head{position:sticky;top:clamp(90px,12vh,130px)}
.deliver__eyebrow{display:inline-block;font-size:11.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
.deliver__title{font-size:clamp(30px,4vw,56px);font-weight:500;letter-spacing:-.02em;line-height:1.05;margin-bottom:24px}
.deliver__lead{font-size:clamp(14px,1.1vw,16.5px);color:#5e5c57;line-height:1.72;max-width:440px}
.deliver__list{list-style:none;display:flex;flex-direction:column}
.deliver__item{display:grid;grid-template-columns:auto 1fr;gap:clamp(20px,2.4vw,40px);align-items:start;
  padding:clamp(26px,3vw,40px) 0;border-top:1px solid var(--line)}
.deliver__item:last-child{border-bottom:1px solid var(--line)}
.deliver__num{font-size:clamp(13px,1vw,15px);font-weight:400;color:var(--bronze);letter-spacing:.12em;padding-top:5px;
  background:var(--bronze-foil);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.deliver__txt h3{font-size:clamp(18px,1.7vw,25px);font-weight:500;letter-spacing:-.01em;margin-bottom:10px;color:var(--ink)}
.deliver__txt p{font-size:clamp(13px,1.02vw,15px);color:#6a6862;line-height:1.66;max-width:480px}

.showroom{margin-top:clamp(60px,8vw,120px);background:var(--ink);color:#fff}
.showroom__inner{display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(30px,5vw,80px);align-items:center;
  padding-block:clamp(48px,6vw,84px)}
.showroom__eyebrow{display:inline-block;font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--bronze-3);margin-bottom:16px}
.showroom__title{font-size:clamp(24px,2.8vw,40px);font-weight:500;letter-spacing:-.02em;line-height:1.1;margin-bottom:16px}
.showroom__lead p{font-size:clamp(13px,1.05vw,15.5px);color:rgba(255,255,255,.68);line-height:1.7;max-width:480px}
.showroom__addr{font-style:normal;font-size:clamp(15px,1.3vw,19px);line-height:1.7;color:rgba(255,255,255,.9);
  justify-self:end;text-align:right;padding-left:clamp(20px,3vw,48px);border-left:1px solid rgba(255,255,255,.16)}
.showroom__addr-h{display:block;font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,255,255,.4);margin-bottom:14px}
@media (max-width:900px){
  .deliver__inner{grid-template-columns:1fr;gap:40px}
  .deliver__head{position:static}
  .showroom__inner{grid-template-columns:1fr;gap:28px}
  .showroom__addr{justify-self:start;text-align:left;padding-left:0;border-left:0;
    padding-top:22px;border-top:1px solid rgba(255,255,255,.16)}
}

/* =========================================================
   9 · SEALS (cream)
   ========================================================= */
.seals{background:var(--cream);padding-block:clamp(60px,8vw,120px)}
.seals__title{font-size:clamp(34px,4.6vw,68px);font-weight:500;color:var(--ink);letter-spacing:-.02em;margin-bottom:clamp(40px,5vw,72px)}
/* stack: award lead on top, then a clean even row of certification cards */
.seals__grid{display:block}
.seals__lead{display:grid;grid-template-columns:minmax(240px,400px) 1fr;gap:clamp(30px,5vw,72px);
  align-items:center;margin-bottom:clamp(44px,6vw,78px)}
.seals__topmind{width:100%;height:auto;margin:0}
.seals__leadtext .seals__sub{font-weight:600;color:var(--ink);font-size:clamp(16px,1.4vw,19px);
  line-height:1.4;margin-bottom:16px;max-width:520px}
.seals__leadtext p{font-size:clamp(13.5px,1vw,15px);color:#5e5c57;line-height:1.75;margin-bottom:14px;max-width:560px}
.seals__leadtext p:last-child{margin-bottom:0}
/* certifications as uniform cards — flex auto-centres the row (handles 5 cleanly) */
.seals__list{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(16px,1.5vw,24px)}
.seal{flex:1 1 160px;max-width:230px;display:flex;flex-direction:column;align-items:center;text-align:center;
  gap:16px;background:var(--paper);border:1px solid var(--line);border-radius:12px;
  padding:clamp(24px,2vw,34px) clamp(16px,1.3vw,22px);
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .5s var(--ease)}
.seal:hover{transform:translateY(-4px);box-shadow:0 24px 50px -30px rgba(0,0,0,.32);border-color:rgba(14,14,14,.2)}
.seal img{width:clamp(54px,4vw,64px);height:clamp(54px,4vw,64px);object-fit:contain;flex:0 0 auto}
.seal p{font-size:13px;color:#5e5c57;line-height:1.62;text-align:center}

/* =========================================================
   1.5 · STATBAND (discreet metrics strip between hero & cols)
   ========================================================= */
.statband{background:var(--cream);border-bottom:1px solid var(--line)}
.statband__inner{display:grid;grid-template-columns:repeat(4,1fr);
  padding-block:clamp(30px,3.4vw,46px)}
.statband__item{display:flex;align-items:baseline;gap:12px;padding-inline:clamp(20px,2.4vw,40px)}
.statband__item:first-child{padding-left:0}
.statband__item b{font-size:clamp(28px,2.9vw,42px);font-weight:400;letter-spacing:-.02em;color:var(--ink);line-height:1;
  white-space:nowrap}
.statband__item i{font-style:normal;font-size:clamp(12px,.92vw,13.5px);color:#6a6862;line-height:1.42}
.statband__item + .statband__item{border-left:1px solid var(--line)}
@media (max-width:820px){
  .statband__inner{grid-template-columns:1fr 1fr;gap:clamp(26px,4vw,36px) 0}
  .statband__item{padding-left:clamp(18px,4vw,30px)}
  .statband__item:nth-child(odd){border-left:0;padding-left:0}
  .statband__item:nth-child(3),.statband__item:nth-child(4){padding-top:clamp(24px,4vw,32px);
    border-top:1px solid var(--line)}
}
@media (max-width:560px){
  /* compact 2×2: number stacked above its label, no big row gaps */
  .statband__inner{grid-template-columns:1fr 1fr;gap:clamp(18px,5vw,26px) clamp(14px,4vw,22px);
    padding-block:clamp(24px,6vw,32px)}
  .statband__item{flex-direction:column;align-items:flex-start;gap:3px;
    padding:0!important;border-left:0!important;border-top:0!important}
  .statband__item b{font-size:clamp(26px,8vw,34px)}
  .statband__item i{font-size:12px;line-height:1.35}
}

/* =========================================================
   11 · CTA FINAL (boardroom)
   ========================================================= */
.cta{position:relative;min-height:100vh;display:flex;align-items:flex-end;overflow:hidden;color:#fff}
.cta__bg{position:absolute;inset:-8% 0;background-size:cover;background-position:center;will-change:transform}
.cta__scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.2) 40%,rgba(0,0,0,.7) 100%)}
.cta__inner{position:relative;z-index:2;width:100%;display:grid;grid-template-columns:1.4fr auto;align-items:end;gap:40px;padding-bottom:clamp(50px,7vw,90px)}
.cta__title{font-size:clamp(30px,4.4vw,64px);font-weight:400;letter-spacing:-.02em;margin-bottom:22px}
.cta__copy{font-size:clamp(13px,1vw,15px);color:rgba(255,255,255,.78);max-width:520px;line-height:1.65}
.cta__btn{padding:18px 42px;font-size:16px}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{background:var(--ink);color:rgba(255,255,255,.62);padding-block:clamp(56px,7vw,92px) 30px}
.footer__top{display:grid;grid-template-columns:1.7fr .9fr 1.3fr 1.2fr;gap:clamp(32px,4vw,64px);
  padding-bottom:clamp(40px,5vw,60px);border-bottom:1px solid rgba(255,255,255,.1)}
.footer__logo{width:158px;height:auto;color:#fff;display:block;margin-bottom:24px}
.footer__logo path{fill:currentColor}
.footer__tagline{font-size:14px;line-height:1.7;color:rgba(255,255,255,.58);max-width:380px;margin-bottom:28px}
.footer__cta{display:inline-flex;align-items:center;gap:10px;font-size:15px;color:#fff;
  border:1px solid rgba(255,255,255,.32);border-radius:3px;padding:13px 24px;
  transition:background .4s var(--ease),color .4s var(--ease),border-color .4s var(--ease)}
.footer__cta span{transition:transform .4s var(--ease)}
.footer__cta:hover{background:#fff;color:var(--ink);border-color:#fff}
.footer__cta:hover span{transform:translateX(4px)}
.footer__col{display:flex;flex-direction:column;gap:13px;font-size:14px}
.footer__h{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:6px}
.footer__col a{color:rgba(255,255,255,.72);transition:color .3s;width:fit-content}
.footer__col a:hover{color:#fff}
.footer__col span{color:rgba(255,255,255,.55)}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;padding-top:24px;flex-wrap:wrap}
.footer__copy,.footer__made{font-size:12.5px;color:rgba(255,255,255,.4)}
.footer__made{letter-spacing:.04em}
@media (max-width:820px){.footer__top{grid-template-columns:1fr 1fr}.footer__brandcol{grid-column:1/-1}}
@media (max-width:560px){.footer__top{grid-template-columns:1fr;gap:30px}.footer__bottom{flex-direction:column;align-items:flex-start;gap:8px}}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1024px){
  .nav__slogan{display:none}
  /* results/cycle: shorter, tighter gap title↔cycle, more translucent overlay */
  .results__inner{grid-template-columns:1fr;gap:clamp(20px,4vw,34px);min-height:auto;
    padding-block:clamp(48px,8vw,84px)}
  .results__scrim{background:linear-gradient(160deg,rgba(8,12,12,.62) 0%,rgba(8,12,12,.5) 55%,rgba(8,12,12,.6) 100%)}
  .diagram{justify-self:center;width:min(72vw,360px)}
  .showcase__row{flex-direction:column;gap:24px}
  .showcase__title{white-space:normal}
  .showcase__copy{max-width:560px}
}
@media (max-width:820px){
  .hero__title{white-space:normal}
  /* privilege the photo: marble becomes a thin accent strip */
  .hero__marble{width:clamp(70px,16vw,130px)}
  .hero__bg{background-position:62% center}
  .hero__content{padding-top:clamp(120px,26vh,220px)}
  .problem__body{grid-template-columns:1fr;gap:30px}
  .services__grid{grid-template-columns:repeat(2,1fr)}
  .seals__lead{grid-template-columns:1fr;justify-items:center;text-align:center;gap:26px}
  .seals__topmind{width:min(70vw,420px)}
  .seals__leadtext .seals__sub,.seals__leadtext p{max-width:620px}
  .experience__inner{grid-template-columns:1fr;align-items:start}
  .experience__cta{justify-self:start}
  .cta__inner{grid-template-columns:1fr;align-items:start}
  /* expanding columns → stacked, taller, bigger type */
  .col__label{font-size:clamp(20px,5vw,26px)}
  .col__desc{font-size:clamp(14px,3.6vw,16px);max-width:none}
  .col__idx{font-size:13px}
  /* showcase: shorter on phones, centred crop; copy reveals on tapping title */
  .showcase{min-height:72vh}
  .slide__img{background-position:center}
  .showcase__copy{display:none}
  .showcase__row.show-copy .showcase__copy{display:block;margin-top:14px}
  .showcase__title{cursor:pointer;display:inline-flex;align-items:center;gap:10px}
  .showcase__title::after{content:"+";font-weight:300;font-size:.8em;opacity:.7;transition:transform .3s var(--ease)}
  .showcase__row.show-copy .showcase__title::after{content:"–"}
  .timeline{max-width:560px}
  .timeline__track,.timeline__fill{left:9px}
  .tl-step{grid-template-columns:1fr;gap:18px;padding-left:42px}
  .tl-step__media{aspect-ratio:16/10}
  .tl-step:nth-of-type(even) .tl-step__media{order:0}
  .tl-step:nth-of-type(even) .tl-step__body{order:0;justify-self:start;text-align:left}
  .tl-step__dot{left:9px;top:34px}
  .tl-step__num{font-size:40px}
  /* results cycle + logos: sane spacing on tablet/phone */
  .results__inner{padding-block:clamp(56px,9vw,90px)}
  .diagram__center{font-size:clamp(14px,3.4vw,18px)}
  .diagram__node{font-size:clamp(10px,2.4vw,12px);max-width:42%}
}
@media (max-width:560px){
  :root{--pad:22px}
  /* shorter hero on phones */
  .hero{min-height:84svh}
  .hero__content{padding-top:clamp(104px,22vh,170px)}
  .hero__marble{width:clamp(54px,14vw,90px)}
  .services__grid{grid-template-columns:1fr}
  .col{height:clamp(230px,54vw,310px)}
  .showcase{min-height:62vh}
  /* seals: single column, comfortable, no justified gaps on narrow text */
  .seals__title{font-size:clamp(30px,9vw,44px)}
  /* bigger, tightly-cropped award logo on phones */
  .seals__topmind{width:min(88vw,440px)}
  .seal{flex:1 1 100%;max-width:340px}
  .statement{min-height:auto}
}

/* =========================================================
   REDUCED MOTION
   ========================================================= */
/* NOTE: no prefers-reduced-motion override — the brand wants motion to play
   on every device. Removing it was required: the old block forced
   transition-duration:.01ms on everything, which made hover/colour/reveal
   snap instantly (no easing) whenever the OS had "reduce motion" enabled. */

/* =========================================================
   WHATSAPP WIDGET (thin, chic, expands on hover)
   ========================================================= */
.wa{position:fixed;right:clamp(18px,2.4vw,34px);bottom:clamp(18px,2.4vw,34px);z-index:150;
  display:inline-flex;align-items:center;height:56px;border-radius:30px;
  background:var(--ink);color:#fff;text-decoration:none;cursor:pointer;font:inherit;padding:0;
  box-shadow:0 16px 40px -14px rgba(0,0,0,.55);
  border:1px solid rgba(255,255,255,.08);
  transition:transform .45s var(--ease),box-shadow .45s var(--ease)}
.wa:hover{transform:translateY(-2px);box-shadow:0 22px 50px -16px rgba(0,0,0,.6)}
.wa__ic{display:grid;place-items:center;width:54px;height:54px;flex:0 0 auto}
.wa__ic svg{width:25px;height:25px;fill:#fff}
.wa__label{white-space:nowrap;max-width:0;opacity:0;overflow:hidden;font-size:14.5px;letter-spacing:.01em;
  transition:max-width .5s var(--ease),opacity .35s var(--ease),padding .5s var(--ease)}
.wa:hover .wa__label{max-width:240px;opacity:1;padding-left:22px}
@media (max-width:560px){.wa__label{display:none}}

/* =========================================================
   QUOTE MODAL (contact form)
   ========================================================= */
.qmodal{position:fixed;inset:0;z-index:200;display:grid;place-items:center;padding:20px;
  opacity:0;visibility:hidden;transition:opacity .5s var(--ease),visibility .5s var(--ease)}
.qmodal.open{opacity:1;visibility:visible}
.qmodal__overlay{position:absolute;inset:0;background:rgba(8,10,12,.55);-webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px)}
.qmodal__dialog{position:relative;z-index:1;display:grid;grid-template-columns:.82fr 1fr;
  width:min(1060px,95vw);max-height:94vh;overflow:auto;background:var(--cream);border-radius:7px;
  box-shadow:0 60px 160px -40px rgba(0,0,0,.65);
  transform:translateY(26px) scale(.985);opacity:0;
  transition:transform .6s var(--ease),opacity .6s var(--ease)}
.qmodal.open .qmodal__dialog{transform:none;opacity:1}
.qmodal__close{position:absolute;top:16px;right:16px;z-index:3;width:40px;height:40px;border:0;border-radius:50%;
  background:rgba(14,14,14,.06);display:grid;place-items:center;cursor:pointer;transition:.45s var(--ease)}
.qmodal__close svg{width:18px;height:18px;stroke:var(--ink);stroke-width:1.6;fill:none;stroke-linecap:round}
.qmodal__close:hover{background:rgba(14,14,14,.12);transform:rotate(90deg)}

.qmodal__aside{background:var(--ink);color:#fff;padding:clamp(32px,3.4vw,52px);display:flex;flex-direction:column}
.qmodal__logo{width:150px;height:auto;color:#fff;margin-bottom:auto}
.qmodal__logo path{fill:currentColor}
.qmodal__headline{font-size:clamp(23px,2.2vw,32px);font-weight:500;line-height:1.14;letter-spacing:-.02em;margin:38px 0 16px}
.qmodal__sub{font-size:13.5px;color:rgba(255,255,255,.68);line-height:1.65;margin-bottom:26px}
.qmodal__points{list-style:none;display:flex;flex-direction:column;gap:11px}
.qmodal__points li{position:relative;padding-left:22px;font-size:13px;color:rgba(255,255,255,.82)}
.qmodal__points li::before{content:"";position:absolute;left:0;top:6px;width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.5)}

.qmodal__form{position:relative;padding:clamp(32px,3.6vw,52px);display:grid;grid-template-columns:1fr 1fr;gap:28px 24px;align-content:start}
.qfield{position:relative}
.qfield--full{grid-column:1/-1}
.qfield input,.qfield textarea{width:100%;border:0;border-bottom:1px solid rgba(14,14,14,.24);
  background:none;padding:9px 0 8px;font:inherit;font-size:15px;color:var(--ink);outline:none;resize:none;
  transition:border-color .4s var(--ease)}
.qfield label{position:absolute;left:0;top:9px;color:var(--muted);font-size:15px;pointer-events:none;transition:.3s var(--ease)}
.qfield label .req{color:#b4452f}
.qfield input:focus,.qfield textarea:focus{border-color:var(--ink)}
.qfield input:focus+label,.qfield input:not(:placeholder-shown)+label,
.qfield textarea:focus+label,.qfield textarea:not(:placeholder-shown)+label{top:-13px;font-size:11.5px;letter-spacing:.04em;color:var(--ink)}
.qmodal__submit{grid-column:1/-1;display:inline-flex;align-items:center;justify-content:center;gap:12px;
  margin-top:6px;padding:17px 28px;background:var(--ink);color:#fff;border:0;border-radius:3px;font-size:15px;cursor:pointer;
  transition:background .45s var(--ease),transform .45s var(--ease)}
.qmodal__submit span{transition:transform .45s var(--ease)}
.qmodal__submit:hover{background:#000}
.qmodal__submit:hover span{transform:translateX(4px)}
.qmodal__note{grid-column:1/-1;font-size:11px;color:var(--muted);text-align:center;margin-top:-10px}
.qmodal__success{display:none;grid-column:1/-1;text-align:center;padding:24px 0}
.qmodal__success h3{font-size:24px;font-weight:500;margin-bottom:10px}
.qmodal__success p{font-size:14px;color:#5e5c57;line-height:1.6}
.qmodal__form.sent .qfield,.qmodal__form.sent .qmodal__submit,.qmodal__form.sent .qmodal__note{display:none}
.qmodal__form.sent .qmodal__success{display:block}
@media (max-width:760px){
  /* bottom sheet: leaves a tappable strip up top (tap outside to close).
     The container is sized to the *visible* viewport (100dvh, bottom:auto) so its
     bottom edge sits ABOVE the iOS Safari toolbar — the submit button + note are
     never hidden behind it. */
  .qmodal{top:0;bottom:auto;height:100dvh;padding:0;place-items:end stretch}
  .qmodal__overlay{cursor:pointer}
  .qmodal__dialog{grid-template-columns:1fr;width:100%;max-width:none;max-height:88dvh;
    border-radius:18px 18px 0 0;transform:translateY(100%);-webkit-overflow-scrolling:touch}
  .qmodal.open .qmodal__dialog{transform:none}
  .qmodal__close{top:12px;right:12px}
  .qmodal__aside{padding:26px 26px 6px}
  .qmodal__headline{margin-top:8px;font-size:clamp(20px,5.4vw,26px)}
  .qmodal__sub,.qmodal__points{display:none}
  .qmodal__form{grid-template-columns:1fr;padding:24px 26px calc(26px + env(safe-area-inset-bottom))}
  .qmodal__note{margin-top:4px}
}
