/* ═══════════════════════════════════════════════════════
   AGOGE Design System V4 — "Warm Command Center"
   Coach app tokens + component styles
   ═══════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

:root {
  /* ── PALETTE ── */
  --ag-orange:    #f97316;
  --ag-orange2:   #ea580c;
  --ag-amber:     #f59e0b;
  --ag-emerald:   #34d399;
  --ag-rose:      #fb7185;
  --ag-violet:    #a78bfa;
  --ag-cyan:      #22d3ee;
  --ag-blue:      #60a5fa;

  /* ── SEMANTIC ── */
  --ag-primary:   var(--ag-orange);
  --ag-success:   var(--ag-emerald);
  --ag-warning:   var(--ag-amber);
  --ag-danger:    var(--ag-rose);
  --ag-info:      var(--ag-blue);
  --ag-accent:    var(--ag-orange2);

  /* ── ZONES FC / ALLURE (5 zones — Charte V4) ── */
  --ag-zone-hr-1: #94a3b8;
  --ag-zone-hr-2: #3b82f6;
  --ag-zone-hr-3: #22c55e;
  --ag-zone-hr-4: #f59e0b;
  --ag-zone-hr-5: #ef4444;

  /* ── ZONES FTP (7 zones Coggan — Charte V4) ── */
  --ag-zone-ftp-1: #94a3b8;
  --ag-zone-ftp-2: #3b82f6;
  --ag-zone-ftp-3: #22c55e;
  --ag-zone-ftp-4: #f59e0b;
  --ag-zone-ftp-5: #f97316;
  --ag-zone-ftp-6: #ef4444;
  --ag-zone-ftp-7: #a855f7;

  /* ── SURFACES (warm dark) ── */
  --ag-bg-base:     #18181b;
  --ag-bg-surface:  #1f1f23;
  --ag-bg-card:     #27272e;
  --ag-bg-elevated: #2f2f38;
  --ag-bg-hover:    #37373f;
  --ag-bg-input:    #1c1c21;
  --ag-bg-inset:    #141417;

  /* ── TEXT ── */
  --ag-text-primary:   #f0f0f5;
  --ag-text-secondary: #a8afc0;
  --ag-text-muted:     #6b7280;
  --ag-text-disabled:  #4b5058;

  /* ── BORDERS ── */
  --ag-border:       rgba(255,255,255, 0.06);
  --ag-border-med:   rgba(255,255,255, 0.10);
  --ag-border-bold:  rgba(255,255,255, 0.16);
  --ag-border-focus: rgba(249,115,22, 0.40);

  /* ── SEMANTIC OVERLAYS ── */
  --ag-ov-orange:  rgba(249,115,22, 0.08);
  --ag-ov-emerald: rgba(52,211,153, 0.08);
  --ag-ov-rose:    rgba(251,113,133, 0.08);
  --ag-ov-amber:   rgba(245,158,11, 0.08);
  --ag-ov-blue:    rgba(96,165,250, 0.08);
  --ag-ov-violet:  rgba(167,139,250, 0.08);
  --ag-ov-cyan:    rgba(34,211,238, 0.08);
  --ag-ov-orange-strong:  rgba(249,115,22, 0.16);
  --ag-ov-emerald-strong: rgba(52,211,153, 0.16);
  --ag-ov-rose-strong:    rgba(251,113,133, 0.16);
  --ag-ov-amber-strong:   rgba(245,158,11, 0.16);
  --ag-ov-blue-strong:    rgba(96,165,250, 0.16);
  --ag-ov-violet-strong:  rgba(167,139,250, 0.16);
  --ag-ov-cyan-strong:    rgba(34,211,238, 0.16);
  --ag-ov1: rgba(255,255,255, 0.03);
  --ag-ov2: rgba(255,255,255, 0.05);
  --ag-ov3: rgba(255,255,255, 0.08);
  --ag-ov4: rgba(255,255,255, 0.12);
  --ag-ov5: rgba(255,255,255, 0.16);

  /* ── GRADIENTS ── */
  --ag-grad-primary: linear-gradient(135deg, #f97316, #ea580c);
  --ag-grad-warm:    linear-gradient(135deg, #f97316, #f59e0b);
  --ag-grad-glow:    linear-gradient(135deg, #f97316 0%, #ea580c 50%, #dc2626 100%);
  --ag-grad-surface: linear-gradient(180deg, rgba(249,115,22,0.03) 0%, transparent 40%);

  /* ── SHADOWS ── */
  --ag-shadow-xs:  0 1px 2px rgba(0,0,0, 0.20);
  --ag-shadow-sm:  0 2px 4px rgba(0,0,0, 0.25);
  --ag-shadow-md:  0 4px 12px rgba(0,0,0, 0.30);
  --ag-shadow-lg:  0 8px 24px rgba(0,0,0, 0.35);
  --ag-shadow-xl:  0 16px 48px rgba(0,0,0, 0.40);
  --ag-shadow-glow:        0 0 24px rgba(249,115,22, 0.12);
  --ag-shadow-glow-strong: 0 0 40px rgba(249,115,22, 0.20);

  /* ── RADII ── */
  --ag-radius-xs:   4px;
  --ag-radius-sm:   6px;
  --ag-radius-md:   10px;
  --ag-radius-lg:   14px;
  --ag-radius-xl:   20px;
  --ag-radius-2xl:  28px;
  --ag-radius-full: 9999px;

  /* ── SPACING (4px base) ── */
  --ag-sp-0:  0;
  --ag-sp-1:  4px;
  --ag-sp-2:  8px;
  --ag-sp-3:  12px;
  --ag-sp-4:  16px;
  --ag-sp-5:  20px;
  --ag-sp-6:  24px;
  --ag-sp-8:  32px;
  --ag-sp-10: 40px;
  --ag-sp-12: 48px;
  --ag-sp-16: 64px;

  /* ── TYPE SCALE ── */
  --ag-text-2xs:  0.62rem;
  --ag-text-xs:   0.70rem;
  --ag-text-sm:   0.80rem;
  --ag-text-base: 0.875rem;
  --ag-text-md:   0.95rem;
  --ag-text-lg:   1.10rem;
  --ag-text-xl:   1.35rem;
  --ag-text-2xl:  1.75rem;
  --ag-text-3xl:  2.25rem;

  /* ── WEIGHTS ── */
  --ag-font-normal:   400;
  --ag-font-medium:   500;
  --ag-font-semibold: 600;
  --ag-font-bold:     700;
  --ag-font-black:    800;

  /* ── MOTION ── */
  --ag-ease:     cubic-bezier(0.22, 1, 0.36, 1);
  --ag-ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ag-dur-fast: 0.15s;
  --ag-dur:      0.25s;
  --ag-dur-slow: 0.40s;

  /* ── Z-INDEX ── */
  --ag-z-base:     0;
  --ag-z-sticky:   100;
  --ag-z-dropdown: 200;
  --ag-z-modal:    300;
  --ag-z-toast:    400;
  --ag-z-max:      9999;

  /* ── LAYOUT ── */
  --ag-header-h:  64px;
  --ag-sidebar-w: 260px;
  --ag-max-w:     1200px;
  --ag-header-bg: rgba(24,24,27, 0.92);
  --ag-mobile-nav-bg: rgba(24,24,27, 0.96);
}

/* ── LIGHT THEME (V4) ── */
.light-theme {
  --ag-primary:   #c2410c;
  --ag-accent:    #9a3412;

  --ag-bg-base:     #f5f5f7;
  --ag-bg-surface:  #ffffff;
  --ag-bg-card:     #ffffff;
  --ag-bg-elevated: #f0f0f3;
  --ag-bg-hover:    #e8e8ec;
  --ag-bg-input:    #f0f0f3;
  --ag-bg-inset:    #eaeaed;

  --ag-text-primary:   #111827;
  --ag-text-secondary: #4b5563;
  --ag-text-muted:     #9ca3af;
  --ag-text-disabled:  #d1d5db;

  --ag-border:       rgba(0,0,0, 0.05);
  --ag-border-med:   rgba(0,0,0, 0.08);
  --ag-border-bold:  rgba(0,0,0, 0.14);
  --ag-border-focus: rgba(194,65,12, 0.35);

  --ag-ov-orange:  rgba(194,65,12, 0.06);
  --ag-ov-emerald: rgba(5,150,105, 0.06);
  --ag-ov-rose:    rgba(225,29,72, 0.06);
  --ag-ov-amber:   rgba(180,83,9, 0.06);
  --ag-ov-blue:    rgba(37,99,235, 0.06);
  --ag-ov-violet:  rgba(124,58,237, 0.06);
  --ag-ov-cyan:    rgba(8,145,178, 0.06);
  --ag-ov-orange-strong:  rgba(194,65,12, 0.12);
  --ag-ov-emerald-strong: rgba(5,150,105, 0.12);
  --ag-ov-rose-strong:    rgba(225,29,72, 0.12);
  --ag-ov-amber-strong:   rgba(180,83,9, 0.12);
  --ag-ov-blue-strong:    rgba(37,99,235, 0.12);
  --ag-ov-violet-strong:  rgba(124,58,237, 0.12);
  --ag-ov-cyan-strong:    rgba(8,145,178, 0.12);
  --ag-ov1: rgba(0,0,0, 0.02);
  --ag-ov2: rgba(0,0,0, 0.04);
  --ag-ov3: rgba(0,0,0, 0.06);
  --ag-ov4: rgba(0,0,0, 0.08);
  --ag-ov5: rgba(0,0,0, 0.12);

  --ag-shadow-xs:  0 1px 2px rgba(0,0,0, 0.04);
  --ag-shadow-sm:  0 2px 4px rgba(0,0,0, 0.05);
  --ag-shadow-md:  0 4px 12px rgba(0,0,0, 0.07);
  --ag-shadow-lg:  0 8px 24px rgba(0,0,0, 0.09);
  --ag-shadow-xl:  0 16px 48px rgba(0,0,0, 0.12);
  --ag-shadow-glow:        0 0 20px rgba(194,65,12, 0.08);
  --ag-shadow-glow-strong: 0 0 40px rgba(194,65,12, 0.15);

  --ag-header-bg: rgba(245,245,247, 0.92);
  --ag-mobile-nav-bg: rgba(245,245,247, 0.96);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:'Plus Jakarta Sans',system-ui,-apple-system,sans-serif;background:var(--ag-bg-base);color:var(--ag-text-primary);line-height:1.6;min-height:100vh}
::selection{background:rgba(249,115,22,0.25);color:#fff}
a{color:var(--ag-primary);text-decoration:none;transition:color var(--ag-dur) var(--ag-ease)}
a:hover{color:var(--ag-orange2)}
input,button,textarea,select{font-family:inherit}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--ag-bg-elevated);border-radius:3px}

/* Header */
.ag-header{position:sticky;top:0;z-index:100;background:var(--ag-header-bg);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--ag-border);padding:0 24px;height:64px;display:flex;align-items:center}
.ag-header-inner{display:flex;align-items:center;gap:24px;width:100%;max-width:1400px;margin:0 auto}
.ag-logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.ag-logo-mark{width:32px;height:32px}
.ag-logo-text{font-family:'Plus Jakarta Sans',system-ui,sans-serif;font-weight:800;font-size:1.1rem;letter-spacing:3px;color:#fff}
.ag-nav{display:flex;align-items:center;gap:4px;flex:1;justify-content:center}
.ag-nav-link{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:var(--ag-radius-sm);color:var(--ag-text-muted);font-size:0.88rem;font-weight:500;text-decoration:none;transition:all var(--ag-dur) var(--ag-ease);position:relative;white-space:nowrap}
.ag-nav-link:hover{color:var(--ag-text-primary);background:var(--ag-bg-card)}
.ag-nav-link.active{color:var(--ag-orange);background:rgba(249,115,22,0.08)}
.ag-nav-link.active::after{content:'';position:absolute;bottom:-1px;left:50%;transform:translateX(-50%);width:20px;height:2px;background:var(--ag-grad-primary);border-radius:2px}
.ag-nav-link .nav-icon{width:18px;height:18px;opacity:0.7;flex-shrink:0}
.ag-nav-link:hover .nav-icon,.ag-nav-link.active .nav-icon{opacity:1}
.nav-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 4px;border-radius:var(--ag-radius-full);background:var(--ag-danger);color:#fff;font-size:0.6rem;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;pointer-events:none;box-shadow:0 0 0 2px var(--ag-header-bg)}
.ag-header-right{display:flex;align-items:center;gap:16px;flex-shrink:0}
.ag-avatar{width:34px;height:34px;border-radius:var(--ag-radius-full);background:var(--ag-grad-primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:0.85rem;cursor:pointer;transition:box-shadow var(--ag-dur)}
.ag-avatar:hover{box-shadow:0 0 0 3px rgba(249,115,22,0.3)}

/* Main */
.ag-main{max-width:1200px;margin:0 auto;padding:32px 24px;animation:fadeInUp 0.5s var(--ag-ease)}
@keyframes fadeInUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* Page header */
.ag-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:32px}
.ag-page-title{font-size:1.75rem;font-weight:700;letter-spacing:-0.02em;line-height:1.2}
.ag-page-subtitle{color:var(--ag-text-secondary);font-size:0.92rem;margin-top:4px}

/* Cards */
.ag-card{background:var(--ag-bg-card);border:1px solid var(--ag-border);border-radius:var(--ag-radius-lg);padding:24px;transition:all var(--ag-dur) var(--ag-ease)}
.ag-card:hover{border-color:var(--ag-border-med);box-shadow:var(--ag-shadow-md)}
.ag-card-interactive{cursor:pointer}
.ag-card-interactive:hover{border-color:var(--ag-primary);box-shadow:var(--ag-shadow-glow);transform:translateY(-2px)}
.ag-card-glow{position:relative;overflow:hidden}
.ag-card-glow::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:var(--ag-grad-glow);opacity:0;transition:opacity var(--ag-dur)}
.ag-card-glow:hover::before{opacity:1}

