/* ============================================================
   YourFreeLottos.nl — Fantasy Tennis Platform
   Main Stylesheet
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Rajdhani:wght@500;600;700&display=swap');

:root {
  --bg:        #07090f;
  --bg2:       #0d1117;
  --bg3:       #161b27;
  --bg4:       #1e2536;
  --card:      #111827;
  --card2:     #1a2235;
  --green:     #10b981;
  --green2:    #059669;
  --green-gl:  rgba(16,185,129,.12);
  --gold:      #f59e0b;
  --gold2:     #d97706;
  --gold-gl:   rgba(245,158,11,.12);
  --blue:      #3b82f6;
  --blue-gl:   rgba(59,130,246,.12);
  --red:       #ef4444;
  --white:     #f9fafb;
  --gray:      #9ca3af;
  --gray2:     #6b7280;
  --border:    rgba(255,255,255,.08);
  --border2:   rgba(16,185,129,.25);
  --shadow:    0 8px 32px rgba(0,0,0,.5);
  --shadow2:   0 4px 16px rgba(0,0,0,.35);
  --radius:    12px;
  --radius2:   8px;
  --radius3:   20px;
  --transition: .25s ease;
  --font:      'Inter', sans-serif;
  --font2:     'Rajdhani', sans-serif;
  --nav-h:     70px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font);background:var(--bg);color:var(--white);line-height:1.6;min-width:300px;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:var(--font)}
input,select,textarea{font-family:var(--font)}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:var(--green2);border-radius:3px}

.section-label{display:inline-flex;align-items:center;gap:8px;font-size:.75rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--green);padding:5px 14px;border-radius:100px;background:var(--green-gl);border:1px solid var(--border2);margin-bottom:16px}
h1,h2,h3,h4{font-weight:700;line-height:1.2}
.display{font-family:var(--font2);font-weight:700;letter-spacing:.02em}
.text-green{color:var(--green)}.text-gold{color:var(--gold)}.text-gray{color:var(--gray)}.text-center{text-align:center}
.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}
.container{max-width:1180px;margin:0 auto;padding:0 24px}
.section{padding:96px 0}.section-sm{padding:64px 0}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}
.flex-between{display:flex;align-items:center;justify-content:space-between}
.flex-col{display:flex;flex-direction:column}
.gap-8{gap:8px}.gap-16{gap:16px}.gap-24{gap:24px}.gap-32{gap:32px}
.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}.mt-48{margin-top:48px}
.mb-16{margin-bottom:16px}.mb-32{margin-bottom:32px}

.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:var(--radius2);font-size:.9rem;font-weight:600;letter-spacing:.02em;transition:all var(--transition);white-space:nowrap}
.btn-primary{background:linear-gradient(135deg,var(--green),var(--green2));color:#fff;box-shadow:0 4px 20px rgba(16,185,129,.35)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(16,185,129,.5)}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#fff;box-shadow:0 4px 20px rgba(245,158,11,.35)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(245,158,11,.5)}
.btn-outline{border:1.5px solid var(--border2);color:var(--green);background:transparent}
.btn-outline:hover{background:var(--green-gl);transform:translateY(-2px)}
.btn-ghost{color:var(--gray);padding:12px 20px}
.btn-ghost:hover{color:var(--white)}
.btn-lg{padding:16px 40px;font-size:1rem}
.btn-sm{padding:8px 20px;font-size:.8rem}

.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;transition:all var(--transition)}
.card:hover{border-color:var(--border2);transform:translateY(-3px);box-shadow:var(--shadow)}
.card-glow{box-shadow:0 0 0 1px var(--border2),0 8px 32px rgba(16,185,129,.1)}

.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:100px;font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}
.badge-green{background:var(--green-gl);color:var(--green);border:1px solid var(--border2)}
.badge-gold{background:var(--gold-gl);color:var(--gold);border:1px solid rgba(245,158,11,.25)}
.badge-blue{background:var(--blue-gl);color:var(--blue);border:1px solid rgba(59,130,246,.25)}
.badge-red{background:rgba(239,68,68,.1);color:var(--red);border:1px solid rgba(239,68,68,.25)}

/* NAVBAR */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);background:rgba(7,9,15,.85);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);transition:all var(--transition)}
.navbar.scrolled{background:rgba(7,9,15,.97);box-shadow:0 4px 30px rgba(0,0,0,.5)}
.nav-inner{max-width:1280px;margin:0 auto;padding:0 24px;height:100%;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:flex;align-items:center;gap:10px;font-family:var(--font2);font-size:1.5rem;font-weight:700;color:var(--white)}
.nav-logo-icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,var(--green),var(--green2));display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(16,185,129,.4)}
.nav-logo-icon img{width:26px;height:26px}
.nav-logo span.accent{color:var(--green)}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-links a{padding:8px 14px;border-radius:var(--radius2);font-size:.875rem;font-weight:500;color:var(--gray);transition:all var(--transition)}
.nav-links a:hover,.nav-links a.active{color:var(--white);background:rgba(255,255,255,.06)}
.nav-links a.active{color:var(--green)}
.nav-auth{display:flex;align-items:center;gap:10px}
.nav-auth .btn-ghost{font-size:.875rem;padding:9px 18px}
.nav-auth .btn-primary{font-size:.875rem;padding:9px 22px}

.burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;padding:4px;background:transparent;cursor:pointer}
.burger span{display:block;height:2px;background:var(--white);border-radius:2px;transition:all .3s ease;transform-origin:center}
.burger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.burger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

.nav-mobile{display:none;position:fixed;top:var(--nav-h);left:0;right:0;bottom:0;background:rgba(7,9,15,.98);backdrop-filter:blur(20px);padding:24px;z-index:999;overflow-y:auto;flex-direction:column;gap:6px}
.nav-mobile.open{display:flex}
.nav-mobile a{display:block;padding:14px 18px;border-radius:var(--radius2);font-size:1rem;font-weight:500;color:var(--gray);border:1px solid transparent;transition:all var(--transition)}
.nav-mobile a:hover,.nav-mobile a.active{color:var(--white);background:rgba(255,255,255,.06);border-color:var(--border)}
.nav-mobile a.active{color:var(--green)}
.nav-mobile .mobile-auth{margin-top:20px;display:flex;flex-direction:column;gap:10px}
.nav-mobile .mobile-auth .btn{width:100%;justify-content:center;padding:14px}

/* HERO */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding-top:var(--nav-h);overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0;background-color:var(--bg);background-image:url('../images/hero.webp');background-size:cover;background-position:center center;background-repeat:no-repeat;}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(7,9,15,.95) 0%,rgba(7,9,15,.75) 45%,rgba(7,9,15,.88) 100%),radial-gradient(ellipse 80% 60% at 50% -20%,rgba(16,185,129,.20) 0%,transparent 60%),radial-gradient(ellipse 40% 40% at 85% 60%,rgba(245,158,11,.12) 0%,transparent 50%),radial-gradient(ellipse 50% 50% at 10% 80%,rgba(59,130,246,.08) 0%,transparent 50%);}
.hero-court-lines{position:absolute;inset:0;z-index:0;opacity:.04;background-image:linear-gradient(90deg,var(--green) 1px,transparent 1px),linear-gradient(0deg,var(--green) 1px,transparent 1px);background-size:60px 60px}
.hero-content{position:relative;z-index:1;max-width:720px}
.hero-title{font-size:clamp(2.5rem,6vw,5rem);font-family:var(--font2);font-weight:700;line-height:1.05;margin-bottom:24px}
.hero-title .line2{color:var(--green)}
.hero-sub{font-size:clamp(1rem,2vw,1.2rem);color:var(--gray);max-width:540px;margin-bottom:40px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-stats{display:flex;gap:40px;margin-top:56px;flex-wrap:wrap}
.hero-stat .num{font-family:var(--font2);font-size:2rem;font-weight:700;color:var(--white)}
.hero-stat .lbl{font-size:.8rem;color:var(--gray);margin-top:2px}
.hero-stat .num span{color:var(--green)}
.hero-visual{position:absolute;right:-60px;top:50%;transform:translateY(-50%);width:500px;z-index:1;opacity:.6}
.hero-badge-float{position:absolute;z-index:2;background:var(--card);border:1px solid var(--border2);border-radius:var(--radius);padding:14px 20px;backdrop-filter:blur(10px);box-shadow:var(--shadow)}
.hero-badge-float.top{top:20%;right:2%;animation:floatUp 3s ease-in-out infinite}
.hero-badge-float.bot{bottom:22%;right:5%;animation:floatUp 3s ease-in-out infinite .8s}
@keyframes floatUp{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

.page-hero{padding:calc(var(--nav-h) + 56px) 0 64px;background:radial-gradient(ellipse 70% 60% at 50% -10%,rgba(16,185,129,.15) 0%,transparent 60%),var(--bg2);border-bottom:1px solid var(--border);text-align:center}
.page-hero h1{font-size:clamp(2rem,4vw,3.2rem);margin-bottom:16px}
.page-hero p{font-size:1.1rem;color:var(--gray);max-width:560px;margin:0 auto}

.feature-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;font-size:1.5rem}
.feature-icon.green{background:var(--green-gl);border:1px solid var(--border2)}
.feature-icon.gold{background:var(--gold-gl);border:1px solid rgba(245,158,11,.25)}
.feature-icon.blue{background:var(--blue-gl);border:1px solid rgba(59,130,246,.25)}
.step-number{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--green2));color:#fff;font-weight:700;font-size:.95rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 14px rgba(16,185,129,.4)}

