/* style.css */
:root{
  --bg:#ffffff;
  --text:#0f172a;
  --muted:#475569;

  --accent:#1f4e79;
  --accent-2:#f5b400;

  --surface:#f8fafc;
  --card:#ffffff;
  --border:#e2e8f0;

  --ring: rgba(31,78,121,.30);
  --shadow: 0 10px 22px rgba(2,6,23,.10);

  --radius-sm:.375rem;
  --radius-md:.5rem;
  --radius-lg:.75rem;

  --container: 1200px;

  --font: ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";
  --leading: 1.6;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: var(--font);
  color: var(--text);
  background: var(--bg);
  line-height: var(--leading);
  font-size: 18px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a{color: var(--accent); text-decoration:none}
a:hover{text-decoration: underline}
:focus-visible{outline:2px solid var(--accent-2); outline-offset: 2px}
::selection{background: var(--accent-2); color: #111}

.container{width:min(var(--container), 92%); margin-inline:auto}

.paymentsimg{width:300px;max-width:100%;height:auto;display:block}
.
.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 .75rem;
  background:#111;
  color:#fff;
  z-index:9999;
  border-radius: var(--radius-sm);
}

.site-header{
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--bg);
  border-bottom: 1px solid var(--border);
}

.header-wrap{
  display:grid;
  grid-template-columns: 400px 1fr 400px;
  align-items:center;
  gap: 1rem;
  padding: .75rem 0;
}

.brand{display:block}
.brand-logo{display:block; max-width:100%; height:auto}

.center-stack{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap: .55rem;
}

.clicktocall img{display:block; max-width:100%; height:auto}

.nav-row{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
}

.nav-toggle{display:none}

.nav-toggle-btn{
  display:none;
  width:44px;
  height:38px;
  cursor:pointer;
  border:1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--card);
  box-shadow: 0 6px 14px rgba(2,6,23,.06);
  align-items:center;
  justify-content:center;
  gap: 5px;
}
.nav-toggle-btn span{
  width: 24px;
  height: 3px;
  background: var(--accent);
  border-radius: 2px;
  display:block;
  transition: transform .25s ease, opacity .25s ease;
}

.site-nav{width:100%}
.menu{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  gap:.35rem;
  align-items:center;
  justify-content:center;
  flex-wrap: wrap;
}
.menu > li{position:relative}

.menu a,
.sub-toggle{
  display:block;
  padding: .55rem .8rem;
  border-radius: var(--radius-sm);
  color: var(--text);
  font-weight: 650;
}
.menu a.active{
  background: rgba(245,180,0,.22);
  border: 1px solid rgba(245,180,0,.35);
}
.menu a:hover{background: rgba(31,78,121,.07); text-decoration:none}

.sub-toggle{
  appearance:none;
  border: 1px solid transparent;
  background: transparent;
  cursor:pointer;
  font: inherit;
  color: var(--text);
}
.sub-toggle:hover{
  background: rgba(31,78,121,.07);
}
.has-sub .sub-toggle::after{
  content:"▾";
  margin-left:.35rem;
  color: var(--muted);
  font-weight: 800;
}

.sub-menu{
  list-style:none;
  padding:.35rem;
  margin:0;
  position:absolute;
  top: calc(100% + .35rem);
  left: 0;
  min-width: 240px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow);
  display:none;
  z-index: 60;
}
.sub-menu li a{
  padding: .6rem .7rem;
  border-radius: var(--radius-sm);
  font-weight: 600;
}
.sub-menu li a:hover{
  background: rgba(245,180,0,.18);
  text-decoration:none;
}

.has-sub:hover .sub-menu{display:block}
.sub-menu[data-open="true"]{display:block}

.social{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  gap:.6rem;
  align-items:center;
  justify-content:center;
  flex-wrap: wrap;
}
.social-btn{
  width: 42px;
  height: 42px;
  display:grid;
  place-items:center;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--card);
  box-shadow: 0 6px 14px rgba(2,6,23,.06);
}
.social-btn svg{
  width: 20px;
  height: 20px;
  fill: var(--accent);
}
.social-btn:hover{
  text-decoration:none;
  border-color: rgba(31,78,121,.35);
}

