.layout{min-height:100vh;display:flex;flex-direction:column}.header{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;background:var(--bg-secondary);border-bottom:1px solid var(--border)}.logo{font-size:1.5rem;font-weight:700;color:var(--text-primary);text-decoration:none!important}.logo:hover{color:var(--accent)!important}.nav{display:flex;align-items:center;gap:1.5rem}.nav a{color:var(--text-secondary);font-weight:500}.nav a:hover{color:var(--accent)}.user-email{font-size:.875rem;color:var(--text-secondary)}.main{flex:1;padding:2rem;max-width:1200px;margin:0 auto;width:100%}.main-full{padding:0;max-width:none;margin:0}.loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-secondary)}.btn{padding:.5rem 1rem;border-radius:8px;font-weight:500;font-size:.9rem}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.admin-page{max-width:960px;margin:0 auto;padding:1.5rem}.admin-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.admin-header h1{font-size:1.5rem;margin:0}.admin-header h1 i{margin-right:.5rem;opacity:.8}.admin-back{color:var(--text-secondary);font-size:.9rem}.admin-back:hover{color:var(--accent)}.admin-tabs{display:flex;gap:.25rem;margin-bottom:1.5rem;border-bottom:1px solid var(--border)}.admin-tabs button{padding:.6rem 1rem;background:none;border:none;color:var(--text-secondary);font-size:.9rem;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.admin-tabs button:hover{color:var(--text-primary)}.admin-tabs button.active{color:var(--accent);font-weight:500;border-bottom-color:var(--accent)}.admin-main{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}.admin-loading{color:var(--text-secondary);padding:2rem;text-align:center}.admin-overview h2,.admin-subscriptions h2,.admin-user-detail h2{font-size:1.1rem;margin:0 0 1rem}.admin-stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}.admin-stat-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;text-align:center}.admin-stat-value{display:block;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.admin-stat-label{font-size:.8rem;color:var(--text-secondary)}.admin-error{color:#f85149;font-size:.9rem;margin-top:1rem}.admin-filter{margin-bottom:1rem}.admin-filter label{font-size:.9rem}.admin-filter select{margin-left:.5rem;padding:.4rem .6rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary)}.admin-sub-table-wrap{overflow-x:auto;margin-bottom:1.5rem}.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-table th,.admin-table td{padding:.6rem .75rem;text-align:left;border-bottom:1px solid var(--border)}.admin-table th{color:var(--text-secondary);font-weight:500}.admin-status{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.8rem}.admin-status-pending{background:#ffc83233;color:#d4a012}.admin-status-confirmed{background:#3fb95033;color:var(--success)}.admin-status-expired{background:#f8514926;color:#f85149}.admin-badge{display:inline-block;padding:.15rem .4rem;border-radius:4px;font-size:.75rem;margin-left:.25rem}.admin-badge-expired{background:#f8514933;color:#f85149}.admin-badge-soon{background:#ffc83240;color:#d4a012}.admin-badge-lifetime,.admin-badge-active{background:#3fb95033;color:var(--success)}.admin-user-categories,.admin-user-subs{margin:.75rem 0}.admin-user-categories ul,.admin-subs-list{margin:.25rem 0 0 1rem;padding-left:1rem}.admin-subs-item{margin:.35rem 0;font-size:.9rem}.admin-settings h2{font-size:1.1rem;margin:0 0 1rem}.admin-settings-form{display:flex;flex-direction:column;gap:1rem}.admin-setting-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.admin-setting-row label{min-width:200px}.admin-setting-row input{width:80px;padding:.5rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary)}.admin-setting-hint{font-size:.85rem;color:var(--text-secondary)}.admin-settings-form button{padding:.5rem 1rem;width:fit-content;background:var(--accent);color:#fff;border:none;border-radius:6px;cursor:pointer}.admin-btn-confirm{padding:.3rem .6rem;font-size:.8rem;background:var(--accent);color:#fff;border:none;border-radius:6px;cursor:pointer}.admin-btn-confirm:hover{opacity:.9}.admin-add-sub{border-top:1px solid var(--border);padding-top:1.5rem}.admin-add-sub h3{font-size:1rem;margin:0 0 .75rem}.admin-add-sub form{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.admin-add-sub form select,.admin-add-sub form input{padding:.5rem .75rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary)}.admin-add-sub form button{padding:.5rem 1rem;background:var(--accent);color:#fff;border:none;border-radius:6px;cursor:pointer}.admin-hint{font-size:.8rem;color:var(--text-secondary);margin:.5rem 0 0}.admin-user-select{margin-bottom:1rem}.admin-user-select label{font-size:.9rem}.admin-user-select select{margin-left:.5rem;padding:.5rem .75rem;min-width:200px;background:var(--bg-primary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary)}.admin-user-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}.admin-user-card p{margin:.5rem 0;font-size:.9rem}.vm-container{display:flex;min-height:100vh}.vm-loading,.vm-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem;color:var(--text-secondary)}.vm-loading i,.vm-error i{font-size:2rem;color:var(--accent)}.vm-hint{font-size:.9rem;opacity:.8}.vm-sidebar{width:260px;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}.vm-sidebar-header{padding:.8rem 1rem;border-bottom:1px solid var(--border)}.vm-sidebar-header-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.5rem}.vm-sidebar-header-row:last-child{margin-bottom:0}.vm-sidebar-close{display:none;background:none;border:none;color:var(--text-secondary);font-size:1.2rem;cursor:pointer;padding:.3rem}.vm-sidebar-close:hover{color:var(--text-primary)}.vm-sidebar-header h1{color:var(--accent);font-size:1.1rem;margin:0;flex:1;min-width:0}.vm-sidebar-hint{font-size:.8rem;color:var(--text-secondary);margin-bottom:.5rem}.vm-user-info{display:flex;flex-direction:column;gap:.4rem;margin-top:.5rem}.vm-sidebar-tabs{display:flex;gap:.25rem;margin-top:.5rem;margin-bottom:.5rem}.vm-sidebar-tab{flex:1;padding:.4rem .5rem;font-size:.85rem;font-weight:600;background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border);border-radius:6px;cursor:pointer}.vm-sidebar-tab:hover{color:var(--text-primary);border-color:var(--text-secondary)}.vm-sidebar-upgrade-badge{margin-left:.35rem;font-size:.65rem;padding:.15rem .4rem;background:var(--accent);color:var(--bg-primary);border-radius:4px;font-weight:600}.vm-sidebar-tab.active{background:var(--accent);color:var(--bg-primary);border-color:var(--accent)}.vm-user-display{text-align:left;overflow:hidden;min-width:0}.vm-user-display-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:inline-block;vertical-align:bottom;max-width:200px}.vm-user-email{font-size:.8rem;color:var(--text-secondary);word-break:break-all}.vm-btn-small{padding:.3rem .6rem;font-size:.8rem;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);border-radius:6px;cursor:pointer}.vm-btn-small.vm-btn-accent{background:var(--accent);color:var(--bg-primary);border-color:var(--accent)}.vm-auth-section{display:flex;flex-direction:column;gap:.4rem;margin-top:.5rem}.vm-login-form{display:flex;flex-direction:column;gap:.3rem}.vm-input-sm{padding:.4rem .6rem;font-size:.85rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary)}.vm-login-actions{display:flex;gap:.4rem;margin-top:.3rem}.vm-add-cat-btn{padding:.2rem .4rem;background:transparent;border:none;color:var(--accent-success);cursor:pointer;font-size:.8rem}.vm-add-cat-btn:hover{color:var(--accent)}.vm-edit-cat-btn{color:var(--text-secondary);margin-left:.2rem}.vm-edit-cat-btn:hover{color:var(--accent)}.vm-drag-handle{cursor:grab;color:var(--text-secondary);padding:0 .3rem;margin-right:.2rem;opacity:.6}.vm-drag-handle:hover{opacity:1}.vm-drag-handle:active{cursor:grabbing}.vm-drag-handle-sm{font-size:.7rem}.vm-parent-category.vm-drag-over .vm-parent-header,.vm-child-item.vm-drag-over{outline:2px dashed var(--accent);outline-offset:2px}.vm-parent-category.vm-dragging .vm-parent-header,.vm-child-item.vm-dragging{opacity:.5}.vm-add-parent-row{margin-top:.5rem;padding:.4rem 0}.vm-add-parent-btn{display:flex;align-items:center;gap:.4rem;padding:.5rem .8rem;background:transparent;border:1px dashed var(--border);border-radius:6px;color:var(--text-secondary);font-size:.9rem;cursor:pointer;width:100%;justify-content:center}.vm-add-parent-btn:hover{border-color:var(--accent);color:var(--accent)}.vm-user-parent .vm-parent-header{padding-right:.4rem}.vm-add-form{display:flex;gap:.5rem;margin:.5rem 0}.vm-add-form-input{flex:1;padding:.5rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:.85rem}.vm-add-form-btn{padding:.5rem .8rem;background:var(--accent);color:var(--bg-primary);border:none;border-radius:6px;cursor:pointer;font-weight:600}.vm-sidebar-hint-inner{font-size:.75rem;color:var(--text-secondary);margin-top:.3rem}.vm-user-parent-item{margin-bottom:.3rem}.vm-user-parent-item .vm-children-list{display:none;padding-left:1rem;margin-top:.2rem}.vm-user-parent-item .vm-inner-parent.expanded+.vm-children-list{display:block}.vm-inner-parent{padding:.5rem .6rem!important;background:var(--bg-secondary)!important;margin:.2rem 0}.vm-inner-parent:hover{background:var(--bg-primary)!important}.vm-leaf-parent .vm-child-name{font-style:italic;color:var(--text-secondary)}.vm-category-list{flex:1;overflow-y:auto;padding:.4rem}.vm-parent-category{margin-bottom:.35rem}.vm-parent-header{display:flex;align-items:center;padding:.4rem .6rem;background:var(--bg-tertiary);border-radius:6px;cursor:pointer;transition:all .2s}.vm-parent-header:hover{background:var(--bg-primary)}.vm-parent-expand{margin-right:.5rem;color:var(--text-secondary);transition:transform .2s;font-size:.8rem}.vm-parent-category.expanded .vm-parent-expand{transform:rotate(90deg)}.vm-parent-name{flex:1;font-weight:600;color:var(--accent)}.vm-parent-count{background:var(--bg-secondary);padding:.15rem .5rem;border-radius:10px;font-size:.75rem;color:var(--text-secondary)}.vm-children-list{display:none;padding-left:1rem;margin-top:.3rem}.vm-parent-category.expanded .vm-children-list{display:block}.vm-child-item{display:flex;align-items:center;padding:.35rem .6rem;margin:.15rem 0;background:var(--bg-secondary);border-radius:6px;cursor:pointer;transition:all .2s;border-left:3px solid transparent}a.vm-child-item{text-decoration:none;color:inherit}.vm-child-item:hover{background:var(--bg-primary)}.vm-child-item.active{background:var(--accent);color:var(--bg-primary);border-left-color:var(--accent-success)}.vm-child-name{flex:1;font-size:.85rem}.vm-child-count{background:var(--bg-tertiary);padding:.1rem .4rem;border-radius:8px;font-size:.7rem;margin-left:.3rem}.vm-child-item.active .vm-child-count{background:var(--bg-primary);color:var(--accent)}.vm-main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.vm-main-header{padding:1.5rem;border-bottom:1px solid var(--border);background:var(--bg-secondary)}.vm-breadcrumb{font-size:.85rem;color:var(--text-secondary);margin-bottom:.5rem}.vm-breadcrumb span{color:var(--accent)}.vm-current-title{color:var(--accent);margin-bottom:1rem}.vm-voice-input-section{margin-bottom:.5rem}.vm-voice-input-section input{width:100%;padding:.8rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:1rem;box-sizing:border-box}.vm-voice-input-section input:disabled{opacity:.6;cursor:not-allowed}.vm-action-buttons{display:flex;gap:.35rem;flex-wrap:wrap}.vm-btn-mode{background:var(--accent)!important;color:var(--bg-primary)!important}.vm-btn-mode.vi-mode{background:#4ade80!important}.vm-btn-voice{background:#fbbf24!important;color:var(--bg-primary)!important}.vm-btn-voice.recording{background:var(--accent-danger)!important;animation:vm-pulse 1s infinite}@keyframes vm-pulse{0%,to{opacity:1}50%{opacity:.7}}.vm-btn-add{background:var(--accent-success)!important;color:var(--bg-primary)!important}.vm-btn-add:hover{background:#22c55e!important}.vm-btn{padding:.4rem .7rem;border:none;border-radius:6px;cursor:pointer;font-weight:600;display:flex;align-items:center;gap:.35rem;font-size:.82rem;white-space:nowrap}.vm-toggle-practice{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border)}.vm-toggle-practice:hover{background:var(--bg-secondary)}.vm-toggle-practice.active{background:var(--accent);color:var(--bg-primary);border-color:var(--accent)}.vm-reader-progress-bar{position:fixed;top:0;left:0;right:0;height:4px;background:var(--bg-tertiary);z-index:9999;overflow:hidden}.vm-reader-progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),#4ade80);transition:width .2s ease}.vm-auto-reader{padding:.5rem 1rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border)}.vm-reader-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.vm-reader-header h3{color:var(--accent);font-size:.9rem}.vm-reader-controls{display:flex;gap:.35rem}.vm-reader-btn{padding:.35rem .7rem;border:none;border-radius:6px;cursor:pointer;font-weight:500;font-size:.8rem}.vm-reader-btn.play{background:#4ade80;color:var(--bg-primary)}.vm-reader-btn.stop{background:#ff6b6b;color:#fff}.vm-reader-btn:disabled{opacity:.5;cursor:not-allowed}.vm-reader-options{display:flex;gap:.75rem;flex-wrap:wrap}.vm-reader-options label{display:flex;align-items:center;gap:.25rem;font-size:.82rem;color:var(--text-secondary)}.vm-reader-options select{padding:.3rem .5rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:4px;color:var(--text-primary)}.vm-checkbox-label{cursor:pointer;-webkit-user-select:none;user-select:none}.vm-reader-progress{display:flex;flex-direction:column;align-items:stretch;gap:.5rem;margin-top:.5rem;background:linear-gradient(135deg,var(--bg-secondary),var(--bg-primary));padding:.5rem .8rem;border-radius:8px;border:1px solid var(--accent);box-shadow:0 0 10px #00d9ff26}.vm-reader-status{font-size:.82rem;color:var(--accent);font-weight:600;background:var(--bg-tertiary);padding:.3rem .6rem;border-radius:6px;white-space:nowrap;align-self:flex-start}.vm-reader-card{padding:.6rem .8rem;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border);display:flex;flex-direction:column;gap:.35rem}.vm-reader-card-word{display:flex;align-items:center;gap:.5rem}.vm-reader-card-word strong{color:var(--accent);font-size:1.15rem;text-shadow:0 0 8px rgba(0,217,255,.3)}.vm-reader-pos{font-size:.8rem;color:var(--text-secondary);background:var(--bg-tertiary);padding:.2rem .5rem;border-radius:4px}.vm-reader-phonetic{font-size:.9rem;color:var(--text-secondary)}.vm-reader-definition{font-size:.9rem;color:var(--text-primary);display:flex;flex-direction:column;gap:.2rem}.vm-reader-def-vi{color:var(--accent-success)}.vm-reader-example{font-size:.88rem;font-style:italic;color:var(--text-secondary)}.vm-reader-ex-vi{color:var(--accent-success);font-style:normal}.vm-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;z-index:1100;display:flex;align-items:center;justify-content:center;padding:1rem}.vm-modal{background:var(--bg-secondary);border-radius:12px;width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.vm-modal.vm-review-modal{max-width:720px;overflow-y:auto}.vm-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border)}.vm-modal-header h3{color:var(--accent);font-size:1.4rem;font-weight:600}.vm-modal-header button{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer}.vm-modal-body{padding:1.5rem}.vm-review-hint{font-size:.95rem;color:var(--text-secondary);margin-bottom:1rem}.vm-review-cat-select{margin-bottom:1rem}.vm-review-list{max-height:60vh;overflow-y:auto;margin-bottom:1rem}.vm-review-item{background:var(--bg-tertiary);border-radius:8px;padding:1rem;margin-bottom:1rem;border:1px solid var(--border)}.vm-review-item-header{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.8rem}.vm-review-item-header input[type=checkbox]{width:18px;height:18px;cursor:pointer;margin-right:.3rem;accent-color:var(--accent-success)}.vm-review-word{color:var(--accent);font-weight:600;font-size:1.1rem}.vm-review-pos{background:var(--accent);color:var(--bg-primary);padding:.15rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600}.vm-review-phonetic{color:var(--text-secondary);font-size:.9rem}.vm-review-audio-btn{background:var(--bg-secondary);border:none;color:var(--accent);padding:.3rem .5rem;border-radius:4px;cursor:pointer;margin-left:auto}.vm-review-audio-btn:hover{background:var(--bg-primary)}.vm-review-info{font-size:.9rem;color:var(--text-secondary)}.vm-review-info p{margin:.3rem 0}.vm-review-info strong{color:var(--text-primary)}.vm-review-meaning-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.vm-review-meaning-row input{flex:1;padding:.4rem .6rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:4px;color:var(--accent-success);font-size:.9rem}.vm-review-def-vi{color:var(--accent-success);font-size:.9rem}.vm-review-example{background:var(--bg-secondary);padding:.6rem;border-radius:4px;font-style:italic;margin-top:.5rem;border-left:3px solid var(--accent);color:var(--text-secondary)}.vm-review-example-vi{padding:.3rem .6rem;color:var(--accent-success);font-size:.85rem;font-style:normal;margin-top:.2rem}.vm-review-no-example{color:var(--accent-warning);font-size:.9rem}.vm-review-loading{text-align:center;padding:2rem;color:var(--text-secondary)}.vm-review-loading i{font-size:2rem;color:var(--accent);margin-bottom:1rem;display:block}.vm-review-loading i.fa-spin{animation:vm-spin 1s linear infinite}.vm-upgrade-modal{max-width:480px}.vm-upgrade-desc{color:var(--text-secondary);margin-bottom:1.25rem;font-size:.95rem}.vm-upgrade-packages{display:flex;gap:.75rem;margin-bottom:1.25rem}.vm-upgrade-pkg{flex:1;padding:1rem;background:var(--bg-tertiary);border:2px solid var(--border);border-radius:8px;cursor:pointer;text-align:center;color:var(--text-primary);display:flex;flex-direction:column;gap:.35rem}.vm-upgrade-pkg:hover{border-color:var(--accent)}.vm-upgrade-pkg.selected{border-color:var(--accent);background:#00d9ff1a;color:var(--accent)}.vm-upgrade-pkg-name{font-weight:600;font-size:1.05rem}.vm-upgrade-pkg-desc{font-size:.85rem;color:var(--text-secondary)}.vm-upgrade-payment{margin-top:1rem;padding:1rem;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border)}.vm-upgrade-payment-title{font-weight:600;margin-bottom:.75rem;color:var(--accent)}.vm-upgrade-payment-info p{margin:.4rem 0;font-size:.9rem}.vm-upgrade-transfer-content{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.vm-upgrade-transfer-content code{background:var(--bg-secondary);padding:.3rem .6rem;border-radius:4px;font-size:.88rem;word-break:break-all}.vm-btn-copy{padding:.35rem .6rem;font-size:.8rem;background:var(--accent);color:var(--bg-primary);border:none;border-radius:4px;cursor:pointer}.vm-btn-copy:hover{opacity:.9}.vm-upgrade-payment-note{font-size:.85rem;color:var(--text-secondary);margin-top:1rem}.vm-upgrade-payment-note a{color:var(--accent)}@keyframes vm-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.vm-form-group{margin-bottom:1rem}.vm-form-group label{display:block;color:var(--text-secondary);margin-bottom:.5rem;font-size:.9rem}.vm-form-group input,.vm-form-group textarea,.vm-form-group select{width:100%;padding:.8rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:1rem}.vm-form-group textarea{min-height:60px;resize:vertical}.vm-add-preview{padding:.6rem .8rem;background:var(--bg-tertiary);border-radius:6px;color:var(--text-primary)}.vm-add-preview.vm-def{font-size:.95rem;color:var(--text-secondary)}.vm-add-preview .vm-phonetic{color:var(--accent);font-size:.95rem}.vm-modal-footer{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem}.vm-account-modal .vm-modal-body{max-width:400px}.vm-input-readonly{background:var(--bg-tertiary);cursor:not-allowed;opacity:.9}.vm-account-section{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.vm-account-section h4{font-size:.95rem;color:var(--accent);margin-bottom:.5rem}.vm-account-hint{font-size:.85rem;color:var(--text-secondary);margin-bottom:.5rem}.vm-account-form{display:flex;flex-direction:column;gap:.5rem}.vm-account-form input{padding:.5rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary)}.vm-btn-sm{padding:.4rem .8rem;font-size:.85rem;align-self:flex-start}.vm-account-footer{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.vm-btn-danger{background:var(--accent-danger)!important;border-color:var(--accent-danger)!important;color:#fff!important}.vm-btn-danger:hover{opacity:.9}.vm-vocab-delete-btn{padding:.25rem .5rem;background:#ff6b6b!important;color:#fff!important;border:none;border-radius:4px;cursor:pointer;font-size:.8rem}.vm-vocab-delete-btn:hover{background:#f44!important}.vm-toast{position:fixed;bottom:20px;right:20px;padding:1rem 1.5rem;border-radius:8px;color:#fff;font-weight:500;z-index:2000;animation:vm-toast-in .3s ease}.vm-toast-success{background:var(--accent-success)}.vm-toast-error{background:#ff6b6b}.vm-toast-info{background:var(--accent)}@keyframes vm-toast-in{0%{transform:translate(150%);opacity:0}to{transform:translate(0);opacity:1}}.vm-vocab-container.practice-mode .vm-vocab-meaning-vi{filter:blur(8px);cursor:pointer;transition:filter .2s}.vm-vocab-container.practice-mode .vm-vocab-meaning-vi:hover{filter:blur(0)}.vm-vocab-container.practice-mode .vm-vocab-details p:first-child{filter:blur(8px);cursor:pointer;transition:filter .2s}.vm-vocab-container.practice-mode .vm-vocab-details p:first-child:hover{filter:blur(0)}.vm-vocab-container{flex:1;overflow-y:auto;display:flex;flex-direction:column}.vm-vocab-count-stats{color:var(--text-secondary);font-size:.85em}.vm-vocab-count-bar{padding:.35rem 1rem;font-size:.82rem;color:var(--text-secondary);border-bottom:1px solid var(--border)}.vm-vocab-list{flex:1;padding:.5rem 1rem;display:flex;flex-direction:column;gap:.3rem}.vm-vocab-item{background:var(--bg-secondary);border-radius:6px;overflow:hidden;transition:all .2s}.vm-vocab-item.reading{border:2px solid var(--accent);box-shadow:0 0 15px #58a6ff4d}.vm-vocab-item.learned{opacity:.65}.vm-vocab-learned-check{display:flex;align-items:center;gap:.4rem;cursor:pointer;margin-right:.3rem}.vm-vocab-learned-check input{cursor:pointer}.vm-vocab-check-label{font-size:.8rem;color:var(--text-secondary)}.vm-vocab-header{display:flex;align-items:center;padding:.5rem .8rem;cursor:pointer;gap:.5rem}.vm-vocab-number{color:var(--text-secondary);font-size:.8rem;min-width:24px}.vm-vocab-word{font-weight:600;color:var(--accent);font-size:.95rem}.vm-vocab-phonetic-inline{font-weight:400;color:var(--text-secondary);font-size:.85rem;margin-left:.2rem}.vm-vocab-phonetic{color:var(--text-secondary);font-size:.85rem}.vm-vocab-details .vm-vocab-phonetic{margin:.2rem 0;font-size:.8rem}.vm-vocab-actions{display:flex;gap:.35rem;margin-top:.5rem;flex-wrap:wrap}.vm-vocab-pos{background:var(--accent);color:var(--bg-primary);padding:.15rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600}.vm-vocab-meaning-vi{color:var(--accent-success);font-size:.88rem;margin-left:auto;margin-right:.5rem}.vm-vocab-audio-btn{background:var(--bg-tertiary);border:none;color:var(--accent);padding:.25rem .4rem;border-radius:4px;cursor:pointer;font-size:.8rem}.vm-vocab-audio-btn:hover{background:var(--bg-primary)}.vm-vocab-expand{color:var(--text-secondary);transition:transform .2s}.vm-vocab-item.expanded .vm-vocab-expand{transform:rotate(180deg)}.vm-vocab-details{display:none;padding:0 .8rem .6rem;border-top:1px solid var(--border)}.vm-vocab-item.expanded .vm-vocab-details{display:block}.vm-vocab-details p{margin:.25rem 0}.vm-vocab-definition{color:var(--text-secondary);margin:.35rem 0;font-size:.88rem}.vm-vocab-example{background:var(--bg-tertiary);padding:.5rem .6rem;border-radius:4px;font-style:italic;color:var(--text-secondary);border-left:2px solid var(--accent);font-size:.88rem}.vm-vocab-example-vi{color:var(--accent-success);font-size:.85rem;margin-top:.2rem;padding-left:.4rem}.vm-vocab-definition-vi{color:var(--text-secondary);font-size:.85rem;margin:.25rem 0}.vm-btn-edit{background:#38bdf8;color:var(--bg-primary);border:none;padding:.25rem .5rem;border-radius:4px;font-size:.8rem;cursor:pointer;font-weight:500;display:inline-flex;align-items:center;gap:.4rem}.vm-btn-edit:hover{background:#0ea5e9}.vm-vocab-action-btn{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);padding:.25rem .5rem;border-radius:4px;cursor:pointer;font-size:.78rem;display:inline-flex;align-items:center;gap:.3rem}.vm-vocab-action-btn:hover:not(:disabled){background:var(--bg-secondary)}.vm-vocab-action-btn:disabled{opacity:.6;cursor:not-allowed}.vm-pagination{display:flex;justify-content:center;align-items:center;gap:.4rem;padding:.5rem 1rem;border-top:1px solid var(--border)}.vm-pagination button{padding:.35rem .7rem;font-size:.85rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);cursor:pointer}.vm-pagination button:disabled{opacity:.5;cursor:not-allowed}.vm-pagination span{color:var(--text-secondary)}.vm-empty-state{text-align:center;padding:2rem;color:var(--text-secondary)}.vm-empty-state i{font-size:2.5rem;margin-bottom:.75rem;color:var(--accent)}.vm-container{--bg-primary: #0f0f23;--bg-secondary: #1a1a2e;--bg-tertiary: #16213e;--text-primary: #e4e4e7;--text-secondary: #a1a1aa;--accent: #00d9ff;--accent-hover: #00b8d4;--accent-success: #4ade80;--accent-danger: #ff6b6b;--accent-warning: #fbbf24;--border: #27272a}.vm-container .vm-sidebar{background:var(--bg-secondary);border-color:var(--border)}.vm-container .vm-parent-header{background:var(--bg-tertiary)}.vm-container .vm-parent-header:hover{background:var(--bg-primary)}.vm-container .vm-main-header{background:var(--bg-secondary)}.vm-container .vm-child-item.active{background:var(--accent);color:var(--bg-primary)}.vm-container .vm-vocab-item{background:var(--bg-secondary)}.vm-container .vm-vocab-word{color:var(--accent)}.vm-container .vm-vocab-pos{background:var(--accent);color:var(--bg-primary)}@media (max-width: 900px){.vm-sidebar{width:260px}}.vm-sidebar-overlay,.vm-mobile-sidebar-toggle{display:none}@media (max-width: 600px){.vm-sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000}.vm-sidebar-overlay.show{display:block}.vm-mobile-sidebar-toggle{display:flex;align-items:center;justify-content:center;position:fixed;bottom:20px;left:20px;width:50px;height:50px;border-radius:50%;background:var(--accent);color:var(--bg-primary);border:none;font-size:1.2rem;cursor:pointer;z-index:999;box-shadow:0 4px 15px #00d9ff66}.vm-mobile-sidebar-toggle:hover{background:var(--accent-hover)}.vm-sidebar{position:fixed;left:-100%;top:0;bottom:0;width:85%;max-width:300px;z-index:1001;transition:left .3s}.vm-sidebar.show{left:0}.vm-sidebar-close{display:flex;align-items:center;justify-content:center}.vm-main-header{padding:1rem}.vm-vocab-header{padding:.6rem;gap:.4rem;flex-wrap:wrap}.vm-vocab-word{font-size:.95rem}.vm-vocab-phonetic{font-size:.8rem}.vm-vocab-meaning-vi{font-size:.85rem;margin-left:0;margin-right:.5rem}.vm-vocab-number{min-width:24px;font-size:.8rem}.vm-vocab-pos{font-size:.7rem;padding:.1rem .4rem}.vm-vocab-list{padding:.5rem}}:root{--bg-primary: #0d1117;--bg-secondary: #161b22;--bg-tertiary: #21262d;--text-primary: #e6edf3;--text-secondary: #8b949e;--accent: #58a6ff;--accent-hover: #79b8ff;--success: #3fb950;--border: #30363d;--radius: 12px;--font-sans: "DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", monospace}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased}#root{min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover);text-decoration:underline}button{font-family:inherit;cursor:pointer;border:none}input,textarea{font-family:inherit}