.tournament-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all var(--transition)}
.tournament-card:hover{border-color:var(--border2);transform:translateY(-4px);box-shadow:var(--shadow)}
.tc-header{padding:20px 24px;background:linear-gradient(135deg,var(--bg3),var(--bg4));border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.tc-body{padding:20px 24px}
.tc-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.tc-prize{font-family:var(--font2);font-size:1.4rem;font-weight:700;color:var(--gold)}
.tc-meta{font-size:.8rem;color:var(--gray)}
.progress-bar{height:6px;background:rgba(255,255,255,.08);border-radius:3px;overflow:hidden;margin:10px 0}
.progress-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--green),var(--green2));transition:width .6s ease}

.lb-table{width:100%;border-collapse:collapse}
.lb-table th{padding:12px 16px;text-align:left;font-size:.75rem;font-weight:600;letter-spacing:.08em;color:var(--gray);text-transform:uppercase;border-bottom:1px solid var(--border)}
.lb-table td{padding:14px 16px;font-size:.9rem;border-bottom:1px solid rgba(255,255,255,.04)}
.lb-table tr:hover td{background:rgba(255,255,255,.03)}
.lb-table tr.top-1 td{background:rgba(245,158,11,.06)}
.lb-table tr.top-2 td{background:rgba(209,213,219,.04)}
.lb-table tr.top-3 td{background:rgba(180,120,60,.05)}
.rank-badge{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem}
.rank-1{background:var(--gold-gl);color:var(--gold)}
.rank-2{background:rgba(209,213,219,.1);color:#d1d5db}
.rank-3{background:rgba(180,120,60,.1);color:#b47c3c}
.rank-n{background:rgba(255,255,255,.05);color:var(--gray)}
.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--green2),var(--blue));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;color:#fff;flex-shrink:0}

.plan-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:32px;position:relative;transition:all var(--transition);display:flex;flex-direction:column}
.plan-card.featured{border-color:var(--green);box-shadow:0 0 0 1px var(--green),0 16px 48px rgba(16,185,129,.15)}
.plan-card:hover:not(.featured){border-color:var(--border2);transform:translateY(-4px);box-shadow:var(--shadow)}
.plan-badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--green),var(--green2));color:#fff;padding:4px 18px;border-radius:100px;font-size:.72rem;font-weight:700;letter-spacing:.1em;white-space:nowrap}
.plan-price{font-family:var(--font2);font-size:3rem;font-weight:700;line-height:1;margin:16px 0 8px}
.plan-price sup{font-size:1.2rem;font-weight:500;vertical-align:super}
.plan-price span{font-size:1rem;font-weight:400;color:var(--gray)}
.plan-features{margin:24px 0;flex:1}
.plan-feature{display:flex;align-items:center;gap:10px;padding:9px 0;font-size:.875rem;color:var(--gray);border-bottom:1px solid rgba(255,255,255,.04)}
.plan-feature:last-child{border-bottom:none}
.plan-feature .check{color:var(--green);flex-shrink:0;font-size:1rem}
.plan-feature .cross{color:var(--gray2);flex-shrink:0}
.plan-feature.active{color:var(--white)}

.player-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;text-align:center;transition:all var(--transition)}
.player-card:hover{border-color:var(--border2);transform:translateY(-3px);box-shadow:var(--shadow)}
.player-avatar{width:70px;height:70px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--blue));margin:0 auto 12px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;border:2px solid var(--border2)}
.player-rank{font-size:.75rem;color:var(--gold);font-weight:600}
.player-pts{font-family:var(--font2);font-size:1.6rem;font-weight:700;color:var(--green)}
.player-pts-label{font-size:.7rem;color:var(--gray)}

.auth-page{min-height:100vh;padding-top:var(--nav-h);display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse 70% 60% at 50% 0%,rgba(16,185,129,.12) 0%,transparent 60%),var(--bg);padding-bottom:40px}
.auth-card{width:100%;max-width:460px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:40px;box-shadow:var(--shadow)}
.auth-logo{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:32px;font-family:var(--font2);font-size:1.6rem;font-weight:700}
.auth-logo-icon{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--green),var(--green2));display:flex;align-items:center;justify-content:center}
.auth-title{font-size:1.6rem;font-weight:700;text-align:center;margin-bottom:6px}
.auth-sub{font-size:.9rem;color:var(--gray);text-align:center;margin-bottom:32px}
.auth-divider{display:flex;align-items:center;gap:12px;color:var(--gray2);font-size:.8rem;margin:20px 0}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.auth-switch{text-align:center;font-size:.875rem;color:var(--gray);margin-top:20px}
.auth-switch a{color:var(--green);font-weight:600}
.auth-switch a:hover{text-decoration:underline}

