/*
Theme Name: Leimkuehler Insurance Services Complete Theme V2
Theme URI: https://midwesthorizons.com/
Author: Midwest Horizons Marketing
Author URI: https://midwesthorizons.com/
Description: Complete premium WordPress theme for Leimkuehler Insurance Services, LLC with clean header, editable menus, homepage, and built-in spam-resistant quote intake PDF page.
Version: 3.1.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
Text Domain: leimkuehler-insurance-services-complete-theme
*/

:root {
  --bg:#f7f9fc;
  --surface:#ffffff;
  --surface-2:#f4f0ff;
  --surface-3:#eefbf3;
  --text:#151936;
  --muted:#667085;
  --line:#e7e8ee;
  --primary:#7c3aed;
  --primary-2:#9a6bff;
  --accent:#a8ebb0;
  --accent-strong:#42c76d;
  --shadow:0 14px 40px rgba(40,24,80,.08);
  --shadow-strong:0 20px 60px rgba(21,25,54,.12);
  --radius-xl:30px;
  --container:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Inter",Arial,sans-serif;
  background:
    radial-gradient(1200px 600px at 0 0,rgba(124,58,237,.10),transparent 45%),
    radial-gradient(800px 500px at 100% 0,rgba(66,199,109,.12),transparent 40%),
    linear-gradient(180deg,#fdfdff 0%,#f6f9fc 100%);
  color:var(--text);
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(calc(100% - 2rem),var(--container));margin:0 auto}

/* Top bar */
.top-bar{
  background:linear-gradient(90deg,var(--primary),var(--accent-strong));
  color:#fff;
  font-size:.92rem;
}
.top-bar-inner{
  min-height:48px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  flex-wrap:wrap;
}
.top-contact-group,.top-actions{
  display:flex;
  align-items:center;
  gap:1rem;
  flex-wrap:wrap;
}
.top-contact-link,.top-utility-link{
  color:#fff;
  font-weight:700;
  display:inline-flex;
  gap:.4rem;
  align-items:center;
}
.top-contact-link:hover,.top-utility-link:hover{text-decoration:underline}
.top-facebook{
  background:rgba(255,255,255,.17);
  padding:.45rem .85rem;
  border-radius:999px;
  color:#fff;
  font-weight:800;
}

/* Header */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(231,232,238,.8);
  box-shadow:0 8px 32px rgba(21,25,54,.05);
  transition:box-shadow .3s ease,background .3s ease;
}
.site-header.scrolled{
  box-shadow:0 16px 40px rgba(21,25,54,.08);
  background:rgba(255,255,255,.97);
}
.nav{
  min-height:96px;
  display:grid;
  grid-template-columns:minmax(260px,330px) 1fr minmax(170px,220px);
  align-items:center;
  gap:1.25rem;
}
.brand{
  display:flex;
  align-items:center;
  gap:.85rem;
  min-width:0;
}
.brand-logo{
  width:64px;
  height:64px;
  flex:0 0 64px;
  border-radius:18px;
  display:grid;
  place-items:center;
  overflow:hidden;
  background:#fff;
  box-shadow:var(--shadow);
  border:1px solid var(--line);
}
.brand-logo img{width:100%;height:100%;object-fit:contain}
.brand-copy strong{display:block;font-size:1.02rem;line-height:1.15;color:var(--text)}
.brand-tagline{display:block;font-size:.86rem;color:var(--muted);line-height:1.25;max-width:260px}
.nav-center{display:flex;justify-content:center;align-items:center;min-width:0}
.nav-right{display:flex;justify-content:flex-end;align-items:center}
.primary-nav{display:flex;justify-content:center;width:100%}
.primary-nav ul{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  justify-content:center;
  align-items:center;
  gap:1.55rem;
  flex-wrap:wrap;
}
.primary-nav a{
  position:relative;
  color:#59627d;
  font-weight:800;
  font-size:1rem;
  transition:color .24s ease;
}
.primary-nav a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-9px;
  width:0;
  height:2px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--primary),var(--accent-strong));
  transition:width .28s ease;
}
.primary-nav a:hover,.primary-nav .current-menu-item>a{color:var(--text)}
.primary-nav a:hover::after,.primary-nav .current-menu-item>a::after{width:100%}

.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:56px;
  border-radius:999px;
  padding:.95rem 1.35rem;
  font-weight:800;
  border:none;
  cursor:pointer;
  transition:transform .18s ease,box-shadow .18s ease;
}
.button:hover{transform:translateY(-2px) scale(1.02)}
.button-primary{
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-2) 45%,var(--accent-strong) 100%);
  color:#fff;
  box-shadow:0 16px 40px rgba(124,58,237,.22);
}
.button-secondary{
  background:rgba(255,255,255,.75);
  color:var(--primary);
  border:1px solid var(--line);
}
.header-cta{
  min-width:168px;
  min-height:60px;
  text-align:center;
  line-height:1.15;
}
.button-full{width:100%}

