@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:ital,wght@0,400;0,600;0,700;0,800;0,900;1,700;1,900&family=Barlow:wght@300;400;500;600&display=swap');

:root {
  --pitch:#0a1f0e;--pitch-2:#0d2712;--pitch-3:#112e16;--grass:#1a4726;
  --line:rgba(255,255,255,0.07);
  --green:#00e676;--green-2:#00c853;--green-dim:#1b5e20;
  --white:#f0fff4;--white-2:rgba(240,255,244,0.85);--white-3:rgba(240,255,244,0.45);
  --white-4:rgba(240,255,244,0.15);--white-5:rgba(240,255,244,0.07);
  --yellow:#ffd600;--red:#ff1744;--red-dim:rgba(255,23,68,0.12);--amber:#ff6d00;
  --glow:0 0 40px rgba(0,230,118,0.15);--glow-sm:0 0 16px rgba(0,230,118,0.2);
  --r:8px;--r-lg:16px;--r-xl:24px;
  --t:0.22s cubic-bezier(0.4,0,0.2,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Barlow',sans-serif;background:var(--pitch);color:var(--white);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}
body::before{content:'';position:fixed;inset:0;background-image:radial-gradient(circle 120px at 50% 50%,transparent 118px,var(--line) 119px,var(--line) 121px,transparent 122px),linear-gradient(to right,transparent 49.8%,var(--line) 49.9%,var(--line) 50.1%,transparent 50.2%),repeating-linear-gradient(180deg,var(--pitch) 0px,var(--pitch) 60px,var(--pitch-2) 60px,var(--pitch-2) 120px);background-size:100% 100%,100% 100%,100% 120px;pointer-events:none;z-index:0;opacity:0.5}
body::after{content:'';position:fixed;inset:0;background:radial-gradient(ellipse 80% 50% at 50% 0%,rgba(0,230,118,0.05) 0%,transparent 60%);pointer-events:none;z-index:0}

/* HEADER */
.header{position:sticky;top:0;z-index:200;background:rgba(10,31,14,0.92);backdrop-filter:blur(20px);border-bottom:1px solid var(--white-4);padding:0 clamp(1rem,4vw,2.5rem)}
.header-inner{max-width:1100px;margin:0 auto;height:56px;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.logo-emblem{width:36px;height:36px;background:var(--green);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;box-shadow:var(--glow-sm)}
.logo-text{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:1.2rem;color:var(--white);letter-spacing:0.04em;text-transform:uppercase;line-height:1}
.logo-text span{color:var(--green)}
.logo-sub{font-size:0.58rem;color:var(--white-3);letter-spacing:0.12em;text-transform:uppercase;margin-top:2px}
.nav-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--r);font-family:'Barlow Condensed',sans-serif;font-size:0.8rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;color:var(--white-3);border:1px solid var(--white-4);background:transparent;text-decoration:none;cursor:pointer;transition:all var(--t);white-space:nowrap}
.nav-btn:hover{color:var(--green);border-color:var(--green);background:rgba(0,230,118,0.06)}

/* LAYOUT */
.wrap{max-width:1100px;margin:0 auto;padding:0 clamp(1rem,4vw,2.5rem);position:relative;z-index:1}
.wrap-sm{max-width:580px;margin:0 auto;padding:0 clamp(1rem,4vw,2rem);position:relative;z-index:1}

/* HERO */
.hero{padding:clamp(2rem,6vw,5rem) clamp(1rem,4vw,2.5rem) clamp(1.5rem,3vw,3rem);position:relative;z-index:1}
.hero-inner{max-width:1100px;margin:0 auto}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(0,230,118,0.1);border:1px solid rgba(0,230,118,0.25);border-radius:4px;padding:5px 14px;font-family:'Barlow Condensed',sans-serif;font-size:0.75rem;font-weight:700;letter-spacing:0.12em;color:var(--green);text-transform:uppercase;margin-bottom:1rem}
.hero-tag-dot{width:6px;height:6px;background:var(--green);border-radius:50%;animation:blink 2s ease infinite}
.hero h1{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-style:italic;font-size:clamp(2.8rem,9vw,7rem);line-height:0.9;letter-spacing:-0.01em;text-transform:uppercase;color:var(--white);margin-bottom:1rem}
.hero h1 .outline{color:transparent;-webkit-text-stroke:2px var(--green);display:block}
.hero h1 .solid{color:var(--green);display:block;text-shadow:0 0 60px rgba(0,230,118,0.3)}
.hero-desc{font-size:clamp(0.85rem,2vw,1rem);color:var(--white-3);max-width:440px;line-height:1.65;font-weight:300;margin-bottom:1.5rem}
.hero-stats{display:flex;gap:2rem;flex-wrap:wrap}
.hero-stat{border-left:2px solid var(--green);padding-left:1rem}
.hero-stat-val{font-family:'Barlow Condensed',sans-serif;font-size:1.5rem;font-weight:900;color:var(--green)}
.hero-stat-lbl{font-size:0.7rem;color:var(--white-3);text-transform:uppercase;letter-spacing:0.08em;margin-top:2px}

