@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

:root {
    --mamopro-white: #FFFFFF;
    --mamopro-pink: #FA7DAA;
    --mamopro-cyan: #2E9FD0;
    --mamopro-navy: #1E3A8A;
    --mamopro-ink: #1F2937;
    --mamopro-muted: #6B7280;
    --mamopro-line: rgba(31, 41, 55, 0.10);
    --mamopro-soft: #F8FAFC;
    --mamopro-soft-2: #EEF4FF;
    --mamopro-radius-lg: 24px;
    --mamopro-radius-md: 18px;
    --mamopro-radius-sm: 14px;
    --mamopro-shadow-lg: 0 24px 60px rgba(31, 41, 55, 0.12);
    --mamopro-shadow-md: 0 16px 40px rgba(31, 41, 55, 0.08);
}

.mamopro-shell,
.mamopro-form-container,
.mamopro-auth-box,
.mamopro-painel,
.mamopro-panel-card,
.mamopro-vagas-grid,
.mamopro-horas-widget {
    font-family: 'Inter', sans-serif;
}

.mamopro-painel {
    max-width: 1180px;
    margin: 0 auto;
    color: var(--mamopro-ink);
}

.mamopro-shell {
    padding: 20px 16px 40px;
}

.mamopro-hero {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 24px;
    padding: 28px;
    border-radius: 28px;
    background:
        radial-gradient(circle at top right, rgba(250, 125, 170, .26), transparent 28%),
        radial-gradient(circle at left bottom, rgba(46, 159, 208, .22), transparent 30%),
        linear-gradient(135deg, #fff 0%, #f9fbff 44%, #f3f7ff 100%);
    border: 1px solid rgba(30, 58, 138, .10);
    box-shadow: var(--mamopro-shadow-lg);
    margin-bottom: 26px;
}

.mamopro-hero h2 {
    margin: 8px 0 10px;
    font-size: clamp(28px, 3vw, 40px);
    line-height: 1.05;
    color: var(--mamopro-ink);
}

.mamopro-hero p {
    margin: 0;
    font-size: 15px;
    line-height: 1.7;
    color: var(--mamopro-muted);
    max-width: 760px;
}

.mamopro-hero-side {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    min-width: 120px;
}

.mamopro-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: .14em;
    font-weight: 800;
    color: var(--mamopro-navy);
}

.mamopro-eyebrow::before {
    content: '';
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--mamopro-pink), var(--mamopro-cyan));
    box-shadow: 0 0 0 5px rgba(250, 125, 170, .14);
}

.mamopro-kpi-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
    margin-bottom: 24px;
}

.mamopro-kpi-card {
    position: relative;
    overflow: hidden;
    padding: 22px;
    background: var(--mamopro-white);
    border-radius: var(--mamopro-radius-lg);
    border: 1px solid var(--mamopro-line);
    box-shadow: var(--mamopro-shadow-md);
}

.mamopro-kpi-card::after {
    content: '';
    position: absolute;
    inset: 0 auto auto 0;
    width: 100%;
    height: 4px;
    opacity: .95;
}

