/* ============================================================
   jagdwaffentransport.de — Büchsenmacher-Look (Loden/Nussbaum/Messing)
   Headlines: Lora · Fließtext: Source Sans 3 (beide selbst gehostet)
   ============================================================ */

/* ---- Fonts (selbst gehostet, KEIN Google-CDN) ---- */
@font-face{font-family:'Lora';font-style:normal;font-weight:500 700;font-display:swap;src:url('fonts/lora-var.woff2') format('woff2');}
@font-face{font-family:'Source Sans 3';font-style:normal;font-weight:400 700;font-display:swap;src:url('fonts/sourcesans3-var.woff2') format('woff2');}

:root{
  --loden:#2A3B2E;        /* Primär */
  --loden-dark:#1F2C23;
  --nuss:#3E3228;         /* Sekundär */
  --messing:#C3A15B;      /* Akzent */
  --messing-dark:#A8863F;
  --pergament:#F5F1E8;    /* Hintergrund */
  --pergament-2:#EDE7D8;
  --text:#1A211D;         /* brünierter Stahl */
  --text-2:#5C5C5C;
  --line:#D9D2C2;
  --white:#FFFDF8;
  --serif:'Lora',Georgia,'Times New Roman',serif;
  --sans:'Source Sans 3',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;
  --wrap:1180px;
  --r:10px;
  --shadow:0 6px 28px rgba(26,33,29,.10);
  --shadow-lg:0 18px 50px rgba(26,33,29,.18);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);color:var(--text);background:var(--pergament);
  line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased;
  /* feines Leinen/Papier-Noise */
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.025'/%3E%3C/svg%3E");
}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.18;letter-spacing:.01em;color:var(--loden-dark)}
h1{font-size:clamp(2.1rem,5vw,3.4rem)}
h2{font-size:clamp(1.6rem,3.4vw,2.5rem)}
h3{font-size:1.28rem}
p{margin:0 0 1rem}
a{color:var(--nuss);text-decoration-color:var(--messing);text-underline-offset:3px}
img{max-width:100%;display:block}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 22px}
.eyebrow{font-family:var(--sans);font-weight:700;text-transform:uppercase;letter-spacing:.18em;font-size:.74rem;color:var(--messing-dark)}
.muted{color:var(--text-2)}
.center{text-align:center}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--sans);font-weight:700;font-size:1rem;
  padding:.85em 1.5em;border-radius:var(--r);border:1.5px solid transparent;cursor:pointer;text-decoration:none;transition:.18s;line-height:1}
