:root{--bg:#f8fafc;--surface:rgba(255,255,255,0.92);--ink:#0f172a;--muted:#64748b;--brand:#1a56db;--brand-strong:#1e3a5f;--brand-light:#dbeafe;--accent:#0ea5e9;--accent-strong:#0369a1;--border:rgba(15,23,42,0.08);--shadow:0 4px 24px rgba(15,23,42,0.06);--shadow-lg:0 20px 60px rgba(15,23,42,0.08);color-scheme:light}*{box-sizing:border-box}body,html{margin:0;min-height:100%;font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{min-height:100vh}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.shell{width:min(1200px,calc(100% - 32px));margin:0 auto}.card{background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow)}.tab-bar{display:flex;gap:4px;background:#f1f5f9;padding:4px;border-radius:12px}.tab-button{padding:10px 20px;border-radius:8px;border:none;background:transparent;color:var(--muted);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .15s ease}.tab-button:hover{color:var(--ink);background:rgba(255,255,255,.6)}.tab-button[data-active=true]{background:#fff;color:var(--brand);box-shadow:0 1px 3px rgba(15,23,42,.08)}.tab-button:disabled{cursor:not-allowed;opacity:.45}.metric-grid{display:grid;grid-gap:12px;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.muted{color:var(--muted)}.status-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;background:#f1f5f9;border:1px solid var(--border);font-size:.85rem}.dashboard-page{padding:24px 0 56px}.dashboard-card,.dashboard-shell{display:grid;grid-gap:16px;gap:16px}.dashboard-card{padding:24px}.dashboard-hero-card{gap:20px}.dashboard-hero-row,.dashboard-section-header,.security-guide-header{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}.dashboard-hero-copy,.dashboard-section-copy{display:grid;grid-gap:4px;gap:4px}.dashboard-kicker{color:var(--brand);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:.75rem}.dashboard-title{margin:0;font-size:clamp(1.5rem,3vw,2rem);font-weight:700;letter-spacing:-.02em}.dashboard-subtitle{margin:0;max-width:760px;font-size:.9rem}.dashboard-section-title{margin:0;font-size:clamp(1.1rem,3vw,1.4rem);font-weight:700}.dashboard-metric-card{padding:16px;border-radius:12px;background:#f8fafc;border:1px solid var(--border)}.dashboard-metric-card-soft{background:#fff}.dashboard-field{display:grid;grid-gap:6px;gap:6px}.dashboard-field-compact{max-width:420px}.dashboard-field-inline{min-width:260px}.dashboard-accent-button,.dashboard-ghost-button,.dashboard-input,.dashboard-primary-button,.dashboard-secondary-button,.dashboard-select,.dashboard-textarea{min-height:44px;border-radius:10px;font-weight:600;font-size:.875rem}.dashboard-select{width:100%;padding:10px 14px;border:1px solid var(--border);background:#fff}.dashboard-input,.dashboard-textarea{width:100%;padding:10px 14px;border-radius:10px;border:1px solid var(--border);background:#fff}.dashboard-textarea{min-height:100px;resize:vertical}.dashboard-accent-button,.dashboard-ghost-button,.dashboard-secondary-button{padding:10px 16px;border:1px solid var(--border);background:#fff;color:var(--ink);cursor:pointer;transition:all .15s ease}.dashboard-accent-button:hover,.dashboard-ghost-button:hover,.dashboard-secondary-button:hover{background:#f1f5f9}.dashboard-ghost-button{align-self:start}.dashboard-primary-button{padding:10px 16px;border:0;background:var(--brand);color:#fff;cursor:pointer;transition:all .15s ease}.dashboard-primary-button:hover{background:#1e40af}.dashboard-secondary-button{background:#fff}.dashboard-accent-button{background:var(--brand-light);color:var(--brand-strong);border-color:rgba(26,86,219,.15)}.dashboard-accent-button:disabled,.dashboard-ghost-button:disabled,.dashboard-primary-button:disabled,.dashboard-secondary-button:disabled{cursor:not-allowed;opacity:.5}.dashboard-pill-row{display:flex;gap:8px;flex-wrap:wrap}.panel-action-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));grid-gap:10px;gap:10px}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#94a3b8 #e2e8f0;padding-bottom:2px}.table-scroll-hint{display:none}.table-scroll::-webkit-scrollbar{height:10px}.table-scroll::-webkit-scrollbar-track{background:#e2e8f0;border-radius:999px}.table-scroll::-webkit-scrollbar-thumb{background:#94a3b8;border-radius:999px}.table-scroll::-webkit-scrollbar-thumb:hover{background:#64748b}.field-required{color:#dc2626;font-weight:700}.field-error{color:#b91c1c;font-size:.78rem}.field-help-inline{color:var(--muted);font-size:.78rem}.field-label-with-tooltip{display:inline-flex;align-items:center;gap:6px}.field-tooltip-wrap{position:relative;display:inline-flex;align-items:center}.field-tooltip-trigger{width:20px;height:20px;border-radius:999px;border:1px solid rgba(148,163,184,.6);background:#fff;color:var(--muted);display:inline-flex;align-items:center;justify-content:center;cursor:help}.field-tooltip-content{position:absolute;left:50%;bottom:calc(100% + 10px);transform:translateX(-50%);width:min(280px,calc(100vw - 48px));padding:10px;border-radius:10px;border:1px solid rgba(148,163,184,.4);background:#0f172a;color:#f8fafc;font-size:.75rem;font-weight:500;line-height:1.45;box-shadow:0 14px 28px rgba(2,6,23,.38);pointer-events:none;opacity:0;visibility:hidden;transition:opacity .14s ease;z-index:20}.field-tooltip-wrap:focus-within .field-tooltip-content,.field-tooltip-wrap:hover .field-tooltip-content{opacity:1;visibility:visible}.modal-backdrop{position:fixed;inset:0;z-index:130;display:grid;place-items:center;padding:16px;background:rgba(15,23,42,.45);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-card{width:min(840px,calc(100vw - 32px));max-height:calc(100vh - 32px);overflow:auto;display:grid;grid-gap:16px;gap:16px;padding:20px}.modal-card-large{width:min(980px,calc(100vw - 32px))}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.modal-title-block{display:grid;grid-gap:4px;gap:4px}.modal-title-block h3{margin:0;font-size:1.15rem}.modal-form,.modal-grid{display:grid;grid-gap:12px;gap:12px}.modal-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.modal-footer{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.global-loading-overlay{position:fixed;inset:0;z-index:200;display:grid;place-items:center;background:rgba(15,23,42,.18);-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.global-loading-card{display:inline-flex;align-items:center;gap:10px;padding:12px 16px;border-radius:10px;background:#ffffff;border:1px solid var(--border);box-shadow:var(--shadow-lg);color:var(--ink);font-weight:600;font-size:.9rem}.global-loading-spinner{width:16px;height:16px;border-radius:999px;border:2px solid #bfdbfe;border-top:2px solid var(--brand);animation:loading-spin .85s linear infinite}@keyframes loading-spin{to{transform:rotate(1turn)}}.ajustes-panel-shell{gap:14px}.ajustes-filters-grid{display:grid;grid-gap:12px;gap:12px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.ajustes-table{width:100%;border-collapse:collapse;min-width:980px}.ajuste-decision-box{display:grid;grid-gap:10px;gap:10px}.dashboard-alert{padding:12px 16px;border-radius:10px;font-size:.875rem}.dashboard-alert-success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.dashboard-alert-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.dashboard-alert-warning{background:#fffbeb;color:#92400e;border:1px solid #fde68a}.dashboard-alert-floating{position:static;right:auto;bottom:auto;z-index:auto;width:100%;box-shadow:none;margin-top:4px}.panel-surface{display:grid;grid-gap:14px;gap:14px;padding:16px;border-radius:12px;background:#f8fafc;border:1px solid var(--border)}.employee-management-layout{gap:20px}.employee-filters-grid,.employee-form-grid{display:grid;grid-gap:12px;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.employee-form-actions{display:flex;align-items:flex-end}.employee-row-actions{display:flex;gap:8px;flex-wrap:wrap}.employee-mirror-card,.employee-schedule-card{display:grid;grid-gap:12px;gap:12px;padding:14px;border-radius:12px;border:1px solid var(--border);background:#f8fafc}.employee-mirror-header,.employee-schedule-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.employee-schedule-grid{display:grid;grid-gap:10px;gap:10px;grid-template-columns:1fr}.employee-schedule-day{display:grid;grid-gap:8px;gap:8px;padding:10px;border-radius:10px;background:#fff;border:1px solid rgba(148,163,184,.25)}.employee-day-toggle{margin:0}.employee-day-turnos{display:grid;grid-gap:8px;gap:8px}.employee-turno-row{display:grid;grid-gap:6px;gap:6px;align-items:center;grid-template-columns:58px 1fr auto 1fr}.employee-turno-row .dashboard-input{min-width:0}.employee-turno-separator{color:var(--muted);font-size:.78rem}.employee-second-turno-toggle{padding-top:2px;border-top:1px dashed rgba(148,163,184,.35)}.dashboard-overview-card .metric-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.dashboard-metric-card-compact{display:grid;grid-gap:4px;gap:4px}.dashboard-metric-label{color:var(--muted);font-size:.78rem;font-weight:700}.dashboard-metric-value{font-weight:700;font-size:.95rem}.dashboard-metric-meta{color:var(--muted);font-size:.8rem}.dashboard-mobile-nav{display:none}.dashboard-mobile-tab{border:1px solid rgba(148,163,184,.35);background:#fff;color:#334155;border-radius:999px;min-height:34px;padding:6px 12px;font-size:.78rem;font-weight:700;cursor:pointer}.dashboard-mobile-tab[data-active=true]{background:var(--brand);border-color:var(--brand);color:#fff}.dashboard-mobile-tab:disabled{opacity:.45;cursor:not-allowed}.employee-mirror-tabs{display:inline-flex;border-radius:10px;background:#e2e8f0;padding:3px;gap:3px}.employee-mirror-tab{border:none;border-radius:8px;padding:7px 10px;background:transparent;color:#334155;font-size:.8rem;font-weight:600;cursor:pointer}.employee-mirror-tab[data-active=true]{background:#fff;color:#0f172a;box-shadow:0 1px 2px rgba(15,23,42,.15)}.employee-mirror-location{display:grid;grid-gap:2px;gap:2px}.table-icon-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.table-icon-button{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--ink);cursor:pointer;transition:all .14s ease}.table-icon-button:hover{transform:translateY(-1px);background:#f1f5f9}.table-icon-button:disabled{opacity:.45;cursor:not-allowed;transform:none}.table-actions-legend{display:flex;flex-wrap:wrap;gap:12px;align-items:center;color:var(--muted);font-size:.82rem}.table-actions-legend span{display:inline-flex;align-items:center;gap:6px}.dashboard-link-button,.dashboard-link-inline{color:#1d4ed8;text-decoration:underline;font-weight:600}.dashboard-link-button{border:none;background:transparent;padding:0;cursor:pointer}.dashboard-link-button:hover{color:#1e3a8a}.dashboard-link-button:focus-visible{outline:2px solid rgba(59,130,246,.5);outline-offset:3px;border-radius:6px}.employee-status-badge{display:inline-flex;align-items:center;justify-content:center;min-width:80px;padding:6px 12px;border-radius:999px;font-size:.8rem;font-weight:600}.employee-status-badge[data-active=true]{background:#f0fdf4;color:#166534}.employee-status-badge[data-active=false]{background:#fef2f2;color:#991b1b}.employee-status-badge[data-status=FERIAS]{background:#ffedd5;color:#9a3412}.employee-status-badge[data-status=ATESTADO]{background:#fffbeb;color:#92400e}.employee-status-badge[data-status=INATIVO]{background:#fef2f2;color:#991b1b}.force-password-backdrop{position:fixed;inset:0;z-index:120;display:grid;place-items:center;padding:16px;background:rgba(15,23,42,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.force-password-card{width:min(480px,100%);display:grid;grid-gap:16px;gap:16px;padding:24px;max-height:calc(100vh - 32px);overflow:auto}.force-password-form{display:grid;grid-gap:14px;gap:14px}.force-password-rules{display:grid;grid-gap:4px;gap:4px;font-size:.85rem}.force-password-rules span{padding-left:18px;position:relative}.force-password-rules span:before{content:"•";position:absolute;left:6px;top:0;color:var(--muted)}.force-password-rules span[data-valid=true]{color:#166534}.force-password-rules span[data-valid=true]:before{color:#16a34a}.security-panel-shell{gap:20px}.security-guide-panel{gap:16px}.security-guide-text{margin:4px 0 0;max-width:62ch;font-size:.9rem}.security-guide-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.security-guide-actions-left{justify-content:flex-start}.security-checkbox-row{display:flex;gap:10px;align-items:center}.onboarding-spotlight{display:grid;grid-gap:14px;gap:14px;padding:16px;border-radius:12px;background:#fffbeb;border:1px solid #fde68a}.onboarding-spotlight-copy{display:grid;grid-gap:6px;gap:6px}.onboarding-spotlight-copy p{margin:0;color:#92400e;line-height:1.6;font-size:.9rem}.onboarding-spotlight-actions{display:flex;justify-content:flex-start}.onboarding-step-grid{display:grid;grid-gap:10px;gap:10px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.onboarding-step-card{display:grid;grid-template-columns:auto 1fr;grid-gap:12px;gap:12px;padding:14px;border-radius:12px;background:#fff;border:1px solid var(--border)}.onboarding-step-card[data-complete=true]{border-color:#bbf7d0;background:#f0fdf4}.onboarding-step-card strong{display:block;margin-bottom:4px;font-size:.9rem}.onboarding-step-card p{margin:0;color:var(--muted);line-height:1.5;font-size:.85rem}.onboarding-step-index{width:32px;height:32px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:var(--brand-light);color:var(--brand);font-weight:700;font-size:.85rem}.onboarding-modal-backdrop{position:fixed;inset:0;z-index:110;display:grid;place-items:center;padding:16px;background:rgba(15,23,42,.58);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.onboarding-modal-card{width:min(980px,calc(100vw - 32px));max-height:calc(100vh - 32px);overflow:auto;display:grid;grid-gap:14px;gap:14px;padding:20px}.onboarding-guidance-strip{display:grid;grid-gap:4px;gap:4px;padding:10px 12px;border-radius:10px;border:1px dashed rgba(2,132,199,.4);background:rgba(224,242,254,.7)}.onboarding-guidance-strip strong{color:#0c4a6e;font-size:.86rem}.onboarding-guidance-strip span{color:#334155;font-size:.82rem}.onboarding-camera-layout{display:grid;grid-gap:12px;gap:12px;grid-template-columns:minmax(300px,1.2fr) minmax(280px,1fr)}.onboarding-camera-preview{position:relative;border-radius:12px;overflow:hidden;border:1px solid var(--border);background:#0f172a;min-height:280px;display:grid;place-items:center}.onboarding-camera-preview video{width:100%;height:100%;min-height:280px;max-height:460px;object-fit:cover;transform:scaleX(-1)}.onboarding-modal-actions{display:flex;flex-wrap:wrap;gap:10px}.onboarding-camera-preview>span{position:absolute;padding:6px 10px;border-radius:999px;background:rgba(15,23,42,.7);color:#fff;font-size:.82rem}.onboarding-camera-overlay{position:absolute;inset:auto 12px 12px 12px;padding:12px;border-radius:12px;background:rgba(15,23,42,.75);color:#f8fafc;display:grid;grid-gap:4px;gap:4px}.onboarding-camera-overlay strong{font-size:.95rem;font-weight:700}.onboarding-camera-overlay span{font-size:2rem;line-height:1;font-weight:800;color:#facc15}.onboarding-camera-overlay small{font-size:.78rem;color:rgba(248,250,252,.8)}.onboarding-camera-overlay-idle{background:rgba(15,23,42,.52)}.onboarding-camera-preview[data-ready=false] video{opacity:.35}.onboarding-capture-list{display:grid;grid-gap:10px;gap:10px}.onboarding-capture-item{display:grid;grid-gap:8px;gap:8px;padding:10px;border-radius:10px;border:1px solid var(--border);background:#fff}.onboarding-capture-item[data-complete=true]{border-color:#bbf7d0;background:#f0fdf4}.onboarding-capture-meta{display:grid;grid-gap:4px;gap:4px}.onboarding-capture-meta strong{font-size:.9rem}.onboarding-capture-meta p{margin:0;color:var(--muted);font-size:.82rem;line-height:1.4}.onboarding-capture-thumb-wrap{display:grid;grid-gap:8px;gap:8px}.onboarding-capture-thumb{width:100%;max-height:150px;object-fit:cover;border-radius:8px;border:1px solid var(--border)}.onboarding-debug-card{display:grid;grid-gap:8px;gap:8px;border:1px solid rgba(148,163,184,.45);border-radius:10px;background:#f8fafc;padding:10px}.onboarding-debug-card strong{font-size:.84rem}.onboarding-debug-list{display:grid;grid-gap:4px;gap:4px;max-height:170px;overflow:auto;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace}.onboarding-debug-list span{font-size:.74rem;color:#334155;line-height:1.35}.auth-page{position:relative;min-height:100vh;display:grid;place-items:center;overflow:hidden;padding:24px 20px;background:linear-gradient(135deg,#0f172a,#1e3a5f 50%,#1a56db)}.auth-stage{position:relative;z-index:1;width:min(460px,100%)}.auth-hero{display:none}.auth-panel{position:relative;display:grid;grid-gap:24px;gap:24px;padding:32px;overflow:hidden;background:#fff;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.2)}.auth-panel:before{display:none}.auth-panel-header{position:relative;display:grid;grid-gap:8px;gap:8px;text-align:center}.auth-panel-tag{color:var(--brand);font-weight:600;letter-spacing:.06em;text-transform:uppercase;font-size:.75rem}.auth-panel-header h2{margin:0;font-size:1.5rem;font-weight:700;letter-spacing:-.02em}.auth-panel-header p{margin:0;color:var(--muted);line-height:1.5;font-size:.875rem}.auth-form{position:relative;display:grid;grid-gap:14px;gap:14px}.auth-field{display:grid;grid-gap:6px;gap:6px}.auth-field-label{font-size:.875rem;font-weight:600}.auth-field-help{color:var(--muted);line-height:1.4;font-size:.8rem}.auth-input{width:100%;padding:12px 14px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;transition:border-color .15s ease,box-shadow .15s ease}.auth-input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(26,86,219,.12)}.auth-error{padding:10px 14px;border-radius:10px;background:#fef2f2;color:#991b1b;border:1px solid #fecaca;font-size:.875rem}.auth-action-stack{display:grid;grid-gap:12px;gap:12px;margin-top:4px}.auth-primary-button,.auth-secondary-button{width:100%;padding:12px 18px;border-radius:10px;font-weight:600;cursor:pointer;transition:all .15s ease}.auth-primary-button{border:0;background:var(--brand);color:#fff}.auth-primary-button:hover{background:#1e40af}.auth-secondary-button{border:1px solid #e2e8f0;background:#fff;color:var(--ink)}.auth-secondary-button:hover{background:#f8fafc}.auth-primary-button:disabled,.auth-secondary-button:disabled{cursor:wait;opacity:.6}.auth-divider{position:relative;display:flex;justify-content:center;align-items:center}.auth-divider:before{content:"";position:absolute;inset-inline:0;top:50%;border-top:1px solid #e2e8f0}.auth-divider span{position:relative;z-index:1;padding:0 12px;background:#fff;color:var(--muted);font-size:.8rem}.auth-footnote,.auth-unavailable{color:var(--muted);line-height:1.5;font-size:.85rem}.auth-unavailable{padding:12px 14px;border-radius:10px;background:#f8fafc;border:1px dashed #e2e8f0}.auth-footnote{padding-top:0;font-size:.8rem}.auth-orb{position:absolute;border-radius:999px;filter:blur(80px);opacity:.4;pointer-events:none}.auth-orb-left{top:10%;left:-60px;width:400px;height:400px;background:#3b82f6}.auth-orb-right{right:-80px;bottom:10%;width:300px;height:300px;background:#0ea5e9}.pwa-install-card{position:fixed;right:16px;bottom:16px;z-index:80;width:min(320px,calc(100vw - 28px));display:grid;grid-gap:10px;gap:10px;padding:14px;border-radius:12px;border:1px solid var(--border);background:#fff;box-shadow:var(--shadow-lg)}.pwa-install-card[data-source=login]{background:linear-gradient(160deg,#fff7e8,#ffe8c2);border-color:rgba(194,120,3,.3)}.pwa-install-card[data-source=login] .pwa-install-kicker{color:#92400e}.pwa-install-card[data-source=login] .pwa-install-benefits span{background:rgba(194,120,3,.15);color:#7c2d12}.pwa-install-card[data-source=login] .pwa-install-secondary{background:#fff9ef;border-color:rgba(194,120,3,.28)}.pwa-install-copy{display:grid;grid-gap:4px;gap:4px}.pwa-install-kicker{color:var(--brand);font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.pwa-install-copy strong{font-size:.9rem}.pwa-install-copy p{margin:0;color:var(--muted);line-height:1.4;font-size:.8rem}.pwa-install-benefits{display:flex;gap:6px;flex-wrap:wrap}.pwa-install-benefits span{padding:4px 8px;border-radius:999px;background:var(--brand-light);color:var(--brand);font-size:.7rem;font-weight:600}.pwa-install-actions{display:flex;gap:8px;flex-wrap:wrap}.pwa-install-primary,.pwa-install-secondary{min-height:36px;padding:8px 14px;border-radius:8px;font-weight:600;font-size:.85rem;cursor:pointer}.pwa-install-primary{border:0;background:var(--brand);color:#fff}.pwa-install-secondary{border:1px solid var(--border);background:#fff;color:var(--ink)}.landing-nav{position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(255,255,255,.9);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.landing-nav-inner{display:flex;align-items:center;justify-content:space-between;height:64px}.landing-logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:1.1rem;color:var(--ink)}.landing-logo-icon{width:36px;height:36px;align-items:center;justify-content:center;border-radius:10px;font-weight:800;font-size:.9rem}.landing-logo-icon,.landing-nav-cta{display:inline-flex;background:var(--brand);color:#fff}.landing-nav-cta{padding:10px 20px;border-radius:8px;font-weight:600;font-size:.875rem;transition:background .15s ease}.landing-nav-cta:hover{background:#1e40af}.landing-hero{padding:120px 0 80px;background:linear-gradient(135deg,#0f172a,#1e3a5f 50%,#1a56db);color:#fff;text-align:center}.landing-hero-inner{display:grid;grid-gap:24px;gap:24px;max-width:720px;margin:0 auto}.landing-hero-badge{display:inline-flex;width:-moz-fit-content;width:fit-content;margin:0 auto;padding:6px 14px;border-radius:999px;background:rgba(255,255,255,.1);color:rgba(255,255,255,.8);font-size:.8rem;font-weight:600;letter-spacing:.04em}.landing-hero h1{margin:0;font-size:clamp(2.2rem,5vw,3.5rem);font-weight:800;line-height:1.1;letter-spacing:-.03em}.landing-hero p{margin:0;font-size:1.15rem;line-height:1.6;color:rgba(255,255,255,.7);max-width:560px;margin-inline:auto}.landing-hero-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:8px}.landing-hero-primary{display:inline-flex;padding:14px 28px;border-radius:10px;border:0;background:#fff;color:var(--brand);font-weight:700;font-size:1rem;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.landing-hero-primary:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(0,0,0,.15)}.landing-hero-secondary{display:inline-flex;padding:14px 28px;border-radius:10px;border:1px solid rgba(255,255,255,.2);color:#fff;font-weight:600;font-size:1rem;transition:background .15s ease}.landing-hero-secondary:hover,.landing-stats{background:rgba(255,255,255,.1)}.landing-stats{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:1px;gap:1px;border-radius:16px;overflow:hidden;margin-top:16px}.landing-stat{padding:24px 16px;text-align:center;background:rgba(255,255,255,.05)}.landing-stat strong{display:block;font-size:1.75rem;font-weight:800}.landing-stat span{display:block;margin-top:4px;font-size:.85rem;color:rgba(255,255,255,.6)}.landing-section{padding:80px 0}.landing-section-alt{background:#fff}.landing-section-header{text-align:center;max-width:600px;margin:0 auto 48px}.landing-section-header h2{margin:0 0 12px;font-size:clamp(1.6rem,3.5vw,2.2rem);font-weight:800;letter-spacing:-.02em}.landing-section-header p{margin:0;color:var(--muted);font-size:1.05rem;line-height:1.6}.landing-features-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:20px;gap:20px}.landing-feature-card{padding:28px 24px;border-radius:14px;background:#fff;border:1px solid var(--border);transition:box-shadow .2s ease,transform .2s ease}.landing-feature-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.landing-feature-icon{width:48px;height:48px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:var(--brand-light);color:var(--brand);font-size:1.4rem;margin-bottom:16px}.landing-feature-card h3{margin:0 0 8px;font-size:1.1rem;font-weight:700}.landing-feature-card p{margin:0;color:var(--muted);line-height:1.6;font-size:.9rem}.landing-steps{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:32px;gap:32px;counter-reset:step}.landing-step{text-align:center;counter-increment:step}.landing-step:before{content:counter(step);display:inline-flex;width:48px;height:48px;align-items:center;justify-content:center;border-radius:999px;background:var(--brand);color:#fff;font-weight:800;font-size:1.2rem;margin-bottom:16px}.landing-step h3{margin:0 0 8px;font-size:1.1rem;font-weight:700}.landing-step p{margin:0;color:var(--muted);line-height:1.5;font-size:.9rem}.landing-plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));grid-gap:18px;gap:18px}.landing-plans-carousel-controls{display:none}.landing-carousel-button{min-height:38px;padding:0 12px;border-radius:10px;border:1px solid rgba(15,23,42,.2);background:#fff;color:#0f172a;font-weight:700;font-size:.82rem;cursor:pointer;transition:all .16s ease}.landing-carousel-button:hover{background:#f8fafc;transform:translateY(-1px)}@media (min-width:1024px){.landing-plans-carousel-controls{display:flex;justify-content:flex-end;gap:8px;margin-bottom:10px}.landing-plans-carousel{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding-bottom:4px}.landing-plans-carousel::-webkit-scrollbar{display:none}.landing-plans-carousel .landing-plan-card{flex-grow:0;flex-shrink:0;flex-basis:calc((100% - 36px) / 3);min-width:290px;scroll-snap-align:start}}.landing-plan-card{position:relative;display:grid;grid-gap:14px;gap:14px;padding:20px;border-radius:18px;border:1px solid rgba(15,23,42,.08);background:linear-gradient(165deg,#ffffff,#f8fbff);box-shadow:0 10px 30px rgba(15,23,42,.08);overflow:hidden}.landing-plan-card[data-highlight=true]{border-color:rgba(8,145,178,.35);box-shadow:0 18px 36px rgba(8,145,178,.22)}.landing-plan-card:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 90% -10%,rgba(14,165,233,.18),transparent 48%);pointer-events:none}.landing-plan-card[data-plan=lite]:before{background:radial-gradient(circle at 85% -8%,rgba(30,64,175,.2),transparent 50%)}.landing-plan-card[data-plan=start]:before{background:radial-gradient(circle at 85% -8%,rgba(8,145,178,.22),transparent 50%)}.landing-plan-card[data-plan=business]:before{background:radial-gradient(circle at 85% -8%,rgba(217,119,6,.24),transparent 52%)}.landing-plan-card[data-plan=corporate]:before,.landing-plan-card[data-plan=personalizado]:before{background:radial-gradient(circle at 85% -8%,rgba(126,34,206,.2),transparent 52%)}.landing-plan-tag{position:absolute;top:12px;right:12px;padding:4px 8px;border-radius:999px;background:rgba(8,145,178,.14);color:#0e7490;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.landing-plan-head{position:relative;display:grid;grid-gap:4px;gap:4px}.landing-plan-head h3{margin:0;font-size:1rem}.landing-plan-head p{margin:0;color:var(--muted);font-size:.82rem}.landing-plan-price{position:relative;display:grid;grid-gap:2px;gap:2px}.landing-plan-price strong{font-size:1.6rem;line-height:1.05}.landing-plan-price span{color:var(--muted);font-size:.8rem}.landing-plan-list{position:relative;margin:0;padding:0;list-style:none;display:grid;grid-gap:6px;gap:6px}.landing-plan-list li{position:relative;padding-left:16px;color:var(--muted);font-size:.82rem;line-height:1.45}.landing-plan-list li:before{content:"•";position:absolute;left:2px;top:0;color:var(--brand)}.landing-plan-footer{position:relative;margin-top:auto;display:grid;grid-gap:8px;gap:8px}.landing-plan-cta{min-height:44px;width:100%;display:inline-flex;align-items:center;justify-content:center;border-radius:12px;border:0;background:linear-gradient(135deg,#0f172a,#1e3a8a);color:#fff;font-weight:700;font-size:.92rem;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease}.landing-plan-cta:hover{transform:translateY(-1px);box-shadow:0 10px 22px rgba(15,23,42,.24)}.landing-plan-card[data-plan=start] .landing-plan-cta{background:linear-gradient(135deg,#0f766e,#0ea5e9)}.landing-plan-card[data-plan=business] .landing-plan-cta{background:linear-gradient(135deg,#b45309,#f59e0b)}.landing-plan-card[data-plan=corporate] .landing-plan-cta,.landing-plan-card[data-plan=personalizado] .landing-plan-cta{background:linear-gradient(135deg,#6d28d9,#9333ea)}.landing-plan-extra{color:var(--muted);font-size:.76rem}.landing-addon-strip{margin-top:20px;padding:16px 18px;border-radius:12px;border:1px solid rgba(14,116,144,.22);background:linear-gradient(120deg,rgba(236,254,255,.95),rgba(240,249,255,.95));color:var(--ink);font-size:.9rem}.landing-trial-modal-backdrop{position:fixed;inset:0;z-index:140;display:grid;place-items:center;padding:16px;background:rgba(15,23,42,.64);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.landing-trial-modal-card{width:min(560px,calc(100vw - 20px));max-height:calc(100vh - 24px);overflow:auto;display:grid;grid-gap:16px;gap:16px;padding:24px;border-radius:18px;background:linear-gradient(170deg,#ffffff,#f7fbff)}.landing-trial-modal-card .modal-title-block h3{margin:0;font-size:1.25rem}.trial-plan-label-row{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}.trial-plan-label-row a{color:#0c4a6e;font-size:.82rem;font-weight:700;text-decoration:underline}.landing-trial-form{display:grid;grid-gap:12px;gap:12px}.landing-trial-actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}.landing-cta-section{padding:80px 0;background:linear-gradient(135deg,#0f172a,#1e3a5f);color:#fff;text-align:center}.landing-cta-inner{max-width:560px;margin:0 auto;display:grid;grid-gap:20px;gap:20px}.landing-cta-inner h2{margin:0;font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800}.landing-cta-inner p{margin:0;color:rgba(255,255,255,.7);font-size:1.05rem;line-height:1.6}.landing-footer{padding:32px 0;text-align:center;color:var(--muted);font-size:.85rem;border-top:1px solid var(--border)}.landing-footer a{color:var(--brand);font-weight:600}.dashboard-topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow)}.dashboard-topbar-left{display:flex;align-items:center;gap:12px}.dashboard-topbar-logo{display:flex;align-items:center;gap:8px;font-weight:700;font-size:.95rem;text-decoration:none;transition:opacity .15s ease}.dashboard-topbar-logo:hover{opacity:.85}.dashboard-topbar-logo-icon{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;background:var(--brand);color:#fff;font-weight:800;font-size:.8rem}.dashboard-topbar-divider{width:1px;height:24px;background:var(--border)}.dashboard-topbar-user{font-size:.85rem;color:var(--muted)}.dashboard-topbar-right{display:flex;align-items:center;gap:10px}.dashboard-topbar-company{display:inline-flex;align-items:center;gap:8px;padding:5px 8px;border-radius:10px;border:1px solid var(--border);background:#f8fafc}.dashboard-topbar-company-label{font-size:.72rem;color:var(--muted);font-weight:700}.dashboard-topbar-company-select{min-width:220px;max-width:340px;height:34px;padding:6px 10px;border-radius:8px;border:1px solid rgba(148,163,184,.5);background:#fff}.dashboard-topbar-company-name{font-size:.82rem;font-weight:600;color:var(--ink)}.dashboard-topbar-status{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:600}.dashboard-topbar-status[data-online=true]{background:#f0fdf4;color:#166534}.dashboard-topbar-status[data-online=false]{background:#fef2f2;color:#991b1b}.dashboard-topbar-status:before{content:"";width:6px;height:6px;border-radius:999px}.dashboard-topbar-status[data-online=true]:before{background:#16a34a}.dashboard-topbar-status[data-online=false]:before{background:#dc2626}.dashboard-logout-btn{padding:8px 16px;border-radius:8px;border:1px solid var(--border);background:#fff;color:var(--ink);font-weight:600;font-size:.8rem;cursor:pointer;transition:all .15s ease}.dashboard-logout-btn:hover{background:#f8fafc}@media (max-width:780px){.shell{width:min(100%,calc(100% - 20px))}.tab-bar{overflow-x:auto;scrollbar-width:thin}.tab-bar::-webkit-scrollbar{height:6px}.tab-button{flex:0 0 auto;white-space:nowrap}.dashboard-page{padding:18px 0 34px}.dashboard-mobile-nav{display:flex;gap:8px;overflow-x:auto;padding:2px 2px 6px;-webkit-overflow-scrolling:touch}.dashboard-mobile-nav .dashboard-mobile-tab{flex:0 0 auto;white-space:nowrap}.tab-bar-desktop{display:none}.dashboard-card{padding:16px}.dashboard-overview-card{gap:12px}.dashboard-overview-card .metric-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.dashboard-metric-card-compact{padding:10px 12px}.dashboard-metric-meta{display:none}.dashboard-hero-row,.dashboard-section-header,.onboarding-spotlight-actions,.security-guide-actions,.security-guide-header{flex-direction:column;align-items:stretch}.dashboard-accent-button,.dashboard-ghost-button,.dashboard-primary-button,.dashboard-secondary-button{width:100%}.dashboard-field-compact,.dashboard-field-inline{max-width:none;min-width:0}.panel-action-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.panel-action-grid .dashboard-accent-button{grid-column:1/-1}.table-scroll{border:1px solid rgba(148,163,184,.35);border-radius:10px;background:#fff}.table-scroll-hint{display:block;margin-top:6px;font-size:.75rem;color:var(--muted);text-align:right}.security-checkbox-row{align-items:flex-start}.employee-form-actions,.employee-row-actions{flex-direction:column}.employee-mirror-header,.employee-schedule-header{flex-direction:column;align-items:stretch}.employee-schedule-grid,.employee-turno-row{grid-template-columns:1fr}.employee-turno-separator{display:none}.employee-mirror-tabs{width:100%}.employee-mirror-tab{flex:1 1}.onboarding-step-card{grid-template-columns:1fr}.onboarding-modal-backdrop{padding:10px;align-items:flex-end}.onboarding-modal-card{width:min(100%,calc(100vw - 12px));max-height:calc(100vh - 12px);padding:14px;border-radius:12px}.onboarding-camera-layout{grid-template-columns:1fr}.onboarding-camera-preview,.onboarding-camera-preview video{min-height:220px}.onboarding-modal-actions{position:-webkit-sticky;position:sticky;bottom:-14px;margin-inline:-14px;padding:10px 14px 0;background:#fff;border-top:1px solid var(--border)}.onboarding-modal-actions .dashboard-accent-button,.onboarding-modal-actions .dashboard-primary-button,.onboarding-modal-actions .dashboard-secondary-button{width:100%}.force-password-card{padding:18px}.auth-page{padding:18px 14px 190px}.auth-stage{width:100%}.auth-panel{padding:24px 20px}.pwa-install-card{right:12px;left:12px;bottom:12px;width:auto}.pwa-install-card-login[data-mobile-fixed=true]{left:0;right:0;bottom:0;border-radius:16px 16px 0 0;border-left:0;border-right:0;border-bottom:0;padding:12px 14px calc(12px + env(safe-area-inset-bottom));width:100%}.pwa-install-actions{flex-direction:column}.pwa-install-primary,.pwa-install-secondary{width:100%}.landing-features-grid,.landing-plans-grid,.landing-steps{grid-template-columns:1fr}.landing-steps{gap:24px}.landing-stats{grid-template-columns:repeat(2,1fr)}.landing-hero{padding:100px 0 60px}.landing-cta-section,.landing-section{padding:48px 0}.landing-nav-inner{height:56px}.landing-trial-actions{flex-direction:column}.landing-trial-actions .dashboard-secondary-button,.landing-trial-actions .landing-hero-primary,.landing-trial-actions .landing-hero-secondary{width:100%;justify-content:center}.dashboard-topbar{padding:10px 14px;flex-wrap:wrap;gap:8px}.dashboard-topbar-company{width:100%;order:3;justify-content:space-between}.dashboard-topbar-company-select{width:100%;max-width:none;min-width:0}.dashboard-topbar-divider,.dashboard-topbar-user{display:none}.modal-card,.modal-card-large{width:min(100%,calc(100vw - 16px));max-height:calc(100vh - 16px);padding:14px;border-radius:12px}.auth-input,.dashboard-input,.dashboard-select,.dashboard-textarea{font-size:16px}.modal-footer,.modal-header{flex-direction:column;align-items:stretch}.modal-footer .dashboard-primary-button,.modal-footer .dashboard-secondary-button{width:100%}.ajustes-filters-grid,.modal-grid{grid-template-columns:1fr}}.auth-password-wrap{position:relative}.auth-password-wrap .auth-input,.auth-password-wrap .dashboard-input{padding-right:96px}.auth-password-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);min-height:32px;padding:4px 8px;border-radius:8px;border:1px solid var(--border);background:#f8fafc;color:var(--brand-strong);font-size:.78rem;font-weight:600;cursor:pointer}