/* ============================================
   MX FANTASY SPORTS — Design System v3
   Full mobile-first, light theme
   ============================================ */

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

:root {
  --bg:        #f2f0eb;
  --surface:   #e8e5de;
  --card:      #ffffff;
  --card2:     #f8f6f2;
  --border:    #ddd9d0;
  --border2:   #cbc6bc;
  --red:       #d4200f;
  --red-light: #fff0ee;
  --orange:    #e8520a;
  --yellow:    #c4860a;
  --green:     #1a8a4a;
  --blue:      #1d5fbf;
  --white:     #ffffff;
  --ink:       #1a1714;
  --text:      #3d3830;
  --muted:     #7a7168;
  --subtle:    #b5b0a6;
  --font-display:   'Bebas Neue', sans-serif;
  --font-condensed: 'Barlow Condensed', sans-serif;
  --font-body:      'Barlow', sans-serif;
  --nav-h:  60px;
  --sidebar-w: 220px;
  --radius: 8px;
  --shadow-sm: 0 1px 4px rgba(26,23,20,0.08);
  --shadow-md: 0 4px 16px rgba(26,23,20,0.1);
  --shadow-lg: 0 12px 40px rgba(26,23,20,0.14);
  --shadow-red: 0 4px 20px rgba(212,32,15,0.25);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:15px;line-height:1.6;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,select,textarea{font-family:inherit}
ul{list-style:none}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:300;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;padding:0 20px;background:var(--ink);border-bottom:1px solid rgba(255,255,255,0.08)}
.nav-logo{font-family:var(--font-display);font-size:20px;letter-spacing:3px;color:#fff;display:flex;align-items:center;gap:8px;flex-shrink:0}
.nav-logo .mx{color:var(--red)}
.live-dot{width:7px;height:7px;border-radius:50%;background:#4ade80;box-shadow:0 0 8px #4ade80;animation:blink 2s infinite;flex-shrink:0}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}
.nav-links{display:flex;gap:2px}
.nav-link{padding:6px 12px;font-family:var(--font-condensed);font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.5);border-radius:var(--radius);transition:all 0.15s}
.nav-link:hover{color:#fff;background:rgba(255,255,255,0.08)}
.nav-link.active{color:#fff}
.nav-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}
.nav-user-btn{display:flex;align-items:center;gap:8px;padding:6px 12px;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);border-radius:var(--radius);color:#fff;font-family:var(--font-condensed);font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:all 0.15s;position:relative}
.nav-user-btn:hover{background:rgba(255,255,255,0.14)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer}
.nav-hamburger span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:all 0.3s}

/* USER DROPDOWN */
.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:180px;overflow:hidden;z-index:400;display:none}
.user-dropdown.open{display:block;animation:fadeUp 0.2s ease}
.user-dropdown-item{display:flex;align-items:center;gap:10px;padding:11px 16px;font-size:14px;color:var(--text);cursor:pointer;transition:background 0.1s;border-bottom:1px solid var(--border)}
.user-dropdown-item:last-child{border-bottom:none}
.user-dropdown-item:hover{background:var(--card2);color:var(--ink)}
.user-dropdown-item.danger{color:var(--red)}
.user-dropdown-item.danger:hover{background:#fff0ee}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 20px;font-family:var(--font-condensed);font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;border-radius:var(--radius);transition:all 0.15s;white-space:nowrap;cursor:pointer}
.btn-primary{background:var(--red);color:#fff;border:1.5px solid var(--red);box-shadow:0 2px 8px rgba(212,32,15,0.2)}
.btn-primary:hover{background:#bf1c0c;box-shadow:var(--shadow-red);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--text);border:1.5px solid var(--border2)}
.btn-ghost:hover{border-color:var(--ink);color:var(--ink)}
.btn-surface{background:var(--card2);color:var(--text);border:1.5px solid var(--border)}
.btn-surface:hover{background:var(--surface);color:var(--ink)}
.btn-dark{background:var(--ink);color:#fff;border:1.5px solid var(--ink)}
.btn-dark:hover{background:#2e2a26;transform:translateY(-1px)}
.btn-green{background:var(--green);color:#fff;border:1.5px solid var(--green)}
.btn-green:hover{filter:brightness(1.1);transform:translateY(-1px)}
.btn-orange{background:var(--orange);color:#fff;border:1.5px solid var(--orange)}
.btn-lg{padding:13px 32px;font-size:14px}
.btn-sm{padding:5px 12px;font-size:11px}
.btn:disabled{opacity:0.4;cursor:not-allowed;transform:none!important}
.w-full{width:100%}

/* CARDS */
.card{background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.card-header{padding:14px 18px;border-bottom:1.5px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--card2);border-radius:var(--radius) var(--radius) 0 0}
.card-title{font-family:var(--font-condensed);font-size:12px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink)}
.card-body{padding:18px}

/* TAGS */
.tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;font-family:var(--font-condensed);font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;border-radius:3px}
.tag-red{background:#fde8e6;border:1px solid #f5bab5;color:#b8190a}
.tag-green{background:#e6f7ee;border:1px solid #a8dfc0;color:#116635}
.tag-orange{background:#fef0e6;border:1px solid #f5ccaa;color:#b84000}
.tag-blue{background:#e8f0fc;border:1px solid #aec6f5;color:#1445a0}
.tag-muted{background:var(--card2);border:1px solid var(--border);color:var(--muted)}
.tag-yellow{background:#fef7e0;border:1px solid #f5dfa0;color:#8a5c00}
.tag-ink{background:var(--ink);border:1px solid var(--ink);color:#fff}

/* FORMS */
.form-group{display:flex;flex-direction:column;gap:6px}
.form-label{font-family:var(--font-condensed);font-size:11px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted)}
.form-input{background:var(--card);border:1.5px solid var(--border2);color:var(--ink);padding:10px 14px;font-size:15px;border-radius:var(--radius);transition:border-color 0.15s,box-shadow 0.15s;width:100%}
.form-input:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(212,32,15,0.1)}
.form-input::placeholder{color:var(--subtle)}
.form-select{background:var(--card);border:1.5px solid var(--border2);color:var(--ink);padding:10px 14px;font-size:15px;border-radius:var(--radius);width:100%;appearance:none;cursor:pointer}
.form-select:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(212,32,15,0.1)}
.form-hint{font-size:12px;color:var(--muted);margin-top:2px}

/* TABS */
.tabs{display:flex;border-bottom:1.5px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch}
.tab{padding:10px 18px;font-family:var(--font-condensed);font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);border-bottom:2.5px solid transparent;margin-bottom:-1.5px;cursor:pointer;transition:all 0.15s;white-space:nowrap;flex-shrink:0}
.tab:hover{color:var(--ink)}
.tab.active{color:var(--ink);border-bottom-color:var(--red)}

/* PAGE */
.page{padding-top:var(--nav-h);min-height:100vh}
.container{max-width:1180px;margin:0 auto;padding:0 20px}
.page-header{padding:24px 0 18px;border-bottom:1.5px solid var(--border);margin-bottom:24px}
.page-title{font-family:var(--font-display);font-size:36px;letter-spacing:2px;color:var(--ink);line-height:1}
.page-subtitle{font-size:14px;color:var(--muted);margin-top:4px}

/* APP LAYOUT — sidebar + main */
.app-layout{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:calc(100vh - var(--nav-h))}
.app-sidebar{background:var(--card);border-right:1.5px solid var(--border);padding:16px 0;position:sticky;top:var(--nav-h);height:calc(100vh - var(--nav-h));overflow-y:auto;z-index:100}
.app-main{background:var(--bg);padding:24px 24px 80px}

/* SIDEBAR NAV */
.sb-section{padding:0 10px;margin-bottom:20px}
.sb-title{font-family:var(--font-condensed);font-size:10px;font-weight:800;letter-spacing:2.5px;text-transform:uppercase;color:var(--subtle);padding:0 8px;margin-bottom:4px}
.sb-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--radius);font-size:14px;font-weight:500;color:var(--text);cursor:pointer;transition:all 0.15s;text-decoration:none;position:relative}
.sb-item:hover{background:var(--surface);color:var(--ink)}
.sb-item.active{background:var(--red-light);color:var(--red);font-weight:700}
.sb-item .icon{font-size:16px;width:20px;text-align:center;flex-shrink:0}
.sb-badge{margin-left:auto;background:var(--red);color:#fff;font-family:var(--font-condensed);font-size:10px;font-weight:800;padding:1px 6px;border-radius:10px}
.sb-league-item{padding:10px 10px;border-radius:var(--radius);cursor:pointer;transition:all 0.15s;margin-bottom:2px;border:1.5px solid transparent;text-decoration:none;display:block}
.sb-league-item:hover{background:var(--surface)}
.sb-league-item.active{background:var(--red-light);border-color:#f5bab5}
.sb-league-name{font-family:var(--font-condensed);font-size:13px;font-weight:800;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-league-meta{font-size:11px;color:var(--muted);margin-top:1px}

/* RIDER CARD */
.rider-row{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border);transition:background 0.1s;cursor:pointer}
.rider-row:last-child{border-bottom:none}
.rider-row:hover{background:var(--card2)}
.rider-avatar{width:40px;height:40px;border-radius:8px;overflow:hidden;background:var(--ink);flex-shrink:0;position:relative}
.rider-avatar img{width:100%;height:100%;object-fit:cover;object-position:top center}
.rider-avatar .fallback{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:16px;color:var(--red)}
.rider-name-text{font-family:var(--font-condensed);font-size:14px;font-weight:800;text-transform:uppercase;color:var(--ink)}
.rider-meta{font-size:11px;color:var(--muted);margin-top:1px}
.rider-pts-num{font-family:var(--font-condensed);font-size:18px;font-weight:700;color:var(--yellow)}
.rider-pts-lbl{font-size:9px;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;text-align:center}

/* ROSTER SLOT */
.roster-slot{display:flex;align-items:center;gap:10px;padding:12px 14px;border:1.5px solid var(--border);border-radius:var(--radius);background:var(--card);transition:all 0.15s}
.roster-slot:hover{border-color:var(--border2);box-shadow:var(--shadow-sm)}
.roster-slot.empty{border-style:dashed;border-color:var(--subtle);background:var(--card2)}
.slot-label{font-family:var(--font-condensed);font-size:10px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;width:36px;text-align:center;flex-shrink:0}
.slot-label.s450{color:var(--red)}
.slot-label.sflex{color:var(--blue)}
.slot-label.sbench{color:var(--subtle)}

/* MODAL */
.modal-overlay{position:fixed;inset:0;z-index:500;background:rgba(26,23,20,0.55);display:flex;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(4px);animation:fadeIn 0.2s ease}
.modal{background:var(--card);border:1.5px solid var(--border);border-radius:12px;width:100%;max-width:520px;max-height:92vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:fadeUp 0.25s ease}
.modal-header{padding:18px 22px 14px;border-bottom:1.5px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--card2);border-radius:12px 12px 0 0;position:sticky;top:0;z-index:10}
.modal-title{font-family:var(--font-display);font-size:24px;letter-spacing:2px;color:var(--ink)}
.modal-close{color:var(--muted);font-size:18px;padding:4px 8px;cursor:pointer;transition:color 0.15s;border:none;background:none}
.modal-close:hover{color:var(--ink)}
.modal-body{padding:20px 22px}
.modal-footer{padding:14px 22px;border-top:1.5px solid var(--border);display:flex;gap:10px;justify-content:flex-end;background:var(--card2);border-radius:0 0 12px 12px}

/* TOAST */
.toast-container{position:fixed;bottom:20px;right:16px;z-index:600;display:flex;flex-direction:column;gap:8px;max-width:calc(100vw - 32px)}
.toast{background:var(--ink);border-radius:var(--radius);padding:11px 16px;display:flex;align-items:center;gap:10px;font-size:14px;color:#fff;animation:slideIn 0.3s ease;min-width:200px;box-shadow:var(--shadow-lg)}
.toast.success{border-left:3px solid #4ade80}
.toast.error{border-left:3px solid #f87171}
.toast.info{border-left:3px solid #60a5fa}

/* ALERTS */
.alert{padding:12px 16px;border-radius:var(--radius);border-left:4px solid;font-size:14px;line-height:1.55}
.alert-yellow{background:#fef7e0;border-color:var(--yellow);color:#5a3e00}
.alert-red{background:#fde8e6;border-color:var(--red);color:#7a1008}
.alert-green{background:#e6f7ee;border-color:var(--green);color:#0c4a22}
.alert-blue{background:#e8f0fc;border-color:var(--blue);color:#0d2f6e}

/* STAT BOX */
.stat-box{text-align:center;padding:14px 10px}
.stat-num{font-family:var(--font-condensed);font-size:22px;font-weight:800;color:var(--ink);line-height:1}
.stat-lbl{font-family:var(--font-condensed);font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-top:4px}

/* GRID */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}

/* UTILS */
.flex{display:flex}
.flex-center{display:flex;align-items:center}
.flex-between{display:flex;align-items:center;justify-content:space-between}
.gap-4{gap:4px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}
.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.mt-24{margin-top:24px}
.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}.mb-24{margin-bottom:24px}
.divider{height:1px;background:var(--border);margin:16px 0}
.text-ink{color:var(--ink)!important}.text-muted{color:var(--muted)!important}.text-red{color:var(--red)!important}.text-green{color:var(--green)!important}.text-yellow{color:var(--yellow)!important}.text-white{color:#fff!important}
.fw-600{font-weight:600}.fw-700{font-weight:700}.fw-800{font-weight:800}
.font-display{font-family:var(--font-display)}.font-condensed{font-family:var(--font-condensed)}
.uppercase{text-transform:uppercase}.ls-wide{letter-spacing:1.5px}
.text-sm{font-size:13px}.text-xs{font-size:11px}
.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rounded{border-radius:var(--radius)}
.shadow-sm{box-shadow:var(--shadow-sm)}
.section-title{font-family:var(--font-condensed);font-size:12px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.empty-state{padding:40px 20px;text-align:center;color:var(--muted)}
.empty-icon{font-size:36px;margin-bottom:10px;opacity:0.5}
.empty-title{font-family:var(--font-condensed);font-size:16px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text);margin-bottom:4px}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideIn{from{opacity:0;transform:translateX(10px)}to{opacity:1;transform:translateX(0)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.5}}

/* MOBILE NAV DRAWER */
.mobile-nav{position:fixed;inset:0;z-index:250;display:none}
.mobile-nav.open{display:block}
.mobile-nav-overlay{position:absolute;inset:0;background:rgba(26,23,20,0.5)}
.mobile-nav-drawer{position:absolute;top:0;left:0;bottom:0;width:280px;background:var(--card);box-shadow:var(--shadow-lg);overflow-y:auto;padding:80px 0 40px;transform:translateX(-100%);transition:transform 0.3s ease}
.mobile-nav.open .mobile-nav-drawer{transform:translateX(0)}

/* SCROLLBAR */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--surface)}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--muted)}

/* MOBILE */
@media(max-width:768px){
  .nav-links{display:none}
  .nav-hamburger{display:flex}
  .app-layout{grid-template-columns:1fr}
  .app-sidebar{display:none}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .modal{border-radius:0;max-height:100vh;max-width:100%;margin:0;border-radius:12px}
  .app-main{padding:16px 12px 80px}
  .page-title{font-size:28px}
  .hide-mobile{display:none!important}
  .show-mobile{display:flex!important}
}
@media(min-width:769px){
  .show-mobile{display:none!important}
}
/* Bottom tab bar for mobile */
.mobile-bottom-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:200;background:var(--ink);border-top:1px solid rgba(255,255,255,0.08);padding:8px 0 env(safe-area-inset-bottom)}
@media(max-width:768px){.mobile-bottom-bar{display:flex}}
.mbb-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:4px;color:rgba(255,255,255,0.45);cursor:pointer;text-decoration:none;transition:color 0.15s}
.mbb-item.active,.mbb-item:hover{color:#fff}
.mbb-icon{font-size:20px;line-height:1}
.mbb-label{font-family:var(--font-condensed);font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase}
