@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@500;600;700;800&family=DM+Sans:wght@400;500;700&display=swap');

:root{
  --bg:#E0E5EC;
  --bg-2:#E0E5EC;
  --surface:#E0E5EC;
  --accent:#6C63FF;
  --accent-2:#6C63FF;
  --accent-3:#38B2AC;
  --accent-light:#8B84FF;
  --border:transparent;
  --text:#3D4852;
  --text-2:#6B7280;
  --maxw:1280px;
  --radius:32px;
  --radius-sm:16px;

  /* Neumorphic shadow system */
  --nm-raised:9px 9px 16px rgba(163,177,198,.6), -9px -9px 16px rgba(255,255,255,.5);
  --nm-raised-sm:5px 5px 10px rgba(163,177,198,.6), -5px -5px 10px rgba(255,255,255,.5);
  --nm-raised-hover:12px 12px 20px rgba(163,177,198,.7), -12px -12px 20px rgba(255,255,255,.6);
  --nm-inset:inset 6px 6px 10px rgba(163,177,198,.6), inset -6px -6px 10px rgba(255,255,255,.5);
  --nm-inset-deep:inset 10px 10px 20px rgba(163,177,198,.7), inset -10px -10px 20px rgba(255,255,255,.6);
  --nm-inset-sm:inset 3px 3px 6px rgba(163,177,198,.6), inset -3px -3px 6px rgba(255,255,255,.5);

  --shadow:var(--nm-raised);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"DM Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,.brand,.section-tag{
  font-family:"Plus Jakarta Sans",-apple-system,sans-serif;
  letter-spacing:-.02em;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.container{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.container.narrow{max-width:820px}

/* FOCUS STATES */
a:focus-visible,
button:focus-visible,
summary:focus-visible,
.btn:focus-visible{
  outline:none;
  box-shadow:0 0 0 2px var(--bg), 0 0 0 4px var(--accent);
  border-radius:12px;
}

/* HEADER */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(224,229,236,.85);
  backdrop-filter:blur(12px);
  border-bottom:none;
}
.header-inner{display:flex;align-items:center;gap:24px;height:80px}
.brand{font-size:1.25rem;font-weight:800;letter-spacing:-.01em;color:var(--accent)}
.brand-dot{color:var(--accent-3);font-weight:600}
.main-nav{display:flex;gap:10px;margin-left:auto;font-family:"DM Sans",sans-serif;font-size:.9rem}
.main-nav a{
  color:var(--text-2);padding:8px 16px;border-radius:999px;
  font-weight:500;transition:.3s ease-out;
}
.main-nav a:hover{color:var(--accent);box-shadow:var(--nm-raised-sm)}
.header-cta{margin-left:8px}
.menu-toggle{
  display:none;background:var(--bg);border:0;cursor:pointer;
  flex-direction:column;gap:5px;padding:14px;border-radius:14px;
  box-shadow:var(--nm-raised-sm);
}
.menu-toggle:active{box-shadow:var(--nm-inset-sm)}
.menu-toggle span{width:22px;height:2px;background:var(--accent);display:block;border-radius:2px}

/* BUTTONS */
.btn{
  display:inline-block;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:.92rem;font-weight:700;
  padding:14px 28px;border-radius:var(--radius-sm);
  transition:.3s ease-out;cursor:pointer;border:0;
  background:var(--bg);color:var(--text);
  box-shadow:var(--nm-raised);
}
.btn:hover{transform:translateY(-1px);box-shadow:var(--nm-raised-hover)}
.btn:active{transform:translateY(.5px);box-shadow:var(--nm-inset-sm)}
.btn-primary{
  background:var(--accent);color:#fff;
  box-shadow:6px 6px 12px rgba(108,99,255,.35), -4px -4px 12px rgba(255,255,255,.4);
}
.btn-primary:hover{
  background:var(--accent-light);
  box-shadow:8px 8px 16px rgba(108,99,255,.4), -6px -6px 16px rgba(255,255,255,.5);
}
.btn-primary:active{
  box-shadow:inset 4px 4px 8px rgba(76,68,200,.5), inset -4px -4px 8px rgba(150,142,255,.4);
}
.btn-outline{background:var(--bg);color:var(--accent-2);box-shadow:var(--nm-raised)}
.btn-outline:hover{color:var(--accent-light)}
.btn-ghost{background:var(--bg);color:var(--accent);box-shadow:var(--nm-raised-sm)}
.btn-ghost:hover{box-shadow:var(--nm-raised-hover)}

/* SECTIONS */
.section{padding:104px 0}
.section-alt{background:var(--bg)}
.section-head{max-width:720px;margin-bottom:56px}
.section-tag{
  display:inline-block;
  text-transform:uppercase;letter-spacing:1.5px;font-size:.72rem;
  color:var(--accent);font-weight:800;margin-bottom:18px;
  padding:8px 18px;border-radius:999px;background:var(--bg);
  box-shadow:var(--nm-inset-sm);
}
.section-head h2{font-size:2.3rem;line-height:1.15;font-weight:800;margin-bottom:16px;color:var(--text)}
.section-lead{color:var(--text-2);font-size:1.08rem}

/* HERO */
.hero{
  padding:128px 0 112px;
  background:var(--bg);
}
.hero-inner{max-width:860px}
.eyebrow{
  display:inline-block;
  text-transform:uppercase;letter-spacing:2px;font-size:.76rem;
  color:var(--accent);font-weight:700;margin-bottom:28px;
  font-family:"DM Sans",sans-serif;
  padding:10px 20px;border-radius:999px;background:var(--bg);
  box-shadow:var(--nm-inset-sm);
}
.hero h1{font-size:3.4rem;line-height:1.08;font-weight:800;letter-spacing:-.03em;margin-bottom:26px;color:var(--text)}
.hero-sub{font-size:1.2rem;color:var(--text-2);margin-bottom:40px;max-width:680px}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}

