/* =====================================================================
   KEDO MEDIA — Immobilienmarketing-Agentur
   Design system & stylesheet
   Editorial premium aesthetic · self-hosted fonts · no external CDNs
   ===================================================================== */

/* ---------- Fonts (self-hosted, DSGVO-safe) ---------- */
@font-face{font-family:"Roboto";src:url("../assets/fonts/Roboto-Light.woff2") format("woff2");font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:"Roboto";src:url("../assets/fonts/Roboto-Regular.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Roboto";src:url("../assets/fonts/Roboto-Medium.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Roboto";src:url("../assets/fonts/Roboto-Bold.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Roboto";src:url("../assets/fonts/Roboto-Black.woff2") format("woff2");font-weight:900;font-style:normal;font-display:swap}

/* ---------- Tokens ---------- */
:root{
  --ink:#0a0a0a;
  --ink-soft:#161616;
  --paper:#f4f2ec;
  --paper-2:#eae7dd;
  --line:#d8d4c8;
  --accent:#e1fc21;
  --muted:#6f6c63;
  --muted-on-dark:#a8a59b;
  --white:#ffffff;

  --maxw:1320px;
  --gut:clamp(20px,5vw,72px);
  --radius:2px;

  --f-display:"Roboto",system-ui,sans-serif;
  --f-body:"Roboto",system-ui,sans-serif;

  --ease:cubic-bezier(.22,1,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --dur:.7s;

  --nav-h:74px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;font-family:var(--f-body);background:var(--paper);color:var(--ink);
  font-weight:400;line-height:1.6;font-size:clamp(16px,1.05vw,18px);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{margin:0;padding:0;list-style:none}
h1,h2,h3,h4,p{margin:0}
::selection{background:var(--accent);color:var(--ink)}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--accent);color:var(--ink);padding:.8em 1.2em;z-index:200;font-weight:700}
.skip-link:focus{left:8px;top:8px}

/* ---------- Layout helpers ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut)}
.section{padding-block:clamp(72px,11vw,160px)}
.section--dark{background:var(--ink);color:var(--paper)}
.section--paper2{background:var(--paper-2)}
.eyebrow{
  font-size:.74rem;font-weight:700;letter-spacing:.32em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:.7em;color:var(--muted);
}
.section--dark .eyebrow{color:var(--muted-on-dark)}
.eyebrow::before{content:"";width:30px;height:1px;background:var(--accent)}
.display{
  font-family:var(--f-display);font-weight:900;line-height:.96;letter-spacing:-.02em;
  text-transform:uppercase;
}
.h-xl{font-size:clamp(2.6rem,8vw,7rem)}
.h-lg{font-size:clamp(2rem,5.4vw,4.4rem)}
.h-md{font-size:clamp(1.5rem,3vw,2.4rem)}
.lead{font-size:clamp(1.05rem,1.6vw,1.4rem);font-weight:300;line-height:1.55;max-width:46ch}
.muted{color:var(--muted)}
.section--dark .muted{color:var(--muted-on-dark)}
.accent-text{color:var(--accent)}

/* reveal */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--accent);--fg:var(--ink);
  display:inline-flex;align-items:center;gap:.7em;
  padding:1.05em 1.9em;background:var(--bg);color:var(--fg);
  font-weight:700;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;
  border-radius:100px;position:relative;overflow:hidden;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease);
  will-change:transform;
}
.btn span{position:relative;z-index:1}
.btn svg{position:relative;z-index:1;transition:transform .5s var(--ease)}
.btn::after{content:"";position:absolute;inset:0;background:var(--ink);transform:translateY(101%);transition:transform .5s var(--ease);z-index:0}
.btn:hover{transform:translateY(-3px)}
.btn:hover svg{transform:translateX(5px)}
.btn:hover::after{transform:translateY(0)}
.btn:hover{color:var(--accent)}
.btn--ghost{--bg:transparent;--fg:currentColor;border:1px solid currentColor}
.btn--ghost::after{background:var(--accent)}
.btn--ghost:hover{color:var(--ink)}
.btn--lg{padding:1.2em 2.3em;font-size:.9rem}
.btn--dark{--bg:var(--ink);--fg:var(--accent)}
.btn--dark::after{background:var(--paper)}
.btn--dark:hover{color:var(--ink)}

.link-underline{position:relative;font-weight:500;letter-spacing:.02em;display:inline-block}
.link-underline::after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .5s var(--ease)}
.link-underline:hover::after{transform:scaleX(1);transform-origin:left}

/* =====================================================================
   NAV
   ===================================================================== */
.nav{
  position:fixed;top:0;left:0;width:100%;height:var(--nav-h);z-index:60;
  display:flex;align-items:center;
  transition:background .5s var(--ease),box-shadow .5s var(--ease),height .4s var(--ease);
}
.nav__inner{max-width:1480px;margin:0 auto;padding-inline:clamp(18px,4vw,46px);width:100%;
  display:flex;align-items:center;justify-content:space-between;gap:2rem}
