@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

/* ═══════════════════════════════════════════════════
   JPM SITE SERVICES — LIGHT THEME
═══════════════════════════════════════════════════ */
:root {
  --bg:       #f4f3ef;
  --surface:  #ffffff;
  --surface2: #eceae4;
  --text:     #1a1c22;
  --text2:    #575d6e;
  --text3:    #939aaa;
  --orange:   #e8600a;
  --orange-d: #c84f06;
  --border:   #dddfe6;
  --dark:     #1c1f28;
  --white:    #ffffff;
}

*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; }
body { font-family:'Inter',system-ui,-apple-system,sans-serif; background:var(--bg); color:var(--text); line-height:1.6; font-size:16px; }
img { max-width:100%; display:block; }
a { color:inherit; }

h1,h2,h3,h4,h5 { font-weight:800; line-height:1.18; color:var(--text); letter-spacing:-0.02em; }
h1 { font-size:clamp(2.2rem,5vw,3.8rem); }
h2 { font-size:clamp(1.6rem,3vw,2.5rem); }
h3 { font-size:1.1rem; font-weight:700; }
h4 { font-size:0.95rem; font-weight:700; }
p  { color:var(--text2); line-height:1.75; }
.lead { font-size:1.1rem; color:var(--text2); max-width:680px; margin-bottom:40px; }

.container { max-width:1240px; margin:0 auto; padding:0 28px; }
.section { padding:80px 28px; }
.section-light  { background:var(--surface); }
.section-grey   { background:var(--bg); }
.section-dark   { background:var(--dark); }

/* ─── UTILITY ─────────────────────────────────── */
.section-eyebrow { display:inline-block; font-size:0.72rem; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--orange); margin-bottom:14px; }

