@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Outfit:wght@400;500;600;700&display=swap";:root{--font-main:"Inter", sans-serif;--font-heading:"Outfit", sans-serif;--bg-color:#fcfcfc;--bg-sidebar:#fff;--bg-card:#fff;--text-main:#1a1a1a;--text-muted:#64748b;--primary:#036;--primary-hover:#024;--accent:#2563eb;--border-color:#e2e8f0;--table-header:#f8fafc;--table-row-hover:#f1f5f9;--shadow:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--danger:#ef4444;--danger-hover:#dc2626;--input-bg:#fff}[data-theme=dark]{--bg-color:#0b0e14;--bg-sidebar:#10141d;--bg-card:#161b22;--text-main:#e6edf3;--text-muted:#8b949e;--primary:#58a6ff;--primary-hover:#79c0ff;--accent:#1f6feb;--border-color:#30363d;--table-header:#161b22;--table-row-hover:#21262d;--shadow:0 4px 6px -1px #0000004d, 0 2px 4px -2px #0000004d;--input-bg:#0d1117}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-main);background-color:var(--bg-color);color:var(--text-main);line-height:1.5;transition:background-color .3s,color .3s}button{font-family:var(--font-main);cursor:pointer}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600}.app-container{min-height:100vh}.main-content{max-width:1400px;margin:0 auto;padding:2rem;overflow-x:hidden}@media (width<=768px){.main-content{padding:1rem}}.counter{color:var(--accent);background:var(--accent-bg);border:2px solid #0000;border-radius:5px;margin-bottom:24px;padding:5px 10px;font-size:16px;transition:border-color .3s}.counter:hover{border-color:var(--accent-border)}.counter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (width<=1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (width<=1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}.navbar{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;gap:1.5rem;margin-bottom:2rem;padding-bottom:1.25rem;display:flex}.navbar-logo{font-family:var(--font-heading);color:var(--primary);white-space:nowrap;flex-shrink:0;align-items:center;gap:.6rem;font-size:1.1rem;font-weight:700;display:flex}.nav-tabs{align-items:center;gap:.25rem;display:flex}.nav-tab{color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #0000;border-radius:.6rem;align-items:center;gap:.4rem;padding:.5rem .9rem;font-size:.875rem;font-weight:500;transition:all .2s;display:flex}.nav-tab:hover{background-color:var(--table-row-hover);color:var(--text-main)}.nav-tab.active{background-color:var(--primary);color:#fff;border-color:var(--primary)}.navbar-divider{background-color:var(--border-color);flex-shrink:0;width:1px;height:28px}.btn-add-contact{background-color:var(--primary);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:.65rem;flex-shrink:0;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.btn-add-contact:hover{background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #00336640}.search-bar{flex:1;align-items:center;max-width:600px;display:flex;position:relative}.search-icon{color:var(--text-muted);position:absolute;left:1rem}.search-bar input{border:1px solid var(--border-color);background-color:var(--input-bg);width:100%;color:var(--text-main);border-radius:.75rem;outline:none;padding:.75rem 1rem .75rem 3rem;font-size:.95rem;transition:all .2s}.search-bar input:focus{border-color:var(--primary);box-shadow:0 0 0 4px #2563eb1a}.navbar-actions{align-items:center;gap:1.5rem;display:flex}.btn-primary{background-color:var(--bg-card);color:var(--primary);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);border-radius:.75rem;align-items:center;gap:.5rem;padding:.55rem 1.25rem;font-size:.9rem;font-weight:600;transition:all .2s;display:flex}.btn-primary:hover{background-color:var(--table-row-hover);border-color:var(--primary);transform:translateY(-1px)}.nav-icon-btn{color:var(--text-muted);cursor:pointer;border-radius:.5rem;padding:.5rem;transition:all .2s}.nav-icon-btn:hover{background-color:var(--table-row-hover);color:var(--text-main)}.theme-toggle-btn{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-muted);cursor:pointer;border-radius:.65rem;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;transition:all .2s;display:flex}.theme-toggle-btn:hover{color:var(--primary);border-color:var(--primary);background:#2563eb12}.user-profile{border:1px solid var(--border-color);background-color:var(--bg-card);box-shadow:var(--shadow-sm);border-radius:.75rem;align-items:center;gap:.6rem;padding:.4rem .4rem .4rem .75rem;transition:box-shadow .2s;display:flex}.user-profile:hover{box-shadow:var(--shadow-md)}.user-avatar{width:32px;height:32px;color:var(--primary);background:#2563eb1f;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.user-info{flex-direction:column;line-height:1.2;display:flex}.user-name{color:var(--text-main);font-size:.88rem;font-weight:600}.user-role{color:var(--text-muted);text-transform:capitalize;font-size:.72rem}.logout-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;margin-left:.15rem;padding:6px;transition:all .2s;display:flex}.logout-btn:hover{color:#ef4444;background:#ef444414}@media (width<=768px){.navbar{flex-direction:column-reverse;align-items:stretch;gap:1rem}.search-bar{max-width:none}.btn-primary span{display:none}}.table-container{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:1rem;transition:all .3s;overflow:hidden}.table-header-box{border-bottom:1px solid var(--border-color);padding:1.5rem}.table-controls{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1.5rem;display:flex}.items-per-page{color:var(--text-muted);align-items:center;gap:.75rem;font-size:.9rem;display:flex}.items-per-page select{border:1px solid var(--border-color);background-color:var(--input-bg);color:var(--text-main);border-radius:.5rem;outline:none;padding:.4rem .75rem}.table-filters{flex:1;gap:.75rem;display:flex}.table-filters select,.table-filters input{border:1px solid var(--border-color);background-color:var(--input-bg);color:var(--text-main);border-radius:.5rem;outline:none;min-width:140px;padding:.5rem .75rem;font-size:.85rem}.table-filters input:focus,.table-filters select:focus{border-color:var(--primary)}.export-actions{align-items:center;gap:.5rem;display:flex;position:relative}.entry-count{background-color:var(--bg-card);border:1px solid var(--border-color);height:38px;color:var(--text-muted);border-radius:6px;align-items:center;gap:6px;margin-right:.5rem;padding:0 12px;font-size:.85rem;display:flex}.count-label{font-weight:500}.count-value{color:var(--primary);font-weight:700}.count-separator{color:var(--text-muted)}.count-total{font-weight:500}.btn-secondary{background-color:var(--bg-card);color:var(--text-main);border:1px solid var(--border-color);border-radius:.5rem;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.9rem;font-weight:500;transition:all .2s;display:flex}.btn-secondary:hover{background-color:var(--table-row-hover);border-color:var(--text-muted)}.column-picker-dropdown{background-color:var(--bg-card);border:1px solid var(--border-color);z-index:50;box-shadow:var(--shadow);border-radius:.75rem;flex-direction:column;gap:.25rem;width:320px;max-height:750px;margin-top:.5rem;padding:.75rem;display:flex;position:absolute;top:100%;right:0;overflow-y:auto}.column-picker-item{border-radius:.4rem;justify-content:space-between;align-items:center;padding:.5rem;transition:background-color .2s;display:flex}.column-picker-item:hover{background-color:var(--table-row-hover)}.column-picker-item .column-label-wrapper{cursor:pointer;flex:1;align-items:center;gap:.75rem;font-size:.85rem;display:flex}.order-btns{gap:.25rem;display:flex}.order-btns button{border:1px solid var(--border-color);color:var(--text-muted);background:0 0;border-radius:.25rem;justify-content:center;align-items:center;padding:.2rem;display:flex}.order-btns button:hover:not(:disabled){color:var(--primary);border-color:var(--primary)}.order-btns button:disabled{opacity:.3}.column-label-wrapper{cursor:pointer;flex:1;align-items:center;gap:.75rem;display:flex}.column-name{color:var(--text-main);font-size:.85rem}.switch{pointer-events:none;flex-shrink:0;width:34px;height:18px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.slider{cursor:pointer;background-color:var(--border-color);border-radius:20px;transition:all .3s;position:absolute;inset:0}.slider:before{content:"";background-color:#fff;border-radius:50%;width:14px;height:14px;transition:all .3s;position:absolute;bottom:2px;left:2px;box-shadow:0 1px 3px #0003}input:checked+.slider{background-color:var(--primary)}input:focus+.slider{box-shadow:0 0 1px var(--primary)}input:checked+.slider:before{transform:translate(16px)}input:disabled+.slider{opacity:.5;cursor:not-allowed}.table-responsive{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.9rem}thead tr{border-bottom:2px solid var(--border-color)}th{background-color:var(--table-header);text-align:left;color:var(--text-muted);cursor:pointer;white-space:nowrap;border-bottom:none;padding:1rem 1.5rem;font-weight:600;transition:color .2s}th:hover{color:var(--primary)}td{border-bottom:1px solid var(--border-color);vertical-align:middle;padding:1rem 1.5rem}tr:hover td{background-color:var(--table-row-hover)}.font-semibold{font-weight:600}.text-center{text-align:center}.badge{white-space:nowrap;border-radius:6px;align-items:center;gap:6px;padding:4px 12px;font-size:.8rem;font-weight:600;display:inline-flex}.badge-ponce{color:#16a34a;background-color:#22c55e1a}.badge-arecibo{color:var(--primary);background-color:#2563eb1a}.badge-mayagüez{color:#b45309;background-color:#f59e0b1a}[data-theme=dark] .badge-ponce{color:#4ade80;background-color:#22c55e26}[data-theme=dark] .badge-arecibo{color:#60a5fa;background-color:#3b82f626}[data-theme=dark] .badge-mayagüez{color:#fbbf24;background-color:#fbbf2426}.copy-field{align-items:center;gap:.5rem;display:flex}.copy-field button{color:var(--text-muted);opacity:.5;background:0 0;border:none;transition:opacity .2s}.copy-field button:hover{opacity:1;color:var(--primary)}.email-link{color:var(--accent);text-decoration:none}.email-link:hover{text-decoration:underline}.actions-cell{justify-content:flex-start;gap:0;display:flex}th:first-child,td:first-child{padding-left:1.5rem}th.actions-th{cursor:default}th.actions-th:hover{color:var(--text-muted)}.action-btn{background:0 0;border:1px solid #0000;border-radius:.5rem;padding:.35rem;transition:all .2s}.action-btn.view{color:var(--primary)}.action-btn.view:hover{background-color:#e0f2fe;border-color:#7dd3fc}.action-btn.edit{color:var(--accent)}.action-btn.edit:hover{background-color:#ebf5ff;border-color:#bfdbfe}.action-btn.delete{color:#ef4444}.action-btn.delete:hover{background-color:#fef2f2;border-color:#fecaca}.table-footer{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:1.5rem;display:flex}.page-info{color:var(--text-muted);font-size:.9rem}.pagination{flex-wrap:nowrap;justify-content:center;align-items:center;gap:.25rem;display:flex}.pagination .page-arrow{border:1px solid var(--border-color);background-color:var(--bg-card);width:2.25rem;height:2.25rem;color:var(--text-main);cursor:pointer;border-radius:.5rem;justify-content:center;align-items:center;transition:all .2s;display:flex}.pagination .page-arrow:hover:not(:disabled){background-color:var(--primary);color:#fff;border-color:var(--primary)}.pagination .page-arrow:disabled{opacity:.35;cursor:not-allowed}.pagination .page-num{border:1px solid var(--border-color);background-color:var(--bg-card);min-width:2.25rem;height:2.25rem;color:var(--text-main);cursor:pointer;border-radius:.5rem;justify-content:center;align-items:center;padding:0 .5rem;font-size:.9rem;transition:all .2s;display:flex}.pagination .page-num.active{background-color:var(--primary);color:#fff;border-color:var(--primary);font-weight:700}.pagination .page-num:hover:not(.active){background-color:var(--table-row-hover)}.pagination .page-dots{color:var(--text-muted);-webkit-user-select:none;user-select:none;padding:0 .25rem;font-size:1rem}.pagination button.active{background-color:var(--primary);color:#fff;border-color:var(--primary)}.pagination button:disabled{opacity:.35;cursor:not-allowed}.print-only-header{display:none}@media print{.navbar,.table-header-box,.table-footer,.btn-add-contact,.entry-count{display:none!important}.print-only-header{text-align:center;border-bottom:2px solid #000;margin-bottom:2rem;padding-bottom:1rem;display:block!important}.print-only-header h1{color:#000;margin:0;font-size:2rem}.print-date{color:#666;margin-top:.5rem;font-size:.9rem}.main-content{margin:0!important;padding:0!important}.table-container{box-shadow:none!important;border:none!important;width:100%!important}table{border-collapse:collapse!important;border:1px solid #ccc!important;width:100%!important}th,td{color:#000!important;border:1px solid #eee!important;padding:8px 12px!important;font-size:8pt!important}th{-webkit-print-color-adjust:exact;print-color-adjust:exact;background-color:#f8f9fa!important}.actions-th,.actions-cell,th svg{display:none!important}.badge{border:1px solid #ccc!important;padding:2px 6px!important}}.admin-container{max-width:1100px;margin:0 auto}.admin-tabs{border-bottom:2px solid var(--border-color);flex-wrap:wrap;gap:.5rem;margin-bottom:2rem;padding-bottom:0;display:flex}.admin-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:3px solid #0000;border-radius:.5rem .5rem 0 0;align-items:center;gap:.5rem;margin-bottom:-2px;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;transition:all .2s;display:flex}.admin-tab:hover{color:var(--primary);background:#2563eb0d}.admin-tab.active{color:var(--primary);border-bottom-color:var(--primary);background:#2563eb0f}.admin-tab.danger-tab:hover{color:#ef4444;background:#ef44440d}.admin-tab.danger-tab.active{color:#ef4444;background:#ef44440f;border-bottom-color:#ef4444}.admin-tab-content{animation:.25s fadeInTab}@keyframes fadeInTab{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.tab-panel{flex-direction:column;gap:1.5rem;display:flex}.panel-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.panel-header h3{color:var(--text-main);margin:0 0 .25rem;font-size:1.4rem}.panel-header p{color:var(--text-muted);margin:0;font-size:.9rem}.users-list-container{border:1px solid var(--border-color);background:var(--bg-main);border-radius:.75rem;overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:.9rem}.admin-table th{text-align:left;color:var(--text-muted);border-bottom:1px solid var(--border-color);background:#0000000a;padding:.75rem 1rem;font-weight:600}.admin-table td{border-bottom:1px solid var(--border-color);color:var(--text-main);padding:.75rem 1rem}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tbody tr:hover{background:#00000005}.role-badge{text-transform:capitalize;border-radius:12px;align-items:center;gap:4px;padding:3px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.role-badge.admin{color:var(--primary);background:#2563eb1a}.role-badge.viewer{color:var(--text-muted);background:#6b72801a}.status-toggle{cursor:pointer;border:1px solid #0000;border-radius:6px;align-items:center;gap:6px;padding:4px 10px;font-size:.8rem;transition:all .2s;display:inline-flex}.status-toggle.active{color:#16a34a;background:#22c55e1a}.status-toggle.inactive{color:var(--text-muted);background:#6b72801a}.data-cards-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;display:grid}.admin-card{background-color:var(--bg-card);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);border-radius:1rem;flex-direction:column;gap:.75rem;padding:1.5rem;transition:box-shadow .2s;display:flex}.admin-card:hover{box-shadow:var(--shadow-md)}.card-header{align-items:center;gap:.75rem;display:flex}.card-header h4{color:var(--text-main);margin:0;font-size:1rem}.card-icon{width:40px;height:40px;color:var(--primary);background-color:#2563eb1a;border-radius:.75rem;flex-shrink:0;justify-content:center;align-items:center;display:flex}.card-icon.danger{color:#ef4444;background-color:#ef44441a}.admin-card p{color:var(--text-muted);margin:0;font-size:.88rem;line-height:1.5}.danger-card{background:linear-gradient(135deg, var(--bg-card), #ef444408);border:1px solid #ef444440;border-radius:1rem;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1.5rem;padding:1.5rem 2rem;display:flex}.danger-card-left{align-items:flex-start;gap:1rem;display:flex}.danger-card-left h4{color:var(--text-main);margin:0 0 .25rem;font-size:1rem}.danger-card-left p{color:var(--text-muted);max-width:500px;margin:0;font-size:.87rem}.wipe-input{border:2px solid var(--border-color);background:var(--input-bg);width:100%;color:var(--text-main);text-align:center;letter-spacing:2px;border-radius:.5rem;margin-top:1rem;padding:.75rem;font-weight:700}.wipe-input:focus{border-color:#ef4444;outline:none}.danger-alert-icon{color:#ef4444;margin-bottom:1rem}.btn-small-primary{background-color:var(--primary);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:.5rem;align-items:center;gap:.5rem;padding:.45rem 1rem;font-size:.85rem;font-weight:600;transition:opacity .2s;display:inline-flex}.btn-small-primary:hover{opacity:.85}.btn-icon-danger{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:5px;transition:all .2s}.btn-icon-danger:hover{color:#ef4444;background:#ef44441a}.btn-icon-edit{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:5px;transition:all .2s}.btn-icon-edit:hover{color:var(--primary);background:#2563eb1a}.loading-state{color:var(--text-muted);justify-content:center;padding:2rem;display:flex}.modal-overlay,.mapping-overlay{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:1000;background:#0006;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-content,.mapping-modal{background:var(--bg-card);width:90%;max-width:500px;box-shadow:var(--shadow-2xl);border:1px solid var(--border-color);border-radius:1.25rem;overflow:hidden}.mapping-modal{max-width:600px}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.modal-body{padding:1.5rem}.modal-footer,.mapping-footer{background:#00000005;justify-content:flex-end;gap:.75rem;padding:1.25rem 1.5rem;display:flex}.mapping-list{flex-direction:column;gap:1rem;max-height:60vh;padding:1.5rem;display:flex;overflow-y:auto}.mapping-row{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;gap:1.5rem;padding-bottom:.75rem;display:flex}.mapping-row:last-child{border-bottom:none}.mapping-row label{color:var(--text-muted);flex:1;font-size:.9rem;font-weight:500}.mapping-row select{border:1px solid var(--border-color);background:var(--input-bg);color:var(--text-main);cursor:pointer;border-radius:.5rem;outline:none;min-width:180px;padding:.5rem .75rem;font-size:.85rem}.mapping-row select:focus{border-color:var(--primary)}.result-alert.floating{z-index:1000;max-width:400px;box-shadow:var(--shadow-lg);background:var(--bg-card);border-radius:1rem;align-items:center;gap:1rem;padding:1rem 1.5rem;animation:.3s ease-out slideInRight;display:flex;position:fixed;bottom:2rem;right:2rem}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background-color:var(--bg-card);width:90%;max-width:800px;max-height:90vh;box-shadow:var(--shadow);border-radius:1.25rem;animation:.3s ease-out modalFadeIn;overflow-y:auto}@keyframes modalFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid var(--border-color);background-color:var(--bg-card);z-index:10;justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex;position:sticky;top:0}.header-title-container{flex-direction:column;gap:.25rem;display:flex}.modal-header h3{color:var(--text-main);margin:0;font-size:1.5rem}.step-indicator{color:var(--primary);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem;font-weight:600}.close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;padding:.5rem;transition:all .2s}.close-btn:hover{background-color:var(--table-row-hover);color:var(--text-main)}.contact-form-body{padding:2rem}.form-container{min-height:250px}.form-step{flex-direction:column;gap:1.5rem;animation:.3s ease-out stepIn;display:flex}@keyframes stepIn{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.form-grid{grid-template-columns:1fr;gap:2rem;display:grid}@media (width<=900px){.form-grid{gap:1.5rem}}.form-section{flex-direction:column;gap:1.25rem;display:flex}.form-section.full-width{grid-column:span 2}.section-title{color:var(--primary);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.9rem;font-weight:700;display:flex}.form-row{flex-wrap:wrap;gap:1rem;display:flex}.form-group{flex-direction:column;gap:.5rem;display:flex}.col-2{flex:0 0 calc(16.66% - 1rem);min-width:80px}.col-3{flex:0 0 calc(25% - 1rem);min-width:120px}.col-4{flex:calc(33.33% - 1rem);min-width:150px}.col-6{flex:calc(50% - 1rem);min-width:200px}.col-8{flex:calc(66.66% - 1rem);min-width:250px}.col-12{flex:100%}.form-group label{color:var(--text-muted);font-size:.85rem;font-weight:600}.form-group input,.form-group select{border:1px solid var(--border-color);background-color:var(--input-bg);color:var(--text-main);border-radius:.5rem;outline:none;padding:.65rem .85rem;font-size:.95rem;transition:all .2s}.form-group input:focus,.form-group select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.input-with-icon{align-items:center;display:flex;position:relative}.input-with-icon svg{color:var(--text-muted);position:absolute;left:.75rem}.input-with-icon input{width:100%;padding-left:2.5rem}.error{border-color:#ef4444!important}.error-text{color:#ef4444;margin-top:.25rem;font-size:.75rem}.form-actions{border-top:1px solid var(--border-color);justify-content:flex-end;gap:1rem;margin-top:3rem;padding-top:1.5rem;display:flex}.btn-ghost{border:1px solid var(--border-color);color:var(--text-muted);background:0 0;border-radius:.75rem;padding:.75rem 1.5rem;font-weight:600;transition:all .2s}.btn-ghost:hover{background-color:var(--table-row-hover);color:var(--text-main)}@media (width<=768px){.modal-content{border-radius:1rem;width:95%!important;max-width:95%!important}.contact-form{padding:1rem!important}.form-grid{display:block!important}.form-section{margin-bottom:2rem}.form-row{display:block!important}.form-group{width:100%!important;margin-bottom:1rem!important;display:block!important}.col-3,.col-4,.col-6,.col-8,.col-12{flex:0 0 100%!important;width:100%!important}}@media (width<=480px){.modal-header{padding:1rem}.modal-header h3{font-size:1.1rem}.form-actions{flex-direction:column;padding:1rem}.form-actions button{width:100%}}.confirm-modal{max-width:450px}.confirm-modal .modal-body{text-align:center;color:var(--text-main);padding:2rem;font-size:1.1rem}.modal-footer{border-top:1px solid var(--border-color);background-color:var(--table-header);justify-content:flex-end;gap:1rem;padding:1.5rem 2rem;display:flex}.btn-danger{background-color:var(--danger);color:#fff;border:none;border-radius:.75rem;padding:.75rem 1.5rem;font-weight:600;transition:all .2s}.btn-danger:hover{background-color:var(--danger-hover);transform:translateY(-1px);box-shadow:0 4px 12px #ef444433}.drawer-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;opacity:0;background-color:#00000080;animation:.3s forwards fadeIn;position:fixed;inset:0}.drawer-content{background-color:var(--bg-card);z-index:1001;border-left:1px solid var(--border-color);flex-direction:column;width:570px;max-width:100%;height:100%;transition:right .3s ease-out;animation:.3s forwards slideIn;display:flex;position:fixed;top:0;right:-570px;box-shadow:-5px 0 25px #0003}@keyframes fadeIn{to{opacity:1}}@keyframes slideIn{to{right:0}}.drawer-header{border-bottom:1px solid var(--border-color);background-color:var(--table-header);justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.drawer-header h2{color:var(--primary);margin:0;font-size:1.25rem}.close-drawer{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:.5rem;padding:.5rem;transition:all .2s}.close-drawer:hover{background-color:var(--table-row-hover);color:var(--text-main)}.drawer-body{flex:1;padding:2rem;overflow-y:auto}.contact-hero{text-align:center;border-bottom:1px solid var(--border-color);margin-bottom:2rem;padding-bottom:2rem}.contact-avatar{background-color:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 1rem;font-size:1.5rem;font-weight:700;display:flex;box-shadow:0 4px 12px #0066cc4d}.contact-hero h3{color:var(--text-main);margin:.5rem 0;font-size:1.25rem;line-height:1.4}.contact-hero .puesto{color:var(--text-muted);font-size:1rem;font-weight:500}.info-section{border-top:1px solid var(--border-color);margin-bottom:2rem;padding-top:1.5rem}.info-section:first-of-type{border-top:none;padding-top:0}.info-section h4{text-transform:uppercase;letter-spacing:.05em;color:var(--primary);margin-bottom:1rem;font-size:.85rem;font-weight:700}.info-grid{flex-direction:column;gap:1.25rem;display:flex}.info-row{gap:2rem;display:flex}.info-row .info-item{flex:1}.info-item{flex-direction:column;gap:.25rem;display:flex}.info-label{color:var(--text-muted);font-size:.75rem}.info-value{color:var(--text-main);font-size:.9rem;font-weight:500}.info-value.email{color:var(--accent);text-decoration:none}.badge-recenter{margin-top:.25rem;display:inline-block}@media (width<=620px){.drawer-content{width:100%}}.login-page{background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 50%,#0f172a 100%);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-bg-overlay{pointer-events:none;background:radial-gradient(70% 70% at 10% 20%,#2563eb2e 0%,#0000 60%),radial-gradient(60% 60% at 90% 80%,#6366f124 0%,#0000 55%),radial-gradient(50% 50%,#0ea5e914 0%,#0000 70%);position:absolute;inset:0}.login-page:before{content:"";pointer-events:none;background-image:linear-gradient(#ffffff08 1px,#0000 1px),linear-gradient(90deg,#ffffff08 1px,#0000 1px);background-size:40px 40px;position:absolute;inset:0}.login-card{z-index:1;-webkit-backdrop-filter:blur(24px);background:#ffffff0d;border:1px solid #ffffff1f;border-radius:1.5rem;width:100%;max-width:420px;padding:2.5rem;position:relative;box-shadow:0 25px 60px #0006,inset 0 0 0 1px #ffffff0d}.login-brand{align-items:center;gap:.85rem;margin-bottom:1.5rem;display:flex}.login-logo{filter:drop-shadow(0 4px 12px #2563eb66);flex-shrink:0}.login-brand h1{color:#fff;margin:0;font-size:1.15rem;font-weight:700;line-height:1.2}.login-brand p{color:#ffffff80;margin:0;font-size:.75rem}.login-divider{background:linear-gradient(90deg,#0000,#ffffff26,#0000);height:1px;margin-bottom:1.75rem}.login-card h2{color:#fff;margin:0 0 .4rem;font-size:1.5rem;font-weight:700}.login-subtitle{color:#ffffff80;margin:0 0 1.75rem;font-size:.88rem}.login-form{flex-direction:column;gap:1rem;display:flex}.login-field{flex-direction:column;gap:.4rem;display:flex}.login-field label{color:#fff9;text-transform:uppercase;letter-spacing:.05em;font-size:.82rem;font-weight:600}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:#ffffff59;pointer-events:none;position:absolute;left:.9rem}.input-wrapper input{color:#fff;box-sizing:border-box;background:#ffffff12;border:1px solid #ffffff1f;border-radius:.65rem;width:100%;padding:.75rem 2.75rem;font-size:.95rem;transition:border-color .2s,background .2s}.input-wrapper input::placeholder{color:#ffffff40}.input-wrapper input:focus{background:#ffffff1a;border-color:#60a5fa99;outline:none}.toggle-pw{color:#ffffff59;cursor:pointer;background:0 0;border:none;align-items:center;padding:4px;transition:color .2s;display:flex;position:absolute;right:.9rem}.toggle-pw:hover{color:#ffffffb3}.login-error{color:#fca5a5;background:#ef444426;border:1px solid #ef44444d;border-radius:.6rem;align-items:center;gap:.5rem;padding:.7rem 1rem;font-size:.88rem;display:flex}.btn-login{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2563eb,#4f46e5);border:none;border-radius:.75rem;justify-content:center;align-items:center;gap:.6rem;margin-top:.5rem;padding:.85rem;font-size:1rem;font-weight:700;transition:opacity .2s,transform .15s;display:flex;box-shadow:0 4px 20px #2563eb66}.btn-login:hover:not(:disabled){opacity:.92;transform:translateY(-1px)}.btn-login:disabled{opacity:.5;cursor:not-allowed}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-hint{text-align:center;color:#ffffff4d;margin-top:1.5rem;font-size:.8rem}.login-hint strong{color:#ffffff8c}
