:root{
  --bg:#F6F3EA;
  --panel:#FFFFFF;
  --panel-2:#FBFAF4;
  --green:#0E5C39;
  --green-d:#0A4127;
  --green-l:#1C7A4D;
  --green-soft:#E7F0E9;
  --gold:#C9A24B;
  --gold-d:#A9842F;
  --ink:#1A271E;
  --muted:#6B7A6F;
  --line:#E6E1D3;
  --red:#B5432F;
  --shadow:0 1px 2px rgba(20,40,28,.05), 0 8px 24px rgba(20,40,28,.07);
  --radius:16px;
  --radius-sm:10px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:var(--bg);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.serif{font-family:'Playfair Display',Georgia,serif;font-weight:600;letter-spacing:.2px}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

#app{display:flex;min-height:100vh}

/* Sidebar */
.sidebar{
  width:248px;flex:0 0 248px;
  background:linear-gradient(180deg,var(--green) 0%,var(--green-d) 100%);
  color:#EAF3EC;display:flex;flex-direction:column;
  position:sticky;top:0;height:100vh;
}
.brand{display:flex;align-items:center;gap:12px;padding:22px 20px 18px}
.brand-mark{font-family:'Playfair Display',serif;font-weight:700;font-size:18px;letter-spacing:.5px;background:rgba(255,255,255,.12);width:44px;height:44px;display:grid;place-items:center;border-radius:12px;color:var(--gold)}
.brand-text{display:flex;flex-direction:column;line-height:1.15}
.brand-title{font-family:'Playfair Display',serif;font-size:18px;font-weight:700}
.brand-sub{font-size:10px;letter-spacing:.7px;text-transform:uppercase;color:var(--gold);line-height:1.3}
.nav{display:flex;flex-direction:column;gap:2px;padding:8px 12px;flex:1;overflow:auto}
.nav a{
  display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;
  color:#D6E6DA;font-size:14px;font-weight:500;transition:.15s;
}
.nav a .ic{width:20px;text-align:center;opacity:.9}
.nav a:hover{background:rgba(255,255,255,.08);color:#fff}
.nav a.active{background:rgba(255,255,255,.14);color:#fff;box-shadow:inset 3px 0 0 var(--gold)}
.nav-toggle{display:none;margin-left:auto;background:rgba(255,255,255,.12);border:none;width:42px;height:42px;border-radius:11px;cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:0}
.nav-toggle span{display:block;width:19px;height:2px;background:#EAF3EC;border-radius:2px;transition:.22s ease}
.sidebar.nav-open .nav-toggle span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.sidebar.nav-open .nav-toggle span:nth-child(2){opacity:0}
.sidebar.nav-open .nav-toggle span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
.sidebar-foot{padding:14px 16px;border-top:1px solid rgba(255,255,255,.1)}
.foot-link{display:block;color:#cfe2d5;font-size:13px;font-weight:600;padding:5px 0;margin-bottom:8px}
.foot-link:hover,.foot-link.active{color:#fff}
.pill{font-size:11px;background:rgba(255,255,255,.1);padding:4px 10px;border-radius:20px;color:#cfe2d5}

/* Main view */
.view{flex:1;padding:34px 40px 80px;max-width:1180px;width:100%;margin:0 auto}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:24px;flex-wrap:wrap}
.page-head h1{font-size:30px;margin:0}
.page-head .eyebrow{font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--gold-d);font-weight:600;margin-bottom:4px}
.page-head p.sub{color:var(--muted);margin:6px 0 0;font-size:14px}

/* Cards */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px}
.card + .card{margin-top:18px}
.card h2{font-size:19px;margin:0 0 4px}
.card h3{font-size:15px;margin:0 0 12px;font-family:'Inter';font-weight:600;color:var(--ink)}
.card .card-sub{color:var(--muted);font-size:13px;margin:0 0 16px}
.grid{display:grid;gap:18px}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:920px){.grid.cols-3,.grid.cols-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){
  .grid.cols-2{grid-template-columns:1fr}
  .grid.cols-3,.grid.cols-4{grid-template-columns:repeat(2,1fr)}
}

/* Stat tiles */
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-sm);padding:16px 18px;box-shadow:var(--shadow)}
.stat .label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;font-weight:600}
.stat .value{font-family:'Playfair Display',serif;font-size:30px;font-weight:700;margin-top:4px;line-height:1}
.stat .sub{font-size:12px;color:var(--muted);margin-top:6px}
.stat.accent{background:linear-gradient(160deg,var(--green) 0%,var(--green-d) 100%);border-color:transparent;color:#fff}
.stat.accent .label{color:#bfe0cb}
.stat.accent .sub{color:#cfe7d6}
.val-good{color:var(--green-l)}.val-bad{color:var(--red)}

/* Controls */
.controls{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end;margin-bottom:18px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
select,input[type=text],input[type=number],input[type=password]{
  font-family:inherit;font-size:14px;padding:9px 12px;border:1px solid var(--line);
  border-radius:10px;background:#fff;color:var(--ink);min-width:150px;outline:none;transition:.15s;
}
select:focus,input:focus{border-color:var(--green-l);box-shadow:0 0 0 3px var(--green-soft)}
.btn{
  display:inline-flex;align-items:center;gap:8px;cursor:pointer;border:none;
  background:var(--green);color:#fff;font-weight:600;font-size:14px;padding:10px 18px;border-radius:10px;transition:.15s;
}
.btn:hover{background:var(--green-d)}
.btn.gold{background:var(--gold);color:#3a2c08}.btn.gold:hover{background:var(--gold-d);color:#fff}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--ink)}
.btn.ghost:hover{background:var(--panel-2)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.seg{display:inline-flex;background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:3px}
.seg button{border:none;background:transparent;padding:8px 16px;border-radius:8px;font-weight:600;font-size:13px;color:var(--muted);cursor:pointer}
.seg button.active{background:#fff;color:var(--green);box-shadow:var(--shadow)}

/* Tables */
table.tbl{width:100%;border-collapse:collapse;font-size:14px}
.tbl th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);font-weight:600;padding:10px 12px;border-bottom:2px solid var(--line)}
.tbl td{padding:11px 12px;border-bottom:1px solid var(--line)}
.tbl tr:last-child td{border-bottom:none}
.tbl tbody tr:hover{background:var(--panel-2)}
.tbl td.num,.tbl th.num{text-align:right;font-variant-numeric:tabular-nums}
.rank-badge{display:inline-grid;place-items:center;width:26px;height:26px;border-radius:8px;font-weight:700;font-size:13px;background:var(--green-soft);color:var(--green)}
.rank-badge.g1{background:var(--gold);color:#3a2c08}
.rank-badge.g2{background:#dfe3e6;color:#444}
.rank-badge.g3{background:#e9d3b8;color:#6a4a22}

/* Bar charts */
.bars{display:flex;flex-direction:column;gap:10px}
.bar-row{display:grid;grid-template-columns:120px 1fr 56px;align-items:center;gap:10px}
.bar-row .bl{font-size:13px;color:var(--ink);font-weight:500}
.bar-track{background:var(--panel-2);border-radius:8px;height:22px;overflow:hidden;border:1px solid var(--line)}
.bar-fill{height:100%;background:linear-gradient(90deg,var(--green-l),var(--green));border-radius:8px;transition:width .6s cubic-bezier(.2,.8,.2,1)}
.bar-fill.gold{background:linear-gradient(90deg,var(--gold),var(--gold-d))}
.bar-row .bv{font-size:13px;text-align:right;font-variant-numeric:tabular-nums;font-weight:600}
.legend{display:flex;gap:16px;font-size:12px;color:var(--muted);margin-bottom:14px}
.legend span{display:inline-flex;align-items:center;gap:6px}
.dot{width:10px;height:10px;border-radius:3px;display:inline-block}

/* Scorecard grid */
.sc-wrap{overflow-x:auto}
.scorecard{border-collapse:collapse;width:100%;font-size:13px;min-width:760px}
.scorecard th,.scorecard td{border:1px solid var(--line);padding:6px 8px;text-align:center;font-variant-numeric:tabular-nums}
.scorecard thead th{background:var(--green);color:#fff;font-weight:600;font-size:12px}
.scorecard .rowlabel{text-align:left;font-weight:600;background:var(--panel-2);position:sticky;left:0}
.scorecard .par-row td{background:var(--green-soft);font-weight:600}
.scorecard input{width:46px;min-width:0;padding:5px;text-align:center;border:1px solid var(--line);border-radius:6px;font-size:13px}
.scorecard .tot{background:#f3efe2;font-weight:700}
.under{color:var(--red);font-weight:700}.overpar{color:var(--ink)}

/* Player card / avatar */
.player-hero{display:flex;gap:20px;align-items:center}
.avatar{width:84px;height:84px;border-radius:18px;background:linear-gradient(160deg,var(--green-l),var(--green-d));color:#fff;display:grid;place-items:center;font-family:'Playfair Display',serif;font-size:34px;font-weight:700;flex:0 0 auto;box-shadow:var(--shadow)}
img.av-img{object-fit:cover;object-position:center top;display:block}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.chip{font-size:12px;background:var(--green-soft);color:var(--green);padding:4px 10px;border-radius:20px;font-weight:600}
.chip.gold{background:#f6ecd2;color:var(--gold-d)}

/* Draft */
.draft-cols{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:920px){.draft-cols{grid-template-columns:repeat(2,1fr)}}
.team-col{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:14px;box-shadow:var(--shadow);min-height:120px}
.team-col h4{margin:0 0 4px;font-family:'Playfair Display',serif;font-size:16px}
.team-col .cap{font-size:11px;color:var(--gold-d);text-transform:uppercase;letter-spacing:.6px;font-weight:600;margin-bottom:10px}
.team-pick{display:flex;justify-content:space-between;align-items:center;background:var(--green-soft);border-radius:9px;padding:7px 10px;margin-bottom:6px;font-size:13px;font-weight:500;animation:pickIn .5s cubic-bezier(.2,.9,.2,1)}
.team-pick .h{color:var(--muted);font-size:12px}
@keyframes pickIn{0%{opacity:0;transform:translateY(-8px) scale(.96)}100%{opacity:1;transform:none}}

.pool{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin-top:6px}
.pcard{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:14px;box-shadow:var(--shadow);transition:.18s;overflow:hidden}
.pcard:hover{transform:translateY(-3px);border-color:var(--green-l);box-shadow:0 12px 30px rgba(14,92,57,.15)}
.pcard .pc-top{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.pcard .mini-av{width:40px;height:40px;border-radius:11px;background:linear-gradient(160deg,var(--green-l),var(--green-d));color:#fff;display:grid;place-items:center;font-weight:700;font-family:'Playfair Display',serif}
.pcard .pc-name{font-weight:700;font-size:15px}
.pcard .pc-meta{font-size:11px;color:var(--muted)}
.pc-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin:8px 0 12px}
.pc-stat{background:var(--panel-2);border-radius:8px;padding:6px;text-align:center}
.pc-stat .k{font-size:10px;color:var(--muted);text-transform:uppercase}
.pc-stat .v{font-weight:700;font-size:14px}
.pc-assign{display:flex;gap:6px;flex-wrap:wrap}
.pc-assign button{flex:1;min-width:0;font-size:12px;padding:7px 4px;border-radius:8px;border:1px solid var(--line);background:#fff;cursor:pointer;font-weight:600;color:var(--green)}
.pc-assign button:hover{background:var(--green);color:#fff;border-color:var(--green)}

/* Pick animation overlay */
.draft-flash{position:fixed;inset:0;display:grid;place-items:center;background:rgba(10,30,18,.55);z-index:50;animation:fadeIn .2s}
.draft-flash .card-flash{background:#fff;border-radius:20px;padding:34px 48px;text-align:center;box-shadow:0 30px 80px rgba(0,0,0,.4);animation:pop .5s cubic-bezier(.2,1.3,.4,1)}
.draft-flash .big-av{width:96px;height:96px;border-radius:24px;margin:0 auto 14px;background:linear-gradient(160deg,var(--green-l),var(--green-d));color:#fff;display:grid;place-items:center;font-family:'Playfair Display',serif;font-size:42px;font-weight:700}
.draft-flash .pick-team{color:var(--gold-d);font-weight:700;text-transform:uppercase;letter-spacing:1.5px;font-size:13px}
.draft-flash .pick-name{font-family:'Playfair Display',serif;font-size:30px;margin:4px 0}
@keyframes pop{0%{transform:scale(.6);opacity:0}100%{transform:scale(1);opacity:1}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* Leaderboard */
.lb{display:flex;flex-direction:column;gap:8px}
.lb-rank{font-family:'Playfair Display',serif;font-weight:700;font-size:20px;color:var(--green);text-align:center}
.lb-row{display:grid;grid-template-columns:44px 1fr auto auto;align-items:center;gap:14px;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:14px 18px;box-shadow:var(--shadow)}
.lb-row.lead{background:linear-gradient(120deg,#fff 0%,#fbf6e8 100%);border-color:var(--gold)}
.lb-team{font-weight:700;font-size:16px}
.lb-players{font-size:12px;color:var(--muted)}
.lb-score{font-family:'Playfair Display',serif;font-size:26px;font-weight:700}
.lb-thru{font-size:12px;color:var(--muted);text-align:right}
.topar-neg{color:var(--red)}.topar-pos{color:var(--ink)}.topar-e{color:var(--green-l)}

.empty{text-align:center;color:var(--muted);padding:46px 20px;border:1px dashed var(--line);border-radius:14px;background:var(--panel-2)}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--green-d);color:#fff;padding:12px 22px;border-radius:30px;font-weight:600;font-size:14px;box-shadow:var(--shadow);z-index:60;animation:fadeIn .2s}
.note{font-size:12px;color:var(--muted);margin-top:10px}
.hr{height:1px;background:var(--line);margin:18px 0;border:0}

@media(max-width:760px){
  #app{flex-direction:column}
  .sidebar{width:100%;height:auto;flex:none;position:sticky;top:0;z-index:40;flex-direction:column;
    box-shadow:0 2px 14px rgba(10,40,24,.22)}
  .brand{padding:7px 12px;width:100%;align-items:center}
  .brand-mark{width:34px;height:34px;font-size:13px}
  .brand-text{line-height:1.15}
  .brand-title{font-size:15px}
  .brand-sub{font-size:9.5px;letter-spacing:.5px}
  .nav-toggle{display:flex;width:38px;height:38px}

  /* collapsible dropdown menu */
  .nav{display:none;flex-direction:column;width:100%;gap:3px;padding:2px 10px 12px}
  .sidebar.nav-open .nav{display:flex}
  .nav a{width:100%;padding:13px 14px;border-radius:10px;font-size:15px}
  .nav a.active{box-shadow:none;background:rgba(255,255,255,.18)}
  .sidebar-foot{display:none}
  .sidebar.nav-open .sidebar-foot{display:flex;align-items:center;justify-content:space-between;padding:8px 14px 12px}
  .sidebar.nav-open .foot-link{margin-bottom:0;font-size:15px;padding:8px 0}

  .view{padding:16px 13px 56px;max-width:100%}
  .page-head{margin-bottom:16px;gap:10px}
  .page-head h1{font-size:23px}
  .page-head .eyebrow{font-size:11px}
  .head-actions{width:100%}
  .card{padding:15px}
  .card + .card{margin-top:14px}
  .grid{gap:12px}

  /* prevent iOS auto-zoom on focus, full-width stacked controls */
  input,select,textarea{font-size:16px}
  .controls{gap:8px;margin-bottom:14px}
  .controls .field{flex:1 1 100%}
  .controls .field select,.controls .field input{width:100%}
  .btn{padding:11px 16px}
  .seg{width:100%;display:flex}
  .seg button{flex:1;text-align:center}

  .stat{padding:13px}
  .stat .value{font-size:23px}

  /* wide data tables scroll instead of overflowing the screen */
  .card .tbl{display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}
  .tbl th,.tbl td{padding:9px 10px}

  /* bar charts: narrower label column on small screens */
  .bar-row{grid-template-columns:96px 1fr 44px;gap:8px}
  .bar-row .bl{font-size:12px}

  .lb-row{grid-template-columns:28px 1fr auto;gap:10px;padding:12px 13px}
  .lb-row .lb-thru{grid-column:2 / -1;text-align:left;margin-top:2px}
  .lb-team{font-size:15px}
  .lb-score{font-size:21px}

  .pool{grid-template-columns:1fr 1fr;gap:10px}
  .draft-cols{grid-template-columns:1fr 1fr;gap:10px}
  .player-hero{gap:14px}
  .avatar{width:66px;height:66px;font-size:26px}
  .draft-flash .card-flash{padding:26px 30px;width:80%}
}

@media(max-width:430px){
  .grid.cols-3,.grid.cols-4{grid-template-columns:1fr 1fr}
  .page-head h1{font-size:21px}
  .pool{grid-template-columns:1fr}
  .draft-cols{grid-template-columns:1fr}
  .scorecard input{width:42px}
  .lb-players{font-size:11px}
}
