.install-prompt{background:var(--color-primary-dark);color:#fff;z-index:500;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 16px #1b433233}.install-prompt__text{flex:1;font-size:14px}.install-prompt__actions{gap:8px;display:flex}.install-prompt__btn{border-radius:var(--radius-sm);transition:opacity var(--duration-fast);padding:8px 14px;font-size:14px;font-weight:600}.install-prompt__btn--install{background:var(--color-primary-subtle);color:#fff}.install-prompt__btn--install:hover{opacity:.9}.install-prompt__btn--dismiss{color:#fff9;background:0 0}.install-prompt__btn--dismiss:hover{color:#fffc}.install-prompt__safari{font-size:13px;line-height:1.4}@media (width>=769px){.install-prompt{display:none}}.update-banner{background:var(--color-primary-dark);color:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:2000;animation:update-slide-up .3s var(--ease-out);border:1px solid #ffffff1a;align-items:center;gap:12px;padding:12px 20px;font-size:14px;font-weight:600;display:flex;position:fixed;bottom:16px;left:50%;transform:translate(-50%)}@keyframes update-slide-up{0%{opacity:0;transform:translate(-50%)translateY(20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.update-banner__btn{color:var(--color-primary-dark);border-radius:var(--radius-sm);cursor:pointer;transition:opacity var(--duration-fast);background:#fff;padding:6px 14px;font-size:13px;font-weight:700}.update-banner__btn:hover{opacity:.9}.login{background:linear-gradient(160deg,#1b4332 0%,#2d6a4f 40%,#40916c 100%);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative;overflow:hidden}.login:before{content:"";pointer-events:none;background:radial-gradient(at 20%,#52b78826 0%,#0000 50%),radial-gradient(at 80% 20%,#d4a3731a 0%,#0000 40%);position:absolute;inset:0}.login__title{font-family:var(--font-display);color:#fff;letter-spacing:.01em;animation:login-title-enter .6s var(--ease-out) both;align-items:center;margin-bottom:8px;font-size:48px;font-weight:400;display:flex;position:relative}@keyframes login-title-enter{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.login__title-icon{cursor:default;filter:brightness(0)invert();width:52px;height:52px;margin-right:-2px}.login__subtitle{color:#ffffffa6;letter-spacing:.02em;animation:login-title-enter .6s var(--ease-out) .1s both;margin-bottom:36px;font-size:16px;font-weight:400;position:relative}.login__google-btn{min-height:44px;animation:login-title-enter .6s var(--ease-out) .2s both;margin-bottom:48px;position:relative}.login__faq{width:100%;max-width:480px;animation:login-title-enter .6s var(--ease-out) .3s both;position:relative}.login__faq-title{font-family:var(--font-display);color:#fffc;margin-bottom:14px;font-size:20px;font-weight:400}.login__faq-item{-webkit-backdrop-filter:blur(8px);border-radius:var(--radius-md);transition:background var(--duration-fast);background:#ffffff14;border:1px solid #ffffff1a;margin-bottom:8px;overflow:hidden}.login__faq-item:hover{background:#ffffff1f}.login__faq-question{text-align:left;color:#ffffffe6;cursor:pointer;justify-content:space-between;align-items:center;width:100%;padding:14px 16px;font-size:15px;font-weight:600;display:flex}.login__faq-question:hover{background:0 0}.login__faq-arrow{transition:transform .25s var(--ease-out);color:#ffffff80;font-size:12px}.login__faq-arrow--open{transform:rotate(180deg)}.login__faq-answer{color:#fff9;padding:0 16px 14px;font-size:14px;line-height:1.6}.search-bar,.search-bar__input-wrap{position:relative}.search-bar__icon{color:#fff6;pointer-events:none;font-size:14px;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.search-bar__input{border-radius:var(--radius-sm);color:#fff;width:100%;transition:all var(--duration-fast);background:#ffffff14;border:1px solid #ffffff26;outline:none;padding:8px 28px 8px 32px;font-size:14px}.search-bar__input::placeholder{color:#ffffff59}.search-bar__input:focus{background:#ffffff1f;border-color:#ffffff4d}.search-bar__clear{color:#fff6;cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:18px;line-height:1;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.search-bar__clear:hover{color:#ffffffb3}.search-bar__dropdown{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);z-index:300;max-height:240px;box-shadow:var(--shadow-xl);margin-top:4px;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.search-bar__result{text-align:left;width:100%;color:var(--color-text);border-bottom:1px solid var(--color-border-light);cursor:pointer;transition:background var(--duration-fast);padding:10px 12px;font-size:14px;display:block}.search-bar__result:hover,.search-bar__result--active{background:var(--color-surface)}.search-bar__result:last-child{border-bottom:none}.search-bar__fi{font-weight:600}.search-bar__base{color:var(--color-primary);font-size:13px;font-weight:400}.search-bar__en{color:var(--color-text-muted);margin-left:6px}.search-bar__fav{color:var(--color-accent);margin-top:2px;font-size:12px;display:block}.search-bar__empty{color:var(--color-text-muted);padding:10px 12px;font-size:14px}.sidebar__header{border-bottom:1px solid #ffffff1a;padding:24px 20px 16px}.sidebar__header-title{font-family:var(--font-display);color:#fff;cursor:default;letter-spacing:.01em;align-items:center;margin-bottom:14px;font-size:22px;font-weight:400;display:flex}.sidebar__title-icon{filter:brightness(0)invert();width:28px;height:28px;margin-right:-1px}.sidebar__nav{flex:1;padding:12px 0}.sidebar__link{color:#ffffffb3;transition:all var(--duration-fast);border-left:3px solid #0000;align-items:center;gap:12px;margin:1px 0;padding:11px 20px;font-size:14px;font-weight:500;text-decoration:none;display:flex}.sidebar__link-text{flex:1}.sidebar__link-shortcut{color:#ffffff4d;font-size:11px;font-weight:400}@media (width<=768px){.sidebar__link-shortcut{display:none}}.sidebar__link:hover{color:#fff;background:#ffffff14;text-decoration:none}.sidebar__link--active{color:#fff;border-left-color:var(--color-primary-subtle);background:#ffffff1f;font-weight:600}.sidebar__link-icon{text-align:center;flex-shrink:0;width:24px;font-size:17px}.sidebar__footer{border-top:1px solid #ffffff1a;padding:16px 20px}.sidebar__logout{color:#ffffff80;text-align:left;cursor:pointer;border-radius:var(--radius-sm);width:100%;transition:all var(--duration-fast);background:0 0;padding:10px;font-size:14px}.sidebar__logout:hover{color:#fffc;background:#ffffff14}.layout{height:100%;display:flex}.topbar{background:var(--color-primary-dark);color:#fff;z-index:100;justify-content:space-between;align-items:center;height:56px;padding:0 16px;display:none;position:fixed;top:0;left:0;right:0;box-shadow:0 2px 12px #1b433233}.topbar__hamburger{color:#fff;border-radius:var(--radius-sm);transition:background var(--duration-fast);padding:4px 8px;font-size:24px}.topbar__hamburger:hover{background:#ffffff1f}.topbar__title{font-family:var(--font-display);letter-spacing:.01em;align-items:center;font-size:20px;font-weight:400;display:flex}.topbar__title-icon{filter:brightness(0)invert();cursor:default;width:26px;height:26px;margin-right:-1px}.sidebar-overlay{-webkit-backdrop-filter:blur(4px);z-index:199;animation:overlay-fade .25s var(--ease-out);background:#1b43324d;display:none;position:fixed;inset:0}@keyframes overlay-fade{0%{opacity:0}to{opacity:1}}.sidebar-overlay.open{display:block}.sidebar{background:var(--color-primary-dark);z-index:200;flex-direction:column;width:260px;height:100%;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.layout__main{flex:1;min-height:100%;margin-left:260px;padding:32px;overflow-y:auto}@media (width<=768px){.topbar{display:flex}.sidebar{transition:transform .3s var(--ease-out);transform:translate(-100%)}.sidebar.open{transform:translate(0)}.layout__main{margin-left:0;padding:72px 16px 16px}}.confetti{pointer-events:none;z-index:1000;width:100%;height:100%;position:fixed;top:0;left:0;overflow:hidden}.confetti__particle{opacity:0;animation:linear forwards confetti-fall;position:absolute;top:-10px}@keyframes confetti-fall{0%{opacity:1;transform:translateY(0)rotate(0)}25%{opacity:1}to{opacity:0;transform:translateY(100vh)rotate(720deg)}}.save-to-list{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);padding:10px}.save-to-list__title{color:var(--color-text-faint);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;font-size:11px;font-weight:700}.save-to-list__option{text-align:left;border-radius:var(--radius-sm);cursor:pointer;width:100%;color:var(--color-text);transition:background var(--duration-fast);padding:8px 10px;font-size:14px;display:block}.save-to-list__option:hover{background:var(--color-surface)}.save-to-list__empty{color:var(--color-text-muted);padding:4px 0;font-size:13px}.save-to-list__new{border-top:1px solid var(--color-border-light);gap:6px;margin-top:8px;padding-top:8px;display:flex}.save-to-list__new-input{border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:border-color var(--duration-fast);outline:none;flex:1;padding:6px 10px;font-size:13px}.save-to-list__new-input:focus{border-color:var(--color-primary)}.save-to-list__new-btn{background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;transition:background var(--duration-fast);padding:6px 12px;font-size:12px;font-weight:600}.save-to-list__new-btn:hover{background:var(--color-primary-dark)}.save-to-list__saved{text-align:center;color:var(--color-success);padding:8px;font-size:14px;font-weight:600}.word-popup__backdrop{-webkit-backdrop-filter:blur(4px);z-index:1000;animation:overlay-fade .2s var(--ease-out);background:#1b433240;justify-content:center;align-items:flex-end;padding:16px;display:flex;position:fixed;inset:0}@media (width>=600px){.word-popup__backdrop{align-items:center}}.word-popup{background:var(--color-card);border-radius:var(--radius-xl);width:100%;max-width:400px;max-height:80vh;box-shadow:var(--shadow-xl);animation:word-popup-slide .25s var(--ease-out);border:1px solid var(--color-border-light);overflow-y:auto}@keyframes word-popup-slide{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.word-popup__header{border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.word-popup__lookup{color:var(--color-primary);font-size:16px;font-weight:700}.word-popup__word{font-family:var(--font-display);font-size:18px;font-weight:400}.word-popup__close,.word-popup__back{color:var(--color-text-faint);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--duration-fast);padding:4px 8px;font-size:18px}.word-popup__close:hover,.word-popup__back:hover{background:var(--color-surface);color:var(--color-text)}.word-popup__loading,.word-popup__not-found{text-align:center;color:var(--color-text-muted);padding:24px 16px;font-size:14px}.word-popup__entry{border-bottom:1px solid var(--color-border-light);padding:14px 18px}.word-popup__entry:last-child{border-bottom:none}.word-popup__main{flex-wrap:wrap;align-items:baseline;gap:8px;display:flex}.word-popup__finnish{font-size:18px;font-weight:700}.word-popup__pos{color:var(--color-text-muted);font-size:12px;font-style:italic}.word-popup__form-of{color:var(--color-primary-light);font-size:12px}.word-popup__english{color:var(--color-text);margin-top:4px;font-size:14px;line-height:1.4}.word-popup__actions{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.word-popup__action-btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration-fast);padding:7px 14px;font-size:13px;font-weight:600}.word-popup__action-btn--save{background:var(--color-primary);color:#fff;box-shadow:0 1px 4px #2d6a4f33}.word-popup__action-btn--save:hover{background:var(--color-primary-dark)}.word-popup__action-btn--known{border:1px solid var(--color-border);color:var(--color-text);background:0 0}.word-popup__action-btn--known:hover{background:var(--color-surface);border-color:var(--color-primary-light)}.word-popup__known-badge{color:var(--color-success);padding:6px 12px;font-size:13px;font-weight:600}.word-popup__action-btn--link{border:1px solid var(--color-primary);color:var(--color-primary);background:0 0;text-decoration:none}.word-popup__action-btn--link:hover{background:#2d6a4f0f}.word-popup__favorite{align-items:center;gap:6px;margin-top:8px;font-size:13px;display:flex}.word-popup__favorite-star{color:var(--color-accent)}.word-popup__favorite-text{font-weight:600}.clickable-word{cursor:pointer;transition:all var(--duration-fast);-webkit-tap-highlight-color:transparent;border-radius:3px;padding:0 1px}.clickable-word:hover{color:var(--color-primary);background:#2d6a4f1f}.clickable-word:active{background:#2d6a4f33}.learn{max-width:600px;margin:0 auto}.learn__review-modes{background:var(--color-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);gap:4px;margin-bottom:16px;padding:4px;display:flex}.learn__review-mode-btn{border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;text-align:center;transition:all var(--duration-fast) var(--ease-out);flex:1;padding:9px 4px;font-size:13px;font-weight:600}.learn__review-mode-btn:hover:not(.learn__review-mode-btn--active){color:var(--color-text);background:var(--color-surface)}.learn__review-mode-btn--active{background:var(--color-primary);color:#fff;box-shadow:0 2px 8px #2d6a4f4d}.learn__celebration{margin-bottom:12px;font-size:48px;display:block}.learn__rate-limited{text-align:center;color:var(--color-text-muted);padding:48px 24px;font-size:16px}.learn__empty-actions{flex-direction:column;align-items:center;gap:8px;margin-top:12px;display:flex}.learn__intro-card{background:var(--color-card);border-radius:var(--radius-xl);text-align:center;box-shadow:var(--shadow-lg);border:1px solid var(--color-border-light);animation:card-enter .4s var(--ease-out);padding:36px 28px}@keyframes card-enter{0%{opacity:0;transform:translateY(12px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.learn__intro-finnish{font-family:var(--font-display);color:var(--color-text);letter-spacing:-.01em;margin:20px 0 8px;font-size:38px;font-weight:400}.learn__intro-english{color:var(--color-text-muted);margin-bottom:8px;font-size:18px}.learn__intro-pos{color:var(--color-primary);text-transform:uppercase;letter-spacing:.08em;background:#2d6a4f14;border-radius:20px;margin-bottom:16px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-block}.learn__intro-example{background:var(--color-surface);border-radius:var(--radius-md);text-align:left;border-left:3px solid var(--color-primary-subtle);margin:16px 0;padding:16px}.learn__intro-example-label{color:var(--color-text-faint);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;font-size:11px;font-weight:700}.learn__intro-example-fi{color:var(--color-text);margin-bottom:4px;font-size:15px;font-weight:600}.learn__intro-example-en{color:var(--color-text-muted);font-size:14px}.learn__intro-actions{flex-direction:column;gap:10px;margin-top:28px;display:flex}.learn__intro-btn{border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);border:none;padding:14px;font-size:15px;font-weight:600}.learn__intro-btn:active{transform:scale(.98)}.learn__intro-btn--learn{background:var(--color-primary);color:#fff;box-shadow:0 2px 8px #2d6a4f40}.learn__intro-btn--learn:hover{background:var(--color-primary-dark);box-shadow:0 4px 16px #2d6a4f4d}.learn__intro-btn--know{background:var(--color-primary-light);color:#fff}.learn__intro-btn--know:hover{background:var(--color-primary)}.learn__intro-btn--skip{color:var(--color-text-muted);border:1px solid var(--color-border);background:0 0}.learn__intro-btn--skip:hover{background:var(--color-surface);border-color:var(--color-text-muted)}.learn__modes{justify-content:flex-end;gap:6px;margin-bottom:16px;display:flex}.learn__mode-btn{color:var(--color-text-muted);border:1px solid var(--color-border);transition:all var(--duration-fast) var(--ease-out);background:0 0;border-radius:20px;padding:6px 14px;font-size:12px;font-weight:600}.learn__mode-btn:hover:not(.learn__mode-btn--active){border-color:var(--color-primary-light);color:var(--color-primary)}.learn__mode-btn--active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.learn__refresh-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-card);color:var(--color-text-muted);cursor:pointer;transition:all var(--duration-fast);margin-left:auto;padding:6px 10px;font-size:18px;line-height:1}.learn__refresh-btn:hover{background:var(--color-surface);color:var(--color-text);border-color:var(--color-primary-light)}.learn__card{background:var(--color-card);border-radius:var(--radius-xl);text-align:center;box-shadow:var(--shadow-md);border:1px solid var(--color-border-light);animation:card-enter .35s var(--ease-out);margin-bottom:20px;padding:36px 28px;position:relative}.learn__badge{background:var(--color-accent);color:#fff;text-transform:uppercase;letter-spacing:.04em;border-radius:20px;padding:3px 10px;font-size:10px;font-weight:700;position:absolute;top:14px;right:14px}.learn__word{color:var(--color-text);margin-bottom:8px;font-size:30px;font-weight:700}.learn__sentence{color:var(--color-text-muted);margin-bottom:4px;font-size:15px;font-style:italic;line-height:1.5}.learn__prompt{color:var(--color-text-faint);margin-top:12px;font-size:13px}.learn__other-meanings{color:var(--color-text-muted);border-top:1px solid var(--color-border-light);flex-direction:column;gap:2px;margin-top:10px;padding-top:10px;font-size:12px;display:flex}.learn__other-meaning em{color:var(--color-primary-light);font-style:italic}.learn__answer-area{margin-top:24px}.learn__skip-btn{color:var(--color-text-faint);cursor:pointer;transition:color var(--duration-fast);background:0 0;border:none;margin:12px auto 0;padding:6px 16px;font-size:13px;display:block}.learn__skip-btn:hover{color:var(--color-text);text-decoration:underline}.learn__reveal-btn{background:var(--color-primary);color:#fff;border-radius:var(--radius-md);width:100%;transition:all var(--duration-fast) var(--ease-out);padding:14px;font-size:16px;font-weight:600;box-shadow:0 2px 8px #2d6a4f33}.learn__reveal-btn:hover{background:var(--color-primary-dark);box-shadow:0 4px 16px #2d6a4f4d}.learn__reveal-btn:active{transform:scale(.98)}.learn__revealed{color:var(--color-primary);margin-bottom:16px;font-size:22px;font-weight:700}.learn__verdict-buttons{gap:12px;display:flex}.learn__verdict-btn{border-radius:var(--radius-md);color:#fff;transition:all var(--duration-fast) var(--ease-out);flex:1;padding:14px;font-size:15px;font-weight:600}.learn__verdict-btn:active{transform:scale(.97)}.learn__verdict-btn--correct{background:var(--color-success);box-shadow:0 2px 8px #2d6a4f40}.learn__verdict-btn--correct:hover{box-shadow:0 4px 16px #2d6a4f4d}.learn__verdict-btn--wrong{background:var(--color-error);box-shadow:0 2px 8px #c1292e40}.learn__verdict-btn--wrong:hover{box-shadow:0 4px 16px #c1292e4d}.learn__options{grid-template-columns:1fr 1fr;gap:10px;display:grid}.learn__option-btn{border-radius:var(--radius-md);background:var(--color-card);border:2px solid var(--color-border);color:var(--color-text);transition:all var(--duration-fast) var(--ease-out);padding:14px 12px;font-size:15px;font-weight:500}.learn__option-btn:hover{border-color:var(--color-primary-light);background:#2d6a4f0a}.learn__option-btn:active{transform:scale(.97)}.learn__option-btn--correct{border-color:var(--color-success);color:var(--color-success);background:#2d6a4f1a}.learn__option-btn--wrong{border-color:var(--color-error);color:var(--color-error);background:#c1292e14}.learn__type-form{gap:10px;display:flex}.learn__type-input-wrap{flex:1;position:relative}.learn__type-clear{color:var(--color-text-muted);cursor:pointer;opacity:.5;background:0 0;border:none;padding:0 4px;font-size:18px;line-height:1;position:absolute;top:10px;right:8px}.learn__type-clear:hover{opacity:1}.learn__type-input{border:2px solid var(--color-border);border-radius:var(--radius-md);width:100%;transition:border-color var(--duration-fast);background:var(--color-card);outline:none;padding:12px 30px 12px 14px;font-size:16px}.learn__type-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2d6a4f1a}.learn__type-input--textarea{resize:vertical;width:100%;min-height:60px;font-family:inherit;line-height:1.4}.learn__type-submit{background:var(--color-primary);color:#fff;border-radius:var(--radius-md);transition:all var(--duration-fast) var(--ease-out);padding:12px 20px;font-weight:600;box-shadow:0 2px 6px #2d6a4f33}.learn__type-submit:hover:not(:disabled){background:var(--color-primary-dark)}.learn__type-submit:active:not(:disabled){transform:scale(.97)}.learn__type-submit:disabled{opacity:.5;cursor:not-allowed}.learn__type-reveal{width:100%;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast);background:0 0;margin-top:8px;padding:10px;font-size:14px;display:block}.learn__type-reveal:hover{background:var(--color-surface);border-color:var(--color-text-muted)}.learn__type-reveal--confirm{color:var(--color-error);border-color:var(--color-error);background:#c1292e0f}.learn__feedback{text-align:center;border-radius:var(--radius-lg);animation:feedback-enter .3s var(--ease-out);margin-bottom:16px;padding:16px;font-size:16px;font-weight:600;position:relative}@keyframes feedback-enter{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.learn__score{opacity:.7;font-size:13px;font-weight:700;position:absolute;top:8px;right:12px}.learn__feedback--correct{color:var(--color-success);background:#2d6a4f1a;border:1px solid #2d6a4f33}.learn__feedback--wrong{color:var(--color-error);background:#c1292e14;border:1px solid #c1292e26}.learn__feedback--retry{color:#8b6914;background:#d4a37326;border:1px solid #d4a3734d}.learn__next-btn--retry{background:var(--color-accent)}.learn__option-key{width:20px;height:20px;color:var(--color-primary);background:#2d6a4f1a;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;margin-right:6px;font-size:11px;font-weight:700;display:inline-flex}.learn__hotkey-hint{opacity:.4;margin-left:8px;font-size:11px}@media (width<=768px){.learn__option-key,.learn__hotkey-hint{display:none}}.learn__user-answer{margin-top:4px;font-size:14px;font-weight:400}.learn__expected-answer{opacity:.8;margin-top:2px;font-size:14px;font-weight:400}.learn__ai-feedback{opacity:.85;margin-top:8px;font-size:14px;font-style:italic;font-weight:400}.learn__next-btn{background:var(--color-primary);color:#fff;border-radius:var(--radius-md);width:100%;transition:all var(--duration-fast) var(--ease-out);padding:14px;font-size:16px;font-weight:600;box-shadow:0 2px 8px #2d6a4f33}.learn__next-btn:hover{background:var(--color-primary-dark)}.learn__next-btn:active{transform:scale(.98)}.learn__empty{text-align:center;padding:48px 24px}.learn__empty-text{color:var(--color-text-muted);margin-bottom:16px;font-size:18px}.learn__empty-link{background:var(--color-primary);color:#fff;border-radius:var(--radius-md);transition:all var(--duration-fast) var(--ease-out);padding:12px 24px;font-weight:600;text-decoration:none;display:inline-block}.learn__empty-link:hover{background:var(--color-primary-dark);color:#fff;text-decoration:none}.learn__stats-bar{border-top:1px solid var(--color-border-light);flex-direction:column;gap:8px;margin-top:20px;padding:14px 0;display:flex}.learn__stats-row{justify-content:center;gap:24px;display:flex}.learn__stat{align-items:center;gap:6px;display:flex}.learn__stat-icon{font-size:16px}.learn__stat-label{color:var(--color-text-faint);text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:700}.learn__stat-value{color:var(--color-text);font-size:18px;font-weight:700}.learn__stat-total{color:var(--color-text-muted);font-size:13px;font-weight:400}.settings{max-width:560px;margin:0 auto}.settings__title{font-family:var(--font-display);color:var(--color-text);margin-bottom:24px;font-size:28px;font-weight:400}.settings__welcome{background:var(--color-card);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-md);border:1px solid var(--color-border-light);margin-bottom:24px;padding:24px}.settings__welcome-title{font-family:var(--font-display);color:var(--color-primary);margin-bottom:8px;font-size:24px;font-weight:400}.settings__welcome-text{color:var(--color-text-muted);margin-bottom:16px;line-height:1.6}.settings__form{background:var(--color-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);padding:28px}.settings__group{margin-bottom:22px}.settings__label{color:var(--color-text);text-transform:uppercase;letter-spacing:.03em;margin-bottom:6px;font-size:13px;font-weight:700;display:block}.settings__input,.settings__select{border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;transition:border-color var(--duration-fast);background:#fff;outline:none;padding:10px 12px;font-size:15px}.settings__input:focus,.settings__select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2d6a4f1a}.settings__radio-group,.settings__checkbox-group{flex-wrap:wrap;gap:8px;margin-top:4px;display:flex}.settings__radio-label,.settings__checkbox-label{cursor:pointer;border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:all var(--duration-fast);align-items:center;gap:6px;padding:7px 12px;font-size:14px;display:flex}.settings__radio-label:hover,.settings__checkbox-label:hover{border-color:var(--color-primary-light)}:is(.settings__radio-label:has(input:checked),.settings__checkbox-label:has(input:checked)){border-color:var(--color-primary);color:var(--color-primary);background:#2d6a4f14;font-weight:600}.settings__save-btn{background:var(--color-primary);color:#fff;border-radius:var(--radius-md);width:100%;transition:all var(--duration-fast) var(--ease-out);margin-top:8px;padding:14px;font-size:16px;font-weight:600;box-shadow:0 2px 8px #2d6a4f33}.settings__save-btn:hover:not(:disabled){background:var(--color-primary-dark)}.settings__save-btn:active:not(:disabled){transform:scale(.98)}.settings__save-btn:disabled{opacity:.5;cursor:not-allowed}.settings__message{text-align:center;border-radius:var(--radius-sm);margin-top:12px;padding:10px;font-size:14px;font-weight:500}.settings__message--success{color:var(--color-success);background:#2d6a4f1a;border:1px solid #2d6a4f33}.settings__message--error{color:var(--color-error);background:#c1292e14;border:1px solid #c1292e26}.packages{max-width:700px;margin:0 auto}.packages__title{font-family:var(--font-display);color:var(--color-text);margin-bottom:20px;font-size:28px;font-weight:400}.packages__create-btn{background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);transition:all var(--duration-fast) var(--ease-out);align-items:center;gap:6px;margin-bottom:20px;padding:10px 18px;font-size:14px;font-weight:600;display:inline-flex;box-shadow:0 2px 6px #2d6a4f33}.packages__create-btn:hover{background:var(--color-primary-dark)}.packages__create-btn:active{transform:scale(.98)}.packages__create-form{background:var(--color-card);border-radius:var(--radius-md);border:1px solid var(--color-border);margin-bottom:20px;padding:16px}.packages__create-form input{border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;transition:border-color var(--duration-fast);outline:none;margin-bottom:8px;padding:10px 12px;font-size:14px}.packages__create-form input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2d6a4f1a}.packages__create-actions{gap:8px;display:flex}.packages__create-submit{background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);transition:background var(--duration-fast);padding:8px 16px;font-size:14px;font-weight:600}.packages__create-submit:hover{background:var(--color-primary-dark)}.packages__create-cancel{background:var(--color-surface);color:var(--color-text);border-radius:var(--radius-sm);transition:background var(--duration-fast);padding:8px 16px;font-size:14px}.packages__create-cancel:hover{background:var(--color-border)}.packages__list{flex-direction:column;gap:12px;display:flex}.pkg-card{background:var(--color-card);border-radius:var(--radius-lg);border:1px solid var(--color-border-light);box-shadow:var(--shadow-sm);transition:box-shadow var(--duration-fast);overflow:hidden}.pkg-card:hover{box-shadow:var(--shadow-md)}.pkg-card__header{cursor:pointer;transition:background var(--duration-fast);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.pkg-card__header:hover{background:var(--color-surface)}.pkg-card__info{flex:1}.pkg-card__name{color:var(--color-text);font-size:16px;font-weight:600}.pkg-card__meta{color:var(--color-text-muted);margin-top:2px;font-size:13px}.pkg-card__badge{background:var(--color-accent);color:#fff;text-transform:uppercase;letter-spacing:.03em;border-radius:12px;margin-left:8px;padding:2px 8px;font-size:10px;font-weight:700;display:inline-block}.pkg-card__actions{align-items:center;gap:10px;display:flex}.pkg-card__toggle{background:var(--color-border);cursor:pointer;border-radius:12px;width:44px;height:24px;transition:background .2s;position:relative}.pkg-card__toggle--active{background:var(--color-success)}.pkg-card__toggle-knob{width:20px;height:20px;transition:transform .2s var(--ease-out);background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #00000026}.pkg-card__toggle--active .pkg-card__toggle-knob{transform:translate(20px)}.pkg-card__delete{color:var(--color-error);transition:opacity var(--duration-fast);padding:4px;font-size:18px}.pkg-card__delete:hover{opacity:.7}.pkg-card__body{border-top:1px solid var(--color-border-light);padding:12px 16px}.pkg-card__add-inline{margin-bottom:12px;position:relative}.pkg-card__add-input{border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;transition:border-color var(--duration-fast);outline:none;padding:8px 12px;font-size:14px}.pkg-card__add-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2d6a4f1a}.pkg-card__add-msg{color:var(--color-success);margin-left:8px;font-size:12px}.pkg-card__add-results{border:1px solid var(--color-border-light);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);margin-top:4px;overflow:hidden}.pkg-card__add-result{text-align:left;cursor:pointer;border-bottom:1px solid var(--color-border-light);background:var(--color-card);width:100%;color:var(--color-text);transition:background var(--duration-fast);align-items:baseline;gap:6px;padding:6px 10px;font-size:13px;display:flex}.pkg-card__add-result:last-child{border-bottom:none}.pkg-card__add-result:hover{background:var(--color-surface)}.pkg-card__add-fi{font-weight:700}.pkg-card__add-pos{color:var(--color-text-muted);font-size:11px;font-style:italic}.pkg-card__add-en{color:var(--color-text-muted);margin-left:auto;font-size:12px}.pkg-card__add-custom{gap:6px;margin-top:6px;display:flex}.pkg-card__add-input--en{flex:1}.pkg-card__add-custom-btn{background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--duration-fast);flex-shrink:0;padding:8px 14px;font-size:13px;font-weight:600}.pkg-card__add-custom-btn:hover:not(:disabled){background:var(--color-primary-dark)}.pkg-card__add-custom-btn:disabled{opacity:.5;cursor:not-allowed}.pkg-card__words{margin-bottom:12px}.pkg-card__word-row{border-bottom:1px solid var(--color-border-light);transition:background var(--duration-fast);flex-wrap:wrap;justify-content:space-between;align-items:center;padding:8px 0;font-size:14px;display:flex;position:relative}.pkg-card__word-row:last-child{border-bottom:none}.pkg-card__word-fi{font-weight:600}.pkg-card__word-en{color:var(--color-text-muted)}.pkg-card__word-actions{align-items:center;gap:8px;display:flex}.pkg-card__word-save{border:1px solid var(--color-border);width:24px;height:24px;color:var(--color-primary);cursor:pointer;transition:all var(--duration-fast);border-radius:50%;justify-content:center;align-items:center;padding-bottom:1px;font-size:18px;line-height:1;display:flex}.pkg-card__word-save:hover{background:var(--color-surface);border-color:var(--color-primary)}.pkg-card__word-remove{color:var(--color-error);transition:opacity var(--duration-fast);padding:2px;font-size:16px}.pkg-card__word-remove:hover{opacity:.7}.pkg-card__save-popup{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;box-shadow:var(--shadow-md);margin-top:6px;padding:10px}.pkg-card__save-title{color:var(--color-text-faint);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;font-size:11px;font-weight:700}.pkg-card__save-option{text-align:left;border-radius:var(--radius-sm);cursor:pointer;width:100%;color:var(--color-text);transition:background var(--duration-fast);padding:8px 10px;font-size:14px;display:block}.pkg-card__save-option:hover{background:var(--color-surface)}.pkg-card__save-new{border-top:1px solid var(--color-border-light);gap:6px;margin-top:8px;padding-top:8px;display:flex}.pkg-card__save-new-input{border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:border-color var(--duration-fast);outline:none;flex:1;padding:6px 10px;font-size:13px}.pkg-card__save-new-input:focus{border-color:var(--color-primary)}.pkg-card__save-new-btn{background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;transition:background var(--duration-fast);padding:6px 12px;font-size:12px;font-weight:600}.pkg-card__save-new-btn:hover{background:var(--color-primary-dark)}.pkg-card__word-label{cursor:pointer;-webkit-tap-highlight-color:transparent;flex:1;align-items:center;min-width:0;display:flex}.pkg-card__word-checkbox{width:18px;height:18px;accent-color:var(--color-primary)}.pkg-card__word-status{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-left:6px;margin-right:10px}.pkg-card__word-status--new{background:var(--color-border)}.pkg-card__word-status--in_progress{background:var(--color-info)}.pkg-card__word-status--learned{background:var(--color-success)}.pkg-card__word-row--learned .pkg-card__word-fi,.pkg-card__word-row--learned .pkg-card__word-en{opacity:.55}.pkg-card__batch-actions{flex-direction:column;gap:8px;margin-top:12px;display:flex}.pkg-card__select-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.pkg-card__select-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);background:var(--color-card);cursor:pointer;transition:all var(--duration-fast);padding:6px 12px;font-size:12px}.pkg-card__select-btn:hover{background:var(--color-surface);border-color:var(--color-primary-light)}.pkg-card__shortcut-hint{color:var(--color-text-faint);cursor:help;font-size:11px}.pkg-card__mark-known-btn{background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);transition:background var(--duration-fast);padding:8px 14px;font-size:13px;font-weight:600}.pkg-card__mark-known-btn:hover{background:var(--color-primary-dark)}.pkg-card__load-more{color:var(--color-primary);text-align:center;width:100%;transition:color var(--duration-fast);padding:8px;font-size:13px;font-weight:600}.pkg-card__load-more:hover{color:var(--color-primary-dark)}.add-word{max-width:500px;margin:0 auto}.add-word__title{font-family:var(--font-display);color:var(--color-text);margin-bottom:16px;font-size:28px;font-weight:400}.add-word__form{background:var(--color-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);padding:28px}.add-word__group{margin-bottom:18px}.add-word__label{text-transform:uppercase;letter-spacing:.03em;color:var(--color-text);margin-bottom:6px;font-size:13px;font-weight:700;display:block}.add-word__input,.add-word__select{border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;transition:border-color var(--duration-fast);outline:none;padding:10px 12px;font-size:15px}.add-word__input:focus,.add-word__select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2d6a4f1a}.add-word__exists{color:var(--color-primary);margin-top:6px;font-size:13px}.add-word__suggestions{border:1px solid var(--color-border-light);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);margin-top:6px;overflow:hidden}.add-word__suggestion{text-align:left;cursor:pointer;border-bottom:1px solid var(--color-border-light);background:var(--color-card);width:100%;color:var(--color-text);transition:background var(--duration-fast);align-items:baseline;gap:6px;padding:8px 12px;font-size:14px;display:flex}.add-word__suggestion:last-child{border-bottom:none}.add-word__suggestion:hover{background:var(--color-surface)}.add-word__suggestion-fi{font-weight:700}.add-word__suggestion-pos{color:var(--color-text-muted);font-size:12px;font-style:italic}.add-word__suggestion-en{color:var(--color-text-muted);margin-left:auto;font-size:13px}.add-word__pkg-row{gap:8px;display:flex}.add-word__pkg-row .add-word__select{flex:1}.add-word__new-pkg-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);width:40px;height:40px;color:var(--color-primary);cursor:pointer;transition:all var(--duration-fast);flex-shrink:0;font-size:20px}.add-word__new-pkg-btn:hover{background:var(--color-surface);border-color:var(--color-primary)}.add-word__create-pkg{gap:8px;margin-top:8px;display:flex}.add-word__create-pkg .add-word__input{flex:1}.add-word__create-pkg-btn{background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--duration-fast);flex-shrink:0;padding:10px 16px;font-size:14px;font-weight:600}.add-word__create-pkg-btn:hover{background:var(--color-primary-dark)}.add-word__submit{background:var(--color-primary);color:#fff;border-radius:var(--radius-md);width:100%;transition:all var(--duration-fast) var(--ease-out);margin-top:8px;padding:14px;font-size:16px;font-weight:600;box-shadow:0 2px 8px #2d6a4f33}.add-word__submit:hover:not(:disabled){background:var(--color-primary-dark)}.add-word__submit:active:not(:disabled){transform:scale(.98)}.add-word__submit:disabled{opacity:.5;cursor:not-allowed}.add-word__message{text-align:center;border-radius:var(--radius-sm);margin-top:12px;padding:10px;font-size:14px;font-weight:500}.add-word__message--success{color:var(--color-success);background:#2d6a4f1a;border:1px solid #2d6a4f33}.add-word__message--error{color:var(--color-error);background:#c1292e14;border:1px solid #c1292e26}.stats{max-width:500px;margin:0 auto}.stats__title{font-family:var(--font-display);color:var(--color-text);margin-bottom:24px;font-size:28px;font-weight:400}.stats__cards{grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:24px;display:grid}.stats__card{background:var(--color-card);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);transition:box-shadow var(--duration-fast);padding:18px 16px}.stats__card:hover{box-shadow:var(--shadow-md)}.stats__card-value{color:var(--color-primary);font-size:28px;font-weight:700}.stats__card-label{color:var(--color-text-faint);text-transform:uppercase;letter-spacing:.04em;margin-top:4px;font-size:11px;font-weight:600}.stats__streak{background:var(--color-card);border-radius:var(--radius-xl);text-align:center;box-shadow:var(--shadow-md);border:1px solid var(--color-border-light);margin-bottom:20px;padding:36px}.stats__streak-icon{margin-bottom:8px;font-size:48px}.stats__streak-count{font-family:var(--font-display);color:var(--color-primary);font-size:56px;font-weight:400}.stats__streak-label{color:var(--color-text-muted);margin-top:4px;font-size:14px}.stats__percentage{background:var(--color-card);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);padding:20px}.stats__percentage-value{color:var(--color-success);font-size:36px;font-weight:700}.stats__percentage-label{color:var(--color-text-muted);margin-top:4px;font-size:13px}.stats__pending{text-align:center;background:var(--color-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);margin-bottom:20px;padding:20px}.stats__pending-value{color:var(--color-text);font-size:28px;font-weight:700}.stats__pending-label{color:var(--color-text-muted);margin-top:4px;font-size:13px}@media (width<=400px){.stats__cards{grid-template-columns:1fr}}.noun-table__tabs{-webkit-overflow-scrolling:touch;gap:4px;margin-bottom:12px;display:flex;overflow-x:auto}.noun-table__tab{border-radius:var(--radius-sm);white-space:nowrap;cursor:pointer;background:var(--color-surface);color:var(--color-text-muted);transition:all var(--duration-fast);border:1px solid #0000;padding:6px 14px;font-size:13px;font-weight:600}.noun-table__tab:hover:not(.noun-table__tab--active){background:var(--color-border-light);color:var(--color-text)}.noun-table__tab--active{background:var(--color-primary);color:#fff}.noun-table__table{border-collapse:collapse;border:1px solid var(--color-border-light);border-radius:var(--radius-sm);width:100%;font-size:14px;overflow:hidden}.noun-table__th{background:var(--color-primary-dark);text-transform:uppercase;letter-spacing:.04em;color:#ffffffd9;text-align:left;border-bottom:1px solid var(--color-border-light);padding:8px 10px;font-size:11px;font-weight:700}.noun-table__row:nth-child(2n){background:var(--color-surface)}.noun-table__case{color:var(--color-text-muted);border-right:1px solid var(--color-border-light);white-space:nowrap;padding:6px 10px;font-size:13px;font-weight:600}.noun-table__cell{padding:6px 10px}.noun-table__form-wrap{justify-content:space-between;align-items:center;gap:4px;display:flex}.noun-table__form{font-weight:500}.noun-table__star{color:var(--color-border);cursor:pointer;transition:color var(--duration-fast);background:0 0;border:none;flex-shrink:0;padding:0 2px;font-size:14px;line-height:1}.noun-table__star:hover,.noun-table__star--active{color:var(--color-accent)}.noun-table__dash{color:var(--color-border)}.verb-table__selectors{flex-direction:column;gap:6px;margin-bottom:12px;display:flex}.verb-table__btn-row{flex-wrap:wrap;gap:4px;display:flex}.verb-table__btn{border-radius:var(--radius-sm);cursor:pointer;background:var(--color-surface);color:var(--color-text-muted);text-transform:capitalize;transition:all var(--duration-fast);border:1px solid #0000;padding:6px 12px;font-size:13px;font-weight:600}.verb-table__btn:hover:not(.verb-table__btn--active){background:var(--color-border-light);color:var(--color-text)}.verb-table__btn--active{background:var(--color-primary);color:#fff}.verb-table__table{border-collapse:collapse;border:1px solid var(--color-border-light);border-radius:var(--radius-sm);width:100%;font-size:14px;overflow:hidden}.verb-table__th{background:var(--color-primary-dark);text-transform:uppercase;letter-spacing:.04em;color:#ffffffd9;text-align:left;border-bottom:1px solid var(--color-border-light);padding:8px 10px;font-size:11px;font-weight:700}.verb-table__row:nth-child(2n){background:var(--color-surface)}.verb-table__person{color:var(--color-text-muted);border-right:1px solid var(--color-border-light);white-space:nowrap;padding:6px 10px;font-size:13px;font-weight:600}.verb-table__label{color:var(--color-text-muted);white-space:nowrap;padding:6px 10px;font-size:12px}.verb-table__cell{padding:6px 10px}.verb-table__form-wrap{justify-content:space-between;align-items:center;gap:4px;display:flex}.verb-table__form{font-weight:500}.verb-table__star{color:var(--color-border);cursor:pointer;transition:color var(--duration-fast);background:0 0;border:none;flex-shrink:0;padding:0 2px;font-size:14px;line-height:1}.verb-table__star:hover,.verb-table__star--active{color:var(--color-accent)}.verb-table__dash{color:var(--color-border)}.verb-table__section{margin-top:16px}.verb-table__section-title{color:var(--color-text);text-transform:uppercase;letter-spacing:.03em;margin-bottom:8px;font-size:13px;font-weight:700}.verb-table__table--simple{border:none}.verb-table__table--simple .verb-table__row{border-bottom:1px solid var(--color-border-light)}.verb-table__table--simple .verb-table__row:last-child{border-bottom:none}.dictionary{max-width:600px;margin:0 auto}.dictionary__loading,.dictionary__not-found{text-align:center;color:var(--color-text-muted);padding:48px}.dictionary__entry{background:var(--color-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);transition:box-shadow var(--duration-fast);margin-bottom:16px;padding:22px}.dictionary__entry:hover{box-shadow:var(--shadow-md)}.dictionary__header{cursor:pointer;-webkit-user-select:none;user-select:none;transition:opacity var(--duration-fast);justify-content:space-between;align-items:flex-start;display:flex}.dictionary__header:hover{opacity:.85}.dictionary__collapse-icon{color:var(--color-text-faint);transition:transform .2s var(--ease-out);margin-right:6px;font-size:14px}.dictionary__header-main{flex:1}.dictionary__word{font-family:var(--font-display);color:var(--color-text);margin:0;font-size:30px;font-weight:400}.dictionary__tags{gap:6px;margin-top:8px;display:flex}.dictionary__tag{text-transform:uppercase;letter-spacing:.04em;border-radius:12px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-block}.dictionary__tag--cefr{background:var(--color-primary-subtle);color:#fff}.dictionary__tag--pos{background:var(--color-surface);color:var(--color-text-muted);border:1px solid var(--color-border-light)}.dictionary__save-btn{border:1px solid var(--color-border);width:32px;height:32px;color:var(--color-primary);cursor:pointer;background:var(--color-card);transition:all var(--duration-fast);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:20px;line-height:1;display:flex}.dictionary__save-btn:hover{background:var(--color-surface);border-color:var(--color-primary)}.dictionary__translations{margin-top:10px}.dictionary__meaning{color:var(--color-text-muted);padding:3px 0;font-size:15px;line-height:1.4}.dictionary__meaning:first-child{color:var(--color-text);font-weight:600}.dictionary__kotus{color:var(--color-text-faint);margin-top:6px;font-size:13px;font-style:italic}.dictionary__favorite{border-radius:var(--radius-sm);background:#d4a3731a;border:1px solid #d4a37340;align-items:center;gap:8px;margin-top:10px;padding:8px 12px;display:flex}.dictionary__sentences-section{margin-top:16px}.dictionary__section-title{text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);margin-bottom:8px;font-size:13px;font-weight:700}.dictionary__sentence{border-bottom:1px solid var(--color-border-light);padding:8px 0;position:relative}.dictionary__sentence:last-child{border-bottom:none}.dictionary__sentence-fi{font-size:14px;font-weight:500}.dictionary__sentence-en{color:var(--color-text-muted);margin-top:2px;font-size:13px}.dictionary__sentence-level{color:var(--color-text-faint);background:var(--color-surface);letter-spacing:.03em;border-radius:8px;padding:1px 7px;font-size:10px;font-weight:600;position:absolute;top:8px;right:0}.dictionary__favorite-star{color:var(--color-accent);font-size:16px}.dictionary__favorite-form{font-size:16px;font-weight:700}.dictionary__favorite-tags{color:var(--color-text-muted);font-size:12px}.dictionary__matched-form{color:var(--color-text-muted);margin-top:8px;font-size:13px}.dictionary__save-popup{margin-top:12px}.dictionary__forms-section{margin-top:16px}.dictionary__generic-section{margin-bottom:12px}.dictionary__generic-title{text-transform:capitalize;color:var(--color-text-muted);margin-bottom:6px;font-size:13px;font-weight:700}.dictionary__generic-table{border-collapse:collapse;width:100%;font-size:14px}.dictionary__generic-form{padding:4px 8px;font-weight:500}.dictionary__generic-tags{color:var(--color-text-muted);padding:4px 8px;font-size:12px}.admin{max-width:800px;margin:0 auto}.admin__title{font-family:var(--font-display);color:var(--color-text);margin-bottom:16px;font-size:28px;font-weight:400}.admin__stats{gap:12px;margin-bottom:16px;display:flex}.admin__stat{background:var(--color-card);border:1px solid var(--color-border-light);border-radius:var(--radius-md);text-align:center;box-shadow:var(--shadow-sm);flex:1;padding:14px}.admin__stat-value{color:var(--color-primary);font-size:22px;font-weight:700;display:block}.admin__stat-label{color:var(--color-text-faint);text-transform:uppercase;letter-spacing:.04em;margin-top:2px;font-size:11px;font-weight:600;display:block}.admin__filter{border:1px solid var(--color-border);border-radius:var(--radius-sm);box-sizing:border-box;width:100%;transition:border-color var(--duration-fast);outline:none;margin-bottom:8px;padding:10px 14px;font-size:14px}.admin__filter:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2d6a4f1a}.admin__count{color:var(--color-text-muted);margin-bottom:12px;font-size:13px}.admin__table-wrap{background:var(--color-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);overflow-x:auto}.admin__table{border-collapse:collapse;width:100%;font-size:14px}.admin__table th{background:var(--color-surface);text-align:left;color:var(--color-text-faint);text-transform:uppercase;white-space:nowrap;letter-spacing:.04em;padding:12px 14px;font-size:11px;font-weight:700}.admin__table td{border-top:1px solid var(--color-border-light);vertical-align:middle;padding:12px 14px}.admin__tier-select{border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:border-color var(--duration-fast);background:#fff;outline:none;padding:6px 10px;font-size:13px}.admin__tier-select:focus{border-color:var(--color-primary)}@media (width<=600px){.admin__table{font-size:13px}.admin__table th,.admin__table td{padding:10px 8px}}.my-words{max-width:600px;margin:0 auto}.my-words__title{font-family:var(--font-display);color:var(--color-text);margin-bottom:4px;font-size:28px;font-weight:400}.my-words__summary{color:var(--color-text-muted);margin-bottom:16px;font-size:14px}.my-words__loading,.my-words__empty{text-align:center;color:var(--color-text-muted);padding:48px}.my-words__list{flex-direction:column;gap:8px;display:flex}.my-words__item{background:var(--color-card);border-radius:var(--radius-md);border:1px solid var(--color-border-light);box-shadow:var(--shadow-sm);transition:all var(--duration-fast);justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;display:flex}.my-words__item:hover{box-shadow:var(--shadow-md);border-color:var(--color-border)}.my-words__item--learned{opacity:.55}.my-words__word-link{min-width:0;color:inherit;flex:1;text-decoration:none}.my-words__word-main{align-items:baseline;gap:6px;display:flex}.my-words__finnish{font-size:16px;font-weight:700}.my-words__pos{color:var(--color-text-muted);font-size:12px;font-style:italic}.my-words__english{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.my-words__meta{flex-shrink:0;align-items:center;gap:8px;display:flex}.my-words__stage{white-space:nowrap;letter-spacing:.02em;border-radius:12px;padding:3px 10px;font-size:11px;font-weight:700}.my-words__stage--new{background:var(--color-surface);color:var(--color-text-muted)}.my-words__stage--in-progress{color:var(--color-info);background:#457b9d1f}.my-words__stage--learned{color:var(--color-success);background:#2d6a4f1a}.my-words__streak{color:var(--color-success);font-size:12px;font-weight:600}.my-words__wrong{color:var(--color-error);font-size:12px;font-weight:600}.my-words__know-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-card);color:var(--color-text);cursor:pointer;white-space:nowrap;transition:all var(--duration-fast);padding:4px 10px;font-size:12px;font-weight:600}.my-words__know-btn:hover{background:var(--color-surface);border-color:var(--color-primary-light)}.my-words__pagination{justify-content:center;align-items:center;gap:16px;margin-top:20px;padding:12px 0;display:flex}.my-words__page-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-card);color:var(--color-text);cursor:pointer;transition:all var(--duration-fast);padding:8px 16px;font-size:14px;font-weight:600}.my-words__page-btn:disabled{opacity:.4;cursor:not-allowed}.my-words__page-btn:not(:disabled):hover{background:var(--color-surface);border-color:var(--color-primary-light)}.my-words__page-info{color:var(--color-text-muted);font-size:14px}@media (width<=480px){.my-words__item{flex-direction:column;align-items:flex-start;gap:8px}.my-words__meta{justify-content:space-between;width:100%}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary:#2d6a4f;--color-primary-dark:#1b4332;--color-primary-light:#40916c;--color-primary-subtle:#52b788;--color-accent:#d4a373;--color-accent-light:#e9c46a;--color-surface:#f1f5f0;--color-surface-warm:#f7f5f2;--color-card:#fff;--color-card-elevated:#fff;--color-text:#1a2e1a;--color-text-muted:#5f7161;--color-text-faint:#8a9b8c;--color-success:#2d6a4f;--color-error:#c1292e;--color-warning:#d4a373;--color-info:#457b9d;--color-streak-active:#52b788;--color-streak-inactive:#8a9b8c;--color-border:#d4ddd5;--color-border-light:#e8ede9;--font-display:"DM Serif Display", Georgia, "Times New Roman", serif;--font-body:"DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--shadow-sm:0 1px 3px #1b43320f, 0 1px 2px #1b43320a;--shadow-md:0 4px 12px #1b433214, 0 2px 4px #1b43320a;--shadow-lg:0 8px 24px #1b43321a, 0 4px 8px #1b43320f;--shadow-xl:0 16px 48px #1b43321f, 0 8px 16px #1b433214;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--duration-fast:.15s;--duration-normal:.25s;--duration-slow:.4s}html,body{height:100%;font-family:var(--font-body);color:var(--color-text);background:var(--color-surface);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.5;overflow-x:hidden}#app{height:100%}a{color:var(--color-primary);transition:color var(--duration-fast);text-decoration:none}a:hover{color:var(--color-primary-dark);text-decoration:underline}button{font-family:inherit;font-size:inherit;cursor:pointer;background:0 0;border:none}input,select,textarea{font-family:inherit;font-size:inherit}ul,ol{list-style:none}img{max-width:100%;display:block}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}button:focus:not(:focus-visible),a:focus:not(:focus-visible),input:focus:not(:focus-visible),select:focus:not(:focus-visible),textarea:focus:not(:focus-visible){outline:none}@media (prefers-reduced-motion:no-preference){html{scroll-behavior:smooth}}
