*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #FAF9F7;--color-surface: #FFFFFF;--color-text: #2C2C2C;--color-text-soft: #6B6B6B;--color-text-muted: #A8A8A8;--color-border: #EEEBE6;--color-accent: #2C2C2C;--color-accent-soft: #F5F3F0;--color-success: #7CB386;--font-sans: "SF Pro Display", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-serif: "New York", Georgia, "Times New Roman", serif;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-full: 100px;--ease-out: cubic-bezier(.16, 1, .3, 1);--duration: .3s}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);line-height:1.5;min-height:100vh;min-height:100dvh}#root{min-height:100vh;min-height:100dvh}.app{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;max-width:420px;margin:0 auto;background:var(--color-surface)}.screen{flex:1;display:flex;flex-direction:column;padding-bottom:80px}.converter-screen{justify-content:space-between;align-items:center;padding:var(--space-lg) var(--space-lg);padding-bottom:72px;min-height:calc(100vh - 72px);min-height:calc(100dvh - 72px);overflow:hidden}.converter-header{text-align:center;padding-top:var(--space-lg);flex-shrink:0}.app-logo{width:52px;height:52px;color:var(--color-text);margin-bottom:var(--space-md)}.app-name{font-family:var(--font-serif);font-size:2rem;font-weight:500;letter-spacing:-.02em;color:var(--color-text);margin-bottom:var(--space-sm)}.app-tagline{font-size:.875rem;font-weight:400;color:var(--color-text-muted);max-width:240px;margin:0 auto;line-height:1.5}.converter-content{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;max-width:280px;flex:1;padding:var(--space-md) 0}.converter-question{font-size:.8125rem;font-weight:400;color:var(--color-text-soft);margin-bottom:var(--space-xs);letter-spacing:.02em}.converter-helper{font-size:.75rem;color:var(--color-text-muted);margin-bottom:var(--space-lg);text-align:center;max-width:220px;line-height:1.5;transition:opacity var(--duration) var(--ease-out)}.converter-helper.hidden{opacity:0}.converter-input-area{display:flex;align-items:baseline;justify-content:center;width:100%;margin-bottom:var(--space-xl);padding-bottom:var(--space-sm);border-bottom:1.5px solid var(--color-border)}.input-currency{font-size:1.5rem;font-weight:300;color:var(--color-text-muted);margin-right:2px;-webkit-user-select:none;user-select:none}.converter-input{font-family:var(--font-sans);font-size:3rem;font-weight:200;letter-spacing:-.03em;color:var(--color-text);background:transparent;border:none;outline:none;width:100%;max-width:160px;text-align:left;caret-color:var(--color-text-soft)}.converter-input::placeholder{color:var(--color-border)}.converter-output{display:flex;flex-direction:column;align-items:center;min-height:70px}.converter-output .output-value,.converter-output .output-label{opacity:0;transform:translateY(8px);transition:opacity var(--duration) var(--ease-out),transform var(--duration) var(--ease-out)}.converter-output.visible .output-value,.converter-output.visible .output-label{opacity:1;transform:translateY(0)}.converter-output .output-example{opacity:1;transition:opacity var(--duration) var(--ease-out)}.converter-output.visible .output-example{opacity:0}.output-context{font-size:.875rem;color:var(--color-text-soft);margin-bottom:var(--space-xs)}.output-explanation{font-size:.8125rem;color:var(--color-text-muted);margin-top:var(--space-md);text-align:center;line-height:1.5}.output-value{font-family:var(--font-serif);font-size:1.625rem;font-weight:500;letter-spacing:-.01em;color:var(--color-text);text-align:center;line-height:1.3}.output-label{font-size:.875rem;font-weight:400;color:var(--color-text-soft);margin-top:var(--space-xs)}.output-placeholder{font-size:1.75rem;font-weight:200;color:var(--color-border)}.output-example{text-align:center}.example-text{font-size:.875rem;color:var(--color-text-muted);font-style:italic}.converter-actions{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);margin-top:var(--space-lg);width:100%;animation:fadeIn .4s var(--ease-out)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.add-button{background:var(--color-accent);color:var(--color-surface);border:none;border-radius:var(--radius-full);padding:var(--space-md) var(--space-xl);font-size:.9375rem;font-weight:500;cursor:pointer;transition:transform var(--duration) var(--ease-out),background var(--duration) var(--ease-out)}.add-button:hover{transform:scale(1.03)}.add-button:active{transform:scale(.97)}.add-button.added{background:var(--color-success)}.label-toggle{background:var(--color-accent-soft);border:none;border-radius:var(--radius-full);font-size:.8125rem;color:var(--color-text-soft);cursor:pointer;padding:var(--space-sm) var(--space-md);transition:background var(--duration),color var(--duration)}.label-toggle:hover{background:var(--color-border);color:var(--color-text)}.label-input{background:var(--color-accent-soft);border:none;border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);font-size:.9375rem;text-align:center;width:100%;outline:none;color:var(--color-text);font-family:var(--font-sans);transition:box-shadow var(--duration)}.label-input:focus{box-shadow:0 0 0 2px var(--color-border)}.label-input::placeholder{color:var(--color-text-muted)}.converter-footer{flex-shrink:0;display:flex;justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md)}.footer-link{background:none;border:none;font-size:.75rem;color:var(--color-text-muted);cursor:pointer;padding:var(--space-xs) var(--space-sm);letter-spacing:.03em;transition:color var(--duration)}.footer-link:hover{color:var(--color-text-soft)}.footer-dot{color:var(--color-text-muted);font-size:.75rem;opacity:.5}.calibration-screen .screen-header{padding:var(--space-lg);display:flex;align-items:center;gap:var(--space-md)}.calibration-screen .screen-header h1{font-family:var(--font-serif);font-size:1.125rem;font-weight:500}.back-button{background:none;border:none;padding:var(--space-sm);cursor:pointer;color:var(--color-text-soft);border-radius:var(--radius-sm);transition:background var(--duration),color var(--duration);display:flex;align-items:center;justify-content:center}.back-button:hover{background:var(--color-accent-soft);color:var(--color-text)}.calibration-main{padding:var(--space-sm) var(--space-lg) var(--space-lg);display:flex;flex-direction:column;gap:var(--space-lg)}.calibration-intro{font-size:.9375rem;color:var(--color-text-soft);line-height:1.7}.input-group{display:flex;flex-direction:column;gap:var(--space-sm)}.input-group label{font-size:.75rem;font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em}.currency-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--color-accent-soft);border:none;border-radius:var(--radius-md);padding:var(--space-md);padding-right:var(--space-2xl);font-size:1rem;font-family:var(--font-sans);color:var(--color-text);cursor:pointer;outline:none;transition:box-shadow var(--duration);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236B6B6B' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.currency-select:focus{box-shadow:0 0 0 2px var(--color-border)}.currency-custom-input{margin-top:var(--space-sm);background:var(--color-accent-soft);border:none;border-radius:var(--radius-md);padding:var(--space-md);font-size:1rem;color:var(--color-text);outline:none;transition:box-shadow var(--duration)}.currency-custom-input:focus{box-shadow:0 0 0 2px var(--color-border)}.currency-custom-input::placeholder{color:var(--color-text-muted)}.toggle-group{display:flex;background:var(--color-accent-soft);border-radius:var(--radius-md);padding:3px;gap:3px}.toggle-option{flex:1;background:transparent;border:none;padding:var(--space-md);font-size:.875rem;font-weight:500;color:var(--color-text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration) var(--ease-out)}.toggle-option.active{background:var(--color-surface);color:var(--color-text);box-shadow:0 1px 3px #0000000f}.cost-input-wrapper{display:flex;align-items:center;background:var(--color-accent-soft);border-radius:var(--radius-md);padding:0 var(--space-md);transition:box-shadow var(--duration)}.cost-input-wrapper:focus-within{box-shadow:0 0 0 2px var(--color-border)}.currency-symbol{font-size:.9375rem;color:var(--color-text-muted);margin-right:var(--space-xs)}.cost-input-wrapper input{flex:1;border:none;background:transparent;font-size:1rem;padding:var(--space-md) 0;outline:none;width:100%;color:var(--color-text);font-family:var(--font-sans)}.input-group>input{background:var(--color-accent-soft);border:none;border-radius:var(--radius-md);padding:var(--space-md);font-size:1rem;outline:none;transition:box-shadow var(--duration);color:var(--color-text);font-family:var(--font-sans)}.input-group>input:focus{box-shadow:0 0 0 2px var(--color-border)}input::placeholder{color:var(--color-text-muted)}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.button-group{display:flex;flex-direction:column;gap:var(--space-sm);margin-top:var(--space-md)}.primary-button{background:var(--color-accent);color:var(--color-surface);border:none;border-radius:var(--radius-full);padding:var(--space-md) var(--space-lg);font-size:.9375rem;font-weight:500;cursor:pointer;transition:transform var(--duration) var(--ease-out)}.primary-button:hover{transform:scale(1.02)}.primary-button:active{transform:scale(.98)}.secondary-button{background:transparent;color:var(--color-text-soft);border:none;border-radius:var(--radius-full);padding:var(--space-md) var(--space-lg);font-size:.9375rem;font-weight:500;cursor:pointer;transition:background var(--duration)}.secondary-button:hover{background:var(--color-accent-soft)}.onboarding-screen{display:flex;flex-direction:column;justify-content:center;padding:var(--space-2xl) var(--space-lg)}.onboarding-main{display:flex;flex-direction:column;align-items:center;text-align:center;max-width:320px;margin:0 auto}.onboarding-header{margin-bottom:var(--space-2xl)}.onboarding-logo{width:80px;height:80px;color:var(--color-text);margin-bottom:var(--space-md)}.onboarding-title{font-family:var(--font-serif);font-size:2.5rem;font-weight:500;letter-spacing:-.02em;color:var(--color-text);margin:0}.onboarding-content{display:flex;flex-direction:column;gap:var(--space-lg);margin-bottom:var(--space-2xl)}.onboarding-content p{font-size:1.0625rem;line-height:1.7;color:var(--color-text-soft)}.onboarding-actions{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg)}.onboarding-cta{min-width:160px}.onboarding-why{font-size:.875rem}@media (max-height: 640px){.onboarding-logo{width:64px;height:64px;margin-bottom:var(--space-sm)}.onboarding-title{font-size:2rem}.onboarding-header{margin-bottom:var(--space-xl)}}.about-screen .screen-header{flex-shrink:0;padding:var(--space-lg);display:flex;align-items:center;gap:var(--space-md)}.about-screen .screen-header h1{font-family:var(--font-serif);font-size:1.125rem;font-weight:500}.about-main{flex:1;min-height:0;padding:var(--space-lg) var(--space-lg) var(--space-md);display:flex;flex-direction:column;align-items:center;text-align:center;max-width:320px;margin:0 auto;overflow-y:auto}.about-title{font-family:var(--font-serif);font-size:2rem;font-weight:500;letter-spacing:-.02em;color:var(--color-text);margin-bottom:var(--space-lg)}.about-content{display:flex;flex-direction:column;gap:var(--space-md);margin-bottom:var(--space-lg)}.about-content p{font-size:1.0625rem;line-height:1.7;color:var(--color-text-soft)}.about-coda{font-family:var(--font-serif);font-size:.9375rem;font-style:italic;color:var(--color-text-muted);line-height:1.6;padding-top:var(--space-md);border-top:1px solid var(--color-border)}.about-footer{flex-shrink:0;display:flex;justify-content:center;align-items:center;padding:var(--space-md) var(--space-md)}@media (max-height: 640px){.about-screen .screen-header{padding:var(--space-md) var(--space-lg)}.about-main{padding:var(--space-md) var(--space-lg) var(--space-sm)}.about-title{font-size:1.75rem;margin-bottom:var(--space-md)}.about-content{gap:var(--space-sm);margin-bottom:var(--space-md)}.about-content p{font-size:1rem;line-height:1.6}.about-coda{padding-top:var(--space-sm);font-size:.875rem}.about-footer{padding:var(--space-sm) var(--space-md)}}.ledger-screen .screen-header{padding:var(--space-lg);display:flex;align-items:flex-start;gap:var(--space-md)}.ledger-screen .screen-header .header-text{display:flex;flex-direction:column;gap:2px}.ledger-screen .screen-header h1{font-family:var(--font-serif);font-size:1.125rem;font-weight:500}.header-subtitle{font-size:.75rem;color:var(--color-text-muted);font-weight:400}.ledger-main{padding:var(--space-sm) var(--space-lg) var(--space-lg);display:flex;flex-direction:column;gap:var(--space-lg)}.period-selector{display:flex;justify-content:center;gap:var(--space-xs)}.period-option{background:none;border:none;padding:var(--space-sm) var(--space-md);font-size:.8125rem;font-weight:500;color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-full);transition:color var(--duration),background var(--duration)}.period-option:hover{color:var(--color-text-soft)}.period-option.active{color:var(--color-text);background:var(--color-accent-soft)}.total-display{text-align:center;padding:var(--space-lg) 0}.total-amount{display:block;font-family:var(--font-serif);font-size:2.5rem;font-weight:500;color:var(--color-text);letter-spacing:-.02em;line-height:1.2}.total-context{display:block;font-size:.875rem;color:var(--color-text-muted);margin-top:var(--space-xs)}.entries-section{flex:1}.empty-state{text-align:center;padding:var(--space-2xl) var(--space-lg)}.empty-state p:first-child{font-size:.9375rem;font-weight:500;color:var(--color-text-soft);margin-bottom:var(--space-sm)}.empty-hint{font-size:.8125rem;color:var(--color-text-muted)}.entries-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-sm)}.entry-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);background:var(--color-accent-soft);border-radius:var(--radius-md);gap:var(--space-md);transition:background var(--duration)}.entry-item:hover{background:var(--color-border)}.entry-content{display:flex;align-items:baseline;gap:var(--space-md);flex:1;min-width:0}.entry-time{font-family:var(--font-serif);font-size:1rem;font-weight:500;color:var(--color-text);flex-shrink:0}.entry-label{font-size:.875rem;color:var(--color-text-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.entry-label-placeholder{color:var(--color-text-muted);font-style:italic}.entry-content{cursor:pointer}.entry-item.editing{background:var(--color-border)}.entry-edit{display:flex;align-items:center;gap:var(--space-md);flex:1}.entry-label-input{flex:1;background:var(--color-surface);border:none;border-radius:var(--radius-sm);padding:var(--space-sm) var(--space-md);font-size:.875rem;color:var(--color-text);outline:none;font-family:var(--font-sans)}.entry-label-input::placeholder{color:var(--color-text-muted)}.entry-timestamp{font-size:.6875rem;color:var(--color-text-muted);flex-shrink:0;margin-left:auto;letter-spacing:.02em;cursor:pointer;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);transition:background var(--duration),color var(--duration)}.entry-timestamp:hover{background:var(--color-surface);color:var(--color-text-soft)}.entry-date-input{font-size:.75rem;background:var(--color-surface);border:none;border-radius:var(--radius-sm);padding:var(--space-xs) var(--space-sm);color:var(--color-text);outline:none;font-family:var(--font-sans);margin-left:auto;flex-shrink:0}.remove-button{background:none;border:none;padding:var(--space-xs);cursor:pointer;color:var(--color-text-muted);border-radius:var(--radius-sm);transition:color var(--duration),background var(--duration);flex-shrink:0;opacity:0}.entry-item:hover .remove-button{opacity:1}.remove-button:hover{color:var(--color-text);background:var(--color-surface)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--color-surface);border-top:1px solid var(--color-border);display:flex;justify-content:center;gap:var(--space-3xl);padding:var(--space-sm) var(--space-lg);padding-bottom:max(var(--space-sm),env(safe-area-inset-bottom));max-width:420px;margin:0 auto}.nav-item{background:none;border:none;display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);cursor:pointer;color:var(--color-text-muted);transition:color var(--duration)}.nav-item svg{width:22px;height:22px}.nav-item span{font-size:.6875rem;font-weight:500;letter-spacing:.04em}.nav-item.active{color:var(--color-text)}.nav-item:hover{color:var(--color-text-soft)}@media (max-height: 700px){.converter-header{padding-top:var(--space-md)}.app-logo{width:44px;height:44px;margin-bottom:var(--space-sm)}.app-name{font-size:1.75rem}.app-tagline{font-size:.8125rem}.converter-question{margin-bottom:var(--space-md)}.converter-input{font-size:2.5rem}.converter-input-area{margin-bottom:var(--space-lg)}.output-value{font-size:1.375rem}.converter-actions{margin-top:var(--space-md)}.add-button{padding:var(--space-sm) var(--space-lg)}}@media (min-width: 421px){.app{box-shadow:0 0 60px #0000000a;border-left:1px solid var(--color-border);border-right:1px solid var(--color-border)}.bottom-nav{max-width:420px;margin:0 auto}}@media (prefers-color-scheme: dark){:root{--color-bg: #0C0C0C;--color-surface: #141414;--color-text: #F0EFED;--color-text-soft: #A0A0A0;--color-text-muted: #7A7A7A;--color-border: #2A2A2A;--color-accent: #F0EFED;--color-accent-soft: #1E1E1E;--color-success: #7CB386}.primary-button,.add-button{color:var(--color-bg)}.toggle-option.active{box-shadow:0 1px 3px #0000004d}.app{box-shadow:none}}