/* Hero */
.hero{padding:5.25rem 0 4.5rem}
.hero-grid{
  display:grid;
  grid-template-columns:1.02fr .98fr;
  gap:3rem;
  align-items:center;
}
.hero-copy{max-width:640px}
.eyebrow,.section-kicker{
  color:var(--primary);
  font-size:.84rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-weight:900;
}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  padding:.5rem .85rem;
  border-radius:999px;
  background:rgba(124,58,237,.08);
}
.eyebrow::before{
  content:"";
  width:8px;height:8px;border-radius:50%;
  background:linear-gradient(135deg,var(--primary),var(--accent-strong));
}
.hero h1{
  color:var(--text);
  font-size:clamp(3rem,7vw,6rem);
  line-height:.92;
  letter-spacing:-.045em;
  margin:1rem 0 1.15rem;
  max-width:11ch;
}
.hero-sub,.section-header p,.why-body,.cta-subtitle{
  font-size:1.14rem;
  line-height:1.8;
  color:var(--muted);
  max-width:62ch;
}
.hero-cta-row{
  display:flex;
  flex-wrap:wrap;
  gap:1rem;
  margin:2rem 0 1.2rem;
}
.trust-points,.proof-strip{
  display:flex;
  flex-wrap:wrap;
  gap:.8rem;
}
.trust-points span,.proof-strip span{
  padding:.72rem .98rem;
  border:1px solid rgba(124,58,237,.08);
  border-radius:999px;
  background:rgba(255,255,255,.75);
  color:#5a6278;
  font-weight:700;
  box-shadow:var(--shadow);
}
.hero-visual{position:relative;isolation:isolate}
.hero-visual::before{
  content:"";
  position:absolute;
  inset:-20px -10px auto auto;
  width:220px;height:220px;border-radius:50%;
  background:radial-gradient(circle,rgba(124,58,237,.16),transparent 65%);
  z-index:-1;
}
.hero-image-wrap{
  border-radius:36px;
  overflow:hidden;
  background:linear-gradient(135deg,#f6f2ff,#f6fffa);
  padding:14px;
  border:1px solid rgba(124,58,237,.08);
  box-shadow:var(--shadow-strong);
}
.hero-image-wrap img{border-radius:28px}

/* Sections */
.logo-bar{padding:0 0 .5rem}
.section{padding:5.5rem 0}
.section-alt{
  background:
    radial-gradient(circle at 20% 10%,rgba(124,58,237,.08),transparent 28%),
    radial-gradient(circle at 85% 20%,rgba(66,199,109,.08),transparent 22%),
    linear-gradient(180deg,#f8f6ff 0%,#f7fff9 100%);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.section-header{
  display:flex;
  flex-direction:column;
  gap:.25rem;
  max-width:760px;
  margin-bottom:2rem;
}
.section h2,.cta-band h2,.quote-page h1{
  color:var(--text);
  font-size:clamp(2.2rem,4vw,3.7rem);
  line-height:1.06;
  max-width:14ch;
  letter-spacing:-.035em;
  margin:.7rem 0 .85rem;
}
.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.2rem}
.grid-2,.two-column,.cta-band-inner{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:2rem;
  align-items:start;
}
.cta-band-inner{grid-template-columns:1fr 420px}
.service-card,.benefit-item,.contact-panel,.quote-form,.quote-intake-card{
  background:rgba(255,255,255,.72);
  backdrop-filter:blur(12px);
  border:1px solid rgba(124,58,237,.08);
  border-radius:30px;
  box-shadow:0 0 0 1px rgba(124,58,237,.08),0 20px 60px rgba(21,25,54,.08);
}
.service-card,.benefit-item,.contact-panel{padding:1.55rem 1.6rem;transition:transform .22s ease,box-shadow .22s ease}
.service-card{position:relative;overflow:hidden;min-height:255px}
.service-card::before{
  content:"";
  position:absolute;inset:0 0 auto 0;height:4px;
  background:linear-gradient(90deg,var(--primary),var(--accent-strong));
}
.service-card:hover,.benefit-item:hover,.contact-panel:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow-strong);
}
.service-card h3,.benefit-item h3,.contact-panel h3{color:var(--text);font-size:1.25rem;margin-top:0}
.service-card p,.benefit-item p,.contact-panel p{color:var(--muted);line-height:1.8}
.benefit-stack{display:grid;gap:1rem}

