/* =============================================
   DTPRO - ESTILOS GLOBAIS
   ============================================= */
:root {
    --verde: #0b63f6;
    --verde-hover: #084fc4;
    --verde-light: #eaf3ff;
    --verde-mid: #0ea5ff;
    --cinza-bg: #f8fafc;
    --cinza-card: #ffffff;
    --cinza-borda: #e2e8f0;
    --cinza-texto: #64748b;
    --preto: #0f172a;
    --sidebar-w: 210px;
    --header-h: 52px;
    --banner-h: 44px;
    --radius: 10px;
    --sombra: 0 1px 4px rgba(0,0,0,.08);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: 'Inter', -apple-system, sans-serif; background: var(--cinza-bg); color: var(--preto); font-size: 14px; }

a { text-decoration: none; color: inherit; }
input, select, textarea { font-family: inherit; font-size: 14px; }

/* ---- BANNER TRIAL ---- */
.trial-banner {
    background: var(--preto); color: #fff;
    height: var(--banner-h); display: flex; align-items: center;
    justify-content: center; gap: 16px; position: sticky; top: 0; z-index: 200;
    font-size: 13px;
}
.trial-banner .btn-assine {
    background: var(--verde); color: #fff; border: none;
    padding: 6px 16px; border-radius: 6px; cursor: pointer; font-weight: 600;
}
.trial-banner .fechar { margin-left: 16px; cursor: pointer; opacity:.7; }
.trial-banner .fechar:hover { opacity:1; }

/* ---- LAYOUT ---- */
.layout { display: flex; min-height: 100vh; }

/* ---- SIDEBAR ---- */
.sidebar {
    width: var(--sidebar-w); background: #fff;
    border-right: 1px solid var(--cinza-borda);
    display: flex; flex-direction: column;
    position: fixed; top: var(--banner-h); left: 0;
    height: calc(100vh - var(--banner-h)); z-index: 100;
    overflow-y: auto;
}
.sidebar-logo {
    padding: 16px 16px 8px;
}
.sidebar-logo .logo-texto {
    font-size: 17px; font-weight: 700; color: var(--preto);
}
.sidebar-logo .logo-texto span { color: var(--verde); }

.btn-vender {
    margin: 8px 12px 12px;
    background: var(--verde); color: #fff;
    border: none; border-radius: 8px;
    padding: 10px; width: calc(100% - 24px);
    cursor: pointer; font-weight: 600; font-size: 14px;
    display: flex; align-items: center; justify-content: center; gap: 8px;
}
.btn-vender:hover { background: var(--verde-hover); }

.sidebar-nav { flex: 1; padding: 4px 8px; }
.sidebar-nav a {
    display: flex; align-items: center; gap: 10px;
    padding: 8px 10px; border-radius: 7px;
    color: #374151; font-size: 13.5px; margin-bottom: 2px;
    transition: background .15s;
}
.sidebar-nav a:hover, .sidebar-nav a.ativo {
    background: var(--verde-light); color: var(--verde);
}
.sidebar-nav a svg { width: 17px; height: 17px; flex-shrink: 0; }

.sidebar-bottom { padding: 8px 8px 16px; border-top: 1px solid var(--cinza-borda); margin-top: 8px; }
.sidebar-bottom a {
    display: flex; align-items: center; gap: 10px;
    padding: 8px 10px; border-radius: 7px;
    color: #374151; font-size: 13.5px; margin-bottom: 2px;
}
.sidebar-bottom a:hover { background: var(--cinza-bg); }

/* ---- CONTEÚDO ---- */
.main-wrap {
    margin-left: var(--sidebar-w);
    margin-top: var(--banner-h);
    flex: 1; display: flex; flex-direction: column;
    min-height: calc(100vh - var(--banner-h));
}

