/* STADTFÜHRUNGEN FRANKFURT – SANDRA POLLER | style.css */
:root{--gold:#C8962B;--gold-lt:#E0B356;--gold-pale:#F9F2E3;--gold-line:rgba(200,150,43,.22);--ink:#1C1610;--ink-mid:#2E2318;--ink-soft:#3D3020;--bark:#6B5540;--sand:#A89070;--parch:#F2EAD8;--cream:#FAF6EE;--white:#FFFDF9;--border:rgba(200,150,43,.18);--border-lt:rgba(200,150,43,.1);--r1:4px;--r2:10px;--r3:18px;--r4:28px;--sh-xs:0 1px 4px rgba(28,22,16,.1);--sh-sm:0 3px 14px rgba(28,22,16,.14);--sh-md:0 8px 32px rgba(28,22,16,.2);--sh-lg:0 20px 64px rgba(28,22,16,.28);--sh-gold:0 8px 28px rgba(200,150,43,.28);--t:.22s ease}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Jost',sans-serif;color:var(--ink);background:var(--white);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
button{cursor:pointer;font-family:inherit;border:none;background:none}
ul{list-style:none}
h1,h2,h3,.serif{font-family:'Cormorant Garamond',serif}
h1{font-size:clamp(2.2rem,5.5vw,4rem);line-height:1.07;font-weight:600;letter-spacing:-.01em}
h2{font-size:clamp(1.6rem,3.8vw,2.6rem);line-height:1.1;font-weight:600}
h3{font-size:clamp(1.05rem,2vw,1.3rem);line-height:1.2;font-weight:600}
p{line-height:1.78;font-weight:300}

/* SKIP LINK */
.skip-link{position:absolute;top:-40px;left:0;background:var(--gold);color:var(--ink);padding:8px 16px;z-index:999;font-weight:700;border-radius:0 0 4px 0;transition:top .2s;font-family:'Jost',sans-serif}
.skip-link:focus{top:0}

/* DECORATIVE */
.gold-rule{display:flex;align-items:center;gap:14px;margin:16px 0 24px}
.gold-rule::before,.gold-rule::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.gold-rule span{color:var(--gold);font-size:.75rem;letter-spacing:3px;text-transform:uppercase;font-weight:500;white-space:nowrap;font-family:'Jost',sans-serif}
.aurum{display:flex;align-items:center;gap:12px;margin:10px 0 22px}
.aurum::after{content:'';flex:0 0 60px;height:1.5px;background:linear-gradient(90deg,var(--gold),transparent)}
.aurum-c{justify-content:center}
.aurum-c::before{content:'';flex:0 0 60px;height:1.5px;background:linear-gradient(270deg,var(--gold),transparent)}
.eyebrow{display:inline-block;font-size:.68rem;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:10px;font-family:'Jost',sans-serif}

/* LAYOUT */
.container{max-width:1240px;margin:0 auto;padding:0 28px}
.section{padding:96px 0}
.section-sm{padding:64px 0}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:14px 30px;border-radius:var(--r1);font-size:.88rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;transition:all var(--t);white-space:nowrap;font-family:'Jost',sans-serif;text-align:center}
.btn-gold{background:var(--gold);color:var(--ink);box-shadow:var(--sh-gold)}
.btn-gold:hover{background:var(--gold-lt);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--gold);border:1.5px solid var(--gold)}
.btn-outline:hover{background:rgba(200,150,43,.08)}
.btn-ghost{background:rgba(255,255,255,.1);color:#fff;border:1.5px solid rgba(255,255,255,.3);backdrop-filter:blur(4px)}
.btn-ghost:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.55)}
.btn-dark{background:var(--ink);color:var(--gold-lt)}
.btn-dark:hover{background:var(--ink-mid)}
.btn-lg{padding:17px 38px;font-size:.95rem}
.btn-sm{padding:9px 18px;font-size:.76rem}

/* BADGES */
.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 11px;border-radius:20px;font-size:.65rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;font-family:'Jost',sans-serif}
.badge-gold{background:var(--gold);color:var(--ink)}
.badge-ink{background:rgba(28,22,16,.75);color:var(--gold-lt)}
.badge-warm{background:var(--gold-pale);color:var(--gold)}
.badge-cream{background:var(--cream);color:var(--bark)}
.stars{color:var(--gold);font-size:.85rem;letter-spacing:1.5px}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:300;background:rgba(28,22,16,.97);backdrop-filter:blur(16px);border-bottom:1px solid var(--gold-line);transition:all var(--t)}
.nav.scrolled{box-shadow:0 4px 24px rgba(28,22,16,.4)}
.nav__inner{max-width:1240px;margin:0 auto;padding:0 28px;height:72px;display:flex;align-items:center}
.nav__logo{display:flex;align-items:center;gap:13px;flex-shrink:0;margin-right:auto}
.nav__logo-emblem{width:42px;height:42px;border-radius:var(--r1);border:1.5px solid var(--gold-line);display:flex;align-items:center;justify-content:center;background:rgba(200,150,43,.1);font-size:1.15rem;flex-shrink:0}
.nav__logo-title{font-family:'Cormorant Garamond',serif;font-size:1.15rem;font-weight:600;color:var(--gold-lt);line-height:1.2}
.nav__logo-sub{font-size:.58rem;font-weight:500;color:rgba(255,255,255,.38);letter-spacing:2px;text-transform:uppercase}
.nav__links{display:flex;align-items:center;gap:2px;margin:0 32px}
.nav__links a{padding:8px 15px;border-radius:var(--r1);font-size:.82rem;font-weight:500;color:rgba(255,255,255,.6);letter-spacing:.3px;transition:all var(--t)}
.nav__links a:hover,.nav__links a.active{background:rgba(200,150,43,.12);color:var(--gold-lt)}
.nav__cta{padding:10px 24px;background:var(--gold);color:var(--ink);border-radius:var(--r1);font-size:.8rem;font-weight:700;letter-spacing:.6px;text-transform:uppercase;box-shadow:var(--sh-gold);transition:all var(--t);flex-shrink:0}
.nav__cta:hover{background:var(--gold-lt);transform:translateY(-1px)}
.nav__ham{display:none;flex-direction:column;gap:5px;margin-left:auto;padding:4px;background:none;border:none;cursor:pointer}
.nav__ham span{width:22px;height:1.5px;background:var(--gold-lt);border-radius:2px;transition:var(--t)}

