:root{
  --bg:#E0E5EC;
  --fg:#3D4852;
  --muted:#6B7280;
  --accent:#007AFF;
  --accent-light:#5AC8FA;
  --teal:#34C759;
  --ios-purple:#AF52DE;
  --ios-pink:#FF2D55;
  --ios-orange:#FF9500;
  --ios-red:#FF3B30;
  --ios-yellow:#FFCC00;
  --ios-indigo:#5856D6;
  --ios-mint:#00C7BE;
  --radius:32px;
  --radius-md:16px;
  --radius-sm:12px;
  --maxw:1180px;
  --sh-dark:rgba(163,177,198,.6);
  --sh-dark-strong:rgba(163,177,198,.7);
  --sh-light:rgba(255,255,255,.5);
  --sh-light-strong:rgba(255,255,255,.6);
  --ext:9px 9px 16px var(--sh-dark),-9px -9px 16px var(--sh-light);
  --ext-hover:12px 12px 20px var(--sh-dark-strong),-12px -12px 20px var(--sh-light-strong);
  --ext-sm:5px 5px 10px var(--sh-dark),-5px -5px 10px var(--sh-light);
  --inset:inset 6px 6px 10px var(--sh-dark),inset -6px -6px 10px var(--sh-light);
  --inset-deep:inset 10px 10px 20px var(--sh-dark-strong),inset -10px -10px 20px var(--sh-light-strong);
  --inset-sm:inset 3px 3px 6px var(--sh-dark),inset -3px -3px 6px var(--sh-light);
  --ios-gradient:linear-gradient(135deg,#007AFF 0%,#5856D6 50%,#AF52DE 100%);
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:'DM Sans',system-ui,sans-serif;
  background:var(--bg);
  color:var(--fg);
  line-height:1.6;
}
h1,h2,h3,h4,.brand{font-family:'Plus Jakarta Sans',sans-serif;letter-spacing:-.02em;}
img{max-width:100%;display:block;}
a{text-decoration:none;color:inherit;}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px;}

/* HEADER */
.site-header{
  position:sticky;top:0;z-index:50;
  background:var(--bg);
  box-shadow:0 8px 20px rgba(163,177,198,.35);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:74px;}
.brand{font-size:1.5rem;font-weight:800;color:var(--fg);}
.brand span{color:var(--accent);}
.main-nav{display:flex;gap:6px;}
.main-nav a{
  color:var(--fg);font-size:.82rem;font-weight:600;
  padding:10px 16px;border-radius:var(--radius-md);
  letter-spacing:.3px;transition:.3s ease-out;
}
.main-nav a:hover{box-shadow:var(--ext-sm);color:var(--accent);}
.nav-toggle{
  display:none;flex-direction:column;gap:5px;background:var(--bg);
  border:0;cursor:pointer;padding:12px;border-radius:var(--radius-md);box-shadow:var(--ext-sm);
}
.nav-toggle span{width:22px;height:3px;background:var(--accent);border-radius:2px;transition:.3s;}

