/* ================================================================
   Summit Pro Roofing & Construction — Contractor Demo
   Nova AI Solutions Showcase Demo

   Identity: bold, light, industrial. Deep "roofing navy" + a
   high-energy safety-orange, condensed Oswald headings on Inter body.
   Deliberately unlike the Nova marketing site — this should read as a
   real home-services contractor a prospect could buy tomorrow.
   ================================================================ */

:root {
  --navy:        #0f2740;
  --navy-2:      #16395c;
  --navy-deep:   #0a1c30;
  --orange:      #ee5a18;
  --orange-600:  #cf4b10;
  --orange-dim:  rgba(238,90,24,0.10);
  --orange-line: rgba(238,90,24,0.30);

  --ink:         #14212e;
  --muted:       #51637a;
  --dim:         #8190a3;

  --bg:          #ffffff;
  --bg-alt:      #f2f5f9;
  --surface:     #ffffff;
  --border:      rgba(16,33,48,0.12);
  --border-strong: rgba(16,33,48,0.20);
  --success:     #1f9d57;

  --radius:      10px;
  --radius-lg:   16px;
  --shadow:      0 10px 30px rgba(16,33,48,0.10);
  --shadow-lg:   0 24px 60px rgba(16,33,48,0.16);
  --transition:  0.3s cubic-bezier(0.23,1,0.32,1);
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:17px; }
body { background:var(--bg); color:var(--ink); font-family:'Inter',sans-serif; font-weight:400; line-height:1.6; overflow-x:hidden; }
h1,h2,h3,h4 { font-family:'Oswald',sans-serif; line-height:1.08; letter-spacing:0.005em; text-transform:uppercase; }
a { color:inherit; text-decoration:none; }
img { max-width:100%; }
::-webkit-scrollbar { width:10px; }
::-webkit-scrollbar-track { background:var(--bg-alt); }
::-webkit-scrollbar-thumb { background:var(--navy); border-radius:0; }

:focus-visible { outline:3px solid var(--orange); outline-offset:2px; }

