/*
  Forever Hardwood Floors, Inc - lightweight, responsive styles
  Stack: plain CSS, mobile‑first, no external deps
*/

:root{
  --brand: #F08731;        /* primary */
  --brand-2: #EC7411;      /* accent */
  --brand-dark: #0b0d10;   /* from logo bg */
  --ink: #1a1d23;          /* main text - darker */
  --muted: #4a5058;        /* secondary text - darker */
  --bg: #f8f9fb;           /* page background - slightly off-white */
  --bg-alt: #0f1114;       /* dark blocks */
  --surface: #ffffff;      /* cards/forms - pure white for contrast */
  --surface-alt: #f1f3f6;  /* alternate surface - slightly darker */
  --border: #d4d8de;       /* borders - more visible */
  --border-light: #e5e8ed; /* lighter borders */
  --ring: rgba(240,135,49,0.45);
  --maxw: 1100px;
  --radius: 14px;
  --section-pad: 48px;     /* unified vertical rhythm (desktop) */
  --grad: linear-gradient(135deg, var(--brand), var(--brand-2));
  --shadow-sm: 0 2px 8px rgba(16,17,20,.12);
  --shadow-md: 0 8px 25px rgba(16,17,20,.15);
  --shadow-lg: 0 12px 35px rgba(16,17,20,.18);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; font:16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Helvetica,Arial,sans-serif; color:var(--ink); background:var(--bg);
}
.container{max-width:var(--maxw); margin:0 auto; padding:0 20px}
.section{padding:var(--section-pad) 0}
.section > *:first-child{margin-top:0}
.section + .section{padding-top:0}
.section > *:last-child{margin-bottom:0}
/* Tighter, uniform spacing on small screens */
@media (max-width: 820px){
  .section{padding:40px 0}
}
/* Normalize inter-section spacing: prevent extra bottom margins leaking out */
.section > *:last-child{margin-bottom:0}
.section-header h2{margin:0 0 8px; position:relative; display:inline-block}
.section-header h2::after{content:""; position:absolute; left:0; bottom:-12px; width:100%; height:6px; border-radius:6px; background:linear-gradient(90deg,var(--brand),var(--brand-2)); box-shadow:0 2px 6px rgba(240,135,49,.22)}
.section-header p{margin:16px 0 0; color:var(--muted)}
/* Add spacing after section-header when it's the only child or followed by content */
.section-header{margin-bottom:20px}
.section-header + *{margin-top:0} /* Reset margin on immediate following element */
.skip-link{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:16px;top:16px;width:auto;height:auto;background:#fff;color:#000;padding:8px 12px;border-radius:8px;z-index:999}

/* Header / Nav */
.site-header{position:sticky; top:0; background:rgba(255,255,255,.95); backdrop-filter:saturate(180%) blur(8px); border-bottom:1px solid var(--border-light); z-index:50; overflow:visible; padding-top:calc(env(safe-area-inset-top,0) + 26px); padding-bottom:6px; box-shadow:0 2px 12px rgba(16,17,20,.08)}
.site-header .nav{display:flex; align-items:center; justify-content:space-between; height:64px; padding:0; box-sizing:border-box}
.brand{display:flex; gap:10px; align-items:center; color:inherit; text-decoration:none; font-weight:700}
.brand img{display:block; width:46px; height:46px; border-radius:8px; flex:0 0 auto; object-fit:contain}
/* Make brand text next to logo slightly larger */
.brand span{font-size:1.1rem}
@media (min-width: 900px){
  .brand span{font-size:1.15rem}
}
/* Tighter baseline so text centers with the logo */
@media (max-width: 820px){
  .brand span{display:block; line-height:1; position:relative; top:1px}
  .nav-toggle{align-self:center}
}
.nav .links{display:flex; gap:18px; align-items:center}
.nav .links a{color:var(--ink); text-decoration:none; font-weight:600}
.nav .links a:not(.primary):hover{color:var(--brand)}

.btn{display:inline-block; padding:10px 14px; border-radius:10px; border:1px solid var(--border); text-decoration:none; color:var(--ink); font-weight:650; box-shadow:var(--shadow-sm); transition:all .2s ease}
.btn:hover{border-color:var(--brand); color:var(--brand); box-shadow:var(--shadow-md); transform:translateY(-1px)}
.btn.primary{background:var(--grad); border:none; color:var(--ink); box-shadow:var(--shadow-md)}
.btn.primary:hover{filter:brightness(1.06); box-shadow:var(--shadow-lg); transform:translateY(-2px)}
.btn.ghost{background:transparent}

.nav-toggle{display:none; background:none; border:0; padding:8px; border-radius:10px}
.nav-toggle span{display:block; width:24px; height:2px; background:var(--ink); margin:5px 0; transition:.2s}

@media (max-width: 820px){
  .nav .links{position:fixed; inset:64px 0 auto 0; background:var(--surface); border-bottom:1px solid var(--border-light); padding:14px 20px; display:grid; grid-template-columns:1fr; gap:10px; transform:translateY(-120%); transition:transform .25s ease; box-shadow:var(--shadow-md)}
  .nav-toggle{display:inline-block}
  .site-header.open .links{transform:translateY(0)}
}

/* Hero */
.hero{display:block; padding:var(--section-pad) 0}
.hero .hero-content > *:first-child{margin-top:0}
.hero :is(h1,h2,h3,p,ul,ol){margin-block-start:0}
.hero > *:last-child{margin-bottom:0}
.hero + .section{padding-top:var(--section-pad)}
.hero{background:linear-gradient(180deg, rgba(240,135,49,.12), rgba(236,116,17,.05)); border-bottom:1px solid var(--border-light); box-shadow:inset 0 -1px 0 rgba(255,255,255,.5)}
.hero .subtitle{color:var(--muted)}
.hero .cta-row{display:flex; gap:12px; flex-wrap:wrap; margin:16px 0}
.badges{display:flex; gap:16px; flex-wrap:wrap; padding:0; margin:16px 0 0; list-style:none; color:var(--ink)}
.badges li{background:var(--surface); padding:6px 10px; border-radius:10px; border:1px solid var(--border); box-shadow:var(--shadow-sm)}
@media (max-width: 820px){
  :root{ --section-pad: 32px }
}

/* Cards */
.cards{margin-top:24px; display:grid; grid-template-columns:repeat(5,1fr); gap:16px}
.card{background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:18px; box-shadow:var(--shadow-sm); transition:transform .2s ease, box-shadow .2s ease}
.card:hover{transform:translateY(-3px); box-shadow:var(--shadow-md)}
.card h3{margin:0 0 6px; color:var(--ink)}
.card p{margin:0; color:var(--muted)}
@media (max-width: 1100px){.cards{grid-template-columns:repeat(3,1fr)}}
@media (max-width: 680px){.cards{grid-template-columns:repeat(2,1fr)}}
@media (max-width: 460px){.cards{grid-template-columns:1fr}}

/* Two column */
.two-col{display:grid; grid-template-columns:1fr 1fr; gap:24px; align-items:start}
@media (max-width: 820px){.two-col{grid-template-columns:1fr}}

/* Quotes */
.quotes{display:grid; grid-template-columns:1fr 1fr 1fr; gap:16px}
.stars{color:#F5A524; font-weight:700; letter-spacing:1px; margin:0 0 6px}
.read-toggle{background:none; border:0; color:var(--brand); font-weight:700; cursor:pointer; padding:0; margin-top:6px}
.read-toggle:hover{color:var(--brand-2)}
/* Interactive rating stars */
.stars-input{display:inline-flex; gap:6px; align-items:center}
.stars-input .star{background:none; border:0; padding:0; margin:0; font-size:1.3rem; line-height:1; cursor:pointer; color:#c7cbd4}
.stars-input .star.active{color:#F5A524}
.stars-input .star:focus{outline:3px solid var(--ring); outline-offset:2px; border-radius:6px}
.quotes figure{margin:0; padding:18px; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); box-shadow:var(--shadow-sm); transition:transform .2s ease, box-shadow .2s ease}
.quotes figure:hover{transform:translateY(-2px); box-shadow:var(--shadow-md)}
.quotes blockquote{margin:0 0 8px; color:var(--ink)}
.quotes figcaption{color:var(--muted); font-weight:600}
@media (max-width: 1100px){.quotes{grid-template-columns:1fr 1fr}}
@media (max-width: 680px){.quotes{grid-template-columns:1fr}}

/* Gallery */
.gallery-grid{margin-top:18px; display:grid; grid-template-columns:repeat(4,1fr); gap:12px}
.gallery-grid img{width:100%; height:160px; object-fit:cover; border-radius:12px; background:linear-gradient(135deg,var(--surface-alt),var(--border-light)); border:1px solid var(--border); box-shadow:var(--shadow-sm); transition:transform .2s ease, box-shadow .2s ease}
.gallery-grid img:hover{transform:translateY(-2px); box-shadow:var(--shadow-md)}
/* before/after labels */
.ba{position:relative}
.ba figcaption{position:absolute; left:10px; top:10px; background:rgba(11,13,16,.85); color:#fff; font-weight:700; padding:4px 8px; border-radius:999px; font-size:.8rem; border:1px solid rgba(255,255,255,.3); box-shadow:0 2px 8px rgba(0,0,0,.25)}

/* thumb links */
.thumb{display:block; position:relative; transition:transform .2s ease, filter .2s ease}
.thumb:hover{transform:translateY(-3px)}
.thumb:hover img{filter:brightness(1.06)}
.thumb .label{position:absolute; right:8px; bottom:8px; background:rgba(16,17,20,.8); color:#fff; padding:4px 8px; border-radius:999px; font-weight:700; font-size:.78rem; border:1px solid rgba(255,255,255,.35); box-shadow:0 2px 8px rgba(0,0,0,.3)}
.view-all-row{margin:10px 0 0}
.subhead{margin:28px 0 6px}
@media (max-width: 1100px){.gallery-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width: 700px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width: 520px){.gallery-grid{grid-template-columns:1fr}}

/* Contact */
.contact .contact-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:12px}
.contact-card{background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:18px; box-shadow:var(--shadow-sm); transition:transform .2s ease, box-shadow .2s ease}
.contact-card:hover{transform:translateY(-2px); box-shadow:var(--shadow-md)}
.contact-card h3{margin:0 0 6px; color:var(--ink)}
.contact-card p {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.contact-card .btn {
  width: 100%;
  text-align: center;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.tel{font-size:1.3rem; font-weight:800; color:var(--brand-2); text-decoration:none}
.legal{margin-top:18px; color:var(--muted)}
@media (max-width: 820px){.contact .contact-grid{grid-template-columns:1fr}}

/* Contact form + map */
.contact-flex{display:grid; grid-template-columns:1.1fr .9fr; gap:18px; margin-top:18px}
@media (max-width: 980px){.contact-flex{grid-template-columns:1fr}}
.form-card,.map-card{background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:18px; box-shadow:var(--shadow-sm)}
.form .field{display:flex; flex-direction:column; gap:6px; margin:10px 0}
.form input,.form select,.form textarea{padding:10px 12px; border:1px solid var(--border); border-radius:10px; font:inherit; background:var(--surface); transition:border-color .2s ease, box-shadow .2s ease}
.form input:focus,.form select:focus,.form textarea:focus{outline:3px solid var(--ring); outline-offset:2px; border-color:var(--brand); box-shadow:var(--shadow-sm)}
.form .actions{margin-top:8px}
.hide{position:absolute; left:-9999px}
.help{color:var(--muted); margin:4px 0 10px}
.notice{padding:10px 12px; border-radius:10px; margin:10px 0; font-weight:600; box-shadow:var(--shadow-sm)}
.notice.success{background:linear-gradient(135deg,rgba(240,135,49,.15),rgba(236,116,17,.1)); border:1px solid rgba(240,135,49,.4); color:var(--ink)}
.notice.error{background:linear-gradient(135deg,rgba(220,38,38,.1),rgba(185,28,28,.05)); border:1px solid rgba(220,38,38,.3); color:#7a0a1a}

/* Google Business Listing */
.google-business-section{margin:16px 0 24px}

/* Custom Google Business Widget */
.google-business-widget {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 18px;
  color: var(--ink);
  margin: 16px 0;
  box-shadow: var(--shadow-sm);
  transition: transform .2s ease, box-shadow .2s ease;
}

.google-business-widget:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.business-header {
  display: flex;
  align-items: center;
  margin-bottom: 16px;
  text-align: left;
}

.business-details h4 {
  margin: 0 0 6px 0;
  color: var(--ink);
  font-size: 1.25rem;
  font-weight: 600;
}

.business-details p {
  margin: 2px 0;
  color: var(--muted);
  font-size: 0.9rem;
}

.business-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 12px;
  margin: 16px 0;
  padding: 16px;
  background: var(--surface-alt);
  border-radius: 8px;
  border: 1px solid var(--border-light);
}

.stat {
  text-align: center;
}

.stat-label {
  display: block;
  font-size: 0.75rem;
  color: var(--muted);
  margin-bottom: 4px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.stat-value {
  display: block;
  font-size: 1.1rem;
  font-weight: bold;
  color: var(--brand);
}

.business-actions-widget {
  display: flex;
  gap: 8px;
  justify-content: center;
  flex-wrap: wrap;
  margin: 16px 0 8px 0;
}

.business-actions-widget .btn {
  background: var(--surface);
  color: var(--ink);
  border: 1px solid var(--border);
  padding: 10px 14px;
  border-radius: 10px;
  text-decoration: none;
  font-size: 0.9rem;
  font-weight: 650;
  transition: all 0.2s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  box-shadow: var(--shadow-sm);
}

.business-actions-widget .btn:hover {
  border-color: var(--brand);
  color: var(--brand);
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}

.business-actions-widget .btn-icon {
  font-size: 1rem;
  opacity: 0.9;
}

.btn-icon {
  font-size: 1rem;
  opacity: 0.9;
}

.business-note {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--border-light);
}

.business-note .help {
  font-size: 0.8rem;
  color: var(--muted);
  margin: 0;
  text-align: center;
  font-style: italic;
}

@media (max-width: 520px){
  .business-stats {
    grid-template-columns: 1fr;
    gap: 8px;
  }
  
  .business-actions-widget {
    flex-direction: column;
    gap: 6px;
  }
  
  .business-actions-widget .btn {
    width: 100%;
    justify-content: center;
  }
}

/* Footer */
.site-footer{padding:28px 0; border-top:1px solid var(--border-light); color:var(--muted); background:var(--surface-alt); text-align:center}

/* Content links accent */
.section a:not(.btn){color:var(--brand); text-decoration-color: rgba(240,135,49,.45); text-underline-offset: 2px}
.section a:not(.btn):hover{color:var(--brand-2); text-decoration-color: rgba(236,116,17,.6)}

/* Focus ring */
:where(a,button).focus,
:where(a,button):focus-visible{outline:3px solid var(--ring); outline-offset:2px; border-radius:10px}

/* Form Enhancements */
.required-indicator {
  color: var(--brand);
  font-weight: 700;
}

.required {
  color: #d32f2f;
  font-weight: 700;
}

.required-or {
  color: var(--brand);
  font-weight: 700;
}

.field-help {
  display: block;
  margin-top: 4px;
  font-size: 0.85rem;
  color: var(--muted);
  font-style: italic;
}

.contact-requirement {
  background: rgba(240, 135, 49, 0.1);
  border: 1px solid rgba(240, 135, 49, 0.3);
  border-radius: 8px;
  padding: 12px;
  margin: 16px 0;
}

.requirement-note {
  margin: 0;
  font-size: 0.9rem;
  color: var(--ink);
}

.requirement-note strong {
  color: var(--brand);
}

.field.error input,
.field.error select,
.field.error textarea {
  border-color: #d32f2f;
  box-shadow: 0 0 0 2px rgba(211, 47, 47, 0.2);
}

.field.success input,
.field.success select,
.field.success textarea {
  border-color: #2e7d32;
  box-shadow: 0 0 0 2px rgba(46, 125, 50, 0.2);
}

/* Simple reveal animation */
.reveal{opacity:0; transform:translateY(10px); transition:opacity .45s ease, transform .45s ease}
.reveal.visible{opacity:1; transform:none}
