/* =============================================
   FIVE MANAGER — Style Principal
   ============================================= */

:root {
  --bg:       #0a0c0f;
  --bg2:      #0f1218;
  --bg3:      #141820;
  --card:     #1a1f2a;
  --card2:    #1f2535;
  --border:   #2a3040;
  --green:    #00e676;
  --green2:   #00c853;
  --green-dim:rgba(0,230,118,0.12);
  --gold:     #ffd740;
  --gold2:    #ffab00;
  --red:      #ff5252;
  --red-dim:  rgba(255,82,82,0.12);
  --blue:     #448aff;
  --orange:   #ff6d00;
  --text:     #e8eaf0;
  --text2:    #8892a4;
  --text3:    #4a5568;
  --glow:     0 0 20px rgba(0,230,118,0.3);
  --glow-gold:0 0 20px rgba(255,215,64,0.3);
  --radius:   12px;
  --tr:       0.25s cubic-bezier(0.4,0,0.2,1);
}

/* ===== RESET & BASE ===== */
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{background:transparent;color:var(--text);font-family:'Rajdhani',sans-serif;font-size:16px;min-height:100vh;overflow-x:hidden;position:relative;}
::-webkit-scrollbar{width:6px;}
::-webkit-scrollbar-track{background:var(--bg2);}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px;}
::-webkit-scrollbar-thumb:hover{background:var(--green);}

/* ===== SPLASH / LOGIN ===== */
.splash-page{display:flex;align-items:center;justify-content:center;min-height:100vh;position:relative;}
.splash-bg{position:fixed;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(0,230,118,0.06) 0%,transparent 60%),radial-gradient(ellipse at 70% 20%,rgba(255,215,64,0.04) 0%,transparent 50%);pointer-events:none;}
.splash-grid{position:fixed;inset:0;background-image:linear-gradient(rgba(255,255,255,0.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.02) 1px,transparent 1px);background-size:60px 60px;animation:gridScroll 20s linear infinite;pointer-events:none;}
@keyframes gridScroll{to{background-position:60px 60px;}}
.splash-content{position:relative;z-index:1;text-align:center;animation:splashIn 0.8s cubic-bezier(0.34,1.56,0.64,1) forwards;}
@keyframes splashIn{from{opacity:0;transform:translateY(30px) scale(0.95);}to{opacity:1;transform:none;}}
.splash-icon{font-size:80px;margin-bottom:16px;filter:drop-shadow(0 0 30px rgba(0,230,118,0.5));animation:ballPulse 3s ease-in-out infinite;}
@keyframes ballPulse{0%,100%{transform:translateY(0);}50%{transform:translateY(-12px);}}
.splash-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(60px,12vw,110px);letter-spacing:8px;line-height:0.9;background:linear-gradient(135deg,#fff 0%,var(--green) 50%,var(--gold) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.splash-sub{font-family:'Barlow Condensed',sans-serif;font-weight:300;letter-spacing:6px;color:var(--text2);margin:8px 0 40px;font-size:14px;text-transform:uppercase;}
.login-box{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:32px;width:min(360px,90vw);}
.login-label{display:block;font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--text2);margin-bottom:8px;}
.login-input{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:14px 16px;color:var(--text);font-family:'Rajdhani',sans-serif;font-size:16px;outline:none;transition:var(--tr);margin-bottom:16px;}
.login-input:focus{border-color:var(--green);box-shadow:var(--glow);}
.btn-login{width:100%;background:linear-gradient(135deg,var(--green) 0%,var(--green2) 100%);border:none;border-radius:8px;padding:14px;color:#000;font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:3px;cursor:pointer;transition:var(--tr);}
.btn-login:hover{transform:translateY(-2px);box-shadow:var(--glow);}
.login-error{color:var(--red);font-size:13px;margin-top:8px;text-align:center;display:none;}

/* ===== NAV ===== */
nav{background:rgba(10,12,15,0.95);border-bottom:1px solid var(--border);backdrop-filter:blur(20px);position:sticky;top:0;z-index:100;padding:0 24px;}
.nav-inner{max-width:1400px;margin:0 auto;display:flex;align-items:center;height:64px;gap:4px;overflow-x:auto;}
.nav-logo{font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:4px;background:linear-gradient(135deg,var(--green),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-right:24px;white-space:nowrap;flex-shrink:0;}
.nav-btn{background:none;border:none;color:var(--text2);font-family:'Rajdhani',sans-serif;font-weight:600;font-size:13px;letter-spacing:1.5px;text-transform:uppercase;padding:8px 14px;border-radius:8px;cursor:pointer;transition:var(--tr);white-space:nowrap;flex-shrink:0;}
.nav-btn:hover{color:var(--text);background:var(--bg3);}
.nav-btn.active{color:var(--green);background:var(--green-dim);}
.nav-btn i{margin-right:6px;}

/* ===== PAGES ===== */
.page{display:none;max-width:1400px;margin:0 auto;padding:32px 24px;position:relative;z-index:1;}
.page.active{display:block;animation:fadeIn 0.3s ease;position:relative;z-index:1;}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}

/* ===== TYPOGRAPHY ===== */
.section-title{font-family:'Bebas Neue',sans-serif;font-size:36px;letter-spacing:4px;color:var(--text);margin-bottom:4px;}
.section-sub{color:var(--text2);font-size:14px;margin-bottom:28px;letter-spacing:1px;}

/* ===== CARDS ===== */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;}

/* ===== BUTTONS ===== */
.btn{background:var(--card2);border:1px solid var(--border);border-radius:8px;padding:10px 20px;color:var(--text);font-family:'Rajdhani',sans-serif;font-weight:600;font-size:14px;letter-spacing:1px;cursor:pointer;transition:var(--tr);display:inline-flex;align-items:center;gap:8px;}
.btn:hover{border-color:var(--green);color:var(--green);}
.btn-green{background:linear-gradient(135deg,var(--green),var(--green2));border-color:transparent;color:#000;}
.btn-green:hover{transform:translateY(-1px);box-shadow:var(--glow);color:#000;}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold2));border-color:transparent;color:#000;}
.btn-red{border-color:var(--red);color:var(--red);background:transparent;}
.btn-red:hover{background:var(--red-dim);color:var(--red);}
.btn:disabled{opacity:0.5;cursor:not-allowed;transform:none;}

/* ===== BADGES ===== */
.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;}
.badge-green{background:var(--green-dim);color:var(--green);border:1px solid rgba(0,230,118,0.3);}
.badge-red{background:var(--red-dim);color:var(--red);border:1px solid rgba(255,82,82,0.3);}
.badge-gold{background:rgba(255,215,64,0.12);color:var(--gold);border:1px solid rgba(255,215,64,0.3);}
.badge-blue{background:rgba(68,138,255,0.12);color:var(--blue);border:1px solid rgba(68,138,255,0.3);}
.badge-gray{background:rgba(255,255,255,0.05);color:var(--text2);border:1px solid var(--border);}

/* ===== STAT CARDS ===== */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px;}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;text-align:center;transition:var(--tr);}
.stat-card:hover{border-color:var(--green);transform:translateY(-2px);}
.stat-val{font-family:'Bebas Neue',sans-serif;font-size:42px;color:var(--green);line-height:1;}
.stat-lbl{font-size:11px;color:var(--text2);letter-spacing:2px;text-transform:uppercase;margin-top:4px;}

/* ===== FORMS ===== */
.form-group{margin-bottom:16px;}
.form-label{display:block;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--text2);margin-bottom:6px;}
.form-input,.form-select{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:12px 14px;color:var(--text);font-family:'Rajdhani',sans-serif;font-size:15px;outline:none;transition:var(--tr);}
.form-input:focus,.form-select:focus{border-color:var(--green);box-shadow:var(--glow);}
.form-select option{background:var(--bg3);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px;}

