@import "https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400;0,500;0,600;1,400&family=Inter:wght@300;400;500;600&display=swap";:root{--bg:#141413;--surface:#1e1e1cd9;--surface-solid:#1e1e1c;--border:#ffffff14;--border-hover:#d977574d;--text:#faf9f5;--muted:#b0aea5;--accent:#d97757;--accent-glow:#d9775733;--ac:#788c5d;--wa:#c15f3c;--tle:#d9b057;--ce:#b89b72;--re:#8b79a5;--mle:#6a9bcc;--cf:#6a9bcc;--atcoder:#788c5d;--lc:#d97757;--accent-2:#b0aea5;--accent-grad:linear-gradient(135deg, #d97757 0%, #b89b72 100%);--shadow-sm:0 1px 3px #0003;--shadow-md:0 4px 20px #00000040;--shadow-lg:0 12px 30px -10px #00000059;--shadow-hover:0 16px 35px -12px #0006;--shadow-modal:0 25px 50px -12px #00000080;--ease-out:cubic-bezier(.22, 1, .36, 1);--ease-smooth:cubic-bezier(.4, 0, .2, 1);--font-family:"Inter", system-ui, -apple-system, sans-serif;--font-display:"Lora", Georgia, "Times New Roman", serif;--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace}body.light-mode{--bg:#f7f6f2;--surface:#ffffffd9;--surface-solid:#fff;--border:#00000014;--border-hover:#d9775766;--text:#2c2a26;--muted:#6e6b62;--accent:#d97757;--accent-glow:#d9775726;--ac:#6a7c51;--wa:#b05030;--tle:#c29845;--ce:#a68b64;--re:#7a6a94;--mle:#5885b5;--cf:#5885b5;--atcoder:#6a7c51;--lc:#d97757;--accent-2:#807c73;--accent-grad:linear-gradient(135deg, #d97757 0%, #b89b72 100%);--shadow-sm:0 1px 3px #0000000d;--shadow-md:0 4px 20px #00000014;--shadow-lg:0 12px 30px -10px #0000001f;--shadow-hover:0 16px 35px -12px #00000026;--shadow-modal:0 25px 50px -12px #0003}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg);color:var(--text);font-family:var(--font-family);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;min-height:100vh;line-height:1.6;position:relative;overflow-x:hidden}body:before{content:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:9999px}::-webkit-scrollbar-thumb:hover{background:#6366f180}.glass-card{background:var(--surface);border:1px solid var(--border);transition:transform .3s var(--ease-smooth), border-color .3s ease, box-shadow .3s ease;box-shadow:var(--shadow-md);will-change:transform;border-radius:16px;padding:1.75rem}.glass-card-hover:hover{border-color:var(--border-hover);box-shadow:var(--shadow-hover);transform:translateY(-4px)}@keyframes fade-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.5s cubic-bezier(.22,1,.36,1) both fade-up}.oj-stats-grid>:first-child{animation:.45s cubic-bezier(.22,1,.36,1) 50ms both fade-up}.oj-stats-grid>:nth-child(2){animation:.45s cubic-bezier(.22,1,.36,1) .1s both fade-up}.oj-stats-grid>:nth-child(3){animation:.45s cubic-bezier(.22,1,.36,1) .15s both fade-up}.oj-stats-grid>:nth-child(4){animation:.45s cubic-bezier(.22,1,.36,1) .2s both fade-up}.oj-stats-grid>:nth-child(5){animation:.45s cubic-bezier(.22,1,.36,1) .25s both fade-up}.oj-stats-grid>:nth-child(6){animation:.45s cubic-bezier(.22,1,.36,1) .3s both fade-up}.today-charts-grid>*{animation:.5s cubic-bezier(.22,1,.36,1) .35s both fade-up}.today-tags-box{animation:.5s cubic-bezier(.22,1,.36,1) .4s both fade-up}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1;background-color:#1f2937cc}}.skeleton-box{background-color:#1f293766;animation:1.6s ease-in-out infinite pulse}.skeleton-text{border-radius:6px;height:12px}.skeleton-title{border-radius:8px;height:20px}.skeleton-circle{border-radius:50%;animation:1.6s ease-in-out infinite pulse}.card-count{font-variant-numeric:tabular-nums}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}body.zen-mode .rating-tag,body.zen-mode .difficulty-tag,body.zen-mode .rating-circle,body.zen-mode .cp31-rating-col,body.zen-mode .rating-badge,body.zen-mode .stuck-rating,body.zen-mode .struggled-rating,body.zen-mode .drilldown-rating-cell,body.zen-mode .rating-mini,body.zen-mode .matrix-rating-lbl,body.zen-mode .col-rating,body.zen-mode .leaderboard-rating,body.zen-mode .recommendation-rating,body.zen-mode .tag-difficulty,body.zen-mode .sheet-tier-rating,body.zen-mode .ring-tier,body.zen-mode .diff-lbl{filter:blur(4px);opacity:.5;pointer-events:none;-webkit-user-select:none;user-select:none;transition:filter .3s,opacity .3s}body.zen-mode .rating-tag:hover,body.zen-mode .difficulty-tag:hover,body.zen-mode .rating-badge:hover,body.zen-mode .stuck-rating:hover,body.zen-mode .struggled-rating:hover,body.zen-mode .drilldown-rating-cell:hover,body.zen-mode .rating-mini:hover,body.zen-mode .matrix-rating-lbl:hover,body.zen-mode .col-rating:hover,body.zen-mode .leaderboard-rating:hover,body.zen-mode .recommendation-rating:hover,body.zen-mode .tag-difficulty:hover,body.zen-mode .sheet-tier-rating:hover,body.zen-mode .ring-tier:hover,body.zen-mode .diff-lbl:hover{filter:blur();opacity:1}body.zen-mode .unified-rating-widget{display:none}.sidebar{background-color:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:260px;height:100vh;padding:1.5rem 1rem;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar-header{margin-bottom:2rem;padding:0 .5rem}.logo{font-family:var(--font-display);color:var(--text);letter-spacing:-.02em;margin-bottom:1.5rem;font-size:1.25rem;font-weight:600}.profile-mini{background:var(--surface-solid);border:1px solid var(--border);border-radius:8px;align-items:center;gap:.75rem;padding:.75rem;display:flex}.avatar-mini{object-fit:cover;border-radius:6px;width:36px;height:36px}.profile-info-mini{flex-direction:column;display:flex}.handle-mini{color:var(--text);font-size:.85rem;font-weight:600}.rating-mini{color:var(--muted);font-size:.75rem;font-family:var(--font-mono)}.setup-btn{width:100%;color:var(--accent);cursor:pointer;background:#6366f11a;border:1px solid #6366f133;border-radius:8px;padding:.6rem;font-size:.8rem;font-weight:600;transition:all .2s}.setup-btn:hover{background:#6366f133}.sidebar-nav{flex-direction:column;flex-grow:1;gap:.5rem;display:flex}.nav-item{color:var(--muted);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:.75rem;padding:.75rem 1rem;font-size:.9rem;font-weight:500;transition:all .2s;display:flex}.nav-item:hover{background:var(--surface-solid);color:var(--text)}.nav-item.active{background:var(--surface-solid);color:var(--text);border-left:3px solid var(--accent);font-weight:600}.nav-icon{text-align:center;width:20px;font-size:1.1rem}.sidebar-footer{border-top:1px solid var(--border);margin-top:auto;padding-top:1rem}.settings-btn{width:100%;color:var(--muted);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:.75rem;padding:.75rem 1rem;font-size:.9rem;font-weight:500;transition:all .2s;display:flex}.settings-btn:hover{background:var(--surface-solid);color:var(--text)}@media (width<=768px){.sidebar{border-right:none;border-bottom:1px solid var(--border);width:100%;height:auto;padding:1rem;position:static}.sidebar-nav{flex-direction:row;padding-bottom:.5rem;overflow-x:auto}.nav-item{white-space:nowrap}}.switch-label{color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:8px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.9rem;transition:all .2s;display:flex}.switch-label:hover{background:var(--surface-solid)}.switch-label input{cursor:pointer;width:16px;height:16px;accent-color:var(--accent);margin-right:.25rem}.heatmap-container{width:100%;margin-top:1rem}.heatmap-title{color:var(--text,#f9fafb);margin-bottom:.75rem;font-size:1rem;font-weight:600}.heatmap-wrapper{padding-bottom:.5rem;position:relative;overflow-x:auto}.heatmap-svg{display:block}.heatmap-month-label{fill:var(--muted,#6b7280);font-family:Inter,sans-serif;font-size:10px}.heatmap-day-label{fill:var(--muted,#6b7280);font-family:Inter,sans-serif;font-size:9px}.heatmap-cell{cursor:pointer;transition:opacity .15s}.heatmap-cell:hover{opacity:.8;stroke:#f9fafb;stroke-width:1px}.heatmap-tooltip{color:#f9fafb;white-space:nowrap;pointer-events:none;z-index:10;background:#1f2937;border-radius:4px;padding:4px 8px;font-size:11px;position:absolute;transform:translate(-50%,-100%);box-shadow:0 2px 8px #0006}.heatmap-tooltip:after{content:"";border:4px solid #0000;border-top-color:#1f2937;position:absolute;top:100%;left:50%;transform:translate(-50%)}.heatmap-legend{justify-content:flex-end;align-items:center;gap:4px;margin-top:.5rem;display:flex}.heatmap-legend-label{color:var(--muted,#6b7280);margin:0 2px;font-size:11px}.heatmap-legend-cell{border-radius:2px;width:12px;height:12px;display:inline-block}.heatmap-cell.interactive{cursor:pointer;transition:transform .1s,filter .1s}.heatmap-cell.interactive:hover{filter:brightness(1.2);transform:scale(1.15)}.notice-banner{background:var(--surface);-webkit-backdrop-filter:blur(8px);border:1px solid var(--border);border-left:3px solid var(--accent);color:#cbd5e1;box-shadow:var(--shadow-sm);border-radius:12px;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.7rem;padding:.7rem 1rem;font-size:.8rem;line-height:1.45;display:flex}.notice-banner--warn{border-left-color:var(--tle)}.notice-banner--info{border-left-color:var(--accent)}.notice-banner--error{border-left-color:var(--wa)}.notice-banner__text{align-items:center;gap:.5rem;min-width:0;display:inline-flex}.notice-banner__icon{flex-shrink:0}.notice-banner__btn{color:#a5b4fc;cursor:pointer;background:#6366f124;border:1px solid #6366f166;border-radius:9px;flex-shrink:0;padding:.4rem .9rem;font-family:inherit;font-size:.78rem;font-weight:600;transition:background .15s,border-color .15s,transform .12s}.notice-banner__btn:hover{background:#6366f138;border-color:#6366f199;transform:translateY(-1px)}.notice-banner__btn:active{transform:translateY(0)}.notice-banner__btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media (width<=560px){.notice-banner{flex-direction:column;align-items:flex-start;gap:.6rem}.notice-banner__btn{text-align:center;align-self:stretch}}.contests-widget{flex-direction:column;gap:1rem;display:flex}.widget-title{font-family:var(--font-display);color:var(--text);margin-bottom:.5rem;font-size:1.1rem;font-weight:500}.contests-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;display:grid}.contest-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:.75rem;padding:1.25rem;transition:all .2s;display:flex;position:relative;overflow:hidden}.contest-card:before{content:"";width:4px;height:100%;position:absolute;top:0;left:0}.contest-card.platform-cf:before{background-color:var(--cf)}.contest-card.platform-lc:before{background-color:var(--lc)}.contest-card.platform-ac:before{background-color:var(--atcoder)}.contest-card.platform-cc:before{background-color:#8b5cf6}.contest-title{color:var(--text);font-size:.95rem;font-weight:600;line-height:1.3}.contest-details{color:var(--muted);justify-content:space-between;font-size:.8rem;display:flex}.contest-actions{gap:.5rem;margin-top:auto;display:flex}.signup-btn{text-align:center;color:var(--text);background:#ffffff0d;border-radius:8px;flex:1;padding:.5rem;font-size:.8rem;font-weight:600;text-decoration:none;transition:all .2s}.calendar-btn{background:#ffffff0d;border-radius:8px;justify-content:center;align-items:center;padding:0 .75rem;font-size:1rem;text-decoration:none;transition:all .2s;display:flex}.signup-btn:hover,.calendar-btn:hover{background:#ffffff1a}.platform-lc .signup-btn,.platform-lc .calendar-btn{color:var(--lc-yellow);background:#d9775726}.platform-lc .signup-btn:hover,.platform-lc .calendar-btn:hover{background:#d9775740}.daily-problems-widget{flex-direction:column;gap:1rem;display:flex}.problems-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;display:grid}.problem-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:.75rem;padding:1.25rem;transition:all .2s;display:flex}.problem-card:hover{border-color:var(--border-hover);background:var(--surface-solid)}.problem-title{color:var(--text);font-size:.95rem;font-weight:600;line-height:1.3}.problem-tags{gap:.5rem;margin-bottom:.5rem;display:flex}.tag-difficulty,.tag-platform{border-radius:12px;padding:.15rem .5rem;font-size:.7rem;font-weight:600}.tag-platform{color:var(--muted);background:#ffffff0d}.diff-easy{color:#4ade80;background:#22c55e26}.diff-medium{color:#facc15;background:#eab30826}.diff-hard{color:#f87171;background:#ef444426}.diff-cf{color:#818cf8;background:#6366f126}.solve-btn{text-align:center;border-radius:8px;margin-top:auto;padding:.5rem;font-size:.85rem;font-weight:600;text-decoration:none;transition:all .2s}.lc-btn{color:var(--lc-yellow);background:#d9775726;border:1px solid #d9775733}.lc-btn:hover{background:#d9775740}.cf-btn{color:var(--cf-blue);background:#6a9bcc26;border:1px solid #6a9bcc33}.cf-btn:hover{background:#6a9bcc40}.empty-card{text-align:center;justify-content:center;align-items:center}.empty-text{color:var(--muted);font-size:.85rem}.streak-stats-grid{grid-template-columns:repeat(2,1fr);gap:1rem;width:100%;display:grid}@media (width>=768px){.streak-stats-grid{grid-template-columns:repeat(4,1fr)}}.streak-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;flex-direction:column;justify-content:center;align-items:flex-start;padding:1.25rem 1.5rem;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex}.streak-stat-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 12px #0003}.streak-stat-title{font-size:.7rem;font-family:var(--font-display);color:var(--muted);letter-spacing:.05em;text-transform:uppercase;margin-bottom:.5rem;font-weight:700}.streak-stat-value{color:var(--text);font-size:1.8rem;font-weight:800;font-family:var(--font-display);align-items:baseline;line-height:1;display:flex}.streak-unit{color:var(--muted);margin-left:.25rem;font-size:.85rem;font-weight:500}.difficulty-distribution{flex-direction:column;display:flex}.difficulty-distribution .widget-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.diff-tabs{background-color:var(--bg);border-radius:6px;gap:.5rem;padding:.25rem;display:flex}.diff-tab{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.4rem .8rem;font-size:.85rem;font-weight:500;transition:all .2s}.diff-tab:hover{color:var(--text)}.diff-tab.active{background-color:var(--surface-solid);color:var(--text);box-shadow:0 1px 3px #0003}.diff-chart-container{justify-content:center;align-items:center;width:100%;height:250px;display:flex}.diff-tooltip{background-color:var(--surface-solid);border:1px solid var(--border);border-radius:6px;padding:.75rem 1rem;box-shadow:0 4px 12px #0000004d}.diff-tooltip-label{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin:0 0 .25rem;font-size:.8rem}.diff-tooltip-value{color:var(--text);margin:0;font-size:1.1rem;font-weight:600}.diff-empty{color:var(--muted);font-size:.9rem;font-style:italic}.unified-rating-widget{flex-direction:column;grid-column:1/-1;gap:1.5rem;padding:1.5rem;display:flex}.unified-rating-badges{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.rating-badge-item{background:var(--surface-light);border:1px solid var(--border);border-radius:.5rem;flex-direction:column;gap:.5rem;padding:1rem 1.25rem;display:flex;position:relative;overflow:hidden}.rating-badge-item:has(.oj-cf){grid-column:span 2}@media (width<=500px){.unified-rating-badges{grid-template-columns:1fr}.rating-badge-item:has(.oj-cf){grid-column:span 1}}.rating-badge-item:before{content:"";width:4px;height:100%;position:absolute;top:0;left:0}.rating-badge-item:has(.oj-cf):before{background:var(--cf)}.rating-badge-item:has(.oj-lc):before{background:var(--lc)}.rating-badge-item:has(.oj-atcoder):before{background:var(--atcoder)}.rating-badge-platform{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem;font-weight:600}.rating-badge-info{justify-content:space-between;align-items:baseline;display:flex}.rating-badge-title{font-size:1.1rem;font-weight:700}.rating-badge-score{color:var(--text);font-family:JetBrains Mono,monospace;font-size:1.5rem;font-weight:800}.rating-badge-empty{color:var(--muted);font-size:1rem;font-style:italic}.unified-rating-chart-section{flex-direction:column;gap:1rem;display:flex}.unified-rating-tabs{border-bottom:1px solid var(--border);gap:.5rem;padding-bottom:.5rem;display:flex}.unified-chart-container{width:100%;height:220px}.unified-tooltip{background:var(--surface-light);border:1px solid var(--border);border-radius:.375rem;padding:.75rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.unified-tooltip-label{color:var(--muted);margin-bottom:.25rem;font-size:.75rem;font-weight:500}.unified-tooltip-value{color:var(--text);font-family:JetBrains Mono,monospace;font-size:.875rem;font-weight:600}.unified-empty{height:100%;color:var(--muted);background:var(--surface);border:1px dashed var(--border);border-radius:.5rem;justify-content:center;align-items:center;font-size:.9rem;font-style:italic;display:flex}.timeline-feed-widget{flex-direction:column;height:100%;max-height:800px;display:flex}.timeline-feed-header{margin-bottom:1.5rem}.timeline-feed-subtitle{color:var(--muted);font-size:.85rem}.timeline-container{scrollbar-width:thin;scrollbar-color:#ffffff1a transparent;flex:1;padding-right:.5rem;overflow-y:auto}.timeline-container::-webkit-scrollbar{width:4px}.timeline-container::-webkit-scrollbar-track{background:0 0}.timeline-container::-webkit-scrollbar-thumb{background-color:#ffffff1a;border-radius:4px}.timeline-list{flex-direction:column;padding-left:1rem;display:flex;position:relative}.timeline-list:before{content:"";background:var(--border);z-index:1;width:2px;position:absolute;top:0;bottom:0;left:20px}.timeline-item{padding-bottom:1.5rem;padding-left:2.5rem;position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-dot{background:var(--surface);border:2px solid var(--muted);z-index:2;width:12px;height:12px;box-shadow:0 0 0 4px var(--surface);border-radius:50%;position:absolute;top:4px;left:-2px}.timeline-dot.ac{border-color:var(--ac);background:var(--ac)}.timeline-dot.wa{border-color:var(--wa)}.timeline-dot.tle{border-color:var(--tle)}.timeline-dot.re{border-color:var(--re)}.timeline-dot.ce{border-color:var(--ce)}.timeline-dot.mle{border-color:var(--mle)}.timeline-content{background:var(--surface-light);border:1px solid var(--border);border-radius:.5rem;flex-direction:column;gap:.25rem;padding:.75rem 1rem;transition:border-color .2s,transform .2s;display:flex}.timeline-content:hover{border-color:#ffffff1a;transform:translate(2px)}.timeline-top-row{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.timeline-prob-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:.95rem;font-weight:600;text-decoration:none;transition:color .2s;overflow:hidden}.timeline-prob-name:hover{color:var(--accent)}.timeline-time{color:var(--muted);white-space:nowrap;font-size:.75rem}.timeline-bottom-row{justify-content:space-between;align-items:center;margin-top:.25rem;display:flex}.timeline-verdict{background:#ffffff0d;border-radius:4px;padding:.15rem .4rem;font-size:.75rem;font-weight:700}.timeline-verdict.ac{color:var(--ac);background:#22c55e1a}.timeline-verdict.wa{color:var(--wa);background:#ef44441a}.timeline-verdict.tle{color:var(--tle);background:#eab3081a}.timeline-verdict.re{color:var(--re);background:#f59e0b1a}.timeline-verdict.ce{color:var(--ce);background:#a8a29e1a}.timeline-verdict.mle{color:var(--mle);background:#3b82f61a}.timeline-platform{text-transform:uppercase;letter-spacing:.05em;border-radius:4px;padding:.1rem .4rem;font-size:.7rem;font-weight:700}.timeline-platform.cf{color:var(--cf);background:#3b82f61a}.timeline-platform.lc{color:var(--lc);background:#f59e0b1a}.timeline-platform.atcoder{color:var(--atcoder);background:#dc26261a}.goal-ring-widget{flex-direction:column;align-items:center;min-width:250px;padding:1.5rem;display:flex}.goal-ring-header{justify-content:space-between;align-items:center;width:100%;margin-bottom:1.5rem;display:flex}.goal-ring-title{color:var(--muted);letter-spacing:.05em;margin:0;font-size:.85rem;font-weight:700}.goal-ring-input-wrapper{color:var(--muted);align-items:center;gap:.5rem;font-size:.85rem;display:flex}.goal-ring-input{background:var(--bg-dark);border:1px solid var(--border);width:50px;color:var(--text);text-align:center;border-radius:4px;padding:.25rem;font-size:.9rem}.goal-ring-container{justify-content:center;align-items:center;display:flex;position:relative}.goal-svg{filter:drop-shadow(0 0 8px #00000080);transform:rotate(-90deg)}.goal-ring-track{stroke:var(--bg-dark)}.goal-ring-progress{stroke:var(--primary);transition:stroke-dashoffset 1s cubic-bezier(.4,0,.2,1)}.goal-ring-progress.met{stroke:var(--success);filter:drop-shadow(0 0 10px var(--success))}.goal-ring-content{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute}.goal-ring-count{color:var(--text);font-family:JetBrains Mono,monospace;font-size:2.5rem;font-weight:800;line-height:1}.goal-ring-label{color:var(--muted);margin-top:.25rem;font-size:.9rem;font-weight:600}.goal-ring-footer{text-align:center;margin-top:1.5rem}.goal-status{border-radius:12px;padding:.25rem .75rem;font-size:.9rem;font-weight:600}.goal-status.success{color:var(--success);background:#26a64133}.goal-status.pending{color:var(--muted)}.upsolving-widget{flex-direction:column;gap:1rem;display:flex}.upsolving-widget .widget-header{justify-content:space-between;align-items:center;display:flex}.upsolving-widget .widget-title{color:var(--text);margin:0;font-size:1.1rem;font-weight:600}.upsolving-widget .queue-count{background:var(--wa);color:#fff;border-radius:12px;padding:.2rem .6rem;font-size:.8rem;font-weight:600}.upsolving-list{flex-direction:column;gap:.75rem;display:flex}.upsolving-item{color:inherit;background:#ffffff08;border:1px solid #0000;border-radius:8px;justify-content:space-between;align-items:center;padding:.75rem 1rem;text-decoration:none;transition:background .2s,transform .2s;display:flex}.upsolving-item:hover{border-color:var(--wa);background:#ffffff14;transform:translateY(-1px)}.upsolving-item .item-left{align-items:center;gap:.75rem;display:flex}.upsolving-item .oj-badge{border-radius:4px;padding:.15rem .4rem;font-size:.65rem;font-weight:700}.upsolving-item .oj-cf{background:var(--cf);color:#000}.upsolving-item .oj-atcoder{background:var(--atcoder);color:#000}.upsolving-item .oj-lc{background:var(--lc);color:#000}.upsolving-item .problem-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:200px;font-size:.95rem;font-weight:500;overflow:hidden}.upsolving-item .item-right{align-items:center;gap:.75rem;display:flex}.upsolving-item .fail-count{color:var(--muted);background:#ffffff1a;border-radius:4px;padding:.2rem .5rem;font-size:.8rem}.srs-widget{flex-direction:column;gap:1rem;display:flex}.srs-widget .widget-header{justify-content:space-between;align-items:center;display:flex}.srs-widget .widget-title{color:var(--text);margin:0;font-size:1.1rem;font-weight:600}.srs-widget .queue-count{background:var(--ac);color:#fff;border-radius:12px;padding:.2rem .6rem;font-size:.8rem;font-weight:600}.srs-desc{color:var(--muted);margin-top:-.5rem;font-size:.85rem}.srs-list{flex-direction:column;gap:.75rem;display:flex}.srs-item{color:inherit;background:#ffffff08;border:1px solid #0000;border-radius:8px;justify-content:space-between;align-items:center;padding:.75rem 1rem;text-decoration:none;transition:background .2s,transform .2s;display:flex}.srs-item:hover{border-color:var(--ac);background:#ffffff14;transform:translateY(-1px)}.srs-item .item-left{align-items:center;gap:.75rem;display:flex}.srs-item .oj-badge{border-radius:4px;padding:.15rem .4rem;font-size:.65rem;font-weight:700}.srs-item .oj-cf{background:var(--cf);color:#000}.srs-item .oj-atcoder{background:var(--atcoder);color:#000}.srs-item .oj-lc{background:var(--lc);color:#000}.srs-item .problem-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:200px;font-size:.95rem;font-weight:500;overflow:hidden}.srs-item .item-right{align-items:center;display:flex}.srs-item .review-tag{color:var(--ac);background:#788c5d33;border-radius:4px;padding:.2rem .5rem;font-size:.8rem;font-weight:500}.empty-msg{color:var(--muted);text-align:center;padding:1rem 0;font-size:.9rem}.today-tab-container{flex-direction:column;gap:1.5rem;display:flex}.tab-actions{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.time-toggle{background:#0a0f1e99;border:1px solid #ffffff0a;border-radius:10px;padding:3px;display:flex}.toggle-btn{color:var(--muted);cursor:pointer;font-size:.75rem;font-weight:700;font-family:var(--font-family);letter-spacing:.01em;background:0 0;border:none;border-radius:8px;padding:.45rem 1.1rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.toggle-btn:hover{color:var(--text)}.toggle-btn.active{background:var(--accent);color:#fff;box-shadow:0 4px 12px #6366f14d}.action-buttons-row{align-items:center;gap:.75rem;display:flex}.refresh-btn,.manual-log-btn{color:var(--text);cursor:pointer;font-size:.75rem;font-weight:700;font-family:var(--font-family);background:#ffffff05;border:1px solid #ffffff0f;border-radius:10px;align-items:center;gap:.5rem;padding:.5rem 1.1rem;transition:all .2s;display:flex}.manual-log-btn{color:var(--accent);background:#6366f10f;border-color:#6366f133}.manual-log-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 4px 12px #6366f140}.refresh-btn:hover{background:#ffffff0f;border-color:#ffffff1f}.oj-stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.25rem;display:grid}.oj-card{background:var(--surface);border:1px solid var(--border);will-change:transform;border-radius:12px;flex-direction:column;padding:1.35rem 1.5rem;transition:transform .3s cubic-bezier(.4,0,.2,1),border-color .3s,box-shadow .3s,background .3s;display:flex;position:relative;overflow:hidden}.oj-card:hover{border-color:var(--border-hover);background:var(--surface-solid);box-shadow:var(--shadow-md);transform:translateY(-2px)}.oj-card.border-left-cf{border-left:3px solid var(--cf)}.oj-card.border-left-atcoder{border-left:3px solid var(--atcoder)}.oj-card.border-left-lc{border-left:3px solid var(--lc)}.text-cf{color:var(--cf)!important}.text-atcoder{color:var(--atcoder)!important}.text-lc{color:var(--lc)!important}.card-top{justify-content:space-between;align-items:center;display:flex}.card-oj-name{font-family:var(--font-display,"Outfit", sans-serif);color:var(--text);letter-spacing:.01em;font-size:.82rem;font-weight:800}.card-oj-handle{color:#9ca3afb3;font-size:.62rem;font-family:var(--font-mono);opacity:.8}.card-count{font-family:var(--font-display);color:var(--text);letter-spacing:-.02em;font-variant-numeric:tabular-nums;margin-top:.75rem;font-size:2.2rem;font-weight:500;line-height:1;transition:color .3s}.oj-card:hover .card-count{color:var(--accent)}.oj-card.border-left-cf:hover .card-count{color:var(--cf)}.oj-card.border-left-atcoder:hover .card-count{color:var(--atcoder)}.oj-card.border-left-lc:hover .card-count{color:var(--lc)}.card-error-text{color:var(--wa);margin-top:1.25rem;margin-bottom:.25rem;font-size:1rem;font-weight:700}.card-warning-indicator{vertical-align:middle;cursor:help;filter:drop-shadow(0 0 4px #eab30866);margin-left:.4rem;font-size:1.1rem}.card-lbl{color:var(--muted);letter-spacing:.02em;text-transform:uppercase;margin-top:.45rem;font-size:.62rem;font-weight:500}.card-secondary-lbl{color:var(--muted);text-transform:none;margin-top:.35rem;font-size:.8rem;font-weight:600}.time-range-highlight{color:var(--accent);font-weight:700}.oj-card--empty{cursor:pointer;opacity:.92;transition:opacity .2s ease, border-color .2s ease, transform .25s var(--ease-smooth);border-top:1px dashed #6366f14d;border-bottom:1px dashed #6366f14d;border-right:1px dashed #6366f14d}.oj-card--empty:hover{opacity:1;border-top-color:var(--accent);border-right-color:var(--accent);border-bottom-color:var(--accent);transform:translateY(-3px)}.oj-card--empty:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.card-count--add{color:var(--accent);font-size:1.6rem}.card-error-text--link{cursor:pointer;text-underline-offset:3px;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.today-charts-grid{grid-template-columns:1fr;gap:1.25rem;display:grid}@media (width>=1024px){.today-charts-grid{grid-template-columns:2.2fr 3.8fr}}.today-chart-box{flex-direction:column;padding:1.5rem;display:flex}.box-title{font-size:1.1rem;font-weight:500;font-family:var(--font-display);color:var(--text);letter-spacing:-.01em;align-items:center;gap:.5rem;margin-bottom:1.25rem;display:flex}.box-title:before{content:"";background:var(--accent);border-radius:2px;width:3px;height:12px;display:inline-block}.no-activity{color:var(--muted);text-align:center;margin:auto;font-size:.8rem;font-weight:500}.verdict-breakdown{flex-direction:column;gap:1.25rem;margin-top:.25rem;display:flex}.stacked-bar{background:#ffffff0a;border:1px solid #ffffff0a;border-radius:9999px;height:10px;display:flex;overflow:hidden}.bar-segment{height:100%;transition:width .4s cubic-bezier(.4,0,.2,1)}.verdict-legend-grid{grid-template-columns:repeat(2,1fr);gap:.5rem .75rem;display:grid}.legend-item{color:var(--text);align-items:center;padding:.25rem;font-size:.75rem;font-weight:500;display:flex}.legend-color-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px;margin-right:.5rem}.legend-name{margin-right:.35rem;font-weight:600}.legend-count{color:var(--muted);margin-right:.25rem}.legend-pct{color:var(--muted);font-size:.65rem;font-weight:400}.today-tags-box{flex-direction:column;padding:1.5rem;display:flex}.tag-chips-wrapper{flex-wrap:wrap;gap:.5rem;margin-top:.25rem;display:flex}.tag-chip{background:var(--surface-solid);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:999px;align-items:center;padding:.35rem .8rem;font-size:.75rem;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex}.tag-chip:hover{background:var(--surface);border-color:var(--accent);transform:translateY(-1px);box-shadow:0 2px 8px #6366f126}.tag-chip-name{font-weight:600}.tag-chip-count{color:var(--accent);background:#6366f11a;border-radius:999px;margin-left:.5rem;padding:.1rem .4rem;font-size:.65rem;font-weight:700;transition:all .2s}.tag-chip:hover .tag-chip-count{background:var(--accent);color:#fff}.modal-overlay{z-index:999;background:#030712d9;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-content{border-color:#ffffff14;flex-direction:column;gap:1.25rem;width:100%;max-width:580px;max-height:90vh;display:flex;overflow-y:auto;box-shadow:0 25px 50px -12px #000c,0 0 30px #6366f10d}.modal-header{border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding-bottom:.75rem;display:flex}.modal-title{color:var(--text);letter-spacing:-.02em;font-size:1.1rem;font-weight:800}.modal-close-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;font-size:1.5rem;line-height:1}.modal-close-btn:hover{color:var(--text)}.modal-form{flex-direction:column;gap:1rem;display:flex}.form-row{flex-wrap:wrap;gap:1rem;display:flex}.form-group{flex-direction:column;flex:1;gap:.35rem;min-width:200px;display:flex}.form-group.full-width{flex:0 0 100%}.form-group label{color:var(--muted);text-transform:uppercase;letter-spacing:.03em;font-size:.75rem;font-weight:700}.form-group input,.form-group select{color:var(--text);font-size:.85rem;font-family:var(--font-family);background:#0a0f1ecc;border:1px solid #ffffff0f;border-radius:8px;outline:none;padding:.55rem .75rem;transition:all .2s}.form-group input:focus,.form-group select:focus{border-color:var(--accent);box-shadow:0 0 0 2px #6366f126}.checkbox-label-header{margin-bottom:.25rem}.tag-checklist-grid{background:#0a0f1e80;border:1px solid #ffffff0a;border-radius:8px;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.5rem;max-height:160px;padding:.75rem;display:grid;overflow-y:auto}.tag-checkbox-item{color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.4rem;font-size:.75rem;font-weight:500;display:flex}.tag-checkbox-item input{min-width:unset;cursor:pointer;flex-shrink:0}.modal-actions{border-top:1px solid #ffffff0f;justify-content:flex-end;gap:.75rem;margin-top:.75rem;padding-top:1rem;display:flex}.modal-cancel-btn{color:var(--muted);cursor:pointer;font-size:.75rem;font-weight:600;font-family:var(--font-family);background:0 0;border:1px solid #ffffff0f;border-radius:8px;padding:.5rem 1rem;transition:all .2s}.modal-cancel-btn:hover{color:var(--text);background:#ffffff0a}.modal-submit-btn{background:var(--accent);border:1px solid var(--accent);color:#fff;cursor:pointer;font-size:.75rem;font-weight:700;font-family:var(--font-family);border-radius:8px;padding:.5rem 1rem;transition:all .2s;box-shadow:0 4px 12px #6366f140}.modal-submit-btn:hover{opacity:.9;transform:translateY(-1px)}.recent-submissions-box{flex-direction:column;gap:1.25rem;margin-top:.5rem;padding:1.75rem;display:flex}.recent-box-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;display:flex}.recent-box-subtitle{color:var(--muted);font-size:.7rem;font-weight:500}.recent-table-wrapper{background:#0a0f1e4d;border:1px solid #ffffff08;border-radius:12px;max-height:450px;overflow:auto}.recent-submissions-table{border-collapse:collapse;text-align:left;width:100%;font-size:.8rem}.recent-submissions-table th,.recent-submissions-table td{border-bottom:1px solid #ffffff05;padding:.85rem 1rem}.recent-submissions-table th{color:var(--muted);text-transform:uppercase;letter-spacing:.03em;z-index:10;background:#111827f2;border-bottom:1px solid #ffffff0a;font-size:.75rem;font-weight:700;position:sticky;top:0}.recent-row{transition:background .15s}.recent-row:hover{background:#ffffff04}.recent-time{color:var(--muted);white-space:nowrap;font-weight:500}.recent-prob-cell{font-weight:600}.recent-prob-link{color:var(--text);text-decoration:none;transition:color .15s}.recent-prob-link:hover{color:var(--accent);text-decoration:underline}.recent-prob-rating{color:var(--muted);margin-left:.4rem;font-size:.7rem;font-weight:500}.recent-tags-cell{max-width:280px}.recent-tags-list{flex-wrap:wrap;gap:.3rem;display:flex}.recent-tag-pill{color:var(--muted);white-space:nowrap;background:#ffffff08;border:1px solid #ffffff0d;border-radius:4px;padding:.15rem .4rem;font-size:.65rem;font-weight:500}.oj-badge{letter-spacing:.01em;border:1px solid #0000;border-radius:6px;justify-content:center;align-items:center;padding:.2rem .5rem;font-size:.7rem;font-weight:700;display:inline-flex}.oj-badge.oj-cf{color:var(--cf);background:#6a9bcc1a;border-color:#6a9bcc33}.oj-badge.oj-atcoder{color:var(--atcoder);background:#788c5d1a;border-color:#788c5d33}.oj-badge.oj-lc{color:var(--lc);background:#d977571a;border-color:#d9775733}.oj-badge.oj-codechef{color:#b89b72;background:#b89b721a;border-color:#b89b7233}.oj-badge.oj-hackerrank{color:#10b981;background:#10b98114;border-color:#10b98126}.oj-badge.oj-hackerearth{color:#3b82f6;background:#3b82f614;border-color:#3b82f626}.oj-badge.oj-vjudge{color:#8b5cf6;background:#8b5cf614;border-color:#8b5cf626}.daily-goal-wrapper{border-color:#ffffff0f;padding:1.25rem 1.5rem!important}.goal-header-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.75rem;display:flex}.goal-info{flex-direction:column;display:flex}.goal-title{color:var(--muted);letter-spacing:.05em;font-size:.7rem;font-weight:700}.goal-number{font-family:var(--font-display);color:var(--text);align-items:center;gap:.25rem;font-size:1.8rem;font-weight:800;line-height:1.2;display:flex}.goal-number.met{color:var(--ac)}.goal-slash{color:var(--muted);font-weight:500}.goal-stat-lbl{color:var(--muted);margin-left:.25rem;font-size:.75rem;font-weight:500}.goal-checked-badge{color:var(--ac);background:#10b98126;border:1px solid #10b9814d;border-radius:9999px;margin-left:.75rem;padding:.1rem .5rem;font-size:.65rem;font-weight:700}.goal-set-wrapper{align-items:center;gap:.5rem;display:flex}.goal-input-lbl{color:var(--muted);font-size:.75rem;font-weight:600}.goal-input-box{border:1px solid var(--border);color:var(--text);text-align:center;background:#0a0f1ecc;border-radius:6px;outline:none;width:55px;padding:.35rem .65rem;font-size:.8rem;font-weight:700}.goal-input-box:focus{border-color:var(--accent)}.goal-progress-bar-container{background:#ffffff0a;border-radius:9999px;width:100%;height:6px;overflow:hidden}.goal-progress-bar-fill{background:linear-gradient(90deg, var(--accent) 0%, #22d3ee 100%);border-radius:9999px;height:100%;transition:width .4s cubic-bezier(.22,1,.36,1)}.goal-progress-bar-fill.met{background:var(--ac)}.clickable-card{cursor:pointer}.clickable-card.filter-active{border-color:var(--accent-glow)!important;box-shadow:0 0 15px -3px var(--accent-glow)!important;background:#6366f112!important}.filter-badge{color:var(--accent);background:#6366f126;border:1px solid #6366f140;border-radius:4px;padding:.1rem .4rem;font-size:.55rem;font-weight:700}.section-title-today{color:var(--text);letter-spacing:.02em;text-transform:uppercase;margin-top:1rem;font-size:.85rem;font-weight:700}.section-subtitle-today{color:var(--muted);margin-top:-1.25rem;margin-bottom:.25rem;font-size:.7rem}.manual-tiles-grid{grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:1rem;display:grid}.manual-log-card{text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex;padding:1rem!important}.manual-oj-lbl{color:#d1d5db;font-size:.75rem;font-weight:700}.manual-solve-count{font-family:var(--font-display);margin-top:.35rem;margin-bottom:.15rem;font-size:1.8rem;font-weight:800;line-height:1}.manual-today-lbl{color:var(--muted);font-size:.58rem}.manual-btns-row{gap:.4rem;width:100%;margin-top:.65rem;display:flex}.manual-bump-btn{border:1px solid var(--border);color:var(--text);cursor:pointer;background:#ffffff08;border-radius:6px;outline:none;flex:1;padding:.25rem .5rem;font-size:.75rem;font-weight:700;transition:all .15s}.manual-bump-btn.inc{color:#a5b4fc;background:#6366f114;border-color:#6366f140}.manual-bump-btn.inc:hover{background:#6366f140}.manual-bump-btn.dec:hover:not(:disabled){color:var(--wa);background:#f43f5e26;border-color:#f43f5e4d}.manual-bump-btn:disabled{opacity:.25;cursor:not-allowed}.clear-filter-btn{color:#fca5a5;cursor:pointer;background:#f43f5e14;border:1px solid #f43f5e40;border-radius:6px;padding:.25rem .55rem;font-size:.65rem;font-weight:700;transition:all .2s}.clear-filter-btn:hover{background:#f43f5e33}.clickable-legend{cursor:pointer;border-radius:6px;transition:background-color .2s}.clickable-legend:hover{background:#ffffff08}.clickable-tag-chip{cursor:pointer;transition:all .2s}.clickable-tag-chip:hover{background:#6366f126!important;border-color:#6366f166!important;transform:translateY(-2px)!important}@media (width<=640px){.manual-tiles-grid{grid-template-columns:1fr 1fr}}.spin-animation{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.agenda-section{flex-direction:column;gap:1rem;display:flex}.scrollable-list{max-height:250px;padding-right:5px;overflow-y:auto}.scrollable-list::-webkit-scrollbar{width:4px}.scrollable-list::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}.learning-queue-row{grid-template-columns:1fr 1fr;gap:1.25rem;display:grid}@media (width<=1024px){.learning-queue-row{grid-template-columns:1fr}}.agenda-title{font-family:var(--font-display);color:var(--text);margin-top:1rem;font-size:1.5rem;font-weight:500}.agenda-subtitle{color:var(--muted);margin-top:-.2rem;font-size:.9rem}.activity-grid{grid-template-columns:2fr 1fr;gap:1.25rem;display:grid}.heatmap-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.25rem}.streak-card{display:flex}.streak-card>*{flex-grow:1}@media (width<=1024px){.activity-grid{grid-template-columns:1fr}}.progress-ring-container{flex-direction:column;justify-content:center;align-items:center;padding:.75rem;display:flex}.ring-wrapper{justify-content:center;align-items:center;width:80px;height:80px;display:flex;position:relative}.progress-ring{transform-origin:50%;transform:rotate(-90deg)}.progress-ring-bar{filter:drop-shadow(0 0 4px var(--accent-color));transition:stroke-dashoffset .85s cubic-bezier(.4,0,.2,1)}.ring-text{font-family:var(--font-family);justify-content:center;align-items:baseline;display:flex;position:absolute}.ring-solved{color:var(--text);font-size:1.1rem;font-weight:700}.ring-total{color:var(--muted);font-size:.75rem}.ring-label{text-align:center;flex-direction:column;align-items:center;margin-top:.5rem;display:flex}.ring-tier{color:var(--text);font-size:.8rem;font-weight:600}.ring-percent{color:var(--muted);margin-top:.1rem;font-size:.75rem}.error-card{background:#ef444408;border-color:#ef444440;align-items:flex-start;gap:1.25rem;display:flex}.error-icon{color:var(--wa);flex-shrink:0;margin-top:.1rem}.error-content{flex-direction:column;align-items:flex-start;display:flex}.error-title{color:var(--text);font-size:1rem;font-weight:600}.error-message{color:var(--muted);margin-top:.25rem;font-size:.85rem}.error-retry-btn{color:var(--accent);cursor:pointer;font-size:.8rem;font-weight:500;font-family:var(--font-family);background:#6366f11a;border:1px solid #6366f14d;border-radius:6px;margin-top:.75rem;padding:.35rem .85rem;transition:background .2s,border-color .2s,color .2s}.error-retry-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.skeleton-card{width:100%}.skeleton-heatmap-grid{grid-template-columns:repeat(13,1fr);gap:4px;margin-top:1rem;display:grid}.skeleton-heatmap-cell{aspect-ratio:1;border-radius:2px;width:100%;height:12px}.skeleton-ring-container{flex-direction:column;justify-content:center;align-items:center;padding:1rem;display:flex}.skeleton-ring-donut{background-color:#1e293b66;width:80px;height:80px}.smart-recommender-widget{background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.recommender-header{align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.recommender-title{font-family:var(--font-display);color:var(--text);margin:0;font-size:1.25rem;font-weight:500}.recommender-badge{color:#c4b5fd;background:#8b5cf626;border:1px solid #8b5cf64d;border-radius:12px;padding:.2rem .5rem;font-size:.75rem;font-weight:600}.recommender-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;display:grid}.recommendation-card{border:1px solid var(--border);background:#ffffff05;border-radius:8px;flex-direction:column;gap:.5rem;padding:1rem;transition:border-color .2s,transform .2s;display:flex}.recommendation-card:hover{border-color:#8b5cf6;transform:translateY(-2px)}.recommendation-target{text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-size:.75rem;font-weight:600}.recommendation-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:1rem;font-weight:500;overflow:hidden}.recommendation-rating{font-family:var(--font-mono);font-size:.85rem;font-weight:700;display:inline-block}.solve-btn{text-align:center;color:var(--text);background:#ffffff0d;border-radius:6px;margin-top:auto;padding:.5rem;font-size:.85rem;font-weight:600;text-decoration:none;transition:background .2s}.solve-btn:hover{color:#c4b5fd;background:#8b5cf633}.suggestions-tab-container{flex-direction:column;gap:1.5rem;display:flex}.progress-rings-grid{flex-direction:column;padding:1.5rem 1.75rem;display:flex}.section-title{color:var(--text);align-items:center;gap:.5rem;margin-bottom:1.25rem;font-size:.9rem;font-weight:700;display:flex}.rings-wrapper{grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:1.25rem;width:100%;display:grid}.ring-card{border:1px solid var(--border);cursor:pointer;background:var(--surface);box-shadow:var(--shadow-sm);border-radius:12px;transition:all .25s cubic-bezier(.4,0,.2,1)}.ring-card:hover{border-color:var(--border-hover);background:var(--surface-solid);box-shadow:var(--shadow-md);transform:translateY(-2px)}.ring-card.active{border-color:var(--accent);background:#d977570d;box-shadow:0 0 15px -3px #d9775726}.suggestions-main-grid{grid-template-columns:1fr;gap:1.25rem;display:grid}@media (width>=1024px){.suggestions-main-grid{grid-template-columns:1.35fr 2.65fr}}.suggestions-sidebar{flex-direction:column;gap:1.25rem;display:flex}.sidebar-box{flex-direction:column;padding:1.5rem;display:flex}.box-title{font-size:1.05rem;font-weight:500;font-family:var(--font-display);color:var(--text);border-bottom:1px solid var(--border);letter-spacing:-.01em;margin-bottom:1rem;padding-bottom:.65rem}.suggestions-list{flex-direction:column;gap:.75rem;display:flex}.suggestion-item{background:var(--surface);border:1px solid var(--border);border-radius:8px;justify-content:space-between;align-items:center;gap:.5rem;padding:.65rem .85rem;transition:all .2s;display:flex}.suggestion-item:hover{border-color:var(--border-hover);background:var(--surface-solid)}.sug-left{align-items:center;gap:.65rem;display:flex;overflow:hidden}.sug-tier{text-align:center;background:#ffffff0a;border-radius:4px;min-width:36px;padding:.15rem .4rem;font-size:.75rem;font-weight:800}.sug-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;font-weight:600;text-decoration:none;overflow:hidden}.sug-name:hover{color:var(--accent);text-decoration:underline}.sug-status-badge{text-transform:uppercase;letter-spacing:.03em;border-radius:4px;padding:.15rem .4rem;font-size:.65rem;font-weight:700}.sug-status-badge.status-attempted{color:var(--tle);background:#f59e0b14;border:1px solid #f59e0b33}.sug-status-badge.status-untouched{color:var(--muted);background:#ffffff0a;border:1px solid #ffffff0f}.weak-tags-headline{color:var(--muted);flex-wrap:wrap;align-items:center;gap:.35rem;margin-bottom:.25rem;font-size:.7rem;display:flex}.focus-tag-pill{color:var(--accent);background:#6366f11f;border-radius:4px;padding:.1rem .4rem;font-size:.65rem;font-weight:700}.sug-tag-match{color:var(--accent);white-space:nowrap;background:#6366f114;border:1px solid #6366f133;border-radius:4px;padding:.15rem .45rem;font-size:.65rem;font-weight:700}.empty-msg{color:var(--muted);text-align:center;margin:1rem 0;font-size:.8rem;font-weight:500}.suggestions-blend-lbl{color:var(--muted);margin-left:.4rem;font-size:.65rem;font-weight:500}.accordion-wrapper{flex-direction:column;padding:1.5rem;display:flex}.accordion-header-row{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.sync-status{color:var(--muted);font-size:.75rem;font-weight:500}.header-right-group{align-items:center;gap:.75rem;display:flex}.accordion-drilldown-btn{color:#a5b4fc;cursor:pointer;background:#6366f11a;border:1px solid #6366f140;border-radius:6px;padding:.2rem .55rem;font-size:.68rem;font-weight:700;transition:all .2s}.accordion-drilldown-btn:hover{background:#6366f140;border-color:#6366f166}.accordions-list{flex-direction:column;gap:.65rem;margin-top:.5rem;display:flex}.accordion-section{border:1px solid var(--border);background:var(--surface);border-radius:8px;transition:border-color .2s;overflow:hidden}.accordion-section.open{border-color:var(--accent)}.accordion-header{width:100%;color:var(--text);cursor:pointer;text-align:left;font-family:var(--font-family);background:#ffffff03;border:none;justify-content:space-between;align-items:center;padding:.95rem 1.25rem;transition:background .2s;display:flex}.accordion-header:hover{background:#ffffff08}.header-left{align-items:center;gap:.75rem;display:flex}.header-indicator{border-radius:50%;width:6px;height:6px}.header-title{font-size:.85rem;font-weight:700}.header-count{color:var(--muted);font-size:.75rem;font-weight:500}.accordion-chevron{color:var(--muted);transition:transform .25s cubic-bezier(.4,0,.2,1)}.accordion-chevron.rotated{color:var(--text);transform:rotate(180deg)}.accordion-content{background:#03071266;border-top:1px solid #ffffff0a;max-height:400px;padding:.5rem;overflow-y:auto}.problems-table-list{flex-direction:column;display:flex}.problem-row{border-bottom:1px solid #ffffff05;grid-template-columns:32px 105px 1.5fr 65px 2.2fr;align-items:center;gap:.75rem;padding:.65rem .85rem;transition:background .15s;display:grid}.problem-row:hover{background:#ffffff04}.problem-row:last-child{border-bottom:none}.prob-col{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.col-idx{color:var(--muted);font-size:.75rem;font-weight:600}.col-status{align-items:center;gap:.35rem;font-size:.72rem;font-weight:600;display:flex}.status-icon{font-size:.8rem}.status-icon-solved{color:var(--ac)}.status-icon-attempted{color:var(--tle)}.status-icon-untouched{color:var(--muted)}.status-text-full{text-transform:capitalize}.status-solved .status-text-full{color:var(--ac)}.status-attempted .status-text-full{color:var(--tle)}.status-untouched .status-text-full{color:var(--muted);font-weight:400}.prob-link-title{color:var(--text);font-size:.8rem;font-weight:600;text-decoration:none;transition:color .15s}.prob-link-title:hover{color:var(--accent)}.prob-title-no-link{color:var(--muted);font-size:.8rem;font-weight:500}.col-rating{font-size:.75rem;font-weight:700}.rating-badge{color:#a5b4fc;background:#ffffff08;border:1px solid #ffffff0d;border-radius:4px;padding:.15rem .4rem}.col-tags{flex-wrap:wrap;gap:.25rem;display:flex;overflow:hidden}.prob-mini-tag{color:var(--muted);background:#ffffff05;border:1px solid #ffffff0a;border-radius:4px;padding:.05rem .35rem;font-size:.65rem;font-weight:500}@media (width<=768px){.problem-row{grid-template-columns:24px 32px 1.5fr 50px;gap:.5rem;padding:.55rem .65rem}.col-tags,.status-text-full{display:none}}.verdict-badge{text-transform:uppercase;letter-spacing:.05em;font-size:.7rem;font-weight:700;font-family:var(--font-family);border:1px solid #0000;border-radius:4px;justify-content:center;align-items:center;padding:.15rem .4rem;display:inline-flex}.verdict-ac{color:var(--ac);background-color:#22c55e1f;border-color:#22c55e40}.verdict-wa{color:var(--wa);background-color:#ef44441f;border-color:#ef444440}.verdict-tle{color:var(--tle);background-color:#f973161f;border-color:#f9731640}.verdict-ce{color:var(--ce);background-color:#eab3081f;border-color:#eab30840}.verdict-re{color:var(--re);background-color:#a855f71f;border-color:#a855f740}.verdict-mle{color:var(--mle);background-color:#3b82f61f;border-color:#3b82f640}.verdict-other{color:var(--muted);background-color:#6b72801f;border-color:#6b728040}.analysis-tab-container{flex-direction:column;gap:2rem;display:flex}.analysis-header-controls{display:flex}.analysis-view-select{background:var(--surface);border:1px solid var(--border);color:var(--text);font-family:var(--font-family);cursor:pointer;appearance:none;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%239ca3af%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E);background-position:right 1rem top 50%;background-repeat:no-repeat;background-size:.65rem;border-radius:8px;outline:none;min-width:280px;padding:.75rem 1.25rem;font-size:.95rem;font-weight:600;transition:all .2s}.analysis-view-select:hover{border-color:var(--accent)}.analysis-view-select:focus{border-color:var(--accent);box-shadow:0 0 0 2px #6366f126}.analysis-section{flex-direction:column;gap:1rem;display:flex}.section-header{flex-direction:column;display:flex}.section-title{font-size:1.05rem;font-family:var(--font-display);color:var(--text);align-items:center;gap:.5rem;font-weight:500;display:flex}.section-title:before{content:"";background:var(--accent);border-radius:2px;width:3px;height:12px;display:inline-block}.stuck-meta-stats{color:var(--muted);flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:1rem;font-size:.8rem;font-weight:500;display:flex}.meta-dot{color:#fff3;margin:0 .2rem}.stuck-expected-complexity{text-align:center;color:var(--muted);padding:2.5rem;font-size:.85rem;font-weight:500}.section-subtitle{color:var(--muted);margin-top:.15rem;font-size:.75rem;font-weight:500}.empty-analysis{text-align:center;color:var(--muted);padding:2.5rem;font-size:.85rem;font-weight:500}.stuck-problems-list{flex-direction:column;gap:1.25rem;display:flex}.stuck-problem-card{border:1px solid var(--border);border-left:4px solid var(--wa);background:var(--surface);border-radius:8px;flex-direction:column;gap:1.25rem;padding:1.5rem 1.75rem;display:flex}.stuck-header{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.stuck-title-box{flex-wrap:wrap;align-items:center;gap:.65rem;display:flex}.oj-tag{color:var(--accent);letter-spacing:.05em;background:#6366f11f;border:1px solid #6366f133;border-radius:4px;padding:.15rem .45rem;font-size:.65rem;font-weight:800}.oj-tag.mini{padding:.1rem .35rem;font-size:.6rem}.stuck-name{color:var(--text);font-size:.95rem;font-weight:700;text-decoration:none;transition:color .15s}.stuck-name:hover{color:var(--accent)}.stuck-rating{color:var(--muted);font-size:.8rem;font-family:var(--font-mono)}.fail-badge{color:var(--wa);white-space:nowrap;text-transform:uppercase;letter-spacing:.03em;background:#f43f5e14;border:1px solid #f43f5e33;border-radius:6px;padding:.2rem .6rem;font-size:.7rem;font-weight:700}.verdict-sequence-row{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.sequence-label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:600}.badge-sequence{flex-wrap:wrap;align-items:center;gap:.35rem;display:flex}.seq-arrow{color:#ffffff1a;font-size:.75rem;font-weight:700}.pattern-hint-box{background:#0a0f1e73;border:1px solid #ffffff08;border-radius:10px;gap:.6rem;padding:.75rem 1rem;font-size:.8rem;line-height:1.5;display:flex}.hint-label{color:var(--tle);flex-shrink:0;font-weight:700}.hint-text{color:var(--text);font-weight:500}.stuck-actions{gap:.75rem;margin-top:.25rem;display:flex}.stuck-btn{cursor:pointer;font-size:.75rem;font-weight:700;font-family:var(--font-family);border-radius:8px;justify-content:center;align-items:center;padding:.45rem 1rem;text-decoration:none;transition:all .2s;display:inline-flex}.try-again-btn{background:var(--accent);color:#fff;border:1px solid var(--accent);box-shadow:0 4px 12px #6366f140}.try-again-btn:hover{opacity:.9;transform:translateY(-1px)}.editorial-btn{color:var(--muted);background:#ffffff05;border:1px solid #ffffff0f}.editorial-btn:hover{color:var(--text);background:#ffffff0d;border-color:#ffffff26}.struggled-problems-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem;display:grid}.struggled-problem-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:.85rem;padding:1rem;display:flex}.struggled-problem-card:hover{border-color:var(--border-hover);background:var(--surface-solid)}.struggled-header{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.struggled-title-box{align-items:center;gap:.5rem;display:flex;overflow:hidden}.struggled-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:700;text-decoration:none;overflow:hidden}.struggled-name:hover{color:var(--accent)}.struggled-rating{color:var(--muted);font-size:.75rem;font-family:var(--font-mono);flex-shrink:0}.struggled-stats{background:#0003;border:1px solid #ffffff05;border-radius:8px;grid-template-columns:1fr 1fr;gap:.5rem;padding:.6rem;display:grid}.s-stat{flex-direction:column;display:flex}.s-stat-lbl{color:var(--muted);font-size:.65rem;font-weight:500}.s-stat-val{margin-top:.15rem;font-size:.75rem;font-weight:700}.text-wa{color:var(--wa)}.text-ac{color:var(--ac)}.struggled-history{align-items:center;gap:.25rem;margin-top:.1rem;display:flex}.mini-verdict-indicator{width:18px;height:18px;color:var(--wa);font-size:.6rem;font-weight:800;font-family:var(--font-mono);background:#f43f5e14;border:1px solid #f43f5e26;border-radius:4px;justify-content:center;align-items:center;display:inline-flex}.mini-verdict-indicator.solved{color:var(--ac);background:#10b98114;border:1px solid #10b98126;width:24px}.mini-verdict-more{color:var(--muted);font-size:.65rem;font-weight:600}.mini-verdict-arrow{color:#ffffff1a;margin:0 .15rem;font-size:.75rem}.cheat-sheet-card{padding:0;overflow:hidden}.cheat-sheet-table{border-collapse:collapse;text-align:left;width:100%;font-size:.85rem}.cheat-sheet-table th{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;background:#ffffff08;border-bottom:1px solid #ffffff0f;padding:1rem 1.25rem;font-size:.75rem;font-weight:700}.cheat-sheet-table td{border-bottom:1px solid #ffffff08;padding:1rem 1.25rem}.cheat-sheet-table tr:last-child td{border-bottom:none}.cheat-sheet-table tr:hover td{background:#ffffff04}.cheat-mono{font-family:var(--font-mono);font-weight:600}.text-cyan{color:#22d3ee}.cheat-desc{color:var(--text);opacity:.9;line-height:1.4}.strengths-tab-container{flex-direction:column;gap:1.5rem;display:flex}.tag-summary-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.25rem;display:grid}.summary-card{border-top:3px solid var(--border);flex-direction:column;padding:1.5rem 1.75rem;display:flex}.summary-card.border-ac{border-top-color:var(--ac)}.summary-card.border-wa{border-top-color:var(--wa)}.summary-card-title{margin-bottom:.25rem;font-size:.95rem;font-weight:700}.summary-card-desc{color:var(--muted);margin-bottom:1.25rem;font-size:.75rem;font-weight:500}.summary-pills-list{flex-direction:column;gap:.5rem;display:flex}.summary-pill{color:var(--text);border:1px solid #0000;border-radius:8px;justify-content:space-between;align-items:center;padding:.45rem .85rem;font-size:.8rem;font-weight:600;display:flex}.summary-pill.bg-ac{background:#10b98114;border-color:#10b98126}.summary-pill.bg-wa{background:#f43f5e14;border-color:#f43f5e26}.pill-name{font-weight:700}.pill-val{font-size:.75rem}.summary-untouched-list{flex-wrap:wrap;gap:.35rem;display:flex}.untouched-pill{color:var(--muted);background:#ffffff05;border:1px solid #ffffff0d;border-radius:6px;padding:.2rem .5rem;font-size:.7rem;font-weight:500}.untouched-more{color:var(--muted);padding:.2rem .3rem;font-size:.7rem;font-weight:500}.empty-summary-msg{color:var(--muted);margin:auto 0;font-size:.8rem;font-weight:500}.tag-performance-grid{grid-template-columns:1fr;gap:1.25rem;display:grid}@media (width>=1024px){.tag-performance-grid{grid-template-columns:2.2fr 1.8fr}}.table-box{flex-direction:column;padding:1.5rem;display:flex}.table-wrapper{margin-top:.5rem;overflow-x:auto}.performance-table{border-collapse:collapse;text-align:left;width:100%;font-size:.8rem}.performance-table th,.performance-table td{border-bottom:1px solid #ffffff05;padding:.75rem .85rem}.performance-table th{color:var(--muted);-webkit-user-select:none;user-select:none;border-bottom:1px solid #ffffff0d;font-weight:700}.performance-table th.sortable{cursor:pointer;transition:color .15s}.performance-table th.sortable:hover{color:var(--text)}.performance-table tr{transition:background .15s}.performance-table tbody tr:hover{background:#ffffff03}.row-untouched{opacity:.35}.cell-name{color:var(--text);font-weight:600}.font-bold{font-weight:700}.chart-box{flex-direction:column;padding:1.5rem;display:flex}.ratio-bars-list{flex-direction:column;gap:.95rem;margin-top:.5rem;display:flex}.ratio-row{flex-direction:column;gap:.3rem;display:flex}.ratio-row-labels{justify-content:space-between;font-size:.75rem;font-weight:500;display:flex}.ratio-tag-name{color:var(--text);font-weight:700}.ratio-attempts{color:var(--muted)}.ratio-bar-wrapper{color:#fff;text-align:center;background:#ffffff08;border:1px solid #ffffff05;border-radius:6px;height:18px;font-size:9px;font-weight:800;line-height:18px;display:flex;overflow:hidden}.ratio-bar-ac{background-color:var(--ac);white-space:nowrap;transition:width .4s cubic-bezier(.4,0,.2,1);overflow:hidden;box-shadow:inset 0 1px #ffffff26}.ratio-bar-wa{background-color:var(--wa);white-space:nowrap;transition:width .4s cubic-bezier(.4,0,.2,1);overflow:hidden;box-shadow:inset 0 1px #ffffff26}.no-ratio-data{color:var(--muted);text-align:center;margin:2rem 0;font-size:.8rem;font-weight:500}.row-clickable{cursor:pointer;-webkit-user-select:none;user-select:none}.row-clickable:hover{background:#ffffff05!important}.row-expanded{border-left:2px solid var(--accent);background:#6366f10a!important}.tag-name-cell{align-items:center;gap:.5rem;display:flex}.expand-icon{color:var(--muted);font-size:.55rem;transition:transform .2s cubic-bezier(.4,0,.2,1);display:inline-block}.expand-icon.expanded{color:var(--accent);transform:rotate(90deg)}.detail-row,.detail-row:hover{background:#0a0f1e33!important}.detail-cell{border-bottom:1px solid #ffffff0a!important;padding:0!important}.detail-problems-container{margin:.75rem 1rem 1rem 1.75rem;animation:.25s cubic-bezier(.16,1,.3,1) slideDown;box-shadow:0 10px 25px -5px #00000080,inset 0 0 12px #6366f105;background:#11182773!important;border-color:#6366f126!important;padding:1.25rem!important}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.detail-header{border-bottom:1px solid #ffffff0a;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.5rem;display:flex}.detail-title{color:var(--text);letter-spacing:-.01em;font-size:.85rem;font-weight:700}.detail-subtitle{color:var(--muted);font-size:.65rem;font-weight:500}.detail-table-wrapper{background:#0a0f1e40;border:1px solid #ffffff05;border-radius:8px;overflow-x:auto}.detail-problems-table{border-collapse:collapse;text-align:left;width:100%;font-size:.75rem}.detail-problems-table th,.detail-problems-table td{border-bottom:1px solid #ffffff03;padding:.65rem .85rem}.detail-problems-table th{color:var(--muted);text-transform:uppercase;letter-spacing:.03em;background:#0a0f1e66;border-bottom:1px solid #ffffff08;font-size:.7rem;font-weight:700}.detail-prob-solved{background:#10b98101}.detail-prob-unsolved{background:#f43f5e01}.detail-prob-link{color:var(--text);font-weight:600;text-decoration:none;transition:color .15s}.detail-prob-link:hover{color:var(--accent);text-decoration:underline}.detail-prob-name-no-link{color:var(--text);font-weight:600}.detail-prob-rating-cell{font-family:var(--font-mono);font-size:.7rem}.status-badge{border:1px solid #0000;border-radius:6px;justify-content:center;align-items:center;padding:.15rem .45rem;font-size:.65rem;font-weight:700;display:inline-flex}.status-badge.ac{color:var(--ac);background:#10b98114;border-color:#10b98126}.status-badge.wa{color:var(--tle);background:#f59e0b14;border-color:#f59e0b26}.history-sequence{flex-wrap:wrap;align-items:center;gap:.35rem;display:flex}.history-verdict-dot{color:#fff;text-shadow:0 1px 1px #0003;border:1px solid #0000;border-radius:4px;justify-content:center;align-items:center;width:26px;height:18px;font-size:.6rem;font-weight:800;display:inline-flex}.history-verdict-dot.verdict-ac{background:var(--ac);border-color:#10b9814d}.history-verdict-dot.verdict-wa{background:var(--wa);border-color:#f43f5e4d}.history-verdict-dot.verdict-tle{background:var(--tle);border-color:#f59e0b4d}.history-verdict-dot.verdict-ce{background:var(--ce);color:#000;text-shadow:none;border-color:#eab3084d}.history-verdict-dot.verdict-re{background:var(--re);border-color:#a855f74d}.history-verdict-dot.verdict-mle{background:var(--mle);border-color:#3b82f64d}.history-arrow{color:var(--muted);font-size:.65rem;font-weight:700}.matrix-section{flex-direction:column;display:flex;padding:1.5rem!important}.matrix-table-wrapper{border:1px solid var(--border);background:var(--surface);border-radius:12px;margin-top:1rem;overflow-x:auto}.matrix-table{border-collapse:collapse;text-align:center;width:100%;font-size:.8rem}.matrix-table th,.matrix-table td{border:1px solid var(--border);white-space:nowrap;padding:.8rem 1rem}.matrix-table th{background:var(--surface-solid);color:var(--muted);text-transform:uppercase;font-size:.75rem;font-weight:700}.matrix-table th.sticky-col,.matrix-table td.sticky-col{z-index:5;border-right:2px solid var(--border);position:sticky;left:0}.matrix-table th.sticky-col{background:var(--surface-solid)}.matrix-table td.sticky-col{background:var(--surface)}.matrix-rating-lbl{font-family:var(--font-display);color:var(--text);text-align:left;font-size:.85rem;font-weight:800}.matrix-cell{transition:all .2s}.matrix-cell.clickable-cell{cursor:pointer}.matrix-cell.clickable-cell:hover{filter:brightness(1.2)contrast(1.1);box-shadow:inset 0 0 10px #ffffff1a}.matrix-cell-content{font-family:var(--font-mono);justify-content:center;align-items:center;gap:2px;font-size:.8rem;display:flex}.solved-cnt{color:#fff;font-weight:700}.matrix-sep{color:#ffffff4d}.attempted-cnt{color:var(--muted)}.matrix-cell-empty{color:#ffffff26;font-family:var(--font-mono)}.matrix-cell-untouched{font-family:var(--font-mono);color:var(--muted);background:#ffffff08;border:1px solid #ffffff0d;border-radius:4px;padding:.1rem .35rem;font-size:.65rem}.clickable-pill{cursor:pointer;transition:all .2s}.clickable-pill:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 4px 12px #0003}.clickable-untouched{cursor:pointer;transition:all .2s}.clickable-untouched:hover{color:var(--accent)!important;background:#6366f11a!important;border-color:#6366f140!important}.clickable-ratio-row{cursor:pointer;border-radius:8px;padding:.35rem .5rem;transition:background-color .15s}.clickable-ratio-row:hover{background:#ffffff05}.sheets-tab-container{flex-direction:column;gap:1.5rem;display:flex}.sheets-header{flex-direction:column;gap:1.5rem;display:flex;padding:1.5rem!important}.selector-row{flex-direction:column;gap:.5rem;display:flex}.sheet-select-label{text-transform:uppercase;color:var(--muted);letter-spacing:.05em;font-size:.75rem;font-weight:700}.sheet-dropdown{border:1px solid var(--border);color:var(--text);cursor:pointer;background:#0a0f1eb3;border-radius:8px;outline:none;width:100%;max-width:400px;padding:.65rem 1rem;font-size:.9rem;font-weight:600;transition:border-color .2s}.sheet-dropdown:focus{border-color:var(--accent)}.sheet-progress-row{flex-wrap:wrap;align-items:center;gap:1.5rem;display:flex}.progress-text-col{flex-direction:column;display:flex}.progress-percentage{font-family:var(--font-display);color:var(--ac);font-size:2.25rem;font-weight:800;line-height:1}.progress-fraction{color:var(--muted);margin-top:.25rem;font-size:.75rem}.sheet-progress-bar-wrapper{background:#ffffff0d;border-radius:9999px;flex:1;min-width:250px;height:8px;overflow:hidden}.sheet-progress-bar-fill{background:linear-gradient(90deg, var(--accent) 0%, var(--ac) 100%);border-radius:9999px;height:100%;transition:width .5s ease-in-out}.sheets-accordions-wrapper{flex-direction:column;gap:1rem;display:flex}.sheet-accordion-section{transition:border-color .2s;overflow:hidden;border:1px solid var(--border)!important;padding:0!important}.sheet-accordion-section.open{border-color:#6366f133!important}.section-head-row{cursor:pointer;-webkit-user-select:none;user-select:none;background:#11182733;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;transition:background-color .2s;display:flex}.section-head-row:hover{background:#11182773}.section-head-left{align-items:center;gap:.75rem;display:flex}.chevron-arrow{color:var(--muted);font-size:.7rem;transition:transform .25s}.chevron-arrow.rotated{transform:rotate(90deg)}.section-head-title{color:var(--text);font-size:1rem;font-weight:700}.section-head-right{align-items:center;gap:1rem;display:flex}.sheet-drilldown-trigger-btn{color:#a5b4fc;cursor:pointer;background:#6366f11a;border:1px solid #6366f140;border-radius:6px;padding:.3rem .75rem;font-size:.75rem;font-weight:600;transition:all .2s}.sheet-drilldown-trigger-btn:hover{background:#6366f133;border-color:#6366f166}.mini-progress-bar{background:#ffffff0d;border-radius:4px;width:80px;height:6px;overflow:hidden}.mini-progress-bar-fill{background:var(--ac);border-radius:4px;height:100%}.section-body-table-wrapper{border-top:1px solid var(--border);background:#03071233;overflow-x:auto}.sheet-problems-table{border-collapse:collapse;text-align:left;width:100%;font-size:.85rem}.sheet-problems-table th{color:var(--muted);border-bottom:1px solid var(--border);background:#1118274d;padding:.75rem 1.25rem;font-weight:600}.sheet-problems-table td{vertical-align:middle;border-bottom:1px solid #ffffff08;padding:.75rem 1.25rem}.sheet-problems-table tr.row-solved{background:#10b98104}.sheet-problems-table tr:hover{background:#ffffff04}.checkbox-cell{text-align:center}.sheet-prob-checkbox{width:16px;height:16px;accent-color:var(--ac);cursor:pointer}.prob-name-cell{font-weight:600}.sheet-prob-link{color:#e0e7ff;align-items:center;gap:4px;text-decoration:none;transition:color .2s;display:inline-flex}.sheet-prob-link:hover{color:var(--accent)}.sheet-prob-link .arrow-icon{opacity:.5;font-size:.7rem}.sheet-prob-name-text{color:var(--text)}.difficulty-cell{text-transform:capitalize}.diff-lbl{font-size:.7rem;font-weight:700}.diff-lbl.easy{color:var(--ac)}.diff-lbl.medium{color:var(--tle)}.diff-lbl.hard{color:var(--wa)}.sync-status-badge{border-radius:4px;padding:.1rem .4rem;font-size:.7rem;font-weight:700;display:inline-block}.sync-status-badge.auto{color:var(--ac);background:#10b9811a}.sync-status-badge.manual{color:#a5b4fc;background:#6366f11a}.sync-status-badge.pending{color:var(--muted);font-weight:500}.drilldown-modal-content{flex-direction:column;width:90%;max-width:850px;max-height:85vh;display:flex;border:1px solid var(--border)!important;background:var(--bg)!important;padding:1.5rem!important;box-shadow:0 25px 50px -12px #000c,0 0 25px #6366f11a!important}.drilldown-modal-content .modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;display:flex}.drilldown-modal-content .modal-title{font-family:var(--font-display);color:var(--text);font-size:1.25rem;font-weight:600}.problems-count-badge{color:#a5b4fc;background:#6366f126;border:1px solid #6366f14d;border-radius:9999px;margin-left:auto;margin-right:1.5rem;padding:.2rem .6rem;font-size:.75rem;font-weight:600}.drilldown-modal-content .modal-close-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;font-size:1.75rem;line-height:1;transition:color .2s}.drilldown-modal-content .modal-close-btn:hover{color:var(--wa)}.drilldown-table-wrapper{-webkit-overflow-scrolling:touch;border:1px solid var(--border);background:var(--surface);border-radius:8px;flex:1;overflow:auto}.no-drilldown-problems{text-align:center;color:var(--muted);padding:3rem;font-size:.9rem}.drilldown-table{border-collapse:collapse;text-align:left;width:100%;font-size:.85rem}.drilldown-table th{background:var(--surface-solid);color:var(--muted);border-bottom:1px solid var(--border);z-index:10;padding:.85rem 1rem;font-weight:600;position:sticky;top:0}.drilldown-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:.85rem 1rem}.drilldown-row{transition:background-color .2s}.drilldown-row:hover{background:#ffffff05}.drilldown-prob-cell{max-width:250px;font-weight:500}.drilldown-prob-link{color:#e0e7ff;align-items:center;gap:4px;text-decoration:none;transition:color .2s;display:inline-flex}.drilldown-prob-link:hover{color:var(--accent)}.drilldown-prob-link .arrow-icon{opacity:.6;font-size:.7rem}.drilldown-prob-text{color:var(--text)}.drilldown-rating-cell{font-family:var(--font-mono);color:#fcd34d}.status-badge{border-radius:4px;padding:.15rem .5rem;font-size:.75rem;font-weight:600;display:inline-block}.status-badge.solved{color:var(--ac);background:#10b9811a;border:1px solid #10b98133}.status-badge.attempted{color:var(--tle);background:#f59e0b1a;border:1px solid #f59e0b33}.status-badge.untouched{color:var(--muted);background:#ffffff0d;border:1px solid #ffffff1a}.drilldown-history-cell{max-width:250px}.drilldown-history-seq{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.drilldown-seq-arrow{color:#ffffff26;font-size:.75rem}.settings-panel-content{width:100%;max-width:460px}.settings-intro{color:#9aa4b2;margin:0 0 1.25rem;font-size:.85rem;line-height:1.5}.settings-intro strong{color:#cbd5e1}.settings-form{flex-direction:column;gap:1.1rem;display:flex}.settings-field{flex-direction:column;gap:.35rem;display:flex}.settings-label{color:#e5e7eb;letter-spacing:.02em;font-size:.8rem;font-weight:600}.settings-input{color:#f9fafb;background:#ffffff0a;border:1px solid #ffffff1f;border-radius:10px;outline:none;padding:.6rem .8rem;font-family:inherit;font-size:.9rem;transition:border-color .15s,box-shadow .15s,background .15s}.settings-input::placeholder{color:#5b6472}.settings-input:focus{background:#6366f10f;border-color:#6366f1;box-shadow:0 0 0 3px #6366f12e}.settings-hint{color:#6b7280;font-size:.7rem}.settings-actions{justify-content:flex-end;gap:.6rem;margin-top:.5rem;display:flex}.settings-btn-secondary,.settings-btn-primary{cursor:pointer;border:1px solid #0000;border-radius:10px;padding:.55rem 1.1rem;font-family:inherit;font-size:.85rem;font-weight:600;transition:transform .12s,filter .15s,background .15s}.settings-btn-secondary{color:#cbd5e1;background:0 0;border-color:#ffffff24}.settings-btn-secondary:hover{background:#ffffff0d}.settings-btn-primary{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6)}.settings-btn-primary:hover{filter:brightness(1.08);transform:translateY(-1px)}.settings-btn-primary:active,.settings-btn-secondary:active{transform:translateY(0)}.error-boundary-screen{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.error-boundary-box{width:100%;max-width:600px}.leaderboard-widget{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.5rem}.leaderboard-title{font-family:var(--font-display);color:var(--text);margin-bottom:1rem;font-size:1.25rem;font-weight:500}.leaderboard-list{flex-direction:column;gap:.75rem;display:flex}.leaderboard-item{background:#ffffff05;border-radius:8px;justify-content:space-between;align-items:center;padding:.75rem 1rem;transition:background .2s;display:flex}.leaderboard-item:hover{background:#ffffff0d}.leaderboard-left{align-items:center;gap:1rem;display:flex}.leaderboard-rank{color:var(--muted);width:1.5rem;font-size:1.2rem;font-weight:700}.leaderboard-item:first-child .leaderboard-rank{color:#fbbf24}.leaderboard-item:nth-child(2) .leaderboard-rank{color:#9ca3af}.leaderboard-item:nth-child(3) .leaderboard-rank{color:#b45309}.leaderboard-handle{flex-direction:column;display:flex}.leaderboard-name{font-size:1.05rem;font-weight:600;text-decoration:none}.leaderboard-title-label{color:var(--muted);text-transform:capitalize;font-size:.8rem}.leaderboard-right{flex-direction:column;align-items:flex-end;display:flex}.leaderboard-rating{font-family:var(--font-mono);font-size:1.1rem;font-weight:700}.leaderboard-empty{color:var(--muted);text-align:center;padding:1rem 0;font-style:italic}.leaderboard-tab-container{flex-direction:column;gap:1.5rem;display:flex}.leaderboard-tab-header{margin-bottom:1rem}.leaderboard-tab-header h2{font-family:var(--font-display);color:var(--text);font-size:1.5rem;font-weight:600}.leaderboard-tab-header p{color:var(--muted);margin-top:.25rem;font-size:.95rem}.welcome-screen-overlay{background-color:var(--color-background);background-image:radial-gradient(circle at 50% 50%, #1e1e1ccc 0%, var(--color-background) 100%);z-index:9999;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0;overflow:hidden}.welcome-blob{filter:blur(80px);z-index:1;opacity:.15;border-radius:50%;animation:15s ease-in-out infinite alternate blob-float;position:absolute}.blob-1{background:var(--color-accent);width:400px;height:400px;animation-delay:-5s;top:-100px;right:-100px}.blob-2{background:var(--color-ac);width:500px;height:500px;bottom:-150px;left:-150px}@keyframes blob-float{0%{transform:translate(0)scale(1)}33%{transform:translate(-50px,30px)scale(1.1)}66%{transform:translate(20px,-40px)scale(.9)}to{transform:translate(0)scale(1)}}.welcome-content{z-index:10;border:1px solid var(--color-border);width:100%;max-width:480px;padding:2.5rem;transition:transform .4s cubic-bezier(.16,1,.3,1),opacity .4s;position:relative;box-shadow:0 25px 50px -12px #00000080}.welcome-content.submitting{opacity:0;pointer-events:none;transform:translateY(-20px)scale(.98)}.welcome-header{text-align:center;margin-bottom:2rem}.welcome-logo-container{background:linear-gradient(135deg,#d9775733 0%,#788c5d33 100%);border:1px solid #ffffff1a;border-radius:16px;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 1.5rem;display:flex;box-shadow:0 8px 16px #0003}.welcome-logo{width:32px;height:32px;color:var(--color-text)}.welcome-title{background:linear-gradient(90deg,#fff,#b0aea5);-webkit-text-fill-color:transparent;letter-spacing:-.02em;-webkit-background-clip:text;margin-bottom:.75rem;font-size:1.75rem;font-weight:700}.welcome-subtitle{color:var(--color-muted);font-size:.95rem;line-height:1.5}.welcome-mute{opacity:.7;font-size:.85rem}.welcome-form{flex-direction:column;gap:1.25rem;display:flex}.welcome-field{opacity:0;flex-direction:column;gap:.4rem;animation:.5s forwards fade-slide-up;display:flex}@keyframes fade-slide-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.welcome-label{color:var(--color-text);margin-left:2px;font-size:.875rem;font-weight:500}.welcome-input{border:1px solid var(--color-border);width:100%;color:var(--color-text);background:#0003;border-radius:10px;padding:.85rem 1rem;font-family:inherit;font-size:1rem;transition:all .2s}.welcome-input:hover{background:#ffffff08;border-color:#ffffff26}.welcome-input:focus{border-color:var(--color-accent);background:#0000004d;outline:none;box-shadow:0 0 0 3px #d9775726}.welcome-hint{color:var(--color-muted);opacity:.8;margin-left:2px;font-size:.75rem}.welcome-actions{opacity:0;margin-top:1.5rem;animation:.5s .6s forwards fade-slide-up}.welcome-btn-primary{background:var(--color-text);width:100%;color:var(--color-background);cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:.5rem;padding:.85rem;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.welcome-btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 16px #ffffff1a}.welcome-btn-primary:active{transform:translateY(0)}.welcome-btn-primary.loading{cursor:wait;background:#ffffff80}.welcome-btn-icon{width:18px;height:18px;transition:transform .2s}.welcome-btn-primary:hover .welcome-btn-icon{transform:translate(3px)}@media (width<=480px){.welcome-content{border-radius:20px;padding:2rem 1.5rem}}.mastery-tab-container{max-width:1400px;margin:0 auto;padding:1.5rem}.mastery-header{margin-bottom:2rem}.mastery-title{background:linear-gradient(135deg,#fff 0%,#a5b4fc 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:.5rem;font-size:2rem;font-weight:700}.mastery-subtitle{color:var(--muted);margin-bottom:1.5rem;font-size:1rem}.mastery-legend{color:var(--text-secondary);gap:1.5rem;font-size:.85rem;display:flex}.legend-item{align-items:center;gap:.5rem;display:flex}.legend-box{border-radius:2px;width:12px;height:12px}.legend-box.none{background:#ffffff0d;border:1px solid #ffffff1a}.legend-box.failed{background:#ef444499}.legend-box.ac{background:#22c55ecc}.mastery-board{flex-direction:column;gap:1.5rem;display:flex}.mastery-row{align-items:flex-start;gap:1rem;display:flex}.mastery-row-label{cursor:pointer;border-right:1px solid #ffffff0d;flex-direction:column;flex:0 0 120px;gap:.25rem;padding-right:1rem;transition:all .2s;display:flex}.mastery-row-label:hover{transform:translate(2px)}.mastery-row-rating{color:#e2e8f0;font-size:1.1rem;font-weight:700}.mastery-row-stats{color:var(--muted);font-size:.75rem}.mastery-row-cells{flex-wrap:wrap;flex:1;gap:3px;display:flex}.mastery-cell{cursor:pointer;background:#ffffff0d;border:1px solid #ffffff08;border-radius:2px;width:14px;height:14px;transition:transform .1s,box-shadow .1s,filter .3s}.mastery-cell.ac{background:#22c55e99;border-color:#22c55ecc}.mastery-cell.failed{background:#ef444480;border-color:#ef4444b3}.mastery-cell:hover{z-index:10;border-color:#fff;transform:scale(1.4);box-shadow:0 0 10px #00000080}body.zen-mode .mastery-row-rating,body.zen-mode .mastery-row-stats{filter:blur(4px);opacity:.5;transition:filter .3s,opacity .3s}body.zen-mode .mastery-row-label:hover .mastery-row-rating,body.zen-mode .mastery-row-label:hover .mastery-row-stats{filter:blur();opacity:1}@media (width<=768px){.mastery-row{flex-direction:column;gap:.5rem}.mastery-row-label{border-bottom:1px solid #ffffff0d;border-right:none;flex-direction:row;flex:auto;justify-content:space-between;align-items:center;width:100%;padding-bottom:.5rem}}.anti-tilt-overlay{-webkit-backdrop-filter:blur(12px);z-index:10000;background:#000000d9;justify-content:center;align-items:center;width:100vw;height:100vh;padding:2rem;display:flex;position:fixed;top:0;left:0}.anti-tilt-card{text-align:center;background:linear-gradient(#1e1414f2 0%,#0f0a0af2 100%);border:1px solid #ef44444d;width:100%;max-width:500px;padding:3rem 2rem;box-shadow:0 20px 40px #00000080,inset 0 1px #ffffff0d}.anti-tilt-icon{margin-bottom:1rem;font-size:4rem;animation:2s ease-in-out infinite pulse-red}@keyframes pulse-red{0%{filter:drop-shadow(0 0 10px #ef444433);transform:scale(1)}50%{filter:drop-shadow(0 0 25px #ef444499);transform:scale(1.1)}to{filter:drop-shadow(0 0 10px #ef444433);transform:scale(1)}}.anti-tilt-title{color:#ef4444;letter-spacing:-.02em;margin-bottom:1rem;font-size:1.8rem;font-weight:700}.anti-tilt-desc{color:var(--text);margin-bottom:2rem;font-size:1.1rem;line-height:1.6}.anti-tilt-desc strong{color:#fff;font-weight:600}.anti-tilt-timer{font-variant-numeric:tabular-nums;color:#fff;text-shadow:0 0 20px #fff3;margin-bottom:2rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:4.5rem;font-weight:800}.anti-tilt-hint{color:var(--muted);max-width:80%;margin:0 auto;font-size:.95rem;font-style:italic}.app-container{background-color:var(--bg);min-height:100vh;display:flex}.main-content-area{flex-direction:column;flex-grow:1;width:100%;max-width:1400px;margin:0 auto;padding:1.5rem 2rem;display:flex}@media (width<=768px){.app-container{flex-direction:column}.main-content-area{padding:1rem}}.tab-main-content{width:100%;animation:.35s cubic-bezier(.4,0,.2,1) tab-fade-in}@keyframes tab-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.app-container.loading-state{justify-content:flex-start}.skeleton-card-header{flex-direction:column;justify-content:center;width:100%;height:110px;display:flex}.skeleton-bar-wrapper{width:100%;padding:.5rem}.skeleton-content-grid{grid-template-columns:1fr;gap:1.5rem;display:grid}@media (width>=768px){.skeleton-content-grid{grid-template-columns:1fr 1fr}}.app-container.error-state{justify-content:center;align-items:center}
