@import url('https://fonts.googleapis.com/css2?family=Archivo+Black&family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root{
  --cream:#EFE9D9;
  --cream-2:#E4DCC4;
  --green:#1F8A4C;
  --pink:#F06CA8;
  --orange:#E85A1F;
  --yellow:#F5C518;
  --ink:#0F0F0F;
  --ink-soft:#2a2a2a;
  --muted:#5a5a55;
  --border:#0F0F0F;
  --shadow-sm:4px 4px 0 var(--ink);
  --shadow-md:8px 8px 0 var(--ink);
  --shadow-lg:12px 12px 0 var(--ink);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Space Grotesk",system-ui,sans-serif;
  background:var(--cream);
  color:var(--ink);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  background-image:
    radial-gradient(circle at 20% 10%,rgba(240,108,168,.06),transparent 40%),
    radial-gradient(circle at 80% 70%,rgba(31,138,76,.06),transparent 40%);
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

.container{max-width:1280px;margin:0 auto;padding:0 28px}

/* Display type */
h1,h2,h3,h4,.brand-text,.hs-num,.fav-country,.host-name,.prev-title,.prev-id,.mi-match,.foot-brand h3{
  font-family:"Archivo Black","Arial Black",sans-serif;
  font-weight:900;
  letter-spacing:-.01em;
}

/* Mono */
.hero-eyebrow,.section-kicker,.hc-tag,.hc-group,.mi-top,.mi-group,.fav-group,.fav-rank,.prev-group,.pc-rank,.host-meta,.guide-num,.foot-block h4,.hs-lab,.gc-note,.hc-meta,.legal-num{
  font-family:"JetBrains Mono",monospace;
}

/* HEADER */
.site-header{
  position:sticky;top:0;z-index:50;
  background:var(--cream);
  border-bottom:3px solid var(--ink);
}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;padding:18px 28px;gap:24px;position:relative}
.brand{display:flex;align-items:center;gap:12px;color:var(--ink)}
.brand-mark{
  background:var(--green);color:var(--cream);
  width:42px;height:42px;
  display:grid;place-items:center;
  font-family:"Archivo Black",sans-serif;
  font-size:.95rem;
  border:2.5px solid var(--ink);
  box-shadow:3px 3px 0 var(--ink);
  clip-path:none;
  flex-shrink:0;
}
.brand-text{font-size:1.1rem;letter-spacing:-.5px}
.brand-dot{color:var(--pink)}
.main-nav{display:flex;gap:6px;flex-wrap:wrap}
.main-nav a{
  color:var(--ink);
  font-size:.78rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:1px;
  padding:8px 12px;
  font-family:"JetBrains Mono",monospace;
  border:2px solid transparent;
  transition:all .15s ease;
}
.main-nav a:hover{
  background:var(--ink);
  color:var(--yellow);
  border-color:var(--ink);
}
.menu-toggle{display:none;background:none;border:2px solid var(--ink);padding:8px;cursor:pointer;flex-direction:column;gap:4px}
.menu-toggle span{width:22px;height:3px;background:var(--ink);display:block}

