.admin-body { min-height: 100vh; display: grid; grid-template-columns: 260px 1fr; background: #050608; }
.admin-sidebar { position: sticky; top: 0; height: 100vh; border-right: 1px solid var(--border); background: rgba(7,8,11,.96); padding: 22px; display: flex; flex-direction: column; gap: 24px; }
.admin-logo img { width: 120px; display: block; margin: 0 auto; }
.admin-nav { display: grid; gap: 8px; }
.admin-nav a { padding: 13px 14px; border-radius: 12px; color: #ccc; }
.admin-nav a:hover, .admin-nav a.active { background: rgba(212,173,86,.12); color: var(--gold-2); }
.admin-user { margin-top: auto; border-top: 1px solid var(--border); padding-top: 18px; color: var(--muted); font-size: 13px; }
.admin-main { padding: 32px; width: min(1240px, 100%); }
.admin-header { display: flex; justify-content: space-between; align-items: center; gap: 18px; margin-bottom: 24px; }
.admin-header h1 { font-size: 32px; line-height: 1.1; margin: 0; }
.admin-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 22px; }
.metric-card, .admin-card { border: 1px solid var(--border); background: var(--panel); border-radius: 18px; padding: 20px; box-shadow: 0 16px 45px rgba(0,0,0,.22); }
.metric-card span { color: var(--muted); font-size: 13px; }
.metric-card b { display: block; color: #fff; font-size: 32px; margin-top: 6px; }
.table-wrap { overflow: auto; }
.admin-table { width: 100%; border-collapse: collapse; min-width: 780px; }
.admin-table th, .admin-table td { padding: 14px 12px; border-bottom: 1px solid var(--border); text-align: left; font-size: 14px; }
.admin-table th { color: var(--muted); font-size: 12px; text-transform: uppercase; letter-spacing: .08em; }
.admin-table tr:hover td { background: rgba(255,255,255,.025); }
.admin-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.btn-sm { padding: 9px 12px; border-radius: 10px; font-size: 12px; }
.detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.kv { display: grid; grid-template-columns: 140px 1fr; gap: 12px; font-size: 14px; }
.kv span { color: var(--muted); }
.admin-form { display: grid; gap: 16px; }
.admin-form .form-grid { margin: 0; }
.login-page { min-height: 100vh; display: grid; place-items: center; background: radial-gradient(circle at top, rgba(212,173,86,.14), transparent 45%), #050608; }
.login-card { width: min(430px, calc(100% - 28px)); border: 1px solid var(--border); background: var(--panel); border-radius: 24px; padding: 34px; box-shadow: var(--shadow); }
.login-card img { width: 150px; display: block; margin: 0 auto 18px; }
.login-card h1 { font-size: 24px; text-align: center; margin: 0 0 6px; }
.login-card p { color: var(--muted); text-align: center; }
.login-actions { display: flex; justify-content: center; margin-top: 18px; }
.login-actions .btn { min-width: 110px; }
.alert { border-radius: 12px; padding: 14px 16px; margin-bottom: 16px; background: rgba(207,71,71,.15); color: #ffabab; border: 1px solid rgba(207,71,71,.28); }
.success { background: rgba(29,168,72,.14); color: #9effba; border-color: rgba(29,168,72,.25); }
.drink-thumb { width: 58px; height: 48px; object-fit: cover; border-radius: 10px; }
.status-form { display: flex; gap: 8px; align-items: center; }
.status-form select { min-width: 190px; }
@media (max-width: 900px) {
    .admin-body { grid-template-columns: 1fr; }
    .admin-sidebar { position: relative; height: auto; }
    .admin-main { padding: 18px; }
    .admin-grid, .detail-grid { grid-template-columns: 1fr; }
}

/* Correções do catálogo e upload de imagens */
.admin-table { table-layout: fixed; }
.admin-table th, .admin-table td { vertical-align: middle; }
.admin-table th:nth-child(1), .admin-table td:nth-child(1) { width: 120px; }
.admin-table th:nth-child(2), .admin-table td:nth-child(2) { width: 240px; }
.admin-table th:nth-child(3), .admin-table td:nth-child(3) { width: 170px; }
.admin-table th:nth-child(4), .admin-table td:nth-child(4) { width: 150px; }
.admin-table .col-status, .admin-table .status-cell { width: 120px; text-align: center; }
.admin-table .col-actions, .admin-table .actions-cell { width: 250px; }
.admin-actions { display: flex; align-items: center; gap: 8px; flex-wrap: nowrap; }
.actions-cell { white-space: nowrap; }
.drink-thumb { width: 66px; height: 52px; object-fit: cover; border-radius: 12px; display: block; box-shadow: 0 8px 22px rgba(0,0,0,.35); }
.form-label { color: #f2f2f2; font-size: 14px; font-weight: 800; }
.upload-field { display: grid; gap: 8px; }
.image-preview-box {
    display: grid;
    grid-template-columns: 92px 1fr;
    gap: 14px;
    align-items: center;
    border: 1px solid var(--border);
    background: rgba(255,255,255,.045);
    border-radius: 14px;
    padding: 10px;
    min-height: 88px;
}
.image-preview-box img { width: 92px; height: 68px; object-fit: cover; border-radius: 11px; display: block; background: #050608; }
.image-preview-box strong { display: block; color: #fff; word-break: break-word; font-size: 13px; }
.image-preview-box small, .file-upload-label small { color: var(--muted); font-weight: 500; line-height: 1.45; }
.file-upload-label input[type="file"] {
    padding: 13px;
    cursor: pointer;
    background: rgba(255,255,255,.055);
}
.file-upload-label input[type="file"]::file-selector-button {
    border: 0;
    border-radius: 10px;
    background: linear-gradient(135deg, var(--gold), #b98728);
    color: #14100a;
    font-weight: 900;
    padding: 10px 14px;
    margin-right: 12px;
    cursor: pointer;
}
.checkbox-label { display:flex; align-items:center; gap:10px; margin-top:25px; }
.checkbox-label input { width:auto; accent-color: var(--gold); }
.admin-form .btn-animated { min-height: 52px; }
@media (max-width: 900px) {
    .admin-table { table-layout: auto; }
    .admin-actions { flex-wrap: wrap; }
    .image-preview-box { grid-template-columns: 1fr; }
    .image-preview-box img { width: 100%; height: 160px; }
}


/* Página de detalhes da solicitação - v3 */
.solicitation-header { align-items: flex-start; }
.breadcrumb-line { display:flex; align-items:center; gap:8px; color:var(--muted); font-size:13px; margin-bottom:8px; }
.breadcrumb-line a { color: var(--gold-2); }
.header-actions { display:flex; align-items:center; justify-content:flex-end; gap:10px; flex-wrap:wrap; }
.btn-whatsapp-admin { background: linear-gradient(135deg, #20c458, #13943d); color:#fff; border:0; }
.panel-kicker { display:block; color:var(--gold-2); text-transform:uppercase; letter-spacing:.12em; font-size:11px; font-weight:900; margin-bottom:6px; }
.pretty-card { position:relative; overflow:hidden; }
.pretty-card::before { content:""; position:absolute; inset:0; background: radial-gradient(circle at top right, rgba(212,173,86,.12), transparent 34%); pointer-events:none; }
.pretty-card > * { position:relative; z-index:1; }
.card-heading { display:flex; align-items:flex-start; justify-content:space-between; gap:14px; margin-bottom:18px; }
.card-heading h2 { margin:0; }
.status-panel { display:grid; grid-template-columns: 280px 1fr; gap:18px; align-items:center; margin-bottom:18px; }
.status-panel h2 { margin:0 0 6px; }
.status-actions { display:flex; justify-content:flex-end; gap:10px; flex-wrap:wrap; }
.status-action {
    border:1px solid rgba(255,255,255,.14);
    background:rgba(255,255,255,.055);
    color:#fff;
    border-radius:999px;
    padding:12px 15px;
    font-weight:900;
    cursor:pointer;
    transition:.2s ease;
}
.status-action:hover { transform:translateY(-2px); border-color:rgba(240,201,108,.55); color:var(--gold-2); }
.status-action.active { background:linear-gradient(135deg, var(--gold), #b98728); color:#14100a; border-color:transparent; box-shadow:0 12px 28px rgba(212,173,86,.18); }
.request-layout { display:grid; grid-template-columns: minmax(0, 1.15fr) minmax(360px, .85fr); gap:18px; align-items:start; }
.event-info-grid { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap:12px; }
.info-tile, .proposal-tile {
    border:1px solid rgba(255,255,255,.11);
    background:linear-gradient(180deg, rgba(255,255,255,.065), rgba(255,255,255,.025));
    border-radius:16px;
    padding:15px;
    min-height:76px;
}
.info-tile.wide, .info-tile.full { grid-column:1 / -1; }
.info-tile span, .proposal-tile span { display:block; color:var(--muted); font-size:12px; text-transform:uppercase; letter-spacing:.08em; margin-bottom:7px; }
.info-tile strong, .proposal-tile strong { color:#fff; font-size:15px; line-height:1.35; word-break:break-word; }
.info-tile .badge, .header-actions .badge { color:inherit; }
.request-drinks-list { display:grid; gap:12px; }
.request-drink-item {
    display:grid;
    grid-template-columns:64px 1fr auto;
    gap:14px;
    align-items:center;
    border:1px solid rgba(255,255,255,.11);
    background:linear-gradient(90deg, rgba(255,255,255,.065), rgba(255,255,255,.025));
    border-radius:18px;
    padding:10px 12px;
}
.request-drink-item img { width:64px; height:58px; border-radius:14px; object-fit:cover; box-shadow:0 10px 24px rgba(0,0,0,.35); }
.request-drink-item strong { display:block; color:#fff; font-size:15px; margin-bottom:4px; }
.request-drink-item small { color:var(--muted); }
.request-drink-item span {
    min-width:44px;
    height:36px;
    border-radius:999px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    color:#14100a;
    background:linear-gradient(135deg, var(--gold), #b98728);
    font-weight:900;
}
.proposal-card { margin-top:18px; }
.proposal-info-grid { display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap:12px; }
.proposal-tile.total { border-color:rgba(240,201,108,.38); background:radial-gradient(circle at top right, rgba(240,201,108,.15), rgba(255,255,255,.035)); }
.proposal-tile.total strong { color:var(--gold-2); font-size:24px; }
.badge { color:#111 !important; border:1px solid transparent; white-space:nowrap; }
.badge-warning { background:#ffd477 !important; color:#17110a !important; }
.badge-info { background:#91d8ff !important; color:#06121a !important; }
.badge-primary { background:#aebdff !important; color:#071034 !important; }
.badge-success { background:#8bf3b1 !important; color:#061d0f !important; }
.badge-danger { background:#ff9c9c !important; color:#2b0707 !important; }
.badge-secondary { background:#d8d8d8 !important; color:#111 !important; }
@media (max-width: 1050px) {
    .status-panel, .request-layout { grid-template-columns:1fr; }
    .status-actions { justify-content:flex-start; }
}
@media (max-width: 680px) {
    .header-actions { justify-content:flex-start; }
    .event-info-grid, .proposal-info-grid { grid-template-columns:1fr; }
    .request-drink-item { grid-template-columns:58px 1fr auto; }
    .request-drink-item img { width:58px; height:54px; }
}

/* Página de listagem de solicitações - v4 */
.requests-page-header {
    margin-bottom: 18px;
}
.request-metrics-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(115px, 1fr));
    gap: 16px;
    margin-bottom: 18px;
}
.request-metric-card {
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.11);
    background: linear-gradient(180deg, rgba(18,20,26,.98), rgba(12,13,17,.92));
    border-radius: 20px;
    padding: 20px;
    box-shadow: 0 18px 44px rgba(0,0,0,.22);
}
.request-metric-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at top right, rgba(212,173,86,.12), transparent 42%);
    opacity: .8;
    pointer-events: none;
}
.request-metric-card.highlight {
    border-color: rgba(240,201,108,.32);
    background: radial-gradient(circle at top right, rgba(240,201,108,.16), transparent 40%), linear-gradient(180deg, rgba(18,20,26,.98), rgba(12,13,17,.94));
}
.request-metric-card span,
.request-metric-card strong,
.request-metric-card small {
    position: relative;
    z-index: 1;
}
.request-metric-card span {
    display: block;
    color: var(--muted);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .1em;
    font-weight: 900;
}
.request-metric-card strong {
    display: block;
    color: #fff;
    font-size: 34px;
    line-height: 1;
    margin-top: 12px;
}
.request-metric-card small {
    display: block;
    color: #bdbdbd;
    margin-top: 9px;
    line-height: 1.35;
}
.requests-toolbar-card {
    margin-bottom: 18px;
}
.requests-toolbar {
    display: grid;
    grid-template-columns: minmax(280px, 1fr) 230px auto;
    gap: 14px;
    align-items: end;
}
.request-search-box,
.request-status-select {
    display: grid;
    gap: 7px;
}
.request-search-box span,
.request-status-select span {
    color: #efefef;
    font-size: 13px;
    font-weight: 900;
}
.toolbar-buttons {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.status-filter-pills {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid rgba(255,255,255,.08);
}
.status-filter-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.045);
    color: #eee;
    border-radius: 999px;
    padding: 10px 13px;
    font-size: 12px;
    font-weight: 900;
    transition: .2s ease;
}
.status-filter-pill b {
    min-width: 24px;
    height: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: rgba(255,255,255,.1);
    color: #fff;
    padding: 0 7px;
}
.status-filter-pill:hover,
.status-filter-pill.active {
    transform: translateY(-2px);
    border-color: rgba(240,201,108,.55);
    color: var(--gold-2);
    box-shadow: 0 12px 26px rgba(0,0,0,.22);
}
.status-filter-pill.active {
    background: rgba(212,173,86,.12);
}
.status-filter-pill.active b {
    background: linear-gradient(135deg, var(--gold), #b98728);
    color: #16100a;
}
.requests-list-card {
    border: 1px solid var(--border);
    background: linear-gradient(180deg, rgba(15,17,22,.95), rgba(10,11,15,.92));
    border-radius: 22px;
    padding: 20px;
    box-shadow: 0 18px 48px rgba(0,0,0,.24);
}
.requests-list-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 16px;
}
.requests-list-head h2 {
    margin: 2px 0 0;
    font-size: 22px;
}
.request-cards-list {
    display: grid;
    gap: 12px;
}
.request-row-card {
    position: relative;
    display: grid;
    grid-template-columns: minmax(310px, 1.06fr) minmax(520px, 1.55fr) minmax(112px, .36fr);
    grid-template-areas:
        "cliente dados status"
        "cliente dados acoes";
    column-gap: 16px;
    row-gap: 10px;
    align-items: center;
    border: 1px solid rgba(255,255,255,.105);
    background: linear-gradient(90deg, rgba(255,255,255,.055), rgba(255,255,255,.022));
    border-radius: 20px;
    padding: 16px;
    min-height: 122px;
    overflow: hidden;
    transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
.request-row-card::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 5px;
    background: rgba(255,255,255,.18);
}
.request-row-card:hover {
    transform: translateY(-3px);
    border-color: rgba(240,201,108,.32);
    box-shadow: 0 18px 42px rgba(0,0,0,.28);
    background: linear-gradient(90deg, rgba(255,255,255,.075), rgba(255,255,255,.03));
}
.status-border-novo::before { background: #ffd477; }
.status-border-em-atendimento::before { background: #91d8ff; }
.status-border-orcamento-enviado::before { background: #aebdff; }
.status-border-fechado::before { background: #8bf3b1; }
.status-border-cancelado::before { background: #ff9c9c; }
.request-client-block {
    grid-area: cliente;
    display: grid;
    grid-template-columns: 54px minmax(0, 1fr);
    gap: 13px;
    align-items: center;
    min-width: 0;
}
.request-client-block > div {
    min-width: 0;
}
.client-avatar {
    width: 54px;
    height: 54px;
    border-radius: 17px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: radial-gradient(circle at top, rgba(240,201,108,.42), rgba(212,173,86,.16));
    border: 1px solid rgba(240,201,108,.28);
    color: var(--gold-2);
    font-size: 22px;
    font-weight: 950;
    box-shadow: 0 12px 26px rgba(0,0,0,.25);
}
.request-id-line {
    color: var(--gold-2);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
    margin-bottom: 4px;
}
.request-client-block h3 {
    margin: 0;
    font-size: 17px;
    color: #fff;
    line-height: 1.25;
    white-space: normal;
    word-break: break-word;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    max-width: 100%;
}
.request-phone {
    display: inline-flex;
    color: #bdbdbd;
    font-size: 13px;
    margin-top: 5px;
}
.request-phone:hover {
    color: #8bf3b1;
}
.request-info-strip {
    grid-area: dados;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    min-width: 0;
}
.request-info-strip div {
    border: 1px solid rgba(255,255,255,.09);
    background: rgba(0,0,0,.14);
    border-radius: 14px;
    padding: 11px 12px;
    min-height: 66px;
}
.request-info-strip span,
.request-status-block small {
    display: block;
    color: var(--muted);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .08em;
    margin-bottom: 6px;
}
.request-info-strip strong {
    display: block;
    color: #fff;
    font-size: 13px;
    line-height: 1.35;
    overflow-wrap: anywhere;
}
.money-highlight {
    color: var(--gold-2) !important;
    font-size: 15px !important;
}
.request-status-block {
    grid-area: status;
    display: grid;
    justify-items: end;
    align-self: end;
    gap: 8px;
    min-width: 0;
}
.request-status-block small {
    margin: 0;
    line-height: 1.3;
    text-transform: none;
    letter-spacing: 0;
}
.request-row-actions {
    grid-area: acoes;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 8px;
    flex-wrap: nowrap;
    min-width: 0;
}
.mini-action {
    min-height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    padding: 10px 12px;
    font-size: 12px;
    font-weight: 950;
    border: 1px solid rgba(255,255,255,.14);
    background: rgba(255,255,255,.055);
    color: #fff;
    transition: .2s ease;
}
.mini-action:hover {
    transform: translateY(-2px);
    border-color: rgba(240,201,108,.55);
    color: var(--gold-2);
}
.mini-action.whatsapp {
    background: rgba(32,196,88,.12);
    border-color: rgba(32,196,88,.2);
    color: #9effba;
}
.mini-action.open {
    background: linear-gradient(135deg, var(--gold), #b98728);
    color: #14100a;
    border: 0;
}
.empty-state {
    display: grid;
    place-items: center;
    text-align: center;
    padding: 48px 20px;
    border: 1px dashed rgba(255,255,255,.15);
    border-radius: 18px;
    background: rgba(255,255,255,.025);
}
.empty-icon {
    width: 74px;
    height: 74px;
    border-radius: 24px;
    display: grid;
    place-items: center;
    background: rgba(212,173,86,.12);
    font-size: 34px;
    margin-bottom: 14px;
}
.empty-state h3 {
    margin: 0;
    font-size: 22px;
}
.empty-state p {
    margin: 8px 0 18px;
}
@media (max-width: 1280px) {
    .request-row-card {
        grid-template-columns: minmax(280px, 1fr) minmax(390px, 1.35fr) minmax(110px, .38fr);
    }
    .request-info-strip { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 1180px) {
    .request-metrics-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .request-row-card {
        grid-template-columns: 1fr;
        grid-template-areas:
            "cliente"
            "dados"
            "status"
            "acoes";
        align-items: stretch;
    }
    .request-status-block { justify-items: start; }
    .request-row-actions { justify-content: flex-start; }
}
@media (max-width: 760px) {
    .requests-toolbar { grid-template-columns: 1fr; }
    .request-metrics-grid { grid-template-columns: 1fr; }
    .requests-list-head { display: grid; }
    .request-info-strip { grid-template-columns: 1fr; }
    .request-row-card { padding: 14px; border-radius: 18px; }
    .request-client-block h3 { white-space: normal; }
    .mini-action { flex: 1; }
}


/* Dashboard premium com gráficos - v6 */
.dashboard-header { margin-bottom: 18px; }
.dashboard-filter-card {
    display: grid;
    grid-template-columns: minmax(220px, .42fr) 1fr;
    gap: 18px;
    align-items: end;
    margin-bottom: 18px;
    position: relative;
    overflow: hidden;
}
.dashboard-filter-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at top right, rgba(212,173,86,.12), transparent 36%);
    pointer-events: none;
}
.dashboard-filter-card > * { position: relative; z-index: 1; }
.dashboard-filter-card h2 { margin: 0; }
.dashboard-period-form {
    display: grid;
    grid-template-columns: 1fr 150px 150px auto;
    gap: 12px;
    align-items: end;
}
.period-pills {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.period-pill {
    min-height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 11px 14px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.045);
    color: #eee;
    font-weight: 900;
    font-size: 12px;
    transition: .2s ease;
}
.period-pill:hover,
.period-pill.active {
    transform: translateY(-2px);
    border-color: rgba(240,201,108,.55);
    color: var(--gold-2);
    background: rgba(212,173,86,.1);
}
.dashboard-period-form label {
    gap: 6px;
    font-size: 12px;
    color: var(--muted);
}
.dashboard-period-form label span {
    color: #efefef;
    font-weight: 900;
}
.dashboard-period-form input[type="date"] { min-height: 42px; padding: 10px 12px; }
.dashboard-metrics-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(115px, 1fr));
    gap: 16px;
    margin-bottom: 18px;
}
.dashboard-metric-card {
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.11);
    background: linear-gradient(180deg, rgba(18,20,26,.98), rgba(10,11,15,.94));
    border-radius: 20px;
    padding: 20px;
    box-shadow: 0 18px 44px rgba(0,0,0,.22);
    min-height: 138px;
}
.dashboard-metric-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at top right, rgba(212,173,86,.13), transparent 42%);
    pointer-events: none;
}
.dashboard-metric-card.primary { border-color: rgba(240,201,108,.28); }
.dashboard-metric-card.success::before { background: radial-gradient(circle at top right, rgba(139,243,177,.15), transparent 42%); }
.dashboard-metric-card.money { border-color: rgba(240,201,108,.34); }
.dashboard-metric-card.money::before { background: radial-gradient(circle at top right, rgba(240,201,108,.19), transparent 42%); }
.dashboard-metric-card span,
.dashboard-metric-card strong,
.dashboard-metric-card small { position: relative; z-index: 1; }
.dashboard-metric-card span {
    display: block;
    color: var(--muted);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .1em;
    font-weight: 950;
}
.dashboard-metric-card strong {
    display: block;
    color: #fff;
    font-size: clamp(26px, 2.4vw, 34px);
    line-height: 1;
    margin-top: 14px;
    word-break: break-word;
}
.dashboard-metric-card.money strong,
.dashboard-metric-card.success strong { color: var(--gold-2); }
.dashboard-metric-card small {
    display: block;
    color: #bdbdbd;
    margin-top: 10px;
    line-height: 1.35;
}
.dashboard-charts-grid {
    display: grid;
    grid-template-columns: 1.35fr .85fr;
    gap: 18px;
    margin-bottom: 18px;
}
.dashboard-chart-card {
    overflow: hidden;
    min-height: 330px;
}
.dashboard-chart-card.wide { grid-row: span 2; }
.chart-title-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 18px;
}
.chart-title-row h2 { margin: 0; }
.chart-title-row small {
    color: var(--gold-2);
    border: 1px solid rgba(240,201,108,.25);
    background: rgba(212,173,86,.08);
    padding: 8px 10px;
    border-radius: 999px;
    font-weight: 900;
    white-space: nowrap;
}
.vertical-chart {
    min-height: 300px;
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(42px, 1fr);
    align-items: end;
    gap: 12px;
    padding: 22px 4px 0;
    border-top: 1px solid rgba(255,255,255,.08);
    overflow-x: auto;
}
.chart-bar-wrap {
    min-width: 42px;
    height: 270px;
    display: grid;
    grid-template-rows: 1fr auto;
    gap: 10px;
    align-items: end;
    text-align: center;
}
.chart-bar {
    position: relative;
    height: var(--bar-height);
    min-height: 28px;
    border-radius: 14px 14px 7px 7px;
    background: linear-gradient(180deg, var(--gold-2), #b98728);
    box-shadow: 0 12px 28px rgba(212,173,86,.17);
    transition: .22s ease;
}
.chart-bar:hover { transform: translateY(-4px); filter: brightness(1.08); }
.chart-bar span {
    position: absolute;
    top: -26px;
    left: 50%;
    transform: translateX(-50%);
    color: #fff;
    font-size: 12px;
    font-weight: 950;
}
.chart-bar-wrap b {
    color: var(--muted);
    font-size: 11px;
    font-weight: 900;
    white-space: nowrap;
}
.status-funnel-list,
.package-bars-list { display: grid; gap: 14px; }
.funnel-item,
.package-bar-item {
    border: 1px solid rgba(255,255,255,.1);
    background: linear-gradient(90deg, rgba(255,255,255,.055), rgba(255,255,255,.025));
    border-radius: 16px;
    padding: 13px;
}
.funnel-line,
.package-bar-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 10px;
}
.funnel-line strong,
.package-bar-head strong { color: #fff; font-size: 14px; }
.funnel-line span,
.package-bar-head span {
    color: var(--gold-2);
    font-weight: 950;
    white-space: nowrap;
}
.funnel-progress,
.package-progress {
    height: 10px;
    border-radius: 999px;
    overflow: hidden;
    background: rgba(255,255,255,.08);
    margin-bottom: 8px;
}
.funnel-progress i,
.package-progress i {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--gold), var(--gold-2));
}
.funnel-item small,
.package-bar-item small { color: var(--muted); font-size: 12px; }
.package-progress i { background: linear-gradient(90deg, #8bf3b1, var(--gold-2)); }
.dashboard-recent-card { margin-bottom: 28px; }
.dashboard-recent-list { display: grid; gap: 12px; }
.dashboard-recent-item {
    display: grid;
    grid-template-columns: minmax(220px, .85fr) minmax(420px, 1.4fr) 150px;
    gap: 16px;
    align-items: center;
    border: 1px solid rgba(255,255,255,.105);
    background: linear-gradient(90deg, rgba(255,255,255,.055), rgba(255,255,255,.022));
    border-radius: 20px;
    padding: 15px;
    transition: .2s ease;
}
.dashboard-recent-item:hover {
    transform: translateY(-2px);
    border-color: rgba(240,201,108,.32);
    box-shadow: 0 18px 42px rgba(0,0,0,.25);
}
.dashboard-recent-info {
    display: grid;
    grid-template-columns: repeat(4, minmax(115px, 1fr));
    gap: 10px;
}
.dashboard-recent-info div {
    border: 1px solid rgba(255,255,255,.09);
    background: rgba(0,0,0,.14);
    border-radius: 14px;
    padding: 11px 12px;
    min-height: 62px;
}
.dashboard-recent-info span {
    display: block;
    color: var(--muted);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .08em;
    margin-bottom: 6px;
}
.dashboard-recent-info strong {
    display: block;
    color: #fff;
    font-size: 13px;
    line-height: 1.35;
}
.dashboard-recent-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 9px;
    flex-wrap: wrap;
}
.empty-state.mini {
    padding: 28px 18px;
}
.empty-state.mini .empty-icon {
    width: 58px;
    height: 58px;
    border-radius: 18px;
    font-size: 26px;
}
@media (max-width: 1180px) {
    .dashboard-filter-card,
    .dashboard-period-form,
    .dashboard-charts-grid { grid-template-columns: 1fr; }
    .dashboard-metrics-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .dashboard-chart-card.wide { grid-row: auto; }
    .dashboard-recent-item { grid-template-columns: 1fr; }
    .dashboard-recent-actions { justify-content: flex-start; }
}
@media (max-width: 760px) {
    .dashboard-metrics-grid,
    .dashboard-recent-info { grid-template-columns: 1fr; }
    .period-pills { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .period-pill { width: 100%; }
    .vertical-chart { grid-auto-columns: minmax(46px, 58px); }
    .chart-title-row { display: grid; }
}


/* Dashboard line chart */
.line-chart-wrap {
    position: relative;
    border-top: 1px solid rgba(255,255,255,.08);
    padding-top: 16px;
}
.line-chart-legend {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
    margin-bottom: 10px;
    color: #fff;
    font-weight: 900;
}
.line-chart-legend span {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    font-size: 13px;
}
.line-chart-legend small {
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
    margin-left: auto;
}
.legend-dot {
    width: 11px;
    height: 11px;
    border-radius: 999px;
    display: inline-block;
    box-shadow: 0 0 0 4px rgba(255,255,255,.05);
}
.legend-dot.total { background: var(--gold-2); }
.legend-dot.closed { background: #8bf3b1; }
.line-chart-scroll {
    width: 100%;
    overflow: visible;
    padding-bottom: 0;
}
.line-chart-svg {
    display: block;
    width: 100%;
    height: 360px;
    min-width: 0;
    max-width: 100%;
    background: radial-gradient(circle at 18% 8%, rgba(240,201,108,.08), transparent 30%), linear-gradient(180deg, rgba(255,255,255,.018), rgba(255,255,255,0));
    border-radius: 18px;
}
.chart-grid-line {
    stroke: rgba(255,255,255,.09);
    stroke-width: 1;
    stroke-dasharray: 5 7;
}
.chart-axis-main {
    stroke: rgba(255,255,255,.18);
    stroke-width: 1.3;
}
.chart-axis-label {
    fill: rgba(255,255,255,.62);
    font-size: 12px;
    font-weight: 900;
}
.chart-axis-label.x {
    fill: rgba(255,255,255,.72);
    font-size: 11px;
}
.chart-line {
    fill: none;
    stroke-width: 4;
    stroke-linecap: round;
    stroke-linejoin: round;
    filter: url(#softGlow);
}
.total-line { stroke: var(--gold-2); }
.closed-line { stroke: #8bf3b1; stroke-width: 3; opacity: .95; }
.chart-point {
    cursor: pointer;
    stroke-width: 3;
    transition: .18s ease;
}
.total-point {
    fill: var(--gold-2);
    stroke: rgba(8,8,10,.96);
}
.closed-point {
    fill: #8bf3b1;
    stroke: rgba(8,8,10,.96);
}
.chart-point:hover {
    r: 9;
    filter: drop-shadow(0 0 10px rgba(240,201,108,.55));
}
.line-chart-tooltip {
    position: absolute;
    z-index: 20;
    min-width: 190px;
    pointer-events: none;
    opacity: 0;
    transform: translateY(6px);
    transition: opacity .14s ease, transform .14s ease;
    border: 1px solid rgba(240,201,108,.34);
    background: linear-gradient(180deg, rgba(22,23,28,.98), rgba(8,9,13,.98));
    box-shadow: 0 18px 46px rgba(0,0,0,.42);
    border-radius: 16px;
    padding: 12px 13px;
    color: #fff;
}
.line-chart-tooltip.show {
    opacity: 1;
    transform: translateY(0);
}
.line-chart-tooltip strong {
    display: block;
    color: var(--gold-2);
    font-size: 13px;
    margin-bottom: 8px;
}
.line-chart-tooltip span {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    color: var(--muted);
    font-size: 12px;
    line-height: 1.55;
}
.line-chart-tooltip b {
    color: #fff;
    font-weight: 950;
}
@media (max-width: 760px) {
    .line-chart-legend small { width: 100%; margin-left: 0; }
    .line-chart-svg { height: 320px; }
    .chart-axis-label.x { font-size: 10px; }
}


/* Correção v13 - listagem de solicitações sem sobreposição + botão excluir */
.admin-alert {
    border: 1px solid rgba(139, 243, 177, .28);
    background: rgba(32, 196, 88, .10);
    color: #baffcf;
    padding: 13px 16px;
    border-radius: 14px;
    margin: 0 0 16px;
    font-weight: 800;
}

.request-row-card {
    grid-template-columns: minmax(320px, 1fr) minmax(470px, 1.45fr) 174px !important;
    grid-template-areas: "cliente dados lateral" !important;
    align-items: center !important;
    gap: 16px !important;
    min-height: 126px;
    overflow: visible;
}

.request-client-block {
    grid-area: cliente !important;
}

.request-info-strip {
    grid-area: dados !important;
    grid-template-columns: 1.05fr .9fr 1fr 1fr !important;
    min-width: 0;
}

.request-info-strip div {
    min-width: 0;
    min-height: 74px;
}

.request-info-strip strong {
    overflow-wrap: normal;
    word-break: normal;
}

.request-side-panel {
    grid-area: lateral;
    display: grid;
    gap: 10px;
    justify-items: stretch;
    align-items: center;
    min-width: 174px;
}

.request-status-block {
    grid-area: auto !important;
    justify-items: end !important;
    align-self: auto !important;
    gap: 6px !important;
}

.request-status-block .status-badge,
.request-status-block .badge {
    white-space: nowrap;
}

.request-status-block small {
    white-space: nowrap;
    font-size: 11px;
    color: #b9bdc7;
}

.request-row-actions {
    grid-area: auto !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 8px !important;
    justify-content: stretch !important;
    align-items: stretch !important;
    flex-wrap: initial !important;
}

.request-row-actions .mini-action,
.request-row-actions button.mini-action {
    width: 100%;
    min-height: 38px;
    padding: 9px 10px;
    border-radius: 11px;
    cursor: pointer;
    font-family: inherit;
    line-height: 1;
}

.delete-request-form {
    grid-column: 1 / -1;
    display: block;
    margin: 0;
}

.mini-action.delete {
    background: rgba(255, 87, 87, .12);
    border-color: rgba(255, 87, 87, .28);
    color: #ffb3b3;
}

.mini-action.delete:hover {
    color: #fff;
    border-color: rgba(255, 87, 87, .55);
    background: rgba(255, 87, 87, .22);
}

@media (max-width: 1360px) {
    .request-row-card {
        grid-template-columns: minmax(280px, 1fr) minmax(390px, 1.35fr) 174px !important;
    }
    .request-info-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 1180px) {
    .request-row-card {
        grid-template-columns: 1fr !important;
        grid-template-areas:
            "cliente"
            "dados"
            "lateral" !important;
        align-items: stretch !important;
    }

    .request-side-panel {
        grid-template-columns: 1fr auto;
        align-items: center;
        min-width: 0;
    }

    .request-status-block {
        justify-items: start !important;
    }

    .request-row-actions {
        min-width: 260px;
    }
}

@media (max-width: 760px) {
    .request-side-panel {
        grid-template-columns: 1fr;
    }

    .request-row-actions {
        min-width: 0;
        grid-template-columns: 1fr;
    }

    .delete-request-form {
        grid-column: auto;
    }
}


/* Modal personalizado do painel - v14 */
body.modal-open {
    overflow: hidden;
}

.site-modal-backdrop {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: grid;
    place-items: center;
    padding: 24px;
    background:
        radial-gradient(circle at center, rgba(212,173,86,.14), transparent 32%),
        rgba(0,0,0,.72);
    opacity: 0;
    pointer-events: none;
    transition: opacity .2s ease;
    backdrop-filter: blur(8px);
}

.site-modal-backdrop.is-open {
    opacity: 1;
    pointer-events: auto;
}

.site-modal {
    position: relative;
    width: min(480px, 100%);
    border-radius: 24px;
    padding: 28px;
    border: 1px solid rgba(240,201,108,.28);
    background:
        linear-gradient(180deg, rgba(28,29,34,.98), rgba(10,11,14,.98)),
        radial-gradient(circle at top right, rgba(212,173,86,.18), transparent 38%);
    box-shadow: 0 32px 90px rgba(0,0,0,.58);
    transform: translateY(12px) scale(.96);
    transition: transform .22s ease;
    color: #fff;
}

.site-modal-backdrop.is-open .site-modal {
    transform: translateY(0) scale(1);
}

.site-modal-close {
    position: absolute;
    top: 14px;
    right: 14px;
    width: 38px;
    height: 38px;
    border-radius: 13px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.06);
    color: #fff;
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
    transition: .18s ease;
}

.site-modal-close:hover {
    color: var(--gold-2);
    border-color: rgba(240,201,108,.42);
    transform: translateY(-1px);
}

.site-modal-icon {
    width: 58px;
    height: 58px;
    border-radius: 19px;
    display: grid;
    place-items: center;
    margin-bottom: 16px;
    font-size: 28px;
    font-weight: 950;
}

.site-modal-icon.danger {
    color: #ffd4d4;
    background: rgba(255,87,87,.13);
    border: 1px solid rgba(255,87,87,.28);
    box-shadow: 0 15px 32px rgba(255,87,87,.10);
}

.site-modal h2 {
    margin: 6px 0 8px;
    font-size: 26px;
}

.site-modal p {
    margin: 0;
    color: #c9cbd3;
    line-height: 1.55;
}

.site-modal p strong {
    color: #fff;
}

.site-modal-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 24px;
    flex-wrap: wrap;
}

.btn-danger-site {
    background: linear-gradient(135deg, #ff6969, #bd3333);
    color: #fff;
    border: 0;
    box-shadow: 0 16px 34px rgba(255,87,87,.18);
}

.btn-danger-site:hover {
    filter: brightness(1.08);
    transform: translateY(-2px);
}

.btn-danger-site:disabled {
    opacity: .65;
    cursor: wait;
    transform: none;
}

@media (max-width: 520px) {
    .site-modal {
        padding: 24px 20px;
    }

    .site-modal-actions {
        display: grid;
        grid-template-columns: 1fr;
    }

    .site-modal-actions .btn {
        width: 100%;
    }
}


/* Novo orçamento pelo admin - v15 */
.quote-header {
    align-items: flex-start;
}

.section-headline {
    margin-bottom: 18px;
}

.section-headline h2 {
    margin: 4px 0 0;
    font-size: 24px;
}

.section-headline.with-actions {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: end;
}

.quote-help {
    color: var(--muted);
    font-size: 13px;
}

.quote-admin-form {
    display: grid;
    gap: 18px;
}

.quote-section {
    position: relative;
    overflow: hidden;
}

.quote-section::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at top right, rgba(212,173,86,.08), transparent 36%);
    pointer-events: none;
}

.quote-section > * {
    position: relative;
    z-index: 1;
}

.quote-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 15px;
}

.quote-form-grid label,
.quote-observations {
    display: grid;
    gap: 8px;
}

.quote-form-grid span,
.quote-observations span {
    color: #fff;
    font-size: 13px;
    font-weight: 850;
}

.quote-form-grid input,
.quote-observations textarea {
    width: 100%;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.045);
    color: #fff;
    border-radius: 13px;
    padding: 14px 15px;
    outline: none;
    transition: .18s ease;
}

.quote-form-grid input:focus,
.quote-observations textarea:focus {
    border-color: rgba(240,201,108,.55);
    box-shadow: 0 0 0 4px rgba(240,201,108,.08);
}

.quote-choice-grid {
    display: grid;
    grid-template-columns: .9fr 1.1fr;
    gap: 18px;
}

.quote-choice-grid h3 {
    margin: 0 0 12px;
    font-size: 16px;
}

.quote-radio-cards {
    display: grid;
    gap: 10px;
}

.quote-radio-cards.package {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.quote-option-card {
    position: relative;
    display: grid;
    gap: 6px;
    min-height: 118px;
    padding: 16px;
    border: 1px solid rgba(255,255,255,.11);
    background: linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025));
    border-radius: 16px;
    cursor: pointer;
    transition: .2s ease;
}

.quote-option-card:hover {
    transform: translateY(-2px);
    border-color: rgba(240,201,108,.32);
}

.quote-option-card.featured {
    border-color: rgba(240,201,108,.28);
    background: linear-gradient(180deg, rgba(212,173,86,.14), rgba(255,255,255,.035));
}

.quote-option-card input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.quote-option-card:has(input:checked) {
    border-color: rgba(240,201,108,.72);
    box-shadow: 0 18px 40px rgba(212,173,86,.10), inset 0 0 0 1px rgba(240,201,108,.2);
}

.quote-option-card strong {
    color: #fff;
    font-size: 15px;
}

.quote-option-card span {
    color: var(--muted);
    font-size: 12px;
    line-height: 1.35;
}

.quote-option-card small {
    color: var(--gold-2);
    font-weight: 900;
}

.quote-drinks-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.quote-drink-card {
    display: grid;
    grid-template-rows: 150px 1fr auto;
    border: 1px solid rgba(255,255,255,.105);
    background: linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.024));
    border-radius: 18px;
    overflow: hidden;
    transition: .2s ease;
}

.quote-drink-card:hover {
    transform: translateY(-3px);
    border-color: rgba(240,201,108,.32);
    box-shadow: 0 18px 42px rgba(0,0,0,.25);
}

.quote-drink-card img {
    width: 100%;
    height: 150px;
    object-fit: cover;
    background: rgba(255,255,255,.04);
}

.quote-drink-body {
    padding: 14px 14px 10px;
}

.quote-drink-body span {
    color: var(--gold-2);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .08em;
    font-weight: 950;
}

.quote-drink-body h3 {
    margin: 5px 0 7px;
    font-size: 16px;
    color: #fff;
}

.quote-drink-body p {
    margin: 0;
    min-height: 38px;
    color: var(--muted);
    font-size: 12px;
    line-height: 1.4;
}

.quote-qty-control {
    display: grid;
    grid-template-columns: 42px 1fr 42px;
    gap: 6px;
    padding: 12px 14px 14px;
}

.quote-qty-control button,
.quote-qty-control input {
    height: 40px;
    border-radius: 11px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(0,0,0,.16);
    color: #fff;
    text-align: center;
    font-weight: 950;
}

.quote-qty-control button {
    cursor: pointer;
    color: var(--gold-2);
    transition: .18s ease;
}

.quote-qty-control button:hover {
    background: rgba(212,173,86,.14);
    border-color: rgba(240,201,108,.38);
}

.quote-final-section {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: 18px;
    align-items: end;
}

.quote-observations {
    margin-top: 16px;
}

.quote-summary-box {
    border: 1px solid rgba(240,201,108,.25);
    background: linear-gradient(180deg, rgba(212,173,86,.13), rgba(255,255,255,.035));
    border-radius: 20px;
    padding: 22px;
    box-shadow: 0 18px 48px rgba(0,0,0,.24);
}

.quote-summary-box span {
    display: block;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .08em;
    font-size: 12px;
    font-weight: 900;
}

.quote-summary-box strong {
    display: block;
    margin: 8px 0 6px;
    color: var(--gold-2);
    font-size: 34px;
}

.quote-summary-box small {
    display: block;
    color: #d8d8d8;
    line-height: 1.45;
    margin-bottom: 18px;
}

@media (max-width: 1180px) {
    .quote-choice-grid,
    .quote-final-section {
        grid-template-columns: 1fr;
    }

    .quote-radio-cards.package,
    .quote-drinks-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 720px) {
    .quote-form-grid,
    .quote-radio-cards.package,
    .quote-drinks-grid {
        grid-template-columns: 1fr;
    }

    .section-headline.with-actions {
        display: grid;
    }
}


/* v19 - botão para reenviar orçamento */
.solicitation-header .header-actions {
    flex-wrap: wrap;
    justify-content: flex-end;
}

.solicitation-header .btn-gold {
    white-space: nowrap;
}

@media (max-width: 900px) {
    .solicitation-header .header-actions {
        justify-content: flex-start;
    }

    .solicitation-header .header-actions .btn {
        width: 100%;
    }
}


/* v21 - módulos comerciais premium */
.admin-alert.warning {
    border: 1px solid rgba(240,201,108,.35);
    background: rgba(212,173,86,.11);
    color: #ffe2a2;
    padding: 14px 16px;
    border-radius: 14px;
    margin: 0 0 16px;
}
.admin-alert.warning span {
    display: inline-flex;
    margin-left: 8px;
    padding: 4px 8px;
    border-radius: 999px;
    background: rgba(255,255,255,.07);
}

.quote-addons-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}
.quote-addon-card {
    display: grid;
    grid-template-columns: 1fr 132px;
    gap: 12px;
    align-items: center;
    border: 1px solid rgba(255,255,255,.105);
    background: linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.024));
    border-radius: 18px;
    padding: 16px;
}
.quote-addon-card strong { color:#fff; font-size:15px; }
.quote-addon-card p { color: var(--muted); margin: 6px 0 8px; font-size: 12px; line-height: 1.4; }
.quote-addon-card small { color: var(--gold-2); font-weight: 900; }
.quote-qty-control.compact { padding: 0; grid-template-columns: 36px 1fr 36px; }
.quote-qty-control.compact button,
.quote-qty-control.compact input { height: 36px; }

.quick-message-panel {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 18px;
    align-items: center;
    margin-bottom: 18px;
}
.quick-message-panel h2 { margin: 4px 0 6px; }
.quick-message-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
}
.quick-message-actions .mini-action { min-width: 118px; }

.admin-two-columns {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
    margin-top: 18px;
}
.finance-form, .history-form {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}
.finance-form label, .history-form label {
    display: grid;
    gap: 7px;
}
.finance-form label span, .history-form label span,
.admin-form label span {
    color: #fff;
    font-size: 13px;
    font-weight: 850;
}
.finance-form input, .finance-form select, .finance-form textarea,
.history-form input, .history-form textarea,
.admin-form input, .admin-form select, .admin-form textarea {
    width: 100%;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.045);
    color: #fff;
    border-radius: 13px;
    padding: 13px 14px;
    outline: none;
}
.finance-form .full, .history-form .full,
.admin-form .full { grid-column: 1 / -1; }
.finance-form button, .history-form button { grid-column: 1 / -1; }

.history-timeline {
    display: grid;
    gap: 10px;
    margin-top: 16px;
    max-height: 360px;
    overflow: auto;
    padding-right: 6px;
}
.history-timeline article {
    border: 1px solid rgba(255,255,255,.09);
    background: rgba(255,255,255,.035);
    border-radius: 14px;
    padding: 12px;
}
.history-timeline article span {
    color: var(--gold-2);
    font-size: 11px;
    text-transform: uppercase;
    font-weight: 950;
    letter-spacing: .08em;
}
.history-timeline article strong {
    display: block;
    color: #fff;
    margin: 4px 0;
    font-size: 12px;
}
.history-timeline article p {
    margin: 0;
    color: #d8d8d8;
    font-size: 13px;
    line-height: 1.45;
}
.addon-list-detail {
    display: grid;
    gap: 8px;
    margin-top: 16px;
}
.addon-list-detail div {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    border: 1px solid rgba(255,255,255,.09);
    background: rgba(255,255,255,.035);
    border-radius: 12px;
    padding: 12px 14px;
}
.addon-list-detail span { color: var(--gold-2); font-weight: 900; }

.template-help {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 18px;
    align-items: center;
}
.template-help code {
    background: rgba(212,173,86,.14);
    border: 1px solid rgba(240,201,108,.22);
    color: var(--gold-2);
    border-radius: 999px;
    padding: 6px 9px;
    font-size: 12px;
}
.check-line {
    display: inline-flex !important;
    align-items: center;
    gap: 9px !important;
    color: #fff;
}
.check-line input { width: auto !important; }

.agenda-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 10px;
}
.agenda-day {
    min-height: 128px;
    border: 1px solid rgba(255,255,255,.09);
    background: rgba(255,255,255,.03);
    border-radius: 16px;
    padding: 12px;
    display: grid;
    align-content: start;
    gap: 8px;
}
.agenda-day > strong {
    color: var(--gold-2);
    font-size: 18px;
}
.agenda-day.has-event {
    border-color: rgba(240,201,108,.28);
    background: linear-gradient(180deg, rgba(212,173,86,.11), rgba(255,255,255,.03));
}
.agenda-day a {
    display: grid;
    gap: 3px;
    border-radius: 12px;
    padding: 8px;
    background: rgba(0,0,0,.18);
    border: 1px solid rgba(255,255,255,.08);
}
.agenda-day a span {
    color: #fff;
    font-size: 12px;
    font-weight: 850;
}
.agenda-day a small {
    color: var(--muted);
    font-size: 11px;
}

@media (max-width: 1180px) {
    .quote-addons-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .admin-two-columns { grid-template-columns: 1fr; }
    .quick-message-panel { grid-template-columns: 1fr; }
    .quick-message-actions { justify-content: flex-start; }
    .agenda-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 720px) {
    .quote-addons-grid { grid-template-columns: 1fr; }
    .quote-addon-card { grid-template-columns: 1fr; }
    .finance-form, .history-form { grid-template-columns: 1fr; }
    .agenda-grid { grid-template-columns: 1fr; }
}


/* v22 - tela de cadastro/edição de drinks refinada */
.admin-main select,
.admin-main select option,
.admin-main select optgroup {
    background: #171920 !important;
    color: #ffffff !important;
}

.admin-main select:focus {
    border-color: rgba(240,201,108,.55) !important;
    box-shadow: 0 0 0 4px rgba(240,201,108,.08);
}

.drink-editor-header {
    align-items: flex-start;
}

.drink-editor-card {
    padding: 0;
    overflow: hidden;
    background:
        radial-gradient(circle at top right, rgba(212,173,86,.10), transparent 34%),
        linear-gradient(180deg, rgba(18,20,26,.96), rgba(10,11,15,.94));
}

.drink-editor-form {
    display: grid;
    grid-template-columns: 360px 1fr;
    gap: 0;
}

.drink-editor-preview {
    padding: 24px;
    border-right: 1px solid rgba(255,255,255,.10);
    background:
        radial-gradient(circle at 50% 0%, rgba(212,173,86,.18), transparent 34%),
        rgba(0,0,0,.16);
    display: grid;
    align-content: start;
    gap: 16px;
}

.drink-preview-frame {
    position: relative;
    width: 100%;
    aspect-ratio: 1.18 / 1;
    border-radius: 24px;
    overflow: hidden;
    border: 1px solid rgba(240,201,108,.26);
    background: #050608;
    box-shadow: 0 24px 58px rgba(0,0,0,.36);
}

.drink-preview-frame::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 48%, rgba(0,0,0,.42));
    pointer-events: none;
}

.drink-preview-frame img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transform: scale(1.01);
}

.drink-preview-meta {
    display: grid;
    gap: 6px;
    padding: 14px;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,.10);
    background: rgba(255,255,255,.045);
}

.drink-preview-meta strong {
    color: #fff;
    word-break: break-word;
}

.drink-preview-meta small {
    color: var(--muted);
    line-height: 1.45;
}

.drink-upload-dropzone {
    position: relative;
    display: grid;
    gap: 6px;
    place-items: center;
    text-align: center;
    min-height: 116px;
    padding: 18px;
    border-radius: 18px;
    border: 1px dashed rgba(240,201,108,.36);
    background: rgba(212,173,86,.08);
    cursor: pointer;
    transition: .2s ease;
}

.drink-upload-dropzone:hover {
    transform: translateY(-2px);
    border-color: rgba(240,201,108,.70);
    background: rgba(212,173,86,.13);
}

.drink-upload-dropzone input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.drink-upload-dropzone span {
    color: var(--gold-2);
    font-weight: 950;
    font-size: 15px;
}

.drink-upload-dropzone small {
    color: #d8d8d8;
    line-height: 1.4;
}

.drink-editor-fields {
    padding: 26px;
}

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

.drink-form-grid label {
    display: grid;
    gap: 8px;
}

.drink-form-grid label > span,
.drink-form-grid .full > span {
    color: #fff;
    font-size: 13px;
    font-weight: 900;
}

.drink-form-grid input:not([type="checkbox"]),
.drink-form-grid select,
.drink-form-grid textarea {
    width: 100%;
    border: 1px solid rgba(255,255,255,.13);
    background: rgba(255,255,255,.045);
    color: #fff;
    border-radius: 14px;
    padding: 14px 15px;
    outline: none;
    transition: border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.drink-form-grid input:not([type="checkbox"]):focus,
.drink-form-grid select:focus,
.drink-form-grid textarea:focus {
    border-color: rgba(240,201,108,.55);
    box-shadow: 0 0 0 4px rgba(240,201,108,.08);
    background: rgba(255,255,255,.065);
}

.drink-form-grid textarea {
    resize: vertical;
    min-height: 132px;
}

.drink-form-grid .full {
    grid-column: 1 / -1;
}

.drink-active-toggle {
    grid-column: 1 / -1;
    display: flex !important;
    align-items: center;
    gap: 12px !important;
    padding: 15px;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,.10);
    background: rgba(255,255,255,.035);
}

.drink-active-toggle input {
    width: 20px;
    height: 20px;
    accent-color: var(--gold);
}

.drink-active-toggle span {
    display: grid;
    gap: 3px;
}

.drink-active-toggle strong {
    color: #fff;
    font-size: 14px;
}

.drink-active-toggle small {
    color: var(--muted);
    font-size: 12px;
}

.drink-editor-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 20px;
}

@media (max-width: 980px) {
    .drink-editor-form {
        grid-template-columns: 1fr;
    }

    .drink-editor-preview {
        border-right: 0;
        border-bottom: 1px solid rgba(255,255,255,.10);
    }

    .drink-preview-frame {
        max-height: 360px;
    }
}

@media (max-width: 680px) {
    .drink-form-grid {
        grid-template-columns: 1fr;
    }

    .drink-editor-fields,
    .drink-editor-preview {
        padding: 18px;
    }

    .drink-editor-actions {
        display: grid;
    }
}


/* v24 - editor da página inicial */
.home-admin-form {
    display: grid;
    gap: 18px;
}

.home-editor-card {
    overflow: hidden;
    position: relative;
}

.home-editor-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at top right, rgba(212,173,86,.08), transparent 34%);
    pointer-events: none;
}