.nav__logo{display:flex;align-items:center}
.nav__logo img{height:22px;width:auto}
.nav__menu{display:flex;align-items:center;gap:clamp(1.1rem,2.2vw,2.4rem)}
.nav__menu a{font-size:.8rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--paper);position:relative;opacity:.85;transition:opacity .3s}
.nav__menu a::after{content:"";position:absolute;left:0;bottom:-6px;width:100%;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:right;transition:transform .4s var(--ease)}
.nav__menu a:hover{opacity:1}
.nav__menu a:hover::after{transform:scaleX(1);transform-origin:left}
.nav__right{display:flex;align-items:center;gap:1.3rem}
.lang{display:flex;align-items:center;gap:.5rem;font-size:.78rem;font-weight:600;letter-spacing:.08em;color:var(--paper)}
.lang a{opacity:.5;transition:opacity .3s}
.lang a.is-active{opacity:1;color:var(--accent)}
.lang a:hover{opacity:1}
.lang__sep{opacity:.3}
.nav__cta{display:inline-flex;align-items:center;gap:.55em;padding:.72em 1.4em;background:var(--accent);color:var(--ink);border-radius:100px;font-size:.76rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;transition:transform .4s var(--ease)}
.nav__cta:hover{transform:translateY(-2px)}

.nav.is-scrolled{background:rgba(10,10,10,.82);backdrop-filter:blur(14px);height:62px;box-shadow:0 1px 0 rgba(255,255,255,.06)}
.nav.is-hidden{transform:translateY(-100%);transition:transform .5s var(--ease)}

/* burger */
.burger{display:none;width:34px;height:34px;position:relative;z-index:80}
.burger span{position:absolute;left:4px;right:4px;height:2px;background:var(--paper);transition:transform .4s var(--ease),opacity .3s}
.burger span:nth-child(1){top:11px}
.burger span:nth-child(2){top:17px}
.burger span:nth-child(3){top:23px}
.nav.menu-open .burger span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav.menu-open .burger span:nth-child(2){opacity:0}
.nav.menu-open .burger span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* mobile overlay */
.mobile-menu{position:fixed;inset:0;background:var(--ink);z-index:55;display:flex;flex-direction:column;justify-content:center;padding:0 var(--gut);
  clip-path:circle(0% at calc(100% - 40px) 40px);transition:clip-path .6s var(--ease);pointer-events:none}
.nav.menu-open + .mobile-menu,.mobile-menu.open{clip-path:circle(150% at calc(100% - 40px) 40px);pointer-events:auto}
.mobile-menu a.m-link{color:var(--paper);font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:clamp(2rem,9vw,3.4rem);line-height:1.08;letter-spacing:-.01em;padding:.12em 0;opacity:0;transform:translateY(20px);transition:opacity .5s var(--ease),transform .5s var(--ease),color .3s}
.mobile-menu.open a.m-link{opacity:1;transform:none}
.mobile-menu a.m-link:hover{color:var(--accent)}
.mobile-menu .m-foot{margin-top:2.4rem;display:flex;gap:1.4rem;align-items:center;color:var(--muted-on-dark);font-size:.85rem;opacity:0;transition:opacity .6s .3s}
.mobile-menu.open .m-foot{opacity:1}

/* =====================================================================
   HERO
   ===================================================================== */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;background:var(--ink);color:var(--paper)}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media video,.hero__media img{width:100%;height:100%;object-fit:cover}
.hero__media::after{content:"";position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(10,10,10,.55) 0%,rgba(10,10,10,.18) 32%,rgba(10,10,10,.4) 62%,rgba(10,10,10,.94) 100%)}
.hero__inner{position:relative;z-index:2;width:100%;max-width:1480px;margin:0 auto;padding:0 clamp(18px,4vw,46px) clamp(40px,7vh,90px)}
.hero__tag{margin-bottom:1.6rem}
.hero__tag .eyebrow{color:var(--paper)}
.hero__tag .eyebrow::before{background:var(--accent)}
.hero__title{font-family:var(--f-display);font-weight:900;text-transform:uppercase;line-height:.92;letter-spacing:-.025em;
  font-size:clamp(3rem,12vw,10rem)}