/* HERO */
.hero{
  background:var(--cream);
  color:var(--ink);
  padding:80px 0 100px;
  position:relative;
  overflow:hidden;
  border-bottom:3px solid var(--ink);
}
.hero::before{
  content:"";position:absolute;
  width:340px;height:340px;
  background:var(--pink);
  border:3px solid var(--ink);
  border-radius:50%;
  top:-120px;right:-80px;
  z-index:0;
}
.hero::after{
  content:"";position:absolute;
  width:180px;height:180px;
  background:var(--yellow);
  border:3px solid var(--ink);
  bottom:-60px;left:30%;
  transform:rotate(15deg);
  z-index:0;
}
.hero-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:60px;align-items:center;position:relative;z-index:1}
.hero-eyebrow{
  display:inline-block;
  font-size:.75rem;
  letter-spacing:2px;
  font-weight:700;
  color:var(--ink);
  text-transform:uppercase;
  margin-bottom:24px;
  padding:8px 14px;
  background:var(--yellow);
  border:2.5px solid var(--ink);
  box-shadow:3px 3px 0 var(--ink);
}
.hero h1{
  font-size:clamp(2.4rem,5.2vw,4.2rem);
  line-height:.98;
  letter-spacing:-.02em;
  margin-bottom:24px;
  text-transform:uppercase;
}
.hl{
  color:var(--ink);
  background:var(--green);
  -webkit-background-clip:initial;
  background-clip:initial;
  display:inline-block;
  padding:0 12px;
  color:var(--cream);
  box-shadow:6px 6px 0 var(--pink);
  margin-top:8px;
}
.hero-lead{
  font-size:1.1rem;
  color:var(--ink-soft);
  max-width:560px;
  margin-bottom:36px;
  font-weight:500;
}
.hero-ctas{display:flex;gap:14px;margin-bottom:48px;flex-wrap:wrap}
.btn{
  display:inline-block;
  padding:16px 28px;
  font-family:"Archivo Black",sans-serif;
  font-size:.85rem;
  letter-spacing:1px;
  text-transform:uppercase;
  border:2.5px solid var(--ink);
  cursor:pointer;
  transition:transform .12s ease,box-shadow .12s ease;
  clip-path:none;
  box-shadow:5px 5px 0 var(--ink);
}
.btn-primary{background:var(--green);color:var(--cream)}
.btn-primary:hover{transform:translate(-2px,-2px);box-shadow:7px 7px 0 var(--ink)}
.btn-ghost{background:var(--pink);color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{transform:translate(-2px,-2px);box-shadow:7px 7px 0 var(--ink);background:var(--orange);color:var(--cream)}

.hero-stats{display:flex;gap:16px;flex-wrap:wrap}
.hs-tile{
  background:var(--cream-2);
  border:2.5px solid var(--ink);
  box-shadow:4px 4px 0 var(--ink);
  padding:16px 22px;
  min-width:130px;
}
.hs-tile:nth-child(1){background:var(--cream-2)}
.hs-tile:nth-child(2){background:var(--orange);color:var(--cream)}
.hs-tile:nth-child(3){background:var(--green);color:var(--cream)}
.hs-num{font-size:2.2rem;display:block;line-height:1}
.hs-lab{font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;margin-top:6px;display:block;font-weight:600}

.hero-card{
  background:var(--cream);
  border:3px solid var(--ink);
  padding:28px;
  position:relative;
  box-shadow:10px 10px 0 var(--green);
  clip-path:none;
}
.hc-head{display:flex;justify-content:space-between;font-size:.72rem;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:22px;font-weight:700;flex-wrap:wrap;gap:8px}
.hc-tag{color:var(--ink);background:var(--yellow);padding:4px 10px;border:2px solid var(--ink)}
.hc-group{color:var(--cream);background:var(--ink);padding:4px 10px}
.hc-vs{display:grid;grid-template-columns:1fr auto 1fr;gap:14px;align-items:center;margin-bottom:22px}
.hc-team{text-align:center;display:flex;flex-direction:column;gap:6px;min-width:0}
.hc-team strong{font-size:1.05rem;color:var(--ink);font-family:"Archivo Black",sans-serif;word-break:break-word}
.hc-team small{font-size:.72rem;color:var(--muted);font-family:"JetBrains Mono",monospace}
.hc-flag{font-size:2rem}
.hc-divider{
  font-family:"Archivo Black",sans-serif;
  color:var(--cream);
  background:var(--orange);
  border:2px solid var(--ink);
  padding:6px 10px;
  font-size:.95rem;
}
.hc-bar{height:14px;background:var(--cream-2);border:2px solid var(--ink);overflow:hidden;margin-bottom:12px}
.hc-fill{height:100%;background:var(--green)}
.hc-meta{font-size:.78rem;color:var(--muted);text-align:center}

/* LEGAL HERO */
.legal-hero{padding:70px 0 80px}
.legal-hero h1{font-size:clamp(2.2rem,4.8vw,3.6rem);margin-bottom:22px}
.legal-hero .hero-lead{max-width:780px;margin-bottom:0}

/* LEGAL CONTENT */
.legal-wrap{
  display:flex;
  flex-direction:column;
  gap:28px;
  max-width:920px;
}
.legal-block{
  background:var(--cream);
  border:2.5px solid var(--ink);
  box-shadow:6px 6px 0 var(--ink);
  padding:32px;
  position:relative;
}
.legal-block:nth-child(4n+1){box-shadow:6px 6px 0 var(--green)}
.legal-block:nth-child(4n+2){box-shadow:6px 6px 0 var(--pink)}
.legal-block:nth-child(4n+3){box-shadow:6px 6px 0 var(--orange)}
.legal-block:nth-child(4n+4){box-shadow:6px 6px 0 var(--yellow)}
.legal-num{
  display:inline-block;
  font-size:.78rem;
  font-weight:700;
  color:var(--ink);
  background:var(--yellow);
  padding:5px 12px;
  border:2px solid var(--ink);
  letter-spacing:2px;
  margin-bottom:16px;
}
.legal-block:nth-child(4n+2) .legal-num{background:var(--pink)}
.legal-block:nth-child(4n+3) .legal-num{background:var(--orange);color:var(--cream)}
.legal-block:nth-child(4n+4) .legal-num{background:var(--green);color:var(--cream)}
.legal-block h2{
  font-size:1.4rem;
  text-transform:uppercase;
  letter-spacing:-.3px;
  line-height:1.15;
  margin-bottom:14px;
}
.legal-sub{
  font-family:"Archivo Black",sans-serif;
  font-size:1.02rem;
  text-transform:uppercase;
  letter-spacing:-.2px;
  margin-top:18px;
  margin-bottom:8px;
  color:var(--ink);
}
.legal-block p{
  color:var(--ink-soft);
  font-size:.96rem;
  line-height:1.7;
  font-weight:500;
  margin-bottom:12px;
}
.legal-block p:last-child{margin-bottom:0}
.legal-block a{
  color:var(--ink);
  font-weight:700;
  border-bottom:2px solid var(--green);
}
.legal-block a:hover{background:var(--yellow)}
.legal-list{
  list-style:none;
  margin:6px 0 14px;
  padding:0;
}
.legal-list li{
  position:relative;
  padding:8px 0 8px 24px;
  color:var(--ink-soft);
  font-size:.94rem;
  line-height:1.6;
  border-bottom:1.5px dashed var(--ink);
  font-weight:500;
}
.legal-list li:last-child{border-bottom:0}
.legal-list li::before{
  content:"▸";
  position:absolute;
  left:4px;
  top:8px;
  color:var(--green);
  font-weight:700;
}
.legal-list strong{color:var(--ink);font-weight:700}

/* SECTIONS */
.section{padding:90px 0;position:relative}
.section-light{background:var(--cream);border-bottom:3px solid var(--ink)}
.section-dark{background:var(--ink);color:var(--cream);border-bottom:3px solid var(--ink)}
.section-mid{background:var(--cream-2);color:var(--ink);border-bottom:3px solid var(--ink)}

.section-head{margin-bottom:56px;max-width:820px}
.section-head.light{color:var(--cream)}
.section-kicker{
  display:inline-block;
  font-size:.72rem;
  letter-spacing:2.5px;
  font-weight:700;
  text-transform:uppercase;
  color:var(--ink);
  margin-bottom:18px;
  padding:6px 12px;
  background:var(--yellow);
  border:2px solid var(--ink);
  box-shadow:3px 3px 0 var(--ink);
}
.accent-orange{background:var(--orange);color:var(--cream)}
.accent-cyan{background:var(--pink);color:var(--ink)}
.accent-green{background:var(--green);color:var(--cream)}
.section-head h2{
  font-size:clamp(2rem,3.6vw,3rem);
  letter-spacing:-.02em;
  margin-bottom:18px;
  line-height:1.02;
  text-transform:uppercase;
}
.section-head p{color:var(--ink-soft);font-size:1.05rem;max-width:680px;font-weight:500}
.section-head.light p{color:var(--cream-2)}

/* MATCH INDEX */
.match-index{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(290px,1fr));
  gap:22px;
}
.mi-card{
  background:var(--cream);
  border:2.5px solid var(--ink);
  box-shadow:6px 6px 0 var(--ink);
  padding:22px;
  position:relative;
  display:flex;
  flex-direction:column;
  gap:14px;
  transition:transform .15s ease,box-shadow .15s ease;
  cursor:pointer;
}
.mi-card:nth-child(4n+1){border-top:8px solid var(--green)}
.mi-card:nth-child(4n+2){border-top:8px solid var(--pink)}
.mi-card:nth-child(4n+3){border-top:8px solid var(--orange)}
.mi-card:nth-child(4n+4){border-top:8px solid var(--yellow)}
.mi-card:hover{
  transform:translate(-3px,-3px);
  box-shadow:9px 9px 0 var(--ink);
}
.mi-top{display:flex;justify-content:space-between;align-items:center;font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--muted);font-weight:600;flex-wrap:wrap;gap:6px}
.mi-group{background:var(--ink);color:var(--yellow);padding:4px 10px;font-weight:700;letter-spacing:1px}
.mi-match{font-size:1.25rem;line-height:1.15;text-transform:uppercase;word-break:break-word}
.mi-teams{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.mi-team{display:flex;flex-direction:column;gap:3px;font-size:.85rem;min-width:0}
.mi-team strong{font-size:.95rem;font-family:"Archivo Black",sans-serif;word-break:break-word}
.mi-team span{color:var(--muted);font-size:.72rem;font-family:"JetBrains Mono",monospace}
.mi-foot{display:flex;justify-content:space-between;padding-top:14px;border-top:2px dashed var(--ink);font-size:.78rem;color:var(--muted);font-family:"JetBrains Mono",monospace;flex-wrap:wrap;gap:6px}
.mi-foot strong{color:var(--ink);font-weight:700}

/* FAVORITES */
.favorites-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(230px,1fr));
  gap:22px;
}
.fav-card{
  background:var(--cream);
  color:var(--ink);
  border:2.5px solid var(--ink);
  box-shadow:6px 6px 0 var(--pink);
  padding:26px;
  display:flex;
  flex-direction:column;
  gap:8px;
  position:relative;
  transition:transform .15s ease,box-shadow .15s ease;
}
.fav-card:nth-child(2){box-shadow:6px 6px 0 var(--green)}
.fav-card:nth-child(3){box-shadow:6px 6px 0 var(--orange)}
.fav-card:nth-child(4){box-shadow:6px 6px 0 var(--yellow)}
.fav-card:nth-child(5){box-shadow:6px 6px 0 var(--pink)}
.fav-card:nth-child(6){box-shadow:6px 6px 0 var(--green)}
.fav-card:hover{transform:translate(-3px,-3px)}
.fav-rank{
  position:absolute;top:-2px;right:-2px;
  background:var(--ink);color:var(--yellow);
  padding:8px 14px;font-size:.85rem;
  font-family:"Archivo Black",sans-serif;
  letter-spacing:.5px;
}
.fav-country{font-size:1.5rem;color:var(--ink);text-transform:uppercase;margin-top:4px;word-break:break-word}
.fav-group{font-size:.72rem;color:var(--ink);background:var(--cream-2);padding:3px 8px;border:1.5px solid var(--ink);display:inline-block;width:fit-content;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:10px;font-weight:700}
.fav-rows{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.fav-row{display:flex;justify-content:space-between;font-size:.85rem;color:var(--ink-soft);border-bottom:1.5px dashed var(--ink);padding-bottom:6px;gap:8px}
.fav-row span{font-family:"JetBrains Mono",monospace;font-size:.78rem}
.fav-row strong{color:var(--ink);font-weight:700;font-family:"Archivo Black",sans-serif;font-size:.92rem;white-space:nowrap}

/* EXPANDED PREVIEWS */
.preview-stack{display:flex;flex-direction:column;gap:28px}
.prev-card{
  background:var(--cream);
  border:3px solid var(--ink);
  box-shadow:8px 8px 0 var(--ink);
  display:grid;
  grid-template-columns:auto 1fr;
  gap:0;
  position:relative;
  overflow:hidden;
}
.prev-card:nth-child(5n+1) .prev-id{background:var(--green);color:var(--cream)}
.prev-card:nth-child(5n+2) .prev-id{background:var(--pink);color:var(--ink)}
.prev-card:nth-child(5n+3) .prev-id{background:var(--orange);color:var(--cream)}
.prev-card:nth-child(5n+4) .prev-id{background:var(--yellow);color:var(--ink)}
.prev-card:nth-child(5n+5) .prev-id{background:var(--ink);color:var(--yellow)}
.prev-id{
  padding:28px 24px;
  font-size:2.6rem;
  display:grid;
  place-items:center;
  min-width:100px;
  letter-spacing:-2px;
  border-right:3px solid var(--ink);
}
.prev-body{padding:32px;min-width:0}
.prev-head{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:12px;margin-bottom:22px}
.prev-title{font-size:1.55rem;line-height:1.1;text-transform:uppercase;letter-spacing:-.5px;word-break:break-word}
.prev-group{
  background:var(--ink);color:var(--cream);
  padding:6px 14px;font-size:.72rem;font-weight:700;
  text-transform:uppercase;letter-spacing:1.5px;
  border:2px solid var(--ink);
  white-space:nowrap;
}
.prev-compare{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  gap:20px;
  align-items:stretch;
  border-top:3px solid var(--ink);
  border-bottom:3px solid var(--ink);
  background:var(--cream-2);
  padding:22px;
  margin:0 -32px 22px;
}
.pc-team{display:flex;flex-direction:column;gap:6px;min-width:0}
.pc-team.right{text-align:right}
.pc-name{font-size:1.15rem;font-family:"Archivo Black",sans-serif;text-transform:uppercase;word-break:break-word}
.pc-rank{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;font-weight:600}
.pc-stats{display:flex;flex-direction:column;gap:5px;margin-top:10px;font-size:.82rem}
.pc-stats span{color:var(--ink-soft);font-family:"JetBrains Mono",monospace;font-size:.78rem}
.pc-stats strong{color:var(--ink);font-family:"Archivo Black",sans-serif;font-size:.88rem}
.pc-vs{
  display:grid;place-items:center;
  font-family:"Archivo Black",sans-serif;
  color:var(--cream);
  background:var(--orange);
  border:2.5px solid var(--ink);
  padding:10px 16px;
  font-size:1.1rem;
  align-self:center;
  box-shadow:3px 3px 0 var(--ink);
}
.prev-text{color:var(--ink-soft);font-size:.96rem;line-height:1.7;font-weight:500}

/* GROUP RACE */
.group-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(290px,1fr));
  gap:22px;
}
.group-card{
  background:var(--cream);
  color:var(--ink);
  border:2.5px solid var(--ink);
  box-shadow:6px 6px 0 var(--ink);
  padding:24px;
  border-top:8px solid var(--green);
}
.group-card:nth-child(3n+2){border-top-color:var(--pink)}
.group-card:nth-child(3n+3){border-top-color:var(--orange)}
.group-card h3{color:var(--ink);font-size:1.05rem;margin-bottom:16px;display:flex;justify-content:space-between;align-items:center;text-transform:uppercase;letter-spacing:-.3px;line-height:1.15;gap:8px;flex-wrap:wrap}
.group-card h3 span{background:var(--ink);color:var(--yellow);font-size:.72rem;padding:4px 10px;font-family:"JetBrains Mono",monospace;letter-spacing:1.5px;font-weight:700;white-space:nowrap}
.gc-row{display:flex;justify-content:space-between;font-size:.92rem;padding:8px 0;color:var(--ink-soft);border-bottom:1.5px dashed var(--ink);font-weight:500;gap:8px}
.gc-row strong{color:var(--ink);font-family:"Archivo Black",sans-serif;white-space:nowrap}
.gc-row.leader{background:var(--yellow);margin:0 -8px;padding:8px;font-weight:700;border-bottom:none}
.gc-row.leader strong{color:var(--ink)}
.gc-note{font-size:.76rem;color:var(--muted);margin-top:12px;font-family:"JetBrains Mono",monospace}
.gc-note strong{color:var(--ink);font-weight:700}

