/* ============================================================
   2'BROTHERS — Marken-Theme (v2) über base.css
   Tokens exakt nach work/shared/DESIGN-LANGUAGE.md (Spalte 2brothers)
   ============================================================ */

/* ---------- Fonts (lokal, woff2) ---------- */
@font-face{font-family:'Montserrat';font-style:normal;font-weight:400;font-display:swap;
  src:url("../fonts/montserrat-regular.woff2") format("woff2")}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:600;font-display:swap;
  src:url("../fonts/montserrat-semibold.woff2") format("woff2")}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:800;font-display:swap;
  src:url("../fonts/montserrat-extrabold.woff2") format("woff2")}

/* ---------- Marken-Tokens ---------- */
:root{
  --bg:#070707;
  --bg-2:#0e0e0e;
  --panel:#141414;
  --ink:#f2f2f2;
  --muted:#9a9a9a;
  --accent:#f47b20;
  --accent-2:#e3e3e3;            /* Silber */
  --grad:linear-gradient(135deg,#f9a03f,#e85d04);
  --accent-ink:#fff;             /* auf Silber: #0a0a0a (siehe .on-silver) */
  --font-display:'Montserrat';
  --font-accent:'Montserrat';    /* 2brothers: Montserrat Italic als Würze */
  --marquee-dur:30s;
}
.on-silver{background:var(--accent-2);color:#0a0a0a}

/* ---------- Nav: Monogramm + Wortmarke ---------- */
.nav-logo{display:inline-flex;align-items:center;gap:12px}
.nav-logo img{height:30px}
.nav-logo span{font-weight:800;font-size:.9rem;letter-spacing:.22em}
.nav-logo em{font-style:normal;color:var(--accent)}

/* ============================================================
   HERO — „Get ready to take off?"
   ============================================================ */
.hero{min-height:min(100svh,1080px);display:flex;align-items:center;justify-content:center;
  text-align:center;padding-block:calc(var(--nav-h) + 46px) 96px;overflow:clip}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:50% 30%;
  animation:hero-zoom 5.5s var(--ease) both}
@keyframes hero-zoom{from{transform:scale(1.07)}to{transform:scale(1)}}
.hero-bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(7,7,7,.66),rgba(7,7,7,.16) 32%,rgba(7,7,7,.42) 68%,#070707 98%),
  radial-gradient(130% 95% at 50% 38%,transparent 42%,rgba(7,7,7,.78) 100%)}
.hero canvas.fx{z-index:1}
.hero .wrap{position:relative;z-index:2;display:grid;justify-items:center;gap:20px;width:100%}
.hero .status-chip{backdrop-filter:blur(6px);
  background:color-mix(in srgb,var(--accent) 16%,rgba(7,7,7,.5))}
/* Logo-Crop: die Tagline steckt unten im SVG — das H1 übernimmt sie */
.hero-logo{width:min(360px,62vw);aspect-ratio:992/486;overflow:hidden;
  filter:drop-shadow(0 14px 44px rgba(0,0,0,.65))}
.hero-logo img{width:100%;height:auto}
.hero-title{font-size:clamp(2.4rem,7vw,5.2rem);line-height:1.04;letter-spacing:.01em;
  text-wrap:balance;margin-top:4px}
.hero-title .acc{text-shadow:0 0 38px rgba(244,123,32,.5)}
.hero-sub{color:var(--muted);font-style:italic;font-size:clamp(.98rem,1.4vw,1.18rem);max-width:46ch}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;margin-top:10px}

/* ============================================================
   STORY — Zwei Brüder, ein Anspruch
   ============================================================ */
.story{background:var(--bg-2)}
.story-grid{display:grid;grid-template-columns:minmax(0,5fr) minmax(0,6fr);
  gap:clamp(34px,5vw,68px);align-items:center}
.story-media{margin:0;position:relative}
.story-media::before{content:"";position:absolute;inset:-12% -8%;z-index:0;
  background:radial-gradient(50% 50% at 50% 58%,rgba(244,123,32,.17),transparent 70%)}
.story-media .tilt-inner{position:relative;border-radius:var(--radius);overflow:hidden;
  border:1px solid color-mix(in srgb,var(--accent) 26%,transparent);
  box-shadow:0 34px 90px -24px rgba(0,0,0,.8)}
.story-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/4.6}
.story-media figcaption{position:absolute;inset-inline:0;bottom:0;padding:52px 20px 16px;
  font-size:.7rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:#fff;
  background:linear-gradient(transparent,rgba(0,0,0,.78))}
