/* =========================================================
   Ferienwohnung am Universitätsring — Gästemappe
   Editorial / Gründerzeit-Hospitality
   ========================================================= */

:root{
  --paper:        #f4ede0;   /* warm parchment            */
  --paper-2:      #ece2d1;   /* slightly deeper surface   */
  --ink:          #221d18;   /* espresso ink              */
  --ink-soft:     #5a5046;   /* muted body                */
  --brass:        #b1813c;   /* Himmelsscheibe gold       */
  --brass-deep:   #8a6326;
  --verd:         #2f5d56;   /* bronze patina / sky       */
  --verd-deep:    #20433d;
  --line:         #d8cab2;   /* hairline                  */
  --card:         #fbf7ef;
  --shadow:       28px 40px 80px -50px rgba(34,29,24,.55);

  --serif: "Fraunces", Georgia, "Times New Roman", serif;
  --sans:  "Hanken Grotesk", "Segoe UI", system-ui, sans-serif;

  --maxw: 1180px;
  --pad: clamp(20px, 5vw, 64px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
/* subtle paper grain */
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(177,129,60,.05), transparent 60%),
    radial-gradient(circle at 80% 70%, rgba(47,93,86,.05), transparent 55%);
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
em{font-style:italic}

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

/* ================= NAV ================= */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:flex-end;
  padding:16px var(--pad);
  background:rgba(244,237,224,0);
  transition:background .4s ease, box-shadow .4s ease, padding .4s ease;
}
.nav.is-stuck{
  background:rgba(244,237,224,.86);
  backdrop-filter:blur(14px);
  box-shadow:0 1px 0 var(--line);
  padding-top:12px;padding-bottom:12px;
}
.nav__brand{display:flex;align-items:center;gap:12px;font-weight:600}
.nav__mark{
  display:grid;place-items:center;width:38px;height:38px;border-radius:50%;
  background:var(--verd);color:var(--paper);
  font-family:var(--serif);font-weight:600;font-size:15px;letter-spacing:.5px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.15);
}
.nav__mark--lg{width:54px;height:54px;font-size:20px;background:var(--brass)}
.nav__name{font-family:var(--serif);font-size:18px;letter-spacing:.2px}
.nav__links{display:flex;align-items:center;gap:30px}
.nav__links a{
  font-size:14.5px;font-weight:500;letter-spacing:.3px;color:var(--ink-soft);
  position:relative;padding:4px 0;transition:color .25s;
}
.nav__links a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;
  background:var(--brass);transition:width .3s ease;
}
.nav__links a:hover,.nav__links a.is-active{color:var(--ink)}
.nav__links a:hover::after,.nav__links a.is-active::after{width:100%}
.nav__cta{
  padding:9px 18px !important;border-radius:40px;
  background:var(--ink);color:var(--paper) !important;
}
.nav__cta::after{display:none}
.nav__cta:hover{background:var(--verd)}
.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.nav__toggle span{width:26px;height:2px;background:var(--ink);transition:.3s}