/* MOBILE DRAWER */
.drawer{position:fixed;inset:0;z-index:299;pointer-events:none}
.drawer__bg{position:absolute;inset:0;background:rgba(28,22,16,.75);opacity:0;transition:opacity .3s}
.drawer__panel{position:absolute;top:0;right:0;bottom:0;width:min(300px,90vw);background:var(--ink-mid);border-left:1px solid var(--gold-line);transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);padding:88px 24px 32px;display:flex;flex-direction:column;gap:6px;overflow-y:auto}
.drawer.open{pointer-events:all}
.drawer.open .drawer__bg{opacity:1}
.drawer.open .drawer__panel{transform:none}
.drawer__link{display:block;padding:13px 18px;border-radius:var(--r1);border:1px solid var(--gold-line);font-size:.9rem;font-weight:500;color:rgba(255,255,255,.65);transition:all var(--t)}
.drawer__link:hover,.drawer__link.active{background:rgba(200,150,43,.1);color:var(--gold-lt);border-color:rgba(200,150,43,.3)}
.drawer__cta{display:block;text-align:center;padding:14px;margin-top:10px;background:var(--gold);color:var(--ink);border-radius:var(--r1);font-weight:700;font-size:.85rem;letter-spacing:.6px;text-transform:uppercase}

/* PAGE HERO */
.page-top{margin-top:72px}
.page-hero{background:var(--ink);padding:80px 28px 60px;text-align:center;position:relative;overflow:hidden;border-bottom:1px solid var(--gold-line)}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(200,150,43,.12) 0%,transparent 70%);pointer-events:none}
.page-hero h1{color:var(--gold-lt);margin-bottom:16px;position:relative}
.page-hero p{color:rgba(255,255,255,.55);font-size:1.05rem;max-width:520px;margin:0 auto;position:relative;font-weight:300}

/* BREADCRUMB */
.breadcrumb{display:flex;gap:8px;align-items:center;font-size:.76rem;color:var(--sand);padding:14px 28px;background:var(--cream);border-bottom:1px solid rgba(200,150,43,.1);flex-wrap:wrap}
.breadcrumb a{color:var(--gold)}
.breadcrumb a:hover{color:var(--gold-lt)}
.breadcrumb span{opacity:.5}

/* TOUR CARD */
.tc{background:var(--white);border-radius:var(--r3);overflow:hidden;border:1px solid rgba(200,150,43,.14);box-shadow:var(--sh-xs);transition:transform var(--t),box-shadow var(--t),border-color var(--t);display:flex;flex-direction:column}
.tc:hover{transform:translateY(-7px);box-shadow:var(--sh-lg);border-color:rgba(200,150,43,.32)}
.tc__img{position:relative;height:216px;overflow:hidden;flex-shrink:0}
.tc__img img{width:100%;height:100%;object-fit:cover;transition:transform .55s ease}
.tc:hover .tc__img img{transform:scale(1.07)}
.tc__badges{position:absolute;top:12px;left:12px;display:flex;gap:6px}
.tc__dur{position:absolute;bottom:12px;right:12px}
.tc__body{padding:22px;flex:1;display:flex;flex-direction:column}
.tc__title{font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-weight:600;color:var(--ink);margin-bottom:9px;line-height:1.25}
.tc__desc{font-size:.84rem;color:var(--bark);line-height:1.68;flex:1;margin-bottom:14px;font-weight:300}
.tc__meta{display:flex;gap:14px;flex-wrap:wrap}
.tc__meta-i{display:flex;align-items:center;gap:5px;font-size:.74rem;font-weight:500;color:var(--sand)}
.tc__foot{padding:14px 22px;border-top:1px solid rgba(200,150,43,.12);display:flex;justify-content:space-between;align-items:center;background:var(--cream)}
.tc__book{padding:9px 20px;background:var(--gold);color:var(--ink);border-radius:var(--r1);font-size:.76rem;font-weight:700;letter-spacing:.6px;text-transform:uppercase;transition:all var(--t)}
.tc__book:hover{background:var(--gold-lt)}

/* TOUR DETAIL */
.tour-detail-hero{min-height:58vh;position:relative;display:flex;align-items:flex-end;margin-top:72px;overflow:hidden}
.tour-detail-hero__bg{position:absolute;inset:0;background-size:cover;background-position:center}
.tour-detail-hero__overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(28,22,16,.95) 0%,rgba(28,22,16,.4) 55%,rgba(28,22,16,.1) 100%)}
.tour-detail-hero__content{position:relative;z-index:2;padding:60px 28px 52px;max-width:1240px;margin:0 auto;width:100%}
.tour-detail-body{display:grid;grid-template-columns:1fr 340px;gap:52px;align-items:start}
.tour-detail-main h2{font-family:'Cormorant Garamond',serif;font-size:1.5rem;color:var(--ink);margin:36px 0 14px}
.tour-detail-main p{color:var(--bark);line-height:1.8;margin-bottom:14px;font-weight:300}
.tour-detail-main ul{margin:12px 0 20px 0;display:flex;flex-direction:column;gap:8px}
.tour-detail-main li{display:flex;align-items:flex-start;gap:9px;font-size:.88rem;color:var(--bark);font-weight:300}
.tour-detail-main li::before{content:'◆';color:var(--gold);font-size:.5rem;margin-top:6px;flex-shrink:0}
.tour-detail-sidebar{position:sticky;top:90px}
.sidebar-card{background:var(--white);border:1px solid rgba(200,150,43,.2);border-radius:var(--r3);box-shadow:var(--sh-md);overflow:hidden}
.sidebar-card__head{background:var(--ink-mid);padding:24px;border-bottom:1px solid var(--gold-line)}
.sidebar-card__head h3{font-family:'Cormorant Garamond',serif;color:var(--gold-lt);font-size:1.3rem;margin-bottom:4px}
.sidebar-card__head p{color:rgba(255,255,255,.5);font-size:.8rem;font-weight:300}
.sidebar-card__body{padding:24px}
.sidebar-info{display:flex;flex-direction:column;gap:12px;margin-bottom:22px}
.sidebar-info-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--cream);border-radius:var(--r1);border:1px solid var(--border-lt)}
.sidebar-info-item strong{display:block;font-size:.78rem;color:var(--ink);font-weight:600;font-family:'Jost',sans-serif}
.sidebar-info-item span{font-size:.72rem;color:var(--sand)}
.sidebar-info-item .si-icon{font-size:1.1rem;flex-shrink:0}