.mamopro-kpi-pink::after { background: linear-gradient(90deg, var(--mamopro-pink), #ffc1d6); }
.mamopro-kpi-cyan::after { background: linear-gradient(90deg, var(--mamopro-cyan), #9fddf6); }
.mamopro-kpi-navy::after { background: linear-gradient(90deg, var(--mamopro-navy), #4d79ef); }

.mamopro-kpi-label {
    display: block;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .10em;
    color: var(--mamopro-muted);
    font-weight: 700;
    margin-bottom: 14px;
}

.mamopro-kpi-value {
    display: block;
    font-size: clamp(24px, 2.4vw, 34px);
    line-height: 1.1;
    margin-bottom: 8px;
    color: var(--mamopro-ink);
}

.mamopro-kpi-desc {
    display: block;
    color: var(--mamopro-muted);
    font-size: 13px;
    line-height: 1.55;
}

.mamopro-tabs {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 8px;
    margin-bottom: 18px;
    border-radius: 18px;
    background: rgba(255, 255, 255, .88);
    border: 1px solid rgba(31, 41, 55, .08);
    box-shadow: var(--mamopro-shadow-md);
    backdrop-filter: blur(10px);
}

.mamopro-tab {
    border: 0 !important;
    background: transparent !important;
    color: var(--mamopro-muted) !important;
    border-radius: 14px !important;
    padding: 12px 18px !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    cursor: pointer !important;
    transition: all .22s ease !important;
}

.mamopro-tab:hover {
    color: var(--mamopro-navy);
    background: rgba(30, 58, 138, .06);
}

.mamopro-tab.active {
    color: var(--mamopro-white) !important;
    background: linear-gradient(135deg, var(--mamopro-navy), #3252b8 58%, var(--mamopro-cyan)) !important;
    box-shadow: 0 16px 28px rgba(30, 58, 138, .24) !important;
}

.mamopro-tab-content {
    display: none;
}

.mamopro-tab-content.active {
    display: block;
}

.mamopro-panel-card,
.mamopro-form-shell {
    background: var(--mamopro-white);
    border: 1px solid var(--mamopro-line);
    border-radius: var(--mamopro-radius-lg);
    padding: 24px;
    box-shadow: var(--mamopro-shadow-md);
    margin: 10px !important;
}

.mamopro-section-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 18px;
}

.mamopro-section-head h3 {
    margin: 0 0 8px;
    font-size: 22px;
    line-height: 1.15;
    color: var(--mamopro-ink);
}

.mamopro-section-head p {
    margin: 0;
    color: var(--mamopro-muted);
    font-size: 14px;
    line-height: 1.65;
}

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

.mamopro-grid-cards {
    align-items: start;
}

.mamopro-field {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin: 10px 0 !important;
}

.mamopro-field-full {
    grid-column: 1 / -1;
}

.mamopro-form h3 {
    margin: 22px 0 12px;
    font-size: 18px;
    color: var(--mamopro-ink);
}

.mamopro-form label {
    color: var(--mamopro-ink);
    font-size: 13px;
    font-weight: 700;
}

.mamopro-help,
.mamopro-muted {
    color: var(--mamopro-muted);
    font-size: 12px;
    line-height: 1.55;
}

.mamopro-form input,
.mamopro-form select,
.mamopro-form textarea {
    width: 100% !important;
    min-height: 50px !important;
    padding: 12px 14px !important;
    border: 1px solid rgba(31, 41, 55, .12) !important;
    border-radius: 16px !important;
    background: #fff !important;
    color: var(--mamopro-ink) !important;
    font-size: 14px !important;
    line-height: 1.4 !important;
    transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease !important;
    box-sizing: border-box !important;
}

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

.mamopro-form input:focus,
.mamopro-form select:focus,
.mamopro-form textarea:focus {
    outline: none;
    border-color: rgba(46, 159, 208, .8);
    box-shadow: 0 0 0 4px rgba(46, 159, 208, .12);
    transform: translateY(-1px);
}

.mamopro-form.is-loading {
    opacity: .82;
}

.mamopro-form-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 18px;
    flex-wrap: wrap;
}

.mamopro-btn-primary,
.mamopro-btn-secondary,
.mamopro-btn-outline,
.mamopro-doc-link {
    appearance: none;
    border: 0;
    text-decoration: none;
    cursor: pointer;
    transition: transform .2s ease, box-shadow .2s ease, opacity .2s ease, background .2s ease, color .2s ease;
}

.mamopro-btn-primary {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 50px !important;
    padding: 0 22px !important;
    border-radius: 16px !important;
    background: linear-gradient(135deg, var(--mamopro-navy), #3252b8 58%, var(--mamopro-cyan)) !important;
    color: var(--mamopro-white) !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    box-shadow: 0 18px 32px rgba(30, 58, 138, .24) !important;
}

.mamopro-btn-primary:hover,
.mamopro-btn-secondary:hover,
.mamopro-btn-outline:hover,
.mamopro-doc-link:hover {
    transform: translateY(-1px);
}

.mamopro-btn-primary:disabled,
.mamopro-btn-secondary:disabled {
    opacity: .65;
    cursor: not-allowed;
    transform: none;
}

.mamopro-btn-secondary,
.mamopro-doc-link {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 44px !important;
    padding: 0 16px !important;
    border-radius: 14px !important;
    background: rgba(46, 159, 208, .08) !important;
    color: var(--mamopro-navy) !important;
    border: 1px solid rgba(46, 159, 208, .22) !important;
    font-size: 13px !important;
    font-weight: 700 !important;
}

.mamopro-actions-inline {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.mamopro-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.mamopro-badge.aprovado,
.mamopro-badge.green,
.mamopro-badge.success {
    background: rgba(46, 159, 208, .14);
    color: #0f6092;
}

.mamopro-badge.pendente,
.mamopro-badge.orange,
.mamopro-badge.warning {
    background: rgba(250, 125, 170, .16);
    color: #be456f;
}

.mamopro-badge.red,
.mamopro-badge.danger,
.mamopro-badge.rejeitado,
.mamopro-badge.pausado {
    background: rgba(239, 68, 68, .12);
    color: #b91c1c;
}

.mamopro-badge.finalizado,
.mamopro-badge.blue {
    background: rgba(30, 58, 138, .12);
    color: var(--mamopro-navy);
}

.mamopro-badge.gray {
    background: rgba(31, 41, 55, .08);
    color: var(--mamopro-ink);
}

.mamopro-alert {
    border-radius: 18px;
    padding: 14px 16px;
    margin: 16px 0;
    font-size: 14px;
    line-height: 1.6;
    border: 1px solid transparent;
}

.mamopro-alert.success {
    background: rgba(46, 159, 208, .10);
    color: #0f6092;
    border-color: rgba(46, 159, 208, .18);
}

.mamopro-alert.warning {
    background: rgba(250, 125, 170, .12);
    color: #be456f;
    border-color: rgba(250, 125, 170, .22);
}

.mamopro-alert.danger {
    background: rgba(239, 68, 68, .10);
    color: #b91c1c;
    border-color: rgba(239, 68, 68, .18);
}

.mamopro-lgpd-box {
    border-radius: 18px;
    padding: 16px;
    background: linear-gradient(135deg, rgba(250, 125, 170, .12), rgba(46, 159, 208, .12));
    border: 1px solid rgba(30, 58, 138, .10);
    color: var(--mamopro-ink);
    font-size: 14px;
    line-height: 1.6;
}

.mamopro-lgpd-box label{
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 10px;
}

.mamopro-lgpd-box input[type="checkbox"]{
    width: 20px !important;
    height: 20px !important;
}

.mamopro-table-wrap {
    overflow-x: auto;
    border-radius: 18px;
    border: 1px solid var(--mamopro-line);
}

.mamopro-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
    background: #fff;
}

.mamopro-table thead th {
    padding: 16px;
    text-align: left;
    font-weight: 800;
    color: var(--mamopro-ink);
    background: linear-gradient(180deg, #f8fbff, #f3f7ff);
    border-bottom: 1px solid var(--mamopro-line);
    white-space: nowrap;
}

.mamopro-table tbody td {
    padding: 15px 16px;
    border-bottom: 1px solid rgba(31, 41, 55, .07);
    vertical-align: top;
    color: var(--mamopro-ink);
}

.mamopro-table tbody tr:last-child td {
    border-bottom: 0;
}

.mamopro-table select {
    min-width: 150px;
}

.mamopro-empty {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 140px;
    border-radius: 20px;
    background: linear-gradient(135deg, rgba(46, 159, 208, .08), rgba(250, 125, 170, .08));
    border: 1px dashed rgba(30, 58, 138, .16);
    color: var(--mamopro-muted);
    font-weight: 600;
    text-align: center;
    padding: 18px;
}

.mamopro-docs-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 16px;
}

.mamopro-doc-card {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 14px;
    min-height: 250px;
    background: linear-gradient(180deg, #fff, #fbfdff);
    border-radius: 20px;
    border: 1px solid var(--mamopro-line);
    padding: 18px;
}

.mamopro-doc-pill {
    display: inline-flex;
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(250, 125, 170, .12);
    color: #be456f;
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
    margin-bottom: 10px;
}

.mamopro-doc-card h4 {
    margin: 0;
    font-size: 18px;
    line-height: 1.25;
}

.mamopro-doc-state {
    font-size: 13px;
    color: var(--mamopro-muted);
}

.mamopro-doc-state-success {
    color: #0f6092;
    font-weight: 700;
}

.mamopro-upload-form {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.mamopro-vagas-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.mamopro-vaga-card {
    border-radius: 24px;
    padding: 22px;
    background: linear-gradient(180deg, #ffffff, #f9fbff);
    border: 1px solid var(--mamopro-line);
    box-shadow: var(--mamopro-shadow-md);
}

.mamopro-vaga-card h3 {
    margin: 14px 0 12px;
    font-size: 21px;
    line-height: 1.2;
    color: var(--mamopro-ink);
}

.mamopro-vaga-card p {
    margin: 0 0 8px;
    color: var(--mamopro-muted);
    font-size: 14px;
    line-height: 1.6;
}

.mamopro-vaga-excerpt {
    margin-top: 12px !important;
}

.mamopro-horas-widget .mamopro-widget-stats {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    margin-bottom: 20px;
}

.mamopro-progress-row {
    padding: 18px;
    border-radius: 20px;
    background: linear-gradient(180deg, #fff, #f8fbff);
    border: 1px solid var(--mamopro-line);
}

.mamopro-progress-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 10px;
}

.mamopro-progress-meta span {
    font-size: 13px;
    color: var(--mamopro-muted);
    font-weight: 700;
}

.mamopro-progress-meta strong {
    font-size: 15px;
    color: var(--mamopro-ink);
}

.mamopro-progress-bar {
    height: 12px;
    border-radius: 999px;
    overflow: hidden;
    background: rgba(30, 58, 138, .08);
    margin-bottom: 8px;
}

.mamopro-progress-bar > div {
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--mamopro-navy), var(--mamopro-cyan));
}

.mamopro-progress-bar-secondary > div {
    background: linear-gradient(90deg, var(--mamopro-pink), #ffb7d0);
}

.mamopro-progress-row small {
    display: block;
    color: var(--mamopro-muted);
    line-height: 1.55;
}

.mamopro-auth-box {
    max-width: 520px;
    margin: 0 auto;
}

.mamopro-checkbox label {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-weight: 600;
    margin-top: 20px;
}

@media (max-width: 991px) {
    .mamopro-kpi-grid,
    .mamopro-vagas-grid,
    .mamopro-horas-widget .mamopro-widget-stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    .mamopro-shell {
        padding-left: 12px;
        padding-right: 12px;
    }

    .mamopro-hero,
    .mamopro-panel-card,
    .mamopro-form-shell {
        padding: 18px;
        border-radius: 22px;
    }

    .mamopro-hero {
        flex-direction: column;
    }

    .mamopro-kpi-grid,
    .mamopro-grid-2,
    .mamopro-vagas-grid,
    .mamopro-horas-widget .mamopro-widget-stats {
        grid-template-columns: 1fr;
    }

    .mamopro-tabs {
        display: flex;
        width: 100%;
        overflow-x: auto;
        flex-wrap: nowrap;
    }

    .mamopro-tab {
        white-space: nowrap;
    }

    .mamopro-table-wrap {
        overflow: visible;
        border: 0;
    }

    .mamopro-table,
    .mamopro-table thead,
    .mamopro-table tbody,
    .mamopro-table tr,
    .mamopro-table th,
    .mamopro-table td {
        display: block;
        width: 100%;
    }

    .mamopro-table thead {
        display: none;
    }

    .mamopro-table tbody {
        display: grid;
        gap: 12px;
    }

    .mamopro-table tbody tr {
        border-radius: 18px;
        border: 1px solid var(--mamopro-line);
        background: #fff;
        box-shadow: var(--mamopro-shadow-md);
        overflow: hidden;
    }

    .mamopro-table tbody td {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 12px;
        padding: 12px 14px;
        border-bottom: 1px solid rgba(31, 41, 55, .06);
        text-align: right;
    }

    .mamopro-table tbody td::before {
        content: attr(data-label);
        font-weight: 800;
        color: var(--mamopro-ink);
        text-align: left;
        max-width: 48%;
    }

    .mamopro-table tbody td:last-child {
        border-bottom: 0;
    }
}

.mamopro-hours-admin {
    margin-top: 14px;
    padding: 16px;
    border: 1px solid rgba(46, 159, 208, 0.16);
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,250,252,0.98));
    box-shadow: 0 16px 36px rgba(31, 41, 55, 0.08);
}

.mamopro-hours-admin-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 12px;
}

.mamopro-hours-admin-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.mamopro-hours-field label {
    display: block;
    margin-bottom: 6px;
    font-size: 12px;
    font-weight: 700;
    color: var(--mamopro-ink);
}

.mamopro-hours-field input,
.mamopro-hours-field select {
    width: 100%;
}

.mamopro-hours-summary {
    margin: 12px 0 8px;
    font-size: 12px;
    line-height: 1.5;
    color: var(--mamopro-muted);
}

.mamopro-hours-hint,
.mamopro-hours-details {
    display: block;
    margin-top: 8px;
    font-size: 12px;
    color: var(--mamopro-muted);
}

.mamopro-hours-chip-wrap {
    display: flex;
    justify-content: flex-end;
}

@media (max-width: 767px) {
    .mamopro-hours-admin-grid {
        grid-template-columns: 1fr;
    }
}

.mamopro-actions-inline-stack {
    margin-bottom: 12px;
}

.mamopro-hours-control {
    margin-top: 12px;
}

.mamopro-hours-trigger-card {
    padding: 16px 18px;
    border-radius: 18px;
    border: 1px solid rgba(46, 159, 208, .16);
    background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(246,250,255,.98));
    box-shadow: 0 16px 34px rgba(31, 41, 55, .08);
}

.mamopro-hours-trigger-head,
.mamopro-hours-trigger-inline,
.mamopro-hours-modal-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
}

.mamopro-hours-trigger-head strong,
.mamopro-hours-modal-top h4 {
    color: var(--mamopro-ink);
}

.mamopro-hours-trigger-range,
.mamopro-hours-modal-top p,
.mamopro-hours-modal-kicker {
    display: block;
    color: var(--mamopro-muted);
}

.mamopro-hours-trigger-range {
    margin-top: 4px;
    font-size: 12px;
}

.mamopro-hours-trigger-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin: 12px 0;
}

.mamopro-hours-trigger-total,
.mamopro-hours-trigger-days {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(30, 58, 138, .06);
    color: var(--mamopro-navy);
    font-size: 12px;
    font-weight: 800;
}

.mamopro-hours-trigger-breakdown {
    color: var(--mamopro-muted);
    line-height: 1.6;
}

.mamopro-hours-modal {
    position: fixed;
    inset: 0;
    z-index: 999999;
}

.mamopro-hours-modal[hidden] {
    display: none !important;
}

.mamopro-hours-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, .55);
    backdrop-filter: blur(4px);
}

