*{box-sizing:border-box;margin:0;padding:0}
:root{
  --sage-dark:#2c5f4f;
  --sage:#7a9485;
  --sage-light:#e8f0eb;
  --cream:#eef3eb;
  --cream2:#e5ebe2;
  --white:#fff;
  --text:#333;
  --muted:#555;
  --muted2:#3d6454;
  --border:#dde8da;
  --r:12px;
}
body{font-family:'Georgia',serif;background:linear-gradient(135deg,var(--cream) 0%,var(--cream2) 100%);color:var(--text);line-height:1.8;min-height:100vh;display:flex;flex-direction:column}
main{flex:1}

/* ── NAV ── */
nav{background:var(--white);box-shadow:0 2px 10px rgba(0,0,0,.1);position:sticky;top:0;z-index:300}
.nav-container{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;padding:15px 20px}
.logo{font-size:1.5em;font-weight:300;color:var(--sage-dark);text-decoration:none;letter-spacing:1px}
.nav-links{display:flex;gap:30px;list-style:none;align-items:center}
.nav-links a{color:var(--sage-dark);text-decoration:none;font-size:1em;transition:color .3s}
.nav-links a:hover{color:var(--sage)}
.nav-book{background:var(--sage-dark)!important;color:#fff!important;padding:8px 20px;border-radius:6px;transition:background .3s}
.nav-book:hover{background:#234538!important}
.hamburger{display:none;background:none;border:none;font-size:22px;color:var(--sage-dark);cursor:pointer}

/* ── MOBILE NAV ── */
.mobile-nav{display:none;position:fixed;inset:0;background:var(--white);z-index:400;flex-direction:column;padding:24px}
.mobile-nav.open{display:flex}
.mobile-nav-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}
.mobile-nav-logo{font-size:19px;font-weight:300;color:var(--sage-dark);letter-spacing:1px}
.mobile-nav-close{background:none;border:none;font-size:26px;color:var(--muted);cursor:pointer}
.mobile-nav ul{list-style:none}
.mobile-nav ul li a{display:block;padding:14px 0;font-size:17px;color:var(--text);text-decoration:none;border-bottom:1px solid var(--border)}
.mob-book{display:block;margin-top:28px;background:var(--sage-dark);color:#fff;text-align:center;padding:15px;border-radius:6px;font-size:16px;font-weight:600;text-decoration:none}

/* ── PAGE HEADER ── */
.page-header{max-width:900px;margin:0 auto;padding:60px 24px 36px;text-align:center}
.page-header h1{font-size:2.5em;color:var(--sage-dark);font-weight:300;margin-bottom:12px;letter-spacing:1px}
.page-header p{color:#777;font-size:1.05em;font-style:italic}

/* ── CONTAINER ── */
.container{max-width:900px;margin:0 auto;padding:0 24px 60px}

/* ── GRID ── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:28px}

/* ── CARDS ── */
.card{background:var(--white);border-radius:var(--r);border:1px solid var(--border);padding:28px 28px 24px;box-shadow:0 2px 6px rgba(0,0,0,.04)}
.card h2{color:var(--sage-dark);font-size:1.1em;font-weight:600;margin-bottom:14px;letter-spacing:.2px}
.card p{color:var(--muted);font-size:.97em;line-height:1.75;margin-bottom:8px}
.card p:last-child{margin-bottom:0}
.card a{color:var(--sage-dark);text-decoration:none}
.card a:hover{text-decoration:underline}
.card strong{color:var(--text);font-weight:600}

/* ── CONTACT CARD — spans full width ── */
.card-contact{grid-column:1/-1}
.contact-body{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}
.contact-detail-group p{color:var(--muted);font-size:.97em;line-height:1.75;margin-bottom:6px}
.contact-detail-group a{color:var(--sage-dark);text-decoration:none;font-size:1em}
.contact-detail-group a:hover{text-decoration:underline}

/* ── BOOK BUTTON ── */
.book-btn{display:inline-block;margin-top:16px;background:var(--sage-dark);color:#fff !important;padding:12px 28px;border-radius:6px;font-size:.97em;font-weight:600;text-decoration:none !important;transition:background .3s}
.book-btn:hover{background:#234538;color:#fff !important}
.book-hint{display:block;margin-top:8px;font-size:.82em;color:var(--muted2);font-style:italic}

/* ── HOURS TABLE ── */
.hours-table{width:100%;border-collapse:collapse;font-size:.95em}
.hours-table tr td{padding:5px 0;color:var(--muted)}
.hours-table tr td:first-child{font-weight:600;color:var(--text);width:110px}
.hours-table tr.closed td{color:#696969}
.hours-badge{display:inline-block;font-size:.72em;background:var(--sage-light);border:1px solid #b0ccbb;color:var(--sage-dark);padding:1px 8px;border-radius:20px;margin-left:6px;font-weight:600;vertical-align:middle}

/* ── MAP SECTION ── */
.map-section{background:var(--white);border-radius:var(--r);border:1px solid var(--border);overflow:hidden;margin-bottom:28px;box-shadow:0 2px 6px rgba(0,0,0,.04)}
.map-section iframe{display:block;width:100%;height:380px;border:0}
.map-footer{padding:20px 24px;display:flex;gap:10px;flex-wrap:wrap;border-top:1px solid var(--border)}
.map-link{display:inline-flex;align-items:center;color:var(--sage-dark);font-size:.88em;font-weight:600;text-decoration:none;border:1px solid var(--border);background:#f6fbf8;border-radius:999px;padding:8px 14px;transition:all .18s}
.map-link:hover{background:var(--sage-light);border-color:#9fc0b2}

/* ── PARKING BOX ── */
.parking-box{background:var(--white);border-radius:var(--r);border:1px solid var(--border);padding:24px 28px;box-shadow:0 2px 6px rgba(0,0,0,.04);margin-bottom:28px}
.parking-box h2{color:var(--sage-dark);font-size:1.1em;font-weight:600;margin-bottom:14px}
.parking-list{list-style:none;display:flex;flex-direction:column;gap:10px}
.parking-list li{font-size:.95em;color:var(--muted);line-height:1.65;padding-left:16px;position:relative}
.parking-list li::before{content:'';position:absolute;left:0;top:10px;width:5px;height:5px;border-radius:50%;background:var(--sage)}
.parking-list li strong{color:var(--text)}

/* ── INLINE STYLE REPLACEMENTS ── */
.email-label{margin-top:12px}
.treatwell-ref{margin-top:10px;font-size:0.85em;color:#555}
.hours-note{margin-top:14px;font-size:.88em;color:var(--muted2);font-style:italic}
.visit-transport{margin-top:12px}

footer{text-align:center;padding:40px 20px 20px;color:var(--muted2);font-size:.9em;line-height:1.6}
footer a{color:var(--muted2);text-decoration:none}
footer a:hover{text-decoration:underline}

@media(max-width:900px){
  .nav-links{display:none}
  .hamburger{display:block}
}
@media(max-width:680px){
  .contact-grid{grid-template-columns:1fr}
  .card-contact{grid-column:auto}
  .contact-body{grid-template-columns:1fr}
  .page-header{padding:32px 20px 24px}
  .page-header h1{font-size:1.8em}
  .container{padding:0 16px 60px}
  .map-section iframe{height:280px}
}
