/* ============================================================
   KIWITT BAU — light edition, logo palette
   (red #d8322b · anthracite #1c1c1c · warm off-white)
   ============================================================ */

:root{
  /* radii + shadow tokens */
  --r-sm: 12px;
  --r-md: 18px;
  --r-lg: 22px;
  --r-xl: 28px;

  --sh-sm: 0 2px 6px rgba(28,28,28,.04), 0 6px 18px -6px rgba(28,28,28,.06);
  --sh-md: 0 6px 14px -4px rgba(28,28,28,.08), 0 18px 40px -16px rgba(28,28,28,.14);
  --sh-lg: 0 30px 80px -30px rgba(28,28,28,.3);

  --nav-h: 78px;

  /* light palette — primary */
  --bg:        #f2efe8;
  --bg-2:      #ebe7dd;
  --surface:   #ffffff;
  --surface-2: #e5e1d6;

  /* dark inverted — used for hero, quote, contact, footer */
  --dark:      #1c1c1c;
  --dark-2:    #232323;
  --dark-3:    #2a2a2a;

  /* type */
  --ink:       #1c1c1c;
  --ink-2:     #2d2d2d;
  --text-2:    #4a4743;
  --muted:     #857f73;
  --on-dark:   #f2efe8;
  --on-dark-2: #c9c4b6;
  --on-dark-m: #7e7a70;

  /* lines */
  --line:      rgba(28,28,28,.1);
  --line-2:    rgba(28,28,28,.2);
  --line-d:    rgba(242,239,232,.1);
  --line-d2:   rgba(242,239,232,.18);

  /* accent — logo red */
  --accent:    #d8322b;
  --accent-2:  #b62520;
  --accent-3:  #f04a42;

  /* signal green — used for availability / "go" indicators (Verfügbar, Jetzt anfragen) */
  --ok:        #22a754;
  --ok-glow:   rgba(34,167,84,.55);

  /* type families */
  --f-serif: 'Instrument Serif', 'Times New Roman', serif;
  --f-sans:  'Space Grotesk', 'Inter', system-ui, sans-serif;
  --f-body:  'Inter', system-ui, sans-serif;
  --f-mono:  'JetBrains Mono', ui-monospace, monospace;

  --ease:   cubic-bezier(.4,.0,.2,1);
  --ease-o: cubic-bezier(.16,1,.3,1);

  --pad-x: clamp(20px, 5vw, 80px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:90px;scrollbar-width:thin;scrollbar-color:var(--line-2) transparent}
html,body{background:var(--bg);color:var(--ink);font-family:var(--f-body);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{overflow-x:hidden;min-height:100vh;position:relative}

/* global scrollbar */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:10px;border:2px solid var(--bg);transition:background .2s}
::-webkit-scrollbar-thumb:hover{background:var(--muted)}

/* global focus */
:focus{outline:none}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}
.btn:focus-visible,.nav__cta:focus-visible,.nav__links a:focus-visible{outline-offset:4px;border-radius:999px}

