: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}.pn-stack{position:fixed;right:20px;bottom:20px;display:flex;flex-direction:column;gap:10px;z-index:1400;max-width:calc(100vw - 40px);align-items:flex-end}.pn-pill-wrap{position:fixed;right:20px;bottom:20px;z-index:1400}.pn-chevron{position:absolute;width:28px;height:22px;display:inline-flex;align-items:center;justify-content:center;background:#fff;color:#94a3b8;border:1px solid rgba(15,23,42,.08);border-radius:999px;cursor:pointer;box-shadow:0 4px 10px -4px #0f172a2e,0 2px 4px -2px #0f172a0f;transition:color .18s ease,background .18s ease,transform .18s ease,border-color .18s ease;padding:0;z-index:2}.pn-chevron:hover{color:#1e293b;background:#f8fafc;border-color:#0f172a29}.pn-chevron:focus-visible{outline:2px solid #6366f1;outline-offset:2px}.pn-chevron--bottom{right:16px;bottom:-11px}.pn-chevron--bottom:hover{transform:translateY(1px)}.pn-chevron--top{right:16px;top:-11px}.pn-chevron--top:hover{transform:translateY(-1px)}.pn-card{width:320px;background:#fff;border:1px solid rgba(15,23,42,.06);border-radius:14px;box-shadow:0 10px 30px -12px #0f172a2e,0 4px 10px -4px #0f172a0f;cursor:pointer;overflow:hidden;position:relative;-webkit-user-select:none;user-select:none;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.pn-card:hover{transform:translateY(-2px);box-shadow:0 18px 40px -14px #0f172a38,0 6px 14px -6px #0f172a14;border-color:#0f172a1a}.pn-card:focus-visible{outline:2px solid #6366f1;outline-offset:2px}.pn-accent{position:absolute;top:0;left:0;bottom:0;width:4px}.pn-card--onsite .pn-accent{background:linear-gradient(180deg,#f59e0b,#d97706)}.pn-card--pending .pn-accent{background:linear-gradient(180deg,#f97316,#ea580c)}.pn-card-content{padding:14px 16px 12px 18px;display:flex;flex-direction:column;gap:4px}.pn-badge{display:inline-flex;align-items:center;gap:7px;align-self:flex-start;padding:4px 9px 4px 7px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;margin-bottom:6px}.pn-card--onsite .pn-badge{background:#fef3c7;color:#92400e}.pn-card--pending .pn-badge{background:#ffedd5;color:#9a3412}.pn-badge-dot{width:7px;height:7px;border-radius:50%;flex:0 0 auto;animation:pn-pulse 1.6s ease-in-out infinite}.pn-card--onsite .pn-badge-dot{background:#f59e0b;box-shadow:0 0 #f59e0b80}.pn-card--pending .pn-badge-dot{background:#f97316;box-shadow:0 0 #f9731680}@keyframes pn-pulse{0%{box-shadow:0 0 0 0 currentColor;opacity:1}70%{box-shadow:0 0 0 6px transparent;opacity:.7}to{box-shadow:0 0 0 0 transparent;opacity:1}}.pn-card--onsite .pn-badge-dot{animation-name:pn-pulse-amber}.pn-card--pending .pn-badge-dot{animation-name:pn-pulse-orange}@keyframes pn-pulse-amber{0%,to{box-shadow:0 0 #f59e0b8c}70%{box-shadow:0 0 0 6px #f59e0b00}}@keyframes pn-pulse-orange{0%,to{box-shadow:0 0 #f973168c}70%{box-shadow:0 0 0 6px #f9731600}}.pn-primary{font-size:15px;font-weight:650;color:#0f172a;line-height:1.3;word-break:break-word}.pn-secondary{font-size:13px;color:#64748b;line-height:1.4;word-break:break-word}.pn-action{display:inline-flex;align-items:center;gap:4px;margin-top:8px;font-size:12px;font-weight:600;letter-spacing:.1px;transition:gap .18s ease}.pn-card--onsite .pn-action{color:#b45309}.pn-card--pending .pn-action{color:#c2410c}.pn-card:hover .pn-action{gap:7px}.pn-pill{position:relative;display:inline-flex;align-items:center;gap:10px;padding:10px 16px 10px 14px;background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:999px;box-shadow:0 10px 30px -12px #0f172a2e,0 4px 10px -4px #0f172a0f;cursor:pointer;font-size:13px;color:#334155;transition:transform .18s ease,box-shadow .18s ease;max-width:calc(100vw - 40px)}.pn-pill:hover{transform:translateY(-1px);box-shadow:0 18px 40px -14px #0f172a38,0 6px 14px -6px #0f172a14}.pn-pill:focus-visible{outline:2px solid #6366f1;outline-offset:2px}.pn-pill-dots{display:inline-flex;gap:4px;align-items:center}.pn-dot{display:inline-block;width:8px;height:8px;border-radius:50%}.pn-dot--onsite{background:#f59e0b;animation:pn-pulse-amber 1.6s ease-in-out infinite}.pn-dot--pending{background:#f97316;animation:pn-pulse-orange 1.6s ease-in-out infinite}.pn-pill-text{display:inline-flex;gap:6px;align-items:baseline}.pn-pill-text strong{color:#0f172a;font-weight:700}.pn-pill-sep{color:#cbd5e1}@media(prefers-reduced-motion:reduce){.pn-badge-dot,.pn-dot--onsite,.pn-dot--pending{animation:none}.pn-card,.pn-pill,.pn-minimize{transition:none}}@media(max-width:480px){.pn-card{width:calc(100vw - 40px)}}.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)}.email-lang-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px;flex-wrap:wrap}.lang-toggle-btn{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;background:#fff;color:#444;border:1px solid var(--color-border, #d8d8d8);border-radius:999px;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease}.lang-toggle-btn:hover{background:#f7f7f7;border-color:#b8b8b8}.lang-toggle-btn.on{background:#1f6feb;color:#fff;border-color:#1f6feb}.lang-toggle-btn.on:hover{background:#185acc;border-color:#185acc}.lang-toggle-flag{font-size:14px;line-height:1}.lang-toggle-check{font-weight:700}.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)}@media(max-width:600px){.attendee-row{grid-template-columns:1fr 36px;grid-template-areas:"name name" "ine  remove"}.attendee-row>input{grid-area:name}.attendee-row .id-photo-input{grid-area:ine}.attendee-row .remove{grid-area:remove;align-self:start}}@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.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.checked_out:before{content:"✓ ";font-weight:800}.status-pill.rejected{background:#fdecea;color:#a8201a}.status-pill.rejected:before{content:"✗ ";font-weight:800}.status-pill.expired{background:#fdecea;color:#a8201a}.status-pill.expired:before{content:"✗ ";font-weight:800}.status-pill.cancelled{background:#ececef;color:#5a5a5a}.status-pill.cancelled:before{content:"⊘ ";font-weight:800}.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}.ine-badge{display:inline-flex;align-items:center;justify-content:center;min-width:44px;padding:3px 8px;border-radius:4px;font-size:11px;font-weight:700;letter-spacing:.5px;white-space:nowrap;flex-shrink:0}.ine-badge--has-photo{background:#e8f4fd;color:#1a73e8;border:1px solid #b3d4f5;cursor:pointer;transition:background .15s}.ine-badge--has-photo:hover{background:#c8e3fa}.ine-badge--empty{background:#f3f3f5;color:#bbb;border:1px dashed var(--color-border);cursor:default}.attendee-readlist{list-style:none;padding:0;margin:0}.attendee-readlist li{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid #f0f0f3}.attendee-readlist li:last-child{border-bottom:none}.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}.id-photo-input{position:relative;display:inline-block;min-width:180px}.id-photo-btn{width:100%;background:#fafafa;color:var(--color-text-muted);border:1px dashed var(--color-border);padding:9px 12px;font-size:13px;border-radius:6px;text-align:center;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.id-photo-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary);background:#fff}.id-photo-btn:disabled{opacity:.6;cursor:not-allowed}.id-photo-input.has-photo{width:56px;height:56px;border-radius:6px;overflow:hidden;border:1px solid var(--color-border);background:#f3f3f5}.id-photo-thumb{width:100%;height:100%;object-fit:cover;display:block}.id-photo-remove{position:absolute;top:-8px;right:-8px;width:22px;height:22px;padding:0;border-radius:50%;background:var(--color-danger);color:#fff;border:2px solid #fff;font-size:13px;line-height:1;cursor:pointer;box-shadow:0 1px 3px #00000026}.id-photo-remove:hover{background:#8b1e16}.id-photo-error{color:var(--color-danger);font-size:12px;margin-top:4px}.lang-switcher{position:absolute;top:12px;right:12px;display:inline-flex;align-items:center;gap:6px;padding:4px 9px;background:#fff;border:1px solid var(--color-border, #d8d8d8);border-radius:8px;cursor:pointer;box-shadow:0 2px 6px #0000000f;transition:transform .15s ease,box-shadow .15s ease,background .15s ease;z-index:5;line-height:1}.lang-switcher:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000001a;background:#fafafa}.lang-switcher:focus-visible{outline:2px solid var(--color-primary, #e2231a);outline-offset:2px}.lang-flag{display:inline-block;border-radius:3px;overflow:hidden;box-shadow:0 0 0 1px #0000001a;line-height:0}.lang-code{font-size:12px;font-weight:700;letter-spacing:.5px;color:#222}.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 10px;color:var(--color-text-muted);font-size:13px}.share-email-sent{background:#d4edda;color:#155724;border:1px solid #c3e6cb;border-radius:6px;padding:10px 14px;font-size:13px;margin-bottom:10px}.share-expiry-notice{background:#fff4d6;color:#6b5300;border:1px solid #f0d97a;border-radius:8px;padding:10px 12px;font-size:13px;line-height:1.4;margin-bottom:16px}.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)}.settings-section{margin-top:28px}.settings-section h2{margin:0 0 4px;font-size:18px;color:var(--color-text)}.settings-subtitle{margin:0 0 12px;font-size:13px;color:var(--color-text-muted);line-height:1.45;max-width:700px}.settings-card{background:var(--color-surface);padding:20px;border-radius:var(--radius);border:1px solid var(--color-border);max-width:720px}.settings-field{margin-bottom:16px}.settings-help{font-size:12px;color:var(--color-text-muted);margin-top:4px;line-height:1.45}.settings-empty{color:var(--color-text-muted);font-size:13px;font-style:italic;margin:0 0 10px}.toggle-row{display:flex;gap:12px;align-items:flex-start;cursor:pointer;padding:4px 0}.toggle-row input[type=checkbox]{margin-top:3px;width:18px;height:18px;accent-color:var(--color-primary);flex-shrink:0}.master-list{list-style:none;padding:0;margin:0 0 14px;display:flex;flex-direction:column;gap:6px}.master-list li{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#fafafa;border:1px solid var(--color-border);border-radius:8px;font-size:14px}.master-email{font-weight:500;color:var(--color-text);word-break:break-all}.master-add{display:flex;gap:8px;align-items:stretch;flex-wrap:wrap}.master-add input{flex:1 1 220px;min-width:0}.catalog-block{margin-bottom:22px}.catalog-block:last-child{margin-bottom:0}.catalog-block h3{margin:0 0 8px;font-size:15px;color:var(--color-text)}.catalog-list{list-style:none;padding:0;margin:0 0 10px;display:flex;flex-wrap:wrap;gap:6px}.catalog-list li{display:inline-flex;align-items:center;gap:6px;padding:5px 6px 5px 12px;background:#f3f4f6;border:1px solid var(--color-border);border-radius:999px;font-size:13px;color:var(--color-text)}.catalog-list li .ghost{background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;padding:2px 6px;border-radius:50%;font-size:14px;line-height:1}.catalog-list li .ghost:hover{background:#e5e7eb;color:var(--color-danger)}.catalog-add{display:flex;gap:8px;align-items:stretch;flex-wrap:wrap}.catalog-add input{flex:1 1 240px;min-width:0}@media(max-width:600px){.settings-card{padding:16px}.master-add,.catalog-add{flex-direction:column;align-items:stretch}.master-add button,.catalog-add button{width:100%}}#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)}