/* NOVA DEMO BANNER (intentionally Nova-branded — marks this as a demo) */
.nova-banner {
  position:fixed; top:0; left:0; right:0; z-index:9999;
  background:rgba(7,11,28,0.96);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(0,200,255,0.3);
  padding:0 5%; height:44px; display:flex; align-items:center;
}
.nova-banner-inner { display:flex; align-items:center; gap:0.75rem; font-size:0.8rem; width:100%; }
.nova-banner-logo { font-family:'Inter',sans-serif; font-weight:700; color:#00c8ff; }
.nova-banner-sep { color:#5a6b86; }
.nova-banner-text { color:#aeb8cc; flex:1; }
.nova-banner-cta {
  padding:0.32rem 0.95rem; background:linear-gradient(135deg,#00c8ff,#a259ff);
  border-radius:50px; color:#fff; font-weight:700; font-size:0.78rem;
  white-space:nowrap; transition:opacity 0.2s;
}
.nova-banner-cta:hover { opacity:0.88; }

/* CLIENT NAV */
.c-nav {
  position:fixed; top:44px; left:0; right:0; z-index:100;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(18px);
  border-bottom:1px solid var(--border);
  transition:box-shadow var(--transition), background var(--transition);
}
.c-nav.scrolled { background:rgba(255,255,255,0.98); box-shadow:0 4px 20px rgba(16,33,48,0.08); }
.c-nav-inner { max-width:1200px; margin:0 auto; padding:0 5%; height:72px; display:flex; align-items:center; gap:2rem; }
.c-nav-logo { display:flex; align-items:center; gap:0.75rem; flex-shrink:0; }
.c-logo-mark {
  width:46px; height:46px; border-radius:8px;
  background:var(--navy); position:relative; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
  font-family:'Oswald',sans-serif; font-weight:700; font-size:1rem; color:#fff;
  box-shadow:inset 0 -3px 0 var(--orange);
}
.c-logo-mark.small { width:34px; height:34px; font-size:0.78rem; border-radius:6px; }
.c-logo-name { font-family:'Oswald',sans-serif; font-weight:700; font-size:1.15rem; display:block; color:var(--navy); text-transform:uppercase; letter-spacing:0.01em; }
.c-logo-sub { font-size:0.68rem; color:var(--muted); display:block; letter-spacing:0.16em; text-transform:uppercase; }
.c-nav-links { display:flex; gap:2rem; list-style:none; flex:1; justify-content:center; }
.c-nav-links a { font-size:0.82rem; color:var(--ink); font-weight:600; letter-spacing:0.06em; text-transform:uppercase; transition:color 0.2s; }
.c-nav-links a:hover { color:var(--orange); }
.c-nav-cta {
  padding:0.7rem 1.5rem; background:var(--orange); color:#fff;
  border-radius:6px; font-family:'Oswald',sans-serif; font-size:0.85rem; font-weight:600;
  letter-spacing:0.05em; text-transform:uppercase; flex-shrink:0;
  transition:background var(--transition), transform 0.15s; box-shadow:0 6px 18px rgba(238,90,24,0.28);
}
.c-nav-cta:hover { background:var(--orange-600); transform:translateY(-1px); }
.c-hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:4px; }
.c-hamburger span { width:24px; height:2px; background:var(--navy); border-radius:2px; transition:all 0.3s; display:block; }

/* BUTTONS */
.c-btn-primary {
  display:inline-flex; align-items:center; gap:8px;
  padding:0.95rem 2rem; border-radius:6px;
  background:var(--orange); color:#fff;
  font-family:'Oswald',sans-serif; font-size:0.98rem; font-weight:600;
  letter-spacing:0.05em; text-transform:uppercase;
  cursor:pointer; border:none; text-decoration:none;
  transition:background var(--transition), transform 0.15s, box-shadow 0.2s;
  box-shadow:0 8px 22px rgba(238,90,24,0.30);
}
.c-btn-primary:hover { background:var(--orange-600); transform:translateY(-2px); box-shadow:0 12px 30px rgba(238,90,24,0.40); }
.c-btn-ghost {
  display:inline-flex; align-items:center; gap:8px;
  padding:0.95rem 2rem; border-radius:6px;
  background:transparent; color:#fff;
  font-family:'Oswald',sans-serif; font-size:0.98rem; font-weight:600;
  letter-spacing:0.05em; text-transform:uppercase;
  cursor:pointer; border:2px solid rgba(255,255,255,0.35); text-decoration:none;
  transition:border-color var(--transition), background var(--transition);
}
.c-btn-ghost:hover { border-color:#fff; background:rgba(255,255,255,0.10); }

/* LAYOUT */
.c-container { max-width:1200px; margin:0 auto; padding:0 5%; }
.c-section { padding:6.5rem 0; }
.c-section-alt { padding:6.5rem 0; background:var(--bg-alt); }

/* SECTION HEADERS */
.c-section-header { text-align:center; margin-bottom:3.5rem; }
.c-eyebrow {
  font-family:'Oswald',sans-serif; font-size:0.8rem; font-weight:600; letter-spacing:0.18em;
  text-transform:uppercase; color:var(--orange); margin-bottom:0.6rem; display:block;
}
.c-eyebrow-amber { color:var(--orange); }
.c-section-title { font-size:clamp(2rem,4vw,3rem); font-weight:700; color:var(--navy); margin-bottom:1rem; }
.c-section-sub { color:var(--muted); font-size:1.02rem; max-width:560px; margin:0 auto; line-height:1.7; }

/* HERO */
.c-hero {
  min-height:100vh; display:flex; align-items:center;
  padding-top:116px; color:#fff;
  background:
    linear-gradient(180deg, rgba(10,28,48,0.86), rgba(10,28,48,0.94)),
    repeating-linear-gradient(125deg, rgba(255,255,255,0.035) 0 2px, transparent 2px 26px),
    linear-gradient(135deg, #13314f 0%, #0a1c30 100%);
}
.c-hero-inner { max-width:1200px; margin:0 auto; padding:5rem 5% 5rem; width:100%; }
.c-hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  padding:0.45rem 1.1rem; border:1px solid rgba(255,255,255,0.22);
  border-radius:4px; background:rgba(255,255,255,0.06);
  font-size:0.78rem; font-weight:600; color:#fff; letter-spacing:0.1em;
  text-transform:uppercase; margin-bottom:1.75rem;
}
.c-badge-dot { width:7px; height:7px; border-radius:50%; background:var(--orange); box-shadow:0 0 10px var(--orange); }
.c-hero-title { font-size:clamp(3rem,6.5vw,5.8rem); font-weight:700; line-height:1.0; margin-bottom:1.5rem; max-width:760px; color:#fff; }
.c-accent { color:var(--orange); }
.c-hero-sub { font-size:1.15rem; color:rgba(255,255,255,0.82); line-height:1.7; max-width:560px; margin-bottom:2.5rem; }
.c-hero-actions { display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:4rem; }
.c-hero-stats {
  display:grid; grid-template-columns:repeat(4,1fr); gap:2rem;
  padding-top:3rem; border-top:1px solid rgba(255,255,255,0.16); max-width:760px;
}
.c-stat-num { font-family:'Oswald',sans-serif; font-size:2.6rem; font-weight:700; color:var(--orange); margin-bottom:0.2rem; }
.c-stat-label { font-size:0.82rem; color:rgba(255,255,255,0.7); font-weight:500; letter-spacing:0.04em; }

/* TRUST BAR */
.c-trust-bar { background:var(--navy); padding:1.4rem 0; }
.c-trust-bar-inner { max-width:1200px; margin:0 auto; padding:0 5%; display:flex; gap:2.5rem; flex-wrap:wrap; justify-content:center; }
.c-trust-item { display:flex; align-items:center; gap:0.6rem; font-size:0.85rem; color:rgba(255,255,255,0.85); font-weight:500; }
.c-trust-item svg { stroke:var(--orange); flex-shrink:0; }

/* SERVICES */
.c-services-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1.5rem; }
.c-service-card {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:2.5rem; position:relative; overflow:hidden;
  transition:border-color var(--transition), transform var(--transition), box-shadow var(--transition);
}
.c-service-card::before { content:''; position:absolute; top:0; left:0; width:100%; height:4px; background:var(--orange); transform:scaleX(0); transform-origin:left; transition:transform var(--transition); }
.c-service-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); border-color:var(--border-strong); }
.c-service-card:hover::before { transform:scaleX(1); }
.c-service-icon {
  width:58px; height:58px; border-radius:10px;
  background:var(--navy); display:flex; align-items:center; justify-content:center; margin-bottom:1.5rem;
}
.c-service-icon svg { width:26px; height:26px; stroke:#fff; }
.c-service-title { font-size:1.5rem; font-weight:600; color:var(--navy); margin-bottom:0.75rem; }
.c-service-desc { font-size:0.95rem; color:var(--muted); line-height:1.7; margin-bottom:1.25rem; }
.c-service-list { list-style:none; display:flex; flex-direction:column; gap:0.5rem; }
.c-service-list li { font-size:0.9rem; color:var(--ink); display:flex; align-items:center; gap:0.6rem; }
.c-service-list li::before { content:''; width:7px; height:7px; background:var(--orange); flex-shrink:0; }

/* ABOUT */
.c-about-inner { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }
.c-about-text { color:var(--muted); line-height:1.85; font-size:1rem; margin-bottom:1rem; }
.c-about-highlights { display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin-top:2rem; }
.c-about-highlight { padding:1.4rem; background:var(--surface); border:1px solid var(--border); border-left:4px solid var(--orange); border-radius:8px; text-align:left; transition:box-shadow var(--transition); }
.c-about-highlight:hover { box-shadow:var(--shadow); }
.c-about-num { font-family:'Oswald',sans-serif; font-size:2rem; font-weight:700; color:var(--navy); }
.c-about-hlabel { font-size:0.8rem; color:var(--muted); margin-top:0.1rem; }
.c-about-img-placeholder {
  background:linear-gradient(135deg,#13314f,#0a1c30);
  border-radius:var(--radius-lg); padding:3rem 2rem;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; min-height:280px; margin-bottom:1rem;
}
.c-about-img-placeholder svg path,
.c-about-img-placeholder svg rect,
.c-about-img-placeholder svg circle { stroke:rgba(238,90,24,0.7) !important; fill:rgba(238,90,24,0.10) !important; }
.c-about-img-label { font-size:0.82rem; color:rgba(255,255,255,0.7); margin-top:1rem; letter-spacing:0.04em; }
.c-cert-badges, .c-about-cert-badges { display:flex; flex-direction:column; gap:0.5rem; }
.c-cert-badge { padding:0.65rem 1rem; background:var(--bg-alt); border:1px solid var(--border); border-radius:6px; font-size:0.82rem; font-weight:500; color:var(--navy); text-align:center; }

/* BEFORE / AFTER GALLERY */
.c-gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.c-ba-wrapper { display:flex; flex-direction:column; gap:0.75rem; }
.c-ba-container { position:relative; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--border); background:var(--navy); min-height:280px; user-select:none; box-shadow:var(--shadow); }
.c-ba-panel { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; }
.c-ba-before { background:linear-gradient(135deg,#4a4038,#33291f); z-index:1; }
.c-ba-after { background:linear-gradient(135deg,#16395c,#0d2742); z-index:2; width:50%; overflow:hidden; border-right:3px solid #fff; transition:width 0.05s linear; }
.c-ba-panel-inner { display:flex; flex-direction:column; align-items:center; text-align:center; padding:1.5rem; gap:0.5rem; }
.c-ba-icon { width:42px; height:42px; display:flex; align-items:center; justify-content:center; }
.c-ba-icon svg { width:32px; height:32px; stroke:rgba(255,255,255,0.35); }
.c-ba-after-icon svg { stroke:rgba(238,90,24,0.9); }
.c-ba-label-tag { font-family:'Oswald',sans-serif; font-size:0.66rem; font-weight:700; letter-spacing:0.18em; padding:0.2rem 0.7rem; border-radius:3px; }
.c-ba-before-tag { background:rgba(0,0,0,0.35); color:#f8c9b3; border:1px solid rgba(248,201,179,0.4); }
.c-ba-after-tag { background:rgba(238,90,24,0.9); color:#fff; }
.c-ba-project { font-family:'Oswald',sans-serif; font-size:0.92rem; font-weight:600; color:#fff; text-transform:none; }
.c-ba-detail { font-size:0.74rem; color:rgba(255,255,255,0.72); line-height:1.6; }
.c-ba-divider { position:absolute; top:0; bottom:0; z-index:3; width:3px; background:#fff; left:50%; transform:translateX(-50%); pointer-events:none; }
.c-ba-range { width:100%; cursor:ew-resize; -webkit-appearance:none; appearance:none; height:30px; background:var(--bg-alt); border-radius:6px; border:1px solid var(--border); outline:none; }
.c-ba-range::-webkit-slider-thumb { -webkit-appearance:none; width:30px; height:30px; border-radius:6px; background:var(--orange); cursor:ew-resize; box-shadow:0 0 0 4px rgba(238,90,24,0.2); }
.c-ba-range::-moz-range-thumb { width:30px; height:30px; border-radius:6px; border:none; background:var(--orange); cursor:ew-resize; }

/* QUOTE ASSISTANT */
.c-quote-card { max-width:760px; margin:0 auto; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-lg); }
.c-quote-steps { display:flex; align-items:center; gap:0; padding:1.5rem 2rem; border-bottom:1px solid var(--border); background:var(--navy); }
.c-quote-step { width:34px; height:34px; border-radius:50%; background:rgba(255,255,255,0.10); border:1px solid rgba(255,255,255,0.18); display:flex; align-items:center; justify-content:center; font-family:'Oswald',sans-serif; font-size:0.82rem; font-weight:600; color:rgba(255,255,255,0.65); flex-shrink:0; transition:all 0.3s; }
.c-quote-step.active { background:var(--orange); border-color:var(--orange); color:#fff; }
.c-quote-step.done { background:var(--success); border-color:var(--success); color:#fff; }
.c-quote-step-line { flex:1; height:2px; background:rgba(255,255,255,0.18); }
.c-quote-panel { padding:2.5rem; display:none; }
.c-quote-panel.active { display:block; }
.c-quote-panel-header { margin-bottom:1.75rem; }
.c-quote-ai-tag { display:inline-flex; align-items:center; gap:7px; font-family:'Oswald',sans-serif; font-size:0.74rem; font-weight:600; letter-spacing:0.12em; text-transform:uppercase; color:var(--orange); margin-bottom:0.75rem; }
.c-ai-dot { width:7px; height:7px; border-radius:50%; background:var(--orange); animation:aipulse 1.5s infinite; }
@keyframes aipulse { 0%,100%{opacity:1;} 50%{opacity:0.3;} }
.c-quote-q { font-size:1.6rem; font-weight:600; color:var(--navy); margin-bottom:0.4rem; }
.c-quote-sub-text { font-size:0.95rem; color:var(--muted); line-height:1.6; }
.c-quote-options { display:flex; flex-wrap:wrap; gap:0.75rem; }
.c-quote-opt { display:flex; align-items:center; gap:0.6rem; padding:0.85rem 1.3rem; background:var(--bg-alt); border:1px solid var(--border); border-radius:8px; cursor:pointer; transition:all 0.2s; color:var(--ink); font-family:'Inter',sans-serif; font-size:0.92rem; font-weight:500; }
.c-quote-opt svg { width:18px; height:18px; stroke:var(--muted); flex-shrink:0; }
.c-quote-opt:hover { border-color:var(--orange-line); background:var(--orange-dim); }
.c-quote-opt.selected { border-color:var(--orange); background:var(--orange-dim); color:var(--orange-600); font-weight:600; }
.c-quote-opt.selected svg { stroke:var(--orange); }
.c-quote-options.small .c-quote-opt { padding:0.6rem 1.1rem; font-size:0.86rem; }
.c-quote-fields { display:flex; flex-direction:column; gap:1.5rem; margin-bottom:1.75rem; }
.c-quote-label { display:block; font-family:'Oswald',sans-serif; font-size:0.78rem; font-weight:600; letter-spacing:0.08em; text-transform:uppercase; color:var(--navy); margin-bottom:0.6rem; }
.c-quote-next { width:100%; justify-content:center; }
.c-quote-next:disabled { opacity:0.4; cursor:not-allowed; transform:none !important; box-shadow:none !important; }

/* Generating animation */
.c-quote-generating { text-align:center; padding:1rem 0 1.5rem; }
.c-gen-spinner { width:50px; height:50px; border:4px solid var(--bg-alt); border-top-color:var(--orange); border-radius:50%; animation:spin 0.9s linear infinite; margin:0 auto 1.25rem; }
@keyframes spin { to { transform:rotate(360deg); } }
.c-gen-title { font-family:'Oswald',sans-serif; font-size:1.25rem; font-weight:600; color:var(--navy); margin-bottom:1.25rem; }
.c-gen-steps { display:flex; flex-direction:column; gap:0.5rem; max-width:340px; margin:0 auto; }
.c-gen-step { font-size:0.88rem; color:var(--dim); padding:0.5rem 1rem; border-radius:6px; transition:all 0.4s; }
.c-gen-step.active { color:var(--orange-600); background:var(--orange-dim); font-weight:600; }
.c-gen-step.done { color:var(--success); }

/* Quote result */
.c-result-header { display:flex; align-items:center; gap:1rem; padding:1.5rem; background:rgba(31,157,87,0.08); border:1px solid rgba(31,157,87,0.25); border-radius:var(--radius); margin-bottom:1.25rem; }
.c-result-label { font-family:'Oswald',sans-serif; font-size:0.74rem; text-transform:uppercase; letter-spacing:0.1em; color:var(--muted); margin-bottom:0.2rem; }
.c-result-range { font-family:'Oswald',sans-serif; font-size:2.1rem; font-weight:700; color:var(--success); }
.c-result-breakdown { display:flex; flex-direction:column; gap:0.5rem; margin-bottom:1.25rem; }
.c-result-row { display:flex; justify-content:space-between; align-items:center; font-size:0.9rem; padding:0.6rem 0; border-bottom:1px solid var(--border); }
.c-result-row-label { color:var(--muted); }
.c-result-row-val { font-family:'Oswald',sans-serif; font-weight:600; color:var(--navy); }
.c-result-disclaimer { font-size:0.82rem; color:var(--dim); line-height:1.65; margin-bottom:1.5rem; }

/* Lead capture */
.c-quote-form { display:flex; flex-direction:column; gap:1rem; }
.c-quote-form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.c-quote-form-group { display:flex; flex-direction:column; gap:0.4rem; }
.c-quote-input { background:var(--bg-alt); border:1px solid var(--border); border-radius:8px; padding:0.8rem 1rem; color:var(--ink); font-family:'Inter',sans-serif; font-size:0.95rem; outline:none; width:100%; transition:border-color 0.2s, box-shadow 0.2s; }
.c-quote-input:focus { border-color:var(--orange); background:#fff; box-shadow:0 0 0 3px rgba(238,90,24,0.12); }
.c-quote-input::placeholder { color:var(--dim); }

/* Success state */
.hidden { display:none !important; }
.c-quote-success { text-align:center; padding:1rem 0; }
.c-success-icon { margin-bottom:1rem; }
.c-success-title { font-family:'Oswald',sans-serif; font-size:1.7rem; font-weight:700; color:var(--navy); margin-bottom:0.75rem; }
.c-success-text { color:var(--muted); font-size:1rem; line-height:1.7; margin-bottom:0.75rem; }
.c-success-phone { font-size:0.92rem; color:var(--muted); }
.c-success-phone a { color:var(--orange); font-weight:600; }

/* TESTIMONIALS */
.c-testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.c-testimonial { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); padding:2rem; box-shadow:var(--shadow); transition:transform var(--transition), box-shadow var(--transition); }
.c-testimonial:hover { transform:translateY(-3px); box-shadow:var(--shadow-lg); }
.c-testimonial-stars { color:var(--orange); font-size:1.1rem; letter-spacing:2px; margin-bottom:1rem; }
.c-testimonial-text { color:var(--ink); font-size:0.95rem; line-height:1.75; margin-bottom:1.5rem; }
.c-testimonial-author { display:flex; align-items:center; gap:0.75rem; }
.c-author-avatar { width:44px; height:44px; border-radius:50%; background:var(--navy); display:flex; align-items:center; justify-content:center; font-family:'Oswald',sans-serif; font-size:0.78rem; font-weight:600; color:#fff; flex-shrink:0; }
.c-author-name { font-family:'Oswald',sans-serif; font-size:0.95rem; font-weight:600; color:var(--navy); text-transform:none; }
.c-author-detail { font-size:0.76rem; color:var(--dim); }

/* SERVICE AREA */
.c-service-area-inner { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }
.c-service-area-text { color:var(--muted); font-size:1rem; line-height:1.7; margin-bottom:1.75rem; }
.c-area-list { display:grid; grid-template-columns:1fr 1fr; gap:0.6rem; margin-bottom:1.75rem; }
.c-area-item { display:flex; align-items:center; gap:0.6rem; font-size:0.92rem; color:var(--ink); }
.c-area-dot { width:7px; height:7px; background:var(--orange); flex-shrink:0; }
.c-area-cta { display:flex; gap:1rem; flex-wrap:wrap; }
.c-area-cta .c-btn-ghost { color:var(--navy); border-color:var(--border-strong); }
.c-area-cta .c-btn-ghost:hover { border-color:var(--orange); background:var(--orange-dim); }
.c-area-map-placeholder { background:linear-gradient(135deg,#13314f,#0a1c30); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow); }
.c-area-map-placeholder svg circle,
.c-area-map-placeholder svg rect,
.c-area-map-placeholder svg line { stroke:rgba(238,90,24,0.6) !important; }
.c-area-map-placeholder svg circle[fill="#f59e0b"] { fill:var(--orange) !important; }
.c-map-inner { padding:2.5rem; display:flex; flex-direction:column; align-items:center; gap:1rem; }
.c-map-label { font-size:0.82rem; color:rgba(255,255,255,0.7); text-align:center; letter-spacing:0.04em; }

/* CONTACT */
.c-contact-inner { display:grid; grid-template-columns:1fr 1.2fr; gap:5rem; align-items:start; }
.c-contact-items { display:flex; flex-direction:column; gap:1.5rem; margin-top:1.5rem; }
.c-contact-item { display:flex; align-items:flex-start; gap:1rem; }
.c-contact-icon { width:46px; height:46px; flex-shrink:0; background:var(--navy); border-radius:10px; display:flex; align-items:center; justify-content:center; }
.c-contact-icon svg { width:20px; height:20px; stroke:#fff; }
.c-contact-label { font-family:'Oswald',sans-serif; font-size:0.74rem; text-transform:uppercase; letter-spacing:0.1em; color:var(--dim); margin-bottom:0.2rem; }
.c-contact-value { font-size:1rem; font-weight:500; color:var(--ink); }
.c-contact-sub { font-size:0.8rem; color:var(--orange-600); margin-top:0.1rem; font-weight:600; }
.c-contact-form { display:flex; flex-direction:column; gap:1rem; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); padding:2rem; box-shadow:var(--shadow); }
.c-form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.c-form-group { display:flex; flex-direction:column; gap:0.35rem; }
.c-form-label { font-family:'Oswald',sans-serif; font-size:0.76rem; font-weight:600; text-transform:uppercase; letter-spacing:0.08em; color:var(--navy); }
.c-form-input { background:var(--bg-alt); border:1px solid var(--border); border-radius:8px; padding:0.8rem 1rem; color:var(--ink); font-family:'Inter',sans-serif; font-size:0.95rem; outline:none; width:100%; transition:border-color 0.2s, box-shadow 0.2s; }
.c-form-input:focus { border-color:var(--orange); background:#fff; box-shadow:0 0 0 3px rgba(238,90,24,0.12); }
.c-form-input::placeholder { color:var(--dim); }
.c-form-textarea { resize:vertical; min-height:120px; line-height:1.6; }

/* NOVA CTA (intentionally Nova-branded) */
.nova-cta-section { padding:6rem 0; background:#0a1124; border-top:1px solid rgba(0,200,255,0.18); }
.nova-cta-inner { max-width:680px; margin:0 auto; text-align:center; padding:0 5%; }
.nova-cta-badge { display:inline-block; padding:0.32rem 0.95rem; margin-bottom:1.5rem; background:rgba(0,200,255,0.08); border:1px solid rgba(0,200,255,0.25); border-radius:50px; font-size:0.74rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:#00c8ff; }
.nova-cta-title { font-family:'Inter',sans-serif; font-size:clamp(1.8rem,3.5vw,2.5rem); font-weight:800; letter-spacing:-0.02em; text-transform:none; margin-bottom:1rem; color:#f1f5f9; }
.nova-cta-sub { color:#aeb8cc; font-size:1.02rem; line-height:1.7; margin-bottom:2.25rem; }
.nova-cta-actions { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }
.nova-cta-btn-primary { padding:0.9rem 2rem; background:linear-gradient(135deg,#00c8ff,#a259ff); border-radius:50px; color:#fff; font-weight:700; transition:opacity 0.2s, transform 0.2s; box-shadow:0 0 30px rgba(0,200,255,0.3); }
.nova-cta-btn-primary:hover { opacity:0.9; transform:translateY(-1px); }
.nova-cta-btn-ghost { padding:0.9rem 2rem; background:transparent; border:1px solid rgba(255,255,255,0.18); border-radius:50px; color:#f1f5f9; font-weight:600; transition:border-color 0.2s, background 0.2s; }
.nova-cta-btn-ghost:hover { border-color:rgba(0,200,255,0.3); background:rgba(0,200,255,0.05); }

/* CLIENT FOOTER */
.c-footer { background:var(--navy); color:#fff; padding:2.5rem 0; }
.c-footer-inner { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1.5rem; margin-bottom:1.25rem; }
.c-footer-brand { display:flex; align-items:center; gap:0.75rem; }
.c-footer-name { font-family:'Oswald',sans-serif; font-size:1.05rem; font-weight:600; color:#fff; }
.c-footer-copy { font-size:0.78rem; color:rgba(255,255,255,0.55); }
.c-footer-links { display:flex; gap:1.5rem; flex-wrap:wrap; }
.c-footer-links a { font-size:0.84rem; color:rgba(255,255,255,0.8); transition:color 0.2s; }
.c-footer-links a:hover { color:var(--orange); }
.c-footer-nova { font-size:0.78rem; color:rgba(255,255,255,0.55); border-top:1px solid rgba(255,255,255,0.12); padding-top:1rem; }
.c-footer-nova a { color:#00c8ff; }

/* RESPONSIVE */
@media (max-width:960px) {
  .c-services-grid { grid-template-columns:1fr; }
  .c-gallery-grid { grid-template-columns:1fr; }
  .c-testimonials-grid { grid-template-columns:1fr; }
  .c-about-inner { grid-template-columns:1fr; gap:3rem; }
  .c-service-area-inner { grid-template-columns:1fr; gap:3rem; }
  .c-contact-inner { grid-template-columns:1fr; gap:3rem; }
  .c-hero-stats { grid-template-columns:repeat(2,1fr); }
}
/* Collapse the nav to a menu button before the links crowd the CTA */
@media (max-width:1024px) {
  .c-nav-links { display:none; }
  .c-hamburger { display:flex; }
  .c-nav-links.open { display:flex; flex-direction:column; position:fixed; top:116px; left:0; right:0; background:rgba(255,255,255,0.98); backdrop-filter:blur(20px); padding:2rem; gap:1.5rem; border-bottom:1px solid var(--border); box-shadow:var(--shadow); }
}
@media (max-width:640px) {
  .c-nav-links { display:none; }
  .c-hamburger { display:flex; }
  .c-nav-links.open { display:flex; flex-direction:column; position:fixed; top:116px; left:0; right:0; background:rgba(255,255,255,0.98); backdrop-filter:blur(20px); padding:2rem; gap:1.5rem; border-bottom:1px solid var(--border); box-shadow:var(--shadow); }
  .c-hero-title { font-size:2.9rem; }
  .c-quote-form-row { grid-template-columns:1fr; }
  .nova-banner-text { display:none; }
  .c-hero-stats { grid-template-columns:repeat(2,1fr); }
  .c-form-row { grid-template-columns:1fr; }
  .c-area-list { grid-template-columns:1fr; }
}
