/* ============================================================
   Parlor — the Yahtzee design language.
   Felt table, aged card, red/black print, pencil-blue entries.
   ============================================================ */
:root{
  --felt:#234E3A; --felt-deep:#193a2b;
  --card:#F4ECD8; --card-edge:#e3d8bd;
  --ink:#1A1A17; --rouge:#B23A30; --rouge-deep:#8f2d25;
  --bone:#FBF7EE; --brass:#B08D57; --brass-bright:#cda86c;
  --rule:#9bb0a0; --pencil:#243a8f;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
html{background:var(--felt-deep);overscroll-behavior:none}
body{
  font-family:"Crimson Pro",Georgia,serif;font-size:18px;color:var(--ink);
  min-height:100dvh;
  padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
  background:radial-gradient(120% 90% at 50% 0%, #2c6049 0%, var(--felt) 44%, var(--felt-deep) 100%);
  position:relative;
}
body.locked{overflow:hidden;touch-action:manipulation;padding:0}
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.45;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix type='saturate' values='0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/></svg>");
}
.stage{position:relative;z-index:1;max-width:560px;margin:0 auto;padding:18px 16px 40px}

/* ---------- headings ---------- */
.masthead{text-align:center;margin:8px 0 14px}
.masthead h1{
  font-family:"Rye",serif;font-weight:400;color:var(--bone);
  font-size:clamp(40px,11vw,58px);line-height:.9;margin:0;
  text-shadow:0 2px 0 rgba(0,0,0,.25);
}
.masthead .sub{color:#cfe0d6;font-style:italic;letter-spacing:.06em;margin-top:4px;opacity:.85}

/* ---------- mode picker ---------- */
.modes{display:flex;flex-direction:column;gap:14px;margin-top:8px}
.mode{
  display:block;text-decoration:none;color:var(--ink);
  background:linear-gradient(180deg, rgba(255,255,255,.35), rgba(0,0,0,.04)), var(--card);
  border:1px solid var(--card-edge);border-radius:12px;padding:16px 18px;
  box-shadow:0 1px 0 rgba(255,255,255,.5) inset, 0 14px 30px -14px rgba(0,0,0,.55);
  transition:transform .08s ease;
}
.mode:active{transform:translateY(2px)}
.mode .nm{font-family:"Rye",serif;color:var(--rouge);font-size:23px;line-height:1}
.mode .desc{font-size:15.5px;color:#5d5648;margin-top:5px;line-height:1.3}
.mode.soon{opacity:.72}
.mode .pill{
  float:right;font-size:12px;font-variant:small-caps;letter-spacing:.08em;
  background:var(--brass);color:#3a2a14;border-radius:20px;padding:2px 10px;margin-top:3px;
}
.foot{text-align:center;color:#bcd0c4;font-size:13px;font-style:italic;margin-top:22px;opacity:.7}

/* ---------- the card ---------- */
.card{
  background:linear-gradient(180deg, rgba(255,255,255,.35), rgba(0,0,0,.04)), var(--card);
  border-radius:8px;border:1px solid var(--card-edge);
  box-shadow:0 1px 0 rgba(255,255,255,.5) inset, 0 18px 40px -12px rgba(0,0,0,.55);
  padding:16px 16px 20px;position:relative;
}
.card::after{
  content:"";position:absolute;inset:0;border-radius:8px;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='p'><feTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='3'/></filter><rect width='100%25' height='100%25' filter='url(%23p)'/></svg>");
}
.card .title{text-align:center;margin:0 0 6px}
.card .title h2{font-family:"Rye",serif;font-weight:400;color:var(--rouge);font-size:34px;margin:0;line-height:1}
.namefield{
  display:block;width:100%;text-align:center;border:none;background:transparent;
  font-family:"Caveat",cursive;font-size:26px;color:var(--pencil);margin:2px 0 4px;
  border-bottom:1px dashed #c9bd9f;padding:2px 0;
}
.namefield::placeholder{color:#b8ad92}
.namefield:focus{outline:none;border-bottom-color:var(--brass)}

.section-band{
  background:var(--rouge);color:var(--bone);font-variant:small-caps;letter-spacing:.12em;
  font-weight:600;font-size:15px;padding:5px 12px;border-radius:3px;margin:16px 0 2px;
  box-shadow:0 1px 0 rgba(255,255,255,.25) inset, 0 1px 2px rgba(0,0,0,.25);
  display:flex;justify-content:space-between;align-items:center;
}
.section-band .pts{opacity:.85;font-size:11px;font-variant:normal;letter-spacing:.04em}

.rows{width:100%;border-collapse:collapse;font-size:18px}
.rows td{padding:0;border-bottom:1px solid var(--rule)}
.rows tr:last-child td{border-bottom:none}
.row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 6px;width:100%;
  background:none;border:none;text-align:left;font:inherit;color:inherit;cursor:pointer}
.row:disabled{cursor:default}
.row .cat{display:flex;flex-direction:column;min-width:0}
.row .cat .name{font-weight:600}
.row .cat .hint{font-size:13.5px;font-style:italic;color:#7a7263;line-height:1.15}
.score{
  flex:0 0 auto;min-width:54px;height:42px;line-height:42px;text-align:center;
  background:linear-gradient(180deg,#fffdf6,#efe6cf);border:1px solid #cdbf9d;border-radius:5px;
  box-shadow:0 1px 2px rgba(0,0,0,.12) inset;
  font-family:"Caveat",cursive;font-size:30px;color:var(--pencil);
}
.score.empty{color:#c3b896}
.row.scored .score{animation:ink .35s ease}
@keyframes ink{from{transform:scale(.7);opacity:.2}to{transform:scale(1);opacity:1}}

.subrow{display:flex;align-items:center;justify-content:space-between;padding:7px 6px;
  font-variant:small-caps;letter-spacing:.05em;color:#5d5648}
.subrow .score{pointer-events:none}
.bonus-note{font-style:italic;text-transform:none;letter-spacing:0;font-size:13px;color:#7a7263}
.grandrow{display:flex;align-items:center;justify-content:space-between;padding:11px 6px 2px;
  border-top:2px solid var(--ink);margin-top:4px}
.grandrow .name{font-family:"Rye",serif;color:var(--rouge);font-size:21px}
.grandrow .score{font-size:33px;font-weight:700;color:var(--rouge-deep);background:#fff}

/* ---------- action bar ---------- */
.actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:18px}
.btn{
  appearance:none;cursor:pointer;border:none;font-family:"Crimson Pro",serif;font-size:16px;
  padding:12px 18px;border-radius:11px;background:rgba(0,0,0,.28);color:#eef3ef;
  border:1px solid rgba(255,255,255,.16);
}
.btn:active{transform:translateY(2px)}
.btn.primary{
  font-family:"Rye",serif;color:#3a2a14;letter-spacing:.02em;
  background:radial-gradient(120% 120% at 30% 20%, var(--brass-bright), var(--brass) 55%, #7c6133 100%);
  box-shadow:0 5px 0 #6b5328, 0 9px 16px rgba(0,0,0,.4), 0 1px 1px rgba(255,255,255,.5) inset;
  border:none;
}
.btn.primary:active{box-shadow:0 2px 0 #6b5328, 0 6px 12px rgba(0,0,0,.4) inset}
.linkrow{text-align:center;margin-top:16px}
.linkrow a{color:#cfe0d6;font-size:14px;font-style:italic;text-decoration:none;border-bottom:1px dotted #7fa28e}

/* ---------- entry sheet ---------- */
.sheet-scrim{position:fixed;inset:0;background:rgba(10,20,15,.55);z-index:40;display:none}
.sheet-scrim.open{display:block}
.sheet{
  position:fixed;left:0;right:0;bottom:0;z-index:50;transform:translateY(100%);
  transition:transform .22s ease;
  background:linear-gradient(180deg, rgba(255,255,255,.4), rgba(0,0,0,.05)), var(--card);
  border-radius:16px 16px 0 0;border-top:1px solid var(--card-edge);
  box-shadow:0 -14px 36px -10px rgba(0,0,0,.5);
  padding:14px 16px calc(20px + env(safe-area-inset-bottom));max-width:560px;margin:0 auto;
}
.sheet.open{transform:translateY(0)}
.sheet .grip{width:42px;height:5px;border-radius:3px;background:#cbbf9f;margin:0 auto 10px}
.sheet h3{margin:0 0 2px;font-family:"Rye",serif;font-weight:400;color:var(--rouge);font-size:24px;text-align:center}
.sheet .hint{text-align:center;font-style:italic;color:#7a7263;font-size:14px;margin:0 0 12px}
.chips{display:flex;flex-wrap:wrap;gap:9px;justify-content:center}
.chip{
  cursor:pointer;border:1px solid #cdbf9d;border-radius:10px;background:#fffdf6;color:var(--ink);
  font-family:"Caveat",cursive;font-size:26px;min-width:60px;height:54px;padding:0 12px;
  box-shadow:0 2px 4px rgba(0,0,0,.1);
}
.chip.zero{font-family:"Crimson Pro",serif;font-size:16px;font-style:italic;color:#8f2d25}
.chip:active{transform:translateY(2px)}
.stepper{display:flex;align-items:center;justify-content:center;gap:16px;margin:6px 0}
.stepper button{width:56px;height:56px;border-radius:50%;border:1px solid #cdbf9d;background:#fffdf6;
  font-size:30px;font-family:"Crimson Pro",serif;cursor:pointer;color:var(--rouge)}
.stepper .val{font-family:"Caveat",cursive;font-size:46px;color:var(--pencil);min-width:80px;text-align:center}
.sheet .confirm{display:flex;gap:10px;margin-top:14px}
.sheet .confirm .btn{flex:1;text-align:center}

/* ---------- printable (shared by both print buttons) ---------- */
.print-only{display:none}
@media print{
  body{background:#fff;color:#000;padding:0}
  body::before{display:none}
  .stage,.actions,.linkrow,.sheet,.sheet-scrim{display:none !important}
  .print-only{display:block}
  @page{size:portrait;margin:12mm}
  .psheet{width:auto}
  .phead{text-align:center}
  .phead h1{font-family:"Rye",serif;font-weight:400;color:#B23A30;margin:0;font-size:34px}
  .phead .tag{font-style:italic;color:#555;font-size:12px}
  table.pad{width:100%;border-collapse:collapse;margin-top:8px;table-layout:fixed}
  table.pad col.cat{width:42%}
  table.pad th,table.pad td{border:1px solid #3a3a35}
  table.pad thead th{background:#B23A30;color:#fff;font-variant:small-caps;font-size:12px;padding:4px}
  table.pad thead th.cat{background:#fff;color:#000;border:none}
  table.pad .band td{background:#f1e9d6;color:#B23A30;font-variant:small-caps;font-weight:600;font-size:12px;padding:3px 8px}
  table.pad .pc{padding:4px 8px;line-height:1.05}
  table.pad .pc .nm{font-weight:600;font-size:14px}
  table.pad .pc .ht{font-size:10px;font-style:italic;color:#888}
  table.pad td.num{height:30px;text-align:center;font-family:"Caveat",cursive;font-size:22px;color:#243a8f}
  table.pad .sub td,table.pad .tot td{background:#faf6ea}
  table.pad .grand td{border-top:2px solid #000;height:34px}
  table.pad .grand .pc{font-family:"Rye",serif;color:#B23A30}
}

/* ============================================================
   Digital mode — home, join, board (TV-first), phone controller
   ============================================================ */
.choice{display:flex;flex-direction:column;gap:14px;margin-top:8px}
.codebig{font-family:"Rye",serif;color:var(--bone);letter-spacing:.18em;font-size:44px;text-align:center}
.codeentry{width:100%;text-align:center;font-family:"Rye",serif;font-size:34px;letter-spacing:.22em;
  text-transform:uppercase;border:1px solid var(--card-edge);border-radius:10px;padding:12px;color:var(--pencil);
  background:#fffdf6}
.codeentry:focus{outline:none;border-color:var(--brass)}
.styleopts{display:flex;gap:10px;margin:4px 0 2px}
.styleopt{flex:1;cursor:pointer;border:1px solid var(--card-edge);border-radius:11px;background:#fffdf6;padding:11px;text-align:center}
.styleopt input{display:none}
.styleopt .t{font-family:"Rye",serif;color:var(--rouge);font-size:18px}
.styleopt .d{font-size:13px;color:#6b6354;font-style:italic;line-height:1.2;margin-top:2px}
.styleopt.sel{border-color:var(--brass);background:#fff6e6;box-shadow:0 0 0 2px var(--brass) inset}
.err{color:#ffd9d3;background:rgba(178,58,48,.35);border:1px solid rgba(178,58,48,.6);
  border-radius:8px;padding:8px 12px;text-align:center;font-style:italic;margin-bottom:10px}

/* ---- board ---- */
.board{position:fixed;inset:0;display:flex;flex-direction:column;overflow:hidden}
.board-head{flex:0 0 auto;z-index:3;display:flex;align-items:center;justify-content:space-between;
  padding:10px 16px;gap:12px}
.board-head .bt{font-family:"Rye",serif;color:var(--bone);font-size:clamp(22px,3.4vw,34px)}
.board-head .code{font-family:"Rye",serif;color:var(--brass-bright);letter-spacing:.2em;font-size:clamp(20px,3vw,30px)}
#lobby,#over{flex:1 1 auto;overflow:auto;min-height:0}
#play{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;position:relative}
.board-grid{flex:1 1 auto;min-height:0;margin:2px 12px;border-radius:10px;overflow:auto}
.sb{width:100%;border-collapse:collapse;color:#eef3ef;font-size:clamp(15px,2.1vw,22px);
  background:rgba(0,0,0,.16);border:1px solid rgba(255,255,255,.1);border-radius:10px}
.sb th,.sb td{padding:6px 10px;border-bottom:1px solid rgba(255,255,255,.08);text-align:center}
.sb th.cat,.sb td.cat{text-align:left;white-space:nowrap;color:#cfe0d6}
.sb thead th{font-family:"Rye",serif;font-weight:400;color:var(--bone);font-size:clamp(16px,2.4vw,26px);
  border-bottom:2px solid var(--brass)}
.sb thead th.active{color:#fff;background:linear-gradient(180deg, rgba(176,141,87,.5), rgba(176,141,87,.18))}
.sb td.active{background:rgba(176,141,87,.16)}
.sb .val{font-family:"Caveat",cursive;font-size:clamp(20px,2.6vw,30px);color:#fff}
.sb .val.fresh{animation:ink .4s ease}
.sb .secband td{background:rgba(178,58,48,.5);color:var(--bone);font-variant:small-caps;letter-spacing:.1em;
  font-size:13px;text-align:left}
.sb .totrow td{font-family:"Rye",serif;color:var(--brass-bright);border-top:2px solid var(--brass);font-size:clamp(17px,2.4vw,26px)}
.sb .bonus td{color:#cfe0d6;font-style:italic;font-size:13px}

#board-dice{position:absolute;left:0;right:0;top:0;bottom:0;z-index:5;pointer-events:auto}
.drive-bar{position:relative;z-index:6;flex:0 0 auto;display:flex;gap:12px;align-items:center;justify-content:center;
  padding:10px 16px calc(12px + env(safe-area-inset-bottom));
  background:linear-gradient(0deg, rgba(15,30,22,.78), rgba(15,30,22,.35) 70%, transparent)}
.turnlabel{color:var(--bone);font-family:"Rye",serif;font-size:clamp(16px,2.4vw,24px);min-width:0}
.turnlabel b{color:var(--brass-bright)}

/* ---- phone controller ---- */
.ctrl{min-height:100dvh;display:flex;flex-direction:column}
.ctrl-head{display:flex;justify-content:space-between;align-items:baseline;padding:10px 16px;color:#cfe0d6}
.ctrl-head .code{font-family:"Rye",serif;color:var(--brass-bright);letter-spacing:.18em}
.turnbanner{text-align:center;margin:6px 16px 0;color:var(--bone);font-family:"Rye",serif;font-size:24px}
.turnbanner.you{color:var(--brass-bright)}
#play-dice{width:100%;height:34vh}
.ctrl .rollbar{display:flex;gap:12px;align-items:center;justify-content:center;padding:6px 0 2px}
.rolls{font-family:"Rye",serif;color:#e7d9b6;font-size:18px;min-width:54px;text-align:center}
.waiting{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#cfe0d6;text-align:center;padding:20px}
.waiting .big{font-family:"Rye",serif;color:var(--bone);font-size:30px}
.mini{margin:8px 16px 0;background:rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:8px 12px;color:#eef3ef}
.mini .r{display:flex;justify-content:space-between;padding:3px 0;font-size:15px}
.mini .r.lead b{color:var(--brass-bright)}
.winbanner{text-align:center;color:var(--bone);margin:14px 16px}
.winbanner .crown{font-family:"Rye",serif;color:var(--brass-bright);font-size:34px}

/* ---- assign sheet (digital) ---- */
.catlist{max-height:50vh;overflow:auto;display:flex;flex-direction:column;gap:8px;padding:2px}
.catbtn{display:flex;align-items:center;justify-content:space-between;gap:10px;cursor:pointer;
  border:1px solid #cdbf9d;border-radius:10px;background:#fffdf6;color:var(--ink);
  padding:10px 14px;font:inherit;text-align:left}
.catbtn:active{transform:translateY(1px)}
.catbtn .nm{font-weight:600}
.catbtn .pv{font-family:"Caveat",cursive;font-size:26px;color:var(--pencil);min-width:40px;text-align:right}
.catbtn .pv.zero{color:#a0967d}
.sheet .back{background:none;border:none;color:var(--rouge);font:inherit;font-style:italic;cursor:pointer;margin-bottom:6px}

/* ---- digital home hierarchy + board lobby seating ---- */
.bigstart{display:block;width:100%;text-align:left;cursor:pointer;border:none;border-radius:14px;padding:20px;color:#3a2a14;
  background:radial-gradient(140% 140% at 25% 15%, var(--brass-bright), var(--brass) 55%, #7c6133 100%);
  box-shadow:0 6px 0 #6b5328, 0 12px 22px rgba(0,0,0,.4), 0 1px 1px rgba(255,255,255,.5) inset}
.bigstart:active{transform:translateY(3px);box-shadow:0 3px 0 #6b5328, 0 8px 16px rgba(0,0,0,.4) inset}
.bigstart .nm{font-family:"Rye",serif;font-size:26px;line-height:1}
.bigstart .desc{font-size:15px;margin-top:6px;color:#46340f;line-height:1.35}
.orline{display:flex;align-items:center;gap:12px;color:#bcd0c4;margin:18px 4px;font-style:italic;font-size:14px}
.orline::before,.orline::after{content:"";flex:1;height:1px;background:rgba(255,255,255,.18)}
.join-card .nm{font-family:"Rye",serif;color:var(--rouge);font-size:20px;text-align:center}
.addseat{display:flex;flex-direction:column;gap:8px;margin:12px 0 4px;padding:12px;border:1px dashed #c9bd9f;border-radius:10px}
.addseat .row1{display:flex;gap:8px}
.addseat input{flex:1;border:1px solid #cdbf9d;border-radius:8px;padding:9px 12px;font-family:"Caveat",cursive;font-size:24px;color:var(--pencil);background:#fffdf6}
.addseat input:focus{outline:none;border-color:var(--brass)}
.addseat .styleopt{padding:7px}
.addseat .styleopt .t{font-size:16px}
.seatchip{display:inline-flex;align-items:center;gap:7px;background:#fff6e6;border:1px solid var(--brass);border-radius:18px;padding:4px 12px;margin:3px;font-size:16px;color:var(--ink)}
.seatchip .tag{font-size:11px;font-variant:small-caps;letter-spacing:.06em;color:#7c6133;background:rgba(176,141,87,.18);border-radius:10px;padding:1px 7px}

/* ---- phone: your-card view ---- */
.ycard-head{margin:14px 16px 4px;color:#cfe0d6;font-variant:small-caps;letter-spacing:.1em;font-size:14px;
  display:flex;justify-content:space-between;align-items:baseline}
.ycard-head .bn{font-style:italic;font-size:12px;color:#bcd0c4}
.ycard{margin:0 16px;display:grid;grid-template-columns:1fr 1fr;gap:2px 12px}
.ycard .yc{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:5px 8px;
  border-bottom:1px solid rgba(255,255,255,.08);color:#dfe9e2;font-size:14px}
.ycard .yc .nm{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ycard .yc .v{font-family:"Caveat",cursive;font-size:21px;color:#fff;min-width:26px;text-align:right}
.ycard .yc .v.preview{color:var(--brass-bright)}
.ycard .yc .v.empty{color:#6f8579;font-family:"Crimson Pro",serif;font-size:15px}
.ycard .yc.filled .nm{color:#9fb8aa}

/* ============================================================
   Dice mode — standalone dice cup (accessibility)
   ============================================================ */
.dicemode{height:100dvh;display:flex;flex-direction:column;overflow:hidden}
.dm-head{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;
  padding:calc(12px + env(safe-area-inset-top)) max(18px,env(safe-area-inset-right)) 12px max(18px,env(safe-area-inset-left))}
.dm-head .bt{font-family:"Rye",serif;color:var(--bone);font-size:clamp(30px,7vw,44px)}
.dm-head .dm-back{color:#cfe0d6;font-style:italic;text-decoration:none;font-size:15px;border-bottom:1px dotted #7fa28e}
.dm-body{flex:1 1 auto;display:flex;flex-direction:column;min-height:0}
#dice-canvas{flex:1 1 auto;width:100%;min-height:0;min-width:0;display:block;touch-action:manipulation;cursor:pointer}
.dm-foot{flex:0 0 auto;display:flex;flex-direction:column;justify-content:center}
.dm-hint{text-align:center;color:#cfe0d6;font-style:italic;font-size:16px;min-height:22px;margin:4px 0}
.dm-controls{display:flex;gap:14px;align-items:center;justify-content:center;padding:8px 16px}
.dm-cup{font-size:22px;padding:18px 34px}
.dm-rolls{font-family:"Rye",serif;color:#e7d9b6;font-size:22px;min-width:64px;text-align:center}
.dm-locked{text-align:center;color:#f3ddd9;background:rgba(178,58,48,.2);border:1px solid rgba(178,58,48,.45);
  margin:6px 16px;border-radius:12px;padding:10px;font-style:italic}
.dicemode .btn{font-size:17px;padding:14px 20px}
.dm-lite{display:flex;align-items:center;justify-content:center;gap:8px;color:#9fb8aa;font-size:13px;
  padding:8px 16px calc(8px + env(safe-area-inset-bottom));font-style:italic}
.dm-lite input{width:18px;height:18px}
.dm-lite span{opacity:.7}

/* ============================================================
   Single-player mode — scrollable parchment card + CSS dice bar
   ============================================================ */
.solo{height:100dvh;display:flex;flex-direction:column;overflow:hidden}
.solo-head{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;
  padding:calc(10px + env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) 10px max(16px,env(safe-area-inset-left))}
.solo-head .bt{font-family:"Rye",serif;color:var(--bone);font-size:clamp(26px,6.5vw,40px)}
.solo-head .solo-back{color:#cfe0d6;font-style:italic;text-decoration:none;font-size:15px;border-bottom:1px dotted #7fa28e}
.solo-card{flex:1 1 auto;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:4px 16px 14px}
.solo-card .card{max-width:560px;margin:6px auto}
.solo-card .card .title h2{font-size:28px}
.solo-card .row[data-cat]{background:linear-gradient(180deg,rgba(205,168,108,.16),rgba(205,168,108,.05))}
.solo-card .row.filled .name{color:#8a8270}
.score.preview{color:var(--brass);font-style:italic}
.solo-card .row.pendingrow{background:linear-gradient(180deg,rgba(205,168,108,.24),rgba(205,168,108,.08));border-radius:6px}
.solo-card .row.pendingrow .score{border-color:var(--brass);
  box-shadow:0 0 0 2px rgba(205,168,108,.4),0 1px 2px rgba(0,0,0,.12) inset}
.score.pending{color:var(--pencil)}
.solo-done{margin:14px 2px 2px;text-align:center;color:var(--rouge-deep);
  background:rgba(178,58,48,.1);border:1px solid rgba(178,58,48,.35);border-radius:8px;padding:9px;font-style:italic}

.solo-bar{flex:0 0 auto;background:rgba(0,0,0,.24);border-top:1px solid rgba(255,255,255,.1);
  padding:10px max(12px,env(safe-area-inset-right)) calc(8px + env(safe-area-inset-bottom)) max(12px,env(safe-area-inset-left))}
.sd-row{display:flex;gap:clamp(5px,1.6vw,9px);justify-content:center;align-items:center}
.sd{--d:clamp(36px,15vw,54px);width:var(--d);height:var(--d);flex:0 0 auto;border:0;
  border-radius:calc(var(--d)*.18);
  display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);
  padding:calc(var(--d)*.14);gap:calc(var(--d)*.05);
  background:linear-gradient(150deg,#fbf7ee,#e7ddc6);
  box-shadow:0 3px 6px rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.7);cursor:pointer;transition:transform .1s}
.sd i{align-self:center;justify-self:center;width:calc(var(--d)*.17);height:calc(var(--d)*.17);
  border-radius:50%;background:radial-gradient(circle at 35% 35%,#3a3a35,#0e0e0c);visibility:hidden}
.sd i.on{visibility:visible}
.sd.blank{background:linear-gradient(150deg,#ece5d3,#d8ccb2);opacity:.5}
.sd.held{background:linear-gradient(150deg,#f0c970,#d39e3f);
  box-shadow:0 0 9px 2px rgba(214,164,74,.7),0 3px 6px rgba(0,0,0,.35)}
.sd.held i{background:radial-gradient(circle at 35% 35%,#4a3a12,#241a06)}
.sd:active{transform:scale(.94)}
.sd i[data-p="1"]{grid-area:1/1}.sd i[data-p="2"]{grid-area:1/2}.sd i[data-p="3"]{grid-area:1/3}
.sd i[data-p="4"]{grid-area:2/1}.sd i[data-p="5"]{grid-area:2/2}.sd i[data-p="6"]{grid-area:2/3}
.sd i[data-p="7"]{grid-area:3/1}.sd i[data-p="8"]{grid-area:3/2}.sd i[data-p="9"]{grid-area:3/3}

.solo-hint{text-align:center;color:#cfe0d6;font-style:italic;font-size:14px;min-height:20px;margin:8px 0 6px}
.solo-controls{display:flex;gap:14px;align-items:center;justify-content:center}
.solo-rolls{font-family:"Rye",serif;color:#e7d9b6;font-size:20px;min-width:58px;text-align:center}
.solo .btn{font-size:17px;padding:13px 22px}

@media (orientation: landscape) and (min-width: 700px){
  .sd{--d:clamp(44px,8vw,64px)}
}

/* ---------- shared high scores (single player) ---------- */
.solo-headlinks{display:flex;align-items:center;gap:14px}
.solo-hs{color:var(--brass-bright);font-style:italic;text-decoration:none;font-size:14px;
  border-bottom:1px dotted var(--brass);cursor:pointer;white-space:nowrap}
.hs-scrim{position:fixed;inset:0;background:rgba(10,20,15,.62);z-index:60;display:none}
.hs-scrim.open{display:block}
.hs-modal{position:fixed;left:0;right:0;top:50%;transform:translateY(-50%);z-index:70;display:none;
  padding:0 16px;max-width:460px;margin:0 auto}
.hs-modal.open{display:block}
.hs-card{padding:20px 18px 18px;max-height:90dvh;overflow:auto}
.hs-title{font-family:"Rye",serif;color:var(--rouge);font-size:30px;text-align:center;line-height:1}
.hs-title.hs-new{color:var(--rouge-deep);animation:hsflash 1s steps(2,end) infinite}
@keyframes hsflash{50%{opacity:.4}}
.hs-bigscore{font-family:"Rye",serif;color:var(--brass-bright);font-size:54px;text-align:center;
  margin:8px 0 2px;text-shadow:0 2px 0 rgba(0,0,0,.2)}
.hs-sub{text-align:center;color:#5d5648;font-style:italic;margin-bottom:10px}
.hs-list{margin:14px 2px 4px}
.hs-row{display:flex;align-items:center;gap:8px;padding:8px 6px;border-bottom:1px solid var(--rule)}
.hs-row:last-child{border-bottom:none}
.hs-rank{font-family:"Rye",serif;color:var(--brass);width:24px;font-size:20px}
.hs-ini{font-family:"Rye",serif;color:var(--ink);font-size:22px;letter-spacing:.14em;min-width:64px}
.hs-dots{flex:1 1 auto;border-bottom:2px dotted #cbbf9d;height:1px;transform:translateY(-5px)}
.hs-score{font-family:"Caveat",cursive;color:var(--pencil);font-size:30px;min-width:46px;text-align:right}
.hs-date{color:#9a907a;font-size:12px;font-style:italic;min-width:44px;text-align:right}
.hs-row.empty .hs-ini,.hs-row.empty .hs-rank{color:#c3b896}
.hs-row.hi{background:linear-gradient(90deg,rgba(205,168,108,.4),rgba(205,168,108,.06));
  border-radius:6px;animation:hsglow 1.1s ease-in-out 3}
@keyframes hsglow{50%{background:rgba(205,168,108,.6)}}
.hs-note{text-align:center;color:#5d5648;font-style:italic;font-size:14px;margin:10px 4px 2px}
.hs-actions{display:flex;gap:10px;justify-content:center;margin-top:16px}
.hs-slots{display:flex;gap:16px;justify-content:center;margin:6px 0 4px}
.hs-slot{display:flex;flex-direction:column;align-items:center;gap:6px}
.hs-cyc{appearance:none;border:1px solid #cdbf9d;background:#fffdf6;color:var(--rouge);
  border-radius:8px;width:56px;height:38px;font-size:17px;cursor:pointer}
.hs-cyc:active{transform:translateY(1px)}
.hs-letter{font-family:"Rye",serif;font-size:46px;color:var(--ink);width:56px;text-align:center;
  cursor:pointer;background:linear-gradient(180deg,#fffdf6,#efe6cf);border:1px solid #cdbf9d;border-radius:8px;line-height:1.35}

/* Landscape / wide screens (e.g. a Mac): dice fill the left, controls sit beside them
   so the dice stay big AND the buttons are always on screen. */
@media (orientation: landscape) and (min-width: 700px){
  .dm-body{flex-direction:row;align-items:stretch}
  #dice-canvas{flex:1 1 auto}
  .dm-foot{flex:0 0 clamp(260px,30vw,380px);gap:8px;
    padding:0 20px calc(8px + env(safe-area-inset-bottom))}
  .dm-controls{flex-direction:column;gap:12px}
  .dm-cup{font-size:26px;padding:20px 46px}
  .dm-locked{margin:6px 0}
}