/* HERO */
.hero{
  background:var(--bg);
  color:var(--fg);
  padding:96px 0 104px;
  position:relative;
  overflow:hidden;
}
.hero-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:center;position:relative;z-index:1;}
.kicker{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--bg);color:var(--accent);
  font-weight:700;font-size:.72rem;letter-spacing:1.5px;text-transform:uppercase;
  padding:10px 20px;border-radius:9999px;margin-bottom:24px;
  box-shadow:var(--ext-sm);
}
.kicker::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--teal);box-shadow:0 0 6px var(--teal);}
.hero h1{
  font-size:3.3rem;line-height:1.05;margin-bottom:20px;font-weight:800;
  background:var(--ios-gradient);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:var(--accent);
}
.hero-copy p{color:var(--muted);font-size:1.05rem;max-width:560px;margin-bottom:32px;}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;}
.btn{
  display:inline-block;font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;
  font-size:.95rem;letter-spacing:.3px;
  padding:15px 30px;border-radius:var(--radius-md);cursor:pointer;
  transition:.3s ease-out;border:0;background:var(--bg);color:var(--fg);
  box-shadow:var(--ext);
}
.btn:hover{transform:translateY(-2px);box-shadow:var(--ext-hover);}
.btn:active{transform:translateY(1px);box-shadow:var(--inset-sm);}
.btn-primary{background:var(--ios-gradient);color:#fff;box-shadow:8px 8px 16px rgba(0,122,255,.35),-8px -8px 16px rgba(255,255,255,.5);}
.btn-primary:hover{transform:translateY(-2px);box-shadow:10px 10px 20px rgba(0,122,255,.45),-10px -10px 20px rgba(255,255,255,.6);}
.btn-primary:active{box-shadow:inset 4px 4px 8px rgba(0,90,200,.6),inset -4px -4px 8px rgba(90,200,250,.5);}
.btn-outline{color:var(--accent);box-shadow:var(--ext);}
.btn-outline:hover{color:var(--accent-light);}

.hero-stats{display:grid;gap:20px;}
.hero-stat-tile{
  background:var(--bg);
  padding:24px 26px;border-radius:var(--radius);
  box-shadow:var(--ext);transition:.3s ease-out;
}
.hero-stat-tile:hover{transform:translateY(-2px);box-shadow:var(--ext-hover);}
.stat-num{display:block;font-family:'Plus Jakarta Sans',sans-serif;font-size:2.8rem;font-weight:800;color:var(--accent);line-height:1;}
.hero-stat-tile:nth-child(2) .stat-num{color:var(--ios-purple);}
.hero-stat-tile:nth-child(3) .stat-num{color:var(--ios-orange);}
.stat-label{font-size:.78rem;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-top:4px;}

/* SECTIONS */
.section{padding:80px 0;}
.dark-section{background:var(--bg);color:var(--fg);}
.section-head{margin-bottom:48px;max-width:640px;}
.section-head h2{font-size:2.3rem;font-weight:800;color:var(--fg);}
.section-head p{color:var(--muted);margin-top:10px;}
.section-head.light h2{color:var(--fg);}
.section-head.light p{color:var(--muted);}

/* MATCH INDEX */
.index-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:28px;}
.index-card{
  background:var(--bg);border-radius:var(--radius);padding:26px;
  box-shadow:var(--ext);transition:transform .3s ease-out,box-shadow .3s ease-out;
  display:block;position:relative;
}
.index-card:hover{transform:translateY(-3px);box-shadow:var(--ext-hover);}
.index-card .group-tag{
  display:inline-block;background:var(--bg);color:var(--accent);
  font-size:.72rem;font-weight:700;letter-spacing:1px;padding:7px 16px;border-radius:9999px;margin-bottom:14px;
  box-shadow:var(--inset-sm);
}
.index-card h3{font-size:1.4rem;margin-bottom:18px;font-weight:700;color:var(--fg);}
.ic-teams{display:flex;gap:14px;}
.ic-team{flex:1;background:var(--bg);border-radius:var(--radius-md);padding:16px;box-shadow:var(--inset);}
.ic-team .ic-name{font-weight:700;font-size:.95rem;color:var(--fg);}
.ic-team .ic-rank{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;}
.ic-team .ic-stat{font-size:.78rem;color:var(--fg);margin-top:7px;}
.ic-team .ic-stat b{color:var(--accent);}