.form-group{margin-bottom:20px}
.form-label{display:block;font-size:.85rem;font-weight:500;margin-bottom:8px;color:var(--gray)}
.form-label span{color:var(--red);margin-left:2px}
.form-control{width:100%;padding:12px 16px;border-radius:var(--radius2);background:var(--bg3);border:1px solid var(--border);color:var(--white);font-size:.9rem;transition:all var(--transition);outline:none}
.form-control:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(16,185,129,.15)}
.form-control::placeholder{color:var(--gray2)}
.form-control-icon{position:relative}
.form-control-icon .icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--gray2);pointer-events:none;font-size:1rem}
.form-control-icon input{padding-left:42px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-check{display:flex;align-items:flex-start;gap:10px}
.form-check input{margin-top:3px;accent-color:var(--green)}
.form-check label{font-size:.85rem;color:var(--gray);cursor:pointer}
.form-check a{color:var(--green)}
.select-control{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b7280' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
select option{background:var(--bg3)}
.password-toggle{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--gray2);cursor:pointer;font-size:1rem;padding:0}
.password-toggle:hover{color:var(--green)}
.form-hint{font-size:.78rem;color:var(--gray2);margin-top:5px}

.legal-content{max-width:820px;margin:0 auto}
.legal-content h2{font-size:1.4rem;font-weight:700;color:var(--white);margin:40px 0 12px;padding-left:16px;border-left:3px solid var(--green)}
.legal-content h3{font-size:1.1rem;font-weight:600;color:var(--gray);margin:24px 0 8px}
.legal-content p{font-size:.9rem;color:var(--gray);line-height:1.75;margin-bottom:12px}
.legal-content ul{list-style:disc;padding-left:24px;margin:12px 0}
.legal-content ul li{font-size:.9rem;color:var(--gray);margin-bottom:6px;line-height:1.6}
.legal-content a{color:var(--green)}
.legal-toc{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-bottom:48px}
.legal-toc h3{font-size:1rem;font-weight:700;color:var(--white);margin-bottom:16px}
.legal-toc ol{list-style:decimal;padding-left:20px}
.legal-toc ol li{margin-bottom:8px}
.legal-toc a{color:var(--green);font-size:.875rem}
.legal-toc a:hover{text-decoration:underline}
.legal-banner{background:var(--green-gl);border:1px solid var(--border2);border-radius:var(--radius);padding:16px 20px;display:flex;align-items:center;gap:14px;margin-bottom:40px}
.legal-banner .icon{font-size:1.4rem;flex-shrink:0}
.legal-banner p{font-size:.85rem;color:var(--gray);margin:0}
.legal-banner strong{color:var(--white)}

.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:40px;align-items:start}
.contact-info-block{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:32px}
.contact-item{display:flex;gap:16px;align-items:flex-start;padding:18px 0;border-bottom:1px solid var(--border)}
.contact-item:last-child{border-bottom:none}
.contact-icon{width:44px;height:44px;border-radius:12px;background:var(--green-gl);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.contact-text label{font-size:.75rem;color:var(--gray2);text-transform:uppercase;letter-spacing:.08em;display:block;margin-bottom:4px}
.contact-text p{font-size:.9rem;color:var(--white)}
.contact-form{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:32px}

.team-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;text-align:center;transition:all var(--transition)}
.team-card:hover{border-color:var(--border2);transform:translateY(-4px);box-shadow:var(--shadow)}
.team-avatar{width:80px;height:80px;border-radius:50%;margin:0 auto 16px;background:linear-gradient(135deg,var(--green2),var(--blue));display:flex;align-items:center;justify-content:center;font-size:2rem;border:3px solid var(--border2)}
.team-name{font-size:1.1rem;font-weight:700;margin-bottom:4px}
.team-role{font-size:.8rem;color:var(--green);font-weight:600;margin-bottom:12px}
.team-bio{font-size:.85rem;color:var(--gray);line-height:1.65}

.stats-strip{background:var(--card);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:48px 0}
.stats-strip .grid-4{text-align:center}
.stat-num{font-family:var(--font2);font-size:2.6rem;font-weight:700}
.stat-lbl{font-size:.85rem;color:var(--gray);margin-top:4px}

.quote-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:28px}
.quote-card blockquote{font-size:.95rem;color:var(--gray);line-height:1.8;font-style:italic;margin-bottom:20px}
.quote-author{display:flex;align-items:center;gap:12px}
.stars{color:var(--gold);font-size:.85rem;letter-spacing:2px;margin-bottom:12px}

