* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    scrollbar-width: thin;
    scrollbar-color: #2a2a2a #0f0f0f;
}

*::-webkit-scrollbar {
    width: 4px;
}
*::-webkit-scrollbar-track {
    background: #0f0f0f;
}
*::-webkit-scrollbar-thumb {
    background: #2a2a2a;
    border-radius: 4px;
}
*::-webkit-scrollbar-thumb:hover {
    background: #c24a24;
}

body {
    font-family: "Manrope", sans-serif;
    font-size: 15px;
    line-height: 1.5;
    background: #111;
    color: #fff;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

/* ── TOPBAR ── */
.orc-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 44px;
    border-bottom: 1px solid #1a1a1a;
    background: #0f0f0f;
    position: sticky;
    top: 0;
    z-index: 100;
}

.orc-topbar-brand {
    display: flex;
    align-items: center;
    gap: 14px;
}

.orc-logo {
    font-family: "Manrope", sans-serif;
    font-size: 20px;
    font-weight: 800;
    letter-spacing: 0.4px;
    color: #fff;
    text-transform: uppercase;
}

.orc-topbar-sep {
    color: #2a2a2a;
    font-size: 19px;
}

.orc-topbar-label {
    font-size: 14px;
    color: #555;
    font-weight: 400;
}

.orc-topbar-actions {
    display: flex;
    gap: 11px;
}

/* ── BOTÕES ── */
.orc-btn-primary {
    background: #c24a24;
    color: #fff;
    border: none;
    padding: 11px 22px;
    border-radius: 4px;
    font-size: 14px;
    font-family: "Manrope", sans-serif;
    font-weight: 700;
    cursor: pointer;
    transition: background 0.2s;
}

.orc-btn-primary:hover {
    background: #9f351a;
}

