/* ===========================================================
   Pizzeria Pummarò
   Palette: red / white / hint of blue
   =========================================================== */
:root{
  --red:#d6202f;
  --red-dark:#a8121f;
  --red-deep:#7a0c16;
  --blue:#1e3a5f;          /* hint of blue accent */
  --cream:#fdfaf5;
  --paper:#fffdf9;
  --ink:#221a17;
  --ink-soft:#5a5048;
  --line:#ece3d6;
  --shadow:0 12px 40px rgba(122,12,22,.12);
  --display:'Playfair Display',Georgia,serif;
  --body:'DM Sans',system-ui,sans-serif;
  --app-height:100vh;
  --hero-mobile-extra:2.5rem;
}

*{margin:0;padding:0;box-sizing:border-box}
html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
}
body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.eyebrow{
  font-family:var(--body);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.72rem;
  font-weight:700;
  color:var(--red);
  display:inline-block;
  margin-bottom:.8rem;
}
h2{
  font-family:var(--display);
  font-weight:600;
  font-size:clamp(2rem,5vw,3.2rem);
  line-height:1.05;
  letter-spacing:-.01em;
}

/* ===== NAV ===== */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(253,250,245,.92);
  backdrop-filter:blur(12px);
  box-shadow:0 2px 24px rgba(122,12,22,.08);
  transition:background .35s ease, box-shadow .35s ease, padding .35s ease;
  padding:1.1rem 0;
}
#nav.scrolled{
  padding:.6rem 0;
}
.nav-inner{
  max-width:1200px;margin:0 auto;padding:0 clamp(1.2rem,4vw,3rem);
  display:flex;align-items:center;justify-content:space-between;
}
.nav-logo{display:flex;align-items:center;gap:.6rem;font-family:var(--display);
  font-weight:600;font-size:1.3rem;color:var(--ink);transition:color .35s}
.nav-logo img{width:38px;height:38px;object-fit:contain}
.nav-logo em{color:var(--red);font-style:normal}
.nav-links{display:flex;gap:2.2rem;align-items:center}
.nav-links a{
  font-weight:600;font-size:.95rem;color:var(--ink);position:relative;
  transition:color .25s;
}
#nav.scrolled .nav-links a{color:var(--ink)}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;
  background:var(--red);transition:width .28s ease;
}
.nav-links a:hover::after{width:100%}
.nav-links a:hover{color:var(--red)}
#nav.scrolled .nav-links a{color:var(--ink)}
.nav-links a.nav-order{
  background:var(--red);color:#fff;padding:.5rem 1.3rem;border-radius:40px;
  box-shadow:0 6px 18px rgba(214,32,47,.3);transition:background .25s,transform .25s,color .25s;
}
.nav-links a.nav-order::after{display:none}
.nav-links a.nav-order:hover{background:#b51a27;color:#fff;transform:translateY(-2px)}
#nav.scrolled .nav-links a.nav-order{color:#fff}
.nav-close{display:none}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.burger span{width:26px;height:2.5px;background:var(--ink);border-radius:2px;transition:background .35s}

/* ===== HERO ===== */
.hero{position:relative;height:100vh;min-height:600px;display:flex;
  align-items:center;justify-content:center;overflow:hidden}
.hero-bg{
  position:absolute;top:50%;left:50%;
  width:min(190vw,190vh);height:min(190vw,190vh);max-width:none;
  object-fit:contain;z-index:0;
  transform:translate(-50%,-50%);
  transform-origin:center center;
  animation:heroRotate 90s linear infinite;
}
@keyframes heroRotate{
  from{transform:translate(-50%,-50%) rotate(0deg)}
  to{transform:translate(-50%,-50%) rotate(360deg)}
}
.hero-content{position:relative;z-index:2;text-align:center;padding:1.5rem;
  display:flex;flex-direction:column;align-items:center;
  animation:fadeUp 1.1s ease both}
.hero.hero-loading .hero-bg,
.hero.hero-loading .hero-content{opacity:0;animation:none}
.hero.hero-ready .hero-bg{opacity:1;transition:opacity .55s ease}
.hero.hero-ready .hero-content{opacity:1;animation:fadeUp 1.1s ease both}
.hero-logo-wrap{position:relative;display:flex;align-items:center;justify-content:center}
.hero-logo{
  position:relative;z-index:2;
  width:min(440px,80vw);height:auto;margin:0 auto;
  filter:drop-shadow(0 14px 36px rgba(0,0,0,.45));
  background:rgba(255,253,249,.80);border-radius:50%;padding:2.2rem;
}
.hero-tag{
  margin-top:1.6rem;color:var(--ink);font-family:var(--display);font-style:italic;
  font-size:clamp(1.1rem,2.6vw,1.5rem);letter-spacing:.04em;font-weight:600;
  background:rgba(255,253,249,.92);padding:.55rem 1.5rem;border-radius:40px;
  box-shadow:0 4px 20px rgba(0,0,0,.12);
}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}

