/* Scout Pro — Baseball Evaluation System */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700&family=Source+Sans+3:wght@400;600&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --gold: #e8d9a0;
  --gold-dark: #c8a84b;
  --gold-dim: rgba(232,217,160,0.15);
  --gold-border: rgba(232,217,160,0.35);
  --bg: #0a0f1a;
  --bg2: #0d1420;
  --bg3: #111827;
  --border: #1e2535;
  --border2: #2a2f3e;
  --text: #e8e0d0;
  --muted: #8a7a60;
  --dim: #4a5568;
  --green: #50b478;
  --orange: #e08030;
  --red: #e05555;
  --blue: #6482c8;
  --radius: 10px;
}

html, body { height: 100%; }
body { background: var(--bg); color: var(--text); font-family: 'Source Sans 3', sans-serif; font-size: 15px; line-height: 1.5; }

/* ── Layout ─────────────────────────────────────── */
#app { min-height: 100vh; display: flex; flex-direction: column; }
.main-layout { display: flex; flex: 1; min-height: calc(100vh - 57px); }
.sidebar { width: 200px; background: var(--bg2); border-right: 1px solid var(--border); padding: 16px; flex-shrink: 0; }
.content { flex: 1; padding: 28px; overflow-y: auto; }

/* ── Header ─────────────────────────────────────── */
.header { background: #060b14; border-bottom: 2px solid var(--gold); padding: 12px 24px; display: flex; align-items: center; justify-content: space-between; }
.header-logo { display: flex; align-items: center; gap: 12px; }
.header-title { color: var(--gold); font-family: 'Playfair Display', serif; font-size: 18px; letter-spacing: 0.1em; }
.badge-admin { background: var(--gold); color: #000; font-size: 10px; font-weight: 700; padding: 2px 8px; border-radius: 4px; letter-spacing: 0.1em; margin-left: 10px; }
.header-right { display: flex; align-items: center; gap: 16px; }
.welcome-text { color: var(--muted); font-size: 14px; }
.welcome-text span { color: var(--text); }

/* ── Nav ─────────────────────────────────────────── */
.nav-btn { width: 100%; text-align: left; padding: 10px 14px; margin-bottom: 4px; background: none; border: 1px solid transparent; color: var(--dim); border-radius: 8px; cursor: pointer; display: flex; align-items: center; gap: 10px; font-size: 14px; font-family: inherit; transition: all 0.15s; }
.nav-btn:hover { color: var(--muted); background: rgba(255,255,255,0.03); }
.nav-btn.active { background: var(--gold-dim); border-color: var(--gold-border); color: var(--gold); }

/* ── Login ───────────────────────────────────────── */
.login-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; background: var(--bg); }
.login-box { width: 380px; text-align: center; }
.login-diamond { width: 80px; height: 80px; background: linear-gradient(135deg, var(--gold), var(--gold-dark)); transform: rotate(45deg); margin: 0 auto 0; box-shadow: 0 0 40px rgba(232,217,160,0.3); display: flex; align-items: center; justify-content: center; }
.login-diamond span { transform: rotate(-45deg); font-size: 32px; }
.login-title { color: var(--gold); font-family: 'Playfair Display', serif; font-size: 28px; margin: 20px 0 4px; letter-spacing: 0.1em; }
.login-sub { color: var(--muted); font-size: 13px; letter-spacing: 0.15em; text-transform: uppercase; margin-bottom: 28px; }
.login-card { background: var(--bg3); border: 1px solid var(--border2); border-radius: 12px; padding: 32px; }
.login-hint { color: var(--dim); font-size: 12px; margin-top: 14px; }

/* ── Forms ───────────────────────────────────────── */
label.field-label { display: block; color: var(--muted); font-size: 12px; margin-bottom: 6px; letter-spacing: 0.08em; text-transform: uppercase; }
input, select, textarea { background: var(--bg2); border: 1px solid var(--border2); color: var(--text); padding: 8px 12px; border-radius: 8px; font-size: 14px; font-family: inherit; outline: none; width: 100%; display: block; transition: border-color 0.15s; }
input:focus, select:focus, textarea:focus { border-color: var(--gold); }
input::placeholder, textarea::placeholder { color: var(--dim); }
select option { background: var(--bg2); }

.form-row { display: flex; gap: 10px; flex-wrap: wrap; align-items: flex-end; }
.pos-checks { display: flex; gap: 14px; align-items: center; padding: 9px 0; flex-shrink: 0; }
.pos-checks label { display: flex; align-items: center; gap: 5px; color: var(--text); font-size: 14px; cursor: pointer; white-space: nowrap; }
.pos-checks input[type="checkbox"] { width: 16px; height: 16px; cursor: pointer; accent-color: var(--gold); flex-shrink: 0; }
.form-row .grow { flex: 1 1 160px; }
.form-row .shrink { flex: 0 1 90px; }
.form-row .med { flex: 1 1 130px; }
.field-group { margin-bottom: 14px; }

/* ── Buttons ─────────────────────────────────────── */
.btn { display: inline-flex; align-items: center; gap: 6px; padding: 9px 18px; border-radius: 8px; font-size: 14px; font-weight: 600; cursor: pointer; border: none; font-family: inherit; transition: opacity 0.15s; white-space: nowrap; }
.btn:disabled { opacity: 0.4; cursor: not-allowed; }
.btn-primary { background: linear-gradient(135deg, var(--gold), var(--gold-dark)); color: #000; }
.btn-primary:hover:not(:disabled) { opacity: 0.85; }
.btn-secondary { background: none; color: var(--muted); border: 1px solid var(--border2); }
.btn-secondary:hover { border-color: var(--muted); }
.btn-danger { background: none; color: var(--red); border: none; padding: 4px 8px; border-radius: 4px; cursor: pointer; opacity: 0.7; font-size: 13px; font-family: inherit; }
.btn-danger:hover { opacity: 1; }
.btn-edit { background: none; color: var(--gold); border: 1px solid var(--gold); padding: 3px 8px; border-radius: 4px; cursor: pointer; opacity: 0.7; font-size: 12px; font-family: inherit; margin-right: 4px; }
.btn-edit:hover { opacity: 1; }
.btn-logout { background: none; border: 1px solid var(--border2); color: var(--muted); padding: 6px 14px; border-radius: 6px; cursor: pointer; font-size: 13px; font-family: inherit; display: flex; align-items: center; gap: 6px; }
.btn-full { width: 100%; justify-content: center; }
.btn-sm { padding: 6px 12px; font-size: 13px; }

/* ── Filter pills ────────────────────────────────── */
.filter-bar { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 16px; }
.filter-pill { background: none; border: 1px solid var(--border2); color: var(--dim); padding: 5px 14px; border-radius: 20px; cursor: pointer; font-size: 13px; font-family: inherit; transition: all 0.15s; }
.filter-pill.active { background: var(--gold-dim); border-color: var(--gold-border); color: var(--gold); }

/* ── Cards ───────────────────────────────────────── */
.card { background: var(--bg3); border: 1px solid var(--border); border-radius: var(--radius); }
.card-pad { padding: 20px; }
.card-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 12px; }
.div-card { background: var(--bg3); border: 1px solid var(--border); border-radius: var(--radius); padding: 12px 16px; display: flex; align-items: center; gap: 12px; }
.div-card .diamond { color: var(--gold); font-size: 18px; }

/* ── Tables ──────────────────────────────────────── */
.table-wrap { background: var(--bg3); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; overflow-x: auto; }
table { width: 100%; border-collapse: collapse; min-width: 500px; }
thead { background: var(--bg2); }
th { padding: 10px 16px; text-align: left; color: var(--dim); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; font-weight: 600; }
th.center, td.center { text-align: center; }
td { padding: 10px 16px; font-size: 14px; color: #c8c0b0; border-bottom: 1px solid #1a2030; }
tr:last-child td { border-bottom: none; }
tr:nth-child(even) td { background: rgba(255,255,255,0.01); }
.empty-row td { padding: 24px; text-align: center; color: var(--dim); }

/* ── Position badges ─────────────────────────────── */
.pos-badge { padding: 2px 10px; border-radius: 20px; font-size: 12px; }
.pos-Pitcher        { background: rgba(232,217,160,0.15); color: var(--gold); }
.pos-Catcher        { background: rgba(80,180,120,0.15);  color: var(--green); }
.pos-Player         { background: rgba(100,130,200,0.15); color: var(--blue); }
.pos-PitcherCatcher { background: rgba(200,130,200,0.15); color: #c878e0; }

/* ── Coach cards ─────────────────────────────────── */
.coach-card { background: var(--bg3); border: 1px solid var(--border); border-radius: var(--radius); padding: 12px 16px; display: flex; align-items: center; gap: 12px; }
.coach-avatar { width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.coach-avatar.admin { background: rgba(232,217,160,0.2); color: var(--gold); }
.coach-avatar.coach { background: rgba(80,120,200,0.2); color: var(--blue); }

/* ── Session / Eval ──────────────────────────────── */
.session-banner { background: rgba(232,217,160,0.1); border: 1px solid var(--gold-border); border-radius: var(--radius); padding: 18px 20px; margin-bottom: 20px; }
.session-banner p { margin: 0; }
.session-banner .session-title { color: var(--gold); font-weight: 600; margin-bottom: 6px; }
.session-banner .session-sub { color: var(--muted); font-size: 13px; }

.skill-progress { display: flex; gap: 8px; margin-bottom: 24px; }
.skill-step { flex: 1; text-align: center; padding: 8px 4px; border-radius: 8px; font-size: 12px; border: 1px solid transparent; transition: all 0.2s; }
.skill-step.done     { background: rgba(80,180,120,0.2); color: var(--green); }
.skill-step.current  { background: var(--gold-dim); border-color: var(--gold-border); color: var(--gold); }
.skill-step.upcoming { background: rgba(255,255,255,0.02); color: var(--dim); }

.player-card { background: var(--bg3); border: 2px solid var(--gold-border); border-radius: 14px; padding: 28px; text-align: center; margin-bottom: 24px; }
.player-emoji { font-size: 48px; margin-bottom: 12px; }
.player-name  { font-family: 'Playfair Display', serif; font-size: 26px; margin-bottom: 6px; }
.player-sub   { color: var(--muted); font-size: 14px; margin-bottom: 4px; }
.player-count { color: var(--dim); font-size: 12px; }
.skill-label  { display: inline-block; background: var(--gold-dim); border: 1px solid var(--gold-border); border-radius: 8px; padding: 8px 20px; margin-top: 14px; color: var(--gold); font-weight: 700; font-size: 15px; letter-spacing: 0.1em; }

.score-grid { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; margin-bottom: 20px; }
.score-btn { width: 48px; height: 48px; border-radius: 8px; background: rgba(255,255,255,0.04); border: 1px solid var(--border2); color: var(--dim); font-size: 16px; font-weight: 600; cursor: pointer; transition: all 0.1s; font-family: inherit; }
.score-btn:hover { border-color: var(--muted); color: var(--text); }
.score-btn.selected-1,.score-btn.selected-2,.score-btn.selected-3  { background: var(--red); border-color: var(--red); color: #fff; }
.score-btn.selected-4,.score-btn.selected-5  { background: var(--orange); border-color: var(--orange); color: #fff; }
.score-btn.selected-6,.score-btn.selected-7  { background: var(--gold); border-color: var(--gold); color: #000; }
.score-btn.selected-8,.score-btn.selected-9,.score-btn.selected-10 { background: var(--green); border-color: var(--green); color: #fff; }

.submitted-box { background: var(--bg3); border: 1px solid var(--border); border-radius: 12px; padding: 28px; text-align: center; }
.submitted-icon { font-size: 36px; margin-bottom: 10px; }
.submitted-ok { color: var(--green); font-size: 16px; font-weight: 600; margin-bottom: 6px; }
.submitted-next { color: var(--dim); font-size: 13px; margin-bottom: 20px; }

/* ── Skill progress clickable ────────────────────── */
.skill-step.clickable { cursor: pointer; }
.skill-step.clickable:hover { opacity: 0.8; transform: translateY(-1px); }

/* ── Skill tabs (review mode) ────────────────────── */
.skill-tabs { display: flex; gap: 6px; margin-bottom: 16px; overflow-x: auto; padding-bottom: 2px; }
.skill-tab { flex: 1; min-width: 72px; padding: 8px 4px; border-radius: 8px; font-size: 12px; font-weight: 600; font-family: inherit; cursor: pointer; border: 1px solid var(--border2); background: none; color: var(--dim); white-space: nowrap; text-align: center; transition: all 0.15s; }
.skill-tab.active { background: var(--gold-dim); border-color: var(--gold-border); color: var(--gold); }
.skill-tab.disabled { opacity: 0.3; cursor: default; }
.skill-tab:not(.disabled):not(.active):hover { border-color: var(--muted); color: var(--muted); }

/* ── Review player list ──────────────────────────── */
.review-list { display: flex; flex-direction: column; gap: 2px; }
.review-row { display: flex; align-items: center; gap: 12px; padding: 12px 14px; background: var(--bg3); border: 1px solid var(--border); border-radius: 8px; cursor: pointer; transition: border-color 0.15s; }
.review-row:hover { border-color: var(--border2); background: #131c2e; }
.review-emoji { font-size: 18px; flex-shrink: 0; }
.review-name { flex: 1; font-size: 14px; display: flex; flex-direction: column; }
.review-pos { font-size: 11px; color: var(--dim); }
.review-score { font-size: 18px; font-weight: 700; min-width: 28px; text-align: right; flex-shrink: 0; }
.review-chevron { color: var(--dim); font-size: 20px; flex-shrink: 0; margin-left: 4px; }

/* ── Player navigation arrows ────────────────────── */
.player-nav { display: flex; align-items: center; justify-content: center; gap: 16px; margin: 10px 0 2px; }
.player-nav-btn { background: none; border: 1px solid var(--border2); color: var(--muted); width: 36px; height: 36px; border-radius: 50%; font-size: 22px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 0.15s; font-family: inherit; padding: 0; line-height: 1; }
.player-nav-btn:hover:not(:disabled) { border-color: var(--gold); color: var(--gold); }
.player-nav-btn:disabled { opacity: 0.25; cursor: default; }
.player-nav-info { color: var(--dim); font-size: 13px; min-width: 80px; text-align: center; }
.player-nav-scored { color: var(--green); font-size: 11px; }

/* ── Skill done (coach waiting screen) ───────────── */
.skill-done-card { background: var(--bg3); border: 1px solid var(--border); border-radius: 14px; padding: 40px 28px; text-align: center; margin-top: 8px; }
.skill-done-icon { font-size: 52px; margin-bottom: 16px; }
.skill-done-title { font-family: 'Playfair Display', serif; color: var(--green); font-size: 24px; margin-bottom: 10px; }
.skill-done-sub { color: var(--muted); font-size: 15px; margin-bottom: 20px; }
.skill-done-next { color: var(--dim); font-size: 14px; line-height: 1.7; margin-bottom: 24px; }
.skill-done-next strong { color: var(--gold); }
.skill-done-spinner { display: flex; justify-content: center; }

.no-session { text-align: center; padding-top: 80px; }
.no-session .big-icon { font-size: 52px; margin-bottom: 16px; }

/* ── Results table extras ────────────────────────── */
.score-val { font-weight: 600; }
.score-high   { color: var(--green); }
.score-mid    { color: var(--gold); }
.score-low    { color: var(--orange); }
.score-poor   { color: var(--red); }
.score-none   { color: #2a3040; }
.rank-gold   { color: var(--gold); font-weight: 700; }
.rank-silver { color: #9ba3af; font-weight: 700; }
.rank-bronze { color: #b45309; font-weight: 700; }
.rank-plain  { color: var(--dim); }

/* ── Alerts ──────────────────────────────────────── */
.alert { padding: 10px 14px; border-radius: 8px; font-size: 13px; margin-bottom: 12px; }
.alert-error { background: rgba(224,85,85,0.12); border: 1px solid rgba(224,85,85,0.3); color: var(--red); }
.alert-success { background: rgba(80,180,120,0.12); border: 1px solid rgba(80,180,120,0.3); color: var(--green); }

/* ── Section title ───────────────────────────────── */
.section-title { font-family: 'Playfair Display', serif; color: var(--gold); font-size: 22px; margin-bottom: 20px; padding-bottom: 10px; border-bottom: 1px solid var(--gold-border); }

/* ── Misc ────────────────────────────────────────── */
.mt8  { margin-top: 8px; }
.mt12 { margin-top: 12px; }
.mt16 { margin-top: 16px; }
.mt20 { margin-top: 20px; }
.mb12 { margin-bottom: 12px; }
.mb16 { margin-bottom: 16px; }
.text-muted { color: var(--muted); }
.text-dim   { color: var(--dim); }
.text-sm    { font-size: 13px; }
.text-xs    { font-size: 11px; }
.mono       { font-family: monospace; }
.hidden     { display: none !important; }
.spinner    { display: inline-block; width: 16px; height: 16px; border: 2px solid var(--border2); border-top-color: var(--gold); border-radius: 50%; animation: spin 0.6s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ── Import textarea ─────────────────────────────── */
.import-box { background: var(--bg3); border: 1px solid #2a3f6e; border-radius: var(--radius); padding: 20px; margin-bottom: 20px; }
.code-hint { color: var(--gold); font-family: monospace; font-size: 13px; }

/* ── MOBILE ──────────────────────────────────────── */
@media (max-width: 768px) {

  /* Bottom tab bar */
  .main-layout { flex-direction: column; min-height: calc(100vh - 50px); }
  .sidebar {
    position: fixed; bottom: 0; left: 0; right: 0;
    width: 100%; height: 64px;
    flex-direction: row;
    padding: 0;
    border-right: none; border-top: 1px solid var(--border);
    z-index: 200;
    /* safe area for iPhone home bar */
    padding-bottom: env(safe-area-inset-bottom);
    background: var(--bg2);
  }
  .nav-btn {
    flex: 1; flex-direction: column;
    align-items: center; justify-content: center;
    gap: 3px; font-size: 10px; line-height: 1.2;
    padding: 6px 4px; margin: 0; border-radius: 0;
    border: none; border-top: 2px solid transparent;
    text-align: center; min-height: 64px;
  }
  .nav-btn span:first-child { font-size: 20px; line-height: 1; }
  .nav-btn.active {
    background: none;
    border-top: 2px solid var(--gold);
    color: var(--gold);
  }

  /* Content padding for tab bar */
  .content {
    padding: 16px 16px 84px;
  }

  /* Compact header */
  .header { padding: 10px 16px; }
  .header-title { font-size: 15px; }
  .badge-admin { font-size: 9px; padding: 1px 6px; margin-left: 6px; }
  .welcome-text { display: none; }
  .btn-logout { padding: 5px 10px; font-size: 12px; }

  /* Login */
  .login-wrap { align-items: flex-start; padding-top: 40px; }
  .login-box { width: 100%; padding: 0 20px; }
  .login-card { padding: 24px 20px; }
  .login-diamond { width: 64px; height: 64px; }
  .login-diamond span { font-size: 26px; }
  .login-title { font-size: 24px; }

  /* Section title */
  .section-title { font-size: 18px; margin-bottom: 14px; }

  /* Forms stack */
  .form-row { flex-direction: column; }
  .form-row .grow, .form-row .shrink, .form-row .med { flex: 1 1 auto; width: 100%; }

  /* Tables */
  td, th { padding: 8px 10px; font-size: 13px; }

  /* Cards */
  .card-grid { grid-template-columns: 1fr; }

  /* ── Evaluate: score grid 2×5 ─── */
  .score-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 8px;
    margin-bottom: 16px;
  }
  .score-btn {
    width: 100%; height: 58px;
    font-size: 20px; border-radius: 10px;
  }

  /* Player card */
  .player-card {
    padding: 20px 16px; margin-bottom: 16px;
    border-radius: 12px;
  }
  .player-emoji { font-size: 38px; margin-bottom: 8px; }
  .player-name  { font-size: 22px; }
  .player-sub   { font-size: 13px; }
  .skill-label  { padding: 6px 16px; font-size: 14px; margin-top: 10px; }

  /* Skill progress */
  .skill-progress { gap: 5px; margin-bottom: 14px; }
  .skill-step { font-size: 10px; padding: 7px 2px; }

  /* Next player / submit button — big thumb target */
  .btn-next-mobile {
    height: 60px !important;
    font-size: 17px !important;
    border-radius: 14px !important;
    letter-spacing: 0.03em;
  }

  /* Submitted box */
  .submitted-box { padding: 24px 16px; border-radius: 12px; }
  .submitted-icon { font-size: 40px; }
  .submitted-ok   { font-size: 18px; }

  /* Review list */
  .review-row { padding: 14px 12px; }
  .review-score { font-size: 20px; }
  .skill-tab { font-size: 11px; padding: 7px 2px; min-width: 60px; }

  /* Player nav arrows */
  .player-nav-btn { width: 44px; height: 44px; font-size: 26px; }

  /* No session */
  .no-session { padding-top: 48px; }

  /* Session banner */
  .session-banner { padding: 14px 16px; }
}

@media (max-width: 390px) {
  .score-btn { height: 52px; font-size: 18px; }
  .nav-btn   { font-size: 9px; }
  .nav-btn span:first-child { font-size: 18px; }
}
