:root{
  	--sg-sticky-offset: 120px; 
	--sg-orange:#198754;
	--sg-navy:#0f1a2b;
	--sg-ink:#1b1b1b;
	--sg-muted:#6b7280;
	--sg-bg:#f7f7fb;
	--sg-card:#ffffff;
	--sg-border:#e5e7eb;
	--sg-accent:#ff7a1a;
	--sg-nav-size:1.15rem;
}
html { scroll-padding-top: var(--sg-sticky-offset); }
body{ color:var(--sg-ink); background:var(--sg-bg); }
.sg-contact-icon { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; border-radius: 50%; border: 1px solid var(--sg-border); color: var(--sg-orange); font-size: 1.05rem; text-decoration: none; }
.sg-contact-icon:hover, .sg-contact-icon:focus-visible { background: #fafafa; border-color: var(--sg-orange); outline: none; }
.sg-contact-icon:active { background: #f2f2f2; }
.sg-contact-icon::after { content: attr(aria-label); position: absolute; transform: translateY(150%); background:#fff; padding:.25rem .5rem; border:1px solid var(--sg-border); border-radius:.4rem; font-size:.75rem; white-space:nowrap; opacity:0; pointer-events:none; transition:opacity .15s ease; }
.sg-contact-icon:hover::after { opacity:1; }
.btn-icon {
  width: 44px; height: 44px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  background: transparent;
  border: 1px solid transparent;
  color: var(--sg-orange, #e8752f);
  text-decoration: none;
}
.btn-icon:hover,
.btn-icon:focus-visible {
  border-color: var(--sg-border, #e5e7eb);
  background: #fafafa;
  outline: 3px solid rgba(232,117,47,.35);
  outline-offset: 2px;
}
.btn-icon[href^="tel:"] {
  margin-right: 0.75rem;
}
.sg-contact-icon::after { content: none !important; }
.offcanvas-top {
  height: auto !important;
  max-height: 100vh;
  border-bottom: 1px solid var(--sg-border, #e5e7eb);
}
.offcanvas-top .offcanvas-body {
  padding-bottom: 0 !important; 
}
.navbar-sg {
  background: #fff;
}
.navbar-sg .navbar-nav .nav-link {
  font-weight: 500;
  font-size: var(--sg-nav-size, 1.15rem);
  color: var(--sg-ink, #1b1b1b);
  padding: .85rem 1rem;
}
.navbar-sg .navbar-nav .nav-link:hover { color: var(--sg-orange, #198754); }
.navbar-sg .dropdown-menu {
  border-color: var(--sg-border, #e5e7eb);
  box-shadow: 0 10px 20px rgba(0,0,0,.08);
}
.navbar-sg .dropdown-item { font-weight: 500; }
.navbar-sg .dropdown-item:active { background: var(--sg-orange, #198754); }
@media (min-width: 992px){
  .navbar-sg .nav-item.dropdown:hover .dropdown-menu { display:block; }
}
.sg-header.sticky-top { z-index: 1030; background: #fff; }
@media (max-width: 991.98px) {
  .offcanvas-body .btn-icon[href^="tel:"] {
    margin-right: 1rem;
  }
}
.sg-announce{ background:var(--sg-orange); color:#fff; font-weight:600; }
.sg-announce a{ color:#fff; text-decoration:none; font-weight:700; }
.sg-announce a:hover{ text-decoration:underline; }
.sg-header.sticky-top{ z-index:1030; background:#fff; }
.sg-row-top{ padding:.9rem 0; }
.sg-divider{ border-top:1px solid var(--sg-border); }
.sg-logo{ color:#000; text-decoration:none; line-height:.95; letter-spacing:.2px; }
.sg-logo .line1,.sg-logo .line2{ display:block; font-size:1.9rem; }
.sg-action {
  width: 44px; height: 44px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--sg-border, #e5e7eb);
  background: #fff;
  color: var(--sg-orange, #e8752f);
  text-decoration: none;
}
.sg-action:hover,
.sg-action:focus-visible {
  background: #fafafa;
  border-color: var(--sg-orange, #e8752f);
  outline: none;
}
.sg-nav .nav-link{
	color:var(--sg-ink);
	font-weight:500;
	padding:.85rem 1rem;
	font-size:var(--sg-nav-size);
}
.sg-nav .nav-link:hover{ color:#e8752f; }
.dropdown-menu{ border-color:var(--sg-border); box-shadow:0 10px 20px rgba(0,0,0,.08); }
.dropdown-item{ font-weight:500; }
.dropdown-item:active{ background:var(--sg-orange); }
@media (min-width: 992px){
	.nav-item.dropdown:hover .dropdown-menu{ display:block; }
}
.sg-phone{ font-size:1.25rem;color:#111; text-decoration:none; }
@media (min-width:1200px){ .sg-container{ max-width:1320px; } }
.rounded-2xl{ border-radius:1rem; }
.shadow-soft{ box-shadow:0 10px 22px rgba(0,0,0,.06); }
.sg-card{ background:var(--sg-card); border:1px solid var(--sg-border); border-radius:1rem; box-shadow:0 6px 18px rgba(17,24,39,.06); height:100%; }
.sg-link{ font-weight:700; color:var(--sg-accent); text-decoration:none; }
.sg-link:hover{ color:#ff8b35; }
.sg-hero{
	background: radial-gradient(1200px 500px at 80% -10%, rgba(229,159,235,.18), transparent 60%), linear-gradient(180deg,#fff,#f9fafb 70%);
	padding:4rem 0 3rem;
}
.sg-badge{ display:inline-flex; align-items:center; gap:.5rem; background:#fff; border:1px solid var(--sg-border); color:var(--sg-navy); border-radius:999px; padding:.4rem .8rem; font-weight:700; }
.sg-hero h1{ font-weight:800; color:var(--sg-navy); line-height:1.1; font-family: "Cedarville Cursive", cursive; }
.sg-hero .lead{ color:var(--sg-muted); font-size:1.15rem; }
.sg-cta-btn{
	--bs-btn-bg: var(--sg-accent);
	--bs-btn-border-color: var(--sg-accent);
	--bs-btn-hover-bg: #ff8b35;
	--bs-btn-hover-border-color: #ff8b35;
	--bs-btn-color:#fff;
	--bs-btn-border-radius:.75rem;
	--bs-btn-padding-y:.75rem;
	--bs-btn-padding-x:1.25rem;
	font-weight:800; box-shadow:0 8px 20px rgba(255,122,26,.25);
}
.sg-why{ background:linear-gradient(180deg,#ffffff,#f3f4f6); border-block:1px solid var(--sg-border); }
.stripe-input {
  padding: 12px 14px;
  border: 1px solid #ced4da;
  border-radius: 6px;
  background: #fff;
  min-height: 44px;
}
.stripe-input.StripeElement--focus {
  border-color: #86b7fe;
  box-shadow: 0 0 0 .25rem rgba(13,110,253,.25);
}
.stripe-input.StripeElement--invalid {
  border-color: #dc3545;
}