.mamopro-hours-modal-dialog {
    position: relative;
    width: min(760px, calc(100vw - 32px));
    margin: min(6vh, 48px) auto 0;
    max-height: calc(100vh - 64px);
    overflow: auto;
    border-radius: 24px;
    background: #fff;
    border: 1px solid rgba(31, 41, 55, .10);
    box-shadow: 0 28px 60px rgba(15, 23, 42, .22);
    padding: 24px;
}

.mamopro-hours-modal-close {
    position: absolute;
    top: 14px;
    right: 14px;
    width: 42px;
    height: 42px;
    border: 0;
    border-radius: 999px;
    background: rgba(31, 41, 55, .08);
    color: var(--mamopro-ink);
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
}

.mamopro-hours-modal-top {
    padding-right: 48px;
    margin-bottom: 18px;
}

.mamopro-hours-modal-kicker {
    margin-bottom: 8px;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--mamopro-navy);
}

.mamopro-hours-modal-top h4 {
    margin: 0 0 8px;
    font-size: 26px;
    line-height: 1.1;
}

.mamopro-hours-modal-top p {
    margin: 0;
    font-size: 14px;
    line-height: 1.65;
}

body.mamopro-modal-open {
    overflow: hidden;
}

@media (max-width: 767px) {
    .mamopro-hours-trigger-head,
    .mamopro-hours-trigger-inline,
    .mamopro-hours-modal-top {
        flex-direction: column;
        align-items: stretch;
    }

    .mamopro-hours-modal-dialog {
        width: calc(100vw - 18px);
        margin-top: 12px;
        max-height: calc(100vh - 24px);
        padding: 18px;
        border-radius: 20px;
    }
}