/* scroll indicator */
.scroll-indicator{
  position:absolute;bottom:2.2rem;left:50%;transform:translateX(-50%);
  z-index:5;display:flex;flex-direction:column;align-items:center;gap:.5rem;
  color:#000;opacity:.9;transition:opacity .25s;
  filter:drop-shadow(0 1px 5px rgba(255,255,255,.6));
}
.scroll-indicator:hover{opacity:1}
.scroll-text{font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;
  font-weight:600}
.scroll-pizza{animation:scrollPizza 2.2s ease-in-out infinite}
@keyframes scrollPizza{
  0%,100%{transform:translateY(-5px);opacity:.7}
  50%{transform:translateY(0);opacity:1}
}

/* ===== reveal anim ===== */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* ===== ABOUT ===== */
.about{position:relative;z-index:1;background:var(--blue);color:var(--cream);padding:clamp(4.5rem,10vw,8rem) clamp(1.2rem,4vw,3rem);--scallop-color:var(--blue)}
.about .eyebrow{color:#ff9aa2}
.about h2{color:#fff}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center;max-width:1200px;margin:0 auto}
.about-images{position:relative;min-height:480px}
.about-img-1{
  width:78%;height:auto;border-radius:14px;box-shadow:var(--shadow);
  border:6px solid var(--paper);
}
.about-img-2{
  position:absolute;bottom:-2rem;right:0;width:55%;height:auto;border-radius:14px;
  box-shadow:var(--shadow);border:6px solid var(--paper);transition-delay:.15s;
}
.about-text p{margin-top:1.1rem;color:rgba(255,255,255,.85);font-size:1.05rem}
.about-text em{color:#ff9aa2;font-style:italic;font-family:var(--display)}
.about-text strong{color:#fff}

/* ===== Sine-wave dividers ===== */
.scallop-top{position:relative}
.scallop-top::before{
  content:"";position:absolute;left:0;right:0;top:-39px;height:40px;
  z-index:5;pointer-events:none;
  background-repeat:no-repeat;background-position:center;background-size:100% 100%;
}
.about.scallop-top::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none' viewBox='0 0 1200 40'%3E%3Cpath d='M0,40 L0,20 C200,2 400,38 600,20 C800,2 1000,38 1200,20 L1200,40 Z' fill='%231e3a5f'/%3E%3C/svg%3E")}
/* Desktop only: straight line between landing page and about (no wave) */
@media(min-width:861px){
  .about.scallop-top::before{background-image:none;top:0;height:0}
}
.process.scallop-top::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none' viewBox='0 0 1200 40'%3E%3Cpath d='M0,40 L0,20 C200,2 400,38 600,20 C800,2 1000,38 1200,20 L1200,40 Z' fill='%23fdfaf5'/%3E%3C/svg%3E")}
.menu.scallop-top::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none' viewBox='0 0 1200 40'%3E%3Cpath d='M0,40 L0,20 C200,2 400,38 600,20 C800,2 1000,38 1200,20 L1200,40 Z' fill='%23fffdf9'/%3E%3C/svg%3E")}
.find.scallop-top::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none' viewBox='0 0 1200 40'%3E%3Cpath d='M0,40 L0,20 C200,2 400,38 600,20 C800,2 1000,38 1200,20 L1200,40 Z' fill='%231e3a5f'/%3E%3C/svg%3E")}
.footer.scallop-top::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none' viewBox='0 0 1200 40'%3E%3Cpath d='M0,40 L0,20 C200,2 400,38 600,20 C800,2 1000,38 1200,20 L1200,40 Z' fill='%23221a17'/%3E%3C/svg%3E")}

/* ===== Pummarò 2.0 — red About & Find ===== */
.site-2 .about{background:var(--red);--scallop-color:var(--red)}
.site-2 .find{background:var(--red);--scallop-color:var(--red)}
.site-2 .about.scallop-top::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none' viewBox='0 0 1200 40'%3E%3Cpath d='M0,40 L0,20 C200,2 400,38 600,20 C800,2 1000,38 1200,20 L1200,40 Z' fill='%23d6202f'/%3E%3C/svg%3E")}
.site-2 .find.scallop-top::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none' viewBox='0 0 1200 40'%3E%3Cpath d='M0,40 L0,20 C200,2 400,38 600,20 C800,2 1000,38 1200,20 L1200,40 Z' fill='%23d6202f'/%3E%3C/svg%3E")}
@media(min-width:861px){
  .site-2 .about.scallop-top::before{background-image:none}
}
.site-2 .about .eyebrow,
.site-2 .find .eyebrow{color:#ffd9c9}
.site-2 .about-text em{color:#ffd9c9}
.site-2 .find .info-block h3{color:#ffd9c9}
.site-2 .find .socials a:hover{background:var(--ink);border-color:var(--ink)}
.hero-order{
  position:relative;z-index:2;display:inline-flex;align-items:center;
  margin-top:1.6rem;background:var(--red);color:#fff;
  font-family:var(--body);font-weight:700;font-size:1rem;letter-spacing:.02em;
  padding:.95rem 2.4rem;border-radius:40px;
  box-shadow:0 12px 30px rgba(214,32,47,.4);transition:background .25s,transform .25s,box-shadow .25s;
}
.hero-order:hover{background:#b51a27;transform:translateY(-3px);box-shadow:0 18px 40px rgba(214,32,47,.5)}

@keyframes heroOrderGlow{
  0%,100%{background-position:0% 50%;opacity:.28;transform:scale(1)}
  50%{background-position:100% 50%;opacity:.63;transform:scale(1.028)}
}

.hero-version{
  position:absolute;left:50%;bottom:20%;transform:translateX(-50%);
  z-index:3;font-family:var(--display);font-weight:700;
  font-size:clamp(1.2rem,3vw,1.7rem);line-height:1;color:var(--ink);
  letter-spacing:.02em;
}

/* ===== PROCESS ===== */
.process{
  background:var(--cream);
  padding:clamp(4.5rem,10vw,8rem) clamp(1.2rem,4vw,3rem);
  position:relative;z-index:2;
}
.process-head{text-align:center;max-width:720px;margin:0 auto clamp(2.5rem,5vw,4rem)}
.process-slogan{
  font-family:var(--display);font-size:clamp(1.3rem,3vw,1.9rem);
  color:var(--ink);margin-top:.8rem;line-height:1.25;
}
.process-slogan em{color:var(--red);font-style:italic}
.slogan-break{display:none}
@media(min-width:861px){.slogan-break{display:inline}}
.process-intro{color:var(--ink-soft);font-size:1.05rem;margin-top:1.2rem}
.process-grid{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(1.5rem,3vw,2.5rem);
}
.process-card{text-align:center}
.process-card:nth-child(2){transition-delay:.12s}
.process-card:nth-child(3){transition-delay:.24s}
.process-img-wrap{
  position:relative;border-radius:16px;overflow:hidden;
  box-shadow:var(--shadow);border:6px solid var(--paper);
  aspect-ratio:4/5;
}
.process-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.process-card:hover .process-img-wrap img{transform:scale(1.05)}
.process-step{
  position:absolute;top:.8rem;left:.8rem;
  width:42px;height:42px;border-radius:50%;
  background:var(--red);color:#fff;
  font-family:var(--display);font-weight:600;font-size:1.05rem;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 16px rgba(214,32,47,.35);
}
.process-card h3{
  font-family:var(--display);font-weight:600;font-size:1.4rem;
  margin:1.3rem 0 .5rem;letter-spacing:-.01em;
}
.process-card p{color:var(--ink-soft);font-size:.98rem;line-height:1.6}
.process-card em{color:var(--red);font-style:italic;font-family:var(--display)}
.process-card strong{color:var(--blue)}

/* ===== MENU ===== */
.menu{
  background:
    linear-gradient(180deg,var(--paper),#fff8ef);
  padding:clamp(4.5rem,10vw,8rem) clamp(1.2rem,4vw,3rem);
  position:relative;z-index:2;
  --scallop-color:var(--paper);
}
.menu-head{text-align:center;max-width:640px;margin:0 auto 3rem}
.menu-sub{color:var(--ink-soft);margin-top:.6rem}
.menu-tabs{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:.55rem;
  max-width:960px;width:100%;margin:0 auto 3rem;
}
.site-2 .menu-tabs{
  grid-template-columns:repeat(5,minmax(0,1fr));
  max-width:1080px;
}
.tab{
  font-family:var(--body);font-weight:600;font-size:clamp(.74rem,1.1vw,.86rem);
  padding:.72rem .65rem;border-radius:12px;border:1.5px solid var(--line);
  background:#fff;color:var(--ink-soft);cursor:pointer;transition:all .25s;
  text-align:center;white-space:normal;line-height:1.25;
  min-height:2.85rem;display:flex;align-items:center;justify-content:center;
  width:100%;
}
.tab:hover{border-color:var(--red);color:var(--red)}
.tab.active{background:var(--red);border-color:var(--red);color:#fff;
  box-shadow:0 6px 18px rgba(214,32,47,.3)}

.menu-panels{max-width:920px;margin:0 auto}
.panel{display:none;animation:panelIn .45s ease both}
.panel.active{
  display:block;
  column-count:2;
  column-gap:3.5rem;
}
@keyframes panelIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

.dish{
  padding:1.15rem 0;border-bottom:1px dashed var(--line);
  break-inside:avoid;-webkit-column-break-inside:avoid;page-break-inside:avoid;
}
.dish:first-child{padding-top:0}
.dish-head{display:flex;justify-content:space-between;align-items:baseline;gap:1rem}
.dish h3{font-family:var(--display);font-weight:600;font-size:1.15rem;letter-spacing:-.01em}
.dish .cl{font-family:var(--body);font-weight:500;font-size:.8rem;color:var(--ink-soft)}
.dish p{color:var(--ink-soft);font-size:.92rem;margin-top:.25rem}
.price{
  font-family:var(--display);font-weight:600;color:var(--red);font-size:1.1rem;
  white-space:nowrap;
}
.price::after{content:" €"}

.drink-group{margin-bottom:2.5rem;break-inside:avoid;-webkit-column-break-inside:avoid;page-break-inside:avoid}
.drink-group:last-child{margin-bottom:0}
.drink-title{
  font-family:var(--display);font-style:italic;color:var(--blue);
  font-size:1.4rem;margin-bottom:.4rem;padding-bottom:.5rem;
  border-bottom:2px solid var(--line);
}

/* ===== FIND ===== */
.find{
  background:var(--blue);color:var(--cream);
  padding:clamp(4.5rem,10vw,8rem) clamp(1.2rem,4vw,3rem);
  position:relative;z-index:3;
  --scallop-color:var(--blue);
}
.find .eyebrow{color:#ff9aa2}
.find-grid{max-width:1200px;margin:0 auto;display:grid;
  grid-template-columns:1fr 1.1fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.find h2{color:#fff;margin-bottom:2rem}
.info-block{margin-bottom:1.8rem}
.info-block h3{font-family:var(--body);text-transform:uppercase;letter-spacing:.14em;
  font-size:.78rem;color:#ff9aa2;margin-bottom:.4rem}
.info-block a{font-size:1.05rem;border-bottom:1px solid transparent;transition:border-color .25s}
.info-block a:hover{border-color:#fff}
.hours{list-style:none;max-width:340px}
.hours li{display:flex;justify-content:space-between;padding:.35rem 0;
  border-bottom:1px solid rgba(255,255,255,.12);font-size:.95rem}
.hours li span:first-child{color:rgba(255,255,255,.78)}
.socials{display:flex;gap:1rem;margin-top:2rem}
.socials a{
  width:46px;height:46px;border-radius:50%;border:1.5px solid rgba(255,255,255,.4);
  display:flex;align-items:center;justify-content:center;color:#fff;transition:all .25s;
}
.socials a svg{width:22px;height:22px}
.socials a:hover{background:var(--red);border-color:var(--red);transform:translateY(-3px)}
.find-map iframe{width:100%;height:480px;border-radius:14px;box-shadow:var(--shadow);filter:saturate(1.05)}

/* ===== FOOTER ===== */
.footer{
  background:var(--ink);color:var(--cream);text-align:center;
  padding:3rem 1.5rem;
  position:relative;z-index:4;
  --scallop-color:var(--ink);
}
.footer-logo{width:54px;height:54px;margin:0 auto 1rem;object-fit:contain}
.footer p{font-family:var(--display);font-size:1.05rem}
.footer-small{font-family:var(--body);font-size:.85rem;color:rgba(255,255,255,.6);margin-top:.4rem}
.footer-links{display:flex;align-items:center;justify-content:center;gap:.9rem;margin-top:1.6rem}
.footer-link{
  background:none;border:0;font-family:var(--body);font-size:.9rem;font-weight:500;
  color:rgba(255,255,255,.8);cursor:pointer;padding:.2rem 0;transition:color .25s;
}
.footer-link:hover{color:#fff}
.footer-sep{color:rgba(255,255,255,.3)}
.footer-credit{margin-top:1.1rem;font-size:.8rem;color:rgba(255,255,255,.5)}
.footer-credit a{color:rgba(255,255,255,.85);border-bottom:1px solid transparent;transition:border-color .25s,color .25s}
.footer-credit a:hover{color:#fff;border-color:#fff}

/* ===== Modals ===== */
.modal{
  position:fixed;inset:0;z-index:300;
  display:flex;align-items:center;justify-content:center;padding:1.5rem;
  background:rgba(0,0,0,.62);
}
.modal[hidden]{display:none}
.modal-box{
  background:var(--cream);color:var(--ink);
  max-width:440px;width:100%;border-radius:16px;
  padding:2.4rem 2.1rem 2.1rem;position:relative;text-align:left;
  box-shadow:0 30px 80px rgba(0,0,0,.45);animation:modalIn .3s ease both;
}
.modal-box h3{font-family:var(--display);font-weight:600;font-size:1.5rem;margin-bottom:1rem;color:var(--ink)}
.modal-box p{font-family:var(--body);font-size:.98rem;line-height:1.65;color:var(--ink-soft)}
.modal-close{
  position:absolute;top:.7rem;right:1rem;background:none;border:0;
  font-size:1.9rem;line-height:1;color:var(--ink-soft);cursor:pointer;transition:color .2s;
}
.modal-close:hover{color:var(--red)}
@keyframes modalIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

/* ===== TRANSIT / ANREISE (2.0) ===== */
.transit{
  --transit-bg:#f3e8d8;
  background:var(--transit-bg);
  padding:clamp(3.5rem,8vw,6rem) clamp(1.2rem,4vw,3rem);
  position:relative;z-index:2;
}
.transit.scallop-top::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none' viewBox='0 0 1200 40'%3E%3Cpath d='M0,40 L0,20 C200,2 400,38 600,20 C800,2 1000,38 1200,20 L1200,40 Z' fill='%23f3e8d8'/%3E%3C/svg%3E")}
.transit-head{text-align:center;max-width:640px;margin:0 auto clamp(2.5rem,5vw,3.5rem)}
.transit .eyebrow{color:var(--red)}
.transit h2{color:var(--ink)}
.transit-sub{color:var(--ink-soft);margin-top:.7rem;font-size:1.05rem;line-height:1.6}

.transit-route{
  display:grid;
  grid-template-columns:1fr 1.3fr 1fr;
  grid-template-rows:auto auto;
  align-items:center;justify-items:center;
  column-gap:.5rem;row-gap:1rem;
  max-width:760px;margin:0 auto;
}
.transit-route > .stop-a{grid-column:1;grid-row:1}
.transit-route > .label-a{grid-column:1;grid-row:2}
.transit-route > .t-leg{grid-column:2;grid-row:1}
.transit-route > .stop-b{grid-column:3;grid-row:1}
.transit-route > .label-b{grid-column:3;grid-row:2}

.t-icon{flex:0 0 auto;display:flex;align-items:center;justify-content:center}
.ubahn-badge{
  width:62px;height:62px;border-radius:12px;background:#ef7d00;color:#fff;
  font-family:var(--body);font-weight:700;font-size:1.7rem;letter-spacing:.01em;
  box-shadow:0 8px 20px rgba(239,125,0,.38);
}
.transit-pin{
  width:62px;height:62px;border-radius:50%;background:var(--red);color:#fff;
  box-shadow:0 8px 20px rgba(214,32,47,.38);
}
.transit-pin svg{width:32px;height:32px}

.t-label{text-align:center;display:flex;flex-direction:column;gap:.15rem}
.t-label-title{font-family:var(--display);font-weight:600;font-size:1.2rem;color:var(--ink);line-height:1.2}
.t-label-sub{font-size:.85rem;color:var(--ink-soft)}

.t-leg{
  position:relative;width:100%;
  display:flex;flex-direction:column;align-items:center;gap:.35rem;
}
.t-leg::before{
  content:"";position:absolute;top:31px;left:-26%;right:-26%;
  border-top:3px dashed #e6d2b6;z-index:0;
}
.t-walk{
  position:relative;z-index:1;display:flex;align-items:center;justify-content:center;
  color:var(--red);background:var(--transit-bg);padding:0 .5rem;
}
.t-walk svg{width:38px;height:38px}
.t-leg-time{
  position:relative;z-index:1;background:var(--transit-bg);padding:0 .5rem;
  font-family:var(--display);font-weight:700;font-size:1.05rem;color:var(--red);white-space:nowrap;
}

@media(max-width:600px){
  .transit-route{
    grid-template-columns:1fr;grid-template-rows:none;
    row-gap:.45rem;max-width:320px;
  }
  .transit-route > .stop-a,
  .transit-route > .label-a,
  .transit-route > .t-leg,
  .transit-route > .stop-b,
  .transit-route > .label-b{grid-column:1;grid-row:auto}
  .t-leg{padding:.5rem 0}
  .t-leg::before{
    top:0;bottom:0;left:50%;right:auto;width:0;height:auto;
    border-top:0;border-left:3px dashed #e6d2b6;transform:translateX(-50%);
  }
  .t-walk{background:var(--transit-bg);padding:.4rem 0}
  .t-leg-time{padding:.2rem .5rem}
}

/* ===== RESPONSIVE ===== */
@media(max-width:860px){
  .about-grid{grid-template-columns:1fr}
  .find-grid{grid-template-columns:1fr}
  .panel.active{column-count:1}
  .process-grid{grid-template-columns:1fr;max-width:440px}
  .process-img-wrap{aspect-ratio:16/10}
  .menu-tabs,
  .site-2 .menu-tabs{
    grid-template-columns:repeat(2,minmax(0,1fr));
    max-width:520px;
  }
  .footer{
    padding-bottom:calc(28px + env(safe-area-inset-bottom,0px) + 2.75rem);
  }
}
@media(max-width:768px){
  .hero{
    height:calc(var(--app-height) + var(--hero-mobile-extra));
    min-height:calc(var(--app-height) + var(--hero-mobile-extra));
  }
}
@media(max-width:720px){
  .scroll-indicator{bottom:0.3rem}
  .hero-order{
    margin-top:calc(1.6rem - 1cm);
    box-shadow:0 10px 28px rgba(214,32,47,.38);
    overflow:visible;
  }
  .hero-order::before{
    content:"";position:absolute;inset:-7px;border-radius:48px;z-index:-1;
    background:linear-gradient(
      115deg,
      rgba(255,255,255,0) 0%,
      rgba(255,255,255,.53) 30%,
      rgba(255,245,235,.39) 50%,
      rgba(255,255,255,.53) 70%,
      rgba(255,255,255,0) 100%
    );
    background-size:220% 220%;
    filter:blur(8px);
    animation:heroOrderGlow 2.8s ease-in-out infinite;
    pointer-events:none;
  }
  .burger{display:flex}
  .nav-links{
    position:fixed;inset:0 0 0 auto;width:min(78vw,320px);height:100vh;
    background:var(--paper);flex-direction:column;align-items:flex-start;
    justify-content:center;gap:1.8rem;padding:2.5rem;
    transform:translateX(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);
    box-shadow:-12px 0 40px rgba(0,0,0,.18);
  }
  .nav-links.open{transform:translateX(0)}
  .nav-links a{color:var(--ink);font-family:var(--display);font-size:1.4rem}
  #nav.scrolled .nav-links a{color:var(--ink)}
  .nav-close{
    display:block;position:absolute;top:1.4rem;right:1.6rem;
    background:none;border:0;font-size:2rem;line-height:1;color:var(--ink);cursor:pointer;
  }
  body.nav-open{overflow:hidden}
}