
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Cormorant+Garamond:wght@400;500;600;700&display=swap');

:root{
  --bg:#f5f3ee;
  --panel:#ffffff;
  --text:#171717;
  --muted:#5f5a54;
  --line:#ddd7ce;
  --gold:#d4a437;
  --gold-dark:#b88922;
  --black:#070707;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',system-ui,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.55;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{
  width:min(1200px, calc(100% - 64px));
  margin:0 auto;
}
.site-header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(255,255,255,.96);
  backdrop-filter: blur(8px);
  border-bottom:1px solid #d8d2c9;
  box-shadow:0 2px 10px rgba(0,0,0,.05);
}
.nav{
  height:72px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}
.logo{width:122px}
.nav-center{
  display:flex;
  gap:34px;
  align-items:center;
  font-size:14px;
  font-weight:500;
}
.nav-center a:hover,.nav-center a.active,.dropdown button.active{
  color:var(--gold-dark);
}
.dropdown{
  position:relative;
}
.dropdown button{
  border:none;
  background:none;
  font:inherit;
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:6px;
  color:inherit;
  padding:0;
}
.dropdown-menu{
  position:absolute;
  top:100%;
  left:-16px;
  min-width:220px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  padding:10px;
  box-shadow:0 15px 40px rgba(0,0,0,.08);
  display:none;
}
.dropdown:hover .dropdown-menu{display:block}
.dropdown-menu a{
  display:block;
  padding:10px 12px;
  border-radius:10px;
  font-size:14px;
}
.dropdown-menu a:hover{background:#f5f2eb}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:13px 24px;
  border-radius:6px;
  border:1px solid transparent;
  font-weight:700;
  font-size:15px;
  transition:.2s ease;
}
.btn-gold{
  background:var(--gold);
  color:#111;
}
.btn-gold:hover{background:#e1b54c}
.btn-dark{
  background:#0a0a0a;
  color:#fff;
}
.btn-dark:hover{background:#1b1b1b}
.hero{
  position:relative;
  background:
    linear-gradient(90deg, rgba(5,5,5,.95) 0%, rgba(15,15,15,.78) 30%, rgba(10,10,10,.85) 55%, rgba(5,5,5,.95) 100%),
    radial-gradient(circle at 50% 10%, rgba(255,255,255,.08), transparent 35%),
    repeating-linear-gradient(90deg, rgba(255,255,255,.03) 0 2px, transparent 2px 95px),
    #070707;
  color:#fff;
}
.hero .container{
  min-height:560px;
  display:flex;
  align-items:center;
}
.eyebrow{
  text-transform:uppercase;
  letter-spacing:.28em;
  font-size:14px;
  color:var(--gold);
  font-weight:600;
  margin-bottom:20px;
}
.hero-title,.section-title,.cta-title,.page-hero-title{
  font-family:'Cormorant Garamond', serif;
  font-weight:600;
  line-height:.95;
  margin:0 0 22px;
}
.hero-title{
  font-size:84px;
  max-width:760px;
}
.hero-title .accent,
.section-title .accent,
.cta-title .accent,
.page-hero-title .accent{color:var(--gold); font-style:italic;}
.hero-text{
  font-size:18px;
  max-width:620px;
  color:#e8e5de;
  margin:0 0 34px;
}
section{
  padding:86px 0;
  border-top:1px solid var(--line);
}
section:first-of-type{border-top:none}
.section-head{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:40px;
  align-items:start;
  margin-bottom:42px;
}
.section-title{
  font-size:62px;
}
.section-copy{
  color:#55504a;
  font-size:17px;
  max-width:460px;
}
.feature-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:22px;
}
.feature-card{
  position:relative;
  min-height:240px;
  border-radius:2px;
  overflow:hidden;
  color:#fff;
  background:
    linear-gradient(180deg, rgba(0,0,0,.12), rgba(0,0,0,.78)),
    linear-gradient(135deg, rgba(255,255,255,.16), rgba(255,255,255,0) 45%),
    #111;
  border:1px solid #1d1d1d;
}
.feature-card:nth-child(1){background:
    linear-gradient(180deg, rgba(0,0,0,.12), rgba(0,0,0,.78)),
    linear-gradient(90deg, rgba(255,255,255,.02), rgba(255,255,255,.02)),
    repeating-linear-gradient(90deg, rgba(255,255,255,.04) 0 2px, transparent 2px 32px),
    #111;}
.feature-card:nth-child(2){background:
    linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.8)),
    linear-gradient(145deg, rgba(255,255,255,.18), transparent 45%),
    linear-gradient(315deg, #3c3c3c, #101010 60%);}
.feature-card:nth-child(3){background:
    linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.85)),
    linear-gradient(180deg, rgba(255,255,255,.06), transparent 40%),
    linear-gradient(135deg, #545454 0%, #151515 65%);}
.feature-card:nth-child(4){background:
    linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.85)),
    linear-gradient(90deg, rgba(255,255,255,.05), transparent 40%),
    radial-gradient(circle at 72% 38%, rgba(255,255,255,.08), transparent 18%),
    #161616;}
.feature-content{
  position:absolute;
  inset:auto 18px 18px 18px;
}
.feature-icon,
.practice-icon{
  width:40px;height:40px;border-radius:4px;
  display:grid;place-items:center;
  background:rgba(212,164,55,.18);
  color:var(--gold);
  margin-bottom:18px;
  border:1px solid rgba(212,164,55,.22);
}
.feature-title,.practice-title-sm{
  font-family:'Cormorant Garamond', serif;
  font-size:28px;
  margin:0 0 8px;
}
.feature-desc{margin:0;color:#ece8de}
.practice-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
.practice-card{
  background:#f7f5ef;
  border:1px solid var(--line);
  padding:22px 22px 26px;
  min-height:166px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.practice-top{display:flex;justify-content:space-between;align-items:flex-start}
.arrow{font-size:26px;color:#5d5851}
.practice-title-sm{color:#171717}
.practice-desc{margin:10px 0 0;color:#57514b;font-size:16px}
.office-grid{
  display:grid;
  grid-template-columns:1.35fr .9fr;
  gap:18px;
  align-items:start;
}
.map-card,.hours-card,.contact-card,.form-card,.mini-card{
  background:#f7f5ef;
  border:1px solid var(--line);
  border-radius:3px;
  overflow:hidden;
}
.map-card{padding:0}
.map-image{
  height:390px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.55), rgba(255,255,255,.55)),
    url('https://maps.googleapis.com/maps/api/staticmap?center=170+Steelwell+Rd+200+Brampton+ON&zoom=15&size=800x450&scale=2&maptype=roadmap&markers=color:red%7C170+Steelwell+Rd+200+Brampton+ON');
  background-size:cover;
  background-position:center;
  position:relative;
}
.map-fallback{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(255,255,255,.55), rgba(255,255,255,.55)),
    repeating-linear-gradient(45deg, #d2d2d2 0 2px, #efefef 2px 24px),
    linear-gradient(90deg, #c9c9c9, #f4f4f4 50%, #d0d0d0);
  opacity:.85;
}
.map-pin{
  position:absolute; left:55%; top:43%;
  width:16px;height:16px;border-radius:50%;
  background:#333;
  border:4px solid #a1a1a1;
}
.map-card .btn-dark{margin:18px}
.hours-card{padding:28px 30px}
.hours-title{
  font-family:'Cormorant Garamond', serif;
  font-size:34px;
  margin:0 0 18px;
  color:var(--gold-dark);
}
.hours-row{
  display:flex;justify-content:space-between;gap:20px;
  padding:12px 0;border-bottom:1px solid var(--line);font-weight:500;
}
.hours-row:last-of-type{border-bottom:none}
.note{font-style:italic;color:#55504a;margin:12px 0 20px}
.contact-list{display:grid;gap:12px;color:#26221e}
.contact-list a:hover{color:var(--gold-dark)}
.cta-band{
  text-align:center;
  padding:88px 0 82px;
}
.cta-title{font-size:62px;margin-bottom:12px}
.cta-text{font-size:17px;color:#59544e;margin:0 0 24px}
.footer{
  background:#060606;
  color:#fff;
  padding:66px 0 52px;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.15fr .65fr .8fr;
  gap:56px;
}
.footer-logo{width:170px;margin-bottom:24px}
.footer h4{
  font-family:'Cormorant Garamond', serif;
  font-size:28px;
  margin:0 0 12px;
  color:var(--gold);
}
.footer p,.footer a,.footer li{
  color:#e7e2d8;
  font-size:16px;
}
.footer ul{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.footer .muted{color:#cfc8bb}
.page-hero{
  background:#060606;
  color:#fff;
}
.page-hero .container{
  min-height:380px;
  display:flex;
  align-items:center;
}
.page-hero-title{font-size:72px}
.page-hero-copy{
  font-size:17px;
  max-width:720px;
  color:#ece8de;
}
.help-grid{
  display:grid;
  grid-template-columns:.75fr 1.35fr;
  gap:42px;
  align-items:start;
}
.help-title{
  font-family:'Cormorant Garamond', serif;
  font-size:52px;
  margin:0 0 10px;
}
.check-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.check-item{
  background:#f7f5ef;
  border:1px solid var(--line);
  padding:16px 18px;
  font-size:16px;
}
.value-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:56px;
}
.value-title{
  font-family:'Cormorant Garamond', serif;
  font-size:28px;
  margin:0 0 10px;
}
.form-layout{
  display:grid;
  grid-template-columns:1.25fr .8fr;
  gap:26px;
  align-items:start;
}
.form-card{padding:26px}
.form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.form-group{display:grid;gap:8px;margin-bottom:14px}
label{font-size:14px;font-weight:600}
input, select, textarea{
  width:100%;
  padding:13px 14px;
  border:1px solid var(--line);
  border-radius:4px;
  font:inherit;
  background:#fff;
}
textarea{min-height:140px;resize:vertical}
small{color:#666059}
.spacer-0{padding-top:0}
@media (max-width: 1050px){
  .hero-title{font-size:66px}
  .section-title,.cta-title,.page-hero-title{font-size:52px}
  .feature-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid,.office-grid,.form-layout,.help-grid{grid-template-columns:1fr}
  .value-grid{grid-template-columns:1fr}
}
@media (max-width: 760px){
  .container{width:min(100% - 32px, 1200px)}
  .nav{height:auto; padding:12px 0; flex-wrap:wrap}
  .nav-center{order:3; width:100%; justify-content:center; flex-wrap:wrap; gap:20px}
  .hero .container,.page-hero .container{min-height:auto; padding:72px 0}
  .hero-title{font-size:52px}
  .section-title,.cta-title,.page-hero-title,.help-title{font-size:42px}
  .section-head,.practice-grid,.check-grid,.feature-grid,.form-grid{grid-template-columns:1fr}
  .cta-band{padding:68px 0}
}


/* v2 adjustments requested by user */
.feature-grid{
  align-items:stretch;
}
.feature-card{
  min-height:255px;
  display:flex;
}
.feature-content{
  position:absolute;
  inset:auto 18px 18px 18px;
}
.feature-title{
  font-size:22px;
  line-height:1.15;
  min-height:52px;
}
.feature-desc{
  font-size:15px;
  line-height:1.5;
  min-height:68px;
}
.map-image.user-map{
  background-image:url('/assets/map-brampton.png');
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}
