/* =========================================================
   Max Cassady Law, PC — Shared Stylesheet
   Classic & Professional: Navy + Gold
   ========================================================= */

:root{
  --navy:        #0b2545;
  --navy-dark:   #071a33;
  --navy-light:  #13355f;
  --gold:        #c9a24b;
  --gold-dark:   #a8862f;
  --cream:       #f7f3ea;
  --paper:       #ffffff;
  --ink:         #1a1a1a;
  --muted:       #555;
  --border:      #e4ddcf;
  --shadow:      0 4px 18px rgba(7,26,51,.10);
  --shadow-lg:   0 12px 32px rgba(7,26,51,.18);
  --radius:      6px;
  --maxw:        1160px;
  --serif:       "Playfair Display", Georgia, "Times New Roman", serif;
  --sans:        "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:var(--navy);text-decoration:none;}
a:hover{color:var(--gold-dark);}

h1,h2,h3,h4{
  font-family:var(--serif);
  color:var(--navy);
  line-height:1.2;
  margin:0 0 .6em;
  font-weight:700;
}
h1{font-size:clamp(2rem, 4.2vw, 3.2rem);}
h2{font-size:clamp(1.6rem, 2.8vw, 2.2rem);}
h3{font-size:1.25rem;}
p{margin:0 0 1em;}

.container{
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 24px;
}

/* ---------- Top Bar ---------- */
.topbar{
  background:var(--navy-dark);
  color:#e8e2d1;
  font-size:.88rem;
}
.topbar .container{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding-top:8px;
  padding-bottom:8px;
  flex-wrap:wrap;
  gap:8px;
}
.topbar a{color:var(--gold);}
.topbar a:hover{color:#fff;}

/* ---------- Header / Nav ---------- */
.site-header{
  background:var(--navy);
  color:#fff;
  border-bottom:3px solid var(--gold);
  position:sticky;
  top:0;
  z-index:50;
}
.site-header .container{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding-top:18px;
  padding-bottom:18px;
  gap:16px;
}
.brand{display:flex;align-items:center;gap:14px;}
.brand-mark{
  width:48px;height:48px;
  border:2px solid var(--gold);
  color:var(--gold);
  font-family:var(--serif);
  font-weight:700;
  font-size:1.3rem;
  display:flex;align-items:center;justify-content:center;
  letter-spacing:.02em;
}
.brand-name{
  font-family:var(--serif);
  font-size:1.35rem;
  line-height:1.1;
  color:#fff;
  font-weight:700;
}
.brand-name small{
  display:block;
  font-family:var(--sans);
  font-size:.68rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:500;
  margin-top:4px;
}

.nav-toggle{
  display:none;
  background:transparent;
  border:1px solid var(--gold);
  color:var(--gold);
  padding:8px 12px;
  border-radius:var(--radius);
  cursor:pointer;
  font-size:1.1rem;
}

.primary-nav ul{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  list-style:none;
  margin:0;padding:0;
  gap:6px;
  align-items:center;
}
.primary-nav a{
  color:#f3ecd8;
  font-weight:500;
  font-size:.95rem;
  padding:10px 14px;
  border-radius:var(--radius);
  transition:background .2s, color .2s;
}
.primary-nav a:hover,
.primary-nav a.active{
  background:var(--navy-light);
  color:var(--gold);
}
.nav-call{
  background:var(--gold);
  color:var(--navy-dark) !important;
  font-weight:700 !important;
  padding:10px 16px !important;
  border-radius:var(--radius);
  margin-left:8px;
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.nav-call:hover{background:#fff !important;color:var(--navy) !important;}

/* ---------- Floating Phone Icon (every page) ---------- */
.floating-call{
  position:fixed;
  right:20px;
  bottom:20px;
  z-index:80;
  background:var(--gold);
  color:var(--navy-dark);
  width:64px;height:64px;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-lg);
  font-size:1.6rem;
  animation:pulse 2.2s ease-in-out infinite;
  transition:transform .2s;
}
.floating-call:hover{transform:scale(1.08);color:var(--navy-dark);}
.floating-call svg{width:28px;height:28px;fill:var(--navy-dark);}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(201,162,75,.55), var(--shadow-lg);}
  50%   {box-shadow:0 0 0 14px rgba(201,162,75,0), var(--shadow-lg);}
}

/* ---------- Hero ---------- */
.hero{
  background:
    linear-gradient(rgba(7,26,51,.82),rgba(7,26,51,.82)),
    linear-gradient(135deg, #0b2545 0%, #13355f 100%);
  color:#fff;
  padding:80px 0 90px;
  text-align:center;
  border-bottom:4px solid var(--gold);
}
.hero h1{color:#fff;margin-bottom:.4em;}
.hero .kicker{
  color:var(--gold);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.85rem;
  font-weight:600;
  margin-bottom:16px;
}
.hero p.lead{
  font-size:1.15rem;
  max-width:720px;
  margin:0 auto 28px;
  color:#e8e2d1;
}
.hero-ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* Smaller page hero (non-home) */
.page-hero{
  background:linear-gradient(rgba(7,26,51,.9),rgba(7,26,51,.9)),
             linear-gradient(135deg, #0b2545, #13355f);
  color:#fff;
  padding:60px 0 70px;
  text-align:center;
  border-bottom:4px solid var(--gold);
}
.page-hero h1{color:#fff;}
.page-hero .kicker{
  color:var(--gold);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.8rem;
  font-weight:600;
  margin-bottom:10px;
}
.page-hero p{color:#e8e2d1;max-width:680px;margin:0 auto;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:14px 26px;
  border-radius:var(--radius);
  font-weight:600;
  font-size:1rem;
  cursor:pointer;
  border:2px solid transparent;
  transition:transform .15s, background .2s, color .2s, border-color .2s;
  text-align:center;
  line-height:1.1;
}
.btn-gold{background:var(--gold);color:var(--navy-dark);}
.btn-gold:hover{background:#fff;color:var(--navy-dark);transform:translateY(-1px);}
.btn-outline{border-color:var(--gold);color:var(--gold);background:transparent;}
.btn-outline:hover{background:var(--gold);color:var(--navy-dark);}
.btn-navy{background:var(--navy);color:#fff;}
.btn-navy:hover{background:var(--navy-dark);color:#fff;}

/* ---------- Section basics ---------- */
section{padding:72px 0;}
.section-cream{background:var(--cream);}
.section-navy{background:var(--navy);color:#fff;}
.section-navy h2{color:#fff;}
.section-navy p{color:#d9d3c2;}
.section-title{text-align:center;margin-bottom:14px;}
.section-sub{
  text-align:center;
  color:var(--muted);
  max-width:720px;
  margin:0 auto 48px;
  font-size:1.05rem;
}
.section-navy .section-sub{color:#d9d3c2;}
.divider{
  width:64px;height:3px;
  background:var(--gold);
  margin:0 auto 34px;
  border:0;
}

/* ---------- Cards / Grids ---------- */
.grid{display:grid;gap:28px;}
.grid-3{grid-template-columns:repeat(3,1fr);}
.grid-2{grid-template-columns:repeat(2,1fr);}
.grid-4{grid-template-columns:repeat(4,1fr);}

.card{
  background:#fff;
  border:1px solid var(--border);
  border-top:4px solid var(--gold);
  border-radius:var(--radius);
  padding:32px 28px;
  box-shadow:var(--shadow);
  transition:transform .2s, box-shadow .2s;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.card h3{margin-top:6px;}
.card .icon{
  width:52px;height:52px;
  background:var(--navy);
  color:var(--gold);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;
  margin-bottom:14px;
}
.card .read-more{
  display:inline-block;
  margin-top:8px;
  font-weight:600;
  color:var(--navy);
  border-bottom:2px solid var(--gold);
  padding-bottom:1px;
}
.card .read-more:hover{color:var(--gold-dark);}

/* County chip list */
.county-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:14px;
  max-width:900px;
  margin:0 auto;
}
.county-chip{
  background:#fff;
  border:1px solid var(--border);
  border-left:4px solid var(--gold);
  padding:16px 18px;
  border-radius:var(--radius);
  font-weight:600;
  color:var(--navy);
  text-align:left;
}

/* Two-column prose block */
.two-col{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:48px;
  align-items:center;
}
.two-col .portrait{
  background:linear-gradient(135deg,var(--navy),var(--navy-light));
  color:var(--gold);
  border:4px solid var(--gold);
  border-radius:var(--radius);
  aspect-ratio:3/4;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);
  font-size:6rem;
  box-shadow:var(--shadow-lg);
}

/* Bulleted emphasis list */
.check-list{list-style:none;padding:0;margin:0 0 24px;}
.check-list li{
  position:relative;
  padding:8px 0 8px 32px;
  border-bottom:1px solid var(--border);
}
.check-list li:last-child{border-bottom:0;}
.check-list li::before{
  content:"✓";
  position:absolute;
  left:0;top:8px;
  color:var(--gold);
  font-weight:700;
}

/* Numbered steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;counter-reset:step;}
.step{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:28px 22px;
  position:relative;
  padding-top:48px;
  box-shadow:var(--shadow);
}
.step::before{
  counter-increment:step;
  content:counter(step);
  position:absolute;
  top:-20px;left:20px;
  width:44px;height:44px;
  border-radius:50%;
  background:var(--gold);
  color:var(--navy-dark);
  font-family:var(--serif);
  font-weight:700;
  font-size:1.3rem;
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow);
}
.step h4{margin:0 0 8px;font-family:var(--serif);color:var(--navy);font-size:1.1rem;}
.step p{color:var(--muted);font-size:.95rem;margin:0;}

/* Testimonial */
.quote{
  background:#fff;
  border-left:5px solid var(--gold);
  padding:26px 28px;
  font-style:italic;
  color:#333;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.quote cite{
  display:block;
  margin-top:12px;
  font-style:normal;
  font-weight:600;
  color:var(--navy);
  font-size:.9rem;
}

/* CTA band */
.cta-band{
  background:
    linear-gradient(rgba(11,37,69,.88),rgba(11,37,69,.88)),
    linear-gradient(135deg, var(--navy), var(--navy-light));
  color:#fff;
  text-align:center;
  padding:64px 0;
  border-top:4px solid var(--gold);
  border-bottom:4px solid var(--gold);
}
.cta-band h2{color:#fff;}
.cta-band p{color:#e8e2d1;max-width:640px;margin:0 auto 26px;}

/* ---------- Contact / Form ---------- */
.contact-wrap{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
}
.info-box{
  background:#fff;
  border:1px solid var(--border);
  border-top:4px solid var(--gold);
  padding:32px;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.info-box h3{margin-top:0;}
.info-item{
  display:flex;
  gap:14px;
  padding:14px 0;
  border-bottom:1px solid var(--border);
}
.info-item:last-child{border-bottom:0;}
.info-item .ico{
  flex:0 0 40px;
  width:40px;height:40px;
  background:var(--navy);
  color:var(--gold);
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;
  font-size:1rem;
}
.info-item strong{display:block;color:var(--navy);font-family:var(--serif);font-size:1.05rem;margin-bottom:2px;}
.info-item a{color:var(--navy);}
.info-item a:hover{color:var(--gold-dark);}

form.contact-form{
  background:#fff;
  border:1px solid var(--border);
  padding:32px;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
form.contact-form label{
  display:block;
  font-weight:600;
  color:var(--navy);
  margin:14px 0 6px;
  font-size:.9rem;
}
form.contact-form input,
form.contact-form select,
form.contact-form textarea{
  width:100%;
  padding:12px 14px;
  border:1px solid #cfc7b5;
  border-radius:var(--radius);
  font-family:var(--sans);
  font-size:1rem;
  background:#fffdf8;
}
form.contact-form input:focus,
form.contact-form select:focus,
form.contact-form textarea:focus{
  outline:none;
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(201,162,75,.25);
}
form.contact-form textarea{min-height:140px;resize:vertical;}
form.contact-form .form-note{
  font-size:.82rem;color:var(--muted);margin-top:12px;
}
form.contact-form button{margin-top:18px;width:100%;}

/* ---------- FAQ ---------- */
.faq details{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px 22px;
  margin-bottom:12px;
  box-shadow:var(--shadow);
}
.faq summary{
  cursor:pointer;
  font-family:var(--serif);
  font-weight:700;
  color:var(--navy);
  font-size:1.1rem;
  list-style:none;
  padding-right:30px;
  position:relative;
}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{
  content:"+";
  position:absolute;
  right:0;top:-2px;
  color:var(--gold);
  font-size:1.6rem;
  line-height:1;
  font-weight:400;
}
.faq details[open] summary::after{content:"–";}
.faq details p{margin:14px 0 0;color:#333;}

/* ---------- Footer ---------- */
.site-footer{
  background:var(--navy-dark);
  color:#d9d3c2;
  padding:56px 0 0;
  font-size:.92rem;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:36px;
  padding-bottom:40px;
}
.site-footer h4{
  color:var(--gold);
  font-size:.85rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-family:var(--sans);
  margin:0 0 16px;
  border-bottom:1px solid #1d3a67;
  padding-bottom:8px;
}
.site-footer ul{list-style:none;padding:0;margin:0;}
.site-footer li{margin-bottom:8px;}
.site-footer a{color:#d9d3c2;}
.site-footer a:hover{color:var(--gold);}
.footer-brand p{color:#a8a497;line-height:1.6;}
.footer-bottom{
  border-top:1px solid #1d3a67;
  padding:18px 0;
  text-align:center;
  color:#8e8876;
  font-size:.82rem;
}
.disclaimer{
  background:#050f1f;
  color:#8e8876;
  font-size:.78rem;
  padding:14px 0;
  text-align:center;
  line-height:1.5;
}
.disclaimer .container{max-width:960px;}

/* ---------- Utilities ---------- */
.text-center{text-align:center;}
.mt-0{margin-top:0;}
.mb-0{margin-bottom:0;}

/* ---------- Responsive ---------- */
@media (max-width: 900px){
  .grid-3,.grid-4,.steps{grid-template-columns:repeat(2,1fr);}
  .two-col{grid-template-columns:1fr;gap:28px;}
  .two-col .portrait{max-width:260px;margin:0 auto;font-size:4rem;}
  .contact-wrap{grid-template-columns:1fr;gap:28px;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .county-grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width: 720px){
  .nav-toggle{display:inline-block;}
  .primary-nav{
    position:absolute;
    left:0;right:0;
    top:100%;
    background:var(--navy-dark);
    border-bottom:3px solid var(--gold);
    max-height:0;
    overflow:hidden;
    transition:max-height .3s ease;
  }
  .primary-nav.open{max-height:520px;}
  .primary-nav ul{
    flex-direction:column;
    align-items:stretch;
    padding:12px 18px 18px;
    gap:2px;
  }
  .primary-nav a{padding:12px 10px;border-radius:4px;}
  .nav-call{margin:10px 0 0 !important;}
  .site-header .container{position:relative;flex-wrap:wrap;}
  section{padding:56px 0;}
  .hero{padding:60px 0 70px;}
  .hero p.lead{font-size:1.05rem;}
  .grid-2,.grid-3,.grid-4,.steps{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .county-grid{grid-template-columns:1fr 1fr;}
  .topbar .container{justify-content:center;text-align:center;}
  .brand-name{font-size:1.15rem;}
  .brand-mark{width:42px;height:42px;font-size:1.1rem;}
  .floating-call{width:58px;height:58px;right:16px;bottom:16px;}
}
@media (max-width: 420px){
  .county-grid{grid-template-columns:1fr;}
  .hero-ctas{flex-direction:column;}
  .hero-ctas .btn{width:100%;}
}

/* ---------- Print ---------- */
@media print{
  .site-header,.topbar,.floating-call,.cta-band,.site-footer{display:none;}
  body{color:#000;}
}
