:root{--bg: #f5f7fb;--surface: #ffffff;--sidebar: #1b2b4f;--border: #e2e8f0;--text: #223a5f;--muted: #65789f;--primary: #415ecb;--primary-soft: #eef1ff;--danger: #d64545;--success: #27ae60}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text)}a{color:inherit;text-decoration:none}.shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.sidebar{background:var(--sidebar);color:#e9f0ff;padding:1.25rem 1rem;display:flex;flex-direction:column;gap:.5rem;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar-brand{font-size:1.3rem;font-weight:800;letter-spacing:.02em;padding:.25rem .5rem 1rem;justify-content:center}.sidebar-section{font-size:.72rem;letter-spacing:.1em;color:#8aa4cc;padding:.6rem .5rem .2rem;text-transform:uppercase}.sidebar-nav{list-style:none;display:flex;flex-direction:column;gap:.15rem}.sidebar-item{list-style:none}.sidebar-link,.sidebar-parent-btn{display:flex;align-items:center;gap:.65rem;width:100%;border:none;background:transparent;color:#cdd7f2;border-radius:8px;padding:.55rem .75rem;font:inherit;font-weight:500;font-size:.93rem;text-align:left;cursor:pointer;transition:background .15s,color .15s;text-decoration:none}.sidebar-link:hover,.sidebar-parent-btn:hover{background:#ffffff1a;color:#fff}.sidebar-link.active{background:#ffffff29;color:#fff;font-weight:600}.sidebar-icon{font-size:1.05rem;flex-shrink:0;line-height:1}.sidebar-label{flex:1}.sidebar-chevron{font-size:.9rem;color:#8aa4cc;transition:transform .2s ease;flex-shrink:0}.sidebar-chevron.open{transform:rotate(-180deg)}.sidebar-submenu{list-style:none;margin:.15rem 0 .15rem 1rem;padding-left:.75rem;border-left:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:.1rem}.sidebar-subitem{list-style:none}.sidebar-sublink{display:flex;align-items:center;gap:.5rem;color:#a8bde0;border-radius:6px;padding:.45rem .7rem;font-size:.875rem;font-weight:400;text-decoration:none;transition:background .15s,color .15s}.sidebar-sublink:hover{background:#ffffff14;color:#fff}.sidebar-sublink.active{background:#ffffff1f;color:#fff;font-weight:600}.main-area{background:var(--bg);display:flex;flex-direction:column;height:100vh;overflow:hidden}.topbar{background:#fff;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;padding:.65rem 1.25rem;position:sticky;top:0;z-index:10}.topbar-left{display:flex;align-items:center;gap:.75rem}.topbar-right{display:flex;align-items:center;gap:.6rem}.topbar-search input{height:36px;padding:0 .75rem;border:1px solid var(--border);border-radius:8px;width:280px;background:#f5f7fb;font:inherit;color:var(--text);outline:none}.icon-btn{width:34px;height:34px;border-radius:50%;border:1px solid var(--border);background:#fff;cursor:pointer;font-size:1rem}.user-profile-wrapper{position:relative}.user-topbar-pill{display:flex;align-items:center;gap:.55rem;padding:.22rem .5rem .22rem .75rem;background:#fff;border:1px solid var(--border);border-radius:24px;cursor:pointer;transition:box-shadow .15s,border-color .15s}.user-topbar-pill:hover{box-shadow:0 2px 10px #415ecb1f;border-color:var(--primary)}.user-topbar-meta{display:flex;flex-direction:column;align-items:flex-end;line-height:1.2}.user-topbar-role{font-size:.78rem;font-weight:700;color:var(--text)}.user-topbar-location{font-size:.68rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:130px}.user-avatar-btn{width:32px;height:32px;border-radius:50%;border:none;background:var(--sidebar);display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-avatar-initials{color:#fff;font-size:.73rem;font-weight:700;letter-spacing:.5px;-webkit-user-select:none;user-select:none}.user-profile-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:248px;background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:0 12px 40px #0a143c24,0 2px 8px #0000000f;z-index:200;overflow:hidden;animation:dropdown-in .15s ease}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-6px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.upd-header{display:flex;align-items:center;gap:.85rem;padding:1.1rem 1.1rem 1rem}.upd-avatar{width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,var(--sidebar) 0%,var(--primary) 100%);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px #415ecb40}.upd-avatar-initials{color:#fff;font-size:1rem;font-weight:800;letter-spacing:.5px;-webkit-user-select:none;user-select:none}.upd-info{display:flex;flex-direction:column;gap:.18rem;min-width:0}.upd-name{font-size:.88rem;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upd-role{display:inline-flex;align-items:center;font-size:.7rem;font-weight:600;color:var(--primary);background:#415ecb17;border-radius:6px;padding:.1rem .45rem;width:fit-content}.upd-location{display:flex;align-items:center;gap:.25rem;font-size:.68rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upd-divider{height:1px;background:var(--border);margin:0}.upd-menu-item{display:flex;align-items:center;gap:.6rem;width:100%;padding:.75rem 1.1rem;background:none;border:none;cursor:pointer;text-align:left;font-size:.83rem;font-weight:600;color:#334370;transition:background .12s;font-family:inherit}.upd-menu-item:hover{background:#415ecb12}.upd-menu-item svg{flex-shrink:0;color:#415ecb}.upd-signout{display:flex;align-items:center;gap:.6rem;width:100%;padding:.75rem 1.1rem;background:none;border:none;cursor:pointer;font-size:.83rem;font-weight:600;color:#d64545;transition:background .12s;font-family:inherit}.upd-signout:hover{background:#d645450f}.upd-signout svg{flex-shrink:0}.content-area{padding:1.25rem;flex:1;overflow-y:auto;display:flex;flex-direction:column}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.1rem 1.25rem;box-shadow:0 4px 12px #243b5f0d}.page-grid{display:grid;gap:1rem}.page-hero{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.page-hero h3{font-size:1.15rem;font-weight:800}.page-hero p{margin-top:.2rem;color:var(--muted);font-size:.9rem}.hero-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.hero-stat{display:flex;flex-direction:column;gap:.1rem;padding:.7rem 1rem;border:1px solid var(--border);border-radius:10px;background:#f9fbff;min-width:110px}.hero-stat strong{font-size:1.05rem;font-weight:800}.hero-stat span{color:var(--muted);font-size:.82rem}.dashboard-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.stat-card{display:flex;justify-content:space-between;align-items:flex-start;border:1px solid var(--border);border-radius:12px;background:var(--surface);padding:1.1rem 1.25rem;box-shadow:0 4px 12px #243b5f0d}.stat-label{color:var(--muted);font-size:.85rem;font-weight:600;margin-bottom:.3rem}.stat-value{font-size:1.75rem;font-weight:800;color:var(--text)}.stat-sub{font-size:.83rem;color:var(--success);margin-top:.3rem}.stat-icon{font-size:1.8rem;opacity:.7}.section-heading{margin-bottom:1rem}.section-heading h3,.section-heading h4{font-weight:700}.section-heading p{margin-top:.3rem;color:var(--muted);font-size:.88rem}.section-heading-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.table-shell{overflow-x:auto}.table-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}.table-search-input{height:36px;padding:0 .75rem;border:1px solid var(--border);border-radius:8px;background:var(--bg);font:inherit;font-size:.85rem;color:var(--text);outline:none;min-width:260px;transition:border-color .15s}.table-search-input:focus{border-color:var(--primary)}.table-pagination{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;padding:.75rem 0 .25rem;border-top:1px solid var(--border);margin-top:.5rem}.pagination-info{font-size:.82rem;color:var(--muted)}.pagination-controls{display:flex;align-items:center;gap:.35rem}.page-size-label{display:flex;align-items:center;gap:.35rem;font-size:.82rem;color:var(--muted);margin-right:.5rem}.page-size-select{height:30px;padding:0 .4rem;border:1px solid var(--border);border-radius:6px;background:var(--bg);font:inherit;font-size:.82rem;color:var(--text);cursor:pointer}.page-btn{height:30px;min-width:30px;padding:0 .5rem;border:1px solid var(--border);border-radius:6px;background:#fff;font-size:.85rem;color:var(--text);cursor:pointer;transition:background .12s,border-color .12s}.page-btn:hover:not(:disabled){background:var(--primary-soft);border-color:var(--primary);color:var(--primary)}.page-btn:disabled{opacity:.35;cursor:not-allowed}.page-indicator{font-size:.82rem;color:var(--text);padding:0 .25rem;min-width:52px;text-align:center}.tabs-container{display:flex;gap:1rem;border-bottom:1px solid var(--border);margin-bottom:1rem}.tab-btn{background:none;border:none;padding:.75rem 1.25rem;font-weight:600;font-size:.95rem;color:var(--muted);cursor:pointer;position:relative}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--primary)}.tab-btn.active:after{content:"";position:absolute;bottom:-1px;left:0;width:100%;height:2px;background:var(--primary)}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{border-bottom:1px solid #edf2f8;padding:.65rem .6rem;text-align:left}.data-table th{color:var(--muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.07em;font-weight:700;background:#f9fbff}.data-table tbody tr:hover{background:#fafbff}.table-primary-cell{display:flex;flex-direction:column;gap:.15rem}.table-primary-cell strong{color:var(--text);font-size:.93rem}.table-primary-cell span{color:var(--muted);font-size:.83rem}.row-btn{padding:.32rem .7rem;border:1px solid var(--border);background:#fff;border-radius:6px;font:inherit;font-size:.85rem;cursor:pointer;transition:background .15s,color .15s}.flex{display:flex}.grid{display:grid}.justify-between{justify-content:space-between}.items-center{align-items:center}.gap-4{gap:1rem}.mb-4{margin-bottom:1rem}.mb-2{margin-bottom:.5rem}.mt-4{margin-top:1rem}.p-2{padding:.5rem}.px-4{padding-left:1rem;padding-right:1rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.p-4{padding:1rem}.w-full{width:100%}.min-w-full{min-width:100%}.block{display:block}.text-left{text-align:left}.text-center{text-align:center}.text-white{color:#fff}.text-gray-600{color:#4b5563}.text-red-700{color:#b91c1c}.text-xl{font-size:1.25rem}.text-sm{font-size:.875rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.rounded{border-radius:.5rem}.border{border:1px solid #e5e7eb}.border-gray-300{border-color:#d1d5db}.border-b{border-bottom:1px solid #e5e7eb}.bg-white{background:#fff}.bg-blue-500{background:#3b82f6}.bg-blue-600{background:#2563eb}.bg-gray-50{background:#f9fafb}.bg-red-100{background:#fee2e2}.text-blue-600{color:#2563eb}.text-red-600{color:#dc2626}.hover\:bg-blue-600:hover{background:#2563eb}.hover\:bg-gray-50:hover{background:#f3f4f6}.hover\:text-blue-800:hover{color:#1e40af}.disabled\:opacity-50:disabled{opacity:.5;pointer-events:none}.cursor-pointer{cursor:pointer}.space-y-4>*+*{margin-top:1rem}.overflow-x-auto,.table-shell{overflow-x:auto}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172aa6;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:50;overflow-y:auto}.modal-panel{width:100%;max-width:560px;max-height:calc(100vh - 2rem);background:#fff;border-radius:1rem;box-shadow:0 30px 60px #0f172a26;position:relative;padding:1.5rem;display:flex;flex-direction:column;overflow:hidden}.modal-close{position:absolute;top:.75rem;right:.75rem;background:transparent;border:none;font-size:1.2rem;cursor:pointer;color:#334155}.row-btn:hover{background:var(--primary-soft)}.row-btn.danger{color:var(--danger);border-color:#d645454d}.row-btn.danger:hover{background:#d645450f}.primary-btn{min-height:40px;padding:.6rem 1.1rem;border-radius:8px;border:none;background:var(--primary);color:#fff;font:inherit;font-weight:700;font-size:.9rem;cursor:pointer;box-shadow:0 6px 14px #415ecb33;transition:transform .15s,opacity .15s}.primary-btn:hover{transform:translateY(-1px)}.primary-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.secondary-btn{min-height:40px;padding:.6rem 1.1rem;border-radius:8px;border:1px solid var(--border);background:#f7f9fd;color:var(--text);font:inherit;font-weight:600;font-size:.9rem;cursor:pointer;transition:background .15s}.secondary-btn:hover{background:#eef0f6}.status-badge{display:inline-flex;align-items:center;padding:.28rem .6rem;border-radius:999px;font-size:.8rem;font-weight:700}.status-badge.active{background:#27ae601f;color:var(--success)}.status-badge.inactive{background:#d645451a;color:var(--danger)}.form-grid{display:grid;gap:.9rem}.form-2col{grid-template-columns:repeat(2,1fr)}.form-3col{grid-template-columns:repeat(3,1fr)}.form-4col{grid-template-columns:repeat(4,1fr)}.form-field{display:flex;flex-direction:column;gap:.4rem}.form-field-full{grid-column:1 / -1}.form-field-span-2{grid-column:span 2}.form-field-span-3{grid-column:span 3}.form-field label{font-size:.9rem;font-weight:700;color:var(--text)}.field-hint{color:var(--muted);font-size:.82rem}.field-hint.text-red-600{color:var(--danger)}.form-field input,.form-field textarea,.form-field select{width:100%;border:1px solid var(--border);border-radius:8px;background:#fafbff;color:var(--text);font:inherit;font-size:.93rem;outline:none;transition:border-color .15s,box-shadow .15s}.form-field input,.form-field select{min-height:40px;padding:0 .85rem}.form-field textarea{min-height:90px;padding:.7rem .85rem;resize:vertical}.form-field input:focus,.form-field textarea:focus,.form-field select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #415ecb1a;background:#fff}.multi-select{min-height:150px;padding:.5rem 0}.multi-select option{padding:.35rem .85rem}.checkbox-label{display:inline-flex;align-items:center;gap:.65rem;cursor:pointer;font-weight:600;font-size:.93rem}.checkbox-label input{width:16px;height:16px;cursor:pointer}.form-actions{display:flex;gap:.65rem;flex-wrap:wrap;margin-top:.25rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0c162d73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem;animation:fade-in .15s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-panel{background:var(--surface);border-radius:14px;box-shadow:0 24px 60px #0f1e3c40;padding:1.75rem 2rem;width:100%;max-height:90vh;overflow:hidden;position:relative;display:flex;flex-direction:column;animation:slide-up .18s ease}@keyframes slide-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-close{position:absolute;top:1rem;right:1rem;width:30px;height:30px;border-radius:50%;border:1px solid var(--border);background:#f7f9fd;color:var(--muted);font-size:.85rem;cursor:pointer;display:grid;place-content:center;transition:background .15s,color .15s}.modal-close:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.modal-title{font-size:1.1rem;font-weight:800;margin-bottom:.3rem}.modal-sub{color:var(--muted);font-size:.88rem;margin-bottom:1.1rem}.role-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.role-card{border:1px solid var(--border);border-radius:12px;padding:1rem 1.1rem;background:#fafbff;display:flex;flex-direction:column;gap:.65rem;transition:box-shadow .2s,transform .2s}.role-card:hover{box-shadow:0 8px 20px #415ecb1a;transform:translateY(-2px)}.role-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.role-card-name{font-weight:800;font-size:.97rem;margin-bottom:.3rem}.role-card-id{font-size:.78rem;color:var(--muted);background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:.2rem .5rem;white-space:nowrap}.role-card-desc{color:var(--muted);font-size:.86rem;line-height:1.5;flex:1}.role-card-nodes{display:flex;flex-wrap:wrap;gap:.35rem}.node-chip{background:var(--primary-soft);color:var(--primary);font-size:.79rem;font-weight:600;border-radius:999px;padding:.22rem .6rem;border:1px solid rgba(65,94,203,.15)}.role-card-actions{display:flex;gap:.4rem;padding-top:.4rem;border-top:1px solid var(--border)}.muted-text{color:var(--muted);font-size:.9rem}.empty-state{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:3rem 1rem;color:var(--muted);text-align:center}.full-card,.form-card,.table-card{grid-column:1 / -1}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1b2b4f,#2d4880,#415ecb);padding:1rem}.login-card{background:#fff;border-radius:16px;padding:2.5rem 2.25rem;width:100%;max-width:420px;box-shadow:0 32px 80px #0a143240}.login-logo{font-size:1.4rem;font-weight:800;color:var(--primary);margin-bottom:1.75rem}.login-title{font-size:1.55rem;font-weight:800;margin-bottom:.35rem}.login-subtitle{color:var(--muted);font-size:.92rem;margin-bottom:1.5rem}.login-form{display:flex;flex-direction:column;gap:1rem}.login-input-group{display:flex;flex-direction:column;gap:.4rem}.login-input-group label{font-weight:700;font-size:.9rem}.login-input-group input{height:44px;padding:0 1rem;border:1.5px solid var(--border);border-radius:10px;font:inherit;font-size:.95rem;color:var(--text);background:#fafbff;outline:none;transition:border-color .15s,box-shadow .15s}.login-input-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #415ecb1f;background:#fff}.password-input-container{position:relative;display:flex;align-items:center}.password-input-container input{flex:1;padding-right:40px}.password-toggle-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--muted);transition:color .15s,background-color .15s}.password-toggle-btn:hover{color:var(--primary);background-color:#415ecb14}.password-toggle-btn:focus{outline:2px solid var(--primary);outline-offset:2px}.login-btn{height:44px;border:none;border-radius:10px;background:var(--primary);color:#fff;font:inherit;font-size:.97rem;font-weight:700;cursor:pointer;margin-top:.5rem;box-shadow:0 8px 20px #415ecb40;transition:transform .15s,opacity .15s}.access-management-page{background:var(--bg);min-height:100vh}.access-management-container{max-width:1200px;margin:0 auto;padding:2rem 1.5rem;background:var(--surface);border-radius:12px;box-shadow:0 2px 8px #00000014}.role-selection{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.role-selection label{display:block;font-weight:600;color:var(--text);margin-bottom:.75rem}.role-dropdown{width:100%;max-width:400px;padding:.75rem 1rem;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);font-size:.95rem;cursor:pointer;transition:border-color .2s,box-shadow .2s}.role-dropdown:hover:not(:disabled),.role-dropdown:focus:not(:disabled){border-color:var(--primary);box-shadow:0 0 0 3px #415ecb1a;outline:none}.role-dropdown:disabled{opacity:.6;cursor:not-allowed}.role-description{margin-top:1rem;padding:.75rem 1rem;background:var(--primary-soft);border-left:3px solid var(--primary);border-radius:4px;font-size:.9rem;color:var(--text)}.access-grid{margin-top:2rem}.access-management-container.full-width{max-width:100%}.module-section{margin-bottom:2rem}.module-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--bg);border-radius:8px;border:1px solid var(--border);margin-bottom:1rem;cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s}.module-header:hover{border-color:var(--primary);background:var(--primary-soft)}.module-title-text{font-size:1.1rem;font-weight:700;color:var(--text);margin:0}.collapse-icon{font-size:.9rem;color:var(--muted);transition:transform .2s ease}.collapse-icon.collapsed{color:var(--primary)}.module-section.collapsed{margin-bottom:1rem}.business-objects-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.business-object-item{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:var(--surface);border:1px solid var(--border);border-radius:8px;transition:all .2s;gap:1rem}.business-object-item:hover{border-color:var(--primary);box-shadow:0 4px 12px #415ecb1a}.bo-info{display:flex;align-items:center;gap:1rem;flex:1;min-width:0}.bo-icon{font-size:1.5rem;min-width:1.5rem}.bo-details{flex:1;min-width:0}.bo-name{font-weight:600;color:var(--text);word-break:break-word}.bo-code{font-size:.85rem;color:var(--muted);margin-top:.25rem;font-family:Courier New,monospace}.toggle-switch{display:flex;align-items:center;gap:.5rem;cursor:pointer;flex-shrink:0}.toggle-switch input{display:none}.slider{position:relative;width:44px;height:24px;background:var(--border);border-radius:12px;transition:background .3s;display:inline-block}.toggle-switch input:checked+.slider{background:var(--success)}.slider:before{content:"";position:absolute;width:20px;height:20px;border-radius:50%;background:#fff;top:2px;left:2px;transition:left .3s;box-shadow:0 2px 4px #0003}.toggle-switch input:checked+.slider:before{left:22px}.status-text{font-size:.75rem;font-weight:600;color:var(--muted);min-width:55px}.toggle-switch input:checked~.status-text{color:var(--success)}.status-text.inactive{color:var(--danger)}.action-buttons{display:flex;gap:1rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border);justify-content:flex-end}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;font-size:.95rem}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 4px 12px #415ecb40}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #415ecb4d}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.empty-state{text-align:center;padding:3rem 1rem;color:var(--muted)}.alert{padding:1rem;border-radius:8px;margin-bottom:1rem;font-weight:500}.alert-error{background:#fef3f3;color:var(--danger);border:1px solid rgba(214,69,69,.2)}.alert-success{background:#f0f9f5;color:var(--success);border:1px solid rgba(39,174,96,.2)}.page-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.page-header h1{font-size:2rem;color:var(--text);margin-bottom:.5rem}.page-header p{color:var(--muted);font-size:.95rem}.sidebar-empty{padding:1rem .5rem;text-align:center;color:var(--muted);font-size:.85rem;font-style:italic}.no-access-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,var(--primary) 0%,var(--sidebar) 100%)}.no-access-container{display:flex;align-items:center;justify-content:center;width:100%;padding:1rem}.no-access-content{background:var(--surface);border-radius:12px;padding:3rem;text-align:center;max-width:500px;box-shadow:0 20px 60px #0000004d}.no-access-icon{font-size:5rem;margin-bottom:1rem}.no-access-title{font-size:2rem;font-weight:800;color:var(--text);margin-bottom:.5rem}.no-access-message{font-size:1.1rem;color:var(--text);margin-bottom:.5rem}.no-access-submessage{font-size:.95rem;color:var(--muted);margin-bottom:2rem}.no-access-actions{display:flex;gap:1rem;justify-content:center;margin-bottom:1.5rem}.btn-secondary{background:var(--border);color:var(--text)}.btn-secondary:hover:not(:disabled){background:#cdd5e0;transform:translateY(-2px)}.no-access-info{padding-top:1.5rem;border-top:1px solid var(--border)}.no-access-error-code{font-family:Courier New,monospace;font-size:.85rem;color:var(--danger);font-weight:600}.login-btn:hover{transform:translateY(-1px)}.login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-error{background:#d6454514;border:1px solid rgba(214,69,69,.25);color:var(--danger);border-radius:8px;padding:.65rem .85rem;font-size:.9rem;font-weight:600}.login-success{background:#27ae6014;border:1px solid rgba(39,174,96,.25);color:#27ae60;border-radius:8px;padding:.65rem .85rem;font-size:.9rem;font-weight:600}.menu-badge{background:#fff3;color:#fff;border-radius:999px;padding:.1rem .5rem;font-size:.72rem;font-weight:700;margin-left:auto}.login-info{background:#415ecb14;border:1px solid rgba(65,94,203,.25);color:var(--primary);border-radius:8px;padding:.65rem .85rem;font-size:.9rem;font-weight:600}.login-footer{margin-top:1.5rem;text-align:center;display:flex;justify-content:center;align-items:center;gap:.75rem}.login-link{color:var(--primary);font-weight:600;font-size:.9rem;text-decoration:none;transition:opacity .15s}.login-link:hover{opacity:.8;text-decoration:underline}.login-link-btn{background:none;border:none;color:var(--primary);font:inherit;font-weight:600;font-size:.9rem;cursor:pointer;padding:0;transition:opacity .15s}.login-link-btn:hover{opacity:.8;text-decoration:underline}.login-link-btn:disabled{opacity:.5;cursor:not-allowed}.login-separator{color:var(--muted);font-size:.85rem}.login-icon-success{width:64px;height:64px;background:linear-gradient(135deg,#27ae60,#2ecc71);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;color:#fff;margin:0 auto 1.5rem;box-shadow:0 12px 24px #27ae6040}.user-details-view{padding:.5rem}.details-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;margin-top:1.5rem}.detail-item{display:flex;flex-direction:column;gap:.35rem}.detail-item label{color:var(--muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;font-weight:700}.detail-value{color:var(--text);font-size:1rem;font-weight:600}.section-label{display:block;font-weight:700;color:var(--text);font-size:.95rem;margin-bottom:.75rem}.location-chips-container{display:flex;flex-wrap:wrap;gap:.6rem}.location-chip{background:var(--primary-soft);color:var(--primary);border:1px solid rgba(65,94,203,.2);padding:.4rem .8rem;border-radius:8px;font-size:.85rem;font-weight:600}.multi-select-search-v2{display:flex;flex-direction:column;gap:.5rem;border:1px solid var(--border);border-radius:10px;background:var(--surface);padding:.75rem;overflow:hidden;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.search-box{position:relative;display:flex;align-items:center}.search-input{width:100%;padding:.75rem .5rem;height:48px;border:1px solid var(--border);border-radius:8px;background:#f8fafc;font-size:1rem;color:#1e293b!important;outline:none;transition:all .2s}.search-input:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #415ecb1a}.clear-search{position:absolute;right:12px;background:none;border:none;font-size:1.5rem;color:#94a3b8;cursor:pointer;line-height:1;padding:0;margin-top:-2px}.clear-search:hover{color:#475569}.selection-actions{display:flex;gap:.5rem;padding:.25rem 0 .5rem;border-bottom:1px solid var(--border)}.action-btn{padding:.4rem .8rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.025em;color:var(--primary);background:var(--primary-soft);border:1px solid rgba(65,94,203,.15);border-radius:6px;cursor:pointer;white-space:nowrap;transition:all .2s}.action-btn:hover:not(:disabled){background:var(--primary);color:#fff}.action-btn:disabled{opacity:.5;cursor:not-allowed}.options-list{display:flex;flex-direction:column;gap:.25rem;max-height:240px;overflow-y:auto;padding:.25rem 0;border-radius:4px}.options-list::-webkit-scrollbar{width:6px}.options-list::-webkit-scrollbar-track{background:#f1f5f9}.options-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}.options-list::-webkit-scrollbar-thumb:hover{background:#94a3b8}.option-row{display:flex;align-items:center;gap:1rem;padding:.65rem .75rem;border-radius:6px;cursor:pointer;transition:all .15s}.option-row:hover{background:#f8fafc}.option-row.is-selected{background:#f0f4ff}.option-row.is-selected .primary-label{color:var(--primary);font-weight:700}.checkbox-wrap{display:flex;align-items:center;justify-content:center}.option-label-wrap{flex:1;display:flex;flex-direction:column}.primary-label{font-size:.95rem;font-weight:500;color:#334155!important}.secondary-label{font-size:.8rem;color:#64748b;margin-top:.15rem}.no-matches{padding:1.5rem;text-align:center;color:#94a3b8;font-size:.9rem;font-style:italic}.selection-summary{padding-top:.75rem;border-top:1px solid var(--border);font-size:.875rem;color:#64748b;text-align:right}.selection-summary strong{color:var(--primary);font-weight:800}.multi-select-search-v2.disabled{background:#f1f5f9;opacity:.8;pointer-events:none}@media (max-width: 1100px){.shell{grid-template-columns:200px 1fr}.dashboard-grid{grid-template-columns:1fr 1fr}.form-2col{grid-template-columns:1fr}}@media (max-width: 768px){.shell{grid-template-columns:1fr}.sidebar{position:fixed;z-index:30;width:240px;transform:translate(-100%)}.dashboard-grid{grid-template-columns:1fr}.page-hero,.hero-meta{flex-direction:column;align-items:flex-start}.topbar-search input{width:160px}.modal-panel{padding:1.25rem 1rem}}.search-wrapper{position:relative;display:flex;align-items:center;width:100%;max-width:800px}.search-wrapper input{width:100%;padding:.85rem 1rem .85rem 3rem!important;border:1px solid #e2e8f0!important;border-radius:12px!important;font-size:.95rem;background-color:#f8fafc!important;transition:all .2s ease;box-shadow:0 1px 2px #0000000d}.search-wrapper input:focus{outline:none;border-color:var(--primary)!important;background-color:#fff!important;box-shadow:0 0 0 4px #415ecb1a}.search-icon{position:absolute;left:1.15rem;width:18px;height:18px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394a3b8'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2.5' d='M21 21l-6-6m2-5a7 7 0 11-14 0 7 7 0 0114 0z'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;pointer-events:none}.dyn-param-page{min-height:0}.dyn-param-layout{display:grid;grid-template-columns:1fr 400px;gap:1.5rem;align-items:stretch}.dyn-param-builder{display:flex;flex-direction:column;gap:1.5rem}.dyn-section-card{padding:0!important;overflow:visible;border:1px solid #e2e8f0}.dyn-section-header{padding:1rem 1.25rem;background:#f8fafc;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;gap:1rem}.dyn-section-num{width:28px;height:28px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem}.dyn-section-title-input{border:none;background:transparent;font-weight:600;font-size:1.1rem;color:var(--text);flex:1;min-width:0;padding:.25rem .4rem;border-bottom:2px solid transparent;transition:border-bottom-color .15s}.dyn-section-title-input:focus{outline:none;border-bottom-color:var(--primary)}.dyn-params-list{display:flex;flex-direction:column;gap:1rem;padding:1.25rem;background:#fff}.dyn-param-preview{position:sticky;top:90px}.preview-panel{background:#fff;border-radius:12px;border:1px solid #e2e8f0;box-shadow:0 8px 30px #243b5f14;overflow:hidden;max-height:calc(100vh - 110px);display:flex;flex-direction:column}.preview-panel-header{padding:1rem 1.25rem;background:var(--primary);color:#fff;display:flex;align-items:center;gap:.6rem;font-weight:600;flex-shrink:0}.preview-panel-body{flex:1;overflow-y:auto;padding:1.25rem}.preview-panel-body::-webkit-scrollbar{width:6px}.preview-panel-body::-webkit-scrollbar-track{background:#f8fafc}.preview-panel-body::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:10px}.preview-panel-body::-webkit-scrollbar-thumb:hover{background:#94a3b8}.preview-section-title{display:flex;align-items:center;gap:.6rem;font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;font-weight:800;color:#64748b;margin-bottom:.85rem;padding-bottom:.5rem;border-bottom:1px solid #edf2f8}.spinner{width:32px;height:32px;border:3px solid rgba(0,0,0,.1);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 1100px){.dyn-param-layout{grid-template-columns:1fr}.dyn-param-preview{position:static}.preview-panel{max-height:none}.preview-panel-body{overflow-y:visible}}.param-editor-card{border:1px solid #e2e8f0;border-radius:10px;background:#fff;box-shadow:0 2px 6px #243b5f0a;transition:box-shadow .2s;overflow:visible}.param-editor-card:hover{box-shadow:0 4px 14px #415ecb1a}.param-editor-header{display:flex;justify-content:space-between;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#f8fafc;border-bottom:1px solid #e2e8f0;border-radius:10px 10px 0 0;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.param-editor-header:hover{background:#f0f4ff}.param-editor-body{display:flex;flex-direction:column;gap:1rem;padding:1rem 1.1rem 1.1rem;background:#fff}.dep-row{display:flex;align-items:center;gap:.6rem;padding:.6rem .85rem;background:#f8fafc;border:1px solid #e6ecf5;border-radius:8px;flex-wrap:wrap}.dep-row select{flex:1;min-width:120px;min-height:36px;padding:0 .75rem;border:1px solid var(--border);border-radius:6px;background:#fff;color:var(--text);font:inherit;font-size:.88rem;outline:none;transition:border-color .15s,box-shadow .15s}.dep-row select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #415ecb1a}.dep-label{font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--primary);background:var(--primary-soft);border:1px solid rgba(65,94,203,.15);border-radius:6px;padding:.2rem .55rem;white-space:nowrap;flex-shrink:0}.searchable-select-wrapper{position:relative;width:100%}.searchable-select-wrapper.open-wrapper{z-index:100}.select-trigger{width:100%;min-height:40px;padding:0 .85rem;border:1px solid var(--border);border-radius:8px;background:#fafbff;color:var(--text);font:inherit;font-size:.93rem;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:border-color .15s,box-shadow .15s}.select-trigger:hover:not(.select-disabled){border-color:var(--primary)}.select-trigger.open{border-color:var(--primary);box-shadow:0 0 0 3px #415ecb1a;background:#fff;border-bottom-left-radius:0;border-bottom-right-radius:0}.select-trigger.select-disabled{opacity:.6;cursor:not-allowed}.placeholder{color:#94a3b8}.selected-value{color:var(--text)}.dropdown-arrow{font-size:.8rem;color:var(--muted);transition:transform .2s}.select-trigger.open .dropdown-arrow{transform:rotate(180deg)}.select-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--border);border-top:none;border-bottom-left-radius:8px;border-bottom-right-radius:8px;box-shadow:0 8px 16px #243b5f1a;z-index:2000;overflow:visible;max-height:300px;display:flex;flex-direction:column}.search-input-wrap{padding:.6rem;border-bottom:1px solid #edf2f8;background:#fafbff}.search-input-wrap input{width:100%;padding:.45rem .75rem;border:1px solid var(--border);border-radius:6px;font:inherit;font-size:.88rem;color:var(--text);outline:none;transition:border-color .15s}.search-input-wrap input:focus{border-color:var(--primary)}.options-list{overflow-y:auto;max-height:220px}.option-item{padding:.5rem 1rem;font-size:.93rem;cursor:pointer;transition:background .15s;display:flex;flex-direction:column;gap:.1rem}.option-item:hover{background:var(--primary-soft);color:var(--primary)}.option-item:hover .option-sub-label{color:var(--primary);opacity:.75}.option-item.selected{background:var(--primary);color:#fff;font-weight:600}.option-item.selected .option-sub-label{color:#ffffffbf}.option-main-label{font-weight:600;font-size:.88rem;color:inherit}.option-sub-label{font-size:.78rem;color:var(--muted);font-weight:400}.no-options{padding:1rem;text-align:center;color:var(--muted);font-size:.9rem}.attendance-page{display:flex;flex-direction:column;gap:1.5rem;padding:.25rem 0;max-width:1200px}.attendance-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.attendance-header-left{display:flex;align-items:center;gap:1rem}.attendance-header-icon{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,#415ecb,#6b8aff);display:flex;align-items:center;justify-content:center;font-size:1.6rem;box-shadow:0 6px 18px #415ecb47;flex-shrink:0}.attendance-title{font-size:1.5rem;font-weight:800;color:var(--text);line-height:1.2}.attendance-subtitle{font-size:.88rem;color:var(--muted);margin-top:.2rem}.attendance-emp-badge{display:flex;flex-direction:column;align-items:flex-end;gap:.15rem;padding:.6rem 1rem;background:var(--primary-soft);border:1px solid rgba(65,94,203,.2);border-radius:10px}.attendance-emp-label{font-size:.72rem;color:var(--primary);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.attendance-emp-id{font-size:1.1rem;font-weight:800;color:var(--primary)}.attendance-body{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:start}@media (max-width: 900px){.attendance-body{grid-template-columns:1fr}}.attendance-capture-panel{display:flex;flex-direction:column;gap:1rem}.attendance-next-action{display:flex;align-items:center;gap:.6rem;padding:.65rem 1rem;border-radius:10px;font-size:.9rem;font-weight:600;border:1px solid transparent}.attendance-next-action.login{background:#27ae6014;border-color:#27ae6040;color:#1a8b4f}.attendance-next-action.logout{background:#d6454512;border-color:#d6454538;color:#b83030}.attendance-next-action-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;animation:pulse-dot 1.5s ease-in-out infinite}.attendance-next-action.login .attendance-next-action-dot{background:var(--success)}.attendance-next-action.logout .attendance-next-action-dot{background:var(--danger)}@keyframes pulse-dot{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.7}}.attendance-camera-box{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:0 4px 16px #243b5f0f;min-height:300px;display:flex;flex-direction:column;align-items:center;justify-content:center}.attendance-camera-placeholder{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2.5rem 1.5rem;text-align:center;color:var(--muted)}.attendance-camera-icon{font-size:3rem;opacity:.5}.attendance-camera-placeholder p{font-size:.9rem}.attendance-camera-live{width:100%;display:flex;flex-direction:column}.attendance-video{width:100%;display:block;background:#000;max-height:340px;object-fit:cover}.attendance-camera-controls{display:flex;gap:.75rem;padding:.75rem;background:#f9fbff;border-top:1px solid var(--border);justify-content:center}.attendance-preview{width:100%;display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:.75rem}.attendance-preview-label{width:100%;display:flex;align-items:center;gap:.5rem}.attendance-preview-badge{background:#415ecb1a;color:var(--primary);border-radius:6px;padding:.2rem .6rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.attendance-preview-img{width:100%;max-height:280px;object-fit:cover;border-radius:10px;border:2px solid var(--primary-soft);box-shadow:0 4px 12px #415ecb1f}.attendance-location-box{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1rem 1.1rem;box-shadow:0 2px 8px #243b5f0d}.attendance-location-header{display:flex;align-items:center;justify-content:space-between;font-weight:700;font-size:.92rem;color:var(--text);margin-bottom:.6rem}.attendance-location-loading,.attendance-location-error{font-size:.88rem;padding:.4rem 0}.attendance-location-loading{color:var(--muted)}.attendance-location-error{color:var(--danger)}.attendance-location-coords{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-top:.25rem}.attendance-coord{display:flex;flex-direction:column;gap:.15rem;background:#f5f7fb;border-radius:8px;padding:.55rem .8rem}.attendance-coord-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600}.attendance-coord-value{font-size:.93rem;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.attendance-alert{border-radius:10px;padding:.75rem 1rem;font-size:.88rem;font-weight:600}.attendance-alert.success{background:#27ae601a;color:#1a7a46;border:1px solid rgba(39,174,96,.25)}.attendance-alert.error{background:#d6454514;color:#a83232;border:1px solid rgba(214,69,69,.2)}.btn-submit-attendance{width:100%;padding:.85rem 1.5rem;border-radius:12px;border:none;font:inherit;font-size:1rem;font-weight:800;cursor:pointer;letter-spacing:.02em;transition:transform .15s,box-shadow .15s,opacity .15s}.btn-submit-attendance.login{background:linear-gradient(135deg,#27ae60,#2ecc71);color:#fff;box-shadow:0 6px 18px #27ae604d}.btn-submit-attendance.logout{background:linear-gradient(135deg,#d64545,#e05252);color:#fff;box-shadow:0 6px 18px #d645454d}.btn-submit-attendance:hover:not(:disabled){transform:translateY(-2px)}.btn-submit-attendance:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}.btn-primary{padding:.6rem 1.2rem;background:var(--primary);color:#fff;border:none;border-radius:8px;font:inherit;font-weight:700;font-size:.9rem;cursor:pointer;transition:opacity .15s,transform .15s;box-shadow:0 4px 10px #415ecb40}.btn-primary:hover{opacity:.9;transform:translateY(-1px)}.btn-secondary{padding:.55rem 1.1rem;background:#f0f2f8;color:var(--text);border:1px solid var(--border);border-radius:8px;font:inherit;font-weight:600;font-size:.9rem;cursor:pointer;transition:background .15s}.btn-secondary:hover{background:#e4e8f2}.btn-capture{padding:.65rem 1.4rem;background:linear-gradient(135deg,var(--primary) 0%,#6b8aff 100%);color:#fff;border:none;border-radius:8px;font:inherit;font-weight:700;font-size:.95rem;cursor:pointer;box-shadow:0 4px 14px #415ecb4d;transition:opacity .15s,transform .15s}.btn-capture:hover{opacity:.92;transform:translateY(-1px)}.btn-icon{background:none;border:none;cursor:pointer;font-size:1rem;padding:.2rem;border-radius:6px;transition:background .15s}.btn-icon:hover{background:var(--border)}.attendance-records-panel{background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:0 4px 16px #243b5f0f;display:flex;flex-direction:column;overflow:hidden;height:600px}.attendance-records-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border);background:#f9fbff}.attendance-records-title{font-size:1rem;font-weight:800;color:var(--text)}.attendance-records-count{background:var(--primary-soft);color:var(--primary);border-radius:99px;padding:.2rem .7rem;font-size:.8rem;font-weight:700}.attendance-tabs{display:flex;border-bottom:1px solid var(--border);background:#f9fbff}.attendance-tab-btn{flex:1;padding:.6rem 0;font-size:.82rem;font-weight:600;color:var(--muted);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .15s,border-color .15s}.attendance-tab-btn:hover{color:var(--primary)}.attendance-tab-btn.active{color:var(--primary);border-bottom-color:var(--primary);background:#fff}.attendance-records-loading,.attendance-records-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:3rem 1rem;color:var(--muted);font-size:.9rem;text-align:center}.attendance-records-empty-icon{font-size:2.5rem;opacity:.4}.attendance-records-list{display:flex;flex-direction:column;gap:0;overflow-y:auto;flex:1}.attendance-record-card{display:flex;align-items:center;gap:1rem;padding:.9rem 1.25rem;border-bottom:1px solid var(--border);transition:background .15s}.attendance-record-card:last-child{border-bottom:none}.attendance-record-card:hover{background:#fafbff}.attendance-record-photo-wrap{flex-shrink:0;background:none;border:none;padding:0;cursor:pointer}.attendance-record-photo-wrap:hover .attendance-record-photo-placeholder{border-color:var(--primary);background:var(--primary-soft)}.attendance-record-photo-placeholder{width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,#f0f2f8,#e4e8f5);display:flex;align-items:center;justify-content:center;font-size:1.4rem;border:1px solid var(--border);transition:background .15s,border-color .15s}.attendance-photo-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease}.attendance-photo-modal{position:relative;background:#fff;border-radius:14px;padding:1rem;box-shadow:0 20px 60px #00000059;max-width:90vw;max-height:90vh;display:flex;align-items:center;justify-content:center}.attendance-photo-close{position:absolute;top:.5rem;right:.5rem;width:28px;height:28px;border-radius:50%;border:none;background:#00000026;color:#fff;font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;transition:background .15s}.attendance-photo-close:hover{background:#00000059}.attendance-photo-img{max-width:min(480px,85vw);max-height:80vh;border-radius:8px;display:block;object-fit:contain}.attendance-photo-loading{padding:2rem 3rem;color:var(--muted);font-size:.9rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.attendance-record-info{flex:1;display:flex;flex-direction:column;gap:.25rem;min-width:0}.attendance-record-top{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.attendance-type-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;border-radius:99px;font-size:.78rem;font-weight:700}.attendance-type-badge.login{background:#27ae601a;color:#1a7a46}.attendance-type-badge.logout{background:#d6454514;color:#b83030}.attendance-record-time{font-size:.88rem;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.attendance-record-date{font-size:.8rem;color:var(--muted)}.attendance-record-coords{font-size:.78rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
