/* ================================================================
   SPORTA v4 — Design System
   Inspired by: SPORTLINK screenshots — clean white, bold black,
   lime accent, purple for live/penalties, card-based layout
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Space+Grotesk:wght@400;500;600;700&display=swap');

:root {
  /* Brand */
  --lime:        #CBFF00;
  --lime-dark:   #A8D400;
  --lime-soft:   #F0FFB0;
  --red:         #FF3040;
  --red-soft:    #FFF0F1;
  --blue:        #3B82F6;
  --blue-soft:   #EFF6FF;
  --purple:      #7C3AED;
  --purple-soft: #F5F3FF;
  --purple-mid:  #8B5CF6;
  --orange:      #F59E0B;
  --orange-soft: #FFFBEB;
  --green:       #10B981;
  --green-soft:  #ECFDF5;

  /* Neutrals */
  --bg:          #F3F4F6;
  --bg-white:    #FFFFFF;
  --bg-card:     #FFFFFF;
  --bg-input:    #F9FAFB;
  --bg-hover:    #F3F4F6;

  /* Text */
  --text-900:    #111827;
  --text-700:    #374151;
  --text-500:    #6B7280;
  --text-400:    #9CA3AF;
  --text-300:    #D1D5DB;
  --text-100:    #F3F4F6;

  /* Borders */
  --border:      #E5E7EB;
  --border-md:   #D1D5DB;

  /* Shadows */
  --shadow-xs:  0 1px 2px rgba(0,0,0,0.05);
  --shadow-sm:  0 1px 3px rgba(0,0,0,0.1), 0 1px 2px rgba(0,0,0,0.06);
  --shadow-md:  0 4px 6px rgba(0,0,0,0.07), 0 2px 4px rgba(0,0,0,0.06);
  --shadow-lg:  0 10px 15px rgba(0,0,0,0.1), 0 4px 6px rgba(0,0,0,0.05);
  --shadow-xl:  0 20px 25px rgba(0,0,0,0.1), 0 10px 10px rgba(0,0,0,0.04);
  --shadow-lime:   0 4px 14px rgba(203,255,0,0.4);
  --shadow-purple: 0 4px 14px rgba(124,58,237,0.3);

  /* Typography */
  --font-body:    'Inter', sans-serif;
  --font-ui:      'Space Grotesk', sans-serif;

  /* Spacing */
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s5:20px;
  --s6:24px; --s8:32px; --s10:40px; --s12:48px; --s16:64px;

  /* Radius */
  --r-sm:  6px;
  --r-md:  10px;
  --r-lg:  14px;
  --r-xl:  18px;
  --r-2xl: 24px;
  --r-full: 999px;

  /* Transitions */
  --ease: cubic-bezier(0.4,0,0.2,1);
  --ease-spring: cubic-bezier(0.34,1.56,0.64,1);
  --t-fast: 0.1s;
  --t-base: 0.2s;
  --t-slow: 0.35s;

  /* Layout */
  --sidebar-w: 256px;
  --topbar-h:  60px;
  --bottom-nav-h: 68px;
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:16px;-webkit-text-size-adjust:100%;}
body{font-family:var(--font-body);background:var(--bg);color:var(--text-900);line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
a{text-decoration:none;color:inherit;}
button{cursor:pointer;border:none;background:none;font-family:inherit;}
input,textarea,select{font-family:inherit;}
img{max-width:100%;display:block;}
ul,ol{list-style:none;}
::-webkit-scrollbar{width:4px;height:4px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--text-300);border-radius:99px;}
::selection{background:rgba(203,255,0,0.3);color:var(--text-900);}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 18px;border-radius:var(--r-full);font-family:var(--font-ui);font-weight:600;font-size:14px;transition:all var(--t-base) var(--ease);cursor:pointer;border:none;white-space:nowrap;position:relative;-webkit-tap-highlight-color:transparent;}
.btn:active{transform:scale(0.97);}
.btn:disabled{opacity:0.55;cursor:not-allowed;transform:none!important;}

