@import url("https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700;800&family=Fraunces:opsz,wght@9..144,700;9..144,800&display=swap");

:root {
  --cream: #fffaf0;
  --cream-deep: #f8ead8;
  --paper: #fffdf8;
  --plum: #3d1730;
  --plum-deep: #2c1125;
  --orange: #ed4b0b;
  --orange-dark: #c83c07;
  --teal: #176f70;
  --teal-soft: #dcefeb;
  --lilac: #c8a9d4;
  --ink: #2e2528;
  --muted: #73686a;
  --line: #eadacb;
  --shadow: 0 14px 35px rgba(77, 44, 29, .1);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  background: var(--cream);
  color: var(--ink);
  font-family: "DM Sans", Arial, sans-serif;
}
a { transition: color .2s ease, background-color .2s ease, border-color .2s ease, transform .2s ease; }
h1, h2, h3, .font-display { color: var(--plum); font-family: "Fraunces", Georgia, serif; }
input, select, textarea { background: white; border-color: var(--line) !important; }
input:focus, select:focus, textarea:focus { border-color: var(--teal) !important; outline: 2px solid rgba(23, 111, 112, .16); }

.site-header { background: rgba(255, 250, 240, .94); border-bottom: 1px solid var(--line); position: sticky; top: 0; z-index: 40; }
.brand { color: var(--plum); font-family: "Fraunces", Georgia, serif; font-size: 2rem; font-weight: 800; letter-spacing: -.06em; }
.brand-tag { color: var(--orange); display: block; font-size: .55rem; font-weight: 800; letter-spacing: .14em; margin-top: -.3rem; text-transform: uppercase; }
.nav-link { color: var(--ink); font-size: .88rem; font-weight: 700; }
.nav-link:hover { color: var(--orange); }
.button-primary, .button-secondary, .button-plum, .button-quiet {
  align-items: center; border-radius: .75rem; display: inline-flex; font-size: .9rem; font-weight: 800;
  justify-content: center; padding: .72rem 1.1rem;
}
.button-primary { background: var(--orange); color: white; box-shadow: 0 7px 16px rgba(237, 75, 11, .2); }
.button-primary:hover { background: var(--orange-dark); transform: translateY(-1px); }
.button-secondary { background: white; border: 1px solid var(--teal); color: var(--teal); }
.button-secondary:hover { background: var(--teal-soft); }
.button-plum { background: var(--plum); color: white; }
.button-plum:hover { background: var(--plum-deep); }
.button-quiet { border: 1px solid var(--line); color: var(--ink); }

