/* ============================================================
   TCS REAL ESTATE INTERNATIONAL — Global Design System
   WCAG 2.1 AA | ADA Accessible | Brand Colors & Manrope
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@300;400;500;600;700;800&display=swap');

:root {
  --tcs-teal-dark: #0c414e;
  --tcs-teal: #0e5a6e;
  --tcs-teal-light: #1a7a94;
  --tcs-terra: #9d442a;
  --tcs-terra-light: #b8553a;
  --tcs-terra-dark: #7e3520;
  --tcs-gold: #bc804d;
  --tcs-gold-light: #d4995f;
  --tcs-gold-dark: #a06b3a;
  --tcs-cream: #d7c2b0;
  --tcs-cream-light: #f5efe9;
  --tcs-cream-bg: #faf7f4;
  --tcs-white: #ffffff;
  --tcs-text: #2d2a26;
  --tcs-text-light: #5c574f;
  --tcs-text-muted: #8a8478;
  --tcs-border: #e5ddd3;
  --font-main: 'Manrope', system-ui, -apple-system, sans-serif;
  --space-xs: 0.5rem; --space-sm: 1rem; --space-md: 1.5rem;
  --space-lg: 2.5rem; --space-xl: 4rem; --space-2xl: 6rem; --space-3xl: 8rem;
  --max-width: 1200px; --max-width-narrow: 800px; --header-height: 80px;
  --radius: 6px; --radius-lg: 12px;
  --transition: 250ms ease; --transition-fast: 150ms ease;
  --shadow-sm: 0 1px 3px rgba(12,65,78,.06);
  --shadow-md: 0 4px 16px rgba(12,65,78,.08);
  --shadow-lg: 0 8px 30px rgba(12,65,78,.1);
  --shadow-xl: 0 20px 60px rgba(12,65,78,.12);
}

@media (prefers-reduced-motion: reduce) {
  *,*::before,*::after { animation-duration:.01ms!important; transition-duration:.01ms!important; scroll-behavior:auto!important; }
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { font-size:100%; scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  font-family:var(--font-main); font-size:1.0625rem; line-height:1.7;
  color:var(--tcs-text); background:var(--tcs-cream-bg);
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; overflow-x:hidden;
}

/* Skip Nav */
.skip-nav {
  position:absolute; top:-100%; left:50%; transform:translateX(-50%);
  background:var(--tcs-teal-dark); color:var(--tcs-white);
  padding:.75rem 1.5rem; border-radius:0 0 var(--radius) var(--radius);
  z-index:10000; font-weight:700; text-decoration:none; font-size:.875rem;
  transition:top var(--transition-fast);
}
.skip-nav:focus { top:0; outline:3px solid var(--tcs-gold); outline-offset:2px; }

/* Focus */
:focus-visible { outline:3px solid var(--tcs-gold); outline-offset:3px; border-radius:2px; }
:focus:not(:focus-visible) { outline:none; }

/* Typography */
h1,h2,h3,h4,h5,h6 { font-family:var(--font-main); color:var(--tcs-teal-dark); line-height:1.2; font-weight:800; letter-spacing:-.02em; }
h1 { font-size:clamp(2.25rem,5vw,3.25rem); margin-bottom:var(--space-md); }
h2 { font-size:clamp(1.75rem,3.5vw,2.375rem); margin-bottom:var(--space-md); }
h3 { font-size:clamp(1.25rem,2.5vw,1.5rem); margin-bottom:var(--space-sm); }
h4 { font-size:.8125rem; font-weight:700; text-transform:uppercase; letter-spacing:.14em; color:var(--tcs-terra); margin-bottom:var(--space-sm); }
.step-label { display:block; font-size:.8125rem; font-weight:700; text-transform:uppercase; letter-spacing:.14em; color:var(--tcs-gold); margin-bottom:var(--space-sm); }
p { margin-bottom:var(--space-sm); max-width:70ch; }
.lead { font-size:1.1875rem; line-height:1.6; color:var(--tcs-text-light); font-weight:400; }
.eyebrow { font-size:.75rem; font-weight:800; text-transform:uppercase; letter-spacing:.18em; color:var(--tcs-terra); margin-bottom:var(--space-xs); display:block; }
blockquote { font-size:1.25rem; font-style:italic; color:var(--tcs-teal-dark); border-left:3px solid var(--tcs-gold); padding-left:var(--space-md); margin:var(--space-lg) 0; max-width:60ch; }
a { color:var(--tcs-teal); text-decoration-color:var(--tcs-gold); text-underline-offset:3px; transition:color var(--transition-fast); }
a:hover { color:var(--tcs-terra); text-decoration-color:var(--tcs-terra); }
img { max-width:100%; height:auto; display:block; }

