:root {
  --green-900: #102a1e;
  --green-800: #1B4332;
  --green-700: #245138;
  --green-600: #2D6A4F;
  --green-500: #40916C;
  --green-100: #E3EDE7;
  --green-50: #EEF3EF;
  --cream: #F7F5EF;
  --gold: #B5651D;
  --accent: #B5651D;
  --ink: #14271d;
  --muted: #5b6b63;
  --line: #e6e2d8;
  --white: #ffffff;
  --shadow-sm: 0 1px 3px rgba(27, 67, 50, 0.08);
  --shadow-md: 0 10px 30px rgba(27, 67, 50, 0.10);
  --shadow-lg: 0 24px 60px rgba(27, 67, 50, 0.16);
  --radius: 16px;
  --maxw: 1140px;
  --font: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  --font-head: 'Sora', var(--font);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; overflow-x: hidden; }
img { max-width: 100%; }

body {
  font-family: var(--font);
  color: var(--ink);
  background: var(--cream);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--green-700); text-decoration: none; }
a:hover { color: var(--green-600); }

.container { max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }

h1, h2, h3 { font-family: var(--font-head); line-height: 1.15; letter-spacing: -0.02em; color: var(--ink); }

/* ---------- Icons ---------- */
.ico-svg {
  width: 26px; height: 26px; display: block;
  fill: none; stroke: currentColor; stroke-width: 2;
  stroke-linecap: round; stroke-linejoin: round;
}
h1 { font-size: clamp(2.2rem, 5vw, 3.6rem); font-weight: 800; }
h2 { font-size: clamp(1.6rem, 3.2vw, 2.4rem); font-weight: 700; }
h3 { font-size: 1.25rem; font-weight: 700; }
p { color: var(--muted); }
.eyebrow {
  text-transform: uppercase; letter-spacing: 0.14em; font-size: 0.8rem;
  font-weight: 700; color: var(--green-600); margin-bottom: 14px;
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-weight: 600; font-size: 1rem; padding: 14px 26px;
  border-radius: 999px; border: 1.5px solid transparent; cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.btn-primary { background: var(--green-600); color: #fff; box-shadow: var(--shadow-md); }
.btn-primary:hover { background: var(--green-700); color:#fff; transform: translateY(-2px); box-shadow: var(--shadow-lg); }
.btn-ghost { background: #fff; color: var(--green-800); border-color: var(--line); }
.btn-ghost:hover { border-color: var(--green-500); color: var(--green-700); }
.btn-light { background: rgba(255,255,255,.15); color:#fff; border-color: rgba(255,255,255,.4); }
.btn-light:hover { background: rgba(255,255,255,.28); color:#fff; }
.btn-block { width: 100%; justify-content: center; }

/* ---------- Header ---------- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(247,245,239,.88); backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
}
.nav { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; height: 72px; }
.nav .brand { justify-self: start; }
.nav .nav-links { justify-self: center; }
.nav .nav-cta { justify-self: end; }
.brand { display:flex; align-items:center; gap:11px; font-family: 'Saira Condensed', var(--font-head); font-weight: 700; font-size: 1.5rem; text-transform: uppercase; color: var(--ink); letter-spacing: 0.04em; white-space: nowrap; }
.brand .logo-mark { height: 40px; width: auto; display:block; }
.brand .accent { color: var(--green-600); }
.nav-links { display:flex; align-items:center; gap: 28px; list-style:none; }
.nav-links a { color: var(--ink); font-weight: 500; font-size: .96rem; }
.nav-links a.active, .nav-links a:hover { color: var(--green-700); }
.nav-cta { display:flex; align-items:center; gap: 12px; }
.menu-toggle { display:none; background:none; border:none; font-size:1.6rem; cursor:pointer; color: var(--ink); }

/* ---------- Hero ---------- */
.hero {
  position: relative; overflow: hidden;
  background:
    radial-gradient(1200px 500px at 85% -10%, var(--green-100), transparent 60%),
    linear-gradient(180deg, var(--green-50), var(--cream) 70%);
  padding: 88px 0 72px;
}
.hero-grid { display:grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items:center; }
.hero p.lead { font-size: 1.18rem; max-width: 44ch; margin: 18px 0 28px; }
.hero-actions { display:flex; gap: 14px; flex-wrap: wrap; }
.hero-trust { margin-top: 28px; display:flex; gap: 22px; flex-wrap:wrap; color: var(--muted); font-size:.92rem; }
.hero-trust strong { color: var(--ink); }
.hero-card {
  background:#fff; border:1px solid var(--line); border-radius: 22px; padding: 28px;
  box-shadow: var(--shadow-lg);
}
.hero-card .price { font-size: 3rem; font-weight: 800; color: var(--green-700); letter-spacing:-.03em; }
.hero-card .price small { font-size: 1rem; color: var(--muted); font-weight:600; }
.hero-card ul { list-style:none; margin: 18px 0 22px; }
.hero-card li { display:flex; gap:10px; padding: 7px 0; color: var(--ink); font-weight:500; }
.hero-card li::before { content:"✓"; color: var(--green-600); font-weight:800; }

/* Dark hero (landing) — drop a photo at public/images/hero.jpg and it shows under the overlay */
.hero-dark { position: relative; background: var(--green-900); overflow: hidden; }
.hero-dark::before {
  content: ""; position: absolute; inset: 0; z-index: 0;
  background: url('/images/lakes.jpg') center/cover no-repeat;
  filter: blur(4px) saturate(.85) brightness(.95);
  transform: scale(1.08); /* hides blurred edges */
}
.hero-dark::after {
  content: ""; position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(100deg, rgba(15,38,27,.94) 0%, rgba(16,42,30,.86) 48%, rgba(27,67,50,.72) 100%);
}
.hero-dark > .container { position: relative; z-index: 2; }
.hero-dark h1 { color: #fff; }
.hero-dark .eyebrow { color: var(--gold); }
.hero-dark p.lead { color: rgba(255,255,255,.82); }
.hero-dark .hero-trust { color: rgba(255,255,255,.78); }
.hero-dark .hero-trust strong { color: #fff; }
.hero-dark .btn-ghost { background: rgba(255,255,255,.10); color:#fff; border-color: rgba(255,255,255,.45); }
.hero-dark .btn-ghost:hover { background: rgba(255,255,255,.20); color:#fff; border-color:#fff; }

/* ---------- Sections ---------- */
.section { padding: 80px 0; }
.section.tint { background: var(--green-50); }
.section-head { text-align:center; max-width: 640px; margin: 0 auto 52px; }
.section-head p { margin-top: 12px; font-size: 1.05rem; }

/* ---------- Cards / services ---------- */
.grid { display:grid; gap: 24px; }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.card {
  background:#fff; border:1px solid var(--line); border-radius: var(--radius);
  padding: 28px; box-shadow: var(--shadow-sm); transition: transform .18s ease, box-shadow .18s ease;
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.card .ico {
  width: 52px; height: 52px; border-radius: 13px; margin-bottom: 16px;
  background: var(--green-100); color: var(--green-700);
  display:flex; align-items:center; justify-content:center; font-size:1.5rem;
}
.card h3 { margin-bottom: 8px; }
.card p { font-size: .98rem; }

/* feature list inside services */
.feature-list { list-style:none; margin-top: 14px; }
.feature-list li { display:flex; gap:10px; padding:6px 0; color: var(--ink); font-size:.95rem; }
.feature-list li::before { content:"✓"; color: var(--green-600); font-weight:800; }

/* ---------- Pricing block ---------- */
.pricing { max-width: 480px; margin: 0 auto; }
.pricing .card { text-align:center; border: 2px solid var(--green-500); }
.pricing .price { font-size: 3.4rem; font-weight:800; color: var(--green-700); letter-spacing:-.03em; }
.pricing .price small { display:block; font-size:1rem; color:var(--muted); font-weight:600; margin-top:4px; }
.pricing .sub { color: var(--muted); margin: 4px 0 22px; }

/* ---------- Packages ---------- */
.pkg-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; align-items:stretch; }
.pkg {
  position:relative; background:#fff; border:1px solid var(--line); border-radius:18px;
  padding:30px 26px; box-shadow:var(--shadow-sm); display:flex; flex-direction:column;
  transition:transform .18s ease, box-shadow .18s ease;
}
.pkg:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.pkg-popular { border:2px solid var(--green-600); box-shadow:var(--shadow-md); }
.pkg-flag {
  position:absolute; top:-13px; left:50%; transform:translateX(-50%);
  background:var(--green-600); color:#fff; font-size:.72rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.06em; padding:5px 14px; border-radius:999px; white-space:nowrap;
}
.pkg-name { font-family:var(--font-head); font-weight:700; font-size:1.4rem; color:var(--ink); }
.pkg-pages { color:var(--accent); font-weight:600; font-size:.9rem; margin-bottom:14px; }
.pkg-price { font-family:var(--font-head); font-size:2.6rem; font-weight:800; color:var(--green-700); letter-spacing:-.02em; line-height:1; }
.pkg-price span { display:inline; font-size:.85rem; color:var(--muted); font-weight:600; margin-left:4px; }
.pkg-monthly { color:var(--ink); font-weight:600; margin:4px 0 14px; }
.pkg-blurb { font-size:.92rem; margin-bottom:14px; }
.pkg .feature-list { flex:1; margin-bottom:22px; }
.pkg .feature-list li { font-size:.92rem; }

.addons-wrap { margin-top:40px; background:#fff; border:1px solid var(--line); border-radius:18px; padding:30px; box-shadow:var(--shadow-sm); }
.addons-head { display:flex; justify-content:space-between; align-items:baseline; flex-wrap:wrap; gap:8px; margin-bottom:20px; }
.addons-head h3 { font-size:1.25rem; }
.addons-price { color:var(--accent); font-weight:700; font-size:.95rem; }
.addons-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.addon { display:flex; gap:14px; align-items:flex-start; }
.addon .ico { flex:0 0 46px; width:46px; height:46px; margin:0; }
.addon .ico-svg { width:22px; height:22px; }
.addon b { font-family:var(--font-head); color:var(--ink); display:block; }
.addon .addon-price { color:var(--accent); font-weight:700; font-size:.85rem; margin:2px 0 4px; }
.addon p { font-size:.88rem; }

/* ---------- Team ---------- */
.team-grid { display:grid; grid-template-columns: repeat(2,1fr); gap: 28px; max-width: 720px; margin: 0 auto; }
.team-card { text-align:center; }
.avatar {
  width: 150px; height:150px; border-radius: 50%; margin: 0 auto 18px; object-fit: cover;
  border: 4px solid #fff; box-shadow: var(--shadow-md); background: var(--green-100);
  display:flex; align-items:center; justify-content:center; color: var(--green-700);
  font-size: 2.6rem; font-weight: 800;
}
.team-card h3 { margin-bottom: 2px; }
.team-card .role { color: var(--green-600); font-weight:600; font-size:.95rem; }
.team-card p { margin-top: 10px; font-size:.95rem; }

/* ---------- Testimonials ---------- */
.quote { position: relative; }
.quote .stars { color: var(--gold); letter-spacing: 2px; margin-bottom: 10px; }
.quote blockquote { font-size: 1.05rem; color: var(--ink); font-style: italic; }
.quote .who { display:flex; align-items:center; gap:12px; margin-top:18px; }
.quote .who .dot { width:42px; height:42px; border-radius:50%; background:var(--green-100); color:var(--green-700); display:flex; align-items:center; justify-content:center; font-weight:700; }
.quote .who b { color: var(--ink); display:block; }
.quote .who span { color: var(--muted); font-size:.88rem; }

/* ---------- Forms ---------- */
.form-wrap { max-width: 640px; margin: 0 auto; }
.form-card { background:#fff; border:1px solid var(--line); border-radius: var(--radius); padding: 34px; box-shadow: var(--shadow-md); }
.field { margin-bottom: 18px; }
.field label { display:block; font-weight:600; font-size:.92rem; margin-bottom: 7px; color: var(--ink); }
.field input, .field select, .field textarea {
  width:100%; padding: 13px 14px; border:1.5px solid var(--line); border-radius: 11px;
  font-family: inherit; font-size: 1rem; color: var(--ink); background:#fff; transition: border-color .15s;
}
.field input:focus, .field select:focus, .field textarea:focus { outline:none; border-color: var(--green-500); box-shadow: 0 0 0 3px var(--green-100); }
.field textarea { min-height: 120px; resize: vertical; }
.row-2 { display:grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.check-grid { display:grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.check { display:flex; align-items:center; gap:9px; padding:11px 13px; border:1.5px solid var(--line); border-radius:11px; cursor:pointer; font-weight:500; font-size:.93rem; background:#fff; transition:border-color .12s, background .12s; }
.check:hover { border-color: var(--green-500); }
.check input { width:17px; height:17px; accent-color: var(--green-600); margin:0; }
.check:has(input:checked) { border-color: var(--green-600); background: var(--green-50); }
.choice-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:18px; }
.choice { display:flex; flex-direction:column; gap:2px; padding:16px; border:1.5px solid var(--line); border-radius:13px; cursor:pointer; background:#fff; transition:border-color .12s, background .12s, box-shadow .12s; position:relative; }
.choice input { position:absolute; opacity:0; }
.choice .choice-t { font-family:var(--font-head); font-weight:700; color:var(--ink); }
.choice .choice-d { font-size:.85rem; color:var(--muted); }
.choice.active { border-color:var(--green-600); background:var(--green-50); box-shadow:0 0 0 3px var(--green-100); }
.alert { padding: 14px 16px; border-radius: 11px; margin-bottom: 18px; font-weight:500; }
.alert-success { background: var(--green-100); color: var(--green-800); }
.alert-error { background: #fde8e8; color: #9b1c1c; }

/* ---------- Booking ---------- */
.booking-grid { display:grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items:start; }
.slot-btn { padding:10px 14px; border:1.5px solid var(--line); background:#fff; border-radius:10px; cursor:pointer; font-weight:600; font-size:.9rem; transition:all .12s; }
.slot-btn.active, .slot-btn:hover { border-color: var(--green-500); background: var(--green-50); color: var(--green-700); }
.slots { display:flex; flex-wrap:wrap; gap:10px; margin-top:8px; }

/* ---------- Footer ---------- */
.site-footer { background: var(--green-900); color: #cde9da; padding: 56px 0 28px; margin-top: 0; }
.footer-grid { display:grid; grid-template-columns: 2fr 1fr 1fr; gap: 36px; }
.site-footer h4 { color:#fff; margin-bottom: 14px; font-size: 1rem; }
.site-footer a { color:#cde9da; display:block; padding: 5px 0; font-size:.94rem; }
.site-footer a:hover { color:#fff; }
.site-footer .brand { color:#fff; margin-bottom: 12px; }
.site-footer .brand .accent { color: var(--green-500); }
.footer-bottom { border-top:1px solid rgba(255,255,255,.12); margin-top: 36px; padding-top: 20px; font-size:.86rem; color:#9cc6b3; display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; }

/* ---------- CTA band ---------- */
.cta-band { background: linear-gradient(135deg, var(--green-700), var(--green-900)); color:#fff; border-radius: 24px; padding: 54px; text-align:center; }
.cta-band h2 { color:#fff; }
.cta-band p { color: #d7f0e2; margin: 12px auto 26px; max-width: 50ch; }

/* ---------- Dashboard ---------- */
.dash-header { display:flex; justify-content:space-between; align-items:center; margin-bottom: 28px; flex-wrap:wrap; gap:14px; }
.stat-row { display:grid; grid-template-columns: repeat(4,1fr); gap:18px; margin-bottom: 28px; }
.stat { background:#fff; border:1px solid var(--line); border-radius: 14px; padding: 20px; box-shadow: var(--shadow-sm); }
.stat .n { font-size: 2rem; font-weight:800; color: var(--green-700); }
.stat .l { color: var(--muted); font-size:.9rem; }
.table-wrap { background:#fff; border:1px solid var(--line); border-radius: var(--radius); overflow:hidden; box-shadow: var(--shadow-sm); }
table { width:100%; border-collapse: collapse; }
th, td { text-align:left; padding: 14px 16px; border-bottom:1px solid var(--line); font-size:.93rem; vertical-align: top; }
th { background: var(--green-50); color: var(--green-800); font-weight:700; text-transform:uppercase; font-size:.74rem; letter-spacing:.06em; }
tr:last-child td { border-bottom:none; }
.badge { display:inline-block; padding: 3px 10px; border-radius: 999px; font-size:.76rem; font-weight:700; }
.badge.New { background: var(--green-100); color: var(--green-800); }
.badge.Contacted { background:#fef3c7; color:#92400e; }
.badge.Won { background:#dbeafe; color:#1e40af; }
.badge.Lost { background:#fee2e2; color:#991b1b; }
/* Lead cards */
.lead-list { display:grid; gap:16px; }
.lead-card { background:#fff; border:1px solid var(--line); border-radius:14px; padding:22px; box-shadow:var(--shadow-sm); }
.lead-top { display:flex; justify-content:space-between; align-items:flex-start; gap:12px; padding-bottom:14px; border-bottom:1px solid var(--line); }
.lead-name { font-family:var(--font-head); font-weight:700; font-size:1.1rem; color:var(--ink); display:flex; align-items:center; gap:9px; }
.lead-sub { color:var(--muted); font-size:.9rem; margin-top:2px; }
.lead-date { color:var(--muted); font-size:.8rem; margin-top:6px; }
.tag-ref { background:var(--gold); color:#fff; font-size:.66rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em; padding:3px 8px; border-radius:999px; }
.lead-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; padding:16px 0; }
.lead-grid .k, .lead-services .k { display:block; font-size:.7rem; text-transform:uppercase; letter-spacing:.06em; color:var(--muted); font-weight:700; margin-bottom:2px; }
.lead-grid > div { font-size:.92rem; color:var(--ink); word-break:break-word; }
.lead-services { font-size:.92rem; padding:4px 0 12px; }
.lead-msg { background:var(--green-50); border-radius:10px; padding:12px 14px; font-style:italic; color:var(--ink); font-size:.93rem; margin-bottom:14px; }
.lead-actions { display:flex; justify-content:space-between; align-items:center; gap:12px; padding-top:6px; }
.inline-form { display:inline-flex; gap:6px; align-items:center; }
.inline-form select { padding:5px 8px; border:1px solid var(--line); border-radius:8px; font-size:.82rem; }
.link-danger { color:#b91c1c; background:none; border:none; cursor:pointer; font-size:.84rem; text-decoration:underline; }
.empty { text-align:center; padding: 50px; color: var(--muted); }

.auth-wrap { max-width: 420px; margin: 80px auto; }

/* ---------- Chatbot ---------- */
#chat-launch {
  position: fixed; bottom: 24px; right: 24px; z-index: 100;
  width: 60px; height: 60px; border-radius: 50%; border:none; cursor:pointer;
  background: var(--green-600); color:#fff; box-shadow: var(--shadow-lg);
  display:flex; align-items:center; justify-content:center; transition: transform .15s;
}
#chat-launch .ico-svg { width: 26px; height: 26px; }
#chat-launch:hover { transform: scale(1.06); background: var(--green-700); }
#chat-panel {
  position: fixed; bottom: 96px; right: 24px; z-index: 100;
  width: 360px; max-width: calc(100vw - 32px); height: 480px; max-height: calc(100vh - 140px);
  background:#fff; border-radius: 18px; box-shadow: var(--shadow-lg);
  display:none; flex-direction: column; overflow:hidden; border:1px solid var(--line);
}
#chat-panel.open { display:flex; }
.chat-head { background: linear-gradient(135deg, var(--green-600), var(--green-800)); color:#fff; padding: 16px 18px; }
.chat-head b { font-size:1rem; } .chat-head span { display:block; font-size:.8rem; opacity:.85; }
.chat-body { flex:1; overflow-y:auto; padding: 16px; background: var(--green-50); display:flex; flex-direction:column; gap:10px; }
.msg { max-width: 80%; padding: 10px 13px; border-radius: 14px; font-size:.92rem; line-height:1.45; }
.msg.bot { background:#fff; border:1px solid var(--line); align-self:flex-start; border-bottom-left-radius:4px; }
.msg.user { background: var(--green-600); color:#fff; align-self:flex-end; border-bottom-right-radius:4px; }
.chat-input { display:flex; gap:8px; padding: 12px; border-top:1px solid var(--line); background:#fff; }
.chat-input input { flex:1; padding: 11px 12px; border:1.5px solid var(--line); border-radius: 999px; font-size:.92rem; }
.chat-input input:focus { outline:none; border-color: var(--green-500); }
.chat-input button { border:none; background: var(--green-600); color:#fff; width:42px; height:42px; flex:0 0 42px; border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center; }
.chat-input button .ico-svg { width:18px; height:18px; }
.success-ico { width:84px; height:84px; margin:0 auto 8px; border-radius:50%; background:var(--green-100); color:var(--green-700); display:flex; align-items:center; justify-content:center; }
.success-ico .ico-svg { width:42px; height:42px; }

/* ---------- Responsive ---------- */

/* Tablet & below */
@media (max-width: 900px) {
  .container { padding: 0 20px; }
  .section { padding: 60px 0; }
  .hero { padding: 64px 0 56px; }
  .hero-grid, .booking-grid { grid-template-columns: 1fr; gap: 34px; }
  .grid-3 { grid-template-columns: 1fr 1fr; }
  .pkg-grid { grid-template-columns: 1fr; max-width: 460px; margin: 0 auto; }
  .addons-grid { grid-template-columns: 1fr 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .stat-row { grid-template-columns: 1fr 1fr; }
  /* Mobile nav menu */
  .nav-links {
    display: none; position: absolute; top: 72px; left: 0; right: 0;
    background: #fff; flex-direction: column; padding: 8px 20px;
    border-bottom: 1px solid var(--line); box-shadow: var(--shadow-md); gap: 0;
  }
  .nav-links.open { display: flex; }
  .nav-links li { width: 100%; }
  .nav-links a { display: block; padding: 14px 4px; font-size: 1.05rem; border-bottom: 1px solid var(--line); }
  .nav-links li:last-child a { border-bottom: none; }
  .menu-toggle { display: block; }
}

/* Phone */
@media (max-width: 600px) {
  .container { padding: 0 16px; }
  .section { padding: 46px 0; }
  .section-head { margin-bottom: 34px; }
  .hero { padding: 48px 0 40px; }
  h1 { font-size: clamp(2rem, 8.5vw, 2.7rem); }
  h2 { font-size: clamp(1.5rem, 6vw, 2rem); }

  .grid-3, .grid-2, .team-grid, .row-2, .footer-grid, .check-grid, .addons-grid, .choice-grid { grid-template-columns: 1fr; }
  .stat-row, .lead-grid { grid-template-columns: 1fr 1fr; }

  /* Compact header */
  .nav { height: 64px; }
  .brand { font-size: 1.2rem; gap: 8px; letter-spacing: .03em; }
  .brand .logo-mark { height: 32px; }
  .nav-links { top: 64px; }
  .nav-cta { gap: 8px; }
  .nav-cta .btn { padding: 10px 15px; font-size: .88rem; }

  /* Full-width hero CTAs + card */
  .hero-actions { width: 100%; }
  .hero-actions .btn { width: 100%; justify-content: center; }
  .hero p.lead { font-size: 1.08rem; }
  .hero-trust { gap: 12px 20px; margin-top: 22px; }

  /* Roomier cards/forms */
  .card { padding: 24px; }
  .form-card { padding: 24px 18px; }
  .cta-band { padding: 36px 22px; }
  .cta-band h2 { font-size: 1.55rem; }
  .pkg { padding: 26px 22px; }

  /* Stack lead-card actions */
  .lead-actions { flex-direction: column; align-items: stretch; gap: 10px; }
  .dash-header { align-items: flex-start; }

  /* Prevent iOS zoom-on-focus (inputs must be >=16px) */
  .field input, .field select, .field textarea, .chat-input input { font-size: 16px; }
}

/* Very small phones */
@media (max-width: 380px) {
  .brand { font-size: 1.05rem; }
  .brand .logo-mark { height: 28px; }
  .nav-cta .btn { padding: 9px 12px; font-size: .82rem; }
  .stat-row, .lead-grid { grid-template-columns: 1fr; }
}