#mamopro-login-form input[type="checkbox"]{
    min-height: 15px !important;
    width: 15px !important;
}

.mamopro-payment-cell{display:grid;gap:8px;min-width:160px}
.mamopro-lock-card{border:1px dashed rgba(30,58,138,.28);border-radius:24px;padding:28px;background:linear-gradient(180deg,rgba(250,125,170,.08),rgba(46,159,208,.06));}
.mamopro-lock-pill{display:inline-flex;align-items:center;justify-content:center;padding:6px 12px;border-radius:999px;background:#1F2937;color:#fff;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:14px}
.mamopro-lock-card h4{margin:0 0 10px;color:#1F2937;font-size:24px}
.mamopro-lock-card p{margin:0 0 14px;color:#4b5563;line-height:1.6}
.mamopro-lock-list{margin:0;padding-left:18px;color:#1F2937;display:grid;gap:6px}
.mamopro-space-top{margin-top:20px}


/* ===== v1.4.1 refinamentos de UX ===== */
.mamopro-painel .mamopro-btn-primary,
.mamopro-painel .mamopro-btn-secondary,
.mamopro-painel .mamopro-btn-outline,
.mamopro-painel .mamopro-btn-ghost,
.mamopro-painel .mamopro-doc-link,
.mamopro-hours-history-actions .mamopro-btn-outline,
.mamopro-hours-history-actions .mamopro-btn-ghost,
.mamopro-hours-actions .mamopro-btn-outline,
.mamopro-hours-actions .mamopro-btn-ghost,
.mamopro-hours-actions .mamopro-btn-secondary {
    appearance: none !important;
    border-width: 1px !important;
    border-style: solid !important;
    outline: 0 !important;
    text-decoration: none !important;
    box-shadow: none !important;
}

.mamopro-painel .mamopro-btn-primary {
    border-color: transparent !important;
    background: linear-gradient(135deg, var(--mamopro-navy), #3252b8 58%, var(--mamopro-cyan)) !important;
    color: #fff !important;
    box-shadow: 0 18px 32px rgba(30, 58, 138, .24) !important;
}

.mamopro-painel .mamopro-btn-secondary,
.mamopro-painel .mamopro-doc-link {
    background: rgba(46, 159, 208, .08) !important;
    border-color: rgba(46, 159, 208, .22) !important;
    color: var(--mamopro-navy) !important;
}

.mamopro-painel .mamopro-btn-outline {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 16px;
    border-radius: 14px;
    background: rgba(30, 58, 138, .04) !important;
    border-color: rgba(30, 58, 138, .16) !important;
    color: var(--mamopro-navy) !important;
    font-size: 13px;
    font-weight: 700;
}

.mamopro-painel .mamopro-btn-ghost {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 16px;
    border-radius: 14px;
    background: rgba(31, 41, 55, .04) !important;
    border-color: rgba(31, 41, 55, .10) !important;
    color: var(--mamopro-ink) !important;
    font-size: 13px;
    font-weight: 700;
}

.mamopro-painel .mamopro-btn-secondary:hover,
.mamopro-painel .mamopro-btn-outline:hover,
.mamopro-painel .mamopro-btn-ghost:hover,
.mamopro-painel .mamopro-btn-primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 14px 26px rgba(15,23,42,.10) !important;
}

.mamopro-actions-inline-stack {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    margin-bottom: 12px;
}

.mamopro-actions-inline-stack .mamopro-btn-secondary,
.mamopro-actions-inline-stack .mamopro-btn-outline,
.mamopro-actions-inline-stack .mamopro-btn-ghost {
    min-width: 112px;
}

.mamopro-payment-cell {
    display: grid;
    gap: 10px;
    min-width: 170px;
    align-content: start;
}

.mamopro-payment-cell select,
.mamopro-hours-field input,
.mamopro-hours-field select,
.mamopro-hours-field textarea,
.mamopro-table select {
    border: 1px solid rgba(31, 41, 55, .14) !important;
    border-radius: 14px !important;
    box-shadow: none !important;
    background: #fff !important;
}

.mamopro-hours-control {
    margin-top: 12px;
}

.mamopro-hours-trigger-card.mamopro-hours-trigger-card-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 16px 18px;
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(248,250,252,.96), rgba(240,245,255,.96));
    border: 1px solid rgba(30, 58, 138, .10);
}

.mamopro-hours-trigger-card.mamopro-hours-trigger-card-actions .mamopro-hours-trigger-head {
    flex: 1;
    align-items: center;
}

.mamopro-hours-trigger-card.mamopro-hours-trigger-card-actions .mamopro-hours-trigger-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.mamopro-hours-modal-dialog {
    border: 1px solid rgba(30,58,138,.12);
    background: linear-gradient(180deg, #fff, #f9fbff 100%);
}

.mamopro-hours-modal-close {
    border: 1px solid rgba(31,41,55,.10) !important;
    background: rgba(31,41,55,.04) !important;
    color: var(--mamopro-ink) !important;
}

.mamopro-hours-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 16px;
    margin-bottom: 16px;
}

.mamopro-hours-history-table th,
.mamopro-hours-history-table td {
    vertical-align: top;
}

.mamopro-hours-history-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.mamopro-hours-history-actions .mamopro-btn-outline,
.mamopro-hours-history-actions .mamopro-btn-ghost {
    min-height: 36px;
    padding: 0 12px;
    border-radius: 12px;
}

.mamopro-lock-card-pending_contract {
    background: linear-gradient(180deg, rgba(250,125,170,.06), rgba(30,58,138,.04));
}

.mamopro-lock-card-pending_payment {
    background: linear-gradient(180deg, rgba(46,159,208,.08), rgba(30,58,138,.05));
}

.mamopro-lock-card-blocked {
    background: linear-gradient(180deg, rgba(239,68,68,.06), rgba(31,41,55,.03));
}

@media (max-width: 980px) {
    .mamopro-hours-trigger-card.mamopro-hours-trigger-card-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .mamopro-hours-trigger-card.mamopro-hours-trigger-card-actions .mamopro-hours-trigger-actions {
        justify-content: stretch;
    }

    .mamopro-hours-trigger-card.mamopro-hours-trigger-card-actions .mamopro-hours-trigger-actions > * {
        flex: 1 1 100%;
    }
}


.mamopro-intern-filters {
    display: grid;
    gap: 12px;
    margin: 0 0 18px;
}
.mamopro-intern-filters-search input,
.mamopro-intern-filters-grid select {
    width: 100% !important;
    min-height: 46px !important;
    border-radius: 14px !important;
    border: 1px solid rgba(31, 41, 55, .12) !important;
    background: #fff !important;
    padding: 0 14px !important;
}
.mamopro-intern-filters-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}
.mamopro-calendar-cell {
    display: grid;
    gap: 10px;
    min-width: 220px;
}
.mamopro-calendar-cell-top { display:grid; gap:6px; }
.mamopro-calendar-caption { display:block; color: var(--mamopro-muted); font-size: 12px; line-height: 1.5; }
.mamopro-row-blocked-badge { margin-left: 8px; }
.mamopro-intern-row[hidden] { display: none !important; }
@media (max-width: 880px) {
    .mamopro-intern-filters-grid { grid-template-columns: 1fr; }
    .mamopro-calendar-cell { min-width: 0; }
}

.mamopro-inline-info {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin: 0 0 18px;
    padding: 16px 18px;
    border-radius: 18px;
    border: 1px solid rgba(46, 159, 208, .18);
    background: linear-gradient(135deg, rgba(30, 58, 138, .05), rgba(46, 159, 208, .08), rgba(250, 125, 170, .08));
}

.mamopro-inline-info strong {
    display: block;
    color: var(--mamopro-ink);
    margin-bottom: 4px;
}

.mamopro-inline-info small {
    display: block;
    color: var(--mamopro-muted);
}

.mamopro-vagas-grid-premium {
    align-items: stretch;
}

.mamopro-vaga-card-premium {
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    min-height: 100%;
    padding: 0;
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
    border: 1px solid rgba(30, 58, 138, .10);
    box-shadow: 0 24px 48px rgba(31, 41, 55, .10);
}

.mamopro-vaga-card-premium::before {
    content: '';
    position: absolute;
    inset: 0 0 auto;
    height: 4px;
    background: linear-gradient(90deg, var(--mamopro-pink), var(--mamopro-cyan), var(--mamopro-navy));
}

.mamopro-vaga-thumb {
    position: relative;
    aspect-ratio: 16 / 8;
    background: linear-gradient(135deg, rgba(250, 125, 170, .18), rgba(46, 159, 208, .20));
    overflow: hidden;
}

.mamopro-vaga-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.mamopro-vaga-body {
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 22px;
    flex: 1;
}

.mamopro-vaga-topline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}