/* Layout */
.container { width:100%; max-width:var(--max-width); margin:0 auto; padding:0 var(--space-md); }
.container--narrow { max-width:var(--max-width-narrow); }
.section { padding:var(--space-2xl) 0; }
.section--cream { background:var(--tcs-cream-bg); }
.section--white { background:var(--tcs-white); }
.section--alt { background:var(--tcs-cream-light); }
.section--teal { background:var(--tcs-teal-dark); color:var(--tcs-cream-light); }
.section--teal h2,.section--teal h3 { color:var(--tcs-cream-light); }
.section--teal .eyebrow { color:var(--tcs-gold-light); }
.section--teal p { color:rgba(245,239,233,.8); }
.section--teal a { color:var(--tcs-gold-light); }
.grid { display:grid; gap:var(--space-lg); }
.grid--2 { grid-template-columns:1fr; }
.grid--3 { grid-template-columns:1fr; }
@media(min-width:768px) { .grid--2{grid-template-columns:repeat(2,1fr);} .grid--3{grid-template-columns:repeat(2,1fr);} }
@media(min-width:1024px) { .grid--3{grid-template-columns:repeat(3,1fr);} }
.text-center { text-align:center; }

/* Buttons */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  font-family:var(--font-main); font-size:.875rem; font-weight:700;
  letter-spacing:.06em; text-transform:uppercase; text-decoration:none;
  padding:.875rem 2rem; border-radius:var(--radius); border:2px solid transparent;
  cursor:pointer; transition:all var(--transition); min-height:48px; white-space:nowrap;
}
.btn--primary { background:var(--tcs-terra); color:var(--tcs-white); border-color:var(--tcs-terra); }
.btn--primary:hover { background:var(--tcs-terra-dark); border-color:var(--tcs-terra-dark); color:var(--tcs-white); transform:translateY(-1px); box-shadow:var(--shadow-md); }
.btn--secondary { background:transparent; color:var(--tcs-teal-dark); border-color:var(--tcs-teal-dark); }
.btn--secondary:hover { background:var(--tcs-teal-dark); color:var(--tcs-white); transform:translateY(-1px); box-shadow:var(--shadow-md); }
.btn--ghost { background:transparent; color:var(--tcs-teal-dark); border-color:var(--tcs-teal-dark); }
.btn--ghost:hover { background:var(--tcs-teal-dark); color:var(--tcs-white); transform:translateY(-1px); box-shadow:var(--shadow-md); }
.btn--gold { background:var(--tcs-gold); color:var(--tcs-white); border-color:var(--tcs-gold); }
.btn--gold:hover { background:var(--tcs-gold-dark); border-color:var(--tcs-gold-dark); transform:translateY(-1px); box-shadow:var(--shadow-md); }
.btn--white { background:var(--tcs-white); color:var(--tcs-teal-dark); border-color:var(--tcs-white); }
.btn--white:hover { background:var(--tcs-cream-light); border-color:var(--tcs-cream-light); transform:translateY(-1px); }
.btn--ghost-white { background:transparent; color:var(--tcs-cream-light); border-color:rgba(245,239,233,.35); }
.btn--ghost-white:hover { background:rgba(245,239,233,.1); border-color:var(--tcs-cream-light); color:var(--tcs-cream-light); }

/* Cards */
.card { background:var(--tcs-white); border-radius:var(--radius-lg); padding:var(--space-lg); box-shadow:var(--shadow-sm); transition:box-shadow var(--transition),transform var(--transition); border:1px solid var(--tcs-border); }
.card:hover { box-shadow:var(--shadow-md); transform:translateY(-2px); }

