/* LetsRollTonight — brand stylesheet (vanilla, self-contained) */
:root{
  --red:#ed1c24; --purple:#591d85; --crimson:#c41230; --violet:#3a1260;
  --ink:#1d0b30; --muted:#6b5b7a; --line:#ece7f1; --card:#ffffff;
  --accent:#ed1c24;
  --shadow-text:1px 1px 2px rgba(20,5,30,.55);
  --shadow-card:0 14px 34px rgba(25,5,40,.30);
  --radius:16px;
  --font:"Montserrat","Arial Black","Helvetica Neue",Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font); color:#fff; min-height:100vh; line-height:1.6;
  background:url("../img/bg.svg") center center / cover fixed no-repeat, #7a153f;
}
a{color:inherit;text-decoration:none}
img{display:block}
.wrap{max-width:1060px;margin:0 auto;padding:0 22px}

/* nav */
.nav{display:flex;align-items:center;gap:16px;padding:20px 0}
.brandlock{display:flex;align-items:center;gap:16px}
.nav .logo{width:150px;height:150px;filter:drop-shadow(0 5px 12px rgba(20,5,30,.42))}
.brand{display:flex;flex-direction:column;line-height:.88;font-weight:800;letter-spacing:.02em;
  text-transform:uppercase;text-shadow:var(--shadow-text)}
.brand span{font-size:48px}
.nav .sp{flex:1}
.nav .link{font-weight:600;font-size:15px;margin-left:20px;text-shadow:var(--shadow-text);opacity:.95}
.nav .link:hover{opacity:1}
.nav .btn-sm{margin-left:18px}

/* buttons */
.btn{display:inline-block;border:none;cursor:pointer;font-family:var(--font);font-weight:800;
  font-size:16px;padding:14px 26px;border-radius:12px;text-transform:uppercase;letter-spacing:.03em;
  box-shadow:var(--shadow-card);transition:transform .08s ease}
.btn:active{transform:translateY(1px)}
.btn-primary{background:#fff;color:var(--purple)}
.btn-primary:hover{color:var(--crimson)}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:2px solid rgba(255,255,255,.7)}
.btn-sm{padding:9px 16px;font-size:13px;border-radius:10px}

/* hero */
.hero{text-align:center;padding:40px 0 34px}
.hero h1{font-weight:800;font-size:clamp(36px,6vw,62px);line-height:1.04;margin:0 auto;
  max-width:800px;text-transform:uppercase;text-shadow:var(--shadow-text)}
.accent{display:block;width:120px;height:6px;background:var(--accent);border-radius:3px;margin:20px auto 0;
  box-shadow:0 2px 6px rgba(20,5,30,.4)}
.hero p{font-weight:600;font-size:clamp(16px,2.4vw,20px);max-width:660px;margin:22px auto 0;
  text-shadow:var(--shadow-text);opacity:.97}
.cta{margin-top:30px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* sections */
.section-title{text-align:center;font-weight:800;font-size:clamp(22px,3.5vw,30px);
  text-transform:uppercase;text-shadow:var(--shadow-text);margin:42px 0 6px}
.section-sub{text-align:center;font-weight:600;opacity:.92;text-shadow:var(--shadow-text);
  margin:0 auto 28px;max-width:620px}
.tagline{font-weight:800;text-transform:uppercase;letter-spacing:.05em;opacity:1;
  font-size:clamp(34px,5.2vw,48px);margin-top:4px}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.step{background:var(--card);color:var(--ink);border-radius:var(--radius);box-shadow:var(--shadow-card);
  padding:26px 22px;text-align:center}
.step .num{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:50%;
  background:linear-gradient(135deg,var(--crimson),var(--violet));color:#fff;font-weight:800;font-size:20px;margin-bottom:14px}
.step h3{margin:0 0 8px;font-weight:800;font-size:18px;text-transform:uppercase}
.step p{margin:0;color:var(--muted);font-weight:500;font-size:15px;line-height:1.55}

/* history feature */
.feature{display:grid;grid-template-columns:1.05fr .95fr;gap:18px;align-items:stretch;padding-bottom:8px}
.feature-text{background:var(--card);color:var(--ink);border-radius:var(--radius);
  box-shadow:var(--shadow-card);padding:28px 26px;display:flex;flex-direction:column;justify-content:center}
.feature-text p{margin:0;font-weight:500;font-size:16px;line-height:1.6;color:var(--ink)}
.feature-text .q{font-weight:800;color:var(--crimson);font-size:18px;display:block;margin-bottom:12px}
.history-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-card);overflow:hidden}
.hc-head{background:linear-gradient(135deg,var(--crimson),var(--violet));color:#fff;
  font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-size:14px;padding:14px 20px}