.btn-gold{background:var(--messing);color:var(--loden-dark);box-shadow:0 4px 14px rgba(168,134,63,.35)}
.btn-gold:hover{background:var(--messing-dark);color:#fff;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--white);border-color:rgba(245,241,232,.5)}
.btn-ghost:hover{border-color:var(--messing);color:var(--messing)}
.btn-outline{background:transparent;color:var(--loden);border-color:var(--loden)}
.btn-outline:hover{background:var(--loden);color:var(--white)}

/* ---- Header / Nav ---- */
header.site{position:sticky;top:0;z-index:50;background:rgba(31,44,35,.96);backdrop-filter:blur(8px);border-bottom:1px solid rgba(195,161,91,.25)}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{display:flex;align-items:center;gap:.6em;color:var(--pergament);font-family:var(--serif);font-weight:600;font-size:1.18rem;text-decoration:none;letter-spacing:.02em}
.brand .mark{color:var(--messing)}
.brand-logo{height:36px;width:auto;display:block;flex:none}
.brand-wordmark{height:18px;width:auto;display:block;flex:none}
@media(max-width:560px){.brand{min-width:0;gap:.45em}.brand-logo{height:28px}.brand-wordmark{height:auto;width:auto;max-width:calc(100vw - 122px)}}
footer.site .brand-logo{height:32px;margin-bottom:10px}
footer.site .dwl-brand{display:inline-block;margin-top:18px}
footer.site .dwl-brand img{display:block;height:42px;width:auto;opacity:.9;transition:opacity .2s}
footer.site .dwl-brand:hover img{opacity:1}
nav.main{display:flex;gap:1.5rem;align-items:center}
nav.main a{color:var(--pergament);text-decoration:none;font-weight:600;font-size:.96rem;opacity:.9}
nav.main a:hover{color:var(--messing);opacity:1}
.nav-cta{background:var(--messing);color:var(--loden-dark)!important;padding:.5em 1em;border-radius:8px}
.burger{display:none;background:none;border:0;color:var(--pergament);cursor:pointer}

/* ---- Hero ---- */
.hero{position:relative;color:var(--pergament);background:var(--loden-dark);overflow:hidden}
.hero-slides{position:absolute;inset:0}
.hero-slide{position:absolute;inset:0;background-position:center;background-size:cover;background-repeat:no-repeat;opacity:0}
.hero-slides.ready .hero-slide{transition:opacity 1.4s ease-in-out}
.hero-slide.is-active{opacity:1}
.hero-shade{position:absolute;inset:0;background:linear-gradient(110deg,rgba(20,28,22,.93) 0%,rgba(20,28,22,.6) 46%,rgba(20,28,22,.22) 100%)}
.hero .wrap{position:relative;padding:5.5rem 22px 5rem;max-width:var(--wrap)}
.hero-dots{position:absolute;left:0;right:0;bottom:18px;display:flex;gap:.5rem;justify-content:center;z-index:3}
.hero-dots button{width:30px;height:4px;border:0;border-radius:3px;background:rgba(245,241,232,.35);cursor:pointer;padding:0;transition:.2s}
.hero-dots button.on{background:var(--messing);width:42px}

/* ---- Bildband ---- */
.imgband{position:relative;background-position:center;background-size:cover;background-attachment:fixed;color:var(--pergament);text-align:center}
.imgband-shade{position:absolute;inset:0;background:rgba(20,28,22,.7)}
.imgband .wrap{position:relative;padding:4.5rem 22px}
.imgband blockquote{font-family:var(--serif);font-size:clamp(1.4rem,3.2vw,2.1rem);color:var(--white);max-width:760px;margin:0 auto .6rem;line-height:1.35}
.imgband p{color:var(--messing);font-weight:600;margin:0}
@media(max-width:760px){.imgband{background-attachment:scroll}}

/* ---- Galerie / Wechsler ---- */
.gallery{position:relative;max-width:1320px;margin:0 auto;padding:0 12px}
.gallery-track{display:flex;gap:1rem;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:.4rem 10px 1rem;-ms-overflow-style:none;scrollbar-width:none}
.gallery-track::-webkit-scrollbar{display:none}
.gslide{position:relative;flex:0 0 clamp(260px,44%,440px);scroll-snap-align:center;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);transition:transform .25s ease,box-shadow .25s ease}
.gslide img{width:100%;height:300px;object-fit:cover;display:block}
.gslide:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.gslide figcaption{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(transparent,rgba(20,28,22,.9));color:var(--pergament);padding:1.6rem .9rem .8rem;font-size:.92rem;font-weight:600}
.g-nav{position:absolute;top:calc(50% - 14px);transform:translateY(-50%);z-index:4;width:46px;height:46px;border-radius:50%;border:0;background:var(--loden-dark);color:var(--messing);font-size:1.6rem;line-height:1;cursor:pointer;box-shadow:var(--shadow);opacity:.92;transition:.18s}
.g-nav:hover{background:var(--messing);color:var(--loden-dark);opacity:1}
.g-prev{left:2px}.g-next{right:2px}
@media(max-width:560px){.gslide img{height:230px}.g-nav{display:none}}
.hero .inner{max-width:680px}
.hero h1{color:var(--white);margin:.5rem 0 1rem}
.hero h1 .gold{color:var(--messing)}
.hero p.sub{font-size:1.18rem;color:rgba(245,241,232,.92);margin-bottom:1.8rem;max-width:600px}
.hero .cta-row{display:flex;gap:.9rem;flex-wrap:wrap}
.hero .note{margin-top:1.3rem;font-size:.86rem;color:rgba(245,241,232,.7)}