/* FAVORITES */
.favorites-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:28px;
}
.fav-card{
  background:var(--bg);border:0;
  border-radius:var(--radius);padding:34px;position:relative;
  box-shadow:var(--nm-raised);transition:.3s ease-out;
}
.fav-card:hover{transform:translateY(-2px);box-shadow:var(--nm-raised-hover)}
.rank-badge{
  position:absolute;top:28px;right:28px;
  font-family:"Plus Jakarta Sans",sans-serif;font-weight:800;
  color:var(--accent);font-size:.95rem;
  width:44px;height:44px;display:flex;align-items:center;justify-content:center;
  border-radius:999px;background:var(--bg);box-shadow:var(--nm-inset);
}
.fav-card h3{font-size:1.55rem;font-weight:700;margin-bottom:6px;color:var(--text)}
.fav-meta{color:var(--accent-3);font-size:.84rem;font-weight:600;margin-bottom:24px;font-family:"DM Sans",sans-serif}
.fav-stats{list-style:none;display:flex;flex-direction:column;gap:12px}
.fav-stats li{
  display:flex;justify-content:space-between;align-items:center;
  font-family:"DM Sans",sans-serif;font-size:.9rem;
  padding:12px 18px;border-radius:14px;background:var(--bg);box-shadow:var(--nm-inset-sm);
}
.fav-stats span{color:var(--text-2)}
.fav-stats strong{color:var(--accent);font-weight:700}

