/* ============================================================
   Goldt Concept GmbH — Stylesheet
   ============================================================ */

/* --- Reset --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
img{max-width:100%;display:block}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
a{color:inherit}
:focus-visible{outline:2px solid var(--brand);outline-offset:3px}

/* --- Tokens --- */
:root{
  --black:#1A1511;          /* warmes Tiefbraun-Schwarz */
  --ink:#221C16;
  --ink2:#2C251D;
  --ink3:#382F25;
  --paper:#F1EADC;          /* warmes Creme */
  --paper2:#E4D9C6;
  --white:#F3ECE0;          /* warmes Off-White */
  --brand:#A6957C;          /* warmes Taupe — Markenakzent, modern-klassisch */
  --brand-lt:#C8BBA3;
  --brand-dk:#7C6D58;
  --muted:#766A5A;
  --muted-lt:#9C8F7C;
  --line:rgba(243,236,224,.10);
  --line-dk:rgba(26,21,17,.13);
  --serif:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --sans:'DM Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --gap:clamp(20px,5vw,60px);
  --shell:clamp(20px,5vw,72px);
}

/* --- Base --- */
body{
  font-family:var(--sans);
  background:var(--black);
  color:var(--white);
  font-weight:300;
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
body.no-scroll{overflow:hidden}

h1,h2,h3{font-family:var(--serif);font-weight:300;line-height:1.08}
::selection{background:var(--brand);color:var(--black)}

/* --- Utility / shared --- */
.shell{max-width:1380px;margin:0 auto;padding-left:var(--shell);padding-right:var(--shell)}
section{padding:clamp(64px,9vw,128px) 0}

.eyebrow{
  font-size:11px;font-weight:500;letter-spacing:.26em;text-transform:uppercase;
  color:var(--brand-lt);display:flex;align-items:center;gap:14px;margin-bottom:20px;
}
.eyebrow::before{content:'';width:30px;height:1px;background:var(--brand);flex-shrink:0}
.eyebrow.center{justify-content:center}
.leistungen .eyebrow,.referenzen .eyebrow{color:#6B6055}

h2{font-size:clamp(32px,4.6vw,62px)}
h2 em{font-style:italic;color:var(--brand-lt)}
h2.on-light{color:var(--black)}

.lead{font-size:clamp(15px,1.5vw,17px);color:rgba(243,236,224,.62);line-height:1.8;max-width:56ch}

.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:32px;margin-bottom:clamp(40px,6vw,76px);flex-wrap:wrap}

.link-arrow{
  font-size:12px;letter-spacing:.13em;text-transform:uppercase;text-decoration:none;
  color:var(--brand);display:inline-flex;align-items:center;gap:10px;
  padding-bottom:5px;border-bottom:1px solid rgba(166,149,124,.4);
  transition:gap .3s,color .3s;white-space:nowrap;
}
.link-arrow:hover{gap:16px;color:var(--brand-lt)}
.leistungen .link-arrow,.referenzen .link-arrow{color:#6B6055;border-color:rgba(26,21,17,.25)}
.leistungen .link-arrow:hover,.referenzen .link-arrow:hover{color:var(--black)}

/* --- Buttons --- */
.btn{
  display:inline-flex;align-items:center;gap:11px;
  font-size:12px;font-weight:500;letter-spacing:.13em;text-transform:uppercase;
  text-decoration:none;padding:16px 34px;transition:.3s;border:1px solid transparent;
}
.btn svg{transition:transform .3s}
.btn:hover svg{transform:translateX(4px)}
.btn-primary{background:var(--brand);color:var(--black)}
.btn-primary:hover{background:var(--brand-lt);transform:translateY(-2px)}
.btn-outline{border-color:var(--brand);color:var(--brand-lt)}
.btn-outline:hover{background:var(--brand);color:var(--black)}
.btn-ghost{padding:16px 0;color:rgba(243,236,224,.72)}
.btn-ghost:hover{color:var(--white)}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:90;
  display:flex;align-items:center;justify-content:space-between;
  padding:24px var(--shell);transition:background .4s,padding .4s,border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(26,21,17,.94);backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);padding:13px var(--shell);
  border-bottom-color:var(--line);
}
.nav__logo{display:flex;align-items:center;text-decoration:none}
.nav__logo img{height:34px;width:auto;filter:invert(1) brightness(.92);transition:height .4s}
.nav.scrolled .nav__logo img{height:28px}

