/* ═══════════════════════════════════════════════════════════════
   GAMES HUB EDINBURGH — "tipped-out game box" concept
   White café-table base · ink meeple black · tongue red · token lime
   Discord band in table-lamp blurple. Greenshields Studio demo.
   ═══════════════════════════════════════════════════════════════ */

:root{
  --paper:#ffffff;
  --paper-warm:#f6f5f0;
  --ink:#161513;
  --ink-soft:#54524c;
  --line:#e5e3dc;
  --red:#e8101f;
  --red-deep:#c00d19;
  --lime:#b5c316;
  --lime-soft:#eef2c8;
  --blurple:#4b5ad9;
  --blurple-deep:#3a48c0;
  --radius:22px;
  --shadow:0 10px 30px rgba(22,21,19,.10);
  --shadow-lift:0 18px 44px rgba(22,21,19,.16);
  --font-display:"Fredoka",system-ui,sans-serif;
  --font-body:"Albert Sans",system-ui,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:96px}
html,body{overflow-x:clip}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:1.0625rem;
  line-height:1.6;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:var(--font-display);font-weight:600;line-height:1.06;margin:0 0 .5em;letter-spacing:-.01em}
h2{font-size:clamp(2rem,4.6vw,3.3rem)}
p{margin:0 0 1em}
a{color:inherit}
img{max-width:100%;height:auto;display:block}
sup{font-size:.62em}
.nowrap{white-space:nowrap}

::selection{background:var(--lime);color:var(--ink)}