/* Programs / feature grid (accessibility.html and similar pages) */
.programs-grid { display:grid; grid-template-columns:1fr; gap:var(--space-md); }
@media(min-width:600px) { .programs-grid{grid-template-columns:repeat(2,1fr);} }
@media(min-width:1024px) { .programs-grid{grid-template-columns:repeat(3,1fr);} }
.program-card { background:var(--tcs-white); border-radius:var(--radius-lg); padding:var(--space-md); border:1px solid var(--tcs-border); box-shadow:var(--shadow-sm); }
.program-card__icon { width:32px; height:32px; color:var(--tcs-teal); margin-bottom:.75rem; }
.program-card__icon svg { width:32px; height:32px; display:block; }
.program-card h3 { font-size:1rem; margin-bottom:.375rem; }
.program-card p { font-size:.9375rem; color:var(--tcs-text-light); margin-bottom:0; }

/* Header */
.site-header {
  position:fixed; top:0; left:0; right:0; height:var(--header-height);
  background:rgba(250,247,244,.97); backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px); z-index:1000; border-bottom:1px solid var(--tcs-border);
  transition:box-shadow var(--transition);
}
.site-header--scrolled { box-shadow:var(--shadow-md); }
.site-header__inner { max-width:var(--max-width); margin:0 auto; padding:0 var(--space-md); height:100%; display:flex; align-items:center; justify-content:space-between; }
.site-header__logo { display:flex; align-items:center; text-decoration:none; }
.site-header__logo img { height:44px; width:auto; }
.site-nav { display:none; }
.site-nav__list { list-style:none; display:flex; align-items:center; gap:.125rem; }
.site-nav__item { position:relative; }
.site-nav__link {
  display:flex; align-items:center; gap:.35rem; padding:.5rem .75rem;
  font-size:.8125rem; font-weight:600; color:var(--tcs-text);
  text-decoration:none; text-transform:uppercase; letter-spacing:.08em;
  border-radius:var(--radius); transition:color var(--transition-fast),background var(--transition-fast); white-space:nowrap;
}
button.site-nav__link { background:none; border:none; cursor:pointer; font-family:var(--font-main); }
button.mobile-nav__link { background:none; border:none; cursor:pointer; font-family:var(--font-main); width:100%; text-align:left; line-height:inherit; }
.site-nav__link:hover,.site-nav__link--active { color:var(--tcs-terra); background:rgba(157,68,42,.05); }
.site-nav__link svg { width:12px; height:12px; transition:transform var(--transition-fast); }
.site-nav__dropdown {
  position:absolute; top:calc(100% + .5rem); left:0; min-width:280px;
  background:var(--tcs-white); border:1px solid var(--tcs-border); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg); padding:.5rem; opacity:0; visibility:hidden;
  transform:translateY(-4px); transition:all var(--transition-fast); z-index:100;
}
.site-nav__item:hover .site-nav__dropdown,.site-nav__item:focus-within .site-nav__dropdown { opacity:1; visibility:visible; transform:translateY(0); }
.site-nav__item:hover .site-nav__link svg { transform:rotate(180deg); }
.site-nav__dropdown-link { display:block; padding:.75rem 1rem; font-size:.875rem; font-weight:600; color:var(--tcs-text); text-decoration:none; border-radius:var(--radius); transition:background var(--transition-fast); }
.site-nav__dropdown-link:hover { background:var(--tcs-cream-light); color:var(--tcs-teal-dark); }
.site-nav__dropdown-desc { display:block; font-size:.75rem; font-weight:400; color:var(--tcs-text-muted); margin-top:.125rem; text-transform:none; letter-spacing:0; }
.site-nav__cta { margin-left:.5rem; }
.site-nav__signin {
  font-size:.75rem; font-weight:700; color:var(--tcs-text-muted);
  letter-spacing:.08em; text-transform:uppercase; text-decoration:none;
  padding:.5rem .625rem; border-radius:var(--radius);
  transition:color var(--transition-fast); white-space:nowrap; margin-left:.25rem;
}
.site-nav__signin:hover { color:var(--tcs-terra); }

