﻿:host { display: block; }
/* home: valdes-home.html */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
.directory-page-root {
  --teal: #1dbfad; --teal-light: #e6f9f7; --teal-dark: #12a89a;
  --gold: #f5a623; --text: #1a1a2e; --muted: #6b7280;
  --border: #e5e7eb; --bg: #fff; --white: #fff;
  --orange: #f97316; --nav-h: var(--tc-navbar-height, 60px);
  --hero-bg: #e8f5f4;
  --section-alt: #fffbf0;
}
.directory-page-root { overflow-x: hidden; font-family: "Open Sans", Arial, Helvetica, sans-serif; background: var(--white); color: var(--text); font-size: 15px; line-height: 1.6; }
.directory-page-root .hero-title,
.directory-page-root .section-title,
.directory-page-root .cat-page-back,
.directory-page-root .cat-page-title,
.directory-page-root .category-card-name,
.directory-page-root .service-card-name,
.directory-page-root .company-card-name,
.directory-page-root .urgency-card-name,
.directory-page-root .results-title,
.directory-page-root .filters-title,
.directory-page-root .filter-label,
.directory-page-root .filter-drawer-title,
.directory-page-root .breadcrumb-current,
.directory-page-root .dp-filter-chip,
.directory-page-root .dp-sidebar-apply-btn,
.directory-page-root .drawer-apply-btn,
.directory-page-root .category-token-chip,
.directory-page-root .provider-card-badge,
.directory-page-root .provider-logo-initials,
.directory-page-root .provider-name,
.directory-page-root .provider-stars .ps-score,
.directory-page-root .provider-category,
.directory-page-root .provider-meta-row strong,
.directory-page-root .page-btn,
.directory-page-root .profile-name,
.directory-page-root .response-pill strong,
.directory-page-root .tab-btn,
.directory-page-root .card-title,
.directory-page-root .rating-num,
.directory-page-root .bar-num,
.directory-page-root .reviewer-name,
.directory-page-root .review-heading,
.directory-page-root .review-heading-sm,
.directory-page-root .doc-name,
.directory-page-root .cinfo-label,
.directory-page-root .offer-name,
.directory-page-root .offer-disc,
.directory-page-root .cta-title,
.directory-page-root .presup-title,
.directory-page-root .form-section-label,
.directory-page-root .form-section-label2,
.directory-page-root .presup-sidebar-label,
.directory-page-root .presup-provider-name,
.directory-page-root .presup-tips-title,
.directory-page-root .presup-sidebar-heading,
.directory-page-root .presup-step-title,
.directory-page-root .modal-title,
.directory-page-root .modal-label,
.directory-page-root .hero-search-btn,
.directory-page-root .btn-see-all,
.directory-page-root .btn-ver,
.directory-page-root .btn-presup,
.directory-page-root .btn-teal,
.directory-page-root .btn-outline,
.directory-page-root .btn-ghost,
.directory-page-root .btn-outline-w,
.directory-page-root .btn-detail-full,
.directory-page-root .btn-teal-w,
.directory-page-root .btn-teal-lg,
.directory-page-root .btn-cancel,
.directory-page-root .btn-send,
.directory-page-root strong {
  font-family: "Montserrat", "Open Sans", Arial, Helvetica, sans-serif;
}
/* profile sticky needs visible overflow in integrated layout */
.directory-profile-root,
.directory-profile-root .page,
.directory-profile-root .content-layout { overflow: visible; }

/* NAV */

