*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0F1C21;--text: #E6E0D6;--sage: #294747;--sage-dark: #476B66;--sage-light: #1A2B2E;--gold: #E08533;--gold-dark: #B86B33;--font: "Nunito", system-ui, -apple-system, sans-serif;--desktop-bp: 700px}[data-theme=light]{--bg: #EDF5F0;--text: #1F3338;--sage: #ADCCBD;--sage-dark: #85A899;--sage-light: #D9E6DE;--gold: #EB9E4D;--gold-dark: #B86B33}html,body{height:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:var(--font);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}#app{margin:0 auto;height:100%;display:flex;flex-direction:column;padding:0 0 env(safe-area-inset-bottom,0)}header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px 0}header .title{font-size:17px;font-weight:700}#settings-btn{width:36px;height:36px;border-radius:50%;background:var(--sage-light);display:flex;align-items:center;justify-content:center;color:var(--text)}.divider{height:1px;background:var(--sage);margin:8px 20px 4px}#main-layout,#game-column{flex:1;display:flex;flex-direction:column;min-height:0}#sidebar{display:none}@media(min-width:700px){#app{max-width:860px;padding-top:16px}#main-layout{flex-direction:row;gap:0}#game-column{flex:0 0 auto;width:420px}#mobile-progress{display:none!important}#sidebar{display:flex;flex-direction:column;flex:1;min-width:260px;max-width:380px;border-left:1px solid var(--sage);min-height:0}}@media(max-width:699px){#app{max-width:420px}#mobile-progress{display:contents}#sidebar{display:none}}#sidebar-progress{padding:8px 20px 12px;flex-shrink:0}#sidebar-milestone-label{font-size:15px;font-weight:700;min-height:21px;line-height:21px}#sidebar-progress-row{display:flex;align-items:center;gap:12px;margin-top:6px}#sidebar-progress-bar{flex:1;height:12px;position:relative;display:flex;align-items:center}#sidebar-score-badge{min-width:38px;height:38px;background:var(--gold);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;flex-shrink:0;padding:0 6px}#sidebar-words{flex:1;display:flex;flex-direction:column;min-height:0}#sidebar-words-header{display:flex;align-items:center;justify-content:space-between;padding:4px 20px 12px;flex-shrink:0}#sidebar-words-divider{flex-shrink:0}#sidebar-word-list{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}#progress-section{padding:8px 24px 12px}#milestone-label,#sidebar-milestone-label{font-size:15px;font-weight:700;min-height:21px;line-height:21px}#progress-row,#sidebar-progress-row{display:flex;align-items:center;gap:12px;margin-top:6px}#progress-bar,#sidebar-progress-bar{flex:1;height:12px;position:relative;display:flex;align-items:center}.progress-track{position:absolute;left:0;right:0;height:3px;background:color-mix(in srgb,var(--gold) 40%,transparent);border-radius:2px}.progress-fill{position:absolute;left:0;height:3px;background:var(--gold);border-radius:2px;transition:width .4s cubic-bezier(.34,1.56,.64,1)}.progress-dots{position:absolute;left:0;right:0;display:flex;justify-content:space-between;align-items:center}.progress-dot{width:8px;height:8px;border-radius:2px;background:color-mix(in srgb,var(--gold) 40%,transparent);transition:background .3s;flex-shrink:0}.progress-dot.active{background:var(--gold)}.progress-indicator{position:absolute;width:12px;height:12px;border-radius:3px;background:var(--gold);transition:left .4s cubic-bezier(.34,1.56,.64,1)}#score-badge,#sidebar-score-badge{min-width:38px;height:38px;background:var(--gold);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;flex-shrink:0;padding:0 6px}#found-words-bar{display:flex;align-items:center;margin:0 16px 8px;padding:12px 16px;background:var(--sage-light);border-radius:12px;font-size:15px;text-align:left;width:calc(100% - 32px)}#found-words-bar:disabled{cursor:default}#found-words-text{flex:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}#found-words-text.placeholder{color:var(--sage-dark)}#found-words-chevron{color:var(--sage-dark);margin-left:8px;flex-shrink:0}#game-area{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;padding:0 20px 16px;min-height:0}#message-container{height:40px;display:flex;align-items:center;justify-content:center;position:relative;width:100%}#current-word-row{display:flex;align-items:center;justify-content:center;transition:transform .08s}#word-display{display:flex;gap:2px;font-size:30px;font-weight:700}#word-display .letter{transition:color .1s}#word-display .letter.gold{color:var(--gold)}#cursor{width:2px;height:30px;background:var(--gold);animation:blink 1.06s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}#message{position:absolute;bottom:100%;margin-bottom:4px;font-size:14px;font-weight:600;padding:6px 16px;border-radius:999px;background:var(--sage);white-space:nowrap;opacity:0;transform:translateY(8px);transition:opacity .2s,transform .2s;pointer-events:none}#message.visible{opacity:1;transform:translateY(0)}#complete-badge{font-size:14px;font-weight:600;padding:6px 16px;border-radius:999px;background:var(--gold);white-space:nowrap}#letter-grid{display:flex;gap:8px;align-items:flex-start}.grid-col{display:flex;flex-direction:column;gap:8px}.grid-cell{width:80px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;cursor:pointer;transition:transform .3s cubic-bezier(.34,1.56,.64,1),background .3s;will-change:transform}.grid-cell.square{height:80px}.grid-cell.tall{height:124px}.grid-cell.normal{background:var(--sage)}.grid-cell.center{background:var(--gold)}.grid-cell.hidden{background:var(--sage-light);cursor:default;font-size:24px;color:color-mix(in srgb,var(--sage-dark) 40%,transparent)}.grid-cell.pressed{transform:scale(.95) rotate(-2deg)}.grid-cell .letter-reveal{animation:letterReveal .5s cubic-bezier(.34,1.56,.64,1)}@keyframes letterReveal{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}#reveal-progress{font-size:13px;font-weight:500;color:var(--sage-dark);text-align:center}#buttons-row{display:flex;align-items:center;gap:16px}.action-btn{display:flex;align-items:center;justify-content:center;gap:6px;font-weight:500;font-size:16px;transition:opacity .15s,background .15s}.action-btn.pill{width:110px;height:46px;border-radius:999px;background:var(--sage-light)}.action-btn.circle{width:46px;height:46px;border-radius:50%;background:var(--sage-light)}.action-btn:disabled{color:var(--sage-dark);background:color-mix(in srgb,var(--sage-light) 50%,transparent)}.action-btn svg{flex-shrink:0}#hint-section{display:flex;flex-direction:column;align-items:center;gap:6px}#hint-display{font-size:18px;font-weight:600;font-family:Courier New,monospace;letter-spacing:2px;min-height:24px}#hint-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:999px;background:color-mix(in srgb,var(--gold) 15%,transparent);color:var(--gold);font-size:14px;font-weight:500}#share-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:999px;background:var(--sage-light);font-size:14px;font-weight:500}#play-again-row{width:100%;display:flex;justify-content:center}#play-again-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:200px;height:50px;border-radius:999px;background:var(--text);color:var(--bg);font-size:17px;font-weight:700}.overlay{position:fixed;inset:0;z-index:100;display:flex;align-items:flex-end;justify-content:center}.overlay:before{content:"";position:absolute;inset:0;background:var(--bg);opacity:0;transition:opacity .3s}.overlay.open:before{opacity:.7}.overlay.celebration{align-items:center;flex-direction:column;justify-content:center}.overlay.celebration:before{opacity:0;transition:opacity .4s}.overlay.celebration.open:before{opacity:.95}.sheet{position:relative;z-index:1;width:100%;max-width:420px;max-height:70vh;background:var(--bg);border-radius:20px 20px 0 0;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .35s cubic-bezier(.32,.72,0,1)}.overlay.open .sheet{transform:translateY(0)}.settings-overlay{align-items:stretch}.settings-overlay:before{opacity:0;transition:opacity .35s}.settings-overlay.open:before{opacity:.7}.settings-overlay .sheet{max-width:100%;max-height:none;border-radius:0;margin-left:auto;transform:translate(100%);transition:transform .35s cubic-bezier(.32,.72,0,1)}@media(min-width:700px){.settings-overlay .sheet{max-width:70%}}.settings-overlay.open .sheet{transform:translate(0)}.settings-close{width:36px;height:36px;border-radius:50%;background:var(--sage-light);display:flex;align-items:center;justify-content:center;color:var(--text)}.settings-sheet{max-height:none}.sheet-handle{width:36px;height:5px;border-radius:3px;background:var(--sage);margin:10px auto 8px;flex-shrink:0}.settings-sheet .sheet-handle{display:none}.sheet-header{display:flex;align-items:center;justify-content:space-between;padding:0 20px 12px;flex-shrink:0}.settings-sheet .sheet-header{padding:16px 20px 12px}.sheet-title{font-size:20px;font-weight:700}.sheet-count{font-size:16px;font-weight:600;opacity:.6}.text-btn{font-size:16px;font-weight:600}.sheet-divider{height:1px;background:var(--sage);flex-shrink:0}.sheet-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.word-row{display:flex;align-items:center;padding:10px 20px;font-size:17px;border-bottom:1px solid color-mix(in srgb,var(--sage) 50%,transparent)}.word-row .word{flex:1}.word-row.pangram .word{font-weight:700;color:var(--gold)}.word-row .pangram-label{font-size:12px;font-weight:600;color:var(--gold)}.word-row .check{width:14px;height:14px;color:var(--gold)}.sidebar-empty{padding:20px;text-align:center;color:var(--sage-dark);font-size:15px}.settings-section-label{font-size:13px;font-weight:700;letter-spacing:1px;text-transform:uppercase;opacity:.5;padding:16px 0 8px}.settings-card{background:var(--sage-light);border-radius:14px;padding:16px;margin-bottom:8px}.settings-row{display:flex;align-items:center;justify-content:space-between}.settings-row label{font-size:16px;font-weight:500}.settings-help{font-size:13px;opacity:.6;margin-top:8px;line-height:1.4}.toggle{position:relative;width:60px;height:34px;border-radius:8px;background:var(--sage);cursor:pointer;transition:background .3s;flex-shrink:0}.toggle.on{background:var(--gold)}.toggle-thumb{position:absolute;top:4px;left:4px;width:26px;height:26px;border-radius:6px;background:#fff;box-shadow:0 1px 3px #00000026;transition:left .3s cubic-bezier(.34,1.56,.64,1)}.toggle.on .toggle-thumb{left:30px}.segmented{display:flex;background:var(--sage);border-radius:10px;height:40px;position:relative;margin-top:10px}.segmented-thumb{position:absolute;top:3px;height:34px;border-radius:8px;background:var(--text);transition:left .3s cubic-bezier(.34,1.56,.64,1),width .3s}.segmented button{flex:1;z-index:1;font-size:15px;font-weight:500;border-radius:8px;transition:color .2s,font-weight .2s}.segmented button.active{color:var(--bg);font-weight:700}.segmented button:not(.active){opacity:.6}.settings-apply-btn{width:100%;height:50px;border-radius:999px;background:var(--text);color:var(--bg);font-size:17px;font-weight:700;margin-top:8px}.settings-newgame-btn{width:100%;height:50px;border-radius:999px;background:var(--gold);font-size:17px;font-weight:700;margin-top:8px}.settings-apply-help{font-size:13px;opacity:.6;text-align:center;margin-top:8px;line-height:1.4}.word-length-header{display:flex;align-items:center;padding:14px 16px 6px}.word-length-header:first-child{padding-top:4px}.word-length-label{font-size:13px;font-weight:700;letter-spacing:.5px;opacity:.5;flex:1}.word-length-reveal{font-size:12px;font-weight:600;color:var(--gold);cursor:pointer;background:none;border:none;padding:2px 8px}.word-length-count{font-size:13px;font-weight:600;opacity:.4;margin-left:8px}.word-length-count.complete{opacity:1;color:var(--gold)}.reveal-row{display:flex;align-items:center;padding:6px 16px}.reveal-word{font-size:15px;text-transform:uppercase}.reveal-word.found{font-weight:600;flex:1}.reveal-word.hidden-word{color:transparent;background:color-mix(in srgb,var(--text) 20%,transparent);border-radius:4px;cursor:pointer;display:inline-block;padding:0 4px;margin:-2px 0}.reveal-word.revealed{opacity:.45}.reveal-word .check-icon{color:var(--gold);font-size:14px;margin-left:auto}.help-row{display:flex;gap:8px;padding:5px 0;font-size:15px}.help-num{font-weight:700;color:var(--gold)}.collapsible-header{display:flex;align-items:center;width:100%;padding:16px;font-size:16px;font-weight:500;text-align:left}.collapsible-header span:first-child{flex:1}.collapsible-header .chevron{opacity:.6;display:flex;align-items:center;flex-shrink:0}.collapsible-header .count{font-size:14px;font-weight:600;opacity:.6;margin-right:8px}.collapsible-content{max-height:0;overflow:hidden;transition:max-height .3s ease;padding-top:0;padding-bottom:0}.collapsible-content.open{max-height:2000px;padding-bottom:14px}.how-to-play-content.open{padding:0 16px 14px}#confetti-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none}#celebration-content,#milestone-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;text-align:center;width:100%;max-width:360px;padding:0 32px;opacity:0;transform:scale(.9);transition:opacity .5s,transform .5s cubic-bezier(.34,1.56,.64,1)}#celebration-content.visible,#milestone-content.visible{opacity:1;transform:scale(1)}.celebrate-emoji{font-size:64px;margin-bottom:16px}.celebrate-title{font-size:36px;font-weight:700}.celebrate-subtitle{font-size:18px;font-weight:500;opacity:.7;margin-top:8px}.celebrate-badge{display:flex;align-items:center;gap:8px;padding:12px 24px;background:var(--sage-light);border-radius:999px;margin-top:16px;font-size:20px;font-weight:700}.celebrate-badge .star{color:var(--gold)}.celebrate-badge .slash{font-weight:500;opacity:.4;font-size:18px}.celebrate-badge .gold{color:var(--gold)}.celebrate-buttons{width:100%;margin-top:32px;display:flex;flex-direction:column;gap:12px}.btn-primary{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;height:54px;border-radius:999px;background:var(--text);color:var(--bg);font-size:17px;font-weight:700}.btn-secondary{width:100%;height:54px;border-radius:999px;background:var(--sage-light);font-size:17px;font-weight:600}@keyframes shake{0%{transform:translate(0)}15%{transform:translate(12px)}30%{transform:translate(-10px)}45%{transform:translate(8px)}60%{transform:translate(-5px)}to{transform:translate(0)}}.shake{animation:shake .4s ease-out}@media(max-height:700px){#game-area{gap:16px;padding-bottom:8px}.grid-cell.square{height:64px;width:64px;font-size:24px}.grid-cell.tall{height:100px;width:64px;font-size:24px}#letter-grid,.grid-col{gap:6px}#word-display{font-size:26px}#cursor{height:26px}}@media(max-width:360px){.grid-cell.square{height:68px;width:68px;font-size:24px}.grid-cell.tall{height:106px;width:68px;font-size:24px}.action-btn.pill{width:96px;height:42px;font-size:14px}.action-btn.circle{width:42px;height:42px}#buttons-row{gap:12px}}#app.loading{display:flex;align-items:center;justify-content:center}#app.loading:after{content:"Loading...";font-size:18px;font-weight:600;color:var(--sage-dark)}
