:root{
  --bg:#05060d;
  --bg2:#0a0e1f;
  --panel:rgba(18,23,42,0.55);
  --stroke:rgba(120,160,255,0.18);
  --txt:#e8edff;
  --muted:#8b96bf;
  --cyan:#3df5ff;
  --magenta:#ff4ddb;
  --violet:#9b6bff;
  --gold:#ffd24a;
  --neg:#ff5c7a;
  --zero:#9aa3c7;
  --pos:#39e6a0;
  --radius:18px;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
html{background:var(--bg);overscroll-behavior:none}
body{
  font-family:'Space Grotesk',system-ui,sans-serif;
  background:radial-gradient(1200px 800px at 70% -10%, #18213f 0%, var(--bg2) 40%, var(--bg) 100%) var(--bg);
  background-attachment:fixed;
  color:var(--txt);
  overflow-x:hidden;
  overscroll-behavior:none;
  min-height:100vh;
}

/* ---- background fx ---- */
.bg-grid{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(90,140,255,0.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(90,140,255,0.05) 1px,transparent 1px);
  background-size:46px 46px;
  mask-image:radial-gradient(ellipse at 50% 30%,#000 30%,transparent 80%);
}
.bg-glow{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(600px 400px at 15% 20%, rgba(61,245,255,0.10), transparent 70%),
    radial-gradient(600px 400px at 85% 80%, rgba(255,77,219,0.10), transparent 70%);
}

.glass{
  background:var(--panel);
  border:1px solid var(--stroke);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  box-shadow:0 20px 60px rgba(0,0,0,0.45), inset 0 1px 0 rgba(255,255,255,0.05);
}

/* ---- screens ---- */
.screen{position:relative;z-index:1;display:none;min-height:100vh}
.screen.active{display:block}

/* ---- login ---- */
#screen-login.active{display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{
  width:min(440px,92vw);padding:42px 38px;border-radius:var(--radius);
  text-align:center;
  animation:rise .6s cubic-bezier(.2,.8,.2,1);
}
.brand-mark{font-size:46px;color:var(--cyan);filter:drop-shadow(0 0 18px var(--cyan));margin-bottom:6px}
.brand h1{font-family:'Orbitron',sans-serif;font-weight:900;font-size:34px;letter-spacing:6px;
  background:linear-gradient(90deg,var(--cyan),var(--violet),var(--magenta));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.tagline{color:var(--muted);margin-top:10px;font-size:15px}
#login-form{margin-top:30px;display:flex;flex-direction:column;gap:14px}
label{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:1.5px;color:var(--muted)}
input[type=text]{
  width:100%;padding:15px 16px;border-radius:12px;
  background:rgba(7,10,22,0.7);border:1px solid var(--stroke);
  color:var(--txt);font-size:17px;font-family:'JetBrains Mono',monospace;
  transition:border .2s, box-shadow .2s;
}
input[type=text]:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px rgba(61,245,255,0.15)}
.fineprint{margin-top:18px;font-size:12px;color:var(--muted);opacity:.8}

.btn-primary{
  padding:15px 22px;border:none;border-radius:12px;cursor:pointer;
  font-family:'Space Grotesk';font-weight:700;font-size:16px;letter-spacing:.5px;color:#04121a;
  background:linear-gradient(90deg,var(--cyan),var(--violet));
  box-shadow:0 8px 26px rgba(61,245,255,0.30);
  transition:transform .15s, box-shadow .2s, filter .2s;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
}
.btn-primary:hover{transform:translateY(-2px);filter:brightness(1.08)}
.btn-primary:active{transform:translateY(0)}
.btn-primary:disabled{filter:grayscale(.7) brightness(.7);cursor:not-allowed;box-shadow:none}
.arrow{transition:transform .2s}
.btn-primary:hover .arrow{transform:translateX(4px)}

.btn-ghost{
  padding:11px 18px;border-radius:11px;cursor:pointer;
  background:transparent;border:1px solid var(--stroke);color:var(--txt);
  font-family:'Space Grotesk';font-weight:600;transition:.2s;
}
.btn-ghost:hover{border-color:var(--magenta);color:var(--magenta)}

/* ---- vote ---- */
#screen-vote{max-width:880px;margin:0 auto;padding:48px 22px 130px}
.vote-header{text-align:center;margin-bottom:34px}
.vote-header h2{font-family:'Orbitron';font-weight:700;font-size:26px;letter-spacing:2px}
.vote-header p{color:var(--muted);margin-top:10px}
.vote-header .neg{color:var(--neg)} .vote-header .zero{color:var(--zero)} .vote-header .pos{color:var(--pos)}

.attr-list{display:flex;flex-direction:column;gap:18px}
.attr-card{
  border-radius:var(--radius);padding:22px 22px 20px;
  background:var(--panel);border:1px solid var(--stroke);
  backdrop-filter:blur(14px);
  animation:rise .5s both;
}
.attr-top{display:flex;align-items:baseline;gap:14px;margin-bottom:6px}
.attr-letter{
  font-family:'Orbitron';font-weight:900;font-size:28px;line-height:1;
  width:46px;height:46px;flex:0 0 46px;display:grid;place-items:center;border-radius:12px;
  background:rgba(61,245,255,0.08);border:1px solid var(--stroke);color:var(--cyan);
}
.attr-name{font-size:19px;font-weight:700}
.attr-q{color:var(--muted);font-size:14px;margin-left:60px;margin-bottom:14px}
.tri{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-left:60px}
.tri-opt{
  cursor:pointer;border-radius:12px;padding:13px 12px;
  background:rgba(7,10,22,0.55);border:1px solid var(--stroke);
  transition:.18s;display:flex;flex-direction:column;gap:6px;text-align:left;
}
.tri-opt:hover{border-color:var(--muted);transform:translateY(-2px)}
.tri-opt .opt-label{font-weight:700;font-size:14px;display:flex;align-items:center;gap:8px}
.tri-opt .opt-val{font-family:'JetBrains Mono';font-size:12px;opacity:.7}
.tri-opt .opt-blurb{font-size:12.5px;color:var(--muted);line-height:1.45}
.tri-opt.sel{background:rgba(255,255,255,0.04)}
.tri-opt[data-v="-1"].sel{border-color:var(--neg);box-shadow:0 0 0 2px rgba(255,92,122,.25)}
.tri-opt[data-v="-1"].sel .opt-label{color:var(--neg)}
.tri-opt[data-v="0"].sel{border-color:var(--zero);box-shadow:0 0 0 2px rgba(154,163,199,.25)}
.tri-opt[data-v="0"].sel .opt-label{color:var(--zero)}
.tri-opt[data-v="1"].sel{border-color:var(--pos);box-shadow:0 0 0 2px rgba(57,230,160,.25)}
.tri-opt[data-v="1"].sel .opt-label{color:var(--pos)}

.vote-footer{
  position:fixed;left:50%;transform:translateX(-50%);bottom:22px;z-index:5;
  width:min(840px,94vw);border-radius:16px;padding:14px 20px;
  display:flex;align-items:center;justify-content:space-between;
}
.progress{font-family:'JetBrains Mono';color:var(--muted);font-size:14px}

/* ---- results ---- */
#screen-results{padding:18px}
.results-grid{
  display:grid;grid-template-columns:1fr 380px;gap:18px;
  height:calc(100vh - 36px);
}
.viz{border-radius:var(--radius);position:relative;overflow:hidden;display:flex;flex-direction:column}
.viz-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;z-index:3}
.viz-title{font-family:'Orbitron';font-weight:700;letter-spacing:3px;font-size:15px;color:var(--cyan)}
.viz-controls{display:flex;gap:8px}
.chip{
  cursor:pointer;font-size:12px;font-family:'JetBrains Mono';
  padding:6px 11px;border-radius:20px;background:rgba(7,10,22,0.6);
  border:1px solid var(--stroke);color:var(--muted);transition:.18s;
}
.chip:hover{color:var(--txt);border-color:var(--muted)}
.chip.on{color:#04121a;background:linear-gradient(90deg,var(--cyan),var(--violet));border-color:transparent;font-weight:600}
#penta{position:absolute;inset:0;width:100%;height:100%;z-index:1}
.viz-hint{position:absolute;bottom:14px;left:18px;z-index:3;font-size:12px;color:var(--muted);font-family:'JetBrains Mono';opacity:.7}
.legend{position:absolute;bottom:14px;right:18px;z-index:3;display:flex;gap:14px;font-size:12px;font-family:'JetBrains Mono'}
.legend .lg{display:flex;align-items:center;gap:6px;color:var(--muted)}
.legend .dot{width:10px;height:10px;border-radius:50%}

/* clicked-point info card */
#pick-info{
  position:absolute;top:58px;left:18px;z-index:4;
  min-width:180px;max-width:240px;padding:12px 14px;border-radius:12px;
  background:rgba(10,14,30,0.82);border:1px solid var(--stroke);
  backdrop-filter:blur(10px);opacity:0;transform:translateY(-6px);
  transition:opacity .18s,transform .18s;pointer-events:none;
}
#pick-info.show{opacity:1;transform:none}
#pick-info .pi-name{font-family:'JetBrains Mono';font-weight:600;font-size:14px;margin-bottom:9px;display:flex;align-items:center;gap:7px}
#pick-info .pi-vals{display:flex;gap:6px;flex-wrap:wrap}
#pick-info .pi{font-family:'JetBrains Mono';font-size:12px;padding:3px 7px;border-radius:7px;background:rgba(255,255,255,0.05);border:1px solid var(--stroke)}
#pick-info .pi b{opacity:.55;font-weight:600;margin-right:3px}
#pick-info .pi.n{color:var(--neg)} #pick-info .pi.z{color:var(--zero)} #pick-info .pi.p{color:var(--pos)}

/* header hover tooltip */
#tip{
  position:fixed;z-index:50;pointer-events:none;
  padding:7px 11px;border-radius:9px;font-size:12.5px;
  font-family:'Space Grotesk';white-space:nowrap;
  background:rgba(10,14,30,0.95);border:1px solid var(--stroke);
  color:var(--txt);box-shadow:0 8px 24px rgba(0,0,0,.5);
  opacity:0;transform:translateY(4px);transition:opacity .12s,transform .12s;
}
#tip.show{opacity:1;transform:none}
#tip b{color:var(--cyan);font-family:'Orbitron'}