/* HOST NATIONS */
.host-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:24px}
.host-card{
  background:var(--cream);
  border:2.5px solid var(--ink);
  padding:28px;
  position:relative;
  box-shadow:8px 8px 0 var(--ink);
}
.host-card.usa{box-shadow:8px 8px 0 var(--pink)}
.host-card.mexico{box-shadow:8px 8px 0 var(--green)}
.host-card.canada{box-shadow:8px 8px 0 var(--orange)}
.host-name{font-size:1.8rem;margin-bottom:6px;text-transform:uppercase;letter-spacing:-.5px}
.host-meta{font-size:.72rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--ink);margin-bottom:20px;background:var(--cream-2);padding:4px 10px;border:1.5px solid var(--ink);display:inline-block;font-weight:700}
.host-stat{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1.5px dashed var(--ink);font-size:.9rem;gap:8px}
.host-stat span{font-family:"JetBrains Mono",monospace;font-size:.8rem;color:var(--ink-soft)}
.host-stat strong{color:var(--ink);font-family:"Archivo Black",sans-serif;font-size:.95rem;white-space:nowrap}
.host-stat:last-child{border-bottom:0}

/* GUIDE */
.guide-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:22px}
.guide-card{
  background:var(--cream);
  color:var(--ink);
  border:2.5px solid var(--ink);
  box-shadow:6px 6px 0 var(--yellow);
  padding:26px;
  position:relative;
}
.guide-card:nth-child(2){box-shadow:6px 6px 0 var(--pink)}
.guide-card:nth-child(3){box-shadow:6px 6px 0 var(--green)}
.guide-card:nth-child(4){box-shadow:6px 6px 0 var(--orange)}
.guide-num{
  display:inline-block;
  font-size:.78rem;
  font-weight:700;
  color:var(--ink);
  background:var(--yellow);
  padding:4px 10px;
  border:2px solid var(--ink);
  letter-spacing:2px;
  margin-bottom:14px;
}
.guide-card:nth-child(2) .guide-num{background:var(--pink)}
.guide-card:nth-child(3) .guide-num{background:var(--green);color:var(--cream)}
.guide-card:nth-child(4) .guide-num{background:var(--orange);color:var(--cream)}
.guide-card h3{color:var(--ink);font-size:1.15rem;margin-bottom:10px;text-transform:uppercase;letter-spacing:-.3px;line-height:1.15}
.guide-card p{color:var(--ink-soft);font-size:.92rem;line-height:1.65;font-weight:500}

