#mobile-block{display:none}@media (width<=480px){#mobile-block{z-index:9999;text-align:center;background:#faf7f2;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:32px 24px;display:flex;position:fixed;inset:0}#mobile-block .mb-kanji{color:#e8a0a8;font-family:Noto Serif JP,serif;font-size:64px;line-height:1}#mobile-block .mb-title{color:#2d3561;margin:0;font-family:Noto Serif JP,serif;font-size:20px;font-weight:700}#mobile-block .mb-sub{color:#6b7a99;max-width:280px;margin:0;font-family:Inter,sans-serif;font-size:14px;line-height:1.6}#mobile-block .mb-seal{opacity:.35;margin-top:8px}}:root{--bg:#faf7f2;--card-bg:#fffdf9;--sakura:#e8a0a8;--indigo:#2d3561;--sage:#8bad8e;--amber:#d4a56a;--text:#2d3561;--text-muted:#6b7a99;--border-color:#2d35612e;--hover-bg:#2d35610a;--font-serif:"Noto Serif JP", "Hiragino Mincho Pro", serif;--font-sans:"Inter", system-ui, sans-serif;--font-mono:"Courier New", Courier, monospace;--radius:8px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}body.dark{--bg:#1a1f3a;--card-bg:#222845;--text:#eee8d5;--text-muted:#8892b0;--border-color:#e8a0a82e;--hover-bg:#e8a0a80f;--sakura:#f0b8c0;--indigo:#7a8ec7;--sage:#9dbf9f;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}*,:before,:after{box-sizing:border-box}html{font-size:16px}body{background:radial-gradient(circle at top left, #e8a0a829, transparent 34%), radial-gradient(circle at top right, #7a8ec724, transparent 30%), linear-gradient(180deg, var(--bg), var(--bg));color:var(--text);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;margin:0;font-size:15px;line-height:1.5;transition:background .25s,color .25s;overflow-x:hidden}#root{text-align:left;border:none;flex-direction:row;width:100%;max-width:100%;min-height:100svh;margin:0;display:flex}h1,h2,h3,h4,h5,h6{font-family:var(--font-serif);color:var(--text);margin:0}p{margin:0}button{font-family:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{color:var(--text);background:#e8a0a84d}.sidebar{background:var(--card-bg);border-right:1.5px solid var(--border-color);z-index:10;flex-direction:column;flex-shrink:0;width:240px;min-width:240px;height:100vh;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar-header{border-bottom:1px solid var(--border-color);align-items:center;gap:12px;padding:20px 18px 16px;display:flex}.logo-seal{filter:drop-shadow(0 2px 4px #0003);flex-shrink:0}.logo-text{flex-direction:column;line-height:1.2;display:flex}.logo-kanji{color:var(--text);letter-spacing:.05em;font-family:Noto Serif JP,serif;font-size:20px;font-weight:700}.logo-roman{color:var(--text-muted);letter-spacing:.12em;text-transform:uppercase;font-family:Inter,sans-serif;font-size:11px;font-weight:500}.sidebar-nav{flex-direction:column;gap:2px;padding:12px 10px;display:flex}.nav-item{cursor:pointer;text-align:left;width:100%;color:var(--text-muted);background:0 0;border:none;border-radius:6px;align-items:center;gap:10px;padding:10px 12px;transition:background .15s,color .15s;display:flex}.nav-item:hover{background:var(--hover-bg);color:var(--text)}.nav-item.active{background:var(--sakura);color:#fff}.nav-item.active .nav-kanji{color:#fff}.nav-kanji{color:var(--sakura);text-align:center;flex-shrink:0;width:20px;font-family:Noto Serif JP,serif;font-size:16px;font-weight:500}.nav-label{font-family:Noto Serif JP,serif;font-size:14px;font-weight:400}.brushstroke-divider{margin-bottom:4px;padding:0 16px}.class-section{flex:1;padding:0 10px}.class-section-header{justify-content:space-between;align-items:center;padding:6px 8px 8px;display:flex}.section-label{color:var(--text-muted);letter-spacing:.1em;font-family:Noto Serif JP,serif;font-size:12px;font-weight:500}.section-label-en{letter-spacing:.04em;opacity:.7;font-family:Inter,sans-serif;font-size:10px;font-weight:400}.add-class-btn{border:1.5px solid var(--border-color);cursor:pointer;width:22px;height:22px;color:var(--text-muted);background:0 0;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:16px;line-height:1;transition:border-color .15s,color .15s;display:flex}.add-class-btn:hover{border-color:var(--sakura);color:var(--sakura)}.add-class-form{background:var(--hover-bg);border:1px solid var(--border-color);border-radius:8px;flex-direction:column;gap:8px;margin-bottom:8px;padding:10px;display:flex}.class-name-input{border:1px solid var(--border-color);background:var(--card-bg);width:100%;color:var(--text);box-sizing:border-box;border-radius:4px;outline:none;padding:6px 8px;font-family:Inter,sans-serif;font-size:13px}.class-name-input:focus{border-color:var(--sakura)}.color-picker{flex-wrap:wrap;gap:6px;display:flex}.color-dot{cursor:pointer;border:2px solid #0000;border-radius:50%;width:20px;height:20px;padding:0;transition:transform .1s,border-color .1s}.color-dot:hover{transform:scale(1.2)}.color-dot.selected{border-color:var(--text);transform:scale(1.15)}.confirm-add-btn{background:var(--indigo);color:#faf7f2;cursor:pointer;border:none;border-radius:4px;padding:6px 10px;font-family:Noto Serif JP,serif;font-size:12px;transition:opacity .15s}.confirm-add-btn:hover{opacity:.85}.class-list{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.class-item{border-radius:6px;align-items:center;gap:8px;padding:7px 8px;transition:background .12s;display:flex}.class-item:hover{background:var(--hover-bg)}.class-item:hover .remove-class-btn,.class-item:hover .edit-class-btn{opacity:1}.class-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.class-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;flex:1;font-family:Inter,sans-serif;font-size:13px;overflow:hidden}.edit-class-btn{opacity:0;cursor:pointer;color:var(--text-muted);background:0 0;border:none;flex-shrink:0;padding:0 2px;font-size:14px;line-height:1;transition:opacity .15s,color .15s}.edit-class-btn:hover{color:var(--indigo)}.remove-class-btn{opacity:0;cursor:pointer;color:var(--text-muted);background:0 0;border:none;flex-shrink:0;padding:0 2px;font-size:16px;line-height:1;transition:opacity .15s,color .15s}.remove-class-btn:hover{color:#e74c3c}.edit-class-form{flex-direction:column;gap:8px;width:100%;padding:6px 4px;display:flex}.edit-class-top{align-items:center;gap:8px;display:flex}.edit-class-top .class-name-input{flex:1}.edit-class-actions{gap:6px;display:flex}.cancel-edit-btn{border:1px solid var(--border-color);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:4px;padding:6px 10px;font-family:Noto Serif JP,serif;font-size:12px;transition:border-color .15s}.cancel-edit-btn:hover{border-color:var(--sakura);color:var(--text)}.class-empty{color:var(--text-muted);padding:8px;font-family:Inter,sans-serif;font-size:12px;font-style:italic}.class-item.is-confirming{background:var(--hover-bg);flex-wrap:wrap;gap:6px}.class-confirm-actions{gap:4px;margin-left:auto;display:flex}.confirm-action-btn{cursor:pointer;border:1.5px solid #0000;border-radius:4px;padding:3px 8px;font-family:Inter,sans-serif;font-size:11px;font-weight:600;line-height:1.4;transition:background .12s,color .12s,border-color .12s}.confirm-action-btn.archive{border-color:var(--amber);color:var(--amber);background:0 0}.confirm-action-btn.archive:hover{background:var(--amber);color:#faf7f2}.confirm-action-btn.delete{color:#e74c3c;background:0 0;border-color:#e74c3c}.confirm-action-btn.delete:hover{color:#faf7f2;background:#e74c3c}.confirm-action-btn.cancel{border-color:var(--border-color);color:var(--text-muted);background:0 0}.confirm-action-btn.cancel:hover{border-color:var(--text-muted);color:var(--text)}.archived-section{border-top:1px dashed var(--border-color);margin-top:8px;padding-top:4px}.archived-section-header{cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:6px;width:100%;padding:6px 8px;transition:background .12s;display:flex}.archived-section-header:hover{background:var(--hover-bg)}.archived-count{color:var(--text-muted);background:var(--hover-bg);border:1px solid var(--border-color);border-radius:10px;padding:1px 6px;font-family:Inter,sans-serif;font-size:11px;font-weight:600}.archived-chevron{color:var(--text-muted);margin-left:auto;font-size:11px}.archived-item .class-name{opacity:.55}.restore-class-btn{opacity:0;cursor:pointer;color:var(--text-muted);background:0 0;border:none;flex-shrink:0;padding:0 2px;font-size:14px;line-height:1;transition:opacity .15s,color .15s}.archived-item:hover .restore-class-btn,.archived-item:hover .remove-class-btn{opacity:1}.restore-class-btn:hover{color:var(--sage)}.sidebar-spacer{flex:1}.sidebar-footer{border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:14px 14px 18px;display:flex}.dark-toggle{background:var(--hover-bg);border:1.5px solid var(--border-color);cursor:pointer;color:var(--text);border-radius:20px;align-items:center;gap:6px;padding:5px 12px 5px 8px;transition:border-color .15s;display:flex}.dark-toggle:hover{border-color:var(--sakura)}.dark-toggle-icon{font-size:16px;font-style:normal}.dark-toggle-label{color:var(--text-muted);font-family:Inter,sans-serif;font-size:12px}.version-tag{color:var(--text-muted);opacity:.6;letter-spacing:.05em;font-family:Noto Serif JP,serif;font-size:10px}.sidebar-user{align-items:center;gap:7px;margin-top:8px;display:flex}.user-avatar{object-fit:cover;border:1px solid var(--border-color);border-radius:50%;width:24px;height:24px}.user-name{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:12px;overflow:hidden}.signout-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:15px;line-height:1;transition:color .15s}.signout-btn:hover{color:var(--sakura)}.poster-card{background:var(--card-bg);border:1.5px solid var(--indigo);border-radius:8px;display:flex;position:relative;overflow:hidden;box-shadow:3px 3px #2d35611f}.poster-card:after{content:"";pointer-events:none;opacity:.04;border-radius:inherit;z-index:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23g)'/%3E%3C/svg%3E");background-size:300px 300px;position:absolute;inset:0}.poster-card-spine{background:var(--indigo);z-index:1;border-radius:6px 0 0 6px;flex-shrink:0;justify-content:center;align-items:center;width:32px;min-width:32px;display:flex;position:relative}.spine-kanji{writing-mode:vertical-rl;text-orientation:mixed;color:var(--sakura);letter-spacing:.15em;-webkit-user-select:none;user-select:none;font-family:Noto Serif JP,serif;font-size:14px;font-weight:500}.poster-card-body{z-index:1;flex:1;padding:20px 24px;position:relative;overflow:hidden}.dashboard-view{flex-direction:column;gap:20px;width:100%;max-width:1180px;margin:0 auto;display:flex}.dashboard-hero{grid-template-columns:minmax(0,1.6fr) minmax(280px,.9fr);align-items:stretch;gap:18px;display:grid}.dashboard-hero-copy,.dashboard-hero-panel,.dashboard-metric-card{background:var(--card-bg);border:1.5px solid var(--indigo);border-radius:8px;box-shadow:3px 3px #2d35611f}body.dark .dashboard-hero-copy,body.dark .dashboard-hero-panel,body.dark .dashboard-metric-card{box-shadow:3px 3px #e8a0a814}body.dark .hero-secondary{color:var(--text);background:#e8a0a81a}body.dark .dashboard-footer-strip{background:#22284573}.dashboard-hero-copy{border-top:3px solid var(--sakura);padding:28px 30px;position:relative;overflow:hidden}.dashboard-hero-copy:before{content:"";opacity:.18;pointer-events:none;background-image:radial-gradient(circle,#2d35611f 1px,#0000 1px);background-size:18px 18px;position:absolute;inset:0}.dashboard-hero-copy:after{content:"勉強";font-family:var(--font-serif);color:var(--indigo);opacity:.04;pointer-events:none;-webkit-user-select:none;user-select:none;font-size:88px;font-weight:700;line-height:1;position:absolute;bottom:-12px;right:14px}.dashboard-kicker{font-family:var(--font-serif);letter-spacing:.12em;color:var(--text-muted);align-items:center;gap:8px;margin-bottom:14px;font-size:11px;display:inline-flex}.dashboard-kicker:before{content:"✿";color:var(--sakura);font-size:12px}.dashboard-hero-main{grid-template-columns:minmax(0,1fr) 220px;align-items:center;gap:20px;display:grid}.dashboard-hero-text{min-width:0}.dashboard-hero-copy h2{letter-spacing:-.04em;max-width:14ch;font-size:clamp(30px,4vw,48px);line-height:1.05}.dashboard-hero-copy p{max-width:58ch;color:var(--text-muted);margin-top:14px;font-size:15px}.dashboard-hero-actions{flex-wrap:wrap;gap:12px;margin-top:22px;display:flex}.dashboard-hero-image-wrap{aspect-ratio:1;border:1.5px solid var(--indigo);background:0 0;border-radius:6px;justify-self:end;width:min(220px,100%);overflow:hidden;box-shadow:3px 3px #2d356124}.dashboard-hero-image{aspect-ratio:1;object-fit:cover;width:100%;height:100%;display:block}body.dark .dashboard-hero-image-wrap{border-color:var(--border-color);box-shadow:3px 3px #e8a0a814}.hero-primary,.hero-secondary{font-family:var(--font-sans);cursor:pointer;border-radius:6px;padding:10px 18px;font-size:13px;font-weight:600;transition:box-shadow .12s,transform .12s}.hero-primary{background:var(--indigo);color:#faf7f2;border:1.5px solid var(--indigo);box-shadow:2px 2px #2d356140}.hero-secondary{color:var(--text);border:1.5px solid var(--border-color);background:0 0;box-shadow:2px 2px #2d356114}.hero-primary:hover{transform:translate(-1px,-1px);box-shadow:3px 3px #2d35614d}.hero-secondary:hover{border-color:var(--indigo);transform:translate(-1px,-1px)}.dashboard-hero-panel{background:var(--indigo);color:#faf7f2;flex-direction:column;gap:16px;padding:22px;display:flex;position:relative;overflow:hidden}.dashboard-hero-panel:before{content:"今日";font-family:var(--font-serif);color:#faf7f20d;writing-mode:vertical-rl;letter-spacing:.08em;pointer-events:none;-webkit-user-select:none;user-select:none;font-size:72px;font-weight:700;line-height:1;position:absolute;top:16px;right:16px}.dashboard-hero-panel:after{content:"";background:var(--sakura);opacity:.7;height:3px;position:absolute;inset:0 0 auto}.dashboard-metric-ring{z-index:1;background:#faf7f20f;border:1px solid #faf7f22e;border-radius:6px;flex-direction:column;gap:6px;padding:18px 22px;display:flex;position:relative}.dashboard-hero-panel .metric-ring-label,.dashboard-hero-panel .dashboard-mini-metrics span{color:#faf7f2ad}.dashboard-metric-ring strong{letter-spacing:-.05em;font-size:clamp(34px,6vw,54px);line-height:1}.dashboard-metric-ring span:last-child{font-size:13px}.dashboard-mini-metrics{z-index:1;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid;position:relative}.dashboard-mini-metrics>div{background:#faf7f20d;border:1px solid #faf7f224;border-radius:6px;flex-direction:column;gap:4px;padding:12px;display:flex}.dashboard-mini-metrics strong{color:#faf7f2;font-size:17px}.dashboard-metrics-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}.dashboard-metric-card{border-top:3px solid var(--sakura);padding:18px 18px 20px;position:relative;overflow:hidden}.dashboard-metric-card:after{content:"";font-family:var(--font-serif);color:var(--indigo);opacity:.05;pointer-events:none;-webkit-user-select:none;user-select:none;font-size:38px;line-height:1;position:absolute;bottom:10px;right:14px}.metric-label{text-transform:uppercase;letter-spacing:.16em;color:var(--text-muted);margin-bottom:12px;font-size:11px;display:block}.dashboard-metric-card strong{letter-spacing:-.03em;color:var(--text);font-size:24px;line-height:1.1;display:block}.dashboard-metric-card p{color:var(--text-muted);margin-top:8px;font-size:13px}.dashboard-content-grid{grid-template-columns:1.25fr 1fr 1fr;gap:16px;display:grid}.dashboard-card .poster-card-body{flex-direction:column;gap:18px;display:flex}.dashboard-rhythm-card,.dashboard-classes-card,.dashboard-recent-card{height:460px}.dashboard-rhythm-card .poster-card-body,.dashboard-classes-card .poster-card-body,.dashboard-recent-card .poster-card-body{height:100%}.dashboard-card-header h3{letter-spacing:-.02em;color:var(--text);font-size:18px}.dashboard-card-header p{color:var(--text-muted);margin-top:4px;font-size:12px}.radar-wrapper{flex:1;justify-content:center;align-items:center;display:flex}.class-rank-list,.recent-session-list{flex-direction:column;flex:1;gap:12px;min-height:0;padding-right:2px;display:flex;overflow-y:auto}.class-rank-list::-webkit-scrollbar{width:4px}.recent-session-list::-webkit-scrollbar{width:4px}.class-rank-list::-webkit-scrollbar-track{background:0 0}.recent-session-list::-webkit-scrollbar-track{background:0 0}.class-rank-list::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.recent-session-list::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.class-rank-item{border-top:1px solid var(--border-color);flex-direction:column;gap:8px;padding:12px 0 0;display:flex}.class-rank-item:first-child{border-top:none;padding-top:0}.class-rank-labels{font-family:var(--font-sans);color:var(--text);align-items:center;gap:8px;font-size:14px;display:flex}.class-rank-labels strong,.class-rank-item strong,.recent-session-duration{color:var(--text)}.class-rank-dot,.recent-session-color{border-radius:999px;flex-shrink:0;width:10px;height:10px}.class-rank-track{background:linear-gradient(90deg,#2d35610a,#2d35611a);border-radius:999px;width:100%;height:8px;overflow:hidden}.class-rank-fill{border-radius:inherit;height:100%}.recent-session-item{border-top:1px solid var(--border-color);grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;padding:12px 0;display:grid}.recent-session-item:first-child{border-top:none;padding-top:0}.recent-session-copy{flex-direction:column;gap:4px;min-width:0;display:flex}.recent-session-copy strong{font-family:var(--font-sans);color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:14px;overflow:hidden}.recent-session-copy span{color:var(--text-muted);font-size:12px}.recent-session-duration{font-family:var(--font-sans);font-size:13px;font-weight:600}.dashboard-empty-state{color:var(--text-muted);font-family:var(--font-sans);padding:18px 0;font-size:13px}.dashboard-footer-strip{background:var(--card-bg);border:1.5px solid var(--indigo);border-radius:8px;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;padding:18px 20px;display:grid;box-shadow:3px 3px #2d356114}.dashboard-footer-strip>div{flex-direction:column;gap:4px;display:flex;position:relative}.dashboard-footer-strip>div:not(:last-child):after{content:"";background:#2d35611a;width:1px;height:calc(100% - 16px);position:absolute;top:8px;right:-7px}.dashboard-footer-strip span{color:var(--text-muted);font-family:var(--font-sans);font-size:12px}.dashboard-footer-strip strong{color:var(--text);font-family:var(--font-sans);font-size:14px}@media (width<=1120px){.dashboard-hero,.dashboard-metrics-grid{grid-template-columns:1fr 1fr}.dashboard-hero-main{grid-template-columns:1fr;gap:14px}.dashboard-hero-image-wrap{justify-self:stretch;width:100%;max-width:360px}.dashboard-content-grid{grid-template-columns:1fr}}@media (width<=780px){.dashboard-hero,.dashboard-metrics-grid,.dashboard-footer-strip{grid-template-columns:1fr}.dashboard-footer-strip>div:not(:last-child):after{display:none}.dashboard-mini-metrics{grid-template-columns:1fr}}.timer-view{flex-direction:column;gap:16px;width:100%;max-width:580px;margin:0 auto;display:flex}.mode-selector{background:var(--hover-bg);border-radius:8px;gap:4px;margin-bottom:4px;padding:3px;display:flex}.mode-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:6px;flex:1;padding:7px 12px;font-family:Noto Serif JP,serif;font-size:13px;transition:background .15s,color .15s}.mode-btn.active{background:var(--card-bg);color:var(--text);box-shadow:0 1px 3px #0000001a}.pomodoro-settings{flex-direction:column;margin-bottom:8px;display:flex}.pomodoro-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.settings-toggle{border:1px dashed var(--border-color);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:4px;padding:4px 10px;font-family:Noto Serif JP,serif;font-size:12px;transition:border-color .15s}.settings-toggle:hover{border-color:var(--sakura);color:var(--sakura)}.settings-grid{background:var(--hover-bg);border-radius:8px;gap:16px;margin-top:10px;padding:12px;display:flex}.settings-grid label{color:var(--text);align-items:center;gap:8px;font-family:Inter,sans-serif;font-size:13px;display:flex}.settings-grid input{border:1.5px solid var(--border-color);text-align:center;background:var(--card-bg);width:56px;color:var(--text);border-radius:4px;outline:none;padding:4px 6px;font-family:Inter,sans-serif;font-size:14px}.settings-grid input:focus{border-color:var(--sakura)}.phase-badge{letter-spacing:.1em;border:1.5px solid;border-radius:20px;padding:3px 12px;font-family:Noto Serif JP,serif;font-size:14px;font-weight:500;transition:color .5s,border-color .5s;display:inline-block}.timer-display{justify-content:center;margin:16px 0;display:flex}.timer-panel{background:var(--indigo);border-radius:12px;flex-direction:column;align-items:center;gap:10px;padding:28px 48px;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 2px 8px #0000004d,0 4px 16px #2d35614d}.timer-panel:before{content:"";pointer-events:none;background:repeating-linear-gradient(0deg,#0000,#0000 2px,#ffffff04 2px 4px);position:absolute;inset:0}.timer-digits{color:#faf7f2;letter-spacing:.08em;text-shadow:0 0 20px #e8a0a866,0 0 40px #e8a0a826;font-family:Courier New,Courier,monospace;font-size:72px;font-weight:700;line-height:1}.elapsed-label{color:#faf7f280;letter-spacing:.08em;font-family:Noto Serif JP,serif;font-size:12px}.break-badge{letter-spacing:.1em;border:1.5px solid;border-radius:20px;padding:3px 12px;font-family:Noto Serif JP,serif;font-size:13px;font-weight:500;transition:color .3s,border-color .3s}.timer-controls{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.ctrl-btn{cursor:pointer;border:none;border-radius:8px;padding:10px 24px;font-family:Noto Serif JP,serif;font-size:14px;transition:opacity .15s,transform .1s}.ctrl-btn:hover:not(:disabled){opacity:.85;transform:translateY(-1px)}.ctrl-btn:active:not(:disabled){transform:translateY(0)}.ctrl-btn:disabled{opacity:.35;cursor:not-allowed}.ctrl-btn.primary{background:var(--sakura);color:#fff;padding:10px 32px}.ctrl-btn.secondary{background:var(--sage);color:#fff;padding:10px 28px}.ctrl-btn.danger{background:var(--indigo);color:#faf7f2}.ctrl-btn.ghost{border:1.5px solid var(--border-color);color:var(--text-muted);background:0 0;padding:10px 16px}.ctrl-btn.break-start{border:1.5px solid var(--sage);color:var(--sage);background:0 0}.ctrl-btn.break-end{background:var(--sage);color:#fff}.class-selector{flex-direction:column;gap:10px;margin-top:16px;display:flex}.selector-label{color:var(--text-muted);letter-spacing:.1em;font-family:Noto Serif JP,serif;font-size:12px}.selector-options{flex-wrap:wrap;gap:8px;display:flex}.class-chip{cursor:pointer;color:var(--text);background:0 0;border:1.5px solid;border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-family:Inter,sans-serif;font-size:13px;transition:background .15s,border-color .15s,transform .1s;display:flex}.class-chip:hover{transform:translateY(-1px)}.chip-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.no-classes{color:var(--text-muted);font-family:Inter,sans-serif;font-size:13px;font-style:italic}.log-popup-backdrop{-webkit-backdrop-filter:blur(3px);z-index:200;background:#1e1c1a73;justify-content:center;align-items:center;animation:.15s backdrop-in;display:flex;position:fixed;inset:0}@keyframes backdrop-in{0%{opacity:0}to{opacity:1}}.log-popup{background:var(--card-bg);border:1.5px solid var(--indigo);border-radius:8px;width:380px;animation:.18s cubic-bezier(.34,1.4,.64,1) popup-in;display:flex;overflow:hidden;box-shadow:4px 4px #2d35612e,0 12px 40px #00000038}@keyframes popup-in{0%{opacity:0;transform:scale(.92)translateY(6px)}to{opacity:1;transform:scale(1)translateY(0)}}.log-popup-spine{background:var(--indigo);flex-shrink:0;justify-content:center;align-items:center;width:32px;min-width:32px;display:flex}.log-popup-kanji{writing-mode:vertical-rl;text-orientation:mixed;color:var(--sakura);letter-spacing:.15em;-webkit-user-select:none;user-select:none;font-family:Noto Serif JP,serif;font-size:13px;font-weight:500}.log-popup-body{flex-direction:column;flex:1;gap:10px;padding:20px 20px 18px;display:flex}.log-popup-title{color:var(--text);margin:0;font-family:Noto Serif JP,serif;font-size:15px;font-weight:500}.log-popup-sub{color:var(--text-muted);margin:-4px 0 0;font-family:Inter,sans-serif;font-size:12px}.log-popup-input{border:1.5px solid var(--border-color);background:var(--hover-bg);width:100%;color:var(--text);box-sizing:border-box;border-radius:6px;outline:none;padding:8px 10px;font-family:Inter,sans-serif;font-size:13px;transition:border-color .15s,background .15s}.log-popup-input::placeholder{color:var(--text-muted);opacity:.55}.log-popup-input:focus{border-color:var(--sakura);background:var(--card-bg)}.log-popup-actions{gap:8px;display:flex}.log-popup-confirm{background:var(--sakura);color:#fff;cursor:pointer;border:none;border-radius:6px;flex:1;padding:8px 0;font-family:Noto Serif JP,serif;font-size:13px;transition:opacity .15s}.log-popup-confirm:hover{opacity:.88}.log-popup-skip{color:var(--text-muted);border:1.5px solid var(--border-color);cursor:pointer;background:0 0;border-radius:6px;padding:8px 16px;font-family:Noto Serif JP,serif;font-size:13px;transition:border-color .15s,color .15s}.log-popup-skip:hover{border-color:var(--text-muted);color:var(--text)}.goal-bar-wrap{flex-direction:column;gap:6px;margin:4px 0 8px;display:flex}.goal-bar-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.goal-bar-label{color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;font-family:Noto Serif JP,serif;font-size:11px}.goal-bar-right{align-items:center;gap:8px;display:flex}.goal-reached-badge{color:var(--sage);border:1px solid var(--sage);letter-spacing:.06em;border-radius:10px;padding:1px 7px;font-family:Noto Serif JP,serif;font-size:11px}.goal-bar-pct{color:var(--text-muted);text-align:right;min-width:34px;font-family:Inter,sans-serif;font-size:12px;font-weight:600}.goal-target-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-family:Inter,sans-serif;font-size:12px;transition:background .15s,color .15s}.goal-target-btn:hover{background:var(--hover-bg);color:var(--text)}.goal-edit-inline{align-items:center;gap:3px;display:flex}.goal-edit-input{border:1.5px solid var(--sakura);text-align:center;background:var(--card-bg);width:52px;color:var(--text);border-radius:4px;outline:none;padding:2px 6px;font-family:Inter,sans-serif;font-size:12px}.goal-edit-unit{color:var(--text-muted);font-family:Inter,sans-serif;font-size:12px}.goal-bar-track{background:var(--hover-bg);border:1px solid var(--border-color);border-radius:99px;height:6px;overflow:hidden}.goal-bar-fill{border-radius:99px;min-width:0;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1),background .4s}.task-section{flex-direction:column;gap:8px;margin-top:16px;display:flex}.task-section-header{justify-content:space-between;align-items:center;display:flex}.task-section-label{color:var(--text-muted);letter-spacing:.1em;font-family:Noto Serif JP,serif;font-size:12px}.task-count{color:var(--text-muted);font-family:Inter,sans-serif;font-size:11px}.task-add-row{gap:6px;display:flex}.task-input{border:1.5px solid var(--border-color);background:var(--hover-bg);color:var(--text);border-radius:6px;outline:none;flex:1;padding:7px 10px;font-family:Inter,sans-serif;font-size:13px;transition:border-color .15s}.task-input::placeholder{color:var(--text-muted);opacity:.5}.task-input:focus{border-color:var(--sakura);background:var(--card-bg)}.task-add-btn{border:1.5px solid var(--border-color);width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;font-size:18px;line-height:1;transition:background .15s,border-color .15s,color .15s;display:flex}.task-add-btn:hover:not(:disabled){background:var(--sakura);border-color:var(--sakura);color:#fff}.task-add-btn:disabled{opacity:.3;cursor:not-allowed}.task-list{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.task-item{background:var(--hover-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 8px;transition:background .12s;display:flex}.task-item.done{opacity:.55}.task-check{border:1.5px solid var(--border-color);cursor:pointer;color:#fff;background:0 0;border-radius:4px;justify-content:center;align-items:center;width:18px;min-width:18px;height:18px;padding:0;transition:background .15s,border-color .15s,color .15s;display:flex}.task-item.done .task-check{background:var(--sage);border-color:var(--sage)}.task-check:hover{border-color:var(--sage)}.task-text{color:var(--text);flex:1;font-family:Inter,sans-serif;font-size:13px;text-decoration:none;transition:-webkit-text-decoration .15s,text-decoration .15s}.task-item.done .task-text{color:var(--text-muted);text-decoration:line-through}.task-remove{color:var(--text-muted);cursor:pointer;opacity:0;background:0 0;border:none;padding:0 2px;font-size:16px;line-height:1;transition:opacity .15s,color .15s}.task-item:hover .task-remove{opacity:1}.task-remove:hover{color:#e74c3c}.focus-rating-row{justify-content:space-between;align-items:center;gap:10px;display:flex}.focus-rating-label{color:var(--text-muted);min-width:64px;font-family:Inter,sans-serif;font-size:12px;transition:color .15s}.focus-dots{gap:7px;display:flex}.focus-dot{border:1.5px solid var(--border-color);cursor:pointer;background:0 0;border-radius:50%;width:20px;height:20px;padding:0;transition:transform .12s,border-color .15s,background .15s}.focus-dot:hover{border-color:var(--sakura);transform:scale(1.2)}.focus-dot.filled{border-color:#0000;transform:scale(1.1)}.popup-task-summary{flex-wrap:wrap;gap:4px;padding:6px 0 2px;display:flex}.popup-task-chip{background:var(--hover-bg);border:1px solid var(--border-color);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;border-radius:10px;max-width:160px;padding:2px 8px;font-family:Inter,sans-serif;font-size:11px;overflow:hidden}.popup-task-chip.done{opacity:.55;text-decoration:line-through}.stats-view{flex-direction:column;gap:20px;width:100%;max-width:860px;margin:0 auto;display:flex}.stat-pills{flex-wrap:wrap;gap:12px;display:flex}.stat-pill{background:var(--card-bg);border:1.5px solid var(--border-color);border-radius:10px;flex:1;align-items:center;gap:14px;min-width:120px;padding:14px 18px;display:flex;box-shadow:2px 2px #2d356114}.stat-pill-kanji{color:var(--sakura);font-family:Noto Serif JP,serif;font-size:26px;line-height:1}.stat-pill-value{color:var(--text);letter-spacing:-.02em;font-family:Inter,sans-serif;font-size:26px;font-weight:700;line-height:1}.stat-pill-label{color:var(--text-muted);margin-top:2px;font-family:Inter,sans-serif;font-size:12px}.stats-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=720px){.stats-grid{grid-template-columns:1fr}}.chart-card .poster-card-body{flex-direction:column;display:flex}.chart-title{color:var(--text);margin:0 0 2px;font-family:Noto Serif JP,serif;font-size:15px;font-weight:500}.chart-subtitle{color:var(--text-muted);letter-spacing:.04em;margin:0 0 16px;font-family:Inter,sans-serif;font-size:11px}.donut-wrapper{max-width:200px;margin:0 auto 16px;position:relative}.donut-center{pointer-events:none;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.donut-center-value{color:var(--text);font-family:Inter,sans-serif;font-size:22px;font-weight:700;line-height:1}.donut-center-label{color:var(--text-muted);margin-top:3px;font-family:Noto Serif JP,serif;font-size:11px}.chart-legend{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.legend-item{align-items:center;gap:8px;display:flex}.legend-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;flex:1;font-family:Inter,sans-serif;font-size:13px;overflow:hidden}.legend-value{color:var(--text-muted);font-family:Inter,sans-serif;font-size:13px;font-weight:600}.bar-wrapper{flex:1;min-height:180px;position:relative}.area-card .poster-card-body{flex-direction:column;display:flex}.area-wrapper{width:100%;height:180px;position:relative}.area-stats{border-top:1px solid var(--border-color);flex-direction:column;gap:10px;margin-top:16px;padding-top:14px;display:flex}.area-stat-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.area-stat-label{color:var(--text-muted);letter-spacing:.03em;font-family:Inter,sans-serif;font-size:11px}.area-top-course{align-items:center;gap:7px;display:flex}.area-course-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.area-course-name{color:var(--text);font-family:Inter,sans-serif;font-size:14px;font-weight:600}.area-course-badge{color:#4caf7d;background:#4caf7d1f;border-radius:20px;padding:2px 9px;font-family:Inter,sans-serif;font-size:12px;font-weight:500}.area-stat-value{color:var(--text);font-family:Inter,sans-serif;font-size:18px;font-weight:700}.no-data{flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:32px;display:flex}.no-data-kanji{color:var(--border-color);font-family:Noto Serif JP,serif;font-size:48px}.no-data p{color:var(--text-muted);margin:0;font-family:Inter,sans-serif;font-size:13px}.history-view{grid-template-columns:minmax(320px,420px) 1fr;align-items:stretch;gap:16px;width:100%;max-width:1140px;margin:0 auto;display:grid}.history-list-card{height:500px}.history-list-card .poster-card-body{flex-direction:column;height:100%;display:flex}@media (width<=820px){.history-view{grid-template-columns:1fr}}.history-empty{text-align:center;flex-direction:column;align-items:center;gap:8px;padding:48px 24px;display:flex}.history-empty-kanji{color:var(--border-color);font-family:Noto Serif JP,serif;font-size:56px}.history-empty p{color:var(--text);margin:0;font-family:Inter,sans-serif;font-size:14px}.history-empty-sub{color:var(--text-muted)!important;font-size:12px!important}.history-header{justify-content:space-between;align-items:baseline;margin-bottom:8px;display:flex}.history-title{color:var(--text);margin:0;font-family:Noto Serif JP,serif;font-size:16px;font-weight:500}.history-total{color:var(--text-muted);font-family:Inter,sans-serif;font-size:13px;font-weight:600}.brush-hr{margin:10px 0 16px}.history-groups{flex-direction:column;flex:1;gap:20px;min-height:0;padding-right:2px;display:flex;overflow-y:auto}.history-groups::-webkit-scrollbar{width:4px}.history-groups::-webkit-scrollbar-track{background:0 0}.history-groups::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.history-group{flex-direction:column;gap:8px;display:flex}.group-date-row{justify-content:space-between;align-items:center;padding:0 2px;display:flex}.group-date{color:var(--text-muted);font-family:Noto Serif JP,serif;font-size:13px;font-weight:500}.group-total{color:var(--text-muted);background:var(--hover-bg);border:1px solid var(--border-color);border-radius:10px;padding:2px 8px;font-family:Inter,sans-serif;font-size:12px}.session-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.session-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;align-items:center;gap:8px;padding:10px 14px 10px 8px;transition:box-shadow .15s,transform .12s;display:flex;position:relative}.session-card:hover{transform:translateY(-1px);box-shadow:2px 2px 8px #2d35611f}.paper-tag-svg{color:var(--text-muted);flex-shrink:0}.session-color-bar{border-radius:2px;flex-shrink:0;width:4px;height:36px}.session-info{flex-direction:column;flex:1;gap:3px;display:flex;overflow:hidden}.session-class{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-family:Inter,sans-serif;font-size:14px;font-weight:500;overflow:hidden}.session-time-label{color:var(--text-muted);font-family:Inter,sans-serif;font-size:11px}.session-notes{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-family:Inter,sans-serif;font-size:11px;font-style:italic;overflow:hidden}.notes-edit-input{border:1.5px solid var(--border-color);background:var(--card-bg);width:100%;color:var(--text);box-sizing:border-box;border-radius:5px;outline:none;padding:5px 8px;font-family:Inter,sans-serif;font-size:12px;transition:border-color .12s}.notes-edit-input::placeholder{color:var(--text-muted);opacity:.6}.notes-edit-input:focus{border-color:var(--sakura)}.session-meta{flex-direction:column;align-items:flex-end;gap:3px;display:flex}.session-duration{color:var(--text);font-family:Inter,sans-serif;font-size:14px;font-weight:600}.session-type-badge{opacity:.7;font-size:12px}.session-actions{opacity:0;align-items:center;gap:4px;margin-left:6px;transition:opacity .15s;display:flex}.session-card:hover .session-actions{opacity:1}.action-icon{border:1.5px solid var(--border-color);cursor:pointer;width:26px;height:26px;color:var(--text-muted);background:0 0;border-radius:5px;justify-content:center;align-items:center;padding:0;font-size:13px;transition:background .12s,color .12s,border-color .12s;display:flex}.action-icon.edit:hover{color:var(--text);border-color:var(--indigo);background:#2d356114}.action-icon.delete:hover,.action-icon.confirm-del{color:#e74c3c;background:#e74c3c1a;border-color:#e74c3c}.action-icon.cancel-del:hover{color:var(--text);background:#2d356114}.session-card.is-editing{flex-wrap:wrap;align-items:flex-start;padding-bottom:12px}.session-edit{flex-direction:column;gap:8px;margin-left:auto;display:flex}.time-edit-grid{flex-direction:column;gap:5px;display:flex}.time-edit-row{align-items:center;gap:5px;display:flex}.time-edit-label{color:var(--text-muted);text-align:right;letter-spacing:.02em;width:30px;font-family:Inter,sans-serif;font-size:11px;font-weight:500}.time-colon{color:var(--text-muted);margin:0 1px;font-family:Inter,sans-serif;font-size:14px;font-weight:600;line-height:1}.time-input{border:1.5px solid var(--border-color);text-align:center;background:var(--card-bg);width:40px;color:var(--text);-moz-appearance:textfield;border-radius:5px;outline:none;padding:5px 4px;font-family:Inter,sans-serif;font-size:14px;font-weight:500;transition:border-color .12s}.time-input::-webkit-inner-spin-button{-webkit-appearance:none}.time-input::-webkit-outer-spin-button{-webkit-appearance:none}.time-input:focus{border-color:var(--sakura)}.time-input.is-error{border-color:#e74c3c}.time-edit-error{color:#e74c3c;text-align:right;font-family:Inter,sans-serif;font-size:11px}.class-pill-group{flex-wrap:wrap;gap:4px;display:flex}.class-pill{border:1.5px solid var(--border-color);color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border-radius:20px;padding:3px 9px;font-family:Inter,sans-serif;font-size:11px;font-weight:500;transition:background .12s,border-color .12s,color .12s}.class-pill:hover{border-color:var(--pill-color);color:var(--pill-color)}.class-pill.is-active{background:var(--pill-color);border-color:var(--pill-color);color:#fff}.edit-actions{gap:6px;display:flex}.action-btn{cursor:pointer;border:none;border-radius:4px;padding:4px 12px;font-family:Inter,sans-serif;font-size:12px;font-weight:500;transition:opacity .12s}.action-btn:hover{opacity:.82}.action-btn.save{background:var(--indigo);color:#faf7f2}.action-btn.cancel{background:var(--hover-bg);color:var(--text-muted);border:1.5px solid var(--border-color)}.cal-top{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.cal-title{color:var(--text);margin:0 0 2px;font-family:Inter,sans-serif;font-size:14px;font-weight:600}.cal-subtitle{color:var(--text-muted);margin:0;font-family:Inter,sans-serif;font-size:12px}.cal-month-nav{flex-shrink:0;align-items:center;gap:6px;display:flex}.cal-month-label{color:var(--text-muted);white-space:nowrap;font-family:Inter,sans-serif;font-size:11px;font-weight:600}.cal-nav-btn{border:1.5px solid var(--border-color);cursor:pointer;width:22px;height:22px;color:var(--text-muted);background:0 0;border-radius:4px;justify-content:center;align-items:center;padding:0;font-size:14px;line-height:1;transition:background .12s,color .12s;display:flex}.cal-nav-btn:hover{background:var(--hover-bg);color:var(--text)}.cal-today-btn{border:1.5px solid var(--sakura);cursor:pointer;color:var(--sakura);white-space:nowrap;background:0 0;border-radius:4px;padding:2px 8px;font-family:Inter,sans-serif;font-size:10px;font-weight:600;transition:background .12s,color .12s}.cal-today-btn:hover{background:var(--sakura);color:#faf7f2}.cal-day-headers{border-bottom:1px solid var(--border-color);margin-bottom:4px;padding-bottom:6px;display:flex}.cal-axis-spacer{flex-shrink:0;width:34px}.cal-day-head{flex-direction:column;flex:1;align-items:center;gap:3px;display:flex}.cal-day-name{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-family:Inter,sans-serif;font-size:10px;font-weight:700}.cal-day-num{color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-family:Inter,sans-serif;font-size:13px;font-weight:500;display:flex}.cal-day-num.is-today{background:var(--sakura);color:#faf7f2;font-weight:700}.cal-scroll-area{border-top:1px solid var(--border-color)}.cal-grid{display:flex;position:relative}.cal-time-axis{flex-shrink:0;width:34px;position:relative}.cal-hour-mark{pointer-events:none;justify-content:flex-end;align-items:center;width:100%;padding-right:6px;display:flex;position:absolute;left:0;transform:translateY(-50%)}.cal-hour-mark span{color:var(--text-muted);opacity:.7;white-space:nowrap;font-family:Inter,sans-serif;font-size:9px}.cal-col{border-left:1px solid var(--border-color);flex:1;min-width:0;position:relative}.cal-col.is-today-col{background:#e8a0a80d}.cal-hour-line{background:var(--border-color);opacity:.45;pointer-events:none;height:1px;position:absolute;left:0;right:0}.cal-now-line{background:var(--sakura);z-index:2;pointer-events:none;border-radius:1px;height:2px;position:absolute;left:0;right:0}.cal-now-line:before{content:"";background:var(--sakura);border-radius:50%;width:8px;height:8px;position:absolute;top:-3px;left:-3px}.cal-block{cursor:default;z-index:1;border-radius:3px;transition:opacity .12s;position:absolute;left:2px;right:2px;overflow:hidden}.cal-block:hover{opacity:.85;z-index:3}.cal-block-label{color:var(--text);white-space:nowrap;text-overflow:ellipsis;padding:2px 4px;font-family:Inter,sans-serif;font-size:9px;font-weight:600;line-height:1.3;display:block;overflow:hidden}.cal-break-block{z-index:2;background:#6b728040;border-left:3px solid #9ca3af}.session-break-duration{color:var(--text-muted);opacity:.85;font-family:Inter,sans-serif;font-size:11px}.detail-backdrop{-webkit-backdrop-filter:blur(3px);z-index:200;background:#1e1c1a73;justify-content:center;align-items:center;animation:.15s backdrop-in;display:flex;position:fixed;inset:0}.detail-popup{background:var(--card-bg);border:1.5px solid var(--indigo);border-radius:10px;width:360px;max-width:calc(100vw - 32px);animation:.18s cubic-bezier(.34,1.4,.64,1) popup-in;display:flex;overflow:hidden;box-shadow:4px 4px #2d35612e,0 12px 40px #00000038}.detail-spine{flex-shrink:0;justify-content:center;align-items:center;width:32px;min-width:32px;display:flex}.detail-spine-kanji{writing-mode:vertical-rl;text-orientation:mixed;color:#ffffffd9;letter-spacing:.15em;-webkit-user-select:none;user-select:none;font-family:Noto Serif JP,serif;font-size:13px;font-weight:600}.detail-body{flex-direction:column;flex:1;gap:12px;padding:18px 18px 20px;display:flex;position:relative}.detail-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 5px;font-size:14px;line-height:1;transition:color .12s,background .12s;position:absolute;top:12px;right:12px}.detail-close:hover{color:var(--text);background:var(--hover-bg)}.detail-class-row{align-items:center;gap:8px;padding-right:24px;display:flex}.detail-class-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.detail-class-name{color:var(--text);font-family:Noto Serif JP,serif;font-size:16px;font-weight:600}.detail-date{color:var(--text-muted);margin-top:-6px;font-family:Inter,sans-serif;font-size:12px}.detail-stats{background:var(--hover-bg);border:1px solid var(--border-color);border-radius:8px;gap:20px;padding:10px 14px;display:flex}.detail-stat{flex-direction:column;gap:2px;display:flex}.detail-stat-value{color:var(--text);font-family:Inter,sans-serif;font-size:18px;font-weight:700;line-height:1}.detail-stat-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);font-family:Inter,sans-serif;font-size:10px}.detail-focus{justify-content:space-between;align-items:center;padding:6px 0;display:flex}.detail-focus-label{color:var(--text-muted);font-family:Inter,sans-serif;font-size:12px;font-style:italic}.detail-focus-dots{gap:5px;display:flex}.detail-focus-dot{border:1.5px solid var(--border-color);border-radius:50%;width:14px;height:14px;display:inline-block}.detail-focus-dot.filled{border-color:#0000}.detail-section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:5px;font-family:Inter,sans-serif;font-size:10px;font-weight:700;display:block}.detail-notes-text{color:var(--text);margin:0;font-family:Inter,sans-serif;font-size:13px;line-height:1.55}.detail-task-list{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.detail-task-item{color:var(--text);align-items:center;gap:7px;font-family:Inter,sans-serif;font-size:12px;display:flex}.detail-task-item.done{opacity:.5;text-decoration:line-through}.detail-task-check{color:var(--text-muted);flex-shrink:0;font-size:11px}.detail-empty{color:var(--text-muted);text-align:center;margin:0;padding:8px 0;font-family:Inter,sans-serif;font-size:12px;font-style:italic}.ledger-view{flex-direction:column;gap:1.5rem;max-width:860px;padding:.25rem 0 2rem;display:flex}.ledger-description{color:var(--text-muted);max-width:560px;margin:0;font-family:Inter,sans-serif;font-size:.84rem;line-height:1.6}.ledger-controls{flex-wrap:wrap;align-items:flex-end;gap:1rem;display:flex}.ledger-control-group{flex-direction:column;gap:.35rem;display:flex}.ledger-label{letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted);font-family:Inter,sans-serif;font-size:.72rem;font-weight:600}.ledger-select{border:1.5px solid var(--border-color);background:var(--card-bg);color:var(--text);cursor:pointer;border-radius:8px;min-width:160px;padding:.5rem .85rem;font-family:Inter,sans-serif;font-size:.88rem;transition:border-color .18s}.ledger-select:focus{border-color:var(--sakura);outline:none}.ledger-export-btn{background:var(--indigo);color:#faf7f2;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:.45rem;padding:.55rem 1.2rem;font-family:Inter,sans-serif;font-size:.88rem;font-weight:600;transition:opacity .18s,transform .12s;display:flex}.ledger-export-btn:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.ledger-export-btn:disabled{opacity:.38;cursor:not-allowed}.ledger-export-icon{font-size:1rem;font-weight:700}.ledger-preview{background:var(--card-bg);border:1px solid var(--border-color);border-radius:14px;overflow:hidden;box-shadow:0 2px 16px #2d356112}.ledger-inv-header{background:var(--indigo);border-bottom:3px solid var(--class-color,var(--sakura));justify-content:space-between;align-items:flex-end;padding:1.1rem 1.6rem;display:flex}.ledger-inv-brand{flex-direction:column;gap:.2rem;display:flex}.ledger-inv-app{color:#faf7f2;letter-spacing:.12em;font-family:Noto Serif JP,serif;font-size:1.3rem;font-weight:700}.ledger-inv-sub{color:#faf7f299;letter-spacing:.05em;text-transform:uppercase;font-family:Inter,sans-serif;font-size:.72rem}.ledger-inv-issued{color:#faf7f28c;font-family:Inter,sans-serif;font-size:.75rem}.ledger-inv-info{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1.2rem 1.6rem;display:flex}.ledger-inv-left{align-items:center;gap:.85rem;display:flex}.ledger-class-dot{border-radius:50%;flex-shrink:0;width:14px;height:14px}.ledger-inv-classname{color:var(--text);font-family:Noto Serif JP,serif;font-size:1.15rem;font-weight:700}.ledger-inv-period{color:var(--text-muted);margin-top:.15rem;font-family:Inter,sans-serif;font-size:.82rem}.ledger-inv-totals{text-align:right}.ledger-total-hours{color:var(--text);font-family:Noto Serif JP,serif;font-size:2rem;font-weight:700;line-height:1}.ledger-total-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:.15rem;font-family:Inter,sans-serif;font-size:.75rem}.ledger-session-count{color:var(--text-muted);margin-top:.25rem;font-family:Inter,sans-serif;font-size:.78rem}.ledger-table-wrap{overflow-x:auto}.ledger-table{border-collapse:collapse;width:100%;font-family:Inter,sans-serif;font-size:.875rem}.ledger-table thead tr{background:var(--indigo)}.ledger-table thead th{text-align:left;letter-spacing:.08em;text-transform:uppercase;color:#faf7f2d9;padding:.6rem 1rem;font-size:.72rem;font-weight:600}.ledger-table tbody tr{border-bottom:1px solid var(--border-color);transition:background .12s}.ledger-table tbody tr:nth-child(2n){background:#2d356108}.ledger-table tbody tr:last-child{border-bottom:none}.ledger-table tbody tr:hover{background:#e8a0a814}.ledger-table td{color:var(--text);vertical-align:top;padding:.7rem 1rem}.col-num{text-align:center;width:32px;font-size:.78rem;color:var(--text-muted)!important}.col-center{text-align:center}.col-right{text-align:right;font-variant-numeric:tabular-nums}.col-notes{color:var(--text-muted);max-width:280px;font-size:.82rem}.col-empty{color:var(--border-color)}.ledger-empty{color:var(--text-muted);flex-direction:column;align-items:center;gap:.75rem;padding:3.5rem 1.5rem;display:flex}.ledger-empty-kanji{opacity:.22;color:var(--text);font-family:Noto Serif JP,serif;font-size:2.5rem}.ledger-empty p{text-align:center;max-width:280px;font-family:Inter,sans-serif;font-size:.88rem;line-height:1.5}.ledger-inv-footer{border-top:2.5px solid var(--class-color,var(--sakura));background:#2d356108;justify-content:space-between;align-items:center;padding:.85rem 1.6rem;display:flex}.ledger-footer-label{text-transform:uppercase;letter-spacing:.09em;color:var(--text-muted);font-family:Inter,sans-serif;font-size:.8rem;font-weight:700}.ledger-footer-value{color:var(--text);font-family:Noto Serif JP,serif;font-size:1.05rem;font-weight:700}body.dark .ledger-select{color:var(--text);background:#ffffff0f;border-color:#ffffff1f}body.dark .ledger-table thead tr{background:#2d3561e6}body.dark .ledger-table tbody tr:nth-child(2n){background:#ffffff08}body.dark .ledger-inv-header{background:#1e2444f2}body.dark .ledger-inv-footer{background:#ffffff08}.cherry-blossoms{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.blossom{will-change:transform;animation:linear infinite fall;position:absolute;top:-60px}@keyframes fall{0%{opacity:0;transform:translateY(0)translate(0)rotate(0)}10%{opacity:1}90%{opacity:.6}to{transform:translateY(110vh) translateX(var(--sway,30px)) rotate(360deg);opacity:0}}.lantern-scene{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.lantern{--scale:1;filter:drop-shadow(0 0 16px var(--glow)) drop-shadow(0 0 28px var(--glow));transform-origin:top;flex-direction:column;align-items:center;animation:6.5s ease-in-out infinite lantern-bob;display:flex;position:absolute}.lantern:before{content:"";background:radial-gradient(circle, var(--glow) 0%, transparent 68%);opacity:.85;z-index:-1;height:180px;position:absolute;inset:-42px -52px auto}.lantern-string{background:linear-gradient(#2d356147,#2d35610f);border-radius:999px;width:2px;height:42px}.lantern-top,.lantern-bottom{background:linear-gradient(#8d212af2,#66131bfa);border-radius:999px;width:28%;height:9px;box-shadow:inset 0 1px #fff0dc33}.lantern-body{background:radial-gradient(circle at 50% 18%,#fff1ccf2,#f8cc76eb 58%,#d68639f5 100%),linear-gradient(#fff3d3f2,#e7aa52f2);border:1px solid #6b410c2e;border-radius:999px;justify-content:center;align-items:center;min-width:74px;min-height:100px;padding:14px 10px;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #faf7f25c,inset 0 -18px 28px #8d34001f}.lantern-body:before,.lantern-body:after{content:"";opacity:.62;background:linear-gradient(90deg,#0000 0 18%,#783c0f38 18% 20%,#0000 20% 40%,#783c0f38 40% 42%,#0000 42% 60%,#783c0f38 60% 62%,#0000 62% 80%,#783c0f38 80% 82%,#0000 82% 100%),linear-gradient(#0000 0 11%,#783c0f2e 11% 12%,#0000 12% 88%,#783c0f2e 88% 89%,#0000 89% 100%);position:absolute;inset:0}.lantern-belt{background:linear-gradient(#882d1ae6,#691812fa);border-radius:999px;height:13px;position:absolute;inset:43% 12% auto;box-shadow:inset 0 1px #fff0dc2e}.lantern-mark{z-index:1;color:#782916c7;text-shadow:0 0 12px #fff4c3a6;font-family:Noto Serif JP,serif;font-size:22px;font-weight:700;position:relative}.lantern-bottom{margin-top:-1px}.lantern-glow{background:radial-gradient(circle, var(--glow) 0%, transparent 70%);filter:blur(2px);opacity:.95;z-index:-1;border-radius:50%;height:200px;position:absolute;inset:50% -60px auto}.lantern-large{--scale:1.08}.lantern-medium{--scale:.92}.lantern-small{--scale:.78}.lantern-center .lantern-body{min-width:66px;min-height:92px}@keyframes lantern-bob{0%,to{transform:scale(var(--scale)) translateY(0) rotate(-1deg)}50%{transform:scale(var(--scale)) translateY(8px) rotate(1deg)}}@media (width<=980px){.lantern-center,.lantern-right{opacity:.55}}@media (width<=720px){.lantern-left,.lantern-right{display:none}.lantern-center{--scale:.76;top:8vh;left:calc(50% - 28px)}}.app-layout{isolation:isolate;width:100%;min-height:100vh;display:flex;position:relative}.app-layout:before,.app-layout:after{content:"";pointer-events:none;z-index:0;position:fixed}.app-layout:before{filter:blur(10px);background:radial-gradient(circle,#e8a0a833,#0000 58%),radial-gradient(circle at 42% 42%,#faf7f2b8 0 10%,#0000 10% 100%);border-radius:50%;width:420px;height:420px;inset:-12% auto auto -8%}.app-layout:after{filter:blur(12px);background:radial-gradient(circle,#7a8ec726,#0000 60%),radial-gradient(circle,#2d35610f 0 14%,#0000 14% 100%);border-radius:50%;width:480px;height:480px;inset:auto -10% -18% auto}.main-content{z-index:1;flex-direction:column;flex:1;min-height:100vh;padding-bottom:16px;display:flex;position:relative;overflow-y:auto}.main-header{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:5;background:linear-gradient(#faf7f2cc,#faf7f299),repeating-linear-gradient(90deg,#0000 0 26px,#2d356108 26px 27px);border-bottom:1px solid #2d35611a;justify-content:space-between;align-items:center;padding:20px 32px 14px;display:flex;position:sticky;top:0}body.dark .main-header{background:linear-gradient(#1a1f3ae0,#1a1f3aad),repeating-linear-gradient(90deg,#0000 0 26px,#e8a0a808 26px 27px);border-bottom-color:#e8a0a824}.header-left{align-items:baseline;gap:12px;display:flex}.page-kanji{color:var(--sakura);text-shadow:0 1px #faf7f2b3;font-family:Noto Serif JP,serif;font-size:28px;font-weight:700;line-height:1}.page-title{color:var(--text-muted);margin:0;font-family:Noto Serif JP,serif;font-size:18px;font-weight:400}.wax-seal{filter:drop-shadow(0 2px 6px #c0392b47)saturate(.94);cursor:default;transition:transform .2s}.wax-seal:hover{transform:rotate(8deg)scale(1.05)}.main-brush-hr{opacity:.9;padding:0 24px}.view-container{z-index:1;flex:1;padding:28px 32px 36px;position:relative}body.dark .view-container:before{content:"";pointer-events:none;background:linear-gradient(90deg,#0000 0 24%,#e8a0a808 24% 25%,#0000 25% 49%,#e8a0a808 49% 50%,#0000 50% 74%,#e8a0a808 74% 75%,#0000 75% 100%),linear-gradient(#0000 0 22px,#faf7f206 22px 23px,#0000 23px 100%);position:absolute;inset:0;-webkit-mask-image:linear-gradient(#0000003d,#0000);mask-image:linear-gradient(#0000003d,#0000)}.auth-screen{justify-content:center;align-items:center;width:100%;min-height:100vh;display:flex;position:relative}.auth-card{border:1px solid var(--border-color);z-index:1;background:radial-gradient(circle at top,#e8a0a81f,#0000 38%),linear-gradient(#fffdf9f5,#fcf7f0e0);border-radius:16px;flex-direction:column;align-items:center;gap:12px;padding:48px 56px;display:flex;position:relative;box-shadow:0 8px 32px #00000014}.auth-kanji{color:var(--sakura);text-shadow:0 1px #faf7f2bf;font-family:Noto Serif JP,serif;font-size:52px;font-weight:700;line-height:1}.auth-title{color:var(--text-primary);margin:0;font-family:Noto Serif JP,serif;font-size:22px;font-weight:400}.auth-subtitle{color:var(--text-muted);text-align:center;margin:0 0 8px;font-size:14px}.auth-loading{color:var(--text-muted);margin:8px 0 0;font-size:14px}.auth-btn{background:var(--card-bg);border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:10px 20px;font-size:14px;font-weight:500;transition:box-shadow .15s,border-color .15s;display:flex}.auth-btn:hover{border-color:var(--sakura);box-shadow:0 2px 8px #0000001f}