/* Mobile Nav */
.mobile-toggle {
  display:flex; align-items:center; justify-content:center; width:48px; height:48px;
  background:none; border:none; cursor:pointer; padding:0; position:relative; z-index:1001;
}
.mobile-toggle__bar {
  display:block; width:24px; height:2px; background:var(--tcs-teal-dark);
  border-radius:2px; transition:all var(--transition); position:absolute;
}
.mobile-toggle__bar:nth-child(1) { transform:translateY(-7px); }
.mobile-toggle__bar:nth-child(3) { transform:translateY(7px); }
.mobile-toggle[aria-expanded="true"] .mobile-toggle__bar:nth-child(1) { transform:rotate(45deg); }
.mobile-toggle[aria-expanded="true"] .mobile-toggle__bar:nth-child(2) { opacity:0; }
.mobile-toggle[aria-expanded="true"] .mobile-toggle__bar:nth-child(3) { transform:rotate(-45deg); }
.mobile-nav {
  display:none; position:fixed; top:0; left:0; right:0; bottom:0;
  background:var(--tcs-cream-bg); z-index:999;
  padding:calc(var(--header-height) + var(--space-lg)) var(--space-md) var(--space-lg); overflow-y:auto;
}
.mobile-nav--open { display:flex; flex-direction:column; }
.mobile-nav__list { list-style:none; }
.mobile-nav__link { display:block; padding:1rem 0; font-size:1.375rem; font-weight:700; color:var(--tcs-teal-dark); text-decoration:none; border-bottom:1px solid var(--tcs-border); }
.mobile-nav__link:hover { color:var(--tcs-terra); }
.mobile-nav__sub { list-style:none; padding-left:var(--space-md); }
.mobile-nav__sub-link { display:block; padding:.5rem 0; font-size:1rem; color:var(--tcs-text-light); text-decoration:none; }
.mobile-nav__sub-link:hover { color:var(--tcs-terra); }
.mobile-nav__cta { margin-top:auto; padding-top:var(--space-lg); display:flex; flex-direction:column; gap:var(--space-xs); }
@media(min-width:1024px) { .site-nav{display:flex;align-items:center;} .mobile-toggle{display:none;} }
main { padding-top:var(--header-height); }

/* Footer */
.site-footer { background:var(--tcs-teal-dark); color:rgba(245,239,233,.7); padding:var(--space-2xl) 0 var(--space-lg); }
.site-footer__grid { display:grid; grid-template-columns:1fr; gap:var(--space-lg); margin-bottom:var(--space-xl); }
@media(min-width:768px) { .site-footer__grid{grid-template-columns:2fr 1fr 1fr 1fr;} }
.site-footer__brand p { font-size:.9375rem; line-height:1.6; max-width:320px; color:rgba(245,239,233,.55); }
.site-footer__logo { height:44px; width:auto; margin-bottom:var(--space-sm); background:#fff; padding:6px 10px; border-radius:var(--radius-md); }
.site-footer__heading { font-size:.75rem; font-weight:800; text-transform:uppercase; letter-spacing:.14em; color:var(--tcs-gold-light); margin-bottom:var(--space-sm); }
.site-footer__links { list-style:none; }
.site-footer__links li { margin-bottom:.5rem; }
.site-footer__links a { color:rgba(245,239,233,.6); text-decoration:none; font-size:.9375rem; transition:color var(--transition-fast); }
.site-footer__links a:hover { color:var(--tcs-cream-light); }
.site-footer__social { display:flex; gap:.625rem; margin-top:var(--space-sm); flex-wrap:wrap; }
.site-footer__social a {
  display:flex; align-items:center; justify-content:center; width:40px; height:40px;
  border-radius:50%; background:rgba(245,239,233,.08); color:rgba(245,239,233,.6);
  text-decoration:none; transition:all var(--transition-fast);
}
.site-footer__social a:hover { background:rgba(245,239,233,.15); color:var(--tcs-cream-light); }
.site-footer__social svg { width:18px; height:18px; fill:currentColor; }
.site-footer__bottom {
  border-top:1px solid rgba(245,239,233,.1); padding-top:var(--space-md);
  display:flex; flex-direction:column; gap:var(--space-sm); align-items:center; text-align:center;
}
@media(min-width:768px) { .site-footer__bottom{flex-direction:row;justify-content:space-between;text-align:left;} }
.site-footer__copy { font-size:.8125rem; color:rgba(245,239,233,.35); }
.site-footer__legal { display:flex; gap:var(--space-md); list-style:none; flex-wrap:wrap; justify-content:center; }
.site-footer__legal a { font-size:.8125rem; color:rgba(245,239,233,.35); text-decoration:none; }
.site-footer__legal a:hover { color:rgba(245,239,233,.6); }

/* Decorative */
.gold-line { width:60px; height:2px; background:var(--tcs-gold); margin-bottom:var(--space-md); }
.gold-line--center { margin-left:auto; margin-right:auto; }
.img-rounded { border-radius:var(--radius-lg); }
.img-feature { border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); width:100%; height:400px; object-fit:cover; }

