/* ═══════════════════════════════════════════════════════
   SPORTDATA v2 — STYLESHEET
   ═══════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0a0f1e;--bg-2:#0f172a;--surface:#1e293b;--surface-2:#263246;
  --border:rgba(255,255,255,0.07);--border-2:rgba(255,255,255,0.12);
  --accent:#22d3ee;--accent-2:#0891b2;--accent-3:#a78bfa;
  --success:#34d399;--danger:#f87171;--warn:#fbbf24;--orange:#fb923c;
  --text:#f1f5f9;--text-2:#94a3b8;--text-3:#64748b;
  --sidebar-w:256px;--topbar-h:64px;
  --radius:12px;--radius-sm:8px;--radius-lg:18px;
  --font-head:'Syne',sans-serif;--font-body:'DM Sans',sans-serif;
  --shadow:0 4px 24px rgba(0,0,0,0.35);--shadow-lg:0 12px 48px rgba(0,0,0,0.5);
  --glow:0 0 32px rgba(34,211,238,0.12);
}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;font-size:15px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
input,select,textarea,button{font-family:var(--font-body)}
.hidden{display:none!important}
.full-width{width:100%}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--surface-2);border-radius:4px}

/* ── AUTH ─────────────────────────────────────── */
.auth-overlay{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;background-image:radial-gradient(ellipse 60% 50% at 70% 20%,rgba(34,211,238,0.06) 0%,transparent 60%),radial-gradient(ellipse 40% 40% at 20% 80%,rgba(167,139,250,0.05) 0%,transparent 60%)}
.auth-screen{display:none;width:100%;max-width:460px;flex-direction:column;align-items:center;gap:28px;animation:fadeSlideUp .4s ease}
.auth-screen.active{display:flex}
.auth-brand{display:flex;align-items:center;gap:12px;font-family:var(--font-head);font-size:22px;font-weight:700;letter-spacing:-0.02em}
.auth-card{width:100%;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius-lg);padding:36px 32px;box-shadow:var(--shadow-lg),var(--glow)}
.auth-header{margin-bottom:28px}
.auth-header h1{font-family:var(--font-head);font-size:24px;font-weight:800;letter-spacing:-0.03em;margin-bottom:4px}
.auth-header p{color:var(--text-2);font-size:14px}
.auth-error{background:rgba(248,113,113,0.1);border:1px solid rgba(248,113,113,0.25);color:var(--danger);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;margin-bottom:16px}
.auth-switch{text-align:center;margin-top:18px;font-size:13px;color:var(--text-2)}
.demo-hint{text-align:center;margin-top:14px;font-size:12px;color:var(--text-3);background:rgba(255,255,255,0.03);border-radius:var(--radius-sm);padding:8px 12px;border:1px solid var(--border)}

/* ── FORMS ─────────────────────────────────────── */
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:12px;font-weight:500;color:var(--text-2);margin-bottom:6px;letter-spacing:0.03em;text-transform:uppercase}
.form-group input,.form-group select,.form-group textarea{width:100%;background:var(--bg-2);border:1px solid var(--border-2);color:var(--text);border-radius:var(--radius-sm);padding:10px 14px;font-size:14px;transition:border-color .2s,box-shadow .2s;outline:none;appearance:none}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-3)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(34,211,238,0.12)}
.form-group select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.form-group textarea{resize:vertical;min-height:80px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* ── BUTTONS ─────────────────────────────────────── */
.btn-primary,.btn-secondary,.btn-danger,.btn-logout{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;border-radius:var(--radius-sm);font-family:var(--font-body);font-weight:500;transition:all .2s;white-space:nowrap}
.btn-primary{background:var(--accent);color:#0f172a;padding:11px 22px;font-size:14px}
.btn-primary:hover{background:#67e8f9;box-shadow:0 0 20px rgba(34,211,238,0.3);transform:translateY(-1px)}
.btn-primary.sm{padding:8px 16px;font-size:13px}
.btn-primary.lg{padding:13px 28px;font-size:15px}
.btn-secondary{background:var(--surface-2);color:var(--text-2);border:1px solid var(--border-2);padding:11px 22px;font-size:14px}
.btn-secondary:hover{background:var(--border-2);color:var(--text)}
.btn-danger{background:rgba(248,113,113,0.1);color:var(--danger);border:1px solid rgba(248,113,113,0.25);padding:11px 22px;font-size:14px}
.btn-danger:hover{background:rgba(248,113,113,0.2)}
.btn-logout{background:transparent;color:var(--text-3);padding:8px;border-radius:var(--radius-sm)}
.btn-logout:hover{color:var(--danger);background:rgba(248,113,113,0.1)}

/* ── APP LAYOUT ─────────────────────────────────────── */
.app{display:flex;min-height:100vh}

/* ── SIDEBAR ─────────────────────────────────────── */
.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;z-index:100;transition:transform .3s ease}
.sidebar-header{display:flex;align-items:center;gap:10px;padding:20px 20px 16px;border-bottom:1px solid var(--border);font-family:var(--font-head);font-size:17px;font-weight:700;letter-spacing:-0.02em}
.sidebar-close{display:none;margin-left:auto;background:none;border:none;color:var(--text-2);cursor:pointer;font-size:16px}
.sidebar-nav{flex:1;padding:12px 10px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}
.nav-section-label{font-size:10px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--text-3);padding:12px 12px 6px;margin-top:4px}
.nav-item{display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:var(--radius-sm);color:var(--text-2);font-size:13.5px;font-weight:500;transition:all .2s;position:relative;text-decoration:none}
.nav-item:hover{background:var(--surface-2);color:var(--text);text-decoration:none}
.nav-item.active{background:rgba(34,211,238,0.1);color:var(--accent)}
.nav-item.active::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:18px;background:var(--accent);border-radius:0 4px 4px 0}
.nav-icon{width:17px;height:17px;flex-shrink:0}
.nav-badge{margin-left:auto;background:var(--accent-2);color:#fff;font-size:11px;font-weight:600;padding:2px 7px;border-radius:20px;min-width:22px;text-align:center}
.sidebar-footer{padding:14px 10px;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px}
.user-info{display:flex;align-items:center;gap:10px;flex:1;overflow:hidden}
.user-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--accent-2),var(--accent-3));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0}
.user-details{overflow:hidden}
.user-name{display:block;font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{display:block;font-size:11px;color:var(--text-3)}

/* ── TOPBAR ─────────────────────────────────────── */
.topbar{height:var(--topbar-h);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;padding:0 20px;background:var(--bg-2);position:sticky;top:0;z-index:50}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.hamburger span{display:block;width:22px;height:2px;background:var(--text-2);border-radius:2px;transition:all .2s}
.topbar-title{font-family:var(--font-head);font-size:17px;font-weight:700;letter-spacing:-0.02em;flex:1}
.topbar-actions{display:flex;align-items:center;gap:8px}
.topbar-icon-btn{background:var(--surface);border:1px solid var(--border-2);color:var(--text-2);width:36px;height:36px;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;position:relative}
.topbar-icon-btn:hover{background:var(--surface-2);color:var(--text)}

/* Quick Search */
.quick-search-bar{background:var(--surface);border-bottom:1px solid var(--border-2);padding:12px 20px;display:flex;align-items:center;gap:12px}
.quick-search-bar input{flex:1;background:none;border:none;color:var(--text);font-size:15px;outline:none}
.quick-search-bar kbd{background:var(--surface-2);border:1px solid var(--border-2);color:var(--text-3);font-size:11px;padding:2px 8px;border-radius:4px}
.quick-search-results{position:absolute;top:calc(var(--topbar-h) + 57px);left:var(--sidebar-w);right:0;background:var(--surface);border-bottom:1px solid var(--border-2);z-index:40;max-height:340px;overflow-y:auto}
.qs-item{display:flex;align-items:center;gap:12px;padding:12px 20px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .15s}
.qs-item:hover{background:var(--surface-2)}
.qs-photo{width:36px;height:36px;border-radius:50%;object-fit:cover;background:var(--surface-2);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:var(--text-3);flex-shrink:0}
.qs-info{flex:1}
.qs-name{font-size:14px;font-weight:600}
.qs-meta{font-size:12px;color:var(--text-3)}
.qs-badge{font-size:11px;font-weight:600;padding:3px 8px;border-radius:20px;background:rgba(34,211,238,0.1);color:var(--accent)}

/* Notifications */
.notif-wrap{position:relative}
.notif-dot{position:absolute;top:6px;right:6px;width:8px;height:8px;border-radius:50%;background:var(--danger);border:2px solid var(--bg-2)}
.notif-panel{position:absolute;top:calc(100% + 8px);right:0;width:300px;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:200}
.notif-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);font-size:13px;font-weight:600}
.notif-header button{background:none;border:none;color:var(--text-3);font-size:11px;cursor:pointer}
.notif-header button:hover{color:var(--text)}
.notif-item{padding:12px 16px;border-bottom:1px solid var(--border);font-size:13px;line-height:1.5}
.notif-item .notif-time{display:block;font-size:11px;color:var(--text-3);margin-top:3px}
.notif-empty{padding:20px 16px;font-size:13px;color:var(--text-3);text-align:center}