/* ─── BUTTONS ─────────────────────────────────── */
.btn { display:inline-flex; align-items:center; gap:8px; padding:14px 28px; border-radius:6px; font-weight:700; font-size:0.92rem; text-decoration:none; transition:all 0.18s; cursor:pointer; border:none; white-space:nowrap; }
.btn-orange  { background:var(--orange); color:#fff; }
.btn-orange:hover { background:var(--orange-d); transform:translateY(-1px); }
.btn-dark    { background:var(--dark); color:#fff; }
.btn-dark:hover { background:#111318; }
.btn-outline { background:transparent; color:var(--text); border:2px solid var(--border); }
.btn-outline:hover { border-color:var(--orange); color:var(--orange); }
.btn-outline-white { background:transparent; color:#fff; border:2px solid rgba(255,255,255,0.5); }
.btn-outline-white:hover { border-color:#fff; background:rgba(255,255,255,0.08); }
.btn-primary { background:var(--orange); color:#fff; }
.btn-primary:hover { background:var(--orange-d); }
.btn-sm { padding:10px 20px; font-size:0.85rem; }
.cta-group { display:flex; gap:14px; flex-wrap:wrap; align-items:center; }

/* ─── EMERGENCY BAR ────────────────────────────── */
.emergency-bar { background:var(--orange); color:#fff; text-align:center; padding:10px 20px; font-size:0.82rem; font-weight:600; letter-spacing:0.2px; z-index:200; position:relative; }
.emergency-bar a { color:#fff; text-decoration:underline; }

/* ─── HEADER ───────────────────────────────────── */
.site-header { position:fixed; top:42px; left:0; right:0; z-index:100; background:#fff; border-bottom:1px solid var(--border); transition:top 0.3s, box-shadow 0.3s; }
.site-header.scrolled { top:0; box-shadow:0 2px 20px rgba(0,0,0,0.1); }
.header-inner { max-width:1240px; margin:0 auto; padding:0 28px; display:flex; align-items:center; gap:32px; height:64px; }
.logo { text-decoration:none; flex-shrink:0; }
.logo-main { font-size:1.4rem; font-weight:900; color:var(--text); letter-spacing:-0.03em; line-height:1; }
.logo-main span { color:var(--orange); }
.logo-sub { font-size:0.58rem; font-weight:600; letter-spacing:2.5px; text-transform:uppercase; color:var(--text3); line-height:1; margin-top:3px; }
nav { flex:1; }
nav ul { list-style:none; display:flex; gap:6px; align-items:center; }
nav ul a { display:block; padding:8px 12px; border-radius:5px; font-size:0.88rem; font-weight:600; color:var(--text2); text-decoration:none; transition:color 0.15s; }
nav ul a:hover, nav ul a.active { color:var(--orange); }
.header-cta a { background:var(--orange); color:#fff; padding:10px 22px; border-radius:6px; font-size:0.88rem; font-weight:700; text-decoration:none; white-space:nowrap; transition:background 0.18s; }
.header-cta a:hover { background:var(--orange-d); }
.mobile-menu-btn { display:none; background:none; border:none; font-size:1.4rem; cursor:pointer; color:var(--text); }
@media(max-width:900px) {
  .mobile-menu-btn { display:block; }
  nav { display:none; }
  nav.open { display:block; position:absolute; top:100%; left:0; right:0; background:#fff; border-bottom:1px solid var(--border); padding:16px 0; }
  nav.open ul { flex-direction:column; gap:0; }
  nav.open ul a { padding:12px 28px; }
}

/* ─── HERO (video — stays dark) ────────────────── */
.hero { position:relative; min-height:100vh; display:flex; align-items:center; overflow:hidden; padding-top:64px; }
.hero-video-wrap { position:absolute; inset:0; z-index:0; }
.hero-video { width:100%; height:100%; object-fit:cover; display:block; }
.hero-overlay { position:absolute; inset:0; background:linear-gradient(135deg,rgba(13,15,20,0.58) 0%,rgba(13,15,20,0.42) 55%,rgba(13,15,20,0.22) 100%); }
.hero-content { position:relative; z-index:1; max-width:1240px; margin:0 auto; padding:80px 28px 160px; width:100%; }
.hero-eyebrow { font-size:0.72rem; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--orange); margin-bottom:20px; display:block; }
.hero h1 { color:#fff; margin-bottom:22px; }
.hero h1 span { color:var(--orange); }
.hero-sub { color:rgba(255,255,255,0.78); font-size:1.1rem; max-width:600px; margin-bottom:28px; line-height:1.75; }
.hero-trust { display:flex; gap:16px; flex-wrap:wrap; margin-bottom:36px; }
.hero-trust span { font-size:0.78rem; font-weight:600; color:rgba(255,255,255,0.65); padding:6px 14px; border:1px solid rgba(255,255,255,0.2); border-radius:20px; }
.stats-bar { position:absolute; bottom:0; left:0; right:0; z-index:2; background:rgba(255,255,255,0.07); backdrop-filter:blur(12px); border-top:1px solid rgba(255,255,255,0.1); }
.stats-inner { max-width:1240px; margin:0 auto; padding:0 28px; display:grid; grid-template-columns:repeat(4,1fr); }
.stat-item { padding:22px 20px; text-align:center; border-right:1px solid rgba(255,255,255,0.1); }
.stat-item:last-child { border-right:none; }
.stat-num { font-size:1.9rem; font-weight:900; color:#fff; letter-spacing:-1px; line-height:1; }
.stat-label { font-size:0.75rem; color:rgba(255,255,255,0.55); margin-top:4px; font-weight:500; }

/* ─── SECTIONS ─────────────────────────────────── */
.section-light  { background:var(--surface); padding:80px 0; }
.section-grey   { background:var(--bg);      padding:80px 0; }
.section-dark2  { background:var(--dark);    padding:80px 0; }
.section-light .section-eyebrow,
.section-grey  .section-eyebrow { color:var(--orange); }
.section-dark2 h2 { color:#fff; }
.section-dark2 p  { color:rgba(255,255,255,0.65); }
.section-dark2 .section-eyebrow { color:rgba(232,96,10,0.9); }

/* ─── SERVICE CARDS ────────────────────────────── */
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:44px; }
@media(max-width:900px) { .services-grid { grid-template-columns:1fr 1fr; } }
@media(max-width:580px) { .services-grid { grid-template-columns:1fr; } }
.service-card { background:var(--surface); border:1px solid var(--border); border-radius:10px; padding:30px; position:relative; transition:border-color 0.2s, box-shadow 0.2s; }
.service-card:hover { border-color:var(--orange); box-shadow:0 4px 24px rgba(232,96,10,0.1); }
.service-card.featured { border-color:var(--orange); background:var(--orange); }
.service-card.featured h3, .service-card.featured p, .service-card.featured .card-link { color:#fff; }
.service-card.featured .card-tag { background:rgba(255,255,255,0.25); color:#fff; }
.card-tag { display:inline-block; font-size:0.68rem; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; background:rgba(232,96,10,0.1); color:var(--orange); padding:4px 10px; border-radius:20px; margin-bottom:14px; }
.service-card h3 { color:var(--text); margin-bottom:10px; font-size:1rem; }
.service-card p  { color:var(--text2); font-size:0.88rem; line-height:1.7; margin-bottom:18px; }
.card-link { font-size:0.82rem; font-weight:700; color:var(--orange); }
.service-card.featured .card-link { color:#fff; }

/* ─── PHOTO SECTION ────────────────────────────── */
.photo-section { position:relative; min-height:520px; display:flex; align-items:center; overflow:hidden; background:var(--dark); }
.photo-section-img { position:absolute; inset:0; background:url('https://images.pexels.com/photos/34006092/pexels-photo-34006092.jpeg?auto=compress&cs=tinysrgb&w=1920') center/cover no-repeat; }
.photo-section-overlay { position:absolute; inset:0; background:linear-gradient(90deg,rgba(13,15,20,0.97) 0%,rgba(13,15,20,0.88) 50%,rgba(13,15,20,0.45) 100%); }
.photo-content { position:relative; z-index:1; max-width:1240px; margin:0 auto; padding:80px 28px; width:100%; }
.photo-content h2 { color:#fff; }
.photo-content .section-eyebrow { color:var(--orange); }

/* ─── TWO-COL ──────────────────────────────────── */
.two-col { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center; }
@media(max-width:860px) { .two-col { grid-template-columns:1fr; gap:44px; } }

/* ─── FM STEPS BOX ─────────────────────────────── */
.fm-box { background:var(--surface); border:1px solid var(--border); border-radius:12px; padding:40px; }
.fm-step { display:flex; gap:16px; align-items:flex-start; padding:18px 0; border-bottom:1px solid var(--border); }
.fm-step:last-child { border-bottom:none; }
.fm-num { background:var(--orange); color:#fff; min-width:32px; height:32px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:800; font-size:0.85rem; flex-shrink:0; }
.fm-step h4 { color:var(--text); margin-bottom:3px; }
.fm-step p  { color:var(--text2); font-size:0.85rem; margin:0; }

/* ─── CHECKLIST ────────────────────────────────── */
.checklist { list-style:none; }
.checklist li { padding:10px 0 10px 28px; position:relative; font-size:0.92rem; color:var(--text2); border-bottom:1px solid var(--border); line-height:1.6; }
.checklist li:last-child { border-bottom:none; }
.checklist li::before { content:"✓"; position:absolute; left:0; color:var(--orange); font-weight:800; }
.photo-content .checklist li { color:rgba(255,255,255,0.72); border-bottom-color:rgba(255,255,255,0.1); }

/* ─── SECTORS ──────────────────────────────────── */
.sectors-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:44px; }
@media(max-width:900px) { .sectors-grid { grid-template-columns:1fr 1fr; } }
@media(max-width:560px) { .sectors-grid { grid-template-columns:1fr; } }
.sector-card { position:relative; height:260px; border-radius:10px; overflow:hidden; background:var(--surface2); display:flex; align-items:flex-end; }
.sector-bg { position:absolute; inset:0; background-size:cover; background-position:center; transition:transform 0.5s; }
.sector-card:hover .sector-bg { transform:scale(1.04); }
.sector-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(13,15,20,0.92) 0%,rgba(13,15,20,0.15) 100%); }
.sector-text { position:relative; z-index:1; padding:22px; }
.sector-text h3 { color:#fff; font-size:0.95rem; margin-bottom:4px; }
.sector-text p  { color:rgba(255,255,255,0.6); font-size:0.78rem; margin:0; line-height:1.5; }

/* ─── WHY GRID ─────────────────────────────────── */
.why-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:0; margin-top:44px; }
@media(max-width:900px) { .why-grid { grid-template-columns:1fr 1fr; } }
@media(max-width:560px) { .why-grid { grid-template-columns:1fr; } }
.why-card { padding:40px 36px; border-right:1px solid var(--border); border-bottom:1px solid var(--border); background:var(--surface); }
.why-card:nth-child(3n) { border-right:none; }
.why-card:nth-last-child(-n+3) { border-bottom:none; }
.why-num { font-size:3rem; font-weight:900; color:rgba(232,96,10,0.12); line-height:1; margin-bottom:14px; letter-spacing:-2px; }
.why-card h3 { color:var(--text); font-size:1rem; margin-bottom:10px; }
.why-card p  { color:var(--text2); font-size:0.88rem; line-height:1.7; margin:0; }

/* ─── CTA BANNER ───────────────────────────────── */
.cta-banner { background:var(--orange); padding:80px 28px; text-align:center; }
.cta-banner h2 { color:#fff; margin-bottom:14px; }
.cta-banner p  { color:rgba(255,255,255,0.88); max-width:540px; margin:0 auto 32px; font-size:1.05rem; }
.cta-banner .btn-outline-white:hover { background:rgba(255,255,255,0.15); }

/* ─── CTA SECTION (inner pages) ────────────────── */
.cta-section { background:var(--orange); padding:72px 28px; text-align:center; }
.cta-section h2 { color:#fff; margin-bottom:14px; }
.cta-section p  { color:rgba(255,255,255,0.88); max-width:560px; margin:0 auto 32px; }

/* ─── PAGE HERO (inner pages) ──────────────────── */
.page-hero { background:var(--surface2); border-bottom:4px solid var(--orange); padding:100px 28px 56px; margin-top:64px; }
.page-hero h1 { color:var(--text); font-size:clamp(1.8rem,4vw,3rem); margin-bottom:12px; }
.page-hero p  { color:var(--text2); max-width:600px; font-size:1rem; }
.badges { display:flex; flex-wrap:wrap; gap:10px; margin-top:20px; }
.badges span { font-size:0.75rem; font-weight:600; color:var(--text2); padding:5px 12px; border:1px solid var(--border); border-radius:20px; background:#fff; }

/* ─── BREADCRUMB ───────────────────────────────── */
.breadcrumb { background:var(--surface); border-bottom:1px solid var(--border); padding:12px 0; }
.breadcrumb .container { display:flex; gap:8px; align-items:center; font-size:0.82rem; color:var(--text3); }
.breadcrumb a { color:var(--text3); text-decoration:none; }
.breadcrumb a:hover { color:var(--orange); }

/* ─── PAGE LAYOUT (inner pages) ────────────────── */
.page-layout { max-width:1240px; margin:0 auto; padding:60px 28px; display:grid; grid-template-columns:1fr 300px; gap:48px; align-items:start; }
@media(max-width:900px) { .page-layout { grid-template-columns:1fr; } }
.page-layout main h2 { color:var(--text); margin-bottom:16px; font-size:1.7rem; }
.page-layout main p  { color:var(--text2); margin-bottom:20px; }
.page-layout main h3 { color:var(--text); margin:28px 0 10px; font-size:1.05rem; }

/* ─── CARD GRID (inner pages) ──────────────────── */
.card-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; margin:28px 0; }
@media(max-width:640px) { .card-grid { grid-template-columns:1fr; } }
.card { background:var(--surface); border:1px solid var(--border); border-radius:10px; padding:28px; text-decoration:none; display:block; transition:border-color 0.2s, box-shadow 0.2s; }
.card:hover { border-color:var(--orange); box-shadow:0 4px 20px rgba(232,96,10,0.1); }
.card-icon { font-size:1.6rem; margin-bottom:14px; }
.card h3 { color:var(--text); margin-bottom:8px; }
.card p  { color:var(--text2); font-size:0.88rem; line-height:1.7; margin-bottom:14px; }
.card .card-link { font-size:0.82rem; font-weight:700; color:var(--orange); }

/* ─── TARGET BANNER ────────────────────────────── */
.target-banner { background:rgba(232,96,10,0.07); border:1px solid rgba(232,96,10,0.2); border-left:4px solid var(--orange); border-radius:0 8px 8px 0; padding:20px 24px; margin:28px 0; }
.target-banner p { color:var(--text); margin:0; font-size:0.92rem; }

/* ─── SIDEBAR ──────────────────────────────────── */
.sidebar { display:flex; flex-direction:column; gap:20px; }
.sidebar-box { background:var(--surface); border:1px solid var(--border); border-radius:10px; padding:24px; }
.sidebar-box h3 { color:var(--text); font-size:0.95rem; margin-bottom:14px; }
.sidebar-box ul { list-style:none; }
.sidebar-box ul li { padding:7px 0; border-bottom:1px solid var(--border); font-size:0.88rem; color:var(--text2); }
.sidebar-box ul li:last-child { border-bottom:none; }
.sidebar-box ul a { color:var(--text2); text-decoration:none; }
.sidebar-box ul a:hover { color:var(--orange); }
.sidebar-box p { font-size:0.88rem; margin-bottom:12px; }

/* ─── FOOTER ───────────────────────────────────── */
.site-footer,footer { background:var(--dark); color:rgba(255,255,255,0.55); padding:64px 28px 32px; }
.footer-inner,.footer-grid { max-width:1240px; margin:0 auto; display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; margin-bottom:48px; }
.footer-logo,.footer-brand .logo-main { font-size:1.3rem; font-weight:900; color:#fff; letter-spacing:-0.03em; margin-bottom:6px; }
.footer-logo span { color:var(--orange); }
.footer-brand .logo-main span { color:var(--orange); }
.footer-brand p { color:rgba(255,255,255,0.4); font-size:0.85rem; line-height:1.7; margin-top:12px; }
.footer-col h4 { color:#fff; font-size:0.75rem; text-transform:uppercase; letter-spacing:2px; margin-bottom:16px; }
.footer-col ul { list-style:none; }
.footer-col ul li { margin-bottom:9px; }
.footer-col ul a { color:rgba(255,255,255,0.5); text-decoration:none; font-size:0.87rem; transition:color 0.2s; }
.footer-col ul a:hover { color:var(--orange); }
.footer-bottom { max-width:1240px; margin:0 auto; border-top:1px solid rgba(255,255,255,0.08); padding-top:24px; font-size:0.8rem; color:rgba(255,255,255,0.3); }
@media(max-width:900px) { .footer-inner,.footer-grid { grid-template-columns:1fr 1fr; } }
@media(max-width:560px) { .footer-inner,.footer-grid { grid-template-columns:1fr; } }

/* ─── PHOTO PAGE HERO (inner pages with photo bg) ─── */
.page-hero-photo { position:relative; padding:160px 28px 120px; margin-top:64px; overflow:hidden; min-height:480px; display:flex; align-items:center; }
.page-hero-photo::before { content:''; position:absolute; inset:0; background-size:cover; background-position:center; background-attachment:fixed; }
.page-hero-photo::after  { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(13,15,20,0.82) 0%,rgba(13,15,20,0.60) 100%); }
.page-hero-photo .container { position:relative; z-index:1; }
.page-hero-photo h1 { color:#fff; }
.page-hero-photo p  { color:rgba(255,255,255,0.78); }
.page-hero-photo .section-eyebrow { color:var(--orange); }
.page-hero-photo .badges span { color:rgba(255,255,255,0.75); border-color:rgba(255,255,255,0.25); background:rgba(255,255,255,0.08); }

/* photo bg helpers */
.bg-roof    { background-image:url('https://images.pexels.com/photos/34006092/pexels-photo-34006092.jpeg?auto=compress&cs=tinysrgb&w=1280'); }
.bg-cladding{ background-image:url('https://images.pexels.com/photos/34134988/pexels-photo-34134988.jpeg?auto=compress&cs=tinysrgb&w=1280'); }
.bg-aerial1 { background-image:url('https://images.pexels.com/photos/19035388/pexels-photo-19035388.jpeg?auto=compress&cs=tinysrgb&w=1280'); }
.bg-aerial2 { background-image:url('https://images.pexels.com/photos/19035391/pexels-photo-19035391.jpeg?auto=compress&cs=tinysrgb&w=1280'); }
.bg-aerial3 { background-image:url('https://images.pexels.com/photos/20711858/pexels-photo-20711858.jpeg?auto=compress&cs=tinysrgb&w=1280'); }
.bg-aerial4 { background-image:url('https://images.pexels.com/photos/16726161/pexels-photo-16726161.jpeg?auto=compress&cs=tinysrgb&w=1280'); }

.page-hero-photo.bg-roof::before    { background-image:url('https://images.pexels.com/photos/34006092/pexels-photo-34006092.jpeg?auto=compress&cs=tinysrgb&w=1280'); }
.page-hero-photo.bg-cladding::before{ background-image:url('https://images.pexels.com/photos/34134988/pexels-photo-34134988.jpeg?auto=compress&cs=tinysrgb&w=1280'); }
.page-hero-photo.bg-aerial1::before { background-image:url('https://images.pexels.com/photos/19035388/pexels-photo-19035388.jpeg?auto=compress&cs=tinysrgb&w=1280'); }
.page-hero-photo.bg-aerial2::before { background-image:url('https://images.pexels.com/photos/19035391/pexels-photo-19035391.jpeg?auto=compress&cs=tinysrgb&w=1280'); }
.page-hero-photo.bg-aerial3::before { background-image:url('https://images.pexels.com/photos/20711858/pexels-photo-20711858.jpeg?auto=compress&cs=tinysrgb&w=1280'); }
.page-hero-photo.bg-aerial4::before { background-image:url('https://images.pexels.com/photos/16726161/pexels-photo-16726161.jpeg?auto=compress&cs=tinysrgb&w=1280'); }
