@import url('../type/fonts.css');

/* ============ MAZAPÈ — poster / oversized-type system ============ */
:root{
  --ink:#101014;
  --paper:#f4f4f2;
  --lime:#c6ff2e;
  --grey:#d9d9d6;
  --spot:#ff4b2b;        /* riso vermilion — the ONE extra spot color, used sparingly */
  --line:4px;
  --wrap:90rem;
  --disp:'Big Shoulders Display',Impact,sans-serif;
  --body:'Karla',system-ui,Arial,sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.55;
  font-size:17px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
ul{list-style:none}

/* ---- push-content shell (mobile menu shifts page) ---- */
.mz-shell{transition:transform .34s cubic-bezier(.4,0,.1,1)}
body.mz-nav-open{overflow:hidden}
body.mz-nav-open .mz-shell{transform:translateX(-268px)}

.mz-wrap{max-width:var(--wrap);margin:0 auto;padding:0 clamp(1rem,4vw,4rem);width:100%}

/* labels */
.mz-kicker{
  font-family:var(--body);
  font-weight:700;
  font-size:.72rem;
  letter-spacing:.28em;
  text-transform:uppercase;
}
.mz-disp{
  font-family:var(--disp);
  font-weight:900;
  line-height:.86;
  letter-spacing:-.01em;
  text-transform:uppercase;
}

/* ============ HEADER ============ */
.mz-head{
  position:sticky;top:0;z-index:40;
  background:var(--paper);
  border-bottom:var(--line) solid var(--ink);
}
.mz-head-in{
  display:flex;align-items:center;justify-content:space-between;
  height:70px;
}
.mz-logo{
  font-family:var(--disp);font-weight:900;font-size:1.9rem;
  text-transform:uppercase;letter-spacing:-.02em;line-height:1;
  display:inline-flex;align-items:center;gap:8px;
}
.mz-logo b{
  background:var(--lime);color:var(--ink);
  padding:2px 9px 0;display:inline-block;
}
.mz-nav{display:flex;gap:34px;align-items:center}
.mz-nav a{
  font-weight:700;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;
  padding:4px 0;border-bottom:3px solid transparent;transition:border-color .15s;
}
.mz-nav a:hover,.mz-nav a[aria-current="page"]{border-color:var(--lime)}
.mz-cta-top{
  background:var(--ink);color:var(--paper)!important;padding:11px 20px 9px;
  border:3px solid var(--ink);letter-spacing:.12em!important;
}
.mz-cta-top:hover{background:var(--lime);color:var(--ink)!important;border-color:var(--ink)}

/* burger */
.mz-burger{
  display:none;width:52px;height:44px;background:var(--ink);border:0;
  position:relative;
}
.mz-burger span{
  position:absolute;left:13px;right:13px;height:3px;background:var(--lime);
  transition:transform .25s,opacity .2s;
}
.mz-burger span:nth-child(1){top:15px}
.mz-burger span:nth-child(2){top:21px}
.mz-burger span:nth-child(3){top:27px}
body.mz-nav-open .mz-burger span:nth-child(1){transform:translateY(6px) rotate(45deg)}
body.mz-nav-open .mz-burger span:nth-child(2){opacity:0}
body.mz-nav-open .mz-burger span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* drawer */
.mz-drawer{
  position:fixed;top:0;right:0;width:268px;height:100%;
  background:var(--ink);color:var(--paper);z-index:30;
  transform:translateX(268px);transition:transform .34s cubic-bezier(.4,0,.1,1);
  padding:92px 26px 30px;display:flex;flex-direction:column;gap:2px;
}
body.mz-nav-open .mz-drawer{transform:translateX(0)}
.mz-drawer a{
  font-family:var(--disp);font-weight:800;font-size:2rem;text-transform:uppercase;
  line-height:1;padding:12px 0;border-bottom:2px solid #2a2a30;
}
.mz-drawer a:hover{color:var(--lime)}

/* ============ HERO (type-dominant poster) ============ */
.mz-hero{border-bottom:var(--line) solid var(--ink);background:var(--paper);position:relative;overflow:hidden}
.mz-hero-in{
  padding:58px clamp(1rem,4vw,4rem) 40px;
  display:flex;flex-direction:column;
  min-height:min(88vh,780px);
}
.mz-hero-tag{color:#5a5a62;margin-bottom:22px}
.mz-hero-big{flex:1;display:flex;align-items:center;padding:18px 0}
.mz-hero-title{
  font-family:var(--disp);font-weight:900;text-transform:uppercase;
  font-size:clamp(3.4rem,15.5vw,10.6rem);line-height:.8;letter-spacing:-.02em;
  margin:0;
}
.mz-hero-title .pop{
  background:var(--lime);padding:0 .1em;
  box-decoration-break:clone;-webkit-box-decoration-break:clone;
}
.mz-hero-title .out{
  -webkit-text-stroke:2px var(--ink);color:transparent;
}
.mz-hero-foot{
  display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;
  gap:22px 34px;border-top:3px solid var(--ink);padding-top:26px;
}
.mz-hero-sub{font-size:1.12rem;max-width:46ch;font-weight:400}
.mz-hero-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.mz-hero-strip{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-top:26px}
.mz-hero-strip-lbl{
  font-family:var(--body);font-weight:700;font-size:.64rem;letter-spacing:.2em;
  text-transform:uppercase;color:#55555c;margin-right:6px;
}
.mz-hero-strip img{width:40px;height:40px;border:3px solid var(--ink);flex:0 0 auto}

/* buttons */
.mz-btn{
  font-family:var(--body);font-weight:700;font-size:.82rem;letter-spacing:.14em;
  text-transform:uppercase;padding:15px 26px;border:3px solid var(--ink);
  display:inline-flex;align-items:center;gap:9px;background:var(--ink);color:var(--paper);
  transition:background .15s,color .15s;
}
.mz-btn:hover{background:var(--lime);color:var(--ink)}
.mz-btn--lime{background:var(--lime);color:var(--ink)}
.mz-btn--lime:hover{background:var(--ink);color:var(--paper)}
.mz-btn--ghost{background:transparent;color:var(--ink)}
.mz-btn--ghost:hover{background:var(--ink);color:var(--paper)}

/* section frame */
.mz-sec{padding:74px 0;border-bottom:var(--line) solid var(--ink)}
.mz-sec--grey{background:var(--grey)}
.mz-sec--ink{background:var(--ink);color:var(--paper)}
.mz-sec--lime{background:var(--lime)}
.mz-sec-head{margin-bottom:44px}
.mz-sec-head .mz-kicker{display:inline-block;margin-bottom:14px}
.mz-sec-head h2{
  font-family:var(--disp);font-weight:900;text-transform:uppercase;
  font-size:clamp(2.6rem,8vw,5.4rem);line-height:.84;letter-spacing:-.01em;
}
.mz-sec-head p{max-width:52ch;margin-top:18px;font-size:1.05rem}
.mz-num-tag{
  font-family:var(--disp);font-weight:900;font-size:1rem;
  background:var(--lime);color:var(--ink);padding:3px 10px 1px;display:inline-block;
}

/* ============ GAMES POSTER GRID ============ */
.mz-games{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-left:3px solid var(--ink);border-top:3px solid var(--ink);
}
.mz-card{
  border-right:3px solid var(--ink);border-bottom:3px solid var(--ink);
  background:var(--paper);padding:24px 22px 22px;display:flex;flex-direction:column;
  position:relative;
}
.mz-card:nth-child(4n+2){background:var(--grey)}
.mz-card-top{display:flex;align-items:flex-start;gap:15px;margin-bottom:18px}
.mz-card-top img{
  width:66px;height:66px;border:3px solid var(--ink);flex:0 0 auto;
}
.mz-card-idx{
  font-family:var(--disp);font-weight:900;font-size:2.6rem;line-height:.8;
  margin-left:auto;color:var(--ink);opacity:.16;
}
.mz-card h3{
  font-family:var(--disp);font-weight:800;text-transform:uppercase;
  font-size:1.62rem;line-height:.92;margin-bottom:6px;
}
.mz-card-meta{
  font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;color:#55555c;
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:12px;
}
.mz-rate{
  background:var(--ink);color:var(--lime);padding:3px 8px 2px;
  font-weight:700;letter-spacing:.06em;
}
.mz-card-blurb{font-size:.95rem;margin-bottom:20px;flex:1}
.mz-card-link{
  font-family:var(--body);font-weight:700;font-size:.76rem;letter-spacing:.11em;
  text-transform:uppercase;border-top:3px solid var(--ink);padding-top:14px;
  display:flex;align-items:center;justify-content:space-between;gap:8px;
}
.mz-card-link:hover{color:var(--ink)}
.mz-card-link .arw{
  background:var(--lime);width:34px;height:34px;display:grid;place-items:center;
  font-size:1.1rem;transition:transform .15s;
}
.mz-card:hover .arw{transform:translate(3px,-3px)}
.mz-card:hover{background:var(--lime)}
.mz-card:hover .mz-card-idx{opacity:.28}

/* ============ TICKER / marquee ============ */
.mz-ticker{
  background:var(--lime);border-bottom:var(--line) solid var(--ink);
  overflow:hidden;padding:16px 0;
}
.mz-ticker-track{
  display:flex;gap:0;white-space:nowrap;width:max-content;
  animation:mz-slide 30s linear infinite;
}
.mz-ticker-track span{
  font-family:var(--disp);font-weight:900;text-transform:uppercase;
  font-size:1.9rem;letter-spacing:-.01em;padding:0 26px;display:inline-flex;align-items:center;gap:26px;
}
.mz-ticker-track span::after{content:'●';font-size:.8rem;color:var(--ink)}
@keyframes mz-slide{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.mz-ticker-track{animation:none}}

/* ============ STEPS ============ */
.mz-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:3px solid var(--paper)}
.mz-step{
  padding:30px 24px 34px;border-right:3px solid var(--paper);
}
.mz-steps .mz-step:last-child{border-right:0}
.mz-step .n{
  font-family:var(--disp);font-weight:900;font-size:4.6rem;line-height:.8;
  color:var(--lime);display:block;margin-bottom:14px;
}
.mz-step h3{font-family:var(--disp);font-weight:800;text-transform:uppercase;font-size:1.5rem;margin-bottom:10px;line-height:.95}
.mz-step p{font-size:.95rem;color:#c8c8cc}

/* ============ COMPARISON ============ */
.mz-cmp{border:3px solid var(--paper);overflow-x:auto}
.mz-cmp table{width:100%;border-collapse:collapse;min-width:560px}
.mz-cmp th,.mz-cmp td{border:3px solid var(--paper);padding:16px 18px;text-align:left;vertical-align:middle}
.mz-cmp thead th{background:var(--lime);color:var(--ink)}
.mz-cmp thead .lbl{background:var(--ink);color:var(--paper)}
.mz-cmp-game{display:flex;align-items:center;gap:12px}
.mz-cmp-game img{width:46px;height:46px;border:2px solid var(--paper)}
.mz-cmp-game span{font-family:var(--disp);font-weight:800;text-transform:uppercase;font-size:1.15rem;line-height:.95;color:var(--paper)}
.mz-cmp thead .mz-cmp-game span{color:var(--ink)}
.mz-cmp th.rowlbl{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#a9a9b0;font-weight:700;background:transparent}
.mz-cmp td{font-weight:600;color:var(--paper)}
.mz-cmp td b{color:var(--lime);font-weight:700}

/* ============ FAQ ============ */
.mz-faq{border-top:3px solid var(--ink)}
.mz-faq details{border-bottom:3px solid var(--ink)}
.mz-faq summary{
  list-style:none;cursor:pointer;padding:24px 60px 24px 0;position:relative;
  font-family:var(--disp);font-weight:800;text-transform:uppercase;font-size:clamp(1.3rem,4vw,2rem);
  line-height:.98;
}
.mz-faq summary::-webkit-details-marker{display:none}
.mz-faq summary::after{
  content:'+';position:absolute;right:0;top:50%;transform:translateY(-50%);
  font-family:var(--disp);font-weight:900;font-size:2.2rem;line-height:1;
  width:46px;height:46px;background:var(--lime);display:grid;place-items:center;
}
.mz-faq details[open] summary::after{content:'–'}
.mz-faq-a{padding:0 60px 26px 0;font-size:1.02rem;max-width:74ch}

/* ============ NEWSLETTER / FORM ============ */
.mz-news-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border:3px solid var(--ink)}
.mz-news-l{background:var(--ink);color:var(--paper);padding:44px 40px}
.mz-news-l h2{font-family:var(--disp);font-weight:900;text-transform:uppercase;font-size:clamp(2.2rem,6vw,3.6rem);line-height:.86;margin-bottom:18px}
.mz-news-l p{color:#c8c8cc;max-width:40ch;margin-bottom:24px}
.mz-news-l ul li{padding:9px 0 9px 26px;position:relative;font-weight:600;border-top:1px solid #2a2a30}
.mz-news-l ul li::before{content:'▸';position:absolute;left:0;color:var(--lime)}
.mz-news-r{background:var(--paper);padding:44px 40px}
.mz-field{margin-bottom:18px}
.mz-field label{display:block;font-weight:700;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:7px}
.mz-field input[type=text],.mz-field input[type=tel],.mz-field input[type=email]{
  width:100%;padding:14px 15px;border:3px solid var(--ink);background:var(--paper);
  font-family:var(--body);font-size:1rem;color:var(--ink);
}
.mz-field input:focus{outline:3px solid var(--lime);outline-offset:2px}
.mz-consent{display:flex;gap:11px;align-items:flex-start;font-size:.86rem;margin-bottom:20px}
.mz-consent input{margin-top:3px;width:20px;height:20px;flex:0 0 auto;accent-color:var(--ink)}
.mz-consent a{text-decoration:underline}
#successMsg{display:none;margin-top:16px;background:var(--lime);border:3px solid var(--ink);padding:14px 16px;font-weight:700}
#successMsg.show{display:block}

/* ============ ABOUT ============ */
.mz-about-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch}
.mz-about-txt{padding:60px 56px 60px 0}
.mz-about-txt h2{font-family:var(--disp);font-weight:900;text-transform:uppercase;font-size:clamp(2.4rem,7vw,4.6rem);line-height:.84;margin-bottom:22px}
.mz-about-txt p{margin-bottom:16px;font-size:1.05rem}
.mz-about-img{position:relative;border:3px solid var(--ink);overflow:hidden;min-height:340px;background:var(--ink)}
.mz-about-img img{width:100%;height:100%;object-fit:cover}
.mz-about-badge{position:absolute;left:0;bottom:0;background:var(--lime);color:var(--ink);padding:14px 20px;font-family:var(--disp);font-weight:900;text-transform:uppercase;font-size:1.4rem;border-top:3px solid var(--ink);border-right:3px solid var(--ink)}

/* ============ SPOTLIGHT ============ */
.mz-spot-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:0;border:4px solid var(--ink)}
.mz-spot-l{padding:46px 42px;background:var(--paper);display:flex;flex-direction:column;justify-content:center}
.mz-spot-flag{display:inline-block;align-self:flex-start;background:var(--ink);color:var(--lime);font-weight:700;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;padding:7px 13px 5px;margin-bottom:22px}
.mz-spot-l h2{font-family:var(--disp);font-weight:900;text-transform:uppercase;font-size:clamp(2.9rem,8.5vw,5.6rem);line-height:.82;letter-spacing:-.015em;margin:0}
.mz-spot-l h2 .pop{background:var(--lime);padding:0 .1em;box-decoration-break:clone;-webkit-box-decoration-break:clone}
.mz-spot-sub{font-size:1.05rem;max-width:44ch;margin:20px 0 0}
.mz-spot-meta{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin:24px 0 26px;border-top:3px solid var(--ink);padding-top:20px}
.mz-spot-rate{font-family:var(--disp);font-weight:900;font-size:2.9rem;line-height:.8;color:var(--ink)}
.mz-spot-metatxt{font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;color:#55555c;line-height:1.5}
.mz-spot-metatxt b{color:var(--ink)}
.mz-spot-r{position:relative;background:var(--ink);border-left:4px solid var(--ink);overflow:hidden;min-height:360px}
.mz-spot-r img.bg{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;filter:contrast(1.05) saturate(1.05)}
.mz-spot-icon{position:absolute;left:26px;bottom:26px;width:96px;height:96px;border:4px solid var(--ink);z-index:2}
.mz-spot-tagbig{position:absolute;right:0;top:0;background:var(--lime);color:var(--ink);font-family:var(--disp);font-weight:900;text-transform:uppercase;font-size:1.3rem;line-height:1;padding:9px 16px 6px;border-left:4px solid var(--ink);border-bottom:4px solid var(--ink);z-index:2}
@media(max-width:1000px){.mz-spot-grid{grid-template-columns:1fr}.mz-spot-r{min-height:300px;border-left:0;border-top:4px solid var(--ink);order:2}.mz-spot-l{order:1}}
@media(max-width:640px){.mz-spot-l{padding:32px 22px}.mz-spot-icon{width:78px;height:78px;left:18px;bottom:18px}}

/* pop highlight for section headings */
.mz-sec-head h2 .pop{
  background:var(--lime);color:var(--ink);padding:0 .08em;
  box-decoration-break:clone;-webkit-box-decoration-break:clone;
}

/* ============ CLASSIFICA (trending chart) ============ */
.mz-chart{border-top:3px solid var(--lime)}
.mz-chart-row{
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;
  gap:14px 22px;padding:22px 6px;border-bottom:3px solid #2a2a30;
}
.mz-chart-rank{
  font-family:var(--disp);font-weight:900;font-size:clamp(2.9rem,8.5vw,6rem);
  line-height:.7;color:var(--lime);letter-spacing:-.02em;flex:0 0 auto;
}
.mz-chart-row:not(.is-top) .mz-chart-rank{
  color:transparent;-webkit-text-stroke:2px var(--lime);
}
.mz-chart-main{display:flex;align-items:center;gap:16px;min-width:0}
.mz-chart-ico{width:60px;height:60px;border:3px solid var(--lime);flex:0 0 auto}
.mz-chart-txt{min-width:0}
.mz-chart-name{
  font-family:var(--disp);font-weight:800;text-transform:uppercase;
  font-size:clamp(1.3rem,3.6vw,2.1rem);line-height:.9;color:var(--paper);
  display:inline-block;overflow-wrap:anywhere;transition:color .15s;
}
.mz-chart-name:hover{color:var(--lime)}
.mz-chart-sub{
  font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;
  color:#9a9aa2;margin-top:8px;display:flex;gap:6px 14px;flex-wrap:wrap;align-items:center;
}
.mz-chart-sub b{color:var(--lime)}
.mz-chart-trend{
  font-family:var(--disp);font-weight:900;text-transform:uppercase;line-height:1;
  font-size:1.05rem;color:var(--ink);background:var(--lime);border:3px solid var(--lime);
  padding:9px 12px 7px;display:inline-flex;align-items:center;gap:7px;flex:0 0 auto;
}
.mz-chart-trend .ar{font-size:1.15rem;line-height:.8}
.mz-chart-trend.is-flat{background:transparent;color:var(--lime)}
.mz-chart-trend.is-new{background:var(--ink);color:var(--lime)}

/* ============ QUANTO TEMPO (pick by time) ============ */
.mz-tempo{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-left:3px solid var(--ink);border-top:3px solid var(--ink);
}
.mz-tempo-col{
  border-right:3px solid var(--ink);border-bottom:3px solid var(--ink);
  padding:30px 26px 26px;display:flex;flex-direction:column;background:var(--paper);
}
.mz-tempo-col.is-pop{background:var(--lime)}
.mz-tempo-lbl{font-weight:700;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:#55555c;margin-bottom:10px}
.mz-tempo-col.is-pop .mz-tempo-lbl{color:var(--ink)}
.mz-tempo-time{
  font-family:var(--disp);font-weight:900;text-transform:uppercase;
  font-size:clamp(3.6rem,6.5vw,5.4rem);line-height:.76;letter-spacing:-.02em;margin-bottom:8px;
}
.mz-tempo-time small{font-size:.3em;font-weight:800;letter-spacing:.02em;margin-left:.06em}
.mz-tempo-tag{font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}
.mz-tempo-pick{
  display:flex;gap:14px;align-items:flex-start;
  border-top:3px solid var(--ink);padding-top:16px;margin-top:18px;
}
.mz-tempo-pick img{width:50px;height:50px;border:3px solid var(--ink);flex:0 0 auto}
.mz-tempo-pick-b{min-width:0}
.mz-tempo-pick h4{font-family:var(--disp);font-weight:800;text-transform:uppercase;font-size:1.2rem;line-height:.95;margin-bottom:5px;overflow-wrap:anywhere}
.mz-tempo-pick p{font-size:.86rem;line-height:1.42}
.mz-tempo-pick .go{display:inline-block;margin-top:8px;font-weight:700;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;border-bottom:2px solid currentColor;padding-bottom:1px}
.mz-tempo-pick .go:hover{color:#55555c}
.mz-tempo-col.is-pop .mz-tempo-pick .go:hover{color:#3a3a1a}
@media(max-width:760px){
  .mz-tempo{grid-template-columns:1fr}
}
@media(max-width:560px){
  .mz-chart-row{gap:12px 16px;padding:18px 2px}
  .mz-chart-ico{width:50px;height:50px}
  .mz-chart-trend{font-size:.86rem;padding:7px 9px 5px;gap:5px}
}

/* generic page hero */
.mz-page-hero{background:var(--ink);color:var(--paper);padding:66px 0 58px;border-bottom:var(--line) solid var(--ink)}
.mz-page-hero .mz-kicker{color:var(--lime)}
.mz-page-hero h1{font-family:var(--disp);font-weight:900;text-transform:uppercase;font-size:clamp(3rem,10vw,7rem);line-height:.82;letter-spacing:-.01em;margin-top:14px}
.mz-page-hero p{max-width:56ch;margin-top:20px;color:#c8c8cc;font-size:1.1rem}

/* prose (legal) */
.mz-prose{max-width:820px}
.mz-prose h2{font-family:var(--disp);font-weight:800;text-transform:uppercase;font-size:2rem;line-height:.95;margin:38px 0 12px;padding-top:20px;border-top:3px solid var(--ink)}
.mz-prose h3{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:1.3rem;margin:22px 0 8px}
.mz-prose p{margin-bottom:14px}
.mz-prose ul{margin:0 0 16px 0}
.mz-prose ul li{padding:6px 0 6px 24px;position:relative}
.mz-prose ul li::before{content:'▸';position:absolute;left:0;color:var(--ink)}
.mz-prose a{text-decoration:underline;font-weight:600}
.mz-prose .mz-nap{border:3px solid var(--ink);background:var(--grey);padding:20px 22px;margin:20px 0}
.mz-prose .mz-nap b{font-family:var(--disp);font-weight:800;font-size:1.2rem;text-transform:uppercase}

/* contact cards */
.mz-contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:20px}
.mz-contact-card{border:3px solid var(--ink);padding:26px 24px;background:var(--paper)}
.mz-contact-card:nth-child(2){background:var(--lime)}
.mz-contact-card .mz-kicker{color:#55555c;margin-bottom:12px;display:block}
.mz-contact-card:nth-child(2) .mz-kicker{color:var(--ink)}
.mz-contact-card p{font-family:var(--disp);font-weight:800;text-transform:uppercase;font-size:1.5rem;line-height:.98;word-break:break-word}
.mz-contact-card a{font-weight:700}
.mz-contact-card small{display:block;font-family:var(--body);font-weight:400;text-transform:none;font-size:.9rem;margin-top:8px;letter-spacing:0}

/* 404 */
.mz-404{min-height:64vh;display:grid;place-items:center;text-align:center;padding:60px 0}
.mz-404 .big{font-family:var(--disp);font-weight:900;font-size:clamp(6rem,26vw,17rem);line-height:.8;color:var(--ink)}
.mz-404 .big span{color:var(--lime);-webkit-text-stroke:3px var(--ink)}
.mz-404 h1{font-family:var(--disp);font-weight:800;text-transform:uppercase;font-size:clamp(1.6rem,6vw,3rem);margin:10px 0 18px}

/* ============ FOOTER ============ */
.mz-foot{background:var(--ink);color:var(--paper);padding:64px 0 30px}
.mz-foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:34px}
.mz-foot-brand .mz-logo{color:var(--paper);margin-bottom:16px}
.mz-foot-brand p{color:#9a9aa2;max-width:34ch;font-size:.95rem;margin-bottom:16px}
.mz-foot-nap{font-size:.9rem;color:#c8c8cc;line-height:1.75}
.mz-foot-nap a{color:var(--lime)}
.mz-foot h4{font-family:var(--disp);font-weight:800;text-transform:uppercase;font-size:1.1rem;letter-spacing:.06em;margin-bottom:14px;color:var(--lime)}
.mz-foot ul li{margin-bottom:9px}
.mz-foot ul a{color:#c8c8cc;font-size:.92rem}
.mz-foot ul a:hover{color:var(--paper)}
.mz-foot-bot{border-top:2px solid #2a2a30;margin-top:44px;padding-top:22px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;color:#7a7a82;font-size:.8rem;letter-spacing:.04em}

/* ============ COOKIE BANNER ============ */
.mz-cookie{
  position:fixed;left:20px;right:20px;bottom:20px;z-index:50;
  background:var(--ink);color:var(--paper);border:3px solid var(--lime);
  padding:14px 18px;max-width:640px;
  display:none;
}
.mz-cookie.show{display:block}
.mz-cookie h4{font-family:var(--disp);font-weight:900;text-transform:uppercase;font-size:1.02rem;margin-bottom:4px;color:var(--lime)}
.mz-cookie p{font-size:.85rem;color:#c8c8cc;margin-bottom:10px}
.mz-cookie p a{color:var(--lime);text-decoration:underline}
.mz-cookie-btns{display:flex;gap:12px;flex-wrap:wrap}
.mz-cookie-btns button{
  font-family:var(--body);font-weight:700;font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;
  padding:12px 20px;border:3px solid var(--lime);
}
.mz-c-acc{background:var(--lime);color:var(--ink)}
.mz-c-dec{background:transparent;color:var(--lime)}
.mz-c-acc:hover{background:transparent;color:var(--lime)}
.mz-c-dec:hover{background:var(--lime);color:var(--ink)}

/* skip link */
.mz-skip{position:absolute;left:-999px;top:0;background:var(--lime);color:var(--ink);padding:10px 16px;font-weight:700;z-index:99}
.mz-skip:focus{left:8px;top:8px}

/* ============ RESPONSIVE ============ */
/* games poster grid: 3-up desktop, 2-up tablet, 1-up mobile */
@media (max-width:1199px){
  .mz-games{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:700px){
  .mz-games{grid-template-columns:1fr}
}
@media (max-width:1000px){
  .mz-hero-in{min-height:auto;padding:48px clamp(1rem,4vw,4rem) 36px}
  .mz-steps{grid-template-columns:repeat(2,1fr)}
  .mz-steps .mz-step{border-right:3px solid var(--paper)}
  .mz-steps .mz-step:nth-child(2n){border-right:0}
  .mz-news-grid,.mz-about-grid{grid-template-columns:1fr}
  .mz-about-txt{padding:48px 0}
  .mz-about-img{min-height:300px}
  .mz-contact-grid{grid-template-columns:1fr}
  .mz-foot-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  body{font-size:16px}
  .mz-nav{display:none}
  .mz-cta-top{display:none}
  .mz-burger{display:block}
  .mz-steps{grid-template-columns:1fr}
  .mz-steps .mz-step{border-right:0}
  .mz-news-l,.mz-news-r{padding:32px 22px}
  .mz-sec{padding:52px 0}
  .mz-wrap{padding:0 18px}
  .mz-hero-strip img{width:34px;height:34px}
  .mz-foot-grid{grid-template-columns:1fr}
  .mz-faq summary{padding-right:52px}
  .mz-faq summary::after{width:38px;height:38px;font-size:1.7rem}
  .mz-cookie{left:12px;right:12px;bottom:12px}
}
@media (max-width:360px){
  .mz-hero-title{font-size:clamp(2.7rem,14vw,3.4rem)}
  .mz-hero-strip-lbl{width:100%;margin-bottom:2px}
  .mz-logo{font-size:1.6rem}
  .mz-btn{padding:13px 18px;font-size:.76rem}
}

/* ==========================================================================
   ZINE ART-DIRECTION LAYER — "Mazapè, la zine dei giochi di Milano"
   CONCEPT: a Milanese silkscreen / risograph games-poster ZINE — a printed
   object, not a web template.
   CONSTITUTION:
   - Two grounds: paper #f4f4f2 + ink #101014. One electric: lime #c6ff2e.
     ONE spot only: riso vermilion --spot, reserved for print marks & one sticker.
   - Type: Big Shoulders Display huge as the graphic; Karla in tracked caps is
     the "caption/mono" voice for folios and meta.
   - Material: riso grain + halftone dot fields; hard-cut edges; offset hard
     shadows; visible registration crosshairs. No soft shadows, no gradients.
   - Structure: every section is a numbered plate (N.0X), carried by a masthead
     folio, ghost display numerals bleeding off-crop, hand-cut rotated stickers,
     asymmetric heads. SIGNATURE: the ✛ registration mark + N.0X folio, repeated.
   ========================================================================== */

/* --- riso grain (fixed film over the whole zine) --- */
.mz-grain{
  position:fixed;inset:0;width:100%;height:100%;
  opacity:.05;mix-blend-mode:multiply;pointer-events:none;z-index:3;
}

/* --- masthead folio (full-bleed ink rule under the header) --- */
.mz-folio{
  background:var(--ink);color:var(--paper);
  border-bottom:var(--line) solid var(--ink);
  display:flex;justify-content:space-between;align-items:center;gap:14px;
  flex-wrap:wrap;
  padding:8px clamp(1rem,4vw,4rem) 7px;
  font-family:var(--body);font-weight:700;font-size:.6rem;letter-spacing:.26em;
  text-transform:uppercase;
}
.mz-folio span{white-space:nowrap;display:inline-flex;align-items:center;gap:8px}
.mz-folio span::before{content:"✛";color:var(--spot);font-size:.8em}
.mz-folio b{color:var(--lime);font-weight:800}

/* --- registration crosshair (signature print mark) --- */
.mz-reg{position:absolute;width:22px;height:22px;pointer-events:none;z-index:4;color:var(--spot)}
.mz-reg::before,.mz-reg::after{content:"";position:absolute;background:currentColor}
.mz-reg::before{left:50%;top:0;width:2px;height:100%;transform:translateX(-50%)}
.mz-reg::after{top:50%;left:0;height:2px;width:100%;transform:translateY(-50%)}
.mz-reg--tl{left:14px;top:14px}
.mz-reg--tr{right:14px;top:14px}
.mz-reg--bl{left:14px;bottom:14px}
.mz-reg--br{right:14px;bottom:14px}

/* --- hand-cut rotated sticker --- */
.mz-sticker{
  display:inline-block;font-family:var(--disp);font-weight:900;text-transform:uppercase;
  background:var(--lime);color:var(--ink);border:3px solid var(--ink);
  padding:9px 14px 6px;line-height:.86;letter-spacing:.01em;text-align:center;
  transform:rotate(-6deg);box-shadow:5px 5px 0 var(--ink);
}
.mz-sticker small{display:block;font-size:.5em;letter-spacing:.14em;margin-top:2px;font-weight:800}
.mz-sticker--spot{background:var(--spot);color:var(--paper)}

/* --- numbered section plates + folio head + ghost numeral --- */
#main{counter-reset:mzsec}
.mz-sec{counter-increment:mzsec;overflow:hidden}
.mz-sec-head{position:relative;padding-top:22px;margin-top:-4px}
.mz-sec-head>*{position:relative;z-index:1}
/* plate rule across the top of every head — a printed zine divider */
.mz-sec-head::before{
  content:"";position:absolute;left:0;right:0;top:0;height:3px;z-index:1;
  background:var(--ink);
}
.mz-sec--ink .mz-sec-head::before,.mz-sec--ink .mz-sec-head .mz-kicker::before{color:var(--spot)}
.mz-sec--ink .mz-sec-head::before{background:var(--lime)}
/* folio prefix on the kicker: ✛ N.0X */
.mz-sec-head .mz-kicker{padding-top:2px}
.mz-sec-head .mz-kicker::before{
  content:"✛ N." counter(mzsec,decimal-leading-zero) "  \00b7  ";
  color:var(--spot);font-weight:800;
}
/* ghost display numeral, cropped top-right like a print bleed */
.mz-sec-head::after{
  content:counter(mzsec,decimal-leading-zero);
  position:absolute;right:0;top:-.28em;z-index:0;
  font-family:var(--disp);font-weight:900;line-height:.7;letter-spacing:-.05em;
  font-size:clamp(5rem,13vw,12.5rem);
  color:transparent;-webkit-text-stroke:2px rgba(16,16,20,.11);
  pointer-events:none;
}
.mz-sec--ink .mz-sec-head::after{-webkit-text-stroke-color:rgba(198,255,46,.16)}
.mz-sec--lime .mz-sec-head::after{-webkit-text-stroke-color:rgba(16,16,20,.16)}

/* --- riso halftone dot fields on the flat color plates --- */
.mz-sec--ink,.mz-sec--lime{position:relative}
.mz-sec--ink::before,.mz-sec--lime::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background-size:9px 9px;
}
.mz-sec--ink::before{background-image:radial-gradient(rgba(198,255,46,.10) 1.1px,transparent 1.4px)}
.mz-sec--lime::before{background-image:radial-gradient(rgba(16,16,20,.12) 1.1px,transparent 1.4px)}
.mz-sec--ink>.mz-wrap,.mz-sec--lime>.mz-wrap{position:relative;z-index:1}

/* ============ HERO as a PRINTED POSTER ============ */
/* halftone dust across the poster */
.mz-hero::before{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:radial-gradient(rgba(16,16,20,.09) 1.1px,transparent 1.5px);
  background-size:10px 10px;
}
.mz-hero-in{position:relative;z-index:1}
.mz-hero-tag::before{content:"✛ ";color:var(--spot);font-weight:800}

/* headline + integrated poster-art collage, asymmetric & type-dominant */
.mz-hero-big{
  flex:1;display:grid;align-items:center;
  grid-template-columns:minmax(0,1.18fr) minmax(0,.82fr);
  gap:clamp(1.4rem,4vw,3.4rem);padding:14px 0;
}
.mz-hero-title{position:relative;z-index:2}
.mz-hero-art{
  position:relative;align-self:stretch;min-height:0;
  display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:center;
}
.mz-hero-poster{
  border:4px solid var(--ink);overflow:hidden;background:var(--ink);
  aspect-ratio:392/560;box-shadow:7px 7px 0 var(--ink);
}
.mz-hero-poster img{width:100%;height:100%;object-fit:cover;display:block}
.mz-hero-poster.a{align-self:start;transform:rotate(-1.6deg)}
.mz-hero-poster.b{align-self:end;transform:rotate(1.8deg)}
.mz-hero-arttag{
  position:absolute;left:2%;top:6%;z-index:5;
  font-family:var(--disp);font-weight:900;text-transform:uppercase;line-height:.9;
  font-size:clamp(.9rem,1.2vw,1.15rem);letter-spacing:.02em;
  background:var(--spot);color:var(--paper);border:3px solid var(--ink);
  padding:8px 12px 6px;transform:rotate(-7deg);box-shadow:4px 4px 0 var(--ink);
}
.mz-hero-articon{
  position:absolute;right:3%;bottom:5%;z-index:5;
  width:78px;height:78px;border:4px solid var(--ink);box-shadow:4px 4px 0 var(--ink);
}
.mz-hero-sticker{position:absolute;right:clamp(1rem,4vw,4rem);top:24px;z-index:3}

@media (max-width:900px){
  .mz-hero-big{grid-template-columns:1fr;gap:26px;padding:8px 0 4px}
  .mz-hero-poster{aspect-ratio:392/470}
  .mz-hero-poster.a,.mz-hero-poster.b{transform:none;box-shadow:5px 5px 0 var(--ink)}
  .mz-hero-articon{width:60px;height:60px}
  .mz-hero-sticker{top:14px;transform:rotate(-6deg) scale(.85)}
}
@media (max-width:520px){
  .mz-hero-poster{aspect-ratio:3/4}
  .mz-hero-arttag{font-size:.78rem;padding:6px 9px 4px}
  .mz-hero-articon{width:50px;height:50px;border-width:3px}
  .mz-hero-sticker{display:none}
  .mz-sec-head::after{font-size:clamp(4rem,20vw,7rem)}
}

/* card poster detail: a spot registration tick on the index corner */
.mz-card{overflow:hidden}
.mz-card-idx{position:relative}
.mz-card:hover{box-shadow:inset 0 0 0 3px var(--ink)}

/* FAQ set as a narrower editorial column with a rule, not a full band */
#faq .mz-faq{max-width:none}

/* reduce grain shimmer for reduced-motion users (already static, keep crisp) */
@media (prefers-reduced-motion:reduce){.mz-grain{opacity:.04}}