.hero__sub{display:block;font-size:clamp(1rem,2.4vw,1.9rem);font-weight:300;letter-spacing:.02em;text-transform:none;margin-top:.6rem;color:var(--accent)}
.hero__row{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:2rem;margin-top:2.4rem}
.hero__claim{max-width:52ch;font-size:clamp(1rem,1.35vw,1.2rem);font-weight:300;color:var(--paper)}
.hero__cta{display:flex;gap:1rem;flex-wrap:wrap}
.hero__scroll{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:.5rem;font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted-on-dark)}
.hero__scroll .bar{width:1px;height:42px;background:linear-gradient(var(--accent),transparent);animation:scrolldown 2.2s var(--ease) infinite}
@keyframes scrolldown{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* marquee */
.marquee{background:var(--accent);color:var(--ink);overflow:hidden;white-space:nowrap;border-block:1px solid var(--ink)}
.marquee__track{display:inline-flex;gap:2.5rem;padding-block:.85rem;animation:marquee 30s linear infinite;will-change:transform}
.marquee span{font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:1rem;letter-spacing:.02em;display:inline-flex;align-items:center;gap:2.5rem}
.marquee span::after{content:"✳";font-size:.8em}
@keyframes marquee{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee__track{animation:none}}

/* =====================================================================
   VISION / INTRO split
   ===================================================================== */
.vision{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.vision__media{position:relative;aspect-ratio:4/5;overflow:hidden;border-radius:var(--radius)}
.vision__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease)}
.vision__media:hover img{transform:scale(1.05)}
.vision__media .badge{position:absolute;left:18px;bottom:18px;background:var(--accent);color:var(--ink);padding:.5em 1em;font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;border-radius:100px}
.vision__body p{margin-top:1.4rem;max-width:50ch}
.options{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:2.4rem}
.option{border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem 1.4rem;transition:border-color .4s var(--ease),background .4s var(--ease),transform .4s var(--ease);background:var(--paper)}
.option:hover{border-color:var(--ink);transform:translateY(-4px)}
.option .num{font-size:.7rem;font-weight:700;letter-spacing:.2em;color:var(--accent);background:var(--ink);width:fit-content;padding:.35em .7em;border-radius:100px}
.option h3{font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:1.35rem;margin-top:1rem;letter-spacing:-.01em}
.option p{margin-top:.5rem;font-size:.95rem;color:var(--muted)}
@media (max-width:860px){.vision{grid-template-columns:1fr}.options{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.options{grid-template-columns:1fr}}

/* =====================================================================
   SERVICES  (text cards on dark)
   ===================================================================== */
.services__head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:clamp(2.5rem,6vw,4.5rem)}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,1.6vw,1.4rem)}
.svc{position:relative;border:1px solid rgba(255,255,255,.13);border-radius:6px;padding:clamp(1.6rem,2.4vw,2.2rem);background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,0));transition:border-color .45s var(--ease),transform .45s var(--ease),background .45s var(--ease);display:flex;flex-direction:column}
.svc:hover{border-color:var(--accent);transform:translateY(-5px)}
.svc__num{font-family:var(--f-display);font-weight:900;font-size:1.05rem;letter-spacing:.04em;color:var(--accent)}
.svc h3{font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:clamp(1.25rem,1.9vw,1.6rem);line-height:1.04;margin:.8rem 0 1.1rem;letter-spacing:-.01em}
.svc__list{display:grid;gap:.6rem}
.svc__list li{position:relative;padding-left:1.4rem;font-size:.92rem;color:#d9d7cf;line-height:1.5}
.svc__list li::before{content:"";position:absolute;left:0;top:.6em;width:7px;height:7px;border-radius:50%;background:var(--accent)}
.svc--feature{grid-column:span 1}
@media (max-width:980px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.svc-grid{grid-template-columns:1fr}}

/* =====================================================================
   PROJECTS / REFERENCES
   ===================================================================== */
.projects__head{display:grid;grid-template-columns:1.2fr 1fr;gap:2rem;align-items:end;margin-bottom:clamp(2.5rem,5vw,4rem)}
.projects__head p{color:var(--muted);max-width:42ch}
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,1.6vw,1.4rem)}
.proj{position:relative;overflow:hidden;border-radius:var(--radius);background:var(--ink-soft);isolation:isolate;display:block}
.proj__media{position:relative;aspect-ratio:1/1;overflow:hidden}
.proj__media img,.proj__media video{width:100%;height:100%;object-fit:cover;transition:transform 1.3s var(--ease)}
.proj:hover .proj__media img,.proj:hover .proj__media video{transform:scale(1.06)}
.proj__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.05) 30%,rgba(10,10,10,.92));display:flex;align-items:flex-end;padding:1.3rem;opacity:0;transition:opacity .5s var(--ease)}
.proj:hover .proj__overlay{opacity:1}
.proj__overlay ul{display:grid;gap:.4rem}
.proj__overlay li{position:relative;padding-left:1.1rem;color:#eceadf;font-size:.82rem;line-height:1.35}
.proj__overlay li::before{content:"";position:absolute;left:0;top:.55em;width:5px;height:5px;border-radius:50%;background:var(--accent)}
.proj__bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.1rem}
.proj__title{font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:.95rem;letter-spacing:-.005em;line-height:1.1}
.proj__yt{flex:none;width:34px;height:34px;border-radius:50%;background:var(--accent);color:var(--ink);display:flex;align-items:center;justify-content:center}
.proj__tag{flex:none;font-size:.62rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-on-dark)}
.section--dark .proj__bar{background:var(--ink)}
.section--dark .proj__title{color:var(--paper)}
@media (max-width:980px){.proj-grid{grid-template-columns:repeat(2,1fr)}.projects__head{grid-template-columns:1fr}}
@media (max-width:560px){.proj-grid{grid-template-columns:1fr 1fr;gap:10px}.proj__title{font-size:.8rem}.proj__overlay{display:none}}

