*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;line-height:1.5;color:#212529;background-color:#f8f9fa}body.devise-layout{min-height:100vh;display:flex;flex-direction:column}body.devise-layout .devise-layout-content{flex:1;width:100%;max-width:none;padding:0;margin:0}.auth-container{width:100%;min-height:calc(100vh - 60px)}.auth-page{min-height:calc(100vh - 60px);display:flex;flex-direction:column;background-color:#f8f9fa}.auth-content{flex:1;display:flex;align-items:center;justify-content:center;padding:1rem 2rem;padding-bottom:1rem;width:100%}.auth-card{position:relative;background:white;border-radius:1rem;box-shadow:0 1rem 3rem rgba(0,0,0,0.175);overflow:hidden;width:100%;max-width:98%;min-height:550px}.auth-language-switcher{position:absolute;top:1rem;right:1rem;z-index:10}.auth-language-switcher-form{display:flex;align-items:center;gap:0.5rem}.auth-language-switcher-label{font-size:0.875rem;color:#6c757d;font-weight:500;white-space:nowrap}.auth-language-switcher-select{min-width:120px;padding:0.4rem 1.75rem 0.4rem 0.6rem;font-size:0.875rem;color:#212529;background-color:#fff;border:1px solid #ced4da;border-radius:0.375rem;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236c757d' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 0.5rem center;background-size:1rem}.auth-language-switcher-select:hover{border-color:#007bff}.auth-language-switcher-select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 0.2rem rgba(0,123,255,0.15)}.auth-signup-card{position:relative;padding-top:2.5rem}.row{display:flex;min-height:550px;align-items:stretch}.column{flex:1}.illustration-column{display:flex;align-items:center;justify-content:center;padding:3rem;background-color:#e0f2f7;min-height:100%}.form-column{padding:3rem;display:flex;flex-direction:column;justify-content:center;background-color:white;min-height:100%}.illustration-content{text-align:center}.logo-container{position:relative;display:inline-block;margin-bottom:1.5rem;width:auto;height:auto;max-width:300px}.logo-background{width:200px;height:200px;background-color:#4f46e51a;border-radius:50%;display:flex;align-items:center;justify-content:center}.logo-icon{position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);font-size:4rem;color:#007bff}.decoration-circle-1{position:absolute;top:10px;right:10px;width:24px;height:24px;background-color:#ffc107;border-radius:50%;z-index:10;box-shadow:0 2px 4px rgba(0,0,0,0.1)}.decoration-circle-2{position:absolute;bottom:10px;left:10px;width:32px;height:32px;background-color:#00bcd4;border-radius:50%;z-index:10;box-shadow:0 2px 4px rgba(0,0,0,0.1)}.welcome-title{font-weight:700;color:#007bff;margin-top:1rem;font-size:1.5rem}.welcome-subtitle{color:#6c757d;margin-top:0.5rem}.form-content{width:100%}.social-login{margin-bottom:1.5rem}.social-title{font-weight:700;margin-bottom:1rem;font-size:1.1rem}.social-buttons{display:flex;gap:0.5rem}.social-btn{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:opacity 0.2s, transform 0.2s;color:white;font-size:1rem}.social-btn:hover{opacity:0.9;transform:translateY(-2px)}.facebook-btn{background-color:#3b5998}.twitter-btn{background-color:#55acee}.linkedin-btn{background-color:#0077b5}.divider{display:flex;align-items:center;margin:1.5rem 0}.divider-line{flex:1;height:1px;background-color:#dee2e6}.divider-text{padding:0 1rem;color:#6c757d;font-size:0.875rem;font-weight:700}.login-form .form-group{margin-bottom:1rem}.form-control{display:block;width:100%;padding:0.75rem 1rem;font-size:1rem;font-weight:400;line-height:1.5;color:#212529;background-color:white;background-clip:padding-box;border:1px solid #ced4da;border-radius:0.375rem;transition:border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out}.form-control:focus{border-color:#007bff;box-shadow:0 0 0 0.25rem rgba(0,123,255,0.25);outline:none}.form-options{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.remember-me{display:flex;align-items:center;gap:0.5rem}.remember-me input[type="checkbox"]{width:1rem;height:1rem;cursor:pointer}.remember-me label{color:#6c757d;font-size:0.875rem;cursor:pointer}.forgot-password{color:#6c757d;font-size:0.875rem;text-decoration:none;transition:color 0.2s}.forgot-password:hover{color:#007bff;text-decoration:underline}.login-btn{background-color:#007bff;color:white;border:none;border-radius:0.375rem;font-size:0.875rem;font-weight:700;padding:0.75rem;text-transform:uppercase;width:100%;cursor:pointer;transition:background-color 0.2s, transform 0.2s;margin-bottom:1.5rem}.login-btn:hover{background-color:#0056b3;transform:translateY(-2px)}.login-btn:active{transform:translateY(0)}.register-prompt{text-align:start;font-size:0.875rem;color:#6c757d}.register-link{background:none;border:none;color:#dc3545;cursor:pointer;font-size:0.875rem;font-weight:700;padding:0;text-decoration:none}.register-link:hover{text-decoration:underline}.form-input{display:block;width:100%;padding:0.75rem 1rem;font-size:1rem;font-weight:400;line-height:1.5;color:#212529;background-color:white;border:1px solid #ced4da;border-radius:0.375rem;transition:border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;box-sizing:border-box}.form-input:focus{border-color:#007bff;box-shadow:0 0 0 0.25rem rgba(0,123,255,0.25);outline:none}.form-label{display:block;font-weight:600;font-size:0.875rem;color:#212529;margin-bottom:0.35rem}.form-actions{margin-top:1.5rem;padding-top:1rem;border-top:1px solid #dee2e6;display:flex;gap:0.75rem;align-items:center}.btn-cancel{padding:0.5rem 1rem;font-size:0.875rem;font-weight:600;color:#6c757d;background:white;border:1px solid #ced4da;border-radius:0.375rem;text-decoration:none;cursor:pointer;transition:background-color 0.2s, border-color 0.2s}.btn-cancel:hover{background-color:#e9ecef;border-color:#adb5bd}.btn-save{padding:0.5rem 1rem;font-size:0.875rem;font-weight:700;color:white;background-color:#007bff;border:1px solid #007bff;border-radius:0.375rem;cursor:pointer;transition:background-color 0.2s, transform 0.2s}.btn-save:hover{background-color:#0056b3;border-color:#0056b3}#error_explanation{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:16px;margin-bottom:20px;box-shadow:0 1px 3px rgba(0,0,0,0.1)}#error_explanation h2{color:#dc2626;font-size:16px;font-weight:600;margin:0 0 10px 0}#error_explanation ul{margin:0;padding-left:20px;color:#dc2626;font-size:14px}#error_explanation li{margin-bottom:5px}.error-message-container{display:flex;align-items:flex-start;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:16px;margin-bottom:20px;box-shadow:0 1px 3px rgba(0,0,0,0.1)}.error-icon{color:#dc2626;font-size:18px;margin-right:12px;margin-top:2px;flex-shrink:0}.error-content{flex:1}.error-text{color:#dc2626;font-size:14px;font-weight:500;margin:0;line-height:1.4}.error-list{margin:8px 0 0 0;padding-left:16px;color:#dc2626;font-size:14px}.error-list li{margin-bottom:4px;line-height:1.4}@media (max-width: 768px){.row{flex-direction:column;min-height:auto}.illustration-column{display:none}.auth-card{max-width:100%;min-height:auto}}@media (max-width: 480px){.auth-content{padding:1rem}.form-column{padding:2rem}.role-buttons{justify-content:center}.role-btn{font-size:0.75rem;padding:0.2rem 0.6rem}}@keyframes fadeIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.end-user-customer-page .content-card{background:white;border-radius:1rem;box-shadow:0 1rem 3rem rgba(0,0,0,0.175);padding:1.5rem 2rem;margin-bottom:1.5rem}.end-user-customer-page .content-card .row{min-height:0}.end-user-customer-page .page-header{margin-bottom:1.5rem}.end-user-customer-page .page-header .page-title{color:#007bff;font-weight:700;font-size:1.5rem;margin:0}.end-user-customer-page .page-header .breadcrumb-link{color:#6c757d;text-decoration:none;font-size:0.875rem}.end-user-customer-page .page-header .breadcrumb-link:hover{color:#007bff}.end-user-customer-page .customer-avatar{width:80px;height:80px;border-radius:50%;background-color:#007bff;color:white;display:flex;align-items:center;justify-content:center;font-weight:bold;font-size:32px}.end-user-customer-page .customer-name{font-weight:700;color:#007bff;font-size:1.25rem;margin:0 0 0.5rem 0}.end-user-customer-page .muted-text{color:#6c757d;font-size:0.875rem;margin:0.25rem 0}.end-user-customer-page .stat-icon{width:50px;height:50px;border-radius:0.5rem;display:flex;align-items:center;justify-content:center;color:white;font-size:1.25rem}.end-user-customer-page .stat-icon.primary{background-color:#007bff}.end-user-customer-page .stat-icon.success{background-color:#27ae60}.end-user-customer-page .stat-icon.warning{background-color:#f39c12}.end-user-customer-page .stat-icon.info{background-color:#00bcd4}.end-user-customer-page .stat-value{font-size:1.5rem;font-weight:700;color:#212529;margin:0}.end-user-customer-page .stat-label{color:#6c757d;font-size:0.875rem;margin:0}.end-user-customer-page .section-title{font-weight:700;font-size:1.1rem;color:#007bff;margin:0 0 1rem 0}.end-user-customer-page .badge-source{padding:0.5rem 1rem;border-radius:0.375rem;font-size:0.875rem;font-weight:600;text-transform:uppercase;background:#e0f2f7;color:#007bff}.end-user-customer-page .btn-primary-custom{background-color:#007bff;color:white;border:none;border-radius:0.375rem;padding:0.5rem 1rem;font-size:0.875rem;font-weight:600;text-decoration:none;display:inline-flex;align-items:center;gap:0.5rem;transition:background-color 0.2s}.end-user-customer-page .btn-primary-custom:hover{background-color:#0056b3;color:white}.end-user-customer-page .btn-outline-danger-custom{background:white;color:#dc3545;border:1px solid #dc3545;border-radius:0.375rem;padding:0.5rem 1rem;font-size:0.875rem;text-decoration:none;display:inline-flex;align-items:center;gap:0.5rem;transition:all 0.2s}.end-user-customer-page .btn-outline-danger-custom:hover{background:#dc3545;color:white}.end-user-customer-page .orders-table{width:100%;border-collapse:collapse;border-radius:0.5rem;overflow:hidden;box-shadow:0 2px 10px rgba(0,0,0,0.08)}.end-user-customer-page .orders-table thead{background:#e0f2f7;border-bottom:2px solid #b8e0e8}.end-user-customer-page .orders-table th{padding:0.75rem 1rem;text-align:left;font-weight:600;color:#007bff;font-size:0.875rem}.end-user-customer-page .orders-table td{padding:0.75rem 1rem;border-bottom:1px solid #e9ecef;font-size:0.875rem}.end-user-customer-page .orders-table tbody tr:hover{background:#f8f9fa}.end-user-customer-page .order-status-badge{padding:0.25rem 0.5rem;border-radius:0.25rem;font-size:0.75rem;font-weight:600;text-transform:uppercase;background:#d4edda;color:#27ae60}.end-user-customer-page .row-label{font-weight:600;color:#212529}.end-user-customer-page .row-value{color:#6c757d}.end-user-customer-page .info-row{display:flex;justify-content:space-between;align-items:center;padding:0.75rem 0;border-bottom:1px solid #e9ecef}.end-user-customer-page .info-row:last-child{border-bottom:none}.logo-image-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.logo-img{max-width:100%;max-height:100%;object-fit:contain}