/* MATCH CARDS */
.match-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}
.match-card{
  background:var(--bg);border:0;
  border-radius:var(--radius);padding:36px;box-shadow:var(--nm-raised);
  transition:.3s ease-out;
}
.match-card:hover{transform:translateY(-2px);box-shadow:var(--nm-raised-hover)}
.match-card-head{margin-bottom:26px}
.group-chip{
  display:inline-block;background:var(--bg);color:var(--accent);
  font-family:"DM Sans",sans-serif;font-size:.72rem;font-weight:700;
  letter-spacing:1px;text-transform:uppercase;padding:8px 16px;border-radius:999px;
  box-shadow:var(--nm-inset-sm);margin-bottom:16px;
}
.match-card-head h3{font-size:1.45rem;font-weight:700;color:var(--text)}
.versus{display:flex;align-items:stretch;gap:18px}
.team{
  flex:1;padding:20px;border-radius:var(--radius-sm);
  background:var(--bg);box-shadow:var(--nm-inset-sm);
}
.team-name{font-family:"Plus Jakarta Sans",sans-serif;font-weight:700;font-size:1.05rem;color:var(--text);margin-bottom:4px}
.fav-tag{
  display:inline-block;font-size:.6rem;letter-spacing:.5px;text-transform:uppercase;font-weight:700;
  background:var(--accent);color:#fff;padding:3px 10px;border-radius:999px;margin-left:6px;vertical-align:middle;
  box-shadow:3px 3px 6px rgba(108,99,255,.3), -2px -2px 6px rgba(255,255,255,.4);
}
.team-rank{font-size:.8rem;color:var(--accent-3);font-weight:600;margin-bottom:14px;font-family:"DM Sans",sans-serif}
.team-rows{display:flex;flex-direction:column;gap:8px;font-family:"DM Sans",sans-serif;font-size:.84rem;color:var(--text-2)}
.team-rows span{display:flex;justify-content:space-between;align-items:center}
.team-rows b{color:var(--accent);font-weight:700}
.vs-divider{
  align-self:center;font-family:"Plus Jakarta Sans",sans-serif;
  font-size:.78rem;color:var(--accent-3);font-weight:800;
  width:44px;height:44px;display:flex;align-items:center;justify-content:center;
  border-radius:999px;background:var(--bg);box-shadow:var(--nm-raised-sm);flex-shrink:0;
}
.match-preview{margin-top:26px;padding:20px 22px;border-radius:var(--radius-sm);background:var(--bg);box-shadow:var(--nm-inset-sm);color:var(--text-2);font-size:.96rem}

/* LONGREAD */
.longread-list{display:flex;flex-direction:column;gap:26px}
.longread{
  background:var(--bg);border:0;
  border-radius:var(--radius);padding:38px 42px;box-shadow:var(--nm-raised);
}
.longread .group-chip{margin-bottom:14px}
.longread h3{font-size:1.45rem;font-weight:700;color:var(--text);margin:0 0 20px}
.compare-row{
  display:flex;gap:20px;flex-wrap:wrap;margin-bottom:24px;
  font-family:"DM Sans",sans-serif;font-size:.85rem;color:var(--text-2);
}
.compare-row>div{
  flex:1;min-width:240px;background:var(--bg);
  border-radius:var(--radius-sm);padding:16px 20px;box-shadow:var(--nm-inset);
}
.compare-row b{color:var(--accent);font-weight:700}
.longread p{color:var(--text-2);margin-bottom:10px;font-size:.97rem}
.lr-label{
  font-family:"Plus Jakarta Sans",sans-serif;font-weight:700;
  color:var(--accent-3);font-size:.8rem;text-transform:uppercase;letter-spacing:.5px;margin-right:6px;
}