.orc-btn-outline {
    background: transparent;
    color: #888;
    border: 1px solid #2a2a2a;
    padding: 11px 22px;
    border-radius: 4px;
    font-size: 14px;
    font-family: "Manrope", sans-serif;
    font-weight: 600;
    cursor: pointer;
    transition:
        border-color 0.2s,
        color 0.2s;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.orc-btn-outline:hover {
    border-color: #555;
    color: #ccc;
}

.orc-btn-outline.full,
.orc-btn-primary.full {
    width: 100%;
    text-align: center;
}

/* ── LAYOUT ── */
.orc-layout {
    display: grid;
    grid-template-columns: 60fr 40fr;
    gap: 26px;
    padding: 30px 44px;
    align-items: start;
    flex: 1;
}

/* ── COLUNA ESQUERDA ── */
.orc-col-left {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

/* ── COLUNA DIREITA ── */
.orc-col-right {
    display: flex;
    flex-direction: column;
    gap: 18px;
    position: sticky;
    top: 80px;
}

/* ── CARD BASE ── */
.orc-card {
    background: #0f0f0f;
    border: 1px solid #1a1a1a;
    border-radius: 4px;
    padding: 26px;
}

.orc-card-title {
    font-family: "Manrope", sans-serif;
    font-size: 17px;
    font-weight: 800;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 0.2px;
    margin-bottom: 20px;
}

/* ── ACCORDION ── */
.orc-accordion-section {
    padding: 0;
    overflow: hidden;
}

.orc-accordion-trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    background: transparent;
    border: 0;
    color: inherit;
    cursor: pointer;
    padding: 22px 26px;
    text-align: left;
}

.orc-accordion-trigger .orc-card-title {
    margin-bottom: 0;
}

.orc-accordion-icon {
    color: #c24a24;
    font-size: 21px;
    line-height: 1;
    transition: transform 0.2s;
}

.orc-accordion-section.open .orc-accordion-icon {
    transform: rotate(45deg);
}

.orc-accordion-panel {
    display: none;
    padding: 0 26px 26px;
}

.orc-accordion-section.open .orc-accordion-panel {
    display: block;
}

/* ── GRIDS ── */
.orc-grid-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.orc-grid-3 {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 16px;
}

/* ── FIELDS ── */
.orc-field {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.orc-field-mt {
    margin-top: 16px;
}

.orc-field label {
    font-size: 11.5px;
    font-weight: 700;
    color: #444;
    text-transform: uppercase;
    letter-spacing: 0.8px;
}

.orc-field input[type="text"],
.orc-field input[type="email"],
.orc-field input[type="number"],
.orc-field input[type="date"],
.orc-field textarea,
.orc-field select {
    background: #141414;
    border: 1px solid #222;
    border-radius: 4px;
    color: #ddd;
    font-family: "Manrope", sans-serif;
    font-size: 14px;
    min-height: 42px;
    padding: 11px 14px;
    outline: none;
    transition: border-color 0.2s;
    appearance: none;
    -webkit-appearance: none;
}

.orc-field textarea {
    resize: vertical;
    min-height: 82px;
    line-height: 1.55;
}

.orc-field input[readonly] {
    color: #666;
}

.orc-field input:focus,
.orc-field textarea:focus,
.orc-field select:focus {
    border-color: #c24a24;
}

.orc-field select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23555' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 36px;
}

/* ── STEPPER ── */
.orc-stepper {
    display: flex;
    align-items: center;
    gap: 0;
    background: #141414;
    border: 1px solid #222;
    border-radius: 4px;
    width: fit-content;
    overflow: hidden;
}

.stepper-btn {
    background: transparent;
    border: none;
    color: #666;
    font-size: 19px;
    width: 40px;
    height: 40px;
    cursor: pointer;
    transition:
        background 0.15s,
        color 0.15s;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

.stepper-btn:hover {
    background: #1e1e1e;
    color: #c24a24;
}

.stepper-btn.sm {
    width: 32px;
    height: 32px;
    font-size: 16px;
}

.stepper-val {
    min-width: 40px;
    text-align: center;
    font-size: 15px;
    color: #ddd;
    font-weight: 500;
    user-select: none;
}

/* ── MATERIAL GRID ── */
.orc-material-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

.orc-material-option input[type="radio"] {
    display: none;
}

.orc-material-card {
    display: flex;
    flex-direction: column;
    gap: 4px;
    background: #141414;
    border: 1px solid #222;
    border-radius: 4px;
    padding: 16px 18px;
    cursor: pointer;
    transition:
        border-color 0.2s,
        background 0.2s;
}

.orc-material-option input:checked + .orc-material-card {
    border-color: #c24a24;
    background: rgba(194, 74, 36, 0.08);
}

.orc-material-card:hover {
    border-color: #333;
}

.orc-material-name {
    font-size: 14px;
    font-weight: 500;
    color: #ddd;
}

.orc-material-desc {
    font-size: 12px;
    color: #444;
}

.orc-material-price {
    font-size: 13px;
    color: #c24a24;
    margin-top: 4px;
    font-weight: 500;
}

/* ── CHECKBOXES ── */
.orc-checkboxes {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-top: 18px;
}

.orc-check {
    display: flex;
    align-items: center;
    gap: 12px;
    cursor: pointer;
    font-size: 14px;
    color: #888;
    transition: color 0.2s;
}

.orc-check:hover {
    color: #ccc;
}

.orc-check input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: #c24a24;
    cursor: pointer;
    flex-shrink: 0;
}

.orc-check em {
    font-style: normal;
    color: #555;
    font-size: 12px;
}

.orc-check-qty {
    display: none;
    align-items: center;
    margin-left: 4px;
}

.orc-check-qty.visible {
    display: flex;
}

.orc-check-qty .orc-stepper {
    background: transparent;
    border: none;
}

/* ── PREVIEW PLACEHOLDER ── */
.orc-preview-card {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 280px;
}

.orc-preview-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    opacity: 0.35;
}

.orc-preview-placeholder svg {
    width: 52px;
    height: 52px;
}

.orc-preview-placeholder p {
    font-size: 15px;
    color: #aaa;
}

.orc-preview-placeholder span {
    font-size: 12px;
    color: #555;
}

/* ── RESUMO / ORÇAMENTO ── */
.orc-resumo-card {
}

.orc-resumo-linhas {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 18px;
}

.orc-resumo-linha {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 13px;
    color: #555;
}

.orc-resumo-linha span:last-child {
    color: #888;
    font-variant-numeric: tabular-nums;
}

.orc-resumo-divider {
    height: 1px;
    background: #1a1a1a;
    margin: 18px 0;
}

