/* ─────────────────────────────────────────
   SHANNONDALE SHORTLIST — Global Stylesheet
   ───────────────────────────────────────── */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500&display=swap');

:root {
  --forest:       #2C4A3E;
  --forest-light: #3d6b5c;
  --cream:        #F7F3EC;
  --warm-white:   #FDFAF5;
  --gold:         #C4973A;
  --gold-light:   #e8b84b;
  --charcoal:     #2A2A2A;
  --slate:        #5C6B74;
  --sage:         #7A9E8E;
  --rust:         #A0522D;
  --border:       #E2D9CC;
  --shadow:       rgba(44,74,62,0.08);
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }

body {
  font-family:'DM Sans', sans-serif;
  background:var(--warm-white);
  color:var(--charcoal);
  font-size:16px;
  line-height:1.6;
}

/* ── NAV ── */
nav {
  background:var(--forest);
  padding:0 2rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:68px;
  position:sticky;
  top:0;
  z-index:100;
  box-shadow:0 2px 20px rgba(0,0,0,0.15);
}
.nav-logo {
  display:flex;
  align-items:center;
  gap:0.75rem;
  text-decoration:none;
}
.nav-logo-mark {
  width:36px; height:36px;
  background:var(--gold);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-family:'Playfair Display',serif;
  font-size:1rem; color:var(--forest); font-weight:700;
  flex-shrink:0;
}
.nav-logo-text { display:flex; flex-direction:column; line-height:1.1; }
.nav-logo-name {
  font-family:'Playfair Display',serif;
  font-size:1.05rem; color:var(--cream); font-weight:600; letter-spacing:0.01em;
}
.nav-logo-tagline {
  font-size:0.65rem; color:var(--sage);
  letter-spacing:0.08em; text-transform:uppercase; font-weight:400;
}
.nav-links { display:flex; align-items:center; gap:2rem; list-style:none; }
.nav-links a {
  color:rgba(247,243,236,0.8);
  text-decoration:none; font-size:0.875rem; font-weight:400;
  letter-spacing:0.02em; transition:color 0.2s;
}
.nav-links a:hover { color:var(--gold); }
.nav-links a.active { color:var(--gold); }
.nav-cta {
  background:var(--gold) !important;
  color:var(--forest) !important;
  padding:0.5rem 1.25rem;
  border-radius:4px;
  font-weight:500 !important;
  transition:background 0.2s !important;
}
.nav-cta:hover { background:var(--gold-light) !important; }
.nav-hamburger {
  display:none;
  flex-direction:column;
  gap:5px;
  cursor:pointer;
  padding:4px;
}
.nav-hamburger span {
  display:block; width:24px; height:2px;
  background:var(--cream); border-radius:2px;
  transition:all 0.3s;
}

/* ── BUTTONS ── */
.btn-primary {
  background:var(--gold); color:var(--forest);
  padding:0.875rem 2rem; border-radius:5px;
  font-weight:500; font-size:0.95rem;
  text-decoration:none; transition:all 0.2s;
  border:none; cursor:pointer;
  display:inline-flex; align-items:center; gap:0.5rem;
  font-family:'DM Sans',sans-serif;
}
.btn-primary:hover {
  background:var(--gold-light);
  transform:translateY(-1px);
  box-shadow:0 6px 20px rgba(196,151,58,0.3);
}
.btn-secondary {
  background:transparent; color:var(--cream);
  padding:0.875rem 2rem; border-radius:5px;
  font-weight:400; font-size:0.95rem;
  text-decoration:none; transition:all 0.2s;
  border:1px solid rgba(247,243,236,0.3);
  display:inline-flex; align-items:center; gap:0.5rem;
}
.btn-secondary:hover {
  border-color:rgba(247,243,236,0.6);
  background:rgba(247,243,236,0.05);
}
.btn-forest {
  background:var(--forest); color:var(--cream);
  padding:0.875rem 2rem; border-radius:5px;
  font-weight:500; font-size:0.95rem;
  text-decoration:none; transition:all 0.2s;
  border:none; cursor:pointer;
  display:inline-flex; align-items:center; gap:0.5rem;
  font-family:'DM Sans',sans-serif;
}
.btn-forest:hover { background:var(--forest-light); transform:translateY(-1px); }