/* Pathway Cards */
.pathway-card {
  background:var(--tcs-white); border:1px solid var(--tcs-border); border-radius:var(--radius-lg);
  padding:var(--space-lg); text-align:center; text-decoration:none; display:flex;
  flex-direction:column; align-items:center; gap:var(--space-sm);
  transition:all var(--transition); position:relative; overflow:hidden;
}
.pathway-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,var(--tcs-terra),var(--tcs-gold)); transform:scaleX(0); transition:transform var(--transition); }
.pathway-card:hover::before { transform:scaleX(1); }
.pathway-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-4px); border-color:var(--tcs-cream); }
.pathway-card__emoji { font-size:2.5rem; line-height:1; }
.pathway-card__title { font-size:1.25rem; color:var(--tcs-teal-dark); font-weight:800; }
.pathway-card__desc { font-size:.9375rem; color:var(--tcs-text-light); line-height:1.55; }

/* Pricing */
.pricing-card { background:var(--tcs-white); border:2px solid var(--tcs-border); border-radius:var(--radius-lg); padding:var(--space-xl) var(--space-lg); text-align:center; }
.pricing-card--featured { border-color:var(--tcs-terra); box-shadow:var(--shadow-lg); position:relative; }
.pricing-card--featured::before {
  content:'Best Value'; position:absolute; top:-14px; left:50%; transform:translateX(-50%);
  background:var(--tcs-terra); color:var(--tcs-white); font-size:.6875rem; font-weight:800;
  text-transform:uppercase; letter-spacing:.1em; padding:.25rem 1rem; border-radius:100px;
}
.pricing-card__price { font-size:3rem; color:var(--tcs-teal-dark); line-height:1; margin-bottom:.25rem; font-weight:800; }
.pricing-card__period { font-size:.875rem; color:var(--tcs-text-muted); margin-bottom:var(--space-md); }

/* Feature list */
.feature-list { list-style:none; display:grid; gap:.625rem; }
.feature-list__item { display:flex; gap:.75rem; align-items:center; font-size:1rem; }
.feature-list__icon { flex-shrink:0; width:22px; height:22px; color:var(--tcs-gold); }

/* Value Items */
.value-item { display:flex; gap:var(--space-sm); align-items:flex-start; }
.value-item__marker { flex-shrink:0; width:32px; height:32px; border-radius:50%; background:var(--tcs-cream-light); display:flex; align-items:center; justify-content:center; margin-top:2px; }
.value-item__marker svg { width:16px; height:16px; color:var(--tcs-terra); }
.value-item h3 { font-size:1.0625rem; margin-bottom:.125rem; }
.value-item p { font-size:.9375rem; color:var(--tcs-text-light); margin-bottom:0; }

/* CTA Banner */
.cta-banner { background:linear-gradient(135deg,var(--tcs-teal-dark),var(--tcs-teal)); text-align:center; padding:var(--space-2xl) var(--space-md); position:relative; overflow:hidden; }
.cta-banner::before { content:''; position:absolute; top:-50%; right:-20%; width:600px; height:600px; border-radius:50%; background:rgba(188,128,77,.06); }
.cta-banner h2 { color:var(--tcs-cream-light); margin-bottom:var(--space-sm); }
.cta-banner p { color:rgba(245,239,233,.7); margin:0 auto var(--space-lg); max-width:560px; }
.cta-banner__actions { display:flex; flex-wrap:wrap; gap:var(--space-sm); justify-content:center; }

