
  :root{
    color-scheme:dark;
    --sat:env(safe-area-inset-top,0px);
    /* READABLE — art-deco speakeasy: espresso black, cream, gold */
    --bg:#15110b; --panel:#201a11;
    --text:#ece1cd; --dim:#9c8d73;
    --green:#c9a24a; --amber:#e7c879; --red:#cf6a5d;
    --border:#3a2f1d; --bartrack:#2a2114;
    --btnbg:#241d12; --btnborder:#4a3b22;
    --shadow:rgba(0,0,0,.55); --glow:none; --rowline:#2a2215;
    --goods-art-ratio:160 / 250; /* market item art native 160×250 — panel scales to fit, keeps this aspect */
    /* 1920s type system: Playfair Display for titles/names, Josefin Sans for body/data */
    --font-display:"Playfair Display",Georgia,"Times New Roman",serif;
    --font-deco:"Josefin Sans","Century Gothic",Futura,"Twentieth Century",ui-sans-serif,system-ui,sans-serif;
    /* Native title-screen.jpg canvas — shared contain-fit frame on desktop */
    --phone-canvas-w:853;
    --phone-canvas-h:1844;
  }

  *{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
  html{height:100%;height:100svh;height:100dvh;}
  html,body{margin:0;padding:0;overflow:hidden;background:var(--bg);color:var(--text);
    font-family:var(--font-deco);font-size:15px;line-height:1.4;
    -webkit-text-size-adjust:100%;touch-action:manipulation;}
  body{display:flex;justify-content:center;align-items:stretch;
    height:100vh;height:100svh;height:100dvh;}
  .serif{font-family:var(--font-deco);}
  #crt{width:100%;max-width:540px;display:flex;flex-direction:column;
    min-height:0;height:100vh;height:100svh;height:100dvh;max-height:100dvh;overflow:hidden;
    padding:calc(env(safe-area-inset-top, 0px) + 10px) 10px calc(env(safe-area-inset-bottom, 0px) + 12px) 10px;background:var(--bg);}
  .masthead{flex:0 0 auto;text-align:center;padding:0;margin:0 0 3px;position:relative;overflow:hidden;}
  #crt.game-mode{padding:calc(env(safe-area-inset-top, 0px) + 1px) 8px 0 8px;}
  #crt.game-mode .masthead{padding:0;margin:0;}
  h1{margin:0;line-height:1;font-size:0;}
  .masthead-banner{display:block;width:100%;height:auto;filter:brightness(1.05);clip-path:inset(0 0 1px 0);}
  #app{flex:1 1 auto;display:flex;flex-direction:column;min-height:0;overflow:hidden;}
  /* ── three-zone permanent frame ── */
  .play{flex:1 1 auto;display:flex;flex-direction:column;min-height:0;}

  /* Illustration assets — lighten ~10% for readability on dark UI */
  .goods-icon-wrap .goods-icon{filter:brightness(1.1);}

  /* MARKET SCREEN — two-column card layout, single-screen (no scroll) — v76 */
  .market-play{gap:3px;overflow:hidden;}
  /* location panel — outer shell unchanged (border + deco brackets) */
  .market-play .loc-header{position:relative;flex:0 0 clamp(82px,10.7vh,104px);min-height:82px;max-height:104px;
    display:flex;gap:0;align-items:stretch;padding:0;
    background:linear-gradient(180deg,#211b11,#15110b);border:1px solid var(--btnborder);border-radius:8px;}
  .market-play .loc-header::before,.market-play .bot-bar::before{content:"";position:absolute;inset:5px;
    pointer-events:none;border:1px solid rgba(201,162,74,.36);border-radius:5px;}
  .market-row::before{content:"";position:absolute;inset:4px;
    pointer-events:none;border:1px solid rgba(201,162,74,.32);border-radius:5px;}
  .market-play .loc-copy{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;justify-content:center;
    padding:10px 10px 10px 14px;z-index:2;overflow:hidden;}
  .market-play .loc-header-title{font-family:var(--font-display);
    font-size:clamp(1.05rem, 4.8vw, 1.44rem);font-weight:700;color:var(--amber);letter-spacing:1px;
    line-height:1.05;text-transform:uppercase;text-align:left;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .market-play .loc-header-desc{margin:8px 0 0;text-align:left;font-family:var(--font-deco);
    font-size:clamp(.744rem, 3.12vw, .912rem);color:var(--text);line-height:1.28;
    display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
  .market-play .loc-day{flex:0 0 auto;display:flex;align-items:center;justify-content:center;
    padding:8px 10px 8px 6px;z-index:2;}
  .market-play .day-counter{width:81px;max-width:81px;display:flex;flex-direction:column;align-items:center;}
  .market-play .day-counter-label{font-family:var(--font-deco);font-size:.58rem;font-weight:700;
    letter-spacing:3px;text-transform:uppercase;color:#1a1206;
    position:absolute;top:0;left:50%;transform:translate(-50%,-50%);z-index:3;white-space:nowrap;
    padding:0 4px;background:linear-gradient(145deg,#8a7344 0%,#c9a85a 50%,#6b5630 100%);}
  .market-play .day-counter-frame{position:relative;width:100%;padding:5px;border-radius:6px;
    background:linear-gradient(145deg,#8a7344 0%,#c9a85a 18%,#6b5630 50%,#a88942 82%,#5c4a28 100%);
    box-shadow:0 2px 6px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,240,200,.25),inset 0 -1px 0 rgba(0,0,0,.45);}
  .market-play .day-counter-inset{border-radius:4px;padding:6px 4px 5px;
    background:linear-gradient(180deg,#0c0a07 0%,#1a1510 45%,#0a0806 100%);
    border:1px solid rgba(0,0,0,.8);
    box-shadow:inset 0 3px 8px rgba(0,0,0,.85),inset 0 -1px 0 rgba(201,162,74,.12);}
  .market-play .day-flip{display:flex;align-items:stretch;justify-content:center;gap:3px;}
  .market-play .flip-digit{flex:1 1 0;min-width:0;aspect-ratio:.72;max-height:52px;position:relative;
    border-radius:3px;overflow:hidden;border:1px solid rgba(201,162,74,.35);
    background:linear-gradient(180deg,#1e1812 0%,#12100c 48%,#181410 49%,#0e0c08 100%);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 1px 2px rgba(0,0,0,.5);}
  .market-play .flip-digit::before{content:"";position:absolute;left:0;right:0;top:50%;height:1px;
    background:rgba(0,0,0,.75);box-shadow:0 1px 0 rgba(201,162,74,.08);z-index:2;}
  .market-play .flip-digit span{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
    font-family:var(--font-deco);font-size:clamp(1.35rem,6.5vw,1.75rem);font-weight:700;color:var(--amber);
    text-shadow:0 0 12px rgba(231,200,121,.35),0 1px 0 rgba(0,0,0,.9);letter-spacing:-1px;}
  .market-play .day-counter-sub{font-size:.52rem;letter-spacing:1.5px;text-transform:uppercase;
    color:#1a1206;font-weight:700;
    position:absolute;bottom:0;left:50%;transform:translate(-50%,50%);z-index:3;white-space:nowrap;
    padding:0 4px;background:linear-gradient(145deg,#8a7344 0%,#c9a85a 50%,#6b5630 100%);}

  /* mid region (transparent — cards float) */
  .market-mid{flex:1 1 0;min-height:0;overflow:hidden;display:flex;flex-direction:column;
    background:transparent;border:none;border-radius:0;margin-bottom:0;}
  .market-head{flex:0 0 auto;padding:0 2px;display:flex;align-items:center;gap:8px;}
  .market-golden-banner{flex:0 0 auto;margin:0 0 5px;padding:5px 10px 4px;border-radius:5px;
    font-size:clamp(.58rem, 2.5vw, .68rem);letter-spacing:1.2px;text-transform:uppercase;
    text-align:center;color:#1a1206;background:linear-gradient(90deg, #b8860b, var(--amber), #b8860b);
    animation:golden-pulse 2s ease-in-out infinite;}
  @keyframes golden-pulse{0%,100%{filter:brightness(1);}50%{filter:brightness(1.15);}}
  .market-head-title{flex:0 0 auto;font-family:var(--font-display);line-height:1;
    font-size:clamp(1.08rem, 5.1vw, 1.464rem);color:var(--amber);letter-spacing:1px;text-transform:uppercase;}
  .market-head-rule{flex:1 1 auto;height:1px;background:var(--border);}
  .market-head-gem{flex:0 0 auto;width:9px;height:9px;transform:rotate(45deg);
    border:1px solid var(--btnborder);background:var(--bg);}
  /* two-column card grid */
  .market-rows{flex:1 1 0;min-height:0;overflow:hidden;
    display:grid;grid-template-columns:1fr 1fr;grid-template-rows:repeat(5,minmax(0,1fr));gap:2px 3px;}
  .market-row{position:relative;min-height:0;overflow:hidden;
    display:flex;flex-direction:row;gap:0;padding:0;
    border:1px solid var(--btnborder);border-radius:7px;
    background:linear-gradient(180deg,#201a11,#141009);}
  .market-row.dead{opacity:.42;}
  .goods-icon-wrap{position:relative;flex:0 0 auto;
    height:100%;aspect-ratio:var(--goods-art-ratio);
    border-right:1px solid var(--btnborder);border-radius:5px 0 0 5px;background:rgba(0,0,0,.45);
    padding:0;box-sizing:border-box;overflow:hidden;
    display:grid;grid-template:1fr/1fr;align-items:center;justify-items:center;}
  .goods-icon-wrap.no-icon::after{content:attr(data-initial);position:absolute;inset:0;
    display:flex;align-items:center;justify-content:center;
    font-family:var(--font-deco);
    font-size:clamp(18px,5vw,28px);color:var(--amber);line-height:1;}
  .goods-icon{width:100%;height:100%;display:block;object-fit:cover;
    object-position:center center;border:none;border-radius:0;background:transparent;padding:0;}
  .card-content{flex:1 1 0;min-width:0;display:flex;flex-direction:column;padding:4px 6px 4px 5px;gap:0;}
  .card-name-row{flex:248 1 0;min-height:0;display:flex;align-items:center;overflow:hidden;}
  .card-price-row{flex:200 1 0;min-height:0;display:flex;align-items:center;justify-content:space-between;gap:4px;min-width:0;}
  .goods-name{min-width:0;color:var(--amber);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
    font-family:var(--font-display);font-weight:700;letter-spacing:.3px;
    font-size:clamp(.7rem,3vw,.9rem);line-height:1;text-transform:uppercase;}
  .market-row .price-cell{text-align:left;color:var(--amber);
    font-family:var(--font-deco);font-weight:700;white-space:nowrap;
    font-size:clamp(1.05rem,4.65vw,1.5rem);line-height:1;}
  .market-row .price-cell.na{color:var(--dim);}
  .market-row .stock-cell{flex:0 0 auto;text-align:right;color:var(--dim);white-space:nowrap;
    font-family:var(--font-deco);font-size:clamp(1.2rem,4.8vw,1.6rem);}
  .market-row .stock-cell.have{color:var(--green);}
  .market-play .market-actions{flex:140 1 0;min-height:0;display:flex;gap:4px;align-items:center;}
  .market-play .market-actions button{flex:1 1 0;height:100%;min-height:0;padding:0 2px;margin:0;
    font-family:var(--font-deco);
    font-size:clamp(.6rem,2.5vw,.66rem);font-weight:700;letter-spacing:.5px;line-height:1;border-radius:4px;}
  .market-play .market-actions .buybtn{background:linear-gradient(180deg,#1e1809,#141005);
    border:1px solid var(--amber);color:var(--amber);}
  .market-play .market-actions .buybtn:active{background:var(--amber);color:#1a1206;}
  .market-play .market-actions .sellbtn{background:transparent;border:1px solid var(--green);color:var(--green);}
  .market-play .market-actions .sellbtn:active{background:var(--green);color:#1a1206;}
  .market-row.dead .market-actions .buybtn{background:#19140c;border-color:var(--border);color:var(--dim);}
  /* actlog removed from market screen */
  /* art-deco corner brackets on district + stats panels */
  .market-play .loc-header::after,.market-play .bot-bar::after{content:"";position:absolute;inset:5px;
    pointer-events:none;
    background:linear-gradient(var(--btnborder),var(--btnborder)) top left,linear-gradient(var(--btnborder),var(--btnborder)) top left,linear-gradient(var(--btnborder),var(--btnborder)) top right,linear-gradient(var(--btnborder),var(--btnborder)) top right,linear-gradient(var(--btnborder),var(--btnborder)) bottom left,linear-gradient(var(--btnborder),var(--btnborder)) bottom left,linear-gradient(var(--btnborder),var(--btnborder)) bottom right,linear-gradient(var(--btnborder),var(--btnborder)) bottom right;
    background-repeat:no-repeat;
    background-size:16px 1px,1px 16px,16px 1px,1px 16px,16px 1px,1px 16px,16px 1px,1px 16px;}

  /* TRAVEL — destination picker, stacked districts, solid title strip */
  /* ── TRAVEL: destination picker on the High Scores shell ───────────────── */
  .travel-row{appearance:none;-webkit-appearance:none;width:100%;background:transparent;
    color:inherit;font:inherit;text-align:left;cursor:pointer;gap:10px;
    -webkit-tap-highlight-color:transparent;}
  .travel-row:focus-visible{outline:2px solid var(--amber);outline-offset:-2px;}
  .travel-row:active:not(.here){background:rgba(231,200,121,.12);}
  .travel-thumb{flex:0 0 auto;height:76px;max-height:calc(100% - 12px);aspect-ratio:3/2;
    box-sizing:border-box;border:1px solid var(--border);border-radius:3px;overflow:hidden;
    background:#0c0a06;display:flex;}
  .travel-thumb img{width:100%;height:100%;object-fit:cover;display:block;filter:brightness(1.05);}
  .travel-row-name{flex:1 1 auto;min-width:0;font-family:var(--font-display);font-weight:700;
    font-size:1rem;letter-spacing:.4px;color:var(--amber);text-transform:uppercase;
    text-align:center;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .travel-chev{flex:0 0 auto;color:var(--dim);font-size:1.4rem;line-height:1;margin-left:2px;}
  .travel-here-badge{flex:0 0 auto;font-family:var(--font-display);color:var(--amber);
    font-size:.7rem;font-weight:700;letter-spacing:.5px;border:1px solid var(--amber);
    border-radius:3px;padding:2px 6px;}
  .travel-row.here{opacity:.5;cursor:default;pointer-events:none;background:rgba(32,26,17,.5);}
  .travel-row.here .travel-thumb img{filter:brightness(1.05) grayscale(.6);}
  .travel-row.here .travel-row-name{color:var(--dim);}
  .travel-foot{display:flex;flex-direction:column;gap:4px;}
  .travel-cost-note{text-align:center;color:var(--dim);letter-spacing:.06em;font-size:.72rem;}
  .loc{font-size:.78rem;color:var(--amber);letter-spacing:1px;
    padding:4px 10px 3px;display:flex;justify-content:space-between;align-items:baseline;
    border-left:1px solid var(--border);border-right:1px solid var(--border);}
  .loc small{color:var(--dim);font-size:.58rem;letter-spacing:0;white-space:nowrap;}
  table{width:100%;border-collapse:collapse;font-size:.84rem;}
  th,td{text-align:left;padding:4px 8px;border-bottom:1px solid var(--rowline);vertical-align:middle;}
  th{color:var(--dim);font-weight:normal;font-size:.65rem;letter-spacing:1px;background:var(--bg);position:sticky;top:0;z-index:1;}
  td.r,th.r{text-align:right;}
  tr.dead{opacity:.4;}
  .price{color:var(--amber);} .have{color:var(--green);} .na{color:var(--dim);}

  /* BOTTOM BAR — cash/debt/bank/guns + action buttons, always visible */
  .market-play .bot-bar{position:relative;flex:0 0 123px;height:123px;min-height:123px;max-height:123px;
    background:linear-gradient(180deg,#201a11,#141009);border:1px solid var(--btnborder);border-radius:8px;
    padding:10px 12px 7px;margin-top:2px;display:flex;flex-direction:column;overflow:hidden;}
  .bot-bar{flex:0 0 auto;background:var(--panel);border:1px solid var(--border);
    border-radius:8px;padding:7px 10px 8px;}
  .bot-stats{display:grid;grid-template-columns:1fr 1fr;gap:1px 10px;margin-bottom:4px;flex:1 1 auto;min-height:0;}
  .bot-stat{display:flex;flex-direction:column;justify-content:center;}
  .bot-stat.right{align-items:flex-end;text-align:right;}
  .market-play .bot-stats{flex:0 0 auto;margin-bottom:0;gap:0 10px;}
  .market-play .bot-stat{flex-direction:row;align-items:baseline;justify-content:flex-start;gap:5px;min-width:0;}
  .market-play .bot-stat.right{justify-content:flex-end;}
  .market-play .bot-stat .bot-label{flex:0 0 auto;font-size:clamp(.7rem,3vw,.9rem);}
  .market-play .bot-stat .bot-val{flex:0 0 auto;overflow:visible;text-overflow:clip;white-space:nowrap;}
  .bot-sub{flex:0 0 auto;display:flex;justify-content:space-between;align-items:baseline;gap:4px 8px;margin-top:5px;
    padding-top:6px;border-top:1px solid rgba(201,162,74,.22);
    font-size:clamp(.7rem,3vw,.9rem);color:var(--dim);letter-spacing:.2px;white-space:nowrap;}
  .bot-label{font-family:var(--font-deco);
    font-size:clamp(.54rem, 2.3vw, .62rem);color:var(--dim);letter-spacing:.3px;line-height:1.1;text-transform:uppercase;}
  .market-play .bot-val{font-size:clamp(1.05rem,4.65vw,1.5rem);line-height:1.12;color:var(--text);}
  .market-play .bot-val.red{color:var(--red);}
  .bot-val{font-size:1.08rem;line-height:1.2;color:var(--amber);}
  .bot-val.red{color:var(--red);}
  .debt-warn{flex:0 0 auto;margin:0 0 4px;padding:0 2px;font-size:clamp(.52rem, 2.2vw, .62rem);
    line-height:1.25;color:var(--amber);text-align:center;letter-spacing:.2px;}
  .market-play .bot-val.dim{font-size:clamp(.72rem, 3.2vw, .88rem);color:var(--text);}
  .bot-val.dim{font-size:.9rem;color:var(--text);}
  .bar{height:4px;background:var(--bartrack);border-radius:3px;margin:3px 0 6px;overflow:hidden;}
  .bar > i{display:block;height:100%;background:var(--green);}
  .market-play .save-err{flex:0 0 auto;margin:0;padding:0;line-height:1.2;}
  .market-play .actions{flex:0 0 auto;margin-top:5px;margin-bottom:3px;display:grid;grid-template-columns:1fr 1fr;gap:10px;}
  .market-play .actions button{min-height:40px;padding:8px 6px;font-size:clamp(.64rem, 2.75vw, .76rem);letter-spacing:.6px;font-weight:700;
    display:flex;align-items:center;justify-content:center;text-align:center;
    background:linear-gradient(180deg,#211a0f,#151009);border-color:var(--amber);border-radius:8px;
    box-shadow:inset 0 0 0 1px rgba(201,162,74,.16);}
  .actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
  .actions button{padding:10px 8px;font-size:.8rem;letter-spacing:.5px;}

  /* other screens that still use .row / .hud */
  .row{display:flex;justify-content:space-between;gap:10px;align-items:flex-end;}
  .hud{flex:0 0 auto;border:1px solid var(--border);border-radius:8px;padding:8px 10px;
    background:var(--panel);font-size:.82rem;line-height:1.4;}
  .hud b{color:var(--amber);} .hud .red{color:var(--red);}
  html.title-route,html.title-route body{margin:0;padding:0;overflow:hidden;width:100%;height:100%;background:#000;}
  html.title-route body{display:block;}
  #crt.title-mode .masthead{display:none;}
  #crt.title-mode{position:fixed;inset:0;width:100%;max-width:none;height:100%;max-height:none;
    min-height:0;padding:0;margin:0 auto;background:#000;overflow:hidden;}
  #crt.title-mode #app{position:absolute;inset:0;width:100%;height:100%;overflow:hidden;}
  .title-play{position:absolute;inset:0;width:100%;height:100%;}
  .title-screen{position:absolute;inset:0;width:100%;height:100%;overflow:hidden;background:#000;}
  .title-cover{position:absolute;container-type:size;}
  .title-cover img{width:100%;height:100%;display:block;user-select:none;-webkit-user-drag:none;
    pointer-events:none;image-rendering:-webkit-optimize-contrast;}
  .title-hit{position:absolute;box-sizing:border-box;border:0;background:transparent;cursor:pointer;padding:0!important;margin:0;
    border-radius:0;min-height:0;min-width:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation;}
  .title-hit:active:not(:disabled){background:transparent;}
  .title-hit:focus-visible{outline:2px solid var(--amber);outline-offset:-2px;}
  .title-hit:disabled{cursor:default;pointer-events:none;opacity:0;}
  /* Title overlay rects on native title-screen canvas; cqw/cqh = title-cover box */
  .title-achievement-count{position:absolute;left:61.9cqw;top:53.82cqh;width:30.9cqw;height:4.15cqh;
    display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
    font-family:var(--font-deco);
    font-size:clamp(8px,1.35cqw,15px);line-height:.95;font-weight:700;letter-spacing:0;
    color:#c99654;text-shadow:0 1px 1px #000,0 0 5px rgba(231,200,121,.22);
    pointer-events:none;text-transform:uppercase;}
  .title-achievement-count span:first-child{font-size:clamp(11px,2.2cqw,24px);line-height:1;}
  /* Title hit rects on 853x1844 canvas; cqw/cqh = title-cover box */
  .title-hit-new{left:2.1cqw;top:80.915cqh;width:47.1cqw;height:6.95cqh;}
  .title-hit-cont{left:51.0cqw;top:80.915cqh;width:47.0cqw;height:6.95cqh;}
  .title-hit-ledger{left:2.1cqw;top:88.365cqh;width:47.1cqw;height:6.95cqh;}
  .title-hit-scores{left:51.0cqw;top:88.365cqh;width:47.0cqw;height:6.95cqh;}
  #crt.game-mode .masthead{position:relative;}
  .save-err{text-align:center;color:var(--red);font-size:.72rem;padding:1px 0;}

  /* CRIME LEDGER v64 — unified template
     Home: blueprint overlay on base PNG (unchanged).
     Categories: in-flow header image + HTML title/counter + 10-slot normal-flow rows.
     No container-type:size, no aspect-ratio frame, no cqh. iOS Safari safe. */

  /* ── shared chrome ─────────────────────────────────────────────────────── */
  #crt.ledger-mode{padding:0;background:#000;}
  #crt.ledger-mode .masthead{display:none;}
  #crt.ledger-mode #app{flex:1 1 auto;min-height:0;}
  .ledger-play{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;
    overflow-y:auto;-webkit-overflow-scrolling:touch;background:#000;}
  .ledger-play:not(.ledger-template-page){overflow:hidden;}

  /* ── HOME: category list (reuses the High Scores shell) ─────────────────── */
  .ledger-home-row{appearance:none;-webkit-appearance:none;width:100%;background:#000;
    color:inherit;font:inherit;text-align:left;cursor:pointer;
    -webkit-tap-highlight-color:transparent;}
  .ledger-home-row:focus-visible{outline:2px solid var(--amber);outline-offset:-2px;}
  .ledger-home-row:active{background:#171107;}
  .ledger-home-icon{flex:0 0 clamp(72px,20vw,96px);width:clamp(72px,20vw,96px);aspect-ratio:1/1;
    box-sizing:border-box;border:1px solid var(--btnborder);border-radius:4px;overflow:hidden;background:#000;display:flex;}
  .ledger-home-icon img{width:100%;height:100%;object-fit:cover;display:block;filter:brightness(1.05);}
  .ledger-home-copy{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:6px;}
  .ledger-home-title{font-family:var(--font-display);font-size:1.17rem;letter-spacing:.6px;
    color:var(--amber);text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .ledger-home-bar{height:4px;border-radius:2px;background:rgba(255,255,255,.08);overflow:hidden;}
  .ledger-home-bar span{display:block;height:100%;background:var(--amber);border-radius:2px;}
  .ledger-home-count{flex:0 0 auto;color:var(--text);font-size:1.17rem;white-space:nowrap;}
  .ledger-home-chev{flex:0 0 auto;color:var(--dim);font-size:1.4rem;line-height:1;margin-left:2px;}
  .ledger-home-foot{display:flex;flex-direction:column;gap:4px;}
  .ledger-home-total{text-align:center;color:#9a8860;letter-spacing:.14em;
    font-size:.74rem;text-transform:uppercase;}

  /* ── CATEGORY TEMPLATE: header + scrollable list + pinned back ─────────── */
  .ledger-play.ledger-template-page{overflow:hidden;}
  .ledger-template-page{display:flex;flex-direction:column;align-items:center;
    flex:1 1 auto;min-height:0;width:100%;background:#0d0b07;}
  .ledger-tpl-inner{display:flex;flex-direction:column;width:100%;
    max-width:calc(100dvh * 473 / 1024);flex:1 1 auto;min-height:0;background:#0d0b07;
    container-type:inline-size;}
  .ledger-tpl-img{display:block;width:100%;height:auto;flex-shrink:0;margin:0;padding:0;vertical-align:bottom;}
  .ledger-tpl-header{text-align:center;padding:0;margin:0;flex-shrink:0;}
  .ledger-tpl-title{font-family:var(--font-display);font-size:7.2cqw;letter-spacing:.22em;color:#d4af37;
    font-weight:700;line-height:1;}
  .ledger-tpl-divider{display:flex;align-items:center;justify-content:center;
    gap:2cqw;padding:.7cqw 6cqw;}
  .ledger-tpl-divider::before,.ledger-tpl-divider::after{content:'';flex:1;height:1px;
    background:linear-gradient(to var(--tdir,right),transparent,#7a6030);}
  .ledger-tpl-divider::after{--tdir:left;}
  .ledger-tpl-ornament{font-size:2.4cqw;color:#7a6030;letter-spacing:.3em;}
  .ledger-tpl-counter{font-size:2.9cqw;letter-spacing:.15em;color:#9a8050;padding-bottom:1.2cqw;}
  .ledger-tpl-separator{height:1px;background:#2a2010;margin:0 3.8cqw;flex-shrink:0;}
  .ledger-tpl-list{width:100%;flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;}
  .ledger-tpl-back{display:block;width:calc(100% - 7.6cqw);margin:2.2cqw 3.8cqw 3cqw;
    padding:2.6cqw 0;background:transparent;border:1px solid #5a4820;border-radius:8px;
    color:#c9a85a;font-family:inherit;font-size:3.2cqw;letter-spacing:.2em;
    cursor:pointer;flex-shrink:0;}

  /* ── shared row styles ──────────────────────────────────────────────────── */
  .ledger-list-panel{position:absolute;overflow:hidden;z-index:2;pointer-events:none;}
  .ledger-list-panel.scroll{overflow-y:auto;-webkit-overflow-scrolling:touch;pointer-events:auto;}
  .ledger-list-inner{display:flex;flex-direction:column;}
  .ledger-list-row{display:flex;align-items:center;gap:3cqw;padding:2.1cqw 1.6cqw;
    border-bottom:1px solid rgba(201,168,90,.10);min-height:11.6cqw;}
  .ledger-list-row:last-child{border-bottom:none;}
  .ledger-row-icon{position:relative;flex:0 0 auto;width:11cqw;height:11cqw;
    border:1px solid #5a5040;border-radius:6px;overflow:hidden;background:#0c0a06;
    display:flex;box-sizing:border-box;}
  .ledger-row-icon.locked{border-color:#5a5040;}
  .ledger-row-icon.revealed{border-color:#c9a85a;}
  .ledger-row-icon img{width:100%;height:100%;object-fit:contain;display:block;pointer-events:none;}
  .ledger-row-copy{flex:1 1 auto;min-width:0;line-height:1.2;overflow:hidden;}
  .ledger-row-title{font-family:var(--font-display);font-size:3.5cqw;letter-spacing:.05em;color:#c9a85a;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .ledger-row-title.hidden{color:#6a5e48;}
  .ledger-row-desc{font-size:2.8cqw;color:#7a6e58;margin-top:.4cqw;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .ledger-row-desc.placeholder{color:#5a5040;}
  .ledger-row-mark{flex:0 0 1.4em;color:#c9a85a;font-size:4cqw;text-align:center;}
  .ledger-list-row.reveal-focus .ledger-row-title{color:#e7c879;}
  .ledger-complete{flex:1 1 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;
    text-align:center;padding:16px;gap:10px;border:3px double var(--amber);border-radius:8px;}
  .ledger-complete h2{margin:0;font-family:var(--font-display);font-size:clamp(.88rem,4vw,1rem);color:var(--amber);letter-spacing:2px;line-height:1.35;}
  .ledger-complete p{margin:0;font-size:clamp(.68rem,3vw,.78rem);color:var(--dim);letter-spacing:1px;}
  .ledger-complete.master h2{font-size:clamp(.82rem,3.6vw,.94rem);}
  .ledger-complete.master .ledger-master-tag{font-size:clamp(.72rem,3.2vw,.82rem);color:var(--text);letter-spacing:1.5px;margin-top:6px;}
  .ach-card-reveal{position:fixed;inset:0;z-index:150;background:#000;display:flex;flex-direction:column;
    align-items:center;justify-content:center;padding:calc(env(safe-area-inset-top,0px) + 12px) 16px calc(env(safe-area-inset-bottom,0px) + 12px);
    animation:achCardFade .45s ease;}
  .ach-card-reveal.golden img{max-width:min(94vw,440px);max-height:min(72dvh,580px);}
  .ach-card-reveal img{max-width:min(92vw,420px);max-height:min(68dvh,560px);width:auto;height:auto;object-fit:contain;}
  .ach-card-next{margin-top:16px;border:1px solid var(--amber);color:var(--amber);background:transparent;
    padding:10px 36px;font-family:inherit;font-size:clamp(.72rem,3.2vw,.84rem);letter-spacing:2px;cursor:pointer;border-radius:7px;}
  .ach-card-next:active{background:var(--amber);color:#1a1206;}
  @keyframes achCardFade{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
  .ach-found-rule{color:var(--amber);letter-spacing:1px;font-size:clamp(.62rem,2.8vw,.72rem);margin:2px 0;}

  /* Achievement Found popup — compact Art Deco panel */
  .modal.achievement-modal-overlay{
    background:rgba(0,0,0,.76);z-index:200;
    padding:max(20px,env(safe-area-inset-top)) 20px max(20px,env(safe-area-inset-bottom));
    animation:ach-modal-overlay-in 220ms ease-out;
    box-sizing:border-box;}
  .achievement-modal{
    --ach-gold:#caa85e;--ach-ivory:#efe5d2;--ach-gold-text:#d5b66a;
    width:min(78vw,490px);max-width:490px;min-width:min(300px,100%);
    padding:34px 28px;margin:0 auto;
    background:
      radial-gradient(circle at 50% 40%,rgba(83,62,28,.16),rgba(23,19,13,.96) 58%,rgba(12,10,7,.98) 100%);
    border:1.5px solid var(--ach-gold);border-radius:18px;
    box-shadow:0 12px 40px rgba(0,0,0,.65),0 0 24px rgba(202,168,94,.06);
    text-align:center;animation:ach-modal-panel-in 220ms ease-out;}
  .achievement-modal__divider{
    display:flex;align-items:center;gap:8px;width:100%;height:12px;}
  .achievement-modal__divider-lines{
    flex:1 1 0;min-width:0;height:12px;display:flex;flex-direction:column;
    justify-content:center;gap:4px;}
  .achievement-modal__divider-lines::before,
  .achievement-modal__divider-lines::after{
    content:"";display:block;height:1px;background:var(--ach-gold);}
  .achievement-modal__divider-diamond{
    flex:0 0 auto;width:8px;height:8px;border:1.5px solid var(--ach-gold);
    transform:rotate(45deg);background:transparent;}
  .achievement-modal__title{
    margin:30px 0 0;font-family:var(--font-display);font-weight:700;
    font-size:clamp(25px,6.2vw,31px);letter-spacing:.035em;line-height:1.05;
    text-transform:uppercase;
    background:linear-gradient(180deg,#f1d88f 0%,#c9a45a 44%,#7b5726 72%,#d4b66d 100%);
    -webkit-background-clip:text;background-clip:text;color:transparent;
    text-shadow:0 1px 0 rgba(255,230,160,.12),0 2px 4px rgba(0,0,0,.8);}
  .achievement-modal__message{
    margin:28px 0;font-size:clamp(12.375px,3.3vw,16.5px);font-weight:400;
    letter-spacing:.045em;line-height:1.35;color:var(--ach-ivory);
    text-transform:uppercase;}
  .achievement-modal__button{
    display:block;width:100%;min-height:50px;height:50px;margin:0;padding:0;
    border:1.5px solid var(--ach-gold);border-radius:8px;
    background:rgba(20,16,10,.55);color:var(--ach-gold-text);
    font-family:inherit;font-size:15.075px;font-weight:500;letter-spacing:.18em;
    text-transform:uppercase;cursor:pointer;line-height:1;}
  .achievement-modal__button:active{
    transform:translateY(1px);background:rgba(202,168,94,.1);border-color:#e1c77f;color:var(--ach-gold-text);}
  .achievement-modal__button:focus-visible{
    outline:2px solid rgba(225,199,127,.75);outline-offset:3px;}
  .achievement-modal__divider--bottom{margin-top:30px;}
  @keyframes ach-modal-overlay-in{from{opacity:0}to{opacity:1}}
  @keyframes ach-modal-panel-in{
    from{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}
  @media (max-width:400px){
    .achievement-modal{padding:28px 22px;}
    .achievement-modal__title{margin-top:24px;font-size:clamp(22px,5.4vw,28px);letter-spacing:.02em;}
    .achievement-modal__message{margin:22px 0;font-size:12.375px;letter-spacing:.035em;}
    .achievement-modal__divider--bottom{margin-top:24px;}
    .achievement-modal__button{min-height:46px;height:46px;font-size:13.87px;}}
  @media (prefers-reduced-motion:reduce){
    .modal.achievement-modal-overlay,.achievement-modal{animation:none;}}

  button{font-family:inherit;background:var(--btnbg);color:var(--text);border:1px solid var(--btnborder);
    padding:12px 12px;font-size:.84rem;letter-spacing:1px;cursor:pointer;border-radius:7px;}
  button:active{background:var(--green);color:#1a1206;}
  button:focus-visible{outline:2px solid var(--amber);outline-offset:2px;}
  input:focus-visible{outline:2px solid var(--amber);outline-offset:2px;}
  button.amber{border-color:var(--amber);color:var(--amber);}
  button.amber:active{background:var(--amber);color:#1a1206;}
  button.red{border-color:var(--red);color:var(--red);}
  button.red:active{background:var(--red);color:#1a0606;}
  button.on{background:var(--green);color:#1a1206;border-color:var(--green);}
  button.full{width:100%;} button:disabled{opacity:.32;}

  .btns{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px;margin-bottom:10px;}
  .btns3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:10px;}
  .grid2{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:6px;}

  #modal-root{position:fixed;inset:0;z-index:150;pointer-events:none;}
  #modal-root:not(:empty){pointer-events:auto;}
  #modal-root:empty{display:none;}
  #modal-root .ach-card-reveal{z-index:151;}

  .modal{position:fixed;inset:0;background:rgba(0,0,0,.74);display:flex;align-items:center;
    justify-content:center;padding:10px 8px;z-index:100;}
  .card{width:100%;max-width:420px;max-height:92dvh;overflow:hidden;background:var(--panel);
    border:1px solid var(--amber);border-radius:11px;padding:16px;box-shadow:0 12px 46px var(--shadow);}
  .card h2{margin:.1rem 0 .6rem;font-family:var(--font-display);font-size:1.05rem;color:var(--amber);letter-spacing:2px;}
  .card p{font-size:.88rem;line-height:1.5;margin:.45rem 0;}
  input[type=number]{font-family:inherit;background:var(--bg);color:var(--text);border:1px solid var(--border);
    padding:11px;width:100%;font-size:1.1rem;text-align:center;border-radius:7px;margin-top:8px;}
  .qtybtns{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin:9px 0;}
  .center{text-align:center;}
  .big{font-size:1.8rem;color:var(--amber);text-shadow:var(--glow);margin:.2rem 0;}
  .err{color:var(--red);min-height:1em;font-size:.78rem;margin:.2rem 0;text-align:center;}
  .scr{font-size:.82rem;}
  .ticker{font-size:.72rem;color:var(--dim);letter-spacing:.5px;margin-top:8px;}
  .flavor{font-size:.74rem;color:var(--dim);margin:4px 0 1px;line-height:1.45;overflow:visible;}
  .profit{font-size:.78rem;}
  .profit.up{color:var(--green);}
  .profit.down{color:var(--red);}
  .tutorial{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.82);display:flex;align-items:center;justify-content:center;
    padding:calc(env(safe-area-inset-top, 0px) + 16px) 16px calc(env(safe-area-inset-bottom, 0px) + 16px) 16px;}
  .scores-play{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;overflow:hidden;gap:4px;}
  /* ── heading strip ── */
  .scores-hero{flex:0 0 50px;position:relative;width:100%;overflow:hidden;background:#000;
    border:1px solid var(--amber);border-radius:4px;}
  .scores-hero-title{position:absolute;inset:0;display:flex;align-items:center;
    gap:clamp(4px,2vw,10px);padding:0 12px;}
  .scores-hero-text{flex:0 0 auto;font-family:var(--font-display);
    font-size:1.56rem;font-weight:700;color:var(--amber);
    letter-spacing:3px;white-space:nowrap;text-transform:uppercase;
    text-shadow:0 1px 6px rgba(0,0,0,.9);}
  /* ── leaderboard rows ── */
  .scores-lb-wrap{flex:1 1 auto;min-height:0;overflow:hidden;display:flex;flex-direction:column;
    border:1px solid var(--amber);border-radius:4px;background:var(--panel);}
  .slb-row{flex:1 1 0;display:flex;align-items:center;gap:8px;
    padding:0 8px;border-bottom:1px solid var(--border);min-height:0;overflow:hidden;}
  .slb-row:last-child{border-bottom:none;}
  .slb-pos{flex:0 0 auto;width:26px;text-align:right;color:var(--dim);font-size:1.02rem;}
  .slb-portrait{flex:0 0 55px;width:55px;height:55px;
    object-fit:cover;object-position:center top;border-radius:3px;
    border:1px solid var(--border);display:block;filter:brightness(1.05);}
  .slb-rank{flex:1 1 auto;font-family:var(--font-display);
    font-size:.82rem;color:var(--amber);letter-spacing:.6px;
    text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .slb-score{flex:0 0 auto;color:var(--text);font-size:.95rem;white-space:nowrap;}
  .slb-row.you{background:rgba(231,200,121,.12);}
  .slb-you{flex:0 0 auto;margin-left:6px;font-family:var(--font-display);
    color:var(--amber);font-size:.72rem;font-weight:700;letter-spacing:.5px;white-space:nowrap;}
  .scores-foot{flex:0 0 auto;padding-top:2px;}
  /* end-of-game reuse of the high-scores layout: final score replaces the title */
  .eos-hero-label{flex:0 0 auto;font-family:var(--font-display);font-size:.96rem;font-weight:700;
    color:var(--amber);letter-spacing:2px;text-transform:uppercase;white-space:nowrap;
    text-shadow:0 1px 6px rgba(0,0,0,.9);}
  .eos-you-wrap{flex:0 0 auto;margin-top:2px;}
  .eos-you-wrap .slb-row{flex:0 0 auto;min-height:58px;}
  .eos-foot{display:grid;grid-template-columns:1fr 1fr;gap:7px;}
  .eos-foot button{font-size:clamp(.66rem,2.8vw,.74rem);padding:9px 4px;letter-spacing:.5px;}
  /* Crime Ledger category pages reuse the high-scores layout; the achievement
     list is the only scrolling region, rows fixed at one-tenth height so short
     categories leave the remaining space empty (no stretch). */
  .scores-lb-wrap.ach-list{overflow-y:auto;-webkit-overflow-scrolling:touch;}
  .ledger-scores[data-ledger-cat="godlike"] .scores-lb-wrap.ach-list,
  .ledger-scores[data-ledger-cat="goldenGodlike"] .scores-lb-wrap.ach-list{justify-content:center;}
  .slb-row.ach-row{flex:0 0 10%;}
  .ach-row .ledger-row-icon{flex:0 0 55px;width:55px;height:55px;box-sizing:border-box;
    border:1px solid var(--border);border-radius:3px;overflow:hidden;background:#0c0a06;display:flex;}
  .ach-row .ledger-row-icon.revealed{border-color:#c9a85a;}
  .ach-row .ledger-row-icon img{width:100%;height:100%;object-fit:contain;display:block;}
  .ach-row .ledger-row-copy{flex:1 1 auto;min-width:0;overflow:hidden;line-height:1.2;}
  .ach-row .ledger-row-title{font-family:var(--font-display);font-size:.82rem;letter-spacing:.6px;
    color:var(--amber);text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .ach-row .ledger-row-title.hidden{color:var(--dim);}
  .ach-row .ledger-row-desc{font-size:.7rem;color:var(--dim);margin-top:2px;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .ach-row .ledger-row-desc.placeholder{color:#5a5040;}
  .ach-row .ledger-row-mark{flex:0 0 auto;margin-left:6px;width:1.2em;text-align:center;
    color:var(--amber);font-size:1rem;}
  .ach-row.reveal-focus .ledger-row-title{color:#e7c879;}
  .tutorial .card{border-color:var(--green);max-width:420px;width:100%;}
  .tutorial .card-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:4px;}
  .save-err{text-align:center;color:var(--red);font-size:.72rem;padding:2px 0;}

  /* ornament divider lines — shared by the high-scores + end-of-game heroes */
  .eos-orn-line{flex:1 1 auto;height:1px;background:linear-gradient(to var(--tdir,right),transparent,var(--amber));}
  .eos-orn-line.r{background:linear-gradient(to left,transparent,var(--amber));}

  /* === EVENT POPUP — locked standard: full-bleed left art (see docs/ui-standards/popup.png) === */
  .modal .ev-popup{width:100%;}
  .ev-popup.ev-measuring{visibility:hidden;}
  .ev-popup{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;width:100%;
    max-width:min(520px, 100%);height:min(436px, 88dvh);max-height:88dvh;
    border:1px solid var(--amber);border-radius:12px;overflow:hidden;
    background:var(--bg);box-shadow:0 12px 46px var(--shadow);}
  .ev-left{grid-column:1;align-self:stretch;min-height:0;min-width:0;overflow:hidden;padding:0;margin:0;
    box-sizing:border-box;background-color:#000;background-size:cover;background-position:center center;
    background-repeat:no-repeat;filter:brightness(1.1);}
  .ev-right{grid-column:2;display:flex;flex-direction:column;padding:14px 13px 12px;
    border-left:1px solid var(--amber);height:100%;min-height:0;min-width:0;overflow:hidden;}
  .ev-body{flex:1 1 auto;display:flex;align-items:center;justify-content:center;
    font-size:.88rem;line-height:1.6;color:var(--text);text-align:center;overflow-y:auto;}
  .ev-body b{color:var(--amber);}
  .ev-acts{flex:0 0 auto;display:flex;flex-direction:column;gap:7px;margin-top:12px;}
  .ev-acts button{font-size:.8rem;padding:10px 8px;letter-spacing:.5px;}
  .ev-status{font-size:.8rem;color:var(--dim);text-align:center;margin-bottom:4px;}
  .ev-warn{font-size:.72rem;color:var(--dim);text-align:center;margin-top:4px;}

  /* === TIER EVENT POPUP — title + description above a large illustration, NEXT below === */
  .modal.modal-event{background:#0a0805;box-sizing:border-box;
    padding:max(10px,env(safe-area-inset-top)) 10px max(10px,env(safe-area-inset-bottom));}
  .modal .ev-tier{width:100%;}
  .ev-tier{display:flex;flex-direction:column;align-items:center;
    width:100%;max-width:min(480px,100%);max-height:min(92dvh,100%);gap:11px;box-sizing:border-box;}
  .ev-tier-head{flex:0 0 auto;width:100%;text-align:center;padding:0 4px;}
  .ev-tier-title{font-family:var(--font-display);font-weight:700;color:var(--amber);
    font-size:clamp(1.3rem,6.4vw,1.95rem);letter-spacing:1.5px;text-transform:uppercase;line-height:1.12;}
  .ev-tier-desc{margin-top:12px;padding:0 8px;font-size:clamp(.8rem,3.4vw,.95rem);line-height:1.42;color:var(--text);}
  .ev-tier-art{flex:0 0 auto;max-width:100%;display:flex;align-items:center;justify-content:center;overflow:hidden;}
  .ev-tier-art img{width:100%;height:100%;object-fit:contain;
    border:1px solid var(--amber);border-radius:10px;display:block;filter:brightness(1.08);}
  .ev-tier-acts{flex:0 0 auto;width:100%;display:flex;justify-content:center;}
  .ev-tier-acts button{font-size:.86rem;padding:13px 8px;letter-spacing:1px;}

  /* Desktop browser — same 853×1844 contain fit as welcome screen */
  @media (pointer:fine) and (min-width:560px){
    #portrait-root{width:100%;height:100dvh;min-height:0;align-items:center;justify-content:center;}
    #crt.game-mode,#crt.ledger-mode{
      container-type:inline-size;
      flex:0 0 auto;
      align-self:center;
      width:min(100vw,100dvh * var(--phone-canvas-w) / var(--phone-canvas-h));
      height:min(100dvh,100vw * var(--phone-canvas-h) / var(--phone-canvas-w));
      max-width:none;
      max-height:none;
      padding:0;}
    #crt.title-mode .title-cover{
      width:min(100vw,100dvh * var(--phone-canvas-w) / var(--phone-canvas-h));
      height:min(100dvh,100vw * var(--phone-canvas-h) / var(--phone-canvas-w));
      left:50%;
      top:50%;
      transform:translate(-50%,-50%);}
    .market-play .loc-header{flex:0 0 82px;height:82px;min-height:82px;max-height:82px;}
    .market-play .loc-header-title{font-size:1.05rem;}
    .market-play .loc-header-desc{font-size:.744rem;line-height:1.25;-webkit-line-clamp:2;}
    .market-golden-banner{font-size:.58rem;}
    .market-head-title{font-size:1.08rem;}
    .goods-icon-wrap.no-icon::after{font-size:20px;}
    .goods-name{font-size:.7rem;}
    .market-row .price-cell{font-size:.88rem;}
    .market-row .stock-cell{font-size:.95rem;}
    .market-play .market-actions button{font-size:.6rem;}
    .market-play .flip-digit span{font-size:1.35rem;}
    .market-play .bot-stat .bot-label{font-size:.7rem;}
    .market-play .bot-val{font-size:1.05rem;}
    .market-play .actions button{font-size:.64rem;}
    .market-play .bot-bar{flex:0 0 123px;height:123px;min-height:123px;max-height:123px;padding:10px 12px 7px;overflow:visible;}
    .market-play .bot-stats{gap:4px 10px;}
    .market-play .bot-stat{flex-direction:column;align-items:flex-start;gap:2px;}
    .market-play .bot-stat.right{align-items:flex-end;}
    .market-play .bot-stat .bot-val{font-size:.95rem;}
    .market-play .bot-sub{display:grid;grid-template-columns:1fr 1fr;gap:3px 10px;white-space:normal;font-size:.72rem;}
    .modal.modal-event .ev-tier{width:auto;max-width:min(340px,92vw);gap:8px;}
    .modal.modal-event .ev-tier-title{font-size:1.1rem;letter-spacing:1px;line-height:1.15;}
    .modal.modal-event .ev-tier-desc{margin-top:8px;font-size:.76rem;line-height:1.35;}
    .modal.modal-event .ev-tier-acts{width:100%;align-self:stretch;padding:0 10px;justify-content:center;}
    .modal.modal-event .ev-tier-acts button.full{width:min(200px,100%);margin:0;padding:10px 16px;font-size:.8rem;min-height:0;}}

  /* === PORTRAIT ONLY — portrait layout fixed; rotate viewport on touch landscape === */
  #portrait-root{width:100%;height:100%;min-height:0;display:flex;justify-content:center;}
  @media (pointer:coarse){
    #portrait-root{align-items:stretch;}
  }
  @media (orientation:landscape) and (pointer:coarse){
    html,body{overflow:hidden;}
    #portrait-root{position:fixed;top:0;left:0;width:100vh;height:100vw;
      transform:rotate(-90deg) translateX(-100%);transform-origin:top left;}
  }
