/* =============================================================================
   TEMA CLÍNICA DIGITAL — Inspirado em Dr. Consulta / Telemedicina
   Customização visual para Easy!Appointments
   ============================================================================= */

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

/* ── VARIÁVEIS ─────────────────────────────────────────────────────────────── */
:root {
    --cl-blue:        #0047CC;
    --cl-blue-dark:   #003399;
    --cl-blue-light:  #E8F0FE;
    --cl-green:       #00C853;
    --cl-green-dark:  #009B3E;
    --cl-white:       #FFFFFF;
    --cl-gray-50:     #F8FAFC;
    --cl-gray-100:    #F1F5F9;
    --cl-gray-200:    #E2E8F0;
    --cl-gray-500:    #64748B;
    --cl-gray-700:    #334155;
    --cl-gray-900:    #0F172A;
    --cl-shadow-sm:   0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);
    --cl-shadow:      0 4px 16px rgba(0,71,204,.10), 0 1px 4px rgba(0,0,0,.06);
    --cl-shadow-lg:   0 10px 40px rgba(0,71,204,.15), 0 4px 12px rgba(0,0,0,.08);
    --cl-radius:      16px;
    --cl-radius-sm:   8px;
    --cl-radius-xs:   4px;
}

/* ── BASE ──────────────────────────────────────────────────────────────────── */
html, body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
    background-color: var(--cl-gray-50) !important;
    color: var(--cl-gray-900) !important;
    -webkit-font-smoothing: antialiased;
}

/* ── CLINICA HEADER / NAVBAR ───────────────────────────────────────────────── */
.cl-navbar {
    background: var(--cl-white);
    border-bottom: 1px solid var(--cl-gray-200);
    padding: 0 24px;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: sticky;
    top: 0;
    z-index: 1000;
    box-shadow: 0 1px 8px rgba(0,0,0,.06);
}

.cl-navbar-brand {
    display: flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
}

.cl-navbar-brand .cl-brand-icon {
    width: 36px;
    height: 36px;
    background: linear-gradient(135deg, var(--cl-blue) 0%, var(--cl-green) 100%);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 18px;
}

.cl-navbar-brand .cl-brand-name {
    font-size: 20px;
    font-weight: 800;
    color: var(--cl-gray-900);
    letter-spacing: -0.5px;
}

.cl-navbar-brand .cl-brand-name span {
    color: var(--cl-blue);
}

.cl-navbar-tag {
    background: var(--cl-blue-light);
    color: var(--cl-blue);
    font-size: 11px;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 20px;
    letter-spacing: 0.5px;
    text-transform: uppercase;
}

.cl-navbar-actions {
    display: flex;
    align-items: center;
    gap: 12px;
}

.cl-btn-nav {
    padding: 8px 20px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    transition: all .2s ease;
    border: none;
    cursor: pointer;
}

.cl-btn-nav-outline {
    background: transparent;
    color: var(--cl-blue);
    border: 1.5px solid var(--cl-blue);
}

.cl-btn-nav-outline:hover {
    background: var(--cl-blue-light);
    color: var(--cl-blue-dark);
}

.cl-btn-nav-solid {
    background: var(--cl-blue);
    color: var(--cl-white);
}

.cl-btn-nav-solid:hover {
    background: var(--cl-blue-dark);
    color: var(--cl-white);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0,71,204,.35);
}