.faq-item{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:10px;overflow:hidden}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;padding:18px 24px;text-align:left;background:transparent;color:var(--white);font-size:.95rem;font-weight:600;cursor:pointer;transition:all var(--transition)}
.faq-q:hover{background:rgba(255,255,255,.03)}
.faq-q .faq-icon{width:26px;height:26px;border-radius:50%;background:var(--bg4);color:var(--green);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;transition:transform .3s}
.faq-q.open .faq-icon{transform:rotate(45deg);background:var(--green-gl)}
.faq-a{padding:0 24px;max-height:0;overflow:hidden;font-size:.875rem;color:var(--gray);line-height:1.75;transition:max-height .4s ease,padding .3s ease}
.faq-a.open{max-height:300px;padding:0 24px 20px}

.cta-section{background:linear-gradient(135deg,rgba(16,185,129,.12) 0%,rgba(245,158,11,.06) 100%);border:1px solid var(--border2);border-radius:var(--radius);padding:64px 48px;text-align:center;position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 50% 50%,rgba(16,185,129,.1) 0%,transparent 70%)}
.cta-section>*{position:relative;z-index:1}
.cta-section h2{font-size:clamp(1.8rem,3vw,2.8rem);margin-bottom:16px}
.cta-section p{font-size:1rem;color:var(--gray);max-width:500px;margin:0 auto 32px}

.footer{background:var(--bg2);border-top:1px solid var(--border);padding:64px 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid var(--border)}
.footer-brand .logo-text{font-family:var(--font2);font-size:1.5rem;font-weight:700;margin-bottom:14px}
.footer-brand p{font-size:.875rem;color:var(--gray);max-width:280px;line-height:1.7}
.footer-col h4{font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray2);margin-bottom:16px}
.footer-col a{display:block;font-size:.875rem;color:var(--gray);padding:5px 0;transition:color var(--transition)}
.footer-col a:hover{color:var(--green)}
.footer-bottom{padding:20px 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.footer-bottom p{font-size:.8rem;color:var(--gray2)}
.footer-bottom .legal{display:flex;gap:20px}
.footer-bottom .legal a{font-size:.8rem;color:var(--gray2);transition:color var(--transition)}
.footer-bottom .legal a:hover{color:var(--green)}
.footer-knltb{display:flex;align-items:center;gap:10px;font-size:.78rem;color:var(--gray2);margin-top:14px}
.footer-knltb strong{color:var(--gray)}
.rg-notice{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius2);padding:12px 16px;display:flex;align-items:center;gap:10px;margin-top:20px}
.rg-notice p{font-size:.78rem;color:var(--gray2);margin:0}
.rg-notice .icon{font-size:1rem;color:var(--gold);flex-shrink:0}

.cookie-banner{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);width:calc(100% - 40px);max-width:680px;background:var(--card);border:1px solid var(--border2);border-radius:var(--radius);padding:20px 24px;box-shadow:var(--shadow);z-index:9000;display:flex;align-items:center;gap:20px;flex-wrap:wrap;animation:slideUp .4s ease}
@keyframes slideUp{from{transform:translateX(-50%) translateY(20px);opacity:0}to{transform:translateX(-50%) translateY(0);opacity:1}}
.cookie-banner p{font-size:.85rem;color:var(--gray);flex:1;min-width:220px}
.cookie-banner a{color:var(--green)}
.cookie-banner .cookie-btns{display:flex;gap:10px;flex-shrink:0}
#cookie-banner.hidden{display:none}

.divider{height:1px;background:var(--border);margin:40px 0}
.tag{display:inline-block;padding:4px 12px;border-radius:100px;font-size:.75rem;font-weight:600;background:var(--bg4);color:var(--gray);border:1px solid var(--border)}
.highlight-box{background:var(--green-gl);border:1px solid var(--border2);border-radius:var(--radius);padding:20px 24px}
.highlight-box.gold{background:var(--gold-gl);border-color:rgba(245,158,11,.25)}
.ticker{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius2);padding:14px 20px;display:flex;gap:32px;overflow-x:auto;align-items:center}
.ticker::-webkit-scrollbar{height:3px}
.ticker-item{white-space:nowrap;font-size:.82rem;color:var(--gray);flex-shrink:0}
.ticker-item strong{color:var(--white)}
.ticker-item .score{color:var(--green);font-weight:700}
.ticker-label{font-size:.7rem;color:var(--green);font-weight:700;letter-spacing:.1em;flex-shrink:0}