/* =====================================================================
   TESTIMONIALS
   ===================================================================== */
.tst__head{text-align:center;max-width:50ch;margin:0 auto clamp(2.5rem,5vw,3.5rem)}
.tst-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1rem,2vw,1.6rem)}
.tst{border:1px solid var(--line);border-radius:8px;padding:clamp(1.8rem,3vw,2.6rem);background:var(--paper);display:flex;flex-direction:column;gap:1.2rem;transition:transform .45s var(--ease),box-shadow .45s var(--ease)}
.tst:hover{transform:translateY(-5px);box-shadow:0 26px 60px rgba(10,10,10,.08)}
.tst__top{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;border-bottom:1px solid var(--line);padding-bottom:1.1rem}
.tst__company{font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:1.05rem;letter-spacing:-.01em}
.tst__stat{text-align:right;line-height:1}
.tst__num{font-family:var(--f-display);font-weight:900;font-size:1.5rem;color:var(--accent);display:block;-webkit-text-stroke:.5px var(--ink)}
.tst__lbl{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.tst__quote{font-size:.98rem;line-height:1.6;color:var(--ink-soft)}
.tst__author{font-size:.82rem;letter-spacing:.06em;color:var(--muted);font-weight:500;margin-top:auto}
.tst__author::before{content:"— "}
@media (max-width:760px){.tst-grid{grid-template-columns:1fr}}

/* =====================================================================
   TEAM
   ===================================================================== */
.team{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.team__media{position:relative}
.team__media .ph{aspect-ratio:3/4;overflow:hidden;border-radius:var(--radius)}
.team__media .ph img{width:100%;height:100%;object-fit:cover}
.team__media .badge{position:absolute;left:16px;bottom:16px;background:var(--accent);color:var(--ink);padding:.45em 1em;font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;border-radius:100px}
.team__body .lead{margin-top:1.4rem}
.team__quote{margin-top:1.4rem;font-size:clamp(1.05rem,1.5vw,1.25rem);font-weight:300;line-height:1.6;color:var(--paper);border-left:2px solid var(--accent);padding-left:1.4rem}
.team__sign{margin-top:1.2rem;display:flex;flex-direction:column;gap:.1rem}
.team__sign strong{font-family:var(--f-display);font-weight:900;text-transform:uppercase;letter-spacing:.02em;color:var(--accent);font-size:1.05rem}
.team__sign span{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-on-dark)}
@media (max-width:860px){.team{grid-template-columns:1fr}.team__media{max-width:420px}}

/* team roster row */
.roster{margin-top:clamp(3rem,6vw,5rem)}
.roster__grid{display:grid;grid-template-columns:repeat(5,1fr);gap:clamp(.7rem,1.4vw,1.1rem)}
.member{text-align:left}
.member__ph{aspect-ratio:3/4;overflow:hidden;border-radius:var(--radius);background:var(--ink-soft);position:relative}
.member__ph img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease);filter:grayscale(1);transition:filter .5s var(--ease),transform 1.2s var(--ease)}
.member:hover .member__ph img{transform:scale(1.05);filter:grayscale(0)}
.member__mono{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--f-display);font-weight:900;font-size:2.4rem;color:var(--accent);background:#1d1d1a}
.member h4{font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:.9rem;letter-spacing:-.005em;margin-top:.9rem;color:var(--paper);line-height:1.1}
.member p{font-size:.78rem;color:var(--muted-on-dark);margin-top:.3rem;line-height:1.4}
@media (max-width:980px){.roster__grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:520px){.roster__grid{grid-template-columns:repeat(2,1fr)}}

/* =====================================================================
   CONTACT / BOOKING
   ===================================================================== */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem)}
.contact__intro .lead{margin-top:1.4rem}
.contact__meta{margin-top:2.4rem;display:grid;gap:1.2rem}
.cmeta{display:flex;gap:1rem;align-items:flex-start}
.cmeta .ic{flex:none;width:42px;height:42px;border-radius:50%;border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;color:var(--accent)}
.cmeta .t{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-on-dark)}
.cmeta .v{font-size:1.02rem;font-weight:500}
.cmeta a:hover .v{color:var(--accent)}
.form{display:grid;gap:1.1rem}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field{position:relative;display:flex;flex-direction:column}
.field label{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-on-dark);margin-bottom:.5rem}
.field input,.field select,.field textarea{
  background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.22);
  color:var(--paper);padding:.7rem 0;font-family:inherit;font-size:1rem;border-radius:0;transition:border-color .4s}