/* ── HERO SECTION ──────────────────────────────────────────────────────────── */
.cl-hero {
    background: linear-gradient(135deg, var(--cl-blue-dark) 0%, var(--cl-blue) 55%, #1565C0 100%);
    padding: 56px 24px 80px;
    position: relative;
    overflow: hidden;
}

.cl-hero::before {
    content: '';
    position: absolute;
    top: -60px;
    right: -60px;
    width: 340px;
    height: 340px;
    background: rgba(255,255,255,.05);
    border-radius: 50%;
}

.cl-hero::after {
    content: '';
    position: absolute;
    bottom: -80px;
    right: 120px;
    width: 200px;
    height: 200px;
    background: rgba(0,200,83,.12);
    border-radius: 50%;
}

.cl-hero-blob {
    position: absolute;
    top: 30px;
    right: 5%;
    width: 220px;
    height: 220px;
    background: rgba(255,255,255,.06);
    border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%;
    animation: cl-blob-morph 8s ease-in-out infinite;
}

@keyframes cl-blob-morph {
    0%, 100% { border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%; }
    50%       { border-radius: 30% 60% 70% 40% / 50% 60% 30% 60%; }
}

.cl-hero-inner {
    max-width: 640px;
    margin: 0 auto;
    position: relative;
    z-index: 2;
}

.cl-hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: rgba(0,200,83,.18);
    border: 1px solid rgba(0,200,83,.35);
    color: #69F0AE;
    font-size: 12px;
    font-weight: 600;
    padding: 5px 12px;
    border-radius: 20px;
    margin-bottom: 20px;
    letter-spacing: 0.4px;
}

.cl-hero-badge::before {
    content: '';
    width: 7px;
    height: 7px;
    background: #00C853;
    border-radius: 50%;
    box-shadow: 0 0 0 3px rgba(0,200,83,.3);
    animation: cl-pulse 1.8s ease-in-out infinite;
}

@keyframes cl-pulse {
    0%, 100% { box-shadow: 0 0 0 3px rgba(0,200,83,.3); }
    50%       { box-shadow: 0 0 0 6px rgba(0,200,83,.1); }
}

.cl-hero h1 {
    font-size: clamp(26px, 5vw, 40px);
    font-weight: 900;
    color: var(--cl-white);
    line-height: 1.15;
    letter-spacing: -1px;
    margin-bottom: 16px;
}

.cl-hero h1 em {
    font-style: normal;
    color: #69F0AE;
}

.cl-hero-subtitle {
    font-size: 16px;
    color: rgba(255,255,255,.75);
    line-height: 1.6;
    margin-bottom: 32px;
    font-weight: 400;
}

.cl-hero-cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--cl-green);
    color: var(--cl-white);
    font-size: 16px;
    font-weight: 700;
    padding: 14px 32px;
    border-radius: 12px;
    text-decoration: none;
    transition: all .25s ease;
    box-shadow: 0 4px 20px rgba(0,200,83,.4);
    border: none;
    cursor: pointer;
}

.cl-hero-cta:hover {
    background: var(--cl-green-dark);
    color: var(--cl-white);
    transform: translateY(-2px);
    box-shadow: 0 8px 28px rgba(0,200,83,.5);
}

.cl-hero-trust {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-top: 28px;
    flex-wrap: wrap;
}

.cl-hero-trust-item {
    display: flex;
    align-items: center;
    gap: 6px;
    color: rgba(255,255,255,.7);
    font-size: 13px;
    font-weight: 500;
}

.cl-hero-trust-item i {
    color: #69F0AE;
    font-size: 14px;
}

/* ── FEATURES STRIP ────────────────────────────────────────────────────────── */
.cl-features {
    background: var(--cl-blue);
    padding: 24px;
}

.cl-features-grid {
    max-width: 900px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 16px;
}

.cl-feature-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 8px;
}

.cl-feature-icon {
    width: 36px;
    height: 36px;
    background: rgba(255,255,255,.12);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #69F0AE;
    font-size: 16px;
    flex-shrink: 0;
}

.cl-feature-text {
    font-size: 12px;
    color: rgba(255,255,255,.85);
    line-height: 1.4;
    font-weight: 500;
}

/* ── WIZARD WRAPPER ────────────────────────────────────────────────────────── */
.cl-wizard-section {
    padding: 40px 16px 60px;
    background: var(--cl-gray-50);
}

.cl-wizard-title {
    text-align: center;
    margin-bottom: 32px;
}

.cl-wizard-title h2 {
    font-size: clamp(22px, 4vw, 30px);
    font-weight: 800;
    color: var(--cl-gray-900);
    letter-spacing: -0.5px;
    margin-bottom: 8px;
}

