/* === RESET & BASE === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Georgia',Georgia,'Times New Roman',serif;font-size:16px;line-height:1.7;color:#1e1a17;background:#faf7f2;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}

/* === TYPOGRAPHY === */
h1,h2,h3{font-family:'Georgia',Georgia,'Times New Roman',serif;font-weight:400;line-height:1.2;color:#1c1528}
h1{font-size:clamp(2rem,5vw,3.5rem);letter-spacing:-0.02em}
h2{font-size:clamp(1.5rem,3.5vw,2.25rem);margin-bottom:1.25rem;letter-spacing:-0.01em}
h3{font-size:clamp(1.125rem,2vw,1.375rem);margin-bottom:0.75rem}
p{margin-bottom:1rem}
p:last-child{margin-bottom:0}

/* === LAYOUT === */
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1.5rem}
.section{padding:5rem 0}
.section--alt{background:#f0ebe1}
.section--dark{background:#1c1528;color:#faf7f2}
.section--dark h2,.section--dark h3,.section--dark .section-subtitle{color:#c9a35a}
.section--dark p,.section--dark li{color:rgba(250,247,242,0.85)}
.section--dark a:not(.cta-btn):hover{color:#c9a35a}
.section-subtitle{font-family:system-ui,-apple-system,sans-serif;font-size:0.875rem;text-transform:uppercase;letter-spacing:0.12em;color:#bc6c5a;margin-bottom:0.5rem}
.content-block{max-width:780px;margin:0 auto}
.content-block p,.content-block ul,.content-block ol{margin-bottom:1rem}
.content-block ul,.content-block ol{padding-left:1.5rem}
.content-block li{margin-bottom:0.5rem}
.content-block a:not(.cta-btn){color:#8b2252;text-decoration:underline;text-underline-offset:2px}
.content-block a:not(.cta-btn):hover{color:#6a1a40}

/* === HEADER === */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(28,21,40,0.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(201,163,90,0.15);transition:background 0.3s}
.site-header .container{display:flex;align-items:center;justify-content:space-between;height:68px}
.header-brand{font-family:'Georgia',Georgia,serif;font-size:1.25rem;color:#faf7f2;font-weight:400;letter-spacing:0.02em;white-space:nowrap}
.header-brand span{color:#c9a35a}
.nav-main{display:flex;align-items:center;gap:2rem}
.nav-main a{font-family:system-ui,-apple-system,sans-serif;font-size:0.875rem;color:rgba(250,247,242,0.8);letter-spacing:0.02em;transition:color 0.2s}
.nav-main a:hover{color:#c9a35a}
.nav-main .cta-btn{padding:0.5rem 1.25rem;font-size:0.8rem;margin-left:0.5rem}
.nav-mobile{display:none}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px;z-index:101}
.hamburger span{display:block;width:24px;height:2px;background:#faf7f2;transition:all 0.3s}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

@media(max-width:1024px){
  .nav-main{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(28,21,40,0.98);flex-direction:column;justify-content:center;align-items:center;gap:2rem;z-index:100}
  .nav-main.active{display:flex}
  .nav-main a{font-size:1.125rem}
  .nav-mobile{display:block}
  .hamburger{display:flex}
}

/* === HERO === */
.hero{position:relative;display:flex;align-items:center;justify-content:center;min-height:100svh;background-size:cover;background-position:center;background-repeat:no-repeat;text-align:center;padding:6rem 1.5rem;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(28,21,40,0.65) 0%,rgba(28,21,40,0.55) 50%,rgba(28,21,40,0.7) 100%);z-index:1}
.hero--home{background-image:url('/assets/images/hero-home.webp');background-color:#1c1528}
.hero--toronto{background-image:url('/assets/images/hero-toronto.webp');background-color:#1c1528}
.hero--vancouver{background-image:url('/assets/images/hero-vancouver.webp');background-color:#1c1528}
.hero--montreal{background-image:url('/assets/images/hero-montreal.webp');background-color:#1c1528}
.hero--calgary{background-image:url('/assets/images/hero-calgary.webp');background-color:#1c1528}
.hero--ottawa{background-image:url('/assets/images/hero-ottawa.webp');background-color:#1c1528}
.hero--edmonton{background-image:url('/assets/images/hero-edmonton.webp');background-color:#1c1528}
.hero--winnipeg{background-image:url('/assets/images/hero-winnipeg.webp');background-color:#1c1528}
.hero--mature{background-image:url('/assets/images/hero-topic-1.webp');background-color:#1c1528}
.hero--older{background-image:url('/assets/images/hero-topic-2.webp');background-color:#1c1528}
.hero--chat{background-image:url('/assets/images/hero-topic-3.webp');background-color:#1c1528}
.hero__content{position:relative;z-index:2;max-width:700px}
.hero__content h1{color:#faf7f2;margin-bottom:2rem}
.hero__content .cta-btn{margin-top:0.5rem}

/* === PAGE HEADER (legal pages, no image) === */
.page-header{background:#1c1528;padding:8rem 0 4rem;text-align:center}
.page-header h1{color:#faf7f2}
.page-header .container{max-width:780px}

/* === CTA BUTTON === */
.cta-btn{display:inline-block;padding:0.9rem 2.5rem;background:linear-gradient(135deg,#8b2252,#7a1d47);color:#fff;font-family:system-ui,-apple-system,sans-serif;font-size:1rem;font-weight:600;letter-spacing:0.04em;text-transform:uppercase;border:none;border-radius:4px;cursor:pointer;transition:all 0.3s;box-shadow:0 2px 12px rgba(139,34,82,0.35)}
.cta-btn:hover{background:linear-gradient(135deg,#a62961,#8b2252);transform:translateY(-1px);box-shadow:0 4px 20px rgba(139,34,82,0.45);color:#fff}
.cta-btn--outline{background:transparent;border:2px solid #c9a35a;box-shadow:none}
.cta-btn--outline:hover{background:rgba(201,163,90,0.1);transform:translateY(-1px);box-shadow:0 4px 16px rgba(201,163,90,0.2);color:#fff}
.cta-section{text-align:center;padding:3rem 0}
.cta-section h2{margin-bottom:1.5rem}

/* === CARDS === */
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin:2.5rem 0}
.card{background:#fff;border:1px solid rgba(28,21,40,0.08);border-radius:6px;padding:2rem;transition:box-shadow 0.3s,transform 0.3s}
.card:hover{box-shadow:0 8px 30px rgba(28,21,40,0.1);transform:translateY(-2px)}
.card h3{font-size:1.25rem;margin-bottom:0.75rem}
.card h3 a{color:#1c1528;transition:color 0.2s}
.card h3 a:hover{color:#8b2252}
.card p{font-size:0.95rem;color:#5c5347;line-height:1.6}
.card--featured{border-left:3px solid #c9a35a}
.card--dark{background:#2a1f3a;border-color:rgba(201,163,90,0.15)}
.card--dark h3,.card--dark h3 a{color:#c9a35a}
.card--dark p{color:rgba(250,247,242,0.8)}

/* === CITY LINKS GRID === */
.city-links{list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:0.75rem;padding:0;margin:2rem 0}
.city-links li{padding:0.875rem 1.25rem;background:#fff;border:1px solid rgba(28,21,40,0.06);border-radius:4px;transition:all 0.25s}
.city-links li:hover{background:#faf7f2;border-color:#c9a35a;transform:translateX(4px)}
.city-links a{display:block;font-family:system-ui,-apple-system,sans-serif;font-size:0.95rem;color:#1c1528}
.city-links a:hover{color:#8b2252}
.city-links--dark li{background:#2a1f3a;border-color:rgba(201,163,90,0.1)}
.city-links--dark li:hover{background:rgba(201,163,90,0.08);border-color:#c9a35a}
.city-links--dark a{color:rgba(250,247,242,0.85)}
.city-links--dark a:hover{color:#c9a35a}

/* === FAQ === */
.faq{max-width:780px;margin:0 auto}
.faq-item{margin-bottom:1.5rem;background:#fff;border:1px solid rgba(28,21,40,0.06);border-radius:6px;overflow:hidden}
.faq-item h3{padding:1.25rem 1.5rem;margin:0;font-size:1.05rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;user-select:none;transition:color 0.2s}
.faq-item h3::after{content:'+';font-size:1.4rem;color:#bc6c5a;transition:transform 0.3s}
.faq-item.open h3::after{content:'\2212';transform:rotate(180deg)}
.faq-item p,.faq-item .faq-answer{padding:0 1.5rem 1.25rem;margin:0;font-size:0.95rem;color:#5c5347;line-height:1.65}
.faq-item--dark{background:#2a1f3a;border-color:rgba(201,163,90,0.1)}
.faq-item--dark h3{color:#c9a35a}
.faq-item--dark p,.faq-item--dark .faq-answer{color:rgba(250,247,242,0.8)}

/* === FOOTER === */
.site-footer{background:#1c1528;color:rgba(250,247,242,0.75);padding:4rem 0 2.5rem;border-top:3px solid #c9a35a}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:3rem;margin-bottom:2.5rem}
.footer-brand-name{font-family:'Georgia',Georgia,serif;font-size:1.35rem;color:#faf7f2;margin-bottom:0.75rem}
.footer-brand-name span{color:#c9a35a}
.footer-desc{font-size:0.9rem;line-height:1.65}
.footer-heading{font-family:system-ui,-apple-system,sans-serif;font-size:0.8rem;text-transform:uppercase;letter-spacing:0.1em;color:#c9a35a;margin-bottom:1rem}
.footer-links{list-style:none;padding:0}
.footer-links li{margin-bottom:0.5rem}
.footer-links a{font-size:0.9rem;transition:color 0.2s}
.footer-links a:hover{color:#c9a35a}
.footer-bottom{border-top:1px solid rgba(201,163,90,0.12);padding-top:1.5rem;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem}
.footer-legal{display:flex;gap:1.5rem;font-size:0.85rem}
.footer-legal a:hover{color:#c9a35a}
.footer-age{font-size:0.8rem;font-family:system-ui,-apple-system,sans-serif;color:rgba(250,247,242,0.5);text-transform:uppercase;letter-spacing:0.06em}

@media(max-width:768px){
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .footer-bottom{flex-direction:column;text-align:center}
}

/* === RESPONSIVE === */
@media(max-width:768px){
  .section{padding:3rem 0}
  .hero{padding:5rem 1.25rem}
  .hero__content h1{font-size:clamp(1.6rem,6vw,2.5rem)}
  .card-grid{grid-template-columns:1fr}
  .city-links{grid-template-columns:1fr}
  .content-block{padding:0}
  .cta-btn{padding:0.8rem 2rem;font-size:0.95rem}
}

@media(max-width:480px){
  .container{padding:0 1rem}
  .hero{padding:4.5rem 1rem;min-height:100svh}
  .hero__content h1{font-size:1.5rem;margin-bottom:1.5rem}
  .section{padding:2.5rem 0}
  .card{padding:1.25rem}
  .faq-item h3{padding:1rem 1.25rem;font-size:0.95rem}
  .faq-item p{padding:0 1.25rem 1rem}
}

/* === UTILITIES === */
.text-center{text-align:center}
.mt-1{margin-top:1rem}
.mt-2{margin-top:2rem}
.mt-3{margin-top:3rem}
.mb-1{margin-bottom:1rem}
.mb-2{margin-bottom:2rem}
.mb-3{margin-bottom:3rem}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* === INTERNAL LINK CARDS === */
.internal-links-section .card h3{font-size:1.15rem}
.internal-links-section .card p{font-size:0.9rem}

/* === SECTION ACCENT === */
.section-accent{border-top:2px solid #c9a35a}

/* === NO-HERO PAGES === */
.page-body{background:#fff;min-height:60vh}
.page-body .section:first-child{padding-top:6rem}
