/* =========================================================
   GOLD richtig – Master Stylesheet
   Datei: /css/formate.css
   Zweck: Einheitliche Typo, Abstände, Layout, Navigation + Galerie
======================================================== */

/* === DESIGN-VARIABLEN (global, für alle Seiten identisch) === */
:root{
  --btnSize:60px; --btnBorder:2px; --iconSize:44px; --gapMax:20px;
  --arrowW:24px; --framePad:8px; --frameToArrow:6px; --arrowToBtn:0px;
  --glowPad:15px; --blackFill:rgba(17,17,17,.7); --railW:1120px
}

/* Robust: alles mit hidden ist wirklich weg */
[hidden]{display:none !important}

/* === GRUNDLAYOUT / HINTERGRUND === */
body{
  margin:0; min-height:100vh; background:#000; color:#e5e5e5;
  font-family:Arial,Helvetica,sans-serif; position:relative; overflow-x:hidden
}
body:before{
  content:""; position:fixed; inset:0; z-index:-2;
  background:
    radial-gradient(900px 520px at 50% 0%,rgba(212,175,55,.14),rgba(0,0,0,0) 62%),
    radial-gradient(700px 420px at 12% 18%,rgba(212,175,55,.06),rgba(0,0,0,0) 62%),
    radial-gradient(700px 420px at 88% 22%,rgba(212,175,55,.045),rgba(0,0,0,0) 62%),
    linear-gradient(180deg,#070707 0%,#000 55%,#000 100%)
}
body:after{
  content:""; position:fixed; inset:-20%; z-index:-1; pointer-events:none;
  background:radial-gradient(closest-side at 50% 50%,rgba(0,0,0,0) 55%,rgba(0,0,0,.55) 100%);
  opacity:.9
}
a{color:inherit}
.page{min-height:100vh;display:flex;flex-direction:column}

/* =========================================================
   Standard-Textlinks (verbindlich im Content)
   Nutzung: <a class="textlink" ...>…</a>
======================================================== */
.textlink{
  color: rgba(59,130,246,1);      /* Blau */
  text-decoration: none;
}

.textlink:hover{
  color: rgba(37,99,235,1);       /* etwas dunkler */
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}

.textlink:focus-visible{
  outline: 2px solid rgba(37,99,235,.85);
  outline-offset: 3px;
  border-radius: 4px;
}

/* === HEADER / TOPBAR === */
.topbar{
  position:sticky; top:0; z-index:50;
  backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
  background:transparent; border-bottom:none
}
.brandline{
  width:min(var(--railW,1120px),calc(100vw - 24px));
  margin:0 auto; padding:0 22px; box-sizing:border-box;
  display:grid; grid-template-columns:1fr auto; align-items:end;
  column-gap:16px; row-gap:6px
}
.brand{display:flex;align-items:baseline;gap:10px;user-select:none}
.brand .name{display:flex;align-items:flex-end;gap:2px;line-height:1.05}
.brand-gold{
  font-family:"Montserrat","Arial Black",Arial,Helvetica,sans-serif;
  font-weight:800; letter-spacing:1px; font-size:1.25em; color:#ffd96a
}
.brand-script{
  font-family:"Allura","Brush Script MT","Segoe Script","Snell Roundhand",cursive;
  font-style:italic; font-weight:400; font-size:1.45em;
  color:#ffd96a; transform:translateY(2px); margin-left:0
}
.brand .tag{letter-spacing:1.4px;font-size:.82rem;opacity:.85;color:rgba(212,175,55,.95)}
.top-actions{display:flex;align-items:center;gap:6px;transform:translateY(2px);align-self:end}

/* Social */
.social{
  width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:50%;text-decoration:none;
  transition:box-shadow .25s ease,transform .15s ease
}
.social svg{width:18px;height:18px}
.social svg *{
  fill:none;stroke:url(#goldGradient);stroke-width:1.6px;
  stroke-linecap:round;stroke-linejoin:round
}
.social:hover{box-shadow:0 0 12px rgba(212,175,55,.45);transform:translateY(-1px)}

/* Pills */
.pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 12px;border-radius:999px;
  border:1px solid rgba(212,175,55,.35);
  background:rgba(0,0,0,.45);color:#d4af37;
  letter-spacing:1.2px;font-size:.72rem;text-decoration:none;
  transition:box-shadow .25s ease,border-color .25s ease,color .25s ease
}
.pill:hover{border-color:rgba(255,217,106,.75);color:#ffd96a;box-shadow:0 0 14px rgba(212,175,55,.35)}
.pill:focus-visible{outline:2px solid #ffd96a;outline-offset:3px}

/* === MAIN / HERO / PANEL === */
.main{
  width:min(var(--railW,1120px),calc(100vw - 24px));
  margin:0 auto; padding:24px 0 32px; box-sizing:border-box
}
.main-pad{padding:0}
.hero{display:grid;grid-template-columns:1fr;gap:18px;align-items:stretch;margin-top:2px}
.panel{
  border-radius:22px; border:1px solid rgba(212,175,55,.28);
  background:rgba(0,0,0,.55); box-shadow:0 10px 40px rgba(0,0,0,.55);
  overflow:hidden
}
.panel .inner{padding:22px}

.box-title{margin:0 0 10px;letter-spacing:1.6px;color:#fff;font-size:1.05rem}
.lead{margin:12px 0 0;line-height:1.55;color:rgba(229,229,229,.86);max-width:60ch}
.cta-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}

/* === CONTENT-RASTER / BOXEN === */
.section{margin-top:26px}
.grid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:16px;margin-bottom:14px}
/* Box↔Box Abstand = 14 + 12 = 26px gesamt */
.grid > .card + .card{margin-top:12px}

.card{
  border-radius:18px;border:1px solid rgba(212,175,55,.22);
  background:rgba(0,0,0,.45);padding:16px;box-sizing:border-box;
  transition:box-shadow .25s ease,border-color .25s ease,transform .12s ease
}
.card:hover{border-color:rgba(255,217,106,.55);box-shadow:0 0 18px rgba(212,175,55,.18)}
.card .t{margin:0;color:#ffd96a;letter-spacing:1.3px;font-size:.92rem}
.card .p{margin:10px 0 0;color:rgba(229,229,229,.84);line-height:1.55;font-size:.92rem}
.card .p:last-child{margin-bottom:0}

/* =========================================================
   GALERIE: Angebote (nur Optik, Toggle-Logik per JS via hidden)
======================================================== */
.offer{position:relative}

.offer-thumb{
  width:100%;
  height:auto;
  display:block;
  margin-top:12px;
  border-radius:14px;
  border:1px solid rgba(212,175,55,.18);
  background:rgba(0,0,0,.35);
}

.offer-body{margin-top:10px}

/* Toggle als reiner Text-Link (über .textlink vereinheitlicht) */
.offer-toggle{
  display:inline-block;
  margin-top:10px;
  font-size:.82rem;
  letter-spacing:1.1px;
  cursor:pointer;
  user-select:none
}

.offer-photos{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px;
  margin-top:12px;
}
.offer-photos img{
  width:100%;
  height:auto;
  display:block;
  border-radius:12px;
  border:1px solid rgba(212,175,55,.14);
  background:rgba(0,0,0,.35);
}

/* === FOOTER === */
.footer{background:rgba(0,0,0,.65);padding:22px 0}
.footer .wrap{
  width:min(var(--railW,1120px),calc(100vw - 24px));
  margin:0 auto;border-top:1px solid rgba(212,175,55,.25);
  padding-top:16px;display:flex;flex-wrap:wrap;
  justify-content:space-between;gap:12px;color:rgba(229,229,229,.75);
  font-size:.9rem;box-sizing:border-box
}
.footer a{text-decoration:none;color:rgba(212,175,55,.95);letter-spacing:1.2px;font-size:.82rem}
.footer a:hover{color:#ffd96a}
.footer-links{display:flex;gap:14px;flex-wrap:wrap}

/* === HAUPTNAVIGATION (Icon-Leiste mit Scroll-Logik) === */
.nav-shell{display:flex;justify-content:center;padding:6px 12px 20px}
.nav-frame{
  display:inline-block;width:fit-content;max-width:calc(100vw - 24px);
  box-sizing:border-box;overflow:hidden;border:1px solid rgba(212,175,55,.55);
  border-radius:22px;background:rgba(0,0,0,.55)
}
.nav-grid{
  width:100%;display:grid;
  grid-template-columns:var(--arrowW) minmax(0,max-content) var(--arrowW);
  align-items:center;column-gap:var(--frameToArrow);
  padding:0 var(--framePad);box-sizing:border-box
}
.arrow-col{display:flex;justify-content:center;position:relative;z-index:5}
.nav-arrow{
  box-sizing:border-box;font-variant-numeric:tabular-nums;
  width:24px;height:24px;border:1px solid rgba(212,175,55,.6);
  color:#d4af37;background:transparent;border-radius:4px;cursor:pointer;
  user-select:none;display:flex;align-items:center;justify-content:center;
  gap:1px;line-height:1;font-size:.75rem;
  transition:box-shadow .25s ease,border-color .25s ease
}
.nav-arrow .sym{font-size:.95rem;line-height:1;transform:translateY(-1px)}
.nav-arrow .num{font-size:.75rem;line-height:1}
.nav-arrow.is-hidden{opacity:0;pointer-events:none}

.row-clip{
  position:relative;z-index:1;overflow:hidden;max-width:100%;
  box-sizing:border-box;padding:var(--glowPad);
  padding-left:calc(var(--glowPad) + var(--arrowToBtn));
  padding-right:calc(var(--glowPad) + var(--arrowToBtn));
  touch-action:pan-y
}
.nav-row{display:flex;justify-content:center;gap:16px;white-space:nowrap}
.btn-wrap{width:var(--btnSize);display:flex;flex-direction:column;align-items:center;gap:8px;flex:0 0 auto}

.gold-btn{
  width:var(--btnSize);height:var(--btnSize);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 30% 30%,#111,#000);
  border:var(--btnBorder) solid rgba(212,175,55,.85);
  transition:box-shadow .25s ease,border-color .25s ease,transform .12s ease;
  -webkit-tap-highlight-color:transparent
}
.btn-wrap:hover .gold-btn{border-color:#ffd96a;box-shadow:0 0 7px rgba(212,175,55,.8),0 0 14px rgba(212,175,55,.5)}
.gold-btn:focus-visible,.nav-arrow:focus-visible{outline:2px solid #ffd96a;outline-offset:4px;box-shadow:0 0 0 4px rgba(212,175,55,.35)}
.gold-btn:active{transform:scale(.98)}
.btn-wrap.is-active .gold-btn{border-color:#ffd96a;box-shadow:0 0 9px rgba(212,175,55,.85),0 0 16px rgba(212,175,55,.55)}

.btn-label{
  font-size:.75rem;letter-spacing:1.4px;color:#d4af37;
  transition:color .25s ease,text-shadow .25s ease;
  text-decoration:none;display:inline-block
}
.btn-wrap:hover .btn-label{color:#ffd96a;text-shadow:0 0 6px rgba(212,175,55,.6),0 0 14px rgba(212,175,55,.45)}
.btn-wrap.is-active .btn-label{color:#d4af37;cursor:pointer;user-select:none}

.gold-btn svg{width:var(--iconSize);height:var(--iconSize);transform:scale(1.1);transition:transform .25s ease}
.btn-wrap:hover .gold-btn svg{transform:scale(1.2)}
.gold-btn svg *{
  fill:url(#goldGradient);stroke:#000;stroke-width:1px;
  stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke
}
.gold-btn svg .fill-dark{fill:var(--blackFill)!important;stroke:none!important}
.gold-btn svg text{
  fill:#000;stroke:#000;stroke-width:.35;font-weight:200;
  paint-order:stroke fill;vector-effect:non-scaling-stroke;opacity:1
}

/* HOME: Claim-Text bleibt verfügbar */
.btn-wrap[data-id="home"] svg .home-claim-gold{
  fill:url(#goldGradient)!important;stroke:none!important;font-weight:700;letter-spacing:1.5px;opacity:1;transform:none
}
.btn-wrap[data-id="home"] svg .home-claim-script{
  fill:url(#goldGradient)!important;stroke:rgba(0,0,0,.55)!important;stroke-width:.25!important;
  font-family:"Brush Script MT","Segoe Script","Snell Roundhand",cursive;
  font-style:italic;font-weight:400;letter-spacing:.5px;opacity:1;transform:none
}
.btn-wrap[data-id="home"] svg .home-body,
.btn-wrap[data-id="home"] svg .home-crown,
.btn-wrap[data-id="home"] svg .home-group{
  transform-origin:center;will-change:opacity,transform;
  transition:opacity .45s cubic-bezier(.25,.1,.25,1),transform .6s cubic-bezier(.25,.1,.25,1)
}
.btn-wrap[data-id="home"] svg .home-body{opacity:1;transform:translateY(0)}
.btn-wrap[data-id="home"] svg .home-crown{pointer-events:none;opacity:0;transition-delay:90ms}
.btn-wrap[data-id="home"]:hover svg .home-body{opacity:0;transform:translateY(-1px);transition-delay:0ms}
.btn-wrap[data-id="home"]:hover svg .home-crown{opacity:1;transition-delay:90ms}

/* Kleine Icon-Interaktionen */
.btn-wrap[data-id="anfahrt"] svg .pin-dot{fill:none;stroke:#000;stroke-width:1px;transition:fill .25s ease}
.btn-wrap[data-id="anfahrt"]:hover svg .pin-dot{fill:var(--blackFill)}
.btn-wrap[data-id="kontakt"] svg .wa-bubble{opacity:0;transition:opacity .25s ease}
.btn-wrap[data-id="kontakt"] svg .wa-bubble .bubble-shape{
  transform-origin:center;transform-box:fill-box;transform:scale(.55);transition:transform .25s ease
}
.btn-wrap[data-id="kontakt"]:hover svg .wa-bubble{opacity:1}
.btn-wrap[data-id="kontakt"]:hover svg .wa-bubble .bubble-shape{transform:scale(.65)}
.btn-wrap[data-id="impressum"] svg .info{
  transform-box:fill-box;transform-origin:center;transform:translate(0,8px);
  transition:transform .35s cubic-bezier(.25,.8,.25,1)
}
.btn-wrap[data-id="impressum"]:hover svg .info{transform:translate(11px,16px) scale(1.1)}
.btn-wrap[data-id="ankauf"] svg .chev path,
.btn-wrap[data-id="verkauf"] svg .chev path{opacity:0;transition:opacity .25s ease, transform .35s ease}
.btn-wrap[data-id="ankauf"] svg .chev path:first-child,
.btn-wrap[data-id="verkauf"] svg .chev path:first-child{
  opacity:1;transform:scale(4.5);transform-origin:center;transform-box:fill-box
}
.btn-wrap[data-id="ankauf"] svg .chev path:first-child{transform:scale(4.5) translateY(-1px)}
.btn-wrap[data-id="verkauf"] svg .chev path:first-child{transform:scale(4.5) translateY(1px)}
.btn-wrap[data-id="ankauf"] svg .chev{transform:translateY(3px)}
.btn-wrap[data-id="verkauf"] svg .chev{transform:translateY(-3px)}
.btn-wrap[data-id="ankauf"]:hover svg .chev,
.btn-wrap[data-id="verkauf"]:hover svg .chev{transform:translateY(0)}
.btn-wrap[data-id="ankauf"]:hover svg .chev path,
.btn-wrap[data-id="verkauf"]:hover svg .chev path{opacity:1}
.btn-wrap[data-id="ankauf"]:hover svg .chev path:first-child,
.btn-wrap[data-id="verkauf"]:hover svg .chev path:first-child{transform:scale(1) translateY(0)}
.btn-wrap[data-id="galerie"] svg .photo{transform-box:fill-box;transform-origin:center;transition:transform .35s cubic-bezier(.25,.8,.25,1)}
.btn-wrap[data-id="galerie"] svg .photo.back{transform:scale(1.14) translate(0,1px)}
.btn-wrap[data-id="galerie"] svg .photo.front{transform:scale(1.14) translate(8px,5px)}
.btn-wrap[data-id="galerie"]:hover svg .photo.back{transform:scale(1.19) translate(-2px,-1px)}
.btn-wrap[data-id="galerie"]:hover svg .photo.front{transform:scale(1.19) translate(10px,7px)}

/* === RESPONSIVE === */
@media (max-width:920px){
  .grid{grid-template-columns:1fr}
  .offer-photos{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:900px){
  .hero{grid-template-columns:1fr}
  .social{width:26px;height:26px}
  .social svg{width:17px;height:17px}
  .brand .tag{
    display:block!important;
    font-size:clamp(.62rem,2.2vw,.78rem);
    letter-spacing:1.1px;opacity:.9;white-space:normal;max-width:100%
  }
}
@media (max-width:520px){
  .brand{flex-wrap:wrap;gap:2px 10px;align-items:flex-end}
  .brand .tag{
    flex-basis:100%;margin-top:0;
    font-size:clamp(.6rem,3.2vw,.76rem);
    line-height:1.1;white-space:normal
  }
  .offer-photos{grid-template-columns:1fr}
}