/* ── buttons ── */
.btn{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--font-display);font-weight:600;font-size:1.02rem;
  padding:.78em 1.5em;border-radius:999px;text-decoration:none;
  border:2.5px solid var(--ink);
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease;
}
.btn:hover{transform:translateY(-2px) rotate(-.5deg);box-shadow:var(--shadow)}
.btn:active{transform:translateY(0)}
.btn svg{width:1.25em;height:auto;flex:none}
.btn-ink{background:var(--ink);color:#fff}
.btn-ink:hover{background:#000}
.btn-ghost{background:transparent;color:var(--ink)}
.btn-discord{background:var(--blurple);border-color:var(--blurple);color:#fff}
.btn-discord:hover{background:var(--blurple-deep);border-color:var(--blurple-deep)}
.btn-white{background:#fff;border-color:#fff;color:var(--blurple-deep);font-size:1.15rem}
.btn-white:hover{background:var(--lime);border-color:var(--lime);color:var(--ink)}

/* ── header ── */
.site-head{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;gap:2rem;
  padding:.7rem clamp(1rem,4vw,3rem);
  background:rgba(255,255,255,.92);backdrop-filter:blur(10px);
  border-bottom:2.5px solid var(--ink);
}
.brand{display:flex;align-items:center;gap:.7rem;text-decoration:none}
.brand img{width:52px;height:52px;transition:transform .3s ease}
.brand:hover img{transform:rotate(-10deg)}
.brand-word{font-family:var(--font-display);font-weight:700;font-size:1.18rem;line-height:1.02;display:flex;flex-direction:column}
.brand-word em{font-style:normal;font-weight:500;font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--red-deep)}
.head-nav{display:flex;gap:1.6rem;margin-left:auto}
.head-nav a{
  text-decoration:none;font-weight:600;font-size:.98rem;
  padding:.3em 0;border-bottom:3px solid transparent;
}
.head-nav a:hover{border-bottom-color:var(--lime)}
.head-cta{font-size:.92rem;padding:.6em 1.2em}

/* ── hero ── */
.hero{
  display:grid;grid-template-columns:minmax(0,10fr) minmax(0,9fr);
  align-items:center;gap:clamp(2rem,5vw,5rem);
  padding:clamp(3rem,7vh,6rem) clamp(1rem,5vw,4.5rem) clamp(3.5rem,8vh,6.5rem);
  max-width:1360px;margin:0 auto;
  position:relative;
}
.hero-est{
  display:inline-flex;align-items:center;gap:.6em;
  font-weight:700;font-size:.85rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-soft);margin-bottom:1.2rem;
}
.pip{width:.85em;height:.85em;border-radius:50%;display:inline-block}
.pip-red{background:var(--red)}
.hero h1{
  font-size:clamp(3.2rem,8.5vw,5.9rem);
  font-weight:700;letter-spacing:-.02em;
  margin-bottom:.35em;
}
.dot-red{color:var(--red)}
.hero-sub{font-size:clamp(1.08rem,1.6vw,1.25rem);color:var(--ink-soft);max-width:34em;margin-bottom:1.6em}
.hero-chips{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2rem}
.chip{
  font-family:var(--font-display);font-weight:500;font-size:.95rem;
  padding:.45em 1.1em;border-radius:999px;
  border:2px solid var(--ink);background:#fff;
}
.chip strong{font-weight:700;color:var(--red-deep)}
.chip-lime{background:var(--lime-soft);border-color:var(--ink)}
.chip-lime strong{color:var(--ink)}
.hero-ctas{display:flex;flex-wrap:wrap;gap:.9rem}

.hero-art{position:relative}
.hero-illo-wrap{
  position:relative;
  transform:rotate(1.6deg);
}
.hero-illo{
  border-radius:32px;
  border:2.5px solid var(--ink);
  box-shadow:var(--shadow-lift);
  background:#fff;
}
.hero-badge{
  position:absolute;bottom:-38px;left:-30px;
  width:clamp(110px,12vw,160px);height:auto;
  filter:drop-shadow(0 10px 22px rgba(22,21,19,.28));
  transform:rotate(-8deg);
  animation:badge-bob 5.5s ease-in-out infinite;
}
@keyframes badge-bob{
  0%,100%{transform:rotate(-8deg) translateY(0)}
  50%{transform:rotate(-5deg) translateY(-8px)}
}
.meeple-svg{display:block}
.confetti{position:absolute;opacity:.95}
.confetti-1{width:44px;top:-26px;right:6%;fill:var(--red);transform:rotate(18deg);animation:drift 7s ease-in-out infinite}
.confetti-2{width:30px;bottom:-8px;right:-14px;fill:var(--lime);transform:rotate(-24deg);animation:drift 8s ease-in-out infinite reverse}
.confetti-3{width:24px;top:38%;left:-34px;fill:var(--ink);transform:rotate(9deg);animation:drift 9s ease-in-out infinite}
@keyframes drift{
  0%,100%{translate:0 0}
  50%{translate:0 -12px}
}

/* ── how to play (box back) ── */
.howto{
  display:grid;grid-template-columns:minmax(0,11fr) minmax(0,8fr);
  gap:clamp(2rem,4vw,4rem);align-items:center;
  padding:clamp(3rem,7vh,5.5rem) clamp(1rem,5vw,4.5rem);
  max-width:1360px;margin:0 auto;
}
.boxback{
  background:var(--paper-warm);
  border:2.5px solid var(--ink);
  border-radius:var(--radius);
  padding:clamp(1.6rem,3vw,2.8rem);
  box-shadow:var(--shadow);
  transform:rotate(-.6deg);
}
.boxback-head h2{margin-bottom:.15em}
.boxback-tag{color:var(--ink-soft);font-style:italic;margin-bottom:1.4em}
.spec-row{
  display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem;
  list-style:none;margin:0 0 1.8rem;padding:0;
}
.spec-row li{
  background:#fff;border:2px solid var(--ink);border-radius:14px;
  padding:.8rem .5rem;text-align:center;
}
.spec-num{display:block;font-family:var(--font-display);font-weight:700;font-size:clamp(1.25rem,2vw,1.7rem);color:var(--red)}
.spec-row li:nth-child(2) .spec-num{color:var(--ink)}
.spec-row li:nth-child(4) .spec-num{color:var(--ink)}
.spec-label{font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}
.setup-steps{margin:0;padding:0;list-style:none;counter-reset:step}
.setup-steps li{
  counter-increment:step;position:relative;
  padding:.65rem 0 .65rem 3.2rem;
  border-top:2px dashed var(--line);
}
.setup-steps li::before{
  content:counter(step);
  position:absolute;left:0;top:.75rem;
  width:2.2rem;height:2.2rem;border-radius:50%;
  background:var(--ink);color:#fff;
  font-family:var(--font-display);font-weight:600;font-size:1.05rem;
  display:grid;place-items:center;
}
.setup-steps li:nth-child(2)::before{background:var(--red)}
.setup-steps li:nth-child(3)::before{background:var(--lime);color:var(--ink)}

.howto-photo{margin:0;transform:rotate(1.4deg)}
.howto-photo img{
  border-radius:var(--radius);
  border:8px solid #fff;
  outline:2.5px solid var(--ink);
  box-shadow:var(--shadow-lift);
}
.howto-photo figcaption{
  font-family:var(--font-display);font-weight:500;
  text-align:center;margin-top:1rem;color:var(--ink-soft);
}

/* ── this week — turn-order track ── */
.week{
  background:var(--paper-warm);
  border-top:2.5px solid var(--ink);
  border-bottom:2.5px solid var(--ink);
  padding:clamp(3rem,7vh,5.5rem) clamp(1rem,5vw,4.5rem) clamp(2.5rem,5vh,4rem);
}
.week-head{max-width:1360px;margin:0 auto 2.2rem;display:flex;align-items:baseline;gap:1.4rem;flex-wrap:wrap}
.week-head h2{margin:0}
.week-head p{margin:0;color:var(--ink-soft);font-size:1.1rem}
.turn-track{
  list-style:none;margin:0 auto;padding:1.2rem 0 2.6rem;max-width:1360px;
  display:grid;grid-template-columns:repeat(7,1fr);gap:.9rem;
  position:relative;
}
.turn-track::before{
  content:"";position:absolute;left:2%;right:2%;top:50%;
  border-top:3px dashed rgba(22,21,19,.22);
  z-index:0;
}
.turn{
  position:relative;z-index:1;
  background:#fff;border:2.5px solid var(--ink);border-radius:16px;
  padding:1rem .8rem 1.1rem;
  display:flex;flex-direction:column;gap:.28rem;
  min-height:8.2rem;
  box-shadow:var(--shadow);
  transition:transform .18s ease;
}
.turn:nth-child(odd){transform:rotate(-1.3deg)}
.turn:nth-child(even){transform:rotate(1.2deg)}
.turn:hover{transform:rotate(0) translateY(-4px)}
.turn-day{
  font-family:var(--font-display);font-weight:700;font-size:.82rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--red-deep);
}
.turn-event{font-family:var(--font-display);font-weight:600;font-size:1.02rem;line-height:1.2}
.turn-note{font-size:.8rem;color:var(--ink-soft)}
.turn.is-today{border-color:var(--red);border-width:3px;background:#fff}
.turn.is-today::after{
  content:"Tonight!";
  position:absolute;top:-1.15rem;right:-.5rem;
  background:var(--red);color:#fff;
  font-family:var(--font-display);font-weight:600;font-size:.78rem;
  padding:.22em .8em;border-radius:999px;
  transform:rotate(4deg);
}
.week-foot{max-width:1360px;margin:0 auto 2.4rem;color:var(--ink-soft);font-size:.92rem}
.week-foot a{color:var(--blurple-deep);font-weight:600}

.plays-strip{
  max-width:1360px;margin:0 auto;
  display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap;
  border-top:2px dashed var(--line);padding-top:1.6rem;
}
.plays-label{font-weight:700;font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.plays-strip ul{display:flex;align-items:center;gap:2rem;flex-wrap:wrap;list-style:none;margin:0;padding:0}
.plays-strip img{
  height:42px;width:auto;
  filter:grayscale(1) contrast(1.05) opacity(.8);
  transition:filter .25s ease,transform .25s ease;
}
.plays-strip li:hover img{filter:none;transform:scale(1.08)}
.plays-text{font-family:var(--font-display);font-weight:600;font-size:1.05rem;color:var(--ink-soft)}

/* ── game librarian ── */
.librarian{padding:clamp(3.5rem,8vh,6rem) clamp(1rem,5vw,4.5rem)}
.librarian-inner{max-width:960px;margin:0 auto}
.librarian-head{text-align:center;max-width:640px;margin:0 auto 2.4rem;position:relative}
.librarian-meeple{width:56px;margin:0 auto 1rem;fill:var(--lime);transform:rotate(-7deg)}
.librarian-head p{color:var(--ink-soft);font-size:1.1rem}
.lib-form{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-bottom:2rem}
.lib-form fieldset{border:none;margin:0;padding:0}
.lib-form legend{
  font-family:var(--font-display);font-weight:600;font-size:1rem;
  margin-bottom:.6rem;padding:0;
}
.chip-group{display:flex;flex-wrap:wrap;gap:.5rem}
.qchip{
  font-family:var(--font-display);font-weight:500;font-size:.92rem;
  padding:.5em 1.05em;border-radius:999px;cursor:pointer;
  border:2px solid var(--ink);background:#fff;color:var(--ink);
  transition:background .15s ease,transform .15s ease;
}
.qchip:hover{transform:translateY(-2px)}
.qchip.is-on{background:var(--ink);color:#fff}
.lib-results{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:1.1rem;min-height:9rem;
}
.pick{
  background:#fff;border:2.5px solid var(--ink);border-radius:18px;
  padding:1.2rem 1.3rem 1.1rem;box-shadow:var(--shadow);
  position:relative;
  animation:pick-in .35s ease backwards;
}
.pick:nth-child(2){animation-delay:.08s;transform:rotate(.8deg)}
.pick:nth-child(3){animation-delay:.16s;transform:rotate(-.7deg)}
.pick:nth-child(1){transform:rotate(-.5deg)}
@keyframes pick-in{
  from{opacity:0;translate:0 14px}
  to{opacity:1;translate:0 0}
}
.pick h3{font-size:1.3rem;margin-bottom:.2em}
.pick-pitch{color:var(--ink-soft);font-size:.95rem;margin-bottom:.9em;min-height:3em}
.pick-meta{
  display:flex;gap:.45rem;flex-wrap:wrap;
}
.pick-meta span{
  font-size:.78rem;font-weight:700;letter-spacing:.04em;
  padding:.28em .8em;border-radius:999px;
  background:var(--lime-soft);border:1.5px solid var(--ink);
}
.pick-tape{
  position:absolute;top:-12px;left:50%;translate:-50% 0;
  background:var(--red);color:#fff;
  font-family:var(--font-display);font-weight:600;font-size:.74rem;
  letter-spacing:.1em;text-transform:uppercase;
  padding:.25em .9em;border-radius:999px;transform:rotate(-2deg);
}
.lib-foot{text-align:center;color:var(--ink-soft);max-width:520px;margin:2.2rem auto 0;font-size:.98rem}

/* ── café ── */
.cafe{
  background:var(--lime-soft);
  border-top:2.5px solid var(--ink);
  padding:clamp(3rem,6vh,4.5rem) clamp(1rem,5vw,4.5rem);
  display:grid;grid-template-columns:minmax(0,2fr) minmax(0,3fr);
  gap:clamp(2rem,4vw,4rem);align-items:center;
  position:relative;
}
.cafe-copy h2{margin-bottom:.3em}
.cafe-copy p{color:var(--ink-soft);font-size:1.12rem;margin:0}
.cafe-menu{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.cafe-menu li{
  background:#fff;border:2.5px solid var(--ink);border-radius:16px;
  padding:1rem 1.2rem;display:flex;flex-direction:column;gap:.1rem;
  box-shadow:var(--shadow);
}
.cafe-menu li:nth-child(odd){transform:rotate(-.7deg)}
.cafe-menu li:nth-child(even){transform:rotate(.7deg)}
.cafe-emoji{font-size:1.6rem;line-height:1;margin-bottom:.35rem}
.cafe-menu strong{font-family:var(--font-display);font-weight:600;font-size:1.08rem}
.cafe-menu span:last-child{font-size:.88rem;color:var(--ink-soft)}

/* ── discord band ── */
.discord{
  background:var(--blurple);
  color:#fff;
  border-top:2.5px solid var(--ink);
  padding:clamp(3.5rem,8vh,6rem) clamp(1rem,5vw,4.5rem) clamp(3rem,6vh,4.5rem);
  position:relative;overflow:hidden;
}
.discord::before,.discord::after{ /* giant faint meeples in the band */
  content:"";position:absolute;width:420px;height:420px;
  background:rgba(255,255,255,.055);
  -webkit-mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><path d="M50 6c9.5 0 16.5 7.2 16.5 16.2 0 3.8-1.2 7.1-3.2 9.8 7.6 4.6 13.9 7.4 21.6 9.5 5.7 1.6 9.1 5.6 9.1 10.6 0 6.1-4.9 10.9-11 10.9-6.6 0-11.6-3-18.1-6.9-.6 7.7 1.6 13.8 5.4 23.2 2 5-1.2 10.7-7.2 10.7h-7.3c-3.6 0-5.5-1.9-5.8-4.6-.3 2.7-2.2 4.6-5.8 4.6h-7.3c-6 0-9.2-5.7-7.2-10.7 3.8-9.4 6-15.5 5.4-23.2-6.5 3.9-11.5 6.9-18.1 6.9-6.1 0-11-4.8-11-10.9 0-5 3.4-9 9.1-10.6 7.7-2.1 14-4.9 21.6-9.5-2-2.7-3.2-6-3.2-9.8C33.5 13.2 40.5 6 50 6z"/></svg>') center/contain no-repeat;
          mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><path d="M50 6c9.5 0 16.5 7.2 16.5 16.2 0 3.8-1.2 7.1-3.2 9.8 7.6 4.6 13.9 7.4 21.6 9.5 5.7 1.6 9.1 5.6 9.1 10.6 0 6.1-4.9 10.9-11 10.9-6.6 0-11.6-3-18.1-6.9-.6 7.7 1.6 13.8 5.4 23.2 2 5-1.2 10.7-7.2 10.7h-7.3c-3.6 0-5.5-1.9-5.8-4.6-.3 2.7-2.2 4.6-5.8 4.6h-7.3c-6 0-9.2-5.7-7.2-10.7 3.8-9.4 6-15.5 5.4-23.2-6.5 3.9-11.5 6.9-18.1 6.9-6.1 0-11-4.8-11-10.9 0-5 3.4-9 9.1-10.6 7.7-2.1 14-4.9 21.6-9.5-2-2.7-3.2-6-3.2-9.8C33.5 13.2 40.5 6 50 6z"/></svg>') center/contain no-repeat;
}
.discord::before{top:-120px;left:-130px;transform:rotate(-18deg)}
.discord::after{bottom:-140px;right:-110px;transform:rotate(14deg)}
.discord-inner{
  max-width:1360px;margin:0 auto 3rem;
  display:grid;grid-template-columns:minmax(0,10fr) minmax(0,8fr);
  gap:clamp(2rem,5vw,4.5rem);align-items:center;
  position:relative;z-index:1;
}
.discord-live{
  display:inline-flex;align-items:center;gap:.6em;
  font-weight:700;font-size:.9rem;letter-spacing:.1em;text-transform:uppercase;
  background:rgba(0,0,0,.22);padding:.5em 1.1em;border-radius:999px;
  margin-bottom:1.4rem;
}
.live-dot{
  width:.7em;height:.7em;border-radius:50%;background:#57F287;
  box-shadow:0 0 0 0 rgba(87,242,135,.6);
  animation:live-pulse 2s ease-out infinite;
}
@keyframes live-pulse{
  0%{box-shadow:0 0 0 0 rgba(87,242,135,.6)}
  70%{box-shadow:0 0 0 9px rgba(87,242,135,0)}
  100%{box-shadow:0 0 0 0 rgba(87,242,135,0)}
}
.discord h2{font-size:clamp(2.3rem,5vw,3.8rem);color:#fff}
.discord-sub{font-size:1.15rem;color:rgba(255,255,255,.88);max-width:32em}
.discord-uses{list-style:none;margin:0 0 2rem;padding:0;display:grid;gap:.55rem}
.discord-uses li{display:flex;align-items:baseline;gap:.8em;font-size:1rem;color:rgba(255,255,255,.92)}
.chan{
  font-family:var(--font-display);font-weight:600;font-size:.9rem;
  background:rgba(0,0,0,.28);padding:.22em .75em;border-radius:8px;
  white-space:nowrap;
}
.discord-tiny{font-size:.8rem;color:rgba(255,255,255,.75);margin-top:1rem}

.discord-side{display:grid;gap:1.4rem}
.discord-illo{
  border-radius:26px;
  border:4px solid rgba(255,255,255,.9);
  box-shadow:0 22px 55px rgba(0,0,0,.35);
  transform:rotate(1.6deg);
}
.chat-card{
  background:#fff;color:var(--ink);
  border-radius:18px;padding:1.1rem 1.3rem;
  box-shadow:0 18px 44px rgba(0,0,0,.3);
  transform:rotate(-1.2deg);
  max-width:420px;justify-self:end;
  margin-top:-3.6rem;margin-right:1rem;
  position:relative;z-index:2;
}
.chat-title{
  font-family:var(--font-display);font-weight:600;font-size:.88rem;
  color:var(--ink-soft);border-bottom:2px dashed var(--line);
  padding-bottom:.5rem;margin-bottom:.7rem;
}
.chat-msg{display:flex;gap:.7rem;align-items:flex-start;margin-bottom:.55rem}
.chat-msg:last-child{margin-bottom:0}
.chat-msg p{margin:0;font-size:.92rem;line-height:1.4}
.chat-msg strong{font-weight:800;margin-right:.35em}
.av{width:30px;flex:none;margin-top:.1rem}
.av-red{fill:var(--red)}
.av-lime{fill:#8fa000}
.av-ink{fill:var(--ink)}

/* member wall */
.member-wall{max-width:1360px;margin:0 auto;position:relative;z-index:1}
.member-wall ul{
  list-style:none;margin:0 0 1rem;padding:0;
  display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.8rem;
}
.member{
  background:rgba(255,255,255,.1);
  border:1.5px solid rgba(255,255,255,.22);
  border-radius:14px;padding:.7rem .85rem;
  display:flex;align-items:center;gap:.65rem;
  transition:background .2s ease,transform .2s ease;
}
.member:hover{background:rgba(255,255,255,.18);transform:translateY(-3px)}
.member .av{width:34px;position:relative}
.m-av-wrap{position:relative;flex:none}
.status{
  position:absolute;right:-2px;bottom:-2px;
  width:11px;height:11px;border-radius:50%;
  border:2.5px solid var(--blurple);
}
.status.on{background:#57F287}
.status.idle{background:#FEE75C}
.status.dnd{background:#ED4245}
.m-name{font-family:var(--font-display);font-weight:600;font-size:.9rem;line-height:1.15;color:#fff}
.m-tag{display:block;font-family:var(--font-body);font-weight:500;font-size:.72rem;color:rgba(255,255,255,.78)}
.member-more{
  background:rgba(0,0,0,.2);border:1.5px dashed rgba(255,255,255,.4);
  border-radius:14px;padding:.7rem .85rem;
  display:grid;place-items:center;
  font-family:var(--font-display);font-weight:600;font-size:.92rem;color:#fff;
}
.wall-note{font-size:.8rem;color:rgba(255,255,255,.72);text-align:center;margin:0}

/* ── visit ── */
.visit{
  display:grid;grid-template-columns:minmax(0,11fr) minmax(0,8fr);
  gap:clamp(2rem,5vw,5rem);align-items:center;
  padding:clamp(3.5rem,8vh,6rem) clamp(1rem,5vw,4.5rem);
  max-width:1360px;margin:0 auto;
}
.visit-photo{margin:0;transform:rotate(-1.3deg)}
.visit-photo img{
  border-radius:var(--radius);
  border:8px solid #fff;
  outline:2.5px solid var(--ink);
  box-shadow:var(--shadow-lift);
}
.visit-info h2{margin-bottom:.25em}
.visit-sub{color:var(--ink-soft);font-size:1.1rem;margin-bottom:1.6em}
.visit-details{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem 2rem;margin:0 0 1.8rem}
.visit-details dt{
  font-family:var(--font-display);font-weight:700;font-size:.8rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--red-deep);
  margin-bottom:.25rem;
}
.visit-details dd{margin:0;font-size:1.02rem;line-height:1.5}
.visit-details a{font-weight:600;text-decoration-color:var(--lime);text-decoration-thickness:2px}
.visit-ctas{display:flex;flex-wrap:wrap;gap:.9rem}

/* ── footer ── */
.site-foot{
  background:var(--ink);color:#fff;
  border-top:2.5px solid var(--ink);
  padding:clamp(2.5rem,5vh,4rem) clamp(1rem,5vw,4.5rem);
  display:grid;grid-template-columns:auto 1fr auto;
  gap:2.5rem;align-items:center;
}
.foot-brand{display:flex;align-items:center;gap:1.2rem}
.foot-brand img{width:72px;height:72px}
.foot-brand p{margin:0;font-size:.92rem;line-height:1.55;color:rgba(255,255,255,.8)}
.foot-brand strong{color:#fff;font-family:var(--font-display);font-size:1.05rem}
.foot-nav{display:flex;gap:1.1rem 1.4rem;justify-content:center;flex-wrap:wrap}
.foot-nav a{color:rgba(255,255,255,.85);text-decoration:none;font-weight:600;font-size:.9rem;white-space:nowrap}
.foot-nav a:hover{color:var(--lime)}
.foot-legal{margin:0;font-size:.82rem;color:rgba(255,255,255,.55);text-align:right;line-height:1.7}
.foot-demo{color:rgba(255,255,255,.35)}

/* ── reveal on scroll (JS-gated: hidden state only under html.js) ── */
html.js .reveal{opacity:0;translate:0 26px;transition:opacity .6s ease,translate .6s ease}
html.js .reveal.in{opacity:1;translate:0 0}

/* ── reduced motion ── */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
  html.js .reveal{opacity:1;translate:0 0}
}

/* ── responsive ── */
@media (max-width:1100px){
  .turn-track{grid-template-columns:repeat(4,1fr)}
  .turn-track::before{display:none}
  .lib-form{grid-template-columns:1fr;gap:1.4rem}
}
@media (max-width:920px){
  .head-nav{display:none}
  .hero{grid-template-columns:1fr;padding-top:2.5rem}
  .hero-art{margin-top:2.5rem;max-width:560px}
  .howto{grid-template-columns:1fr}
  .howto-photo{max-width:560px}
  .cafe{grid-template-columns:1fr}
  .discord-inner{grid-template-columns:1fr}
  .chat-card{justify-self:start;margin-right:0}
  .visit{grid-template-columns:1fr}
  .visit-photo{max-width:560px}
  .site-foot{grid-template-columns:1fr;text-align:left;gap:1.6rem}
  .foot-nav{justify-content:flex-start}
  .foot-legal{text-align:left}
}
@media (max-width:640px){
  .turn-track{grid-template-columns:repeat(2,1fr)}
  .turn{min-height:7rem}
  .spec-row{grid-template-columns:repeat(2,1fr)}
  .cafe-menu{grid-template-columns:1fr}
  .visit-details{grid-template-columns:1fr}
  .brand-word{display:none}
  .hero h1{font-size:clamp(2.9rem,13vw,4rem)}
  .hero-badge{bottom:-24px;left:-10px}
}
