/* =========================================================
   THE UGLY DUCKLING — sticker-bomb dive-bar styles
   ========================================================= */

:root{
  --cyan:        #25c2e8;
  --cyan-bright: #4fd6f5;
  --cyan-deep:   #119bbd;
  --cyan-ink:    #0a6e88;
  --yellow:      #ffd21e;
  --yellow-deep: #f7b500;
  --orange:      #ff7a1a;
  --pink:        #ff3d9a;
  --pink-soft:   #ff7ac0;
  --lime:        #b6e94a;
  --purple:      #9b6bff;
  --ink:         #0c0c0e;
  --ink-soft:    #1a1a1f;
  --cream:       #fff7e9;
  --paper:       #fffdf6;

  --shadow-hard: 5px 5px 0 var(--ink);
  --shadow-pop:  8px 8px 0 var(--ink);
  --radius:      22px;

  --display: "Bagel Fat One", system-ui, sans-serif;
  --marker:  "Permanent Marker", "Bagel Fat One", cursive;
  --body:    "Archivo", system-ui, sans-serif;
}

*{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; scroll-padding-top:80px; }

body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  line-height:1.55;
}

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

::selection{ background:var(--pink); color:#fff; }

/* ---------- shared bits ---------- */
.eyebrow{
  font-family:var(--marker);
  font-size:clamp(.95rem,2vw,1.15rem);
  letter-spacing:.04em;
  color:var(--pink);
  transform:rotate(-2deg);
  display:inline-block;
}
.eyebrow--neon{ color:var(--cyan-bright); }

.section-title{
  font-family:var(--display); font-weight:700;
  font-size:clamp(2.6rem,7vw,5.2rem);
  line-height:.95;
  letter-spacing:-.01em;
  -webkit-text-stroke:4px var(--ink);
  paint-order:stroke fill;
  color:var(--paper);
  text-shadow:var(--shadow-hard);
  margin:.15em 0 .35em;
}
.section-title--neon{
  color:var(--ink-soft);
  -webkit-text-stroke:3px var(--cyan-bright);
  text-shadow:0 0 24px rgba(79,214,245,.55), 5px 5px 0 #000;
}
.section-sub{
  font-size:clamp(1rem,2.2vw,1.25rem);
  font-weight:600;
  max-width:46ch;
  margin-inline:auto;
}
.section-sub--dim{ color:#cfe9f2; }

.hand{ font-family:var(--marker); }

/* ---------- buttons ---------- */
.btn{
  --bg:var(--yellow);
  font-family:var(--display); font-weight:700;
  font-size:1rem;
  letter-spacing:.01em;
  background:var(--bg);
  color:var(--ink);
  border:3px solid var(--ink);
  border-radius:60px;
  padding:.7em 1.4em;
  display:inline-flex;
  align-items:center;
  gap:.4em;
  cursor:pointer;
  box-shadow:var(--shadow-hard);
  transition:transform .12s ease, box-shadow .12s ease, background .2s;
  white-space:nowrap;
}
.btn:hover{ transform:translate(-2px,-2px) rotate(-1deg); box-shadow:7px 7px 0 var(--ink); }
.btn:active{ transform:translate(3px,3px); box-shadow:1px 1px 0 var(--ink); }
.btn--lg{ font-size:1.2rem; padding:.8em 1.7em; }
.btn--yellow{ --bg:var(--yellow); }
.btn--pink{ --bg:var(--pink); color:#fff; }
.btn--ghost{ --bg:transparent; color:#fff; }
.btn--ghost.btn--dark{ color:var(--ink); }

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:100;
  display:flex; align-items:center; gap:1rem;
  padding:.7rem clamp(1rem,4vw,2.5rem);
  background:rgba(12,12,14,.85);
  backdrop-filter:blur(10px);
  border-bottom:3px solid var(--ink);
  transition:transform .35s ease;
}
.nav.is-hidden{ transform:translateY(-110%); }
.nav__brand{ display:flex; align-items:center; gap:.55rem; margin-right:auto; }
.nav__duck{ width:46px; height:46px; filter:drop-shadow(2px 2px 0 rgba(0,0,0,.6)); transition:transform .3s; }
.nav__brand:hover .nav__duck{ transform:rotate(-8deg) scale(1.08); }
.nav__logo{ height:62px; width:auto; transition:transform .3s; }
.nav__brand:hover .nav__logo{ transform:rotate(-1deg) scale(1.04); }
.nav__links{ display:flex; gap:1.6rem; align-items:center; }
.nav__links a{
  font-family:var(--display); font-weight:700; color:#fff; font-size:1.02rem;
  position:relative; padding:.2em 0;
}
.nav__links a::after{
  content:""; position:absolute; left:0; right:100%; bottom:-2px; height:3px;
  background:var(--pink); border-radius:3px; transition:right .25s ease;
}
.nav__links a:hover{ color:var(--yellow); }
.nav__links a:hover::after{ right:0; }
.nav__cta{ font-size:.95rem; padding:.55em 1.1em; }
.nav__burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:6px; }
.nav__burger span{ width:28px; height:3px; background:#fff; border-radius:3px; transition:.25s; }
.nav.is-open .nav__burger span:nth-child(1){ transform:translateY(8px) rotate(45deg); }
.nav.is-open .nav__burger span:nth-child(2){ opacity:0; }
.nav.is-open .nav__burger span:nth-child(3){ transform:translateY(-8px) rotate(-45deg); }

/* =========================================================
   HERO
   ========================================================= */
html[data-shot] .hero{ min-height:760px; }
.hero{
  position:relative; min-height:100svh;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:7rem 1.2rem 6rem; overflow:hidden;
  background:var(--cyan);
}
/* animated pool water */
.water{ position:absolute; inset:0; z-index:0; overflow:hidden; }
.water__wave{
  position:absolute; left:-25%; right:-25%; height:60%;
  background:
    radial-gradient(closest-side, transparent 60%, transparent 60%),
    linear-gradient(transparent,transparent);
  opacity:.55;
}
.water__wave--1{
  top:-10%;
  background:
    repeating-radial-gradient(circle at 20% 30%, transparent 0 38px, rgba(255,255,255,.10) 38px 52px);
  animation:drift 26s linear infinite;
}
.water__wave--2{
  top:30%; height:70%;
  background:
    repeating-radial-gradient(circle at 70% 60%, transparent 0 46px, rgba(255,255,255,.12) 46px 64px);
  animation:drift 34s linear infinite reverse;
}
.water__wave--3{
  inset:0; height:100%; opacity:.4;
  background:
    radial-gradient(120% 90% at 50% 110%, var(--cyan-deep), transparent 60%),
    radial-gradient(80% 60% at 12% 8%, var(--cyan-bright), transparent 60%);
}
@keyframes drift{ to{ transform:translate(12%, -6%) rotate(8deg); } }

/* floating bubbles (JS-injected) */
.bubbles{ position:absolute; inset:0; }
.bubble{
  position:absolute; bottom:-40px; border-radius:50%;
  background:radial-gradient(circle at 35% 30%, rgba(255,255,255,.9), rgba(255,255,255,.15));
  box-shadow:inset 0 0 6px rgba(255,255,255,.6);
  animation:rise linear infinite;
}
@keyframes rise{
  0%{ transform:translateY(0) scale(.6); opacity:0; }
  15%{ opacity:.9; }
  100%{ transform:translateY(-115svh) translateX(var(--drift,20px)) scale(1.1); opacity:0; }
}

/* ink speckles + halftone vibe */
.hero::after{
  content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background-image:
    radial-gradient(var(--ink) 1.6px, transparent 1.7px),
    radial-gradient(var(--ink) 1.2px, transparent 1.3px);
  background-size:90px 90px, 54px 54px;
  background-position:0 0, 30px 25px;
  opacity:.10;
}

.hero__inner{ position:relative; z-index:5; max-width:920px; }
.hero__kicker{
  font-family:var(--marker); color:var(--ink);
  background:var(--yellow); border:3px solid var(--ink);
  padding:.35em 1em; border-radius:40px; display:inline-block;
  font-size:clamp(.8rem,2vw,1rem); box-shadow:var(--shadow-hard);
  transform:rotate(-2deg);
}
.hero__logo{ margin:1.2rem auto .4rem; max-width:min(760px,90vw); }
.hero__logo img{
  width:auto; max-width:100%; max-height:min(38svh,460px);
  display:block; margin-inline:auto;
  filter:drop-shadow(6px 8px 0 rgba(0,0,0,.35));
}
.hero__tag{
  font-size:clamp(1.05rem,2.6vw,1.5rem); font-weight:700; color:var(--ink);
  text-shadow:1px 1px 0 rgba(255,255,255,.4);
}
.hero__tag strong{
  color:#fff; background:var(--pink); padding:0 .25em;
  border-radius:6px; -webkit-box-decoration-break:clone; box-decoration-break:clone;
}
.hero__cta{ margin-top:1.8rem; display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

.hero__duck{
  position:absolute; z-index:4; width:clamp(150px,26vw,300px);
  right:clamp(-20px,3vw,6vw); bottom:clamp(-30px,2vw,4vh);
  filter:drop-shadow(8px 10px 0 rgba(0,0,0,.3));
  animation:bob 4.5s ease-in-out infinite;
}
@keyframes bob{ 0%,100%{ transform:translateY(0) rotate(-4deg); } 50%{ transform:translateY(-18px) rotate(3deg); } }

.hero__scroll{
  position:absolute; bottom:1.1rem; left:50%; transform:translateX(-50%);
  z-index:4; pointer-events:none; display:flex; flex-direction:column; align-items:center; gap:.4rem;
  font-family:var(--marker); font-size:.8rem; color:var(--ink);
}
.hero__scroll i{ width:3px; height:34px; background:var(--ink); border-radius:3px; position:relative; overflow:hidden; }
.hero__scroll i::after{ content:""; position:absolute; inset:0; background:var(--pink); animation:scrolldot 1.6s ease-in-out infinite; }
@keyframes scrolldot{ 0%{ transform:translateY(-100%); } 60%,100%{ transform:translateY(100%); } }

/* ---------- floating stickers ---------- */
.sticker{ position:absolute; z-index:4; pointer-events:none; }
.sticker--star{ top:14%; left:7%; width:78px; animation:spin 14s linear infinite; }
.sticker--star svg{ fill:var(--yellow); stroke:var(--ink); stroke-width:5; filter:drop-shadow(3px 3px 0 var(--ink)); }
.sticker--heart{ top:24%; right:9%; width:60px; animation:bob 5s ease-in-out infinite; }
.sticker--heart svg{ fill:var(--pink); stroke:var(--ink); stroke-width:2.2; filter:drop-shadow(3px 3px 0 var(--ink)); }
.sticker--zig{
  bottom:9%; left:5%; width:90px; height:26px;
  background:repeating-linear-gradient(135deg, var(--lime) 0 10px, var(--ink) 10px 13px);
  transform:rotate(-12deg); border:3px solid var(--ink); border-radius:8px;
  box-shadow:var(--shadow-hard); animation:bob 6s ease-in-out infinite;
}
.sticker--dots{
  bottom:14%; left:42%; width:80px; height:80px;
  background:radial-gradient(var(--purple) 28%, transparent 30%);
  background-size:20px 20px; opacity:.7; transform:rotate(10deg);
}
@keyframes spin{ to{ transform:rotate(360deg); } }

/* =========================================================
   MARQUEE
   ========================================================= */
.marquee{
  background:var(--ink); color:var(--yellow);
  border-top:3px solid var(--ink); border-bottom:3px solid var(--ink);
  padding:.6rem 0; overflow:hidden; white-space:nowrap;
}
.marquee__track{ display:inline-flex; animation:marq 22s linear infinite; }
.marquee__track span{
  font-family:var(--display); font-weight:700; font-size:clamp(1.1rem,3vw,1.7rem);
  letter-spacing:.02em; padding-right:1rem;
}
@keyframes marq{ to{ transform:translateX(-50%); } }

/* =========================================================
   STORY
   ========================================================= */
.story{
  background:var(--cream); padding:clamp(4rem,9vw,8rem) clamp(1.2rem,5vw,5rem);
  position:relative;
}
.story::before{
  content:""; position:absolute; inset:0; pointer-events:none; opacity:.5;
  background-image:radial-gradient(var(--cyan) 1.4px, transparent 1.5px);
  background-size:30px 30px; mask:linear-gradient(180deg,#000,transparent 40%);
}
.story__grid{
  position:relative; max-width:1100px; margin:0 auto;
  display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(2rem,5vw,4.5rem); align-items:center;
}
.story__art{ position:relative; }
.polaroid{
  background:#fff; border:4px solid var(--ink); border-radius:14px;
  padding:14px 14px 0; box-shadow:var(--shadow-pop);
  transform:rotate(-3deg); transition:transform .4s ease;
}
.polaroid:hover{ transform:rotate(-1deg) scale(1.02); }
.polaroid img{ border-radius:6px; border:3px solid var(--ink); }
.polaroid__cap{
  font-family:var(--marker); font-size:1.4rem; display:block;
  text-align:center; padding:.5em 0 .4em; color:var(--ink);
}
.sticker--burst{
  position:absolute; right:-18px; bottom:-22px; z-index:3;
  font-family:var(--display); font-weight:700; color:#fff; background:var(--pink);
  border:3px solid var(--ink); border-radius:50%;
  width:108px; height:108px; display:flex; align-items:center; justify-content:center;
  text-align:center; line-height:1; font-size:1.1rem; padding:.4em;
  box-shadow:var(--shadow-hard); transform:rotate(12deg);
  animation:bob 5.5s ease-in-out infinite;
}
.story__copy h2{
  font-family:var(--display); font-weight:700; font-size:clamp(2.4rem,6vw,4.4rem);
  line-height:.92; margin:.15em 0 .5em; color:var(--cyan);
  -webkit-text-stroke:3px var(--ink); paint-order:stroke fill; text-shadow:var(--shadow-hard);
}
.story__copy p{ font-size:1.1rem; margin-bottom:1rem; font-weight:500; max-width:52ch; }
.story__copy p strong{ background:var(--yellow); padding:0 .2em; border-radius:4px; }
.story__copy .hand{ font-size:1.5rem; color:var(--pink); transform:rotate(-2deg); }
.story__stats{
  display:flex; gap:1.6rem; margin-top:1.6rem; flex-wrap:wrap;
}
.story__stats div{ display:flex; flex-direction:column; }
.story__stats b{ font-family:var(--display); font-weight:700; font-size:2.4rem; color:var(--orange); -webkit-text-stroke:2px var(--ink); paint-order:stroke fill; line-height:1; }
.story__stats span{ font-family:var(--marker); font-size:.95rem; }

/* =========================================================
   MENU
   ========================================================= */
.menu{
  background:
    radial-gradient(120% 80% at 80% 0%, var(--yellow) 0%, var(--yellow-deep) 60%, #e9a800 100%);
  color:var(--ink);
  padding:clamp(4rem,9vw,7rem) clamp(1.2rem,5vw,5rem);
  border-top:4px solid var(--ink);
  position:relative; overflow:hidden;
}
.menu::before{
  content:""; position:absolute; inset:0; pointer-events:none; opacity:.16;
  background-image:radial-gradient(var(--ink) 2px, transparent 2.2px);
  background-size:34px 34px;
}
.menu__head{ position:relative; text-align:center; margin-bottom:clamp(2rem,4vw,3.2rem); }
.menu__cols{
  position:relative; max-width:1180px; margin:0 auto;
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.4rem,3vw,2.4rem); align-items:start;
}
.menu__col{ display:flex; flex-direction:column; gap:clamp(1.4rem,3vw,2.4rem); }

.card{
  background:var(--paper); border:4px solid var(--ink); border-radius:var(--radius);
  box-shadow:var(--shadow-pop); overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease;
}
.card:hover{ transform:translate(-3px,-3px); box-shadow:11px 11px 0 var(--ink); }
.card__head{
  display:flex; align-items:baseline; justify-content:space-between; gap:1rem;
  padding:.7em 1.1em; border-bottom:4px solid var(--ink);
}
.card__head h3{
  font-family:var(--display); font-weight:700; font-size:clamp(1.4rem,3.4vw,2rem);
  color:#fff; -webkit-text-stroke:2px var(--ink); paint-order:stroke fill;
  text-shadow:2px 2px 0 var(--ink); line-height:1;
}
.card__head span{ font-family:var(--marker); font-size:.9rem; color:var(--ink); white-space:nowrap; }
.card__head--cyan{ background:var(--cyan); }
.card__head--pink{ background:var(--pink); }
.card__head--orange{ background:var(--orange); }
.card__head--lime{ background:var(--lime); }
.card__head--lime h3{ color:var(--ink); -webkit-text-stroke:0; text-shadow:none; }
.card__head--ink{ background:var(--ink); }
.card__head--ink h3{ color:var(--yellow); -webkit-text-stroke:0; text-shadow:none; }
.card__head--ink span{ color:#fff; }

.dishlist{ list-style:none; padding:1.1em 1.2em 1.3em; display:flex; flex-direction:column; gap:1em; }
.dishlist--tight{ gap:.65em; }
.dishlist--cols li,
.dishlist--tight li{ }
.dish__top{ display:flex; align-items:baseline; gap:.5em; }
.dish__name{ font-family:var(--display); font-weight:700; font-size:1.05rem; line-height:1.1; }
.dish__name small{ display:block; font-family:var(--marker); font-size:.72rem; color:var(--cyan-ink); letter-spacing:.02em; }
.leader{ flex:1; border-bottom:3px dotted rgba(12,12,14,.35); transform:translateY(-3px); min-width:14px; }
.dish__price{ font-family:var(--display); font-weight:700; font-size:1.05rem; color:var(--orange); white-space:nowrap; }
.dish__price i{ font-style:normal; color:var(--cyan-deep); }
.dish__desc{ font-size:.9rem; font-weight:500; color:#4a4a4a; margin-top:.25em; max-width:48ch; }

.tag{
  font-family:var(--body); font-style:normal; font-weight:800; font-size:.6rem;
  text-transform:uppercase; letter-spacing:.06em; color:#fff;
  padding:.15em .5em; border-radius:30px; border:2px solid var(--ink);
  vertical-align:middle; margin-left:.3em;
}
.tag--v{ background:var(--lime); color:var(--ink); }
.tag--dog{ background:var(--purple); }

.card--sauce .sauces{ display:flex; flex-wrap:wrap; gap:.5em; padding:1.1em 1.2em 0; }
.card--sauce .sauces span{
  font-family:var(--marker); font-size:.95rem;
  background:var(--cream); border:2.5px solid var(--ink); border-radius:30px;
  padding:.25em .8em; box-shadow:3px 3px 0 var(--ink); transition:transform .15s;
}
.card--sauce .sauces span:hover{ transform:rotate(-3deg) scale(1.05); background:var(--yellow); }
.card__note{ padding:1em 1.2em 1.3em; font-weight:600; font-size:.92rem; }

/* =========================================================
   VISIT
   ========================================================= */
.visit{
  background:var(--cyan);
  padding:clamp(4rem,9vw,7rem) clamp(1.2rem,5vw,5rem);
  border-top:4px solid var(--ink); position:relative; overflow:hidden;
}
.visit::before{
  content:""; position:absolute; inset:0; opacity:.5;
  background:repeating-radial-gradient(circle at 80% 20%, transparent 0 44px, rgba(255,255,255,.12) 44px 60px);
  animation:drift 30s linear infinite;
}
.visit__inner{
  position:relative; max-width:1080px; margin:0 auto;
  display:grid; grid-template-columns:1.4fr 1fr; gap:clamp(1.4rem,3vw,2.2rem); align-items:stretch;
}
.visit__card{
  background:var(--paper); border:4px solid var(--ink); border-radius:var(--radius);
  box-shadow:var(--shadow-pop); padding:clamp(1.6rem,4vw,2.6rem);
}
.visit__card--main h2{
  font-family:var(--display); font-weight:700; font-size:clamp(2.2rem,5vw,3.6rem); line-height:.95;
  color:var(--pink); -webkit-text-stroke:3px var(--ink); paint-order:stroke fill; text-shadow:var(--shadow-hard);
  margin:.1em 0 .35em;
}
.visit__addr{ font-family:var(--display); font-weight:700; font-size:1.4rem; line-height:1.25; margin-bottom:1.2rem; }
.visit__btns{ display:flex; gap:.8rem; flex-wrap:wrap; margin-bottom:1.4rem; }
.visit__btns .btn--ghost{ border-color:var(--ink); }

.visit__card--hours{ display:flex; flex-direction:column; background:var(--ink); color:#fff; }
.visit__card--hours h3{
  font-family:var(--display); font-weight:700; font-size:1.8rem; color:var(--yellow); margin-bottom:.7em;
}
.hours{ list-style:none; display:flex; flex-direction:column; gap:.5em; flex:1; }
.hours li{
  display:flex; justify-content:space-between; align-items:baseline; gap:1em;
  padding-bottom:.5em; border-bottom:2px dotted rgba(255,255,255,.2);
}
.hours span{ font-weight:600; color:#cfe9f2; }
.hours b{ font-family:var(--display); font-weight:700; color:#fff; }
.hours--sun b{ color:var(--pink-soft); }
.hours__note{ font-family:var(--marker); font-size:.9rem; color:var(--cyan-bright); margin-top:1em; }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{
  background:var(--ink); color:#fff;
  padding:clamp(3rem,6vw,5rem) clamp(1.2rem,5vw,5rem) 2rem;
}
.footer__top{ display:flex; align-items:center; justify-content:center; gap:1rem; position:relative; margin-bottom:2.5rem; }
.footer__logo{ width:min(420px,70vw); }
.footer__duck{ width:90px; animation:bob 5s ease-in-out infinite; }
.footer__cols{
  max-width:900px; margin:0 auto; display:grid; grid-template-columns:repeat(3,1fr);
  gap:2rem; padding-bottom:2.5rem; border-bottom:2px solid rgba(255,255,255,.14);
}
.footer__cols h4{ font-family:var(--display); font-weight:700; color:var(--yellow); font-size:1.3rem; margin-bottom:.6em; }
.footer__cols a{ display:block; color:#cfe9f2; font-weight:600; padding:.18em 0; transition:color .2s, transform .2s; }
.footer__cols a:hover{ color:var(--pink-soft); transform:translateX(4px); }
.footer__cols p{ color:#cfe9f2; font-weight:500; }
.footer__base{
  max-width:900px; margin:1.5rem auto 0; display:flex; justify-content:space-between;
  gap:1rem; flex-wrap:wrap; font-size:.85rem; color:#8aa6b0;
}
.footer__follow{ font-family:var(--marker); color:var(--cyan-bright); }
.footer__follow a{ color:var(--pink-soft); }

/* =========================================================
   REVEAL ANIMATION
   ========================================================= */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }
.reveal:nth-child(2){ transition-delay:.06s; }
.reveal:nth-child(3){ transition-delay:.12s; }
.reveal:nth-child(4){ transition-delay:.18s; }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:900px){
  .nav__links{
    position:fixed; inset:64px 0 auto 0; flex-direction:column; gap:0;
    background:rgba(12,12,14,.97); border-bottom:3px solid var(--ink);
    padding:1rem 0; transform:translateY(-150%); transition:transform .3s ease;
  }
  .nav.is-open .nav__links{ transform:none; }
  .nav__links a{ padding:.9rem 2rem; width:100%; text-align:center; font-size:1.3rem; }
  .nav__burger{ display:flex; }
  .nav__cta{ display:none; }

  .story__grid{ grid-template-columns:1fr; }
  .story__art{ max-width:380px; margin:0 auto; }
  .menu__cols{ grid-template-columns:1fr; }
  .visit__inner{ grid-template-columns:1fr; }
  .hero__duck{ width:150px; opacity:.92; }
}
@media (max-width:560px){
  .hero__cta{ width:100%; flex-direction:column; align-items:stretch; }
  .hero__cta .btn{ justify-content:center; }
  .btn--lg{ font-size:1.05rem; }
  .hero__tag br{ display:none; }
  .footer__base{ flex-direction:column; text-align:center; }
  .footer__cols{ grid-template-columns:1fr; text-align:center; }
  .footer__cols a:hover{ transform:none; }
  .sticker--dots,.sticker--zig{ display:none; }
}

/* reduced motion */
@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; }
  .reveal{ opacity:1; transform:none; }
  html{ scroll-behavior:auto; }
}
