/* ===========================================================
   McReynolds Physical Therapy - shared styles
   Palette matches the brand logo: blue primary + lime-green accent
   on a soft cool paper. Variable names kept for stability, so the
   tokens below named "green/honey" now hold the brand blue/green.
   Signature: arc of dots, echoing the logo mark.
   Built for older readers: large type, high contrast, big tap targets.
   =========================================================== */

:root{
  --paper:#F6F9FB;
  --surface:#FFFFFF;
  --sage:#E9F2F8;          /* light blue tint (was sage) */
  --sage-line:#D2E4EF;
  --ink:#15242C;
  --ink-soft:#45565F;
  --green:#135A82;         /* PRIMARY brand blue: buttons, links, headings, icons */
  --green-900:#0C3247;     /* deepest blue: dark bands */
  --green-700:#0F3F5C;     /* footer blue */
  --green-500:#1670A0;     /* hover / eyebrow blue */
  --bright:#2C9CD6;        /* logo bright blue, decorative */
  --honey:#7FB539;         /* ACCENT lime-green, decorative only */
  --honey-deep:#4E7A1E;    /* green for small text when needed */
  --stone:#E0E7EC;
  --shadow-sm:0 1px 2px rgba(18,40,55,.06), 0 2px 8px rgba(18,40,55,.05);
  --shadow-md:0 6px 22px rgba(18,40,55,.10), 0 2px 6px rgba(18,40,55,.06);
  --radius:14px;
  --display:'Fraunces', Georgia, 'Times New Roman', serif;
  --body:'Hanken Grotesk', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --maxw:1140px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--body); font-size:1.125rem; line-height:1.65;
  font-optical-sizing:auto; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
h1,h2,h3{font-family:var(--display); font-weight:500; line-height:1.12; margin:0;}
p{margin:0 0 1rem;}
a{color:var(--green);}
img{max-width:100%; display:block;}

