/* ============================================================
   Pickle Pro — app.css
   Design tokens mirror the original React C{} object
   ============================================================ */

:root {
  --bg:         #0d0f16;
  --surface:    #13161f;
  --card:       #191c28;
  --card-hov:   #1e2232;
  --panel:      #1e2232;
  --border:     #252a3c;
  --border-hov: #363c56;
  --accent:     #ff6b2b;
  --accent-dim: #cc4d12;
  --accent-glow:rgba(255,107,43,.18);
  --blue:       #3b82f6;
  --blue-glow:  rgba(59,130,246,.18);
  --green:      #22c55e;
  --red:        #ef4444;
  --yellow:     #f59e0b;
  --purple:     #a855f7;
  --teal:       #14b8a6;
  --text:       #f1f3f9;
  --text-mid:   #9aa3b8;
  --muted:      #4b5268;
  --gold:       #f59e0b;
  --silver:     #94a3b8;
  --bronze:     #b87333;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--text);font-family:'Nunito',sans-serif;min-height:100vh}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:var(--surface)}
::-webkit-scrollbar-thumb{background:var(--muted);border-radius:4px}

a{color:var(--accent);text-decoration:none}

/* ── Typography ── */
.rajdhani{font-family:'Rajdhani',sans-serif}
.accent{color:var(--accent)}
.muted{color:var(--muted)}
.text-mid{color:var(--text-mid)}

/* ── Inputs ── */
input,select,textarea{
  background:var(--panel);border:1.5px solid var(--border);color:var(--text);
  font-family:'Nunito',sans-serif;font-size:14px;padding:10px 14px;
  border-radius:12px;outline:none;width:100%;transition:border-color .18s,box-shadow .18s;
}
input:focus,select:focus,textarea:focus{
  border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);
}
select option{background:var(--card);color:var(--text)}
textarea{resize:vertical}

/* ── Buttons ── */
button{cursor:pointer;font-family:'Nunito',sans-serif;font-weight:700;border:none;border-radius:12px;transition:all .18s}
.btn{display:inline-flex;align-items:center;gap:6px;font-weight:700;border-radius:12px;cursor:pointer;transition:all .18s;border:none}
.btn-primary  {background:var(--accent);color:#fff;padding:10px 22px;font-size:13px}
.btn-primary:hover{background:#ff7d42;transform:translateY(-1px);box-shadow:0 4px 20px var(--accent-glow)}
.btn-secondary{background:transparent;color:var(--accent);border:1.5px solid rgba(255,107,43,.4);padding:10px 22px;font-size:13px}
.btn-secondary:hover{background:var(--accent-glow)}
.btn-blue     {background:var(--blue);color:#fff;padding:10px 22px;font-size:13px}
.btn-blue:hover{background:#5b9ef9;transform:translateY(-1px);box-shadow:0 4px 20px var(--blue-glow)}
.btn-ghost    {background:transparent;color:var(--text-mid);border:1.5px solid var(--border);padding:10px 22px;font-size:13px}
.btn-ghost:hover{background:var(--panel)}
.btn-danger   {background:rgba(239,68,68,.1);color:var(--red);border:1.5px solid rgba(239,68,68,.21);padding:6px 14px;font-size:12px}
.btn-danger:hover{background:rgba(239,68,68,.16)}
.btn-green    {background:rgba(34,197,94,.1);color:var(--green);border:1.5px solid rgba(34,197,94,.21);padding:6px 14px;font-size:12px}
.btn-green:hover{background:rgba(34,197,94,.16)}
.btn-purple   {background:rgba(168,85,247,.1);color:var(--purple);border:1.5px solid rgba(168,85,247,.21);padding:6px 14px;font-size:12px}
.btn-sm{padding:6px 14px!important;font-size:12px!important}
.btn-lg{padding:13px 32px!important;font-size:14px!important}
.btn-xl{padding:16px 40px!important;font-size:16px!important}
.btn-full{width:100%}
button:disabled,.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}

/* ── Cards ── */
.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:20px;transition:all .2s}
.card-hover{cursor:pointer}
.card-hover:hover{background:var(--card-hov);border-color:var(--border-hov);transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,.4)}

/* ── Tags / Pills ── */
.tag{display:inline-block;padding:3px 11px;border-radius:20px;font-size:11px;font-weight:700;
  letter-spacing:.5px;text-transform:uppercase;white-space:nowrap}

/* ── Layout ── */
header#nav{background:var(--surface);border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:200;backdrop-filter:blur(10px)}
.nav-inner{max-width:1160px;margin:0 auto;padding:0 24px;height:54px;display:flex;align-items:center;gap:12px}
.logo{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:20px;letter-spacing:2px;
  color:var(--accent);background:none;border:none;cursor:pointer;white-space:nowrap}

main#app{min-height:calc(100vh - 54px - 48px)}
.screen{padding-bottom:80px}

footer{background:var(--surface);border-top:1px solid var(--border);
  padding:14px 24px;text-align:center;font-size:12px;color:var(--muted);font-weight:600}

/* ── Modal ── */
#modalOverlay{position:fixed;inset:0;background:rgba(0,0,0,.78);
  display:flex;align-items:center;justify-content:center;z-index:999;padding:16px;backdrop-filter:blur(6px)}
.modal-box{background:var(--surface);border:1px solid var(--border);border-radius:20px;
  padding:28px;width:100%;max-width:520px;max-height:93vh;overflow-y:auto;animation:scaleIn .2s ease both}