/* ---- Trust-Bar ---- */
.trust{background:var(--nuss);color:var(--pergament)}
.trust .wrap{display:flex;flex-wrap:wrap;gap:1.2rem 2.4rem;justify-content:center;align-items:center;padding:.9rem 22px;font-size:.92rem;font-weight:600}
.trust .item{display:flex;align-items:center;gap:.5em}
.trust svg{stroke:var(--messing);width:20px;height:20px;flex:none}

/* ---- Sections ---- */
section{padding:4.5rem 0}
.sec-head{max-width:760px;margin:0 auto 2.6rem;text-align:center}
.sec-head h2{margin:.4rem 0 .8rem}
.sec-head p{font-size:1.08rem;color:var(--text-2)}
.alt{background:var(--pergament-2)}

/* ---- SEO-Hub Grid ---- */
.hub-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.2rem}
.hub-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:1.6rem;box-shadow:var(--shadow);transition:.18s}
.hub-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--messing)}
.hub-card .ic{width:42px;height:42px;margin-bottom:.9rem}
.hub-card .ic svg{width:42px;height:42px;stroke:var(--messing);fill:none;stroke-width:1.5}
.hub-card h3{margin-bottom:.5rem}
.hub-card p{font-size:.97rem;color:var(--text-2);margin:0}

