/* =====================================================================
   Hausverwaltung Brombach — style.css
   Design: Vertrauens-Blau + Messing-Akzent, warmes Off-White
   Typo: Fraunces (Display, Serife) + Inter (Body)
   A11y: WCAG 2.2 AA+ — Fokus sichtbar, Kontraste, reduced-motion
   ===================================================================== */

/* ---- Self-hosted Fonts ---- */
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;
  src:url('../fonts/inter-latin-400-normal.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;
  src:url('../fonts/inter-latin-ext-400-normal.woff2') format('woff2');
  unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/inter-latin-500-normal.woff2') format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/inter-latin-ext-500-normal.woff2') format('woff2');unicode-range:U+0100-024F,U+1E00-1EFF,U+20A0-20CF,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/inter-latin-600-normal.woff2') format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/inter-latin-ext-600-normal.woff2') format('woff2');unicode-range:U+0100-024F,U+1E00-1EFF,U+20A0-20CF,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/inter-latin-700-normal.woff2') format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/inter-latin-ext-700-normal.woff2') format('woff2');unicode-range:U+0100-024F,U+1E00-1EFF,U+20A0-20CF,U+2C60-2C7F,U+A720-A7FF;}

@font-face{font-family:'Fraunces';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/fraunces-latin-500-normal.woff2') format('woff2');}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/fraunces-latin-ext-500-normal.woff2') format('woff2');unicode-range:U+0100-024F,U+1E00-1EFF,U+20A0-20CF,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/fraunces-latin-600-normal.woff2') format('woff2');}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/fraunces-latin-ext-600-normal.woff2') format('woff2');unicode-range:U+0100-024F,U+1E00-1EFF,U+20A0-20CF,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/fraunces-latin-700-normal.woff2') format('woff2');}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/fraunces-latin-ext-700-normal.woff2') format('woff2');unicode-range:U+0100-024F,U+1E00-1EFF,U+20A0-20CF,U+2C60-2C7F,U+A720-A7FF;}

/* ---- Design Tokens ---- */
:root{
  --navy:#16243D;        /* Vertrauen, Headlines, Footer */
  --navy-700:#1F3556;
  --slate:#46556B;       /* Fließtext gedämpft */
  --ink:#1A1F2B;         /* Haupttext */
  --paper:#FAF8F5;       /* warmes Off-White */
  --paper-2:#F2EEE7;     /* Sektionswechsel */
  --line:#E2DCD2;        /* Trennlinien */
  --brass:#B0823B;       /* Messing-Akzent */
  --brass-700:#8C6526;
  --teal:#2E6E73;        /* sekundärer Akzent (Mieter) */
  --ok:#2F7A4D;
  --warn:#9A6B00;
  --err:#B23A38;
  --white:#FFFFFF;

  --radius:14px;
  --radius-sm:9px;
  --shadow-sm:0 1px 2px rgba(22,36,61,.06),0 2px 8px rgba(22,36,61,.05);
  --shadow:0 6px 24px rgba(22,36,61,.10);
  --maxw:1160px;
  --space:clamp(3rem,6vw,5.5rem);
  --font-body:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --font-display:'Fraunces','Iowan Old Style',Georgia,serif;
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}

body{
  margin:0;font-family:var(--font-body);color:var(--ink);background:var(--paper);
  font-size:clamp(1rem,.96rem + .2vw,1.075rem);line-height:1.7;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}

/* ---- Fokus: deutlich sichtbar (WCAG 2.4.7 / 2.4.11) ---- */
:focus-visible{outline:3px solid var(--brass);outline-offset:2px;border-radius:3px}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:3px solid var(--brass);outline-offset:2px}

/* ---- Skip-Link ---- */
.skip-link{position:absolute;left:-999px;top:0;z-index:1000;background:var(--navy);color:#fff;
  padding:.75rem 1.25rem;border-radius:0 0 var(--radius-sm) 0;font-weight:600}
.skip-link:focus{left:0}