.quote-form{padding:1.5rem;display:grid;gap:.95rem}
.quote-form label{display:grid;gap:.45rem;color:#58627b;font-weight:800}
.quote-form input,.quote-form select,.quote-form textarea{
  width:100%;
  min-height:54px;
  border:1px solid rgba(124,58,237,.12);
  border-radius:16px;
  padding:.95rem 1rem;
  font:inherit;
  color:var(--text);
  background:#fff;
}
.quote-form textarea{min-height:120px;resize:vertical}
.quote-form input:focus,.quote-form select:focus,.quote-form textarea:focus{
  outline:2px solid rgba(124,58,237,.16);
  border-color:rgba(124,58,237,.35);
}

/* Quote intake page */
.quote-page{padding:4rem 0 5rem}
.quote-intake-card{padding:2rem;margin-top:1.5rem}
.quote-intake-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.quote-intake-full{grid-column:1/-1}
.quote-intake-card label{display:grid;gap:.45rem;color:#58627b;font-weight:800}
.quote-intake-card input,.quote-intake-card select,.quote-intake-card textarea{
  width:100%;border:1px solid rgba(124,58,237,.12);border-radius:16px;padding:.95rem 1rem;font:inherit;background:#fff;color:var(--text)
}
.quote-intake-card textarea{min-height:130px;resize:vertical}
.lis-success{background:#ecfdf3;color:#17633a;border:1px solid #bbf7d0;padding:18px;border-radius:18px;margin-bottom:20px;font-weight:800}
.lis-error{background:#fff1f2;color:#9f1239;border:1px solid #fecdd3;padding:18px;border-radius:18px;margin-bottom:20px;font-weight:800}
.lis-hide-field{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;overflow:hidden!important}
.small-note{color:var(--muted);font-size:.92rem;line-height:1.5}

/* Footer */
.site-footer{
  padding:2rem 0 6rem;
  border-top:1px solid var(--line);
  background:rgba(255,255,255,.84);
}
.footer-wrap{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.footer-links{display:flex;flex-wrap:wrap;gap:1rem;color:var(--muted)}
.footer-links a:hover{color:var(--primary)}

.page-content{padding:3rem 0 5rem}
.page-content .entry-content{max-width:900px;margin:0 auto;color:var(--muted);line-height:1.8}
.mobile-menu-toggle,.sticky-mobile-cta{display:none}

/* Responsive */
@media(max-width:1100px){
  .nav{
    grid-template-columns:1fr auto;
    grid-template-areas:"left right" "center center";
    row-gap:.75rem;
  }
  .brand{grid-area:left}
  .nav-center{grid-area:center}
  .nav-right{grid-area:right}
}
@media(max-width:900px){
  .hero-grid,.grid-3,.grid-2,.two-column,.cta-band-inner,.quote-intake-grid{grid-template-columns:1fr}
  .hero h1,.section h2,.cta-band h2,.quote-page h1{max-width:none}
  .primary-nav{display:none}
  .mobile-menu-toggle{display:inline-flex;background:#fff;color:var(--primary);border:1px solid var(--line)}
  .site-header.menu-open .primary-nav{
    display:block;position:absolute;top:calc(100% + 8px);left:1rem;right:1rem;background:#fff;border:1px solid var(--line);border-radius:20px;padding:1rem;box-shadow:var(--shadow)
  }
  .site-header.menu-open .primary-nav ul{flex-direction:column;gap:.9rem}
}
@media(max-width:720px){
  .top-bar-inner{justify-content:center;text-align:center;padding:.45rem 0}
  .top-actions{justify-content:center}
  .brand-logo{width:52px;height:52px;flex-basis:52px}
  .nav{grid-template-columns:1fr auto;grid-template-areas:"left right";min-height:78px}
  .nav-center{justify-content:flex-end}
  .hero{padding-top:3.6rem}
  .site-footer{padding-bottom:7rem}
  .sticky-mobile-cta{display:block;position:fixed;bottom:0;left:0;right:0;z-index:60;padding:.75rem;background:rgba(255,255,255,.95);backdrop-filter:blur(12px);border-top:1px solid var(--line)}
}


/* V2 fix: force top utility buttons to show on live site and wrap cleanly */
.top-bar-inner{
  width:min(calc(100% - 2rem),var(--container));
  margin:0 auto;
}
.top-actions{
  margin-left:auto;
}
.top-utility-link{
  white-space:nowrap;
}
@media(max-width:1180px){
  .top-bar-inner{
    justify-content:center;
  }
  .top-contact-group,
  .top-actions{
    justify-content:center;
    width:100%;
  }
}
.header-cta{
  white-space:normal;
}
