:root{--color-primary: #E2231A;--color-primary-dark: #B71C13;--color-primary-light: #FFE1DF;--color-text: #1f1f23;--color-text-muted: #5f6368;--color-bg: #f5f5f7;--color-surface: #ffffff;--color-border: #e3e3e6;--color-success: #1f8a3a;--color-warning: #b78103;--color-danger: #c0271e;--color-info: #1c4fa6;--radius: 8px;--shadow: 0 1px 3px rgba(0,0,0,.06);font-family:-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5;color:var(--color-text);background-color:var(--color-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100vh;background:var(--color-bg);color:var(--color-text)}a{color:var(--color-primary);text-decoration:none;font-weight:500}a:hover{color:var(--color-primary-dark)}h1,h2,h3,h4{color:var(--color-text);margin-top:0}button{font-family:inherit;font-size:1rem;font-weight:500;cursor:pointer;border:1px solid transparent;border-radius:var(--radius);padding:10px 18px;background:var(--color-primary);color:#fff;transition:background .15s,border-color .15s}button:hover:not(:disabled){background:var(--color-primary-dark)}button:disabled{background:#c8c8cc;cursor:not-allowed}button.secondary{background:#fff;color:var(--color-text);border-color:var(--color-border)}button.secondary:hover:not(:disabled){background:#f3f3f5}button.ghost{background:transparent;color:var(--color-primary);padding:6px 10px}button.ghost:hover{background:var(--color-primary-light);color:var(--color-primary-dark)}input,select,textarea{font-family:inherit;font-size:1rem;padding:9px 12px;border:1px solid var(--color-border);border-radius:6px;background:#fff;color:var(--color-text);width:100%}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}label{display:block;font-size:13px;color:var(--color-text-muted);margin-bottom:4px;font-weight:500}.error-banner{background:#fdecea;color:var(--color-danger);border:1px solid #f5c6c2;padding:10px 14px;border-radius:6px;font-size:14px;margin-bottom:12px}.success-banner{background:#e7f6ec;color:var(--color-success);border:1px solid #b9e0c4;padding:10px 14px;border-radius:6px;font-size:14px;margin-bottom:12px}.info-banner{background:#e7f0fa;color:var(--color-info);border:1px solid #b9d2ee;padding:10px 14px;border-radius:6px;font-size:14px;margin-bottom:12px}.app-layout{display:flex;min-height:100vh}.sidebar{width:260px;background:#1a1a1f;color:#fff;display:flex;flex-direction:column;box-shadow:2px 0 8px #00000014}.sidebar-header{padding:18px 18px 14px;border-bottom:1px solid rgba(255,255,255,.08)}.brand{display:flex;align-items:center;gap:10px;background:#fff;padding:8px 10px;border-radius:6px}.brand-logo{height:28px;width:auto;display:block}.brand-sub{margin-top:8px;font-size:11px;color:#ffffff8c;text-transform:uppercase;letter-spacing:.6px}.sidebar-nav{flex:1;padding:12px 0;overflow-y:auto}.nav-item{display:flex;align-items:center;padding:11px 18px;color:#ffffffbf;text-decoration:none;border-left:3px solid transparent;font-size:14px;font-weight:500;transition:background .15s,color .15s}.nav-item:hover{background:#ffffff0d;color:#fff}.nav-item.active{background:#e2231a24;color:#fff;border-left-color:var(--color-primary)}.nav-icon{width:22px;margin-right:10px;text-align:center;font-size:16px}.sidebar-footer{padding:14px 16px;border-top:1px solid rgba(255,255,255,.08)}.user-info{margin-bottom:12px;padding:10px;background:#ffffff0a;border-radius:6px}.user-name{font-size:13px;font-weight:600}.user-role{margin-top:2px;font-size:11px;color:#fff9;text-transform:uppercase;letter-spacing:.6px}.logout-btn{width:100%;padding:9px;background:transparent;border:1px solid rgba(255,255,255,.18);color:#ffffffd9;border-radius:6px;font-size:13px;cursor:pointer}.logout-btn:hover{background:#e2231a2e;border-color:var(--color-primary)}.main-content{flex:1;overflow-y:auto;background:var(--color-bg)}.page-shell{max-width:1200px;margin:0 auto;padding:24px}.page-shell h1{font-size:22px;margin:0 0 18px}.mobile-menu-toggle,.overlay{display:none}@media(max-width:768px){.sidebar{position:fixed;left:-260px;top:0;bottom:0;height:100vh;z-index:1001;transition:transform .25s ease-in-out}.sidebar.open{transform:translate(260px)}.main-content{width:100%}.mobile-menu-toggle{display:block;position:fixed;top:12px;left:12px;z-index:1002;background:#1a1a1f;color:#fff;border:none;padding:8px 12px;border-radius:6px;font-size:18px;cursor:pointer}.overlay{position:fixed;inset:0;background:#00000080;z-index:1000}.overlay.visible{display:block}.page-shell{padding:56px 16px 16px}}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:18px;margin-bottom:16px;box-shadow:var(--shadow)}.card h2{font-size:16px;margin:0 0 12px}.card .row{display:flex;gap:12px;flex-wrap:wrap}.card .row>*{flex:1;min-width:200px}.segmented{display:inline-flex;background:#f3f3f5;border-radius:8px;padding:4px;gap:4px}.segmented button{background:transparent;color:var(--color-text-muted);padding:8px 14px;font-size:13px;font-weight:500;border-radius:6px;border:1px solid transparent}.segmented button.active{background:#fff;color:var(--color-text);box-shadow:0 1px 3px #0000000f}.segmented button:hover:not(.active){background:#0000000a;color:var(--color-text)}.attendees-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.attendee-row{display:grid;grid-template-columns:1fr 200px 36px;gap:8px;align-items:center}.attendee-row .remove{background:transparent;color:var(--color-danger);border:1px solid var(--color-border);padding:8px;font-size:14px}.attendee-row .remove:hover{background:#fdecea;border-color:var(--color-danger)}.status-pill{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.4px}.status-pill.draft,.status-pill.awaiting_visitor_input{background:#f3f3f5;color:#555}.status-pill.pending_approval{background:#fff4d6;color:#8a6d00}.status-pill.approved{background:#def7e6;color:#14622e}.status-pill.rejected,.status-pill.expired{background:#fdecea;color:#a8201a}.status-pill.cancelled{background:#ececef;color:#5a5a5a}.status-pill.checked_in{background:#def0fb;color:#1c4fa6}.status-pill.checked_out{background:#ffe1df;color:#a8201a}.visit-table{width:100%;border-collapse:collapse;background:var(--color-surface);border-radius:var(--radius);overflow:hidden;border:1px solid var(--color-border)}.visit-table th,.visit-table td{padding:10px 14px;border-bottom:1px solid var(--color-border);font-size:14px;text-align:left}.visit-table th{font-weight:600;color:var(--color-text-muted);background:#fafafa;font-size:12px;text-transform:uppercase;letter-spacing:.4px}.visit-table tr:last-child td{border-bottom:none}.visit-table tbody tr{cursor:pointer}.visit-table tbody tr:hover{background:#fafafa}.filter-bar{display:flex;gap:8px;flex-wrap:wrap;align-items:end;margin-bottom:16px}.filter-bar>*{min-width:160px}.filter-bar input.search{flex:2;min-width:240px}.qr-display{text-align:center;padding:16px;background:#fafafa;border-radius:8px;border:1px solid var(--color-border)}.qr-display img{width:240px;height:240px}.qr-display .copy-link{font-size:13px;color:var(--color-text-muted);word-break:break-all}.copy-link-box{background:#fafafa;border:1px solid var(--color-border);border-radius:6px;padding:10px 12px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;word-break:break-all;margin:8px 0 12px}.attendee-checklist{display:flex;flex-direction:column;gap:6px;margin:10px 0 16px}.attendee-checklist label{display:flex;align-items:center;gap:8px;background:#fafafa;padding:10px 12px;border-radius:6px;border:1px solid var(--color-border);cursor:pointer;font-size:14px;color:var(--color-text);margin:0}.attendee-checklist input[type=checkbox]{width:auto;margin:0;transform:scale(1.2)}.attendee-checklist label.done{background:#def7e6;border-color:#b6e3c4}.account-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:20px;margin-bottom:16px;max-width:600px}.account-info{line-height:1.9;font-size:14px}.account-info .lbl{color:var(--color-text-muted);display:inline-block;min-width:80px}#root{width:100%;min-height:100vh;margin:0;padding:0;text-align:left}.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(ellipse at top right,rgba(226,35,26,.08),transparent 50%),radial-gradient(ellipse at bottom left,rgba(226,35,26,.04),transparent 50%),var(--color-bg)}.auth-card{width:100%;max-width:420px;background:var(--color-surface);border-radius:12px;padding:32px;box-shadow:0 4px 16px #0000000f}.auth-card h1{font-size:22px;margin:0 0 6px}.auth-card .subtitle{color:var(--color-text-muted);margin:0 0 20px;font-size:14px}.auth-card .form-row{margin-bottom:14px}.auth-card .form-actions{margin-top:16px}.auth-card .form-actions button{width:100%}.auth-card .auth-links{margin-top:16px;display:flex;justify-content:space-between;font-size:14px}.auth-brand{display:flex;align-items:center;gap:10px;margin-bottom:20px}.auth-brand .badge{width:26px;height:26px;border-radius:5px;background:var(--color-primary);display:inline-block}.auth-brand .name{font-weight:700;letter-spacing:.4px;font-size:15px;color:var(--color-text)}