.nav__right{display:flex;align-items:center;gap:clamp(16px,2.6vw,34px)}
.nav__lang{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:500;letter-spacing:.06em}
.nav__lang-on{color:var(--white)}
.nav__lang-sep{color:var(--muted)}
.nav__lang a{color:var(--muted-lt);text-decoration:none;transition:color .3s}
.nav__lang a:hover{color:var(--white)}

.nav__links{display:flex;align-items:center;gap:clamp(20px,3vw,42px);list-style:none}
.nav__links a{
  font-size:12px;font-weight:400;letter-spacing:.13em;text-transform:uppercase;
  color:var(--muted-lt);text-decoration:none;position:relative;padding:4px 0;transition:color .3s;
}
.nav__links a::after{
  content:'';position:absolute;left:0;bottom:0;height:1px;width:0;
  background:var(--brand);transition:width .35s ease;
}
.nav__links a:hover,.nav__links a.active{color:var(--white)}
.nav__links a:hover::after,.nav__links a.active::after{width:100%}
.nav__links a.nav__cta{
  display:inline-block;border:1px solid var(--brand);color:var(--brand-lt)!important;
  padding:12px 28px;text-indent:.13em;transition:background .3s,color .3s!important;
}
.nav__links a.nav__cta::after{display:none}
.nav__links a.nav__cta:hover{background:var(--brand);color:var(--black)!important}

/* burger */
.nav__burger{display:none;width:30px;height:22px;position:relative;z-index:101}
.nav__burger span{
  position:absolute;left:0;height:1.5px;width:100%;background:var(--white);
  transition:transform .35s,opacity .25s,top .35s;
}
.nav__burger span:nth-child(1){top:2px}
.nav__burger span:nth-child(2){top:10px}
.nav__burger span:nth-child(3){top:18px}
.nav.open .nav__burger span:nth-child(1){top:10px;transform:rotate(45deg)}
.nav.open .nav__burger span:nth-child(2){opacity:0}
.nav.open .nav__burger span:nth-child(3){top:10px;transform:rotate(-45deg)}