/* FAQ */
.faq-list{display:flex;flex-direction:column;gap:14px;max-width:900px}
.faq-list details{
  background:var(--cream);
  border:2.5px solid var(--ink);
  box-shadow:5px 5px 0 var(--ink);
  padding:18px 22px;
  transition:box-shadow .15s ease,transform .15s ease;
}
.faq-list details:nth-child(2n){box-shadow:5px 5px 0 var(--pink)}
.faq-list details:nth-child(3n){box-shadow:5px 5px 0 var(--green)}
.faq-list details:nth-child(5n){box-shadow:5px 5px 0 var(--orange)}
.faq-list details[open]{box-shadow:5px 5px 0 var(--yellow)}
.faq-list summary{
  cursor:pointer;font-weight:700;font-size:1rem;
  list-style:none;display:flex;justify-content:space-between;align-items:center;
  font-family:"Archivo Black",sans-serif;
  text-transform:uppercase;
  letter-spacing:-.3px;
  gap:12px;
}
.faq-list summary::after{
  content:"+";
  color:var(--ink);
  font-size:1.6rem;
  font-family:"Archivo Black",sans-serif;
  background:var(--yellow);
  width:32px;height:32px;
  display:grid;place-items:center;
  border:2px solid var(--ink);
  line-height:1;
  flex-shrink:0;
}
.faq-list details[open] summary::after{content:"−";background:var(--orange);color:var(--cream)}
.faq-list p{margin-top:14px;color:var(--ink-soft);font-size:.94rem;line-height:1.65;padding-top:12px;border-top:1.5px dashed var(--ink);font-weight:500}