.field textarea{resize:vertical;min-height:90px}
.field select option{color:#111}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent)}
.field input::placeholder,.field textarea::placeholder{color:rgba(255,255,255,.32)}
.consent{display:flex;gap:.7rem;align-items:flex-start;font-size:.82rem;color:var(--muted-on-dark)}
.consent input{margin-top:.2rem;accent-color:var(--accent);width:16px;height:16px;flex:none}
.consent a{color:var(--accent)}
.form__note{font-size:.78rem;color:var(--muted-on-dark)}
.form__ok{display:none;padding:1.4rem;border:1px solid var(--accent);border-radius:6px;color:var(--paper);background:rgba(225,252,33,.06)}
.form__ok.show{display:block}
.hp{position:absolute!important;left:-9999px;width:1px;height:1px;opacity:0;overflow:hidden;pointer-events:none}
.steps{display:grid;gap:1.1rem;margin-top:2.2rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.12)}
.steps__title{font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-on-dark);margin-bottom:.4rem}
.step{display:flex;gap:1rem;align-items:flex-start}
.step__n{flex:none;width:42px;height:42px;border-radius:50%;background:var(--accent);color:var(--ink);font-family:var(--f-display);font-weight:900;display:flex;align-items:center;justify-content:center;font-size:1.05rem}
.step h4{font-size:1rem;font-weight:700;color:var(--paper)}
.step p{font-size:.88rem;color:var(--muted-on-dark);margin-top:.15rem;max-width:42ch}
@media (max-width:820px){.contact{grid-template-columns:1fr}.form .row{grid-template-columns:1fr}}

/* =====================================================================
   LOCATION
   ===================================================================== */
.loc-head{margin-bottom:clamp(2rem,4vw,3rem)}
.location{display:grid;grid-template-columns:1fr 1fr;gap:0;border-radius:6px;overflow:hidden;border:1px solid var(--line)}
.location__info{padding:clamp(2rem,4vw,3.4rem);background:var(--paper)}
.location__info h3{font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:clamp(1.4rem,2.4vw,2rem);letter-spacing:-.01em}
.loc-addr{margin-top:1.6rem;display:grid;gap:1.6rem}
.loc-addr .a{display:grid;gap:.2rem}
.loc-addr .a h4{font-size:.74rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);margin-bottom:.3rem}
.loc-addr .a p{color:var(--muted);font-size:.95rem;line-height:1.5}
.loc-addr .a a:hover{color:var(--ink)}
.location__map{min-height:360px;position:relative;filter:grayscale(1) contrast(1.05);transition:filter .6s;background:var(--ink)}
.location:hover .location__map{filter:grayscale(0)}
.location__map iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.map-consent{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.05rem;text-align:center;padding:2.2rem;color:var(--paper);
  background:
    radial-gradient(120% 90% at 50% 0%,rgba(225,252,33,.08),transparent 60%),
    linear-gradient(180deg,#0d0d0c,#0a0a0a),
    repeating-linear-gradient(0deg,rgba(255,255,255,.045) 0 1px,transparent 1px 46px),
    repeating-linear-gradient(90deg,rgba(255,255,255,.045) 0 1px,transparent 1px 46px)}
.map-consent__pin{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--ink);background:var(--accent);box-shadow:0 0 0 8px rgba(225,252,33,.12),0 10px 30px rgba(0,0,0,.45);animation:mapPinFloat 3s var(--ease) infinite}
@keyframes mapPinFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@media (prefers-reduced-motion:reduce){.map-consent__pin{animation:none}}
.map-consent__title{font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:1.05rem;letter-spacing:.01em;color:var(--paper)}
.map-consent p{font-size:.85rem;color:var(--muted-on-dark);max-width:36ch;line-height:1.55;margin:0}
.map-consent a{font-size:.8rem;color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.map-consent a:hover{color:var(--paper)}
@media (max-width:760px){.location{grid-template-columns:1fr}}

/* =====================================================================
   FOOTER
   ===================================================================== */
.footer{background:var(--ink);color:var(--paper);padding-top:clamp(3.5rem,7vw,6rem)}
.footer__cta{text-align:center;padding-bottom:clamp(3rem,6vw,5rem);border-bottom:1px solid rgba(255,255,255,.1)}
.footer__cta h2{font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:clamp(2.2rem,7vw,5.5rem);line-height:.98;letter-spacing:-.02em}
.footer__cta p{color:var(--muted-on-dark);margin:1.2rem auto 2rem;max-width:48ch}
.footer__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.4rem;padding-block:clamp(2.5rem,5vw,4rem)}
.footer__brand img{height:32px;margin-bottom:1.1rem;width:auto;max-width:190px;object-fit:contain;object-position:left center}
.footer__brand img.fer{height:32px}
.footer__brand h5{font-size:.95rem;font-weight:700;margin-bottom:.6rem;color:var(--paper)}
.footer__brand p{color:var(--muted-on-dark);max-width:38ch;font-size:.88rem;line-height:1.6}
.footer__nav{display:flex;flex-wrap:wrap;gap:.4rem 1.4rem;padding-block:1.6rem;border-top:1px solid rgba(255,255,255,.1)}
.footer__nav a,.footer__nav button{font-size:.85rem;color:var(--paper);opacity:.8;transition:opacity .3s,color .3s}
.footer__nav a:hover,.footer__nav button:hover{opacity:1;color:var(--accent)}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;padding-block:1.8rem;border-top:1px solid rgba(255,255,255,.1);font-size:.8rem;color:var(--muted-on-dark)}
.footer__bottom a:hover{color:var(--accent)}
.socials{display:flex;gap:.8rem}
.socials a{width:38px;height:38px;border:1px solid rgba(255,255,255,.18);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .3s,color .3s,border-color .3s}
.socials a:hover{background:var(--accent);color:var(--ink);border-color:var(--accent)}
@media (max-width:860px){.footer__grid{grid-template-columns:1fr;gap:2.4rem}}