.mamopro-vaga-expira-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    border-radius: 999px;
    background: rgba(30, 58, 138, .08);
    color: var(--mamopro-navy);
    font-size: 12px;
    font-weight: 700;
}

.mamopro-vaga-card-premium h3 {
    margin: 0;
    font-size: 24px;
    line-height: 1.15;
}

.mamopro-vaga-card-premium h3 a {
    color: var(--mamopro-ink);
    text-decoration: none;
}

.mamopro-vaga-card-premium h3 a:hover {
    color: var(--mamopro-navy);
}

.mamopro-vaga-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.mamopro-vaga-meta span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    border-radius: 14px;
    background: rgba(31, 41, 55, .05);
    color: var(--mamopro-ink);
    font-size: 13px;
    font-weight: 600;
}

.mamopro-vaga-excerpt {
    color: var(--mamopro-muted);
}

.mamopro-vaga-actions {
    margin-top: auto;
    display: flex;
    align-items: center;
    gap: 10px;
}

.mamopro-vaga-btn {
    min-width: 180px;
}

.mamopro-vaga-single-shell {
    max-width: 1080px;
    margin: 30px auto;
    padding: 0 16px;
}

.mamopro-vaga-single-card {
    border-radius: 28px;
    border: 1px solid rgba(30, 58, 138, .10);
    background: linear-gradient(180deg, #ffffff, #f8fbff);
    box-shadow: 0 30px 60px rgba(31, 41, 55, .10);
    overflow: hidden;
}

.mamopro-vaga-single-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 22px;
    padding: 28px 28px 20px;
    border-bottom: 1px solid rgba(31, 41, 55, .08);
}