.story-stats{display:flex;gap:clamp(20px,3.6vw,48px);flex-wrap:wrap;margin-top:32px}
.stat{display:grid;gap:4px;justify-items:start}
.stat-num{font-weight:800;font-size:clamp(1.9rem,3.4vw,2.7rem);line-height:1;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  font-variant-numeric:tabular-nums}
.stat-label{font-size:.68rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.value-chips{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}
.chip{padding:9px 18px;border-radius:99px;font-size:.7rem;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;color:var(--accent-2);
  border:1px solid color-mix(in srgb,var(--accent) 45%,transparent);
  background:color-mix(in srgb,var(--accent) 9%,transparent)}

/* ============================================================
   MARKEN — Ein Haus, zwei Geschmäcker (ambient.jpg als Bühne)
   ============================================================ */
.brands{background:
  linear-gradient(180deg,rgba(7,7,7,.9),rgba(7,7,7,.84) 45%,rgba(7,7,7,.94)),
  url("../img/v2/ambient.jpg") center/cover no-repeat var(--bg)}
@media(pointer:fine) and (min-width:861px){.brands{background-attachment:fixed}}
.brands .lead{margin-top:8px}
.brand-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,320px),1fr));
  gap:clamp(20px,3vw,36px);margin-top:46px}
.brand-card{padding:0;overflow:hidden}
.brand-card .tilt-inner{display:flex;flex-direction:column;height:100%}
.brand-logo-pane{position:relative;background:#1c1c1c;display:grid;place-items:center;
  padding:clamp(26px,4vw,44px);height:250px;
  clip-path:polygon(0 0,100% 0,100% calc(100% - 26px),calc(100% - 26px) 100%,0 100%)}
.brand-logo-pane::before{content:"";position:absolute;inset:0;pointer-events:none}
.brand-card.vm .brand-logo-pane::before{
  background:radial-gradient(62% 62% at 50% 50%,rgba(244,123,32,.16),transparent 74%)}
.brand-card.sb .brand-logo-pane::before{
  background:radial-gradient(62% 62% at 50% 50%,rgba(149,165,93,.18),transparent 74%)}
.brand-logo-pane img{position:relative;width:auto;height:auto;max-width:min(320px,76%);
  max-height:172px;transition:transform .6s var(--ease)}
