*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{background-color:#f5f5f5;min-height:100vh}.session-timeout-overlay{align-items:center;animation:fadeIn .3s ease-out;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.session-timeout-modal{animation:scaleIn .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:400px;padding:40px;text-align:center;width:90%}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.timeout-icon{animation:pulse 2s ease-in-out infinite;margin-bottom:20px}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.session-timeout-modal h2{color:#333;font-size:24px;font-weight:700;margin-bottom:12px}.timeout-message{color:#666;font-size:15px;margin-bottom:20px}.countdown-display{align-items:center;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:12px;display:flex;flex-direction:column;margin:24px 0;padding:20px}.countdown-number{animation:countPulse 1s ease-in-out infinite;color:#f59e0b;font-size:48px;font-weight:700;line-height:1;margin-bottom:8px}@keyframes countPulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.countdown-label{color:#92400e;font-size:14px;font-weight:600;letter-spacing:1px;text-transform:uppercase}.timeout-hint{color:#666;font-size:14px;margin-bottom:24px}.timeout-actions{display:flex;flex-direction:column;gap:12px}.btn-keep-session{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px 24px;transition:all .3s ease}.btn-keep-session:hover{box-shadow:0 8px 20px #667eea66;transform:translateY(-2px)}.btn-logout{background:#fff;border:2px solid #e0e0e0;border-radius:8px;color:#666;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .3s ease}.btn-logout:hover{background-color:#f5f5f5;border-color:#d0d0d0}@media (max-width:600px){.session-timeout-modal{padding:30px 20px}.session-timeout-modal h2{font-size:20px}.countdown-number{font-size:40px}.btn-keep-session{font-size:14px}}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{animation:slideUp .5s ease-out;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-width:450px;padding:40px;width:100%}.login-header{margin-bottom:30px;text-align:center}.login-title{color:#667eea;font-size:2rem;font-weight:700;margin:0 0 10px}.login-subtitle{color:#718096;font-size:1.1rem;margin:0}.form-group,.login-form{margin-bottom:20px}.form-group label{color:#2d3748;font-size:.9rem;margin-bottom:8px}.form-group input{border:2px solid #e2e8f0;border-radius:10px;box-sizing:border-box;font-size:1rem;padding:12px 16px;transition:all .3s ease;width:100%}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background-color:#f7fafc}.error-message,.success-message{margin-bottom:16px}.success-message{align-items:center;background-color:#d1fae5;border:1px solid #6ee7b7;border-radius:8px;color:#065f46;display:flex;gap:8px;padding:12px 16px}.success-icon{font-weight:700}.error-icon,.success-icon{font-size:18px}.login-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:14px;transition:all .3s ease;width:100%}.login-button:hover:not(:disabled){box-shadow:0 8px 20px #667eea66;transform:translateY(-2px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{cursor:not-allowed;opacity:.6}.login-divider{align-items:center;color:#a0aec0;display:flex;margin:20px 0}.login-divider:after,.login-divider:before{background:#e2e8f0;content:"";flex:1 1;height:1px}.login-divider span{font-size:.9rem;padding:0 15px}.google-button{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:10px;color:#2d3748;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:12px;justify-content:center;padding:12px;transition:all .3s ease;width:100%}.google-button:hover:not(:disabled){background:#f7fafc;border-color:#cbd5e0;box-shadow:0 4px 12px #0000001a}.google-button:disabled{cursor:not-allowed;opacity:.6}.google-icon{height:20px;width:20px}.login-footer{border-top:1px solid #e2e8f0;color:#718096;font-size:.9rem;margin-top:25px;padding-top:20px;text-align:center}.link-button{background:none;border:none;color:#667eea;cursor:pointer;font-size:inherit;font-weight:600;padding:0;text-decoration:underline}.link-button:hover{color:#5a67d8}.demo-credentials{background:linear-gradient(135deg,#f7fafc,#edf2f7);border:1px solid #e2e8f0;border-radius:10px;margin-top:20px;padding:15px}.demo-title{color:#2d3748;font-size:.9rem;font-weight:600;margin:0 0 8px}.demo-text{color:#4a5568;font-size:.85rem;margin:4px 0}.demo-text strong{color:#667eea;font-family:Courier New,monospace}@media (max-width:500px){.login-card{padding:30px 20px}.login-title{font-size:1.75rem}.login-subtitle{font-size:1rem}}.register-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.register-card{animation:slideUp .5s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:480px;padding:40px;width:100%}.register-header{margin-bottom:30px;text-align:center}.register-header h1{color:#333;font-size:28px;font-weight:700;margin-bottom:8px}.register-header p{color:#666;font-size:16px}.register-form{gap:20px}.form-group,.register-form{display:flex;flex-direction:column}.form-group{gap:8px}.form-group label{font-size:14px}.form-group input,.form-group select{border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:15px;padding:12px 16px;transition:all .3s ease}.form-group input:focus,.form-group select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group input.error{border-color:#ef4444}.form-group input:disabled,.form-group select:disabled{background-color:#f5f5f5;cursor:not-allowed}.field-hint{color:#666}.field-error,.field-hint{font-size:12px;margin-top:-4px}.field-error{color:#ef4444}.error-message{align-items:center;border:1px solid #fcc;display:flex;font-size:14px;gap:8px;padding:12px 16px}.btn-register{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:10px;padding:14px 24px;transition:all .3s ease}.btn-register:hover:not(:disabled){box-shadow:0 8px 20px #667eea66;transform:translateY(-2px)}.btn-register:active:not(:disabled){transform:translateY(0)}.btn-register:disabled{cursor:not-allowed;opacity:.6}.divider{align-items:center;display:flex;margin:10px 0;text-align:center}.divider:after,.divider:before{border-bottom:1px solid #e0e0e0;content:"";flex:1 1}.divider span{color:#999;font-size:14px;padding:0 16px}.btn-google{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:8px;color:#333;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:12px;justify-content:center;padding:12px 24px;transition:all .3s ease}.btn-google:hover:not(:disabled){background-color:#f8f9fa;border-color:#d0d0d0;transform:translateY(-1px)}.btn-google:disabled{cursor:not-allowed;opacity:.5}.register-footer{border-top:1px solid #e0e0e0;margin-top:24px;padding-top:20px;text-align:center}.register-footer p{color:#666;font-size:14px}.register-footer a{color:#667eea;font-weight:600;text-decoration:none}.register-footer a:hover{text-decoration:underline}@media (max-width:600px){.register-card{padding:30px 20px}.register-header h1{font-size:24px}.btn-google,.btn-register{font-size:14px;padding:12px 20px}}.home-container{background:linear-gradient(135deg,#e8eaf6,#f5f5f5);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh}.home-header{align-items:center;background:linear-gradient(135deg,#4a5fd9,#3949ab);box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;padding:15px 40px}.header-left{color:#fff;gap:15px}.app-title{color:#fff;font-size:18px}.header-separator{color:#ffffff80;font-size:20px}.portal-title{color:#fff;font-size:18px}.header-right{gap:20px}.user-info{align-items:flex-end;color:#fff;flex-direction:column}.user-label{font-size:13px;font-weight:600;letter-spacing:.5px}.user-id{font-size:11px;margin-top:2px;opacity:.9}.logout-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:6px;font-size:14px;padding:8px 20px}.logout-btn:hover{background:#ffffff4d;transform:translateY(-1px)}.home-content{margin:0 auto;max-width:1200px;padding:80px 40px}.cards-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(3,1fr);padding:12px}.menu-card{align-items:center;background:#fff;border-radius:21px;box-shadow:0 6px 18px #0000001a;cursor:pointer;display:flex;flex-direction:column;gap:12px;justify-content:center;min-height:132px;overflow:hidden;padding:36px 24px;position:relative;transition:all .3s ease}.menu-card:before{background:linear-gradient(135deg,#ffffff80,#ffffff1a);border-radius:21px;bottom:0;content:"";left:0;-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;padding:2px;position:absolute;right:0;top:0;transition:opacity .3s ease}.menu-card:hover:before{opacity:1}.menu-card:hover{box-shadow:0 12px 24px #00000026;transform:translateY(-6px)}.menu-card.purple{background:linear-gradient(135deg,#7c4dff,#651fff)}.menu-card.teal{background:linear-gradient(135deg,#26c6da,#00acc1)}.menu-card.green{background:linear-gradient(135deg,#66bb6a,#43a047)}.menu-card.orange{background:linear-gradient(135deg,#ff9800,#f57c00)}.menu-card.pink{background:linear-gradient(135deg,#ec407a,#d81b60)}.menu-card.blue{background:linear-gradient(135deg,#42a5f5,#1e88e5)}.menu-card.white{background:#fff;border:2px solid #e0e0e0}.card-icon{align-items:center;background:#fff3;border-radius:12px;display:flex;font-size:36px;height:48px;justify-content:center;transition:all .3s ease;width:48px}.menu-card.blue .card-icon,.menu-card.green .card-icon,.menu-card.orange .card-icon,.menu-card.pink .card-icon,.menu-card.purple .card-icon,.menu-card.teal .card-icon{background:#fff3;color:#fff}.menu-card.white .card-icon{background:#f5f5f5;color:#424242}.menu-card:hover .card-icon{transform:scale(1.1) rotate(5deg)}.card-title{font-size:12px;margin:0;text-align:center;transition:all .3s ease}.menu-card.blue .card-title,.menu-card.green .card-title,.menu-card.orange .card-title,.menu-card.pink .card-title,.menu-card.purple .card-title,.menu-card.teal .card-title{color:#fff}.menu-card.white .card-title{color:#212121}.menu-card:hover .card-title{transform:scale(1.05)}@media (max-width:1024px){.cards-grid{gap:18px;grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.home-header{flex-direction:column;gap:15px;padding:20px}.header-left{flex-direction:column;gap:5px;text-align:center}.header-separator{display:none}.header-right{flex-direction:column;gap:10px}.cards-grid{gap:12px;grid-template-columns:1fr;padding:6px}.home-content{padding:40px 20px}.menu-card{min-height:108px;padding:24px 18px}}.menu-card{animation:fadeIn .5s ease forwards}.menu-card:first-child{animation-delay:.1s}.menu-card:nth-child(2){animation-delay:.2s}.menu-card:nth-child(3){animation-delay:.3s}.menu-card:nth-child(4){animation-delay:.4s}.menu-card:nth-child(5){animation-delay:.5s}.menu-card:nth-child(6){animation-delay:.6s}.contacts-list-container{background-color:#f5f5f5;min-height:100vh}.contacts-header{background-color:#fff;border-bottom:1px solid #e0e0e0;padding:1rem 2rem}.contacts-content{margin:0 auto;max-width:1200px;padding:2rem}.search-section{align-items:center;background-color:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;display:flex;flex-wrap:wrap;gap:1.5rem;margin-bottom:2rem;padding:2rem}.search-input-wrapper{flex:1 1;min-width:300px;position:relative}.search-icon{font-size:1.2rem;left:1rem;position:absolute;top:50%;transform:translateY(-50%)}.search-input{border:2px solid #e0e0e0;border-radius:12px;font-size:1rem;padding:1rem 1rem 1rem 3rem;transition:border-color .2s}.search-input:focus{border-color:#4a90e2}.contacts-table-wrapper{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000000d;margin-bottom:20px;overflow:hidden}.desktop-table{border-collapse:collapse;width:100%}.mobile-cards{display:none}.contacts-table thead{background:linear-gradient(135deg,#f8f9fa,#e9ecef)}.contacts-table th{border-bottom:2px solid #dee2e6;color:#495057;font-size:14px;font-weight:600;letter-spacing:.5px;padding:18px 20px;text-align:left;text-transform:uppercase}.contact-row{border-bottom:1px solid #e9ecef;cursor:pointer;transition:all .2s ease}.contact-row:hover{background:linear-gradient(90deg,#f8f9ff,#fff);box-shadow:-5px 0 15px #4a5fd91a;transform:translateX(5px)}.contacts-table td{color:#212529;font-size:14px;padding:16px 20px;vertical-align:middle}.contacts-table td:first-child{color:#4a5fd9;font-weight:600}.no-results{color:#6c757d;font-style:italic;padding:40px 20px}@media (max-width:768px){.desktop-table{display:none}.mobile-cards{display:flex;flex-direction:column;gap:12px;padding:15px}.contact-card{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 2px 8px #0000000d;cursor:pointer;padding:16px;position:relative;transition:all .3s ease}.contact-card:active{box-shadow:0 1px 4px #0000001a;transform:scale(.98)}.contact-card:hover{border-color:#4a5fd9;box-shadow:0 4px 12px #4a5fd926}.card-header{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.contact-name{color:#212529;font-size:16px;font-weight:600;margin:0}.contact-nif{color:#4a5fd9;font-size:13px;font-weight:500}.card-body{display:flex;flex-direction:column;gap:8px}.contact-info{align-items:center;color:#495057;display:flex;font-size:14px;gap:10px}.info-icon{font-size:16px}.info-text{flex:1 1}.card-arrow{color:#adb5bd;font-size:20px;position:absolute;right:16px;top:50%;transform:translateY(-50%);transition:all .3s ease}.contact-card:hover .card-arrow{color:#4a5fd9;transform:translateY(-50%) translateX(5px)}}.create-contact-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;flex-shrink:0;font-size:1rem;font-weight:600;padding:1rem 2rem;transition:transform .2s,box-shadow .2s;white-space:nowrap}.create-contact-btn:hover{box-shadow:0 6px 16px #667eea66;transform:translateY(-2px)}.error-message,.loading,.no-results{color:#666;font-size:1rem;padding:2rem;text-align:center}.error-message{background-color:#fee;border-radius:8px;color:#c33;margin-bottom:1rem}.pagination{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin:2rem 0 1rem}.pagination-btn{background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;color:#666;cursor:pointer;font-size:.9rem;font-weight:600;padding:.625rem 1.25rem;transition:all .2s}.pagination-btn:hover:not(:disabled){background-color:#f5f5f5;border-color:#667eea;color:#667eea}.pagination-btn:disabled{cursor:not-allowed;opacity:.4}.pagination-numbers{align-items:center;display:flex;gap:.5rem}.pagination-number{align-items:center;background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;color:#666;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;height:40px;justify-content:center;padding:0;transition:all .2s;width:40px}.pagination-number:hover{background-color:#f5f5f5;border-color:#667eea;color:#667eea}.pagination-number.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 4px 12px #667eea4d;color:#fff}.pagination-ellipsis{color:#999;font-weight:600;padding:0 .5rem}.pagination-info{color:#666;font-size:.9rem;margin-bottom:1rem;text-align:center}@media (max-width:768px){.contacts-header{padding:10px 15px}.header-content{flex-direction:column;gap:15px}.logo{gap:8px}.logo-icon{font-size:20px}.logo h1{font-size:18px}.nav-menu{flex-wrap:wrap;gap:8px;justify-content:space-around;width:100%}.nav-link{font-size:12px;padding:6px 10px}.user-section{flex-wrap:wrap;gap:.75rem;justify-content:center;width:100%}.user-info{order:0}.logout-btn{min-width:80px;order:1;width:auto}.user-details{display:none}.user-avatar{height:36px;width:36px}.contacts-content{padding:15px}.search-section{flex-direction:column;margin-bottom:15px;padding:1.5rem}.search-input-wrapper{min-width:0;min-width:auto;width:100%}.search-input{font-size:14px;padding:12px 15px 12px 45px}.search-icon{font-size:16px;left:15px}.create-contact-btn{font-size:15px;padding:14px;width:100%}.contacts-table{font-size:.85rem}.contacts-table td,.contacts-table th{padding:.75rem .5rem}.pagination{gap:.25rem;margin:1.5rem 0 1rem}.pagination-btn{font-size:.8rem;padding:.5rem .875rem}.pagination-number{font-size:.85rem;height:36px;width:36px}.pagination-info{font-size:.8rem;padding:0 10px}}.modal-overlay{animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-message strong{color:#1a1a1a;font-weight:600}.modal-btn.primary{background:linear-gradient(135deg,#4a90e2,#357abd);box-shadow:0 4px 12px #4a90e24d;color:#fff}.modal-btn.primary:hover{box-shadow:0 6px 16px #4a90e266;transform:translateY(-2px)}@media (max-width:768px){.modal-content{padding:2rem}.modal-actions{flex-direction:column}.modal-btn{width:100%}}.contact-form-container{background-color:#f5f5f5;min-height:100vh}.form-header{background-color:#fff;border-bottom:1px solid #e0e0e0;padding:1rem 2rem}.form-content{margin:3rem auto;max-width:600px;padding:0 2rem}.form-card{background-color:#fff;border-radius:16px;box-shadow:0 4px 16px #00000014;padding:3rem}.form-title{color:#1a1a1a;font-size:1.75rem;font-weight:600;margin-bottom:2rem}.form-group{margin-bottom:1.5rem}.form-group label{color:#333;display:block;font-size:.95rem;font-weight:600;margin-bottom:.5rem}.required{color:#e74c3c}.form-group input[type=email],.form-group input[type=text]{border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;padding:.875rem;transition:border-color .2s;width:100%}.form-group input:focus{border-color:#4a90e2;outline:none}.form-group input.error{border-color:#e74c3c}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.error-text{color:#e74c3c;display:block;font-size:.85rem;margin-top:.25rem}.radio-group{display:flex;gap:2rem}.radio-label{align-items:center;color:#555;cursor:pointer;display:flex;font-weight:400;gap:.5rem}.radio-label input[type=radio]{cursor:pointer;height:18px;width:18px}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2.5rem}.cancel-btn,.save-btn{border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;padding:.875rem 2rem;transition:all .2s}.cancel-btn{background-color:#f0f0f0;border:none;color:#666}.cancel-btn:hover{background-color:#e0e0e0}.save-btn{background:linear-gradient(135deg,#4a90e2,#357abd);border:none;box-shadow:0 4px 12px #4a90e24d;color:#fff}.save-btn:hover:not(:disabled){box-shadow:0 6px 16px #4a90e266;transform:translateY(-2px)}.save-btn:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.header-content{flex-direction:column;gap:1rem}.nav-menu{gap:1rem}.user-section{flex-wrap:wrap;gap:.75rem;justify-content:center}.user-info{order:0}.logout-btn{min-width:80px;order:1;width:auto}.user-details{display:none}.user-avatar{height:36px;width:36px}.form-card{padding:2rem 1.5rem}.form-actions{flex-direction:column}.cancel-btn,.save-btn{width:100%}}.contact-details-container{background-color:#f5f5f5;min-height:100vh}.details-header{background-color:#fff;border-bottom:1px solid #e0e0e0;padding:1rem 2rem}.header-content{justify-content:space-between;margin:0 auto;max-width:1400px}.header-content,.logo{align-items:center;display:flex}.logo{gap:.5rem}.logo-icon{font-size:1.5rem}.logo h1{color:#1a1a1a;font-size:1.25rem;font-weight:600}.nav-menu{display:flex;gap:2rem}.nav-link{color:#666;font-size:.95rem;font-weight:500;text-decoration:none;transition:color .2s}.nav-link.active,.nav-link:hover{color:#1a1a1a}.user-section{align-items:center;display:flex;gap:1rem}.user-avatar{background-position:50%;background-size:cover;border:2px solid #e0e0e0;flex-shrink:0}.user-details{gap:.125rem}.user-name{color:#1a1a1a;font-size:.95rem;line-height:1.2}.user-role{color:#666;font-size:.8rem;line-height:1.2}.logout-btn{background-color:#f0f0f0;color:#666;font-size:.9rem;font-weight:600;padding:.5rem 1.25rem;transition:all .2s}.logout-btn:hover{background-color:#e0e0e0;color:#333}.details-content{margin:0 auto;max-width:1200px;padding:2rem}.details-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:2fr 1fr}.back-link{color:#4a90e2;cursor:pointer;display:inline-block;font-weight:500;margin-bottom:1.5rem}.back-link:hover{text-decoration:underline}.details-title{color:#1a1a1a;font-size:2rem;font-weight:600;margin-bottom:.5rem}.details-subtitle{color:#666;margin-bottom:2rem}.details-main{background-color:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000d;padding:2.5rem}.info-section{border-bottom:1px solid #f0f0f0;margin-bottom:2rem;padding-bottom:2rem}.info-section:last-of-type{border-bottom:none}.section-title{color:#1a1a1a;font-size:1.25rem;font-weight:600;margin-bottom:1.5rem}.info-row{border-bottom:1px solid #f8f8f8;display:grid;grid-template-columns:200px 1fr;padding:1rem 0}.info-row:last-child{border-bottom:none}.info-label{color:#666;font-weight:500}.info-value{color:#1a1a1a}.action-buttons{display:flex;gap:1rem;margin-top:2rem}.delete-btn,.edit-btn{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;padding:.875rem 2rem;transition:all .2s}.edit-btn{background-color:#f0f0f0;color:#333}.edit-btn:hover{background-color:#e0e0e0}.delete-btn{background:linear-gradient(135deg,#4a90e2,#357abd);box-shadow:0 4px 12px #4a90e24d;color:#fff}.delete-btn:hover{box-shadow:0 6px 16px #4a90e266;transform:translateY(-2px)}.details-sidebar{display:flex;flex-direction:column;gap:1.5rem}.company-card,.contact-person-card,.notes-card{background-color:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000d;padding:2rem}.company-card{background:linear-gradient(135deg,#2d5f5d,#1a3a38);color:#fff;text-align:center}.company-icon{align-items:center;background-color:#fff3;border-radius:12px;display:flex;font-size:2rem;font-weight:600;height:80px;justify-content:center;margin:0 auto 1rem;width:80px}.company-name{font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.company-nif,.company-type{font-size:.95rem;margin:.25rem 0;opacity:.9}.card-title{color:#1a1a1a;font-size:1.1rem;font-weight:600;margin-bottom:1rem}.person-info{align-items:center;display:flex;gap:1rem}.person-avatar{background-position:50%;background-size:cover;border:2px solid #f5576c;border-radius:50%;height:50px;width:50px}.person-name{color:#1a1a1a;font-weight:600;margin-bottom:.25rem}.person-role{color:#666;font-size:.9rem}.notes-text{color:#555;font-size:.95rem;line-height:1.6}.loading{color:#666;font-size:1.1rem;padding:3rem;text-align:center}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background-color:#fff;border-radius:16px;box-shadow:0 8px 32px #00000026;max-width:500px;padding:2.5rem;width:90%}.modal-title{color:#e74c3c;font-size:1.5rem;font-weight:600;margin-bottom:1rem;text-align:center}.modal-message{color:#555;font-size:1rem;line-height:1.6;margin-bottom:2rem;text-align:center}.modal-actions{display:flex;gap:1rem;justify-content:center}.modal-btn{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;padding:.875rem 2rem;transition:all .2s}.modal-btn.danger{background:linear-gradient(135deg,#e74c3c,#c0392b);box-shadow:0 4px 12px #e74c3c4d;color:#fff}.modal-btn.danger:hover{box-shadow:0 6px 16px #e74c3c66;transform:translateY(-2px)}.modal-btn.secondary{background-color:#f0f0f0;color:#666}.modal-btn.secondary:hover{background-color:#e0e0e0}@media (max-width:968px){.details-header{padding:.75rem 1rem}.header-content{align-items:stretch;flex-direction:column;gap:1rem}.logo,.nav-menu{justify-content:center}.nav-menu{flex-wrap:wrap;gap:1rem}.nav-link{font-size:.85rem}.user-section{flex-wrap:wrap;gap:.75rem;justify-content:center}.user-info{order:0}.logout-btn{min-width:80px;order:1;width:auto}.user-details{display:none}.user-avatar{height:36px;width:36px}.details-content{padding:1rem}.details-grid{gap:1.5rem}.details-grid,.info-row{grid-template-columns:1fr}.info-row{gap:.5rem}.action-buttons{flex-direction:column}.delete-btn,.edit-btn{width:100%}.details-title{font-size:1.5rem}.details-subtitle{font-size:.9rem}}.documentation-container{background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;min-height:100vh}.documentation-header{align-items:center;background:#fffffff2;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;padding:1rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-left{align-items:center;display:flex;gap:1rem}.app-title{color:#667eea;font-size:1.2rem;font-weight:600;margin:0}.header-separator{color:#cbd5e0;font-size:1.5rem}.portal-title{color:#4a5568;font-size:1rem;font-weight:400;margin:0}.header-right{gap:1.5rem}.header-right,.user-info{align-items:center;display:flex}.user-info{gap:.75rem}.user-avatar{border:2px solid #667eea;border-radius:50%;height:40px;object-fit:cover;width:40px}.user-details{display:flex;flex-direction:column}.user-name{color:#2d3748;font-size:.9rem;font-weight:600}.user-role{color:#718096;font-size:.75rem}.logout-btn{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:.5rem 1.5rem;transition:all .3s ease}.logout-btn:hover{background:#5a67d8;box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.documentation-content{background:#fff;box-shadow:0 0 50px #0000001a;display:flex;flex:1 1;gap:0;margin:0 auto;max-width:1600px;width:100%}.documentation-sidebar{background:#f7fafc;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;max-height:calc(100vh - 70px);overflow-y:auto;width:320px}.sidebar-header{border-bottom:1px solid #e2e8f0;padding:1.5rem}.back-btn{align-items:center;background:#0000;border:1px solid #cbd5e0;border-radius:8px;color:#4a5568;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;padding:.75rem 1rem;transition:all .2s ease;width:100%}.back-btn:hover{background:#fff;border-color:#667eea;color:#667eea}.search-box{border-bottom:1px solid #e2e8f0;padding:1rem 1.5rem;position:relative}.search-input{border:1px solid #cbd5e0;border-radius:8px;font-size:.9rem;padding:.75rem 2.5rem .75rem 1rem;transition:all .2s ease;width:100%}.search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.clear-search{align-items:center;background:#e2e8f0;border:none;border-radius:50%;color:#4a5568;cursor:pointer;display:flex;font-size:.8rem;height:24px;justify-content:center;position:absolute;right:2rem;top:50%;transform:translateY(-50%);transition:all .2s ease;width:24px}.clear-search:hover{background:#cbd5e0}.categories-nav{overflow-y:auto;padding:1rem 0}.category-section{margin-bottom:.5rem}.category-btn{align-items:center;background:#0000;border:none;border-left:3px solid #0000;cursor:pointer;display:flex;gap:1rem;padding:1rem 1.5rem;text-align:left;transition:all .2s ease;width:100%}.category-btn:hover{background:#667eea0d}.category-btn.active{background:#667eea1a;border-left-color:initial}.category-icon{font-size:1.8rem;min-width:40px;text-align:center}.category-info{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.category-title{color:#2d3748;font-size:.95rem;font-weight:600}.category-desc{color:#718096;font-size:.8rem}.subcategories{background:#fff;border-left:3px solid #e2e8f0;margin-left:1.5rem}.subcategory-btn{background:#0000;border:none;border-left:3px solid #0000;color:#4a5568;cursor:pointer;font-size:.9rem;padding:.75rem 1.5rem;text-align:left;transition:all .2s ease;width:100%}.subcategory-btn:hover{background:#667eea0d;color:#667eea}.subcategory-btn.active{background:#667eea1a;border-left-color:#667eea;color:#667eea;font-weight:600}.documentation-main{flex:1 1;max-height:calc(100vh - 70px);overflow-y:auto;padding:2rem 3rem}.welcome-content{max-width:900px}.welcome-content h1{color:#2d3748;font-size:2.5rem;margin-bottom:1rem}.welcome-subtitle{color:#718096;font-size:1.2rem}.quick-links,.welcome-subtitle{margin-bottom:3rem}.quick-links h2{color:#2d3748;font-size:1.5rem;margin-bottom:1.5rem}.quick-links-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.quick-link-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;border-top:4px solid;cursor:pointer;padding:1.5rem;text-align:left;transition:all .3s ease}.quick-link-card:hover{border-color:currentColor;box-shadow:0 8px 20px #0000001a;transform:translateY(-4px)}.quick-link-icon{display:block;font-size:2.5rem;margin-bottom:1rem}.quick-link-card h3{color:#2d3748;font-size:1.1rem;margin-bottom:.5rem}.quick-link-card p{color:#718096;font-size:.9rem;margin-bottom:1rem}.quick-link-count{color:#a0aec0;font-size:.8rem;font-weight:600}.help-banner{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;padding:2rem;text-align:center}.help-banner h3{font-size:1.3rem;margin-bottom:.5rem}.help-banner p{font-size:1rem;margin-bottom:1.5rem;opacity:.9}.contact-support-btn{background:#fff;border:none;border-radius:8px;color:#667eea;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 2rem;transition:all .3s ease}.contact-support-btn:hover{box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.category-overview{max-width:900px}.category-header{align-items:center;background:#f7fafc;border-left:5px solid;border-radius:12px;display:flex;gap:1.5rem;margin-bottom:2rem;padding:2rem}.category-large-icon{font-size:4rem}.category-header h1{color:#2d3748;font-size:2rem;margin:0 0 .5rem}.category-header p{color:#718096;font-size:1.1rem;margin:0}.subcategories-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.subcategory-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;padding:1.5rem;text-align:left;transition:all .3s ease}.subcategory-card:hover{border-color:#667eea;box-shadow:0 8px 20px #667eea26;transform:translateY(-4px)}.subcategory-card h3{color:#2d3748;font-size:1.1rem;margin-bottom:.5rem}.subcategory-card p{color:#667eea;font-size:.9rem;margin:0}.article-content{max-width:800px}.article-header{margin-bottom:2rem}.back-to-category{background:#0000;border:1px solid #cbd5e0;border-radius:8px;color:#4a5568;cursor:pointer;font-size:.9rem;margin-bottom:1.5rem;padding:.5rem 1rem;transition:all .2s ease}.back-to-category:hover{background:#f7fafc;border-color:#667eea;color:#667eea}.article-header h1{color:#2d3748;font-size:2.5rem;margin:0}.article-body{line-height:1.8}.doc-h1{border-bottom:2px solid #e2e8f0;color:#2d3748;font-size:2rem;margin:2rem 0 1rem;padding-bottom:.5rem}.doc-h2{color:#2d3748;font-size:1.5rem;margin:1.5rem 0 1rem}.doc-h3{color:#4a5568;font-size:1.2rem;margin:1.25rem 0 .75rem}.doc-p{margin:.75rem 0}.doc-li,.doc-p{color:#4a5568;font-size:1rem}.doc-li{margin:.5rem 0 .5rem 1.5rem}.doc-code{background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;color:#2d3748;font-family:Courier New,monospace;font-size:.9rem;margin:.5rem 0;overflow-x:auto;padding:.75rem 1rem}.no-results{padding:4rem 2rem;text-align:center}.no-results h2{color:#2d3748;font-size:2rem;margin-bottom:1rem}.no-results p{color:#718096;font-size:1.1rem;margin-bottom:2rem}.clear-search-btn{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:.75rem 2rem;transition:all .3s ease}.clear-search-btn:hover{background:#5a67d8;box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}@media (max-width:1024px){.documentation-sidebar{width:280px}.documentation-main{padding:1.5rem 2rem}}@media (max-width:768px){.documentation-content{flex-direction:column}.documentation-sidebar{border-bottom:1px solid #e2e8f0;border-right:none;max-height:none;width:100%}.documentation-main{padding:1.5rem}.documentation-header{flex-wrap:wrap;gap:1rem;padding:1rem}.header-left,.header-right{gap:.75rem}.app-title{font-size:1rem}.portal-title{font-size:.9rem}.welcome-content h1{font-size:2rem}.welcome-subtitle{font-size:1rem}.quick-links-grid{grid-template-columns:1fr}.article-header h1{font-size:2rem}.doc-h1{font-size:1.75rem}.doc-h2{font-size:1.3rem}.user-details{display:none}}
/*# sourceMappingURL=main.f54b5f3d.css.map*/