/*
Theme Name: Antiquitaeten Fulda v9.2.3 (Baroque Edges + Mobile Perfect)
Theme URI: https://antiquitaeten-fulda.de
Author: ChatGPT
Description: Heritage Luxe mit sicher sichtbaren Barockrändern, Video-Hero (contain), Services, Timeline, Über, Kontakt. Topbar nur mit Telefon. Mobile final poliert.
Version: 9.2.3
Text Domain: af-v923
License: GPL-2.0-or-later
*/

:root{
  --bg:#f5f1eb; --paper:#ffffff; --ink:#201a19; --muted:#6f6864;
  --brand:#692b2e; --gold:#c5a679;
  --radius:18px; --radius-lg:26px;
  --shadow-sm:0 6px 14px rgba(0,0,0,.06);
  --shadow:0 14px 32px rgba(0,0,0,.10);
  --s1:8px;--s2:12px;--s3:16px;--s4:20px;--s5:24px;--s6:28px;--s7:32px;--s8:40px;--s9:56px;--s10:72px;--s11:96px;--s12:120px;
  --max:1120px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
}
body{
  margin:0;color:var(--ink);font:16px/1.65 Inter,system-ui,-apple-system,Segoe UI,Roboto,"Helvetica Neue",Arial,sans-serif;
  background:linear-gradient(180deg, #f8f4ee, #f5f1eb);
  position:relative;
}

/* ================= Baroque side pattern (robust) ================= */
:root{
  --baroque-svg: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160' viewBox='0 0 160 160'><defs><pattern id='p' width='160' height='160' patternUnits='userSpaceOnUse'><g fill='%23c5a679'><path d='M80 10c12 16 24 22 40 28-16 6-28 12-40 28-12-16-24-22-40-28 16-6 28-12 40-28z' opacity='.5'/><circle cx='80' cy='80' r='6' opacity='.35'/><path d='M20 80c14 10 24 16 60 16s46-6 60-16c-14-10-24-16-60-16S34 70 20 80z' opacity='.35'/></g></pattern></defs><rect width='160' height='160' fill='url(%23p)'/></svg>");
}
body::before, body::after{
  content:""; position:fixed; top:0; bottom:0; width:min(12vw,150px);
  z-index:0; pointer-events:none; opacity:.10;
  background-size:160px 160px; background-repeat:repeat-y; filter:grayscale(.1) contrast(1.08);
}
body::before{ left:0; background-image:var(--baroque-svg); }
body::after{ right:0; transform:scaleX(-1); transform-origin:right center; background-image:var(--baroque-svg); }
/* Fallback für Browser ohne data:SVG */
@supports not (background-image: var(--baroque-svg)) {
  body::before, body::after{
    background: repeating-linear-gradient(
      to bottom,
      rgba(197,166,121,.18) 0 22px,
      rgba(197,166,121,.30) 22px 44px,
      transparent 44px 66px
    );
  }
}
/* Auf sehr kleinen Phones schmaler, aber sichtbar lassen */
@media (max-width: 480px){
  body::before, body::after{ width: 42px; opacity:.08; }
}

/* Content layer above pattern */
.wrap{max-width:var(--max);margin:0 auto;padding:clamp(14px,2.4vw,22px);position:relative;z-index:1}
.row{display:flex;align-items:flex-start;gap:var(--s6);flex-wrap:wrap}
.space{flex:1}
img{max-width:100%;height:auto;display:block;border-radius:14px}
a{color:var(--brand);text-decoration:none}
h1,h2,h3{font-family:"Playfair Display",serif;color:var(--ink);line-height:1.12;margin:0}
h1{font-size:clamp(36px,4.7vw,64px);letter-spacing:.2px;margin-bottom:var(--s4)}
h2{font-size:clamp(24px,2.9vw,40px);letter-spacing:.1px;margin-bottom:var(--s4)}
h3{font-size:clamp(18px,2vw,24px);margin-bottom:var(--s2)}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 20px;border-radius:999px;
  background:var(--brand);color:#fff;
  font-weight:800;letter-spacing:.15px;
  box-shadow:var(--shadow);
  transition:opacity .2s ease, transform .15s ease;
}
.btn:hover{opacity:.95; transform: translateY(-1px)}
.btn.alt{background:#fff;color:var(--brand);border:1px solid #e6d9c9}

/* Topbar – nur Telefon, kompakt auf Mobile */
.topbar{position:sticky;top:0;z-index:50;background:rgba(245,242,237,.9);backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid #eadfcd}
.logo{display:flex;align-items:center;gap:12px;font-weight:900}
.logo img{width:36px;height:36px;border-radius:9px;box-shadow:var(--shadow-sm)}
.topbar .wrap{display:flex;align-items:center;gap:var(--s3)}
@media (max-width:780px){
  .topbar .wrap{gap:10px}
  .topbar .btn{padding:10px 14px}
}

/* Hero */
.hero{padding:calc(var(--s10) + 6px) 0; margin-bottom:22px}
.hero .inner{display:grid;grid-template-columns:1.05fr .95fr;gap:var(--s7);align-items:center}
.badge{display:inline-block;background:var(--gold);color:#2b2924;padding:8px 14px;border-radius:999px;font-weight:800;letter-spacing:.25px;margin-bottom:var(--s3)}
.lead{color:var(--muted);font-size:clamp(15px,1.5vw,19px);margin-bottom:var(--s5);max-width:760px}
.frame{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:#000;box-shadow:var(--shadow);border:1px solid rgba(197,166,121,.55)}
.frame::before{content:"";position:absolute;inset:14px;border-radius:calc(var(--radius-lg) - 14px);border:1px solid rgba(197,166,121,.35);pointer-events:none}
.frame video{width:100%;height:auto;object-fit:contain;display:block;border-radius:inherit;background:#000}
.frame img{width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit}
@media (max-width:980px){.hero .inner{grid-template-columns:1fr}}

/* Trust bar */
.trust{padding:var(--s4) 0;border-top:1px solid #eadfcd;border-bottom:1px solid #eadfcd;background:linear-gradient(180deg,#f7f3ec,transparent); margin:0 0 24px 0}
.trust .row{justify-content:center;gap:var(--s6);flex-wrap:wrap}
.trust .pill{background:#fff;border:1px solid #eee;border-radius:999px;padding:10px 16px;font-weight:700;box-shadow:var(--shadow-sm)}

/* Sections – extra Luft */
section{position:relative; z-index:1; padding:var(--s11) 0}
.paper{background:rgba(255,255,255,.9);backdrop-filter:saturate(130%) blur(2px);border-radius:var(--radius);box-shadow:var(--shadow);padding:calc(var(--s7) + 6px); margin: 30px 0}

/* Services */
.grid{display:grid;gap:var(--s6)}
.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
@media (max-width:1024px){.grid.cols-3{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:680px){.grid.cols-3{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid #eee;border-radius:18px;overflow:hidden;box-shadow:0 10px 24px rgba(0,0,0,.07)}
.card .body{padding:var(--s5)}
.card img{aspect-ratio:16/10;object-fit:cover}
.kicker{display:inline-block;font-weight:800;font-size:12px;letter-spacing:.16em;color:var(--brand);background:#f4ebe4;border:1px solid #edd9cc;border-radius:999px;padding:6px 10px;margin-bottom:var(--s2)}

/* Timeline */
.timeline{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s5);position:relative; margin-bottom:10px}
.step{background:#fff;border:1px solid #eee;border-radius:14px;padding:var(--s5);box-shadow:var(--shadow-sm);position:relative}
.step .num{position:absolute;top:-14px;left:16px;background:var(--brand);color:#fff;border-radius:999px;padding:6px 10px;font-weight:800;font-size:12px}
@media (max-width:900px){.timeline{grid-template-columns:1fr}}

/* Kontakt */
#kontakt input,#kontakt textarea{width:100%;padding:16px;border:1px solid #e8e0d3;border-radius:14px;font-size:16px;background:#fff}
#kontakt .btn,#kontakt .btn.alt{width:100%;justify-content:center}
@media(min-width:640px){#kontakt .btn,#kontakt .btn.alt{width:auto}}
#kontakt .card{transition:none;border:1px solid #eee}
#kontakt iframe{border-radius:12px}
#kontakt textarea{min-height:140px}
@media (max-width:780px){
  #kontakt .row{flex-direction:column;gap:var(--s4)}
  #kontakt .card{width:100%}
  #kontakt .card:first-child{order:1}
  #kontakt .card:last-child{order:2}
  #kontakt input,#kontakt textarea{font-size:17px}
}

/* Über-Bild: sicher und edel */
#ueber .row > div:last-child img{
  width:100%; height:auto; max-height:460px;
  object-fit:cover; border-radius:16px;
  box-shadow: 0 10px 24px rgba(0,0,0,.08);
}

/* Footer */
footer{padding:var(--s7) 0;border-top:1px solid #eadfcd;color:#5b5f68;text-align:center;font-size:15px}

/* Reveal */
.reveal{opacity:0;transform:translateY(10px);transition:opacity .5s ease, transform .5s ease; will-change: opacity, transform}
.reveal.in{opacity:1;transform:none}

/* Small phones */
@media (max-width:420px){
  h1{font-size:clamp(28px,9vw,38px)}
  h2{font-size:clamp(22px,6vw,28px)}
}

.slider-controls, .glide__arrows, .swiper-button-prev, .swiper-button-next { display: none !important; }

/* hero image cover */
.hero .right .frame img { width:100%; height:100%; object-fit:cover; display:block; }

/* ================= Hero Slider – clean version ================= */
.hero .right { position: relative; }

.hero-slider{
  position:relative;
  width:100%;
  overflow:hidden;
  border-radius:var(--r2,1.25rem);
  min-height:260px;
  background:#fff;
  box-shadow:0 12px 40px rgba(0,0,0,.08);
  border:none;
}

.hero-slider .slides{
  position:relative;
  width:100%;
  min-height:320px;
}

.hero-slider .slide{
  position:absolute;
  inset:0;
  opacity:0;
  transform:scale(1.02);
  transition:opacity .8s ease, transform .8s ease;
}

.hero-slider .slide.is-active{
  opacity:1;
  transform:scale(1);
}

.hero-slider img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  background:#fff;
}

.hero-slider .nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  background:rgba(0,0,0,.4);
  color:#fff;
  border:0;
  border-radius:50%;
  width:38px;
  height:38px;
  cursor:pointer;
}

.hero-slider .nav.prev{ left:10px; }
.hero-slider .nav.next{ right:10px; }

.hero-slider .dots{
  position:absolute;
  bottom:10px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  gap:8px;
}

.hero-slider .dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:rgba(255,255,255,.6);
  border:0;
  cursor:pointer;
}

.hero-slider .dot.is-active{ background:#fff; }

@media(max-width:768px){
  .hero-slider .slides{ min-height:220px; }
  .hero-slider{ min-height:200px; }
  .hero-slider .nav{ width:28px; height:28px; }
  .hero-slider .dot{ width:6px; height:6px; }
}

/* About-Slider falls genutzt */
.about-slider{
  position:relative;
  width:100%;
  overflow:hidden;
  border-radius:var(--r2,1.25rem);
  box-shadow:0 12px 40px rgba(0,0,0,.08);
  min-height:280px;
}
.about-slider .slides{ position:relative; width:100%; min-height:320px; }
.about-slider .slide{
  position:absolute; inset:0; opacity:0;
  transition:opacity .8s ease, transform .8s ease;
}
.about-slider .slide.is-active{ opacity:1; transform:scale(1); }
.about-slider img{ width:100%; height:100%; object-fit:cover; display:block; }

@media(max-width:768px){
  .about-slider .slides{ min-height:220px; }
}

/* v9.7.3 anchor spacing */
main section{scroll-margin-top:100px}

/* === v9.7.5 Hero polish (white background) === */
.right, .hero-slider, .hero-slider .slides, .hero-slider .slide { background:#fff; }
.hero .frame, .right .frame{ background:#fff; border:none; }

/* ========= FAQ – schönes Styling ========= */

section#faq .faq{
  display:flex;
  flex-direction:column;
  gap:10px;
}

/* Browser-Default komplett überschreiben + eigene Cards */
section#faq .faq details{
  all:unset;
  display:block;
  background:#fff;
  border-radius:var(--radius);
  border:1px solid #eadfcd;
  padding:14px 18px;
  box-shadow:var(--shadow-sm);
  margin:0;
  transition:
    box-shadow .2s ease,
    transform .15s ease,
    border-color .2s ease,
    background .2s ease;
}

section#faq .faq details + details{
  margin-top:8px;
}

section#faq .faq details:hover{
  box-shadow:var(--shadow);
  transform:translateY(-1px);
  background:#fdf9f4;
}

section#faq .faq details[open]{
  border-color:var(--brand);
}

/* Kopfzeile (Frage) */
section#faq .faq summary{
  cursor:pointer;
  list-style:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  font-weight:600;
  color:var(--ink);
  font-size:0.98rem;
}

/* Standard-Dreieck verstecken */
section#faq .faq summary::-webkit-details-marker,
section#faq .faq summary::marker{
  content:"";
  display:none;
}

/* Pfeil rechts */
section#faq .faq .chev{
  margin-left:12px;
  font-size:16px;
  line-height:1;
  color:var(--muted);
  transition:transform .2s ease, color .2s ease;
}

/* gedrehter Pfeil bei geöffnetem FAQ */
section#faq .faq details[open] .chev{
  transform:rotate(180deg);
  color:var(--brand);
}

/* Antwort */
section#faq .faq details > div{
  margin-top:8px;
  color:var(--muted);
  line-height:1.6;
  font-size:0.95rem;
}

@media(max-width:600px){
  section#faq .paper{ padding:var(--s5); }
  section#faq .faq details{ padding:10px 12px; }
}
section#faq {
  outline: 3px solid red !important;
}
