:root{--bg: #f4f6f5;--surface: #ffffff;--text: #1c2522;--muted: #6b7772;--primary: #1f8f6b;--primary-dark: #176f53;--warn: #e0a100;--danger: #d2503f;--border: #e3e8e6;--subtle: #eef1f0;--soft-primary: #e3f0ec;--soft-danger: #fbeae7;--soft-warn: #fff4d6;--soft-warn-text: #9a6b00;--soft-ok: #e3f6ec;--radius: 14px;--shadow: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);font-family:system-ui,-apple-system,Segoe UI,Hiragino Kaku Gothic ProN,Noto Sans JP,sans-serif}:root[data-theme=dark]{--bg: #14181a;--surface: #1e2426;--text: #e7edea;--muted: #9aa7a2;--border: #2c3539;--shadow: 0 1px 3px rgba(0, 0, 0, .55), 0 1px 2px rgba(0, 0, 0, .4);--subtle: #283033;--soft-primary: #1b2e29;--soft-danger: #3a2422;--soft-warn: #34301d;--soft-warn-text: #e4ba5e;--soft-ok: #1d2e26}*{box-sizing:border-box}html,body,#root{margin:0;height:100%}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer}.app{max-width:640px;margin:0 auto;min-height:100%;display:flex;flex-direction:column;background:var(--bg)}.header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:max(12px,env(safe-area-inset-top)) 16px 12px;background:var(--surface);border-bottom:1px solid var(--border);min-height:48px}.page-title{margin:0;font-size:17px;font-weight:800}.sync-badge{font-size:12px;font-weight:700;color:var(--primary-dark);background:var(--soft-primary);padding:4px 10px;border-radius:999px}.brand{display:flex;align-items:baseline;gap:8px}.brand-lg{flex-direction:column;align-items:center;gap:4px}.logo{font-weight:800;font-size:22px;letter-spacing:.5px;color:var(--primary)}.tagline{font-size:12px;color:var(--muted)}.header-right{display:flex;align-items:center;gap:10px}.main{flex:1;padding:16px 16px 84px}.logout-btn{margin-top:24px;color:var(--danger)}.seg{display:inline-flex;background:var(--subtle);border-radius:999px;padding:2px}.seg-btn{border:none;background:none;padding:4px 14px;font-size:13px;font-weight:700;color:var(--muted);border-radius:999px}.seg-btn.on{background:var(--surface);color:var(--primary-dark);box-shadow:var(--shadow)}.seg-btn:disabled{opacity:.4}.seg.seg-wide{display:grid;grid-template-columns:1fr 1fr;width:100%}.seg-wide .seg-btn{padding:8px 0;text-align:center}.seg.seg-3{grid-template-columns:1fr 1fr 1fr}.seg-3 .seg-btn{font-size:12px;padding:8px 2px}.wk-nav{gap:8px}.wk-label{display:flex;flex-direction:column;align-items:center;line-height:1.3}.wk-rel{font-weight:800;font-size:15px}.tabbar{position:fixed;bottom:0;left:0;right:0;max-width:640px;margin:0 auto;display:grid;grid-template-columns:repeat(5,1fr);background:var(--surface);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom)}.tab{border:none;background:none;padding:8px 0 10px;display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--muted);font-size:11px}.tab-active{color:var(--primary);font-weight:700}.tab-locked{opacity:.3;cursor:not-allowed}.tab-icon{font-size:20px}.stack>*+*{margin-top:12px}.muted{color:var(--muted)}.small{font-size:12px}.center{text-align:center}.row-between{display:flex;align-items:center;justify-content:space-between}.row-end{display:flex;justify-content:flex-end}.gap{gap:8px}.sep{border:none;border-top:1px solid var(--border);margin:4px 0}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.card-title{margin:0;font-size:15px}.card-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;padding:0;color:var(--text);font:inherit}.btn{border:1px solid transparent;border-radius:10px;padding:10px 16px;font-size:14px;font-weight:600;background:var(--subtle);color:var(--text)}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-warn{background:var(--warn);color:#fff}.btn-danger{background:var(--soft-danger);color:var(--danger)}.btn-ghost{background:transparent;border-color:var(--border);color:var(--text)}.btn-sm{padding:6px 12px;font-size:13px}.btn-lg{padding:14px 22px;font-size:16px}.btn-block{display:block;width:100%}.btn:disabled{opacity:.45;cursor:not-allowed}.link-btn{border:none;background:none;color:var(--muted);font-size:13px;text-decoration:underline}.badge{font-size:11px;font-weight:700;padding:3px 8px;border-radius:999px}.badge-cloud{background:var(--soft-primary);color:var(--primary-dark)}.badge-local{background:var(--subtle);color:var(--muted)}.field{display:flex;flex-direction:column;gap:6px}.field-label{font-size:13px;font-weight:600;color:var(--muted)}.input{border:1px solid var(--border);border-radius:10px;padding:10px 12px;font-size:15px;background:var(--surface);color:var(--text);width:100%}.input:focus{outline:2px solid var(--primary);outline-offset:-1px}.input.num{width:80px}.time-input{display:flex;align-items:center;gap:8px}.unit{font-size:14px;color:var(--muted)}.inline-add{display:flex;gap:8px;margin-top:8px}.inline-add .input{flex:1}.stat-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow)}.stat-label{font-size:12px;color:var(--muted)}.stat-value{font-size:24px;font-weight:800;margin-top:2px}.stat-value.sm{font-size:18px}.stat-row-3{grid-template-columns:repeat(3,1fr)}.stat-row-4{grid-template-columns:repeat(4,1fr)}.lock-badge{font-size:.8em}.back-btn{align-self:flex-start}.lock-field{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 0 2px;border-top:1px solid var(--border)}.lock-field-text{min-width:0}.toggle{flex:none;min-width:56px;padding:8px 14px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--muted);font-weight:700;cursor:pointer}.toggle.on{background:var(--primary);border-color:var(--primary);color:#fff}.card-subtitle{margin:4px 0 0;font-size:14px;font-weight:700}.chart-area{display:flex;gap:8px;margin-top:16px}.chart-yaxis{position:relative;width:44px;height:120px;flex:none}.ytick{position:absolute;right:0;transform:translateY(50%);font-size:10px;color:var(--muted);white-space:nowrap}.chart-body{flex:1;min-width:0}.chart-bars{position:relative;height:120px;overflow:visible}.gridline{position:absolute;left:0;right:0;border-top:1px dashed var(--border)}.chart{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.chart-col{position:relative;display:flex;align-items:flex-end;justify-content:center;cursor:pointer}.chart-bar-wrap{width:100%;height:100%;display:flex;align-items:flex-end;justify-content:center;position:relative;cursor:pointer}.bar-value{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:4px;background:#1c2522;color:#fff;border-radius:6px;padding:3px 7px;font-size:11px;font-weight:700;white-space:nowrap;z-index:2}.chart-bar{width:62%;min-height:2px;background:var(--primary);border-radius:4px 4px 0 0;transition:height .2s,background .15s}.chart-bar.active,.chart-bar.on{background:var(--primary-dark)}.bar-tip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:6px;background:#1c2522;color:#fff;border-radius:8px;padding:6px 10px;font-size:12px;line-height:1.3;white-space:nowrap;display:flex;flex-direction:column;align-items:center;gap:1px;box-shadow:0 4px 12px #0000002e;z-index:5;pointer-events:none}.bar-tip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:#1c2522}.bar-tip-day{font-size:10px;opacity:.7}.bar-tip-val{font-weight:700}.chart-xrow{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-top:6px}.chart-x{display:flex;flex-direction:column;align-items:center;line-height:1.25;font-size:11px;color:var(--muted);text-align:center}.x-sub{font-size:10px;font-weight:700;color:var(--text);opacity:.75}.exam-card{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow)}.exam-card.no-pad{border:none;box-shadow:none;padding:0}.exam-dot{width:12px;height:12px;border-radius:50%;flex:none}.exam-main{flex:1;min-width:0}.exam-name{font-weight:700;font-size:15px}.exam-sub{font-size:12px;margin-top:2px}.countdown{font-size:13px;font-weight:700;padding:4px 10px;border-radius:999px;background:var(--subtle);color:var(--muted);flex:none}.countdown.soon{background:var(--soft-warn);color:var(--soft-warn-text)}.countdown.past{background:var(--soft-danger);color:var(--danger)}.countdown.acquired{background:var(--soft-primary);color:var(--primary-dark)}.archived{opacity:.6}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip{display:inline-flex;align-items:center;gap:4px;background:var(--subtle);border-radius:999px;padding:5px 10px;font-size:13px}.chip-add{border:1px dashed var(--border);background:var(--surface);color:var(--primary-dark)}.chip-x{border:none;background:none;color:var(--muted);font-size:16px;line-height:1;padding:0 2px}.preset-group+.preset-group{margin-top:12px}.preset-provider{display:flex;align-items:center;gap:6px;font-weight:700;font-size:13px;margin-bottom:6px}.focus-banner{background:var(--soft-warn);color:var(--soft-warn-text);border-radius:10px;padding:10px 12px;font-size:13px;font-weight:600;text-align:center}.focus-banner.saved{background:var(--soft-ok);color:var(--primary-dark)}.donut-card{display:flex;align-items:center;gap:16px}.donut{flex:none}.donut-track{stroke:var(--subtle)}.donut-arc{stroke:var(--primary);transition:stroke-dasharray .5s ease}.donut-arc.done{stroke:#f0a500}.donut-pct{font-size:24px;font-weight:800;fill:var(--text, #1a1a1a)}.donut-sub{font-size:11px;fill:var(--muted)}.donut-legend{min-width:0}.donut-figures{margin:2px 0 6px}.donut-now{font-size:20px;font-weight:800;color:var(--primary-dark)}.timer-display{text-align:center;padding:20px 0}.timer-clock{font-size:56px;font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:2px}.timer-min{margin-top:6px;font-size:14px}.timer-controls{display:flex;gap:12px}.timer-controls .btn{flex:1}.day-head{margin-top:4px}.day-date{font-weight:700;font-size:14px}.record-row{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px 14px;box-shadow:var(--shadow)}.record-main{flex:1;min-width:0}.record-title{font-size:14px;font-weight:600;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.record-material{color:var(--muted);font-weight:400}.record-memo{margin-top:2px;display:-webkit-box;-webkit-line-clamp:1;line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.record-min{font-weight:700;font-size:14px;white-space:nowrap}.record-row.editing{outline:2px solid var(--primary)}.icon-btn{border:none;background:none;font-size:15px;line-height:1;padding:2px 4px;opacity:.7}.icon-btn:hover{opacity:1}.profile-head{display:flex;align-items:center;gap:14px}.avatar{width:56px;height:56px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;color:#fff;font-size:26px;font-weight:800;text-transform:uppercase}.profile-id{min-width:0}.profile-name{font-size:18px;font-weight:800}.profile-bio{font-size:13px;margin-top:2px}.note-sns{margin-top:8px}.avatar-pick-row{display:flex;align-items:center;gap:10px}.avatar-pick-row>.muted{width:40px;flex:none}.avatar-colors,.avatar-emojis{display:flex;gap:8px;flex-wrap:wrap}.avatar-dot{width:30px;height:30px;border-radius:50%;border:2px solid var(--border)}.avatar-dot.on{border-color:var(--text);box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--text)}.avatar-emoji{width:36px;height:36px;border-radius:10px;border:1px solid var(--border);background:var(--surface);font-size:18px;display:flex;align-items:center;justify-content:center}.avatar-emoji.on{border-color:var(--primary);background:color-mix(in srgb,var(--primary) 12%,var(--surface))}.theme-swatches{display:flex;gap:12px;flex-wrap:wrap}.theme-swatch{width:38px;height:38px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800}.theme-swatch.on{border-color:var(--text);box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--text)}.theme-check{font-size:16px}.badge-public{font-size:11px;font-weight:700;color:var(--primary);background:color-mix(in srgb,var(--primary) 14%,transparent);border-radius:999px;padding:2px 8px}.icon-btn.shared{opacity:1}.filter-chips{display:flex;flex-wrap:wrap;gap:6px}.chip-filter{border:1px solid var(--border);background:var(--surface);color:var(--muted);border-radius:999px;padding:4px 12px;font-size:12px;font-weight:700}.chip-filter.on{background:var(--primary);border-color:var(--primary);color:#fff}.stack-sm>*+*{margin-top:8px}.book-input-row{display:flex;gap:8px;align-items:center}.book-input-row .input{flex:1;min-width:0}.book-toggle{flex:none;white-space:nowrap}.book-list{display:flex;flex-direction:column;gap:6px}.book-opt{display:flex;align-items:center;gap:8px;text-align:left;border:1px solid var(--border);background:var(--surface);border-radius:10px;padding:8px 10px;width:100%}.book-opt:hover{border-color:var(--primary)}.book-opt-main{display:flex;flex-direction:column;min-width:0}.book-opt-title{font-size:13px;font-weight:700;line-height:1.3}.book-opt-sub{margin-top:1px}.book-cover{width:30px;height:42px;object-fit:cover;border-radius:3px;flex:none;background:var(--subtle)}.book-net{border-top:1px dashed var(--border);padding-top:8px}.book-free{margin-top:6px}.chip-book{background:color-mix(in srgb,var(--primary) 10%,var(--surface))}.chip-link{color:var(--primary-dark);text-decoration:underline}.aff-links{display:flex;align-items:center;gap:8px;margin-top:4px}.aff-link{font-size:12px;color:var(--primary-dark);text-decoration:underline}.aff-pr{font-size:10px;font-weight:700;color:var(--muted);border:1px solid var(--border);border-radius:4px;padding:0 4px;line-height:16px}.aff-note{margin-top:0}.app-footer{margin-top:28px;padding:12px 6px 4px;border-top:1px solid var(--border);color:var(--muted);font-size:11px;line-height:1.7;text-align:center}.avatar.sm{width:38px;height:38px;font-size:17px}.tl-item{display:flex;align-items:flex-start;gap:10px}.tl-main{min-width:0;flex:1}.tl-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.tl-name{font-weight:700;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tl-body{margin-top:2px;display:flex;align-items:baseline;flex-wrap:wrap;gap:2px}.tl-exam{font-weight:600;font-size:14px}.tl-min{margin-left:auto;font-weight:700;font-size:13px;white-space:nowrap}.tl-comment{margin-top:6px;font-size:13px;line-height:1.5;white-space:pre-wrap;word-break:break-word}.tl-material{margin-top:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tl-tap{flex:1;min-width:0;display:flex;align-items:flex-start;gap:10px;width:100%;text-align:left;border:none;background:none;padding:0;font:inherit;color:inherit;cursor:pointer}.tl-tap:active{transform:scale(.997)}.like-btn{flex:none;align-self:center;display:flex;align-items:center;gap:4px;border:none;background:none;padding:4px 2px;font-size:18px;line-height:1;color:var(--muted);cursor:pointer;border-radius:8px}.like-btn:active{transform:scale(.92)}.like-btn .like-count{font-size:13px;min-width:8px}.like-btn.on{color:#e2522b}.modal-foot{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--border);padding-top:8px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;padding:20px;z-index:50}.modal-card{background:var(--surface);border-radius:16px;padding:18px;width:100%;max-width:420px;max-height:86vh;overflow-y:auto;box-shadow:0 10px 40px #0003}.tl-card{display:flex;flex-direction:column;gap:8px}.tl-actions{display:flex;align-items:center;gap:2px;border-top:1px solid var(--border);padding-top:6px}.act-btn{display:inline-flex;align-items:center;gap:4px;border:none;background:none;padding:4px 10px;font-size:15px;line-height:1;color:var(--muted);cursor:pointer;border-radius:8px}.act-btn:active{transform:scale(.94)}.act-btn .like-count{font-size:13px;min-width:8px}.act-more{margin-left:auto}.like-btn:not(.on){filter:grayscale(1);opacity:.5}.like-btn.on{filter:none;opacity:1}.like-static{flex:none;align-self:center;display:inline-flex;align-items:center;gap:4px;font-size:14px;color:var(--muted)}.like-static .like-count{font-size:13px}.cmt-section{border-top:1px solid var(--border);padding-top:10px}.cmt-title{font-weight:700;font-size:13px;margin-bottom:8px}.cmt-list{display:flex;flex-direction:column;gap:10px;margin-bottom:10px}.cmt-item{display:flex;align-items:flex-start;gap:8px}.cmt-body{flex:1;min-width:0}.cmt-head{display:flex;align-items:baseline;gap:6px}.cmt-name{font-weight:600;font-size:13px}.cmt-text{font-size:13px;line-height:1.5;white-space:pre-wrap;word-break:break-word}.cmt-act{flex:none;border:none;background:none;cursor:pointer;font-size:14px;opacity:.55;padding:2px}.cmt-act:hover{opacity:1}.cmt-form{display:flex;gap:8px;align-items:flex-end}.cmt-input{flex:1;border:1px solid var(--border);border-radius:10px;padding:8px 10px;font:inherit;font-size:13px;line-height:1.4;background:var(--surface);color:inherit;resize:vertical}.cmt-input:focus{outline:none;border-color:var(--primary)}.sheet{background:var(--surface);border-radius:16px;padding:8px;width:100%;max-width:360px;display:flex;flex-direction:column;gap:2px;box-shadow:0 10px 40px #0003}.sheet-title{font-weight:700;font-size:13px;padding:8px 12px;color:var(--muted)}.sheet-item{border:none;background:none;text-align:left;padding:13px 12px;font:inherit;font-size:15px;color:inherit;cursor:pointer;border-radius:10px}.sheet-item:active{background:var(--subtle)}.sheet-item.danger{color:var(--danger)}.report-sheet{max-width:340px}.report-done{padding:22px 12px;text-align:center;font-weight:600;font-size:14px}.inline-menu{display:flex;flex-direction:column;gap:2px;background:var(--subtle);border-radius:12px;padding:4px}.modal-more{font-size:18px;flex:none}.avatar.xs{width:28px;height:28px;font-size:13px}.xsmall{font-size:11px}.row-actions{display:flex;gap:8px}.row-actions>.btn{flex:1}.blocked-row{display:flex;align-items:center;gap:10px}.blocked-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:14px}.modal-head{display:flex;align-items:center;gap:10px}.modal-head .tl-name{flex:1;font-size:16px}.modal-x{font-size:16px}.detail-row{display:flex;gap:10px;font-size:14px;padding:6px 0;border-top:1px solid var(--border)}.detail-label{flex:none;width:72px;color:var(--muted);font-size:13px}.detail-val{flex:1;min-width:0;font-weight:600;word-break:break-word}.celebrate{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#1c25228c;display:flex;align-items:center;justify-content:center;padding:24px;overflow:hidden;animation:fade-in .2s ease}.confetti{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.confetti-piece{position:absolute;top:-8%;animation-name:confetti-fall;animation-timing-function:linear;animation-iteration-count:infinite}.celebrate-card{position:relative;background:var(--surface);border-radius:20px;padding:28px 24px;max-width:340px;width:100%;text-align:center;box-shadow:0 12px 40px #0000004d;animation:pop-in .4s cubic-bezier(.18,.89,.32,1.28)}.celebrate-emoji{font-size:34px;letter-spacing:2px}.celebrate-title{font-size:20px;font-weight:800;margin-top:8px;color:var(--primary-dark)}.celebrate-name{font-size:15px;font-weight:700;margin-top:10px}.celebrate-pass{font-size:28px;font-weight:900;color:var(--warn);margin:2px 0 6px;transform:rotate(-3deg)}.celebrate-card .btn{margin-top:14px}@keyframes fade-in{0%{opacity:0}}@keyframes pop-in{0%{opacity:0;transform:scale(.7) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes confetti-fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(110vh) rotate(540deg);opacity:.9}}.empty{text-align:center;padding:48px 16px}.empty-emoji{font-size:44px;margin:0 0 8px}.empty h2{margin:8px 0;font-size:18px}.empty .btn{margin-top:16px}.signin{min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px}.signin-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:32px 24px;max-width:360px;width:100%;text-align:center}.signin-card .muted{margin:16px 0;font-size:14px}