.brand-card:hover .brand-logo-pane img{transform:scale(1.05)}
.brand-body{padding:26px 28px 30px;display:grid;gap:12px;align-content:start;flex:1}
.brand-tag{font-size:.64rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--muted)}
.brand-body h3{font-size:1.3rem;font-weight:800;letter-spacing:.01em}
.brand-body p{color:var(--muted);font-size:.94rem}
.card-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:14px}
.card-actions .btn{padding:13px 22px;font-size:.72rem}
.brand-card.sb:hover{border-color:color-mix(in srgb,#95a55d 60%,transparent)}
/* Licht-Sweep über die ganze Karte (Muster von .btn-primary::after) */
.brand-card::after{content:"";position:absolute;inset:0;z-index:3;pointer-events:none;
  background:linear-gradient(115deg,transparent 32%,rgba(255,255,255,.13) 50%,transparent 68%);
  transform:translateX(-140%);transition:transform .9s var(--ease)}
.brand-card:hover::after{transform:translateX(140%)}

/* ============================================================
   STANDORT — texture.jpg als Hintergrundfläche
   ============================================================ */
.location{background:
  linear-gradient(180deg,rgba(10,10,10,.78),rgba(7,7,7,.92)),
  url("../img/v2/texture.jpg") center/cover no-repeat var(--bg-2)}
.location-grid{display:grid;grid-template-columns:minmax(0,5fr) minmax(0,6fr);
  gap:clamp(34px,5vw,64px);align-items:center}
.location address{font-style:normal;font-weight:800;
  font-size:clamp(1.45rem,2.6vw,2.05rem);line-height:1.3;margin-block:18px 14px}
.location address .acc{color:var(--accent)}
.location .lead{margin-bottom:26px}
.map-box{position:relative;min-height:380px;border-radius:var(--radius);overflow:hidden;
  display:grid;place-content:center;justify-items:center;gap:18px;text-align:center;
  padding:36px;background:color-mix(in srgb,var(--panel) 78%,transparent);
  border:1px dashed color-mix(in srgb,var(--ink) 22%,transparent);backdrop-filter:blur(5px)}
.map-box p{color:var(--muted);font-size:.86rem;max-width:44ch}

/* ============================================================
   KONTAKT
   ============================================================ */
.contact{background:var(--bg-2)}
.contact-grid{display:grid;grid-template-columns:minmax(0,5fr) minmax(0,7fr);
  gap:clamp(34px,5vw,64px);align-items:start}
.phone-label{margin-top:26px;font-size:.68rem;font-weight:600;letter-spacing:.26em;
  text-transform:uppercase;color:var(--muted)}
.phone-big{display:inline-block;margin-top:6px;font-weight:800;
  font-size:clamp(1.5rem,2.8vw,2.1rem);line-height:1.2;transition:color .3s}
.phone-big:hover{color:var(--accent)}
.contact-form{background:var(--panel);border-radius:var(--radius);
  border:1px solid color-mix(in srgb,var(--ink) 8%,transparent);
  padding:clamp(26px,3.6vw,42px)}
.contact-form .field input:focus+label,
.contact-form .field input:not(:placeholder-shown)+label,
.contact-form .field textarea:focus+label,
.contact-form .field textarea:not(:placeholder-shown)+label{background:var(--panel)}
.contact-form .check{margin-block:6px 16px}
.form-note{min-height:1.4em;margin-bottom:14px;font-size:.85rem;color:var(--accent-2)}

/* ============================================================
   FOOTER — Watermark + Family-Strip + Fußzeile
   ============================================================ */
.footer{background:var(--bg);padding-top:clamp(46px,8vh,86px)}
.watermark-clip{overflow:hidden}
.footer-line{border-top:1px solid color-mix(in srgb,var(--ink) 9%,transparent)}
.footer-line .wrap{display:flex;align-items:center;justify-content:space-between;
  gap:16px;flex-wrap:wrap;padding-block:22px;font-size:.78rem;color:var(--muted)}
.footer-line nav{display:flex;gap:20px}
.footer-line a{transition:color .3s}
.footer-line a:hover{color:var(--accent)}

/* ============================================================
   GIMMICK — Rakete am rechten Rand (Desktop)
   ============================================================ */
.rocket{position:fixed;right:clamp(16px,3.2vw,46px);bottom:8vh;z-index:45;width:38px;
  pointer-events:none;transform:translateY(var(--ry,0px));
  transition:transform .25s linear;will-change:transform;
  filter:drop-shadow(0 0 14px rgba(244,123,32,.22))}
.rocket svg{display:block;width:100%;height:auto;overflow:visible}
.rocket .rocket-flame{opacity:0;transform-box:fill-box;transform-origin:top center;
  transform:scaleY(.2)}
.rocket.ignite .rocket-flame{opacity:1;animation:flame .2s linear infinite alternate}
@keyframes flame{from{transform:scaleY(.7) scaleX(.85)}to{transform:scaleY(1.12) scaleX(1.05)}}
.rocket.ignite svg{animation:rumble .16s linear infinite}
@keyframes rumble{0%{translate:0 0}25%{translate:.9px -.5px}50%{translate:-.8px .6px}
  75%{translate:.5px .9px}100%{translate:-.6px -.7px}}
.rocket::before{content:"";position:absolute;left:50%;top:97%;translate:-50%;width:3px;height:0;
  border-radius:3px;opacity:0;pointer-events:none;
  background:linear-gradient(#ffe2ae,rgba(244,123,32,.55),transparent);
  transition:height .3s var(--ease),opacity .3s}
.rocket.ignite::before{height:26px;opacity:.7}
.rocket.launch{transition:transform 1.1s cubic-bezier(.55,0,.85,.4);
  transform:translateY(calc(var(--ry,0px) - 130vh))}
.rocket.launch .rocket-flame{opacity:1;transform:scaleY(1.5)}
.rocket.launch::before{height:42vh;opacity:.95}
@media(max-width:860px){.rocket{display:none}}
@media(prefers-reduced-motion:reduce){.rocket{display:none}}

/* ============================================================
   Rechtsseiten (Impressum / Datenschutz)
   ============================================================ */
.legal-main{max-width:860px;margin-inline:auto;padding-inline:var(--pad);
  padding-block:calc(var(--nav-h) + clamp(42px,8vh,84px)) clamp(60px,9vh,100px)}
.legal-main h1{font-weight:800;font-size:clamp(1.9rem,4.2vw,2.9rem);letter-spacing:-.01em;
  margin-bottom:8px}
.legal-main h1::after{content:"";display:block;width:56px;height:3px;margin-top:18px;
  background:var(--grad);transform:skewX(var(--skew))}
.legal-main h2{font-size:1rem;font-weight:700;letter-spacing:.05em;color:var(--accent);
  margin:34px 0 10px}
.legal-main p,.legal-main li{color:var(--muted);font-size:.95rem}
.legal-main strong{color:var(--ink)}
.legal-main ul{padding-left:22px;margin-block:10px}
.legal-main a{color:var(--ink);text-decoration:underline;text-underline-offset:3px;
  transition:color .3s}
.legal-main a:hover{color:var(--accent)}
.placeholder{color:var(--accent);border-bottom:1px dashed var(--accent)}

/* ============================================================
   Responsive
   ============================================================ */
@media(max-width:900px){
  .story-grid,.location-grid,.contact-grid{grid-template-columns:1fr}
  .story-media{max-width:480px;margin-inline:auto}
  .map-box{min-height:320px}
}
