*{box-sizing:border-box;margin:0;padding:0}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#0000000d;border-radius:3px}::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#aaa}html{scroll-behavior:smooth}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f5f6fa;color:#222;min-height:100vh}a{color:inherit;text-decoration:none}.header{background:#073075;color:#fff;padding:16px 18px 18px;position:relative}.planning-page .header{position:sticky;top:0;z-index:800}.header-top{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;position:relative}.main-nav{display:flex;gap:8px}.nav-link{padding:8px 18px;border-radius:999px;background:#ffffff24;font-size:15px}.nav-link.active{background:#fff;color:#073075;font-weight:600}.deadline-box{margin-top:14px;text-align:center}.deadline-title{font-size:20px;font-weight:700;margin-bottom:6px}.deadline-progress-bar-background{width:100%;max-width:600px;margin:0 auto 6px;height:18px;background:#fff3;border-radius:999px;overflow:hidden}.deadline-progress-bar-fill{height:100%;width:0;background:linear-gradient(90deg,#ffe082,#ff7043);transition:width 3s cubic-bezier(.22,1,.36,1)}#deadline-countdown{font-size:14px;opacity:.9}.sub-nav{margin-top:14px;display:flex;flex-wrap:wrap;gap:10px;justify-content:center;font-size:14px}.sub-nav a{padding:6px 12px;background:#fff;color:#073075;border-radius:999px;font-weight:600;box-shadow:0 2px 4px #0000001a}.motivation-btn{margin-top:10px;padding:8px 14px;border-radius:999px;border:none;cursor:pointer;font-size:14px;font-weight:600;background:#ffb74d;color:#4e342e;box-shadow:0 2px 6px #00000026}.motivation-btn:hover{filter:brightness(.97)}.motivation-box{margin:15px auto 0;width:fit-content;max-width:90%;background:#fffffff2;color:#2f2f2f;border-radius:12px;padding:12px 24px;font-size:15px;font-weight:500;line-height:1.5;text-align:center;box-shadow:0 4px 12px #00000026;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.container{max-width:1020px;margin:18px auto 40px;padding:0 16px}.planning-container{max-width:1400px}.progress-section{margin-bottom:20px}.progress-bar-background{width:100%;height:22px;background:#e3e5e9;border-radius:999px;overflow:hidden}.progress-bar-fill{height:100%;width:0;background:linear-gradient(90deg,#f46b45,#42a5f5);transition:width 3s cubic-bezier(.22,1,.36,1)}.progress-text{margin-top:8px;font-weight:600;text-align:center}.controls{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-end;margin-bottom:24px}.search-wrapper{flex:0 1 320px;max-width:200px;display:flex;flex-direction:column;gap:4px}.search-wrapper input{padding:8px 10px;border-radius:6px;border:1px solid #ccc;font-size:14px}.filters-wrapper{display:flex;align-items:center;font-size:13px;gap:6px}.filters-wrapper input{margin-right:4px}.buttons-wrapper{display:flex;flex-wrap:wrap;gap:8px}button{padding:8px 12px;border-radius:6px;border:none;cursor:pointer;font-size:14px;font-weight:600;background:#073075;color:#fff;transition:transform .05s ease-out,box-shadow .1s}button:hover{box-shadow:0 2px 6px #0000001f}button:active{transform:translateY(1px);box-shadow:0 1px 3px #00000026}.chapters-list{list-style:none;display:flex;flex-direction:column;gap:8px;height:85vh;min-height:400px;overflow-y:auto;border:1px solid rgba(0,0,0,.05);border-radius:8px;padding:10px;background:#ffffff80}.chapter-item{background:#fff;border-radius:8px;padding:10px 12px;display:flex;align-items:flex-start;gap:8px;box-shadow:0 1px 3px #0000000f}.chapter-item.completed{background:#e6ebf5}.chapter-checkbox{margin-top:3px}.chapter-label{cursor:pointer;width:100%}.chapter-title-row{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:2px}.chapter-title{font-weight:600}.chapter-info-btn{padding:4px 8px;font-size:12px;border-radius:999px;background:#e3f2fd;color:#1e88e5;border:none;cursor:pointer;white-space:nowrap}.chapter-info-btn:hover{box-shadow:0 1px 4px #00000026}.chapter-subtitle{font-size:13px;color:#555}.today-header-row{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.today-nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:8px 0 4px}.today-label{font-weight:600;font-size:14px}.nav-button{padding:4px 10px;border-radius:999px;border:1px solid #073075;background:#073075;color:#fff;cursor:pointer;font-size:12px}.nav-button:hover{background:#e61624}.planning-section{margin-bottom:32px}.planning-section h2{margin-bottom:6px}.section-note{font-size:13px;color:#555;margin-bottom:10px}.reviews-list{list-style:none;display:flex;flex-direction:column;gap:8px;min-height:100px;max-height:500px;overflow-y:auto;border:1px solid #f0f0f0;border-radius:8px;padding:8px}.review-item{background:#fff;border-radius:10px;padding:10px 12px;box-shadow:0 1px 4px #00000014;display:flex;flex-direction:column;gap:4px;border-left:4px solid #073075}.review-item.done{background:#e6ebf5;border-left-color:#052358}.review-item.failed{background:#ffebee;border-left-color:#c62828}.today-controls{margin:8px 0 12px;font-size:13px;display:flex;align-items:center;gap:6px}.review-main-line{display:flex;justify-content:space-between;gap:8px;align-items:center;flex-wrap:wrap}.review-left{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.review-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:12px}.review-done-checkbox{cursor:pointer;accent-color:#073075}.review-postpone-btn{border:none;cursor:pointer;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:600;background:#ffe082}.review-postpone-btn:hover{filter:brightness(.95)}.review-date{font-weight:600}.review-chapter-link{display:inline-block;padding:2px 10px;border-radius:999px;background:#e3f2fd;color:#1a237e;text-decoration:none;cursor:pointer;font-weight:600;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.review-chapter-link:hover{background:#bbdefb}.review-meta{font-size:12px;color:#555}.week-controls,.month-controls{display:flex;align-items:center;gap:8px;margin-bottom:10px}.week-label,.month-label{font-weight:600}.week-view{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;table-layout:fixed}.week-day{background:#fff;border-radius:10px;padding:8px;box-shadow:0 1px 4px #00000014;font-size:13px;display:flex;flex-direction:column;height:250px;min-height:250px;max-height:250px;overflow:hidden}.week-day.today{border:2px solid #073075}.week-day-title{font-weight:700;margin-bottom:6px;flex-shrink:0}.week-day-list{list-style:none;display:flex;flex-direction:column;gap:6px;flex-grow:1;overflow-y:auto;padding-right:4px;min-height:0}.week-review{font-size:12px}.week-review a{display:inline-block;padding:2px 8px;border-radius:999px;background:#ffe0b2;color:#ef6c00;font-weight:600;text-decoration:none}.week-review a:hover{filter:brightness(.95)}.week-review a,.month-review a{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.week-review.done a{background:#e8f5e9;color:#2e7d32}.week-review.failed a{background:#ffebee;color:#c62828}.week-review.moved-original a{text-decoration:line-through;opacity:.7}.week-review.moved-child{padding-left:10px}.month-view{background:#fff;border-radius:12px;padding:10px;box-shadow:0 1px 4px #00000014}.month-grid{width:100%;border-collapse:collapse;font-size:12px;table-layout:fixed}.month-grid th,.month-grid td{border:1px solid #e0e0e0;vertical-align:top;padding:4px}.month-grid td{height:200px;min-height:200px;max-height:200px;overflow:hidden}.month-grid th{text-align:center;background:#f0f4c3;font-weight:700;height:30px}.month-grid td.today{background:#e3f2fd}.month-day-number{font-weight:700;font-size:11px;margin-bottom:4px}.month-day-list{list-style:none;display:flex;flex-direction:column;gap:4px;max-height:180px;overflow-y:auto;padding-right:2px}.month-review a{display:inline-block;padding:2px 8px;border-radius:999px;background:#ffe0b2;color:#ef6c00;font-weight:600;text-decoration:none;font-size:11px}.month-review a:hover{filter:brightness(.95)}.month-review.done a{background:#e6ebf5;color:#052358}.month-review.failed a{background:#ffebee;color:#c62828}.month-review.moved-original a{text-decoration:line-through;opacity:.7}.month-review.moved-child{padding-left:10px}.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:1000}.modal.open{display:flex}.modal-backdrop{position:absolute;inset:0;background:#0006}.modal-content{position:relative;background:#fff;border-radius:16px;max-width:560px;width:95%;max-height:90vh;overflow:auto;padding:20px 18px 16px;box-shadow:0 8px 24px #00000040}.modal-close{position:absolute;right:10px;top:8px;background:transparent;color:#333;box-shadow:none;font-size:18px}.modal-close:hover{background:#eee}.modal-header-block{margin-bottom:8px}.modal-title{font-size:20px;font-weight:700;margin-bottom:4px}.modal-desc{font-size:14px;color:#444}.modal-meta{font-size:13px;color:#555;margin:10px 0 6px}.modal-meta p+p{margin-top:2px}.modal-progress-container{margin-bottom:10px}.modal-progress-label{font-size:12px;margin-bottom:3px}.modal-progress-bg{width:100%;height:10px;border-radius:999px;background:#e0e0e0;overflow:hidden}.modal-progress-fill{height:100%;background:linear-gradient(90deg,#42a5f5,#052358);transition:width 3s cubic-bezier(.22,1,.36,1)}.modal-reviews-list{list-style:none;margin-top:10px;display:flex;flex-direction:column;gap:8px}.modal-review-item{font-size:13px;display:flex;gap:8px;align-items:flex-start;padding:8px 10px;background:#f5f5f5;border-radius:8px}.modal-review-item input{margin-top:2px}.modal-review-item.moved-original .modal-review-label{text-decoration:line-through;opacity:.7}.modal-review-item.moved-child{padding-left:16px}.review-item.moved-original .review-chapter-link,.review-item.moved-original .review-meta{text-decoration:line-through;opacity:.7}.review-item.moved-child{padding-left:16px}.mini-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:1500}.mini-modal.open{display:flex}.mini-modal-backdrop{position:absolute;inset:0;background:#00000059}.mini-modal-content{position:relative;background:#fff;border-radius:14px;max-width:360px;width:92%;padding:16px 16px 14px;box-shadow:0 6px 18px #00000040;z-index:1501}.mini-modal-content h3{margin-bottom:6px;font-size:16px}.mini-modal-content p{font-size:13px;margin-bottom:8px}.mini-modal-content input[type=date]{width:100%;padding:6px 8px;font-size:14px;border-radius:6px;border:1px solid #ccc;margin-bottom:10px}.mini-modal-buttons{display:flex;justify-content:flex-end;gap:8px}.toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.9);width:min(90%,420px);background:#073075;color:#fff;padding:18px 24px;border-radius:16px;font-size:16px;text-align:center;box-shadow:0 6px 18px #0000004d;opacity:0;pointer-events:none;transition:opacity .25s ease,transform .25s ease;z-index:2000}.toast.show{opacity:1;transform:translate(-50%,-50%) scale(1)}@media(max-width:950px){.week-view{grid-template-columns:repeat(4,1fr)}}@media(max-width:700px){.header-top{flex-direction:column;align-items:flex-start}.week-view{grid-template-columns:repeat(2,1fr)}.month-grid th,.month-grid td{height:auto;min-height:80px}}@media(max-width:500px){.week-view{grid-template-columns:1fr}}.review-item.late{border-left-color:#d32f2f;background:#ffebee}.review-item.late .review-date{color:#c62828;font-weight:800}.review-item.late .review-meta{color:#b71c1c}.late-badge{display:inline-block;margin-left:8px;background:#d32f2f;color:#fff;font-size:10px;padding:2px 6px;border-radius:4px;vertical-align:middle}.planning-options{margin-top:24px}.title-length-controls{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:6px}.meta-toggle-label{display:flex;align-items:center;gap:4px;font-size:13px;cursor:pointer}.title-length-controls input{width:70px;padding:4px 6px;border-radius:6px;border:1px solid #ccc;font-size:13px}.planning-width-controls{margin-top:10px;display:flex;flex-wrap:wrap;align-items:center;gap:8px}.planning-width-controls input{width:90px;padding:4px 6px;border-radius:6px;border:1px solid #ccc;font-size:13px}.modal-review-move-btn{margin-left:10px;padding:2px 6px;font-size:11px;border-radius:4px;border:1px solid #ccc;background:#f7f7f7;cursor:pointer}.modal-review-move-btn:hover{background:#eaeaea}.modal-review-reset-btn{margin-left:8px;padding:2px 6px;font-size:11px;border-radius:4px;border:1px solid #ccc;background:#f7f7f7;cursor:pointer}.modal-review-reset-btn:hover{background:#eaeaea}.modal-review-item.done{background:#e6ebf5;border-left:4px solid #052358}.stats-summary-grid-4{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:#fff;border-radius:12px;padding:16px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 6px #00000014}.stat-icon{font-size:28px;background:#f0f4c3;width:50px;height:50px;display:flex;align-items:center;justify-content:center;border-radius:50%}.stat-info h3{font-size:13px;color:#666;margin-bottom:4px}.stat-value{font-size:18px;font-weight:700;color:#073075}.stats-grid-secondary{margin-bottom:24px}.stats-grid-secondary.single-box{display:flex;justify-content:center}.stat-box{background:#fff;border-radius:12px;padding:18px;box-shadow:0 2px 6px #00000014;width:100%}.projection-box{border-left:5px solid #7e57c2;max-width:600px}.projection-content{display:flex;justify-content:space-around;align-items:center;text-align:center;margin-bottom:8px}.projection-content p{font-size:13px;color:#666;margin-bottom:4px}.projection-content strong{font-size:20px;color:#7e57c2}.divider{width:1px;height:40px;background:#eee}.mini-note{font-size:12px;color:#888;font-style:italic;margin-top:6px;text-align:center}.flop-card{border:1px solid #ffcdd2;background:#ffebee}.flop-card .top-subject-title{color:#c62828}.charts-row{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px}.half-width{flex:1;min-width:300px}.chart-desc{font-size:13px;color:#666;margin-bottom:10px;margin-top:-10px}.chart-container-small{position:relative;height:200px;width:100%}.chart-container-medium{position:relative;height:250px;width:100%}.stats-section{background:#fff;padding:20px;border-radius:12px;margin-bottom:24px;box-shadow:0 2px 6px #00000014}.stats-section h2{font-size:18px;margin-bottom:16px;color:#333}.podium-container{display:flex;align-items:flex-end;justify-content:center;gap:12px;height:220px;padding-bottom:10px}.podium-card{position:relative;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;text-align:center;background:#fff;border-radius:12px 12px 4px 4px;box-shadow:0 4px 10px #0000001a;padding:10px;width:30%;overflow:hidden;border:1px solid #eee;z-index:1}.rank-1{height:100%;order:2;z-index:2;border-color:gold}.rank-2{height:85%;order:1;border-color:silver}.rank-3{height:70%;order:3;border-color:#cd7f32}.podium-fill{position:absolute;bottom:0;left:0;width:100%;height:0%;transition:height 1.5s cubic-bezier(.25,1,.5,1);z-index:-1;opacity:.2}.top-fill{background-color:#052358}.flop-fill{background-color:#c62828}.podium-content{z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;width:100%}.podium-medal{font-size:28px;margin-bottom:4px}.podium-title{font-weight:700;font-size:13px;margin-bottom:4px;line-height:1.2}.podium-percent{font-size:18px;font-weight:800}#subjects-list{display:flex;flex-direction:column;gap:12px;height:600px!important;min-height:600px!important;overflow-y:auto!important;padding:10px 8px 10px 10px;border:1px solid #ccc;border-radius:8px;background:#fff}body.dark-mode #subjects-list{border-color:#444!important;background:#1e1e1e!important}.stats-category-title{font-size:16px;font-weight:700;color:#073075;margin:20px 0 10px;display:flex;align-items:center;gap:8px;border-bottom:2px solid rgba(7,48,117,.1);padding-bottom:5px}body.dark-mode .stats-category-title{color:#64b5f6;border-bottom-color:#ffffff1a}.subject-item{flex-shrink:0}.subject-item{border:1px solid #e0e0e0;border-radius:8px;overflow:hidden;transition:all .3s ease}.subject-header{background:#fff;padding:12px 16px;cursor:pointer;display:flex;align-items:center}.subject-header:hover{background:#fafafa}.subject-info{width:100%}.subject-name-row{display:flex;justify-content:space-between;margin-bottom:6px;font-size:15px;font-weight:600}.subject-count{font-size:13px;color:#777;font-weight:400}.subject-progress-bg{width:100%;height:8px;background:#eee;border-radius:999px;overflow:hidden;margin-bottom:4px}.subject-progress-fill{height:100%;border-radius:999px;transition:width 3s cubic-bezier(.22,1,.36,1)}.subject-percent-text{text-align:right;font-size:12px;font-weight:700}.subject-content{display:none;background:#fbfbfb;padding:10px 16px;border-top:1px solid #e0e0e0}.subject-item.open .subject-content{display:block}.subject-chapter{list-style:none;font-size:13px;padding:4px 0;color:#555;display:flex;align-items:flex-start}.subject-chapter.done{color:#052358;font-weight:500}body.dark-mode{background:#121212;color:#e0e0e0}body.dark-mode .header{background:#052358;color:#eee}body.dark-mode .nav-link{background:#ffffff1a;color:#ddd}body.dark-mode .nav-link.active{background:#333;color:#64b5f6}body.dark-mode .chapter-item,body.dark-mode .stat-card,body.dark-mode .stat-box,body.dark-mode .week-day,body.dark-mode .month-view,body.dark-mode .review-item,body.dark-mode .modal-content,body.dark-mode .mini-modal-content,body.dark-mode .subject-header,body.dark-mode .subject-content,body.dark-mode .podium-card,body.dark-mode .motivation-box{background:#1e1e1e;color:#e0e0e0;border-color:#333;box-shadow:0 2px 6px #0006}body.dark-mode h1,body.dark-mode h2,body.dark-mode h3{color:#f5f5f5}body.dark-mode .chapter-subtitle,body.dark-mode .section-note,body.dark-mode .modal-desc,body.dark-mode .modal-meta,body.dark-mode .review-meta,body.dark-mode .stat-info h3,body.dark-mode .chart-desc,body.dark-mode .subject-count{color:#aaa}body.dark-mode input[type=text],body.dark-mode input[type=number],body.dark-mode input[type=date]{background:#2c2c2c;border:1px solid #444;color:#fff}body.dark-mode button.nav-button,body.dark-mode button#btn-save,body.dark-mode button#btn-load,body.dark-mode .chapter-info-btn,body.dark-mode .review-chapter-link{background:#333;border:1px solid #555;color:#64b5f6}body.dark-mode .chapter-item.completed{background:#051633;border:1px solid #073075}body.dark-mode .week-day.today,body.dark-mode .month-grid td.today{background:#263238;border-color:#64b5f6}body.dark-mode .month-grid th{background:#333;color:#ddd;border-color:#444}body.dark-mode .month-grid td{border-color:#444}body.dark-mode .review-item.done,body.dark-mode .week-review.done a,body.dark-mode .month-review.done a{background:#052358;color:#90caf9;border-left-color:#0d47a1}body.dark-mode .review-item.late,body.dark-mode .review-item.failed{background:#3e2723;border-left-color:#c62828}body.dark-mode .review-item.late .review-date{color:#ef9a9a}body.dark-mode .stat-icon{background:#333}body.dark-mode .stat-value{color:#64b5f6}body.dark-mode .subject-progress-bg{background:#333}body.dark-mode .podium-fill{opacity:.3}.header-right-actions{position:absolute;top:20px;right:20px;display:flex;gap:10px;align-items:center;z-index:200}.theme-toggle-btn2{position:static;transform:none;margin:0;display:inline-flex;align-items:center;gap:6px;width:fit-content;padding:6px 12px;background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff;border:none;border-radius:50px;font-size:13px;font-weight:700;box-shadow:0 4px 10px #0003;cursor:pointer;transition:transform .2s}.theme-toggle-btn2:hover{transform:translateY(-2px);box-shadow:0 6px 12px #0000004d}.logout-btn-header{background:linear-gradient(135deg,#e53935,#c62828);color:#fff;border:none;border-radius:50px;font-size:13px;font-weight:700;padding:6px 12px;display:inline-flex;align-items:center;gap:6px;box-shadow:0 4px 10px #0003;cursor:pointer;transition:transform .2s;text-decoration:none}.logout-btn-header:hover{transform:translateY(-2px);box-shadow:0 6px 12px #0000004d;background:linear-gradient(135deg,#d32f2f,#b71c1c)}.theme-toggle-btn{background:#0003;border:none;cursor:pointer;font-size:18px;padding:6px 10px;border-radius:50%;transition:transform .2s;margin-left:0;color:#fff;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:100}.theme-toggle-btn:hover{background:#ffffff1a;transform:rotate(5deg) translate(-50%,-50%)}.header-top{position:relative}@media(max-width:700px){.theme-toggle-btn{position:static;transform:none;margin-top:0;margin-left:10px}.theme-toggle-btn:hover{transform:rotate(15deg)}}.feedback-btn{position:fixed;bottom:20px;right:20px;width:50px;height:50px;border-radius:50%;background:#073075;color:#fff;border:none;font-size:24px;box-shadow:0 4px 12px #0000004d;cursor:pointer;z-index:1900;transition:transform .2s,background .2s;display:flex;align-items:center;justify-content:center}.feedback-btn:hover{transform:scale(1.1);background:#052358}.feedback-content{max-width:450px}.form-group{margin-bottom:12px;text-align:left}.form-group label{display:block;font-size:13px;font-weight:600;margin-bottom:4px;color:#444}.form-group input[type=text],.form-group input[type=email],.form-group textarea{width:100%;padding:10px;border:1px solid #ccc;border-radius:6px;font-family:inherit;font-size:14px}.form-group input[type=file]{font-size:13px}.submit-btn{width:100%;padding:10px;background:#073075;color:#fff;border:none;border-radius:6px;font-weight:700;cursor:pointer;margin-top:8px}.submit-btn:hover{background:#052358}body.dark-mode .form-group label{color:#ddd}body.dark-mode .form-group input,body.dark-mode .form-group textarea{background:#2c2c2c;border-color:#444;color:#fff}.news-content{max-width:600px;height:90vh;display:flex;flex-direction:column}.changelog-list{flex:1;max-height:none;overflow-y:auto;margin-bottom:10px;padding-right:10px}.changelog-item{position:relative;padding-left:20px;border-left:3px solid #eee;padding-bottom:24px}.changelog-item:last-child{border-left-color:transparent}.changelog-item:before{content:"";position:absolute;left:-8px;top:0;width:13px;height:13px;background:#073075;border-radius:50%;border:2px solid #fff}.changelog-date{font-size:11px;text-transform:uppercase;color:#888;margin-bottom:4px;font-weight:700}.changelog-version{font-size:16px;margin-bottom:8px;color:#073075}.changelog-details{padding-left:16px;margin:0;font-size:14px;color:#444;line-height:1.5}.changelog-details li{margin-bottom:4px}body.dark-mode .changelog-item{border-left-color:#333}body.dark-mode .changelog-item:before{border-color:#1e1e1e}body.dark-mode .changelog-details{color:#ddd}body.dark-mode .changelog-version{color:#4db6ac}.settings-btn{background:#fff3;border:1px solid rgba(255,255,255,.6);color:#fff;border-radius:8px;padding:10px 20px;font-size:16px;cursor:pointer;font-weight:600;display:flex;align-items:center;gap:8px;margin-top:5px;transition:all .2s ease}.settings-btn:hover{background:#ffffff4d;transform:scale(1.05)}.settings-group{margin-bottom:16px;border-bottom:1px solid #eee;padding-bottom:16px}.settings-group label{display:block;font-weight:600;margin-bottom:6px;font-size:14px}.settings-group input[type=date],.settings-group input[type=text]{width:100%;padding:8px;border:1px solid #ccc;border-radius:6px}.settings-note{font-size:12px;color:#666;margin-top:4px;font-style:italic}.goals-section{background:#fff;border-radius:12px;padding:16px;margin-bottom:24px;box-shadow:0 2px 6px #00000014;border-left:5px solid #29b6f6}.goals-container{display:flex;flex-wrap:wrap;gap:20px;align-items:flex-end}.goal-input-group{flex:1;min-width:200px}.goal-input-group label{font-size:13px;font-weight:600;color:#555;display:block;margin-bottom:4px}.goal-input-wrapper{display:flex;align-items:center;gap:8px}.goal-input-wrapper input{width:70px;padding:6px;border:1px solid #ddd;border-radius:6px;text-align:center}.goal-progress{margin-top:8px;height:8px;background:#eee;border-radius:999px;overflow:hidden}.goal-progress-bar{height:100%;background:#29b6f6;transition:width 1s}.goal-text{font-size:12px;margin-top:4px;color:#666;text-align:right}.subject-search-container{margin-bottom:16px}.subject-search-input{width:100%;padding:10px;border:1px solid #ccc;border-radius:8px;font-size:14px}body.dark-mode .settings-group{border-bottom-color:#333}body.dark-mode .settings-note{color:#aaa}body.dark-mode .goals-section{background:#1e1e1e;border-left-color:#0288d1}body.dark-mode .goal-input-group label{color:#ccc}body.dark-mode .goal-input-wrapper input,body.dark-mode .subject-search-input{background:#2c2c2c;border-color:#444;color:#fff}body.dark-mode .goal-progress{background:#333}.header-title-group{display:flex;flex-direction:column;align-items:flex-start;gap:5px}.settings-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.4);color:#fff;border-radius:6px;padding:4px 10px;cursor:pointer;font-size:13px;font-weight:500;display:flex;align-items:center;gap:6px;margin-top:0;transition:all .2s ease}.settings-btn:hover{background:#ffffff4d;transform:translateY(-1px)}body.dark-mode .sub-nav a{background:#2c2c2c;color:#4db6ac;border:1px solid #444;box-shadow:0 2px 4px #0006}body.dark-mode .sub-nav a:hover{background:#3e3e3e;color:#fff;transform:translateY(-1px)}body.dark-mode .stats-section{background:#1e1e1e;color:#e0e0e0;border:1px solid #333;box-shadow:0 4px 12px #0000004d}body.dark-mode .stats-section h2{color:#fff}body.dark-mode .subject-item{border-color:#444;background:transparent}body.dark-mode .subject-header{background:#262626;color:#e0e0e0}body.dark-mode .subject-header:hover{background:#333}body.dark-mode .subject-content{background:#1a1a1a;border-top:1px solid #444}body.dark-mode .subject-chapter{color:#aaa}body.dark-mode .subject-chapter.done{color:#66bb6a}.header-bottom-row{position:relative;display:flex;justify-content:center;align-items:center;margin-top:15px;min-height:40px}.header .motivation-btn{position:absolute;left:0;top:50%;transform:translateY(-50%);margin:0}.header #btn-settings{position:static!important;transform:none!important;margin:0!important}.motivation-box{margin-top:15px;position:relative;z-index:50}@media(max-width:650px){.header-bottom-row{flex-direction:column;gap:10px}.header .motivation-btn{position:static;transform:none}}@media(max-width:650px){.header>#btn-settings{position:static;transform:none;margin:10px auto 0;display:table}}body.dark-mode .modal-review-item{background:#2c2c2c;border:1px solid #444;color:#e0e0e0}body.dark-mode .modal-review-item.done{background:#1b3a28;border-left-color:#43a047;color:#a5d6a7}body.dark-mode .modal-close{color:#fff}body.dark-mode .modal-close:hover{background:#333}body.dark-mode .modal-progress-bg{background:#444}body.dark-mode .modal-review-reset-btn{background:#444;border-color:#555;color:#ccc}body.dark-mode .modal-review-reset-btn:hover{background:#555}.info-btn{background:#e3f2fd;color:#1565c0;border:1px solid #90caf9;padding:8px 12px;border-radius:8px;cursor:pointer;font-size:16px;line-height:1;transition:all .2s}.info-btn:hover{background:#bbdefb;transform:translateY(-1px);box-shadow:0 2px 5px #0000001a}body.dark-mode .info-btn{background:#263238;color:#90caf9;border-color:#546e7a}body.dark-mode .info-btn:hover{background:#37474f}body.dark-mode h3[style*="color: #d32f2f"]{color:#ef5350!important}body.dark-mode div[style*="background:#ffebee"]{background:#3e2723!important;border-color:#b71c1c!important;color:#ffcdd2!important}#btn-settings{padding:6px 8px!important;font-size:15px!important;width:auto!important}.search-wrapper,.subject-search-container{position:relative}.search-clear-btn{position:absolute;right:10px;top:27%;transform:translateY(-10%);background:none;border:none;color:#999;font-size:16px;cursor:pointer;display:none;padding:0 5px}.search-clear-btn:hover{color:#d32f2f}.search-wrapper input,.subject-search-container input{padding-right:30px!important}@media(max-width:950px){.header-top{flex-direction:column;align-items:center;gap:15px;padding-bottom:10px}.theme-toggle-btn{position:static!important;transform:none!important;margin:5px auto;order:2}.header-title-group{align-items:center;width:100%;order:1;margin-bottom:10px}.main-nav{flex-wrap:wrap;justify-content:center;order:4;margin-top:10px}.header-bottom-row{flex-direction:column;gap:15px;margin-top:20px}.header .motivation-btn,.header>#btn-settings{position:static!important;transform:none!important;width:fit-content;margin:0 auto}}.planning-nav-center{display:flex;gap:20px;margin-right:40px}.stats-nav-center{display:flex;gap:20px;margin-right:2px}.planning-nav-center a,.stats-nav-center a{display:inline-block;padding:6px 14px;background:#fff3;color:#fff;border-radius:8px;font-size:14px;font-weight:600;text-decoration:none;border:1px solid rgba(255,255,255,.4);transition:all .2s ease}.planning-nav-center a:hover,.stats-nav-center a:hover{background:#ffffff59;transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}@media(max-width:950px){.planning-nav-center,.stats-nav-center{flex-wrap:wrap;justify-content:center;width:100%;margin-right:0}}@media(max-width:30000px){.controls{flex-direction:column;align-items:stretch;gap:12px}.buttons-wrapper{order:1;display:flex;flex-direction:column;gap:8px;margin-bottom:10px;width:100%}.buttons-wrapper button,.buttons-wrapper .info-btn{width:100%;justify-content:center}.search-wrapper{order:2;max-width:100%;flex:1 1 auto}.filters-wrapper{order:3;margin-top:5px}}.sort-select{padding:8px 12px;border-radius:6px;border:1px solid #ccc;background-color:#fff;font-size:14px;cursor:pointer;color:#333;outline:none;transition:border-color .2s,box-shadow .2s;height:38px}.sort-select:hover{border-color:#073075}.sort-select:focus{border-color:#2f7e5f;box-shadow:0 0 0 2px #2f7e5f33}body.dark-mode .sort-select{background-color:#2c2c2c;border-color:#444;color:#fff}body.dark-mode .sort-select:hover{border-color:#4db6ac}@media(max-width:600px){.subject-search-container{flex-direction:column}.sort-select{width:100%}}.controls{display:flex;flex-direction:column;gap:15px;align-items:center;margin-bottom:30px}.buttons-wrapper{display:flex!important;flex-direction:row!important;flex-wrap:wrap;justify-content:center;gap:10px;width:100%;order:1}.buttons-wrapper button,.buttons-wrapper .info-btn{width:auto!important;min-width:0;padding:8px 16px;white-space:nowrap;font-size:14px}.search-tools{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:15px;width:100%;order:2}.search-group{position:relative;display:flex;align-items:center}.search-group input{padding:8px 30px 8px 10px;border:1px solid #ccc;border-radius:6px;width:220px}.sort-group{display:flex;align-items:center;gap:5px;font-size:14px;font-weight:600}.filter-checkbox{display:flex;align-items:center;gap:5px;font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap}@media(max-width:700px){.search-group input{width:100%;min-width:200px}.buttons-wrapper{width:100%!important}}body{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}input,textarea{-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}body.dark-mode .search-group input,body.dark-mode .sort-select{background-color:#2c2c2c;color:#fff;border-color:#555}body.dark-mode .sort-select:hover,body.dark-mode .search-group input:focus{border-color:#4db6ac}body.dark-mode .filter-checkbox,body.dark-mode .sort-group label{color:#e0e0e0}body.dark-mode .search-clear-btn{color:#bbb}body.dark-mode .search-clear-btn:hover{color:#ef5350}body.dark-mode .info-btn{background-color:#37474f;color:#90caf9;border-color:#546e7a}body.dark-mode .info-btn:hover{background-color:#455a64;color:#fff}body.dark-mode #info-modal ul{color:#e0e0e0!important}body.dark-mode #info-modal div[style*="background:#fff5f5"]{background-color:#3e2723!important;border-color:#b71c1c!important;color:#ffcdd2!important}body.dark-mode #info-modal h3[style*="color: #d32f2f"]{color:#ef5350!important}body.dark-mode #info-modal p[style*="color:#b71c1c"]{color:#ffcdd2!important}body.dark-mode #info-modal h3[style*="color: #1565c0"]{color:#90caf9!important}body.dark-mode #info-modal h2[style*="color: #2f7e5f"]{color:#81c784!important}body.dark-mode #info-modal hr{border-top-color:#444!important}#info-modal ul{gap:20px!important}#info-modal li{padding-bottom:15px;border-bottom:1px solid #eee;align-items:flex-start!important}#info-modal li:last-child{border-bottom:none}#info-modal li strong{display:block;font-size:15px;color:#1565c0;margin-bottom:4px;text-decoration:underline;text-underline-offset:3px;text-decoration-color:#b3e5fc}body.dark-mode #info-modal li{border-bottom-color:#444}body.dark-mode #info-modal li strong{color:#90caf9;text-decoration-color:#1e88e5}#info-modal h3[style*="color: #1565c0"]{text-align:center!important;margin-top:10px}.difficulty-buttons{display:flex;gap:8px;margin:12px 0;flex-wrap:wrap}.difficulty-btn{flex:1;min-width:90px;padding:12px 16px;border:none;border-radius:10px;cursor:pointer;font-weight:700;font-size:14px;transition:transform .15s ease,box-shadow .15s ease;display:flex;flex-direction:column;align-items:center;gap:4px}.difficulty-btn:hover{transform:scale(1.03);box-shadow:0 4px 16px #0003}.difficulty-btn:active{transform:scale(.98)}.difficulty-btn.easy{background:linear-gradient(135deg,#4caf50,#81c784);color:#fff}.difficulty-btn.medium{background:linear-gradient(135deg,#ff9800,#ffb74d);color:#fff}.difficulty-btn.hard{background:linear-gradient(135deg,#f44336,#e57373);color:#fff}.difficulty-btn.selected{box-shadow:0 0 0 3px #0000004d,0 4px 12px #0003}.community-stats{display:flex;justify-content:space-around;margin-top:15px;padding:15px;background:linear-gradient(135deg,#f5f5f5,#e8e8e8);border-radius:12px;font-size:13px}.community-stat{text-align:center;padding:8px}.community-stat-label{display:block;font-size:18px;margin-bottom:4px}.community-stat-value{font-weight:700;font-size:16px}.community-stat-count{font-size:11px;color:#666;margin-top:2px}.community-stat.easy .community-stat-value{color:#4caf50}.community-stat.medium .community-stat-value{color:#ff9800}.community-stat.hard .community-stat-value{color:#f44336}body.dark-mode .community-stats{background:linear-gradient(135deg,#2a2a2a,#333)}body.dark-mode .community-stat-count{color:#aaa}.notes-section{margin-top:20px;padding:15px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:12px;border:1px solid #dee2e6}.notes-section label{display:block;font-weight:600;margin-bottom:8px;color:#495057}.chapter-notes{width:100%;min-height:100px;padding:12px;border:1px solid #ced4da;border-radius:8px;resize:vertical;font-family:inherit;font-size:14px;line-height:1.5;transition:border-color .2s,box-shadow .2s}.chapter-notes:focus{border-color:#2f7e5f;box-shadow:0 0 0 3px #2f7e5f1a;outline:none}.save-indicator{display:block;margin-top:8px;font-size:12px;color:#4caf50;font-weight:600;min-height:18px}body.dark-mode .notes-section{background:linear-gradient(135deg,#2a2a2a,#333);border-color:#444}body.dark-mode .notes-section label{color:#ddd}body.dark-mode .chapter-notes{background:#1e1e1e;border-color:#444;color:#eee}body.dark-mode .chapter-notes:focus{border-color:#66bb6a;box-shadow:0 0 0 3px #66bb6a33}.pomodoro-toggle-btn{padding:8px 14px;border-radius:999px;border:none;cursor:pointer;font-size:14px;font-weight:600;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 2px 8px #667eea4d;transition:transform .15s,box-shadow .15s;margin-left:10px}.pomodoro-toggle-btn:hover{transform:scale(1.02);box-shadow:0 4px 12px #667eea66}.pomodoro-toggle-btn.active{background:linear-gradient(135deg,#764ba2,#667eea);box-shadow:0 0 0 3px #764ba24d}.pomodoro-widget{display:none;position:absolute;top:100%;right:0;margin-top:10px;background:linear-gradient(145deg,#667eea,#764ba2);border-radius:16px;padding:16px 20px;color:#fff;box-shadow:0 8px 32px #667eea66;z-index:900;min-width:260px;animation:slideDown .2s ease-out}.pomodoro-widget.visible{display:block}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.pomodoro-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.pomodoro-title{font-weight:700;font-size:16px}.pomo-close-btn{background:#fff3;border:none;color:#fff;padding:4px 8px;border-radius:6px;cursor:pointer;font-size:12px}.pomo-close-btn:hover{background:#ffffff4d}.pomodoro-display{text-align:center;margin-bottom:15px}.pomodoro-time{display:block;font-size:48px;font-weight:800;font-variant-numeric:tabular-nums;text-shadow:0 2px 8px rgba(0,0,0,.2);letter-spacing:2px}.pomodoro-mode-label{display:block;font-size:13px;opacity:.9;margin-top:4px}.pomodoro-controls{display:flex;justify-content:center;gap:10px;margin-bottom:15px}.pomo-btn{background:#fff3;border:none;padding:10px 14px;border-radius:10px;cursor:pointer;font-size:18px;transition:background .15s,transform .1s;display:inline-flex;align-items:center;justify-content:center}.pomo-btn:hover{background:#ffffff4d;transform:scale(1.05)}.pomo-btn:active{transform:scale(.95)}.pomodoro-modes{display:flex;gap:6px;flex-wrap:wrap}.pomo-mode-btn{flex:1;min-width:55px;padding:8px 6px;background:#ffffff26;border:1px solid rgba(255,255,255,.3);border-radius:8px;color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.pomo-mode-btn:hover{background:#ffffff40}.pomo-mode-btn.active{background:#ffffff59;border-color:#fff}.heatmap-container{padding:20px;background:#fff;border-radius:12px;box-shadow:0 1px 4px #00000014;overflow-x:auto}.heatmap-grid{display:flex;gap:3px;justify-content:flex-start}.heatmap-week{display:flex;flex-direction:column;gap:3px}.heatmap-cell{width:14px;height:14px;border-radius:3px;cursor:pointer;transition:transform .1s}.heatmap-cell:hover{transform:scale(1.2)}.heatmap-cell.level-0{background:#ebedf0}.heatmap-cell.level-1{background:#9be9a8}.heatmap-cell.level-2{background:#40c463}.heatmap-cell.level-3{background:#30a14e}.heatmap-cell.level-4{background:#216e39}body.dark-mode .heatmap-container{background:#1e1e1e}body.dark-mode .heatmap-cell.level-0{background:#2d333b}.trophies-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:15px;padding:10px 0}.trophy-card{text-align:center;padding:18px 12px;border-radius:14px;transition:transform .15s;cursor:default}.trophy-card:hover{transform:translateY(-3px)}.trophy-card.unlocked{background:linear-gradient(145deg,#fff9c4,#ffecb3);box-shadow:0 4px 16px #ffc10733}.trophy-card.locked{background:#f5f5f5;opacity:.65;filter:grayscale(.8)}.trophy-icon{font-size:36px;margin-bottom:8px;display:block}.trophy-name{font-weight:700;font-size:14px;margin-bottom:4px;color:#333}.trophy-desc{font-size:11px;color:#666}body.dark-mode .trophy-card.unlocked{background:linear-gradient(145deg,#4e4007,#5d4c00)}body.dark-mode .trophy-card.locked{background:#2a2a2a}body.dark-mode .trophy-name{color:#eee}body.dark-mode .trophy-desc{color:#aaa}.cloud-btn{padding:8px 14px;border-radius:999px;border:none;cursor:pointer;font-size:14px;font-weight:600;background:linear-gradient(135deg,#29b6f6,#0288d1);color:#fff;box-shadow:0 2px 8px #29b6f64d;transition:transform .15s,box-shadow .15s;margin-left:10px}.cloud-btn:hover{transform:scale(1.02);box-shadow:0 4px 12px #29b6f666}.cloud-btn.connected{background:linear-gradient(135deg,#66bb6a,#43a047);box-shadow:0 2px 8px #66bb6a4d}.cloud-modal-tabs{display:flex;gap:0;margin-bottom:20px;border-bottom:2px solid #e0e0e0}.cloud-tab{flex:1;padding:12px;background:transparent;border:none;cursor:pointer;font-weight:600;color:#666;transition:color .2s,border-color .2s;border-bottom:2px solid transparent;margin-bottom:-2px}.cloud-tab.active{color:#073075;border-bottom-color:#073075}.cloud-tab:hover:not(.active){color:#333}.cloud-form{display:flex;flex-direction:column;gap:15px}.cloud-form-group{display:flex;flex-direction:column;gap:6px}.cloud-form-group label{font-weight:600;font-size:13px;color:#555}.cloud-form-group input{padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:14px;transition:border-color .2s,box-shadow .2s}.cloud-form-group input:focus{border-color:#073075;box-shadow:0 0 0 3px #0730751a;outline:none}.password-wrapper{position:relative;display:flex;align-items:center}.password-wrapper input{width:100%;padding-right:40px}.password-toggle-btn{position:absolute;right:10px;background:transparent;border:none;cursor:pointer;font-size:16px;color:#888;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s}.password-toggle-btn:hover{color:#073075}.forgot-password-link{display:inline-block;margin-top:6px;font-size:13px;color:#073075;text-decoration:underline;cursor:pointer;background:none;border:none;padding:0}.forgot-password-link:hover{color:#1b5e45}body.dark-mode .password-toggle-btn{color:#aaa}body.dark-mode .password-toggle-btn:hover{color:#66bb6a}body.dark-mode .forgot-password-link{color:#81c784}.cloud-submit-btn{padding:12px;background:linear-gradient(135deg,#073075,#42a5f5);color:#fff;border:none;border-radius:10px;font-weight:700;font-size:15px;cursor:pointer;transition:transform .1s,box-shadow .2s}.cloud-submit-btn:hover{transform:scale(1.01);box-shadow:0 4px 16px #0730754d}.cloud-connected-state{text-align:center;padding:20px}.cloud-user-info{margin-bottom:20px}.cloud-user-avatar{font-size:48px;margin-bottom:10px}.cloud-user-name{font-weight:700;font-size:18px}.cloud-last-sync{font-size:13px;color:#666;margin-top:5px}.cloud-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.cloud-sync-btn{padding:10px 20px;background:linear-gradient(135deg,#29b6f6,#0288d1);color:#fff;border:none;border-radius:999px;font-weight:600;cursor:pointer}.cloud-logout-btn{padding:10px 20px;background:#f5f5f5;color:#666;border:1px solid #ddd;border-radius:999px;font-weight:600;cursor:pointer}body.dark-mode .cloud-tab{color:#999}body.dark-mode .cloud-tab.active{color:#66bb6a;border-bottom-color:#66bb6a}body.dark-mode .cloud-form-group label{color:#ccc}body.dark-mode .cloud-form-group input{background:#1e1e1e;border-color:#444;color:#eee}body.dark-mode .cloud-last-sync{color:#aaa}body.dark-mode .cloud-logout-btn{background:#333;color:#ccc;border-color:#555}.leaderboard-tabs{display:flex;gap:8px;margin-bottom:15px;flex-wrap:wrap}.lb-tab{padding:8px 16px;background:#f5f5f5;border:1px solid #e0e0e0;border-radius:999px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.lb-tab:hover{background:#e0e0e0}.lb-tab.active{background:#073075;color:#fff;border-color:#073075}#lb-subject-select{padding:8px 12px;border-radius:8px;border:1px solid #ddd;font-size:13px;margin-bottom:15px;max-width:300px}.leaderboard-list{display:flex;flex-direction:column;gap:8px}.leaderboard-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fff;border-radius:10px;box-shadow:0 1px 4px #0000000f}.leaderboard-item.rank-1{background:linear-gradient(135deg,#fff9c4,#ffecb3);border:2px solid #ffc107}.leaderboard-item.rank-2{background:linear-gradient(135deg,#f5f5f5,#e0e0e0);border:2px solid #9e9e9e}.leaderboard-item.rank-3{background:linear-gradient(135deg,#ffe0b2,#ffcc80);border:2px solid #ff9800}.leaderboard-rank{font-size:20px;min-width:36px;text-align:center}.leaderboard-name{flex:1;font-weight:600}.leaderboard-score{font-weight:700;color:#073075}body.dark-mode .lb-tab{background:#2a2a2a;border-color:#444;color:#ccc}body.dark-mode .lb-tab:hover{background:#333}body.dark-mode .lb-tab.active{background:#073075;color:#fff}body.dark-mode .leaderboard-item{background:#1e1e1e}body.dark-mode .leaderboard-item.rank-1{background:linear-gradient(135deg,#4e4007,#5d4c00)}body.dark-mode .leaderboard-item.rank-2{background:linear-gradient(135deg,#3a3a3a,#4a4a4a)}body.dark-mode .leaderboard-item.rank-3{background:linear-gradient(135deg,#5d3a00,#6d4500)}body.dark-mode .leaderboard-name{color:#eee}.header-bottom-row{margin-top:12px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;position:relative}.settings-btn{padding:8px 14px;border-radius:999px;border:none;cursor:pointer;font-size:14px;font-weight:600;background:#fff3;color:#fff;margin-left:auto}#auth-wall{position:fixed;top:0;left:0;width:100%;height:100%;z-index:10000;background:var(--bg-color);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;overflow-y:auto;transition:opacity .5s ease}#auth-wall.hidden{opacity:0;pointer-events:none}.auth-container{background:var(--card-bg);padding:30px;border-radius:20px;box-shadow:0 10px 30px #00000026;max-width:400px;width:100%;text-align:center}.auth-logo{font-size:3rem;margin-bottom:10px}.auth-title{font-size:1.5rem;font-weight:700;margin-bottom:20px;color:var(--text-color)}.auth-subtitle{color:var(--gray-text);margin-bottom:30px;font-size:.95rem}.auth-import-section{margin-top:20px;padding-top:20px;border-top:1px solid var(--border-color);text-align:left}.auth-import-label{display:block;font-size:.85rem;margin-bottom:8px;color:var(--gray-text)}.auth-file-input{width:100%;padding:8px;background:var(--bg-color);border:1px solid var(--border-color);border-radius:8px;font-size:.85rem}body.dark-mode #auth-wall{background:#121212}body.dark-mode .auth-container{background:#1e1e1e}#landing-view{background:#fff;min-height:100vh;display:flex;flex-direction:column;font-family:Segoe UI,system-ui,sans-serif;color:#333}.landing-nav{display:flex;justify-content:space-between;align-items:center;padding:20px 5%;background:#fff;position:sticky;top:0;z-index:100;box-shadow:0 1px #0000000d}.landing-logo{font-size:20px;font-weight:700;color:#073075;display:flex;align-items:center;gap:8px}.landing-nav-buttons{display:flex;gap:12px}.landing-btn-primary{background:#073075;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;font-size:15px}.landing-btn-primary:hover{background:#052358;transform:translateY(-1px);box-shadow:0 4px 12px #07307533}.landing-btn-outline{background:transparent;color:#073075;border:1px solid #073075;padding:9px 19px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;font-size:15px}.landing-btn-outline:hover{background:#e6ebf5}.big-btn{padding:14px 28px;font-size:17px}.full-width{width:100%;margin-top:10px}.landing-hero{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;padding:60px 5% 40px;gap:40px;background:radial-gradient(circle at top right,#e7f7ed,#fff 50%)}.hero-content{flex:1 1 500px;max-width:600px}.hero-title{font-size:48px;line-height:1.2;font-weight:800;margin-bottom:20px;color:#1a1a1a}.hero-title .highlight{color:#073075}.hero-subtitle{font-size:18px;line-height:1.6;color:#555;margin-bottom:30px}.hero-buttons{margin-bottom:30px}.hero-trust{display:flex;gap:20px;font-size:14px;color:#666;font-weight:500}.hero-visual{flex:1 1 500px;display:flex;justify-content:center}.hero-dashboard-img{width:100%;max-width:650px;border-radius:12px;box-shadow:0 20px 40px #0000001a;transform:perspective(1000px) rotateY(-5deg) rotateX(2deg);transition:transform .3s ease}.hero-dashboard-img:hover{transform:perspective(1000px) rotateY(0) rotateX(0)}.landing-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:30px;padding:80px 5%;background:#f9fafb}.feature-card{background:#fff;padding:30px;border-radius:12px;box-shadow:0 4px 6px #00000005;border:1px solid #eee;transition:transform .2s}.feature-card:hover{transform:translateY(-5px);box-shadow:0 10px 20px #0000000d;border-color:#073075}.feature-icon{font-size:32px;margin-bottom:15px;background:#e6ebf5;width:60px;height:60px;display:flex;align-items:center;justify-content:center;border-radius:50%}.feature-card h3{font-size:20px;margin-bottom:10px;color:#222}.feature-card p{font-size:15px;color:#666;line-height:1.5}.landing-footer{text-align:center;padding:40px;color:#888;font-size:14px;border-top:1px solid #eee;margin-top:auto}.auth-modal-content{max-width:420px;padding:30px!important;text-align:left}.auth-header{text-align:center;margin-bottom:24px}.auth-logo-small{font-size:40px;margin-bottom:10px}.auth-form .form-group{margin-bottom:15px;text-align:left}.auth-form label{display:block;font-size:14px;font-weight:600;margin-bottom:6px;color:#333}.auth-form input[type=text],.auth-form input[type=email],.auth-form input[type=password]{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:15px;transition:border-color .2s}.auth-form input:focus{border-color:#073075;outline:none;box-shadow:0 0 0 3px #0730751a}.checkbox-group{display:flex;align-items:center}.remember-label{display:flex;align-items:center;gap:8px;font-weight:400!important;cursor:pointer;-webkit-user-select:none;user-select:none}.info-box-blue{background:#e3f2fd;color:#0d47a1;padding:10px;border-radius:6px;font-size:13px;margin-bottom:15px;border-left:3px solid #0d47a1}.auth-error{margin-top:15px;padding:10px;background:#ffebee;color:#c62828;border-radius:6px;font-size:14px;text-align:center}@media(max-width:768px){.hero-title{font-size:36px}.landing-hero{flex-direction:column;text-align:center}.hero-content{margin:0 auto}.hero-trust{justify-content:center;flex-wrap:wrap}}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s ease-in-out infinite;margin-right:8px;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}.btn-loading{position:relative;pointer-events:none;opacity:.8}.btn-loading .btn-text{visibility:hidden}.btn-loading:after{content:"";position:absolute;left:50%;top:50%;width:18px;height:18px;margin-left:-9px;margin-top:-9px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .8s linear infinite}.auth-success{margin-top:15px;padding:10px;background:#e8f5e9;color:#2e7d32;border-radius:6px;font-size:14px;text-align:center;border:1px solid #c8e6c9}.landing-pricing{padding:60px 20px 80px;background:linear-gradient(180deg,#f5f6fa,#e8eaf6);text-align:center}.pricing-title{font-size:2rem;font-weight:700;margin-bottom:8px;color:#073075}.pricing-subtitle{font-size:1.1rem;color:#555;margin-bottom:20px}.pricing-info-box{display:flex;align-items:flex-start;gap:12px;max-width:600px;margin:0 auto 30px;padding:16px 20px;background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-radius:12px;border-left:4px solid #1976d2;text-align:left}.pricing-info-icon{font-size:24px;flex-shrink:0}.pricing-info-box p{margin:0;font-size:14px;color:#1565c0;line-height:1.5}.pricing-info-box strong{color:#0d47a1}stripe-pricing-table{max-width:900px;margin:0 auto;display:block}@media(max-width:768px){.pricing-title{font-size:1.6rem}.pricing-subtitle{font-size:1rem}}.user-status-box{display:flex;align-items:center;gap:12px;padding:8px 16px;background:#ffffff1a;border-radius:999px}.user-status-box span{color:#fff;font-weight:500;font-size:14px}.user-status-box .landing-btn-primary,.user-status-box .landing-btn-outline{padding:6px 14px;font-size:13px}@media(max-width:768px){.user-status-box{flex-direction:column;gap:8px;padding:12px;width:100%;background:#073075e6;border-radius:12px}.user-status-box span{font-size:13px}.user-status-box button{width:100%}}:root{--sidebar-width: 260px;--sidebar-collapsed-width: 70px;--sidebar-bg: #073075;--sidebar-hover: rgba(255,255,255,.1);--sidebar-active: rgba(255,255,255,.2);--sidebar-text: #fff;--sidebar-muted: rgba(255,255,255,.7);--sidebar-transition: .3s ease}body:not(.sidebar-ready){opacity:0}body.sidebar-ready{opacity:1;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}body{animation:fallbackReveal 0s 2s forwards}@keyframes fallbackReveal{to{opacity:1}}.app-layout{display:flex;min-height:100vh}.app-content{flex:1;margin-left:var(--sidebar-width);transition:margin-left var(--sidebar-transition);min-width:0}.sidebar-collapsed .app-content{margin-left:var(--sidebar-collapsed-width)}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;z-index:1000;transition:width var(--sidebar-transition);overflow:hidden}.sidebar-collapsed .sidebar{width:var(--sidebar-collapsed-width)}.sidebar-header{display:flex;align-items:center;gap:12px;padding:16px;border-bottom:1px solid rgba(255,255,255,.1);min-height:60px}.sidebar-toggle{background:transparent;border:none;color:var(--sidebar-text);font-size:22px;cursor:pointer;padding:8px;border-radius:8px;transition:background .2s;flex-shrink:0}.sidebar-toggle:hover{background:var(--sidebar-hover)}.sidebar-logo{font-size:18px;font-weight:700;white-space:nowrap;opacity:1;transition:opacity var(--sidebar-transition)}.sidebar-collapsed .sidebar-logo{opacity:0;width:0}.sidebar-profile{padding:20px 16px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;align-items:center;gap:10px}.sidebar-collapsed .sidebar-profile{padding:16px 8px}.profile-avatar-btn{background:transparent;border:none;padding:0;cursor:pointer;border-radius:50%;transition:transform .2s,box-shadow .2s}.profile-avatar-btn:hover{transform:scale(1.05)}.profile-avatar-btn:hover .profile-avatar{box-shadow:0 0 0 3px #ffffff4d}.profile-info{text-align:center;transition:opacity var(--sidebar-transition),height var(--sidebar-transition)}.sidebar-collapsed .profile-info{opacity:0;height:0;overflow:hidden}.profile-name{font-weight:600;font-size:15px;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.profile-settings-btn{background:#ffffff1a;border:none;color:var(--sidebar-muted);font-size:12px;padding:6px 12px;border-radius:999px;cursor:pointer;transition:background .2s,color .2s;white-space:nowrap}.profile-settings-btn:hover{background:#fff3;color:#fff}.sidebar-collapsed .profile-settings-btn{display:none}.profile-status{display:inline-block;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600;margin-top:4px;text-align:center}.profile-status.premium{background:linear-gradient(135deg,#f5af00 0% 100%);color:#5d4200}.profile-status.free{background:#ff8a8026;color:#ff8a80;font-size:10px;max-width:140px;line-height:1.3;padding:4px 8px;text-decoration:none;cursor:pointer;transition:background .2s,transform .2s}.profile-status.free:hover{background:#ff8a8040;transform:scale(1.02)}.sidebar-collapsed .profile-status{display:none}.profile-avatar{position:relative;width:50px;height:50px;background:#ffffff26;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:box-shadow .2s}.avatar-icon{font-size:24px}.avatar-crown{position:absolute;top:-4px;left:50%;transform:translate(-50%);font-size:14px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3));animation:crownBounce 2s ease-in-out infinite}@keyframes crownBounce{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(-2px)}}.sidebar-collapsed .profile-avatar{width:40px;height:40px}.sidebar-collapsed .avatar-icon{font-size:20px}.sidebar-collapsed .avatar-crown{font-size:10px;top:-2px}.avatar-premium{box-shadow:0 0 8px #ffd7004d}.is-premium .profile-avatar-btn:hover .avatar-premium{box-shadow:0 0 12px #ffd70080}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.sidebar-link{display:flex;align-items:center;gap:14px;padding:12px 14px;border-radius:10px;color:var(--sidebar-text);text-decoration:none;font-size:15px;font-weight:500;transition:background .2s;margin-bottom:4px;white-space:nowrap}.sidebar-link:hover{background:var(--sidebar-hover)}.sidebar-link.active{background:var(--sidebar-active);font-weight:600}.sidebar-link-icon{font-size:20px;width:24px;text-align:center;flex-shrink:0}.sidebar-link-text{opacity:1;transition:opacity var(--sidebar-transition)}.sidebar-collapsed .sidebar-link-text{opacity:0;width:0;overflow:hidden}.sidebar-collapsed .sidebar-link{justify-content:center;padding:12px}.sidebar-collapsed .sidebar-nav{padding:16px 8px}.sidebar-footer{padding:12px;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:6px}.sidebar-btn{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;background:transparent;border:none;color:var(--sidebar-muted);font-size:14px;cursor:pointer;transition:background .2s,color .2s;text-align:left;width:100%;white-space:nowrap}.sidebar-btn:hover{background:var(--sidebar-hover);color:#fff}.sidebar-btn.logout{color:#ff8a80}.sidebar-btn.logout:hover{background:#ff6b6b26;color:#ff5252}.sidebar-btn-icon{font-size:18px;width:24px;text-align:center;flex-shrink:0}.sidebar-btn-text{opacity:1;transition:opacity var(--sidebar-transition)}.sidebar-collapsed .sidebar-btn-text{opacity:0;width:0;overflow:hidden}.sidebar-collapsed .sidebar-btn{justify-content:center;padding:12px}.sidebar-collapsed .sidebar-footer{padding:12px 8px}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:999;opacity:0;transition:opacity .3s}.sidebar-overlay.active{opacity:1}.mobile-menu-btn{display:none;position:fixed;top:12px;left:12px;z-index:998;background:var(--sidebar-bg);color:#fff;border:none;padding:10px 12px;border-radius:10px;font-size:20px;cursor:pointer;box-shadow:0 2px 8px #0003}@media(max-width:900px){.sidebar{transform:translate(-100%);width:var(--sidebar-width)}.sidebar.mobile-open{transform:translate(0)}.sidebar-overlay{display:block}.app-content,.sidebar-collapsed .app-content{margin-left:0}.mobile-menu-btn{display:flex;align-items:center;justify-content:center}.header{padding-left:60px}}body.dark-mode .sidebar{--sidebar-bg: #0a1628;--sidebar-hover: rgba(255,255,255,.08);--sidebar-active: rgba(255,255,255,.12);background:var(--sidebar-bg)}body.dark-mode .sidebar-overlay{background:#000000b3}body.dark-mode .mobile-menu-btn{background:#0a1628}.sidebar-collapsed .sidebar-link,.sidebar-collapsed .sidebar-btn{position:relative}.sidebar-collapsed .sidebar-link:hover:after,.sidebar-collapsed .sidebar-btn:hover:after{content:attr(data-tooltip);position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);background:#333;color:#fff;padding:6px 12px;border-radius:6px;font-size:13px;white-space:nowrap;z-index:1001;pointer-events:none}.sidebar-link.locked{opacity:.5;cursor:pointer;position:relative}.sidebar-link.locked:hover{opacity:.7}.sidebar-link.locked .sidebar-link-text{text-decoration:line-through;text-decoration-color:#ffffff80}.sidebar-lock{margin-left:auto;font-size:14px;opacity:.9}.sidebar-collapsed .sidebar-link.locked{opacity:.4}.sidebar-collapsed .sidebar-lock{display:block;position:absolute;right:4px;bottom:4px;font-size:10px;background:#0009;border-radius:50%;width:16px;height:16px;display:flex;align-items:center;justify-content:center}.sidebar-collapsed .sidebar-link.locked .sidebar-link-icon{opacity:.5;filter:grayscale(.5)}.sidebar-profile-guest .profile-avatar{background:#ffffff14}.sidebar-login-btn{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff!important;font-weight:600}.sidebar-login-btn:hover{filter:brightness(1.1);background:linear-gradient(135deg,#4facfe,#00f2fe)}.sidebar-btn.primary{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff;font-weight:600}.sidebar-btn.primary:hover{filter:brightness(1.1);background:linear-gradient(135deg,#4facfe,#00f2fe)}body:has(.sidebar) .landing-nav{display:none}body:has(.sidebar) #landing-view{padding-top:0}