.home-editor-card > * {
    position: relative;
    z-index: 1;
}

.home-editor-grid {
    display: grid;
    grid-template-columns: 1fr 340px;
    gap: 18px;
}

.home-editor-fields,
.home-admin-form .quote-form-grid {
    display: grid;
    gap: 14px;
}

.home-editor-fields label,
.home-admin-form .quote-form-grid label,
.testimonial-admin-grid label,
.home-gallery-admin-grid label {
    display: grid;
    gap: 8px;
}

.home-editor-fields span,
.home-admin-form .quote-form-grid span,
.testimonial-admin-grid span,
.home-gallery-admin-grid span {
    color: #fff;
    font-size: 13px;
    font-weight: 900;
}

.home-editor-fields input,
.home-editor-fields textarea,
.home-admin-form .quote-form-grid input,
.home-admin-form .quote-form-grid textarea,
.testimonial-admin-grid input,
.testimonial-admin-grid textarea,
.home-gallery-admin-grid input[type="file"] {
    width: 100%;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.045);
    color: #fff;
    border-radius: 14px;
    padding: 13px 14px;
    outline: none;
}

.home-editor-fields input:focus,
.home-editor-fields textarea:focus,
.home-admin-form .quote-form-grid input:focus,
.home-admin-form .quote-form-grid textarea:focus,
.testimonial-admin-grid input:focus,
.testimonial-admin-grid textarea:focus {
    border-color: rgba(240,201,108,.55);
    box-shadow: 0 0 0 4px rgba(240,201,108,.08);
}