/* ── MAIN ─────────────────────────────────────── */
.main-content{flex:1;min-width:0;display:flex;flex-direction:column;background:var(--bg)}
.page{display:none;padding:28px 24px;flex:1;animation:fadeSlideUp .3s ease}
.page.active{display:block}
.page-intro{margin-bottom:24px}
.page-heading{font-family:var(--font-head);font-size:26px;font-weight:800;letter-spacing:-0.03em;margin-bottom:4px}
.page-subheading{color:var(--text-2);font-size:14px}

/* ── DASHBOARD ─────────────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.stat-card.accent{border-color:rgba(34,211,238,0.2);background:linear-gradient(135deg,rgba(34,211,238,0.08),var(--surface))}
.stat-card.accent::after{content:'';position:absolute;top:-40px;right:-40px;width:100px;height:100px;background:radial-gradient(circle,rgba(34,211,238,0.15),transparent);border-radius:50%}
.stat-icon{width:40px;height:40px;background:rgba(34,211,238,0.1);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;margin-bottom:14px;color:var(--accent)}
.stat-card:not(.accent) .stat-icon{background:rgba(255,255,255,0.05);color:var(--text-2)}
.stat-value{font-family:var(--font-head);font-size:32px;font-weight:800;letter-spacing:-0.04em;margin-bottom:4px}
.stat-label{font-size:12px;color:var(--text-2);font-weight:500}
.stat-trend{margin-top:8px;font-size:11px;color:var(--text-3)}
.stat-trend.up{color:var(--success)}

.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.dashboard-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px}
.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.panel-header h3{font-family:var(--font-head);font-size:14px;font-weight:700;letter-spacing:-0.01em}
.panel-link{font-size:12px;color:var(--accent)}
.recent-list{display:flex;flex-direction:column;gap:8px}
.recent-item{display:flex;align-items:center;gap:12px;padding:10px;background:var(--bg-2);border-radius:var(--radius-sm);border:1px solid var(--border);transition:border-color .2s;cursor:pointer}
.recent-item:hover{border-color:var(--accent)}
.recent-item-photo{width:36px;height:36px;border-radius:50%;object-fit:cover;background:var(--surface-2);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:var(--text-2);flex-shrink:0}
.recent-item-name{font-size:13px;font-weight:600}
.recent-item-sport{font-size:11px;color:var(--text-3)}
.recent-item-badge{font-size:10px;font-weight:600;padding:3px 8px;border-radius:20px;background:rgba(34,211,238,0.1);color:var(--accent);flex-shrink:0}
.empty-msg{color:var(--text-3);font-size:13px}
.sport-dist{display:flex;flex-direction:column;gap:10px}
.sport-row{display:flex;align-items:center;gap:10px}
.sport-name{font-size:12px;width:90px;flex-shrink:0;color:var(--text-2)}
.sport-bar-wrap{flex:1;height:8px;background:var(--bg);border-radius:4px;overflow:hidden}
.sport-bar{height:100%;border-radius:4px;transition:width 1s ease}
.sport-count{font-size:12px;color:var(--text-2);min-width:20px;text-align:right}

/* Top Performers */
.top-performers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.top-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:border-color .2s}
.top-card:hover{border-color:var(--accent)}
.top-rank{font-family:var(--font-head);font-size:22px;font-weight:800;color:var(--text-3);min-width:32px}
.top-rank.gold{color:var(--warn)}
.top-rank.silver{color:#94a3b8}
.top-rank.bronze{color:var(--orange)}
.top-info{flex:1;min-width:0}
.top-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.top-meta{font-size:11px;color:var(--text-3)}
.top-val{font-family:var(--font-head);font-size:16px;font-weight:700;color:var(--accent)}

/* Future cards */
.future-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.future-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;transition:transform .2s,border-color .2s}
.future-card:hover{transform:translateY(-2px);border-color:rgba(34,211,238,0.2)}
.future-badge{display:inline-block;font-size:10px;font-weight:700;letter-spacing:0.05em;text-transform:uppercase;background:rgba(167,139,250,0.15);color:var(--accent-3);border:1px solid rgba(167,139,250,0.2);padding:3px 10px;border-radius:20px;margin-bottom:16px}
.future-icon{margin-bottom:14px}
.future-card h4{font-family:var(--font-head);font-size:15px;font-weight:700;margin-bottom:8px}
.future-card p{font-size:13px;color:var(--text-2);line-height:1.6;margin-bottom:14px}
.future-tag{font-size:11px;color:var(--text-3);border-top:1px solid var(--border);padding-top:12px}

