@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/ba9851c3c22cd980-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/21350d82a1f187e9-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/c5fe6dc8356a8c31-s.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/19cfc7226ec3afaa-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/df0a9ae256c0569c-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/8e9860b6e62d6359-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/e4af272ccee01ff0-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__Inter_Fallback_f367f3;src:local("Arial");ascent-override:90.49%;descent-override:22.56%;line-gap-override:0.00%;size-adjust:107.06%}.__className_f367f3{font-family:__Inter_f367f3,__Inter_Fallback_f367f3;font-style:normal}:root{--primary:#0b6db5;--primary-dark:#085a96;--primary-light:#a8d4f0;--primary-bg:#edf6fc;--accent-teal:#00a3b4;--accent-green:#2d8c4e;--gradient-brand:linear-gradient(135deg,#2d8c4e,#00a3b4 40%,#0b6db5);--success:#22c55e;--success-bg:#f0fdf4;--danger:#ef4444;--danger-bg:#fef2f2;--warning:#f59e0b;--warning-bg:#fffbeb;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--radius:12px;--radius-sm:8px;--shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);--shadow-md:0 4px 6px rgba(0,0,0,.06),0 2px 4px rgba(0,0,0,.04);--shadow-lg:0 10px 25px rgba(11,109,181,.1),0 4px 6px rgba(0,0,0,.04)}body{font-family:Inter,system-ui,-apple-system,sans-serif;color:var(--gray-800);background:#fff;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px;color:var(--gray-500)}.spinner{width:40px;height:40px;border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.auth-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px;background:#fff}.auth-card{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:440px;box-shadow:0 4px 30px rgba(11,109,181,.1);border:1px solid var(--gray-100)}.auth-header{text-align:center;margin-bottom:32px}.auth-header-logo{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:8px}.auth-brand-name,.auth-header h1{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#2d8c4e,#00a3b4 50%,#0b6db5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-header h1{margin-bottom:4px}.auth-header p{color:var(--gray-500);font-size:.95rem}.auth-form{gap:20px}.auth-form,.form-group{display:flex;flex-direction:column}.form-group{gap:6px}.form-group label{font-size:.875rem;font-weight:600;color:var(--gray-700)}.form-group input{padding:12px 16px;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);font-size:.95rem;font-family:inherit;transition:border-color .2s,box-shadow .2s;outline:none;color:var(--gray-800)}.form-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(11,109,181,.1)}.form-group input::placeholder{color:var(--gray-400)}.btn-primary{padding:12px 24px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .2s,transform .1s}.btn-primary:hover{background:var(--primary-dark)}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{background:var(--gray-300);cursor:not-allowed}.btn-secondary{padding:12px 24px;background:var(--gray-100);color:var(--gray-700);border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);font-size:1rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .2s}.btn-secondary:hover{background:var(--gray-200)}.btn-link{background:none;border:none;color:var(--primary);font-size:.875rem;cursor:pointer;padding:8px 0;text-decoration:underline;font-family:inherit;margin-top:4px}.btn-link:hover{color:var(--primary-dark)}.error-message{color:var(--danger);font-size:.875rem;background:var(--danger-bg);padding:10px 14px;border-radius:var(--radius-sm);border:1px solid rgba(239,68,68,.2)}.success-message{color:#166534;background:var(--success-bg);border-radius:var(--radius-sm);border:1px solid rgba(34,197,94,.2);margin-bottom:20px}.info-message,.success-message{font-size:.875rem;padding:14px;line-height:1.5}.info-message{color:var(--primary-dark);background:var(--primary-bg);border-radius:var(--radius-sm);border:1px solid rgba(11,109,181,.12)}.password-requirements{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-sm);padding:12px 14px;display:flex;flex-direction:column;gap:8px}.password-requirements-title{font-size:.85rem;font-weight:600;color:var(--gray-700)}.password-requirements ul{list-style:none;display:flex;flex-direction:column;gap:6px;margin:0;padding:0}.password-requirements li{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--gray-600)}.password-requirements .rule-icon{display:inline-flex;align-items:center;justify-content:center;width:30px;height:22px;font-size:.7rem;font-weight:700;border-radius:999px;border:1px solid var(--gray-200);color:var(--gray-500);background:#fff}.password-requirements .rule-ok{color:var(--success)}.password-requirements .rule-ok .rule-icon{color:var(--success);border-color:rgba(34,197,94,.4);background:var(--success-bg)}.password-requirements .rule-bad{color:var(--gray-500)}.auth-footer{text-align:center;margin-top:24px;padding-top:20px;border-top:1px solid var(--gray-100)}.auth-footer p{color:var(--gray-500);font-size:.875rem}.auth-footer a{color:var(--primary);font-weight:600;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.pending-message,.rejected-message{text-align:center;padding:24px 0}.pending-icon,.rejected-icon{font-size:3rem;margin-bottom:16px}.pending-message h2,.rejected-message h2{font-size:1.25rem;color:var(--gray-800);margin-bottom:12px}.pending-message p,.rejected-message p{color:var(--gray-500);line-height:1.6;margin-bottom:24px}.home-container{min-height:100vh;background:#fff}.home-header{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;background:#fff;border-bottom:1px solid var(--gray-100);box-shadow:0 1px 8px rgba(11,109,181,.06)}.home-header h1{font-size:1.1rem;background:linear-gradient(135deg,#2d8c4e,#00a3b4 50%,#0b6db5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700;flex:none;text-align:center}.home-header-brand{display:flex;align-items:center;gap:10px;flex:1 1;justify-content:flex-start}.brand-logo{height:36px}.brand-logo,.brand-logo-sm{width:auto;object-fit:contain}.brand-logo-sm{height:28px}.brand-logo-lg{height:64px;width:auto;object-fit:contain}.brand-logo-xl{height:80px;width:auto;object-fit:contain}.header-actions{gap:8px;position:relative}.avatar-btn,.header-actions{display:flex;align-items:center}.avatar-btn{width:38px;height:38px;border-radius:50%;border:1.5px solid var(--gray-200);background:var(--gray-50,#f9fafb);color:var(--gray-500);justify-content:center;cursor:pointer;transition:all .2s}.avatar-btn:hover{background:var(--gray-100);color:var(--gray-700);border-color:var(--gray-300)}.avatar-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:180px;background:#fff;border:1px solid var(--gray-100);border-radius:var(--radius-md,10px);box-shadow:0 8px 24px rgba(0,0,0,.12);z-index:100;padding:6px;animation:dropdownFadeIn .15s ease}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.avatar-dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:none;border:none;border-radius:var(--radius-sm,8px);font-size:.875rem;font-weight:500;font-family:inherit;color:var(--gray-700);cursor:pointer;transition:background .15s}.avatar-dropdown-item:hover{background:var(--gray-50,#f9fafb)}.avatar-dropdown-logout{color:#dc2626}.avatar-dropdown-logout:hover{background:#fef2f2}.avatar-dropdown-divider{height:1px;background:var(--gray-100);margin:4px 0}.btn-logout{padding:8px 16px;background:none;color:var(--gray-500);border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s}.btn-logout:hover{background:var(--gray-100);color:var(--gray-700)}.btn-admin{padding:8px 16px;background:var(--primary-bg);color:var(--primary);border:1.5px solid var(--primary-light);border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s}.btn-admin:hover{background:var(--primary-light)}.home-main{max-width:800px;margin:0 auto;padding:32px 24px}.welcome-section{margin-bottom:32px}.welcome-section h2{font-size:1.5rem;color:var(--gray-800);margin-bottom:4px}.welcome-section p{color:var(--gray-500);font-size:.95rem}.modules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));grid-gap:16px;gap:16px}.module-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:28px 20px;background:#fff;border:1.5px solid var(--gray-200);border-radius:var(--radius);cursor:pointer;transition:all .2s;font-family:inherit;box-shadow:var(--shadow)}.module-btn:hover{border-color:var(--primary-light);box-shadow:0 4px 12px rgba(11,109,181,.12);transform:translateY(-2px)}.module-icon{font-size:2rem}.module-label{font-size:.95rem;font-weight:600;color:var(--gray-700)}.module-separator{grid-column:1/-1;border:none;border-top:1px solid var(--gray-200);margin:8px 0}.profile-container{min-height:100vh;background:#fff}.profile-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:#fff;border-bottom:1px solid var(--gray-100);box-shadow:0 1px 8px rgba(11,109,181,.06)}.profile-header h1{font-size:1.25rem;color:var(--gray-800);font-weight:700;flex:1 1;text-align:center}.btn-back{padding:10px 18px;background:#fff;color:var(--gray-700);border:1.5px solid var(--gray-300);border-radius:var(--radius);font-size:.9rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px}.btn-back:hover{background:var(--gray-50);border-color:var(--primary);color:var(--primary);transform:translateY(-1px)}.btn-back:active{transform:translateY(0)}.profile-main{max-width:600px;margin:32px auto;padding:0 24px}.profile-card{background:#fff;border-radius:var(--radius);padding:32px;box-shadow:var(--shadow)}.profile-avatar{width:80px;height:80px;background:var(--primary-bg);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;margin:0 auto 24px;border:2px solid var(--primary-light)}.profile-info{gap:20px}.profile-field,.profile-info{display:flex;flex-direction:column}.profile-field{gap:4px}.profile-field label{font-size:.8rem;font-weight:600;color:var(--gray-400);text-transform:uppercase;letter-spacing:.5px}.profile-field p{font-size:1rem;color:var(--gray-800)}.form-actions{display:flex;gap:12px}.form-actions .btn-primary,.form-actions .btn-secondary{flex:1 1}.admin-container{min-height:100vh;background:#fff}.admin-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:#fff;border-bottom:1px solid var(--gray-100);box-shadow:0 1px 8px rgba(11,109,181,.06)}.admin-header h1{font-size:1.25rem;color:var(--gray-800);font-weight:700;flex:1 1;text-align:center}.admin-main{max-width:800px;margin:32px auto;padding:0 24px}.admin-filters{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap}.filter-btn{padding:8px 16px;background:#fff;color:var(--gray-600);border:1.5px solid var(--gray-200);border-radius:20px;font-size:.875rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}.filter-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.filter-btn:hover:not(.active){background:var(--gray-100)}.filter-count{background:hsla(0,0%,100%,.2);padding:2px 8px;border-radius:10px;font-size:.75rem}.filter-btn:not(.active) .filter-count{background:var(--gray-100)}.empty-state{text-align:center;padding:48px 24px;color:var(--gray-400)}.residents-list{display:flex;flex-direction:column;gap:12px}.resident-card{display:flex;justify-content:space-between;align-items:center;padding:20px;background:#fff;border-radius:var(--radius);border:1px solid var(--gray-200);box-shadow:var(--shadow);gap:16px;flex-wrap:wrap}.resident-info{display:flex;flex-direction:column;gap:4px}.resident-email{font-weight:600;color:var(--gray-800)}.resident-name{color:var(--gray-600);font-size:.9rem}.resident-address{color:var(--gray-400);font-size:.85rem}.status-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;margin-top:4px;width:-moz-fit-content;width:fit-content}.status-pendiente{background:var(--warning-bg);color:#92400e}.status-aprobado{background:var(--success-bg);color:#166534}.status-rechazado{background:var(--danger-bg);color:#991b1b}.resident-actions{display:flex;gap:8px;flex-shrink:0}.approve-section{display:flex;flex-direction:column;gap:8px;align-items:flex-start}.role-select-label{font-size:.8rem;font-weight:600;color:var(--gray-600)}.role-select{padding:8px 12px;border:1.5px solid var(--gray-300);border-radius:var(--radius-sm);font-size:.875rem;font-family:inherit;background:#fff;color:var(--gray-700);cursor:pointer;width:100%}.role-select:focus{outline:none;border-color:var(--primary)}.action-buttons{display:flex;gap:8px;width:100%}.resident-badges{display:flex;gap:6px;flex-wrap:wrap}.role-badge{padding:3px 10px;border-radius:12px;font-size:.75rem;font-weight:600}.role-residente{background:#dbeafe;color:#1e40af}.role-seguridad{background:#fef3c7;color:#92400e}.role-admin{background:var(--primary-bg);color:var(--primary-dark)}.btn-approve{padding:8px 16px;background:var(--success);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;font-family:inherit;cursor:pointer;transition:opacity .2s}.btn-approve:hover{opacity:.9}.btn-reject{padding:8px 16px;background:var(--danger);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;font-family:inherit;cursor:pointer;transition:opacity .2s}.btn-reject:hover{opacity:.9}.accesos-filters{display:flex;gap:12px;margin-bottom:16px;align-items:flex-end;flex-wrap:wrap}.acceso-card{padding:16px 20px;background:#fff;border-radius:var(--radius);border:1px solid var(--gray-200);box-shadow:var(--shadow);cursor:pointer;transition:all .2s}.acceso-card:hover{border-color:var(--primary-light);box-shadow:var(--shadow-md);transform:translateY(-1px)}.acceso-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.acceso-time{font-size:.85rem;font-weight:700;color:var(--primary);background:var(--primary-bg);padding:2px 10px;border-radius:12px}.acceso-persons{font-size:.8rem;color:var(--gray-500);font-weight:500}.acceso-visitor{font-weight:600;font-size:1rem;color:var(--gray-800);margin-bottom:4px}.acceso-plate{font-size:.875rem;color:var(--gray-600);margin-bottom:2px}.acceso-reason{font-size:.85rem;color:var(--gray-400)}.acceso-photo-badge{display:inline-block;margin-top:6px;font-size:.75rem;color:var(--gray-500);background:var(--gray-100);padding:2px 8px;border-radius:10px}.acceso-card-qr{border-left:4px solid var(--accent-teal);background:linear-gradient(135deg,#edf9fb,#fff)}.acceso-card-qr:hover{border-left-color:var(--primary)}.acceso-qr-badge{display:inline-block;background:var(--primary);color:#fff;font-size:.65rem;font-weight:700;padding:2px 7px;border-radius:6px;letter-spacing:.5px;line-height:1.3}.acceso-qr-host{font-size:.85rem;color:var(--primary-dark);font-weight:500;margin-bottom:2px}.acceso-qr-code-badge{display:inline-block;font-size:.75rem;color:var(--primary);background:var(--primary-bg);padding:2px 8px;border-radius:10px;font-weight:600;font-family:Courier New,monospace;letter-spacing:1px;margin-top:4px}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-large{max-width:560px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 0}.modal-header h2{font-size:1.15rem;font-weight:700;color:var(--gray-800)}.modal-close{background:none;border:none;font-size:1.2rem;color:var(--gray-400);cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:all .2s}.modal-close:hover{background:var(--gray-100);color:var(--gray-700)}.acceso-form{padding:20px 24px 24px;display:flex;flex-direction:column;gap:16px}.acceso-form .form-group label{font-size:.8rem;font-weight:600;color:var(--gray-500);margin-bottom:4px;display:block}.acceso-form .form-group input,.acceso-form .form-group select{padding:10px 14px;border-radius:var(--radius-sm);border:1.5px solid var(--gray-300);font-size:.95rem;font-family:inherit;width:100%;transition:border-color .2s}.acceso-form .form-group input:focus{outline:none;border-color:var(--primary)}.acceso-form-row{display:flex;gap:12px}.photo-thumbnails{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}.photo-thumb{position:relative;width:80px;height:80px;border-radius:var(--radius-sm);overflow:hidden;border:1.5px solid var(--gray-200)}.photo-thumb img{width:100%;height:100%;object-fit:cover}.photo-thumb-remove{position:absolute;top:2px;right:2px;background:rgba(0,0,0,.6);color:#fff;border:none;border-radius:50%;width:22px;height:22px;font-size:.7rem;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.photo-thumb-remove:hover{background:var(--danger)}.lightbox-overlay{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.92);display:flex;align-items:center;justify-content:center;animation:lightboxFadeIn .2s ease}@keyframes lightboxFadeIn{0%{opacity:0}to{opacity:1}}.lightbox-img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:8px;box-shadow:0 4px 40px rgba(0,0,0,.5);-webkit-user-select:none;-moz-user-select:none;user-select:none}.lightbox-close{position:absolute;top:16px;right:20px;background:hsla(0,0%,100%,.15);border:none;color:#fff;font-size:1.5rem;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;z-index:1}.lightbox-close:hover{background:hsla(0,0%,100%,.3)}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:hsla(0,0%,100%,.15);border:none;color:#fff;font-size:2.5rem;width:48px;height:48px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;line-height:1;z-index:1}.lightbox-nav:hover{background:hsla(0,0%,100%,.3)}.lightbox-prev{left:16px}.lightbox-next{right:16px}.lightbox-counter{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);color:hsla(0,0%,100%,.8);font-size:.9rem;font-weight:500;background:rgba(0,0,0,.4);padding:4px 14px;border-radius:20px}.photo-add-wrapper{position:relative}.photo-add-btn{width:80px;height:80px;border-radius:var(--radius-sm);border:2px dashed var(--gray-300);background:var(--gray-50);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;font-size:.7rem;color:var(--gray-500);font-family:inherit;transition:all .2s}.photo-add-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-bg)}.photo-menu{position:absolute;bottom:88px;left:0;background:#fff;border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);border:1px solid var(--gray-200);overflow:hidden;z-index:10;min-width:160px}.photo-menu button{display:block;width:100%;text-align:left;padding:10px 16px;border:none;background:none;font-size:.875rem;font-family:inherit;color:var(--gray-700);cursor:pointer;transition:background .15s}.photo-menu button:hover{background:var(--gray-100)}.acceso-detail{padding:20px 24px 24px;flex-direction:column}.acceso-detail,.acceso-detail-row{display:flex;gap:16px}.acceso-detail-row .acceso-detail-field{flex:1 1}.acceso-detail-field label{font-size:.75rem;font-weight:600;color:var(--gray-400);text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:4px}.acceso-detail-field p{font-size:.95rem;color:var(--gray-800)}.photo-thumbnails-detail{gap:8px}.photo-thumb-detail{width:100px;height:100px;display:block;cursor:pointer;transition:transform .2s}.photo-thumb-detail:hover{transform:scale(1.05)}.activity-log{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-sm);max-height:200px;overflow-y:auto;padding:0}.activity-log-entry{padding:10px 14px;font-size:.8rem;color:var(--gray-600);line-height:1.5;border-bottom:1px solid var(--gray-200);word-break:break-word}.activity-log-entry:last-child{border-bottom:none}.qr-page{min-height:100vh;background:#fff;display:flex;align-items:center;justify-content:center;padding:20px}.qr-card{background:#fff;border-radius:16px;box-shadow:0 4px 30px rgba(11,109,181,.12);width:100%;max-width:420px;overflow:hidden;border:1px solid var(--gray-100)}.qr-header-bar{background:var(--gradient-brand);color:#fff;text-align:center;padding:24px 20px 18px}.qr-header-bar h1{font-size:1.25rem;font-weight:700;margin-bottom:4px;color:#fff;background:none;-webkit-background-clip:unset;-webkit-text-fill-color:#fff;background-clip:unset}.qr-header-bar p{font-size:.9rem;opacity:.85}.qr-body{padding:24px;display:flex;flex-direction:column;gap:20px}.qr-status{padding:8px 16px;border-radius:20px;color:#fff;font-weight:700;font-size:.85rem;letter-spacing:1px;align-self:center}.qr-field,.qr-status{text-align:center}.qr-field label{font-size:.75rem;font-weight:600;color:var(--gray-400);text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:4px}.qr-field-value{font-size:1rem;color:var(--gray-800);font-weight:500}.qr-field-large{font-size:1.35rem;font-weight:700}.qr-code-container{display:flex;justify-content:center;padding:16px 0}.qr-access-code-container{text-align:center}.qr-access-code-container label{font-size:.75rem;font-weight:600;color:var(--gray-400);text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:6px}.qr-access-code{font-size:2rem;font-weight:800;letter-spacing:6px;font-family:Courier New,monospace;color:var(--primary)}.qr-host-info{background:var(--gray-50);border-radius:var(--radius-sm);padding:16px;display:flex;flex-direction:column;gap:12px;border:1px solid var(--gray-200)}.qr-footer-text{text-align:center;padding:12px 0 0;border-top:1px solid var(--gray-200)}.qr-footer-text p{font-size:.85rem;color:var(--gray-500);font-style:italic}.qr-detail-grid{display:flex;flex-direction:column;gap:14px}.qr-detail-grid .acceso-detail-field{padding:0}.qr-detail-grid .acceso-detail-field label{font-size:.75rem;font-weight:600;color:var(--gray-400);text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:3px}.qr-detail-grid .acceso-detail-field p{font-size:.95rem;color:var(--gray-800)}@media (max-width:600px){.auth-card{padding:28px 20px}.home-header{flex-direction:row;gap:8px;padding:10px 16px}.home-header-brand{justify-content:flex-start}.home-header h1{font-size:.95rem}.modules-grid{grid-template-columns:repeat(2,1fr)}.resident-card{flex-direction:column;align-items:flex-start}.resident-actions{width:100%}.resident-actions button{flex:1 1}.approve-section{width:100%}.admin-header{padding:12px 16px;position:-webkit-sticky;position:sticky;top:0;z-index:100;gap:8px}.admin-header h1{font-size:1.05rem}.admin-main{margin:16px auto;padding:0 12px}.btn-back{padding:10px 14px;font-size:.85rem;min-height:44px}.btn-approve,.btn-reject{min-height:44px;padding:10px 16px}.btn-primary,.btn-secondary{min-height:48px;font-size:.95rem}.accesos-filters{flex-direction:column;align-items:stretch;gap:10px}.acceso-card{padding:14px 16px}.acceso-card:active{background:var(--gray-50);transform:scale(.98)}.acceso-visitor{font-size:.95rem}.modal-overlay{padding:0;align-items:flex-end}.modal-content{max-width:100%;max-height:95vh;max-height:95dvh;border-radius:16px 16px 0 0;-webkit-overflow-scrolling:touch}.modal-large{max-width:100%;height:95vh;height:95dvh}.modal-header{padding:16px 16px 12px;position:-webkit-sticky;position:sticky;top:0;background:#fff;z-index:1;border-bottom:1px solid var(--gray-200);border-radius:16px 16px 0 0}.modal-header h2{font-size:1.05rem}.modal-close{min-width:40px;min-height:40px;display:flex;align-items:center;justify-content:center}.acceso-form{padding:16px;gap:14px}.acceso-form-row{flex-direction:column;gap:14px}.acceso-form .form-group input,.acceso-form .form-group select,.acceso-form .form-group textarea{padding:12px 14px;font-size:16px;min-height:48px}.form-group textarea{font-size:16px!important;min-height:80px}.form-actions{flex-direction:column-reverse;gap:10px}.form-actions .btn-primary,.form-actions .btn-secondary,.form-actions button{width:100%;min-height:48px;font-size:.95rem}.photo-thumbnails{gap:8px}.photo-add-btn,.photo-thumb{width:88px;height:88px}.photo-add-btn{font-size:.75rem}.photo-thumb-remove{width:28px;height:28px;font-size:.85rem;top:4px;right:4px}.photo-menu{min-width:200px;bottom:auto;top:88px;left:0}.photo-menu button{padding:14px 16px;font-size:.95rem;min-height:48px}.acceso-detail-row{flex-direction:column;gap:14px}.acceso-detail{padding:16px}.activity-log{max-height:160px}.activity-log-entry{padding:10px 12px;font-size:.78rem}.empty-state{padding:32px 16px}.profile-main{margin:16px auto;padding:0 12px}.profile-card{padding:24px 16px}.qr-page{align-items:flex-start;padding:24px 12px 12px}.qr-card{max-width:100%}.qr-body{padding:20px 16px;gap:16px}.qr-access-code{font-size:1.6rem;letter-spacing:4px}.qr-field-large{font-size:1.2rem}}@media (max-width:380px){.admin-header h1{font-size:.95rem}.btn-back{padding:8px 10px;font-size:.8rem;gap:4px}.btn-back span{display:none}.acceso-form{padding:14px 12px}.photo-add-btn,.photo-thumb{width:72px;height:72px}.modal-header{padding:14px 12px 10px}}*{box-sizing:border-box;padding:0;margin:0}