@import "https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/variable/pretendardvariable-dynamic-subset.min.css";
@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--color-primary:#ff7a00;--color-primary-light:#ff9e43;--color-primary-dark:#d35400;--color-secondary:#2d3436;--color-secondary-light:#636e72;--color-success:#00b894;--color-success-bg:#00b89414;--color-danger:#ff6b6b;--color-danger-bg:#ff6b6b14;--color-warning:#fdcb6e;--color-warning-bg:#fdcb6e14;--color-info:#74b9ff;--color-info-bg:#74b9ff14;--bg-base:#f4f6f9;--bg-surface:#fff;--bg-elevated:#eaeff5;--bg-hover:#e1e6ed;--bg-active:#d4dbe5;--glass-bg:#ffffffbf;--glass-border:#00000014;--glass-hover:#ffffffe6;--glass-blur:16px;--text-primary:#2d3436;--text-secondary:#636e72;--text-tertiary:#b2bec3;--text-inverse:#fff;--border-default:#00000014;--border-strong:#00000029;--border-focus:var(--color-primary);--shadow-sm:0 2px 8px #0000000f;--shadow-md:0 4px 16px #00000014;--shadow-lg:0 8px 32px #0000001f;--shadow-glow:0 0 30px #ff7a0026;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--font-sans:"Pretendard Variable", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"SF Mono", "Fira Code", monospace;--text-xs:.75rem;--text-sm:.8125rem;--text-base:.9375rem;--text-lg:1.125rem;--text-xl:1.3125rem;--text-2xl:1.625rem;--text-3xl:2rem;--text-4xl:2.5rem;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1);--transition-spring:.5s cubic-bezier(.34, 1.56, .64, 1);--sidebar-width:260px;--sidebar-collapsed:72px;--header-height:64px;--z-dropdown:100;--z-sticky:200;--z-modal-backdrop:300;--z-modal:400;--z-toast:500}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);background:var(--bg-base);color:var(--text-primary);min-height:100vh;line-height:1.6;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(at 20% 20%,#ff7a000a 0%,#0000 50%),radial-gradient(at 80% 80%,#fdcb6e08 0%,#0000 50%),radial-gradient(#ff6b6b05 0%,#0000 60%);animation:15s ease-in-out infinite alternate bgPulse;position:fixed;inset:0}@keyframes bgPulse{0%{opacity:.6}50%{opacity:1}to{opacity:.7}}a{color:var(--color-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary-dark)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#0000001f}::-webkit-scrollbar-thumb:hover{background:#0000003d}.glass{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-lg);transition:all var(--transition-base)}.glass:hover{background:var(--glass-hover);border-color:var(--border-strong);box-shadow:var(--shadow-md)}.btn{justify-content:center;align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;border:none;padding:10px 20px;font-weight:600;display:inline-flex;position:relative;overflow:hidden}.btn:after{content:"";opacity:0;transition:opacity var(--transition-fast);background:linear-gradient(135deg,#ffffff1a 0%,#0000 100%);position:absolute;inset:0}.btn:hover:after{opacity:1}.btn:active{transform:scale(.97)}.btn-primary{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));color:#fff;box-shadow:0 4px 15px #6c5ce74d}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #6c5ce780}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-default)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-strong)}.btn-danger{background:linear-gradient(135deg, var(--color-danger), #e55555);color:#fff;box-shadow:0 4px 15px #ff6b6b4d}.btn-danger:hover{transform:translateY(-1px);box-shadow:0 6px 20px #ff6b6b80}.btn-success{background:linear-gradient(135deg, var(--color-success), #00a383);color:#fff;box-shadow:0 4px 15px #00b8944d}.btn-ghost{color:var(--text-secondary);background:0 0;padding:8px 12px}.btn-ghost:hover{background:var(--glass-hover);color:var(--text-primary)}.btn-sm{font-size:var(--text-xs);padding:6px 14px}.btn-lg{font-size:var(--text-base);padding:14px 28px}.btn-icon{width:36px;height:36px;padding:8px}.form-group{gap:var(--space-sm);flex-direction:column;display:flex}.form-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.form-input,.form-select,.form-textarea{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);width:100%;color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-sm);transition:all var(--transition-fast);outline:none;padding:10px 14px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);background:var(--bg-hover);box-shadow:0 0 0 3px #6c5ce726}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-tertiary)}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23A0A0B8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.form-select option{background:var(--bg-surface);color:var(--text-primary)}.form-textarea{resize:vertical;min-height:80px}.badge{border-radius:var(--radius-full);font-size:var(--text-xs);letter-spacing:.02em;align-items:center;padding:3px 10px;font-weight:600;display:inline-flex}.badge-success{background:var(--color-success-bg);color:var(--color-success)}.badge-danger{background:var(--color-danger-bg);color:var(--color-danger)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning)}.badge-info{background:var(--color-info-bg);color:var(--color-info)}.badge-primary{color:var(--color-primary-light);background:#6c5ce71f}.badge-neutral{color:var(--text-secondary);background:#ffffff0f}.table-container{border-radius:var(--radius-lg);border:1px solid var(--border-default);background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}.table th{text-align:left;color:var(--text-secondary);font-weight:600;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-default);white-space:nowrap;background:#ffffff05;padding:14px 16px}.table td{color:var(--text-primary);vertical-align:middle;border-bottom:1px solid #ffffff08;padding:12px 16px}.table tbody tr{transition:background var(--transition-fast)}.table tbody tr:hover{background:#ffffff08}.table tbody tr:last-child td{border-bottom:none}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal-backdrop);animation:fadeIn var(--transition-fast) ease;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:90%;max-width:560px;max-height:85vh;z-index:var(--z-modal);animation:modalSlideUp var(--transition-spring) ease;overflow-y:auto}.modal-header{padding:var(--space-lg);border-bottom:1px solid var(--border-default);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--text-lg);font-weight:700}.modal-body{padding:var(--space-lg);gap:var(--space-md);flex-direction:column;display:flex}.modal-footer{justify-content:flex-end;align-items:center;gap:var(--space-sm);padding:var(--space-lg);border-top:1px solid var(--border-default);display:flex}.stat-card{padding:var(--space-lg);border-radius:var(--radius-lg);background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);transition:all var(--transition-base);position:relative;overflow:hidden}.stat-card:before{content:"";border-radius:var(--radius-lg) var(--radius-lg) 0 0;height:3px;position:absolute;top:0;left:0;right:0}.stat-card.income:before{background:linear-gradient(90deg, var(--color-success), var(--color-secondary))}.stat-card.expense:before{background:linear-gradient(90deg, var(--color-danger), var(--color-warning))}.stat-card.profit:before{background:linear-gradient(90deg, var(--color-primary), var(--color-primary-light))}.stat-card.balance:before{background:linear-gradient(90deg, var(--color-info), var(--color-secondary))}.stat-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong);transform:translateY(-2px)}.stat-card-label{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-xs);font-weight:500}.stat-card-value{font-size:var(--text-2xl);font-weight:800;font-family:"Inter", var(--font-sans);letter-spacing:-.02em}.stat-card-change{margin-top:var(--space-sm);font-size:var(--text-xs);align-items:center;gap:4px;font-weight:600;display:inline-flex}.stat-card-change.up{color:var(--color-success)}.stat-card-change.down{color:var(--color-danger)}.page-header{margin-bottom:var(--space-xl);justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.page-title{font-size:var(--text-2xl);letter-spacing:-.02em;font-weight:800}.page-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin-top:2px}.grid-stats{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));display:grid}.grid-2col{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}.grid-3col{gap:var(--space-md);grid-template-columns:repeat(3,1fr);display:grid}.filter-bar{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-lg);flex-wrap:wrap;display:flex}.filter-bar .form-input,.filter-bar .form-select{width:auto;min-width:140px}.search-input{position:relative}.search-input .form-input{padding-left:38px}.search-input svg{color:var(--text-tertiary);position:absolute;top:50%;left:12px;transform:translateY(-50%)}.empty-state{padding:var(--space-3xl) var(--space-lg);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{margin-bottom:var(--space-md);opacity:.4;font-size:3rem}.empty-state-title{font-size:var(--text-lg);color:var(--text-secondary);margin-bottom:var(--space-xs);font-weight:600}.empty-state-desc{font-size:var(--text-sm);color:var(--text-tertiary);margin-bottom:var(--space-lg)}.pin-container{z-index:1;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative}.pin-card{text-align:center;padding:var(--space-2xl) var(--space-3xl);background:var(--glass-bg);-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg), var(--shadow-glow);animation:modalSlideUp var(--transition-spring) ease}.pin-logo{font-size:var(--text-3xl);background:linear-gradient(135deg, var(--color-primary), var(--color-secondary));-webkit-text-fill-color:transparent;margin-bottom:var(--space-xs);-webkit-background-clip:text;background-clip:text;font-weight:800}.pin-subtitle{color:var(--text-secondary);font-size:var(--text-sm);margin-bottom:var(--space-xl)}.pin-dots{gap:var(--space-md);margin-bottom:var(--space-xl);justify-content:center;display:flex}.pin-dot{border:2px solid var(--border-strong);width:14px;height:14px;transition:all var(--transition-base);border-radius:50%}.pin-dot.filled{background:var(--color-primary);border-color:var(--color-primary);box-shadow:0 0 10px #6c5ce780}.pin-dot.error{border-color:var(--color-danger);background:var(--color-danger);animation:.5s shake}.pin-keypad{gap:var(--space-sm);grid-template-columns:repeat(3,1fr);max-width:260px;margin:0 auto;display:grid}.pin-key{border-radius:var(--radius-lg);border:1px solid var(--border-default);background:var(--glass-bg);width:72px;height:72px;color:var(--text-primary);font-size:var(--text-xl);font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.pin-key:hover{background:var(--glass-hover);border-color:var(--border-strong);transform:scale(1.05)}.pin-key:active{background:var(--bg-active);transform:scale(.95)}.pin-key.empty{cursor:default;background:0 0;border:none}.pin-key.empty:hover{transform:none}.pin-key.delete{color:var(--text-secondary);font-size:var(--text-base)}.pin-error{color:var(--color-danger);font-size:var(--text-sm);margin-top:var(--space-md);min-height:20px;animation:fadeIn var(--transition-fast) ease}.sidebar{width:var(--sidebar-width);background:var(--bg-surface);-webkit-backdrop-filter:blur(30px);border-right:1px solid var(--border-default);z-index:var(--z-sticky);transition:width var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden}.sidebar-logo{padding:var(--space-lg) var(--space-lg);border-bottom:1px solid var(--border-default);align-items:center;gap:var(--space-md);display:flex}.sidebar-logo-text{font-size:var(--text-lg);background:linear-gradient(135deg, var(--color-primary), var(--color-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:800}.sidebar-logo-badge{background:var(--color-primary);color:#fff;border-radius:var(--radius-full);letter-spacing:.05em;padding:2px 6px;font-size:9px;font-weight:700}.sidebar-nav{padding:var(--space-md) var(--space-sm);flex-direction:column;flex:1;gap:2px;display:flex;overflow-y:auto}.sidebar-section-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.1em;padding:var(--space-md) var(--space-md) var(--space-sm);font-size:10px;font-weight:700}.sidebar-link{align-items:center;gap:var(--space-md);padding:10px var(--space-md);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-sm);transition:all var(--transition-fast);cursor:pointer;text-align:left;width:100%;font-weight:500;font-family:var(--font-sans);background:0 0;border:none;text-decoration:none;display:flex}.sidebar-link:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-link.active{color:var(--color-primary);background:#ff7a0014;font-weight:600}.sidebar-link.active:before{content:"";background:var(--color-primary);border-radius:0 3px 3px 0;width:3px;height:20px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-link svg,.sidebar-link .nav-icon{width:20px;height:20px;font-size:var(--text-lg);flex-shrink:0}.sidebar-footer{padding:var(--space-md);border-top:1px solid var(--border-default)}.app-layout{min-height:100vh;display:flex}.main-wrapper{margin-left:var(--sidebar-width);transition:margin-left var(--transition-base);flex:1}.main-header{height:var(--header-height);padding:0 var(--space-xl);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-default);z-index:var(--z-sticky);background:#fffc;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.main-header-title{font-size:var(--text-base);color:var(--text-secondary);font-weight:600}.main-header-actions{align-items:center;gap:var(--space-md);display:flex}.main-content{padding:var(--space-xl);z-index:1;min-height:calc(100vh - var(--header-height));position:relative}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(30px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}@keyframes countUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-fade-in{animation:fadeIn var(--transition-base) ease}.animate-fade-in-up{animation:fadeInUp var(--transition-slow) ease}.animate-slide-in-left{animation:slideInLeft var(--transition-base) ease}.stagger-1{animation-delay:50ms}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.text-warning{color:var(--color-warning)}.text-info{color:var(--color-info)}.text-primary{color:var(--color-primary-light)}.text-muted{color:var(--text-secondary)}.text-right{text-align:right}.text-center{text-align:center}.font-mono{font-family:var(--font-mono)}.font-bold{font-weight:700}.nowrap{white-space:nowrap}.flex{display:flex}.flex-col{flex-direction:column;display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.gap-xl{gap:var(--space-xl)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.w-full{width:100%}.tabs{border-radius:var(--radius-md);border:1px solid var(--border-default);background:#ffffff08;gap:2px;width:fit-content;padding:3px;display:flex}.tab{color:var(--text-secondary);font-family:var(--font-sans);font-size:var(--text-sm);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;padding:8px 18px;font-weight:500}.tab:hover{color:var(--text-primary);background:#ffffff0d}.tab.active{color:var(--text-primary);background:var(--color-primary);font-weight:600}.toast-container{bottom:var(--space-lg);right:var(--space-lg);z-index:var(--z-toast);gap:var(--space-sm);flex-direction:column;display:flex;position:fixed}.toast{padding:var(--space-md) var(--space-lg);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);font-size:var(--text-sm);animation:fadeInUp var(--transition-base) ease;align-items:center;gap:var(--space-sm);min-width:280px;display:flex}.toast.success{border-left:3px solid var(--color-success)}.toast.error{border-left:3px solid var(--color-danger)}.toast.info{border-left:3px solid var(--color-info)}.skeleton{background:linear-gradient(90deg, var(--bg-elevated) 25%, var(--bg-hover) 50%, var(--bg-elevated) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s ease-in-out infinite pulse}.chart-container{padding:var(--space-lg);background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-lg)}.chart-title{font-size:var(--text-base);margin-bottom:var(--space-md);font-weight:700}@media (max-width:1024px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-wrapper{margin-left:0}.grid-2col,.grid-3col{grid-template-columns:1fr}}@media (max-width:768px){.main-content{padding:var(--space-md)}.page-header{flex-direction:column;align-items:flex-start}.filter-bar{flex-direction:column;align-items:stretch}.filter-bar .form-input,.filter-bar .form-select{width:100%}.grid-stats{grid-template-columns:1fr 1fr}.modal{width:95%;margin:var(--space-md)}.table th,.table td{padding:10px 12px}}@media (max-width:480px){.grid-stats{grid-template-columns:1fr}}