.cl-wizard-title p {
    font-size: 15px;
    color: var(--cl-gray-500);
    font-weight: 400;
}

/* ── OVERRIDE BOOK APPOINTMENT WIZARD ─────────────────────────────────────── */
#main {
    padding: 0 !important;
    max-width: 100% !important;
}

/* Remove old container constraints */
#main.container {
    max-width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.row.wrapper {
    min-height: unset !important;
    margin: 0 !important;
    display: block !important;
}

#book-appointment-wizard {
    max-width: 800px !important;
    margin: 0 auto !important;
    border-radius: var(--cl-radius) !important;
    overflow: hidden !important;
    box-shadow: var(--cl-shadow-lg) !important;
    background: var(--cl-white) !important;
}

/* ──────────────────────────────────────────────────────
   HEADER DO WIZARD — layout flex horizontal
────────────────────────────────────────────────────── */
#book-appointment-wizard #header {
    background: linear-gradient(135deg, var(--cl-blue-dark) 0%, var(--cl-blue) 100%) !important;
    padding: 16px 24px !important;
    height: auto !important;
    overflow: visible !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 16px !important;
}

/* Company name — bloco da esquerda */
#book-appointment-wizard #company-name {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    float: none !important;
    color: var(--cl-white) !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    letter-spacing: -0.3px !important;
    margin: 0 !important;
    min-width: 0 !important;
    flex: 1 !important;
}

/* Esconde o logo padrão (checkmark feio) quando for o logo default */
#book-appointment-wizard #company-name #company-logo {
    max-height: 40px !important;
    max-width: 40px !important;
    border-radius: 8px !important;
    flex-shrink: 0 !important;
    object-fit: contain !important;
    /* Esconde se for o logo padrão do sistema */
    display: none !important;
}

/* Ícone substituto quando não há logo personalizado */
#book-appointment-wizard #company-name::before {
    content: '';
    display: inline-flex !important;
    width: 36px !important;
    height: 36px !important;
    background: rgba(255,255,255,.15) !important;
    border-radius: 10px !important;
    flex-shrink: 0 !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M12 21.593c-5.63-5.539-11-10.297-11-14.402 0-3.791 3.068-5.191 5.281-5.191 1.312 0 4.151.501 5.719 4.457 1.59-3.968 4.464-4.447 5.726-4.447 2.54 0 5.274 1.621 5.274 5.181 0 4.069-5.136 8.625-11 14.402z'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    background-size: 18px !important;
}

#book-appointment-wizard #company-name span {
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    line-height: 1.2 !important;
}

#book-appointment-wizard #company-name .display-booking-selection {
    display: none !important;   /* Remove o "Serviço | Profissional" poluído */
}

/* ──────────────────────────────────────────────────────
   STEPS — barra de progresso horizontal no header
────────────────────────────────────────────────────── */
#book-appointment-wizard #steps {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    float: none !important;
    width: auto !important;
    margin: 0 !important;
    flex-shrink: 0 !important;
}

#book-appointment-wizard .book-step {
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    background: rgba(255,255,255,.18) !important;
    border: 2px solid rgba(255,255,255,.25) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    float: none !important;
    margin: 0 !important;
    padding: 0 !important;
    transition: all .25s ease !important;
    position: relative !important;
}

/* Linha conectora entre steps */
#book-appointment-wizard .book-step:not(:last-child)::after {
    content: '' !important;
    position: absolute !important;
    left: calc(100% + 3px) !important;
    width: 6px !important;
    height: 2px !important;
    background: rgba(255,255,255,.25) !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
}

#book-appointment-wizard .book-step strong {
    color: rgba(255,255,255,.65) !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    display: block !important;
    text-align: center !important;
}

#book-appointment-wizard .active-step {
    width: 36px !important;
    height: 36px !important;
    background: var(--cl-green) !important;
    border-color: var(--cl-green) !important;
    box-shadow: 0 0 0 4px rgba(0,200,83,.25), 0 4px 12px rgba(0,200,83,.5) !important;
    margin: 0 !important;
}