.floating-phone{
  position: fixed;
  right: 1rem;
  bottom: 1rem;
  z-index: 100;
  display:flex;
  align-items:center;
  gap: .6rem;
  padding: .75rem 1rem;
  border-radius: 999px;
  background: var(--accent);
  color: #fff;
  border: 2px solid var(--accent-2);
  box-shadow: var(--shadow);
  font-weight: 800;
}
.floating-phone:hover{
  text-decoration:none;
  transform: translateY(-1px);
}
.phone-icon svg{width:20px; height:20px; fill:#fff}

.layout{
  display:grid;
  grid-template-columns: 1fr 25%;
  gap: 1.25rem;
  padding: 1.25rem 0 2rem 0;
}

.main{
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: 0 6px 16px rgba(2,6,23,.06);
  padding: 1rem;
}
.main h1{
  margin: .25rem 0 .75rem 0;
  font-size: clamp(1.4rem, 2.2vw + 1rem, 2.1rem);
  line-height: 1.2;
}
.content-placeholder{
  min-height: 320px;
  padding: .75rem;
  border: 1px dashed rgba(31,78,121,.25);
  border-radius: var(--radius-md);
  background: rgba(248,250,252,.8);
  color: var(--muted);
  overflow-wrap:anywhere;
}

.sidebar{
  display:flex;
  flex-direction:column;
  gap: 1rem;
}

.widget{
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: 0 6px 16px rgba(2,6,23,.06);
  padding: 1rem;
}
.widget-title{
  margin: 0 0 .75rem 0;
  font-size: 1.05rem;
  line-height: 1.2;
}

.field{display:flex; flex-direction:column; gap:.35rem; margin: 0}
.label{font-weight: 700; color: var(--muted); font-size: .95rem}

input, textarea, button{font: inherit}
input, textarea{
  border: 1px solid #cbd5e1;
  border-radius: .65rem;
  padding: .65rem .75rem;
  background: #fff;
  color: var(--text);
}
input:focus, textarea:focus{
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--ring);
}

.actions{display:flex; gap:.6rem; margin-top:.75rem}
button{
  border: 2px solid var(--accent);
  background: var(--accent);
  color: #fff;
  border-radius: .65rem;
  padding: .6rem .85rem;
  font-weight: 800;
  cursor:pointer;
}
button:hover{filter: brightness(.97)}

.contact-list{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:.6rem;
}
.contact-label{
  display:block;
  color: var(--muted);
  font-weight: 700;
  font-size: .92rem;
}

.map{
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow:hidden;
}
.map iframe{
  width: 100%;
  height: 220px;
  border: 0;
  display:block;
}
.hint{
  margin: .65rem 0 0 0;
  color: var(--muted);
  font-size: .95rem;
}

.quote .grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: .75rem;
}

.payments{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: .75rem;
}
.pay{
  display:flex;
  align-items:center;
  gap:.6rem;
  padding: .6rem .65rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--surface);
}
.pay svg{width: 46px; height: 30px}
.pay svg rect{
  fill: #fff;
  stroke: rgba(15,23,42,.18);
  stroke-width: 2;
}
.pay svg path,
.pay svg circle{fill: var(--accent)}
.pay span{font-weight: 800; color: var(--text)}

.site-footer{
  border-top: 1px solid var(--border);
  background: var(--surface);
}
.footer-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  padding: 1.5rem 0;
}
.footer-title{margin:0 0 .75rem 0; font-size: 1.05rem}
.footer-links{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:.4rem;
}
.hours{margin:0; color: var(--text); font-weight: 650}
.footer-bottom{
  border-top: 1px solid var(--border);
  padding: .9rem 0;
  text-align:center;
  color: var(--muted);
}

