/*
Theme Name: HAVEIGOTACASE — Miguel Silverstein Paralegal
Theme URI: https://haveigotacase.ca
Author: Miguel | Silverstein Paralegal LLP
Description: Trust-first conversion theme for a licensed Ontario paralegal firm. Navy and gold palette. Coordinates with GOTACASE.CA intake platform.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: Private
Text Domain: higac
*/

/* ============================================================
   DESIGN TOKENS — sampled from live haveigotacase.ca site
   ============================================================ */
:root {
  --navy:        #152643;
  --navy-deep:   #192f69;
  --navy-mid:    #1e3a5f;
  --gold:        #cfab5c;
  --gold-dk:     #b8963e;
  --gold-lt:     rgba(207,171,92,0.12);
  --gold-rule:   rgba(207,171,92,0.28);
  --body-color:  #334155;
  --muted:       #6b7a8d;
  --light-bg:    #f5f7ff;
  --section-bg:  #f5f7ff;
  --white:       #ffffff;
  --border:      rgba(21,38,67,0.14);
  --border-lt:   rgba(21,38,67,0.07);
  --xsite-bg:    #fff6e8;
  --wolf-bg:     #f0f9ff;
  --wolf-rule:   #0ea5e9;
  --success:     #16a34a;
  --error:       #dc2626;
  --font-head:   'Playfair Display', Georgia, serif;
  --font-body:   'Lato', system-ui, sans-serif;
  --sp-xs:  0.5rem;
  --sp-sm:  1rem;
  --sp-md:  1.5rem;
  --sp-lg:  2.5rem;
  --sp-xl:  4rem;
  --sp-2xl: 6rem;
  --max-w:  1200px;
  --max-narrow: 780px;
  --r:      8px;
  --r-lg:   12px;
  --r-xl:   16px;
  --trans:  0.2s ease;
}

/* ============================================================ RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:17px;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);font-size:1rem;line-height:1.75;color:var(--body-color);background:#fff;-webkit-font-smoothing:antialiased}
img,video{max-width:100%;height:auto;display:block}
a{color:var(--gold);text-decoration:none;transition:color var(--trans)}
a:hover{color:var(--gold-dk)}
a:focus-visible{outline:3px solid var(--gold);outline-offset:3px;border-radius:3px}
button,input,select,textarea{font-family:var(--font-body);font-size:1rem}
ul,ol{list-style:none}

/* ============================================================ TYPOGRAPHY */
h1,h2,h3,h4,h5,h6{font-family:var(--font-head);color:var(--navy);line-height:1.2;font-weight:700}
h1{font-size:clamp(2rem,4.5vw,3rem);margin-bottom:1.25rem}
h2{font-size:clamp(1.5rem,3vw,2.1rem);margin-bottom:1rem}
h3{font-size:clamp(1.1rem,2vw,1.35rem);margin-bottom:0.5rem}
p{margin-bottom:1rem}
p:last-child{margin-bottom:0}
strong{font-weight:700}
.eyebrow{display:block;font-family:var(--font-body);font-size:0.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:.75rem}
.section-intro{font-size:1.05rem;color:var(--muted);max-width:640px;line-height:1.7}
.gold-rule{width:40px;height:3px;background:var(--gold);border-radius:2px;margin-bottom:1.25rem}

