:root{--color-primary: #6366f1;--color-primary-10: #6366f11a;--color-secondary: #8b5cf6;--color-success: #10b981;--color-error: #ef4444;--color-warning: #f59e0b;--color-surface: #ffffff;--color-bg: #f9fafb;--color-border: #e5e7eb;--color-text: #111827;--color-muted: #6b7280;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 12px rgba(0,0,0,.12);--shadow-lg: 0 8px 30px rgba(0,0,0,.16);--container-max: 1200px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:var(--color-text);background:var(--color-bg);line-height:1.5;-webkit-font-smoothing:antialiased}a{color:inherit}img{max-width:100%;height:auto;display:block}input,button,select,textarea{font:inherit;outline:none}.container{max-width:var(--container-max);margin:0 auto;padding:0 1.5rem}.btn,.btn-ghost,.btn-outline,.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.55rem 1.25rem;border-radius:var(--radius-md);font-size:.9rem;font-weight:500;cursor:pointer;border:none;transition:opacity .15s,transform .1s;text-decoration:none}.btn:active,.btn-ghost:active,.btn-outline:active,.btn-primary:active{transform:scale(.98)}.btn:disabled,.btn-ghost:disabled,.btn-outline:disabled,.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{opacity:.9}.btn-outline{background:transparent;border:1.5px solid var(--color-border);color:var(--color-text)}.btn-outline:hover{border-color:var(--color-primary);color:var(--color-primary)}.btn-ghost{background:transparent;color:var(--color-muted)}.btn-ghost:hover{background:var(--color-bg);color:var(--color-text)}.card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);overflow:hidden}.badge{display:inline-flex;align-items:center;padding:.2rem .65rem;border-radius:999px;font-size:.75rem;font-weight:500;background:var(--color-primary-10);color:var(--color-primary)}.section-title{font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.section-subtitle{color:var(--color-muted);margin-bottom:2rem}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}@media(max-width:900px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}}.page-container{max-width:var(--container-max);margin:0 auto;padding:2rem 1.5rem}.page-header{margin-bottom:2rem}.page-header h1{font-size:2rem;font-weight:700}.page-header p{color:var(--color-muted);margin-top:.5rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-size:.9rem;font-weight:500}.form-group input,.form-group select,.form-group textarea{padding:.65rem .9rem;border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:#fff;transition:border-color .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-primary)}.form-group textarea{resize:vertical;min-height:80px}.form-group .hint{font-size:.8rem;color:var(--color-muted)}.form-group .error-msg{font-size:.8rem;color:var(--color-error)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#9ca3af}