.mamopro-vaga-single-top h1 {
    margin: 12px 0 0;
    font-size: clamp(30px, 3vw, 42px);
    line-height: 1.05;
    color: var(--mamopro-ink);
}

.mamopro-vaga-meta-single {
    margin-top: 14px;
}

.mamopro-vaga-single-content {
    padding: 28px;
    color: var(--mamopro-ink);
    line-height: 1.8;
}

.mamopro-vaga-single-content > *:first-child {
    margin-top: 0;
}

@media (max-width: 900px) {
    .mamopro-inline-info,
    .mamopro-vaga-single-top {
        flex-direction: column;
        align-items: stretch;
    }

    .mamopro-vaga-btn,
    .mamopro-inline-info .mamopro-btn-ghost {
        width: 100%;
    }
}

/* ===== v1.6.0 enhancements ===== */
.mamopro-docs-alert-top{margin-bottom:18px}
.mamopro-docs-progress-banner{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px;padding:16px 18px;border:1px solid rgba(46,159,208,.18);border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.94),rgba(248,250,252,.98))}
.mamopro-docs-progress-banner small{display:block;color:#6b7280;margin-top:4px}
.mamopro-doc-review-status,.mamopro-doc-note{margin-top:8px}
.mamopro-doc-note{font-size:13px;color:#6b7280;line-height:1.45}
.mamopro-vaga-expira-chip-inline{display:inline-flex;align-items:center;min-height:44px;padding:0 14px;border-radius:999px;background:#F8FAFC;border:1px solid #E5E7EB;color:#1F2937;font-size:13px;font-weight:600}
.mamopro-vaga-title a,.mamopro-vaga-title span{color:#1F2937;text-decoration:none}
.mamopro-vaga-title a:hover{color:#1E3A8A}
.mamopro-vaga-apply-box{margin-top:24px}
.mamopro-intern-detail-modal{position:fixed;inset:0;z-index:99998;display:flex;align-items:center;justify-content:center;padding:24px}
.mamopro-intern-detail-modal[hidden]{display:none!important}
.mamopro-intern-detail-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.56);backdrop-filter:blur(4px)}
.mamopro-intern-detail-dialog{position:relative;z-index:2;max-width:1080px;width:min(1080px,96vw);max-height:90vh;overflow:auto;background:#fff;border-radius:28px;padding:24px;box-shadow:0 30px 80px rgba(15,23,42,.34)}
.mamopro-intern-detail-grid{margin-bottom:18px}
.mamopro-doc-review-controls{display:grid;grid-template-columns:180px 1fr auto;gap:10px;align-items:center}
.mamopro-doc-review-controls input,.mamopro-doc-review-controls select{width:100%}
.mamopro-vaga-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:18px}
.mamopro-vaga-single-card .mamopro-vaga-expira-chip{margin-left:10px}
@media (max-width: 782px){
  .mamopro-intern-detail-dialog{padding:18px;border-radius:22px}
  .mamopro-doc-review-controls{grid-template-columns:1fr}
}
.mamopro-record-modal .mamopro-record-modal-dialog{max-width:920px;width:min(920px,96vw)}
.mamopro-record-modal-form .mamopro-grid-2{margin-top:16px}
.mamopro-record-modal-form .mamopro-form-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.mamopro-record-modal-form textarea{min-height:140px}


/* ============================================================
   MAMOPRO 2.1.7 — Agenda da clínica + validação de horas
   ============================================================ */
.mamopro-clinic-schedule-wrap,
.mamopro-stage-validation-wrap {
    display: grid;
    gap: 22px;
}

.mamopro-section-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
}

.mamopro-section-head h3 {
    margin: 0 0 4px;
}

.mamopro-section-head p {
    margin: 0;
    color: #64748b;
}

.mamopro-schedule-top-grid {
    align-items: end;
}

.mamopro-switch-line {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px;
    border: 1px solid rgba(15, 23, 42, .1);
    border-radius: 14px;
    background: #f8fafc;
    min-height: 58px;
}

.mamopro-switch-line input[type="checkbox"],
.mamopro-schedule-day-name input[type="checkbox"]{
    width: 20px !important;
    height: 20px !important;
}

.mamopro-ajax-form{
    margin-bottom: 15px !important;
}

.mamopro-schedule-days {
    display: grid;
    gap: 10px;
    margin-top: 18px;
}

.mamopro-schedule-day-row {
    display: grid;
    grid-template-columns: minmax(150px, .8fr) minmax(230px, 1.1fr) minmax(230px, 1.1fr);
    gap: 12px;
    align-items: center;
    padding: 14px;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 16px;
    background: #fff;
}

.mamopro-schedule-day-name {
    display: flex;
    align-items: center;
    gap: 10px;
}

.mamopro-schedule-time-group {
    display: grid;
    grid-template-columns: 64px 1fr 1fr;
    align-items: center;
    gap: 8px;
}

.mamopro-schedule-time-group span {
    font-size: 12px;
    font-weight: 700;
    color: #475569;
    text-transform: uppercase;
    letter-spacing: .04em;
}

.mamopro-small-alert {
    margin-top: 16px;
}

.mamopro-stage-table td {
    vertical-align: top;
}

.mamopro-stage-validation-grid {
    display: grid;
    grid-template-columns: 1fr 130px;
    gap: 10px;
}

.mamopro-stage-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: 10px;
}

.mamopro-admin-validations-wrap .mamopro-grid-3 {
    margin-bottom: 22px;
}

.mamopro-student-validated-hours {
    border-color: rgba(34, 197, 94, .18);
}

@media (max-width: 900px) {
    .mamopro-section-head,
    .mamopro-stage-footer {
        flex-direction: column;
        align-items: stretch;
    }

    .mamopro-schedule-day-row,
    .mamopro-stage-validation-grid {
        grid-template-columns: 1fr;
    }

    .mamopro-schedule-time-group {
        grid-template-columns: 1fr 1fr;
    }

    .mamopro-schedule-time-group span {
        grid-column: 1 / -1;
    }
}

/* =========================================================
   MAMOPRO RAD — JetAppointment Premium UI
   ========================================================= */

.mamopro-appointment-shortcode-wrap{
    --mp-white:#FFFFFF;
    --mp-pink:#FA7DAA;
    --mp-cyan:#2E9FD0;
    --mp-blue:#1E3A8A;
    --mp-dark:#1F2937;
    --mp-border:#D9E2EC;
    --mp-soft:#F8FBFF;
    --mp-soft-2:#F4F7FB;
    --mp-success:#16A34A;
    --mp-danger:#E11D48;
    --mp-shadow:0 18px 50px rgba(31,41,55,.08);
    --mp-radius:22px;
}

/* Card geral */
.mamopro-appointment-shortcode-wrap .jet-form{
    background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%);
    border:1px solid var(--mp-border);
    border-radius:28px;
    padding:28px;
    box-shadow:var(--mp-shadow);
}