/* ---- Layout ---- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2rem)}
.section{padding-block:var(--space)}
.section--alt{background:var(--paper-2);border-block:1px solid var(--line)}

h1,h2,h3,h4{font-family:var(--font-display);color:var(--navy);line-height:1.12;
  font-weight:600;letter-spacing:-.01em;margin:0 0 .5em}
h1{font-size:clamp(2.1rem,1.5rem + 2.8vw,3.5rem);font-weight:700}
h2{font-size:clamp(1.6rem,1.2rem + 1.8vw,2.4rem)}
h3{font-size:clamp(1.2rem,1.05rem + .7vw,1.5rem)}
p{margin:0 0 1rem}
a{color:var(--brass-700);text-underline-offset:.18em;text-decoration-thickness:1px}
a:hover{color:var(--navy)}
.lead{font-size:clamp(1.1rem,1rem + .5vw,1.3rem);color:var(--slate)}
.eyebrow{font-family:var(--font-body);font-weight:600;font-size:.8rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--brass-700);margin:0 0 .9rem;display:flex;align-items:center;gap:.6rem}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--brass);display:inline-block}

/* ---- Signature: Keller→Dach Leiste ---- */
.kd-spine{display:flex;flex-direction:column;align-items:center;gap:.35rem;color:var(--brass-700);
  font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600}
.kd-spine__bar{width:3px;flex:1;min-height:120px;border-radius:3px;
  background:linear-gradient(var(--navy),var(--brass) 55%,var(--paper-2));}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--font-body);font-weight:600;
  font-size:1rem;padding:.85rem 1.5rem;border-radius:var(--radius-sm);border:2px solid transparent;
  cursor:pointer;text-decoration:none;transition:transform .15s ease,background .15s ease,box-shadow .15s ease;line-height:1.1}
.btn:hover{transform:translateY(-1px)}
.btn--primary{background:var(--navy);color:#fff;box-shadow:var(--shadow-sm)}
.btn--primary:hover{background:var(--navy-700);color:#fff}
.btn--brass{background:var(--brass);color:#1a1206;box-shadow:var(--shadow-sm)}
.btn--brass:hover{background:var(--brass-700);color:#fff}
.btn--ghost{background:transparent;color:var(--navy);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--navy);background:var(--white)}
.btn--block{width:100%;justify-content:center}

/* ---- Header / Nav ---- */
.site-header{position:sticky;top:0;z-index:90;background:rgba(250,248,245,.92);
  backdrop-filter:saturate(150%) blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:72px}
.brand{display:flex;align-items:center;gap:.7rem;text-decoration:none;color:var(--navy);font-weight:700}
.brand__mark{width:34px;height:34px;flex:0 0 auto}
.brand__name{font-family:var(--font-display);font-size:1.15rem;line-height:1.05}
.brand__name small{display:block;font-family:var(--font-body);font-weight:500;font-size:.7rem;
  letter-spacing:.12em;text-transform:uppercase;color:var(--brass-700)}
.nav__links{display:flex;align-items:center;gap:.35rem;list-style:none;margin:0;padding:0}
.nav__links a{display:inline-block;padding:.55rem .8rem;border-radius:var(--radius-sm);
  color:var(--ink);text-decoration:none;font-weight:500;font-size:.97rem}
.nav__links a:hover{background:var(--paper-2);color:var(--navy)}
.nav__links a[aria-current="page"]{color:var(--navy);font-weight:600;box-shadow:inset 0 -2px 0 var(--brass)}
.nav__cta{margin-left:.4rem}
.nav__toggle{display:none;background:none;border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:.55rem .7rem;cursor:pointer;color:var(--navy)}
.nav__toggle svg{display:block}

@media (max-width:920px){
  .nav__toggle{display:inline-flex}
  .nav__links{position:absolute;left:0;right:0;top:72px;flex-direction:column;align-items:stretch;
    background:var(--paper);border-bottom:1px solid var(--line);padding:.6rem clamp(1.1rem,4vw,2rem) 1.2rem;
    gap:.2rem;box-shadow:var(--shadow);display:none}
  .nav__links.is-open{display:flex}
  .nav__links a{padding:.8rem .9rem}
  .nav__cta{margin:.4rem 0 0}
}

/* ---- Hero ---- */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(1200px 500px at 85% -10%,rgba(176,130,59,.12),transparent 60%),
  linear-gradient(180deg,var(--paper),var(--paper-2))}
.hero__grid{display:grid;grid-template-columns:1fr auto;gap:clamp(1.5rem,4vw,3.5rem);
  align-items:center;padding-block:clamp(3.5rem,7vw,6rem)}
.hero__slogan{font-family:var(--font-display);font-weight:600;color:var(--navy);
  font-size:clamp(1.15rem,1rem + .8vw,1.5rem);font-style:italic;margin:.2rem 0 1.6rem;
  padding-left:1rem;border-left:3px solid var(--brass)}
.hero__cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.8rem}
.hero__aside{align-self:stretch}
@media (max-width:760px){.hero__grid{grid-template-columns:1fr}.hero__aside{display:none}}

/* ---- Cards / Audience split ---- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.25rem}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.6rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:.4rem}
.card__icon{width:46px;height:46px;border-radius:11px;display:grid;place-items:center;
  background:var(--paper-2);color:var(--navy);margin-bottom:.4rem}
.card h3{margin-bottom:.25rem}
.card--feature{border-top:3px solid var(--brass)}
.card__foot{margin-top:auto;padding-top:1rem}

.split{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
@media (max-width:760px){.split{grid-template-columns:1fr}}
.panel{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(1.4rem,3vw,2.2rem);box-shadow:var(--shadow-sm)}
.panel--tenant{border-top:4px solid var(--teal)}
.panel--owner{border-top:4px solid var(--brass)}

/* ---- Steps ---- */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem;counter-reset:s}
.step{position:relative;padding:1.4rem 1.4rem 1.4rem 3.4rem;background:var(--white);
  border:1px solid var(--line);border-radius:var(--radius)}