/* --- Skip link --- */
.skip{
  position:absolute;left:50%;top:-60px;transform:translateX(-50%);
  background:var(--brand);color:var(--black);padding:10px 20px;font-size:13px;
  z-index:200;transition:top .3s;
}
.skip:focus{top:10px}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100vh;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden}
.hero__slider{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero__track{display:flex;height:100%;transition:transform 1s cubic-bezier(.65,0,.35,1)}
.hero__slide{flex:0 0 100%;height:100%;overflow:hidden}
.hero__slide img{width:100%;height:100%;object-fit:cover;filter:sepia(14%) saturate(.94)}
.hero__overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(155deg,rgba(26,21,17,.85) 0%,rgba(26,21,17,.55) 40%,rgba(26,21,17,.97) 100%);
}
.hero__inner{position:relative;z-index:2;width:100%;padding-top:140px;padding-bottom:clamp(72px,11vh,128px)}
.hero__content{max-width:880px;animation:fade-up 1.1s cubic-bezier(.22,.61,.36,1) .25s both}
.hero h1{
  font-size:clamp(46px,7.6vw,104px);margin:8px 0 26px;letter-spacing:-.01em;
  font-weight:400;text-shadow:0 2px 28px rgba(26,21,17,.55),0 1px 3px rgba(26,21,17,.5);
}
.hero h1 em{font-style:italic;color:var(--brand-lt)}
.hero__sub{
  font-size:clamp(15px,1.6vw,18px);color:rgba(243,236,224,.95);font-weight:400;
  line-height:1.8;max-width:54ch;margin-bottom:0;text-shadow:0 1px 14px rgba(26,21,17,.65);
}
.hero__dots{display:flex;gap:11px;margin-top:38px}
.hero__dot{width:9px;height:9px;border-radius:50%;background:rgba(243,236,224,.28);cursor:pointer;padding:0;transition:background .3s,transform .3s}
.hero__dot:hover{background:rgba(243,236,224,.6)}
.hero__dot.is-active{background:var(--brand);transform:scale(1.18)}
.hero__scroll{
  position:absolute;right:var(--shell);bottom:clamp(72px,11vh,128px);z-index:2;
  writing-mode:vertical-rl;font-size:10px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--muted-lt);display:flex;align-items:center;gap:14px;
  animation:fade-up 1s ease-out 1s both;
}
.hero__scroll::after{content:'';width:1px;height:64px;background:linear-gradient(var(--brand),transparent)}
.hero .eyebrow{text-shadow:0 1px 10px rgba(26,21,17,.6)}
.hero__caption{position:absolute;right:var(--shell);bottom:clamp(26px,4vh,42px);z-index:3;display:flex;align-items:center;gap:10px;font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--brand-lt);text-shadow:0 1px 10px rgba(26,21,17,.75);transition:opacity .35s ease}
.hero__caption::before{content:'';width:22px;height:1px;background:var(--brand)}

/* ============================================================
   STATS
   ============================================================ */
.stats{background:var(--ink);border-block:1px solid var(--line)}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line)}
.stat{background:var(--ink);padding:clamp(34px,4vw,52px) clamp(20px,3vw,40px)}
.stat__num{
  font-family:var(--serif);font-size:clamp(40px,5vw,62px);line-height:1;
  color:var(--white);margin-bottom:10px;
}
.stat__num span{color:var(--brand-lt)}
.stat__label{font-size:11px;font-weight:400;letter-spacing:.15em;text-transform:uppercase;color:var(--muted-lt)}

/* ============================================================
   LEISTUNGEN
   ============================================================ */
.leistungen{background:var(--paper);color:var(--black)}
.leistungen .lead,.referenzen .lead{color:#564D42}
.leist-body{display:grid;grid-template-columns:1.85fr 1fr;gap:clamp(16px,1.8vw,26px);align-items:stretch}
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line-dk);border:1px solid var(--line-dk)}
.leist-photo{position:relative;min-height:380px}
.leist-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:sepia(12%) saturate(.96)}
.card{
  background:var(--paper);padding:clamp(34px,3.4vw,52px);position:relative;overflow:hidden;
  transition:background .4s;
}
.card::after{content:'';position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--brand);transition:width .45s ease}
.card:hover{background:var(--paper2)}
.card:hover::after{width:100%}
.card__num{
  font-family:var(--serif);font-size:78px;line-height:1;color:rgba(26,21,17,.07);
  margin-bottom:-26px;
}
.card__icon{width:38px;height:38px;color:var(--brand-dk);margin-bottom:22px;transition:color .4s}
.card:hover .card__icon{color:var(--brand)}
.card h3{font-size:26px;color:var(--black);margin-bottom:14px;transform-origin:left top;transition:transform .3s ease}
.card:hover h3,.card:focus-within h3{transform:scale(1.05)}
.card__text{font-size:14.5px;color:#5E5448;line-height:1.75}
.card__list{list-style:none;margin-top:24px}
.card__list li{
  font-size:13px;color:#5E5448;padding:9px 0;display:flex;gap:12px;align-items:flex-start;
  border-bottom:1px solid rgba(26,21,17,.09);
}
.card__list li::before{content:'';width:4px;height:4px;margin-top:8px;background:var(--brand);flex-shrink:0}

/* ============================================================
   ÜBER UNS
   ============================================================ */
.about{background:var(--black)}
.about__grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(40px,7vw,100px);align-items:center}
.about__visual{position:relative}
.about__media{position:relative;overflow:hidden;aspect-ratio:4/5}
.about__media img{position:absolute;left:0;top:-11%;width:100%;height:122%;object-fit:cover;object-position:center;will-change:transform}
.about__frame{position:absolute;right:-24px;bottom:-24px;width:48%;height:46%;border:1px solid rgba(166,149,124,.3);z-index:-1}
/* Wiederkehrendes Rahmen-Element hinter Fotos */
.media-frame{position:absolute;right:-24px;bottom:-24px;width:48%;height:46%;border:1px solid rgba(166,149,124,.34);z-index:-1;pointer-events:none}
.media-frame.fr-light{border-color:rgba(26,21,17,.2)}
.about__badge{
  position:absolute;left:-30px;top:40px;background:var(--brand);color:var(--black);
  padding:22px 26px;font-family:var(--serif);
}
.about__badge b{display:block;font-size:38px;font-weight:300;line-height:1}
.about__badge span{font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;font-family:var(--sans)}
.about__text p+p{margin-top:18px}
.quote{
  border-left:2px solid var(--brand);padding:6px 0 6px 26px;margin:32px 0;
  font-family:var(--serif);font-size:clamp(20px,2.2vw,26px);font-style:italic;
  color:var(--white);line-height:1.4;
}

