@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--spacing:.25rem;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--shadow-sm:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.absolute{position:absolute}.relative{position:relative}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.block{display:block}.flex{display:flex}.grid{display:grid}.inline{display:inline}.inline-flex{display:inline-flex}.table{display:table}.w-full{width:100%}.flex-1{flex:1}.shrink{flex-shrink:1}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.border{border-style:var(--tw-border-style);border-width:1px}.text-center{text-align:center}.lowercase{text-transform:lowercase}.uppercase{text-transform:uppercase}.invert{--tw-invert:invert(100%);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--bg-primary:#f5f5f7;--bg-secondary:#fff;--bg-tertiary:#f0f1f5;--bg-card:#fffc;--bg-card-hover:#fffffff2;--bg-modal:#0006;--bg-input:#f0f1f5;--bg-nav:#ffffffb8;--text-primary:#1a1a2e;--text-secondary:#64748b;--text-tertiary:#94a3b8;--text-inverse:#fff;--border-color:#0000000f;--border-light:#00000008;--accent:#6366f1;--accent-light:#818cf8;--accent-dark:#4f46e5;--accent-bg:#6366f114;--accent-bg-hover:#6366f126;--accent-muted:#6366f10f;--accent-glow:#6366f140;--easy:#10b981;--easy-bg:#10b98114;--easy-border:#10b98133;--medium:#f59e0b;--medium-bg:#f59e0b14;--medium-border:#f59e0b33;--hard:#ef4444;--hard-bg:#ef444414;--hard-border:#ef444433;--status-not-started:#94a3b8;--status-in-progress:#3b82f6;--status-solved:#10b981;--status-revision:#f59e0b;--status-mastered:#8b5cf6;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--info:#3b82f6;--space-xs:4px;--space-sm:8px;--space-md:12px;--space-lg:16px;--space-xl:24px;--space-2xl:32px;--space-3xl:48px;--font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-xs:11px;--font-sm:13px;--font-base:15px;--font-lg:17px;--font-xl:20px;--font-2xl:24px;--font-3xl:30px;--font-4xl:36px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:100px;--shadow-sm:0 1px 2px #0000000a;--shadow-md:0 4px 16px #0000000f;--shadow-lg:0 8px 32px #00000014;--shadow-xl:0 20px 60px #0000001f;--shadow-glow:0 0 24px var(--accent-glow);--nav-height:64px;--safe-bottom:env(safe-area-inset-bottom,0px);--transition-fast:.15s cubic-bezier(.4,0,.2,1);--transition-base:.25s cubic-bezier(.4,0,.2,1);--transition-slow:.4s cubic-bezier(.4,0,.2,1);--transition-spring:.5s cubic-bezier(.175,.885,.32,1.275);--heatmap-0:#ebedf0;--heatmap-1:#9be9a8;--heatmap-2:#40c463;--heatmap-3:#30a14e;--heatmap-4:#216e39}[data-theme=dark]{--bg-primary:#0a0a0f;--bg-secondary:#12121a;--bg-tertiary:#1a1a28;--bg-card:#161623b3;--bg-card-hover:#1e1e2dd9;--bg-input:#1a1a28;--bg-nav:#0a0a0fcc;--text-primary:#f0f0f5;--text-secondary:#8b8fa3;--text-tertiary:#5a5e73;--text-inverse:#1a1a2e;--border-color:#ffffff0f;--border-light:#ffffff08;--accent-bg:#6366f11f;--accent-bg-hover:#6366f133;--accent-glow:#6366f14d;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 16px #00000059;--shadow-lg:0 8px 32px #0006;--shadow-xl:0 20px 60px #00000080;--shadow-glow:0 0 32px var(--accent-glow);--heatmap-0:#161625;--heatmap-1:#0e4429;--heatmap-2:#006d32;--heatmap-3:#26a641;--heatmap-4:#39d353}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;scroll-behavior:smooth}body{font-family:var(--font-family);font-size:var(--font-base);color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh;line-height:1.5;overflow-x:hidden}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit;font-size:inherit;color:inherit;-webkit-tap-highlight-color:transparent;background:0 0;border:none}button:focus,a:focus,input:focus,textarea:focus,select:focus{outline:none}button:focus-visible,a:focus-visible{outline:2px solid var(--accent);outline-offset:2px}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none;outline:none}img{max-width:100%;display:block}ul,ol{list-style:none}.app-container{max-width:480px;min-height:100dvh;padding-bottom:calc(var(--nav-height) + var(--safe-bottom) + 24px);margin:0 auto;position:relative}.page{padding:var(--space-lg);padding-top:var(--space-xl);animation:.3s pageIn}@keyframes pageIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.page-header{margin-bottom:var(--space-xl)}.page-title{font-size:var(--font-2xl);letter-spacing:-.5px;color:var(--text-primary);font-weight:800}.page-subtitle{font-size:var(--font-sm);color:var(--text-secondary);margin-top:var(--space-xs)}.bottom-nav{bottom:calc(8px + var(--safe-bottom));width:calc(100% - 24px);max-width:440px;height:var(--nav-height);background:var(--bg-nav);-webkit-backdrop-filter:blur(24px)saturate(180%);border:1px solid var(--border-color);border-radius:var(--radius-xl);z-index:100;box-shadow:var(--shadow-lg);justify-content:space-around;align-items:center;display:flex;position:fixed;left:50%;transform:translate(-50%)}.nav-item{padding:var(--space-sm)var(--space-md);border-radius:var(--radius-md);transition:all var(--transition-fast);flex-direction:column;align-items:center;gap:3px;min-width:56px;display:flex;position:relative}.nav-item:active{transform:scale(.92)}.nav-item .nav-icon{width:24px;height:24px;color:var(--text-tertiary);transition:all var(--transition-fast)}.nav-item .nav-label{color:var(--text-tertiary);transition:all var(--transition-fast);font-size:10px;font-weight:500}.nav-item.active .nav-icon{color:var(--accent)}.nav-item.active .nav-label{color:var(--accent);font-weight:600}.nav-item.active:before{content:"";background:var(--accent);border-radius:var(--radius-full);width:20px;height:3px;position:absolute;top:2px;left:50%;transform:translate(-50%)}.nav-badge{background:var(--danger);color:#fff;border-radius:var(--radius-full);justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;font-weight:700;display:flex;position:absolute;top:2px;right:6px}.card{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-fast)}@media (hover:hover){.card:hover{background:var(--bg-card-hover);box-shadow:var(--shadow-sm)}}.card[style*="cursor: pointer"]:active,.card[role=button]:active{background:var(--accent-bg);transform:scale(.98)}.card-glass{background:var(--bg-card);-webkit-backdrop-filter:blur(16px)saturate(180%);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg)}.stat-card{background:var(--bg-card);-webkit-backdrop-filter:blur(12px)saturate(180%);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg);gap:var(--space-sm);transition:all var(--transition-base);flex-direction:column;display:flex}@media (hover:hover){.stat-card:hover{background:var(--bg-card-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}}.stat-card:active{transform:scale(.97)}.stat-card .stat-value{font-size:var(--font-2xl);letter-spacing:-.5px;font-weight:800}.stat-card .stat-label{font-size:var(--font-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:500}.stat-card .stat-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:36px;height:36px;display:flex}.badge{border-radius:var(--radius-full);font-size:var(--font-xs);letter-spacing:.2px;align-items:center;padding:3px 10px;font-weight:600;display:inline-flex}.badge-easy{background:var(--easy-bg);color:var(--easy);border:1px solid var(--easy-border)}.badge-medium{background:var(--medium-bg);color:var(--medium);border:1px solid var(--medium-border)}.badge-hard{background:var(--hard-bg);color:var(--hard);border:1px solid var(--hard-border)}.badge-status{border-radius:var(--radius-full);font-size:var(--font-xs);padding:3px 10px;font-weight:600}.btn{justify-content:center;align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);font-weight:600;font-size:var(--font-sm);transition:all var(--transition-base);cursor:pointer;border:1px solid #0000;padding:10px 20px;display:inline-flex}.btn:active{transform:scale(.96)}.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-sm),inset 0 -2px 4px #0000001a,inset 0 2px 4px #fff3}@media (hover:hover){.btn-primary:hover{background:var(--accent-light);box-shadow:var(--shadow-md),0 4px 12px var(--accent-bg),inset 0 -2px 4px #0000001a,inset 0 2px 4px #fff3;transform:translateY(-1px)}}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary)}.btn-ghost{color:var(--text-secondary);background:0 0}@media (hover:hover){.btn-ghost:hover{background:var(--bg-tertiary)}}.btn-danger{background:var(--hard-bg);color:var(--hard)}.btn-sm{font-size:var(--font-xs);padding:6px 12px}.fab{bottom:calc(var(--nav-height) + var(--safe-bottom) + 32px);border-radius:var(--radius-full);background:var(--accent);color:#fff;width:56px;height:56px;box-shadow:var(--shadow-lg),inset 0 -2px 6px #0003,inset 0 2px 6px #ffffff4d;transition:all var(--transition-spring);z-index:90;justify-content:center;align-items:center;display:flex;position:fixed;right:max(16px,50% - 224px)}@media (hover:hover){.fab:hover{box-shadow:var(--shadow-xl),0 0 0 8px var(--accent-bg),inset 0 -2px 6px #0003,inset 0 2px 6px #ffffff4d,var(--shadow-glow);transform:scale(1.08)translateY(-4px)}}.fab:active{transform:scale(.92)}@media (max-width:480px){.fab{right:16px}}.input-group{gap:var(--space-sm);flex-direction:column;display:flex}.input-group label{font-size:var(--font-sm);color:var(--text-secondary);font-weight:600}.input{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;font-size:var(--font-base);color:var(--text-primary);transition:all var(--transition-fast);padding:12px 16px}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}.input::placeholder{color:var(--text-tertiary)}textarea.input{resize:vertical;min-height:100px}select.input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.search-bar{align-items:center;gap:var(--space-sm);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-base);padding:12px 16px;display:flex;box-shadow:inset 0 2px 4px #00000005}.search-bar:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-bg),inset 0 2px 4px #00000005;transform:translateY(-1px)}.search-bar input{font-size:var(--font-base);flex:1}.search-bar .search-icon{color:var(--text-tertiary);flex-shrink:0;width:20px;height:20px}.filter-chips{gap:var(--space-sm);-webkit-overflow-scrolling:touch;padding:var(--space-sm)0;scrollbar-width:none;-ms-overflow-style:none;display:flex;overflow-x:auto}.filter-chips::-webkit-scrollbar{display:none}.chip{border-radius:var(--radius-full);font-size:var(--font-sm);white-space:nowrap;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;box-shadow:var(--shadow-sm);align-items:center;gap:6px;padding:8px 16px;font-weight:600;display:inline-flex}@media (hover:hover){.chip:hover{background:var(--bg-card-hover);border-color:var(--text-tertiary);color:var(--text-primary);transform:translateY(-1px)}}.chip:active{transform:scale(.96)}.chip.active{background:var(--accent);color:#fff;border-color:var(--accent-dark);box-shadow:0 4px 12px var(--accent-bg)}.modal-overlay{background:var(--bg-modal);z-index:200;justify-content:center;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-sheet{background:var(--bg-secondary);border-radius:var(--radius-xl)var(--radius-xl)0 0;width:100%;max-width:480px;max-height:90dvh;padding:var(--space-lg);padding-bottom:calc(var(--space-xl) + var(--safe-bottom));animation:.3s slideUp;overflow-y:auto}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-handle{background:var(--border-color);border-radius:var(--radius-full);width:36px;height:4px;margin:0 auto var(--space-lg)}.modal-title{font-size:var(--font-lg);margin-bottom:var(--space-xl);font-weight:700}.progress-bar{background:var(--bg-tertiary);border-radius:var(--radius-full);width:100%;height:6px;overflow:hidden}.progress-fill{border-radius:var(--radius-full);background:var(--accent);height:100%;transition:width var(--transition-slow)}.progress-ring-container{justify-content:center;align-items:center;display:inline-flex;position:relative}.progress-ring-text{font-size:var(--font-xs);color:var(--text-primary);font-weight:700;position:absolute}.swipe-container{border-radius:var(--radius-lg);position:relative;overflow:hidden}.swipe-action{color:#fff;width:80px;font-size:var(--font-xs);justify-content:center;align-items:center;font-weight:700;display:flex;position:absolute;top:0;bottom:0}.swipe-action-left{background:var(--warning);right:0}.swipe-action-right{background:var(--success);left:0}.swipe-content{background:var(--bg-card);transition:transform var(--transition-fast);z-index:1;position:relative}.problem-card{background:var(--bg-card);-webkit-backdrop-filter:blur(12px)saturate(180%);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg)var(--space-lg)var(--space-lg)max(var(--space-lg),20px);gap:var(--space-sm);transition:all var(--transition-base);cursor:pointer;contain:content;flex-direction:column;display:flex;position:relative;overflow:hidden}@media (hover:hover){.problem-card:hover{background:var(--bg-card-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}}.problem-card:before{content:"";background:var(--border-color);width:4px;transition:background var(--transition-fast);position:absolute;top:0;bottom:0;left:0}.problem-card.easy:before{background:var(--easy);box-shadow:2px 0 8px var(--easy-bg)}.problem-card.medium:before{background:var(--medium);box-shadow:2px 0 8px var(--medium-bg)}.problem-card.hard:before{background:var(--hard);box-shadow:2px 0 8px var(--hard-bg)}.problem-card:active{transform:scale(.98)}.problem-card .problem-title{font-size:var(--font-base);color:var(--text-primary);font-weight:600}.problem-card .problem-meta{align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.problem-card .problem-topic{font-size:var(--font-xs);color:var(--text-secondary)}.topic-card{background:var(--bg-card);-webkit-backdrop-filter:blur(12px)saturate(180%);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg);align-items:center;gap:var(--space-lg);transition:all var(--transition-base);cursor:pointer;display:flex}@media (hover:hover){.topic-card:hover{background:var(--bg-card-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}}.topic-card:active{transform:scale(.98)}.topic-card .topic-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.topic-card .topic-info{flex:1;min-width:0}.topic-card .topic-name{font-size:var(--font-base);font-weight:600}.topic-card .topic-count{font-size:var(--font-xs);color:var(--text-secondary);margin-top:2px}.topic-card .topic-progress{width:100%;margin-top:var(--space-sm)}.heatmap-container{position:relative}.heatmap-summary{gap:var(--space-lg);margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:1px solid var(--border-color);display:flex}.heatmap-stat{flex-direction:column;gap:1px;display:flex}.heatmap-stat-value{font-size:var(--font-lg);color:var(--accent);letter-spacing:-.5px;font-weight:800}.heatmap-stat-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:500}.heatmap-months{margin-bottom:4px;display:flex}.heatmap-day-spacer{flex-shrink:0;width:28px}.heatmap-month-track{flex:1;grid-auto-columns:1fr;display:grid;overflow:hidden}.heatmap-month-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.3px;font-size:10px;font-weight:600}.heatmap-grid-wrapper{-webkit-overflow-scrolling:touch;scrollbar-width:none;display:flex;overflow-x:auto}.heatmap-grid-wrapper::-webkit-scrollbar{display:none}.heatmap-day-labels{flex-direction:column;flex-shrink:0;gap:3px;margin-right:6px;display:flex}.heatmap-day-label{height:13px;color:var(--text-tertiary);align-items:center;width:22px;font-size:9px;font-weight:500;display:flex}.heatmap{gap:3px;padding:0;display:flex}.heatmap-week{flex-direction:column;gap:3px;display:flex}.heatmap-cell{cursor:pointer;border-radius:3px;flex-shrink:0;width:13px;min-width:13px;height:13px;transition:all .12s}.heatmap-cell:hover{z-index:2;transform:scale(1.4)}.heatmap-level--1{pointer-events:none;background:0 0}.heatmap-level-0{background:var(--heatmap-0)}.heatmap-level-1{background:var(--heatmap-1);box-shadow:0 0 0 0 var(--heatmap-1)}.heatmap-level-2{background:var(--heatmap-2);box-shadow:0 0 0 0 var(--heatmap-2)}.heatmap-level-3{background:var(--heatmap-3);box-shadow:0 0 0 0 var(--heatmap-3)}.heatmap-level-4{background:var(--heatmap-4);box-shadow:0 0 4px var(--heatmap-4)}.heatmap-today{outline:2px solid var(--accent);outline-offset:1px;border-radius:3px}.heatmap-legend{margin-top:var(--space-md);padding-top:var(--space-sm);justify-content:flex-end;align-items:center;gap:4px;display:flex}.heatmap-legend-label{color:var(--text-tertiary);margin:0 2px;font-size:10px;font-weight:500}.heatmap-legend-cell{cursor:default;width:11px;min-width:11px;height:11px}.heatmap-legend-cell:hover{transform:none}.heatmap-tooltip{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);z-index:300;pointer-events:none;box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(12px);white-space:nowrap;padding:6px 10px;animation:.1s tooltipIn;position:fixed;transform:translate(-50%,-100%)}@keyframes tooltipIn{0%{opacity:0;transform:translate(-50%,-100%)scale(.9)}to{opacity:1;transform:translate(-50%,-100%)scale(1)}}.heatmap-tooltip-date{color:var(--text-primary);margin-bottom:2px;font-size:11px;font-weight:700}.heatmap-tooltip-detail{color:var(--text-secondary);font-size:10px;font-weight:500}.calendar{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg)}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.calendar-day{aspect-ratio:1;border-radius:var(--radius-md);font-size:var(--font-sm);transition:all var(--transition-fast);justify-content:center;align-items:center;font-weight:500;display:flex;position:relative}.calendar-day.today{border:2px solid var(--accent);font-weight:700}.calendar-day.has-activity{background:var(--accent-bg);color:var(--accent);font-weight:600}.calendar-day.streak{background:var(--accent);color:#fff;font-weight:700}.calendar-day-header{font-size:var(--font-xs);color:var(--text-tertiary);text-transform:uppercase;font-weight:600}.empty-state{padding:var(--space-3xl)var(--space-xl);text-align:center;justify-content:center;align-items:center;gap:var(--space-lg);flex-direction:column;display:flex}.empty-state .empty-icon{width:64px;height:64px;color:var(--text-tertiary);opacity:.5}.empty-state .empty-title{font-size:var(--font-lg);color:var(--text-secondary);font-weight:600}.empty-state .empty-text{font-size:var(--font-sm);color:var(--text-tertiary);max-width:280px}.motivation-banner{background:linear-gradient(135deg,var(--accent)0%,var(--accent-light)50%,var(--accent-dark)100%);color:#fff;border-radius:var(--radius-xl);padding:var(--space-xl)var(--space-2xl);box-shadow:var(--shadow-xl),0 12px 24px var(--accent-bg);transition:all var(--transition-base);position:relative;overflow:hidden}@media (hover:hover){.motivation-banner:hover{box-shadow:var(--shadow-xl),0 16px 32px var(--accent-bg),var(--shadow-glow);transform:translateY(-2px)}}.motivation-banner:before{content:"";z-index:1;background:radial-gradient(at 100% 0,#ffffff4d 0%,#0000 60%),radial-gradient(at 0 100%,#0000001a 0%,#0000 60%);position:absolute;inset:0}.motivation-banner:after{content:"";filter:blur(8px);z-index:1;background:radial-gradient(circle,#fff3 0%,#0000 70%);border-radius:50%;width:200px;height:200px;position:absolute;top:-40%;right:-10%}.motivation-banner .motivation-text{font-size:var(--font-xl);z-index:2;letter-spacing:-.5px;text-shadow:0 2px 4px #0000001a;font-weight:800;position:relative}.motivation-banner .motivation-sub{font-size:var(--font-sm);opacity:.9;margin-top:var(--space-base);z-index:2;font-weight:500;position:relative}.streak-fire{align-items:center;gap:var(--space-xs);color:var(--warning);font-weight:700;display:inline-flex}.toggle{background:var(--bg-tertiary);border-radius:var(--radius-full);cursor:pointer;width:44px;height:24px;transition:all var(--transition-fast);border:1px solid var(--border-color);position:relative}.toggle.active{background:var(--accent);border-color:var(--accent)}.toggle:after{content:"";width:18px;height:18px;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);background:#fff;border-radius:50%;position:absolute;top:2px;left:2px}.toggle.active:after{left:22px}.tab-bar{background:var(--bg-tertiary);border-radius:var(--radius-md);gap:2px;padding:3px;display:flex}.tab-item{border-radius:var(--radius-sm);font-size:var(--font-sm);color:var(--text-secondary);text-align:center;transition:all var(--transition-fast);white-space:nowrap;flex:1;padding:8px 12px;font-weight:600}.tab-item.active{background:var(--bg-secondary);color:var(--text-primary);box-shadow:var(--shadow-sm)}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary)25%,var(--bg-card-hover)50%,var(--bg-tertiary)75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.toast-container{z-index:300;width:100%;max-width:440px;padding:0 var(--space-lg);pointer-events:none;position:fixed;top:16px;left:50%;transform:translate(-50%)}.toast{padding:var(--space-md)var(--space-lg);border-radius:var(--radius-md);font-size:var(--font-sm);align-items:center;gap:var(--space-sm);box-shadow:var(--shadow-lg);cursor:pointer;pointer-events:all;opacity:0;font-weight:600;transition:transform .3s cubic-bezier(.175,.885,.32,1.275),opacity .3s;display:flex;position:relative;overflow:hidden;transform:translateY(-20px)}.toast-visible,.toast-enter{opacity:1;transform:translateY(0)}.toast-exit{opacity:0;transform:translateY(-20px)scale(.95)}.toast-icon{flex-shrink:0;align-items:center;display:flex}.toast-message{flex:1;min-width:0}.toast-close{opacity:.6;color:inherit;cursor:pointer;background:0 0;border:none;flex-shrink:0;align-items:center;padding:2px;transition:opacity .15s;display:flex}.toast-close:hover{opacity:1}.toast-progress{background:#fff3;height:3px;position:absolute;bottom:0;left:0;right:0}.toast-progress-bar{background:#ffffff80;width:100%;height:100%;animation:linear forwards toastCountdown}@keyframes toastCountdown{0%{width:100%}to{width:0%}}.toast-success{background:var(--success);color:#fff}.toast-warning{background:var(--warning);color:#fff}.toast-danger{background:var(--danger);color:#fff}.toast-info{background:var(--info);color:#fff}.loading-screen{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100dvh;display:flex}.loading-logo{align-items:center;gap:var(--space-md);flex-direction:column;animation:.6s loadingFadeIn;display:flex}.loading-icon{font-size:48px;animation:2s ease-in-out infinite loadingPulse}.loading-title{font-size:var(--font-xl);letter-spacing:-.5px;background:linear-gradient(135deg,var(--accent),var(--accent-light));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:800}.loading-dots{margin-top:var(--space-sm);gap:6px;display:flex}.loading-dot{background:var(--accent);border-radius:50%;width:6px;height:6px;animation:1.4s ease-in-out infinite loadingDotBounce}.loading-dot:nth-child(2){animation-delay:.16s}.loading-dot:nth-child(3){animation-delay:.32s}@keyframes loadingFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes loadingPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@keyframes loadingDotBounce{0%,80%,to{opacity:.4;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}.scroll-top-btn{bottom:calc(84px + var(--safe-bottom));background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-color);width:40px;height:40px;color:var(--text-secondary);cursor:pointer;z-index:90;box-shadow:var(--shadow-md);border-radius:50%;justify-content:center;align-items:center;font-size:18px;font-weight:700;transition:background .15s,transform .15s;animation:.3s cubic-bezier(.175,.885,.32,1.275) scrollTopIn;display:flex;position:fixed;right:16px}.scroll-top-btn:hover{background:var(--accent);color:#fff;transform:scale(1.05)}.scroll-top-btn:active{transform:scale(.92)}@keyframes scrollTopIn{0%{opacity:0;transform:scale(.5)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.nav-item.active{background:var(--accent-muted)}.nav-item.active:before{animation:.3s cubic-bezier(.175,.885,.32,1.275) navIndicatorIn}@keyframes navIndicatorIn{0%{opacity:0;width:0}to{opacity:1;width:20px}}.status-checkbox{transition:transform .15s,color .15s}.accordion-body{animation:.25s accordionOpen}@keyframes accordionOpen{0%{opacity:0;max-height:0}to{opacity:1;max-height:2000px}}.accordion-header.completed{border-color:var(--success)}@supports (color:color-mix(in lab, red, red)){.accordion-header.completed{border-color:color-mix(in srgb,var(--success)30%,var(--border-color))}}.accordion-header.completed .accordion-title{color:var(--success)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.gap-xl{gap:var(--space-xl)}.flex-1{flex:1}.w-full{width:100%}.text-center{text-align:center}.font-bold{font-weight:700}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.grid-2{gap:var(--space-md);grid-template-columns:repeat(2,1fr);display:grid}.grid-3{gap:var(--space-md);grid-template-columns:repeat(3,1fr);display:grid}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}.code-block{border-radius:var(--radius-md);padding:var(--space-lg);font-size:var(--font-sm);background:#1e1e2e;line-height:1.6;overflow-x:auto}.code-block code{font-family:JetBrains Mono,Fira Code,SF Mono,monospace}@keyframes celebrate{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}@keyframes confetti{0%{opacity:1;transform:translateY(0)rotate(0)}to{opacity:0;transform:translateY(-100px)rotate(720deg)}}.celebrate{animation:.5s celebrate}@media (min-width:481px){.app-container{border-left:1px solid var(--border-color);border-right:1px solid var(--border-color)}}@media (min-width:768px){.app-container{max-width:420px}}.auth-page{min-height:100dvh;padding:var(--space-xl);background:var(--bg-primary);justify-content:center;align-items:center;display:flex}.auth-container{width:100%;max-width:360px}.auth-header{text-align:center;margin-bottom:var(--space-2xl)}.auth-logo{background:linear-gradient(135deg,var(--accent)0%,var(--accent-light)100%);color:#fff;border-radius:var(--radius-xl);width:64px;height:64px;margin:0 auto var(--space-lg);justify-content:center;align-items:center;display:flex;box-shadow:0 8px 24px #6366f14d}.auth-title{font-size:var(--font-2xl);color:var(--text-primary);letter-spacing:-.5px;font-weight:800}.auth-subtitle{font-size:var(--font-sm);color:var(--text-secondary);margin-top:var(--space-xs)}.auth-form{gap:var(--space-lg);flex-direction:column;display:flex}.auth-alert{padding:var(--space-md)var(--space-lg);border-radius:var(--radius-md);font-size:var(--font-sm);margin-bottom:var(--space-md);font-weight:500}.auth-alert-error{background:var(--hard-bg);color:var(--hard);border:1px solid var(--hard-border)}.auth-alert-success{background:var(--easy-bg);color:var(--easy);border:1px solid var(--easy-border)}.input-with-icon{position:relative}.input-with-icon .input-icon{color:var(--text-tertiary);z-index:1;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.input-with-icon .input-icon-right{color:var(--text-tertiary);z-index:1;padding:4px;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.auth-divider{align-items:center;gap:var(--space-md);margin:var(--space-xl)0;color:var(--text-tertiary);font-size:var(--font-xs);display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border-color);flex:1;height:1px}.auth-toggle{text-align:center;margin-top:var(--space-xl);font-size:var(--font-sm);color:var(--text-secondary)}.auth-toggle button{color:var(--accent);text-underline-offset:2px;font-weight:600;text-decoration:underline}.ai-trigger-btn{border-radius:var(--radius-full);font-size:var(--font-xs);border:1px solid var(--ai-color,var(--accent));align-items:center;gap:6px;padding:7px 14px;font-weight:600;display:inline-flex}@supports (color:color-mix(in lab, red, red)){.ai-trigger-btn{border:1px solid color-mix(in srgb,var(--ai-color,var(--accent))25%,transparent)}}.ai-trigger-btn{background:var(--ai-color,var(--accent))}@supports (color:color-mix(in lab, red, red)){.ai-trigger-btn{background:color-mix(in srgb,var(--ai-color,var(--accent))8%,transparent)}}.ai-trigger-btn{color:var(--ai-color,var(--accent));transition:all var(--transition-base);cursor:pointer;white-space:nowrap;position:relative;overflow:hidden}.ai-trigger-btn:before{content:"";background:linear-gradient(135deg,transparent 30%,var(--ai-color,var(--accent))50%,transparent 70%);position:absolute;inset:0}@supports (color:color-mix(in lab, red, red)){.ai-trigger-btn:before{background:linear-gradient(135deg,transparent 30%,color-mix(in srgb,var(--ai-color,var(--accent))12%,transparent)50%,transparent 70%)}}.ai-trigger-btn:before{background-size:200% 200%;animation:3s ease-in-out infinite aiShimmer}.ai-trigger-btn:hover{border-color:var(--ai-color,var(--accent))}@supports (color:color-mix(in lab, red, red)){.ai-trigger-btn:hover{border-color:color-mix(in srgb,var(--ai-color,var(--accent))40%,transparent)}}.ai-trigger-btn:hover{background:var(--ai-color,var(--accent))}@supports (color:color-mix(in lab, red, red)){.ai-trigger-btn:hover{background:color-mix(in srgb,var(--ai-color,var(--accent))14%,transparent)}}.ai-trigger-btn:hover{box-shadow:0 4px 12px var(--ai-color,var(--accent));transform:translateY(-1px)}@supports (color:color-mix(in lab, red, red)){.ai-trigger-btn:hover{box-shadow:0 4px 12px color-mix(in srgb,var(--ai-color,var(--accent))15%,transparent)}}.ai-trigger-btn:active{transform:scale(.96)}.ai-trigger-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}@keyframes aiShimmer{0%,to{background-position:200% 0}50%{background-position:-100% 0}}.ai-panel{border-radius:var(--radius-lg);border:1px solid var(--ai-color,var(--accent))}@supports (color:color-mix(in lab, red, red)){.ai-panel{border:1px solid color-mix(in srgb,var(--ai-color,var(--accent))20%,var(--border-color))}}.ai-panel{background:var(--ai-color,var(--accent))}@supports (color:color-mix(in lab, red, red)){.ai-panel{background:color-mix(in srgb,var(--ai-color,var(--accent))4%,var(--bg-card))}}.ai-panel{transition:all var(--transition-base);overflow:hidden}.ai-panel-header{padding:var(--space-md)var(--space-lg);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;display:flex}.ai-panel-title{font-size:var(--font-sm);color:var(--ai-color,var(--accent));align-items:center;gap:8px;font-weight:700;display:flex}.ai-badge{border-radius:var(--radius-full);background:var(--ai-color,var(--accent));padding:1px 6px;font-size:9px;font-weight:800}@supports (color:color-mix(in lab, red, red)){.ai-badge{background:color-mix(in srgb,var(--ai-color,var(--accent))15%,transparent)}}.ai-badge{color:var(--ai-color,var(--accent));letter-spacing:.5px}.ai-icon-btn{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-tertiary);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.ai-icon-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.ai-panel-body{padding:0 var(--space-lg)var(--space-lg);animation:.2s aiFadeIn}@keyframes aiFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.ai-loading{align-items:center;gap:var(--space-md);padding:var(--space-lg);justify-content:center;display:flex}.ai-loading-dots{gap:4px;display:flex}.ai-loading-dots span{background:var(--ai-color,var(--accent));border-radius:50%;width:6px;height:6px;animation:1.4s ease-in-out infinite aiDotPulse}.ai-loading-dots span:nth-child(2){animation-delay:.2s}.ai-loading-dots span:nth-child(3){animation-delay:.4s}@keyframes aiDotPulse{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1.1)}}.ai-loading-text{font-size:var(--font-sm);color:var(--text-secondary);font-style:italic}.ai-error{justify-content:space-between;align-items:center;gap:var(--space-md);padding:var(--space-md)var(--space-lg);background:var(--hard-bg);border:1px solid var(--hard-border);border-radius:var(--radius-md);font-size:var(--font-sm);color:var(--hard);display:flex}.ai-content{font-size:var(--font-sm);color:var(--text-secondary);line-height:1.7}.ai-content strong{color:var(--text-primary)}.ai-spin{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.ai-actions{gap:var(--space-sm);padding:var(--space-md)0;flex-wrap:wrap;display:flex}.ai-coach-card{background:linear-gradient(135deg,var(--accent),#8b5cf6)}@supports (color:color-mix(in lab, red, red)){.ai-coach-card{background:linear-gradient(135deg,color-mix(in srgb,var(--accent)8%,var(--bg-card)),color-mix(in srgb,#8b5cf6 6%,var(--bg-card)))}}.ai-coach-card{border:1px solid var(--accent)}@supports (color:color-mix(in lab, red, red)){.ai-coach-card{border:1px solid color-mix(in srgb,var(--accent)20%,var(--border-color))}}.ai-coach-card{border-radius:var(--radius-lg);padding:var(--space-lg);position:relative;overflow:hidden}.ai-coach-card:before{content:"";background:radial-gradient(circle,var(--accent)0%,transparent 70%);width:100%;height:100%;position:absolute;top:-50%;right:-50%}@supports (color:color-mix(in lab, red, red)){.ai-coach-card:before{background:radial-gradient(circle,color-mix(in srgb,var(--accent)8%,transparent)0%,transparent 70%)}}.ai-coach-card:before{pointer-events:none}.ai-coach-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.ai-coach-title{font-size:var(--font-sm);color:var(--accent);align-items:center;gap:8px;font-weight:700;display:flex}.ai-interview-card{background:linear-gradient(135deg,#ec4899,#8b5cf6)}@supports (color:color-mix(in lab, red, red)){.ai-interview-card{background:linear-gradient(135deg,color-mix(in srgb,#ec4899 6%,var(--bg-card)),color-mix(in srgb,#8b5cf6 6%,var(--bg-card)))}}.ai-interview-card{border:1px solid #ec4899}@supports (color:color-mix(in lab, red, red)){.ai-interview-card{border:1px solid color-mix(in srgb,#ec4899 20%,var(--border-color))}}.ai-interview-card{border-radius:var(--radius-lg);padding:var(--space-lg)}.accordion-list{flex-direction:column;gap:2px;display:flex}.accordion-group{border-radius:var(--radius-md);overflow:hidden}.accordion-header{align-items:center;gap:var(--space-sm);width:100%;padding:14px var(--space-md);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;text-align:left;color:var(--text-primary);font-family:inherit;transition:background .15s,border-color .15s,transform .1s;display:flex}.accordion-header:active{transform:scale(.985)}@media (hover:hover){.accordion-header:hover{background:var(--bg-tertiary)}}.accordion-header.open{background:var(--bg-tertiary);border-bottom-color:#0000;border-bottom-right-radius:0;border-bottom-left-radius:0}.accordion-chevron{color:var(--text-tertiary);flex-shrink:0;transition:transform .2s}.accordion-title{font-weight:700;font-size:var(--font-sm);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}.accordion-count{font-size:var(--font-xs);color:var(--text-secondary);text-align:right;flex-shrink:0;min-width:45px;font-weight:600}.accordion-progress{background:var(--bg-primary);border-radius:2px;flex-shrink:0;width:120px;height:4px;overflow:hidden}@media (max-width:480px){.accordion-progress{width:60px}}.accordion-progress-fill{border-radius:2px;height:100%;transition:width .3s}.accordion-body{border:1px solid var(--border-color);border-bottom-left-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md);background:var(--bg-card);border-top:none;overflow-x:auto}.accordion-table-header{padding:8px var(--space-md);border-bottom:1px solid var(--border-color);text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);background:var(--bg-tertiary);align-items:center;min-width:500px;font-size:11px;font-weight:700;display:flex}.accordion-row{padding:10px var(--space-md);border-bottom:1px solid var(--border-color);align-items:center;display:flex}@supports (color:color-mix(in lab, red, red)){.accordion-row{border-bottom:1px solid color-mix(in srgb,var(--border-color)50%,transparent)}}.accordion-row{cursor:pointer;-webkit-user-select:none;user-select:none;min-width:500px;transition:background .15s,transform .1s}.accordion-row:last-child{border-bottom:none}.accordion-row:active{background:var(--accent-bg);transform:scale(.985)}@media (hover:hover){.accordion-row:hover{background:var(--bg-tertiary)}}.accordion-row.solved{background:var(--success)}@supports (color:color-mix(in lab, red, red)){.accordion-row.solved{background:color-mix(in srgb,var(--success)4%,transparent)}}.accordion-row.solved:active{background:var(--success)}@supports (color:color-mix(in lab, red, red)){.accordion-row.solved:active{background:color-mix(in srgb,var(--success)12%,transparent)}}@media (hover:hover){.accordion-row.solved:hover{background:var(--success)}@supports (color:color-mix(in lab, red, red)){.accordion-row.solved:hover{background:color-mix(in srgb,var(--success)8%,transparent)}}}.atcol-status{flex-shrink:0;justify-content:center;width:50px;display:flex}.atcol-star{flex-shrink:0;justify-content:center;width:40px;display:flex}.atcol-problem{flex:1;align-items:center;gap:6px;min-width:0;display:flex}.atcol-difficulty{text-align:center;flex-shrink:0;width:80px}.atcol-solution{flex-shrink:0;justify-content:center;width:60px;display:flex}.status-checkbox{cursor:pointer;background:0 0;border:none;align-items:center;padding:2px;transition:transform .15s;display:flex}.status-checkbox:active{transform:scale(.85)}.problem-title{font-size:var(--font-sm);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.external-link-icon{color:var(--text-tertiary);opacity:.5;flex-shrink:0;transition:opacity .15s}.external-link-icon:hover{opacity:1;color:var(--accent)}.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.sortable:hover{color:var(--text-primary)}.solution-btn{cursor:pointer;color:var(--text-tertiary);background:0 0;border:none;align-items:center;padding:4px;transition:color .15s;display:flex}.solution-btn:hover{color:var(--accent)}.view-toggle{background:var(--bg-tertiary);border-radius:var(--radius-md);gap:2px;padding:2px;display:flex}.view-toggle button{border-radius:var(--radius-sm);font-size:var(--font-xs);color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;padding:6px 12px;font-family:inherit;font-weight:600;transition:all .15s}.view-toggle button.active{background:var(--bg-card);color:var(--text-primary);box-shadow:0 1px 3px #0000001a}.problem-title,.accordion-row,.accordion-header,.status-checkbox,.solution-btn,.external-link-icon,.pd-action-btn,.pd-back-btn,.pd-status-btn,.pd-tab,.card[role=button],.card[onclick]{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;outline:none}.accordion-row:focus,.accordion-row a:focus,.external-link-icon:focus{color:inherit;outline:none}.accordion-row a{color:inherit;text-decoration:none}.problem-detail-page{padding-bottom:calc(var(--nav-height) + var(--safe-bottom) + 32px)}.pd-hero{margin:calc(-1*var(--space-xl))calc(-1*var(--space-lg))0;padding:var(--space-lg)var(--space-lg)var(--space-xl);background:linear-gradient(180deg,var(--diff-color)0%,var(--bg-primary)100%)}@supports (color:color-mix(in lab, red, red)){.pd-hero{background:linear-gradient(180deg,color-mix(in srgb,var(--diff-color)6%,var(--bg-primary))0%,var(--bg-primary)100%)}}.pd-hero{border-bottom:1px solid var(--border-color);margin-bottom:var(--space-lg)}.pd-topbar{margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;display:flex}.pd-topbar-actions{align-items:center;gap:4px;display:flex}.pd-back-btn,.pd-action-btn{border-radius:var(--radius-sm);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.pd-back-btn:hover,.pd-action-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.pd-back-btn:active,.pd-action-btn:active{transform:scale(.9)}.pd-title{font-size:var(--font-xl);margin-bottom:var(--space-md);letter-spacing:-.3px;font-weight:800;line-height:1.3}.pd-meta{align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.pd-diff-badge{font-size:var(--font-xs);border-radius:var(--radius-full);background:currentColor;padding:2px 10px;font-weight:700}@supports (color:color-mix(in lab, red, red)){.pd-diff-badge{background:color-mix(in srgb,currentColor 10%,transparent)}}.pd-topic-badge{font-size:var(--font-xs);color:var(--text-secondary);font-weight:500}.pd-pattern-badge{border-radius:var(--radius-full);background:var(--accent-bg);color:var(--accent);padding:2px 8px;font-size:10px;font-weight:600}.pd-companies{margin-top:var(--space-sm);flex-wrap:wrap;gap:4px;display:flex}.pd-company-chip{border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-secondary);padding:2px 8px;font-size:10px;font-weight:500}.pd-status-bar{margin-bottom:var(--space-lg);scrollbar-width:none;-webkit-overflow-scrolling:touch;gap:4px;display:flex;overflow-x:auto}.pd-status-bar::-webkit-scrollbar{display:none}.pd-status-btn{border-radius:var(--radius-full);font-size:var(--font-xs);white-space:nowrap;border:1.5px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;align-items:center;gap:4px;padding:6px 12px;font-weight:600;transition:all .15s;display:flex}.pd-status-btn:active{transform:scale(.95)}.pd-status-btn.active{background:var(--status-color)}@supports (color:color-mix(in lab, red, red)){.pd-status-btn.active{background:color-mix(in srgb,var(--status-color)12%,transparent)}}.pd-status-btn.active{color:var(--status-color);border-color:var(--status-color)}@supports (color:color-mix(in lab, red, red)){.pd-status-btn.active{border-color:color-mix(in srgb,var(--status-color)30%,transparent)}}.pd-revision-banner{align-items:center;gap:var(--space-sm);padding:var(--space-md)var(--space-lg);background:var(--warning);display:flex}@supports (color:color-mix(in lab, red, red)){.pd-revision-banner{background:color-mix(in srgb,var(--warning)8%,transparent)}}.pd-revision-banner{border:1px solid var(--warning)}@supports (color:color-mix(in lab, red, red)){.pd-revision-banner{border:1px solid color-mix(in srgb,var(--warning)20%,transparent)}}.pd-revision-banner{border-radius:var(--radius-md);margin-bottom:var(--space-lg);font-size:var(--font-sm);color:var(--warning);font-weight:500}.pd-revision-btn{border-radius:var(--radius-full);background:var(--warning);color:#fff;font-size:var(--font-xs);cursor:pointer;border:none;margin-left:auto;padding:4px 12px;font-weight:700}.pd-timer-card{padding:var(--space-md)var(--space-lg);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;animation:.2s accordionOpen;display:flex}.pd-timer-display{flex-direction:column;display:flex}.pd-timer-value{font-size:var(--font-2xl);letter-spacing:1px;font-family:SF Mono,JetBrains Mono,monospace;font-weight:800}.pd-timer-total{font-size:var(--font-xs);color:var(--text-tertiary)}.pd-timer-controls{gap:6px;display:flex}.pd-timer-btn{cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:transform .15s;display:flex}.pd-timer-btn:active{transform:scale(.85)}.pd-timer-btn.primary{background:var(--accent);color:#fff}.pd-timer-btn.danger{background:var(--danger);color:#fff}.pd-timer-btn.success{background:var(--success);color:#fff}.pd-timer-btn.ghost{background:var(--bg-tertiary);color:var(--text-secondary)}.pd-tabs{background:var(--bg-tertiary);border-radius:var(--radius-md);margin-bottom:var(--space-lg);gap:2px;padding:3px;display:flex}.pd-tab{border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-xs);color:var(--text-tertiary);background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:4px;padding:8px 6px;font-weight:600;transition:all .15s;display:flex}.pd-tab:active{transform:scale(.96)}.pd-tab.active{background:var(--bg-card);color:var(--text-primary);box-shadow:var(--shadow-sm)}.pd-tab-icon{font-size:14px}.pd-content{min-height:200px}.pd-tab-content{gap:var(--space-md);flex-direction:column;animation:.2s pdContentIn;display:flex}@keyframes pdContentIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.pd-section{gap:var(--space-sm);flex-direction:column;display:flex}.pd-section-header{font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);align-items:center;gap:6px;font-weight:700;display:flex}.pd-section-body{padding:var(--space-md)var(--space-lg);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md)}.pd-description{font-size:var(--font-sm);color:var(--text-primary);line-height:1.7}.pd-hints .pd-section-body{background:var(--warning)}@supports (color:color-mix(in lab, red, red)){.pd-hints .pd-section-body{background:color-mix(in srgb,var(--warning)4%,var(--bg-card))}}.pd-hints .pd-section-body{border-color:var(--warning)}@supports (color:color-mix(in lab, red, red)){.pd-hints .pd-section-body{border-color:color-mix(in srgb,var(--warning)15%,var(--border-color))}}.pd-hint-item{gap:var(--space-sm);padding:var(--space-xs)0;font-size:var(--font-sm);color:var(--text-secondary);display:flex}.pd-hint-num{color:var(--warning);flex-shrink:0;width:18px;font-weight:700}.pd-approaches-label{font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);margin-top:var(--space-sm);align-items:center;gap:6px;font-weight:700;display:flex}.pd-approach-card{padding:var(--space-lg);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);border-left:3px solid var(--text-tertiary)}.pd-approach-card.optimal{border-left-color:var(--success);background:var(--success)}@supports (color:color-mix(in lab, red, red)){.pd-approach-card.optimal{background:color-mix(in srgb,var(--success)3%,var(--bg-card))}}.pd-approach-header{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm);display:flex}.pd-approach-name{font-size:var(--font-sm);font-weight:800}.pd-approach-card.optimal .pd-approach-name{color:var(--success)}.pd-optimal-badge{border-radius:var(--radius-full);background:var(--success);padding:1px 6px;font-size:10px;font-weight:700}@supports (color:color-mix(in lab, red, red)){.pd-optimal-badge{background:color-mix(in srgb,var(--success)12%,transparent)}}.pd-optimal-badge{color:var(--success)}.pd-approach-desc{font-size:var(--font-sm);color:var(--text-secondary);margin-bottom:var(--space-md);line-height:1.6}.pd-complexity-row{gap:var(--space-sm);display:flex}.pd-complexity{font-size:var(--font-xs);border-radius:var(--radius-full);align-items:center;gap:4px;padding:3px 10px;font-weight:600;display:flex}.pd-complexity.time{background:var(--accent-bg);color:var(--accent)}.pd-complexity.space{background:var(--bg-tertiary);color:var(--text-secondary)}.pd-textarea{width:100%;padding:var(--space-md);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--font-sm);color:var(--text-primary);resize:vertical;line-height:1.6;font-family:var(--font-family);transition:border-color .15s}.pd-textarea:focus{border-color:var(--accent);outline:none}.pd-code-input{font-family:SF Mono,JetBrains Mono,Fira Code,monospace;font-size:13px}.pd-complexity-inputs{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}.pd-input-label{font-size:var(--font-xs);color:var(--text-secondary);margin-bottom:4px;font-weight:600;display:block}.pd-input{width:100%;padding:8px var(--space-md);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--font-sm);color:var(--text-primary);transition:border-color .15s}.pd-input:focus{border-color:var(--accent);outline:none}.pd-pattern-card{padding:var(--space-md)var(--space-lg);background:var(--accent-bg);border:1px solid var(--accent)}@supports (color:color-mix(in lab, red, red)){.pd-pattern-card{border:1px solid color-mix(in srgb,var(--accent)15%,transparent)}}.pd-pattern-card{border-radius:var(--radius-md)}.pd-pattern-label{font-size:var(--font-sm);color:var(--accent);margin-bottom:4px;font-weight:700}.pd-pattern-desc{font-size:var(--font-sm);color:var(--text-secondary);line-height:1.5}.pd-ai-grid{gap:var(--space-md);flex-direction:column;display:flex}.pd-danger-zone{margin-top:var(--space-2xl);border-top:1px solid var(--border-color);padding-top:var(--space-lg)}.pd-delete-toggle{align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-sm)0;color:var(--text-tertiary);font-size:var(--font-xs);cursor:pointer;background:0 0;border:none;font-weight:600;display:flex}.pd-delete-toggle:hover{color:var(--danger)}.pd-delete-confirm{padding:var(--space-md);margin-top:var(--space-sm);border-radius:var(--radius-md);background:var(--danger)}@supports (color:color-mix(in lab, red, red)){.pd-delete-confirm{background:color-mix(in srgb,var(--danger)5%,transparent)}}.pd-delete-confirm{border:1px solid var(--danger)}@supports (color:color-mix(in lab, red, red)){.pd-delete-confirm{border:1px solid color-mix(in srgb,var(--danger)15%,transparent)}}.pd-delete-confirm{animation:.2s accordionOpen}.pd-delete-confirm p{font-size:var(--font-xs);color:var(--text-secondary);margin-bottom:var(--space-md)}.pd-delete-btn{background:var(--danger);color:#fff;border-radius:var(--radius-sm);font-size:var(--font-sm);cursor:pointer;border:none;align-items:center;gap:6px;padding:8px 16px;font-weight:600;transition:transform .15s;display:flex}.pd-delete-btn:active{transform:scale(.95)}@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-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
