/* ============================================================
   2BROTHERS WEB FAMILY — gemeinsame Basis aller drei Marken-Sites
   Theming ausschließlich über Tokens in theme.css:
   --bg --bg-2 --panel --ink --muted --accent --accent-2 --accent-ink
   --grad (Verlauf) --font-display --font-accent
   Familien-Signatur: 12°-Speed-Cut (wie 2B-Monogramm), gemeinsame
   Bewegungssprache (--ease/--dur), identische Bausteine.
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --ease:cubic-bezier(.22,.61,.36,1);
  --dur:.7s;
  --cut:14px;                 /* Speed-Cut-Größe */
  --skew:-12deg;              /* Familien-Winkel = 2B-Monogramm */
  --radius:18px;
  --nav-h:72px;
  --max:1180px;
  --pad:clamp(20px,5vw,48px);
}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  background:var(--bg);color:var(--ink);
  font-family:'Montserrat',system-ui,sans-serif;
  font-size:clamp(15px,1.05vw,17px);line-height:1.65;
  -webkit-font-smoothing:antialiased;overflow-x:clip;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:var(--accent-ink,#fff)}

/* ---------- Layout ---------- */
.wrap{max-width:var(--max);margin-inline:auto;padding-inline:var(--pad)}
section{padding-block:clamp(72px,11vh,130px);position:relative}
.eyebrow{display:flex;align-items:center;gap:14px;font-size:.72rem;font-weight:600;
  letter-spacing:.34em;text-transform:uppercase;color:var(--accent);margin-bottom:18px}
.eyebrow::before{content:"";width:34px;height:2px;background:var(--accent);
  transform:skewX(var(--skew))}
.h-display{font-family:var(--font-display,'Montserrat');font-weight:800;
  font-size:clamp(2rem,5.2vw,3.6rem);line-height:1.06;letter-spacing:-.01em}
.h-display .acc{color:var(--accent)}
.lead{color:var(--muted);max-width:56ch}

/* Diagonale Section-Naht (Familien-Signatur) */
.seam-top{clip-path:polygon(0 0,100% 3.2vw,100% 100%,0 100%)}
.seam-bottom{clip-path:polygon(0 0,100% 0,100% calc(100% - 3.2vw),0 100%)}

/* ---------- Buttons: Speed-Cut + magnetisch ---------- */
.btn{position:relative;display:inline-flex;align-items:center;gap:10px;
  padding:15px 30px;font-weight:700;font-size:.82rem;letter-spacing:.14em;
  text-transform:uppercase;cursor:pointer;border:0;user-select:none;
  clip-path:polygon(var(--cut) 0,100% 0,100% calc(100% - var(--cut)),calc(100% - var(--cut)) 100%,0 100%,0 var(--cut));
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .35s}
.btn-primary{background:var(--grad,var(--accent));color:var(--accent-ink,#fff)}
.btn-ghost{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--ink) 28%,transparent)}
.btn-ghost:hover{box-shadow:inset 0 0 0 2px var(--accent);color:var(--accent)}
.btn-primary::after{content:"";position:absolute;inset:0;
  background:linear-gradient(115deg,transparent 30%,rgba(255,255,255,.35) 50%,transparent 70%);
  transform:translateX(-120%);transition:transform .7s var(--ease)}
.btn-primary:hover::after{transform:translateX(120%)}
.btn:active{transform:scale(.97)}

/* ---------- Nav ---------- */
.nav{position:fixed;inset-inline:0;top:0;z-index:60;height:var(--nav-h);
  display:flex;align-items:center;transition:background .4s,box-shadow .4s,height .4s}
.nav.scrolled{background:color-mix(in srgb,var(--bg) 82%,transparent);
  backdrop-filter:blur(14px);box-shadow:0 1px 0 color-mix(in srgb,var(--ink) 8%,transparent);height:60px}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;gap:20px;width:100%}
.nav-logo img{height:34px;width:auto}
.nav-links{display:flex;gap:26px;list-style:none;align-items:center}
.nav-links a{font-size:.74rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  opacity:.85;position:relative;padding-block:6px}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;
  background:var(--accent);transform:skewX(var(--skew));transition:width .3s var(--ease)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:70;
  background:var(--grad,var(--accent))}
.burger{display:none;background:0;border:0;cursor:pointer;width:40px;height:40px;position:relative;z-index:65}
.burger span{position:absolute;left:8px;right:8px;height:2px;background:var(--ink);transition:.35s var(--ease)}
.burger span:nth-child(1){top:13px}.burger span:nth-child(2){top:19px}.burger span:nth-child(3){top:25px}
.burger.open span:nth-child(1){top:19px;transform:rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){top:19px;transform:rotate(-45deg)}
@media(max-width:860px){
  .burger{display:block}
  .nav-links{position:fixed;inset:0;background:color-mix(in srgb,var(--bg) 96%,transparent);
    backdrop-filter:blur(18px);flex-direction:column;justify-content:center;gap:34px;
    opacity:0;pointer-events:none;transition:opacity .35s var(--ease)}
  .nav-links.open{opacity:1;pointer-events:auto}
  .nav-links a{font-size:1.05rem}
}