/* ── ATHLETES LIST ─────────────────────────────────────── */
.filters-bar{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap;align-items:center}
.search-wrap{position:relative;flex:1;min-width:200px}
.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-3);pointer-events:none}
.search-wrap input{width:100%;background:var(--surface);border:1px solid var(--border-2);color:var(--text);border-radius:var(--radius-sm);padding:10px 14px 10px 38px;font-size:14px;outline:none}
.search-wrap input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(34,211,238,0.1)}
#sport-filter,#country-filter,#sort-filter{background:var(--surface);border:1px solid var(--border-2);color:var(--text);border-radius:var(--radius-sm);padding:10px 36px 10px 14px;font-size:13px;outline:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;cursor:pointer}
.filter-count{font-size:12px;color:var(--text-3)}
.athletes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.athlete-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform .2s,border-color .2s,box-shadow .2s;cursor:pointer;animation:fadeSlideUp .3s ease}
.athlete-card:hover{transform:translateY(-3px);border-color:rgba(34,211,238,0.25);box-shadow:var(--shadow),var(--glow)}
.card-photo-wrap{height:160px;overflow:hidden;background:linear-gradient(135deg,var(--surface-2),var(--bg));position:relative}
.card-photo-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.athlete-card:hover .card-photo-wrap img{transform:scale(1.06)}
.card-photo-initials{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:48px;font-weight:800;color:rgba(255,255,255,0.08)}
.card-sport-tag{position:absolute;top:10px;right:10px;background:rgba(15,23,42,0.85);backdrop-filter:blur(8px);border:1px solid var(--border-2);color:var(--accent);font-size:10px;font-weight:700;letter-spacing:0.05em;text-transform:uppercase;padding:4px 10px;border-radius:20px}
.card-level-tag{position:absolute;top:10px;left:10px;background:rgba(15,23,42,0.85);backdrop-filter:blur(8px);border:1px solid var(--border-2);color:var(--warn);font-size:10px;font-weight:600;padding:3px 8px;border-radius:20px}
.card-body{padding:16px}
.card-name{font-family:var(--font-head);font-size:15px;font-weight:700;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-meta{font-size:12px;color:var(--text-2);margin-bottom:12px}
.card-stats{display:flex;gap:8px;margin-bottom:14px}
.card-stat{flex:1;text-align:center;background:var(--bg);border-radius:var(--radius-sm);padding:8px 4px;border:1px solid var(--border)}
.card-stat-val{font-size:15px;font-weight:700;color:var(--text)}
.card-stat-label{font-size:10px;color:var(--text-3);margin-top:2px}
.card-actions{display:flex;gap:8px}
.card-btn{flex:1;padding:8px;border-radius:var(--radius-sm);font-size:12px;font-weight:500;cursor:pointer;border:1px solid var(--border-2);transition:all .2s;background:transparent;color:var(--text-2)}
.card-btn.view{background:rgba(34,211,238,0.08);border-color:rgba(34,211,238,0.2);color:var(--accent)}
.card-btn.view:hover{background:rgba(34,211,238,0.15)}
.card-btn.edit:hover{background:var(--surface-2);color:var(--text)}
.card-btn.delete:hover{background:rgba(248,113,113,0.1);border-color:rgba(248,113,113,0.2);color:var(--danger)}
.empty-state{grid-column:1/-1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:64px 24px;color:var(--text-3);text-align:center;font-size:14px}
.empty-state p{line-height:2}

/* ── ADD ATHLETE FORM ─────────────────────────────────────── */
.form-layout{display:grid;grid-template-columns:320px 1fr;gap:20px;align-items:start}
.form-col{display:flex;flex-direction:column;gap:16px}
.form-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px}
.form-section-title{font-family:var(--font-head);font-size:12px;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;color:var(--text-2);margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.photo-upload-area{width:100%;height:200px;border:2px dashed var(--border-2);border-radius:var(--radius);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;cursor:pointer;transition:border-color .2s,background .2s;position:relative;overflow:hidden;background:var(--bg-2)}
.photo-upload-area:hover{border-color:var(--accent);background:rgba(34,211,238,0.04)}
.photo-upload-area img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
#photo-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-3);font-size:13px}
.video-upload-area{border:2px dashed var(--border-2);border-radius:var(--radius);padding:24px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:all .2s;background:var(--bg-2);color:var(--text-3);font-size:13px}
.video-upload-area:hover{border-color:var(--accent);background:rgba(34,211,238,0.04)}
.upload-hint{font-size:11px;color:var(--text-3)}
.video-preview-list{margin-top:12px;display:flex;flex-direction:column;gap:8px}
.video-preview-item{display:flex;align-items:center;gap:10px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;font-size:12px;color:var(--text-2)}
.form-actions{display:flex;gap:12px;justify-content:flex-end}

/* ── ANALYTICS ─────────────────────────────────────── */
.analytics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.analytics-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px}
.analytics-card.wide{grid-column:span 2}
.analytics-card h3{font-family:var(--font-head);font-size:12px;font-weight:700;color:var(--text-2);text-transform:uppercase;letter-spacing:0.04em;margin-bottom:20px}
.bar-chart{display:flex;flex-direction:column;gap:10px}
.bar-row{display:flex;align-items:center;gap:10px}
.bar-label{font-size:12px;color:var(--text-2);min-width:100px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar-track{flex:1;height:10px;background:var(--bg);border-radius:5px;overflow:hidden}
.bar-fill{height:100%;border-radius:5px;transition:width 1s ease}
.bar-val{font-size:12px;color:var(--text-2);min-width:40px;text-align:right}
.scatter-chart{position:relative;height:200px;background:var(--bg);border-radius:var(--radius-sm);overflow:hidden}
.scatter-axis-x{position:absolute;bottom:6px;right:10px;font-size:10px;color:var(--text-3)}
.scatter-axis-y{position:absolute;top:6px;left:6px;font-size:10px;color:var(--text-3)}
.scatter-point{position:absolute;width:10px;height:10px;border-radius:50%;transform:translate(-50%,-50%);transition:transform .2s;cursor:pointer}
.scatter-point:hover{transform:translate(-50%,-50%) scale(1.8)}
.radar-wrap{display:flex;flex-direction:column;gap:10px}
.score-row{display:flex;align-items:center;gap:10px}
.score-label{font-size:12px;color:var(--text-2);width:100px;flex-shrink:0}
.score-bar{flex:1;height:6px;background:var(--bg);border-radius:3px;overflow:hidden}
.score-fill{height:100%;border-radius:3px;transition:width 1s ease}
.score-val{font-size:12px;color:var(--text-2);min-width:32px;text-align:right}

/* ── COMPARE ─────────────────────────────────────── */
.compare-selectors{display:flex;align-items:center;gap:20px;margin-bottom:28px;flex-wrap:wrap}
.compare-selector{flex:1;min-width:200px}
.compare-selector label{display:block;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:0.04em;color:var(--text-2);margin-bottom:8px}
.compare-selector select{width:100%;background:var(--surface);border:1px solid var(--border-2);color:var(--text);border-radius:var(--radius-sm);padding:10px 36px 10px 14px;font-size:14px;outline:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
.compare-vs{font-family:var(--font-head);font-size:22px;font-weight:800;color:var(--text-3)}
.compare-empty{display:flex;flex-direction:column;align-items:center;gap:16px;color:var(--text-3);font-size:14px;text-align:center;padding:48px 0}
.compare-grid{display:grid;grid-template-columns:1fr 48px 1fr;gap:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.compare-col{padding:24px}
.compare-col.a{border-right:1px solid var(--border)}
.compare-col.b{border-left:1px solid var(--border)}
.compare-col-header{text-align:center;margin-bottom:20px}
.compare-athlete-photo{width:72px;height:72px;border-radius:50%;object-fit:cover;background:var(--surface-2);display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:28px;font-weight:800;color:rgba(255,255,255,0.15);margin:0 auto 10px}
.compare-athlete-name{font-family:var(--font-head);font-size:16px;font-weight:700}
.compare-athlete-sport{font-size:12px;color:var(--text-3);margin-top:3px}
.compare-stat-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border)}
.compare-stat-row:last-child{border-bottom:none}
.compare-stat-label-col{font-size:11px;color:var(--text-3);text-align:center;text-transform:uppercase;letter-spacing:0.04em}
.compare-stat-val{font-size:15px;font-weight:700}
.compare-stat-val.better{color:var(--success)}
.compare-stat-val.worse{color:var(--danger)}
.compare-labels-col{padding:24px 0;display:flex;flex-direction:column}
.compare-stat-label-center{flex:1;display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--text-3);text-align:center;padding:10px 4px;border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:0.03em}