/* SECTION LABEL */
.slabel{font-family:'Barlow Condensed',sans-serif;font-size:0.75rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--green);display:flex;align-items:center;gap:10px;margin-bottom:1.25rem}
.slabel::after{content:'';flex:1;height:1px;background:var(--white-4)}

/* CARD */
.card{background:rgba(17,46,22,0.7);border:1px solid var(--white-4);border-radius:var(--r-xl);backdrop-filter:blur(12px);box-shadow:0 4px 24px rgba(0,0,0,0.3)}

/* DATE */
.date-card{padding:clamp(1.25rem,3vw,2rem);margin-bottom:1.5rem;animation:slideUp 0.5s ease both}
.date-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.date-iw{position:relative;flex:1;min-width:200px}
.date-ico{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:18px;pointer-events:none}
.date-input{width:100%;padding:13px 13px 13px 44px;background:var(--white-5);border:1px solid var(--white-4);border-radius:var(--r);color:var(--white);font-family:'Barlow',sans-serif;font-size:1rem;outline:none;transition:all var(--t);cursor:pointer;color-scheme:dark}
.date-input:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(0,230,118,0.12)}
.date-lbl{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:1rem;color:var(--white-2);letter-spacing:0.02em;white-space:nowrap}

/* SLOTS */
.creneaux-wrap{animation:slideUp 0.5s 0.1s ease both;opacity:0;animation-fill-mode:forwards}
.legend{display:flex;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}
.leg{display:flex;align-items:center;gap:6px;font-size:0.75rem;color:var(--white-3)}
.leg-dot{width:10px;height:10px;border-radius:3px}
.leg-dot.libre{background:rgba(0,230,118,0.25);border:1.5px solid var(--green)}
.leg-dot.pris{background:var(--white-5);border:1.5px solid var(--white-4)}
.leg-dot.bloque{background:rgba(255,109,0,0.2);border:1.5px solid var(--amber)}

.heure-card{padding:clamp(1.25rem,3vw,1.75rem);margin-bottom:1.5rem}
.heure-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
.slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px;margin-bottom:1.5rem}
.slots-title{font-family:'Barlow Condensed',sans-serif;font-size:0.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--white-3);margin-bottom:.75rem}

.slot{border-radius:var(--r);padding:12px 10px 10px;border:1px solid var(--white-4);background:var(--white-5);cursor:pointer;transition:all var(--t);position:relative;overflow:hidden}
.slot:hover:not(.pris):not(.bloque){border-color:var(--green);transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,0.3),var(--glow-sm)}
.slot.pris{opacity:0.4;cursor:not-allowed}
.slot.bloque{background:rgba(255,109,0,0.08);border-color:rgba(255,109,0,0.25);cursor:not-allowed;opacity:0.6}
.slot-time{font-family:'Barlow Condensed',sans-serif;font-size:1rem;font-weight:800;color:var(--white)}
.slot-dur{font-size:0.68rem;color:var(--white-3);margin-top:2px}
.slot-badge{font-family:'Barlow Condensed',sans-serif;font-size:0.62rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;margin-top:4px}
.slot-badge.libre{color:var(--green)}
.slot-badge.pris{color:var(--white-4)}
.slot-badge.bloque{color:var(--amber)}

