/* --- Theme & base --- */
* { box-sizing: border-box; }
:root{
  --bg-1: #f6f9ff;
  --bg-2: #eef4ff;
  --primary: #0b66c3;
  --accent: #08304d;
  --muted: #6b7b8b;
  --card-bg: #ffffff;
  --glass: rgba(255,255,255,0.6);
  --success: #2eb872;
  --danger: #e05353;
}
body{
  margin:0; font-family: Inter, system-ui, -apple-system, 'Segoe UI', Roboto, 'Noto Sans KR', 'Malgun Gothic', Arial, sans-serif;
  background: linear-gradient(180deg,var(--bg-1) 0%, var(--bg-2) 100%);
  color: var(--accent);
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}

/* --- Header --- */
header{
  position:fixed; left:0; right:0; top:0; z-index:120;
  display:flex; align-items:center; justify-content:center;
  padding:14px 18px; background: linear-gradient(90deg,var(--primary), #3a8be0);
  color:#fff; box-shadow:0 6px 20px rgba(11,35,64,0.08);
}
header h1{ margin:0; font-size:18px; font-weight:700; letter-spacing:0.2px; }

/* --- Layout --- */
.scoreboard-container{ padding:96px 16px 40px; max-width:1280px; margin:0 auto; }
.scoreboard-grid{ display:grid; gap:20px; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }

/* --- Team cards --- */
.team-card{
  background:var(--card-bg); border-radius:12px; padding:18px; text-align:center;
  position: relative; /* ensure ::before is positioned relative to each card */
  box-shadow: 0 8px 26px rgba(6,30,60,0.06); border:1px solid rgba(11,35,64,0.04);
  display:flex; flex-direction:column; align-items:center; gap:8px;
}
.team-card h2{ margin:0; font-size:15px; font-weight:700; color:var(--accent); }
.team-card .score{ display:flex; align-items:baseline; gap:10px; color:var(--muted); }
.team-card .score-number{ font-size:3rem; font-weight:800; color:var(--primary); }

/* colorful accent bar */
.team-card::before{ content:''; position:absolute; left:0; right:0; height:12px; top:-6px; border-radius:12px 12px 0 0; z-index: -1;}
.scoreboard-grid{ position:relative; }
.scoreboard-grid .team-card:nth-child(1)::before{ background:#0b66c3; }
.scoreboard-grid .team-card:nth-child(2)::before{ background:#ff7a59; }
.scoreboard-grid .team-card:nth-child(3)::before{ background:#2eb872; }
.scoreboard-grid .team-card:nth-child(4)::before{ background:#9b59b6; }
.scoreboard-grid .team-card:nth-child(5)::before{ background:#f1c40f; }
.scoreboard-grid .team-card:nth-child(6)::before{ background:#e67e22; }
.scoreboard-grid .team-card:nth-child(7)::before{ background:#1abc9c; }
.scoreboard-grid .team-card:nth-child(8)::before{ background:#34495e; }

/* --- Buttons & form controls --- */
.pm-btn{
  background:var(--primary); color:#fff; border:0; padding:8px 12px; border-radius:8px; cursor:pointer;
  box-shadow: 0 6px 14px rgba(11,35,64,0.08); font-weight:600;
}
.pm-btn[disabled]{ opacity:0.6; cursor:not-allowed; }
.pm-btn.secondary{ background:#fff; color:var(--accent); border:1px solid rgba(11,35,64,0.06); }
.pm-btn.danger{ background:var(--danger); }
.pm-btn:hover{ transform:translateY(-2px); transition: transform .12s ease; }

input[type='number'], input[type='text'], textarea{ width:100%; padding:10px; border-radius:8px; border:1px solid rgba(11,35,64,0.08); background: #fff; color:var(--accent); }
textarea{ min-height:84px; resize:vertical; }

/* manager specific */
.manager-note{ text-align:center; color:var(--accent); padding:10px; background: linear-gradient(90deg, rgba(13,41,74,0.04), rgba(11,35,64,0.02)); border-radius:8px; }
.manager-controls{ display:flex; gap:8px; align-items:center; justify-content:center; flex-wrap:wrap; }

/* vote container */
#vote-container{ max-width:920px; margin:18px auto; padding:14px; border-radius:10px; background: linear-gradient(180deg, #ffffff, #fbfdff); border:1px solid rgba(11,35,64,0.04); box-shadow: 0 8px 22px rgba(6,30,60,0.04); }
#vote-container h3{ margin:0; font-size:16px; color:var(--accent); }
#vote-container .vote-list{ margin-top:12px; display:grid; gap:8px; }
#vote-container .vote-list .row{ display:flex; align-items:center; justify-content:space-between; padding:8px; border-radius:8px; border:1px solid rgba(11,35,64,0.04); background:var(--glass); }
#vote-container .pm-btn{ padding:6px 10px; border-radius:6px; }

.vote-note{ margin-top:10px; font-size:13px; color:#6b4f00; background:#fff8e6; border:1px solid #ffecb3; padding:8px; border-radius:6px; }

/* vote list style in manager */
.vote-raw ul{ margin:8px 0 0 18px; color:var(--muted); }

/* editable card inputs in manager */
.team-name-input, .team-score-input{ padding:8px; border-radius:8px; border:1px solid rgba(11,35,64,0.06); }

/* responsive tweaks */
@media (min-width:420px){ .team-card .score-number{ font-size:3.4rem; } }
@media (min-width:900px){ .scoreboard-container{ padding-left:24px; padding-right:24px; } .team-card .score-number{ font-size:3.8rem; } }

/* mobile-specific adjustments */
@media (max-width:480px) {
  header{ padding:12px 12px; }
  .scoreboard-container{ padding:80px 12px 24px; }
  .scoreboard-grid{ gap:12px; grid-template-columns: 1fr; }
  .team-card{ padding:12px; border-radius:10px; }
  .team-card h2{ font-size:14px; }
  .team-card .score-number{ font-size:2.2rem; }
  .pm-btn{ padding:7px 10px; font-size:14px; }
  input[type='number'], input[type='text'], textarea{ padding:8px; }
  #vote-container{ margin:12px 12px; padding:10px; }
  #vote-container .vote-list .row{ padding:8px; }
  .vote-note{ font-size:12px; }
  .manager-controls{ flex-direction:column; gap:10px; }
  .team-card::before{ height:8px; top:-8px; }
}

/* accessibility */
@media (prefers-reduced-motion: reduce){ *{ transition:none !important; } }