/* Stat cards */
.ag-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px}
.ag-stat-card{background:var(--ag-bg-card);border:1px solid var(--ag-border);border-radius:var(--ag-radius-lg);padding:24px;position:relative;overflow:hidden;animation:fadeInUp 0.5s var(--ag-ease) both}
.ag-stat-card:nth-child(1){animation-delay:0.05s}.ag-stat-card:nth-child(2){animation-delay:0.1s}.ag-stat-card:nth-child(3){animation-delay:0.15s}.ag-stat-card:nth-child(4){animation-delay:0.2s}
.ag-stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;opacity:0.5}
.ag-stat-card.stat-blue::before{background:var(--ag-blue)}.ag-stat-card.stat-green::before{background:var(--ag-emerald)}.ag-stat-card.stat-amber::before{background:var(--ag-amber)}.ag-stat-card.stat-violet::before{background:var(--ag-violet)}.ag-stat-card.stat-rose::before{background:var(--ag-rose)}.ag-stat-card.stat-cyan::before{background:var(--ag-cyan)}
.ag-stat-card .stat-icon{width:40px;height:40px;border-radius:var(--ag-radius-sm);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.ag-stat-card .stat-value{font-size:2rem;font-weight:800;letter-spacing:-0.02em;line-height:1}
.ag-stat-card .stat-label{color:var(--ag-text-muted);font-size:0.82rem;font-weight:500;text-transform:uppercase;letter-spacing:1px;margin-top:6px}

/* Buttons */
.ag-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;font-size:0.88rem;font-weight:600;border:none;border-radius:var(--ag-radius-sm);cursor:pointer;transition:all var(--ag-dur) var(--ag-ease);white-space:nowrap;text-decoration:none;line-height:1.4;position:relative;overflow:hidden}
.ag-btn::after{content:'';position:absolute;inset:0;background:#fff;opacity:0;transition:opacity 0.15s}
.ag-btn:active::after{opacity:0.1}
.ag-btn-primary{background:var(--ag-grad-primary);color:#fff;box-shadow:0 2px 10px rgba(249,115,22,0.3)}
.ag-btn-primary:hover{box-shadow:0 4px 20px rgba(249,115,22,0.4);transform:translateY(-1px)}
.ag-btn-secondary{background:var(--ag-bg-elevated);color:var(--ag-text-primary);border:1px solid var(--ag-border-med)}
.ag-btn-secondary:hover{background:var(--ag-bg-hover);border-color:var(--ag-border-bold)}
.ag-btn-ghost{background:transparent;color:var(--ag-text-secondary);padding:8px 12px}
.ag-btn-ghost:hover{background:var(--ag-bg-card);color:var(--ag-text-primary)}
.ag-btn-danger{background:rgba(251,113,133,0.1);color:var(--ag-rose);border:1px solid rgba(251,113,133,0.2)}
.ag-btn-danger:hover{background:rgba(251,113,133,0.2)}
.ag-btn-orion-primary{background:linear-gradient(135deg,#8b5cf6,#a78bfa);color:#fff;box-shadow:0 2px 10px rgba(167,139,250,0.30)}
.ag-btn-orion-primary:hover{box-shadow:0 4px 20px rgba(167,139,250,0.40);transform:translateY(-1px)}
.ag-btn-success{background:rgba(52,211,153,0.1);color:var(--ag-emerald);border:1px solid rgba(52,211,153,0.2)}
.ag-btn-success:hover{background:rgba(52,211,153,0.2)}
.ag-btn-sm{padding:6px 14px;font-size:0.82rem}
.ag-btn-lg{padding:14px 28px;font-size:1rem}
.ag-btn .btn-icon{width:16px;height:16px}

/* Badges */
.ag-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;font-size:0.75rem;font-weight:600;border-radius:var(--ag-radius-sm);letter-spacing:0.3px}
.ag-badge-blue{background:rgba(249,115,22,0.15);color:var(--ag-blue)}
.ag-badge-green{background:rgba(52,211,153,0.15);color:var(--ag-emerald)}
.ag-badge-amber{background:rgba(251,191,36,0.15);color:var(--ag-amber)}
.ag-badge-rose{background:rgba(251,113,133,0.15);color:var(--ag-rose)}
.ag-badge-violet{background:rgba(167,139,250,0.15);color:var(--ag-violet)}
.ag-badge-cyan{background:rgba(34,211,238,0.15);color:var(--ag-cyan)}
.ag-badge-gray{background:rgba(148,163,184,0.12);color:var(--ag-text-muted)}

/* Forms */
.ag-form-group{margin-bottom:16px}
.ag-form-group label{display:block;font-size:0.82rem;font-weight:500;color:var(--ag-text-secondary);margin-bottom:6px}
.ag-input,.ag-select,.ag-textarea{width:100%;padding:10px 14px;background:var(--ag-bg-input);border:1px solid var(--ag-border-med);border-radius:var(--ag-radius-sm);color:var(--ag-text-primary);font-size:0.92rem;transition:all var(--ag-dur) var(--ag-ease);outline:none}
.ag-input:focus,.ag-select:focus,.ag-textarea:focus{border-color:var(--ag-primary);box-shadow:0 0 0 3px rgba(249,115,22,0.15)}
.ag-input::placeholder,.ag-textarea::placeholder{color:var(--ag-text-muted)}
.ag-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%2394a3b8' viewBox='0 0 16 16'%3E%3Cpath d='M4.5 5.5l3.5 4 3.5-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}

/* Global <select> styling — V4 charte, catches bare <select> and overrides native browser rendering */
select{appearance:none;-webkit-appearance:none;-moz-appearance:none;width:100%;padding:10px 36px 10px 14px;background-color:var(--ag-bg-input);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.75' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;border:1px solid var(--ag-border-med);border-radius:var(--ag-radius-sm);color:var(--ag-text-primary);font-size:0.92rem;font-family:inherit;cursor:pointer;transition:border-color var(--ag-dur) var(--ag-ease),box-shadow var(--ag-dur) var(--ag-ease);outline:none}
select:hover{border-color:var(--ag-border-focus,rgba(249,115,22,0.35))}
select:focus{border-color:var(--ag-primary);box-shadow:0 0 0 3px rgba(249,115,22,0.15)}
select:disabled{opacity:.5;cursor:not-allowed}
select option{background:var(--ag-bg-card);color:var(--ag-text-primary);padding:8px}
/* Force chevron+padding on selects that use .ag-input class (historical inconsistency in codebase) */
select.ag-input{padding-right:36px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.75' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer}
.ag-textarea{resize:vertical;min-height:80px}
.ag-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* Tables */
.ag-table-wrap{overflow-x:auto;border-radius:var(--ag-radius-lg);border:1px solid var(--ag-border)}
.ag-table{width:100%;border-collapse:collapse}
.ag-table th{padding:12px 16px;text-align:left;font-size:0.78rem;font-weight:600;text-transform:uppercase;letter-spacing:0.8px;color:var(--ag-text-muted);background:var(--ag-bg-surface);border-bottom:1px solid var(--ag-border-med);white-space:nowrap}
.ag-table td{padding:14px 16px;font-size:0.9rem;border-bottom:1px solid var(--ag-border);background:var(--ag-bg-card);transition:background var(--ag-dur)}
.ag-table tr:hover td{background:var(--ag-bg-elevated)}
.ag-table tr:last-child td{border-bottom:none}
.ag-table .actions{display:flex;gap:6px;justify-content:flex-end}

/* Modals */
.ag-modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.7);backdrop-filter:blur(8px);z-index:200;align-items:center;justify-content:center;padding:24px;animation:fadeIn 0.2s var(--ag-ease)}
.ag-modal-overlay.open{display:flex}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.ag-modal{background:var(--ag-bg-surface);border:1px solid var(--ag-border-med);border-radius:var(--ag-radius-xl);width:100%;max-width:560px;max-height:85vh;overflow-y:auto;box-shadow:var(--ag-shadow-xl);animation:modalSlideUp 0.35s var(--ag-ease)}
@keyframes modalSlideUp{from{opacity:0;transform:translateY(20px) scale(0.98)}to{opacity:1;transform:translateY(0) scale(1)}}
.ag-modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px;border-bottom:1px solid var(--ag-border)}
.ag-modal-header h2{font-size:1.2rem;font-weight:700}
.ag-modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--ag-radius-sm);border:none;background:transparent;color:var(--ag-text-muted);cursor:pointer;transition:all 0.2s}
.ag-modal-close:hover{background:var(--ag-bg-card);color:var(--ag-text-primary)}
.ag-modal-body{padding:24px}
.ag-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 24px;border-top:1px solid var(--ag-border)}