/* Am oberen Rand (über dem Hero) hell für Kontrast; gescrollt dann dunkel */
.nav:not(.is-stuck) .nav__brand,
.nav:not(.is-stuck) .nav__name{color:#f7efe1;text-shadow:0 1px 12px rgba(15,11,7,.45)}
.nav:not(.is-stuck) .nav__links a{color:rgba(247,239,225,.92);text-shadow:0 1px 10px rgba(15,11,7,.4)}
.nav:not(.is-stuck) .nav__links a:hover,
.nav:not(.is-stuck) .nav__links a.is-active{color:#fff}
.nav:not(.is-stuck) .nav__mark{box-shadow:0 2px 14px rgba(15,11,7,.35),inset 0 0 0 1px rgba(255,255,255,.18)}
.nav:not(.is-stuck) .nav__cta{background:rgba(247,239,225,.16);color:#fff !important;
  backdrop-filter:blur(4px);box-shadow:inset 0 0 0 1px rgba(247,239,225,.45)}
.nav:not(.is-stuck) .nav__cta:hover{background:rgba(247,239,225,.28)}
.nav:not(.is-stuck) .nav__toggle span{background:#f7efe1;box-shadow:0 1px 6px rgba(15,11,7,.4)}

/* ================= HERO ================= */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:50% 28%;
  animation:heroZoom 18s ease-out forwards}
@keyframes heroZoom{from{transform:scale(1.12)}to{transform:scale(1)}}
.hero__scrim{position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(20,16,12,.30) 0%, rgba(20,16,12,0) 28%, rgba(20,16,12,.12) 55%, rgba(20,16,12,.78) 100%);
}
.hero__inner{position:relative;z-index:2;max-width:var(--maxw);width:100%;margin:0 auto;
  padding:0 var(--pad) clamp(40px,7vh,90px);color:#f7efe1}
.hero__eyebrow{font-size:13px;letter-spacing:.32em;text-transform:uppercase;font-weight:600;
  color:#e9d3a7;margin-bottom:20px;opacity:0;animation:rise .9s .15s forwards}
.hero__title{font-family:var(--serif);font-weight:400;line-height:.98;
  font-size:clamp(46px,9vw,108px);letter-spacing:-.02em;
  text-shadow:0 6px 40px rgba(0,0,0,.35);opacity:0;animation:rise 1s .3s forwards}
.hero__title em{color:#e6c886;font-style:italic}
.hero__lead{max-width:46ch;margin:24px 0 0;font-size:clamp(15px,1.6vw,18px);
  color:#f0e6d6;opacity:0;animation:rise 1s .5s forwards}
.hero__actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px;opacity:0;animation:rise 1s .65s forwards}
@keyframes rise{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}

.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 26px;border-radius:44px;
  font-weight:600;font-size:15px;letter-spacing:.2px;cursor:pointer;border:1.5px solid transparent;
  transition:transform .25s, background .25s, color .25s, border-color .25s}
.btn:hover{transform:translateY(-3px)}
.btn--solid{background:var(--brass);color:#1c140a;box-shadow:0 14px 30px -12px rgba(177,129,60,.8)}
.btn--solid:hover{background:#c79347}
.btn--ghost{border-color:rgba(247,239,225,.6);color:#f7efe1}
.btn--ghost:hover{background:rgba(247,239,225,.12);border-color:#f7efe1}

/* hero facts strip */
.hero__facts{position:relative;z-index:2;background:var(--ink);color:var(--paper)}
.hero__facts-inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);
  display:grid;grid-template-columns:repeat(4,1fr)}
.fact{padding:26px 24px;border-left:1px solid rgba(255,255,255,.1)}
.fact:first-child{border-left:0}
.fact__k{font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);font-weight:600}
.fact__v{font-family:var(--serif);font-size:clamp(18px,2vw,23px);margin-top:6px;line-height:1.2}
.fact a{display:inline-flex;align-items:center;gap:7px}
.fact a:hover{color:var(--brass)}

/* ================= SECTIONS ================= */
.section{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;
  padding:clamp(70px,11vh,140px) var(--pad)}
.section--alt{max-width:none;background:var(--paper-2);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section--alt > *{max-width:var(--maxw);margin-left:auto;margin-right:auto}
.section__head{max-width:760px;margin-bottom:54px}
.section__num{font-family:var(--serif);font-size:14px;color:var(--brass);
  letter-spacing:.3em;display:block;margin-bottom:14px;font-weight:600}
.section__title{font-family:var(--serif);font-weight:400;font-size:clamp(34px,5vw,58px);
  letter-spacing:-.02em;line-height:1.02}
.section__sub{margin-top:18px;color:var(--ink-soft);font-size:clamp(15px,1.5vw,17.5px);max-width:62ch}
.subhead{font-family:var(--serif);font-size:26px;margin:64px 0 26px;font-weight:500}

/* reveal */
[data-reveal] .section__head,[data-reveal] .steps,[data-reveal] .gallery,
[data-reveal] .parking,[data-reveal] .info-cards,[data-reveal] .services,
[data-reveal] .discover-tools,[data-reveal] .cards,[data-reveal] .maps,
[data-reveal] .footer__grid{opacity:0;transform:translateY(34px);
  transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1)}
[data-reveal].in-view .section__head,[data-reveal].in-view .steps,
[data-reveal].in-view .gallery,[data-reveal].in-view .parking,
[data-reveal].in-view .info-cards,[data-reveal].in-view .services,
[data-reveal].in-view .discover-tools,[data-reveal].in-view .cards,
[data-reveal].in-view .maps,[data-reveal].in-view .footer__grid{opacity:1;transform:none}

/* ---------- STEPS (access) ---------- */
.steps{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.step{background:var(--card);border:1px solid var(--line);border-radius:18px;
  padding:30px 30px 28px;position:relative;overflow:hidden;
  transition:transform .3s, box-shadow .3s}
.step:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.step__icon{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;
  background:var(--verd);color:var(--paper);margin-bottom:18px}
.step__icon svg{width:23px;height:23px}
.step h4{font-family:var(--serif);font-size:21px;font-weight:500;margin-bottom:10px}
.step p{color:var(--ink-soft);font-size:15px}
.step__action{margin-top:18px;display:inline-flex;align-items:center;gap:9px;
  padding:11px 20px;border-radius:40px;background:var(--brass);color:#1c140a;
  font-weight:600;font-size:14.5px;transition:background .25s, transform .25s}
.step__action:hover{background:#c79347;transform:translateY(-2px)}
.step__big{position:absolute;right:18px;top:8px;font-family:var(--serif);
  font-size:80px;color:var(--line);opacity:.5;line-height:1;pointer-events:none}

/* ---------- GALLERY ---------- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:18px}
.gallery figure{position:relative;border-radius:14px;overflow:hidden;cursor:zoom-in;
  aspect-ratio:3/4;border:1px solid var(--line)}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.gallery figure:hover img{transform:scale(1.07)}
.gallery figcaption{position:absolute;left:0;right:0;bottom:0;padding:22px 14px 12px;
  font-size:12.5px;color:#fff;background:linear-gradient(transparent,rgba(20,15,10,.8))}

/* ---------- LOCKED CARD (Zugang teaser) ---------- */
.locked-card{display:flex;align-items:center;gap:26px;flex-wrap:wrap;
  background:linear-gradient(115deg,var(--verd) 0%,var(--verd-deep) 100%);
  color:#f4ede0;border-radius:22px;padding:clamp(26px,4vw,40px);position:relative;overflow:hidden;
  box-shadow:var(--shadow);transition:transform .35s ease}
.locked-card::after{content:"";position:absolute;right:-60px;top:-60px;width:240px;height:240px;
  border-radius:50%;background:radial-gradient(circle,rgba(177,129,60,.28),transparent 70%);pointer-events:none}
.locked-card:hover{transform:translateY(-4px)}
.locked-card__icon{flex:none;width:66px;height:66px;border-radius:16px;display:grid;place-items:center;
  background:rgba(244,237,224,.12);color:#e6c886;border:1px solid rgba(244,237,224,.2)}
.locked-card__icon svg{width:32px;height:32px}
.locked-card__body{flex:1;min-width:240px}
.locked-card__tag{display:inline-block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  font-weight:600;color:#e6c886;margin-bottom:8px}
.locked-card__body h3{font-family:var(--serif);font-weight:500;font-size:clamp(22px,2.4vw,28px);line-height:1.1}
.locked-card__body p{color:rgba(244,237,224,.72);font-size:14.5px;margin-top:8px;max-width:60ch}
.locked-card__cta{display:inline-flex;align-items:center;gap:9px;flex:none;font-weight:600;font-size:15px;
  background:var(--brass);color:#1c140a;padding:13px 22px;border-radius:40px;transition:gap .25s,background .25s}
.locked-card:hover .locked-card__cta{gap:14px;background:#c79347}
.locked-card__cta svg{width:18px;height:18px}

/* ---------- PARKING ---------- */
.parking{margin-top:70px;background:var(--card);border:1px solid var(--line);
  border-radius:22px;padding:clamp(26px,4vw,48px)}
.parking__head h3{font-family:var(--serif);font-size:30px;font-weight:500;margin-bottom:10px}
.parking__head p{color:var(--ink-soft);max-width:62ch}
.parking__grid{display:grid;grid-template-columns:1fr 1fr;gap:38px;margin-top:30px;align-items:start}
.parking__list{list-style:none}
.parking__list li{display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:13px 2px;border-bottom:1px dashed var(--line)}
.parking__list li:last-child{border-bottom:0}
.lot__name{font-weight:500;display:flex;align-items:center;gap:9px}
.lot__name .tag{font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;
  background:var(--verd);color:var(--paper);padding:3px 8px;border-radius:20px;font-weight:600}
.lot__meta{display:flex;gap:18px;align-items:baseline;white-space:nowrap}
.lot__spaces{font-family:var(--serif);font-size:20px;color:var(--brass-deep)}
.lot__spaces small{font-size:11px;color:var(--ink-soft);font-family:var(--sans);margin-left:3px}
.lot__max{font-size:13px;color:var(--ink-soft)}
.parking__map img{border-radius:14px;border:1px solid var(--line);cursor:zoom-in}
.parking__map figcaption{font-size:12.5px;color:var(--ink-soft);margin-top:8px;text-align:center}

/* ---------- INFO CARDS (stay) ---------- */
.info-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.info-card{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:30px;
  transition:transform .3s, box-shadow .3s}
.info-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.info-card__icon{color:var(--brass);margin-bottom:14px}
.info-card__icon svg{width:28px;height:28px}
.info-card h4{font-family:var(--serif);font-size:21px;font-weight:500;margin-bottom:9px}
.info-card p{color:var(--ink-soft);font-size:14.5px}

/* ---------- SERVICES ---------- */
.services{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.service{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:26px 28px}
.service__top{display:flex;align-items:center;gap:13px;margin-bottom:12px}
.service__ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;
  background:var(--paper-2);color:var(--verd)}
.service__ic svg{width:22px;height:22px}
.service h4{font-family:var(--serif);font-size:19px;font-weight:500}
.service p{color:var(--ink-soft);font-size:14.5px}
.service__meta{margin-top:16px;display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:var(--paper);border:1px dashed var(--line);border-radius:12px;padding:10px 14px}
.service__meta .k{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}
.service__meta .v{font-family:var(--serif);font-size:16px}
.copy-btn{border:0;background:var(--verd);color:var(--paper);width:34px;height:34px;border-radius:9px;
  cursor:pointer;display:grid;place-items:center;transition:background .25s, transform .2s;flex:none}
.copy-btn:hover{background:var(--verd-deep);transform:translateY(-2px)}
.copy-btn svg{width:16px;height:16px}

/* ---------- DISCOVER ---------- */
.discover-tools{display:flex;align-items:center;justify-content:space-between;gap:20px;
  flex-wrap:wrap;margin-bottom:32px}
.filters{display:flex;gap:10px;flex-wrap:wrap}
.chip{border:1.5px solid var(--line);background:transparent;color:var(--ink-soft);
  padding:9px 18px;border-radius:40px;cursor:pointer;font-family:var(--sans);
  font-size:14px;font-weight:500;transition:.25s}
.chip:hover{border-color:var(--brass);color:var(--ink)}
.chip.is-active{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.search input{border:1.5px solid var(--line);background:var(--card);border-radius:40px;
  padding:11px 20px;font-family:var(--sans);font-size:14.5px;color:var(--ink);min-width:220px}
.search input:focus{outline:none;border-color:var(--brass)}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:var(--card);border:1px solid var(--line);border-radius:18px;overflow:hidden;
  display:flex;flex-direction:column;transition:transform .35s, box-shadow .35s;
  animation:cardIn .5s both}
@keyframes cardIn{from{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:none}}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card__media{aspect-ratio:16/11;overflow:hidden;cursor:zoom-in;background:var(--verd-deep);position:relative}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.card:hover .card__media img{transform:scale(1.07)}
.card__media--badge img{object-fit:contain}
.card__noimg{position:absolute;inset:0;display:grid;place-items:center;color:var(--paper);
  background:radial-gradient(circle at 30% 20%,var(--verd),var(--verd-deep))}
.card__noimg svg{width:46px;height:46px;opacity:.7}
.card__cat{position:absolute;top:12px;left:12px;font-size:11px;letter-spacing:.08em;
  text-transform:uppercase;font-weight:600;background:rgba(34,29,24,.82);color:var(--paper);
  padding:5px 11px;border-radius:20px;backdrop-filter:blur(4px)}
.card__body{padding:22px 24px 24px;display:flex;flex-direction:column;flex:1}
.card__body h4{font-family:var(--serif);font-size:22px;font-weight:500;line-height:1.15}
.card__addr{font-size:12.5px;color:var(--brass-deep);margin:7px 0 12px;font-weight:500}
.card__text{font-size:14px;color:var(--ink-soft);flex:1}
.card__link{margin-top:16px;align-self:flex-start;font-weight:600;font-size:14px;color:var(--verd);
  display:inline-flex;align-items:center;gap:6px;border-bottom:2px solid transparent;transition:.25s}
.card__link:hover{gap:11px;border-color:var(--brass);color:var(--ink)}
.cards__empty{grid-column:1/-1;text-align:center;color:var(--ink-soft);padding:50px;font-style:italic}

.events-link{margin-top:40px;font-size:16px;color:var(--ink-soft)}
.events-link a{color:var(--verd);font-weight:600;border-bottom:2px solid var(--brass)}
.events-link a:hover{color:var(--ink)}

/* ---------- ANREISE ---------- */
.app-link{display:inline-flex;align-items:center;gap:8px;background:var(--ink);color:var(--paper);
  padding:13px 24px;border-radius:40px;font-weight:600;font-size:15px;margin-bottom:36px;
  transition:background .25s, transform .25s}
.app-link:hover{background:var(--verd);transform:translateY(-3px)}
.maps{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.maps figure{border-radius:16px;overflow:hidden;border:1px solid var(--line);cursor:zoom-in;background:var(--card)}
.maps img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.maps figure:hover img{transform:scale(1.04)}
.maps figcaption{padding:13px 18px;font-size:13.5px;color:var(--ink-soft);background:var(--card)}

/* ================= FOOTER ================= */
.footer{position:relative;z-index:1;background:var(--ink);color:var(--paper);
  padding:clamp(60px,9vh,110px) var(--pad) 40px}
.footer__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.2fr 1fr;gap:50px}
.footer__brand h2{font-family:var(--serif);font-weight:400;font-size:clamp(26px,3vw,38px);
  margin:20px 0 14px;line-height:1.1}
.footer__brand p{color:rgba(244,237,224,.65);max-width:42ch}
.footer__contact{display:grid;gap:20px;align-content:start}
.contact-row{display:block}
.contact-row .k{font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--brass);font-weight:600;display:block;margin-bottom:4px}
.contact-row .v{font-family:var(--serif);font-size:20px}
.contact-row a:hover{color:var(--brass)}
.footer__legal{max-width:var(--maxw);margin:48px auto 0;padding-top:24px;
  border-top:1px solid rgba(244,237,224,.14);display:flex;justify-content:space-between;
  gap:16px;flex-wrap:wrap;font-size:13px;color:rgba(244,237,224,.55)}
.footer__legal a{color:rgba(244,237,224,.8);border-bottom:1px solid var(--brass)}

/* ================= LIGHTBOX ================= */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(20,15,10,.92);
  display:flex;align-items:center;justify-content:center;padding:30px;
  opacity:0;visibility:hidden;transition:opacity .3s, visibility .3s;backdrop-filter:blur(6px)}
.lightbox.is-open{opacity:1;visibility:visible}
.lightbox__fig{max-width:92vw;max-height:88vh;transform:scale(.96);transition:transform .35s}
.lightbox.is-open .lightbox__fig{transform:scale(1)}
.lightbox__fig img{max-width:92vw;max-height:80vh;object-fit:contain;border-radius:8px;
  box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lightbox__fig figcaption{text-align:center;color:var(--paper);margin-top:14px;font-family:var(--serif);font-size:16px}
.lightbox__close{position:absolute;top:22px;right:28px;background:none;border:0;color:var(--paper);
  font-size:42px;line-height:1;cursor:pointer;opacity:.8;transition:opacity .2s, transform .2s}
.lightbox__close:hover{opacity:1;transform:rotate(90deg)}

/* ================= TOAST ================= */
.toast{position:fixed;bottom:30px;left:50%;
  transform:translateX(-50%) translateY(120px);
  background:var(--ink);color:var(--paper);padding:13px 24px;border-radius:40px;
  font-size:14.5px;font-weight:500;z-index:210;box-shadow:var(--shadow);
  transition:transform .4s cubic-bezier(.2,.8,.2,1);display:flex;align-items:center;gap:9px}
.toast.is-show{transform:translateX(-50%) translateY(0)}
.toast svg{width:18px;height:18px;color:var(--brass)}

/* ================= RESPONSIVE ================= */
@media (max-width:920px){
  .nav__links{position:fixed;inset:0 0 0 auto;width:min(80vw,340px);flex-direction:column;
    align-items:flex-start;justify-content:center;gap:26px;padding:40px;
    background:var(--paper);box-shadow:var(--shadow);transform:translateX(100%);
    transition:transform .4s cubic-bezier(.3,.8,.2,1)}
  .nav__links.is-open{transform:translateX(0)}
  .nav__links a{font-size:20px;font-family:var(--serif)}
  .nav__toggle{display:flex}
  .nav.is-open .nav__toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav.is-open .nav__toggle span:nth-child(2){opacity:0}
  .nav.is-open .nav__toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .hero__facts-inner{grid-template-columns:1fr 1fr}
  .fact:nth-child(3){border-left:0}
  .steps,.info-cards,.services,.cards,.maps,.parking__grid,.footer__grid,.gallery{grid-template-columns:1fr 1fr}
  .footer__grid{grid-template-columns:1fr}
}
@media (max-width:560px){
  .hero__facts-inner{grid-template-columns:1fr}
  .fact{border-left:0;border-top:1px solid rgba(255,255,255,.1)}
  .fact:first-child{border-top:0}
  .steps,.info-cards,.services,.cards,.maps,.parking__grid,.gallery,.discover-tools{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr 1fr}
  .search input{width:100%}
  .discover-tools{align-items:stretch}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;transition-duration:.001ms !important}
  html{scroll-behavior:auto}
}
