:root{
  --shell:#d9d4c5;
  --shell-dark:#c2bcab;
  --shell-line:#8d8775;
  --bezel:#2b2b28;
  --lcd:#aab39a;          /* зеленовато-серый экран */
  --lcd-dim:#9aa489;
  --seg:#1c1f17;          /* "пиксели" сегментов */
  --red:#c8362c;
  --red-dark:#8f201a;
  --brand-red:#b5322a;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;}
body{
  margin:0;
  background:radial-gradient(circle at 50% 30%, #3a3f46, #1a1c20 70%);
  font-family:"Helvetica Neue",Arial,sans-serif;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  min-height:100vh;
  padding:16px;
  gap:14px;
  user-select:none;
}

/* ---------- Корпус ---------- */
.console{
  position:relative;
  display:flex;
  align-items:stretch;
  gap:10px;
  background:
    /* состаренные пятна/неравномерность пластика */
    radial-gradient(120% 80% at 20% 0%, rgba(255,252,240,.55), transparent 55%),
    radial-gradient(140% 90% at 90% 110%, rgba(120,108,80,.22), transparent 60%),
    linear-gradient(160deg,#eae3d2 0%,#ddd4bf 45%,#cabfa4 100%);
  border:2px solid #b3ad9b;
  border-radius:26px;
  padding:20px 18px;
  box-shadow:
    inset 0 2px 6px rgba(255,255,255,.65),
    inset 0 -7px 16px rgba(80,70,45,.22),
    inset 0 0 0 6px rgba(255,255,255,.10),
    0 20px 46px rgba(0,0,0,.6);
  max-width:840px;
  width:100%;
}
/* лёгкая зернистость пластика */
.console::before{
  content:"";position:absolute;inset:0;border-radius:24px;pointer-events:none;
  background-image:
    repeating-linear-gradient(115deg, rgba(0,0,0,.018) 0 2px, transparent 2px 4px);
  mix-blend-mode:multiply;opacity:.6;
}

/* винтики по углам */
.screw{
  position:absolute;width:13px;height:13px;border-radius:50%;
  background:radial-gradient(circle at 38% 32%, #f1ecdf, #9c947f 75%, #7d765f);
  box-shadow:inset 0 1px 1px rgba(255,255,255,.7),inset 0 -1px 2px rgba(0,0,0,.35),0 1px 1px rgba(0,0,0,.25);
  z-index:3;
}
.screw::after{
  content:"";position:absolute;inset:0;margin:auto;width:9px;height:2px;border-radius:1px;
  background:rgba(60,54,38,.7);transform:rotate(40deg);
}
.screw.tl{top:9px;left:9px;}
.screw.tr{top:9px;right:9px;}
.screw.bl{bottom:9px;left:9px;}
.screw.br{bottom:9px;right:9px;}

.side{display:flex;flex-direction:column;align-items:center;justify-content:space-between;gap:14px;padding:6px 2px;}
.side-left{justify-content:space-between;}

.badge{
  width:62px;height:62px;border-radius:50%;
  border:3px solid #2b2b28;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-weight:800;color:#2b2b28;line-height:.95;font-size:20px;letter-spacing:1px;
  background:radial-gradient(circle at 40% 35%, #efeade, #d2ccba);
  box-shadow:inset 0 1px 2px rgba(255,255,255,.7);
}

.redbtn{
  width:54px;height:54px;border-radius:50%;
  border:none;cursor:pointer;
  background:radial-gradient(circle at 38% 32%, #e8584d, var(--red));
  box-shadow:
    inset 0 2px 3px rgba(255,255,255,.45),
    inset 0 -4px 8px var(--red-dark),
    0 4px 8px rgba(0,0,0,.4);
  color:rgba(255,255,255,.6);font-size:18px;
  transition:transform .04s;
}
.redbtn:active{transform:translateY(2px);box-shadow:inset 0 2px 6px var(--red-dark),0 1px 2px rgba(0,0,0,.4);}

.modes{display:flex;flex-direction:column;gap:9px;width:100%;}
.mode{display:flex;align-items:center;gap:6px;justify-content:flex-end;}
.caps{font-size:11px;font-weight:700;color:#4a4636;letter-spacing:.5px;}
.modebtn{
  width:30px;height:18px;border-radius:9px;border:1px solid #a59f8d;cursor:pointer;
  background:linear-gradient(#f0ebde,#d4cebd);font-size:10px;
  box-shadow:inset 0 1px 1px rgba(255,255,255,.7),0 1px 2px rgba(0,0,0,.2);
  display:flex;align-items:center;justify-content:center;padding:0;
}
.modebtn:active{transform:translateY(1px);}
.modebtn.off{opacity:.4;}

/* ---------- Центр / заголовок ---------- */
.center{flex:1;display:flex;flex-direction:column;align-items:center;min-width:0;}
.title{text-align:center;margin-bottom:8px;}
.brand{
  color:var(--brand-red);font-weight:800;letter-spacing:7px;font-size:26px;
  text-shadow:0 1px 0 rgba(255,255,255,.7), 0 -1px 1px rgba(120,20,15,.4);
}
.subtitle{
  color:#2b2b28;font-weight:800;letter-spacing:3px;font-size:15px;margin-top:3px;
  text-shadow:0 1px 0 rgba(255,255,255,.6);
}
.brand-bottom{
  color:#2b2b28;font-weight:800;letter-spacing:5px;font-size:18px;margin-top:8px;opacity:.85;
  text-shadow:0 1px 0 rgba(255,255,255,.55);
}

/* ---------- Экран ---------- */
.bezel{
  background:linear-gradient(#1f1f1c,#36352f);
  border-radius:14px;
  padding:14px;
  width:100%;
  box-shadow:inset 0 3px 10px rgba(0,0,0,.7),0 1px 0 rgba(255,255,255,.25);
}
.screen-wrap{position:relative;width:100%;border-radius:6px;overflow:hidden;background:var(--lcd);}
canvas#game{
  display:block;width:100%;height:auto;
  background:var(--lcd);
  image-rendering:pixelated;
  image-rendering:crisp-edges;
}
/* пиксельная LCD-сетка + виньетка + лёгкий зелёный тон */
.lcd-fx{
  position:absolute;inset:0;pointer-events:none;z-index:2;
  background:
    repeating-linear-gradient(0deg, rgba(20,24,15,.10) 0 1px, transparent 1px 3px),
    repeating-linear-gradient(90deg, rgba(20,24,15,.10) 0 1px, transparent 1px 3px),
    radial-gradient(120% 130% at 50% 45%, transparent 60%, rgba(30,40,20,.30) 100%);
  mix-blend-mode:multiply;
}
/* глянцевый блик стекла */
.lcd-glare{
  position:absolute;inset:0;pointer-events:none;z-index:2;
  background:linear-gradient(125deg, rgba(255,255,255,.30) 0%, rgba(255,255,255,.06) 14%, transparent 32%);
}

/* ---------- Оверлеи ---------- */
.overlay{
  position:absolute;inset:0;z-index:5;
  background:rgba(150,160,135,.92);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;color:var(--seg);padding:18px;gap:12px;
}
.overlay.hidden{display:none;}
.ov-title{font-weight:800;letter-spacing:2px;font-size:clamp(18px,4vw,30px);}
.ov-text{font-size:clamp(11px,2.4vw,15px);line-height:1.6;font-weight:600;}
.ov-text b{background:var(--seg);color:var(--lcd);padding:0 4px;border-radius:2px;}
.ov-hi{font-size:13px;font-weight:700;opacity:.8;}
.startbtn{
  margin-top:4px;padding:10px 26px;border:none;border-radius:8px;cursor:pointer;
  background:radial-gradient(circle at 38% 32%, #e8584d, var(--red));
  color:#fff;font-weight:800;letter-spacing:2px;font-size:16px;
  box-shadow:inset 0 2px 3px rgba(255,255,255,.4),inset 0 -4px 8px var(--red-dark),0 4px 8px rgba(0,0,0,.35);
}
.startbtn:active{transform:translateY(2px);}
.ov-btns{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;}
.startbtn.ghost{
  background:transparent;color:var(--seg);
  border:2px solid var(--seg);box-shadow:none;font-size:14px;padding:9px 18px;
}
.startbtn.ghost:active{transform:translateY(2px);background:rgba(28,31,23,.08);}

/* ---------- Мобильные кнопки ---------- */
.touch-actions{display:none;gap:14px;}
.touchbtn{
  flex:1;padding:16px;border:none;border-radius:14px;cursor:pointer;
  background:linear-gradient(#3a3f46,#23262b);color:#e9e4d6;font-weight:800;letter-spacing:1px;font-size:14px;
  box-shadow:0 4px 10px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.1);
}
.touchbtn:active{transform:translateY(2px);}

@media (max-width:760px){
  .brand{font-size:18px;letter-spacing:3px;}
  .subtitle{font-size:11px;}
  .badge{width:46px;height:46px;font-size:15px;}
  .redbtn{width:46px;height:46px;}
  .console{padding:12px 8px;border-radius:18px;}
  .touch-actions{display:flex;width:100%;max-width:840px;}
}
