/* Brand */
:root{
  --brand:#0C3C7E; --brand-2:#183F8F; --text:#0B1220; --muted:#5c6b82;
  --bg:#ffffff; --alt:#f6f8fb; --card:#ffffff; --accent:#C9D6EA;
  --radius:16px; --shadow:0 10px 20px rgba(0,0,0,.08);
}
*{box-sizing:border-box} html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,"Helvetica Neue",Arial,sans-serif;color:var(--text);background:var(--bg);line-height:1.6}
img{max-width:100%;height:auto;vertical-align:middle}
h1,h2,h3{font-family:"Playfair Display",Georgia,serif;line-height:1.2;margin:0 0 .5rem}
h1{font-size:clamp(2rem,3.2vw + 1rem,3.2rem)}
h2{font-size:clamp(1.6rem,2.2vw + .8rem,2.2rem)}
h3{font-size:1.25rem}
p{margin:.5rem 0 1rem}
.lead{font-size:1.125rem;max-width:70ch;margin-inline:auto}
.small{font-size:.9rem}.muted{color:var(--muted)}
.eyebrow{display:block;font-size:.9rem;letter-spacing:.08em;text-transform:uppercase;color:#e6edf8}

/* Accessibility */
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:1rem;top:1rem;width:auto;height:auto;padding:.5rem 1rem;background:#fff;color:#000;z-index:1000;border-radius:8px;box-shadow:var(--shadow)}
.sr-only{position:absolute;left:-10000px;width:1px;height:1px;overflow:hidden}

/* Header */
.site-header{position:sticky;top:0;z-index:60;background:linear-gradient(0deg,rgba(12,60,126,.95),rgba(12,60,126,1));color:#fff;box-shadow:0 2px 8px rgba(0,0,0,.05)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.6rem 1rem;max-width:1200px;margin:0 auto}
.brand{display:flex;align-items:center;text-decoration:none;color:#fff;gap:.6rem}
.brand img{width:40px;height:40px;border-radius:10px;object-fit:contain;background:rgba(255,255,255,.06)}
.brand-text{font-weight:800;letter-spacing:.2px}
.menu{display:flex;gap:1rem;align-items:center;list-style:none;margin:0;padding:0}
.link{color:#fff;text-decoration:none;font-weight:700;opacity:.9}
.link:hover,.link:focus{opacity:1;text-decoration:underline}
.nav-toggle{display:none;background:none;border:1px solid rgba(255,255,255,.4);color:#fff;padding:.4rem .6rem;border-radius:10px}
@media (max-width: 820px){
  .nav-toggle{display:inline-block}
  .menu{position:absolute;inset:56px 1rem auto 1rem;background:#0C3C7E;border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:.8rem;flex-direction:column;display:none}
  .menu.open{display:flex}
}

/* Buttons (interactive) */
.btn{display:inline-block;text-decoration:none;font-weight:800;border-radius:999px;padding:.62rem 1.05rem;transition:transform .12s ease,box-shadow .12s ease;cursor:pointer;user-select:none}
.btn:focus{outline:3px solid #9cc0ff;outline-offset:2px}
.btn-primary{background:#fff;color:var(--brand);border:2px solid #fff;box-shadow:0 8px 18px rgba(0,0,0,.08)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 12px 20px rgba(0,0,0,.12)}
.btn-outline{background:transparent;color:#fff;border:2px solid #cfe0ff}
.btn-outline:hover{transform:translateY(-1px);background:rgba(255,255,255,.06)}
.btn-small{padding:.45rem .8rem}

/* Non-interactive labels */
.tags{display:flex;gap:.8rem;list-style:none;margin:1.2rem 0 0;padding:0;flex-wrap:wrap;justify-content:center}
.tag{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.25);color:#e8f0ff;border-radius:999px;padding:.45rem .75rem;cursor:default}
.pill-list{display:flex;gap:.5rem;flex-wrap:wrap;margin:.5rem 0 1rem;justify-content:center}
.chip{display:inline-block;background:#eef3ff;border:1px solid #dfe8fb;color:var(--brand);padding:.4rem .7rem;border-radius:999px;text-decoration:none;font-weight:700}
.chip:hover{background:#e3ebff}

/* Hero + brand parallax (no photos) */
.hero{position:relative;overflow:hidden;color:#fff;text-align:center}
.parallax{position:absolute;inset:0;z-index:-1;overflow:hidden}
.layer{position:absolute;inset:-10%;will-change:transform}
.layer-grad{background:radial-gradient(90% 120% at 10% 10%, #315EAA 0%, #0C3C7E 40%, #072A54 100%)}
.layer-shine{background:radial-gradient(60% 40% at 80% 0%, rgba(255,255,255,.18), transparent 70%)}
.layer-shapes{
  background:
    radial-gradient(12px 12px at 20% 70%, rgba(255,255,255,.06) 40%, transparent 41%) repeat,
    radial-gradient(18px 18px at 60% 30%, rgba(255,255,255,.05) 40%, transparent 41%) repeat;
  background-size:160px 160px, 240px 240px;
}
@media (prefers-reduced-motion: reduce){ .layer{transform:none!important} }
.hero-inner{max-width:1100px;margin:0 auto;padding:clamp(3rem,7vw,6rem) 1rem}
.hero-logo{display:block;margin:0 auto 1rem;width:min(220px,40vw);height:auto;filter:drop-shadow(0 8px 20px rgba(0,0,0,.25));border-radius:18px;background:rgba(255,255,255,.05)}
.cta-row{display:flex;gap:.8rem;margin:1rem 0 1.2rem;flex-wrap:wrap;justify-content:center}

/* Sections */
.section{padding:clamp(2.5rem,6vw,4rem) 1rem}
.section.alt{background:var(--alt)}
.container{max-width:1100px;margin:0 auto}
.section-intro{max-width:70ch;margin-inline:auto;text-align:center}

/* Card grid */
.cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;margin-top:1rem}
@media (max-width: 900px){ .cards{grid-template-columns:1fr} }

/* Card and media */
.card{
  background:var(--card);
  border:1px solid #e6ecf7;
  border-radius:var(--radius);
  padding:0;
  box-shadow:var(--shadow);
  transition:transform .2s ease, box-shadow .2s ease;
}
.card:hover{transform:translateY(-3px);box-shadow:0 16px 26px rgba(0,0,0,.12)}

/* Image in the top band (uses the --img inline var) */
.card-media{
  height:180px;
  border-radius:16px 16px 0 0;
  background-image:
    linear-gradient(to bottom, rgba(7,42,84,0) 55%, rgba(7,42,84,.10) 100%),
    var(--img);
  background-size:cover;
  background-position:center;
}

/* Centered text in cards */
.card-body{padding:1rem;text-align:center}
.card h3{margin:.2rem 0 .4rem;text-align:center}
.card p{margin:0;text-align:center}

/* Parallax brand band */
.band{position:relative}
.band-bg{position:relative;height:44vh;min-height:250px;overflow:hidden}
.band-layer{position:absolute;inset:-15%;will-change:transform}
.band-grad{background:linear-gradient(90deg,#0C3C7E,#183F8F)}
.band-grid{
  background-image:repeating-linear-gradient(0deg, rgba(255,255,255,.06) 0 2px, transparent 2px 40px),
                   repeating-linear-gradient(90deg, rgba(255,255,255,.06) 0 2px, transparent 2px 40px);
}
@media (prefers-reduced-motion: reduce){ .band-layer{transform:none!important} }
.band-caption{position:absolute;left:50%;bottom:10%;transform:translateX(-50%);color:#fff;background:rgba(0,0,0,.3);padding:.5rem .8rem;border-radius:10px}

/* Estimator */
.estimator{background:#fff;border:1px solid #e6ecf7;border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow);margin-top:.5rem}
.estimator .grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}
label{display:flex;flex-direction:column;gap:.35rem;font-weight:800}
label.number{gap:.3rem;font-weight:700}
input[type="text"],input[type="email"],input[type="number"],select,textarea{border:1px solid #c8d2e5;border-radius:12px;padding:.6rem .7rem;font:inherit;outline-offset:2px}
.checkbox{flex-direction:row;align-items:center;gap:.5rem;font-weight:700}
.addons{margin:.6rem 0;border:1px dashed #c8d2e5;border-radius:12px;padding:.6rem}
.hide{display:none}
.estimate{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-top:.5rem}
output#estimate{font-weight:800;font-size:1.4rem;background:#F1F5FF;border:1px solid #dfe8fb;border-radius:999px;padding:.4rem .8rem}
.breakdown{margin-top:.6rem}.breakdown[open] summary{margin-bottom:.3rem}
.breakdown ul{margin:.4rem 0;padding-left:1.2rem}
.disabled{opacity:.6;pointer-events:none}

/* Info boxes (text containers distinct from buttons) */
.info-box{background:#fff;border:1px solid #e6ecf7;border-radius:16px;padding:1rem;box-shadow:var(--shadow);margin-top:1rem}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;align-items:start}
.contact-form{background:#fff;border:1px solid #e6ecf7;border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow)}
.contact-list{list-style:none;padding:0;margin:.5rem 0 1rem}
.contact-list .link{color:var(--brand);text-decoration:none}
@media (max-width: 880px){ .contact-grid{grid-template-columns:1fr} }

/* Footer */
.footer{background:#041F46;color:#cdd8ee;padding:1rem}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;max-width:1100px;margin:0 auto;flex-wrap:wrap}
.footer .link{color:#cdd8ee;text-decoration:none}
.footer .link:hover{color:#fff;text-decoration:underline}

/* --- Center all section titles + intro text --- */
.section h2,
.section .section-intro {
  text-align: center;
}

/* --- Estimator: make Optional add-ons span both columns & center --- */
.estimator .grid .addons {
  grid-column: 1 / -1;        /* span full width across the 2-column grid */
}

.addons {
  text-align: center;          /* center legend + labels */
  max-width: 720px;            /* tidy, readable width */
  margin: .6rem auto;          /* center the whole box */
  border: 1px dashed #c8d2e5;
  border-radius: 12px;
  padding: .6rem;
}

.addons legend {
  font-weight: 800;
  margin: 0 auto .4rem;        /* centers the legend text */
  padding: 0 .4rem;
}

.addons label.number,
.addons .checkbox {
  align-items: center;         /* center label + control vertically */
}

/* make the number fields look neat and centered within the box */
.addons input[type="number"] {
  max-width: 340px;
  margin: .25rem auto;
  text-align: center;
  display: block;
}

/* --- Estimator: center the button + price bubble --- */
.estimate {
  justify-content: center;     /* centers Calculate + output */
}

/* keep the price bubble visually strong when centered */
output#estimate {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 180px;
  text-align: center;
}

/* Fix: outline buttons should be readable on light backgrounds */
.btn-outline{
  color: var(--brand);               /* visible on white cards */
  border: 2px solid #c8d2e5;
  background: #fff;
}
.btn-outline:hover{
  background: #f4f7ff;
}

/* Keep outline buttons white ONLY on the dark hero */
.hero .btn-outline{
  color: #fff;
  border-color: #cfe0ff;
  background: transparent;
}
.hero .btn-outline:hover{
  background: rgba(255,255,255,.06);
}

/* Optional: make "disabled" state still readable */
.disabled{ opacity: .65; }

/* Center the cost breakdown + the "Email this estimate" button */
#breakdownWrap { 
  text-align: center;                 /* centers inline elements inside details */
}

#breakdownWrap .info-box {
  display: inline-block;              /* keep the box snug and centered */
  text-align: left;                   /* list remains left-aligned inside the box */
  margin: .4rem auto .6rem;           
  max-width: 720px;
}

/* Make the email button center itself */
#emailLink {
  display: block;                     /* block allows auto margins to center */
  width: max-content;                 /* shrink to its content */
  margin: .75rem auto 0;              /* <-- centers the button */
}

/* CONTACT — interactive action cards */
.contact-actions{
  display:grid;
  gap:12px;
  align-content:start;
}
.action-card{
  --r:18px;
  position:relative;
  border-radius:var(--r);
  padding:1px; /* gradient border thickness */
  background:
    conic-gradient(from 180deg at 50% 50%, #cddcff, #9db7ff, #cddcff);
  box-shadow:0 12px 26px rgba(12,60,126,.08);
  opacity:0; transform:translateY(8px);
  transition:opacity .5s ease, transform .5s ease;
}
.action-card.in{ opacity:1; transform:none; }
.action-card-inner{
  border-radius:calc(var(--r) - 1px);
  background:#fff;
  padding:14px;
}
.action-head{
  display:flex; align-items:center; gap:.5rem;
  font-weight:800; color:var(--brand);
}
.big-link{
  display:block;
  font-weight:800;
  font-size:clamp(1rem, 1vw + .9rem, 1.25rem);
  color:#0b1a36; text-decoration:none;
  margin:.2rem 0 .6rem;
  word-break:break-word;
}
.big-link:hover{ text-decoration:underline; }
.action-buttons{ display:flex; gap:.5rem; align-items:center; flex-wrap:wrap }

.action-utility{
  display:flex; gap:.6rem; align-items:center; margin-top:.4rem;
}
.btn-ghost{
  background:transparent; color:var(--brand);
  border:2px dashed #b9c9f0;
}
.btn-ghost:hover{ background:#f4f7ff }

/* Subtle reveal preference */
@media (prefers-reduced-motion: reduce){
  .action-card{ opacity:1; transform:none; }
}

/* Optional toast for copy feedback */
.toast{
  position:fixed; left:50%; bottom:22px; transform:translateX(-50%);
  background:#072a54; color:#fff;
  padding:.45rem .8rem; border-radius:999px;
  box-shadow:0 10px 22px rgba(0,0,0,.2);
  z-index:1200; font-weight:800; font-size:.95rem;
  opacity:0; pointer-events:none; transition:opacity .2s ease, transform .2s ease;
}
.toast.show{ opacity:1; transform:translate(-50%,-2px); }

/* Floating quick-contact reveal on scroll (optional) */
(function(){
  const bar = document.getElementById('quickContact');
  if(!bar) return;
  const reduce = window.matchMedia('(prefers-reduced-motion: reduce)').matches;
  const reveal = () => {
    const y = window.scrollY || 0;
    // show after user has engaged with page (e.g., >600px scroll)
    bar.hidden = y < 600;
    if(!reduce && !bar.hidden){
      bar.style.opacity = '1';
      bar.style.transform = 'translateY(0)';
    }
  };
  // initial state
  bar.style.opacity = '0'; bar.style.transform = 'translateY(8px)';
  reveal();
  window.addEventListener('scroll', reveal, { passive:true });
})();



.estimator #estimateNote {
  text-align: center !important;
  margin: 0.75rem auto 0;
  max-width: 60rem;
}