/* ---- Regel-Matrix / Spezialfälle ---- */
.tbl-wrap{overflow-x:auto;margin:0 auto 2.6rem;max-width:940px;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);background:var(--white);-webkit-overflow-scrolling:touch}
.tbl{width:100%;border-collapse:collapse;font-size:.96rem;min-width:660px}
.tbl th,.tbl td{padding:.85rem 1rem;text-align:left;border-bottom:1px solid var(--line);vertical-align:middle}
.tbl thead th{background:var(--loden);color:var(--pergament);font-family:var(--sans);font-weight:700;font-size:.76rem;text-transform:uppercase;letter-spacing:.05em}
.tbl thead th:not(:first-child){text-align:center}
.tbl tbody tr:nth-child(even){background:rgba(42,59,46,.035)}
.tbl tbody tr:last-child td{border-bottom:0}
.tbl tbody tr{transition:background .15s}
.tbl tbody tr:hover{background:rgba(195,161,91,.10)}
.tbl td.c{text-align:center}
.tbl .sit{display:flex;align-items:center;gap:.6rem;font-weight:700;color:var(--loden-dark)}
.tbl .sit svg{width:21px;height:21px;stroke:var(--messing-dark);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;flex:none}
.tbl td.y::before{content:"✓";display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:rgba(63,125,68,.13);color:#3f7d44;font-weight:800;font-size:15px}
.tbl .soft{color:var(--text-2);font-size:.9rem;font-style:italic}
.tbl .pill{display:inline-block;background:var(--pergament-2);border:1px solid var(--line);border-radius:20px;padding:.25em .8em;font-size:.83rem;color:var(--loden-dark);font-weight:600;white-space:nowrap}
.special-note{text-align:center;font-size:.85rem;color:var(--text-2);margin-top:1.8rem}

/* ---- WaffG-Ampel ---- */
.ampel{background:var(--loden);color:var(--pergament);border-radius:14px;padding:2.2rem;box-shadow:var(--shadow-lg);max-width:880px;margin:0 auto;border:1px solid rgba(195,161,91,.3)}
.ampel h3{color:var(--white);font-size:1.45rem;margin-bottom:.4rem}
.ampel .lead{color:rgba(245,241,232,.85);margin-bottom:1.6rem}
.ampel-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}
.ampel-step{background:rgba(245,241,232,.06);border:1px solid rgba(245,241,232,.12);border-radius:10px;padding:1.1rem;position:relative}
.ampel-step .dot{width:14px;height:14px;border-radius:50%;background:#6FBF73;box-shadow:0 0 0 4px rgba(111,191,115,.2);margin-bottom:.7rem}
.ampel-step b{display:block;color:var(--white);margin-bottom:.25rem}
.ampel-step span{font-size:.9rem;color:rgba(245,241,232,.8)}
.ampel .verdict{margin-top:1.4rem;text-align:center;font-family:var(--serif);font-size:1.15rem;color:var(--messing)}
.ampel .disc{margin-top:.8rem;font-size:.8rem;color:rgba(245,241,232,.55);text-align:center}

/* ---- Transport-Kompass ---- */
.kompass{background:var(--white);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);max-width:760px;margin:0 auto;padding:2.2rem;min-height:340px}
.kompass .step-q{font-family:var(--serif);font-size:1.5rem;color:var(--loden-dark);margin-bottom:.4rem}
.kompass .progress{font-size:.8rem;text-transform:uppercase;letter-spacing:.15em;color:var(--messing-dark);font-weight:700;margin-bottom:1.3rem}
.kompass .opts{display:grid;gap:.7rem}
.kompass .opt{text-align:left;background:var(--pergament);border:1.5px solid var(--line);border-radius:10px;padding:1rem 1.2rem;font-family:var(--sans);font-size:1.02rem;font-weight:600;color:var(--text);cursor:pointer;transition:.15s;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.kompass .opt:hover{border-color:var(--messing);background:var(--white);transform:translateX(3px)}
.kompass .opt small{display:block;font-weight:400;color:var(--text-2);font-size:.85rem;margin-top:.15rem}
.kompass .opt .arr{color:var(--messing);flex:none}
.kompass .back{margin-top:1.3rem;background:none;border:0;color:var(--text-2);cursor:pointer;font-size:.9rem;font-weight:600}
.kompass .back:hover{color:var(--loden)}
/* Ergebnis */
.kompass .result{text-align:center}
.kompass .result .badge{display:inline-block;background:var(--messing);color:var(--loden-dark);font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;padding:.35em .9em;border-radius:20px;margin-bottom:1rem}
.kompass .result h3{font-size:1.7rem;margin-bottom:.5rem}
.kompass .result p{color:var(--text-2);max-width:520px;margin:0 auto 1.5rem}
.kompass .result .why{background:var(--pergament-2);border-radius:10px;padding:1rem 1.2rem;font-size:.95rem;text-align:left;margin:0 auto 1.5rem;max-width:520px}

/* ---- Funnel Cards ---- */
.funnel-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(310px,1fr));gap:1.4rem}
.fcard{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:1.8rem;display:flex;flex-direction:column;box-shadow:var(--shadow);transition:.18s}
.fcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--messing)}
.fcard .top{display:flex;align-items:center;gap:.8rem;margin-bottom:.5rem}
.fcard .ic{width:44px;height:44px;flex:none;border-radius:9px;background:var(--loden);display:grid;place-items:center}
.fcard .ic svg{width:24px;height:24px;stroke:var(--messing);fill:none;stroke-width:1.6}
.fcard .usecase{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--messing-dark)}
.fcard h3{font-size:1.2rem;margin:0}
.fcard .domain{font-size:.86rem;color:var(--text-2);margin:.1rem 0 .8rem}
.fcard p{font-size:.97rem;color:var(--text-2);margin-bottom:1rem}
.fcard ul{list-style:none;margin:0 0 1.3rem;padding:0;font-size:.92rem}
.fcard ul li{display:flex;gap:.5em;align-items:flex-start;margin-bottom:.4rem}
.fcard ul li::before{content:"";flex:none;width:18px;height:18px;margin-top:2px;background:no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23A8863F' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E")}
.fcard .btn{margin-top:auto;justify-content:center}

/* ---- FAQ ---- */
.faq{max-width:820px;margin:0 auto}
.faq details{background:var(--white);border:1px solid var(--line);border-radius:var(--r);margin-bottom:.8rem;overflow:hidden}
.faq summary{cursor:pointer;padding:1.1rem 1.3rem;font-family:var(--serif);font-weight:600;font-size:1.1rem;color:var(--loden-dark);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--messing);font-size:1.5rem;font-family:var(--sans);flex:none;transition:.2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .fa{padding:0 1.3rem 1.2rem;color:var(--text-2);font-size:1rem}

/* ---- Kontakt ---- */
.kontakt{background:linear-gradient(135deg,var(--loden) 0%,var(--loden-dark) 100%);color:var(--pergament)}
.contact-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:3rem;align-items:start}
.contact-intro h2{color:var(--white);margin:.4rem 0 1rem}
.contact-intro>p{color:rgba(245,241,232,.85);font-size:1.08rem;max-width:46ch;margin:0 0 1.8rem}
.ci-list{display:flex;flex-direction:column;gap:1.1rem}
.ci-item{display:flex;align-items:flex-start;gap:.9rem}
.ci-item .ic{flex:none;width:42px;height:42px;border-radius:10px;background:rgba(195,161,91,.14);display:flex;align-items:center;justify-content:center}
.ci-item .ic svg{width:21px;height:21px;stroke:var(--messing)}
.ci-item .t{font-size:.74rem;text-transform:uppercase;letter-spacing:.14em;color:rgba(245,241,232,.6);font-weight:700;margin-bottom:.1rem}
.ci-item .v{color:var(--white);font-weight:600;text-decoration:none;font-size:1.04rem}
a.ci-item .v:hover,.ci-item a.v:hover{color:var(--messing)}
.ci-item .v.plain{font-weight:600}
.ci-foot{margin-top:1.8rem;font-size:.95rem;color:rgba(245,241,232,.75)}
.ci-foot a{color:var(--messing);font-weight:700;text-decoration:none;white-space:nowrap}