/* ── PAGE HERO (inner pages) ── */
.page-hero {
  background:var(--forest);
  padding:4rem 2rem 3.5rem;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.page-hero::before {
  content:'';
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse at 20% 50%, rgba(196,151,58,0.08) 0%, transparent 60%),
    radial-gradient(ellipse at 80% 20%, rgba(122,158,142,0.1) 0%, transparent 50%);
}
.page-hero-eyebrow {
  display:inline-flex; align-items:center; gap:0.5rem;
  background:rgba(196,151,58,0.15);
  border:1px solid rgba(196,151,58,0.3);
  color:var(--gold);
  padding:0.35rem 1rem; border-radius:100px;
  font-size:0.75rem; letter-spacing:0.1em;
  text-transform:uppercase; font-weight:500;
  margin-bottom:1.25rem; position:relative;
}
.page-hero h1 {
  font-family:'Playfair Display',serif;
  font-size:clamp(2rem,5vw,3.25rem);
  color:var(--cream); line-height:1.2;
  font-weight:700; position:relative;
  margin-bottom:1rem;
}
.page-hero h1 em { font-style:italic; color:var(--gold); }
.page-hero p {
  font-size:1.05rem; color:rgba(247,243,236,0.7);
  max-width:520px; margin:0 auto;
  font-weight:300; line-height:1.75;
  position:relative;
}

/* ── SECTION SHARED ── */
.section-label {
  font-size:0.7rem; letter-spacing:0.15em;
  text-transform:uppercase; color:var(--gold);
  font-weight:500; margin-bottom:0.75rem;
}
.section-title {
  font-family:'Playfair Display',serif;
  font-size:clamp(1.75rem,4vw,2.5rem);
  color:var(--forest); line-height:1.25;
  font-weight:700; margin-bottom:1rem;
}
.section-sub {
  font-size:1rem; color:var(--slate);
  max-width:560px; line-height:1.75; font-weight:300;
}

/* ── TRUST BAR ── */
.trust-bar {
  background:var(--cream);
  border-bottom:1px solid var(--border);
  padding:1rem 2rem;
  display:flex; justify-content:center;
  gap:2.5rem; flex-wrap:wrap;
}
.trust-item {
  display:flex; align-items:center; gap:0.5rem;
  font-size:0.8rem; color:var(--slate); font-weight:400;
}