.topbar {
    height: var(--header-h); background: #fff;
    border-bottom: 1px solid var(--cinza-borda);
    display: flex; align-items: center; justify-content: space-between;
    padding: 0 24px; position: sticky; top: var(--banner-h); z-index: 90;
}
.topbar-title { font-size: 18px; font-weight: 700; }
.topbar-right { display: flex; align-items: center; gap: 12px; }
.topbar-right a, .topbar-right button {
    display: flex; align-items: center; gap: 6px;
    color: #374151; font-size: 13px; background: none;
    border: 1px solid var(--cinza-borda); border-radius: 7px;
    padding: 5px 10px; cursor: pointer;
}
.topbar-right a:hover { background: var(--cinza-bg); }
.topbar-user { font-weight: 600; }

.page-content { padding: 24px; flex: 1; }

/* ---- CARDS ---- */
.card {
    background: #fff; border-radius: var(--radius);
    border: 1px solid var(--cinza-borda);
    box-shadow: var(--sombra); padding: 20px;
}

/* ---- BOTÕES ---- */
.btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 8px 16px; border-radius: 8px;
    font-weight: 600; font-size: 13.5px; cursor: pointer;
    border: none; transition: all .15s;
}
.btn-primary { background: var(--verde); color: #fff; }
.btn-primary:hover { background: var(--verde-hover); }
.btn-outline { background: #fff; color: var(--verde); border: 1.5px solid var(--verde); }
.btn-outline:hover { background: var(--verde-light); }
.btn-danger { background: #dc2626; color: #fff; }
.btn-gray { background: var(--cinza-bg); color: #374151; border: 1px solid var(--cinza-borda); }

/* ---- ABAS ---- */
.tabs { display: flex; border-bottom: 2px solid var(--cinza-borda); margin-bottom: 20px; }
.tab-item {
    padding: 10px 18px; font-size: 14px; font-weight: 500;
    color: var(--cinza-texto); cursor: pointer; border-bottom: 2px solid transparent;
    margin-bottom: -2px;
}
.tab-item.ativo, .tab-item:hover { color: var(--verde); border-color: var(--verde); }

/* ---- TABELA ---- */
.tabela { width: 100%; border-collapse: collapse; }
.tabela th { text-align: left; padding: 10px 14px; font-size: 12px; color: var(--cinza-texto); background: var(--cinza-bg); border-bottom: 1px solid var(--cinza-borda); }
.tabela td { padding: 12px 14px; border-bottom: 1px solid var(--cinza-borda); font-size: 13.5px; }
.tabela tr:hover td { background: #eaf3ff; }

/* ---- BADGES ---- */
.badge { display: inline-flex; align-items: center; gap: 4px; padding: 3px 10px; border-radius: 20px; font-size: 11.5px; font-weight: 600; }
.badge-verde { background: var(--verde-light); color: var(--verde); }
.badge-laranja { background: #fff7ed; color: #c2410c; }
.badge-vermelho { background: #fef2f2; color: #dc2626; }
.badge-cinza { background: #f1f5f9; color: #475569; }
.badge-azul { background: #eff6ff; color: #1d4ed8; }

/* ---- FORMULÁRIOS ---- */
.form-group { margin-bottom: 14px; }
.form-label { display: block; font-size: 12.5px; font-weight: 600; color: #374151; margin-bottom: 5px; }
.form-control {
    width: 100%; padding: 10px 12px;
    border: 1.5px solid var(--cinza-borda); border-radius: 8px;
    background: #f8fafc; font-size: 14px; color: var(--preto);
    transition: border .15s;
}
.form-control:focus { outline: none; border-color: var(--verde); background: #fff; }
.form-row { display: grid; gap: 12px; }
.form-row-2 { grid-template-columns: 1fr 1fr; }
.form-row-3 { grid-template-columns: 1fr 1fr 1fr; }

/* ---- TOGGLE ---- */
.toggle-wrap { display: flex; align-items: center; gap: 8px; }
.toggle { position: relative; width: 40px; height: 22px; }
.toggle input { opacity: 0; width: 0; height: 0; }
.toggle-slider {
    position: absolute; inset: 0; background: #cbd5e1;
    border-radius: 22px; cursor: pointer; transition: .2s;
}
.toggle-slider:before {
    content: ''; position: absolute;
    width: 16px; height: 16px; left: 3px; bottom: 3px;
    background: #fff; border-radius: 50%; transition: .2s;
}
.toggle input:checked + .toggle-slider { background: var(--verde); }
.toggle input:checked + .toggle-slider:before { transform: translateX(18px); }

/* ---- MODAL ---- */
.modal-overlay {
    position: fixed; inset: 0; background: rgba(0,0,0,.4);
    z-index: 500; display: flex; align-items: flex-start;
    justify-content: center; padding: 40px 16px; overflow-y: auto;
}
.modal {
    background: #fff; border-radius: 12px;
    width: 100%; max-width: 680px;
    max-height: 90vh; overflow-y: auto;
    box-shadow: 0 20px 60px rgba(0,0,0,.2);
}
.modal-header {
    padding: 20px 24px 0;
    position: sticky; top: 0; background: #fff; z-index: 10;
}
.modal-header h2 { font-size: 18px; font-weight: 700; }
.modal-tabs { display: flex; border-bottom: 2px solid var(--cinza-borda); margin-top: 16px; }
.modal-tab {
    padding: 10px 16px; font-size: 13.5px; font-weight: 500;
    color: var(--cinza-texto); cursor: pointer;
    border-bottom: 2px solid transparent; margin-bottom: -2px;
}
.modal-tab.ativo { color: var(--verde); border-color: var(--verde); }
.modal-body { padding: 20px 24px; }
.modal-footer {
    padding: 16px 24px; border-top: 1px solid var(--cinza-borda);
    display: flex; justify-content: flex-end; gap: 10px;
    position: sticky; bottom: 0; background: #fff;
}

/* ---- ESTADO VAZIO ---- */
.empty-state {
    text-align: center; padding: 60px 20px;
    color: var(--cinza-texto);
}
.empty-state h3 { color: var(--verde); font-size: 20px; margin-bottom: 8px; }
.empty-state p { margin-bottom: 20px; }

/* ---- FILTROS ---- */
.filtros-bar {
    display: flex; align-items: center; gap: 10px;
    margin-bottom: 20px; flex-wrap: wrap;
}
.filtros-bar .busca {
    flex: 1; min-width: 200px; padding: 8px 12px;
    border: 1.5px solid var(--cinza-borda); border-radius: 8px;
    background: #fff;
}

/* ---- STATS ---- */
.stats-row { display: grid; gap: 16px; margin-bottom: 20px; }
.stats-row-3 { grid-template-columns: repeat(3, 1fr); }
.stats-row-4 { grid-template-columns: repeat(4, 1fr); }
.stat-card { background: #fff; border-radius: var(--radius); border: 1px solid var(--cinza-borda); padding: 16px 20px; }
.stat-card .label { font-size: 12px; color: var(--cinza-texto); margin-bottom: 4px; }
.stat-card .valor { font-size: 22px; font-weight: 700; color: var(--verde); }
.stat-card .valor.vermelho { color: #dc2626; }

/* ---- ONBOARDING ---- */
.ob-wrap {
    min-height: 100vh; display: flex; align-items: center;
    justify-content: center; background: #fff;
}
.ob-card {
    width: 100%; max-width: 580px; padding: 40px 32px;
    text-align: center;
}
.ob-logo { font-size: 22px; font-weight: 800; color: var(--preto); margin-bottom: 32px; }
.ob-logo span { color: var(--verde); }
.ob-card h2 { font-size: 24px; font-weight: 800; margin-bottom: 6px; }
.ob-card p { color: var(--cinza-texto); margin-bottom: 28px; }
.ob-opcoes { display: flex; flex-direction: column; gap: 10px; margin-bottom: 28px; }
.ob-btn {
    padding: 14px 20px; border-radius: 10px; font-size: 15px; font-weight: 600;
    cursor: pointer; border: 1.5px solid var(--cinza-borda);
    background: #fff; color: var(--preto); text-align: left;
    transition: all .15s;
}
.ob-btn.selecionado { background: var(--verde); color: #fff; border-color: var(--verde); }
.ob-btn:hover:not(.selecionado) { border-color: var(--verde); color: var(--verde); }
.ob-nav { display: flex; justify-content: center; gap: 12px; align-items: center; margin-bottom: 20px; }
.ob-btn-nav {
    padding: 10px 28px; border-radius: 8px; font-weight: 700;
    cursor: pointer; font-size: 15px;
}
.ob-btn-back { background: none; border: none; color: var(--cinza-texto); }
.ob-btn-next { background: var(--verde); color: #fff; border: none; }
.ob-btn-next:disabled { background: #cbd5e1; cursor: default; }
.ob-dots { display: flex; gap: 6px; justify-content: center; }
.ob-dot { width: 8px; height: 8px; border-radius: 50%; background: #cbd5e1; }
.ob-dot.ativo { background: var(--verde); }
.ob-alerta { color: var(--verde); font-size: 13px; margin-bottom: 8px; display: flex; align-items: center; justify-content: center; gap: 6px; }
.ob-segmentos { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 28px; text-align: left; }

/* ---- LOGIN / CADASTRO ---- */
.auth-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; background: var(--cinza-bg); }
.auth-card { background: #fff; border-radius: 14px; padding: 40px; width: 100%; max-width: 420px; box-shadow: 0 4px 24px rgba(0,0,0,.08); }
.auth-logo { font-size: 22px; font-weight: 800; text-align: center; margin-bottom: 28px; }
.auth-logo span { color: var(--verde); }
.auth-footer { text-align: center; margin-top: 16px; font-size: 13px; color: var(--cinza-texto); }
.auth-footer a { color: var(--verde); font-weight: 600; }
.erro { background: #fef2f2; color: #dc2626; border-radius: 8px; padding: 10px 14px; font-size: 13px; margin-bottom: 14px; }
.sucesso { background: var(--verde-light); color: var(--verde); border-radius: 8px; padding: 10px 14px; font-size: 13px; margin-bottom: 14px; }

/* ---- PDV ---- */
.pdv-wrap { display: flex; height: 100vh; overflow: hidden; background: #fff; }
.pdv-left { flex: 1; display: flex; flex-direction: column; border-right: 1px solid var(--cinza-borda); overflow: hidden; }
.pdv-right { width: 340px; display: flex; flex-direction: column; }
.pdv-header { height: 52px; display: flex; align-items: center; padding: 0 16px; gap: 12px; border-bottom: 1px solid var(--cinza-borda); }
.pdv-busca { flex: 1; padding: 8px 12px; border: 1.5px solid var(--cinza-borda); border-radius: 8px; font-size: 14px; }
.pdv-produtos { flex: 1; overflow-y: auto; padding: 12px; }
.pdv-produto-item {
    display: flex; align-items: center; justify-content: space-between;
    padding: 10px 12px; border-radius: 8px; cursor: pointer;
    border: 1px solid var(--cinza-borda); margin-bottom: 6px;
}
.pdv-produto-item:hover { background: var(--verde-light); border-color: var(--verde); }
.pdv-carrinho { flex: 1; overflow-y: auto; padding: 12px; }
.pdv-item-carrinho { display: flex; align-items: center; gap: 8px; padding: 8px 0; border-bottom: 1px solid var(--cinza-borda); }
.pdv-footer { padding: 12px; border-top: 1px solid var(--cinza-borda); }
.pdv-total { display: flex; justify-content: space-between; font-size: 16px; font-weight: 700; margin-bottom: 10px; }
.pdv-footer-btns { display: flex; gap: 8px; }

/* ---- PRIMEIROS PASSOS ---- */
.passos-card { border: 1px solid var(--cinza-borda); border-radius: 10px; overflow: hidden; }
.passos-header { display: flex; justify-content: space-between; align-items: center; padding: 14px 18px; border-bottom: 1px solid var(--cinza-borda); }
.passo-item { display: flex; align-items: center; gap: 14px; padding: 14px 18px; border-bottom: 1px solid var(--cinza-borda); cursor: pointer; }
.passo-item:last-child { border-bottom: none; }
.passo-item:hover { background: var(--cinza-bg); }
.passo-icon { width: 28px; height: 28px; border-radius: 50%; border: 1.5px solid var(--cinza-borda); display: flex; align-items: center; justify-content: center; color: var(--verde); flex-shrink: 0; }
.passo-icon.ok { background: var(--verde-light); border-color: var(--verde); }

@media (max-width: 768px) {
    .sidebar { transform: translateX(-100%); transition: .3s; }
    .sidebar.aberta { transform: none; }
    .main-wrap { margin-left: 0; }
    .form-row-2, .form-row-3 { grid-template-columns: 1fr; }
    .stats-row-3, .stats-row-4 { grid-template-columns: 1fr 1fr; }
    .ob-segmentos { grid-template-columns: 1fr; }
}

/* =============================================
   IDENTIDADE DTPRO - azul corporativo
   ============================================= */
:root{
    --verde:#0b63f6;
    --verde-hover:#084fc4;
    --verde-light:#eaf3ff;
    --verde-mid:#0ea5ff;
    --preto:#071a33;
    --dt-navy:#061a33;
    --dt-navy-2:#0b2548;
    --dt-blue:#0b63f6;
    --dt-blue-2:#0ea5ff;
}
.trial-banner{background:#0b1220;color:#fff;box-shadow:0 1px 0 rgba(255,255,255,.06) inset;}
.trial-banner .btn-assine{background:linear-gradient(135deg,var(--dt-blue),var(--dt-blue-2));box-shadow:0 8px 18px rgba(11,99,246,.22);}
.sidebar{background:linear-gradient(180deg,var(--dt-navy) 0%,#07172b 100%);border-right:1px solid rgba(255,255,255,.08);box-shadow:10px 0 30px rgba(2,8,23,.08);}
.sidebar-logo{padding:14px 14px 10px;margin:0 0 4px;background:#fff;border-bottom:1px solid rgba(226,232,240,.9);}
.sidebar-logo img{height:auto!important;max-height:62px!important;max-width:185px!important;width:100%!important;object-fit:contain!important;display:block;margin:0 auto;}
.btn-vender{background:linear-gradient(135deg,var(--dt-blue),var(--dt-blue-2));box-shadow:0 8px 18px rgba(11,99,246,.20);}
.btn-vender:hover{background:linear-gradient(135deg,var(--dt-blue-2),var(--dt-blue));}
.sidebar-nav a,.sidebar-bottom a{color:#dbeafe;}
.sidebar-nav a:hover,.sidebar-nav a.ativo{background:linear-gradient(135deg,var(--dt-blue),var(--dt-blue-2));color:#fff;box-shadow:0 8px 20px rgba(11,99,246,.18);}
.sidebar-nav a svg,.sidebar-bottom a svg{color:currentColor;}
.sidebar-bottom{border-top:1px solid rgba(255,255,255,.10);}
.sidebar-bottom a:hover{background:rgba(255,255,255,.08);color:#fff;}
.topbar{background:rgba(255,255,255,.96);backdrop-filter:blur(10px);}
.btn-primary{background:linear-gradient(135deg,var(--dt-blue),var(--dt-blue-2));box-shadow:0 8px 18px rgba(11,99,246,.16);}
.btn-primary:hover{background:linear-gradient(135deg,var(--dt-blue-2),var(--dt-blue));}
.btn-outline{color:var(--dt-blue);border-color:var(--dt-blue);}
.btn-outline:hover{background:var(--verde-light);}
.card,.stat-card,.modal,.tabela{box-shadow:0 6px 18px rgba(15,23,42,.05);}
.form-control:focus{border-color:var(--dt-blue);box-shadow:0 0 0 3px rgba(11,99,246,.10);background:#fff;}
.badge-verde{background:var(--verde-light);color:var(--dt-blue);}
.tab-item.ativo,.tab-item:hover{color:var(--dt-blue);border-color:var(--dt-blue);}
.bottom-nav .bn-item.ativo{color:var(--dt-blue)!important;}
.bottom-nav .bn-vender{background:linear-gradient(135deg,var(--dt-blue),var(--dt-blue-2))!important;}
@media(max-width:768px){
  .sidebar-logo{border-radius:0;padding-top:20px;}
  .sidebar-logo img{max-width:205px!important;max-height:70px!important;}
}
