@import"https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.min.css";:root{--c-bg: #f2f4f6;--c-surface: #ffffff;--c-blue: #3182f6;--c-blue-soft: #e8f3ff;--c-red: #f04452;--c-red-soft: #fff0f1;--c-green: #1ec97e;--c-green-soft: #e7faf1;--c-orange: #ff8f00;--c-orange-soft: #fff4e5;--c-purple: #7b5cfa;--c-purple-soft: #f0ecff;--c-text-1: #191f28;--c-text-2: #4e5968;--c-text-3: #8b95a1;--c-border: #eceef0;--r-lg: 20px;--r-md: 14px;--r-sm: 10px;--shadow: 0 4px 20px rgba(0, 0, 0, .06);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .04)}.loader{width:28px;height:28px;border:3px solid rgba(255,255,255,.1);border-top-color:#6c63ff;border-radius:50%;animation:spin .8s linear infinite}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html{font-size:16px}body{font-family:Pretendard Variable,Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Roboto,Helvetica Neue,Segoe UI,Apple SD Gothic Neo,Noto Sans KR,Malgun Gothic,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,sans-serif;background:var(--c-bg);color:var(--c-text-1);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;letter-spacing:-.02em;overscroll-behavior-y:none}button{cursor:pointer;font-family:inherit;user-select:none;-webkit-user-select:none}a{text-decoration:none;color:inherit}#root{display:flex;justify-content:center;background:#e5e8ec;min-height:100dvh}.shell{width:100%;max-width:430px;min-height:100dvh;background:var(--c-bg);display:flex;flex-direction:column;position:relative;overflow:hidden;user-select:none;-webkit-user-select:none}.topbar{display:flex;align-items:center;justify-content:space-between;padding:calc(18px + env(safe-area-inset-top)) 20px 14px;background:var(--c-bg);position:sticky;top:0;z-index:40}.topbar-logo{display:flex;align-items:center;gap:8px}.logo-icon{width:34px;height:34px;background:var(--c-blue);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff}.logo-name{font-family:Outfit,sans-serif;font-weight:800;font-size:20px;letter-spacing:-.5px}.logo-name em{color:var(--c-blue);font-style:normal}.topbar-actions{display:flex;gap:14px;align-items:center}.icon-btn{background:none;border:none;padding:4px;color:var(--c-text-2);position:relative;display:flex;align-items:center}.badge{position:absolute;top:0;right:0;width:8px;height:8px;background:var(--c-red);border-radius:50%;border:1.5px solid var(--c-bg)}.page-content{flex:1;overflow-y:auto;padding-bottom:90px;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.page-content::-webkit-scrollbar{display:none}.section{padding:0 16px;margin-bottom:20px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.section-title{font-family:Outfit,sans-serif;font-weight:700;font-size:17px}.section-link{font-size:13px;color:var(--c-blue);font-weight:600}.card{background:var(--c-surface);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);border:1px solid var(--c-border);overflow:hidden}.card-pad{padding:20px}.card+.card{margin-top:10px}.score-card{background:linear-gradient(135deg,#1a2035,#1e3a6e);color:#fff;border-radius:var(--r-lg);padding:22px;position:relative;overflow:hidden;border:none}.score-card:after{content:"";position:absolute;right:-30px;top:-30px;width:160px;height:160px;background:radial-gradient(circle,rgba(49,130,246,.4),transparent 70%);border-radius:50%}.score-label{font-size:13px;opacity:.7;margin-bottom:8px;font-weight:500}.score-big{font-size:60px;font-weight:800;line-height:1;display:flex;align-items:baseline;gap:6px}.score-big sub{font-size:16px;opacity:.6;font-weight:500}.score-desc{font-size:13px;opacity:.75;margin-top:8px}.score-desc strong{color:#ff8f00}.coaching-pill{display:inline-flex;align-items:center;gap:6px;background:#ffffff1f;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.18);border-radius:50px;padding:8px 14px;font-size:13px;font-weight:600;margin-top:14px}.score-ring{position:absolute;right:20px;top:50%;transform:translateY(-50%)}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.stat-card{background:var(--c-surface);border-radius:var(--r-lg);padding:18px;border:1px solid var(--c-border)}.stat-tag{font-size:12px;font-weight:600;color:var(--c-text-3);margin-bottom:6px}.stat-val{font-size:22px;font-weight:800}.stat-sub{font-size:12px;margin-top:4px}.insight-row{display:flex;gap:14px;align-items:flex-start;padding:16px 20px;border-bottom:1px solid var(--c-border);transition:background .15s}.insight-row:last-child{border-bottom:none}.insight-row:active{background:#f7f9fb}.insight-ico{width:44px;height:44px;flex-shrink:0;border-radius:13px;display:flex;align-items:center;justify-content:center}.insight-body{flex:1;min-width:0}.insight-chip{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;padding:2px 7px;border-radius:5px;margin-bottom:4px}.insight-title{font-size:15px;font-weight:700;margin-bottom:2px}.insight-desc{font-size:13px;color:var(--c-text-2);line-height:1.5}.insight-arrow{color:var(--c-text-3);flex-shrink:0;align-self:center}.insight-amount{font-size:15px;font-weight:700;color:var(--c-red);margin-top:4px}.cat-list{display:flex;flex-direction:column;gap:14px}.cat-row{display:flex;align-items:center;gap:12px}.cat-icon{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}.cat-info{flex:1}.cat-name{font-size:14px;font-weight:600;margin-bottom:5px}.cat-bar-track{height:6px;background:var(--c-bg);border-radius:3px}.cat-bar-fill{height:100%;border-radius:3px;transition:width .8s cubic-bezier(.4,0,.2,1)}.cat-amt{font-size:14px;font-weight:700;flex-shrink:0;min-width:52px;text-align:right}.challenge-scroll{display:flex;gap:12px;overflow-x:auto;padding:2px 16px 12px;scrollbar-width:none}.challenge-scroll::-webkit-scrollbar{display:none}.challenge-card{background:var(--c-surface);border-radius:var(--r-lg);border:1px solid var(--c-border);padding:18px;min-width:170px;flex-shrink:0;display:flex;flex-direction:column;gap:8px;cursor:pointer;transition:transform .15s}.challenge-card:active{transform:scale(.96)}.challenge-emoji{font-size:28px}.challenge-name{font-size:15px;font-weight:700}.challenge-sub{font-size:12px;color:var(--c-text-3)}.prog-track{height:5px;background:var(--c-bg);border-radius:3px}.prog-fill{height:100%;border-radius:3px;transition:width 1s cubic-bezier(.4,0,.2,1)}.challenge-add{min-width:130px;flex-shrink:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:6px;font-size:13px;font-weight:600;color:var(--c-blue);border:1.5px dashed #c5d7f5;background:var(--c-blue-soft);border-radius:var(--r-lg);padding:18px;cursor:pointer}.report-hero{background:linear-gradient(145deg,#0f1923,#1e3d5c);margin:0 16px;border-radius:var(--r-lg);padding:26px;color:#fff;position:relative;overflow:hidden}.report-hero:before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='200' height='200' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='150' cy='50' r='80' fill='rgba(49,130,246,0.15)'/%3E%3C/svg%3E") right top no-repeat}.report-mo{font-size:13px;opacity:.6;margin-bottom:4px}.report-total{font-size:38px;font-weight:800}.report-pill-row{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}.report-pill{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:50px;background:#ffffff1a;font-size:12px;font-weight:600}.input-tabs{display:flex;gap:0;background:#edf0f4;border-radius:12px;padding:3px;margin-bottom:16px}.tab-btn{flex:1;padding:8px;border:none;background:none;border-radius:10px;font-size:13px;font-weight:600;color:var(--c-text-3);transition:all .2s}.tab-btn.active{background:var(--c-surface);color:var(--c-text-1);box-shadow:var(--shadow-sm)}.text-area{width:100%;height:130px;padding:14px;resize:none;background:var(--c-bg);border:1.5px solid var(--c-border);border-radius:14px;font-size:14px;color:var(--c-text-1);outline:none;transition:border-color .2s;user-select:text;-webkit-user-select:text}.text-area:focus{border-color:var(--c-blue)}.expense-list{display:flex;flex-direction:column;gap:0}.expense-row{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid var(--c-border)}.expense-row:last-child{border-bottom:none}.expense-icon{font-size:22px;width:40px;height:40px;background:var(--c-bg);border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.expense-info{flex:1}.expense-name{font-size:15px;font-weight:600}.expense-date{font-size:12px;color:var(--c-text-3);margin-top:2px}.expense-amt{font-size:16px;font-weight:700}.expense-amt.minus{color:var(--c-red)}.btn-primary{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:15px;border:none;background:var(--c-blue);color:#fff;border-radius:14px;font-size:15px;font-weight:700;transition:opacity .2s,transform .15s}.btn-primary:active{transform:scale(.98);opacity:.9}.btn-primary:disabled{background:var(--c-border);color:var(--c-text-3);transform:none}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:430px;background:#ffffffe0;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid rgba(0,0,0,.07);display:flex;justify-content:space-around;padding:10px 0 calc(10px + env(safe-area-inset-bottom));z-index:50}.nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--c-text-3);font-size:10px;font-weight:600;padding:4px 16px;background:none;border:none;transition:color .2s}.nav-item.active{color:var(--c-blue)}.nav-dot{width:4px;height:4px;background:var(--c-blue);border-radius:2px;margin-top:1px}.pro-banner{background:linear-gradient(135deg,#0f1923,#1e3d72 60%,#3182f6);border-radius:var(--r-lg);padding:22px;color:#fff;display:flex;flex-direction:column;gap:10px;position:relative;overflow:hidden;border:none}.pro-badge{display:inline-flex;align-items:center;gap:5px;background:var(--c-blue);border-radius:6px;padding:3px 10px;font-size:11px;font-weight:700;letter-spacing:1px;width:fit-content}.pro-title{font-size:20px;font-weight:800}.pro-desc{font-size:13px;opacity:.8}.pro-btn{background:#fff;color:#1a2035;border:none;border-radius:10px;padding:10px 18px;font-size:14px;font-weight:700;width:fit-content}.pro-bg-icon{position:absolute;right:-10px;bottom:-10px;opacity:.12}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:18px;height:18px;border:2.5px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.pulse{animation:pulse 1.5s ease-in-out infinite}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.text-red{color:var(--c-red)}.text-green{color:var(--c-green)}.text-orange{color:var(--c-orange)}.text-2{color:var(--c-text-2)}.text-3{color:var(--c-text-3)}.fw-700{font-weight:700}.fs-13{font-size:13px}.fs-14{font-size:14px}.report-cta-btn{width:100%;display:flex;align-items:center;gap:14px;padding:18px 20px;background:linear-gradient(135deg,#e8f3ff,#f0ecff);border:1.5px solid #c5d7f5;border-radius:18px;color:#1a2852;font-family:Inter,sans-serif;cursor:pointer;transition:transform .15s,box-shadow .15s}.report-cta-btn:hover{box-shadow:0 6px 20px #3182f626}.report-full-btn{display:flex;align-items:center;justify-content:center;gap:4px;width:calc(100% - 32px);margin:12px 16px 0;padding:13px;background:#fff;border:1.5px solid #c5d7f5;border-radius:14px;color:var(--c-blue);font-size:14px;font-weight:700;font-family:Inter,sans-serif;cursor:pointer;transition:background .15s}.report-full-btn:hover{background:var(--c-blue-soft)}.analysis-step-done{background:#1ec97e;color:#fff}.analysis-step-active{background:#3182f6;color:#fff}.analysis-step-pending{background:#e5e8ec;color:#8b95a1}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.float-anim{animation:float 3s ease-in-out infinite}.loader{width:40px;height:40px;border:3px solid #f2f4f6;border-bottom-color:var(--c-blue);border-radius:50%;display:inline-block;box-sizing:border-box;animation:rotation 1s linear infinite}@keyframes rotation{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ai-card-glow{background:linear-gradient(135deg,#e8f3ff,#f0ecff);border:1px solid #c5d7f5;box-shadow:0 4px 12px #3182f61a}.text-blue{color:var(--c-blue)}.fs-12{font-size:12px}.fw-600{font-weight:600}.bg-none{background:none}.br-none{border:none}