/* Toast */
.ag-toast{position:fixed;top:80px;right:24px;padding:14px 20px;border-radius:var(--ag-radius-md);font-size:0.88rem;font-weight:500;z-index:1000;max-width:400px;display:flex;align-items:center;gap:10px;box-shadow:var(--ag-shadow-lg);animation:toastIn 0.4s var(--ag-ease),toastOut 0.4s var(--ag-ease) 3.5s forwards;backdrop-filter:blur(12px)}
@keyframes toastIn{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}
@keyframes toastOut{from{opacity:1}to{opacity:0;transform:translateY(-10px)}}
.ag-toast-success{background:rgba(52,211,153,0.15);border:1px solid rgba(52,211,153,0.3);color:#6ee7b7}
.ag-toast-error{background:rgba(251,113,133,0.15);border:1px solid rgba(251,113,133,0.3);color:#fda4af}

/* Empty state */
.ag-empty{text-align:center;padding:64px 32px;animation:fadeInUp 0.5s var(--ag-ease)}
.ag-empty-icon{width:56px;height:56px;margin:0 auto 24px;background:var(--ag-bg-card);border-radius:var(--ag-radius-lg);display:flex;align-items:center;justify-content:center;border:1px solid var(--ag-border)}
.ag-empty-icon svg{width:28px;height:28px;color:var(--ag-text-muted)}
.ag-empty p{color:var(--ag-text-secondary);font-size:0.95rem;line-height:1.6}

/* Loading */
.ag-loading{display:flex;align-items:center;justify-content:center;padding:64px;gap:16px;color:var(--ag-text-muted)}
.ag-spinner{width:24px;height:24px;border:2px solid var(--ag-border-med);border-top-color:var(--ag-primary);border-radius:50%;animation:spin 0.8s linear infinite}
.ag-spinner-lg{width:40px;height:40px;border-width:3px}
@keyframes spin{to{transform:rotate(360deg)}}

/* Stagger */
.ag-stagger>*{animation:fadeInUp 0.4s var(--ag-ease) both}
.ag-stagger>*:nth-child(1){animation-delay:.03s}.ag-stagger>*:nth-child(2){animation-delay:.06s}.ag-stagger>*:nth-child(3){animation-delay:.09s}.ag-stagger>*:nth-child(4){animation-delay:.12s}.ag-stagger>*:nth-child(5){animation-delay:.15s}.ag-stagger>*:nth-child(6){animation-delay:.18s}.ag-stagger>*:nth-child(7){animation-delay:.21s}.ag-stagger>*:nth-child(8){animation-delay:.24s}.ag-stagger>*:nth-child(9){animation-delay:.27s}.ag-stagger>*:nth-child(10){animation-delay:.3s}

/* Pulse dot */
.ag-pulse-dot{width:8px;height:8px;border-radius:50%;position:relative}
.ag-pulse-dot::after{content:'';position:absolute;inset:-3px;border-radius:50%;background:inherit;opacity:0.4;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:0.4}50%{transform:scale(1.8);opacity:0}}

/* Skeleton */
.ag-skeleton{background:linear-gradient(90deg,var(--ag-bg-card) 25%,var(--ag-bg-elevated) 50%,var(--ag-bg-card) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--ag-radius-sm)}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* Background decoration */
.ag-bg-glow{position:fixed;top:-200px;right:-200px;width:600px;height:600px;background:radial-gradient(circle,rgba(249,115,22,0.06) 0%,transparent 70%);pointer-events:none;z-index:-1}
.ag-bg-glow-2{position:fixed;bottom:-300px;left:-200px;width:500px;height:500px;background:radial-gradient(circle,rgba(234,88,12,0.04) 0%,transparent 70%);pointer-events:none;z-index:-1}

/* Theme toggle */
.ag-theme-toggle{background:none;border:1px solid var(--ag-border-med);border-radius:var(--ag-radius-sm);width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ag-text-muted);transition:all var(--ag-dur) var(--ag-ease);padding:0}
.ag-theme-toggle:hover{color:var(--ag-text-primary);border-color:var(--ag-border-bold);background:var(--ag-bg-card)}
.ag-theme-toggle svg{width:16px;height:16px}

