:root{
  /* Core */
  --bb-text:#0b1220;
  --bb-muted:#55657a;
  --bb-line:rgba(15,23,42,.12);
  --bb-bg:#ffffff;

  /* Brand palette inspired by Morro Bay sunsets + coastal blues */
  --bb-primary:#071a2f;          /* deep navy */
  --bb-ocean:#0b5d7a;            /* ocean blue */
  --bb-sky:#1ea7d7;              /* bright coastal sky */
  --bb-sunset:#f97316;           /* sunset orange */
  --bb-sand:#f3e6d6;             /* warm sand */
  --bb-foam:#e9f4f7;             /* sea-foam light */
  --bb-soft:#f6f8fb;

  --bb-max:1120px;
  --bb-radius:20px;
  --bb-shadow: 0 18px 50px rgba(2,8,23,.14);

  --bb-hero-image: url('assets/photos/morro-sunset.jpg');
}


/*
Theme Name: Boulder To Bay
Theme URI: https://bouldertobay.com/
Author: Aaron Bouplon
Description: Custom WordPress theme for Boulder To Bay Finance & Insurance.
Version: 1.1.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: bouldertobay
*/


*{box-sizing:border-box}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--bb-text);
  background:var(--bb-bg);
  line-height:1.5;
}
a{color:var(--bb-accent); text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:var(--bb-max); margin:0 auto; padding:0 20px;}
.site-header{
  border-bottom:1px solid var(--bb-line);
  background:rgba(255,255,255,.92); backdrop-filter:saturate(180%) blur(10px);
  position:sticky; top:0; z-index:50;
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; padding:14px 0;
}
.brand{display:flex; align-items:center; gap:12px; min-width:220px}
.brand img{height:48px; width:auto; display:block}
.brand .site-title{font-weight:700; letter-spacing:.02em}
.nav-toggle{display:none; background:none; border:1px solid var(--bb-line); padding:10px 12px; border-radius:10px}
.primary-nav ul{list-style:none; display:flex; gap:18px; margin:0; padding:0; align-items:center}
.primary-nav a{color:var(--bb-text); font-weight:600}
.primary-nav a:hover{color:var(--bb-accent); text-decoration:none}

.hero{padding:64px 0 34px; border-bottom:1px solid var(--bb-line); background:linear-gradient(135deg, rgba(11,31,59,.06) 0%, rgba(15,118,110,.08) 45%, rgba(215,185,142,.14) 100%);} 

.btn-primary:hover{text-decoration:none; filter:brightness(.95)}
.btn-secondary{background:transparent; color:var(--bb-primary); border-color:rgba(11,31,59,.25)}
.btn-secondary:hover{background:rgba(15,118,110,.08); border-color:rgba(15,118,110,.35);}