/* =====================================================================
   COOKIE
   ===================================================================== */
.cookie{position:fixed;left:20px;bottom:20px;max-width:380px;background:var(--ink);color:var(--paper);padding:1.6rem;border-radius:8px;z-index:130;box-shadow:0 24px 60px rgba(0,0,0,.4);transform:translateY(140%);transition:transform .6s var(--ease)}
.cookie.show{transform:none}
.cookie h4{font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:1.1rem;margin-bottom:.6rem}
.cookie p{font-size:.85rem;color:var(--muted-on-dark);margin-bottom:1.1rem}
.cookie p a{color:var(--accent)}
.cookie__btns{display:flex;gap:.7rem;flex-wrap:wrap}
.cookie__btns .btn{padding:.8em 1.3em;font-size:.72rem}
.cookie .btn--mini{background:transparent;color:var(--paper);border:1px solid rgba(255,255,255,.3)}
.cookie .btn--mini::after{background:var(--accent)}
@media (max-width:480px){.cookie{left:12px;right:12px;bottom:12px;max-width:none}}

/* =====================================================================
   LEGAL pages
   ===================================================================== */
.legal{padding-top:calc(var(--nav-h) + 40px);padding-bottom:80px;min-height:70vh}
.legal h1{font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:clamp(2rem,5vw,3.4rem);margin-bottom:2rem;letter-spacing:-.01em}
.legal h2{font-size:1.3rem;font-weight:700;margin:2.2rem 0 .8rem}
.legal h3{font-size:1.05rem;font-weight:700;margin:1.4rem 0 .5rem}
.legal p,.legal li,.legal address{color:var(--ink-soft);max-width:80ch;margin-bottom:.8rem;font-style:normal}
.legal ul{list-style:disc;padding-left:1.3rem;margin-bottom:1rem}
.legal a{color:#3b6b1f;text-decoration:underline}
.legal .back{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:2rem;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--ink)}
.legal .muted-note{background:var(--paper-2);border-left:3px solid var(--accent);padding:1rem 1.2rem;font-size:.9rem;border-radius:0 4px 4px 0}
.legal .lead-sub{color:var(--muted);margin-bottom:2.4rem;max-width:70ch}

/* utility */
.center{text-align:center}
.mt-2{margin-top:2rem}
.nowrap{white-space:nowrap}

/* =====================================================================
   ★ PREMIUM LAYER — overrides & new components
   ===================================================================== */
:root{
  --sand:#e7dec9;
  --olive:#586b3f;
  --warm:#bda87f;          /* muted gold — secondary accent */
  --paper-3:#efece2;
  --hair:rgba(10,10,10,.10);
  --hair-d:rgba(255,255,255,.12);
}