/* Responsive */
@media(max-width:768px){
  .ag-header{padding:0 16px;height:56px}
  .ag-nav{display:none}
  .ag-main{padding:24px 16px}
  .ag-page-header{flex-direction:column;gap:12px}
  .ag-page-title{font-size:1.35rem}
  .ag-stats-grid{grid-template-columns:repeat(2,1fr)}
  .ag-form-row{grid-template-columns:1fr}
  .ag-modal{max-width:100%;border-radius:var(--ag-radius-lg) var(--ag-radius-lg) 0 0;max-height:90vh}
  .ag-toast{left:16px;right:16px;max-width:none}
  .ag-mobile-nav{display:flex!important}
  body{padding-bottom:70px}
}
.ag-mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--ag-mobile-nav-bg);backdrop-filter:blur(20px);border-top:1px solid var(--ag-border);padding:6px 8px 8px;z-index:100;justify-content:space-around}
.ag-mobile-nav-link{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 10px;border-radius:var(--ag-radius-sm);color:var(--ag-text-muted);font-size:0.65rem;font-weight:500;text-decoration:none;transition:color 0.2s}
.ag-mobile-nav-link.active{color:var(--ag-orange)}
.ag-mobile-nav-link .nav-icon{width:20px;height:20px}

/* Tablet landscape */
@media (min-width: 600px) and (max-width: 767px) {
  .ag-main { max-width: 95%; padding: 0 12px; }
  .ag-stats-grid { grid-template-columns: repeat(2, 1fr); }
  .ag-card { padding: 16px; }
}

