: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}.modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal-card{background:var(--color-surface);border-radius:var(--radius);padding:24px;width:100%;box-shadow:0 8px 32px #0003}.notif-center{position:fixed;right:20px;bottom:20px;width:340px;max-width:calc(100vw - 40px);background:var(--color-surface);border-radius:12px;box-shadow:0 10px 32px #0000002e;border:1px solid var(--color-border);z-index:1500;overflow:hidden}.notif-center.pulse{animation:notif-pulse 1.2s ease-out 2}@keyframes notif-pulse{0%{box-shadow:0 10px 32px #0000002e,0 0 #e2231a8c}50%{box-shadow:0 10px 32px #0000002e,0 0 0 12px #e2231a00}to{box-shadow:0 10px 32px #0000002e,0 0 #e2231a00}}.notif-header{display:flex;justify-content:space-between;align-items:center;background:var(--color-primary);color:#fff;padding:10px 12px;font-weight:600;font-size:14px}.notif-header button.ghost{background:transparent;color:#fff;border:none;padding:2px 8px;cursor:pointer;font-size:16px;border-radius:4px}.notif-header button.ghost:hover{background:#ffffff2e}.notif-list{max-height:320px;overflow-y:auto}.notif-item{display:flex;justify-content:space-between;align-items:center;padding:12px;border-bottom:1px solid var(--color-border);gap:10px}.notif-item:last-child{border-bottom:none}.notif-title{font-size:13px;font-weight:600;margin-bottom:2px}.notif-text{font-size:12px;color:var(--color-text-muted)}.notif-actions{display:flex;gap:4px;flex-shrink:0}.notif-actions button{padding:6px 10px;font-size:12px}.notif-actions button.ghost{background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border)}.notif-pill{position:fixed;right:20px;bottom:20px;background:var(--color-primary);color:#fff;border:none;border-radius:999px;padding:10px 16px;font-weight:600;box-shadow:0 4px 14px #0003;cursor:pointer;z-index:1500}.notif-pill.pulse{animation:notif-pulse 1.2s ease-out infinite}.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)}@keyframes pulse-orange{0%,to{opacity:1;box-shadow:0 0 #d47f0066}50%{opacity:.85;box-shadow:0 0 0 4px #d47f0000}}.status-pill{display:inline-flex;align-items:center;gap:4px;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:#e3f0ff;color:#1c4fa6}.status-pill.checked_in{background:#fff3e0;color:#d47f00;animation:pulse-orange 2s ease-in-out infinite}.status-pill.checked_out{background:#def7e6;color:#14622e}.status-pill.rejected,.status-pill.expired{background:#fdecea;color:#a8201a}.status-pill.cancelled{background:#ececef;color:#5a5a5a}.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}.info-grid{display:grid;grid-template-columns:160px 1fr;row-gap:7px;font-size:14px;align-items:start}.info-grid .ig-label{color:var(--color-text-muted);padding-top:1px}.visit-calendar{max-width:280px;-webkit-user-select:none;user-select:none}.vc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.vc-title{font-size:14px;font-weight:600}.vc-nav{background:transparent;border:1px solid var(--color-border);border-radius:6px;padding:2px 10px;font-size:16px;line-height:1.4;cursor:pointer;color:var(--color-text)}.vc-nav:hover{background:#f3f3f5}.vc-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;text-align:center}.vc-dow{font-size:11px;font-weight:600;color:var(--color-text-muted);padding:4px 0}.vc-day{font-size:13px;padding:5px 0;border-radius:6px;cursor:default}.vc-day.vc-today{outline:2px solid var(--color-primary);outline-offset:-2px;font-weight:600}.vc-day.vc-visit{background:var(--color-primary);color:#fff;font-weight:700;border-radius:50%}.vc-day.vc-visit.vc-today{background:var(--color-primary);outline:2px solid #000;outline-offset:-2px}.scan-error-box{display:flex;flex-direction:column;align-items:center;gap:12px;padding:32px 24px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);text-align:center;max-width:480px;margin:0 auto}.scan-error-icon{width:64px;height:64px;border-radius:50%;background:#fdecea;display:flex;align-items:center;justify-content:center;font-size:32px;color:var(--color-danger)}.scan-error-icon.warn{background:#fff4d6;color:#8a6d00}.scan-error-icon.success{background:#def7e6;color:#14622e}.scan-error-msg{font-size:15px;font-weight:600;color:var(--color-text);line-height:1.4}.scan-error-sub{font-size:13px;color:var(--color-text-muted)}.recurring-locked{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#f3f3f5;border:1px dashed var(--color-border);border-radius:6px;color:var(--color-text-muted);font-size:14px;position:relative}.recurring-locked input[type=checkbox]{width:auto;margin-left:auto;transform:scale(1.1);cursor:not-allowed;opacity:.5}.help-icon{display:inline-flex;width:18px;height:18px;border-radius:50%;background:var(--color-text-muted);color:#fff;font-size:11px;font-weight:700;align-items:center;justify-content:center;cursor:help;position:relative;-webkit-user-select:none;user-select:none}.help-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:#1a1a1f;color:#fff;padding:8px 10px;border-radius:6px;font-size:12px;line-height:1.4;width:240px;box-shadow:0 4px 14px #0003;z-index:10;cursor:default;text-align:left;font-weight:400}.help-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#1a1a1f}.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}.combobox{position:relative;display:flex;align-items:stretch;width:100%}.combobox input{flex:1;padding-right:32px}.combobox-caret{position:absolute;right:4px;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--color-text-muted);font-size:14px;width:28px;height:28px;padding:0;cursor:pointer;border-radius:4px}.combobox-caret:hover{background:#0000000d;color:var(--color-text)}.combobox-pop{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:30;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 4px 16px #0000001a;max-height:220px;overflow-y:auto;padding:4px}.combobox-status{padding:8px 12px;color:var(--color-text-muted);font-size:13px}.combobox-status.muted{color:#999}.combobox-option{width:100%;text-align:left;background:transparent;color:var(--color-text);border:none;padding:8px 12px;border-radius:6px;font-size:14px;cursor:pointer}.combobox-option:hover,.combobox-option.active{background:var(--color-primary-light);color:var(--color-primary-dark)}.combobox-create{width:100%;text-align:left;background:var(--color-primary);color:#fff;border:none;padding:9px 12px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;margin-top:4px}.combobox-create:hover:not(:disabled){background:var(--color-primary-dark)}.combobox.disabled .combobox-caret{display:none}.wheel-col{display:flex;flex-direction:column;align-items:center;flex:1;min-width:70px}.wheel-label{font-size:11px;color:var(--color-text-muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.wheel{position:relative;height:144px;width:100%;overflow-y:scroll;scroll-snap-type:y mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;background:#fafafa;border-radius:8px;border:1px solid var(--color-border);mask-image:linear-gradient(to bottom,transparent 0%,black 25%,black 75%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,transparent 0%,black 25%,black 75%,transparent 100%)}.wheel::-webkit-scrollbar{display:none}.wheel-item{height:36px;line-height:36px;text-align:center;scroll-snap-align:center;font-size:16px;color:var(--color-text-muted);cursor:pointer;-webkit-user-select:none;user-select:none}.wheel-item.active{color:var(--color-text);font-weight:700}.wheel-spacer{height:54px;scroll-snap-align:none}.wheel-col{position:relative}.wheel-frame{position:absolute;pointer-events:none;left:4px;right:4px;top:69px;height:36px;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);background:#e2231a0d}.dtp{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:14px}.dtp-row{display:flex;gap:10px;margin-bottom:12px}.dtp-toggle{display:flex;align-items:center;gap:8px;padding:8px 0;font-size:14px;color:var(--color-text);cursor:pointer;margin-bottom:8px}.dtp-toggle input[type=checkbox]{width:auto;margin:0;transform:scale(1.1)}.dtp-summary{margin:6px 0 0;font-size:14px;color:var(--color-text);background:var(--color-primary-light);border-radius:6px;padding:8px 12px}.rec-edit{background:#fafafa;border:1px solid var(--color-border);border-radius:8px;padding:14px;margin-top:8px}.rec-help{font-size:13px;color:var(--color-text-muted);margin:0 0 10px}.rec-kinds,.rec-mode{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}.rec-mode{background:#fff;padding:10px;border-radius:6px;border:1px solid var(--color-border)}.rec-mode-title{font-size:12px;color:var(--color-text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.rec-radio{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--color-border);border-radius:6px;cursor:pointer;font-size:14px;background:#fff}.rec-radio.sel{background:var(--color-primary-light);border-color:var(--color-primary)}.rec-radio input{width:auto;margin:0}.rec-hint{font-size:12px;color:var(--color-text-muted);margin:6px 0 0}.rec-cal-nav{display:flex;justify-content:space-between;align-items:center;font-weight:600;margin-bottom:8px}.cal-month-name{display:none}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;-webkit-user-select:none;user-select:none}.cal-dow{text-align:center;font-size:11px;color:var(--color-text-muted);text-transform:uppercase;padding:4px 0;font-weight:600}.cal-day{aspect-ratio:1 / 1;background:#fff;border:1px solid var(--color-border);border-radius:6px;cursor:pointer;font-size:13px;color:var(--color-text);padding:0}.cal-day:hover{background:#f0f0f3}.cal-day.sel{background:var(--color-primary);color:#fff;border-color:var(--color-primary);font-weight:600}.share-overlay{position:fixed;inset:0;background:#00000080;z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}.share-modal{background:var(--color-surface);border-radius:12px;padding:24px;width:100%;max-width:440px;box-shadow:0 8px 32px #0000002e}.share-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.share-header h2{font-size:18px;margin:0}.share-close{background:transparent;border:none;font-size:24px;color:var(--color-text-muted);cursor:pointer;padding:0 6px;line-height:1}.share-close:hover{color:var(--color-text);background:#0000000d}.share-sub{margin:0 0 16px;color:var(--color-text-muted);font-size:13px}.share-icons{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}.share-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:12px 6px;background:#fafafa;border:1px solid var(--color-border);border-radius:10px;text-decoration:none;color:var(--color-text);font-size:12px;cursor:pointer;transition:transform .06s,background .15s}.share-btn:hover{background:#f0f0f3;transform:translateY(-1px)}.share-glyph{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;background:#fff;border:1px solid var(--color-border)}.share-whatsapp .share-glyph{background:#25d366;color:#fff;border-color:#25d366}.share-email .share-glyph{background:#4285f4;color:#fff;border-color:#4285f4}.share-telegram .share-glyph{background:#229ed9;color:#fff;border-color:#229ed9}.share-x .share-glyph{background:#000;color:#fff;border-color:#000;font-weight:800}.share-facebook .share-glyph{background:#1877f2;color:#fff;border-color:#1877f2;font-weight:800}.share-native .share-glyph{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.share-label{font-weight:500}.share-url{display:flex;gap:6px}.share-url input{flex:1;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;color:var(--color-text);background:#fafafa}.share-url button{white-space:nowrap}.share-url button.copied{background:var(--color-success)}#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)}
