@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Outfit:wght@400;500;600;700&display=swap";@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Outfit:wght@400;500;600;700&display=swap";@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";.login-page{background:#f8fafc;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative;overflow:hidden}.login-page__bg-ring{pointer-events:none;border:1px solid #3b82f60d;border-radius:50%;position:absolute}.login-page__bg-ring--1{width:600px;height:600px;top:-180px;left:-200px}.login-page__bg-ring--2{width:400px;height:400px;top:-100px;left:-100px}.login-page__bg-ring--3{width:300px;height:300px;bottom:-80px;right:-100px}.login-card-single{z-index:10;background:#fff;border:1px solid #f1f5f9;border-radius:24px;width:100%;max-width:420px;animation:.5s cubic-bezier(.16,1,.3,1) cardEnter;overflow:hidden;box-shadow:0 10px 40px #0000000a,0 2px 10px #00000005}@keyframes cardEnter{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-card__header{background:linear-gradient(160deg,#2b7fff 0%,#1a5fe6 40%,#1348c4 100%);justify-content:center;align-items:center;padding:32px;display:flex}.login-card__logo-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:1px solid #ffffff1a;border-radius:20px;justify-content:center;align-items:center;padding:12px;display:flex}.login-card__logo-main{object-fit:contain;max-width:250px;height:auto;filter:none!important}.login-card__content{flex-direction:column;padding:25px 40px;display:flex}.login-card__form-title{background:linear-gradient(160deg,#2b7fff 0%,#1a5fe6 40%,#1348c4 100%);-webkit-text-fill-color:transparent;text-align:center;-webkit-background-clip:text;font-size:35px;font-weight:800}.login-card__form-subtitle{color:#64748b;text-align:center;margin-bottom:32px;font-size:14px;font-weight:500}.login-card__form{flex-direction:column;gap:20px;display:flex}.login-field{flex-direction:column;gap:8px;display:flex}.login-field__label{color:#475569;font-size:13px;font-weight:700}.login-field__label-row{justify-content:space-between;align-items:center;display:flex}.login-field__forgot{color:#2563eb;font-size:12px;font-weight:600;text-decoration:none}.login-field__input-wrapper{align-items:center;display:flex;position:relative}.login-field__icon{color:#94a3b8;pointer-events:none;display:flex;position:absolute;left:14px}.login-field__input{color:#1e293b;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;outline:none;width:100%;padding:12px 14px 12px 42px;font-size:14px;font-weight:600;transition:all .2s}.login-field__input:focus{background:#fff;border-color:#2563eb;box-shadow:0 0 0 4px #2563eb14}.login-field__input:focus~.login-field__icon{color:#2563eb}.login-field__toggle{color:#94a3b8;cursor:pointer;background:0 0;border:none;padding:4px;position:absolute;right:12px}.login-forgot-container{justify-content:flex-end;margin-top:-8px;display:flex}.login-forgot-link{color:#2563eb;font-size:13px;font-weight:600;text-decoration:none;transition:color .2s}.login-forgot-link:hover{color:#1d4ed8;text-decoration:underline}.login-card__submit{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:12px;justify-content:center;align-items:center;gap:10px;width:100%;margin-top:8px;padding:14px;font-size:15px;font-weight:700;transition:all .2s;display:flex;box-shadow:0 4px 12px #2563eb33}.login-card__submit:hover:not(:disabled){background:#1d4ed8;transform:translateY(-1px);box-shadow:0 6px 20px #2563eb4d}.login-card__submit:disabled{opacity:.7;cursor:not-allowed}.login-card__error{color:#e11d48;background:#fff1f2;border:1px solid #ffe4e6;border-radius:12px;align-items:center;gap:8px;margin-bottom:24px;padding:12px;font-size:13px;font-weight:600;animation:.4s shake;display:flex}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.login-card__support{text-align:center;color:#94a3b8;margin-top:32px;font-size:13px;font-weight:600}.login-card__support-link{color:#2563eb;text-decoration:none}.login-page__footer{z-index:10;margin-top:32px}.login-page__credit{color:#94a3b8;letter-spacing:.02em;font-size:12px;font-weight:600}.login-page__credit-name{color:#475569;font-weight:800}.login-card__spinner{border:3px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (width<=480px){.login-page{padding:16px}.login-card__content{padding:24px}}.support-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10000;background:#0f172a80;justify-content:center;align-items:center;padding:20px;animation:.3s ease-out fadeInSupport;display:flex;position:fixed;inset:0}.support-card{background:#fff;border-radius:24px;width:100%;max-width:520px;animation:.4s cubic-bezier(.16,1,.3,1) slideInSupport;overflow:hidden;box-shadow:0 20px 40px #0003}.support-header{color:#fff;background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);justify-content:space-between;align-items:flex-start;padding:28px 32px;display:flex}.support-title-box{align-items:center;gap:16px;display:flex}.support-icon-bg{background:#fff3;border-radius:12px;padding:12px;display:flex}.support-header h3{margin:0;font-size:20px;font-weight:700}.support-header p{opacity:.8;margin:4px 0 0;font-size:14px}.support-close-btn{color:#fff;cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.support-close-btn:hover{background:#ffffff40;transform:rotate(90deg)}.support-body{padding:32px}.support-grid{grid-template-columns:1fr 1fr;gap:24px;display:grid}.support-input-group{flex-direction:column;gap:8px;display:flex}.support-input-group.full{grid-column:1/-1}.support-input-group label{color:#475569;margin-left:4px;font-size:13px;font-weight:600}.support-input-group input,.support-input-group textarea{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:12px;padding:12px 16px;font-family:inherit;font-size:14px;transition:all .2s}.support-input-group input:focus,.support-input-group textarea:focus{background:#fff;border-color:#2563eb;outline:none;box-shadow:0 0 0 4px #2563eb1a}.support-footer{justify-content:flex-end;gap:12px;margin-top:32px;display:flex}.support-btn-cancel{color:#64748b;cursor:pointer;background:#f1f5f9;border:none;border-radius:12px;padding:12px 24px;font-weight:600}.support-btn-submit{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:12px;padding:12px 32px;font-weight:600;transition:all .2s;box-shadow:0 4px 6px #2563eb33}.support-btn-submit:hover:not(:disabled){background:#1d4ed8;transform:translateY(-1px);box-shadow:0 8px 12px #2563eb4d}.support-btn-submit:disabled{opacity:.7;cursor:not-allowed;justify-content:center;align-items:center;gap:10px;display:flex}.modal-spinner-small{border:2.5px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spinSupport}@keyframes spinSupport{to{transform:rotate(360deg)}}.support-success{text-align:center;padding:20px 0;animation:.5s cubic-bezier(.34,1.56,.64,1) scaleInSupport}.success-circle{color:#22c55e;background:#f0fdf4;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 24px;display:flex}.support-success h4{color:#1e293b;margin:0 0 8px;font-size:24px}.support-success p{color:#64748b;font-size:15px}@keyframes fadeInSupport{0%{opacity:0}to{opacity:1}}@keyframes slideInSupport{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes scaleInSupport{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@media (width<=576px){.support-overlay{padding:12px}.support-card{border-radius:20px}.support-header{gap:12px;padding:20px 24px}.support-title-box{gap:12px}.support-icon-bg{padding:8px}.support-header h3{font-size:18px}.support-body{padding:24px}.support-grid{grid-template-columns:1fr;gap:16px}.support-footer{flex-direction:column-reverse;gap:10px;margin-top:24px}.support-btn-cancel,.support-btn-submit{justify-content:center;width:100%;padding:14px;display:flex}}.eduguard-layout{background-color:#f8fafc;flex-direction:column;height:100vh;font-family:Inter,-apple-system,sans-serif;display:flex}.eduguard-header{z-index:100;background:#fff;border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;height:72px;padding:0 20px;display:flex;position:relative}.header-left{align-items:center;gap:10px;display:flex}.header-page-title{align-items:center;gap:12px;display:flex}.header-divider{color:#cbd5e1;font-size:22px;font-weight:300;line-height:1}.header-title-text{color:#1d4ed8;letter-spacing:-.01em;font-family:Outfit,sans-serif;font-size:32px;font-weight:800}.logo-img{width:180px;height:auto}.logo-box{background:#fff;justify-content:center;align-items:center;width:auto;height:60px;padding:0 10px;display:flex}.brand-name{color:#0f172a;letter-spacing:-.02em;font-size:35px;font-weight:800}.header-right{align-items:center;display:flex}.user-profile-wrapper{z-index:1000;position:relative}.user-profile{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:12px;align-items:center;gap:12px;padding:8px 16px;transition:all .2s;display:flex}.user-profile:hover,.user-profile.active{background:#f1f5f9}.user-text{text-align:right;flex-direction:column;display:flex}.user-name{color:#0f172a;font-size:15px;font-weight:800}.user-role{color:#64748b;font-size:11px;font-weight:500}.user-avatar{background:#2563eb;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;display:flex;overflow:hidden}.user-avatar img{object-fit:cover;width:100%;height:100%}.dropdown-arrow-icon{color:#94a3b8;transition:transform .2s}.dropdown-arrow-icon.open{transform:rotate(180deg)}.profile-dropdown-menu{z-index:1001;background:#fff;border:1px solid #f1f5f9;border-radius:12px;width:200px;padding:8px;animation:.2s ease-out dropdownFadeIn;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-menu-item{color:#475569;cursor:pointer;border-radius:8px;align-items:center;gap:12px;padding:10px 12px;font-size:14px;font-weight:600;transition:all .15s;display:flex}.dropdown-menu-item:hover{color:#2563eb;background:#f8fafc}.dropdown-menu-item svg{color:#94a3b8;transition:color .15s}.dropdown-menu-item:hover svg{color:#2563eb}.dropdown-menu-divider{background:#f1f5f9;height:1px;margin:8px 0}.logout-item{color:#ef4444}.logout-item:hover{color:#dc2626!important;background:#fef2f2!important}.logout-item:hover svg{color:#dc2626!important}.eduguard-main{background-color:#f8fafc;flex-direction:column;flex:1;justify-content:flex-start;align-items:center;padding:24px 20px 40px;display:flex;overflow-y:auto}.eduguard-status-bar{color:#64748b;background:#fff;border-top:1px solid #e2e8f0;justify-content:space-between;align-items:center;height:32px;padding:0 40px;font-size:11px;font-weight:600;display:flex}.status-left,.status-right{align-items:center;gap:24px;display:flex}.status-item{align-items:center;gap:8px;display:flex}.dot{border-radius:50%;width:8px;height:8px}.dot.online{background:#10b981}.terminal-id,.version{letter-spacing:.02em}.layout{background-color:#f8fafc;width:100%;min-height:100vh;display:flex}.layout__main{flex-direction:column;flex:1;min-height:100vh;margin-left:240px;padding:105px 24px 24px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;overflow-x:hidden}@media (width<=1024px){.layout__main{margin-left:0;padding:92px 20px 24px}}@media (width<=640px){.layout__main{padding:80px 16px 16px}}.global-footer{text-align:center;color:#94a3b8;width:100%;margin-top:auto;padding-top:24px;padding-bottom:12px;font-size:13px;font-weight:600}.footer-link{color:#1e293b;font-weight:800;text-decoration:none;transition:color .2s}.footer-link:hover,.footer-link:active{color:#2563eb!important}@media (width<=768px){.eduguard-header{height:64px;padding:0 12px}.logo-img{width:120px}.logo-box{height:50px;padding:0 5px}.header-page-title span.header-title-text{margin-right:8px;white-space:nowrap!important;font-size:13px!important;font-weight:700!important;line-height:1!important}.user-profile{gap:4px;padding:4px}.user-text{flex-direction:column;align-items:flex-end;display:flex!important}.user-name{display:none!important}.user-role{white-space:nowrap;color:#1e293b;font-weight:700;font-size:9px!important;display:block!important}.header-page-title span.header-title-text{letter-spacing:-.01em!important;margin-right:2px!important;font-size:8px!important;font-weight:600!important;display:inline-block!important}.user-avatar{width:28px;height:28px;font-size:12px!important}}@media (width<=480px){.header-left{gap:6px!important}.logo-box{flex-shrink:0!important;width:65px!important;padding:0!important}.logo-img{width:100%!important;display:block!important}.header-page-title span.header-title-text{letter-spacing:-.01em!important;margin-right:4px!important;font-size:12px!important;font-weight:700!important}.eduguard-header{padding:0 6px!important}.header-right{flex-shrink:0!important}}.sidebar{z-index:200;background:#fff;border-right:1px solid #f1f5f9;flex-direction:column;width:240px;height:100vh;padding:0 16px 24px;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;left:0;overflow-y:auto}.sidebar__close-btn{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px;display:none;position:absolute;top:16px;right:16px}.sidebar__close-btn:hover{color:#1e293b;background:#f1f5f9}.sidebar-overlay{display:none}.sidebar__brand{border-bottom:1px solid #f1f5f9;justify-content:center;align-items:center;height:80px;margin:0 -16px 16px;padding:0;display:flex}.sidebar__logo{justify-content:center;align-items:center;width:180px;height:auto;display:flex}.sidebar__logo-img{object-fit:contain;max-width:100%;max-height:56px}.sidebar__brand-text{min-width:0}.sidebar__title{color:#2563eb;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:16px;font-weight:700;line-height:1.2;overflow:hidden}.sidebar__subtitle{letter-spacing:.08em;color:#94a3b8;text-transform:uppercase;margin-top:2px;font-size:9px;font-weight:700;display:block}.sidebar__nav{flex-direction:column;flex:1;gap:4px;display:flex}.sidebar__nav-item{color:#64748b;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:12px;width:100%;padding:11px 16px;font-family:inherit;font-size:13px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.sidebar__nav-item:hover{color:#334155;background:#f1f5f9}.sidebar__nav-item--active{color:#2563eb;background:#eff6ff;font-weight:600}.sidebar__nav-item--active .sidebar__nav-icon{color:#2563eb}.sidebar__nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.sidebar__nav-label{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sidebar__footer{border-top:1px solid #f1f5f9;flex-direction:column;gap:4px;margin-top:auto;padding-top:16px;display:flex}.sidebar__nav-item--logout{color:#ef4444}.sidebar__nav-item--logout:hover{color:#dc2626;background:#fef2f2}@media (width<=1024px){.sidebar{box-shadow:none;transform:translate(-100%)}.sidebar--open{transform:translate(0);box-shadow:4px 0 24px #0000001f}.sidebar__close-btn{display:flex}.sidebar-overlay{z-index:199;opacity:0;pointer-events:none;background:#0f172a66;transition:opacity .3s;display:block;position:fixed;inset:0}.sidebar-overlay--visible{opacity:1;pointer-events:auto}}.app-header{z-index:150;background:#fff;border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;gap:16px;height:80px;padding:0 24px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;left:240px;right:0}.app-header__menu-btn{color:#334155;cursor:pointer;background:0 0;border:none;border-radius:8px;flex-shrink:0;padding:6px;display:none}.app-header__menu-btn:hover{background:#f1f5f9}.app-header__dynamic-title{flex-direction:column;flex:1;justify-content:center;min-width:0;animation:.4s ease-out titleFadeIn;display:flex}@keyframes titleFadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.app-header__page-title{color:#1d4ed8;letter-spacing:-.01em;white-space:nowrap;text-overflow:ellipsis;margin:0;font-family:Outfit,sans-serif;font-size:32px;font-weight:800;line-height:1.1;overflow:hidden}.app-header__page-subtitle{color:#64748b;white-space:nowrap;text-overflow:ellipsis;margin:2px 0 0;font-size:13px;font-weight:500;overflow:hidden}.app-header__user-wrapper{z-index:1000;position:relative}.app-header__user{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:12px;flex-shrink:0;align-items:center;gap:12px;padding:6px 12px;transition:all .2s;display:flex}.app-header__user:hover,.app-header__user.active{background:#f1f5f9}.app-header__user-info{text-align:right;flex-direction:column;display:flex}.app-header__user-name{color:#1e293b;margin-bottom:2px;font-family:Outfit,sans-serif;font-size:15px;font-weight:700;line-height:1.2}.app-header__user-role{text-transform:uppercase;letter-spacing:.05em;border-radius:6px;align-self:flex-end;width:fit-content;padding:2px 8px;font-size:10px;font-weight:700}.app-header__avatar{color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb);border:2px solid #fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:14px;font-weight:600;display:flex;box-shadow:0 2px 4px #00000014}.app-header__dropdown-arrow{color:#94a3b8;transition:transform .2s}.app-header__dropdown-arrow.open{transform:rotate(180deg)}.app-header__dropdown{background:#fff;border:1px solid #f1f5f9;border-radius:12px;width:200px;padding:8px;animation:.2s ease-out dropdownFadeIn;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a}.app-header__dropdown-item{color:#475569;cursor:pointer;border-radius:8px;align-items:center;gap:12px;padding:10px 12px;font-size:14px;font-weight:600;transition:all .15s;display:flex}.app-header__dropdown-item:hover{color:#2563eb;background:#f8fafc}.app-header__dropdown-item svg{color:#94a3b8;transition:color .15s}.app-header__dropdown-item:hover svg{color:#2563eb}.app-header__dropdown-divider{background:#f1f5f9;height:1px;margin:8px 0}.app-header__dropdown-item--logout:hover{color:#ef4444;background:#fef2f2}.app-header__dropdown-item--logout:hover svg{color:#ef4444}@media (width<=1024px){.app-header{height:80px;padding:0 20px;left:0}.app-header__menu-btn{display:flex}.app-header__page-title{font-size:24px}}@media (width<=640px){.app-header{gap:10px;height:72px;padding:0 16px}.app-header__user-info{display:none}.app-header__page-title{font-size:20px}.app-header__page-subtitle{font-size:11px}.app-header__avatar{width:34px;height:34px;font-size:13px}}.welcome-container{flex-direction:column;align-items:center;gap:20px;width:100%;max-width:800px;padding-top:20px;display:flex}.welcome-header{text-align:center}.welcome-header h1{color:#1d4ed8;letter-spacing:-.01em;margin-bottom:8px;font-family:Outfit,sans-serif;font-size:48px;font-weight:800}.welcome-header p{color:#64748b;font-size:14px;font-weight:500}.selection-card-container{background:#fff;border-radius:20px;width:100%;padding:24px 32px 16px;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -2px #0000000d}.selection-grid{grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:20px;display:grid}.selection-grid>div:last-child{grid-column:span 2;justify-self:center;width:calc(50% - 8px)}.selection-card{text-align:center;cursor:pointer;background:#f8fafc;border:2px solid #0000;border-radius:16px;flex-direction:column;align-items:center;padding:24px 20px;transition:all .2s;display:flex}.selection-card:hover{background:#fff;border-color:#2563eb;transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a}.card-icon{border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:16px;display:flex}.card-icon.parent,.card-icon.vendor,.card-icon.others{color:#2563eb;background:#eff6ff}.selection-card h3{color:#0f172a;margin-bottom:4px;font-size:16px;font-weight:700}.selection-card p{color:#64748b;font-size:11px;font-weight:500}@media (width<=768px){.selection-grid{grid-template-columns:1fr}.selection-grid>div:last-child{grid-column:span 1;width:100%}.selection-card-container{padding:24px}.selection-footer{text-align:center;flex-direction:column;gap:20px}}@media (width<=768px){.form-grid{grid-template-columns:1fr}.standard-form-header h1{font-size:22px!important}.full-width-field{grid-column:span 1}.footer-top-row{flex-direction:column;align-items:center;gap:24px}.action-buttons-standard{gap:12px;width:100%}.action-buttons-standard .form-btn{flex:1;gap:6px!important;padding:10px 8px!important;font-size:13px!important}}@keyframes modalScaleUp{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media (width<=768px){.camera-modal-content{border-radius:0;flex-direction:column;max-width:100%;height:100%;display:flex}.camera-modal-overlay{padding:0}.camera-view-container{aspect-ratio:auto;flex:1}}@media print{body *{visibility:hidden}#printable-badge,#printable-badge *{visibility:visible}#printable-badge{box-shadow:none;border:1px solid #eee;position:absolute;top:0;left:50%;transform:translate(-50%)}.badge-preview-screen{background:#fff;padding:0}.badge-preview-footer{display:none}}.visitor-checkout-wrapper{flex-direction:column;align-items:center;width:100%;max-width:1000px;margin:0 auto;padding:20px;display:flex}.checkout-container{background:#fff;border:1px solid #f1f5f9;border-radius:24px;flex-direction:column;align-items:center;width:100%;max-width:600px;padding:40px;display:flex;box-shadow:0 4px 30px #00000008}.checkout-header{text-align:center;margin-bottom:32px}.checkout-header h1{color:#1d4ed8;letter-spacing:-.02em;margin:0 0 8px;font-size:28px;font-weight:800}.checkout-header p{color:#64748b;margin:0;font-size:15px;line-height:1.5}.scanner-section{width:100%;margin-bottom:32px}.scanner-viewport{aspect-ratio:1;background:#0f172a;border-radius:20px;justify-content:center;align-items:center;width:100%;display:flex;position:relative;overflow:hidden}.scanner-video{object-fit:cover;width:100%;height:100%}#scanner-video-container{width:100%;height:100%}#scanner-video-container video{border-radius:20px;object-fit:cover!important;width:100%!important;height:100%!important}.scanner-overlay{z-index:10;background:0 0;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:absolute;top:0;left:0}#scanner-video-container div,#scanner-video-container canvas{display:none!important}#scanner-video-container video{display:block!important}.scanner-frame{justify-content:center;align-items:center;width:70%;height:70%;display:flex;position:relative}.frame-corner{border-style:solid;border-color:#3b82f6;width:30px;height:30px;position:absolute}.top-left{border-width:4px 0 0 4px;border-top-left-radius:12px;top:0;left:0}.top-right{border-width:4px 4px 0 0;border-top-right-radius:12px;top:0;right:0}.bottom-left{border-width:0 0 4px 4px;border-bottom-left-radius:12px;bottom:0;left:0}.bottom-right{border-width:0 4px 4px 0;border-bottom-right-radius:12px;bottom:0;right:0}.scanner-line{background:#3b82f699;width:100%;height:2px;animation:2s linear infinite scan;position:absolute;box-shadow:0 0 15px 2px #3b82f6cc}@keyframes scan{0%{top:0}50%{top:100%}to{top:0}}.scanner-hint{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;border-radius:20px;padding:8px 16px;font-size:13px;font-weight:600;position:absolute;bottom:20px;left:50%;transform:translate(-50%)}.scanner-error{text-align:center;color:#94a3b8;flex-direction:column;align-items:center;gap:16px;padding:32px;display:flex}.scanner-error p{color:#f1f5f9;font-size:14px}.retry-btn{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:10px;padding:10px 24px;font-weight:700;transition:all .2s}.retry-btn:hover{background:#2563eb;transform:translateY(-1px)}.checkout-actions{flex-direction:column;gap:16px;width:100%;display:flex}.divider-text{text-align:center;color:#cbd5e1;align-items:center;font-size:12px;font-weight:700;display:flex}.divider-text:before,.divider-text:after{content:"";border-bottom:1px solid #f1f5f9;flex:1}.divider-text span{padding:0 12px}.manual-checkout-btn{color:#475569;cursor:pointer;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;justify-content:center;align-items:center;gap:10px;width:100%;padding:14px;font-size:15px;font-weight:700;transition:all .2s;display:flex}.manual-checkout-btn:hover{color:#1e293b;background:#f1f5f9;border-color:#cbd5e1}.checkout-container.success{text-align:center;padding:48px}.success-icon-wrap{margin-bottom:24px;animation:.5s cubic-bezier(.175,.885,.32,1.275) scaleIn}@keyframes scaleIn{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.checkout-summary-card{text-align:left;background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;flex-direction:column;gap:16px;margin:32px 0;padding:24px;display:flex}.summary-item{flex-direction:column;gap:4px;display:flex}.summary-item label{color:#94a3b8;letter-spacing:.05em;font-size:11px;font-weight:800}.summary-item span{color:#1e293b;font-size:16px;font-weight:700}.mono-text{font-family:monospace;color:#2563eb!important}.done-btn{color:#fff;cursor:pointer;background:#1e293b;border:none;border-radius:12px;width:100%;padding:14px;font-size:16px;font-weight:700;transition:all .2s}.done-btn:hover{background:#0f172a;transform:translateY(-2px)}.manual-id-form{flex-direction:column;gap:12px;width:100%;margin-top:8px;display:flex}.manual-id-input{color:#1e293b;text-align:center;letter-spacing:.05em;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;outline:none;width:100%;height:52px;padding:0 16px;font-size:15px;font-weight:600;transition:all .2s}.manual-id-input:focus{background:#fff;border-color:#2563eb;box-shadow:0 0 0 4px #2563eb1a}.manual-checkout-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:12px;justify-content:center;align-items:center;gap:10px;width:100%;height:52px;font-size:15px;font-weight:700;transition:all .2s;display:flex}.manual-checkout-btn:hover{background:#1d4ed8;transform:translateY(-2px);box-shadow:0 4px 12px #2563eb33}.checkout-btn-group{grid-template-columns:1fr 1fr!important;gap:12px!important;width:100%!important;margin-top:8px!important;display:grid!important}.checkout-btn-group .manual-checkout-btn,.checkout-btn-group .cancel-btn{white-space:nowrap!important;justify-content:center!important;align-items:center!important;width:100%!important;height:52px!important;margin:0!important;padding:0!important;font-size:14px!important;display:flex!important}@media (width<=640px){.checkout-container{padding:24px}.checkout-header h1{font-size:24px}.checkout-btn-group{gap:8px!important}.checkout-btn-group .manual-checkout-btn,.checkout-btn-group .cancel-btn{padding:0 10px!important;font-size:13px!important}.manual-checkout-btn svg{width:16px!important;min-width:16px!important;height:16px!important}.scanner-hint{display:none!important}}.table-container-v2{background:#fff;border:1px solid #f1f5f9;border-radius:24px;width:100%;overflow:hidden;box-shadow:0 4px 20px #00000005}.table-header-v2{justify-content:space-between;align-items:center;margin-bottom:24px;padding:24px 32px 0;display:flex}.table-title-v2{color:#1e293b;font-family:Outfit,sans-serif;font-size:18px;font-weight:800}.view-all-link-v2{color:#2563eb;font-size:13px;font-weight:700;text-decoration:none}.entries-table-v2 th{text-align:left;text-transform:uppercase;color:#94a3b8;letter-spacing:.05em;white-space:nowrap;border-bottom:1px solid #f1f5f9;padding:16px 24px;font-size:11px;font-weight:700}.entries-table-v2 td{vertical-align:middle;border-bottom:1px solid #f8fafc;padding:20px 24px}.entries-table-v2 tr:last-child td{border-bottom:none}.visitor-avatar-v2{color:#64748b;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;font-weight:700;display:flex;overflow:hidden}.visitor-avatar-v2 img{object-fit:cover;width:100%;height:100%}.type-pill-v2{letter-spacing:.02em;border-radius:100px;padding:4px 12px;font-size:10px;font-weight:800}.type-pill-v2.other{color:#9333ea;background:#faf5ff}.contact-cell-v2,.reason-cell-v2{color:#475569;font-size:13px;font-weight:500}.contact-cell-v2{white-space:nowrap}.datetime-cell-v2{flex-direction:column;display:flex}.date-v2{color:#1e293b;white-space:nowrap;font-size:13px;font-weight:700}.time-v2{color:#94a3b8;white-space:nowrap;font-size:11px;font-weight:600}.added-by-v2{flex-direction:column;display:flex}.added-by-name{color:#1e293b;font-size:13px;font-weight:700}.added-by-role{color:#64748b;text-transform:uppercase;letter-spacing:.02em;font-size:10px;font-weight:600}@media (width<=640px){.table-header-v2{flex-direction:column;align-items:flex-start;gap:8px;padding:16px 20px 12px}.table-title-v2{font-size:16px}.entries-table-v2 th,.entries-table-v2 td{padding:12px 16px}.visitor-avatar-v2{width:32px;height:32px;font-size:12px}.visitor-name-v2{font-size:13px}.table-footer-v2{flex-direction:column;align-items:center;gap:16px;padding:16px 20px}}.dashboard-overview{flex-direction:column;gap:14px;width:100%;display:flex}.new-entry-btn-v2{color:#fff;cursor:pointer;box-sizing:border-box;background:#2563eb;border:none;border-radius:12px;align-items:center;gap:10px;height:42px;padding:0 24px;font-size:14px;font-weight:700;text-decoration:none;transition:all .2s;display:flex;box-shadow:0 4px 12px #2563eb33}.table-container-v2{background:#fff;border:1px solid #f1f5f9;border-radius:20px;overflow:hidden;box-shadow:0 4px 20px #00000008}.table-header-v2{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.table-title-v2{color:#1e293b;font-size:18px;font-weight:700}.view-all-link-v2{color:#2563eb;font-size:14px;font-weight:600;text-decoration:none;transition:color .2s}.view-all-link-v2:hover{color:#1d4ed8}.table-responsive-wrapper{width:100%;overflow-x:auto}.entries-table-v2{border-collapse:collapse;width:100%}.entries-table-v2 th{text-align:left;color:#94a3b8;letter-spacing:.05em;text-transform:uppercase;background:#f8fafc;padding:14px 24px;font-size:11px;font-weight:700}.entries-table-v2 td{border-bottom:1px solid #f1f5f9;padding:16px 24px}.visitor-cell-v2{align-items:center;gap:12px;display:flex}.visitor-name-v2{color:#1e293b;font-size:14px;font-weight:700}.contact-cell-v2{color:#64748b;font-size:14px}.time-v2{color:#1e293b;font-size:14px;font-weight:600}.type-pill-v2{border-radius:6px;padding:4px 10px;font-size:11px;font-weight:700}.type-pill-v2.parent{color:#2563eb;background:#eff6ff}.type-pill-v2.vendor{color:#ea580c;background:#fff7ed}@media (width<=1024px){.stats-row-v2{flex-wrap:wrap}.stat-card-v2{flex:calc(50% - 12px)}}@media (width<=768px){.controls-row-v2{flex-direction:column;align-items:stretch}}.visitor-pass-card{box-sizing:border-box;background:#fff;border:1px solid #e2e8f0;border-radius:16px;width:100%;max-width:450px;margin:0 auto;padding:32px;box-shadow:0 10px 30px #0000000d}.v-pass-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:24px;display:flex}.v-pass-logo{width:auto;height:48px}.v-pass-title{color:#0f172a;font-size:18px;font-weight:500}.v-pass-body{justify-content:space-between;gap:24px;display:flex}.v-pass-info{flex-direction:column;flex:1;gap:20px;display:flex}.v-pass-field label{color:#64748b;letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px;font-size:11px;font-weight:800;display:block}.v-pass-field h1{color:#000;margin:0;font-family:Outfit,sans-serif;font-size:26px;font-weight:900;line-height:1.1}.v-pass-field p{color:#334155;margin:0;font-size:15px;font-weight:500}.v-pass-field p.type-value{color:#0f172a;font-weight:600}.v-pass-media{flex-direction:column;align-items:center;gap:24px;min-width:120px;display:flex}.v-pass-photo{background:#f1f5f9;border:4px solid #fff;border-radius:50%;width:100px;height:100px;overflow:hidden;box-shadow:0 4px 12px #0000001a}.v-pass-photo img{object-fit:cover;width:100%;height:100%}.v-pass-initials{color:#64748b;justify-content:center;align-items:center;width:100%;height:100%;font-size:32px;font-weight:800;display:flex}.v-pass-qr{background:#fff;border:1px solid #f1f5f9;border-radius:12px;flex-direction:column;align-items:center;gap:8px;padding:8px;display:flex}.v-pass-qr img{width:90px;height:90px}.v-pass-status{color:#94a3b8;letter-spacing:.05em;text-transform:uppercase;font-size:10px;font-weight:800}@media print{body *{visibility:hidden}#printable-badge,#printable-badge *{visibility:visible}#printable-badge{position:absolute;top:0;left:50%;transform:translate(-50%);box-shadow:none!important;border:1px solid #eee!important;width:450px!important;margin:0!important}.dashboard-overview{background:#fff;padding:0}.preview-modal{background:0 0!important;padding:0!important;position:absolute!important;top:0!important;left:0!important}.modal-header,.modal-footer{display:none!important}}.dashboard-content{background-color:#f8fafc;flex-direction:column;gap:14px;width:100%;max-width:1280px;margin:0 auto;padding:24px;display:flex}.stats-grid{gap:24px;width:100%;display:flex}@media (width<=1024px){.stats-grid{flex-wrap:wrap}}.stat-card{cursor:pointer;background:#fff;border:1px solid #f1f5f9;border-radius:16px;flex:1;justify-content:space-between;align-items:flex-start;min-height:110px;padding:18px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden;box-shadow:0 4px 20px #00000008}.stat-card:hover,.stat-card.gradient{background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border-color:#0000;transform:translateY(-4px);box-shadow:0 12px 24px #2563eb33}.stat-card:hover .stat-title,.stat-card.gradient .stat-title,.stat-card:hover .stat-count,.stat-card.gradient .stat-count{color:#fff!important}.stat-card:hover .stat-icon-wrapper,.stat-card.gradient .stat-icon-wrapper{color:#fff;background:#fff3}.stat-card:hover .trend-badge,.stat-card.gradient .trend-badge{color:#fff;background:#ffffff26}.stat-card-header{justify-content:flex-start;align-items:center;gap:12px;display:flex}.stat-icon-wrapper{border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.stat-icon-wrapper.parent,.stat-icon-wrapper.all{color:#2563eb;background:#eff6ff}.stat-icon-wrapper.vendor{color:#ea580c;background:#fff7ed}.stat-icon-wrapper.other{color:#9333ea;background:#faf5ff}.stat-icon-wrapper.gatepasses{color:#16a34a;background:#f0fdf4}.trend-badge{border-radius:20px;padding:4px 8px;font-size:11px;font-weight:700}.trend-badge.up{color:#10b981;background:#ecfdf5}.trend-badge.down{color:#ef4444;background:#fef2f2}.trend-badge.neutral{color:#64748b;background:#f8fafc}.stat-card-content{text-align:right;flex-direction:column;align-items:flex-end;gap:14px;display:flex}.stat-title{color:#94a3b8;letter-spacing:.05em;text-transform:uppercase;font-size:10px;font-weight:700}.stat-count{color:#0f172a;margin:0;font-size:24px;font-weight:800}.filter-bar-container{background:#fff;border:1px solid #f1f5f9;border-radius:20px;align-items:center;gap:16px;margin-top:16px;padding:20px;display:flex;box-shadow:0 4px 12px #00000005}.filter-bar{align-items:center;gap:16px;width:100%;display:flex}.filter-dropdown-v2{align-items:center;display:flex;position:relative}.new-entry-btn-v2{color:#fff;white-space:nowrap;background:#2563eb;border-radius:12px;align-items:center;gap:10px;padding:14px 24px;font-size:14px;font-weight:700;transition:all .2s;display:flex;box-shadow:0 4px 12px #2563eb33}.table-card{background-color:#fff;border:1px solid #f1f5f9;border-radius:16px;padding:24px;box-shadow:0 4px 20px #00000008}.table-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.table-header h3{color:#1e293b;font-size:18px;font-weight:700}.view-all-btn{color:#2563eb;cursor:pointer;background:0 0;border:none;font-size:14px;font-weight:700}.table-wrapper{width:100%;overflow-x:auto}.visitor-table{border-collapse:collapse;width:100%}.visitor-table th{text-align:left;text-transform:uppercase;color:#94a3b8;letter-spacing:.05em;white-space:nowrap;border-bottom:1px solid #f1f5f9;padding:16px 24px;font-size:11px;font-weight:700}.visitor-table td{color:#475569;white-space:nowrap;border-bottom:1px solid #f8fafc;padding:20px 24px;font-size:14px}.visitor-cell{align-items:center;gap:12px;display:flex}.visitor-cell img{border-radius:50%;width:36px;height:36px}.visitor-cell span{color:#1e293b;font-weight:700}.type-badge{text-transform:uppercase;border-radius:20px;padding:4px 10px;font-size:10px;font-weight:800}.type-badge.parent{color:#2563eb;background-color:#eff6ff}.type-badge.vendor{color:#ea580c;background-color:#fff7ed}.type-badge.other{color:#7c3aed;background-color:#f5f3ff}.date-cell .date{color:#1e293b;font-weight:700;display:block}.date-cell .time{color:#94a3b8;font-size:11px}.added-by-cell .added-by-name{color:#1e293b;font-weight:700;display:block}.added-by-cell .added-by-role{color:#94a3b8;font-size:10px;font-weight:600}.table-footer{justify-content:space-between;align-items:center;margin-top:24px;display:flex}.table-footer p{color:#94a3b8;font-size:13px;font-weight:600}.pagination{gap:8px;display:flex}.pagination button{color:#64748b;background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.eduguard-header{background-color:#fff!important;border-bottom:1px solid #e2e8f0!important;padding:16px 24px!important}.header-title-text{color:#2563eb!important;font-size:24px!important;font-weight:700!important}.admin-dashboard-v2{flex-direction:column;gap:14px;width:100%;display:flex}.dashboard-overview-header{margin-bottom:8px}.dashboard-title{color:#1d4ed8;margin-bottom:4px;font-family:Outfit,sans-serif;font-size:28px;font-weight:800}.dashboard-subtitle{color:#64748b;font-size:14px;font-weight:500}.stats-row-v2{gap:24px;width:100%;display:flex}.stat-card-v2{cursor:pointer;background:#fff;border:1px solid #f1f5f9;border-radius:20px;flex-direction:column;flex:1;justify-content:space-between;min-height:140px;padding:20px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden;box-shadow:0 4px 20px #00000008}.stat-card-v2:hover,.stat-card-v2.active{background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border-color:#0000;transform:translateY(-4px);box-shadow:0 12px 24px #2563eb33}.stat-card-v2:hover .stat-card-v2__label,.stat-card-v2.active .stat-card-v2__label,.stat-card-v2:hover .stat-card-v2__value,.stat-card-v2.active .stat-card-v2__value{color:#fff}.stat-card-v2:hover .stat-card-v2__icon-box,.stat-card-v2.active .stat-card-v2__icon-box{color:#fff;background:#fff3}.stat-card-v2:hover .stat-card-v2__trend,.stat-card-v2.active .stat-card-v2__trend{color:#fff;background:#ffffff26}.stat-card-v2__header{justify-content:space-between;align-items:center;width:100%;display:flex}.stat-card-v2__icon-box{border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.stat-card-v2__icon-box.blue{color:#2563eb;background:#eff6ff}.stat-card-v2__icon-box.indigo{color:#4f46e5;background:#eef2ff}.stat-card-v2__icon-box.orange{color:#ea580c;background:#fff7ed}.stat-card-v2__icon-box.purple{color:#9333ea;background:#faf5ff}.stat-card-v2__icon-box.green{color:#16a34a;background:#f0fdf4}.stat-card-v2__trend{border-radius:20px;padding:4px 10px;font-size:11px;font-weight:700}.stat-card-v2__trend.up{color:#10b981;background:#ecfdf5}.stat-card-v2__trend.down{color:#ef4444;background:#fef2f2}.stat-card-v2__trend.neutral{color:#64748b;background:#f8fafc}.stat-card-v2__info{text-align:right;flex-direction:column;align-items:flex-end;margin-top:auto;display:flex}.stat-card-v2__label{color:#94a3b8;letter-spacing:.05em;margin-bottom:4px;font-size:11px;font-weight:700}.stat-card-v2__value{color:#0f172a;font-size:32px;font-weight:800;line-height:1}.controls-row-v2{background:#fff;border:1px solid #f1f5f9;border-radius:20px;justify-content:space-between;align-items:center;gap:16px;width:100%;margin-top:16px;padding:12px 20px;display:flex;box-shadow:0 4px 12px #00000005}.search-bar-v2 input{color:#1e293b;background:#fff;border:1px solid #e2e8f0;border-radius:12px;outline:none;width:100%;padding:10px 16px 10px 48px;font-size:14px;transition:all .2s}.filter-dropdown-v2{align-items:center;width:auto;min-width:180px;display:flex;position:relative}.filter-dropdown-v2 select{color:#334155;cursor:pointer;appearance:none;background:#fff;border:1px solid #e2e8f0;border-radius:12px;outline:none;padding:10px 40px 10px 44px;font-size:14px;font-weight:600}.new-entry-btn-v2{color:#fff;background:#2563eb;border-radius:12px;align-items:center;gap:10px;padding:14px 24px;font-size:14px;font-weight:700;transition:all .2s;display:flex;box-shadow:0 4px 12px #2563eb33}@media (width<=1024px){.stats-row-v2{flex-wrap:wrap}.stat-card-v2{flex:calc(50% - 12px)}}@media (width<=768px){.controls-row-v2{flex-direction:column;align-items:stretch}}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-title h1{color:#1d4ed8;margin-bottom:4px;font-family:Outfit,sans-serif;font-size:28px;font-weight:800}.page-title p{color:#64748b;font-size:14px;font-weight:500}.export-csv-btn{color:#fff;cursor:pointer;box-sizing:border-box;background:#1d4ed8;border:none;border-radius:12px;align-items:center;gap:8px;height:42px;margin-left:auto;padding:0 24px;font-weight:600;transition:background .2s;display:flex}.log-filters{background:#fff;border:1px solid #f1f5f9;border-radius:24px;justify-content:space-between;align-items:center;gap:16px;width:100%;margin-bottom:24px;padding:16px 24px;display:flex;box-shadow:0 4px 12px #00000005}.search-bar-v2 input{color:#1e293b;box-sizing:border-box;background:#fff;border:1px solid #e2e8f0;border-radius:12px;outline:none;width:100%;height:42px;font-size:14px;transition:all .2s;padding:0 16px 0 48px!important}.filter-dropdown-v2{box-sizing:border-box;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;align-items:center;height:42px;transition:all .2s;display:flex;position:relative}.filter-dropdown-v2:hover{background:#fff;border-color:#cbd5e1}.filter-dropdown-v2 svg{color:#64748b;pointer-events:none;z-index:1;position:absolute;left:14px}.filter-dropdown-v2 select{color:#334155;cursor:pointer;appearance:none;background:0 0;border:none;outline:none;width:100%;height:100%;padding:0 36px 0 44px;font-size:14px;font-weight:600}.date-picker-v2{min-width:200px;padding:0 16px}.visitor-count-v2{color:#64748b;white-space:nowrap;margin-left:auto;padding-left:16px;font-size:14px;font-weight:500}.visitor-count-v2 strong{color:#0f172a}.filter-tabs{gap:12px;display:flex}.filter-tab{color:#64748b;cursor:pointer;border-radius:10px;padding:8px 20px;font-size:14px;font-weight:600;transition:all .2s}.filter-tab.active{color:#fff;background:#1d4ed8}.more-filters{color:#64748b;cursor:pointer;align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.visitor-count{color:#64748b;font-size:14px;font-weight:500}.records-table-container{width:100%}@media (width<=1024px){.page-header{flex-direction:column;align-items:flex-start;gap:16px}.page-title h1{font-size:28px}.page-title p{font-size:15px}.log-filters{flex-direction:column;align-items:flex-start;gap:12px;padding:16px 20px}}@media (width<=640px){.page-title h1{font-size:22px}.page-title p{font-size:13px}.export-csv-btn{border-radius:10px;padding:10px 16px;font-size:13px}.filter-tabs{flex-wrap:wrap;gap:8px}.filter-tab{padding:6px 14px;font-size:12px}.log-filters{gap:12px;padding:12px}.search-bar-v2{flex:none;width:100%}.filter-dropdown-v2,.filter-dropdown-v2 select{width:100%}.range-filter-group{flex-direction:row;gap:8px;width:100%;display:flex}.date-picker-v2{flex:1;min-width:0;padding:0 8px}.date-picker-v2 input[type=date]{width:100%;padding:10px 0;font-size:11px}.filter-label{margin-right:4px;font-size:10px}.export-csv-btn{justify-content:center;width:100%;margin-left:0!important}}.preview-modal-v2{background:#fff;border-radius:24px;flex-direction:column;width:100%;max-width:500px;animation:.3s ease-out slideUp;display:flex;overflow:hidden;box-shadow:0 20px 50px #0003}.preview-content{background:#f8fafc;padding:32px}.preview-badge{background:#fff;border:2px solid #e2e8f0;border-radius:20px;gap:24px;padding:24px;display:flex;box-shadow:0 10px 25px #0000000d}.badge-left{flex-direction:column;align-items:center;gap:16px;display:flex}.badge-photo{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:16px;justify-content:center;align-items:center;width:120px;height:120px;display:flex;overflow:hidden}.badge-photo img{object-fit:cover;width:100%;height:100%}.avatar-placeholder{color:#2563eb;font-size:32px;font-weight:800}.badge-right{flex-direction:column;flex:1;gap:16px;display:flex}.badge-field label{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:11px;font-weight:800;display:block}.badge-field p{color:#1e293b;margin:0;font-size:15px;font-weight:700}.badge-row{gap:24px;display:flex}.badge-type{text-transform:uppercase;border-radius:20px;padding:6px 12px;font-size:11px;font-weight:800}.modal-footer{background:#fff;border-top:1px solid #f1f5f9;gap:12px;padding:24px 32px;display:flex}.print-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:8px;padding:12px;font-weight:700;transition:all .2s;display:flex}.close-action-btn{color:#64748b;cursor:pointer;background:#f1f5f9;border:none;border-radius:12px;flex:1;padding:12px;font-weight:700;transition:all .2s}.close-action-btn:hover{color:#1e293b;background:#e2e8f0}@media print{.modal-overlay,.sidebar,.header-v2,.log-filters,.records-table-container{display:none!important}.preview-modal-v2{box-shadow:none;width:100%;position:static}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.custom-modal-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10000;background:#0f172a73;justify-content:center;align-items:center;padding:20px;animation:.3s ease-out modalFadeIn;display:flex;position:fixed;inset:0}.custom-modal-container{text-align:center;transform-origin:50%;background:#fff;border-radius:20px;width:100%;max-width:440px;padding:40px 32px;animation:.4s cubic-bezier(.34,1.56,.64,1) modalScaleIn;position:relative;box-shadow:0 25px 50px -12px #00000040}.modal-icon-wrapper{border-radius:24px;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 28px;animation:.6s ease-out iconBounce;display:flex}.modal-icon-wrapper.warning{color:#dc2626;background:#fef2f2}.modal-icon-wrapper.success{color:#16a34a;background:#f0fdf4}.modal-icon-wrapper.info{color:#1e3a8a;background:#eff6ff}.custom-modal-container h3{color:#1e293b;letter-spacing:-.02em;margin-bottom:12px;font-size:24px;font-weight:700}.custom-modal-container p{color:#64748b;margin-bottom:36px;font-size:16px;line-height:1.6}.modal-actions-v2{gap:12px;display:flex}.modal-btn-v2{cursor:pointer;border:none;border-radius:14px;flex:1;justify-content:center;align-items:center;gap:8px;height:52px;font-size:16px;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.modal-btn-v2:disabled{opacity:.7;cursor:not-allowed;transform:none!important}.modal-btn-v2.cancel{color:#64748b;background:#f1f5f9}.modal-btn-v2.cancel:hover:not(:disabled){background:#e2e8f0}.modal-btn-v2.confirm{color:#fff;background:#1e3a8a}.modal-btn-v2.confirm:hover:not(:disabled){background:#172554;transform:translateY(-2px);box-shadow:0 10px 15px -3px #1e3a8a4d}.modal-btn-v2.confirm.danger{background:#dc2626}.modal-btn-v2.confirm.danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-2px);box-shadow:0 10px 15px -3px #dc26264d}.modal-spinner{border:3px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalScaleIn{0%{opacity:0;transform:scale(.9)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes iconBounce{0%{transform:scale(0)}70%{transform:scale(1.1)}to{transform:scale(1)}}.toast-container{z-index:10001;flex-direction:column;gap:12px;display:flex;position:fixed;top:32px;right:32px}.toast-card{background:#fff;border-left:5px solid #16a34a;border-radius:16px;align-items:center;gap:16px;min-width:320px;padding:16px 20px;animation:.4s cubic-bezier(.175,.885,.32,1.275) toastSlideIn;display:flex;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a}.toast-icon{color:#16a34a;flex-shrink:0}.toast-info h4{color:#1e293b;margin:0;font-size:15px;font-weight:700}.toast-info p{color:#64748b;margin:4px 0 0;font-size:13px}@keyframes toastSlideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.staff-page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.staff-title h1{color:#1d4ed8;margin-bottom:4px;font-family:Outfit,sans-serif;font-size:28px;font-weight:800}.staff-title p{color:#64748b;font-size:14px;font-weight:500}.add-gateguard-btn{color:#fff;cursor:pointer;background:#1d4ed8;border:none;border-radius:12px;align-items:center;gap:10px;padding:12px 24px;font-weight:600;transition:all .2s;display:flex}.add-gateguard-btn:hover{background:#1e40af}.staff-stats-row{gap:24px;margin-bottom:32px;display:flex}.staff-stat-card{background:#fff;border:1px solid #f1f5f9;border-radius:16px;flex:1;justify-content:space-between;align-items:flex-start;min-height:90px;padding:16px;display:flex;position:relative}.stat-icon-box{color:#1d4ed8;background:#eff6ff;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.staff-stat-card .active-pill{color:#15803d;background:#dcfce7;border-radius:100px;padding:2px 10px;font-size:10px;font-weight:700;position:absolute;bottom:12px;left:16px}.stat-info-group{text-align:right;flex-direction:column;align-items:flex-end;gap:2px;display:flex}.stat-val-text{color:#0f172a;font-size:24px;font-weight:800;display:block}.stat-label-text{color:#64748b;font-size:11px;font-weight:600}.directory-card{background:#fff;border:1px solid #f1f5f9;border-radius:24px;overflow:hidden;box-shadow:0 4px 6px -1px #0000000d}.controls-row-v2{background:#fff;border:1px solid #f1f5f9;border-radius:24px;justify-content:space-between;align-items:center;gap:16px;width:100%;margin-bottom:24px;padding:16px 24px;display:flex;box-shadow:0 4px 12px #00000005}.new-entry-btn-v2:hover{background:#1d4ed8;transform:translateY(-2px);box-shadow:0 6px 20px #2563eb4d}.staff-table{border-collapse:collapse;width:100%}.staff-table th{text-align:left;text-transform:uppercase;color:#94a3b8;letter-spacing:.05em;background:#f8fafc;border-bottom:1px solid #f1f5f9;padding:16px 24px;font-size:11px;font-weight:700}.staff-table td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:20px 24px}.staff-profile-cell{align-items:center;gap:16px;display:flex}.staff-avatar{object-fit:cover;border-radius:50%;width:44px;height:44px}.staff-name{color:#1e293b;margin-bottom:2px;font-size:15px;font-weight:700;display:block}.staff-id{color:#94a3b8;font-size:12px}.role-pill{border-radius:100px;padding:6px 16px;font-size:12px;font-weight:600}.role-admin{color:#1d4ed8;background:#eff6ff}.role-super_admin{color:#7c3aed;background:#f5f3ff}.role-gateguard{color:#16a34a;background:#f0fdf4}.email-cell,.date-cell{color:#64748b;font-size:14px}.action-group-v2{align-items:center;gap:8px;display:flex}.action-btn-v2{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;padding:0;transition:all .2s;display:flex}.action-btn-v2:hover{color:#1e293b;background:#f8fafc;border-color:#cbd5e1;transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}.action-btn-v2.edit:hover{color:#2563eb;background:#eff6ff;border-color:#dbeafe}.action-btn-v2.delete:hover{color:#ef4444;background:#fef2f2;border-color:#fee2e2}.table-footer-v2{border-top:1px solid #f8fafc;justify-content:space-between;align-items:center;padding:24px 32px 32px;display:flex}.showing-entries-v2{color:#94a3b8;font-size:12px;font-weight:600}.pagination-v2{gap:8px;display:flex}.page-btn-v2{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.page-btn-v2:hover{color:#1e293b;background:#f8fafc;border-color:#cbd5e1}@media (width<=1024px){.staff-page-header{flex-direction:column;align-items:flex-start;gap:16px}.staff-stats-row{flex-wrap:wrap;gap:16px}.staff-stat-card{flex:calc(50% - 8px)}.directory-toolbar{flex-direction:column;align-items:stretch;gap:16px}.directory-search{width:100%}.directory-card{-webkit-overflow-scrolling:touch;overflow-x:auto}.staff-table{min-width:600px}}@media (width<=640px){.staff-title h1{font-size:22px}.staff-title p{font-size:13px}.add-gateguard-btn{padding:10px 16px;font-size:13px}.staff-stats-row{flex-direction:column}.staff-stat-card{flex:100%;padding:18px}.stat-val-text{font-size:24px}.directory-card{border-radius:16px;padding:12px}.dir-actions{flex-wrap:wrap;gap:8px}.dir-btn{padding:8px 12px;font-size:12px}.directory-footer{flex-direction:column;align-items:center;gap:12px}}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;background:#0f172a99;justify-content:center;align-items:center;padding:20px;animation:.3s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:24px;width:100%;max-width:850px;animation:.4s cubic-bezier(.16,1,.3,1) slideUp;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}.modal-header{background:linear-gradient(90deg,#f8fafc,#fff);border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:flex-start;padding:32px 40px;display:flex}.modal-title h2{color:#1d4ed8;margin-bottom:8px;font-family:Outfit,sans-serif;font-size:18px;font-weight:800}.modal-title p{color:#64748b;font-size:14px;font-weight:500}.close-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:12px;padding:8px;transition:all .2s}.close-btn:hover{color:#1e293b;background:#f1f5f9;transform:rotate(90deg)}.gateguard-form{padding:40px}.grid{display:grid}.grid-cols-1{grid-template-columns:1fr}.gap-4{gap:16px}@media (width>=768px){.md\:grid-cols-2{grid-template-columns:1fr 1fr}}.form-group.full-width{grid-column:span 2}.form-group label{color:#475569;margin-left:4px;font-size:13px;font-weight:700}.input-with-icon{box-sizing:border-box;align-items:center;width:100%;display:flex;position:relative}.input-with-icon svg{color:#94a3b8;pointer-events:none;z-index:5;display:block;position:absolute;top:50%;left:18px;transform:translateY(-50%)}.gateguard-form .input-with-icon input,.gateguard-form .input-with-icon select{color:#1e293b;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;outline:none;font-size:14px;font-weight:500;transition:all .2s;display:block;box-sizing:border-box!important;width:100%!important;height:48px!important;padding:0 16px 0 52px!important}.input-with-icon input:focus,.input-with-icon select:focus{background:#fff;border-color:#2563eb;box-shadow:0 0 0 4px #2563eb1a}.input-with-icon select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 16px center;background-repeat:no-repeat;padding-right:44px!important}.form-footer{justify-content:center;align-items:center;gap:16px;margin-top:40px;display:flex}.cancel-btn{color:#64748b;cursor:pointer;background:#f1f5f9;border:none;border-radius:10px;justify-content:center;align-items:center;width:120px;height:38px;font-size:13px;font-weight:700;transition:all .2s;display:flex}.submit-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:10px;justify-content:center;align-items:center;width:120px;height:38px;font-size:13px;font-weight:700;transition:all .2s;display:flex;box-shadow:0 4px 10px #2563eb33}.submit-btn:hover{background:#1d4ed8;transform:translateY(-2px);box-shadow:0 8px 20px #2563eb4d}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (width<=640px){.form-grid{grid-template-columns:1fr}.form-group.full-width{grid-column:span 1}.modal-content{border-radius:0;height:100%;max-height:100vh;overflow-y:auto}.modal-overlay{padding:0}}.gatepass-management-v2{padding:0;animation:.4s ease-out fadeIn}.anim-fade-in{animation:.4s ease-out fadeIn}.controls-row-v2{box-sizing:border-box;background:#fff;border:1px solid #f1f5f9;border-radius:24px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;width:100%;margin-bottom:24px;padding:16px 24px;display:flex;box-shadow:0 4px 12px #00000005}.search-bar-v2 svg{color:#94a3b8;position:absolute;left:16px}.search-bar-v2 input{color:#1e293b;box-sizing:border-box;background:#fff;border:1px solid #e2e8f0;border-radius:12px;outline:none;width:100%;height:42px;padding:0 16px 0 48px;font-size:14px;transition:all .2s}.search-bar-v2 input:focus{border-color:#2563eb;box-shadow:0 0 0 4px #2563eb14}.filter-dropdown-v2{box-sizing:border-box;align-items:center;width:auto;min-width:180px;height:42px;display:flex;position:relative}.filter-dropdown-v2 svg{color:#64748b;pointer-events:none;position:absolute;left:16px}.filter-dropdown-v2 select{color:#334155;cursor:pointer;appearance:none;background:#fff;border:1px solid #e2e8f0;border-radius:12px;outline:none;height:100%;padding:0 40px 0 44px;font-size:14px;font-weight:600}.new-entry-btn-v2{color:#fff;box-sizing:border-box;background:#2563eb;border:none;border-radius:12px;align-items:center;gap:10px;height:42px;padding:0 24px;font-size:14px;font-weight:700;transition:all .2s;display:flex;box-shadow:0 4px 12px #2563eb33}.range-filter-group{align-items:center;gap:12px;display:flex}.date-picker-v2{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;min-width:200px;padding:0 16px}.filter-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;margin-right:8px;font-size:11px;font-weight:800}.date-picker-v2 input[type=date]{color:#1e293b;cursor:pointer;background:0 0;border:none;outline:none;align-items:center;width:100%;height:100%;padding:0;font-size:14px;font-weight:600;display:flex}.status-badge{text-transform:uppercase;letter-spacing:.05em;border-radius:99px;padding:6px 12px;font-size:11px;font-weight:700}.status-badge.approved{color:#15803d;background:#dcfce7}.status-badge.pending{color:#854d0e;background:#fef9c3}.entry-mode-container{width:100%}.gatepass-entry-grid{grid-template-columns:1.2fr .8fr;align-items:start;gap:24px;display:grid}.form-card-v2{box-sizing:border-box;background:#fff;border:1px solid #f1f5f9;border-radius:24px;width:100%;padding:32px;box-shadow:0 10px 40px #00000008}.form-header-v2{margin-bottom:24px}.form-header-v2 h3{color:#1e293b;margin-bottom:4px;font-family:Outfit,sans-serif;font-size:20px;font-weight:800}.form-header-v2 p{color:#64748b;font-size:14px;font-weight:500}.form-grid-v2{flex-direction:column;gap:20px;display:flex}.form-row-v2{grid-template-columns:repeat(12,1fr);gap:16px;width:100%;display:grid}.form-group-v2{flex-direction:column;min-width:0;display:flex}.form-group-v2.span-8{grid-column:span 8}.form-group-v2.span-4{grid-column:span 4}.form-group-v2.span-2{grid-column:span 2}.form-group-v2 label{color:#2563eb;margin-bottom:8px;font-size:13px;font-weight:700;display:block}.form-group-v2 input,.form-group-v2 select,.form-group-v2 textarea{color:#1e293b;box-sizing:border-box;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;outline:none;width:100%;padding:12px 16px;font-size:14px;font-weight:500;transition:all .2s}.form-group-v2 input:focus,.form-group-v2 select:focus,.form-group-v2 textarea:focus{background:#fff;border-color:#2563eb;box-shadow:0 0 0 4px #2563eb14}.form-group-v2 textarea{resize:none;height:100px}.generate-btn-v2{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:12px;justify-content:center;align-items:center;gap:10px;width:100%;margin-top:24px;padding:16px;font-size:15px;font-weight:700;transition:all .2s;display:flex}.generate-btn-v2:hover{background:#1d4ed8;transform:translateY(-2px);box-shadow:0 8px 20px #2563eb33}.preview-card-v2{flex-direction:column;gap:20px;min-width:0;display:flex}.preview-actions-v2{gap:12px;display:flex}.back-btn-v2,.print-pass-btn-v2{cursor:pointer;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:10px;padding:14px;font-size:14px;font-weight:700;transition:all .2s;display:flex}.back-btn-v2{color:#64748b;background:#fff;border:1px solid #e2e8f0}.back-btn-v2:hover{color:#1e293b;background:#f8fafc}.print-pass-btn-v2{color:#fff;background:#2563eb;border:none;box-shadow:0 4px 12px #2563eb33}.print-pass-btn-v2:disabled{cursor:not-allowed;box-shadow:none;opacity:.6;background:#94a3b8}.print-pass-btn-v2:not(:disabled):hover{background:#1d4ed8;transform:translateY(-2px);box-shadow:0 6px 16px #2563eb4d}.visitor-badge-card{box-sizing:border-box;background:#fff;border:1px solid #e2e8f0;border-radius:20px;width:100%;box-shadow:0 10px 30px #0000000d}.badge-logo{width:auto;height:50px}.badge-visitor-name{color:#000;margin:0;font-family:Outfit,sans-serif;font-size:28px;font-weight:900;line-height:1.1}.badge-qr-section-right{flex-direction:column;align-items:center;gap:8px;display:flex}.badge-visitor-id-small{color:#94a3b8;letter-spacing:.05em;font-family:monospace;font-size:12px;font-weight:800}.new-entry-btn-v2.active-toggle{color:#ef4444;box-shadow:none;background:#f1f5f9;border:1px solid #fee2e2}.new-entry-btn-v2.active-toggle:hover{background:#fee2e2;transform:translateY(-2px)}@media (width<=1024px){.gatepass-entry-grid{grid-template-columns:1fr}}@media (width<=640px){.gatepass-filters{flex-wrap:wrap;gap:12px;padding:16px}.gatepass-filters .search-bar-v2{flex:none;width:100%}.gatepass-filters .filter-dropdown-v2,.gatepass-filters .filter-dropdown-v2 select,.gatepass-filters>div:last-child{width:100%}.gatepass-filters .new-entry-btn-v2{justify-content:center;width:100%}.form-row-v2{flex-direction:column!important;gap:12px!important;display:flex!important}.form-group-v2,.form-group-v2.span-8,.form-group-v2.span-4,.form-group-v2.span-2{grid-column:span 12!important;width:100%!important;min-width:0!important}.form-card-v2{border-radius:16px;min-width:0;padding:24px 16px!important}.form-header-v2 h3{font-size:18px}.badge-content{padding:20px}.badge-middle-section{flex-direction:column;gap:20px}.badge-visitor-name{word-break:break-word;font-size:20px}.badge-header-row{text-align:center;flex-direction:column;align-items:center;gap:12px;padding-bottom:16px}.badge-logo{width:auto;height:36px}.badge-type-label{font-size:14px}.visitor-badge-card{min-width:0}.preview-actions-v2{flex-direction:column;width:100%}.preview-actions-v2 button{width:100%}}@media print{body *{visibility:hidden}#printable-badge,#printable-badge *{visibility:visible}#printable-badge{position:absolute;top:0;left:50%;transform:translate(-50%);box-shadow:none!important;border:1px solid #eee!important;width:450px!important}.gatepass-management-v2{background:#fff;padding:0}.preview-actions-v2,.gatepass-filters,.table-container-v2,.form-card-v2{display:none!important}}.export-csv-btn{color:#fff;cursor:pointer;box-sizing:border-box;white-space:nowrap;background:#1d4ed8;border:none;border-radius:12px;flex-shrink:0;align-items:center;gap:8px;height:42px;padding:0 24px;font-weight:600;transition:background .2s;display:flex}.export-csv-btn:hover{background:#1e40af}.export-csv-btn svg{margin-right:4px}@media (width<=768px){.form-grid{grid-template-columns:1fr}.standard-form-header h1{font-size:22px!important}.full-width-field{grid-column:span 1}.footer-top-row{flex-direction:column;align-items:center;gap:24px}.action-buttons-standard{gap:12px;width:100%}.action-buttons-standard .form-btn{flex:1;gap:6px!important;padding:10px 8px!important;font-size:13px!important}}@media (width<=768px){.camera-modal-content{border-radius:0;flex-direction:column;max-width:100%;height:100%;display:flex}.camera-modal-overlay{padding:0}.camera-view-container{aspect-ratio:auto;flex:1}}@media print{body *{visibility:hidden}#printable-badge,#printable-badge *{visibility:visible}#printable-badge{box-shadow:none;border:1px solid #eee;position:absolute;top:0;left:50%;transform:translate(-50%)}.badge-preview-screen{background:#fff;padding:0}.badge-preview-footer{display:none}}.visitor-entry-page-wrapper{flex-direction:column;justify-content:flex-start;align-items:center;width:100%;min-height:auto;padding-top:0;display:flex}.standard-form-header{text-align:left;width:100%;margin-bottom:16px}.standard-form-header h1{color:#1d4ed8;letter-spacing:-.02em;margin:0;font-family:Outfit,sans-serif;font-size:28px;font-weight:800}.standard-form-header p{color:#64748b;margin:4px 0 0;font-size:14px;font-weight:500;line-height:1.4}.security-badge-standard{color:#2563eb;letter-spacing:.05em;background:#eff6ff;border:1px solid #dbeafe;border-radius:8px;align-items:center;gap:8px;margin-bottom:16px;padding:6px 14px;font-size:12px;font-weight:800;display:inline-flex}.entry-card-standard{background:#fff;border:1px solid #f1f5f9;border-radius:24px;flex-direction:column;gap:0;width:100%;margin-bottom:20px;padding:32px;display:flex;box-shadow:0 4px 30px #00000008}.input-with-icon{align-items:center;display:flex;position:relative}.field-icon{pointer-events:none;z-index:5;position:absolute;top:50%;left:18px;transform:translateY(-50%)}.input-with-icon input{color:#0f172a;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;outline:none;width:100%;height:40px;font-size:14px;font-weight:500;transition:all .2s;box-sizing:border-box!important;padding:0 16px 0 52px!important}.input-with-icon input:focus{border-color:#2563eb;box-shadow:0 0 0 4px #2563eb14}.form-row-nested{grid-template-columns:1fr 1fr;gap:12px;display:grid}.custom-dropdown-container{z-index:1;flex-direction:column;gap:4px;width:100%;display:flex;position:relative}.custom-dropdown-container label{color:#2563eb;font-size:14px;font-weight:700}.custom-dropdown-container.active{z-index:1001}.custom-select-box{color:#0f172a;cursor:pointer;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;justify-content:space-between;align-items:center;width:100%;height:40px;font-size:14px;font-weight:500;transition:all .2s;display:flex;position:relative;box-sizing:border-box!important;padding:0 16px 0 52px!important}.dropdown-field-icon{color:#94a3b8;z-index:5;align-items:center;display:flex;position:absolute;top:50%;left:18px;transform:translateY(-50%)}.select-value{flex:1}.select-value.placeholder{color:#94a3b8;font-weight:500}.custom-select-box.active{border-color:#2563eb;box-shadow:0 0 0 4px #2563eb14}.dropdown-options{z-index:1000;background:#fff;border:1px solid #e2e8f0;border-radius:12px;width:100%;max-height:400px;position:absolute;top:calc(100% + 4px);left:0;overflow-y:auto;box-shadow:0 10px 25px #0000001a}.option-item{color:#1e293b;cursor:pointer;padding:12px 16px;font-size:15px;font-weight:600;transition:background .1s}.option-item:hover{background:#f8fafc}.option-item.selected{color:#2563eb;background:#eff6ff}.full-width-field{grid-column:span 2}.photo-profile-section-standard{background:#f8fafc;border:2px dashed #e2e8f0;border-radius:20px;flex-direction:column;align-items:center;gap:4px;margin-top:-8px;padding:4px 16px;display:flex}.photo-circle-standard{cursor:pointer;background:#cbd5e1;border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;display:flex;position:relative}.photo-preview-img-standard{object-fit:cover;border:3px solid #fff;border-radius:50%;width:100%;height:100%}.upload-placeholder-standard{text-align:center;flex-direction:column;align-items:center;gap:4px;padding:0 8px;display:flex;transform:translateY(-10px)}.upload-placeholder-standard span{color:#64748b;letter-spacing:.02em;text-align:center;max-width:80px;font-size:11px;font-weight:700;line-height:1.3}.edit-btn-standard{cursor:pointer;background:#2563eb;border:3px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;display:flex;position:absolute;bottom:0;right:0;box-shadow:0 4px 10px #2563eb4d}.photo-label-standard{color:#64748b;margin:0;font-size:14px;font-weight:700}.standard-form-footer{flex-direction:column;gap:16px;margin-top:24px;display:flex}.footer-top-row{justify-content:space-between;align-items:center;width:100%;display:flex}.security-info-standard{color:#94a3b8;align-items:center;gap:10px;font-size:13px;font-weight:600;display:flex}.action-buttons-standard{grid-template-columns:1fr 1fr!important;gap:16px!important;width:100%!important;display:grid!important}.form-btn{cursor:pointer;border-radius:12px;justify-content:center;align-items:center;gap:10px;padding:10px 24px;font-size:14px;font-weight:700;transition:all .2s;display:flex}.form-btn.primary{color:#fff;background:#2563eb;border:none;box-shadow:0 4px 12px #2563eb33}.form-btn.primary:hover{background:#1d4ed8;transform:translateY(-2px);box-shadow:0 6px 20px #2563eb4d}.form-btn.secondary{color:#64748b;background:#f1f5f9;border:1px solid #e2e8f0}.form-btn.secondary:hover{color:#1e293b;background:#e2e8f0}.terminal-footer-standard{background:#f8fafc;border:1px solid #f1f5f9;border-top:none;border-radius:0 0 24px 24px;justify-content:space-between;width:100%;margin-top:-24px;padding:12px 32px;display:flex}.textarea-with-icon-standard{width:100%;position:relative}.textarea-with-icon-standard textarea{color:#0f172a;resize:none;background:#fff;border:1px solid #e2e8f0;border-radius:12px;outline:none;min-height:120px;font-size:15px;font-weight:600;transition:all .2s;box-sizing:border-box!important;width:100%!important;padding:16px 16px 16px 52px!important}.textarea-with-icon-standard textarea:focus{border-color:#2563eb;box-shadow:0 0 0 4px #2563eb14}.field-icon-textarea{pointer-events:none;z-index:5;position:absolute;top:18px;left:18px}.form-container-standard{flex-direction:column;gap:0;width:100%;max-width:1000px;display:flex}@media (width<=768px){.form-grid{grid-template-columns:1fr}.standard-form-header h1{font-size:22px!important}.full-width-field{grid-column:span 1}.footer-top-row{flex-direction:column;align-items:center;gap:24px}.action-buttons-standard{gap:12px;width:100%}.action-buttons-standard .form-btn{flex:1;gap:6px!important;padding:10px 8px!important;font-size:13px!important}}.entry-card-standard.parent-compact-card{gap:0}.photo-profile-section-standard.parent-compact-section{gap:2px;margin-top:-8px;padding:4px 12px}.photo-circle-standard.parent-compact-circle{width:90px;height:90px}.camera-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;background:#0f172ad9;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.camera-modal-content{background:#fff;border-radius:24px;width:100%;max-width:500px;animation:.3s cubic-bezier(.4,0,.2,1) modalScaleUp;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}.camera-modal-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.camera-modal-header h3{color:#1e293b;margin:0;font-family:Outfit,sans-serif;font-size:18px;font-weight:800}.close-camera-btn{color:#64748b;cursor:pointer;background:#f1f5f9;border:none;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s;display:flex}.close-camera-btn:hover{color:#1e293b;background:#e2e8f0;transform:rotate(90deg)}.camera-view-container{aspect-ratio:4/3;background:#000;width:100%;position:relative;overflow:hidden}.camera-video-feed{object-fit:cover;width:100%;height:100%}.camera-overlay-frame{pointer-events:none;border:2px solid #ffffff80;border-radius:50%;width:280px;height:280px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 1000px #0006}.camera-modal-footer{background:#f8fafc;flex-direction:column;align-items:center;gap:16px;padding:24px;display:flex}.camera-modal-footer p{color:#64748b;margin:0;font-size:13px;font-weight:600}.capture-action-btn{cursor:pointer;background:#fff;border:4px solid #2563eb;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;padding:4px;transition:all .2s;display:flex}.capture-action-btn:hover{transform:scale(1.05)}.capture-action-btn:active{transform:scale(.95)}.capture-btn-inner{background:#2563eb;border-radius:50%;width:100%;height:100%;transition:all .2s}.capture-action-btn:hover .capture-btn-inner{background:#1d4ed8}.photo-profile-section-standard{cursor:pointer;transition:all .2s}.photo-profile-section-standard:hover{background:#eff6ff;border-color:#2563eb}@media (width<=768px){.camera-modal-content{border-radius:0;flex-direction:column;max-width:100%;height:100%;display:flex}.camera-modal-overlay{padding:0}.camera-view-container{aspect-ratio:auto;flex:1}}.badge-preview-screen{background:#f1f5f9;justify-content:center;width:100%;min-height:100%;padding:40px 20px;display:flex}.badge-preview-container{flex-direction:column;gap:24px;width:100%;max-width:450px;display:flex}.badge-preview-footer{justify-content:space-between;align-items:center;gap:16px;margin-top:8px;display:flex}.back-btn,.print-btn{cursor:pointer;border-radius:10px;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:700;transition:all .2s;display:flex}.back-btn{color:#64748b;background:#fff;border:1px solid #e2e8f0}.back-btn:hover{color:#1e293b;background:#f8fafc}.print-btn{color:#fff;background:#2563eb;border:none;box-shadow:0 4px 12px #2563eb33}.print-btn:hover{background:#1d4ed8;transform:translateY(-2px)}.visitor-badge-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;width:100%;max-width:450px;margin:0 auto;position:relative;overflow:hidden;box-shadow:0 10px 40px #00000014}.badge-top-accent{background:linear-gradient(90deg,#2563eb,#3b82f6);height:12px}.visitor-badge-card{background:#fff;border-radius:16px;width:450px;margin:0 auto;overflow:hidden;box-shadow:0 10px 40px #0000001a}.badge-content{flex-direction:column;gap:32px;padding:32px;display:flex}.badge-header-row{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding-bottom:16px;display:flex}.badge-logo{object-fit:contain;width:auto;height:60px}.badge-type-label{color:#0f172a;font-size:18px;font-weight:500}.badge-middle-section{justify-content:space-between;align-items:flex-start;gap:24px;display:flex}.badge-info-left{flex-direction:column;flex:1;gap:20px;display:flex}.badge-info-item label{color:#64748b;letter-spacing:.1em;margin-bottom:4px;font-size:12px;font-weight:800;display:block}.badge-visitor-name{color:#000;margin:0;font-size:36px;font-weight:900;line-height:1.1}.badge-text-primary{color:#1e293b;margin:0;font-size:20px;font-weight:600}.badge-text-secondary{color:#475569;margin:0;font-size:16px;font-weight:500}.badge-photo-right{flex-direction:column;flex-shrink:0;align-items:center;gap:32px;display:flex}.badge-photo-circle{background:#f1f5f9;border:4px solid #fff;border-radius:50%;width:110px;height:110px;overflow:hidden;box-shadow:0 4px 15px #0000001a}.badge-photo-img{object-fit:cover;width:100%;height:100%}.badge-qr-section-right{flex-direction:column;align-items:center;gap:4px;padding-top:8px;display:flex}.badge-qr-image-small{background:#fff;border:1px solid #f1f5f9;border-radius:8px;width:100px;height:100px;padding:4px}.badge-visitor-id-small{color:#94a3b8;letter-spacing:.05em;margin:0;font-family:monospace;font-size:11px;font-weight:800}@media print{body *{visibility:hidden}#printable-badge,#printable-badge *{visibility:visible}#printable-badge{box-shadow:none;border:1px solid #eee;position:absolute;top:0;left:50%;transform:translate(-50%)}.badge-preview-screen{background:#fff;padding:0}.badge-preview-footer{display:none}}.stepper-box{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;align-items:center;width:100%;height:40px;transition:all .2s;display:flex;position:relative;box-sizing:border-box!important}.stepper-field-icon{color:#94a3b8;z-index:5;align-items:center;display:flex;position:absolute;top:50%;left:18px;transform:translateY(-50%)}.stepper-controls{justify-content:space-between;align-items:center;width:100%;height:100%;padding:0 12px 0 52px;display:flex;box-sizing:border-box!important}.step-btn{color:#64748b;cursor:pointer;background:#f1f5f9;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;transition:all .2s;display:flex}.step-btn:hover{color:#1e293b;background:#e2e8f0}.step-btn:active{transform:scale(.95)}.step-btn.plus{color:#2563eb;background:#eff6ff}.step-btn.plus:hover{background:#dbeafe}.step-value{color:#1e293b;text-align:center;min-width:30px;font-size:14px;font-weight:600}.stepper-box:focus-within{border-color:#2563eb;box-shadow:0 0 0 4px #2563eb14}.student-entry-page-wrapper{flex-direction:column;justify-content:flex-start;align-items:stretch;width:100%;padding:0;display:flex}.form-section-title{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.form-section-title h3{color:#1e293b;align-items:center;gap:12px;margin:0;font-family:Outfit,sans-serif;font-size:18px;font-weight:800;display:flex}.section-divider{background:#2563eb;border-radius:2px;width:60px;height:4px}.premium-select{color:#0f172a;cursor:pointer;appearance:none;background:#f8fafc url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") right 18px center no-repeat;border:1px solid #e2e8f0;border-radius:10px;outline:none;width:100%;height:45px;padding:0 16px;font-size:14px;font-weight:500;transition:all .2s}.premium-select:focus{border-color:#2563eb;box-shadow:0 0 0 4px #2563eb14}.student-entry-page-wrapper .entry-card-standard{margin-top:0}.student-entry-page-wrapper .form-container-standard{max-width:none}.form-grid{margin-bottom:20px}.photo-profile-section-standard{margin:40px 0}.form-or-divider{align-items:center;gap:16px;width:100%;margin:16px 0;display:flex}.or-line{background:#e2e8f0;flex:1;height:1px}.form-or-divider span{color:#94a3b8;background:#f8fafc;padding:0 8px;font-size:13px;font-weight:800}.vendor-entry-page-wrapper{flex-direction:column;justify-content:flex-start;align-items:stretch;width:100%;padding:0;display:flex}.vendor-entry-page-wrapper .entry-card-standard{margin-top:0}.master-records-container{flex-direction:column;gap:20px;width:100%;display:flex}.master-controls{background:#fff;border:1px solid #f1f5f9;border-radius:24px;justify-content:space-between;align-items:center;gap:20px;width:100%;margin-bottom:24px;padding:16px 24px;display:flex;box-shadow:0 4px 12px #00000005}.header-content h1{color:#1e293b;margin:0 0 8px;font-size:28px;font-weight:800}.header-content p{color:#64748b;margin:0}.search-bar-v2{flex:1;align-items:center;display:flex;position:relative}.search-bar-v2 svg{color:#94a3b8;pointer-events:none;position:absolute;left:16px}.search-bar-v2 input{color:#1e293b;background:#fff;border:1px solid #e2e8f0;border-radius:12px;outline:none;width:100%;padding:10px 16px 10px 48px;font-size:15px;transition:all .2s;box-shadow:inset 0 2px 4px #00000005}.search-bar-v2 input:focus{background:#fff;border-color:#2563eb;box-shadow:0 0 0 4px #2563eb1a}.tab-navigation{background:#f1f5f9;border-radius:16px;gap:12px;width:fit-content;padding:6px;display:flex}.tab-btn{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:12px;padding:10px 24px;font-size:14px;font-weight:700;transition:all .2s}.tab-btn:hover{color:#1e293b}.tab-btn.active{color:#2563eb;background:#fff;box-shadow:0 4px 12px #0000000d}.records-table-container{background:#fff;border:1px solid #e2e8f0;border-radius:20px;overflow:hidden;box-shadow:0 4px 6px -1px #0000000d}.master-table{border-collapse:collapse;width:100%}.master-table th{text-align:left;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:16px 24px;font-size:11px;font-weight:700}.master-table td{color:#475569;border-bottom:1px solid #f1f5f9;padding:16px 24px;font-size:15px}.master-table tr:hover td{background:#f8fafc}.user-info strong{color:#1e293b;font-weight:700}.badge-type{border-radius:20px;padding:4px 10px;font-size:12px;font-weight:700}.badge-type.parent{color:#166534;background:#dcfce7}.badge-type.vendor{color:#854d0e;background:#fef9c3}.badge-type.other{color:#475569;background:#f1f5f9}.loading-state{text-align:center;color:#94a3b8;padding:64px}.spinner{border:3px solid #f3f3f3;border-top-color:#2563eb;border-radius:50%;width:40px;height:40px;margin:0 auto 16px;animation:1s linear infinite spin}.no-records{text-align:center;color:#94a3b8;padding:64px!important}.action-btns{gap:8px;display:flex}.action-btn{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.action-btn:hover{color:#2563eb;background:#f8fafc;border-color:#2563eb}.action-btn.delete:hover{color:#ef4444;background:#fef2f2;border-color:#ef4444}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0f172a99;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.edit-modal-v2{background:#fff;border-radius:24px;flex-direction:column;width:100%;max-width:650px;max-height:90vh;display:flex;box-shadow:0 20px 50px #0003}.modal-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:24px;display:flex}.modal-header h3{color:#1e293b;margin:0;font-size:20px;font-weight:800}.close-btn{color:#64748b;cursor:pointer;background:#f1f5f9;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:20px;display:flex}.form-scroll-area{padding:24px;overflow-y:auto}.form-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:#2563eb;font-size:13px;font-weight:700}.form-group input,.form-group select{border:1px solid #e2e8f0;border-radius:12px;outline:none;padding:12px 16px;font-size:15px;transition:all .2s}.form-group input:focus{border-color:#2563eb;box-shadow:0 0 0 4px #2563eb1a}.modal-footer{border-top:1px solid #f1f5f9;justify-content:flex-end;gap:12px;padding:24px;display:flex}.cancel-btn,.update-btn{cursor:pointer;border-radius:12px;padding:12px 24px;font-size:14px;font-weight:700;transition:all .2s}.cancel-btn{color:#64748b;background:#f1f5f9;border:none}.cancel-btn:hover{color:#1e293b;background:#e2e8f0}.update-btn{color:#fff;background:#2563eb;border:none;box-shadow:0 4px 12px #2563eb33}.update-btn:hover{background:#1d4ed8;transform:translateY(-2px)}.update-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}@media (width<=640px){.form-grid{grid-template-columns:1fr}}:root{--primary-50:#eff6ff;--primary-100:#dbeafe;--primary-200:#bfdbfe;--primary-300:#93c5fd;--primary-400:#60a5fa;--primary-500:#3b82f6;--primary-600:#2563eb;--primary-700:#1d4ed8;--primary-800:#1e40af;--primary-900:#1e3a8a;--primary-950:#172554;--success-50:#f0fdf4;--success-100:#dcfce7;--success-500:#22c55e;--success-600:#16a34a;--success-700:#15803d;--warning-50:#fffbeb;--warning-500:#f59e0b;--danger-50:#fef2f2;--danger-100:#fee2e2;--danger-500:#ef4444;--danger-600:#dc2626;--neutral-50:#f8fafc;--neutral-100:#f1f5f9;--neutral-200:#e2e8f0;--neutral-300:#cbd5e1;--neutral-400:#94a3b8;--neutral-500:#64748b;--neutral-600:#475569;--neutral-700:#334155;--neutral-800:#1e293b;--neutral-900:#0f172a;--bg-page:#f0f4f8;--bg-card:#fff;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--text-inverse:#fff;--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-xs:.75rem;--font-sm:.875rem;--font-base:1rem;--font-lg:1.125rem;--font-xl:1.25rem;--font-2xl:1.5rem;--font-3xl:1.875rem;--font-4xl:2.25rem;--sp-1:.25rem;--sp-2:.5rem;--sp-3:.75rem;--sp-4:1rem;--sp-5:1.25rem;--sp-6:1.5rem;--sp-8:2rem;--sp-10:2.5rem;--sp-12:3rem;--sp-16:4rem;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-2xl:1.25rem;--radius-full:9999px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -4px #0000000a;--shadow-xl:0 20px 25px -5px #00000014, 0 8px 10px -6px #0000000a;--shadow-2xl:0 25px 50px -12px #00000026;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.35s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-family);font-size:var(--font-base);color:var(--text-primary);background-color:var(--bg-page);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6}a{color:inherit;text-decoration:none}ul,ol{list-style:none}img{max-width:100%;display:block}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,textarea,select{font-family:inherit;font-size:inherit;outline:none}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--neutral-100)}::-webkit-scrollbar-thumb{background:var(--neutral-300);border-radius:var(--radius-full)}