/* ============ SUBTLE BLUEPRINT GRID BEHIND CREAM SECTIONS ============ */
.bg-grid{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.4;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:80px 80px;
  mask-image:linear-gradient(180deg, transparent 0%, #000 15%, #000 85%, transparent 100%);
  -webkit-mask-image:linear-gradient(180deg, transparent 0%, #000 15%, #000 85%, transparent 100%)}

/* ============ CORNER MARKS (architectural detailing) ============ */
.corner-marks{position:relative}
.corner-marks::before,.corner-marks::after{content:'';position:absolute;width:18px;height:18px;z-index:2;pointer-events:none;opacity:.45}
.corner-marks::before{top:20px;left:calc(var(--pad-x) - 4px);
  background-image:
    linear-gradient(var(--accent),var(--accent)),
    linear-gradient(var(--accent),var(--accent));
  background-size:18px 1px, 1px 18px;
  background-position:0 0, 0 0;
  background-repeat:no-repeat}
.corner-marks::after{top:20px;right:calc(var(--pad-x) - 4px);
  background-image:
    linear-gradient(var(--accent),var(--accent)),
    linear-gradient(var(--accent),var(--accent));
  background-size:18px 1px, 1px 18px;
  background-position:100% 0, 100% 0;
  background-repeat:no-repeat}

/* ============ SOFT AMBIENT BLOBS ============ */
.amb-blob{position:absolute;border-radius:50%;filter:blur(120px);pointer-events:none;z-index:0}
.amb-blob--red{background:var(--accent);opacity:.08}
.amb-blob--dark{background:var(--ink);opacity:.05}

/* ============ ICON BASE ============ */
.ico{width:22px;height:22px;flex-shrink:0;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;fill:none;stroke:currentColor}
.ico--lg{width:32px;height:32px;stroke-width:1.4}
.ico--xl{width:42px;height:42px;stroke-width:1.2}

/* ============ WATERMARK HOUSE ============ */
.wm-house{position:absolute;pointer-events:none;user-select:none;opacity:.05;z-index:0;width:clamp(280px,35vw,520px);filter:grayscale(1) brightness(0)}

/* ============ BRAND MARK (K-house) ============ */
.brand-mark{position:absolute;pointer-events:none;user-select:none;z-index:0}
.brand-mark--about{right:-10%;top:50%;transform:translateY(-50%) rotate(-6deg);width:clamp(420px,56vw,820px);opacity:.09;filter:saturate(.85)}
.brand-mark--footer{right:-2%;bottom:10%;width:clamp(180px,18vw,260px);opacity:.12;transform:rotate(8deg);filter:brightness(1.2)}
.brand-mark--contact{right:-80px;bottom:-80px;width:clamp(260px,28vw,420px);opacity:.08;transform:rotate(-4deg);filter:brightness(1.3)}
@media(max-width:900px){.brand-mark--about{right:-30%;opacity:.05}}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:0;color:inherit}
ul{list-style:none}
::selection{background:var(--accent);color:#fff}

.mono{font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
em{font-style:italic;font-family:var(--f-serif);font-weight:400;letter-spacing:-.01em}

/* ============ NOISE / GRAIN ============ */
.noise{position:fixed;inset:0;pointer-events:none;z-index:5;opacity:.035;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='140' height='140'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='.8'/></svg>")}

/* ============ PROGRESS ============ */
.progress{position:fixed;top:0;left:0;right:0;height:2px;z-index:100;background:transparent}
.progress__bar{height:100%;width:0%;background:var(--accent);transition:width .08s linear;box-shadow:0 0 14px rgba(216,50,43,.5)}

/* ============ BACK TO TOP ============ */
.back-top{position:fixed;bottom:24px;right:24px;width:52px;height:52px;display:grid;place-items:center;background:var(--ink);color:var(--on-dark);border-radius:50%;z-index:60;opacity:0;visibility:hidden;transform:translateY(12px) scale(.9);transition:opacity .3s var(--ease), transform .3s var(--ease), background .3s var(--ease);box-shadow:var(--sh-md);cursor:pointer}
.back-top.is-visible{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.back-top:hover{background:var(--accent);transform:translateY(-3px) scale(1.04)}
.back-top svg{stroke:currentColor;stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round}
@media(max-width:500px){.back-top{width:46px;height:46px;bottom:16px;right:16px}}

/* ============ NAV ============ */
.nav{position:fixed;top:0;left:0;right:0;z-index:80;display:flex;align-items:center;justify-content:space-between;padding:18px var(--pad-x);transition:padding .3s var(--ease),background .3s var(--ease),border-color .3s var(--ease);border-bottom:1px solid transparent;
  --nav-text: #ffffff;
  --nav-text-2: rgba(255,255,255,.78);
  --nav-muted: rgba(255,255,255,.6);
  --nav-pill: rgba(255,255,255,.1);
  --nav-cta-bg: #ffffff;
  --nav-cta-fg: #1c1c1c;
}
.nav.is-scrolled{padding:12px var(--pad-x);background:rgba(242,239,232,.82);backdrop-filter:blur(20px) saturate(140%);border-bottom:1px solid var(--line);
  --nav-text: var(--ink);
  --nav-text-2: var(--ink-2);
  --nav-muted: var(--muted);
  --nav-pill: var(--surface-2);
  --nav-cta-bg: var(--ink);
  --nav-cta-fg: var(--on-dark);
}

.nav__brand{display:flex;align-items:center;gap:12px}
.nav__brand img{width:42px;height:42px;object-fit:contain;background:#fff;padding:3px;border-radius:10px;transition:background .3s var(--ease), padding .3s var(--ease)}
.nav.is-scrolled .nav__brand img{background:transparent;padding:0}
.nav__name{display:block;font-family:var(--f-sans);font-weight:700;font-size:15px;letter-spacing:.01em;color:var(--nav-text);text-transform:uppercase;text-shadow:0 1px 10px rgba(0,0,0,.35);transition:color .3s var(--ease), text-shadow .3s var(--ease)}
.nav.is-scrolled .nav__name{text-shadow:none}
.nav__sub{display:block;font-family:var(--f-mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--nav-muted);margin-top:2px;text-shadow:0 1px 8px rgba(0,0,0,.4);transition:color .3s var(--ease), text-shadow .3s var(--ease)}
.nav.is-scrolled .nav__sub{text-shadow:none}

.nav__links{display:flex;gap:4px}
.nav__links a{position:relative;padding:8px 14px;font-family:var(--f-sans);font-size:13px;font-weight:500;color:var(--nav-text-2);transition:color .25s var(--ease);border-radius:999px;z-index:1;text-shadow:0 1px 8px rgba(0,0,0,.45)}
.nav.is-scrolled .nav__links a{text-shadow:none}
.nav__links a::before{content:'';position:absolute;inset:0;border-radius:999px;background:var(--nav-pill);opacity:0;transform:scale(.85);transition:opacity .25s var(--ease), transform .25s var(--ease);z-index:-1;backdrop-filter:blur(6px)}
.nav__links a:hover{color:var(--nav-text)}
.nav__links a:hover::before{opacity:1;transform:scale(1)}
.nav__links a.is-active{color:var(--nav-text)}
.nav__links a.is-active::before{opacity:1;transform:scale(1)}
.nav__links a.is-active::after{content:'';position:absolute;left:50%;bottom:-2px;width:4px;height:4px;border-radius:50%;background:var(--accent);transform:translateX(-50%);box-shadow:0 0 6px var(--accent)}

/* mobile burger */
.nav__toggle{display:none;position:relative;width:44px;height:44px;border-radius:12px;background:transparent;border:1px solid transparent;cursor:pointer;z-index:2;transition:background .25s var(--ease), border-color .25s var(--ease)}
.nav.is-scrolled .nav__toggle{border-color:var(--line-2)}
.nav__toggle span{position:absolute;left:50%;width:18px;height:1.5px;background:var(--nav-text);transform:translateX(-50%);transition:all .3s var(--ease);border-radius:2px;box-shadow:0 0 4px rgba(0,0,0,.25)}
.nav.is-scrolled .nav__toggle span{box-shadow:none}
.nav__toggle span:nth-child(1){top:17px}
.nav__toggle span:nth-child(2){bottom:17px}
body.menu-open .nav__toggle span:nth-child(1){top:50%;transform:translate(-50%,-50%) rotate(45deg)}
body.menu-open .nav__toggle span:nth-child(2){bottom:50%;transform:translate(-50%,50%) rotate(-45deg)}

/* mobile panel */
.nav-panel{position:fixed;inset:0;background:var(--bg);z-index:75;display:flex;flex-direction:column;padding:100px var(--pad-x) 40px;gap:10px;transform:translateY(-100%);transition:transform .5s var(--ease-o);visibility:hidden}
.nav-panel.is-open{transform:translateY(0);visibility:visible}
.nav-panel a{display:flex;align-items:center;justify-content:space-between;padding:20px 0;font-family:var(--f-serif);font-size:clamp(28px,6vw,42px);color:var(--ink);border-bottom:1px solid var(--line);transition:padding-left .3s var(--ease), color .25s var(--ease)}
.nav-panel a:hover,.nav-panel a.is-active{color:var(--accent);padding-left:14px}
.nav-panel a .mono{color:var(--muted);font-size:11px;font-family:var(--f-mono);font-weight:400}
.nav-panel__footer{margin-top:auto;padding-top:40px;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;border-top:1px solid var(--line)}
.nav-panel__footer a{font-family:var(--f-sans);font-size:14px;padding:10px 0;border-bottom:0}
.nav-panel__footer a:hover{padding-left:0}

.nav__cta{display:inline-flex;align-items:center;gap:10px;padding:11px 18px;background:var(--nav-cta-bg);color:var(--nav-cta-fg);border-radius:999px;font-family:var(--f-sans);font-size:13px;font-weight:500;transition:background .25s var(--ease), color .25s var(--ease), transform .2s var(--ease);will-change:transform;box-shadow:0 4px 20px rgba(0,0,0,.15)}
.nav.is-scrolled .nav__cta{box-shadow:none}
.nav__cta:hover{background:var(--accent);color:#fff}
.nav__cta .dot{width:6px;height:6px;border-radius:50%;background:var(--ok);box-shadow:0 0 10px var(--ok-glow);animation:pulse-dot 2s infinite}
.nav__cta:hover .dot{background:#fff;box-shadow:0 0 10px #fff}
@keyframes pulse-dot{0%,100%{opacity:1}50%{opacity:.45}}

@media(max-width:960px){
  .nav__links{display:none}
  .nav__toggle{display:block}
  .nav__cta{padding:11px 14px;font-size:12px}
  .nav__cta span:last-child{display:none}
}

/* ============ HERO (dark image on cream body) ============ */
.hero{position:relative;min-height:100vh;padding:160px var(--pad-x) 50px;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;background:var(--dark);color:var(--on-dark);border-bottom-left-radius:clamp(20px,4vw,40px);border-bottom-right-radius:clamp(20px,4vw,40px)}

.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg img{width:100%;height:100%;object-fit:cover;filter:grayscale(.2) brightness(.48) contrast(1.08)}
.hero__bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(28,28,28,.3) 0%,rgba(28,28,28,.55) 40%,rgba(28,28,28,.85) 100%)}

.hero__grid{position:absolute;inset:0;z-index:1;opacity:.07;pointer-events:none;
  background-image:linear-gradient(var(--on-dark) 1px, transparent 1px), linear-gradient(90deg, var(--on-dark) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image:radial-gradient(ellipse at center,#000 20%,transparent 72%);
  -webkit-mask-image:radial-gradient(ellipse at center,#000 20%,transparent 72%)}

.hero__glow{position:absolute;z-index:1;pointer-events:none;border-radius:50%;filter:blur(130px);opacity:.22}
.hero__glow--1{width:620px;height:620px;background:var(--accent);top:-10%;right:-10%}
.hero__glow--2{width:480px;height:480px;background:#4a4743;bottom:-20%;left:-5%;opacity:.5}

.hero > *:not(.hero__bg):not(.hero__grid):not(.hero__glow){position:relative;z-index:2}

.hero__badge{display:inline-flex;align-items:center;gap:10px;padding:8px 16px;border:1px solid var(--line-d2);background:rgba(28,28,28,.4);backdrop-filter:blur(10px);border-radius:999px;font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--on-dark-2);align-self:flex-start;margin-bottom:auto}
.hero__badge .pulse{width:6px;height:6px;border-radius:50%;background:var(--ok);box-shadow:0 0 10px var(--ok-glow);animation:pulse-dot 2s infinite}

.hero__title{font-family:var(--f-serif);font-weight:400;font-size:clamp(68px, 15vw, 260px);line-height:.9;letter-spacing:-.03em;color:var(--on-dark);margin:60px 0 50px}
.hero__title .reveal{display:block;overflow:hidden;padding-bottom:.05em}
.hero__title .reveal > span{display:inline-block;transform:translateY(105%);animation:rise 1.1s var(--ease-o) forwards}
.hero__title .reveal:nth-child(2) > span{animation-delay:.12s}
.hero__title em{color:var(--accent);font-style:italic}
@keyframes rise{to{transform:translateY(0)}}

.hero__foot{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:end;padding-bottom:40px;opacity:0;animation:fadeUp 1s .7s var(--ease-o) forwards}
.hero__lede{max-width:480px;font-size:17px;line-height:1.55;color:var(--on-dark-2)}
.hero__cta{display:flex;gap:12px;justify-content:flex-end;flex-wrap:wrap}

.hero__meta{display:flex;justify-content:space-between;padding-top:20px;border-top:1px solid var(--line-d2);opacity:0;animation:fadeUp 1s .9s var(--ease-o) forwards;align-items:center;gap:20px}
.hero__meta > div{display:flex;gap:24px;flex-wrap:wrap}
.hero__meta .mono{color:var(--on-dark-2)}
.hero__scroll{display:inline-flex;align-items:center;gap:10px;color:var(--on-dark-2);font-family:var(--f-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;opacity:.7;transition:opacity .25s}
.hero__scroll:hover{opacity:1}
.hero__scroll__line{display:block;width:40px;height:1px;background:currentColor;position:relative;overflow:hidden}
.hero__scroll__line::after{content:'';position:absolute;top:0;left:-40%;width:40%;height:100%;background:var(--accent);animation:slideR 2.2s var(--ease) infinite}
@keyframes slideR{0%{left:-40%}100%{left:100%}}
@keyframes fadeUp{to{opacity:1}}

@media(max-width:800px){
  .hero__foot{grid-template-columns:1fr;gap:30px}
  .hero__cta{justify-content:flex-start}
  .hero__meta{flex-direction:column;gap:16px;align-items:flex-start}
}

/* ============ BUTTONS ============ */
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 24px;font-family:var(--f-sans);font-size:13px;font-weight:500;letter-spacing:.01em;border-radius:999px;transition:background .3s var(--ease), color .3s var(--ease), border-color .3s var(--ease), transform .2s var(--ease), box-shadow .3s var(--ease);position:relative;will-change:transform;white-space:nowrap;cursor:pointer}
.btn:active{transform:translateY(1px) scale(.98)}
.btn--primary{background:var(--accent);color:#fff}
.btn--primary:hover{background:var(--accent-2)}
.btn--ghost{background:transparent;color:var(--on-dark);border:1px solid var(--line-d2)}
.btn--ghost:hover{background:var(--on-dark);color:var(--ink);border-color:var(--on-dark)}
.btn--block{width:100%;justify-content:center;padding:18px}
.btn svg{transition:transform .3s var(--ease)}
.btn:hover svg{transform:translateX(4px)}

/* on light sections override ghost */
.contact .btn--ghost,.svc .btn--ghost{color:var(--ink);border-color:var(--line-2)}
.contact .btn--ghost:hover,.svc .btn--ghost:hover{background:var(--ink);color:var(--on-dark)}

/* ============ IMAGE MARQUEE ============ */
.imarq{background:var(--bg);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:40px 0 50px;overflow:hidden;position:relative}
.imarq__head{display:flex;justify-content:space-between;align-items:center;padding:0 var(--pad-x) 30px}
.imarq__head .mono{display:inline-flex;align-items:center;gap:10px;color:var(--accent)}
.imarq__scroll{animation:bounceR 1.8s var(--ease) infinite}
@keyframes bounceR{0%,100%{transform:translateX(0)}50%{transform:translateX(6px)}}

.imarq__track{display:flex;gap:18px;white-space:nowrap;animation:marq 58s linear infinite;align-items:stretch;padding:0 18px}
.imarq__track:hover{animation-play-state:paused}
.imarq__cell{position:relative;flex-shrink:0;width:clamp(300px,32vw,440px);aspect-ratio:5/4;border-radius:18px;overflow:hidden;background:var(--surface-2);border:1px solid var(--line);white-space:normal;box-shadow:var(--sh-sm)}
.imarq__cell img{width:100%;height:100%;object-fit:cover;filter:contrast(1.05);transition:transform 1.2s var(--ease-o), filter .4s var(--ease)}
.imarq__cell:hover img{transform:scale(1.05)}
.imarq__cell::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%, rgba(28,28,28,.8) 100%);pointer-events:none}
.imarq__cell figcaption{position:absolute;left:22px;right:22px;bottom:22px;display:flex;flex-direction:column;gap:4px;color:#fff;z-index:1}
.imarq__cell figcaption .mono{color:rgba(255,255,255,.72)}
.imarq__cell figcaption b{font-family:var(--f-serif);font-weight:400;font-size:22px;letter-spacing:-.005em;line-height:1.2}
@keyframes marq{to{transform:translateX(-50%)}}

/* ============ FEATURE SPLIT ============ */
.feat{position:relative;padding:140px 0 160px;background:var(--bg);overflow:hidden}
.feat__inner{max-width:1320px;margin:0 auto;padding:0 var(--pad-x);display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;position:relative;z-index:1}

.feat__left{display:flex;flex-direction:column;gap:28px;padding-top:10px}
.feat__idx{display:inline-flex;align-items:center;gap:10px;color:var(--accent)}
.feat__title{font-family:var(--f-serif);font-weight:400;font-size:clamp(48px,7vw,108px);line-height:.95;letter-spacing:-.03em;color:var(--ink)}
.feat__title em{color:var(--accent);font-style:italic}
.feat__lede{font-family:var(--f-serif);font-weight:400;font-size:clamp(19px,1.7vw,24px);line-height:1.4;color:var(--text-2);max-width:50ch;letter-spacing:-.005em}
.feat__lede em{color:var(--ink);font-style:italic}
.feat__sig{display:flex;justify-content:space-between;align-items:center;gap:20px;padding-top:24px;border-top:1px solid var(--line);flex-wrap:wrap;margin-top:10px}
.feat__link{display:inline-flex;align-items:center;gap:8px;font-family:var(--f-sans);font-size:14px;font-weight:500;color:var(--ink);transition:color .25s var(--ease), gap .25s var(--ease)}
.feat__link:hover{color:var(--accent);gap:14px}

.feat__card{background:var(--ink);color:var(--on-dark);border-radius:26px;padding:36px;position:sticky;top:120px;display:flex;flex-direction:column;gap:6px;box-shadow:0 30px 80px -30px rgba(28,28,28,.35);overflow:hidden}
.feat__card::before{content:'';position:absolute;top:-80px;right:-80px;width:240px;height:240px;background:var(--accent);filter:blur(100px);opacity:.28;pointer-events:none}
.feat__card__head{display:flex;justify-content:space-between;align-items:center;padding-bottom:24px;border-bottom:1px solid var(--line-d);margin-bottom:18px;position:relative;z-index:1}
.feat__card__head .mono{color:var(--on-dark-m)}
.feat__card__yr{color:var(--accent)}

.feat__row{display:grid;grid-template-columns:44px 1fr;gap:20px;align-items:center;padding:20px 0;border-top:1px solid var(--line-d);position:relative;z-index:1;transition:padding-left .3s var(--ease)}
.feat__row:first-of-type{border-top:0}
.feat__row:hover{padding-left:8px}
.feat__ico{width:44px;height:44px;padding:11px;background:rgba(216,50,43,.14);border-radius:12px;color:var(--accent)}
.feat__lbl{display:flex;flex-direction:column;gap:4px;min-width:0}
.feat__lbl strong{font-family:var(--f-serif);font-weight:400;font-size:clamp(20px,1.7vw,24px);letter-spacing:-.005em;color:var(--on-dark);line-height:1.15}
.feat__lbl span{font-size:13px;color:var(--on-dark-2);line-height:1.5}

.feat__cta{display:inline-flex;align-items:center;justify-content:center;gap:10px;margin-top:24px;padding:18px 24px;background:var(--accent);color:#fff;border-radius:999px;font-family:var(--f-sans);font-size:13px;font-weight:500;letter-spacing:.01em;transition:background .3s var(--ease), transform .2s var(--ease);position:relative;z-index:1}
.feat__cta:hover{background:var(--accent-3)}
.feat__cta svg{transition:transform .3s var(--ease)}
.feat__cta:hover svg{transform:translateX(4px)}

@media(max-width:1000px){
  .feat__inner{grid-template-columns:1fr;gap:50px}
  .feat__card{position:relative;top:0}
}
@media(max-width:520px){
  .feat__row{grid-template-columns:40px 1fr;gap:14px}
}


/* ============ INTRO / MANIFEST ============ */
.intro{max-width:1280px;margin:0 auto;padding:60px var(--pad-x) 160px;position:relative}
.intro__idx{display:block;margin-bottom:40px;color:var(--accent)}
.intro__text{font-family:var(--f-serif);font-weight:400;font-size:clamp(32px,5vw,70px);line-height:1.1;letter-spacing:-.02em;color:var(--ink);max-width:20ch}
.intro__text em{color:var(--accent)}
.intro__dim{color:var(--muted);display:block;margin-top:.3em;font-size:.85em}

/* ============ SECTION HEAD ============ */
.sec-head{max-width:1280px;margin:0 auto;padding:140px var(--pad-x) 60px}
.sec-head > .mono{display:block;margin-bottom:26px;color:var(--accent)}
.sec-head h2{font-family:var(--f-serif);font-weight:400;font-size:clamp(40px,6.5vw,96px);line-height:1;letter-spacing:-.025em;color:var(--ink);max-width:16ch}
.sec-head h2 em{color:var(--accent)}
.sec-head__lede{margin-top:30px;font-size:17px;line-height:1.55;color:var(--text-2);max-width:58ch}

/* ============ ABOUT ============ */
.about{background:var(--bg);position:relative;overflow:hidden}
.about__grid{max-width:1280px;margin:0 auto;padding:20px var(--pad-x) 120px;display:grid;grid-template-columns:repeat(3,1fr);gap:20px;position:relative;z-index:1}
.about__card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:40px;display:flex;flex-direction:column;gap:20px;min-height:280px;transition:transform .4s var(--ease-o), border-color .4s var(--ease), box-shadow .4s var(--ease);position:relative;overflow:hidden;box-shadow:var(--sh-sm)}
.about__card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:0;transform:translateX(-100%);transition:opacity .4s var(--ease), transform .8s var(--ease-o)}
.about__card:hover{transform:translateY(-6px);border-color:var(--line-2);box-shadow:var(--sh-md)}
.about__card:hover::after{opacity:1;transform:translateX(0)}
.about__card:hover .about__card__num{color:var(--accent);opacity:.25}
.about__card__ico{width:44px;height:44px;stroke:var(--accent);stroke-width:1.3;fill:none;stroke-linecap:round;stroke-linejoin:round;margin-bottom:4px;transition:transform .4s var(--ease-o)}
.about__card:hover .about__card__ico{transform:rotate(-6deg) scale(1.08)}
.about__card__num{transition:color .4s var(--ease), opacity .4s var(--ease)}
.about__card > .mono{color:var(--accent);position:relative;padding-bottom:16px;border-bottom:1px solid var(--line);width:fit-content}
.about__card p{font-family:var(--f-serif);font-size:clamp(20px,1.8vw,24px);line-height:1.3;color:var(--ink);letter-spacing:-.005em}
.about__card__num{position:absolute;top:20px;right:24px;font-family:var(--f-serif);font-size:56px;font-style:italic;color:var(--line-2);line-height:1;font-weight:400}
@media(max-width:900px){.about__grid{grid-template-columns:1fr}}

/* ============ VISION ============ */
.vision{background:var(--bg);padding:80px 0 140px;position:relative;overflow:hidden}
.vision__grid{max-width:1280px;margin:0 auto;padding:0 var(--pad-x);display:grid;grid-template-columns:1.2fr 1fr;gap:80px;align-items:start;position:relative;z-index:1}
.vision__text > .mono{display:block;margin-bottom:24px;color:var(--accent)}
.vision__text h2{font-family:var(--f-serif);font-weight:400;font-size:clamp(38px,5.5vw,80px);line-height:1;letter-spacing:-.025em;color:var(--ink);margin-bottom:32px}
.vision__text h2 em{color:var(--accent)}
.vision__text p{font-size:16px;line-height:1.6;color:var(--text-2);margin-bottom:18px;max-width:60ch}
.vision__text .btn{margin-top:24px}

.vision__points{display:flex;flex-direction:column;gap:16px;position:sticky;top:120px}
.vision__points li{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:26px 28px;display:grid;grid-template-columns:44px 1fr;align-items:center;gap:18px;transition:transform .4s var(--ease-o), border-color .3s var(--ease), box-shadow .4s var(--ease);box-shadow:var(--sh-sm)}
.vision__points li:hover{transform:translateX(6px);border-color:var(--accent);box-shadow:var(--sh-md)}
.vision__points__ico{width:42px;height:42px;padding:9px;background:rgba(216,50,43,.08);border-radius:12px;stroke:var(--accent);stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round}
.vision__points__body{display:flex;flex-direction:column;gap:4px}
.vision__points h3{font-family:var(--f-serif);font-weight:400;font-size:clamp(20px,1.8vw,24px);line-height:1.15;letter-spacing:-.01em;color:var(--ink)}
.vision__points p{font-size:13px;line-height:1.5;color:var(--muted)}

@media(max-width:900px){
  .vision__grid{grid-template-columns:1fr;gap:40px}
  .vision__points{position:relative;top:0}
}

/* ============ BTN DARK ============ */
.btn--dark{background:var(--ink);color:var(--on-dark)}
.btn--dark:hover{background:var(--accent);color:#fff}

/* ============ REVEAL ============ */
[data-reveal-lines]{overflow:hidden}
[data-reveal-lines] > *, [data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease-o), transform .8s var(--ease-o)}
[data-reveal-lines].in > *, [data-reveal].in{opacity:1;transform:translateY(0)}

/* ============ SERVICES ============ */
.services{padding-bottom:160px;background:var(--bg);position:relative;overflow:hidden}
.services > .sec-head, .services > .svc{position:relative;z-index:1}
.svc{max-width:1280px;margin:0 auto;padding:0 var(--pad-x)}

/* editorial spreads — one per service */
.svc__spreads{list-style:none;margin:0;padding:0}
.svc__spread{display:grid;grid-template-columns:minmax(180px,300px) 1fr;gap:70px;padding:90px 0;border-top:1px solid var(--line);align-items:center;position:relative;transition:background .4s var(--ease)}
.svc__spread:first-child{border-top:0;padding-top:30px}
.svc__spread::after{content:'';position:absolute;left:0;right:0;bottom:-1px;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:left center;transition:transform .6s var(--ease-o);pointer-events:none}
.svc__spread:hover::after{transform:scaleX(1)}

/* huge outlined serif number — fills with accent on hover */
.svc__num{
  display:block;
  font-family:var(--f-serif);
  font-weight:400;
  font-style:italic;
  font-size:clamp(140px,18vw,260px);
  line-height:.82;
  letter-spacing:-.05em;
  color:transparent;
  -webkit-text-stroke:1.5px var(--accent);
  text-stroke:1.5px var(--accent);
  transition:color .5s var(--ease-o), -webkit-text-stroke-color .5s var(--ease-o), transform .6s var(--ease-o);
  user-select:none;
}
.svc__spread:hover .svc__num{color:var(--accent);transform:translateX(8px)}

.svc__content{display:flex;flex-direction:column;gap:26px;min-width:0}

.svc__sp-head{display:flex;justify-content:space-between;align-items:flex-start;gap:36px}
.svc__sp-head h3{font-family:var(--f-serif);font-weight:400;font-size:clamp(32px,4.2vw,60px);line-height:1.02;letter-spacing:-.025em;color:var(--ink);max-width:14ch;flex:1;min-width:0}
.svc__sp-head h3 em{color:var(--accent);font-style:italic}

.svc__icon{width:84px;height:84px;flex-shrink:0;color:var(--ink-2);transition:transform .6s var(--ease-o), color .35s var(--ease)}
.svc__icon svg{width:100%;height:100%;display:block;overflow:visible}
.svc__spread:hover .svc__icon{color:var(--accent);transform:rotate(-8deg) scale(1.08)}

.svc__lede{font-family:var(--f-serif);font-size:clamp(18px,1.5vw,22px);line-height:1.45;color:var(--text-2);max-width:58ch;letter-spacing:-.005em}

.svc__chips{list-style:none;margin:0;padding:8px 0 0;display:flex;flex-wrap:wrap;gap:8px}
.svc__chips li{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);padding:9px 16px;background:var(--surface);border:1px solid var(--line);border-radius:999px;transition:all .3s var(--ease)}
.svc__chips li:hover{background:var(--ink);border-color:var(--ink);color:var(--on-dark);transform:translateY(-2px)}

/* footer row: count + cta */
.svc__foot{display:flex;justify-content:space-between;align-items:center;gap:20px;padding-top:36px;margin-top:30px;border-top:1px solid var(--line)}
.svc__foot .mono{color:var(--muted);font-size:11px;letter-spacing:.1em;text-transform:uppercase}
.svc__foot__link{display:inline-flex;align-items:center;gap:10px;font-family:var(--f-sans);font-size:13px;font-weight:500;letter-spacing:.01em;color:var(--ink);padding:12px 20px;border:1px solid var(--line-2);border-radius:999px;transition:background .3s var(--ease), color .3s var(--ease), border-color .3s var(--ease), gap .25s var(--ease)}
.svc__foot__link:hover{background:var(--ink);color:var(--on-dark);border-color:var(--ink);gap:14px}
.svc__foot__link svg{transition:transform .3s var(--ease)}
.svc__foot__link:hover svg{transform:translateX(4px)}

@media(max-width:900px){
  .svc__spread{grid-template-columns:1fr;gap:18px;padding:50px 0;align-items:flex-start}
  .svc__spread:first-child{padding-top:20px}
  .svc__num{font-size:clamp(96px,28vw,160px);line-height:.85}
  .svc__sp-head{flex-direction:row-reverse;justify-content:flex-end;align-items:center;gap:20px}
  .svc__sp-head h3{font-size:clamp(26px,6.4vw,34px)}
  .svc__icon{width:56px;height:56px}
  .svc__foot{flex-direction:column;align-items:stretch;gap:16px}
  .svc__foot__link{justify-content:center}
}

/* ============ BUILD-A-HOUSE — scroll-driven construction ============ */
.build{background:var(--bg);position:relative;overflow:clip;padding:0}
.build__inner{max-width:1400px;margin:0 auto;padding:0 var(--pad-x);display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:stretch}

/* LEFT — sticky stage (must stretch full grid row so sticky has scroll runway) */
.build__stage{position:relative;height:100%}
.build__stage-inner{position:sticky;top:90px;height:calc(100vh - 100px);display:flex;flex-direction:column;gap:24px;padding:60px 0;color:var(--ink)}
.build__kicker{color:var(--accent);display:block}
.build__title{font-family:var(--f-serif);font-weight:400;font-size:clamp(36px,4.4vw,72px);line-height:.98;letter-spacing:-.025em;color:var(--ink)}
.build__title em{color:var(--accent);font-style:italic}

.build__house{flex:1;display:grid;place-items:center;min-height:0;padding:20px 0}
.build__svg{width:100%;height:100%;max-height:520px;max-width:560px;color:var(--ink)}

/* base SVG element states (hidden) */
.build__svg .b-foundation,
.build__svg .b-walls,
.build__svg .b-roof,
.build__svg .b-door,
.build__svg .b-window,
.build__svg .b-detail,
.build__svg .b-outdoor{transform-box:fill-box;transform-origin:center bottom;transition:opacity .8s var(--ease-o), transform .9s cubic-bezier(.34,1.36,.64,1), clip-path 1.1s var(--ease-o)}

.build__svg .b-foundation{opacity:0;transform:translateY(30px) scaleY(.4)}
.build__svg.is-p1 .b-foundation{opacity:1;transform:translateY(0) scaleY(1)}

.build__svg .b-walls{opacity:0;clip-path:inset(100% 0 0 0)}
.build__svg.is-p2 .b-walls{opacity:1;clip-path:inset(0 0 0 0)}

.build__svg .b-roof{opacity:0;transform:translateY(-60px);transform-origin:center top}
.build__svg.is-p3 .b-roof{opacity:1;transform:translateY(0)}

.build__svg .b-door,
.build__svg .b-window{opacity:0;transform:scale(.5);transform-origin:center}
.build__svg.is-p4 .b-door{opacity:1;transform:scale(1);transition-delay:.05s}
.build__svg.is-p4 .b-window--l{opacity:1;transform:scale(1);transition-delay:.18s}
.build__svg.is-p4 .b-window--r{opacity:1;transform:scale(1);transition-delay:.32s}

.build__svg .b-detail{opacity:0;transform:translateY(20px);transform-origin:center bottom}
.build__svg.is-p5 .b-detail{opacity:1;transform:translateY(0)}
.build__svg.is-p5 .b-smoke{animation:smokeRise 3s ease-out infinite}
@keyframes smokeRise{
  0%{opacity:.4;transform:translateY(0)}
  100%{opacity:0;transform:translateY(-14px)}
}

.build__svg .b-outdoor{opacity:0;transform:translateY(20px) scaleY(.6);transform-origin:center bottom}
.build__svg.is-p6 .b-outdoor{opacity:1;transform:translateY(0) scaleY(1)}

/* phase counter + progress */
.build__phase-counter{display:flex;align-items:center;gap:18px;padding-top:22px;border-top:1px solid var(--line)}
.build__phase-counter .mono{color:var(--muted);text-transform:uppercase;letter-spacing:.1em;font-size:11px}
.build__phase-num{font-family:var(--f-mono);font-size:13px;color:var(--text-2);display:inline-flex;align-items:baseline;gap:6px}
.build__phase-num strong{font-family:var(--f-serif);font-weight:400;font-size:32px;color:var(--ink);letter-spacing:-.02em;line-height:1;transition:color .3s var(--ease)}
.build__phase-num .sep{opacity:.4;margin:0 4px}
.build__progress{flex:1;height:2px;background:var(--line-2);border-radius:2px;overflow:hidden;position:relative}
.build__progress span{position:absolute;left:0;top:0;height:100%;width:0;background:var(--accent);border-radius:2px;transition:width .6s var(--ease-o)}

/* RIGHT — phase steps */
.build__steps{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}
.build__step{min-height:72vh;display:flex;flex-direction:column;justify-content:center;gap:18px;padding:60px 0;border-top:1px solid var(--line);transition:opacity .5s var(--ease)}
.build__step:first-child{border-top:0}
.build__step:not(.is-active){opacity:.4}
.build__step__n{color:var(--accent);letter-spacing:.08em}
.build__step h3{font-family:var(--f-serif);font-weight:400;font-size:clamp(28px,3vw,42px);line-height:1.1;letter-spacing:-.02em;color:var(--ink)}
.build__step p{font-size:16px;line-height:1.65;color:var(--text-2);max-width:48ch}

/* mobile — fully-built static house + compact step list (no sticky, no scroll-animation) */
@media(max-width:1024px){
  .build__inner{grid-template-columns:1fr;gap:0;padding:60px var(--pad-x)}

  /* stage becomes a static intro block */
  .build__stage{height:auto}
  .build__stage-inner{position:static;height:auto;padding:0 0 30px;gap:18px;box-shadow:none}
  .build__house{padding:16px 0;flex:initial}
  .build__svg{max-height:300px;max-width:440px;margin:0 auto;display:block}

  /* force every phase visible — house arrives pre-built */
  .build__svg [class^="b-"]{opacity:1 !important;transform:none !important;clip-path:none !important;transition:none !important}

  /* hide the phase counter — no animation = no progress to show */
  .build__phase-counter{display:none}

  /* steps: clean editorial list, full opacity, tight spacing */
  .build__steps{border-top:1px solid var(--line);padding-top:10px}
  .build__step{min-height:auto;padding:28px 0;gap:8px;border-top:1px solid var(--line)}
  .build__step:first-child{border-top:0}
  .build__step:not(.is-active){opacity:1}
  .build__step h3{font-size:clamp(22px,5.2vw,28px)}
  .build__step p{font-size:15px;line-height:1.6}
}
@media(prefers-reduced-motion:reduce){
  .build__svg [class^="b-"]{opacity:1 !important;transform:none !important;clip-path:none !important}
  .build__svg .b-smoke{animation:none}
}

/* ============ CTA BAND (breaker · light) ============ */
.cta-band{position:relative;padding:340px var(--pad-x) 200px;overflow:hidden;background:var(--bg);isolation:isolate}
.cta-band__inner{position:relative;z-index:1;max-width:1320px;margin:0 auto;display:grid;grid-template-columns:1.3fr 1fr;gap:80px;align-items:center}

.cta-band__left{display:flex;flex-direction:column;gap:28px}
.cta-band__badge{display:inline-flex;align-items:center;gap:10px;padding:9px 16px;background:rgba(216,50,43,.08);border:1px solid rgba(216,50,43,.25);border-radius:999px;color:var(--accent);width:fit-content}
.cta-band__badge .pulse{width:6px;height:6px;border-radius:50%;background:var(--ok);box-shadow:0 0 10px var(--ok-glow);animation:pulse-dot 2s infinite}
.cta-band__title{font-family:var(--f-serif);font-weight:400;font-size:clamp(44px,7vw,108px);line-height:.95;letter-spacing:-.03em;color:var(--ink);max-width:16ch}
.cta-band__title em{color:var(--accent);font-style:italic}
.cta-band__lede{font-size:16px;line-height:1.55;color:var(--text-2);max-width:52ch}
.cta-band__actions{display:flex;gap:20px;align-items:center;flex-wrap:wrap;margin-top:8px}
.cta-band__phone{display:inline-flex;align-items:center;gap:10px;font-family:var(--f-serif);font-size:clamp(18px,1.8vw,24px);color:var(--ink);transition:color .25s var(--ease)}
.cta-band__phone:hover{color:var(--accent)}
.cta-band__phone svg{color:var(--accent)}

/* Right visual composition */
/* shared --lift on the visual — crane + block rise together as one rig */
.cta-band__visual{--lift:0;position:relative;max-width:460px;justify-self:end;width:100%;padding-top:200px}

/* crane suspended high above the payload — sways gently, AND rises with the load */
.cta-band__crane{position:absolute;top:-240px;left:50%;width:170px;z-index:4;pointer-events:none;transform-origin:top center;animation:craneSway 6s ease-in-out infinite;translate:-50% calc((1 - var(--lift)) * 280px);transition:translate .08s linear}
.cta-band__crane > *{display:block}
.cta-band__hook{position:relative;width:100%;height:auto;filter:drop-shadow(0 14px 22px rgba(0,0,0,.18))}
@keyframes craneSway{
  0%,100%{transform:rotate(-1.4deg)}
  50%{transform:rotate(1.4deg)}
}

.cta-band__block{position:relative;width:100%;aspect-ratio:1/1;background:linear-gradient(135deg,var(--ink) 0%,var(--ink-2) 100%);border-radius:26px;overflow:hidden;box-shadow:0 calc(20px + var(--lift)*30px) calc(40px + var(--lift)*60px) calc(-20px) rgba(28,28,28,calc(.15 + var(--lift)*.25));transform:translateY(calc((1 - var(--lift)) * 280px)) rotate(calc((1 - var(--lift)) * -2.5deg));transform-origin:top center;opacity:calc(.25 + var(--lift)*.75);transition:transform .08s linear, opacity .12s linear}

@media(prefers-reduced-motion:reduce){
  .cta-band__crane{animation:none}
  .cta-band__visual{--lift:1 !important}
  .cta-band__block{transform:none;opacity:1}
}
.cta-band__block::before{content:'';position:absolute;top:-30%;right:-30%;width:80%;height:80%;background:radial-gradient(circle,var(--accent) 0%,transparent 60%);opacity:.4;pointer-events:none}
.cta-band__block__mono{position:absolute;top:26px;left:26px;color:var(--on-dark-m);z-index:2}
.cta-band__mark{position:absolute;left:50%;top:52%;transform:translate(-50%,-50%) rotate(-6deg);width:62%;opacity:.95;filter:drop-shadow(0 20px 40px rgba(0,0,0,.4));z-index:1}
.cta-band__marker{position:absolute;left:26px;bottom:26px;width:12px;height:12px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(216,50,43,.25), 0 0 18px var(--accent);z-index:2;animation:pulse-dot 2s infinite}

/* corner ticks on dark block */
.cta-band__corner{position:absolute;width:14px;height:14px;z-index:2}
.cta-band__corner--tl{top:14px;left:14px;border-top:1px solid var(--on-dark-2);border-left:1px solid var(--on-dark-2);opacity:.4}
.cta-band__corner--tr{top:14px;right:14px;border-top:1px solid var(--on-dark-2);border-right:1px solid var(--on-dark-2);opacity:.4}
.cta-band__corner--bl{bottom:14px;left:14px;border-bottom:1px solid var(--on-dark-2);border-left:1px solid var(--on-dark-2);opacity:.4}
.cta-band__corner--br{bottom:14px;right:14px;border-bottom:1px solid var(--on-dark-2);border-right:1px solid var(--on-dark-2);opacity:.4}

@media(max-width:900px){
  .cta-band__inner{grid-template-columns:1fr;gap:50px}
  .cta-band__visual{max-width:340px;margin:0 auto;justify-self:center}
}

/* ============ WHY US ============ */
.why{background:var(--bg);padding-bottom:140px;position:relative;overflow:hidden}
.usps{max-width:1280px;margin:0 auto;padding:0 var(--pad-x);display:grid;grid-template-columns:repeat(4,1fr);gap:16px;position:relative;z-index:1}
.usp{padding:32px 28px 30px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);min-height:280px;display:flex;flex-direction:column;gap:14px;transition:transform .4s var(--ease-o), border-color .3s var(--ease), background .3s var(--ease), box-shadow .4s var(--ease);position:relative;overflow:hidden;box-shadow:var(--sh-sm)}
.usp:hover{transform:translateY(-8px);border-color:var(--accent);background:var(--ink);color:var(--on-dark);box-shadow:var(--sh-md)}
.usp__ico{width:48px;height:48px;padding:10px;background:rgba(216,50,43,.08);border-radius:14px;stroke:var(--accent);stroke-width:1.5;fill:none;stroke-linecap:round;stroke-linejoin:round;transition:background .3s var(--ease), transform .4s var(--ease-o)}
.usp:hover .usp__ico{background:rgba(255,255,255,.08);transform:rotate(-6deg) scale(1.08)}
.usp__n{font-family:var(--f-serif);font-size:18px;font-weight:400;color:var(--muted);font-style:italic;line-height:1;letter-spacing:.02em;position:absolute;top:22px;right:26px;transition:color .3s var(--ease)}
.usp:hover .usp__n{color:var(--on-dark-m)}
.usp h3{font-family:var(--f-serif);font-weight:400;font-size:clamp(22px,2vw,26px);line-height:1.15;letter-spacing:-.01em;color:inherit;margin-top:4px}
.usp p{font-size:14px;line-height:1.55;color:var(--text-2);margin-top:auto;transition:color .3s var(--ease)}
.usp:hover p{color:var(--on-dark-2)}
@media(max-width:1000px){.usps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.usps{grid-template-columns:1fr}}

/* ============ PROJECTS ============ */
.projects{padding-bottom:160px;background:var(--bg);position:relative;overflow:hidden}
.projects > .proj-head,.projects > .proj-grid,.projects > .proj-foot{position:relative;z-index:1}

/* editorial split header */
.proj-head{max-width:1400px;margin:0 auto;padding:140px var(--pad-x) 70px;display:grid;grid-template-columns:1.15fr 1fr;gap:80px;align-items:end}
.proj-head__left .mono{display:block;margin-bottom:22px;color:var(--accent)}
.proj-head__left h2{font-family:var(--f-serif);font-weight:400;font-size:clamp(48px,8vw,124px);line-height:.92;letter-spacing:-.03em;color:var(--ink)}
.proj-head__left h2 em{color:var(--accent);font-style:italic}
.proj-head__right{display:flex;flex-direction:column;gap:22px;padding-bottom:16px}
.proj-head__tag{display:inline-flex;align-items:center;gap:10px;padding:9px 16px;background:var(--surface);border:1px solid var(--line);border-radius:999px;color:var(--ink);font-size:11px;letter-spacing:.1em;text-transform:uppercase;width:fit-content}
.proj-head__tag .pulse{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 0 rgba(216,50,43,.55);animation:svcPulse 1.8s var(--ease-o) infinite}
.proj-head__right p{font-family:var(--f-serif);font-size:clamp(18px,1.6vw,22px);line-height:1.45;color:var(--text-2);max-width:46ch;letter-spacing:-.005em}
.proj-head__right p em{color:var(--ink);font-style:italic}
.proj-head__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:8px;padding-top:24px;border-top:1px solid var(--line-2)}
.proj-head__stats > div{display:flex;flex-direction:column;gap:4px}
.proj-head__stats b{font-family:var(--f-serif);font-weight:400;font-size:clamp(30px,3.6vw,44px);line-height:1;letter-spacing:-.02em;color:var(--accent)}
.proj-head__stats span{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;color:var(--muted);text-transform:uppercase}

/* grid */
.proj-grid{max-width:1400px;margin:0 auto;padding:0 var(--pad-x);display:grid;grid-template-columns:repeat(6,1fr);gap:18px;grid-auto-flow:dense}

.pj{grid-column:span 3;position:relative;border-radius:22px;overflow:hidden;background:var(--ink);aspect-ratio:16/10;cursor:pointer;will-change:transform;transition:transform .6s var(--ease-o), box-shadow .5s var(--ease)}
.pj--tall{grid-column:span 3;grid-row:span 2;aspect-ratio:4/5}
.pj--wide{grid-column:span 6;aspect-ratio:21/9}
.pj:hover{transform:translateY(-4px);box-shadow:0 40px 90px -30px rgba(28,28,28,.4)}

.pj__img{position:absolute;inset:0;background:var(--surface-2)}
.pj__img img{width:100%;height:100%;object-fit:cover;transition:transform 1.6s var(--ease-o), filter .6s var(--ease);filter:contrast(1.06) saturate(.9) brightness(.92)}
.pj:hover .pj__img img{transform:scale(1.08);filter:contrast(1.08) saturate(1) brightness(.78)}

.pj__shade{position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(28,28,28,.55) 0%,rgba(28,28,28,.05) 22%,rgba(28,28,28,.05) 38%,rgba(28,28,28,.7) 62%,rgba(28,28,28,.96) 100%);
  pointer-events:none;transition:background .5s var(--ease)}
.pj:hover .pj__shade{background:
  linear-gradient(180deg,rgba(28,28,28,.7) 0%,rgba(28,28,28,.35) 20%,rgba(28,28,28,.55) 40%,rgba(28,28,28,.9) 65%,rgba(28,28,28,.98) 100%)}

.pj__c{position:absolute;width:18px;height:18px;border:1px solid rgba(255,255,255,.5);z-index:3;pointer-events:none;transition:border-color .3s var(--ease), width .4s var(--ease-o), height .4s var(--ease-o)}
.pj__c--tl{top:14px;left:14px;border-right:0;border-bottom:0}
.pj__c--tr{top:14px;right:14px;border-left:0;border-bottom:0}
.pj__c--bl{bottom:14px;left:14px;border-right:0;border-top:0}
.pj__c--br{bottom:14px;right:14px;border-left:0;border-top:0}
.pj:hover .pj__c{border-color:var(--accent);width:24px;height:24px}

.pj__top{position:absolute;top:24px;left:24px;right:24px;display:flex;justify-content:space-between;align-items:center;z-index:4;color:#fff}
.pj__id{font-family:var(--f-mono);font-size:11px;letter-spacing:.15em;color:var(--accent);font-weight:500}
.pj__loc{display:inline-flex;align-items:center;gap:6px;font-family:var(--f-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.85);padding:5px 10px;background:rgba(255,255,255,.1);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.18);border-radius:999px}
.pj__loc svg{color:var(--accent)}

.pj__bottom{position:absolute;left:24px;right:24px;bottom:24px;display:flex;flex-direction:column;gap:12px;z-index:4;color:#fff}
.pj__bottom .pj__tags{display:flex;flex-wrap:wrap;gap:5px}
.pj__bottom .pj__tags span{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;padding:4px 9px;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.06);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:999px;color:rgba(255,255,255,.9);transition:background .25s var(--ease), border-color .25s var(--ease)}
.pj:hover .pj__bottom .pj__tags span{border-color:rgba(216,50,43,.6);background:rgba(216,50,43,.15)}

.pj__bottom h3{font-family:var(--f-serif);font-weight:400;font-size:clamp(22px,2.2vw,34px);line-height:1.05;letter-spacing:-.015em;color:#fff;text-shadow:0 2px 20px rgba(0,0,0,.35)}
.pj--tall .pj__bottom h3,.pj--wide .pj__bottom h3{font-size:clamp(24px,2.6vw,40px)}
.pj__bottom h3 em{color:var(--accent);font-style:italic}
.pj__bottom p{font-size:13px;line-height:1.5;color:rgba(255,255,255,.92);max-width:52ch;max-height:0;opacity:0;overflow:hidden;transition:max-height .5s var(--ease-o), opacity .4s var(--ease);text-shadow:0 1px 14px rgba(0,0,0,.4)}
.pj:hover .pj__bottom p{max-height:120px;opacity:1}

.pj__data{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:4px;background:rgba(255,255,255,.1);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.14);border-radius:12px;overflow:hidden;padding:1px}
.pj__data > div{display:flex;flex-direction:column;gap:3px;padding:10px 12px;background:rgba(28,28,28,.22)}
.pj__data span{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.pj__data b{font-family:var(--f-mono);font-weight:500;font-size:12px;letter-spacing:.02em;color:#fff}

.pj__cta{display:inline-flex;align-items:center;gap:8px;width:fit-content;margin-top:4px;padding:9px 16px;background:rgba(255,255,255,.08);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:999px;color:#fff;font-family:var(--f-sans);font-size:12px;font-weight:500;letter-spacing:.02em;max-height:0;opacity:0;padding-top:0;padding-bottom:0;border-width:0;overflow:hidden;transition:max-height .4s var(--ease-o), opacity .3s var(--ease), padding .4s var(--ease-o), border-width 0s linear .4s, background .25s var(--ease), gap .25s var(--ease)}
.pj:hover .pj__cta{max-height:40px;opacity:1;padding:9px 16px;border-width:1px;transition:max-height .4s var(--ease-o), opacity .3s var(--ease) .1s, padding .4s var(--ease-o), border-width 0s linear, background .25s var(--ease), gap .25s var(--ease)}
.pj__cta:hover{background:var(--accent);border-color:var(--accent);gap:12px}

/* foot marquee */
.proj-foot{max-width:1400px;margin:70px auto 0;padding:0 var(--pad-x);display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center}
.proj-foot > .mono{color:var(--muted);font-size:11px;letter-spacing:.1em;text-transform:uppercase}
.proj-foot__ticker{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;color:var(--muted);padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.proj-foot__ticker span:not(:nth-child(even)){color:var(--ink)}
.proj-foot__ticker span:last-child{color:var(--accent);font-weight:500}
.proj-foot__link{display:inline-flex;align-items:center;gap:10px;font-family:var(--f-sans);font-size:13px;font-weight:500;color:var(--ink);padding:12px 20px;background:var(--ink);color:var(--on-dark);border-radius:999px;transition:background .3s var(--ease), gap .25s var(--ease)}
.proj-foot__link:hover{background:var(--accent);gap:14px}
.proj-foot__link svg{transition:transform .3s var(--ease)}
.proj-foot__link:hover svg{transform:translateX(4px)}

@media(max-width:1000px){
  .proj-head{grid-template-columns:1fr;gap:40px;padding-top:100px;padding-bottom:50px}
  .proj-head__right{padding-bottom:0}
}
@media(max-width:900px){
  .proj-grid{grid-template-columns:1fr;gap:14px}
  .pj,.pj--tall,.pj--wide{grid-column:span 1;grid-row:auto;aspect-ratio:16/11}
  .pj__bottom p{max-height:80px;opacity:1}
  .pj__cta{max-height:40px;opacity:1;padding:9px 16px;border-width:1px}
  .proj-foot{grid-template-columns:1fr;text-align:center;gap:16px}
  .proj-foot__link{justify-self:center}
  .proj-head__stats{grid-template-columns:repeat(3,1fr);gap:4px}
}

/* ============ TESTIMONIALS — split-screen carousel (dark) ============ */
.testimonials{position:relative;background:var(--dark);color:var(--on-dark);overflow:hidden;padding:0}
.tm-split{display:grid;grid-template-columns:1fr 1fr;min-height:min(820px,92vh)}

/* LEFT — image stack + brand meta */
.tm-split__media{position:relative;overflow:hidden;background:#0c0c0c;isolation:isolate}
.tm-split__images{position:absolute;inset:0;z-index:0}
.tm-split__images img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.08);transition:opacity 1.1s var(--ease-o), transform 12s linear;filter:grayscale(.25) brightness(.55) contrast(1.05)}
.tm-split__images img.is-active{opacity:1;transform:scale(1)}
.tm-split__media::after{content:'';position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(180deg,rgba(28,28,28,.35) 0%,rgba(28,28,28,.55) 50%,rgba(28,28,28,.85) 100%)}
.tm-split__media::before{content:'';position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(90deg,transparent 60%,rgba(28,28,28,.5) 100%)}

.tm-split__media-meta{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:space-between;gap:48px;padding:clamp(40px,5vw,80px)}
.tm-split__kicker{color:var(--accent);display:block}
.tm-split__media-meta h2{font-family:var(--f-serif);font-weight:400;font-size:clamp(44px,5.2vw,86px);line-height:.95;letter-spacing:-.025em;color:var(--on-dark);margin-top:24px}
.tm-split__media-meta h2 em{color:var(--accent);font-style:italic}

.tm-split__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding-top:36px;border-top:1px solid var(--line-d2)}
.tm-stat strong{display:block;font-family:var(--f-serif);font-weight:400;font-size:clamp(36px,3.6vw,52px);line-height:1;color:var(--on-dark);margin-bottom:10px;letter-spacing:-.02em}
.tm-stat strong sup{font-size:.5em;vertical-align:super;color:var(--accent);margin-left:2px}
.tm-stat .mono{color:var(--on-dark-2);font-size:11px;letter-spacing:.08em;text-transform:uppercase}

/* RIGHT — carousel pane */
.tm-split__pane{position:relative;display:flex;flex-direction:column;justify-content:center;gap:48px;padding:clamp(48px,5vw,80px);background:var(--dark);border-left:1px solid var(--line-d)}
.tm-split__pane::before{content:'"';position:absolute;top:24px;right:36px;font-family:var(--f-serif);font-size:280px;font-style:italic;font-weight:400;color:var(--accent);opacity:.08;line-height:1;pointer-events:none}

.tm-split__track{position:relative;flex:1;display:flex;align-items:center;min-height:380px}
.tm-card{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;gap:32px;opacity:0;transform:translateX(40px);transition:opacity .55s var(--ease-o), transform .55s var(--ease-o);pointer-events:none}
.tm-card.is-active{opacity:1;transform:translateX(0);pointer-events:auto}
.tm-card.is-leaving{transform:translateX(-40px)}

.tm-card__top{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.tm-card__stars{display:inline-flex;gap:4px;color:var(--accent)}
.tm-card__stars svg{width:18px;height:18px;fill:currentColor}
.tm-card__label{color:var(--on-dark-2);padding-left:18px;border-left:1px solid var(--line-d2)}

.tm-card blockquote{font-family:var(--f-serif);font-weight:400;font-size:clamp(24px,2.2vw,36px);line-height:1.28;letter-spacing:-.01em;color:var(--on-dark)}
.tm-card blockquote em{color:var(--accent);font-style:italic}

.tm-card__foot{display:flex;align-items:center;gap:18px;padding-top:32px;border-top:1px solid var(--line-d)}
.tm-card__avatar{width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:grid;place-items:center;flex-shrink:0;color:#fff;font-family:var(--f-serif);font-size:22px;font-style:italic;font-weight:400}
.tm-card__who strong{display:block;font-family:var(--f-sans);font-weight:500;font-size:16px;color:var(--on-dark);margin-bottom:4px}
.tm-card__who .mono{color:var(--on-dark-m)}

/* nav row */
.tm-split__nav{display:flex;align-items:center;gap:28px;padding-top:36px;border-top:1px solid var(--line-d)}
.tm-split__count{font-family:var(--f-mono);font-size:13px;color:var(--on-dark-m);display:inline-flex;align-items:baseline;gap:8px;flex-shrink:0}
.tm-split__count strong{font-family:var(--f-serif);font-size:32px;color:var(--on-dark);font-weight:400;letter-spacing:-.02em}
.tm-split__count .sep{opacity:.5;margin:0 4px}

.tm-split__dots{display:flex;gap:8px;flex:1;align-items:center}
.tm-split__dots button{width:36px;height:2px;background:var(--line-d2);border:0;cursor:pointer;padding:0;transition:background .3s var(--ease), width .3s var(--ease)}
.tm-split__dots button:hover{background:var(--on-dark-m)}
.tm-split__dots button.is-active{background:var(--accent);width:56px}

.tm-split__arrows{display:flex;gap:10px;flex-shrink:0}
.tm-arrow{width:48px;height:48px;border-radius:50%;border:1px solid var(--line-d2);background:transparent;color:var(--on-dark);cursor:pointer;display:grid;place-items:center;transition:all .3s var(--ease)}
.tm-arrow:hover{background:var(--accent);border-color:var(--accent);transform:translateY(-2px)}
.tm-arrow svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

@media(max-width:1024px){
  .tm-split{grid-template-columns:1fr;min-height:auto}
  .tm-split__media{min-height:60vh}
  .tm-split__pane{border-left:0;border-top:1px solid var(--line-d)}
  .tm-split__pane::before{font-size:200px;top:8px;right:20px}
  .tm-split__track{min-height:320px}
}
@media(max-width:640px){
  .tm-split__stats{grid-template-columns:1fr 1fr;gap:18px}
  .tm-stat:last-child{grid-column:span 2;border-top:1px solid var(--line-d);padding-top:18px}
  .tm-split__nav{flex-wrap:wrap;gap:20px}
  .tm-split__dots{order:3;flex:0 0 100%}
  .tm-card__label{padding-left:0;border-left:0}
}

/* ============ FAQ ============ */
.faq{background:var(--bg);padding-bottom:160px;position:relative;overflow:hidden}
.faq__list{max-width:1100px;margin:0 auto;padding:0 var(--pad-x);position:relative;z-index:1}
.faq__item{border-top:1px solid var(--line);overflow:hidden;transition:background .3s var(--ease)}
.faq__item:last-child{border-bottom:1px solid var(--line)}
.faq__item[open]{background:rgba(216,50,43,.02)}
.faq__item summary{display:grid;grid-template-columns:60px 1fr 40px;align-items:center;gap:20px;padding:30px 14px;cursor:pointer;list-style:none;transition:padding-left .4s var(--ease)}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary:hover{padding-left:22px}
.faq__item summary > .mono{color:var(--muted);font-size:12px;transition:color .3s var(--ease)}
.faq__q{font-family:var(--f-serif);font-weight:400;font-size:clamp(20px,2.4vw,30px);line-height:1.15;letter-spacing:-.01em;color:var(--ink);transition:color .3s var(--ease)}
.faq__toggle{width:38px;height:38px;border-radius:50%;border:1px solid var(--line-2);display:grid;place-items:center;font-family:var(--f-serif);font-size:22px;font-weight:400;color:var(--muted);transition:transform .4s var(--ease), color .3s var(--ease), border-color .3s var(--ease), background .3s var(--ease);line-height:1}
.faq__item:hover .faq__toggle{border-color:var(--accent);color:var(--accent)}
.faq__item[open] .faq__toggle{transform:rotate(45deg);color:#fff;background:var(--accent);border-color:var(--accent)}
.faq__item[open] summary > .mono{color:var(--accent)}
.faq__item[open] .faq__q{color:var(--accent)}
.faq__a{padding:0 94px 32px 80px;animation:fadeA .5s var(--ease-o)}
.faq__a p{font-size:16px;line-height:1.65;color:var(--text-2);max-width:65ch}
@keyframes fadeA{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:700px){
  .faq__item summary{grid-template-columns:40px 1fr 32px;gap:12px;padding:24px 6px}
  .faq__a{padding:0 0 26px 52px}
  .faq__toggle{width:32px;height:32px;font-size:18px}
}

/* ============ PROCESS ============ */
.process{padding-bottom:160px;background:var(--bg);position:relative;overflow:hidden}
.steps{max-width:1100px;margin:0 auto;padding:0 var(--pad-x);position:relative;z-index:1}
.step{display:grid;grid-template-columns:74px 64px 1fr 140px;gap:24px;align-items:center;padding:34px 0;border-top:1px solid var(--line);transition:padding-left .4s var(--ease)}
.step:last-child{border-bottom:1px solid var(--line)}
.step:hover{padding-left:20px}
.step__n{font-family:var(--f-serif);font-size:clamp(48px,6vw,72px);font-weight:400;color:var(--accent);line-height:1;letter-spacing:-.02em;font-style:italic}
.step__ico{width:52px;height:52px;padding:12px;background:rgba(216,50,43,.08);border-radius:14px;stroke:var(--accent);stroke-width:1.5;fill:none;stroke-linecap:round;stroke-linejoin:round;transition:background .3s var(--ease), transform .4s var(--ease-o)}
.step:hover .step__ico{background:var(--accent);stroke:#fff;transform:rotate(-6deg) scale(1.08)}
.step__c h3{font-family:var(--f-serif);font-weight:400;font-size:clamp(22px,2.6vw,36px);line-height:1.1;letter-spacing:-.01em;margin-bottom:10px;color:var(--ink)}
.step__c p{color:var(--text-2);max-width:58ch;line-height:1.55;font-size:15px}
.step > .mono{text-align:right}

@media(max-width:700px){
  .step{grid-template-columns:50px 44px 1fr;gap:14px;align-items:flex-start}
  .step > .mono{display:none}
  .step__ico{width:40px;height:40px;padding:9px}
}

/* ============ CONTACT (dark) ============ */
.contact{background:var(--dark);color:var(--on-dark);border-top:0;display:grid;grid-template-columns:1fr 1fr;gap:0;min-height:100vh;border-top-left-radius:clamp(20px,4vw,40px);border-top-right-radius:clamp(20px,4vw,40px)}
.contact__left{padding:120px var(--pad-x);display:flex;flex-direction:column;gap:40px;border-right:1px solid var(--line-d);position:relative;overflow:hidden}
.contact__left > *:not(.brand-mark){position:relative;z-index:1}
.contact__left > .mono{color:var(--accent)}
.contact__left h2{font-family:var(--f-serif);font-weight:400;font-size:clamp(40px,5.5vw,82px);line-height:1;letter-spacing:-.025em;color:var(--on-dark);max-width:14ch}
.contact__left h2 em{color:var(--accent)}
.contact__lede{font-size:16px;line-height:1.6;color:var(--on-dark-2);max-width:42ch}

.contact__blocks{display:grid;grid-template-columns:1fr 1fr;gap:30px 20px;margin-top:auto;padding-top:40px}
.contact__blocks > div{display:flex;flex-direction:column;gap:10px;padding:22px 0;border-top:1px solid var(--line-d);position:relative}
.contact__blocks > div > .mono{color:var(--on-dark-m);display:flex;align-items:center;gap:10px}
.contact__blocks__ico{width:16px;height:16px;stroke:var(--accent);stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round}
.contact__blocks a,.contact__blocks p{font-family:var(--f-serif);font-size:clamp(20px,2vw,26px);font-weight:400;line-height:1.35;color:var(--on-dark);transition:color .25s var(--ease)}
.contact__blocks a:hover{color:var(--accent)}

/* direct-contact panel — replaces the form */
.contact__direct{padding:120px var(--pad-x);display:flex;flex-direction:column;gap:30px;justify-content:center;position:relative;overflow:hidden}
.contact__direct > .mono{color:var(--accent)}
.contact__direct__title{font-family:var(--f-serif);font-weight:400;font-size:clamp(36px,5vw,68px);line-height:1;letter-spacing:-.025em;color:var(--on-dark)}
.contact__direct__title em{color:var(--accent);font-style:italic}
.contact__direct__lede{font-size:16px;line-height:1.6;color:var(--on-dark-2);max-width:44ch}

.contact__direct__channels{display:flex;flex-direction:column;margin-top:20px}
.contact__direct__channel{display:grid;grid-template-columns:90px 1fr 48px;gap:24px;align-items:center;padding:30px 0;border-top:1px solid var(--line-d);transition:padding-left .4s var(--ease), color .35s var(--ease);color:var(--on-dark);position:relative;overflow:hidden}
.contact__direct__channel:last-child{border-bottom:1px solid var(--line-d)}
.contact__direct__channel::before{content:'';position:absolute;left:0;top:0;width:0;height:100%;background:linear-gradient(90deg,rgba(216,50,43,.06) 0%,transparent 60%);transition:width .5s var(--ease-o);pointer-events:none;z-index:-1}
.contact__direct__channel:hover{padding-left:18px;color:var(--accent)}
.contact__direct__channel:hover::before{width:100%}
.contact__direct__channel .mono{color:var(--on-dark-m);transition:color .3s var(--ease)}
.contact__direct__channel:hover .mono{color:var(--accent)}
.contact__direct__channel strong{font-family:var(--f-serif);font-weight:400;font-size:clamp(24px,3vw,40px);letter-spacing:-.018em;line-height:1;word-break:break-all;transition:transform .4s var(--ease)}
.contact__direct__channel:hover strong{transform:translateX(4px)}
.contact__direct__arrow{display:grid;place-items:center;width:48px;height:48px;border-radius:50%;border:1px solid var(--line-d2);transition:all .35s var(--ease);justify-self:end}
.contact__direct__channel:hover .contact__direct__arrow{background:var(--accent);border-color:var(--accent);transform:translateX(4px)}
.contact__direct__arrow svg{width:18px;height:18px;stroke:currentColor;stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round}

.contact__direct__trust{list-style:none;margin:30px 0 0;padding:0;display:flex;flex-direction:column;gap:10px}
.contact__direct__trust li{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--on-dark-m);display:flex;align-items:center;gap:10px}
.contact__direct__trust li::before{content:'';width:14px;height:14px;border-radius:50%;background:rgba(34,167,84,.18);display:grid;place-items:center;flex-shrink:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2322a754' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");background-size:8px 8px;background-position:center;background-repeat:no-repeat}

@media(max-width:900px){
  .contact{grid-template-columns:1fr;min-height:auto}
  .contact__left{border-right:0;border-bottom:1px solid var(--line-d);padding:80px var(--pad-x)}
  .contact__direct{padding:80px var(--pad-x)}
  .contact__direct__channel{grid-template-columns:70px 1fr 42px;gap:14px;padding:24px 0}
  .contact__direct__arrow{width:42px;height:42px}
  .contact__blocks{grid-template-columns:1fr}
}

/* ============ FOOTER (dark) ============ */
.footer{padding:40px var(--pad-x) 30px;background:var(--dark);color:var(--on-dark);border-top:1px solid var(--line-d);position:relative;overflow:hidden}
.footer__top{display:flex;justify-content:space-between;align-items:center;padding:20px 0 40px;border-bottom:1px solid var(--line-d);flex-wrap:wrap;gap:20px}
.footer__brand{display:flex;align-items:center;gap:14px}
.footer__brand img{width:44px;height:44px;object-fit:contain;background:var(--on-dark);padding:4px;border-radius:10px}
.footer__brand strong{font-family:var(--f-sans);font-weight:700;font-size:15px;color:var(--on-dark);letter-spacing:.01em;text-transform:uppercase;display:block}
.footer__brand span{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--on-dark-m)}
.footer__trust{display:flex;gap:24px;flex-wrap:wrap;align-items:center}
.footer__trust span{display:inline-flex;align-items:center;gap:8px;font-family:var(--f-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--on-dark-2)}
.footer__trust svg{stroke:var(--accent);stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round;width:14px;height:14px}

.footer__big{font-family:var(--f-serif);font-weight:400;font-size:clamp(120px,22vw,320px);line-height:.85;letter-spacing:-.04em;color:var(--on-dark);padding:60px 0 30px;white-space:nowrap}
.footer__big em{color:var(--accent);font-style:italic}
.footer__tagline{font-family:var(--f-serif);font-size:clamp(22px,3vw,36px);line-height:1.3;color:var(--on-dark-2);max-width:30ch;padding-bottom:70px;letter-spacing:-.01em}
.footer__tagline em{color:var(--accent);font-style:italic}

.footer__cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-top:40px;border-top:1px solid var(--line-d)}
.footer__col{display:flex;flex-direction:column;gap:8px}
.footer__cols .mono{color:var(--on-dark-m);margin-bottom:10px}
.footer__cols p{color:var(--on-dark-2);font-size:14px;max-width:40ch;line-height:1.5;margin-top:0}
.footer__cols a{font-size:14px;color:var(--on-dark-2);transition:color .25s var(--ease), padding-left .25s var(--ease)}
.footer__cols a:hover{color:var(--accent);padding-left:4px}

.footer__bottom{margin-top:60px;padding-top:26px;border-top:1px solid var(--line-d);display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;color:var(--on-dark-m);font-family:var(--f-mono);font-size:11px;letter-spacing:.08em}
.footer__bottom a{color:var(--on-dark-m);transition:color .25s}
.footer__bottom a:hover{color:var(--accent)}
.footer__bottom__credit{text-align:center;flex:1}
.footer__bottom__credit a{color:var(--on-dark-2);border-bottom:1px solid transparent;transition:color .25s var(--ease), border-color .25s var(--ease)}
.footer__bottom__credit a:hover{color:var(--accent);border-bottom-color:var(--accent)}
.footer__bottom__to-top{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid var(--line-d2);border-radius:999px;transition:border-color .25s var(--ease), color .25s var(--ease)}
.footer__bottom__to-top:hover{border-color:var(--accent);color:var(--accent)}
.footer__bottom__to-top svg{stroke:currentColor;stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round;width:12px;height:12px}

@media(max-width:900px){.footer__cols{grid-template-columns:1fr 1fr}}
@media(max-width:500px){.footer__cols{grid-template-columns:1fr}.footer__bottom{flex-direction:column;align-items:flex-start}}

/* ============ COOKIE BANNER (bottom-left, dismissible, localStorage) ============ */
.cookies{position:fixed;left:24px;bottom:24px;width:min(380px,calc(100vw - 48px));background:var(--dark);color:var(--on-dark);border-radius:18px;padding:24px 26px;z-index:120;box-shadow:0 30px 60px -20px rgba(0,0,0,.45), 0 0 0 1px var(--line-d2);transform:translateY(120%) scale(.96);opacity:0;transition:transform .65s cubic-bezier(.34,1.36,.64,1), opacity .4s var(--ease);pointer-events:none;display:flex;flex-direction:column;gap:14px;font-family:var(--f-body)}
.cookies.is-visible{transform:translateY(0) scale(1);opacity:1;pointer-events:auto}
.cookies__top{display:flex;justify-content:space-between;align-items:center}
.cookies__kicker{color:var(--accent);font-size:11px;letter-spacing:.1em;text-transform:uppercase;font-family:var(--f-mono)}
.cookies__close{background:transparent;border:0;color:var(--on-dark-m);font-size:22px;line-height:1;cursor:pointer;width:28px;height:28px;display:grid;place-items:center;border-radius:50%;transition:background .25s var(--ease), color .25s var(--ease)}
.cookies__close:hover{background:var(--line-d2);color:var(--on-dark)}
.cookies__title{font-family:var(--f-serif);font-weight:400;font-size:22px;line-height:1.1;color:var(--on-dark);letter-spacing:-.015em}
.cookies__body{font-size:13px;line-height:1.55;color:var(--on-dark-2)}
.cookies__body a{color:var(--accent);border-bottom:1px solid currentColor;transition:opacity .2s var(--ease)}
.cookies__body a:hover{opacity:.7}
.cookies__actions{display:flex;gap:8px;margin-top:4px}
.cookies__btn{flex:1;font-family:var(--f-sans);font-weight:500;font-size:12px;letter-spacing:.04em;padding:12px 16px;border-radius:999px;cursor:pointer;transition:background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease);border:1px solid transparent}
.cookies__btn--ghost{background:transparent;color:var(--on-dark-2);border-color:var(--line-d2)}
.cookies__btn--ghost:hover{background:var(--line-d2);color:var(--on-dark)}
.cookies__btn--primary{background:var(--accent);color:#fff}
.cookies__btn--primary:hover{background:var(--accent-2)}
@media(max-width:560px){
  .cookies{left:12px;right:12px;bottom:12px;width:auto;padding:20px}
  .cookies__title{font-size:19px}
}

/* ============ LEGAL PAGES (Impressum, Datenschutz) ============ */
.legal{max-width:780px;margin:0 auto;padding:140px var(--pad-x) 100px;color:var(--ink);position:relative;z-index:1}
.legal__head{margin-bottom:50px;padding-bottom:32px;border-bottom:1px solid var(--line)}
.legal__head .mono{color:var(--accent);display:inline-block;margin-bottom:18px;font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-family:var(--f-mono)}
.legal__head h1{font-family:var(--f-serif);font-weight:400;font-size:clamp(44px,6.4vw,90px);line-height:.98;letter-spacing:-.03em;color:var(--ink)}
.legal__head h1 em{color:var(--accent);font-style:italic}
.legal__head .legal__meta{font-family:var(--f-mono);font-size:11px;color:var(--muted);margin-top:22px;letter-spacing:.08em;text-transform:uppercase}

.legal__section{margin-top:56px}
.legal__section + .legal__section{padding-top:48px;border-top:1px solid var(--line)}
.legal__section h2{font-family:var(--f-serif);font-weight:400;font-size:clamp(26px,3vw,40px);line-height:1.08;letter-spacing:-.02em;color:var(--ink);margin-bottom:22px}
.legal__section h2 .mono{display:block;font-family:var(--f-mono);font-size:11px;color:var(--accent);letter-spacing:.1em;text-transform:uppercase;margin-bottom:10px;font-weight:500}
.legal__section h3{font-family:var(--f-sans);font-weight:500;font-size:16px;color:var(--ink);margin-top:28px;margin-bottom:10px;letter-spacing:-.005em}
.legal__section p,.legal__section li{font-family:var(--f-body);font-size:15px;line-height:1.7;color:var(--text-2)}
.legal__section p + p{margin-top:14px}
.legal__section ul,.legal__section ol{margin-left:22px;margin-top:12px}
.legal__section li + li{margin-top:6px}
.legal__section a{color:var(--accent);border-bottom:1px solid transparent;transition:border-color .25s var(--ease);word-break:break-word}
.legal__section a:hover{border-bottom-color:var(--accent)}

.legal__contact{display:grid;grid-template-columns:140px 1fr;gap:14px 24px;margin-top:22px;padding:26px;background:var(--surface);border:1px solid var(--line);border-radius:16px}
.legal__contact dt{font-family:var(--f-mono);font-size:11px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;align-self:center}
.legal__contact dd{font-family:var(--f-sans);font-size:15px;color:var(--ink);margin:0;line-height:1.5}
.legal__contact dd a{color:var(--ink)}
.legal__contact dd a:hover{color:var(--accent)}

@media(max-width:680px){
  .legal{padding-top:120px}
  .legal__contact{grid-template-columns:1fr;gap:14px;padding:22px}
  .legal__contact dt{margin-bottom:-8px}
}

/* ============ MOBILE REFINEMENT ============ */
@media(max-width:760px){
  .sec-head{padding:100px var(--pad-x) 44px}
  .hero{padding:140px var(--pad-x) 40px}
  .hero__title{margin:40px 0 40px}
  .stats,.about__grid,.vision,.why,.projects,.process,.faq,.cta-band,.imarq,.feat,.testimonials{padding-top:100px;padding-bottom:100px}
  .feat{padding-top:90px;padding-bottom:100px}
  .imarq{padding-top:30px;padding-bottom:40px}
  .footer__big{padding:40px 0 20px;font-size:clamp(80px,25vw,200px)}
  .footer__tagline{padding-bottom:40px}
  .contact__left,.contact__direct{padding:70px var(--pad-x)}
}

/* ============ REDUCE MOTION ============ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .ticker__track{animation:none}
}