/* FOOTER */
.site-footer{background:var(--ink);color:var(--cream);padding-top:70px;border-top:3px solid var(--ink)}
.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1.4fr;gap:40px;padding-bottom:48px}
.foot-brand .brand-mark{background:var(--green);color:var(--cream);box-shadow:3px 3px 0 var(--yellow)}
.foot-brand h3{color:var(--cream);margin:18px 0 12px;font-size:1.4rem;text-transform:uppercase}
.foot-brand p{color:var(--cream-2);font-size:.9rem;font-weight:500}
.foot-block h4{color:var(--yellow);font-size:.78rem;text-transform:uppercase;letter-spacing:2px;margin-bottom:18px;font-weight:700}
.foot-block ul li{margin-bottom:10px}
.foot-block ul li a{color:var(--cream-2);font-size:.92rem;transition:color .15s ease;font-weight:500}
.foot-block ul li a:hover{color:var(--pink)}
.address-block{color:var(--cream-2);font-size:.9rem;line-height:1.7;font-weight:500;font-style:normal}
.address-block a{color:var(--yellow);font-weight:600}
.address-block a:hover{color:var(--pink)}
.footer-bottom{background:#000;padding:22px 0;font-size:.78rem;color:var(--cream-2);border-top:2px solid var(--green);font-family:"JetBrains Mono",monospace}
.footer-bottom .container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;align-items:center}
.addr-small{max-width:600px;text-align:right}