/* FORM */
.form-label{display:block;font-size:0.7rem;font-weight:600;color:var(--white-3);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:0.45rem}
.form-input,.form-select{width:100%;padding:12px 14px;background:var(--white-5);border:1px solid var(--white-4);border-radius:var(--r);color:var(--white);font-family:'Barlow',sans-serif;font-size:0.95rem;outline:none;transition:all var(--t);appearance:none;-webkit-appearance:none;color-scheme:dark}
.form-input::placeholder{color:var(--white-3)}
.form-input:focus,.form-select:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(0,230,118,0.1);background:rgba(0,230,118,0.05)}
.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='rgba(240,255,244,0.45)' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;cursor:pointer}
.form-select option{background:var(--pitch-3);color:var(--white)}
.form-group{margin-bottom:1.25rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-sep{height:1px;background:var(--white-4);margin:1.5rem 0}

/* MONTANT */
.montant-strip{background:linear-gradient(135deg,var(--green-dim) 0%,rgba(0,200,83,0.15) 100%);border:1px solid rgba(0,230,118,0.3);border-radius:var(--r-lg);padding:1rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}
.montant-info{font-size:0.82rem;color:var(--white-3)}
.montant-info strong{display:block;color:var(--white);font-size:0.88rem;margin-bottom:2px}
.montant-val{font-family:'Barlow Condensed',sans-serif;font-size:1.8rem;font-weight:900;color:var(--green);letter-spacing:-0.02em}
.montant-cur{font-size:0.82rem;font-weight:600;opacity:0.8}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 24px;border-radius:var(--r);font-family:'Barlow Condensed',sans-serif;font-size:0.95rem;font-weight:800;letter-spacing:0.08em;text-transform:uppercase;cursor:pointer;transition:all var(--t);border:none;text-decoration:none;-webkit-tap-highlight-color:transparent}
.btn-green{background:var(--green);color:var(--pitch)}
.btn-green:hover{background:#00f07e;transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,230,118,0.4)}
.btn-green:active{transform:scale(0.98)}
.btn-green:disabled{opacity:0.35;cursor:not-allowed;transform:none;box-shadow:none}
.btn-outline{background:transparent;color:var(--white);border:1.5px solid var(--white-4)}
.btn-outline:hover{border-color:var(--green);color:var(--green)}
.btn-ghost{background:var(--white-5);color:var(--white-3);border:1px solid var(--white-4)}
.btn-ghost:hover{background:var(--white-4);color:var(--white)}
.btn-block{width:100%}
.btn-sm{padding:8px 16px;font-size:0.8rem}
.btn-danger{background:var(--red);color:white}

/* ALERTS */
.alert{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:var(--r);font-size:0.85rem;margin-bottom:1rem;line-height:1.55;animation:slideUp 0.25s ease both}
.a-ok{background:rgba(0,230,118,0.08);border:1px solid rgba(0,230,118,0.25);color:var(--green)}
.a-err{background:var(--red-dim);border:1px solid rgba(255,23,68,0.25);color:#ff6b88}
.a-warn{background:rgba(255,109,0,0.08);border:1px solid rgba(255,109,0,0.25);color:var(--amber)}

/* RESA PAGE */
.resa-head{background:linear-gradient(135deg,var(--grass) 0%,var(--pitch-3) 100%);border:1px solid var(--white-4);border-radius:var(--r-xl) var(--r-xl) 0 0;padding:clamp(1.25rem,4vw,2rem);position:relative;overflow:hidden}
.resa-head::after{content:'⚽';position:absolute;right:-10px;top:-10px;font-size:90px;opacity:0.06;transform:rotate(-15deg)}
.resa-head h2{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-style:italic;font-size:clamp(1.3rem,4vw,1.6rem);text-transform:uppercase;letter-spacing:0.02em;margin-bottom:0.35rem}
.resa-head p{font-size:0.82rem;color:var(--white-3);font-weight:300}
.slot-chips{display:flex;gap:.6rem;margin-top:1rem;flex-wrap:wrap}
.slot-chip{display:inline-flex;align-items:center;gap:5px;background:rgba(0,230,118,0.1);border:1px solid rgba(0,230,118,0.2);border-radius:4px;padding:4px 10px;font-family:'Barlow Condensed',sans-serif;font-size:0.78rem;font-weight:700;letter-spacing:0.04em;color:var(--green);text-transform:uppercase}
.resa-body{background:rgba(17,46,22,0.6);border:1px solid var(--white-4);border-top:none;border-radius:0 0 var(--r-xl) var(--r-xl);padding:clamp(1.25rem,4vw,2rem);backdrop-filter:blur(12px)}

/* CONFIRMATION */
.confirm-page{padding:2rem 0 4rem}
.confirm-icon{width:72px;height:72px;border-radius:50%;background:rgba(0,230,118,0.1);border:2px solid rgba(0,230,118,0.35);display:flex;align-items:center;justify-content:center;font-size:32px;margin:0 auto 1.25rem;animation:popIn 0.6s cubic-bezier(0.34,1.56,0.64,1) both;box-shadow:var(--glow)}
.confirm-title{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-style:italic;font-size:clamp(1.8rem,5vw,2.8rem);text-transform:uppercase;text-align:center;margin-bottom:0.4rem}
.confirm-sub{text-align:center;color:var(--white-3);margin-bottom:1.5rem;font-size:0.88rem}
.code-card{background:var(--grass);border:1px solid rgba(0,230,118,0.25);border-radius:var(--r-xl);padding:clamp(1.5rem,4vw,2.5rem);text-align:center;margin-bottom:1.5rem;position:relative;overflow:hidden;box-shadow:var(--glow)}
.code-card::after{content:'⚽';position:absolute;right:-15px;bottom:-20px;font-size:100px;opacity:0.05}
.code-eyebrow{font-family:'Barlow Condensed',sans-serif;font-size:0.7rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--white-3);margin-bottom:.75rem}
.code-value{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:clamp(1.3rem,4vw,2.2rem);color:var(--green);letter-spacing:0.08em;word-break:break-all}
.code-note{font-size:0.75rem;color:var(--white-3);margin-top:.6rem}
.recap-list{background:rgba(17,46,22,0.7);border:1px solid var(--white-4);border-radius:var(--r-xl);overflow:hidden;margin-bottom:1.5rem}
.recap,.recap-list{background:rgba(17,46,22,0.7);border:1px solid var(--white-4);border-radius:var(--r-xl);overflow:hidden;margin-bottom:1.5rem}
.recap-row{display:flex;justify-content:space-between;align-items:center;padding:.8rem 1.25rem;border-bottom:1px solid var(--white-4);font-size:0.85rem;gap:.5rem}
.recap-row:last-child{border-bottom:none}
.recap-k{color:var(--white-3);flex-shrink:0}
.recap-v{color:var(--white);font-weight:600;text-align:right}
.recap-row.tot .recap-k{font-family:'Barlow Condensed',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--white)}
.recap-row.tot .recap-v{font-family:'Barlow Condensed',sans-serif;font-size:1.2rem;font-weight:900;color:var(--green)}