/* Page Header */
.page-header { background:linear-gradient(135deg,var(--tcs-teal-dark),var(--tcs-teal)); padding:var(--space-2xl) 0 var(--space-xl); text-align:center; position:relative; overflow:hidden; }
.page-header::before { content:''; position:absolute; top:-40%; right:-15%; width:500px; height:500px; border-radius:50%; background:rgba(188,128,77,.06); }
.page-header h1 { color:var(--tcs-cream-light); margin-bottom:var(--space-sm); }
.page-header p { color:rgba(245,239,233,.75); max-width:600px; margin:0 auto; }
.page-header .eyebrow { color:var(--tcs-gold-light); }

/* Two Column */
.two-col { display:grid; grid-template-columns:1fr; gap:var(--space-xl); align-items:center; }
@media(min-width:1024px) { .two-col{grid-template-columns:1fr 1fr;} }
.two-col--reverse { direction:ltr; }
@media(min-width:1024px) { .two-col--reverse{direction:rtl;} .two-col--reverse>*{direction:ltr;} }

/* Accordion */
.accordion { border-top:1px solid var(--tcs-border); }
.accordion__item { border-bottom:1px solid var(--tcs-border); }
.accordion__trigger { display:flex; align-items:center; justify-content:space-between; width:100%; padding:var(--space-md) 0; background:none; border:none; cursor:pointer; font-family:var(--font-main); font-size:1.0625rem; font-weight:700; color:var(--tcs-teal-dark); text-align:left; line-height:1.4; }
.accordion__trigger:hover { color:var(--tcs-terra); }
.accordion__icon { flex-shrink:0; width:20px; height:20px; margin-left:var(--space-sm); transition:transform var(--transition); color:var(--tcs-gold); }
.accordion__trigger[aria-expanded="true"] .accordion__icon { transform:rotate(180deg); }
.accordion__panel { overflow:hidden; max-height:0; transition:max-height .4s ease; }
.accordion__panel--open { max-height:600px; }
.accordion__content { padding-bottom:var(--space-md); color:var(--tcs-text-light); font-size:.9375rem; line-height:1.7; }

/* ============================================================
   FIND A PRO — Map Page
   ============================================================ */

/* Nav button */
.site-nav__findpro { margin-left:.5rem; }
.site-nav__findpro--active { background:var(--tcs-teal-dark); color:var(--tcs-white); border-color:var(--tcs-teal-dark); }

/* Hero layout */
.pro-hero { display:flex; flex-direction:column; gap:var(--space-lg); }
@media(min-width:768px) { .pro-hero{flex-direction:row; align-items:flex-start; justify-content:space-between; gap:var(--space-xl);} }
.pro-hero__text { flex:1; }
.pro-hero__cta { flex-shrink:0; display:flex; flex-direction:column; align-items:flex-start; gap:var(--space-xs); }
@media(min-width:768px) { .pro-hero__cta{align-items:flex-end; text-align:right;} }
.pro-hero__apply-btn { white-space:nowrap; }
.pro-hero__apply-note { font-size:1rem; font-weight:600; color:var(--tcs-cream-light); max-width:32ch; line-height:1.5; margin-bottom:0; }

/* Filter bar */
.pro-filter-bar { display:flex; align-items:center; flex-wrap:wrap; gap:.75rem var(--space-md); margin-bottom:var(--space-md); }
.pro-filter-label { display:flex; align-items:center; gap:.4rem; font-size:.875rem; font-weight:700; color:var(--tcs-teal-dark); white-space:nowrap; }
.pro-filter-label svg { width:16px; height:16px; color:var(--tcs-terra); flex-shrink:0; }
.pro-filter-select { font-family:var(--font-main); font-size:.9375rem; font-weight:600; padding:.625rem 1rem; border:2px solid var(--tcs-border); border-radius:var(--radius); background:var(--tcs-white); color:var(--tcs-text); cursor:pointer; min-width:220px; transition:border-color var(--transition-fast); }
.pro-filter-select:hover { border-color:var(--tcs-teal); }
.pro-filter-select:focus { border-color:var(--tcs-teal); outline:3px solid var(--tcs-gold); outline-offset:2px; }
.pro-filter-count { font-size:.8125rem; font-weight:600; color:var(--tcs-text-muted); margin-left:auto; }