/* ============================================================ LAYOUT */
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 1.5rem}
.container--narrow{max-width:var(--max-narrow);margin:0 auto;padding:0 1.5rem}
.section{padding:var(--sp-2xl) 0}
.section--sm{padding:var(--sp-xl) 0}
.section--alt{background:var(--section-bg)}
.section--navy{background:var(--navy)}
.section--navy h2,.section--navy h3{color:#fff}
.section--navy p{color:rgba(255,255,255,.68)}
.section--deep{background:var(--navy-deep)}
.section--deep h2,.section--deep h3{color:#fff}
.section--deep p{color:rgba(255,255,255,.65)}
.text-center{text-align:center}
.mt-sm{margin-top:var(--sp-sm)}.mt-md{margin-top:var(--sp-md)}.mt-lg{margin-top:var(--sp-lg)}.mt-xl{margin-top:var(--sp-xl)}
.mb-md{margin-bottom:var(--sp-md)}.mb-lg{margin-bottom:var(--sp-lg)}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ============================================================ SKIP */
.skip-link{position:absolute;top:-100px;left:1rem;background:var(--gold);color:var(--navy);padding:.75rem 1.5rem;border-radius:0 0 var(--r) var(--r);font-weight:700;z-index:9999;transition:top var(--trans)}
.skip-link:focus{top:0;color:var(--navy)}

/* ============================================================ HEADER */
.site-header{position:sticky;top:0;z-index:100;background:var(--navy);border-bottom:1px solid var(--gold-rule);transition:box-shadow var(--trans)}
.site-header.scrolled{box-shadow:0 2px 20px rgba(0,0,0,.25)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px;gap:1.5rem}

/* Logo */
.nav-logo{display:flex;align-items:center;gap:.6rem;text-decoration:none}
.nav-logo__crest{width:38px;height:38px;background:var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:1rem;font-weight:700;color:var(--navy);flex-shrink:0}
.nav-logo__text{display:flex;flex-direction:column;line-height:1.15}
.nav-logo__primary{font-family:var(--font-head);font-size:1.05rem;font-weight:700;color:#fff;white-space:nowrap}
.nav-logo__sub{font-size:.68rem;color:var(--gold);letter-spacing:.04em}

/* Nav links */
.nav-links{display:flex;align-items:center;gap:.15rem;list-style:none}
.nav-links a{display:block;padding:.4rem .7rem;font-size:.875rem;font-weight:600;color:rgba(255,255,255,.78);border-radius:var(--r);transition:background var(--trans),color var(--trans)}
.nav-links a:hover{background:rgba(255,255,255,.08);color:var(--gold)}
.nav-item--dropdown{position:relative}
.nav-dropdown{position:absolute;top:calc(100% + 8px);left:0;background:var(--navy);border:1px solid var(--gold-rule);border-radius:var(--r-lg);box-shadow:0 8px 32px rgba(0,0,0,.25);min-width:260px;padding:.5rem;opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity var(--trans),transform var(--trans),visibility var(--trans);list-style:none}
.nav-item--dropdown:hover .nav-dropdown,.nav-item--dropdown:focus-within .nav-dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.nav-dropdown a{display:block;padding:.5rem .75rem;font-size:.875rem;color:rgba(255,255,255,.78);border-radius:var(--r);transition:background var(--trans)}
.nav-dropdown a:hover{background:rgba(255,255,255,.08);color:var(--gold)}
.nav-dropdown__divider{height:1px;background:var(--gold-rule);margin:.35rem .5rem}
.btn-nav{display:inline-flex;align-items:center;padding:.55rem 1.2rem;background:var(--gold);color:var(--navy) !important;font-size:.875rem;font-weight:700;border-radius:999px;white-space:nowrap;transition:background var(--trans),transform var(--trans);margin-left:.5rem}
.btn-nav:hover{background:var(--gold-dk);transform:translateY(-1px);color:var(--navy) !important}

/* Hamburger */
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;border-radius:var(--r);min-width:44px;min-height:44px;align-items:center;justify-content:center}
.nav-toggle__bar{display:block;width:24px;height:2px;background:#fff;border-radius:2px;transition:transform var(--trans),opacity var(--trans)}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile nav */
.nav-mobile{display:none;flex-direction:column;border-top:1px solid var(--gold-rule);padding:1rem 0;gap:.25rem;background:var(--navy)}
.nav-mobile.is-open{display:flex}
.nav-mobile a{display:block;padding:.6rem 1.5rem;font-size:.95rem;font-weight:600;color:rgba(255,255,255,.8);border-radius:var(--r)}
.nav-mobile a:hover{background:rgba(255,255,255,.07);color:var(--gold)}
.nav-mobile__sub{padding-left:2.25rem !important;font-size:.875rem !important;color:rgba(255,255,255,.5) !important;font-weight:500 !important}
.nav-mobile__cta{margin:.75rem 1.5rem .25rem;display:block;text-align:center;padding:.75rem;background:var(--gold);color:var(--navy) !important;font-weight:700;border-radius:999px}

/* Mobile sticky bar */
.mobile-sticky-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:200;background:#fff;border-top:1px solid var(--border-lt);padding:.75rem 1rem;gap:.5rem}
.mobile-sticky-bar__btn{flex:1;display:flex;align-items:center;justify-content:center;padding:.7rem;font-size:.875rem;font-weight:700;border-radius:999px;text-align:center;min-height:44px}
.mobile-sticky-bar__btn--primary{background:var(--gold);color:var(--navy)}
.mobile-sticky-bar__btn--secondary{background:var(--light-bg);color:var(--navy);border:1px solid var(--border)}

/* ============================================================ BUTTONS */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.75rem;font-family:var(--font-body);font-size:1rem;font-weight:700;border-radius:999px;cursor:pointer;border:2px solid transparent;transition:background var(--trans),color var(--trans),border-color var(--trans),transform var(--trans);text-decoration:none;line-height:1.3;white-space:nowrap}
.btn:focus-visible{outline:3px solid var(--gold);outline-offset:3px}
.btn--primary{background:var(--gold);color:var(--navy);border-color:var(--gold)}
.btn--primary:hover{background:var(--gold-dk);border-color:var(--gold-dk);color:var(--navy);transform:translateY(-1px)}
.btn--outline{background:transparent;color:var(--gold);border-color:var(--gold)}
.btn--outline:hover{background:var(--gold);color:var(--navy);transform:translateY(-1px)}
.btn--outline-white{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn--outline-white:hover{background:rgba(255,255,255,.1);color:#fff}
.btn--white{background:#fff;color:var(--navy);border-color:#fff}
.btn--white:hover{background:var(--light-bg);color:var(--navy)}
.btn--lg{padding:1rem 2.25rem;font-size:1.05rem}
.btn--sm{padding:.55rem 1.25rem;font-size:.875rem}

/* ============================================================ HERO */
.hero{padding:var(--sp-2xl) 0;background:var(--navy)}
.hero__inner{display:grid;grid-template-columns:3fr 2fr;gap:var(--sp-xl);align-items:center}
.hero__badge{display:inline-block;font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--navy);background:var(--gold);padding:.3rem .85rem;border-radius:999px;margin-bottom:1.25rem}
.hero__h1{color:#fff;margin-bottom:1.25rem}
.hero__h1 em{font-style:normal;color:var(--gold)}
.hero__sub{font-size:1.05rem;color:rgba(255,255,255,.7);line-height:1.7;margin-bottom:2rem;max-width:520px}
.hero__ctas{display:flex;flex-wrap:wrap;align-items:center;gap:1rem}
.hero__secondary{font-size:.9rem;color:rgba(255,255,255,.55);font-weight:600;border-bottom:1px solid rgba(255,255,255,.25);padding-bottom:1px;transition:color var(--trans),border-color var(--trans)}
.hero__secondary:hover{color:var(--gold);border-color:var(--gold)}
.hero__secondary::after{content:' →'}
.hero__image img{width:100%;border-radius:var(--r-xl);object-fit:cover;aspect-ratio:4/5}
.hero__image-placeholder{width:100%;aspect-ratio:4/5;background:rgba(255,255,255,.06);border-radius:var(--r-xl);border:1px solid var(--gold-rule);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;color:rgba(255,255,255,.35);font-size:.85rem;text-align:center;padding:2rem}

/* ============================================================ TRUST BAR */
.trust-bar{background:var(--navy-deep);border-top:1px solid var(--gold-rule);border-bottom:1px solid var(--gold-rule);padding:1.25rem 0}
.trust-bar__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;align-items:center}
.trust-item{display:flex;align-items:center;gap:.6rem}
.trust-item__icon{width:32px;height:32px;flex-shrink:0;background:var(--gold-lt);border-radius:50%;display:flex;align-items:center;justify-content:center}
.trust-item__icon svg{width:15px;height:15px;color:var(--gold)}
.trust-item__text{font-size:.82rem;font-weight:600;color:rgba(255,255,255,.78);line-height:1.35}

/* ============================================================ PA CARDS */
.pa-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.pa-card{background:#fff;border:0.5px solid var(--border);border-top:3px solid var(--gold);border-radius:var(--r-lg);padding:1.5rem;transition:border-color var(--trans),transform var(--trans),box-shadow var(--trans);display:flex;flex-direction:column}
.pa-card:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(207,171,92,.15)}
.pa-card__icon{width:40px;height:40px;background:var(--gold-lt);border-radius:var(--r);display:flex;align-items:center;justify-content:center;margin-bottom:1rem}
.pa-card__icon svg{width:20px;height:20px;color:var(--gold)}
.pa-card__title{font-family:var(--font-head);font-size:1.05rem;font-weight:700;color:var(--navy);margin-bottom:.5rem}
.pa-card__desc{font-size:.875rem;color:var(--muted);line-height:1.65;flex:1;margin-bottom:1rem}
.pa-card__link{font-size:.85rem;font-weight:700;color:var(--gold)}
.pa-card__link::after{content:' →'}

/* ============================================================ WHY US */
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}
.why-item{padding:1.5rem;background:rgba(255,255,255,.06);border:0.5px solid var(--gold-rule);border-left:4px solid var(--gold);border-radius:0 var(--r-lg) var(--r-lg) 0}
.why-item__title{font-family:var(--font-head);font-size:1.05rem;font-weight:700;color:#fff;margin-bottom:.6rem}
.why-item__body{font-size:.9rem;color:rgba(255,255,255,.65);line-height:1.7;margin:0}

/* ============================================================ STEPS */
.steps-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2.5rem;position:relative}
.steps-row::before{content:'';position:absolute;top:28px;left:calc(12.5% + 1rem);right:calc(12.5% + 1rem);height:2px;background:var(--gold-rule);z-index:0}
.step-item{text-align:center;position:relative;z-index:1}
.step-item__num{width:56px;height:56px;background:var(--gold);color:var(--navy);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:1.3rem;font-weight:700;margin:0 auto 1rem;border:4px solid var(--navy-deep);outline:2px solid var(--gold)}
.step-item__title{font-family:var(--font-head);font-size:1rem;font-weight:700;color:#fff;margin-bottom:.4rem}
.step-item__body{font-size:.85rem;color:rgba(255,255,255,.6);line-height:1.6}

/* ============================================================ REVIEWS */
.review-aggregate{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}
.review-aggregate__stars{display:flex;gap:2px;color:var(--gold)}
.review-aggregate__stars svg{width:20px;height:20px}
.review-aggregate__score{font-size:1.3rem;font-weight:700;color:var(--navy)}
.review-aggregate__count{font-size:.875rem;color:var(--muted)}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.review-card{background:#fff;border:0.5px solid var(--border);border-radius:var(--r-lg);padding:1.5rem;display:flex;flex-direction:column;gap:1rem}
.review-card__stars{display:flex;gap:2px;color:var(--gold)}
.review-card__stars svg{width:15px;height:15px}
.review-card__quote{font-size:.9rem;color:var(--body-color);line-height:1.7;flex:1;font-style:italic}
.review-card__quote::before{content:'\201C'}
.review-card__quote::after{content:'\201D'}
.review-card__meta{border-top:1px solid var(--border-lt);padding-top:.75rem}
.review-card__name{font-weight:700;font-size:.85rem;color:var(--navy)}
.review-card__source{font-size:.78rem;color:var(--muted);margin-top:.15rem}

/* ============================================================ FAQ */
.faq-list{border:0.5px solid var(--border);border-radius:var(--r-lg);overflow:hidden}
.faq-item{border-bottom:1px solid var(--border-lt)}
.faq-item:last-child{border-bottom:none}
.faq-item__trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.1rem 1.25rem;background:#fff;border:none;cursor:pointer;text-align:left;font-family:var(--font-body);font-size:.95rem;font-weight:600;color:var(--navy);transition:background var(--trans);min-height:44px}
.faq-item__trigger:hover,.faq-item__trigger[aria-expanded="true"]{background:var(--section-bg)}
.faq-item__trigger:focus-visible{outline:3px solid var(--gold);outline-offset:-3px}
.faq-icon{flex-shrink:0;width:22px;height:22px;background:var(--gold-lt);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:transform var(--trans),background var(--trans);font-size:1rem;color:var(--gold);line-height:1}
.faq-item__trigger[aria-expanded="true"] .faq-icon{transform:rotate(45deg);background:var(--gold);color:var(--navy)}
.faq-item__panel{display:none;padding:0 1.25rem 1.25rem;background:var(--section-bg)}
.faq-item__panel p{font-size:.9rem;color:var(--body-color);line-height:1.75;margin:0}

/* ============================================================ XSITE & WOLF */
.xsite-block{background:var(--xsite-bg);border-left:5px solid var(--gold);border-radius:0 var(--r-lg) var(--r-lg) 0;padding:1.5rem 1.75rem;margin:2rem 0}
.xsite-block__heading{font-family:var(--font-head);font-size:1rem;font-weight:700;color:#7a5c1a;margin-bottom:.5rem}
.xsite-block__body{font-size:.9rem;color:#78350f;line-height:1.65;margin-bottom:.85rem}
.xsite-block__cta{display:inline-flex;align-items:center;font-size:.9rem;font-weight:700;color:var(--gold-dk);border-bottom:1px solid var(--gold-dk);padding-bottom:1px;transition:color var(--trans)}
.xsite-block__cta:hover{color:#92400e}
.xsite-block__cta::after{content:' →'}
.wolf-block{background:var(--wolf-bg);border-left:4px solid var(--wolf-rule);border-radius:0 var(--r-lg) var(--r-lg) 0;padding:1.25rem 1.5rem;margin:2rem 0;display:flex;align-items:flex-start;gap:1rem}
.wolf-block__avatar{width:36px;height:36px;flex-shrink:0;background:var(--wolf-rule);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.wolf-block__label{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--wolf-rule);margin-bottom:.3rem}
.wolf-block__body{font-size:.875rem;color:#0c4a6e;line-height:1.6;margin-bottom:.6rem}
.wolf-block__cta{font-size:.85rem;font-weight:700;color:var(--wolf-rule);border-bottom:1px solid var(--wolf-rule);transition:color var(--trans)}
.wolf-block__cta::after{content:' →'}

/* ============================================================ FINAL CTA */
.final-cta{text-align:center;padding:var(--sp-2xl) 0;background:var(--navy);border-top:3px solid var(--gold)}
.final-cta h2{color:#fff;margin-bottom:1rem}
.final-cta p{color:rgba(255,255,255,.68);max-width:540px;margin:0 auto 2rem;font-size:1.05rem}
.final-cta__btns{display:flex;flex-direction:column;align-items:center;gap:1rem}
.final-cta__secondary{font-size:.9rem;color:rgba(207,171,92,.55);font-weight:600;border-bottom:1px solid rgba(207,171,92,.3);padding-bottom:1px;transition:color var(--trans),border-color var(--trans)}
.final-cta__secondary:hover{color:var(--gold);border-color:var(--gold)}
.final-cta__secondary::after{content:' →'}
.service-cta-band{background:var(--navy-deep);padding:var(--sp-xl) 0;text-align:center;border-top:3px solid var(--gold)}
.service-cta-band h2{color:#fff;margin-bottom:.75rem}
.service-cta-band p{color:rgba(255,255,255,.75);margin-bottom:1.5rem}

/* ============================================================ FOOTER */
.site-footer{background:var(--navy);color:rgba(255,255,255,.5);padding:var(--sp-2xl) 0 0;border-top:1px solid var(--gold-rule)}
.footer-grid{display:grid;grid-template-columns:2fr 1.5fr 1.5fr 1.5fr;gap:2.5rem;margin-bottom:var(--sp-xl)}
.footer-col__title{font-family:var(--font-head);font-size:.85rem;font-weight:700;color:var(--gold);margin-bottom:1rem;letter-spacing:.04em}
.footer-col p{font-size:.85rem;line-height:1.7;margin-bottom:.4rem}
.footer-col__links{list-style:none;display:flex;flex-direction:column;gap:.4rem}
.footer-col__links a{font-size:.85rem;color:rgba(255,255,255,.5);transition:color var(--trans)}
.footer-col__links a:hover{color:var(--gold)}
.footer-firm__name{font-family:var(--font-head);font-size:1.1rem;font-weight:700;color:#fff;display:block;margin-bottom:.35rem}
.footer-firm__lso{font-size:.75rem;color:rgba(207,171,92,.45);display:block;margin-top:.4rem}
.footer-btn{display:inline-block;margin-top:1rem;padding:.6rem 1.25rem;background:transparent;color:var(--gold);font-size:.85rem;font-weight:700;border-radius:999px;border:1px solid var(--gold);transition:background var(--trans),color var(--trans)}
.footer-btn:hover{background:var(--gold);color:var(--navy)}
.footer-disclaimer{border-top:1px solid var(--gold-rule);padding:1.5rem 0;font-size:.78rem;color:rgba(255,255,255,.3);line-height:1.7}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;border-top:1px solid rgba(207,171,92,.08);font-size:.78rem;color:rgba(255,255,255,.3);flex-wrap:wrap;gap:.5rem}
.footer-bottom a{color:rgba(255,255,255,.3)}
.footer-bottom a:hover{color:var(--gold)}

/* ============================================================ BREADCRUMB */
.breadcrumb{padding:.75rem 0;border-bottom:1px solid var(--border-lt);background:var(--section-bg)}
.breadcrumb ol{display:flex;align-items:center;flex-wrap:wrap;gap:.25rem;list-style:none;font-size:.82rem;color:var(--muted)}
.breadcrumb li+li::before{content:'›';margin-right:.25rem;color:var(--border)}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb [aria-current="page"]{color:var(--navy);font-weight:600}

/* ============================================================ PAGE HERO (interior) */
.page-hero{padding:var(--sp-xl) 0 var(--sp-lg);border-bottom:1px solid var(--border-lt);background:var(--section-bg)}
.page-hero h1{margin-bottom:.75rem}

/* ============================================================ SERVICE PAGE */
.service-who{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.service-side__title{font-family:var(--font-head);font-size:1.05rem;font-weight:700;color:var(--navy);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--gold);display:inline-block}
.service-side ul{display:flex;flex-direction:column;gap:.6rem}
.service-side li{display:flex;align-items:flex-start;gap:.6rem;font-size:.9rem;color:var(--body-color);line-height:1.55}
.service-side li::before{content:'';width:6px;height:6px;background:var(--gold);border-radius:50%;flex-shrink:0;margin-top:.5em}
.service-help-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.help-col{background:#fff;border:0.5px solid var(--border);border-radius:var(--r-lg);padding:1.5rem}
.help-col__title{font-family:var(--font-head);font-size:.95rem;font-weight:700;color:var(--navy);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--gold);display:inline-block}
.help-col ul{display:flex;flex-direction:column;gap:.5rem}
.help-col li{font-size:.875rem;color:var(--body-color);display:flex;align-items:flex-start;gap:.5rem;line-height:1.5}
.help-col li::before{content:'✓';color:var(--success);font-weight:700;flex-shrink:0;font-size:.82rem;margin-top:.1em}
.bring-list{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
.bring-list li{display:flex;align-items:flex-start;gap:.6rem;font-size:.9rem;color:var(--body-color);padding:.65rem .85rem;background:#fff;border:0.5px solid var(--border-lt);border-radius:var(--r)}
.bring-list li::before{content:'→';color:var(--gold);font-weight:700;flex-shrink:0}

/* ============================================================ ABOUT */
.approach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.approach-item{padding:1.5rem;background:#fff;border:0.5px solid var(--border);border-radius:var(--r-lg)}
.approach-item__title{font-family:var(--font-head);font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:.5rem}
.approach-item__body{font-size:.9rem;color:var(--muted);line-height:1.7;margin:0}
.lso-block{background:var(--light-bg);border:0.5px solid var(--border);border-radius:var(--r-lg);padding:1.5rem 2rem;display:flex;align-items:flex-start;gap:1.5rem}
.lso-block__badge{width:52px;height:52px;flex-shrink:0;background:var(--gold);border-radius:var(--r);display:flex;align-items:center;justify-content:center;color:var(--navy);font-size:1.4rem}
.lso-block__title{font-family:var(--font-head);font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:.4rem}
.lso-block li{font-size:.9rem;color:var(--muted);padding:.2rem 0}

/* ============================================================ TEAM */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.team-card{background:#fff;border:0.5px solid var(--border);border-radius:var(--r-lg);overflow:hidden}
.team-card__photo{aspect-ratio:4/3;overflow:hidden;background:var(--light-bg)}
.team-card__photo img{width:100%;height:100%;object-fit:cover}
.team-card__photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.82rem;min-height:200px}
.team-card__body{padding:1.25rem}
.team-card__name{font-family:var(--font-head);font-size:1.1rem;font-weight:700;color:var(--navy);margin-bottom:.25rem}
.team-card__role{font-size:.82rem;color:var(--gold);font-weight:600;margin-bottom:.75rem}
.team-card__bio{font-size:.875rem;color:var(--muted);line-height:1.65;margin:0}
.team-card__lso{font-size:.75rem;color:rgba(21,38,67,.35);margin-top:.5rem}

/* ============================================================ CONTACT */
.contact-grid{display:grid;grid-template-columns:3fr 2fr;gap:var(--sp-xl);align-items:flex-start}
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-size:.875rem;font-weight:700;color:var(--navy);margin-bottom:.4rem}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.7rem 1rem;border:1px solid var(--border);border-radius:var(--r);font-family:var(--font-body);font-size:.95rem;color:var(--body-color);background:#fff;transition:border-color var(--trans),box-shadow var(--trans);appearance:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(207,171,92,.18)}
.form-group textarea{min-height:140px;resize:vertical;line-height:1.6}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-disclaimer{font-size:.8rem;color:var(--muted);line-height:1.6;margin-top:.75rem;border-top:1px solid var(--border-lt);padding-top:.75rem}
.form-feedback{padding:.85rem 1.1rem;border-radius:var(--r);font-size:.9rem;margin-bottom:1.25rem;font-weight:600;display:none}
.form-feedback--success{background:#DCFCE7;color:#15803D;border:1px solid #86EFAC}
.form-feedback--error{background:#FEF2F2;color:var(--error);border:1px solid #FECACA}
.form-error{color:var(--error);font-size:.8rem;margin-top:.3rem;display:none}
.contact-info{background:var(--section-bg);border:0.5px solid var(--border);border-radius:var(--r-lg);padding:1.75rem}
.contact-info__title{font-family:var(--font-head);font-size:1.05rem;font-weight:700;color:var(--navy);margin-bottom:1.25rem}
.contact-info__item{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1rem;font-size:.9rem}
.contact-info__icon{width:30px;height:30px;background:var(--gold-lt);border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.contact-info__icon svg{width:14px;height:14px;color:var(--gold)}
.contact-info__label{font-size:.72rem;font-weight:700;color:var(--muted);display:block;margin-bottom:.15rem}
.contact-info__value{font-weight:600;color:var(--navy)}
.booking-nudge{margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid var(--border-lt)}
.booking-nudge p{font-size:.85rem;color:var(--muted);margin-bottom:.75rem}

/* ============================================================ BOOKING */
.booking-embed-wrap{background:var(--section-bg);border:0.5px solid var(--border);border-radius:var(--r-xl);overflow:hidden;min-height:680px}
.booking-embed-placeholder{min-height:680px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;text-align:center;padding:3rem;color:var(--muted)}
.booking-embed-placeholder h3{color:var(--navy);font-size:1.1rem}
.booking-embed-placeholder p{font-size:.9rem;max-width:360px}

/* ============================================================ BLOG */
.blog-header{background:var(--wolf-bg);border-bottom:3px solid var(--wolf-rule);padding:var(--sp-xl) 0 var(--sp-lg)}
.blog-header__inner{display:flex;align-items:flex-start;gap:1.5rem}
.blog-header__avatar{width:64px;height:64px;background:var(--wolf-rule);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.8rem;flex-shrink:0}
.blog-filter{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.5rem}
.blog-filter__btn{padding:.4rem 1rem;border-radius:999px;font-size:.82rem;font-weight:600;color:var(--muted);background:var(--light-bg);border:0.5px solid var(--border);cursor:pointer;text-decoration:none;transition:background var(--trans),color var(--trans)}
.blog-filter__btn:hover,.blog-filter__btn.active{background:var(--gold);color:var(--navy);border-color:var(--gold)}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.blog-card{background:#fff;border:0.5px solid var(--border);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;text-decoration:none;transition:border-color var(--trans),transform var(--trans)}
.blog-card:hover{border-color:var(--gold);transform:translateY(-2px)}
.blog-card__thumb{aspect-ratio:16/9;background:var(--light-bg);overflow:hidden}
.blog-card__thumb img{width:100%;height:100%;object-fit:cover}
.blog-card__body{padding:1.25rem;flex:1;display:flex;flex-direction:column}
.blog-card__tag{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--wolf-rule);margin-bottom:.5rem}
.blog-card__title{font-family:var(--font-head);font-size:1rem;font-weight:700;color:var(--navy);line-height:1.4;margin-bottom:.5rem}
.blog-card__excerpt{font-size:.85rem;color:var(--muted);line-height:1.6;flex:1;margin-bottom:.75rem}
.blog-card__meta{font-size:.78rem;color:var(--muted);border-top:1px solid var(--border-lt);padding-top:.75rem}
.blog-cards-mini{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.blog-card-mini{background:#fff;border:0.5px solid var(--border);border-radius:var(--r-lg);padding:1.25rem;text-decoration:none;display:flex;flex-direction:column;gap:.5rem;transition:border-color var(--trans),transform var(--trans)}
.blog-card-mini:hover{border-color:var(--gold);transform:translateY(-2px)}
.blog-card-mini__tag{font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--wolf-rule)}
.blog-card-mini__title{font-family:var(--font-head);font-size:.95rem;font-weight:700;color:var(--navy);line-height:1.4}
.blog-card-mini__excerpt{font-size:.82rem;color:var(--muted);line-height:1.6;flex:1}
.blog-card-mini__more{font-size:.82rem;font-weight:700;color:var(--gold)}

/* ============================================================ VIDEOS */
.video-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.video-card{background:#fff;border:0.5px solid var(--border);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column}
.video-card__embed{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;background:var(--navy)}
.video-card__embed iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}
.video-card__body{padding:1.1rem 1.25rem;flex:1;display:flex;flex-direction:column;gap:.4rem}
.video-card__label{font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);display:block}
.video-card__title{font-family:var(--font-head);font-size:.95rem;font-weight:700;color:var(--navy);line-height:1.35;margin:0}
.video-card__desc{font-size:.85rem;color:var(--muted);line-height:1.6;margin:0;flex:1}
.video-featured{display:grid;grid-template-columns:2fr 1fr;gap:var(--sp-lg);align-items:flex-start}
.video-featured__embed{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:var(--r-lg);background:#000}
.video-featured__embed iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}
.video-filter{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:var(--sp-lg)}

/* ============================================================ MISC */
.post-header{padding:var(--sp-xl) 0 var(--sp-lg);border-bottom:1px solid var(--border-lt)}
.post-header__tag{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--wolf-rule);margin-bottom:.75rem;display:block}
.post-header__meta{font-size:.82rem;color:var(--muted);display:flex;align-items:center;gap:.75rem}
.post-body{padding:var(--sp-xl) 0}
.post-body h2,.post-body h3{margin-top:2rem}
.post-body ul{list-style:disc;padding-left:1.5rem;display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}
.in-post-cta{background:var(--light-bg);border-radius:var(--r-lg);padding:1.5rem 2rem;margin:2.5rem 0;display:flex;align-items:center;justify-content:space-between;gap:1.5rem}
.in-post-cta p{margin:0;font-size:.95rem;color:var(--navy);font-weight:600}
.error-page{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:var(--sp-2xl) 0}
.error-page__code{font-family:var(--font-head);font-size:6rem;font-weight:700;color:var(--light-bg);line-height:1}
.error-page__title{font-size:1.5rem;color:var(--navy);margin-bottom:1rem}
.error-page__body{color:var(--muted);margin-bottom:2rem}
.legal-content{padding:var(--sp-2xl) 0}
.legal-content h2{margin-top:2rem;margin-bottom:.75rem;font-size:1.2rem}
.legal-content p{font-size:.95rem;color:var(--body-color);line-height:1.75}
.legal-content ul{list-style:disc;padding-left:1.5rem;display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}
.legal-content li{font-size:.95rem;color:var(--body-color)}

/* ============================================================ RESPONSIVE ≤1024 */
@media(max-width:1024px){
  .nav-links,.btn-nav{display:none}
  .nav-toggle{display:flex}
  .hero__inner{grid-template-columns:1fr}
  .hero__image,.hero__image-placeholder{display:none}
  .trust-bar__grid{grid-template-columns:repeat(2,1fr)}
  .pa-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:1fr}
  .steps-row{grid-template-columns:repeat(2,1fr)}
  .steps-row::before{display:none}
  .reviews-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
  .service-who{grid-template-columns:1fr}
  .service-help-cols{grid-template-columns:1fr}
  .bring-list{grid-template-columns:1fr}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .approach-grid{grid-template-columns:1fr 1fr}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
  .blog-cards-mini{grid-template-columns:1fr 1fr}
  .video-grid{grid-template-columns:repeat(2,1fr)}
  .video-featured{grid-template-columns:1fr}
  .in-post-cta{flex-direction:column;align-items:flex-start}
}
/* ============================================================ RESPONSIVE ≤640 */
@media(max-width:640px){
  html{font-size:16px}
  .section{padding:var(--sp-xl) 0}
  .trust-bar__grid,.pa-grid,.why-grid,.steps-row,.reviews-grid,.team-grid,.approach-grid,.blog-grid,.blog-cards-mini,.video-grid,.bring-list{grid-template-columns:1fr}
  .footer-grid,.form-row{grid-template-columns:1fr}
  .lso-block{flex-direction:column}
  .mobile-sticky-bar{display:flex}
  .site-footer{padding-bottom:calc(var(--sp-xl) + 80px)}
  .final-cta{padding-bottom:calc(var(--sp-2xl) + 80px)}
}
@media print{
  .site-header,.site-footer,.mobile-sticky-bar,.nav-mobile{display:none}
  body{font-size:12pt;color:#000}
  a{color:#000;text-decoration:underline}
}
