/* ==========================================================================
   HeroSeguros Deploy — Design System (acabamento premium sobre o Tabler)
   Sprint 01 — UX/UI. Suporta tema light/dark via [data-bs-theme] no <html>.
   ========================================================================== */

/* ----------------------------------------------------------------- Tokens */
:root {
    --brand:        #2f6bff;
    --brand-2:      #6f9bff;
    --brand-dark:   #1e51e6;
    --brand-rgb:    47, 107, 255;

    --sidebar-bg:   #0c111d;
    --sidebar-bg-2: #090d16;
    --sidebar-fg:   #9aa7bd;
    --sidebar-muted:#5d6b85;

    --radius:       14px;
    --radius-sm:    9px;
    --shadow-sm:    0 1px 2px rgba(16,24,40,.04), 0 1px 3px rgba(16,24,40,.04);
    --shadow-md:    0 8px 24px rgba(16,24,40,.08);
    --shadow-lg:    0 18px 48px rgba(16,24,40,.14);

    /* Override do tema Tabler/Bootstrap (claro) */
    --tblr-primary: #2f6bff;
    --tblr-primary-rgb: 47, 107, 255;
    --tblr-font-sans-serif: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    --tblr-body-font-family: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

    --app-bg:       #f4f6fb;
    --surface:      #ffffff;
    --surface-2:    #f7f9fd;
    --border:       #e8ecf4;
    --border-2:     #eef1f7;
    --txt:          #16202e;
    --txt-2:        #3a4658;
    --muted:        #8a94a6;
}

/* Tema escuro: o Tabler já reestila os componentes base; aqui ajustamos os
   tokens próprios para o conteúdo combinar. A sidebar é sempre escura. */
[data-bs-theme="dark"] {
    --app-bg:    #0b0f1a;
    --surface:   #131a29;
    --surface-2: #182135;
    --border:    #222c40;
    --border-2:  #1c2638;
    --txt:       #e6edf3;
    --txt-2:     #c3cdda;
    --muted:     #8b98a5;
    --tblr-body-bg: #0b0f1a;
    --tblr-bg-surface: #131a29;
    --tblr-border-color: #222c40;
}

