:root{--primary-color: #0066cc;--primary-hover: #0052a3;--secondary-color: #6c757d;--success-color: #28a745;--danger-color: #dc3545;--text-color: #333;--bg-color: #f4f7f9;--card-bg: #ffffff;--border-color: #e0e0e0;--shadow: 0 2px 8px rgba(0,0,0,.08);--shadow-hover: 0 4px 12px rgba(0,0,0,.12)}body{font-family:Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;margin:0;padding:0;background-color:var(--bg-color);color:var(--text-color);line-height:1.6}.container{max-width:100%;margin:0 auto;padding:30px 40px}.modern-nav{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:0;box-shadow:0 4px 12px #00000026;position:sticky;top:0;z-index:999}.nav-container{max-width:1400px;margin:0 auto;padding:0 30px;display:flex;align-items:center;height:70px;gap:40px}.nav-brand{display:flex;align-items:center;gap:12px;flex-shrink:0}.brand-icon{font-size:32px;line-height:1;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.brand-text{display:flex;flex-direction:column;gap:2px}.brand-title{font-size:18px;font-weight:700;color:#fff;line-height:1;letter-spacing:.5px}.brand-subtitle{font-size:11px;color:#fffc;text-transform:uppercase;letter-spacing:1px;font-weight:500}.nav-links{list-style:none;padding:0;margin:0;display:flex;gap:8px;flex:1}.nav-links li{margin:0}.nav-links a{display:flex;align-items:center;gap:8px;padding:10px 16px;color:#ffffffe6;text-decoration:none;font-weight:500;font-size:14px;border-radius:8px;transition:all .2s;position:relative}.nav-links a:hover{background:rgba(255,255,255,.15);color:#fff;transform:translateY(-2px)}.nav-links a.active{background:rgba(255,255,255,.25);color:#fff;box-shadow:0 2px 8px #0003}.nav-links a.active:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:40%;height:3px;background:white;border-radius:2px 2px 0 0}.nav-icon{font-size:18px;line-height:1}.nav-user{display:flex;align-items:center;gap:12px;padding:8px 12px;background:rgba(255,255,255,.1);border-radius:50px;margin-left:auto;flex-shrink:0}.user-avatar{width:38px;height:38px;border-radius:50%;background:white;color:#667eea;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;box-shadow:0 2px 8px #0003}.user-details{display:flex;flex-direction:column;gap:2px}.user-name{color:#fff;font-size:14px;font-weight:600;line-height:1}.user-role{color:#fffc;font-size:11px;text-transform:uppercase;letter-spacing:.5px;font-weight:500;line-height:1}.logout-btn{background:rgba(255,255,255,.15);color:#fff;border:none;padding:8px 10px;border-radius:50%;cursor:pointer;font-size:18px;transition:all .2s;display:flex;align-items:center;justify-content:center;width:38px;height:38px}.logout-btn:hover{background:rgba(255,255,255,.25);transform:rotate(10deg)}h1,h2,h3,h4,h5,h6{margin-top:0;color:#2c3e50}h1{font-size:28px;font-weight:600;margin-bottom:20px}h2{font-size:22px;margin-bottom:15px}h3{font-size:18px;margin-bottom:10px}.text-muted{color:#666}.text-sm{font-size:13px}.m-0{margin:0}.mt-20{margin-top:20px}.mb-5{margin-bottom:5px}.mb-10{margin-bottom:10px}.mb-20{margin-bottom:20px}.mr-10{margin-right:10px}.text-right{text-align:right}.text-center{text-align:center}.d-flex{display:flex}.d-block{display:block}.justify-between{justify-content:space-between}.align-center{align-items:center}.align-end{align-items:flex-end}.gap-5{gap:5px}.gap-10{gap:10px}.gap-20{gap:20px}.card{background:var(--card-bg);padding:25px;border-radius:8px;box-shadow:var(--shadow);margin-bottom:25px;border:1px solid var(--border-color)}.grid-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:25px}.product-card{display:flex;flex-direction:column;height:100%}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:15px;border-bottom:1px solid var(--border-color);padding-bottom:10px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;background-color:var(--primary-color);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;text-decoration:none}.btn:hover{background-color:var(--primary-hover);box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.btn-secondary{background-color:var(--secondary-color)}.btn-secondary:hover{background-color:#5a6268}.btn-danger{background-color:var(--danger-color)}.btn-danger:hover{background-color:#c82333}.btn-success{background-color:var(--success-color)}.btn-success:hover{background-color:#218838}.btn-sm{padding:6px 12px;font-size:12px}.btn-icon{background:none;border:none;cursor:pointer;font-size:16px;padding:5px;border-radius:4px;transition:background .2s}.btn-icon:hover{background-color:#0000000d}.btn-icon.delete:hover{color:var(--danger-color);background-color:#dc35451a}.btn-text{background:none;border:none;color:var(--primary-color);cursor:pointer;padding:0 5px;font-size:13px}.btn-text:hover{text-decoration:underline}.btn-text.delete{color:var(--danger-color)}.form-group{margin-bottom:20px}label{display:block;margin-bottom:8px;font-weight:500;color:#444;font-size:14px}input,select,textarea{width:100%;padding:10px 12px;box-sizing:border-box;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .2s}input:focus,select:focus,textarea:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #0066cc1a}.input-sm{padding:6px 10px;font-size:13px}table{width:100%;border-collapse:collapse;margin-bottom:10px}th,td{padding:12px 15px;text-align:left;border-bottom:1px solid var(--border-color)}th{background-color:#f8f9fa;font-weight:600;color:#555;font-size:13px;text-transform:uppercase;letter-spacing:.5px}tr:hover td{background-color:#fafafa}.simple-table th,.simple-table td{padding:8px 10px;font-size:13px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000a6;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s}.modal-content{background:#fff;padding:0;border-radius:16px;width:90%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 48px #0000004d;animation:slideUp .3s;border:1px solid rgba(255,255,255,.2)}.modal-content.sm{max-width:500px}.modal-header{padding:28px 32px;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:16px 16px 0 0}.modal-header h2{margin:0;font-size:22px;font-weight:600;color:#fff;letter-spacing:.3px}.modal-body{padding:32px;overflow-y:auto;background:#fafbfc}.modal-footer{padding:24px 32px;border-top:2px solid #f0f0f0;background-color:#fff;border-radius:0 0 16px 16px;display:flex;gap:12px;justify-content:flex-end}.modal-footer .btn{min-width:120px;padding:12px 24px;font-size:15px;font-weight:600}.modal-footer .btn-secondary{background:#e9ecef;color:#495057}.modal-footer .btn-secondary:hover{background:#dee2e6}.close-btn{background:rgba(255,255,255,.2);border:none;font-size:28px;cursor:pointer;color:#fff;line-height:1;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}.close-btn:hover{background:rgba(255,255,255,.3);transform:rotate(90deg)}.divider{border:0;height:2px;background:linear-gradient(to right,transparent,#e0e0e0,transparent);margin:28px 0}.section-title{color:#2c3e50;margin-bottom:20px;font-size:15px;text-transform:uppercase;letter-spacing:1px;font-weight:700;padding-bottom:10px;border-bottom:3px solid #667eea;display:inline-block}.section{background:white;padding:24px;border-radius:12px;margin-bottom:20px;border:1px solid #e9ecef;box-shadow:0 2px 4px #0000000a}.modal-body>div[style*="background: #f0f8ff"],.modal-body>div[style*="background: #fff3cd"]{padding:20px!important;border-radius:12px!important;border:2px solid!important;box-shadow:0 2px 8px #00000014!important;font-size:15px!important}.modal-body>div[style*="background: #f0f8ff"]{background:linear-gradient(135deg,#e3f2fd 0%,#f0f8ff 100%)!important;border-color:#2196f3!important}.modal-body>div[style*="background: #fff3cd"]{background:linear-gradient(135deg,#fff8e1 0%,#fff3cd 100%)!important;border-color:#ff9800!important}.modal-body>div[style*="background: #e3f2fd"]{background:linear-gradient(135deg,#e8eaf6 0%,#e3f2fd 100%)!important;border:2px solid #5c6bc0!important;border-radius:12px!important;padding:16px 20px!important;box-shadow:0 2px 8px #00000014!important}.modal-body input[type=text],.modal-body input[type=date],.modal-body select,.modal-body textarea{border:2px solid #e0e0e0;border-radius:8px;padding:12px 16px;font-size:15px;transition:all .2s;background:white}.modal-body input[type=text]:focus,.modal-body input[type=date]:focus,.modal-body select:focus,.modal-body textarea:focus{border-color:#667eea;box-shadow:0 0 0 4px #667eea1a;transform:translateY(-1px)}.modal-body label{font-weight:600;color:#2c3e50;font-size:14px;margin-bottom:10px;letter-spacing:.3px}.modal-body h4{color:#2c3e50;font-size:16px;font-weight:600;margin-bottom:12px;letter-spacing:.3px}.modal-body input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#667eea}.row{display:flex;gap:30px}.col{flex:1}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.module-selector-modal{max-width:500px!important}.module-selector-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.module-selector-item{display:flex;align-items:center;gap:10px;padding:10px;background:#f8f9fa;border-radius:6px;border:2px solid transparent;transition:all .2s}.module-selector-item:hover{background:#e9ecef;border-color:var(--primary-color)}.module-selector-item input[type=checkbox]{width:18px;height:18px;cursor:pointer;margin:0}.module-selector-item input[type=checkbox]:disabled{cursor:not-allowed}.module-selector-item label{margin:0;font-size:14px;font-weight:500;flex:1}.client-table-wrapper{overflow-x:auto;border-radius:8px;border:1px solid #e9ecef}.client-table{width:100%;border-collapse:collapse}.client-table thead th{background:#6c63ff;font-weight:600;color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:.8px;padding:16px;border-bottom:none;position:sticky;top:0;z-index:10}.client-table thead th:first-child{border-radius:8px 0 0}.client-table thead th:last-child{border-radius:0 8px 0 0}.client-table tbody td{padding:16px;border-bottom:1px solid #e9ecef;vertical-align:middle;font-size:14px}.client-table tbody tr{transition:background-color .2s;background:white}.client-table tbody tr:nth-child(2n){background:#f8f9fa}.client-table tbody tr:hover{background:#f0f7ff}.client-table tbody tr:last-child td{border-bottom:none}.client-table tbody tr:last-child td:first-child{border-radius:0 0 0 8px}.client-table tbody tr:last-child td:last-child{border-radius:0 0 8px}.client-name{font-weight:600;color:#2c3e50;font-size:14px}.client-name-link{color:var(--primary-color);text-decoration:none;font-weight:600;font-size:14px;transition:color .2s}.client-name-link:hover{color:var(--primary-hover);text-decoration:underline}.client-address{color:#666;font-size:13px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.product-badge{display:inline-block;padding:5px 12px;background:#f1f3f5;color:#495057;border:1px solid #dee2e6;border-radius:4px;font-size:12px;font-weight:500}.no-expiry-badge{display:inline-block;padding:4px 10px;background:#20c997;color:#fff;border-radius:10px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.expired-badge{color:#dc3545;font-weight:600;padding:4px 10px;background:#ffe5e5;border-radius:10px;display:inline-block;font-size:12px}.group-count-badge{display:inline-block;padding:4px 10px;background:var(--primary-color);color:#fff;border-radius:12px;font-size:12px;font-weight:600}.action-buttons{display:flex;gap:8px;flex-wrap:wrap}.action-buttons .btn{white-space:nowrap}.product-group-card{overflow:hidden;transition:box-shadow .3s}.product-group-card:hover{box-shadow:0 4px 12px #0000001f}.product-group-header{-webkit-user-select:none;user-select:none}.collapse-icon{color:var(--primary-color);transition:transform .2s;display:inline-block;width:20px;text-align:center}.product-group-content{animation:expandDown .3s ease-out}@keyframes expandDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.product-number-badge{display:inline-block;padding:3px 8px;background:#e3f2fd;color:#1976d2;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.product-description{color:#666;font-size:14px;line-height:1.5;margin:15px 0;padding:10px;background:#f9f9f9;border-radius:4px;border-left:3px solid var(--primary-color)}.modules-section{margin-top:20px;padding-top:20px;border-top:1px solid #e0e0e0}.modules-list{display:flex;flex-direction:column;gap:8px}.module-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;transition:all .2s}.module-item:hover{background:#e9ecef;border-color:#dee2e6;transform:translate(2px)}.module-name{font-size:14px;font-weight:500;color:#2c3e50}.module-actions{display:flex;gap:5px}.module-count{color:#999;font-weight:400}.no-modules-placeholder{padding:20px;text-align:center;background:#f9f9f9;border:2px dashed #e0e0e0;border-radius:6px;color:#999}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:20px}.login-card{background:white;border-radius:12px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:420px;overflow:hidden}.login-header{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:40px 30px;text-align:center}.login-header h1{margin:0 0 10px;font-size:24px;color:#fff}.login-header p{margin:0;opacity:.9;font-size:14px}.login-form{padding:30px}.login-btn{width:100%;padding:12px;font-size:16px;margin-top:10px}.login-footer{padding:20px 30px;background:#f8f9fa;text-align:center;border-top:1px solid #e0e0e0}.error-message{background:#ffe5e5;color:#dc3545;padding:12px;border-radius:6px;margin-bottom:20px;border-left:4px solid #dc3545;font-size:14px}.user-type-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.user-type-badge.admin{background:#ffd700;color:#8b6914}.user-type-badge.support{background:#e3f2fd;color:#1976d2}.status-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase}.status-badge.active{background:#d4edda;color:#155724}.status-badge.inactive{background:#f8d7da;color:#721c24}.user-info{display:flex;align-items:center;gap:15px;margin-left:auto}.user-name{color:#ffffffe6;font-size:14px}.user-role{background:rgba(255,255,255,.2);padding:3px 8px;border-radius:10px;font-size:11px;text-transform:uppercase;font-weight:600}.logout-btn{background:rgba(255,255,255,.2);color:#fff;border:none;padding:6px 14px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:background .2s}.logout-btn:hover{background:rgba(255,255,255,.3)}.requests-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(500px,1fr));gap:20px}.request-card{transition:transform .2s,box-shadow .2s}.request-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.request-badge{display:inline-block;padding:5px 12px;border-radius:12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.request-badge.badge-warning{background:#fff3cd;color:#856404;border:1px solid #ffc107}.request-badge.badge-success{background:#d4edda;color:#155724;border:1px solid #28a745}.request-badge.badge-danger{background:#f8d7da;color:#721c24;border:1px solid #dc3545}.request-type-badge{display:inline-block;padding:5px 12px;background:#e3f2fd;color:#1976d2;border-radius:6px;font-size:12px;font-weight:600}.request-info{background:#f9f9f9;padding:12px;border-radius:6px;border-left:3px solid var(--primary-color)}.info-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid #e0e0e0}.info-row:last-child{border-bottom:none}.info-row strong{color:#555;font-size:13px}.info-row span{color:#333;font-size:13px}.request-details{margin-top:15px}.details-grid{display:grid;grid-template-columns:1fr;gap:12px;font-size:14px}.details-grid>div{padding:8px;background:#f8f9fa;border-radius:4px;border-left:2px solid #dee2e6}.code-item{padding:6px 10px;background:white;border:1px solid #dee2e6;border-radius:4px;margin-top:3px;font-size:13px;font-family:Courier New,monospace}.module-badge{display:inline-block;padding:4px 8px;background:#e3f2fd;color:#1976d2;border-radius:4px;font-size:11px;margin:2px}.filter-buttons{display:flex;gap:10px}.filter-buttons .btn{min-width:120px}@media (max-width: 768px){.module-selector-grid{grid-template-columns:1fr}.action-buttons{flex-direction:column}.action-buttons .btn{width:100%}.client-address{max-width:150px}.grid-container{grid-template-columns:1fr}.user-info{flex-direction:column;gap:5px;align-items:flex-end}.requests-grid{grid-template-columns:1fr}.filter-buttons{flex-direction:column}.filter-buttons .btn{width:100%}}
