/* =========================================================
   Café & Konditorei Gantenbein — "Konditorei-Editorial"
   Vitrine-Lookbook art direction
   ========================================================= */

:root{
  --paper:#f7f0e3;
  --card:#faf5ea;
  --card-2:#f3ead8;
  --ink:#2c1d12;
  --ink-soft:#5a463a;
  --ink-faint:#8a7361;
  --gold:#c98a3c;
  --gold-deep:#a86d27;
  --berry:#b6566b;
  --cocoa:#6b4a32;
  --line:#e3d6bf;
  --shadow-warm:18px 26px 60px -28px rgba(78,48,20,.45);
  --shadow-soft:0 10px 30px -16px rgba(78,48,20,.35);
  --serif:"Cormorant", Georgia, "Times New Roman", serif;
  --grotesk:"Hanken Grotesk", system-ui, -apple-system, "Segoe UI", sans-serif;
  --hand:"Caveat", "Comic Sans MS", cursive;
  --maxw:1240px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  font-family:var(--grotesk);
  color:var(--ink);
  background-color:var(--paper);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  position:relative;
}
/* faint warm paper grain */
body::before{
  content:"";
  position:fixed;inset:0;
  pointer-events:none;z-index:1;
  opacity:.5;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' 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='0.06'/%3E%3C/svg%3E");
}

img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}

:focus-visible{outline:3px solid var(--berry);outline-offset:3px;border-radius:3px}

.skip-link{
  position:absolute;left:-999px;top:0;z-index:200;
  background:var(--ink);color:var(--paper);padding:.7rem 1.1rem;border-radius:0 0 10px 0;
  font-weight:600;
}
.skip-link:focus{left:0}

/* ---------- shared bits ---------- */
.eyebrow{
  font-family:var(--grotesk);
  text-transform:uppercase;letter-spacing:.26em;
  font-size:.72rem;font-weight:700;color:var(--gold-deep);
  margin-bottom:.9rem;
}
.eyebrow.light{color:#e7b878}
.hand{font-family:var(--hand);color:var(--berry);font-weight:600;line-height:1}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--grotesk);font-weight:600;font-size:1rem;
  padding:.92em 1.7em;border-radius:999px;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .3s,color .3s;
  cursor:pointer;border:1.5px solid transparent;letter-spacing:.01em;
}
.btn-primary{background:var(--ink);color:var(--paper);box-shadow:var(--shadow-soft)}
.btn-primary:hover{background:var(--berry);transform:translateY(-3px);box-shadow:0 16px 30px -14px rgba(182,86,107,.6)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper);transform:translateY(-3px)}