/* ===== TERRAIN ===== */
.pitch-layout{display:grid;grid-template-columns:280px 1fr;gap:24px;align-items:start;}
.player-panel{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;position:sticky;top:88px;}
.panel-header{background:var(--bg3);padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.panel-header h3{font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:3px;}
.player-list-scroll{max-height:calc(100vh - 220px);overflow-y:auto;}
.player-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid rgba(255,255,255,0.04);cursor:grab;transition:var(--tr);user-select:none;}
.player-item:hover{background:var(--bg3);}
.player-item.dragging{opacity:0.5;}
.player-item.absent{opacity:0.4;}
.player-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:15px;color:#000;flex-shrink:0;overflow:hidden;}
.player-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;}
.player-info{flex:1;min-width:0;}
.player-name{font-weight:700;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.player-pos{font-size:11px;color:var(--text2);letter-spacing:1px;}
.presence-btn{width:28px;height:28px;border-radius:50%;border:none;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:var(--tr);flex-shrink:0;}
.presence-btn.present{background:var(--green-dim);color:var(--green);}
.presence-btn.absent{background:var(--red-dim);color:var(--red);}
.presence-btn.uncertain{background:rgba(255,215,64,0.12);color:var(--gold);}

/* Pitch SVG */
.pitch-container{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;}
.pitch-controls{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;align-items:center;}
.pitch-svg-wrap{position:relative;background:#1a4a2a;border-radius:8px;overflow:hidden;aspect-ratio:7/10;max-height:560px;margin:0 auto;}
.pitch-svg{width:100%;height:100%;}
.placed-player{position:absolute;transform:translate(-50%,-50%);cursor:grab;text-align:center;z-index:10;user-select:none;transition:var(--tr);}
.placed-player:hover{z-index:20;transform:translate(-50%,-50%) scale(1.1);}
.placed-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:15px;color:#000;margin:0 auto 4px;border:3px solid rgba(255,255,255,0.8);box-shadow:0 4px 12px rgba(0,0,0,0.5);overflow:hidden;}
.placed-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;}
.placed-name{font-size:10px;font-weight:700;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,0.8);background:rgba(0,0,0,0.6);padding:1px 6px;border-radius:4px;white-space:nowrap;}
.team-a .placed-avatar{border-color:var(--green);}
.team-b .placed-avatar{border-color:#f44336;}

/* Score panel */
.score-panel{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-top:20px;}
.score-inputs{display:flex;align-items:center;justify-content:center;gap:20px;margin:16px 0;}
.score-team{text-align:center;}
.score-team-name{font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:2px;margin-bottom:8px;}
.score-input{width:80px;height:80px;background:var(--card);border:2px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:'Bebas Neue',sans-serif;font-size:42px;text-align:center;outline:none;transition:var(--tr);}
.score-input:focus{border-color:var(--green);}
.score-vs{font-family:'Bebas Neue',sans-serif;font-size:32px;color:var(--text3);letter-spacing:2px;}

/* Analyse proba */
.proba-panel{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-top:16px;display:none;}
.proba-bars{display:grid;grid-template-columns:1fr auto 1fr;gap:8px;align-items:center;margin:16px 0;}
.proba-bar-wrap{text-align:center;}
.proba-val{font-family:'Bebas Neue',sans-serif;font-size:36px;line-height:1;}
.proba-lbl{font-size:11px;color:var(--text2);letter-spacing:2px;margin-bottom:6px;text-transform:uppercase;}
.proba-bar{height:8px;border-radius:4px;transition:width 0.8s cubic-bezier(0.4,0,0.2,1);}
.bar-a{background:linear-gradient(90deg,var(--green),var(--green2));}
.bar-nul{background:var(--gold);}
.bar-b{background:linear-gradient(90deg,#f44336,#b71c1c);}
.proba-sep{font-family:'Bebas Neue',sans-serif;font-size:20px;color:var(--text3);text-align:center;}
.conseil-box{background:var(--bg3);border-radius:8px;padding:14px 16px;font-size:14px;margin-top:12px;border-left:3px solid var(--green);}
.conseil-box.warn{border-color:var(--red);}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:12px 0;font-size:13px;}
.detail-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid rgba(255,255,255,0.04);}
.detail-lbl{color:var(--text2);}

/* ===== JOUEURS PAGE ===== */
.players-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;}
.player-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:var(--tr);position:relative;}
.player-card:hover{border-color:var(--green);transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,0.3);}
.player-card-header{height:100px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.player-card-avatar{width:80px;height:80px;border-radius:50%;border:3px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:28px;color:#000;position:relative;z-index:1;overflow:hidden;}
.player-card-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;}
.player-card-num{position:absolute;top:8px;right:8px;font-family:'Bebas Neue',sans-serif;font-size:28px;color:rgba(255,255,255,0.12);line-height:1;}
.player-card-body{padding:16px;}
.player-card-name{font-weight:700;font-size:17px;margin-bottom:4px;}
.player-card-pos{font-size:11px;color:var(--text2);letter-spacing:2px;text-transform:uppercase;margin-bottom:12px;}
.player-card-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.pcs{text-align:center;}
.pcs-val{font-family:'Bebas Neue',sans-serif;font-size:22px;color:var(--green);}
.pcs-lbl{font-size:9px;color:var(--text3);letter-spacing:1px;text-transform:uppercase;}
.rank-badge{position:absolute;top:8px;left:8px;font-size:16px;}

/* ===== HISTORIQUE ===== */
.match-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;margin-bottom:12px;transition:var(--tr);}
.match-card:hover{border-color:var(--green);}
.match-score-display{display:flex;align-items:center;gap:12px;}
.mscore{font-family:'Bebas Neue',sans-serif;font-size:40px;line-height:1;min-width:40px;text-align:center;}
.mscore.win{color:var(--green);}
.mscore.lose{color:var(--red);}
.mscore.draw{color:var(--gold);}
.msep{font-family:'Bebas Neue',sans-serif;font-size:24px;color:var(--text3);}
.match-date{font-size:12px;color:var(--text2);letter-spacing:1px;}
.match-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px;}