/* GROUPS */
.group-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.group-card{
  background:var(--bg);border:0;
  border-radius:var(--radius);padding:30px;box-shadow:var(--nm-raised);
  transition:.3s ease-out;
}
.group-card:hover{transform:translateY(-2px);box-shadow:var(--nm-raised-hover)}
.group-card .gm{font-family:"Plus Jakarta Sans",sans-serif;font-weight:700;margin:14px 0 16px;color:var(--text)}
.group-card ul{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.group-card li{
  display:flex;justify-content:space-between;font-family:"DM Sans",sans-serif;font-size:.88rem;color:var(--text-2);
  padding:10px 16px;border-radius:12px;background:var(--bg);box-shadow:var(--nm-inset-sm);
}
.group-card li b{color:var(--accent);font-weight:700}
.gf{font-size:.85rem;color:var(--text-2)}
.gf b{color:var(--accent-3);font-weight:700}

/* HOSTS */
.host-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.host-card{
  background:var(--accent);color:#fff;border-radius:var(--radius);
  padding:36px;transition:.3s ease-out;
  box-shadow:9px 9px 18px rgba(108,99,255,.35), -9px -9px 18px rgba(255,255,255,.5);
}
.host-card:hover{
  transform:translateY(-2px);
  box-shadow:12px 12px 22px rgba(108,99,255,.42), -12px -12px 22px rgba(255,255,255,.55);
}
.host-card h3{font-size:1.75rem;font-weight:800;margin-bottom:6px}
.host-meta{color:rgba(255,255,255,.78);font-size:.85rem;margin-bottom:24px;font-family:"DM Sans",sans-serif}
.host-stats{list-style:none;display:flex;flex-direction:column;gap:12px}
.host-stats li{
  display:flex;justify-content:space-between;align-items:center;
  font-family:"DM Sans",sans-serif;font-size:.9rem;
  padding:12px 18px;border-radius:14px;
  background:rgba(255,255,255,.08);
  box-shadow:inset 3px 3px 6px rgba(76,68,200,.4), inset -3px -3px 6px rgba(150,142,255,.3);
}
.host-stats span{color:rgba(255,255,255,.8)}
.host-stats b{color:#fff;font-weight:700}

/* GUIDE */
.guide-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.guide-item{
  background:var(--bg);border:0;
  border-radius:var(--radius);padding:34px;box-shadow:var(--nm-raised);
  transition:.3s ease-out;
}
.guide-item:hover{transform:translateY(-2px);box-shadow:var(--nm-raised-hover)}
.guide-item h3{font-size:1.2rem;font-weight:700;color:var(--accent);margin-bottom:12px;font-family:"Plus Jakarta Sans",sans-serif}
.guide-item p{color:var(--text-2);font-size:.97rem}

/* LEGAL PAGES */
.legal-section{padding-top:72px}
.legal-content{
  background:var(--bg);border:0;
  border-radius:var(--radius);padding:48px 50px;box-shadow:var(--nm-raised);
}
.legal-content h3{
  font-size:1.2rem;font-weight:700;color:var(--accent);margin:32px 0 12px;
  font-family:"Plus Jakarta Sans",sans-serif;
}
.legal-content h3:first-child{margin-top:0}
.legal-content p{color:var(--text-2);font-size:1rem;margin-bottom:14px}
.legal-content ul{color:var(--text-2);font-size:1rem;margin:0 0 14px 22px}
.legal-content li{margin-bottom:8px}
.legal-content a{color:var(--accent);text-decoration:underline}
.legal-content a:hover{color:var(--accent-light)}

/* FAQ */
.faq-list{display:flex;flex-direction:column;gap:18px}
.faq-item{
  background:var(--bg);border:0;
  border-radius:var(--radius-sm);padding:24px 30px;box-shadow:var(--nm-raised);
  transition:.3s ease-out;
}
.faq-item[open]{box-shadow:var(--nm-inset)}
.faq-item summary{
  font-family:"Plus Jakarta Sans",sans-serif;font-weight:700;
  cursor:pointer;color:var(--text);font-size:1.05rem;list-style:none;
  display:flex;justify-content:space-between;align-items:center;
}
.faq-item summary::after{
  content:"+";color:var(--accent);font-size:1.3rem;font-weight:600;
  width:36px;height:36px;display:flex;align-items:center;justify-content:center;
  border-radius:999px;background:var(--bg);box-shadow:var(--nm-raised-sm);
}
.faq-item[open] summary::after{content:"–";box-shadow:var(--nm-inset-sm)}
.faq-item p{margin-top:18px;color:var(--text-2);padding:18px 22px;border-radius:14px;background:var(--bg);box-shadow:var(--nm-inset-sm)}

/* FOOTER */
.site-footer{background:var(--bg);color:var(--text-2);padding:80px 0 44px}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:44px;padding-bottom:44px;border-bottom:none}
.footer-brand .brand{color:var(--accent);font-size:1.35rem}
.footer-brand .brand-dot{color:var(--accent-3)}
.footer-desc{margin-top:16px;color:var(--text-2);max-width:340px;font-size:.95rem}
.footer-links h4,.footer-address h4{color:var(--text);font-family:"Plus Jakarta Sans",sans-serif;font-weight:700;font-size:.92rem;margin-bottom:18px;letter-spacing:.3px}
.footer-links a{display:block;color:var(--text-2);margin-bottom:11px;font-family:"DM Sans",sans-serif;font-size:.9rem;transition:.3s ease-out}
.footer-links a:hover{color:var(--accent)}
.footer-address address{font-style:normal;color:var(--text-2);font-size:.92rem;line-height:1.85}
.footer-note{
  margin-top:36px;padding:24px 32px;border-radius:var(--radius-sm);
  background:var(--bg);box-shadow:var(--nm-inset-sm);
  display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;
}
.footer-note p{color:var(--text-2);font-size:.84rem;font-family:"DM Sans",sans-serif;max-width:640px}

/* COOKIE BANNER */
.cookie-banner{
  position:fixed;left:0;right:0;bottom:0;z-index:80;
  background:var(--bg);color:var(--text);
  border-top:0;
  box-shadow:0 -8px 28px rgba(163,177,198,.5);
  transform:translateY(120%);transition:transform .4s ease;
}
.cookie-banner.show{transform:translateY(0)}
.cookie-inner{
  max-width:var(--maxw);margin:0 auto;padding:24px 32px;
  display:flex;align-items:center;gap:28px;flex-wrap:wrap;
}
.cookie-text{
  flex:1;min-width:260px;font-size:.92rem;color:var(--text-2);
}
.cookie-text a{color:var(--accent);text-decoration:underline}
.cookie-text a:hover{color:var(--accent-light)}
.cookie-actions{display:flex;gap:14px;flex-shrink:0}
.cookie-btn{padding:11px 26px}
.cookie-banner .btn-outline{background:var(--bg);color:var(--accent-2);box-shadow:var(--nm-raised-sm)}
.cookie-banner .btn-outline:hover{color:var(--accent-light)}

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

/* BREAKPOINTS */
@media (max-width:1200px){
  .favorites-grid,.group-grid,.guide-grid{grid-template-columns:repeat(2,1fr)}
  .hero h1{font-size:2.9rem}
  .footer-inner{grid-template-columns:1fr 1fr}
}
@media (max-width:768px){
  .section{padding:72px 0}
  .hero{padding:88px 0 72px}
  .container{padding:0 22px}
  .main-nav,.header-cta{display:none}
  .main-nav.open{
    display:flex;flex-direction:column;position:absolute;top:80px;left:22px;right:22px;
    background:var(--bg);border-radius:var(--radius);padding:22px;gap:8px;
    box-shadow:var(--nm-raised);
  }
  .menu-toggle{display:flex;margin-left:auto}
  .match-grid,.host-grid,.guide-grid,.favorites-grid,.group-grid{grid-template-columns:1fr}
  .hero h1{font-size:2.4rem}
  .footer-inner{grid-template-columns:1fr;gap:34px}
  .cookie-inner{padding:20px 22px;gap:16px}
  .cookie-actions{width:100%}
  .cookie-btn{flex:1;text-align:center}
}
@media (max-width:480px){
  .section{padding:48px 0}
  .container{padding:0 16px}
  .hero h1{font-size:2rem}
  .hero-sub{font-size:1.05rem}
  .section-head h2{font-size:1.7rem}
  .match-card,.longread,.fav-card,.group-card,.host-card,.guide-item{padding:24px}
  .legal-content{padding:28px 24px}
  .versus{flex-direction:column;gap:18px}
  .vs-divider{align-self:flex-start}
  .hero-actions .btn{width:100%;text-align:center}
}