/* ============================================================
   PROZESS
   ============================================================ */
.prozess{background:var(--ink)}
.proz-head{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(32px,5vw,72px);align-items:center;margin-bottom:clamp(38px,5vw,66px)}
.proz-photo{position:relative;aspect-ratio:16/10}
.proz-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(28%) sepia(20%)}
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;align-items:stretch}
.step{background:var(--ink2);padding:clamp(26px,2.5vw,34px) clamp(20px,2vw,28px);border-top:2px solid transparent;transition:background .35s,border-color .35s;cursor:pointer;position:relative;display:flex;flex-direction:column}
.step:hover,.step.open,.step:focus-visible{background:var(--ink3);border-top-color:var(--brand)}
.step__num{
  font-family:var(--serif);font-size:16px;color:var(--brand);
  padding-bottom:14px;margin-bottom:20px;border-bottom:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:baseline;
  transform-origin:left top;transition:transform .3s ease;
}
.step__num b{font-weight:300}
.step h3{font-size:clamp(20px,1.9vw,24px);color:var(--white);margin-bottom:0;line-height:1.18;min-height:2.36em;transform-origin:left top;transition:transform .3s ease}
.step:hover h3,.step.open h3,.step:focus-visible h3{transform:scale(1.07)}
.step:hover .step__num,.step.open .step__num,.step:focus-visible .step__num{transform:scale(1.06)}
.step__keys{list-style:none;margin-top:18px;display:flex;flex-direction:column;gap:9px}
.step__keys li{font-size:12.5px;color:var(--muted-lt);line-height:1.4;display:flex;gap:10px;align-items:center}
.step__keys li::before{content:'';width:5px;height:5px;background:var(--brand);flex-shrink:0}
.step__text{font-size:12.5px;color:var(--muted-lt);line-height:1.66;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.step__toggle{display:inline-flex;align-self:flex-start;align-items:center;gap:8px;margin-top:auto;padding-top:20px;font-size:10px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--brand);transition:color .3s}
.step__toggle svg{transition:transform .35s ease}
.step:hover .step__toggle{color:var(--brand-lt)}
.step.open .step__toggle svg{transform:rotate(180deg)}
.step__detail{display:grid;grid-template-rows:0fr;transition:grid-template-rows .42s ease}
.step.open .step__detail{grid-template-rows:1fr}
.step__detail-inner{overflow:hidden}