/* Large screens */
@media (min-width: 1024px) {
  .ag-main { max-width: 960px; }
  .ag-stats-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (min-width: 1200px) {
  .ag-main { max-width: 1140px; }
  .ag-stats-grid { grid-template-columns: repeat(4, 1fr); gap: 24px; }
}

/* Text overflow protection for long names */
.ag-card h3, .ag-card .athlete-name, .ag-card .coach-name,
.ag-page-title, .ag-page-header h1, .ag-page-header h2 {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* === COMPAT (still-used non-prefixed classes) === */
.subtitle{color:var(--ag-text-secondary);font-size:0.92rem;margin-top:4px}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:0.82rem;font-weight:500;color:var(--ag-text-secondary);margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 14px;background:var(--ag-bg-input);border:1px solid var(--ag-border-med);border-radius:var(--ag-radius-sm);color:var(--ag-text-primary);font-size:0.92rem;transition:all var(--ag-dur) var(--ag-ease);outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--ag-primary);box-shadow:0 0 0 3px rgba(249,115,22,0.15)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.7);backdrop-filter:blur(8px);z-index:200;align-items:center;justify-content:center;padding:24px}
.modal-overlay.open{display:flex}
.modal{background:var(--ag-bg-surface);border:1px solid var(--ag-border-med);border-radius:var(--ag-radius-xl);width:100%;max-width:560px;max-height:85vh;overflow-y:auto;box-shadow:var(--ag-shadow-xl);animation:modalSlideUp 0.35s var(--ag-ease);padding:24px}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.modal-header h2{font-size:1.2rem;font-weight:700}
.modal-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:20px;padding-top:16px;border-top:1px solid var(--ag-border)}
table{width:100%;border-collapse:collapse}
table th{padding:12px 16px;text-align:left;font-size:0.78rem;font-weight:600;text-transform:uppercase;letter-spacing:0.8px;color:var(--ag-text-muted);background:var(--ag-bg-surface);border-bottom:1px solid var(--ag-border-med)}
table td{padding:14px 16px;font-size:0.9rem;border-bottom:1px solid var(--ag-border);background:var(--ag-bg-card);transition:background var(--ag-dur)}
table tr:hover td{background:var(--ag-bg-elevated)}
table .actions{display:flex;gap:6px;justify-content:flex-end}
.empty-state{text-align:center;padding:64px 32px;color:var(--ag-text-secondary)}
.empty-state .icon{font-size:2.5rem;margin-bottom:16px}
.toast{position:fixed;top:80px;right:24px;padding:14px 20px;border-radius:var(--ag-radius-md);font-size:0.88rem;font-weight:500;z-index:1000;max-width:400px;box-shadow:var(--ag-shadow-lg);animation:toastIn 0.4s var(--ag-ease),toastOut 0.4s var(--ag-ease) 3.5s forwards}
.toast-success{background:rgba(52,211,153,0.15);border:1px solid rgba(52,211,153,0.3);color:#6ee7b7}
.toast-error{background:rgba(251,113,133,0.15);border:1px solid rgba(251,113,133,0.3);color:#fda4af}

/* Tooltips */
.ag-tip{position:relative;display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:var(--ag-radius-full);background:var(--ag-bg-elevated);border:1px solid var(--ag-border-med);color:var(--ag-text-muted);font-size:0.65rem;font-weight:700;cursor:help;vertical-align:middle;margin-left:5px;flex-shrink:0;transition:all var(--ag-dur)}
.ag-tip:hover{color:var(--ag-orange);border-color:var(--ag-orange);background:rgba(249,115,22,0.08)}
.ag-tip-content{display:none;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);width:260px;padding:10px 14px;background:var(--ag-bg-surface);border:1px solid var(--ag-border-med);border-radius:var(--ag-radius-md);box-shadow:var(--ag-shadow-lg);font-size:0.8rem;font-weight:400;color:var(--ag-text-secondary);line-height:1.5;z-index:200;text-align:left;pointer-events:none}
.ag-tip-content::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:6px solid transparent;border-top-color:var(--ag-border-med)}
.ag-tip:hover .ag-tip-content{display:block}
.ag-help-link{display:inline-flex;align-items:center;gap:4px;font-size:0.78rem;color:var(--ag-primary);text-decoration:none;font-weight:500;transition:opacity var(--ag-dur)}
.ag-help-link:hover{opacity:0.8;text-decoration:underline}
.ag-help-link svg{width:14px;height:14px}
/* ─── iOS: prevent keyboard zoom on input focus ─── */
/* iOS zooms when input font-size < 16px */
@media (max-width: 768px) {
  input, textarea, select {
    font-size: 16px !important;
  }
}
/* ═══ ORION AIDE — Panneau gauche ═══ */

/* Header button */
.orion-help-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 16px; border-radius: 10px;
  background: linear-gradient(135deg, rgba(96,165,250,0.10), rgba(139,92,246,0.08));
  border: 1px solid rgba(96,165,250,0.25);
  color: #93c5fd; font-size: 0.78rem; font-weight: 600;
  cursor: pointer; font-family: inherit;
  transition: background 0.15s, border-color 0.15s, box-shadow 0.2s;
  box-shadow: 0 0 12px rgba(96,165,250,0.08);
}
.orion-help-btn:hover {
  background: linear-gradient(135deg, rgba(96,165,250,0.18), rgba(139,92,246,0.12));
  border-color: rgba(96,165,250,0.4);
  box-shadow: 0 0 20px rgba(96,165,250,0.15);
  color: #bfdbfe;
}