#book-appointment-wizard .active-step strong {
    color: var(--cl-white) !important;
    font-size: 14px !important;
    font-weight: 800 !important;
}

/* ──────────────────────────────────────────────────────
   TÍTULO DO FRAME — sem all-caps
────────────────────────────────────────────────────── */
#book-appointment-wizard .frame-container .frame-title {
    font-size: 20px !important;
    font-weight: 700 !important;
    color: var(--cl-gray-900) !important;
    letter-spacing: -0.3px !important;
    text-transform: none !important;
    margin-bottom: 20px !important;
}

/* ──────────────────────────────────────────────────────
   FRAMES / CONTEÚDO
────────────────────────────────────────────────────── */
#book-appointment-wizard .wizard-frame {
    padding: 24px 28px !important;
}

#book-appointment-wizard .wizard-frame .frame-container {
    min-height: 380px !important;
    padding: 8px 0 !important;
}

/* Form inputs */
#book-appointment-wizard .form-select,
#book-appointment-wizard .form-control {
    border-radius: var(--cl-radius-sm) !important;
    border: 1.5px solid var(--cl-gray-200) !important;
    padding: 10px 14px !important;
    font-size: 14px !important;
    font-family: 'Inter', sans-serif !important;
    transition: border-color .2s ease, box-shadow .2s ease !important;
    background-color: var(--cl-white) !important;
}

#book-appointment-wizard .form-select:focus,
#book-appointment-wizard .form-control:focus {
    border-color: var(--cl-blue) !important;
    box-shadow: 0 0 0 3px rgba(0,71,204,.12) !important;
    outline: none !important;
}

#book-appointment-wizard label,
#book-appointment-wizard .form-label {
    font-size: 12px !important;
    font-weight: 600 !important;
    color: var(--cl-gray-500) !important;
    letter-spacing: 0.5px !important;
    text-transform: uppercase !important;
    margin-bottom: 6px !important;
}

/* Botões de navegação */
#book-appointment-wizard .command-buttons {
    padding: 16px 0 8px !important;
    border-top: 1px solid var(--cl-gray-100) !important;
    margin-top: 16px !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
}

#book-appointment-wizard .btn-dark,
#book-appointment-wizard .button-next.btn-dark {
    background: var(--cl-blue) !important;
    border-color: var(--cl-blue) !important;
    color: var(--cl-white) !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    padding: 11px 32px !important;
    border-radius: 10px !important;
    transition: all .2s ease !important;
    letter-spacing: 0.3px !important;
}

#book-appointment-wizard .btn-dark:hover,
#book-appointment-wizard .button-next.btn-dark:hover {
    background: var(--cl-blue-dark) !important;
    border-color: var(--cl-blue-dark) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 14px rgba(0,71,204,.4) !important;
}

#book-appointment-wizard .btn-outline-secondary,
#book-appointment-wizard .button-back.btn-outline-secondary {
    border-color: var(--cl-gray-200) !important;
    color: var(--cl-gray-500) !important;
    font-weight: 500 !important;
    font-size: 14px !important;
    padding: 11px 24px !important;
    border-radius: 10px !important;
    background: transparent !important;
    transition: all .2s ease !important;
}

#book-appointment-wizard .btn-outline-secondary:hover {
    background: var(--cl-gray-100) !important;
    border-color: var(--cl-gray-200) !important;
    color: var(--cl-gray-900) !important;
}

/* ──────────────────────────────────────────────────────
   HORÁRIOS — grid 2 colunas, compacto
────────────────────────────────────────────────────── */
#book-appointment-wizard #available-hours {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    grid-auto-rows: max-content !important;
    align-content: start !important;
    gap: 8px !important;
    max-height: 300px !important;
    overflow-y: auto !important;
    padding-right: 4px !important;
    margin: 12px 0 !important;
    /* scrollbar customizada */
    scrollbar-width: thin !important;
    scrollbar-color: var(--cl-blue) var(--cl-gray-100) !important;
}

#book-appointment-wizard #available-hours::-webkit-scrollbar {
    width: 5px !important;
}

