/* InCondo - Tema Premium */
:root{
  --ic-primary:#3A5BFF;
  --ic-text:#0F172A;
  --ic-text-2:#334155;
  --ic-border:#E2E8F0;
  --ic-bg:#F8FAFC;
  --ic-white:#FFFFFF;
  --ic-success:#16A34A;
  --ic-warn:#F59E0B;
  --ic-error:#EF4444;
  --ic-radius:12px;
  --ic-shadow:0 4px 16px rgba(15,23,42,0.06);
  --ic-space:8px;
}

*{box-sizing:border-box}
body{margin:0;background:var(--ic-bg);color:var(--ic-text);font: 14px/1.4 Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";}

.ic-app{display:grid;grid-template-columns:280px 1fr;min-height:100dvh;}
.ic-app.sidebar-collapsed{grid-template-columns:72px 1fr;}

.ic-sidebar{background:var(--ic-white);border-right:1px solid var(--ic-border);padding:16px;display:flex;flex-direction:column;gap:16px;}
.ic-brand{display:flex;align-items:center;gap:12px;padding:8px 8px;}
.ic-logo{display:grid;place-items:center;width:36px;height:36px;border-radius:10px;background:var(--ic-primary);color:#fff;font-weight:700}
.ic-title{font-weight:700;letter-spacing:.2px;}
.ic-nav{display:flex;flex-direction:column;gap:6px;}
.ic-nav-item{padding:10px 12px;border-radius:10px;color:var(--ic-text-2);text-decoration:none}
.ic-nav-item:hover{background:#EEF2FF}
.ic-nav-item.is-active{background:#E0E7FF;color:#1E3A8A}

.ic-nav-group{margin:6px 0;}
.ic-nav-group summary{list-style:none;padding:10px 12px;border-radius:10px;color:var(--ic-text-2);cursor:pointer;font-weight:500;}
.ic-nav-group summary:hover{background:#EEF2FF}
.ic-nav-group summary::-webkit-details-marker{display:none;}
.ic-nav-group summary::after{content:'▼';float:right;font-size:12px;transition:transform 0.3s ease;}
.ic-nav-group[open] summary::after{transform:rotate(180deg);}
.ic-nav-subitems{padding-left:12px;margin-top:6px;}
.ic-nav-subitems .ic-nav-item{padding:8px 12px;font-size:13px;}

.ic-main{display:flex;flex-direction:column;min-width:0}
.ic-topbar{display:flex;align-items:center;justify-content:space-between;background:var(--ic-white);border-bottom:1px solid var(--ic-border);padding:10px 16px;position:sticky;top:0;z-index:10}
.ic-burger{border:0;background:transparent;font-size:20px;cursor:pointer}
.ic-breadcrumb{color:var(--ic-text-2);font-size:13px;}
.ic-actions{display:flex;align-items:center;gap:12px}
.ic-search{padding:10px 12px;border:1px solid var(--ic-border);border-radius:10px;min-width:260px}
.ic-user{width:32px;height:32px;display:grid;place-items:center;background:#E5E7EB;border-radius:8px;font-weight:600}

.ic-content{padding:16px;display:flex;flex-direction:column;gap:16px;flex:1;}
.ic-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.ic-card{background:var(--ic-white);border:1px solid var(--ic-border);border-radius:var(--ic-radius);box-shadow:var(--ic-shadow);padding:16px}
.ic-card h3{margin:0 0 6px 0;font-size:13px;color:var(--ic-text-2)}
.ic-metric{font-size:22px;font-weight:700}

.ic-panel{background:var(--ic-white);border:1px solid var(--ic-border);border-radius:var(--ic-radius);box-shadow:var(--ic-shadow);}
.ic-panel-head{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--ic-border)}
.ic-panel-head h2{margin:0;font-size:16px;font-weight:600;}
.ic-filters{display:flex;gap:8px;align-items:center}
.ic-btn{border:0;background:var(--ic-primary);color:#fff;padding:10px 16px;border-radius:10px;cursor:pointer;font-size:14px;font-weight:500;transition:all 0.2s ease;}
.ic-btn:hover{background:#2948FF;transform:translateY(-1px);}
.ic-btn.ghost{background:transparent;color:var(--ic-primary);border:1px solid #C7D2FE}
.ic-btn.ghost:hover{background:#F0F4FF;}
.ic-btn.danger{background:var(--ic-error);}
.ic-btn.danger:hover{background:#DC2626;}

.ic-table{width:100%;border-collapse:collapse}
.ic-table th,.ic-table td{padding:12px 16px;border-bottom:1px solid var(--ic-border);text-align:left}
.ic-table th{background:#F8FAFC;font-weight:600;font-size:13px;color:var(--ic-text-2);}
.ic-table tr:hover{background:#F8FAFC;}

.ic-footer{margin-top:auto;padding:12px 16px;color:var(--ic-text-2);border-top:1px solid var(--ic-border);background:var(--ic-white);font-size:12px;}

/* Forms */
.ic-form{display:flex;flex-direction:column;gap:16px;max-width:400px;}
.ic-form-group{display:flex;flex-direction:column;gap:6px;}
.ic-label{font-weight:500;font-size:14px;color:var(--ic-text);}
.ic-input{padding:12px;border:1px solid var(--ic-border);border-radius:10px;font-size:14px;}
.ic-input:focus{outline:none;border-color:var(--ic-primary);box-shadow:0 0 0 3px rgba(58,91,255,0.1);}
.ic-select{padding:12px;border:1px solid var(--ic-border);border-radius:10px;font-size:14px;background:white;}

/* Login Page */
.ic-login{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg, #667eea 0%, #764ba2 100%);}
.ic-login-card{background:var(--ic-white);padding:32px;border-radius:var(--ic-radius);box-shadow:var(--ic-shadow);width:100%;max-width:400px;}
.ic-login-header{text-align:center;margin-bottom:24px;}
.ic-login-logo{font-size:32px;font-weight:700;color:var(--ic-primary);margin-bottom:8px;}
.ic-login-subtitle{color:var(--ic-text-2);font-size:14px;}

/* Cards de métricas */
.ic-metric-card{position:relative;overflow:hidden;}
.ic-metric-card::before{content:'';position:absolute;top:0;right:0;width:40px;height:40px;background:linear-gradient(45deg, rgba(58,91,255,0.1), transparent);border-radius:0 var(--ic-radius) 0 var(--ic-radius);}

/* Status badges */
.ic-badge{padding:4px 8px;border-radius:6px;font-size:12px;font-weight:500;}
.ic-badge.success{background:#DCFCE7;color:#16A34A;}
.ic-badge.warning{background:#FEF3C7;color:#D97706;}
.ic-badge.error{background:#FEE2E2;color:#DC2626;}
.ic-badge.info{background:#DBEAFE;color:#2563EB;}

/* Tabs */
.ic-tabs{display:flex;border-bottom:1px solid var(--ic-border);margin-bottom:16px;}
.ic-tab{padding:12px 16px;border:0;background:transparent;cursor:pointer;color:var(--ic-text-2);border-bottom:2px solid transparent;}
.ic-tab.active{color:var(--ic-primary);border-bottom-color:var(--ic-primary);font-weight:500;}
.ic-tab:hover{background:#F8FAFC;}

/* Progress Bar */
.ic-progress{position:relative;background:#E5E7EB;border-radius:8px;height:8px;overflow:hidden;}
.ic-progress-bar{height:100%;background:var(--ic-primary);transition:width 0.3s ease;}
.ic-progress-text{margin-top:4px;font-size:12px;color:var(--ic-text-2);}

/* File Upload */
.ic-file-upload{display:inline-block;}

/* Color Picker */
.ic-color-picker{display:flex;gap:8px;align-items:center;}
.ic-color-input{width:40px;height:40px;border:1px solid var(--ic-border);border-radius:8px;cursor:pointer;}

/* Plan Cards */
.ic-plan-card{background:var(--ic-white);border:1px solid var(--ic-border);border-radius:var(--ic-radius);padding:20px;transition:all 0.2s ease;}
.ic-plan-card:hover{box-shadow:var(--ic-shadow);transform:translateY(-2px);}
.ic-plan-card.current{border-color:var(--ic-primary);background:linear-gradient(135deg, #F0F4FF, #FFFFFF);}
.ic-plan-header{text-align:center;margin-bottom:16px;}
.ic-plan-header h3{margin:0 0 8px 0;font-size:18px;}
.ic-plan-price{font-size:24px;font-weight:700;color:var(--ic-primary);}
.ic-plan-limits{margin-bottom:20px;}
.ic-plan-limits div{padding:4px 0;font-size:14px;color:var(--ic-text-2);}

/* Template Editor */
.ic-template-editor{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:16px;}
.ic-template-form{display:flex;flex-direction:column;gap:16px;}
.ic-template-preview{background:#F8FAFC;border:1px solid var(--ic-border);border-radius:var(--ic-radius);padding:16px;}
.ic-template-preview h4{margin:0 0 12px 0;color:var(--ic-text-2);font-size:14px;}
.ic-preview-content{background:white;border:1px solid var(--ic-border);border-radius:8px;padding:12px;min-height:200px;font-family:monospace;font-size:13px;white-space:pre-wrap;}

/* Import Wizard */
.ic-import-wizard{display:flex;flex-direction:column;gap:24px;}
.ic-import-steps{display:flex;justify-content:space-between;margin-bottom:24px;}
.ic-import-step{display:flex;align-items:center;gap:8px;flex:1;}
.ic-import-step-number{width:32px;height:32px;border-radius:50%;background:#E5E7EB;display:grid;place-items:center;font-weight:600;}
.ic-import-step.active .ic-import-step-number{background:var(--ic-primary);color:white;}
.ic-import-step.completed .ic-import-step-number{background:var(--ic-success);color:white;}

/* Mapping Table */
.ic-mapping-table{margin-top:16px;}
.ic-mapping-table th,.ic-mapping-table td{padding:8px 12px;border:1px solid var(--ic-border);}
.ic-mapping-select{width:100%;border:0;background:white;padding:4px;}

/* Usage Meters */
.ic-usage-meter{display:flex;align-items:center;gap:12px;margin-bottom:12px;}
.ic-usage-label{min-width:120px;font-size:14px;color:var(--ic-text-2);}
.ic-usage-bar{flex:1;background:#E5E7EB;border-radius:4px;height:8px;overflow:hidden;}
.ic-usage-fill{height:100%;background:var(--ic-primary);transition:width 0.3s ease;}
.ic-usage-fill.warning{background:var(--ic-warn);}
.ic-usage-fill.danger{background:var(--ic-error);}
.ic-usage-text{font-size:12px;color:var(--ic-text-2);}

/* PWA Styles */
.ic-pwa-card{text-align:center;padding:32px;background:linear-gradient(135deg, #667eea 0%, #764ba2 100%);color:white;border-radius:var(--ic-radius);}
.ic-pwa-icon{font-size:64px;margin-bottom:16px;}
.ic-install-prompt{background:var(--ic-success);color:white;padding:12px 24px;border-radius:50px;border:0;font-weight:600;cursor:pointer;transition:all 0.3s ease;}
.ic-install-prompt:hover{background:#15803D;transform:translateY(-2px);}

/* System Health */
.ic-health-metric{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--ic-border);}
.ic-health-metric:last-child{border-bottom:0;}
.ic-health-value{font-weight:600;font-size:18px;}
.ic-health-good{color:var(--ic-success);}
.ic-health-warning{color:var(--ic-warn);}
.ic-health-error{color:var(--ic-error);}

/* API Documentation */
.ic-api-endpoint{background:#F8FAFC;border:1px solid var(--ic-border);border-radius:8px;padding:12px;margin:8px 0;font-family:monospace;}
.ic-api-method{color:var(--ic-success);font-weight:700;margin-right:8px;}
.ic-api-path{color:var(--ic-text);}

/* Code blocks */
.ic-code{background:#1F2937;color:#F9FAFB;padding:16px;border-radius:8px;overflow-x:auto;font-family:'Courier New',monospace;font-size:13px;}
.ic-code .keyword{color:#60A5FA;}
.ic-code .string{color:#34D399;}
.ic-code .comment{color:#9CA3AF;}

/* Permission Management Styles */
.ic-permission-category{margin:16px 0;}
.ic-permission-category h4{font-size:14px;font-weight:600;margin:0 0 8px 0;}
.ic-permission-list{display:flex;flex-direction:column;gap:8px;}
.ic-permission-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;transition:background-color 0.2s ease;}
.ic-permission-item:hover{background:var(--ic-bg);}
.ic-permission-item input[type="checkbox"]{margin:0;width:16px;height:16px;accent-color:var(--ic-primary);}
.ic-permission-item label{cursor:pointer;font-size:14px;flex:1;user-select:none;}
.ic-permission-item input[type="checkbox"]:checked + label{font-weight:500;color:var(--ic-primary);}

/* User Management Styles */
.ic-user-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--ic-primary);color:white;font-weight:600;font-size:14px;}
.ic-user-status{display:flex;align-items:center;gap:6px;}
.ic-user-status .ic-badge{font-size:12px;}

/* Role Badge Colors */
.ic-badge.master{background:#EF4444;color:white;}
.ic-badge.gestor{background:#16A34A;color:white;}
.ic-badge.operador{background:#F59E0B;color:white;}
.ic-badge.agente{background:#3B82F6;color:white;}
.ic-badge.emissoes{background:#6B7280;color:white;}

/* Mobile optimizations */
.ic-mobile-optimized{touch-action:manipulation;-webkit-tap-highlight-color:transparent;}
.ic-swipe-action{position:relative;overflow:hidden;}
.ic-swipe-content{transform:translateX(0);transition:transform 0.3s ease;}
.ic-swipe-actions{position:absolute;right:0;top:0;bottom:0;display:flex;align-items:center;background:var(--ic-error);color:white;padding:0 16px;}

/* Skeleton loading */
.ic-skeleton{background:linear-gradient(90deg, #f0f0f0 25%, transparent 37%, #f0f0f0 63%);background-size:400% 100%;animation:skeleton 1.5s ease-in-out infinite;}
.ic-skeleton-text{height:16px;border-radius:4px;margin:4px 0;}
.ic-skeleton-title{height:24px;border-radius:4px;margin:8px 0;}
@keyframes skeleton{0%{background-position:100% 50%;}100%{background-position:0% 50%;}}

/* Language selector */
.ic-language-flag{font-size:20px;margin-right:8px;}
.ic-preview-box{background:#F8FAFC;border:1px solid var(--ic-border);border-radius:8px;padding:16px;margin:16px 0;}

/* Environment banners */
.ic-env-banner{background:var(--ic-warn);color:white;text-align:center;padding:8px;font-size:13px;font-weight:500;}
.ic-env-banner.sandbox{background:#8B5CF6;}
.ic-env-banner.demo{background:#06B6D4;}

/* Toast notifications enhancement */
.ic-toast{position:fixed;top:20px;right:20px;padding:12px 16px;border-radius:8px;color:white;font-weight:500;z-index:1000;max-width:400px;box-shadow:0 10px 25px rgba(0,0,0,0.1);}
.ic-toast.success{background:var(--ic-success);}
.ic-toast.error{background:var(--ic-error);}
.ic-toast.warning{background:var(--ic-warn);}
.ic-toast.info{background:var(--ic-primary);}

/* PWA Install button */
#install-button{background:linear-gradient(135deg, #667eea 0%, #764ba2 100%);border:0;color:white;padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all 0.3s ease;}
#install-button:hover{transform:translateY(-2px);box-shadow:0 10px 25px rgba(102,126,234,0.3);}

/* Responsive */
@media (max-width:1100px){
  .ic-cards{grid-template-columns:repeat(2,1fr)}
  .ic-template-editor{grid-template-columns:1fr;}
  .ic-api-endpoint{font-size:12px;}
}
@media (max-width:720px){
  .ic-app{grid-template-columns:1fr}
  .ic-sidebar{position:fixed;inset:0 auto 0 0;width:280px;transform:translateX(-100%);transition:transform .15s ease;z-index:20;}
  .ic-app.sidebar-collapsed .ic-sidebar{transform:none}
  .ic-topbar{position:sticky}
  .ic-cards{grid-template-columns:1fr}
  .ic-form{max-width:100%;}
  .ic-actions{flex-wrap:wrap;}
  .ic-search{min-width:200px;}
  .ic-template-editor{grid-template-columns:1fr;}
  .ic-import-steps{flex-direction:column;gap:12px;}
  .ic-color-picker{flex-direction:column;align-items:stretch;}
  .ic-toast{left:20px;right:20px;max-width:none;}
  .ic-api-endpoint{font-size:11px;word-break:break-all;}
}