:root{font-family:Segoe UI,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;padding:0;min-width:320px;min-height:100vh;background:#f5f5f5}#root{width:100%;min-height:100vh}button:focus,[role=button]:focus,[tabindex]:focus{outline:2px solid #667eea;outline-offset:2px}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.app{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#667eea,#764ba2);font-family:Segoe UI,-apple-system,BlinkMacSystemFont,sans-serif}.app-header{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 20px #0000001a}.app-title{color:#fff;margin:0;font-size:2rem;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.generate-button{background:linear-gradient(45deg,#ff6b6b,#ee5a52);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:25px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #ee5a524d}.generate-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #ee5a5266}.generate-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.app-main{flex:1;padding:2rem;display:flex;justify-content:center;align-items:flex-start}.crossword-layout{display:grid;grid-template-columns:1fr 350px;gap:2rem;max-width:1200px;width:100%}.crossword-container{background:#fff;border-radius:15px;padding:1.5rem;box-shadow:0 10px 30px #0003}.crossword-grid{display:grid;gap:1px;background:#ddd;border-radius:8px;overflow:hidden;aspect-ratio:1;max-width:500px;margin:0 auto}.crossword-cell{background:#fff;display:flex;align-items:center;justify-content:center;position:relative;cursor:pointer;transition:all .2s ease;font-size:1rem;font-weight:700;min-height:30px}.crossword-cell.empty{background:#333;cursor:default}.crossword-cell.filled:hover{background:#f0f8ff}.crossword-cell.highlighted{background:#ffe4b5!important;box-shadow:inset 0 0 5px #ffa50080}.crossword-cell.numbered{position:relative}.cell-number{position:absolute;top:2px;left:2px;font-size:.6rem;font-weight:700;color:#666;line-height:1}.cell-letter{color:#333;font-size:.9rem;margin-top:4px}.clues-container{background:#fff;border-radius:15px;padding:1.5rem;box-shadow:0 10px 30px #0003;max-height:600px;overflow-y:auto}.clues-section{margin-bottom:2rem}.clues-section:last-child{margin-bottom:0}.clues-title{color:#333;margin:0 0 1rem;font-size:1.3rem;font-weight:700;padding-bottom:.5rem;border-bottom:2px solid #667eea}.clues-list{list-style:none;padding:0;margin:0}.clue-item{padding:.75rem;margin-bottom:.5rem;border-radius:8px;cursor:pointer;transition:all .2s ease;border:2px solid transparent;display:flex;align-items:flex-start;gap:.5rem}.clue-item:hover{background:#f8f9fa;border-color:#667eea}.clue-item.selected{background:#667eea;color:#fff;border-color:#5a6fd8}.clue-number{font-weight:700;color:#667eea;min-width:25px}.clue-item.selected .clue-number{color:#fff}.clue-text{flex:1;line-height:1.4}.clue-length{font-size:.85rem;opacity:.7;font-style:italic}.loading{display:flex;justify-content:center;align-items:center;color:#fff;font-size:1.2rem;text-shadow:1px 1px 2px rgba(0,0,0,.3)}@media (max-width: 768px){.app-header{flex-direction:column;gap:1rem;text-align:center}.app-title{font-size:1.5rem}.crossword-layout{grid-template-columns:1fr;gap:1rem}.crossword-grid{max-width:100%}.crossword-cell{min-height:25px;font-size:.8rem}.cell-letter{font-size:.7rem}.app-main{padding:1rem}}@media (max-width: 480px){.crossword-cell{min-height:20px;font-size:.7rem}.cell-letter{font-size:.6rem}.cell-number{font-size:.5rem}.clue-item{padding:.5rem;font-size:.9rem}}.help-guide{margin-bottom:20px}.help-toggle{padding:12px 20px;background:#17a2b8;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;width:100%;text-align:left;display:flex;align-items:center;justify-content:space-between}.help-toggle:hover{background:#138496}.help-toggle.active{background:#dc3545;border-radius:6px 6px 0 0}.help-toggle.active:hover{background:#c82333}.help-content{border:2px solid #17a2b8;border-top:none;border-radius:0 0 6px 6px;padding:20px;background:#fff;box-shadow:0 2px 4px #0000001a}.help-section{margin-bottom:24px}.help-section:last-child{margin-bottom:0}.help-section h4{margin:0 0 16px;color:#333;font-size:1.1rem;border-bottom:2px solid #f0f0f0;padding-bottom:8px}.help-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-bottom:16px}.help-item{background:#f8f9fa;padding:16px;border-radius:6px;border-left:4px solid #007bff}.help-item h5{margin:0 0 8px;color:#333;font-size:1rem}.help-item p{margin:0 0 8px;font-size:14px;color:#666}.help-item code{background:#e9ecef;padding:2px 6px;border-radius:3px;font-family:Courier New,monospace;font-size:13px;color:#495057;display:inline-block;margin:2px 0}.help-item pre{background:#e9ecef;padding:8px;border-radius:4px;font-size:12px;overflow-x:auto;margin:8px 0 0;color:#495057}.template-buttons{display:flex;gap:12px;margin:16px 0;flex-wrap:wrap}.template-btn{padding:10px 16px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;min-width:120px}.template-btn.json{background:#ffc107;color:#212529}.template-btn.json:hover{background:#e0a800}.template-btn.csv{background:#28a745;color:#fff}.template-btn.csv:hover{background:#218838}.template-btn.excel{background:#17a2b8;color:#fff}.template-btn.excel:hover{background:#138496}.template-note{font-size:13px;color:#666;font-style:italic;margin-top:8px}.help-list{margin:12px 0;padding-left:20px}.help-list li{margin-bottom:8px;font-size:14px;color:#555;line-height:1.4}.help-list strong{color:#333}@media (max-width: 768px){.help-content{padding:16px}.help-grid{grid-template-columns:1fr}.template-buttons{flex-direction:column}.template-btn{width:100%}.help-item{padding:12px}}.virtual-words-list{background:#fff;border-radius:8px;border:1px solid #e0e0e0;margin-top:16px;overflow:hidden}.virtual-words-list.empty{padding:20px;text-align:center;color:#666;background:#f8f9fa}.virtual-words-list.empty p{margin:0;font-style:italic}.words-list-header{background:#f8f9fa;border-bottom:1px solid #e0e0e0;padding:12px 16px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.words-count{display:flex;align-items:center;gap:12px;font-size:14px}.words-count strong{color:#007bff}.expand-toggle{padding:6px 12px;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;transition:background .2s ease}.expand-toggle:hover{background:#0056b3}.words-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.download-buttons{display:flex;gap:6px}.download-btn{padding:6px 10px;border:none;border-radius:4px;cursor:pointer;font-size:11px;font-weight:500;transition:all .2s ease;min-width:50px}.download-btn.json{background:#ffc107;color:#212529}.download-btn.json:hover{background:#e0a800}.download-btn.csv{background:#28a745;color:#fff}.download-btn.csv:hover{background:#218838}.download-btn.excel{background:#17a2b8;color:#fff}.download-btn.excel:hover{background:#138496}.clear-all-btn{padding:6px 10px;background:#dc3545;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:11px;font-weight:500;transition:background .2s ease}.clear-all-btn:hover{background:#c82333}.words-list-expanded{border-top:1px solid #e0e0e0}.list-container{background:#fff}.word-item{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;border-bottom:1px solid #f0f0f0;transition:background .2s ease}.word-item:hover{background:#f8f9fa}.word-item:last-child{border-bottom:none}.word-content{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.word-index{color:#666;font-size:12px;min-width:30px;text-align:right}.word-text{font-weight:600;color:#007bff;min-width:60px;text-align:left;font-size:14px}.word-clue{color:#333;font-size:13px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.remove-word-btn{padding:4px 8px;background:#dc3545;color:#fff;border:none;border-radius:3px;cursor:pointer;font-size:10px;opacity:.7;transition:opacity .2s ease;flex-shrink:0}.remove-word-btn:hover{opacity:1}.words-list-preview{padding:12px 16px}.preview-items{display:flex;flex-direction:column;gap:8px}.preview-item{display:flex;align-items:center;gap:12px;padding:6px 0;font-size:13px}.preview-word{font-weight:600;color:#007bff;min-width:60px}.preview-clue{color:#666;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-more{padding:6px 0;color:#6c757d;font-style:italic;font-size:12px;text-align:center;border-top:1px solid #f0f0f0;margin-top:4px}@media (max-width: 768px){.words-list-header{flex-direction:column;align-items:stretch}.words-count,.words-actions{justify-content:space-between}.download-buttons{flex:1;justify-content:space-around}.word-content{gap:8px}.word-index{min-width:25px}.word-text{min-width:50px;font-size:13px}.word-clue{font-size:12px}.preview-item{gap:8px}.preview-word{min-width:50px;font-size:12px}.preview-clue{font-size:12px}}@media (max-width: 480px){.words-list-header{padding:10px 12px}.word-item{padding:6px 12px}.words-list-preview{padding:10px 12px}.download-buttons{gap:4px}.download-btn{padding:5px 8px;font-size:10px;min-width:45px}.clear-all-btn{padding:5px 8px;font-size:10px}}.word-input{background:#fff;border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.word-input-header{margin-bottom:20px}.word-input h3{margin-top:0;margin-bottom:8px;color:#333;font-size:1.2rem}.help-info{margin-bottom:12px}.help-text{display:block;color:#666;font-size:14px;margin-bottom:6px}.requirements{font-size:13px;color:#555;background:#f8f9fa;padding:8px 12px;border-radius:4px;border-left:3px solid #007bff}.input-method-selector{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.input-method-selector button{padding:8px 16px;border:2px solid #e0e0e0;background:#fff;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s ease}.input-method-selector button:hover{border-color:#007bff;background:#f8f9fa}.input-method-selector button.active{background:#007bff;color:#fff;border-color:#007bff}.current-status{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#f8f9fa;border-radius:6px;margin-bottom:16px;font-size:14px}.clear-button{padding:6px 12px;background:#dc3545;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px}.clear-button:hover{background:#c82333}.error-message{padding:12px;background:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-radius:6px;margin-bottom:16px;font-size:14px;white-space:pre-line}.success-message{padding:12px;background:#d4edda;color:#155724;border:1px solid #c3e6cb;border-radius:6px;margin-bottom:16px;font-size:14px;display:flex;align-items:center;gap:8px}.success-message:before{content:"✅";font-size:16px}.loading-message{padding:12px;background:#d1ecf1;color:#0c5460;border:1px solid #bee5eb;border-radius:6px;margin-bottom:16px;font-size:14px;text-align:center}.direct-input-section{margin-top:16px}.input-instructions{margin-bottom:12px;padding:12px;background:#e7f3ff;border-radius:6px;font-size:14px}.input-instructions p{margin:0 0 8px;font-weight:500}.input-instructions ul{margin:8px 0 0 20px;padding:0}.input-instructions li{margin-bottom:4px}.input-instructions code{background:#f1f3f4;padding:2px 4px;border-radius:3px;font-family:Courier New,monospace;font-size:13px}.direct-input-textarea{width:100%;min-height:150px;padding:12px;border:2px solid #e0e0e0;border-radius:6px;font-family:inherit;font-size:14px;resize:vertical;margin-bottom:12px}.direct-input-textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.add-words-button{padding:10px 20px;background:#28a745;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500}.add-words-button:hover:not(:disabled){background:#218838}.add-words-button:disabled{background:#6c757d;cursor:not-allowed}.file-input-section{margin-top:16px}.file-input-instructions{margin-bottom:16px;padding:12px;background:#e7f3ff;border-radius:6px;font-size:14px}.file-input-instructions p{margin:0 0 8px}.file-input-instructions pre{background:#f1f3f4;padding:12px;border-radius:4px;font-size:12px;overflow-x:auto;margin:8px 0}.sample-button{padding:6px 12px;background:#17a2b8;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;margin-top:8px}.sample-button:hover{background:#138496}.file-input{width:100%;padding:12px;border:2px dashed #007bff;border-radius:6px;background:#f8f9fa;cursor:pointer;font-size:14px}.file-input:hover{background:#e9ecef}@media (max-width: 768px){.word-input{padding:16px}.input-method-selector{flex-direction:column}.input-method-selector button{width:100%}.current-status{flex-direction:column;gap:8px;align-items:stretch}.direct-input-textarea{min-height:120px}}
