/* ============================================================
   LIFE IN THE FAST LANE  —  styles.css
   Happystoner5420 Games
   ============================================================ */
:root{
  --ink:#0b1020;
  --panel:#121a30;
  --panel2:#1a2440;
  --line:rgba(255,255,255,.10);
  --txt:#eaf0ff;
  --muted:#9fb0d0;
  --gold:#ffcf4d;
  --gold2:#e7a93b;
  --teal:#39e0d0;
  --green:#46d36b;
  --red:#ff5a6a;
  --blue:#4aa3ff;
  --purple:#b06bff;
  --shadow:0 18px 50px rgba(0,0,0,.55);
  --radius:16px;
  --font:'Segoe UI',system-ui,-apple-system,Roboto,Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--font);
  background:#05070f;
  color:var(--txt);
  overflow:hidden;
  -webkit-font-smoothing:antialiased;
  user-select:none;
}
button{font-family:inherit;cursor:pointer;color:inherit}
input,select{font-family:inherit}
.hidden{display:none !important}

/* ---------- screen system ---------- */
.screen{position:fixed;inset:0;opacity:0;pointer-events:none;transition:opacity .45s ease;display:flex;align-items:center;justify-content:center}
.screen.active{opacity:1;pointer-events:auto;z-index:2}
.screen svg{display:block}

/* ---------- BOOT ---------- */
#boot{background:radial-gradient(120% 120% at 50% 20%,#11203f 0%,#05070f 70%)}
.boot-inner{width:min(520px,86vw);text-align:center}
#bootLogo{margin-bottom:26px}
.boot-bar{height:10px;border-radius:10px;background:rgba(255,255,255,.08);overflow:hidden;border:1px solid var(--line)}
#bootFill{height:100%;width:0;background:linear-gradient(90deg,var(--gold2),var(--gold));box-shadow:0 0 18px var(--gold);transition:width .25s}
#bootMsg{margin-top:14px;color:var(--muted);font-size:13px;letter-spacing:.5px}

