/* ============================================================================
   FINISH LINE HOME REPAIR — Version 3
   Editorial-minimal, conversion-first. Informed by verified research:
   phone-first CTAs, thumb-reach sticky call bar, short quote form, owner
   photo + trust badges in hero, outcome-framed realtor section, and the
   premium-minimal density of vitruviusbuilt.com (7 sections, short copy,
   generous whitespace).
   ============================================================================ */

:root {
  --ink:       #11233a;   /* deep navy text */
  --ink-soft:  #51606f;
  --paper:     #fdfdfb;   /* warm off-white */
  --paper-dim: #f6f5f1;
  --navy:      #102a43;
  --navy-deep: #0a1c30;
  --gold:      #c8a96b;
  --gold-dark: #ab8c50;
  --gold-tint: #f4eddd;
  --hairline:  #e7e4dc;

  --font-head: "Plus Jakarta Sans", system-ui, sans-serif;
  --font-body: "Inter", system-ui, sans-serif;

  --container: 1120px;
  --r: 16px;
  --r-pill: 999px;
  --ease: cubic-bezier(.16,1,.3,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
/* scroll-padding deliberately LESS than the header height: sections have
   110px internal top padding, so landing the section edge 85px under the
   header puts the visible CONTENT ~24px below it — tight, no dead space. */
html{scroll-behavior:smooth;scroll-padding-top:34px;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);color:var(--ink);background:var(--paper);font-size:16.5px;line-height:1.65;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:var(--ink);text-decoration:none}
h1,h2,h3{font-family:var(--font-head);font-weight:800;line-height:1.08;letter-spacing:-.025em;color:var(--ink)}
h1{font-size:clamp(2.1rem,4.6vw,4rem)}
h2{font-size:clamp(1.7rem,3.2vw,2.6rem)}
h3{font-size:1.05rem;font-weight:700;letter-spacing:-.01em}

.container{max-width:var(--container);margin:0 auto;padding:0 24px}
section{padding:110px 0}
.eyebrow{
  display:block;font-family:var(--font-head);font-weight:700;font-size:.72rem;
  text-transform:uppercase;letter-spacing:.22em;color:var(--gold-dark);margin-bottom:20px;
}
.sub{color:var(--ink-soft);font-size:1.12rem;max-width:54ch}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--font-head);font-weight:700;font-size:.98rem;
  padding:16px 28px;border-radius:var(--r-pill);cursor:pointer;
  border:1.5px solid transparent;transition:all .22s var(--ease);white-space:nowrap;
}
.btn-gold{background:var(--gold);color:var(--navy-deep);border-color:var(--gold)}
.btn-gold:hover{background:var(--gold-dark);border-color:var(--gold-dark);transform:translateY(-1px)}
.btn-ink{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-ink:hover{background:var(--navy-deep);transform:translateY(-1px)}
.btn-line{background:transparent;color:var(--ink);border-color:#cfd6dd}
.btn-line:hover{border-color:var(--ink);transform:translateY(-1px)}
.btn-line-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.btn-line-light:hover{background:#fff;color:var(--navy)}
.btn-row{display:flex;flex-wrap:wrap;gap:12px}

/* ---------- Version bar ---------- */
.version-bar{background:var(--navy-deep);color:rgba(255,255,255,.8);font-family:var(--font-head);font-size:.8rem;font-weight:600;text-align:center;padding:8px 14px}
.version-bar a{color:var(--gold);font-weight:700}
.version-bar .tag{background:var(--gold);color:var(--navy-deep);border-radius:var(--r-pill);padding:1px 9px;font-size:.7rem;font-weight:800;margin-right:6px}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(253,253,251,.92);backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid var(--hairline)}
.nav{display:flex;align-items:center;justify-content:space-between;height:118px;gap:20px}
.nav-logo img{height:96px;width:auto}
.nav-links{display:flex;gap:34px;list-style:none}
.nav-links a{font-family:var(--font-head);font-weight:600;font-size:.93rem;color:var(--ink-soft);transition:color .2s}
.nav-links a:hover{color:var(--ink)}
.nav-right{display:flex;align-items:center;gap:18px}
.nav-phone{font-family:var(--font-head);font-weight:700;font-size:.98rem;white-space:nowrap}
.nav-phone:hover{color:var(--gold-dark)}
.nav-cta{padding:12px 22px}
.mobile-call{display:none}

/* ---------- Hero ---------- */
.hero{padding:84px 0 96px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.hero h1{margin-bottom:22px}
.hero .sub{margin-bottom:30px}
.hero .btn-row{margin-bottom:34px}

/* owner credibility row (compact) */
.owner-row{display:flex;align-items:center;gap:16px;margin-bottom:24px;max-width:480px}
.owner-row .avatar{width:64px;height:64px;border-radius:50%;overflow:hidden;flex-shrink:0;border:2px solid var(--gold)}
.owner-row .avatar img{width:100%;height:100%;object-fit:cover;object-position:50% 18%}
.owner-row .txt{font-size:.92rem;color:var(--ink-soft);line-height:1.5}
.owner-row .txt strong{display:block;font-family:var(--font-head);color:var(--ink);font-size:.95rem}

/* hero photo */
.hero-media{position:relative}
.hero-media .frame{border-radius:var(--r);overflow:hidden;aspect-ratio:4/4.5;background:var(--navy)}
.hero-media .frame img{width:100%;height:100%;object-fit:cover}
.hero-media .caption{
  display:flex;align-items:center;gap:10px;justify-content:center;
  margin-top:14px;font-size:.88rem;color:var(--ink-soft);
}
.hero-media .caption .dotline{display:inline-flex;align-items:center;gap:10px}
.badge-chip{
  display:inline-flex;align-items:center;gap:7px;font-family:var(--font-head);
  font-weight:700;font-size:.78rem;color:var(--ink);
  background:var(--paper-dim);border:1px solid var(--hairline);
  border-radius:var(--r-pill);padding:7px 14px;
}
.badge-chip svg{width:14px;height:14px;color:var(--gold-dark)}
.hero-badges{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:26px}

/* ---------- Services ---------- */
.services{background:var(--paper-dim);border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline)}
.services .head{max-width:560px;margin-bottom:56px}
.svc-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.svc{
  background:var(--paper);border:1px solid var(--hairline);border-radius:var(--r);
  padding:22px 18px;transition:border-color .2s var(--ease), transform .2s var(--ease);
}
.svc:hover{border-color:var(--gold);transform:translateY(-2px)}
.svc svg{width:26px;height:26px;color:var(--gold-dark);margin-bottom:14px}
.svc h3{font-size:.95rem;margin-bottom:4px}
.svc p{font-size:.82rem;color:var(--ink-soft);line-height:1.45}
.svc-note{margin-top:28px;font-size:.92rem;color:var(--ink-soft)}
.svc-note a{font-weight:700;color:var(--gold-dark)}

/* ---------- On the Job (photo gallery) ---------- */
.onjob .head{max-width:560px;margin-bottom:48px}
.job-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(186px,1fr));gap:16px}
.job{margin:0}
.job .ph{border-radius:var(--r);overflow:hidden;background:var(--paper-dim)}
.job .ph img{width:100%;height:auto;aspect-ratio:2/3;object-fit:cover;object-position:center top;display:block;transition:transform .5s var(--ease)}
.job:hover .ph img{transform:scale(1.045)}
.job figcaption{font-family:var(--font-head);font-weight:700;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);margin-top:12px}
@media (max-width:560px){
  .job-grid{grid-template-columns:1fr 1fr;gap:10px}
  .job figcaption{font-size:.68rem;margin-top:8px}
}