/* ===== CLASSEMENT ===== */
.podium{display:flex;align-items:flex-end;justify-content:center;gap:16px;margin-bottom:40px;}
.podium-item{text-align:center;flex:1;max-width:180px;cursor:pointer;}
.podium-avatar{width:70px;height:70px;border-radius:50%;margin:0 auto 8px;display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:24px;color:#000;overflow:hidden;}
.podium-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;}
.podium-name{font-weight:700;font-size:16px;}
.podium-stat{font-size:12px;color:var(--text2);}
.podium-step{border-radius:8px 8px 0 0;display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:36px;margin-top:12px;}
.p1 .podium-step{height:100px;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000;}
.p2 .podium-step{height:70px;background:linear-gradient(135deg,#9e9e9e,#616161);color:#fff;}
.p3 .podium-step{height:50px;background:linear-gradient(135deg,#a1887f,#6d4c41);color:#fff;}
.p1 .podium-avatar{border:3px solid var(--gold);box-shadow:0 0 20px rgba(255,215,64,0.4);}
.p2 .podium-avatar{border:3px solid #9e9e9e;}
.p3 .podium-avatar{border:3px solid #a1887f;}
.lb-row{display:flex;align-items:center;gap:16px;padding:14px 20px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;transition:var(--tr);cursor:pointer;}
.lb-row:hover{border-color:var(--green);}
.lb-rank{font-family:'Bebas Neue',sans-serif;font-size:24px;color:var(--text3);width:32px;text-align:center;}
.lb-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:16px;color:#000;flex-shrink:0;overflow:hidden;}
.lb-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;}
.lb-name{font-weight:700;font-size:16px;flex:1;}
.lb-stats{display:flex;gap:20px;}
.lb-stat{text-align:center;}
.lb-stat-val{font-family:'Bebas Neue',sans-serif;font-size:20px;}
.lb-stat-lbl{font-size:10px;color:var(--text3);letter-spacing:1px;}
.trophies-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-top:16px;}
.trophy-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;text-align:center;transition:var(--tr);}
.trophy-card:hover{transform:translateY(-3px);border-color:var(--gold);}
.trophy-icon{font-size:36px;margin-bottom:8px;}
.trophy-title{font-family:'Bebas Neue',sans-serif;font-size:14px;letter-spacing:2px;color:var(--gold);margin-bottom:4px;}
.trophy-winner{font-weight:700;font-size:18px;}
.trophy-detail{font-size:12px;color:var(--text2);margin-top:2px;}

/* ===== MATCHS FUTURS ===== */
.upcoming-match{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:20px;}
.um-header{background:linear-gradient(135deg,rgba(0,230,118,0.08),rgba(0,200,83,0.03));border-bottom:1px solid var(--border);padding:20px 24px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;}
.um-date{font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:3px;color:var(--green);}
.um-meta{font-size:13px;color:var(--text2);}
.um-body{padding:20px 24px;}

/* Barre de progression */
.places-progress{margin:16px 0;}
.places-label{font-size:12px;color:var(--text2);letter-spacing:1px;text-transform:uppercase;margin-bottom:6px;display:flex;justify-content:space-between;}
.progress-bar{background:var(--border);border-radius:4px;height:10px;overflow:hidden;}
.progress-fill{height:10px;border-radius:4px;background:linear-gradient(90deg,var(--green),var(--green2));transition:width 0.5s ease;}
.progress-fill.warn{background:linear-gradient(90deg,var(--red),#b71c1c);}

/* Colonnes présence */
.presence-cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-top:16px;}
.presence-col{background:var(--bg3);border-radius:var(--radius);padding:14px;}
.presence-col-title{font-family:'Bebas Neue',sans-serif;font-size:14px;letter-spacing:2px;margin-bottom:10px;}
.presence-col-title.t-green{color:var(--green);}
.presence-col-title.t-red{color:var(--red);}
.presence-col-title.t-gold{color:var(--gold);}
.presence-col-title.t-gray{color:var(--text2);}
.presence-player{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid rgba(255,255,255,0.04);font-size:14px;font-weight:600;}
.presence-player:last-child{border:none;}
.mini-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:11px;color:#000;flex-shrink:0;overflow:hidden;}
.mini-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;}

/* SMS Section */
.sms-section{background:var(--bg3);border-radius:var(--radius);padding:20px;margin-top:16px;border:1px solid var(--border);}
.sms-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:8px;}
.sms-title{font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:3px;color:var(--text);}
.sms-filters{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px;}
.filter-btn{background:var(--card);border:1px solid var(--border);border-radius:6px;padding:5px 12px;color:var(--text2);font-family:'Rajdhani',sans-serif;font-weight:600;font-size:12px;letter-spacing:1px;cursor:pointer;transition:var(--tr);}
.filter-btn:hover,.filter-btn.active{border-color:var(--green);color:var(--green);}
.sms-player-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,0.04);}
.sms-player-row:last-child{border:none;}
.sms-checkbox{width:18px;height:18px;accent-color:var(--green);cursor:pointer;flex-shrink:0;}
.sms-check-all{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--border);margin-bottom:4px;font-weight:700;cursor:pointer;}
.sms-counter{font-size:13px;color:var(--text2);margin-top:10px;}
.sms-counter span{color:var(--green);font-weight:700;}
.sms-footer{display:flex;align-items:center;justify-content:space-between;margin-top:14px;flex-wrap:wrap;gap:8px;}
.no-phone{font-size:11px;color:var(--text3);font-style:italic;}

/* ===== MODAL ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.8);backdrop-filter:blur(8px);z-index:500;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:var(--tr);}
.modal-overlay.open{opacity:1;visibility:visible;}
.modal{background:var(--bg2);border:1px solid var(--border);border-radius:16px;width:min(700px,100%);max-height:90vh;overflow-y:auto;transform:scale(0.95);transition:var(--tr);position:relative;}
.modal-overlay.open .modal{transform:scale(1);}
.modal-header{padding:28px 28px 0;display:flex;gap:24px;align-items:center;}
.modal-avatar{width:90px;height:90px;border-radius:50%;border:3px solid var(--green);display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:32px;color:#000;flex-shrink:0;overflow:hidden;}
.modal-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;}
.modal-info h2{font-family:'Bebas Neue',sans-serif;font-size:36px;letter-spacing:3px;}
.modal-info p{color:var(--text2);font-size:13px;letter-spacing:2px;text-transform:uppercase;margin-top:4px;}
.modal-body{padding:24px 28px 28px;}
.modal-close{position:absolute;top:16px;right:16px;background:var(--card);border:1px solid var(--border);border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text2);transition:var(--tr);}
.modal-close:hover{color:var(--red);border-color:var(--red);}

/* Photo upload */
.photo-upload{display:flex;align-items:center;gap:12px;margin-bottom:20px;}
.photo-preview{width:60px;height:60px;border-radius:50%;background:var(--bg3);border:2px dashed var(--border);display:flex;align-items:center;justify-content:center;color:var(--text3);font-size:20px;overflow:hidden;cursor:pointer;transition:var(--tr);}
.photo-preview:hover{border-color:var(--green);}
.photo-preview img{width:100%;height:100%;object-fit:cover;border-radius:50%;}
.photo-file{display:none;}

/* Chart */
.chart-wrap{position:relative;height:200px;}

/* Quote */
.quote-banner{background:var(--bg3);border-left:3px solid var(--green);padding:12px 20px;margin-bottom:24px;border-radius:0 8px 8px 0;font-style:italic;color:var(--text2);font-size:15px;}