/* Map */
#pro-map { height:520px; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--tcs-border); box-shadow:var(--shadow-md); }
@media(max-width:767px) { #pro-map{height:380px;} }

/* Custom marker */
.pro-marker { width:42px; height:42px; border-radius:50%; display:flex; align-items:center; justify-content:center; border:3px solid rgba(255,255,255,.9); box-shadow:0 2px 10px rgba(12,65,78,.35); cursor:pointer; transition:transform var(--transition-fast),box-shadow var(--transition-fast); }
.pro-marker:hover { transform:scale(1.12); box-shadow:0 4px 16px rgba(12,65,78,.45); }

/* Leaflet popup overrides */
.pro-leaflet-popup .leaflet-popup-content-wrapper { border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); padding:0; overflow:hidden; border:1px solid var(--tcs-border); }
.pro-leaflet-popup .leaflet-popup-content { margin:0; padding:0; }
.pro-leaflet-popup .leaflet-popup-tip-container { margin-top:-1px; }

/* Popup card */
.pro-popup { padding:var(--space-sm); min-width:210px; max-width:280px; }
.pro-popup__badge { display:inline-block; font-size:.6875rem; font-weight:800; text-transform:uppercase; letter-spacing:.12em; color:white; padding:.2rem .6rem; border-radius:20px; margin-bottom:.625rem; }
.pro-popup__name { font-size:1rem; font-weight:800; color:var(--tcs-teal-dark); line-height:1.25; margin-bottom:.2rem; }
.pro-popup__specialty { font-size:.8125rem; color:var(--tcs-text-light); margin-bottom:.625rem; }
.pro-popup__details { display:flex; flex-direction:column; gap:.3rem; font-size:.8125rem; }
.pro-popup__location { display:flex; align-items:center; gap:.3rem; color:var(--tcs-text-muted); margin-bottom:.1rem; }
.pro-popup__location svg { flex-shrink:0; }
.pro-popup__details a { color:var(--tcs-teal); font-weight:600; word-break:break-all; }
.pro-popup__details a:hover { color:var(--tcs-terra); }