/* ── HISTORY ─────────────────────────────────────── */
.history-selector{display:flex;align-items:flex-end;gap:16px;margin-bottom:24px}
.history-timeline{display:flex;flex-direction:column;gap:0}
.history-entry{display:flex;gap:16px;position:relative;padding-bottom:20px}
.history-entry::before{content:'';position:absolute;left:19px;top:36px;bottom:0;width:2px;background:var(--border)}
.history-entry:last-child::before{display:none}
.history-dot{width:40px;height:40px;border-radius:50%;background:var(--surface);border:2px solid var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0;z-index:1}
.history-dot svg{color:var(--accent)}
.history-body{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:4px}
.history-date{font-size:12px;color:var(--text-3);margin-bottom:8px;font-weight:500}
.history-note{font-size:13px;color:var(--text-2);margin-bottom:10px}
.history-stats{display:flex;flex-wrap:wrap;gap:8px}
.history-stat{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 12px;font-size:12px}
.history-stat span{color:var(--accent);font-weight:600}
.history-chart{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:20px}
.history-chart h4{font-family:var(--font-head);font-size:13px;font-weight:700;color:var(--text-2);text-transform:uppercase;letter-spacing:0.04em;margin-bottom:16px}
.sparkline{display:flex;align-items:flex-end;gap:6px;height:60px}
.spark-bar{flex:1;border-radius:3px 3px 0 0;min-width:8px;transition:opacity .2s;cursor:default;position:relative}
.spark-bar:hover{opacity:0.8}
.spark-val{position:absolute;bottom:calc(100% + 4px);left:50%;transform:translateX(-50%);background:var(--surface-2);color:var(--text);font-size:10px;padding:2px 5px;border-radius:4px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .2s}
.spark-bar:hover .spark-val{opacity:1}

