:root{--color-primary:#6badd6;--color-brand-navy:#1a2b44;--color-primary-dark:#4a90b8;--color-primary-light:#a8d4ee;--color-primary-subtle:#e8f4fb;--color-bg:#f5f9fc;--color-surface:#fff;--color-text:#1a2e44;--color-text-muted:#5a7184;--color-border:#d4e5f0;--color-success:#3d9a6a;--color-danger:#c45c5c;--shadow-sm:0 1px 3px #1a2e440f;--shadow-md:0 4px 16px #1a2e4414;--radius:10px;--font:"Segoe UI", system-ui, -apple-system, sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;line-height:1.6}a{color:var(--color-primary-dark);text-decoration:none}button{cursor:pointer;font-family:inherit}input,select{font-family:inherit}.clock-loader{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1.25rem;padding:1.5rem;animation:.55s ease-out both clock-loader-enter;display:flex}.clock-loader--inline{flex-direction:row;gap:.55rem;padding:0;animation:none}.clock-loader__svg{filter:drop-shadow(0 8px 24px #6badd647);flex-shrink:0;width:88px;height:88px}.clock-loader--sm .clock-loader__svg{filter:none;width:30px;height:30px}.clock-loader--md .clock-loader__svg{width:72px;height:72px}.clock-loader--lg .clock-loader__svg{width:104px;height:104px}.clock-loader--xl .clock-loader__svg{filter:drop-shadow(0 12px 32px #6badd659);width:132px;height:132px}.clock-loader--dark .clock-loader__svg{filter:drop-shadow(0 10px 28px #00000059)}.clock-loader__ring{transform-origin:32px 36px;animation:4.8s ease-in-out infinite clock-loader-ring}.clock-loader__hand{transform-origin:32px 36px;animation:3.6s linear infinite clock-loader-spin}.clock-loader__badge{transform-origin:48px 20px;animation:3.2s ease-in-out infinite clock-loader-badge}.clock-loader__label{color:var(--color-text-muted);letter-spacing:.02em;margin:0;font-size:1rem;font-weight:500}.clock-loader--lg .clock-loader__label,.clock-loader--xl .clock-loader__label{font-size:1.05rem}.clock-loader--dark .clock-loader__label{color:#ffffffe0}.clock-loader--inline .clock-loader__label{font-size:.85rem}@keyframes clock-loader-enter{0%{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}@keyframes clock-loader-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes clock-loader-ring{0%,to{opacity:1}50%{opacity:.45}}@keyframes clock-loader-badge{0%,to{opacity:1;transform:scale(1)}50%{opacity:.9;transform:scale(1.08)}}.page-loader{justify-content:center;align-items:center;width:100%;display:flex}.page-loader--centered{min-height:min(72vh,100dvh - 10rem);padding:2rem}.page-loader--compact{min-height:min(52vh,100dvh - 14rem);padding:2.5rem 1rem}.page-loader--fullscreen{z-index:9999;background:color-mix(in srgb, var(--color-bg) 94%, transparent);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);min-height:100dvh;padding:2rem;position:fixed;inset:0}.page-loader--fullscreen.page-loader--dark{background:#1a2b3ceb}.page-loader--fullscreen:has(.clock-loader--dark){background:#1a2b3ceb}@media (prefers-reduced-motion:reduce){.clock-loader,.clock-loader__hand,.clock-loader__ring,.clock-loader__badge{animation:none}}.logo-brand{align-items:center;gap:.55rem;line-height:1.1;display:inline-flex}.logo-brand__icon{flex-shrink:0;width:36px;height:36px}.logo-brand--xs .logo-brand__icon{width:18px;height:18px}.logo-brand--sm .logo-brand__icon{width:28px;height:28px}.logo-brand--lg .logo-brand__icon{width:48px;height:48px}.logo-brand__text-wrap{flex-direction:column;gap:.15rem;display:flex}.logo-brand__text{letter-spacing:-.02em;white-space:nowrap;font-size:1.2rem;font-weight:700}.logo-brand--sm .logo-brand__text{font-size:1rem}.logo-brand--lg .logo-brand__text{font-size:1.65rem}.logo-brand--xs .logo-brand__text{font-size:.72rem}.logo-brand__veri{color:var(--color-primary);font-weight:600}.logo-brand__shyft{color:var(--color-brand-navy,#1a2b44);font-weight:800}.logo-brand--dark .logo-brand__shyft{color:#fff}.logo-brand__tagline{letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted);white-space:nowrap;font-size:.58rem;font-weight:500}.logo-brand--dark .logo-brand__tagline{color:#ffffffbf}.logo-brand--lg .logo-brand__tagline{font-size:.62rem}.powered-by{color:var(--color-text-muted);text-align:center;margin:0;padding:.5rem 0;font-size:.72rem}.powered-by strong{color:#475569;font-weight:600}.powered-by-subtle{opacity:.85;font-size:.68rem}.powered-by-badge{margin-top:.35rem;padding:0;font-size:.55rem}.app-powered-by{border-top:1px solid var(--color-border);margin-top:auto;padding-top:.75rem}.marketing-powered{border-top:1px solid #ffffff1f;margin-top:.5rem;padding:.75rem 0 0}.marketing-powered .powered-by{color:#ffffff8c}.marketing-powered .powered-by strong{color:#ffffffbf}.marketing{flex-direction:column;min-height:100vh;display:flex}.marketing-header{background:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:100;position:sticky;top:0}.marketing .container{max-width:1100px;margin:0 auto;padding:0 1.5rem}.marketing .header-inner{justify-content:space-between;align-items:center;gap:1rem;height:64px;display:flex}.marketing .logo{color:var(--color-text);align-items:center;gap:.6rem;font-size:1.25rem;font-weight:700;text-decoration:none;display:flex}.marketing-header nav{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.marketing-header nav a:not(.btn){color:var(--color-text-muted);font-size:.875rem;text-decoration:none}.marketing-header nav a:not(.btn):hover{color:var(--color-primary-dark)}.marketing-page{flex:1;padding:3rem 0 4rem}.marketing-page h1{margin-bottom:.75rem;font-size:2rem}.marketing-page .lead{color:var(--color-text-muted);max-width:640px;margin-bottom:2rem;font-size:1.1rem}.marketing-footer{background:var(--color-surface);border-top:1px solid var(--color-border);margin-top:auto;padding:2.5rem 0 1rem}.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr;gap:2rem;margin-bottom:2rem;display:grid}.footer-grid h4{color:var(--color-text);margin-bottom:.75rem;font-size:.85rem}.footer-grid a{color:var(--color-text-muted);margin-bottom:.4rem;font-size:.85rem;text-decoration:none;display:block}.footer-grid a:hover{color:var(--color-primary-dark)}.footer-tagline{color:var(--color-text-muted);margin-top:.5rem;font-size:.85rem}.footer-bottom{border-top:1px solid var(--color-border);text-align:center;color:var(--color-text-muted);padding-top:1rem;font-size:.8rem}@media (width<=768px){.marketing-header nav a:not(.btn){display:none}.footer-grid{grid-template-columns:1fr 1fr}}.landing{min-height:100vh}.container{max-width:1100px;margin:0 auto;padding:0 1.5rem}.landing-header{background:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:100;position:sticky;top:0}.header-inner{justify-content:space-between;align-items:center;height:64px;display:flex}.logo{color:var(--color-text);align-items:center;gap:.6rem;font-size:1.25rem;font-weight:700;display:flex}.logo-icon{background:var(--color-primary);color:#fff;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-weight:800;display:flex}.landing-header nav{align-items:center;gap:1.25rem;display:flex}.landing-header nav a:not(.btn){color:var(--color-text-muted);font-size:.9rem}.landing-header nav a:not(.btn):hover{color:var(--color-primary-dark)}.btn-sm{padding:.45rem 1rem;font-size:.875rem}.btn-lg{padding:.85rem 1.75rem;font-size:1rem}.hero{background:linear-gradient(180deg, var(--color-primary-subtle) 0%, var(--color-bg) 100%);padding:4rem 0 5rem}.hero-inner{grid-template-columns:1fr 1fr;align-items:center;gap:3rem;display:grid}.hero-tagline{color:var(--color-primary-dark);margin-bottom:.75rem;font-size:.95rem;font-weight:600}.hero h1{color:var(--color-text);margin-bottom:1rem;font-size:2.5rem;line-height:1.2}.hero-desc{color:var(--color-text-muted);margin-bottom:1.75rem;font-size:1.1rem}.hero-actions{gap:1rem;margin-bottom:1.5rem;display:flex}.hero-trust{color:var(--color-text-muted);flex-wrap:wrap;gap:1rem;font-size:.875rem;display:flex}.hero-trust span{color:var(--color-success)}.verification-card{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow-md);border:1px solid var(--color-border);padding:2rem}.verification-card h3{color:var(--color-primary-dark);margin-bottom:1.25rem}.verification-card ul{list-style:none}.verification-card li{border-bottom:1px solid var(--color-border);padding:.65rem 0;font-size:.95rem}.verification-card li:last-child{border-bottom:none}.verification-card li.check:before{content:"✓ ";color:var(--color-success);font-weight:700}.features,.pricing{padding:4rem 0}.features h2,.pricing h2{text-align:center;margin-bottom:2.5rem;font-size:1.75rem}.features-grid,.pricing-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;display:grid}.feature-card h3{color:var(--color-primary-dark);margin-bottom:.5rem}.feature-card p{color:var(--color-text-muted);font-size:.9rem}.pricing-card{text-align:center;position:relative}.pricing-card h3{margin-bottom:.5rem}.pricing-card li{padding:.35rem 0}.landing-footer{text-align:center;color:var(--color-text-muted);border-top:1px solid var(--color-border);padding:2rem 0;font-size:.875rem}@media (width<=768px){.hero-inner{grid-template-columns:1fr}.hero h1{font-size:1.75rem}.landing-header nav a:not(.btn){display:none}}.modules-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;display:grid}.module-card{padding:1.25rem}.module-num{color:var(--color-primary-dark);text-transform:uppercase;font-size:.7rem;font-weight:700}.module-card h3{margin:.5rem 0;font-size:1rem}.module-card ul{color:var(--color-text-muted);font-size:.85rem;list-style:none}.module-card li{padding:.2rem 0}.module-card li:before{content:"✓ ";color:var(--color-success)}.cta-row{flex-wrap:wrap;gap:1rem;margin-top:2rem;display:flex}.pricing-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;display:grid}.pricing-card{text-align:center;padding:1.5rem;position:relative}.pricing-card.featured{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.pricing-card .popular{background:var(--color-primary);color:#fff;border-radius:999px;padding:.2rem .75rem;font-size:.7rem;font-weight:600;position:absolute;top:-10px;left:50%;transform:translate(-50%)}.pricing-card .price{color:var(--color-primary-dark);margin:.75rem 0;font-size:2rem;font-weight:700}.pricing-card .price span{color:var(--color-text-muted);font-size:.9rem;font-weight:400}.pricing-card ul{text-align:left;color:var(--color-text-muted);margin-top:1rem;font-size:.9rem;list-style:none}.pricing-card li:before{content:"✓ ";color:var(--color-success)}.use-cases-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;display:grid}.use-case-card{text-align:center;padding:1.25rem}.use-case-card h3{color:var(--color-primary-dark);margin-bottom:.5rem}.contact-form{max-width:480px}.contact-form .form-group{margin-bottom:1rem}.contact-form input,.contact-form textarea,.contact-form select{border:1px solid var(--color-border);border-radius:var(--radius);width:100%;padding:.65rem;font-family:inherit}.blog-list{flex-direction:column;gap:1rem;display:flex}.blog-item{padding:1.25rem}.blog-item h3{margin-bottom:.25rem;font-size:1rem}.blog-item p{color:var(--color-text-muted);font-size:.85rem}.tab-btn{border:1px solid var(--color-border);background:var(--color-surface);border-radius:var(--radius);cursor:pointer;padding:.55rem 1.1rem;font-size:.9rem}.legal-tabs{flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;display:flex}.legal-content{max-width:720px;color:var(--color-text-muted);line-height:1.7}.login-page{background:linear-gradient(180deg, var(--color-primary-subtle) 0%, var(--color-bg) 100%);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.login-card{width:100%;max-width:400px}.login-logo{color:var(--color-text);align-items:center;gap:.5rem;margin-bottom:1.5rem;font-size:1.1rem;font-weight:700;display:flex}.login-card h1{margin-bottom:.25rem;font-size:1.5rem}.login-sub{color:var(--color-text-muted);margin-bottom:1.5rem;font-size:.9rem}.btn-full{width:100%;margin-top:.5rem}.login-error{color:var(--color-danger);border-radius:var(--radius);background:#fde8e8;margin-bottom:1rem;padding:.65rem;font-size:.875rem}.login-demo{color:var(--color-text-muted);text-align:center;margin-top:1.25rem;font-size:.8rem}.login-demo code{background:var(--color-primary-subtle);border-radius:4px;padding:.1rem .35rem;font-size:.75rem}.onboarding-card{width:100%;max-width:440px}.onboarding-progress{gap:.5rem;margin-bottom:1.5rem;display:flex}.progress-dot{background:var(--color-border);border-radius:2px;flex:1;height:4px}.progress-dot.done{background:var(--color-primary)}.onboarding-placeholder{background:var(--color-primary-subtle);border-radius:var(--radius);text-align:center;margin:1.25rem 0;padding:1.25rem;font-size:.9rem}@media (width<=1100px){.stats-grid-compact{grid-template-columns:repeat(3,1fr)}.donuts-grid{grid-template-columns:repeat(2,1fr)}.charts-grid{grid-template-columns:1fr 1fr}.chart-card.chart-wide{grid-column:span 2}}@media (width<=700px){.stats-grid-compact{grid-template-columns:repeat(2,1fr)}.donuts-grid{grid-template-columns:1fr 1fr}.charts-grid{grid-template-columns:1fr}.chart-card.chart-wide{grid-column:span 1}}@media (width<=900px){.dashboard{flex-direction:column}.sidebar{flex-direction:column;width:100%;height:auto;max-height:none;position:static;overflow:visible}.sidebar nav,.sidebar-nav{flex-direction:column;max-height:42vh;margin-right:0;padding-right:0}.dashboard-columns{grid-template-columns:1fr}}.header-actions{align-items:center;gap:.75rem;display:flex}.sidebar-logo{color:var(--color-text);align-items:center;gap:.5rem;margin-bottom:.75rem;padding:0 .5rem;font-weight:700;text-decoration:none;display:flex}.sidebar-tenant{color:var(--color-text-muted);margin:0;padding:0 .5rem 1.25rem;font-size:.75rem;line-height:1.3}.sidebar-header{flex-shrink:0}.sidebar-nav{scrollbar-gutter:stable;flex:1;min-height:0;margin-right:-.35rem;padding-right:.35rem;overflow:hidden auto}.sidebar-nav::-webkit-scrollbar{width:5px}.sidebar-nav::-webkit-scrollbar-track{background:0 0}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:var(--color-primary-light)}.nav-group{margin-bottom:1.25rem}.nav-group-title{text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:.35rem;padding:0 .75rem;font-size:.7rem;font-weight:700;display:block}.sidebar-nav a{border-radius:var(--radius);color:var(--color-text-muted);padding:.55rem .75rem;font-size:.875rem;text-decoration:none;display:block}.sidebar-nav a:hover,.sidebar-nav a.active,.sidebar-nav a[aria-current=page]{background:var(--color-primary-subtle);color:var(--color-primary-dark);font-weight:600}.sidebar-footer{border-top:1px solid var(--color-border);flex-direction:column;flex-shrink:0;gap:.5rem;margin-top:auto;padding-top:1rem;display:flex}.sidebar-link-muted{color:var(--color-text-muted);padding:.25rem .5rem;font-size:.8rem;text-decoration:none}.sidebar-link-muted:hover{color:var(--color-primary-dark)}.dashboard{min-height:100vh;display:flex}.sidebar{background:var(--color-surface);border-right:1px solid var(--color-border);flex-direction:column;flex-shrink:0;width:220px;height:100vh;padding:1.5rem 1rem 1rem;display:flex;position:sticky;top:0;overflow:hidden}.sidebar-logo{align-items:center;gap:.5rem;margin-bottom:2rem;padding:0 .5rem;font-weight:700;display:flex}.sidebar nav,.sidebar-nav{flex-direction:column;flex:1;gap:.25rem;min-height:0;margin-right:-.35rem;padding-right:.35rem;display:flex;overflow:hidden auto}.sidebar nav a{border-radius:var(--radius);color:var(--color-text-muted);padding:.6rem .75rem;font-size:.9rem}.sidebar nav a:hover,.sidebar nav a.active,.sidebar nav a[aria-current=page]{background:var(--color-primary-subtle);color:var(--color-primary-dark)}.logout-btn{margin-top:0}.dashboard-main{flex:1;padding:1.5rem 2rem;overflow-y:auto}.dashboard-header{justify-content:space-between;align-items:flex-start;margin-bottom:1rem;display:flex}.dashboard-header h1{font-size:1.5rem}.dashboard-header p{color:var(--color-text-muted);font-size:.9rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-bottom:1rem;display:grid}.stats-grid-compact{grid-template-columns:repeat(6,1fr);gap:.65rem;margin-bottom:.75rem}.stat-card-compact{padding:.65rem .5rem!important}.stat-card-compact .value{font-size:1.35rem;line-height:1.1}.stat-card-compact .label{margin-top:.15rem;font-size:.7rem;line-height:1.2}.dashboard-columns{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}.dashboard-columns h2{color:var(--color-primary-dark);margin-bottom:1rem;font-size:1rem}.dashboard-columns table{border-collapse:collapse;width:100%;font-size:.875rem}.dashboard-columns th,.dashboard-columns td{text-align:left;border-bottom:1px solid var(--color-border);padding:.5rem}.dashboard-columns th{color:var(--color-text-muted);font-weight:500}.empty{color:var(--color-text-muted);font-size:.9rem}.incident-list{list-style:none}.incident-list li{border-bottom:1px solid var(--color-border);flex-direction:column;gap:.25rem;padding:.75rem 0;display:flex}.incident-list small{color:var(--color-text-muted);font-size:.8rem}.stat-card.highlight{border:2px solid var(--color-primary);background:linear-gradient(135deg,#eef6fb 0%,#fff 100%)}.stat-card.highlight .value{color:var(--color-primary-dark)}.donuts-grid{grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:.85rem;display:grid}.chart-card-compact{padding:.65rem .75rem .5rem!important}.chart-card-compact h2{margin-bottom:.15rem;font-size:.8rem}.chart-wrap.donut.compact{height:118px}.donut-center-compact{padding-bottom:.75rem!important}.donut-center-compact strong{font-size:1.15rem}.charts-grid{grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-bottom:1.5rem;display:grid}.charts-grid-main{margin-bottom:1rem}.chart-card{padding:1.25rem}.chart-card.chart-wide{grid-column:span 2}.chart-card h2{color:var(--color-primary-dark);margin-bottom:.25rem;font-size:.95rem}.chart-sub{color:var(--color-text-muted);margin-bottom:.75rem;font-size:.8rem}.chart-wrap{height:220px;position:relative}.chart-wrap.tall{height:220px}.chart-wrap.donut{height:200px}.chart-wrap.health-donut{position:relative}.donut-center{pointer-events:none;flex-direction:column;justify-content:center;align-items:center;padding-bottom:1.5rem;display:flex;position:absolute;inset:0}.donut-center strong{color:var(--color-primary-dark);font-size:1.75rem;line-height:1}.donut-center span{color:var(--color-text-muted);margin-top:.2rem;font-size:.75rem}.dashboard-loading{color:var(--color-text-muted);padding:2rem 0}.dashboard-quick-links{padding:.85rem 1rem}.dashboard-quick-links h2{color:var(--color-primary-dark);margin-bottom:.75rem;font-size:.95rem}.quick-links-row{flex-wrap:wrap;gap:.5rem;display:flex}@media (width<=1100px){.stats-grid-compact{grid-template-columns:repeat(3,1fr)}.donuts-grid{grid-template-columns:repeat(2,1fr)}.charts-grid{grid-template-columns:1fr 1fr}.chart-card.chart-wide{grid-column:span 2}}@media (width<=700px){.stats-grid-compact{grid-template-columns:repeat(2,1fr)}.donuts-grid{grid-template-columns:1fr 1fr}.charts-grid{grid-template-columns:1fr}.chart-card.chart-wide{grid-column:span 1}}@media (width<=900px){.dashboard{flex-direction:column}.sidebar{flex-direction:column;width:100%;height:auto;max-height:none;position:static;overflow:visible}.sidebar nav,.sidebar-nav{flex-direction:column;max-height:42vh;margin-right:0;padding-right:0}.dashboard-columns{grid-template-columns:1fr}}.badge-preview-wrap{flex-direction:column;align-items:center;gap:1rem;display:flex}.badge-cards-row{flex-wrap:wrap;justify-content:center;gap:1.25rem;display:flex}.employee-badge{border:2px solid var(--color-primary);background:linear-gradient(145deg,#f8fbfd 0%,#fff 55%);border-radius:10px;flex-direction:column;width:340px;height:214px;padding:.65rem .75rem;display:flex;position:relative;box-shadow:0 4px 14px #4a8fb81f}.employee-badge-verso{text-align:center;background:#fff;align-items:center}.badge-brand{color:var(--color-primary-dark);letter-spacing:.02em;align-items:center;gap:.35rem;font-size:.7rem;font-weight:700;display:flex}.badge-brand.centered{justify-content:center}.badge-logo{background:var(--color-primary);color:#fff;border-radius:4px;justify-content:center;align-items:center;width:18px;height:18px;font-size:.65rem;display:inline-flex}.badge-recto-body{flex:1;gap:.65rem;min-height:0;margin-top:.45rem;display:flex}.badge-photo-wrap{flex-shrink:0}.badge-photo{object-fit:cover;border:1px solid var(--color-border);background:#e2e8f0;border-radius:5px;width:78px;height:96px}.badge-photo-empty{color:var(--color-text-muted);justify-content:center;align-items:center;font-size:.65rem;display:flex}.badge-info{flex:1;font-size:.72rem;line-height:1.35;overflow:hidden}.badge-name{color:var(--color-primary-dark);font-size:.9rem;font-weight:700;margin-bottom:.35rem!important}.badge-info p{margin:0 0 .2rem}.badge-info span{color:var(--color-text-muted);margin-right:.25rem;font-weight:600}.badge-tenant{color:var(--color-text-muted);font-size:.65rem;margin-top:.35rem!important}.badge-qr{width:120px;height:120px;margin:.35rem 0 .15rem}.badge-qr-code{color:var(--color-primary-dark);margin:0;font-size:.8rem;font-weight:700}.badge-qr-hint{color:var(--color-text-muted);margin:.15rem 0 0;font-size:.62rem}.badge-actions{flex-wrap:wrap;justify-content:center;gap:.5rem;display:flex}@media print{body *{visibility:hidden}#employee-badge-print,#employee-badge-print *{visibility:visible}#employee-badge-print{flex-direction:column;gap:8mm;display:flex;position:absolute;top:0;left:0}.employee-badge{box-shadow:none;page-break-inside:avoid}.no-print{display:none!important}}@media (width<=600px){.employee-form .form-row{grid-template-columns:1fr}}@media (width<=600px){.employee-form .form-row{grid-template-columns:1fr}}@media (width<=600px){.settings-form .form-row{grid-template-columns:1fr}}@media (width<=600px){.employee-form .form-row{grid-template-columns:1fr}}@media (width<=600px){.settings-form .form-row{grid-template-columns:1fr}}.contracts-hint{color:var(--color-text-muted);margin-bottom:1rem;padding:.85rem 1rem;font-size:.88rem;line-height:1.45}.file-meta{color:var(--color-text-muted);font-size:.8rem}.contract-modal{text-align:left;width:100%;max-width:400px;max-height:min(88vh,520px);overflow-y:auto;padding:1rem 1.15rem!important}.contract-modal h2{color:var(--color-primary-dark);margin-bottom:.75rem;font-size:1rem}.contract-form .form-group{margin-bottom:.65rem}.contract-form label{margin-bottom:.2rem;font-size:.8rem}.contract-form input,.contract-form select,.contract-form textarea{padding:.45rem .55rem;font-size:.875rem}.contract-form textarea{resize:vertical;min-height:52px}.contract-form-grid{grid-template-columns:1fr 1fr;gap:.65rem;display:grid}.contract-form .optional{color:var(--color-text-muted);font-size:.75rem;font-weight:400}.contract-form-actions{border-top:1px solid var(--color-border);justify-content:flex-end;gap:.5rem;margin-top:.85rem;padding-top:.75rem;display:flex}.contract-modal .alert-error{margin-bottom:.65rem;padding:.5rem .65rem;font-size:.8rem}@media (width<=480px){.contract-form-grid{grid-template-columns:1fr}.contract-modal{max-height:92vh}}@media (width<=600px){.employee-form .form-row{grid-template-columns:1fr}}@media (width<=600px){.settings-form .form-row{grid-template-columns:1fr}}textarea{border:1px solid var(--color-border);border-radius:var(--radius);width:100%;padding:.65rem;font-family:inherit}.leave-modal{text-align:left;width:100%;max-width:400px;max-height:min(88vh,480px);overflow-y:auto;padding:1rem 1.15rem!important}.leave-modal h2{color:var(--color-primary-dark);margin-bottom:.75rem;font-size:1rem}.leave-form .form-group{margin-bottom:.65rem}.leave-form label{font-size:.8rem}.leave-form input,.leave-form select,.leave-form textarea{padding:.45rem .55rem;font-size:.875rem}.leave-form-actions{border-top:1px solid var(--color-border);justify-content:flex-end;gap:.5rem;margin-top:.85rem;padding-top:.75rem;display:flex}.leave-modal .alert-error{margin-bottom:.65rem;font-size:.8rem}.employees-toolbar{margin-bottom:1rem;padding:1rem}.search-input{border:1px solid var(--color-border);border-radius:var(--radius);width:100%;padding:.65rem .85rem;font-size:.95rem}.search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle);outline:none}.employees-table-wrap{overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:.9rem}.data-table th,.data-table td{text-align:left;border-bottom:1px solid var(--color-border);padding:.75rem .5rem}.data-table th{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em;font-size:.8rem;font-weight:600}.data-table code{background:var(--color-primary-subtle);border-radius:4px;padding:.15rem .4rem;font-size:.8rem}.actions-cell{flex-wrap:wrap;gap:.5rem .75rem;display:flex}.btn-link{color:var(--color-primary-dark);cursor:pointer;background:0 0;border:none;padding:0;font-size:.85rem;font-weight:500;text-decoration:none}.btn-link:hover{text-decoration:underline}.btn-link.danger{color:var(--color-danger)}.pagination{border-top:1px solid var(--color-border);color:var(--color-text-muted);justify-content:center;align-items:center;gap:1rem;margin-top:1.25rem;padding-top:1rem;font-size:.9rem;display:flex}.alert-error{color:var(--color-danger);border-radius:var(--radius);background:#fde8e8;margin-bottom:1rem;padding:.75rem 1rem;font-size:.9rem}.form-card{max-width:720px}.employee-form .form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.employee-form select{border:1px solid var(--color-border);border-radius:var(--radius);background:#fff;width:100%;padding:.65rem .85rem;font-size:1rem}.checkbox-group label{cursor:pointer;align-items:center;gap:.5rem;font-weight:500;display:flex}.form-actions{border-top:1px solid var(--color-border);justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1.25rem;display:flex}.modal-overlay{z-index:200;background:#1a2e4473;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{text-align:center;width:100%;max-width:360px}.modal h2{margin-bottom:.5rem;font-size:1.1rem}.modal-meta{color:var(--color-text-muted);margin-bottom:.25rem;font-size:.85rem}.qr-image{border:1px solid var(--color-border);border-radius:var(--radius);margin:1rem auto;display:block}.qr-hint{color:var(--color-text-muted);margin-bottom:1rem;font-size:.8rem}.employee-tutorial{background:#eef6fb;border-radius:8px;margin-bottom:1.25rem;padding:1rem;font-size:.9rem}.employee-tutorial summary{cursor:pointer;color:var(--color-primary-dark);font-weight:600}.badge-success-card{padding:1.5rem}.employee-form-sections fieldset{border:1px solid var(--color-border);border-radius:8px;margin-bottom:1.25rem;padding:1rem 1.25rem}.employee-form-sections legend{color:var(--color-primary-dark);padding:0 .5rem;font-weight:600}.field-hint{color:var(--color-text-muted);margin-top:.35rem;font-size:.8rem}.photo-preview{border:2px solid var(--color-border);border-radius:8px;max-width:160px;margin-top:.75rem;display:block}.doc-list{margin-top:.5rem;padding-left:1.2rem;font-size:.85rem}@media (width<=600px){.employee-form .form-row{grid-template-columns:1fr}}.settings-tabs{flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem;display:flex}.tab-btn{border:1px solid var(--color-border);background:var(--color-surface);border-radius:var(--radius);color:var(--color-text-muted);cursor:pointer;padding:.55rem 1.1rem;font-size:.9rem;font-weight:500;transition:all .2s}.tab-btn:hover{border-color:var(--color-primary);color:var(--color-primary-dark)}.tab-btn.active{background:var(--color-primary-subtle);border-color:var(--color-primary);color:var(--color-primary-dark);font-weight:600}.settings-form h2{color:var(--color-primary-dark);border-bottom:1px solid var(--color-border);margin:1.5rem 0 1rem;padding-bottom:.5rem;font-size:1rem}.settings-form h2:first-child{margin-top:0}.settings-form .form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.settings-form select{border:1px solid var(--color-border);border-radius:var(--radius);background:#fff;width:100%;padding:.65rem .85rem;font-size:1rem}.settings-meta{color:var(--color-text-muted);margin-top:1rem;font-size:.85rem}.alert-success{color:var(--color-success);border-radius:var(--radius);background:#e6f5ed;margin-bottom:1rem;padding:.75rem 1rem;font-size:.9rem}.settings-section .section-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.settings-section h2{color:var(--color-primary-dark);font-size:1rem}.modal-lg{text-align:left;max-width:520px}.modal-lg h2{margin-bottom:1.25rem;font-size:1.1rem}.day-picker{flex-wrap:wrap;gap:.4rem;display:flex}.day-btn{border:1px solid var(--color-border);cursor:pointer;background:#fff;border-radius:6px;padding:.4rem .65rem;font-size:.8rem}.day-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}@media (width<=600px){.settings-form .form-row{grid-template-columns:1fr}}.scan-panel{max-width:720px;padding:1.5rem}.scan-panel h2{color:var(--color-primary-dark);margin-bottom:.5rem;font-size:1rem}.scan-hint{color:var(--color-text-muted);margin-bottom:1.25rem;font-size:.9rem}.scan-panel select{border:1px solid var(--color-border);border-radius:var(--radius);width:100%;padding:.65rem}.scan-actions{flex-wrap:wrap;gap:.75rem;margin-top:1rem;display:flex}.qr-ready{color:var(--color-success);margin-top:.75rem;font-size:.85rem}.scan-result{border-radius:var(--radius);margin-top:1rem;padding:.75rem;font-size:.9rem}.scan-result.ok{color:var(--color-success);background:#e6f5ed}.scan-result.fail{color:var(--color-danger);background:#fde8e8}.filters-bar{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1rem;padding:1rem;display:flex}.filters-bar input,.filters-bar select{border:1px solid var(--color-border);border-radius:var(--radius);padding:.5rem .75rem}.reports-page{flex-direction:column;gap:1.15rem;display:flex}.reports-hero{background:linear-gradient(135deg,#fff 0%,#eef6fb 55%,#e3f0f9 100%);border-color:#c5dff0;position:relative;overflow:hidden;padding:1.35rem 1.5rem!important}.reports-hero:before{content:"";pointer-events:none;background:radial-gradient(circle,#6badd62e 0%,#0000 70%);border-radius:50%;width:160px;height:160px;position:absolute;top:-40px;right:-40px}.reports-hero-top{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;display:flex;position:relative}.reports-hero-eyebrow{letter-spacing:.06em;text-transform:uppercase;color:var(--color-primary-dark);opacity:.85;margin-bottom:.2rem;font-size:.72rem;font-weight:600}.reports-hero-period{color:var(--color-text);font-size:1.2rem;font-weight:700;line-height:1.3}.reports-refresh{padding:.55rem 1.1rem;font-size:.875rem;box-shadow:0 4px 14px #4a90b840}.reports-presets{flex-wrap:wrap;gap:.45rem;margin:1rem 0 .85rem;display:flex;position:relative}.reports-preset{border:1px solid var(--color-border);color:var(--color-text-muted);background:#ffffffd9;border-radius:999px;padding:.35rem .75rem;font-size:.78rem;font-weight:600;transition:all .18s}.reports-preset:hover{border-color:var(--color-primary);color:var(--color-primary-dark);box-shadow:var(--shadow-sm);background:#fff}.reports-dates{flex-wrap:wrap;align-items:flex-end;gap:.65rem;display:flex;position:relative}.reports-date-field{flex-direction:column;gap:.3rem;min-width:150px;display:flex}.reports-date-field span{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.72rem;font-weight:600}.reports-date-field input{border:1px solid var(--color-border);background:#fff;border-radius:8px;padding:.5rem .65rem;font-size:.875rem;transition:border-color .18s,box-shadow .18s}.reports-date-field input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle);outline:none}.reports-date-sep{color:var(--color-primary);opacity:.6;padding-bottom:.55rem;font-weight:700}.reports-alert{margin:0}.reports-kpis{grid-template-columns:repeat(4,1fr);gap:.85rem;display:grid}.reports-kpi{border-left:4px solid var(--color-primary);position:relative;overflow:hidden;padding:1rem 1.1rem!important}.reports-kpi:after{content:"";opacity:.12;background:var(--color-primary);border-radius:0 0 0 72px;width:72px;height:72px;position:absolute;top:0;right:0}.reports-kpi.tone-blue{border-left-color:#6badd6}.reports-kpi.tone-blue:after{background:#6badd6}.reports-kpi.tone-teal{border-left-color:#3d9a6a}.reports-kpi.tone-teal:after{background:#3d9a6a}.reports-kpi.tone-amber{border-left-color:#d4845c}.reports-kpi.tone-amber:after{background:#d4845c}.reports-kpi.tone-violet{border-left-color:#7b6fd6}.reports-kpi.tone-violet:after{background:#7b6fd6}.reports-kpi-label{color:var(--color-text-muted);margin-bottom:.35rem;font-size:.78rem;font-weight:600}.reports-kpi-value{color:var(--color-text);letter-spacing:-.02em;font-size:1.85rem;font-weight:800;line-height:1}.reports-kpi-sub{color:var(--color-text-muted);margin-top:.4rem;font-size:.75rem}.reports-kpi-skeleton{background:linear-gradient(90deg,#f0f6fa 25%,#e8f0f6 50%,#f0f6fa 75%) 0 0/200% 100%;min-height:96px;animation:1.2s infinite reports-shimmer;border-left-color:#0000!important}@keyframes reports-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.reports-layout{grid-template-columns:1fr 380px;align-items:start;gap:1rem;display:grid}.reports-section-head{margin-bottom:.85rem}.reports-section-head h2{color:var(--color-primary-dark);margin-bottom:.2rem;font-size:1.05rem;font-weight:700}.reports-section-head p{color:var(--color-text-muted);font-size:.82rem}.reports-export-grid{grid-template-columns:repeat(2,1fr);gap:.85rem;display:grid}.report-export-card{border-top:3px solid var(--accent,var(--color-primary));transition:transform .2s,box-shadow .2s,border-color .2s;padding:1.1rem 1.15rem!important}.report-export-card:hover{box-shadow:var(--shadow-md);border-color:#b8d4e8;transform:translateY(-2px)}.report-export-head{gap:.85rem;margin-bottom:1rem;display:flex}.report-export-icon{background:color-mix(in srgb, var(--accent,#6badd6) 14%, white);width:42px;height:42px;color:var(--accent,var(--color-primary-dark));border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.report-icon-svg{width:22px;height:22px;display:flex}.report-icon-svg svg{width:100%;height:100%}.report-export-head h3{color:var(--color-text);margin-bottom:.2rem;font-size:.95rem;font-weight:700}.report-export-head p{color:var(--color-text-muted);font-size:.78rem;line-height:1.45}.report-export-formats{flex-wrap:wrap;gap:.45rem;display:flex}.report-format-btn{border:1px solid var(--color-border);color:var(--color-text);background:#fff;border-radius:8px;align-items:center;gap:.45rem;padding:.42rem .75rem;font-size:.78rem;font-weight:600;transition:all .18s;display:inline-flex}.report-format-btn:hover:not(:disabled){border-color:var(--color-primary);background:var(--color-primary-subtle);color:var(--color-primary-dark)}.report-format-btn:disabled{opacity:.55;cursor:not-allowed}.format-tag{letter-spacing:.05em;border-radius:4px;padding:.12rem .35rem;font-size:.62rem;font-weight:800}.format-csv .format-tag{color:#2d7a52;background:#e6f5ed}.format-pdf .format-tag{color:#b54545;background:#fdeaea}.reports-audit-section{flex-direction:column;max-height:calc(100vh - 220px);display:flex;position:sticky;top:1rem;padding:0!important}.reports-audit-head{border-bottom:1px solid var(--color-border);border-radius:var(--radius) var(--radius) 0 0;background:linear-gradient(#fafcfe 0%,#fff 100%);justify-content:space-between;align-items:flex-start;gap:.75rem;padding:1.1rem 1.15rem .85rem;display:flex}.reports-audit-head h2{color:var(--color-primary-dark);font-size:.95rem;font-weight:700}.reports-audit-head p{color:var(--color-text-muted);margin-top:.15rem;font-size:.75rem}.reports-audit-count{background:var(--color-primary-subtle);min-width:2rem;height:2rem;color:var(--color-primary-dark);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;padding:0 .5rem;font-size:.8rem;font-weight:700;display:flex}.reports-audit-loading,.reports-audit-empty{text-align:center;color:var(--color-text-muted);padding:2rem 1.15rem;font-size:.85rem}.reports-audit-empty .report-icon-svg{width:36px;height:36px;color:var(--color-primary-light);margin:0 auto .65rem}.reports-timeline{flex:1;margin:0;padding:.65rem 0;list-style:none;overflow-y:auto}.reports-timeline-item{gap:0;padding:0 1rem 0 1.35rem;display:flex;position:relative}.reports-timeline-item:not(:last-child) .reports-timeline-dot:after{content:"";background:var(--color-border);width:2px;height:calc(100% + 10px);position:absolute;top:14px;left:50%;transform:translate(-50%)}.reports-timeline-dot{flex-shrink:0;width:10px;margin-top:.55rem;margin-right:.75rem;position:relative}.reports-timeline-dot:before{content:"";background:var(--color-primary);width:10px;height:10px;box-shadow:0 0 0 1px var(--color-primary-light);z-index:1;border:2px solid #fff;border-radius:50%;display:block;position:relative}.reports-timeline-body{flex:1;min-width:0;padding-bottom:.85rem}.reports-timeline-row{align-items:flex-start;gap:.55rem;display:flex}.reports-timeline-avatar{background:var(--color-primary-subtle);width:30px;height:30px;color:var(--color-primary-dark);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:.65rem;font-weight:700;display:flex}.reports-timeline-main{flex:1;min-width:0}.reports-timeline-main strong{color:var(--color-text);word-break:break-word;font-size:.8rem;font-weight:600;line-height:1.3;display:block}.reports-timeline-meta{color:var(--color-text-muted);margin-top:.15rem;font-size:.72rem;line-height:1.35;display:block}.reports-timeline-time{color:var(--color-text-muted);white-space:nowrap;flex-shrink:0;padding-top:.1rem;font-size:.68rem}@media (width<=1100px){.reports-layout{grid-template-columns:1fr}.reports-audit-section{max-height:none;position:static}}@media (width<=900px){.reports-kpis{grid-template-columns:repeat(2,1fr)}.reports-export-grid{grid-template-columns:1fr}}@media (width<=520px){.reports-kpis{grid-template-columns:1fr}.reports-hero-period{font-size:1rem}.reports-timeline-time{display:none}}.manager-join-page{background:#eef6fb;justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.manager-join-card{width:100%;max-width:440px;padding:2rem}.manager-join-logo{justify-content:center;margin-bottom:.5rem;display:flex}.manager-join-sub{text-align:center;margin-bottom:.5rem}.manager-join-perms{color:var(--color-text-muted);text-align:center;margin-bottom:1.25rem;font-size:.85rem}.manager-join-tabs{grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:1rem;display:grid}.manager-join-tabs button{border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;background:#fff;padding:.5rem;font-size:.85rem}.manager-join-tabs button.active{background:var(--color-primary-subtle);border-color:var(--color-primary);color:var(--color-primary-dark);font-weight:600}.manager-join-form{flex-direction:column;gap:.75rem;display:flex}.manager-join-error{color:#b91c1c;border-radius:var(--radius);background:#fef2f2;margin-bottom:.75rem;padding:.6rem .75rem;font-size:.85rem}.manager-join-page--loading{min-height:100dvh}.manager-join-loading{text-align:center;color:var(--color-text-muted)}.btn{border-radius:var(--radius);border:none;justify-content:center;align-items:center;gap:.5rem;padding:.65rem 1.25rem;font-size:.95rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-dark)}.btn-outline{border:1.5px solid var(--color-primary);color:var(--color-primary-dark);background:0 0}.btn-outline:hover{background:var(--color-primary-subtle)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:1.5rem}.stat-card{text-align:center}.stat-card .value{color:var(--color-primary-dark);font-size:2rem;font-weight:700}.stat-card .label{color:var(--color-text-muted);margin-top:.25rem;font-size:.875rem}.form-group{margin-bottom:1rem}.form-group label{margin-bottom:.35rem;font-size:.9rem;font-weight:500;display:block}.form-group input{border:1px solid var(--color-border);border-radius:var(--radius);width:100%;padding:.65rem .85rem;font-size:1rem}.form-group input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle);outline:none}.badge{border-radius:999px;padding:.2rem .6rem;font-size:.75rem;font-weight:600;display:inline-block}.badge-open{color:var(--color-danger);background:#fde8e8}.badge-validated{color:var(--color-success);background:#e6f5ed}