/* ── BADGES ── */
.badge {
  display:inline-flex; align-items:center; gap:0.3rem;
  padding:0.25rem 0.65rem; border-radius:100px;
  font-size:0.7rem; font-weight:500;
  letter-spacing:0.02em; white-space:nowrap;
}
.badge-verified   { background:rgba(44,74,62,0.08);   color:var(--forest);  border:1px solid rgba(44,74,62,0.2); }
.badge-insured    { background:rgba(44,74,62,0.08);   color:var(--forest);  border:1px solid rgba(44,74,62,0.2); }
.badge-community  { background:rgba(196,151,58,0.1);  color:#8B6914;        border:1px solid rgba(196,151,58,0.3); }
.badge-local      { background:rgba(122,158,142,0.12);color:#3d6b5c;        border:1px solid rgba(122,158,142,0.3); }
.badge-responsive { background:rgba(100,149,180,0.1); color:#2c5f7a;        border:1px solid rgba(100,149,180,0.25); }
.badge-emergency  { background:rgba(160,82,45,0.08);  color:var(--rust);    border:1px solid rgba(160,82,45,0.2); }
.badge-founders   {
  background:linear-gradient(135deg,rgba(196,151,58,0.18),rgba(160,82,45,0.12));
  color:#7a4a10; border:1px solid rgba(196,151,58,0.5); font-weight:600;
}

/* ── PROVIDER CARDS ── */
.card {
  background:white; border-radius:10px;
  border:1px solid var(--border); overflow:hidden;
  transition:all 0.25s; position:relative;
}
.card:hover {
  transform:translateY(-3px);
  box-shadow:0 12px 40px var(--shadow);
  border-color:rgba(44,74,62,0.2);
}
.card-tier-bar          { height:4px; background:var(--forest); }
.card-tier-bar.community{ background:linear-gradient(90deg,var(--gold),var(--rust)); }
.card-tier-bar.founders { background:linear-gradient(90deg,#8B5E10,var(--gold),#C4973A); }

.card.founders-pick {
  border-color:rgba(196,151,58,0.4);
  box-shadow:0 0 0 1px rgba(196,151,58,0.15), 0 4px 24px rgba(196,151,58,0.08);
}
.card.founders-pick:hover {
  box-shadow:0 0 0 1px rgba(196,151,58,0.3), 0 12px 40px rgba(196,151,58,0.15);
  border-color:rgba(196,151,58,0.5);
}
.card.founders-pick .card-contact {
  background:linear-gradient(135deg,#8B5E10,var(--gold)); color:white;
}
.card.founders-pick .card-contact:hover {
  background:linear-gradient(135deg,var(--gold),var(--gold-light));
}
.card.community-trusted .card-contact {
  background:linear-gradient(135deg,var(--gold),#b8882e); color:white;
}
.card.community-trusted .card-contact:hover {
  background:linear-gradient(135deg,var(--gold-light),var(--gold));
}

.card-body   { padding:1.5rem; }
.card-top    { display:flex; gap:1rem; margin-bottom:1rem; }
.card-avatar {
  width:56px; height:56px; border-radius:50%;
  background:var(--forest);
  display:flex; align-items:center; justify-content:center;
  font-family:'Playfair Display',serif;
  font-size:1.25rem; color:var(--cream); font-weight:700;
  flex-shrink:0; border:2px solid var(--border);
}
.card-info   { flex:1; min-width:0; }
.card-name   {
  font-family:'Playfair Display',serif;
  font-size:1.1rem; font-weight:600;
  color:var(--charcoal); margin-bottom:0.15rem; line-height:1.2;
}
.card-business { font-size:0.8rem; color:var(--slate); margin-bottom:0.5rem; }
.card-category {
  display:inline-block;
  background:var(--cream); color:var(--forest);
  padding:0.2rem 0.6rem; border-radius:4px;
  font-size:0.72rem; font-weight:500;
  border:1px solid var(--border);
}
.card-bio {
  font-size:0.875rem; color:var(--slate);
  line-height:1.65; margin-bottom:1rem; font-weight:300;
}
.card-badges { display:flex; flex-wrap:wrap; gap:0.4rem; margin-bottom:1.25rem; }
.card-footer {
  display:flex; justify-content:space-between; align-items:center;
  padding-top:1rem; border-top:1px solid var(--border); gap:0.75rem;
}
.card-area {
  font-size:0.75rem; color:var(--slate);
  display:flex; align-items:center; gap:0.3rem;
}
.card-contact {
  background:var(--forest); color:var(--cream);
  padding:0.5rem 1.1rem; border-radius:5px;
  font-size:0.8rem; font-weight:500;
  text-decoration:none; transition:all 0.2s;
  white-space:nowrap; border:none; cursor:pointer;
  font-family:'DM Sans',sans-serif;
}
.card-contact:hover { background:var(--forest-light); }
.card-member {
  font-size:0.7rem; color:rgba(92,107,116,0.6);
  margin-top:0.5rem; text-align:right;
}

/* Founder quote block on card */
.founders-quote {
  background:linear-gradient(135deg,rgba(196,151,58,0.06),rgba(160,82,45,0.04));
  border:1px solid rgba(196,151,58,0.25);
  border-left:3px solid var(--gold);
  border-radius:0 6px 6px 0;
  padding:0.75rem 1rem; margin-bottom:1rem;
}
.founders-quote-label {
  font-size:0.68rem; color:#8B6914; font-weight:600;
  letter-spacing:0.06em; text-transform:uppercase; margin-bottom:0.35rem;
}
.founders-quote-text {
  font-size:0.82rem; color:#6b4f10;
  font-style:italic; line-height:1.6;
}
.founders-quote-sig {
  font-size:0.72rem; color:rgba(107,79,16,0.65);
  margin-top:0.35rem; font-weight:500;
}

/* Vouch block on card */
.vouch-block {
  background:rgba(196,151,58,0.07);
  border:1px solid rgba(196,151,58,0.2);
  border-radius:6px; padding:0.6rem 0.75rem; margin-bottom:1rem;
}
.vouch-count { font-size:0.72rem; color:#8B6914; font-weight:500; margin-bottom:0.25rem; }
.vouch-quote { font-size:0.72rem; color:rgba(139,105,20,0.7); font-style:italic; }

/* ── DIRECTORY GRID ── */
.directory-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(320px,1fr));
  gap:1.5rem;
}

/* ── HOW IT WORKS ── */
.how-section { background:var(--forest); padding:5rem 2rem; }
.how-inner { max-width:1000px; margin:0 auto; }
.how-section .section-label { color:var(--sage); }
.how-section .section-title { color:var(--cream); }
.how-section .section-sub   { color:rgba(247,243,236,0.6); }
.how-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:2rem; margin-top:3rem;
}
.how-num {
  font-family:'Playfair Display',serif;
  font-size:3rem; color:rgba(196,151,58,0.2);
  font-weight:700; line-height:1; margin-bottom:0.75rem;
}
.how-title {
  font-family:'Playfair Display',serif;
  font-size:1.1rem; color:var(--cream);
  font-weight:600; margin-bottom:0.5rem;
}
.how-desc { font-size:0.875rem; color:rgba(247,243,236,0.55); line-height:1.7; font-weight:300; }

/* ── TIERS ── */
.tiers-section { padding:5rem 2rem; background:var(--cream); }
.tiers-inner   { max-width:1000px; margin:0 auto; }
.tiers-grid    {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:1.5rem; margin-top:3rem;
}
.tier-card {
  background:white; border-radius:10px;
  padding:2rem; border:1.5px solid var(--border);
  position:relative; overflow:hidden;
}
.tier-card::before {
  content:''; position:absolute;
  top:0; left:0; right:0; height:4px;
}
.tier-card.verified::before  { background:var(--forest); }
.tier-card.community::before { background:linear-gradient(90deg,var(--gold),var(--rust)); }
.tier-card.founders-tier     { border-color:rgba(196,151,58,0.35); }
.tier-card.founders-tier::before { background:linear-gradient(90deg,#8B5E10,var(--gold),#C4973A); }
.tier-icon {
  width:44px; height:44px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:1.25rem; margin-bottom:1.25rem;
}
.tier-icon.v { background:rgba(44,74,62,0.1); }
.tier-icon.c { background:rgba(196,151,58,0.12); }
.tier-icon.f { background:linear-gradient(135deg,rgba(196,151,58,0.15),rgba(160,82,45,0.1)); }
.tier-title {
  font-family:'Playfair Display',serif;
  font-size:1.25rem; font-weight:600;
  color:var(--charcoal); margin-bottom:0.5rem;
}
.tier-desc  { font-size:0.875rem; color:var(--slate); line-height:1.7; margin-bottom:1.25rem; font-weight:300; }
.tier-list  { list-style:none; display:flex; flex-direction:column; gap:0.5rem; }
.tier-list li {
  font-size:0.8rem; color:var(--slate);
  display:flex; align-items:flex-start; gap:0.5rem; line-height:1.5;
}
.tier-list li::before { content:'✓'; color:var(--forest); font-weight:600; flex-shrink:0; margin-top:0.05rem; }
.tier-card.community .tier-list li::before { color:var(--gold); }
.tier-card.founders-tier .tier-list li::before { color:#8B5E10; }

/* ── DISCLAIMER ── */
.disclaimer-section { background:var(--cream); border-top:1px solid var(--border); padding:2rem; }
.disclaimer-inner   { max-width:900px; margin:0 auto; text-align:center; }
.disclaimer-text    { font-size:0.78rem; color:rgba(92,107,116,0.7); line-height:1.8; font-style:italic; }

/* ── FOOTER ── */
footer { background:var(--charcoal); color:rgba(247,243,236,0.6); padding:3rem 2rem 2rem; }
.footer-inner { max-width:1100px; margin:0 auto; }
.footer-top {
  display:flex; justify-content:space-between;
  align-items:flex-start; gap:3rem; flex-wrap:wrap;
  margin-bottom:2.5rem; padding-bottom:2.5rem;
  border-bottom:1px solid rgba(247,243,236,0.1);
}
.footer-logo-name {
  font-family:'Playfair Display',serif;
  font-size:1.25rem; color:var(--cream); font-weight:600; margin-bottom:0.5rem;
}
.footer-tagline { font-size:0.8rem; color:rgba(247,243,236,0.4); font-style:italic; }
.footer-links   { display:flex; gap:4rem; flex-wrap:wrap; }
.footer-col h4  {
  font-size:0.7rem; letter-spacing:0.1em;
  text-transform:uppercase; color:rgba(247,243,236,0.4);
  margin-bottom:1rem; font-weight:500;
}
.footer-col ul  { list-style:none; display:flex; flex-direction:column; gap:0.6rem; }
.footer-col a   { color:rgba(247,243,236,0.55); text-decoration:none; font-size:0.875rem; transition:color 0.2s; }
.footer-col a:hover { color:var(--gold); }
.footer-bottom  {
  display:flex; justify-content:space-between;
  align-items:center; flex-wrap:wrap; gap:1rem;
  font-size:0.75rem; color:rgba(247,243,236,0.3);
}

/* ── FORMS ── */
.form-group { margin-bottom:1.5rem; }
.form-label {
  display:block; font-size:0.85rem; font-weight:500;
  color:var(--charcoal); margin-bottom:0.5rem;
}
.form-label span { color:var(--rust); margin-left:2px; }
.form-input, .form-select, .form-textarea {
  width:100%; padding:0.875rem 1.25rem;
  border:1.5px solid var(--border); border-radius:6px;
  font-family:'DM Sans',sans-serif; font-size:0.95rem;
  color:var(--charcoal); background:white; outline:none;
  transition:border-color 0.2s;
}
.form-input:focus, .form-select:focus, .form-textarea:focus { border-color:var(--forest); }
.form-textarea { resize:vertical; min-height:120px; line-height:1.6; }
.form-select {
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%235C6B74' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 1rem center;
  padding-right:2.5rem; cursor:pointer;
}
.form-hint { font-size:0.78rem; color:var(--slate); margin-top:0.4rem; line-height:1.5; }
.form-row  { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
@media(max-width:600px){ .form-row { grid-template-columns:1fr; } }
.form-section-title {
  font-family:'Playfair Display',serif;
  font-size:1.15rem; color:var(--forest);
  font-weight:600; margin-bottom:1.5rem;
  padding-bottom:0.75rem; border-bottom:1px solid var(--border);
}

/* ── SEARCH ── */
.search-section { background:var(--cream); border-bottom:1px solid var(--border); padding:2.5rem 2rem; }
.search-inner   { max-width:900px; margin:0 auto; }
.search-label   {
  font-size:0.75rem; letter-spacing:0.1em;
  text-transform:uppercase; color:var(--slate);
  font-weight:500; margin-bottom:1rem; display:block;
}
.search-row     { display:flex; gap:0.75rem; flex-wrap:wrap; }
.search-input   {
  flex:1; min-width:200px; padding:0.875rem 1.25rem;
  border:1.5px solid var(--border); border-radius:6px;
  font-family:'DM Sans',sans-serif; font-size:0.95rem;
  color:var(--charcoal); background:white; outline:none;
  transition:border-color 0.2s;
}
.search-input:focus { border-color:var(--forest); }
.search-select  {
  padding:0.875rem 1.25rem; border:1.5px solid var(--border);
  border-radius:6px; font-family:'DM Sans',sans-serif;
  font-size:0.95rem; color:var(--charcoal); background:white;
  outline:none; cursor:pointer; min-width:180px;
  transition:border-color 0.2s; appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%235C6B74' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 1rem center; padding-right:2.5rem;
}
.search-select:focus { border-color:var(--forest); }
.search-btn {
  background:var(--forest); color:var(--cream);
  padding:0.875rem 1.75rem; border-radius:6px; border:none;
  font-family:'DM Sans',sans-serif; font-size:0.95rem;
  font-weight:500; cursor:pointer; transition:all 0.2s; white-space:nowrap;
}
.search-btn:hover { background:var(--forest-light); }
.category-pills {
  display:flex; gap:0.5rem; margin-top:1rem;
  flex-wrap:wrap;
}
.pill {
  padding:0.375rem 0.875rem; border-radius:100px;
  font-size:0.8rem; border:1px solid var(--border);
  background:white; color:var(--slate);
  cursor:pointer; transition:all 0.2s; white-space:nowrap;
  font-family:'DM Sans',sans-serif;
}
.pill:hover, .pill.active { background:var(--forest); color:var(--cream); border-color:var(--forest); }

/* ── ANIMATIONS ── */
@keyframes fadeUp {
  from { opacity:0; transform:translateY(20px); }
  to   { opacity:1; transform:translateY(0); }
}
.fade-up-1 { animation:fadeUp 0.6s 0.0s ease both; }
.fade-up-2 { animation:fadeUp 0.6s 0.1s ease both; }
.fade-up-3 { animation:fadeUp 0.6s 0.2s ease both; }
.fade-up-4 { animation:fadeUp 0.6s 0.3s ease both; }
.fade-up-5 { animation:fadeUp 0.6s 0.4s ease both; }

/* ── MOBILE ── */
@media(max-width:768px){
  .nav-links    { display:none; }
  .nav-hamburger{ display:flex; }
  .nav-mobile-open .nav-links {
    display:flex; flex-direction:column;
    position:absolute; top:68px; left:0; right:0;
    background:var(--forest); padding:1.5rem 2rem; gap:1.25rem;
    box-shadow:0 8px 24px rgba(0,0,0,0.2);
  }
  .directory-grid { grid-template-columns:1fr; }
  .footer-links   { gap:2rem; }
  .page-hero      { padding:3rem 1.5rem 2.5rem; }
}