/* LOGIN */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;position:relative;z-index:1}
.login-card{width:100%;max-width:420px;background:rgba(10,31,14,0.95);border:1px solid var(--white-4);border-radius:var(--r-xl);padding:clamp(1.5rem,5vw,2.5rem);box-shadow:0 24px 80px rgba(0,0,0,0.5),var(--glow);animation:slideUp 0.5s ease both;backdrop-filter:blur(20px)}
.login-emblem{width:56px;height:56px;background:var(--green);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 1rem;box-shadow:var(--glow)}
.login-title{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-style:italic;font-size:clamp(1.6rem,4vw,2rem);text-transform:uppercase;text-align:center;margin-bottom:.35rem}
.login-sub{text-align:center;color:var(--white-3);font-size:.82rem;margin-bottom:1.5rem}
.eye-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:16px;color:var(--white-3);transition:color var(--t);padding:4px}
.eye-btn:hover{color:var(--white)}
.irel{position:relative}
.login-foot{text-align:center;margin-top:1.25rem;font-size:.7rem;color:var(--white-4)}

/* DASHBOARD */
.dash-grid{display:grid;grid-template-columns:220px 1fr;min-height:calc(100vh - 56px)}
.sidebar{background:rgba(5,18,8,0.95);border-right:1px solid var(--white-4);padding:1.25rem;position:sticky;top:56px;height:calc(100vh - 56px);overflow-y:auto;flex-shrink:0}
.sb-section{font-family:'Barlow Condensed',sans-serif;font-size:.65rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--white-4);margin-bottom:.6rem;margin-top:1.25rem}
.sb-section:first-child{margin-top:0}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--r);color:var(--white-3);font-family:'Barlow Condensed',sans-serif;font-size:.85rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;transition:all var(--t);border:none;background:none;width:100%;text-align:left}
.nav-item:hover{background:var(--white-5);color:var(--white)}
.nav-item.active{background:rgba(0,230,118,0.1);color:var(--green);border:1px solid rgba(0,230,118,0.15)}
.dash-main{padding:clamp(1rem,3vw,2rem);overflow-y:auto;min-width:0}
.stats-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;margin-bottom:1.5rem}
.stat-card{background:rgba(17,46,22,0.7);border:1px solid var(--white-4);border-radius:var(--r-lg);padding:1.25rem;transition:border-color var(--t)}
.stat-lbl{font-family:'Barlow Condensed',sans-serif;font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--white-3);margin-bottom:.5rem}
.stat-num{font-family:'Barlow Condensed',sans-serif;font-size:2rem;font-weight:900;letter-spacing:-.02em;color:var(--white)}
.stat-num.green{color:var(--green)}
.stat-num.amber{color:var(--yellow)}
.panel-hd{font-family:'Barlow Condensed',sans-serif;font-size:1.1rem;font-weight:900;letter-spacing:.02em;text-transform:uppercase;color:var(--white);margin-bottom:1rem}
.search-bar{position:relative;margin-bottom:.875rem}
.search-ico{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--white-3);font-size:14px;pointer-events:none}
.search-inp{width:100%;padding:11px 12px 11px 40px;background:var(--white-5);border:1px solid var(--white-4);border-radius:var(--r-lg);color:var(--white);font-family:'Barlow',sans-serif;font-size:.88rem;outline:none;transition:all var(--t)}
.search-inp::placeholder{color:var(--white-4)}
.search-inp:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(0,230,118,.1)}
.filters{display:flex;gap:6px;margin-bottom:1rem;flex-wrap:wrap}
.fpill{padding:5px 14px;border-radius:4px;border:1px solid var(--white-4);background:transparent;color:var(--white-3);font-family:'Barlow Condensed',sans-serif;font-size:.75rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:all var(--t)}
.fpill:hover,.fpill.active{background:rgba(0,230,118,.1);border-color:rgba(0,230,118,.3);color:var(--green)}

