/*
Theme Name: JJs Painting & Construction Temporary Theme
Theme URI: https://example.com
Author: JJs Painting & Construction
Description: A hardcoded, mobile-friendly temporary WordPress theme for JJs Painting & Construction, Ltd.
Version: 1.0.0
License: GPLv2 or later
Text Domain: jjs-painting-construction
*/

:root {
  --bg: #0f172a;
  --bg-soft: #111c33;
  --panel: #ffffff;
  --ink: #172033;
  --muted: #657084;
  --brand: #b91c1c;
  --brand-dark: #7f1212;
  --gold: #d9a441;
  --line: rgba(15, 23, 42, 0.12);
  --shadow: 0 22px 60px rgba(15, 23, 42, 0.14);
  --radius: 24px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background: #f7f3ec;
  line-height: 1.6;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
.container { width: min(1120px, calc(100% - 36px)); margin: 0 auto; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(15, 23, 42, 0.94);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  min-height: 76px;
}
.brand-wrap { display: flex; align-items: center; gap: 12px; min-width: 0; }
.logo-mark {
  width: 46px; height: 46px; border-radius: 15px;
  display: grid; place-items: center;
  background: linear-gradient(145deg, var(--brand), #ef4444);
  color: #fff; font-weight: 900; letter-spacing: -1px;
  box-shadow: 0 12px 30px rgba(185,28,28,.32);
  flex: 0 0 auto;
}
.brand-text strong { display:block; color:#fff; font-size: clamp(15px, 2vw, 20px); line-height:1.1; }
.brand-text span { display:block; color:rgba(255,255,255,.65); font-size:12px; }
.nav { display:flex; align-items:center; gap: 22px; color:rgba(255,255,255,.78); font-weight:700; font-size:14px; }
.nav a:hover { color:#fff; }
.header-cta { display:inline-flex; align-items:center; justify-content:center; border-radius:999px; padding: 11px 17px; background:#fff; color:#7f1212; font-weight:900; white-space:nowrap; }

.hero {
  position: relative;
  overflow: hidden;
  color: #fff;
  background:
    radial-gradient(circle at top left, rgba(217,164,65,.28), transparent 30%),
    linear-gradient(135deg, rgba(15,23,42,.93), rgba(30,41,59,.82)),
    url('https://images.unsplash.com/photo-1562259949-e8e7689d7828?auto=format&fit=crop&w=1800&q=80') center/cover;
  padding: clamp(64px, 9vw, 118px) 0;
}
.hero-grid { display:grid; grid-template-columns: 1.08fr .92fr; gap: 44px; align-items:center; }
.eyebrow { color:#f8d98e; font-size:13px; font-weight:900; text-transform:uppercase; letter-spacing:.14em; margin:0 0 12px; }
h1 { font-size: clamp(39px, 6vw, 72px); line-height:.95; letter-spacing:-.055em; margin:0 0 20px; max-width: 850px; }
.hero p { color: rgba(255,255,255,.82); font-size: clamp(17px, 2vw, 21px); max-width: 660px; margin:0 0 28px; }
.actions { display:flex; flex-wrap:wrap; gap: 12px; align-items:center; }
.btn { display:inline-flex; align-items:center; justify-content:center; border-radius:999px; padding: 14px 20px; font-weight:900; border:1px solid transparent; min-height:48px; }
.btn-primary { background: var(--brand); color:#fff; box-shadow: 0 16px 36px rgba(185,28,28,.35); }
.btn-primary:hover { background:#991b1b; }
.btn-secondary { background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.22); color:#fff; }
.hero-card { background: rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.18); border-radius: 30px; padding: 24px; box-shadow: 0 24px 70px rgba(0,0,0,.22); backdrop-filter: blur(14px); }
.hero-card h2 { margin:0 0 14px; font-size:24px; letter-spacing:-.03em; }
.check-list { list-style:none; padding:0; margin:0; display:grid; gap:12px; }
.check-list li { display:flex; gap:10px; color:rgba(255,255,255,.84); }
.check-list li:before { content:'✓'; color:#f8d98e; font-weight:900; }

.section { padding: clamp(54px, 7vw, 88px) 0; }
.section-alt { background:#fff; }
.section-head { max-width: 760px; margin-bottom: 28px; }
.section-head h2 { font-size: clamp(31px, 4vw, 48px); line-height:1; letter-spacing:-.045em; margin:0 0 14px; color:#111827; }
.section-head p { margin:0; color:var(--muted); font-size:18px; }
.cards { display:grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.card { background:#fff; border:1px solid var(--line); border-radius: var(--radius); padding: 24px; box-shadow: var(--shadow); }
.card.dark { background: linear-gradient(145deg, #111827, #1f2937); color:#fff; border-color: rgba(255,255,255,.1); }
.card h3 { margin: 0 0 9px; font-size:22px; letter-spacing:-.025em; }
.card p { margin:0; color:var(--muted); }
.card.dark p { color:rgba(255,255,255,.72); }
.icon { width:48px; height:48px; display:grid; place-items:center; border-radius:16px; background:rgba(185,28,28,.09); color:var(--brand); font-size:24px; margin-bottom:16px; }
.card.dark .icon { background:rgba(217,164,65,.16); color:#f8d98e; }

.split { display:grid; grid-template-columns: .9fr 1.1fr; gap: 34px; align-items:center; }
.photo-panel { min-height: 430px; border-radius: 34px; background: linear-gradient(135deg, rgba(15,23,42,.2), rgba(185,28,28,.18)), url('https://images.unsplash.com/photo-1621905251189-08b45d6a269e?auto=format&fit=crop&w=1300&q=80') center/cover; box-shadow: var(--shadow); }
.feature-list { display:grid; gap: 14px; margin-top:22px; }
.feature { display:flex; gap:14px; padding: 16px; border-radius: 20px; background:#fff; border:1px solid var(--line); }
.feature strong { display:block; margin-bottom:2px; }
.feature span { color:var(--muted); }

.areas { display:flex; flex-wrap:wrap; gap: 10px; margin-top:22px; }
.area-pill { border-radius:999px; padding: 10px 14px; background:#fff; border:1px solid var(--line); font-weight:800; color:#334155; }

.cta-band { background: linear-gradient(135deg, #7f1212, #b91c1c); color:#fff; border-radius: 34px; padding: clamp(28px, 5vw, 54px); display:flex; justify-content:space-between; gap:24px; align-items:center; box-shadow: 0 22px 60px rgba(185,28,28,.24); }
.cta-band h2 { margin:0 0 8px; font-size: clamp(28px, 4vw, 46px); line-height:1; letter-spacing:-.04em; }
.cta-band p { margin:0; color:rgba(255,255,255,.78); }
.footer { background:#0f172a; color:rgba(255,255,255,.72); padding: 34px 0; }
.footer-inner { display:flex; justify-content:space-between; gap:20px; align-items:center; flex-wrap:wrap; }
.footer strong { color:#fff; }

@media (max-width: 920px) {
  .nav { display:none; }
  .hero-grid, .split { grid-template-columns:1fr; }
  .hero-card { max-width: 620px; }
  .cards { grid-template-columns:1fr 1fr; }
  .cta-band { align-items:flex-start; flex-direction:column; }
}

@media (max-width: 620px) {
  .container { width: min(100% - 28px, 1120px); }
  .header-inner { min-height: 68px; gap:10px; }
  .logo-mark { width:42px; height:42px; border-radius:13px; }
  .brand-text strong { font-size:13px; max-width: 175px; line-height:1.15; }
  .brand-text span { display:none; }
  .header-cta { padding: 9px 11px; font-size: 12px; }
  .hero { padding: 52px 0 46px; }
  h1 { font-size: 37px; letter-spacing:-.05em; }
  .hero p { font-size:16px; }
  .actions { flex-direction:column; align-items:stretch; }
  .btn { width:100%; }
  .hero-card { padding: 20px; border-radius:24px; }
  .cards { grid-template-columns:1fr; }
  .card { padding: 21px; }
  .photo-panel { min-height: 280px; border-radius:24px; }
  .feature { padding:14px; }
  .area-pill { font-size:13px; padding:9px 12px; }
  .footer-inner { align-items:flex-start; flex-direction:column; }
}
