:root { --cream: #f5f2ea; --sand: #dce9e1; --clay: #94bba8; --bark: #497266; --moss: #274438; --charcoal: #17352b; --warm-white: #fbf9f5; --sage-light: #dce9e1; --terra: #c96b3b; --mid: #1f3129; --sage-dark: #1f3129; } *,*::before,*::after{margin:0;padding:0;box-sizing:border-box} html{scroll-behavior:smooth} body{font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--charcoal)} .topbar{background:var(--charcoal);text-align:center;padding:.6rem 1rem;font-size:.78rem;letter-spacing:.1em;color:var(--sage-light)} .topbar a{color:#fff;text-decoration:none;font-weight:500} header{display:flex;justify-content:space-between;align-items:center;padding:1.8rem 6%;background:var(--cream);border-bottom:1px solid var(--sand);flex-wrap:wrap;gap:1rem} .logo-wrap{display:flex;align-items:center;gap:1.1rem;text-decoration:none} .logo-circle{width:68px;height:68px;background:var(--clay);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0} .logo-drop{width:9px;height:13px;background:var(--terra);border-radius:50% 50% 50% 50%/60% 60% 40% 40%;margin-bottom:3px} .logo-js{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:600;color:var(--charcoal);line-height:1} .logo-text .sub{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mid);display:block} .logo-text .main{font-family:'Cormorant Garamond',serif;font-size:1.85rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--charcoal);line-height:1.1;display:block} .header-cta{display:inline-flex;align-items:center;gap:.6rem;background:var(--terra);color:#fff;text-decoration:none;padding:.85rem 1.8rem;font-size:.95rem;font-weight:500;border-radius:2px;white-space:nowrap;transition:background .2s,transform .15s} .header-cta:hover{background:#a8480f;transform:translateY(-1px)} nav.breadcrumb{background:var(--sand);padding:.8rem 6%;font-size:.78rem;color:var(--mid)} nav.breadcrumb a{color:var(--sage-dark);text-decoration:none} nav.breadcrumb a:hover{text-decoration:underline} nav.breadcrumb span{margin:0 .4rem} .page-hero{background:var(--clay);padding:4rem 6%;position:relative;overflow:hidden;color:var(--charcoal)} .page-hero h1{font-family:'Cormorant Garamond',serif;font-size:clamp(2rem,4.5vw,3.4rem);font-weight:300;line-height:1.2;margin-bottom:.8rem} .page-hero-sub{font-size:1rem;opacity:.9;line-height:1.7;max-width:600px} /* Grid Zones */ .zones-section { padding: 4rem 6%; background: var(--warm-white); } .zones-full-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 2.5rem; } .zones-full-group-title { font-family: 'Cormorant Garamond', serif; font-size: 1.2rem; font-weight: 600; color: var(--bark); margin-bottom: 1rem; letter-spacing: .04em; text-transform: uppercase; border-bottom: 2px solid var(--sand); padding-bottom: 0.5rem; } .zones-full-list { display: flex; flex-wrap: wrap; gap: .6rem; } .zone-btn { display: inline-flex; background: var(--cream); border: 1px solid var(--sand); color: var(--mid); padding: .45rem 1.1rem; border-radius: 2px; font-size: .85rem; text-decoration: none; transition: all .2s; } .zone-btn:hover { background: var(--clay); color: #fff; border-color: var(--clay); transform: translateY(-1px); } .cta-band{background:var(--charcoal);padding:3.5rem 6%;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:2rem;color:#fff} .cta-band-text h2{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:300;margin-bottom:.3rem} .cta-band-text p{font-size:.88rem;color:rgba(255,255,255,.5)} .contact-num{font-family:'Cormorant Garamond',serif;font-size:2.2rem;font-weight:600;color:#fff;text-decoration:none;letter-spacing:.06em} footer{background:var(--charcoal);padding:2.5rem 6%;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;font-size:.76rem;color:rgba(255,255,255,.3)} footer a{color:var(--sand);text-decoration:none} .footer-copy{width:100%;text-align:center;margin-top:2rem} @media(max-width:768px) { header { padding: 1rem 6%; } .cta-band { flex-direction: column; text-align: center; } .zones-full-grid { grid-template-columns: 1fr; } }