/* TABLE */
.tbl{background:rgba(17,46,22,0.5);border:1px solid var(--white-4);border-radius:var(--r-xl);overflow:hidden}
.tbl-head{display:grid;grid-template-columns:1.8fr 1.5fr 1fr 1fr 1fr 90px;padding:.75rem 1.25rem;background:rgba(0,0,0,0.25);border-bottom:1px solid var(--white-4)}
.th{font-family:'Barlow Condensed',sans-serif;font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--white-3)}
.tbl-row{display:grid;grid-template-columns:1.8fr 1.5fr 1fr 1fr 1fr 90px;padding:.875rem 1.25rem;border-bottom:1px solid var(--white-4);align-items:center;transition:background var(--t);animation:slideUp .3s ease both}
.tbl-row:last-child{border-bottom:none}
.tbl-row:hover{background:var(--white-5)}
.td{font-size:.82rem;color:var(--white)}
.td-sm{font-size:.75rem;color:var(--white-3)}
.code-tag{font-family:'Barlow Condensed',sans-serif;font-size:.72rem;font-weight:800;letter-spacing:.05em;color:var(--green);background:rgba(0,230,118,.08);border:1px solid rgba(0,230,118,.2);border-radius:4px;padding:2px 7px;display:inline-block;white-space:nowrap}
.spill{display:inline-flex;align-items:center;gap:4px;font-family:'Barlow Condensed',sans-serif;font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;border-radius:4px;padding:3px 8px;white-space:nowrap}
.spill::before{content:'';width:5px;height:5px;border-radius:50%;flex-shrink:0}
.s-payee{background:rgba(0,230,118,.1);color:var(--green)}.s-payee::before{background:var(--green)}
.s-attente{background:rgba(255,214,0,.08);color:var(--yellow)}.s-attente::before{background:var(--yellow)}
.s-annulee{background:var(--red-dim);color:#ff6b88}.s-annulee::before{background:var(--red)}
.verify-box{background:rgba(17,46,22,0.6);border:1px solid var(--white-4);border-radius:var(--r-xl);padding:clamp(1.25rem,3vw,2rem)}
.verify-ok{background:rgba(0,230,118,.06);border:1px solid rgba(0,230,118,.2);border-radius:var(--r-lg);padding:1.25rem;animation:slideUp .3s ease both}
.bloc-box{background:rgba(17,46,22,0.6);border:1px solid var(--white-4);border-radius:var(--r-xl);padding:clamp(1.25rem,3vw,2rem);margin-bottom:1.5rem}
.blq-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:rgba(255,109,0,.06);border:1px solid rgba(255,109,0,.2);border-radius:var(--r);padding:.75rem 1rem;flex-wrap:wrap}
.blq-item+.blq-item{margin-top:8px}
.blq-name{font-size:.85rem;font-weight:600}
.blq-sub{font-size:.72rem;color:var(--white-3)}
.dots{display:flex;gap:6px;justify-content:center;padding:2.5rem}
.dots span{width:8px;height:8px;background:var(--white-4);border-radius:50%;animation:bounce 1.2s ease infinite}
.dots span:nth-child(2){animation-delay:.2s}
.dots span:nth-child(3){animation-delay:.4s}
.empty-state{text-align:center;padding:2.5rem;color:var(--white-3)}
.bc{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--white-3);margin-bottom:1.25rem;flex-wrap:wrap}
.bc a{color:var(--white-3);text-decoration:none;transition:color var(--t)}
.bc a:hover{color:var(--green)}
.bc-sep{color:var(--white-4)}