/* ── MEDIA ─────────────────────────────────────── */
.media-tabs{display:flex;gap:8px;margin-bottom:24px}
.media-tab{padding:9px 20px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;background:var(--surface);border:1px solid var(--border-2);color:var(--text-2);transition:all .2s}
.media-tab.active{background:rgba(34,211,238,0.1);border-color:rgba(34,211,238,0.3);color:var(--accent)}
.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.photo-thumb{aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border);background:var(--surface);position:relative;cursor:pointer;transition:transform .2s,border-color .2s}
.photo-thumb:hover{transform:scale(1.03);border-color:var(--accent)}
.photo-thumb img{width:100%;height:100%;object-fit:cover}
.photo-thumb-label{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,0.8));color:#fff;font-size:11px;padding:16px 8px 8px}
.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.video-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.video-item video{width:100%;display:block;background:#000}
.video-item-info{padding:12px}
.video-item-name{font-size:13px;font-weight:600;margin-bottom:2px}
.video-item-meta{font-size:11px;color:var(--text-3)}
.media-empty{padding:64px 24px;text-align:center;color:var(--text-3);font-size:14px}

/* ── REPORTS ─────────────────────────────────────── */
.reports-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:28px}
.report-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px}
.report-icon{width:56px;height:56px;background:rgba(34,211,238,0.08);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.report-card h3{font-family:var(--font-head);font-size:15px;font-weight:700;margin-bottom:8px}
.report-card p{font-size:13px;color:var(--text-2);line-height:1.6;margin-bottom:16px}
.pdf-preview-area{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius);overflow:hidden}
.pdf-preview-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--border);font-family:var(--font-head);font-size:14px;font-weight:700}
.pdf-content{padding:28px;color:var(--text);max-height:600px;overflow-y:auto}

/* ── SETTINGS ─────────────────────────────────────── */
.settings-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.settings-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px}
.settings-card h3{font-family:var(--font-head);font-size:15px;font-weight:700;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.settings-avatar-row{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.settings-avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--accent-2),var(--accent-3));display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:22px;font-weight:800;flex-shrink:0}
.settings-user-name{font-size:15px;font-weight:600}
.settings-user-email{font-size:12px;color:var(--text-3);margin-top:2px}
.settings-info-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border);font-size:13px;color:var(--text-2)}
.settings-info-row:last-child{border-bottom:none}
.settings-val{font-weight:600;color:var(--text)}
.settings-actions{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}
.about-logo{display:flex;align-items:center;gap:10px;margin-bottom:16px}

/* ── MODAL ─────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(10,15,30,0.85);backdrop-filter:blur(8px);z-index:500;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .2s ease}
.modal-box{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius-lg);width:100%;max-width:680px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);position:relative;animation:scaleIn .25s ease}
.modal-close{position:absolute;top:14px;right:14px;background:var(--surface-2);border:1px solid var(--border-2);color:var(--text-2);width:30px;height:30px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;z-index:2;transition:all .2s}
.modal-close:hover{background:var(--danger);color:#fff;border-color:var(--danger)}
.modal-hero{padding:28px 28px 20px;display:flex;align-items:flex-start;gap:20px;background:linear-gradient(135deg,rgba(34,211,238,0.05),transparent);border-bottom:1px solid var(--border)}
.modal-avatar-wrap{position:relative;flex-shrink:0}
.modal-avatar{width:84px;height:84px;border-radius:var(--radius-sm);object-fit:cover;border:2px solid var(--border-2);background:var(--surface-2);display:block}
.modal-avatar-initials{width:84px;height:84px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--surface-2),var(--bg));display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:32px;font-weight:800;color:rgba(255,255,255,0.2);border:2px solid var(--border-2)}
.modal-sport-badge{display:inline-block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;background:rgba(34,211,238,0.12);border:1px solid rgba(34,211,238,0.25);color:var(--accent);padding:4px 10px;border-radius:20px;margin-bottom:8px}
.modal-hero-info h2{font-family:var(--font-head);font-size:22px;font-weight:800;letter-spacing:-0.03em;margin-bottom:6px}
.modal-meta{font-size:13px;color:var(--text-2);margin-bottom:6px}
.modal-level-badge{display:inline-block;font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;background:rgba(251,191,36,0.12);color:var(--warn);border:1px solid rgba(251,191,36,0.2)}
.modal-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);padding:0 20px;overflow-x:auto}
.modal-tab{padding:14px 18px;font-size:13px;font-weight:500;color:var(--text-2);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap}
.modal-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.modal-tab:hover{color:var(--text)}
.modal-tab-content{display:none;padding:24px 28px}
.modal-tab-content.active{display:block}
.detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.detail-item{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px}
.detail-item.full{grid-column:span 3}
.detail-label{display:block;font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:4px}
.detail-val{font-size:14px;font-weight:600}
.perf-bars{display:flex;flex-direction:column;gap:16px}
.perf-row{}
.perf-label{display:flex;justify-content:space-between;font-size:13px;margin-bottom:6px}
.perf-label span:first-child{color:var(--text-2)}
.perf-label span:last-child{font-weight:600}
.perf-track{height:8px;background:var(--bg);border-radius:4px;overflow:hidden}
.perf-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--accent-2),var(--accent));transition:width 1s ease}
.modal-media-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.modal-media-grid video{width:100%;border-radius:var(--radius-sm);background:#000}
.modal-media-grid img{width:100%;border-radius:var(--radius-sm);object-fit:cover;aspect-ratio:16/9}
.modal-footer{padding:16px 28px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end}

/* ── TOAST ─────────────────────────────────────── */
.toast{position:fixed;bottom:28px;right:28px;background:var(--surface-2);border:1px solid var(--border-2);color:var(--text);padding:14px 20px;border-radius:var(--radius);font-size:14px;z-index:9999;box-shadow:var(--shadow-lg);animation:toastIn .3s ease;max-width:320px}
.toast.success{border-left:3px solid var(--success)}
.toast.error{border-left:3px solid var(--danger)}
.toast.info{border-left:3px solid var(--accent)}

