*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root{--ct-bg-base: #0f1117;--ct-bg-surface: #151823;--ct-bg-surface2: #111420;--ct-bg-elevated: #0d1019;--ct-bg-input: #0f1117;--ct-bg-hover: #1a2035;--ct-border: #1a2035;--ct-border2: #1e2538;--ct-border-strong: #2d3347;--ct-text-primary: #e2e8f0;--ct-text-secondary: #94a3b8;--ct-text-muted: #64748b;--ct-text-dim: #3d4461;--ct-overlay: rgba(0,0,0,.65);--ct-modal-shadow: rgba(0,0,0,.7);--ct-card-shadow: rgba(0,0,0,.3)}[data-theme=light]{--ct-bg-base: #f1f5f9;--ct-bg-surface: #ffffff;--ct-bg-surface2: #f8fafc;--ct-bg-elevated: #ffffff;--ct-bg-input: #f8fafc;--ct-bg-hover: #f1f5f9;--ct-border: #e2e8f0;--ct-border2: #e2e8f0;--ct-border-strong: #cbd5e1;--ct-text-primary: #0f172a;--ct-text-secondary: #475569;--ct-text-muted: #64748b;--ct-text-dim: #94a3b8;--ct-overlay: rgba(0,0,0,.4);--ct-modal-shadow: rgba(0,0,0,.15);--ct-card-shadow: rgba(0,0,0,.08)}body{background:var(--ct-bg-base);color:var(--ct-text-primary);font-family:DM Sans,system-ui,sans-serif;line-height:1.5;min-height:100vh}code,pre,.mono{font-family:DM Mono,Courier New,monospace}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--ct-bg-base)}::-webkit-scrollbar-thumb{background:var(--ct-border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--ct-text-dim)}::selection{background:#d4a01740;color:#f0c040}input,textarea,select,button{font-family:inherit}:focus-visible{outline:2px solid #d4a017;outline-offset:2px}input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.6);cursor:pointer}select option{background:var(--ct-bg-surface);color:var(--ct-text-primary)}.fade-in{animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.spinner{animation:spin .8s linear infinite}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--ct-bg-hover) 25%,var(--ct-border2) 50%,var(--ct-bg-hover) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:4px}