/* subtle film grain for depth (very light, no perf cost) */
body::after{
  content:"";position:fixed;inset:0;z-index:9;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
@media (prefers-reduced-motion:reduce){body::after{display:none}}

/* refined section eyebrow with index feel */
.eyebrow{gap:.8em}
.eyebrow::before{width:34px;background:linear-gradient(90deg,var(--accent),var(--warm))}
.section--dark .eyebrow::before{background:linear-gradient(90deg,var(--accent),var(--warm))}

/* hero kicker polish */
.hero__sub{background:linear-gradient(90deg,var(--accent),#eaffa0);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* ---------- SERVICES — editorial redesign ---------- */
.svc-grid{gap:clamp(1rem,1.7vw,1.5rem)}
.svc{
  border:1px solid var(--hair-d);border-radius:12px;
  padding:clamp(1.9rem,2.6vw,2.5rem) clamp(1.6rem,2.4vw,2.2rem) clamp(2.1rem,2.8vw,2.7rem);
  background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,0));
  position:relative;overflow:hidden;transition:border-color .5s var(--ease),transform .5s var(--ease),background .5s var(--ease)
}
.svc::before{
  content:"";position:absolute;left:0;top:0;height:3px;width:100%;
  background:linear-gradient(90deg,var(--accent),var(--warm));transform:scaleX(0);transform-origin:left;transition:transform .55s var(--ease)
}
.svc:hover{transform:translateY(-6px);border-color:rgba(255,255,255,.28);background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.01))}
.svc:hover::before{transform:scaleX(1)}
.svc__num{
  position:absolute;top:.8rem;right:1.2rem;font-family:var(--f-display);font-weight:900;font-size:3.4rem;line-height:1;
  color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.16);transition:-webkit-text-stroke .5s,color .5s
}
.svc:hover .svc__num{-webkit-text-stroke:1px rgba(225,252,33,.5)}
.svc h3{font-size:clamp(1.3rem,1.9vw,1.65rem);margin:.3rem 0 1.2rem;max-width:14ch}
.svc__list li{font-size:.93rem;color:#dcdad1}
.svc__list li::before{background:linear-gradient(180deg,var(--accent),var(--warm))}
.svc__cta-row{margin-top:clamp(2.4rem,4vw,3.4rem);display:flex;justify-content:center}

/* ---------- RESULTS / STATS band ---------- */
.stats{
  margin-top:clamp(2.6rem,5vw,4rem);padding-top:clamp(2.2rem,4vw,3rem);
  border-top:1px solid var(--hair-d);
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem
}
.stat{position:relative;padding-left:1.4rem}
.stat::before{content:"";position:absolute;left:0;top:.35rem;bottom:.35rem;width:2px;background:linear-gradient(180deg,var(--accent),var(--warm))}
.stat__num{font-family:var(--f-display);font-weight:900;font-size:clamp(2.4rem,4.4vw,3.6rem);line-height:1;letter-spacing:-.02em;color:var(--paper)}
.stat__num .u{color:var(--accent)}
.stat__lbl{margin-top:.6rem;font-size:.74rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-on-dark);line-height:1.3}
@media (max-width:760px){.stats{grid-template-columns:1fr 1fr;gap:1.6rem 1.2rem}}

