:root{--white: #ffffff;--bg: #F2F2F7;--bg2: #E5E5EA;--card: #ffffff;--text: #000000;--text2: #3C3C43;--text3: #8E8E93;--text4: #C7C7CC;--border: rgba(60,60,67,.12);--divider: rgba(60,60,67,.08);--fill: rgba(120,120,128,.08);--g-start: #000000;--g-end: #1c1c1e;--gradient: linear-gradient(135deg, #000, #1c1c1e);--accent: #FF7E8A;--accent2: #E8636F;--accent-bg: rgba(255,126,138,.08);--blue: #FF7E8A;--blue-bg: rgba(255,126,138,.08);--green: #34C759;--green-bg: rgba(52,199,89,.08);--orange: #FF9500;--orange-bg: rgba(255,149,0,.08);--red: #FF3B30;--red-bg: rgba(255,59,48,.08);--purple: #FFB088;--purple-bg: rgba(255,176,136,.08);--teal: #5AC8FA;--teal-bg: rgba(90,200,250,.08);--pink: #FF7E8A;--pink-bg: rgba(255,126,138,.08);--estimate-color: #FFB088;--estimate-bg: rgba(255,176,136,.1);--invoice-color: #FF7E8A;--invoice-bg: rgba(255,126,138,.1);--font: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Hiragino Sans", "Noto Sans JP", sans-serif;--mono: "SF Mono", "Menlo", monospace;--fs-xs: 11px;--fs-sm: 12px;--fs-caption: 13px;--fs-sub: 15px;--fs-base: 17px;--fs-md: 17px;--fs-lg: 20px;--fs-xl: 22px;--fs-2xl: 28px;--fs-3xl: 34px;--s1: 4px;--s2: 8px;--s3: 12px;--s4: 16px;--s5: 20px;--s6: 24px;--s7: 32px;--r1: 8px;--r2: 10px;--r3: 13px;--r4: 16px;--r5: 20px;--r-full: 100px;--sh1: 0 .5px 0 rgba(0,0,0,.04);--sh2: 0 1px 3px rgba(0,0,0,.08);--sh3: 0 4px 12px rgba(0,0,0,.1);--sh-accent: 0 2px 8px rgba(255,126,138,.2);--ease: cubic-bezier(.25, .46, .45, .94);--dur: .3s;--dur-fast: .2s;--header-h: 44px;--nav-h: 50px;--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-top: env(safe-area-inset-top, 0px);--btn-primary-bg: #FF7E8A;--btn-primary-text: #ffffff}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}html,body{background:var(--bg)}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh}input,button,select,textarea{font-family:var(--font)}#app{display:flex;flex-direction:column;min-height:100dvh}::-webkit-scrollbar{width:0;height:0}#app-header{position:sticky;top:0;z-index:100;background:#ffffffeb;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid rgba(0,0,0,.06)}#app-header:empty{display:none}.nav-bar{display:flex;align-items:center;justify-content:space-between;max-width:500px;margin:0 auto;min-height:var(--header-h);padding:0 var(--s2)}.nav-bar-title{font-size:var(--fs-md);font-weight:600;text-align:center;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-bar-btn{display:flex;align-items:center;gap:var(--s1);background:none;border:none;color:var(--accent);font-size:var(--fs-base);font-weight:500;padding:var(--s3);border-radius:var(--r1);cursor:pointer;min-width:56px;transition:background var(--dur-fast)}.nav-bar-btn:active{background:var(--fill)}.nav-bar-btn svg{width:20px;height:20px}.nav-bar-btn.right{justify-content:flex-end}.nav-bar-btn.save-btn{background:var(--accent);color:#fff;padding:6px 16px;border-radius:var(--r-full);font-weight:700;font-size:var(--fs-sub);box-shadow:var(--sh-accent);min-width:auto}.nav-bar-btn.save-btn:active{background:var(--accent2);transform:scale(.93)}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.stat-card.has-unpaid .stat-value{position:relative}.stat-card.has-unpaid:after{content:"";position:absolute;top:10px;right:10px;width:8px;height:8px;border-radius:50%;background:var(--orange);animation:pulse-dot 2s ease-in-out infinite}.report-card{position:relative}.report-card.highlight{border-left:3px solid var(--green)}.report-card.warn{border-left:3px solid var(--orange)}#app-main{flex:1;padding-bottom:calc(var(--nav-h) + var(--safe-bottom) + var(--s7));max-width:500px;margin:0 auto;width:100%}.page-pad{padding:0 var(--s4)}#app-nav{position:fixed;bottom:0;left:0;right:0;z-index:100;height:calc(var(--nav-h) + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:#f9f9f9f0;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-top:.5px solid rgba(60,60,67,.12);display:flex;align-items:stretch;justify-content:space-around}#app-nav:empty{display:none}.tab-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;flex:1;background:none;border:none;color:var(--text4);font-size:10px;font-weight:600;cursor:pointer;padding:var(--s2) 0;transition:color var(--dur-fast);letter-spacing:.02em}.tab-item.active{color:var(--accent)}.tab-item svg{width:22px;height:22px;fill:currentColor;stroke:none}.hero{background:var(--bg);color:var(--text);padding:var(--s3) var(--s5) var(--s4);margin-bottom:0;position:relative;overflow:hidden;display:flex;align-items:center;gap:var(--s3);border-bottom:none}.hero:before{display:none}.hero-logo{height:44px;width:auto;object-fit:contain;margin-bottom:4px}.hero-title{font-size:var(--fs-3xl);font-weight:700;letter-spacing:-.01em;line-height:1.15;color:var(--text)}.hero-sub{font-size:var(--fs-caption);color:var(--text3);font-weight:400;letter-spacing:-.01em}.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:var(--s3);padding:var(--s3) var(--s4)}.quick-action{background:var(--card);border-radius:var(--r3);padding:var(--s3) var(--s3) var(--s4);display:flex;flex-direction:column;align-items:center;gap:var(--s2);border:.5px solid var(--border);cursor:pointer;transition:transform .2s ease,opacity .2s;-webkit-tap-highlight-color:transparent;overflow:hidden}.quick-action:active{transform:scale(.96);opacity:.7}.quick-action-img{width:100%;height:100px;object-fit:contain;border-radius:var(--r1);pointer-events:none}.quick-action-icon{width:44px;height:44px;border-radius:var(--r2);display:flex;align-items:center;justify-content:center;flex-shrink:0}.quick-action-icon svg{width:20px;height:20px;color:#fff}.quick-action-text{width:100%;text-align:center}.quick-action-label{font-size:var(--fs-sub);font-weight:700;color:var(--text)}.quick-action-desc{font-size:var(--fs-xs);color:var(--text3);margin-top:1px}.quick-action-arrow{display:none}.quick-action-arrow svg{width:20px;height:20px}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s3);padding:0 var(--s4);margin-bottom:var(--s4)}.stat-card{background:var(--card);border-radius:var(--r2);padding:var(--s4) var(--s3);text-align:center;border:.5px solid var(--border)}.stat-value{font-size:22px;font-weight:800;color:var(--text);font-variant-numeric:tabular-nums;line-height:1}.stat-label{font-size:11px;color:var(--text3);margin-top:6px;font-weight:500;letter-spacing:-.01em}.section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--s3) var(--s4) var(--s2)}.section-title{font-size:var(--fs-md);font-weight:700;color:var(--text)}.section-link{font-size:var(--fs-caption);font-weight:500;color:var(--accent);background:none;border:none;cursor:pointer;padding:var(--s1) var(--s2);border-radius:var(--r1)}.section-link:active{background:var(--fill)}.doc-list{display:flex;flex-direction:column;gap:var(--s3);padding:0 var(--s4)}.doc-card{background:var(--card);border-radius:var(--r2);overflow:hidden;border:.5px solid var(--border);transition:opacity var(--dur);-webkit-tap-highlight-color:transparent;display:flex;position:relative}.doc-card:before{content:"";width:4px;flex-shrink:0;border-radius:var(--r2) 0 0 var(--r2)}.doc-card.type-estimate:before{background:var(--estimate-color)}.doc-card.type-invoice:before{background:var(--invoice-color)}.doc-card:active{opacity:.6}.doc-card-body{flex:1;padding:var(--s4);cursor:pointer;display:flex;flex-direction:column;gap:var(--s2)}.doc-card-row1{display:flex;align-items:center;justify-content:space-between}.doc-card-badges{display:flex;align-items:center;gap:var(--s2)}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--r-full);font-size:var(--fs-xs);font-weight:500}.badge-estimate{background:var(--estimate-bg);color:var(--estimate-color)}.badge-invoice{background:var(--invoice-bg);color:var(--invoice-color)}.badge-draft{background:var(--fill);color:var(--text3)}.badge-sent{background:var(--blue-bg);color:var(--blue)}.badge-paid{background:var(--green-bg);color:var(--green)}.badge-overdue{background:var(--red-bg);color:var(--red)}.doc-card-number{font-size:var(--fs-xs);color:var(--text3);font-family:var(--mono);font-variant-numeric:tabular-nums}.doc-card-customer{font-size:var(--fs-md);font-weight:600;line-height:1.3}.doc-card-subject{font-size:var(--fs-caption);color:var(--text2)}.doc-card-footer{display:flex;align-items:baseline;justify-content:space-between;margin-top:var(--s1)}.doc-card-amount{font-size:20px;font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:-.02em;color:var(--text)}.doc-card-date{font-size:var(--fs-xs);color:var(--text3);font-weight:500}.doc-card-more{width:44px;display:flex;align-items:center;justify-content:center;background:none;border:none;border-left:1px solid var(--divider);color:var(--text3);cursor:pointer;flex-shrink:0;transition:background var(--dur-fast)}.doc-card-more:active{background:var(--fill)}.doc-card-more svg{width:18px;height:18px}.segmented{display:flex;background:#7878801f;border-radius:8px;padding:2px;margin:0 var(--s4) var(--s4)}.seg-btn{flex:1;padding:7px var(--s3);border:none;background:none;border-radius:7px;font-family:var(--font);font-size:var(--fs-caption);font-weight:500;color:var(--text);cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.seg-btn.active{background:var(--card);color:var(--text);box-shadow:0 1px 3px #00000014,0 .5px 1px #0000000a;font-weight:600}.search-wrap{padding:var(--s3) var(--s4);position:relative}.search-wrap input{width:100%;height:36px;padding:0 var(--s3) 0 36px;background:#7878801f;border:none;border-radius:var(--r2);font-size:var(--fs-md);color:var(--text);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;transition:box-shadow var(--dur-fast)}.search-wrap input:focus{box-shadow:0 0 0 3px var(--accent-bg)}.search-wrap input::placeholder{color:var(--text3)}.search-icon{position:absolute;left:calc(var(--s4) + 10px);top:50%;transform:translateY(-50%);width:14px;height:14px;color:var(--text3)}.empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:48px var(--s5)}.empty-visual{width:80px;height:80px;background:var(--fill);border-radius:var(--r4);display:flex;align-items:center;justify-content:center;margin-bottom:var(--s5);box-shadow:none}.empty-visual svg{width:32px;height:32px;color:var(--text4)}.empty-img{width:180px;height:auto;margin-bottom:var(--s5);pointer-events:none;animation:emptyFloat 3s ease-in-out infinite}@keyframes emptyFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.empty h3{font-size:var(--fs-lg);font-weight:700;margin-bottom:var(--s2)}.empty p{font-size:var(--fs-sub);color:var(--text3);line-height:1.6;max-width:240px}.empty-btn{margin-top:var(--s5);background:var(--btn-primary-bg);color:var(--btn-primary-text);border:none;border-radius:var(--r-full);padding:var(--s3) var(--s7);font-size:var(--fs-base);font-weight:600;cursor:pointer;box-shadow:var(--sh1);transition:transform var(--dur) var(--ease),opacity var(--dur-fast)}.empty-btn:active{transform:scale(.95);opacity:.9}.group{margin-bottom:var(--s6);padding:0 var(--s4)}.group-label{font-size:var(--fs-caption);font-weight:400;color:var(--text3);letter-spacing:-.01em;padding:0 var(--s4) var(--s2);text-transform:none}.group-note{font-size:var(--fs-xs);color:var(--text3);padding:var(--s2) var(--s1) 0;line-height:1.5}.g-list{background:var(--card);border-radius:var(--r2);overflow:hidden;box-shadow:var(--sh1)}.g-row{display:flex;align-items:center;gap:var(--s3);padding:var(--s3) var(--s4);min-height:50px;cursor:pointer;transition:background var(--dur-fast)}.g-row:active{background:var(--fill)}.g-row+.g-row{border-top:.5px solid var(--border)}.g-icon{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff}.g-icon svg{width:17px;height:17px}.g-body{flex:1;min-width:0}.g-title{font-size:var(--fs-base);font-weight:500}.g-sub{font-size:var(--fs-xs);color:var(--text3);margin-top:1px}.g-detail{font-size:var(--fs-sub);color:var(--text3);flex-shrink:0}.g-chevron{width:14px;height:14px;color:var(--text4);flex-shrink:0}.f-row{display:flex;align-items:center;min-height:50px;padding:0 var(--s4);gap:var(--s2)}.f-row+.f-row{border-top:.5px solid var(--border)}.f-label{font-size:var(--fs-base);font-weight:500;color:var(--text2);white-space:nowrap;min-width:60px}.f-row input,.f-row select,.f-row textarea{flex:1;border:none;background:none;font-size:var(--fs-base);color:var(--text);text-align:right;padding:var(--s3) 0;outline:none;min-width:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;transition:box-shadow .2s ease;border-radius:4px}.f-row input:focus,.f-row select:focus,.f-row textarea:focus{box-shadow:inset 0 -2px 0 var(--accent)}.f-row textarea{text-align:left;resize:none;line-height:1.5}.f-row input::placeholder,.f-row textarea::placeholder{color:var(--text4)}.f-row select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%23aeaeb2' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 0 center;padding-right:16px}.pick-btn{width:44px;height:44px;margin:-4px -8px -4px 0;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--accent);cursor:pointer;border-radius:var(--r1);flex-shrink:0;transition:background var(--dur-fast)}.pick-btn:active{background:#ff7e8a14}.pick-btn svg{width:22px;height:22px}.li-card{background:var(--card);border-radius:var(--r2);overflow:hidden;box-shadow:var(--sh1);margin-bottom:var(--s3);animation:cardIn .25s var(--ease)}@keyframes cardIn{0%{opacity:0;transform:translateY(6px) scale(.98)}to{opacity:1;transform:none}}.li-top{display:flex;align-items:center;justify-content:space-between;padding:var(--s3) var(--s4) 0}.li-num{font-size:var(--fs-xs);font-weight:700;color:#fff;background:var(--accent);padding:2px 8px;border-radius:var(--r-full)}.li-del{width:44px;height:44px;margin:-10px -12px -10px 0;border:none;background:none;color:var(--red);display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:var(--r1);transition:background var(--dur-fast)}.li-del:active{background:var(--red-bg)}.li-del svg{width:18px;height:18px}.li-name{padding:var(--s2) var(--s4)}.li-name input{width:100%;border:none;background:none;font-size:var(--fs-base);font-weight:500;color:var(--text);padding:var(--s2) 0;border-bottom:1.5px solid var(--border);outline:none;transition:border-color var(--dur-fast)}.li-name input:focus{border-bottom-color:var(--accent)}.li-name input::placeholder{color:var(--text4)}.li-fields{display:grid;grid-template-columns:1fr 1fr 1fr}.li-field{padding:var(--s3);border-right:.5px solid var(--border);border-top:.5px solid var(--border)}.li-field:last-child{border-right:none}.li-field-label{font-size:var(--fs-xs);color:var(--text3);font-weight:500;margin-bottom:var(--s1)}.li-field input,.li-field select{width:100%;border:none;background:none;font-size:var(--fs-sub);font-weight:600;color:var(--text);padding:0;outline:none;text-align:right;-webkit-appearance:none;-moz-appearance:none;appearance:none}.li-field select{text-align:left;font-size:var(--fs-sm);font-weight:500}.li-sub{display:flex;justify-content:space-between;align-items:center;padding:var(--s3) var(--s4);background:#ff7e8a0a}.li-sub-label{font-size:var(--fs-caption);color:var(--text3)}.li-sub-val{font-size:var(--fs-sub);font-weight:700;font-variant-numeric:tabular-nums}.add-line{display:flex;align-items:center;justify-content:center;gap:var(--s2);width:100%;height:48px;border:none;border-radius:var(--r-full);background:var(--accent-bg);color:var(--accent);font-family:var(--font);font-size:var(--fs-sub);font-weight:600;cursor:pointer;transition:all var(--dur-fast)}.add-line:active{background:#ff7e8a26}.add-line svg{width:16px;height:16px}.totals{background:var(--card);border-radius:var(--r2);overflow:hidden;box-shadow:var(--sh1)}.t-row{display:flex;justify-content:space-between;align-items:center;padding:var(--s3) var(--s4)}.t-row+.t-row{border-top:.5px solid var(--border)}.t-label{font-size:var(--fs-sub);color:var(--text2)}.t-val{font-size:var(--fs-sub);font-weight:600;font-variant-numeric:tabular-nums}.t-grand{background:var(--btn-primary-bg);color:var(--btn-primary-text)}.t-grand .t-label{color:#fffc;font-weight:600}.t-grand .t-val{font-size:var(--fs-xl);font-weight:800;color:var(--btn-primary-text)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--s2);height:52px;padding:0 var(--s6);border:none;border-radius:var(--r-full);font-family:var(--font);font-size:var(--fs-base);font-weight:600;cursor:pointer;width:100%;transition:transform var(--dur) var(--ease),opacity var(--dur-fast);-webkit-tap-highlight-color:transparent}.btn:active{transform:scale(.97);opacity:.85}.btn svg{width:18px;height:18px}.btn-primary{background:var(--btn-primary-bg);color:var(--btn-primary-text);box-shadow:var(--sh2)}.btn-secondary{background:#ff7e8a14;color:var(--accent)}.btn-soft{background:var(--fill);color:var(--text)}.btn-danger{background:var(--red-bg);color:var(--red)}.btn-text{background:none;color:var(--accent);height:auto;padding:var(--s2) var(--s3);font-weight:500;width:auto}.btn-text:active{opacity:.5;transform:none}.btn-sm{height:38px;font-size:var(--fs-sub);padding:0 var(--s3);border-radius:var(--r1);width:auto}.chip-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;background:var(--accent-bg);color:var(--accent);border:none;border-radius:var(--r-full);font-size:var(--fs-xs);font-weight:600;font-family:var(--font);cursor:pointer;transition:opacity var(--dur-fast)}.chip-btn svg{width:14px;height:14px}.chip-btn:active{opacity:.6}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:1000;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--card);border-radius:var(--r4) var(--r4) 0 0;width:100%;max-width:500px;max-height:88vh;overflow-y:auto;padding:0 var(--s5) calc(var(--s6) + var(--safe-bottom));animation:sheetUp .4s cubic-bezier(.34,1.56,.64,1);overscroll-behavior:contain}@keyframes sheetUp{0%{transform:translateY(100%);opacity:.5}to{transform:translateY(0);opacity:1}}.modal-handle{width:36px;height:5px;background:var(--text4);border-radius:var(--r-full);margin:10px auto 20px}.modal-title{font-size:var(--fs-lg);font-weight:700;margin-bottom:var(--s5);text-align:center}.modal-content .g-list+.g-list{margin-top:var(--s3);padding-top:var(--s1)}.toast{position:fixed;top:calc(var(--safe-top) + var(--s4));left:50%;transform:translate(-50%);padding:var(--s3) var(--s5);background:var(--text);color:var(--bg);border-radius:var(--r-full);font-size:var(--fs-caption);font-weight:600;box-shadow:var(--sh3);z-index:2000;animation:toastIn .5s cubic-bezier(.34,1.56,.64,1);white-space:nowrap}.toast.toast-out{animation:toastOut .3s var(--ease) forwards}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(-30px) scale(.8)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}@keyframes toastOut{to{opacity:0;transform:translate(-50%) translateY(-15px) scale(.9)}}.preview-wrap{padding:var(--s3) var(--s4);margin:0 var(--s4)}.preview-scaler{overflow:hidden}.pdf-page{width:210mm;background:#fff;color:#1e1e1e;padding:15mm 18mm;margin:0 auto;font-size:10pt;line-height:1.55;box-shadow:0 2px 8px #00000014,0 8px 30px #0000001f;font-family:Noto Sans JP,Hiragino Kaku Gothic ProN,sans-serif;border-radius:3px;border:1px solid rgba(0,0,0,.05);transform-origin:top left}.stamp-img{width:80px;height:80px;display:block;margin:var(--s3) auto;border-radius:4px}.stamp-placeholder{width:80px;height:80px;border-radius:var(--r1);border:2px dashed var(--text4);display:flex;align-items:center;justify-content:center;margin:var(--s3) auto;color:var(--text3);font-size:var(--fs-sm)}.toggle-wrap{position:relative;width:51px;height:31px;flex-shrink:0}.toggle-input{opacity:0;width:0;height:0;position:absolute}.toggle-track{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--text4);border-radius:31px;transition:background var(--dur) var(--ease);cursor:pointer}.toggle-track:after{content:"";position:absolute;top:2px;left:2px;width:27px;height:27px;background:#fff;border-radius:50%;box-shadow:0 1px 3px #00000026;transition:transform var(--dur) var(--ease)}.toggle-input:checked+.toggle-track{background:var(--accent)}.toggle-input:checked+.toggle-track:after{transform:translate(20px)}.mt-2{margin-top:var(--s2)}.mt-3{margin-top:var(--s3)}.mt-4{margin-top:var(--s4)}.mb-3{margin-bottom:var(--s3)}.mb-4{margin-bottom:var(--s4)}.px{padding-left:var(--s4);padding-right:var(--s4)}.filter-chips{display:flex;gap:8px;padding:0 var(--s4) var(--s3);overflow-x:auto;-webkit-overflow-scrolling:touch}.filter-chips .chip-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 14px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--card);color:var(--text2);font-size:var(--fs-caption);font-weight:500;cursor:pointer;white-space:nowrap;transition:all .2s ease;font-family:var(--font);-webkit-tap-highlight-color:transparent}.filter-chips .chip-btn:active{transform:scale(.95)}.filter-chips .chip-active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}.page-enter{animation:pgIn .25s var(--ease)}@keyframes pgIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1}}.report-period-bar{background:var(--fill);border-radius:var(--r2);padding:var(--s3) var(--s4);text-align:center;font-size:var(--fs-sub);font-weight:600;color:var(--text2);margin-bottom:var(--s4)}.report-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s3);margin-bottom:var(--s5)}.report-card{background:var(--white);border-radius:var(--r3);padding:var(--s4);box-shadow:var(--sh1);border-left:4px solid var(--text4)}.report-card.highlight{border-left-color:var(--green)}.report-card.warn{border-left-color:var(--red)}.report-label{font-size:var(--fs-xs);color:var(--text3);font-weight:600;margin-bottom:var(--s1)}.report-value{font-size:28px;font-weight:800;color:var(--text);line-height:1.1}.report-unit{font-size:var(--fs-sm);font-weight:500;color:var(--text3);margin-left:2px}.report-amount{font-size:var(--fs-md);color:var(--text);font-weight:700;margin-top:var(--s1);font-variant-numeric:tabular-nums}.ob-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:var(--white);display:flex;align-items:center;justify-content:center;animation:obFadeIn .3s ease}@keyframes obFadeIn{0%{opacity:0}to{opacity:1}}@keyframes obFadeOut{0%{opacity:1}to{opacity:0}}@keyframes obSlideIn{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:none}}.ob-slide{width:100%;max-width:400px;padding:var(--s6);display:flex;flex-direction:column;align-items:center;text-align:center}.ob-step-indicator{display:flex;gap:8px;margin-bottom:var(--s7)}.ob-dot{width:8px;height:8px;border-radius:50%;background:var(--text4);transition:all var(--dur) var(--ease)}.ob-dot.active{width:24px;border-radius:4px;background:var(--accent)}.ob-logo{width:96px;height:96px;background:var(--gradient);border-radius:28px;display:flex;align-items:center;justify-content:center;margin-bottom:var(--s6);box-shadow:var(--sh-accent)}.ob-logo-icon{color:#fff}.ob-logo-icon svg{width:42px;height:42px}.ob-title{font-size:30px;font-weight:800;letter-spacing:-.02em;line-height:1.3;margin-bottom:var(--s3);background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ob-heading{font-size:var(--fs-2xl);font-weight:800;letter-spacing:-.02em;margin-bottom:var(--s2)}.ob-desc,.ob-sub{font-size:var(--fs-sub);color:var(--text2);line-height:1.7;margin-bottom:var(--s5)}.ob-emoji{font-size:56px;margin-bottom:var(--s5)}.ob-confetti{font-size:72px;margin-bottom:var(--s5);animation:obBounce .6s var(--ease)}@keyframes obBounce{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.ob-features{display:flex;flex-direction:column;gap:var(--s3);width:100%;margin-bottom:var(--s6)}.ob-feature{display:flex;align-items:center;gap:var(--s3);text-align:left;background:var(--fill);padding:var(--s3) var(--s4);border-radius:var(--r2)}.ob-feature-icon{width:40px;height:40px;border-radius:var(--r1);display:flex;align-items:center;justify-content:center;flex-shrink:0}.ob-feature-icon svg{width:20px;height:20px}.ob-feature strong{font-size:var(--fs-sub);display:block}.ob-feature-sub{font-size:var(--fs-xs);color:var(--text3);margin-top:1px}.ob-input-wrap{width:100%;margin-bottom:var(--s6)}.ob-input{width:100%;height:56px;border:2px solid var(--border);border-radius:var(--r2);padding:0 var(--s4);font-size:var(--fs-lg);font-weight:500;text-align:center;color:var(--text);background:var(--fill);outline:none;transition:border-color var(--dur-fast);font-family:var(--font)}.ob-input:focus{border-color:var(--accent);background:var(--white);box-shadow:0 0 0 4px #ff7e8a1a}.ob-input::placeholder{color:var(--text4)}.ob-tax-cards{display:flex;flex-direction:column;gap:var(--s3);width:100%;margin-bottom:var(--s6)}.ob-tax-card{display:flex;align-items:flex-start;gap:var(--s3);padding:var(--s4);border:2px solid var(--border);border-radius:var(--r3);text-align:left;cursor:pointer;transition:all var(--dur) var(--ease);background:var(--white)}.ob-tax-card.selected{border-color:var(--accent);background:#ff7e8a08;box-shadow:0 0 0 3px #ff7e8a1a}.ob-tax-radio{width:24px;height:24px;border-radius:50%;border:2px solid var(--text4);flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:2px;transition:all var(--dur-fast)}.ob-tax-card.selected .ob-tax-radio{border-color:var(--accent)}.ob-tax-dot{width:12px;height:12px;border-radius:50%;background:transparent;transition:all var(--dur-fast)}.ob-tax-card.selected .ob-tax-dot{background:var(--accent)}.ob-tax-body{flex:1}.ob-tax-title{font-size:var(--fs-md);font-weight:700;margin-bottom:2px}.ob-tax-desc{font-size:var(--fs-caption);color:var(--text2);margin-bottom:var(--s2)}.ob-tax-hint{font-size:var(--fs-xs);color:var(--text3);line-height:1.5}.ob-tips{display:flex;flex-direction:column;gap:var(--s3);width:100%;margin-bottom:var(--s6)}.ob-tip{display:flex;align-items:center;gap:var(--s3);text-align:left;font-size:var(--fs-sub);color:var(--text2)}.ob-tip-num{width:28px;height:28px;border-radius:50%;background:var(--gradient);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--fs-sm);font-weight:800;flex-shrink:0}.ob-next{width:100%}.ob-next:disabled{opacity:.4;pointer-events:none}.ob-skip{margin-top:var(--s3);color:var(--text4)!important;font-size:var(--fs-xs)!important;background:none!important;border:none!important;box-shadow:none!important;height:auto!important;padding:var(--s2) var(--s3)!important;width:auto!important;text-decoration:underline;text-underline-offset:3px}.ob-illust{width:160px;height:160px;object-fit:contain;margin-bottom:var(--s5)}.ob-illust-sm{width:120px;height:120px}.ob-input-hint{font-size:var(--fs-xs);color:var(--text3);margin-top:var(--s2);line-height:1.6}.ob-privacy-icon{margin-bottom:var(--s4)}.ob-privacy-box{width:100%;background:var(--fill);border-radius:var(--r2);padding:var(--s4);margin-bottom:var(--s5);display:flex;flex-direction:column;gap:var(--s3)}.ob-privacy-item{display:flex;align-items:flex-start;gap:var(--s2);text-align:left;font-size:var(--fs-caption);color:var(--text2);line-height:1.5}.ob-privacy-check{color:var(--green);font-weight:700;font-size:var(--fs-md);flex-shrink:0;margin-top:-2px}.ob-agree-row{display:flex;align-items:center;gap:var(--s2);margin-bottom:var(--s5);font-size:var(--fs-caption);color:var(--text2);cursor:pointer}.ob-agree-check{width:22px;height:22px;accent-color:var(--accent);flex-shrink:0}