/* Pos colors */
.pos-gk{background:linear-gradient(135deg,#ffd740,#ff6f00)!important;}
.pos-def{background:linear-gradient(135deg,#448aff,#1565c0)!important;color:#fff!important;}
.pos-mid{background:linear-gradient(135deg,#69f0ae,#00c853)!important;}
.pos-att{background:linear-gradient(135deg,#ff5252,#b71c1c)!important;color:#fff!important;}

/* Empty state */
.empty-state{text-align:center;padding:60px 20px;color:var(--text3);}
.empty-state i{font-size:48px;margin-bottom:16px;display:block;}

/* Toast */
.toast{position:fixed;bottom:24px;right:24px;background:var(--card2);border:1px solid var(--green);border-radius:var(--radius);padding:14px 20px;color:var(--text);font-weight:600;z-index:9000;transform:translateX(120%);transition:transform 0.3s cubic-bezier(0.34,1.56,0.64,1);max-width:320px;}
.toast.show{transform:translateX(0);}
.toast i{color:var(--green);margin-right:8px;}

/* Confetti */
.confetti-container{position:fixed;inset:0;pointer-events:none;z-index:9999;}
.confetti-piece{position:absolute;width:10px;height:10px;animation:confettiFall 3s ease-in forwards;}
@keyframes confettiFall{0%{transform:translateY(-20px) rotate(0deg);opacity:1;}100%{transform:translateY(100vh) rotate(720deg);opacity:0;}}

/* Domination */
.domination-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.85);z-index:8000;display:flex;align-items:center;justify-content:center;flex-direction:column;text-align:center;opacity:0;visibility:hidden;transition:var(--tr);}
.domination-overlay.show{opacity:1;visibility:visible;}
.dom-text{font-family:'Bebas Neue',sans-serif;font-size:clamp(50px,12vw,100px);letter-spacing:6px;background:linear-gradient(135deg,var(--gold),var(--green));-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:domPulse 0.5s ease infinite alternate;}
@keyframes domPulse{to{transform:scale(1.05);}}
.dom-sub{color:var(--text);font-size:18px;letter-spacing:3px;margin-top:8px;}

/* Responsive */
@media(max-width:900px){.pitch-layout{grid-template-columns:1fr;}.player-panel{position:static;}}
@media(max-width:600px){.form-row{grid-template-columns:1fr;}.lb-stats{gap:10px;}.podium{gap:8px;}.lb-stat-lbl{display:none;}}

/* ===== PUB IRONIQUE ===== */
.pub-banner {
  background: linear-gradient(135deg, #1a0a2e, #2d1b4e);
  border: 1px solid rgba(180,0,255,0.3);
  border-radius: var(--radius);
  margin-bottom: 20px;
  overflow: hidden;
  position: relative;
}
.pub-inner {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 16px;
}
.pub-tag {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 10px;
  letter-spacing: 2px;
  color: rgba(180,0,255,0.8);
  border: 1px solid rgba(180,0,255,0.4);
  padding: 2px 6px;
  border-radius: 4px;
  white-space: nowrap;
  flex-shrink: 0;
}
.pub-text {
  font-size: 13px;
  color: #c084fc;
  flex: 1;
  font-style: italic;
}
.pub-close {
  background: none;
  border: none;
  color: rgba(180,0,255,0.6);
  cursor: pointer;
  font-size: 16px;
  padding: 2px 6px;
  border-radius: 4px;
  transition: var(--tr);
  flex-shrink: 0;
}
.pub-close:hover { color: #c084fc; background: rgba(180,0,255,0.1); }

/* ===== PITCH SLOT EMPTY ===== */
.pitch-slot-empty {
  cursor: default;
  transition: var(--tr);
}
.pitch-slot-empty:hover > div {
  opacity: 0.9 !important;
  border-style: solid !important;
}

/* ===== FIABILITE BADGE ===== */
.fiabilite-high { color: var(--green); }
.fiabilite-mid  { color: var(--gold); }
.fiabilite-low  { color: var(--red); }

/* ===== BANNIERE PROCHAIN MATCH ===== */
.next-match-banner {
  background: linear-gradient(135deg, rgba(0,230,118,0.08), rgba(0,200,83,0.03));
  border: 1px solid rgba(0,230,118,0.25);
  border-radius: var(--radius);
  padding: 12px 20px;
  margin-bottom: 16px;
  font-size: 14px;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}

/* ===== JOUEUR PLACÉ (grisé sidebar) ===== */
.player-placed {
  opacity: 0.35 !important;
  pointer-events: none !important;
}
.player-placed .player-name { text-decoration: line-through; }

/* ===== IMAGE FUN ===== */
.fun-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  text-align: center;
}
.fun-img-wrap {
  width: 100%;
  aspect-ratio: 16/10;
  overflow: hidden;
  background: var(--bg3);
}
.fun-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.fun-caption {
  padding: 10px 12px 4px;
  font-size: 12px;
  color: var(--text2);
  font-style: italic;
  min-height: 36px;
}
.fun-next {
  background: none;
  border: none;
  color: var(--text3);
  cursor: pointer;
  font-size: 12px;
  padding: 4px 12px 10px;
  transition: var(--tr);
}
.fun-next:hover { color: var(--green); }

/* ===== BACKGROUND TERRAIN ===== */
.bg-pitch {
  position: fixed; inset: 0; z-index: -1; pointer-events: none;
  background: linear-gradient(160deg, #060810 0%, #0a0f18 40%, #07090f 100%);
  overflow: hidden;
}
.bg-pitch::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 15% 60%, rgba(0,180,50,0.07) 0%, transparent 55%),
    radial-gradient(ellipse at 85% 20%, rgba(0,50,180,0.05) 0%, transparent 50%),
    radial-gradient(ellipse at 50% 90%, rgba(0,230,118,0.04) 0%, transparent 40%);
}
.bg-pitch svg { width:100%; height:100%; opacity:0.9; }
/* Assurer que html a aussi le bon fond */
html { background: #060810; }
#pageWrap { position: relative; z-index: 1; }
nav { position: sticky; top:0; z-index: 100; }

/* ===== CITATION MISE EN VALEUR ===== */
.citation-block {
  display: flex; align-items: flex-start; gap: 12px;
  background: linear-gradient(135deg, rgba(0,230,118,0.06), rgba(255,215,64,0.03));
  border: 1px solid rgba(0,230,118,0.2);
  border-radius: var(--radius);
  padding: 20px 24px;
  margin-bottom: 24px;
  position: relative;
  overflow: hidden;
}
.citation-block::before {
  content: '';
  position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: linear-gradient(180deg, var(--green), var(--gold));
}
.citation-icon {
  font-family: Georgia, serif;
  font-size: 36px;
  color: var(--green);
  opacity: 0.5;
  line-height: 1;
  flex-shrink: 0;
  margin-top: -4px;
}
.citation-close { margin-top: auto; align-self: flex-end; }
.citation-text {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 18px;
  font-weight: 400;
  font-style: italic;
  color: var(--text);
  line-height: 1.5;
  flex: 1;
  letter-spacing: 0.5px;
}

/* ===== MOBILE NAV ===== */
#desktopNav { display: flex; }

#mobileNav {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 200;
  height: 58px;
  max-height: 58px;
  min-height: 58px;
  background: rgba(10,12,15,0.97);
  border-top: 1px solid var(--border);
  backdrop-filter: blur(20px);
  display: none;
  grid-template-columns: repeat(8,1fr);
  align-items: center;
  overflow: hidden;
  padding-bottom: 0;
}
.mob-btn {
  background: none; border: none;
  color: var(--text3);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 4px 2px;
  cursor: pointer;
  transition: var(--tr);
  font-family: 'Rajdhani', sans-serif;
  gap: 2px;
  height: 58px;
  max-height: 58px;
  overflow: hidden;
  width: 100%;
}
.mob-btn i  { font-size: 18px; }
.mob-btn span { font-size: 9px; letter-spacing: 0.5px; text-transform: uppercase; }
.mob-btn.active { color: var(--green); }

#pageWrap {
  max-width: 1400px;
  margin: 0 auto;
  padding: 24px 24px 32px;
}

/* ===== ARTICLE BLOG ===== */
.article-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px 24px;
  margin-bottom: 16px;
  cursor: pointer;
  transition: var(--tr);
}
.article-card:hover { border-color: var(--gold); transform: translateY(-2px); }
.article-meta  { display:flex; gap:12px; align-items:center; margin-bottom:10px; }
.article-date  { font-size:12px; color:var(--text2); }
.article-title {
  font-family:'Bebas Neue',sans-serif;
  font-size:22px; letter-spacing:2px;
  margin-bottom:8px; line-height:1.1;
}
.article-excerpt { font-size:14px; color:var(--text2); line-height:1.6; margin-bottom:12px; }
.article-footer { display:flex; justify-content:space-between; align-items:center; }
.article-full-content { font-size:15px; line-height:1.8; color:var(--text); }
.article-full-content p { margin-bottom:12px; }

/* ===== BLEUS ===== */
.bleus-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:16px; }
.bleus-card { background:var(--card); border:1px solid var(--border); border-radius:var(--radius); padding:16px; transition:var(--tr); }
.bleus-card:hover { border-color:var(--blue); }
.bleus-league { font-size:10px; letter-spacing:2px; color:var(--blue); text-transform:uppercase; margin-bottom:4px; }
.bleus-date   { font-size:12px; color:var(--text2); margin-bottom:12px; }
.bleus-match  { display:flex; align-items:center; gap:8px; }
.bleus-team   { display:flex; flex-direction:column; align-items:center; gap:6px; flex:1; }
.bleus-team-right { align-items:flex-end; }
.bleus-logo   { width:32px; height:32px; object-fit:contain; }
.bleus-name   { font-size:13px; font-weight:700; text-align:center; }
.bleus-france { color:var(--blue); }
.bleus-score  { display:flex; align-items:center; gap:6px; padding:0 8px; }
.bleus-vs     { font-family:'Bebas Neue',sans-serif; font-size:20px; color:var(--text3); padding:0 8px; }
.score-win  { font-family:'Bebas Neue',sans-serif; font-size:32px; color:var(--green); }
.score-lose { font-family:'Bebas Neue',sans-serif; font-size:32px; color:var(--red); }
.score-draw { font-family:'Bebas Neue',sans-serif; font-size:32px; color:var(--gold); }
.score-sep  { font-family:'Bebas Neue',sans-serif; font-size:24px; color:var(--text3); }
.bleus-result { text-align:center; margin-top:10px; font-size:13px; font-weight:700; padding:4px; border-radius:6px; }
.bleus-win  { background:var(--green-dim); color:var(--green); }
.bleus-lose { background:var(--red-dim); color:var(--red); }
.bleus-draw { background:rgba(255,215,64,0.1); color:var(--gold); }
.bleus-api-notice { text-align:center; padding:40px 20px; }

/* ===== SAISONS & RIVALITÉS ===== */
.saison-card { background:var(--card); border:1px solid var(--border); border-radius:var(--radius); padding:20px; margin-bottom:16px; }
.saison-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; }
.saison-title { font-family:'Bebas Neue',sans-serif; font-size:20px; letter-spacing:3px; color:var(--gold); }
.saison-stats { font-size:12px; color:var(--text2); }
.saison-winner { font-size:14px; margin-bottom:10px; color:var(--text); }
.saison-rank { font-size:14px; padding:4px 0; border-bottom:1px solid rgba(255,255,255,0.04); }
.saison-rank:last-child { border:none; }
.palmares-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:16px; margin-bottom:24px; }
.palmares-card { background:var(--card); border:1px solid var(--border); border-radius:var(--radius); padding:20px; text-align:center; }
.palmares-year { font-size:11px; letter-spacing:2px; color:var(--text2); text-transform:uppercase; margin-bottom:8px; }
.palmares-trophy { font-size:28px; margin-bottom:8px; }
.palmares-avatar { width:50px; height:50px; border-radius:50%; margin:0 auto 8px; display:flex; align-items:center; justify-content:center; font-family:'Bebas Neue',sans-serif; font-size:18px; color:#000; overflow:hidden; border:2px solid var(--gold); }
.palmares-avatar img { width:100%; height:100%; object-fit:cover; border-radius:50%; }
.palmares-name { font-weight:700; font-size:14px; }
.palmares-stat { font-size:11px; color:var(--text2); margin-top:3px; }
.rivalite-card { background:var(--card); border:1px solid var(--border); border-radius:var(--radius); padding:20px; margin-bottom:12px; }
.rivalite-players { display:flex; align-items:center; justify-content:space-between; gap:16px; margin-bottom:12px; }
.rivalite-player { text-align:center; flex:1; }
.rivalite-avatar { width:52px; height:52px; border-radius:50%; margin:0 auto 6px; display:flex; align-items:center; justify-content:center; font-family:'Bebas Neue',sans-serif; font-size:18px; color:#000; overflow:hidden; }
.rivalite-avatar img { width:100%; height:100%; object-fit:cover; border-radius:50%; }
.rivalite-name { font-weight:700; font-size:15px; }
.rivalite-wins { font-family:'Bebas Neue',sans-serif; font-size:20px; }
.rivalite-bar { display:flex; border-radius:4px; overflow:hidden; height:6px; background:var(--border); }

/* ===== SUPPR HISTORIQUE ===== */
.match-card-actions { display:flex; justify-content:flex-end; margin-top:12px; }

/* ===== RESPONSIVE MOBILE ===== */
@media (max-width: 768px) {
  #desktopNav { display: none !important; }
  #mobileNav  { display: grid !important; height: 58px !important; max-height: 58px !important; }

  /* Fix principal mobile portrait */
  html, body {
    height: 100%;
    overflow-x: hidden;
    background: #060810;
  }

  /* bg-pitch doit rester visible */
  .bg-pitch {
    position: fixed !important;
    inset: 0 !important;
    z-index: 0 !important;
  }

  /* pageWrap au-dessus du bg, sous la bottom bar */
  #pageWrap {
    position: relative !important;
    z-index: 1 !important;
    padding: 16px 12px 100px !important;
    min-height: calc(100vh - 60px) !important;
    display: block !important;
  }

  /* Pages visibles */
  .page { display: none !important; }
  .page.active { display: block !important; }

  .pitch-layout { grid-template-columns: 1fr; gap: 12px; }
  .player-panel { position: static; max-height: 280px; }
  .player-list-scroll { max-height: 200px; }
  .citation-block { padding: 14px 16px; }
  .citation-text { font-size: 14px; }
  .citation-icon { font-size: 26px; }
  .form-row { grid-template-columns: 1fr; }
  .score-inputs { gap: 10px; }
  .score-input { width: 72px; height: 72px; font-size: 36px; }
  .lb-stats { gap: 8px; flex-wrap: wrap; }
  .lb-stat-lbl { display: none; }
  .lb-name { font-size: 14px; }
  .podium { gap: 8px; }
  .bleus-grid { grid-template-columns: 1fr; }
  .players-grid { grid-template-columns: repeat(2, 1fr); }
  .btn-label { display: none; }
  .stat-grid { grid-template-columns: repeat(3, 1fr); }
  .section-title { font-size: 26px; letter-spacing: 2px; }
  .section-sub { font-size: 12px; margin-bottom: 16px; }
  .pitch-svg-wrap { max-height: 400px; }
  .placed-avatar { width: 36px; height: 36px; font-size: 12px; }
  .placed-name { font-size: 9px; }
  .card { padding: 16px; }
  .score-panel { padding: 16px; }
  .pitch-container { padding: 16px; }
  .pitch-controls { gap: 8px; }
  .stat-card { padding: 14px 10px; }
  .stat-val { font-size: 32px; }
  .player-card-header { height: 80px; }
  .player-card-avatar { width: 64px; height: 64px; font-size: 22px; }
  .trophies-grid { grid-template-columns: repeat(2, 1fr); }
  .modal { width: 100% !important; max-height: 85vh; border-radius: 16px 16px 0 0; }
  .modal-overlay { align-items: flex-end; padding: 0; }
  .next-match-banner { font-size: 12px; padding: 10px 14px; }
  .match-score-display { gap: 8px; }
  .mscore { font-size: 32px; }
  .article-card { padding: 16px; }
  .article-title { font-size: 18px; }
  .prono-btns { flex-direction: column; }
  .prono-btn { text-align: center; }
}

@media (max-width: 400px) {
  .players-grid { grid-template-columns: 1fr; }
  .mob-btn span { display: none; }
  #mobileNav { grid-template-columns: repeat(8, 1fr); }
  .trophies-grid { grid-template-columns: 1fr; }
}

/* ===== BLEUS v2 ===== */
.bleus-header { display:flex; align-items:center; gap:20px; margin-bottom:24px; }
.bleus-flag   { font-size:48px; }
.bleus-prono-block { margin-top:8px; }
.prono-card   { background:var(--card); border:1px solid rgba(0,35,149,0.4); border-radius:var(--radius); padding:24px; max-width:500px; }
.prono-title  { font-family:'Bebas Neue',sans-serif; font-size:15px; letter-spacing:2px; color:var(--blue); margin-bottom:8px; }
.prono-question { font-size:16px; font-weight:700; margin-bottom:16px; }
.prono-btns   { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:16px; }
.prono-btn    { padding:10px 18px; border-radius:8px; border:2px solid; font-family:'Rajdhani',sans-serif; font-weight:700; font-size:14px; cursor:pointer; transition:var(--tr); }
.prono-blue   { background:rgba(0,35,149,0.15); border-color:#002395; color:#4d79ff; }
.prono-blue:hover { background:rgba(0,35,149,0.3); }
.prono-gray   { background:var(--bg3); border-color:var(--border); color:var(--text2); }
.prono-gray:hover { border-color:var(--text2); }
.prono-red    { background:rgba(237,41,57,0.1); border-color:#ED2939; color:#ff6b78; }
.prono-red:hover { background:rgba(237,41,57,0.2); }
.prono-result-title { font-size:11px; letter-spacing:2px; color:var(--text2); text-transform:uppercase; margin-bottom:12px; }
.prono-result-row { display:flex; align-items:center; gap:12px; margin-bottom:8px; font-size:13px; }
.prono-result-row span:first-child { width:140px; flex-shrink:0; }
.prono-result-row span:last-child  { width:36px; text-align:right; font-weight:700; flex-shrink:0; }
.prono-bar-wrap { flex:1; background:var(--border); border-radius:4px; height:8px; overflow:hidden; }
.prono-bar      { height:8px; border-radius:4px; transition:width 0.6s; }

/* ===== CAROUSEL ===== */
.carousel-wrap {
  position: relative;
  width: 100vw;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  height: 240px;
  overflow: hidden;
  margin-bottom: 0;
  flex-shrink: 0;
}
@media(max-width:768px) { .carousel-wrap { height: 170px; } }

.carousel-track {
  display: flex;
  height: 100%;
  transition: transform 0.7s cubic-bezier(0.4, 0, 0.2, 1);
}

.carousel-slide {
  min-width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden;
}

.carousel-slide-bg {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  filter: brightness(0.45) saturate(1.2);
  transform: scale(1.05);
  transition: transform 8s ease;
}
.carousel-slide.active .carousel-slide-bg { transform: scale(1.0); }

.carousel-slide-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(
    to right,
    rgba(0,0,0,0.7) 0%,
    rgba(0,0,0,0.2) 50%,
    rgba(0,0,0,0.05) 100%
  );
}

.carousel-slide-content {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  justify-content: center;
  padding: 0 48px;
}
@media(max-width:768px) { .carousel-slide-content { padding: 0 20px; } }

.carousel-tag {
  display: inline-block;
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--green);
  border: 1px solid rgba(0,230,118,0.4);
  padding: 3px 10px;
  border-radius: 20px;
  margin-bottom: 10px;
  width: fit-content;
}

.carousel-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(22px, 4vw, 42px);
  letter-spacing: 3px;
  line-height: 1.05;
  color: #fff;
  text-shadow: 0 2px 20px rgba(0,0,0,0.8);
  max-width: 600px;
}

.carousel-sub {
  font-size: clamp(12px, 1.5vw, 15px);
  color: rgba(255,255,255,0.65);
  margin-top: 8px;
  letter-spacing: 1px;
  max-width: 400px;
}
@media(max-width:768px) { .carousel-sub { display: none; } }

/* Dots navigation */
.carousel-dots {
  position: absolute;
  bottom: 14px; left: 50%;
  transform: translateX(-50%);
  display: flex; gap: 6px; z-index: 10;
}
.carousel-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: rgba(255,255,255,0.3);
  cursor: pointer;
  transition: all 0.3s;
  border: none; padding: 0;
}
.carousel-dot.active {
  background: var(--green);
  width: 20px;
  border-radius: 3px;
}

