:root{--color-primary: #3b82f6;--color-primary-light: #60a5fa;--color-primary-dark: #1d4ed8;--color-secondary: #6b7280;--color-success: #10b981;--color-danger: #ef4444;--color-warning: #f59e0b;--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--bg-card: #ffffff;--bg-overlay: rgba(0, 0, 0, .5);--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--text-inverse: #ffffff;--border-color: #e2e8f0;--border-focus: var(--color-primary);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: .75rem;--transition-fast: .15s ease-in-out;--transition-normal: .2s ease-in-out;--transition-slow: .3s ease-in-out;--z-dropdown: 1000;--z-sticky: 1010;--z-fixed: 1020;--z-modal: 1030;--z-toast: 1040}@media (prefers-color-scheme: dark){:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-card: #1e293b;--text-primary: #f8fafc;--text-secondary: #cbd5e1;--text-muted: #64748b;--border-color: #334155}}*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}html{line-height:var(--line-height-normal);-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--text-primary);background-color:var(--bg-primary);line-height:var(--line-height-normal)}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}button{cursor:pointer}.app{min-height:100vh;display:flex;flex-direction:column}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--space-md)}.main{flex:1;padding:var(--space-xl) 0}.header{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);color:var(--text-inverse);padding:var(--space-xl) 0;text-align:center;position:relative}.header__home-link{position:absolute;top:var(--space-md);right:var(--space-md);z-index:10}.home-link{display:flex;align-items:center;gap:var(--space-xs);color:var(--text-inverse);text-decoration:none;font-size:var(--font-size-sm);font-weight:500;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-lg);background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all var(--transition-fast)}.home-link:hover{background:#fff3;transform:translateY(-1px);text-decoration:none}.home-icon{font-size:var(--font-size-base)}.home-text{display:none}@media (min-width: 768px){.home-text{display:inline}}.header__title{font-size:var(--font-size-3xl);font-weight:700;margin-bottom:var(--space-sm);display:flex;align-items:center;justify-content:center;gap:var(--space-sm)}.header__title a{color:var(--text-inverse);text-decoration:none;transition:opacity var(--transition-fast);cursor:pointer}.header__title a:hover{opacity:.8;text-decoration:underline}.header__icon{font-size:2rem}.header__subtitle{font-size:var(--font-size-lg);opacity:.9;font-weight:400}.card{background:var(--bg-card);border-radius:var(--radius-xl);padding:var(--space-xl);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);margin-bottom:var(--space-xl)}.section-title{font-size:var(--font-size-2xl);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-lg)}.tabs-nav{display:flex;border-bottom:1px solid var(--border-color);margin-bottom:var(--space-lg);overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;justify-content:space-between;gap:var(--space-sm)}.tabs-nav::-webkit-scrollbar{display:none}.tab-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:var(--space-md) var(--space-lg);background:none;border:none;border-bottom:3px solid transparent;color:var(--text-secondary);font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;position:relative;flex:1;min-width:0}.tab-btn:hover{color:var(--color-primary);background:var(--bg-tertiary)}.tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.tab-icon{font-size:1.2em;flex-shrink:0}.tab-text{flex-shrink:0}.tab-badge{background:var(--color-primary);color:#fff;font-size:.75em;padding:2px 6px;border-radius:10px;font-weight:600;min-width:18px;text-align:center;flex-shrink:0}.tab-badge.optional{background:var(--text-muted);font-size:.7em;padding:1px 4px}.tab-content{position:relative}.tab-pane{display:none}.tab-pane.active{display:block}.tab-description{color:var(--text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--space-lg);line-height:var(--line-height-relaxed)}.generate-section{margin-top:var(--space-2xl);padding-top:var(--space-xl);border-top:2px solid var(--border-color);text-align:center}.word-form{margin-bottom:var(--space-xl)}.input-group{display:flex;flex-direction:column;gap:var(--space-sm)}.input-label{font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary)}.input-wrapper{display:flex;gap:var(--space-sm)}.word-input{flex:1;padding:var(--space-md);border:2px solid var(--border-color);border-radius:var(--radius-lg);font-size:var(--font-size-base);background:var(--bg-primary);color:var(--text-primary);transition:border-color var(--transition-fast);min-height:44px}.word-input:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #3b82f61a}.word-input::placeholder{color:var(--text-muted)}.input-help{font-size:var(--font-size-xs);color:var(--text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border:none;border-radius:var(--radius-lg);font-size:var(--font-size-base);font-weight:500;text-decoration:none;transition:all var(--transition-fast);cursor:pointer;min-height:44px;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--color-primary);color:var(--text-inverse)}.btn--primary:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn--secondary{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color)}.btn--secondary:hover:not(:disabled){background:var(--bg-secondary);color:var(--text-primary)}.btn--generate{width:100%;background:linear-gradient(135deg,var(--color-success) 0%,#059669 100%);color:var(--text-inverse);font-size:var(--font-size-lg);padding:var(--space-lg) var(--space-xl);margin-top:var(--space-lg)}.btn--generate:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn--small{padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm);min-height:36px}.btn--icon .btn__icon{font-size:1.2em}.grid-config-section{border-top:1px solid var(--border-color);padding-top:var(--space-lg);margin-top:var(--space-lg);margin-bottom:var(--space-lg)}.config-toggle{width:100%;display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);font-size:var(--font-size-sm);color:var(--text-secondary)}.config-toggle:hover{background:var(--bg-secondary);color:var(--text-primary)}.config-toggle__icon{font-size:var(--font-size-base)}.config-toggle__text{flex:1;text-align:left;font-weight:500}.config-toggle__arrow{font-size:var(--font-size-xs);transition:transform var(--transition-fast)}.config-toggle[aria-expanded=true] .config-toggle__arrow{transform:rotate(180deg)}.config-content{max-height:0;overflow:hidden;transition:max-height var(--transition-slow),padding var(--transition-slow);padding:0}.config-content.expanded{max-height:500px;padding:var(--space-lg) 0}.square-slider-section{display:flex;flex-direction:column;gap:var(--space-md)}.slider-header{display:flex;justify-content:space-between;align-items:center}.slider-label{font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary)}.slider-value{font-size:var(--font-size-lg);font-weight:600;color:var(--color-primary);background:var(--bg-primary);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-md);border:1px solid var(--border-color)}.size-slider{width:100%;height:6px;border-radius:3px;background:var(--border-color);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.size-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:2px solid var(--bg-primary);box-shadow:var(--shadow-sm)}.size-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:2px solid var(--bg-primary);box-shadow:var(--shadow-sm)}.slider-labels{display:flex;justify-content:space-between;font-size:var(--font-size-xs);color:var(--text-muted)}.unlink-toggle{display:flex;align-items:center;padding:var(--space-md);background:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border-color)}.toggle-label{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;font-size:var(--font-size-sm);color:var(--text-secondary)}.toggle-input{width:18px;height:18px;accent-color:var(--color-primary)}.toggle-text{font-weight:500}.separate-inputs{display:flex;flex-direction:row;align-items:end;gap:var(--space-md);padding:var(--space-md);background:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border-color)}.size-input-group{display:flex;flex-direction:column;gap:var(--space-xs)}.size-input-label{font-size:var(--font-size-xs);font-weight:500;color:var(--text-secondary)}.size-input{width:80px;padding:var(--space-sm);border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--bg-primary);color:var(--text-primary);text-align:center;transition:border-color var(--transition-fast)}.size-input:focus{outline:none;border-color:var(--border-focus)}.size-separator{font-size:var(--font-size-lg);font-weight:600;color:var(--text-secondary);margin:0 var(--space-xs)}.word-list-container{margin-bottom:var(--space-lg)}.word-list-title{font-size:var(--font-size-lg);font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-md)}.word-list{list-style:none;display:flex;flex-wrap:wrap;gap:var(--space-sm)}.word-item{display:flex;align-items:center;gap:var(--space-sm);background:var(--bg-tertiary);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:1px solid var(--border-color);animation:slideIn var(--transition-normal)}.word-item__text{font-weight:500;color:var(--text-primary)}.word-item__remove{background:none;border:none;color:var(--color-danger);font-size:var(--font-size-lg);cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color var(--transition-fast)}.word-item__remove:hover{background:#ef44441a}.next-tab-hint{margin-top:var(--space-lg);text-align:center;animation:fadeIn var(--transition-normal)}.next-tab-btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.next-tab-btn:hover{background:var(--bg-tertiary);color:var(--text-primary);transform:translateY(-1px);box-shadow:var(--shadow-sm);border-color:var(--color-primary)}.next-tab-icon{font-size:var(--font-size-base);transition:transform var(--transition-fast)}.next-tab-btn:hover .next-tab-icon{transform:translate(2px)}.grid-section{display:none}.grid-section.active{display:block}.grid-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg);flex-wrap:wrap;gap:var(--space-md)}.grid-actions{display:flex;gap:var(--space-sm)}.loading{text-align:center;padding:var(--space-2xl);display:none}.loading.active{display:block}.loading__spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top:3px solid var(--color-primary);border-radius:50%;margin:0 auto var(--space-md);animation:spin 1s linear infinite}.loading__text{color:var(--text-secondary);font-size:var(--font-size-lg)}.grid-container{margin-bottom:var(--space-xl);padding:var(--space-sm);width:100%;overflow:hidden}.word-search-grid{display:grid;gap:2px;margin:0 auto;background:var(--border-color);padding:2px;border-radius:var(--radius-md);width:100%;max-width:100%;box-sizing:border-box}.grid-cell{background:var(--bg-card);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--font-size-base);color:var(--text-primary);border-radius:var(--radius-sm);transition:background-color var(--transition-fast);min-height:26px;min-width:26px;aspect-ratio:1;border:1px solid var(--border-color)}.grid-cell:hover{background:var(--bg-tertiary)}.grid-cell.highlighted{background:var(--color-primary);color:var(--text-inverse);transform:scale(1.05);box-shadow:var(--shadow-md);z-index:1;position:relative}.solution-words{text-align:center}.solution-title{font-size:var(--font-size-lg);font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-md)}.solution-list{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-md)}.solution-word{background:var(--bg-secondary);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-weight:500;color:var(--text-primary);border:1px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;display:inline-block;margin:var(--space-xs)}.solution-word:hover{background:var(--bg-tertiary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.solution-word.active{background:var(--color-primary);color:var(--text-inverse);border-color:var(--color-primary);transform:translateY(-1px);box-shadow:var(--shadow-md)}.solution-word--hidden{background:var(--color-warning);color:var(--text-inverse);border-color:var(--color-warning);font-style:italic;position:relative}.solution-word--hidden:before{content:"🔍";margin-right:var(--space-xs);font-style:normal}.solution-word--hidden:hover{background:var(--color-warning);opacity:.9;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.solution-word--hidden.active{background:var(--color-warning);color:var(--text-inverse);border-color:var(--color-warning);transform:translateY(-1px);box-shadow:var(--shadow-md)}.footer{background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:var(--space-lg) 0;text-align:center}.footer__text{color:var(--text-muted);font-size:var(--font-size-sm)}.toast-container{position:fixed;top:var(--space-md);right:var(--space-md);z-index:var(--z-toast);max-width:400px}.toast{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-md);margin-bottom:var(--space-sm);box-shadow:var(--shadow-lg);animation:slideInRight var(--transition-normal);display:flex;align-items:center;gap:var(--space-sm)}.toast--success{border-left:4px solid var(--color-success)}.toast--error{border-left:4px solid var(--color-danger)}.toast--warning{border-left:4px solid var(--color-warning)}.toast__icon{font-size:var(--font-size-lg)}.toast__content{flex:1}.toast__title{font-weight:500;font-size:var(--font-size-sm);color:var(--text-primary)}.toast__message{font-size:var(--font-size-xs);color:var(--text-secondary)}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@media (max-width: 768px){.container{padding:0 var(--space-sm)}.card{padding:var(--space-lg)}.header__title{font-size:var(--font-size-2xl)}.tabs-nav{flex-direction:column;gap:1px;justify-content:flex-start}.tab-btn{padding:var(--space-sm) var(--space-md);justify-content:flex-start;border-bottom:none;border-left:3px solid transparent;flex:none}.tab-btn.active{border-bottom-color:transparent;border-left-color:var(--color-primary)}.tab-text{font-size:var(--font-size-sm)}.tab-badge{margin-left:auto}.input-wrapper{flex-direction:column}.btn{width:100%}.grid-actions{width:100%;justify-content:stretch}.grid-cell{min-height:18px;min-width:18px;font-size:var(--font-size-sm);font-weight:700;aspect-ratio:1}.word-search-grid{gap:1px;padding:1px}.toast-container{top:var(--space-sm);right:var(--space-sm);left:var(--space-sm);max-width:none}.grid-settings-container{flex-direction:column;gap:var(--space-lg)}.grid-size-controls{margin-bottom:var(--space-lg)}.custom-size-inputs{flex-direction:column;gap:var(--space-sm)}.size-separator{transform:rotate(90deg)}}.hidden-word-section{border-top:1px solid var(--border-color);padding-top:var(--space-lg);margin-top:var(--space-lg)}.hidden-word-title{font-size:var(--font-size-base);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-md);display:flex;align-items:center;gap:var(--space-sm)}.hidden-word-input-group{margin-bottom:var(--space-lg)}.hidden-word-input-wrapper{position:relative;display:flex;align-items:center}.hidden-word-input{width:100%;padding:var(--space-md);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--font-size-base);background:var(--bg-primary);color:var(--text-primary);transition:border-color var(--transition-fast)}.hidden-word-input:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #3b82f61a}.hidden-word-input::placeholder{color:var(--text-muted)}.hidden-word-clear{position:absolute;right:var(--space-sm);top:50%;transform:translateY(-50%);width:24px;height:24px;border:none;background:var(--color-danger);color:#fff;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);font-weight:700;transition:all var(--transition-fast);opacity:.8}.hidden-word-clear:hover{opacity:1;background:var(--color-danger);transform:translateY(-50%) scale(1.1)}.hidden-word-clear:focus{outline:none;box-shadow:0 0 0 3px #ef44444d}.clear-icon{line-height:1;font-size:var(--font-size-lg)}.hidden-word-help{margin-top:var(--space-sm);font-size:var(--font-size-xs);color:var(--text-muted)}@media (max-width: 480px){.header{padding:var(--space-lg) 0}.header__title{font-size:var(--font-size-xl);flex-direction:column;gap:var(--space-xs)}.grid-cell{min-height:16px;min-width:16px;font-size:var(--font-size-xs);font-weight:700;aspect-ratio:1}.word-search-grid{gap:1px;padding:1px}}@media print{.header,.footer,.word-input-section,.grid-actions,.toast-container{display:none!important}.main{padding:0}.card{box-shadow:none;border:none;padding:0}.word-search-grid{max-width:100%;page-break-inside:avoid}.solution-words{page-break-before:always;margin-top:2cm}}.grid-settings-container{display:flex;flex-direction:column;gap:var(--space-lg)}.grid-size-controls{display:flex;flex-direction:column;gap:var(--space-md)}.size-option{display:flex;align-items:flex-start;gap:var(--space-sm)}.size-option input[type=radio]{margin-top:2px;cursor:pointer}.size-label{flex:1;cursor:pointer;display:flex;flex-direction:column;gap:var(--space-xs)}.size-label__text{font-weight:500;color:var(--text-primary)}.size-label__desc{font-size:var(--font-size-xs);color:var(--text-muted)}.custom-size-inputs{display:none;flex-direction:column;gap:var(--space-lg);padding:var(--space-lg);background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.custom-size-inputs.active{display:flex}@media (min-width: 768px){.grid-settings-container{flex-direction:row;align-items:flex-start;gap:var(--space-xl)}.grid-size-controls{flex:0 0 300px;margin-bottom:0}.custom-size-inputs{flex:1;margin-bottom:0}}@media (min-width: 1024px){.tabs-nav{gap:var(--space-md)}.tab-btn{padding:var(--space-md) var(--space-xl)}}@media (max-width: 767px){.grid-settings-container{flex-direction:column;gap:var(--space-lg)}.grid-size-controls{margin-bottom:var(--space-lg)}.custom-size-inputs{margin-bottom:var(--space-sm)}}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg);flex-wrap:wrap;gap:var(--space-md)}.result-actions{display:flex;gap:var(--space-sm)}.result-empty{text-align:center;padding:var(--space-xl) var(--space-lg);color:var(--color-text-secondary)}.empty-icon{font-size:4rem;margin-bottom:var(--space-md);opacity:.5}.empty-title{font-size:1.5rem;font-weight:600;margin-bottom:var(--space-md);color:var(--color-text-primary)}.empty-description{font-size:1rem;line-height:1.6;max-width:500px;margin:0 auto var(--space-lg)}.result-empty .btn--generate{margin-top:var(--space-md)}.result-content{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.result-header{flex-direction:column;align-items:stretch;gap:var(--space-md)}.result-actions{justify-content:center}.empty-icon{font-size:3rem}.empty-title{font-size:1.25rem}}