/* ── ANIMATIONS ─────────────────────────────────────── */
@keyframes fadeSlideUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scaleIn{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
@keyframes toastIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.6}}
.stat-trend.up{animation:pulse 2s infinite}

/* ── RESPONSIVE ─────────────────────────────────────── */
@media(max-width:1300px){.stats-grid{grid-template-columns:repeat(2,1fr)}.future-grid{grid-template-columns:repeat(2,1fr)}.settings-grid{grid-template-columns:repeat(2,1fr)}.reports-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:1100px){.form-layout{grid-template-columns:1fr}.analytics-grid{grid-template-columns:1fr}.analytics-card.wide{grid-column:span 1}.dashboard-grid{grid-template-columns:1fr}.compare-grid{grid-template-columns:1fr 40px 1fr}.top-performers-grid{grid-template-columns:1fr 1fr}}
@media(max-width:900px){.quick-search-results{left:0}}
@media(max-width:768px){:root{--sidebar-w:260px}.sidebar{position:fixed;top:0;left:0;bottom:0;transform:translateX(-100%);box-shadow:var(--shadow-lg)}.sidebar.open{transform:translateX(0)}.sidebar-close{display:flex}.hamburger{display:flex}.topbar-title{font-size:15px}.page{padding:16px 14px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}.future-grid{grid-template-columns:1fr}.settings-grid{grid-template-columns:1fr}.reports-grid{grid-template-columns:1fr}.auth-card{padding:24px 20px}.form-row{grid-template-columns:1fr}.detail-grid{grid-template-columns:repeat(2,1fr)}.detail-item.full{grid-column:span 2}.compare-grid{grid-template-columns:1fr}.compare-labels-col{display:none}.compare-vs{display:none}.top-performers-grid{grid-template-columns:1fr}}
@media(max-width:480px){.stats-grid{grid-template-columns:1fr}.athletes-grid{grid-template-columns:1fr}.photo-grid{grid-template-columns:repeat(2,1fr)}.topbar-actions .btn-primary{display:none}.detail-grid{grid-template-columns:1fr}.detail-item.full{grid-column:span 1}.modal-media-grid{grid-template-columns:1fr}.compare-grid{grid-template-columns:1fr}.compare-col.a,.compare-col.b{border:none}}

/* ── PRINT STYLES ─────────────────────────────────────── */

/* ── TABLETTE 10 POUCES (800-1100px) ──────────────────────── */
@media(max-width:1100px) and (min-width:769px){
  .form-layout{grid-template-columns:1fr}
  .form-actions{
    position:sticky;
    bottom:0;
    background:var(--bg);
    padding:14px 0;
    border-top:1px solid var(--border);
    z-index:10;
    margin-top:8px;
  }
  .btn-primary.lg{width:100%;justify-content:center;padding:15px}
  .btn-secondary{flex:1}
}

/* ── BOUTON SAUVEGARDER TOUJOURS VISIBLE SUR MOBILE/TABLETTE  */
@media(max-width:1100px){
  .form-actions{
    position:sticky;
    bottom:0;
    background:var(--bg-2);
    padding:12px 16px;
    border-top:2px solid var(--border-2);
    z-index:20;
    margin:0 -14px;
    box-shadow:0 -4px 20px rgba(0,0,0,0.3);
  }
  .btn-primary.lg{
    flex:1;
    padding:14px;
    font-size:15px;
    justify-content:center;
  }
}

@media print{body{background:#fff;color:#000}.sidebar,.topbar,.auth-overlay,.toast,.modal-overlay{display:none!important}.main-content{margin:0}.page.active{padding:0}}


/* ═══════════════════════════════════════════════════════
   PROGRESSION GRAPHS — SVG Line Charts
   ═══════════════════════════════════════════════════════ */

/* Athlete progression page */
.progression-hero {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 24px 28px;
  margin-bottom: 24px;
  display: flex;
  align-items: center;
  gap: 20px;
}
.progression-hero-photo {
  width: 72px; height: 72px;
  border-radius: 50%;
  object-fit: cover;
  background: var(--surface-2);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-head); font-size: 26px; font-weight: 800;
  color: rgba(255,255,255,0.2);
  flex-shrink: 0;
  border: 2px solid var(--border-2);
}
.progression-hero-photo img {
  width: 100%; height: 100%; border-radius: 50%; object-fit: cover;
}
.progression-hero-info { flex: 1; }
.progression-hero-name {
  font-family: var(--font-head);
  font-size: 22px; font-weight: 800;
  letter-spacing: -0.03em; margin-bottom: 4px;
}
.progression-hero-meta { font-size: 13px; color: var(--text-2); margin-bottom: 10px; }
.progression-hero-stats {
  display: flex; gap: 16px; flex-wrap: wrap;
}
.prog-mini-stat {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 8px 14px;
  text-align: center;
}
.prog-mini-stat-val {
  font-family: var(--font-head);
  font-size: 18px; font-weight: 800; color: var(--accent);
  display: block;
}
.prog-mini-stat-label {
  font-size: 10px; color: var(--text-3);
  text-transform: uppercase; letter-spacing: 0.05em;
}

/* Graph grid */
.progression-graphs-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  margin-bottom: 24px;
}
.progression-graphs-grid.wide { grid-template-columns: 1fr; }

.graph-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px 22px;
  position: relative;
  overflow: hidden;
}
.graph-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}
.graph-card-title {
  font-family: var(--font-head);
  font-size: 12px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--text-2);
}
.graph-card-trend {
  display: flex; align-items: center; gap: 6px;
  font-size: 13px; font-weight: 700;
}
.graph-card-trend.up   { color: var(--success); }
.graph-card-trend.down { color: var(--danger); }
.graph-card-trend.flat { color: var(--text-3); }