/* RELATED TOURS */
.related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}

/* CTA BANNER */
.cta-banner{background:linear-gradient(120deg,var(--ink) 0%,var(--ink-mid) 100%);border-radius:var(--r4);padding:64px 48px;text-align:center;position:relative;overflow:hidden;border:1px solid var(--gold-line)}
.cta-banner::before,.cta-banner::after{content:'';position:absolute;width:80px;height:80px;border:1px solid rgba(200,150,43,.2)}
.cta-banner::before{top:16px;left:16px;border-right:0;border-bottom:0}
.cta-banner::after{bottom:16px;right:16px;border-left:0;border-top:0}
.cta-banner h2{color:var(--gold-lt);margin-bottom:14px;position:relative}
.cta-banner p{color:rgba(255,255,255,.65);font-size:1.05rem;margin-bottom:32px;position:relative;font-weight:300}
.cta-banner__btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative}

/* TESTIMONIALS */
.testi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(285px,1fr));gap:20px}
.testi{background:var(--white);border:1px solid rgba(200,150,43,.14);border-radius:var(--r2);padding:28px;box-shadow:var(--sh-xs);position:relative}
.testi::after{content:'"';position:absolute;top:12px;right:18px;font-family:'Cormorant Garamond',serif;font-size:5rem;line-height:1;color:var(--gold-pale);pointer-events:none}
.testi__text{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1rem;color:var(--ink-soft);line-height:1.7;margin:12px 0 18px;position:relative;z-index:1}
.testi__author{display:flex;align-items:center;gap:11px}
.testi__av{width:38px;height:38px;border-radius:50%;background:var(--gold-pale);color:var(--gold);border:1.5px solid var(--gold-line);display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1rem;flex-shrink:0}
.testi__name{font-size:.83rem;font-weight:600;color:var(--ink)}
.testi__via{font-size:.7rem;color:var(--sand)}

/* WHY CARDS */
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(216px,1fr));gap:22px}
.why-card{padding:30px 24px;border-radius:var(--r2);background:var(--white);border:1px solid var(--border-lt);box-shadow:var(--sh-xs);transition:border-color var(--t),transform var(--t),box-shadow var(--t);position:relative;overflow:hidden}
.why-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:0;transition:opacity var(--t)}
.why-card:hover{border-color:rgba(200,150,43,.3);transform:translateY(-4px);box-shadow:var(--sh-sm)}
.why-card:hover::before{opacity:1}
.why-card__icon{font-size:1.8rem;margin-bottom:14px}
.why-card h3{font-size:1rem;margin-bottom:8px}
.why-card p{font-size:.83rem;color:var(--bark);line-height:1.65;font-weight:300}

/* GALLERY */
.gal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.gal-item{border-radius:var(--r2);overflow:hidden;cursor:pointer;position:relative;aspect-ratio:4/3;background:var(--parch);border:1px solid var(--border-lt)}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease;display:block}
.gal-item:hover img{transform:scale(1.06)}
.gal-item__ov{position:absolute;inset:0;background:rgba(28,22,16,0);display:flex;align-items:flex-end;padding:16px;transition:background var(--t)}
.gal-item:hover .gal-item__ov{background:rgba(28,22,16,.52)}
.gal-item__lbl{color:var(--gold-lt);font-style:italic;font-family:'Cormorant Garamond',serif;font-size:.95rem;opacity:0;transform:translateY(5px);transition:opacity var(--t),transform var(--t)}
.gal-item:hover .gal-item__lbl{opacity:1;transform:none}
.lb{display:none;position:fixed;inset:0;z-index:500;background:rgba(28,22,16,.96);align-items:center;justify-content:center;padding:24px}
.lb.open{display:flex}
.lb__img{max-height:88vh;max-width:90vw;border-radius:var(--r2);border:1px solid var(--gold-line)}
.lb__btn{position:absolute;width:48px;height:48px;border-radius:50%;background:rgba(200,150,43,.12);border:1px solid var(--gold-line);color:var(--gold-lt);display:flex;align-items:center;justify-content:center;transition:all var(--t);cursor:pointer;font-size:1.3rem}
.lb__btn:hover{background:var(--gold);color:var(--ink)}
#lbClose{top:20px;right:20px}
#lbPrev{top:50%;left:16px;transform:translateY(-50%);font-size:1.6rem}
#lbNext{top:50%;right:16px;transform:translateY(-50%);font-size:1.6rem}