body {
    font-family: var(--tblr-font-sans-serif);
    background: var(--app-bg);
    color: var(--txt);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

/* =============================================================== Sidebar */
.navbar-vertical {
    background: linear-gradient(180deg, var(--sidebar-bg) 0%, var(--sidebar-bg-2) 100%) !important;
    border-right: 1px solid rgba(255,255,255,.05);
    box-shadow: 2px 0 20px rgba(8,12,22,.30);
    width: 256px;
}
.navbar-vertical .container-fluid { padding-left: 0; padding-right: 0; }
.brand-block {
    display: flex; align-items: center; gap: 11px;
    padding: 18px 18px 16px; width: 100%;
    border-bottom: 1px solid rgba(255,255,255,.06); margin-bottom: 6px;
}
.brand-logo {
    width: 38px; height: 38px; border-radius: 11px; flex: none;
    display: grid; place-items: center;
    background: linear-gradient(135deg, var(--brand) 0%, var(--brand-2) 100%);
    box-shadow: 0 6px 18px rgba(var(--brand-rgb), .5);
}
.brand-logo svg { width: 22px; height: 22px; }
.brand-name { color: #fff; font-weight: 700; font-size: 15px; line-height: 1.05; letter-spacing: .2px; }
.brand-sub  { color: var(--sidebar-fg); font-size: 10.5px; text-transform: uppercase; letter-spacing: .14em; margin-top: 2px; }

.navbar-vertical .nav-section {
    color: var(--sidebar-muted); font-size: 10px; font-weight: 700;
    text-transform: uppercase; letter-spacing: .14em; padding: 16px 22px 6px;
}
.navbar-vertical .nav-item { padding: 0 12px; }
.navbar-vertical .nav-link {
    color: var(--sidebar-fg); border-radius: var(--radius-sm);
    padding: .56rem .72rem; margin: 1px 0; font-weight: 500; font-size: 14px;
    display: flex; align-items: center; gap: 2px;
    transition: background .15s, color .15s, transform .05s;
}
.navbar-vertical .nav-link .nav-link-icon { color: inherit; opacity: .82; margin-right: 6px; font-size: 18px; }
.navbar-vertical .nav-link:hover { color: #fff; background: rgba(255,255,255,.06); }
.navbar-vertical .nav-link:active { transform: scale(.99); }
.navbar-vertical .nav-link.active {
    color: #fff;
    background: linear-gradient(90deg, rgba(var(--brand-rgb), .32), rgba(var(--brand-rgb), .05));
    box-shadow: inset 3px 0 0 var(--brand);
}
.navbar-vertical .nav-link.active .nav-link-icon { opacity: 1; }
.navbar-vertical .nav-link.is-soon { opacity: .55; cursor: default; }
.navbar-vertical .nav-link.is-soon:hover { background: transparent; color: var(--sidebar-fg); }
.nav-soon-pill {
    margin-left: auto; font-size: 9px; font-weight: 700; letter-spacing: .06em;
    text-transform: uppercase; color: var(--sidebar-muted);
    border: 1px solid rgba(255,255,255,.12); border-radius: 6px; padding: 1px 6px;
}
.sidebar-foot {
    margin-top: auto; padding: 14px 18px; font-size: 11px; color: var(--sidebar-muted);
    border-top: 1px solid rgba(255,255,255,.06);
}

/* ================================================================ Header */
.app-header {
    background: color-mix(in srgb, var(--surface) 88%, transparent);
    backdrop-filter: saturate(160%) blur(10px);
    border-bottom: 1px solid var(--border);
    min-height: 60px;
}
.header-search {
    position: relative; max-width: 420px; width: 100%;
}
.header-search .ti { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); color: var(--muted); font-size: 17px; }
.header-search input {
    background: var(--surface-2); border: 1px solid var(--border);
    border-radius: 10px; padding: .5rem .75rem .5rem 2.2rem; width: 100%; font-size: 13.5px;
    transition: border-color .15s, box-shadow .15s;
}
.header-search input:focus { outline: none; border-color: var(--brand); box-shadow: 0 0 0 .2rem rgba(var(--brand-rgb), .14); }
.header-search kbd {
    position: absolute; right: 10px; top: 50%; transform: translateY(-50%);
    font-size: 10px; background: var(--surface); border: 1px solid var(--border);
    border-radius: 5px; padding: 1px 6px; color: var(--muted);
}
.header-icon-btn {
    width: 38px; height: 38px; border-radius: 10px; display: grid; place-items: center;
    color: var(--muted); border: 1px solid transparent; background: transparent;
    transition: background .15s, color .15s, border-color .15s;
}
.header-icon-btn:hover { background: var(--surface-2); color: var(--txt); border-color: var(--border); }
.header-icon-btn .ti { font-size: 19px; }
.infra-pill {
    display: inline-flex; align-items: center; gap: 7px; font-size: 12px; font-weight: 600;
    color: var(--txt-2); background: var(--surface-2); border: 1px solid var(--border);
    border-radius: 999px; padding: .32rem .7rem;
}
.infra-pill .status-dot { margin: 0; box-shadow: 0 0 0 3px rgba(33,189,118,.18); }

/* Breadcrumb */
.app-breadcrumb { font-size: 12.5px; color: var(--muted); display: flex; align-items: center; gap: 6px; }
.app-breadcrumb a { color: var(--muted); text-decoration: none; }
.app-breadcrumb a:hover { color: var(--brand); }
.app-breadcrumb .sep { opacity: .5; }
.app-breadcrumb .cur { color: var(--txt-2); font-weight: 600; }

/* ================================================ Page header / tipografia */
.page-title { font-weight: 700; letter-spacing: -.015em; color: var(--txt); font-size: 1.6rem; }
.page-pretitle { text-transform: uppercase; letter-spacing: .1em; color: var(--muted); font-size: 11px; font-weight: 600; }

/* ================================================================== Cards */
.card {
    border: 1px solid var(--border); border-radius: var(--radius);
    box-shadow: var(--shadow-sm); background: var(--surface);
}
.card .card-header { border-bottom: 1px solid var(--border-2); padding: .9rem 1.15rem; min-height: 0; }
.card .card-title { font-weight: 600; font-size: 14.5px; letter-spacing: -.01em; }

/* Stat cards (dashboard) */
.stat-card { transition: transform .12s, box-shadow .12s; }
.stat-card .card-body { display: flex; align-items: center; gap: 14px; padding: 1.05rem 1.1rem; }
.stat-ico { width: 46px; height: 46px; border-radius: 12px; display: grid; place-items: center; font-size: 22px; flex: none; }
.stat-card .stat-value { font-size: 26px; font-weight: 700; line-height: 1; color: var(--txt); }
.stat-card .stat-label { color: var(--muted); font-size: 13px; }
.stat-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }

/* Mini barra de recurso */
.res-row { display: flex; justify-content: space-between; align-items: center; font-size: 13.5px; margin-bottom: .35rem; }
.res-bar { height: 6px; border-radius: 4px; background: var(--surface-2); overflow: hidden; }
.res-bar > span { display: block; height: 100%; border-radius: 4px; background: linear-gradient(90deg, var(--brand), var(--brand-2)); }

/* ============================================== Application cards (grid) */
.app-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(330px, 1fr)); gap: 18px; }
.app-card {
    background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius);
    box-shadow: var(--shadow-sm); display: flex; flex-direction: column; overflow: hidden;
    transition: transform .12s, box-shadow .12s, border-color .12s;
}
.app-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: color-mix(in srgb, var(--brand) 30%, var(--border)); }
.app-card-head { display: flex; align-items: center; gap: 12px; padding: 16px 16px 12px; }
.app-avatar {
    width: 40px; height: 40px; border-radius: 11px; flex: none; display: grid; place-items: center;
    color: #fff; font-weight: 700; font-size: 16px;
    background: linear-gradient(135deg, var(--brand), var(--brand-2));
}
.app-card-name { font-weight: 700; font-size: 15px; color: var(--txt); line-height: 1.1; }
.app-card-repo { font-size: 12px; color: var(--muted); margin-top: 2px; }
.app-card-meta { display: grid; grid-template-columns: 1fr 1fr; gap: 8px 14px; padding: 4px 16px 14px; }
.app-meta-item { font-size: 12px; }
.app-meta-item .k { color: var(--muted); display: block; font-size: 10.5px; text-transform: uppercase; letter-spacing: .06em; }
.app-meta-item .v { color: var(--txt-2); font-weight: 600; }
.app-card-foot { margin-top: auto; border-top: 1px solid var(--border-2); padding: 10px 12px; display: flex; flex-wrap: wrap; gap: 6px; }
.app-card-url { padding: 0 16px 12px; font-size: 12px; }
.app-card-url a { color: var(--brand); text-decoration: none; }

