*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--accent: #1a2744;--accent-light: #2e4070;--accent-muted: #e8ecf3;--text: #1e2533;--text-muted: #6b7280;--border: #e5e7eb;--surface: #f9fafb;--white: #ffffff;--danger: #dc2626;--success: #16a34a;--warning: #d97706;--radius: 8px;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.06)}html{font-size:16px;scroll-behavior:smooth}body{font-family:Inter,system-ui,sans-serif;color:var(--text);background:var(--white);line-height:1.6}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;border-radius:var(--radius);font-size:.9rem;font-weight:500;border:none;transition:all .15s}.btn-primary{background:var(--accent);color:var(--white)}.btn-primary:hover{background:var(--accent-light)}.btn-outline{background:transparent;color:var(--accent);border:1.5px solid var(--accent)}.btn-outline:hover{background:var(--accent-muted)}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover{background:var(--surface);color:var(--text)}.btn-danger{background:var(--danger);color:var(--white)}.btn-sm{padding:.375rem .875rem;font-size:.8rem}.btn:disabled{opacity:.5;cursor:not-allowed}.badge{display:inline-block;padding:.2rem .6rem;border-radius:99px;font-size:.75rem;font-weight:500}.badge-pending{background:#fef3c7;color:#92400e}.badge-confirmed{background:#d1fae5;color:#065f46}.badge-cancelled{background:#fee2e2;color:#991b1b}.badge-completed{background:#e0e7ff;color:#3730a3}.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow)}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-group label{font-size:.85rem;font-weight:500;color:var(--text)}.form-control{width:100%;padding:.625rem .875rem;border:1.5px solid var(--border);border-radius:var(--radius);font-size:.9rem;background:var(--white);transition:border-color .15s}.form-control:focus{outline:none;border-color:var(--accent)}.form-control.error{border-color:var(--danger)}textarea.form-control{resize:vertical;min-height:120px}.page-header{padding:2rem 0 1rem}.page-header h1{font-size:1.6rem;font-weight:700}.page-header p{color:var(--text-muted);margin-top:.25rem}.table-wrapper{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.9rem}th{text-align:left;padding:.75rem 1rem;font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border)}td{padding:.875rem 1rem;border-bottom:1px solid var(--border);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:var(--surface)}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.empty-state .icon{font-size:2.5rem;margin-bottom:.75rem}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:var(--white);border-radius:12px;padding:2rem;width:100%;max-width:520px;box-shadow:0 20px 60px #00000026;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h2{font-size:1.2rem;font-weight:700}.modal-close{background:none;border:none;font-size:1.4rem;color:var(--text-muted);cursor:pointer}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem}.alert{padding:.875rem 1rem;border-radius:var(--radius);font-size:.9rem;margin-bottom:1rem}.alert-success{background:#d1fae5;color:#065f46}.alert-error{background:#fee2e2;color:#991b1b}@media (max-width: 768px){.hide-mobile{display:none}}