.contact-card{position:relative}
.contact-form{background:var(--white);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-lg);padding:2rem}
.contact-form h3{color:var(--loden-dark);font-size:1.4rem;margin:0 0 .2rem}
.contact-form .sub{color:var(--text-2);font-size:.95rem;margin:0 0 1.4rem}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:.9rem 1rem}
.fgrid .full{grid-column:1 / -1}
.flbl{display:block;font-size:.8rem;font-weight:700;color:var(--loden-dark);margin-bottom:.35rem;letter-spacing:.01em}
.fld{width:100%;font-family:var(--sans);font-size:1rem;color:var(--text);background:var(--pergament);border:1.5px solid var(--line);border-radius:9px;padding:.7rem .85rem;transition:border-color .15s,box-shadow .15s}
.fld:focus{outline:0;border-color:var(--messing);box-shadow:0 0 0 3px rgba(195,161,91,.18)}
textarea.fld{resize:vertical;min-height:118px}
select.fld{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23A8863F' stroke-width='2.4'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .9rem center;padding-right:2.4rem}
.consent{display:flex;align-items:flex-start;gap:.6rem;margin:1.2rem 0;font-size:.88rem;color:var(--text-2);line-height:1.5;cursor:pointer}
.consent input{margin-top:.2rem;flex:none;width:17px;height:17px;accent-color:var(--messing-dark)}
.consent a{color:var(--nuss);font-weight:600}
.contact-form .btn-gold{width:100%;justify-content:center}
.form-note{font-size:.78rem;color:var(--text-2);margin:.9rem 0 0;text-align:center}
.form-success{display:none;background:var(--white);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-lg);padding:2.6rem 2rem;text-align:center}
.form-success.show{display:block}
.form-success .ic{width:62px;height:62px;border-radius:50%;background:rgba(195,161,91,.16);display:flex;align-items:center;justify-content:center;margin:0 auto 1.2rem}
.form-success .ic svg{width:30px;height:30px;stroke:var(--messing-dark)}
.form-success h3{color:var(--loden-dark);font-size:1.45rem;margin:0 0 .5rem}
.form-success p{color:var(--text-2);font-size:1rem;margin:0;max-width:36ch;margin-inline:auto}