/* TITLE CONTEXT */
.title-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:24px;}
.title-card{
  background:var(--bg);border-radius:var(--radius);padding:24px;
  box-shadow:var(--ext);position:relative;transition:transform .3s ease-out,box-shadow .3s ease-out;
}
.title-card:hover{transform:translateY(-3px);box-shadow:var(--ext-hover);}
.title-card .rank-badge{
  position:absolute;top:16px;right:18px;font-family:'Plus Jakarta Sans',sans-serif;
  font-size:1.9rem;font-weight:800;color:var(--accent-light);opacity:.35;
}
.title-card h3{font-size:1.5rem;color:var(--fg);font-weight:800;}
.title-card .tc-group{font-size:.72rem;color:var(--teal);letter-spacing:1px;text-transform:uppercase;margin-bottom:14px;font-weight:600;}
.title-card .tc-row{display:flex;justify-content:space-between;font-size:.82rem;padding:9px 0;border-top:1px solid rgba(163,177,198,.3);}
.title-card .tc-row span:first-child{color:var(--muted);}
.title-card .tc-row b{color:var(--accent);}
.title-card:nth-child(1)::before,
.title-card:nth-child(2)::before,
.title-card:nth-child(3)::before,
.title-card:nth-child(4)::before,
.title-card:nth-child(5)::before,
.title-card:nth-child(6)::before{
  content:"";position:absolute;top:0;left:0;width:100%;height:5px;border-radius:var(--radius) var(--radius) 0 0;
}
.title-card:nth-child(1)::before{background:var(--accent);}
.title-card:nth-child(2)::before{background:var(--ios-indigo);}
.title-card:nth-child(3)::before{background:var(--ios-purple);}
.title-card:nth-child(4)::before{background:var(--teal);}
.title-card:nth-child(5)::before{background:var(--ios-orange);}
.title-card:nth-child(6)::before{background:var(--ios-pink);}

/* PREVIEWS */
.preview-list{display:grid;gap:32px;}
.preview-card{
  background:var(--bg);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--ext);transition:transform .3s ease-out,box-shadow .3s ease-out;
}
.preview-card:hover{transform:translateY(-3px);box-shadow:var(--ext-hover);}
.pc-header{
  background:var(--bg);
  color:var(--fg);padding:26px 28px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;
}
.pc-header h3{font-size:1.7rem;font-weight:800;color:var(--fg);}
.pc-header .pc-group{
  background:var(--bg);color:var(--teal);font-size:.75rem;font-weight:700;
  letter-spacing:1px;padding:8px 18px;border-radius:9999px;box-shadow:var(--inset-sm);
}
.pc-body{padding:8px 28px 28px;}
.compare{display:grid;grid-template-columns:1fr auto 1fr;gap:20px;align-items:stretch;margin-bottom:22px;}
.compare-team{background:var(--bg);border-radius:var(--radius-md);padding:22px;box-shadow:var(--inset);}
.compare-team.leader{box-shadow:inset 6px 6px 10px var(--sh-dark),inset -6px -6px 10px var(--sh-light),0 0 0 2px rgba(52,199,89,.4);}
.compare-team h4{font-size:1.3rem;margin-bottom:5px;font-weight:800;color:var(--fg);}
.compare-team .rank{font-size:.74rem;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px;}
.compare-team .crow{display:flex;justify-content:space-between;font-size:.82rem;padding:8px 0;border-top:1px solid rgba(163,177,198,.3);}
.compare-team .crow b{color:var(--accent);}
.vs-pill{display:flex;align-items:center;justify-content:center;font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;font-size:1.1rem;color:#fff;background:var(--ios-gradient);border-radius:50%;width:60px;height:60px;align-self:center;box-shadow:6px 6px 12px rgba(0,122,255,.35),-6px -6px 12px var(--sh-light);}
.pc-note{font-size:.94rem;color:var(--fg);background:var(--bg);border-radius:var(--radius-md);padding:18px 20px;box-shadow:var(--inset);}

/* GROUP RACE */
.group-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px;}
.group-card{
  background:var(--bg);border-radius:var(--radius);padding:26px;box-shadow:var(--ext);transition:transform .3s ease-out,box-shadow .3s ease-out;
}
.group-card:hover{transform:translateY(-3px);box-shadow:var(--ext-hover);}
.group-card .gc-label{font-size:.74rem;color:var(--teal);letter-spacing:1px;text-transform:uppercase;font-weight:600;}
.group-card h3{font-size:1.4rem;color:var(--fg);margin:6px 0 16px;font-weight:700;}
.group-card .gc-team{display:flex;justify-content:space-between;font-size:.86rem;padding:10px 14px;margin-top:8px;border-radius:var(--radius-sm);color:var(--muted);}
.group-card .gc-team.top{color:var(--accent);font-weight:700;box-shadow:var(--inset-sm);}
.group-card .gc-team b{color:var(--accent);}