.orc-custo-bloco {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.orc-custo-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.orc-custo-label {
    font-size: 13px;
    color: #666;
}

.orc-custo-val {
    font-size: 18px;
    font-weight: 600;
    color: #ccc;
    font-variant-numeric: tabular-nums;
}

.orc-margem-row {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.orc-margem-label {
    font-size: 11.5px;
    color: #444;
    text-transform: uppercase;
    letter-spacing: 0.8px;
}

.orc-margem-controle {
    display: flex;
    align-items: center;
    gap: 14px;
}

.orc-margem-controle input[type="range"] {
    flex: 1;
    accent-color: #c24a24;
    cursor: pointer;
    height: 4px;
}

#margemVal {
    font-size: 13px;
    color: #c24a24;
    font-weight: 500;
    min-width: 36px;
    text-align: right;
}

.orc-venda-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: rgba(194, 74, 36, 0.08);
    border: 1px solid rgba(194, 74, 36, 0.34);
    border-radius: 4px;
    padding: 16px 18px;
    margin-top: 4px;
}

.orc-venda-label {
    font-size: 13px;
    color: #888;
}

.orc-venda-val {
    font-size: 25px;
    font-weight: 800;
    color: #c24a24;
    font-variant-numeric: tabular-nums;
}

.orc-resumo-actions {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 22px;
}

.orc-status-msg {
    min-height: 20px;
    margin-top: 14px;
    color: #8c8c8c;
    font-size: 13px;
    line-height: 1.4;
}

.orc-status-msg.success {
    color: #75b66a;
}

.orc-status-msg.error {
    color: #d36a52;
}

/* ── LISTA DE ORÇAMENTOS ── */
.orc-lista-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
}

.orc-badge {
    border: 1px solid rgba(194, 74, 36, 0.4);
    border-radius: 999px;
    color: #c24a24;
    font-size: 11px;
    letter-spacing: 0.6px;
    padding: 5px 9px;
    text-transform: uppercase;
    white-space: nowrap;
}

.orc-badge.muted {
    border-color: #343434;
    color: #777;
}

.orc-lista {
    display: flex;
    flex-direction: column;
    gap: 10px;
    max-height: 360px;
    overflow: auto;
}

.orc-lista-empty {
    border: 1px dashed #242424;
    border-radius: 4px;
    color: #555;
    font-size: 13px;
    line-height: 1.45;
    padding: 16px;
}

.orc-lista-item {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 9px 14px;
    width: 100%;
    background: #141414;
    border: 1px solid #222;
    border-radius: 4px;
    color: inherit;
    cursor: pointer;
    padding: 14px;
    text-align: left;
    transition:
        border-color 0.2s,
        background 0.2s;
}

.orc-lista-item:hover,
.orc-lista-item.active {
    border-color: #c24a24;
    background: rgba(194, 74, 36, 0.08);
}

.orc-lista-title {
    color: #ddd;
    font-size: 14px;
    font-weight: 600;
    overflow-wrap: anywhere;
}

.orc-lista-value {
    color: #c24a24;
    font-size: 13px;
    font-variant-numeric: tabular-nums;
    font-weight: 600;
    text-align: right;
}

.orc-lista-meta,
.orc-lista-date {
    color: #555;
    font-size: 12px;
    line-height: 1.4;
}

.orc-lista-date {
    text-align: right;
}

.orc-lista-actions {
    margin-top: 12px;
}

/* ── PÁGINA DE LISTAGEM ── */
.orc-list-page {
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding: 30px 44px;
}

.orc-list-toolbar {
    display: grid;
    grid-template-columns: auto minmax(220px, 1fr) 180px 180px;
    gap: 14px;
}

.orc-list-toolbar .orc-field {
    gap: 0;
}