@media(max-width:1200px){.footer-grid{grid-template-columns:1fr 1fr 1fr}.footer-brand{grid-column:span 3}.hero-visual{width:400px;right:-20px}}
@media(max-width:991px){.nav-links,.nav-auth{display:none}.burger{display:flex}.hero-title{font-size:clamp(2rem,5vw,3.2rem)}.hero-visual,.hero-badge-float{display:none}.hero-content{max-width:100%}.grid-4{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:1fr 1fr}.contact-grid{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr 1fr;gap:32px}.footer-brand{grid-column:span 2}.cta-section{padding:48px 32px}}
@media(max-width:768px){:root{--nav-h:60px}.section{padding:72px 0}.container{padding:0 16px}.hero-stats{gap:24px}.grid-2{grid-template-columns:1fr}.grid-3{grid-template-columns:1fr}.grid-4{grid-template-columns:1fr 1fr}.stats-strip .grid-4{grid-template-columns:1fr 1fr;gap:32px}.footer-grid{grid-template-columns:1fr}.footer-brand{grid-column:span 1}.footer-bottom{flex-direction:column;text-align:center}.plan-card{padding:24px}.auth-card{padding:28px 20px}.form-row{grid-template-columns:1fr}.cta-section{padding:36px 20px}.cookie-banner{flex-direction:column;align-items:stretch}.cookie-banner .cookie-btns{flex-direction:row;justify-content:flex-end}.hero-actions{flex-direction:column}.hero-actions .btn{text-align:center;justify-content:center}}
@media(max-width:480px){.hero-title{font-size:2rem}.page-hero h1{font-size:1.8rem}.grid-4{grid-template-columns:1fr}.stats-strip .grid-4{grid-template-columns:1fr 1fr}.plan-price{font-size:2.4rem}.lb-table th,.lb-table td{padding:10px 10px;font-size:.8rem}.auth-card{padding:24px 16px}.cta-section{padding:28px 16px}.cookie-banner{padding:16px;bottom:12px}.cookie-banner .cookie-btns{flex-direction:column}.cookie-banner .cookie-btns .btn{width:100%;justify-content:center}}
@media(max-width:360px){.container{padding:0 12px}.hero-title{font-size:1.75rem}.btn{padding:10px 18px;font-size:.85rem}.btn-lg{padding:12px 24px;font-size:.9rem}.plan-card{padding:20px 14px}.auth-card{padding:20px 12px}.tc-header,.tc-body,.tc-footer{padding-left:14px;padding-right:14px}.nav-mobile a{padding:12px 14px}}
@media(max-width:320px){.container{padding:0 10px}.section{padding:52px 0}.hero-title{font-size:1.55rem}.auth-card{padding:18px 10px;margin:0 4px}.card{padding:18px 14px}}


/* ── ═══════════════════════════════════════════════
   NAV LOGO — TWO LINE
   ══════════════════════════════════════════════════ */
.nav-logo-text {
  display: flex; flex-direction: column; line-height: 1.15;
  font-size: 1.1rem;
}
.nav-logo-text span:first-child { color: var(--white); }
.nav-logo-text .accent { color: var(--green); }

/* ── ═══════════════════════════════════════════════
   SUCCESS MODAL
   ══════════════════════════════════════════════════ */
.modal-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,.7); backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  padding: 20px; opacity: 0; pointer-events: none;
  transition: opacity .3s ease;
}
.modal-overlay.open { opacity: 1; pointer-events: all; }
.modal-box {
  background: var(--card); border: 1px solid var(--border2);
  border-radius: var(--radius); padding: 40px 36px;
  max-width: 420px; width: 100%; text-align: center;
  transform: translateY(20px) scale(.97);
  transition: transform .35s cubic-bezier(.34,1.56,.64,1);
  box-shadow: 0 24px 64px rgba(0,0,0,.5);
}
.modal-overlay.open .modal-box { transform: translateY(0) scale(1); }
.modal-icon {
  width: 72px; height: 72px; border-radius: 50%;
  background: var(--green-gl); border: 2px solid var(--border2);
  display: flex; align-items: center; justify-content: center;
  font-size: 2rem; margin: 0 auto 20px;
}
.modal-icon.gold { background: var(--gold-gl); border-color: rgba(245,158,11,.3); }
.modal-box h3 { font-size: 1.4rem; font-weight: 700; margin-bottom: 10px; }
.modal-box p  { font-size: .9rem; color: var(--gray); line-height: 1.7; margin-bottom: 24px; }
.modal-close {
  position: absolute; top: 16px; right: 16px;
  background: rgba(255,255,255,.06); border: 1px solid var(--border);
  border-radius: 8px; width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--gray); font-size: 1.1rem;
  transition: all var(--transition);
}
.modal-close:hover { background: rgba(255,255,255,.12); color: var(--white); }

/* ── ═══════════════════════════════════════════════
   NEW FOOTER DESIGN
   ══════════════════════════════════════════════════ */