/* HOSTS */
.host-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:28px;}
.host-card{
  background:var(--bg);border-radius:var(--radius);padding:28px;
  box-shadow:var(--ext);transition:transform .3s ease-out,box-shadow .3s ease-out;position:relative;overflow:hidden;
}
.host-card:hover{transform:translateY(-3px);box-shadow:var(--ext-hover);}
.host-card::before{content:"";position:absolute;top:0;left:0;width:100%;height:5px;}
.host-card:nth-child(1)::before{background:var(--accent);}
.host-card:nth-child(2)::before{background:var(--teal);}
.host-card:nth-child(3)::before{background:var(--ios-red);}
.host-card h3{font-size:1.8rem;font-weight:800;color:var(--fg);}
.host-card .hc-sub{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:18px;}
.host-stats{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.host-stat{background:var(--bg);border-radius:var(--radius-md);padding:15px;box-shadow:var(--inset);}
.host-stat span{display:block;font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;}
.host-stat b{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.4rem;color:var(--accent);font-weight:800;}

/* GUIDE */
.guide-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px;}
.guide-card{background:var(--bg);border-radius:var(--radius);padding:28px;box-shadow:var(--ext);transition:transform .3s ease-out,box-shadow .3s ease-out;position:relative;overflow:hidden;}
.guide-card:hover{transform:translateY(-3px);box-shadow:var(--ext-hover);}
.guide-card::before{content:"";position:absolute;top:0;left:0;height:100%;width:5px;}
.guide-card:nth-child(1)::before{background:var(--accent);}
.guide-card:nth-child(2)::before{background:var(--ios-purple);}
.guide-card:nth-child(3)::before{background:var(--teal);}
.guide-card:nth-child(4)::before{background:var(--ios-orange);}
.guide-card h3{font-size:1.3rem;color:var(--fg);margin-bottom:10px;font-weight:700;}
.guide-card p{color:var(--muted);font-size:.9rem;}

/* FAQ */
.faq-list{display:grid;gap:18px;max-width:840px;}
.faq-item{background:var(--bg);border-radius:var(--radius-md);padding:22px 26px;box-shadow:var(--ext);transition:box-shadow .3s ease-out;}
.faq-item[open]{box-shadow:var(--inset);}
.faq-item summary{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.15rem;font-weight:700;cursor:pointer;list-style:none;color:var(--fg);}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after{content:"+";float:right;color:var(--accent);font-weight:700;}
.faq-item[open] summary::after{content:"–";}
.faq-item p{margin-top:12px;color:var(--muted);font-size:.94rem;}

/* LEGAL PAGES */
.legal-section{padding:64px 0 80px;}
.legal-wrap{max-width:860px;background:var(--bg);border-radius:var(--radius);padding:48px;box-shadow:var(--ext);}
.legal-wrap .back-link{
  display:inline-block;color:var(--accent);font-weight:600;font-size:.85rem;
  text-transform:uppercase;letter-spacing:.5px;margin-bottom:24px;
  padding:10px 18px;border-radius:var(--radius-md);box-shadow:var(--ext-sm);transition:.3s ease-out;
}
.legal-wrap .back-link:hover{transform:translateY(-2px);box-shadow:var(--ext);color:var(--accent-light);}
.legal-wrap h1{font-size:2.6rem;margin-bottom:8px;font-weight:800;color:var(--fg);}
.legal-updated{color:var(--muted);font-size:.85rem;margin-bottom:32px;}
.legal-wrap h2{font-size:1.4rem;margin:32px 0 12px;color:var(--fg);font-weight:700;}
.legal-wrap p{color:var(--muted);font-size:.96rem;margin-bottom:14px;}
.legal-wrap ul{margin:0 0 16px 22px;color:var(--muted);font-size:.96rem;}
.legal-wrap ul li{margin-bottom:7px;}
.legal-wrap address{
  font-style:normal;color:var(--fg);font-size:.96rem;line-height:1.7;
  background:var(--bg);padding:18px 22px;border-radius:var(--radius-md);margin-bottom:14px;box-shadow:var(--inset);
}
.legal-wrap a{color:var(--accent);}
.legal-wrap a:hover{color:var(--accent-light);text-decoration:underline;}
.cookie-table{
  width:100%;border-collapse:separate;border-spacing:0;margin:16px 0 20px;font-size:.9rem;
  border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--inset);
}
.cookie-table th,.cookie-table td{
  padding:13px 15px;text-align:left;vertical-align:top;color:var(--fg);
  border-bottom:1px solid rgba(163,177,198,.3);
}
.cookie-table th{
  background:var(--bg);color:var(--accent);
  font-family:'Plus Jakarta Sans',sans-serif;letter-spacing:.5px;font-weight:700;
}
.cookie-table tbody tr:last-child td{border-bottom:0;}