.modal-box.wide{max-width:700px}
.modal-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:22px}
.modal-title{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:24px;letter-spacing:.5px}
.modal-sub{font-size:12px;color:var(--muted);margin-top:3px}
.modal-close{background:none;border:none;color:var(--muted);font-size:20px;cursor:pointer;padding:2px 8px;border-radius:8px}
.modal-close:hover{color:var(--text)}

/* ── Form fields ── */
.fld{margin-bottom:14px}
.fld-label{font-size:10px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;color:var(--muted);margin-bottom:6px}

/* ── Pill tabs ── */
.pill-tabs{display:flex;background:var(--panel);border-radius:30px;padding:4px;gap:2px;width:fit-content;flex-wrap:wrap}
.pill-tab{padding:7px 18px;border-radius:26px;font-size:12px;font-weight:700;cursor:pointer;
  background:transparent;color:var(--text-mid);border:none;transition:all .15s}
.pill-tab.active{background:var(--accent);color:#fff}

/* ── FAB ── */
#fab{position:fixed;bottom:32px;right:32px;z-index:300;width:60px;height:60px;
  border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-dim));
  color:#fff;font-size:28px;font-weight:700;border:none;cursor:pointer;
  box-shadow:0 6px 28px var(--accent-glow),0 2px 8px rgba(0,0,0,.4);
  display:flex;align-items:center;justify-content:center;transition:transform .18s,box-shadow .18s}
#fab:hover{transform:scale(1.12);box-shadow:0 10px 36px var(--accent-glow),0 4px 12px rgba(0,0,0,.5)}

/* ── Hero ── */
.hero{background:linear-gradient(160deg,var(--surface),var(--card));
  border-bottom:1px solid var(--border);padding:32px 20px 28px;position:relative;overflow:hidden}
.hero-inner{max-width:1160px;margin:0 auto;position:relative}
.hero h1{font-family:'Rajdhani',sans-serif;font-weight:700;
  font-size:clamp(38px,8vw,72px);line-height:.9;letter-spacing:1px;margin-bottom:14px}

/* ── Stat grid ── */
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px;max-width:480px}
.stat-card{background:rgba(13,15,22,.88);border:1px solid var(--border);border-radius:16px;
  padding:18px 20px 16px;position:relative;overflow:hidden;backdrop-filter:blur(8px)}
.stat-val{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:52px;line-height:1}
.stat-lbl{font-size:11px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;
  color:var(--muted);margin-bottom:10px;display:flex;align-items:center;gap:5px}

/* ── Tournament cards ── */
.page-inner{max-width:1160px;margin:0 auto;padding:0 24px}
.t-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;margin-top:16px}
.t-card-status{font-size:10px;font-weight:800;letter-spacing:1px;text-transform:uppercase;margin-bottom:10px}
.t-card-name{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:22px;letter-spacing:.5px;margin-bottom:6px}
.filter-bar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;
  background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:14px 18px;margin-bottom:20px}

/* ── Tournament screen ── */
.t-header{background:var(--surface);border-bottom:1px solid var(--border);padding:16px 24px}
.t-header-inner{max-width:1100px;margin:0 auto}
.tab-content{max-width:1100px;margin:24px auto;padding:0 24px 48px}

/* ── Standings table ── */
.standings-table{width:100%;border-collapse:collapse;font-size:13px}
.standings-table th{padding:13px 14px;font-size:11px;color:var(--muted);font-weight:800;
  letter-spacing:.6px;text-transform:uppercase;white-space:nowrap;border-bottom:2px solid var(--border)}
.standings-table td{padding:12px 14px;border-bottom:1px solid var(--border)}

/* ── Scorer ── */
.score-num{font-family:'Rajdhani',sans-serif;font-weight:700;line-height:1;font-size:76px}
.score-side{flex:1;text-align:center;padding:16px 8px 12px;border-radius:16px;
  border:2px solid transparent;position:relative;transition:all .2s}
.score-side.serving{background:rgba(255,107,43,.06);border-color:rgba(255,107,43,.4)}

/* ── Match card ── */
.match-score{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:30px;min-width:64px;text-align:center}

/* ── Leaderboard ── */
.lb-rank{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:clamp(36px,6vw,54px);letter-spacing:1px;line-height:.95}

/* ── Animations ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes scaleIn{from{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.fade{animation:fadeUp .25s ease both}
.scale{animation:scaleIn .2s ease both}
.pulse{animation:pulse 1.5s infinite}

/* ── Profile dropdown ── */
.profile-dropdown{position:relative}
.profile-pill{display:flex;align-items:center;gap:10px;background:var(--panel);
  border:1px solid var(--border);border-radius:30px;padding:5px 12px 5px 6px;cursor:pointer;transition:all .18s}
.profile-pill:hover{border-color:rgba(255,107,43,.3)}
.profile-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--surface);
  border:1px solid var(--border);border-radius:16px;padding:8px;min-width:220px;z-index:500;
  box-shadow:0 16px 48px rgba(0,0,0,.55);animation:scaleIn .2s ease both}
.profile-menu-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:10px;
  cursor:pointer;font-size:13px;font-weight:700;color:var(--text-mid);transition:background .15s;border:none;
  background:transparent;width:100%;text-align:left}
.profile-menu-item:hover{background:var(--card-hov)}

/* ── Responsive ── */
@media(max-width:600px){
  .stat-grid{grid-template-columns:1fr 1fr}
  .modal-box{padding:18px}
  .tab-content{padding:0 14px 48px}
  .page-inner{padding:0 14px}
}
