*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#333;background:#fff8f0;min-height:100vh;font-family:PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif}#root{flex-direction:column;min-height:100vh;display:flex}.loading-screen,.error-screen{color:#666;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;font-size:1.1rem;display:flex}.loading-spinner{border:4px solid #f3c677;border-top-color:#f97316;border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.error-icon{font-size:2.5rem}.error-detail{color:#999;text-align:center;max-width:300px;font-size:.9rem}.btn{cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;padding:10px 20px;font-family:inherit;font-size:1rem;font-weight:600;transition:transform .1s,box-shadow .1s;display:inline-flex}.btn:active{transform:scale(.96)}.btn-primary{color:#fff;background:#f97316;box-shadow:0 3px 8px #f9731659}.btn-primary:hover{background:#ea6c0f}.btn-upload{color:#fff;background:#f97316;box-shadow:0 2px 8px #f9731666}.btn-upload:hover{background:#ea6c0f}.btn-wordbook-entry{color:#374151;cursor:pointer;background:#fff;border:1.5px solid #e5e7eb;border-radius:16px;justify-content:space-between;align-items:center;width:100%;padding:14px 18px;font-family:inherit;font-size:.95rem;font-weight:600;display:flex;box-shadow:0 2px 6px #0000000f}.btn-wordbook-entry:hover{background:#f9fafb}.btn-wordbook-entry:after{content:"›";color:#9ca3af;font-size:1.2rem;line-height:1}.btn-hint{color:#92400e;box-shadow:none;background:#fef3c7;border:1.5px solid #fde68a}.btn-hint:hover{background:#fde68a}.btn-restart{color:#374151;background:#fff;border:1.5px solid #e5e7eb;box-shadow:0 2px 6px #0000000f}.btn-restart:hover{background:#f9fafb}.btn-outline{color:#92400e;box-shadow:none;background:#fef3c7;border:1.5px solid #fde68a}.btn-outline:hover{background:#fde68a}.btn-sm{border-radius:8px;padding:6px 14px;font-size:.85rem}.btn-danger{color:#dc2626;box-shadow:none;background:#fee2e2}.btn-danger:hover{background:#fecaca}.level-select-screen{flex-direction:column;flex:1;width:100%;max-width:500px;margin:0 auto;padding:20px 16px 32px;display:flex}.level-select-footer{text-align:center;color:#d1d5db;letter-spacing:.04em;margin-top:auto;padding-top:24px;font-size:.75rem}.level-select-header{text-align:center;margin-bottom:20px}.game-title{color:#f97316;letter-spacing:.05em;font-size:1.8rem;font-weight:700}.game-subtitle{color:#9ca3af;margin-top:4px;font-size:.95rem}.tabs{background:#f3f4f6;border-radius:12px;gap:2px;margin-bottom:16px;padding:4px;display:flex}.tab-btn{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:9px;flex:1;padding:8px 4px;font-family:inherit;font-size:.85rem;font-weight:500;transition:all .15s}.tab-active{color:#f97316;background:#fff;font-weight:700;box-shadow:0 1px 4px #0000001a}.tab-btn-custom{color:#f97316;background:linear-gradient(135deg,#fff7ed,#fef3c7);border:1.5px solid #fed7aa;font-weight:600}.tab-btn-custom.tab-active{color:#fff;background:linear-gradient(135deg,#f97316,#f59e0b);border-color:#0000;box-shadow:0 2px 8px #f9731666}.tab-content{flex:1}.level-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.level-card{cursor:pointer;background:#fff;border:2px solid #0000;border-radius:16px;padding:16px;transition:transform .15s,box-shadow .15s;position:relative;box-shadow:0 2px 8px #00000014}.level-card:hover:not(.level-locked){border-color:#fed7aa;transform:translateY(-2px);box-shadow:0 6px 16px #0000001f}.level-locked{opacity:.5;cursor:not-allowed}.level-completed{border-color:#86efac}.level-card-top{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.level-number{color:#9ca3af;font-size:.85rem}.level-badge{font-size:1rem}.level-card-title{color:#1f2937;font-size:1.1rem;font-weight:700}.level-card-sub{color:#9ca3af;margin-top:4px;font-size:.8rem}.custom-tab{flex-direction:column;gap:12px;display:flex}.upload-zone{text-align:center;cursor:pointer;background:#fffbeb;border:2px dashed #fbbf24;border-radius:16px;padding:32px 16px;transition:background .15s,border-color .15s}.upload-zone-over,.upload-zone:hover{background:#fef3c7;border-color:#f97316}.upload-icon{margin-bottom:8px;font-size:2.5rem}.upload-text{color:#92400e;font-size:1.1rem;font-weight:600}.upload-sub{color:#b45309;margin-top:4px;font-size:.85rem}.upload-example{text-align:left;color:#6b7280;margin-top:16px;font-size:.82rem;display:inline-block}.upload-example code{white-space:pre;background:#f9fafb;border-radius:8px;margin-top:4px;padding:8px 12px;display:block}.upload-btn-small{align-self:flex-start}.input-panel{background:#fffbeb;border:2px dashed #fbbf24;border-radius:16px;flex-direction:column;gap:10px;padding:16px;display:flex}.input-mode-tabs{gap:6px;display:flex}.input-mode-btn{color:#6b7280;cursor:pointer;background:#fff;border:2px solid #e5e7eb;border-radius:10px;flex:1;padding:8px 12px;font-family:inherit;font-size:.88rem;font-weight:500;transition:all .15s}.input-mode-btn.active{color:#f97316;background:#fff7ed;border-color:#f97316;font-weight:700}.upload-zone{border-radius:12px;padding:24px 16px}.paste-panel{flex-direction:column;gap:8px;display:flex}.paste-title-input{color:#1f2937;background:#fff;border:2px solid #e5e7eb;border-radius:10px;outline:none;width:100%;padding:9px 12px;font-family:inherit;font-size:.95rem;transition:border-color .15s}.paste-title-input:focus{border-color:#f97316}.paste-textarea{color:#1f2937;resize:vertical;box-sizing:border-box;background:#fff;border:2px solid #e5e7eb;border-radius:10px;outline:none;width:100%;padding:10px 12px;font-family:PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;font-size:1rem;line-height:1.6;transition:border-color .15s}.paste-textarea:focus{border-color:#f97316}.paste-error{color:#dc2626;background:#fef2f2;border-radius:8px;padding:8px 10px;font-size:.85rem}.custom-level-list{flex-direction:column;gap:10px;display:flex}.custom-level-card{background:#fff;border-radius:14px;padding:14px 16px;box-shadow:0 2px 8px #00000012}.custom-level-card-top{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.custom-level-title{color:#1f2937;font-size:1rem;font-weight:600}.custom-level-meta{color:#9ca3af;font-size:.82rem}.custom-play-btn{width:100%;margin-top:10px}.preview-warnings{margin-top:8px}.warning-text{color:#d97706;font-size:.82rem}.game-screen{flex-direction:column;flex:1;gap:12px;width:100%;max-width:500px;margin:0 auto;padding:12px 12px 24px;display:flex}.game-header{background:#fff;border-radius:16px;padding:12px 16px;box-shadow:0 2px 8px #00000012}.game-header-top{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.game-header-info{justify-content:space-between;align-items:center;display:flex}.level-label{color:#374151;font-size:.9rem;font-weight:600}.progress-label{color:#f97316;font-size:.85rem;font-weight:600}.game-board{background:#fef3c7;border-radius:20px;grid-template-columns:repeat(6,1fr);gap:6px;padding:10px;display:grid;box-shadow:0 4px 16px #00000014}.cell{aspect-ratio:1;cursor:pointer;-webkit-user-select:none;user-select:none;background:#fff;border:2px solid #0000;border-radius:10px;justify-content:center;align-items:center;transition:transform .12s,border-color .12s,background .12s;display:flex;box-shadow:0 2px 4px #00000014}.cell:hover{background:#fffbeb;transform:scale(1.05)}.cell-char{color:#1f2937;font-size:clamp(18px,5vw,28px);font-weight:700;line-height:1}.cell-empty{box-shadow:none;cursor:default;background:0 0;border:none}.cell-empty:hover{transform:none}.cell-selected{background:#fff7ed;border-color:#f97316;box-shadow:0 0 0 3px #f9731633}.cell-selected:hover{transform:scale(1.05)}.cell-hinted{background:#f0fdf4;border-color:#22c55e;animation:.6s ease-in-out infinite alternate hint-pulse}@keyframes hint-pulse{0%{box-shadow:0 0 0 2px #22c55e4d}to{box-shadow:0 0 0 6px #22c55e26}}.cell-eliminating{animation:.3s ease-out forwards eliminate}@keyframes eliminate{0%{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.15)}to{opacity:0;transform:scale(0)}}.cell-shaking{animation:.5s ease-in-out shake}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-5px)}40%{transform:translate(5px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.feedback-toast{color:#fff;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#1f2937d9;border-radius:24px;padding:10px 24px;font-size:.95rem;font-weight:500;animation:.2s toast-in;position:fixed;bottom:100px;left:50%;transform:translate(-50%)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%)translateY(8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.milestone-toast{color:#fff;text-align:center;background:linear-gradient(135deg,#f97316,#fb923c);border-radius:14px;margin:0 16px 10px;padding:10px 20px;font-size:1rem;font-weight:700;animation:2s forwards milestone-in-out;box-shadow:0 4px 16px #f9731659}@keyframes milestone-in-out{0%{opacity:0;transform:translateY(-6px)scale(.96)}12%{opacity:1;transform:translateY(0)scale(1)}75%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-4px)scale(.97)}}.game-controls{gap:8px;display:flex}.game-controls .btn{border-radius:16px;flex:1;padding:14px 8px;font-size:.95rem}.wordbook-screen{flex-direction:column;flex:1;gap:16px;width:100%;max-width:500px;margin:0 auto;padding:16px 16px 40px;display:flex}.wordbook-topbar{justify-content:space-between;align-items:center;display:flex}.wordbook-back-btn{color:#f97316;cursor:pointer;background:0 0;border:none;padding:6px 0;font-size:.95rem;font-weight:600}.wordbook-back-btn:hover{opacity:.75}.wordbook-topbar-title{color:#1f2937;font-size:1rem;font-weight:700}.wordbook-topbar-spacer{width:60px}.wordbook-hero{background:linear-gradient(135deg,#f97316,#fb923c);border-radius:18px;align-items:baseline;gap:8px;padding:20px 24px;display:flex;box-shadow:0 4px 16px #f973164d}.wordbook-hero-num{color:#fff;font-size:3rem;font-weight:900;line-height:1}.wordbook-hero-label{color:#ffffffe0;font-size:1rem;font-weight:600}.wordbook-sections{flex-direction:column;gap:12px;display:flex}.wordbook-section{background:#fff;border:1.5px solid #fed7aa;border-radius:16px;padding:14px 16px}.wordbook-section-locked{background:#f9fafb;border-color:#e5e7eb}.wordbook-section-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.wordbook-section-title{color:#92400e;font-size:.95rem;font-weight:700}.wordbook-section-locked .wordbook-section-title{color:#9ca3af}.wordbook-section-badge{color:#f97316;background:#fff7ed;border:1px solid #fed7aa;border-radius:12px;padding:2px 10px;font-size:.78rem;font-weight:600}.wordbook-section-badge.badge-locked{color:#9ca3af;background:#f3f4f6;border-color:#e5e7eb}.wordbook-locked-hint,.wordbook-empty-hint{color:#9ca3af;text-align:center;padding:6px 0;font-size:.85rem}.wordbook-custom-group{flex-direction:column;gap:8px;margin-bottom:14px;display:flex}.wordbook-custom-group:last-child{margin-bottom:0}.wordbook-custom-title{color:#9ca3af;font-size:.82rem;font-weight:600}.wordbook-chips{flex-wrap:wrap;gap:8px;display:flex}.word-chip{color:#c2410c;letter-spacing:.05em;background:#fff7ed;border:1.5px solid #fed7aa;border-radius:20px;padding:4px 12px;font-size:.9rem;font-weight:600}.modal-overlay{z-index:200;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#00000080;justify-content:center;align-items:center;animation:.2s fade-in;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-content{text-align:center;background:#fff;border-radius:24px;width:90%;max-width:320px;padding:32px 28px;animation:.25s cubic-bezier(.34,1.56,.64,1) modal-pop;box-shadow:0 20px 60px #0003}@keyframes modal-pop{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.modal-emoji{margin-bottom:8px;font-size:3rem}.modal-title{color:#1f2937;margin-bottom:4px;font-size:1.6rem;font-weight:700}.modal-sub{color:#6b7280;margin-bottom:20px}.modal-actions{flex-direction:column;gap:10px;display:flex}.modal-actions .btn{width:100%}.upload-modal{text-align:left;flex-direction:column;gap:14px;max-width:420px;padding:24px 20px;display:flex}.upload-modal-header{justify-content:space-between;align-items:center;display:flex}.close-btn{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:1.1rem;line-height:1}.close-btn:hover{color:#374151;background:#f3f4f6}