/* FOOTER */
.site-footer{background:var(--bg);color:var(--fg);padding-top:60px;box-shadow:0 -8px 20px rgba(163,177,198,.3);}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr;gap:44px;padding-bottom:40px;}
.footer-brand .brand{font-size:1.6rem;font-weight:800;}
.footer-note{color:var(--muted);font-size:.88rem;margin-top:14px;max-width:520px;}
.footer-address h4,.footer-links h4{color:var(--accent);font-size:1.1rem;margin-bottom:12px;font-weight:700;}
.footer-address address{font-style:normal;color:var(--muted);font-size:.92rem;line-height:1.7;}
.footer-address address a{color:var(--accent);}
.footer-address address a:hover{text-decoration:underline;}
.footer-links ul{list-style:none;}
.footer-links li{margin-bottom:9px;}
.footer-links a{color:var(--muted);font-size:.92rem;}
.footer-links a:hover{color:var(--accent);}
.footer-bottom{border-top:1px solid rgba(163,177,198,.3);padding:22px 0;}
.footer-bottom p{font-size:.82rem;color:var(--muted);text-align:center;}

/* COOKIE BANNER */
.cookie-banner{
  position:fixed;left:0;right:0;bottom:0;z-index:100;
  background:var(--bg);color:var(--fg);
  transform:translateY(120%);transition:transform .4s ease;
  box-shadow:0 -10px 30px rgba(163,177,198,.5);
}
.cookie-banner.show{transform:translateY(0);}
.cookie-inner{
  max-width:var(--maxw);margin:0 auto;padding:22px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
}
.cookie-inner p{font-size:.9rem;color:var(--muted);max-width:760px;margin:0;}
.cookie-inner p a{color:var(--accent);}
.cookie-inner p a:hover{text-decoration:underline;}
.cookie-actions{display:flex;gap:12px;flex-shrink:0;}
.cookie-btn{padding:12px 26px;font-size:.85rem;}

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

/* FOCUS STATES */
a:focus-visible,.btn:focus-visible,summary:focus-visible,.nav-toggle:focus-visible{
  outline:2px solid var(--accent);outline-offset:3px;border-radius:var(--radius-md);
}

/* RESPONSIVE */
@media(max-width:1200px){
  .hero h1{font-size:2.8rem;}
}
@media(max-width:768px){
  .nav-toggle{display:flex;}
  .main-nav{
    position:absolute;top:74px;left:14px;right:14px;flex-direction:column;gap:4px;
    background:var(--bg);padding:14px;display:none;border-radius:var(--radius);box-shadow:var(--ext-hover);
  }
  .main-nav.open{display:flex;}
  .main-nav a{padding:13px 18px;}
  .hero-grid{grid-template-columns:1fr;gap:36px;}
  .hero h1{font-size:2.3rem;}
  .footer-inner{grid-template-columns:1fr;gap:32px;}
  .compare{grid-template-columns:1fr;}
  .vs-pill{margin:0 auto;}
  .cookie-inner{flex-direction:column;align-items:flex-start;}
  .cookie-actions{width:100%;}
  .cookie-btn{flex:1;}
  .legal-wrap{padding:32px 24px;}
}
@media(max-width:480px){
  .hero{padding:64px 0 72px;}
  .hero h1{font-size:2rem;}
  .section{padding:56px 0;}
  .section-head h2{font-size:1.8rem;}
  .index-grid{grid-template-columns:1fr;}
  .host-stats{grid-template-columns:1fr 1fr;}
  .pc-header h3{font-size:1.35rem;}
  .legal-wrap h1{font-size:2rem;}
  .legal-section{padding:44px 0 60px;}
}