/* ── RESPONSIVE ── */

/* Tablette large */
@media(max-width:1024px){
  .dash-grid{grid-template-columns:200px 1fr}
  .tbl-head,.tbl-row{grid-template-columns:1.5fr 1.5fr 1fr 1fr 80px}
  .th:nth-child(3),.tbl-row .td:nth-child(3){display:none}
}

/* Tablette */
@media(max-width:900px){
  .dash-grid{grid-template-columns:1fr;grid-template-rows:auto 1fr}
  .sidebar{
    position:static;height:auto;
    padding:.75rem 1rem;
    border-right:none;
    border-bottom:1px solid var(--white-4);
    display:flex;flex-direction:column;gap:.25rem
  }
  .sidebar .sb-section{display:none}
  nav{display:flex !important;flex-direction:row !important;gap:4px;overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px;-webkit-overflow-scrolling:touch}
  nav::-webkit-scrollbar{height:2px}
  nav::-webkit-scrollbar-thumb{background:var(--white-4);border-radius:2px}
  .nav-item{white-space:nowrap;flex-shrink:0;width:auto;padding:8px 12px;font-size:.78rem}
  .dash-main{padding:1rem}
  .stats-bar{grid-template-columns:repeat(2,1fr);gap:.6rem}
}

/* Mobile */
@media(max-width:700px){
  .header-inner{height:52px}
  .logo-sub{display:none}
  .form-row,.heure-grid{grid-template-columns:1fr}
  .wrap-sm{padding:0 .875rem}

  /* Table mobile — cartes */
  .tbl-head{display:none}
  .tbl-row{
    display:flex;flex-direction:column;gap:.5rem;
    padding:1rem;
    border-bottom:1px solid var(--white-4)
  }
  .tbl-row .td,.tbl-row .td-sm{font-size:.82rem}

  .montant-strip{flex-direction:column;align-items:flex-start;gap:.5rem}
  .montant-val{font-size:1.6rem}

  .stats-bar{grid-template-columns:1fr 1fr;gap:.5rem}
  .stat-card{padding:1rem}
  .stat-num{font-size:1.7rem}

  .slots-grid{grid-template-columns:repeat(auto-fill,minmax(85px,1fr));gap:6px}
  .slot{padding:10px 8px 8px}

  .resa-head{padding:1.25rem}
  .resa-body{padding:1.25rem}
  .code-value{font-size:1.2rem;letter-spacing:.04em}

  .recap-row{padding:.7rem 1rem;font-size:.82rem}

  .login-card{padding:1.5rem}

  /* Dashboard mobile — table simplifiée */
  .tbl{border-radius:var(--r-lg)}
}