.step::before{counter-increment:s;content:counter(s,decimal-leading-zero);position:absolute;left:1.2rem;top:1.3rem;
  font-family:var(--font-display);font-weight:700;color:var(--brass);font-size:1.05rem}

/* ---- Forms ---- */
.form{display:grid;gap:1.1rem}
.field{display:grid;gap:.4rem}
.field > label{font-weight:600;color:var(--navy);font-size:.95rem}
.field .hint{font-size:.85rem;color:var(--slate)}
.req{color:var(--err)}
.input,.textarea,.select{font:inherit;color:var(--ink);background:var(--white);
  border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:.7rem .85rem;width:100%}
.input:hover,.textarea:hover,.select:hover{border-color:#c8bfb0}
.input:focus,.textarea:focus,.select:focus{border-color:var(--navy);outline:3px solid var(--brass);outline-offset:1px}
.textarea{min-height:140px;resize:vertical}
.field--error .input,.field--error .textarea,.field--error .select{border-color:var(--err)}
.error-text{color:var(--err);font-size:.88rem;font-weight:500}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
@media (max-width:560px){.row-2{grid-template-columns:1fr}}
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}
.checkbox{display:flex;gap:.6rem;align-items:flex-start;font-size:.92rem;color:var(--slate)}
.checkbox input{margin-top:.25rem;width:18px;height:18px;accent-color:var(--navy);flex:0 0 auto}

