/* ══════════════════════════════════════════
   Sean Sheridan Sews — Shared Stylesheet
   ══════════════════════════════════════════ */

/* ── Base ── */
*, *::before, *::after { box-sizing: border-box; }
body { background-color: #f8f4eb; font-family: 'Lora', Georgia, serif; color: #1c1c1c; overflow-x: hidden; margin: 0; }
a { color: inherit; text-decoration: none; }

/* ── Homepage hero (hero.png background) ── */
.hero-bg {
  background:
    linear-gradient(105deg, rgba(11,44,25,0.82) 0%, rgba(11,44,25,0.72) 45%, rgba(7,30,17,0.60) 100%),
    url('hero.png') center 40% / cover no-repeat;
  min-height: 580px;
}

/* ── Inner page hero ── */
.inner-hero {
  background-color: #0b2c19;
  padding: 52px 0 44px;
}

/* ── Breadcrumb ── */
.breadcrumb {
  font-family: 'Lora', Georgia, serif;
  font-size: 13px;
  font-style: italic;
  color: rgba(255,255,255,0.50);
  margin-bottom: 18px;
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.breadcrumb a { color: rgba(207,159,63,0.80); }
.breadcrumb a:hover { color: #cf9f3f; }
.breadcrumb .sep { opacity: 0.4; font-style: normal; }

/* ── Celtic divider ── */
.celtic-divider { display: flex; align-items: center; gap: 12px; }
.celtic-divider::before, .celtic-divider::after { content: ''; flex: 1; height: 1px; background: currentColor; opacity: 0.3; }

/* ── Form fields (hero contact form) ── */
.form-field {
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(207,159,63,0.35);
  color: #fff;
  padding: 10px 14px;
  width: 100%;
  font-family: 'Lora', Georgia, serif;
  font-size: 15px;
  border-radius: 1px;
  outline: none;
  transition: border-color 0.2s, background 0.2s;
}
.form-field::placeholder { color: rgba(255,255,255,0.45); font-style: italic; }
.form-field:focus { border-color: rgba(207,159,63,0.75); background: rgba(255,255,255,0.13); }
select.form-field option { color: #1c1c1c; background: #fff; }
textarea.form-field { resize: vertical; min-height: 80px; }

/* ── Service strip panels ── */
.panel-dark { background: linear-gradient(to top, rgba(0,0,0,0.82) 0%, rgba(0,0,0,0.38) 55%, rgba(0,0,0,0.08) 100%); }
.panel-gold { background: linear-gradient(to top, rgba(207,159,63,0.88) 0%, rgba(207,159,63,0.48) 55%, rgba(207,159,63,0.08) 100%); }

/* ── Navigation ── */
.sss-nav {
  display: flex;
  align-items: stretch;
  list-style: none;
  margin: 0;
  padding: 0;
}
.sss-nav > li > a {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 19px 20px;
  color: #fff;
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 14px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  white-space: nowrap;
  transition: color 0.15s;
}
.sss-nav > li > a:hover { color: #cf9f3f; }

.sss-quote-btn {
  display: inline-flex;
  align-items: center;
  background: #cf9f3f;
  color: #0b2c19 !important;
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  padding: 14px 28px;
  white-space: nowrap;
  transition: background 0.15s;
  flex-shrink: 0;
  text-decoration: none;
}
.sss-quote-btn:hover { background: #b8852a; }

/* ── Services dropdown ── */
.has-dropdown { position: relative; }
.dropdown-menu {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  background: #071e11;
  border: 1px solid rgba(207,159,63,0.2);
  border-top: 2px solid #cf9f3f;
  min-width: 255px;
  z-index: 200;
  padding: 6px 0;
  box-shadow: 0 8px 24px rgba(0,0,0,0.35);
  list-style: none;
  margin: 0;
}
.has-dropdown:hover .dropdown-menu { display: block; }
.dropdown-menu li a {
  display: block;
  padding: 9px 18px;
  color: rgba(255,255,255,0.75);
  font-family: 'Lora', Georgia, serif;
  font-size: 14px;
  font-style: italic;
  transition: color 0.15s, background 0.15s;
  text-transform: none;
  letter-spacing: normal;
}
.dropdown-menu li a:hover { color: #cf9f3f; background: rgba(255,255,255,0.04); }

/* ── Footer list ── */
.sss-footer-list { list-style: none; margin: 0; padding: 0; }
.sss-footer-list li { margin-bottom: 8px; }
.sss-footer-list a {
  font-family: 'Lora', Georgia, serif;
  font-style: italic;
  font-size: 13px;
  color: rgba(255,255,255,0.65);
  transition: color 0.15s;
}
.sss-footer-list a:hover { color: #cf9f3f; }

/* ── FAQ items ── */
.faq-item { border-top: 1px solid rgba(11,44,25,0.12); padding: 22px 0; }
.faq-item:last-child { border-bottom: 1px solid rgba(11,44,25,0.12); }
.faq-q {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 700;
  font-size: 17px;
  color: #0b2c19;
  margin: 0 0 10px;
  line-height: 1.35;
}
.faq-a {
  font-family: 'Lora', Georgia, serif;
  font-style: italic;
  font-size: 15px;
  line-height: 1.85;
  color: #444;
  margin: 0;
}

/* ── Internal link grid (hub/location pages) ── */
.link-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
}
.link-grid a {
  display: block;
  padding: 12px 16px;
  background: #fff;
  border: 1px solid rgba(11,44,25,0.12);
  font-family: 'Lora', Georgia, serif;
  font-style: italic;
  font-size: 14px;
  color: #0b2c19;
  transition: border-color 0.15s, background 0.15s;
}
.link-grid a:hover { border-color: #cf9f3f; background: #fdfaf3; }