/* ---------- Loader ---------- */
.loader{position:fixed;inset:0;z-index:100;display:grid;place-items:center;background:var(--bg);
  transition:opacity .55s var(--ease),visibility .55s}
.loader.done{opacity:0;visibility:hidden}
.loader svg,.loader img{width:min(30vw,150px);animation:loaderpulse 1.1s var(--ease) infinite alternate}
@keyframes loaderpulse{from{transform:scale(.94);opacity:.75}to{transform:scale(1);opacity:1}}

/* ---------- Reveal-System ---------- */
.reveal{opacity:0;transform:translateY(34px);transition:opacity var(--dur) var(--ease),transform var(--dur) var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-reveal="left"]{transform:translateX(-40px)}
.reveal[data-reveal="right"]{transform:translateX(40px)}
.reveal[data-reveal="scale"]{transform:scale(.92)}
.reveal[data-reveal="left"].in,.reveal[data-reveal="right"].in,.reveal[data-reveal="scale"].in{transform:none}
[data-stagger]>*{opacity:0;transform:translateY(26px);
  transition:opacity .6s var(--ease),transform .6s var(--ease);transition-delay:var(--d,0s)}
[data-stagger].in>*{opacity:1;transform:none}

/* ---------- Marquee-Band ---------- */
.marquee{overflow:hidden;white-space:nowrap;padding-block:16px;user-select:none;
  background:var(--accent);color:var(--accent-ink,#fff);
  transform:rotate(-1.6deg) scale(1.02);border-block:2px solid color-mix(in srgb,var(--accent-ink,#fff) 18%,transparent)}
.marquee-inner{display:inline-block;animation:marquee var(--marquee-dur,26s) linear infinite}
.marquee span{font-weight:800;font-size:.95rem;letter-spacing:.3em;text-transform:uppercase;margin-right:2.2em}
.marquee span::after{content:"✦";margin-left:2.2em;opacity:.7}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---------- Cards & Tilt ---------- */
.card{background:var(--panel);border-radius:var(--radius);padding:30px;position:relative;
  border:1px solid color-mix(in srgb,var(--ink) 7%,transparent);
  transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .45s}
.card:hover{border-color:color-mix(in srgb,var(--accent) 55%,transparent)}
[data-tilt]{transform-style:preserve-3d;will-change:transform}
[data-tilt] .tilt-inner{transform:translateZ(28px)}

/* ---------- Menü-Zeilen ---------- */
.menu-row{display:flex;align-items:baseline;gap:12px;padding-block:13px;
  border-bottom:1px dashed color-mix(in srgb,var(--ink) 14%,transparent);
  transition:padding-left .3s var(--ease)}
.menu-row:hover{padding-left:8px}
.menu-row:hover .menu-name{color:var(--accent)}
.menu-name{font-weight:600;transition:color .3s}
.menu-dots{flex:1;border-bottom:2px dotted color-mix(in srgb,var(--ink) 22%,transparent);
  transform:translateY(-4px)}
.menu-price{font-weight:800;color:var(--accent);white-space:nowrap;font-variant-numeric:tabular-nums}
.menu-desc{font-size:.85rem;color:var(--muted);width:100%;margin-top:2px}

/* ---------- Status-Chip (auf/zu) ---------- */
.status-chip{display:inline-flex;align-items:center;gap:9px;padding:9px 18px;border-radius:99px;
  font-size:.78rem;font-weight:700;letter-spacing:.06em;
  background:color-mix(in srgb,var(--accent) 13%,transparent);color:var(--ink)}
.status-dot{width:9px;height:9px;border-radius:50%;background:var(--accent);position:relative}
.status-dot::after{content:"";position:absolute;inset:-4px;border-radius:50%;
  border:2px solid var(--accent);animation:pulse 1.6s var(--ease) infinite}
.status-chip.closed .status-dot,.status-chip.closed .status-dot::after{background:#c0392b;border-color:#c0392b}
@keyframes pulse{from{transform:scale(.6);opacity:.9}to{transform:scale(1.5);opacity:0}}

/* ---------- Galerie-Strip + Lightbox ---------- */
.gallery-strip{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;
  padding-block:10px;scrollbar-width:none;cursor:grab}
.gallery-strip::-webkit-scrollbar{display:none}
.gallery-strip figure{flex:0 0 min(72vw,420px);scroll-snap-align:center;margin:0;position:relative;
  border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3}
.gallery-strip img{width:100%;height:100%;object-fit:cover;transform:scale(1.06);
  transition:transform .8s var(--ease)}
.gallery-strip figure:hover img{transform:scale(1.13)}
.gallery-strip figcaption{position:absolute;inset-inline:0;bottom:0;padding:40px 18px 14px;
  font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;color:#fff;
  background:linear-gradient(transparent,rgba(0,0,0,.72))}
.lightbox{position:fixed;inset:0;z-index:90;background:rgba(0,0,0,.92);display:grid;
  place-items:center;opacity:0;pointer-events:none;transition:opacity .35s var(--ease)}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox img{max-width:92vw;max-height:86vh;border-radius:12px}
.lightbox button{position:absolute;top:20px;right:24px;background:0;border:0;color:#fff;
  font-size:2.2rem;cursor:pointer;line-height:1}

/* ---------- Formulare ---------- */
.field{position:relative;margin-bottom:20px}
.field input,.field textarea,.field select{width:100%;padding:16px 16px 12px;
  background:color-mix(in srgb,var(--ink) 5%,transparent);color:var(--ink);
  border:1px solid color-mix(in srgb,var(--ink) 16%,transparent);border-radius:10px;
  font:inherit;transition:border-color .3s,box-shadow .3s;outline:0}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--accent);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 22%,transparent)}
.field label{position:absolute;left:16px;top:14px;color:var(--muted);font-size:.92rem;
  pointer-events:none;transition:.25s var(--ease);background:transparent}
.field input:focus+label,.field input:not(:placeholder-shown)+label,
.field textarea:focus+label,.field textarea:not(:placeholder-shown)+label{
  top:-9px;left:12px;font-size:.68rem;letter-spacing:.08em;color:var(--accent);
  background:var(--bg);padding-inline:6px}
.check{display:flex;gap:10px;align-items:flex-start;font-size:.83rem;color:var(--muted)}
.check input{accent-color:var(--accent);margin-top:3px}
.hp{position:absolute;left:-5000px;opacity:0}

/* ---------- Footer: Watermark + Family-Strip ---------- */
.watermark{font-family:var(--font-display,'Montserrat');font-weight:800;text-align:center;
  font-size:clamp(3.2rem,13vw,11rem);line-height:1;letter-spacing:.02em;user-select:none;
  color:transparent;-webkit-text-stroke:1.5px color-mix(in srgb,var(--ink) 14%,transparent);
  transform:translateY(.18em);pointer-events:none}
.family-strip{border-top:1px solid color-mix(in srgb,var(--ink) 9%,transparent);
  padding-block:26px}
.family-strip .wrap{display:flex;flex-wrap:wrap;align-items:center;gap:22px;justify-content:space-between}
.family-strip .fam-label{font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted)}
.family-logos{display:flex;gap:26px;align-items:center}
.family-logos a{opacity:.55;transition:opacity .3s,transform .3s var(--ease)}
.family-logos a:hover{opacity:1;transform:translateY(-3px)}
.family-logos img{height:26px;width:auto}
.fam-slogan{font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);font-weight:700}

