:root{--color-bg: #f3f6fb;--color-bg-soft: #eef3fb;--color-card: #ffffff;--color-primary: #2563eb;--color-primary-hover: #1e4fcb;--color-primary-soft: #dbeafe;--color-success: #059669;--color-danger: #dc2626;--color-warning: #d97706;--color-text: #0f172a;--color-text-muted: #6b7280;--color-border: #e2e8f0;--font-sans: "Noto Sans SC", -apple-system, BlinkMacSystemFont, sans-serif;--radius: 14px;--shadow: 0 8px 24px -10px rgb(15 23 42 / 18%);--shadow-soft: 0 4px 14px -8px rgb(15 23 42 / 14%)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background:radial-gradient(1200px 500px at -10% -10%,#dbeafe 0%,transparent 55%),radial-gradient(1000px 400px at 110% -10%,#e0e7ff 0%,transparent 50%),var(--color-bg);color:var(--color-text);min-height:100vh;line-height:1.6}#app{min-height:100vh}a{color:var(--color-primary);text-decoration:none;transition:color .2s ease}a:hover{color:var(--color-primary-hover)}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:.62rem 1.15rem;border-radius:10px;border:none;font-weight:600;font-size:.95rem;transition:transform .15s ease,box-shadow .2s ease,background .2s ease,color .2s ease,border-color .2s ease}.btn-primary{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;box-shadow:0 8px 18px -10px #2563eb99}.btn-primary:hover{background:linear-gradient(135deg,#1f55d0,#1c49be);transform:translateY(-1px)}.btn-success{background:var(--color-success);color:#fff}.btn-danger{background:var(--color-danger);color:#fff}.btn-outline{background:#fff;border:1px solid #bfdbfe;color:var(--color-primary)}.btn-outline:hover{background:var(--color-primary-soft);border-color:#93c5fd}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.65;cursor:not-allowed;box-shadow:none}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.35rem;font-weight:500;color:var(--color-text)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.64rem .78rem;border:1px solid var(--color-border);border-radius:10px;font-size:.98rem;background:#fff;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb24}input,select,textarea{border:1px solid var(--color-border);border-radius:10px;padding:.62rem .75rem;font-size:.95rem;background:#fff}input::placeholder,textarea::placeholder{color:#94a3b8}input:focus,select:focus,textarea:focus{outline:none;border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa33}.card{background:var(--color-card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid rgba(226,232,240,.8);padding:1.2rem 1.25rem}.page{max-width:1200px;margin:0 auto;padding:1.2rem}.page-title{font-size:1.28rem;font-weight:700;margin-bottom:.85rem;letter-spacing:.2px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;background:#fff}th,td{padding:.72rem .9rem;text-align:left;border-bottom:1px solid var(--color-border);vertical-align:middle}th{font-weight:700;color:#475569;font-size:.82rem;text-transform:uppercase;letter-spacing:.4px;background:var(--color-bg-soft)}tbody tr:hover{background:#f8fbff}.badge{display:inline-block;padding:.2rem .6rem;border-radius:9999px;font-size:.8rem;font-weight:500}.badge-pending{background:#fef3c7;color:#92400e}.badge-success{background:#d1fae5;color:#065f46}.badge-danger{background:#fee2e2;color:#991b1b}.alert{padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem}.alert-error{background:#fee2e2;color:#991b1b}.alert-success{background:#d1fae5;color:#065f46}.admin-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.admin-header h1{font-size:1.35rem;font-weight:700}.nav{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}.nav a{color:#334155;background:#fff;border:1px solid var(--color-border);padding:.35rem .65rem;border-radius:8px;font-size:.92rem}.nav a.router-link-active{color:#1d4ed8;border-color:#93c5fd;background:#eff6ff;font-weight:600}@media (max-width: 768px){.page{padding:.85rem}.card{padding:.95rem}.btn{padding:.56rem .9rem;font-size:.9rem}th,td{padding:.62rem .6rem}}