.section-head{max-width:680px;margin:0 auto 3rem;text-align:center}
.section-head.left{margin-left:0;text-align:left}
.section-head h2,
h2{
  font-family:var(--serif);font-weight:600;
  font-size:clamp(2rem,4.4vw,3.4rem);line-height:1.04;
  letter-spacing:-.01em;color:var(--ink);
}
.lead{font-size:1.1rem;color:var(--ink-soft);margin-top:1rem}
.lead.light{color:#e9dcc6}

/* piping divider */
.piping{color:var(--gold);width:100%;line-height:0;opacity:.85}
.piping svg{width:100%;height:24px;display:block}

/* =========================================================
   MASTHEAD
   ========================================================= */
.masthead{
  position:sticky;top:0;z-index:100;
  background:rgba(247,240,227,.82);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid transparent;
  transition:padding .35s var(--ease),background .35s var(--ease),border-color .35s var(--ease),box-shadow .35s var(--ease);
}
.masthead-inner{
  max-width:var(--maxw);margin:0 auto;
  padding:1.25rem clamp(1.1rem,4vw,2.4rem);
  display:flex;align-items:center;gap:1.5rem;
}
.wordmark{display:flex;flex-direction:column;line-height:1;margin-right:auto}
.wordmark-name{font-family:var(--serif);font-weight:600;font-size:1.6rem;letter-spacing:.005em;transition:font-size .35s var(--ease)}
.wordmark-dateline{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);margin-top:.32rem;font-weight:600}
.topnav ul{display:flex;gap:1.9rem;list-style:none}
.topnav a{
  font-size:.95rem;font-weight:500;color:var(--ink-soft);position:relative;padding:.2rem 0;
  transition:color .25s;
}
.topnav a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--berry);
  transition:width .3s var(--ease);
}
.topnav a:hover{color:var(--ink)}
.topnav a:hover::after{width:100%}
.nav-cta{
  font-weight:700;font-size:.92rem;color:var(--ink);
  border:1.5px solid var(--gold);border-radius:999px;padding:.55em 1.1em;
  transition:background .3s,color .3s,transform .3s;
}
.nav-cta:hover{background:var(--gold);color:#fff;transform:translateY(-2px)}

.masthead.condensed{background:rgba(247,240,227,.94);box-shadow:0 6px 24px -18px rgba(78,48,20,.5);border-color:var(--line)}
.masthead.condensed .masthead-inner{padding-top:.7rem;padding-bottom:.7rem}
.masthead.condensed .wordmark-name{font-size:1.34rem}

.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.burger span{display:block;width:26px;height:2.5px;background:var(--ink);border-radius:2px;transition:transform .3s var(--ease),opacity .25s}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

.mobilenav{
  background:var(--card);border-bottom:1px solid var(--line);
  padding:1rem clamp(1.1rem,4vw,2.4rem) 1.6rem;
}
.mobilenav ul{list-style:none;display:flex;flex-direction:column}
.mobilenav a{display:block;padding:.85rem 0;font-family:var(--serif);font-size:1.4rem;border-bottom:1px solid var(--line);color:var(--ink)}
.mobilenav-call{display:block;margin-top:1.1rem;text-align:center;background:var(--ink);color:var(--paper);padding:.9rem;border-radius:999px;font-weight:600}

/* =========================================================
   HERO — asymmetric editorial
   ========================================================= */
.hero{
  position:relative;z-index:2;
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(2rem,5vw,4.5rem) clamp(1.1rem,4vw,2.4rem) clamp(2.5rem,5vw,4rem);
  display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(1.5rem,4vw,3.5rem);
  align-items:center;
}
.hero-copy{position:relative;z-index:3}
.hero-eyebrow{
  text-transform:uppercase;letter-spacing:.24em;font-size:.74rem;font-weight:700;
  color:var(--gold-deep);margin-bottom:1.2rem;
}
.hero h1{
  font-family:var(--serif);font-weight:600;
  font-size:clamp(3.1rem,7.4vw,6rem);line-height:.97;letter-spacing:-.02em;
  color:var(--ink);
}
.hero h1 em{font-style:italic;color:var(--berry);font-weight:500}
.hero-intro{font-size:1.14rem;color:var(--ink-soft);margin:1.6rem 0 2rem;max-width:30rem}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}

.hero-media{position:relative}
.hero-photo{
  position:relative;border-radius:20px 20px 20px 90px;overflow:hidden;
  box-shadow:var(--shadow-warm);
  margin-right:clamp(-2.4rem,-4vw,-1rem); /* bleed off right edge */
  aspect-ratio:4/3;
  will-change:transform;
}
.hero-photo img{width:100%;height:120%;object-fit:cover;position:absolute;top:-10%;left:0;will-change:transform}
.hero-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(44,29,18,.12));pointer-events:none}
.hero-caption{position:absolute;left:-.5rem;bottom:-1.4rem;transform:rotate(-4deg)}
.hero-caption .hand{font-size:1.7rem;background:var(--card);padding:.25rem .8rem;border-radius:40% 60% 55% 45%/60% 50% 50% 40%;box-shadow:var(--shadow-soft);display:inline-block}

/* =========================================================
   VITRINE — display-case grid
   ========================================================= */
