/* Brickstone Builders — Clean Stylesheet */

:root{
  --accent:#d18912;
  --accent-2:#b97910;
  --text:#1f2937;
  --muted:#6b7280;
  --bg:#ffffff;
  --soft:#ffffff;
  --card:#ffffff;
  --border:rgba(17,24,39,.10);
  --border-strong:rgba(17,24,39,.16);
  --shadow-xs:0 1px 0 rgba(17,24,39,.04);
  --shadow-sm:0 10px 22px rgba(17,24,39,.08);
  --shadow:0 16px 40px rgba(17,24,39,.10);
  --shadow-lg:0 26px 70px rgba(17,24,39,.14);
  --radius:20px;
  --radius-sm:14px;

  --font-sans: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --font-serif: "Playfair Display", ui-serif, Georgia, "Times New Roman", Times, serif;
}

*{box-sizing:border-box}
html,body{
  margin:0;
  padding:0;
  font-family:var(--font-sans);
  color:var(--text);
  background:var(--bg);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1140px,92%);margin:0 auto}

/* Typography */
h1,h2,h3,h4{font-family:var(--font-serif);letter-spacing:-0.02em}
.muted{color:var(--muted)}
.center{display:flex;justify-content:center}
.center-text{text-align:center}

/* Topbar */
.topbar{background:#fff;border-bottom:1px solid var(--border);box-shadow:0 1px 0 rgba(17,24,39,.03)}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px 0;flex-wrap:wrap}
.mini{font-size:13px;color:#111827;display:inline-flex;align-items:center;gap:8px}
.dot{width:8px;height:8px;border-radius:999px;background:var(--accent)}
.sep{color:#d1d5db}
.phone{font-weight:800;color:#111827}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  border:none;
  background:linear-gradient(180deg,var(--accent),var(--accent-2));
  color:#fff;font-weight:900;
  padding:12px 16px;border-radius:14px;
  box-shadow:var(--shadow-sm);
  cursor:pointer;
  transition:transform .15s ease, box-shadow .15s ease, filter .15s ease;
}
.btn:hover{filter:brightness(1.03);transform:translateY(-1px);box-shadow:var(--shadow)}
.btn-outline{background:transparent;color:var(--accent);border:2px solid rgba(209,137,18,.65);box-shadow:none}
.btn-outline:hover{background:rgba(209,137,18,.08);border-color:var(--accent)}
.btn-sm{padding:10px 12px;border-radius:10px}
.btn-block{width:100%}
.btn-video{background:var(--accent);box-shadow:0 18px 36px rgba(0,0,0,.20)}
.btn-video::before{content:"▶";font-size:12px;margin-right:6px;opacity:.95}

/* Header */
.header{background:#fff;position:sticky;top:0;z-index:50;border-bottom:1px solid var(--border);box-shadow:0 8px 24px rgba(17,24,39,.06)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 0}
.logo{height:46px;width:auto}
.logo.small{height:34px}
.nav{display:flex;gap:18px;align-items:center}
.nav a{font-weight:700;color:#111827}
.nav a:hover{color:var(--accent)}
.menu{
  display:none;
  border:1px solid var(--border);
  background:#fff;
  border-radius:14px;
  padding:10px 12px;
  box-shadow:var(--shadow-sm);
}
.mobile-nav{display:none;padding:10px 0 14px}
.mobile-nav a{display:block;padding:10px 0;font-weight:700;border-top:1px solid var(--border)}
.mobile-nav .btn{margin-top:10px}

/* Cards / form */
.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:0 1px 0 rgba(255,255,255,.85) inset, var(--shadow);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.card:hover{transform:translateY(-2px);border-color:var(--border-strong);box-shadow:0 1px 0 rgba(255,255,255,.85) inset, var(--shadow-lg)}
.label{display:block;font-size:13px;font-weight:800;color:#111827;margin:12px 0 6px}
.field{margin-top:8px}
input,textarea{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  outline:none;
  font:inherit;
  background:#fff;
  box-shadow:0 1px 0 rgba(255,255,255,.7) inset;
  transition:border-color .15s ease, box-shadow .15s ease;
}
input:focus,textarea:focus{
  border-color:rgba(209,137,18,.70);
  box-shadow:0 0 0 4px rgba(209,137,18,.14), 0 1px 0 rgba(255,255,255,.7) inset;
}

/* Sections */
.section{padding:56px 0;background:#fff}
.section-alt{padding:56px 0;background:#fff}
.section-cream{background:#fff;padding:70px 0}
.section-head{margin-bottom:30px}
.tag{display:inline-block;color:var(--accent);font-weight:900;letter-spacing:.02em}
.section-head h2{margin:8px 0 6px;font-size:32px}
.section-head p{margin:0}

/* HERO */
.hero{position:relative}
.hero-austin{
  position:relative;
  overflow:hidden;
  min-height:720px;
  background:
    linear-gradient(90deg, rgba(0,0,0,.70) 0%, rgba(0,0,0,.52) 45%, rgba(0,0,0,.20) 100%),
    url('images/hero.jpg') center center / cover no-repeat;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.hero-austin-grid{
  width:100%;
  max-width:1200px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:22px;
  align-items:center;
  padding:78px 16px 34px;
}
.hero-austin-copy{color:#fff;max-width:640px}
.hero-cap{font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:900;opacity:.92;margin-bottom:10px;font-family:var(--font-sans)}
.hero-austin-copy h1{
  margin:0 0 14px;
  font-size:clamp(24px,3vw,46px);
  line-height:1.02;
  text-shadow:0 14px 28px rgba(0,0,0,.35);
}
.hero-desc{margin:0 0 18px;max-width:560px;line-height:1.65;opacity:.92;color:#f1f1f1;font-family:var(--font-sans)}
.hero-austin-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.hero-mini-ratings{display:flex;gap:12px;flex-wrap:wrap;margin-top:6px}
.mini-rating{
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(6px);
  border-radius:10px;
  padding:10px 14px;
  min-width:120px;
  text-align:center;
}
.mr-label{font-weight:900;font-size:12px;opacity:.9;color:#fff;font-family:var(--font-sans)}
.mr-stars{color:#f3b400;letter-spacing:2px;font-size:13px;margin-top:4px;font-family:var(--font-sans)}

.wizard{
  padding:22px;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(10px);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.wizard h2{margin:0 0 6px;font-size:26px}
.stepper{display:flex;align-items:center;gap:10px;margin:12px 0 6px}
.stepper-dot{width:30px;height:30px;border-radius:999px;border:2px solid rgba(209,137,18,.55);display:grid;place-items:center;font-weight:900;color:#7a5207;background:#fff;flex:0 0 auto;font-family:var(--font-sans)}
.stepper-dot.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.stepper-line{flex:1;height:2px;background:rgba(209,137,18,.35)}
.choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:10px}
.choice{
  border:1px solid var(--border);
  background:rgba(246,242,234,.75);
  padding:14px 12px;
  border-radius:14px;
  font-weight:900;
  color:#111827;
  cursor:pointer;
  box-shadow:var(--shadow-xs);
  transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease, background .15s ease;
  font-family:var(--font-sans);
}
.choice:hover{border-color:rgba(209,137,18,.55);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.choice.active{border-color:var(--accent);box-shadow:0 0 0 4px rgba(209,137,18,.12), var(--shadow-sm);background:#fff}
.wizard-actions{margin-top:14px}
.tiny-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:10px;color:var(--muted);font-size:12px;font-weight:700;font-family:var(--font-sans)}
.two-btn{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.status{margin-top:10px;font-weight:800;font-family:var(--font-sans)}
.fine{font-size:12px;color:var(--muted);line-height:1.5;margin-top:10px;font-family:var(--font-sans)}

/* Hero strip */
.hero-strip{width:100%;background:#fff;margin-top:150px}
.hero-strip-inner{
  max-width:1200px;
  margin:0 auto;
  display:flex;
  justify-content:center;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
  padding:14px 16px;
  color:#6b7280;
  font-weight:800;
  font-size:13px;
  text-align:center;
  font-family:var(--font-sans);
}
.strip-sep{opacity:.5}

/* Ratings grid */
.ratings{display:flex;flex-direction:column;align-items:center;text-align:center}
.ratings-head .smallcap{font-size:12px;letter-spacing:.16em;color:#8c6a2b;font-weight:900;font-family:var(--font-sans)}
.ratings-head h2{margin:10px 0 10px;font-size:42px}
.underline{width:90px;height:4px;background:#111827;margin:0 auto;border-radius:999px}
.ratings-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:16px;margin-top:26px;width:100%}
.rating-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:18px;
  padding:18px 16px;
  box-shadow:var(--shadow-sm);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.rating-card:hover{transform:translateY(-2px);border-color:var(--border-strong);box-shadow:var(--shadow)}
.rating-card img{height:26px;width:auto;opacity:.95}
.rating-name{font-weight:900;font-family:var(--font-sans)}
.stars{color:#f3b400;letter-spacing:2px;font-size:14px;font-family:var(--font-sans)}
.ratings-sub{margin-top:18px;color:var(--muted);font-weight:700;font-family:var(--font-sans)}

/* Services + Process */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.svc-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.svc-card:hover{transform:translateY(-2px);border-color:var(--border-strong);box-shadow:var(--shadow)}
.svc-media{height:220px}
.svc-media img{width:100%;height:200px;object-fit:cover}
.svc-body{padding:20px}
.svc-body h3{margin:0 0 10px;font-weight:900}
.work-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:20px}
.work-card{background:#fff;padding:20px;border-radius:16px;border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.work-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:rgba(217,151,6,.15);margin-bottom:12px}

/* Gallery */
.gallery{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.gallery figure{overflow:hidden;border-radius:16px;border:1px solid var(--border);background:#fff;box-shadow:var(--shadow-xs)}
.gallery img{width:100%;height:210px;object-fit:cover}
.gallery figcaption{padding:10px 12px;color:#111827;font-weight:800;font-family:var(--font-sans)}

/* FAQ */
.faq{display:grid;gap:12px}
details{
  padding:14px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:#fff;
  box-shadow:var(--shadow-xs);
  transition:box-shadow .18s ease, border-color .18s ease;
}
details[open]{box-shadow:var(--shadow-sm);border-color:var(--border-strong)}
summary{cursor:pointer;font-weight:900;font-family:var(--font-sans)}

/* Contact */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:stretch}
.contact-card{padding:16px;display:grid;gap:10px}
.map img{height:280px;width:100%;object-fit:cover;border-radius:calc(var(--radius) - 2px);box-shadow:var(--shadow-sm)}

/* Footer */
.footer{padding:24px 0;background:#fff}
.footer-inner{display:flex;justify-content:space-between;gap:16px;align-items:center;flex-wrap:wrap}
.foot-left{display:flex;align-items:center;gap:12px}
.foot-links{display:flex;gap:14px;flex-wrap:wrap}
.foot-links a{font-weight:800;color:#111827;font-family:var(--font-sans)}
.foot-links a:hover{color:var(--accent)}

/* Exit intent modal */
.exit-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.55);
  display:none;
  align-items:center;
  justify-content:center;
  padding:18px;
  z-index:9999;
}
.exit-overlay.is-open{display:flex}
.exit-modal{
  width:min(520px,100%);
  background:rgba(255,255,255,.96);
  border:1px solid rgba(255,255,255,.22);
  border-radius:22px;
  box-shadow:0 24px 70px rgba(0,0,0,.35);
  padding:22px 22px 18px;
  position:relative;
}
.exit-close{
  position:absolute;top:10px;right:12px;
  width:40px;height:40px;border-radius:999px;
  border:1px solid rgba(17,24,39,.12);
  background:#fff;
  box-shadow:0 10px 24px rgba(17,24,39,.14);
  cursor:pointer;
  font-size:22px;line-height:1;
}
.exit-icon{
  width:46px;height:46px;border-radius:999px;
  background:rgba(209,137,18,.14);
  display:grid;place-items:center;
  margin:0 auto 10px;
  font-size:20px;
}
.exit-sub{margin:0 0 14px;color:var(--muted);text-align:center;line-height:1.55;font-family:var(--font-sans)}
.exit-form{display:grid;gap:10px}
.exit-form label span{display:block;font-size:13px;font-weight:800;color:#111827;margin-bottom:6px;font-family:var(--font-sans)}
.exit-fine{margin-top:8px;text-align:center;font-size:12px;color:var(--muted);font-weight:700;font-family:var(--font-sans)}

/* Responsive */
@media (max-width: 980px){
  .nav{display:none}
  .menu{display:inline-flex}
  .hero-austin{min-height:auto}
  .hero-austin-grid{grid-template-columns:1fr;padding:46px 16px 18px;gap:16px}
  .wizard{max-width:620px;justify-self:start}
  .hero-austin-actions .btn{width:100%}
  .choice-grid{grid-template-columns:1fr}
  .hero-strip{margin-top:28px}
  .ratings-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .ratings-head h2{font-size:32px}
  .svc-grid{grid-template-columns:1fr}
  .work-grid{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr}
  .map img{height:240px}
}
@media (max-width: 520px){
  .exit-modal{padding:18px 16px 14px;border-radius:18px}
  .exit-close{width:38px;height:38px}
}
