@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;600;700&family=Zen+Kaku+Gothic+New:wght@400;500;700&display=swap";*{margin:0;padding:0}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;line-height:1.6;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color-scheme:light;color:#0f172a;background-color:#f6f8fb;--bg-0: #f6f8fb;--bg-1: #ffffff;--surface: #ffffff;--surface-2: #f8fafc;--text: #0f172a;--text-muted: #64748b;--border: #e2e8f0;--accent: #1d4ed8;--accent-weak: rgba(29, 78, 216, .12);--shadow-xs: 0 2px 8px rgba(15, 23, 42, .04);--shadow-sm: 0 8px 24px rgba(15, 23, 42, .06);--shadow-md: 0 12px 30px rgba(15, 23, 42, .08);--radius-lg: 16px;--radius-md: 12px;--radius-sm: 10px;--ring: 0 0 0 3px rgba(29, 78, 216, .2);--app-tabbar-safe: max(8px, env(safe-area-inset-bottom));--app-tabbar-total: calc(64px + 8px + var(--app-tabbar-safe));touch-action:manipulation;-webkit-tap-highlight-color:transparent}html,body{box-sizing:border-box}*,*:before,*:after{box-sizing:inherit}body{margin:0;min-width:320px;min-height:100vh;color:var(--text);background:var(--bg-0);overflow-x:hidden;padding-bottom:env(safe-area-inset-bottom)}a{font-weight:600;color:var(--accent);text-decoration:none}a:hover{color:#1e40af}img{max-width:100%;display:block}@media(max-width:640px){:root{font-size:14px}}h1,h2,h3,h4,h5,h6{line-height:1.2}button,select,input,textarea{font-family:inherit}button{border-radius:var(--radius-sm);border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:600;background-color:var(--surface);color:var(--text);cursor:pointer;transition:transform .1s ease,box-shadow .15s ease,border-color .2s ease}button:focus,button:focus-visible,input:focus,input:focus-visible,select:focus,select:focus-visible,textarea:focus,textarea:focus-visible{outline:none;box-shadow:var(--ring)}.app-shell{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-0);color:var(--text)}.app-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 20px;background:#ffffffeb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}.app-brand{font-weight:700;letter-spacing:.02em;font-size:16px;color:var(--text)}.app-nav{display:flex;gap:12px}.app-nav__link{padding:8px 10px;border-radius:10px;color:#334155;text-decoration:none;font-weight:600;transition:background-color .15s ease,color .15s ease}.app-nav__link:hover{background:var(--surface-2);color:var(--text)}.app-nav__link--active{background:var(--accent);color:#f8fafc;box-shadow:var(--shadow-xs)}.app-main{flex:1;padding:16px 16px 88px}.app-tabbar{position:fixed;bottom:0;left:0;right:0;height:64px;display:none;align-items:center;justify-content:space-around;background:var(--surface);border-top:1px solid var(--border);box-shadow:0 -6px 16px #0f172a0f;z-index:10;padding-bottom:var(--app-tabbar-safe)}.app-tabbar__link{flex:1;text-align:center;text-decoration:none;color:#475569;font-weight:600;padding:10px 0}.app-tabbar__link--active{color:var(--accent)}.app-tabbar__label{display:block;font-size:13px}@media(max-width:768px){.app-nav{display:none}.app-tabbar{display:flex}.app-main{padding:12px;padding-bottom:calc(var(--app-tabbar-total) + 8px)}}.home-root{min-height:100vh;width:100%;background:linear-gradient(180deg,var(--bg-0) 0%,var(--surface-2) 100%);display:flex;flex-direction:column;align-items:center;padding:6rem 1.25rem;box-sizing:border-box;color:var(--text)}.home-hero{width:100%;display:flex;justify-content:center;margin-bottom:3.5rem}.hero-inner{max-width:1120px;width:100%;text-align:center}.hero-title{font-size:3.25rem;line-height:1.02;font-weight:700;margin:0;letter-spacing:-.02em}.hero-sub{margin-top:.875rem;color:var(--text-muted);font-size:.875rem;letter-spacing:.08em}.features-wrap{width:100%;display:flex;justify-content:center}.features-grid{width:100%;max-width:1120px;display:grid;grid-template-columns:1fr;gap:1.5rem;align-items:start}@media(min-width:640px){.features-grid{grid-template-columns:repeat(2,1fr);gap:1.75rem}}@media(min-width:1024px){.features-grid{grid-template-columns:repeat(3,1fr);gap:2rem}}.ft-card{display:block;text-decoration:none;color:inherit;background:#fff;border:1px solid var(--border);border-radius:20px;padding:1.25rem;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;box-shadow:var(--shadow-xs)}.ft-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-sm);border-color:var(--accent-weak)}.ft-card-inner{display:flex;gap:1rem;align-items:flex-start}.ft-card-media{flex:0 0 auto}.ft-icon{width:56px;height:56px;border-radius:12px;border:1px solid var(--border);display:inline-flex;align-items:center;justify-content:center;color:var(--accent);font-size:22px}.ft-card-body{flex:1 1 auto;min-width:0}.ft-card-title{margin:0 0 .5rem;font-size:1.0625rem;font-weight:600;color:var(--text);white-space:normal}.ft-card-desc{margin:0;color:var(--text-muted);font-size:.95rem;line-height:1.6}.ft-card-cta{margin-top:1rem;color:var(--accent);font-weight:600;font-size:.9rem}.emoji{display:inline-block;transform:translateY(1px)}@media(max-width:640px){.hero-title{font-size:2rem}.features-grid{gap:1rem}.ft-card{padding:1rem;border-radius:16px}.ft-icon{width:48px;height:48px;border-radius:12px}}*{box-sizing:border-box}body{margin:0;font-family:Space Grotesk,Zen Kaku Gothic New,sans-serif;background:var(--c-bg-body);color:var(--c-text-primary)}h1,h2,h3{margin:0;font-weight:700}button,input,select{font-family:inherit}:root{--c-bg-body: #f7f8fb;--c-bg-surface: #ffffff;--c-text-primary: #101828;--c-text-secondary: #475467;--c-text-tertiary: #98a2b3;--c-accent: #2563eb;--c-accent-strong: #1d4ed8;--c-accent-soft: #e8efff;--c-border: #e4e7ec;--c-shadow: rgba(16, 24, 40, .08)}.cpm-root{max-width:980px;margin:0 auto;padding:24px 18px 160px}.tab-bar{position:fixed;left:50%;bottom:calc(64px + env(safe-area-inset-bottom));transform:translate(-50%);z-index:120;display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:8px;width:min(980px,calc(100% - 24px));border-radius:16px;background:#ffffffe6;border:1px solid var(--c-border);box-shadow:0 6px 18px var(--c-shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tab-btn{display:flex;flex-direction:column;gap:4px;align-items:center;padding:8px 6px;border-radius:12px;color:var(--c-text-tertiary);border:1px solid transparent;background:transparent;transition:all .2s ease}.tab-btn.active{background:var(--c-accent-soft);color:var(--c-text-primary);border-color:var(--c-accent)}.tab-label{font-size:.85rem;font-weight:700}.tab-sub{font-size:.6rem;letter-spacing:.12em;text-transform:uppercase}.measure-root{padding-top:20px;display:flex;flex-direction:column;gap:18px}.measure-hero{display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;padding:20px;border-radius:18px;background:#fff;border:1px solid var(--c-border);box-shadow:0 10px 24px var(--c-shadow)}.measure-hero h1{font-size:1.7rem;margin-bottom:6px}.measure-hero p{margin:0;color:var(--c-text-secondary)}.measure-identity{margin-top:10px;display:flex;flex-direction:column;gap:4px;color:var(--c-text-secondary);font-size:.95rem}.measure-identity strong{color:var(--c-text-primary);font-size:1rem}.measure-stats{display:grid;grid-template-columns:repeat(3,minmax(120px,1fr));gap:12px;min-width:240px}.measure-stats div{background:#fff;padding:12px 14px;border-radius:12px;border:1px solid var(--c-border);box-shadow:inset 0 0 0 1px #fffc}.measure-stats span{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--c-text-tertiary)}.measure-stats strong{display:block;font-size:1.3rem;margin-top:6px}.measure-stats-collapse{background:#fff;border:1px solid var(--c-border);border-radius:12px;padding:10px 12px}.measure-stats-collapse summary{cursor:pointer;font-weight:600;color:var(--c-text-secondary)}.session-setup,.measure-live{background:var(--c-bg-surface);border-radius:18px;border:1px solid var(--c-border);padding:20px;box-shadow:0 8px 20px var(--c-shadow)}.section-title{font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;color:var(--c-text-tertiary);margin-bottom:12px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}label{display:flex;flex-direction:column;gap:6px;font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:var(--c-text-secondary)}input,select{padding:10px 12px;border-radius:12px;border:1px solid var(--c-border);background:#fff;font-size:1rem}.items-block{margin-top:16px}.items-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--c-text-tertiary);margin-bottom:8px}.items-grid{display:grid;grid-template-columns:repeat(3,minmax(70px,1fr));gap:10px}.item-chip{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 8px;border-radius:12px;border:1px solid var(--c-border);background:#fff;cursor:pointer;transition:all .2s ease}.item-chip input{display:none}.item-chip.active{background:var(--c-accent);border-color:var(--c-accent);color:#fff}.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 18px;border-radius:14px;font-weight:700;font-size:1rem;border:none;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease}.btn-primary{background:var(--c-accent);color:#fff;box-shadow:0 10px 20px #2563eb33}.btn-primary:hover{transform:translateY(-1px)}.btn-outline{background:#fff;border:1px solid var(--c-border);color:var(--c-text-primary)}.btn-ghost{background:transparent;color:var(--c-text-secondary)}.btn-start{margin-top:16px;width:100%}.btn-delete{font-size:.75rem;color:#667085;border:1px solid #e4e7ec;background:#fff;padding:6px 10px;border-radius:999px}.btn-delete:hover{border-color:#d0d5dd;color:#344054}.session-bar{display:flex;justify-content:space-between;gap:16px;padding:12px;border-radius:14px;background:#fff;border:1px solid var(--c-border);margin-bottom:16px}.session-label{font-size:1rem;font-weight:700}.session-items{font-size:.8rem;color:var(--c-text-tertiary)}.session-counts{display:flex;gap:12px}.session-counts span{font-size:.7rem;text-transform:uppercase;color:var(--c-text-tertiary)}.session-counts strong{display:block;font-size:1.2rem}.stopwatch-block{display:flex;flex-direction:column;align-items:center;gap:16px;padding:20px 0 10px}.stopwatch-display{font-size:4.5rem;font-weight:700;letter-spacing:.05em;font-variant-numeric:tabular-nums;color:var(--c-text-primary)}.stopwatch-display.running{color:var(--c-accent);text-shadow:0 0 16px rgba(37,99,235,.25)}.stopwatch-controls{display:flex;gap:12px}.coin-input-block{display:flex;flex-direction:column;gap:8px}.coin-input{font-size:2.4rem;font-weight:700;letter-spacing:.04em;text-align:center;padding:16px 18px;border-radius:18px;background:#fff;border:2px solid #dbe4ff}.save-bar{margin-top:12px;display:flex;flex-direction:column;gap:8px;padding:14px;border-radius:16px;background:#fff;border:1px solid var(--c-border);box-shadow:0 12px 24px #1018281f}.btn-save{width:100%;font-size:1.2rem;padding:16px 18px}.only-desktop{display:block}.only-mobile{display:none}.save-meta{display:flex;justify-content:space-between;font-size:.85rem;color:var(--c-text-secondary)}.inline-error{color:#b42318;font-weight:600;margin-top:8px}.session-complete{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:30}.session-complete-card{background:#fff;padding:24px;border-radius:20px;max-width:380px;width:90%;text-align:center;box-shadow:0 20px 40px #10182833}.session-complete-card h3{margin-bottom:16px}.complete-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:16px}.complete-grid span{font-size:.75rem;text-transform:uppercase;color:var(--c-text-tertiary)}.complete-grid strong{display:block;font-size:1.3rem;margin-top:6px}.ranking-root,.analysis-root{padding-top:20px}.ranking-header,.analysis-header{display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;background:#fff;border-radius:16px;padding:18px;border:1px solid var(--c-border);margin-bottom:16px}.ranking-header h1,.analysis-header h1{margin-bottom:6px}.sort-select select{margin-top:6px}.ranking-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}.ranking-card{background:#fff;border-radius:16px;padding:16px;border:1px solid var(--c-border);box-shadow:0 8px 18px var(--c-shadow)}.card-terminal{margin-top:6px;font-size:.85rem;color:var(--c-text-secondary)}.rank-badge{font-weight:700;color:var(--c-accent)}.chip-row{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0 12px}.chip{padding:4px 8px;border-radius:999px;background:#f2f4f7;color:var(--c-text-primary);font-size:.7rem}.card-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.card-stats span{font-size:.7rem;text-transform:uppercase;color:var(--c-text-tertiary)}.card-stats strong{font-size:1.1rem}.card-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;color:var(--c-text-secondary);font-size:.8rem}.ranking-table-wrap{margin-top:20px;overflow-x:auto;border-radius:16px;border:1px solid var(--c-border);background:#fff}.ranking-table{width:100%;border-collapse:collapse;min-width:900px}.ranking-table th,.ranking-table td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--c-border);font-size:.85rem}.analysis-summary{display:flex;gap:16px}.analysis-summary span{font-size:.7rem;text-transform:uppercase;color:var(--c-text-tertiary)}.analysis-summary strong{display:block;font-size:1.2rem}.analysis-grid{display:grid;grid-template-columns:minmax(220px,320px) 1fr;gap:18px}.session-list{display:flex;flex-direction:column;gap:12px}.session-card{background:#fff;border:1px solid var(--c-border);border-radius:16px;padding:14px;text-align:left;cursor:pointer;box-shadow:0 6px 16px var(--c-shadow)}.session-card.active{border-color:var(--c-accent);box-shadow:0 8px 24px #2563eb2e}.condition-card{background:#fff;border:1px solid var(--c-border);border-radius:16px;padding:14px;text-align:left;cursor:pointer;box-shadow:0 6px 16px var(--c-shadow)}.condition-card.active{border-color:var(--c-accent);box-shadow:0 8px 24px #2563eb2e}.condition-card-main{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.condition-terminal{font-size:.8rem;color:var(--c-text-secondary);margin-top:6px}.session-card-main{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.session-title{font-weight:700}.session-meta{font-size:.75rem;color:var(--c-text-tertiary)}.session-actions{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.session-count{font-size:.85rem;color:var(--c-text-secondary)}.session-items{display:flex;flex-wrap:wrap;gap:6px;margin:10px 0}.session-stats{display:grid;grid-template-columns:repeat(2,minmax(90px,1fr));gap:10px}.session-stats span{font-size:.7rem;text-transform:uppercase;color:var(--c-text-tertiary)}.session-stats strong{font-size:1.1rem}.session-detail,.condition-detail{background:#fff;border-radius:18px;border:1px solid var(--c-border);padding:18px;box-shadow:0 8px 24px var(--c-shadow)}.condition-detail-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.condition-meta{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px;color:var(--c-text-secondary);font-size:.85rem}.session-detail-sub{color:var(--c-text-secondary);margin-top:4px}.session-detail-stats{display:grid;grid-template-columns:repeat(4,minmax(120px,1fr));gap:10px;margin:12px 0 6px}.session-detail-stats div{background:#fff;border:1px solid var(--c-border);border-radius:12px;padding:10px 12px}.session-detail-stats span{font-size:.7rem;text-transform:uppercase;color:var(--c-text-tertiary);letter-spacing:.08em}.session-detail-stats strong{display:block;font-size:1.1rem;margin-top:6px}.chart-wrap{margin:12px 0 16px;background:#f8fafc;border-radius:12px;padding:10px}.play-list{display:grid;gap:8px}.play-row{display:grid;grid-template-columns:60px 80px 1fr 1fr auto;gap:10px;padding:10px 12px;border-radius:12px;border:1px solid var(--c-border);background:#fff;font-size:.85rem}.play-row .btn-delete{justify-self:end}.play-index{font-weight:700}.play-cpm{text-align:right;font-weight:700}@media(max-width:768px){.cpm-root{padding:16px 14px 170px}.tab-bar{bottom:var(--app-tabbar-total)}.measure-hero{flex-direction:column}.measure-stats{grid-template-columns:repeat(2,1fr)}.only-desktop{display:none}.only-mobile{display:block}.items-grid{grid-template-columns:repeat(3,1fr)}.stopwatch-display{font-size:3.6rem}.save-bar{position:sticky;bottom:12px}.save-meta{flex-direction:column;gap:4px}.analysis-grid{grid-template-columns:1fr}.session-detail-stats{grid-template-columns:repeat(2,minmax(120px,1fr))}.ranking-table-wrap{display:none}.play-row{grid-template-columns:50px 70px 1fr auto}.play-cpm{text-align:left}}@media(min-width:768px){.cpm-root{padding-bottom:80px}.tab-bar{position:sticky;top:0;bottom:auto;left:auto;transform:none;width:100vw;margin:0 0 0 calc(50% - 50vw);background:#fff;-webkit-backdrop-filter:none;backdrop-filter:none;border-radius:0 0 16px 16px;display:flex;justify-content:center;gap:12px}.tab-bar .tab-btn{min-width:120px;max-width:220px}}.layout{min-height:100vh;display:flex;flex-direction:column}.layout__main{flex:1;padding:16px 8px 160px}.header{display:none;background:#fff;border-bottom:1px solid #f5f5f5;padding:0 24px;height:64px;position:sticky;top:0;z-index:100}.header__inner{max-width:1200px;margin:0 auto;height:100%;display:flex;align-items:center;justify-content:space-between}.header__title{font-size:1.125rem;font-weight:600;color:#111;margin:0;letter-spacing:-.01em}.header__nav{display:flex;gap:8px}.header__link{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:10px;font-size:.8125rem;font-weight:500;color:#999;text-decoration:none;transition:all .15s ease}.header__link:hover{background:#fafafa;color:#111}.header__link--active{background:#f5f5f5;color:#111}.header__icon{width:18px;height:18px}.settings-button{background:transparent;border:none;padding:8px;border-radius:10px;cursor:pointer}.settings-button:hover{background:#fafafa}.settings-button--mobile{position:fixed;top:calc(12px + env(safe-area-inset-top));right:12px;z-index:500;background:#fafafa;border:none;padding:8px;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center}.settings-button--mobile:hover{background:#f5f5f5}@media(min-width:768px){.settings-button--mobile{display:none}}.tabbar{display:flex;position:fixed;bottom:64px;left:0;right:0;background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(0,0,0,.04);padding:8px 0;padding-bottom:max(8px,env(safe-area-inset-bottom));z-index:100}.tabbar__link{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px;text-decoration:none;color:#bbb;transition:all .2s ease}.tabbar__link[type=button]{appearance:none;background:transparent;border:none;cursor:pointer}.tabbar__link--active{color:#111}.tabbar__icon{width:24px;height:24px}.tabbar__label{font-size:.6875rem;font-weight:500;letter-spacing:.02em}@media(min-width:768px){.header{display:block}.tabbar{display:none}.layout__main{padding:32px 24px}}.settings-panel{position:fixed;top:0;right:0;width:320px;max-width:90%;height:100%;background:#fff;box-shadow:-8px 0 32px #00000008;transform:translate(100%);transition:transform .25s ease;z-index:400;display:flex;flex-direction:column}.settings-panel--open{transform:translate(0)}.settings-panel__header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid #f5f5f5}.settings-panel__body{padding:20px;flex:1;overflow:auto}@media(min-width:900px){.settings-panel{width:720px;max-width:60%}}.settings-panel__footer{padding:16px 20px;border-top:1px solid #f5f5f5;display:flex;gap:8px;justify-content:flex-end}.settings-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.settings-row__label{font-size:.875rem;color:#111;margin-right:8px;font-weight:400}.settings-panel__close{background:transparent;border:none;font-size:18px;cursor:pointer}.btn{padding:10px 16px;border-radius:10px;border:none;font-size:.8125rem;font-weight:500}.btn--ghost{background:#fafafa;color:#666}.btn--ghost:hover{background:#f5f5f5}.btn--primary{background:#111;color:#fff}.btn--primary:hover{background:#222}.settings-row{gap:12px}.settings-row>*:not(.settings-row__label){min-width:0;flex:1}.ocr-controls{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.ocr-controls label{display:flex;flex-direction:column;align-items:flex-start}.ocr-note{margin-top:6px;font-size:12px;color:#6b7280}.weekday-goals{display:grid;grid-template-columns:1fr;gap:6px 12px}.weekday-goals__header{display:grid;grid-template-columns:120px 1fr 1fr;gap:12px;align-items:center;position:sticky;top:0;background:#fff;z-index:20;padding:8px 0;border-bottom:1px solid #f1f5f9}.weekday-goals__col-header{font-size:.875rem;color:#111827;font-weight:600}.weekday-goals__item{display:grid;grid-template-columns:120px 1fr 1fr;gap:12px;align-items:center;padding:10px 0;border-bottom:1px solid #f5f7fa}.weekday-goals__label{width:120px;font-weight:600;color:#111827}.weekday-goals__cell{display:flex;align-items:center;gap:8px}.weekday-goals__hint{font-size:12px;color:#6b7280;min-width:36px}.weekday-goals__input{width:100%;max-width:160px;padding:6px 8px;border-radius:8px;border:1px solid #e6e6e6;text-align:right}@media(max-width:600px){.weekday-goals{display:flex;flex-direction:column;gap:10px}.weekday-goals__header{display:none}.weekday-goals__item{display:flex;flex-direction:column;gap:8px;padding:12px;border:1px solid #f1f5f9;border-radius:10px;background:#fff}.weekday-goals__label{font-weight:700;margin-bottom:6px}.weekday-goals__cell{flex-direction:column;align-items:stretch}.weekday-goals__hint{color:#9ca3af}.weekday-goals__input{max-width:100%}}@media(max-width:600px){.settings-row{flex-direction:column;align-items:stretch}.settings-row__label{margin-bottom:8px}.ocr-controls label{flex:1 1 48%;min-width:120px}.ocr-note{width:100%}}.register-page{max-width:480px;margin:0 auto}.register-page__header{text-align:center;margin-bottom:64px}.register-page__title{font-size:1.125rem;font-weight:600;color:#111;margin:0 0 8px;letter-spacing:-.01em}.register-page__subtitle{font-size:.6875rem;color:#999;margin:0;text-transform:uppercase;letter-spacing:.12em}.register-card{background:transparent;border-radius:0;padding:0;box-shadow:none;border:none}.form-group{margin-bottom:32px}.form-group:last-child{margin-bottom:0}.form-label{display:block;font-size:.6875rem;font-weight:500;color:#999;margin-bottom:12px;text-transform:uppercase;letter-spacing:.08em;text-align:center}.form-input{width:100%;padding:14px 16px;font-size:1rem;border:1px solid #f0f0f0;border-radius:12px;background:#fafafa;color:#111;transition:all .15s ease;box-sizing:border-box}.form-input:focus{outline:none;border-color:#e5e5e5;background:#fff}.form-input--large{font-size:3rem;font-weight:800;text-align:center;padding:32px 16px;letter-spacing:-.03em;border-radius:16px}input[type=date].form-input,input[type=date]{-webkit-appearance:none;-moz-appearance:none;appearance:none;color:#111827;background:#f9fafb;padding:10px 12px;max-width:100%}input[type=date]::-webkit-calendar-picker-indicator{right:8px;opacity:.8}.form-group{margin-bottom:24px;overflow:hidden}.mode-selector{display:flex;gap:8px;justify-content:center}.mode-button{flex:1;max-width:100px;padding:10px 12px;font-size:.8125rem;font-weight:500;border:none;border-radius:10px;background:#fafafa;color:#999;cursor:pointer;transition:all .15s ease}.mode-button:hover{background:#f5f5f5}.mode-button--add.mode-button--active,.mode-button--premium.mode-button--active,.mode-button--other.mode-button--active,.mode-button--serebo.mode-button--active,.mode-button--pick.mode-button--active{background:#111;color:#fff}.last-coin-info{display:flex;flex-direction:column;align-items:center;padding:0;background:transparent;border-radius:0;margin-bottom:64px;border-top:none;border-bottom:none;gap:8px}.last-coin-info__label{font-size:.6875rem;color:#999;text-transform:uppercase;letter-spacing:.12em;font-weight:500;order:2}.last-coin-info__value{font-size:3rem;font-weight:800;color:#111;letter-spacing:-.03em;order:1}.last-coin-info__value-main{line-height:1}.last-record-date{font-size:.6875rem;color:#999;margin-top:4px;line-height:1}.last-record-date--outside{font-size:.75rem;color:#999;text-align:center;margin:0 0 32px}.submit-button{width:100%;padding:16px;font-size:.875rem;font-weight:600;color:#111;background:#f5f5f5;box-shadow:none;border:none;border-radius:12px;cursor:pointer;transition:all .15s ease}.submit-button:hover{background:#eee}.submit-button:active{transform:scale(.98)}.submit-button:disabled{background:#fafafa;color:#ccc;cursor:not-allowed;transform:none}.submit-button--undo{width:auto;padding:8px 12px;font-size:.75rem;font-weight:500;color:#dc2626;background:transparent;border:1px solid #eee;border-radius:6px;cursor:pointer;box-shadow:none;display:block;margin:8px auto 0}.submit-button--undo:hover{background:#fafafa;border-color:#ddd}.submit-button--undo:active{transform:translateY(0)}.submit-button--muted{background:#fafafa;color:#666;box-shadow:none;border:1px solid #eee;padding:10px;font-size:.8125rem;font-weight:500;border-radius:6px;cursor:pointer}.submit-button--muted:hover{transform:none;background:#f5f5f5;border-color:#ddd}.submit-button--muted:active{transform:none}.error-message{padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#dc2626;font-size:.875rem;margin-bottom:24px}.success-message{padding:12px 16px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px;color:#15803d;font-size:.875rem;margin-bottom:24px;text-align:center}.diff-preview{display:flex;justify-content:center;align-items:center;gap:8px;padding:20px;background:transparent;border-radius:0;margin-bottom:32px}.diff-preview__value{font-size:1.75rem;font-weight:700;letter-spacing:-.02em}.diff-preview__value--positive{color:#111}.diff-preview__value--negative{color:#dc2626}.diff-preview__label{font-size:.875rem;color:#666}.calendar{background:transparent;border-radius:0;padding:0;box-shadow:none;border:none;max-width:100%;overflow-x:hidden;box-sizing:border-box}.calendar__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}.calendar__title{font-size:.875rem;font-weight:600;color:#111;margin:0;letter-spacing:-.01em}.calendar__nav-button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;border-radius:8px;background:#fafafa;cursor:pointer;transition:all .15s ease}.calendar__nav-button:hover{background:#f5f5f5}.calendar__nav-button:focus{outline:2px solid #059669;outline-offset:2px}.calendar__nav-button svg{width:14px;height:14px;stroke:#666}.calendar__weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px;width:100%;box-sizing:border-box}.calendar__weekday{text-align:center;font-size:.75rem;font-weight:500;color:#9ca3af;padding:8px 0}.calendar__weekday:nth-child(6){color:#3b82f6}.calendar__weekday:last-child{color:#ef4444}.calendar__days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;width:100%;box-sizing:border-box}.calendar__day{aspect-ratio:1;min-height:60px;padding:8px 6px;border-radius:6px;background:transparent;display:flex;flex-direction:column;overflow:visible;position:relative}.calendar__day--empty{background:transparent}.calendar__day--today{background:#f8f8f8;border:1px solid #e5e5e5}.calendar__day--has-data{background:#fcfcfc;border:1px solid #f5f5f5}.calendar__day-number{font-size:.6875rem;font-weight:600;color:#999;margin-bottom:4px}.calendar__day--today .calendar__day-number{color:#111;font-weight:700}.calendar__day-stats{flex:1;display:flex;flex-direction:column;justify-content:center;gap:2px;font-size:.625rem}.calendar__stat{display:flex;align-items:center;white-space:nowrap;overflow:hidden;font-weight:600}.calendar__stat--earned{color:#111}.calendar__stat--spent{color:#999}@media(max-width:480px){.calendar__day{min-height:50px}.calendar__day-stats{font-size:.5625rem}}@media(max-width:640px){.calendar{padding:0;width:100%;max-width:100%;box-sizing:border-box;overflow-x:hidden}.calendar__header{margin-bottom:16px;gap:8px}.calendar__weekdays{grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:6px;width:100%}.calendar__days{grid-template-columns:repeat(7,1fr);gap:2px;grid-auto-rows:minmax(40px,auto);width:100%}.calendar__day{aspect-ratio:auto;min-height:40px;padding:4px;border-radius:4px}.calendar__day-number{font-size:.625rem;margin-bottom:2px}.calendar__day-stats{font-size:.5rem;gap:1px}.calendar__stat{white-space:nowrap;line-height:1.2}.calendar__nav-button{width:28px;height:28px}.calendar__title{font-size:.875rem}}.calendar__popover{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:8px;background:#fff;border:1px solid #f0f0f0;border-radius:12px;padding:16px;min-width:180px;z-index:10;box-shadow:0 8px 24px #0000000a,0 2px 8px #00000005;animation:popoverFadeIn .2s ease}@keyframes popoverFadeIn{0%{opacity:0;transform:translate(-50%) translateY(-4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.calendar__popover-title{font-size:.6875rem;font-weight:600;color:#111;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #f8f8f8;text-transform:uppercase;letter-spacing:.08em}.calendar__popover-item{display:flex;align-items:center;gap:10px;padding:8px 0;font-size:.875rem}.calendar__popover-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.calendar__popover-item--earned .calendar__popover-dot{background:#111}.calendar__popover-item--premium .calendar__popover-dot{background:#ef4444}.calendar__popover-item--serebo .calendar__popover-dot{background:#3b82f6}.calendar__popover-item--pick .calendar__popover-dot{background:#8b5cf6}.calendar__popover-item--other .calendar__popover-dot{background:#f59e0b}.calendar__popover-label{flex:1;color:#666;font-size:.8125rem;font-weight:500}.calendar__popover-value{color:#111;font-weight:700;font-size:.875rem;letter-spacing:-.01em}@media(max-width:640px){.calendar__popover{bottom:100%;top:auto;margin-bottom:8px;margin-top:0}@keyframes popoverFadeIn{0%{opacity:0;transform:translate(-50%) translateY(4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}}.today-hero{background:#f6f7f9;text-align:center;padding:clamp(32px,6vw,48px) 16px;margin:0 0 48px;min-height:40vh;display:flex;flex-direction:column;justify-content:center;align-items:center}.today-hero__label{font-size:.6875rem;font-weight:500;color:#999;letter-spacing:.15em;margin-bottom:16px;text-transform:uppercase}.today-hero__value{font-size:clamp(3.5rem,12vw,7rem);font-weight:800;color:#111;letter-spacing:-.04em;line-height:1;margin-bottom:12px;font-variant-numeric:tabular-nums}.today-hero__diff{font-size:.9375rem;font-weight:500;color:#666;margin-top:8px}.today-hero__diff--positive{color:#059669}.today-hero__diff--negative{color:#dc2626}@media(max-width:768px){.today-hero{margin:0 -16px;padding:clamp(24px,8vw,40px) 16px;min-height:35vh}.today-hero__label{font-size:.625rem;margin-bottom:12px}.today-hero__diff{font-size:.875rem}}.stats-page{max-width:840px;margin:0 auto;background:#fff}.stats-page__content{padding:0 24px;max-width:680px;margin:0 auto}.stats-page__empty{padding:48px 24px;min-height:60vh;display:flex;align-items:center;justify-content:center}.stats-section{margin-bottom:80px}.stats-section--compact{margin-bottom:24px}.stats-section__title{font-size:.6875rem;font-weight:500;color:#999;margin:0 0 24px;text-transform:uppercase;letter-spacing:.12em;text-align:center}.stats-section__goal{font-size:.875rem;color:#666;margin:0 0 16px;font-weight:500;text-align:center}.stats-section__today{margin-top:8px;font-size:.875rem;color:#666;font-weight:500;text-align:center}.stats-section__today--done{color:#059669}.stats-section__target{margin-top:6px;font-size:.8125rem;font-weight:400;color:#999;text-align:center}.stats-section__toggle{background:transparent;border:1px solid #ECECEC;padding:10px 24px;border-radius:20px;font-size:.75rem;color:#666;cursor:pointer;font-weight:500;transition:all .2s ease}.stats-section__toggle:hover{background:#fafafa;border-color:#ddd}.stats-section__toggle:focus{outline:2px solid #059669;outline-offset:2px}.stats-section__toggle--under{display:block;margin:16px auto 0}.stats-simple-card{text-align:center;padding:32px 16px;border-bottom:1px solid #ECECEC}.stats-simple-card__label{font-size:.75rem;font-weight:500;color:#999;margin-bottom:12px;letter-spacing:.05em}.stats-simple-card__value{font-size:2rem;font-weight:700;color:#111;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.stats-card{background:transparent;border-radius:0;padding:0;box-shadow:none;border:none}.chart-container{width:100%;height:220px;padding:16px 0}.chart-container{position:relative}.chart-sparkles{position:absolute;inset:0;pointer-events:none}.chart-sparkle{position:absolute;width:14px;height:14px;transform:translate(-50%,-50%)}.pie-chart-container{width:100%;height:280px;display:flex;align-items:center;justify-content:center;padding:16px 0}.total-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:40px 24px;padding:24px 0}.total-stat{text-align:center;padding:0;border-radius:0;background:transparent}.total-stat__label{font-size:.6875rem;font-weight:400;color:#999;margin-bottom:12px;text-transform:uppercase;letter-spacing:.08em;display:block}.total-stat__value{font-size:1.875rem;font-weight:700;color:#111;letter-spacing:-.02em;font-variant-numeric:tabular-nums;display:block}.total-stat--earned .total-stat__value{color:#111}.total-stat--premium .total-stat__value,.total-stat--other .total-stat__value,.total-stat--serebo .total-stat__value,.total-stat--pick .total-stat__value{color:#dc2626}.period-stats-table{width:100%;border-collapse:collapse;margin:8px 0}.period-stats-table th,.period-stats-table td{padding:18px 12px;text-align:right;font-size:.875rem}.period-stats-table th{font-weight:500;color:#999;border-bottom:1px solid #ECECEC;font-size:.6875rem;text-transform:uppercase;letter-spacing:.08em}.period-stats-table th:first-child,.period-stats-table td:first-child{text-align:left;font-weight:500}.period-stats-table td{color:#111;font-weight:600;border-bottom:1px solid #f8f8f8;font-variant-numeric:tabular-nums}.period-stats-table tbody tr:hover{background:#fafafa}.period-stats-table__earned{color:#111!important}.period-stats-table__premium,.period-stats-table__other,.period-stats-table__serebo,.period-stats-table__pick{color:#dc2626!important}.data-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;padding:8px 0}.data-button{flex:0 0 auto;min-width:140px;padding:12px 24px;font-size:.8125rem;font-weight:500;border-radius:24px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px;border:1px solid #ECECEC}.data-button--export{background:transparent;color:#111}.data-button--export:hover{background:#fafafa}.data-button--import{background:transparent;color:#666}.data-button--import:hover{background:#fafafa}.data-button:focus{outline:2px solid #059669;outline-offset:2px}.data-button svg{width:18px;height:18px}.hidden-input{display:none}.stats-message{padding:12px 16px;border-radius:8px;font-size:.875rem;margin:24px 24px 0;border:1px solid}.stats-message--success{background:#f0fdf4;border-color:#bbf7d0;color:#15803d}.stats-message--error{background:#fef2f2;border-color:#fecaca;color:#dc2626}.empty-state{text-align:center;padding:48px 20px;color:#999;font-size:.875rem}.empty-state__icon{width:48px;height:48px;margin:0 auto 16px;stroke:#ddd}.empty-state__text{font-size:.875rem;margin:0;line-height:1.6}.stats-section__debt{text-align:center;padding:16px}.weekly-progress{padding:16px}.weekly-progress__summary{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}.weekly-progress__value{font-size:1.25rem;font-weight:700;color:#111}.weekly-progress__rate{font-size:1rem;font-weight:700;color:#059669}.weekly-progress__bar{position:relative;height:28px;background:linear-gradient(90deg,#f3f4f6,#f8fafc);border-radius:14px;overflow:hidden}.weekly-progress__fill{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,#10b981,#059669);border-radius:14px 0 0 14px;transition:width .5s ease}.weekly-progress__marker{position:absolute;top:-6px;width:2px;height:40px;transform:translate(-50%)}.weekly-progress__marker--primary{background:#16a34a}.weekly-progress__marker--secondary{background:#d4af37}.weekly-progress__info{margin-top:12px;font-size:.95rem;color:#444}.weekly-progress__daily{margin-top:6px;font-size:.85rem;color:#666}@media(max-width:768px){.stats-page__content{padding:0 16px}.stats-section{margin-bottom:64px}.stats-section--compact{margin-bottom:16px}.stats-simple-card{padding:24px 16px}.stats-simple-card__value{font-size:1.75rem}.total-stats{grid-template-columns:repeat(2,1fr);gap:32px 24px}.total-stat:first-child{grid-column:1 / -1}.total-stat__value{font-size:1.5rem}.period-stats-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.period-stats-table th,.period-stats-table td{padding:14px 10px;font-size:.8125rem;white-space:nowrap}.chart-container{height:200px}.pie-chart-container{height:240px}.stats-message{margin:16px 16px 0}}@media(max-width:480px){.stats-page__content{padding:0 8px}.stats-simple-card__value{font-size:1.5rem}.total-stat__value{font-size:1.25rem}.data-button{min-width:120px;padding:10px 20px;font-size:.75rem}}.goal-with-sparkles{position:relative;display:inline-block}.sparkles{position:absolute;inset:0;pointer-events:none;overflow:visible}.sparkle{position:absolute;width:12px;height:12px;opacity:0;transform:translateY(0) scale(.8) rotate(0);animation:sparkle 1.4s ease-in-out infinite}.sparkle svg{width:100%;height:100%;display:block}@keyframes sparkle{0%{opacity:0;transform:translateY(0) scale(.6) rotate(0)}12%{opacity:1;transform:translateY(-6px) scale(1.05) rotate(15deg)}60%{opacity:.9;transform:translateY(-16px) scale(1) rotate(30deg)}to{opacity:0;transform:translateY(-28px) scale(.6) rotate(60deg)}}.sparkle--1{left:14%;top:62%;animation-delay:0ms}.sparkle--2{left:30%;top:64%;animation-delay:.12s}.sparkle--3{left:44%;top:58%;animation-delay:.24s}.sparkle--4{left:56%;top:60%;animation-delay:80ms}.sparkle--5{left:70%;top:64%;animation-delay:.2s}.sparkle--6{left:84%;top:58%;animation-delay:.32s}.sync-page{display:flex;justify-content:center;padding:24px 0}.sync-card{width:min(720px,100%);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px;box-shadow:var(--shadow-md)}.sync-title{margin:0 0 16px;font-size:24px;font-weight:800;color:var(--text)}.sync-status{display:flex;flex-direction:column;gap:12px;margin-bottom:8px}.sync-user{font-weight:600;color:var(--text)}.sync-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.btn-primary,.btn-secondary,.btn-ghost{padding:10px 14px;border-radius:var(--radius-sm);font-weight:700;border:none;cursor:pointer;transition:transform .1s ease,box-shadow .15s ease}.btn-primary{background:linear-gradient(135deg,#1d4ed8,#2563eb);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled{opacity:.6;cursor:not-allowed;box-shadow:none;transform:none}.btn-secondary{background:#0f172a;color:#fff;box-shadow:var(--shadow-sm)}.btn-ghost{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}.btn-primary:not(:disabled):active,.btn-secondary:not(:disabled):active,.btn-ghost:not(:disabled):active{transform:translateY(1px)}.sync-remaining{margin-top:8px;font-weight:700;color:var(--text)}.sync-message{margin-top:10px;padding:10px 12px;border-radius:var(--radius-sm);font-weight:600}.sync-message--ok{background:#eff6ff;color:#1e3a8a;border:1px solid #bfdbfe}.sync-message--error{background:#fef2f2;color:#991b1b;border:1px solid #fecdd3}@media(max-width:640px){.sync-card{padding:16px;border-radius:12px}.sync-actions{flex-direction:column;align-items:stretch}.sync-actions button{width:100%}}.tsum-page{max-width:1280px;margin:0 auto;padding:16px;color:var(--text);background:var(--bg-0);font-family:Noto Sans JP,Segoe UI,system-ui,-apple-system,sans-serif}.tsum-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);box-shadow:var(--shadow-xs)}.tsum-header h1{margin:4px 0 0;font-size:20px}.eyebrow{margin:0;font-size:12px;letter-spacing:.08em;color:var(--text-muted)}.header-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}button,select,input{font-family:inherit}.tsum-page{color-scheme:light}input,select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-color:var(--surface);color:var(--text)}select option{background-color:var(--surface);color:var(--text)}.ghost-btn,.danger-btn,.file-btn{border:1px solid var(--border);background:var(--surface);padding:8px 12px;border-radius:10px;font-weight:600;color:var(--text);cursor:pointer;transition:all .2s ease}.ghost-btn:hover,.file-btn:hover{border-color:var(--accent);color:var(--accent)}.danger-btn{border-color:#ef4444;color:#b91c1c}.danger-btn:hover{background:#fef2f2}.file-btn{position:relative;overflow:hidden}.file-btn input{position:absolute;inset:0;opacity:0;cursor:pointer}.toolbar{margin-top:16px;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:space-between;gap:12px}.search{flex:1;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px}.gacha-panel{margin-top:16px;padding:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:10px;box-shadow:var(--shadow-xs)}.gacha-head h2{margin:0;font-size:18px}.gacha-head p{margin:4px 0 0;color:var(--text-muted);font-size:13px}.gacha-input-row{display:flex}.gacha-results{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:8px}.gacha-item{display:flex;justify-content:space-between;align-items:center;gap:8px;border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;background:var(--surface-2);cursor:pointer;transition:all .15s ease}.gacha-item:hover{border-color:var(--accent);box-shadow:var(--shadow-sm)}.gacha-name{font-weight:700;color:var(--text)}.gacha-meta{display:flex;flex-direction:column;gap:2px;align-items:flex-end;color:var(--text-muted);font-size:13px}.gacha-meta-line{display:inline-flex;align-items:baseline;gap:4px}.gacha-empty{padding:10px 12px;border:1px dashed var(--border);border-radius:10px;color:var(--text-muted)}.gacha-message{padding:10px 12px;border:1px solid #22c55e;border-radius:10px;background:#f0fdf4;color:#15803d;font-weight:600;text-align:center;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.toolbar-meta{display:flex;align-items:center;gap:12px;color:var(--text-muted);font-weight:600}.check-all{display:inline-flex;align-items:center;gap:6px;font-weight:600}.table-wrap{margin-top:14px;overflow:auto;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);box-shadow:var(--shadow-xs);max-height:70vh;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.table-scroll-top{margin-top:14px;margin-bottom:6px;overflow-x:auto;overflow-y:hidden;border:1px solid var(--border);border-radius:var(--radius-sm);height:14px;background:linear-gradient(180deg,var(--surface-2) 0%,var(--border) 100%)}.table-scroll-top::-webkit-scrollbar,.table-wrap::-webkit-scrollbar{height:10px;width:10px}.table-scroll-top::-webkit-scrollbar-thumb,.table-wrap::-webkit-scrollbar-thumb{background:var(--border);border-radius:999px}.tsum-table{width:100%;border-collapse:collapse;min-width:960px}.tsum-table th,.tsum-table td{padding:10px 12px;border-bottom:1px solid var(--border);text-align:left;white-space:nowrap}.tsum-table th{background:var(--surface-2);position:sticky;top:0;z-index:1}.tsum-table th button{background:none;border:none;padding:0;font-weight:700;color:var(--text);cursor:pointer}.tsum-table tbody tr:nth-child(2n){background:var(--surface-2)}.tsum-table tbody tr.row-checked{background:#eff6ff}.name-col{max-width:220px;white-space:normal}.name-cell{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.chip{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:12px;font-weight:700;background:var(--surface-2);color:var(--text);border:1px solid transparent}.chip-monthly{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}.progress-col{font-family:Roboto Mono,Noto Sans JP,monospace}.tsum-table input[type=number],.tsum-table select{width:120px;padding:6px 8px;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.tsum-table input[type=checkbox]{width:18px;height:18px}.summary{margin-top:18px}.summary h2{margin:0 0 8px;font-size:18px}.summary-note{margin:0 0 8px;color:var(--text-muted);font-size:13px}.premium-goal-alert{color:#b91c1c;font-weight:600}.premium-goal-controls{margin-bottom:10px;display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap}.premium-goal-field{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--text)}.premium-goal-field input{border:1px solid var(--border);border-radius:8px;padding:8px 10px;font-size:14px;background:var(--surface);color:var(--text)}.premium-goal-grid{margin-bottom:10px;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}.premium-complete-slot{margin-bottom:12px}.premium-goal-card{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);padding:10px 12px;box-shadow:var(--shadow-xs)}.premium-goal-title{font-size:12px;color:var(--text-muted);margin-bottom:4px;font-weight:700}.premium-goal-value{color:var(--text);font-size:18px;font-weight:700}.agg-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}.note-list{margin-top:8px;display:flex;align-items:center;gap:8px;color:var(--text-muted);font-size:13px;flex-wrap:wrap}.agg-card{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);padding:12px;box-shadow:var(--shadow-xs)}.agg-title{font-weight:700;margin-bottom:6px;color:var(--text)}.agg-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 10px;color:var(--text-muted);font-size:14px}.ocr-panel{margin-top:18px;padding:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-xs);display:flex;flex-direction:column;gap:12px}.ocr-head h2{margin:0;font-size:18px}.ocr-head p{margin:4px 0 0;color:var(--text-muted);font-size:13px}.ocr-controls{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end}.crop-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;flex:1}.crop-field{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--text)}.crop-field input{border:1px solid var(--border);border-radius:8px;padding:8px;font-size:14px}.ocr-actions{display:flex;gap:8px;flex-wrap:wrap}.ocr-status{padding:10px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-weight:600}.ocr-loading{color:#0ea5e9;font-weight:700}.ocr-results{display:flex;flex-direction:column;gap:12px}.ocr-card{display:grid;grid-template-columns:280px 1fr;gap:12px;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;background:var(--surface);box-shadow:var(--shadow-xs)}.ocr-card-unmatched{border-color:#f87171;box-shadow:0 0 0 1px #f87171 inset,0 6px 16px #f8717126}.ocr-card-near{border-color:#facc15;box-shadow:0 0 0 1px #facc15 inset,0 6px 16px #facc152e}.ocr-image-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;background:var(--surface-2);padding:10px;justify-items:center}.ocr-image-wrap{position:relative;background:var(--surface);display:flex;align-items:center;justify-content:center;padding:10px;border:1px solid var(--border);border-radius:var(--radius-sm)}.ocr-image-label{position:absolute;top:8px;left:8px;background:#0f172ae0;color:#fff;font-size:12px;font-weight:700;padding:2px 6px;border-radius:6px}.ocr-image{width:100%;height:auto;object-fit:contain;border-radius:6px}.ocr-body{padding:12px 12px 14px 0;display:flex;flex-direction:column;gap:10px}.ocr-row{display:flex;flex-direction:column;gap:6px}.ocr-label{font-weight:700;color:var(--text);font-size:13px}.ocr-text-input{border:1px solid var(--border);border-radius:8px;padding:8px 10px;font-size:14px}.ocr-match-row{flex-direction:row;align-items:center;gap:10px;flex-wrap:wrap}.ocr-tag{display:inline-flex;align-items:center;justify-content:center;padding:4px 8px;border-radius:999px;font-weight:700;font-size:12px}.ocr-tag-match{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe}.ocr-tag-miss{background:#fef2f2;color:#b91c1c;border:1px solid #fecdd3}.ocr-tag-skip{background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border)}.ocr-match-name{color:var(--text);font-weight:600}.ocr-skip-btn{padding:6px 10px;border-radius:8px;font-size:13px}.ocr-candidates{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px}.ocr-candidate{border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 10px;background:var(--surface-2);text-align:left;cursor:pointer;transition:all .15s ease}.ocr-candidate:hover{border-color:var(--accent);box-shadow:var(--shadow-sm)}.ocr-candidate-active{border-color:var(--accent);background:#eff6ff;box-shadow:0 0 0 1px var(--accent) inset}.ocr-candidate-name{display:block;font-weight:700;color:var(--text)}.ocr-candidate-meta{font-size:12px;color:var(--text-muted)}.ocr-empty{padding:8px 10px;border:1px dashed var(--border);border-radius:var(--radius-sm);color:var(--text-muted)}.ocr-footer{display:flex;justify-content:flex-end}.ocr-log-panel{margin-top:12px;border:1px solid #334155;border-radius:10px;background:#0b1220;color:#c7f9cc;padding:8px;font-size:12px}.ocr-log-head{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.ocr-log-toggle{min-width:200px}.ocr-log-body{margin:8px 0 0;max-height:200px;overflow:auto;white-space:pre-wrap}@media(max-width:768px){.tsum-page{padding:12px 10px 96px}.tsum-header{flex-direction:column;align-items:flex-start;gap:10px;padding:12px}.header-actions{width:100%;flex-direction:column;align-items:stretch}.header-actions>*{width:100%;text-align:center}.toolbar{flex-direction:column;align-items:stretch;gap:10px}.toolbar-meta{width:100%;justify-content:space-between;flex-wrap:wrap;gap:8px}.search{width:100%}.table-wrap{border-radius:10px;max-height:65vh;margin-bottom:12px}.tsum-table{min-width:640px;font-size:13px}.tsum-table th,.tsum-table td{padding:8px 10px}.table-scroll-top{height:12px}.agg-list,.ocr-card,.ocr-candidates{grid-template-columns:1fr}.premium-goal-controls{align-items:stretch}.premium-goal-controls>*{width:100%}}.complete-animation{position:relative;isolation:isolate;overflow:hidden;border-radius:16px;border:2px solid #fbbf24;background:radial-gradient(circle at 12% 18%,rgba(255,245,157,.6),transparent 36%),radial-gradient(circle at 84% 14%,rgba(251,191,36,.52),transparent 34%),radial-gradient(circle at 52% 120%,rgba(249,115,22,.3),transparent 44%),linear-gradient(130deg,#78350f,#a16207 16%,#f59e0b 44%,#fde68a 68%,#fff7ed);padding:18px 16px;box-shadow:0 18px 40px #b4530959,0 0 0 1px #fef3c766 inset;animation:gold-aura-shift 7.2s linear infinite}.complete-animation:before{content:"";position:absolute;inset:-35% -140%;z-index:0;background:linear-gradient(100deg,#fff0 20%,#fff3 33%,#ffffffbd 48%,#ffffff2e,#fff0 76%);transform:translate(-58%) rotate(8deg);pointer-events:none}.complete-animation:after{content:"";position:absolute;inset:0;z-index:0;background-image:radial-gradient(circle at 16% 24%,#ffffff8f 0,#fff0 28%),radial-gradient(circle at 74% 18%,#ffffff73 0,#fff0 24%),radial-gradient(circle at 28% 76%,#fef9c366 0,#fef9c300 26%),radial-gradient(circle at 86% 82%,#fef08a57 0,#fef08a00 24%);mix-blend-mode:screen;opacity:.72;pointer-events:none}.complete-animation-celebrate{animation:complete-pop .7s cubic-bezier(.21,1,.32,1) both,gold-frame-pulse 1s ease-out .18s 3}.complete-animation-celebrate:before{animation:shine-sweep 1.4s ease-out 2}.complete-animation-steady:before{animation:shine-sweep 5.6s linear infinite}.complete-animation-steady{border-color:#fcd34d;box-shadow:0 10px 24px #f59e0b47,0 0 0 1px #fff7ed75 inset}.complete-content{position:relative;z-index:2;display:flex;flex-direction:column;gap:8px}.complete-kicker{margin:0;font-size:12px;font-weight:800;letter-spacing:.14em;color:#fff7ed;text-shadow:0 1px 0 rgba(120,53,15,.8),0 0 10px rgba(254,240,138,.62)}.complete-content h3{margin:0;font-size:clamp(26px,4.8vw,38px);line-height:1.12;font-weight:900;background:linear-gradient(180deg,#fffef5,#fef08a 20%,#facc15 48%,#f59e0b,#b45309);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 2px 0 rgba(120,53,15,.42),0 0 14px rgba(254,240,138,.72),0 0 24px rgba(251,191,36,.5)}.complete-message{margin:0;font-size:14px;font-weight:600;color:#fff7ed;line-height:1.6;text-shadow:0 1px 0 rgba(120,53,15,.62)}.complete-animation-celebrate .complete-content h3{animation:title-flare .92s ease-out .22s 2}.complete-confetti-layer{position:absolute;inset:0;z-index:1;pointer-events:none}.confetti-piece{position:absolute;top:-18%;left:var(--confetti-left);width:10px;height:20px;opacity:0;border-radius:4px;transform:rotate(var(--confetti-rotate));box-shadow:0 0 12px #ffffff73,0 0 18px #fbbf245c;animation:confetti-fall var(--confetti-duration) linear var(--confetti-delay) forwards}.confetti-tone-0{background:#fde68a}.confetti-tone-1{background:#facc15}.confetti-tone-2{background:#f59e0b}.confetti-tone-3{background:#fb923c}.confetti-tone-4{background:#fff7ed}.confetti-tone-5{background:#fef3c7}@keyframes gold-aura-shift{0%{filter:saturate(1) brightness(1)}50%{filter:saturate(1.18) brightness(1.1)}to{filter:saturate(1) brightness(1)}}@keyframes complete-pop{0%{opacity:0;transform:scale(.74) rotate(-1.6deg)}60%{opacity:1;transform:scale(1.08) rotate(.8deg)}to{opacity:1;transform:scale(1) rotate(0)}}@keyframes gold-frame-pulse{0%{box-shadow:0 20px 36px #b4530942,0 0 #fef08ab3}50%{box-shadow:0 26px 42px #f59e0b61,0 0 0 8px #fef08a00}to{box-shadow:0 18px 40px #b4530959,0 0 #fef08a00}}@keyframes shine-sweep{0%{transform:translate(-62%) rotate(8deg);opacity:0}16%{opacity:1}to{transform:translate(62%) rotate(8deg);opacity:0}}@keyframes title-flare{0%{filter:brightness(1);transform:scale(1)}50%{filter:brightness(1.28);transform:scale(1.03)}to{filter:brightness(1);transform:scale(1)}}@keyframes confetti-fall{0%{opacity:0;transform:translate3d(0,-22px,0) rotate(0) scale(.8)}10%{opacity:1}to{opacity:0;transform:translate3d(-24px,300px,0) rotate(520deg) scale(1.06)}}@media(max-width:768px){.complete-animation{padding:14px 12px}.complete-content h3{font-size:clamp(22px,8vw,30px)}.complete-message{font-size:13px}}#root{min-width:100%;max-width:none;margin:0;padding:0;text-align:initial;background:var(--bg-0)}
