/*
Theme Name: Larry Borins Psychotherapist
Theme URI: https://larryborins.com
Author: Larry Borins
Author URI: https://larryborins.com
Description: Custom therapy practice website for Larry Borins, MSW, RSW, Registered Psychotherapist, Midtown Toronto
Version: 1.2
License: GNU General Public License v2 or later
Text Domain: larry-borins
*/


*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --gold:#C97B2E;
  --cream:#F9F6F1;
  --charcoal:#1C1C1A;
  --warm-grey:#6B6560;
  --rule:#D4C4A8;
  --serif:'EB Garamond',Georgia,serif;
  --sans:'Inter',system-ui,sans-serif;
  /* Type scale */
  --text-xs:.8rem;     /* labels, eyebrows */
  --text-sm:1rem;      /* body text */
  --text-md:1.05rem;   /* slightly larger body */
  --text-lg:1.2rem;    /* pullquotes, intro italic */
}
html{font-size:var(--text-sm)}
body{background:#FFFFFF;color:var(--charcoal);font-family:var(--sans);font-weight:400;line-height:1.7;min-height:100vh}
nav{position:fixed;top:0;left:0;right:0;z-index:100;background:#FFFFFF;border-bottom:1px solid #D4C4A8}
.nav-inner{max-width:1080px;margin:0 auto;padding:0 1.25rem;height:64px;display:flex;align-items:center;justify-content:space-between}
.site-name{font-family:var(--serif);font-size:var(--text-md);font-weight:500;letter-spacing:.01em;cursor:pointer;color:var(--charcoal);display:flex;flex-direction:column;justify-content:center;gap:3px}
.nav-name-row{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.nav-badge{font-family:var(--sans);font-size:.6rem;letter-spacing:.06em;text-transform:uppercase;color:#4a7c59;background:#edf5f0;border:1px solid #c3dbc9;padding:.1rem .45rem;white-space:nowrap}
.hamburger{background:none;border:none;cursor:pointer;display:flex;flex-direction:column;gap:5px;padding:4px}
.hamburger span{display:block;width:22px;height:1.5px;background:var(--charcoal);transition:transform .25s,opacity .25s}
.hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.menu-overlay{position:fixed;inset:0;background:#1C1C1A;z-index:99;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:1.75rem;opacity:0;pointer-events:none;transition:opacity .3s;overflow-y:auto;padding:5rem 2rem 3rem;box-sizing:border-box}
.menu-overlay.open{opacity:1;pointer-events:all}
.menu-overlay a{font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-style:italic;font-weight:300;color:#fff;text-decoration:none;transition:color .2s;cursor:pointer;letter-spacing:.02em}
.menu-overlay a:hover{color:var(--gold)}
.gold-rule-sm{width:40px;height:1px;background:#C97B2E;margin:0 auto}
.gold-rule{width:60px;height:1.5px;background:var(--gold);margin:1.5rem auto}
.page{display:none;padding-top:calc(64px + env(safe-area-inset-top));min-height:100vh;background:#FFFFFF}
.page.active{display:block}
.hero{max-width:720px;margin:0 auto;padding:5rem 1.5rem 4rem;text-align:center}
.hero-eyebrow{font-family:var(--sans);font-size:var(--text-xs);letter-spacing:.15em;text-transform:uppercase;color:var(--warm-grey);margin-bottom:1.5rem}
.hero-name{font-family:var(--serif);font-size:clamp(2.4rem,5vw,3.8rem);font-weight:400;line-height:1.15;margin-bottom:.25rem}
.hero-title{font-family:var(--serif);font-style:italic;font-size:var(--text-lg);color:var(--warm-grey);margin-bottom:2.5rem}
.hero-start{font-family:var(--serif);font-style:italic;font-size:1.4rem;color:var(--warm-grey);margin-bottom:3rem}
.hero-tagline{font-family:var(--serif);font-size:2.5rem;line-height:1.3;margin-bottom:1rem}
.hero-sub{font-family:var(--sans);font-size:var(--text-sm);color:var(--charcoal);line-height:1.7;max-width:520px;margin:0 auto 1.25rem}
.cta-row{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2rem}
.btn-primary{background:var(--charcoal);color:#F9F6F1;font-family:var(--sans);font-size:var(--text-sm);letter-spacing:.08em;text-transform:uppercase;padding:.75rem 2rem;border:none;cursor:pointer;transition:background .2s}
.btn-primary:hover{background:#444}
.btn-ghost{background:none;color:var(--charcoal);font-family:var(--sans);font-size:var(--text-sm);letter-spacing:.08em;text-transform:uppercase;padding:.75rem 2rem;border:1px solid var(--charcoal);cursor:pointer;transition:all .2s}
.btn-ghost:hover{background:var(--charcoal);color:#F9F6F1}
.split-section{max-width:1080px;margin:0 auto;padding:5rem 2rem;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.split-section.reverse .split-text{order:2}
.split-section.reverse .split-img{aspect-ratio:4/5;overflow:hidden;position:relative}
.split-img{aspect-ratio:4/5;overflow:hidden;position:relative}
.split-img img{width:100%;height:100%;object-fit:cover;object-position:center 40%;display:block}
.split-img.img-b img{object-fit:cover;object-position:center center}
.section-label{font-family:var(--sans);font-size:var(--text-xs);letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem}
.section-heading{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.4rem);font-weight:400;line-height:1.25;margin-bottom:1.25rem}
.section-body{font-family:var(--sans);font-size:var(--text-sm);color:var(--warm-grey);line-height:1.9;margin-bottom:1.75rem}
.text-link{font-family:var(--sans);font-size:var(--text-sm);letter-spacing:.1em;text-transform:uppercase;color:var(--charcoal);text-decoration:none;border-bottom:1px solid var(--charcoal);padding-bottom:2px;cursor:pointer;background:none;border-left:none;border-top:none;border-right:none}
.text-link:hover{color:var(--gold);border-color:var(--gold)}
.section-divider{max-width:1080px;margin:0 auto;padding:0 2rem}
.section-divider hr{border:none;border-top:1px solid var(--rule)}
.pullquote-section{max-width:720px;margin:4rem auto;padding:4rem 2rem;text-align:center}
.pullquote{font-family:var(--serif);font-style:italic;font-size:clamp(1.3rem,2.5vw,1.8rem);line-height:1.55;color:var(--charcoal);margin-bottom:1.5rem}
.pullquote-attr{font-family:var(--sans);font-size:var(--text-xs);letter-spacing:.12em;text-transform:uppercase;color:var(--warm-grey)}
.approach-section{background:#F7F3ED;padding:5rem 2rem}
.approach-inner{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}
.modality-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:2rem}
.modality{border-top:1px solid var(--rule);padding-top:1rem}
.modality-abbr{font-family:var(--serif);font-size:var(--text-lg);font-weight:500;color:var(--gold);margin-bottom:.25rem}
.modality-name{font-family:var(--sans);font-size:var(--text-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--charcoal);margin-bottom:.5rem}
.modality-desc{font-family:var(--sans);font-size:var(--text-sm);color:var(--warm-grey);line-height:1.7}
.inner-hero{max-width:720px;margin:0 auto;padding:5rem 2rem 3rem;border-bottom:1px solid var(--rule)}
.inner-hero h1{font-family:var(--serif);font-size:clamp(2rem,4vw,3rem);font-weight:400;line-height:1.2;margin-bottom:1rem}
.inner-hero p{font-family:var(--serif);font-style:italic;font-size:var(--text-lg);color:var(--warm-grey);line-height:1.7}
.inner-content{max-width:720px;margin:0 auto;padding:3rem 2rem 6rem}
.inner-content h2{font-family:var(--serif);font-size:1.6rem;font-weight:400;margin:2.5rem 0 .75rem}
.inner-content p{font-family:var(--sans);font-size:var(--text-sm);color:var(--warm-grey);line-height:1.9;margin-bottom:1.25rem}
.inner-content ul{font-family:var(--sans);font-size:var(--text-sm);color:var(--warm-grey);line-height:1.9;padding-left:1.5rem;margin-bottom:1.25rem}
.inner-content li{margin-bottom:.4rem}
.cred-strip{display:flex;flex-wrap:wrap;gap:.5rem 1.5rem;margin:2rem 0}
.cred{font-family:var(--sans);font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--warm-grey);padding-right:1.5rem;border-right:1px solid var(--rule)}
.cred:last-child{border-right:none}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;max-width:1080px;margin:0 auto;padding:4rem 2rem 6rem}
.contact-detail{font-family:var(--sans);font-size:var(--text-sm);color:var(--warm-grey);line-height:2}
.contact-detail strong{color:var(--charcoal);font-weight:500}
.contact-detail a{color:var(--charcoal)}
.contact-form label{display:block;font-family:var(--sans);font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--charcoal);margin-bottom:.4rem;margin-top:1.25rem}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;font-family:var(--sans);font-size:var(--text-sm);background:transparent;border:none;border-bottom:1px solid var(--charcoal);padding:.5rem 0;color:var(--charcoal);outline:none}
.contact-form input:focus,.contact-form textarea:focus{border-color:var(--gold)}
.contact-form textarea{resize:vertical;min-height:120px}
footer{background:var(--charcoal);color:#F9F6F1;padding:3rem 2rem}
.footer-inner{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr 1fr;gap:2rem;align-items:start}
.footer-name{font-family:var(--serif);font-size:var(--text-lg);margin-bottom:.5rem}
.footer-sub{font-family:var(--sans);font-size:var(--text-xs);color:var(--warm-grey);line-height:1.8}
.footer-col-label{font-family:var(--sans);font-size:var(--text-xs);letter-spacing:.15em;text-transform:uppercase;color:#C97B2E;margin-bottom:.75rem}
.footer-links{list-style:none}
.footer-links li{margin-bottom:.35rem}
.footer-links button{background:none;border:none;font-family:var(--sans);font-size:var(--text-sm);color:#e0e0e0;cursor:pointer;padding:0;text-align:left}
.footer-links button:hover{color:#ffffff}
.footer-bottom{max-width:1080px;margin:2rem auto 0;padding-top:1.5rem;border-top:1px solid #333;font-family:var(--sans);font-size:var(--text-xs);color:var(--warm-grey);display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem}
@media(max-width:680px){
  .split-section{grid-template-columns:1fr;gap:2.5rem}
  .split-section.reverse .split-text,.split-section.reverse .split-img{order:unset}
  .approach-inner{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .modality-grid{grid-template-columns:1fr}
}

.about-hero{max-width:1080px;margin:0 auto;padding:5rem 2rem 3rem;display:grid;grid-template-columns:1fr 420px;gap:5rem;align-items:center;border-bottom:1px solid var(--rule)}
.about-hero-img{overflow:hidden;border-radius:2px}
.about-hero-img img{width:100%;display:block;object-fit:cover}
@media(max-width:780px){.about-hero{grid-template-columns:1fr;gap:2.5rem;padding:3rem 2rem 2rem}.about-hero-img{max-width:320px}}

.hero-bg{
  background-image: linear-gradient(to bottom, rgba(10,10,8,0.62) 0%, rgba(10,10,8,0.48) 45%, rgba(10,10,8,0.68) 100%), url("images/hero-forest.jpg");
  background-size: cover;
  background-position: right top;
  background-repeat: no-repeat;
  max-width: 100%;
  padding: 9rem 2rem 8rem;
}
.hero-bg .hero-eyebrow{color:#ffffff;text-shadow:0 1px 10px rgba(0,0,0,0.6)}
.hero-bg .hero-name{color:#fff;text-shadow:0 2px 16px rgba(0,0,0,0.55)}
.hero-bg .hero-title{color:rgba(255,255,255,0.85);text-shadow:0 1px 8px rgba(0,0,0,0.45)}
.hero-bg .hero-start{color:#ffffff;text-shadow:0 1px 10px rgba(0,0,0,0.5)}
.hero-bg .hero-tagline{color:#fff;text-shadow:0 1px 12px rgba(0,0,0,0.5)}
.hero-bg .hero-sub{color:rgba(255,255,255,0.9);text-shadow:0 1px 6px rgba(0,0,0,0.4)}
.hero-bg .gold-rule{background:rgba(184,150,46,0.9)}
.hero-bg .btn-primary{background:#fff;color:var(--charcoal)}
.hero-bg .btn-primary:hover{background:rgba(255,255,255,0.88)}
.hero-bg .btn-ghost{border-color:rgba(255,255,255,0.7);color:#fff}
.hero-bg .btn-ghost:hover{background:rgba(255,255,255,0.15);color:#fff}

.nav-name-bold{font-family:var(--serif);font-size:1.75rem;font-weight:500;color:var(--gold);letter-spacing:.1em;text-transform:uppercase;line-height:1}
.nav-name-creds{font-family:var(--sans);font-size:var(--text-xs);font-weight:400;color:var(--warm-grey);letter-spacing:.02em;line-height:1;white-space:nowrap}

.btn-amber{background:#C97B2E;color:#fff;font-family:var(--sans);font-size:var(--text-sm);letter-spacing:.08em;text-transform:uppercase;padding:.75rem 2rem;border:none;cursor:pointer;transition:background .2s}
.btn-amber:hover{background:#A8611E}

@media(max-width:480px){
  .hero-bg{padding:3.5rem 1.25rem 2.5rem !important;background-position:right top !important}
  .hero-tagline{font-size:1.5rem !important;line-height:1.3 !important}
  .hero-sub{font-size:.9rem !important;margin-bottom:.75rem !important}
  .hero-eyebrow{margin-bottom:1rem !important}
  .gold-rule{margin-top:0 !important;margin-bottom:.75rem !important}
  .hero-tagline{font-size:1.3rem}
  .hero-sub{font-size:.95rem}
  .nav-inner{padding:0 1rem}
  .site-name .nav-name-bold{font-family:var(--serif);font-size:1.75rem;font-weight:500;color:var(--gold);letter-spacing:.1em;text-transform:uppercase;line-height:1}
  .nav-name-creds{font-family:var(--sans);font-size:var(--text-xs);font-weight:400;color:var(--warm-grey);letter-spacing:.02em;line-height:1;white-space:nowrap}
}

.split-img.img-b{aspect-ratio:700/321;background:none}
.split-img.img-b img{object-fit:cover !important;object-position:center center !important}

.meet-larry-grid{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.meet-larry-photo{border-radius:2px;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,0.12)}
@media(max-width:768px){
  .meet-larry-grid{grid-template-columns:1fr;gap:2.5rem}
  .meet-larry-photo{order:-1;max-width:320px;margin:0 auto;width:100%}
}

.menu-services-group{display:flex;flex-direction:column;align-items:center;gap:0.5rem}
.menu-services-toggle{cursor:pointer}
.menu-services-sub{display:none;flex-direction:column;align-items:center;gap:0.75rem;margin-top:0.5rem}
.menu-services-sub.open{display:flex}
.menu-services-sub a{font-size:1.6rem !important}

@media(max-width:600px){
  .contact-name-grid{grid-template-columns:1fr !important}
}

@media(max-width:768px){
  .how-it-works-grid{grid-template-columns:1fr !important}
}

.how-steps{display:flex;flex-direction:column;gap:1rem}
.how-step{display:flex;align-items:flex-start;gap:1rem;text-align:left}
.how-icon{width:36px;height:36px;flex-shrink:0;color:var(--gold);padding-top:2px}
.how-icon svg{width:100%;height:100%}
.how-title{font-family:var(--sans);font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--charcoal);margin-bottom:.25rem;font-weight:600}
.how-body{font-family:var(--sans);font-size:var(--text-sm);color:var(--warm-grey);line-height:1.6;margin:0}
@media(min-width:640px){
  .how-steps{flex-direction:row;gap:2rem}
  .how-step{flex-direction:column;align-items:center;text-align:center;flex:1}
  .how-icon{width:40px;height:40px;padding-top:0}
}
.split-img-wrap{display:flex;flex-direction:column}

@media(max-width:480px){
  .nav-name-bold{font-size:1.1rem;letter-spacing:.05em}
  .nav-name-creds{font-size:.65rem}
  .nav-badge{font-size:.55rem;padding:.08rem .35rem}
}
