@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--radius-lg:.5rem;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--ease-out:cubic-bezier(0, 0, .2, 1);--ease-in-out:cubic-bezier(.4, 0, .2, 1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.start{inset-inline-start:var(--spacing)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.h-full{height:100%}.min-h-screen{min-height:100vh}.w-full{width:100%}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.border{border-style:var(--tw-border-style);border-width:1px}.capitalize{text-transform:capitalize}.uppercase{text-transform:uppercase}.italic{font-style:italic}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.grayscale{--tw-grayscale:grayscale(100%);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}}:root{--bg:#f5f2ed;--surface:#faf8f4;--surface-2:#f0ede7;--border:#e4dfd6;--border-2:#d3cdc3;--ink:#1c1a17;--ink-2:#4a4641;--ink-3:#8c8680;--sage:#3d7a70;--sage-light:#eaf2f0;--sage-dark:#2d6058;--amber:#c9872a;--amber-light:#fdf3e3;--rose:#b05a5a;--rose-light:#fceaea;--radius:12px;--radius-lg:18px;--shadow:0 2px 12px #1c1a1712;--shadow-lg:0 8px 32px #1c1a171a;--sidebar-w:220px;--transition:.18s ease;--logo-highlight:#8fb1ab}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{width:100%;font-size:16px}body{background:var(--bg);color:var(--ink);width:100%;min-height:100vh;font-family:DM Sans,sans-serif;overflow-x:hidden}#root{flex:1;width:100%;min-height:100vh;display:flex}button{cursor:pointer;font:inherit;background:0 0;border:none}input,textarea,select{font:inherit}textarea{resize:vertical}ul{list-style:none}svg{fill:none;stroke:currentColor;stroke-width:1.8px;stroke-linecap:round;stroke-linejoin:round;width:18px;height:18px}.auth-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10000;background:#000c;flex-direction:column;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:420px;box-shadow:var(--shadow-lg);padding:40px 20px;animation:.4s cubic-bezier(.34,1.56,.64,1) popIn}@keyframes popIn{0%{opacity:0;transform:scale(.9)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.auth-title{color:var(--ink);text-align:center;margin-bottom:8px;font-family:Lora,serif;font-size:1.8rem;font-weight:600}.auth-subtitle{text-align:center;color:var(--ink-3);margin-bottom:28px;font-size:.9rem}.auth-google-btn-custom{background:var(--ink);border:2px solid var(--bg);width:100%;color:var(--bg);cursor:pointer;border-radius:50px;justify-content:center;align-items:center;gap:12px;margin-bottom:24px;padding:12px 24px;font-size:1.05rem;font-weight:600;transition:all .2s;display:flex;box-shadow:0 4px 6px #0000001a}.auth-google-btn-custom:hover{opacity:.9;transform:translateY(-1px)}.auth-divider{text-align:center;color:var(--ink-3);align-items:center;margin-bottom:24px;font-size:.85rem;display:flex}.auth-divider:before,.auth-divider:after{content:"";border-bottom:1px solid var(--border-2);flex:1}.auth-divider:not(:empty):before{margin-right:.8em}.auth-divider:not(:empty):after{margin-left:.8em}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);z-index:100;flex-direction:column;min-height:100vh;padding:28px 16px 20px;display:flex;position:fixed;top:0;left:0}.logo{align-items:center;gap:10px;padding:0 4px 32px;display:flex}.logo-text{color:var(--ink);font-family:Lora,serif;font-size:1.1rem;font-weight:600}.nav-links{flex-direction:column;flex:1;gap:4px;display:flex}.nav-btn{border-radius:var(--radius);width:100%;color:var(--ink-2);transition:background var(--transition), color var(--transition);text-align:left;align-items:center;gap:10px;padding:10px 12px;font-size:.9rem;font-weight:400;display:flex;position:relative}.nav-btn svg{opacity:.7;width:16px;height:16px}.nav-btn:hover{background:var(--surface-2);color:var(--ink)}.nav-btn.active{background:var(--sage-light);color:var(--sage-dark);font-weight:500}.nav-btn.active svg{opacity:1}.nav-badge{background:var(--sage);color:#fff;border-radius:20px;margin-left:auto;padding:1px 6px;font-size:.72rem;font-weight:500;display:none}.nav-badge.visible{display:block}.sidebar-footer{border-top:1px solid var(--border);flex-direction:column;gap:8px;padding-top:16px;display:flex}.action-btn-small{color:var(--ink-2);border-radius:6px;align-items:center;gap:8px;padding:6px 10px;font-size:.8rem;transition:background .2s;display:flex}.action-btn-small:hover{background:var(--surface-2);color:var(--ink)}.action-btn-small svg{width:14px;height:14px}.mobile-header{background:var(--surface);border-bottom:1px solid var(--border);z-index:100;flex-direction:column;padding:16px 16px 0;display:none;position:sticky;top:0}.mobile-header .logo{padding-bottom:14px}.mobile-nav{gap:2px;padding-bottom:12px;display:flex;overflow-x:auto}.mobile-nav .nav-btn{white-space:nowrap;flex-direction:column;flex-shrink:0;gap:4px;padding:8px 14px;font-size:.75rem}.mobile-nav .nav-btn svg{width:18px;height:18px}.main-content{margin-left:var(--sidebar-w);min-height:100vh;width:calc(100% - var(--sidebar-w));flex:1;padding:40px;transition:all .3s}.view{animation:.22s fadeIn;display:none}.view.active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.view-layout{grid-template-columns:1fr;align-items:stretch;gap:40px;display:grid}@media (min-width:1100px){.view-layout:has(.view-right){grid-template-columns:1fr 280px}}.view-header{margin-bottom:28px}.view-title{color:var(--ink);margin-bottom:6px;font-family:Lora,serif;font-size:2rem;font-weight:600;line-height:1.2}.view-subtitle{color:var(--ink-3);font-size:.95rem}.review-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:32px 36px;position:relative}.card-meta{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.card-tag{background:var(--surface-2);border:1px solid var(--border);color:var(--ink-3);text-transform:uppercase;letter-spacing:.05em;border-radius:20px;padding:3px 12px;font-size:.78rem}.card-count{color:var(--ink-3);font-size:.85rem}.card-word{color:var(--ink);flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:28px;font-family:Lora,serif;font-size:2rem;font-weight:600;line-height:1.3;display:flex}.card-reveal-zone{min-height:80px}.reveal-btn{color:var(--sage);border:1px dashed var(--sage);border-radius:var(--radius);transition:all var(--transition);padding:10px 20px;font-size:.9rem}.reveal-btn:hover{background:var(--sage-light)}.card-answer{animation:.2s fadeIn}.card-meaning{color:var(--ink-2);margin-bottom:12px;font-size:1.05rem;line-height:1.6}.card-example{color:var(--ink-3);border-left:3px solid var(--border-2);padding-left:14px;font-family:Lora,serif;font-size:.95rem;font-style:italic}.rating-bar{border-top:1px solid var(--border);gap:12px;margin-top:28px;padding-top:24px;animation:.2s fadeIn;display:flex}.rating-btn{border-radius:var(--radius);cursor:pointer;border:1px solid #0000;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:14px 8px;font-size:.95rem;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.rating-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #0000000f}.rating-btn:active:not(:disabled){box-shadow:none;transform:translateY(0)}.rating-btn:disabled{opacity:.6;cursor:not-allowed}.rating-btn.again{background:var(--surface-2);color:var(--ink-2);border-color:var(--border)}.rating-btn.again:hover:not(:disabled){background:var(--border);border-color:var(--border-2)}.rating-btn.hard{background:var(--rose-light);color:var(--rose);border-color:var(--rose)}.rating-btn.hard:hover:not(:disabled){background:#f5d6d6}.rating-btn.medium{background:var(--amber-light);color:var(--amber);border-color:var(--amber)}.rating-btn.medium:hover:not(:disabled){background:#fde8c0}.rating-btn.easy{background:var(--sage-light);color:var(--sage-dark);border-color:var(--sage)}.rating-btn.easy:hover:not(:disabled){background:#d4e6d6}.empty-state,.session-complete{text-align:center;padding:60px 40px}.empty-icon,.complete-icon{margin-bottom:16px;font-size:2.5rem;display:block}.empty-state h2,.session-complete h2{margin-bottom:8px;font-family:Lora,serif;font-size:1.5rem}.empty-state p,.session-complete p{color:var(--ink-3);margin-bottom:24px;font-size:.95rem}.review-right{flex-direction:column;gap:16px;display:flex;position:sticky;top:40px}.streak-widget{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow);flex-direction:column;justify-content:center;align-items:center;padding:24px;display:flex}.streak-number{color:var(--sage-dark);font-family:Lora,serif;font-size:2.8rem;font-weight:600;line-height:1}.streak-label{color:var(--ink-3);margin-top:4px;font-size:.85rem}.progress-widget{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:24px;display:flex}.progress-ring-wrap{width:80px;height:80px;position:relative}.progress-ring{width:80px;height:80px;transform:rotate(-90deg)}.ring-bg{fill:none;stroke:var(--border);stroke-width:6px}.ring-fill{fill:none;stroke:var(--sage);stroke-width:6px;stroke-linecap:round;stroke-dasharray:201;stroke-dashoffset:201px;transition:stroke-dashoffset .5s}.progress-center{color:var(--ink-2);justify-content:center;align-items:center;font-size:.8rem;font-weight:500;display:flex;position:absolute;inset:0}.progress-label{color:var(--ink-3);font-size:.83rem}.audio-btn{background:var(--sage-light);color:var(--sage-dark);border:1px solid var(--sage);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:inline-flex}.audio-btn:hover{background:var(--sage);color:#fff;transform:scale(1.05)}.audio-btn svg{stroke-width:2px;width:16px;height:16px}.category-badge{color:#475569;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;text-overflow:ellipsis;vertical-align:middle;background:#e2e8f0;border-radius:12px;max-width:130px;padding:2px 8px;font-size:.75rem;font-weight:500;display:inline-block;overflow:hidden}.flashcard-scene{perspective:1000px;cursor:pointer;width:100%;height:340px;margin:0 auto;position:relative}.flashcard{width:100%;height:100%;transform-style:preserve-3d;transition:transform .6s cubic-bezier(.4,.2,.2,1);position:relative}.flashcard.is-flipped{transform:rotateY(180deg)}.flashcard-face{backface-visibility:hidden;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;height:100%;box-shadow:var(--shadow);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:32px;display:flex;position:absolute}.flashcard-back{background:var(--sage-light);border-color:var(--sage);transform:rotateY(180deg)}.fc-word{color:var(--ink);flex-wrap:wrap;justify-content:center;align-items:center;gap:12px;font-family:Lora,serif;font-size:2.2rem;font-weight:600;line-height:1.3;display:flex}.fc-meaning{color:var(--sage-dark);font-size:1.4rem;font-weight:500;line-height:1.4}.fc-example{color:var(--ink-2);max-width:90%;font-size:1.05rem;font-style:italic;line-height:1.6}.fc-controls{flex-wrap:wrap;justify-content:center;gap:12px;margin-top:24px;display:flex}.dictation-icon{cursor:pointer;color:var(--sage);margin-bottom:16px;font-size:4rem;transition:transform .2s}.dictation-icon:hover{transform:scale(1.1)}.dictation-hint{color:var(--ink-3);margin-bottom:20px;font-size:.9rem}.typing-zone{width:100%;max-width:300px;margin-top:24px}.typing-input{text-align:center;border:2px solid var(--border);border-radius:var(--radius);outline:none;width:100%;padding:14px;font-size:1.1rem;transition:border-color .2s}.typing-input:focus{border-color:var(--sage)}.typing-input.error{border-color:var(--rose);background:var(--rose-light);color:var(--rose);animation:.4s shake}.typing-input.success{border-color:var(--sage);background:var(--sage-light);color:var(--sage-dark)}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.btn-primary{background:var(--sage);color:#fff;border-radius:var(--radius);transition:all var(--transition);justify-content:center;align-items:center;gap:8px;padding:11px 24px;font-size:.9rem;font-weight:500;display:inline-flex}.btn-primary:hover{background:var(--sage-dark);transform:translateY(-1px);box-shadow:0 4px 14px #3d7a7040}.btn-ghost{border:1px solid var(--border-2);color:var(--ink-2);border-radius:var(--radius);transition:all var(--transition);background:0 0;justify-content:center;align-items:center;padding:11px 24px;font-size:.9rem;font-weight:400;display:inline-flex}.btn-ghost:hover{background:var(--surface-2);border-color:var(--ink-3)}.btn-danger{color:var(--rose);border-color:#f0cccc}.btn-danger:hover{background:var(--rose-light);border-color:var(--rose)}.form-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:28px 32px}.form-group{margin-bottom:18px}.form-label{color:var(--ink-2);margin-bottom:6px;font-size:.85rem;font-weight:500;display:block}.required{color:var(--rose)}.form-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--ink);transition:border-color var(--transition), box-shadow var(--transition);outline:none;padding:10px 14px;font-size:.95rem}.form-input:focus{border-color:var(--sage);box-shadow:0 0 0 3px #3d7a701f}select.form-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238c8680' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;padding-right:40px}html[data-theme=dark] select.form-input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23707070' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E")}.form-textarea{line-height:1.5}.form-actions{flex-wrap:wrap;gap:10px;margin-top:22px;display:flex}.form-feedback{color:var(--sage-dark);min-height:20px;margin-top:14px;font-size:.88rem;transition:opacity .3s}.add-right{flex-direction:column;gap:16px;display:flex}.tip-card{background:var(--amber-light);border-radius:var(--radius-lg);border:1px solid #f0dfb8;padding:20px 22px}.tip-title{color:var(--amber);margin-bottom:10px;font-size:.9rem;font-weight:500}.tip-list{flex-direction:column;gap:8px;display:flex}.tip-list li{color:var(--ink-2);padding-left:14px;font-size:.85rem;line-height:1.6;position:relative}.tip-list li:before{content:"Ă˘â‚¬â€ś";color:var(--amber);position:absolute;left:0}.recent-added{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px}.recent-title{color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px;font-size:.8rem;font-weight:500}.recent-item{color:var(--ink-2);border-bottom:1px solid var(--border);padding:5px 0;font-size:.88rem}.recent-item:last-child{border-bottom:none}.library-controls{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.search-input{flex:1;min-width:160px}.select-input{width:auto}.library-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));align-items:stretch;gap:14px;margin-top:24px;padding-bottom:80px;display:grid}.library-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition);box-shadow:var(--shadow);flex-direction:column;min-height:148px;padding:15px 18px;display:flex;position:relative}.library-card:hover{border-color:var(--sage);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.library-card.selectable{border-style:dashed;padding-left:48px}.library-card.selected{border-color:var(--rose);background:var(--rose-light);border-style:solid}.card-checkbox{border:2px solid var(--border-2);pointer-events:none;border-radius:4px;width:20px;height:20px;display:none;position:absolute;top:22px;left:16px}.library-card.selectable .card-checkbox{display:block}.library-card.selected .card-checkbox{background:var(--rose);border-color:var(--rose)}.library-card.selected .card-checkbox:after{content:"";border:2px solid #fff;border-width:0 2px 2px 0;width:5px;height:10px;position:absolute;top:1px;left:5px;transform:rotate(45deg)}.bulk-action-bar{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border);z-index:1000;align-items:center;gap:16px;padding:16px 24px;display:none;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.bulk-action-bar.visible{animation:.3s fadeUp;display:flex}@keyframes fadeUp{0%{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%)}}.lib-word{color:var(--ink);justify-content:space-between;align-items:center;gap:8px;margin-bottom:5px;font-family:Lora,serif;font-size:1rem;font-weight:600;display:flex}.lib-meaning{color:var(--ink-3);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;height:2.3rem;font-size:.78rem;line-height:1.5;display:-webkit-box;overflow:hidden}.lib-meta{border-top:1px solid #ffffff14;justify-content:space-between;align-items:center;margin-top:auto;padding-top:12px;display:flex}.lib-interval{color:var(--ink-3);font-size:.78rem}.lib-due-dot{background:var(--border-2);border-radius:50%;width:8px;height:8px}.lib-due-dot.due{background:var(--sage)}.lib-due-dot.overdue{background:var(--rose)}.reader-content{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--ink);box-shadow:var(--shadow);padding:32px;font-family:Lora,serif;font-size:1.15rem;line-height:1.8}.reader-sentence{border-radius:4px;transition:background .2s}.reader-sentence:hover{background:var(--sage-light)}.reader-word{cursor:pointer;border-bottom:1px solid #0000;transition:color .2s,border-color .2s}.reader-word:hover{color:var(--sage-dark);border-bottom-color:var(--sage);font-weight:500}.card-notes{color:var(--ink-3);border-top:1px dashed var(--border-2);margin-top:12px;padding-top:12px;font-size:.9rem}.fc-notes{color:var(--ink-3);border-top:1px dashed var(--sage);max-width:90%;margin-top:16px;margin-left:auto;margin-right:auto;padding-top:12px;font-size:.85rem}.calendar-widget{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:24px}.cal-nav{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.cal-month-label{color:var(--ink);font-family:Lora,serif;font-size:1rem;font-weight:600}.cal-grid-header{text-align:center;color:var(--ink-3);letter-spacing:.04em;grid-template-columns:repeat(7,1fr);margin-bottom:8px;font-size:.75rem;font-weight:500;display:grid}.cal-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.cal-day{aspect-ratio:1;cursor:pointer;transition:all var(--transition);color:var(--ink-2);border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:2px;font-size:.82rem;display:flex;position:relative}.cal-day:hover{background:var(--surface-2)}.cal-day.other-month{color:var(--border-2)}.cal-day.today{background:var(--sage-light);color:var(--sage-dark);font-weight:600}.cal-day.selected{background:var(--sage);color:#fff}.cal-day.selected .cal-dot{background:#fff9}.cal-dot{background:var(--sage);border-radius:50%;width:5px;height:5px}.cal-day.past .cal-dot{background:var(--border-2)}.cal-day-num{line-height:1}.calendar-right{position:sticky;top:40px}.cal-detail{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);min-height:200px;padding:22px}.cal-detail-date{color:var(--ink);border-bottom:1px solid var(--border);margin-bottom:14px;padding-bottom:12px;font-family:Lora,serif;font-size:1rem;font-weight:600}.cal-detail-item{color:var(--ink-2);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:7px 0;font-size:.88rem;display:flex}.cal-detail-item:last-child{border-bottom:none}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#1c1a1759;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:480px;box-shadow:var(--shadow-lg);padding:28px 32px;animation:.2s fadeIn}.modal-header{justify-content:space-between;align-items:center;margin-bottom:22px;display:flex}.modal-title{font-family:Lora,serif;font-size:1.2rem;font-weight:600}.modal-actions{flex-wrap:wrap;gap:10px;margin-top:22px;display:flex}#print-area{display:none}@media print{body{background:#fff!important;height:auto!important;display:block!important;overflow:visible!important}body>:not(#print-area){display:none!important}#print-area{color:#000;width:100%;padding:10px;position:relative;display:block!important}.print-word{color:#000;margin-bottom:4px;font-size:14pt;font-weight:700}.print-meaning{color:#333;margin-bottom:4px;font-size:12pt}.print-example{color:#555;border-bottom:1px solid #ccc;margin-bottom:15px;padding-bottom:10px;font-size:11pt;font-style:italic}}@media (max-width:900px){.view-layout{grid-template-columns:1fr}}@media (max-width:1100px){:root{--sidebar-w:190px}.main-content{padding:30px 24px}.view-layout{gap:24px}}@media (max-width:720px){.sidebar{display:none}.mobile-header{display:flex}body{flex-direction:column}.main-content{margin-left:0;padding:20px 16px}.view-title{font-size:1.6rem}.review-card{padding:22px 20px}.card-word{font-size:1.6rem}.rating-bar{gap:8px}.form-card{padding:20px}.library-grid{grid-template-columns:1fr}.modal{padding:22px 20px}.calendar-widget{padding:16px}.bulk-action-bar{flex-wrap:wrap;justify-content:center;width:90%}.flashcard-scene{height:380px}}@media (max-width:900px){.view-layout{grid-template-columns:1fr}.main-content{padding:30px}.review-right,.add-right,.calendar-right{flex-flow:wrap;position:static}.streak-widget,.progress-widget{flex:1;min-width:200px}}@media (max-width:768px){.desktop-hide{display:flex!important}.mobile-hide{display:none!important}body{padding-bottom:70px}.main-content{width:100%;margin-left:0;padding:70px 15px 20px}:is(.view-layout,.view-layout:has(.library-grid),.view-layout:has(.flashcard-scene)){flex-direction:column;align-items:stretch;gap:20px;width:100%;max-width:100%;margin:0;display:flex}.view-left,.view-right{width:100%}.review-right,.add-right{flex-direction:row;justify-content:space-between;gap:10px;width:100%}.streak-widget,.progress-widget{flex:1;min-width:0;max-width:none;padding:16px}.badge-pill{padding:1px 5px;font-size:.6rem;position:absolute;top:2px;right:50%;transform:translate(20px);margin:0!important}.view-header{text-align:center}.view-title{font-size:1.6rem}.mobile-topbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:1000;justify-content:space-between;align-items:center;width:100%;height:60px;padding:0 20px;position:fixed;top:0;left:0}.sidebar{background:var(--surface);border-top:1px solid var(--border);z-index:1000;border-right:none;flex-direction:row;justify-content:space-between;align-items:center;width:100%;height:65px;min-height:65px;margin:0;padding:0 5px;display:flex;position:fixed;top:auto;bottom:0;left:0}.nav-links{white-space:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-direction:row;justify-content:flex-start;width:100%;padding:0 10px;overflow:auto hidden}.nav-links::-webkit-scrollbar{display:none}.nav-btn{text-align:center;background:0 0;flex-direction:column;flex-shrink:0;gap:3px;min-width:68px;padding:6px 4px}.nav-btn:hover{background:0 0}.nav-btn.active{color:var(--sage);background:0 0}.nav-btn svg{opacity:1;width:20px;height:20px;margin:0 auto}.nav-text{white-space:nowrap;font-size:.55rem;font-weight:500}.badge-pill{padding:1px 5px;font-size:.6rem;position:absolute;top:0;right:5px}.form-card,.review-card,.cal-detail,.reader-content,.calendar-widget{border-radius:var(--radius);width:100%;padding:20px 15px}.library-grid{grid-template-columns:1fr}.form-actions{flex-direction:column}.btn-primary,.btn-ghost{width:100%}.library-controls{grid-template-columns:1fr 1fr;gap:8px!important;display:grid!important}.search-input{order:-1;grid-column:span 2}.select-input{padding:8px 10px!important;font-size:.85rem!important}.empty-state{padding:30px 20px!important}.empty-icon{margin-bottom:10px!important;font-size:1.8rem!important}.empty-state h2{font-size:1.1rem!important}.empty-state p{font-size:.85rem!important}}.mobile-modal-overlay{z-index:9999;background:#0006;position:fixed;inset:0}.mobile-modal-content{background:var(--surface);border-radius:24px 24px 0 0;width:100%;margin-bottom:65px;padding:24px;animation:.3s ease-out slideUp;position:fixed;bottom:0;left:0;box-shadow:0 -10px 40px #0000001a}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@media (max-width:640px){.lp-nav-links{display:none!important}.review-right{flex-direction:column!important;gap:12px!important}}.mobile-topbar{display:none}@media (max-width:768px){.mobile-topbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:200;justify-content:space-between;align-items:center;width:100%;height:56px;padding:0 16px;display:flex;position:fixed;top:0;left:0}.mobile-topbar .logo-text{color:var(--ink);font-family:Lora,serif;font-size:1rem;font-weight:600}}@media (max-width:640px){.url-input-group{flex-direction:column}.url-input-group .form-input,.url-input-group .btn-primary{flex:auto!important;width:100%!important}.url-fetch-box{padding:12px!important}.reader-article{--reader-padding:24px 16px!important}.reader-article h1{font-size:1.6rem!important}.reader-article p{margin-bottom:1.4em!important;font-size:1.05rem!important;line-height:1.65!important}}.recharts-rectangle:focus,.recharts-bar-rectangle:focus,.recharts-bar-rectangles path:focus,.recharts-wrapper:focus,.recharts-surface:focus,.recharts-sector:focus{box-shadow:none!important;outline:none!important}html[data-theme=dark]{--bg:#121212;--surface:#1e1e1e;--surface-2:#282828;--border:#333;--border-2:#444;--ink:#e2e2e2;--ink-2:#a0a0a0;--ink-3:#707070;--sage:#4da694;--sage-light:#1a2b27;--sage-dark:#a8d5cc;--amber:#d69e4e;--amber-light:#2d2416;--rose:#d66d6d;--rose-light:#2d1818;--shadow:0 4px 16px #0006;--shadow-lg:0 8px 32px #0009;--logo-highlight:#eaf2f0}.xp-giant-popup{animation:1.2s ease-out forwards popAndFade}@keyframes popAndFade{0%{opacity:0;transform:translate(-50%,-20%)scale(.6)}20%{opacity:1;transform:translate(-50%,-50%)scale(1.1)}80%{opacity:1;transform:translate(-50%,-50%)scale(1)}to{opacity:0;transform:translate(-50%,-70%)scale(.8)}}:root{--topbar-h:64px;--sidebar-collapsed-w:80px}.topbar{top:0;right:0;left:var(--sidebar-w);height:var(--topbar-h);background:var(--surface);border-bottom:1px solid var(--border);z-index:90;justify-content:space-between;align-items:center;padding:0 32px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed}.topbar.sidebar-collapsed{left:var(--sidebar-collapsed-w)}.topbar-left{align-items:center;gap:16px;display:flex}.topbar-right{align-items:center;gap:20px;display:flex}.toggle-btn{width:40px;height:40px;color:var(--ink-2);border-radius:10px;justify-content:center;align-items:center;transition:all .2s;display:flex}.toggle-btn:hover{background:var(--surface-2);color:var(--ink)}.profile-trigger{background:var(--surface-2);border:1px solid var(--border);cursor:pointer;border-radius:50px;align-items:center;gap:12px;padding:6px 12px;transition:all .2s;display:flex}.profile-trigger:hover{border-color:var(--sage);background:var(--surface);box-shadow:var(--shadow)}.profile-circle-small{background:var(--border);border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:1rem;display:flex;overflow:hidden}.profile-circle-small img{object-fit:cover;width:100%;height:100%}.sidebar{transition:width .3s cubic-bezier(.4,0,.2,1),padding .3s}.sidebar.collapsed{width:var(--sidebar-collapsed-w);padding:28px 12px 20px}.sidebar.collapsed .logo-text,.sidebar.collapsed .nav-text,.sidebar.collapsed .badge-pill,.sidebar.collapsed .sidebar-level-info,.sidebar.collapsed .user-footer-text{display:none!important}.sidebar.collapsed .nav-btn{justify-content:center;padding:12px}.sidebar.collapsed .nav-btn svg{width:20px;height:20px;margin:0}.sidebar.collapsed .logo{justify-content:center;padding-left:0;padding-right:0}.main-content{margin-top:var(--topbar-h);padding-top:32px}.main-content.sidebar-collapsed{margin-left:var(--sidebar-collapsed-w);width:calc(100% - var(--sidebar-collapsed-w))}@media (max-width:768px){.topbar{display:none}.main-content,.main-content.sidebar-collapsed{width:100%;margin-top:0;margin-left:0;padding-top:80px;padding-bottom:90px}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}