/* Labels */
.mamopro-appointment-shortcode-wrap .jet-form__label-text{
    font-size:14px;
    font-weight:700;
    color:var(--mp-dark);
    letter-spacing:.01em;
}

.mamopro-appointment-shortcode-wrap .jet-form__required{
    color:var(--mp-pink);
}

/* Campos */
.mamopro-appointment-shortcode-wrap .jet-form__field,
.mamopro-appointment-shortcode-wrap select,
.mamopro-appointment-shortcode-wrap input[type="email"],
.mamopro-appointment-shortcode-wrap input[type="text"]{
    width:100%;
    min-height:52px;
    border:1px solid #D7E1EC;
    border-radius:16px;
    background:#fff;
    color:var(--mp-dark);
    padding:0 16px;
    font-size:15px;
    transition:border-color .22s ease, box-shadow .22s ease, transform .22s ease;
    box-shadow:none;
}

.mamopro-appointment-shortcode-wrap .jet-form__field:focus,
.mamopro-appointment-shortcode-wrap select:focus,
.mamopro-appointment-shortcode-wrap input:focus{
    outline:none;
    border-color:rgba(46,159,208,.75);
    box-shadow:0 0 0 4px rgba(46,159,208,.12);
}

.mamopro-appointment-shortcode-wrap .jet-form-row{
    margin-bottom:18px;
}