/* Panel (left side) */
.orion-help-panel {
  position: fixed; top: 0; left: -400px; bottom: 0;
  width: 400px; max-width: 100vw;
  background: var(--ag-bg-base, #111114);
  border-right: 1px solid rgba(96,165,250,0.15);
  box-shadow: 8px 0 40px rgba(0,0,0,0.2);
  z-index: 9998;
  display: flex; flex-direction: column;
  transition: left 0.25s cubic-bezier(0.22, 1, 0.36, 1);
}
.orion-help-panel.open { left: 0; }
.orion-help-panel.closing { left: -400px; }

/* Header */
.oh-header {
  display: flex; align-items: center; gap: 12px;
  padding: 16px 18px; flex-shrink: 0;
  border-bottom: 1px solid rgba(96,165,250,0.10);
  background: linear-gradient(180deg, rgba(96,165,250,0.04), transparent);
}
.oh-title {
  display: flex; align-items: center; gap: 8px; flex: 1;
}
.oh-close {
  background: none; border: none; color: var(--ag-text-muted, #64748b);
  cursor: pointer; padding: 4px; border-radius: 6px;
  transition: color 0.15s, background 0.15s;
}
.oh-close:hover { color: var(--ag-text-primary, #f1f5f9); background: var(--ag-ov2); }

/* Chat */
.oh-chat {
  flex: 1; overflow-y: auto; padding: 16px;
  display: flex; flex-direction: column; gap: 8px;
  scroll-behavior: smooth;
}
.oh-chat::-webkit-scrollbar { width: 3px; }
.oh-chat::-webkit-scrollbar-thumb { background: var(--ag-border-med, #334155); border-radius: 3px; }

/* Welcome */
.oh-welcome {
  text-align: center; padding: 40px 20px;
}
.oh-welcome-icon { margin-bottom: 16px; }
.oh-welcome-title {
  font-size: 1.1rem; font-weight: 700;
  background: linear-gradient(135deg, #60a5fa, #a78bfa);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  margin-bottom: 8px;
}
.oh-welcome-text {
  font-size: 0.85rem; color: var(--ag-text-muted, #64748b); line-height: 1.6;
}

/* Nav button under message */
.oh-nav-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px; margin-left: 0; margin-top: 4px; margin-bottom: 4px;
  border-radius: 10px;
  background: linear-gradient(135deg, rgba(96,165,250,0.08), rgba(139,92,246,0.06));
  border: 1px solid rgba(96,165,250,0.18);
  color: #93c5fd; font-size: 0.78rem; font-weight: 700;
  cursor: pointer; font-family: inherit;
  transition: background 0.15s, border-color 0.15s;
  align-self: flex-start;
}
.oh-nav-btn:hover {
  background: rgba(96,165,250,0.15);
  border-color: rgba(96,165,250,0.35);
}

/* Chips */
.oh-chips {
  display: flex; gap: 6px; padding: 8px 16px;
  overflow-x: auto; scrollbar-width: none;
  border-top: 1px solid rgba(96,165,250,0.06);
  flex-shrink: 0;
}
.oh-chips::-webkit-scrollbar { display: none; }

/* Input */
.oh-input-area {
  padding: 12px 16px; flex-shrink: 0;
  border-top: 1px solid rgba(96,165,250,0.08);
}

/* Messages — reuse orion-msg styles from coach-dashboard.css or agoge-athlete.css */
.orion-help-panel .orion-msg {
  max-width: 88%; padding: 10px 14px; border-radius: 14px;
  font-size: 0.82rem; line-height: 1.55;
  animation: ohFadeUp 0.3s ease both; word-wrap: break-word;
}
.orion-help-panel .orion-msg.user {
  align-self: flex-end;
  background: rgba(249,115,22,0.10);
  border: 1px solid rgba(249,115,22,0.15);
  color: var(--ag-text-primary, #f1f5f9);
  border-bottom-right-radius: 4px;
}
.orion-help-panel .orion-msg.ai {
  align-self: flex-start;
  background: rgba(96,165,250,0.05);
  border: 1px solid rgba(96,165,250,0.10);
  color: var(--ag-text-primary, #f1f5f9);
  border-bottom-left-radius: 4px;
}
.orion-help-panel .orion-msg-name {
  font-size: 0.70rem; font-weight: 700; color: #60a5fa;
  margin-bottom: 4px; display: flex; align-items: center; gap: 4px;
}
.orion-help-panel .orion-typing {
  display: flex; gap: 4px; padding: 10px 14px; align-self: flex-start;
}
.orion-help-panel .orion-typing span {
  width: 5px; height: 5px; border-radius: 50%;
  background: #60a5fa; opacity: 0.4;
  animation: ohDot 0.8s ease infinite;
}
.orion-help-panel .orion-typing span:nth-child(2) { animation-delay: 0.15s; }
.orion-help-panel .orion-typing span:nth-child(3) { animation-delay: 0.3s; }
.orion-help-panel .orion-input-wrap {
  display: flex; align-items: flex-end; gap: 8px;
}
.orion-help-panel .orion-input {
  flex: 1; background: var(--ag-bg-card, #1e293b); border: 1px solid var(--ag-border-med, #334155);
  border-radius: 12px; padding: 10px 14px;
  font-size: 0.84rem; color: var(--ag-text-primary, #f1f5f9);
  font-family: inherit; resize: none; outline: none;
  transition: border-color 0.2s; min-height: 40px; max-height: 80px;
}
.orion-help-panel .orion-input:focus { border-color: rgba(96,165,250,0.4); }
.orion-help-panel .orion-input::placeholder { color: var(--ag-text-muted, #64748b); }
.orion-help-panel .orion-send {
  width: 36px; height: 36px; border-radius: 10px; border: none;
  background: linear-gradient(135deg, #60a5fa, #a78bfa);
  color: #fff; display: flex; align-items: center; justify-content: center;
  cursor: pointer; flex-shrink: 0;
  transition: opacity 0.2s, transform 0.1s;
  box-shadow: 0 2px 12px rgba(96,165,250,0.3);
}
.orion-help-panel .orion-send:disabled { opacity: 0.3; cursor: not-allowed; }
.orion-help-panel .orion-send:active:not(:disabled) { transform: scale(0.92); }
.orion-help-panel .orion-chip {
  flex-shrink: 0; padding: 7px 12px;
  border-radius: 8px;
  background: rgba(96,165,250,0.06);
  border: 1px solid rgba(96,165,250,0.12);
  color: #93c5fd; font-size: 0.72rem; font-weight: 600;
  cursor: pointer; font-family: inherit;
  transition: background 0.15s, border-color 0.15s;
}
.orion-help-panel .orion-chip:hover {
  background: rgba(96,165,250,0.12);
  border-color: rgba(96,165,250,0.25);
}

@keyframes ohFadeUp {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes ohDot {
  0%, 80%, 100% { opacity: 0.2; transform: scale(0.8); }
  40% { opacity: 1; transform: scale(1.2); }
}

@media (max-width: 500px) {
  .orion-help-panel { width: 100vw; }
  .orion-help-btn span { display: none; }
  .orion-help-btn { padding: 6px 10px; }
}

/* ═══════════════════════════════════════════════════════
   GATE / PAYWALL SYSTEM — Composants réutilisables
   .ag-gate          — base
   .ag-gate-page     — plein écran (remplace le contenu)
   .ag-gate-inline   — carte inline (encart dans une page)
   .ag-gate-quota    — bandeau quota atteint
   .ag-badge-pro     — badge plan cliquable
   .ag-badge-team    — badge plan cliquable
   ═══════════════════════════════════════════════════════ */

/* ── Badge plan cliquable ── */
.ag-badge-pro,
.ag-badge-team {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 2px 8px;
  border-radius: var(--ag-radius-full);
  font-size: var(--ag-text-2xs);
  font-weight: var(--ag-font-bold);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition: all var(--ag-dur-fast) var(--ag-ease);
  vertical-align: middle;
  line-height: 1.6;
}
.ag-badge-pro {
  background: var(--ag-ov-orange);
  color: var(--ag-orange);
  border: 1px solid var(--ag-ov-orange-strong);
}
.ag-badge-pro:hover {
  background: var(--ag-ov-orange-strong);
  box-shadow: 0 0 12px rgba(249,115,22,0.15);
}
.ag-badge-team {
  background: var(--ag-ov-violet);
  color: var(--ag-violet);
  border: 1px solid var(--ag-ov-violet-strong);
}
.ag-badge-team:hover {
  background: var(--ag-ov-violet-strong);
  box-shadow: 0 0 12px rgba(167,139,250,0.15);
}

/* ── Base gate container ── */
.ag-gate {
  position: relative;
  border-radius: var(--ag-radius-lg);
  overflow: hidden;
}

/* ── PAGE gate — plein écran upgrade CTA ── */
.ag-gate-page {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--ag-sp-16) var(--ag-sp-6);
  min-height: 50vh;
  background: var(--ag-bg-card);
  border: 1px solid var(--ag-border);
}
.ag-gate-page .ag-gate-icon {
  width: 72px;
  height: 72px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--ag-radius-xl);
  background: var(--ag-ov-orange);
  border: 1px solid var(--ag-ov-orange-strong);
  color: var(--ag-orange);
  margin-bottom: var(--ag-sp-5);
}
.ag-gate-page .ag-gate-icon svg {
  width: 32px;
  height: 32px;
}
.ag-gate-page .ag-gate-title {
  font-size: var(--ag-text-xl);
  font-weight: var(--ag-font-bold);
  color: var(--ag-text-primary);
  margin-bottom: var(--ag-sp-2);
}
.ag-gate-page .ag-gate-desc {
  font-size: var(--ag-text-sm);
  color: var(--ag-text-muted);
  max-width: 420px;
  margin-bottom: var(--ag-sp-6);
  line-height: 1.6;
}
.ag-gate-page .ag-gate-features {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--ag-sp-8) 0;
  text-align: left;
  max-width: 340px;
}
.ag-gate-page .ag-gate-features li {
  display: flex;
  align-items: center;
  gap: var(--ag-sp-2);
  font-size: var(--ag-text-sm);
  color: var(--ag-text-secondary);
  padding: var(--ag-sp-2) 0;
}
.ag-gate-page .ag-gate-features li svg {
  width: 16px;
  height: 16px;
  color: var(--ag-orange);
  flex-shrink: 0;
}
.ag-gate-page .ag-gate-cta {
  display: inline-flex;
  align-items: center;
  gap: var(--ag-sp-2);
  padding: var(--ag-sp-3) var(--ag-sp-8);
  border-radius: var(--ag-radius-full);
  background: var(--ag-grad-primary);
  color: #fff;
  font-weight: var(--ag-font-bold);
  font-size: var(--ag-text-md);
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: transform var(--ag-dur-fast) var(--ag-ease), box-shadow var(--ag-dur-fast) var(--ag-ease);
  box-shadow: var(--ag-shadow-glow);
}
.ag-gate-page .ag-gate-cta:hover {
  transform: translateY(-1px);
  box-shadow: var(--ag-shadow-glow-strong);
}

/* ── INLINE gate — bordure pointillée, contenu bloqué ── */
.ag-gate-inline {
  padding: var(--ag-sp-5);
  background: var(--ag-bg-card);
  border: 2px dashed var(--ag-ov-orange-strong);
  display: flex;
  align-items: center;
  gap: var(--ag-sp-4);
  flex-wrap: wrap;
}
.ag-gate-inline .ag-gate-inline-icon {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--ag-radius-md);
  background: var(--ag-ov-orange);
  color: var(--ag-orange);
  flex-shrink: 0;
}
.ag-gate-inline .ag-gate-inline-icon svg {
  width: 20px;
  height: 20px;
}
.ag-gate-inline .ag-gate-inline-body {
  flex: 1;
  min-width: 180px;
}
.ag-gate-inline .ag-gate-inline-title {
  font-size: var(--ag-text-sm);
  font-weight: var(--ag-font-semibold);
  color: var(--ag-text-primary);
  margin-bottom: 2px;
}
.ag-gate-inline .ag-gate-inline-desc {
  font-size: var(--ag-text-xs);
  color: var(--ag-text-muted);
  line-height: 1.5;
}

/* ── QUOTA gate — bandeau horizontal ── */
.ag-gate-quota {
  display: flex;
  align-items: center;
  gap: var(--ag-sp-3);
  padding: var(--ag-sp-3) var(--ag-sp-4);
  background: var(--ag-ov-amber);
  border: 1px solid var(--ag-ov-amber-strong);
  border-radius: var(--ag-radius-md);
  margin-bottom: var(--ag-sp-4);
  flex-wrap: wrap;
}
.ag-gate-quota .ag-gate-quota-icon {
  color: var(--ag-warning);
  flex-shrink: 0;
  display: flex;
}
.ag-gate-quota .ag-gate-quota-icon svg {
  width: 16px;
  height: 16px;
}
.ag-gate-quota .ag-gate-quota-text {
  flex: 1;
  min-width: 160px;
  font-size: var(--ag-text-sm);
  color: var(--ag-text-secondary);
}
.ag-gate-quota .ag-gate-quota-text strong {
  color: var(--ag-warning);
  font-weight: var(--ag-font-semibold);
}
.ag-gate-quota .ag-gate-quota-link {
  font-size: var(--ag-text-xs);
  font-weight: var(--ag-font-semibold);
  color: var(--ag-orange);
  text-decoration: none;
  white-space: nowrap;
}
.ag-gate-quota .ag-gate-quota-link:hover {
  text-decoration: underline;
}
.ag-gate-quota.ag-gate-quota--exhausted {
  background: var(--ag-ov-rose);
  border-color: var(--ag-ov-rose-strong);
}
.ag-gate-quota.ag-gate-quota--exhausted .ag-gate-quota-icon {
  color: var(--ag-danger);
}
.ag-gate-quota.ag-gate-quota--exhausted .ag-gate-quota-text strong {
  color: var(--ag-danger);
}

/* ── ATHLETE LIMIT MODAL overlay ── */
.ag-gate-modal-body {
  text-align: center;
  padding: var(--ag-sp-6);
}
.ag-gate-modal-body .ag-gate-icon {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--ag-radius-xl);
  background: var(--ag-ov-orange);
  border: 1px solid var(--ag-ov-orange-strong);
  color: var(--ag-orange);
  margin: 0 auto var(--ag-sp-4);
}
.ag-gate-modal-body .ag-gate-icon svg {
  width: 28px;
  height: 28px;
}
.ag-gate-modal-body .ag-gate-title {
  font-size: var(--ag-text-lg);
  font-weight: var(--ag-font-bold);
  color: var(--ag-text-primary);
  margin-bottom: var(--ag-sp-2);
}
.ag-gate-modal-body .ag-gate-desc {
  font-size: var(--ag-text-sm);
  color: var(--ag-text-muted);
  line-height: 1.6;
  margin-bottom: var(--ag-sp-6);
}

/* ── Disabled state for gated buttons ── */
.ag-btn-gated {
  opacity: 0.45;
  pointer-events: none;
  filter: grayscale(0.3);
}

/* ── Light theme overrides ── */
.light-theme .ag-gate-page { background: var(--ag-bg-card); }
.light-theme .ag-gate-inline { background: var(--ag-bg-card); }
.light-theme .ag-gate-quota { background: rgba(245,158,11,0.06); }
.light-theme .ag-gate-quota.ag-gate-quota--exhausted { background: rgba(251,113,133,0.06); }/* ═══ CH-002.5 — AI Credits UI ═══ */

/* Badge crédits header — Style charte V4 "Warm Night" */
.ai-credits-badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 11px;
  border-radius: 999px;
  font-size: 12px; font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  letter-spacing: 0.01em;
  background: transparent;
  border: 1px solid transparent;
  transition:
    transform 0.18s cubic-bezier(.22, 1, .36, 1),
    background 0.18s,
    border-color 0.18s,
    box-shadow 0.18s;
  line-height: 1.2;
}
.ai-credits-badge:hover {
  transform: translateY(-1px);
}
/* Symbole ✦ Orion */
.ai-credits-badge::before {
  content: '✦';
  font-size: 12px;
  line-height: 1;
  opacity: 0.95;
  letter-spacing: 0;
}

/* État > 50% : violet Orion (état "normal", confiance) */
.ai-credits-badge.aibad-emerald {
  color: var(--ag-violet, #a78bfa);
  background: rgba(167, 139, 250, 0.08);
  border-color: rgba(167, 139, 250, 0.28);
}
.ai-credits-badge.aibad-emerald:hover {
  background: rgba(167, 139, 250, 0.12);
  border-color: rgba(167, 139, 250, 0.42);
  box-shadow: 0 2px 12px rgba(167, 139, 250, 0.18);
}

/* État 20-50% : ambre (warning doux) */
.ai-credits-badge.aibad-amber {
  color: var(--ag-amber, #fbbf24);
  background: rgba(251, 191, 36, 0.10);
  border-color: rgba(251, 191, 36, 0.32);
}
.ai-credits-badge.aibad-amber:hover {
  background: rgba(251, 191, 36, 0.16);
  border-color: rgba(251, 191, 36, 0.48);
  box-shadow: 0 2px 12px rgba(251, 191, 36, 0.18);
}

/* État 1-19% : rose (alerte) */
.ai-credits-badge.aibad-rose {
  color: var(--ag-rose, #fb7185);
  background: rgba(251, 113, 133, 0.10);
  border-color: rgba(251, 113, 133, 0.35);
}
.ai-credits-badge.aibad-rose:hover {
  background: rgba(251, 113, 133, 0.16);
  border-color: rgba(251, 113, 133, 0.50);
  box-shadow: 0 2px 12px rgba(251, 113, 133, 0.20);
}

/* État 0 : épuisé (muted) */
.ai-credits-badge.aibad-muted {
  color: var(--ag-text-muted);
  background: transparent;
  border-color: var(--ag-border);
}
.ai-credits-badge.aibad-muted::before { opacity: 0.5; }

@media (max-width: 768px) {
  .ai-credits-badge {
    font-size: 11px; padding: 3px 9px; gap: 4px;
  }
  .ai-credits-badge::before { font-size: 11px; }
}

/* Modale "Crédits insuffisants" */
.ai-insuf-overlay {
  position: fixed; inset: 0;
  background: rgba(0, 0, 0, 0.65);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  z-index: 9000;
  opacity: 0; transition: opacity 0.2s ease;
  padding: 20px;
}
.ai-insuf-overlay.open { opacity: 1; }

.ai-insuf-modal {
  max-width: 440px; width: 100%;
  background: var(--ag-bg-card);
  border: 1px solid var(--ag-border);
  border-radius: 14px;
  padding: 28px 24px 22px;
  text-align: center;
  box-shadow: 0 24px 48px rgba(0, 0, 0, 0.4);
  transform: translateY(8px) scale(0.98);
  opacity: 0;
  transition: transform 0.22s cubic-bezier(.22, 1, .36, 1), opacity 0.22s;
}
.ai-insuf-overlay.open .ai-insuf-modal {
  transform: translateY(0) scale(1);
  opacity: 1;
}

.ai-insuf-icon {
  display: flex; justify-content: center;
  margin-bottom: 14px;
}
.ai-insuf-title {
  font-size: 1.05rem; font-weight: 700;
  color: var(--ag-text-primary);
  margin-bottom: 12px;
  line-height: 1.4;
}
.ai-insuf-body {
  font-size: 0.86rem;
  color: var(--ag-text-secondary);
  line-height: 1.55;
  margin-bottom: 22px;
}
.ai-insuf-body strong {
  color: var(--ag-text-primary);
  font-weight: 700;
}
.ai-insuf-actions {
  display: flex; justify-content: center;
}
.ai-insuf-actions .ag-btn {
  min-width: 160px;
}

/* Bandeau alerte 20% */
.ai-low-banner {
  position: fixed; top: 0; left: 0; right: 0;
  background: var(--ag-amber, #fbbf24);
  color: #000;
  padding: 10px 16px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
  z-index: 8500;
  font-size: 0.86rem;
  font-weight: 500;
  transform: translateY(-100%);
  transition: transform 0.28s cubic-bezier(.22, 1, .36, 1);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}
.ai-low-banner.visible {
  transform: translateY(0);
}
.ai-low-banner-content {
  display: flex; align-items: center; gap: 10px;
  flex: 1;
}
.ai-low-banner-close {
  background: transparent;
  border: none;
  color: #000;
  font-size: 1.4rem;
  font-weight: 700;
  cursor: pointer;
  padding: 0 8px;
  line-height: 1;
  opacity: 0.65;
  transition: opacity 0.18s;
}
.ai-low-banner-close:hover { opacity: 1; }

/* Card "Crédits IA" dans account.html */
.account-card.ai-credits-card::before {
  background: linear-gradient(90deg, var(--ag-violet), var(--ag-cyan, #06b6d4));
}
.ai-cc-hero {
  display: flex; flex-direction: column; align-items: center;
  padding: 16px 0 12px;
  gap: 6px;
}
.ai-cc-counter {
  font-size: 1.8rem; font-weight: 800;
  color: var(--ag-text-primary);
  letter-spacing: -0.01em;
}
.ai-cc-counter strong {
  color: var(--ag-violet);
  font-weight: 800;
}
.ai-cc-period {
  font-size: 0.78rem; color: var(--ag-text-muted);
}
.ai-cc-estim {
  font-size: 0.82rem; color: var(--ag-text-secondary);
  margin-top: 4px;
  font-style: italic;
}
.ai-cc-estim.warning { color: var(--ag-rose); }
.ai-cc-info {
  font-size: 0.78rem;
  color: var(--ag-text-muted);
  padding: 12px 14px;
  margin-top: 14px;
  background: rgba(167,139,250,0.04);
  border: 1px solid rgba(167,139,250,0.1);
  border-radius: var(--ag-radius-sm, 8px);
  line-height: 1.5;
}
.ai-cc-info b { color: var(--ag-violet); }