.vitrine{
  position:relative;z-index:2;
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(3rem,6vw,5.5rem) clamp(1.1rem,4vw,2.4rem);
}
.case-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:13rem;
  gap:1.3rem;
}
.case-tile{
  position:relative;border-radius:16px;overflow:hidden;
  background:var(--card);box-shadow:var(--shadow-soft);
  grid-row:span 2;
  transition:transform .45s var(--ease),box-shadow .45s var(--ease);
  isolation:isolate;
}
.tile-tall{grid-row:span 3}
.tile-wide{grid-column:span 2}
.tile-photo{position:absolute;inset:0}
.tile-photo img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.tile-body{
  position:absolute;left:0;right:0;bottom:0;z-index:2;
  padding:1.4rem 1.3rem 1.2rem;color:#fff;
  background:linear-gradient(180deg,transparent,rgba(36,22,12,.18) 30%,rgba(36,22,12,.86));
  transform:translateY(0);
}
.tile-body h3{font-family:var(--serif);font-weight:600;font-size:1.5rem;line-height:1.05;letter-spacing:-.01em}
.tile-body p{font-size:.9rem;line-height:1.4;margin:.35rem 0 .55rem;color:rgba(255,255,255,.9);
  max-height:0;opacity:0;overflow:hidden;transition:max-height .45s var(--ease),opacity .35s var(--ease),margin .45s var(--ease)}
.tile-body .price{
  display:inline-block;font-weight:700;font-size:.82rem;letter-spacing:.03em;
  background:var(--gold);color:#2c1d12;padding:.28em .7em;border-radius:999px;
}
.case-tile:hover{transform:translateY(-8px);box-shadow:0 28px 50px -22px rgba(78,48,20,.6)}
.case-tile:hover .tile-photo img{transform:scale(1.07)}
.case-tile:hover .tile-body p,
.case-tile:focus-within .tile-body p{max-height:6rem;opacity:1;margin:.35rem 0 .65rem}
.case-note{text-align:center;margin-top:2rem}
.case-note .hand{font-size:1.8rem}

/* =========================================================
   TAGESFRISCH — chalkboard
   ========================================================= */