/* Flèches */
.carousel-arrow {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: rgba(0,0,0,0.4);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 50%;
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; z-index: 10;
  color: #fff; font-size: 14px;
  transition: var(--tr);
  backdrop-filter: blur(4px);
}
.carousel-arrow:hover { background: rgba(0,230,118,0.3); border-color: var(--green); }
.carousel-arrow-left  { left: 16px; }
.carousel-arrow-right { right: 16px; }
@media(max-width:768px) { .carousel-arrow { display: none; } }

/* Barre de progression slide */
.carousel-progress {
  position: absolute;
  bottom: 0; left: 0;
  height: 3px;
  background: var(--green);
  transition: width 0.1s linear;
  z-index: 10;
}

/* ===== THÈME CLAIR ===== */
[data-theme="light"] {
  --bg:       #f0f2f5;
  --bg2:      #e8eaed;
  --bg3:      #dde0e4;
  --card:     #ffffff;
  --card2:    #f8f9fa;
  --border:   #d0d4da;
  --text:     #1a1a2e;
  --text2:    #555e6b;
  --text3:    #9aa0ab;
  --green-dim:rgba(0,180,80,0.1);
  --red-dim:  rgba(220,50,50,0.1);
}
[data-theme="light"] body { background: #f0f2f5; }
[data-theme="light"] .bg-pitch { opacity: 0.3; }
[data-theme="light"] nav { background: rgba(240,242,245,0.95); }
[data-theme="light"] .stat-val { color: #00aa44; }

/* ===== SPLASH ===== */
.app-splash {
  position: fixed; inset: 0; z-index: 9999;
  background: #060810;
  display: flex; align-items: center; justify-content: center;
  transition: opacity 0.6s ease, transform 0.6s ease;
  overflow: hidden;
}
.splash-bg-grid {
  position: absolute; inset: 0;
  background-image: linear-gradient(rgba(0,230,118,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,230,118,0.03) 1px, transparent 1px);
  background-size: 50px 50px;
  animation: gridScroll 15s linear infinite;
}
.splash-pitch-lines {
  position: absolute; inset: 0;
  opacity: 0.5;
  animation: pitchFadeIn 1s ease forwards;
}
@keyframes pitchFadeIn { from { opacity:0; transform:scale(1.1); } to { opacity:0.5; transform:scale(1); } }
.splash-projector {
  position: absolute;
  top: -20%;
  left: 25%;
  width: 200px; height: 120%;
  background: linear-gradient(180deg, rgba(0,230,118,0.12) 0%, transparent 70%);
  transform: rotate(-15deg);
  animation: projectorSweep 3s ease-in-out infinite alternate;
  pointer-events: none;
}
.splash-projector-2 {
  left: 55%;
  background: linear-gradient(180deg, rgba(255,215,64,0.08) 0%, transparent 70%);
  animation: projectorSweep 3s ease-in-out infinite alternate-reverse;
}
@keyframes projectorSweep { from { opacity:0.6; transform:rotate(-15deg); } to { opacity:1; transform:rotate(-5deg); } }
.splash-content {
  position: relative; z-index: 1;
  text-align: center;
  animation: splashContentIn 0.8s cubic-bezier(0.34,1.56,0.64,1) forwards;
}
@keyframes splashContentIn { from { opacity:0; transform:translateY(20px); } to { opacity:1; transform:none; } }
.splash-ball {
  font-size: 64px;
  animation: ballBounce 1s ease-in-out infinite;
  display: block; margin-bottom: 16px;
  filter: drop-shadow(0 0 20px rgba(0,230,118,0.4));
}
@keyframes ballBounce { 0%,100%{transform:translateY(0);} 50%{transform:translateY(-14px);} }
.splash-logo {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(60px, 15vw, 120px);
  letter-spacing: 12px;
  background: linear-gradient(135deg, #fff 0%, var(--green) 50%, var(--gold) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  line-height: 0.9;
}
.splash-tagline {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 14px; letter-spacing: 8px;
  color: rgba(255,255,255,0.4);
  text-transform: uppercase;
  margin: 10px 0 32px;
}
.splash-loader {
  width: 200px; height: 3px;
  background: rgba(255,255,255,0.1);
  border-radius: 2px;
  margin: 0 auto;
  overflow: hidden;
}
.splash-loader-bar {
  height: 100%;
  background: linear-gradient(90deg, var(--green), var(--gold));
  border-radius: 2px;
  animation: splashLoad 1.6s cubic-bezier(0.4,0,0.2,1) forwards;
}
@keyframes splashLoad { from { width:0; } to { width:100%; } }

/* ===== BG PROJECTEUR ANIMÉ ===== */
.bg-projector {
  position: absolute; z-index: -1;
  top: -30%;
  left: 20%;
  width: 300px;
  height: 140%;
  background: linear-gradient(180deg, rgba(0,230,118,0.07) 0%, transparent 65%);
  transform: rotate(-20deg);
  animation: bgProjAnim 8s ease-in-out infinite alternate;
  pointer-events: none;
}
.bg-proj2 {
  left: 55%;
  background: linear-gradient(180deg, rgba(255,215,64,0.05) 0%, transparent 65%);
  animation: bgProjAnim 10s ease-in-out infinite alternate-reverse;
}
@keyframes bgProjAnim {
  0%   { opacity:0.4; transform:rotate(-20deg); }
  50%  { opacity:0.8; transform:rotate(-8deg); }
  100% { opacity:0.4; transform:rotate(-20deg); }
}

/* ===== BANNIÈRE CE SOIR ===== */
.tonight-banner {
  background: linear-gradient(135deg, rgba(0,230,118,0.15), rgba(0,200,83,0.08));
  border: 1px solid rgba(0,230,118,0.4);
  border-radius: var(--radius);
  padding: 14px 20px;
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  animation: tonightPulse 2s ease-in-out infinite;
}
@keyframes tonightPulse {
  0%,100% { box-shadow: 0 0 0 rgba(0,230,118,0); }
  50%     { box-shadow: 0 0 20px rgba(0,230,118,0.2); }
}

/* ===== TIRAGE AU SORT ===== */
.tirage-spinning { min-height: 100px; display:flex; align-items:center; justify-content:center; }
.tirage-spin-name {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 48px; letter-spacing: 6px;
  color: var(--green);
  text-shadow: 0 0 20px rgba(0,230,118,0.5);
  animation: spinNameFlash 0.1s ease;
}
@keyframes spinNameFlash { from { opacity:0.3; } to { opacity:1; } }
.tirage-result { display:grid; grid-template-columns:1fr auto 1fr; gap:16px; margin-top:8px; }
.tirage-team { text-align:center; }
.tirage-team-title { font-family:'Bebas Neue',sans-serif; font-size:18px; letter-spacing:3px; margin-bottom:12px; }
.tirage-player {
  display:flex; align-items:center; gap:10px;
  padding:8px 12px; border-radius:8px;
  background:var(--bg3); margin-bottom:6px;
  opacity:0; transform:translateX(-20px);
}
.tirage-player.tirage-reveal {
  animation: tirageReveal 0.4s cubic-bezier(0.34,1.56,0.64,1) forwards;
}
@keyframes tirageReveal { to { opacity:1; transform:translateX(0); } }
.tirage-avatar {
  width:36px; height:36px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-family:'Bebas Neue',sans-serif; font-size:13px; color:#000;
  flex-shrink:0; overflow:hidden;
}
.tirage-separator {
  font-family:'Bebas Neue',sans-serif; font-size:32px; color:var(--text3);
  display:flex; align-items:center; justify-content:center;
}
@media(max-width:480px) {
  .tirage-result { grid-template-columns:1fr; }
  .tirage-separator { display:none; }
}

/* ===== MÉTÉO OVERLAY TERRAIN ===== */
.meteo-overlay {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 20;
  pointer-events: none;
}
.meteo-overlay > div {
  background: rgba(10,12,15,0.75) !important;
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,0.12) !important;
  border-radius: 8px !important;
  padding: 6px 12px !important;
  font-size: 13px !important;
}

/* ===== LOGO CLIQUABLE ===== */
a.nav-logo {
  cursor: pointer;
  transition: var(--tr);
  display: flex;
  align-items: center;
}
a.nav-logo:hover {
  opacity: 0.8;
  transform: scale(1.03);
}

/* ===== TERRAIN MOBILE TOUCH ===== */
@media (max-width: 768px) {
  /* Terrain plus petit pour laisser de la place */
  .pitch-svg-wrap {
    max-height: 340px !important;
    touch-action: none;
  }

  /* Colonne gauche pleine largeur */
  .pitch-layout > *:first-child {
    width: 100% !important;
  }
  .pitch-layout > div:first-child {
    width: 100% !important;
  }

  /* Slots plus grands pour les doigts */
  .placed-avatar {
    width: 38px !important;
    height: 38px !important;
  }

  /* Player list plus compacte */
  .player-item {
    padding: 8px 12px !important;
  }

  /* Pitch layout colonne unique avec ordre correct */
  .pitch-layout {
    display: flex !important;
    flex-direction: column !important;
  }

  /* Score panel inputs en colonne sur mobile */
  .score-inputs {
    gap: 8px !important;
  }
  .score-input {
    width: 64px !important;
    height: 64px !important;
    font-size: 30px !important;
  }
}

/* ===== HERO HEADER ===== */
.hero-header {
  position: relative;
  border-radius: var(--radius);
  height: 220px;
  overflow: hidden;
  margin-bottom: 24px;
  flex-shrink: 0;
}
@media(max-width:768px) { .hero-header { height: 160px; margin-bottom: 16px; } }

/* Terrain SVG parallax en fond */
.hero-bg {
  position: absolute; inset: 0;
  background-image: url('../hero.jpg');
  background-size: cover;
  background-position: center 30%;
  filter: brightness(0.32) saturate(1.1);
  transform: scale(1.08);
  transform-origin: center center;
  transition: transform 0.1s linear;
  will-change: transform;
}

/* Dégradé par-dessus la photo */
.hero-bg::after {
  content: '';
  position: absolute; inset: 0;
  background:
    linear-gradient(to right,  rgba(0,0,0,0.65) 0%, rgba(0,0,0,0.1) 60%, rgba(0,0,0,0.4) 100%),
    linear-gradient(to bottom, rgba(0,0,0,0.3) 0%, rgba(0,0,0,0.0) 50%, rgba(0,0,0,0.5) 100%);
}

/* Lignes lumineuses animées par-dessus */
.hero-light {
  position: absolute;
  top: -40%; left: 8%;
  width: 120px; height: 180%;
  background: linear-gradient(180deg, rgba(255,215,64,0.12) 0%, transparent 60%);
  transform: rotate(-20deg);
  animation: heroLightAnim 6s ease-in-out infinite alternate;
  mix-blend-mode: screen;
}
.hero-light-2 {
  left: 55%;
  background: linear-gradient(180deg, rgba(0,230,118,0.08) 0%, transparent 60%);
  animation: heroLightAnim 9s ease-in-out infinite alternate-reverse;
}
@keyframes heroLightAnim {
  from { opacity:0.4; transform:rotate(-20deg) translateX(0); }
  to   { opacity:0.9; transform:rotate(-12deg) translateX(15px); }
}

/* SVG terrain en overlay subtil */
.hero-pitch-svg {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  opacity: 0.06;
  transform: perspective(500px) rotateX(18deg) scale(1.4);
  transform-origin: center bottom;
}

/* Contenu */
.hero-content {
  position: relative; z-index: 2;
  height: 100%;
  display: flex;
  align-items: center;
  padding: 0 36px;
  gap: 32px;
}
@media(max-width:768px) { .hero-content { padding: 0 20px; gap: 16px; } }

.hero-logo-block {
  flex-shrink: 0;
  text-align: center;
}
.hero-logo-icon {
  font-size: 44px;
  display: block;
  filter: drop-shadow(0 0 16px rgba(0,230,118,0.6));
  animation: heroball 3s ease-in-out infinite;
  line-height: 1;
}
@keyframes heroball {
  0%,100% { transform: translateY(0) rotate(0deg); }
  50%      { transform: translateY(-6px) rotate(15deg); }
}
@media(max-width:768px) { .hero-logo-icon { font-size: 32px; } }

.hero-divider {
  width: 1px; height: 80px;
  background: linear-gradient(180deg, transparent, rgba(0,230,118,0.3), transparent);
  flex-shrink: 0;
}
@media(max-width:768px) { .hero-divider { display: none; } }

.hero-text { flex: 1; }
.hero-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 10px; letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--green);
  border: 1px solid rgba(0,230,118,0.35);
  background: rgba(0,230,118,0.06);
  padding: 3px 10px; border-radius: 20px;
  margin-bottom: 8px;
}
.hero-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(28px, 5vw, 56px);
  letter-spacing: 8px;
  color: #fff;
  line-height: 0.95;
  margin: 0 0 6px;
  text-shadow: 0 2px 20px rgba(0,0,0,0.5);
}
.hero-title span {
  background: linear-gradient(90deg, var(--green), var(--gold));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.hero-sub {
  font-size: 12px;
  color: rgba(255,255,255,0.45);
  letter-spacing: 2px;
  margin-bottom: 0;
}
@media(max-width:480px) { .hero-sub { display: none; } }

.hero-stats {
  display: flex; flex-direction: column;
  gap: 8px; flex-shrink: 0;
  margin-left: auto;
}
@media(max-width:600px) { .hero-stats { display: none; } }

.hero-stat {
  display: flex; align-items: baseline; gap: 6px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 8px;
  padding: 6px 12px;
  min-width: 110px;
}
.hero-stat-val {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 22px; color: var(--green); line-height: 1;
}
.hero-stat-lbl {
  font-size: 10px; color: rgba(255,255,255,0.35);
  letter-spacing: 1px; text-transform: uppercase;
}

/* ===== FOOTER ===== */
.site-footer {
  margin-top: 48px;
  padding: 20px 0 12px;
  border-top: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  font-size: 12px;
  color: var(--text3);
}
.footer-logo {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 18px;
  letter-spacing: 4px;
  background: linear-gradient(135deg, var(--green), var(--gold));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.footer-links {
  display: flex; gap: 16px; align-items: center; flex-wrap: wrap;
}
.footer-links button {
  background: none; border: none;
  color: var(--text3); cursor: pointer;
  font-family: 'Rajdhani', sans-serif;
  font-size: 12px; letter-spacing: 1px;
  transition: var(--tr); padding: 0;
}
.footer-links button:hover { color: var(--green); }
@media(max-width:768px) {
  .site-footer { justify-content: center; text-align: center; }
  .footer-links { justify-content: center; }
}

/* ===== ÉQUIPE B BLEUE ===== */
.team-b .placed-avatar { border-color: var(--blue) !important; }
.proba-bar.bar-b { background: linear-gradient(90deg, var(--blue), #1565c0) !important; }

/* ===== ACTIONS RAPIDES ===== */
.quick-actions {
  display: flex;
  gap: 10px;
  margin-bottom: 24px;
  align-items: center;
}

/* Desktop — boutons compacts alignés à gauche, pas pleine largeur */
.quick-btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 9px 18px;
  color: var(--text2);
  font-family: 'Rajdhani', sans-serif;
  font-weight: 600; font-size: 13px;
  letter-spacing: 0.5px;
  cursor: pointer;
  transition: var(--tr);
  white-space: nowrap;
  flex: 0; /* ne pas s'étirer */
}
.quick-btn:hover {
  border-color: var(--green);
  color: var(--green);
  background: var(--green-dim);
  transform: translateY(-1px);
}
.quick-btn i { font-size: 14px; }

/* Bouton principal "Créer un match" plus mis en valeur */
.quick-btn-green {
  background: linear-gradient(135deg, var(--green), var(--green2));
  border-color: transparent;
  color: #000;
  font-weight: 700;
  padding: 10px 22px;
  font-size: 14px;
}
.quick-btn-green:hover {
  color: #000;
  box-shadow: var(--glow);
  transform: translateY(-2px);
}
.quick-btn-green i { font-size: 15px; }

/* Mobile — icônes égales pleine largeur */
@media(max-width:600px) {
  .quick-actions { gap: 8px; }
  .quick-btn {
    flex: 1;
    flex-direction: column;
    padding: 10px 8px;
    gap: 4px;
    font-size: 11px;
    letter-spacing: 0;
    justify-content: center;
    text-align: center;
  }
  .quick-btn i { font-size: 20px; }
  .quick-btn-green { padding: 10px 8px; font-size: 11px; }
}

/* ===== PAGE AIDE ===== */
.aide-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 20px;
  margin-top: 8px;
}
@media(max-width:768px) { .aide-grid { grid-template-columns: 1fr; } }

.aide-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 24px;
  transition: var(--tr);
}
.aide-card:hover { border-color: var(--green); }
.aide-card-tips { border-color: rgba(255,215,64,0.3); }
.aide-card-tips:hover { border-color: var(--gold); }

.aide-icon { font-size: 32px; margin-bottom: 10px; }
.aide-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 20px; letter-spacing: 3px;
  color: var(--green); margin-bottom: 12px;
}
.aide-card-tips .aide-title { color: var(--gold); }
.aide-body { font-size: 14px; color: var(--text2); line-height: 1.7; }
.aide-body p { margin-bottom: 8px; }
.aide-body ul { padding-left: 16px; margin: 8px 0; }
.aide-body li { margin-bottom: 4px; }
.aide-body strong { color: var(--text); }