/* ---------- MAIN MENU ---------- */
#menuBg{position:absolute;inset:0;overflow:hidden}
#menuBg svg{width:100%;height:100%}
.menu-vignette{position:absolute;inset:0;background:radial-gradient(120% 90% at 50% 45%,transparent 35%,rgba(0,0,0,.72) 100%)}
.menu-content{position:relative;z-index:3;text-align:center;width:min(560px,90vw)}
#titleLogo{margin-bottom:30px;filter:drop-shadow(0 10px 30px rgba(0,0,0,.6))}
.menu-buttons{display:flex;flex-direction:column;gap:14px;width:340px;margin:0 auto}
.menu-btn{
  position:relative;padding:16px 20px;font-size:20px;font-weight:800;letter-spacing:2px;
  color:#fff8e6;border:1px solid rgba(255,255,255,.18);border-radius:14px;
  background:linear-gradient(180deg,rgba(36,52,92,.92),rgba(16,24,46,.95));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12),var(--shadow);
  transition:transform .12s, box-shadow .2s, background .2s;
}
.menu-btn::before{content:'';position:absolute;left:14px;top:50%;width:8px;height:8px;border-radius:50%;background:var(--gold);transform:translateY(-50%) scale(0);transition:transform .15s;box-shadow:0 0 12px var(--gold)}
.menu-btn:hover{transform:translateY(-2px);background:linear-gradient(180deg,rgba(52,74,128,.96),rgba(22,32,60,.98))}
.menu-btn:hover::before{transform:translateY(-50%) scale(1)}
.menu-btn.danger:hover{background:linear-gradient(180deg,#7a2230,#3a1018)}
.menu-foot{margin-top:26px;color:var(--muted);font-size:12px;letter-spacing:1px}

/* ---------- generic panel backgrounds ---------- */
.panel-bg{position:absolute;inset:0;background:
  radial-gradient(90% 70% at 50% 0%,#16203c 0%,#070b15 75%);}
.panel-bg::after{content:'';position:absolute;inset:0;background-image:
  linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
  linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:42px 42px;mask:radial-gradient(80% 70% at 50% 40%,#000,transparent)}

.screen-title{
  text-align:center;font-size:26px;letter-spacing:3px;font-weight:800;
  color:var(--gold);text-shadow:0 2px 0 #00000060;margin:10px 0 18px;
}
.screen-title span{color:var(--teal)}

/* ---------- SETUP ---------- */
.setup-wrap{position:relative;z-index:2;width:min(960px,94vw);max-height:94vh;overflow:auto;padding:20px}
.mode-row{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:18px}
.mode-card{padding:14px 10px;border-radius:12px;border:1px solid var(--line);background:var(--panel);text-align:center;font-weight:700;font-size:13px;transition:.15s}
.mode-card small{display:block;color:var(--muted);font-weight:500;font-size:11px;margin-top:6px}
.mode-card:hover{border-color:var(--teal)}
.mode-card.sel{background:linear-gradient(180deg,#27406f,#16233f);border-color:var(--gold);box-shadow:0 0 0 2px var(--gold) inset}

.char-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:16px}
.char-card{border-radius:14px;border:1px solid var(--line);background:linear-gradient(180deg,#15203c,#0d1525);overflow:hidden;cursor:pointer;transition:.15s;text-align:center}
.char-card:hover{transform:translateY(-3px);border-color:var(--teal)}
.char-card.sel{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold) inset,var(--shadow)}
.char-card .cc-art{background:radial-gradient(80% 60% at 50% 20%,#2a3a5e,#0c1322)}
.char-card .cc-name{padding:8px;font-weight:800;letter-spacing:1px}
.char-card .cc-tag{padding:0 8px 12px;color:var(--muted);font-size:11px}

.setup-config{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;margin:10px 0 18px}
.setup-config label{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--muted);font-weight:700;letter-spacing:1px}
.setup-config input,.setup-config select{padding:10px 12px;border-radius:10px;border:1px solid var(--line);background:#0c1424;color:var(--txt);font-size:14px;min-width:230px}
.setup-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.roster{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:16px}
.roster .rchip{display:flex;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--line);border-radius:30px;padding:5px 12px 5px 5px;font-size:13px;font-weight:700}
.roster .rdot{width:18px;height:18px;border-radius:50%}

/* ---------- big buttons ---------- */
.big-btn{padding:13px 22px;border-radius:12px;font-weight:800;letter-spacing:1.5px;font-size:15px;
  border:1px solid rgba(255,255,255,.16);background:linear-gradient(180deg,#2a3c66,#16233f);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 8px 22px rgba(0,0,0,.4);transition:.14s}
.big-btn:hover{transform:translateY(-2px);filter:brightness(1.12)}
.big-btn.go{background:linear-gradient(180deg,#2fae54,#178a3c);border-color:#5ff08a}
.big-btn.ghost{background:linear-gradient(180deg,#1a2238,#10182a)}
.big-btn.danger{background:linear-gradient(180deg,#b23046,#7a1828);border-color:#ff7a8a}
.big-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}

/* ---------- DOC pages (howto / credits) ---------- */
.doc-wrap{position:relative;z-index:2;width:min(820px,92vw);max-height:90vh;overflow:auto;
  background:linear-gradient(180deg,rgba(20,28,52,.92),rgba(10,16,30,.95));border:1px solid var(--line);
  border-radius:20px;padding:30px;box-shadow:var(--shadow);text-align:center}
.doc-body{text-align:left;color:#dfe7fb;line-height:1.7;font-size:15px;margin:6px 0 22px}
.doc-body h3{color:var(--gold);margin:18px 0 6px;letter-spacing:1px;font-size:16px}
.doc-body p{margin:8px 0;color:#cdd8f2}
.doc-body .kbd{display:inline-block;background:#0c1424;border:1px solid var(--line);border-radius:6px;padding:1px 8px;font-weight:700;color:var(--teal)}
.doc-body .lane{display:flex;gap:14px;align-items:flex-start;margin:10px 0;padding:10px;border:1px solid var(--line);border-radius:12px;background:rgba(255,255,255,.02)}
.doc-body .lane .ic{flex:0 0 auto}
.credits-wrap #creditsLogo{margin-bottom:8px}
.credits-line{font-size:15px;margin:6px 0}
.credits-line b{color:var(--gold)}

/* ============================================================
   IN-GAME
   ============================================================ */
#game{flex-direction:column;align-items:stretch;background:#05070f}
#hud{
  height:64px;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:0 16px;
  background:linear-gradient(180deg,#13203c,#0c1526);border-bottom:1px solid var(--line);
  box-shadow:0 6px 22px rgba(0,0,0,.5);z-index:5;flex:0 0 auto;
}
.hud-left{display:flex;align-items:center;gap:10px}
#hudAvatar{width:42px;height:42px;border-radius:10px;overflow:hidden;border:1px solid var(--line);background:#0c1424;flex:0 0 auto}
.hud-id #hudName{font-weight:800;letter-spacing:.5px}
.hud-sub{font-size:11px;color:var(--muted)}
.hud-stats{display:flex;gap:10px;flex:1;justify-content:center;flex-wrap:wrap}
.stat{display:flex;flex-direction:column;align-items:center;min-width:64px;gap:3px}
.stat .lab{font-size:9px;letter-spacing:1.5px;color:var(--muted);font-weight:700}
.stat .val{font-size:14px;font-weight:800}
.stat .bar{width:62px;height:6px;border-radius:6px;background:rgba(255,255,255,.1);overflow:hidden}
.stat .bar i{display:block;height:100%;border-radius:6px;transition:width .3s}
.stat.money .val{color:var(--gold)}
.hud-right{display:flex;align-items:center;gap:10px}
#hudClock{text-align:right;font-size:12px;font-weight:700;color:var(--teal);line-height:1.3}
#hudClock b{color:#fff;font-size:14px}
.hud-btn{padding:9px 14px;border-radius:10px;font-weight:800;letter-spacing:1px;border:1px solid var(--line);background:linear-gradient(180deg,#26375f,#16233f)}
.hud-btn:hover{filter:brightness(1.15)}

/* time wheel */
#timeWheel{position:relative;width:52px;height:52px;flex:0 0 auto}
#timeWheel svg{display:block;width:100%;height:100%;transform:rotate(-90deg)}
#timeWheel .wheel-bg{fill:none;stroke:rgba(255,255,255,.08);stroke-width:5}
#timeWheel .wheel-fill{fill:none;stroke-width:5;transition:stroke-dashoffset .3s ease, stroke .3s ease;stroke-linecap:round}
#timeWheel .wheel-center{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;font-weight:800}
#timeWheel .wheel-hours{font-size:16px;line-height:1;color:#fff}
#timeWheel .wheel-label{font-size:8px;color:var(--muted);letter-spacing:.5px}

#viewport{position:relative;flex:1;overflow:hidden;background:#070d18}
#mapLayer,#interiorLayer{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
#mapLayer svg,#interiorLayer svg{width:100%;height:100%;max-height:100%}
#overlayFx{position:absolute;inset:0;pointer-events:none;z-index:9}

/* map interactive bits */
.bldg{cursor:pointer;transition:filter .15s, transform .15s;transform-box:fill-box;transform-origin:center}
.bldg:hover{filter:brightness(1.12) drop-shadow(0 0 10px rgba(255,220,120,.6))}
.bldg.reach{}
.bldg.locked{filter:grayscale(.5) brightness(.7)}
.bldg-label{font:800 13px var(--font);fill:#fff;paint-order:stroke;stroke:#00000099;stroke-width:4px;pointer-events:none;letter-spacing:.5px}
.node-dot{cursor:pointer}
.player-token{transition:transform .5s cubic-bezier(.5,1.4,.5,1)}

/* dock */
#dock{flex:0 0 auto;background:linear-gradient(180deg,#0c1526,#0a1120);border-top:1px solid var(--line);padding:8px 12px 12px;z-index:5}
#ticker{height:22px;overflow:hidden;border-radius:8px;background:#070d18;border:1px solid var(--line);margin-bottom:8px;position:relative}
#tickerText{position:absolute;white-space:nowrap;line-height:22px;font-size:12px;font-weight:700;color:var(--teal);will-change:transform}
#actionBar{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;min-height:46px}
.act-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:11px;font-weight:800;letter-spacing:.5px;font-size:14px;
  border:1px solid rgba(255,255,255,.14);background:linear-gradient(180deg,#23345b,#15223c);box-shadow:inset 0 1px 0 rgba(255,255,255,.1);transition:.13s}
.act-btn:hover{transform:translateY(-2px);filter:brightness(1.13)}
.act-btn .cost{font-size:11px;color:var(--gold);font-weight:700}
.act-btn.go{background:linear-gradient(180deg,#2fae54,#178a3c);border-color:#5ff08a}
.act-btn.red{background:linear-gradient(180deg,#b23046,#7a1828);border-color:#ff7a8a}
.act-btn.ghost{background:linear-gradient(180deg,#1a2238,#10182a)}
.act-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}

/* goal tracker */
#goals{position:absolute;right:14px;top:78px;width:188px;background:linear-gradient(180deg,rgba(18,26,48,.95),rgba(10,16,30,.95));
  border:1px solid var(--line);border-radius:14px;padding:12px;z-index:6;box-shadow:var(--shadow)}
#goals h4{font-size:11px;letter-spacing:2px;color:var(--gold);margin-bottom:8px;text-align:center}
.goal{margin-bottom:9px}
.goal .gl{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);font-weight:700;margin-bottom:3px}
.goal .gbar{height:8px;border-radius:8px;background:rgba(255,255,255,.08);overflow:hidden}
.goal .gbar i{display:block;height:100%;border-radius:8px;transition:width .4s}
#goalTotal{text-align:center;margin-top:8px;font-weight:800;color:var(--teal)}

/* ============================================================
   MODAL
   ============================================================ */
.modal{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;
  background:rgba(2,5,12,.72);backdrop-filter:blur(6px);opacity:0;pointer-events:none;transition:opacity .25s}
.modal:not(.hidden){opacity:1;pointer-events:auto}
.modal-card{width:min(720px,94vw);max-height:90vh;overflow:auto;background:linear-gradient(180deg,#16203c,#0c1424);
  border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);padding:0}
.modal-title{padding:18px 22px;font-size:20px;font-weight:800;letter-spacing:1px;color:var(--gold);
  border-bottom:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.04),transparent)}
.modal-body{padding:18px 22px;line-height:1.6;color:#dde6fb}
.modal-actions{padding:14px 22px 20px;display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.pause-card{width:min(420px,92vw)}
.pause-btns{display:flex;flex-direction:column;gap:10px;padding:20px}

/* store / interior generic UI */
.shelf{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-top:6px}
.item{border:1px solid var(--line);border-radius:12px;background:linear-gradient(180deg,#16213c,#0e1626);padding:10px;text-align:center;transition:.13s}
.item:hover{border-color:var(--teal);transform:translateY(-2px)}
.item .iname{font-weight:800;margin:6px 0 2px}
.item .idesc{font-size:11px;color:var(--muted);min-height:28px}
.item .iprice{color:var(--gold);font-weight:800;margin:6px 0}
.item button{width:100%;padding:8px;border-radius:9px;border:1px solid var(--line);background:linear-gradient(180deg,#2a3c66,#16233f);font-weight:800}
.item button:hover{filter:brightness(1.15)}
.item.owned{opacity:.55}
.row-line{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--line)}
.row-line:last-child{border-bottom:0}
.muted{color:var(--muted)}
.gold{color:var(--gold)}
.green{color:var(--green)}
.red{color:var(--red)}
.center{text-align:center}
.big-num{font-size:30px;font-weight:900;letter-spacing:1px}

/* toast */
#toast{position:fixed;bottom:96px;left:50%;transform:translateX(-50%);z-index:80;display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none}
.toast{padding:11px 20px;border-radius:30px;font-weight:800;letter-spacing:.5px;font-size:14px;
  background:linear-gradient(180deg,#1c2a4c,#111a30);border:1px solid var(--line);box-shadow:var(--shadow);
  animation:toastIn .3s ease, toastOut .3s ease 2.4s forwards}
.toast.good{border-color:#3fe07a;color:#bfffd6}
.toast.bad{border-color:#ff6a7a;color:#ffd3d8}
.toast.gold{border-color:var(--gold);color:#fff2c9}
@keyframes toastIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes toastOut{to{opacity:0;transform:translateY(-10px)}}

/* fx flashes */
.fx-flash{position:absolute;inset:0;background:radial-gradient(circle,rgba(255,255,255,.7),transparent 60%);opacity:0;pointer-events:none}
@keyframes flash{0%{opacity:.9}100%{opacity:0}}
.alarm{animation:alarmpulse .5s infinite}
@keyframes alarmpulse{0%,100%{box-shadow:inset 0 0 0 0 rgba(255,0,0,0)}50%{box-shadow:inset 0 0 120px 0 rgba(255,0,0,.45)}}

/* intoxication wobble */
#viewport.tipsy{animation:tipsy 6s ease-in-out infinite}
@keyframes tipsy{0%,100%{filter:hue-rotate(0) saturate(1)}50%{filter:hue-rotate(18deg) saturate(1.3) blur(.4px)}}

/* casino specifics */
.casino-tabs{display:flex;gap:8px;justify-content:center;margin-bottom:10px;flex-wrap:wrap}
.casino-tab{padding:9px 16px;border-radius:10px;font-weight:800;border:1px solid var(--line);background:#16233f}
.casino-tab.sel{background:linear-gradient(180deg,#caa23a,#8a6c20);color:#1a1405;border-color:var(--gold)}
.bet-row{display:flex;gap:8px;align-items:center;justify-content:center;flex-wrap:wrap;margin:10px 0}
.chip{width:46px;height:46px;border-radius:50%;border:3px dashed rgba(255,255,255,.6);font-weight:900;font-size:12px;display:flex;align-items:center;justify-content:center;transition:.12s}
.chip:hover{transform:translateY(-3px) scale(1.05)}
.chip.c1{background:#e8e8e8;color:#222}
.chip.c5{background:#e23b3b;color:#fff}
.chip.c25{background:#2eae57;color:#fff}
.chip.c100{background:#222;color:#fff}
.chip.c500{background:#7a3bd1;color:#fff}

/* responsive */
@media (max-width:760px){
  .mode-row{grid-template-columns:repeat(2,1fr)}
  .char-row{grid-template-columns:repeat(2,1fr)}
  .hud-stats .stat{min-width:54px}
}