.btn-dark{background:var(--text-900);color:white;}
.btn-dark:hover{background:var(--text-700);box-shadow:var(--shadow-md);}
.btn-lime{background:var(--lime);color:var(--text-900);font-weight:700;}
.btn-lime:hover{background:var(--lime-dark);box-shadow:var(--shadow-lime);}
.btn-purple{background:var(--purple);color:white;}
.btn-purple:hover{background:#6D28D9;box-shadow:var(--shadow-purple);}
.btn-red{background:var(--red);color:white;}
.btn-red:hover{background:#DC2626;}
.btn-outline{background:white;color:var(--text-700);border:1.5px solid var(--border-md);}
.btn-outline:hover{border-color:var(--text-900);background:var(--bg-hover);}
.btn-ghost{background:var(--bg-input);color:var(--text-700);}
.btn-ghost:hover{background:var(--text-100);}
.btn-orange{background:var(--orange);color:white;}
.btn-orange:hover{background:#D97706;}
.btn-green{background:var(--green);color:white;}

.btn-sm{padding:7px 14px;font-size:13px;}
.btn-xs{padding:5px 10px;font-size:12px;}
.btn-lg{padding:13px 26px;font-size:15px;}
.btn-icon{padding:9px;border-radius:var(--r-md);}

/* ── Cards ── */
.card{background:var(--bg-card);border-radius:var(--r-xl);box-shadow:var(--shadow-sm);overflow:hidden;transition:box-shadow var(--t-base) var(--ease);}
.card-hover:hover{box-shadow:var(--shadow-md);cursor:pointer;}
.card-border{box-shadow:none;border:1.5px solid var(--border);}

/* ── Inputs ── */
.input-group{display:flex;flex-direction:column;gap:var(--s2);}
.input-label{font-family:var(--font-ui);font-size:11px;font-weight:700;color:var(--text-500);text-transform:uppercase;letter-spacing:0.06em;}
.input-field{width:100%;padding:11px 14px;background:var(--bg-input);border:1.5px solid var(--border);border-radius:var(--r-md);color:var(--text-900);font-size:15px;font-family:var(--font-body);transition:all var(--t-fast);outline:none;}
.input-field:focus{border-color:var(--purple);background:white;box-shadow:0 0 0 3px rgba(124,58,237,0.1);}
.input-field::placeholder{color:var(--text-400);}
.input-field.error{border-color:var(--red);}
.input-wrapper{position:relative;}
.input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-400);pointer-events:none;font-size:15px;}
.input-field.has-icon{padding-left:38px;}
select.input-field{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='%236B7280' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:34px;}

/* ── Badges ── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--r-full);font-family:var(--font-ui);font-size:11px;font-weight:700;letter-spacing:0.03em;}
.badge-lime{background:var(--lime);color:#3A5000;}
.badge-red{background:var(--red-soft);color:var(--red);}
.badge-blue{background:var(--blue-soft);color:var(--blue);}
.badge-purple{background:var(--purple-soft);color:var(--purple);}
.badge-orange{background:var(--orange-soft);color:var(--orange);}
.badge-green{background:var(--green-soft);color:var(--green);}
.badge-dark{background:var(--text-900);color:white;}
.badge-muted{background:var(--bg-input);color:var(--text-500);}
.badge-live{background:var(--red);color:white;animation:live-pulse 1.8s infinite;}
.badge-live::before{content:'';width:6px;height:6px;background:white;border-radius:50%;}
.badge-live-purple{background:var(--purple);color:white;animation:live-pulse 1.8s infinite;}
.badge-live-purple::before{content:'';width:6px;height:6px;background:white;border-radius:50%;}
@keyframes live-pulse{0%,100%{opacity:1}50%{opacity:0.75}}

/* ── Avatar ── */
.avatar{border-radius:var(--r-full);object-fit:cover;flex-shrink:0;background:var(--bg-input);display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-ui);font-weight:700;color:var(--text-500);overflow:hidden;}
.avatar-xs{width:28px;height:28px;font-size:11px;}
.avatar-sm{width:36px;height:36px;font-size:13px;}
.avatar-md{width:44px;height:44px;font-size:16px;}
.avatar-lg{width:56px;height:56px;font-size:20px;}
.avatar-xl{width:80px;height:80px;font-size:28px;}
.avatar-2xl{width:104px;height:104px;font-size:36px;}