/* Legend */
.pro-legend { margin-top:var(--space-md); padding:var(--space-sm) var(--space-md); background:var(--tcs-white); border:1px solid var(--tcs-border); border-radius:var(--radius-lg); }
.pro-legend__title { font-size:.75rem; font-weight:800; text-transform:uppercase; letter-spacing:.14em; color:var(--tcs-text-muted); margin-bottom:.625rem; }
.pro-legend__items { display:flex; flex-wrap:wrap; gap:.5rem var(--space-lg); }
.pro-legend__item { display:flex; align-items:center; gap:.5rem; font-size:.8125rem; font-weight:600; color:var(--tcs-text); }
.pro-legend__icon { width:28px; height:28px; border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.pro-legend__icon svg { width:14px; height:14px; }

/* Referral modal */
.pro-modal { position:fixed; inset:0; z-index:9000; display:flex; align-items:center; justify-content:center; padding:var(--space-md); }
.pro-modal[hidden] { display:none; }
.pro-modal__overlay { position:absolute; inset:0; background:rgba(12,65,78,.65); cursor:pointer; }
.pro-modal__content { position:relative; background:var(--tcs-white); border-radius:var(--radius-lg); padding:var(--space-xl); max-width:520px; width:100%; box-shadow:var(--shadow-xl); max-height:90vh; overflow-y:auto; }
.pro-modal__content--wide { max-width:680px; padding:var(--space-md); }
.pro-modal__iframe { width:100%; min-height:580px; border:none; border-radius:var(--radius); display:block; margin-top:var(--space-sm); }
.pro-modal__iframe-fallback { font-size:.8125rem; color:var(--tcs-text-muted); text-align:center; margin-top:.75rem; }
.pro-modal__iframe-fallback a { color:var(--tcs-teal); font-weight:600; }
.pro-modal__close { position:absolute; top:var(--space-sm); right:var(--space-sm); background:none; border:none; cursor:pointer; padding:.5rem; border-radius:var(--radius); color:var(--tcs-text-muted); display:flex; align-items:center; justify-content:center; transition:color var(--transition-fast),background var(--transition-fast); }
.pro-modal__close:hover { color:var(--tcs-teal-dark); background:var(--tcs-cream-bg); }

/* Client request callout — below map legend */
.pro-request-callout { display:flex; align-items:center; justify-content:space-between; gap:var(--space-md); margin-top:var(--space-md); padding:var(--space-md) var(--space-lg); background:var(--tcs-cream-bg); border:1.5px solid var(--tcs-border); border-left:4px solid var(--tcs-teal-light); border-radius:var(--radius-lg); flex-wrap:wrap; }
.pro-request-callout__content { display:flex; align-items:flex-start; gap:var(--space-sm); flex:1; min-width:240px; }
.pro-request-callout__icon { width:44px; height:44px; border-radius:50%; background:var(--tcs-teal-light); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.pro-request-callout__title { font-size:1rem; font-weight:800; color:var(--tcs-teal-dark); margin-bottom:.2rem; line-height:1.3; }
.pro-request-callout__desc { font-size:.875rem; color:var(--tcs-text-light); margin-bottom:0; max-width:52ch; }
.pro-request-callout__btn { flex-shrink:0; }
@media(max-width:600px) { .pro-request-callout { flex-direction:column; align-items:flex-start; } .pro-request-callout__btn { width:100%; } }

/* Chooser modal — "Which best describes you?" */
.pro-chooser__title { font-size:1.375rem; font-weight:800; color:var(--tcs-teal-dark); margin-bottom:.375rem; letter-spacing:-.02em; }
.pro-chooser__sub { font-size:.9375rem; color:var(--tcs-text-light); margin-bottom:var(--space-md); }
.pro-chooser__cards { display:grid; grid-template-columns:1fr 1fr; gap:var(--space-sm); }
@media(max-width:560px) { .pro-chooser__cards{grid-template-columns:1fr;} }
.pro-chooser__card { border:2px solid var(--tcs-border); border-radius:var(--radius-lg); padding:var(--space-md); display:flex; flex-direction:column; gap:.5rem; background:var(--tcs-cream-bg); transition:border-color var(--transition),box-shadow var(--transition); }
.pro-chooser__card:not(.pro-chooser__card--disabled):hover { border-color:var(--tcs-teal-light); box-shadow:var(--shadow-md); }
.pro-chooser__card--disabled { opacity:.6; }
.pro-chooser__card-icon { width:44px; height:44px; border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.pro-chooser__card-title { font-size:.9375rem; font-weight:800; color:var(--tcs-teal-dark); margin-bottom:0; line-height:1.3; }
.pro-chooser__card-types { font-size:.75rem; color:var(--tcs-text-muted); line-height:1.6; flex:1; margin-bottom:0; }
.pro-chooser__card-btn { display:inline-flex; align-items:center; justify-content:center; gap:.4rem; font-family:var(--font-main); font-size:.75rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase; text-decoration:none; padding:.625rem 1rem; border-radius:var(--radius); border:2px solid transparent; cursor:pointer; transition:all var(--transition-fast); white-space:nowrap; margin-top:auto; }
.pro-chooser__card-btn--terra { background:var(--tcs-terra); color:var(--tcs-white); border-color:var(--tcs-terra); }
.pro-chooser__card-btn--terra:hover { background:var(--tcs-terra-dark); border-color:var(--tcs-terra-dark); color:var(--tcs-white); }
.pro-chooser__card-btn--muted { background:var(--tcs-cream-light); color:var(--tcs-text-muted); border-color:var(--tcs-border); cursor:not-allowed; pointer-events:none; }
.pro-chooser__soon { font-size:.6875rem; font-weight:800; text-transform:uppercase; letter-spacing:.14em; color:var(--tcs-gold); margin-bottom:0; }

/* Utilities */
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border-width:0; }
@media(max-width:767px) { .section{padding:var(--space-xl) 0;} .hide-mobile{display:none;} }
@media(min-width:768px) { .hide-desktop{display:none;} }
@media print { .site-header,.site-footer,.mobile-toggle,.mobile-nav{display:none;} main{padding-top:0;} }