/* ===== LISTE JOUEURS MOBILE — SCROLL AMÉLIORÉ ===== */
@media(max-width:768px) {
  .player-list-scroll {
    max-height: 240px !important;
    overflow-y: scroll !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior: contain;
  }
  .player-item {
    padding: 10px 12px !important;
    min-height: 52px;
    /* Empêcher le scroll de déclencher le drag */
    touch-action: pan-y;
  }
  /* Agrandir la zone de drag sur mobile */
  .player-item[draggable="true"] {
    touch-action: none;
  }
  .player-item.player-placed {
    touch-action: pan-y !important;
  }
}

/* ===== BOUTON CRÉER UN MATCH ===== */
.btn-create-match {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: linear-gradient(135deg, var(--green), var(--green2));
  border: none;
  border-radius: var(--radius);
  padding: 14px 32px;
  color: #000;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 20px;
  letter-spacing: 3px;
  cursor: pointer;
  transition: var(--tr);
  box-shadow: 0 4px 16px rgba(0,230,118,0.25);
}
.btn-create-match:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 24px rgba(0,230,118,0.4);
}
.btn-create-match i { font-size: 18px; }
@media(max-width:600px) {
  .btn-create-match { width: 100%; justify-content: center; font-size: 18px; padding: 12px 20px; }
}