/* HERO */
.directory-page-root.directory-home-root {
  background:
    linear-gradient(180deg,
      #e8f5f4 0%,
      #edf8f7 22rem,
      rgba(239, 249, 248, .72) 36rem,
      rgba(247, 252, 251, .36) 54rem,
      rgba(255, 255, 255, 0) 76rem),
    #fff;
}
.directory-home-root .hero { background: transparent; }
.hero { background: var(--hero-bg); padding: 5rem 1.5rem 4rem; text-align: center; }
.hero-inner { max-width: 800px; margin: 0 auto; }
.hero-title { font-size: 3rem; font-weight: 800; line-height: 1.15; letter-spacing: -.5px; margin-bottom: 1rem; color: var(--text); }
.hero-sub { font-size: 1rem; color: var(--muted); margin-bottom: 2.5rem; }
.hero-search { display: flex; max-width: 580px; margin: 0 auto; background: white; border-radius: 99px; border: 1.5px solid var(--border); box-shadow: 0 4px 20px rgba(0,0,0,.08); overflow: visible; position: relative; isolation: isolate; transition: border-color .22s ease, box-shadow .22s ease, transform .22s ease; }
.hero-search:hover { box-shadow: 0 10px 28px rgba(0,0,0,.10); }
.hero-search.is-focused { border-color: rgba(29,191,173,.55); box-shadow: 0 16px 36px rgba(29,191,173,.14), 0 0 0 4px rgba(29,191,173,.10); transform: translateY(-1px); }
.hero-search-main { flex: 1; display: flex; align-items: center; padding: .7rem 1.25rem; gap: .6rem; transition: background-color .2s ease; position: relative; overflow: visible; }
.hero-search-main svg { color: var(--muted); flex-shrink: 0; transition: color .2s ease; }
.hero-search-main input { border: none; outline: none; font-family: inherit; font-size: .9rem; color: var(--text); width: 100%; background: transparent; }
.hero-search-main input::placeholder { color: var(--muted); }
.hero-search-divider { width: 1px; background: var(--border); flex-shrink: 0; transition: opacity .18s ease; }
.hero-search-location { display: flex; align-items: center; padding: .7rem 1.25rem; gap: .5rem; cursor: pointer; transition: background-color .2s ease; }
.hero-search-location svg { color: var(--teal); flex-shrink: 0; transition: color .2s ease, transform .18s ease; }
.hero-search-location span { font-size: .875rem; color: var(--muted); white-space: nowrap; }
.hero-search-btn { background: var(--teal); color: white; border: none; padding: .7rem 1.5rem; font-family: inherit; font-size: .875rem; font-weight: 700; cursor: pointer; transition: background .2s ease, transform .16s ease, box-shadow .2s ease, opacity .2s ease; border-radius: 0 99px 99px 0; white-space: nowrap; }
.hero-search-btn:hover { background: var(--teal-dark); box-shadow: inset 0 0 0 999px rgba(0,0,0,.03); }
.hero-search-btn:active { transform: translateY(1px); }
.hero-search-btn.is-soft { opacity: .78; }
.hero-help-action { margin-top: 1.05rem; display: flex; justify-content: center; }
.hero-help-link { display: inline-flex; align-items: center; gap: .48rem; padding: .3rem .78rem .3rem .66rem; border-radius: 999px; border: 2px solid #dfe5e8; background: #fff; color: #111111; text-decoration: none; box-shadow: none; transition: border-color .18s ease, background-color .18s ease; }
.hero-help-link:hover { border-color: #dfe5e8; background: #fff; box-shadow: none; transform: none; color: #111111; }
.hero-help-link-icon { width: 24px; height: 24px; display: inline-flex; align-items: center; justify-content: center; background: transparent; border: 0; color: #1ac0b2 !important; flex-shrink: 0; }
.hero-help-link-icon svg { width: 21px; height: 21px; color: #1ac0b2 !important; stroke: #1ac0b2 !important; }
.hero-help-link-label { font-family: "Montserrat", "Open Sans", Arial, Helvetica, sans-serif; font-size: .87rem; font-weight: 400; line-height: .95; letter-spacing: -.01em; color: #111111; }

/* HELP CTA BAND */
.help-cta-band { display: flex; align-items: center; justify-content: space-between; gap: 1.35rem; overflow: hidden; border-radius: 20px; padding: 2rem 2.1rem; background: linear-gradient(180deg, rgba(207, 234, 232, 0.20) 35.58%, rgba(255, 255, 255, 0.20) 100%), linear-gradient(90deg, #eef9f8 0%, #d7f4f0 52%, #96dfd9 100%); }
.help-cta-copy { flex: 0 0 48%; max-width: 560px; }
.help-cta-title { font-family: "Montserrat", "Open Sans", Arial, Helvetica, sans-serif; font-size: 1.62rem; font-weight: 700; line-height: 1.14; letter-spacing: 0; margin-bottom: .58rem; color: #24334a; }
.help-cta-sub { font-family: "Open Sans", Arial, Helvetica, sans-serif; font-size: .98rem; font-weight: 400; color: #24334a; line-height: 1.45; margin-bottom: 1.18rem; }
.help-cta-points { display: flex; flex-direction: column; gap: .72rem; margin-bottom: 1.4rem; }
.help-cta-point { display: flex; align-items: center; gap: .62rem; font-size: .92rem; color: #24334a; }
.help-cta-point-icon { width: 19px; height: 19px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; background: rgba(255,255,255,.92); color: var(--teal-dark); flex-shrink: 0; box-shadow: none; }
.help-cta-button { min-width: auto; padding: .44rem 1rem; font-size: .78rem; font-weight: 600; line-height: 1.15; box-shadow: none; }
.help-cta-button:hover,
.help-cta-button:active { box-shadow: none; transform: none; }
.help-cta-visual { flex: 0 0 52%; min-width: 0; display: flex; align-items: center; justify-content: flex-end; gap: 0; padding-left: 0; transform: translateX(108px); }
.help-cta-circle { width: 174px; height: 174px; border-radius: 50%; overflow: hidden; border: none; box-shadow: none; flex-shrink: 0; background: #dceff0; }
.help-cta-circle img { width: 100%; height: 100%; object-fit: cover; display: block; }
.help-cta-circle + .help-cta-circle { margin-left: 0; }
.help-cta-circle-2 { transform: none; }
.help-cta-circle-3 { transform: none; }
/* REQUIRED FIELD STATE (NO TEXT) */
.field-required-error {
  position: relative;
  z-index: 1;
  background-color: rgba(248,113,113,0);
  box-shadow:
    inset 0 0 0 0 rgba(220, 38, 38, 0),
    0 0 0 0 rgba(220, 38, 38, 0);
  animation: required-field-blink .78s cubic-bezier(.22, .61, .36, 1) 1;
}

.hero-search-main.field-required-error {
  border-radius: 99px 0 0 99px;
}

.hero-search-location.field-required-error {
  border-radius: 0;
}

.hero-search-main.field-required-error + .hero-search-divider {
  opacity: 0;
}

@keyframes required-field-blink {
  0% {
    background-color: rgba(248,113,113,0);
    box-shadow:
      inset 0 0 0 0 rgba(220, 38, 38, 0),
      0 0 0 0 rgba(220, 38, 38, 0);
  }
  38% {
    background-color: rgba(248,113,113,.15);
    box-shadow:
      inset 0 0 0 1.5px rgba(220, 38, 38, .86),
      0 0 0 2px rgba(220, 38, 38, .05);
  }
  62% {
    background-color: rgba(248,113,113,.18);
    box-shadow:
      inset 0 0 0 1.5px rgba(220, 38, 38, .92),
      0 0 0 4px rgba(220, 38, 38, .08);
  }
  100% {
    background-color: rgba(248,113,113,0);
    box-shadow:
      inset 0 0 0 0 rgba(220, 38, 38, 0),
      0 0 0 0 rgba(220, 38, 38, 0);
  }
}

.field-required-error svg {
  color: #dc2626 !important;
  animation: required-field-icon-blink .78s cubic-bezier(.22, .61, .36, 1) 1;
}

@keyframes required-field-icon-blink {
  0%, 100% {
    opacity: .55;
  }
  45%, 62% {
    opacity: 1;
  }
}

/* PAGE WRAPPER */
.page { max-width: 1140px; margin: 0 auto; padding: 0 1.5rem; }

/* SECTION HEADER */
.section-wrap { padding: 3rem 0 2.5rem; }
.section-inner { max-width: 1140px; margin: 0 auto; }
.section-urgent-warning {
  border: 2px solid #ef4444;
  border-radius: 14px;
  padding: 1.2rem 1rem 1.4rem;
  background: #fff;
}
.urgent-warning-note {
  margin-bottom: .9rem;
  font-size: .78rem;
  color: #b91c1c;
  font-weight: 600;
}
.section-alt {
  background: var(--section-alt);
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
  padding-left: calc(50vw - 50%);
  padding-right: calc(50vw - 50%);
}
.section-wrap.alt-bg { background: var(--section-alt); margin: 0 -9999px; padding: 3rem calc(9999px + 1.5rem); }
.section-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1.5rem; }
.section-title { font-size: 1.25rem; font-weight: 800; }
.section-see-all { text-align: center; margin-top: 1.5rem; }
.btn-see-all { display: inline-block; font-size: .875rem; color: var(--text); font-weight: 600; text-decoration: none; cursor: pointer; padding: .5rem 1.5rem; border-radius: 99px; border: 1.5px solid var(--border); background: white; transition: border-color .2s, color .2s; }
.btn-see-all:hover { border-color: var(--teal); color: var(--teal); }

/* COMPANY CARDS */
.cards-row { display: grid; grid-template-columns: repeat(5, 1fr); gap: 1rem; }
.company-card,
.urgency-card { background: white; border-radius: 14px; border: 1.5px solid var(--border); overflow: hidden; cursor: pointer; display: flex; flex-direction: column; }
.company-card { transition: box-shadow .2s, border-color .2s; }
.urgency-card { transition: box-shadow .2s; }
.company-card:hover,
.urgency-card:hover { box-shadow: 0 6px 24px rgba(0,0,0,.1); }
.company-card:hover { border-color: #d1d5db; }
.company-card-logo,
.urgency-card-img { height: 110px; display: flex; align-items: center; justify-content: center; padding: 1rem; background: linear-gradient(135deg, #f8fafc, #eefdf9); }
.company-card-logo {
  border-bottom: 1px solid #dfe6ea;
  background: #eef3f5;
}
.urgency-card-img { position: relative; overflow: hidden; }
.urgency-card-img img { width: 100%; height: 100%; object-fit: cover; }
.company-card-body,
.urgency-card-body { padding: .85rem 1rem 1rem; flex: 1; display: flex; flex-direction: column; gap: .35rem; }
.company-card-name,
.urgency-card-name { font-weight: 700; font-size: .9rem; line-height: 1.3; font-family: "Montserrat", "Open Sans", Arial, Helvetica, sans-serif; }
.company-card-stars,
.urgency-card-stars { display: flex; align-items: center; gap: .25rem; color: var(--gold); font-size: .85rem; }
.company-card-stars .cs-score,
.urgency-card-stars .cs-score { color: var(--text); font-weight: 700; font-size: .82rem; }
.company-card-stars .cs-count,
.urgency-card-stars .cs-count { color: var(--muted); font-size: .75rem; font-weight: 400; }
.company-card-tags,
.urgency-card-tags { display: flex; align-items: center; gap: .35rem; flex-wrap: wrap; }
.company-card-tag,
.urgency-card-tag { display: inline-flex; align-items: center; gap: .3rem; background: #f3f4f6; border: 1px solid var(--border); border-radius: 5px; padding: .18rem .55rem; font-size: .72rem; font-weight: 600; color: #374151; }
.company-card-desc,
.urgency-card-desc { font-size: .78rem; color: var(--muted); line-height: 1.45; display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; min-height: calc(.78rem * 1.45 * 2); }
.company-card-location,
.urgency-card-location { display: flex; align-items: center; gap: .3rem; font-size: .78rem; color: var(--muted); margin-top: auto; padding-top: .35rem; }
.company-card-location svg,
.urgency-card-location svg { color: var(--teal); flex-shrink: 0; }

/* URGENCY CARDS */
.urgency-row { display: grid; grid-template-columns: repeat(5, 1fr); gap: 1rem; }
.urgency-badge { position: absolute; top: 8px; left: 8px; display: inline-flex; align-items: center; gap: .3rem; background: #fef3c7; color: #d97706; border: 1px solid #fde68a; border-radius: 99px; padding: .22rem .6rem; font-size: .7rem; font-weight: 700; line-height: 1; }
.provider-card-logo,
.urgency-card-logo { width: 74px; height: 74px; border-radius: 18px; background: #ffffff; border: 1px solid rgba(20,184,166,.12); box-shadow: 0 10px 24px rgba(20,184,166,.08); display: flex; align-items: center; justify-content: center; color: #14b8a6; font-weight: 800; font-size: 1.45rem; letter-spacing: -.03em; }

/* CATEGORIES GRID */
.categories-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: .75rem; }
.category-card { background: white; border-radius: 12px; border: 1.5px solid var(--border); padding: 1.25rem .75rem .9rem; display: flex; flex-direction: column; align-items: center; gap: .6rem; cursor: pointer; transition: box-shadow .2s, border-color .2s; text-align: center; }
.category-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,.09); border-color: #d1d5db; }
.category-card .category-card-icon,
.category-card svg { width: 44px; height: 44px; flex-shrink: 0; }
.category-card .category-card-icon { display: block; object-fit: contain; }
.category-card svg { color: #3a3e44; }
.category-card-name { font-size: .8rem; font-weight: 600; color: var(--text); line-height: 1.3; }
.categories-grid .category-card.is-desktop-extra { display: none; }

/* SERVICIOS MAS BUSCADOS */
.services-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.service-card { background: white; border-radius: 14px; border: 1.5px solid var(--border); display: flex; align-items: center; gap: 1rem; padding: 0; overflow: hidden; cursor: pointer; transition: box-shadow .2s, border-color .2s; }
.service-card:hover { box-shadow: 0 4px 18px rgba(0,0,0,.09); border-color: #d1d5db; }
.service-card-img { width: 90px; min-width: 90px; height: 90px; overflow: hidden; flex-shrink: 0; }
.service-card-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.service-card-body { padding: .85rem 1rem .85rem 0; }
.service-card-name { font-weight: 700; font-size: .95rem; margin-bottom: .2rem; }
.service-card-count { font-size: .8rem; color: var(--muted); }
.service-card-img-placeholder { display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, #f8fafc, #eefdf9); }
.service-card-img-initials { width: 52px; height: 52px; border-radius: 12px; border: 1px solid rgba(20,184,166,.15); box-shadow: 0 8px 18px rgba(20,184,166,.10); display: flex; align-items: center; justify-content: center; font-size: 1.05rem; font-weight: 800; color: #14b8a6; background: #fff; }

/* FOOTER */

/* CATEGORIES PAGE */
.categories-page { display: none; position: fixed; inset: 0; background: white; z-index: 1200; overflow-y: auto; padding: 1.5rem; }
.categories-page.open { display: block; }
.categories-page-inner { max-width: 480px; margin: 0 auto; padding: 1rem 0; }
.cat-page-back { display: inline-flex; align-items: center; justify-content: center; gap: .35rem; font-size: .9rem; font-weight: 600; cursor: pointer; color: var(--text); background: none; border: none; font-family: inherit; }
.cat-page-back:hover { color: var(--teal); }
.cat-page-title { position: relative; font-size: 1.25rem; font-weight: 800; line-height: 1.2; padding-left: 2.6rem; min-height: 2rem; display: flex; align-items: center; margin: .75rem 0 1.25rem; }
.cat-page-title .cat-page-back {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 2rem;
  height: 2rem;
  padding: 0;
  line-height: 1;
  border-radius: 999px;
  background: #f4f5f7;
  color: #475569;
  transition: background .18s ease, color .18s ease, transform .18s ease;
}
.cat-page-title .cat-page-back:hover {
  background: var(--teal-light);
  color: var(--teal-dark);
  transform: translateY(-50%) translateX(-1px);
}
.cat-page-title .cat-page-back svg { width: 16px; height: 16px; flex-shrink: 0; }
.cat-page-search { display: flex; align-items: center; gap: .6rem; background: #f3f4f6; border-radius: 99px; padding: .55rem 1rem; margin-bottom: 1.5rem; }
.cat-page-search input { border: none; outline: none; background: transparent; font-family: inherit; font-size: .875rem; color: var(--text); flex: 1; }
.cat-page-search svg { color: var(--muted); flex-shrink: 0; }
.cat-page-filter-btn { width: 36px; height: 36px; border: 1.5px solid var(--border); border-radius: 8px; background: white; display: flex; align-items: center; justify-content: center; cursor: pointer; color: var(--teal); flex-shrink: 0; padding: 0; }
.cat-page-filter-btn::before,
.filter-toggle-btn::before {
  content: '';
  width: 18px;
  height: 14px;
  display: block;
  background:
    linear-gradient(currentColor, currentColor) 0 1px / 18px 2px no-repeat,
    linear-gradient(currentColor, currentColor) 4px 6px / 10px 2px no-repeat,
    linear-gradient(currentColor, currentColor) 8px 11px / 4px 2px no-repeat;
  border-radius: 2px;
}
.cat-page-filter-btn svg,
.filter-toggle-btn svg { display: block; color: currentColor; }
.cat-page-filter-btn svg *,
.filter-toggle-btn svg * { fill: none; stroke: currentColor; }
.cat-page-filter-btn > svg,
.filter-toggle-btn > svg { display: none; }
.cat-page-filter-btn.is-disabled { opacity: 1; cursor: default; color: #6b7280; background: #f8fafc; }
.cat-page-filter-btn.is-ready { background: var(--teal); border-color: var(--teal); color: white; }
.cat-page-filter-btn.is-ready:hover { background: var(--teal-dark); border-color: var(--teal-dark); }
.cat-full-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: .75rem; }
.cat-full-grid .category-card.is-hidden { display: none; }
.cat-full-grid .category-card.is-selected { border-color: var(--teal); background: #f0fdf9; box-shadow: 0 8px 22px rgba(29,191,173,.14); }
.cat-full-grid .category-card.is-selected svg { color: var(--teal-dark); }
.cat-full-grid .category-card.is-selected .category-card-name { color: var(--teal-dark); }
.cat-page-empty { display: none; text-align: center; padding: 1.1rem 1rem; border: 1.5px dashed var(--border); border-radius: 14px; color: var(--muted); font-size: .88rem; }
.cat-page-empty.is-visible { display: block; }
.dp-floating-panel {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 6px);
  background: #fff;
  border: 1.5px solid #e5e7eb;
  border-radius: 16px;
  box-shadow: 0 12px 40px rgba(0,0,0,.10), 0 2px 8px rgba(0,0,0,.05);
  z-index: 140;
  transition: opacity .18s ease, transform .18s ease;
  visibility: hidden;
  opacity: 0;
  transform: translateY(8px);
  pointer-events: none;
}
.dp-floating-panel.is-open { visibility: visible; opacity: 1; transform: translateY(0); pointer-events: auto; }
.dp-suggestions-panel { max-height: 300px; overflow-y: auto; }
.dp-suggestion-item {
  width: 100%;
  text-align: left;
  border: none;
  background: transparent;
  border-bottom: 1px solid #f9fafb;
  padding: .62rem 1rem;
  cursor: pointer;
  transition: background .12s ease;
  font-family: inherit;
  font-size: .9rem;
  font-weight: 400;
  color: #1a1a2e;
  display: flex;
  align-items: center;
  gap: .7rem;
  line-height: 1.4;
}
.dp-suggestion-item.is-active { background: #e6f9f7; color: #1dbfad; font-weight: 600; }
.dp-suggestion-item.is-last { border-bottom: none; border-radius: 0 0 14px 14px; }
.dp-suggestion-icon { flex-shrink: 0; stroke: #9ca3af; }
.hero-location-select {
  flex: 0 0 auto;
  width: auto;
  overflow: visible;
  position: relative;
  z-index: 60;
  cursor: pointer;
  user-select: none;
}
.hero-location-trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .35rem;
  width: 100%;
  cursor: pointer;
  white-space: nowrap;
  overflow: hidden;
}
.hero-location-icon { flex-shrink: 0; stroke: #1dbfad; }
.hero-location-label {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 140px;
  flex: 1 1 auto;
  display: block;
  font-size: .875rem;
  color: #6b7280;
}
.hero-location-chevron { flex-shrink: 0; stroke: #9ca3af; transition: transform .18s ease; }
.hero-location-chevron.is-open { transform: rotate(180deg); }
.dp-province-panel { max-height: 300px; overflow: hidden; }
.dp-province-search {
  width: calc(100% - 1.7rem);
  margin: .65rem .85rem .5rem;
  border: 1.5px solid #e5e7eb;
  border-radius: 8px;
  padding: .4rem .7rem;
  font-family: inherit;
  font-size: .82rem;
  color: #1a1a2e;
  outline: none;
  background: #f9fafb;
}
.dp-province-list { overflow-y: auto; max-height: 240px; padding: .35rem 0; }
.dp-province-option {
  width: 100%;
  text-align: left;
  border: none;
  background: transparent;
  border-bottom: 1px solid #f9fafb;
  padding: .55rem 1rem;
  cursor: pointer;
  font-family: inherit;
  font-size: .875rem;
  font-weight: 400;
  color: #1a1a2e;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.dp-province-option.is-active { background: #e6f9f7; color: #1dbfad; font-weight: 700; }
.dp-province-option.is-last { border-bottom: none; }

/* MOBILE SCROLL */
.company-cards-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
.company-cards-scroll::-webkit-scrollbar { display: none; }

/* RESPONSIVE */
@media (max-width: 1070px) {
  .cards-row { grid-template-columns: repeat(4, 1fr); }
  .urgency-row { grid-template-columns: repeat(4, 1fr); }
}

@media (max-width: 900px) {
  .hero-title { font-size: 2rem; }
  .categories-grid { grid-template-columns: repeat(3, 1fr); }
  .cards-row { grid-template-columns: repeat(3, 1fr); }
  .urgency-row { grid-template-columns: repeat(3, 1fr); }
  .help-cta-band { flex-direction: column; align-items: flex-start; padding: 1.75rem; border-radius: 20px; }
  .help-cta-copy { max-width: none; }
  .help-cta-title { font-size: 1.5rem; }
  .help-cta-visual { width: 100%; justify-content: center; gap: 0; padding-left: 0; margin-right: 0; transform: none; }
  .help-cta-circle { width: 160px; height: 160px; }
}

@media (min-width: 1025px) {
  .categories-grid.is-expanded .category-card.is-desktop-extra { display: flex; }
}

@media (max-width: 640px) {
  .hero { padding: 3rem 1.25rem 2.5rem; }
  .hero-title { font-size: 1.65rem; }
  .hero-sub { margin-bottom: 1.5rem; font-size: .875rem; }
  .hero-search { max-width: 450px; border-radius: 99px; }
  .hero-search-divider { display: none; }
  .hero-search-location { display: none; }
  .hero-search-btn { display: none; }
  .hero-search-main { padding: .65rem 1.25rem; }
  .cards-row { display: flex; flex-direction: row; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; gap: .75rem; }
  .cards-row::-webkit-scrollbar { display: none; }
  .cards-row .company-card { min-width: 200px; flex-shrink: 0; }
  .categories-grid { display: flex; flex-direction: row; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; gap: .75rem; }
  .categories-grid::-webkit-scrollbar { display: none; }
  .categories-grid .category-card { min-width: 130px; flex-shrink: 0; }
  .category-card { padding: 1rem .5rem .75rem; }
  .services-grid { grid-template-columns: 1fr; }
  .cat-full-grid { grid-template-columns: repeat(3, 1fr); }
  .section-wrap { padding: 2rem 0 1.75rem; }
    .section-alt {
	  margin-left: -1.25rem;
	  margin-right: -1.25rem;
	  padding-left: 1.25rem;
	  padding-right: 1.25rem;
   }
  .urgency-row { display: flex; flex-direction: row; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; gap: .75rem; }
  .urgency-row::-webkit-scrollbar { display: none; }
  .urgency-row .urgency-card { min-width: 200px; flex-shrink: 0; }
}

@media (max-width: 480px) {
  .hero-title { font-size: 1.45rem; }
  .hero-search { max-width: 370px; }
  .hero-sub { margin-bottom: 1.2rem; }
  .categories-grid { grid-template-columns: repeat(3, 1fr); }
  .cat-full-grid { grid-template-columns: repeat(3, 1fr); }
}

/* list: valdes-listado.html */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
.directory-page-root {
  --teal: #1dbfad; --teal-light: #e6f9f7; --teal-dark: #12a89a;
  --gold: #f5a623; --text: #1a1a2e; --muted: #6b7280;
  --border: #e5e7eb; --bg: #fff; --white: #fff;
  --orange: #f97316; --nav-h: var(--tc-navbar-height, 60px);
}
.directory-page-root { font-family: "Open Sans", Arial, Helvetica, sans-serif; background: var(--bg); color: var(--text); font-size: 15px; line-height: 1.6; }

/* NAV */

/* BREADCRUMB */
.breadcrumb-bar { background: transparent; padding: .75rem 0 .25rem; }
.breadcrumb { max-width: 1200px; margin: 0 auto; padding: 0 1.5rem; display: flex; align-items: center; gap: .4rem; font-size: .8rem; color: var(--muted); }
.breadcrumb a { font-size: 0.8rem; color: var(--muted); text-decoration: none; }
.breadcrumb a:hover { color: var(--teal); }
.breadcrumb-sep { color: #cbd5e1; }
.breadcrumb-current { font-size: 0.8rem; color: var(--text); font-weight: 500; }

/* MAIN LAYOUT */
.main-wrap { max-width: 1200px; margin: 0 auto; padding: 1.5rem 1.5rem 3rem; display: grid; grid-template-columns: 280px 1fr; gap: 1.5rem; align-items: start; }

/* RESULTS BAR */
.results-bar { grid-column: 1 / -1; display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.results-title { font-size: 1.05rem; font-weight: 700; white-space: nowrap; }
.results-title span { color: var(--teal); }
.search-bar-wrap { max-width: 320px; width: 100%; position: relative; }
.search-bar-input { width: 100%; border: 1.5px solid var(--border); border-radius: 99px; padding: .42rem .85rem .42rem 2.2rem; font-family: inherit; font-size: .82rem; color: var(--text); background: white; outline: none; transition: border-color .2s; line-height: 1.4; }
.search-bar-input:focus { border-color: var(--teal); }
.search-bar-icon { position: absolute; left: .75rem; top: 50%; transform: translateY(-50%); color: var(--muted); display: flex; align-items: center; cursor: pointer; }
.sort-wrap { position: relative; margin-left: auto; }
.sort-select { appearance: none; border: 1.5px solid var(--border); border-radius: 8px; padding: .5rem 2.5rem .5rem 1rem; font-family: inherit; font-size: .875rem; color: var(--text); background: white; cursor: pointer; outline: none; }
.sort-select:focus { border-color: var(--teal); }
.sort-arrow { position: absolute; right: .75rem; top: 50%; transform: translateY(-50%); pointer-events: none; color: var(--muted); }
.dp-quick-filters { width: 100%; display: flex; flex-wrap: wrap; align-items: center; gap: .5rem; margin-top: .6rem; padding-top: .25rem; }
.dp-filter-chip { display: inline-flex; align-items: center; justify-content: center; padding: .42rem .9rem; border: 1.5px solid var(--border); border-radius: 999px; background: #fff; color: var(--text); font-size: .84rem; font-weight: 600; font-family: inherit; cursor: pointer; transition: border-color .18s ease, background .18s ease, color .18s ease, opacity .18s ease; }
.dp-filter-chip:hover { border-color: var(--teal); background: var(--teal-light); color: var(--teal-dark); }
.dp-filter-chip.is-active { background: var(--teal-light); border-color: var(--teal); color: var(--teal-dark); }
.dp-filter-chip:disabled { opacity: .5; cursor: not-allowed; background: #f3f4f6; color: #9ca3af; border-color: var(--border); }
.dp-filter-chip-primary { background: var(--teal); border-color: var(--teal); color: #fff; font-weight: 700; }
.dp-filter-chip-primary:hover { background: var(--teal-dark); border-color: var(--teal-dark); color: #fff; }
.dp-sidebar-actions { display: flex; align-items: center; gap: .5rem; margin-top: 1rem; padding-top: .75rem; border-top: 1px solid var(--border); }
.dp-sidebar-apply-btn { width: 100%; background: var(--teal); color: #fff; border: none; padding: .7rem; border-radius: 999px; font-family: inherit; font-size: .9rem; font-weight: 700; cursor: pointer; transition: background .18s ease; }
.dp-sidebar-apply-btn:hover { background: var(--teal-dark); }

/* SIDEBAR FILTERS */
.filters-panel { background: white; border: 1.5px solid var(--border); border-radius: 14px; padding: 1.4rem 1.5rem; box-shadow: 0 2px 10px rgba(0,0,0,.06); position: sticky; top: calc(var(--nav-h) + 1rem); }
.filters-title { font-weight: 800; font-size: 1rem; margin-bottom: 1.25rem; }
.filter-section { padding: 1rem 0; border-top: 1px solid var(--border); }
.filter-section-notop { border-top: none; padding-top: 0; }
.filter-section.dp-filter-unsupported {
  border: 1.5px solid #ef4444;
  border-radius: 10px;
  padding: .9rem .75rem;
  margin-top: .9rem;
  background: #fff;
}
.filter-section.dp-filter-unsupported .filter-label {
  color: #b91c1c;
}
.filter-label { font-weight: 700; font-size: .875rem; margin-bottom: .75rem; }
.filter-input { width: 100%; border: 1.5px solid var(--border); border-radius: 8px; padding: .55rem .85rem; font-family: inherit; font-size: .85rem; color: var(--text); background: white; outline: none; transition: border-color .2s; }
.filter-input:focus { border-color: var(--teal); }
.filter-input::placeholder { color: #b0b7c3; }
.category-token-box {
  position: relative;
  width: 100%;
  min-height: 44px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .28rem;
  border: 1.5px solid var(--border);
  border-radius: 10px;
  background: #fff;
  padding: .44rem 2.15rem .48rem .5rem;
  transition: border-color .2s, box-shadow .2s;
}
.category-token-box:focus-within {
  border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(29,191,173,.09);
}
.category-token-box.has-categories { align-items: center; }
.category-token-list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .3rem;
  min-width: 0;
}
.directory-page-root .category-token-box .category-token-chip {
  display: inline-flex;
  align-items: center;
  gap: .1rem;
  max-width: 160px;
  min-height: 21px;
  border: 1px solid #e2e6ec;
  border-radius: 999px;
  background: #f4f5f7;
  color: #344054;
  padding: .08rem .28rem .08rem .5rem;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-size: .76rem;
  font-weight: 400;
  line-height: 1.05;
  cursor: pointer;
  overflow: hidden;
  transform-origin: left center;
  transition: background .18s ease, border-color .18s ease, color .18s ease, transform .18s ease, opacity .18s ease, max-width .18s ease, padding .18s ease, margin .18s ease;
  box-shadow: none;
  appearance: none;
  -webkit-appearance: none;
}
.directory-page-root .category-token-box .category-token-chip-label {
  display: block;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-size: .76rem;
  font-weight: 400;
  line-height: 1.05;
  transform: translateY(.3px);
}
.category-token-chip:hover {
  background: #e9edf3;
  border-color: #c9d0dc;
  color: #111827;
  transform: translateY(-1px);
}
.category-token-chip:focus-visible {
  outline: none;
  border-color: #aeb7c5;
  box-shadow: 0 0 0 3px rgba(52,64,84,.08);
}
.category-token-chip.is-removing {
  max-width: 0;
  opacity: 0;
  padding-left: 0;
  padding-right: 0;
  margin-right: -.35rem;
  transform: scale(.92);
}
.category-token-chip-label {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.category-token-chip-x {
  width: 10px;
  height: 10px;
  opacity: .78;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  color: #667085;
  transition: opacity .18s ease, background .18s ease, color .18s ease;
}
.category-token-chip:hover .category-token-chip-x {
  opacity: 1;
  background: #d0d5dd;
  color: #111827;
}
.category-token-chip-x svg {
  width: 7px;
  height: 7px;
  display: block;
}
.category-token-input.filter-input {
  flex: 1 1 116px;
  min-width: 76px;
  width: auto;
  border: 0;
  border-radius: 0;
  padding: .12rem .18rem;
  background: transparent;
  font-size: .86rem;
  box-shadow: none;
}
.category-token-input.filter-input:focus {
  border-color: transparent;
  box-shadow: none;
}
.category-token-clear-all {
  position: absolute;
  top: .44rem;
  right: .46rem;
  width: 20px !important;
  min-width: 20px !important;
  max-width: 20px !important;
  height: 20px !important;
  min-height: 20px !important;
  border: 1px solid #e2e6ec;
  border-radius: 999px;
  background: #f4f5f7;
  color: #475467;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 20px;
  padding: 0 !important;
  margin: 0;
  font-size: 0;
  line-height: 0;
  box-sizing: border-box;
  box-shadow: none;
  appearance: none;
  -webkit-appearance: none;
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
  transition: background .18s ease, border-color .18s ease, color .18s ease, opacity .18s ease;
}
.category-token-box.has-categories .category-token-clear-all {
  opacity: 1;
  pointer-events: auto;
}
.category-token-clear-all:hover {
  background: #e9edf3;
  border-color: #c9d0dc;
  color: #111827;
}
.category-token-clear-all::before {
  content: '×';
  display: block;
  color: currentColor;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 13px;
  font-weight: 400;
  line-height: 18px;
  transform: translateY(-.5px);
}
.category-token-clear-all svg {
  display: none;
}
.dp-relative { position: relative; }
.filter-sub { font-size: .75rem; color: var(--muted); margin-bottom: .6rem; }
.dp-input-suggest-panel {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 6px);
  background: #fff;
  border: 1.5px solid #e5e7eb;
  border-radius: 12px;
  box-shadow: 0 12px 30px rgba(0,0,0,.10), 0 2px 8px rgba(0,0,0,.05);
  max-height: 230px;
  overflow-y: auto;
  z-index: 120;
  display: none;
  padding: .2rem 0;
  scrollbar-width: thin;
  scrollbar-color: #e5e7eb transparent;
}
.dp-input-suggest-panel.open { display: block; }
.dp-input-suggest-option {
  width: 100%;
  border: none;
  background: transparent;
  text-align: left;
  padding: .58rem .8rem;
  font-family: inherit;
  font-size: .86rem;
  color: #1f2937;
  cursor: pointer;
  border-bottom: 1px solid #f3f4f6;
}
.dp-input-suggest-option.is-last { border-bottom: none; }
.dp-input-suggest-option:hover { background: #f0fdf9; color: #0f766e; }
.sort-in-filters { display: none; margin-bottom: 1rem; }
.sort-in-filters select,
.drawer-sort select { appearance: none; width: 100%; border: 1.5px solid var(--border); border-radius: 8px; padding: .5rem .85rem; font-family: inherit; font-size: .85rem; color: var(--text); background: white; cursor: pointer; outline: none; }

/* Checkboxes */
.check-option { display: flex; align-items: center; gap: .6rem; padding: .3rem 0; cursor: pointer; font-size: .875rem; color: #333; user-select: none; }
.check-option input[type=checkbox] { width: 16px; height: 16px; accent-color: var(--teal); cursor: pointer; flex-shrink: 0; }

/* RANGE SLIDERS */
.range-wrap { padding: .5rem 0 .25rem; }

/* Single range */
.single-range { -webkit-appearance: none; appearance: none; display: block; width: 100%; height: 5px; background: linear-gradient(to right, var(--teal) 0%, var(--teal) var(--val, 25%), #e5e7eb var(--val, 25%), #e5e7eb 100%); border-radius: 99px; outline: none; cursor: pointer; margin-top: .75rem; }
.single-range::-webkit-slider-thumb { -webkit-appearance: none; width: 18px; height: 18px; border-radius: 50%; background: var(--teal); border: 2.5px solid white; box-shadow: 0 2px 6px rgba(29,191,173,.4); cursor: pointer; }
.single-range::-webkit-slider-thumb:hover { box-shadow: 0 0 0 8px rgba(29,191,173,.15); }
.single-range::-moz-range-thumb { width: 18px; height: 18px; border-radius: 50%; background: var(--teal); border: 2.5px solid white; cursor: pointer; }
.range-labels { display: flex; justify-content: space-between; font-size: .8rem; color: var(--muted); margin-top: .5rem; }
.range-labels span { font-size: .8rem; line-height: 1.2; }
.range-labels span:nth-child(2) { color: var(--teal); font-weight: 600; }

/* Dual range */
.dual-range-wrap { position: relative; height: 18px; margin-top: .75rem; }
.dual-range-track { position: absolute; top: 50%; left: 0; right: 0; height: 5px; background: #e5e7eb; border-radius: 99px; transform: translateY(-50%); pointer-events: none; z-index: 1; }
.dual-range-fill { position: absolute; top: 50%; height: 5px; background: var(--teal); border-radius: 99px; transform: translateY(-50%); pointer-events: none; z-index: 2; left: 0; width: 100%; }
.dual-range-wrap input[type=range] { -webkit-appearance: none; appearance: none; position: absolute; top: 50%; transform: translateY(-50%); width: 100%; height: 5px; background: transparent; outline: none; cursor: pointer; pointer-events: none; margin: 0; padding: 0; z-index: 3; }
.dual-range-wrap input[type=range]::-webkit-slider-thumb { -webkit-appearance: none; width: 18px; height: 18px; border-radius: 50%; background: var(--teal); border: 2.5px solid white; box-shadow: 0 2px 6px rgba(29,191,173,.4); cursor: pointer; pointer-events: all; }
.dual-range-wrap input[type=range]::-webkit-slider-thumb:hover { box-shadow: 0 0 0 8px rgba(29,191,173,.15); }
.dual-range-wrap input[type=range]::-moz-range-thumb { width: 18px; height: 18px; border-radius: 50%; background: var(--teal); border: 2.5px solid white; cursor: pointer; pointer-events: all; }
.dual-range-labels { display: flex; justify-content: space-between; font-size: .8rem; margin-top: .5rem; }
.dual-range-labels span { color: var(--teal); font-weight: 600; font-size: .8rem; line-height: 1.2; }

/* Rating filter */
.rating-option { display: flex; align-items: center; justify-content: space-between; padding: .28rem 0; cursor: pointer; }
.rating-option-left { display: flex; align-items: center; gap: .6rem; font-size: .875rem; }
.rating-option input[type=checkbox] { width: 16px; height: 16px; accent-color: var(--teal); cursor: pointer; }
.rating-count { font-size: .78rem; color: var(--muted); }

/* RESULTS */
.results-list { display: flex; flex-direction: column; gap: 1rem; }
.provider-card { background: white; border-radius: 14px; border: 1.5px solid var(--border); overflow: hidden; display: flex; position: relative; transition: box-shadow .2s, border-color .2s; cursor: pointer; }
.provider-card:hover { box-shadow: 0 6px 24px rgba(0,0,0,.1); border-color: #d1d5db; }
.provider-card-badge { position: absolute; top: 12px; left: 12px; z-index: 2; display: inline-flex; align-items: center; justify-content: center; gap: .3rem; font-size: .72rem; font-weight: 700; padding: .3rem .75rem; border-radius: 99px; line-height: 1; }
.provider-card-badge svg,
.provider-badge-icon {
  flex-shrink: 0;
  display: block;
  color: inherit;
  width: 11px;
  height: 11px;
}
.provider-card-badge svg *,
.provider-badge-icon * {
  fill: none;
  stroke: currentColor;
}
.badge-urgencia { background: #fef3c7; color: #d97706; border: 1px solid #fde68a; }
.badge-top { background: #ede9fe; color: #7c3aed; border: 1px solid #ddd6fe; }
.provider-logo-wrap { width: 245px; min-width: 180px; display: flex; align-items: center; justify-content: center; padding: 1.5rem; border-right: 1px solid #dfe6ea; background: #eef3f5; flex-shrink: 0; }
.provider-logo-wrap img { max-width: 140px; max-height: 80px; object-fit: contain; }
.provider-logo-initials {
  width: 74px;
  height: 74px;
  border-radius: 18px;
  background: #ffffff;
  border: 1px solid rgba(20,184,166,.12);
  box-shadow: 0 10px 24px rgba(20,184,166,.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 1.45rem;
  letter-spacing: -.03em;
  color: #14b8a6;
}
.provider-card.is-static-card { cursor: default; }
.provider-actions [data-available="0"] { opacity: .65; cursor: default; }
.provider-body { padding: 1.25rem 1.5rem; flex: 1; display: flex; flex-direction: column; justify-content: center; }
.provider-name { font-weight: 800; font-size: 1.1rem; margin-bottom: .3rem; color: var(--text); font-family: "Montserrat", "Open Sans", Arial, Helvetica, sans-serif; }
.provider-stars { display: flex; align-items: center; gap: .3rem; color: var(--gold); font-size: .95rem; margin-bottom: .45rem; }
.provider-stars .ps-score { color: var(--text); font-weight: 700; font-size: .9rem; }
.provider-stars .ps-count { color: var(--muted); font-size: .82rem; font-weight: 400; }
.provider-stars .star-empty { color: #ddd; }
.provider-category { display: inline-flex; align-items: center; gap: .4rem; background: #f3f4f6; border: 1px solid var(--border); border-radius: 6px; padding: .22rem .65rem; font-size: .78rem; font-weight: 600; color: #374151; margin-bottom: .7rem; align-self: flex-start; }
.provider-desc { font-size: .84rem; color: #4b5563; line-height: 1.6; margin-bottom: .85rem; display: -webkit-box; -webkit-line-clamp: 3; line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.provider-meta { display: flex; flex-direction: column; gap: .32rem; margin-bottom: .95rem; }
.provider-meta-row { display: grid; grid-template-columns: 16px minmax(0, 1fr); align-items: center; column-gap: .34rem; min-height: 18px; font-size: .77rem; color: var(--muted); }
.provider-meta-row svg { width: 14px; height: 14px; color: #667085; flex-shrink: 0; display: block; justify-self: center; align-self: center; }
.provider-meta-row span,
.provider-meta-link { display: block; min-width: 0; font-size: .8rem; color: #667085; line-height: 1.25; text-decoration: none; transform: translateY(-.2px); }
.provider-meta-link:hover { color: var(--teal-dark); text-decoration: underline; text-underline-offset: 2px; }
.provider-meta-link-web { color: #166dde; }
.provider-meta-link-web:hover { color: #1258b4; }
.provider-meta-row strong { color: var(--text); font-weight: 600; font-size: .9rem; }
.provider-actions { display: flex; flex-direction: row; align-items: center; gap: .5rem; }
.btn-ver { border: 1.5px solid var(--teal); background: transparent; color: var(--teal); padding: .48rem 1.25rem; border-radius: 99px; font-family: inherit; font-size: .85rem; font-weight: 700; cursor: pointer; transition: background .2s; white-space: nowrap; }
.btn-ver:hover { background: var(--teal-light); }
.btn-presup { background: transparent; border: none; color: var(--text); font-family: inherit; font-size: .85rem; font-weight: 600; cursor: pointer; padding: .48rem .75rem; transition: color .2s; white-space: nowrap; }
.btn-presup:hover { color: var(--teal); }

/* PAGINATION */
.pagination { display: flex; align-items: center; justify-content: center; gap: .5rem; margin-top: 1.5rem; }
.page-btn { width: 36px; height: 36px; border-radius: 8px; border: 1.5px solid var(--border); background: white; font-family: inherit; font-size: .875rem; font-weight: 600; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all .2s; color: var(--text); }
.page-btn:hover { border-color: var(--teal); color: var(--teal); }
.page-btn.active { background: var(--teal); border-color: var(--teal); color: white; }
.page-btn.arrow { color: var(--text); font-size: 1.35rem; font-weight: 700; line-height: 1; padding-bottom: 2px; }
.page-btn.arrow svg {
  display: block;
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  overflow: visible;
}
.page-btn.arrow svg,
.page-btn.arrow svg * {
  fill: none;
  stroke: currentColor;
}
.page-btn.arrow svg path {
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* FOOTER */

/* FILTER TOGGLE */
.filter-toggle-btn { display: none; align-items: center; justify-content: center; width: 38px; height: 38px; border: 1.5px solid var(--border); border-radius: 8px; background: white; cursor: pointer; color: var(--teal); flex-shrink: 0; padding: 0; transition: border-color .2s, color .2s, background .2s; }
.filter-toggle-btn:hover { border-color: var(--teal); color: var(--teal); }
.filter-toggle-btn.active { border-color: var(--teal); color: var(--teal); background: var(--teal-light); }

/* FILTER DRAWER */
.filter-drawer-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.35); z-index: 400; }
.filter-drawer-overlay.open { display: block; }
.filter-drawer { position: fixed; top: 0; left: -100%; width: min(320px, 88vw); height: 100vh; background: white; z-index: 401; overflow-y: auto; transition: left .28s cubic-bezier(.4,0,.2,1); padding: 1.5rem 1.25rem; box-shadow: 4px 0 24px rgba(0,0,0,.15); }
.filter-drawer.open { left: 0; }
.filter-drawer-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1.25rem; }
.filter-drawer-title { font-weight: 800; font-size: 1rem; }
.filter-drawer-close { width: 32px; height: 32px; border: 1.5px solid var(--border); border-radius: 7px; background: transparent; cursor: pointer; display: flex; align-items: center; justify-content: center; color: var(--muted); transition: border-color .2s; }
.filter-drawer-close:hover { border-color: var(--text); color: var(--text); }
.drawer-sort { margin-bottom: 1rem; }
.drawer-apply-btn { width: 100%; background: var(--teal); color: white; border: none; padding: .7rem; border-radius: 99px; font-family: inherit; font-size: .9rem; font-weight: 700; cursor: pointer; margin-top: 1rem; }

/* RESPONSIVE */
@media (max-width: 900px) {
  .main-wrap { grid-template-columns: 1fr; }
  .filters-panel { display: none !important; }
  .results-bar { grid-column: 1; flex-wrap: wrap; }
  .results-title { width: 100%; margin-bottom: .25rem; }
  .filter-toggle-btn { display: flex; }
}
@media (max-width: 640px) {
  .provider-card { flex-direction: column; }
  .provider-logo-wrap { width: 100%; min-width: unset; height: 140px; border-right: none; border-bottom: 1px solid var(--border); padding: 1.25rem; }
  .provider-logo-wrap img { max-width: 180px; max-height: 80px; }
  .provider-body { padding: 1.1rem 1.1rem 1.25rem; }
  .provider-name { font-size: 1rem; }
  .provider-card-badge { top: 10px; left: auto; right: 10px; }
  .results-title { font-size: .95rem; }
  .search-bar-wrap { flex: 1; min-width: 0; max-width: 100%; }
  .sort-wrap { margin-left: 0; }
  .sort-select { font-size: .8rem; padding: .45rem 2rem .45rem .75rem; }
}
@media (max-width: 510px) {
  .sort-wrap { display: none; }
  .sort-in-filters { display: block; }
}
@media (max-width: 400px) {
  .provider-actions { flex-direction: column; align-items: stretch; gap: .5rem; }
  .btn-ver { text-align: center; }
  .btn-presup { text-align: center; }
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
.directory-page-root {
  --teal: #1dbfad; --teal-light: #e6f9f7; --teal-dark: #12a89a;
  --gold: #f5a623; --text: #1a1a2e; --muted: #6b7280;
  --border: #e5e7eb; --bg: #fff; --white: #fff;
  --orange: #f97316; --nav-h: var(--tc-navbar-height, 60px);
}
.directory-page-root { font-family: "Open Sans", Arial, Helvetica, sans-serif; background: var(--bg); color: var(--text); font-size: 15px; line-height: 1.6; }

/* NAV */

/* SCREENS */
.screen { display: none; }
.screen.active { display: block; }

/* PROFILE SCREEN */
.page { max-width: 1140px; margin: 0 auto; padding: 0 1.5rem; }
.back-bar { padding: .9rem 0 .4rem; }
.back-link { display: inline-flex; align-items: center; gap: .35rem; color: var(--text); text-decoration: none; font-size: .875rem; font-weight: 500; cursor: pointer; }
.back-link:hover { color: var(--teal); }

.banner-wrap { position: relative; border-radius: 14px 14px 0 0; overflow: hidden; height: 250px; background: #edf8f7; }
.banner-wrap img { width: 100%; height: 100%; object-fit: cover; display: block; }
.banner-wrap .banner-fallback {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  background:
    radial-gradient(circle at 16% 18%, rgba(255, 255, 255, .88) 0 8%, rgba(255, 255, 255, 0) 30%),
    linear-gradient(180deg, #ffffff 0%, #f7fcfb 20%, #edf9f8 45%, #dff4f2 70%, #cfebe8 100%);
}
.banner-wrap .banner-fallback::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255, 255, 255, .34) 0%, rgba(255, 255, 255, 0) 100%);
  pointer-events: none;
}
.banner-wrap .banner-image {
  position: relative;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: none;
}
.banner-wrap.has-image .banner-image { display: block; }
.banner-wrap.has-image .banner-fallback { display: none; }
.profile-header-wrap { position: relative; border-radius: 16px; box-shadow: 0 4px 24px rgba(0,0,0,.09); overflow: visible; }
.fav-btn { padding: 0; position: absolute; top: 14px; right: 14px; width: 40px; height: 40px; border-radius: 50%; background: #fff; color: #9ca3af; border: 1px solid #e5e7eb; cursor: pointer; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 10px rgba(15,23,42,.12); transition: transform .2s, color .2s ease, box-shadow .2s ease, border-color .2s ease; }
.fav-btn:hover { transform: scale(1.05); color: #6b7280; border-color: #d1d5db; box-shadow: 0 7px 14px rgba(15,23,42,.16); }
.fav-btn svg { width: 18px; height: 18px; display: block; flex-shrink: 0; }
.fav-btn svg path { fill: none; stroke: currentColor; }

.profile-card { background: white; border-radius: 0 0 16px 16px; padding: 0 2rem 0; text-align: center; box-shadow: 0 4px 20px rgba(0,0,0,.08); }
.logo-circle { width: 110px; height: 110px; border-radius: 50%; border: 4px solid var(--teal); box-shadow: 0 4px 20px rgba(0,0,0,.18); background: white; margin: -58px auto 1.1rem; overflow: hidden; display: flex; align-items: center; justify-content: center; position: relative; z-index: 10; }
.logo-circle img { width: 85%; height: 85%; object-fit: contain; }
.directory-page-root #screen-profile .page { max-width: 1240px; }
.profile-name { font-size: 1.62rem; font-weight: 700; margin-bottom: 1rem; letter-spacing: -.2px; color: #0f2147; line-height: 1.25; font-family: "Montserrat", "Open Sans", Arial, Helvetica, sans-serif; }
.profile-meta { display: flex; align-items: center; justify-content: center; gap: 1.35rem; flex-wrap: wrap; margin-bottom: 1rem; }
.stars-row { display: flex; align-items: center; gap: .3rem; color: var(--gold); font-size: 1.02rem; font-family: Arial, Helvetica, sans-serif; letter-spacing: .2px; }
.stars-row .star-filled { color: var(--gold); }
.stars-row .star-empty { color: #d1d5db; }
.stars-row .rating-text { color: #3f4e67; font-size: .85rem; font-weight: 500; }
.star-empty { color: #d1d5db; }
.rating-count-text { color: var(--muted); font-weight: 400; }
.meta-badge { display: inline-flex; align-items: center; gap: .35rem; font-size: .85rem; font-weight: 500; color: #536077; }
.meta-badge svg { color: var(--teal); stroke: var(--teal) !important; }
.response-pill { display: inline-flex; align-items: center; gap: .4rem; background: var(--teal-light); color: #0ea99a; border-radius: 99px; padding: .34rem 1rem; font-size: .82rem; font-weight: 600; margin-bottom: 1.1rem; }
.response-pill strong { font-size: 0.9rem; color: inherit; font-weight: 700; }
.response-pill span { font-size: 0.9rem; color: inherit; }
.response-pill svg { color: var(--teal); stroke: var(--teal) !important; }
.profile-response-wrap { display: flex; justify-content: center; margin-bottom: 1.1rem; }
.profile-actions { display: flex; justify-content: center; gap: 1rem; margin-bottom: 1.25rem; }
.btn-teal { background: var(--teal); color: white; border: none; padding: .6rem 1.7rem; border-radius: 99px; font-size: .875rem; font-weight: 700; cursor: pointer; font-family: inherit; transition: background .2s; }
.btn-teal:hover { background: var(--teal-dark); }
.btn-outline { background: transparent; color: var(--text); border: 1.5px solid var(--border); padding: .58rem 1.5rem; border-radius: 99px; font-size: .875rem; font-weight: 600; cursor: pointer; font-family: inherit; transition: border-color .2s; }
.btn-outline:hover { border-color: var(--teal); color: var(--teal); }
.tabs-wrap { margin-top: .2rem; border-top: 1.5px solid var(--border); }
.tabs { display: flex; border-bottom: 1px solid var(--border); }
.tab-btn { position: relative; flex: 1; padding: .95rem .75rem; background: none; border: none; font-family: inherit; font-size: .9rem; font-weight: 500; color: #475467; cursor: pointer; transition: color .2s ease, background-color .2s ease; }
.tab-btn::after { content: ''; position: absolute; left: 0%; right: 0%; bottom: -1px; height: 3px; border-radius: 999px 999px 0 0; background: transparent; transition: background .2s ease; }
.tab-btn:hover { color: var(--text); }
.tab-btn:focus-visible { outline: 3px solid rgba(29,191,173,.32); outline-offset: -4px; border-radius: 10px 10px 0 0; }
.tab-btn.active { color: #111827; font-weight: 700; }
.tab-btn.active::after { background: #111827; }

.content-layout { display: grid; grid-template-columns: 1fr 310px; gap: 1.25rem; margin: 1.25rem 0 3rem; align-items: start; position: relative; }
.tab-panel { display: none; }
.tab-panel.active { display: flex; flex-direction: column; gap: 1.15rem; }
.tab-panel:focus-visible { outline: 3px solid rgba(29,191,173,.24); outline-offset: 4px; border-radius: 14px; }

.card { background: #fff; border: 1px solid #dfe3e8; border-radius: 14px; padding: 1.5rem 1.55rem; box-shadow: 0 3px 10px rgba(15,23,42,.04); }
.card-title { font-weight: 700; font-size: .975rem; margin-bottom: 1rem; color: #111827; }

/* Rating bars */
.rating-overview { display: flex; gap: 2.2rem; align-items: center; }
.rating-overview-summary { margin-bottom: 1.25rem; }
.rating-overview-reviews { margin-bottom: 1.5rem; }
.rating-big {
  text-align: center;
  flex-shrink: 0;
  background: white;
  padding: 1.25rem 1.75rem;
  min-width: 130px;
}
.rating-star-big { font-size: 2.9rem; color: #f5a623; line-height: 1; margin-bottom: .2rem; }
.rating-num { font-size: 1.9rem; font-weight: 800; letter-spacing: -.5px; line-height: 1.1; }
.rating-num strong { font-size: 1.9rem; }
.rating-num span { font-size: 1.1rem; font-weight: 400; color: var(--muted); }
.rating-label { font-size: .8rem; color: #667085; margin-top: .3rem; }
.rating-bars { flex: 1; display: flex; flex-direction: column; gap: .55rem; }
.bar-row { display: flex; align-items: center; gap: .55rem; font-size: .82rem; }
.bar-num { width: 12px; color: var(--muted); text-align: right; font-weight: 600; }
.bar-star-s { color: var(--gold); font-size: .75rem; }
.bar-track { flex: 1; height: 10px; background: #e5e7eb; border-radius: 99px; overflow: hidden; }
.bar-fill { height: 100%; background: #27bdb0; border-radius: 99px; width: 0; transition: width 1s cubic-bezier(.4,0,.2,1); }
.bar-count { width: 26px; text-align: right; color: #667085; font-size: .76rem; font-weight: 600; }

/* Review list (vertical, no border, as in screenshot) */
.review-list { display: flex; flex-direction: column; gap: 1.25rem; margin-top: .75rem; }
.review-item { padding-bottom: 1.25rem; border-bottom: 1px solid var(--border); }
.review-item:last-child { border-bottom: none; padding-bottom: 0; }
.reviewer-row { display: flex; align-items: center; gap: .65rem; margin-bottom: .5rem; }
.avatar { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.avatar-initials { width: 40px; height: 40px; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: white; font-weight: 700; font-size: .85rem; flex-shrink: 0; }
.avatar-initials-brand { background: linear-gradient(135deg,#14b8a6,#0ea5e9); }
.avatar-initials-lg { width: 84px; height: 84px; margin: 0 auto; font-size: 1.4rem; }
.avatar-initials-md { width: 72px; height: 72px; margin: 0 auto; font-size: 1.2rem; }
.reviewer-name { font-weight: 700; font-size: .9rem; }
.reviewer-meta { font-size: .8rem; color: #5e6f86; display: flex; align-items: center; gap: .25rem; flex-wrap: wrap; margin-top: .1rem; }
.stars-visual { display: inline-flex; align-items: center; gap: 0; letter-spacing: .03em; color: var(--gold); }
.stars-visual .star-filled { color: var(--gold); }
.stars-visual .star-empty { color: #d1d5db; }
.rev-stars { display: flex; align-items: center; gap: .2rem; color: var(--gold); font-size: .95rem; margin-bottom: .35rem; }
.rev-stars .rs-num { color: var(--text); font-size: .82rem; font-weight: 700; margin-left: .2rem; }
.review-heading { font-weight: 700; font-size: .9rem; margin-bottom: .2rem; }
.review-text { font-size: .82rem; color: #555; line-height: 1.55; }

/* reviews-grid for resumen (2 col) */
.reviews-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-top: .75rem; }
.review-card { border: 1.5px solid #d7dde6; border-radius: 16px; padding: 1.1rem 1.1rem 1rem; background: #fff; }
.review-card-header { display: flex; align-items: center; gap: .65rem; margin-bottom: .9rem; }
.review-card-bubble {
  background: #f6f7f9;
  border-radius: 12px;
  padding: .85rem 1rem;
  margin-bottom: .75rem;
  position: relative;
}
.review-card-bubble-quote {
  font-size: 1.5rem;
  color: #9aa4b2;
  font-family: Georgia, serif;
  line-height: 1;
  margin-bottom: .35rem;
  display: flex;
  align-items: center;
  gap: .35rem;
}
.review-card-bubble-quote svg { flex-shrink: 0; }
.review-heading-sm { font-weight: 700; font-size: .9rem; margin-bottom: .25rem; display: inline; }
.review-text-sm { font-size: .8rem; color: #374151; line-height: 1.58; margin-top: .2rem; }
.review-stars-sm { display: flex; align-items: center; gap: .25rem; color: #f5a623; font-size: 1rem; }
.review-stars-sm .rs-num { color: var(--text); font-size: .85rem; font-weight: 700; margin-left: .3rem; }

.center-btn { text-align: center; margin-top: 1.1rem; }
.btn-ghost { border: 1.6px solid #23b8aa; background: transparent; color: #15b3a5; padding: .52rem 1.7rem; border-radius: 99px; font-size: .85rem; font-weight: 700; cursor: pointer; font-family: inherit; transition: background .2s, color .2s, border-color .2s; }
.btn-ghost:hover { background: var(--teal-light); }

.about-text { font-size: .875rem; color: #273244; line-height: 1.72; margin-bottom: .95rem; }
.check-list { list-style: none; display: flex; flex-direction: column; gap: .45rem; }
.check-list li { display: flex; align-items: center; gap: .5rem; font-size: .95rem; color: #111827; }
.check-list li svg { color: #20b9ab; stroke: #20b9ab !important; stroke-width: 2.7; flex-shrink: 0; }
.services-cols {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  column-gap: 2rem;
  row-gap: 0;
  list-style: none;
  margin: .1rem 0 1rem;
}
.services-cols li { font-size: .875rem; color: #273244; padding: .33rem 0; display: flex; align-items: center; gap: .5rem; }
.services-cols li::before { content: '•'; color: #20b9ab; font-size: 1.15rem; line-height: 1; flex-shrink: 0; }
.photos-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .9rem; margin-top: .15rem; }
.photo-thumb { border-radius: 12px; height: 142px; overflow: hidden; }
.photo-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .3s; }
.photo-thumb:hover img { transform: scale(1.04); }
.doc-item { display: inline-flex; align-items: center; gap: .75rem; width: fit-content; max-width: 260px; border: 1.5px solid #dfe3e8; border-radius: 12px; padding: .7rem 1rem; cursor: pointer; transition: border-color .2s, box-shadow .2s; }
.doc-item:hover { border-color: var(--teal); }
.doc-item { text-decoration: none; color: inherit; }
.doc-item.doc-item-unavailable { background: #f9fafb; border-color: #e5e7eb; cursor: pointer; text-align: left; font-family: inherit; appearance: none; -webkit-appearance: none; }
.doc-item.doc-item-unavailable:hover { border-color: #d1d5db; }
.dp-api-unavailable { border: 1.5px solid #ef4444 !important; }
.dp-api-unavailable .cinfo-label,
.dp-api-unavailable .meta-badge,
.dp-api-unavailable .card-title { color: #b91c1c; }
.doc-icon { width: 36px; height: 36px; background: var(--teal-light); border-radius: 8px; display: flex; align-items: center; justify-content: center; color: var(--teal); flex-shrink: 0; }
.doc-icon svg,
.doc-icon svg * { color: var(--teal) !important; stroke: var(--teal) !important; }
.doc-name { font-size: .82rem; font-weight: 700; color: #0f172a; }
.doc-size { font-size: .75rem; color: #667085; }
.text-muted-block { margin: .25rem 0 0; color: #6b7280; font-size: .9rem; }
.text-muted-feedback { margin: .45rem 0 0; color: #6b7280; font-size: .82rem; }
.center-btn-compact { margin-top: .5rem; }
.reviews-unavailable-note { font-size: .86rem; color: #6b7280; line-height: 1.45; }
.reviews-unavailable-note--full { width: 100%; grid-column: 1 / -1; }
.dp-hidden { display: none !important; }

/* OFERTAS TAB - card style from screenshot */
.offers-grid { display: flex; flex-direction: column; gap: 1.1rem; }
.offers-grid:empty { display: none; }
.offers-empty-card { padding: 0; overflow: hidden; }
.offers-empty-state {
  min-height: 322px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  background: #fff;
}
.offers-empty-icon {
  width: 66px;
  height: 66px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #d9f5f1;
  color: #111827;
  margin-bottom: 1rem;
}
.offers-empty-icon svg { width: 34px; height: 34px; display: block; }
.offers-empty-title {
  font-family: "Montserrat", "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.25;
  color: #303136;
  margin-bottom: .35rem;
}
.offers-empty-text {
  font-size: .76rem;
  color: #757b83;
  line-height: 1.35;
}
.offer-card-big {
  border: 1px solid #d7dde4;
  border-radius: 14px;
  overflow: hidden;
  display: flex;
  flex-direction: row;
  align-items: stretch;
  background: #fff;
  min-height: 172px;
}
.offer-card-img {
  width: 155px;
  min-width: 155px;
  overflow: hidden;
  flex-shrink: 0;
  background: #eef2f6;
}
.offer-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.offer-card-body {
  padding: 1.05rem 1.35rem 1rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.offer-card-title {
  font-weight: 700;
  font-size: .94rem;
  line-height: 1.25;
  margin-bottom: .2rem;
  color: #0f2147;
}
.offer-card-sub {
  font-size: .82rem;
  color: #50627d;
  margin-bottom: .78rem;
  font-style: italic;
}
.offer-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: flex-start;
  min-height: 34px;
  min-width: 145px;
  background: #f97316;
  color: #fff;
  font-weight: 800;
  font-size: .92rem;
  line-height: 1;
  text-transform: uppercase;
  padding: .5rem .95rem;
  border-radius: 8px;
  margin-bottom: .45rem;
  letter-spacing: .01em;
}
.offer-until {
  font-size: .76rem;
  color: #5f6f86;
  margin-top: 0;
}
.directory-profile-root .offer-card-title { font-size: .94rem !important; }
.directory-profile-root .offer-card-sub { font-size: .8rem !important; }
.directory-profile-root .offer-badge { font-size: .84rem !important; }

/* SIDEBAR */
.sidebar {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  position: sticky;
  top: calc(var(--nav-h) + 1rem);
  align-self: start;
}
.sidebar .card { padding: 1.2rem; border: 1px solid #d9dde3; box-shadow: 0 2px 8px rgba(15,23,42,.04); }
.map-frame { width: 100%; height: 185px; border-radius: 10px; overflow: hidden; margin-bottom: .85rem; }
.map-frame iframe { width: 100%; height: 100%; border: none; display: block; }
.map-empty-msg { margin: -.25rem 0 .75rem; color: #6b7280; font-size: .8rem; line-height: 1.35; }
.contact-rows { display: flex; flex-direction: column; gap: .65rem; }
.cinfo-row { display: flex; align-items: flex-start; gap: .6rem; font-size: .8rem; }
.cinfo-row svg { color: var(--teal); flex-shrink: 0; margin-top: 2px; }
.cinfo-label { font-weight: 700; font-size: .78rem; color: var(--muted); margin-bottom: .1rem; }
.cinfo-val { color: #333; line-height: 1.5; font-size: .82rem; }
.cinfo-link { display: inline-block; color: #166dde; text-decoration: none; word-break: break-word; }
.cinfo-link:hover { color: #1258b4; text-decoration: underline; text-underline-offset: 2px; }
.offer-pill { border-left: 4px solid var(--gold); background: #fffbf0; border-radius: 8px; padding: .85rem 1rem; margin-bottom: .75rem; }
.offer-name { font-weight: 700; font-size: .9rem; margin-bottom: .2rem; }
.offer-disc { font-size: .8rem; color: var(--orange); font-weight: 600; }
.offer-valid { font-size: .75rem; color: var(--muted); margin-top: .15rem; }
.offer-empty-msg { margin: .2rem 0 .75rem; color: #6b7280; font-size: .82rem; line-height: 1.35; }
.btn-outline-w,
.btn-detail-full { width: 100%; background: transparent; color: var(--text); border: 1.5px solid var(--border); border-radius: 99px; padding: .6rem; font-family: inherit; font-size: .85rem; font-weight: 600; cursor: pointer; transition: border-color .2s; }
.btn-outline-w:hover,
.btn-detail-full:hover { border-color: var(--teal); color: var(--teal); }
.cta-title { font-weight: 700; font-size: .925rem; margin-bottom: .85rem; }
.btn-teal-w { width: 100%; background: var(--teal); color: white; border: none; padding: .65rem; border-radius: 99px; font-family: inherit; font-size: .875rem; font-weight: 700; cursor: pointer; margin-bottom: .5rem; transition: background .2s; }
.btn-teal-w:hover { background: var(--teal-dark); }
.response-note { font-size: .76rem; color: #9ca3af; line-height: 1.25; display: flex; align-items: center; justify-content: center; gap: .25rem; margin-top: .52rem; font-weight: 500; }
.response-note span,
.response-note strong { color: inherit; font-size: inherit; }
.response-note strong { font-weight: 600; }
.response-note svg { width: 12px; height: 12px; color: #9ca3af; stroke: #9ca3af; }

/* PRESUPUESTO SCREEN */
#screen-presupuesto,
.directory-request-page { background: var(--bg); min-height: calc(100vh - var(--nav-h)); }
.presup-wrap { max-width: 1140px; margin: 0 auto; padding: 0 1.5rem 3rem; }
.presup-layout { display: grid; grid-template-columns: 1fr 300px; gap: 1.5rem; margin-top: 1.5rem; align-items: start; }
.presup-main { background: white; border-radius: 16px; padding: 2rem 2.5rem; box-shadow: 0 2px 12px rgba(0,0,0,.07); }
.presup-title { font-size: 2rem; font-weight: 800; margin-bottom: .3rem; }
.presup-sub { font-size: .875rem; color: var(--muted); margin-bottom: 1.75rem; }
.form-section-label { font-weight: 700; font-size: .95rem; margin-bottom: 1rem; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: .85rem; margin-bottom: .85rem; }
.form-row.single { grid-template-columns: 1fr; }
.form-row-tight { margin-bottom: .85rem; }
.input-field { width: 100%; border: 1.5px solid var(--border); border-radius: 10px; padding: .7rem 1rem; font-family: inherit; font-size: .875rem; color: var(--text); background: white; outline: none; transition: border-color .2s; }
.input-field:focus { border-color: var(--teal); }
.input-field::placeholder { color: #b0b7c3; }
.form-divider { margin: 1.5rem 0; border: none; border-top: 1px solid var(--border); }
.radio-group-label { font-size: .85rem; color: var(--muted); margin-bottom: .65rem; }
.radio-option { display: flex; align-items: center; gap: .6rem; margin-bottom: .45rem; cursor: pointer; font-size: .875rem; }
.radio-option input[type=radio] { accent-color: var(--teal); width: 16px; height: 16px; cursor: pointer; }
textarea.input-field { resize: vertical; min-height: 110px; }
.form-section-label2 { font-weight: 700; font-size: .95rem; margin: 1.5rem 0 .3rem; }
.form-section-label2-tight { margin-top: .25rem; }
.form-helper { font-size: .8rem; color: var(--muted); margin-bottom: .75rem; }
.checkbox-row { display: flex; align-items: center; gap: .6rem; font-size: .83rem; color: #444; margin-bottom: 1.5rem; cursor: pointer; }
.checkbox-row input { accent-color: var(--teal); width: 15px; height: 15px; }
.checkbox-row a { color: var(--teal); }
.presup-submit-row { display: flex; justify-content: flex-end; }
.btn-teal-lg { background: var(--teal); color: white; border: none; padding: .7rem 2rem; border-radius: 99px; font-family: inherit; font-size: .95rem; font-weight: 700; cursor: pointer; transition: background .2s; }
.btn-teal-lg:hover { background: var(--teal-dark); }
.budget-feedback { width: 100%; margin-bottom: .65rem; font-size: .82rem; font-weight: 600; }
.budget-feedback.is-error { color: #b91c1c; }
.budget-feedback.is-success { color: #047857; }

/* Presupuesto sidebar */
.presup-sidebar { background: white; border-radius: 16px; padding: 1.5rem; box-shadow: 0 2px 12px rgba(0,0,0,.07); position: sticky; top: calc(var(--nav-h) + 1rem); }
.presup-sidebar-label { font-size: .78rem; color: var(--muted); font-weight: 600; margin-bottom: 1rem; }
.presup-provider-logo { width: 100%; height: 90px; display: flex; align-items: center; justify-content: center; border: 1.5px solid var(--border); border-radius: 10px; margin-bottom: 1rem; overflow: hidden; padding: .5rem; }
.presup-provider-logo img { max-width: 100%; max-height: 100%; object-fit: contain; }
.presup-provider-name { font-weight: 700; font-size: 1rem; margin-bottom: .3rem; font-family: "Montserrat", "Open Sans", Arial, Helvetica, sans-serif; }
.presup-stars { display: flex; align-items: center; gap: .25rem; color: var(--gold); font-size: .9rem; margin-bottom: .75rem; }
.presup-stars .star-filled { color: var(--gold); }
.presup-stars .star-empty { color: #d1d5db; }
.presup-stars .presup-stars-text { color: var(--muted); font-size: .78rem; font-weight: 400; margin-left: .1rem; }
.presup-response-pill { display: inline-flex; align-items: center; gap: .4rem; background: var(--teal-light); color: var(--teal-dark); border-radius: 99px; padding: .25rem .75rem; font-size: .78rem; font-weight: 600; margin-bottom: 1.25rem; }
.presup-divider { height: 1px; background: var(--border); margin: 1rem 0; }
.presup-tips-title { font-weight: 700; font-size: .85rem; margin-bottom: .7rem; }
.presup-tip { display: flex; align-items: flex-start; gap: .5rem; font-size: .8rem; color: #444; margin-bottom: .5rem; line-height: 1.45; }
.presup-tip svg { color: var(--teal); flex-shrink: 0; margin-top: 2px; }
.presup-sidebar-badge { width: 48px; height: 48px; border-radius: 50%; display: flex; align-items: center; justify-content: center; background: #fff2db; color: #946200; margin-bottom: 1rem; }
.presup-sidebar-heading { font-size: 1.35rem; font-weight: 800; line-height: 1.15; margin-bottom: .25rem; }
.presup-sidebar-copy { font-size: .9rem; color: var(--muted); line-height: 1.45; }
.presup-step { display: flex; align-items: flex-start; gap: .75rem; }
.presup-step + .presup-step { margin-top: 1rem; }
.presup-step-icon { width: 34px; height: 34px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; background: #eefdf9; color: var(--teal-dark); flex-shrink: 0; }
.presup-step-body { min-width: 0; }
.presup-step-title { font-size: .86rem; font-weight: 700; line-height: 1.3; margin-bottom: .15rem; }
.presup-step-copy { font-size: .78rem; color: var(--muted); line-height: 1.45; }

/* REQUEST HELP PAGE */
.directory-request-page .presup-wrap { max-width: 1080px; padding: 0 1.25rem 2.5rem; }
.directory-request-page .presup-layout { grid-template-columns: minmax(0, 1fr) 280px; gap: 1.35rem; margin-top: .85rem; align-items: start; }
.directory-request-page .presup-main,
.directory-request-page .presup-sidebar {
  border: 1px solid #dfe3ea;
  border-radius: 22px;
  box-shadow: none;
  background: #fff;
}
.directory-request-page .presup-main { padding: 1.55rem 1.45rem 1.65rem; }
.directory-request-page .presup-sidebar { padding: 1.25rem 1.1rem; position: static; top: auto; }
.directory-request-page .presup-title {
  font-family: "Montserrat", "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: -.02em;
  margin-bottom: .55rem;
}
.directory-request-page .presup-sub {
  max-width: 620px;
  font-size: .95rem;
  color: #6b7280;
  line-height: 1.55;
  margin-bottom: 2rem;
}
.directory-request-page .form-section-label,
.directory-request-page .form-section-label2 {
  font-size: .96rem;
  font-weight: 600;
  color: #111827;
  margin-bottom: .55rem;
}
.directory-request-page .form-section-label2 { margin-top: 1.05rem; }
.directory-request-page .form-helper,
.directory-request-page .radio-group-label {
  font-size: .8rem;
  color: #5f6773;
  line-height: 1.45;
  margin-bottom: .55rem;
}
.directory-request-page .form-row { gap: 1rem; margin-bottom: 1.05rem; }
.directory-request-page .form-row.single { margin-bottom: .95rem; }
.directory-request-page .input-field {
  border: 1px solid #111827;
  border-radius: 999px;
  padding: .66rem 1rem;
  font-size: .8rem;
  color: #111827;
  background: #fff;
  box-shadow: none;
}
.directory-request-page .input-field:focus {
  border-color: #111827;
  box-shadow: 0 0 0 3px rgba(26,192,178,.12);
}
.directory-request-page .input-field::placeholder { color: #a3aab5; }
.directory-request-page textarea.input-field {
  min-height: 84px;
  border-radius: 18px;
  padding-top: .8rem;
  resize: none;
}
.directory-request-page .form-divider { display: none; }
.directory-request-page .radio-option {
  gap: .5rem;
  margin-bottom: .55rem;
  font-size: .84rem;
  color: #374151;
}
.directory-request-page .radio-option input[type=radio] {
  width: 14px;
  height: 14px;
}
.directory-request-page .checkbox-row {
  gap: .45rem;
  margin: 1.2rem 0 2rem;
  font-size: .72rem;
  color: #374151;
}
.directory-request-page .checkbox-row input {
  width: 13px;
  height: 13px;
}
.directory-request-page .budget-feedback {
  font-size: .78rem;
  margin-bottom: .75rem;
}
.directory-request-page .presup-submit-row { margin-top: .1rem; }
.directory-request-page .btn-teal-lg {
  min-width: 132px;
  padding: .52rem 1.25rem;
  border-radius: 999px;
  font-size: .8rem;
  font-weight: 600;
  box-shadow: none;
}
.directory-request-page .btn-teal-lg:hover,
.directory-request-page .btn-teal-lg:active {
  transform: none;
  box-shadow: none;
}
.directory-request-page .presup-sidebar-badge {
  width: 44px;
  height: 44px;
  margin-bottom: .95rem;
}
.directory-request-page .presup-sidebar-heading {
  font-family: "Montserrat", "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 1.28rem;
  font-weight: 700;
  line-height: 1.15;
  margin-bottom: .25rem;
}
.directory-request-page .presup-sidebar-copy {
  font-size: .86rem;
  color: #6b7280;
  margin-bottom: .15rem;
}
.directory-request-page .presup-divider { margin: .95rem 0 1rem; }
.directory-request-page .presup-step { gap: .68rem; }
.directory-request-page .presup-step + .presup-step { margin-top: .95rem; }
.directory-request-page .presup-step-icon {
  width: 30px;
  height: 30px;
}
.directory-request-page .presup-step-title {
  font-size: .82rem;
  font-weight: 700;
  line-height: 1.3;
  margin-bottom: .12rem;
}
.directory-request-page .presup-step-copy {
  font-size: .72rem;
  color: #7b8491;
  line-height: 1.45;
}

/* PROVIDER BUDGET PAGE */
.directory-budget-page { background: var(--bg); min-height: calc(100vh - var(--nav-h)); }
.directory-budget-page .presup-wrap { max-width: 1080px; padding: 0 1.4rem 2.8rem; }
.directory-budget-page .presup-layout { grid-template-columns: minmax(0, 1fr) 286px; gap: 1.55rem; margin-top: .95rem; align-items: start; }
.directory-budget-page .presup-main,
.directory-budget-page .presup-sidebar {
  background: #fff;
  border: 1px solid #e9eef4;
  border-radius: 22px;
  box-shadow: 0 10px 30px rgba(15,23,42,.06);
}
.directory-budget-page .presup-main { padding: 2.15rem 2.2rem 1.9rem; }
.directory-budget-page .presup-sidebar { padding: 1.1rem 1.15rem 1.25rem; }
.directory-budget-page .presup-title {
  font-family: "Montserrat", "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 2.08rem;
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -.02em;
  margin-bottom: .7rem;
}
.directory-budget-page .presup-sub {
  font-size: .96rem;
  color: #667085;
  line-height: 1.5;
  margin-bottom: 2rem;
}
.directory-budget-page .form-section-label,
.directory-budget-page .form-section-label2 {
  font-family: "Montserrat", "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 1.02rem;
  font-weight: 700;
  color: #101828;
  margin-bottom: .8rem;
}
.directory-budget-page .form-section-label2 {
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  margin-top: .1rem;
  margin-bottom: .55rem;
}
.directory-budget-page .form-helper,
.directory-budget-page .radio-group-label {
  font-size: .92rem;
  color: #667085;
  line-height: 1.55;
  margin-bottom: .8rem;
}
.directory-budget-page .form-row { gap: .9rem; margin-bottom: .85rem; }
.directory-budget-page .form-row.single { margin-bottom: .9rem; }
.directory-budget-page .form-row-tight { margin-bottom: .9rem; }
.directory-budget-page .input-field {
  border: 1px solid #d9e3ee;
  border-radius: 13px;
  padding: .86rem .95rem;
  font-size: .95rem;
  color: #101828;
  background: #fff;
  box-shadow: none;
}
.directory-budget-page .input-field:focus {
  border-color: rgba(29,191,173,.65);
  box-shadow: 0 0 0 4px rgba(29,191,173,.10);
}
.directory-budget-page .input-field::placeholder { color: #b1bcc9; }
.directory-budget-page textarea.input-field {
  min-height: 98px;
  border-radius: 14px;
  padding: .9rem .95rem;
  resize: vertical;
}
.directory-budget-page .form-divider {
  display: block;
  margin: 1.55rem 0 1.55rem;
  border: none;
  border-top: 1px solid #edf2f7;
}
.directory-budget-page .radio-option {
  gap: .58rem;
  margin-bottom: .6rem;
  font-size: .95rem;
  color: #101828;
}
.directory-budget-page .radio-option input[type=radio] {
  width: 15px;
  height: 15px;
  accent-color: var(--teal);
}
.directory-budget-page .checkbox-row {
  gap: .5rem;
  margin: 1.45rem 0 1.75rem;
  font-size: .86rem;
  color: #344054;
}
.directory-budget-page .checkbox-row input {
  width: 14px;
  height: 14px;
}
.directory-budget-page .checkbox-row a {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.directory-budget-page .budget-feedback {
  font-size: .82rem;
  margin-bottom: .8rem;
}
.directory-budget-page .presup-submit-row { margin-top: .1rem; }
.directory-budget-page .btn-teal-lg {
  min-width: 206px;
  padding: .92rem 1.7rem;
  border-radius: 999px;
  background: linear-gradient(90deg, #34d0c2 0%, #1dbfad 100%);
  color: #0f2147;
  font-family: "Montserrat", "Open Sans", Arial, Helvetica, sans-serif;
  font-size: .97rem;
  font-weight: 700;
  box-shadow: 0 14px 30px rgba(29,191,173,.18);
}
.directory-budget-page .btn-teal-lg:hover {
  background: linear-gradient(90deg, #30cbbe 0%, #18b6a7 100%);
  border-color: #18b6a7;
  color: #0f2147;
  box-shadow: 0 14px 30px rgba(29,191,173,.18);
  transform: none;
}
.directory-budget-page .btn-teal-lg:active { transform: none; }
.directory-budget-page .presup-sidebar-label {
  font-size: .92rem;
  font-weight: 600;
  color: #475467;
  margin-bottom: .8rem;
}
.directory-budget-page .presup-provider-summary {
  border: 1px solid #e8edf3;
  border-radius: 14px;
  overflow: hidden;
  background: #fff;
  margin-bottom: .95rem;
}
.directory-budget-page .presup-provider-logo {
  width: 100%;
  height: 104px;
  margin-bottom: 0;
  padding: 1rem 1.2rem;
  border: 0;
  border-bottom: 1px solid #edf2f7;
  border-radius: 0;
}
.directory-budget-page .presup-provider-logo img {
  max-width: 82%;
  max-height: 56px;
}
.directory-budget-page .presup-provider-logo .avatar-initials-md {
  width: 64px;
  height: 64px;
  font-size: 1.08rem;
}
.directory-budget-page .presup-provider-summary-body { padding: .9rem .95rem .95rem; }
.directory-budget-page .presup-provider-name {
  font-size: 1.02rem;
  line-height: 1.15;
  margin-bottom: .45rem;
  color: #1f2937;
}
.directory-budget-page .presup-stars {
  gap: .2rem;
  font-size: .92rem;
  margin-bottom: 0;
}
.directory-budget-page .presup-stars .presup-stars-text {
  font-size: .8rem;
  color: #667085;
}
.directory-budget-page .presup-response-pill {
  display: flex;
  width: 100%;
  justify-content: flex-start;
  gap: .5rem;
  padding: .5rem .8rem;
  background: #e7faf8;
  color: #1f2937;
  font-size: .84rem;
  font-weight: 600;
  margin-bottom: 1.15rem;
}
.directory-budget-page .presup-response-pill svg {
  color: #475467;
  stroke: #475467;
  flex-shrink: 0;
}
.directory-budget-page .presup-response-pill strong {
  color: inherit;
  font-weight: 700;
}
.directory-budget-page .presup-divider {
  background: #edf2f7;
  margin: 1rem 0 1.2rem;
}
.directory-budget-page .presup-tips-title {
  font-family: "Montserrat", "Open Sans", Arial, Helvetica, sans-serif;
  font-size: .98rem;
  font-weight: 700;
  color: #1f2937;
  margin-bottom: .85rem;
}
.directory-budget-page .presup-tip {
  gap: .48rem;
  font-size: .84rem;
  color: #344054;
  line-height: 1.45;
  margin-bottom: .65rem;
}
.directory-budget-page .presup-tip svg {
  color: var(--teal-dark);
  stroke: var(--teal-dark);
  margin-top: .12rem;
}

/* MODAL CONTACTAR */
.modal-overlay { position: fixed; inset: 0; background: rgba(0, 0, 0, .28); z-index: 3000; display: none; align-items: center; justify-content: center; padding: 1.5rem; backdrop-filter: blur(7px); -webkit-backdrop-filter: blur(7px); }
.directory-page-root .modal-overlay { background: rgba(0, 0, 0, .28); backdrop-filter: blur(7px); -webkit-backdrop-filter: blur(7px); }
.modal-overlay.open { display: flex; }
.contact-modal { display: block; position: relative; width: 100%; max-width: 810px; height: auto; overflow: hidden; outline: none; background: white; border-radius: 4px; box-shadow: 0 18px 45px rgba(15,23,42,.08); animation: modalIn .22s ease; }
@keyframes modalIn { from { opacity: 0; transform: translateY(14px) scale(.97); } to { opacity: 1; transform: none; } }
.contact-modal .modal-header { padding: 2.9rem 2.4rem 1.25rem; border-bottom: 1px solid #e7e7e7; display: flex; flex-direction: row; align-items: center; justify-content: flex-start; gap: 1rem; text-align: left; }
.contact-modal .modal-header > div:last-child { flex: 0 1 auto; margin: 0; text-align: left; }
.contact-modal .modal-icon { width: 46px; height: 46px; border-radius: 50%; background: #1fc0b1; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.contact-modal .modal-icon svg { width: 31px; height: 31px; display: block; }
.contact-modal .modal-title { width: auto; margin: 0; font-family: "Montserrat", "Open Sans", Arial, Helvetica, sans-serif; font-size: 1.72rem; font-weight: 800; line-height: 1.12; color: #303136; letter-spacing: -.03em; text-align: left; }
.contact-modal .modal-subtitle { width: auto; font-size: .98rem; color: #6f7379; margin-top: .22rem; line-height: 1.35; text-align: left; }
.modal-body { margin: 1.9rem 1.9rem 0; padding: 1.6rem 1.45rem 1.35rem; border-radius: 8px; background: #fbfbfc; }
.modal-field + .modal-field { margin-top: 1.35rem; }
.modal-label { font-weight: 400; font-size: .92rem; margin-bottom: .38rem; display: block; color: #303136; }
.modal-input { width: 100%; border: 1px solid #d9dde3; border-radius: 3px; padding: .68rem .78rem; font-family: inherit; font-size: .98rem; color: var(--text); outline: none; transition: border-color .2s, box-shadow .2s; margin-bottom: 0; background: #fff; }
.modal-input:focus { border-color: var(--teal); background: white; box-shadow: 0 0 0 3px rgba(31,192,177,.12); }
.modal-input::placeholder { color: #8b8f97; }
textarea.modal-input { resize: vertical; min-height: 138px; margin-bottom: 0; }
.modal-footer { padding: 2rem 2.35rem 2.75rem; display: flex; justify-content: flex-end; gap: 1rem; }
.contact-modal .btn-cancel,
.contact-modal .btn-send { min-width: 158px; min-height: 38px; padding: .52rem 1.35rem; border-radius: 99px; font-family: "Montserrat", "Open Sans", Arial, Helvetica, sans-serif; font-size: .92rem; font-weight: 500; cursor: pointer; box-shadow: none; transform: none; }
.contact-modal .btn-cancel { background: #fff; border: 2px solid var(--teal); color: #303136; }
.contact-modal .btn-cancel:hover { background: #fff; border-color: var(--teal-dark); color: #303136; box-shadow: none; transform: none; }
.contact-modal .btn-send { background: var(--teal); color: #0f2147; border: 2px solid var(--teal); }
.contact-modal .btn-send:hover { background: var(--teal-dark); border-color: var(--teal-dark); color: #0f2147; box-shadow: none; transform: none; }
.contact-modal .btn-send:disabled { opacity: .78; cursor: default; transform: none; }
.contact-modal-success {
  display: none;
  align-items: center;
  gap: .7rem;
  margin: 1rem 1.9rem 0;
  padding: .85rem 1rem;
  border: 1px solid rgba(20, 184, 166, .22);
  border-radius: 14px;
  background: #e6f9f7;
  color: #0f766e;
  font-family: "Montserrat", "Open Sans", Arial, Helvetica, sans-serif;
  font-size: .9rem;
  font-weight: 600;
  line-height: 1.35;
}
.contact-modal.is-success .contact-modal-success { display: flex; }
.contact-modal-success-icon {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  background: var(--teal);
  color: #fff;
  font-weight: 800;
}
.dp-unsupported-note { margin-top: .55rem; font-size: .74rem; color: #6b7280; line-height: 1.35; }

/* FOOTER */

/* HAMBURGER */

@media (max-width: 900px) {
  .content-layout, .presup-layout { grid-template-columns: 1fr; }
  .sidebar { position: static; top: auto; }
  .presup-sidebar { position: static; top: auto; }
  .reviews-grid { grid-template-columns: 1fr; }
  .services-cols { grid-template-columns: 1fr; }
  .directory-request-page .presup-layout { grid-template-columns: 1fr; gap: 1rem; }
  .directory-budget-page .presup-layout { grid-template-columns: 1fr; gap: 1rem; }
}

/* In this project the navbar offset is already applied by .extra-mg-nav */
.directory-profile-root .sidebar { top: calc(var(--nav-h) + 1rem); }
.directory-profile-root .presup-sidebar { top: calc(var(--nav-h) + 1rem); }

@media (max-width: 640px) {
  .hero-help-action { margin-top: .95rem; }
  .hero-help-link { width: auto; max-width: 100%; justify-content: center; gap: .42rem; padding: .28rem .66rem .28rem .58rem; }
  .hero-help-link-icon { width: 22px; height: 22px; }
  .hero-help-link-icon svg { width: 19px; height: 19px; }
  .hero-help-link-label { font-size: .8rem; line-height: .95; }
  .help-cta-band { border-radius: 20px; padding: 1.3rem; gap: 1.35rem; }
  .help-cta-title { font-size: 1.34rem; }
  .help-cta-sub { font-size: .92rem; line-height: 1.45; margin-bottom: 1rem; }
  .help-cta-point { font-size: .92rem; }
  .help-cta-button { width: auto; }
  .help-cta-visual { justify-content: flex-start; gap: .55rem; }
  .help-cta-circle { width: 120px; height: 120px; }
  .help-cta-circle + .help-cta-circle { margin-left: 0; }
  .form-row { grid-template-columns: 1fr; }
  .presup-main { padding: 1.25rem; }
  .presup-title { font-size: 1.5rem; }
  .directory-budget-page .presup-wrap { padding: 0 1rem 2rem; }
  .directory-budget-page .presup-main { padding: 1.3rem 1.1rem 1.4rem; }
  .directory-budget-page .presup-sidebar { padding: 1rem; }
  .directory-budget-page .presup-title { font-size: 1.72rem; }
  .directory-budget-page .presup-sub { font-size: .9rem; margin-bottom: 1.45rem; }
  .directory-budget-page .input-field { font-size: .9rem; padding: .8rem .9rem; }
  .directory-budget-page textarea.input-field { min-height: 96px; }
  .directory-budget-page .btn-teal-lg { width: 100%; min-width: 0; }
  .directory-request-page .presup-wrap { padding: 0 1rem 2rem; }
  .directory-request-page .presup-main { padding: 1.15rem 1rem 1.3rem; }
  .directory-request-page .presup-sidebar { padding: 1rem; }
  .directory-request-page .presup-sidebar,
  .directory-budget-page .presup-sidebar { order: -1; }
  .directory-request-page .presup-main,
  .directory-budget-page .presup-main { order: 1; }
  .directory-request-page .presup-title { font-size: 1.55rem; }
  .directory-request-page .presup-sub { font-size: .88rem; margin-bottom: 1.35rem; }
  .directory-request-page textarea.input-field { min-height: 96px; }
  .offers-empty-state { min-height: 240px; padding: 2.25rem 1rem; }
  .offers-empty-icon { width: 58px; height: 58px; }
  .modal-overlay { padding: .85rem; align-items: flex-start; overflow-y: auto; }
  .contact-modal { margin: 0 auto; max-height: calc(100dvh - 1.7rem); overflow-y: auto; }
  .contact-modal .modal-header { padding: 1.05rem 1rem .9rem; gap: .72rem; align-items: flex-start; }
  .contact-modal .modal-header > div:last-child { flex: 1; min-width: 0; }
  .contact-modal .modal-icon { width: 40px; height: 40px; }
  .contact-modal .modal-icon svg { width: 27px; height: 27px; }
  .contact-modal .modal-title { font-size: 1.24rem; line-height: 1.15; }
  .contact-modal .modal-subtitle { font-size: .86rem; line-height: 1.35; }
  .modal-body { margin: 1rem .9rem 0; padding: 1rem .9rem; }
  .contact-modal-success { margin: .85rem .9rem 0; font-size: .82rem; }
  textarea.modal-input { min-height: 120px; }
  .modal-footer { padding: 1.1rem .9rem 1.35rem; flex-direction: column-reverse; gap: .7rem; }
  .contact-modal .btn-cancel,
  .contact-modal .btn-send { width: 100%; min-width: 0; }
  .profile-name { font-size: 1.25rem; }
  .profile-meta { gap: .75rem; font-size: .8rem; }
  .banner-wrap { height: 185px; }
  .logo-circle { width: 88px; height: 88px; margin-top: -44px; }
  .offer-card-big { min-height: 138px; }
  .offer-card-img { width: 120px; min-width: 120px; }
  .offer-card-body { padding: .85rem 1rem .85rem; }
  .offer-card-title { font-size: 1rem; }
  .offer-card-sub { font-size: .78rem; margin-bottom: .55rem; }
  .offer-badge { min-width: 128px; min-height: 32px; font-size: .86rem; padding: .5rem .75rem; margin-bottom: .34rem; }
  .offer-until { font-size: .74rem; }
}

/* DIRECTORY BUTTON SYSTEM */
.directory-page-root {
  --directory-btn-primary-bg: #2ac9bb;
  --directory-btn-primary-bg-hover: #1fc0b1;
  --directory-btn-primary-border: #2ac9bb;
  --directory-btn-primary-border-hover: #1fc0b1;
  --directory-btn-primary-text: #0f2147;
  --directory-btn-secondary-bg: #fff;
  --directory-btn-secondary-bg-hover: #f3fcfb;
  --directory-btn-secondary-border: #2ac9bb;
  --directory-btn-secondary-border-hover: #1fc0b1;
  --directory-btn-secondary-text: #0f2147;
  --directory-btn-focus-ring: rgba(42,201,187,.22);
  --directory-btn-shadow: 0 10px 22px rgba(29,191,173,.18);
  --directory-btn-shadow-hover: 0 14px 28px rgba(29,191,173,.22);
}

.hero-search-btn,
.drawer-apply-btn,
.btn-see-all,
.btn-ver,
.btn-presup,
.btn-teal,
.btn-outline,
.btn-ghost,
.btn-outline-w,
.btn-detail-full,
.btn-teal-w,
.btn-teal-lg,
.btn-cancel,
.btn-send {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .35rem;
  color: var(--directory-btn-secondary-text);
  border-radius: 999px;
  font-family: inherit;
  font-weight: 700;
  text-align: center;
  text-decoration: none;
  transition: background .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease, transform .16s ease;
}

.hero-search-btn,
.drawer-apply-btn,
.btn-presup,
.btn-teal,
.btn-teal-w,
.btn-teal-lg,
.btn-send {
  background: var(--directory-btn-primary-bg);
  color: var(--directory-btn-primary-text);
  border: 1.5px solid var(--directory-btn-primary-border);
  box-shadow: var(--directory-btn-shadow);
}

.hero-search-btn:hover,
.drawer-apply-btn:hover,
.btn-presup:hover,
.btn-teal:hover,
.btn-teal-w:hover,
.btn-teal-lg:hover,
.btn-send:hover {
  background: var(--directory-btn-primary-bg-hover);
  color: var(--directory-btn-primary-text);
  border-color: var(--directory-btn-primary-border-hover);
  box-shadow: var(--directory-btn-shadow-hover);
  transform: translateY(-1px);
}

.btn-see-all,
.btn-ver,
.btn-outline,
.btn-ghost,
.btn-outline-w,
.btn-detail-full,
.btn-cancel {
  background: var(--directory-btn-secondary-bg);
  color: var(--directory-btn-secondary-text);
  border: 1.5px solid var(--directory-btn-secondary-border);
  box-shadow: none;
}

.btn-see-all:hover,
.btn-ver:hover,
.btn-outline:hover,
.btn-ghost:hover,
.btn-outline-w:hover,
.btn-detail-full:hover,
.btn-cancel:hover {
  background: var(--directory-btn-secondary-bg-hover);
  color: var(--directory-btn-secondary-text);
  border-color: var(--directory-btn-secondary-border-hover);
  transform: translateY(-1px);
}

.hero-search-btn:focus-visible,
.drawer-apply-btn:focus-visible,
.btn-see-all:focus-visible,
.btn-ver:focus-visible,
.btn-presup:focus-visible,
.btn-teal:focus-visible,
.btn-outline:focus-visible,
.btn-ghost:focus-visible,
.btn-outline-w:focus-visible,
.btn-detail-full:focus-visible,
.btn-teal-w:focus-visible,
.btn-teal-lg:focus-visible,
.btn-cancel:focus-visible,
.btn-send:focus-visible {
  outline: none;
  box-shadow: 0 0 0 4px var(--directory-btn-focus-ring);
}

.hero-search-btn:active,
.drawer-apply-btn:active,
.btn-see-all:active,
.btn-ver:active,
.btn-presup:active,
.btn-teal:active,
.btn-outline:active,
.btn-ghost:active,
.btn-outline-w:active,
.btn-detail-full:active,
.btn-teal-w:active,
.btn-teal-lg:active,
.btn-cancel:active,
.btn-send:active {
  transform: translateY(0);
}

.hero-search-btn {
  border-radius: 0 999px 999px 0;
  box-shadow: none;
}

.hero-search-btn:hover,
.hero-search-btn:active {
  box-shadow: none;
  transform: none;
}

.hero-search-btn:focus-visible {
  box-shadow: 0 0 0 4px var(--directory-btn-focus-ring);
}

.btn-presup {
  padding-left: 1.25rem;
  padding-right: 1.25rem;
}

.provider-actions .btn-presup {
  background: var(--directory-btn-primary-bg);
  color: var(--directory-btn-primary-text);
  border: 1.5px solid var(--directory-btn-primary-border);
  padding: .38rem 1.05rem;
  min-height: 32px;
  font-weight: 500;
  box-shadow: none;
}

.provider-actions .btn-presup:hover {
  background: var(--directory-btn-primary-bg-hover);
  color: var(--directory-btn-primary-text);
  border-color: var(--directory-btn-primary-border-hover);
  box-shadow: none;
  transform: none;
}

.provider-actions .btn-ver {
  background: var(--directory-btn-secondary-bg);
  color: var(--directory-btn-secondary-text);
  border: 1.5px solid var(--directory-btn-secondary-border);
  padding: .36rem 1.05rem;
  min-height: 32px;
  font-weight: 500;
  box-shadow: none;
}

.provider-actions .btn-ver:hover {
  background: var(--directory-btn-secondary-bg-hover);
  color: var(--directory-btn-secondary-text);
  border-color: var(--directory-btn-secondary-border-hover);
  box-shadow: none;
  transform: none;
}

/* RESPONSIVE STABILIZATION PASS */
.directory-page-root,
.directory-page-root * {
  min-width: 0;
}

.directory-page-root img,
.directory-page-root svg {
  max-width: 100%;
}

@media (max-width: 1366px) {
  .directory-page-root .page,
  .directory-page-root .main-wrap,
  .directory-page-root .breadcrumb,
  .directory-page-root .presup-wrap {
    max-width: min(1140px, calc(100vw - 48px));
  }

  .hero-title {
    font-size: clamp(2.35rem, 4vw, 3rem);
  }

  .help-cta-band {
    margin-left: auto;
    margin-right: auto;
  }

  .help-cta-visual {
    transform: translateX(72px);
  }

  .help-cta-circle {
    width: 158px;
    height: 158px;
  }
}

@media (max-width: 1120px) {
  .main-wrap {
    grid-template-columns: 250px minmax(0, 1fr);
    gap: 1.15rem;
  }

  .filters-panel {
    padding: 1.2rem;
  }

  .provider-logo-wrap {
    width: 210px;
    min-width: 175px;
  }

  .provider-body {
    padding: 1.15rem 1.25rem;
  }

  .content-layout {
    grid-template-columns: minmax(0, 1fr) 285px;
    gap: 1rem;
  }

  .directory-request-page .presup-layout,
  .directory-budget-page .presup-layout {
    grid-template-columns: minmax(0, 1fr) 260px;
    gap: 1.1rem;
  }

  .directory-budget-page .presup-main {
    padding: 1.85rem 1.75rem 1.65rem;
  }
}

@media (max-width: 1024px) {
  .hero {
    padding-top: 4.2rem;
    padding-bottom: 3.3rem;
  }

  .hero-inner {
    max-width: 720px;
  }

  .section-wrap {
    padding: 2.6rem 0;
  }

  .cards-row,
  .urgency-row {
    gap: .85rem;
  }

  .company-card-body,
  .urgency-card-body {
    padding: .8rem .85rem .95rem;
  }

  .company-card-name,
  .urgency-card-name {
    font-size: .84rem;
  }

  .categories-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .services-grid {
    gap: .85rem;
  }

  .provider-actions {
    flex-wrap: wrap;
  }

  .profile-header-wrap,
  .card,
  .presup-main,
  .presup-sidebar {
    max-width: 100%;
  }
}

@media (max-width: 900px) {
  .directory-page-root .main-wrap,
  .directory-page-root .breadcrumb,
  .directory-page-root .page,
  .directory-page-root .presup-wrap {
    max-width: 100%;
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }

  .main-wrap,
  .content-layout,
  .presup-layout,
  .directory-request-page .presup-layout,
  .directory-budget-page .presup-layout {
    grid-template-columns: 1fr;
  }

  .results-bar {
    gap: .75rem;
  }

  .search-bar-wrap {
    max-width: none;
    flex: 1 1 260px;
  }

  .dp-quick-filters {
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: .15rem;
    scrollbar-width: none;
  }

  .dp-quick-filters::-webkit-scrollbar {
    display: none;
  }

  .dp-filter-chip {
    flex: 0 0 auto;
    min-height: 38px;
  }

  .filter-drawer {
    width: min(360px, 90vw);
  }

  .content-layout,
  .presup-layout {
    gap: 1rem;
  }

  .sidebar {
    position: static;
  }

  .rating-overview {
    gap: 1.2rem;
  }

  .tabs {
    overflow-x: auto;
    scrollbar-width: none;
  }

  .tabs::-webkit-scrollbar {
    display: none;
  }

  .tab-btn {
    min-width: 150px;
  }

  .directory-request-page .presup-main,
  .directory-budget-page .presup-main {
    padding: 1.45rem 1.25rem 1.5rem;
  }

  .directory-request-page .presup-sidebar,
  .directory-budget-page .presup-sidebar {
    position: static;
  }
}

@media (max-width: 768px) {
  .hero-title {
    font-size: clamp(1.9rem, 7vw, 2.35rem);
  }

  .hero-search {
    width: min(100%, 560px);
  }

  .help-cta-band {
    padding: 1.55rem;
  }

  .help-cta-copy {
    flex-basis: auto;
    width: 100%;
  }

  .help-cta-visual {
    flex-basis: auto;
    width: 100%;
    transform: none;
  }

  .cards-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .urgency-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .services-grid {
    grid-template-columns: 1fr;
  }

  .profile-card {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }

  .profile-actions {
    flex-wrap: wrap;
  }

  .profile-actions .btn-teal,
  .profile-actions .btn-outline {
    min-width: 176px;
  }

  .rating-overview {
    align-items: stretch;
  }

  .offer-card-big {
    min-height: 150px;
  }

  .directory-request-page .presup-title,
  .directory-budget-page .presup-title {
    font-size: clamp(1.55rem, 5vw, 1.9rem);
  }
}

@media (max-width: 640px) {
  .directory-page-root {
    font-size: 14px;
  }

  .directory-page-root .page,
  .directory-page-root .main-wrap,
  .directory-page-root .breadcrumb,
  .directory-page-root .presup-wrap {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .hero {
    padding: 2.75rem 1rem 2.25rem;
  }

  .hero-search {
    width: 100%;
    max-width: none;
  }

  .hero-search-main input {
    font-size: .86rem;
  }

  .hero-help-link {
    min-height: 40px;
  }

  .section-wrap {
    padding: 2rem 0;
  }

  .section-title {
    font-size: 1.12rem;
  }

  .directory-home-root .section-alt {
    margin-left: 0;
    margin-right: 0;
    padding-left: 0;
    padding-right: 0;
  }

  .directory-home-root .section-alt .section-inner {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .directory-home-root .section-alt .company-cards-scroll {
    margin-left: 0;
    margin-right: 0;
  }

  .company-cards-scroll {
    margin-left: -1rem;
    margin-right: -1rem;
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .cards-row,
  .urgency-row {
    scroll-snap-type: x proximity;
  }

  .cards-row .company-card,
  .urgency-row .urgency-card {
    min-width: min(215px, 76vw);
    scroll-snap-align: start;
  }

  .help-cta-band {
    overflow: hidden;
  }

  .help-cta-visual {
    justify-content: flex-start;
    width: calc(100% + 1rem);
    margin-right: -1rem;
    overflow: hidden;
  }

  .help-cta-circle {
    width: 108px;
    height: 108px;
  }

  .cat-page-search {
    padding: .45rem .55rem .45rem .85rem;
  }

  .cat-full-grid {
    gap: .6rem;
  }

  .main-wrap {
    padding-top: 1rem;
  }

  .results-bar {
    align-items: stretch;
  }

  .directory-page-root .results-title {
    width: 100%;
    white-space: normal;
    overflow-wrap: anywhere;
    line-height: 1.35;
  }

  .filter-toggle-btn {
    width: 40px;
    height: 40px;
    background: #fff;
    border-color: #d7dde4;
    color: var(--teal);
  }

  .filter-toggle-btn svg {
    width: 16px;
    height: 16px;
    display: block;
    color: currentColor;
    overflow: visible;
  }

  .filter-toggle-btn svg * {
    fill: none;
    stroke: currentColor;
  }

  .search-bar-input {
    min-height: 40px;
  }

  .provider-card {
    flex-direction: column;
    border-radius: 16px;
  }

  .provider-logo-wrap {
    width: 100%;
    min-width: 0;
    align-self: stretch;
    height: 118px;
    border-right: 0;
    border-bottom: 1px solid var(--border);
    padding: 1.15rem;
  }

  .provider-actions .btn-presup,
  .provider-actions .btn-ver {
    min-height: 38px;
  }

  .rating-overview {
    flex-direction: column;
  }

  .rating-big {
    width: 100%;
  }

  .bar-row {
    gap: .4rem;
  }

  .tabs-wrap {
    margin-left: -1.25rem;
    margin-right: -1.25rem;
  }

  .tab-btn {
    min-width: 128px;
    padding: .85rem .65rem;
  }

  .profile-actions .btn-teal,
  .profile-actions .btn-outline {
    width: 100%;
  }

  .offer-card-big {
    flex-direction: column;
  }

  .offer-card-img {
    width: 100%;
    min-width: 0;
    height: 132px;
  }

  .presup-main,
  .presup-sidebar,
  .directory-request-page .presup-main,
  .directory-request-page .presup-sidebar,
  .directory-budget-page .presup-main,
  .directory-budget-page .presup-sidebar {
    border-radius: 18px;
  }

  .form-row {
    grid-template-columns: 1fr;
    gap: .7rem;
  }

  .input-field,
  .directory-request-page .input-field,
  .directory-budget-page .input-field {
    min-height: 42px;
  }

  .checkbox-row {
    align-items: flex-start;
  }

  .presup-submit-row {
    justify-content: stretch;
  }
}

@media (max-width: 430px) {
  .directory-page-root .page,
  .directory-page-root .main-wrap,
  .directory-page-root .breadcrumb,
  .directory-page-root .presup-wrap {
    padding-left: .9rem;
    padding-right: .9rem;
  }

  .hero-title {
    font-size: 1.42rem;
  }

  .hero-sub {
    font-size: .84rem;
  }

  .hero-search-main {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .help-cta-band {
    padding: 1.15rem;
  }

  .help-cta-title {
    font-size: 1.22rem;
  }

  .help-cta-circle {
    width: 96px;
    height: 96px;
  }

  .categories-grid .category-card {
    min-width: 118px;
  }

  .cards-row .company-card,
  .urgency-row .urgency-card {
    min-width: min(202px, 78vw);
  }

  .category-token-box {
    padding-right: 2rem;
  }

  .directory-page-root .category-token-box .category-token-chip {
    max-width: 134px;
  }

  .results-title {
    white-space: normal;
  }

  .pagination {
    gap: .35rem;
  }

  .page-btn {
    width: 34px;
    height: 34px;
  }

  .profile-name {
    font-size: 1.14rem;
  }

  .profile-meta {
    flex-direction: column;
    gap: .45rem;
  }

  .contact-modal .modal-header {
    align-items: flex-start;
    gap: .62rem;
    padding: .95rem .9rem .82rem;
  }

  .contact-modal .modal-title {
    font-size: 1.1rem;
    line-height: 1.16;
  }

  .contact-modal .modal-subtitle {
    font-size: .8rem;
  }
}

@media (max-width: 360px) {
  .directory-page-root .page,
  .directory-page-root .main-wrap,
  .directory-page-root .breadcrumb,
  .directory-page-root .presup-wrap {
    padding-left: .75rem;
    padding-right: .75rem;
  }

  .hero-title {
    font-size: 1.32rem;
  }

  .help-cta-circle {
    width: 88px;
    height: 88px;
  }

  .cards-row .company-card,
  .urgency-row .urgency-card {
    min-width: 188px;
  }

  .provider-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .provider-actions .btn-presup,
  .provider-actions .btn-ver {
    width: 100%;
  }

  .tab-btn {
    min-width: 112px;
    font-size: .8rem;
  }

  .contact-modal .modal-icon {
    width: 36px;
    height: 36px;
  }

  .contact-modal .modal-icon svg {
    width: 24px;
    height: 24px;
  }

  .directory-request-page .btn-teal-lg,
  .directory-budget-page .btn-teal-lg {
    width: 100%;
    min-width: 0;
  }
}

@media (max-width: 640px) {
  .directory-home-root .company-cards-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }

  .directory-home-root .company-cards-scroll::-webkit-scrollbar {
    display: none;
  }

  .directory-home-root #featuredCompaniesRow,
  .directory-home-root #topRatedCompaniesRow {
    display: flex;
    gap: .65rem;
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x proximity;
    scrollbar-width: none;
  }

  .directory-home-root #featuredCompaniesRow::-webkit-scrollbar,
  .directory-home-root #topRatedCompaniesRow::-webkit-scrollbar {
    display: none;
  }

  .directory-home-root #featuredCompaniesRow > .company-card,
  .directory-home-root #topRatedCompaniesRow > .company-card {
    box-sizing: border-box;
    flex: 0 0 calc((100% - .65rem) / 2);
    width: calc((100% - .65rem) / 2);
    min-width: calc((100% - .65rem) / 2);
    max-width: calc((100% - .65rem) / 2);
    scroll-snap-align: start;
  }

  .directory-home-root .company-card-logo {
    height: 78px;
    padding: .6rem;
  }

  .directory-home-root .company-card-body {
    padding: .62rem .58rem .72rem;
    gap: .24rem;
  }

  .directory-home-root .provider-card-logo {
    width: 52px;
    height: 52px;
    border-radius: 14px;
    font-size: .98rem;
  }

  .directory-home-root .company-card-name {
    font-size: .76rem;
    line-height: 1.28;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }

  .directory-home-root .company-card-stars {
    flex-wrap: wrap;
    gap: .12rem .22rem;
    font-size: .72rem;
    line-height: 1.2;
  }

  .directory-home-root .company-card-stars .cs-score,
  .directory-home-root .company-card-stars .cs-count,
  .directory-home-root .company-card-tag,
  .directory-home-root .company-card-desc,
  .directory-home-root .company-card-location {
    font-size: .66rem;
  }

  .directory-home-root .company-card-tag {
    padding: .12rem .36rem;
  }
}

/* Provider budget page aligned with the request-help/contact form style */
.directory-budget-page {
  background: var(--bg);
  min-height: calc(100vh - var(--nav-h));
}

.directory-budget-page .presup-wrap {
  max-width: 1080px;
  padding: 0 1.25rem 2.5rem;
}

.directory-budget-page .presup-layout {
  grid-template-columns: 1fr;
  gap: 1rem;
  margin-top: .85rem;
  align-items: start;
}

.directory-budget-page .presup-main,
.directory-budget-page .presup-sidebar {
  border: 1px solid #dfe3ea;
  border-radius: 22px;
  box-shadow: none;
  background: #fff;
}

.directory-budget-page .presup-main {
  order: 1;
  padding: 1.55rem 1.45rem 1.65rem;
}

.directory-budget-page .presup-sidebar {
  order: -1;
  padding: 1.25rem 1.1rem;
  position: static;
  top: auto;
}

.directory-budget-page .presup-provider-panel {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(240px, .85fr);
  gap: 1.15rem;
  align-items: stretch;
}

.directory-budget-page .presup-provider-info,
.directory-budget-page .presup-provider-assist {
  min-width: 0;
}

.directory-budget-page .presup-provider-assist {
  display: flex;
  flex-direction: column;
  justify-content: center;
  border-left: 1px solid #edf2f7;
  padding-left: 1.15rem;
}

.directory-budget-page .presup-title {
  font-family: "Montserrat", "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: -.02em;
  margin-bottom: .55rem;
}

.directory-budget-page .presup-sub {
  max-width: 620px;
  font-size: .95rem;
  color: #6b7280;
  line-height: 1.55;
  margin-bottom: 2rem;
}

.directory-budget-page .form-section-label,
.directory-budget-page .form-section-label2 {
  font-family: "Montserrat", "Open Sans", Arial, Helvetica, sans-serif;
  font-size: .96rem;
  font-weight: 600;
  color: #111827;
  margin-bottom: .55rem;
}

.directory-budget-page .form-section-label2 {
  margin-top: 1.05rem;
}

.directory-budget-page .form-helper,
.directory-budget-page .radio-group-label {
  font-size: .8rem;
  color: #5f6773;
  line-height: 1.45;
  margin-bottom: .55rem;
}

.directory-budget-page .form-row {
  gap: 1rem;
  margin-bottom: 1.05rem;
}

.directory-budget-page .form-row.single {
  margin-bottom: .95rem;
}

.directory-budget-page .input-field {
  border: 1px solid #111827;
  border-radius: 999px;
  padding: .66rem 1rem;
  font-size: .8rem;
  color: #111827;
  background: #fff;
  box-shadow: none;
}

.directory-budget-page .input-field:focus {
  border-color: #111827;
  box-shadow: 0 0 0 3px rgba(26,192,178,.12);
}

.directory-budget-page .input-field::placeholder {
  color: #a3aab5;
}

.directory-budget-page textarea.input-field {
  min-height: 84px;
  border-radius: 18px;
  padding-top: .8rem;
  resize: none;
}

.directory-budget-page .form-divider {
  display: none;
}

.directory-budget-page .radio-option {
  gap: .5rem;
  margin-bottom: .55rem;
  font-size: .84rem;
  color: #374151;
}

.directory-budget-page .radio-option input[type=radio] {
  width: 14px;
  height: 14px;
}

.directory-budget-page .checkbox-row {
  gap: .45rem;
  margin: 1.2rem 0 2rem;
  font-size: .72rem;
  color: #374151;
}

.directory-budget-page .checkbox-row input {
  width: 13px;
  height: 13px;
}

.directory-budget-page .budget-feedback {
  font-size: .78rem;
  margin-bottom: .75rem;
}

.directory-budget-page .presup-submit-row {
  margin-top: .1rem;
}

.directory-budget-page .btn-teal-lg {
  min-width: 132px;
  padding: .52rem 1.25rem;
  border-radius: 999px;
  background: var(--teal);
  color: #0f2147;
  border-color: var(--teal);
  font-family: "Montserrat", "Open Sans", Arial, Helvetica, sans-serif;
  font-size: .8rem;
  font-weight: 600;
  box-shadow: none;
}

.directory-budget-page .btn-teal-lg:hover,
.directory-budget-page .btn-teal-lg:active {
  background: var(--teal-dark);
  border-color: var(--teal-dark);
  color: #0f2147;
  transform: none;
  box-shadow: none;
}

.directory-budget-page .presup-sidebar-label {
  font-size: .78rem;
  color: #5f6773;
  font-weight: 600;
  margin-bottom: .75rem;
}

.directory-budget-page .presup-provider-summary {
  border: 1px solid #dfe3ea;
  border-radius: 14px;
  overflow: hidden;
  background: #fff;
  margin-bottom: 0;
}

.directory-budget-page .presup-provider-logo {
  height: 86px;
  margin-bottom: 0;
  padding: .75rem 1rem;
  border: 0;
  border-bottom: 1px solid #edf2f7;
  border-radius: 0;
}

.directory-budget-page .presup-provider-logo img {
  max-width: 82%;
  max-height: 52px;
}

.directory-budget-page .presup-provider-logo .avatar-initials-md {
  width: 58px;
  height: 58px;
  font-size: 1rem;
}

.directory-budget-page .presup-provider-summary-body {
  padding: .82rem .9rem .9rem;
}

.directory-budget-page .presup-provider-name {
  font-size: .92rem;
  line-height: 1.25;
  margin-bottom: .35rem;
  color: #111827;
}

.directory-budget-page .presup-stars {
  gap: .18rem;
  font-size: .82rem;
  margin-bottom: 0;
}

.directory-budget-page .presup-stars .presup-stars-text {
  font-size: .72rem;
  color: #6b7280;
}

.directory-budget-page .presup-response-pill {
  display: inline-flex;
  width: auto;
  align-self: flex-start;
  justify-content: flex-start;
  gap: .4rem;
  padding: .28rem .62rem;
  background: var(--teal-light);
  color: #303136;
  font-size: .72rem;
  font-weight: 600;
  margin-bottom: .85rem;
  box-shadow: none;
}

.directory-budget-page .presup-response-pill svg {
  color: #303136;
  stroke: #303136;
  flex-shrink: 0;
}

.directory-budget-page .presup-response-pill strong {
  color: inherit;
  font-weight: 700;
}

.directory-budget-page .presup-divider {
  background: #edf2f7;
  margin: .95rem 0 1rem;
}

.directory-budget-page .presup-tips-title {
  font-family: "Montserrat", "Open Sans", Arial, Helvetica, sans-serif;
  font-size: .82rem;
  font-weight: 700;
  color: #111827;
  margin-bottom: .55rem;
}

.directory-budget-page .presup-tip {
  gap: .45rem;
  font-size: .72rem;
  color: #374151;
  line-height: 1.45;
  margin-bottom: .45rem;
}

.directory-budget-page .presup-tip svg {
  color: var(--teal-dark);
  stroke: var(--teal-dark);
  margin-top: .12rem;
}

@media (max-width: 700px) {
  .directory-budget-page .presup-provider-panel {
    grid-template-columns: 1fr;
    gap: .95rem;
  }

  .directory-budget-page .presup-provider-assist {
    border-left: 0;
    border-top: 1px solid #edf2f7;
    padding-left: 0;
    padding-top: .95rem;
  }
}

@media (max-width: 900px) {
  .directory-budget-page .presup-layout {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .directory-budget-page .presup-main {
    padding: 1.45rem 1.25rem 1.5rem;
  }

  .directory-budget-page .presup-sidebar {
    position: static;
    order: -1;
  }

  .directory-budget-page .presup-main {
    order: 1;
  }
}

@media (max-width: 640px) {
  .directory-budget-page .presup-wrap {
    padding: 0 1rem 2rem;
  }

  .directory-budget-page .presup-main {
    padding: 1.15rem 1rem 1.3rem;
  }

  .directory-budget-page .presup-sidebar {
    padding: 1rem;
    order: -1;
  }

  .directory-budget-page .presup-main {
    order: 1;
  }

  .directory-budget-page .presup-title {
    font-size: 1.55rem;
  }

  .directory-budget-page .presup-sub {
    font-size: .88rem;
    margin-bottom: 1.35rem;
  }

  .directory-budget-page textarea.input-field {
    min-height: 96px;
  }
}

@media (max-width: 430px) {
  .directory-budget-page .presup-wrap {
    padding-left: .9rem;
    padding-right: .9rem;
  }
}

@media (max-width: 360px) {
  .directory-budget-page .btn-teal-lg {
    width: 100%;
    min-width: 0;
  }
}
