.advanced-settings{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;margin-bottom:20px;overflow:hidden}.advanced-settings-header{display:flex;align-items:center;padding:12px 16px;background:#e9ecef;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s ease}.advanced-settings-header:hover{background:#dee2e6}.settings-icon{margin-right:8px;font-size:1.1rem}.settings-title{flex:1;font-weight:600;color:#2c3e50}.expand-icon{color:#6c757d;font-size:.9rem}.advanced-settings-content{padding:20px}.setting-group{margin-bottom:24px}.setting-group:last-child{margin-bottom:0}.setting-label{display:flex;justify-content:space-between;align-items:center;font-weight:600;color:#2c3e50;margin-bottom:8px}.setting-value{background:#e9ecef;padding:2px 8px;border-radius:12px;font-size:.9rem;color:#495057}.slider-container{margin-bottom:8px}.slider{width:100%;height:6px;border-radius:3px;background:#dee2e6;outline:none;-webkit-appearance:none;cursor:pointer}.slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#3498db;cursor:pointer;transition:transform .2s ease}.slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#3498db;cursor:pointer;border:none}.slider-labels{display:flex;justify-content:space-between;margin-top:4px;font-size:.85rem;color:#6c757d}.setting-description{font-size:.9rem;color:#6c757d;font-style:italic}.presets-section{margin-top:20px;padding-top:20px;border-top:1px solid #dee2e6}.presets-label{font-weight:600;color:#2c3e50;margin-bottom:10px}.presets-container{display:flex;gap:8px;flex-wrap:wrap}.preset-button{padding:6px 12px;border:2px solid #6c757d;background:#fff;color:#6c757d;border-radius:16px;cursor:pointer;transition:all .2s ease;font-size:.85rem;font-weight:500}.preset-button:hover{border-color:#3498db;color:#3498db}.preset-button.active{border-color:#3498db;background:#3498db;color:#fff}.settings-info{margin-top:16px;padding:12px;background:#e3f2fd;border-radius:6px;border-left:4px solid #2196f3}.info-item{margin-bottom:8px;font-size:.85rem;color:#1976d2}.info-item:last-child{margin-bottom:0}.crossword-app{max-width:1200px;margin:0 auto;padding:20px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.app-header{text-align:center;margin-bottom:30px}.app-title{color:#2c3e50;font-size:2.5rem;margin-bottom:10px}.topic-selector{background:#f8f9fa;padding:20px;border-radius:8px;margin-bottom:20px}.topic-selector h3{margin-top:0;color:#2c3e50}.topic-buttons{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:15px}.topic-btn{padding:8px 16px;border:2px solid #3498db;background:#fff;color:#3498db;border-radius:20px;cursor:pointer;transition:all .3s ease;font-weight:500}.topic-btn:hover,.topic-btn.selected{background:#3498db;color:#fff}.selected-count{color:#7f8c8d;font-size:.9rem;margin:0}.custom-topics-container{margin-top:20px;padding-top:15px;border-top:1px solid #e9ecef}.custom-topics-container h3{color:#2c3e50;margin-bottom:8px}.custom-topics-description{color:#7f8c8d;font-size:.9rem;margin-bottom:15px;margin-top:0}.custom-topic-input-container{display:flex;align-items:center;gap:8px;margin-bottom:10px}.custom-topic-input{flex:1;padding:8px 12px;border:2px solid #ddd;border-radius:4px;font-size:.9rem;transition:border-color .3s ease}.custom-topic-input:focus{outline:none;border-color:#3498db}.remove-topic-btn{background:#e74c3c;color:#fff;border:none;border-radius:4px;width:30px;height:30px;cursor:pointer;transition:background-color .3s ease;display:flex;align-items:center;justify-content:center;font-size:14px}.remove-topic-btn:hover{background:#c0392b}.add-topic-btn{background:#27ae60;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;transition:background-color .3s ease;font-size:.9rem;margin-top:5px}.add-topic-btn:hover{background:#229954}.sentence-input-container{margin-top:20px;margin-bottom:15px}.sentence-label{display:block;margin-bottom:8px;color:#2c3e50;font-weight:500;font-size:.95rem}.sentence-input{width:100%;padding:12px;border:2px solid #e1e8ed;border-radius:8px;font-family:inherit;font-size:.9rem;line-height:1.4;resize:vertical;min-height:80px;background:#fff;transition:border-color .3s ease,box-shadow .3s ease;box-sizing:border-box}.sentence-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.sentence-input::placeholder{color:#95a5a6;font-style:italic}.sentence-info{display:flex;justify-content:space-between;align-items:center;margin-top:6px;font-size:.8rem}.char-count{color:#7f8c8d}.clear-sentence-btn{background:#e74c3c;color:#fff;border:none;padding:4px 8px;border-radius:4px;cursor:pointer;font-size:.75rem;transition:background-color .2s ease}.clear-sentence-btn:hover{background:#c0392b}.clear-sentence-btn:active{background:#a93226}.multi-theme-toggle-container{margin-top:20px;margin-bottom:15px;padding:15px;background:#f0f4f8;border:1px solid #e1e8ed;border-radius:8px}.multi-theme-toggle{display:flex;align-items:center;cursor:pointer;margin-bottom:8px}.multi-theme-checkbox{width:18px;height:18px;margin-right:10px;cursor:pointer;accent-color:#3498db}.multi-theme-label{font-weight:500;color:#2c3e50;font-size:.95rem;-webkit-user-select:none;user-select:none}.multi-theme-description{margin:0;font-size:.85rem;color:#5a6c7d;line-height:1.4;font-style:italic;padding-left:28px}.ai-toggle-container{margin:20px 0;padding:15px;background:#f8f9fa;border-radius:8px;border:2px solid #e9ecef;transition:all .3s ease}.ai-toggle-container:has(.ai-checkbox:checked){background:linear-gradient(135deg,#e3f2fd,#f3e5f5);border-color:#3498db}.ai-toggle{display:flex;align-items:center;cursor:pointer;font-weight:500;margin-bottom:8px}.ai-checkbox{width:20px;height:20px;margin-right:12px;cursor:pointer;accent-color:#3498db}.ai-label{font-size:1rem;color:#2c3e50;-webkit-user-select:none;user-select:none}.ai-status{color:#27ae60;font-weight:600;font-size:.9rem}.ai-description{margin:0;font-size:.85rem;color:#6c757d;line-height:1.4;padding-left:32px}.puzzle-controls{display:flex;gap:15px;margin-bottom:20px;justify-content:center}.control-btn{padding:10px 20px;border:none;border-radius:5px;cursor:pointer;font-weight:600;transition:background-color .3s ease}.control-btn:disabled{background:#bdc3c7!important;color:#7f8c8d!important;cursor:not-allowed;opacity:.7}.generate-btn{background:#27ae60;color:#fff}.generate-btn:hover{background:#229954}.generate-btn:disabled{background:#bdc3c7;cursor:not-allowed}.reset-btn{background:#e74c3c;color:#fff}.reset-btn:hover{background:#c0392b}.reveal-btn{background:#f39c12;color:#fff}.reveal-btn:hover{background:#e67e22}.loading-spinner{display:flex;flex-direction:column;align-items:center;padding:40px}.spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:15px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-message{color:#7f8c8d;font-size:1.1rem}.puzzle-info{display:flex;justify-content:space-between;align-items:center;margin:20px 0 10px;padding:10px 15px;background:#f8f9fa;border-radius:6px;border-left:4px solid #3498db}.puzzle-stats{font-size:.9rem;color:#6c757d;font-weight:500}.ai-generated-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:4px 12px;border-radius:15px;font-size:.8rem;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.2);box-shadow:0 2px 4px #0000001a}.puzzle-layout{display:grid;grid-template-columns:1fr 300px;gap:30px;margin-top:20px}@media (max-width: 768px){.puzzle-layout{grid-template-columns:1fr;gap:20px}.puzzle-info{flex-direction:column;gap:8px;text-align:center}.ai-toggle-container{padding:12px}.ai-description{padding-left:0;text-align:center}}.puzzle-container{display:flex;justify-content:center}.puzzle-grid{display:grid;gap:0;margin:0 auto;width:fit-content;height:fit-content}.grid-cell{width:35px;height:35px;position:relative;display:flex;align-items:center;justify-content:center;box-sizing:border-box;background:#fff}.grid-cell:before{content:"";position:absolute;top:0;left:0;right:-1px;bottom:-1px;border:1px solid #2c3e50;pointer-events:none;z-index:10}.black-cell{background:#f0f0f0}.black-cell:before{background:#f0f0f0;border:1px solid #2c3e50}.white-cell{background:#fff}.empty-cell{background:transparent;border:none;visibility:hidden}.empty-cell:before{display:none}.cell-input{width:100%;height:100%;border:none!important;text-align:center;font-size:16px;font-weight:700;background:transparent;outline:none;text-transform:uppercase;position:relative;z-index:5}.cell-input:focus{background:#e8f4fd;box-shadow:inset 0 0 0 2px #3498db}.cell-number{position:absolute;top:1px;left:2px;font-size:10px;font-weight:700;color:#2c3e50;line-height:1;z-index:15;pointer-events:none}.solution-text{color:#2c3e50!important;font-weight:700!important;background:#fff!important}.solution-text:disabled{opacity:1!important;cursor:default}.grid-cell .solution-text{border:none!important;background:#fff!important}.clue-list{background:#f8f9fa;padding:20px;border-radius:8px;max-height:600px;overflow-y:auto}.clue-section{margin-bottom:25px}.clue-section h4{color:#2c3e50;margin-bottom:15px;font-size:1.2rem;border-bottom:2px solid #3498db;padding-bottom:5px}.clue-section ol{padding-left:0;list-style:none}.clue-item{display:flex;margin-bottom:8px;padding:8px;border-radius:4px;cursor:pointer;transition:background-color .2s ease}.clue-item:hover{background:#e9ecef}.clue-number{font-weight:700;color:#3498db;margin-right:10px;min-width:25px}.clue-text{flex:1;color:#2c3e50}.error-message{background:#f8d7da;color:#721c24;padding:15px;border-radius:5px;margin:20px 0;border:1px solid #f5c6cb}.success-message{background:#d4edda;color:#155724;padding:15px;border-radius:5px;margin:20px 0;border:1px solid #c3e6cb;text-align:center;font-weight:600}.tab-nav{display:flex;border-bottom:2px solid #e9ecef;margin-bottom:20px;gap:2px}.tab-btn{padding:12px 20px;border:none;background:#f8f9fa;color:#6c757d;cursor:pointer;border-radius:8px 8px 0 0;font-weight:500;transition:all .3s ease}.tab-btn:hover{background:#e9ecef;color:#495057}.tab-btn.active{background:#3498db;color:#fff}.debug-tab{background:#f8f9fa;border-radius:8px;padding:20px;margin-top:20px}.debug-nav{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px;border-bottom:2px solid #e9ecef;padding-bottom:15px}.debug-nav-btn{padding:8px 16px;border:1px solid #dee2e6;background:#fff;color:#495057;border-radius:20px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .3s ease}.debug-nav-btn:hover{background:#e9ecef;border-color:#adb5bd}.debug-nav-btn.active{background:#3498db;color:#fff;border-color:#3498db}.debug-content{min-height:300px}.debug-section h3{color:#2c3e50;margin-bottom:15px;border-bottom:1px solid #dee2e6;padding-bottom:8px}.debug-section h4{color:#495057;margin-top:20px;margin-bottom:10px}.debug-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:10px;margin-bottom:20px}.debug-grid>div{padding:8px 12px;background:#fff;border-radius:4px;border:1px solid #e9ecef;font-size:.9rem}.debug-grid strong{color:#2c3e50}.word-table-container{max-height:400px;overflow-y:auto;border:1px solid #dee2e6;border-radius:6px;background:#fff}.word-table{width:100%;border-collapse:collapse;font-size:.85rem}.word-table th{background:#f8f9fa;padding:8px 12px;text-align:left;border-bottom:2px solid #dee2e6;font-weight:600;color:#495057;position:sticky;top:0;z-index:1}.word-table th.sorted-column{background:#e3f2fd;color:#1976d2;font-weight:700}.word-table th[style*="cursor: pointer"]:hover{background:#e9ecef}.word-table td{padding:6px 12px;border-bottom:1px solid #f1f3f4}.word-table tr:hover{background-color:#f8f9fa}.word-table td:first-child{font-weight:600;color:#2c3e50}.debug-section ul{margin:10px 0;padding-left:20px}.debug-section li{margin:5px 0;font-size:.9rem;line-height:1.4}.prob-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:10px 15px;margin:15px 0 20px;padding:15px;background:#f8f9fa;border-radius:8px;font-size:.9rem}.chart-container{margin:20px 0;padding:20px;background:#fff;border:1px solid #dee2e6;border-radius:8px;box-shadow:0 2px 4px #0000001a}.chart-description{background:#e3f2fd;padding:12px 15px;border-radius:6px;border-left:4px solid #1976d2;margin-top:15px;font-size:.9rem;line-height:1.4;color:#1565c0}.probability-table-container{max-height:600px;overflow-y:auto;border:1px solid #dee2e6;border-radius:8px}.probability-table{width:100%;border-collapse:collapse;font-size:.9rem}.probability-table th{background:#495057;color:#fff;padding:12px 8px;text-align:left;font-weight:600;position:sticky;top:0;z-index:10;border-bottom:2px solid #343a40}.probability-table td{padding:8px;border-bottom:1px solid #e9ecef;vertical-align:middle}.probability-table tr:hover{background:#f8f9fa}.probability-table tr.selected-word{background:#e8f5e8;border-left:4px solid #4CAF50}.probability-table tr.selected-word:hover{background:#d4edda}.probability-cell{display:flex;align-items:center;gap:10px}.prob-text{min-width:60px;font-weight:600}.prob-bar{height:16px;border-radius:8px;transition:all .3s ease;min-width:2px}.probability-table td:first-child{text-align:center;color:#6c757d;font-weight:600}.probability-table td:last-child{text-align:center;font-size:1.1rem;font-weight:700;color:#4caf50}.probability-table tr:not(.selected-word) td:last-child{color:#f44336}@media (max-width: 768px){.debug-nav{justify-content:center}.debug-nav-btn{font-size:.8rem;padding:6px 12px}.debug-grid{grid-template-columns:1fr}.word-table{font-size:.75rem}.word-table th,.word-table td{padding:4px 8px}.prob-summary{grid-template-columns:repeat(2,1fr);text-align:center}.chart-container{padding:10px;margin:10px 0}.probability-table{font-size:.75rem}.probability-table th,.probability-table td{padding:6px 4px}.prob-text{min-width:50px;font-size:.8rem}.prob-bar{height:12px}}
