
:root {
  --bg: #f8fafc;
  --bg-dark: #0f172a;
  --panel: #ffffff;
  --text: #1e293b;
  --text-light: #64748b;
  --brand: #0f2d46;
  --vinyl: #3b82f6;
  --cta: #ff8c00;
  --cta-dark: #e67e00;
  --white: #ffffff;
  --line: rgba(0, 0, 0, 0.05);
  --shadow-md: 0 10px 25px -5px rgba(0,0,0,0.08);
  --shadow-lg: 0 18px 50px -12px rgba(0,0,0,0.18);
  --radius: 12px;
}
*, body { font-family: 'Raleway', sans-serif; font-weight: 300; letter-spacing: 0.02em; line-height: 1.75; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--bg); color: var(--text); overflow-x: hidden; }
img { max-width: 100%; display: block; }
a { text-decoration: none; color: inherit; }
.container { width: min(1180px, 92%); margin: 0 auto; }
h1, h2, h3, h4, h5, h6 { font-family: 'Cormorant Garamond', serif !important; font-weight: 300 !important; letter-spacing: 0.05em; line-height: 1.2; }
h1 { font-size: clamp(2rem, 4.6vw, 4.2rem) !important; }
h2 { font-size: clamp(1.6rem, 3vw, 2.5rem) !important; color: var(--brand); }
h3 { font-size: clamp(1.08rem, 2vw, 1.45rem) !important; }
h1 em, h2 em, h3 em { font-style: italic; font-weight: 300 !important; }
strong, b { font-weight: 500 !important; }
.site-header { position: sticky; top: 0; z-index: 100; background: rgba(255,255,255,.94); backdrop-filter: blur(10px); border-bottom: 1px solid var(--line); }
.header-shell, header .container { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 20px; padding-top: 10px; padding-bottom: 10px; }
.brand-logo { height: 56px; width: auto; object-fit: contain; }
.site-nav { display: flex; justify-content: center; gap: 18px; align-items: center; }
.nav-link, .menu-item a, .site-nav a { font-weight: 700 !important; letter-spacing: 0.5px; font-size: 0.84rem !important; text-transform: uppercase; color: var(--text-light); }
.site-nav a:hover { color: var(--vinyl); }
.phone-number, .header-phone { display: flex; align-items: center; white-space: nowrap; font-size: 1rem !important; font-weight: 700 !important; color: var(--cta) !important; background: rgba(255,140,0,0.08); padding: 8px 14px; border-radius: 999px; border: 1px solid rgba(255,140,0,0.2); }
.header-actions { display: flex; gap: 10px; align-items: center; }
.menu-toggle { display: none; border: 1px solid var(--line); background: #fff; border-radius: 10px; padding: 8px 12px; font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; }
.btn { display: inline-flex; align-items: center; justify-content: center; padding: 12px 18px; border-radius: 8px; transition: .25s ease; border: none; cursor: pointer; font-family: 'Raleway', sans-serif !important; font-weight: 500 !important; font-size: 0.78rem !important; letter-spacing: 0.14em !important; text-transform: uppercase !important; }
.btn-secondary { background: var(--brand); color: #fff; }
.btn-estimate, .quote-form button { background-color: #FF8C00 !important; color: white !important; font-weight: 800 !important; border-radius: 5px; text-transform: uppercase; transition: 0.3s; box-shadow: 0 8px 20px rgba(255, 140, 0, 0.35); }
.btn-estimate:hover { background-color: #e67e00 !important; transform: translateY(-2px); }
.btn-icon { display:inline-flex; align-items:center; gap:8px; }
.hero { position: relative; min-height: 88vh; display: flex; align-items: center; background: var(--bg-dark); }
.hero-media { position: absolute; inset: 0; }
.hero-media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(15,23,42,.84) 0%, rgba(15,23,42,.58) 36%, rgba(15,23,42,.36) 100%); }
.hero-media img { width: 100%; height: 100%; object-fit: cover; animation: zoomslow 18s ease-in-out infinite alternate; }
@keyframes zoomslow { from { transform: scale(1); } to { transform: scale(1.06); } }
.hero-content { position: relative; z-index: 2; padding: 120px 0 76px; }
.eyebrow { display: inline-block; margin-bottom: 14px; color: #93c5fd; font-size: .76rem; letter-spacing: .16em; text-transform: uppercase; font-weight: 600 !important; }
.hero h1 { color: #fff; max-width: 1000px; }
.hero p { color: rgba(255,255,255,.86); max-width: 760px; }
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; margin: 24px 0; }
.hero-points { display: flex; flex-wrap: wrap; gap: 10px 16px; }
.hero-points span { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12); color: #dbeafe; padding: 8px 12px; border-radius: 999px; font-size: .84rem; }
.section { padding: 92px 0; }
.section-intro { max-width: 760px; margin-bottom: 28px; color: var(--text-light); }
.trust-band { padding: 0; background: #fff; }
.trust-grid { display: grid; grid-template-columns: repeat(4,1fr); }
.trust-grid > div { padding: 24px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.trust-grid > div:last-child { border-right: none; }
.service-grid, .review-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 18px; }
.mini-card, .gallery-card, .review-card, .quote-shell, .service-section-copy, .map-shell { background: var(--white); border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow-md); overflow: hidden; }
.mini-card, .review-card, .service-section-copy { padding: 28px; }
.dark-panel { background: #f1f5f9; }
.portfolio-item img, .gallery-img, .gallery-card img { border: 1px solid rgba(0,0,0,0.1); box-shadow: 0px 4px 12px rgba(0, 0, 0, 0.08); border-radius: 8px; transition: transform 0.3s ease, box-shadow 0.3s ease; }
.gallery-card img { width: 100%; height: 290px; object-fit: cover; }
.portfolio-item img:hover, .gallery-img:hover, .gallery-card img:hover { transform: scale(1.02); box-shadow: 0px 6px 18px rgba(0, 0, 0, 0.15); }
.gallery-caption { padding: 18px; background: #fff; }
.gallery-caption strong { display: block; color: var(--text); font-weight: 500 !important; }
.gallery-caption span { color: var(--text-light); }
.marquee { overflow: hidden; }
.marquee-track { display: flex; gap: 18px; width: max-content; animation: marquee 44s linear infinite; padding: 0 4% 10px; }
.marquee:hover .marquee-track { animation-play-state: paused; }
.gallery-card { min-width: 320px; max-width: 320px; }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.split-panel { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: stretch; }
.pill-grid { display: flex; flex-wrap: wrap; gap: 12px; }
.pill-grid a { padding: 10px 14px; border-radius: 999px; background: #f8fafc; border: 1px solid #e2e8f0; color: var(--brand); font-weight: 600 !important; }
.map-shell iframe { width: 100%; height: 100%; min-height: 380px; border: 0; }
.insta-grid { display:grid; grid-template-columns: 1.2fr .8fr; gap:24px; }
.hashtag-row { display:flex; flex-wrap:wrap; gap:10px; margin-top:18px; }
.hashtag-row span { padding:10px 14px; background:#fff; border:1px solid var(--line); border-radius:999px; color:var(--brand); font-weight:600 !important; }
.small-note { font-size:.95rem; color:var(--text-light); }
.quote-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.quote-shell { max-width: 680px !important; margin-left: auto !important; margin-right: auto !important; padding: 2.5rem !important; }
.field { margin-bottom: 14px; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.field label { font-size: 0.72rem !important; font-weight: 600 !important; letter-spacing: 0.10em !important; text-transform: uppercase !important; color: var(--brand); display: block; margin-bottom: 8px; }
.field input, .field select, .field textarea { width: 100% !important; box-sizing: border-box !important; padding: 0.7rem 1rem !important; margin-bottom: 0.75rem !important; border: 1px solid #e2e8f0; border-radius: 8px; background: #fff; }
.field textarea { min-height: 140px; resize: vertical; }
.quote-actions { display: flex; gap: 12px; flex-wrap: wrap; }
.check-list { padding-left: 18px; color: var(--text-light); }
.seo-section { background:#fff; }
.seo-section p { max-width: 980px; }
.site-footer { background: var(--bg-dark); color: #fff; padding: 60px 0 110px; }
.footer-grid { display: grid; grid-template-columns: 1.2fr 1fr 1fr 1fr; gap: 22px; }
.footer-logo { height: 60px; width: auto; margin-bottom: 12px; filter: brightness(0) invert(1); opacity: 0.96; }
.site-footer a, .site-footer p { color: #cbd5e1; display:block; margin:8px 0; }
.site-footer h4 { color:#fff; }
.floating-cta { position: fixed; right: 18px; bottom: 18px; display: grid; gap: 10px; z-index: 110; }
.float-email, .float-sms { padding: 12px 16px; border-radius: 999px; box-shadow: var(--shadow-lg); display:inline-flex; align-items:center; gap:8px; font-weight: 700 !important; font-size: .8rem !important; }
.float-email { background: #fff; color: var(--brand); }
.float-sms { background: var(--brand); color: #fff; }
.btn-sms::before { content: "💬"; margin-right: 8px; }
.btn-email::before { content: "✉"; margin-right: 8px; }
@media (max-width: 980px) { .service-grid, .review-grid, .trust-grid, .split-panel, .quote-layout, .footer-grid, .insta-grid { grid-template-columns: 1fr; } .field-row { grid-template-columns: 1fr; } }
@media (max-width: 930px) { .header-shell { grid-template-columns: auto auto; justify-content: space-between; } .menu-toggle { display: inline-flex; } .site-nav { display: none; position: absolute; top: 68px; left: 4%; right: 4%; background: #fff; border: 1px solid var(--line); border-radius: 14px; box-shadow: var(--shadow-lg); padding: 14px; flex-direction: column; align-items: flex-start; } .site-nav.open { display: flex; } .header-actions { display: none; } .brand-logo { height: 46px; } .floating-cta { left: 14px; right: 14px; grid-template-columns: 1fr 1fr; } }


.hero-content{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);gap:28px;align-items:center;}
.hero-sidecard{position:relative;z-index:2;}
.hero-form-card{background:rgba(255,255,255,.95);border-radius:16px;padding:28px;border:1px solid rgba(255,255,255,.4);box-shadow:var(--shadow-lg);}
.eyebrow-dark{color:var(--brand);}
.hero-form-card p,.hero-form-card h3{color:var(--text);}
.hero-form-actions{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0;}
.hero-mini-list{margin:16px 0 0;padding-left:18px;color:var(--text-light);}
.why-grid,.process-grid,.faq-list,.jobber-grid{display:grid;gap:18px;}
.why-grid{grid-template-columns:repeat(3,1fr);}
.process-grid{grid-template-columns:repeat(4,1fr);}
.process-card,.faq-item,.jobber-card,.jobber-copy{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:28px;}
.process-card span{display:inline-flex;width:40px;height:40px;border-radius:999px;background:rgba(59,130,246,.12);align-items:center;justify-content:center;font-weight:700;color:var(--brand);margin-bottom:12px;}
.faq-list{grid-template-columns:1fr;}
.booking-note{color:var(--brand);font-weight:600 !important;}
.jobber-grid{grid-template-columns:1.1fr .9fr;align-items:stretch;}
.jobber-actions{display:flex;gap:12px;flex-wrap:wrap;margin:22px 0 10px;}
@media (max-width: 980px){.hero-content,.why-grid,.process-grid,.jobber-grid{grid-template-columns:1fr;}}