/* ── Skeleton ── */
.skeleton{background:linear-gradient(90deg,#F3F4F6 25%,#E5E7EB 50%,#F3F4F6 75%);background-size:200% 100%;animation:shimmer 1.6s infinite;border-radius:var(--r-md);}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ── Toast ── */
.toast-container{position:fixed;bottom:82px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:var(--s2);pointer-events:none;}
@media(min-width:1024px){.toast-container{bottom:20px;}}
.toast{display:flex;align-items:center;gap:var(--s3);padding:12px 16px;max-width:320px;background:var(--text-900);color:white;border-radius:var(--r-lg);font-size:14px;font-weight:500;font-family:var(--font-ui);box-shadow:var(--shadow-lg);pointer-events:all;animation:toast-in 0.3s var(--ease-spring) forwards;}
.toast.success{background:#064E3B;border-left:3px solid var(--green);}
.toast.error{background:#7F1D1D;border-left:3px solid var(--red);}
.toast.info{background:var(--text-900);border-left:3px solid var(--blue);}
.toast.warning{background:#78350F;border-left:3px solid var(--orange);}
.toast.exit{animation:toast-out 0.2s var(--ease) forwards;}
@keyframes toast-in{from{opacity:0;transform:translateX(20px) scale(0.94)}to{opacity:1;transform:none}}
@keyframes toast-out{from{opacity:1}to{opacity:0;transform:translateX(20px)}}

/* ── Modal ── */
.modal-backdrop{position:fixed;inset:0;background:rgba(17,24,39,0.5);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:flex-end;justify-content:center;animation:backdrop-in 0.2s forwards;}
@media(min-width:640px){.modal-backdrop{align-items:center;}}
@keyframes backdrop-in{from{opacity:0}to{opacity:1}}
.modal{width:100%;max-width:520px;max-height:92vh;background:white;border-radius:20px 20px 0 0;overflow:hidden;display:flex;flex-direction:column;animation:modal-in 0.3s var(--ease-spring) forwards;box-shadow:var(--shadow-xl);}
@media(min-width:640px){.modal{border-radius:20px;}}
@keyframes modal-in{from{transform:translateY(28px);opacity:0}to{transform:none;opacity:1}}
.modal-handle{width:36px;height:4px;background:var(--text-300);border-radius:99px;margin:10px auto 0;flex-shrink:0;}
@media(min-width:640px){.modal-handle{display:none;}}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--s4) var(--s6);border-bottom:1px solid var(--border);flex-shrink:0;}
.modal-title{font-family:var(--font-ui);font-size:17px;font-weight:700;}
.modal-close{width:30px;height:30px;background:var(--bg-input);border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;color:var(--text-500);cursor:pointer;transition:all var(--t-fast);border:none;font-family:inherit;font-size:16px;}
.modal-close:hover{background:var(--text-100);color:var(--text-900);}
.modal-body{padding:var(--s5) var(--s6);overflow-y:auto;flex:1;}
.modal-footer{padding:var(--s4) var(--s6);border-top:1px solid var(--border);display:flex;gap:var(--s3);justify-content:flex-end;flex-shrink:0;}

/* ── Tabs (pill style like screenshots) ── */
.tab-bar{display:flex;gap:var(--s2);background:var(--bg-input);padding:4px;border-radius:var(--r-full);overflow-x:auto;scrollbar-width:none;}
.tab-bar::-webkit-scrollbar{display:none;}
.tab-pill{flex-shrink:0;padding:8px 18px;border-radius:var(--r-full);font-family:var(--font-ui);font-size:13px;font-weight:600;color:var(--text-500);cursor:pointer;transition:all var(--t-base) var(--ease);display:flex;align-items:center;gap:6px;}
.tab-pill:hover{color:var(--text-900);}
.tab-pill.active{background:var(--text-900);color:white;box-shadow:var(--shadow-sm);}

/* ── Dropdown ── */
.dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:white;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border);z-index:500;overflow:hidden;animation:dd-in 0.15s var(--ease) forwards;}
@keyframes dd-in{from{opacity:0;transform:translateY(-6px) scale(0.97)}to{opacity:1;transform:none}}
.dropdown-item{display:flex;align-items:center;gap:var(--s3);padding:10px 14px;font-size:14px;font-family:var(--font-ui);color:var(--text-700);cursor:pointer;transition:background var(--t-fast);}
.dropdown-item:hover{background:var(--bg-hover);color:var(--text-900);}
.dropdown-item.danger{color:var(--red);}
.dropdown-divider{height:1px;background:var(--border);}

/* ── Animations ── */
@keyframes fade-in{from{opacity:0}to{opacity:1}}
@keyframes slide-up{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
@keyframes scale-in{from{opacity:0;transform:scale(0.96)}to{opacity:1;transform:none}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

.anim-fade{animation:fade-in var(--t-base) var(--ease) both;}
.anim-up{animation:slide-up var(--t-base) var(--ease) both;}

/* Stagger */
.stagger>*:nth-child(1){animation-delay:.04s}
.stagger>*:nth-child(2){animation-delay:.08s}
.stagger>*:nth-child(3){animation-delay:.12s}
.stagger>*:nth-child(4){animation-delay:.16s}
.stagger>*:nth-child(5){animation-delay:.20s}
.stagger>*:nth-child(6){animation-delay:.24s}

/* ── Spinner ── */
.spinner{width:18px;height:18px;border:2px solid rgba(0,0,0,0.12);border-top-color:currentColor;border-radius:50%;animation:spin 0.65s linear infinite;}

/* ── Empty State ── */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--s4);padding:var(--s16) var(--s6);text-align:center;}
.empty-icon{font-size:44px;animation:float 3s ease-in-out infinite;}
.empty-title{font-family:var(--font-ui);font-size:17px;font-weight:700;color:var(--text-700);}
.empty-desc{font-size:14px;color:var(--text-500);max-width:240px;line-height:1.5;}

/* ── Progress ── */
.progress{height:5px;background:var(--bg-input);border-radius:99px;overflow:hidden;}
.progress-fill{height:100%;background:var(--lime-dark);border-radius:99px;transition:width 0.6s var(--ease);}

/* ── Section header ── */
.section-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--s4);}
.section-title{font-family:var(--font-ui);font-size:16px;font-weight:700;color:var(--text-900);}
.section-link{font-family:var(--font-ui);font-size:13px;font-weight:600;color:var(--text-500);cursor:pointer;transition:color var(--t-fast);}
.section-link:hover{color:var(--text-900);}

/* ── Util ── */
.flex{display:flex;} .flex-col{flex-direction:column;} .items-c{align-items:center;} .justify-b{justify-content:space-between;}
.gap-2{gap:var(--s2);} .gap-3{gap:var(--s3);} .gap-4{gap:var(--s4);}
.w-full{width:100%;} .truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;} .relative{position:relative;}
:focus-visible{outline:2px solid var(--purple);outline-offset:2px;border-radius:4px;}
