:root{--bg-color: #0a0e1a;--bg-secondary: #111827;--bg-tertiary: #1a2035;--text-color: #cbd5e1;--text-secondary: #94a3b8;--text-muted: #64748b;--primary-color: #353DF0;--primary-light: #5b63f5;--primary-dim: rgba(53, 61, 240, .12);--primary-glow: rgba(53, 61, 240, .2);--secondary-color: #0ea5e9;--secondary-dim: rgba(14, 165, 233, .1);--success: #22c55e;--error: #ef4444;--warning: #f59e0b;--card-bg: #111827;--card-hover: #1e293b;--border-color: #1e293b;--border-accent: rgba(53, 61, 240, .2);--glow-primary: 0 0 15px rgba(53, 61, 240, .15);--glow-blue: 0 0 15px rgba(14, 165, 233, .15)}body{margin:0;font-family:Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-color);color:var(--text-color)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box}html,body,#root{height:100%}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:20px;background:#0a0e1a;background-image:linear-gradient(rgba(53,61,240,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(53,61,240,.03) 1px,transparent 1px);background-size:40px 40px}.login-card{background:#111827;border:1px solid #1e293b;border-radius:12px;padding:48px 40px;width:100%;max-width:420px;box-shadow:0 4px 30px #0000004d}.login-card h1{color:#353df0!important;font-size:32px;font-weight:900;text-align:center;margin:0 0 12px}.login-card p{color:#94a3b8!important;font-size:15px;text-align:center;margin:0 0 32px}.form-input{width:100%;padding:14px 16px;border:1px solid #1e293b!important;border-radius:8px;font-size:15px;background:#0f1629!important;color:#cbd5e1!important;box-sizing:border-box;transition:all .3s ease}.form-input::placeholder{color:#475569!important}.form-input:focus{outline:none;border-color:#353df0!important;box-shadow:0 0 0 3px #353df01f}.login-button{width:100%;padding:14px;background:#353DF0;color:#fff!important;border:none;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;margin-top:16px;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}.login-button:hover{background:#5b63f5;box-shadow:0 0 20px #353df033;transform:translateY(-1px)}.login-button:disabled{background:#1e293b;color:#475569!important;cursor:not-allowed;box-shadow:none;transform:none}.register-link-button{display:block;text-align:center;margin-top:24px;color:#64748b!important;font-size:14px;background:none;border:none;font-weight:600;cursor:pointer;transition:color .3s ease}.register-link-button:hover{color:#353df0!important}.register-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:20px;background:#0a0e1a;background-image:linear-gradient(rgba(53,61,240,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(53,61,240,.03) 1px,transparent 1px);background-size:40px 40px}.register-card{background:#111827;border:1px solid #1e293b;border-radius:12px;padding:48px 40px;width:100%;max-width:420px;box-shadow:0 4px 30px #0000004d}.register-card h1{color:#353df0!important;font-size:28px;font-weight:900;text-align:center;margin:0 0 12px}.register-card p{color:#94a3b8!important;font-size:15px;text-align:center;margin:0 0 32px}.form-group{margin-bottom:24px}.form-group label{display:block;color:#cbd5e1!important;font-weight:600!important;font-size:13px;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.form-group input{width:100%;padding:14px 16px;border:1px solid #1e293b!important;border-radius:8px;font-size:15px;background:#0f1629!important;color:#cbd5e1!important;box-sizing:border-box;transition:all .3s ease}.form-group input::placeholder{color:#475569!important}.form-group input:focus{outline:none;border-color:#353df0!important;box-shadow:0 0 0 3px #353df01f}.register-button{width:100%;padding:14px;background:#353DF0;color:#fff!important;border:none;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;margin-top:16px;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}.register-button:hover{background:#5b63f5;box-shadow:0 0 20px #353df033;transform:translateY(-1px)}.register-button:disabled{background:#1e293b;color:#475569!important;cursor:not-allowed;box-shadow:none;transform:none}.login-link{display:block;text-align:center;margin-top:24px;color:#64748b!important;font-size:14px}.login-link span{color:#353df0!important;font-weight:700;cursor:pointer;transition:color .3s ease}.login-link span:hover{color:#5b63f5!important}.error-message{background:rgba(239,68,68,.1);color:#f87171;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:.9rem;text-align:center;border:1px solid rgba(239,68,68,.15)}.success-message{background:rgba(34,197,94,.1);color:#4ade80;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:.9rem;text-align:center;border:1px solid rgba(34,197,94,.15)}.image-analysis-extended-container{min-height:100vh;background:#000000;padding:20px;font-family:Arial,sans-serif}.analysis-header{display:flex;align-items:center;margin-bottom:40px;background:rgba(255,255,255,.1);padding:25px 30px;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 32px #0000001a;border:1px solid rgba(255,255,255,.2)}.back-button{background:linear-gradient(45deg,#FFD700,#FFA500);color:#000;border:none;padding:12px 20px;border-radius:25px;cursor:pointer;margin-right:20px;display:flex;align-items:center;gap:8px;font-weight:700;transition:all .3s ease;box-shadow:0 4px 15px #ffd7004d}.back-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ffd70066}h2{color:gold;display:flex;align-items:center;gap:12px;margin:0;font-size:2.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.3);background:linear-gradient(45deg,#FFD700,#FFA500);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.analysis-content{display:grid;grid-template-columns:1fr 1fr;gap:30px;max-width:1400px;margin:0 auto}.upload-section{display:flex;flex-direction:column}.upload-card{background:rgba(255,255,255,.1);padding:30px;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 32px #0000001a;border:1px solid rgba(255,255,255,.2)}.upload-area{text-align:center;margin-bottom:30px}.upload-label{display:inline-flex;flex-direction:column;align-items:center;gap:15px;padding:40px;border:3px dashed rgba(255,255,255,.3);border-radius:20px;cursor:pointer;transition:all .3s ease;background:rgba(255,255,255,.05)}.upload-label:hover{border-color:gold;background:rgba(255,215,0,.1);transform:translateY(-2px)}.upload-icon{font-size:3rem;color:gold}.upload-label span{font-size:1.2rem;color:#fff;font-weight:700}.image-preview{margin-top:20px}.image-container{position:relative;display:inline-block;border-radius:20px;overflow:hidden;box-shadow:0 8px 32px #0000004d}.image-container img{max-width:400px;max-height:300px;border-radius:20px;display:block}.detection-canvas{position:absolute!important;top:0!important;left:0!important;pointer-events:none!important;border-radius:20px;z-index:1!important}.image-info{margin-top:20px;background:rgba(0,0,0,.3);padding:20px;border-radius:15px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid rgba(255,255,255,.1)}.image-info p{margin:5px 0;color:#fff}.error-message{background:rgba(244,67,54,.2);color:#ff6b6b;padding:15px;border-radius:10px;margin:20px 0;border:1px solid rgba(244,67,54,.3)}.action-buttons{display:flex;gap:15px;margin-top:20px}.analyze-button{background:linear-gradient(45deg,#4CAF50,#45a049);color:#fff;border:none;padding:15px 30px;border-radius:25px;cursor:pointer;font-size:1.1rem;font-weight:700;transition:all .3s ease;box-shadow:0 4px 15px #4caf504d;flex:1}.analyze-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #4caf5066}.analyze-button:disabled{opacity:.6;cursor:not-allowed}.results-section{grid-column:1 / -1}.results-card{background:rgba(255,255,255,.1);padding:30px;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 32px #0000001a;border:1px solid rgba(255,255,255,.2)}.tabs-container{display:flex;gap:10px;margin-bottom:30px;border-bottom:2px solid rgba(255,255,255,.1);padding-bottom:10px}.tab-button{background:transparent;border:none;padding:15px 25px;border-radius:15px;cursor:pointer;display:flex;align-items:center;gap:8px;color:#ffffffb3;font-weight:700;transition:all .3s ease;position:relative}.tab-button:hover{background:rgba(255,255,255,.1);color:#fff}.tab-button.active{background:linear-gradient(45deg,#FFD700,#FFA500);color:#000;box-shadow:0 4px 15px #ffd7004d}.tab-icon{font-size:1.2rem}.tab-content{min-height:400px}.raw-data-tab,.classification-tab,.knowledge-tab,.action-tab{padding:20px 0}.detections-list,.classifications-list{display:flex;flex-direction:column;gap:20px}.detection-item,.classification-item{background:rgba(255,255,255,.05);padding:20px;border-radius:15px;border-left:4px solid #FFD700;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.detection-header,.classification-details h4{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.detection-label{font-size:1.2rem;font-weight:700;color:gold}.detection-confidence{background:rgba(76,175,80,.2);color:#4caf50;padding:5px 15px;border-radius:20px;font-weight:700}.detection-details p,.classification-details p{margin:5px 0;color:#fffc}.knowledge-content{background:rgba(255,255,255,.05);padding:30px;border-radius:15px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.challenge-steps{display:flex;flex-direction:column;gap:30px}.challenge-step{background:rgba(255,255,255,.05);padding:25px;border-radius:15px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.challenge-step h4{color:gold;margin-bottom:15px;font-size:1.3rem}.radio-group{display:flex;flex-direction:column;gap:10px}.radio-option{display:flex;align-items:center;gap:10px;padding:10px;border-radius:10px;cursor:pointer;transition:all .3s ease;color:#fff}.radio-option:hover{background:rgba(255,255,255,.1)}.radio-option input[type=radio]{accent-color:#FFD700}.notes-textarea{width:100%;min-height:120px;padding:15px;border:2px solid rgba(255,255,255,.3);border-radius:10px;background:rgba(255,255,255,.1);color:#fff;font-family:inherit;font-size:1rem;resize:vertical;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.notes-textarea:focus{outline:none;border-color:gold;background:rgba(255,255,255,.2)}.notes-textarea::placeholder{color:#ffffff80}.generate-report-button{background:linear-gradient(45deg,#FF6B6B,#FF8E8E);color:#fff;border:none;padding:15px 30px;border-radius:25px;cursor:pointer;font-size:1.1rem;font-weight:700;transition:all .3s ease;box-shadow:0 4px 15px #ff6b6b4d;margin-top:20px}.generate-report-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #ff6b6b66}.generate-report-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.analysis-content{grid-template-columns:1fr}.tabs-container{flex-wrap:wrap}.tab-button{flex:1;min-width:120px}}.language-selector{position:relative;display:inline-block}.language-button{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;padding:10px 15px;border-radius:25px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:.9rem;font-weight:500;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);min-width:140px;justify-content:space-between}.language-button:hover{background:rgba(255,255,255,.2);border-color:gold;transform:translateY(-1px)}.globe-icon{font-size:1.1rem;color:gold}.language-text{display:flex;align-items:center;gap:5px}.chevron-icon{font-size:.8rem;transition:transform .3s ease;color:#ffffffb3}.chevron-icon.open{transform:rotate(180deg)}.language-dropdown{position:absolute;top:100%;left:0;right:0;background:rgba(0,0,0,.9);border:1px solid rgba(255,255,255,.2);border-radius:15px;padding:8px;margin-top:5px;z-index:1000;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 8px 32px #0000004d;animation:fadeInDown .3s ease}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.language-option{background:transparent;border:none;color:#fff;padding:12px 15px;border-radius:10px;cursor:pointer;display:flex;align-items:center;gap:10px;width:100%;text-align:left;font-size:.9rem;transition:all .3s ease;margin-bottom:2px}.language-option:hover{background:rgba(255,255,255,.1)}.language-option.active{background:linear-gradient(45deg,#FFD700,#FFA500);color:#000;font-weight:600}.language-option:last-child{margin-bottom:0}.flag{font-size:1.2rem;min-width:20px}.name{flex:1}@media (max-width: 768px){.language-button{min-width:120px;padding:8px 12px;font-size:.8rem}.language-text{font-size:.8rem}.language-option{padding:10px 12px;font-size:.8rem}}.drone-viewer-container{padding:20px;background:#0a0e1a;color:#cbd5e1;min-height:100vh;background-image:linear-gradient(rgba(53,61,240,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(53,61,240,.02) 1px,transparent 1px);background-size:40px 40px}.drone-viewer-header{display:flex;align-items:center;margin-bottom:20px}.back-button{background:#353DF0;color:#fff;border:none;padding:10px 15px;border-radius:10px;cursor:pointer;margin-right:20px;display:flex;align-items:center;gap:5px;font-weight:700;transition:all .3s ease;box-shadow:0 2px 10px #353df026}h2{color:#353df0;display:flex;align-items:center;gap:10px;margin:0}.camera-controls{background:#111827;padding:20px;border-radius:12px;margin-bottom:20px;text-align:center;border:1px solid #1e293b;box-shadow:0 4px 20px #0000004d}.info-text{background:#0f1629;padding:15px;border-radius:8px;margin-bottom:15px;text-align:left;line-height:1.6;border:1px solid #1e293b;color:#94a3b8}.info-text code{background:rgba(53,61,240,.1);color:#5b63f5;padding:2px 6px;border-radius:4px;font-weight:700}.start-button,.stop-button{background:#353DF0;color:#fff;border:none;padding:12px 25px;border-radius:10px;cursor:pointer;margin:0 10px;font-weight:700;display:inline-flex;align-items:center;gap:8px;font-size:14px;transition:all .3s ease;box-shadow:0 2px 10px #353df026}.start-button:hover{background:#5b63f5;box-shadow:0 4px 15px #353df040}.stop-button{background:#ef4444;color:#fff;box-shadow:0 2px 10px #ef444426}.stop-button:hover{background:#dc2626;box-shadow:0 4px 15px #ef444440}.stop-button:disabled,.start-button:disabled{opacity:.4;cursor:not-allowed}.detection-status{background:#111827;padding:15px;border-radius:12px;margin-bottom:20px;text-align:center;border:1px solid #1e293b;box-shadow:0 4px 20px #0000004d}.status-active{color:#22c55e;display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap}.status-inactive{color:#ef4444;display:flex;align-items:center;justify-content:center;gap:10px}.last-update{font-size:.85em;color:#64748b;margin-left:10px}.detections-container{background:#111827;padding:20px;border-radius:12px;border:1px solid #1e293b;box-shadow:0 4px 20px #0000004d}.detections-container h3{color:#353df0;margin-bottom:15px;margin-top:0}.detections-list{display:grid;gap:10px}.detection-item{background:#0f1629;padding:15px;border-radius:10px;border-left:4px solid;transition:all .2s ease;border:1px solid #1e293b}.detection-item:hover{transform:translate(5px);border-color:#353df033}.detection-persona{border-left-color:#22c55e}.detection-crack{border-left-color:#ef4444}.detection-humedad{border-left-color:#0ea5e9}.detection-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}.detection-label{font-weight:700;font-size:1rem;color:#cbd5e1}.detection-confidence{background:rgba(53,61,240,.1);color:#5b63f5;padding:4px 10px;border-radius:8px;font-size:.85em;font-weight:700}.detection-details{color:#64748b;font-size:.85em}.no-detections{text-align:center;color:#64748b;font-style:italic;padding:20px;background:#0f1629;border-radius:8px;border:1px solid #1e293b}.icon{margin-right:5px}@media (max-width: 768px){.drone-viewer-container{padding:10px}.drone-viewer-header{flex-direction:column;gap:10px;text-align:center}.back-button{margin-right:0}.start-button,.stop-button{margin:5px;padding:10px 20px}.status-active,.status-inactive{flex-direction:column;gap:5px}.detection-header{flex-direction:column;align-items:flex-start;gap:5px}}.material-management-container{min-height:100vh;background:#0a0e1a;padding:20px;font-family:Arial,sans-serif;background-image:linear-gradient(rgba(53,61,240,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(53,61,240,.02) 1px,transparent 1px);background-size:40px 40px}.material-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px;background:#111827;padding:25px 30px;border-radius:16px;box-shadow:0 4px 20px #0000004d;border:1px solid #1e293b}.material-title{font-size:2rem;font-weight:700;color:#353df0;margin:0}.add-material-button{background:#353DF0;color:#fff;border:none;padding:14px 24px;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:10px;transition:all .3s ease;box-shadow:0 2px 10px #353df033;text-transform:uppercase;letter-spacing:1px}.add-material-button:hover{background:#5b63f5;box-shadow:0 4px 20px #353df04d}.button-icon{font-size:1.2rem}.materials-container{background:#111827;border-radius:16px;padding:30px;box-shadow:0 4px 20px #0000004d;border:1px solid #1e293b;margin-bottom:30px}.header-actions{display:flex;align-items:center;gap:15px}.view-toggle{display:flex;gap:5px;background:#0f1629;padding:5px;border-radius:10px;border:1px solid #1e293b}.view-button{background:transparent;border:none;color:#64748b;padding:8px 12px;border-radius:8px;cursor:pointer;transition:all .3s ease;font-size:1.2rem}.view-button.active{background:rgba(53,61,240,.12);color:#353df0}.view-button:hover{color:#cbd5e1}.filters-section{display:flex;justify-content:space-between;align-items:center;background:#111827;padding:20px 30px;border-radius:12px;margin-bottom:30px;border:1px solid #1e293b}.filter-group{display:flex;align-items:center;gap:15px;position:relative}.filter-icon{font-size:1.3rem;color:#353df0}.filter-group label{color:#cbd5e1;font-weight:700;font-size:1rem}.filter-select{padding:10px 40px 10px 15px;border:1px solid #1e293b;border-radius:10px;background:#0f1629;color:#cbd5e1;font-size:1rem;cursor:pointer;transition:all .3s ease;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23353DF0' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 15px center;background-size:12px}.filter-select:focus{outline:none;border-color:#353df0;box-shadow:0 0 0 3px #353df01a}.filter-select option{background:#111827;color:#cbd5e1;padding:10px}.filter-select:hover{border-color:#353df04d}.materials-count{color:#353df0;font-weight:700;font-size:1rem}.budget-container{margin:40px 0 30px;display:flex;justify-content:center}.budget-section{background:rgba(34,197,94,.06);padding:30px 50px;border-radius:16px;border:1px solid rgba(34,197,94,.15);text-align:center;min-width:300px}.budget-header{margin-bottom:15px}.budget-title{color:#94a3b8;font-size:1.1rem;font-weight:600;margin:0;text-transform:uppercase;letter-spacing:2px}.budget-amount{color:#22c55e;font-size:3rem;font-weight:700;margin:20px 0;line-height:1}.budget-details{color:#64748b;font-size:.95rem;margin-top:10px}.materials-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:25px;margin-top:20px}.material-card{background:#0f1629;border-radius:12px;overflow:hidden;box-shadow:0 2px 10px #0003;transition:all .3s ease;display:flex;flex-direction:column;position:relative;border:1px solid #1e293b}.material-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px #0000004d;border-color:#353df033}.card-header{padding:15px 20px;background:rgba(53,61,240,.04);border-left:4px solid;display:flex;flex-direction:column;gap:10px}.card-header-top{display:flex;justify-content:space-between;align-items:center}.favorite-button{background:transparent;border:none;color:#374151;font-size:1.3rem;cursor:pointer;transition:all .3s ease;padding:5px;display:flex;align-items:center}.favorite-button:hover{transform:scale(1.2);color:#fbbf24}.favorite-button.active{color:#fbbf24}.favorite-button-table{background:transparent;border:none;color:#374151;font-size:1.1rem;cursor:pointer;transition:all .3s ease;padding:5px 8px}.favorite-button-table:hover{color:#fbbf24;transform:scale(1.1)}.favorite-button-table.active{color:#fbbf24}.favorite-icon-table{color:#fbbf24;margin-left:5px}.card-usage{font-size:.8rem;color:#64748b;font-weight:600}.card-image{width:100%;height:200px;overflow:hidden;background:#111827;display:flex;align-items:center;justify-content:center;min-height:200px}.card-image img{width:100%;height:100%;object-fit:cover;display:block}.card-image-placeholder{width:100%;height:100%;display:none;align-items:center;justify-content:center;background:#111827;min-height:200px;position:absolute;top:0;left:0}.table-material-name{display:flex;align-items:center;gap:10px}.table-material-image{width:40px;height:40px;object-fit:cover;border-radius:5px}.image-preview-form{margin-top:10px;width:100%;max-height:200px;overflow:hidden;border-radius:10px;background:#0f1629;display:flex;align-items:center;justify-content:center}.image-preview-form img{max-width:100%;max-height:200px;object-fit:contain}.card-category,.card-pathology{display:flex;align-items:center;gap:5px;font-size:.8rem;font-weight:700;color:#94a3b8;padding:4px 10px;background:rgba(255,255,255,.04);border-radius:6px}.card-body{padding:20px;flex-grow:1}.card-title{font-size:1.2rem;font-weight:700;color:#cbd5e1;margin:0 0 10px}.card-supplier{color:#64748b;font-size:.9rem;margin:0 0 15px}.card-price{display:flex;align-items:baseline;gap:5px}.price-amount{font-size:1.5rem;font-weight:700;color:#353df0}.price-unit{font-size:.9rem;color:#64748b}.card-actions{padding:15px 20px;background:rgba(255,255,255,.02);display:flex;gap:10px;position:relative;z-index:10;border-top:1px solid #1e293b}.card-actions .edit-button,.card-actions .delete-button{flex:1;padding:10px;font-size:.85rem;position:relative;z-index:11;cursor:pointer}.category-badge{display:inline-block;padding:4px 10px;border-radius:8px;color:#fff;font-size:.8rem;font-weight:700}.form-hint{display:block;margin-top:5px;font-size:.8rem;color:#64748b;font-style:italic}.empty-state{text-align:center;padding:60px 20px;color:#64748b}.empty-state-icon{font-size:4rem;margin-bottom:20px;opacity:.5}.empty-state-title{font-size:1.5rem;color:#94a3b8;margin-bottom:15px}.empty-state-description{font-size:1rem;line-height:1.6;max-width:400px;margin:0 auto}.table-wrapper{overflow-x:auto;border-radius:12px;border:1px solid #1e293b}.materials-table{width:100%;border-collapse:collapse;background:#111827;border-radius:12px;overflow:hidden}.materials-table thead{background:#0f1629}.materials-table th{padding:18px 15px;text-align:left;font-weight:700;color:#353df0;font-size:.9rem;text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid #1e293b}.materials-table td{padding:16px 15px;border-bottom:1px solid #1e293b;color:#cbd5e1;font-size:.95rem}.materials-table tbody tr{transition:all .3s ease}.materials-table tbody tr:hover{background:rgba(53,61,240,.04)}.materials-table tbody tr:last-child td{border-bottom:none}.action-buttons{display:flex;gap:10px;flex-wrap:wrap}.edit-button,.delete-button{padding:8px 15px;border:none;border-radius:10px;font-size:.85rem;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px;position:relative;z-index:10;pointer-events:auto}.edit-button{background:rgba(34,197,94,.12);color:#22c55e;border:1px solid rgba(34,197,94,.2)}.edit-button:hover{background:rgba(34,197,94,.2)}.delete-button{background:rgba(239,68,68,.1);color:#ef4444;border:1px solid rgba(239,68,68,.2)}.delete-button:hover{background:rgba(239,68,68,.2)}.action-icon{font-size:.9rem}.dashboard-footer{text-align:center;margin-top:30px}.back-button{background:#1e293b;color:#94a3b8;border:1px solid #374151;padding:14px 28px;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px}.back-button:hover{background:#374151;color:#cbd5e1}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-content{background:#111827;padding:0;border-radius:16px;box-shadow:0 20px 60px #00000080;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;border:1px solid #1e293b}.modal-header{background:#0f1629;padding:25px 30px;border-radius:16px 16px 0 0;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #1e293b}.modal-title{font-size:1.5rem;font-weight:700;color:#353df0;margin:0}.close-button{background:rgba(255,255,255,.06);color:#94a3b8;border:none;width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.3rem;transition:all .3s ease}.close-button:hover{background:rgba(255,255,255,.1);color:#cbd5e1}form{padding:30px}.form-group{margin-bottom:25px}.form-label{display:block;font-weight:700;color:#cbd5e1;margin-bottom:8px;font-size:1rem}.form-input{width:100%;padding:14px 18px;border:1px solid #1e293b;border-radius:10px;font-size:1rem;background:#0f1629;color:#cbd5e1;transition:all .3s ease;box-sizing:border-box}.form-input::placeholder{color:#475569}.form-input:focus{outline:none;border-color:#353df0;box-shadow:0 0 0 3px #353df01a}.form-input:hover{border-color:#353df04d}.form-group select.form-input{padding-right:50px;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23353DF0' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 20px center;background-size:12px;background-color:#0f1629}.form-group select.form-input:focus{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23353DF0' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 20px center;background-size:12px;background-color:#0f1629}.form-group select.form-input option{background:#111827;color:#cbd5e1;padding:10px}.modal-actions{display:flex;gap:15px;justify-content:flex-end;margin-top:30px}.cancel-button,.save-button{padding:14px 24px;border:none;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px}.cancel-button{background:#1e293b;color:#94a3b8;border:1px solid #374151}.cancel-button:hover{background:#374151;color:#cbd5e1}.save-button{background:#353DF0;color:#fff;box-shadow:0 2px 10px #353df033}.save-button:hover{background:#5b63f5;box-shadow:0 4px 20px #353df04d}.loading-spinner{display:flex;justify-content:center;align-items:center;height:200px;font-size:2rem;color:#353df0}@media (max-width: 768px){.material-header{flex-direction:column;gap:20px;text-align:center}.material-title{font-size:1.5rem}.materials-table-container{padding:20px}.action-buttons{flex-direction:column}.modal-content{width:95%}.modal-actions{flex-direction:column}.form-input{padding:12px 15px}}@media (max-width: 480px){.material-management-container{padding:10px}.material-title{font-size:1.3rem}.add-material-button{padding:12px 20px;font-size:.95rem}.materials-table th,.materials-table td{padding:12px 8px;font-size:.85rem}}.pathology-toggle-button{position:fixed;top:120px;right:20px;z-index:1000;background:#353DF0;color:#fff;border:none;border-radius:50%;width:48px;height:48px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.3rem;box-shadow:0 2px 10px #353df033;transition:all .3s ease}.pathology-toggle-button:hover{background:#5b63f5;box-shadow:0 4px 20px #353df04d}.pathology-info-modal{position:fixed;top:120px;right:20px;z-index:999;max-width:320px;animation:slideInRight .3s ease-out}@media (max-width: 768px){.pathology-toggle-button{top:80px;right:10px;width:42px;height:42px;font-size:1.1rem}.pathology-info-modal{top:80px;right:10px;max-width:280px}}@keyframes pulse{0%,to{transform:scale(1);opacity:.6}50%{transform:scale(1.05);opacity:.8}}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.pathology-info-content{background:#111827;border:1px solid #1e293b;border-radius:12px;padding:0;box-shadow:0 8px 30px #0006}.pathology-info-header{background:#0f1629;padding:15px 20px;border-radius:12px 12px 0 0;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #1e293b}.pathology-info-header h4{margin:0;color:#353df0;font-size:1rem;font-weight:700;display:flex;align-items:center;gap:8px}.pathology-info-close{background:rgba(255,255,255,.06);color:#94a3b8;border:none;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:1.3rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .3s ease;font-weight:700}.pathology-info-close:hover{background:rgba(255,255,255,.1);color:#cbd5e1}.pathology-info-image{width:100%;max-height:150px;overflow:hidden;background:#0f1629;display:flex;align-items:center;justify-content:center;border-bottom:1px solid #1e293b}.pathology-info-image img{width:100%;height:100%;object-fit:cover;max-height:150px}.pathology-info-body{padding:20px}.pathology-info-item{display:flex;justify-content:space-between;align-items:center;padding:12px;margin-bottom:10px;background:rgba(53,61,240,.04);border-radius:8px;border-left:3px solid #353DF0}.pathology-label{color:#cbd5e1;font-weight:700;font-size:.95rem}.pathology-confidence{background:rgba(53,61,240,.12);color:#5b63f5;padding:4px 10px;border-radius:8px;font-size:.8rem;font-weight:700}.pathology-info-suggestion{margin-top:15px;padding:12px;background:rgba(34,197,94,.06);border-radius:8px;border-left:3px solid #22c55e;color:#94a3b8;font-size:.9rem;line-height:1.6}.pathology-info-suggestion strong{color:#22c55e}.image-analysis-container{min-height:100vh;background:#0a0e1a;padding:20px;font-family:Arial,sans-serif;background-image:linear-gradient(rgba(53,61,240,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(53,61,240,.02) 1px,transparent 1px);background-size:40px 40px}.analysis-header{display:flex;align-items:center;margin-bottom:40px;background:#111827;padding:25px 30px;border-radius:16px;box-shadow:0 4px 20px #0000004d;border:1px solid #1e293b}.back-button{background:#353DF0;color:#fff;border:none;padding:12px 20px;border-radius:10px;cursor:pointer;margin-right:20px;display:flex;align-items:center;gap:8px;font-weight:700;transition:all .3s ease;box-shadow:0 2px 10px #353df026}.back-button:hover{background:#5b63f5;box-shadow:0 4px 15px #353df040}h2{color:#353df0;display:flex;align-items:center;gap:12px;margin:0;font-size:2rem}.analysis-content{display:grid;grid-template-columns:1.2fr 1fr;gap:30px;align-items:start}.upload-section{display:flex;flex-direction:column;grid-column:1}.upload-card{background:#111827;padding:30px;border-radius:16px;box-shadow:0 4px 20px #0000004d;border:1px solid #1e293b;transition:all .3s ease;position:relative;overflow:hidden}.upload-card:hover{border-color:#353df033;box-shadow:0 8px 30px #0006}.upload-header{margin-bottom:25px;text-align:center}.upload-title{color:#353df0;font-size:1.5rem;margin:0 0 10px;display:flex;align-items:center;justify-content:center;gap:12px}.upload-description{color:#94a3b8;font-size:1rem;margin:0;line-height:1.6}.upload-area{text-align:center;margin-bottom:25px}.upload-label{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 50px;border:2px dashed rgba(53,61,240,.3);border-radius:16px;cursor:pointer;transition:all .3s ease;background:rgba(53,61,240,.04);position:relative;overflow:hidden;width:100%;min-height:250px;box-sizing:border-box}.upload-label:hover{background:rgba(53,61,240,.08);border-color:#353df080;box-shadow:0 0 20px #353df01a}.upload-icon{font-size:4rem;color:#353df0;margin-bottom:20px;position:relative;z-index:1}.upload-text-main{font-size:1.5rem;color:#353df0;font-weight:700;position:relative;z-index:1;margin-bottom:10px}.upload-text-hint{font-size:1rem;color:#64748b;position:relative;z-index:1;font-weight:400}.image-preview{margin:25px 0;text-align:center}.image-container{position:relative;display:inline-block;border-radius:16px;overflow:hidden;box-shadow:0 8px 30px #0006;transition:transform .3s ease}.image-container:hover{transform:scale(1.02)}.image-preview img{max-width:100%;max-height:400px;border-radius:16px;display:block}.detection-canvas{position:absolute!important;top:0!important;left:0!important;pointer-events:none!important;border-radius:16px;z-index:1!important}.image-info{margin-top:20px;background:#0f1629;padding:20px;border-radius:12px;border:1px solid #1e293b}.image-info p{margin:10px 0;color:#cbd5e1;font-weight:500;font-size:1rem}.action-buttons{display:flex;gap:20px;justify-content:center;margin-top:30px}.analyze-button,.reset-button{padding:16px 32px;border:none;border-radius:12px;cursor:pointer;font-weight:700;display:flex;align-items:center;gap:12px;font-size:1rem;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px}.analyze-button{background:#353DF0;color:#fff;box-shadow:0 2px 10px #353df033}.analyze-button:hover:not(:disabled){background:#5b63f5;box-shadow:0 4px 20px #353df04d}.analyze-button:disabled{background:#374151;color:#64748b;cursor:not-allowed}.reset-button{background:#1e293b;color:#94a3b8;border:1px solid #374151}.reset-button:hover:not(:disabled){background:#374151;color:#cbd5e1}.results-section{display:flex;flex-direction:column;grid-column:2;align-self:start}.results-card{background:#111827;padding:30px;border-radius:16px;box-shadow:0 4px 20px #0000004d;border:1px solid #1e293b;transition:all .3s ease;position:relative;overflow:hidden}.results-card:hover{border-color:#353df033}.results-card h3{color:#353df0;margin-bottom:30px;font-size:1.5rem}.results-summary{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:30px}.summary-item{background:#0f1629;padding:25px;border-radius:12px;display:flex;justify-content:space-between;align-items:center;border:1px solid #1e293b;transition:transform .3s ease}.summary-item:hover{transform:translateY(-2px)}.summary-label{color:#94a3b8;font-weight:500;font-size:1rem}.summary-value{color:#353df0;font-weight:700;font-size:1.3rem}.detections-list h4{color:#353df0;margin-bottom:25px;font-size:1.3rem}.detection-item{background:#0f1629;padding:25px;border-radius:12px;border-left:4px solid;margin-bottom:20px;transition:all .3s ease;border:1px solid #1e293b;position:relative;overflow:hidden}.detection-item:hover{transform:translate(8px);border-color:#353df04d}.detection-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.detection-label{font-weight:700;font-size:1.2rem;color:#cbd5e1}.detection-confidence{background:rgba(53,61,240,.12);color:#5b63f5;padding:8px 16px;border-radius:10px;font-size:.9rem;font-weight:700}.detection-details p{margin:10px 0;color:#94a3b8;font-size:1rem}.info-button{margin-top:10px;background:rgba(34,197,94,.12);color:#22c55e;border:1px solid rgba(34,197,94,.2);padding:10px 16px;border-radius:10px;cursor:pointer;font-weight:600;transition:all .3s ease}.info-button:hover{background:rgba(34,197,94,.2)}.extra-info{margin-top:12px;background:#0f1629;border:1px solid #1e293b;border-left:4px solid #22c55e;padding:12px 14px;border-radius:10px;color:#94a3b8;line-height:1.4}.no-detections{text-align:center;color:#64748b;font-style:italic;padding:40px;background:#0f1629;border-radius:12px;border:1px solid #1e293b;font-size:1rem}.error-message{background:rgba(239,68,68,.1);color:#fca5a5;padding:20px;border-radius:12px;margin:20px 0;text-align:center;font-weight:700;border:1px solid rgba(239,68,68,.2);font-size:1rem}.icon{margin-right:10px}@media (max-width: 768px){.analysis-content{grid-template-columns:1fr}.analysis-header{flex-direction:column;gap:20px;text-align:center}.back-button{margin-right:0}.results-summary{grid-template-columns:1fr}.action-buttons{flex-direction:column}h2{font-size:1.5rem}.upload-label{padding:40px 30px}.upload-icon{font-size:3rem}.upload-label span{font-size:1.2rem}}@media (max-width: 480px){.image-analysis-container{padding:10px}h2{font-size:1.3rem}.upload-label{padding:30px 20px}.upload-icon{font-size:2.5rem}.upload-label span{font-size:1rem}.action-buttons{gap:15px}.analyze-button,.reset-button{padding:14px 24px;font-size:.95rem}}.recommendations-section{margin-top:30px;grid-column:1 / -1}.recommendations-card{background:#111827;padding:30px;border-radius:16px;box-shadow:0 4px 20px #0000004d;border:1px solid #1e293b;border-left:4px solid #22c55e}.recommendations-title{color:#22c55e;margin-bottom:15px;font-size:1.5rem;display:flex;align-items:center;gap:10px}.recommendations-subtitle{color:#94a3b8;margin-bottom:25px;font-size:1rem;line-height:1.6}.recommendations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-top:20px}.recommendation-item{background:#0f1629;padding:0;border-radius:12px;box-shadow:0 2px 10px #0003;transition:all .3s ease;border-left:4px solid #22c55e;overflow:hidden;display:flex;flex-direction:column;border:1px solid #1e293b}.recommendation-item:hover{transform:translateY(-3px);box-shadow:0 6px 20px #0000004d;border-color:#22c55e4d}.recommendation-image{width:100%;height:150px;overflow:hidden;background:#111827;display:flex;align-items:center;justify-content:center}.recommendation-image img{width:100%;height:100%;object-fit:cover}.recommendation-header{display:flex;justify-content:space-between;align-items:flex-start;margin:15px 20px 10px;gap:10px}.recommendation-name{font-size:1.1rem;font-weight:700;color:#cbd5e1;margin:0;flex:1}.recommendation-category{padding:4px 10px;border-radius:8px;color:#fff;font-size:.75rem;font-weight:700;white-space:nowrap}.recommendation-supplier{color:#64748b;font-size:.9rem;margin:0 20px 10px}.recommendation-price{display:flex;align-items:baseline;gap:5px;margin:10px 20px}.recommendation-price .price{font-size:1.4rem;font-weight:700;color:#22c55e}.recommendation-price .unit{font-size:.9rem;color:#64748b}.recommendation-match{display:flex;align-items:center;gap:8px;margin:10px 20px;padding:10px;background:rgba(34,197,94,.08);border-radius:8px;color:#22c55e;font-size:.85rem;font-weight:600}.recommendation-footer{display:flex;gap:10px;margin:10px 20px 15px;flex-wrap:wrap}.recommendation-badge{display:flex;align-items:center;gap:5px;padding:4px 10px;background:rgba(53,61,240,.08);border-radius:6px;color:#5b63f5;font-size:.8rem;font-weight:600}.recommendation-usage{padding:4px 10px;background:rgba(255,255,255,.04);border-radius:6px;color:#64748b;font-size:.8rem;font-weight:600}.loading-recommendations{text-align:center;color:#353df0;padding:20px;font-size:1rem;margin-top:20px}.materials-action-section{margin-top:30px;padding-top:25px;border-top:1px solid #1e293b;text-align:center}.go-to-materials-button{background:#353DF0;color:#fff;border:none;padding:16px 32px;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:12px;transition:all .3s ease;box-shadow:0 2px 10px #353df033;text-transform:uppercase;letter-spacing:1px}.go-to-materials-button:hover{background:#5b63f5;box-shadow:0 4px 20px #353df04d}.materials-hint{color:#64748b;font-size:.9rem;margin-top:15px;font-style:italic}@media (max-width: 768px){.recommendations-grid{grid-template-columns:1fr}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-window{background:#111827;border:1px solid #1e293b;border-radius:16px;width:100%;max-width:650px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #1e293b;background:#0f1629}.modal-header h2{color:#353df0;font-size:18px;font-weight:700;margin:0;text-transform:uppercase;letter-spacing:1px}.close-button{background:transparent;border:none;color:#64748b;font-size:24px;cursor:pointer;padding:4px 8px;transition:color .2s}.close-button:hover{color:#cbd5e1}.modal-body{flex:1;overflow-y:auto;padding:20px 24px}.materials-list{display:flex;flex-direction:column;gap:16px}.material-card{background:#0f1629;border:1px solid #1e293b;border-radius:12px;padding:16px;cursor:pointer;transition:all .2s ease}.material-card:hover{background:rgba(53,61,240,.06);border-color:#353df04d;transform:translateY(-2px)}.material-card.selected{border-color:#353df0;background:rgba(53,61,240,.08);box-shadow:0 0 0 2px #353df026}.material-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.material-name{color:#cbd5e1;font-size:15px;font-weight:600;margin:0}.aliado-badge{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:#353df0;background:rgba(53,61,240,.08);padding:4px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.5px}.material-description{color:#64748b;font-size:13px;margin:0 0 12px;line-height:1.4}.material-details{display:flex;flex-direction:column;gap:6px}.detail-item{display:flex;justify-content:space-between;font-size:13px}.detail-item .label{color:#475569}.detail-item .value{color:#cbd5e1;font-weight:500}.detail-item .value.price{color:#22c55e;font-weight:700}.detail-item .value.tags{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.tag{background:rgba(53,61,240,.1);color:#5b63f5;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.no-pathologies,.no-materials{color:#64748b;text-align:center;font-size:14px;padding:30px 0}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #1e293b;background:#0f1629}.btn-cancel,.btn-select{padding:10px 20px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.btn-cancel{background:#1e293b;color:#94a3b8;border:1px solid #374151}.btn-cancel:hover{background:#374151;color:#cbd5e1}.btn-select{background:#353DF0;color:#fff;box-shadow:0 2px 10px #353df033}.btn-select:hover:not(:disabled){background:#5b63f5;box-shadow:0 4px 15px #353df04d}.btn-select:disabled{opacity:.4;cursor:not-allowed}.modal-body::-webkit-scrollbar{width:6px}.modal-body::-webkit-scrollbar-track{background:rgba(255,255,255,.02)}.modal-body::-webkit-scrollbar-thumb{background:#1e293b;border-radius:3px}.modal-body::-webkit-scrollbar-thumb:hover{background:#374151}.tutor-layout{display:grid;grid-template-columns:300px 1fr;gap:20px}.tutor-panel{background:#111827;border:1px solid #1e293b;border-radius:16px}.tutor-panel--flat{background:transparent;border:none}.tutor-panel__header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #1e293b}.tutor-title{display:flex;align-items:center;gap:10px;margin:0;color:#353df0}.tutor-sidebar{position:sticky;top:90px;height:calc(100vh - 120px);overflow:hidden}.tutor-sidebar__scroller{height:100%;overflow:auto}.tutor-topic{width:100%;text-align:left;padding:12px 16px;background:transparent;border:none;color:#94a3b8;cursor:pointer;transition:all .2s ease;border-radius:8px;margin:2px 4px}.tutor-topic:hover{background:rgba(53,61,240,.06);color:#cbd5e1}.tutor-topic--active{background:rgba(53,61,240,.1);color:#353df0;font-weight:600}.tutor-tabs{display:flex;flex-wrap:wrap;gap:8px;padding:12px;border-bottom:1px solid #1e293b}.tutor-tab{padding:8px 12px;border:1px solid #1e293b;border-radius:999px;background:transparent;color:#94a3b8;cursor:pointer;transition:all .2s ease}.tutor-tab:hover{border-color:#353df04d;color:#cbd5e1}.tutor-tab--active{background:rgba(53,61,240,.1);color:#353df0;border-color:#353df04d}.tutor-content{padding:16px}.tutor-card{background:#0f1629;border:1px solid #1e293b;border-radius:12px;padding:16px}.tutor-section-title{margin:0 0 8px;color:#cbd5e1}.tutor-grid{display:grid;gap:16px}.tutor-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.tutor-chip{background:rgba(53,61,240,.08);color:#5b63f5;padding:6px 10px;border-radius:10px;font-size:.85rem}.tutor-right{display:none}.tutor-chat-list{flex:1;overflow:auto;padding-right:6px}.tutor-button{border:none;border-radius:10px;padding:10px 14px;cursor:pointer;transition:all .2s ease}.tutor-button--primary{background:#353DF0;color:#fff;box-shadow:0 2px 10px #353df033}.tutor-button--primary:hover{background:#5b63f5;box-shadow:0 4px 15px #353df04d}.tutor-button--ghost{background:transparent;border:1px solid #1e293b;color:#94a3b8}.tutor-button--ghost:hover{border-color:#353df04d;color:#cbd5e1}.dashboard-content,.tutor-card,.tutor-panel{color:#cbd5e1}.summary-label{color:#94a3b8}.summary-value{color:#cbd5e1}.form-input{color:#cbd5e1;background:#0f1629;border:1px solid #1e293b}.upload-label span{color:#94a3b8}@media (max-width: 1100px){.tutor-layout{grid-template-columns:1fr}.tutor-right{max-height:none}}.tutor-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:80;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.tutor-modal{width:min(720px,94vw);background:#111827;border:1px solid #1e293b;border-radius:16px;overflow:hidden;box-shadow:0 20px 60px #00000080}.tutor-modal__header{padding:14px 16px;border-bottom:1px solid #1e293b;display:flex;align-items:center;justify-content:space-between;background:#0f1629}.tutor-modal__body{padding:16px}.tutor-modal__footer{padding:12px 16px;border-top:1px solid #1e293b;display:flex;gap:10px;justify-content:flex-end;background:#0f1629}.tutor-fab{position:fixed;right:22px;bottom:22px;z-index:70;background:#353DF0;color:#fff;border:none;border-radius:999px;padding:14px 16px;display:flex;align-items:center;gap:8px;box-shadow:0 4px 20px #353df04d;cursor:pointer;transition:all .3s ease}.tutor-fab:hover{background:#5b63f5;box-shadow:0 6px 25px #353df066}.inspection-history{padding:40px;max-width:1200px;margin:0 auto;min-height:100vh;background:#0a0e1a;background-image:linear-gradient(rgba(53,61,240,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(53,61,240,.02) 1px,transparent 1px);background-size:40px 40px}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.history-header h2{color:#353df0;font-size:28px;font-weight:700;margin:0;text-transform:uppercase;letter-spacing:2px}.back-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;background:#353DF0;color:#fff;border:none;border-radius:10px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease;box-shadow:0 2px 10px #353df033}.back-btn:hover{background:#5b63f5;box-shadow:0 4px 20px #353df04d}.table-container{background:#111827;border:1px solid #1e293b;border-radius:16px;overflow:hidden;box-shadow:0 8px 30px #0000004d}.inspections-table{width:100%;border-collapse:collapse}.inspections-table th{background:#0f1629;color:#353df0;font-weight:600;text-align:left;padding:16px 20px;font-size:12px;text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid #1e293b}.inspections-table td{padding:16px 20px;color:#cbd5e1;font-size:14px;border-bottom:1px solid #1e293b}.inspections-table tbody tr{transition:background-color .2s ease}.inspections-table tbody tr:hover{background-color:#353df00a}.inspections-table tbody tr:last-child td{border-bottom:none}.cell-fecha{color:#353df0;font-weight:600}.cell-punto{font-weight:500}.cell-inspector{color:#0ea5e9}.cell-observaciones{color:#94a3b8;font-size:13px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:9999px;font-size:12px;font-weight:600}.status svg{font-size:14px}.status-completada{background:rgba(34,197,94,.12);color:#22c55e;border:1px solid rgba(34,197,94,.2)}.status-pendiente{background:rgba(245,158,11,.12);color:#fbbf24;border:1px solid rgba(245,158,11,.2)}.status-en-proceso{background:rgba(53,61,240,.12);color:#5b63f5;border:1px solid rgba(53,61,240,.2)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#64748b}.loading-spinner{width:40px;height:40px;border:3px solid rgba(53,61,240,.15);border-top-color:#353df0;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.error-container{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.2);border-radius:12px;padding:24px;text-align:center;color:#fca5a5}.create-inspection-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:40px 20px;background:#0a0e1a;background-image:linear-gradient(rgba(53,61,240,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(53,61,240,.02) 1px,transparent 1px);background-size:40px 40px}.create-inspection-card{background:#111827;border:1px solid #1e293b;border-radius:16px;padding:40px;width:100%;max-width:450px;box-shadow:0 8px 30px #0000004d}.back-button{display:flex;align-items:center;gap:8px;background:transparent;border:none;color:#64748b;cursor:pointer;font-size:14px;margin-bottom:20px;padding:0;transition:color .2s}.back-button:hover{color:#353df0}.create-inspection-card h1{color:#353df0;font-size:24px;font-weight:700;margin:0 0 8px;text-transform:uppercase;letter-spacing:2px}.subtitle{color:#64748b;margin-bottom:24px}.error-message{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.2);border-radius:8px;padding:12px;color:#fca5a5;margin-bottom:16px}.success-message{background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.2);border-radius:8px;padding:12px;color:#86efac;margin-bottom:16px}.form-group label{display:flex;align-items:center;gap:8px;color:#cbd5e1;font-size:14px;font-weight:500;margin-bottom:8px}.form-group .icon{color:#353df0}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;background:#0f1629;border:1px solid #1e293b;border-radius:8px;color:#cbd5e1;font-size:15px;transition:border-color .2s;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#353df0;box-shadow:0 0 0 3px #353df01a}.form-group input::placeholder,.form-group textarea::placeholder{color:#475569}.form-group select{cursor:pointer}.submit-button{width:100%;padding:14px 24px;background:#353DF0;color:#fff;border:none;border-radius:10px;cursor:pointer;font-size:16px;font-weight:600;transition:all .3s ease;margin-top:8px;box-shadow:0 2px 10px #353df033}.submit-button:hover:not(:disabled){background:#5b63f5;box-shadow:0 4px 20px #353df04d}.submit-button:disabled{opacity:.5;cursor:not-allowed}.measurements-section{margin-top:24px;padding-top:24px;border-top:1px solid #1e293b}.measurements-section h3{color:#353df0;font-size:15px;font-weight:600;margin:0 0 16px;text-transform:uppercase;letter-spacing:1px}.measurements-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}@media (max-width: 480px){.measurements-grid{grid-template-columns:1fr}}.realtime-results{margin-top:20px;padding:16px;background:#0f1629;border:1px solid #1e293b;border-radius:8px;display:flex;flex-direction:column;gap:12px}.result-item{display:flex;justify-content:space-between;align-items:center;font-size:14px}.result-label{color:#64748b;font-weight:500}.result-value{font-weight:700;font-size:16px}.severity-badge.severity-critical .result-value{color:#ef4444}.severity-badge.severity-low .result-value{color:#22c55e}.severity-badge.severity-medium .result-value{color:#fbbf24}.dashboard-container{min-height:100vh;background:#0a0e1a;background-image:linear-gradient(rgba(53,61,240,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(53,61,240,.02) 1px,transparent 1px);background-size:40px 40px;padding:20px;font-family:Segoe UI,Roboto,sans-serif}.dashboard-content{max-width:1200px;margin:0 auto;padding:40px 20px}.dashboard-header{margin-bottom:50px;background:#111827;border-radius:16px;padding:30px;border:1px solid #1e293b;box-shadow:0 4px 20px #0003}.header-content{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;flex-wrap:wrap;gap:20px}.logo-section{display:flex;align-items:center;gap:20px}.logo-icon{width:70px;height:70px;background:linear-gradient(135deg,#353DF0,#5b63f5);border-radius:15px;display:flex;align-items:center;justify-content:center;font-size:2.5rem;color:#fff;box-shadow:0 0 15px #353df026}.logo-text{display:flex;flex-direction:column}.dashboard-title{font-size:3.5rem;font-weight:900;color:#353df0;margin:0;letter-spacing:-1px}.company-tagline{font-size:1rem;color:#64748b;margin:5px 0 0;font-weight:500}.header-actions{display:flex;align-items:center;gap:20px}#google_translate_element select,.language-selector,.goog-te-combo{background-color:#0f1629!important;color:#cbd5e1!important;border:1px solid #1e293b!important;border-radius:8px!important;padding:10px 15px!important;font-weight:600!important;font-size:.9rem!important;cursor:pointer!important;outline:none!important;transition:all .3s ease!important}#google_translate_element select:hover,.language-selector:hover,.goog-te-combo:hover{border-color:#353df0!important}#google_translate_element select option,.language-selector option,.goog-te-combo option{background-color:#111827!important;color:#cbd5e1!important}.goog-logo-link{display:none!important}.goog-te-gadget{color:transparent!important}.header-stats{display:flex;justify-content:space-around;gap:20px;padding-top:20px;border-top:1px solid #1e293b;flex-wrap:wrap}.stat-item{display:flex;align-items:center;gap:15px;padding:15px 20px;background:#0f1629;border-radius:12px;flex:1;min-width:150px;transition:all .3s ease;border:1px solid #1e293b}.stat-item:hover{border-color:#353df0;transform:translateY(-2px)}.stat-icon{font-size:2rem;color:#353df0}.stat-content{display:flex;flex-direction:column}.stat-value{font-size:1.8rem;font-weight:800;color:#e2e8f0;line-height:1}.stat-label{font-size:.8rem;color:#64748b;text-transform:uppercase;letter-spacing:1px;margin-top:5px}.services-section{text-align:center;margin-bottom:40px}.section-title{font-size:2.5rem;font-weight:800;color:#e2e8f0;margin-bottom:15px}.section-description{font-size:1.1rem;color:#64748b;max-width:700px;margin:0 auto;line-height:1.6}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:25px;margin-bottom:50px}.dashboard-card{background:#111827;border-radius:16px;padding:30px;cursor:pointer;transition:all .3s ease;border:1px solid #1e293b;box-shadow:0 4px 15px #0003;display:flex;align-items:center;gap:20px;position:relative;overflow:hidden}.dashboard-card:before{display:none}.dashboard-card:hover{transform:translateY(-5px);box-shadow:0 0 20px #353df01a;border-color:#353df0}.dashboard-card.disabled{opacity:.5;cursor:not-allowed}.dashboard-card.disabled:hover{transform:none;box-shadow:0 4px 15px #0003;border-color:#1e293b}.card-icon{font-size:2.5rem;color:#353df0;min-width:70px;display:flex;justify-content:center;align-items:center;background:rgba(53,61,240,.08);border-radius:12px;padding:18px;border:1px solid rgba(53,61,240,.12)}.card-content{flex:1}.card-content h3{font-size:1.4rem;font-weight:700;color:#e2e8f0;margin:0 0 8px}.card-content p{font-size:.95rem;color:#64748b;margin:0 0 10px;line-height:1.4}.card-badge{display:inline-block;padding:4px 12px;background:rgba(53,61,240,.1);border:1px solid rgba(53,61,240,.2);border-radius:20px;font-size:.7rem;color:#5b63f5;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.card-arrow{font-size:1.5rem;color:#353df0;transition:transform .3s ease;min-width:30px;display:flex;justify-content:center;align-items:center;opacity:.5}.dashboard-card:hover .card-arrow{transform:translate(5px);opacity:1}.coming-soon{font-size:.9rem;color:#475569;font-style:italic}.dashboard-footer{text-align:center;margin-top:50px}.logout-button{background:transparent;color:#ef4444;border:1px solid rgba(239,68,68,.3);padding:14px 36px;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px}.logout-button:hover{background:rgba(239,68,68,.08);border-color:#ef4444;transform:translateY(-2px)}.tutor-button{background:transparent;color:#353df0;border:1px solid rgba(53,61,240,.3);padding:14px 26px;border-radius:8px;cursor:pointer;font-weight:700;display:flex;align-items:center;gap:10px;font-size:1rem;transition:all .3s ease}.tutor-button:hover{background:rgba(53,61,240,.08);border-color:#353df0;transform:translateY(-2px)}.info-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:25px;margin:50px 0}.info-card{background:#111827;border-radius:12px;padding:25px;border:1px solid #1e293b;transition:all .3s ease;text-align:center}.info-card:hover{transform:translateY(-5px);border-color:#2d3a50}.info-icon{font-size:2.5rem;color:#353df0;margin-bottom:15px}.info-card h4{font-size:1.2rem;color:#e2e8f0;margin:0 0 10px;font-weight:700}.info-card p{font-size:.9rem;color:#64748b;line-height:1.6;margin:0}.company-footer{margin-top:60px;padding-top:30px;border-top:1px solid #1e293b;text-align:center}.footer-text{font-size:1rem;color:#64748b;margin:0 0 10px}.footer-text strong{color:#353df0;font-weight:700}.footer-copyright{font-size:.85rem;color:#475569;margin:0}@media (max-width: 768px){.dashboard-container{padding:10px}.dashboard-content{padding:20px 10px}.dashboard-header{padding:20px}.header-content{flex-direction:column;align-items:flex-start}.logo-section{width:100%}.dashboard-title{font-size:2.5rem}.company-tagline{font-size:.85rem}.header-stats{flex-direction:column}.stat-item{width:100%}.section-title{font-size:1.8rem}.section-description{font-size:.95rem}.dashboard-grid{grid-template-columns:1fr;gap:15px}.dashboard-card{padding:20px;flex-direction:column;text-align:center}.card-icon{font-size:2rem;min-width:60px;padding:15px}.card-content h3{font-size:1.2rem}.card-arrow{margin-top:10px}.info-section{grid-template-columns:1fr}.dashboard-footer{flex-direction:column}.tutor-button,.logout-button{width:100%;justify-content:center}}@media (max-width: 480px){.dashboard-title{font-size:2rem}.dashboard-card{padding:15px}.card-icon{font-size:1.8rem;min-width:50px;padding:12px}}.App{text-align:center;min-height:100vh;background:var(--bg-color);color:var(--text-color)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:inherit;cursor:pointer;border:none;outline:none}input,select,textarea{font-family:inherit;outline:none}a{text-decoration:none;color:inherit}.container{max-width:1200px;margin:0 auto;padding:0 20px}.btn{display:inline-block;padding:12px 24px;border-radius:8px;font-weight:600;text-align:center;transition:all .3s ease;cursor:pointer;border:none;text-decoration:none}.btn-primary{background:var(--primary-color);color:#fff;font-weight:700}.btn-primary:hover{background:var(--primary-light);transform:translateY(-2px);box-shadow:var(--glow-primary)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-color);border:1px solid var(--border-color)}.btn-secondary:hover{background:#243049;transform:translateY(-2px)}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover{background:#dc2626;transform:translateY(-2px)}.card{background:var(--card-bg);border-radius:12px;box-shadow:0 4px 20px #0000004d;padding:30px;margin-bottom:20px;border:1px solid var(--border-color)}.form-group{margin-bottom:20px}.form-label{display:block;margin-bottom:8px;color:var(--text-secondary);font-weight:600;font-size:.9rem}.form-input{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:8px;font-size:1rem;transition:all .3s ease;background:var(--bg-tertiary);color:var(--text-color)}.form-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-dim)}.form-input::placeholder{color:var(--text-muted)}.error-message{background:rgba(239,68,68,.1);color:#f87171;padding:12px 16px;border-radius:8px;margin-bottom:15px;font-size:.9rem;text-align:center;border:1px solid rgba(239,68,68,.2)}.success-message{background:rgba(34,197,94,.1);color:#4ade80;padding:12px 16px;border-radius:8px;margin-bottom:15px;font-size:.9rem;text-align:center;border:1px solid rgba(34,197,94,.2)}.loading-spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--border-color);border-top:2px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.container{padding:0 15px}.card{padding:20px;margin-bottom:15px}}
