*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #0F4C5C;--secondary: #E8AA42;--success: #2D6A4F;--danger: #C1292E;--bg: #F5F5F0;--surface: #FFFFFF;--text: #1A1A2E;--text-light: #777;--radius: 14px;--shadow: 0 1px 3px rgba(0,0,0,.06), 0 4px 12px rgba(0,0,0,.04)}html{font-size:16px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent}[dir=rtl] body,[dir=rtl]{font-family:Noto Sans Arabic,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.7}.app{max-width:480px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;background:var(--bg)}.page-content{flex:1;overflow-y:auto;padding-bottom:80px}.page{padding:16px}.navbar{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;display:flex;justify-content:space-around;background:#ffffffeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(0,0,0,.06);padding:6px 0 env(safe-area-inset-bottom,8px);z-index:100}.nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;border:none;background:none;cursor:pointer;padding:4px 8px;font-size:.7rem;color:var(--text-light);transition:color .2s}.nav-item.active{color:var(--primary);font-weight:600}.nav-icon{font-size:1.3rem}.nav-label{font-size:.65rem}.page-header{text-align:center;padding:12px 0 16px}.page-header h1{font-size:1.4rem;color:var(--primary)}.subtitle{font-size:.9rem;color:var(--text-light);margin-top:4px}.section-title{font-size:.8rem;font-weight:700;color:var(--text-light);text-transform:uppercase;letter-spacing:.8px;margin:20px 0 10px}.state-badge{display:inline-flex;align-items:center;gap:6px;margin-top:8px;padding:4px 12px;background:linear-gradient(135deg,#e8f4f8,#dbeef5);border:1px solid #c5dde6;border-radius:20px;font-size:.85rem;color:var(--primary);font-weight:500}.state-badge-icon{font-size:1.1rem}.exam-state-badge{margin-top:4px;font-size:.95rem;padding:6px 16px}.onboarding{display:flex;flex-direction:column;align-items:center;padding:40px 20px;text-align:center}.onboarding-logo{font-size:4rem;margin-bottom:16px}.onboarding h1{font-size:1.6rem;color:var(--primary)}.onboarding h2{font-size:1.2rem;color:var(--text-light);margin-top:4px}.onboarding-subtitle{font-weight:400}.onboarding-hint{font-size:.85rem;color:var(--text-light);margin:16px 0}.lang-list{width:100%;max-width:320px;display:flex;flex-direction:column;gap:10px;margin-top:16px}.lang-btn{display:flex;align-items:center;gap:12px;width:100%;padding:14px 20px;border:2px solid #e5e5e5;border-radius:var(--radius);background:var(--surface);font-size:1.1rem;cursor:pointer;transition:all .2s}.lang-btn:hover{border-color:var(--primary);background:#f0f8f9}.lang-flag{font-size:1.5rem}.state-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;max-width:360px;margin-top:16px}.state-btn{padding:14px;border:2px solid #e5e5e5;border-radius:var(--radius);background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;font-size:.95rem;transition:all .2s}.state-btn:not(.locked):hover{border-color:var(--primary);background:#f0f8f9}.state-btn.locked{opacity:.5;cursor:not-allowed;background:#f5f5f5}.state-check{color:var(--success);font-weight:700}.state-lock{font-size:.8rem}.card-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.card-grid-3{grid-template-columns:repeat(3,1fr);gap:10px}@media(max-width:360px){.card-grid-3{grid-template-columns:1fr 1fr}}.home-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 8px;border:none;border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow);cursor:pointer;transition:transform .2s;text-align:center}.home-card:active{transform:scale(.97)}.home-card-icon{font-size:1.6rem}.home-card-title{font-size:.85rem;font-weight:600;color:var(--primary);line-height:1.2}.home-card-info{font-size:.75rem;color:var(--text-light)}.today-card{display:flex;align-items:center;justify-content:space-between;padding:16px;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:12px}.today-left{display:flex;align-items:center;gap:12px}.today-ring{position:relative;width:52px;height:52px}.ring-svg{width:100%;height:100%;transform:rotate(-90deg)}.ring-bg{fill:none;stroke:#e5e5e5;stroke-width:3}.ring-fill{fill:none;stroke:var(--secondary);stroke-width:3;stroke-linecap:round;transition:stroke-dasharray .4s ease}.ring-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.7rem;font-weight:700;color:var(--text)}.today-info{display:flex;flex-direction:column;gap:2px}.today-label{font-size:.9rem;font-weight:600;color:var(--text)}.today-detail{font-size:.8rem;color:var(--text-light)}.streak-badge{background:#fff3e0;color:#e65100;padding:6px 12px;border-radius:20px;font-size:.85rem;font-weight:700;white-space:nowrap}.total-progress-card{padding:14px;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:16px;width:100%;border:none;text-align:start;cursor:default}.total-progress-card.clickable{cursor:pointer;transition:transform .1s}.total-progress-card.clickable:active{transform:scale(.98)}.total-progress-row{display:flex;justify-content:space-between;margin-bottom:6px}.total-progress-label{font-size:.9rem;font-weight:600;color:var(--text)}.total-progress-pct{font-size:.9rem;font-weight:700;color:var(--primary)}.success-text{color:var(--success)}.danger-text{color:var(--danger)}.success-fill{background:var(--success)}.danger-fill{background:var(--danger)}.total-progress-title{display:block;font-size:.95rem;font-weight:700;color:var(--primary);margin-bottom:8px}.total-stacked-bar{height:10px;border-radius:5px}.total-legend{display:flex;gap:12px;font-size:.8rem;margin-top:4px}.total-progress-detail{display:block;font-size:.8rem;color:var(--text-light);margin-top:8px;text-align:center}.progress-bar{height:8px;background:#e5e5e5;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:var(--primary);border-radius:4px;transition:width .4s ease;min-width:0}.category-list{display:flex;flex-direction:column;gap:8px}.category-item{display:flex;align-items:center;gap:10px;padding:12px;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);border:none;width:100%;text-align:start;font:inherit;cursor:pointer;transition:transform .15s}.category-item:active{transform:scale(.98)}.cat-icon{font-size:1.3rem}.cat-info{flex:1;display:flex;flex-direction:column;gap:4px}.cat-name{font-size:.9rem}.cat-progress-bar{height:6px;background:#e5e5e5;border-radius:3px;overflow:hidden}.cat-progress-fill{height:100%;background:var(--primary);border-radius:3px;transition:width .4s ease}.cat-pct{font-size:.85rem;font-weight:700;color:var(--primary);min-width:36px;text-align:end}.cat-stacked-bar{display:flex;height:8px;border-radius:4px;overflow:hidden;background:#e5e5e5}.cat-seg{height:100%;transition:width .4s ease}.cat-seg-correct{background:var(--success)}.cat-seg-wrong{background:var(--danger)}.cat-seg-open{background:#e0e0e0}.cat-legend{display:flex;gap:10px;font-size:.72rem;margin-top:2px}.cat-legend-item{font-weight:600}.muted-text{color:#999}.today-goal{font-size:.7rem;color:#999}.cat-filter-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.cat-filter-btn{padding:5px 10px;border:1.5px solid #ccc;border-radius:16px;background:#fff;font-size:.7rem;color:#666;cursor:pointer;transition:all .2s}.cat-filter-btn.active{border-color:var(--primary);background:var(--primary);color:#fff;font-weight:600}.filter-row{display:flex;gap:6px;overflow-x:auto;padding-bottom:8px;margin-bottom:12px}.filter-btn{padding:6px 14px;border:1px solid #ddd;border-radius:20px;background:var(--surface);font-size:.85rem;cursor:pointer;white-space:nowrap;transition:all .2s}.filter-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.learn-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.question-progress{font-size:.85rem;color:var(--text-light)}.shuffle-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 14px;border:1.5px solid var(--primary);border-radius:20px;background:transparent;color:var(--primary);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s ease}.shuffle-btn:active{transform:scale(.95)}.shuffle-btn.shuffled{border-color:var(--success);color:var(--success)}.question-card{background:var(--surface);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);margin-bottom:12px}.question-de{font-size:1.05rem;font-weight:600;line-height:1.5}.question-translated{font-size:.95rem;color:var(--text-light);margin-top:8px;font-style:italic;line-height:1.6}.answers{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.answer-btn{display:flex;flex-direction:column;gap:2px;padding:14px;border:2px solid #e5e5e5;border-radius:var(--radius);background:var(--surface);cursor:pointer;text-align:start;transition:all .2s}.answer-btn:hover{border-color:var(--primary)}.answer-btn.correct{border-color:var(--success);background:#e8f5e9}.answer-btn.wrong{border-color:var(--danger);background:#ffebee}.answer-de{font-size:.95rem;font-weight:500}.answer-translated{font-size:.85rem;color:var(--text-light)}.result-box{padding:16px;border-radius:var(--radius);margin-top:8px}.result-box.correct{background:#e8f5e9;border:2px solid var(--success)}.result-box.wrong{background:#ffebee;border:2px solid var(--danger)}.result-label{font-size:1.1rem;font-weight:700;margin-bottom:8px}.result-box.correct .result-label{color:var(--success)}.result-box.wrong .result-label{color:var(--danger)}.explanation-label{font-size:.85rem;font-weight:600;color:var(--text-light);margin-bottom:4px}.explanation-de{font-size:.9rem;line-height:1.5}.explanation-translated{font-size:.85rem;color:var(--text-light);font-style:italic;margin-top:4px;line-height:1.6}.learn-nav-row{display:flex;gap:10px;margin-top:14px}.learn-nav-row.standalone{margin-top:10px}.next-btn{display:block;flex:1;padding:12px;border:none;border-radius:var(--radius);background:var(--primary);color:#fff;font-size:1rem;font-weight:600;cursor:pointer}.next-btn:active{opacity:.9}.prev-btn{padding:12px 18px;border:2px solid var(--primary);border-radius:var(--radius);background:#fff;color:var(--primary);font-size:1rem;font-weight:600;cursor:pointer}.prev-btn:active{opacity:.8}.back-btn{border:none;background:none;color:var(--primary);font-size:1rem;cursor:pointer;padding:8px 0;font-weight:600}.fish-detail{margin-top:12px}.fish-detail-img{display:flex;justify-content:center;padding:0;background:#fff;border-radius:var(--radius);margin-bottom:12px}.fish-detail-img .fish-image-frame{border:none;box-shadow:none;background:transparent;width:100%!important;height:auto!important;aspect-ratio:3 / 2}.fish-detail h1{font-size:1.5rem;color:var(--primary)}.fish-subtitle{font-size:1rem;color:var(--text-light);margin-top:2px}.fish-latin{font-size:.9rem;color:var(--text-light);margin-top:4px}.detail-section{margin-top:16px;padding:12px;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow)}.detail-section h3{font-size:.85rem;color:var(--primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.detail-section p{font-size:.95rem;line-height:1.5}.fish-list{display:flex;flex-direction:column;gap:6px}.fish-item{display:flex;align-items:center;justify-content:space-between;padding:14px;border:none;border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow);cursor:pointer;text-align:start;width:100%;transition:transform .1s}.fish-item:active{transform:scale(.98)}.fish-item-thumb{flex-shrink:0;width:60px;display:flex;align-items:center;justify-content:center;margin-right:10px}.fish-item-info{display:flex;flex-direction:column;gap:2px;flex:1}.fish-name{font-size:1rem;font-weight:600}.fish-name-de{font-size:.85rem;color:var(--text-light)}.fish-latin-small{font-size:.8rem;color:var(--text-light)}.fish-arrow{font-size:1.3rem;color:var(--text-light)}.family-filter{flex-wrap:wrap;gap:6px;margin-bottom:16px}.fish-family-group{margin-bottom:20px}.fish-family-header{font-size:.95rem;font-weight:700;color:var(--primary);padding:8px 0 6px;border-bottom:2px solid var(--primary);margin-bottom:8px;opacity:.85}.season-card{padding:14px;margin-bottom:8px;border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow);border-inline-start:4px solid}.season-card.protected{border-color:var(--danger)}.season-card.open{border-color:var(--success)}.season-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:6px}.season-name{font-weight:600;font-size:1rem}.season-name-de{font-size:.85rem;color:var(--text-light)}.season-badge{padding:2px 10px;border-radius:12px;font-size:.75rem;font-weight:600;margin-inline-start:auto}.season-badge.protected{background:#ffebee;color:var(--danger)}.season-badge.open{background:#e8f5e9;color:var(--success)}.season-info{display:flex;flex-direction:column;gap:2px;font-size:.85rem;color:var(--text-light)}.season-disclaimer{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:#0f4c5c0f;border:1.5px solid rgba(15,76,92,.2);border-radius:var(--radius);margin-bottom:16px}.season-disclaimer-icon{font-size:1.1rem;flex-shrink:0;margin-top:2px}.season-disclaimer-text{font-size:.8rem;line-height:1.5;color:var(--text-muted);margin:0}.season-alert{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:#e8aa4214;border:1.5px solid rgba(232,170,66,.3);border-radius:var(--radius);margin-bottom:16px}.season-alert-icon{font-size:1.3rem;flex-shrink:0;margin-top:1px}.season-alert-text{font-size:.85rem;line-height:1.5;color:var(--text)}.season-alert-text strong{color:#bf5f00}.season-calendar{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);overflow-x:auto;margin-bottom:12px}.season-cal-header{display:flex;align-items:center;padding:10px 8px 8px;border-bottom:2px solid rgba(0,0,0,.06);position:sticky;top:0;background:var(--surface);z-index:2}.season-cal-name-col{min-width:100px;max-width:110px;flex-shrink:0;display:flex;flex-direction:column;padding-right:6px}.season-cal-month{flex:1;text-align:center;font-size:.62rem;font-weight:700;color:var(--text-light);padding:3px 0}.season-cal-month.current{color:var(--primary);background:#0f4c5c1a;border-radius:6px;font-weight:800}.season-cal-row{display:flex;align-items:center;padding:7px 8px;gap:0;border:none;background:none;width:100%;cursor:pointer;border-bottom:1px solid rgba(0,0,0,.04);transition:background .15s;text-align:start}.season-cal-row:hover{background:#00000005}.season-cal-row:active{background:#0000000a}.season-cal-row:last-child{border-bottom:none}.season-cal-fish-name{font-size:.74rem;font-weight:600;color:var(--text);line-height:1.25;word-break:break-word;-webkit-hyphens:auto;hyphens:auto}.season-cal-min{font-size:.6rem;color:var(--text-light);margin-top:1px}.season-cal-cell{flex:1;height:8px;max-width:none;margin:0 .5px;border-radius:2px;transition:all .2s}.season-cal-cell:first-of-type{border-radius:4px 2px 2px 4px}.season-cal-cell:last-of-type{border-radius:2px 4px 4px 2px}.season-cal-cell.protected{background:#c1292e80}.season-cal-cell.open{background:#2d6a4f4d}.season-cal-cell.no-season{background:#0000000f}.season-cal-cell.current{box-shadow:0 0 0 2px var(--primary);border-radius:3px;z-index:1;position:relative}.season-cal-legend{display:flex;justify-content:center;gap:16px;padding:10px 0;margin-bottom:16px}.season-legend-item{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--text-light)}.season-legend-item:before{content:"";display:block;width:14px;height:8px;border-radius:3px}.season-legend-item.protected:before{background:#c1292e80}.season-legend-item.open:before{background:#2d6a4f4d}.season-legend-item.no-season:before{background:#0000000f}.fish-image-frame{display:flex;align-items:center;justify-content:center;background:#fff;border-radius:var(--radius);border:1px solid rgba(0,0,0,.06);box-shadow:0 1px 4px #0000000f;overflow:hidden;max-width:100%}.fish-image-photo{width:100%;height:100%;object-fit:contain;object-position:center;display:block;padding:2px}.fish-image-placeholder{background:linear-gradient(135deg,#eee,#e0e0e0)}.season-detail-header{text-align:center;margin-bottom:16px}.season-detail-img{display:flex;justify-content:center;padding:20px 0;background:linear-gradient(135deg,#f0f4f8,#e8eef3);border-radius:var(--radius);margin-bottom:12px}.season-detail-header h2{font-size:1.4rem;color:var(--primary)}.season-detail-de{font-size:.95rem;color:var(--text-light)}.season-months-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;margin-bottom:16px}.season-months-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:4px;margin-bottom:10px}.season-month-cell{aspect-ratio:1;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;transition:all .2s}.season-month-cell.protected{background:#c1292e26;color:var(--danger)}.season-month-cell.open{background:#2d6a4f1a;color:var(--success)}.season-month-cell.current{box-shadow:inset 0 0 0 2.5px var(--primary)}.season-detail-legend{display:flex;justify-content:center;gap:16px}.season-info-cards{display:grid;grid-template-columns:1fr 1fr;gap:8px}.season-info-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px;display:flex;flex-direction:column;gap:4px}.season-info-label{font-size:.78rem;color:var(--text-light)}.season-info-value{font-size:1.05rem;font-weight:700;color:var(--primary)}.season-status-card{grid-column:1 / -1;padding:14px;border-radius:var(--radius);text-align:center;font-weight:700;font-size:.95rem}.season-status-card.protected{background:#c1292e14;color:var(--danger);border:1px solid rgba(193,41,46,.2)}.season-status-card.open{background:#2d6a4f14;color:var(--success);border:1px solid rgba(45,106,79,.2)}.search-input{width:100%;padding:12px 16px;border:2px solid #e5e5e5;border-radius:var(--radius);font-size:1rem;background:var(--surface);margin-bottom:12px;outline:none;transition:border-color .2s}.search-input:focus{border-color:var(--primary)}[dir=rtl] .search-input{text-align:right}.no-results{text-align:center;color:var(--text-light);padding:40px 0}.search-results-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.search-fish-card{padding:12px;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow)}.search-fish-clickable,.search-question-clickable{width:100%;border:none;cursor:pointer;text-align:left;font:inherit;color:inherit;transition:transform .15s,box-shadow .15s;position:relative}.search-fish-clickable:active,.search-question-clickable:active{transform:scale(.98)}.search-fish-thumb{flex-shrink:0;width:56px;height:28px;display:flex;align-items:center;justify-content:center}.search-card-arrow{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:1.4rem;color:var(--text-light);opacity:.5}.search-fish-top{display:flex;align-items:center;gap:10px}.search-fish-name-col{display:flex;flex-direction:column;gap:1px}.search-season-badge{flex-shrink:0;padding:2px 8px;border-radius:10px;font-size:.7rem;font-weight:600;white-space:nowrap}.search-season-badge.protected{background:#ffebee;color:var(--danger)}.search-season-badge.open{background:#e8f5e9;color:var(--success)}.search-season-row{display:flex;justify-content:space-between;margin-top:6px;padding-top:6px;border-top:1px solid #f0f0f0;font-size:.78rem;color:var(--text-light)}.search-result-habitat{font-size:.85rem;color:var(--text-light);line-height:1.4}.search-question-card{padding:12px;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow)}.search-q-cat{font-size:.75rem;color:var(--text-light);display:block;margin-bottom:4px}.search-q-text{font-size:.95rem;font-weight:500;line-height:1.4;margin-bottom:4px}.search-q-de{font-size:.82rem;color:var(--text-light);font-style:italic;margin-bottom:6px}.search-q-answer{font-size:.82rem;font-weight:600;color:var(--success);padding:4px 8px;background:#2d6a4f14;border-radius:6px;display:inline-block}.search-glossary-def{color:var(--text);font-weight:400;background:#00000008}.search-exam-badge{display:inline-block;font-size:.72rem;font-weight:600;padding:2px 8px;border-radius:10px;background:var(--accent);color:#fff;margin-top:4px}.settings-section{margin-bottom:24px}.settings-section h2{font-size:1rem;color:var(--primary);margin-bottom:8px}.settings-current{font-size:.9rem;color:var(--text-light);margin-bottom:8px}.settings-options{display:flex;gap:8px;flex-wrap:wrap}.settings-btn{padding:10px 16px;border:2px solid #e5e5e5;border-radius:var(--radius);background:var(--surface);cursor:pointer;font-size:.95rem;transition:all .2s}.settings-btn.active{border-color:var(--primary);background:var(--primary);color:#fff}.settings-input{width:100%;padding:12px 16px;border:2px solid #e5e5e5;border-radius:var(--radius);background:var(--surface);font-size:.95rem;color:var(--text);font-family:inherit;transition:border-color .2s}.settings-input:focus{outline:none;border-color:var(--primary)}.settings-input::placeholder{color:#bbb}[data-theme=dark] .settings-input{background:var(--surface);border-color:#444}[dir=rtl] .settings-input{text-align:right}.reset-btn{padding:12px 24px;border:2px solid var(--danger);border-radius:var(--radius);background:none;color:var(--danger);font-size:.95rem;font-weight:600;cursor:pointer}.reset-btn:hover{background:#ffebee}.reset-confirm{background:#fff8f8;border:1.5px solid var(--danger);border-radius:var(--radius);padding:16px}.reset-confirm-text{font-size:.9rem;color:var(--danger);margin-bottom:12px;line-height:1.5}.reset-confirm-btns{display:flex;gap:8px}.settings-link-btn{width:100%;padding:12px 16px;border:none;border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow);font-size:.9rem;color:var(--primary);font-weight:600;cursor:pointer;text-align:left}.settings-link-btn:active{opacity:.8}[dir=rtl] .settings-link-btn{text-align:right}.settings-app-info{margin-top:32px;padding-top:16px;border-top:1px solid #eee;display:flex;flex-direction:column;align-items:center;gap:4px;font-size:.75rem;color:#bbb}.error-report-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:900;display:flex;align-items:center;justify-content:center;padding:16px}.error-report-dialog{background:var(--surface);border-radius:var(--radius);padding:20px;max-width:400px;width:100%;box-shadow:0 8px 32px #0003;animation:card-enter .2s ease-out}.error-report-dialog h3{font-size:1.1rem;margin-bottom:8px;color:var(--primary)}.error-report-desc{font-size:.85rem;color:var(--text-light);margin-bottom:12px;line-height:1.4}.error-report-label{font-size:.8rem;font-weight:600;color:var(--text-light);margin-bottom:6px;display:block}.error-report-sections{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:12px}.error-report-section-btn{padding:4px 10px;border:1px solid #ddd;border-radius:20px;background:var(--bg);font-size:.75rem;color:var(--text-light);cursor:pointer}.error-report-section-btn.active{border-color:var(--primary);background:var(--primary);color:#fff}.error-report-textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:8px;font-size:.9rem;resize:vertical;font-family:inherit;background:var(--bg);color:var(--text);margin-bottom:12px}.error-report-actions{display:flex;gap:8px;justify-content:flex-end}.error-report-cancel{padding:8px 16px;border:1px solid #ddd;border-radius:8px;background:var(--surface);font-size:.9rem;cursor:pointer;color:var(--text-light)}.error-report-send{padding:8px 20px;border:none;border-radius:8px;background:var(--primary);color:#fff;font-size:.9rem;font-weight:600;cursor:pointer}.error-report-send:disabled{opacity:.4;cursor:not-allowed}.error-report-thanks{text-align:center;padding:20px 0;font-size:1rem;font-weight:500;color:var(--success)}.error-report-close{display:block;margin:0 auto;padding:8px 24px;border:none;border-radius:8px;background:var(--primary);color:#fff;font-size:.95rem;cursor:pointer}.error-report-fab{position:fixed;bottom:80px;right:16px;z-index:50;width:44px;height:44px;border-radius:50%;background:var(--secondary);color:#fff;border:none;box-shadow:0 2px 8px #0003;font-size:1.2rem;display:flex;align-items:center;justify-content:center;cursor:pointer}.progress-question-list{display:flex;flex-direction:column;gap:8px}.progress-question-item{padding:12px;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);border-inline-start:4px solid #e5e5e5}.progress-question-item.correct{border-color:var(--success)}.progress-question-item.wrong{border-color:var(--danger)}.pq-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.pq-cat{font-size:.8rem;color:var(--text-light)}.pq-status-badge{font-size:.85rem;font-weight:700;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%}.pq-status-badge.correct{background:#e8f5e9;color:var(--success)}.pq-status-badge.wrong{background:#ffebee;color:var(--danger)}.pq-status-badge.unanswered{background:#f5f5f5;color:var(--text-light)}.pq-text{font-size:.95rem;font-weight:500;line-height:1.4}.pq-text-translated{font-size:.85rem;color:var(--text-light);font-style:italic;margin-top:4px;line-height:1.5}.pq-attempts{font-size:.8rem;color:var(--text-light);margin-top:6px}.pq-toggle{width:100%;border:none;background:none;cursor:pointer;text-align:start;padding:0;position:relative}.pq-expand-hint{position:absolute;bottom:0;right:0;font-size:.7rem;color:var(--text-light)}[dir=rtl] .pq-expand-hint{right:auto;left:0}.pq-answers-section{margin-top:12px;padding-top:12px;border-top:1px solid #e5e5e5}.relearn-btn{display:block;width:100%;margin-top:10px;padding:10px;border:2px solid var(--secondary);border-radius:var(--radius);background:#fff9f0;color:#a06800;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.relearn-btn:active{background:#fff3e0}.toast{position:fixed;bottom:90px;left:50%;transform:translate(-50%);background:var(--text);color:#fff;padding:10px 20px;border-radius:20px;font-size:.85rem;font-weight:600;z-index:200;animation:toast-fade 2s ease-in-out}@keyframes toast-fade{0%{opacity:0;transform:translate(-50%) translateY(10px)}15%{opacity:1;transform:translate(-50%) translateY(0)}85%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-10px)}}.filter-btn.danger-active{background:var(--danger);color:#fff;border-color:var(--danger)}.filter-btn.success-active{background:var(--success);color:#fff;border-color:var(--success)}.exam-intro-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;margin-bottom:16px}.exam-intro-row{display:flex;align-items:center;gap:12px;padding:10px 0}.exam-intro-row+.exam-intro-row{border-top:1px solid #eee}.exam-intro-icon{font-size:1.4rem}.exam-intro-label{display:block;font-size:.75rem;color:var(--text-light)}.exam-intro-value{display:block;font-size:1rem;font-weight:700;color:var(--primary)}.exam-intro-note{display:block;font-size:.7rem;color:var(--danger)}.exam-start-btn{display:block;width:100%;padding:14px;border:none;border-radius:var(--radius);background:var(--primary);color:#fff;font-size:1.05rem;font-weight:700;cursor:pointer;margin-bottom:20px;transition:transform .1s}.exam-start-btn:active{transform:scale(.98)}.exam-topbar{display:flex;justify-content:space-between;align-items:center;padding:8px 0;margin-bottom:8px;font-size:.85rem;font-weight:600}.exam-timer{color:var(--primary);font-size:1.1rem;font-weight:700}.exam-timer.timer-low{color:var(--danger);animation:timer-pulse .8s ease-in-out infinite}.exam-counter{color:var(--text)}.exam-answered{color:var(--text-light);font-size:.75rem}.exam-progress-bar{height:4px;background:#e5e5e5;border-radius:2px;overflow:hidden;margin-bottom:14px}.exam-progress-fill{height:100%;background:var(--primary);border-radius:2px;transition:width .3s ease}.exam-question-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;margin-bottom:14px}.exam-q-cat{font-size:.75rem;color:var(--text-light);display:block;margin-bottom:8px}.exam-q-text{font-size:1rem;font-weight:600;color:var(--text);margin-bottom:6px}.exam-q-translated{font-size:.85rem;color:var(--text-light);font-style:italic;margin-bottom:12px}.exam-question-card .answer-btn.selected{border-color:var(--secondary);background:#e8aa421f;box-shadow:0 0 0 2px #e8aa4240}.exam-nav-row{display:flex;gap:10px;margin-bottom:14px}.exam-nav-btn{flex:1;padding:10px;border:1.5px solid #ccc;border-radius:var(--radius);background:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s}.exam-nav-btn:disabled{opacity:.4;cursor:default}.exam-nav-btn.primary{border-color:var(--primary);background:var(--primary);color:#fff}.exam-nav-btn.finish{border-color:var(--success);background:var(--success);color:#fff}.exam-dots{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;padding-bottom:16px}.exam-dot{width:28px;height:28px;border:1.5px solid #ccc;border-radius:50%;background:#fff;font-size:.65rem;font-weight:600;color:#999;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.exam-dot.answered{background:var(--primary);color:#fff;border-color:var(--primary)}.exam-dot.current{border-color:var(--accent);border-width:2.5px}.exam-result-card{text-align:center;padding:24px 16px;border-radius:var(--radius);margin-bottom:20px}.exam-result-card.passed{background:#2d6a4f14;border:2px solid var(--success)}.exam-result-card.failed{background:#c1292e14;border:2px solid var(--danger)}.exam-result-score{font-size:3rem;font-weight:800}.exam-result-card.passed .exam-result-score{color:var(--success)}.exam-result-card.failed .exam-result-score{color:var(--danger)}.exam-result-detail{font-size:.9rem;color:var(--text);margin-top:4px}.exam-result-threshold{font-size:.8rem;color:var(--text-light);margin-top:8px}.exam-review-list{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.exam-review-item{display:flex;flex-direction:column;gap:4px;padding:10px 12px;border-radius:8px;background:var(--surface)}.exam-review-item.correct{border-left:3px solid var(--success)}.exam-review-item.wrong{border-left:3px solid var(--danger)}.exam-review-header{display:flex;align-items:center;gap:6px}.exam-review-num{font-size:.75rem;font-weight:700;color:var(--text-light)}.exam-review-cat{font-size:.8rem}.exam-review-badge{font-size:.8rem;margin-left:auto}.exam-review-badge.correct{color:var(--success)}.exam-review-badge.wrong{color:var(--danger)}.exam-review-q{font-size:.85rem;color:var(--text)}.exam-review-user-answer{font-size:.8rem;color:var(--danger);text-decoration:line-through;opacity:.8;margin-bottom:2px}.exam-review-correct{font-size:.8rem;color:var(--success);font-weight:600}.exam-review-correct.was-correct{color:var(--text-light);font-weight:500}.exam-fish-image{display:flex;justify-content:center;padding:20px 12px;margin-bottom:12px;background:#fff;border:1px solid var(--border);border-radius:var(--radius)}.exam-fish-image img,.exam-fish-img{max-width:100%;width:auto;height:auto;max-height:300px;object-fit:contain}.exam-image-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 16px;margin-bottom:12px;background:linear-gradient(135deg,#f5f5f5,#ebebeb);border-radius:var(--radius);border:2px dashed #ccc}.exam-image-placeholder-icon{font-size:2rem;opacity:.5}.exam-image-placeholder-text{font-size:.75rem;color:var(--text-light);text-align:center}.exam-history-list{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.exam-history-item{padding:10px 12px;border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow)}.exam-history-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.exam-history-badge{font-size:.75rem;font-weight:700;padding:2px 8px;border-radius:10px}.exam-history-badge.passed{background:#2d6a4f1f;color:var(--success)}.exam-history-badge.failed{background:#c1292e1f;color:var(--danger)}.exam-history-date{font-size:.75rem;color:var(--text-light)}.exam-history-stats{display:flex;gap:16px;font-size:.8rem;color:var(--text)}.exam-chart-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;margin-top:20px}.exam-chart-title{font-size:.9rem;color:var(--primary);font-weight:600;margin-bottom:12px}.exam-chart{position:relative;height:160px}.exam-chart-threshold{position:absolute;left:0;right:0;border-top:2px dashed var(--success);z-index:1;pointer-events:none}.exam-chart-threshold-label{position:absolute;top:-10px;left:0;font-size:.65rem;color:var(--success);font-weight:700;background:var(--surface);padding:0 4px}.exam-chart-bars{display:flex;align-items:flex-end;justify-content:center;gap:6px;height:100%;padding-bottom:22px}.exam-chart-col{flex:1;max-width:40px;display:flex;flex-direction:column;align-items:center;height:100%}.exam-chart-bar-wrap{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center}.exam-chart-bar{width:100%;border-radius:4px 4px 0 0;min-height:8px;display:flex;align-items:flex-start;justify-content:center;transition:height .4s ease}.exam-chart-bar.passed{background:linear-gradient(180deg,#2d6a4f,#40916c)}.exam-chart-bar.failed{background:linear-gradient(180deg,#c1292e,#e05a5a)}.exam-chart-bar-val{font-size:.6rem;font-weight:700;color:#fff;padding-top:3px}.exam-chart-date{font-size:.55rem;color:var(--text-light);margin-top:3px;white-space:nowrap}.quiz-intro-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;text-align:center;margin-bottom:16px}.quiz-intro-fish{display:flex;justify-content:center;padding:12px 0;background:linear-gradient(135deg,#f0f4f8,#e8eef3);border-radius:8px;margin-bottom:12px}.quiz-intro-text{font-size:.95rem;color:var(--text);line-height:1.5}.quiz-highscore-badge{margin-top:10px;font-size:.9rem;font-weight:600;color:var(--secondary)}.quiz-topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.quiz-round{font-size:.85rem;font-weight:600;color:var(--primary)}.quiz-score{font-size:.9rem;font-weight:700;color:var(--secondary)}.quiz-fish-display{display:flex;justify-content:center;padding:20px 0;background:linear-gradient(135deg,#f0f4f8,#e8eef3);border-radius:var(--radius);margin-bottom:12px}.quiz-fish-display-large{padding:24px 0;background:linear-gradient(135deg,#f0f7fa,#e4eef5);border-radius:var(--radius);margin-bottom:16px}.quiz-nav-row{display:flex;gap:8px;justify-content:center}.quiz-nav-row .prev-btn{flex:0 0 auto;padding:12px 18px;border:2px solid #e0e0e0;border-radius:var(--radius);background:var(--surface);font-size:.95rem;font-weight:600;color:var(--text-light);cursor:pointer}.quiz-nav-row .next-btn{flex:1;padding:12px 18px;border:none;border-radius:var(--radius);background:var(--primary);color:#fff;font-size:1rem;font-weight:700;cursor:pointer}.quiz-prompt{text-align:center;font-size:1.1rem;font-weight:600;color:var(--primary);margin-bottom:12px}.quiz-options{display:flex;flex-direction:column;gap:8px}.quiz-option-btn{width:100%;padding:14px 16px;border:2px solid #e0e0e0;border-radius:var(--radius);background:var(--surface);font-size:1rem;font-weight:500;color:var(--text);cursor:pointer;transition:all .2s;text-align:start}.quiz-option-btn:active:not(:disabled){transform:scale(.98)}.quiz-option-btn.correct{border-color:var(--success);background:#e8f5e9;color:var(--success);font-weight:700}.quiz-option-btn.wrong{border-color:var(--danger);background:#ffebee;color:var(--danger)}.quiz-option-btn.dimmed{opacity:.4}.quiz-feedback{text-align:center;font-size:.95rem;font-weight:600;padding:10px;border-radius:var(--radius);margin-top:12px}.quiz-feedback.correct{background:#e8f5e9;color:var(--success)}.quiz-feedback.wrong{background:#ffebee;color:var(--danger)}.quiz-fish-info{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);margin-top:12px;overflow:hidden;animation:card-enter .3s ease-out}.quiz-fish-info-header{background:var(--primary);color:#fff;padding:10px 14px;font-weight:700;font-size:.9rem}.quiz-fish-info-row{display:flex;gap:8px;padding:8px 14px;border-bottom:1px solid #f0f0f0;font-size:.85rem;line-height:1.4}.quiz-fish-info-row:last-child{border-bottom:none}.quiz-fish-info-label{flex-shrink:0;width:90px;font-weight:600;color:var(--text-light)}.quiz-fish-info-value{flex:1;color:var(--text)}[data-theme=dark] .quiz-fish-info{background:var(--surface)}[dir=rtl] .quiz-fish-info-row{direction:rtl}.quiz-dots{display:flex;justify-content:center;gap:6px;margin-top:16px;flex-wrap:wrap}.quiz-dot{width:10px;height:10px;border-radius:50%;background:#ddd}.quiz-dot.current{background:var(--primary);transform:scale(1.3)}.quiz-dot.done{background:var(--success)}.quiz-result-card{text-align:center;padding:24px;border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow);margin-bottom:16px}.quiz-result-card.great{border-top:4px solid var(--success)}.quiz-result-card.good{border-top:4px solid var(--secondary)}.quiz-result-card.needs-work{border-top:4px solid var(--danger)}.quiz-result-score{font-size:2.5rem;font-weight:800;color:var(--primary)}.quiz-result-pct{font-size:1.2rem;color:var(--text-light);margin-top:4px}.quiz-new-highscore{margin-top:12px;font-size:1.1rem;font-weight:700;color:var(--secondary);animation:highscore-pop .6s ease-in-out 3}@keyframes highscore-pop{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.quiz-old-highscore{margin-top:8px;font-size:.85rem;color:var(--text-light)}.dash-ring-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;text-align:center;margin-bottom:12px}.dash-ring{position:relative;width:140px;height:140px;margin:0 auto 16px}.dash-ring-svg{width:100%;height:100%}.dash-ring-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center}.dash-ring-pct{font-size:2rem;font-weight:800;color:var(--primary)}.dash-ring-label{font-size:.7rem;color:var(--text-light)}.dash-ring-stats{display:flex;justify-content:center;gap:24px}.dash-stat{display:flex;flex-direction:column;align-items:center}.dash-stat-num{font-size:1.3rem;font-weight:800}.dash-stat-label{font-size:.7rem;color:var(--text-light)}.dash-streak-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:16px}.dash-streak-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:12px 8px;display:flex;flex-direction:column;align-items:center;gap:2px}.dash-streak-icon{font-size:1.3rem}.dash-streak-num{font-size:1.4rem;font-weight:800;color:var(--primary)}.dash-streak-label{font-size:.65rem;color:var(--text-light);text-align:center}.dash-categories{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.dash-cat-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:12px;border:none;width:100%;text-align:start;cursor:pointer;transition:transform .1s}.dash-cat-card:active{transform:scale(.98)}.dash-cat-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.dash-cat-icon{font-size:1.2rem}.dash-cat-name{font-size:.9rem;font-weight:600;color:var(--text);flex:1}.dash-cat-pct{font-size:.9rem;font-weight:700;color:var(--primary)}.dash-cat-nums{display:flex;gap:12px;margin-top:4px;font-size:.72rem;font-weight:600}.dash-all-btn{display:block;width:100%;padding:12px;border:1.5px solid var(--primary);border-radius:var(--radius);background:transparent;color:var(--primary);font-size:.9rem;font-weight:600;cursor:pointer;text-align:center;margin-bottom:16px;transition:all .2s}.dash-all-btn:active{background:#0f4c5c0d}@keyframes page-enter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page{animation:page-enter .25s ease-out}@keyframes card-enter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.home-card,.category-item,.fish-item,.dash-cat-card,.dash-streak-card,.season-cal-row,.progress-question-item,.exam-history-item,.search-fish-card,.search-question-card,.settings-section{animation:card-enter .3s ease-out backwards}.home-card:nth-child(1),.category-item:nth-child(1),.fish-item:nth-child(1),.dash-cat-card:nth-child(1),.settings-section:nth-child(1){animation-delay:.03s}.home-card:nth-child(2),.category-item:nth-child(2),.fish-item:nth-child(2),.dash-cat-card:nth-child(2),.settings-section:nth-child(2){animation-delay:.06s}.home-card:nth-child(3),.category-item:nth-child(3),.fish-item:nth-child(3),.dash-cat-card:nth-child(3),.settings-section:nth-child(3){animation-delay:.09s}.home-card:nth-child(4),.category-item:nth-child(4),.fish-item:nth-child(4),.dash-cat-card:nth-child(4),.settings-section:nth-child(4){animation-delay:.12s}.home-card:nth-child(5),.category-item:nth-child(5),.fish-item:nth-child(5){animation-delay:.15s}.home-card:nth-child(6),.category-item:nth-child(6),.fish-item:nth-child(6){animation-delay:.18s}@keyframes ring-grow{0%{stroke-dasharray:0 326.7}}.dash-ring-svg circle:last-child{animation:ring-grow .8s ease-out}.home-card:active,.category-item:active,.dash-cat-card:active,.fish-item:active,.quiz-option-btn:active:not(:disabled),.settings-btn:active,.filter-btn:active,.cat-filter-btn:active,.lang-btn:active,.state-btn:active:not(.locked){transform:scale(.96);transition:transform .1s}button:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.answer-btn.correct{animation:answer-correct .3s ease}.answer-btn.wrong:not(.correct){animation:answer-wrong .3s ease}@keyframes answer-correct{0%{transform:scale(1)}50%{transform:scale(1.02)}to{transform:scale(1)}}@keyframes answer-wrong{0%,to{transform:translate(0)}20%,60%{transform:translate(-4px)}40%,80%{transform:translate(4px)}}@keyframes result-enter{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.result-box{animation:result-enter .3s ease-out}.quiz-feedback{animation:result-enter .25s ease-out}@keyframes onboard-logo{0%{transform:scale(.5) rotate(-10deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}.onboarding-logo{animation:onboard-logo .5s ease-out}@keyframes onboard-fade-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.onboarding h1{animation:onboard-fade-up .4s ease-out .1s backwards}.onboarding h2{animation:onboard-fade-up .4s ease-out .2s backwards}.onboarding-hint{animation:onboard-fade-up .4s ease-out .3s backwards}.lang-list{animation:onboard-fade-up .4s ease-out .4s backwards}.state-grid{animation:onboard-fade-up .4s ease-out .2s backwards}@keyframes alert-enter{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.season-alert{animation:alert-enter .3s ease-out}.exam-timer.timer-low{animation:timer-pulse .8s ease-in-out infinite}@keyframes timer-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.05)}}.page-content::-webkit-scrollbar{width:4px}.page-content::-webkit-scrollbar-track{background:transparent}.page-content::-webkit-scrollbar-thumb{background:#00000026;border-radius:2px}.season-calendar::-webkit-scrollbar{height:3px}.season-calendar::-webkit-scrollbar-thumb{background:#0000001f;border-radius:2px}.disclaimer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:200;display:flex;align-items:center;justify-content:center;padding:16px;animation:page-enter .2s ease-out}.disclaimer-modal{background:var(--surface);border-radius:16px;max-width:420px;width:100%;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 32px #0003}.disclaimer-modal-header{padding:16px 20px;font-size:1.05rem;font-weight:700;background:var(--primary);color:#fff}.disclaimer-modal-body{padding:16px 20px;overflow-y:auto;flex:1;font-size:.88rem;line-height:1.6;color:var(--text)}.disclaimer-modal-body p{margin-bottom:12px}.disclaimer-accept-btn{margin:12px 20px 16px;padding:14px;border:none;border-radius:var(--radius);background:var(--success);color:#fff;font-size:1rem;font-weight:700;cursor:pointer}.disclaimer-accept-btn:active{opacity:.9}.disclaimer-content{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;font-size:.88rem;line-height:1.6}.disclaimer-content h2{font-size:.95rem;color:var(--primary);margin:20px 0 8px}.disclaimer-content h2:first-child{margin-top:0}.disclaimer-content p{margin-bottom:12px;color:var(--text)}[data-theme=dark] .disclaimer-modal,[data-theme=dark] .disclaimer-content{background:var(--surface)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}[dir=rtl] .back-btn,[dir=rtl] .next-btn{direction:rtl}[dir=rtl] .exam-review-item.correct{border-left:none;border-right:3px solid var(--success)}[dir=rtl] .exam-review-item.wrong{border-left:none;border-right:3px solid var(--danger)}[dir=rtl] .progress-question-item{border-inline-start:4px solid #e5e5e5}[dir=rtl] .progress-question-item.correct{border-color:var(--success)}[dir=rtl] .progress-question-item.wrong{border-color:var(--danger)}[data-theme=dark]{--bg: #121218;--surface: #1E1E2A;--text: #F0F0F5;--text-light: #A0A0B5;--primary: #1A7A8A;--success: #3DA06A;--danger: #E04448;--shadow: 0 2px 8px rgba(0,0,0,.35)}[data-theme=dark] body{background:var(--bg);color:var(--text)}[data-theme=dark] .navbar{background:#18181feb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top-color:#ffffff0f}[data-theme=dark] .nav-item{color:#8888a0}[data-theme=dark] .nav-item.active{color:var(--secondary)}[data-theme=dark] .answer-btn{border-color:#444;background:var(--surface)}[data-theme=dark] .answer-btn:hover{border-color:var(--secondary)}[data-theme=dark] .answer-btn.correct{background:#2d6a4f33;border-color:var(--success)}[data-theme=dark] .answer-btn.wrong{background:#c1292e33;border-color:var(--danger)}[data-theme=dark] .filter-btn,[data-theme=dark] .cat-filter-btn{border-color:#444;background:var(--surface);color:var(--text-light)}[data-theme=dark] .search-input{border-color:#444;background:var(--surface);color:var(--text)}[data-theme=dark] .search-input::placeholder{color:#666}[data-theme=dark] .result-box.correct{background:#2d6a4f26;border-color:var(--success)}[data-theme=dark] .result-box.wrong{background:#c1292e26;border-color:var(--danger)}[data-theme=dark] .lang-btn{border-color:#444;background:var(--surface);color:var(--text)}[data-theme=dark] .lang-btn:hover{border-color:var(--secondary);background:#e8aa421a}[data-theme=dark] .state-btn{border-color:#444;background:var(--surface);color:var(--text)}[data-theme=dark] .state-btn:not(.locked):hover{border-color:var(--secondary);background:#e8aa421a}[data-theme=dark] .state-btn.locked{background:#1e1e30}[data-theme=dark] .settings-btn{border-color:#444;background:var(--surface);color:var(--text)}[data-theme=dark] .settings-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}[data-theme=dark] .settings-input{background:var(--surface);border-color:#444;color:var(--text)}[data-theme=dark] .settings-input::placeholder{color:#666}[data-theme=dark] .ring-bg{stroke:#333}[data-theme=dark] .cat-stacked-bar,[data-theme=dark] .cat-seg-open,[data-theme=dark] .progress-bar{background:#333}[data-theme=dark] .streak-badge{background:#e8aa4226;color:var(--secondary)}[data-theme=dark] .season-disclaimer{background:#0f4c5c26;border-color:#0f4c5c4d}[data-theme=dark] .season-alert{background:#e8aa421a;border-color:#e8aa424d}[data-theme=dark] .season-alert-text strong{color:var(--secondary)}[data-theme=dark] .season-cal-row{border-bottom-color:#ffffff0f}[data-theme=dark] .season-cal-row:hover{background:#ffffff05}[data-theme=dark] .season-cal-row:active{background:#ffffff0a}[data-theme=dark] .season-cal-header{background:var(--surface);border-bottom-color:#ffffff14}[data-theme=dark] .season-cal-cell.no-season{background:#ffffff14}[data-theme=dark] .season-legend-item.no-season:before{background:#ffffff14}[data-theme=dark] .season-cal-cell.protected{background:#c1292e80}[data-theme=dark] .season-cal-cell.open{background:#2d6a4f66}[data-theme=dark] .season-status-card.protected{background:#c1292e1f;border-color:#c1292e40}[data-theme=dark] .season-status-card.open{background:#2d6a4f1f;border-color:#2d6a4f40}[data-theme=dark] .state-badge{background:#0f4c5c33;border-color:#0f4c5c66}[data-theme=dark] .fish-detail-img{background:#1a1a1a;border-color:#ffffff0f}[data-theme=dark] .fish-image-frame{background:#fff;border-color:#ffffff0f}[data-theme=dark] .fish-image-placeholder{background:linear-gradient(135deg,#222,#2a2a2a)}[data-theme=dark] .season-detail-img,[data-theme=dark] .quiz-fish-display,[data-theme=dark] .quiz-intro-fish{background:linear-gradient(135deg,#1e2a38,#253040)}[data-theme=dark] .reset-confirm{background:#c1292e14;border-color:var(--danger)}[data-theme=dark] .relearn-btn{background:#e8aa421a;border-color:var(--secondary);color:var(--secondary)}[data-theme=dark] .settings-link-btn{background:var(--surface)}[data-theme=dark] .disclaimer-overlay{background:#000000b3}[data-theme=dark] .settings-app-info{border-top-color:#333;color:#555}[data-theme=dark] .exam-nav-btn{border-color:#444;background:var(--surface);color:var(--text)}[data-theme=dark] .exam-dot{border-color:#444;background:var(--surface);color:#666}[data-theme=dark] .exam-question-card .answer-btn.selected{background:#e8aa4226}[data-theme=dark] .quiz-option-btn{border-color:#444;background:var(--surface);color:var(--text)}[data-theme=dark] .quiz-option-btn.correct{background:#2d6a4f33;color:#6fcf97}[data-theme=dark] .quiz-option-btn.wrong{background:#c1292e33;color:#ef9a9a}[data-theme=dark] .quiz-feedback.correct{background:#2d6a4f26}[data-theme=dark] .quiz-feedback.wrong{background:#c1292e26}[data-theme=dark] .search-season-badge.protected{background:#c1292e33}[data-theme=dark] .search-season-badge.open{background:#2d6a4f33}[data-theme=dark] .season-badge.protected{background:#c1292e33}[data-theme=dark] .season-badge.open{background:#2d6a4f33}[data-theme=dark] .exam-result-card.passed{background:#2d6a4f1a}[data-theme=dark] .exam-result-card.failed{background:#c1292e1a}[data-theme=dark] .toast{background:var(--surface);color:var(--text)}[data-theme=dark] .search-season-row,[data-theme=dark] .pq-answers-section{border-top-color:#333}[data-theme=dark] .pq-text{color:#fff}[data-theme=dark] .pq-text-translated,[data-theme=dark] .pq-cat{color:#a0a0b5}[data-theme=dark] .pq-status-badge.correct{background:#2d6a4f33;color:var(--success)}[data-theme=dark] .pq-status-badge.wrong{background:#c8323226;color:var(--danger)}[data-theme=dark] .pq-status-badge.unanswered{background:#ffffff14;color:var(--text-light)}[data-theme=dark] .pq-attempts{color:#a0a0b5}[data-theme=dark] .progress-question-item{background:var(--surface);border-color:#ffffff1a}[data-theme=dark] .progress-question-item.correct{border-color:#2d6a4f4d}[data-theme=dark] .progress-question-item.wrong{border-color:#c832324d}[data-theme=dark] .exam-progress-bar{background:#333}[data-theme=dark] .exam-history-badge.passed{background:#2d6a4f33}[data-theme=dark] .exam-history-badge.failed{background:#c1292e33}[data-theme=dark] .search-q-answer{background:#2d6a4f26}[data-theme=dark] .quiz-fish-info-row{border-bottom-color:#333}[data-theme=dark] .dark-mode-switch{background:#444}[data-theme=dark] .home-card{background:var(--surface);color:var(--text)}[data-theme=dark] .home-card-info{color:var(--text-light)}[data-theme=dark] .question-card{background:var(--surface)}[data-theme=dark] .question-de{color:#fff}[data-theme=dark] .answer-de{color:#f0f0f5}[data-theme=dark] .answer-translated{color:#a0a0b5}[data-theme=dark] .search-question-card,[data-theme=dark] .search-fish-card{background:var(--surface)}[data-theme=dark] .next-btn{background:var(--primary);color:#fff}[data-theme=dark] .prev-btn{background:var(--surface);border-color:var(--primary);color:var(--primary)}[data-theme=dark] .back-btn{color:var(--text-light)}[data-theme=dark] .section-title{color:var(--text)}[data-theme=dark] .explanation-de{color:#fff}[data-theme=dark] .explanation-translated{color:#a0a0b5}[data-theme=dark] .result-box.correct,[data-theme=dark] .result-box.wrong{color:var(--text)}[data-theme=dark] .result-label{color:inherit}[data-theme=dark] .explanation-label{color:#a0a0b5}[data-theme=dark] .search-glossary-def{background:#ffffff0d;color:var(--text-light)}[data-theme=dark] .knot-card,[data-theme=dark] .glossary-card,[data-theme=dark] .category-progress-card{background:var(--surface)}.dark-mode-toggle{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;border:none;border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow);cursor:pointer;transition:all .2s}.dark-mode-toggle:active{transform:scale(.98)}.dark-mode-icon{font-size:1.3rem}.dark-mode-label{flex:1;font-size:.95rem;font-weight:500;color:var(--text);text-align:start}.dark-mode-switch{width:44px;height:24px;border-radius:12px;background:#ccc;position:relative;transition:background .3s}.dark-mode-switch.on{background:var(--primary)}.dark-mode-knob{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .3s;box-shadow:0 1px 3px #0003}.dark-mode-switch.on .dark-mode-knob{transform:translate(20px)}.nav-item{position:relative}.nav-item.active:after{content:"";position:absolute;top:-6px;left:50%;transform:translate(-50%);width:20px;height:3px;border-radius:2px;background:var(--primary)}[data-theme=dark] .nav-item.active:after{background:var(--secondary)}.week-chart-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;margin-bottom:16px}.week-chart-title{display:block;font-size:.85rem;font-weight:600;color:var(--primary);margin-bottom:12px}.week-chart-bars{display:flex;align-items:flex-end;gap:6px;height:100px}.week-chart-col{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}.week-chart-col.today .week-chart-day{font-weight:700;color:var(--primary)}.week-chart-bar-wrap{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center}.week-chart-bar{width:100%;max-width:28px;border-radius:4px 4px 0 0;background:linear-gradient(180deg,var(--primary),rgba(15,76,92,.6));display:flex;align-items:flex-start;justify-content:center;min-height:4px;transition:height .4s ease}.week-chart-val{font-size:.6rem;font-weight:700;color:#fff;padding-top:2px}.week-chart-day{font-size:.65rem;color:var(--text-light);margin-top:4px}.search-empty-state{text-align:center;padding:48px 20px;color:var(--text-light)}.search-empty-icon{font-size:3rem;display:block;margin-bottom:12px;opacity:.4}.search-empty-text{font-size:.95rem}.install-banner{display:flex;align-items:center;gap:10px;padding:12px 16px;background:linear-gradient(135deg,var(--primary),#1a6b7d);color:#fff;font-size:.88rem;animation:slideDown .35s ease}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.install-icon{font-size:1.2rem}.install-text{flex:1;line-height:1.3}.install-btn{padding:6px 14px;border:2px solid #fff;border-radius:20px;background:transparent;color:#fff;font-weight:600;font-size:.82rem;cursor:pointer;white-space:nowrap;transition:background .2s}.install-btn:active{background:#fff3}.install-close{background:none;border:none;color:#ffffffb3;font-size:1.1rem;cursor:pointer;padding:4px;line-height:1}.install-close:hover{color:#fff}[data-theme=dark] .install-banner{background:linear-gradient(135deg,#1a3a50,#25506a)}.traffic-dot{display:inline-block;width:12px;height:12px;border-radius:50%;flex-shrink:0}.traffic-green{background:#2d6a4f;box-shadow:0 0 4px #2d6a4f66}.traffic-yellow{background:#e8aa42;box-shadow:0 0 4px #e8aa4266}.traffic-red{background:#c1292e;box-shadow:0 0 4px #c1292e66}[data-theme=dark] .traffic-green{background:#40916c}[data-theme=dark] .traffic-yellow{background:gold}[data-theme=dark] .traffic-red{background:#ff6b6b}.question-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;min-height:24px}.bookmark-btn{background:none;border:none;font-size:1.3rem;cursor:pointer;padding:2px 6px;color:#bbb;transition:color .2s,transform .2s;line-height:1}.bookmark-btn.active{color:#e8aa42}.bookmark-btn:active{transform:scale(1.3)}.readiness-card{border-radius:var(--radius);padding:16px;margin-bottom:14px;background:var(--surface);box-shadow:var(--shadow)}.readiness-header{display:flex;align-items:center;gap:10px}.readiness-icon{font-size:1.4rem}.readiness-info{flex:1;display:flex;flex-direction:column}.readiness-title{font-size:.78rem;color:var(--text-light);text-transform:uppercase;letter-spacing:.5px}.readiness-label{font-size:.9rem;font-weight:600;color:var(--text)}.readiness-pct{font-size:1.5rem;font-weight:800}.readiness-pct-green{color:#2d6a4f}.readiness-pct-yellow{color:#d4960a}.readiness-pct-red{color:#c1292e}.readiness-bar{margin-top:10px;height:8px;background:#0000000f;border-radius:4px;overflow:hidden}[data-theme=dark] .readiness-bar{background:#ffffff1a}.readiness-bar-fill{height:100%;border-radius:4px;transition:width .5s ease}.readiness-green .readiness-bar-fill{background:linear-gradient(90deg,#2d6a4f,#40916c)}.readiness-yellow .readiness-bar-fill{background:linear-gradient(90deg,#e8aa42,#f4c95d)}.readiness-red .readiness-bar-fill{background:linear-gradient(90deg,#c1292e,#e85d5d)}.category-weak{border-left:3px solid #C1292E}[data-theme=dark] .category-weak{border-color:#ff6b6b}.cat-weak-badge{font-size:.7rem;background:#c1292e1f;color:#c1292e;padding:2px 8px;border-radius:10px;font-weight:600;white-space:nowrap}[data-theme=dark] .cat-weak-badge{background:#ff6b6b26;color:#ff6b6b}.cat-start-badge{font-size:.7rem;background:#2a644f1f;color:#2a644f;padding:2px 8px;border-radius:10px;font-weight:600;white-space:nowrap}[data-theme=dark] .cat-start-badge{background:#4caf5026;color:#81c784}.share-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;border:2px solid var(--primary);border-radius:12px;background:transparent;color:var(--primary);font-size:.95rem;font-weight:600;cursor:pointer;transition:background .2s}.share-btn:active{background:#0f4c5c14}.exam-result-actions{display:flex;flex-direction:column;gap:10px;margin-top:20px}.offline-banner{display:flex;align-items:center;gap:10px;padding:10px 16px;background:#fff3cd;color:#856404;font-size:.85rem;animation:slideDown .35s ease}[data-theme=dark] .offline-banner{background:#3d3520;color:gold}.offline-icon{font-size:1.1rem}.offline-text{flex:1;line-height:1.3}.offline-close{background:none;border:none;color:inherit;opacity:.6;font-size:1rem;cursor:pointer;padding:4px}.offline-close:hover{opacity:1}.glossary-tabs{display:flex;gap:0;margin-bottom:16px;border-radius:10px;overflow:hidden;border:2px solid var(--primary)}.glossary-tab{flex:1;padding:10px 16px;border:none;background:var(--card-bg);color:var(--text);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.glossary-tab-active{background:var(--primary);color:#fff}.glossary-result-count{color:var(--text-muted);font-size:.85rem;margin-bottom:12px;padding:0 4px}.glossary-groups{display:flex;flex-direction:column;gap:12px}.glossary-group{background:var(--card-bg);border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}.glossary-group-header{display:flex;align-items:center;gap:10px;width:100%;padding:14px 16px;border:none;background:transparent;color:var(--text);cursor:pointer;font-size:1rem;font-weight:600;text-align:left}.glossary-group-icon{font-size:1.3rem}.glossary-group-name{flex:1}.glossary-group-count{background:var(--bg);color:var(--text-muted);padding:2px 8px;border-radius:10px;font-size:.8rem;font-weight:500}.glossary-group-entries{padding:0 8px 8px}.glossary-entry{display:block;width:100%;text-align:left;padding:12px 14px;border:none;background:var(--bg);border-radius:8px;margin-bottom:6px;cursor:pointer;transition:all .2s;color:var(--text)}.glossary-entry:hover,.glossary-entry-expanded{background:var(--primary-light)}.glossary-entry-header{display:flex;justify-content:space-between;align-items:center}.glossary-term{font-weight:600;font-size:.95rem}.glossary-expand-icon{font-size:.7rem;color:var(--text-muted)}.glossary-entry-body{margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.glossary-term-de{color:var(--text-muted);font-size:.85rem;margin-bottom:6px;font-style:italic}.glossary-definition{font-size:.9rem;line-height:1.6;color:var(--text)}.glossary-group-tag{display:inline-block;margin-top:8px;padding:3px 10px;background:var(--card-bg);border-radius:12px;font-size:.8rem;color:var(--text-muted)}.glossary-related{margin-top:10px;display:flex;flex-wrap:wrap;align-items:center;gap:6px}.glossary-related-label{font-size:.8rem;color:var(--text-muted);font-weight:500}.glossary-related-link{display:inline-block;padding:3px 10px;background:var(--primary);color:#fff;border:none;border-radius:12px;font-size:.8rem;cursor:pointer;transition:opacity .2s}.glossary-related-link:hover{opacity:.85}.glossary-az{margin-top:8px}.glossary-letter-bar{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:16px;justify-content:center}.glossary-letter-link{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;background:var(--primary);color:#fff;font-weight:700;font-size:.85rem;text-decoration:none;transition:opacity .2s}.glossary-letter-link:hover{opacity:.85}.glossary-letter-section{margin-bottom:16px}.glossary-letter-heading{font-size:1.3rem;font-weight:700;color:var(--primary);margin-bottom:8px;padding-bottom:4px;border-bottom:2px solid var(--primary)}[data-theme=dark] .glossary-group{background:var(--card-bg)}[data-theme=dark] .glossary-entry{background:#ffffff0d}[data-theme=dark] .glossary-entry:hover,[data-theme=dark] .glossary-entry-expanded,[data-theme=dark] .glossary-group-count,[data-theme=dark] .glossary-group-tag{background:#ffffff1a}.knot-filters{display:flex;gap:8px;margin-bottom:12px}.knot-filter-btn{padding:8px 14px;border:2px solid var(--border);border-radius:20px;background:var(--card-bg);color:var(--text-muted);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}.knot-filter-active{border-color:var(--primary);background:var(--primary);color:#fff}.knot-cat-tabs{display:flex;gap:6px;overflow-x:auto;padding-bottom:8px;margin-bottom:16px;-webkit-overflow-scrolling:touch}.knot-cat-tab{flex-shrink:0;padding:8px 14px;border:2px solid var(--border);border-radius:20px;background:var(--card-bg);color:var(--text);font-size:.85rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .2s}.knot-cat-tab-active{border-color:var(--primary);background:var(--primary);color:#fff}.knot-list{display:flex;flex-direction:column;gap:12px}.knot-category-section{margin-bottom:8px}.knot-category-heading{display:flex;align-items:center;gap:8px;font-size:1.1rem;font-weight:700;color:var(--primary);margin-bottom:10px;padding-bottom:6px;border-bottom:2px solid var(--primary)}.knot-category-count{background:var(--primary-light);color:var(--primary);padding:2px 8px;border-radius:10px;font-size:.8rem;font-weight:600;margin-left:auto}.knot-card{background:var(--card-bg);border-radius:12px;overflow:hidden;box-shadow:var(--shadow);margin-bottom:8px}.knot-card-header{display:flex;flex-direction:column;gap:8px;width:100%;padding:14px 16px;border:none;background:transparent;color:var(--text);cursor:pointer;text-align:left}.knot-card-title-row{display:flex;justify-content:space-between;align-items:center}.knot-name{font-weight:700;font-size:1rem}.knot-expand-icon{font-size:.7rem;color:var(--text-muted)}.knot-meta{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.knot-diff-badge{padding:2px 10px;border-radius:10px;font-size:.75rem;font-weight:600}.knot-diff-easy{background:#d4edda;color:#155724}.knot-diff-medium{background:#fff3cd;color:#856404}.knot-diff-hard{background:#f8d7da;color:#721c24}.knot-strength{font-size:.8rem;color:var(--text-muted);font-weight:500}.knot-exam-badge{padding:2px 10px;border-radius:10px;font-size:.75rem;font-weight:600;background:var(--primary);color:#fff}.knot-card-body{padding:14px 16px 16px;border-top:1px solid var(--border)}.knot-purpose{font-size:.9rem;line-height:1.6;color:var(--text);margin-bottom:14px}.knot-section-label{display:block;font-size:.85rem;font-weight:700;color:var(--primary);margin-bottom:6px}.knot-usedfor{margin-bottom:14px}.knot-tags{display:flex;flex-wrap:wrap;gap:6px}.knot-tag{padding:3px 10px;background:var(--bg);border-radius:12px;font-size:.8rem;color:var(--text)}.knot-steps{margin-bottom:14px}.knot-step-list{padding-left:20px;display:flex;flex-direction:column;gap:8px}.knot-step{font-size:.9rem;line-height:1.5;color:var(--text)}.knot-step::marker{color:var(--primary);font-weight:700}.knot-tips{display:flex;gap:10px;padding:12px;background:var(--primary-light);border-radius:10px;align-items:flex-start}.knot-tips-icon{font-size:1.2rem;flex-shrink:0}.knot-tips-text{font-size:.85rem;line-height:1.5;color:var(--text);margin:0}[data-theme=dark] .knot-diff-easy{background:#28a74533;color:#6fcf97}[data-theme=dark] .knot-diff-medium{background:#ffc10733;color:#ffc107}[data-theme=dark] .knot-diff-hard{background:#dc354533;color:#f08080}[data-theme=dark] .knot-tag{background:#ffffff14}[data-theme=dark] .knot-tips{background:#0f4c5c33}[data-theme=dark] .knot-category-count{background:#0f4c5c4d}.waters-term-row{display:flex;align-items:center;gap:8px;flex:1}.waters-exam-badge{font-size:.65rem;padding:2px 6px;border-radius:4px;background:#0f4c5c1a;color:var(--primary);font-weight:600;white-space:nowrap}.waters-filter-row{display:flex;margin-bottom:12px}.waters-exam-filter{font-size:.8rem;padding:6px 14px;border-radius:20px;border:1.5px solid var(--text-light);background:transparent;color:var(--text-light);cursor:pointer;transition:all .2s}.waters-exam-filter.active{background:var(--primary);color:#fff;border-color:var(--primary)}.waters-cat-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}.waters-cat-chip{font-size:.75rem;padding:5px 10px;border-radius:16px;border:1.5px solid rgba(0,0,0,.1);background:var(--surface);color:var(--text);cursor:pointer;transition:all .2s;white-space:nowrap}.waters-cat-chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}[data-theme=dark] .waters-exam-badge{background:#e8aa4226;color:var(--secondary)}[data-theme=dark] .waters-exam-filter{border-color:#fff3;color:#fff9}[data-theme=dark] .waters-exam-filter.active{background:var(--primary);color:#fff;border-color:var(--primary)}[data-theme=dark] .waters-cat-chip{background:var(--surface);border-color:#ffffff1a;color:#fffc}[data-theme=dark] .waters-cat-chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}.method-detail-header{text-align:center;margin-bottom:20px}.method-detail-header h2{font-size:1.3rem;margin-bottom:4px}.method-detail-de{color:var(--text-light);font-size:.9rem;margin-bottom:8px}.method-badges{display:flex;gap:8px;justify-content:center}.method-description{font-size:.9rem;line-height:1.6;color:var(--text);margin-bottom:20px;padding:16px;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow)}.method-gear-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.method-gear-card{background:var(--surface);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:4px}.method-gear-icon{font-size:1.2rem}.method-gear-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);font-weight:600}.method-gear-value{font-size:.82rem;line-height:1.4;color:var(--text)}.method-info-cards{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.method-info-card{background:var(--surface);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow)}.method-info-label{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);font-weight:600;margin-bottom:4px}.method-info-value{font-size:.88rem;line-height:1.5;color:var(--text)}.method-tips{display:flex;gap:12px;padding:16px;background:#e8aa4214;border-radius:var(--radius);border:1px solid rgba(232,170,66,.2)}.method-tips-icon{font-size:1.4rem;flex-shrink:0}.method-tips-label{display:block;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--secondary);margin-bottom:4px}.method-tips-text{font-size:.85rem;line-height:1.5;color:var(--text);margin:0}.method-category-section{margin-bottom:20px}.method-category-title{font-size:.9rem;font-weight:600;margin-bottom:10px;color:var(--text)}.method-list{display:flex;flex-direction:column;gap:8px}.method-card{width:100%;text-align:left;background:var(--surface);border:none;border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow);cursor:pointer;transition:transform .15s}.method-card:active{transform:scale(.98)}.method-card-top{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px}.method-card-name{font-size:.9rem;font-weight:600;color:var(--text)}.method-card-badges{display:flex;gap:6px;flex-shrink:0}.method-card-fish{font-size:.78rem;color:var(--text-light);line-height:1.3}[data-theme=dark] .method-description,[data-theme=dark] .method-gear-card,[data-theme=dark] .method-info-card,[data-theme=dark] .method-card{background:var(--surface)}[data-theme=dark] .method-tips{background:#e8aa421a;border-color:#e8aa4226}.catching-tips-section{margin-top:24px;padding-top:20px;border-top:1px solid rgba(0,0,0,.06)}.catching-tips-section h3{font-size:1rem;font-weight:700;margin-bottom:14px;color:var(--text)}.catching-tips-grid{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.catching-tip-item{display:grid;grid-template-columns:28px 1fr;grid-template-rows:auto auto;gap:0 10px;background:var(--surface);border-radius:var(--radius);padding:12px 14px;box-shadow:var(--shadow)}.catching-tip-icon{grid-row:1 / 3;font-size:1.1rem;align-self:center}.catching-tip-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);font-weight:600}.catching-tip-value{font-size:.85rem;line-height:1.4;color:var(--text)}.catching-extra-tip{display:flex;gap:12px;padding:14px;background:#e8aa4214;border-radius:var(--radius);border:1px solid rgba(232,170,66,.2);margin-top:12px}.catching-extra-icon{font-size:1.3rem;flex-shrink:0}.catching-extra-label{display:block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--secondary);margin-bottom:4px}.catching-extra-text{font-size:.85rem;line-height:1.5;color:var(--text);margin:0}[data-theme=dark] .catching-tips-section{border-top-color:#ffffff14}[data-theme=dark] .catching-tip-item{background:var(--surface)}[data-theme=dark] .catching-extra-tip{background:#e8aa421a;border-color:#e8aa4226}.guide-note{font-size:.82rem;color:var(--secondary);background:#e8aa421a;border:1px solid rgba(232,170,66,.2);border-radius:8px;padding:8px 12px;margin:8px 0 0;line-height:1.5}.guide-sections{display:flex;flex-direction:column;gap:8px;padding:0 16px 32px}.guide-section{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.guide-section-header{display:flex;align-items:center;gap:10px;width:100%;padding:14px 16px;border:none;background:none;cursor:pointer;font-size:1rem;font-weight:600;color:var(--text);text-align:start}.guide-section-header:active{background:#00000008}.guide-section-icon{font-size:1.3rem}.guide-section-title{flex:1}.guide-section-count{font-size:.75rem;font-weight:600;background:var(--primary);color:#fff;padding:2px 8px;border-radius:10px;min-width:24px;text-align:center}.guide-chevron{font-size:.9rem;color:var(--text-light);transition:transform .2s ease}.guide-chevron-open{transform:rotate(90deg)}.guide-items{border-top:1px solid rgba(0,0,0,.06)}.guide-item{border-bottom:1px solid rgba(0,0,0,.04)}.guide-item:last-child{border-bottom:none}.guide-item-question{display:flex;align-items:center;gap:8px;width:100%;padding:12px 16px;border:none;background:none;cursor:pointer;font-size:.9rem;color:var(--primary);text-align:start;font-weight:500}.guide-item-question:active{background:#0f4c5c0a}.guide-item-q{flex:1}.guide-item-open{color:var(--secondary)}.guide-item-answer{padding:0 16px 14px;animation:fadeInDown .2s ease}.guide-answer-primary{font-size:.88rem;line-height:1.65;color:var(--text);white-space:pre-line}.guide-answer-translated{font-size:.88rem;line-height:1.65;color:var(--text);margin-bottom:10px;padding-bottom:10px;border-bottom:1px dashed rgba(0,0,0,.1);white-space:pre-line}.guide-answer-de{font-size:.82rem;line-height:1.6;color:var(--text-light);white-space:pre-line}[data-theme=dark] .guide-section{background:var(--surface)}[data-theme=dark] .guide-items{border-top-color:#ffffff14}[data-theme=dark] .guide-item{border-bottom-color:#ffffff0d}[data-theme=dark] .guide-answer-translated{border-bottom-color:#ffffff1a}[data-theme=dark] .guide-answer-de{color:#c8c8d8}[data-theme=dark] .guide-answer-primary{color:#f0f0f5}[data-theme=dark] .guide-item-question{color:#fff}[data-theme=dark] .guide-item-open{color:var(--secondary)}.flash-container{padding:0 16px 32px}.flash-progress{margin-bottom:16px}.flash-progress-text{font-size:.85rem;color:var(--text-light);display:block;margin-bottom:6px;text-align:center}.flash-progress-bar{height:4px;background:#00000014;border-radius:2px;overflow:hidden}.flash-progress-fill{height:100%;background:var(--primary);border-radius:2px;transition:width .3s ease}.flash-progress-scores{display:flex;justify-content:center;gap:16px;margin-top:6px;font-size:.8rem}.flash-score-correct{color:var(--success);font-weight:600}.flash-score-wrong{color:var(--danger);font-weight:600}.flash-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);min-height:240px;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;user-select:none;transition:transform .15s ease;border:2px solid transparent}.flash-card:active{transform:scale(.98)}.flash-card-flipped{border-color:var(--secondary)}.flash-card-front,.flash-card-back{padding:24px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;width:100%}.flash-card-group{font-size:.78rem;color:var(--text-light);margin-bottom:12px}.flash-card-term{font-size:1.5rem;font-weight:700;color:var(--primary)}.flash-card-term-translated{font-size:1.1rem;color:var(--text-light);margin-top:8px}.flash-card-hint{font-size:.75rem;color:var(--text-light);margin-top:20px;opacity:.6}.flash-card-term-small{font-size:.85rem;font-weight:600;color:var(--primary);margin-bottom:12px}.flash-card-definition{font-size:.95rem;line-height:1.6;color:var(--text)}.flash-card-definition-de{font-size:.82rem;line-height:1.5;color:var(--text-light);margin-top:10px;padding-top:10px;border-top:1px dashed rgba(0,0,0,.1)}.flash-actions{display:flex;gap:10px;margin-top:16px}.flash-btn{flex:1;padding:12px;border-radius:var(--radius);border:none;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .15s}.flash-btn:active{opacity:.8}.flash-btn-no{background:var(--danger);color:#fff}.flash-btn-yes{background:var(--success);color:#fff}.flash-result{padding:0 16px 32px;text-align:center}.flash-result-icon{font-size:3rem;margin-bottom:8px}.flash-result-title{font-size:1.1rem;font-weight:600;color:var(--text);margin-bottom:16px}.flash-result-stats{display:flex;justify-content:center;gap:24px;margin-bottom:12px}.flash-stat{display:flex;flex-direction:column;align-items:center}.flash-stat-num{font-size:1.6rem;font-weight:700}.flash-stat-correct .flash-stat-num{color:var(--success)}.flash-stat-wrong .flash-stat-num{color:var(--danger)}.flash-stat-label{font-size:.78rem;color:var(--text-light)}.flash-result-pct{font-size:2rem;font-weight:700;color:var(--primary);margin:8px 0 16px}.flash-result-actions{display:flex;flex-direction:column;gap:8px}.flash-btn-restart{background:var(--primary);color:#fff}.flash-btn-wrong{background:var(--secondary);color:#fff}[data-theme=dark] .flash-card{background:var(--surface)}[data-theme=dark] .flash-card-definition-de{border-top-color:#ffffff1a}[data-theme=dark] .flash-progress-bar{background:#ffffff1a}.identify-container{padding:0 16px 32px}.identify-hint{font-size:.85rem;color:var(--text-light);margin-bottom:16px;text-align:center}.identify-filters{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.identify-category{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:12px 14px;overflow:hidden}.identify-category-title{font-size:.85rem;font-weight:600;color:var(--text);margin-bottom:8px}.identify-options{display:flex;flex-wrap:wrap;gap:6px}.identify-option{padding:6px 12px;border-radius:20px;border:1.5px solid rgba(0,0,0,.12);background:none;font-size:.78rem;color:var(--text);cursor:pointer;transition:all .15s ease}.identify-option:active{transform:scale(.97)}.identify-option-active{background:var(--primary);color:#fff;border-color:var(--primary)}.identify-reset{display:block;margin:0 auto 16px;padding:8px 20px;border-radius:20px;border:1.5px solid var(--danger);background:none;color:var(--danger);font-size:.82rem;font-weight:500;cursor:pointer}.identify-reset:active{background:var(--danger);color:#fff}.identify-results-title{font-size:.9rem;font-weight:600;color:var(--text);margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid rgba(0,0,0,.06)}.fish-trait-badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.fish-trait-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:12px;font-size:.75rem;background:#0f4c5c14;color:var(--primary)}[data-theme=dark] .identify-category{background:var(--surface)}[data-theme=dark] .identify-option{border-color:#ffffff26;color:var(--text)}[data-theme=dark] .identify-option-active{background:var(--primary);color:#fff;border-color:var(--primary)}[data-theme=dark] .identify-results-title{border-bottom-color:#ffffff14}[data-theme=dark] .fish-trait-badge{background:#0f4c5c33}.glossary-term-wrapper{position:relative;display:inline}.glossary-term-highlight{background:#0f4c5c1a;border-bottom:1.5px dashed var(--primary);cursor:pointer;border-radius:2px;padding:0 1px;transition:background .15s}.glossary-term-highlight:hover,.glossary-term-highlight.active{background:#0f4c5c33}.glossary-popup{position:absolute;left:50%;transform:translate(-50%);z-index:100;background:#fff;border:1px solid #ddd;border-radius:12px;box-shadow:0 8px 32px #00000026;padding:14px 16px 12px;min-width:260px;max-width:340px;display:flex;flex-direction:column;gap:8px;animation:glossaryPopIn .15s ease-out}.glossary-popup.below{top:calc(100% + 8px)}.glossary-popup.above{bottom:calc(100% + 8px)}@keyframes glossaryPopIn{0%{opacity:0;transform:translate(-50%) translateY(4px) scale(.97)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.glossary-popup-term{font-weight:700;font-size:.95rem;color:var(--primary);line-height:1.3}.glossary-popup-term-translated{font-weight:400;color:#666;font-size:.88rem}.glossary-popup-definition{font-size:.85rem;line-height:1.45;color:#333}.glossary-popup-definition.translated{color:#666;font-size:.82rem;padding-top:4px;border-top:1px solid #eee}.glossary-popup-close{position:absolute;top:6px;right:8px;background:none;border:none;font-size:1.2rem;color:#999;cursor:pointer;padding:2px 6px;line-height:1;border-radius:4px}.glossary-popup-close:hover{background:#f0f0f0;color:#333}[dir=rtl] .glossary-popup{left:auto;right:50%;transform:translate(50%)}[dir=rtl] .glossary-popup.below{top:calc(100% + 8px)}[dir=rtl] .glossary-popup.above{bottom:calc(100% + 8px)}[dir=rtl] .glossary-popup-close{right:auto;left:8px}@keyframes glossaryPopInRtl{0%{opacity:0;transform:translate(50%) translateY(4px) scale(.97)}to{opacity:1;transform:translate(50%) translateY(0) scale(1)}}[dir=rtl] .glossary-popup{animation-name:glossaryPopInRtl}[data-theme=dark] .glossary-term-highlight{background:#64c8dc1f;border-bottom-color:var(--primary-light, #4db8c9)}[data-theme=dark] .glossary-term-highlight:hover,[data-theme=dark] .glossary-term-highlight.active{background:#64c8dc38}[data-theme=dark] .glossary-popup{background:var(--surface, #1e1e1e);border-color:#ffffff1f;box-shadow:0 8px 32px #0006}[data-theme=dark] .glossary-popup-term{color:var(--primary-light, #4db8c9)}[data-theme=dark] .glossary-popup-term-translated{color:#aaa}[data-theme=dark] .glossary-popup-definition{color:#ddd}[data-theme=dark] .glossary-popup-definition.translated{color:#999;border-top-color:#ffffff14}[data-theme=dark] .glossary-popup-close{color:#777}[data-theme=dark] .glossary-popup-close:hover{background:#ffffff1a;color:#ddd}.premium-wall{text-align:center;padding:2rem 1.5rem;margin:1.5rem 0;background:linear-gradient(135deg,#fff8e1,#fff3c4);border-radius:var(--radius);border:2px solid var(--secondary);box-shadow:var(--shadow)}.premium-wall-icon{font-size:2.5rem;display:block;margin-bottom:.75rem}.premium-wall-title{font-size:1.25rem;font-weight:700;color:var(--primary);display:block;margin-bottom:.5rem}.premium-wall-features{list-style:none;padding:0;margin:1rem 0;text-align:left}.premium-wall-features li{padding:.35rem 0;color:var(--text);font-size:.95rem}.premium-wall-cta{display:inline-block;padding:.85rem 2rem;background:linear-gradient(135deg,var(--secondary),#D4922A);color:#fff;font-size:1.05rem;font-weight:700;border:none;border-radius:50px;cursor:pointer;margin-top:.75rem;box-shadow:0 4px 12px #e8aa4259;transition:transform .15s,box-shadow .15s}.premium-wall-cta:active{transform:scale(.97)}.premium-wall-onetime{display:block;color:var(--text-light);font-size:.8rem;margin-top:.5rem}.premium-wall-compact{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem;margin:1rem 0;background:linear-gradient(135deg,#fff8e1,#fff3c4);border-radius:var(--radius);border:1.5px solid var(--secondary);cursor:pointer}.premium-wall-compact .premium-wall-icon{font-size:1.5rem;margin-bottom:0}.premium-wall-compact .premium-compact-info{flex:1;text-align:left}.premium-compact-hint{display:block;font-size:.8rem;font-weight:600;color:var(--primary)}.premium-compact-sub{display:block;font-size:.75rem;color:var(--text-light);margin-top:2px}.premium-compact-arrow{font-size:1.2rem;color:var(--secondary);font-weight:700}.premium-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;background:linear-gradient(135deg,#ffd54f,#ffc107);color:#5d4037;font-size:.65rem;font-weight:700;border-radius:20px;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap}.locked-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#ffffffa6;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);z-index:2}.locked-overlay-icon{font-size:1.5rem}.fish-item-locked{position:relative;opacity:.7}.fish-item-locked .fish-thumb{filter:grayscale(1);opacity:.3}.home-premium-banner{display:flex;align-items:center;gap:.75rem;width:100%;padding:.85rem 1rem;margin:.75rem 0;background:linear-gradient(135deg,#fff8e1,#fff3c4);border:1.5px solid var(--secondary);border-radius:var(--radius);cursor:pointer;text-align:left}.home-premium-icon{font-size:1.5rem}.home-premium-text{flex:1}.home-premium-title{display:block;font-size:.95rem;font-weight:700;color:var(--primary)}.home-premium-sub{display:block;font-size:.8rem;color:var(--text-light);margin-top:2px}.home-premium-arrow{font-size:1.2rem;color:var(--secondary);font-weight:700}.home-premium-active{text-align:center;padding:.5rem;margin:.5rem 0;color:var(--success);font-weight:600;font-size:.9rem}.settings-premium-active{padding:.75rem;background:#e8f5e9;border-radius:var(--radius);color:var(--success);font-weight:600;text-align:center}.settings-premium-box{text-align:center}.settings-premium-info{color:var(--text-light);font-size:.9rem;margin-bottom:.75rem}.settings-restore-btn{display:block;width:100%;padding:.6rem;margin-top:.5rem;background:transparent;border:1.5px solid var(--text-light);border-radius:var(--radius);color:var(--text-light);font-size:.85rem;cursor:pointer}.upgrade-page{text-align:center}.upgrade-icon{font-size:3rem;margin-bottom:.75rem;display:block}.upgrade-title{font-size:1.5rem;font-weight:700;color:var(--primary);margin-bottom:.5rem}.upgrade-subtitle{color:var(--text-light);font-size:.95rem;margin-bottom:1.5rem}.upgrade-comparison{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin:1.5rem 0;text-align:left}.upgrade-col{padding:1rem;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow)}.upgrade-col-premium{border:2px solid var(--secondary);background:linear-gradient(135deg,#fff8e1,#fff)}.upgrade-col h3{font-size:1rem;margin-bottom:.75rem;color:var(--primary)}.upgrade-col ul{list-style:none;padding:0}.upgrade-col li{padding:.3rem 0;font-size:.85rem;color:var(--text)}.upgrade-cta-section{margin-top:1.5rem}.upgrade-restore{display:block;margin:.75rem auto 0;background:none;border:none;color:var(--text-light);font-size:.85rem;cursor:pointer;text-decoration:underline}[data-theme=dark] .premium-wall{background:linear-gradient(135deg,#3e2723,#4e342e);border-color:#d4922a}[data-theme=dark] .premium-wall-title{color:#ffd54f}[data-theme=dark] .premium-wall-compact{background:linear-gradient(135deg,#3e2723,#4e342e);border-color:#d4922a}[data-theme=dark] .premium-compact-hint{color:#ffd54f}[data-theme=dark] .home-premium-banner{background:linear-gradient(135deg,#3e2723,#4e342e);border-color:#d4922a}[data-theme=dark] .home-premium-title{color:#ffd54f}[data-theme=dark] .locked-overlay{background:#1e1e1ea6}[data-theme=dark] .settings-premium-active{background:#1b3a1f}[data-theme=dark] .upgrade-col{background:var(--surface)}[data-theme=dark] .upgrade-col-premium{background:linear-gradient(135deg,#3e2723,#2c2c2c);border-color:#d4922a}.fish-confetti-container{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:9999}.fish-confetti-particle{position:absolute;top:-10%;animation:fishFall linear forwards;will-change:transform}@keyframes fishFall{0%{transform:translateY(0) translate(0) rotate(var(--rotation, 0deg)) scale(.5);opacity:1}20%{opacity:1;transform:translateY(20vh) translate(calc(var(--drift, 0px) * .4)) rotate(calc(var(--rotation, 0deg) + 90deg)) scale(1)}80%{opacity:1}to{transform:translateY(110vh) translate(var(--drift, 0px)) rotate(calc(var(--rotation, 0deg) + 360deg)) scale(.8);opacity:0}}.upgrade-thankyou{display:flex;flex-direction:column;align-items:center;text-align:center;padding:2rem 1.5rem;margin-top:2rem;animation:thankYouFadeIn .8s ease-out}.upgrade-thankyou-icon{font-size:4rem;margin-bottom:1rem;animation:thankYouBounce 1s ease-out .3s both}.upgrade-thankyou-title{font-size:1.75rem;font-weight:800;color:var(--primary);margin-bottom:1rem}.upgrade-thankyou-text{font-size:1rem;line-height:1.7;color:var(--text);max-width:380px;margin-bottom:1.5rem}.upgrade-thankyou-badge{display:inline-flex;align-items:center;gap:6px;padding:.5rem 1.25rem;background:linear-gradient(135deg,#ffd54f,#ffc107);color:#5d4037;font-size:1.1rem;font-weight:700;border-radius:50px;box-shadow:0 4px 16px #ffc10759}@keyframes thankYouFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes thankYouBounce{0%{transform:scale(.3) rotate(-10deg);opacity:0}50%{transform:scale(1.15) rotate(5deg);opacity:1}70%{transform:scale(.95) rotate(-2deg)}to{transform:scale(1) rotate(0);opacity:1}}[data-theme=dark] .upgrade-thankyou-title{color:#ffd54f}[data-theme=dark] .upgrade-thankyou-text{color:#ddd}.review-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9000;padding:1.5rem;animation:reviewFadeIn .3s ease-out}.review-dialog{background:var(--surface);border-radius:20px;padding:2rem 1.5rem;max-width:380px;width:100%;text-align:center;box-shadow:0 16px 48px #0003;animation:reviewSlideUp .4s ease-out}.review-icon{font-size:3rem;margin-bottom:.75rem}.review-title{font-size:1.25rem;font-weight:700;color:var(--primary);margin-bottom:.5rem}.review-subtitle{font-size:.9rem;color:var(--text-light);line-height:1.5;margin-bottom:1.25rem}.review-buttons{display:flex;flex-direction:column;gap:.6rem;margin-bottom:.75rem}.review-btn{padding:.85rem 1.5rem;border:none;border-radius:50px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .15s,opacity .15s}.review-btn:active{transform:scale(.97)}.review-btn:disabled{opacity:.5;cursor:not-allowed}.review-btn-positive{background:linear-gradient(135deg,var(--secondary),#D4922A);color:#fff;box-shadow:0 4px 12px #e8aa424d}.review-btn-negative{background:var(--bg);color:var(--text);border:1.5px solid #ddd}.review-dismiss{background:none;border:none;color:var(--text-light);font-size:.85rem;cursor:pointer;padding:.5rem;text-decoration:underline}.review-textarea{width:100%;padding:.85rem;border:1.5px solid #ddd;border-radius:var(--radius);font-family:inherit;font-size:.95rem;resize:vertical;min-height:100px;margin-bottom:1rem;color:var(--text);background:var(--bg)}.review-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0f4c5c1a}@keyframes reviewFadeIn{0%{opacity:0}to{opacity:1}}@keyframes reviewSlideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}[data-theme=dark] .review-dialog{background:var(--surface)}[data-theme=dark] .review-title{color:#ffd54f}[data-theme=dark] .review-btn-negative{background:#333;color:#ddd;border-color:#555}[data-theme=dark] .review-textarea{background:#2a2a2a;border-color:#555;color:#ddd}.promo-toggle{display:block;margin:.75rem auto 0;background:none;border:none;color:var(--primary);font-size:.9rem;font-weight:600;cursor:pointer;padding:.4rem .75rem;border-radius:20px;transition:background .15s}.promo-toggle:hover{background:#0f4c5c14}.promo-section{margin-top:.75rem}.promo-input-row{display:flex;gap:.5rem;align-items:stretch}.promo-input{flex:1;padding:.65rem .85rem;border:1.5px solid #ddd;border-radius:var(--radius);font-family:monospace;font-size:.95rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--text);background:var(--bg)}.promo-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0f4c5c1a}.promo-input::placeholder{font-family:inherit;font-weight:400;letter-spacing:0;text-transform:none}.promo-btn{padding:.65rem 1rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:.9rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:opacity .15s}.promo-btn:disabled{opacity:.4;cursor:not-allowed}.promo-btn:active:not(:disabled){opacity:.8}.promo-message{margin-top:.5rem;padding:.5rem .75rem;border-radius:var(--radius);font-size:.85rem;font-weight:500;animation:promoMsgFade .3s ease-out}.promo-message-success{background:#e8f5e9;color:var(--success)}.promo-message-error{background:#ffebee;color:var(--danger)}@keyframes promoMsgFade{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.promo-input-row.shake{animation:promoShake .5s ease-in-out}@keyframes promoShake{0%,to{transform:translate(0)}15%{transform:translate(-8px)}30%{transform:translate(8px)}45%{transform:translate(-6px)}60%{transform:translate(6px)}75%{transform:translate(-3px)}90%{transform:translate(3px)}}[data-theme=dark] .promo-input{background:#2a2a2a;border-color:#555;color:#ddd}[data-theme=dark] .promo-toggle{color:#ffd54f}[data-theme=dark] .promo-message-success{background:#1b3a1f}[data-theme=dark] .promo-message-error{background:#3e1515}.promo-alert-card{background:#fff8e1;border:2px solid #FFB300;border-radius:12px;padding:1rem;margin-bottom:.75rem}.promo-alert-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.promo-alert-header strong{color:#e65100;font-size:1rem}.promo-alert-code{font-family:Courier New,monospace;font-size:.8rem;background:#fff3e0;padding:2px 8px;border-radius:4px;color:#bf360c}.promo-alert-bar{height:8px;background:#ffe0b2;border-radius:4px;overflow:hidden;margin-bottom:.5rem}.promo-alert-fill{height:100%;background:linear-gradient(90deg,#ff9800,#f44336);border-radius:4px;transition:width .3s ease}.promo-alert-text{font-size:.85rem;color:#bf360c;margin-bottom:.5rem}.promo-alert-dismiss{background:#e8f5e9;border:1px solid #66BB6A;color:#2e7d32;padding:.4rem 1rem;border-radius:8px;font-size:.85rem;cursor:pointer}.promo-alert-dismiss:hover{background:#c8e6c9}[data-theme=dark] .promo-alert-card{background:#3e2723;border-color:#ff8f00}[data-theme=dark] .promo-alert-header strong{color:#ffb74d}[data-theme=dark] .promo-alert-code{background:#4e342e;color:#ffab91}[data-theme=dark] .promo-alert-bar{background:#4e342e}[data-theme=dark] .promo-alert-text{color:#ffab91}[data-theme=dark] .promo-alert-dismiss{background:#1b5e20;border-color:#43a047;color:#a5d6a7}
