:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.navbar{position:sticky;top:0;z-index:100;background:#3b5bdb;box-shadow:0 2px 16px #00000040;margin-bottom:5px}.navbar-inner{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;padding:0 24px;height:60px;gap:24px}.navbar-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:#fff;font-weight:700;font-size:1rem;letter-spacing:-.3px;white-space:nowrap;flex-shrink:0}.logo-icon{display:flex;align-items:center;justify-content:center;width:34px;height:34px;background:#ffffff26;border-radius:8px;color:#fff}.logo-text span{color:#a5c8ff}.navbar-links{display:flex;list-style:none;gap:24px;flex:1;justify-content:flex-end;align-items:center;margin-right:24px}.nav-link{padding:6px 4px;color:#ffffffe6;text-decoration:none;font-size:.95rem;font-weight:400;border-radius:0;transition:opacity .18s}.nav-link:hover,.nav-link.active{background:transparent;color:#fff;opacity:1;text-shadow:0 0 8px rgba(255,255,255,.3)}.navbar-auth{flex-shrink:0}.auth-btns{display:flex;align-items:center}.btn-nav-pill{padding:8px 24px;border-radius:999px;border:none;background:#4d8ef7;color:#fff;font-size:.9rem;font-weight:500;text-decoration:none;cursor:pointer;transition:background .18s,transform .15s;box-shadow:0 4px 12px #4d8ef733}.btn-nav-pill:hover{background:#3b82f6;transform:translateY(-1px)}.user-menu{display:flex;align-items:center;gap:10px}.user-avatar{width:34px;height:34px;border-radius:50%;background:#ffffff40;color:#fff;font-weight:700;font-size:.9rem;display:flex;align-items:center;justify-content:center}.user-name{color:#fff;font-size:.88rem;font-weight:500}.btn-logout{padding:5px 14px;border-radius:6px;border:1.5px solid rgba(255,255,255,.4);background:transparent;color:#fff;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .18s}.btn-logout:hover{background:#ffffff26}.hamburger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:36px;height:36px;background:none;border:none;cursor:pointer;padding:0;-webkit-tap-highlight-color:transparent}.hamburger:focus{outline:none}.hamburger span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:transform .25s,opacity .25s}.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.mobile-menu{display:none;flex-direction:column;padding:16px 24px 20px;background:#2f4bc2;gap:4px;border-top:1px solid rgba(255,255,255,.12);animation:slideDown .2s ease;position:absolute;top:60px;left:0;right:0;box-shadow:0 10px 20px #0003}.mobile-menu.visible{display:flex}.mobile-link{color:#ffffffd9;text-decoration:none;font-size:.92rem;font-weight:500;padding:10px 12px;border-radius:8px;transition:background .18s}.mobile-link:hover,.mobile-link.active{background:#ffffff1f;color:#fff}.mobile-auth{display:flex;flex-direction:column;gap:10px;margin-top:12px;padding-top:16px;border-top:1px solid rgba(255,255,255,.15)}.mobile-auth .btn-nav-pill{width:100%;text-align:center;padding:10px}.w-full{width:100%;text-align:center}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.navbar-links,.navbar-auth{display:none}.hamburger{display:flex}}@media(min-width:769px){.mobile-menu{display:none!important}}.proveedor-feed-container{max-width:1200px;margin:40px auto;padding:0 20px;font-family:Inter,sans-serif}.feed-title{color:#1a1a1a;font-size:1.8rem;margin-bottom:20px}.table-responsive{width:100%;overflow-x:auto;background:#fff;border-radius:12px;box-shadow:0 4px 15px #0000000d;border:1px solid #eaeaea}.feed-table{width:100%;min-width:900px;border-collapse:collapse}.feed-table th{background:#edf3fa;color:#4a5568;font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;padding:16px 20px;text-align:left;border-bottom:1px solid #eaeaea}.feed-table td{padding:20px;border-bottom:1px solid #eaeaea;vertical-align:middle}.feed-table tr:last-child td{border-bottom:none}.feed-img-placeholder{width:50px;height:50px;background:#e2e8f0;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.piece-title{font-weight:700;color:#1a202c;font-size:1rem;margin-bottom:4px}.piece-subtitle{color:#718096;font-size:.85rem;margin-bottom:4px}.piece-time{color:#a0aec0;font-size:.75rem}.searcher-info{display:flex;align-items:center;gap:12px}.searcher-avatar{width:32px;height:32px;background:#3182ce;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem}.searcher-name{font-weight:600;color:#2d3748;font-size:.9rem}.searcher-location{color:#a0aec0;font-size:.75rem}.distance-badge{background:#f0fff4;color:#38a169;padding:4px 10px;border-radius:20px;font-size:.8rem;font-weight:600}.price-input-group{display:flex;align-items:center;background:#fff;border:1px solid #cbd5e0;border-radius:8px;overflow:hidden}.currency-symbol{padding:8px 12px;color:#718096;background:#f7fafc;border-right:1px solid #cbd5e0}.price-input{width:80px;border:none;padding:8px;outline:none;font-family:inherit}.btn-send-price{background:#edf2f7;border:none;border-left:1px solid #cbd5e0;padding:8px 16px;color:#4a5568;font-weight:600;cursor:pointer;transition:background .2s}.btn-send-price:hover{background:#e2e8f0}.btn-contact{background:#3182ce;color:#fff;border:none;padding:10px 20px;border-radius:20px;font-weight:600;cursor:pointer;transition:background .2s}.btn-contact:hover{background:#2b6cb0}.feed-empty{text-align:center;color:#718096;padding:40px!important}.feed-loading{text-align:center;padding:50px;color:#4a5568;font-size:1.2rem}.services-container{display:flex;flex-direction:column;align-items:center;background-color:#3b5bdb;padding:60px 24px 100px;min-height:calc(100vh - 65px)}.services-header{text-align:center;color:#fff;margin-bottom:50px}.services-title{font-size:2.2rem;font-weight:700;letter-spacing:1px;margin-bottom:12px}.services-subtitle{font-size:1rem;font-weight:400;opacity:.9;letter-spacing:.5px}.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;max-width:1000px;width:100%}.service-card{background-color:#fff;border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:30px 20px 20px;box-shadow:0 8px 24px #00000026;transition:transform .2s ease,box-shadow .2s ease;cursor:pointer}.service-card:hover{transform:translateY(-5px);box-shadow:0 12px 30px #0003}.service-image-container{width:80px;height:80px;display:flex;align-items:center;justify-content:center;margin-bottom:20px}.service-image{max-width:100%;max-height:100%;object-fit:contain}.service-label{color:#1a1a1a;font-size:.95rem;font-weight:700;letter-spacing:.5px}@media(max-width:900px){.services-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:700px){.services-grid{grid-template-columns:repeat(2,1fr);gap:20px}.services-title{font-size:1.8rem}}@media(max-width:400px){.services-grid{grid-template-columns:repeat(2,1fr);gap:12px}.service-card{padding:20px 10px 15px}.service-image-container{width:55px;height:55px;margin-bottom:10px}.service-label{font-size:.8rem}}.services-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease-out}.services-modal-content{background:#fff;border-radius:20px;padding:35px 30px;width:90%;max-width:400px;text-align:center;box-shadow:0 20px 50px #0000004d;animation:slideUp .3s ease-out}.services-modal-content h3{color:#0b57d0;margin-bottom:12px;font-size:1.6rem;font-weight:800}.services-modal-content p{color:#666;margin-bottom:30px;font-size:1rem}.services-modal-options{display:flex;flex-direction:column;gap:14px;margin-bottom:24px}.services-modal-btn{background:#f4f7fc;color:#0b57d0;border:1px solid #d3e3fd;border-radius:12px;padding:16px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 10px #00000005}.services-modal-btn:hover{background:#0b57d0;color:#fff;transform:translateY(-2px);box-shadow:0 8px 20px #0b57d033}.services-modal-btn:active{transform:translateY(0)}.services-modal-close{background:transparent;color:#888;border:none;font-size:.95rem;font-weight:600;cursor:pointer;padding:10px;border-radius:8px;transition:background .2s,color .2s}.services-modal-close:hover{background:#f1f3f4;color:#333}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.request-form-modal{max-width:500px;text-align:left}.request-form-modal h3{text-align:center}.request-form{display:flex;flex-direction:column;gap:16px}.form-group-request{display:flex;flex-direction:column;gap:6px}.form-group-request label{font-size:.85rem;font-weight:600;color:#333}.form-group-request input,.form-group-request textarea{width:100%;padding:12px;border:1px solid #dcdfe4;border-radius:8px;font-family:inherit;font-size:.95rem;background:#fdfdfd;transition:all .2s}.form-group-request input:focus,.form-group-request textarea:focus{outline:none;border-color:#0b57d0;box-shadow:0 0 0 3px #0b57d01a;background:#fff}.request-form-actions{display:flex;justify-content:flex-end;align-items:center;gap:12px;margin-top:10px}.btn-request-submit{background:#0b57d0;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s,transform .1s}.btn-request-submit:hover{background:#0842a0;transform:translateY(-1px)}.btn-request-submit:active{transform:translateY(0)}.form-row-request{display:flex;gap:12px}.form-row-request .form-group-request{flex:1}.request-select{width:100%;padding:12px;border:1px solid #dcdfe4;border-radius:8px;font-family:inherit;font-size:.95rem;background:#fdfdfd;cursor:pointer;transition:all .2s}.request-select:focus{outline:none;border-color:#0b57d0;box-shadow:0 0 0 3px #0b57d01a}.request-file-input{font-size:.9rem}.request-file-input::file-selector-button{background:#f1f3f4;border:1px solid #dcdfe4;border-radius:6px;padding:8px 12px;cursor:pointer;font-weight:500;margin-right:10px;color:#333}.requests-dashboard{width:100%;max-width:1000px;margin-top:60px;padding:0 10px}.dashboard-title{color:#fff;font-size:1.8rem;margin-bottom:20px;text-align:left;border-bottom:2px solid rgba(255,255,255,.2);padding-bottom:10px}.requests-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.request-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 4px 15px #0000001a;display:flex;flex-direction:column;gap:12px;transition:transform .2s,box-shadow .2s}.request-card:hover{transform:translateY(-3px);box-shadow:0 8px 25px #00000026}.request-header{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.request-header h4{margin:0;font-size:1.1rem;color:#1a1a1a;line-height:1.3}.request-status{font-size:.75rem;font-weight:700;padding:4px 10px;border-radius:20px;text-transform:uppercase}.status-activa{background:#e6f4ea;color:#137333}.status-resuelta{background:#fef7e0;color:#b06000}.status-cancelada{background:#fce8e6;color:#c5221f}.request-category{margin:0;font-size:.85rem;color:#0b57d0;font-weight:600}.request-description{font-size:.9rem;color:#555;background:#f8f9fa;padding:12px;border-radius:8px;line-height:1.5}.request-footer{margin-top:auto;text-align:right;color:#888}.contact-container{display:flex;justify-content:center;align-items:center;padding:60px 24px;background-color:#f4f6f8}.contact-card{background:#fff;padding:50px 40px;border-radius:16px;box-shadow:0 10px 30px #0000000d;max-width:600px;width:100%;text-align:center}.contact-title{color:#3b5bdb;font-size:2rem;font-weight:700;margin-bottom:12px}.contact-subtitle{color:#555;font-size:1rem;margin-bottom:30px;line-height:1.5}.contact-form{display:flex;flex-direction:column;gap:20px;text-align:left}.form-group-contact{display:flex;flex-direction:column;gap:8px}.form-group-contact label{font-size:.9rem;font-weight:600;color:#333}.form-group-contact input,.form-group-contact textarea{width:100%;padding:12px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;background:#fdfdfd;transition:border-color .2s,box-shadow .2s;font-family:inherit}.form-group-contact input:focus,.form-group-contact textarea:focus{outline:none;border-color:#3b5bdb;box-shadow:0 0 0 3px #3b5bdb26;background:#fff}.form-group-contact textarea{resize:vertical}.btn-contact-submit{margin-top:10px;padding:14px;background:#3b5bdb;color:#fff;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:background .2s,transform .1s}.btn-contact-submit:hover{background:#2a41a8;transform:translateY(-1px)}.btn-contact-submit:active{transform:translateY(0)}@media(max-width:500px){.contact-card{padding:30px 20px}.contact-title{font-size:1.6rem}}.home-container{flex:1;display:flex;align-items:center;justify-content:center;background-color:#eef2f6;padding:40px 24px}.home-card{display:flex;background:#fff;border-radius:24px;box-shadow:0 10px 40px #0000000d;max-width:1100px;width:100%;overflow:hidden;min-height:560px}.home-login-section{flex:0 0 40%;padding:60px 40px;display:flex;flex-direction:column;justify-content:center;background:#fff}.home-welcome-text{font-size:1.05rem;color:#555;margin-bottom:40px;line-height:1.5}.home-welcome-text strong{color:#111;font-weight:700}.home-form{display:flex;flex-direction:column;gap:20px}.form-group-home{display:flex;flex-direction:column;gap:8px}.form-group-home label{font-size:.85rem;font-weight:700;color:#333}.form-label-row{display:flex;justify-content:space-between;align-items:center}.forgot-link{font-size:.75rem;color:#0b57d0;text-decoration:none;font-weight:600}.input-wrapper-home{position:relative;display:flex;align-items:center}.input-icon-home{position:absolute;left:14px;color:#999;display:flex}.input-wrapper-home input{width:100%;padding:12px 16px 12px 42px;border:1px solid #dcdfe4;border-radius:8px;font-size:.9rem;color:#333;background:#fff;transition:border-color .2s}.input-wrapper-home input:focus{outline:none;border-color:#0b57d0}.input-icon-right{position:absolute;right:14px;color:#999;cursor:pointer}.btn-home-login{background:#0b57d0;color:#fff;border:none;border-radius:999px;padding:14px;font-size:1rem;font-weight:600;cursor:pointer;margin-top:10px;transition:background .2s}.btn-home-login:hover{background:#0842a0}.btn-home-login:disabled{opacity:.7;cursor:not-allowed}.register-hint{text-align:center;margin-top:24px;font-size:.85rem;color:#666}.register-link{color:#0b57d0;text-decoration:none;font-weight:700;margin-left:4px}.login-error{color:#d32f2f;font-size:.85rem;background:#ffebee;padding:10px;border-radius:6px;text-align:center}.home-marketing-section{flex:1;background:#fafbfc;padding:50px 40px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;border-right:1px solid #eef0f3}.marketing-logo{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:30px}.logo-icon-large{max-width:100%;max-height:140px;width:auto;height:auto}.logo-text-large{display:flex;flex-direction:column;align-items:flex-start;color:#0b57d0;font-size:2.2rem;font-weight:500;line-height:1.1;text-transform:lowercase}.logo-text-large span:first-child{font-weight:600;text-transform:capitalize}.marketing-title{color:#002e6e;font-size:1.25rem;font-weight:800;letter-spacing:1px;margin-bottom:8px}.marketing-subtitle{color:#002e6e;font-size:.85rem;font-weight:500;margin-bottom:30px;letter-spacing:.5px}.marketing-stats{display:flex;align-items:center;justify-content:center;gap:40px;margin-bottom:40px;width:100%}.stat-item{display:flex;flex-direction:column;align-items:center}.stat-number{color:#0b57d0;font-size:2.5rem;font-weight:800;line-height:1}.stat-label{color:#0b57d0;font-size:.65rem;font-weight:700;letter-spacing:.5px;margin-top:4px}.stat-divider{width:1px;height:40px;background:#dcdfe4}.marketing-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;width:100%}.step-card{background:#fff;border-radius:16px;padding:24px 12px;display:flex;flex-direction:column;align-items:center;gap:12px;box-shadow:0 4px 12px #00000008;border:1px solid #eef0f3}.step-icon{color:#0b57d0}.step-text{font-size:.65rem;color:#555;font-weight:500;line-height:1.4}@media(max-width:900px){.home-card{flex-direction:column}.home-login-section{padding:40px 24px}.home-marketing-section{padding:40px 24px;border-right:none;border-bottom:1px solid #eef0f3}.marketing-steps{grid-template-columns:repeat(2,1fr)}}@media(max-width:500px){.marketing-steps{grid-template-columns:1fr}.marketing-stats{flex-direction:row;gap:16px}.stat-divider{width:1px;height:35px}.stat-number{font-size:2rem}.stat-label{font-size:.55rem}}.auth-page{position:relative;min-height:calc(100vh - 60px);display:flex;align-items:center;justify-content:center;padding:40px 20px;overflow:hidden}.auth-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 0%,rgba(59,91,219,.15),transparent 60%);pointer-events:none;z-index:0}.auth-card{position:relative;z-index:1;width:100%;max-width:440px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:48px 40px;box-shadow:0 16px 40px #0000004d}.auth-header{text-align:center;margin-bottom:32px}.auth-icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;background:#3b5bdb1a;color:#3b5bdb;border-radius:16px;margin-bottom:20px}.auth-header h1{font-size:1.6rem;font-weight:700;color:var(--text);margin-bottom:8px}.auth-header p{color:var(--muted);font-size:.95rem}.auth-error{display:flex;align-items:center;gap:10px;background:#ff44441a;border:1px solid rgba(255,68,68,.3);color:var(--red);padding:12px 16px;border-radius:8px;font-size:.9rem;margin-bottom:24px}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:.9rem;font-weight:500;color:var(--text)}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:14px;color:var(--muted);display:flex;align-items:center;justify-content:center}.input-wrapper input{width:100%;background:#ffffff0a;border:1px solid var(--border);border-radius:10px;padding:12px 14px 12px 42px;color:var(--text);font-size:.95rem;font-family:inherit;transition:all .2s}.input-wrapper input:focus{outline:none;border-color:#3b5bdb;background:#3b5bdb0d;box-shadow:0 0 0 3px #3b5bdb26}.input-wrapper input::placeholder{color:#ffffff4d}.btn-auth{margin-top:8px;width:100%;padding:14px;border:none;border-radius:10px;background:#3b5bdb;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s,transform .1s;display:flex;justify-content:center;align-items:center;height:50px}.btn-auth:hover:not(:disabled){background:#2f4bc2;transform:translateY(-1px)}.btn-auth:active:not(:disabled){transform:translateY(0)}.btn-auth:disabled{opacity:.7;cursor:not-allowed}.btn-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.auth-footer{margin-top:32px;text-align:center;color:var(--muted);font-size:.95rem}.auth-footer a{color:var(--primary-color);font-weight:500;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.role-selection-card{max-width:600px;text-align:center}.role-options-container{display:flex;gap:20px;justify-content:center;margin-top:10px}.role-option{flex:1;background-color:#fff;border:1px solid #eaeaea;border-radius:12px;padding:30px 20px;cursor:pointer;transition:all .2s ease-in-out;display:flex;flex-direction:column;align-items:center;box-shadow:0 4px 6px #00000005}.role-option:hover{border-color:#d0d0d0;transform:translateY(-3px);box-shadow:0 8px 15px #0000000d}.role-icon-wrapper{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:20px}.role-title{font-size:1.25rem;font-weight:700;color:#1a1a1a;margin-bottom:10px}.role-desc{font-size:.9rem;color:#666;margin:0;line-height:1.4}@media(max-width:600px){.role-options-container{flex-direction:column}}@media(max-width:480px){.auth-card{padding:32px 24px}}.app-footer{background-color:#3b5bdb;width:100%;padding:15px 40px;border-top:1px solid rgba(255,255,255,.1)}.footer-content{max-width:1200px;margin:0 auto;display:flex;justify-content:center;align-items:center}.footer-content p{color:#fff;font-size:.9rem;font-weight:500;margin:0;letter-spacing:.5px}@media(max-width:768px){.footer-content{justify-content:center;text-align:center}}