.wrap{max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(1.1rem,4vw,2.5rem);}
.section{padding-block:clamp(3.4rem,7vw,6rem);}
.section--sage{background:var(--sage); border-block:1px solid var(--sage-line);}
.section--green{background:var(--green-900); color:#EAF3F8;}
.narrow{max-width:760px;}

.eyebrow{
  font-family:var(--body); text-transform:uppercase; letter-spacing:.16em;
  font-size:.78rem; font-weight:700; color:var(--green-500); margin:0 0 .85rem;
  display:flex; align-items:center; gap:.6rem;
}
.eyebrow::before{content:""; width:26px; height:2px; background:var(--honey); border-radius:2px; flex:none;}
.section--green .eyebrow{color:#A9D58C;}

.section-title{font-size:clamp(1.85rem,4.4vw,2.7rem); max-width:20ch; margin-bottom:.6rem;}
.lede{font-size:1.18rem; color:var(--ink-soft); max-width:62ch;}
.section--green .lede{color:#C7D8E2;}

/* ---------- Skip link ---------- */
.skip{position:absolute; left:-999px; top:0; background:var(--green); color:#fff; padding:.7rem 1.1rem; border-radius:0 0 10px 0; z-index:200;}
.skip:focus{left:0;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  font-family:var(--body); font-weight:600; font-size:1.05rem;
  min-height:54px; padding:.7rem 1.35rem; border-radius:11px; border:1.5px solid transparent;
  text-decoration:none; cursor:pointer; transition:transform .12s ease, background .15s ease, border-color .15s ease;
}
.btn:active{transform:translateY(1px);}
.btn-call{background:var(--green); color:#fff;}
.btn-call:hover{background:var(--green-500);}
.btn-ghost{background:transparent; color:var(--green); border-color:var(--stone);}
.btn-ghost:hover{border-color:var(--green); background:#fff;}
.section--green .btn-ghost{color:#fff; border-color:rgba(255,255,255,.4);}
.section--green .btn-ghost:hover{border-color:#fff; background:rgba(255,255,255,.08);}
.btn-fb{background:#fff; color:var(--green); border-color:var(--stone);}
.btn-fb:hover{border-color:var(--green);}
.btn svg{flex:none;}
:focus-visible{outline:3px solid var(--honey); outline-offset:2px; border-radius:6px;}

/* ---------- Header ---------- */
.site-header{position:sticky; top:0; z-index:100; background:rgba(251,250,246,.92); backdrop-filter:blur(8px); border-bottom:1px solid var(--stone);}
.header-row{display:flex; align-items:center; justify-content:space-between; gap:1rem; min-height:74px;}
.brand{display:flex; align-items:center; gap:.7rem; text-decoration:none; color:var(--ink);}
.brand .mark{width:50px; height:32px; flex:none;}
.brand b{font-family:var(--display); font-weight:600; font-size:1.16rem; line-height:1.05; color:var(--green);}
.brand .brand-text span{display:block; font-family:var(--body); font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:var(--honey-deep); font-weight:700;}

.nav{display:flex; align-items:center; gap:.4rem;}
.nav-desktop{display:flex; align-items:center; gap:.25rem;}
.nav a.navlink{text-decoration:none; color:var(--ink); font-weight:600; font-size:1.02rem; padding:.55rem .8rem; border-radius:8px; border-bottom:2px solid transparent;}
.nav a.navlink:hover{background:var(--sage); color:var(--green);}
.nav a.navlink[aria-current="page"]{color:var(--green); border-bottom-color:var(--honey);}
.nav .btn{min-height:46px; padding:.5rem 1.05rem; font-size:1rem; margin-left:.4rem;}

.mobile-menu{display:none;}
.nav-toggle{display:none; align-items:center; gap:.5rem; background:var(--green); color:#fff; border:0; border-radius:10px; font-family:var(--body); font-weight:600; font-size:1rem; padding:.6rem .95rem; min-height:46px; cursor:pointer;}

/* ---------- Home hero ---------- */
.hero{position:relative; overflow:hidden;}
.hero .wrap{position:relative; z-index:1;}
.hero-grid{display:grid; gap:2.4rem; padding-block:clamp(2.8rem,6vw,4.4rem) clamp(2.6rem,5vw,4rem); align-items:center;}
.hero-copy h1{font-size:clamp(2.35rem,6.2vw,4rem); font-weight:500; letter-spacing:-.01em; max-width:16ch;}
.hero-copy h1 em{font-style:normal; color:var(--green);}
.hero-sub{font-size:1.22rem; color:var(--ink-soft); max-width:54ch; margin-top:1.1rem;}
.hero-media{position:relative;}

.quickcall{margin-top:2rem;}
.qc-label{font-size:.82rem; text-transform:uppercase; letter-spacing:.13em; font-weight:700; color:var(--ink-soft); margin-bottom:.9rem;}
.qc-cards{display:grid; gap:1rem;}
.qc-card{background:var(--surface); border:1px solid var(--stone); border-radius:var(--radius); padding:1.15rem 1.25rem; box-shadow:var(--shadow-sm); display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap;}
.qc-town{font-family:var(--display); font-weight:600; font-size:1.3rem;}
.qc-town small{display:block; font-family:var(--body); font-size:.8rem; font-weight:600; letter-spacing:.04em; color:var(--honey-deep); text-transform:uppercase; margin-top:.15rem;}
.qc-phone{font-weight:700; font-size:1.18rem; color:var(--green); text-decoration:none; white-space:nowrap;}

/* ---------- Sub-page header ---------- */
.page-head{position:relative; overflow:hidden; background:var(--sage); border-bottom:1px solid var(--sage-line);}
.page-head .wrap{position:relative; z-index:1; padding-block:clamp(2.6rem,6vw,4.2rem);}
.page-head h1{font-size:clamp(2.1rem,5.4vw,3.3rem); max-width:18ch;}
.page-head .lede{margin-top:.9rem;}

/* ---------- Photo frames / slots ---------- */
.photo-frame{border-radius:var(--radius); overflow:hidden; background:var(--sage); box-shadow:var(--shadow-sm); border:1px solid var(--sage-line);}
.photo-frame img{width:100%; height:100%; object-fit:cover; display:block;}
.photo-slot{
  width:100%; height:100%; min-height:200px;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:.55rem;
  text-align:center; color:var(--ink-soft); padding:1.6rem;
  background:repeating-linear-gradient(135deg,#E9F2F8,#E9F2F8 14px,#DCEAF3 14px,#DCEAF3 28px);
}
.photo-slot svg{width:30px; height:30px; stroke:var(--green-500); fill:none; stroke-width:1.6;}
.photo-slot .ps-label{font-weight:600; color:var(--ink); font-size:1rem;}
.photo-slot .ps-dim{font-size:.85rem; color:var(--ink-soft);}

/* ---------- Cards / services ---------- */
.cards-grid{display:grid; gap:1.15rem; grid-template-columns:1fr; margin-top:2.4rem;}
.card{background:var(--surface); border:1px solid var(--stone); border-radius:var(--radius); padding:1.6rem 1.5rem; box-shadow:var(--shadow-sm); transition:transform .18s ease, box-shadow .18s ease;}
.card:hover{transform:translateY(-3px); box-shadow:var(--shadow-md);}
.ico{width:50px; height:50px; border-radius:13px; background:var(--sage); display:flex; align-items:center; justify-content:center; margin-bottom:1.05rem; border:1px solid var(--sage-line);}
.ico svg{width:26px; height:26px; stroke:var(--green); fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round;}
.card h3{font-size:1.28rem; font-weight:600; margin-bottom:.45rem;}
.card p{color:var(--ink-soft); margin:0; font-size:1.04rem;}

.note-box{margin-top:2rem; padding:1.15rem 1.35rem; background:var(--surface); border:1px dashed var(--sage-line); border-radius:var(--radius); color:var(--ink-soft); font-size:1.05rem; display:flex; gap:.85rem; align-items:flex-start;}
.note-box strong{color:var(--ink);}
.note-box svg{stroke:var(--green); fill:none; stroke-width:1.8; width:24px; height:24px; flex:none; margin-top:2px;}

/* service detail rows */
.svc-detail{display:grid; gap:1.2rem; margin-top:2.4rem;}
.svc-item{background:var(--surface); border:1px solid var(--stone); border-radius:var(--radius); box-shadow:var(--shadow-sm); padding:1.7rem; display:grid; gap:1rem; grid-template-columns:54px 1fr; align-items:start;}
.svc-item .ico{margin-bottom:0;}
.svc-item h3{font-size:1.35rem; font-weight:600; margin-bottom:.4rem;}
.svc-item p{margin:0; color:var(--ink-soft);}

/* ---------- About ---------- */
.about-grid{display:grid; gap:2.4rem; align-items:start;}
.about-card{background:var(--surface); border:1px solid var(--stone); border-radius:var(--radius); padding:1.5rem; box-shadow:var(--shadow-sm);}
.about-card h3{font-size:1.45rem; font-weight:600; margin:1.1rem 0 0;}
.credentials{list-style:none; padding:0; margin:.6rem 0 0; display:grid; gap:.55rem;}
.credentials li{display:flex; gap:.6rem; align-items:flex-start; color:var(--ink-soft); font-size:1.02rem;}
.credentials svg{width:20px; height:20px; stroke:var(--green); fill:none; stroke-width:2; flex:none; margin-top:3px;}
.values{display:grid; gap:1.1rem; margin-top:2.2rem;}
.value{display:flex; gap:.85rem; align-items:flex-start;}
.value svg{width:26px; height:26px; stroke:var(--green); fill:none; stroke-width:1.7; flex:none; margin-top:3px;}
.value h3{font-size:1.18rem; font-weight:600; margin-bottom:.25rem;}
.value p{margin:0; color:var(--ink-soft); font-size:1.03rem;}

/* ---------- Steps ---------- */
.steps{display:grid; gap:1.15rem; margin-top:2.4rem; grid-template-columns:1fr;}
.step{background:var(--surface); border:1px solid var(--stone); border-radius:var(--radius); padding:1.5rem; box-shadow:var(--shadow-sm);}
.step .num{font-family:var(--display); font-weight:600; font-size:1.5rem; color:#fff; width:46px; height:46px; border-radius:50%; background:var(--green); display:flex; align-items:center; justify-content:center; margin-bottom:.9rem;}
.step h3{font-size:1.22rem; font-weight:600; margin-bottom:.4rem;}
.step p{color:var(--ink-soft); margin:0; font-size:1.04rem;}

/* ---------- Social band ---------- */
.social-inner{display:grid; gap:1.6rem; align-items:center;}
.social-btns{display:flex; flex-wrap:wrap; gap:.9rem;}
.social .section-title{color:#fff;}

/* ---------- Locations ---------- */
.loc-grid{display:grid; gap:1.4rem; margin-top:2.4rem;}
.loc{background:var(--surface); border:1px solid var(--stone); border-radius:var(--radius); padding:1.5rem; box-shadow:var(--shadow-sm);}
.loc .photo-frame{margin-bottom:1.3rem;}
.loc-top{display:flex; align-items:center; justify-content:space-between; gap:.8rem; flex-wrap:wrap; margin-bottom:1.1rem;}
.loc h3{font-size:1.55rem; font-weight:600;}
.tag{font-family:var(--body); font-size:.72rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--honey-deep); background:#E7F2D9; border:1px solid #CDE4AE; padding:.3rem .6rem; border-radius:999px;}
.loc-row{display:flex; gap:.7rem; align-items:flex-start; margin-bottom:.85rem; color:var(--ink-soft); font-size:1.05rem;}
.loc-row svg{width:22px; height:22px; stroke:var(--green); fill:none; stroke-width:1.8; flex:none; margin-top:3px;}
.loc-row a{color:var(--green); font-weight:600; text-decoration:none;}
.loc-phone{font-size:1.45rem; font-weight:700;}
.loc-actions{display:flex; flex-wrap:wrap; gap:.8rem; margin-top:1.3rem;}

/* hours table */
.hours{width:100%; border-collapse:collapse; margin-top:.2rem;}
.hours th,.hours td{text-align:left; padding:.4rem 0; font-size:1.02rem; border-bottom:1px solid var(--sage-line);}
.hours th{font-weight:600; color:var(--ink); width:55%;}
.hours td{color:var(--ink-soft);}
.hours tr.closed td{color:#9a3b2f;}
.hours tr:last-child th,.hours tr:last-child td{border-bottom:0;}

/* ---------- Contact form ---------- */
.contact-grid{display:grid; gap:2.4rem; align-items:start;}
.form-card{background:var(--surface); border:1px solid var(--stone); border-radius:var(--radius); padding:1.7rem; box-shadow:var(--shadow-sm);}
.field{margin-bottom:1.1rem;}
.field label{display:block; font-weight:600; margin-bottom:.4rem; font-size:1rem;}
.field input,.field select,.field textarea{
  width:100%; font-family:var(--body); font-size:1.05rem; color:var(--ink);
  background:var(--paper); border:1.5px solid var(--stone); border-radius:10px; padding:.8rem .9rem; min-height:52px;
}
.field textarea{min-height:130px; resize:vertical;}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--green); outline:none; box-shadow:0 0 0 3px rgba(28,132,192,.18);}
.hp{position:absolute; left:-9999px;}
.form-foot{font-size:.92rem; color:var(--ink-soft); margin-top:.4rem;}

.contact-aside{display:grid; gap:1.2rem;}
.contact-block{background:var(--surface); border:1px solid var(--stone); border-radius:var(--radius); padding:1.4rem 1.5rem; box-shadow:var(--shadow-sm);}
.contact-block h3{font-size:1.2rem; font-weight:600; margin-bottom:.6rem;}
.contact-block .big-phone{font-size:1.5rem; font-weight:700; color:var(--green); text-decoration:none; display:inline-block; margin-bottom:.2rem;}

/* ---------- FAQ ---------- */
.faq{margin-top:2.2rem; display:grid; gap:.8rem;}
.faq details{background:var(--surface); border:1px solid var(--stone); border-radius:var(--radius); box-shadow:var(--shadow-sm); overflow:hidden;}
.faq summary{list-style:none; cursor:pointer; padding:1.15rem 1.4rem; font-weight:600; font-size:1.1rem; display:flex; align-items:center; justify-content:space-between; gap:1rem;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:"+"; font-family:var(--display); font-size:1.6rem; color:var(--green); line-height:1; flex:none;}
.faq details[open] summary::after{content:"\2013";}
.faq .faq-body{padding:0 1.4rem 1.3rem; color:var(--ink-soft);}
.faq .faq-body p{margin:0;}

/* ---------- Footer ---------- */
footer{background:var(--green-700); color:#C7D8E2; padding-block:clamp(2.6rem,5vw,3.6rem);}
.foot-grid{display:grid; gap:2rem;}
footer h4{font-family:var(--body); text-transform:uppercase; letter-spacing:.12em; font-size:.8rem; color:#9FB6C4; margin:0 0 .9rem;}
footer a{color:#EAF2F8; text-decoration:none;}
footer a:hover{text-decoration:underline;}
.foot-brand b{font-family:var(--display); font-weight:600; font-size:1.3rem; color:#fff; display:block; margin-bottom:.5rem;}
.foot-nav{display:grid; gap:.5rem;}
.foot-list{display:grid; gap:.5rem;}
.foot-bottom{border-top:1px solid rgba(255,255,255,.14); margin-top:2.2rem; padding-top:1.4rem; display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; font-size:.92rem; color:#9FB6C4;}

/* ---------- Reveal ---------- */
.reveal{opacity:0; transform:translateY(18px); transition:opacity .6s ease, transform .6s ease;}
.reveal.in-view{opacity:1; transform:none;}

/* ---------- Responsive ---------- */
@media (max-width:1040px){
  .nav-desktop{display:none;}
  .nav-toggle{display:inline-flex;}
  .nav{position:relative;}
  .mobile-menu{display:none; position:absolute; right:0; top:calc(100% + 12px); background:var(--surface); border:1px solid var(--stone); border-radius:14px; box-shadow:var(--shadow-md); padding:.6rem; min-width:240px; z-index:120;}
  .mobile-menu.open{display:grid; gap:.2rem;}
  .mobile-menu a{padding:.78rem .9rem; border-radius:9px; text-decoration:none; color:var(--ink); font-weight:600;}
  .mobile-menu a:hover,.mobile-menu a[aria-current="page"]{background:var(--sage); color:var(--green);}
  .mobile-menu .btn-call{margin-top:.35rem; color:#fff;}
}

@media (min-width:680px){
  .qc-cards{grid-template-columns:1fr 1fr;}
  .cards-grid{grid-template-columns:1fr 1fr;}
  .steps{grid-template-columns:1fr 1fr 1fr;}
  .loc-grid{grid-template-columns:1fr 1fr;}
  .foot-grid{grid-template-columns:1.5fr 1fr 1fr 1fr;}
  .contact-grid{grid-template-columns:1.4fr 1fr;}
}
@media (min-width:960px){
  .cards-grid{grid-template-columns:repeat(3,1fr);}
  .hero-grid{grid-template-columns:1.05fr .95fr;}
  .about-grid{grid-template-columns:360px 1fr;}
  .social-inner{grid-template-columns:1.5fr 1fr;}
}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  .reveal{opacity:1; transform:none; transition:none;}
  .card,.btn{transition:none;}
}

/* ---------- Trust strip (home) ---------- */
.trust{background:var(--green-900); color:#EAF3F8;}
.trust-row{display:grid; gap:1rem; padding-block:1.4rem; grid-template-columns:1fr;}
.trust-item{display:flex; align-items:center; gap:.7rem; font-size:1.05rem; color:#EAF3F8;}
.trust-item svg{width:26px; height:26px; flex:none; stroke:#7FB539; fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round;}
.trust-item strong{color:#fff; font-weight:700;}
@media (min-width:760px){ .trust-row{grid-template-columns:repeat(3,1fr); align-items:center;} }

/* ===========================================================
   2026 polish pass
   - Uses the clean McReynolds logo asset in the header/footer
   - Removes the thin arc line graphics that could read as scratches
   - Tightens spacing, cards, shadows, and mobile presentation
   =========================================================== */
:root{
  --paper:#F8FBFD;
  --surface:#FFFFFF;
  --sage:#EDF6FB;
  --sage-line:#D7E8F2;
  --ink:#102E44;
  --ink-soft:#4F6673;
  --green:#0F6F9F;
  --green-900:#0A3148;
  --green-700:#0D405C;
  --green-500:#1489C7;
  --bright:#2C9CD6;
  --honey:#7FB539;
  --honey-deep:#5F8E2A;
  --stone:#DCE8EF;
  --shadow-sm:0 1px 2px rgba(14,45,68,.05), 0 10px 26px rgba(14,45,68,.07);
  --shadow-md:0 18px 42px rgba(14,45,68,.12);
  --radius:18px;
}

.site-header{
  background:rgba(255,255,255,.96);
  border-bottom:1px solid rgba(15,111,159,.16);
  box-shadow:0 1px 0 rgba(255,255,255,.8), 0 10px 30px rgba(16,46,68,.04);
}
.header-row{min-height:86px;}
.brand{min-width:0; gap:0; flex:0 0 auto;}
.brand-logo{display:block; width:clamp(210px, 26vw, 315px); height:auto;}
.nav a.navlink{color:#203844;}
.nav a.navlink:hover{background:#EEF7FC; color:var(--green);}
.nav a.navlink[aria-current="page"]{border-bottom-color:var(--bright); color:var(--green);}
.nav .btn-call{background:var(--honey); color:#fff; box-shadow:0 7px 18px rgba(127,181,57,.22);}
.nav .btn-call:hover{background:#6EA02E;}

/* The old scratch-like arc decorations have been removed from the HTML. */
.hero{background:radial-gradient(circle at 8% 18%, rgba(44,156,214,.12), transparent 32%), linear-gradient(135deg,#FFFFFF 0%,#F3FAFD 100%);}
.hero::after,
.page-head::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 88% 20%, rgba(44,156,214,.10), transparent 25%),
    radial-gradient(circle at 70% 85%, rgba(127,181,57,.08), transparent 28%);
  z-index:0;
}
.hero .wrap,.page-head .wrap{position:relative; z-index:1;}
.hero-copy h1{font-family:var(--body); font-weight:800; letter-spacing:-.04em; color:var(--green-900);}
.hero-copy h1 em{color:var(--honey);}
.hero-sub{font-size:1.24rem; line-height:1.55;}
.eyebrow::before{display:none;}
.eyebrow{letter-spacing:.13em; color:var(--green-500);}

.btn{border-radius:999px; box-shadow:none;}
.btn-call{background:var(--green);}
.btn-call:hover{background:var(--green-500);}
.btn-ghost{background:#fff; border-color:var(--stone);}
.btn-ghost:hover{background:#F7FBFD;}

.qc-card,.card,.svc-item,.step,.loc,.form-card,.contact-block,.faq details,.about-card{
  border-color:rgba(15,111,159,.14);
  box-shadow:var(--shadow-sm);
}
.qc-card{border-top:4px solid rgba(44,156,214,.42);}
.qc-card:nth-child(2){border-top-color:rgba(127,181,57,.65);}
.qc-town{font-family:var(--body); font-weight:800; color:var(--green-900);}
.qc-phone{color:var(--green-500);}

.photo-frame{border-color:rgba(15,111,159,.16); background:#fff; box-shadow:var(--shadow-sm);}
.photo-slot{
  background:
    linear-gradient(135deg, rgba(255,255,255,.96), rgba(238,247,252,.96)),
    radial-gradient(circle at 22% 24%, rgba(44,156,214,.20), transparent 28%),
    radial-gradient(circle at 75% 75%, rgba(127,181,57,.14), transparent 30%);
  color:var(--ink-soft);
}
.photo-slot svg{stroke:var(--green-500);}

.card:hover,.svc-item:hover,.loc:hover{transform:translateY(-2px); box-shadow:var(--shadow-md);}
.ico{border-radius:999px; background:linear-gradient(135deg,#EAF6FC,#fff); border-color:rgba(44,156,214,.24);}
.card:nth-child(2n) .ico,.svc-item:nth-child(2n) .ico{background:linear-gradient(135deg,#EEF7E6,#fff); border-color:rgba(127,181,57,.25);}
.card h3,.svc-item h3,.step h3,.loc h3{font-family:var(--body); font-weight:800; color:var(--green-900);}

.trust{background:linear-gradient(135deg,var(--green-900),#0F5578);}
.trust-row{gap:1.1rem;}
.trust-item{background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.14); border-radius:16px; padding:1rem;}

.page-head{background:linear-gradient(135deg,#F6FBFD,#EAF6FC);}
.page-head h1{font-family:var(--body); font-weight:800; color:var(--green-900); letter-spacing:-.035em;}

.footer-logo{display:inline-flex; background:#fff; padding:.45rem .65rem; border-radius:12px; margin-bottom:1rem; box-shadow:0 10px 24px rgba(0,0,0,.12);}
.footer-logo img{width:min(245px, 70vw); height:auto;}
.foot-brand b{display:none;}
footer{background:linear-gradient(135deg,#0A3148,#0E4F75);}
.foot-bottom{border-top-color:rgba(255,255,255,.18);}

@media (max-width:860px){
  .header-row{min-height:76px;}
  .brand-logo{width:clamp(185px, 58vw, 255px);}
  .mobile-menu{right:0; top:calc(100% + 10px); min-width:min(280px, 86vw);}
  .mobile-menu .btn-call{background:var(--honey);}
}

@media (max-width:680px){
  body{font-size:1.06rem;}
  .wrap{padding-inline:1rem;}
  .hero-grid{padding-block:2.1rem 2.7rem; gap:1.7rem;}
  .hero-copy h1{font-size:clamp(2.35rem, 12vw, 3.25rem); max-width:12ch;}
  .hero-sub{font-size:1.08rem;}
  .quickcall{margin-top:1.45rem;}
  .qc-card{align-items:flex-start;}
  .section{padding-block:3rem;}
  .section-title{font-family:var(--body); font-weight:800; letter-spacing:-.025em;}
  .trust-item{padding:.9rem;}
  .footer-logo img{width:225px;}
}


/* ---------- Location photography ---------- */
.loc-grid{align-items:start;}
.loc-photo,
.loc-thumb{
  width:100%;
  overflow:hidden;
  background:#fff;
}
.loc-photo img,
.loc-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.loc-photo--brownsville img{object-position:center center;}
.loc-photo--albany img{object-position:center center;}
.loc-thumb{
  aspect-ratio:16/9;
  margin-bottom:1.25rem;
}
.loc-thumb--albany img{object-position:center 42%;}
@media (max-width:680px){
  .loc-photo--albany{aspect-ratio:4/5 !important;}
  .loc-thumb{aspect-ratio:16/10;}
}


/* ---------- No-portrait homepage panels ---------- */
.hero-panel{
  position:relative;
}
.hero-panel-card{
  background:rgba(255,255,255,.9);
  border:1px solid var(--stone);
  border-radius:calc(var(--radius) + 8px);
  box-shadow:var(--shadow-md);
  padding:clamp(1.4rem, 3vw, 2rem);
  backdrop-filter:blur(12px);
}
.hero-panel-card h2{
  font-family:var(--display);
  font-size:clamp(1.8rem, 3vw, 2.5rem);
  line-height:1.08;
  letter-spacing:-.03em;
  margin:.25rem 0 1.2rem;
}
.hero-panel-list{
  display:grid;
  gap:.9rem;
}
.hero-panel-list div{
  padding:1rem;
  border-radius:16px;
  background:var(--sage);
  border:1px solid var(--sage-line);
}
.hero-panel-list strong{
  display:block;
  color:var(--ink);
  margin-bottom:.25rem;
  font-weight:700;
}
.hero-panel-list span{
  color:var(--ink-soft);
  font-size:1rem;
}
.about-preview-card{
  display:grid;
  gap:1.5rem;
  align-items:start;
  background:linear-gradient(135deg,#fff 0%,#F3FAFD 58%,#EEF7E7 100%);
  border:1px solid var(--stone);
  border-radius:calc(var(--radius) + 10px);
  box-shadow:var(--shadow-sm);
  padding:clamp(1.6rem, 4vw, 2.4rem);
}
.about-preview-note{
  display:grid;
  gap:.8rem;
  padding:1.3rem;
  border-radius:var(--radius);
  background:#fff;
  border:1px solid var(--stone);
  box-shadow:var(--shadow-sm);
}
.about-preview-note strong{
  font-family:var(--display);
  font-size:1.35rem;
  line-height:1.12;
  color:var(--ink);
}
.about-preview-note span{
  color:var(--ink-soft);
}
@media (min-width:860px){
  .about-preview-card{
    grid-template-columns:minmax(0,1.45fr) minmax(260px,.75fr);
  }
}


/* ---------- No-photo team section ---------- */
.no-photo-team .card{
  min-height:100%;
}
.no-photo-team .ico{
  margin-bottom:1.05rem;
}


/* ---------- Desktop header polish ---------- */
@media (min-width:1041px){
  .header-row{gap:1.25rem;}
  .nav-desktop{gap:.15rem;}
  .nav a.navlink{padding:.52rem .68rem;}
  .nav .btn{margin-left:.25rem;}
}
