.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;padding:40px;width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:30px}.login-header h1{font-size:24px;color:#333;margin-bottom:8px;font-weight:600}.login-header p{color:#666;font-size:14px}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:500;color:#333}.form-group input{padding:12px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#667eea}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:6px;font-size:14px;border:1px solid #fcc}.login-button{padding:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:500;cursor:pointer;transition:opacity .2s;margin-top:10px}.login-button:hover:not(:disabled){opacity:.9}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:20px;text-align:center;font-size:12px;color:#999}.dashboard-container{min-height:100vh;background-color:#f5f5f5}.dashboard-header{background:#fff;box-shadow:0 2px 4px #0000001a;padding:20px 0;margin-bottom:30px}.header-content{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center}.header-content h1{font-size:24px;color:#333;font-weight:600}.header-right{display:flex;align-items:center;gap:20px}.header-nav{display:flex;align-items:center;gap:12px}.nav-link{color:#333;text-decoration:none;font-weight:600;font-size:14px;padding:8px 12px;border:1px solid #e6e6e6;border-radius:10px;background:#fafafa;transition:background-color .2s,border-color .2s}.nav-link:hover{background:#f2f2f2;border-color:#d9d9d9}.user-info{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.user-name{font-weight:500;color:#333;font-size:14px}.user-email{font-size:12px;color:#666}.user-roles{display:flex;gap:6px;margin-top:4px}.role-badge{background-color:#667eea;color:#fff;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:500}.logout-button{padding:8px 16px;background-color:#dc3545;color:#fff;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:background-color .2s}.logout-button:hover{background-color:#c82333}.dashboard-main{max-width:1200px;margin:0 auto;padding:0 20px 40px}.loading-state{text-align:center;padding:40px;color:#666;font-size:16px}.dashboard-content{display:flex;flex-direction:column;gap:30px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.stat-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;gap:20px;transition:transform .2s,box-shadow .2s}.stat-card-link{text-decoration:none;color:inherit;cursor:pointer}.stat-card-link:focus-visible{outline:3px solid rgba(79,172,254,.45);outline-offset:3px}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.stat-icon{font-size:48px;width:80px;height:80px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:linear-gradient(135deg,#667eea,#764ba2)}.stat-icon.clients{background:linear-gradient(135deg,#667eea,#764ba2)}.stat-icon.products{background:linear-gradient(135deg,#f093fb,#f5576c)}.stat-icon.infrastructure{background:linear-gradient(135deg,#4facfe,#00f2fe)}.stat-info h3{font-size:14px;color:#666;font-weight:500;margin-bottom:8px}.stat-value{font-size:32px;font-weight:600;color:#333;margin:0}.dashboard-section{background:#fff;border-radius:12px;padding:30px;box-shadow:0 2px 8px #0000001a}.dashboard-section h2{font-size:20px;color:#333;margin-bottom:16px;font-weight:600}.welcome-text{color:#666;line-height:1.6;margin-bottom:12px}.welcome-text:last-child{margin-bottom:0}.app-header{background:#fff;box-shadow:0 2px 4px #0000001a;padding:16px 0;margin-bottom:24px}.app-header-content{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center;gap:16px}.app-header-left{display:flex;align-items:center;gap:14px;min-width:0}.app-logo{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;border:1px solid #e6e6e6;background:#fafafa;color:#333;text-decoration:none;font-weight:900;letter-spacing:.5px;flex:0 0 auto}.app-header-titles{min-width:0}.app-header-title{font-size:22px;color:#333;font-weight:700;margin:0;line-height:1.2}.app-header-subtitle{margin:6px 0 0;color:#666;font-size:13px;white-space:pre-line}.app-header-right{display:flex;align-items:center;gap:14px}.app-rec-banner{display:inline-flex;flex-direction:column;align-items:flex-start;gap:4px;padding:6px 10px;border-radius:14px;background:transparent;border:none;color:#7f1d1d;max-width:220px}.app-rec-dot{width:10px;height:10px;border-radius:999px;background:#ef4444;box-shadow:0 0 #ef44448c;animation:recPulse 1.2s infinite;flex:0 0 auto}@keyframes recPulse{0%{box-shadow:0 0 #ef44448c}70%{box-shadow:0 0 0 10px #ef444400}to{box-shadow:0 0 #ef444400}}.app-rec-line{display:inline-flex;align-items:center;gap:8px;max-width:200px}.app-rec-client{color:#7f1d1d;font-weight:900;font-size:12px;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-rec-stop-link{background:transparent;border:none;padding:0;margin:0;color:#7f1d1d;font-weight:900;font-size:12px;line-height:1.1;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.app-rec-stop-link:hover{color:#991b1b}.app-nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.app-nav-link{color:#333;text-decoration:none;font-weight:650;font-size:14px;padding:8px 10px;border-radius:10px;border:1px solid transparent;background:transparent;transition:background-color .15s,border-color .15s}.app-nav-link:hover{background:#f5f5f5;border-color:#e6e6e6}.app-nav-link.active{background:#eef3ff;border-color:#d8e2ff}.app-user{display:flex;flex-direction:column;gap:2px;align-items:flex-end}.app-user-name{font-weight:700;font-size:13px;color:#333}.app-user-email{font-size:12px;color:#666}.app-logout{background:#ff4757;color:#fff;border:none;padding:8px 12px;border-radius:10px;cursor:pointer;font-weight:700;font-size:13px;transition:background-color .15s}.app-logout:hover{background:#ff3838}@media (max-width: 900px){.app-header-content{flex-direction:column;align-items:stretch}.app-header-right{justify-content:space-between}.app-user{align-items:flex-start}}.infra-container{min-height:100vh;background-color:#f5f5f5}.infra-header{background:#fff;box-shadow:0 2px 4px #0000001a;padding:20px 0;margin-bottom:30px}.infra-header-content{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center;gap:16px}.infra-header-left h1{font-size:24px;color:#333;font-weight:600;margin:0}.infra-subtitle{margin:6px 0 0;color:#666;font-size:14px}.infra-link-button{color:#333;text-decoration:none;font-weight:600;font-size:14px;padding:8px 12px;border:1px solid #e6e6e6;border-radius:10px;background:#fafafa;transition:background-color .2s,border-color .2s}.infra-link-button:hover{background:#f2f2f2;border-color:#d9d9d9}.infra-main{max-width:1200px;margin:0 auto;padding:0 20px 40px}.infra-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.infra-card{background:#fff;border-radius:12px;padding:18px;box-shadow:0 2px 8px #0000001a;text-decoration:none;color:inherit;transition:transform .2s,box-shadow .2s}.infra-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.infra-card-title{font-size:16px;font-weight:700;color:#333;margin-bottom:8px}.infra-card-path{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:12px;color:#666}.infra-section{background:#fff;border-radius:12px;padding:18px;box-shadow:0 2px 8px #0000001a}.infra-section h2{margin:0 0 12px;font-size:18px;color:#333}.infra-table{width:100%;border-collapse:collapse;background:#fff}.infra-table th,.infra-table td{text-align:left;padding:10px 12px;border-bottom:1px solid #eee;font-size:13px;color:#333;vertical-align:top}.infra-table-middle th,.infra-table-middle td{vertical-align:middle}.infra-table th{color:#666;font-weight:700;background:#fafafa}.infra-muted{color:#666;font-size:13px}.infra-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:14px}.infra-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid #e6e6e6;background:#fafafa;color:#333;font-weight:700;font-size:13px;padding:10px 12px;border-radius:10px;cursor:pointer;transition:background-color .2s,border-color .2s}.infra-button:hover{background:#f2f2f2;border-color:#d9d9d9}.infra-button:disabled{cursor:not-allowed;opacity:.6}.infra-button.primary{background:linear-gradient(135deg,#4facfe,#00f2fe);border-color:#4facfe59;color:#0b1220}.infra-button.primary:hover{border-color:#4facfe8c}.infra-button.excel{background:linear-gradient(135deg,#217346,#107c41);border-color:#107c4173;color:#fff}.infra-button.excel:hover{background:linear-gradient(135deg,#1e6a40,#0e6f3a);border-color:#107c41a6}.infra-file-meta{font-size:13px;color:#333}.infra-report{display:flex;flex-direction:column;gap:12px}.infra-report-summary{display:flex;flex-wrap:wrap;gap:10px;color:#333;font-size:13px}.infra-pill{display:inline-flex;gap:6px;align-items:center;padding:6px 10px;border-radius:999px;border:1px solid #eee;background:#fafafa}.infra-pill strong{font-weight:800}.infra-changes{margin:6px 0 0;padding-left:18px;color:#666;font-size:12px}.infra-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;padding:16px;z-index:1000}.infra-modal{width:min(560px,100%);background:#fff;border-radius:14px;box-shadow:0 10px 30px #00000040;border:1px solid #eee;padding:16px}.infra-modal-wide{width:min(920px,100%);max-height:min(80vh,900px);display:flex;flex-direction:column}.infra-modal-title{font-size:16px;font-weight:800;color:#333;margin-bottom:8px}.infra-modal-body{font-size:13px;color:#333;line-height:1.5}.infra-modal-body-scroll{overflow:auto;padding-right:6px;flex:1 1 auto}.infra-modal-actions{display:flex;justify-content:flex-end;margin-top:14px}.client-form{display:flex;flex-direction:column;gap:14px}.client-row{display:grid;gap:12px}.client-row-1{grid-template-columns:1fr}.client-row-2{grid-template-columns:1fr 240px;align-items:end}.client-row-top{grid-template-columns:1fr 280px 1fr;align-items:center}.client-row-3{grid-template-columns:repeat(3,1fr)}.client-row-2wide{grid-template-columns:repeat(2,1fr)}.client-field{display:flex;flex-direction:column;gap:6px}.client-field-inline{flex-direction:row;align-items:center;gap:10px}.client-label-inline{width:130px;flex:0 0 130px;margin:0}.client-control{flex:1 1 auto}.client-label{font-size:12px;font-weight:800;color:#666}.client-input,.client-textarea{width:100%;border:1px solid #e6e6e6;border-radius:10px;padding:10px 12px;font-size:13px;color:#333;background:#fff}.client-textarea{resize:vertical}.client-edit-top{display:flex;gap:12px;align-items:stretch;flex-direction:column}.client-edit-company{flex:1 1 auto;min-width:0}.client-checkbox{display:inline-flex;gap:8px;align-items:center;padding:10px 0 2px;font-size:13px;color:#333}.client-summary{display:flex;flex-direction:column;gap:12px}.client-summary-top,.client-summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.client-kv{border:1px solid #eee;border-radius:12px;padding:10px 12px;background:#fff}.client-kv-wide{grid-column:1 / -1}.client-k{font-size:12px;font-weight:800;color:#666;margin-bottom:6px}.client-v{font-size:13px;color:#333;word-break:break-word}.client-v-pre{white-space:pre-wrap}.client-center-cell{text-align:center;vertical-align:middle}.client-primary-flag{font-weight:800;color:#333}.client-row-clickable{cursor:pointer}.client-row-clickable:hover td{background:#fafafa}.client-row-former td{background:#f3f3f3}.client-section-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px}.client-section-actions{display:inline-flex;gap:10px;align-items:center}.client-toggle{display:inline-flex;gap:8px;align-items:center;font-size:13px;color:#333;-webkit-user-select:none;user-select:none}@media (max-width: 900px){.client-row-top,.client-summary-top,.client-summary-grid,.client-row-2,.client-row-3,.client-row-2wide{grid-template-columns:1fr}.client-edit-top{flex-direction:column;align-items:stretch}.client-edit-company{min-width:0}.client-label-inline{width:120px;flex-basis:120px}.client-section-header{flex-direction:column;align-items:stretch}.client-section-actions{justify-content:space-between}}.loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:18px;color:#666}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,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:#f5f5f5}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}