/* ================================================================ Tabs */
.app-tabs { display: flex; gap: 2px; border-bottom: 1px solid var(--border); margin-bottom: 1.25rem; overflow-x: auto; }
.app-tabs .nav-link, .app-tabs button {
    border: none; background: none; color: var(--muted); font-weight: 600; font-size: 13.5px;
    padding: .65rem .95rem; border-bottom: 2px solid transparent; border-radius: 0;
    display: inline-flex; align-items: center; gap: 7px; white-space: nowrap; cursor: pointer;
    transition: color .12s, border-color .12s;
}
.app-tabs .nav-link:hover { color: var(--txt); }
.app-tabs .nav-link.active { color: var(--brand); border-bottom-color: var(--brand); }
.app-tabs .ti { font-size: 17px; }
.tab-pane-soon { padding: 3rem 1rem; text-align: center; color: var(--muted); }

/* ============================================== Timeline (deploy steps) */
.deploy-steps { display: flex; flex-wrap: wrap; gap: 0; }
.deploy-step { display: flex; align-items: flex-start; gap: 12px; position: relative; padding-bottom: 18px; }
.deploy-step:last-child { padding-bottom: 0; }
.deploy-step .ds-rail { display: flex; flex-direction: column; align-items: center; }
.deploy-step .ds-dot {
    width: 28px; height: 28px; border-radius: 50%; display: grid; place-items: center; flex: none;
    border: 2px solid var(--border); background: var(--surface); color: var(--muted); font-size: 14px;
}
.deploy-step .ds-line { width: 2px; flex: 1; background: var(--border); margin: 2px 0; min-height: 14px; }
.deploy-step:last-child .ds-line { display: none; }
.deploy-step.done .ds-dot { border-color: #2fb344; background: #2fb344; color: #fff; }
.deploy-step.current .ds-dot { border-color: var(--brand); color: var(--brand); animation: pulse 1.4s infinite; }
.deploy-step.failed .ds-dot { border-color: #d63939; background: #d63939; color: #fff; }
.deploy-step .ds-body { padding-top: 3px; }
.deploy-step .ds-title { font-weight: 600; font-size: 13.5px; color: var(--txt); }
.deploy-step .ds-meta { font-size: 12px; color: var(--muted); }
@keyframes pulse { 0%,100%{ box-shadow: 0 0 0 0 rgba(var(--brand-rgb),.4);} 50%{ box-shadow: 0 0 0 6px rgba(var(--brand-rgb),0);} }

/* ================================================================ Tabelas */
.card-table thead th, .table thead th {
    text-transform: uppercase; font-size: 11px; letter-spacing: .04em; color: var(--muted); font-weight: 700;
    border-bottom: 1px solid var(--border-2);
}
.table tbody tr { transition: background .12s; }
.table tbody tr:hover { background: var(--surface-2); }
.table td { vertical-align: middle; }

/* ================================================================ Badges */
.badge { font-weight: 600; border-radius: 7px; padding: .36em .62em; letter-spacing: .01em; }
.status-dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; margin-right: 6px; vertical-align: baseline; }

/* ================================================================ Botões */
.btn { border-radius: var(--radius-sm); font-weight: 500; }
.btn-primary { background: var(--brand); border-color: var(--brand); box-shadow: 0 4px 12px rgba(var(--brand-rgb), .25); }
.btn-primary:hover, .btn-primary:focus { background: var(--brand-dark); border-color: var(--brand-dark); }
.btn .ti { vertical-align: -2px; }

/* ================================================================== Forms */
.form-label { font-weight: 500; color: var(--txt-2); }
.form-control, .form-select { border-radius: var(--radius-sm); border-color: var(--border); background: var(--surface); }
.form-control:focus, .form-select:focus { border-color: var(--brand); box-shadow: 0 0 0 .2rem rgba(var(--brand-rgb), .15); }
.form-hint { color: var(--muted); font-size: 12px; }

/* ================================================================== Logs */
pre.logbox {
    background: #0b0e16; color: #cdd6e3; padding: 16px; border-radius: 12px;
    max-height: 460px; overflow: auto; font-size: 12.5px; line-height: 1.55;
    font-family: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
    border: 1px solid #1b2436;
}
.log-source-tabs { display: inline-flex; gap: 4px; background: var(--surface-2); border: 1px solid var(--border); border-radius: 10px; padding: 3px; }
.log-source-tabs button { border: none; background: none; font-size: 12.5px; font-weight: 600; color: var(--muted); padding: .3rem .7rem; border-radius: 7px; cursor: pointer; }
.log-source-tabs button.active { background: var(--surface); color: var(--brand); box-shadow: var(--shadow-sm); }
.log-source-tabs button:disabled { opacity: .5; cursor: default; }

/* ================================================================ Avatar */
.avatar-brand { background: linear-gradient(135deg, var(--brand) 0%, var(--brand-2) 100%); color: #fff; font-weight: 600; }

/* ============================================================ Empty state */
.empty { padding: 2.5rem 1rem; }
.empty-icon { font-size: 40px; color: color-mix(in srgb, var(--muted) 55%, transparent); }

/* ============================================================ Dropdowns */
.dropdown-menu { border-radius: 12px; border-color: var(--border); box-shadow: var(--shadow-md); }
.notif-empty { padding: 1.5rem 1rem; text-align: center; color: var(--muted); font-size: 13px; }

/* =========================================================== Danger zone */
.danger-zone { border: 1px solid color-mix(in srgb, #d63939 35%, var(--border)); border-radius: var(--radius); background: color-mix(in srgb, #d63939 5%, var(--surface)); }

/* ============================================================ Wizard */
.wizard-steps { display: flex; gap: 8px; flex-wrap: wrap; }
.wizard-step { display: flex; align-items: center; gap: 8px; padding: 8px 14px; border-radius: 999px;
    border: 1px solid var(--border); background: var(--surface); color: var(--muted); font-weight: 600; font-size: 13px; }
.wizard-step .ws-num { width: 22px; height: 22px; border-radius: 50%; display: grid; place-items: center;
    background: var(--surface-2); color: var(--muted); font-size: 12px; border: 1px solid var(--border); }
.wizard-step.active { border-color: var(--brand); color: var(--brand); box-shadow: 0 0 0 .18rem rgba(var(--brand-rgb),.12); }
.wizard-step.active .ws-num { background: var(--brand); color: #fff; border-color: var(--brand); }
.wizard-step.done { color: #2fb344; border-color: color-mix(in srgb,#2fb344 40%,var(--border)); }
.wizard-step.done .ws-num { background: #2fb344; color: #fff; border-color: #2fb344; }
.env-row .form-check-input { cursor: pointer; }

/* ============================================================ Responsivo */
@media (max-width: 992px) {
    .header-search { max-width: 220px; }
    .page-title { font-size: 1.35rem; }
}
@media (max-width: 576px) {
    .app-grid { grid-template-columns: 1fr; }
    .header-search { display: none !important; }
    .app-card-meta { grid-template-columns: 1fr 1fr; }
}