.footer-v2 {
  background: var(--bg2);
  border-top: 1px solid var(--border);
}
.footer-v2 .footer-top {
  padding: 56px 0 0;
}
.footer-v2 .footer-main {
  display: grid;
  grid-template-columns: 1.8fr 1fr 1fr 1fr;
  gap: 48px;
  padding-bottom: 48px;
  border-bottom: 1px solid var(--border);
}
.footer-v2 .footer-brand-logo {
  font-family: var(--font2); font-size: 2rem; font-weight: 700;
  margin-bottom: 14px; display: flex; align-items: center; gap: 12px;
}
.footer-v2 .footer-brand-logo .icon {
  width: 44px; height: 44px; border-radius: 12px;
  background: linear-gradient(135deg, var(--green), var(--green2));
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 14px rgba(16,185,129,.35);
}
.footer-v2 .footer-brand-logo .icon img { width: 30px; height: 30px; }
.footer-v2 .footer-desc {
  font-size: .875rem; color: var(--gray); max-width: 290px;
  line-height: 1.75; margin-bottom: 20px;
}
.footer-v2 .footer-stats {
  display: flex; gap: 24px; margin-bottom: 20px; flex-wrap: wrap;
}
.footer-v2 .footer-stat-item .num {
  font-family: var(--font2); font-size: 1.3rem; font-weight: 700;
  color: var(--green);
}
.footer-v2 .footer-stat-item .lbl {
  font-size: .7rem; color: var(--gray2); margin-top: 1px;
}
.footer-v2 .footer-col h4 {
  font-size: .75rem; font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; color: var(--green);
  margin-bottom: 18px; padding-bottom: 10px;
  border-bottom: 1px solid var(--border2);
}
.footer-v2 .footer-col a {
  display: flex; align-items: center; gap: 8px;
  font-size: .875rem; color: var(--gray);
  padding: 6px 0; transition: color var(--transition);
}
.footer-v2 .footer-col a::before {
  content: ''; width: 4px; height: 4px; border-radius: 50%;
  background: var(--border2); flex-shrink: 0;
  transition: background var(--transition);
}
.footer-v2 .footer-col a:hover { color: var(--white); }
.footer-v2 .footer-col a:hover::before { background: var(--green); }
.footer-v2 .footer-bottom-bar {
  background: var(--bg);
  border-top: 1px solid var(--border);
  padding: 18px 0;
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 12px;
}
.footer-v2 .footer-bottom-bar p { font-size: .78rem; color: var(--gray2); }
.footer-v2 .footer-bottom-links {
  display: flex; gap: 20px; align-items: center;
}
.footer-v2 .footer-bottom-links a {
  font-size: .78rem; color: var(--gray2);
  transition: color var(--transition);
}
.footer-v2 .footer-bottom-links a:hover { color: var(--green); }
.footer-v2 .knltb-strip {
  background: var(--bg3); border-top: 1px solid var(--border);
  padding: 14px 0;
  display: flex; align-items: center; justify-content: center;
  gap: 16px; flex-wrap: wrap;
}
.footer-v2 .knltb-strip p {
  font-size: .78rem; color: var(--gray2); text-align: center;
}
.footer-v2 .knltb-strip strong { color: var(--gray); }
.footer-v2 .rg-notice-v2 {
  display: flex; align-items: center; gap: 8px;
  background: rgba(245,158,11,.07); border: 1px solid rgba(245,158,11,.2);
  border-radius: var(--radius2); padding: 10px 14px;
  margin-top: 16px;
}
.footer-v2 .rg-notice-v2 p { font-size: .76rem; color: var(--gray2); margin: 0; }
.footer-v2 .rg-notice-v2 .icon { color: var(--gold); flex-shrink: 0; font-size: .95rem; }

/* ── ═══════════════════════════════════════════════
   STEPS REDESIGN
   ══════════════════════════════════════════════════ */
.step-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 28px 32px;
  display: flex; gap: 24px; align-items: flex-start;
  transition: all var(--transition); position: relative;
  overflow: hidden;
}
.step-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--green), var(--green2));
  transform: scaleX(0); transform-origin: left;
  transition: transform .4s ease;
}
.step-card:hover { border-color: var(--border2); box-shadow: var(--shadow); }
.step-card:hover::before { transform: scaleX(1); }
.step-num-big {
  font-family: var(--font2); font-size: 3.5rem; font-weight: 900;
  line-height: 1; color: var(--border);
  transition: color .3s;
  flex-shrink: 0; width: 52px; text-align: center;
}
.step-card:hover .step-num-big { color: rgba(16,185,129,.25); }
.step-body h3 { font-size: 1.1rem; font-weight: 700; margin-bottom: 10px; }

/* ── ═══════════════════════════════════════════════
   TOURNAMENT SORT CONTROLS
   ══════════════════════════════════════════════════ */