.btn-secondary:hover{text-decoration:none; background:#f9fafb}

.card{border:1px solid var(--bb-line); border-radius:var(--bb-radius); padding:22px; background:#fff; box-shadow:var(--bb-shadow);}
.grid-3{display:grid; grid-template-columns: repeat(3, 1fr); gap:16px}
.section{padding:34px 0; border-bottom:1px solid var(--bb-line)}
.section h2{margin:0 0 12px; font-size:1.55rem}
.section p{color:var(--bb-muted); margin:0 0 14px}
.badge{display:inline-block; padding:6px 10px; border-radius:999px; border:1px solid rgba(11,31,59,.18); color:var(--bb-primary); background:rgba(11,31,59,.04); font-size:.86rem;}

.site-footer{padding:26px 0; font-size:.93rem; color:var(--bb-muted)}
.footer-grid{display:grid; grid-template-columns: 1.2fr .8fr; gap:18px; align-items:start}
.disclosures{font-size:.85rem; color:#6b7280; margin-top:12px}
.small{font-size:.9rem}

.page-wrap{padding:28px 0}
.entry-title{margin:.2rem 0 1rem}
.content{max-width:820px}
.content p{color:var(--bb-muted)}
.content h2, .content h3{color:var(--bb-text)}
.form-row{display:grid; grid-template-columns: 1fr 1fr; gap:12px}
label{font-weight:700; font-size:.92rem}
input, textarea{
  width:100%; padding:12px 12px; border-radius:12px; border:1px solid var(--bb-line);
  font:inherit;
}
textarea{min-height:140px}
.notice{padding:12px 14px; border-radius:12px; border:1px solid var(--bb-line); background:#fafafa; margin:14px 0}

@media (max-width: 860px){
  .hero-grid{grid-template-columns: 1fr}
  .grid-3{grid-template-columns: 1fr}
  .nav-toggle{display:inline-flex}
  .primary-nav{display:none}
  .primary-nav.is-open{display:block}
  .primary-nav ul{flex-direction:column; align-items:flex-start; padding:10px 0}
}

.section-alt{background:var(--bb-soft);}


/* --- Modern hero treatment (photo + glass) --- */
.hero.hero-photo{
  position:relative;
  padding:88px 0 70px;
  color:#fff;
  background:
    radial-gradient(1200px 600px at 18% 20%, rgba(30,167,215,.28), rgba(0,0,0,0) 60%),
    radial-gradient(900px 500px at 70% 10%, rgba(249,115,22,.22), rgba(0,0,0,0) 55%),
    linear-gradient(180deg, rgba(7,26,47,.78), rgba(7,26,47,.50)),
    var(--bb-hero-image) center/cover no-repeat;
  overflow:hidden;
}
.hero-overlay{
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.15), rgba(0,0,0,.35));
  pointer-events:none;
}
.hero-grid{ position:relative; z-index:1; display:grid; gap:26px; grid-template-columns: 1.1fr .9fr; align-items:stretch;}
@media (max-width: 920px){ .hero-grid{grid-template-columns:1fr;} .hero.hero-photo{padding:72px 0 58px;} }

.hero-copy .kicker{color:rgba(255,255,255,.82)}
.hero-copy h1{font-size: clamp(34px, 4vw, 52px); line-height:1.05; margin:.35rem 0 .75rem; letter-spacing:-.02em;}
.hero-copy .lead{color:rgba(255,255,255,.88); font-size: 1.05rem; max-width: 52ch;}
.hero-footnote{margin-top:16px; color:rgba(255,255,255,.78)}
.hero-link{color:#fff; text-decoration:underline; text-underline-offset: 3px;}
.hero-link:hover{opacity:.9}

.hero-panel{display:flex; flex-direction:column; gap:14px;}
.panel-card{
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: var(--bb-radius);
  box-shadow: 0 18px 60px rgba(0,0,0,.25);
  padding:18px 18px 16px;
  backdrop-filter: blur(10px);
}
.panel-links{display:grid; gap:10px; margin-top:10px;}
.panel-links a{
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.14);
  color:#fff;
  text-decoration:none;
}
.panel-links a:hover{background: rgba(255,255,255,.16);}

.photo-strip{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:10px;
}
.photo-strip img{
  width:100%; height:110px; object-fit:cover;
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.18);
  box-shadow: 0 16px 40px rgba(0,0,0,.22);
}

/* Buttons */
.btn{border-radius: 999px; font-weight:650; letter-spacing:.01em;}
.btn-primary{
  background: linear-gradient(135deg, var(--bb-sky), var(--bb-ocean));
  border: 1px solid rgba(255,255,255,.14);
}
.btn-primary:hover{filter: brightness(1.05);}
.btn-ghost{
  background: rgba(255,255,255,.10);
  color:#fff;
  border: 1px solid rgba(255,255,255,.22);
}
.btn-ghost:hover{background: rgba(255,255,255,.16); text-decoration:none}

/* Section polish */
.section-alt{
  background:
    radial-gradient(900px 500px at 10% 0%, rgba(30,167,215,.10), rgba(0,0,0,0) 60%),
    radial-gradient(900px 500px at 90% 10%, rgba(249,115,22,.10), rgba(0,0,0,0) 55%),
    linear-gradient(180deg, #ffffff, var(--bb-foam));
  border-top:1px solid var(--bb-line);
  border-bottom:1px solid var(--bb-line);
}
.card{
  border:1px solid rgba(15,23,42,.10);
}
.badge{
  background: rgba(30,167,215,.10);
  border: 1px solid rgba(30,167,215,.22);
  color: var(--bb-primary);
}

/* Footer gradient */
.site-footer{
  background:
    radial-gradient(900px 500px at 20% 20%, rgba(30,167,215,.12), rgba(0,0,0,0) 60%),
    radial-gradient(900px 500px at 80% 10%, rgba(249,115,22,.10), rgba(0,0,0,0) 55%),
    linear-gradient(180deg, var(--bb-primary), #030b16);
  color: rgba(255,255,255,.86);
}
.site-footer a{color:#fff}


/* === Button Spacing Enhancement (v4) === */
button,
.button,
.wp-block-button__link,
input[type="submit"] {
    padding: 16px 32px;
    letter-spacing: 0.1em;
    font-weight: 600;
}


/* === Global Button Spacing Fix (v5) === */
.btn,
.btn-primary,
.btn-ghost,
button,
.button,
.wp-block-button__link,
input[type="submit"],
a[class*="btn"] {
    padding: 18px 36px !important;
    letter-spacing: 0.12em;
    line-height: 1.4;
    font-weight: 600;
    box-sizing: border-box;
}

/* Ensure inner spans or icons don't collapse spacing */
.btn span,
.button span,
.wp-block-button__link span {
    display: inline-block;
    padding: 2px 0;
}


/* === Footer Contact Visibility Fix (v6) === */
.site-footer {
    background: linear-gradient(180deg, #0f2a3a 0%, #0b1f2b 100%);
    color: #e6eef4;
}

.site-footer a {
    color: #cfe3ef;
    text-decoration: none;
}

.site-footer a:hover {
    color: #ffffff;
}

.site-footer .footer-contact,
.site-footer .footer-contact p,
.site-footer .footer-contact span {
    color: #e6eef4;
}

.site-footer h4,
.site-footer h5 {
    color: #ffffff;
    letter-spacing: 0.08em;
}

.site-footer .footer-contact {
    background: rgba(255,255,255,0.04);
    padding: 24px;
    border-radius: 8px;
}


/* === Footer Contact Card Contrast Fix (v7) === */
/* Keep footer links light on dark background... */
.site-footer a { color: #cfe3ef; }

/* ...but force dark text/links inside the white contact card */
.site-footer .card {
  background: #ffffff;
  color: #0b1f2b;
  border: 1px solid rgba(11,31,43,0.10);
  box-shadow: 0 12px 32px rgba(0,0,0,0.18);
}

.site-footer .card .kicker,
.site-footer .card strong {
  color: #0b1f2b;
}

.site-footer .card a {
  color: #0f5f7a;
  text-decoration: none;
}

.site-footer .card a:hover {
  color: #08384a;
  text-decoration: underline;
}

/* Improve readability of the left-side footer copy/disclosures */
.site-footer,
.site-footer p,
.site-footer li,
.site-footer .small {
  color: rgba(230, 238, 244, 0.92);
}

.site-footer .small {
  margin-top: 6px;
  color: rgba(230, 238, 244, 0.80);
}

/* Ensure CTA row buttons never inherit footer link colors */
.site-footer .cta-row .btn {
  color: #ffffff !important;
}

.site-footer .cta-row .btn.btn-secondary,
.site-footer .cta-row .btn.btn-ghost {
  background: transparent !important;
  color: #0f5f7a !important;
  border: 2px solid rgba(15,95,122,0.35) !important;
}

.site-footer .cta-row .btn.btn-secondary:hover,
.site-footer .cta-row .btn.btn-ghost:hover {
  border-color: rgba(15,95,122,0.70) !important;
  color: #08384a !important;
}


/* === Footer layout fixes (v8) === */

/* Make footer grid a two-column layout with spacing */
.container.footer-grid {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 40px;
  align-items: start;
  padding: 48px 24px;
}

/* Ensure left column has enough breathing room for long disclosures */
.site-footer .footer-left {
  padding-right: 24px;
  line-height: 1.6;
  max-width: 100%;
}

/* Make the contact card fixed width and prevent overflowing */
.site-footer .card {
  width: 100%;
  max-width: 520px;
  box-sizing: border-box;
  padding: 28px;
  overflow: visible;
}

/* CTA row: ensure buttons sit horizontally with gap and wrap properly */
.site-footer .cta-row {
  display: flex;
  gap: 16px;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  margin-top: 18px;
}

/* Make sure primary button doesn't overlap text (give it its own spacing) */
.site-footer .cta-row .btn {
  min-width: 160px;
  padding: 14px 28px !important;
  border-radius: 40px;
}

/* Secondary/ghost buttons */
.site-footer .cta-row .btn.btn-secondary,
.site-footer .cta-row .btn.btn-ghost {
  min-width: 160px;
  padding: 12px 26px !important;
  border-radius: 40px;
}

/* Prevent anchor text inside the card wrapping under buttons */
.site-footer .card .contact-lines {
  margin-bottom: 12px;
}

/* Small screens: stack the layout */
@media (max-width: 840px) {
  .container.footer-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .site-footer .card {
    max-width: 100%;
  }
  .site-footer .cta-row {
    justify-content: flex-start;
  }
}