.public-main { max-width: none !important; padding: 0 !important; }
.page-width { margin-inline: auto; max-width: 72rem; padding-inline: 1rem; }
.section-space { padding-block: 4rem; }
.eyebrow { color: var(--orange); font-size: .72rem; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.display-xl { font-size: clamp(3rem, 7vw, 5.8rem); letter-spacing: -.075em; line-height: .95; }
.display-lg { font-size: clamp(2.5rem, 5vw, 4.5rem); letter-spacing: -.065em; line-height: .98; }
.display-md { font-size: clamp(2rem, 4vw, 3.1rem); letter-spacing: -.055em; line-height: 1; }
.hero { overflow: hidden; padding-block: 4.8rem 3.8rem; position: relative; }
.hero::after { background: var(--teal); border-radius: 999px; content: ""; height: .28rem; left: 1rem; opacity: .7; position: absolute; top: 88%; transform: rotate(-5deg); width: 4rem; }
.hero-panel { background: var(--plum); border-radius: 2rem; color: white; min-height: 21rem; overflow: hidden; padding: 2rem; position: relative; }
.hero-panel h2 { color: white; }
.hero-panel::after { background: var(--orange); border-radius: 50%; content: ""; height: 13rem; opacity: .85; position: absolute; right: -4rem; top: -4rem; width: 13rem; }
.hero-panel::before { border: 3px solid var(--lilac); border-radius: 50%; bottom: -6rem; content: ""; height: 15rem; position: absolute; right: 2rem; width: 15rem; }
.card { background: var(--paper); border: 1px solid var(--line); border-radius: 1.2rem; box-shadow: var(--shadow); }
.soft-panel { background: var(--cream-deep); border: 1px solid var(--line); border-radius: 1.5rem; }
.plum-panel { background: var(--plum); border-radius: 1.5rem; color: white; }
.plum-panel h1, .plum-panel h2, .plum-panel h3 { color: white; }

.special-card { background: var(--paper); border: 1px solid var(--line); border-radius: 1.1rem; box-shadow: var(--shadow); overflow: hidden; }
.special-photo { height: 13.5rem; object-fit: cover; width: 100%; }
.special-placeholder { align-items: center; background: linear-gradient(135deg, var(--plum), #60364e); color: var(--cream); display: flex; height: 13.5rem; justify-content: center; letter-spacing: .15em; text-transform: uppercase; }
.special-price { background: var(--plum); border-radius: 999px; color: white; flex: none; font-size: .85rem; font-weight: 800; padding: .4rem .7rem; }
.preview-badge { color: var(--orange-dark); font-size: .65rem; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }
.launch-note { align-items: center; background: #fff3df; border: 1px solid #f1d0ad; border-radius: 1rem; display: flex; gap: 1rem; justify-content: space-between; padding: 1rem 1.1rem; }
.location-search { align-items: center; background: white; border: 1px solid var(--line); border-radius: 1rem; box-shadow: var(--shadow); display: flex; gap: .55rem; max-width: 39rem; padding: .45rem; }
.location-search input { border: 0; flex: 1; min-width: 0; padding: .65rem .7rem; }
.location-search input:focus { outline: 0; }
.step-number { align-items: center; background: var(--teal); border-radius: 50%; color: white; display: flex; font-weight: 800; height: 2rem; justify-content: center; width: 2rem; }
.step-card:nth-child(2) .step-number { background: var(--orange); }
.step-card:nth-child(3) .step-number { background: #6b4278; }
.icon-bubble { align-items: center; background: var(--teal-soft); border-radius: 50%; color: var(--teal); display: inline-flex; font-size: 1.4rem; height: 3rem; justify-content: center; width: 3rem; }
.icon-bubble.orange { background: #ffe1cf; color: var(--orange); }
.icon-bubble.lilac { background: #eee0f1; color: #6b4278; }

.admin-main { max-width: 72rem; }
.admin-nav { background: var(--plum); color: white; }
.admin-nav a { color: white; font-size: .85rem; font-weight: 700; }
.admin-nav a:hover { color: #ffb18c; }
.admin-nav-button { background: var(--orange); border-radius: .5rem; color: white !important; margin-block: -.2rem; padding: .2rem .55rem; }
.admin-nav-button:hover { background: var(--orange-dark); color: white !important; }
.admin-card { background: var(--paper); border: 1px solid var(--line); border-radius: .85rem; box-shadow: 0 5px 16px rgba(77, 44, 29, .06); }
.admin-main .bg-white { background: var(--paper) !important; }
.admin-main .bg-stone-50, .admin-main .bg-stone-100 { background: var(--cream-deep) !important; }
.admin-main .bg-stone-950 { background: var(--plum) !important; }
.admin-main .bg-rose-700 { background: var(--orange) !important; }
.admin-main .text-rose-700 { color: var(--orange-dark) !important; }
.admin-main .border-stone-200, .admin-main .border-stone-300 { border-color: var(--line) !important; }
.admin-main section, .admin-main article, .admin-main .shadow-sm { border-radius: .85rem; }
.status-badge { border-radius: 999px; display: inline-flex; font-size: .7rem; font-weight: 800; letter-spacing: .06em; padding: .28rem .58rem; text-transform: uppercase; }
.status-new, .status-draft { background: #ffe1cf; color: #a63808; }
.status-contacted, .status-published { background: var(--teal-soft); color: var(--teal); }
.status-converted { background: #def1d2; color: #397026; }
.status-closed, .status-expired { background: #ece7e3; color: #746a68; }
.icon-button { align-items: center; border: 1px solid var(--line); border-radius: .5rem; color: var(--ink); display: inline-flex; font-size: .95rem; font-weight: 800; height: 2rem; justify-content: center; line-height: 1; width: 2rem; }
.icon-button:hover { background: var(--teal-soft); border-color: var(--teal); color: var(--teal); }
.icon-button.danger { color: #b42318; }
.icon-button.danger:hover { background: #fee4e2; border-color: #fda29b; color: #912018; }
.site-footer { background: var(--plum); color: #f8e9de; }
.site-footer h2 { color: white; }
.site-footer a:hover { color: #ffb18c; }
.footer-heading { color: #ffb18c; font-family: "DM Sans", Arial, sans-serif; font-size: .72rem; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.map-layout { display: grid; gap: 1rem; grid-template-columns: minmax(0, 1fr) minmax(16rem, 21rem); }
.specials-map { border: 1px solid var(--line); border-radius: 1.2rem; min-height: 36rem; overflow: hidden; }
.map-results { display: grid; gap: .75rem; max-height: 36rem; overflow-y: auto; padding-right: .25rem; }
.map-result-card { background: var(--paper); border: 1px solid var(--line); border-radius: 1rem; padding: 1rem; }

@media (max-width: 767px) {
  .desktop-nav { display: none !important; }
  .hero { padding-block: 3.6rem 2.8rem; }
  .hero-panel { display: none; }
  .section-space { padding-block: 3rem; }
  .launch-note { align-items: flex-start; flex-direction: column; }
  .map-layout { grid-template-columns: 1fr; }
  .specials-map { min-height: 22rem; }
  .map-results { max-height: none; }
}