/* ---- Footer ---- */
footer.site{background:var(--loden-dark);color:rgba(245,241,232,.8);padding:3.2rem 0 1.8rem;font-size:.93rem}
footer.site .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem;margin-bottom:2rem}
footer.site h4{color:var(--white);font-size:1rem;margin-bottom:.9rem;font-family:var(--sans);text-transform:uppercase;letter-spacing:.1em;font-weight:700}
footer.site a{color:rgba(245,241,232,.8);text-decoration:none;display:block;margin-bottom:.5rem}
footer.site a:hover{color:var(--messing)}
footer.site .legal{border-top:1px solid rgba(245,241,232,.15);padding-top:1.4rem;font-size:.84rem;color:rgba(245,241,232,.6);display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;justify-content:space-between}
footer.site .legal a{display:inline;margin:0}

/* ---- Cookie-Banner ---- */
.cc{position:fixed;left:16px;right:16px;bottom:16px;z-index:90;max-width:560px;margin:0 auto;background:var(--loden-dark);color:var(--pergament);border:1px solid var(--messing);border-radius:12px;padding:1.2rem 1.3rem;box-shadow:var(--shadow-lg);display:none}
.cc.show{display:block}
.cc p{font-size:.9rem;margin-bottom:.9rem;color:rgba(245,241,232,.9)}
.cc .row{display:flex;gap:.6rem;flex-wrap:wrap}
.cc .btn{padding:.6em 1.1em;font-size:.9rem}

/* ---- Nach-oben-Button ---- */
.totop{position:fixed;right:22px;bottom:22px;z-index:80;width:52px;height:52px;border-radius:10px;border:0;background:var(--messing);color:var(--loden-dark);display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .25s,visibility .25s,transform .25s,background .2s;box-shadow:0 6px 18px rgba(26,33,29,.4)}
.totop svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.totop:hover{background:var(--messing-dark);color:#fff;transform:translateY(0)}
.totop.show{opacity:1;visibility:visible;transform:translateY(0)}
@media(max-width:560px){.totop{right:16px;bottom:16px;width:46px;height:46px}}

/* ---- Prose / Rechtstexte ---- */
.page-hero{background:var(--loden-dark);color:var(--pergament);padding:3rem 0 2.4rem}
.page-hero h1{color:var(--white);font-size:clamp(1.8rem,4vw,2.6rem)}
.page-hero p{color:rgba(245,241,232,.8);margin:.4rem 0 0}
.prose{max-width:780px;margin:0 auto;padding:3rem 22px}
.prose h2{font-size:1.4rem;margin:2rem 0 .7rem}
.prose h3{font-size:1.12rem;margin:1.4rem 0 .4rem}
.prose p,.prose li{color:var(--text);font-size:1rem}
.prose ul{margin:0 0 1rem 1.2rem}
.prose a{color:var(--nuss)}
.prose .box{background:var(--white);border:1px solid var(--line);border-left:3px solid var(--messing);border-radius:8px;padding:1rem 1.2rem;margin:1.2rem 0}
.prose table{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.95rem}
.prose th,.prose td{text-align:left;padding:.6rem .7rem;border-bottom:1px solid var(--line);vertical-align:top}
.prose th{color:var(--loden-dark);font-family:var(--sans);font-weight:700}

/* ---- Responsive ---- */
@media(max-width:860px){
  footer.site .cols{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr;gap:2.2rem}
  nav.main{position:fixed;inset:68px 0 auto 0;background:var(--loden-dark);flex-direction:column;align-items:flex-start;padding:1rem 22px;gap:.4rem;border-bottom:1px solid rgba(195,161,91,.25);display:none}
  nav.main.open{display:flex}
  nav.main a{padding:.5rem 0;width:100%}
  .burger{display:block}
}
@media(max-width:560px){
  footer.site .cols{grid-template-columns:1fr}
  section{padding:3.2rem 0}
  .hero .wrap{padding:3.5rem 22px}
  .fgrid{grid-template-columns:1fr}
  .contact-form{padding:1.5rem}
}
