: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%}@media (max-width: 480px){input,select,textarea,button{font-size:16px!important}}.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}.forgot-password-link:hover{color:#353df0!important}.reset-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.reset-card{background:#111827;border:1px solid #1e293b;border-radius:12px;padding:40px;width:100%;max-width:420px;box-shadow:0 4px 30px #0000004d;text-align:center}@media (max-width: 480px){.login-card{padding:30px 20px}.login-card h1{font-size:24px}.login-card p{font-size:14px;margin-bottom:24px}.form-group{margin-bottom:18px}.form-input{padding:12px 14px;font-size:16px}.login-button{padding:14px;font-size:16px}.reset-card{padding:30px 20px}.login-container{padding:10px}}@media (max-width: 360px){.login-card{padding:20px 15px}.login-card h1{font-size:20px}}.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)}.role-selector{display:flex;gap:12px}.role-option{flex:1;display:flex;align-items:center;gap:8px;padding:12px 16px;border:2px solid #1e293b;border-radius:8px;cursor:pointer;transition:all .3s ease;color:#94a3b8;font-size:14px;font-weight:600}.role-option input{display:none}.role-option.selected{border-color:#353df0;background:rgba(53,61,240,.1);color:#353df0}.role-option:hover{border-color:#353df0;background:rgba(53,61,240,.05)}.register-button-secondary{padding:14px 20px;background:transparent;color:#94a3b8;border:1px solid #1e293b;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}.register-button-secondary:hover{border-color:#353df0;color:#353df0}.normativas-grid{display:flex;flex-wrap:wrap;gap:8px}.normativa-chip{display:inline-flex;align-items:center;padding:6px 12px;border:1px solid #1e293b;border-radius:20px;font-size:12px;color:#94a3b8;cursor:pointer;transition:all .2s ease;background:#0f1629}.normativa-chip input{display:none}.normativa-chip.selected{border-color:#353df0;background:rgba(53,61,240,.15);color:#353df0}.normativa-chip:hover{border-color:#353df0}.steps-indicator{display:flex;align-items:center;justify-content:center;gap:0;margin-top:24px}.step-dot{width:28px;height:28px;border-radius:50%;background:#1e293b;color:#475569;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid transparent;transition:all .3s ease}.step-dot.active{background:rgba(53,61,240,.2);border-color:#353df0;color:#353df0}.step-line{width:40px;height:2px;background:#1e293b}.step-dot.active+.step-line{background:#353DF0}textarea:focus{outline:none;border-color:#353df0!important;box-shadow:0 0 0 3px #353df01f}select:focus{outline:none;border-color:#353df0!important;box-shadow:0 0 0 3px #353df01f}.confirmation-box{background:#0f1629;border:1px solid #1e293b;border-radius:12px;padding:24px;margin-bottom:8px}.confirmation-field{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #1e293b}.confirmation-field:last-of-type{border-bottom:none}.confirmation-label{color:#94a3b8;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.confirmation-value{color:#e2e8f0;font-size:14px;font-weight:500}@media (max-width: 480px){.register-card{padding:30px 20px}.register-card h1{font-size:22px}.register-card p{font-size:14px;margin-bottom:24px}.form-group{margin-bottom:18px}.form-group input{padding:12px 14px;font-size:16px}.register-button{padding:14px;font-size:16px}.register-button-secondary{width:100%;justify-content:center;padding:14px}.role-selector{flex-direction:column;gap:10px}.role-option{padding:14px 16px}.steps-indicator{flex-wrap:wrap}.step-line{width:20px}.confirmation-field{flex-direction:column;align-items:flex-start;gap:8px}.normativas-grid{gap:6px}.register-container{padding:10px}}@media (max-width: 360px){.register-card{padding:20px 15px}.register-card h1{font-size:18px}}.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: 1024px){.filters-section{flex-wrap:wrap;gap:15px}.filter-group{flex:1;min-width:200px}}@media (max-width: 768px){.material-header{flex-direction:column;gap:20px;text-align:center}.material-title{font-size:1.5rem}.header-actions{flex-wrap:wrap;justify-content:center}.materials-table-container{padding:20px}.filters-section{flex-direction:column;align-items:stretch;gap:12px;padding:15px}.filter-group{flex-direction:column;align-items:stretch;gap:8px}.filter-select{width:100%}.materials-cards-grid{grid-template-columns:1fr;gap:15px}.budget-section{padding:20px;min-width:auto}.budget-amount{font-size:2rem}.action-buttons{flex-direction:column}.modal-content{width:95%}.modal-actions{flex-direction:column}.form-input{padding:12px 15px}.materials-container{padding:20px}}@media (max-width: 480px){.material-management-container>div[style*="min-height: 80px"]{padding:10px 12px!important;min-height:50px!important;margin-bottom:12px!important;flex-wrap:wrap;gap:8px}.material-management-container>div[style*="min-height: 80px"] h2{font-size:1.1rem!important}.materials-container>div[style*="background: linear-gradient"],.materials-container>div[style*="border: 1px solid rgba(76,175,80,0.2)"]{padding:10px 14px!important}.materials-container>div[style*="background: linear-gradient"] div[style*="font-size: 2.5rem"],.materials-container>div[style*="border: 1px solid rgba(76,175,80,0.2)"] div[style*="font-size: 2.5rem"]{font-size:1.6rem!important}.material-card .card-image{height:100px!important;min-height:100px!important}.material-card div[style*="padding: 12px 14px 10px"]{padding:8px 10px 6px!important}.material-card .card-body{padding:6px 10px!important}.material-card .price-amount{font-size:1.1rem!important}.material-card .card-actions{flex-direction:row!important;flex-wrap:nowrap!important;padding:6px 8px!important;gap:4px}.material-card .card-actions button,.material-card .card-actions button[style*=flex]{flex:1!important;padding:5px 4px!important;font-size:.6rem!important;gap:2px!important;min-width:0!important}.material-card .card-actions button span{font-size:.6rem!important}.materials-table .action-buttons{flex-direction:row!important;flex-wrap:nowrap!important;gap:3px}.materials-table .action-buttons .edit-button,.materials-table .action-buttons .delete-button{padding:4px 6px!important;font-size:.6rem!important;gap:2px;white-space:nowrap}.materials-container div[style*="overflow-x: auto"] td[style*="display: flex"]{flex-wrap:nowrap!important;gap:3px!important}.materials-container div[style*="overflow-x: auto"] td[style*="display: flex"] button{padding:3px 6px!important;font-size:10px!important}}@media (max-width: 360px){.material-management-container{padding:5px}.material-title{font-size:1.1rem}.add-material-button{padding:10px 16px;font-size:.85rem}.materials-table th,.materials-table td{padding:6px 3px;font-size:.7rem}.material-management-container button[style*="padding: 12px 20px"]{padding:6px!important;font-size:11px!important}.material-card .card-image{height:80px!important;min-height:80px!important}.material-card .card-actions button{font-size:.55rem!important;padding:4px 3px!important}.material-card .price-amount{font-size:.95rem!important}}.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}}.paginator-wrapper{display:flex;justify-content:center;align-items:center;gap:6px;margin-top:20px;flex-wrap:wrap}@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: 600px){.image-analysis-container .analysis-header>button,.image-analysis-container .analysis-header>div[style*="position: absolute"]{position:static!important}.image-analysis-container .analysis-header{flex-direction:column!important;gap:10px!important;padding:12px 10px!important;min-height:auto!important}.image-analysis-container .analysis-header h2{font-size:1.2rem!important;text-align:center}.image-analysis-container .analysis-header>div[style*="position: absolute"]{display:flex!important;flex-wrap:wrap;justify-content:center;gap:6px;width:100%}.image-analysis-container .analysis-header>div[style*="position: absolute"] button{flex:1 1 auto;min-width:0;padding:8px 10px!important;font-size:11px!important;justify-content:center}}@media (max-width: 480px){.image-analysis-container{padding:8px}h2{font-size:1.1rem!important}.upload-card,.results-card{padding:16px!important}.upload-label{padding:24px 16px;min-height:150px}.upload-icon{font-size:2.2rem}.upload-label span{font-size:.95rem}.action-buttons{gap:10px;flex-direction:column;align-items:stretch}.analyze-button,.reset-button{padding:12px 20px;font-size:.9rem;justify-content:center}.detections-list h4{font-size:1rem}.detection-header{flex-direction:column;align-items:flex-start;gap:6px}.detection-details p{font-size:.85rem}.detection-item div[style*="display: flex"][style*="gap: 8px"][style*="margin-top: 8px"]{flex-direction:column!important;gap:6px!important}.detection-item div[style*="display: flex"][style*="gap: 8px"][style*="margin-top: 8px"] button{width:100%!important;justify-content:center}.recommendation-header{flex-direction:column;align-items:flex-start}.recommendation-item{padding:12px}.recommendation-header{margin:10px 12px 6px}.recommendation-supplier,.recommendation-price,.recommendation-match{margin-left:12px;margin-right:12px}.recommendation-footer{margin:8px 12px 12px}}.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}}@media (max-width: 360px){.image-analysis-container{padding:5px}.analysis-header{padding:15px}h2{font-size:1.1rem}.upload-label{padding:20px 15px;min-height:180px}.upload-icon{font-size:2rem}.upload-text-main{font-size:1.1rem}.upload-text-hint{font-size:.85rem}.results-card{padding:20px}.summary-item,.detection-item{padding:15px}.detection-header{flex-direction:column;gap:10px;align-items:flex-start}.analyze-button,.reset-button{padding:12px 20px;font-size:.9rem}.action-buttons{gap:10px}}.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:750px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;overflow:hidden;position:relative}.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;overflow-x:hidden;padding:20px 24px;min-height:0}.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!important;background:linear-gradient(135deg,rgba(53,61,240,.15) 0%,rgba(53,61,240,.05) 100%)!important;box-shadow:0 0 20px #353df04d,0 0 0 1px #353df080!important;transform:scale(1.01)}.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!important;flex-direction:row!important;justify-content:space-between!important;align-items:center!important;gap:16px;padding:16px 24px!important;border-top:2px solid #334155!important;background:linear-gradient(180deg,rgba(15,23,42,0) 0%,#0F172A 100%)!important;flex-wrap:wrap;min-height:70px;width:100%;box-sizing:border-box}.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}@media (max-width: 768px){.modal-window{max-width:95%;margin:10px;max-height:85vh}.modal-header{padding:15px 18px}.modal-header h2{font-size:16px}.modal-body{padding:15px 18px}.modal-footer{flex-direction:column!important;gap:12px!important;padding:16px 18px!important}.btn-cancel,.btn-select{width:100%;text-align:center;justify-content:center}.material-card{padding:12px}.material-header{flex-direction:column;gap:8px}.material-name{font-size:14px}.detail-item{flex-direction:column;gap:4px}.detail-item .value.tags{justify-content:flex-start}}@media (max-width: 480px){.modal-overlay{padding:10px}.modal-window{max-width:100%;margin:0;border-radius:12px;max-height:90vh}.modal-header,.modal-body{padding:12px 14px}.modal-footer{padding:12px 14px!important}}.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-x:auto;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}.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}@media (max-width: 768px){.inspection-history{padding:20px}.history-header{flex-direction:column;gap:15px;align-items:flex-start}.history-header h2{font-size:22px}.back-btn{width:100%;justify-content:center}.inspections-table th,.inspections-table td{padding:12px 14px;font-size:13px}.cell-observaciones{max-width:120px;font-size:12px}}@media (max-width: 480px){.inspection-history{padding:8px}.history-header{flex-direction:column;gap:10px;align-items:stretch}.history-header h2{font-size:16px;text-align:center}.history-header>div{justify-content:center!important}.history-header .back-btn{flex:1;justify-content:center;padding:10px 14px;font-size:12px}.table-container{border-radius:8px}.inspections-table th,.inspections-table td{padding:8px 6px;font-size:11px;white-space:nowrap}.inspections-table th{font-size:10px;padding:8px 6px}.cell-fecha{font-size:10px;min-width:80px}.cell-observaciones{max-width:100px;font-size:10px}.status{padding:3px 8px;font-size:10px;gap:3px}.inspection-history>div[style*="padding: 20px"]{padding:12px!important;gap:10px!important}.inspection-history input[type=date],.inspection-history select{font-size:11px!important;padding:6px 8px!important}.inspection-history input[type=date]{width:110px!important;flex:0 0 auto!important}.inspection-history>div[style*="padding: 20px"]>div{flex:1 1 100%!important}}@media (max-width: 360px){.inspection-history{padding:5px}.inspections-table th,.inspections-table td{padding:6px 4px;font-size:10px}.inspections-table th{font-size:9px}.cell-fecha{min-width:70px;font-size:9px}}.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:800px;box-shadow:0 8px 30px #0000004d;overflow:hidden}.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}.create-inspection-card{padding:20px}}.form-section{margin-bottom:20px;padding:15px;border-radius:10px;border:1px solid rgba(53,61,240,.2)}.form-section-title{font-size:14px;font-weight:600;margin-bottom:15px;display:flex;align-items:center;gap:8px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px}@media (max-width: 600px){.form-grid{grid-template-columns:1fr}}@media (max-width: 480px){.create-inspection-container{padding:20px 10px}.create-inspection-card h1{font-size:20px}.form-group input,.form-group select,.form-group textarea{padding:12px 14px;font-size:16px}.submit-button{padding:14px;font-size:16px}}@media (max-width: 360px){.create-inspection-container{padding:10px 5px}.create-inspection-card{padding:15px}.create-inspection-card h1{font-size:17px;letter-spacing:1px}.measurements-section h3{font-size:13px}}@media (max-width: 600px){.create-inspection-card div[style*="grid-template-columns: 1fr 1fr"],.create-inspection-card div[style*="grid-template-columns: 1fr 1fr 1fr"]{grid-template-columns:1fr!important}}.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}.model-upload-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.7);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.model-upload-modal{background:#111827;border:1px solid #1e293b;border-radius:20px;padding:35px;width:90%;max-width:560px;box-shadow:0 20px 60px #00000080;animation:slideUp .3s ease;position:relative}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.model-upload-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px}.model-upload-header h2{font-size:1.5rem;font-weight:700;color:#e2e8f0;margin:0;display:flex;align-items:center;gap:10px}.model-upload-close{background:#0f1629;border:1px solid #1e293b;color:#64748b;width:36px;height:36px;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:all .3s ease}.model-upload-close:hover{background:#1a2235;color:#e2e8f0;border-color:#353df0}.model-upload-dropzone{border:2px dashed #1e293b;border-radius:16px;padding:40px 20px;text-align:center;cursor:pointer;transition:all .3s ease;margin-bottom:24px;position:relative}.model-upload-dropzone:hover{border-color:#353df0;background:rgba(53,61,240,.03)}.model-upload-dropzone.dragging{border-color:#353df0;background:rgba(53,61,240,.08);border-style:solid}.model-upload-dropzone.has-file{border-color:#22c55e;background:rgba(34,197,94,.05);border-style:solid}.model-upload-dropzone-icon{font-size:3rem;color:#353df0;margin-bottom:16px;opacity:.7;transition:all .3s ease}.model-upload-dropzone:hover .model-upload-dropzone-icon{opacity:1;transform:translateY(-3px)}.model-upload-dropzone-text{font-size:1rem;color:#64748b;margin:0 0 8px}.model-upload-dropzone-hint{font-size:.8rem;color:#475569;margin:0}.model-upload-dropzone input[type=file]{display:none}.model-upload-file-info{display:flex;align-items:center;gap:12px;margin-top:16px;padding:12px 16px;background:#0f1629;border-radius:10px;border:1px solid #1e293b}.model-upload-file-icon{font-size:1.5rem;color:#22c55e}.model-upload-file-details{flex:1;text-align:left}.model-upload-file-name{font-size:.9rem;color:#e2e8f0;font-weight:600;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.model-upload-file-size{font-size:.75rem;color:#64748b;margin:2px 0 0}.model-upload-progress{width:100%;height:6px;background:#0f1629;border-radius:3px;margin-top:12px;overflow:hidden}.model-upload-progress-bar{height:100%;background:linear-gradient(90deg,#353DF0,#5b63f5);border-radius:3px;transition:width .3s ease;animation:progressPulse 1.5s ease infinite}@keyframes progressPulse{0%,to{opacity:1}50%{opacity:.8}}.model-upload-form-group{margin-bottom:18px}.model-upload-label{display:block;font-size:.85rem;font-weight:600;color:#94a3b8;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.model-upload-input{width:100%;background:#0f1629;border:1px solid #1e293b;border-radius:10px;padding:12px 16px;color:#e2e8f0;font-size:.95rem;outline:none;transition:all .3s ease;font-family:inherit}.model-upload-input::placeholder{color:#475569}.model-upload-input:focus{border-color:#353df0;box-shadow:0 0 0 3px #353df01a}.model-upload-textarea{resize:vertical;min-height:80px}.model-upload-select{-webkit-appearance:none;-moz-appearance:none;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='%2364748b' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}.model-upload-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:28px}.model-upload-cancel{background:#0f1629;border:1px solid #1e293b;color:#64748b;padding:12px 24px;border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease}.model-upload-cancel:hover{background:#1a2235;color:#e2e8f0}.model-upload-submit{background:linear-gradient(135deg,#353DF0,#5b63f5);border:none;color:#fff;padding:12px 30px;border-radius:10px;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #353df04d;display:flex;align-items:center;gap:8px}.model-upload-submit:hover{background:linear-gradient(135deg,#5b63f5,#7b83f7);box-shadow:0 6px 25px #353df066;transform:translateY(-1px)}.model-upload-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}.model-upload-error{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);border-radius:10px;padding:12px 16px;color:#ef4444;font-size:.85rem;margin-bottom:18px}@media (max-width: 560px){.model-upload-modal{width:95%;padding:24px}.model-upload-actions{flex-direction:column}.model-upload-cancel,.model-upload-submit{width:100%;justify-content:center}}.model-viewer-container{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0e1a;z-index:900;display:flex;flex-direction:column;animation:fadeIn .3s ease}@keyframes viewerFadeIn{0%{opacity:0}to{opacity:1}}.model-viewer-topbar{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;background:#111827;border-bottom:1px solid #1e293b;z-index:10;flex-shrink:0}.model-viewer-topbar-left{display:flex;align-items:center;gap:15px}.model-viewer-back{background:#0f1629;border:1px solid #1e293b;color:#64748b;padding:8px 16px;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .3s ease}.model-viewer-back:hover{background:#1a2235;color:#e2e8f0;border-color:#353df0}.model-viewer-title{font-size:1.1rem;font-weight:700;color:#e2e8f0;margin:0}.model-viewer-topbar-right{display:flex;align-items:center;gap:10px}.model-viewer-fullscreen-btn{background:#0f1629;border:1px solid #1e293b;color:#64748b;width:38px;height:38px;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:all .3s ease}.model-viewer-fullscreen-btn:hover{background:#1a2235;color:#353df0;border-color:#353df0}.model-viewer-body{display:flex;flex:1;overflow:hidden}.model-viewer-canvas-wrapper{flex:1;position:relative;overflow:hidden}.model-viewer-canvas-wrapper canvas{display:block}.model-viewer-toolbar{position:absolute;left:16px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:6px;background:rgba(17,24,39,.85);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:8px;border-radius:14px;border:1px solid #1e293b;box-shadow:0 8px 32px #0006;z-index:5}.model-viewer-tool-btn{width:42px;height:42px;border:none;background:transparent;color:#64748b;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:all .2s ease;position:relative}.model-viewer-tool-btn:hover{background:rgba(53,61,240,.1);color:#cbd5e1}.model-viewer-tool-btn.active{background:rgba(53,61,240,.2);color:#353df0}.model-viewer-tool-btn .tooltip{position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);background:#1e293b;color:#e2e8f0;padding:6px 12px;border-radius:8px;font-size:.75rem;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .2s ease;box-shadow:0 4px 12px #0000004d}.model-viewer-tool-btn:hover .tooltip{opacity:1}.model-viewer-tool-divider{height:1px;background:#1e293b;margin:4px 0}.model-viewer-info-panel{width:320px;background:#111827;border-left:1px solid #1e293b;overflow-y:auto;flex-shrink:0;display:flex;flex-direction:column}.model-viewer-info-section{padding:20px;border-bottom:1px solid #1e293b}.model-viewer-info-section h3{font-size:.8rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:1px;margin:0 0 14px}.model-viewer-info-name{font-size:1.2rem;font-weight:700;color:#e2e8f0;margin:0 0 10px}.model-viewer-info-desc{font-size:.9rem;color:#94a3b8;line-height:1.5;margin:0}.model-viewer-info-meta{display:flex;flex-direction:column;gap:10px}.model-viewer-info-row{display:flex;justify-content:space-between;align-items:center}.model-viewer-info-label{font-size:.8rem;color:#64748b}.model-viewer-info-value{font-size:.85rem;color:#e2e8f0;font-weight:600}.model-viewer-annotations-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.model-viewer-annotations-header h3{margin:0}.model-viewer-annotation-count{background:#0f1629;padding:2px 10px;border-radius:10px;font-size:.75rem;color:#64748b}.model-viewer-annotations-list{display:flex;flex-direction:column;gap:10px}.model-viewer-annotation-item{background:#0f1629;border:1px solid #1e293b;border-radius:10px;padding:12px;cursor:pointer;transition:all .2s ease}.model-viewer-annotation-item:hover{border-color:#353df0;background:rgba(53,61,240,.05)}.model-viewer-annotation-pin{display:inline-flex;align-items:center;gap:6px;font-size:.75rem;color:#353df0;font-weight:700;margin-bottom:6px}.model-viewer-annotation-comment{font-size:.85rem;color:#94a3b8;line-height:1.4;margin:0}.model-viewer-annotation-coords{font-size:.7rem;color:#475569;margin-top:6px}.model-viewer-measurement-bar{position:absolute;bottom:20px;left:50%;transform:translate(-50%);background:rgba(17,24,39,.9);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid #1e293b;border-radius:12px;padding:10px 20px;display:flex;align-items:center;gap:12px;z-index:5;box-shadow:0 8px 32px #0006}.model-viewer-measurement-label{color:#e2e8f0;font-size:.9rem;font-weight:700}.model-viewer-measurement-unit{color:#64748b;font-size:.8rem}.model-viewer-measurement-clear{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:4px 12px;border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s ease}.model-viewer-measurement-clear:hover{background:rgba(239,68,68,.2)}.model-viewer-hint{position:absolute;top:16px;left:50%;transform:translate(-50%);background:rgba(17,24,39,.85);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid #1e293b;border-radius:10px;padding:8px 18px;color:#64748b;font-size:.8rem;z-index:5;pointer-events:none;transition:opacity .3s ease}.model-viewer-annotation-input-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.4);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:20}.model-viewer-annotation-input-modal{background:#111827;border:1px solid #1e293b;border-radius:14px;padding:24px;width:380px;box-shadow:0 12px 40px #00000080}.model-viewer-annotation-input-modal h4{color:#e2e8f0;font-size:1rem;margin:0 0 16px}.model-viewer-annotation-input-modal textarea{width:100%;background:#0f1629;border:1px solid #1e293b;border-radius:10px;padding:12px;color:#e2e8f0;font-size:.9rem;resize:vertical;min-height:80px;outline:none;font-family:inherit;margin-bottom:16px}.model-viewer-annotation-input-modal textarea:focus{border-color:#353df0}.model-viewer-annotation-input-actions{display:flex;justify-content:flex-end;gap:10px}.model-viewer-annotation-input-cancel{background:#0f1629;border:1px solid #1e293b;color:#64748b;padding:8px 18px;border-radius:8px;font-size:.85rem;cursor:pointer;transition:all .2s ease}.model-viewer-annotation-input-cancel:hover{color:#e2e8f0}.model-viewer-annotation-input-save{background:#353DF0;border:none;color:#fff;padding:8px 18px;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease}.model-viewer-annotation-input-save:hover{background:#5b63f5}.model-viewer-measurement-line{pointer-events:none}.model-viewer-measurement-line-label{background:#ef4444;color:#fff;padding:2px 8px;border-radius:6px;font-size:.75rem;font-weight:700;white-space:nowrap;pointer-events:none}.model-viewer-annotation-pin-label{pointer-events:none}.model-viewer-annotation-pin-dot{width:24px;height:24px;background:#353DF0;border:2px solid #fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;color:#fff;box-shadow:0 2px 8px #353df080}@media (max-width: 768px){.model-viewer-info-panel{display:none}.model-viewer-toolbar{left:8px}}.model-gallery-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}.model-gallery-content{max-width:1200px;margin:0 auto;padding:40px 20px}.model-gallery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;background:#111827;padding:25px 30px;border-radius:16px;box-shadow:0 4px 20px #0000004d;border:1px solid #1e293b;flex-wrap:wrap;gap:20px}.model-gallery-header-left{display:flex;align-items:center;gap:15px}.model-gallery-header-left h1{font-size:2rem;font-weight:700;color:#353df0;margin:0}.model-gallery-header-left .model-count{font-size:.85rem;color:#64748b;background:#0f1629;padding:4px 12px;border-radius:20px;border:1px solid #1e293b}.model-gallery-search{display:flex;align-items:center;gap:10px}.model-search-input{background:#0f1629;border:1px solid #1e293b;border-radius:10px;padding:10px 16px;color:#e2e8f0;font-size:.95rem;width:280px;outline:none;transition:all .3s ease}.model-search-input::placeholder{color:#475569}.model-search-input:focus{border-color:#353df0;box-shadow:0 0 0 3px #353df01a}.model-view-toggle{display:flex;gap:4px;background:#0f1629;padding:4px;border-radius:10px;border:1px solid #1e293b}.model-view-btn{background:transparent;border:none;color:#64748b;padding:8px 12px;border-radius:8px;cursor:pointer;transition:all .3s ease;font-size:1.1rem;display:flex;align-items:center;justify-content:center}.model-view-btn.active{background:rgba(53,61,240,.12);color:#353df0}.model-view-btn:hover{color:#cbd5e1}.model-upload-fab{background:linear-gradient(135deg,#353DF0,#5b63f5);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 4px 20px #353df04d;text-transform:uppercase;letter-spacing:1px}.model-upload-fab:hover{background:linear-gradient(135deg,#5b63f5,#7b83f7);box-shadow:0 6px 30px #353df066;transform:translateY(-2px)}.model-categories{display:flex;gap:8px;margin-bottom:30px;overflow-x:auto;padding-bottom:5px;scrollbar-width:thin;scrollbar-color:#1e293b transparent}.model-category-tab{background:#111827;border:1px solid #1e293b;border-radius:10px;padding:10px 20px;color:#64748b;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap;display:flex;align-items:center;gap:8px}.model-category-tab:hover{border-color:#353df0;color:#cbd5e1}.model-category-tab.active{background:rgba(53,61,240,.12);border-color:#353df0;color:#353df0}.model-category-badge{background:#0f1629;padding:2px 8px;border-radius:10px;font-size:.75rem;color:#64748b}.model-category-tab.active .model-category-badge{background:rgba(53,61,240,.2);color:#5b63f5}.model-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:25px;margin-bottom:40px}.model-grid.list-view{grid-template-columns:1fr;gap:12px}.model-card{background:#111827;border-radius:16px;border:1px solid #1e293b;overflow:hidden;cursor:pointer;transition:all .3s ease;position:relative}.model-card:hover{transform:translateY(-5px);border-color:#353df0;box-shadow:0 8px 30px #353df026}.model-card-preview{height:200px;background:linear-gradient(135deg,#0f1629,#111827);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.model-card-preview:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 30% 50%,rgba(53,61,240,.08) 0%,transparent 60%),radial-gradient(circle at 70% 30%,rgba(91,99,245,.05) 0%,transparent 50%)}.model-card-3d-icon{position:relative;z-index:1}.model-card-3d-icon .cube{width:60px;height:60px;position:relative;transform-style:preserve-3d;animation:cubeRotate 8s linear infinite}.model-card:hover .cube{animation-duration:3s}@keyframes cubeRotate{0%{transform:rotateX(0) rotateY(0)}25%{transform:rotateX(90deg) rotateY(90deg)}50%{transform:rotateX(180deg) rotateY(180deg)}75%{transform:rotateX(270deg) rotateY(270deg)}to{transform:rotateX(360deg) rotateY(360deg)}}.model-card-3d-icon .cube .face{position:absolute;width:60px;height:60px;border:2px solid rgba(53,61,240,.4);background:rgba(53,61,240,.05);border-radius:4px}.model-card-3d-icon .cube .face:nth-child(1){transform:rotateY(0) translateZ(30px)}.model-card-3d-icon .cube .face:nth-child(2){transform:rotateY(90deg) translateZ(30px)}.model-card-3d-icon .cube .face:nth-child(3){transform:rotateY(180deg) translateZ(30px)}.model-card-3d-icon .cube .face:nth-child(4){transform:rotateY(270deg) translateZ(30px)}.model-card-3d-icon .cube .face:nth-child(5){transform:rotateX(90deg) translateZ(30px)}.model-card-3d-icon .cube .face:nth-child(6){transform:rotateX(-90deg) translateZ(30px)}.model-card-category-badge{position:absolute;top:12px;left:12px;background:rgba(15,22,41,.85);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:4px 10px;border-radius:8px;font-size:.7rem;color:#5b63f5;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border:1px solid rgba(53,61,240,.2);z-index:2}.model-card-format{position:absolute;top:12px;right:12px;background:rgba(15,22,41,.85);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:4px 10px;border-radius:8px;font-size:.7rem;color:#64748b;font-weight:700;text-transform:uppercase;border:1px solid #1e293b;z-index:2}.model-card-delete{position:absolute;bottom:12px;right:12px;background:rgba(15,22,41,.85);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:6px 8px;color:#ef4444;cursor:pointer;z-index:2;opacity:0;transform:scale(.8);transition:all .2s ease;display:flex;align-items:center;justify-content:center}.model-card:hover .model-card-delete{opacity:1;transform:scale(1)}.model-card-delete:hover{background:rgba(239,68,68,.2);border-color:#ef4444}.model-card-info{padding:20px}.model-card-name{font-size:1.1rem;font-weight:700;color:#e2e8f0;margin:0 0 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.model-card-meta{display:flex;align-items:center;justify-content:space-between;gap:10px}.model-card-supplier{font-size:.85rem;color:#64748b;display:flex;align-items:center;gap:6px}.model-card-date{font-size:.8rem;color:#475569}.model-card-comments{display:flex;align-items:center;gap:5px;font-size:.8rem;color:#64748b;background:#0f1629;padding:4px 10px;border-radius:8px}.model-grid.list-view .model-card{display:flex;flex-direction:row}.model-grid.list-view .model-card-preview{width:200px;height:auto;min-height:120px;flex-shrink:0}.model-grid.list-view .model-card-info{flex:1}.model-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center}.model-empty-icon{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,rgba(53,61,240,.1),rgba(91,99,245,.05));display:flex;align-items:center;justify-content:center;margin-bottom:24px;border:2px solid rgba(53,61,240,.15)}.model-empty-icon svg{font-size:3rem;color:#353df0;opacity:.7}.model-empty-title{font-size:1.5rem;font-weight:700;color:#e2e8f0;margin:0 0 10px}.model-empty-text{font-size:1rem;color:#64748b;margin:0 0 30px;max-width:400px;line-height:1.5}.model-empty-upload{background:linear-gradient(135deg,#353DF0,#5b63f5);color:#fff;border:none;padding:14px 30px;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 4px 20px #353df04d}.model-empty-upload:hover{background:linear-gradient(135deg,#5b63f5,#7b83f7);box-shadow:0 6px 30px #353df066;transform:translateY(-2px)}.model-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;gap:20px}.model-spinner{width:50px;height:50px;border:3px solid #1e293b;border-top-color:#353df0;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.model-loading-text{color:#64748b;font-size:.95rem}@media (max-width: 768px){.model-gallery-header{flex-direction:column;align-items:flex-start}.model-search-input{width:100%}.model-grid{grid-template-columns:1fr}.model-categories{gap:6px}.model-category-tab{padding:8px 14px;font-size:.85rem}}.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(2,1fr);gap:25px;margin:0 auto 50px;max-width:800px}.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}.logo-icon{width:55px;height:55px;font-size:2rem}.stat-item{padding:12px 15px;min-width:120px}.stat-value{font-size:1.4rem}.dashboard-header{padding:15px}.header-actions{width:100%;justify-content:center}.info-card{padding:20px}}@media (max-width: 360px){.dashboard-container{padding:5px}.dashboard-content{padding:15px 5px}.dashboard-title{font-size:1.5rem}.logo-icon{width:45px;height:45px;font-size:1.5rem}.section-title{font-size:1.4rem}.stat-item{min-width:100%}}.placeholder-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:60px 20px;background:#111827;border:1px solid #1e293b;border-radius:12px;text-align:center}.placeholder-card h3{color:#e2e8f0;margin:0;font-size:20px}.placeholder-card p{color:#94a3b8;margin:0;font-size:14px;max-width:400px}.sidebar-toggle--open{position:fixed;top:12px;left:12px;z-index:1100;background:#1e293b;border:1px solid #353DF0;color:#353df0;width:40px;height:40px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;transition:opacity .3s ease}.sidebar-toggle--open:hover{background:rgba(53,61,240,.15)}.sidebar{position:fixed;top:0;left:0;width:260px;height:100vh;background:#0f1629;border-right:1px solid #1e293b;display:flex;flex-direction:column;z-index:1200;transition:transform .3s ease;box-shadow:4px 0 20px #0006}.sidebar--collapsed{transform:translate(-100%)}.sidebar--open{transform:translate(0)}.sidebar-header{padding:16px 16px 12px;border-bottom:1px solid #1e293b}.sidebar-header-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.sidebar-logo{color:#353df0;font-size:22px;font-weight:900;letter-spacing:2px}.sidebar-close{background:transparent;border:none;color:#64748b;font-size:22px;cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center}.sidebar-close:hover{color:#e2e8f0;background:rgba(255,255,255,.05)}.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px 12px;background:rgba(53,61,240,.08);border-radius:8px}.sidebar-user-icon{font-size:22px;color:#353df0;flex-shrink:0}.sidebar-user-info{display:flex;flex-direction:column;overflow:hidden;min-width:0}.sidebar-user-name{color:#e2e8f0;font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{color:#94a3b8;font-size:11px;text-transform:uppercase;letter-spacing:.5px}.sidebar-nav{flex:1;padding:12px;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.sidebar-nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:transparent;border:none;border-radius:8px;color:#94a3b8;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;width:100%;text-align:left}.sidebar-nav-item:hover{background:rgba(53,61,240,.08);color:#e2e8f0}.sidebar-nav-item.active{background:rgba(53,61,240,.15);color:#353df0;font-weight:600}.sidebar-nav-icon{font-size:18px;min-width:20px}.sidebar-footer{padding:12px;border-top:1px solid #1e293b}.sidebar-logout{display:flex;align-items:center;gap:12px;padding:10px 12px;background:transparent;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#f87171;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;width:100%}.sidebar-logout:hover{background:rgba(239,68,68,.1);border-color:#ef4444}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:1100;cursor:pointer}.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}}.app-layout{display:flex;min-height:100vh;background:#0a0e1a}.app-main{flex:1;min-height:100vh;background:#0a0e1a;width:100%}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:#0a0e1a;color:#94a3b8;gap:20px}.loading-spinner-large{width:40px;height:40px;border:3px solid #1e293b;border-top:3px solid #353DF0;border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 768px){.app-main{margin-left:0;padding-top:60px}}@media (max-width: 480px){.card{padding:15px}.container{padding:0 10px}.btn{padding:12px 18px;font-size:.9rem}}
