*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter,-apple-system,system-ui,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:JetBrains Mono,ui-monospace,Menlo,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.static{position:static}.absolute{position:absolute}.relative{position:relative}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.border{border-width:1px}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{--accent-hue: 275;--bg-0: oklch(.08 0 0);--bg-1: oklch(.12 .002 265);--bg-2: oklch(.155 .003 265);--bg-3: oklch(.2 .004 265);--bg-4: oklch(.26 .005 265);--border-1: oklch(.24 .003 265 / .7);--border-2: oklch(.32 .005 265 / .6);--text-1: oklch(.97 .005 265);--text-2: oklch(.78 .01 265);--text-3: oklch(.58 .015 265);--text-4: oklch(.42 .015 265);--accent: oklch(.72 .15 var(--accent-hue));--accent-hi: oklch(.8 .15 var(--accent-hue));--accent-lo: oklch(.58 .16 var(--accent-hue));--accent-wash: oklch(.72 .15 var(--accent-hue) / .12);--accent-ring: oklch(.72 .15 var(--accent-hue) / .35);--pos: oklch(.78 .11 155);--pos-wash: oklch(.78 .11 155 / .12);--neg: oklch(.72 .13 25);--neg-wash: oklch(.72 .13 25 / .12);--warn: oklch(.82 .12 75);--warn-wash: oklch(.82 .12 75 / .12);--cat-1: oklch(.72 .13 275);--cat-2: oklch(.75 .13 200);--cat-3: oklch(.78 .13 155);--cat-4: oklch(.8 .13 95);--cat-5: oklch(.78 .13 50);--cat-6: oklch(.72 .13 15);--cat-7: oklch(.68 .13 325);--shadow-sm: 0 1px 2px rgb(0 0 0 / .25);--shadow-md: 0 6px 24px -8px rgb(0 0 0 / .45), 0 2px 6px -2px rgb(0 0 0 / .3);--shadow-lg: 0 24px 64px -16px rgb(0 0 0 / .55), 0 8px 20px -8px rgb(0 0 0 / .4);--radius-sm: 6px;--radius: 10px;--radius-lg: 14px;--radius-xl: 20px;--font-sans: "Inter", -apple-system, system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, Menlo, monospace;--font-serif: "Instrument Serif", Georgia, serif}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100%}html,body{background:var(--bg-0);color:var(--text-1);font-family:var(--font-sans);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"ss01","cv11"}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(1000px 600px at 85% -10%,oklch(.72 .15 var(--accent-hue) / .08),transparent 60%),radial-gradient(800px 500px at -10% 110%,oklch(.72 .13 200 / .05),transparent 60%);z-index:0}button{font:inherit;color:inherit;background:none;border:0;padding:0;cursor:pointer}input,select,textarea{font:inherit;color:inherit}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-4);border-radius:10px;border:2px solid var(--bg-0)}::-webkit-scrollbar-thumb:hover{background:var(--border-2)}.num{font-family:var(--font-mono);font-feature-settings:"tnum","zero";letter-spacing:-.01em}.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh;position:relative;z-index:1}.app.auth-mode{grid-template-columns:1fr}.sidebar{background:var(--bg-1);border-right:1px solid var(--border-1);padding:18px 14px;display:flex;flex-direction:column;gap:8px;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:10px;padding:6px 8px 14px}.brand-mark{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,var(--accent-hi),var(--accent-lo));display:grid;place-items:center;color:var(--bg-0);font-weight:700;box-shadow:0 0 0 1px #ffffff0f,0 6px 16px -8px var(--accent);font-family:var(--font-serif);font-size:18px}.brand-name{font-weight:600;letter-spacing:-.01em;font-size:15px}.brand-sub{color:var(--text-3);font-size:11px;margin-top:1px}.nav-section-label{color:var(--text-3);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.08em;padding:14px 10px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:8px;color:var(--text-2);font-weight:500;font-size:13.5px;cursor:pointer;transition:background .12s ease,color .12s ease;position:relative;text-decoration:none}.nav-item:hover{background:var(--bg-2);color:var(--text-1)}.nav-item.active{background:var(--bg-3);color:var(--text-1)}.nav-item.active:before{content:"";position:absolute;left:-14px;top:8px;bottom:8px;width:2px;background:var(--accent);border-radius:2px}.nav-item svg{width:16px;height:16px;color:var(--text-3)}.nav-item.active svg,.nav-item:hover svg{color:var(--text-1)}.nav-item .badge{margin-left:auto;background:var(--bg-3);color:var(--text-2);padding:1px 6px;border-radius:6px;font-size:11px;font-weight:500;font-family:var(--font-mono)}.sidebar-foot{margin-top:auto;border-top:1px solid var(--border-1);padding-top:12px;display:flex;align-items:center;gap:10px}.avatar{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#48b7bd,#6ba5d0,#8391e2);display:grid;place-items:center;color:var(--bg-0);font-weight:600;font-size:12px}.user-meta{flex:1;min-width:0}.user-name{font-size:13px;font-weight:500}.user-email{color:var(--text-3);font-size:11.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.main{padding:28px 36px 60px;max-width:1280px;width:100%}.page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:28px}.page-title{font-size:26px;font-weight:600;letter-spacing:-.02em;margin:0}.page-title .serif{font-family:var(--font-serif);font-weight:400;font-style:italic;color:var(--text-2)}.page-sub{color:var(--text-3);font-size:13.5px;margin-top:4px}.page-actions{display:flex;gap:8px}.btn{display:inline-flex;align-items:center;gap:7px;padding:7px 12px;border-radius:8px;font-size:13px;font-weight:500;background:var(--bg-2);border:1px solid var(--border-1);color:var(--text-1);transition:all .12s ease}.btn:hover{background:var(--bg-3);border-color:var(--border-2)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn svg{width:14px;height:14px}.btn-primary{background:var(--accent);color:#070b14;border-color:transparent;font-weight:600}.btn-primary:hover:not(:disabled){background:var(--accent-hi)}.btn-ghost{background:transparent;border-color:transparent;color:var(--text-2)}.btn-ghost:hover{background:var(--bg-2);color:var(--text-1)}.btn-sm{padding:5px 9px;font-size:12px;border-radius:6px}.card{background:var(--bg-2);border:1px solid var(--border-1);border-radius:var(--radius-lg);padding:20px;position:relative}.card-hd{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.card-title{font-size:13px;font-weight:500;color:var(--text-3);letter-spacing:.01em}.card-title.lg{font-size:15px;color:var(--text-1);font-weight:600;letter-spacing:-.01em}.stat{display:flex;flex-direction:column;gap:14px;min-height:148px}.stat-label{display:flex;align-items:center;gap:7px;color:var(--text-3);font-size:12.5px;font-weight:500}.stat-label .dot{width:6px;height:6px;border-radius:50%;background:var(--accent)}.stat-label .dot.pos{background:var(--pos)}.stat-label .dot.neg{background:var(--neg)}.stat-value{font-family:var(--font-mono);font-size:32px;font-weight:500;letter-spacing:-.02em;color:var(--text-1);display:flex;align-items:baseline;gap:4px}.stat-value .cents{font-size:18px;color:var(--text-3)}.stat-value .sign{font-size:18px;color:var(--text-3);margin-right:2px}.stat-delta{display:inline-flex;align-items:center;gap:5px;padding:2px 7px;border-radius:6px;font-size:11.5px;font-weight:500;font-family:var(--font-mono)}.stat-delta.pos{color:var(--pos);background:var(--pos-wash)}.stat-delta.neg{color:var(--neg);background:var(--neg-wash)}.stat-meta{color:var(--text-3);font-size:12px}.stat-spark{margin-top:auto;height:40px}.grid-12{display:grid;gap:16px}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-21{grid-template-columns:2fr 1fr}@media (max-width: 1100px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}.grid-21{grid-template-columns:1fr}}@media (max-width: 720px){.grid-3,.grid-4,.grid-2,.app{grid-template-columns:1fr}.sidebar{display:none}.main{padding:20px 16px 60px}}.table{width:100%;border-collapse:collapse;font-size:13px}.table th{text-align:left;font-weight:500;color:var(--text-3);font-size:11px;text-transform:uppercase;letter-spacing:.06em;padding:10px 12px;border-bottom:1px solid var(--border-1);background:var(--bg-2);position:sticky;top:0}.table td{padding:12px;border-bottom:1px solid var(--border-1);vertical-align:middle}.table tbody tr:hover td{background:#ffffff04}.table tbody tr:last-child td{border-bottom:0}.table .num{text-align:right}.table .td-amt.pos{color:var(--pos)}.table .td-amt.neg{color:var(--text-1)}.pill{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:999px;font-size:11.5px;font-weight:500;background:var(--bg-3);color:var(--text-2);border:1px solid var(--border-1)}.pill .dot{width:6px;height:6px;border-radius:50%}.input,.select{background:var(--bg-1);border:1px solid var(--border-1);border-radius:8px;padding:8px 11px;color:var(--text-1);font-size:13px;width:100%;transition:border-color .12s,box-shadow .12s}.input:focus,.select:focus{outline:none;border-color:var(--accent-lo);box-shadow:0 0 0 3px var(--accent-ring)}.input::-moz-placeholder{color:var(--text-4)}.input::placeholder{color:var(--text-4)}.label{display:block;font-size:12px;color:var(--text-3);margin-bottom:6px;font-weight:500}.bar{height:6px;border-radius:4px;background:var(--bg-3);overflow:hidden;position:relative}.bar>span{display:block;height:100%;background:var(--accent);border-radius:inherit}.bar.neg>span{background:linear-gradient(90deg,var(--neg),oklch(.78 .13 40))}.bar.pos>span{background:var(--pos)}.auth-wrap{display:grid;grid-template-columns:1.05fr 1fr;min-height:100vh}@media (max-width: 900px){.auth-wrap{grid-template-columns:1fr}.auth-left{display:none}}.auth-left{position:relative;background:radial-gradient(800px 500px at 80% 20%,oklch(.72 .15 var(--accent-hue) / .22),transparent 60%),radial-gradient(600px 400px at 20% 80%,oklch(.68 .12 200 / .15),transparent 60%),linear-gradient(180deg,#12161f,#06090f);padding:48px;display:flex;flex-direction:column;overflow:hidden}.auth-left:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(oklch(1 0 0 / .025) 1px,transparent 1px),linear-gradient(90deg,oklch(1 0 0 / .025) 1px,transparent 1px);background-size:48px 48px;-webkit-mask-image:radial-gradient(ellipse at 50% 50%,black 40%,transparent 80%);mask-image:radial-gradient(ellipse at 50% 50%,black 40%,transparent 80%);pointer-events:none}.auth-brand{display:flex;align-items:center;gap:10px;position:relative;z-index:1}.auth-hero{margin-top:auto;position:relative;z-index:1;max-width:480px}.auth-hero h1{font-family:var(--font-serif);font-size:52px;line-height:1.05;letter-spacing:-.02em;font-weight:400;margin:0 0 16px}.auth-hero h1 em{font-style:italic;color:var(--accent-hi)}.auth-hero p{color:var(--text-2);font-size:15px;max-width:420px;line-height:1.55}.auth-card-demo{margin-top:36px;background:#171b2299;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border:1px solid oklch(1 0 0 / .06);border-radius:14px;padding:18px 20px;max-width:360px;box-shadow:var(--shadow-lg)}.auth-right{display:grid;place-items:center;padding:48px 24px}.auth-form{width:100%;max-width:380px}.auth-form h2{font-size:24px;font-weight:600;letter-spacing:-.02em;margin:0 0 6px}.auth-form .muted{color:var(--text-3);margin:0 0 28px;font-size:13.5px}.auth-field{margin-bottom:14px}.auth-tabs{display:inline-flex;padding:3px;background:var(--bg-2);border-radius:10px;margin-bottom:24px;border:1px solid var(--border-1)}.auth-tab{padding:6px 14px;font-size:12.5px;color:var(--text-3);border-radius:7px;font-weight:500}.auth-tab.active{background:var(--bg-3);color:var(--text-1);box-shadow:var(--shadow-sm)}.auth-sep{display:flex;align-items:center;gap:10px;color:var(--text-4);font-size:11px;text-transform:uppercase;letter-spacing:.08em;margin:20px 0}.auth-sep:before,.auth-sep:after{content:"";flex:1;height:1px;background:var(--border-1)}.auth-error{margin-top:8px;padding:10px 12px;border-radius:8px;background:var(--neg-wash);color:var(--neg);font-size:12.5px;border:1px solid oklch(.72 .13 25 / .3)}.auth-info{margin-top:8px;padding:10px 12px;border-radius:8px;background:var(--accent-wash);color:var(--accent-hi);font-size:12.5px;border:1px solid oklch(.72 .15 var(--accent-hue) / .3)}.upload{border:1.5px dashed var(--border-2);border-radius:14px;padding:36px;text-align:center;background:repeating-linear-gradient(45deg,transparent 0 14px,oklch(1 0 0 / .008) 14px 15px),var(--bg-2);transition:border-color .15s,background .15s;cursor:pointer}.upload:hover,.upload.dragging{border-color:var(--accent);background:repeating-linear-gradient(45deg,transparent 0 14px,oklch(1 0 0 / .012) 14px 15px),oklch(.72 .15 var(--accent-hue) / .06)}.upload-icon{width:44px;height:44px;margin:0 auto 12px;border-radius:12px;background:var(--bg-3);display:grid;place-items:center;color:var(--accent)}.upload h3{margin:0 0 4px;font-size:15px;font-weight:600;letter-spacing:-.01em}.upload p{margin:0;color:var(--text-3);font-size:13px}.cat-dot{width:8px;height:8px;border-radius:2px;display:inline-block}.debt-row{display:grid;grid-template-columns:28px 1fr auto auto auto;gap:14px;align-items:center;padding:14px 16px;border-radius:10px;background:var(--bg-2);border:1px solid var(--border-1);transition:background .12s,border-color .12s}.debt-row:hover{border-color:var(--border-2)}.debt-rank{width:22px;height:22px;border-radius:6px;background:var(--bg-3);color:var(--text-2);display:grid;place-items:center;font-size:11px;font-weight:600;font-family:var(--font-mono)}.debt-rank.hi{background:var(--neg-wash);color:var(--neg)}.debt-name{font-weight:500}.debt-meta{color:var(--text-3);font-size:12px;display:flex;gap:10px;align-items:center;margin-top:3px}.sub-card{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--bg-2);border:1px solid var(--border-1);border-radius:12px;transition:all .12s}.sub-card:hover{border-color:var(--border-2);background:var(--bg-3)}.sub-logo{width:40px;height:40px;border-radius:10px;background:var(--bg-3);display:grid;place-items:center;font-weight:600;font-family:var(--font-serif);font-size:18px;color:var(--text-1);flex-shrink:0}.chart{width:100%}.donut-legend{display:flex;flex-direction:column;gap:10px}.donut-legend-row{display:grid;grid-template-columns:16px 1fr auto;gap:10px;align-items:center;font-size:13px;padding:6px 0;border-bottom:1px dashed var(--border-1)}.donut-legend-row:last-child{border-bottom:0}body[data-density=compact] .card{padding:14px 16px}body[data-density=compact] .stat-value{font-size:26px}body[data-density=compact] .stat{min-height:120px;gap:10px}body[data-density=compact] .table td{padding:8px 12px}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.page{animation:fadeUp .28s ease both}:focus-visible{outline:2px solid var(--accent-ring);outline-offset:2px;border-radius:8px}.toast-stack{position:fixed;right:20px;bottom:20px;display:flex;flex-direction:column;gap:8px;z-index:200}.toast{background:#171b22f2;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border-2);border-radius:10px;padding:10px 14px;min-width:240px;font-size:13px;box-shadow:var(--shadow-md);animation:fadeUp .2s ease both}.toast.err{border-color:#eb827b80}.toast.ok{border-color:#7bcc9880}.loader-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#02020299;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:150}.spinner{width:32px;height:32px;border-radius:50%;border:2px solid var(--border-2);border-top-color:var(--accent);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.skel{background:linear-gradient(90deg,var(--bg-2),var(--bg-3),var(--bg-2));background-size:200% 100%;border-radius:6px;animation:shimmer 1.4s ease-in-out infinite}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}