/* CONTACT */
.kontakt-layout{display:grid;grid-template-columns:1fr 1.4fr;gap:56px;align-items:start}
.kontakt-info{background:var(--ink-mid);border:1px solid var(--gold-line);border-radius:var(--r4);padding:42px;position:sticky;top:90px}
.kontakt-info h2{font-family:'Cormorant Garamond',serif;color:var(--gold-lt);font-size:1.5rem;margin-bottom:8px}
.kontakt-info .info-sub{color:rgba(255,255,255,.52);font-size:.86rem;line-height:1.7;margin-bottom:26px;font-weight:300}
.k-method{display:flex;align-items:center;gap:14px;padding:14px 16px;background:rgba(200,150,43,.05);border:1px solid var(--gold-line);border-radius:var(--r1);margin-bottom:10px;text-decoration:none;transition:all var(--t)}
.k-method:hover{background:rgba(200,150,43,.12);border-color:rgba(200,150,43,.35)}
.k-method__icon{font-size:1.2rem;flex-shrink:0}
.k-method strong{display:block;color:var(--gold-lt);font-size:.88rem;margin-bottom:2px;font-weight:500}
.k-method span{color:rgba(255,255,255,.4);font-size:.74rem}
.k-promise{margin-top:22px;padding:14px 16px;background:rgba(200,150,43,.08);border:1px solid rgba(200,150,43,.2);border-radius:var(--r1);font-size:.79rem;color:rgba(255,255,255,.6);display:flex;gap:9px;line-height:1.6;font-weight:300}
.k-guide-card{margin-top:22px;background:rgba(255,255,255,.04);border:1px solid var(--gold-line);border-radius:var(--r2);padding:18px;display:flex;gap:14px;align-items:center}
.k-guide-card img{width:56px;height:56px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid var(--gold-line)}
.k-guide-name{font-weight:600;font-size:.94rem;color:var(--gold-lt);font-family:'Cormorant Garamond',serif}
.k-guide-sub{font-size:.72rem;color:rgba(255,255,255,.4)}
.k-form{background:var(--white);border:1px solid rgba(200,150,43,.16);border-radius:var(--r4);box-shadow:var(--sh-sm);padding:44px}
.k-form h2{font-family:'Cormorant Garamond',serif;font-size:1.6rem;margin-bottom:6px;color:var(--ink)}
.k-form__sub{color:var(--bark);font-size:.86rem;margin-bottom:28px;font-weight:300}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.fg{display:flex;flex-direction:column;gap:6px}
.fg.full{grid-column:1/-1}
.fg label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--sand)}
.fg input,.fg select,.fg textarea{padding:13px 15px;border:1.5px solid rgba(200,150,43,.18);border-radius:var(--r1);font-family:'Jost',sans-serif;font-size:.9rem;color:var(--ink);outline:none;background:var(--cream);transition:border-color var(--t),box-shadow var(--t);appearance:none;font-weight:300}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--gold);background:var(--white);box-shadow:0 0 0 3px rgba(200,150,43,.1)}
.fg textarea{resize:vertical;min-height:110px}
.fg select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23A89070' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.fg-check{grid-column:1/-1;display:flex;align-items:flex-start;gap:10px}
.fg-check input[type=checkbox]{margin-top:3px;flex-shrink:0;width:16px;height:16px;accent-color:var(--gold);cursor:pointer}
.fg-check label{font-size:.77rem;color:var(--sand);text-transform:none;letter-spacing:0;font-weight:300;line-height:1.55}
.form-submit{width:100%;padding:16px;background:var(--gold);color:var(--ink);border-radius:var(--r1);font-family:'Jost',sans-serif;font-size:.88rem;font-weight:700;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:9px;letter-spacing:.7px;text-transform:uppercase;box-shadow:var(--sh-gold);transition:all var(--t);margin-top:6px}
.form-submit:hover{background:var(--gold-lt);transform:translateY(-1px)}
.form-success{display:none;margin-top:14px;background:rgba(200,150,43,.1);border:1px solid rgba(200,150,43,.25);border-radius:var(--r1);padding:14px 18px;color:var(--gold);font-weight:600;font-size:.86rem}
.form-success.show{display:block}

/* FAQ */
.faq-item{background:var(--white);border:1px solid rgba(200,150,43,.2);border-radius:var(--r2);margin-bottom:12px;overflow:hidden}
.faq-item summary{font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-weight:600;color:var(--ink);padding:18px 22px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;list-style:none;transition:background var(--t)}
.faq-item summary:hover{background:var(--cream)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';color:var(--gold);font-size:1.4rem;font-family:'Jost',sans-serif;flex-shrink:0;margin-left:12px;transition:transform var(--t)}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item__body{padding:4px 22px 18px;color:var(--bark);font-size:.9rem;line-height:1.75;font-weight:300}
.faq-item__body a{color:var(--gold)}

/* LEGAL */
.legal-box{max-width:760px;margin:0 auto;background:var(--white);border:1px solid rgba(200,150,43,.14);border-radius:var(--r4);padding:52px;box-shadow:var(--sh-sm)}
.legal-box h2{font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:var(--ink);margin:36px 0 12px;padding-top:36px;border-top:1px solid rgba(200,150,43,.14)}
.legal-box h2:first-child{margin-top:0;padding-top:0;border:0}
.legal-box h3{font-size:1rem;color:var(--ink);margin:18px 0 8px;font-family:'Cormorant Garamond',serif;font-weight:600}
.legal-box p{font-size:.87rem;color:var(--bark);line-height:1.78;margin-bottom:10px;font-weight:300}
.legal-box a{color:var(--gold)}

/* ABOUT SPLIT */
.about-split{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:center}
.about-split__img-wrap{position:relative;max-width:340px}
.about-split__img{width:100%;aspect-ratio:3/4;object-fit:cover;border-radius:var(--r4);box-shadow:var(--sh-lg);border:4px solid var(--gold-pale)}
.about-split__frame{position:absolute;top:-16px;left:-16px;right:16px;bottom:16px;border-radius:var(--r4);border:1.5px solid var(--gold-line);pointer-events:none}
.about-split__badge-box{position:absolute;bottom:-28px;right:-28px;background:var(--ink-mid);border:1px solid var(--gold-line);border-radius:var(--r2);padding:22px 24px;min-width:204px;box-shadow:var(--sh-md)}
.about-split__badge-box h5{font-size:.6rem;text-transform:uppercase;letter-spacing:2px;color:var(--gold);margin-bottom:12px;font-weight:600}
.cert-row{display:flex;align-items:center;gap:8px;font-size:.8rem;font-weight:500;color:rgba(255,255,255,.75);padding:6px 0;border-bottom:1px solid rgba(200,150,43,.12)}
.cert-row:last-child{border:0}
.cert-row::before{content:'◆';color:var(--gold);font-size:.5rem;flex-shrink:0}

/* FOOTER */
.footer{background:var(--ink);border-top:1px solid var(--gold-line);padding:72px 0 36px}
.footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:52px;margin-bottom:52px}
.footer__brand h3{font-family:'Cormorant Garamond',serif;color:var(--gold-lt);font-size:1.3rem;margin-bottom:12px}
.footer__brand p{font-size:.82rem;color:rgba(255,255,255,.38);line-height:1.75;max-width:272px;font-weight:300}
.footer__brand address{margin-top:18px;display:flex;flex-direction:column;gap:6px;font-style:normal}
.footer__brand address a{color:rgba(255,255,255,.48);font-size:.81rem;transition:color var(--t)}
.footer__brand address a:hover{color:var(--gold-lt)}
.footer__col h4{font-size:.62rem;text-transform:uppercase;letter-spacing:2.5px;color:rgba(200,150,43,.5);font-weight:700;margin-bottom:18px}
.footer__col ul{display:flex;flex-direction:column;gap:9px}
.footer__col a{font-size:.81rem;color:rgba(255,255,255,.42);transition:color var(--t);font-weight:300}
.footer__col a:hover{color:var(--gold-lt)}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;padding-top:26px;border-top:1px solid rgba(200,150,43,.1);font-size:.74rem;flex-wrap:wrap;gap:10px}
.footer__bottom span{color:rgba(255,255,255,.28)}
.footer__bottom a{color:rgba(255,255,255,.28);margin-left:14px;transition:color var(--t)}
.footer__bottom a:hover{color:var(--gold-lt)}