.tagesfrisch{
  position:relative;z-index:2;
  padding:clamp(2.5rem,5vw,4.5rem) clamp(1.1rem,4vw,2.4rem);
}
.board{
  max-width:980px;margin:0 auto;
  background:
    radial-gradient(circle at 30% 20%,rgba(255,255,255,.04),transparent 60%),
    #2e2017;
  border:10px solid #7a5430;
  border-radius:14px;
  box-shadow:var(--shadow-warm),inset 0 0 80px rgba(0,0,0,.5);
  padding:clamp(2rem,4vw,3.2rem) clamp(1.5rem,4vw,3.5rem);
  color:#f4ecdd;text-align:center;
  position:relative;
}
.board::after{
  content:"";position:absolute;inset:10px;border:1px solid rgba(244,236,221,.16);border-radius:8px;pointer-events:none;
}
.board-kicker{font-family:var(--hand);color:#f0b56b;font-size:1.5rem;margin-bottom:.4rem}
.board-title{font-family:var(--serif);line-height:1}
.board-line{display:block;font-size:clamp(1.3rem,3vw,1.9rem);color:#e9dcc6;font-weight:400}
.board-big{
  display:inline-block;position:relative;
  font-size:clamp(2.6rem,7vw,4.6rem);font-weight:600;color:#fff;margin-top:.2rem;
}
.board-big::after{
  content:"";position:absolute;left:0;right:0;bottom:-.05em;height:.12em;
  background:var(--berry);border-radius:2px;
  transform:scaleX(0);transform-origin:left;
  transition:transform 1s var(--ease);
}
.board-big.drawn::after{transform:scaleX(1)}
.board-time{font-family:var(--hand);font-size:1.6rem;color:#f0b56b;margin:.8rem 0 1.4rem}
.board-menu{
  list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem 1.5rem;
  max-width:760px;margin:0 auto 1.6rem;
}
.board-menu li{
  font-family:var(--hand);font-size:1.5rem;color:#f4ecdd;
  padding-left:1.1rem;position:relative;text-align:left;
}
.board-menu li::before{content:"·";position:absolute;left:.1rem;color:#f0b56b;font-size:1.6rem;line-height:1}
.board-foot{font-size:1rem;color:#d8c9b2}
.board-foot a{color:#f0b56b;border-bottom:1px solid #f0b56b}
.board-foot .hand{color:#f0b56b;font-size:1.5rem;margin-left:.4rem;display:inline-block}

/* =========================================================
   CAFÉ — two column menu + photo
   ========================================================= */
.cafe{
  position:relative;z-index:2;
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(3rem,6vw,5rem) clamp(1.1rem,4vw,2.4rem);
  display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(1.8rem,4vw,3.5rem);align-items:center;
}
.cafe-photo{position:relative}
.cafe-photo img{border-radius:16px 90px 16px 16px;box-shadow:var(--shadow-warm);width:100%;aspect-ratio:3/3.4;object-fit:cover}
.cafe-photo-cap{position:absolute;right:-.4rem;bottom:-1.2rem;transform:rotate(3deg)}
.cafe-photo-cap .hand{font-size:1.45rem;background:var(--card);padding:.2rem .7rem;border-radius:50% 50% 45% 55%/60% 50% 50% 40%;box-shadow:var(--shadow-soft);display:inline-block}
.menu-card{
  background:var(--card);border:1px solid var(--line);border-radius:16px;
  padding:clamp(1.6rem,3vw,2.4rem);box-shadow:var(--shadow-soft);
  display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:1.6rem;
}
.menu-head{font-family:var(--serif);font-size:1.55rem;font-weight:600;color:var(--berry);margin-bottom:.9rem;padding-bottom:.5rem;border-bottom:2px solid var(--line)}
.menu-list div{display:flex;align-items:baseline;gap:.4rem;padding:.42rem 0;font-size:.98rem}
.menu-list dt{flex:1;display:flex;align-items:baseline;color:var(--ink-soft)}
.menu-list .dots{flex:1;border-bottom:1.5px dotted var(--line);margin:0 .4rem;transform:translateY(-.18em)}
.menu-list dd{font-weight:700;color:var(--ink)}
.cafe-note{font-size:.8rem;color:var(--ink-faint);margin-top:1rem}

/* =========================================================
   TORTEN — dark indulgent showpiece
   ========================================================= */
.torten{
  position:relative;z-index:2;
  background:linear-gradient(165deg,#3a271a,#2c1d12);
  color:#f4ecdd;
  padding:clamp(3.5rem,7vw,6rem) clamp(1.1rem,4vw,2.4rem);
  margin-top:clamp(2rem,4vw,3rem);
}
.torten-head{max-width:720px;margin:0 auto 3rem;text-align:center}
.torten-head h2{color:#fff}
.torten-gallery{
  max-width:var(--maxw);margin:0 auto 3rem;
  display:grid;grid-template-columns:1fr 1.25fr 1fr;gap:1.3rem;align-items:end;
}
.torten-gallery figure{position:relative;border-radius:14px;overflow:hidden;box-shadow:0 24px 50px -24px rgba(0,0,0,.7)}
.torten-gallery img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.torten-gallery figure:nth-child(1) img{aspect-ratio:3/4}
.torten-gallery figure:nth-child(2) img{aspect-ratio:4/4.6}
.torten-gallery figure:nth-child(3) img{aspect-ratio:3/4}
.torten-gallery figure:hover img{transform:scale(1.06)}
.torten-gallery figcaption{
  position:absolute;left:0;bottom:0;right:0;
  padding:1.4rem 1.2rem .9rem;font-family:var(--serif);font-size:1.4rem;font-weight:600;color:#fff;
  background:linear-gradient(transparent,rgba(20,12,6,.82));
}
.torten-cta{max-width:620px;margin:0 auto;text-align:center}
.torten-cta p{color:#e3d4bd;margin-bottom:1.6rem;font-size:1.05rem}

/* =========================================================
   GESCHICHTE
   ========================================================= */
.geschichte{
  position:relative;z-index:2;
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(3.5rem,7vw,6rem) clamp(1.1rem,4vw,2.4rem);
  display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;
}
.gesch-photo img{border-radius:120px 16px 16px 16px;box-shadow:var(--shadow-warm);width:100%;aspect-ratio:3/3.8;object-fit:cover;object-position:center top}
.gesch-copy h2{margin-bottom:1.2rem}
.gesch-copy p{color:var(--ink-soft);margin-bottom:1.1rem;font-size:1.06rem}
.gesch-copy strong{color:var(--ink)}
.gesch-facts{list-style:none;display:flex;flex-wrap:wrap;gap:1.6rem 2.2rem;margin:1.8rem 0 1.4rem;padding-top:1.5rem;border-top:1px solid var(--line)}
.gesch-facts li{display:flex;flex-direction:column;gap:.1rem}
.fact-num{font-size:2.6rem;color:var(--gold-deep)}
.gesch-facts li span:last-child{font-size:.9rem;color:var(--ink-faint);max-width:11rem}
.gesch-sign .hand{font-size:1.7rem}

/* =========================================================
   BESUCH
   ========================================================= */
.besuch{
  position:relative;z-index:2;
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(3rem,6vw,5rem) clamp(1.1rem,4vw,2.4rem) clamp(2.5rem,5vw,4rem);
}
.besuch-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(1.8rem,4vw,3.2rem);align-items:stretch}
.besuch-info{display:flex;flex-direction:column;gap:1.6rem}
.info-block{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:1.5rem 1.6rem;box-shadow:var(--shadow-soft)}
.info-block h3{font-family:var(--serif);font-size:1.4rem;font-weight:600;color:var(--berry);margin-bottom:.9rem}
.hours div{display:flex;justify-content:space-between;gap:1rem;padding:.4rem 0;border-bottom:1px solid var(--line);font-size:.98rem}
.hours div:last-child{border-bottom:0}
.hours dt{color:var(--ink-soft);font-weight:600}
.hours dd{text-align:right;color:var(--ink)}
.hours-note{display:block;font-size:.74rem;color:var(--ink-faint);font-weight:400}
.info-fine{font-size:.84rem;color:var(--ink-faint);margin-top:.9rem;line-height:1.45}
.contact-line{font-size:1.05rem;margin-bottom:.4rem}
.contact-line a:hover{color:var(--berry)}
.socials{display:flex;gap:.7rem;margin-top:1rem}
.socials a{font-size:.85rem;font-weight:600;border:1.5px solid var(--gold);border-radius:999px;padding:.4em 1em;transition:background .3s,color .3s}
.socials a:hover{background:var(--gold);color:#fff}
.besuch-map{border-radius:14px;overflow:hidden;box-shadow:var(--shadow-soft);border:1px solid var(--line);position:relative;min-height:420px;display:flex;flex-direction:column}
.map-canvas{position:relative;flex:1;display:block;overflow:hidden;min-height:380px;background:#efe4cf}
.map-art{position:absolute;inset:0;width:100%;height:100%}
.map-pin{position:absolute;top:50%;left:46%;transform:translate(-50%,-100%);filter:drop-shadow(0 6px 8px rgba(78,48,20,.4));transition:transform .35s var(--ease)}
.map-canvas:hover .map-pin{transform:translate(-50%,-112%)}
.map-pin::after{content:"";position:absolute;left:50%;bottom:-3px;width:14px;height:5px;background:rgba(78,48,20,.28);border-radius:50%;transform:translateX(-50%)}
.map-tag{
  position:absolute;left:1rem;bottom:1rem;right:1rem;
  background:rgba(250,245,234,.95);border-radius:10px;padding:.7rem .9rem;
  box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:.1rem;
  font-size:.86rem;color:var(--ink-soft);
}
.map-tag strong{font-family:var(--serif);font-size:1.1rem;color:var(--ink);font-weight:600}
.map-links{display:flex}
.map-links a{flex:1;text-align:center;background:var(--card);padding:.75rem;font-weight:600;font-size:.9rem;color:var(--gold-deep);border-top:1px solid var(--line)}
.map-links a:first-child{border-right:1px solid var(--line)}
.map-links a:hover{background:var(--card-2);color:var(--berry)}
.besuch-close{text-align:center;margin-top:2.6rem}
.besuch-close .hand{font-size:2rem}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{position:relative;z-index:2;background:var(--ink);color:#e6d8c4;padding:clamp(2.5rem,5vw,3.5rem) clamp(1.1rem,4vw,2.4rem) 2rem;margin-top:clamp(2rem,4vw,3rem)}
.footer-inner{max-width:var(--maxw);margin:0 auto;display:flex;flex-wrap:wrap;gap:2.5rem;justify-content:space-between}
.footer-brand{display:flex;flex-direction:column}
.footer-mark{font-family:var(--serif);font-size:1.8rem;font-weight:600;color:#fff}
.footer-sub{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:#a98e72;margin-top:.4rem}
.footer-cols{display:flex;gap:2.5rem;flex-wrap:wrap}
.footer-h{font-size:.72rem;text-transform:uppercase;letter-spacing:.18em;color:var(--gold);margin-bottom:.6rem;font-weight:700}
.footer-cols p{font-size:.95rem;line-height:1.7;color:#d8c5ad}
.footer-cols a:hover{color:#fff}
.footer-fine{max-width:var(--maxw);margin:2.2rem auto 0;padding-top:1.4rem;border-top:1px solid rgba(255,255,255,.1);font-size:.78rem;color:#9d8268}

/* =========================================================
   STICKY MOBILE CALL BAR
   ========================================================= */
.callbar{
  position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:120;
  display:none;align-items:center;justify-content:center;gap:.6rem;
  background:var(--ink);color:var(--paper);
  padding:1rem;border-radius:999px;font-weight:700;font-size:1.05rem;
  box-shadow:0 14px 30px -10px rgba(44,29,18,.6);
}
.callbar-icon{display:inline-flex;color:var(--gold)}

/* =========================================================
   REVEAL ANIMATIONS
   ========================================================= */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:980px){
  .topnav,.nav-cta{display:none}
  .burger{display:flex}
  .hero{grid-template-columns:1fr;gap:2.5rem}
  .hero-media{order:-1}
  .hero-photo{margin-right:0;border-radius:18px 18px 18px 70px}
  .hero h1{font-size:clamp(3rem,12vw,5rem)}
  .cafe{grid-template-columns:1fr}
  .cafe-photo{max-width:520px;margin:0 auto}
  .geschichte{grid-template-columns:1fr}
  .gesch-photo{max-width:480px;margin:0 auto}
  .besuch-grid{grid-template-columns:1fr}
  .torten-gallery{grid-template-columns:1fr 1fr;gap:1rem}
  .torten-gallery figure:nth-child(1) img,
  .torten-gallery figure:nth-child(2) img,
  .torten-gallery figure:nth-child(3) img{aspect-ratio:3/3.4}
  .case-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:11rem}
}

@media (max-width:560px){
  .masthead-inner{padding:.9rem 1.1rem}
  .wordmark-name{font-size:1.3rem}
  .case-grid{grid-template-columns:1fr;grid-auto-rows:auto}
  .case-tile,.tile-tall,.tile-wide{grid-row:auto;grid-column:auto;aspect-ratio:3/2.4}
  .tile-tall{aspect-ratio:3/3.2}
  .tile-body p{max-height:6rem;opacity:1;margin:.35rem 0 .65rem} /* always show on mobile */
  .menu-card{grid-template-columns:1fr;gap:1.6rem}
  .board-menu{grid-template-columns:1fr 1fr;gap:.4rem 1rem}
  .torten-gallery{grid-template-columns:1fr;max-width:420px}
  .torten-gallery figure:nth-child(1) img,
  .torten-gallery figure:nth-child(2) img,
  .torten-gallery figure:nth-child(3) img{aspect-ratio:4/3}
  .gesch-facts{gap:1.2rem 1.8rem}
  .fact-num{font-size:2.2rem}
  .callbar{display:flex}
  .footer-inner{flex-direction:column;gap:1.8rem}
  body{padding-bottom:5rem} /* room for callbar */
  .hero-caption .hand{font-size:1.4rem}
}

/* =========================================================
   MOTION GUARDS
   ========================================================= */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .reveal{opacity:1!important;transform:none!important}
  .board-big::after{transform:scaleX(1)!important}
  .hero-photo img{position:static;height:auto;width:100%}
}
/* JS-set noanim flag */
.noanim *,.noanim *::before,.noanim *::after{animation:none!important;transition:none!important}
.noanim .reveal{opacity:1!important;transform:none!important}
.noanim .board-big::after{transform:scaleX(1)!important}
.noanim .hero-photo img{position:static!important;height:auto!important;width:100%!important;transform:none!important}
