:root{--bg:#e2e2e2;--surface:#efefef;--surface2:#d0d0d0;--border:#b43c008c;--text:#1a1a1a;--text2:#505050;--accent:#c84a00;--accent2:#e06000;--accent3:#f07820;--radius:10px;-webkit-font-smoothing:antialiased;font:15px/1.5 system-ui,Segoe UI,sans-serif}[data-theme=dark]{--bg:#1a1a1a;--surface:#222;--surface2:#2c2c2c;--border:#e8782073;--text:#d8d8d8;--text2:#c8c8c8;--accent:#e87820;--accent2:#f08030;--accent3:#f09848}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);min-height:100dvh;transition:background .3s,color .3s}button{cursor:pointer;font-family:inherit}#root{min-height:100dvh}.dashboard{flex-direction:column;gap:24px;display:flex}.dash-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.dash-title{letter-spacing:-.4px;font-size:22px;font-weight:700}.dash-sub{color:var(--text2);margin-top:3px;font-size:13px}.reset-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text2);white-space:nowrap;border-radius:8px;align-items:center;gap:6px;padding:7px 14px;font-size:13px;transition:background .15s,color .15s;display:flex}.reset-btn:hover{background:var(--border);color:var(--text)}.date-range-wrap{background:color-mix(in srgb, var(--surface) 80%, transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:14px;padding:18px 22px;display:flex}.date-range-labels{color:var(--text);justify-content:space-between;font-size:13px;font-weight:600;display:flex}.dual-slider{height:20px;position:relative}.dual-slider-track{background:var(--surface2);pointer-events:none;border-radius:2px;height:4px;position:absolute;top:8px;left:0;right:0}.dual-slider-fill{background:var(--accent);pointer-events:none;border-radius:2px;height:4px;position:absolute;top:8px}.slider-thumb{appearance:none;pointer-events:none;background:0 0;outline:none;width:100%;height:20px;margin:0;padding:0;position:absolute;top:0}.slider-thumb::-webkit-slider-thumb{appearance:none;background:var(--accent);border:2px solid var(--surface);cursor:pointer;pointer-events:all;border-radius:50%;width:18px;height:18px;margin-top:1px;box-shadow:0 1px 5px #00000040}.slider-thumb::-moz-range-thumb{background:var(--accent);border:2px solid var(--surface);cursor:pointer;pointer-events:all;border-radius:50%;width:18px;height:18px}.status-bar-wrap{background:color-mix(in srgb, var(--surface) 80%, transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:14px;padding:18px 22px}.status-bar-track{background:var(--surface2);border-radius:99px;height:10px;margin-bottom:10px;overflow:hidden}.status-bar-fill{border-radius:99px;height:100%;transition:width .8s cubic-bezier(.4,0,.2,1)}.status-bar-labels{justify-content:space-between;font-size:14px;font-weight:600;display:flex}.status-bar-remain{font-weight:500}.legend{background:color-mix(in srgb, var(--surface) 80%, transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:14px;flex-wrap:wrap;gap:8px;padding:14px 16px;display:flex}.legend-item{background:var(--surface2);border-radius:20px;align-items:center;gap:6px;padding:4px 10px 4px 6px;font-size:13px;display:flex}.legend-swatch{border-radius:50%;flex-shrink:0;width:10px;height:10px}.legend-name{font-weight:500}.legend-count{color:var(--text2);font-size:12px}.cal-wrap{background:color-mix(in srgb, var(--surface) 80%, transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:14px;flex-wrap:wrap;gap:28px 24px;padding:22px 20px;display:flex}.month-block{flex-direction:column;gap:5px;display:flex}.month-header{color:var(--text2);text-transform:uppercase;letter-spacing:.07em;margin-bottom:2px;font-size:11px;font-weight:700}.month-dow{grid-template-columns:repeat(7,26px);gap:2px;margin-bottom:2px;display:grid}.month-dow span{color:var(--text2);text-align:center;text-transform:uppercase;opacity:.55;font-size:9px;font-weight:600}.month-grid{grid-template-columns:repeat(7,26px);gap:2px;display:grid}.cal-empty{width:26px;height:26px}.cal-day{cursor:default;border-radius:6px;justify-content:center;align-items:center;width:26px;height:26px;font-size:11px;font-weight:500;transition:transform .1s;display:flex}.cal-day.out-window{color:var(--text2);opacity:.25;background:0 0}.cal-day.in-window{color:var(--text);background:var(--surface2);opacity:.85}.cal-day.active{color:#fff;opacity:1;font-weight:700}.cal-day.active:hover{z-index:2;transform:scale(1.28)}.breakdown{flex-direction:column;gap:12px;display:flex}.breakdown-title{color:var(--text2);text-transform:uppercase;letter-spacing:.08em;font-size:11px;font-weight:700}.breakdown-note{text-transform:none;letter-spacing:0;opacity:.7;font-size:10px;font-weight:400}.breakdown-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:10px;display:grid}.breakdown-card{background:color-mix(in srgb, var(--surface) 85%, transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border);border-left:4px solid;border-radius:12px;align-items:center;gap:14px;padding:14px 16px;transition:transform .15s,box-shadow .15s;display:flex}.breakdown-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001f}.bc-code{letter-spacing:.04em;background:var(--surface2);width:32px;height:32px;color:var(--text);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-family:ui-monospace,monospace;font-size:12px;font-weight:800;display:flex}.bc-name{font-size:13px;font-weight:600}.bc-days{margin-top:2px;font-size:18px;font-weight:700}.no-data{background:color-mix(in srgb, var(--surface) 80%, transparent);border:1px solid var(--border);text-align:center;color:var(--text2);border-radius:14px;padding:48px;font-size:15px;line-height:1.8}.no-data small{font-size:13px}@media (width<=600px){.dashboard{gap:16px}.date-range-wrap,.status-bar-wrap,.legend,.cal-wrap{border-radius:12px;padding:14px}.cal-wrap{gap:20px 14px}.month-dow,.month-grid{grid-template-columns:repeat(7,22px);gap:2px}.cal-day,.cal-empty{width:22px;height:22px;font-size:10px}.breakdown-grid{grid-template-columns:1fr 1fr;gap:8px}.breakdown-card{gap:10px;padding:10px 12px}.bc-days{font-size:15px}.no-data{padding:28px 16px}}.lava-wrap{z-index:0;pointer-events:none;position:fixed;inset:0;overflow:hidden}.lava-orb{filter:blur(90px);will-change:transform;mix-blend-mode:multiply;border-radius:50%;position:absolute}[data-theme=dark] .lava-orb{mix-blend-mode:screen}.o1{background:#c84a0061}.o2{background:#e0600047}.o3{background:#f08c1e52}.o4{background:#a03c0038}.o5{background:#8c8c8c38}.o6{background:#c8a05047}[data-theme=dark] .o1{background:#c8640a6b}[data-theme=dark] .o2{background:#f082144d}[data-theme=dark] .o3{background:#b44b0061}[data-theme=dark] .o4{background:#96370047}[data-theme=dark] .o5{background:#dc9b2d52}[data-theme=dark] .o6{background:#c8500a40}.o1{animation:32s ease-in-out infinite drift1;top:-15%;left:-8%}.o2{animation:28s ease-in-out infinite drift2;top:50%;right:-12%}.o3{animation:38s ease-in-out infinite drift3;top:30%;left:40%}.o4{animation:24s ease-in-out infinite drift4;bottom:-5%;left:15%}.o5{animation:35s ease-in-out infinite drift5;top:10%;right:5%}.o6{animation:30s ease-in-out infinite drift6;bottom:20%;right:30%}@keyframes drift1{0%{transform:translate(0)scale(1)}33%{transform:translate(80px,120px)scale(1.12)}66%{transform:translate(-40px,60px)scale(.95)}to{transform:translate(0)scale(1)}}@keyframes drift2{0%{transform:translate(0)scale(1)}33%{transform:translate(-100px,-80px)scale(1.08)}66%{transform:translate(-60px,40px)scale(1.15)}to{transform:translate(0)scale(1)}}@keyframes drift3{0%{transform:translate(0)scale(1)}25%{transform:translate(60px,-90px)scale(1.1)}50%{transform:translate(-80px,-40px)scale(.9)}75%{transform:translate(40px,80px)scale(1.05)}to{transform:translate(0)scale(1)}}@keyframes drift4{0%{transform:translate(0)scale(1)}50%{transform:translate(120px,-100px)scale(1.2)}to{transform:translate(0)scale(1)}}@keyframes drift5{0%{transform:translate(0)scale(1)}33%{transform:translate(-70px,90px)scale(.92)}66%{transform:translate(50px,50px)scale(1.1)}to{transform:translate(0)scale(1)}}@keyframes drift6{0%{transform:translate(0)scale(1)}40%{transform:translate(-90px,-70px)scale(1.15)}80%{transform:translate(60px,30px)scale(.88)}to{transform:translate(0)scale(1)}}.app{background:var(--bg);min-height:100dvh;color:var(--text);flex-direction:column;transition:background .3s,color .3s;display:flex;position:relative;overflow-x:hidden}.header{border-bottom:1px solid var(--border);z-index:20;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:color-mix(in srgb, var(--surface) 85%, transparent);justify-content:space-between;align-items:center;padding:14px 28px;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:10px;display:flex}.app-title{letter-spacing:-.3px;color:var(--text2);font-size:17px;font-weight:700}.title-bolt{color:var(--text2);flex-shrink:0;margin-right:7px}.theme-toggle{border:1px solid var(--accent);color:var(--accent);background:0 0;border-radius:8px;justify-content:center;align-items:center;padding:7px;transition:background .2s,color .2s;display:flex}.theme-toggle:hover{background:#c84a001f}.main{z-index:1;flex:1;width:100%;max-width:1120px;margin:0 auto;padding:48px 28px;position:relative}.hero{text-align:center;flex-direction:column;align-items:center;gap:20px;padding-top:24px;display:flex}.hero-title{letter-spacing:-2px;color:var(--text2);font-size:clamp(36px,10vw,64px);font-weight:800;line-height:1}.catchphrase{color:var(--text2);letter-spacing:.01em;opacity:.75;margin-top:-4px;font-size:18px;font-weight:400}.dropzone{border:2px dashed var(--border);cursor:pointer;background:color-mix(in srgb, var(--surface) 70%, transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);text-align:left;border-radius:14px;align-items:center;gap:16px;width:100%;max-width:480px;padding:32px 36px;transition:border-color .2s,background .2s;display:flex}.app-footer{color:var(--text2);opacity:.55;z-index:1;justify-content:center;align-items:center;padding:16px 28px;font-size:12px;display:flex;position:relative}.footer-version{text-align:center;flex:1}.footer-privacy{color:inherit;opacity:.7;font-size:12px;text-decoration:none;transition:opacity .15s;position:absolute;left:28px}.footer-privacy:hover{opacity:1}.footer-github{color:inherit;align-items:center;transition:opacity .15s;display:flex;position:absolute;right:28px}.footer-github:hover{opacity:1}.dropzone:hover,.dropzone.dragging{border-color:var(--accent2);background:color-mix(in srgb, var(--surface2) 80%, transparent)}.dropzone-icon{color:var(--text2);flex-shrink:0}.dropzone-text{font-size:14px;font-weight:500}.dropzone-hint{color:var(--text2);margin-top:4px;font-size:12px;line-height:1.5}.loading-msg{color:var(--accent2);align-items:center;gap:8px;font-size:14px;font-weight:500;display:flex}.spinner{border:2px solid var(--border);border-top-color:var(--accent2);border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.error-msg{color:var(--accent);background:#1e3a5f1a;border:1px solid #1e3a5f4d;border-radius:10px;align-items:flex-start;gap:8px;width:100%;max-width:480px;padding:12px 16px;font-size:14px;line-height:1.5;display:flex}@media (width<=600px){.main{padding:24px 16px}.hero{gap:14px;padding-top:12px}.catchphrase{font-size:16px}.dropzone{gap:12px;padding:20px 18px}.dropzone-hint{display:none}.header,.app-footer{padding:12px 16px}.footer-privacy{left:16px}.footer-github{right:16px}}
