@import "https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=DM+Sans:wght@400;500;600&display=swap";:root{--bg-primary:#fff;--bg-secondary:#f7f6f3;--bg-card:#fff;--bg-surface:#f2f1ee;--accent:#00b899;--accent-dim:#00b8991a;--accent-border:#00b89940;--text-primary:#111827;--text-secondary:#4b5563;--text-muted:#9ca3af;--coral:#ff6b6b;--coral-dim:#ff6b6b1a;--success:#00b899;--warning:#f59e0b;--error:#ff6b6b;--card-bg:#fff;--card-shadow:0 1px 4px #00000014, 0 4px 16px #0000000f;--border:#00000014;--border-subtle:#0000000a;--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--radius-xl:28px;--sans:"DM Sans", system-ui, sans-serif;--display:"Syne", system-ui, sans-serif;font-family:var(--sans);color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.5}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-secondary);min-height:100dvh}#root{flex-direction:column;min-height:100dvh;display:flex}h1,h2,h3{font-family:var(--display);color:var(--text-primary);font-weight:700}.btn-primary{background:var(--accent);color:#fff;border-radius:var(--radius-md);font-family:var(--sans);cursor:pointer;border:none;justify-content:center;align-items:center;padding:12px 24px;font-size:15px;font-weight:600;text-decoration:none;transition:all .18s;display:inline-flex}.btn-primary:hover{background:#009e83;transform:translateY(-1px);box-shadow:0 4px 16px #00b89940}.btn-primary:active{box-shadow:none;transform:none}.btn-primary:disabled,.btn-primary--disabled{opacity:.45;cursor:not-allowed;box-shadow:none;pointer-events:none;transform:none}.btn-secondary{color:var(--text-primary);border:1.5px solid var(--border);border-radius:var(--radius-md);font-family:var(--sans);cursor:pointer;background:0 0;justify-content:center;align-items:center;padding:11px 22px;font-size:15px;font-weight:500;text-decoration:none;transition:all .18s;display:inline-flex}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.app-header{background:var(--bg-card);border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;padding:14px 24px;display:flex;position:sticky;top:0}.header-logo{font-family:var(--display);color:var(--accent);letter-spacing:-.5px;font-size:20px;font-weight:800;text-decoration:none}.header-right{align-items:center;gap:10px;display:flex}.header-item{background:var(--bg-surface);border:1.5px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;align-items:center;gap:8px;padding:8px 14px;font-size:13px;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.header-item:hover{background:var(--accent-dim);border-color:var(--accent);color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 12px #00b89926}.logout-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;transition:all .2s;display:flex}.logout-btn:hover{color:var(--coral);background:#ff6b6b14}.logout-modal-backdrop{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.logout-modal{background:var(--bg-card);border-radius:var(--radius-xl);width:90%;max-width:320px;padding:24px;box-shadow:0 20px 60px #0000004d}.logout-modal h3{margin:0 0 8px;font-size:16px}.logout-modal p{color:var(--text-secondary);margin:0 0 20px;font-size:13px}.logout-modal-buttons{gap:8px;display:flex}.logout-modal-buttons button{flex:1}.streak-modal-backdrop{z-index:1001;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.streak-modal{background:var(--bg-card);border-radius:var(--radius-xl);width:90%;max-width:420px;max-height:80vh;padding:24px;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.streak-modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.streak-modal-title{margin:0;font-size:18px;font-weight:700}.streak-modal-close{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;justify-content:center;align-items:center;width:24px;height:24px;padding:0;font-size:20px;transition:color .18s;display:flex}.streak-modal-close:hover{color:var(--text-primary)}.streak-modal-content{flex-direction:column;gap:16px;display:flex}.streak-section{background:var(--bg-secondary);border-radius:var(--radius-md);padding:12px}.streak-section h3{margin:0 0 8px;font-size:14px}.streak-section p{color:var(--text-secondary);margin:0;font-size:13px;line-height:1.5}.streak-list{color:var(--text-secondary);margin:0;padding-left:16px;font-size:13px}.streak-list li{margin-bottom:6px}.streak-section.highlight{border:1.5px solid var(--accent-border);background:#00b89914}.streak-modal-btn{width:100%;margin-top:8px}.login-page{background:var(--bg-secondary);justify-content:center;align-items:center;min-height:100dvh;display:flex}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);text-align:center;width:100%;max-width:400px;box-shadow:var(--card-shadow);padding:48px 40px}.login-logo{color:var(--accent);letter-spacing:-1px;margin-bottom:6px;font-size:44px;font-weight:800}.login-tagline{color:var(--text-secondary);margin-bottom:28px;font-size:14px}.login-mascot-preview{background:var(--accent-dim);border:1px solid var(--accent-border);border-radius:var(--radius-md);justify-content:center;align-items:center;gap:10px;margin-bottom:28px;padding:10px 18px;display:flex}.mascot-emoji{font-size:22px}.mascot-label{color:var(--accent);font-size:13px;font-weight:600}.login-form{flex-direction:column;gap:10px;display:flex}.pseudo-input{background:var(--bg-surface);border:1.5px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);font-family:var(--sans);text-align:center;outline:none;padding:13px 16px;font-size:16px;transition:border-color .18s}.pseudo-input:focus{border-color:var(--accent)}.pseudo-input::placeholder{color:var(--text-muted)}.login-btn{width:100%;padding:14px;font-size:16px}.login-error{color:var(--coral);text-align:center;font-size:13px}.login-hint{color:var(--text-muted);margin-top:14px;font-size:12px}.collective-gauge{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--card-shadow);cursor:pointer;flex-direction:column;flex:1;justify-content:space-between;padding:24px;transition:all .18s;display:flex}.collective-gauge:hover{border-color:var(--accent-border);background:var(--bg-card);box-shadow:0 4px 20px #00b8991a}.gauge-header{align-items:center;gap:16px;margin-bottom:16px;display:flex}.gauge-mascot{flex-shrink:0;font-size:40px;line-height:1}.gauge-info{flex-direction:column;flex:1;gap:4px;display:flex}.gauge-level{font-family:var(--display);margin:0;font-size:18px;font-weight:700}.gauge-xp{color:var(--text-secondary);margin:0;font-size:13px}.gauge-chevron{color:var(--text-muted);flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;transition:color .18s;display:flex}.collective-gauge:hover .gauge-chevron{color:var(--accent)}.gauge-bar-track{background:var(--bg-surface);border-radius:4px;flex-shrink:0;height:8px;margin:20px 0;overflow:hidden}.gauge-bar-fill{background:linear-gradient(90deg, var(--accent), #00e8b8);border-radius:4px;height:100%}.gauge-next{color:var(--text-muted);text-align:right;margin:0;font-size:13px}.levels-modal-backdrop{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.levels-modal{background:var(--bg-card);border-radius:var(--radius-lg);flex-direction:column;width:90%;max-width:520px;height:80dvh;display:flex;box-shadow:0 20px 60px #0000004d}.levels-modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.levels-modal-title{margin:0;font-size:18px}.levels-modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:28px;height:28px;font-size:20px;transition:color .18s;display:flex}.levels-modal-close:hover{color:var(--text-primary)}.levels-modal-grid{grid-template-columns:repeat(2,1fr);gap:12px;padding:16px;display:grid}.levels-modal-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);gap:12px;padding:12px;transition:all .18s;display:flex}.levels-modal-card--unlocked{border-color:var(--accent-border);background:#00b8990d}.levels-modal-creature{flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex;position:relative}.levels-modal-lock{font-size:18px;position:absolute;top:-4px;right:-4px}.levels-modal-info{flex-direction:column;flex:1;gap:3px;display:flex}.levels-modal-name{font-family:var(--display);font-size:13px;font-weight:700}.levels-modal-xp{color:var(--text-muted);font-size:11px}.levels-modal-badge{color:var(--accent);margin-top:2px;font-size:11px;font-weight:600}.levels-modal-progress{flex-direction:column;gap:3px;margin-top:4px;display:flex}.levels-modal-progress-bar{background:var(--border);border-radius:2px;height:4px;overflow:hidden}.levels-modal-progress-fill{background:linear-gradient(90deg, var(--accent), #00e8b8);border-radius:2px;height:100%}.levels-modal-remaining{color:var(--text-muted);font-size:10px}.levels-modal-footer{border-top:1px solid var(--border);padding:12px 24px}.levels-modal-tabs{border-bottom:1px solid var(--border);background:var(--bg-card);z-index:10;flex-shrink:0;gap:24px;padding:0 24px;display:flex;position:sticky;top:0}.levels-modal-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:12px 0;font-size:14px;font-weight:600;transition:all .18s}.levels-modal-tab:hover{color:var(--text-primary)}.levels-modal-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.levels-modal-body{flex:1;padding:20px 24px;overflow-y:auto}.levels-modal-leaderboard{padding:16px 0}.leaderboard-list{flex-direction:column;display:flex}.leaderboard-item{border-bottom:1px solid var(--border-subtle);align-items:center;gap:12px;padding:12px 24px;font-size:14px;display:flex}.leaderboard-item:last-child{border-bottom:none}.leaderboard-rank{text-align:center;min-width:28px;font-size:18px}.leaderboard-name{color:var(--text-primary);flex:1;font-weight:600}.leaderboard-xp{color:var(--accent);font-weight:600}.leaderboard-item--active{background:var(--accent-dim);border-color:var(--accent-border);border-left:4px solid var(--accent)}.leaderboard-item--user{border-top:1px solid var(--border);background:#00b89908;margin-top:12px;padding-top:12px}@media (width<=600px){.levels-modal-grid{grid-template-columns:1fr}.leaderboard-item{padding:10px 16px;font-size:13px}}.hub-page{background:var(--bg-secondary);min-height:100dvh}.hub-main{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:40px 20px}.hub-section--spaced{margin-top:44px}.community-groups{flex-direction:column;gap:28px;display:flex}.community-group-date{color:var(--text-muted);text-transform:capitalize;letter-spacing:.04em;border-bottom:1px solid var(--border);margin:0 0 12px;padding-bottom:8px;font-size:13px;font-weight:700}.community-show-more{background:var(--bg-card);border:1.5px dashed var(--border);border-radius:var(--radius-md);width:100%;color:var(--text-secondary);cursor:pointer;text-align:center;padding:12px;font-size:13px;font-weight:600;transition:all .15s;display:block}.community-show-more:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.top-sections{grid-template-columns:1fr 1fr;gap:30px;margin-top:44px;margin-bottom:60px;display:grid}.top-sections>section{flex-direction:column;display:flex}.section-title{color:var(--text-primary);align-items:center;gap:8px;margin-bottom:24px;font-size:24px;font-weight:700;display:flex}.section-tip{color:var(--text-muted);cursor:default;flex-shrink:0;align-items:center;display:inline-flex;position:relative}.section-tip:after{content:attr(data-tip);background:var(--text-primary);color:#fff;font-size:12px;font-weight:400;font-family:var(--sans);border-radius:var(--radius-sm);white-space:normal;pointer-events:none;opacity:0;z-index:200;width:220px;padding:7px 10px;line-height:1.4;transition:opacity .15s;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)}.section-tip:before{content:"";border:5px solid #0000;border-top:5px solid var(--text-primary);pointer-events:none;opacity:0;z-index:200;transition:opacity .15s;position:absolute;bottom:calc(100% + 3px);left:50%;transform:translate(-50%)}.section-tip:hover:after,.section-tip:hover:before{opacity:1}.my-grid-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);min-height:200px;box-shadow:var(--card-shadow);flex-direction:column;justify-content:center;align-items:center;padding:24px;display:flex}.my-grid-empty{text-align:center;width:100%}.my-grid-empty h3{color:var(--text-secondary);margin-bottom:16px;font-size:16px;font-weight:600}.create-grid-btn{background:var(--accent);color:#fff;border-radius:var(--radius-md);font-family:var(--sans);cursor:pointer;border:none;padding:14px 32px;font-size:16px;font-weight:600;text-decoration:none;transition:all .18s;display:inline-block}.create-grid-btn:hover{background:#009e83;transform:translateY(-2px);box-shadow:0 4px 16px #00b89940}.create-grid-btn--disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.my-grid-forfeit-hint{color:var(--text-secondary);margin-bottom:16px;font-size:13px;line-height:1.5}.my-grid-card-container{flex-direction:column;flex:1;width:100%;display:flex}.my-grid-card-container .card-v2{width:100%;height:100%}.cards-grid{grid-template-columns:repeat(4,280px);justify-items:start;gap:16px;margin-bottom:60px;display:grid}.empty-state{background:var(--bg-card);border:1.5px dashed var(--border);border-radius:var(--radius-lg);text-align:center;color:var(--text-secondary);padding:60px 40px}.empty-state p{margin-bottom:20px;font-size:16px}@media (width<=768px){.hub-main{padding:24px 16px}.top-sections{grid-template-columns:1fr;gap:20px;margin-bottom:40px}.cards-grid{grid-template-columns:repeat(2,280px);gap:16px;margin-bottom:40px}}@media (width<=600px){.hub-main{padding:16px}.section-title{margin-bottom:16px;font-size:18px}.top-sections{grid-template-columns:1fr;gap:12px;margin-bottom:32px}.cards-grid{grid-template-columns:1fr;gap:12px}.empty-state{padding:40px 20px}}.card-v2{width:280px;height:280px;color:inherit;background:#fff;border-radius:12px;flex-direction:column;text-decoration:none;transition:transform .3s,box-shadow .3s;display:flex;overflow:hidden;box-shadow:0 4px 12px #0000001a}.card-v2:hover{transform:translateY(-4px);box-shadow:0 8px 20px #00000026}.card-v2-header{border-bottom:2px solid #e0e0e0;flex-shrink:0;align-items:center;gap:12px;padding:16px;display:flex}.card-v2-avatar{color:#fff;background:#ffffff40;border:2px solid #fff6;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:18px;font-weight:700;display:flex;box-shadow:0 2px 6px #00000026}.card-v2-name{color:#fff;flex:1;font-size:15px;font-weight:700}.card-v2-icon{color:#fff;font-size:16px}.card-v2-body{flex:1;grid-template-columns:1fr 1fr;gap:12px;padding:14px;display:grid}.card-v2-cell{text-align:center;background:#fafafa;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;padding:8px;display:flex}.card-v2-cell-label{color:#999;text-transform:uppercase;letter-spacing:.4px;justify-content:center;align-items:center;gap:3px;margin-bottom:4px;font-size:10px;font-weight:500;display:flex}.card-v2-cell-label svg{flex-shrink:0}.card-v2-cell-value{color:#1a1a1a;font-size:13px;font-weight:700}.card-v2-status--inprogress{color:#e89010}.card-v2-status--done,.card-v2-difficulty--easy{color:#00a889}.card-v2-difficulty--medium{color:#e89010}.card-v2-difficulty--hard{color:#f0440a}.grid-card-skeleton{background:var(--bg-surface);border-radius:var(--radius-md);height:68px;animation:1.5s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.hub-empty{text-align:center;color:var(--text-secondary);border:1.5px dashed var(--border);border-radius:var(--radius-lg);padding:44px 20px}.hub-loading{flex-direction:column;gap:10px;display:flex}.word-card{width:var(--slot-size,210px);height:var(--slot-size,210px);background:var(--card-bg);border:2px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--card-shadow);-webkit-user-select:none;user-select:none;flex-shrink:0;grid-template:".top."44px"left center right"1fr".bottom."44px/44px 1fr 44px;place-items:center;transition:border-color .18s,box-shadow .18s;display:grid;position:relative;overflow:visible}@media (width<=600px){.word-card{grid-template-rows:28px 1fr 28px;grid-template-columns:28px 1fr 28px;width:140px;height:140px}}.word-card--correct{box-shadow:0 0 0 3px #00b89926;border-color:var(--success)!important}.word-card--rotation{box-shadow:0 0 0 3px #f59e0b26;border-color:var(--warning)!important}.word-card--wrong{box-shadow:0 0 0 3px #ff6b6b26;border-color:var(--error)!important}.word-card--dragging{opacity:.35;box-shadow:0 20px 40px #00000026}.word-card-top{font-size:clamp(14px, calc(var(--slot-size,210px) * .078), 22px);text-align:center;letter-spacing:.04em;text-transform:uppercase;grid-area:top;font-weight:800}.word-card-bottom{font-size:clamp(14px, calc(var(--slot-size,210px) * .078), 22px);text-align:center;letter-spacing:.04em;text-transform:uppercase;grid-area:bottom;font-weight:800}.word-card-left{font-size:clamp(14px, calc(var(--slot-size,210px) * .078), 22px);text-align:center;letter-spacing:.04em;text-transform:uppercase;grid-area:left;font-weight:800;line-height:1.1}.word-card-right{font-size:clamp(14px, calc(var(--slot-size,210px) * .078), 22px);text-align:center;letter-spacing:.04em;text-transform:uppercase;grid-area:right;font-weight:800;line-height:1.1}.word-card-draggable{cursor:grab;display:inline-flex;position:relative}.word-card-draggable:active{cursor:grabbing}.word-card-rotate{border:2.5px solid var(--accent);cursor:pointer;width:52px;height:52px;color:var(--accent);z-index:10;background:#fffffff2;border-radius:50%;justify-content:center;align-items:center;font-size:26px;transition:background .15s,color .15s,transform .15s;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 3px 12px #00000029}.word-card-rotate:hover{background:var(--accent);color:#fff;transform:translate(-50%,-50%)scale(1.1)}.clover-wrapper{grid-template:".top."52px"left grid right"1fr".bottom."52px/auto 1fr auto;align-self:center;place-items:center;gap:6px;width:fit-content;margin:0 auto;display:grid}@media (width<=600px){.clover-wrapper{grid-template-rows:44px 1fr 44px;gap:4px;margin:16px auto}}.clue{font-family:var(--display);color:var(--accent);text-align:center;background:var(--accent-dim);border-radius:var(--radius-sm);white-space:nowrap;padding:7px 14px;font-size:23px;font-weight:700}@media (width<=600px){.clue{padding:4px 8px;font-size:14px}}.clue--top{grid-area:top}.clue--bottom{grid-area:bottom}.clue--left{writing-mode:vertical-rl;grid-area:left;transform:rotate(180deg)}.clue--right{writing-mode:vertical-rl;grid-area:right;transform:rotate(180deg)}.clue-input{background:var(--bg-surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--accent);font-family:var(--display);text-align:center;outline:none;width:110px;padding:8px 12px;font-size:17px;font-weight:700;transition:border-color .18s}.clue-input:focus{border-color:var(--accent);background:var(--bg-card)}.clue-input::placeholder{color:var(--text-muted);font-weight:400}.clue-input--top{grid-area:top;justify-self:stretch;width:100%}.clue-input--bottom{grid-area:bottom;justify-self:stretch;width:100%}.clue-input--left{grid-area:left;width:110px}.clue-input--right{grid-area:right;width:110px}.clover-grid{grid-area:grid;grid-template-columns:var(--slot-size,210px) var(--slot-size,210px);grid-template-rows:var(--slot-size,210px) var(--slot-size,210px);background:var(--bg-surface);border-radius:var(--radius-md);border:1px solid var(--border);gap:8px;padding:8px;display:grid}.clover-slot{border-radius:var(--radius-sm);width:var(--slot-size,210px);height:var(--slot-size,210px);justify-content:center;align-items:center;transition:background .15s,outline .15s;display:flex}.clover-slot--over{background:var(--accent-dim);outline:2px dashed var(--accent);outline-offset:-2px}.clover-slot--empty .clover-slot-placeholder{width:calc(var(--slot-size,210px) * .82);height:calc(var(--slot-size,210px) * .82);border:2px dashed var(--border);border-radius:var(--radius-md);background:var(--bg-card)}@media (width<=768px){.clover-slot--empty .clover-slot-placeholder{width:110px;height:110px}}.play-page,.create-page{background:var(--bg-secondary);--slot-size:min(calc((100dvh - 316px) / 2), calc(100vw / 3 - 198px), 320px);--tray-w:230px;--feedback-w:calc(100vw / 3);--header-h:64px;--footer-h:70px;flex-direction:column;height:100dvh;display:flex;overflow:hidden}@media (width<=768px){.play-page,.create-page{--slot-size:140px;--tray-w:100%;--feedback-w:100%;height:auto;overflow:auto}}.play-tray-drawer{left:0;top:var(--header-h);bottom:var(--footer-h);width:var(--tray-w);background:var(--bg-card);border-right:1px solid var(--border);z-index:40;flex-direction:column;align-items:center;padding:24px 0;display:flex;position:fixed;overflow:hidden}.tray-cards{flex-direction:column;flex:1;align-items:center;gap:8px;width:100%;padding:4px 0;display:flex;overflow:hidden}.card-tray-item{transform-origin:50%;margin:calc(var(--slot-size,210px) * -.2) 0;flex-shrink:0;transform:scale(.6)}.tray-cards:has(>.card-tray-item:nth-child(5)) .card-tray-item{margin:calc(var(--slot-size,210px) * -.27) 0;transform:scale(.46)}.play-main{min-height:0;margin-left:var(--tray-w);margin-right:var(--feedback-w);padding:20px 0 calc(var(--footer-h) + 20px);flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.play-grid-area{flex-direction:column;align-items:center;gap:8px;display:flex}.btn-reset{border-radius:var(--radius-md);background:var(--accent);color:#fff;width:auto;height:40px;font-size:15px;font-weight:600;font-family:var(--sans);cursor:pointer;z-index:5;border:none;justify-content:center;align-items:center;gap:8px;padding:0 16px;transition:all .18s;display:flex;position:absolute;top:16px;right:16px;box-shadow:0 2px 8px #00b89940}.btn-reset:hover:not(:disabled){background:#009e83;transform:translateY(-1px);box-shadow:0 4px 14px #00b89959}.btn-reset:disabled{opacity:.3;cursor:default;background:var(--bg-surface);color:var(--text-muted);box-shadow:none}.play-feedback-drawer{right:0;top:var(--header-h);bottom:var(--footer-h);width:var(--feedback-w);background:var(--bg-card);border-left:1px solid var(--border);z-index:40;flex-direction:column;justify-content:flex-start;gap:0;padding:24px 20px 20px;display:flex;position:fixed;overflow-y:auto}.play-history-panel--ghost{opacity:.45;pointer-events:none}.play-tab-ghost{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm) var(--radius-sm) 0 0;border-bottom:none;width:64px;height:32px;animation:1.8s ease-in-out infinite pulse}.play-feedback-row--ghost{gap:12px}.play-ghost-count{background:var(--bg-surface);border-radius:6px;width:32px;height:32px;animation:1.8s ease-in-out infinite pulse;display:inline-block}.play-ghost-label{background:var(--bg-surface);border-radius:4px;flex:1;height:13px;animation:1.8s ease-in-out infinite pulse;display:inline-block}.play-ghost-minigrid{background:var(--bg-surface);border-radius:var(--radius-md);width:120px;height:120px;animation:1.8s ease-in-out infinite pulse}.play-ghost-caption{color:var(--text-muted);text-align:center;margin-top:10px;font-size:12px}.play-history{flex-direction:column;gap:0;width:100%;display:flex}.play-history-tabs{gap:6px;margin-bottom:-1px;padding-left:2px;display:flex}.play-history-tab{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm) var(--radius-sm) 0 0;font-size:12px;font-weight:600;font-family:var(--sans);cursor:pointer;color:var(--text-secondary);border-bottom:none;padding:7px 16px;transition:all .15s}.play-history-tab:hover{color:var(--text-primary)}.play-history-tab--active{background:var(--bg-card);color:var(--accent);border-color:var(--border)}.play-history-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:0 var(--radius-md) var(--radius-md) var(--radius-md);box-shadow:var(--card-shadow);flex-direction:column;gap:18px;padding:22px 20px;display:flex}.play-feedback-rows{flex-direction:column;gap:18px;display:flex}.play-feedback-divider{background:var(--border);height:1px}.play-mini-grid-center{justify-content:center;display:flex}@media (width<=768px){.play-tray-drawer{border-right:none;border-bottom:1px solid var(--border);flex-direction:row;gap:12px;width:100%;padding:12px 16px;position:relative;top:auto;bottom:auto;overflow:auto hidden}.tray-cards{flex-direction:row;flex:none;overflow:auto hidden}.card-tray-item{margin:0 -24px!important;transform:scale(.65)!important}.tray-cards:has(>.card-tray-item:nth-child(5)) .card-tray-item{margin:0 -28px!important;transform:scale(.55)!important}.play-main{margin:0;padding:16px 16px 90px}.btn-reset{width:auto;margin-bottom:12px;position:static}.play-feedback-drawer{border-left:none;border-top:1px solid var(--border);justify-content:flex-start;width:100%;position:relative;top:auto;bottom:auto;right:auto}}.mini-clover-wrapper{grid-template:".top.""left grid right"1fr".bottom."/38px 1fr 38px;place-items:center;gap:6px;width:fit-content;margin:0 auto;display:grid}.mini-clue{font-family:var(--display);color:var(--accent);background:var(--accent-dim);white-space:nowrap;text-align:center;text-overflow:ellipsis;border-radius:4px;max-width:140px;padding:4px 7px;font-size:12px;font-weight:700;overflow:hidden}.mini-clue--top{grid-area:top}.mini-clue--bottom{grid-area:bottom}.mini-clue--left{writing-mode:vertical-rl;grid-area:left;max-width:none;max-height:100px;padding:5px 2px;transform:rotate(180deg)}.mini-clue--right{writing-mode:vertical-rl;grid-area:right;max-width:none;max-height:100px;padding:5px 2px}.mini-clover-grid{background:var(--bg-surface);border-radius:var(--radius-sm);border:1px solid var(--border);grid-area:grid;grid-template-rows:160px 160px;grid-template-columns:160px 160px;gap:6px;padding:6px;display:grid}.mini-slot{border-radius:6px;justify-content:center;align-items:center;display:flex}.mini-slot-empty{background:var(--bg-surface);border:1.5px dashed var(--border);border-radius:6px;width:160px;height:160px}.mini-card{border:2px solid;border-radius:11px;flex-shrink:0;grid-template:".top."26px"left.right"1fr".bottom."26px/26px 1fr 26px;place-items:center;width:160px;height:160px;transition:transform .25s cubic-bezier(.34,1.56,.64,1);display:grid;overflow:hidden}.mini-card-word{text-align:center;letter-spacing:.02em;text-transform:uppercase;text-overflow:ellipsis;font-size:11px;font-weight:800;overflow:hidden}.mini-card-word--top{grid-area:top}.mini-card-word--bottom{grid-area:bottom}.mini-card-word--right{grid-area:right}.mini-card-word--left{grid-area:left}.play-feedback-row{color:var(--text-secondary);align-items:center;gap:14px;font-size:14px;display:flex}.play-feedback-dot{border-radius:50%;flex-shrink:0;width:20px;height:20px}.play-feedback-count{font-family:var(--sans);min-width:36px;color:var(--text-primary);font-size:28px;font-weight:800}.feedback-info-icon{color:var(--text-muted);cursor:help;opacity:.6;margin-left:auto;font-size:12px;transition:opacity .2s}.feedback-info-icon:hover{opacity:1;color:var(--warning)}.play-feedback-dot--correct{background:var(--success)}.play-feedback-dot--rotation{background:var(--warning)}.play-feedback-dot--wrong{background:var(--error)}.play-loading{color:var(--text-secondary);flex:1;justify-content:center;align-items:center;display:flex}.play-footer{z-index:50;background:var(--bg-card);border-top:1px solid var(--border);justify-content:center;align-items:center;gap:12px;padding:12px 24px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 16px #0000000f}.play-footer-submit{flex:1;max-width:320px}.play-footer-hub{flex-shrink:0}.play-footer-hint{text-align:center;color:var(--text-muted);flex:1;font-size:14px}@media (width<=600px){.play-main{flex-direction:column;gap:12px}.play-right{flex-flow:wrap;gap:8px;width:100%;padding-top:0}.play-attempt-row{flex-direction:row;align-items:center;gap:6px}}.create-info-drawer{justify-content:flex-start;gap:0;padding:28px 20px 20px}.create-phase-panel{flex-direction:column;gap:20px;width:100%;display:flex}.create-timer-block{align-items:center;gap:14px;width:100%;display:flex}.create-step-header{flex-direction:column;gap:6px;display:flex}.create-step-badge{text-transform:uppercase;letter-spacing:.1em;color:var(--accent);background:var(--accent-dim);border-radius:4px;align-self:flex-start;padding:3px 8px;font-size:10px;font-weight:700}.create-step-title{font-family:var(--display);color:var(--text-primary);margin:0;font-size:16px;font-weight:700}.create-placement-status{flex-direction:column;gap:14px;display:flex}.create-status-hint{color:var(--text-secondary);margin:0;font-size:13px;line-height:1.5}.create-progress-dots{align-items:center;gap:8px;display:flex}.create-dot{background:var(--bg-surface);border:2px solid var(--border);border-radius:50%;width:14px;height:14px;transition:all .2s}.create-dot--filled{background:var(--accent);border-color:var(--accent)}.create-dot-label{color:var(--text-muted);margin-left:4px;font-size:13px;font-weight:600}.create-clues-check{flex-direction:column;gap:12px;display:flex}.create-clue-item{color:var(--text-muted);align-items:baseline;gap:10px;font-size:14px;transition:color .18s;display:flex}.create-clue-item--done{color:var(--text-primary)}.create-clue-item--conflict{color:#f0440a}.create-clue-icon{width:16px;color:var(--text-muted);flex-shrink:0;font-size:14px}.create-clue-item--done .create-clue-icon{color:var(--accent)}.create-clue-item--conflict .create-clue-icon{color:#f0440a}.create-clue-label{flex-shrink:0;font-weight:600}.create-clue-value{color:var(--accent);font-size:13px;font-style:italic}.create-clue-item--conflict .create-clue-value{color:#f0440a}.create-clue-conflict-hint{text-transform:uppercase;letter-spacing:.04em;color:#f0440a;margin-left:auto;font-size:11px;font-weight:600}.difficulty-modal-backdrop{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.difficulty-modal{background:var(--bg-card);border-radius:var(--radius-lg);width:90%;max-width:480px;padding:36px 28px;box-shadow:0 20px 60px #0000004d}.difficulty-modal-title{text-align:center;font-family:var(--display);margin-bottom:24px;font-size:22px;font-weight:700}.difficulty-options{flex-direction:column;gap:12px;display:flex}.difficulty-card{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-md);cursor:pointer;font-family:var(--display);text-align:center;outline:none;padding:20px;transition:all .18s}.difficulty-card:hover{border-color:var(--accent);background:var(--accent-dim);transform:translateY(-2px)}.difficulty-card--locked{opacity:.5;cursor:not-allowed}.difficulty-card--locked:hover{border-color:var(--border);background:var(--bg-card);transform:none}.difficulty-name{margin-bottom:8px;font-size:18px;font-weight:700}.difficulty-desc{color:var(--text-secondary);font-size:13px;line-height:1.4}.create-phase-label{font-family:var(--display);margin-bottom:16px;font-size:17px;font-weight:700}.create-timer{align-items:center;gap:14px;width:100%;max-width:380px;margin-bottom:14px;display:flex}.timer-bar-track{background:var(--bg-surface);border:1px solid var(--border);border-radius:4px;flex:1;height:8px;overflow:hidden}.timer-bar-fill{border-radius:4px;height:100%}.timer-value{font-family:var(--sans);text-align:right;min-width:48px;font-size:22px;font-weight:700}.create-expired{border-radius:var(--radius-md);color:var(--text-primary);text-align:center;background:#ff6b6b0d;border:1px solid #ff6b6b33;flex-direction:column;align-items:center;gap:12px;margin-bottom:14px;padding:24px;display:flex}.create-expired-icon{font-size:36px;line-height:1}.create-expired-title{font-family:var(--display);color:var(--text-primary);margin:0;font-size:18px;font-weight:800}.create-expired-text{color:var(--text-secondary);margin:0;font-size:14px}.create-expired-actions{gap:10px;margin-top:4px;display:flex}.create-confirm{min-width:220px;margin-top:20px}.tour-backdrop{z-index:1500;background:#0000008c;position:fixed;inset:0}.tour-card{background:var(--bg-card);border-radius:var(--radius-xl);z-index:1501;flex-direction:column;gap:12px;width:300px;padding:24px;display:flex;position:fixed;box-shadow:0 20px 60px #0000004d}.tour-card--center{top:50%;left:50%;transform:translate(-50%,-50%)}.tour-card--center-right{top:50%;right:16px;transform:translateY(-50%)}.tour-card--center-right:before{content:"";border:11px solid #0000;border-right:11px solid var(--bg-card);filter:drop-shadow(-3px 0 3px #0000001a);border-left:0;position:absolute;top:50%;left:-11px;transform:translateY(-50%)}.tour-card--top-center{top:80px;left:50%;transform:translate(-50%)}.tour-card--top-center:after{content:"";border:11px solid #0000;border-top:11px solid var(--bg-card);filter:drop-shadow(0 3px 3px #0000001a);border-bottom:0;position:absolute;bottom:-11px;left:50%;transform:translate(-50%)}.tour-card--bottom-center{bottom:80px;left:50%;transform:translate(-50%)}.tour-card--bottom-center:before{content:"";border:11px solid #0000;border-bottom:11px solid var(--bg-card);border-top:0;position:absolute;top:-11px;left:50%;transform:translate(-50%)}.tour-card--tray-right{left:calc(var(--tray-w,230px) + 16px);top:50%;transform:translateY(-50%)}.tour-card--tray-right:before{content:"";border:11px solid #0000;border-right:11px solid var(--bg-card);filter:drop-shadow(-3px 0 3px #0000001a);border-left:0;position:absolute;top:50%;left:-11px;transform:translateY(-50%)}.tour-card--footer-center{bottom:80px;left:50%;transform:translate(-50%)}.tour-card--footer-center:after{content:"";border:11px solid #0000;border-top:11px solid var(--bg-card);filter:drop-shadow(0 3px 3px #0000001a);border-bottom:0;position:absolute;bottom:-11px;left:50%;transform:translate(-50%)}.tour-card--center-left{left:calc(var(--tray-w,230px) + 16px);top:50%;transform:translateY(-50%)}.tour-card--center-left:before{content:"";border:11px solid #0000;border-left:11px solid var(--bg-card);border-right:0;position:absolute;top:50%;right:-11px;transform:translateY(-50%)}.tour-zone{text-transform:uppercase;letter-spacing:.06em;color:var(--accent);background:var(--accent-dim);border:1px solid var(--accent-border);border-radius:var(--radius-sm);align-self:flex-start;padding:4px 10px;font-size:11px;font-weight:700}.tour-title{margin:0;font-size:16px;font-weight:700}.tour-desc{color:var(--text-secondary);margin:0;font-size:13px;line-height:1.55}.tour-footer{justify-content:space-between;align-items:center;gap:12px;margin-top:4px;display:flex}.tour-dots{align-items:center;gap:5px;display:flex}.tour-dot{background:var(--border);border-radius:50%;width:6px;height:6px;transition:all .2s}.tour-dot--active{background:var(--accent);border-radius:3px;width:18px}.tour-dot--done{background:var(--accent);opacity:.4}.tour-actions{align-items:center;gap:8px;display:flex}.tour-skip{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:13px}.tour-skip:hover{color:var(--text-secondary)}.tour-next{padding:9px 18px;font-size:14px}@media (width<=640px){.tour-card--center-right,.tour-card--center-left,.tour-card--top-center,.tour-card--bottom-center,.tour-card--tray-right,.tour-card--footer-center{width:calc(100vw - 48px);inset:auto auto 24px 50%;transform:translate(-50%)}.tour-card--center-right:before,.tour-card--center-left:before,.tour-card--top-center:after,.tour-card--bottom-center:before,.tour-card--tray-right:before,.tour-card--footer-center:after{display:none}}.tutorial-backdrop{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.tutorial-modal{background:var(--bg-card);border-radius:var(--radius-lg);flex-direction:column;width:90%;max-width:520px;max-height:80dvh;display:flex;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.tutorial-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:24px 24px 12px;display:flex}.tutorial-header h2{margin:0;font-size:20px}.tutorial-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:28px;height:28px;font-size:20px;transition:color .18s;display:flex}.tutorial-close:hover{color:var(--text-primary)}.tutorial-tabs{border-bottom:1px solid var(--border);flex-shrink:0;gap:0;padding:0 24px;display:flex}.tutorial-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:3px solid #0000;padding:14px 16px;font-size:14px;font-weight:600;transition:all .18s}.tutorial-tab:hover{color:var(--text-primary)}.tutorial-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.tutorial-content{flex:1;padding:20px 24px;overflow-y:auto}.tutorial-section h3{margin-bottom:16px;font-size:17px}.tutorial-steps{flex-direction:column;gap:16px;padding-left:24px;list-style:decimal;display:flex}.tutorial-steps li{padding-left:8px}.tutorial-steps strong{color:var(--text-primary);font-weight:600}.tutorial-steps p{color:var(--text-secondary);margin:6px 0 0;font-size:14px;line-height:1.5}.tutorial-close-btn{flex-shrink:0;width:calc(100% - 48px);margin:12px 24px 24px;padding:14px 24px}.result-page{background:var(--bg-secondary);flex-direction:column;height:100dvh;display:flex;overflow:hidden}.result-main{box-sizing:border-box;flex:1;grid-template-columns:1fr 1fr 1.3fr;align-items:start;gap:24px;width:100%;max-width:1280px;margin:0 auto;padding:28px 32px 24px;display:grid;overflow-y:auto}.result-col{flex-direction:column;gap:20px;display:flex}.result-section-title{font-size:17px;font-weight:700;font-family:var(--display);color:var(--text-primary)}.result-empty-state{color:var(--text-muted);text-align:center;padding:20px 0;font-size:13px}.result-footer{background:var(--bg-card);border-top:1px solid var(--border);flex-shrink:0;justify-content:center;padding:14px 32px;display:flex}.result-footer-cta{min-width:200px}@media (width<=1024px){.result-main{grid-template-columns:1fr 1fr}}@media (width<=680px){.result-main{grid-template-columns:1fr;padding:20px 16px}.result-footer{padding:12px 16px}}.result-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);text-align:center;box-shadow:var(--card-shadow);padding:36px 28px}.result-icon{margin-bottom:10px;font-size:44px}.result-title{margin-bottom:18px;font-size:26px}.result-meta{color:var(--text-secondary);margin-bottom:16px;font-size:14px}.result-xp{color:var(--text-secondary);margin-top:8px;font-size:14px}.result-xp-block{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);text-align:left;margin-top:20px;padding:18px}.result-xp-title{color:var(--text-primary);margin-bottom:12px;font-size:13px;font-weight:700}.result-xp-row{color:var(--text-secondary);justify-content:space-between;align-items:center;padding:5px 0;font-size:14px;display:flex}.result-xp-value{color:var(--accent);font-weight:700}.result-xp-divider{background:var(--border);height:1px;margin:10px 0}.result-xp-total{color:var(--text-primary);justify-content:space-between;align-items:center;font-size:15px;font-weight:700;display:flex}.result-xp-total-value{color:var(--accent);font-size:22px;font-weight:700}.result-leaderboard h2{margin-bottom:10px;font-size:17px}.leaderboard-list{flex-direction:column;gap:8px;list-style:none;display:flex}.leaderboard-row{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--card-shadow);align-items:center;gap:12px;padding:9px 14px;display:flex}.leaderboard-rank{color:var(--text-muted);width:26px;font-weight:700}.leaderboard-name{flex:1}.leaderboard-score{color:var(--accent);font-weight:700}.leaderboard-row--me{border-color:var(--accent-border);background:var(--accent-dim)}.leaderboard-row--me .leaderboard-rank{color:var(--accent)}.leaderboard-separator{text-align:center;color:var(--text-muted);letter-spacing:2px;padding:4px 0;font-size:16px}.result-comment{flex-direction:column;gap:8px;display:flex}.comment-input{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);font-family:var(--sans);resize:vertical;outline:none;padding:11px 14px;font-size:14px;transition:border-color .18s}.comment-input:focus{border-color:var(--accent-border)}.result-comment-sent{color:var(--accent);text-align:center;font-size:14px}.result-comments-feed h2{margin-bottom:12px;font-size:17px}.comment-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--card-shadow);padding:12px 16px}.comment-pseudo{color:var(--accent);margin-bottom:4px;font-size:12px;font-weight:700;display:block}.comment-text{color:var(--text-primary);margin:0;font-size:14px;line-height:1.45}.result-solution{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:24px}.result-solution h2{margin-bottom:12px;font-size:18px}.result-sol-tabs{gap:6px;margin-bottom:-1px;padding-left:2px;display:flex}.result-sol-tab{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm) var(--radius-sm) 0 0;font-size:12px;font-weight:600;font-family:var(--sans);cursor:pointer;color:var(--text-secondary);border-bottom:none;padding:6px 14px;transition:all .15s}.result-sol-tab:hover{color:var(--text-primary)}.result-sol-tab--active{background:var(--bg-card);color:var(--accent);border-color:var(--border)}.result-sol-body{background:var(--bg-card);border:1px solid var(--border);border-radius:0 var(--radius-md) var(--radius-md) var(--radius-md);justify-content:center;padding:24px;display:flex}.result-attempt-detail{flex-direction:column;gap:12px;width:100%;display:flex}.result-feedback-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--card-shadow);overflow:hidden}.result-feedback-tabs{flex-wrap:wrap;gap:6px;margin-bottom:-1px;padding:16px 16px 0;display:flex}.result-feedback-tab{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm) var(--radius-sm) 0 0;font-size:12px;font-weight:600;font-family:var(--sans);cursor:pointer;color:var(--text-secondary);border-bottom:none;padding:7px 16px;transition:all .15s}.result-feedback-tab:hover{color:var(--text-primary)}.result-feedback-tab--active{background:var(--bg-secondary);color:var(--accent);border-color:var(--border)}.result-feedback-tab--solution.result-feedback-tab--active{color:var(--accent)}.result-feedback-body{background:var(--bg-secondary);border-top:1px solid var(--border);border-radius:0 var(--radius-md) var(--radius-md) var(--radius-md);flex-direction:column;gap:16px;margin:0 16px 16px;padding:20px;display:flex}.result-feedback-dots{flex-direction:column;gap:16px;display:flex}.result-feedback-divider{background:var(--border);height:1px}.result-feedback-grid-wrap{justify-content:center;display:flex}.result-feedback-loading{color:var(--text-muted);text-align:center;padding:20px}.result-feedback-grid-wrap .mini-clover-grid{grid-template-rows:140px 140px;grid-template-columns:140px 140px;gap:8px;padding:8px}.result-feedback-grid-wrap .mini-slot-empty{width:124px;height:124px}.result-feedback-grid-wrap .mini-card{border-width:1.5px;border-radius:11px;grid-template-rows:26px 1fr 26px;grid-template-columns:26px 1fr 26px;width:124px;height:124px}.result-feedback-grid-wrap .mini-card-word{font-size:10px}.result-feedback-grid-wrap .mini-clue{padding:4px 7px;font-size:11px}.result-feedback-grid-wrap .mini-clue--left,.result-feedback-grid-wrap .mini-clue--right{padding:7px 4px}.result-feedback-grid-wrap .mini-clover-wrapper{grid-template-columns:38px 1fr 38px}.result-col-right .mini-clover-grid{grid-template-rows:160px 160px;grid-template-columns:160px 160px;gap:8px;padding:8px}.result-col-right .mini-slot-empty{width:140px;height:140px}.result-col-right .mini-card{border-width:1.5px;border-radius:12px;grid-template-rows:28px 1fr 28px;grid-template-columns:28px 1fr 28px;width:140px;height:140px}.result-col-right .mini-card-word{font-size:11px}.result-col-right .mini-clue{padding:4px 8px;font-size:12px}.result-col-right .mini-clue--left,.result-col-right .mini-clue--right{padding:8px 4px}.result-col-right .mini-clover-wrapper{grid-template-columns:40px 1fr 40px}.replay-modal-backdrop{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.replay-modal{background:var(--bg-card);border-radius:var(--radius-xl);width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.replay-modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.replay-modal-title{margin:0;font-size:18px;font-weight:600}.replay-modal-close{cursor:pointer;color:var(--text-muted);background:0 0;border:none;font-size:20px}.replay-modal-content{flex-direction:column;gap:20px;padding:24px;display:flex}.replay-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.replay-position{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px}.replay-label{color:var(--text-muted);text-transform:uppercase;margin-bottom:8px;font-size:11px;font-weight:600}.replay-word{background:var(--accent-dim);color:var(--accent);text-align:center;border-radius:4px;min-height:20px;margin-bottom:6px;padding:8px;font-size:14px;font-weight:700}.replay-word--wrong{background:var(--coral-dim);color:var(--coral)}.replay-word--empty{opacity:.5}.replay-correct{color:var(--text-secondary);text-align:center;font-size:12px}.replay-attempts h3{margin:0 0 8px;font-size:13px;font-weight:600}.replay-attempt-list{flex-wrap:wrap;gap:6px;display:flex}.replay-attempt-btn{background:var(--bg-surface);border:1px solid var(--border);cursor:pointer;border-radius:4px;padding:6px 12px;font-size:12px;transition:all .18s}.replay-attempt-btn:hover{border-color:var(--accent)}.replay-attempt-btn--active{background:var(--accent);color:#fff;border-color:var(--accent)}.replay-feedback{flex-direction:column;gap:8px;display:flex}.replay-feedback-row{background:var(--bg-surface);border-radius:4px;justify-content:space-between;padding:8px;font-size:13px;display:flex}.replay-feedback-row strong{color:var(--accent)}.replay-modal-close-btn{width:100%;margin-top:12px}.profile-page{background:var(--bg-secondary);min-height:100dvh}.profile-main{flex-direction:column;gap:24px;width:100%;max-width:600px;margin:0 auto;padding:28px 20px;display:flex}.profile-header-block{align-items:center;gap:16px;display:flex}.profile-avatar{background:var(--accent-dim);border:2px solid var(--accent-border);width:58px;height:58px;color:var(--accent);font-family:var(--display);border-radius:50%;justify-content:center;align-items:center;font-size:24px;font-weight:800;display:flex}.profile-name{margin-bottom:2px;font-size:22px}.profile-streak{color:var(--text-secondary);gap:20px;font-size:14px;display:flex}.profile-stats{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);text-align:center;box-shadow:var(--card-shadow);flex-direction:column;gap:3px;padding:14px 10px;display:flex}.stat-value{font-family:var(--sans);color:var(--accent);font-variant-numeric:tabular-nums;letter-spacing:-.5px;font-size:32px;font-weight:700;line-height:1.2}.stat-label{color:var(--text-muted);font-size:11px}.profile-stats-block{flex-direction:column;gap:10px;display:flex}.profile-stats-title{margin:0;font-size:17px}.profile-section h2{margin-bottom:10px;font-size:17px}.history-list{flex-direction:column;gap:7px;list-style:none;display:flex}.history-item{justify-content:space-between;align-items:center;display:flex}.history-item--rich{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--card-shadow);align-items:flex-start;gap:12px;padding:12px 16px}.history-item-main{flex-direction:column;flex:1;gap:5px;min-width:0;display:flex}.history-item-top{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.history-item-meta{color:var(--text-secondary);flex-wrap:wrap;align-items:center;gap:10px;font-size:12px;display:flex}.history-item-meta span+span:before{content:"·";margin-right:10px}.history-item-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:6px;display:flex}.history-clue{color:var(--text-primary);font-size:14px;font-weight:600}.history-diff-badge{text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:700}.history-date{color:var(--text-muted);font-size:11px}.history-result{font-size:13px;font-weight:700}.history-result.success{color:var(--success)}.history-result.fail{color:var(--error)}.history-replay-btn{color:var(--accent);background:var(--accent-dim);border:1px solid var(--accent-border);border-radius:var(--radius-sm);cursor:pointer;padding:4px 10px;font-size:12px;transition:all .18s}.history-replay-btn:hover{background:var(--accent);color:#fff}.history-link{color:var(--accent);font-size:13px;font-weight:600;text-decoration:none}.history-link:hover{text-decoration:underline}.profile-empty{color:var(--text-muted);font-size:14px}.profile-logout{align-self:flex-start}.profile-xp-bar{flex-direction:column;gap:6px;display:flex}.profile-xp-info{justify-content:space-between;font-size:12px;display:flex}.profile-xp-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;font-weight:600}.profile-xp-amount{color:var(--accent);font-weight:600}.profile-xp-track{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:4px;height:6px;overflow:hidden}.profile-xp-fill{background:var(--accent);border-radius:4px;height:100%}.profile-xp-next{color:var(--text-muted);font-size:11px}.skin-grid{grid-template-columns:repeat(5,1fr);gap:10px;display:grid}.skin-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-md);cursor:pointer;box-shadow:var(--card-shadow);flex-direction:column;align-items:center;gap:8px;padding:12px 8px;transition:all .18s;display:flex;position:relative}.skin-card:hover{border-color:var(--accent)}.skin-card--locked{opacity:.6;cursor:default}.skin-card--locked:hover{border-color:var(--border)}.skin-card--active{border-color:var(--accent);background:var(--accent-dim);border-width:2px}.skin-creature{justify-content:center;align-items:center;height:48px;display:flex;position:relative}.skin-lock{font-size:18px;position:absolute}.skin-info{text-align:center;width:100%}.skin-name{color:var(--text-primary);font-size:12px;font-weight:600}.skin-badge{color:var(--accent);text-transform:uppercase;letter-spacing:.03em;font-size:10px;font-weight:700}@media (width<=600px){.skin-grid{grid-template-columns:repeat(4,1fr);gap:8px}.skin-card{gap:6px;padding:10px 6px}.skin-creature{height:36px}.skin-name{font-size:11px}.skin-badge{font-size:9px}}@media (width<=480px){.skin-grid{grid-template-columns:repeat(3,1fr)}}.dashboard-page{background:var(--bg-secondary);min-height:100dvh}.dashboard-main{width:100%;max-width:640px;margin:0 auto;padding:28px 20px}.dashboard-title{margin-bottom:20px;font-size:20px}.dashboard-stats{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:28px;display:grid}.dashboard-section{margin-bottom:28px}.dashboard-section h2{margin-bottom:14px;font-size:17px}.dashboard-solution-wrap{justify-content:center;display:flex}.dashboard-solution-card-bg{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--card-shadow);padding:24px;display:inline-flex}.dashboard-solution-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px;display:grid}.dashboard-solution-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);text-align:center;box-shadow:var(--card-shadow);padding:14px}.dashboard-solution-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:11px;font-weight:600}.dashboard-solution-word{color:var(--accent);font-size:18px;font-weight:700}.dist-bars{flex-direction:column;gap:9px;display:flex}.dist-bar-item{align-items:center;gap:10px;font-size:13px;display:flex}.dist-bar-label{width:68px;color:var(--text-secondary)}.dist-bar-track{background:var(--bg-surface);border:1px solid var(--border);border-radius:5px;flex:1;height:9px;overflow:hidden}.dist-bar-fill{background:var(--accent);border-radius:5px;height:100%}.dist-bar-fill--fail{background:var(--error)}.dist-bar-count{text-align:right;width:22px;color:var(--text-muted);font-size:12px}.comments-list{flex-direction:column;gap:8px;list-style:none;display:flex}.comment-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--card-shadow);flex-direction:column;gap:3px;padding:11px 14px;display:flex}.comment-author{color:var(--accent);text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:700}.comment-text{font-size:13px}.players-list{flex-direction:column;gap:7px;list-style:none;display:flex}.player-row{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--card-shadow);align-items:center;gap:14px;padding:9px 14px;font-size:13px;display:flex}.player-row>:first-child{flex:1}.text-success{color:var(--success);font-weight:600}.text-error{color:var(--error);font-weight:600}.text-muted{color:var(--text-muted)}.dashboard-loading{min-height:100dvh;color:var(--text-secondary);justify-content:center;align-items:center;display:flex}.daily-challenge-layout{grid-template-columns:300px 1fr;gap:20px;display:grid}.daily-challenge-card{min-width:0}.daily-challenge-side{flex-direction:column;gap:16px;height:100%;display:flex}.daily-lb{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--card-shadow);flex-direction:column;flex:1;padding:16px;display:flex}.daily-lb-header{border-bottom:1px solid var(--border);align-items:center;gap:8px;margin-bottom:16px;padding-bottom:12px;display:flex}.daily-lb-trophy{color:#f5a623;flex-shrink:0;width:20px;height:20px}.daily-lb-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:13px;font-weight:700}.daily-lb-empty{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:10px;padding:24px 16px;display:flex}.daily-lb-empty-icon{background:var(--bg-surface);border:1px solid var(--border);border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.daily-lb-empty-icon svg{width:24px;height:24px;color:var(--text-muted)}.daily-lb-empty-text{color:var(--text-muted);margin:0;font-size:13px;line-height:1.5}.daily-lb-empty-cta{color:var(--accent);margin:0;font-size:13px;font-weight:700}.daily-lb-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.daily-lb-row{border-radius:var(--radius-sm);background:var(--bg-surface);align-items:center;gap:10px;padding:8px 10px;font-size:13px;display:flex}.daily-lb-row--me{background:var(--accent-dim);border:1px solid var(--accent-border)}.daily-lb-rank{text-align:center;flex-shrink:0;width:28px;font-size:18px}.daily-lb-name{color:var(--text-primary);flex:1;font-weight:500}.daily-lb-score{color:var(--accent);white-space:nowrap;font-size:12px;font-weight:700}.daily-lb-separator{text-align:center;color:var(--text-muted);padding:4px 0;font-size:12px}.daily-archives-link{color:var(--accent);padding:8px 0;font-size:13px;font-weight:600;text-decoration:none;display:inline-block}.daily-archives-link:hover{text-decoration:underline}.daily-archive-item{flex-direction:column;gap:6px;display:flex}.daily-archive-label{color:var(--text-muted);text-transform:capitalize;font-size:12px;font-weight:600}@media (width<=640px){.daily-challenge-layout{grid-template-columns:1fr}}.admin-page{background:var(--bg-secondary);min-height:100dvh}.admin-main{grid-template-columns:280px 1fr;align-items:start;gap:28px;max-width:1100px;margin:0 auto;padding:28px 20px;display:grid}.admin-schedule{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--card-shadow);overflow:hidden}.admin-schedule-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);margin:0;padding:14px 16px;font-size:14px;font-weight:700}.admin-schedule-list{margin:0;padding:0;list-style:none}.admin-schedule-row{text-align:left;border:none;border-bottom:1px solid var(--border);cursor:pointer;background:0 0;flex-direction:column;gap:3px;width:100%;padding:12px 16px;transition:background .15s;display:flex}.admin-schedule-row:last-child{border-bottom:none}.admin-schedule-row:hover{background:var(--bg-surface)}.admin-schedule-row--active{background:var(--accent-dim)}.admin-schedule-date{color:var(--text-primary);text-transform:capitalize;font-size:13px;font-weight:600}.admin-schedule-status{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:6px;font-size:12px;display:flex;overflow:hidden}.admin-schedule-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.admin-schedule-dot--ok{background:var(--success)}.admin-schedule-dot--empty{background:var(--border)}.admin-editor{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--card-shadow);flex-direction:column;gap:20px;padding:24px;display:flex}.admin-editor-empty{color:var(--text-muted);text-align:center;padding:40px 0;font-size:14px}.admin-editor-header{justify-content:space-between;align-items:center;display:flex}.admin-editor-title{margin:0;font-size:17px}.admin-delete-btn{border:1px solid var(--error);color:var(--error);border-radius:var(--radius-sm);cursor:pointer;background:0 0;padding:6px 14px;font-size:12px;transition:all .15s}.admin-delete-btn:hover{background:var(--error);color:#fff}.admin-editor-body{justify-content:center;display:flex}.admin-editor-actions{flex-wrap:wrap;justify-content:flex-end;gap:12px;display:flex}.admin-refresh-btn{flex-shrink:0}.admin-save-btn{min-width:140px}.admin-hint{color:var(--text-muted);text-align:right;margin:0;font-size:12px}.admin-clover-slot{position:relative}.admin-slot-refresh{background:var(--bg-surface);border:1px solid var(--border);width:26px;height:26px;color:var(--text-secondary);cursor:pointer;z-index:10;border-radius:50%;justify-content:center;align-items:center;font-size:13px;transition:all .15s;display:flex;position:absolute;bottom:4px;right:4px}.admin-slot-refresh:hover:not(:disabled){background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.admin-slot-refresh:disabled{opacity:.5;cursor:default}.admin-play-btn{text-decoration:none}@media (width<=768px){.admin-main{grid-template-columns:1fr}}
