@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/ba9851c3c22cd980-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/21350d82a1f187e9-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/c5fe6dc8356a8c31-s.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/19cfc7226ec3afaa-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/df0a9ae256c0569c-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/8e9860b6e62d6359-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/e4af272ccee01ff0-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Inter Fallback;src:local("Arial");ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.00%;size-adjust:107.12%}.__className_f367f3{font-family:Inter,Inter Fallback;font-style:normal}.__variable_f367f3{--font-inter:"Inter","Inter Fallback"}:root{--white:#ffffff;--blue-50:#eff6ff;--blue-100:#dbeafe;--blue-200:#bfdbfe;--blue-300:#93c5fd;--blue-400:#60a5fa;--blue-500:#3b82f6;--blue-600:#2563eb;--blue-700:#1d4ed8;--blue-800:#1e40af;--blue-900:#1e3a8a;--green-50:#f0fdf4;--green-100:#dcfce7;--green-500:#22c55e;--green-600:#16a34a;--green-700:#15803d;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-150:#eaeff5;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--danger:#ef4444;--danger-50:#fef2f2;--shadow-xs:0 1px 2px rgba(15,23,42,0.05);--shadow-sm:0 1px 3px rgba(15,23,42,0.07),0 2px 8px rgba(15,23,42,0.04);--shadow:0 2px 12px rgba(37,99,235,0.08),0 1px 4px rgba(15,23,42,0.05);--shadow-md:0 4px 24px rgba(37,99,235,0.12),0 2px 8px rgba(15,23,42,0.06);--shadow-lg:0 12px 48px rgba(37,99,235,0.16),0 4px 16px rgba(15,23,42,0.08);--shadow-blue:0 6px 24px rgba(37,99,235,0.35);--shadow-green:0 6px 24px rgba(22,163,74,0.3);--shadow-inset:inset 0 1px 2px rgba(15,23,42,0.06);--radius-xs:5px;--radius-sm:8px;--radius:12px;--radius-lg:16px;--radius-xl:20px;--radius-2xl:28px;--radius-full:9999px;--ease:cubic-bezier(0.4,0,0.2,1);--ease-spring:cubic-bezier(0.34,1.3,0.64,1);--transition:0.16s var(--ease);--transition-fast:0.09s var(--ease);--transition-slow:0.28s var(--ease);--container:1120px;--header-h:auto}@keyframes fade-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{opacity:0;transform:translateY(16px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes spin{to{transform:rotate(1turn)}}@keyframes sync-pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes toast-in{0%{opacity:0;transform:translateY(10px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}*,:after,:before{box-sizing:border-box}html{scroll-behavior:smooth;height:100%;-webkit-text-size-adjust:100%}body,html{margin:0;padding:0;font-family:var(--font-inter,Inter),system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;background:var(--gray-50);color:var(--gray-800);min-height:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}button,input,select,textarea{font:inherit}img,svg{display:block}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.spin{animation:spin .9s linear infinite;flex-shrink:0}.muted{color:var(--gray-400);font-size:.8rem;font-weight:500}:focus-visible{outline:2px solid var(--blue-500);outline-offset:2px}button:focus-visible,input:focus-visible{outline:2px solid var(--blue-500);outline-offset:2px}.app{width:100%;max-width:var(--container);margin:0 auto;padding:0 16px 96px}.header{padding:12px 0 0}.hero{background:linear-gradient(140deg,#1e3a8a,#1d4ed8 45%,#2563eb);border-radius:var(--radius-xl);padding:20px 22px 18px;box-shadow:var(--shadow-lg);position:relative;overflow:hidden;animation:fade-up .35s var(--ease) both}.hero:before{top:-60px;right:-40px;width:220px;height:220px;background:radial-gradient(circle,rgba(255,255,255,.08) 0,transparent 70%)}.hero:after,.hero:before{content:"";position:absolute;border-radius:50%;pointer-events:none}.hero:after{bottom:-40px;left:-20px;width:180px;height:180px;background:radial-gradient(circle,rgba(96,165,250,.12) 0,transparent 70%)}.hero-top{justify-content:space-between;flex-wrap:wrap;margin-bottom:16px}.brand,.hero-top{display:flex;align-items:center;gap:12px}.brand{min-width:0}.brand-icon{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;background:rgba(255,255,255,.15);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.25);flex:0 0 auto;overflow:hidden;transition:transform var(--transition)}.brand-icon:hover{transform:scale(1.04) rotate(-2deg)}.brand-icon img{width:100%;height:100%;object-fit:contain;border-radius:10px}.brand h1{margin:0;font-size:1.15rem;font-weight:800;color:#fff;letter-spacing:-.01em;line-height:1.2}.brand p{margin:3px 0 0;color:rgba(255,255,255,.65);font-size:.82rem;font-weight:500;line-height:1.3}.header-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.month-input{width:100%;min-height:38px;padding:7px 11px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);border-radius:var(--radius);color:#fff;font-size:.88rem;font-weight:600;outline:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background var(--transition),border-color var(--transition);color-scheme:dark}.month-input:hover{background:rgba(255,255,255,.18)}.month-input:focus{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.45);box-shadow:0 0 0 3px rgba(255,255,255,.12)}.month-input::placeholder{color:rgba(255,255,255,.5)}.pill{display:inline-flex;align-items:center;gap:5px;border-radius:var(--radius-full);padding:5px 11px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);color:rgba(255,255,255,.9);font-size:.78rem;font-weight:700;white-space:nowrap;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background var(--transition),border-color var(--transition)}.sync-badge{font-size:.74rem;font-weight:700;transition:background var(--transition),color var(--transition),border-color var(--transition)}.sync-badge.sync-syncing{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.18);color:rgba(255,255,255,.7);animation:sync-pulse 1.4s ease-in-out infinite}.sync-badge.sync-synced{background:rgba(34,197,94,.18);border-color:rgba(34,197,94,.35);color:#86efac}.sync-badge.sync-error{background:rgba(239,68,68,.18);border-color:rgba(239,68,68,.35);color:#fca5a5}.user-pill{max-width:180px;overflow:hidden}.user-pill-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:120px;display:inline-block;vertical-align:middle}.cards{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));grid-gap:10px;gap:10px}.card{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:var(--radius-lg);padding:13px 14px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);position:relative;overflow:hidden;transition:background var(--transition),border-color var(--transition)}.card:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.28)}.card small{display:block;color:rgba(255,255,255,.6);margin-bottom:5px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.card strong{display:block;font-size:1.15rem;font-weight:800;color:#fff;letter-spacing:-.01em}.card.total{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.32)}.card.total strong{color:#86efac}.tabs{position:-webkit-sticky;position:sticky;top:0;z-index:40;margin:10px 0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:4px;gap:4px;background:rgba(255,255,255,.82);backdrop-filter:blur(20px) saturate(1.8);-webkit-backdrop-filter:blur(20px) saturate(1.8);border:1px solid var(--gray-200);border-radius:var(--radius-xl);padding:5px;box-shadow:0 2px 16px rgba(15,23,42,.08),0 1px 4px rgba(15,23,42,.04)}.tab-button{border:none;background:transparent;color:var(--gray-500);border-radius:var(--radius-lg);padding:10px 12px;min-height:46px;font-weight:700;font-size:.84rem;cursor:pointer;transition:background var(--transition),color var(--transition),box-shadow var(--transition);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;-webkit-tap-highlight-color:transparent}.tab-button:hover{background:var(--blue-50);color:var(--blue-700)}.tab-button.active{background:linear-gradient(135deg,var(--blue-700),var(--blue-600));color:#fff;box-shadow:0 4px 16px rgba(37,99,235,.32)}.tab-icon{flex-shrink:0}.tab-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;line-height:1}.tab-panel{display:none}.tab-panel.active{display:block;animation:fade-up .2s var(--ease) both;margin-top:1rem}.panel{background:var(--white);border:1px solid var(--gray-150);border-radius:var(--radius-xl);padding:20px;box-shadow:var(--shadow-sm);margin-bottom:12px;transition:box-shadow var(--transition)}.panel:last-child{margin-bottom:0}.panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:16px}.panel-header h2,.panel-header h3{margin:0;font-size:1rem;font-weight:800;color:var(--gray-800);letter-spacing:-.01em}.panel-header p{margin:3px 0 0;color:var(--gray-400);font-size:.84rem;line-height:1.45}.input{min-height:42px;border:1.5px solid var(--gray-200);border-radius:var(--radius);background:var(--white);color:var(--gray-800);padding:9px 13px;outline:none;transition:border-color var(--transition),box-shadow var(--transition),background var(--transition);font-size:.9rem;line-height:1.4}.input::placeholder{color:var(--gray-400)}.input:hover{border-color:var(--blue-300)}.input:focus{border-color:var(--blue-500);box-shadow:0 0 0 3px rgba(59,130,246,.13);background:#fafcff}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;border-radius:var(--radius);min-height:42px;padding:10px 18px;font-weight:700;font-size:.88rem;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition),background var(--transition),opacity var(--transition);color:#fff;background:linear-gradient(135deg,var(--green-600),var(--green-500));box-shadow:var(--shadow-green);white-space:nowrap;letter-spacing:.01em;display:inline-flex;align-items:center;justify-content:center;gap:6px;-webkit-tap-highlight-color:transparent;line-height:1}.btn:hover{transform:translateY(-1px);box-shadow:0 10px 28px rgba(22,163,74,.35)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.btn.secondary{background:linear-gradient(135deg,var(--blue-800),var(--blue-600));box-shadow:var(--shadow-blue)}.btn.secondary:hover{box-shadow:0 10px 28px rgba(37,99,235,.38)}.btn.ghost{background:var(--white);color:var(--gray-600);border:1.5px solid var(--gray-200);box-shadow:var(--shadow-xs)}.btn.ghost:hover{background:var(--blue-50);border-color:var(--blue-200);color:var(--blue-700);box-shadow:var(--shadow-sm)}.btn.danger{background:linear-gradient(135deg,#dc2626,var(--danger));box-shadow:0 6px 20px rgba(239,68,68,.28)}.btn.danger:hover{box-shadow:0 10px 28px rgba(239,68,68,.38)}.btn.icon{width:42px;min-height:42px;padding:0;border-radius:var(--radius-full);display:grid;place-items:center}.icon-btn{padding:8px 12px;font-size:.82rem;gap:5px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);color:rgba(255,255,255,.9);box-shadow:none}.icon-btn:hover{background:rgba(255,255,255,.24);border-color:rgba(255,255,255,.38);color:#fff;box-shadow:none;transform:translateY(-1px)}.btn.confirm{background:linear-gradient(135deg,#b91c1c,var(--danger));color:#fff;box-shadow:0 4px 14px rgba(239,68,68,.22);font-size:.8rem;font-weight:800;padding:8px 14px;min-height:42px;min-width:0;width:auto;border-radius:var(--radius);animation:fade-in .12s ease both;white-space:nowrap}.btn.confirm:hover{box-shadow:0 8px 22px rgba(239,68,68,.38)}.btn svg,.login-hint svg,.pill svg,.storage-title svg,.sync-badge svg{flex-shrink:0}.table-wrap{overflow-x:auto;overflow-y:clip;border:1px solid var(--gray-200);border-radius:var(--radius-lg);background:var(--white)}.table-wrap::-webkit-scrollbar{height:4px}.table-wrap::-webkit-scrollbar-track{background:var(--gray-100)}.table-wrap::-webkit-scrollbar-thumb{background:var(--blue-200);border-radius:2px}.table-wrap::-webkit-scrollbar-thumb:hover{background:var(--blue-300)}table{width:100%;border-collapse:separate;border-spacing:0;min-width:680px}thead th{top:0;z-index:2;color:var(--blue-700);border-bottom:1.5px solid var(--blue-100);font-size:.75rem;font-weight:800;text-align:left;padding:11px 12px;white-space:nowrap;text-transform:uppercase;letter-spacing:.06em}thead th,thead th:first-child{position:-webkit-sticky;position:sticky;background:var(--gray-50)}thead th:first-child{left:0;z-index:3;box-shadow:2px 0 8px rgba(255,255,255,.9)}tbody td,tfoot td{padding:9px 12px;border-bottom:1px solid var(--gray-100);background:var(--white);vertical-align:middle;transition:background var(--transition-fast);font-size:.88rem}tbody tr:last-child td{border-bottom:none}tbody td:first-child{position:-webkit-sticky;position:sticky;left:0;z-index:1;background:var(--white);box-shadow:2px 0 6px rgba(0,0,0,.06)}tbody tr:hover td,tbody tr:hover td:first-child{background:var(--blue-50)}tbody tr[data-weekend=true] td,tbody tr[data-weekend=true] td:first-child{background:var(--gray-50)}tbody tr[data-weekend=true]:hover td,tbody tr[data-weekend=true]:hover td:first-child{background:var(--blue-50)}.day-cell{font-weight:700;font-size:.88rem;color:var(--gray-700);white-space:nowrap}.qty-input{width:100%;min-width:72px;min-height:36px;text-align:center;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);padding:5px 6px;background:var(--white);outline:none;font-weight:700;font-size:.9rem;color:var(--gray-800);transition:border-color var(--transition),box-shadow var(--transition),background var(--transition)}.qty-input:hover{border-color:var(--blue-300)}.qty-input:focus{border-color:var(--blue-500);box-shadow:0 0 0 3px rgba(59,130,246,.12);background:#fafcff}.qty-input::-webkit-inner-spin-button,.qty-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.qty-input[type=number]{-moz-appearance:textfield}tfoot td{background:var(--gray-50);color:var(--blue-700);font-weight:700;font-size:.84rem;border-top:1.5px solid var(--blue-100);border-bottom:none}tfoot td:first-child{position:-webkit-sticky;position:sticky;left:0;z-index:1;background:var(--gray-50)}.stack{display:flex;flex-direction:column;gap:8px}.row-item{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr) auto;grid-gap:10px;gap:10px;align-items:center;border:1.5px solid var(--gray-150);border-radius:var(--radius-lg);padding:12px 14px;background:var(--white);transition:border-color var(--transition),box-shadow var(--transition)}.row-item:hover{border-color:var(--blue-200);box-shadow:var(--shadow-xs)}.extra-calc{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.extra-calc .input{min-width:0;width:74px;flex:1 1 60px}.extra-calc-eq,.extra-calc-sep{color:var(--gray-300);font-size:.82rem;font-weight:600;flex-shrink:0}.extra-calc-result{font-weight:800;color:var(--green-600);white-space:nowrap;font-size:.88rem;flex-shrink:0}.empty{border:1.5px dashed var(--gray-200);border-radius:var(--radius-lg);padding:32px 20px;text-align:center;color:var(--gray-400);background:var(--gray-50);font-size:.9rem;line-height:1.6}.empty strong{color:var(--blue-600)}.toolbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.report-grid,.summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:10px;gap:10px}.report-grid .card{background:var(--white);border:1.5px solid var(--gray-150);border-radius:var(--radius-lg);padding:14px 16px;box-shadow:var(--shadow-xs);transition:box-shadow var(--transition),border-color var(--transition)}.report-grid .card:hover{box-shadow:var(--shadow);border-color:var(--blue-200)}.report-grid .card small{color:var(--gray-500);font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;font-weight:700;margin-bottom:5px;display:block}.report-grid .card strong{color:var(--gray-800);font-size:1.1rem;font-weight:800}.report-grid .card.total{background:var(--green-50);border-color:#a7f3c0}.report-grid .card.total strong{color:var(--green-700)}.report-box{background:var(--gray-50);border:1px solid var(--gray-150);border-radius:var(--radius-lg);padding:12px}.report-list{display:flex;flex-direction:column;gap:4px}.report-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 13px;border:1px solid transparent;border-radius:var(--radius);background:var(--white);transition:border-color var(--transition),box-shadow var(--transition);font-size:.88rem}.report-row:hover{border-color:var(--gray-200);box-shadow:var(--shadow-xs)}.report-row:first-child{border-color:var(--blue-100);background:var(--blue-50);font-weight:600}.report-row strong{font-weight:700;color:var(--gray-800);white-space:nowrap}.hint{margin-top:10px;color:var(--gray-400);font-size:.82rem;line-height:1.5}.import-confirm{background:var(--danger-50);border:1.5px solid #fca5a5;border-radius:var(--radius);padding:14px 16px;display:flex;flex-direction:column;gap:12px;animation:fade-up .2s var(--ease) both;margin-top:12px}.import-confirm-body{display:flex;align-items:flex-start;gap:12px}.import-confirm-icon{display:flex;align-items:center;color:var(--danger);flex-shrink:0;margin-top:1px}.import-confirm-title{margin:0;font-weight:700;color:var(--gray-800);font-size:.9rem;word-break:break-all}.import-confirm-desc{margin:4px 0 0;color:var(--gray-500);font-size:.82rem;line-height:1.5}.import-confirm-actions{display:flex;gap:8px;flex-wrap:wrap}.footer-outer{position:fixed;bottom:0;left:0;right:0;z-index:50;background:rgba(255,255,255,.9);backdrop-filter:blur(20px) saturate(1.8);-webkit-backdrop-filter:blur(20px) saturate(1.8);border-top:1px solid var(--gray-150);box-shadow:0 -2px 16px rgba(15,23,42,.06)}.footer-bar{justify-content:space-between;gap:12px;padding:10px 20px;max-width:var(--container);margin:0 auto}.footer-bar,.footer-month-wrap{display:flex;align-items:center}.footer-month-wrap{gap:6px;font-size:.86rem;font-weight:600;color:var(--gray-500)}.footer-total{display:flex;flex-direction:column;align-items:flex-end}.footer-bar small{display:block;color:var(--gray-400);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.footer-bar strong{font-size:1.2rem;font-weight:900;color:var(--green-600);letter-spacing:-.01em}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100svh;gap:16px;background:linear-gradient(160deg,var(--white) 0,var(--blue-50) 100%)}.loading-logo{width:68px;height:68px;border-radius:18px;overflow:hidden;margin-bottom:4px;animation:fade-in .3s ease both;box-shadow:var(--shadow-md)}.loading-logo img{width:100%;height:100%;object-fit:contain}.spinner{width:36px;height:36px;border:3px solid var(--blue-100);border-top-color:var(--blue-600);border-radius:var(--radius-full);animation:spin .7s linear infinite}.loading-screen p{color:var(--gray-400);font-size:.86rem;font-weight:600;margin:0}.login-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;background:linear-gradient(140deg,#1e3a8a,#1d4ed8 45%,#3b82f6);padding:20px}.login-overlay:before{top:-80px;right:-80px;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.07) 0,transparent 70%)}.login-overlay:after,.login-overlay:before{content:"";position:fixed;border-radius:50%;pointer-events:none}.login-overlay:after{bottom:-80px;left:-80px;width:360px;height:360px;background:radial-gradient(circle,rgba(96,165,250,.12) 0,transparent 70%)}.login-card{background:var(--white);border-radius:var(--radius-2xl);padding:40px 36px 36px;max-width:420px;width:100%;box-shadow:0 24px 80px rgba(15,23,42,.28),0 8px 28px rgba(15,23,42,.12);text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px;animation:slide-up .38s var(--ease-spring) both;position:relative;z-index:1}.login-card .brand-icon{width:76px;height:76px;font-size:32px;border-radius:20px;background:var(--blue-50);border:none;-webkit-backdrop-filter:none;backdrop-filter:none;display:grid;place-items:center;margin-bottom:4px;overflow:hidden}.login-card .brand-icon img{width:100%;height:100%;object-fit:contain;border-radius:16px}.login-card h1{margin:0;font-size:1.4rem;font-weight:900;color:var(--gray-900);letter-spacing:-.02em}.login-card>p{margin:0;color:var(--gray-500);font-size:.9rem;line-height:1.5}.login-tagline{margin:0;color:var(--gray-400);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.login-form{display:flex;flex-direction:column;gap:10px;width:100%;margin-top:6px}.login-form .input{width:100%;text-align:center;font-size:.96rem;min-height:50px;border-radius:var(--radius-lg);font-weight:600;border-color:var(--gray-200)}.login-form .input:focus{border-color:var(--blue-500);box-shadow:0 0 0 3px rgba(59,130,246,.12)}.login-form .btn{width:100%;min-height:50px;border-radius:var(--radius-lg);font-size:.96rem}.login-error{color:var(--danger);font-size:.84rem;margin:0;font-weight:600;background:var(--danger-50);padding:8px 12px;border-radius:var(--radius-sm);text-align:left}.login-hint{font-size:.78rem;color:var(--gray-400);margin:2px 0 0;line-height:1.5;justify-content:center;gap:5px}.login-hint,.login-sent{display:flex;align-items:center}.login-sent{flex-direction:column;gap:8px;width:100%;margin-top:4px}.sent-icon-wrap{display:grid;place-items:center;width:56px;height:56px;border-radius:var(--radius-full);background:var(--green-100);color:var(--green-600);margin-bottom:4px}.sent-title{font-weight:800;font-size:1.1rem;color:var(--gray-800);margin:0}.profile-avatar{width:46px;height:46px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--blue-700),var(--blue-500));color:#fff;display:grid;place-items:center;font-size:1.2rem;font-weight:800;flex-shrink:0;box-shadow:var(--shadow-blue);-webkit-user-select:none;-moz-user-select:none;user-select:none}.profile-form{gap:14px}.profile-field,.profile-form{display:flex;flex-direction:column}.profile-field{gap:6px}.profile-label{font-size:.75rem;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.06em}.profile-input{width:100%}.profile-hint{font-size:.8rem;color:var(--gray-400);margin:0;line-height:1.5}.profile-email{font-size:.9rem;font-weight:600;color:var(--gray-600);padding:10px 13px;background:var(--gray-50);border:1.5px solid var(--gray-150);border-radius:var(--radius);word-break:break-all}.profile-save-btn{align-self:flex-start}.storage-title{display:flex;align-items:center;gap:6px;font-size:.96rem;font-weight:700;margin:0;color:var(--gray-800)}.storage-email{color:var(--gray-400);font-weight:400;font-size:.84em}.toast-container{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);z-index:600;display:flex;flex-direction:column;gap:8px;width:min(420px,calc(100vw - 32px));pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:var(--radius);color:#fff;font-size:.88rem;font-weight:600;box-shadow:0 8px 32px rgba(0,0,0,.18),0 2px 8px rgba(0,0,0,.1);pointer-events:all;animation:toast-in .26s var(--ease-spring) both;line-height:1.4;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.toast-success{background:linear-gradient(135deg,#166534,var(--green-600));border:1px solid #15803d}.toast-error{background:linear-gradient(135deg,#991b1b,#dc2626);border:1px solid #b91c1c}.toast-info{background:linear-gradient(135deg,var(--blue-800),var(--blue-600));border:1px solid var(--blue-500)}.toast-icon{flex-shrink:0;display:flex;align-items:center}.toast-msg{flex:1 1;min-width:0}.toast-close{flex-shrink:0;background:none;border:none;color:currentColor;opacity:.65;cursor:pointer;padding:4px;display:flex;align-items:center;border-radius:var(--radius-xs);transition:opacity var(--transition-fast),background var(--transition-fast);margin-left:2px}.toast-close:hover{opacity:1;background:rgba(255,255,255,.18)}@media (max-width:900px){.report-grid,.summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:768px){.report-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.toast-container{bottom:76px}}@media (max-width:600px){.toolbar{flex-direction:column}.toolbar .btn{width:100%;justify-content:center}}@media (max-width:480px){.app{padding:0 12px 88px}.hero{padding:14px 16px}.brand-icon{width:40px;height:40px;border-radius:11px}.brand h1{font-size:1rem}.brand p{display:none}.header-controls{gap:6px}.icon-btn span{display:none}.icon-btn{padding:8px 10px}.month-input{min-height:36px;font-size:.84rem;padding:6px 9px}.cards{gap:8px}.cards .card{padding:10px}.cards .card small{font-size:.66rem}.cards .card strong{font-size:1rem}.tabs{margin:8px 0;padding:4px;gap:3px}.tab-button{min-height:46px;padding:8px 6px}.tab-label{font-size:.62rem;letter-spacing:.02em}.panel{padding:14px 16px}.panel-header{margin-bottom:12px}table{min-width:360px}thead th{padding:10px 8px;font-size:.7rem}tbody td,tfoot td{padding:7px 8px}.qty-input{min-width:52px;min-height:34px}.btn,.qty-input{font-size:.86rem}.btn{min-height:42px;padding:9px 14px}.btn.icon{width:40px;min-height:40px}.footer-bar{padding:10px 16px}.footer-bar strong{font-size:1.1rem}.login-card{padding:30px 22px 26px}.login-card h1{font-size:1.25rem}.profile-save-btn{align-self:stretch;justify-content:center}.row-item{gap:8px;padding:10px 12px}}@media (max-width:560px){.row-item{grid-template-columns:1fr auto;grid-template-rows:auto auto;gap:8px}.row-item>:first-child{grid-column:1/-1}.extra-calc .input{width:60px;min-width:0;flex:1 1 50px}.extra-calc-result{font-size:.82rem}}@media (max-width:640px){.tabs{position:fixed;bottom:0;left:0;right:0;top:auto;margin:0;border-radius:0;border-radius:18px 18px 0 0;border-bottom:none;padding:6px 8px max(env(safe-area-inset-bottom,0px),4px);z-index:60}.app{padding-bottom:calc(80px + env(safe-area-inset-bottom, 0px))}.footer-outer{bottom:calc(66px + env(safe-area-inset-bottom, 0px));display:none}.toast-container{bottom:calc(72px + env(safe-area-inset-bottom, 0px))}}