.sort-bar {
  display: flex; align-items: center; gap: 12px;
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 14px 20px;
  margin-bottom: 32px; flex-wrap: wrap;
}
.sort-bar label { font-size: .8rem; font-weight: 600; color: var(--gray2); white-space: nowrap; }
.sort-btn {
  padding: 7px 16px; border-radius: var(--radius2); font-size: .8rem;
  font-weight: 600; color: var(--gray); background: transparent;
  border: 1px solid transparent; cursor: pointer;
  transition: all var(--transition);
}
.sort-btn:hover { color: var(--white); border-color: var(--border); background: rgba(255,255,255,.04); }
.sort-btn.active { background: var(--green-gl); color: var(--green); border-color: var(--border2); }
.sort-btn.asc::after  { content: ' ↑'; }
.sort-btn.desc::after { content: ' ↓'; }

/* ── RESPONSIVE ADDITIONS ─────────────────────────── */
@media(max-width:991px){
  .footer-v2 .footer-main { grid-template-columns: 1fr 1fr; }
  .footer-v2 .footer-brand { grid-column: span 2; }
}
@media(max-width:768px){
  .footer-v2 .footer-main { grid-template-columns: 1fr; }
  .footer-v2 .footer-brand { grid-column: span 1; }
  .footer-v2 .footer-bottom-bar { flex-direction: column; text-align: center; }
  .step-card { flex-direction: column; gap: 12px; padding: 22px; }
  .step-num-big { font-size: 2.5rem; width: auto; }
}
@media(max-width:480px){
  .footer-v2 .footer-stats { gap: 16px; }
}

/* ============================================================
   PERFORMANCE & ACCESSIBILITY ADDITIONS
   ============================================================ */

/* font-display: swap is already set via Google Fonts ?display=swap param */

/* ── Focus visible styles (WCAG 2.1 AA) ──────────────── */
:focus-visible {
  outline: 3px solid var(--green);
  outline-offset: 3px;
  border-radius: 4px;
}
button:focus-visible,
a:focus-visible {
  outline: 3px solid var(--green);
  outline-offset: 3px;
}
/* Remove default outline only when focus-visible is supported */
:focus:not(:focus-visible) {
  outline: none;
}

/* ── High-contrast mode support ──────────────────────── */
@media (forced-colors: active) {
  .btn { border: 2px solid ButtonText; }
  .card, .tournament-card, .plan-card { border: 1px solid ButtonText; }
  .navbar { border-bottom: 2px solid ButtonText; }
}

/* ── Reduced motion ──────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* ── Print styles ────────────────────────────────────── */
@media print {
  .navbar, .nav-mobile, .burger, .cookie-banner,
  .hero-bg, .hero-court-lines, .score-ticker,
  .btn-primary, .btn-outline, .lineup-builder-wrap { display: none !important; }
  body { background: #fff !important; color: #000 !important; font-size: 12pt; }
  a[href]::after { content: ' (' attr(href) ')'; font-size: .75em; }
  .footer-v2 { background: #f5f5f5 !important; color: #000 !important; border-top: 1pt solid #ccc; }
}

/* ── Content-visibility for off-screen sections ──────── */
.section:not(:first-of-type) {
  content-visibility: auto;
  contain-intrinsic-size: 0 600px;
}

/* ── Image aspect-ratio to prevent CLS ──────────────── */
img { height: auto; }
.nav-logo-icon img,
.footer-brand-logo .icon img { width: 36px; height: 36px; }

/* ── Improved button accessibility ──────────────────── */
.btn { cursor: pointer; }
.btn:disabled,
[aria-disabled="true"] { opacity: .5; cursor: not-allowed; pointer-events: none; }

/* ── Skip link ───────────────────────────────────────── */
.skip-link {
  position: absolute;
  top: -50px; left: 6px;
  z-index: 10000;
  background: var(--green);
  color: #fff;
  padding: 10px 18px;
  border-radius: 0 0 8px 8px;
  font-weight: 700;
  font-size: .9rem;
  text-decoration: none;
  transition: top .2s ease;
}
.skip-link:focus { top: 0; outline: 3px solid #fff; outline-offset: 2px; }

/* ── Accessible form error states ────────────────────── */
.form-control[aria-invalid="true"] {
  border-color: var(--red, #ef4444);
  box-shadow: 0 0 0 3px rgba(239,68,68,.2);
}
.field-error {
  color: var(--red, #ef4444);
  font-size: .78rem;
  margin-top: 4px;
  display: block;
}

/* ── Visually hidden (screen-reader only) ────────────── */
.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* ── Aria-current for active nav links ───────────────── */
.nav-links a[aria-current="page"],
.nav-mobile a[aria-current="page"] {
  color: var(--green);
  font-weight: 700;
}