/* ---------- Custom Cursor (nur Desktop-Pointer) ---------- */
@media(pointer:fine){
  .cursor-dot,.cursor-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:120;
    border-radius:50%;translate:-50% -50%}
  .cursor-dot{width:7px;height:7px;background:var(--accent)}
  .cursor-ring{width:34px;height:34px;border:1.5px solid color-mix(in srgb,var(--accent) 65%,transparent);
    transition:width .25s,height .25s,border-color .25s}
  body.cursor-active .cursor-ring{width:52px;height:52px;border-color:var(--accent)}
}

/* ---------- Utilities ---------- */
.scroll-cue{position:absolute;bottom:26px;left:50%;translate:-50%;width:24px;height:40px;
  border:2px solid color-mix(in srgb,var(--ink) 40%,transparent);border-radius:14px}
.scroll-cue::after{content:"";position:absolute;top:7px;left:50%;translate:-50%;width:4px;height:8px;
  border-radius:3px;background:var(--accent);animation:cue 1.6s var(--ease) infinite}
@keyframes cue{50%{transform:translateY(12px);opacity:.2}}
.grain::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)'/%3E%3C/svg%3E")}
canvas.fx{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.egg-item{position:fixed;top:-60px;z-index:110;pointer-events:none;font-size:26px;
  animation:eggfall linear forwards}
@keyframes eggfall{to{transform:translateY(110vh) rotate(340deg)}}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001s!important;animation-iteration-count:1!important;
    transition-duration:.001s!important}
  .reveal,[data-stagger]>*{opacity:1!important;transform:none!important}
}