.panel{border-radius:var(--radius);display:flex;flex-direction:column;overflow:hidden}
.panel-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--stroke)}
.panel-head h3{font-family:'Orbitron';font-weight:700;letter-spacing:2px;font-size:16px}
.count{font-family:'JetBrains Mono';font-size:13px;color:var(--cyan);background:rgba(61,245,255,0.1);padding:4px 10px;border-radius:20px}
.table-scroll{flex:1;overflow-y:auto;overflow-x:hidden;padding:6px 6px}
table{width:100%;border-collapse:collapse;font-size:13px;table-layout:fixed}
th,td{padding:8px 4px;text-align:center}
th{position:sticky;top:0;background:rgba(12,16,32,0.95);font-family:'JetBrains Mono';font-size:12px;color:var(--muted);font-weight:600;backdrop-filter:blur(6px)}
th:first-child,td:first-child{text-align:left;font-family:'JetBrains Mono';width:auto;max-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
th:not(:first-child),td:not(:first-child){width:13%}
tbody tr{border-top:1px solid rgba(120,160,255,0.07)}
tbody tr{cursor:pointer;transition:background .15s}
tbody tr:hover{background:rgba(120,160,255,0.08)}
tbody tr.me{background:rgba(61,245,255,0.07)}
tbody tr.sel{background:rgba(255,77,219,0.14);box-shadow:inset 3px 0 0 var(--magenta)}
th[data-tip]{cursor:help}
tbody tr.avg{background:rgba(255,210,74,0.08);font-weight:700}
tbody tr.avg td:first-child{color:var(--gold)}
td .v{font-family:'JetBrains Mono';font-weight:600;display:inline-block;min-width:22px}
.v.n{color:var(--neg)} .v.z{color:var(--zero)} .v.p{color:var(--pos)}
.name-dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:7px;vertical-align:middle}
.panel-foot{padding:14px 18px;border-top:1px solid var(--stroke);display:flex;justify-content:flex-end}

@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

@media(max-width:880px){
  .results-grid{grid-template-columns:1fr;height:auto}
  #viz-wrap{height:60vh}
  .panel{height:auto;max-height:50vh}
  .attr-q,.tri{margin-left:0}
}