/* ============================================================
   BILD-BAND
   ============================================================ */
.band{position:relative;min-height:clamp(360px,52vh,560px);display:flex;align-items:center;overflow:hidden}
.band__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(45%) sepia(30%)}
.band__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,21,17,.74),rgba(26,21,17,.58))}
.band__inner{position:relative;z-index:2;width:100%;text-align:center}
.band__statement{font-family:var(--serif);font-size:clamp(27px,4.2vw,54px);font-weight:300;color:var(--white);line-height:1.18;margin-top:10px}
.band__statement em{font-style:italic;color:var(--brand-lt)}

/* ============================================================
   REFERENZEN
   ============================================================ */
.referenzen{background:var(--paper);color:var(--black)}
.proj-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,1.8vw,26px)}
.proj{
  grid-column:span 2;background:#FBF6EC;border:1px solid var(--line-dk);
  display:flex;flex-direction:column;overflow:hidden;cursor:pointer;
  transition:transform .4s cubic-bezier(.22,.61,.36,1),box-shadow .4s;
}
.proj:hover{transform:translateY(-6px);box-shadow:0 24px 50px -24px rgba(26,21,17,.4)}
.proj.open{box-shadow:0 24px 50px -24px rgba(26,21,17,.35)}
.proj__media{position:relative;overflow:hidden;aspect-ratio:16/10}
.proj__media img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(58%) sepia(30%) contrast(1.03);transition:transform .7s ease,filter .6s ease;
}
.proj:hover .proj__media img,.proj.open .proj__media img{transform:scale(1.05);filter:grayscale(0%) sepia(0%) contrast(1.03)}
.proj__tag{
  position:absolute;left:16px;top:16px;background:rgba(26,21,17,.82);
  color:var(--brand-lt);font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  padding:7px 13px;backdrop-filter:blur(4px);
}
.proj__body{padding:clamp(22px,2.4vw,32px);display:flex;flex-direction:column;flex:1}
.proj__type{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--brand-dk);margin-bottom:8px}
.proj h3{font-size:clamp(22px,2.4vw,28px);color:var(--black);margin-bottom:6px}
.proj__loc{font-size:13.5px;color:#867A6A;margin-bottom:20px}
.proj__data{list-style:none;margin-top:auto;border-top:1px solid var(--line-dk)}
.proj__data > div{
  display:flex;justify-content:space-between;gap:16px;padding:10px 0;
  font-size:13px;border-bottom:1px solid rgba(26,21,17,.07);
}
.proj__data > div:last-child{border-bottom:none}
.proj__data dt{color:#8B7F6D;letter-spacing:.04em}
.proj__data dd{color:var(--black);font-weight:400;text-align:right}
.proj__toggle{display:inline-flex;align-items:center;gap:8px;margin-top:18px;font-size:10px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--brand-dk);transition:color .3s}
.proj__toggle svg{transition:transform .35s ease}
.proj:hover .proj__toggle,.proj.open .proj__toggle{color:var(--black)}
.proj.open .proj__toggle svg{transform:rotate(180deg)}
.proj__detail{display:grid;grid-template-rows:0fr;transition:grid-template-rows .42s ease}
.proj.open .proj__detail{grid-template-rows:1fr}
.proj__detail-inner{overflow:hidden}
.proj__story{margin-top:16px;padding-top:16px;border-top:1px solid var(--line-dk);font-size:13.5px;color:#5E5448;line-height:1.75}
.proj__facts{list-style:none;margin-top:12px;display:flex;flex-direction:column;gap:8px}
.proj__facts li{font-size:13px;color:#5E5448;line-height:1.6;display:flex;gap:10px}
.proj__facts li::before{content:'';width:4px;height:4px;margin-top:7px;background:var(--brand);flex-shrink:0}
.proj__facts b{color:var(--black);font-weight:500}
.proj--more{display:none}
.proj-grid.show-more .proj--more{display:flex}
.proj-more__icon{transition:transform .35s ease}
.proj-more[aria-expanded="true"] .proj-more__icon{transform:rotate(180deg)}

/* ============================================================
   TEAM
   ============================================================ */
.team{background:var(--black)}
.team__grid{display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(40px,6vw,80px);align-items:center}
.team__photo{position:relative}
.team__photo img{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:center}
.team__name{
  background:var(--brand);color:var(--black);padding:17px 24px;
  display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
}
.team__name b{font-family:var(--serif);font-size:21px;font-weight:400}
.team__name span{font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase}
.team__bio{
  font-family:var(--serif);font-size:clamp(22px,2.5vw,30px);font-style:italic;
  font-weight:300;line-height:1.35;color:var(--white);margin:14px 0 26px;
}
.team__text{font-size:15px;color:rgba(243,236,224,.62);line-height:1.8}
.team__text+.team__text{margin-top:14px}
.creds{margin-top:28px;list-style:none}
.creds li{
  display:flex;gap:14px;align-items:flex-start;padding:13px 0;
  font-size:13.5px;color:var(--muted-lt);border-bottom:1px solid var(--line);
}
.creds li::before{content:'';width:5px;height:5px;margin-top:7px;background:var(--brand);flex-shrink:0}

/* ============================================================
   KONTAKT
   ============================================================ */
.kontakt{background:var(--ink2)}
.kontakt__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:start}
.kontakt h2{margin-bottom:22px}
.kontakt h2 em{font-style:italic;color:var(--brand-lt)}
.kontakt__lead{margin-bottom:22px}
.kontakt__assure{display:flex;flex-wrap:wrap;gap:9px 22px;list-style:none;margin-bottom:44px}
.kontakt__assure li{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:500;letter-spacing:.13em;text-transform:uppercase;color:var(--brand-lt)}
.kontakt__assure li::before{content:'✓';color:var(--brand);font-size:12px;font-weight:600}
.contact-list{list-style:none}
.contact-list li{display:flex;gap:16px;padding:17px 0;border-bottom:1px solid var(--line)}
.contact-list svg{width:18px;height:18px;color:var(--brand);flex-shrink:0;margin-top:3px}
.contact-list .lbl{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:5px}
.contact-list .val{font-size:14.5px;color:var(--white)}
.contact-list a{color:var(--white);text-decoration:none;transition:color .3s}
.contact-list a:hover{color:var(--brand-lt)}

.form{display:flex;flex-direction:column;gap:18px;background:var(--ink);padding:clamp(26px,3vw,42px);border:1px solid var(--line)}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-lt)}
.field input,.field select,.field textarea{
  width:100%;background:rgba(243,236,224,.04);border:1px solid var(--line);
  color:var(--white);font-family:var(--sans);font-size:14px;font-weight:300;
  padding:13px 16px;transition:border-color .3s,background .3s;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--brand);background:rgba(243,236,224,.06);
}
.field textarea{resize:vertical;min-height:120px}
.field select option{background:var(--ink)}
.form__check{display:flex;gap:11px;align-items:flex-start;font-size:12.5px;color:var(--muted-lt);line-height:1.6}
.form__check input{width:16px;height:16px;margin-top:2px;accent-color:var(--brand);flex-shrink:0}
.form__check a{color:var(--brand-lt)}
.form__note{font-size:12px;color:var(--muted)}
.form__status{font-size:13.5px;padding:13px 16px;display:none;border:1px solid var(--brand)}
.form__status.show{display:block}
.form__status.ok{background:rgba(166,149,124,.12);color:var(--brand-lt)}
.form__status.err{background:rgba(168,86,66,.15);border-color:#A85642;color:#E2BAAC}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--black);border-top:1px solid var(--line);padding:clamp(48px,6vw,72px) 0 32px}
.footer__top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:clamp(28px,4vw,56px);margin-bottom:44px}
.footer__logo img{height:30px;filter:invert(1) brightness(.88);margin-bottom:18px}
.footer__about{font-size:13.5px;color:var(--muted-lt);line-height:1.75;max-width:34ch}
.footer__col h4{
  font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:.2em;
  text-transform:uppercase;color:var(--brand-lt);margin-bottom:16px;
}
.footer__col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer__col a{font-size:13.5px;color:var(--muted-lt);text-decoration:none;transition:color .3s}
.footer__col a:hover{color:var(--white)}
.footer__bottom{
  display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;
  padding-top:26px;border-top:1px solid var(--line);
  font-size:12px;color:var(--muted);
}
.footer__bottom nav{display:flex;gap:24px}
.footer__bottom a{color:var(--muted);text-decoration:none;transition:color .3s}
.footer__bottom a:hover{color:var(--white)}