/* ---------- TESTIMONIALS — premium ---------- */
/* WCAG AA: darker muted text on warm backgrounds (sand / paper2) */
#testimonials,.section--paper2{--muted:#5e5a52}
#testimonials{background:var(--sand)}
.tst{border:1px solid rgba(10,10,10,.1);border-radius:14px;padding:clamp(2rem,3.2vw,2.9rem);background:var(--paper);position:relative;overflow:hidden}
.tst::before{content:"\201C";position:absolute;top:.4rem;right:1.6rem;font-family:Georgia,"Times New Roman",serif;font-size:6rem;line-height:1;color:var(--warm);opacity:.32;pointer-events:none}
.tst::after{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--accent),var(--warm));opacity:0;transition:opacity .5s var(--ease)}
.tst:hover::after{opacity:1}
.tst__top{border-color:var(--hair)}
.tst__num{-webkit-text-stroke:0;color:var(--olive)}
.tst__company{letter-spacing:-.01em}
.tst__quote{color:#2b2a25;font-weight:300;font-size:1.02rem}

/* ---------- TEAM — refined monogram + roster ---------- */
.member__ph{border-radius:8px;border:1px solid rgba(255,255,255,.08)}
.member__ph img{filter:grayscale(1) contrast(1.04)}
.member:hover .member__ph img{filter:grayscale(0) contrast(1)}
.member__mono{
  background:radial-gradient(120% 120% at 30% 20%,#26261f,#141410);
  color:var(--paper);font-size:2rem;letter-spacing:.04em;flex-direction:column;gap:.5rem
}
.member__mono::after{content:"";width:26px;height:2px;background:linear-gradient(90deg,var(--accent),var(--warm))}
.member h4{font-size:.92rem;margin-top:1rem}
.roster__grid{gap:clamp(.8rem,1.5vw,1.3rem)}

/* ---------- VISION badge / options polish ---------- */
.vision__media .badge{background:linear-gradient(90deg,var(--accent),#eaffa0)}
.option{border-radius:10px}
.option:hover{box-shadow:0 18px 44px rgba(10,10,10,.08)}
.team__media .badge{background:linear-gradient(90deg,var(--accent),#eaffa0)}

/* ---------- PROJECTS — premium framing ---------- */
.proj{border-radius:12px}
.proj__media{border-radius:12px 12px 0 0}
.proj__title{letter-spacing:-.01em}
.proj__bar{padding:1.05rem 1.15rem 1.2rem}
.section .proj__bar{background:var(--paper-3)}

/* ---------- buttons: premium sheen ---------- */
.btn{box-shadow:0 1px 0 rgba(10,10,10,.04)}
.btn--lg{letter-spacing:.18em}

/* ---------- FAQ (AEO) — native details ---------- */
.faq{max-width:880px;margin:0 auto}
.faq__head{text-align:center;margin-bottom:clamp(2rem,4vw,3rem)}
.faq details{border-bottom:1px solid var(--line)}
.faq details:first-of-type{border-top:1px solid var(--line)}
.faq summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;padding:1.45rem 0;font-size:clamp(1rem,1.5vw,1.18rem);font-weight:500;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary .ic{flex:none;width:28px;height:28px;border-radius:50%;border:1px solid var(--line);position:relative;transition:background .4s var(--ease),border-color .4s}
.faq summary .ic::before,.faq summary .ic::after{content:"";position:absolute;background:var(--ink);left:50%;top:50%;transition:transform .35s var(--ease)}
.faq summary .ic::before{width:2px;height:12px;transform:translate(-50%,-50%)}
.faq summary .ic::after{width:12px;height:2px;transform:translate(-50%,-50%)}
.faq details[open] summary .ic{background:var(--accent);border-color:var(--accent)}
.faq details[open] summary .ic::before{transform:translate(-50%,-50%) scaleY(0)}
.faq__a{padding:0 0 1.5rem;color:var(--muted);max-width:74ch;font-size:.98rem;line-height:1.6}

/* section tone rhythm */
.section--sand{background:var(--sand)}
.footer__cta h2{background:linear-gradient(180deg,var(--paper),#cfcdc4);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}


/* ---------- PROJECTS — no dark gap under tiles (uniform cards) ---------- */
#projects .proj{background:var(--paper-3);display:flex;flex-direction:column}
#projects .proj__media{flex:none}
#projects .proj__bar{flex:1 1 auto;align-items:center}

/* ---------- TEAM — intro aside + person slider ---------- */
.team-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.team-aside{position:sticky;top:104px}
.team-aside .lead{margin-top:1.4rem;max-width:42ch}

.tm{position:relative;min-width:0}
.tm__viewport{overflow:hidden}
.tm__track{display:flex;transition:transform .6s var(--ease);will-change:transform}
.tm__slide{flex:0 0 100%;min-width:100%;display:grid;grid-template-columns:1fr 280px;gap:clamp(1.6rem,3vw,2.8rem);align-items:start}
.tm__bio{display:grid;gap:1rem;color:var(--muted-on-dark);font-size:.96rem;line-height:1.75}
.tm__bio p{margin:0}
.tm__bio p:first-child{color:var(--paper);font-size:1.02rem}
.tm__figure{display:flex;flex-direction:column;gap:1rem}
.tm__photo{aspect-ratio:3/4;overflow:hidden;border-radius:10px;background:#1d1d1a}
.tm__photo img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.03)}
.tm__id{display:flex;flex-direction:column;gap:.35rem;border-left:2px solid var(--accent);padding-left:.9rem}
.tm__name{font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:1rem;letter-spacing:-.005em;color:var(--paper);line-height:1.1}
.tm__short{margin:0;font-size:.85rem;color:var(--muted-on-dark);line-height:1.5;font-style:italic}
.tm__controls{display:flex;align-items:center;gap:1.1rem;margin-top:2rem}
.tm__arrow{flex:none;width:52px;height:52px;border-radius:50%;border:1px solid rgba(255,255,255,.18);background:transparent;color:var(--paper);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .35s var(--ease),color .35s,border-color .35s,transform .35s}
.tm__arrow:hover{background:var(--accent);color:var(--ink);border-color:var(--accent);transform:translateY(-2px)}
.tm__dots{display:flex;gap:.55rem;flex:1;flex-wrap:wrap}
.tm__dot{width:9px;height:9px;border-radius:50%;border:0;padding:0;background:rgba(255,255,255,.22);cursor:pointer;transition:background .35s,transform .35s}
.tm__dot.is-active{background:var(--accent);transform:scale(1.25)}
.tm:focus-visible{outline:2px solid var(--accent);outline-offset:6px;border-radius:4px}
@media (max-width:920px){
  .team-grid{grid-template-columns:1fr;gap:clamp(2rem,5vw,3rem)}
  .team-aside{position:static}
  .team-aside .lead{max-width:none}
}
@media (max-width:640px){
  .tm__slide{grid-template-columns:1fr;gap:1.4rem}
  .tm__figure{flex-direction:row;align-items:flex-start;gap:1.1rem;order:-1}
  .tm__photo{flex:none;width:128px}
  .tm__id{flex:1}
  .tm__arrow{width:46px;height:46px}
}
@media (max-width:420px){
  .tm__figure{flex-direction:column}
  .tm__photo{width:100%;max-width:220px}
}