#book-appointment-wizard #available-hours::-webkit-scrollbar-track {
    background: var(--cl-gray-100) !important;
    border-radius: 99px !important;
}

#book-appointment-wizard #available-hours::-webkit-scrollbar-thumb {
    background: var(--cl-blue) !important;
    border-radius: 99px !important;
}

#book-appointment-wizard #available-hours div {
    margin: 0 !important;
}

#book-appointment-wizard #available-hours .available-hour {
    border-radius: 8px !important;
    border: 1.5px solid var(--cl-gray-200) !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--cl-gray-700) !important;
    transition: all .18s ease !important;
    padding: 8px 6px !important;
    text-align: center !important;
    width: 100% !important;
    background: var(--cl-white) !important;
    cursor: pointer !important;
    display: block !important;
}

#book-appointment-wizard #available-hours .available-hour:hover {
    border-color: var(--cl-blue) !important;
    color: var(--cl-blue) !important;
    background: var(--cl-blue-light) !important;
    transform: translateY(-1px) !important;
}

#book-appointment-wizard #available-hours .selected-hour {
    background: var(--cl-blue) !important;
    border-color: var(--cl-blue) !important;
    color: var(--cl-white) !important;
    box-shadow: 0 2px 8px rgba(0,71,204,.35) !important;
    transform: none !important;
}

/* ──────────────────────────────────────────────────────
   CALENDÁRIO FLATPICKR — 100% azul, sem verde
────────────────────────────────────────────────────── */
#book-appointment-wizard .flatpickr-calendar {
    border-radius: 12px !important;
    box-shadow: var(--cl-shadow) !important;
    border: 1px solid var(--cl-gray-200) !important;
    font-family: 'Inter', sans-serif !important;
    overflow: hidden !important;
}

/* Cabeçalho do mês — azul */
.flatpickr-months,
.flatpickr-month,
.flatpickr-months .flatpickr-month {
    background: var(--cl-blue) !important;
    color: var(--cl-white) !important;
    fill: var(--cl-white) !important;
    border-radius: 0 !important;
}

.flatpickr-current-month .flatpickr-monthDropdown-months {
    background: transparent !important;
    color: var(--cl-white) !important;
    font-weight: 700 !important;
    font-size: 15px !important;
}

.flatpickr-current-month input.cur-year {
    color: var(--cl-white) !important;
    font-weight: 700 !important;
    font-size: 15px !important;
}

.flatpickr-prev-month,
.flatpickr-next-month {
    fill: var(--cl-white) !important;
    color: var(--cl-white) !important;
}

.flatpickr-prev-month:hover svg,
.flatpickr-next-month:hover svg {
    fill: rgba(255,255,255,.7) !important;
}

/* Dias da semana */
.flatpickr-weekdays {
    background: var(--cl-blue-light) !important;
}

.flatpickr-weekday {
    color: var(--cl-blue) !important;
    font-weight: 700 !important;
    font-size: 11px !important;
    text-transform: uppercase !important;
    background: transparent !important;
}

/* Dias */
.flatpickr-days {
    border-left: none !important;
    border-right: none !important;
}

.flatpickr-day {
    border-radius: 8px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    color: var(--cl-gray-700) !important;
}

.flatpickr-day:hover:not(.disabled):not(.selected) {
    background: var(--cl-blue-light) !important;
    border-color: var(--cl-blue-light) !important;
    color: var(--cl-blue) !important;
}

.flatpickr-day.selected,
.flatpickr-day.selected:hover {
    background: var(--cl-blue) !important;
    border-color: var(--cl-blue) !important;
    color: var(--cl-white) !important;
    font-weight: 700 !important;
}

.flatpickr-day.today:not(.selected) {
    border-color: var(--cl-blue) !important;
    color: var(--cl-blue) !important;
    font-weight: 700 !important;
    background: transparent !important;
}

.flatpickr-day.disabled,
.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay {
    color: var(--cl-gray-200) !important;
}

/* ──────────────────────────────────────────────────────
   FOOTER DO WIZARD
────────────────────────────────────────────────────── */
#book-appointment-wizard #frame-footer {
    border-top: 1px solid var(--cl-gray-100) !important;
    padding: 12px 24px !important;
    background: var(--cl-gray-50) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
}