.home-image-admin {
    display: grid;
    gap: 12px;
    align-content: start;
}

.home-image-admin img,
.home-gallery-admin-grid img {
    width: 100%;
    height: 210px;
    object-fit: cover;
    border-radius: 18px;
    border: 1px solid rgba(240,201,108,.22);
    background: #050608;
}

.home-gallery-admin-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
}

.home-gallery-admin-grid article,
.testimonial-admin-grid article {
    border: 1px solid rgba(255,255,255,.10);
    background: rgba(255,255,255,.035);
    border-radius: 18px;
    padding: 14px;
    display: grid;
    gap: 12px;
}

.testimonial-admin-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
}

.home-admin-actions {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
}

@media (max-width: 1100px) {
    .home-editor-grid,
    .home-gallery-admin-grid,
    .testimonial-admin-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 720px) {
    .home-admin-actions {
        display: grid;
    }
}

/* Melhorias v25 */
.inline-form {
    display: inline-flex;
    margin: 0;
    gap: 8px;
    align-items: center;
}
.inline-form button {
    font: inherit;
}
.quick-message-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.responsive-table {
    overflow-x: auto;
}
.responsive-table table {
    width: 100%;
    border-collapse: collapse;
}
.responsive-table th,
.responsive-table td {
    padding: 12px;
    border-bottom: 1px solid rgba(255,255,255,.08);
    text-align: left;
    vertical-align: middle;
}
.checkbox-line {
    display: flex !important;
    align-items: center;
    gap: 8px;
}
.checkbox-line input {
    width: auto !important;
}
.quote-exact-guests {
    display: grid;
    gap: 8px;
    padding: 16px;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,.1);
    background: rgba(255,255,255,.04);
    margin-bottom: 12px;
}
.quote-exact-guests input {
    font-weight: 800;
}
.admin-user small {
    display: block;
    opacity: .7;
    margin-top: 4px;
}
.header-actions .inline-form .btn,
.quick-message-actions .inline-form .mini-action {
    cursor: pointer;
}
/* Tela de troca de senha */
.password-card { max-width: 620px; }
.password-form { margin-top: 18px; }
.password-form label { display: grid; gap: 8px; }
.password-actions { display: flex; justify-content: flex-start; margin-top: 4px; }
@media (max-width: 700px) {
    .password-actions .btn { width: 100%; justify-content: center; }
}

/* Logs administrativos - v29 */
.logs-filter-form {
    display: grid;
    grid-template-columns: 220px minmax(260px, 1fr) 180px auto;
    gap: 14px;
    align-items: end;
}
.logs-filter-form label {
    display: grid;
    gap: 7px;
}
.logs-filter-form span {
    color: var(--muted);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .08em;
    font-weight: 900;
}
.logs-filter-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.activity-log-table th:nth-child(1), .activity-log-table td:nth-child(1) { width: 145px; }
.activity-log-table th:nth-child(2), .activity-log-table td:nth-child(2) { width: 170px; }
.activity-log-table th:nth-child(3), .activity-log-table td:nth-child(3) { width: 170px; }
.activity-log-table th:nth-child(4), .activity-log-table td:nth-child(4) { width: 140px; }
.activity-log-table th:nth-child(6), .activity-log-table td:nth-child(6) { width: 130px; }
.activity-log-table td { white-space: normal; }
@media (max-width: 900px) {
    .logs-filter-form { grid-template-columns: 1fr; }
}