/* SVG line chart */
.svg-chart-wrap {
  position: relative;
  width: 100%;
}
.svg-chart {
  width: 100%;
  overflow: visible;
  display: block;
}
.chart-grid-line {
  stroke: rgba(255,255,255,0.04);
  stroke-width: 1;
}
.chart-axis-label {
  fill: var(--text-3);
  font-size: 10px;
  font-family: 'DM Sans', sans-serif;
}
.chart-line {
  fill: none;
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.chart-area {
  opacity: 0.08;
}
.chart-dot {
  r: 4;
  stroke-width: 2;
  stroke: var(--bg);
  cursor: pointer;
  transition: r 0.15s;
}
.chart-dot:hover { r: 6; }

/* Tooltip */
.chart-tooltip {
  position: absolute;
  background: var(--surface-2);
  border: 1px solid var(--border-2);
  border-radius: var(--radius-sm);
  padding: 8px 12px;
  font-size: 12px;
  pointer-events: none;
  z-index: 10;
  white-space: nowrap;
  box-shadow: var(--shadow);
  opacity: 0;
  transition: opacity 0.15s;
}
.chart-tooltip.visible { opacity: 1; }
.chart-tooltip strong { display: block; color: var(--accent); margin-bottom: 2px; }

/* Year axis labels */
.chart-x-labels {
  display: flex;
  justify-content: space-between;
  padding: 4px 0 0 32px;
  font-size: 10px;
  color: var(--text-3);
}
.chart-y-labels {
  position: absolute;
  left: 0; top: 0; bottom: 24px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 0 6px 0 0;
  font-size: 10px;
  color: var(--text-3);
  text-align: right;
  width: 32px;
}

/* Radar chart (spider) */
.radar-chart-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 0;
}

/* Summary table under graphs */
.progression-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.progression-table th {
  background: var(--bg);
  color: var(--text-3);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 10px 14px;
  text-align: left;
  font-weight: 600;
  border-bottom: 1px solid var(--border);
}
.progression-table td {
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  color: var(--text);
  vertical-align: middle;
}
.progression-table tr:last-child td { border-bottom: none; }
.progression-table tr:hover td { background: rgba(255,255,255,0.02); }
.delta-badge {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 11px; font-weight: 700;
  padding: 3px 8px; border-radius: 20px;
}
.delta-badge.pos { background: rgba(52,211,153,0.12); color: var(--success); }
.delta-badge.neg { background: rgba(248,113,113,0.12); color: var(--danger); }
.delta-badge.neu { background: rgba(255,255,255,0.05); color: var(--text-3); }

/* No-data placeholder for graph */
.graph-no-data {
  height: 140px;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 10px;
  color: var(--text-3); font-size: 13px;
}

/* Year filter pills */
.year-filter-bar {
  display: flex; gap: 8px; flex-wrap: wrap;
  margin-bottom: 20px;
}
.year-pill {
  padding: 5px 14px;
  border-radius: 20px;
  font-size: 12px; font-weight: 600;
  background: var(--surface);
  border: 1px solid var(--border-2);
  color: var(--text-2);
  cursor: pointer;
  transition: all 0.2s;
}
.year-pill.active {
  background: rgba(34,211,238,0.12);
  border-color: var(--accent);
  color: var(--accent);
}
.year-pill:hover { color: var(--text); border-color: var(--border-2); background: var(--surface-2); }
.year-pill.active:hover { color: var(--accent); }

/* ═══════════════════════════════════════════════════════
   FORM SECURITY — Validation styles
   ═══════════════════════════════════════════════════════ */

/* Required field star */
.form-group label .req {
  color: var(--danger);
  margin-left: 2px;
}

/* Field states */
.form-group input.field-error,
.form-group select.field-error,
.form-group textarea.field-error {
  border-color: var(--danger) !important;
  box-shadow: 0 0 0 3px rgba(248,113,113,0.12) !important;
  background: rgba(248,113,113,0.04);
}
.form-group input.field-ok,
.form-group select.field-ok {
  border-color: var(--success) !important;
}

/* Inline error message */
.field-error-msg {
  display: none;
  font-size: 11px;
  color: var(--danger);
  margin-top: 5px;
  padding-left: 2px;
}
.field-error-msg.visible { display: block; }

/* Field hint */
.field-hint {
  font-size: 11px;
  color: var(--text-3);
  margin-top: 4px;
  padding-left: 2px;
}

/* Form validation summary banner */
.form-error-banner {
  background: rgba(248,113,113,0.1);
  border: 1px solid rgba(248,113,113,0.25);
  border-radius: var(--radius-sm);
  padding: 12px 16px;
  margin-bottom: 16px;
  font-size: 13px;
  color: var(--danger);
  display: none;
}
.form-error-banner.visible { display: block; }
.form-error-banner ul {
  margin: 6px 0 0 16px;
  font-size: 12px;
}

/* Duplicate warning */
.duplicate-warning {
  background: rgba(251,191,36,0.1);
  border: 1px solid rgba(251,191,36,0.3);
  border-radius: var(--radius-sm);
  padding: 12px 16px;
  font-size: 13px;
  color: var(--warn);
  margin-bottom: 16px;
  display: none;
}
.duplicate-warning.visible { display: block; }

/* Form progress indicator */
.form-progress-bar {
  height: 3px;
  background: var(--border);
  border-radius: 2px;
  margin-bottom: 20px;
  overflow: hidden;
}
.form-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--accent-2), var(--accent));
  border-radius: 2px;
  transition: width 0.4s ease;
}
.form-progress-label {
  font-size: 11px;
  color: var(--text-3);
  margin-bottom: 6px;
  display: flex;
  justify-content: space-between;
}

/* Responsive graph */
@media (max-width: 768px) {
  .progression-graphs-grid { grid-template-columns: 1fr; }
  .progression-hero { flex-direction: column; text-align: center; }
  .progression-hero-stats { justify-content: center; }
}

/* ═══════════════════════════════════════════════════════
   SYSTÈME PIN ADMINISTRATEUR
   ═══════════════════════════════════════════════════════ */