.history-card ul{list-style:none;margin:0;padding:8px 12px}
.history-card li{display:flex;align-items:center;gap:12px;padding:11px 8px;border-bottom:1px solid var(--line);
  color:var(--ink);font-weight:600;font-size:15px}
.history-card li:last-child{border-bottom:none}
.history-card li .date{min-width:62px;color:var(--muted);font-weight:700;font-size:13px}
.history-card li .now{color:var(--crimson)}

/* interactive list widget */
.listwrap{max-width:560px;margin:0 auto}
.lcard{background:var(--card);color:var(--ink);border-radius:var(--radius);box-shadow:var(--shadow-card)}
.lcard>:first-child{border-top-left-radius:var(--radius);border-top-right-radius:var(--radius)}
.lcard>:last-child{border-bottom-left-radius:var(--radius);border-bottom-right-radius:var(--radius)}
.lhead{background:linear-gradient(135deg,var(--crimson),var(--violet));color:#fff;padding:15px 20px;display:flex;align-items:center}
.lhead .ltitle{font-weight:800;font-size:20px;letter-spacing:.01em}
.lhead .lmeta{margin-left:auto;font-weight:600;font-size:12px;background:rgba(255,255,255,.22);padding:4px 10px;border-radius:20px}
.members{margin-left:auto;position:relative;display:inline-block}
.members .lmeta{cursor:pointer}
.members-pop{position:absolute;top:calc(100% + 8px);right:0;width:252px;background:#fff;color:var(--ink);
  border-radius:12px;box-shadow:0 16px 40px rgba(0,0,0,.32);padding:8px;display:none;z-index:40}
.members-pop::before{content:"";position:absolute;top:-10px;left:0;right:0;height:10px}
.members:hover .members-pop{display:block}
.members-pop .mp-head{font-weight:800;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:6px 8px}
.members-pop ul{list-style:none;margin:0;padding:0}
.members-pop li{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px;border-bottom:1px solid var(--line)}
.members-pop li:last-child{border-bottom:none}
.members-pop .mname{font-weight:700;font-size:14px;color:var(--ink)}
.members-pop .mvoted{color:#1aa64b;font-weight:800;font-size:13px}
.members-pop .mnudge{border:none;background:var(--crimson);color:#fff;font-weight:700;font-size:12px;padding:6px 12px;border-radius:8px;cursor:pointer}
.members-pop .mnudge.done,.members-pop .mnudge:disabled{background:#b7adc4;cursor:default}
.members-pop .nudgeall{margin-top:8px;width:100%;border:none;background:var(--ink);color:#fff;font-weight:800;font-size:13px;padding:10px;border-radius:10px;cursor:pointer}
.members-pop .nudgeall:disabled{background:#b7adc4;cursor:default}
.members-pop .mp-all{text-align:center;font-weight:700;font-size:13px;color:#1aa64b;padding:8px}
.demo-toggle{display:flex;align-items:center;gap:11px;justify-content:center;color:#fff;font-weight:800;
  font-size:15px;text-transform:uppercase;letter-spacing:.04em;margin:0 auto 30px;cursor:pointer;width:max-content;
  background:rgba(13,3,22,.6);border:2px solid rgba(255,255,255,.7);border-radius:30px;padding:11px 22px;box-shadow:var(--shadow-card)}
.demo-toggle:hover{background:rgba(13,3,22,.8);border-color:#fff}
.demo-toggle input{width:20px;height:20px;cursor:pointer;accent-color:var(--red)}
.demo-stage{display:grid;grid-template-columns:1fr minmax(0,520px) 1fr;gap:50px;align-items:center;max-width:1160px;margin:0 auto}
.demo-stage .listwrap{margin:0 auto;width:100%}
.rules{color:#fff;text-shadow:var(--shadow-text);padding-top:8px}
.rules h3{margin:0 0 14px;font-weight:800;font-size:16px;text-transform:uppercase;letter-spacing:.04em}
.rules ul{list-style:none;margin:0;padding:0}
.rules li{position:relative;padding:0 0 16px 26px;font-weight:600;font-size:15px;line-height:1.45}
.rules li::before{content:"▸";position:absolute;left:2px;top:-1px;font-size:16px;color:#ffd0d6}
.rules .hl{color:#ffe14d;font-weight:800;text-shadow:1px 1px 3px rgba(0,0,0,.6)}
.addrow .addinput.typing{border-color:var(--crimson);box-shadow:0 0 0 3px rgba(237,28,36,.18)}
@media (max-width:980px){.demo-stage{grid-template-columns:1fr}.rules{max-width:520px;margin:0 auto}}
.opts{list-style:none;margin:0;padding:6px 14px}
.opt{display:flex;align-items:center;gap:12px;padding:11px 6px;border-bottom:1px solid var(--line)}
.opt:last-child{border-bottom:none}
.opt.win{background:#fff1f4;border-radius:10px}
.opt.art{background-size:cover;background-position:center;border-bottom:none;border-radius:12px;
  margin:6px 0;min-height:78px;color:#fff;box-shadow:0 4px 14px rgba(20,5,30,.28)}
.opt.art.win{box-shadow:0 0 0 2px #fff inset,0 4px 14px rgba(20,5,30,.28)}
.ologo{height:52px;width:auto;max-width:180px;object-fit:contain;display:block;flex-shrink:0;filter:drop-shadow(0 0 2px rgba(255,255,255,.92)) drop-shadow(0 1px 3px rgba(0,0,0,.7))}
.obody.haslogo .oname{display:none}
.obody.haslogo.noimg .oname{display:block}
.obody.noimg .ologo{display:none}
.oname.light{color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.7)}
.onote.light{color:#efe7f4;text-shadow:1px 1px 2px rgba(0,0,0,.7)}
.notebtn.light{color:#ffd0d6}
.notebtn.light:hover{color:#fff}
.n.light{color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.6)}
.opt .x.light{color:rgba(255,255,255,.85)}
.opt .x.light:hover{color:#fff}
.opt{position:relative;transition:transform .2s ease}

/* countdown + winner crown */
.countdown{background:#241036;color:#fff;text-align:center;font-weight:800;font-size:14px;letter-spacing:.03em;padding:11px 12px}
.countdown .cd-time{font-size:17px;color:#ffd0d6;margin-left:2px}
.countdown.urgent{background:#b3122a;animation:cdpulse 1s infinite}
.countdown.urgent .cd-time{color:#fff}
.winnerbar{background:linear-gradient(90deg,#159c46,#27c66e);color:#fff;text-align:center;font-weight:800;
  font-size:16px;text-transform:uppercase;letter-spacing:.04em;padding:13px;animation:winpop .5s ease}
.opt.crowned{border-radius:12px;position:relative;z-index:2;
  box-shadow:0 0 0 3px #29d17a,0 0 22px rgba(41,209,122,.65);
  animation:crownzap .9s ease, crownglow 1.5s ease-in-out .9s infinite}
.opt.crowned:not(.art){background:#e9fff3}
.opt.crowned:not(.art) .oname{color:#0f7a40}
.arcs{position:absolute;inset:0;pointer-events:none;z-index:3;overflow:visible}
.bolt{position:absolute;width:22px;height:74px;opacity:0;animation:flicker 1.1s infinite}
.bolt svg{width:100%;height:100%;display:block}
.bolt svg path{fill:none;stroke:#e6f4ff;stroke-width:2.4;stroke-linejoin:round;stroke-linecap:round;
  filter:drop-shadow(0 0 3px #7cc8ff) drop-shadow(0 0 8px #2f9bff)}
.bolt:nth-child(1){top:0;left:16%;transform:translate(-50%,-96%) rotate(10deg);animation-delay:0s}
.bolt:nth-child(2){top:0;left:48%;transform:translate(-50%,-98%) rotate(-8deg);animation-delay:.18s}
.bolt:nth-child(3){top:0;left:82%;transform:translate(-50%,-96%) rotate(16deg);animation-delay:.42s}
.bolt:nth-child(4){top:50%;left:0;transform:translate(-92%,-50%) rotate(-96deg);animation-delay:.1s}
.bolt:nth-child(5){top:50%;left:100%;transform:translate(-8%,-50%) rotate(96deg);animation-delay:.3s}
.bolt:nth-child(6){top:100%;left:22%;transform:translate(-50%,-4%) rotate(168deg);animation-delay:.24s}
.bolt:nth-child(7){top:100%;left:64%;transform:translate(-50%,-4%) rotate(-170deg);animation-delay:.5s}
.bolt:nth-child(8){top:100%;left:90%;transform:translate(-50%,-4%) rotate(150deg);animation-delay:.36s}
.goldcrown{position:absolute;top:-22px;left:-14px;width:56px;height:48px;z-index:5;
  filter:drop-shadow(0 5px 6px rgba(0,0,0,.45));transform-origin:bottom center;
  animation:crowndrop .85s cubic-bezier(.2,1.25,.4,1) both}
@keyframes crownzap{
  0%{transform:scale(.9);box-shadow:0 0 0 2px #29d17a,0 0 8px rgba(41,209,122,.4)}
  18%{transform:scale(1.07);box-shadow:0 0 0 4px #6effa8,0 0 38px rgba(120,255,170,.95),0 0 12px #fff}
  34%{transform:scale(.99);box-shadow:0 0 0 3px #29d17a,0 0 18px rgba(41,209,122,.6)}
  52%{transform:scale(1.04);box-shadow:0 0 0 5px #8effc0,0 0 44px rgba(120,255,170,.95)}
  100%{transform:scale(1);box-shadow:0 0 0 3px #29d17a,0 0 22px rgba(41,209,122,.6)}}
@keyframes crownglow{0%,100%{box-shadow:0 0 0 3px #29d17a,0 0 16px rgba(41,209,122,.5)}
  50%{box-shadow:0 0 0 3px #4cea93,0 0 34px rgba(80,240,150,.9)}}
@keyframes flicker{0%,100%{opacity:0}4%{opacity:1}8%{opacity:.15}11%{opacity:.95}15%{opacity:0}50%{opacity:0}54%{opacity:.9}57%{opacity:.1}61%{opacity:.75}65%{opacity:0}}
@keyframes crowndrop{0%{transform:translateY(-90px) rotate(-20deg) scale(.5);opacity:0}
  55%{transform:translateY(6px) rotate(6deg) scale(1.06);opacity:1}
  72%{transform:translateY(-4px) rotate(-3deg) scale(1)}
  100%{transform:translateY(0) rotate(-10deg) scale(1)}}
.opt.bumped{animation:bumpglow .7s ease}
@keyframes bumpglow{0%{box-shadow:0 0 0 0 rgba(237,28,36,0)}25%{box-shadow:0 0 0 4px rgba(237,28,36,.55)}100%{box-shadow:0 0 0 0 rgba(237,28,36,0)}}
@keyframes crownpop{0%{transform:scale(.92)}45%{transform:scale(1.05)}70%{transform:scale(.99)}100%{transform:scale(1)}}
@keyframes winpop{0%{transform:translateY(-10px);opacity:0}100%{transform:translateY(0);opacity:1}}
@keyframes cdpulse{0%,100%{opacity:1}50%{opacity:.6}}
.vote{display:flex;flex-direction:column;align-items:center;min-width:44px}
.vote .vbtn{border:none;background:#f3eef7;color:var(--purple);font-weight:800;font-size:15px;width:38px;height:30px;border-radius:8px;cursor:pointer}
.vote .vbtn:hover{background:#e6dcef}
.vote .vbtn.on{background:var(--crimson);color:#fff}
.vote .vbtn.on:hover{background:var(--crimson)}
.vote .dbtn{border:none;background:#f3eef7;color:#8a7a98;font-weight:800;font-size:13px;width:38px;height:26px;border-radius:8px;cursor:pointer;margin-top:4px}
.vote .dbtn:hover{background:#e6dcef}
.vote .dbtn.on{background:#5b4b6a;color:#fff}
.vote .dbtn.on:hover{background:#5b4b6a}
.opt.art .vote .n{color:#fff;text-shadow:1px 1px 3px rgba(0,0,0,.85)}
.objbadge{position:absolute;top:8px;right:42px;width:20px;height:20px;border-radius:50%;background:var(--red);color:#fff;font-weight:800;font-size:13px;line-height:1;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 5px rgba(0,0,0,.35);z-index:2}
.vote .n{font-weight:800;font-size:15px;margin-top:3px;color:var(--ink)}
.obody{flex:1;min-width:0;display:flex;align-items:center;gap:14px}
.ometa{min-width:0;display:flex;flex-direction:column}
.oname{font-weight:700;font-size:16px}
.onote{font-size:13px;color:var(--muted);font-weight:600;margin-top:2px}
.notebtn{margin-top:3px;border:none;background:none;color:var(--purple);font-weight:700;font-size:12px;cursor:pointer;padding:0}
.notebtn:hover{color:var(--crimson);text-decoration:underline}
.opt .x{border:none;background:none;color:#c7bcd2;font-weight:800;font-size:18px;cursor:pointer;padding:4px 8px}
.opt .x:hover{color:var(--crimson)}
.addrow{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--line)}
.addrow .addinput{flex:1;font-family:var(--font);font-weight:600;font-size:15px;padding:10px 12px;border:2px solid #e6e0ee;border-radius:10px;color:var(--ink)}
.addrow .addinput:focus{outline:none;border-color:var(--purple)}
.addrow .addbtn{border:none;background:var(--ink);color:#fff;font-family:var(--font);font-weight:800;padding:0 18px;border-radius:10px;cursor:pointer}
.rollbar{padding:14px 16px;display:flex;align-items:center;gap:14px;border-top:1px solid var(--line);background:#fbf9fd}
.rollbar .die{width:46px;height:46px;border-radius:10px;background:var(--ink);color:#fff;font-size:26px;display:flex;align-items:center;justify-content:center}
.rollbar .rollbtn{border:none;background:linear-gradient(135deg,var(--crimson),var(--violet));color:#fff;font-family:var(--font);font-weight:800;font-size:14px;text-transform:uppercase;letter-spacing:.03em;padding:12px 18px;border-radius:11px;cursor:pointer}
.rollbar .rollbtn:disabled{opacity:.6;cursor:default}
.rollbar .result{font-weight:800;color:var(--ink);font-size:15px}
.rollbar .result strong{color:var(--crimson)}
.histbox{max-width:560px;margin:16px auto 0;background:rgba(255,255,255,.12);border-radius:14px;padding:14px 18px}
.histhead{font-weight:800;font-size:14px;text-transform:uppercase;letter-spacing:.05em;text-shadow:var(--shadow-text);margin-bottom:8px}
.histlist{list-style:none;margin:0;padding:0}
.histlist li{font-weight:600;font-size:14px;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.18);text-shadow:var(--shadow-text)}
.histlist li:last-child{border-bottom:none}
.histlist .date{display:inline-block;min-width:58px;font-weight:800;opacity:.95}
.histlist .date.now{color:#ffd0d6}
.histlist .how{opacity:.75}
.histlist .empty{opacity:.7}

/* auth modal */
.auth-modal{position:fixed;inset:0;background:rgba(20,5,30,.55);display:none;align-items:center;justify-content:center;padding:20px;z-index:50}
.auth-modal.show{display:flex}
.auth-card{background:var(--card);color:var(--ink);border-radius:var(--radius);box-shadow:0 24px 60px rgba(0,0,0,.4);width:100%;max-width:400px;overflow:hidden;position:relative}
.auth-top{background:linear-gradient(135deg,var(--crimson),var(--violet));padding:22px 24px 0;color:#fff}
.auth-top h2{margin:0 0 14px;font-weight:800;font-size:20px;text-transform:uppercase;letter-spacing:.02em}
.auth-tabs{display:flex;gap:6px}
.auth-tab{border:none;background:rgba(255,255,255,.16);color:#fff;font-family:var(--font);font-weight:700;font-size:14px;padding:10px 16px;border-radius:10px 10px 0 0;cursor:pointer;opacity:.8}
.auth-tab.active{background:var(--card);color:var(--ink);opacity:1}
.auth-form{padding:22px 24px 24px;display:flex;flex-direction:column;gap:12px}
.auth-form label{font-weight:700;font-size:13px;color:var(--muted)}
.auth-form input{font-family:var(--font);font-weight:600;font-size:15px;padding:12px;border:2px solid #e6e0ee;border-radius:10px;color:var(--ink);width:100%}
.auth-form input:focus{outline:none;border-color:var(--purple)}
.auth-submit{margin-top:6px;border:none;background:linear-gradient(135deg,var(--crimson),var(--violet));color:#fff;font-family:var(--font);font-weight:800;text-transform:uppercase;letter-spacing:.03em;padding:13px;border-radius:11px;cursor:pointer}
.auth-note{font-weight:600;font-size:13px;color:var(--purple);min-height:18px;text-align:center}
.auth-close{position:absolute;top:12px;right:14px;border:none;background:none;color:#fff;font-size:22px;font-weight:800;cursor:pointer;line-height:1}

/* footer */
.footer{text-align:center;padding:46px 22px 30px;font-weight:600;font-size:14px;
  opacity:.9;text-shadow:var(--shadow-text)}

@media (max-width:760px){
  .steps{grid-template-columns:1fr}
  .feature{grid-template-columns:1fr}
  .nav .link{display:none}
  .nav .logo{width:108px;height:108px}
  .brand span{font-size:34px}
}
