:root {
  --bg: #111010;
  --surface: #1c1b1a;
  --surface2: #252423;
  --cream: #f0ebe0;
  --cream-dim: #9a9186;
  --cream-faint: #3a3630;
  --green: #2d6a4f;
  --green-bright: #52c28a;
  --green-bg: rgba(45,106,79,0.18);
  --amber: #b8860b;
  --amber-bright: #e8b830;
  --amber-bg: rgba(184,134,11,0.15);
  --red: #8b3030;
  --red-bright: #e05252;
  --red-bg: rgba(139,48,48,0.18);
  --gold: #e8b830;
  --border: rgba(240,235,224,0.10);
  --border-mid: rgba(240,235,224,0.20);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{
  background:var(--bg);color:var(--cream);
  font-family:'DM Sans',sans-serif;
  min-height:100vh;max-width:430px;
  margin:0 auto;padding:0 14px 20px;
  position:relative;overflow-x:hidden;
}
body::before{
  content:'';position:fixed;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");
  opacity:0.3;pointer-events:none;z-index:0;
}

/* HEADER */
.header{display:flex;justify-content:space-between;align-items:center;padding:18px 0 16px;border-bottom:1px solid var(--border);position:relative;z-index:1}
.logo{font-family:'Playfair Display',serif;font-size:21px;font-weight:700;letter-spacing:-0.3px}
.logo span{color:var(--gold);font-style:italic;font-weight:400}
.header-right{display:flex;align-items:center;gap:8px}
.timer-display{font-family:'Inconsolata',monospace;font-size:14px;color:var(--cream-dim);letter-spacing:.5px}
.hints-pill{display:flex;align-items:center;gap:4px;padding:5px 10px;border-radius:20px;border:1px solid rgba(232,184,48,0.4);font-size:13px;font-weight:600;color:var(--gold)}

/* SCREENS */
.screen{display:none;position:relative;z-index:1}
.screen.active{display:block}

/* HOME */
.puzzle-meta{text-align:center;padding:16px 0 18px;border-bottom:1px solid var(--border);margin-bottom:18px}
.puzzle-num-label{font-size:11px;text-transform:uppercase;letter-spacing:3px;color:var(--cream-dim);margin-bottom:3px}
.puzzle-title-large{font-family:'Playfair Display',serif;font-size:30px;font-weight:700}
.puzzle-date-small{font-size:12px;color:var(--cream-dim);margin-top:2px;font-style:italic;font-family:'Playfair Display',serif}
.cards-list{display:flex;flex-direction:column;gap:8px}

.puzzle-card{
  background:var(--surface);border:1px solid var(--border);border-radius:14px;
  padding:14px 15px;cursor:pointer;display:flex;align-items:center;gap:12px;
  transition:border-color .2s,background .15s,transform .1s;
  -webkit-tap-highlight-color:transparent;
  opacity:0;animation:fade-up .35s ease forwards;
}
.puzzle-card:nth-child(1){animation-delay:.05s}
.puzzle-card:nth-child(2){animation-delay:.10s}
.puzzle-card:nth-child(3){animation-delay:.15s}
.puzzle-card:nth-child(4){animation-delay:.20s}
.puzzle-card:nth-child(5){animation-delay:.25s}
.puzzle-card:active{transform:scale(.98);background:var(--surface2)}
.puzzle-card.solved{border-color:rgba(82,194,138,.45);background:rgba(45,106,79,0.12)}
.puzzle-card.solved .card-num{color:var(--green-bright)}
.puzzle-card.solved .card-chain{color:var(--green-bright)}
.puzzle-card.solved .sep{color:rgba(82,194,138,.3)!important}
.puzzle-card.solved-hinted{border-color:rgba(232,184,48,.45);background:rgba(184,134,11,0.12)}
.puzzle-card.solved-hinted .card-num{color:var(--amber-bright)}
.puzzle-card.solved-hinted .card-chain{color:var(--amber-bright)}
.puzzle-card.solved-hinted .sep{color:rgba(232,184,48,.3)!important}
.card-hint-badge{font-family:'Inconsolata',monospace;font-size:12px;font-weight:700;color:var(--amber-bright);flex-shrink:0}
.puzzle-card.revealed{border-color:rgba(224,82,82,.3);background:rgba(139,48,48,0.08);opacity:.7}
.puzzle-card.done{cursor:default}
.puzzle-card.done:active{transform:none}
@keyframes card-pop{0%{transform:scale(1)}40%{transform:scale(1.025)}100%{transform:scale(1)}}
.puzzle-card.just-solved{animation:card-pop .4s ease}

.card-num{font-family:'Inconsolata',monospace;font-size:13px;color:var(--cream-dim);min-width:18px}
.card-body{flex:1;min-width:0}
.card-chain{font-family:'Inconsolata',monospace;font-size:14px;font-weight:700;letter-spacing:.8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-chain .blanks{color:var(--cream-dim);font-weight:500}
.card-chain .connector-answer{color:var(--gold)}
.card-chain .sep{color:var(--cream-faint);margin:0 5px}
.card-icon{font-size:16px;flex-shrink:0}

/* PUZZLE NAV */
.puzzle-nav{display:flex;align-items:center;gap:10px;padding:12px 0;border-bottom:1px solid var(--border)}
.back-btn{background:none;border:1px solid var(--border-mid);color:var(--cream);width:34px;height:34px;border-radius:9px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;-webkit-tap-highlight-color:transparent;transition:background .15s}
.back-btn:active{background:var(--surface2)}
.puzzle-nav-label{font-size:13px;color:var(--cream-dim);font-family:'Inconsolata',monospace;letter-spacing:.5px}

/* CHAIN DISPLAY */
.chain-display{display:flex;flex-direction:column;align-items:center;padding:22px 0 16px;gap:5px}
.chain-outer{font-family:'Inconsolata',monospace;font-size:17px;font-weight:700;letter-spacing:2px;color:var(--cream-dim)}
.chain-separator{font-size:11px;color:var(--cream-faint);letter-spacing:5px;margin:1px 0}
.slots-row{display:flex;gap:6px;margin:2px 0}
.slot{
  width:44px;height:52px;border-radius:10px;border:2px solid var(--border-mid);
  display:flex;align-items:center;justify-content:center;
  font-family:'Inconsolata',monospace;font-size:22px;font-weight:700;
  transition:border-color .15s,background .15s,color .15s;
}
.slot.is-active{border-color:rgba(240,235,224,.45);background:rgba(240,235,224,.03)}
.slot.is-hint{border-color:var(--amber);color:var(--amber-bright);background:var(--amber-bg)}
.slot.is-user{border-color:var(--border-mid);color:var(--cream)}
.slot.is-correct{border-color:var(--green);color:var(--green-bright);background:var(--green-bg)}
.slot.is-wrong{border-color:var(--red);color:var(--red-bright);background:var(--red-bg)}
@keyframes shake{0%,100%{transform:translateX(0)}15%{transform:translateX(-7px)}35%{transform:translateX(7px)}55%{transform:translateX(-5px)}75%{transform:translateX(5px)}}
.slots-row.shaking{animation:shake .42s ease}
@keyframes slot-bounce{0%{transform:translateY(0)}45%{transform:translateY(-5px)}100%{transform:translateY(0)}}

/* CONTROLS */
.controls-row{display:flex;gap:7px;padding:8px 0 10px}
.ctrl-btn{
  border-radius:11px;border:1px solid var(--border-mid);background:none;color:var(--cream);
  font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;cursor:pointer;
  padding:10px 8px;transition:background .15s,border-color .15s;
  -webkit-tap-highlight-color:transparent;text-align:center;
}
.ctrl-btn:active{background:var(--surface2)}
.ctrl-btn:disabled{opacity:.35;cursor:not-allowed;pointer-events:none}
.btn-hint{flex:1;border-color:rgba(232,184,48,.4);color:var(--amber-bright)}
.btn-hint:active{background:var(--amber-bg)}
.btn-reveal{flex:1;border-color:rgba(224,82,82,.3);color:var(--red-bright);font-size:13px}
.btn-reveal:active{background:var(--red-bg)}
.btn-reveal.confirm-mode{border-color:var(--red-bright);background:var(--red-bg)}

/* KEYBOARD */
.keyboard{display:flex;flex-direction:column;gap:6px;padding:2px 0 0;user-select:none}
.kb-row{display:flex;gap:5px;justify-content:center}
.kb-key{
  height:52px;min-width:30px;flex:1;max-width:40px;
  background:#2e2c2a;border:none;border-radius:8px;
  color:var(--cream);font-family:'DM Sans',sans-serif;
  font-size:14px;font-weight:600;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .1s,transform .08s;
  -webkit-tap-highlight-color:transparent;
  box-shadow:0 2px 0 rgba(0,0,0,.4);
}
.kb-key:active{transform:translateY(1px);box-shadow:none;background:#3d3a37}
.kb-key.key-wide{min-width:50px;max-width:58px;font-size:12px}

/* RESULTS */
.results-wrap{padding:24px 0}
.results-headline{font-family:'Playfair Display',serif;font-size:32px;font-weight:700;text-align:center;line-height:1.1;margin-bottom:5px}
.results-sub{text-align:center;color:var(--cream-dim);font-size:13px;margin-bottom:22px}
.share-card{background:var(--surface);border:1px solid var(--border-mid);border-radius:16px;padding:18px 16px;margin-bottom:14px}
.share-card-title{font-family:'Inconsolata',monospace;font-size:14px;font-weight:700;color:var(--gold);margin-bottom:14px;letter-spacing:.5px}
.share-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.share-row-num{font-family:'Inconsolata',monospace;font-size:12px;color:var(--cream-dim);min-width:20px}
.share-row-emojis{font-size:18px;letter-spacing:1px;line-height:1}
.share-divider{height:1px;background:var(--border);margin:12px 0}
.share-stats-line{font-family:'Inconsolata',monospace;font-size:13px;color:var(--cream-dim);line-height:1.7}
.share-url{color:var(--gold)}
.copy-btn{width:100%;padding:16px;background:var(--gold);color:#111010;border:none;border-radius:13px;font-family:'DM Sans',sans-serif;font-size:16px;font-weight:700;cursor:pointer;transition:opacity .15s,background .2s;-webkit-tap-highlight-color:transparent}
.copy-btn:active{opacity:.8}
.copy-btn.copied{background:var(--green-bright)}

/* DAY SWITCHER removed */

/* TOAST */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--cream);color:#111010;padding:9px 20px;border-radius:22px;font-size:13px;font-weight:600;transition:transform .28s cubic-bezier(.34,1.56,.64,1);pointer-events:none;z-index:999;white-space:nowrap;box-shadow:0 4px 20px rgba(0,0,0,.5)}
.toast.show{transform:translateX(-50%) translateY(0)}
@keyframes fade-up{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
