/* Pages additionnelles uniquement : ne modifie pas accueil ni inscription */
.inner-page{min-height:100svh;overflow:visible;background:#080b12}
.inner-page .page-bg{position:fixed;top:var(--header-height)!important;height:calc(100svh - var(--header-height))!important;opacity:.72;filter:saturate(.95)}
.inner-page:after{position:fixed;background:linear-gradient(180deg,rgba(8,11,18,.70) 0%,rgba(8,11,18,.88) 42%,rgba(8,11,18,.96) 100%)}
.inner-main{position:relative;z-index:2;width:var(--content-width);max-width:1160px;margin:0 auto;padding:clamp(44px,7vh,72px) 0 140px}
.page-title{text-align:center;margin:0 0 36px}.page-title h1{margin:0 0 12px;font-size:clamp(34px,4vw,54px);line-height:1.05;font-weight:400;letter-spacing:.5px}.page-title h1 span{color:#e31e26}.page-title p{margin:0 auto;color:#d9d9d9;font-size:clamp(14px,1.2vw,18px);line-height:1.5;max-width:760px}.panel{background:rgba(14,18,28,.8);border:1px solid rgba(227,30,38,.32);border-radius:16px}.section-card{padding:clamp(22px,3vw,34px);margin-bottom:24px}.section-head{display:flex;align-items:center;gap:14px;margin-bottom:20px}.section-head img{width:36px;height:36px;object-fit:contain}.section-head h2{margin:0;color:#fff;font-size:clamp(21px,2vw,28px);font-weight:400}.red{color:#e31e26}.muted{color:#d9d9d9}.btn-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:24px}.outline-btn,.red-btn{min-height:47px;border-radius:7px;padding:0 22px;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:10px;font-size:15px}.red-btn{background:#e31e26;color:#fff;border:1px solid #e31e26}.outline-btn{color:#fff;border:1px solid rgba(255,255,255,.28);background:rgba(8,11,18,.42)}
.info-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.mini-card{padding:22px;text-align:center;background:rgba(8,11,18,.48);border:1px solid rgba(227,30,38,.28);border-radius:12px}.mini-card img{width:42px;height:42px;object-fit:contain;margin-bottom:12px}.mini-card h3{margin:0 0 8px;font-size:18px;font-weight:400}.mini-card p{margin:0;color:#d9d9d9;font-size:14px;line-height:1.45}
.game-list{display:grid;gap:24px}.game-card{padding:clamp(22px,3vw,34px);display:grid;grid-template-columns:minmax(0,1fr) 180px;gap:24px;align-items:start}.game-card h2{margin:0 0 6px;font-size:clamp(28px,3vw,40px);font-weight:400}.game-card .category{color:#e31e26;margin:0 0 18px;font-size:17px}.game-card p{color:#d9d9d9;line-height:1.55}.game-meta{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:20px}.game-meta div{border:1px solid rgba(255,255,255,.16);background:rgba(8,11,18,.44);padding:13px;border-radius:8px}.game-meta strong{display:block;color:#fff;font-weight:400}.game-meta span{display:block;color:#d9d9d9;margin-top:4px;font-size:13px}.prize-box{text-align:center;background:rgba(227,30,38,.16);border:1px solid #e31e26;border-radius:10px;padding:20px}.prize-box strong{display:block;font-size:28px;font-weight:400}.prize-box span{font-size:12px;color:#d9d9d9}.feature-list{margin:18px 0 0;padding:0;list-style:none;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px 18px}.feature-list li{color:#d9d9d9}.feature-list li:before{content:'•';color:#e31e26;margin-right:9px}
.rules-stack{display:grid;gap:22px}.rule-list{margin:0;padding:0;list-style:none;display:grid;gap:14px}.rule-list li{color:#d9d9d9;line-height:1.55;padding-left:28px;position:relative}.rule-list li:before{content:'✓';position:absolute;left:0;top:0;color:#e31e26}.rule-list strong{color:#fff;font-weight:400}.prize-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.rank-card{padding:22px;text-align:center;border-radius:12px;background:rgba(8,11,18,.44);border:1px solid rgba(255,255,255,.18)}.rank-card .medal{font-size:38px;margin-bottom:8px}.rank-card h3{margin:0 0 6px;font-weight:400}.rank-card strong{font-size:24px;font-weight:400}.rank-card p{margin:6px 0 0;color:#d9d9d9;font-size:13px}
.timeline{display:grid;gap:28px}.day-head{border-left:4px solid #e31e26;background:linear-gradient(90deg,rgba(227,30,38,.24),rgba(8,11,18,.60));padding:18px 22px;margin-bottom:14px;border-radius:0 12px 12px 0}.day-head h2{margin:0;font-weight:400;font-size:30px}.day-head p{margin:4px 0 0;color:#e31e26}.event-list{display:grid;gap:12px}.event{display:grid;grid-template-columns:170px 1fr auto;gap:18px;align-items:center;padding:18px 20px;background:rgba(14,18,28,.8);border:1px solid rgba(227,30,38,.25);border-radius:12px}.event time{color:#fff}.event h3{margin:0 0 6px;font-size:19px;font-weight:400}.event p{margin:0;color:#d9d9d9;font-size:14px}.tag{background:#e31e26;color:#fff;font-size:12px;border-radius:999px;padding:6px 11px;white-space:nowrap}.legend{display:flex;flex-wrap:wrap;gap:12px}.legend span{display:inline-flex;align-items:center;gap:8px;color:#d9d9d9}.legend i{width:14px;height:14px;background:#e31e26;display:inline-block;border-radius:3px}
.contact-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(280px,1fr);gap:24px}.contact-form{display:grid;gap:16px}.two-cols{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.contact-form label{font-size:14px;color:#fff}.contact-form input,.contact-form select,.contact-form textarea{display:block;width:100%;margin-top:8px;border:1px solid #d9d9d9;border-radius:5px;background:rgba(8,11,18,.54);color:#fff;padding:0 12px;font-size:14px;outline:none}.contact-form input,.contact-form select{height:40px}.contact-form textarea{min-height:150px;padding-top:12px;resize:vertical}.contact-form option{color:#111}.contact-info{display:grid;gap:16px}.contact-line{display:flex;align-items:flex-start;gap:13px;color:#d9d9d9}.contact-line img{width:28px;height:28px;object-fit:contain;flex:0 0 auto}.contact-line strong{display:block;color:#fff;font-weight:400;margin-bottom:4px}.hours{margin-top:8px;display:grid;gap:8px;color:#d9d9d9}.hours div{display:flex;justify-content:space-between;gap:18px;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:7px}.social-box{margin-top:18px;border:1.5px solid #e31e26;background:rgba(227,30,38,.16);border-radius:8px;padding:18px;color:#d9d9d9}
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:24px}.about-list{display:grid;gap:14px}.about-list div{padding:16px;background:rgba(8,11,18,.44);border:1px solid rgba(255,255,255,.12);border-radius:10px}.about-list strong{display:block;color:#e31e26;font-weight:400;margin-bottom:6px}.about-list p{margin:0;color:#d9d9d9;line-height:1.5}
@media (max-width:980px){.inner-main{padding-top:42px;padding-bottom:44px}.info-grid,.game-meta,.prize-grid{grid-template-columns:1fr}.game-card,.contact-grid,.about-grid{grid-template-columns:1fr}.feature-list{grid-template-columns:1fr}.event{grid-template-columns:1fr;gap:8px}.tag{width:max-content}.two-cols{grid-template-columns:1fr}}
@media (max-width:640px){.page-title{text-align:left}.section-card{border-radius:12px}.btn-row a{width:100%}.info-grid{gap:12px}.event{padding:16px}.day-head h2{font-size:24px}}

/* Admin inscriptions */
.admin-main{padding-bottom:150px}.admin-title{margin-bottom:24px}.admin-alert{margin:0 0 18px;padding:12px 15px;border-radius:8px;border:1px solid transparent;background:rgba(14,18,28,.8);font-size:14px}.admin-alert.success{border-color:rgba(40,167,69,.72);background:rgba(40,167,69,.18)}.admin-alert.error{border-color:rgba(227,30,38,.72);background:rgba(227,30,38,.18)}.admin-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:18px}.stat-card{border:1px solid rgba(255,255,255,.16);border-radius:14px;background:rgba(14,18,28,.8);padding:18px}.stat-card span{display:block;color:#d9d9d9;font-size:13px;margin-bottom:8px}.stat-card strong{font-size:34px;font-weight:400;line-height:1}.stat-card.pending{border-color:rgba(255,193,7,.45)}.stat-card.confirmed{border-color:rgba(40,167,69,.45)}.stat-card.rejected{border-color:rgba(227,30,38,.45)}.admin-filters{padding:18px;margin-bottom:18px}.admin-filters form{display:flex;align-items:end;gap:14px;flex-wrap:wrap}.admin-filters label{display:grid;gap:7px;font-size:13px;text-transform:uppercase;color:#fff;min-width:190px}.admin-filters select{height:40px;border:1px solid rgba(255,255,255,.28);border-radius:7px;background:#080b12;color:#fff;padding:0 12px}.admin-filter-btn,.admin-reset-btn{height:40px;border-radius:7px;padding:0 18px;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;font-size:14px}.admin-filter-btn{border:1px solid #e31e26;background:#e31e26;color:#fff}.admin-reset-btn{border:1px solid rgba(255,255,255,.28);background:rgba(8,11,18,.45);color:#fff}.admin-game-counts{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-bottom:18px}.game-count-card{border:1px solid rgba(227,30,38,.28);border-radius:14px;background:rgba(14,18,28,.8);padding:16px}.game-count-card h2{font-size:18px;font-weight:400;margin:0 0 8px}.game-count-card p{margin:0 0 12px;color:#e31e26}.mini-stats{display:flex;gap:8px;flex-wrap:wrap}.mini-stats span{font-size:12px;color:#d9d9d9;border:1px solid rgba(255,255,255,.14);border-radius:999px;padding:5px 8px}.admin-table-panel{overflow:hidden}.admin-table-head{display:flex;justify-content:space-between;align-items:center;padding:18px 20px;border-bottom:1px solid rgba(255,255,255,.12)}.admin-table-head h2{margin:0;font-size:22px;font-weight:400}.admin-table-head span{color:#d9d9d9}.admin-table-wrap{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;min-width:980px}.admin-table th,.admin-table td{padding:14px 16px;text-align:left;border-bottom:1px solid rgba(255,255,255,.1);vertical-align:top}.admin-table th{font-size:12px;text-transform:uppercase;color:#d9d9d9;font-weight:400;background:rgba(8,11,18,.45)}.admin-table td{font-size:14px}.admin-table td strong,.admin-table td span{display:block}.admin-table td span{color:#d9d9d9;margin-top:4px}.status-pill{display:inline-flex!important;align-items:center;border-radius:999px;padding:5px 10px;font-size:12px!important;margin:0!important;color:#fff!important;border:1px solid rgba(255,255,255,.18)}.status-pill.pending{background:rgba(255,193,7,.16);border-color:rgba(255,193,7,.44)}.status-pill.confirmed{background:rgba(40,167,69,.18);border-color:rgba(40,167,69,.5)}.status-pill.rejected{background:rgba(227,30,38,.18);border-color:rgba(227,30,38,.5)}.admin-actions{display:flex;gap:7px;flex-wrap:wrap;min-width:250px}.admin-actions form{margin:0}.small-action{height:30px;border-radius:6px;border:1px solid rgba(255,255,255,.2);padding:0 9px;color:#fff;background:rgba(8,11,18,.6);font-size:11px;cursor:pointer}.small-action.confirm{border-color:rgba(40,167,69,.8);background:rgba(40,167,69,.24)}.small-action.reject,.small-action.delete{border-color:rgba(227,30,38,.8);background:rgba(227,30,38,.22)}.small-action.pending{border-color:rgba(255,193,7,.65);background:rgba(255,193,7,.14)}.empty-admin{padding:36px;text-align:center;color:#d9d9d9}.login-btn{text-decoration:none}.login-btn.active{color:#e31e26}
@media (max-width:980px){.admin-stats,.admin-game-counts{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-main{padding-bottom:60px}.admin-filters form{align-items:stretch}.admin-filters label{min-width:min(100%,220px)}}
@media (max-width:620px){.admin-stats,.admin-game-counts{grid-template-columns:1fr}.admin-filter-btn,.admin-reset-btn{width:100%}.admin-filters label{width:100%}.admin-table-head{align-items:flex-start;gap:8px;flex-direction:column}}

/* Admin jeux */
.admin-tabs{display:flex;gap:12px;flex-wrap:wrap;margin:0 0 18px}.admin-tabs a{height:40px;border-radius:7px;padding:0 18px;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;color:#fff;border:1px solid rgba(255,255,255,.22);background:rgba(8,11,18,.48);font-size:14px}.admin-tabs a.active{border-color:#e31e26;background:#e31e26}.admin-games-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.admin-game-card{padding:20px;border-color:rgba(227,30,38,.28)}.admin-game-card.is-disabled{opacity:.78}.admin-game-top{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px}.admin-game-top h2{margin:0 0 6px;font-size:24px;font-weight:400}.admin-game-top p{margin:0;color:#e31e26}.game-status{border-radius:999px;padding:6px 10px;font-size:12px;color:#fff;border:1px solid rgba(255,255,255,.18);white-space:nowrap}.game-status.active{background:rgba(40,167,69,.18);border-color:rgba(40,167,69,.55)}.game-status.disabled{background:rgba(227,30,38,.18);border-color:rgba(227,30,38,.55)}.capacity-bar{height:9px;border-radius:999px;background:rgba(255,255,255,.12);overflow:hidden;margin-bottom:14px}.capacity-bar span{display:block;height:100%;border-radius:999px;background:#e31e26}.admin-game-numbers{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:16px}.admin-game-numbers span{border:1px solid rgba(255,255,255,.12);background:rgba(8,11,18,.42);border-radius:8px;padding:10px;color:#d9d9d9;font-size:13px}.admin-game-numbers strong{display:block;color:#fff;font-size:22px;font-weight:400;margin-bottom:2px}.admin-game-form{display:grid;gap:12px;margin-top:14px}.admin-game-form label{display:grid;gap:7px;color:#fff;font-size:13px;text-transform:uppercase}.admin-game-form input{height:40px;border:1px solid rgba(255,255,255,.28);border-radius:7px;background:#080b12;color:#fff;padding:0 12px;outline:none}.game-toggle{width:100%;margin-top:12px}.admin-alert.small{font-size:12px;padding:9px 10px;margin:0 0 12px}
@media (max-width:1100px){.admin-games-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:680px){.admin-games-grid{grid-template-columns:1fr}.admin-tabs a{width:100%}.admin-game-numbers{grid-template-columns:1fr}}

/* Priorité 4 : planning / matchs */
.admin-match-create{margin-bottom:18px;overflow:hidden}.compact-head{padding-bottom:12px}.match-create-form{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;padding:18px 20px 20px}.match-create-form label,.match-inline-form label{display:grid;gap:7px;color:#fff;font-size:13px;text-transform:uppercase}.match-create-form input,.match-create-form select,.match-inline-form input,.match-inline-form select{height:40px;border:1px solid rgba(255,255,255,.28);border-radius:7px;background:#080b12;color:#fff;padding:0 12px;outline:none}.match-create-form option,.match-create-form optgroup,.match-inline-form option{color:#111}.match-create-form .admin-filter-btn{align-self:end}.match-actions-cell{min-width:420px}.match-inline-form{display:grid;grid-template-columns:1.2fr 1.35fr 72px 72px 1fr auto;gap:8px;align-items:center;margin-bottom:8px}.match-inline-form input,.match-inline-form select{height:32px;font-size:12px;padding:0 8px}.matches-table{min-width:1180px}.status-pill.upcoming{background:rgba(255,193,7,.16);border-color:rgba(255,193,7,.44)}.status-pill.live{background:rgba(227,30,38,.28);border-color:rgba(227,30,38,.7)}.status-pill.finished{background:rgba(40,167,69,.18);border-color:rgba(40,167,69,.5)}.status-pill.cancelled{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.25)}
.public-matches-section{margin-bottom:22px}.section-headline{display:flex;justify-content:space-between;gap:18px;align-items:flex-end;margin-bottom:16px}.section-headline h2{margin:0;font-weight:400;font-size:26px}.section-headline p{margin:0;color:#d9d9d9;font-size:14px}.public-match-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.public-match-card{border:1px solid rgba(255,255,255,.14);border-radius:14px;background:rgba(8,11,18,.48);padding:18px;min-height:150px}.public-match-card.live{border-color:rgba(227,30,38,.72);background:linear-gradient(135deg,rgba(227,30,38,.22),rgba(8,11,18,.58))}.public-match-card.finished{border-color:rgba(40,167,69,.38)}.public-match-card h3{margin:12px 0 8px;font-weight:400;font-size:20px;line-height:1.25}.public-match-card h3 span{color:#e31e26}.public-match-card p{margin:0 0 12px;color:#d9d9d9}.public-match-card strong{display:block;font-size:32px;font-weight:400;margin:8px 0}.public-match-card small{display:block;color:#d9d9d9}.live-tag{background:#e31e26!important}.public-event-list{gap:10px}.public-event{background:rgba(8,11,18,.48)}.live-board{margin-bottom:22px;min-height:240px;display:flex;align-items:center;justify-content:center}.empty-live{text-align:center;max-width:520px;margin:auto;padding:38px 18px}.empty-live strong{display:block;font-size:28px;font-weight:400;margin-bottom:10px}.empty-live p{margin:0;color:#d9d9d9}.live-grid{width:100%}.main-live-card{min-height:240px}.score-board{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:18px;margin:22px 0}.score-board div{border:1px solid rgba(255,255,255,.14);border-radius:12px;background:rgba(8,11,18,.45);padding:16px;text-align:center}.score-board span{display:block;color:#d9d9d9;font-size:14px;min-height:34px}.score-board strong{font-size:48px;margin:8px 0 0}.score-board em{font-style:normal;color:#e31e26;font-size:18px}.live-extra-grid{align-items:start}.compact-match-list{display:grid;gap:12px}.compact-match-list div{border:1px solid rgba(255,255,255,.12);border-radius:9px;background:rgba(8,11,18,.38);padding:12px}.compact-match-list strong{display:block;font-weight:400;margin-bottom:5px}.compact-match-list span{display:block;color:#d9d9d9;font-size:13px}
@media (max-width:1100px){.match-create-form{grid-template-columns:repeat(2,minmax(0,1fr))}.match-inline-form{grid-template-columns:repeat(2,minmax(0,1fr))}.public-match-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.section-headline{align-items:flex-start;flex-direction:column}}
@media (max-width:700px){.match-create-form,.public-match-grid,.live-extra-grid{grid-template-columns:1fr}.match-create-form .admin-filter-btn{width:100%}.score-board{grid-template-columns:1fr;gap:10px}.score-board em{display:none}.public-match-card strong{font-size:28px}.empty-live strong{font-size:22px}}

/* Priorité 5 : sécurité admin */
.logout-form{margin:0;display:flex}.logout-form .login-btn{cursor:pointer;font-family:inherit}.admin-login-main{min-height:calc(100svh - var(--header-height,75px) - 104px);display:flex;align-items:center;justify-content:center;padding-top:110px;padding-bottom:80px}.admin-login-card{width:min(92vw,520px);padding:30px;border-color:rgba(227,30,38,.34);background:rgba(14,18,28,.88)}.login-title{margin-bottom:20px}.login-title h1{font-size:clamp(32px,4vw,48px)}.admin-login-form{display:grid;gap:16px;margin-top:18px}.admin-login-form label{display:grid;gap:8px;color:#fff;font-size:13px;text-transform:uppercase}.admin-login-form input{height:44px;border:1px solid rgba(255,255,255,.28);border-radius:7px;background:#080b12;color:#fff;padding:0 14px;outline:none}.admin-login-form input:focus{border-color:#e31e26}.admin-login-form .admin-filter-btn{width:100%;height:44px}.admin-login-help{margin:18px 0 0;color:#d9d9d9;font-size:13px;line-height:1.5}.admin-login-help code{color:#fff;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.14);border-radius:5px;padding:2px 6px}.admin-login-help strong{color:#e31e26;font-weight:400}
@media (max-width:700px){.admin-login-main{align-items:flex-start;padding-top:120px}.admin-login-card{padding:22px}.logout-form,.logout-form .login-btn{width:100%}}

/* Priorité 6 : tableau de bord admin */
.dashboard-main{padding-top:clamp(38px,6vh,66px)}
.dashboard-stats .admin-stat-card small{display:block;margin-top:8px;color:#d9d9d9;font-size:12px;line-height:1.35}
.admin-stat-card.warning{border-color:rgba(255,193,7,.42)}
.admin-stat-card.success{border-color:rgba(40,167,69,.42)}
.admin-stat-card.live{border-color:rgba(227,30,38,.65);background:linear-gradient(135deg,rgba(227,30,38,.18),rgba(14,18,28,.82))}
.dashboard-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:18px;margin-top:18px;align-items:start}
.lower-dashboard-grid{grid-template-columns:1fr 1fr}
.dashboard-card{margin-bottom:0;min-height:100%}
.dashboard-card .admin-table-head h2,.quick-actions-card h2{margin:0 0 6px;font-size:24px;font-weight:400;color:#fff}
.dashboard-card .admin-table-head p,.quick-actions-card p{margin:0;color:#d9d9d9;font-size:13px}
.dashboard-game-list,.dashboard-player-list{display:grid;gap:12px}
.dashboard-game-row,.dashboard-player-row{display:grid;grid-template-columns:minmax(180px,1fr) minmax(120px,.72fr) auto;gap:14px;align-items:center;border:1px solid rgba(255,255,255,.12);border-radius:10px;background:rgba(8,11,18,.42);padding:12px}
.dashboard-game-row strong,.dashboard-player-row strong{display:block;color:#fff;font-weight:400;margin-bottom:4px}
.dashboard-game-row span,.dashboard-player-row span{display:block;color:#d9d9d9;font-size:13px}
.dashboard-game-row em{font-style:normal;color:#e31e26;font-size:13px;white-space:nowrap;text-align:right}
.dashboard-mini-bar{height:8px;border-radius:999px;background:rgba(255,255,255,.12);overflow:hidden}
.dashboard-mini-bar span{display:block;height:100%;border-radius:999px;background:#e31e26}
.dashboard-match-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:14px 0 16px}
.dashboard-match-stats span{border:1px solid rgba(255,255,255,.12);border-radius:9px;background:rgba(8,11,18,.42);padding:12px;color:#d9d9d9;font-size:13px}
.dashboard-match-stats strong{display:block;color:#fff;font-size:24px;font-weight:400;margin-bottom:3px}
.dashboard-compact-list .dashboard-live-item{border-color:rgba(227,30,38,.58);background:rgba(227,30,38,.14)}
.dashboard-player-row{grid-template-columns:1fr auto}
.dashboard-player-row .status-pill{font-style:normal;white-space:nowrap}
.dashboard-actions{display:grid;grid-template-columns:1fr;gap:12px;margin-top:18px}
.dashboard-actions .red-btn,.dashboard-actions .outline-btn{width:100%;min-height:43px}
.quick-actions-card{display:flex;flex-direction:column}
@media (max-width:980px){.dashboard-grid,.lower-dashboard-grid{grid-template-columns:1fr}.dashboard-game-row{grid-template-columns:1fr}.dashboard-game-row em{text-align:left}.dashboard-match-stats{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:560px){.dashboard-match-stats{grid-template-columns:1fr}.dashboard-player-row{grid-template-columns:1fr}.dashboard-player-row .status-pill{width:max-content}}

/* Fix footer admin/dashboard : footer collé en bas de la fenêtre si la page est courte */
body.inner-page{
  min-height:100svh;
  display:flex;
  flex-direction:column;
  overflow-x:hidden;
}
body.inner-page .header{
  flex:0 0 auto;
}
body.inner-page .inner-main{
  flex:1 0 auto;
}
body.inner-page .footer{
  position:relative;
  left:auto;
  right:auto;
  bottom:auto;
  width:100%;
  margin-top:auto;
  flex:0 0 auto;
}
@media (min-width:981px){
  body.inner-page .footer{
    height:104px;
  }
}

/* Fix dashboard : même header, même footer et mêmes marges que les autres pages */
body.inner-page.admin-page{
  --header-height:75px;
  --content-width:min(75vw,1160px);
  min-height:100svh;
  display:flex;
  flex-direction:column;
  overflow-x:hidden;
  background:#080b12;
}
body.inner-page.admin-page .header{
  flex:0 0 auto;
}
body.inner-page.admin-page .page-bg{
  position:fixed;
  top:var(--header-height)!important;
  height:calc(100svh - var(--header-height))!important;
  object-position:center top!important;
}
body.inner-page.admin-page .inner-main,
body.inner-page.admin-page .dashboard-main{
  width:var(--content-width);
  max-width:1160px;
  margin-left:auto;
  margin-right:auto;
  flex:1 0 auto;
  padding-left:0;
  padding-right:0;
  padding-top:clamp(44px,7vh,72px);
  padding-bottom:64px;
}
body.inner-page.admin-page .footer{
  position:relative;
  left:auto;
  right:auto;
  bottom:auto;
  width:100%;
  height:104px;
  margin-top:auto;
  flex:0 0 auto;
}
body.inner-page.admin-page .footer-line,
body.inner-page.admin-page .footer-content{
  width:var(--content-width);
}

.admin-page .admin-title,
.admin-page .page-title{
  width:100%;
  margin-left:auto;
  margin-right:auto;
  margin-bottom:24px;
  text-align:center;
}
.admin-page .admin-tabs{
  width:100%;
  margin:0 0 18px;
}
.admin-page .admin-stats.dashboard-stats{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  width:100%;
  margin:0 0 18px;
}
.admin-page .admin-stat-card{
  min-width:0;
  padding:18px;
  background:rgba(14,18,28,.8);
  border:1px solid rgba(255,255,255,.16);
  border-radius:14px;
}
.admin-page .admin-stat-card span{
  display:block;
  color:#d9d9d9;
  font-size:13px;
  margin-bottom:8px;
}
.admin-page .admin-stat-card strong{
  display:block;
  color:#fff;
  font-size:34px;
  line-height:1;
  font-weight:400;
}
.admin-page .dashboard-grid,
.admin-page .lower-dashboard-grid{
  width:100%;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  margin-top:18px;
  align-items:stretch;
}
.admin-page .dashboard-card{
  margin:0;
  min-width:0;
  height:100%;
}
.admin-page .dashboard-card .admin-table-head{
  padding:0 0 16px;
  margin-bottom:16px;
  border-bottom:1px solid rgba(255,255,255,.12);
}
.admin-page .dashboard-game-row{
  grid-template-columns:minmax(0,1fr) minmax(120px,.72fr) auto;
}
.admin-page .quick-actions-card{
  justify-content:flex-start;
}

@media (max-width:1200px){
  body.inner-page.admin-page{--content-width:min(88vw,1040px)}
}
@media (max-width:1100px) and (min-width:981px){
  body.inner-page.admin-page{--content-width:90vw}
}
@media (max-width:980px){
  body.inner-page.admin-page{--header-height:124px;--content-width:92vw}
  body.inner-page.admin-page .inner-main,
  body.inner-page.admin-page .dashboard-main{padding-top:42px;padding-bottom:44px}
  body.inner-page.admin-page .footer{height:auto;padding:18px 24px}
  .admin-page .admin-stats.dashboard-stats{grid-template-columns:repeat(2,minmax(0,1fr))}
  .admin-page .dashboard-grid,
  .admin-page .lower-dashboard-grid{grid-template-columns:1fr;align-items:start}
  .admin-page .dashboard-game-row{grid-template-columns:1fr}
  .admin-page .dashboard-game-row em{text-align:left}
}
@media (max-width:640px){
  body.inner-page.admin-page{--header-height:116px;--content-width:92vw}
  body.inner-page.admin-page .footer{padding:18px 16px}
  .admin-page .admin-title,.admin-page .page-title{text-align:left}
  .admin-page .admin-stats.dashboard-stats{grid-template-columns:1fr}
  .admin-page .dashboard-match-stats{grid-template-columns:1fr}
  .admin-page .dashboard-player-row{grid-template-columns:1fr}
}

/* Public dynamic pages */
.disabled-cta{opacity:.65;cursor:not-allowed}.public-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-bottom:22px}.public-summary-card{padding:18px;border-color:rgba(227,30,38,.24)}.public-summary-card span{display:block;color:#d9d9d9;font-size:13px;text-transform:uppercase;letter-spacing:.03em;margin-bottom:6px}.public-summary-card strong{display:block;color:#fff;font-size:32px;font-weight:400}.public-game-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:6px}.game-card.is-closed{border-color:rgba(255,255,255,.12);opacity:.86}.public-capacity{margin:16px 0 2px}.public-game-actions{margin-top:18px}.disabled-link{opacity:.58;cursor:not-allowed;pointer-events:none}.public-games-list .game-card{align-items:stretch}
@media (max-width:980px){.public-summary-grid{grid-template-columns:1fr}.public-game-head{flex-direction:column}.public-games-list .game-card{grid-template-columns:1fr}}


/* Admin : infos dynamiques de l'accueil */
.admin-settings-form{
  max-width:720px;
  margin:0 auto;
  display:grid;
  gap:16px;
}
.admin-settings-form label{
  display:grid;
  gap:8px;
  color:#fff;
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.02em;
}
.admin-settings-form input{
  height:44px;
  border:1px solid rgba(255,255,255,.28);
  border-radius:7px;
  background:#080b12;
  color:#fff;
  padding:0 14px;
  outline:none;
  font-family:inherit;
}
.admin-settings-form input:focus{border-color:#e31e26}
.admin-settings-preview{
  max-width:720px;
  margin:18px auto 0;
}
.admin-settings-preview .home-info{
  margin-top:0;
  max-width:none;
}
@media (max-width:700px){
  .admin-settings-form,.admin-settings-preview{max-width:none}
}

/* Admin export / sauvegarde */
.export-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
  margin-bottom:18px;
}
.export-card{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.export-card h2{
  margin:0;
  color:#fff;
  font-size:24px;
  font-weight:400;
}
.export-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  align-items:center;
}
.export-actions form{margin:0}
.export-actions .red-btn,
.export-actions .outline-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 18px;
  text-decoration:none;
}
.compact-export-actions .outline-btn{min-width:116px}
.export-game-list{
  display:grid;
  gap:10px;
}
.export-game-list a{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:12px 14px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:9px;
  background:rgba(8,11,18,.46);
  color:#fff;
  text-decoration:none;
}
.export-game-list a:hover{border-color:#e31e26}
.export-game-list span{color:#d9d9d9;font-size:13px}
.export-backups-panel{margin-top:4px}
.export-backups-panel code{
  color:#fff;
  background:rgba(227,30,38,.18);
  padding:2px 6px;
  border-radius:5px;
}
@media (max-width:900px){
  .export-grid{grid-template-columns:1fr}
  .export-actions{align-items:stretch}
  .export-actions .red-btn,
  .export-actions .outline-btn,
  .export-actions form{width:100%}
}

/* Email confirmation / Resend */
.status-pill.verified{background:rgba(47,178,106,.18);color:#77ffae;border-color:rgba(47,178,106,.45)}
.status-pill.unverified{background:rgba(255,176,0,.14);color:#ffd27a;border-color:rgba(255,176,0,.38)}
.email-date{display:block;margin-top:5px;color:#b8b8b8;font-size:11px;white-space:nowrap}.small-action.email{background:rgba(227,30,38,.14);border-color:rgba(227,30,38,.45);color:#fff}.email-confirm-panel{max-width:720px;margin:0 auto;text-align:center}.email-confirm-panel h2{margin:0 0 10px;color:#fff;font-size:28px;font-weight:400}.email-confirm-panel p{color:#d9d9d9}.email-confirm-panel.success{border-color:rgba(47,178,106,.45)}.email-confirm-panel.error{border-color:rgba(227,30,38,.45)}.email-confirm-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:20px}.email-confirm-actions a{text-decoration:none;min-height:42px;padding:0 18px;display:inline-flex;align-items:center;justify-content:center}

/* Priorité 11 : compte joueur avec mot de passe après confirmation */
.player-page .player-main{padding-top:clamp(44px,7vh,72px)}
.player-card{padding:clamp(22px,3vw,32px);max-width:720px;margin:0 auto 18px;background:rgba(14,18,28,.84)}
.login-player-card{max-width:520px}
.player-summary{border:1px solid rgba(255,255,255,.12);border-radius:12px;background:rgba(8,11,18,.38);padding:16px;margin-bottom:18px}
.player-summary.big{margin-bottom:18px}
.player-summary h2,.player-card h2{margin:0 0 12px;color:#fff;font-weight:400;font-size:clamp(22px,2.2vw,30px)}
.player-summary p{margin:6px 0;color:#d9d9d9}.player-summary strong{color:#fff;font-weight:400}.player-form{display:grid;gap:16px}.player-form label{display:grid;gap:8px;color:#fff;font-size:13px;text-transform:uppercase}.player-form input{height:44px;border:1px solid rgba(255,255,255,.28);border-radius:7px;background:#080b12;color:#fff;padding:0 14px;outline:none}.player-form input:focus{border-color:#e31e26}.player-help{margin:14px 0 0;color:#d9d9d9;font-size:13px;line-height:1.5}.player-submit{width:100%;height:46px;border:0;cursor:pointer;font-family:inherit}.player-submit:disabled{opacity:.58;cursor:not-allowed}.player-dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:stretch}.player-dashboard-grid .player-card{max-width:none;margin:0;min-height:100%}.player-status-list{display:grid;gap:10px}.player-status-list div{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid rgba(255,255,255,.12);border-radius:10px;background:rgba(8,11,18,.38);padding:12px}.player-status-list span{color:#d9d9d9;font-size:13px}.player-status-list strong{color:#fff;font-weight:400;text-align:right}.player-status-list strong.ok,.player-status-list strong.confirmed{color:#35d07f}.player-status-list strong.warn,.player-status-list strong.pending{color:#ffc857}.player-status-list strong.rejected{color:#ff6961}.player-logout{width:100%;background:transparent;cursor:pointer;font-family:inherit}.payment-card .player-submit{margin-top:16px}.email-confirm-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.status-pill.verified{background:rgba(53,208,127,.16);border-color:rgba(53,208,127,.42);color:#35d07f}.status-pill.unverified{background:rgba(255,200,87,.13);border-color:rgba(255,200,87,.38);color:#ffc857}
@media (max-width:860px){.player-dashboard-grid{grid-template-columns:1fr}.player-status-list div{align-items:flex-start;flex-direction:column}.player-status-list strong{text-align:left}.player-card{padding:22px}}

.text-link {
  color: #e31e26;
  text-decoration: none;
  font-weight: 700;
}

.text-link:hover {
  text-decoration: underline;
}

.player-summary-mini {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 18px;
  padding: 14px 16px;
  border: 1px solid rgba(227, 30, 38, 0.35);
  border-radius: 10px;
  background: rgba(227, 30, 38, 0.08);
  color: #fff;
}

.player-summary-mini span {
  color: rgba(255,255,255,.72);
  font-size: 13px;
}

.unified-login-main {
  min-height: calc(100svh - var(--header-height) - var(--footer-height, 104px));
  display: grid;
  place-items: center;
}

.unified-login-card {
  max-width: 520px;
  width: min(100%, 520px);
}

.unified-login-card .login-title {
  margin-bottom: 22px;
}

/* Notifications globales en bas à droite */
.toast-root{
  position:fixed;
  right:clamp(16px,3vw,34px);
  bottom:clamp(16px,3vw,34px);
  z-index:9999;
  pointer-events:none;
}
.site-toast{
  position:relative;
  display:flex;
  align-items:center;
  gap:12px;
  width:min(380px,calc(100vw - 32px));
  min-height:58px;
  padding:14px 16px 14px 14px;
  color:#fff;
  background:rgba(8,11,18,.94);
  border:1px solid rgba(255,255,255,.16);
  border-radius:13px;
  box-shadow:0 18px 46px rgba(0,0,0,.42);
  transform:translateY(120%);
  opacity:0;
  transition:transform .38s ease, opacity .38s ease;
  overflow:hidden;
  pointer-events:auto;
}
.site-toast.is-visible{transform:translateY(0);opacity:1}
.site-toast.is-leaving{transform:translateY(120%);opacity:0}
.site-toast p{margin:0;font-size:14px;line-height:1.35;color:#fff}
.site-toast-bar{width:5px;align-self:stretch;border-radius:999px;background:#e31e26;flex:0 0 auto}
.site-toast-success .site-toast-bar{background:#21c55d}
.site-toast-error .site-toast-bar{background:#e31e26}
.site-toast-info .site-toast-bar{background:#d9d9d9}
.site-toast-success{border-color:rgba(33,197,93,.34)}
.site-toast-error{border-color:rgba(227,30,38,.46)}
.site-toast-info{border-color:rgba(217,217,217,.28)}

/* Erreurs liées directement aux champs */
.field-error{
  display:block;
  margin-top:6px;
  color:#ff7b80;
  font-size:12px;
  line-height:1.25;
}
.has-field-error{
  border-color:#e31e26!important;
  box-shadow:0 0 0 2px rgba(227,30,38,.18)!important;
}
.check-row-error span{color:#ffb1b4}
.check-field-error{margin:7px 0 0 0}
.player-form label,.grid-form label{position:relative}

@media (max-width:640px){
  .toast-root{right:14px;bottom:14px;left:14px}
  .site-toast{width:100%}
}


/* Menu déroulant des actions dans Admin > Inscriptions */
.admin-table-panel,
.admin-table-wrap{
  overflow:visible;
}
.admin-table-wrap{
  overflow-x:auto;
}
.admin-actions{
  display:flex;
  align-items:flex-start;
  gap:8px;
  flex-wrap:nowrap;
  min-width:160px;
}
.admin-actions form{
  margin:0;
}
.edit-icon-action{
  width:36px;
  height:36px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
  border:1px solid rgba(227,30,38,.7);
  border-radius:8px;
  background:rgba(227,30,38,.13);
  text-decoration:none;
  transition:background .2s ease,border-color .2s ease,transform .2s ease;
}
.edit-icon-action:hover{
  background:rgba(227,30,38,.24);
  border-color:#e31e26;
  transform:translateY(-1px);
}
.edit-icon-action img{
  width:18px;
  height:18px;
  display:block;
}
.action-dropdown{
  position:relative;
  min-width:116px;
}
.action-dropdown summary{
  height:36px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:100%;
  padding:0 12px;
  border:1px solid rgba(255,255,255,.2);
  border-radius:8px;
  background:rgba(8,11,18,.62);
  color:#fff;
  font-size:11px;
  text-transform:uppercase;
  cursor:pointer;
  user-select:none;
}
.action-dropdown summary::-webkit-details-marker{
  display:none;
}
.action-dropdown summary::after{
  content:"";
  width:7px;
  height:7px;
  margin-left:9px;
  border-right:1.5px solid currentColor;
  border-bottom:1.5px solid currentColor;
  transform:rotate(45deg) translateY(-2px);
  transition:transform .2s ease;
}
.action-dropdown[open] summary{
  border-color:rgba(227,30,38,.58);
  background:rgba(227,30,38,.14);
}
.action-dropdown[open] summary::after{
  transform:rotate(225deg) translateY(-1px);
}
.action-dropdown-list{
  display:grid;
  gap:6px;
  margin-top:8px;
  width:180px;
  padding:8px;
  border:1px solid rgba(255,255,255,.16);
  border-radius:10px;
  background:rgba(8,11,18,.96);
  box-shadow:0 16px 36px rgba(0,0,0,.34);
}
.action-dropdown-list .small-action{
  width:100%;
  height:34px;
  display:inline-flex;
  align-items:center;
  justify-content:flex-start;
  padding:0 10px;
  text-align:left;
}
.action-dropdown-list form{
  width:100%;
}
.small-action.email{
  border-color:rgba(217,217,217,.44);
  background:rgba(217,217,217,.08);
}

@media (max-width:760px){
  .admin-actions{
    min-width:148px;
  }
  .action-dropdown{
    min-width:104px;
  }
  .action-dropdown-list{
    width:160px;
  }
}


/* Correction page édition joueur : même logique visuelle que la page inscription */
.registration-like-edit{
  width:100%;
  max-width:1160px;
  margin:0 auto 28px;
  padding:0;
  border:0;
  border-radius:16px;
  background:rgba(14,18,28,.80);
  box-shadow:0 18px 60px rgba(0,0,0,.22);
  overflow:hidden;
}
.registration-like-edit .admin-table-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  padding:24px 31px 16px;
  border-bottom:0;
  background:transparent;
}
.registration-like-edit .admin-table-head h2{
  margin:0;
  color:#fff;
  font-size:20px;
  line-height:24px;
  font-weight:400;
  text-transform:uppercase;
}
.registration-like-edit .admin-table-head p{
  margin:7px 0 0;
  color:#d9d9d9;
  font-size:14px;
  line-height:17px;
}
.registration-like-edit .admin-reset-btn{
  height:36px;
  border-radius:5px;
  border:1px solid #d9d9d9;
  background:transparent;
  color:#fff;
  padding:0 14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  white-space:nowrap;
}
.admin-edit-status{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  padding:0 31px 20px;
}
.admin-edit-status span{
  border:1px solid rgba(217,217,217,.42);
  border-radius:6px;
  background:rgba(8,11,18,.32);
  color:#d9d9d9;
  padding:8px 12px;
  font-size:13px;
  line-height:1.2;
}
.admin-edit-status strong{
  color:#fff;
  font-weight:400;
}
.registration-edit-form{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,464px));
  column-gap:31px;
  row-gap:14px;
  padding:0 31px 32px;
  align-items:start;
}
.registration-edit-form label{
  display:block;
  color:#fff;
  font-size:14px;
  line-height:17px;
  text-transform:uppercase;
  font-weight:400;
}
.registration-edit-form input,
.registration-edit-form select{
  display:block;
  width:100%;
  height:36px;
  margin-top:7px;
  border:1px solid #d9d9d9;
  border-radius:5px;
  background:transparent;
  color:#fff;
  padding:0 12px;
  font-size:14px;
  outline:none;
  font-family:inherit;
}
.registration-edit-form select{
  appearance:none;
  background-image:linear-gradient(45deg,transparent 50%,#fff 50%),linear-gradient(135deg,#fff 50%,transparent 50%);
  background-position:calc(100% - 17px) 15px,calc(100% - 12px) 15px;
  background-size:5px 5px,5px 5px;
  background-repeat:no-repeat;
  padding-right:34px;
}
.registration-edit-form input:focus,
.registration-edit-form select:focus{
  border-color:#e31e26;
  box-shadow:0 0 0 2px rgba(227,30,38,.18);
}
.registration-edit-form option{
  color:#111;
}
.admin-edit-note{
  grid-column:1/-1;
  margin-top:3px;
  border:1.5px solid #e31e26;
  background:rgba(227,30,38,.16);
  border-radius:6px;
  color:#fff;
  padding:14px 16px;
  font-size:13px;
  line-height:1.45;
}
.admin-edit-note strong{
  color:#e31e26;
  font-weight:400;
}
.admin-edit-actions{
  grid-column:1/-1;
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  margin-top:10px;
}
.admin-edit-actions .admin-filter-btn{
  min-width:260px;
  height:47px;
  border:0;
  border-radius:7px;
  background:#e31e26;
  color:#fff;
  font-size:18px;
  font-family:inherit;
  cursor:pointer;
}
.admin-edit-actions .admin-reset-btn{
  min-width:160px;
  height:47px;
  border-radius:7px;
}
@media (max-width:980px){
  .registration-like-edit .admin-table-head,
  .admin-edit-status,
  .registration-edit-form{
    padding-left:24px;
    padding-right:24px;
  }
  .registration-edit-form{
    grid-template-columns:repeat(2,minmax(220px,1fr));
  }
}
@media (max-width:720px){
  .registration-like-edit{
    border-radius:12px;
  }
  .registration-like-edit .admin-table-head{
    flex-direction:column;
  }
  .registration-like-edit .admin-reset-btn{
    width:100%;
  }
  .registration-edit-form{
    grid-template-columns:1fr;
    padding-bottom:24px;
  }
  .admin-edit-actions .admin-filter-btn,
  .admin-edit-actions .admin-reset-btn{
    width:100%;
    min-width:0;
  }
}

/* Recherche + pagination admin inscriptions */
.admin-search-panel form{
  display:grid;
  grid-template-columns:minmax(240px,2fr) repeat(5,minmax(145px,1fr)) auto auto;
  align-items:end;
}
.admin-search-panel label{
  min-width:0;
}
.admin-search-panel .admin-search-field{
  min-width:240px;
}
.admin-filters input[type="search"]{
  height:40px;
  border:1px solid rgba(255,255,255,.28);
  border-radius:7px;
  background:#080b12;
  color:#fff;
  padding:0 12px;
  outline:none;
  font-family:inherit;
}
.admin-filters input[type="search"]:focus,
.admin-filters select:focus{
  border-color:#e31e26;
}
.admin-pagination{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:18px 20px;
  border-top:1px solid rgba(255,255,255,.12);
  background:rgba(8,11,18,.26);
}
.pagination-pages{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:7px;
  flex-wrap:wrap;
}
.pagination-btn,
.pagination-number{
  min-height:34px;
  border:1px solid rgba(255,255,255,.22);
  border-radius:7px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  color:#fff;
  background:rgba(8,11,18,.55);
  font-size:12px;
  padding:0 12px;
}
.pagination-number{
  min-width:34px;
  padding:0 8px;
}
.pagination-number.active{
  background:#e31e26;
  border-color:#e31e26;
}
.pagination-btn.disabled{
  opacity:.38;
  pointer-events:none;
}
.pagination-info{
  color:#d9d9d9;
  font-size:13px;
  white-space:nowrap;
}
.pagination-info strong{
  color:#fff;
  font-weight:400;
}

@media (max-width:1280px){
  .admin-search-panel form{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
  .admin-search-panel .admin-search-field{
    grid-column:span 3;
  }
}
@media (max-width:760px){
  .admin-search-panel form{
    grid-template-columns:1fr;
  }
  .admin-search-panel .admin-search-field{
    grid-column:auto;
  }
  .admin-pagination{
    flex-direction:column;
    align-items:stretch;
  }
  .pagination-btn,
  .pagination-info{
    width:100%;
    text-align:center;
  }
}


/* Icon-only buttons for admin inscription filters */
.admin-search-panel .admin-icon-btn{
  width:40px;
  height:40px;
  border-radius:7px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0;
  text-decoration:none;
  cursor:pointer;
  transition:transform .18s ease, border-color .18s ease, background .18s ease;
}
.admin-search-panel .admin-icon-btn img{
  width:18px;
  height:18px;
  display:block;
  pointer-events:none;
}
.admin-search-panel .admin-icon-search{
  border:1px solid #e31e26;
  background:#e31e26;
}
.admin-search-panel .admin-icon-reset{
  border:1px solid rgba(227,30,38,.55);
  background:rgba(8,11,18,.55);
}
.admin-search-panel .admin-icon-btn:hover{
  transform:translateY(-1px);
}
.admin-search-panel .admin-icon-search:hover{
  background:#ff2b34;
  border-color:#ff2b34;
}
.admin-search-panel .admin-icon-reset:hover{
  background:rgba(227,30,38,.14);
  border-color:#e31e26;
}
@media (max-width:760px){
  .admin-search-panel .admin-icon-btn{
    width:100%;
  }
}

/* Live video board */
.live-board {
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.live-video-shell {
  width: 100%;
}

.live-video-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 14px;
}

.live-video-header h2 {
  margin: 8px 0 0;
  color: #fff;
  font-size: clamp(22px, 3vw, 38px);
  line-height: 1;
}

.live-state {
  border: 1px solid rgba(227, 30, 38, .65);
  border-radius: 999px;
  padding: 8px 12px;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.live-state.on {
  color: #fff;
  background: rgba(227, 30, 38, .22);
}

.live-state.off {
  color: rgba(255,255,255,.72);
  background: rgba(8, 11, 18, .45);
}

.live-video-frame {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border: 1px solid rgba(227, 30, 38, .55);
  border-radius: 14px;
  background:
    linear-gradient(135deg, rgba(8,11,18,.92), rgba(14,18,28,.62)),
    #080b12;
  box-shadow: 0 18px 60px rgba(0,0,0,.35);
}

.live-video-frame video,
.live-video-frame iframe {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
  object-fit: cover;
  background: #000;
}

.live-video-empty {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 28px;
  text-align: center;
  color: #fff;
}

.live-video-empty strong {
  color: #e31e26;
  font-size: clamp(20px, 2.4vw, 34px);
  text-transform: uppercase;
}

.live-video-empty p {
  max-width: 560px;
  margin: 12px auto 0;
  color: rgba(255,255,255,.78);
}

.live-video-matches {
  margin-top: 0;
}

/* Admin live settings */
.admin-live-panel {
  background: rgba(14,18,28,.80);
}

.admin-live-form {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.admin-live-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px 22px;
}

.admin-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
  color: #fff;
  font-size: 14px;
  text-transform: uppercase;
}

.admin-field input,
.admin-field select,
.admin-field textarea {
  width: 100%;
  border: 1px solid rgba(255,255,255,.78);
  border-radius: 6px;
  background: rgba(8,11,18,.42);
  color: #fff;
  padding: 12px 13px;
  outline: none;
  font: inherit;
  text-transform: none;
}

.admin-field textarea {
  resize: vertical;
  min-height: 92px;
}

.admin-field input:focus,
.admin-field select:focus,
.admin-field textarea:focus {
  border-color: #e31e26;
  box-shadow: 0 0 0 3px rgba(227,30,38,.18);
}

.admin-field-wide {
  grid-column: 1 / -1;
}

.admin-toggle-field {
  justify-content: end;
}

.admin-toggle-field input {
  width: 22px;
  height: 22px;
  accent-color: #e31e26;
}

.live-admin-help {
  border: 1px solid rgba(227,30,38,.35);
  border-radius: 12px;
  padding: 16px 18px;
  background: rgba(227,30,38,.08);
  color: rgba(255,255,255,.82);
}

.live-admin-help strong {
  color: #e31e26;
  text-transform: uppercase;
}

.live-admin-help p {
  margin: 7px 0 0;
}

.live-admin-help code {
  color: #fff;
  word-break: break-all;
}

.admin-live-preview h2 {
  margin: 0 0 12px;
  color: #fff;
  text-transform: uppercase;
}

.live-video-frame.preview {
  max-width: 920px;
}

.primary-admin-btn {
  align-self: flex-start;
  border: 0;
  border-radius: 8px;
  background: #e31e26;
  color: #fff;
  padding: 14px 26px;
  font-weight: 700;
  cursor: pointer;
  text-transform: uppercase;
}

.primary-admin-btn:hover {
  filter: brightness(1.08);
}

@media (max-width: 860px) {
  .live-video-header {
    align-items: flex-start;
    flex-direction: column;
  }

  .admin-live-grid {
    grid-template-columns: 1fr;
  }
}

.admin-field .file-input {
  cursor: pointer;
  padding: 10px 12px;
}

.admin-field .file-input::file-selector-button {
  margin-right: 12px;
  border: 1px solid #e31e26;
  border-radius: 6px;
  background: #e31e26;
  color: #fff;
  padding: 8px 12px;
  cursor: pointer;
  font-family: inherit;
  text-transform: uppercase;
}

.admin-field small {
  color: rgba(255,255,255,.62);
  font-size: 12px;
  line-height: 1.45;
  text-transform: none;
}

.current-video-box {
  border: 1px solid rgba(227,30,38,.35);
  border-radius: 10px;
  padding: 12px 14px;
  background: rgba(227,30,38,.08);
}

.current-video-box code {
  display: block;
  color: rgba(255,255,255,.82);
  font-size: 13px;
  overflow-wrap: anywhere;
  text-transform: none;
}

/* Public live player: no timeline, volume button only */
.live-video-player::-webkit-media-controls,
.live-video-player::-webkit-media-controls-enclosure,
.live-video-player::-webkit-media-controls-panel,
.live-video-player::-webkit-media-controls-timeline,
.live-video-player::-webkit-media-controls-current-time-display,
.live-video-player::-webkit-media-controls-time-remaining-display,
.live-video-player::-webkit-media-controls-play-button,
.live-video-player::-webkit-media-controls-fullscreen-button {
  display: none !important;
}

.live-volume-btn {
  position: absolute;
  right: 18px;
  bottom: 18px;
  z-index: 5;
  width: 46px;
  height: 46px;
  border: 1px solid rgba(227, 30, 38, .85);
  border-radius: 999px;
  background: rgba(8, 11, 18, .72);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  backdrop-filter: blur(8px);
  box-shadow: 0 10px 26px rgba(0,0,0,.34);
  opacity: .5;
  transition: opacity .18s ease, transform .18s ease, background .18s ease, border-color .18s ease;
}

.live-video-frame:hover .live-volume-btn,
.live-volume-btn:hover,
.live-volume-btn:focus-visible {
  opacity: 1;
}

.live-volume-btn:hover {
  transform: translateY(-2px);
  background: rgba(227, 30, 38, .82);
  border-color: #e31e26;
}

.live-volume-btn img {
  width: 23px;
  height: 23px;
  display: block;
  filter: brightness(0) invert(1);
}

.live-volume-btn.is-muted img {
  opacity: .55;
}

/* MediaMTX / OBS live admin */
.live-source-box[hidden] {
  display: none !important;
}

.obs-config-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  border: 1px solid rgba(227,30,38,.35);
  border-radius: 12px;
  padding: 14px;
  background: rgba(227,30,38,.08);
}

.obs-config-grid div {
  min-width: 0;
}

.obs-config-grid .obs-wide {
  grid-column: 1 / -1;
}

.obs-config-grid small {
  display: block;
  margin-bottom: 6px;
  color: rgba(255,255,255,.62);
  text-transform: uppercase;
  letter-spacing: .05em;
}

.obs-config-grid code {
  display: block;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 8px;
  background: rgba(8,11,18,.56);
  color: #fff;
  padding: 11px 12px;
  overflow-wrap: anywhere;
  text-transform: none;
}

.live-video-embed {
  width: 100%;
  height: 100%;
  border: 0;
}

@media (max-width: 760px) {
  .obs-config-grid {
    grid-template-columns: 1fr;
  }
}

/* Admin live : mêmes boutons rapides que les autres panels admin */
.admin-panel-tabs{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  width:100%;
  margin:0 0 18px;
}
.admin-panel-tabs a{
  min-height:40px;
  border-radius:7px;
  padding:0 16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  color:#fff;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(8,11,18,.48);
  font-size:14px;
  white-space:nowrap;
}
.admin-panel-tabs a.active{
  border-color:#e31e26;
  background:#e31e26;
}
.admin-panel-tabs a:hover{
  border-color:#e31e26;
}
@media (max-width:680px){
  .admin-panel-tabs a{
    flex:1 1 100%;
  }
}


/* Fix À propos game images */
.about-grid{
  align-items:stretch;
}
.about-grid > .section-card{
  height:100%;
  margin-bottom:0;
}
.about-list{
  height:100%;
}
.about-games-list{
  display:grid;
  gap:18px;
}
.about-game-card{
  position:relative;
  overflow:hidden;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(280px,42%);
  align-items:stretch;
  min-height:235px;
  padding:0;
}
.about-game-content{
  position:relative;
  z-index:2;
  padding:clamp(22px,2.5vw,32px);
  min-width:0;
}
.about-game-visual{
  position:relative;
  align-self:stretch;
  min-height:100%;
  height:100%;
  margin-left:-1px;
  border-left:0 !important;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  overflow:hidden;
}
.about-game-visual::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(14,18,28,.98) 0%,rgba(14,18,28,.62) 26%,rgba(14,18,28,.08) 72%,rgba(14,18,28,.18) 100%);
  pointer-events:none;
}
.about-game-visual::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(0deg,rgba(8,11,18,.38),rgba(8,11,18,0));
  pointer-events:none;
}
.about-game-visual--fc26{background-image:url('/assets/about-fc26.jpg');}
.about-game-visual--mortal-kombat{background-image:url('/assets/about-mortal-kombat.png');}
.about-game-visual--tekken{background-image:url('/assets/about-tekken.png');}
.about-game-card--fc26 .about-game-visual{background-image:url('/assets/about-fc26.jpg');}
.about-game-card--mortal-kombat .about-game-visual{background-image:url('/assets/about-mortal-kombat.png');}
.about-game-card--tekken .about-game-visual{background-image:url('/assets/about-tekken.png');}
.about-game-card.is-closed .about-game-visual{
  filter:grayscale(.45);
}
@media (max-width:980px){
  .about-game-card{
    grid-template-columns:1fr;
    min-height:0;
  }
  .about-game-visual{
    min-height:220px;
    height:220px;
    margin-left:0;
    order:-1;
  }
  .about-game-visual::before{
    background:linear-gradient(0deg,rgba(14,18,28,.92) 0%,rgba(14,18,28,.18) 68%,rgba(14,18,28,.1) 100%);
  }
}
@media (max-width:640px){
  .about-game-visual{
    min-height:170px;
    height:170px;
  }
}

/* Fix ciblé : champs de texte de /admin/reglement */
.admin-rules-form{
  display:grid;
  gap:22px;
}
.admin-rule-card{
  background:rgba(14,18,28,.80);
  border:1px solid rgba(227,30,38,.32);
  border-radius:16px;
}
.admin-rule-card-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  margin-bottom:20px;
}
.admin-rule-card label{
  display:grid;
  gap:8px;
  color:#fff;
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.02em;
  margin-top:16px;
}
.admin-rule-card input[type="text"],
.admin-rule-card textarea{
  width:100%;
  border:1px solid rgba(255,255,255,.78);
  border-radius:6px;
  background:rgba(8,11,18,.42);
  color:#fff;
  padding:12px 13px;
  outline:none;
  font:inherit;
  text-transform:none;
  box-sizing:border-box;
}
.admin-rule-card input[type="text"]{
  min-height:44px;
}
.admin-rule-card textarea{
  min-height:180px;
  resize:vertical;
  line-height:1.5;
}
.admin-rule-card input[type="text"]:focus,
.admin-rule-card textarea:focus{
  border-color:#e31e26;
  box-shadow:0 0 0 3px rgba(227,30,38,.18);
}
.admin-rule-card small{
  color:#d9d9d9;
  font-size:12px;
  line-height:1.45;
  text-transform:none;
  letter-spacing:0;
}
.admin-rule-card small strong{
  color:#fff;
  font-weight:400;
}
.admin-rules-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:12px;
  padding:18px;
  background:rgba(14,18,28,.80);
}
@media (max-width:700px){
  .admin-rule-card-head,
  .admin-rules-actions{
    flex-direction:column;
    align-items:stretch;
  }
  .admin-rules-actions .admin-filter-btn,
  .admin-rules-actions .admin-reset-btn{
    width:100%;
    justify-content:center;
  }
}

/* Live : marge interne horizontale uniquement des panels info-card */
.live-extra-grid .info-card {
  padding-left: 10%;
  padding-right: 10%;
  box-sizing: border-box;
}

@media (max-width: 700px) {
  .live-extra-grid .info-card {
    padding-left: 20px;
    padding-right: 20px;
  }
}

/* Admin live upload confirmation button */
.live-upload-control {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 54px;
  gap: 10px;
  align-items: stretch;
}

.live-file-picker {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 54px;
  border: 1px solid rgba(255,255,255,.78);
  border-radius: 6px;
  background: rgba(8,11,18,.42);
  overflow: hidden;
  cursor: pointer;
}

.live-file-picker:focus-within {
  border-color: #e31e26;
  box-shadow: 0 0 0 3px rgba(227,30,38,.18);
}

.live-file-picker .live-file-input {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}

.live-file-name {
  display: block;
  width: 100%;
  padding: 12px 13px;
  color: rgba(255,255,255,.88);
  font-size: 14px;
  text-transform: none;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.live-upload-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 54px;
  min-height: 54px;
  border: 1px solid rgba(255,255,255,.78);
  border-radius: 6px;
  background: rgba(8,11,18,.62);
  cursor: pointer;
  transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease, opacity .2s ease;
}

.live-upload-btn img {
  width: 28px;
  height: 28px;
  object-fit: contain;
  filter: invert(1);
  pointer-events: none;
}

.live-upload-btn:not(:disabled):hover,
.live-upload-btn:not(:disabled):focus-visible {
  border-color: #e31e26;
  box-shadow: 0 0 0 3px rgba(227,30,38,.18);
  transform: translateY(-1px);
}

.live-upload-btn:disabled {
  cursor: not-allowed;
  opacity: .45;
}

.live-upload-btn.is-uploading {
  cursor: wait;
  border-color: rgba(227,30,38,.75);
}

.live-upload-btn.is-done {
  border-color: rgba(67, 255, 164, .78);
  box-shadow: 0 0 0 3px rgba(67, 255, 164, .15);
}

.live-upload-status {
  margin-top: 4px;
  color: rgba(255,255,255,.62);
  font-size: 12px;
  line-height: 1.45;
  text-transform: none;
}

.live-upload-status[data-state="uploading"] {
  color: rgba(255,255,255,.82);
}

.live-upload-status[data-state="success"] {
  color: #43ffa4;
}

.live-upload-status[data-state="error"] {
  color: #ff5b64;
}


/* Typographie gaming MHTM - pages internes/admin */
.admin-title,
.admin-title h1,
.page-title h1,
.section-head h2,
.section-headline h2,
.game-card h2,
.day-head h2,
.public-match-card strong,
.live-hero-title,
.live-admin-title{
  font-family:var(--font-hero);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.035em;
}

.admin-table th,
.admin-table td,
.admin-filters label,
.match-create-form label,
.match-inline-form label,
.form-panel label,
.confirm-title,
.live-upload-status,
.toast,
.field-error{
  font-family:var(--font-body);
}

.stat-card strong,
.stat-card span,
.game-meta strong,
.game-meta span,
.rank-card strong,
.match-time,
.match-date,
.admin-table .number,
.admin-table .cash,
.admin-table .price{
  font-family:var(--font-stats);
  letter-spacing:.025em;
}

.admin-filter-btn,
.admin-action-btn,
.red-btn,
.outline-btn,
.submit-btn,
.live-upload-btn,
.status-pill{
  font-family:var(--font-action);
  letter-spacing:.055em;
  text-transform:uppercase;
}


/* Ajustement tailles pages internes/admin */
.page-title h1{
  font-size:clamp(44px,4.8vw,68px);
  line-height:.92;
}

.page-title p{
  font-size:20px;
  line-height:1.35;
}

.section-head h2,
.section-headline h2{
  font-size:clamp(29px,2.5vw,40px);
  line-height:.95;
}

.mini-card h3{
  font-size:23px;
}

.mini-card p,
.game-card p,
.rule-list li,
.feature-list li,
.section-headline p{
  font-size:18px;
  line-height:1.42;
}

.game-card h2{
  font-size:clamp(40px,3.8vw,58px);
  line-height:.9;
}

.game-card .category{
  font-size:21px;
}

.game-meta strong,
.game-meta span{
  font-size:17px;
}

.form-title h1{
  font-size:clamp(42px,4vw,62px);
  line-height:.92;
}

.form-title p{
  font-size:19px;
}

.form-panel label,
.admin-filters label,
.match-create-form label,
.match-inline-form label{
  font-size:16px;
}

.form-panel input,
.form-panel select,
.form-panel textarea,
.admin-filters input,
.admin-filters select,
.match-create-form input,
.match-create-form select,
.match-inline-form input,
.match-inline-form select{
  font-size:18px;
}

.confirm-title{
  font-size:18px;
}

.check-row{
  font-size:16px;
  line-height:1.25;
}

.summary-row strong{
  font-size:19px;
}

.summary-row span{
  font-size:17px;
}

.limited strong{
  font-size:23px;
}

.limited span{
  font-size:17px;
  line-height:1.18;
}

.admin-title h1{
  font-size:clamp(42px,4.2vw,64px);
  line-height:.92;
}

.admin-alert{
  font-size:17px;
}

.stat-card span{
  font-size:16px;
}

.stat-card strong{
  font-size:42px;
}

.admin-table th{
  font-size:15px;
}

.admin-table td{
  font-size:16px;
}

.admin-filter-btn,
.admin-action-btn,
.red-btn,
.outline-btn,
.status-pill{
  font-size:17px;
}

.rank-card h3{
  font-size:24px;
}

.rank-card strong{
  font-size:31px;
}


/* Ajustement graisse pages internes/admin - version 50% plus light */
.page-title h1,
.admin-title h1,
.form-title h1,
.section-head h2,
.section-headline h2,
.game-card h2,
.day-head h2,
.rank-card h3,
.mini-card h3{
  font-weight:600;
}

.page-title p,
.form-title p,
.mini-card p,
.game-card p,
.rule-list li,
.feature-list li,
.section-headline p,
.form-panel label,
.check-row,
.admin-alert,
.admin-table th,
.admin-table td{
  font-weight:400;
}

.admin-filter-btn,
.admin-action-btn,
.red-btn,
.outline-btn,
.submit-btn,
.live-upload-btn,
.status-pill{
  font-weight:400;
}

.stat-card strong,
.rank-card strong,
.game-meta strong,
.game-meta span,
.summary-row strong,
.summary-row span,
.match-time,
.match-date{
  font-weight:500;
}

.limited strong{
  font-weight:500;
}

.limited span{
  font-weight:400;
}


/* Ajustement demandé : règles, textes longs et prix encore plus light */
.page-title p,
.form-title p,
.mini-card p,
.game-card p,
.rule-list li,
.rule-list strong,
.feature-list li,
.section-headline p,
.form-panel label,
.check-row,
.admin-alert,
.admin-table th,
.admin-table td{
  font-weight:300;
}

.page-title h1,
.admin-title h1,
.form-title h1,
.section-head h2,
.section-headline h2,
.game-card h2,
.day-head h2,
.rank-card h3,
.mini-card h3{
  font-weight:500;
}

.admin-filter-btn,
.admin-action-btn,
.red-btn,
.outline-btn,
.submit-btn,
.live-upload-btn,
.status-pill{
  font-weight:400;
  opacity:.92;
}

.stat-card strong,
.rank-card strong,
.game-meta strong,
.game-meta span,
.summary-row strong,
.summary-row span,
.match-time,
.match-date,
.rank-card,
.rank-card p{
  font-weight:400;
}

.limited strong{
  font-weight:400;
}

.limited span{
  font-weight:300;
}

.prize-grid,
.prize-grid *,
.rules-stack,
.rules-stack *,
.rule-list,
.rule-list *{
  font-weight:300;
}

.prize-grid strong,
.rank-card strong{
  font-weight:400;
}


/* Header login/logout text-only state override */
.login-btn.active{
  color:#fff;
}

.header .login-btn:hover,
.header .login-btn:focus-visible{
  color:#e31e26!important;
}

@media (max-width:700px){
  .header .logout-form,
  .header .logout-form .login-btn{
    width:auto!important;
  }
}

/* Header/footer mobile commun : reprend la structure mobile de l'accueil sur toutes les pages */
@media (max-width:640px){
  .page,
  .page.inner-page,
  .home-page,
  body.inner-page,
  body.inner-page.admin-page{
    --header-height:92px;
    --content-width:calc(100vw - 44px);
  }

  .page .header,
  .page.inner-page .header,
  .home-page .header,
  body.inner-page .header,
  body.inner-page.admin-page .header{
    position:relative!important;
    height:92px!important;
    min-height:92px!important;
    display:grid!important;
    grid-template-columns:52px 1fr auto!important;
    align-items:center!important;
    gap:10px!important;
    padding:12px 22px 8px!important;
    flex-wrap:nowrap!important;
    background:linear-gradient(180deg,#070b12 0%,rgba(7,11,18,.94) 72%,rgba(7,11,18,0) 100%)!important;
    z-index:20!important;
  }

  .page .mobile-menu-toggle,
  .page.inner-page .mobile-menu-toggle,
  .home-page .mobile-menu-toggle,
  body.inner-page .mobile-menu-toggle,
  body.inner-page.admin-page .mobile-menu-toggle{
    display:inline-flex!important;
    flex-direction:column!important;
    justify-content:center!important;
    gap:7px!important;
    width:42px!important;
    height:42px!important;
    border:0!important;
    padding:0!important;
    background:transparent!important;
    justify-self:start!important;
    grid-column:1!important;
    z-index:2!important;
  }

  .page .mobile-menu-toggle span,
  .page.inner-page .mobile-menu-toggle span,
  .home-page .mobile-menu-toggle span,
  body.inner-page .mobile-menu-toggle span,
  body.inner-page.admin-page .mobile-menu-toggle span{
    display:block!important;
    width:34px!important;
    height:3px!important;
    border-radius:999px!important;
    background:#e84a4f!important;
    box-shadow:0 0 10px rgba(227,30,38,.28)!important;
  }

  .page .brand,
  .page.inner-page .brand,
  .home-page .brand,
  body.inner-page .brand,
  body.inner-page.admin-page .brand{
    position:absolute!important;
    left:50%!important;
    top:50%!important;
    transform:translate(-50%,-50%)!important;
    width:118px!important;
    height:56px!important;
    flex:0 0 auto!important;
    justify-self:center!important;
    grid-column:auto!important;
    z-index:1!important;
  }

  .page .brand img,
  .page.inner-page .brand img,
  .home-page .brand img,
  body.inner-page .brand img,
  body.inner-page.admin-page .brand img{
    width:100%!important;
    height:100%!important;
    object-fit:contain!important;
  }

  .page .header > .login-btn,
  .page.inner-page .header > .login-btn,
  .home-page .header > .login-btn,
  body.inner-page .header > .login-btn,
  body.inner-page.admin-page .header > .login-btn,
  .page .header .logout-form,
  .page.inner-page .header .logout-form,
  .home-page .header .logout-form,
  body.inner-page .header .logout-form,
  body.inner-page.admin-page .header .logout-form{
    grid-column:3!important;
    justify-self:end!important;
    z-index:2!important;
  }

  .page .nav,
  .page.inner-page .nav,
  .home-page .nav,
  body.inner-page .nav,
  body.inner-page.admin-page .nav{
    display:none!important;
    position:absolute!important;
    left:22px!important;
    right:22px!important;
    top:82px!important;
    z-index:30!important;
    width:auto!important;
    padding:12px!important;
    border:1px solid rgba(227,30,38,.28)!important;
    border-radius:14px!important;
    background:rgba(7,11,18,.97)!important;
    box-shadow:0 22px 40px rgba(0,0,0,.55)!important;
    overflow:visible!important;
    white-space:normal!important;
    order:initial!important;
  }

  .page .nav.is-open,
  .page.inner-page .nav.is-open,
  .home-page .nav.is-open,
  body.inner-page .nav.is-open,
  body.inner-page.admin-page .nav.is-open{
    display:grid!important;
    grid-template-columns:1fr 1fr!important;
    gap:8px!important;
  }

  .page .nav a,
  .page.inner-page .nav a,
  .home-page .nav a,
  body.inner-page .nav a,
  body.inner-page.admin-page .nav a{
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    min-height:38px!important;
    padding:8px 10px!important;
    border:1px solid rgba(255,255,255,.08)!important;
    border-radius:10px!important;
    background:rgba(255,255,255,.035)!important;
    font-size:15px!important;
    line-height:1.1!important;
  }

  .page .footer,
  .page.inner-page .footer,
  .home-page .footer,
  body.inner-page .footer,
  body.inner-page.admin-page .footer{
    position:relative!important;
    left:auto!important;
    right:auto!important;
    bottom:auto!important;
    width:100%!important;
    height:auto!important;
    margin-top:auto!important;
    padding:0 22px 12px!important;
    background:linear-gradient(180deg,rgba(5,8,14,0) 0%,rgba(5,8,14,.88) 26%,#05080e 100%)!important;
  }

  .page .footer-line,
  .page.inner-page .footer-line,
  .home-page .footer-line,
  body.inner-page .footer-line,
  body.inner-page.admin-page .footer-line{
    display:none!important;
  }

  .page .footer-content,
  .page.inner-page .footer-content,
  .home-page .footer-content,
  body.inner-page .footer-content,
  body.inner-page.admin-page .footer-content{
    position:relative!important;
    left:auto!important;
    top:auto!important;
    transform:none!important;
    width:100%!important;
    height:48px!important;
    display:grid!important;
    grid-template-columns:1fr auto 1fr!important;
    align-items:center!important;
    justify-items:center!important;
    gap:10px!important;
  }

  .page .footer-brand,
  .page.inner-page .footer-brand,
  .home-page .footer-brand,
  body.inner-page .footer-brand,
  body.inner-page.admin-page .footer-brand{
    width:64px!important;
    height:42px!important;
    flex:0 0 64px!important;
    justify-self:start!important;
  }

  .page .footer-brand img,
  .page.inner-page .footer-brand img,
  .home-page .footer-brand img,
  body.inner-page .footer-brand img,
  body.inner-page.admin-page .footer-brand img{
    left:0!important;
    top:8px!important;
    width:64px!important;
    height:30px!important;
  }

  .page .footer-brand span,
  .page.inner-page .footer-brand span,
  .home-page .footer-brand span,
  body.inner-page .footer-brand span,
  body.inner-page.admin-page .footer-brand span,
  .page .footer-social a:nth-child(2),
  .page.inner-page .footer-social a:nth-child(2),
  .home-page .footer-social a:nth-child(2),
  body.inner-page .footer-social a:nth-child(2),
  body.inner-page.admin-page .footer-social a:nth-child(2){
    display:none!important;
  }

  .page .footer-content p,
  .page.inner-page .footer-content p,
  .home-page .footer-content p,
  body.inner-page .footer-content p,
  body.inner-page.admin-page .footer-content p{
    margin:0!important;
    font-size:13px!important;
    white-space:nowrap!important;
  }

  .page .footer-social,
  .page.inner-page .footer-social,
  .home-page .footer-social,
  body.inner-page .footer-social,
  body.inner-page.admin-page .footer-social{
    width:auto!important;
    height:42px!important;
    gap:0!important;
    justify-self:end!important;
    flex:0 0 auto!important;
    font-size:0!important;
  }

  .page .footer-social img,
  .page.inner-page .footer-social img,
  .home-page .footer-social img,
  body.inner-page .footer-social img,
  body.inner-page.admin-page .footer-social img{
    width:36px!important;
    height:36px!important;
  }
}

@media (max-width:420px){
  .page,
  .page.inner-page,
  .home-page,
  body.inner-page,
  body.inner-page.admin-page{
    --content-width:calc(100vw - 30px);
  }

  .page .header,
  .page.inner-page .header,
  .home-page .header,
  body.inner-page .header,
  body.inner-page.admin-page .header{
    grid-template-columns:42px 1fr auto!important;
    padding-left:15px!important;
    padding-right:15px!important;
    gap:7px!important;
  }

  .page .mobile-menu-toggle,
  .page.inner-page .mobile-menu-toggle,
  .home-page .mobile-menu-toggle,
  body.inner-page .mobile-menu-toggle,
  body.inner-page.admin-page .mobile-menu-toggle{
    width:36px!important;
  }

  .page .mobile-menu-toggle span,
  .page.inner-page .mobile-menu-toggle span,
  .home-page .mobile-menu-toggle span,
  body.inner-page .mobile-menu-toggle span,
  body.inner-page.admin-page .mobile-menu-toggle span{
    width:29px!important;
  }

  .page .brand,
  .page.inner-page .brand,
  .home-page .brand,
  body.inner-page .brand,
  body.inner-page.admin-page .brand{
    width:96px!important;
    height:46px!important;
  }

  .page .nav,
  .page.inner-page .nav,
  .home-page .nav,
  body.inner-page .nav,
  body.inner-page.admin-page .nav{
    left:15px!important;
    right:15px!important;
  }

  .page .footer,
  .page.inner-page .footer,
  .home-page .footer,
  body.inner-page .footer,
  body.inner-page.admin-page .footer{
    padding-left:15px!important;
    padding-right:15px!important;
  }

  .page .footer-brand img,
  .page.inner-page .footer-brand img,
  .home-page .footer-brand img,
  body.inner-page .footer-brand img,
  body.inner-page.admin-page .footer-brand img{
    width:55px!important;
  }

  .page .footer-content p,
  .page.inner-page .footer-content p,
  .home-page .footer-content p,
  body.inner-page .footer-content p,
  body.inner-page.admin-page .footer-content p{
    font-size:11px!important;
  }

  .page .footer-social img,
  .page.inner-page .footer-social img,
  .home-page .footer-social img,
  body.inner-page .footer-social img,
  body.inner-page.admin-page .footer-social img{
    width:32px!important;
    height:32px!important;
  }
}

/* Menu burger mobile en panneau latéral sombre, couleur thème MHTM */
@media (max-width:820px){
  body.mobile-nav-open{
    overflow:hidden!important;
  }

  body.mobile-nav-open::before{
    content:'';
    position:fixed;
    inset:0;
    z-index:70;
    background:rgba(3,5,10,.58);
    backdrop-filter:blur(2px);
    pointer-events:none;
  }

  .header .mobile-menu-toggle{
    cursor:pointer!important;
  }

  .header .mobile-menu-toggle.is-open{
    position:fixed!important;
    left:32px!important;
    top:32px!important;
    z-index:100!important;
    width:32px!important;
    height:32px!important;
    display:inline-flex!important;
    align-items:center!important;
    justify-content:center!important;
    gap:0!important;
    background:transparent!important;
    border:0!important;
    padding:0!important;
  }

  .header .mobile-menu-toggle.is-open span{
    position:absolute!important;
    width:20px!important;
    height:2px!important;
    background:#fff!important;
    border-radius:999px!important;
    box-shadow:none!important;
  }

  .header .mobile-menu-toggle.is-open span:nth-child(1){
    transform:rotate(45deg)!important;
  }

  .header .mobile-menu-toggle.is-open span:nth-child(2){
    opacity:0!important;
  }

  .header .mobile-menu-toggle.is-open span:nth-child(3){
    transform:rotate(-45deg)!important;
  }

  .header .mobile-menu-toggle + .brand + .nav,
  .page .mobile-menu-toggle + .brand + .nav,
  .page.inner-page .mobile-menu-toggle + .brand + .nav,
  .home-page .mobile-menu-toggle + .brand + .nav,
  body.inner-page .mobile-menu-toggle + .brand + .nav,
  body.inner-page.admin-page .mobile-menu-toggle + .brand + .nav{
    display:flex!important;
    position:fixed!important;
    left:18px!important;
    top:18px!important;
    right:auto!important;
    bottom:18px!important;
    width:min(76vw,292px)!important;
    max-width:292px!important;
    height:auto!important;
    z-index:90!important;
    flex-direction:column!important;
    align-items:stretch!important;
    justify-content:flex-start!important;
    gap:0!important;
    padding:66px 16px 22px!important;
    border:1px solid rgba(227,30,38,.32)!important;
    border-left:3px solid #e31e26!important;
    border-radius:16px!important;
    background:
      radial-gradient(circle at 0% 0%,rgba(227,30,38,.22) 0,rgba(227,30,38,0) 34%),
      linear-gradient(180deg,rgba(10,14,24,.99) 0%,rgba(5,8,14,.99) 100%)!important;
    box-shadow:18px 0 48px rgba(0,0,0,.62),0 0 0 1px rgba(255,255,255,.04) inset!important;
    overflow:hidden!important;
    white-space:normal!important;
    opacity:0!important;
    pointer-events:none!important;
    transform:translateX(calc(-100% - 28px))!important;
    transition:transform .28s ease,opacity .22s ease!important;
  }

  .header .mobile-menu-toggle + .brand + .nav::before,
  .page .mobile-menu-toggle + .brand + .nav::before,
  .page.inner-page .mobile-menu-toggle + .brand + .nav::before,
  .home-page .mobile-menu-toggle + .brand + .nav::before,
  body.inner-page .mobile-menu-toggle + .brand + .nav::before,
  body.inner-page.admin-page .mobile-menu-toggle + .brand + .nav::before{
    content:'MENU';
    position:absolute;
    left:50px;
    top:30px;
    color:#e31e26;
    font-family:'Oswald','Barlow Condensed',sans-serif;
    font-size:13px;
    letter-spacing:.18em;
    line-height:1;
  }

  .header .mobile-menu-toggle + .brand + .nav::after,
  .page .mobile-menu-toggle + .brand + .nav::after,
  .page.inner-page .mobile-menu-toggle + .brand + .nav::after,
  .home-page .mobile-menu-toggle + .brand + .nav::after,
  body.inner-page .mobile-menu-toggle + .brand + .nav::after,
  body.inner-page.admin-page .mobile-menu-toggle + .brand + .nav::after{
    content:'';
    position:absolute;
    right:-46px;
    top:52px;
    width:92px;
    height:160px;
    border-radius:999px;
    background:radial-gradient(circle,rgba(227,30,38,.22) 0,rgba(227,30,38,.08) 45%,rgba(227,30,38,0) 70%);
    pointer-events:none;
  }

  .header .mobile-menu-toggle + .brand + .nav.is-open,
  .page .mobile-menu-toggle + .brand + .nav.is-open,
  .page.inner-page .mobile-menu-toggle + .brand + .nav.is-open,
  .home-page .mobile-menu-toggle + .brand + .nav.is-open,
  body.inner-page .mobile-menu-toggle + .brand + .nav.is-open,
  body.inner-page.admin-page .mobile-menu-toggle + .brand + .nav.is-open{
    opacity:1!important;
    pointer-events:auto!important;
    transform:translateX(0)!important;
  }

  .header .mobile-menu-toggle + .brand + .nav a,
  .page .mobile-menu-toggle + .brand + .nav a,
  .page.inner-page .mobile-menu-toggle + .brand + .nav a,
  .home-page .mobile-menu-toggle + .brand + .nav a,
  body.inner-page .mobile-menu-toggle + .brand + .nav a,
  body.inner-page.admin-page .mobile-menu-toggle + .brand + .nav a{
    display:flex!important;
    align-items:center!important;
    justify-content:flex-start!important;
    min-height:38px!important;
    padding:9px 8px!important;
    border:0!important;
    border-radius:0!important;
    background:transparent!important;
    color:#fff!important;
    font-size:17px!important;
    line-height:1.15!important;
    letter-spacing:.035em!important;
    text-align:left!important;
    box-shadow:none!important;
    transition:color .2s ease,transform .2s ease,padding-left .2s ease!important;
  }

  .header .mobile-menu-toggle + .brand + .nav a:hover,
  .header .mobile-menu-toggle + .brand + .nav a:focus-visible,
  .header .mobile-menu-toggle + .brand + .nav a.active,
  .page .mobile-menu-toggle + .brand + .nav a:hover,
  .page .mobile-menu-toggle + .brand + .nav a:focus-visible,
  .page .mobile-menu-toggle + .brand + .nav a.active,
  .home-page .mobile-menu-toggle + .brand + .nav a:hover,
  .home-page .mobile-menu-toggle + .brand + .nav a:focus-visible,
  .home-page .mobile-menu-toggle + .brand + .nav a.active,
  body.inner-page .mobile-menu-toggle + .brand + .nav a:hover,
  body.inner-page .mobile-menu-toggle + .brand + .nav a:focus-visible,
  body.inner-page .mobile-menu-toggle + .brand + .nav a.active,
  body.inner-page.admin-page .mobile-menu-toggle + .brand + .nav a:hover,
  body.inner-page.admin-page .mobile-menu-toggle + .brand + .nav a:focus-visible,
  body.inner-page.admin-page .mobile-menu-toggle + .brand + .nav a.active{
    color:#e31e26!important;
    padding-left:14px!important;
  }

  .header .mobile-menu-toggle + .brand + .nav a:nth-last-child(1){
    margin-top:22px!important;
    padding-top:18px!important;
    border-top:1px solid rgba(255,255,255,.12)!important;
  }
}

@media (max-width:420px){
  .header .mobile-menu-toggle.is-open{
    left:28px!important;
    top:30px!important;
  }

  .header .mobile-menu-toggle + .brand + .nav,
  .page .mobile-menu-toggle + .brand + .nav,
  .page.inner-page .mobile-menu-toggle + .brand + .nav,
  .home-page .mobile-menu-toggle + .brand + .nav,
  body.inner-page .mobile-menu-toggle + .brand + .nav,
  body.inner-page.admin-page .mobile-menu-toggle + .brand + .nav{
    left:14px!important;
    top:16px!important;
    bottom:16px!important;
    width:min(78vw,278px)!important;
    padding-left:14px!important;
    padding-right:14px!important;
  }
}

/* Correctif mobile : menu burger en liste latérale attachée à gauche, sans effet popup */
@media (max-width:820px){
  body.mobile-nav-open{
    overflow:hidden!important;
  }

  body.mobile-nav-open::before{
    content:''!important;
    position:fixed!important;
    inset:0!important;
    z-index:70!important;
    background:rgba(3,5,10,.48)!important;
    backdrop-filter:none!important;
    -webkit-backdrop-filter:none!important;
    pointer-events:none!important;
  }

  .header .mobile-menu-toggle.is-open{
    position:fixed!important;
    left:16px!important;
    top:25px!important;
    z-index:100!important;
    width:28px!important;
    height:28px!important;
    display:inline-flex!important;
    align-items:center!important;
    justify-content:center!important;
    background:transparent!important;
    border:0!important;
    border-radius:0!important;
    padding:0!important;
    box-shadow:none!important;
  }

  .header .mobile-menu-toggle.is-open span{
    position:absolute!important;
    width:22px!important;
    height:2px!important;
    background:#fff!important;
    border-radius:999px!important;
    box-shadow:none!important;
  }

  .header .mobile-menu-toggle.is-open span:nth-child(1){
    transform:rotate(45deg)!important;
  }

  .header .mobile-menu-toggle.is-open span:nth-child(2){
    opacity:0!important;
  }

  .header .mobile-menu-toggle.is-open span:nth-child(3){
    transform:rotate(-45deg)!important;
  }

  .header .mobile-menu-toggle + .brand + .nav,
  .page .mobile-menu-toggle + .brand + .nav,
  .page.inner-page .mobile-menu-toggle + .brand + .nav,
  .home-page .mobile-menu-toggle + .brand + .nav,
  body.inner-page .mobile-menu-toggle + .brand + .nav,
  body.inner-page.admin-page .mobile-menu-toggle + .brand + .nav{
    display:flex!important;
    position:fixed!important;
    left:0!important;
    top:0!important;
    right:auto!important;
    bottom:0!important;
    width:min(67vw,260px)!important;
    max-width:260px!important;
    height:100dvh!important;
    min-height:100svh!important;
    z-index:90!important;
    flex-direction:column!important;
    align-items:stretch!important;
    justify-content:flex-start!important;
    gap:0!important;
    padding:78px 20px 26px!important;
    border:0!important;
    border-right:1px solid rgba(255,255,255,.08)!important;
    border-radius:0!important;
    background:linear-gradient(180deg,rgba(8,13,22,.99) 0%,rgba(4,8,14,.99) 100%)!important;
    box-shadow:12px 0 28px rgba(0,0,0,.42)!important;
    overflow:hidden!important;
    white-space:normal!important;
    opacity:0!important;
    pointer-events:none!important;
    transform:translateX(-100%)!important;
    transition:transform .28s ease,opacity .2s ease!important;
  }

  .header .mobile-menu-toggle + .brand + .nav::before,
  .page .mobile-menu-toggle + .brand + .nav::before,
  .page.inner-page .mobile-menu-toggle + .brand + .nav::before,
  .home-page .mobile-menu-toggle + .brand + .nav::before,
  body.inner-page .mobile-menu-toggle + .brand + .nav::before,
  body.inner-page.admin-page .mobile-menu-toggle + .brand + .nav::before{
    content:''!important;
    position:absolute!important;
    right:22px!important;
    top:28px!important;
    left:auto!important;
    width:20px!important;
    height:20px!important;
    border:2px solid rgba(255,255,255,.96)!important;
    border-radius:999px!important;
    background:transparent!important;
    pointer-events:none!important;
  }

  .header .mobile-menu-toggle + .brand + .nav::after,
  .page .mobile-menu-toggle + .brand + .nav::after,
  .page.inner-page .mobile-menu-toggle + .brand + .nav::after,
  .home-page .mobile-menu-toggle + .brand + .nav::after,
  body.inner-page .mobile-menu-toggle + .brand + .nav::after,
  body.inner-page.admin-page .mobile-menu-toggle + .brand + .nav::after{
    content:''!important;
    position:absolute!important;
    right:17px!important;
    top:48px!important;
    width:11px!important;
    height:2px!important;
    border-radius:999px!important;
    background:#fff!important;
    transform:rotate(45deg)!important;
    pointer-events:none!important;
  }

  .header .mobile-menu-toggle + .brand + .nav.is-open,
  .page .mobile-menu-toggle + .brand + .nav.is-open,
  .page.inner-page .mobile-menu-toggle + .brand + .nav.is-open,
  .home-page .mobile-menu-toggle + .brand + .nav.is-open,
  body.inner-page .mobile-menu-toggle + .brand + .nav.is-open,
  body.inner-page.admin-page .mobile-menu-toggle + .brand + .nav.is-open{
    opacity:1!important;
    pointer-events:auto!important;
    transform:translateX(0)!important;
  }

  .header .mobile-menu-toggle + .brand + .nav a,
  .page .mobile-menu-toggle + .brand + .nav a,
  .page.inner-page .mobile-menu-toggle + .brand + .nav a,
  .home-page .mobile-menu-toggle + .brand + .nav a,
  body.inner-page .mobile-menu-toggle + .brand + .nav a,
  body.inner-page.admin-page .mobile-menu-toggle + .brand + .nav a{
    position:relative!important;
    display:block!important;
    min-height:0!important;
    margin:0!important;
    padding:9px 0 10px!important;
    border:0!important;
    border-radius:0!important;
    background:transparent!important;
    color:#fff!important;
    font-family:'Oswald','Barlow Condensed',sans-serif!important;
    font-size:18px!important;
    font-weight:500!important;
    line-height:1.15!important;
    letter-spacing:.02em!important;
    text-align:left!important;
    box-shadow:none!important;
    text-decoration:none!important;
    transform:none!important;
    transition:color .2s ease,padding-left .2s ease!important;
  }

  .header .mobile-menu-toggle + .brand + .nav a::after,
  .page .mobile-menu-toggle + .brand + .nav a::after,
  .page.inner-page .mobile-menu-toggle + .brand + .nav a::after,
  .home-page .mobile-menu-toggle + .brand + .nav a::after,
  body.inner-page .mobile-menu-toggle + .brand + .nav a::after,
  body.inner-page.admin-page .mobile-menu-toggle + .brand + .nav a::after{
    display:none!important;
    content:none!important;
  }

  .header .mobile-menu-toggle + .brand + .nav a::before,
  .page .mobile-menu-toggle + .brand + .nav a::before,
  .page.inner-page .mobile-menu-toggle + .brand + .nav a::before,
  .home-page .mobile-menu-toggle + .brand + .nav a::before,
  body.inner-page .mobile-menu-toggle + .brand + .nav a::before,
  body.inner-page.admin-page .mobile-menu-toggle + .brand + .nav a::before{
    content:''!important;
    position:absolute!important;
    left:-20px!important;
    top:50%!important;
    width:3px!important;
    height:22px!important;
    border-radius:0!important;
    background:#e31e26!important;
    opacity:0!important;
    transform:translateY(-50%)!important;
    transition:opacity .2s ease!important;
  }

  .header .mobile-menu-toggle + .brand + .nav a:hover,
  .header .mobile-menu-toggle + .brand + .nav a:focus-visible,
  .page .mobile-menu-toggle + .brand + .nav a:hover,
  .page .mobile-menu-toggle + .brand + .nav a:focus-visible,
  .home-page .mobile-menu-toggle + .brand + .nav a:hover,
  .home-page .mobile-menu-toggle + .brand + .nav a:focus-visible,
  body.inner-page .mobile-menu-toggle + .brand + .nav a:hover,
  body.inner-page .mobile-menu-toggle + .brand + .nav a:focus-visible,
  body.inner-page.admin-page .mobile-menu-toggle + .brand + .nav a:hover,
  body.inner-page.admin-page .mobile-menu-toggle + .brand + .nav a:focus-visible{
    color:#e31e26!important;
    padding-left:4px!important;
  }

  .header .mobile-menu-toggle + .brand + .nav a.active,
  .page .mobile-menu-toggle + .brand + .nav a.active,
  .page.inner-page .mobile-menu-toggle + .brand + .nav a.active,
  .home-page .mobile-menu-toggle + .brand + .nav a.active,
  body.inner-page .mobile-menu-toggle + .brand + .nav a.active,
  body.inner-page.admin-page .mobile-menu-toggle + .brand + .nav a.active{
    color:#fff!important;
    padding-left:0!important;
  }

  .header .mobile-menu-toggle + .brand + .nav a.active::before,
  .page .mobile-menu-toggle + .brand + .nav a.active::before,
  .page.inner-page .mobile-menu-toggle + .brand + .nav a.active::before,
  .home-page .mobile-menu-toggle + .brand + .nav a.active::before,
  body.inner-page .mobile-menu-toggle + .brand + .nav a.active::before,
  body.inner-page.admin-page .mobile-menu-toggle + .brand + .nav a.active::before{
    opacity:1!important;
  }

  .header .mobile-menu-toggle + .brand + .nav a:nth-last-child(1){
    margin-top:0!important;
    padding-top:9px!important;
    border-top:0!important;
  }
}

@media (max-width:420px){
  .header .mobile-menu-toggle.is-open{
    left:14px!important;
    top:24px!important;
  }

  .header .mobile-menu-toggle + .brand + .nav,
  .page .mobile-menu-toggle + .brand + .nav,
  .page.inner-page .mobile-menu-toggle + .brand + .nav,
  .home-page .mobile-menu-toggle + .brand + .nav,
  body.inner-page .mobile-menu-toggle + .brand + .nav,
  body.inner-page.admin-page .mobile-menu-toggle + .brand + .nav{
    left:0!important;
    top:0!important;
    bottom:0!important;
    width:min(68vw,245px)!important;
    max-width:245px!important;
    height:100dvh!important;
    padding:74px 18px 24px!important;
    border-radius:0!important;
  }

  .header .mobile-menu-toggle + .brand + .nav a,
  .page .mobile-menu-toggle + .brand + .nav a,
  .page.inner-page .mobile-menu-toggle + .brand + .nav a,
  .home-page .mobile-menu-toggle + .brand + .nav a,
  body.inner-page .mobile-menu-toggle + .brand + .nav a,
  body.inner-page.admin-page .mobile-menu-toggle + .brand + .nav a{
    font-size:17px!important;
    padding-top:8px!important;
    padding-bottom:9px!important;
  }
}