/* ---------- Realtor band ---------- */
.realtor{background:var(--navy-deep);color:#fff}
.realtor .eyebrow{color:var(--gold)}
.realtor h2{color:#fff}
.realtor-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:center}
.realtor p.lead-line{color:rgba(255,255,255,.78);font-size:1.1rem;margin:20px 0 30px;max-width:46ch}
.r-list{list-style:none;display:grid;gap:22px}
.r-list li{display:grid;grid-template-columns:34px 1fr;gap:14px;align-items:start}
.r-list .n{
  width:34px;height:34px;border-radius:50%;border:1.5px solid var(--gold);color:var(--gold);
  font-family:var(--font-head);font-weight:700;font-size:.85rem;display:flex;align-items:center;justify-content:center;
}
.r-list strong{display:block;font-family:var(--font-head);font-size:1rem;color:#fff;margin-bottom:3px}
.r-list span{color:rgba(255,255,255,.66);font-size:.93rem;line-height:1.5}

/* ---------- Quote ---------- */
.quote .wrap{max-width:600px;margin:0 auto;text-align:center}
.quote form{margin-top:40px;text-align:left;display:grid;gap:16px}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field label{display:block;font-family:var(--font-head);font-weight:600;font-size:.85rem;margin-bottom:7px}
.field label .opt{color:var(--ink-soft);font-weight:400}
.field input,.field textarea{
  width:100%;font-family:var(--font-body);font-size:1rem;color:var(--ink);
  padding:14px 16px;background:var(--paper);border:1.5px solid var(--hairline);border-radius:12px;
  transition:border-color .2s;
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--gold)}
.field input[type=file]{padding:11px;background:var(--paper-dim);cursor:pointer}
.field textarea{min-height:110px;resize:vertical}
.quote .btn{width:100%}
.quote .alt{margin-top:18px;font-size:.92rem;color:var(--ink-soft)}
.quote .alt a{font-weight:700;color:var(--gold-dark)}

/* ---------- FAQ ---------- */
.faq{background:var(--paper-dim);border-top:1px solid var(--hairline)}
.faq .wrap{max-width:680px;margin:0 auto}
.faq h2{text-align:center;margin-bottom:40px}
.faq details{border-bottom:1px solid var(--hairline)}
.faq summary{
  list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;
  font-family:var(--font-head);font-weight:700;font-size:1rem;padding:20px 4px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary .x{color:var(--gold-dark);font-weight:400;font-size:1.3rem;transition:transform .25s var(--ease)}
.faq details[open] summary .x{transform:rotate(45deg)}
.faq .a{padding:0 4px 20px;color:var(--ink-soft);font-size:.96rem}

/* ---------- Footer ---------- */
.site-footer{padding:54px 0 90px;border-top:1px solid var(--hairline)}
.foot{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:24px}
.foot .brand img{height:64px}
.foot .meta{font-size:.88rem;color:var(--ink-soft);line-height:1.7;text-align:right}
.foot .meta a{font-weight:600}
.foot .meta a:hover{color:var(--gold-dark)}

/* ---------- Sticky mobile call bar (thumb-reach primary CTA) ---------- */
.callbar{display:none}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:44px}
  .hero-media{max-width:440px}
  .svc-grid{grid-template-columns:repeat(3,1fr)}
  .realtor-grid{grid-template-columns:1fr;gap:40px}
}
@media (max-width:720px){
  html{scroll-padding-top:40px} /* mobile: 64px section padding - 83px header + ~21px gap */
  body{font-size:16px}
  section{padding:64px 0}
  .nav{height:82px}
  .nav-logo img{height:60px}
  .nav-links,.nav-phone,.nav-cta{display:none}
  .mobile-call{display:inline-flex;padding:10px 18px;font-size:.9rem}

  /* Compact one-viewport hero: face + headline + CTAs together */
  .hero{padding:36px 0 56px}
  .hero h1{font-size:clamp(1.9rem,8vw,2.3rem);margin-bottom:14px}
  .hero .sub{font-size:1rem;margin-bottom:22px}
  .hero .btn-row{margin-bottom:0;gap:10px}
  .hero .btn{width:100%;padding:15px 24px}
  .hero-badges{margin-bottom:18px;gap:8px}
  .badge-chip{font-size:.72rem;padding:6px 11px}

  /* owner row moves ABOVE headline: face first, compact */
  .hero-grid{display:flex;flex-direction:column;gap:0}
  .hero-media{order:-1;max-width:none;margin-bottom:18px}
  .hero-media .frame{display:none}                /* big photo hidden on mobile */
  .hero-media .caption{display:none}
  .owner-row{order:-1;margin-bottom:18px;max-width:none}
  .owner-row .avatar{width:76px;height:76px}

  .services .head{margin-bottom:32px}
  .svc-grid{grid-template-columns:1fr 1fr;gap:10px}
  .svc{padding:16px 14px}
  .svc p{display:none}                            /* labels only on mobile = short */
  .svc svg{margin-bottom:10px;width:22px;height:22px}
  .svc h3{font-size:.86rem;margin:0}

  .realtor h2{max-width:none}
  .f2{grid-template-columns:1fr}
  .foot{flex-direction:column;text-align:center}
  .foot .meta{text-align:center}

  body{padding-bottom:64px}
  .callbar{
    display:flex;position:fixed;bottom:0;left:0;right:0;z-index:200;
    box-shadow:0 -6px 24px rgba(16,42,67,.16);
  }
  .callbar a{
    flex:1;text-align:center;padding:17px 10px;font-family:var(--font-head);
    font-weight:700;font-size:.98rem;
  }
  .callbar .c{background:var(--gold);color:var(--navy-deep)}
  .callbar .q{background:var(--navy-deep);color:#fff}
}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
