/* ============================================================
   Lackfuchs Allgäu · Stylesheet
   ============================================================ */
:root {
  --bg:        #0d0d0f;
  --bg-soft:   #141418;
  --surface:   #1a1a20;
  --surface-2: #22222b;
  --text:      #f4f4f6;
  --muted:     #a3a3ad;
  --line:      rgba(255,255,255,.09);

  --brand:     #ff6a1a;   /* Fuchs-Orange */
  --brand-2:   #ff9838;
  --brand-deep:#d94e00;

  --radius:    18px;
  --radius-sm: 12px;
  --maxw:      1200px;
  --ease:      cubic-bezier(.16,1,.3,1);
  --shadow:    0 24px 60px -20px rgba(0,0,0,.6);
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family:'Inter',system-ui,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4,.brand__text { font-family:'Sora',sans-serif; line-height:1.1; letter-spacing:-.02em; }
img { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }

.container { width:min(100% - 2.4rem, var(--maxw)); margin-inline:auto; }
.txt-grad {
  background:linear-gradient(100deg,var(--brand-2),var(--brand));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

/* ---------- Buttons ---------- */
.btn {
  --pad:.85rem 1.4rem;
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  padding:var(--pad); border-radius:100px; font-weight:600; font-family:'Sora',sans-serif;
  cursor:pointer; border:1px solid transparent; transition:transform .3s var(--ease), box-shadow .3s var(--ease), background .3s;
  white-space:nowrap;
}
.btn:active { transform:scale(.97); }
.btn--primary {
  background:linear-gradient(120deg,var(--brand),var(--brand-deep));
  color:#fff; box-shadow:0 10px 30px -8px rgba(255,106,26,.6);
}
.btn--primary:hover { transform:translateY(-2px); box-shadow:0 18px 40px -10px rgba(255,106,26,.75); }
.btn--ghost { background:rgba(255,255,255,.06); color:#fff; border-color:var(--line); backdrop-filter:blur(6px); }
.btn--ghost:hover { background:rgba(255,255,255,.12); transform:translateY(-2px); }
.btn--lg { --pad:1.05rem 1.9rem; font-size:1.02rem; }
.btn--sm { --pad:.6rem 1.1rem; font-size:.9rem; }
.btn--block { width:100%; }

.tag {
  display:inline-block; font-size:.78rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase;
  color:var(--brand-2); padding:.4rem .9rem; border:1px solid var(--line); border-radius:100px;
  background:rgba(255,106,26,.08); margin-bottom:1.1rem;
}

/* ---------- Scroll progress ---------- */
.scroll-progress {
  position:fixed; top:0; left:0; height:3px; width:0;
  background:linear-gradient(90deg,var(--brand),var(--brand-2)); z-index:200;
  transition:width .1s linear;
}

/* ---------- Nav ---------- */
.nav {
  position:fixed; inset:0 0 auto 0; z-index:100;
  transition:background .4s var(--ease), backdrop-filter .4s, border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.is-scrolled {
  background:rgba(13,13,15,.72); backdrop-filter:blur(16px);
  border-bottom-color:var(--line);
}
.nav__inner { display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:1rem 0; }
.brand { display:flex; align-items:center; gap:.6rem; font-weight:800; }
.brand__mark { font-size:1.7rem; filter:drop-shadow(0 4px 8px rgba(255,106,26,.4)); }
.brand__text { font-size:1.3rem; display:flex; align-items:baseline; gap:.15rem; }
.brand__text span { color:var(--brand); }
.brand__text small { font-size:.62rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); margin-left:.35rem; }

.nav__links { display:flex; gap:1.3rem; }
.nav__links a { font-size:.95rem; font-weight:500; color:var(--muted); position:relative; transition:color .25s; white-space:nowrap; }
.nav__links a::after {
  content:''; position:absolute; left:0; bottom:-6px; height:2px; width:0;
  background:var(--brand); transition:width .3s var(--ease);
}
.nav__links a:hover { color:#fff; }
.nav__links a:hover::after { width:100%; }

.nav__actions { display:flex; align-items:center; gap:.55rem; }

.nav__burger { display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:.4rem; }
.nav__burger span { width:26px; height:2px; background:#fff; border-radius:2px; transition:.3s var(--ease); }
.nav.is-open .nav__burger span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav.is-open .nav__burger span:nth-child(2){ opacity:0; }
.nav.is-open .nav__burger span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ---------- Hero ---------- */
.hero { position:relative; min-height:100vh; display:flex; align-items:center; overflow:hidden; }
.hero__video { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2; }
.hero__overlay {
  position:absolute; inset:0; z-index:-1;
  background:
    radial-gradient(1200px 700px at 75% 15%, rgba(255,106,26,.22), transparent 60%),
    linear-gradient(180deg, rgba(13,13,15,.55) 0%, rgba(13,13,15,.82) 60%, var(--bg) 100%);
}
.hero__content { padding:8rem 0 5rem; max-width:820px; }
.hero__eyebrow {
  display:inline-block; padding:.5rem 1rem; border:1px solid var(--line); border-radius:100px;
  background:rgba(255,255,255,.05); backdrop-filter:blur(6px); font-size:.9rem; font-weight:500; margin-bottom:1.6rem;
}
.hero__title { font-size:clamp(2.6rem,7vw,5rem); font-weight:800; margin-bottom:1.4rem; }
.hero__sub { font-size:clamp(1.05rem,2vw,1.28rem); color:var(--muted); max-width:620px; margin-bottom:2.2rem; }
.hero__sub strong { color:var(--text); font-weight:600; }
.hero__actions { display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:3rem; }
.hero__trust { display:flex; gap:2.5rem; flex-wrap:wrap; padding-top:1.8rem; border-top:1px solid var(--line); }
.hero__trust div { display:flex; flex-direction:column; }
.hero__trust strong { font-family:'Sora'; font-size:1.6rem; color:var(--brand-2); }
.hero__trust span { font-size:.85rem; color:var(--muted); }

.hero__scroll { position:absolute; bottom:1.8rem; left:50%; transform:translateX(-50%); width:26px; height:42px; border:2px solid rgba(255,255,255,.35); border-radius:20px; }
.hero__scroll span { position:absolute; top:8px; left:50%; transform:translateX(-50%); width:4px; height:8px; background:#fff; border-radius:4px; animation:scrolldot 1.6s infinite; }
@keyframes scrolldot { 0%{opacity:0;transform:translate(-50%,0)} 40%{opacity:1} 80%{opacity:0;transform:translate(-50%,14px)} 100%{opacity:0} }

/* ---------- Marquee ---------- */
.marquee { background:var(--brand); color:#1a1000; overflow:hidden; padding:.9rem 0; border-block:1px solid rgba(0,0,0,.15); }
.marquee__track { display:flex; gap:1.6rem; width:max-content; animation:marquee 26s linear infinite; }
.marquee__track span { font-family:'Sora'; font-weight:700; font-size:1.05rem; text-transform:uppercase; letter-spacing:.02em; }
@keyframes marquee { to { transform:translateX(-50%); } }

/* ---------- Sections ---------- */
.section { padding:6.5rem 0; }
.section--dark { background:var(--bg-soft); }
.section__head { max-width:640px; margin:0 auto 3.5rem; text-align:center; }
.section__head h2 { font-size:clamp(2rem,4.5vw,3rem); margin-bottom:1rem; }
.section__head p { color:var(--muted); font-size:1.08rem; }

/* ---------- Cards ---------- */
.cards { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1.4rem; }
.card {
  background:linear-gradient(180deg,var(--surface),var(--bg-soft));
  border:1px solid var(--line); border-radius:var(--radius); padding:2rem 1.8rem;
  position:relative; overflow:hidden; transition:transform .4s var(--ease), border-color .4s;
}
.card::before {
  content:''; position:absolute; inset:0; border-radius:inherit; padding:1px;
  background:linear-gradient(120deg,var(--brand),transparent 40%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; opacity:0; transition:opacity .4s;
}
.card:hover { transform:translateY(-6px); }
.card:hover::before { opacity:1; }
.card__icon {
  width:56px; height:56px; display:grid; place-items:center; font-size:1.7rem;
  background:rgba(255,106,26,.12); border-radius:14px; margin-bottom:1.2rem;
}
.card h3 { font-size:1.3rem; margin-bottom:.6rem; overflow-wrap:break-word; hyphens:auto; }
.card p { color:var(--muted); font-size:.98rem; margin-bottom:1.1rem; }
.card__link { color:var(--brand-2); font-weight:600; font-size:.9rem; transition:letter-spacing .3s; }
.card:hover .card__link { letter-spacing:.02em; }

/* ---------- Split ---------- */
.split { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
.split--rev .split__text { order:2; }
.split__text h2 { font-size:clamp(2rem,4vw,2.8rem); margin-bottom:1.2rem; }
.split__text p { color:var(--muted); margin-bottom:1.6rem; }
.checklist { list-style:none; display:grid; gap:.8rem; margin-bottom:2rem; }
.checklist li { position:relative; padding-left:2rem; }
.checklist li::before {
  content:'✓'; position:absolute; left:0; top:0; width:1.4rem; height:1.4rem;
  background:var(--brand); color:#fff; border-radius:50%; display:grid; place-items:center; font-size:.8rem; font-weight:700;
}

/* ---------- Before/After ---------- */
.ba { position:relative; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); aspect-ratio:4/3; user-select:none; }
.ba__img { width:100%; height:100%; object-fit:cover; position:absolute; inset:0; }
.ba__before { position:absolute; inset:0; width:50%; overflow:hidden; border-right:3px solid var(--brand); }
.ba__before .ba__img { width:100vw; max-width:none; }
.ba__range { position:absolute; inset:0; width:100%; height:100%; opacity:0; cursor:ew-resize; z-index:5; }
.ba__handle {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:44px; height:44px; border-radius:50%; background:var(--brand); color:#fff;
  display:grid; place-items:center; font-size:.7rem; box-shadow:0 4px 14px rgba(0,0,0,.4); pointer-events:none; z-index:4;
}
.ba__label {
  position:absolute; bottom:1rem; padding:.3rem .8rem; border-radius:100px; font-size:.75rem; font-weight:600;
  background:rgba(0,0,0,.55); backdrop-filter:blur(4px); z-index:3;
}
.ba__label--l { left:1rem; } .ba__label--r { right:1rem; }

/* ---------- Gallery ---------- */
.gallery { display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; grid-auto-flow:dense; }
.gallery__item { position:relative; border-radius:var(--radius-sm); overflow:hidden; aspect-ratio:1; }
.gallery__item--tall { grid-row:span 2; aspect-ratio:1/2; }
.gallery__item--wide { grid-column:span 2; aspect-ratio:2/1; }
.gallery__item img { width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease); }
.gallery__item:hover img { transform:scale(1.08); }
.gallery__item figcaption {
  position:absolute; inset:auto 0 0 0; padding:1.4rem 1rem .9rem; font-weight:600; font-size:.9rem;
  background:linear-gradient(transparent,rgba(0,0,0,.8)); transform:translateY(100%); transition:transform .4s var(--ease);
}
.gallery__item:hover figcaption { transform:translateY(0); }

/* ---------- Video ---------- */
.video { position:relative; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); aspect-ratio:16/9; max-width:960px; margin-inline:auto; }
.video video { width:100%; height:100%; object-fit:cover; }
.video__play {
  position:absolute; inset:0; margin:auto; width:84px; height:84px; border-radius:50%;
  background:linear-gradient(120deg,var(--brand),var(--brand-deep)); color:#fff; border:0; cursor:pointer;
  display:grid; place-items:center; box-shadow:0 10px 40px rgba(255,106,26,.5); transition:transform .3s var(--ease);
}
.video__play::after { content:''; position:absolute; inset:-10px; border-radius:50%; border:2px solid rgba(255,106,26,.5); animation:pulse 2s infinite; }
.video__play:hover { transform:scale(1.08); }
.video.is-playing .video__play { opacity:0; pointer-events:none; }
@keyframes pulse { 0%{transform:scale(1);opacity:.7} 100%{transform:scale(1.4);opacity:0} }

/* ---------- Instagram ---------- */
.ig { display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; margin-bottom:2.5rem; }
.ig__item { position:relative; aspect-ratio:1; border-radius:var(--radius-sm); overflow:hidden; }
.ig__item img { width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.ig__item:hover img { transform:scale(1.1); }
.ig__overlay {
  position:absolute; inset:0; display:grid; place-items:center; font-size:2rem;
  background:linear-gradient(120deg,rgba(255,106,26,.85),rgba(217,78,0,.85)); opacity:0; transition:opacity .35s;
}
.ig__item:hover .ig__overlay { opacity:1; }
.ig__cta { text-align:center; }

/* ---------- Contact ---------- */
.contact-list { list-style:none; display:grid; gap:1.3rem; margin-top:.5rem; }
.contact-list li { display:flex; gap:1rem; align-items:flex-start; }
.contact-list .ci { width:44px; height:44px; flex:none; display:grid; place-items:center; font-size:1.2rem; background:var(--surface); border:1px solid var(--line); border-radius:12px; }
.contact-list a:hover { color:var(--brand-2); }

.form { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:2rem; display:grid; gap:1rem; }
.form__row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form label { display:grid; gap:.4rem; font-size:.88rem; font-weight:600; color:var(--muted); }
.form input, .form select, .form textarea {
  font:inherit; color:var(--text); background:var(--bg); border:1px solid var(--line);
  border-radius:var(--radius-sm); padding:.8rem .9rem; transition:border-color .25s, box-shadow .25s;
}
.form input:focus, .form select:focus, .form textarea:focus {
  outline:0; border-color:var(--brand); box-shadow:0 0 0 3px rgba(255,106,26,.18);
}
.form textarea { resize:vertical; }
.form__note { font-size:.9rem; text-align:center; min-height:1.2rem; }
.form__note.ok { color:#4ade80; } .form__note.err { color:#f87171; }
.form__consent { flex-direction:row; align-items:flex-start; gap:.6rem; font-weight:400; color:var(--muted); font-size:.82rem; }
.form__consent input { width:1.1rem; height:1.1rem; margin-top:.15rem; accent-color:var(--brand); flex:none; }
.form__consent a { color:var(--brand-2); text-decoration:underline; }

/* ---------- Reviews ---------- */
.reviews { display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:1.4rem; }
.review {
  background:linear-gradient(180deg,var(--surface),var(--bg-soft));
  border:1px solid var(--line); border-radius:var(--radius); padding:2rem 1.8rem;
  display:flex; flex-direction:column; gap:1rem; position:relative;
}
.review::before {
  content:'\201C'; position:absolute; top:.4rem; right:1.4rem;
  font-family:'Sora'; font-size:4.5rem; line-height:1; color:var(--brand); opacity:.16;
}
.review__stars { color:#ffb020; letter-spacing:.15em; font-size:1.05rem; }
.review blockquote { color:var(--text); font-size:1rem; line-height:1.7; margin:0; }
.review figcaption { display:flex; align-items:center; gap:.85rem; margin-top:auto; padding-top:.6rem; border-top:1px solid var(--line); }
.review__avatar {
  width:44px; height:44px; flex:none; display:grid; place-items:center; border-radius:50%;
  background:linear-gradient(120deg,var(--brand),var(--brand-deep)); color:#fff; font-family:'Sora'; font-weight:700; font-size:.9rem;
}
.review figcaption span { display:flex; flex-direction:column; }
.review figcaption small { color:var(--muted); font-size:.8rem; }

/* ---------- Map ---------- */
.map-wrap { margin-top:3.5rem; }
.map {
  position:relative; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow);
  aspect-ratio:21/8; background:var(--surface); border:1px solid var(--line);
}
.map iframe { width:100%; height:100%; border:0; display:block; filter:grayscale(.2) contrast(1.05); }
.map__placeholder {
  position:absolute; inset:0; display:grid; place-content:center; text-align:center; gap:.5rem; padding:2rem;
  background:
    linear-gradient(rgba(13,13,15,.72), rgba(13,13,15,.82)),
    url('../assets/img/gal-3.jpg') center/cover;
}
.map__pin { font-size:2rem; }
.map__placeholder strong { font-family:'Sora'; font-size:1.15rem; }
.map__placeholder p { color:var(--muted); font-size:.92rem; max-width:420px; margin:0 auto .6rem; }
.map__placeholder .btn { justify-self:center; }
.map__note { margin-top:.9rem; font-size:.82rem; color:var(--muted); text-align:center; }
.map__note a { color:var(--brand-2); text-decoration:underline; }
@media (max-width:720px){ .map { aspect-ratio:4/3; } }

/* ---------- Footer ---------- */
.footer { background:#08080a; border-top:1px solid var(--line); padding:4rem 0 0; }
.footer__inner { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:2.5rem; padding-bottom:3rem; }
.footer__brand .brand__text { margin:.6rem 0; }
.footer__brand p { color:var(--muted); font-size:.92rem; max-width:320px; }
.footer__col h4 { font-size:.9rem; text-transform:uppercase; letter-spacing:.1em; margin-bottom:1rem; color:var(--muted); }
.footer__col a, .footer__col span { display:block; color:var(--text); font-size:.95rem; margin-bottom:.6rem; }
.footer__col a:hover { color:var(--brand-2); }
.footer__bar { border-top:1px solid var(--line); padding:1.4rem 0; display:flex; justify-content:space-between; flex-wrap:wrap; gap:.6rem; font-size:.82rem; color:var(--muted); width:min(100% - 2.4rem,var(--maxw)); margin-inline:auto; }
.footer__legal { display:flex; gap:1.2rem; }
.footer__legal a:hover { color:var(--brand-2); }

/* ---------- Legal pages ---------- */
.legal { padding:9rem 0 5rem; }
.legal__inner { max-width:820px; margin-inline:auto; }
.legal h1 { font-size:clamp(2rem,5vw,2.8rem); margin-bottom:.4rem; }
.legal .tag { margin-bottom:1.6rem; }
.legal h2 { font-size:1.35rem; margin:2.4rem 0 .8rem; }
.legal h3 { font-size:1.05rem; margin:1.6rem 0 .5rem; }
.legal p, .legal li { color:var(--muted); margin-bottom:.7rem; }
.legal ul { padding-left:1.2rem; margin-bottom:.7rem; }
.legal a { color:var(--brand-2); text-decoration:underline; }
.legal address { font-style:normal; color:var(--text); line-height:1.9; }
.legal .back { display:inline-flex; gap:.4rem; margin-top:2.5rem; font-weight:600; color:var(--brand-2); }
.legal .muted-note { font-size:.85rem; padding:1rem 1.1rem; border:1px dashed var(--line); border-radius:var(--radius-sm); background:var(--surface); }

/* ---------- FAB ---------- */
.fab {
  position:fixed; right:1.2rem; bottom:1.2rem; z-index:90;
  background:linear-gradient(120deg,var(--brand),var(--brand-deep)); color:#fff; font-weight:600; font-family:'Sora';
  padding:.9rem 1.3rem; border-radius:100px; box-shadow:0 12px 30px -6px rgba(255,106,26,.6);
  transform:translateY(150%); transition:transform .4s var(--ease); font-size:.92rem;
}
.fab.show { transform:translateY(0); }
.fab:hover { transform:translateY(-3px); }

/* ---------- WhatsApp ---------- */
:root { --wa:#25d366; --wa-deep:#1da851; }
.btn--wa { background:linear-gradient(120deg,var(--wa),var(--wa-deep)); color:#fff; box-shadow:0 10px 30px -8px rgba(37,211,102,.55); }
.btn--wa:hover { transform:translateY(-2px); box-shadow:0 18px 40px -10px rgba(37,211,102,.7); }

.wa-fab {
  position:fixed; left:1.2rem; bottom:1.2rem; z-index:95;
  display:flex; align-items:center; gap:0; overflow:hidden;
  height:58px; width:58px; padding:0 14px; border-radius:100px;
  background:linear-gradient(120deg,var(--wa),var(--wa-deep)); color:#fff;
  box-shadow:0 12px 30px -6px rgba(37,211,102,.6);
  transition:width .4s var(--ease), transform .3s var(--ease), box-shadow .3s var(--ease);
}
.wa-fab svg { flex:none; }
.wa-fab__label { font-family:'Sora'; font-weight:600; font-size:.95rem; white-space:nowrap; margin-left:10px; opacity:0; transition:opacity .3s .05s; }
.wa-fab:hover { width:170px; transform:translateY(-3px); box-shadow:0 18px 40px -8px rgba(37,211,102,.75); }
.wa-fab:hover .wa-fab__label { opacity:1; }
.wa-fab::after { content:''; position:absolute; inset:0; border-radius:100px; box-shadow:0 0 0 0 rgba(37,211,102,.55); animation:waPulse 2.4s infinite; }
@keyframes waPulse { 0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)} 70%{box-shadow:0 0 0 16px rgba(37,211,102,0)} 100%{box-shadow:0 0 0 0 rgba(37,211,102,0)} }
@media (max-width:720px){ .wa-fab { height:54px; width:54px; padding:0 12px; } .wa-fab:hover { width:54px; } .wa-fab__label { display:none; } }

/* ---------- Reveal animation ---------- */
.reveal { opacity:0; transform:translateY(28px); transition:opacity .7s var(--ease), transform .7s var(--ease); transition-delay:calc(var(--i,0)*70ms); }
.reveal.in { opacity:1; transform:none; }

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .split, .split--rev .split__text { grid-template-columns:1fr; order:0; }
  .split { gap:2.5rem; }
  .gallery { grid-template-columns:repeat(2,1fr); }
  .gallery__item--wide { grid-column:span 2; }
  .ig { grid-template-columns:repeat(2,1fr); }
  .footer__inner { grid-template-columns:1fr 1fr; }
}
@media (max-width:720px){
  .nav__actions { display:none; }
  .nav__burger { display:flex; }
  .nav__links {
    position:fixed; inset:0 0 0 auto; width:min(78vw,320px); flex-direction:column; gap:1.6rem;
    background:rgba(16,16,20,.97); backdrop-filter:blur(20px); padding:6rem 2rem 2rem;
    transform:translateX(100%); transition:transform .4s var(--ease); border-left:1px solid var(--line);
  }
  .nav.is-open .nav__links { transform:translateX(0); }
  .nav__links a { font-size:1.15rem; color:#fff; }
  .hero__trust { gap:1.6rem; }
  .form__row { grid-template-columns:1fr; }
  .footer__inner { grid-template-columns:1fr; }
  .footer__bar { flex-direction:column; }
  .section { padding:4.5rem 0; }
}
@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms!important; transition-duration:.001ms!important; }
  .reveal{ opacity:1; transform:none; }
}