/* ---- Alerts ---- */
.alert{border-radius:var(--radius-sm);padding:1rem 1.15rem;border:1px solid;display:flex;gap:.7rem;align-items:flex-start}
.alert--ok{background:#EAF5EE;border-color:#Bfe0CC;color:#1f5a37}
.alert--err{background:#FBEAE9;border-color:#F0C7C5;color:#8a2a28}
.alert--info{background:#EAF0F7;border-color:#C9D8EC;color:#234268}

/* ---- Contact strip ---- */
.contact-card{background:var(--navy);color:#EAF0F7;border-radius:var(--radius);padding:1.6rem;display:grid;gap:.5rem}
.contact-card a{color:#fff;font-weight:600}
.contact-card .num{font-family:var(--font-display);font-size:1.5rem;color:#fff}

/* ---- Footer ---- */
.site-footer{background:var(--navy);color:#C4D0E2;margin-top:var(--space)}
.site-footer a{color:#E6EDF7}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem;padding-block:3rem}
@media (max-width:760px){.footer__grid{grid-template-columns:1fr;gap:1.5rem}}
.footer__grid h4{color:#fff;font-size:1rem;margin-bottom:.8rem}
.footer__links{list-style:none;margin:0;padding:0;display:grid;gap:.4rem}
.footer__bottom{border-top:1px solid rgba(255,255,255,.12);padding-block:1.2rem;
  display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;justify-content:space-between;font-size:.85rem;color:#94A6C2}

/* ---- Mieter-Bubble (Telefon-Hotline) ---- */
.bubble{position:fixed;right:max(1rem,3vw);bottom:max(1rem,3vw);z-index:120}
.bubble__btn{display:flex;align-items:center;gap:.6rem;background:var(--teal);color:#fff;border:none;
  border-radius:50px;padding:.85rem 1.2rem;font:inherit;font-weight:600;cursor:pointer;box-shadow:var(--shadow)}
.bubble__btn:hover{background:#255b5f}
.bubble__panel{position:absolute;right:0;bottom:calc(100% + .7rem);width:min(330px,86vw);
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:1.2rem;display:none}
.bubble__panel.is-open{display:block}
.bubble__panel h3{font-size:1.1rem;margin-bottom:.3rem}
.bubble__num{font-family:var(--font-display);font-size:1.45rem;color:var(--navy);font-weight:700}

/* ---- Cookie-Consent ---- */
.consent{position:fixed;inset:auto 1rem 1rem 1rem;z-index:200;max-width:560px;margin-inline:auto;
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:1.3rem 1.4rem;display:none}
.consent.is-visible{display:block}
.consent h2{font-size:1.15rem;margin-bottom:.4rem}
.consent p{font-size:.92rem;color:var(--slate);margin-bottom:1rem}
.consent__actions{display:flex;flex-wrap:wrap;gap:.6rem}

/* ---- Utilities ---- */
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0 0 0 0);white-space:nowrap;border:0}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}.center{text-align:center}
.stack > * + *{margin-top:1rem}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
@media (max-width:760px){.grid-2{grid-template-columns:1fr}}
.prose h2{margin-top:2rem}
.prose h3{margin-top:1.4rem}
.prose ul{padding-left:1.2rem}
.prose li{margin-bottom:.4rem}
.tag{display:inline-block;font-size:.78rem;font-weight:600;padding:.2rem .6rem;border-radius:50px;
  background:var(--paper-2);color:var(--slate);border:1px solid var(--line)}

/* =====================================================================
   v2 — Medienverwaltung (Backend) + Objektverwaltung (Front/Back)
   ===================================================================== */

/* ---- kleine Utilities (Backend) ---- */
.row-3{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem}
.row-4{display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem}
@media(max-width:680px){.row-3,.row-4{grid-template-columns:1fr 1fr}}
@media(max-width:430px){.row-3,.row-4{grid-template-columns:1fr}}
.input--sm,.select--sm{padding:.32rem .5rem;font-size:.85rem;border-radius:7px;min-height:0}
.btn--sm{padding:.35rem .7rem;font-size:.84rem}
.btn--danger{background:var(--err);color:#fff;border:1px solid var(--err)}
.btn--danger:hover{background:#9a302e;border-color:#9a302e}
.linkbtn{background:none;border:none;padding:0;margin:0;color:var(--err);font:inherit;font-size:.92rem;cursor:pointer;text-decoration:underline}
.linkbtn--danger{color:var(--err)}
.chk{display:flex;align-items:center;gap:.5rem;font-size:.92rem;color:var(--ink);cursor:pointer}
.chk input{width:1.05rem;height:1.05rem;flex:0 0 auto}
.oc-h{font-size:1.05rem;margin:0 0 .9rem;font-family:var(--font-display)}

/* ---- Medien-Bibliothek (Backend) ---- */
.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:1rem}
.media-tile{margin:0;background:#fff;border:1px solid var(--line);border-radius:11px;overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.media-tile>a{display:block;aspect-ratio:4/3;background:var(--paper-2)}
.media-tile>a img{width:100%;height:100%;object-fit:cover;display:block}
.media-tile figcaption{padding:.6rem;display:grid;gap:.45rem}
.media-meta{font-size:.74rem;color:var(--slate)}
.media-altform{display:flex;gap:.3rem}
.media-altform .input{flex:1}
.media-actions{display:flex;gap:.3rem;align-items:center}
.media-url{flex:1;background:var(--paper);color:var(--slate);font-size:.72rem}

/* ---- Objekt-Editor (Backend) ---- */
.obj-grid{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:1.4rem;align-items:start}
@media(max-width:900px){.obj-grid{grid-template-columns:1fr}}
.obj-form .a-card{margin:0}
.feature-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.5rem .9rem}
.faq-row{display:grid;gap:.4rem;padding:.7rem;border:1px solid var(--line);border-radius:9px;margin-bottom:.7rem;background:var(--paper)}
.faq-row .textarea{min-height:64px}
.pick-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.7rem}
.pick{position:relative;display:block;border:2px solid var(--line);border-radius:10px;overflow:hidden;cursor:pointer;background:var(--paper-2)}
.pick img{width:100%;aspect-ratio:1;object-fit:cover;display:block}
.pick.is-sel{border-color:var(--brass);box-shadow:0 0 0 2px rgba(176,130,59,.25)}
.pick__bar{display:flex;align-items:center;gap:.3rem;padding:.35rem;background:#fff;border-top:1px solid var(--line)}
.pick__cb{width:1.1rem;height:1.1rem;margin:0}
.pick__ord{width:3.2rem;padding:.2rem .3rem;font-size:.78rem}
.pick__star{margin-left:auto;display:inline-flex;align-items:center;font-size:1rem;cursor:pointer;filter:grayscale(1);opacity:.5}
.pick__star input{position:absolute;opacity:0;width:0;height:0}
.pick__star:has(input:checked){filter:none;opacity:1}

/* =====================================================================
   Objekte — Frontend
   ===================================================================== */
.section--tight{padding-block:clamp(1.4rem,3vw,2.4rem)}

/* Brotkrumen */
.crumbs{border-bottom:1px solid var(--line);background:var(--paper)}
.crumbs .container{padding-block:.7rem;font-size:.84rem;color:var(--slate)}
.crumbs a{color:var(--slate)}
.crumbs a:hover{color:var(--brass-700)}
.crumbs span[aria-current]{color:var(--ink)}

/* Filter-Pills */
.obj-filters{display:flex;flex-wrap:wrap;gap:.5rem;margin:1.4rem 0 0}
.obj-filters a{padding:.4rem .9rem;border-radius:50px;border:1px solid var(--line);background:#fff;color:var(--slate);text-decoration:none;font-size:.88rem;font-weight:500}
.obj-filters a:hover{border-color:var(--brass)}
.obj-filters a.active{background:var(--navy);color:#fff;border-color:var(--navy)}

/* Karten-Raster */
.obj-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.6rem;margin-top:2rem}
.obj-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .18s ease,box-shadow .18s ease}
.obj-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.obj-card__media{position:relative;display:block;aspect-ratio:3/2;background:var(--paper-2)}
.obj-card__media img{width:100%;height:100%;object-fit:cover;display:block}
.obj-card__noimg{position:absolute;inset:0;display:grid;place-items:center;color:var(--slate);font-size:.9rem}
.obj-tag{position:absolute;top:.6rem;font-size:.72rem;font-weight:600;padding:.2rem .6rem;border-radius:50px;color:#fff;backdrop-filter:saturate(1.2)}
.obj-tag--type{right:.6rem;background:rgba(22,36,61,.86)}
.obj-tag--res{left:.6rem;background:var(--brass)}
.obj-card__body{display:flex;flex-direction:column;gap:.5rem;padding:1.1rem;flex:1}
.obj-card__title{font-size:1.12rem;margin:0;line-height:1.3}
.obj-card__title a{color:var(--navy);text-decoration:none}
.obj-card__title a:hover{color:var(--brass-700)}
.obj-card__loc{margin:0;color:var(--slate);font-size:.88rem}
.obj-facts{list-style:none;display:flex;flex-wrap:wrap;gap:.3rem .9rem;margin:.2rem 0;padding:0;color:var(--slate);font-size:.9rem}
.obj-facts strong{color:var(--ink)}
.obj-card__price{margin:.1rem 0 0}
.obj-card__price strong{font-family:var(--font-display);font-size:1.25rem;color:var(--navy)}
.obj-card__price span{color:var(--slate);font-size:.85rem}
.obj-card__foot{margin-top:auto;padding-top:.6rem}

/* Detail-Layout */
.obj-detail{display:grid;grid-template-columns:minmax(0,1fr) 340px;grid-template-areas:"gallery side" "main side";gap:1.6rem 2rem;align-items:start}
.obj-gallery{grid-area:gallery}
.obj-side{grid-area:side;position:sticky;top:1.2rem}
.obj-main{grid-area:main;min-width:0}
@media(max-width:880px){
  .obj-detail{grid-template-columns:1fr;grid-template-areas:"gallery" "side" "main"}
  .obj-side{position:static}
}
.obj-main h1{margin:.2rem 0 1rem}
.obj-main h2{font-size:1.25rem;margin:1.8rem 0 .6rem}

/* Galerie */
.obj-gallery__main{margin:0;border-radius:var(--radius);overflow:hidden;background:var(--paper-2);border:1px solid var(--line)}
.obj-gallery__main img{width:100%;display:block;max-height:480px;object-fit:cover}
.obj-gallery__noimg{aspect-ratio:3/2;display:grid;place-items:center;color:var(--slate)}
.obj-thumbs{display:grid;grid-template-columns:repeat(auto-fill,minmax(86px,1fr));gap:.5rem;margin-top:.6rem}
.obj-thumb{padding:0;border:2px solid transparent;border-radius:9px;overflow:hidden;cursor:pointer;background:none;aspect-ratio:4/3}
.obj-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.obj-thumb:hover{border-color:var(--line)}
.obj-thumb.is-active{border-color:var(--brass)}

/* Infospalte */
.obj-pricecard{padding:1.3rem}
.obj-badges{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.8rem}
.obj-price{margin:.2rem 0 1rem}
.obj-price strong{display:block;font-family:var(--font-display);font-size:1.8rem;color:var(--navy);line-height:1.1}
.obj-price span{color:var(--slate);font-size:.9rem}
.obj-keyfacts{list-style:none;margin:0 0 1.1rem;padding:0;display:grid;gap:.45rem}
.obj-keyfacts li{display:flex;justify-content:space-between;gap:1rem;font-size:.92rem;padding-bottom:.45rem;border-bottom:1px solid var(--line)}
.obj-keyfacts li:last-child{border-bottom:none}
.obj-keyfacts span{color:var(--slate)}
.obj-keyfacts b{color:var(--ink)}

/* Eckdaten-Highlights */
.obj-stats{list-style:none;display:flex;flex-wrap:wrap;gap:.8rem;margin:0 0 1.2rem;padding:0}
.obj-stats li{flex:1;min-width:96px;background:var(--paper);border:1px solid var(--line);border-radius:11px;padding:.8rem 1rem;text-align:center}
.obj-stats b{display:block;font-family:var(--font-display);font-size:1.35rem;color:var(--navy)}
.obj-stats span{font-size:.8rem;color:var(--slate)}

/* Ausstattung */
.obj-features{list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:.45rem .9rem;margin:.4rem 0;padding:0}
.obj-features li{position:relative;padding-left:1.5rem;color:var(--ink);font-size:.95rem}
.obj-features li::before{content:"";position:absolute;left:0;top:.45em;width:.7rem;height:.4rem;border-left:2px solid var(--brass);border-bottom:2px solid var(--brass);transform:rotate(-45deg)}

/* FAQ */
.obj-faq details{border:1px solid var(--line);border-radius:10px;padding:.2rem .9rem;margin-bottom:.6rem;background:#fff}
.obj-faq summary{cursor:pointer;font-weight:600;padding:.7rem 0;list-style:none;color:var(--navy)}
.obj-faq summary::-webkit-details-marker{display:none}
.obj-faq summary::before{content:"+";display:inline-block;width:1.2em;color:var(--brass);font-weight:700}
.obj-faq details[open] summary::before{content:"–"}
.obj-faq .prose{padding:0 0 .9rem .1rem;color:var(--slate)}

/* CTA */
.obj-cta{margin-top:2rem;padding:1.6rem;background:var(--navy);color:#fff;border-radius:var(--radius)}
.obj-cta h2{color:#fff}
.obj-cta p{color:#A9B7CE;margin:.3rem 0 1rem}
.obj-desc{white-space:normal}