/* UCSDtbl (pricing table) */
.UCSDtbl{
  width:100%;
  border-collapse: collapse;
  border:1px solid var(--border);
  background: var(--card);
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: 0 6px 16px rgba(2,6,23,.06);
}

.UCSDtbl td{
  border-top:1px solid var(--border);
  border-left:1px solid var(--border);
  padding:.75rem .85rem;
  vertical-align: top;
  line-height: 1.45;
}

.UCSDtbl tr td:first-child{
  border-left:0;
  font-weight:700;
}

.UCSDtbl tr:first-child td{
  border-top:0;
  background: rgba(31,78,121,.08);
  font-weight: 900;
  color: var(--text);
}

.UCSDtbl tr:nth-child(even) td{
  background: rgba(248,250,252,.85);
}

.UCSDtbl tr:hover td{
  background: rgba(245,180,0,.12);
}

@media (max-width: 720px){
  .UCSDtbl,
  .UCSDtbl tbody,
  .UCSDtbl tr,
  .UCSDtbl td{
    display:block;
    width:100%;
  }

  .UCSDtbl{
    border:1px solid var(--border);
  }

  .UCSDtbl tr{
    border-top:1px solid var(--border);
  }

  .UCSDtbl tr:first-child{
    display:none;
  }

  .UCSDtbl td{
    border:0;
    border-top:1px solid var(--border);
    padding:.7rem .85rem;
  }

  .UCSDtbl td:nth-child(1)::before{content:"Service Type"; display:block; color: var(--muted); font-weight: 800; font-size:.92rem; margin-bottom:.15rem;}
  .UCSDtbl td:nth-child(2)::before{content:"Description"; display:block; color: var(--muted); font-weight: 800; font-size:.92rem; margin-bottom:.15rem;}
  .UCSDtbl td:nth-child(3)::before{content:"Estimated Price"; display:block; color: var(--muted); font-weight: 800; font-size:.92rem; margin-bottom:.15rem;}

  .UCSDtbl td:last-child{
    font-weight: 900;
    color: var(--accent);
  }
}


@media (max-width: 1100px){
  .header-wrap{grid-template-columns: 320px 1fr 320px}
}
@media (max-width: 980px){
  .header-wrap{grid-template-columns: 1fr; gap: .75rem}
  .brand{display:flex; justify-content:center}
  .clicktocall{display:flex; justify-content:center}
  .layout{grid-template-columns: 1fr}
  .payments{grid-template-columns: 1fr 1fr}
}

@media (max-width: 860px){
  .nav-toggle-btn{display:flex}
  .site-nav{
    position: fixed;
    inset: 86px 0 auto 0;
    background: var(--bg);
    border-bottom: 1px solid var(--border);
    transform: translateY(-130%);
    transition: transform .25s ease;
    box-shadow: var(--shadow);
    padding: .75rem 0;
    z-index: 70;
  }
  .menu{
    flex-direction: column;
    align-items: stretch;
    width: min(720px, 92%);
    margin-inline: auto;
  }
  .menu a,
  .sub-toggle{
    padding: .9rem 1rem;
    border-radius: var(--radius-md);
    border: 1px solid var(--border);
    background: var(--card);
  }

  .has-sub:hover .sub-menu{display:none}
  .sub-menu{
    position: static;
    min-width: auto;
    margin-top: .5rem;
    padding: .5rem;
  }
  .sub-menu li a{border: 1px solid var(--border)}

  .nav-toggle:checked ~ .site-nav{transform: translateY(0)}
  .nav-toggle:checked + .nav-toggle-btn span:nth-child(1){transform: translateY(8px) rotate(45deg)}
  .nav-toggle:checked + .nav-toggle-btn span:nth-child(2){opacity:0}
  .nav-toggle:checked + .nav-toggle-btn span:nth-child(3){transform: translateY(-8px) rotate(-45deg)}
}

@media (max-width: 520px){
  .payments{grid-template-columns: 1fr}
  .floating-phone{left: 1rem; right: 1rem; justify-content:center}
}