/* ============================================================
   LEGAL PAGES
   ============================================================ */
.legal{padding-top:160px;padding-bottom:100px;background:var(--black);min-height:80vh}
.legal h1{font-size:clamp(36px,5vw,58px);margin-bottom:14px}
.legal__intro{color:var(--muted-lt);margin-bottom:48px;font-size:15px}
.legal h2{font-size:clamp(22px,2.6vw,30px);margin:44px 0 14px;color:var(--white)}
.legal h3{font-family:var(--sans);font-size:15px;font-weight:500;color:var(--brand-lt);margin:24px 0 6px}
.legal p,.legal li{font-size:14.5px;color:rgba(243,236,224,.66);line-height:1.8}
.legal p{margin-bottom:12px}
.legal ul{margin:8px 0 12px 22px}
.legal li{margin-bottom:5px}
.legal a{color:var(--brand-lt)}
.legal .back{
  display:inline-flex;align-items:center;gap:9px;margin-top:48px;
  font-size:12px;letter-spacing:.13em;text-transform:uppercase;color:var(--brand);
  text-decoration:none;
}
.legal .back:hover{color:var(--brand-lt)}

/* ============================================================
   ANIMATION / REVEAL
   ============================================================ */
@keyframes fade-up{from{opacity:0;transform:translateY(34px)}to{opacity:1;transform:translateY(0)}}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s ease,transform .9s cubic-bezier(.22,.61,.36,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal[data-delay="1"]{transition-delay:.1s}
.reveal[data-delay="2"]{transition-delay:.2s}
.reveal[data-delay="3"]{transition-delay:.3s}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;animation-iteration-count:1!important;
    transition-duration:.01ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1080px){
  .stats__grid{grid-template-columns:repeat(2,1fr)}
  .leist-body{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .leist-photo{min-height:0;aspect-ratio:16/9}
  .proz-head{grid-template-columns:1fr;gap:36px}
  .about__grid,.team__grid,.kontakt__grid{grid-template-columns:1fr}
  .about__grid{gap:64px}
  .about__visual{max-width:440px}
  .steps{grid-template-columns:repeat(2,1fr)}
  .proj-grid{grid-template-columns:repeat(2,1fr)}
  .proj{grid-column:span 1}
  .footer__top{grid-template-columns:1fr 1fr}
  .team__photo{max-width:440px}
}

@media(max-width:760px){
  .nav__links{
    position:fixed;inset:0;flex-direction:column;justify-content:center;gap:30px;
    background:rgba(26,21,17,.98);backdrop-filter:blur(10px);
    transform:translateX(100%);transition:transform .4s cubic-bezier(.22,.61,.36,1);
  }
  .nav.open .nav__links{transform:translateX(0)}
  .nav__links a{font-size:16px}
  .nav__burger{display:block}
  .hero__inner{padding-top:120px}
  .hero__scroll{display:none}
  .stats__grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .proj-grid{grid-template-columns:1fr}
  .form__row{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr}
  .about__badge{left:-14px;padding:16px 18px}
  .about__badge b{font-size:30px}
  .sec-head{margin-bottom:40px}
}
