:root{
  --bg:#ffffff;--muted:#6c757d;--accent:#212529;--accent-2:#495057;--primary:#ff9800;
  --max-width:1200px;
  --header-height:64px;
  font-size:16px;
}
/* native smooth scrolling as a baseline */
html{scroll-behavior:smooth}
html{-webkit-text-size-adjust:100%}
*{box-sizing:border-box}
html,body{height:100%;margin:0;font-family:Inter,system-ui,Arial,sans-serif;color:var(--accent);background:var(--bg)}
a{color:var(--accent-2);text-decoration:none}
.site-header{position:fixed;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:12px 20px;z-index:10001;transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
.logo{font-weight:600;color:var(--accent);font-size:16px;line-height:1}
.logo img{height:70px;width:auto;display:block}
.header-right{display:flex;align-items:center;gap:12px}
.contact-top{color:var(--muted);font-size:0.95rem;display:flex;gap:8px;align-items:center}
.contact-top a{color:var(--accent-2)}
.sep{opacity:.45}
.main-nav{display:flex;gap:18px;align-items:center}
.main-nav a{color:var(--accent-2);opacity:.95;padding:3px 4px;font-size:16px;line-height:1;font-weight:600}
.mobile-logo{display:none}

/* main nav is visible on large screens; mobile toggle shows at <=960px */

/* Ensure header children don't inherit accidental transforms that change rendering */
.site-header .logo{transform:none}

/* Normalize rendering for header text to avoid bolder appearance on some pages */
.site-header .logo, .site-header .main-nav a, .site-header .contact-top a{
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
.contact-btn{
  padding:8px 16px;
  /* background:#ff9800; */
  color:#ffffff;
  border:1px solid #ff9800;
  border-radius:4px;
  transition:background 0.3s ease;
}
.contact-btn:hover{
  background:#f57c00;
  border-color:#f57c00;
}
.nav-toggle{
  display:none;
  background:transparent;
  border:0;
  color:var(--accent-2);
  font-size:20px;
}

/* Side nav / mobile */
.main-nav{transition:transform .28s ease, left .28s ease}
.nav-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:55}
.main-nav.open + .nav-overlay{opacity:1;pointer-events:auto}

/* Header: solid background to remain above content */
.site-header{background:#ffffff;box-shadow:0 2px 8px rgba(0,0,0,0.1);border-bottom:1px solid #e9ecef}
main{padding-top:var(--header-height)}

/* Scroll progress indicator */
.scroll-indicator{position:fixed;left:0;right:0;top:var(--header-height);height:4px;z-index:70;pointer-events:none;opacity:0;transition:opacity .25s ease}
.scroll-indicator .bar{height:100%;width:0;background:linear-gradient(90deg,#000000,#bdbdbd);box-shadow:0 0 8px rgba(0,0,0,.25);transition:width .12s linear}
.scroll-indicator.visible{opacity:1}

/* Background for non-home pages */
.page-bg{background:#f8f9fa;min-height:100vh}


.hero{height:63vh;min-height:390px;background:url('../images/photos/service_02.jpg') no-repeat center;background-size:cover;background-position:center;display:flex;align-items:center;position:relative}
.hero::before{content:'';position:absolute;inset:0;background:rgba(0,0,0,0.5);backdrop-filter:blur(2px);z-index:1}
.hero-inner{max-width:var(--max-width);margin:0 auto;padding:96px 28px 48px;position:relative;z-index:2}
.hero h1{font-size: clamp(28px, 5vw, 56px);margin:0 0 12px;line-height:1.02;color:#ffffff}
.tagline{color:#ffffff;margin:0 0 20px;opacity:0.95}
.cta-row a{display:inline-block;margin-right:24px;padding:12px 24px;border-radius:4px;font-weight:600;transition:all 0.3s ease}
.primary-cta{background:#212529;color:#ffffff;border:2px solid #212529}
.primary-cta:hover{background:#000000;border-color:#000000}
.secondary-cta{background:transparent;color:#212529;border:2px solid #212529}
.secondary-cta:hover{background:#212529;color:#ffffff}

.attributes{padding:64px 20px 40px}
.grid{max-width:var(--max-width);margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.tile{background:#ffffff;padding:24px;border-radius:8px;border:1px solid #e9ecef;box-shadow:0 2px 8px rgba(0,0,0,0.08);transition:transform 0.3s ease, box-shadow 0.3s ease}
.tile:hover{transform:translateY(-4px);box-shadow:0 4px 16px rgba(0,0,0,0.12)}
.tile h3{margin:0 0 8px;color:#212529}

.services-preview,.projects-preview{padding:60px 20px;background:#ffffff}
.services-preview h2,.projects-preview h2{text-align:center;font-size:2.5rem;margin-bottom:40px;color:#212529}
.services-preview .cards{display:flex;gap:20px;flex-wrap:wrap;max-width:var(--max-width);margin:12px auto}
.card{background:#ffffff;padding:24px;border-radius:8px;flex:1 1 280px;border:1px solid #e9ecef;box-shadow:0 2px 8px rgba(0,0,0,0.08);transition:transform 0.3s ease}
.card:hover{transform:translateY(-4px)}
.card h4{color:#ff9800;margin-top:0}

.project-list{max-width:var(--max-width);margin:12px auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.project{padding:0;background:#ffffff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,0.1);transition:transform 0.3s ease}
.project:hover{transform:translateY(-4px)}
.project-image{width:100%;height:240px;object-fit:cover;display:block;background:#e9ecef}
.project-content{padding:20px}
.project h4{margin-top:0;color:#212529}

/* Slideshow Gallery */
.slideshow-gallery{position:relative;width:100%;height:400px;overflow:hidden;background:#000}
.slideshow-gallery .slides{position:relative;width:100%;height:100%}
.slideshow-gallery .slide{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;transition:opacity 0.5s ease-in-out}
.slideshow-gallery .slide.active{opacity:1}
.slideshow-gallery .slide img{width:100%;height:100%;object-fit:cover;display:block}
.slideshow-gallery .prev,.slideshow-gallery .next{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,0.9);color:#212529;border:none;padding:12px 16px;cursor:pointer;font-size:18px;font-weight:bold;border-radius:4px;transition:all 0.3s ease;z-index:10;user-select:none}
.slideshow-gallery .prev:hover,.slideshow-gallery .next:hover{background:#ffffff;box-shadow:0 2px 8px rgba(0,0,0,0.2)}
.slideshow-gallery .prev{left:12px}
.slideshow-gallery .next{right:12px}
.slideshow-gallery .dots{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:10}
.slideshow-gallery .dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,0.6);border:2px solid rgba(255,255,255,0.9);cursor:pointer;transition:all 0.3s ease}
.slideshow-gallery .dot.active{background:#ff9800;border-color:#ff9800;width:28px;border-radius:5px}
.slideshow-gallery .dot:hover{background:rgba(255,255,255,0.9)}
.slideshow-gallery .counter{position:absolute;top:12px;right:12px;background:rgba(0,0,0,0.6);color:#ffffff;padding:6px 12px;border-radius:4px;font-size:14px;z-index:10}

@media (max-width:768px){
  .slideshow-gallery{height:300px}
  .slideshow-gallery .prev,.slideshow-gallery .next{padding:8px 12px;font-size:16px}
}

.contact{padding:60px 20px;text-align:center;background:#f8f9fa}
.contact h2{font-size:2.5rem;margin-bottom:20px;color:#212529}

.site-footer{border-top:1px solid #e9ecef;padding:32px 20px;margin-top:0;background:#212529;color:#ffffff}
.site-footer p{color:#ffffff;margin:0}
.footer-inner{max-width:var(--max-width);margin:0 auto;display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}

/* Responsive */
@media (max-width:960px){
  .nav-toggle{display:inline-block}
  .main-nav{position:fixed;top:0;left:-320px;height:100vh;width:280px;flex-direction:column;padding:104px 16px 20px;background:#ffffff;backdrop-filter:blur(6px);border-right:1px solid #e9ecef;z-index:60;box-shadow:2px 0 8px rgba(0,0,0,0.1)}
  .mobile-logo{display:block;position:absolute;top:16px;left:50%;transform:translateX(-50%);padding:0}
  .mobile-logo img{height:80px;width:auto}
  .main-nav a{display:block;padding:12px 6px;border-radius:6px}
  .nav-sections{display:flex;width:90%;flex-direction:row;gap:8px;margin:40px 0 7px}
  .main-nav .section-btn{flex:1;text-align:center;padding:2px 4px}
  .main-nav.open{left:0}
  .nav-overlay{opacity:0;pointer-events:none}
  .main-nav.open ~ .nav-overlay,.main-nav.open + .nav-overlay{opacity:1;pointer-events:auto}
  .hero-inner{padding-top:72px}
  .contact-top{display:none}
  .cta-row{display:flex; flex-direction:column; gap: 12px; 
  align-items:center; }
  .cta-row a{margin-right:0;}
}

/* small polish */
h2{margin:0 0 12px}
.more{text-align:center;margin-top:24px}
.more a{color:#ff9800;font-weight:600;text-decoration:none;border-bottom:2px solid #ff9800;padding-bottom:2px;transition:opacity 0.3s ease}
.more a:hover{opacity:0.8}
.attributes{padding:64px 20px 40px;background:#ffffff}

/* Navigation sections (CFR / Homeowner) */
.nav-sections{display:flex;gap:12px;align-items:center}
.section-btn{padding:4px 8px;border-radius:4px;font-weight:600;transition:all 0.3s ease;border:2px solid transparent}
.cfr-btn{
  /* background:#ff9800; */
  color:#ffffff;
  border-color:#ff9800}
.cfr-btn:hover{background:#f57c00;border-color:#f57c00}
.homeowner-btn{
  /* background:#ff9800; */
  color:#ffffff;
  border-color:#ff9800}
.homeowner-btn:hover{background:#f57c00;border-color:#f57c00}
.nav-divider{width:1px;height:24px;background:#e9ecef;margin:0 4px}

/* Footer navigation */
.footer-nav{display:flex;gap:8px;align-items:center}
.footer-nav a{color:#ffffff;opacity:0.9;transition:opacity 0.3s ease}
.footer-nav a:hover{opacity:1}
.footer-nav .sep{color:#ffffff}

/* Landing page styles */
.landing-hero{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:100px 20px 60px;background:linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%)}
.landing-container{max-width:var(--max-width);margin:0 auto;text-align:center}
.landing-hero h1{font-size:clamp(32px, 5vw, 48px);margin:0 0 16px;color:#212529}
.landing-hero .tagline{font-size:clamp(16px, 2vw, 20px);color:#6c757d;margin:0 0 60px}
.landing-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:32px;max-width:900px;margin:0 auto}
.landing-card{display:block;background:#ffffff;border-radius:12px;overflow:hidden;box-shadow:0 4px 16px rgba(0,0,0,0.1);transition:all 0.4s ease;text-decoration:none;border:2px solid transparent}
.landing-card:hover{transform:translateY(-8px);box-shadow:0 8px 32px rgba(0,0,0,0.15);border-color:#ff9800}
.landing-card-image{width:100%;height:280px;background:linear-gradient(135deg, #e9ecef 0%, #dee2e6 100%);display:flex;align-items:center;justify-content:center;font-size:48px;color:#adb5bd;position:relative;overflow:hidden}
.landing-card-content{padding:32px 24px;text-align:center}
.landing-card h2{margin:0;font-size:1.5rem;color:#212529;font-weight:600}
.landing-card p{margin:12px 0 0;color:#6c757d;font-size:0.95rem}

/* Responsive adjustments for landing page */
@media (max-width:960px){
  .landing-cards{grid-template-columns:1fr;max-width:450px}
  .landing-hero{padding:100px 20px 40px}
  .nav-divider{display:none}
}