/* Modal box */
.pin-modal-box {
  background: var(--surface);
  border: 1px solid var(--border-2);
  border-radius: var(--radius-lg);
  width: 100%;
  max-width: 360px;
  padding: 36px 32px 28px;
  box-shadow: var(--shadow-lg), 0 0 60px rgba(34,211,238,0.1);
  position: relative;
  animation: scaleIn .25s ease;
  text-align: center;
}

/* Header */
.pin-lock-icon {
  width: 72px; height: 72px;
  background: rgba(34,211,238,0.08);
  border: 1px solid rgba(34,211,238,0.2);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 16px;
}
.pin-title {
  font-family: var(--font-head);
  font-size: 20px; font-weight: 800;
  letter-spacing: -0.02em;
  margin-bottom: 6px;
}
.pin-subtitle {
  font-size: 13px;
  color: var(--text-2);
  margin-bottom: 24px;
}

/* PIN dots display */
.pin-dots-row {
  display: flex;
  justify-content: center;
  gap: 16px;
  margin-bottom: 10px;
}
.pin-dot {
  width: 16px; height: 16px;
  border-radius: 50%;
  border: 2px solid var(--border-2);
  background: transparent;
  transition: all .2s;
}
.pin-dot.filled {
  background: var(--accent);
  border-color: var(--accent);
  box-shadow: 0 0 10px rgba(34,211,238,0.4);
}
.pin-dot.active {
  border-color: var(--accent);
}
.pin-dot.flash {
  transform: scale(1.3);
}

/* Error message */
.pin-error-msg {
  background: rgba(248,113,113,0.1);
  border: 1px solid rgba(248,113,113,0.25);
  color: var(--danger);
  border-radius: var(--radius-sm);
  padding: 8px 14px;
  font-size: 12px;
  margin-bottom: 16px;
  text-align: center;
}

/* Keyboard */
.pin-keyboard {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin: 16px 0 20px;
}
.pin-key {
  background: var(--surface-2);
  border: 1px solid var(--border-2);
  border-radius: var(--radius);
  color: var(--text);
  font-family: var(--font-head);
  font-size: 20px; font-weight: 700;
  height: 64px;
  cursor: pointer;
  transition: all .15s;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 2px;
  position: relative;
  overflow: hidden;
}
.pin-key:not(.empty):not(.del):hover {
  background: var(--border-2);
  border-color: var(--accent);
  color: var(--accent);
  transform: scale(1.04);
}
.pin-key:not(.empty):active {
  transform: scale(0.96);
  background: rgba(34,211,238,0.1);
}
.pin-key span {
  font-size: 8px;
  font-family: var(--font-body);
  font-weight: 500;
  letter-spacing: 0.1em;
  color: var(--text-3);
}
.pin-key.empty { background: transparent; border-color: transparent; cursor: default; }
.pin-key.del {
  background: var(--surface-2);
  color: var(--text-2);
  font-size: 14px;
}
.pin-key.del:hover { background: rgba(248,113,113,0.1); color: var(--danger); border-color: rgba(248,113,113,0.2); }

/* Cancel button */
.pin-cancel-btn {
  background: none;
  border: none;
  color: var(--text-3);
  font-size: 13px;
  cursor: pointer;
  padding: 8px 20px;
  border-radius: var(--radius-sm);
  transition: all .2s;
  font-family: var(--font-body);
}
.pin-cancel-btn:hover { color: var(--text); background: var(--surface-2); }

/* Shake animation for wrong PIN */
@keyframes pinShake {
  0%, 100% { transform: translateX(0); }
  15%       { transform: translateX(-8px); }
  30%       { transform: translateX(8px); }
  45%       { transform: translateX(-6px); }
  60%       { transform: translateX(6px); }
  75%       { transform: translateX(-4px); }
  90%       { transform: translateX(4px); }
}
.pin-shake { animation: pinShake .5s ease; }

/* ── PIN Logs (dans paramètres) ─────────────────────── */
.pin-log-stat {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 12px;
  text-align: center;
}
.pin-log-stat-val {
  display: block;
  font-family: var(--font-head);
  font-size: 24px; font-weight: 800;
  color: var(--accent);
  margin-bottom: 2px;
}
.pin-log-stat-label {
  font-size: 10px;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.pin-log-entries {
  display: flex;
  flex-direction: column;
  gap: 6px;
  max-height: 320px;
  overflow-y: auto;
}

.pin-log-entry {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: var(--bg);
  transition: border-color .2s;
}
.pin-log-entry.success { border-left: 3px solid var(--success); }
.pin-log-entry.fail    { border-left: 3px solid var(--danger); }

.pin-log-icon {
  width: 28px; height: 28px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.pin-log-entry.success .pin-log-icon { background: rgba(52,211,153,0.1); }
.pin-log-entry.fail    .pin-log-icon { background: rgba(248,113,113,0.1); }

.pin-log-info {
  flex: 1;
  min-width: 0;
}
.pin-log-user {
  display: block;
  font-size: 13px; font-weight: 600;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.pin-log-email {
  display: block;
  font-size: 11px; color: var(--text-3);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

.pin-log-meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 3px;
  flex-shrink: 0;
}
.pin-log-status {
  font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.05em;
  padding: 2px 8px; border-radius: 20px;
}
.pin-log-status.success { background: rgba(52,211,153,0.12); color: var(--success); }
.pin-log-status.fail    { background: rgba(248,113,113,0.12); color: var(--danger); }
.pin-log-time {
  font-size: 11px; color: var(--text-3);
}

/* Responsive PIN */
@media (max-width: 480px) {
  .pin-modal-box { padding: 24px 20px 20px; }
  .pin-key { height: 56px; font-size: 18px; }
}

/* ── BOUTON RAPIDE SAUVEGARDER (tablette) ───────────────────  */
.form-quick-save{
  display:none;
  align-items:center;
  justify-content:space-between;
  background:var(--surface);
  border:1px solid var(--border-2);
  border-radius:var(--radius);
  padding:12px 16px;
  margin-bottom:16px;
  gap:12px;
}
@media(max-width:1100px){
  .form-quick-save{ display:flex; }
}
