:root{--bg: #0f1117;--bg-card: #1a1d27;--bg-hover: #22263a;--border: #2a2d3e;--text: #e2e8f0;--text-muted: #64748b;--green: #22c55e;--red: #ef4444;--orange: #f97316;--blue: #3b82f6;--topbar-h: 56px;--r: 8px;--font: "Inter", system-ui, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;min-height:100dvh;font-size:14px;line-height:1.5;padding-top:env(safe-area-inset-top)}a{color:inherit;text-decoration:none}.topbar{height:var(--topbar-h);background:var(--bg-card);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:24px;position:sticky;top:0;z-index:100}.topbar-logo{font-weight:700;font-size:16px;margin-right:auto}.topbar-nav{display:flex;gap:4px}.topbar-nav a{padding:6px 12px;border-radius:var(--r);color:var(--text-muted);font-size:13px;transition:background .15s,color .15s;display:inline-flex;align-items:center;gap:6px}.topbar-nav a:hover,.topbar-nav a.active{background:var(--bg-hover);color:var(--text)}.nav-icon{display:none;font-style:normal}.nav-label{display:inline}.topbar-right{display:flex;align-items:center;gap:8px}.currency-select{background:var(--bg);border:1px solid var(--border);color:var(--text);padding:4px 8px;border-radius:var(--r);font-size:13px;cursor:pointer}.btn-logout{background:none;border:1px solid var(--border);color:var(--text-muted);padding:4px 12px;border-radius:var(--r);font-size:13px;cursor:pointer;transition:border-color .15s,color .15s}.btn-logout:hover{border-color:var(--red);color:var(--red)}.main{padding:24px;max-width:1200px;margin:0 auto}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);padding:20px}.metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.metric-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.metric-value{font-size:28px;font-weight:700}.metric-sub{font-size:12px;color:var(--text-muted);margin-top:4px}.charts{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}canvas{max-height:220px}table{width:100%;border-collapse:collapse}th{text-align:left;padding:10px 12px;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border)}td{padding:12px;border-bottom:1px solid var(--border)}tr:last-child td{border-bottom:none}tr:hover td{background:var(--bg-hover)}.badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600}.badge-red{background:#ef444426;color:var(--red)}.badge-green{background:#22c55e26;color:var(--green)}.badge-orange{background:#f9731626;color:var(--orange)}.badge-blue{background:#3b82f626;color:var(--blue)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--r);font-size:13px;font-weight:500;cursor:pointer;border:none;transition:opacity .15s}.btn:hover{opacity:.85}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--blue);color:#fff}.btn-danger{background:var(--red);color:#fff}.btn-ghost{background:var(--bg-hover);color:var(--text)}.btn-sm{padding:4px 10px;font-size:12px}.pay-btn{background:none;border:1px solid var(--border);color:var(--text-muted);padding:4px 10px;border-radius:var(--r);font-size:12px;cursor:pointer;transition:all .15s}.pay-btn:hover{border-color:var(--green);color:var(--green)}.pay-btn.paid{border-color:var(--green);color:var(--green);background:#22c55e1a}.empty{text-align:center;padding:48px;color:var(--text-muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);align-items:center;justify-content:center;z-index:200;display:none}.modal-overlay.open{display:flex}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:24px;width:480px;max-width:90vw}.modal h3,.form-group{margin-bottom:16px}.form-label{display:block;font-size:12px;color:var(--text-muted);margin-bottom:6px}.form-input{width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);padding:8px 12px;border-radius:var(--r);font-size:14px;font-family:var(--font)}.form-input:focus{outline:none;border-color:var(--blue)}select.form-input{cursor:pointer}.dropzone{border:2px dashed var(--border);border-radius:var(--r);padding:32px;text-align:center;color:var(--text-muted);cursor:pointer;transition:border-color .15s}.dropzone.drag-over{border-color:var(--blue);color:var(--text)}#authGuard{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f1117;z-index:9999;transition:opacity .18s ease}#authGuard.fade{opacity:0;pointer-events:none}.seoul-clock{font-size:12px;color:var(--text-muted);font-variant-numeric:tabular-nums;white-space:nowrap}.role-tag{font-size:12px;color:var(--text-muted);white-space:nowrap}.cat-group{border-bottom:1px solid var(--border)}.cat-group:last-child{border-bottom:none}.cat-summary{display:flex;align-items:center;gap:10px;padding:14px 0;cursor:pointer;-webkit-user-select:none;user-select:none}.cat-chevron{font-size:10px;color:var(--text-muted);transition:transform .25s ease;flex-shrink:0}.cat-group.open .cat-chevron{transform:rotate(90deg)}.cat-group-name{font-weight:600;font-size:14px;flex:1}.cat-group-total{font-size:13px;font-weight:600;color:var(--text-muted)}.cat-group-count{font-size:12px;color:var(--text-muted)}.cat-content-wrap{display:grid;grid-template-rows:0fr;transition:grid-template-rows .3s cubic-bezier(.4,0,.2,1)}.cat-group.open .cat-content-wrap{grid-template-rows:1fr}.cat-content{overflow:hidden;min-height:0}.mobile-user-header{display:none}@media (max-width: 640px){body{padding-top:0;padding-bottom:calc(var(--topbar-h) + env(safe-area-inset-bottom))}.mobile-user-header{display:flex;align-items:center;gap:12px;padding:calc(env(safe-area-inset-top) + 16px) 16px 8px}.muh-avatar{width:46px;height:46px;background:var(--bg-card);border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0}.muh-info{display:flex;flex-direction:column;gap:4px}.muh-name{font-weight:700;font-size:18px;color:var(--text)}.topbar{position:fixed;bottom:0;left:0;right:0;top:auto;height:auto;border-bottom:none;border-top:1px solid var(--border);padding:0 12px;padding-bottom:env(safe-area-inset-bottom);gap:8px}.topbar-logo{display:none}.topbar-nav{flex:1;justify-content:space-around;gap:0}.topbar-nav a{flex:1;justify-content:center;font-size:22px;padding:10px 4px;border-radius:var(--r);white-space:nowrap}.topbar-right{gap:6px;flex-shrink:0}.nav-icon{display:inline}.nav-label,.seoul-clock,.role-tag{display:none}.currency-select{font-size:12px;padding:3px 6px}.btn-logout{font-size:12px;padding:4px 8px}}@media (max-width: 768px){.metrics{grid-template-columns:1fr 1fr}.charts{grid-template-columns:1fr}.main,.card{padding:16px}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}table{min-width:540px}.modal{width:calc(100vw - 32px);padding:20px 16px}}@media (max-width: 480px){.metrics{grid-template-columns:1fr}.metric-value{font-size:22px}}#topbar{view-transition-name:nav-shell}::view-transition-old(nav-shell),::view-transition-new(nav-shell){animation:none;mix-blend-mode:normal}::view-transition-old(root){animation:.3s cubic-bezier(.4,0,.2,1) slide-to-left}::view-transition-new(root){animation:.3s cubic-bezier(.4,0,.2,1) slide-from-right}:root[data-nav-dir=backward]::view-transition-old(root){animation:.3s cubic-bezier(.4,0,.2,1) slide-to-right}:root[data-nav-dir=backward]::view-transition-new(root){animation:.3s cubic-bezier(.4,0,.2,1) slide-from-left}@keyframes slide-to-left{to{transform:translate(-100%)}}@keyframes slide-from-right{0%{transform:translate(100%)}}@keyframes slide-to-right{to{transform:translate(100%)}}@keyframes slide-from-left{0%{transform:translate(-100%)}}@media (prefers-reduced-motion: reduce){::view-transition-old(root),::view-transition-new(root){animation:none}}.section-title{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:16px}.xp-wrap{display:flex;flex-direction:column;gap:10px;justify-content:center;height:100%}.xp-labels{display:flex;justify-content:space-between;align-items:baseline}.xp-label-paid{font-size:20px;font-weight:700;color:#4ade80}.xp-label-sep{font-size:13px;color:var(--text-muted);margin:0 4px}.xp-label-total{font-size:14px;color:var(--text-muted);font-weight:500}.xp-track{width:100%;height:28px;background:var(--bg);border-radius:14px;border:1px solid var(--border);overflow:hidden;position:relative}.xp-fill{height:100%;width:0%;border-radius:14px;background:linear-gradient(90deg,#16a34a,#4ade80);box-shadow:0 0 12px #4ade8073;transition:width .7s cubic-bezier(.4,0,.2,1);position:relative}.xp-fill:after{content:"";position:absolute;top:0;right:0;bottom:50%;left:0;background:#ffffff1f;border-radius:14px 14px 0 0}.xp-fill:before{content:"";position:absolute;top:0;left:-60%;width:40%;height:100%;background:#ffffff2e;transform:skew(-20deg);animation:xp-shine 2.4s infinite}@keyframes xp-shine{0%{left:-60%;opacity:0}20%{opacity:1}to{left:120%;opacity:0}}.xp-percent{text-align:right;font-size:12px;font-weight:600;color:var(--text-muted);letter-spacing:.04em}@media (max-width: 640px){.xp-wrap{height:auto;justify-content:flex-start}.xp-labels{align-items:center}.xp-label-paid{font-size:17px}.xp-label-total{font-size:13px}}.pay-row{display:flex;align-items:center;gap:12px;padding:10px 0 10px 20px;border-top:1px solid var(--border)}.pay-name{flex:1;font-weight:500;font-size:14px}.pay-meta{font-size:12px;color:var(--text-muted)}.pay-amt{font-weight:600;min-width:100px;text-align:right}@media (max-width: 480px){.pay-row{padding-left:8px;gap:8px}.pay-amt{min-width:70px;font-size:13px}}.cat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.cat-title{font-weight:600;font-size:15px}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-grid-4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:12px}@media (max-width: 600px){.form-grid-4{grid-template-columns:1fr 1fr}}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}.detail-label{font-size:11px;text-transform:uppercase;color:var(--text-muted);margin-bottom:4px}.detail-value{font-size:18px;font-weight:600}.doc-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}.doc-item:last-child{border-bottom:none}.doc-meta{font-size:12px;color:var(--text-muted)}.doc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}.doc-card{cursor:pointer;transition:border-color .15s}.doc-card:hover{border-color:var(--blue)}.doc-thumb{width:100%;height:120px;object-fit:cover;border-radius:6px;margin-bottom:10px;display:block;background:var(--bg)}.doc-thumb-skeleton{width:100%;height:120px;border-radius:6px;margin-bottom:10px;background:linear-gradient(90deg,var(--bg) 25%,var(--bg-hover) 50%,var(--bg) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.doc-icon{font-size:32px;margin-bottom:8px}.doc-name{font-weight:500;margin-bottom:4px;word-break:break-word;font-size:13px}.doc-debt{font-size:12px;color:var(--text-muted)}.doc-date{font-size:11px;color:var(--text-muted);margin-top:8px}.lb-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;display:none;flex-direction:column;z-index:300}.lb-overlay.open{display:flex}.lb-toolbar{display:flex;justify-content:flex-end;align-items:center;gap:8px;padding:12px 16px;padding-top:calc(12px + env(safe-area-inset-top));flex-shrink:0}.lb-btn{background:#ffffff1f;border:none;color:#fff;width:40px;height:40px;border-radius:50%;font-size:18px;cursor:pointer;transition:background .15s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.lb-btn:hover{background:#ffffff40}.lb-scroll{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.lb-img{max-width:100%;max-height:100%;object-fit:contain;display:block;transform-origin:center center;will-change:transform;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;touch-action:none}.lb-hint{position:absolute;bottom:24px;left:50%;transform:translate(-50%);font-size:12px;color:#fff6;pointer-events:none;white-space:nowrap}.month-group{margin-bottom:24px}.month-header{font-size:15px;font-weight:700;color:var(--text);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.month-header-total{font-size:13px;color:var(--text-muted);font-weight:500}.hist-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}.hist-row:last-child{border-bottom:none}.hist-main{flex:1;min-width:0}.hist-name{font-weight:500;font-size:14px;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hist-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.hist-date{font-size:12px;color:var(--text-muted)}.hist-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}.hist-amt{font-weight:600;font-size:14px;color:var(--green);white-space:nowrap}.hist-del{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:18px;padding:0 4px;line-height:1;border-radius:4px;transition:color .15s}.hist-del:hover{color:var(--red)}.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh}.login-box{width:360px}.login-title{font-size:24px;font-weight:700;margin-bottom:8px}.login-sub{color:var(--text-muted);margin-bottom:24px;font-size:13px}.error-msg{color:var(--red);font-size:13px;margin-top:12px}.btn-submit{width:100%;justify-content:center;margin-top:8px}
