@import "https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=Inter+Tight:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&family=Noto+Sans+JP:wght@400;500;600;700;800&family=Noto+Serif+JP:wght@400;500;600&display=swap";
:root{--studio-bg:#faf6f1;--studio-paper:#fefbf8;--studio-ink:#1a1511;--studio-muted:#5a544f;--studio-rule:#1a15111f;--studio-accent:#ca653c;--app-bg:#f5f7f4;--app-panel:#fff;--app-panel-soft:#edf3eb;--app-ink:#17211a;--app-muted:#718071;--app-line:#17211a1f;--app-green:#2f7d4f;--app-green-dark:#225b3a;--app-primary:#17211a;--app-red:#b42318;--app-gold:#9b6b1e}@supports (color:lab(0% 0 0)){:root{--studio-bg:lab(97.1139% .690103 2.95939);--studio-paper:lab(98.8548% .282347 1.88134);--studio-ink:lab(7.19909% 2.05951 3.4455);--studio-muted:lab(36.1757% 2.0691 4.02619);--studio-rule:lab(7.19909% 2.05951 3.4455/.12);--studio-accent:lab(54.8858% 38.7746 42.0978)}}*{box-sizing:border-box}html,body{min-height:100%;margin:0}body{background:var(--studio-bg);color:var(--studio-ink);letter-spacing:0;-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;font-family:Inter Tight,Noto Sans JP,sans-serif}button,input,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.72}a{color:inherit}.bj-auth-page{width:min(100%,1040px);min-height:100vh;color:var(--app-ink);background:radial-gradient(circle at 12% 10%, #b7791f29, transparent 28rem), radial-gradient(circle at 86% 20%, #22765c1f, transparent 30rem), var(--app-bg);grid-template-columns:minmax(0,1.08fr) minmax(360px,440px);align-items:center;gap:24px;margin:0 auto;padding:24px;display:grid}.bj-auth-hero,.bj-auth-card{border:1px solid var(--app-line);background:#fffaf2eb;border-radius:8px;box-shadow:0 24px 70px #24211d24}.bj-auth-hero{align-content:space-between;min-height:620px;padding:34px;display:grid}.bj-auth-brand{align-items:center;gap:12px;width:fit-content;text-decoration:none;display:inline-flex}.bj-auth-brand span{background:var(--app-green);color:#fffaf2;border-radius:8px;place-items:center;width:38px;height:38px;font-weight:800;display:grid}.bj-auth-brand strong{font-size:18px}.bj-eyebrow{color:var(--app-muted);letter-spacing:.08em;text-transform:uppercase;margin:0 0 12px;font-size:12px;font-weight:800}.bj-auth-hero h1{max-width:560px;margin:0;font-family:Instrument Serif,Noto Serif JP,serif;font-size:clamp(42px,6vw,68px);font-weight:400;line-height:1.02}.bj-auth-hero p:last-child{max-width:520px;color:var(--app-muted);margin:18px 0 0;font-size:16px;line-height:1.8}.bj-auth-metrics{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.bj-auth-metrics div{border:1px solid var(--app-line);background:#f1eadf;border-radius:8px;padding:16px}.bj-auth-metrics span,.bj-auth-metrics strong{display:block}.bj-auth-metrics span{color:var(--app-muted);font-size:12px;font-weight:700}.bj-auth-metrics strong{margin-top:8px;font-size:24px}.bj-auth-card{padding:34px}.bj-auth-heading{margin-bottom:22px}.bj-auth-heading h2{margin:0;font-size:32px;line-height:1.15}.bj-auth-heading p:last-child{color:var(--app-muted);margin:10px 0 0;line-height:1.7}.bj-auth-form{gap:14px;display:grid}.bj-auth-form label{color:var(--app-muted);gap:8px;font-size:13px;font-weight:800;display:grid}.bj-auth-form input{width:100%;height:44px;color:var(--app-ink);background:#fffdf8;border:1px solid #24211d2e;border-radius:8px;padding:0 12px}.bj-auth-form input:focus{border-color:var(--app-primary);outline:3px solid #17211a1f}.bj-primary-button,.bj-secondary-button{border:1px solid var(--app-primary);border-radius:8px;justify-content:center;align-items:center;gap:8px;width:100%;min-height:44px;font-weight:800;display:inline-flex}.bj-primary-button{background:var(--app-primary);color:#fffaf2}.bj-secondary-button{color:var(--app-ink);background:#fffdf8;border-color:#24211d2e}.bj-divider{color:var(--app-muted);grid-template-columns:1fr auto 1fr;align-items:center;gap:10px;margin:18px 0 14px;font-size:12px;font-weight:800;display:grid}.bj-divider span{background:var(--app-line);height:1px}.bj-form-message{color:var(--app-muted);text-align:center;margin:0;font-size:13px;line-height:1.5}.bj-auth-links{color:var(--app-primary);flex-wrap:wrap;justify-content:center;gap:12px;margin-top:20px;font-size:14px;font-weight:700;display:flex}.bj-auth-links a{text-decoration:none}.bj-spin{animation:.8s linear infinite bj-spin}@keyframes bj-spin{to{transform:rotate(360deg)}}.studio-page{background:radial-gradient(circle at 20% 10%, #b7791f29, transparent 28rem), radial-gradient(circle at 85% 30%, #22765c1f, transparent 30rem), var(--studio-bg);min-height:100vh;color:var(--studio-ink)}.studio-page:before{content:"";pointer-events:none;opacity:.38;background-image:radial-gradient(#00000007 1px,#0000 1px),radial-gradient(#00000005 1px,#0000 1px);background-position:0 0,1px 2px;background-size:3px 3px,7px 7px;position:fixed;inset:0}.studio-frame{z-index:1;max-width:1320px;margin:0 auto;padding:0 40px;position:relative}.studio-nav{z-index:10;background:color-mix(in oklch, var(--studio-bg) 84%, transparent);border-bottom:1px solid var(--studio-rule);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);position:sticky;top:0}.studio-nav-inner{justify-content:space-between;align-items:center;max-width:1320px;margin:0 auto;padding:18px 40px;display:flex}.studio-brand{align-items:center;gap:10px;text-decoration:none;display:inline-flex}.studio-mark{background:var(--studio-ink);width:26px;height:26px;color:var(--studio-bg);border-radius:6px;place-items:center;font-family:Instrument Serif,Noto Serif JP,serif;font-size:18px;font-style:italic;display:grid}.studio-brand-name{font-family:Instrument Serif,Noto Serif JP,serif;font-size:21px}.studio-brand-name em,.studio-em{color:var(--studio-accent);font-style:italic}.studio-links{color:var(--studio-muted);align-items:center;gap:24px;font-size:13px;font-weight:600;display:flex}.studio-links a{text-decoration:none}.studio-cta{border:1px solid var(--studio-rule);color:var(--studio-ink);background:var(--studio-paper);border-radius:999px;padding:9px 16px}.studio-hero{padding:84px 0 96px}.studio-meta{color:var(--studio-muted);letter-spacing:.04em;text-transform:uppercase;align-items:center;gap:14px;margin-bottom:52px;font-family:JetBrains Mono,monospace;font-size:11px;display:flex}.studio-dot{background:var(--studio-accent);width:6px;height:6px;box-shadow:0 0 0 4px color-mix(in oklch, var(--studio-accent) 24%, transparent);border-radius:50%}.studio-hero h1{max-width:980px;margin:0;font-family:Instrument Serif,Noto Serif JP,serif;font-size:clamp(58px,8vw,124px);font-weight:400;line-height:.98}.studio-hero-sub{border-top:1px solid var(--studio-rule);grid-template-columns:1fr 1.15fr;gap:56px;margin-top:34px;padding-top:36px;display:grid}.studio-copy{max-width:48ch;color:var(--studio-muted);margin:0;font-size:16px;line-height:1.7}.studio-side{color:var(--studio-muted);align-content:end;gap:8px;font-family:JetBrains Mono,monospace;font-size:11px;display:grid}.studio-side div{justify-content:space-between;gap:24px;display:flex}.studio-section{border-top:1px solid var(--studio-rule);padding:76px 0}.studio-section-head{justify-content:space-between;align-items:flex-end;gap:32px;margin-bottom:42px;display:flex}.studio-eyebrow{color:var(--studio-muted);letter-spacing:.06em;text-transform:uppercase;font-family:JetBrains Mono,monospace;font-size:11px}.studio-title{margin:10px 0 0;font-family:Instrument Serif,Noto Serif JP,serif;font-size:clamp(38px,4vw,58px);font-weight:400;line-height:1.05}.studio-grid{grid-template-columns:repeat(12,1fr);gap:16px;display:grid}.studio-card{border:1px solid var(--studio-rule);background:var(--studio-paper);border-radius:18px;flex-direction:column;grid-column:span 4;justify-content:space-between;min-height:260px;padding:24px;text-decoration:none;transition:transform .18s,box-shadow .18s;display:flex}.studio-card:hover{transform:translateY(-3px);box-shadow:0 18px 50px -28px #0000004d}.studio-card.featured{background:var(--studio-ink);min-height:330px;color:var(--studio-bg);grid-column:span 6}.studio-card-kicker{color:var(--studio-muted);letter-spacing:.08em;text-transform:uppercase;font-family:JetBrains Mono,monospace;font-size:10px}.studio-card.featured .studio-card-kicker{color:color-mix(in oklch, var(--studio-bg) 70%, transparent)}.studio-card h3{margin:14px 0 10px;font-family:Instrument Serif,Noto Serif JP,serif;font-size:34px;font-weight:400;line-height:1.05}.studio-card p{max-width:46ch;color:inherit;opacity:.78;margin:0;line-height:1.6}.studio-stack-grid{border:1px solid var(--studio-rule);background:var(--studio-rule);border-radius:14px;grid-template-columns:repeat(3,1fr);gap:1px;display:grid;overflow:hidden}.studio-stack-item{background:var(--studio-paper);min-height:138px;padding:28px 30px}.studio-tags{flex-wrap:wrap;gap:8px;margin-top:16px;display:flex}.studio-tags span{border:1px solid var(--studio-rule);color:var(--studio-muted);border-radius:999px;padding:5px 12px;font-family:JetBrains Mono,monospace;font-size:11px}.studio-philosophy{grid-template-columns:1fr 2fr;gap:72px;display:grid}.studio-philosophy blockquote{margin:0;font-family:Instrument Serif,Noto Serif JP,serif;font-size:clamp(30px,3.4vw,48px);font-weight:400;line-height:1.25}.studio-signature{color:var(--studio-muted);letter-spacing:.04em;margin-top:32px;font-family:JetBrains Mono,monospace;font-size:11px}.studio-stats{border-top:1px solid var(--studio-rule);border-bottom:1px solid var(--studio-rule);grid-template-columns:repeat(4,1fr);display:grid}.studio-stat{border-right:1px solid var(--studio-rule);min-height:190px;padding:32px 28px}.studio-stat:last-child{border-right:0}.studio-stat-number{margin-bottom:18px;font-family:Instrument Serif,Noto Serif JP,serif;font-size:clamp(48px,5vw,72px);line-height:1}.studio-stat p{color:var(--studio-muted);margin:12px 0 0;font-size:13px}.studio-contact{border-top:1px solid var(--studio-rule);padding:90px 0}.studio-contact-inner{grid-template-columns:1fr auto;align-items:end;gap:40px;display:grid}.studio-contact h2{margin:18px 0 0;font-family:Instrument Serif,Noto Serif JP,serif;font-size:clamp(52px,6vw,90px);font-weight:400;line-height:1}.studio-contact-actions{flex-direction:column;align-items:flex-end;gap:14px;display:flex}.studio-contact-actions a{border:1px solid var(--studio-ink);background:var(--studio-ink);min-width:150px;color:var(--studio-bg);text-align:center;border-radius:999px;padding:14px 22px;font-weight:600;text-decoration:none}.studio-contact-actions a:last-child{color:var(--studio-ink);border-color:var(--studio-rule);background:0 0}.studio-footer{border-top:1px solid var(--studio-rule);padding:56px 0 34px}.studio-footer-grid{grid-template-columns:2fr 1fr 1fr;gap:56px;margin-bottom:48px;display:grid}.studio-footer p{margin:0 0 22px;font-family:Instrument Serif,Noto Serif JP,serif;font-size:24px;line-height:1.35}.studio-footer span,.studio-footer-bottom{color:var(--studio-muted);letter-spacing:.04em;font-family:JetBrains Mono,monospace;font-size:11px}.studio-footer h4{color:var(--studio-muted);letter-spacing:.08em;text-transform:uppercase;margin:0 0 14px;font-family:JetBrains Mono,monospace;font-size:11px}.studio-footer a{color:var(--studio-muted);padding:5px 0;text-decoration:none;display:block}.studio-footer-bottom{border-top:1px solid var(--studio-rule);justify-content:space-between;gap:24px;padding-top:26px;display:flex}.app-shell{background:linear-gradient(135deg, #17211a0d, transparent 24rem), radial-gradient(circle at 82% 12%, #caac531f, transparent 24rem), var(--app-bg);min-height:100vh;color:var(--app-ink);font-family:Noto Sans JP,sans-serif}.app-layout{grid-template-columns:260px minmax(0,1fr);min-height:100vh;display:grid}.app-sidebar{border-right:1px solid var(--app-line);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffdb;height:100vh;padding:24px 18px;position:sticky;top:0}.app-brand{align-items:center;gap:10px;margin-bottom:24px;font-size:19px;font-weight:800;display:flex}.app-brand-icon{background:var(--app-green);width:36px;height:36px;color:var(--app-panel);border-radius:10px;place-items:center;display:grid}.month-box,.side-card{border:1px solid var(--app-line);background:var(--app-panel);border-radius:8px;margin-bottom:18px;padding:14px}.month-row{grid-template-columns:36px 1fr 36px;align-items:center;gap:8px;display:grid}.icon-button,.month-button{border:1px solid var(--app-line);min-height:36px;color:var(--app-ink);background:#fff;border-radius:8px;place-items:center;display:inline-grid}.month-button{justify-content:center;gap:8px;padding:0 10px;font-size:13px;font-weight:700;display:inline-flex}.app-nav{gap:6px;display:grid}.nav-item{width:100%;color:var(--app-muted);text-align:left;background:0 0;border:0;border-radius:8px;align-items:center;gap:10px;padding:11px 12px;font-weight:700;display:flex}.nav-item.active{background:var(--app-primary);color:var(--app-panel)}.app-main{min-width:0;padding:28px}.topbar{justify-content:space-between;align-items:center;gap:18px;margin-bottom:20px;display:flex}.topbar h1{margin:0;font-size:28px}.mode-tabs{border:1px solid var(--app-line);background:var(--app-panel);border-radius:999px;padding:4px;display:inline-flex}.mode-tabs button{color:var(--app-muted);background:0 0;border:0;border-radius:999px;align-items:center;gap:6px;padding:8px 14px;font-weight:800;display:inline-flex}.mode-tabs button.active{background:var(--app-primary);color:var(--app-panel)}.panel-grid{grid-template-columns:repeat(12,1fr);gap:16px;display:grid}.panel{border:1px solid var(--app-line);background:#ffffffeb;border-radius:8px;grid-column:span 12;padding:18px}.panel.half{grid-column:span 6}.panel.third{grid-column:span 4}.hero-panel{background:var(--app-primary);color:var(--app-panel);grid-template-columns:1fr auto;align-items:end;gap:18px;display:grid}.hero-panel .balance{margin:10px 0 0;font-size:clamp(42px,7vw,78px);font-weight:900;line-height:1}.stat-row{gap:10px;margin-top:14px;display:flex}.stat{border:1px solid #ffffff2e;border-radius:8px;min-width:140px;padding:12px}.stat-label{color:#fffaf2a3;font-size:12px;font-weight:700}.stat-value{margin-top:4px;font-size:22px;font-weight:900}.income{color:var(--app-primary)}.expense{color:var(--app-red)}.btn{border:1px solid var(--app-line);min-height:40px;color:var(--app-ink);background:#fff;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:0 14px;font-weight:800;text-decoration:none;display:inline-flex}.btn.primary{border-color:var(--app-primary);background:var(--app-primary);color:var(--app-panel)}.btn.danger{color:var(--app-red);border-color:#bd3d3242}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.field{color:var(--app-muted);gap:6px;font-size:12px;font-weight:800;display:grid}.field.full{grid-column:1/-1}.field input,.field select,.field textarea,.search-input{border:1px solid var(--app-line);width:100%;min-height:42px;color:var(--app-ink);background:#fbfdf9;border-radius:8px;padding:0 12px}.category-grid{flex-wrap:wrap;gap:8px;display:flex}.chip{border:1px solid var(--app-line);color:var(--app-muted);background:#fff;border-radius:999px;align-items:center;gap:6px;padding:7px 11px;font-size:12px;font-weight:800;display:inline-flex}.chip.active{border-color:var(--app-primary);background:var(--app-primary);color:var(--app-panel)}.table{gap:8px;display:grid}.record-row{border:1px solid var(--app-line);background:#fff;border-radius:8px;grid-template-columns:96px 80px 1fr 120px 84px;align-items:center;gap:12px;padding:12px;display:grid}.record-note{color:var(--app-muted);font-size:13px}.category-label{align-items:center;gap:8px;display:inline-flex}.category-icon{border-radius:999px;flex:none;place-items:center;width:26px;height:26px;display:inline-grid}.record-actions{justify-content:flex-end;gap:6px;display:flex}.empty{color:var(--app-muted);text-align:center;padding:28px}.toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:14px;display:flex}.segmented-control{border:1px solid var(--app-line);background:#fff;border-radius:8px;display:inline-flex;overflow:hidden}.segmented-control button{border:0;border-right:1px solid var(--app-line);min-height:36px;color:var(--app-muted);background:0 0;padding:0 12px;font-size:12px;font-weight:800}.segmented-control button:last-child{border-right:0}.segmented-control button.active{background:var(--app-primary);color:var(--app-panel)}.budget-row{grid-template-columns:120px 1fr 110px;align-items:center;gap:12px;margin-bottom:12px;display:grid}.progress{background:#24211d1a;border-radius:999px;height:10px;overflow:hidden}.progress span{background:var(--app-gold);border-radius:999px;height:100%;display:block}.notice{color:#654615;background:#9b6b1e17;border:1px solid #9b6b1e3d;border-radius:8px;padding:12px}.account-details{gap:10px;margin:14px 0;display:grid}.account-details div{border:1px solid var(--app-line);background:#fff;border-radius:8px;gap:4px;padding:12px;display:grid}.account-details span{color:var(--app-muted);font-size:12px;font-weight:800}.account-details strong{overflow-wrap:anywhere}.error{color:var(--app-red);background:#bd3d3217;border:1px solid #bd3d3252}.modal-backdrop{z-index:40;background:#24211d6b;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.modal{background:var(--app-panel);border-radius:10px;width:min(720px,100%);max-height:min(86vh,860px);padding:20px;overflow:auto;box-shadow:0 24px 90px #00000047}.modal-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.modal-head h2{margin:0}@media (max-width:920px){.studio-frame,.studio-nav-inner{padding-inline:20px}.studio-links{gap:12px}.studio-links a:not(.studio-cta){display:none}.studio-hero-sub,.studio-stack-grid,.studio-philosophy,.studio-stats,.studio-contact-inner,.studio-footer-grid,.app-layout{grid-template-columns:1fr}.studio-section-head{flex-direction:column;align-items:flex-start}.studio-stat{border-right:0;border-bottom:1px solid var(--studio-rule)}.studio-stat:last-child{border-bottom:0}.studio-contact-actions{align-items:stretch}.studio-footer-bottom{flex-direction:column}.studio-card,.studio-card.featured,.panel.half,.panel.third{grid-column:span 12}.app-sidebar{border-right:0;border-bottom:1px solid var(--app-line);height:auto;position:static}.app-nav{grid-template-columns:repeat(5,minmax(0,1fr))}.nav-item{justify-content:center;padding:10px 6px;font-size:12px}.nav-item span{display:none}.hero-panel,.record-row,.budget-row,.form-grid{grid-template-columns:1fr}.app-main{padding:18px}}
