:root{--primary: #7F2DBF;--primary-hover: #6623A0;--primary-light: #A15AD8;--primary-bg: #F3E8FF;--secondary: #6B7280;--tertiary: #00EDAD;--tertiary-hover: #00D99A;--tertiary-bg: #E6FFF7;--tertiary-fg: #005C44;--neutral: #F5F5F5;--surface: #FFFFFF;--on-surface: #1A1A1A;--muted: #F5F5F5;--muted-foreground: #6B7280;--border: #E5E5E5;--error: #EF4444;--error-bg: #FEF2F2;--error-fg: #B91C1C;--destructive: #B91C1C;--destructive-hover: #991717;--warning: #F59E0B;--info: #3B82F6;--font-sans: "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace;--r-sm: 6px;--r-md: 8px;--r-lg: 9px;--r-xl: 12px;--r-2xl: 16px;--r-full: 9999px;--shadow-xs: 0 1px 2px 0 rgba(0,0,0,.04);--shadow-sm: 0 1px 3px 0 rgba(0,0,0,.06), 0 1px 2px -1px rgba(0,0,0,.04);--shadow-md: 0 4px 8px -2px rgba(0,0,0,.08), 0 2px 4px -2px rgba(0,0,0,.04);--shadow-lg: 0 10px 24px -8px rgba(0,0,0,.12), 0 4px 8px -4px rgba(0,0,0,.06);--shadow-emboss: inset 0 4px 4px rgba(255,255,255,.4), inset 0 -4px 4px rgba(0,0,0,.25);--shadow-emboss-sm: inset 0 2px 3px rgba(255,255,255,.35), inset 0 -2px 3px rgba(0,0,0,.2);--ring: 0 0 0 3px color-mix(in srgb, var(--primary) 30%, transparent);--ring-error: 0 0 0 3px color-mix(in srgb, var(--error) 30%, transparent);--z-base: 0;--z-raised: 10;--z-dropdown: 1000;--z-sticky: 1100;--z-overlay: 1200;--z-modal: 1300;--z-popover: 1400;--z-toast: 1500;--z-tooltip: 1600;--ease-standard: cubic-bezier(.4, 0, .2, 1);--ease-decel: cubic-bezier(0, 0, .2, 1);--ease-accel: cubic-bezier(.4, 0, 1, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--dur-instant: 80ms;--dur-fast: .12s;--dur-base: .2s;--dur-slow: .32s;--dur-slower: .48s;--bp-sm: 640px;--bp-md: 768px;--bp-lg: 1024px;--bp-xl: 1280px}.is-embossed{box-shadow:var(--shadow-emboss);transition:transform var(--dur-instant) var(--ease-standard),box-shadow var(--dur-fast) var(--ease-standard)}.is-embossed--sm{box-shadow:var(--shadow-emboss-sm)}.is-embossed--mint{box-shadow:inset 0 4px 4px #ffffff8c,inset 0 -4px 4px #005c4438}.is-embossed--dark{box-shadow:inset 0 4px 4px #ffffff2e,inset 0 -4px 4px #00000073}.is-pressed{box-shadow:inset 0 2px 4px #0000002e,inset 0 -1px 1px #fff6;transition:box-shadow var(--dur-fast) var(--ease-standard)}.is-embossed:active:not(:disabled):not([aria-disabled=true]){transform:scale(.97)}@media (prefers-reduced-motion: reduce){.is-embossed:active{transform:none}*,*:before,*:after{animation-duration:.001ms!important;transition-duration:.001ms!important}}*{box-sizing:border-box}html,body{margin:0;background:var(--neutral);color:var(--on-surface);font-family:var(--font-sans);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;cursor:pointer;font-family:var(--font-sans);font-size:14px;font-weight:500;line-height:1;white-space:nowrap;-webkit-user-select:none;user-select:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;height:36px;padding:0 16px;border-radius:var(--r-md);transition:background-color var(--dur-fast),color var(--dur-fast),border-color var(--dur-fast),box-shadow var(--dur-fast),transform var(--dur-instant)}.btn:focus-visible{outline:none;box-shadow:var(--ring)}.btn:disabled,.btn[aria-disabled=true]{opacity:.5;cursor:not-allowed;pointer-events:none}.btn:active:not(:disabled){transform:translateY(.5px)}.btn .icon{width:16px;height:16px;flex-shrink:0;display:inline-flex}.btn .icon svg{width:100%;height:100%}.btn--sm{height:32px;padding:0 12px;font-size:13px;border-radius:var(--r-sm)}.btn--lg{height:56px;padding:0 24px;font-size:16px;font-weight:700;border-radius:var(--r-2xl)}.btn--icon{width:36px;padding:0}.btn--icon.btn--sm{width:32px}.btn--icon.btn--lg{width:56px}.btn--full{width:100%}.btn--primary{background:var(--primary);color:#fff;font-weight:700;border-radius:var(--r-2xl);box-shadow:var(--shadow-emboss)}.btn--primary:hover:not(:disabled){background:var(--primary-hover)}.btn--primary:active:not(:disabled){transform:scale(.97)}.btn--secondary{background:var(--muted);color:var(--on-surface)}.btn--secondary:hover:not(:disabled){background:#ececec}.btn--outline{background:var(--surface);color:var(--on-surface);border:1px solid var(--border)}.btn--outline:hover:not(:disabled){background:var(--neutral);border-color:#d6d6d6}.btn--ghost{background:transparent;color:var(--on-surface)}.btn--ghost:hover:not(:disabled){background:var(--muted)}.btn--destructive{background:var(--destructive);color:#fff;font-weight:700;border-radius:var(--r-2xl);box-shadow:var(--shadow-emboss)}.btn--destructive:hover:not(:disabled){background:var(--destructive-hover)}.btn--destructive:active:not(:disabled){transform:scale(.97)}.btn--loading{pointer-events:none;position:relative;color:transparent!important}.btn--loading>*{visibility:hidden}.btn--loading:after{content:"";position:absolute;top:50%;left:50%;width:14px;height:14px;margin:-7px 0 0 -7px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;color:var(--on-surface);visibility:visible;animation:btn-spin .7s linear infinite}.btn--primary.btn--loading:after,.btn--destructive.btn--loading:after{color:#fff}.btn--lg.btn--loading:after{width:20px;height:20px;margin:-10px 0 0 -10px;border-width:2.5px}.btn--sm.btn--loading:after{width:12px;height:12px;margin:-6px 0 0 -6px}@keyframes btn-spin{to{transform:rotate(360deg)}}.side-nav{display:flex;flex-direction:column;gap:2px}.side-nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--r-md);font-family:var(--font-sans);font-size:14px;font-weight:500;color:var(--on-surface);text-decoration:none;transition:background-color var(--dur-fast),color var(--dur-fast)}.side-nav-item:hover{background:var(--muted)}.side-nav-item .icon{width:18px;height:18px;flex-shrink:0;color:var(--muted-foreground)}.side-nav-item.is-active{background:var(--primary);color:#fff;font-weight:600;box-shadow:var(--shadow-emboss-sm)}.side-nav-item.is-active .icon{color:#fff}.badge{display:inline-flex;align-items:center;gap:6px;height:22px;padding:0 8px;font-size:12px;font-weight:500;letter-spacing:.05em;border-radius:var(--r-md);white-space:nowrap}.badge--default{background:var(--primary);color:#fff}.badge--secondary{background:var(--muted);color:var(--on-surface)}.badge--outline{background:var(--surface);color:var(--on-surface);border:1px solid var(--border)}.badge--purple{background:var(--primary-bg);color:var(--primary)}.badge--mint{background:var(--tertiary-bg);color:var(--tertiary-fg)}.badge--dot:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:13px;font-weight:500;color:var(--on-surface)}.field label .req{color:var(--primary);margin-left:2px}.input-wrap{position:relative;display:flex;align-items:center}.input-wrap .lead-icon{position:absolute;left:12px;color:var(--muted-foreground);width:16px;height:16px;display:flex}.input{width:100%;height:36px;padding:0 12px;background:var(--surface);color:var(--on-surface);border:1px solid var(--border);border-radius:var(--r-md);font-family:var(--font-sans);font-size:14px;line-height:1;transition:border-color var(--dur-fast),box-shadow var(--dur-fast)}.input::placeholder{color:var(--muted-foreground)}.input:focus{outline:none;border-color:var(--primary);box-shadow:var(--ring)}.input:disabled{opacity:.5;cursor:not-allowed;background:var(--muted)}.input.has-icon{padding-left:36px}.input[aria-invalid=true]{border-color:var(--error)}.input[aria-invalid=true]:focus{box-shadow:var(--ring-error)}.field .helper{font-size:12px;color:var(--muted-foreground)}.field .error{font-size:12px;color:var(--error-fg)}.input--sm,.select--sm{height:32px;font-size:13px;padding:0 10px;border-radius:var(--r-sm)}.input--lg,.select--lg{height:44px;font-size:16px;padding:0 14px;border-radius:var(--r-lg)}.input--lg.has-icon,.select--lg.has-icon{padding-left:40px}.input--sm.has-icon,.select--sm.has-icon{padding-left:32px}.textarea{width:100%;min-height:88px;padding:10px 12px;background:var(--surface);color:var(--on-surface);border:1px solid var(--border);border-radius:var(--r-md);font-family:var(--font-sans);font-size:14px;line-height:1.5;resize:vertical;transition:border-color var(--dur-fast),box-shadow var(--dur-fast)}.textarea::placeholder{color:var(--muted-foreground)}.textarea:focus{outline:none;border-color:var(--primary);box-shadow:var(--ring)}.textarea:disabled{opacity:.5;cursor:not-allowed;background:var(--muted)}.textarea[aria-invalid=true]{border-color:var(--error)}.textarea[aria-invalid=true]:focus{box-shadow:var(--ring-error)}.textarea--sm{min-height:64px;font-size:13px;padding:8px 10px}.textarea--lg{min-height:144px;font-size:16px;padding:12px 14px;border-radius:var(--r-lg)}.select-wrap{position:relative;display:flex;align-items:center;width:100%}.select-wrap .lead-icon{position:absolute;left:12px;color:var(--muted-foreground);width:16px;height:16px;display:flex;pointer-events:none}.select-wrap:after{content:"";position:absolute;right:14px;top:50%;width:8px;height:8px;border-right:1.5px solid var(--muted-foreground);border-bottom:1.5px solid var(--muted-foreground);transform:translateY(-65%) rotate(45deg);pointer-events:none}.select{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:100%;height:36px;padding:0 36px 0 12px;background:var(--surface);color:var(--on-surface);border:1px solid var(--border);border-radius:var(--r-md);font-family:var(--font-sans);font-size:14px;line-height:1;cursor:pointer;transition:border-color var(--dur-fast),box-shadow var(--dur-fast)}.select:focus{outline:none;border-color:var(--primary);box-shadow:var(--ring)}.select:disabled{opacity:.5;cursor:not-allowed;background:var(--muted)}.select.has-icon{padding-left:36px}.select[aria-invalid=true]{border-color:var(--error)}.select[aria-invalid=true]:focus{box-shadow:var(--ring-error)}.select.is-placeholder{color:var(--muted-foreground)}.check{display:inline-flex;align-items:center;gap:8px;font-size:14px;cursor:pointer;-webkit-user-select:none;user-select:none}.check input{position:absolute;opacity:0;pointer-events:none}.check .box{width:18px;height:18px;border-radius:var(--r-sm);border:1.5px solid #C7C7C7;background:var(--surface);display:inline-flex;align-items:center;justify-content:center;transition:background var(--dur-fast),border-color var(--dur-fast),box-shadow var(--dur-fast)}.check input:focus-visible+.box{box-shadow:var(--ring)}.check input:checked+.box{background:var(--primary);border-color:var(--primary)}.check input:checked+.box:after{content:"";width:10px;height:10px;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='white' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><path d='M3 8l3.5 3.5L13 5'/></svg>") center/contain no-repeat}.check input:disabled+.box{opacity:.5}.check.indet input+.box{background:var(--primary);border-color:var(--primary)}.check.indet input+.box:after{content:"";width:8px;height:2px;background:#fff;border-radius:1px}.radio{display:inline-flex;align-items:center;gap:8px;font-size:14px;cursor:pointer;-webkit-user-select:none;user-select:none}.radio input{position:absolute;opacity:0;pointer-events:none}.radio .dot{width:18px;height:18px;border-radius:50%;border:1.5px solid #C7C7C7;background:var(--surface);display:inline-flex;align-items:center;justify-content:center;transition:border-color var(--dur-fast),box-shadow var(--dur-fast)}.radio input:focus-visible+.dot{box-shadow:var(--ring)}.radio input:checked+.dot{border-color:var(--primary);border-width:5px}.switch{display:inline-flex;align-items:center;gap:8px;font-size:14px;cursor:pointer;-webkit-user-select:none;user-select:none}.switch input{position:absolute;opacity:0;pointer-events:none}.switch .track{width:36px;height:20px;border-radius:var(--r-full);background:#d4d4d4;position:relative;transition:background var(--dur-base)}.switch .track:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 2px #00000040;transition:transform var(--dur-base)}.switch input:checked+.track{background:var(--primary)}.switch input:checked+.track:after{transform:translate(16px)}.switch input:focus-visible+.track{box-shadow:var(--ring)}.tag{display:inline-flex;align-items:center;gap:6px;height:26px;padding:0 10px;background:var(--surface);color:var(--on-surface);border:1px solid var(--border);border-radius:var(--r-full);font-size:12px;font-weight:500}.tag--purple{background:var(--primary-bg);color:var(--primary);border-color:transparent}.tag--mint{background:var(--tertiary-bg);color:var(--tertiary-fg);border-color:transparent}.tag .x{width:14px;height:14px;border-radius:50%;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;margin-right:-4px;opacity:.5}.tag .x:hover{opacity:1;background:#0000000f}.skel{background:linear-gradient(90deg,#ececec,#f5f5f5,#ececec);background-size:200% 100%;border-radius:var(--r-md);animation:shimmer 1.4s linear infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.progress{width:100%;height:6px;background:var(--muted);border-radius:var(--r-full);overflow:hidden}.progress>.bar{height:100%;background:var(--primary);border-radius:var(--r-full);transition:width var(--dur-base) var(--ease-standard)}.progress--mint>.bar{background:var(--tertiary)}.avatar{position:relative;display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--primary-bg);color:var(--primary);font-weight:600;font-size:14px;overflow:hidden;flex-shrink:0}.avatar img{width:100%;height:100%;object-fit:cover}.avatar--xs{width:24px;height:24px;font-size:10px}.avatar--sm{width:32px;height:32px;font-size:12px}.avatar--lg{width:56px;height:56px;font-size:18px}.avatar--xl{width:72px;height:72px;font-size:22px}.avatar .status{position:absolute;bottom:0;right:0;width:10px;height:10px;border-radius:50%;border:2px solid var(--surface);background:var(--tertiary)}.alert{display:flex;gap:12px;align-items:flex-start;padding:14px 16px;border-radius:var(--r-lg);border:1px solid var(--border);background:var(--surface)}.alert .icon{width:20px;height:20px;flex-shrink:0;margin-top:1px}.alert .body{flex:1}.alert .title{font-weight:600;font-size:14px;line-height:1.4;margin:0 0 2px}.alert .desc{font-size:13px;color:var(--muted-foreground);margin:0;line-height:1.5}.alert--success{background:var(--tertiary-bg);border-color:color-mix(in srgb,var(--tertiary) 30%,transparent);color:var(--tertiary-fg)}.alert--success .desc{color:color-mix(in srgb,var(--tertiary-fg) 80%,transparent)}.alert--error{background:var(--error-bg);border-color:color-mix(in srgb,var(--error) 30%,transparent);color:var(--error-fg)}.alert--error .desc{color:color-mix(in srgb,var(--error-fg) 80%,transparent)}.alert--info{background:#eff6ff;border-color:#bfdbfe;color:#1e40af}.alert--info .desc{color:#1e40af;opacity:.8}.tip-host{position:relative;display:inline-flex}.tip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);padding:6px 10px;background:#1a1a1a;color:#fff;font-size:12px;border-radius:var(--r-sm);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity var(--dur-fast);z-index:var(--z-tooltip)}.tip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:#1a1a1a}.tip-host:hover .tip,.tip-host:focus-within .tip{opacity:1}.link{color:var(--primary);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}.link:hover{color:var(--primary-hover);text-decoration-thickness:2px}.link--quiet{color:var(--on-surface);text-decoration-color:var(--border)}.link--quiet:hover{text-decoration-color:var(--on-surface)}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border)}.tab{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:0;cursor:pointer;padding:10px 14px;font-family:var(--font-sans);font-size:14px;font-weight:500;color:var(--muted-foreground);border-bottom:2px solid transparent;margin-bottom:-1px;transition:color var(--dur-fast),border-color var(--dur-fast)}.tab:hover{color:var(--on-surface)}.tab[aria-selected=true]{color:var(--primary);border-bottom-color:var(--primary)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:24px;box-shadow:var(--shadow-xs)}.card--interactive{cursor:pointer;transition:border-color var(--dur-base),box-shadow var(--dur-base),transform var(--dur-base)}.card--interactive:hover{border-color:#d6d6d6;box-shadow:var(--shadow-md);transform:translateY(-1px)}.halo-h{position:relative;display:inline-block;font-family:var(--font-sans);font-weight:600;line-height:1.1;letter-spacing:-.01em;color:var(--on-surface);isolation:isolate}.halo-h .halo{position:absolute;top:0;right:0;bottom:0;left:0;-webkit-text-stroke:10px #FFFFFF;-webkit-text-fill-color:transparent;filter:drop-shadow(0 2px 3px rgba(0,0,0,.08)) drop-shadow(0 1px 2px rgba(0,0,0,.05));pointer-events:none;z-index:-1}.halo-h .text{position:relative}.halo-h--lg{font-size:30px}.halo-h--lg .halo{-webkit-text-stroke-width:10px}.halo-h--xl{font-size:44px;letter-spacing:-.02em}.halo-h--xl .halo{-webkit-text-stroke-width:14px}.halo-h--2xl{font-size:64px;font-weight:700;letter-spacing:-.03em;line-height:1.05}.halo-h--2xl .halo{-webkit-text-stroke-width:18px}.halo-h--on-tint .halo{-webkit-text-stroke-color:var(--neutral)}.halo{position:relative;display:inline-block;font-family:var(--font-sans);font-weight:600;letter-spacing:-.01em;line-height:1.15;color:var(--on-surface);isolation:isolate}.halo:before{content:attr(data-text);position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:-1;-webkit-text-stroke:10px var(--surface);-webkit-text-fill-color:transparent;filter:drop-shadow(0 2px 3px rgba(0,0,0,.08)) drop-shadow(0 1px 2px rgba(0,0,0,.05))}.halo--sm{font-size:20px}.halo--sm:before{-webkit-text-stroke-width:6px}.halo--md{font-size:28px}.halo--md:before{-webkit-text-stroke-width:8px}.halo--lg{font-size:40px;line-height:1.1}.halo--lg:before{-webkit-text-stroke-width:12px}.halo--xl{font-size:56px;line-height:1.05;letter-spacing:-.02em}.halo--xl:before{-webkit-text-stroke-width:16px}.halo--on-neutral:before{-webkit-text-stroke-color:var(--neutral)}.halo--on-purple:before{-webkit-text-stroke-color:var(--primary-bg)}.halo--on-mint:before{-webkit-text-stroke-color:var(--tertiary-bg)}.halo--purple{color:var(--primary)}.toast{display:flex;gap:12px;align-items:flex-start;padding:12px 36px 12px 14px;min-width:320px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);position:relative}.toast .icon{width:18px;height:18px;margin-top:1px;flex-shrink:0}.toast .title{font-size:13px;font-weight:600;margin:0 0 2px}.toast .desc{font-size:12px;color:var(--muted-foreground);margin:0}.toast .close{position:absolute;top:8px;right:8px;width:22px;height:22px;border:0;background:transparent;cursor:pointer;border-radius:var(--r-sm);color:var(--muted-foreground)}.toast .close:hover{background:var(--muted)}.toast--success .icon{color:var(--tertiary-fg)}.toast--error .icon{color:var(--error-fg)}.stat-tile{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 20px;display:flex;flex-direction:column;gap:10px;box-shadow:var(--shadow-xs)}.stat-tile__head{display:flex;align-items:center;justify-content:space-between;gap:8px}.stat-tile__label{font-size:12px;font-weight:500;color:var(--muted-foreground);text-transform:uppercase;letter-spacing:.06em;margin:0}.stat-tile__icon{width:18px;height:18px;color:var(--muted-foreground);display:inline-flex;flex-shrink:0}.stat-tile__value{font-size:32px;font-weight:700;letter-spacing:-.02em;line-height:1.1;color:var(--on-surface);font-variant-numeric:tabular-nums;margin:0}.stat-tile__meta{display:flex;align-items:center;gap:6px;font-size:12px;line-height:1.4;color:var(--muted-foreground)}.stat-tile__delta{display:inline-flex;align-items:center;gap:2px;font-weight:600;font-variant-numeric:tabular-nums}.stat-tile__delta--up{color:var(--tertiary-fg)}.stat-tile__delta--down{color:var(--error-fg)}.stat-tile__delta--flat{color:var(--muted-foreground)}.stat-tile__delta-icon{width:12px;height:12px;display:inline-flex}.member-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px;display:flex;align-items:center;gap:12px}.member-card__body{flex:1;min-width:0}.member-card__name{font-size:14px;font-weight:600;color:var(--on-surface);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.member-card__role{font-size:12px;color:var(--muted-foreground);margin:2px 0 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.member-card__role-badge{display:inline-block;margin-top:6px;font-size:10px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:2px 6px;border-radius:var(--r-sm);background:var(--primary-bg);color:var(--primary)}.member-card__role-badge--mint{background:var(--tertiary-bg);color:var(--tertiary-fg)}.member-card__role-badge--neutral{background:var(--muted);color:var(--muted-foreground)}.member-card__actions{display:inline-flex;gap:4px;flex-shrink:0}*,*:before,*:after{margin:0;padding:0}a{color:inherit;text-decoration:none}button{font-family:var(--font-sans)}input,select,textarea{width:100%;padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--r-md);font-size:14px;font-family:var(--font-sans);outline:none;background:var(--surface);color:var(--on-surface);transition:border-color var(--dur-fast),box-shadow var(--dur-fast)}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:var(--ring)}input::placeholder,textarea::placeholder{color:var(--muted-foreground)}.btn-primary{background:var(--primary);color:#fff;font-weight:700;border-radius:var(--r-2xl);box-shadow:var(--shadow-emboss)}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-primary:active:not(:disabled){transform:scale(.97)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--muted);color:var(--on-surface);border:none}.btn-secondary:hover:not(:disabled){background:#ececec}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-danger{background:var(--destructive);color:#fff;font-weight:700;border-radius:var(--r-2xl);box-shadow:var(--shadow-emboss)}.btn-danger:hover:not(:disabled){background:var(--destructive-hover)}.btn-danger:active:not(:disabled){transform:scale(.97)}.page{max-width:800px;margin:0 auto;padding:1rem}.alert-warning{background:#fffbeb;border:1px solid var(--warning);border-radius:var(--r-md);padding:.75rem 1rem;margin-bottom:1rem;font-size:13px;color:#92400e}.alert-error{background:var(--error-bg);border:1px solid color-mix(in srgb,var(--error) 40%,transparent);border-radius:var(--r-md);padding:.75rem 1rem;color:var(--error-fg);margin-bottom:1rem;font-size:13px}.form-group{margin-bottom:1rem}.form-group label{display:block;font-weight:500;margin-bottom:.25rem;font-size:13px;color:var(--on-surface)}nav{display:flex;gap:.25rem;margin-bottom:1.5rem;flex-wrap:wrap}nav a{padding:.5rem .75rem;border-radius:var(--r-md);font-weight:500;color:var(--muted-foreground);font-size:13px;transition:background var(--dur-fast),color var(--dur-fast)}nav a:hover{background:var(--muted);color:var(--on-surface)}nav a.active{background:var(--primary-bg);color:var(--primary);font-weight:600}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:.6rem .75rem;border-bottom:1px solid var(--muted);font-size:13px}th{font-weight:600;color:var(--muted-foreground);background:var(--neutral)}.badge-income{color:var(--tertiary-fg);font-weight:600}.badge-expense{color:var(--error-fg);font-weight:600}
