@font-face{font-family:Inter;src:url(/fonts/Inter/Inter-Variable.woff2) format("woff2");font-weight:100 900;font-style:normal;font-display:swap}:root{--font-heading: "Inter", "Noto Sans KR", -apple-system, BlinkMacSystemFont, sans-serif;--font-body: "Inter", "Noto Sans KR", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--slate-900: #0f172a;--slate-700: #334155;--slate-500: #64748b;--slate-300: #cbd5e1;--slate-200: #e2e8f0;--slate-100: #f1f5f9;--slate-50: #f8fafc;--white: #ffffff;--accent: #6366f1;--accent-hover: #4f46e5;--accent-light: #eef2ff;--accent-muted: #a5b4fc;--success: #4ade80;--success-light: #f0fdf4;--error: #fb7185;--error-dark: #f43f5e;--error-light: #fff1f2;--warning: #fbbf24;--info: #6366f1;--info-light: #eef2ff;--info-dark: #4f46e5;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .06);--shadow-md: 0 4px 12px rgba(15, 23, 42, .08);--shadow-lg: 0 8px 24px rgba(15, 23, 42, .12);--shadow-overlay: 0 16px 48px rgba(15, 23, 42, .16);--transition-fast: .15s ease;--transition-base: .2s ease}*{box-sizing:border-box;margin:0;padding:0}button,input,select,textarea{font-family:inherit}body{font-family:var(--font-body);background:var(--slate-50);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;color:var(--slate-700)}.container{background:var(--white);border-radius:var(--radius-lg);padding:30px;box-shadow:var(--shadow-md);border:1px solid var(--slate-200);max-width:600px;width:100%}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--slate-900)}.app-header{display:flex;align-items:center;justify-content:center;gap:15px;margin-bottom:20px}.app-header h1{margin-bottom:0}.app-logo{width:50px;height:50px;object-fit:contain}h1{text-align:center;color:var(--slate-900);font-size:2em;font-weight:700}.auth-container{max-width:350px;margin:0 auto}.auth-tabs{display:flex;gap:10px;margin-bottom:25px}.auth-tab{flex:1;padding:12px;border:none;background:var(--slate-100);border-radius:var(--radius-md);cursor:pointer;font-size:1em;font-weight:500;color:var(--slate-500);transition:all var(--transition-fast)}.auth-tab.active{background:var(--accent);color:var(--white)}.auth-tab:hover:not(.active){background:var(--slate-200)}.auth-form{display:flex;flex-direction:column;gap:15px}.form-group{display:flex;flex-direction:column;gap:5px}.form-group label{font-size:.9em;color:var(--slate-500);font-weight:500}.form-group input{padding:12px 15px;border:1px solid var(--slate-300);border-radius:var(--radius-md);font-size:1em;transition:all var(--transition-fast)}.form-group input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.auth-error{color:var(--error);font-size:.9em;padding:10px;background:var(--error-light);border-radius:var(--radius-md);border:1px solid #fecdd3;text-align:center}.auth-submit-btn{padding:14px;background:var(--accent);color:var(--white);border:none;border-radius:var(--radius-md);font-size:1.1em;font-weight:600;cursor:pointer;transition:background var(--transition-fast);margin-top:10px}.auth-submit-btn:hover{background:var(--accent-hover)}.auth-submit-btn:disabled{opacity:.6;cursor:not-allowed}.user-header{display:flex;justify-content:space-between;align-items:center;padding:10px 15px;background:var(--slate-100);border-radius:var(--radius-md);margin-bottom:20px}#usernameDisplay{font-weight:600;color:var(--slate-900)}.logout-btn{padding:6px 12px;background:transparent;border:1px solid var(--slate-300);border-radius:var(--radius-md);cursor:pointer;font-size:.85em;color:var(--slate-500);transition:all var(--transition-fast)}.logout-btn:hover{border-color:var(--error);color:var(--error)}.vocab-buttons-row{display:flex;gap:10px;margin-bottom:20px}.selection-subtitle{text-align:center;color:var(--slate-500);margin-bottom:25px;font-size:1.1em}.filter-section{background:var(--slate-100);border-radius:var(--radius-lg);padding:20px;margin-bottom:20px}.filter-title{color:var(--slate-900);font-size:1em;margin-bottom:15px;font-weight:600}.category-checkboxes{display:flex;flex-wrap:wrap;gap:10px}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;padding:8px 12px;background:var(--white);border-radius:var(--radius-md);border:1px solid var(--slate-200);transition:all var(--transition-fast);font-size:.95em}.checkbox-label:hover{border-color:var(--accent)}.checkbox-label input[type=checkbox]{display:none}.checkbox-custom{width:18px;height:18px;border:2px solid var(--slate-300);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0}.checkbox-label input[type=checkbox]:checked+.checkbox-custom{background:var(--accent);border-color:var(--accent)}.checkbox-label input[type=checkbox]:checked+.checkbox-custom:after{content:"✓";color:var(--white);font-size:12px;font-weight:700}.checkbox-label:has(input:checked){border-color:var(--accent);background:var(--accent-light)}.tags-container{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:15px}.tag-chip{display:inline-flex;align-items:center;padding:8px 16px;background:var(--white);border:1px solid var(--slate-200);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);font-size:.9em;color:var(--slate-700)}.tag-chip:hover{border-color:var(--accent)}.tag-chip.active{background:var(--accent);border-color:var(--accent);color:var(--white)}.tag-chip.custom:after{content:"×";margin-left:8px;font-size:1.1em;opacity:.7}.tag-chip.custom:hover:after{opacity:1}.add-tag-container{display:flex;gap:10px}.add-tag-container input{flex:1;padding:10px 15px;border:1px solid var(--slate-300);border-radius:var(--radius-md);font-size:.95em;outline:none;transition:all var(--transition-fast)}.add-tag-container input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.add-tag-btn{padding:10px 20px;background:var(--accent);color:var(--white);border:none;border-radius:var(--radius-md);cursor:pointer;font-size:.95em;font-weight:500;transition:background var(--transition-fast)}.add-tag-btn:hover{background:var(--accent-hover)}.personal-filter-section{background:var(--accent-light);border:1px solid var(--accent-muted);border-radius:var(--radius-lg);padding:15px 20px;margin-bottom:5px}.checkbox-label-personal{color:var(--accent-hover);font-weight:600;font-size:1.05em}.checkbox-custom-personal{border-color:var(--accent-muted)!important;background:#ffffff80}.checkbox-label-personal:hover .checkbox-custom-personal{background:#fffc}.checkbox-label-personal input:checked+.checkbox-custom-personal{background:var(--accent)!important;border-color:var(--accent)!important}.checkbox-label-personal:has(input:checked){color:var(--accent-hover)}.personal-count{margin-left:8px;opacity:.8;font-weight:400}.additional-filters{display:flex;flex-direction:column;gap:10px}.word-counter{text-align:center;padding:12px 20px;background:var(--slate-100);border-radius:var(--radius-md);color:var(--slate-700);font-size:1em;margin-bottom:20px;border:1px solid var(--slate-200)}.word-counter #selectedCount{font-weight:700;font-size:1.2em;color:var(--accent)}.start-btn{width:100%;padding:18px;background:var(--accent);color:var(--white);border:none;border-radius:var(--radius-md);font-size:1.2em;font-weight:600;cursor:pointer;transition:background var(--transition-fast)}.start-btn:hover{background:var(--accent-hover)}.start-btn:disabled{background:var(--slate-300);cursor:not-allowed}.app-controls{display:flex;justify-content:center;gap:10px;margin-bottom:20px;flex-wrap:wrap}.back-btn{background:var(--slate-100);border:none;padding:8px 16px;border-radius:var(--radius-full);font-size:.9em;cursor:pointer;transition:background var(--transition-fast);color:var(--slate-700)}.back-btn:hover{background:var(--slate-200)}.stats-btn,.reset-btn{background:var(--slate-100);border:none;padding:8px 16px;border-radius:var(--radius-full);font-size:.9em;cursor:pointer;transition:background var(--transition-fast);color:var(--slate-700)}.stats-btn:hover,.reset-btn:hover{background:var(--slate-200)}.mode-selector{display:flex;justify-content:center;gap:10px;margin-bottom:20px}.mode-btn{background:var(--slate-200);border:none;padding:10px 20px;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);font-size:1em;color:var(--slate-700)}.mode-btn.active{background:var(--accent);color:var(--white)}.mode-btn:hover:not(.active){background:var(--slate-300)}.category-filter{text-align:center;margin-bottom:30px}.category-select{padding:10px 20px;border-radius:var(--radius-md);border:1px solid var(--slate-300);font-size:1em;cursor:pointer;transition:all var(--transition-fast);color:var(--slate-700)}.category-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.card{background:var(--slate-900);border-radius:var(--radius-lg);padding:50px;margin-bottom:30px;text-align:center;cursor:pointer;transition:box-shadow var(--transition-base);position:relative;min-height:250px;display:flex;flex-direction:column;justify-content:center}.card:hover{box-shadow:var(--shadow-lg)}.difficulty-indicator{position:absolute;top:15px;right:15px;background:var(--success);color:var(--white);padding:5px 15px;border-radius:var(--radius-full);font-size:.8em;font-weight:700}.korean-word{font-size:3em;color:var(--white);margin-bottom:20px;font-weight:700}.spanish-word{font-size:1.5em;color:var(--white);margin-bottom:10px}.pronunciation{font-size:1.2em;color:#ffffffb3;font-style:italic}.hidden{display:none}.controls{display:flex;justify-content:center;gap:15px;margin-bottom:30px}.btn{background:var(--accent);color:var(--white);border:none;padding:12px 24px;border-radius:var(--radius-full);cursor:pointer;font-size:1em;font-weight:500;transition:background var(--transition-fast)}.btn:hover{background:var(--accent-hover)}.btn-success{background:var(--success)}.btn-success:hover{background:#22c55e}.btn-danger{background:var(--error)}.btn-danger:hover{background:var(--error-dark)}.quiz-options{display:grid;grid-template-columns:repeat(2,1fr);gap:15px;margin-top:30px}.quiz-option{background:var(--white);border:1px solid var(--slate-200);padding:15px;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-size:1.1em}.quiz-option:hover{background:var(--slate-50);border-color:var(--accent)}.quiz-option.correct{background:var(--success);color:var(--white);border-color:var(--success)}.quiz-option.incorrect{background:var(--error);color:var(--white);border-color:var(--error)}#typingMode{text-align:center}.typing-input{width:100%;padding:15px;font-size:1.2em;text-align:center;border:1px solid var(--slate-300);border-radius:var(--radius-md);margin-bottom:20px;transition:all var(--transition-fast)}.typing-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.typing-feedback{margin-top:20px;font-size:1.2em}.score{text-align:center;margin-top:20px;color:var(--slate-700)}.progress{background:var(--slate-200);border-radius:var(--radius-full);height:20px;margin-top:10px;overflow:hidden}.progress-bar{background:var(--accent);height:100%;transition:width .3s}.modal{display:none;position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;background-color:#0f172a80}.modal-content{background-color:var(--white);margin:10% auto;padding:30px;border-radius:var(--radius-lg);width:80%;max-width:500px;position:relative;box-shadow:var(--shadow-overlay)}.close{color:var(--slate-500);float:right;font-size:28px;font-weight:700;cursor:pointer}.close:hover{color:var(--slate-900)}#statsContent h3{color:var(--slate-900);margin-bottom:20px}#statsContent h4{color:var(--slate-500);margin-top:20px;margin-bottom:10px}#statsContent p{margin-bottom:10px;color:var(--slate-700)}#statsContent ul{list-style-position:inside;color:var(--slate-500)}.confirm-dialog{border:none;border-radius:var(--radius-lg);padding:0;box-shadow:var(--shadow-overlay);max-width:400px;width:90%;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);margin:0}.confirm-dialog::backdrop{background-color:#0f172a80}.dialog-content{padding:30px;text-align:center}.dialog-content p{font-size:1.1em;color:var(--slate-900);margin-bottom:25px;line-height:1.5}.dialog-buttons{display:flex;gap:15px;justify-content:center}.dialog-btn{padding:12px 30px;border:none;border-radius:var(--radius-md);font-size:1em;font-weight:500;cursor:pointer;transition:background var(--transition-fast)}.dialog-btn-cancel{background:var(--slate-100);color:var(--slate-500)}.dialog-btn-cancel:hover{background:var(--slate-200)}.dialog-btn-confirm{background:var(--error);color:var(--white)}.dialog-btn-confirm:hover{background:var(--error-dark)}.add-vocab-btn,.manage-vocab-btn{flex:1;padding:10px 16px;border:none;border-radius:var(--radius-md);font-size:.9em;font-weight:500;cursor:pointer;transition:background var(--transition-fast)}.add-vocab-btn{background:var(--accent);color:var(--white)}.add-vocab-btn:hover{background:var(--accent-hover)}.manage-vocab-btn{background:var(--slate-100);color:var(--slate-900);border:1px solid var(--slate-300)}.manage-vocab-btn:hover{background:var(--slate-200)}.vocab-dialog{border:none;border-radius:var(--radius-lg);padding:0;box-shadow:var(--shadow-overlay);max-width:450px;width:90%;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);margin:0}.vocab-dialog::backdrop{background-color:#0f172a80}.vocab-dialog-content{padding:25px}.vocab-dialog-content h3{margin:0 0 20px;color:var(--slate-900);text-align:center}.vocab-dialog-content .form-group{margin-bottom:15px}.vocab-dialog-content label{display:block;margin-bottom:5px;color:var(--slate-700);font-weight:500}.vocab-dialog-content input,.vocab-dialog-content select{width:100%;padding:10px;border:1px solid var(--slate-300);border-radius:var(--radius-md);font-size:1em;box-sizing:border-box}.vocab-dialog-content input:focus,.vocab-dialog-content select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light);outline:none}.dialog-btn-save{background:var(--accent);color:var(--white)}.dialog-btn-save:hover{background:var(--accent-hover)}.manage-vocab-dialog{border:none;border-radius:var(--radius-lg);padding:0;box-shadow:var(--shadow-overlay);max-width:500px;width:90%;max-height:80vh;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);margin:0}.manage-vocab-dialog::backdrop{background-color:#0f172a80}.manage-vocab-content{padding:20px}.manage-vocab-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid var(--slate-200)}.manage-vocab-header h3{margin:0;color:var(--slate-900)}.close-manage-btn{background:none;border:none;font-size:24px;color:var(--slate-500);cursor:pointer}.close-manage-btn:hover{color:var(--slate-900)}.personal-vocab-list{max-height:50vh;overflow-y:auto}.vocab-item{display:flex;justify-content:space-between;align-items:center;padding:12px;border-radius:var(--radius-md);background:var(--slate-50);margin-bottom:8px}.vocab-item:hover{background:var(--slate-100)}.vocab-item-info{flex:1}.vocab-item-korean{font-size:1.1em;font-weight:600;color:var(--slate-900)}.vocab-item-spanish{font-size:.9em;color:var(--slate-500)}.vocab-item-category{font-size:.75em;color:var(--slate-500);margin-top:2px}.vocab-item-actions{display:flex;gap:8px}.vocab-item-actions button{padding:6px 12px;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:.85em;transition:background var(--transition-fast)}.vocab-edit-btn{background:var(--info-light);color:var(--info-dark)}.vocab-edit-btn:hover{background:#e0e7ff}.vocab-delete-btn{background:var(--error-light);color:var(--error-dark)}.vocab-delete-btn:hover{background:#ffe4e6}.no-vocab-message{text-align:center;color:var(--slate-500);padding:30px}.personal-indicator{position:absolute;top:10px;left:10px;background:var(--accent);color:var(--white);font-size:.7em;padding:3px 8px;border-radius:var(--radius-full)}@media(max-width:600px){.container{padding:20px}h1{font-size:1.6em}.korean-word{font-size:2em}.card{padding:30px;min-height:200px}.quiz-options{grid-template-columns:1fr}.controls,.mode-selector{flex-wrap:wrap}.category-checkboxes{flex-direction:column}.checkbox-label{width:100%}.app-controls{flex-direction:row;justify-content:center;gap:8px}.add-tag-container{flex-direction:column}.add-tag-btn{width:100%}.start-btn{font-size:1em;padding:15px}}
