html { scroll-behavior: smooth; }
body { margin: 0; }
* { box-sizing: border-box; }
::selection { background: var(--gold-200); color: var(--teal-900); }
.be-input::placeholder { color: var(--gray-500); opacity: 0.8; }
.be-input:focus { outline: none; border-color: var(--gold-500) !important; box-shadow: 0 0 0 3px var(--focus-ring); }
.be-ds-btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; font-family:var(--font-body); font-weight:600; line-height:1; border-radius:var(--radius-md); border:1px solid transparent; text-decoration:none; cursor:pointer; white-space:nowrap; transition:transform var(--dur-fast) var(--ease-out), box-shadow var(--dur-base) var(--ease-out), background var(--dur-base) var(--ease-out); }
.be-ds-btn:hover { transform: translateY(-2px); }
.be-ds-btn:active { transform: scale(.98); }
.be-btn-primary { background:var(--grad-gold-soft); color:var(--teal-900); box-shadow:var(--shadow-gold); }
.be-btn-secondary { background:transparent; color:var(--gold-500); border:1.5px solid var(--gold-500); }
.be-btn-ghost { background:transparent; color:var(--gold-500); }
.be-btn-md { font-size:15px; padding:12px 22px; min-height:44px; }
.be-btn-lg { font-size:17px; padding:15px 30px; min-height:52px; }
.be-mobile-link { display:block; color:var(--cream); text-decoration:none; font-size:16px; font-weight:500; padding:13px 4px; border-bottom:1px solid var(--border-on-dark); }
.be-legal h2 { font-family:var(--font-display); color:var(--teal-900); font-size:22px; margin:34px 0 10px; }
.be-legal h3 { font-family:var(--font-display); color:var(--teal-800); font-size:18px; margin:24px 0 8px; }
.be-legal p { color:var(--text-on-light-mut); }
@keyframes beFloat { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }
@keyframes beDrop { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: translateY(0); } }
@media (max-width: 900px) {
  .be-desknav, .be-deskname { display: none !important; }
  .be-burger { display: inline-flex !important; }
  .be-herogrid, .be-aboutgrid, .be-contactgrid, .be-footergrid, .be-detailgrid { grid-template-columns: 1fr !important; }
  .be-footergrid { width: auto !important; }
  .be-footerbottom { flex-direction: column; align-items: flex-start !important; }
  .be-servicegrid { grid-template-columns: 1fr 1fr !important; }
}
@media (max-width: 620px) {
  .be-servicegrid, .be-aboutcards, .be-formrow, .be-detailgrid2 { grid-template-columns: 1fr !important; }
  .be-herogrid h1 { font-size: 36px !important; }
}