/* Select com seta mais bonita */
.mamopro-appointment-shortcode-wrap .appointment-provider,
.mamopro-appointment-shortcode-wrap select[name="service_id"]{
    appearance:none;
    -webkit-appearance:none;
    -moz-appearance:none;
    padding-right:44px;
    background-image:
        linear-gradient(45deg, transparent 50%, #64748B 50%),
        linear-gradient(135deg, #64748B 50%, transparent 50%);
    background-position:
        calc(100% - 20px) calc(50% - 3px),
        calc(100% - 14px) calc(50% - 3px);
    background-size:6px 6px, 6px 6px;
    background-repeat:no-repeat;
}

/* Submit */
.mamopro-appointment-shortcode-wrap .jet-form__submit{
    width:100%;
    min-height:54px;
    border:0 !important;
    border-radius:16px;
    background:linear-gradient(135deg,var(--mp-blue),var(--mp-cyan)) !important;
    color:#fff !important;
    font-size:16px;
    font-weight:800;
    letter-spacing:.01em;
    box-shadow:0 14px 34px rgba(30,58,138,.20);
    transition:transform .22s ease, box-shadow .22s ease, opacity .22s ease;
}

.mamopro-appointment-shortcode-wrap .jet-form__submit:hover{
    transform:translateY(-2px);
    box-shadow:0 18px 40px rgba(30,58,138,.25);
}

.mamopro-appointment-shortcode-wrap .jet-form__submit:disabled{
    opacity:.65;
    cursor:not-allowed;
    transform:none;
}

/* Mensagens */
.mamopro-appointment-shortcode-wrap .jet-form-message{
    margin-top:16px;
    border-radius:16px;
    padding:14px 18px;
    font-weight:700;
    border:1px solid transparent;
}

.mamopro-appointment-shortcode-wrap .jet-form-message--success{
    background:rgba(22,163,74,.08);
    border-color:rgba(22,163,74,.18);
    color:#15703d;
}

.mamopro-appointment-shortcode-wrap .jet-form-message--error{
    background:rgba(225,29,72,.08);
    border-color:rgba(225,29,72,.18);
    color:#b01846;
}

/* Wrapper do calendário */
.mamopro-appointment-shortcode-wrap .jet-apb-calendar-wrapper{
    background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%);
    border:1px solid var(--mp-border);
    border-radius:22px;
    padding:18px;
}

/* Header */
.mamopro-appointment-shortcode-wrap .jet-apb-calendar-header{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:10px;
    margin-bottom:16px;
}

.mamopro-appointment-shortcode-wrap .jet-apb-calendar-header__label{
    font-size:20px;
    font-weight:800;
    color:var(--mp-dark);
    letter-spacing:-.02em;
}

/* Botões anterior/próximo */
.mamopro-appointment-shortcode-wrap .jet-apb-calendar-btn{
    width:44px;
    height:44px;
    border:1px solid #D8E3EE;
    border-radius:14px;
    background:#fff;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    color:var(--mp-blue);
    box-shadow:0 8px 20px rgba(31,41,55,.05);
    transition:all .22s ease;
}

.mamopro-appointment-shortcode-wrap .jet-apb-calendar-btn:hover{
    border-color:rgba(46,159,208,.45);
    background:#F4FAFF;
    transform:translateY(-1px);
}

.mamopro-appointment-shortcode-wrap .jet-apb-calendar-btn svg{
    width:20px;
    height:20px;
    fill:currentColor;
}

/* Linha de dias */
.mamopro-appointment-shortcode-wrap .jet-apb-calendar-week{
    display:grid;
    grid-template-columns:repeat(7,1fr);
    gap:8px;
    margin-bottom:10px;
}

.mamopro-appointment-shortcode-wrap .jet-apb-calendar-week span{
    text-align:center;
    font-size:12px;
    font-weight:800;
    text-transform:uppercase;
    color:#6B7280;
    letter-spacing:.06em;
    padding:8px 0;
}

/* Corpo do calendário */
.mamopro-appointment-shortcode-wrap .jet-apb-calendar-body{
    display:grid;
    grid-template-columns:repeat(7,1fr);
    gap:8px;
}

/* Datas */
.mamopro-appointment-shortcode-wrap .jet-apb-calendar-date{
    min-height:56px;
}

.mamopro-appointment-shortcode-wrap .jet-apb-calendar-date-body{
    width:100%;
    min-height:56px;
    display:flex;
    align-items:center;
    justify-content:center;
    border:1px solid #E3EAF2;
    border-radius:16px;
    background:#fff;
    color:var(--mp-dark);
    font-size:15px;
    font-weight:700;
    transition:all .22s ease;
    cursor:pointer;
}

/* Hover dia ativo */
.mamopro-appointment-shortcode-wrap .jet-apb-calendar-date[data-status="true"] .jet-apb-calendar-date-body:hover{
    border-color:rgba(46,159,208,.55);
    background:#F4FAFF;
    color:var(--mp-blue);
    transform:translateY(-1px);
    box-shadow:0 10px 20px rgba(46,159,208,.10);
}

/* Hoje */
.mamopro-appointment-shortcode-wrap .jet-apb-calendar-date--today .jet-apb-calendar-date-body{
    border-color:rgba(250,125,170,.45);
    box-shadow:0 0 0 3px rgba(250,125,170,.10);
}

/* Selecionado */
.mamopro-appointment-shortcode-wrap .jet-apb-calendar-date--selected .jet-apb-calendar-date-body,
.mamopro-appointment-shortcode-wrap .jet-apb-calendar-date.is-selected .jet-apb-calendar-date-body,
.mamopro-appointment-shortcode-wrap .jet-apb-calendar-date-body[aria-selected="true"]{
    background:linear-gradient(135deg,var(--mp-blue),var(--mp-cyan));
    color:#fff;
    border-color:transparent;
    box-shadow:0 16px 30px rgba(30,58,138,.20);
}

/* Bloqueado */
.mamopro-appointment-shortcode-wrap .jet-apb-calendar-date--disabled .jet-apb-calendar-date-body,
.mamopro-appointment-shortcode-wrap .jet-apb-calendar-date[data-status="false"] .jet-apb-calendar-date-body{
    background:#F8FAFC;
    color:#B6C0CC;
    border-color:#EEF2F6;
    cursor:not-allowed;
    box-shadow:none;
}

/* Área de slots */
.mamopro-appointment-shortcode-wrap .jet-apb-calendar-slots{
    grid-column:1/-1;
    margin:8px 0 4px;
    padding:14px !important;
    border-radius:18px;
    background:#F8FBFF;
    border:1px dashed #D8E6F3;
}

/* Botões de horário */
.mamopro-appointment-shortcode-wrap .jet-apb-slot,
.mamopro-appointment-shortcode-wrap .jet-apb-slot-button,
.mamopro-appointment-shortcode-wrap .jet-apb-calendar-slot{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:42px;
    padding:0 14px;
    border-radius:999px;
    border:1px solid #D6E2EE;
    background:#fff;
    color:var(--mp-dark);
    font-size:14px;
    font-weight:700;
    margin:4px 6px 4px 0;
    transition:all .22s ease;
    cursor:pointer;
}

.mamopro-appointment-shortcode-wrap .jet-apb-slot:hover,
.mamopro-appointment-shortcode-wrap .jet-apb-slot-button:hover,
.mamopro-appointment-shortcode-wrap .jet-apb-calendar-slot:hover{
    border-color:rgba(46,159,208,.55);
    background:#F4FAFF;
    color:var(--mp-blue);
}

.mamopro-appointment-shortcode-wrap .jet-apb-slot.is-selected,
.mamopro-appointment-shortcode-wrap .jet-apb-slot-button.is-selected,
.mamopro-appointment-shortcode-wrap .jet-apb-calendar-slot.is-selected,
.mamopro-appointment-shortcode-wrap .jet-apb-slot[aria-pressed="true"]{
    background:linear-gradient(135deg,var(--mp-blue),var(--mp-cyan));
    color:#fff;
    border-color:transparent;
}

/* Lista de detalhes da reserva */
.mamopro-appointment-shortcode-wrap .jet-apb-calendar-appointments-list-wrapper{
    margin-top:16px;
    padding:16px;
    border-radius:18px;
    background:#F8FBFF;
    border:1px solid #DCE8F4;
}

.mamopro-appointment-shortcode-wrap .jet-apb-calendar-appointments-list-wrapper .jet-form__heading{
    margin-bottom:10px;
}

.mamopro-appointment-shortcode-wrap .jet-apb-calendar-appointments-list-wrapper .jet-form__label-text{
    font-size:13px;
    text-transform:uppercase;
    letter-spacing:.08em;
    color:var(--mp-blue);
}

/* Responsivo */
@media (max-width: 767px){
    .mamopro-appointment-shortcode-wrap .jet-form{
        padding:18px;
        border-radius:22px;
    }

    .mamopro-appointment-shortcode-wrap .jet-apb-calendar-wrapper{
        padding:14px;
        border-radius:18px;
    }

    .mamopro-appointment-shortcode-wrap .jet-apb-calendar-header__label{
        font-size:17px;
    }

    .mamopro-appointment-shortcode-wrap .jet-apb-calendar-body{
        gap:6px;
    }

    .mamopro-appointment-shortcode-wrap .jet-apb-calendar-date-body{
        min-height:48px;
        border-radius:14px;
        font-size:14px;
    }

    .mamopro-appointment-shortcode-wrap .jet-apb-calendar-week span{
        font-size:11px;
    }

    .mamopro-appointment-shortcode-wrap .jet-form__submit{
        min-height:50px;
        font-size:15px;
    }
}

.mamopro-appointment-shortcode-wrap .mamopro-slot-blocked {
    display: none !important;
    pointer-events: none !important;
}
