@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--primary-blue: #00AAE5;--primary-pink: #CD398B;--primary-blue-light: #4CC4F0;--primary-blue-dark: #0088BA;--primary-pink-light: #E05BA8;--primary-pink-dark: #A12D6F;--gradient-primary: linear-gradient(135deg, var(--primary-blue) 0%, var(--primary-pink) 100%);--gradient-blue: linear-gradient(135deg, var(--primary-blue-light) 0%, var(--primary-blue-dark) 100%);--gradient-pink: linear-gradient(135deg, var(--primary-pink-light) 0%, var(--primary-pink-dark) 100%);--white: #FFFFFF;--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;--success: #10B981;--success-light: #D1FAE5;--warning: #F59E0B;--warning-light: #FEF3C7;--error: #EF4444;--error-light: #FEE2E2;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-glow-blue: 0 0 30px rgba(0, 170, 229, .3);--shadow-glow-pink: 0 0 30px rgba(205, 57, 139, .3);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--font-family: "Inter", system-ui, -apple-system, sans-serif}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-family);background:linear-gradient(180deg,var(--gray-50) 0%,var(--white) 100%);color:var(--gray-800);min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}.app-container{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;min-height:100vh;position:relative;overflow:hidden}.app-container:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 20%,rgba(0,170,229,.08) 0%,transparent 50%),radial-gradient(circle at 70% 80%,rgba(205,57,139,.06) 0%,transparent 50%);z-index:-1;animation:backgroundFloat 20s ease-in-out infinite}@keyframes backgroundFloat{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(2%,2%) rotate(1deg)}50%{transform:translate(-1%,3%) rotate(-1deg)}75%{transform:translate(1%,-2%) rotate(.5deg)}}.card{background:var(--white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:420px;padding:40px;position:relative;overflow:hidden;animation:cardEntrance .6s cubic-bezier(.34,1.56,.64,1)}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient-primary)}@keyframes cardEntrance{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.logo-container{display:flex;justify-content:center;margin-bottom:32px}.logo{width:180px;height:auto;transition:var(--transition-normal)}.logo:hover{transform:scale(1.05)}.title{font-size:1.75rem;font-weight:700;text-align:center;margin-bottom:8px;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{font-size:.95rem;color:var(--gray-500);text-align:center;margin-bottom:32px}.form-group{margin-bottom:24px}.form-label{display:block;font-size:.875rem;font-weight:600;color:var(--gray-700);margin-bottom:8px}.form-input{width:100%;padding:14px 16px;font-size:1rem;font-family:var(--font-family);color:var(--gray-800);background:var(--gray-50);border:2px solid var(--gray-200);border-radius:var(--radius-md);outline:none;transition:var(--transition-normal)}.form-input:focus{border-color:var(--primary-blue);background:var(--white);box-shadow:0 0 0 4px #00aae51a}.form-input::placeholder{color:var(--gray-400)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:14px 24px;font-size:1rem;font-weight:600;font-family:var(--font-family);border:none;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-normal);position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:var(--transition-slow)}.btn:hover:before{left:100%}.btn-primary{width:100%;color:var(--white);background:var(--gradient-primary);box-shadow:var(--shadow-md),var(--shadow-glow-blue)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),var(--shadow-glow-pink)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-outline{color:var(--primary-blue);background:transparent;border:2px solid var(--primary-blue)}.btn-outline:hover{background:var(--primary-blue);color:var(--white)}.options-container{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.option-card{display:flex;align-items:center;gap:16px;padding:20px;background:var(--gray-50);border:2px solid var(--gray-200);border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition-normal)}.option-card:hover{border-color:var(--primary-blue);background:var(--white);transform:translate(4px)}.option-card.selected{border-color:var(--primary-blue);background:#00aae50d;box-shadow:var(--shadow-md)}.option-card.selected .option-icon{background:var(--gradient-primary);color:var(--white)}.option-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--gray-200);border-radius:var(--radius-md);font-size:1.5rem;transition:var(--transition-normal)}.option-content{flex:1}.option-title{font-size:1rem;font-weight:600;color:var(--gray-800)}.option-description{font-size:.85rem;color:var(--gray-500);margin-top:2px}.option-check{width:24px;height:24px;border:2px solid var(--gray-300);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;transition:var(--transition-normal)}.option-card.selected .option-check{background:var(--gradient-primary);border-color:transparent;color:var(--white)}.location-status{display:flex;align-items:center;gap:12px;padding:16px;background:var(--gray-50);border-radius:var(--radius-md);margin-bottom:24px}.location-status.loading{background:var(--warning-light)}.location-status.success{background:var(--success-light)}.location-status.error{background:var(--error-light)}.location-icon{font-size:1.25rem}.location-text{flex:1;font-size:.9rem}.turno-buttons{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}.turno-btn{padding:24px 16px;border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;gap:12px;cursor:pointer;border:2px solid transparent;transition:var(--transition-normal)}.turno-btn-ingreso{background:linear-gradient(135deg,#00aae51a,#00aae50d);border-color:var(--primary-blue)}.turno-btn-ingreso:hover{background:var(--primary-blue);color:var(--white);transform:translateY(-4px);box-shadow:var(--shadow-lg),var(--shadow-glow-blue)}.turno-btn-salida{background:linear-gradient(135deg,#cd398b1a,#cd398b0d);border-color:var(--primary-pink)}.turno-btn-salida:hover{background:var(--primary-pink);color:var(--white);transform:translateY(-4px);box-shadow:var(--shadow-lg),var(--shadow-glow-pink)}.turno-icon{font-size:2.5rem}.turno-text{font-size:1rem;font-weight:600}.message{padding:16px;border-radius:var(--radius-md);text-align:center;margin-bottom:24px;font-weight:500;animation:messageSlide .3s ease}@keyframes messageSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.message-success{background:var(--success-light);color:#065f46}.message-error{background:var(--error-light);color:#991b1b}.message-info{background:#00aae51a;color:var(--primary-blue-dark)}.user-info{display:flex;align-items:center;gap:12px;padding:16px;background:var(--gray-50);border-radius:var(--radius-md);margin-bottom:24px}.user-avatar{width:48px;height:48px;background:var(--gradient-primary);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--white);font-weight:700;font-size:1.25rem}.user-details{flex:1}.user-name{font-weight:600;color:var(--gray-800)}.user-role{font-size:.85rem;color:var(--gray-500)}.btn-logout{padding:8px 16px;font-size:.875rem;color:var(--gray-500);background:transparent;border:1px solid var(--gray-300);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast)}.btn-logout:hover{color:var(--error);border-color:var(--error);background:var(--error-light)}.confirmation-container{text-align:center;padding:32px 0}.confirmation-icon{width:80px;height:80px;margin:0 auto 24px;background:var(--success-light);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:2.5rem;animation:confirmationPop .5s cubic-bezier(.34,1.56,.64,1)}@keyframes confirmationPop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.confirmation-title{font-size:1.5rem;font-weight:700;color:var(--gray-800);margin-bottom:8px}.confirmation-details{color:var(--gray-600);margin-bottom:24px}.confirmation-time{font-size:2rem;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px}.confirmation-date{color:var(--gray-500);font-size:.9rem}.spinner{width:24px;height:24px;border:3px solid rgba(255,255,255,.3);border-top-color:var(--white);border-radius:50%;animation:spin .8s linear infinite}.spinner-dark{border-color:#00aae533;border-top-color:var(--primary-blue)}@keyframes spin{to{transform:rotate(360deg)}}.btn-back{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;font-size:.875rem;color:var(--gray-600);background:transparent;border:none;cursor:pointer;margin-bottom:16px;transition:var(--transition-fast)}.btn-back:hover{color:var(--primary-blue)}@media(max-width:480px){.app-container{padding:16px}.card{padding:24px;border-radius:var(--radius-lg)}.logo{width:150px}.title{font-size:1.5rem}.turno-buttons{grid-template-columns:1fr}.turno-btn{flex-direction:row;padding:20px}}.admin-badge{display:inline-block;margin-left:8px;padding:2px 8px;background:var(--gradient-primary);color:var(--white);font-size:.7rem;font-weight:600;border-radius:var(--radius-full)}.btn-admin-access{width:100%;padding:12px;margin-bottom:24px;background:linear-gradient(135deg,#00aae51a,#cd398b1a);border:2px solid var(--primary-blue);border-radius:var(--radius-md);color:var(--primary-blue);font-weight:600;font-size:.95rem;cursor:pointer;transition:var(--transition-normal)}.btn-admin-access:hover{background:var(--gradient-primary);color:var(--white);border-color:transparent;transform:translateY(-2px)}.admin-container{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:24px;animation:cardEntrance .5s ease}.admin-card{background:var(--white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);overflow:hidden}.admin-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;background:var(--gradient-primary);flex-wrap:wrap;gap:16px}.admin-header-left{display:flex;align-items:center;gap:20px}.admin-logo{width:60px;height:auto;filter:brightness(0) invert(1)}.admin-title{font-size:1.5rem;font-weight:700;color:var(--white);margin:0}.admin-subtitle{font-size:.9rem;color:#fffc;margin:0}.admin-header-right{display:flex;gap:12px}.btn-admin-nav{padding:10px 20px;background:var(--white);color:var(--primary-blue);border:none;border-radius:var(--radius-md);font-weight:600;font-size:.9rem;cursor:pointer;transition:var(--transition-fast)}.btn-admin-nav:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-admin-nav-secondary{background:#fff3;color:var(--white)}.btn-admin-nav-secondary:hover{background:#ffffff4d}.admin-filters{padding:24px 32px;background:var(--gray-50);border-bottom:1px solid var(--gray-200)}.filter-row{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:16px}.filter-row:last-child{margin-bottom:0}.filter-group{flex:1;min-width:150px}.filter-search{flex:2;min-width:250px}.filter-label{display:block;font-size:.75rem;font-weight:600;color:var(--gray-600);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.filter-input{width:100%;padding:10px 14px;font-size:.9rem;font-family:var(--font-family);color:var(--gray-800);background:var(--white);border:1px solid var(--gray-300);border-radius:var(--radius-sm);outline:none;transition:var(--transition-fast)}.filter-input:focus{border-color:var(--primary-blue);box-shadow:0 0 0 3px #00aae51a}.btn-export{display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--success);color:var(--white);border:none;border-radius:var(--radius-sm);font-weight:600;font-size:.9rem;cursor:pointer;transition:var(--transition-fast);white-space:nowrap}.btn-export:hover{background:#059669;transform:translateY(-2px)}.admin-stats{display:flex;gap:16px;padding:24px 32px;background:var(--white);border-bottom:1px solid var(--gray-200);flex-wrap:wrap}.stat-card{flex:1;min-width:120px;display:flex;align-items:center;gap:12px;padding:16px;background:var(--gray-50);border-radius:var(--radius-md);transition:var(--transition-fast)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-icon{font-size:1.5rem}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:1.5rem;font-weight:700;color:var(--gray-800)}.stat-label{font-size:.75rem;color:var(--gray-500);text-transform:uppercase}.stat-ingreso{background:#00aae51a}.stat-salida{background:#cd398b1a}.stat-presencial{background:#10b9811a}.stat-remoto{background:#f59e0b1a}.admin-table-container{padding:24px 32px;overflow-x:auto}.admin-loading,.admin-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:16px;color:var(--gray-500)}.admin-empty-icon{font-size:3rem}.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-table th{padding:14px 16px;text-align:left;font-weight:600;color:var(--gray-700);background:var(--gray-50);border-bottom:2px solid var(--gray-200);white-space:nowrap}.admin-table td{padding:14px 16px;border-bottom:1px solid var(--gray-100);vertical-align:middle}.admin-table tbody tr:hover{background:var(--gray-50)}.admin-table tbody tr.row-inactive{opacity:.6}.table-time{font-weight:600;font-family:SF Mono,Monaco,Courier New,monospace;color:var(--gray-800)}.table-user{display:flex;flex-direction:column}.table-user-name{font-weight:600;color:var(--gray-800)}.table-user-cargo{font-size:.8rem;color:var(--gray-500)}.table-username{font-family:SF Mono,Monaco,Courier New,monospace;font-size:.85rem;color:var(--gray-600)}.table-area{display:inline-block;padding:4px 10px;background:var(--gray-100);border-radius:var(--radius-full);font-size:.8rem;color:var(--gray-700)}.table-badge{display:inline-block;padding:4px 10px;border-radius:var(--radius-full);font-size:.8rem;font-weight:500;white-space:nowrap}.badge-ingreso{background:#00aae51a;color:var(--primary-blue-dark)}.badge-salida{background:#cd398b1a;color:var(--primary-pink-dark)}.badge-presencial{background:#10b9811a;color:#065f46}.badge-remoto{background:#f59e0b1a;color:#92400e}.badge-admin{background:var(--gradient-primary);color:var(--white)}.badge-usuario{background:var(--gray-200);color:var(--gray-700)}.badge-activo{background:var(--success-light);color:#065f46}.badge-inactivo{background:var(--error-light);color:#991b1b}.table-location-link{color:var(--primary-blue);text-decoration:none;font-weight:500;transition:var(--transition-fast)}.table-location-link:hover{color:var(--primary-pink)}.table-location-na{color:var(--gray-400)}.table-actions{display:flex;gap:8px}.btn-action{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--gray-100);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition-fast);font-size:.9rem}.btn-action:hover{transform:scale(1.1)}.btn-edit:hover{background:#00aae533}.btn-toggle:hover{background:#f59e0b33}.btn-delete:hover{background:#ef444433}.user-form-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.user-form-card{background:var(--white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:600px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.user-form-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid var(--gray-200)}.user-form-header h2{font-size:1.25rem;font-weight:700;color:var(--gray-800);margin:0}.user-form-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--gray-100);border:none;border-radius:var(--radius-full);font-size:1.5rem;color:var(--gray-500);cursor:pointer;transition:var(--transition-fast)}.user-form-close:hover{background:var(--gray-200);color:var(--gray-700)}.user-form-card form{padding:24px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group-full{grid-column:1 / -1}.form-checkbox{display:flex;align-items:center;gap:10px;cursor:pointer}.form-checkbox input{width:20px;height:20px;accent-color:var(--primary-blue)}.checkbox-label{font-weight:500;color:var(--gray-700)}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:24px;border-top:1px solid var(--gray-200)}.form-actions .btn{width:auto;min-width:140px}@media(max-width:768px){.admin-container{padding:0}.admin-card{border-radius:0}.admin-header{padding:16px}.admin-header-left{gap:12px}.admin-logo{width:40px}.admin-title{font-size:1.1rem}.admin-subtitle{font-size:.8rem}.btn-admin-nav{padding:8px 12px;font-size:.8rem}.admin-filters,.admin-stats,.admin-table-container{padding:16px}.filter-group,.filter-search{min-width:100%}.stat-card{min-width:calc(50% - 8px)}.form-grid{grid-template-columns:1fr}.form-actions{flex-direction:column}.form-actions .btn{width:100%}}.mobile-cards-view{display:none}.desktop-view{display:block}.table-responsive{width:100%;overflow-x:auto}.marcacion-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:16px;margin-bottom:16px;box-shadow:var(--shadow-sm);transition:var(--transition-fast)}.marcacion-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-blue-light)}.mc-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--gray-100)}.mc-user{display:flex;flex-direction:column}.mc-body{display:flex;flex-direction:column;gap:8px}.mc-info{display:flex;justify-content:space-between;align-items:center}.mc-label{font-size:.85rem;color:var(--gray-500);font-weight:500}.mc-value{font-size:.9rem;color:var(--gray-800);font-weight:500;text-align:right}.mc-location{margin-top:4px;padding-top:12px;border-top:1px dashed var(--gray-200);display:flex;flex-direction:column;gap:8px}@media(max-width:768px){.mobile-cards-view{display:flex;flex-direction:column}.desktop-view{display:none}.admin-table-container{padding:12px;background:transparent}}