.orc-list-table {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.orc-list-row {
    display: grid;
    grid-template-columns: 1.4fr 1fr 130px 140px 140px 112px;
    gap: 14px;
    align-items: center;
    background: #0f0f0f;
    border: 1px solid #1a1a1a;
    border-radius: 4px;
    padding: 16px;
}

.orc-list-row.header {
    color: #555;
    font-size: 12px;
    letter-spacing: 0.8px;
    text-transform: uppercase;
}

.orc-list-row:not(.header) {
    color: #aaa;
}

.orc-list-main {
    display: flex;
    flex-direction: column;
    gap: 5px;
    min-width: 0;
}

.orc-list-title {
    color: #eee;
    font-size: 15px;
    font-weight: 600;
    overflow-wrap: anywhere;
}

.orc-list-subtitle {
    color: #555;
    font-size: 13px;
    overflow-wrap: anywhere;
}

.orc-status-pill {
    border: 1px solid #2a2a2a;
    border-radius: 999px;
    color: #aaa;
    display: inline-flex;
    font-size: 12px;
    justify-content: center;
    padding: 6px 10px;
    text-transform: uppercase;
    width: fit-content;
}

.orc-status-pill.rascunho {
    border-color: #555;
    color: #aaa;
}

.orc-status-pill.enviado {
    border-color: #346a96;
    color: #68a9d8;
}

.orc-status-pill.aprovado {
    border-color: #3f7f39;
    color: #75b66a;
}

.orc-status-pill.em_producao,
.orc-status-pill.entregue {
    border-color: #346a96;
    color: #68a9d8;
}

.orc-status-pill.perdido,
.orc-status-pill.arquivado {
    border-color: #724131;
    color: #d36a52;
}

.orc-list-money {
    color: #c24a24;
    font-variant-numeric: tabular-nums;
    font-weight: 600;
}

.orc-list-actions-row {
    display: flex;
    gap: 9px;
    justify-content: flex-end;
    flex-wrap: wrap;
}

.orc-item-sections {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.orc-item-section {
    background: #111;
    border: 1px solid #1d1d1d;
    border-radius: 4px;
    padding: 18px;
}

.orc-item-section h3 {
    color: #ddd;
    font-family: "Manrope", sans-serif;
    font-size: 15px;
    font-weight: 800;
    letter-spacing: 0.2px;
    text-transform: uppercase;
}

.orc-item-add {
    align-items: end;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 132px auto;
    gap: 12px;
    margin-top: 16px;
}

.orc-budget-lines {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.orc-budget-line {
    align-items: center;
    background: #141414;
    border: 1px solid #222;
    border-radius: 4px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 118px auto auto;
    gap: 10px;
    padding: 12px;
}

.orc-budget-line strong,
.orc-budget-line span {
    display: block;
}

.orc-budget-line strong {
    color: #ddd;
    font-size: 13px;
}

.orc-budget-line span {
    color: #666;
    font-size: 12px;
}

.orc-budget-line > span {
    color: #c24a24;
    font-size: 13px;
    font-weight: 600;
    text-align: right;
}

.orc-qty-control {
    align-items: stretch;
    background: #101010;
    border: 1px solid #242424;
    border-radius: 4px;
    display: grid;
    grid-template-columns: 34px minmax(42px, 1fr) 34px;
    min-height: 42px;
    overflow: hidden;
}

.orc-qty-control button {
    align-items: center;
    background: #151515;
    border: 0;
    color: #777;
    cursor: pointer;
    display: flex;
    font-family: "Manrope", sans-serif;
    font-size: 17px;
    font-weight: 800;
    justify-content: center;
    line-height: 1;
    transition:
        background 0.15s,
        color 0.15s;
}

.orc-qty-control button:first-child {
    border-right: 1px solid #242424;
}

.orc-qty-control button:last-child {
    border-left: 1px solid #242424;
}

.orc-qty-control button:hover {
    background: rgba(194, 74, 36, 0.12);
    color: #c24a24;
}

.orc-qty-control input {
    background: transparent;
    border: 0;
    color: #ddd;
    font-family: "Manrope", sans-serif;
    font-size: 14px;
    font-weight: 600;
    min-width: 0;
    outline: none;
    padding: 0 8px;
    text-align: center;
}

.orc-login-page,
.orc-config-page {
    width: min(1100px, 100%);
    margin: 0 auto;
    padding: 52px 44px;
}

.orc-login-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

.orc-login-card {
    width: min(460px, 100%);
}

.orc-login-form {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.orc-login-form input[type="password"] {
    background: #141414;
    border: 1px solid #222;
    border-radius: 4px;
    color: #ddd;
    font-family: "Manrope", sans-serif;
    font-size: 15px;
    min-height: 44px;
    padding: 11px 14px;
    outline: none;
}

.orc-config-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.orc-config-section {
    border: 1px solid #1d1d1d;
    border-radius: 4px;
    padding: 18px;
    background: #111;
}

.orc-config-section legend {
    color: #ddd;
    font-family: "Manrope", sans-serif;
    font-size: 15px;
    font-weight: 800;
    letter-spacing: 0.2px;
    padding: 0 7px;
    text-transform: uppercase;
}

.orc-config-fields {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.orc-config-actions {
    display: flex;
    gap: 12px;
    justify-content: flex-end;
    margin-top: 20px;
}

/* ── DASHBOARD DE MÍDIA ── */
.orc-dashboard-shell {
    align-items: start;
    display: grid;
    flex: 1;
    gap: 24px;
    grid-template-columns: 220px minmax(0, 1fr);
    padding: 22px 44px 30px;
}

.orc-dashboard-sidebar {
    position: sticky;
    top: 90px;
}

.orc-dashboard-page {
    display: flex;
    flex-direction: column;
    gap: 12px;
    min-width: 0;
}

.orc-dashboard-head {
    align-items: start;
    display: grid;
    gap: 24px;
    grid-template-columns: minmax(0, 1fr) auto;
    padding-bottom: 8px;
}

.orc-dashboard-title-block .orc-card-title,
.orc-dashboard-grid .orc-card-title,
.orc-analysis-note .orc-card-title {
    margin-bottom: 0;
}

.orc-dashboard-title-block .orc-card-title {
    font-size: 22px;
}

.orc-dashboard-lead {
    color: #969696;
    font-size: 14px;
    margin-top: 6px;
    max-width: 720px;
}

.orc-dashboard-filters {
    align-items: end;
    background: rgba(15, 15, 15, 0.78);
    border: 1px solid #1c1c1c;
    border-radius: 4px;
    display: grid;
    gap: 10px;
    grid-template-columns: minmax(190px, 1fr) minmax(190px, 1fr) auto;
    min-width: min(520px, 100%);
    padding: 12px;
}

.orc-dashboard-filters .orc-btn-primary {
    background: #a43d20;
    min-height: 42px;
    padding-left: 18px;
    padding-right: 18px;
}

.orc-dashboard-filters .orc-btn-primary:hover {
    background: #c24a24;
}

.orc-dashboard-tabs {
    background: #0f0f0f;
    border: 1px solid #1a1a1a;
    border-radius: 4px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 8px;
}

.orc-dashboard-tabs button {
    align-items: center;
    background: transparent;
    border: 1px solid transparent;
    border-radius: 4px;
    color: #8b8b8b;
    cursor: pointer;
    display: flex;
    gap: 10px;
    font-family: "Manrope", sans-serif;
    font-size: 13px;
    font-weight: 800;
    min-height: 42px;
    padding: 11px 12px;
    text-align: left;
    text-transform: uppercase;
    transition:
        background 0.2s,
        border-color 0.2s,
        color 0.2s;
}

.orc-dashboard-tabs button span {
    align-items: center;
    background: #151515;
    border: 1px solid #282828;
    border-radius: 50%;
    color: #777;
    display: inline-flex;
    flex: 0 0 auto;
    font-size: 10px;
    height: 22px;
    justify-content: center;
    width: 22px;
}

.orc-dashboard-tabs button:hover,
.orc-dashboard-tabs button.active {
    background: rgba(194, 74, 36, 0.06);
    border-color: rgba(194, 74, 36, 0.5);
    color: #c24a24;
}

.orc-dashboard-tabs button:hover span,
.orc-dashboard-tabs button.active span {
    background: rgba(194, 74, 36, 0.14);
    border-color: rgba(194, 74, 36, 0.5);
    color: #d85d36;
}

.orc-dashboard-panel {
    display: none;
    flex-direction: column;
    gap: 14px;
}

.orc-dashboard-panel.active {
    display: flex;
}

.orc-dashboard-meta-row {
    color: #777;
    display: flex;
    font-size: 12px;
    gap: 16px;
    justify-content: space-between;
    line-height: 1.4;
    margin-top: -2px;
}

.orc-dashboard-alert {
    align-items: flex-start;
    background: rgba(194, 74, 36, 0.08);
    border: 1px solid rgba(194, 74, 36, 0.28);
    border-radius: 4px;
    color: #d9a08e;
    display: flex;
    gap: 12px;
    padding: 12px 14px;
}

.orc-alert-icon {
    align-items: center;
    background: rgba(194, 74, 36, 0.16);
    border: 1px solid rgba(194, 74, 36, 0.42);
    border-radius: 50%;
    color: #e06d45;
    display: inline-flex;
    flex: 0 0 auto;
    font-size: 12px;
    font-weight: 800;
    height: 22px;
    justify-content: center;
    width: 22px;
}

.orc-dashboard-alert strong {
    color: #f1c0b0;
    display: block;
    font-size: 13px;
    margin-bottom: 2px;
}

.orc-dashboard-alert p {
    color: #b98675;
    font-size: 12.5px;
    line-height: 1.45;
}

.orc-dashboard-metrics {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(auto-fit, minmax(165px, 1fr));
}

.orc-metric-card {
    background: #0f0f0f;
    border: 1px solid #1a1a1a;
    border-radius: 4px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-height: 116px;
    padding: 16px;
}

.orc-metric-card.emphasis {
    background: linear-gradient(180deg, rgba(194, 74, 36, 0.08), rgba(194, 74, 36, 0.035));
    border-color: rgba(194, 74, 36, 0.36);
}

.orc-metric-label {
    color: #767676;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.7px;
    text-transform: uppercase;
}

.orc-metric-card strong {
    color: #f4f4f4;
    font-size: 25px;
    font-variant-numeric: tabular-nums;
    font-weight: 800;
    line-height: 1.08;
    overflow-wrap: anywhere;
}

.orc-metric-card.emphasis strong {
    color: #d85d36;
}

.orc-metric-delta {
    font-size: 12px;
    font-variant-numeric: tabular-nums;
    font-weight: 700;
}

.orc-metric-delta.good {
    color: #75b66a;
}

.orc-metric-delta.bad {
    color: #d36a52;
}

.orc-metric-delta.muted {
    color: #555;
}

.orc-dashboard-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(280px, 0.8fr) minmax(0, 1.2fr);
}

.orc-dashboard-page > .orc-status-msg {
    color: #858585;
    margin-top: 0;
    min-height: 16px;
}

.orc-dashboard-grid.analysis {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.orc-dashboard-insight {
    color: #aaa;
    font-size: 14px;
    line-height: 1.6;
    margin-top: 18px;
}

.orc-dashboard-insight-list {
    display: grid;
    gap: 10px;
    margin-top: 18px;
}

.orc-dashboard-insight-list p {
    color: #b3b3b3;
    display: grid;
    font-size: 14px;
    gap: 10px;
    grid-template-columns: auto minmax(0, 1fr);
    line-height: 1.55;
}

.orc-dashboard-insight-list p span {
    background: #c24a24;
    border-radius: 50%;
    height: 5px;
    margin-top: 9px;
    width: 5px;
}

.orc-dashboard-funnel {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-top: 22px;
}

.orc-funnel-head {
    align-items: center;
    color: #838383;
    display: flex;
    font-size: 13px;
    justify-content: space-between;
    margin-bottom: 8px;
}

.orc-funnel-head strong {
    color: #c7c7c7;
    font-variant-numeric: tabular-nums;
}

.orc-funnel-bar {
    background: #1b1b1b;
    border-radius: 999px;
    height: 8px;
    overflow: hidden;
}

.orc-funnel-bar span {
    background: linear-gradient(90deg, #c24a24, #d85d36);
    border-radius: inherit;
    display: block;
    height: 100%;
}

.orc-campaign-table {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 18px;
}

.orc-campaign-row {
    align-items: center;
    background: #121212;
    border: 1px solid #202020;
    border-radius: 4px;
    color: #b5b5b5;
    display: grid;
    font-size: 13px;
    gap: 12px;
    grid-template-columns: minmax(150px, 1.25fr) 110px 100px 80px 70px 70px;
    padding: 13px 12px;
}

.orc-campaign-row.header {
    background: transparent;
    border-color: transparent;
    color: #777;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.7px;
    padding-bottom: 0;
    padding-top: 0;
    text-transform: uppercase;
}

.orc-campaign-row span:nth-child(n + 3) {
    font-variant-numeric: tabular-nums;
    text-align: right;
}

.orc-analysis-actions {
    display: grid;
    gap: 10px;
    margin-top: 22px;
}

.orc-analysis-actions span,
.orc-analysis-comment {
    background: #141414;
    border: 1px solid #222;
    border-radius: 4px;
    color: #888;
    font-size: 13px;
    line-height: 1.5;
    padding: 14px;
}

.orc-analysis-comments {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-top: 18px;
    max-height: 430px;
    overflow: auto;
}

.orc-analysis-comment {
    display: flex;
    flex-direction: column;
    gap: 7px;
}

.orc-analysis-comment span {
    color: #555;
    font-size: 12px;
}

.orc-analysis-comment strong {
    color: #ddd;
    font-size: 14px;
}

.orc-analysis-comment p {
    color: #888;
    font-size: 13px;
}

/* ══════════════════════════════════════
   RESPONSIVIDADE
══════════════════════════════════════ */

/* ── Tablet (≤ 900px): layout começa a apertar ── */
@media (max-width: 900px) {
    .orc-layout {
        grid-template-columns: 1fr;
        padding: 22px 26px;
    }

    .orc-col-right {
        position: static;
    }

    .orc-list-toolbar,
    .orc-list-row,
    .orc-dashboard-head,
    .orc-dashboard-grid,
    .orc-dashboard-grid.analysis {
        grid-template-columns: 1fr;
    }

    .orc-dashboard-shell {
        gap: 18px;
        grid-template-columns: 180px minmax(0, 1fr);
        padding: 20px 26px;
    }

    .orc-config-grid,
    .orc-config-fields,
    .orc-item-sections,
    .orc-item-add,
    .orc-budget-line,
    .orc-dashboard-filters {
        grid-template-columns: 1fr;
    }

    .orc-dashboard-head {
        align-items: start;
    }

    .orc-dashboard-meta-row {
        flex-direction: column;
        gap: 4px;
    }

    .orc-campaign-row {
        grid-template-columns: minmax(0, 1fr) repeat(3, minmax(64px, auto));
    }

    .orc-campaign-row span:nth-child(2) {
        display: none;
    }

    .orc-campaign-row span:nth-child(6) {
        display: none;
    }

    .orc-list-row.header {
        display: none;
    }

    .orc-campaign-row.header {
        display: none;
    }

    /* Esconde o preview placeholder — no mobile não faz sentido */
    .orc-preview-card {
        display: none;
    }

    /* Orçamento sobe para logo após a calculadora */
    .orc-col-right {
        order: 2;
    }
    .orc-col-left {
        order: 1;
    }
}

/* ── Mobile (≤ 600px) ── */
@media (max-width: 600px) {
    /* Topbar: esconde os dois botões, mostra só o salvar */
    .orc-topbar {
        padding: 16px 20px;
    }

    #btnNovo,
    #btnSalvarCopia {
        display: none;
    }

    .orc-topbar-label {
        display: none;
    }

    .orc-topbar-sep {
        display: none;
    }

    .orc-layout {
        padding: 16px;
        gap: 18px;
    }

    .orc-card {
        padding: 20px;
    }

    .orc-accordion-section {
        padding: 0;
    }

    .orc-accordion-trigger {
        padding: 20px;
    }

    .orc-accordion-panel {
        padding: 0 20px 20px;
    }

    .orc-list-page {
        padding: 16px;
    }

    .orc-dashboard-shell {
        display: flex;
        flex-direction: column;
        padding: 16px;
    }

    .orc-dashboard-sidebar {
        position: static;
        width: 100%;
    }

    .orc-dashboard-tabs {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .orc-dashboard-tabs button {
        text-align: center;
    }

    .orc-dashboard-title-block .orc-card-title {
        font-size: 19px;
    }

    .orc-login-page,
    .orc-config-page {
        padding: 16px;
    }

    .orc-topbar {
        align-items: flex-start;
        flex-direction: column;
        gap: 12px;
    }

    .orc-topbar-actions {
        width: 100%;
        overflow-x: auto;
    }

    /* Grids viram coluna única */
    .orc-grid-2,
    .orc-grid-3 {
        grid-template-columns: 1fr;
    }

    /* Material mantém 2 colunas — cabe bem */
    .orc-material-grid {
        grid-template-columns: 1fr 1fr;
    }

    /* Valor de venda em destaque maior */
    .orc-venda-val {
        font-size: 22px;
    }
}

/* ── Mobile pequeno (≤ 380px) ── */
@media (max-width: 380px) {
    .orc-material-grid {
        grid-template-columns: 1fr;
    }

    .orc-venda-val {
        font-size: 20px;
    }
}