#book-appointment-wizard #frame-footer a {
    color: var(--cl-blue) !important;
    font-weight: 500 !important;
    font-size: 12px !important;
}

#book-appointment-wizard .footer-powered-by,
#book-appointment-wizard .footer-options {
    font-size: 12px !important;
    color: var(--cl-gray-500) !important;
}

#book-appointment-wizard .badge.bg-secondary {
    background: var(--cl-gray-100) !important;
    color: var(--cl-gray-600) !important;
    font-weight: 500 !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    font-size: 11px !important;
}

#book-appointment-wizard .badge.bg-primary {
    background: var(--cl-blue) !important;
    border-radius: 6px !important;
    font-size: 11px !important;
}

/* Mensagem de sucesso */
#success-frame, #message-frame {
    background: var(--cl-white) !important;
    border-radius: 0 !important;
}

#success-frame .btn,
#message-frame .btn {
    border-radius: 10px !important;
}

/* ── FOOTER DA PÁGINA ──────────────────────────────────────────────────────── */
.cl-page-footer {
    background: var(--cl-gray-900);
    color: rgba(255,255,255,.5);
    padding: 32px 24px;
    text-align: center;
    font-size: 13px;
}

.cl-page-footer a {
    color: rgba(255,255,255,.7);
    text-decoration: none;
}

.cl-page-footer a:hover {
    color: var(--cl-white);
}

/* ── SEÇÃO DE COMO FUNCIONA ────────────────────────────────────────────────── */
.cl-how-section {
    background: var(--cl-white);
    padding: 48px 24px;
    border-bottom: 1px solid var(--cl-gray-100);
}

.cl-how-inner {
    max-width: 860px;
    margin: 0 auto;
}

.cl-section-label {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 1.5px;
    color: var(--cl-blue);
    text-transform: uppercase;
    margin-bottom: 8px;
}

.cl-section-title {
    font-size: clamp(20px, 3.5vw, 28px);
    font-weight: 800;
    color: var(--cl-gray-900);
    letter-spacing: -0.5px;
    margin-bottom: 10px;
}

.cl-section-sub {
    font-size: 15px;
    color: var(--cl-gray-500);
    margin-bottom: 36px;
    line-height: 1.6;
}

.cl-steps-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 24px;
}

.cl-step-card {
    background: var(--cl-gray-50);
    border: 1px solid var(--cl-gray-100);
    border-radius: var(--cl-radius);
    padding: 24px 20px;
    text-align: center;
    transition: all .25s ease;
    position: relative;
}

.cl-step-card:hover {
    box-shadow: var(--cl-shadow);
    transform: translateY(-2px);
    border-color: var(--cl-blue-light);
}

.cl-step-number {
    width: 44px;
    height: 44px;
    background: linear-gradient(135deg, var(--cl-blue) 0%, var(--cl-green) 100%);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    font-weight: 900;
    color: white;
    margin: 0 auto 14px;
    box-shadow: 0 4px 14px rgba(0,71,204,.3);
}

.cl-step-title {
    font-size: 15px;
    font-weight: 700;
    color: var(--cl-gray-900);
    margin-bottom: 6px;
}

.cl-step-desc {
    font-size: 13px;
    color: var(--cl-gray-500);
    line-height: 1.5;
}

/* ── RESPONSIVIDADE ────────────────────────────────────────────────────────── */
@media (max-width: 600px) {
    .cl-navbar-actions { gap: 6px; }
    .cl-btn-nav { padding: 6px 14px; font-size: 13px; }
    .cl-hero { padding: 40px 16px 60px; }
    .cl-hero-trust { gap: 12px; }
    .cl-how-section { padding: 36px 16px; }
    .cl-wizard-section { padding: 24px 12px 48px; }
    #book-appointment-wizard .wizard-frame { padding: 16px 16px !important; }
    .cl-features-grid { grid-template-columns: repeat(2, 1fr); }
}
