@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/8a480f0b521d4e75-s.8e0177b5.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7178b3e590c64307-s.b97b3418.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/caa3a2e1cccd8315-s.p.853070df.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Fallback;src:local(Arial);ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.0%;size-adjust:104.76%}.geist_a71539c9-module__T19VSG__className{font-family:Geist,Geist Fallback;font-style:normal}.geist_a71539c9-module__T19VSG__variable{--font-geist-sans:"Geist","Geist Fallback"}
@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/4fa387ec64143e14-s.c1fdd6c2.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/bbc41e54d2fcbd21-s.799d8ef8.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/797e433ab948586e-s.p.dbea232f.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Mono Fallback;src:local(Arial);ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.0%;size-adjust:134.59%}.geist_mono_8d43a2aa-module__8Li5zG__className{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.geist_mono_8d43a2aa-module__8Li5zG__variable{--font-geist-mono:"Geist Mono","Geist Mono Fallback"}
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-ease:initial}::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--ease-out:cubic-bezier(0,0,.2,1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before{box-sizing:border-box;border:0 solid;margin:0;padding:0}::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::-webkit-file-upload-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:transparent;border-radius:0}::-webkit-file-upload-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:transparent;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:transparent;border-radius:0}:where(select:-webkit-any([multiple],[size])) optgroup{font-weight:bolder}:where(select:-moz-any([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:-webkit-any([multiple],[size])) optgroup option:not(:-webkit-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))){padding-left:20px}:where(select:-moz-any([multiple],[size])) optgroup option:not(:-moz-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))){padding-left:20px}:where(select:is([multiple],[size])) optgroup option:not(:is(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))){padding-left:20px}:where(select:-webkit-any([multiple],[size])) optgroup option:-webkit-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi)){padding-right:20px}:where(select:-moz-any([multiple],[size])) optgroup option:-moz-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi)){padding-right:20px}:where(select:is([multiple],[size])) optgroup option:is(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi)){padding-right:20px}:not(:-webkit-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi)))::-webkit-file-upload-button{margin-right:4px}:not(:-moz-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi)))::file-selector-button{margin-right:4px}:not(:is(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi)))::file-selector-button{margin-right:4px}:-webkit-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))::-webkit-file-upload-button{margin-left:4px}:-moz-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))::file-selector-button{margin-left:4px}:is(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))::file-selector-button{margin-left:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-top:0;padding-bottom:0}::-webkit-datetime-edit-year-field{padding-top:0;padding-bottom:0}::-webkit-datetime-edit-month-field{padding-top:0;padding-bottom:0}::-webkit-datetime-edit-day-field{padding-top:0;padding-bottom:0}::-webkit-datetime-edit-hour-field{padding-top:0;padding-bottom:0}::-webkit-datetime-edit-minute-field{padding-top:0;padding-bottom:0}::-webkit-datetime-edit-second-field{padding-top:0;padding-bottom:0}::-webkit-datetime-edit-millisecond-field{padding-top:0;padding-bottom:0}::-webkit-datetime-edit-meridiem-field{padding-top:0;padding-bottom:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button{-webkit-appearance:button;-moz-appearance:button;appearance:button}input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-file-upload-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.flex{display:flex}.grid{display:grid}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.overflow-x-scroll{overflow-x:scroll}.border{border-style:var(--tw-border-style);border-width:1px}.lowercase{text-transform:lowercase}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.transition{transition-property:color,background-color,border-color,outline-color,-webkit-text-decoration-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,visibility,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;overflow-x:hidden}.App{box-sizing:border-box;width:100%;max-width:1400px;margin:0 auto;padding:20px}.App-header{background:#fff;border-radius:12px;margin-bottom:20px;padding:20px;box-shadow:0 4px 6px rgba(0,0,0,.1)}.App-header h1{color:#333;text-align:center;font-size:28px}.overview-analytics-container{background:#fff;border-radius:12px;margin-bottom:20px;box-shadow:0 4px 6px rgba(0,0,0,.1)}.overview-analytics-tabs{border-bottom:1px solid #e2e8f0;gap:8px;padding:10px 10px 0;display:flex}.overview-tab{cursor:pointer;background:#fff;border:2px solid #e2e8f0;border-bottom:none;border-radius:8px 8px 0 0;flex:1;justify-content:center;align-items:center;gap:8px;max-width:200px;padding:12px 16px;font-size:14px;transition:all .3s;display:flex}.overview-tab:hover{background:#f7fafc;border-color:#cbd5e0}.overview-tab.active{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-color:#667eea}.overview-analytics-content{padding:0}.topics-container{background:#fff;border-radius:12px;box-shadow:0 4px 6px rgba(0,0,0,.1)}.tabs-container{background:#fff;border-radius:12px;margin-bottom:20px;padding:10px;box-shadow:0 4px 6px rgba(0,0,0,.1)}.tabs{flex-wrap:wrap;gap:8px;display:flex}.tab{cursor:pointer;background:#fff;border:2px solid #e2e8f0;border-radius:8px;flex:1;align-items:center;gap:8px;min-width:150px;padding:12px 16px;font-size:14px;transition:all .3s;display:flex}.tab:hover{background:#f7fafc;border-color:#cbd5e0}.tab.active{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-color:#667eea}.tab-number{font-size:16px;font-weight:700}.tab-title{text-align:left;text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.tab-progress{background:rgba(0,0,0,.1);border-radius:12px;padding:2px 8px;font-size:12px;font-weight:700}.tab.active .tab-progress{background:rgba(255,255,255,.3)}.main-content{box-sizing:border-box;background:#fff;border-radius:12px;width:100%;min-height:500px;max-height:calc(100vh - 200px);padding:30px;overflow-x:hidden;overflow-y:auto;box-shadow:0 4px 6px rgba(0,0,0,.1)}.main-content::-webkit-scrollbar{width:8px}.main-content::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.main-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.main-content::-webkit-scrollbar-thumb:hover{background:#94a3b8}.topic-tab{animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.topic-header{border-bottom:2px solid #e2e8f0;justify-content:space-between;align-items:center;margin-bottom:25px;padding-bottom:15px;display:flex}.topic-header h2{color:#333;flex:1;font-size:24px}.topic-link{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:8px;padding:10px 20px;font-weight:500;text-decoration:none;transition:transform .2s,box-shadow .2s}.topic-link:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(102,126,234,.4)}.progress-bar-container{margin-bottom:25px}.progress-info{justify-content:space-between;margin-bottom:8px;display:flex}.progress-info span{color:#666;font-size:14px;font-weight:500}.progress-bar{background:#e2e8f0;border-radius:10px;height:20px;overflow:hidden}.progress-fill{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:flex-end;align-items:center;height:100%;padding-right:8px;transition:width .3s;display:flex}.add-problem-form{background:#f7fafc;border-radius:8px;gap:10px;margin-bottom:25px;padding:20px;display:flex}.input-field{border:2px solid #e2e8f0;border-radius:6px;flex:1;padding:10px 15px;font-size:14px;transition:border-color .2s}.input-field:focus{border-color:#667eea;outline:none}.add-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#48bb78 0%,#38a169 100%);border:none;border-radius:6px;padding:10px 25px;font-weight:500;transition:transform .2s,box-shadow .2s}.add-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(72,187,120,.4)}.problems-list{flex-direction:column;gap:12px;max-height:600px;padding-right:8px;display:flex;overflow-y:auto}.problems-list::-webkit-scrollbar{width:6px}.problems-list::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.problems-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.problems-list::-webkit-scrollbar-thumb:hover{background:#94a3b8}.empty-message{text-align:center;color:#a0aec0;padding:40px;font-size:16px}.problem-item{background:#f7fafc;border-radius:8px;align-items:center;gap:15px;padding:15px;transition:background .2s;display:flex}.problem-item:hover{background:#edf2f7}.problem-checkbox{cursor:pointer;accent-color:#667eea;width:20px;height:20px}.problem-content{flex-direction:column;flex:1;gap:5px;display:flex}.problem-link{color:#667eea;font-size:16px;font-weight:500;text-decoration:none;transition:color .2s}.problem-link:hover{color:#764ba2;text-decoration:underline}.completion-date{color:#48bb78;font-size:12px;font-weight:500}.topic-tab-structured{animation:.3s fadeIn}.topic-actions{align-items:center;gap:15px;display:flex}.toggle-form-btn{color:#fff;cursor:pointer;background:#4f46e5;border:none;border-radius:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:background-color .2s}.toggle-form-btn:hover{background:#4338ca}.chapter-view{margin-bottom:40px}.chapter-title{color:#1e293b;border-bottom:2px solid #e2e8f0;margin-bottom:20px;padding-bottom:8px;font-size:22px;font-weight:600}.subsection{margin-bottom:30px}.subsection-title{color:#475569;border-left:4px solid #667eea;margin-bottom:15px;padding-left:10px;font-size:18px;font-weight:500}.problems-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:15px;max-height:600px;padding-right:8px;display:grid;overflow-y:auto}.problems-grid::-webkit-scrollbar{width:6px}.problems-grid::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.problems-grid::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.problems-grid::-webkit-scrollbar-thumb:hover{background:#94a3b8}.problem-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:15px;transition:all .2s}.problem-card:hover{background:#f1f5f9;border-color:#cbd5e0;transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.1)}.problem-header{align-items:center;gap:8px;margin-bottom:10px;display:flex}.problem-number{color:#667eea;min-width:40px;font-size:14px;font-weight:600}.problem-title-link{color:#1e293b;flex:1;font-size:14px;font-weight:500;line-height:1.4;text-decoration:none}.problem-title-link:hover{color:#667eea;text-decoration:underline}.difficulty-badge{color:#fff;background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%);border-radius:12px;padding:2px 8px;font-size:11px;font-weight:600}.problem-actions{flex-direction:column;gap:8px;display:flex}.checkbox-label{cursor:pointer;color:#64748b;align-items:center;gap:8px;font-size:13px;display:flex}.problem-checkbox{margin:0}.completion-info{color:#059669;background:#ecfdf5;border:1px solid #a7f3d0;border-radius:4px;padding:4px 8px;font-size:11px}.add-problem-form-container{box-sizing:border-box;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;width:100%;margin-bottom:30px;padding:20px;overflow-x:hidden}.form-mode-selector{gap:8px;margin-bottom:20px;display:flex}.mode-btn{color:#64748b;cursor:pointer;background:#fff;border:2px solid #e2e8f0;border-radius:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .2s}.mode-btn:hover{background:#f1f5f9;border-color:#cbd5e0}.mode-btn.active{color:#fff;background:#667eea;border-color:#667eea}.add-form{flex-direction:column;gap:15px;display:flex}.form-row{gap:10px;display:flex}.select-field{color:#374151;background:#fff;border:2px solid #e2e8f0;border-radius:6px;flex:1;padding:10px 15px;font-size:14px;transition:border-color .2s}.select-field:focus{border-color:#667eea;outline:none}.submit-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#10b981 0%,#059669 100%);border:none;border-radius:6px;align-self:flex-start;padding:12px 24px;font-weight:600;transition:transform .2s,box-shadow .2s}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(16,185,129,.4)}.empty-state{text-align:center;color:#64748b;padding:60px 20px}.empty-state p:first-child{margin-bottom:8px;font-size:18px;font-weight:500}.empty-state p:last-child{font-size:14px}.chapters-container{max-height:700px;margin-top:20px;padding-right:8px;overflow-y:auto}.chapters-container::-webkit-scrollbar{width:6px}.chapters-container::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.chapters-container::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.chapters-container::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media (max-width:768px){.App{padding:10px}.tab{flex:auto;min-width:140px}.topic-header{flex-direction:column;align-items:stretch;gap:15px}.topic-link{text-align:center}.add-problem-form{flex-direction:column}.main-content{box-sizing:border-box;width:100%;max-height:calc(100vh - 150px);padding:20px;overflow-y:auto}.problems-grid{grid-template-columns:1fr;max-height:500px}.problems-list{max-height:450px;overflow-y:auto}.chapters-container{max-height:500px;overflow-y:auto}.topics-grid{grid-template-columns:1fr;max-height:400px}.topic-stats{max-height:300px;overflow-y:auto}.form-row{flex-direction:column}.topic-actions{flex-direction:column;gap:10px}.form-mode-selector{flex-wrap:wrap}.dashboard,.analytics{padding:20px}.problem-item{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:12px;padding:16px}.problem-content{width:100%}.problem-link{word-wrap:break-word;font-size:15px;line-height:1.4}.completion-date{margin-top:8px;font-size:11px}.problem-card{padding:12px}.problem-header{flex-direction:column;align-items:flex-start;gap:6px}.problem-title-link{font-size:13px;line-height:1.3}.problem-actions{margin-top:8px}.chapter-view{margin-bottom:24px}.chapter-title{font-size:20px}.subsection-title{margin-bottom:12px;font-size:16px}}.dashboard{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-sizing:border-box;background:#fff;border-radius:16px;width:100%;padding:32px;box-shadow:0 8px 32px rgba(0,0,0,.08)}.dashboard-header{margin-bottom:32px}.dashboard-header h2{color:#1a1a2e;-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);-webkit-background-clip:text;background-clip:text;margin-bottom:24px;font-size:32px;font-weight:700;display:inline-block}.dashboard-summary{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:40px;display:grid}.summary-card{text-align:center;background:linear-gradient(135deg,#f8fafc 0%,#fff 100%);border:1px solid rgba(255,255,255,.8);border-radius:16px;padding:28px;transition:all .3s;position:relative;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.05)}.summary-card:before{content:"";background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);height:4px;position:absolute;top:0;left:0;right:0}.summary-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.1)}.summary-card h3{color:#64748b;text-transform:uppercase;letter-spacing:1px;margin-bottom:16px;font-size:16px;font-weight:600}.progress-circle{background:conic-gradient(from 0deg,#667eea 0%,#764ba2 var(--percentage,0%),#f1f5f9 var(--percentage,0%));border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;margin:16px auto;display:flex;position:relative;box-shadow:0 8px 24px rgba(102,126,234,.2)}.progress-circle:after{content:"";background:#fff;border-radius:50%;width:70px;height:70px;position:absolute}.percentage{z-index:1;color:#1a1a2e;font-size:20px;font-weight:700;position:relative}.stat-number{margin:16px 0;font-size:48px;font-weight:800;line-height:1}.stat-number.completed{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#10b981 0%,#059669 100%);-webkit-background-clip:text;background-clip:text}.stat-number.in-progress{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%);-webkit-background-clip:text;background-clip:text}.stat-number.total{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);-webkit-background-clip:text;background-clip:text}.dashboard-content{grid-template-columns:2fr 1fr;gap:40px;display:grid}.topics-overview h3,.recent-activity h3{color:#1a1a2e;margin-bottom:20px;font-size:24px;font-weight:700}.topics-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px;max-height:500px;padding-right:8px;display:grid;overflow-y:auto}.topics-grid::-webkit-scrollbar{width:6px}.topics-grid::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.topics-grid::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.topics-grid::-webkit-scrollbar-thumb:hover{background:#94a3b8}.topic-card{background:linear-gradient(135deg,#fff 0%,#f8fafc 100%);border:1px solid rgba(226,232,240,.6);border-radius:12px;padding:20px;transition:all .3s;position:relative;overflow:hidden}.topic-card:before{content:"";opacity:0;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);height:3px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.topic-card:hover{border-color:rgba(102,126,234,.3);transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,.12)}.topic-card:hover:before{opacity:1}.topic-header{align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.topic-number{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;margin-right:0;font-size:14px;font-weight:700;display:flex;box-shadow:0 4px 12px rgba(102,126,234,.3)}.topic-header h4{color:#1e293b;flex:1;margin:0;font-size:16px;font-weight:600;line-height:1.4}.topic-progress{margin-top:16px}.progress-bar{background:#f1f5f9;border-radius:8px;height:12px;margin-bottom:12px;overflow:hidden;box-shadow:inset 0 2px 4px rgba(0,0,0,.1)}.progress-fill{background:linear-gradient(135deg,#10b981 0%,#059669 100%);border-radius:8px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1);position:relative;box-shadow:0 2px 8px rgba(16,185,129,.3)}.progress-fill:after{content:"";background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);animation:2s infinite shimmer;position:absolute;top:0;bottom:0;left:0;right:0}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-text{color:#64748b;text-align:right;font-size:14px;font-weight:600}.recent-list{max-height:500px;padding-right:8px;overflow-y:auto}.recent-list::-webkit-scrollbar{width:6px}.recent-list::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.recent-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.recent-list::-webkit-scrollbar-thumb:hover{background:#94a3b8}.recent-item{border-bottom:1px solid rgba(226,232,240,.6);justify-content:space-between;align-items:center;padding:16px 0;transition:all .2s;display:flex}.recent-item:hover{border-color:rgba(102,126,234,.3);padding-left:8px}.recent-item:last-child{border-bottom:none}.problem-info{flex:1;align-items:center;gap:12px;display:flex}.problem-number{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:6px;padding:4px 8px;font-size:12px;font-weight:700}.problem-title{color:#1e293b;flex:1;font-size:14px;font-weight:500}.topic-badge{color:#4338ca;background:linear-gradient(135deg,#e0e7ff 0%,#c7d2fe 100%);border:1px solid rgba(67,56,202,.2);border-radius:12px;padding:4px 12px;font-size:11px;font-weight:600}.completion-date{color:#64748b;white-space:nowrap;font-size:12px;font-weight:500}.no-activity{color:#94a3b8;text-align:center;background:linear-gradient(135deg,#f8fafc 0%,#f1f5f9 100%);border:2px dashed #cbd5e1;border-radius:12px;padding:40px 20px;font-size:16px;font-style:italic}@media (max-width:1024px){.dashboard-content{grid-template-columns:1fr;gap:32px}.topics-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.dashboard-summary{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}}@media (max-width:768px){.dashboard{padding:20px}.dashboard-header h2{font-size:24px}.topics-grid{grid-template-columns:1fr}.dashboard-summary{grid-template-columns:1fr;gap:16px}.summary-card{padding:20px}.stat-number{font-size:36px}.progress-circle{width:80px;height:80px}.progress-circle:after{width:56px;height:56px}.percentage{font-size:16px}}.analytics{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-sizing:border-box;background:#fff;border-radius:16px;width:100%;padding:32px;box-shadow:0 8px 32px rgba(0,0,0,.08)}.analytics-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.analytics-header h2{color:#1a1a2e;-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);-webkit-background-clip:text;background-clip:text;font-size:32px;font-weight:700;display:inline-block}.time-range-selector{gap:8px;display:flex}.time-range-selector button{cursor:pointer;color:#64748b;background:#f8fafc;border:2px solid #e2e8f0;border-radius:8px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .2s}.time-range-selector button:hover{background:#f1f5f9;border-color:#cbd5e1}.time-range-selector button.active{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-color:#667eea;box-shadow:0 4px 12px rgba(102,126,234,.3)}.analytics-summary{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:32px;display:grid}.completion-chart{margin-bottom:32px}.completion-chart h3{color:#1a1a2e;margin-bottom:16px;font-size:24px;font-weight:700}.chart{background:linear-gradient(135deg,#f8fafc 0%,#fff 100%);border:1px solid #e2e8f0;border-radius:12px;height:320px;padding:24px;box-shadow:0 4px 20px rgba(0,0,0,.05)}.chart-bars{justify-content:space-between;align-items:flex-end;gap:4px;height:260px;padding:0 8px;display:flex}.chart-bar-container{flex-direction:column;flex:1;align-items:center;max-width:40px;height:100%;display:flex;position:relative}.chart-bar{background:linear-gradient(#764ba2,#667eea);border-radius:4px 4px 0 0;justify-content:center;align-items:flex-start;width:100%;transition:all .3s;display:flex;position:relative;box-shadow:0 2px 8px rgba(102,126,234,.3)}.chart-bar:hover{opacity:.8;transform:scaleY(1.05)}.bar-value{color:#374151;text-align:center;background:#fff;border-radius:4px;min-width:20px;padding:2px 6px;font-size:11px;font-weight:600;position:absolute;top:-24px;box-shadow:0 2px 4px rgba(0,0,0,.1)}.bar-label{color:#6b7280;text-align:center;transform-origin:50%;white-space:nowrap;min-width:60px;margin-top:12px;font-size:11px;font-weight:500;transform:rotate(-45deg)}.topic-breakdown{margin-bottom:32px}.topic-breakdown h3{color:#1a1a2e;margin-bottom:16px;font-size:24px;font-weight:700}.topic-stats{flex-direction:column;gap:12px;max-height:400px;padding-right:8px;display:flex;overflow-y:auto}.topic-stats::-webkit-scrollbar{width:6px}.topic-stats::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.topic-stats::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.topic-stats::-webkit-scrollbar-thumb:hover{background:#94a3b8}.topic-stat-row{background:linear-gradient(135deg,#f8fafc 0%,#fff 100%);border:1px solid #e2e8f0;border-radius:12px;justify-content:space-between;align-items:center;padding:16px;transition:all .2s;display:flex}.topic-stat-row:hover{border-color:rgba(102,126,234,.3);transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.08)}.topic-info{flex:1;align-items:center;gap:12px;display:flex}.topic-rank{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:700;display:flex;box-shadow:0 4px 12px rgba(102,126,234,.3)}.topic-name{color:#1e293b;flex:1;font-size:15px;font-weight:500}.topic-progress{align-items:center;gap:12px;min-width:200px;display:flex}.stat-count{color:#64748b;text-align:right;min-width:80px;font-size:14px;font-weight:600}.recent-completions h3{color:#1a1a2e;margin-bottom:16px;font-size:24px;font-weight:700}.completions-timeline{max-height:400px;padding-right:8px;overflow-y:auto}.completions-timeline::-webkit-scrollbar{width:6px}.completions-timeline::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.completions-timeline::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.completions-timeline::-webkit-scrollbar-thumb:hover{background:#94a3b8}.timeline-item{border-bottom:1px solid rgba(226,232,240,.6);gap:16px;padding:12px 0;transition:all .2s;display:flex}.timeline-item:hover{border-color:rgba(102,126,234,.3);padding-left:8px}.timeline-item:last-child{border-bottom:none}.timeline-date{color:#64748b;text-align:right;min-width:80px;font-size:12px;font-weight:500}.timeline-content{flex:1;align-items:center;gap:8px;display:flex}@media (max-width:1024px){.analytics-header{flex-direction:column;align-items:flex-start;gap:16px}.time-range-selector{justify-content:space-between;width:100%}.chart-bars{gap:2px}.bar-label{font-size:9px}}@media (max-width:768px){.analytics{padding:20px}.analytics-header h2{font-size:24px}.chart{height:260px;padding:16px}.chart-bars{height:200px}.bar-label{font-size:8px}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-ease{syntax:"*";inherits:false}
*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.app-layout{flex-direction:column;height:100vh;margin:0;padding:0;display:flex}.app-header{background:#fff;border-bottom:1px solid #e2e8f0;border-radius:0;flex-shrink:0;margin:0;padding:20px}.app-header h1{color:#333;text-align:left;font-size:28px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.app-container{flex:1;align-items:flex-start;gap:0;margin:0;display:flex;overflow:hidden}.sidebar{background:#f8fafc;border:1px solid #e2e8f0;border-top:none;border-left:none;border-radius:0;flex-shrink:0;width:280px;max-height:calc(100vh - 80px);margin:0;padding:0;transition:all .3s;position:relative;overflow-y:auto;box-shadow:0 4px 6px rgba(0,0,0,.05)}.sidebar.collapsed{width:60px}.sidebar.collapsed .sidebar-label,.sidebar.collapsed .sidebar-progress,.sidebar.collapsed .sidebar-section-title,.sidebar.collapsed .sidebar-content{display:none}.sidebar-toggle{cursor:pointer;z-index:10;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:rgba(255,255,255,.9);border:1px solid #e2e8f0;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex;position:absolute;top:15px;left:15px;box-shadow:0 2px 8px rgba(0,0,0,.15)}.sidebar-toggle:hover{background:#fff;transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.2)}.sidebar-toggle-icon{color:#374151;font-size:16px;font-weight:700;transition:transform .3s}.sidebar.collapsed .sidebar-toggle-icon{transform:rotate(180deg)}.mobile-tab-bar{display:none}.sidebar-section{border-bottom:1px solid #e2e8f0}.sidebar-section:last-child{border-bottom:none}.sidebar-section-title{color:#374151;text-transform:uppercase;letter-spacing:.5px;background:#f8fafc;margin:0;padding:20px 20px 12px 70px;font-size:12px;font-weight:600}.sidebar.collapsed .sidebar-section-title{padding:20px 20px 12px}.sidebar-section:first-child .sidebar-section-title{border-radius:12px 12px 0 0}.sidebar-menu{flex-direction:column;padding:0 0 20px;display:flex}.sidebar-item{cursor:pointer;text-align:left;color:#6b7280;background:0 0;border:none;border-left:3px solid transparent;align-items:center;gap:12px;width:100%;padding:12px 20px;font-size:14px;transition:all .2s;display:flex}.sidebar-item:hover{color:#374151;background:#f1f5f9;border-left-color:#cbd5e0}.sidebar-item.active{color:#0369a1;background:#f0f9ff;border-left-color:#0369a1;font-weight:500}.sidebar-icon{text-align:center;width:20px;font-size:16px}.sidebar-number{color:#6b7280;background:#e2e8f0;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;font-weight:600;display:flex}.sidebar-item.active .sidebar-number{color:#fff;background:#0369a1}.sidebar-content{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.sidebar-label{text-overflow:ellipsis;white-space:nowrap;line-height:1.2;overflow:hidden}.sidebar-progress{color:#6b7280;background:#e5e7eb;border-radius:10px;padding:2px 6px;font-size:11px;font-weight:500}.sidebar-item.active .sidebar-progress{color:#0369a1;background:#bfdbfe}.main-content{background:#fff;border-radius:0;flex:1;max-height:calc(100vh - 80px);padding:30px;overflow-y:auto;box-shadow:0 4px 6px rgba(0,0,0,.1)}.topic-tab{animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.topic-header{border-bottom:2px solid #e2e8f0;justify-content:space-between;align-items:center;margin-bottom:25px;padding-bottom:15px;display:flex}.topic-header h2{color:#333;flex:1;font-size:24px}.topic-link{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:8px;padding:10px 20px;font-weight:500;text-decoration:none;transition:transform .2s,box-shadow .2s}.topic-link:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(102,126,234,.4)}.progress-bar-container{margin-bottom:25px}.progress-info{justify-content:space-between;margin-bottom:8px;display:flex}.progress-info span{color:#666;font-size:14px;font-weight:500}.progress-bar{background:#e2e8f0;border-radius:10px;height:20px;overflow:hidden}.progress-fill{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:flex-end;align-items:center;height:100%;padding-right:8px;transition:width .3s;display:flex}.add-problem-form{background:#f7fafc;border-radius:8px;gap:10px;margin-bottom:25px;padding:20px;display:flex}.input-field{border:2px solid #e2e8f0;border-radius:6px;flex:1;padding:10px 15px;font-size:14px;transition:border-color .2s}.input-field:focus{border-color:#667eea;outline:none}.add-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#48bb78 0%,#38a169 100%);border:none;border-radius:6px;padding:10px 25px;font-weight:500;transition:transform .2s,box-shadow .2s}.add-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(72,187,120,.4)}.problems-list{flex-direction:column;gap:12px;display:flex}.empty-message{text-align:center;color:#a0aec0;padding:40px;font-size:16px}.problem-item{background:#f7fafc;border-radius:8px;align-items:center;gap:15px;padding:15px;transition:background .2s;display:flex}.problem-item:hover{background:#edf2f7}.problem-checkbox{cursor:pointer;accent-color:#667eea;width:20px;height:20px}.problem-content{flex-direction:column;flex:1;gap:5px;display:flex}.problem-link{color:#667eea;font-size:16px;font-weight:500;text-decoration:none;transition:color .2s}.problem-link:hover{color:#764ba2;text-decoration:underline}.premium-indicator{color:#f59e0b;opacity:.8;margin-left:8px;font-size:14px}.completion-date{color:#48bb78;font-size:12px;font-weight:500}.topic-tab-structured{animation:.3s fadeIn}.topic-actions{align-items:center;gap:15px;display:flex}.toggle-form-btn{color:#fff;cursor:pointer;background:#4f46e5;border:none;border-radius:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:background-color .2s}.toggle-form-btn:hover{background:#4338ca}.chapter-view{margin-bottom:40px}.chapter-title{color:#1e293b;border-bottom:2px solid #e2e8f0;margin-bottom:20px;padding-bottom:8px;font-size:22px;font-weight:600}.subsection{margin-bottom:30px}.subsection-title{color:#475569;border-left:4px solid #667eea;margin-bottom:15px;padding-left:10px;font-size:18px;font-weight:500}.problems-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:15px;display:grid}.problem-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:15px;transition:all .2s}.problem-card:hover{background:#f1f5f9;border-color:#cbd5e0;transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.1)}.problem-header{align-items:center;gap:8px;margin-bottom:10px;display:flex}.problem-number{color:#667eea;min-width:40px;font-size:14px;font-weight:600}.problem-title-link{color:#1e293b;flex:1;font-size:14px;font-weight:500;line-height:1.4;text-decoration:none}.problem-title-link:hover{color:#667eea;text-decoration:underline}.difficulty-badge{color:#fff;background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%);border-radius:12px;padding:2px 8px;font-size:11px;font-weight:600}.problem-actions{flex-direction:column;gap:8px;display:flex}.checkbox-label{cursor:pointer;color:#64748b;align-items:center;gap:8px;font-size:13px;display:flex}.problem-checkbox{margin:0}.completion-info{color:#059669;background:#ecfdf5;border:1px solid #a7f3d0;border-radius:4px;padding:4px 8px;font-size:11px}.add-problem-form-container{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;margin-bottom:30px;padding:20px}.form-mode-selector{gap:8px;margin-bottom:20px;display:flex}.mode-btn{color:#64748b;cursor:pointer;background:#fff;border:2px solid #e2e8f0;border-radius:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .2s}.mode-btn:hover{background:#f1f5f9;border-color:#cbd5e0}.mode-btn.active{color:#fff;background:#667eea;border-color:#667eea}.add-form{flex-direction:column;gap:15px;display:flex}.form-row{gap:10px;display:flex}.select-field{color:#374151;background:#fff;border:2px solid #e2e8f0;border-radius:6px;flex:1;padding:10px 15px;font-size:14px;transition:border-color .2s}.select-field:focus{border-color:#667eea;outline:none}.submit-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#10b981 0%,#059669 100%);border:none;border-radius:6px;align-self:flex-start;padding:12px 24px;font-weight:600;transition:transform .2s,box-shadow .2s}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(16,185,129,.4)}.empty-state{text-align:center;color:#64748b;padding:60px 20px}.empty-state p:first-child{margin-bottom:8px;font-size:18px;font-weight:500}.empty-state p:last-child{font-size:14px}.chapters-container{margin-top:20px}@media (max-width:768px){.app-layout{height:100vh;padding:0;overflow:hidden}.app-header{margin:0;padding:15px}.app-header h1{font-size:20px}.app-container{flex-direction:column;gap:0;height:calc(100vh - 70px);margin:0}.sidebar{background:#f8fafc;border:none;border-bottom:1px solid #e2e8f0;border-radius:0;order:-1;width:100%;max-height:300px;transition:max-height .4s ease-in-out,padding .3s ease-in-out;position:static;overflow-y:auto}.sidebar.collapsed{max-height:50px;padding:0;transition:max-height .4s ease-in-out,padding .3s ease-in-out}.sidebar.collapsed .sidebar-section{display:none}.sidebar.collapsed:after{content:"";width:100%;height:50px;display:block;position:relative}.sidebar.collapsed{width:100%!important}.mobile-tab-bar{display:none}.sidebar.collapsed .mobile-tab-bar{align-items:center;gap:5px;width:100%;height:50px;padding:5px;overflow-x:auto;display:flex!important}.mobile-tab{cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #e2e8f0;border-radius:6px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;min-width:45px;height:40px;padding:4px;font-size:11px;transition:all .2s;display:flex}.mobile-tab:hover{background:#f1f5f9;border-color:#cbd5e1}.mobile-tab.active{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-color:#667eea}.mobile-tab-number{font-size:12px;font-weight:700}.mobile-tab-progress{opacity:.8;margin-top:1px;font-size:9px}.mobile-tab.active .mobile-tab-progress{opacity:1}.sidebar-toggle{z-index:20;background:rgba(255,255,255,.95);border:1px solid #e2e8f0;border-radius:6px;justify-content:center;align-items:center;width:30px;height:30px;display:flex;position:absolute;top:8px;left:auto;right:15px;box-shadow:0 2px 4px rgba(0,0,0,.1)}.sidebar-toggle:hover{background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.15)}.sidebar-toggle-icon{color:#374151;font-size:0;transition:transform .3s;position:relative}.sidebar-toggle-icon:before{content:"▲";color:#374151;font-size:14px;transition:all .3s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.sidebar.collapsed .sidebar-toggle-icon:before{content:"▼"}.sidebar.collapsed .sidebar-toggle-icon{transform:rotate(0)}.sidebar.collapsed .sidebar-toggle{background:rgba(102,126,234,.9);border-color:#667eea;top:8px;right:15px}.sidebar.collapsed .sidebar-toggle-icon{color:#fff}.sidebar-section{margin-bottom:0}.sidebar-section:first-child{padding-top:45px}.sidebar-section:first-child .sidebar-section-title{margin-top:0;padding-top:5px}.sidebar-menu{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:6px;padding:10px;display:grid}.sidebar-item{border-radius:6px;padding:8px;font-size:12px}.sidebar-content{gap:2px}.sidebar-label{font-size:11px}.sidebar-progress{padding:1px 4px;font-size:10px}.topic-header{flex-direction:column;align-items:stretch;gap:15px}.topic-link{text-align:center;padding:12px 16px;font-size:14px}.add-problem-form{flex-direction:column;margin-bottom:20px;padding:15px}.main-content{border-radius:0;flex:1;max-height:calc(100vh - 250px);padding:15px 15px 0;transition:max-height .3s;overflow-y:auto}.main-content.sidebar-collapsed{max-height:calc(100vh - 115px)}.problems-grid{grid-template-columns:1fr;gap:10px}.problems-list{gap:8px}.form-row{flex-direction:column}.topic-actions{flex-direction:column;gap:10px}.form-mode-selector{flex-wrap:wrap;gap:6px}.mode-btn{flex:1;min-width:80px;padding:6px 12px;font-size:12px}.problem-item{border-radius:6px;padding:12px}.problem-checkbox{width:18px;height:18px}.problem-content{flex:1}.problem-link{word-break:break-word;font-size:14px;line-height:1.3}.completion-date{margin-top:4px;font-size:10px}.chapter-view{margin-bottom:20px}.chapter-title{margin-bottom:15px;font-size:18px}.subsection-title{margin-bottom:10px;padding-left:8px;font-size:15px}.problem-card{border-radius:6px;padding:10px}.problem-number{min-width:35px;font-size:12px}.problem-title-link{font-size:12px;line-height:1.2}.difficulty-badge{padding:1px 6px;font-size:10px}.checkbox-label{font-size:11px}.completion-info{padding:2px 6px;font-size:10px}}.dashboard{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 6px rgba(0,0,0,.1)}.dashboard-header h2{color:#333;margin-bottom:24px;font-size:24px}.dashboard-summary{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:32px;display:grid}.summary-card{text-align:center;background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%);border-radius:12px;padding:20px;box-shadow:0 2px 4px rgba(0,0,0,.1)}.summary-card h3{color:#555;margin-bottom:12px;font-size:16px}.progress-circle{background:conic-gradient(from 0deg,#4f46e5 var(--percentage,0%),#e5e7eb var(--percentage,0%));border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:12px auto;display:flex;position:relative}.progress-circle:after{content:"";background:#fff;border-radius:50%;width:60px;height:60px;position:absolute}.percentage{z-index:1;color:#333;font-size:18px;font-weight:700;position:relative}.stat-number{margin:12px 0;font-size:32px;font-weight:700}.stat-number.completed{color:#10b981}.stat-number.in-progress{color:#f59e0b}.stat-number.total{color:#6366f1}.dashboard-content{grid-template-columns:2fr 1fr;gap:32px;display:grid}.topics-overview h3,.recent-activity h3{color:#333;margin-bottom:16px;font-size:20px}.topics-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;display:grid}.topic-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:16px;transition:transform .2s}.topic-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.1)}.topic-header{align-items:center;margin-bottom:12px;display:flex}.topic-number{color:#fff;background:#4f46e5;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;margin-right:12px;font-size:12px;font-weight:700;display:flex}.topic-header h4{color:#374151;font-size:14px;line-height:1.4}.progress-bar{background:#e5e7eb;border-radius:4px;height:8px;margin-bottom:8px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#10b981,#059669);height:100%;transition:width .3s}.progress-text{color:#6b7280;text-align:right;font-size:12px}.recent-list{max-height:400px;overflow-y:auto}.recent-item{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:12px 0;display:flex}.recent-item:last-child{border-bottom:none}.problem-info{flex:1;align-items:center;gap:8px;display:flex}.problem-number{color:#fff;background:#4f46e5;border-radius:4px;padding:2px 6px;font-size:12px;font-weight:700}.problem-title{color:#374151;flex:1;font-size:14px}.topic-badge{color:#3730a3;background:#e0e7ff;border-radius:4px;padding:2px 6px;font-size:11px}.completion-date{color:#6b7280;white-space:nowrap;font-size:12px}.no-activity{color:#9ca3af;text-align:center;padding:24px;font-style:italic}.analytics{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 6px rgba(0,0,0,.1)}.analytics-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.analytics-header h2{color:#333;font-size:24px}.time-range-selector{gap:8px;display:flex}.time-range-selector button{cursor:pointer;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;padding:8px 16px;font-size:14px;transition:all .2s}.time-range-selector button:hover{background:#e5e7eb}.time-range-selector button.active{color:#fff;background:#4f46e5;border-color:#4f46e5}.analytics-summary{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:32px;display:grid}.completion-chart{margin-bottom:32px}.completion-chart h3{color:#333;margin-bottom:16px;font-size:20px}.chart{background:#f8fafc;border-radius:8px;height:300px;padding:20px}.chart-bars{justify-content:space-between;align-items:flex-end;gap:4px;height:240px;display:flex}.chart-bar-container{flex-direction:column;flex:1;align-items:center;height:100%;display:flex}.chart-bar{background:linear-gradient(#7c3aed,#4f46e5);border-radius:2px 2px 0 0;justify-content:center;align-items:flex-start;width:100%;max-width:30px;transition:all .3s;display:flex;position:relative}.chart-bar:hover{opacity:.8}.bar-value{color:#374151;font-size:10px;font-weight:700;position:absolute;top:-20px}.bar-label{color:#6b7280;text-align:center;transform-origin:50%;margin-top:8px;font-size:10px;transform:rotate(-45deg)}.topic-breakdown{margin-bottom:32px}.topic-breakdown h3{color:#333;margin-bottom:16px;font-size:20px}.topic-stats{flex-direction:column;gap:12px;display:flex}.topic-stat-row{background:#f8fafc;border-radius:8px;justify-content:space-between;align-items:center;padding:12px;display:flex}.topic-info{flex:1;align-items:center;gap:12px;display:flex}.topic-rank{color:#fff;background:#6b7280;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;font-weight:700;display:flex}.topic-name{color:#374151;font-size:14px;font-weight:500}.topic-progress{align-items:center;gap:12px;min-width:200px;display:flex}.stat-count{color:#6b7280;text-align:right;min-width:80px;font-size:14px;font-weight:500}.recent-completions h3{color:#333;margin-bottom:16px;font-size:20px}.completions-timeline{max-height:400px;overflow-y:auto}.timeline-item{border-bottom:1px solid #e5e7eb;gap:16px;padding:12px 0;display:flex}.timeline-item:last-child{border-bottom:none}.timeline-date{color:#6b7280;text-align:right;min-width:80px;font-size:12px}.timeline-content{flex:1;align-items:center;gap:8px;display:flex}@media (max-width:768px){.dashboard-content,.topics-grid{grid-template-columns:1fr}.analytics-header{flex-direction:column;align-items:flex-start;gap:16px}.time-range-selector{justify-content:space-between;width:100%}.chart-bars{gap:2px}.bar-label{font-size:8px}}