/* Petit mobile */
@media(max-width:480px){
  .hero h1{font-size:2.5rem}
  .stats-bar{grid-template-columns:1fr 1fr}
  .stat-num{font-size:1.5rem}

  .btn{padding:12px 20px;font-size:.88rem}
  .btn-sm{padding:7px 14px;font-size:.75rem}

  .slots-grid{grid-template-columns:repeat(3,1fr)}

  .confirm-icon{width:64px;height:64px;font-size:28px}

  .code-card{padding:1.25rem}
  .code-value{font-size:1rem;letter-spacing:.03em}

  .filters{gap:4px}
  .fpill{padding:4px 10px;font-size:.7rem}
}

/* ── MODAL ── */
.modal-overlay{
  position:fixed !important;top:0 !important;left:0 !important;right:0 !important;bottom:0 !important;
  width:100vw !important;height:100vh !important;z-index:99999 !important;
  background:rgba(5,15,7,0.88);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  display:flex !important;align-items:center !important;justify-content:center !important;
  padding:1rem;animation:overlayIn .2s ease both;margin:0 !important;
}
.modal{
  background:linear-gradient(145deg,#112e16,#0d2712);
  border:1px solid rgba(0,230,118,0.2);border-radius:var(--r-xl);
  padding:clamp(1.5rem,4vw,2.5rem);width:100%;max-width:440px;
  box-shadow:0 32px 80px rgba(0,0,0,0.7);
  animation:modalIn .3s cubic-bezier(0.34,1.2,0.64,1) both;
  position:relative;overflow:hidden;
}
.modal::after{content:'⚽';position:absolute;right:-20px;bottom:-25px;font-size:120px;opacity:0.04;pointer-events:none}
.modal::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--r-xl) var(--r-xl) 0 0}
.modal.danger::before{background:linear-gradient(90deg,var(--red),rgba(255,23,68,0.2))}
.modal.warning::before{background:linear-gradient(90deg,var(--amber),rgba(255,109,0,0.2))}
.modal-icon{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;margin:0 0 1.25rem;position:relative}
.modal-icon.danger{background:rgba(255,23,68,0.1);border:1.5px solid rgba(255,23,68,0.3)}
.modal-icon.warning{background:rgba(255,109,0,0.1);border:1.5px solid rgba(255,109,0,0.3)}
.modal-title{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-style:italic;font-size:clamp(1.3rem,4vw,1.6rem);text-transform:uppercase;color:var(--white);margin-bottom:.5rem}
.modal-body{font-size:.88rem;color:var(--white-3);line-height:1.65;margin-bottom:1.75rem}
.modal-body strong{color:var(--white);font-weight:600}
.modal-actions{display:flex;gap:.75rem}
.modal-actions .btn{flex:1;font-size:.88rem;padding:12px 16px}
.modal-btn-cancel{background:var(--white-5);color:var(--white-3);border:1px solid var(--white-4) !important}
.modal-btn-cancel:hover{background:var(--white-4);color:var(--white)}
.modal-btn-ok-danger{background:var(--red);color:white}
.modal-btn-ok-warning{background:var(--amber);color:white}

/* ANIMATIONS */
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes popIn{from{opacity:0;transform:scale(0.4)}to{opacity:1;transform:scale(1)}}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}
@keyframes bounce{0%,80%,100%{transform:translateY(0)}40%{transform:translateY(-8px)}}
@keyframes modalIn{from{opacity:0;transform:scale(0.85) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}
@keyframes overlayIn{from{opacity:0}to{opacity:1}}
.d1{animation-delay:.1s}.d2{animation-delay:.2s}.d3{animation-delay:.3s}

/* Fix date row mobile */
@media(max-width:600px){
  .date-row{flex-direction:column;align-items:stretch}
  .date-iw{min-width:0;width:100%}
  .date-input{width:100%;font-size:16px}
  .date-lbl{text-align:center;font-size:.9rem}
  .heure-grid{grid-template-columns:1fr}
  .slots-grid{grid-template-columns:repeat(3,1fr)}
}