/* TRUST BAND */
.trust-band{background:var(--ink);border-top:1px solid var(--gold-line);border-bottom:1px solid var(--gold-line);padding:22px 0}
.trust-band__inner{max-width:1240px;margin:0 auto;padding:0 28px;display:flex;justify-content:center;align-items:center;gap:48px;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:10px;font-size:.78rem;font-weight:500;color:rgba(255,255,255,.65);letter-spacing:.3px}

/* SCROLL REVEAL */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.vis{opacity:1;transform:none}

/* FILTERS */
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:40px}
.filter-btn{padding:8px 20px;border-radius:20px;border:1.5px solid rgba(200,150,43,.2);font-size:.78rem;font-weight:600;color:var(--bark);cursor:pointer;transition:all var(--t);background:var(--white);font-family:'Jost',sans-serif;letter-spacing:.3px}
.filter-btn:hover,.filter-btn.on{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.price-notice{background:var(--cream);border:1px solid rgba(200,150,43,.2);border-left:3px solid var(--gold);border-radius:var(--r2);padding:20px 26px;font-size:.86rem;color:var(--bark);line-height:1.7;margin-top:48px;font-weight:300}
.price-notice strong{color:var(--ink);font-weight:600}

/* ══════════════════════════════════════════════════════
   RESPONSIVE – vollständig überarbeitet
   Breakpoints: 1024px (Tablet), 768px (Mobile), 480px (Small), 360px (XS)
══════════════════════════════════════════════════════ */

/* ── TABLET (≤1024px) ── */
@media(max-width:1024px){
  .about-split{grid-template-columns:1fr;gap:44px}
  .about-split__img-wrap{max-width:300px;margin:0 auto}
  .about-split__badge-box{position:static;margin-top:16px;right:auto;bottom:auto}
  .about-split__frame{display:none}
  .footer__grid{grid-template-columns:1fr 1fr;gap:36px}
  .kontakt-layout{grid-template-columns:1fr;gap:40px}
  .kontakt-info{position:static}
  .tour-detail-body{grid-template-columns:1fr;gap:40px}
  .tour-detail-sidebar{position:static}
  .section{padding:72px 0}
  .section-sm{padding:52px 0}
}

/* ── MOBILE (≤768px) ── */
@media(max-width:768px){
  /* Nav */
  .nav__links,.nav__cta{display:none}
  .nav__ham{display:flex;min-width:44px;min-height:44px;align-items:center;justify-content:center}

  /* Container */
  .container{padding:0 18px}

  /* Sections */
  .section{padding:56px 0}
  .section-sm{padding:40px 0}

  /* Hero (index) */
  .hero__content{padding:100px 18px 56px}
  .hero__tagline{font-size:.97rem;border-left:none;padding-left:0;border-bottom:1px solid var(--gold-line);padding-bottom:16px}
  .hero__btns{flex-direction:column;align-items:stretch}
  .hero__btns .btn{justify-content:center;text-align:center}
  .hero__stat-card{gap:18px;padding:16px 18px;width:100%;justify-content:space-around}
  .hero__stat-n{font-size:1.7rem}

  /* Page hero (inner pages) */
  .page-hero{padding:56px 18px 44px}
  .page-hero h1{font-size:clamp(1.7rem,6vw,2.4rem)}

  /* Tour detail hero */
  .tour-detail-hero{min-height:52vh}
  .tour-detail-hero__content{padding:40px 18px 36px}
  .tour-detail-hero__content h1{font-size:clamp(1.6rem,6vw,2.2rem)}

  /* CTA Banner */
  .cta-banner{padding:40px 22px}
  .cta-banner::before,.cta-banner::after{display:none}
  .cta-banner__btns{flex-direction:column;align-items:stretch}
  .cta-banner__btns .btn{justify-content:center}

  /* Forms */
  .k-form{padding:28px 20px}
  .form-grid{grid-template-columns:1fr}

  /* Legal */
  .legal-box{padding:28px 20px}

  /* Footer */
  .footer{padding:52px 0 28px}
  .footer__grid{grid-template-columns:1fr;gap:28px;margin-bottom:36px}
  .footer__bottom{flex-direction:column;align-items:flex-start;gap:8px}

  /* Trust band */
  .trust-band__inner{gap:14px;flex-direction:column;align-items:flex-start;padding:0 18px}
  .trust-item{font-size:.82rem}

  /* Tour cards */
  .tc__img{height:200px}

  /* Why grid */
  .why-grid{grid-template-columns:1fr 1fr}

  /* Testi grid */
  .testi-grid{grid-template-columns:1fr}

  /* Gallery */
  .gal-grid{grid-template-columns:1fr 1fr;gap:10px}

  /* Sidebar on tour detail */
  .sidebar-card__body{padding:18px}

  /* Filters wrapping */
  .filters{gap:6px}
  .filter-btn{font-size:.73rem;padding:7px 14px}

  /* Breadcrumb */
  .breadcrumb{padding:12px 18px;font-size:.72rem}

  /* About split */
  .about-split__img-wrap{max-width:100%}
  .about-split__img{aspect-ratio:4/3}

  /* Lightbox buttons bigger for touch */
  .lb__btn{width:52px;height:52px;font-size:1.5rem}
  #lbPrev{left:8px}
  #lbNext{right:8px}
}

/* ── SMALL MOBILE (≤480px) ── */
@media(max-width:480px){
  /* Heading sizes */
  h1{font-size:clamp(1.6rem,7vw,2.1rem)}
  h2{font-size:clamp(1.35rem,5.5vw,1.7rem)}

  /* Container tighter */
  .container{padding:0 14px}

  /* Hero */
  .hero__content{padding:90px 14px 48px}
  .hero__stat-card{flex-wrap:wrap;gap:16px}

  /* Gallery single column on very small */
  .gal-grid{grid-template-columns:1fr 1fr}

  /* Why grid single column */
  .why-grid{grid-template-columns:1fr}

  /* Tour cards full width */
  .tc__img{height:185px}

  /* Page hero */
  .page-hero{padding:48px 14px 36px}

  /* Footer cols */
  .footer__col:last-child{display:none}

  /* Lightbox */
  .lb__img{max-width:100vw;border-radius:0}
  #lbPrev{left:4px}
  #lbNext{right:4px}

  /* Nav hamburger larger touch target */
  .nav__ham{min-width:48px;min-height:48px;padding:8px}

  /* Kontakt info padding */
  .kontakt-info{padding:28px 18px}
}

/* ── EXTRA SMALL (≤360px) ── */
@media(max-width:360px){
  .container{padding:0 12px}
  h1{font-size:1.55rem}
  h2{font-size:1.3rem}
  .btn{padding:13px 20px;font-size:.82rem}
  .btn-lg{padding:15px 24px;font-size:.88rem}
  .hero__stat-card{display:none} /* hide on very small screens */
  .section{padding:44px 0}
  .section-sm{padding:32px 0}
}

/* ══════════════════════════════════════════════════════
   TOUCH & MOBILE UX IMPROVEMENTS
══════════════════════════════════════════════════════ */

/* Smooth scrolling for iOS */
html{-webkit-overflow-scrolling:touch}

/* Remove tap highlight on mobile */
a,button{-webkit-tap-highlight-color:transparent}

/* Better touch targets for all interactive elements */
.drawer__link{min-height:48px;display:flex;align-items:center}
.tc__book{min-height:40px;display:inline-flex;align-items:center}
.filter-btn{min-height:40px}

/* Hamburger animation */
.nav__ham.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav__ham.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav__ham.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* Prevent horizontal scroll on mobile */
body{overflow-x:hidden;max-width:100vw}
.hero__stat-card{max-width:100%}

/* Mobile: tour detail hero min-height less aggressive */
@media(max-width:480px){
  .tour-detail-hero{min-height:44vh}
  .tour-detail-hero__content{padding:32px 14px 28px}
  .tour-detail-hero__content .badge-gold{font-size:.6rem}
  .tour-detail-hero__content h1{margin-bottom:10px}
  .tour-detail-hero__content p{font-size:.92rem}
  .tour-detail-hero__content .btn-lg{padding:14px 22px;font-size:.85rem}
}

/* Mobile: sidebar-info-item stacking */
@media(max-width:480px){
  .sidebar-info-item{flex-direction:row;gap:10px}
  .related-grid{grid-template-columns:1fr}
}

/* Mobile: footer compact */
@media(max-width:480px){
  .footer__brand p{display:none}
  .footer__brand address{margin-top:12px}
}

/* Mobile: faq items */
@media(max-width:480px){
  .faq-item summary{font-size:1rem;padding:15px 16px}
  .faq-item__body{padding:4px 16px 15px;font-size:.86rem}
}

/* Mobile: about split image */
@media(max-width:480px){
  .about-split__badge-box{min-width:unset;width:100%}
  .cert-row{font-size:.75rem}
}

/* Mobile: testimonials */
@media(max-width:480px){
  .testi{padding:22px 18px}
  .testi::after{font-size:3.5rem;top:8px;right:12px}
}

/* Mobile: form improvements */
@media(max-width:480px){
  .fg input,.fg select,.fg textarea{font-size:16px} /* prevent iOS zoom */
  .form-submit{font-size:.82rem;padding:15px}
}

/* Mobile: gallery lightbox full screen */
@media(max-width:480px){
  .lb{padding:0}
  .lb__img{max-height:100vh;max-width:100vw;border-radius:0;border:none}
  #lbClose{top:12px;right:12px;width:44px;height:44px}
}

/* Safe area insets for iPhone notch */
@supports(padding:max(0px)){
  .nav__inner{
    padding-left:max(28px,env(safe-area-inset-left));
    padding-right:max(28px,env(safe-area-inset-right));
  }
  @media(max-width:768px){
    .nav__inner{padding-left:max(18px,env(safe-area-inset-left));padding-right:max(18px,env(safe-area-inset-right))}
    .container{padding-left:max(18px,env(safe-area-inset-left));padding-right:max(18px,env(safe-area-inset-right))}
  }
  .footer{padding-bottom:max(36px,env(safe-area-inset-bottom))}
}


/* ══════════════════════════════════════════════════════
   ACCESSIBILITY & PREFERENCE MEDIA QUERIES
══════════════════════════════════════════════════════ */

/* Reduced Motion – wichtig für Nutzer mit Vestibulitis/Epilepsie */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .reveal { opacity: 1 !important; transform: none !important; }
}