/* REVEAL */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* RESPONSIVE */
@media(max-width:1200px){
  .hero-grid{gap:40px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  .foot-brand{grid-column:span 2}
}
@media(max-width:900px){
  .main-nav{gap:2px}
  .main-nav a{font-size:.72rem;padding:6px 8px}
}
@media(max-width:768px){
  .menu-toggle{display:flex}
  .main-nav{
    position:absolute;top:100%;left:0;right:0;
    background:var(--cream);
    flex-direction:column;
    padding:20px 28px;
    display:none;
    border-top:3px solid var(--ink);
    border-bottom:3px solid var(--ink);
    gap:6px;
    z-index:60;
  }
  .main-nav.open{display:flex}
  .main-nav a{font-size:.8rem;padding:10px 12px;width:100%}
  .hero{padding:60px 0 80px}
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero::before{width:200px;height:200px;top:-60px;right:-40px}
  .section{padding:64px 0}
  .section-head{margin-bottom:40px}
  .prev-card{grid-template-columns:1fr}
  .prev-id{padding:18px;font-size:1.6rem;border-right:0;border-bottom:3px solid var(--ink);min-width:auto}
  .prev-body{padding:24px}
  .prev-compare{grid-template-columns:1fr;gap:16px;margin:0 0 22px;padding:18px}
  .pc-team.right{text-align:left}
  .pc-vs{justify-self:start}
  .footer-grid{grid-template-columns:1fr;gap:36px}
  .foot-brand{grid-column:auto}
  .addr-small{text-align:left;max-width:100%}
  .footer-bottom .container{flex-direction:column;align-items:flex-start}
  .legal-block{padding:24px}
  .legal-block h2{font-size:1.2rem}
}
@media(max-width:560px){
  .hc-vs{grid-template-columns:1fr;gap:10px}
  .hc-divider{justify-self:center}
  .hero-card{padding:22px}
}
@media(max-width:480px){
  .container{padding:0 18px}
  .nav-wrap{padding:14px 18px}
  .hero h1{font-size:2.2rem}
  .hero-ctas{flex-direction:column;align-items:stretch}
  .btn{text-align:center;padding:14px 20px}
  .hs-tile{flex:1 1 100%;min-width:auto}
  .match-index,.favorites-grid,.host-grid,.guide-grid,.group-grid{grid-template-columns:1fr}
  .prev-title{font-size:1.2rem}
  .prev-body{padding:20px}
  .prev-compare{margin:0 0 18px;padding:16px}
  .pc-name{font-size:1rem}
  .mi-card,.fav-card,.host-card,.guide-card,.group-card{padding:20px}
  .fav-country{font-size:1.3rem}
  .host-name{font-size:1.5rem}
  .section-head h2{font-size:1.7rem}
  .faq-list details{padding:14px 16px}
  .faq-list summary{font-size:.9rem}
  .faq-list summary::after{width:28px;height:28px;font-size:1.3rem}
  .legal-block{padding:20px}
  .legal-block h2{font-size:1.1rem}
}