/* Focus-Visible – bessere Tastaturnavigation */
:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 3px;
  border-radius: var(--r1);
}
a:focus-visible, button:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 3px;
}
/* Remove outline for mouse users */
:focus:not(:focus-visible) { outline: none; }

/* Print Styles – falls jemand eine Tour ausdruckt */
@media print {
  .nav, .drawer, .hero__btns, .cta-banner, .footer,
  .tc__foot, .sidebar-card .btn, .faq-item summary::after { display: none !important; }
  body { color: #000; background: #fff; font-size: 12pt; }
  h1, h2, h3 { color: #000; page-break-after: avoid; }
  .hero__overlay { background: rgba(0,0,0,.6) !important; }
  .tour-detail-body { grid-template-columns: 1fr !important; }
  a[href]::after { content: " (" attr(href) ")"; font-size: .8em; color: #555; }
  a[href^="tel"]::after, a[href^="mailto"]::after { content: " (" attr(href) ")"; }
}

/* High Contrast Mode Support */
@media (forced-colors: active) {
  .btn-gold { forced-color-adjust: none; }
  .badge { forced-color-adjust: none; }
}

/* ══════════════════════════════════════════════════════
   MICRO-ANIMATIONS (respectful of reduced-motion)
══════════════════════════════════════════════════════ */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
.hero__content h1 { animation: fadeInUp .7s ease both; animation-delay: .1s; }
.hero__tagline    { animation: fadeInUp .7s ease both; animation-delay: .25s; }
.hero__btns       { animation: fadeInUp .7s ease both; animation-delay: .4s; }
.hero__stat-card  { animation: fadeInUp .7s ease both; animation-delay: .55s; }

/* ══════════════════════════════════════════════════════
   WHATSAPP FLOATING BUTTON
══════════════════════════════════════════════════════ */
.wa-float {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 200;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #25D366;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.6rem;
  box-shadow: 0 4px 20px rgba(37,211,102,.4);
  transition: transform .2s ease, box-shadow .2s ease;
  text-decoration: none;
  border: 2px solid rgba(255,255,255,.2);
}
.wa-float:hover {
  transform: scale(1.08) translateY(-2px);
  box-shadow: 0 8px 28px rgba(37,211,102,.5);
}
.wa-float__tooltip {
  position: absolute;
  right: 64px;
  background: var(--ink);
  color: var(--gold-lt);
  padding: 6px 14px;
  border-radius: var(--r1);
  font-size: .75rem;
  font-weight: 600;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s;
  letter-spacing: .3px;
  border: 1px solid var(--gold-line);
}
.wa-float:hover .wa-float__tooltip { opacity: 1; }
@media(max-width:480px) {
  .wa-float { bottom: 16px; right: 16px; width: 50px; height: 50px; font-size: 1.4rem; }
}

/* ══════════════════════════════════════════════════════
   STICKY MOBILE CTA BAR (auf Tour-Seiten)
══════════════════════════════════════════════════════ */
.sticky-cta {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 150;
  background: var(--ink);
  border-top: 1px solid var(--gold-line);
  padding: 12px 16px;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
  box-shadow: 0 -4px 20px rgba(28,22,16,.4);
  padding-bottom: max(12px, env(safe-area-inset-bottom));
}
.sticky-cta__text {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1rem;
  color: var(--gold-lt);
  font-weight: 600;
  flex: 1;
  line-height: 1.2;
}
.sticky-cta__sub {
  font-size: .68rem;
  color: rgba(255,255,255,.4);
  font-family: 'Jost', sans-serif;
  font-weight: 300;
}
@media(max-width:768px) {
  .sticky-cta { display: flex; }
  body { padding-bottom: 80px; }
  body.no-sticky-padding { padding-bottom: 0; }
}

/* ══════════════════════════════════════════════════════
   SCROLL PROGRESS BAR (Tour-Detail-Seiten)
══════════════════════════════════════════════════════ */
.scroll-progress {
  position: fixed;
  top: 72px;
  left: 0;
  height: 2px;
  background: var(--gold);
  z-index: 299;
  width: 0%;
  transition: width .1s linear;
  box-shadow: 0 0 8px rgba(200,150,43,.5);
}

/* ══════════════════════════════════════════════════════
   COOKIE BANNER (DSGVO)
══════════════════════════════════════════════════════ */
.cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 400;
  background: var(--ink-mid);
  border-top: 1px solid var(--gold-line);
  padding: 20px 28px;
  display: flex;
  align-items: center;
  gap: 20px;
  justify-content: space-between;
  flex-wrap: wrap;
  box-shadow: 0 -4px 24px rgba(28,22,16,.4);
  transform: translateY(100%);
  transition: transform .4s cubic-bezier(.4,0,.2,1);
  padding-bottom: max(20px, env(safe-area-inset-bottom));
}
.cookie-banner.show { transform: translateY(0); }
.cookie-banner p {
  color: rgba(255,255,255,.65);
  font-size: .82rem;
  margin: 0;
  flex: 1;
  min-width: 200px;
  line-height: 1.6;
}
.cookie-banner p a { color: var(--gold-lt); }
.cookie-btn-wrap { display: flex; gap: 10px; flex-shrink: 0; }
.cookie-accept {
  padding: 9px 22px;
  background: var(--gold);
  color: var(--ink);
  border-radius: var(--r1);
  font-size: .8rem;
  font-weight: 700;
  border: none;
  cursor: pointer;
  letter-spacing: .5px;
  text-transform: uppercase;
  transition: background .2s;
  font-family: 'Jost', sans-serif;
}
.cookie-accept:hover { background: var(--gold-lt); }
.cookie-decline {
  padding: 9px 18px;
  background: transparent;
  color: rgba(255,255,255,.5);
  border-radius: var(--r1);
  font-size: .8rem;
  border: 1px solid rgba(255,255,255,.15);
  cursor: pointer;
  font-family: 'Jost', sans-serif;
  transition: border-color .2s;
}
.cookie-decline:hover { border-color: rgba(255,255,255,.3); }
@media(max-width:480px) {
  .cookie-banner { padding: 16px 16px; padding-bottom: max(16px, env(safe-area-inset-bottom)); }
  .cookie-btn-wrap { width: 100%; }
  .cookie-accept, .cookie-decline { flex: 1; text-align: center; }
}

/* Formular-Fehler Styling */
.fg input[aria-invalid="true"],
.fg select[aria-invalid="true"],
.fg textarea[aria-invalid="true"] {
  border-color: #c85050;
  background: rgba(200,80,80,.04);
}
.fg input[aria-invalid="true"]:focus,
.fg select[aria-invalid="true"]:focus {
  border-color: #c85050;
  box-shadow: 0 0 0 3px rgba(200,80,80,.12);
}

/* Screen-reader only text */
.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* ══════════════════════════════════════════════════════
   WCAG AA FARBKONTRAST-KORREKTUREN
   Gold #C8962B auf Weiss hat nur 2.6:1 (braucht 4.5:1 fuer Text).
   Loesung: --gold-text fuer Text auf hellem Hintergrund.
   #8B6914 auf Weiss: 5.8:1 → WCAG AA bestanden.
══════════════════════════════════════════════════════ */
:root {
  --gold-text: #8B6914;   /* Fuer Text auf hellem Hintergrund – 5.8:1 Kontrast */
  --gold-text-lt: #A07820; /* Fuer groesseren Text (>18pt) – 4.5:1 */
}

/* Links auf hellem Hintergrund (cream/white) */
.legal-box a,
.faq-item__body a,
.tour-detail-main a,
.price-notice a,
.k-form__sub a,
.fg-check label a,
.footer__bottom a:not([class]) {
  color: var(--gold-text);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.legal-box a:hover,
.faq-item__body a:hover,
.tour-detail-main a:hover {
  color: var(--gold-text-lt);
}

/* Eyebrow auf hellen Sektionen */
.section:not([style*="background:var(--ink)"]) .eyebrow,
.section-sm:not([style*="background:var(--ink)"]) .eyebrow {
  color: var(--gold-text);
}

/* Sidebar-Info auf hellem BG */
.sidebar-info-item strong {
  color: #2A1E0A;
}

/* Social Share Bar */
.share-bar{display:flex;align-items:center;gap:10px;margin-top:32px;padding-top:20px;border-top:1px solid rgba(200,150,43,.15);flex-wrap:wrap}
.share-bar__label{font-size:.72rem;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--sand);margin-right:4px}
.share-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:20px;font-size:.76rem;font-weight:600;border:1.5px solid;cursor:pointer;transition:all .2s;font-family:'Jost',sans-serif;text-decoration:none;letter-spacing:.3px}
.share-btn--wa{color:#128C7E;border-color:#128C7E}
.share-btn--wa:hover{background:#128C7E;color:#fff}
.share-btn--fb{color:#1877F2;border-color:#1877F2}
.share-btn--fb:hover{background:#1877F2;color:#fff}
.share-btn--mail{color:var(--gold-text);border-color:var(--gold-text)}
.share-btn--mail:hover{background:var(--gold-text);color:#fff}
.share-btn--copy{color:var(--bark);border-color:rgba(107,85,64,.35)}
.share-btn--copy:hover{background:var(--cream)}
.share-btn--copy.copied{color:#2e7d32;border-color:#2e7d32}
@media(max-width:480px){.share-bar{gap:8px}.share-btn{padding:7px 12px;font-size:.72rem}}

/* Print-Button */
.print-btn{display:inline-flex;align-items:center;gap:7px;padding:7px 16px;border-radius:20px;font-size:.74rem;font-weight:500;border:1.5px solid rgba(107,85,64,.25);cursor:pointer;color:var(--sand);background:transparent;font-family:'Jost',sans-serif;transition:all .2s;margin-left:auto}
.print-btn:hover{background:var(--cream);border-color:var(--gold-text);color:var(--gold-text)}
@media print{.print-btn{display:none}}

/* ══════════════════════════════════════════════════════
   SCROLL-TO-TOP BUTTON
══════════════════════════════════════════════════════ */
.scroll-top {
  position: fixed;
  bottom: 88px;
  right: 24px;
  z-index: 199;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--ink-mid);
  border: 1.5px solid var(--gold-line);
  color: var(--gold-lt);
  font-size: 1.1rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity .3s, transform .3s, background .2s;
  box-shadow: var(--sh-sm);
  pointer-events: none;
}
.scroll-top.visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: all;
}
.scroll-top:hover {
  background: var(--gold);
  color: var(--ink);
  border-color: var(--gold);
}
@media(max-width:768px) {
  .scroll-top { bottom: 96px; right: 16px; width: 40px; height: 40px; }
}

/* Form Submit Spinner */
@keyframes spin { to { transform: rotate(360deg); } }
.form-submit .spinner {
  width: 16px; height: 16px;
  border: 2px solid rgba(28,22,16,.3);
  border-top-color: var(--ink);
  border-radius: 50%;
  animation: spin .7s linear infinite;
  display: none;
}
.form-submit.loading .spinner { display: inline-block; }
.form-submit.loading .btn-text { opacity: 0.7; }
