/* ============================================
   HIGHT RISE ROOFING — Modern Design
   ============================================ */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --gold:#c8a84e;
  --gold-light:#d4b96a;
  --gold-dark:#a88a3a;
  --gold-glow:rgba(200,168,78,0.25);
  --dark:#111111;
  --dark2:#1a1a1a;
  --dark3:#2a2a2a;
  --dark4:#333333;
  --white:#ffffff;
  --off-white:#f5f4f0;
  --text:#2a2a2a;
  --muted:#6b6b6b;
  --border:rgba(200,168,78,0.15);
  --border-light:#e8e5dd;
  --shadow:0 4px 24px rgba(0,0,0,0.06);
  --shadow-lg:0 12px 48px rgba(0,0,0,0.12);
  --shadow-gold:0 8px 32px rgba(200,168,78,0.2);
  --radius:16px;
  --radius-sm:10px;
  --radius-lg:24px;
}
html{scroll-behavior:smooth;scroll-padding-top:90px}
body{
  font-family:'Inter','Segoe UI',Roboto,-apple-system,BlinkMacSystemFont,sans-serif;
  color:var(--text);
  line-height:1.6;
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--gold-dark);text-decoration:none;transition:all 0.3s}
a:hover{color:var(--gold)}
h1,h2,h3,h4{line-height:1.15;color:var(--dark);font-weight:800;letter-spacing:-0.02em}
h1{font-size:clamp(32px,5.5vw,56px)}
h2{font-size:clamp(26px,4.5vw,42px)}
h3{font-size:clamp(18px,3vw,24px);font-weight:700}
p{margin-bottom:16px}

/* CONTAINER */
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.container-sm{max-width:800px;margin:0 auto;padding:0 24px}

/* ============================================
   HEADER — Glassmorphism
   ============================================ */
.site-header{
  position:sticky;top:0;z-index:1000;
  background:rgba(17,17,17,0.92);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(200,168,78,0.1);
  transition:all 0.4s;
}
.site-header.scrolled{
  box-shadow:0 4px 30px rgba(0,0,0,0.4);
  background:rgba(17,17,17,0.97);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 24px;max-width:1200px;margin:0 auto;
}
.header-logo img{height:64px;width:auto;transition:transform 0.3s}
.header-logo:hover img{transform:scale(1.05)}
.header-logo span{display:none}
.nav{display:flex;align-items:center;gap:28px}
.nav a{
  color:rgba(255,255,255,0.8);font-size:14px;font-weight:500;
  transition:all 0.3s;position:relative;letter-spacing:0.3px;
}
.nav a:hover,.nav a.active{color:var(--gold)}
.nav-dropdown{position:relative}
.nav-dropdown .dropdown-menu{
  display:none;position:absolute;top:100%;left:-16px;
  background:rgba(26,26,26,0.96);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(200,168,78,0.15);
  border-radius:var(--radius-sm);padding:8px 0;min-width:240px;
  box-shadow:0 16px 48px rgba(0,0,0,0.4);z-index:100;padding-top:12px;
}
.nav-dropdown::after{
  content:'';position:absolute;top:100%;left:0;right:0;height:20px;
}
.nav-dropdown:hover .dropdown-menu{display:block}
.dropdown-menu a{
  display:block;padding:10px 20px;font-size:13px;
  color:rgba(255,255,255,0.6);white-space:nowrap;
  transition:all 0.2s;
}
.dropdown-menu a:hover{
  color:var(--gold);background:rgba(200,168,78,0.08);
  padding-left:24px;
}
.header-cta{
  display:inline-flex;align-items:center;gap:6px;
  background:linear-gradient(135deg,var(--gold),var(--gold-light));
  color:var(--dark);
  padding:11px 24px;border-radius:50px;
  font-size:13px;font-weight:700;text-transform:uppercase;
  letter-spacing:0.8px;transition:all 0.3s;border:none;cursor:pointer;
}
.header-cta:hover{
  transform:translateY(-2px);
  box-shadow:0 6px 24px rgba(200,168,78,0.35);
  color:var(--dark);
}
.header-phone{
  display:flex;align-items:center;gap:8px;
  color:var(--gold);font-size:14px;font-weight:700;
}
.header-phone svg{width:16px;height:16px}

/* MOBILE MENU */
.hamburger{
  display:none;flex-direction:column;gap:6px;
  background:none;border:none;cursor:pointer;padding:4px;
}
.hamburger span{display:block;width:26px;height:2px;background:var(--gold);transition:all 0.3s;border-radius:2px}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,6px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-6px)}
.mobile-nav{
  display:none;position:fixed;top:76px;left:0;right:0;bottom:0;
  background:rgba(17,17,17,0.98);
  backdrop-filter:blur(20px);z-index:999;
  padding:24px;overflow-y:auto;
}
.mobile-nav.open{display:block}
.mobile-nav a{
  display:block;padding:14px 0;color:var(--white);
  font-size:16px;font-weight:500;border-bottom:1px solid rgba(255,255,255,0.06);
}
.mobile-nav a:hover{color:var(--gold)}
.mobile-nav .sub-links{padding-left:16px}
.mobile-nav .sub-links a{font-size:14px;color:rgba(255,255,255,0.5)}
.mobile-nav-cta{
  display:block;text-align:center;
  background:linear-gradient(135deg,var(--gold),var(--gold-light));
  color:var(--dark);
  padding:16px;border-radius:50px;margin-top:24px;
  font-weight:700;text-transform:uppercase;font-size:14px;
  letter-spacing:0.5px;
}

@media(max-width:900px){
  .nav,.header-phone,.header-cta{display:none}
  .hamburger{display:flex}
}

/* ============================================
   PROMO BANNER
   ============================================ */
.promo-banner{
  background:linear-gradient(90deg,var(--gold),var(--gold-light),var(--gold));
  background-size:200% 100%;
  animation:promo-shimmer 3s ease infinite;
  color:var(--dark);
  text-align:center;padding:12px 20px;
  font-size:14px;font-weight:700;
}
.promo-banner span{font-weight:500}
@keyframes promo-shimmer{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}

/* ============================================
   HERO — Full Impact
   ============================================ */
.hero{
  background:var(--dark);
  color:var(--white);padding:100px 0 80px;
  position:relative;overflow:hidden;
  background-size:cover;background-position:center;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(17,17,17,0.25) 0%,rgba(17,17,17,0.08) 50%,rgba(17,17,17,0.20) 100%);
}
.hero::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:120px;
  background:linear-gradient(to top,var(--dark),transparent);
}
.hero-content{position:relative;z-index:2;max-width:680px}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(200,168,78,0.12);
  border:1px solid rgba(200,168,78,0.25);
  color:var(--gold);font-size:12px;font-weight:700;
  padding:8px 18px;border-radius:50px;margin-bottom:24px;
  text-transform:uppercase;letter-spacing:2px;
  backdrop-filter:blur(10px);
}
.hero h1{color:var(--white);margin-bottom:24px;line-height:1.1}
.hero h1 span{
  color:var(--gold);
  background:linear-gradient(135deg,var(--gold),var(--gold-light));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.hero p{color:rgba(255,255,255,0.7);font-size:18px;margin-bottom:32px;line-height:1.8}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap}
.hero-trust{
  display:flex;gap:28px;margin-top:44px;flex-wrap:wrap;
  padding-top:28px;border-top:1px solid rgba(255,255,255,0.08);
}
.hero-trust-item{
  display:flex;align-items:center;gap:10px;
  font-size:13px;color:rgba(255,255,255,0.5);font-weight:500;
}
.hero-trust-item svg{width:20px;height:20px;fill:var(--gold)}

/* PAGE HERO (inner pages) */
.page-hero{
  background:var(--dark);
  color:var(--white);padding:60px 0 50px;text-align:center;
  position:relative;overflow:hidden;
  background-size:cover;background-position:center;
}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(17,17,17,0.88),rgba(17,17,17,0.95));
}
.page-hero .container{position:relative;z-index:2}
.page-hero.has-bg{background-blend-mode:overlay;background-color:rgba(17,17,17,0.82)}
.page-hero h1{color:var(--white);margin-bottom:14px}
.page-hero p{color:rgba(255,255,255,0.6);font-size:17px;max-width:600px;margin:0 auto}
.breadcrumb{font-size:13px;color:rgba(255,255,255,0.4);margin-bottom:16px}
.breadcrumb a{color:var(--gold)}

/* Service page hero image */
.service-hero-img{
  width:100%;max-height:360px;object-fit:cover;
  border-radius:var(--radius);margin:28px 0;
  box-shadow:var(--shadow-lg);
}
/* Blog featured image */
.blog-featured-img{
  width:100%;max-height:420px;object-fit:cover;
  border-radius:var(--radius);margin:0 0 28px;
  box-shadow:var(--shadow-lg);
}

/* ============================================
   BUTTONS — Modern Pills
   ============================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:15px 32px;border-radius:50px;font-size:15px;
  font-weight:700;cursor:pointer;transition:all 0.35s;
  border:none;text-decoration:none;letter-spacing:0.3px;
}
.btn-gold{
  background:linear-gradient(135deg,var(--gold),var(--gold-light));
  color:var(--dark);
}
.btn-gold:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-gold);
  color:var(--dark);
}
.btn-outline{
  background:transparent;color:var(--white);
  border:2px solid rgba(200,168,78,0.5);
}
.btn-outline:hover{
  background:var(--gold);color:var(--dark);border-color:var(--gold);
  transform:translateY(-3px);
}
.btn-dark{background:var(--dark);color:var(--white)}
.btn-dark:hover{background:var(--dark3);transform:translateY(-2px)}
.btn-sm{padding:10px 22px;font-size:13px}
.btn-lg{padding:18px 38px;font-size:16px}

/* ============================================
   SECTIONS
   ============================================ */
.section{padding:80px 0}
.section-dark{background:var(--dark);color:var(--white)}
.section-dark h2,.section-dark h3{color:var(--white)}
.section-dark p{color:rgba(255,255,255,0.6)}
.section-grey{background:var(--off-white)}
.section-header{text-align:center;margin-bottom:52px}
.section-header .label{
  display:inline-block;color:var(--gold);
  font-size:12px;font-weight:700;text-transform:uppercase;
  letter-spacing:3px;margin-bottom:12px;
}
.section-header h2{margin-bottom:12px}
.section-header p{color:var(--muted);font-size:17px;max-width:580px;margin:0 auto;line-height:1.7}

/* ============================================
   SERVICE CARDS — Glass Effect
   ============================================ */
.services-grid{
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:24px;
}
.service-card{flex:0 1 calc(33.333% - 16px);min-width:280px}
.service-card{
  background:var(--white);
  border:1px solid var(--border-light);
  border-radius:var(--radius);padding:32px 28px;
  transition:all 0.4s cubic-bezier(0.25,0.46,0.45,0.94);
  position:relative;overflow:hidden;
}
.service-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--gold),var(--gold-light));
  transform:scaleX(0);transform-origin:left;transition:transform 0.4s;
}
.service-card:hover::before{transform:scaleX(1)}
.service-card:hover{
  border-color:rgba(200,168,78,0.3);
  transform:translateY(-8px);
  box-shadow:var(--shadow-gold);
}
.section-dark .service-card{
  background:rgba(255,255,255,0.04);
  border-color:rgba(255,255,255,0.08);
  backdrop-filter:blur(10px);
}
.section-dark .service-card:hover{
  background:rgba(255,255,255,0.08);
  border-color:rgba(200,168,78,0.3);
}
.service-card-icon{
  width:56px;height:56px;
  background:linear-gradient(135deg,rgba(200,168,78,0.12),rgba(200,168,78,0.06));
  border:1px solid rgba(200,168,78,0.15);
  border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:20px;transition:all 0.3s;
}
.service-card:hover .service-card-icon{
  background:linear-gradient(135deg,var(--gold),var(--gold-light));
  border-color:var(--gold);
}
.service-card:hover .service-card-icon svg{fill:var(--dark)}
.service-card-icon svg{width:26px;height:26px;fill:var(--gold);transition:fill 0.3s}
.service-card h3{font-size:19px;margin-bottom:10px}
.service-card p{font-size:14px;color:var(--muted);margin-bottom:18px;line-height:1.7}
.service-card .card-link{
  font-size:13px;font-weight:700;color:var(--gold);
  display:inline-flex;align-items:center;gap:6px;
  transition:gap 0.3s;
}
.service-card:hover .card-link{gap:10px}

/* ============================================
   TRUST / WHY US — Modern Cards
   ============================================ */
.trust-grid{
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:24px;
}
.trust-card{flex:0 1 calc(25% - 18px);min-width:230px}
.trust-card{
  text-align:center;padding:36px 24px;
  background:var(--white);border-radius:var(--radius);
  border:1px solid var(--border-light);
  transition:all 0.4s;
}
.trust-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-gold);
  border-color:rgba(200,168,78,0.3);
}
.section-dark .trust-card{
  background:rgba(255,255,255,0.04);
  border-color:rgba(255,255,255,0.06);
  backdrop-filter:blur(10px);
}
.section-dark .trust-card:hover{
  background:rgba(255,255,255,0.08);
  border-color:rgba(200,168,78,0.3);
}
.trust-card-icon{
  width:64px;height:64px;margin:0 auto 20px;
  background:linear-gradient(135deg,rgba(200,168,78,0.12),rgba(200,168,78,0.04));
  border:1px solid rgba(200,168,78,0.15);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  transition:all 0.4s;
}
.trust-card:hover .trust-card-icon{
  background:linear-gradient(135deg,var(--gold),var(--gold-light));
  border-color:var(--gold);
  transform:scale(1.1);
}
.trust-card:hover .trust-card-icon svg{fill:var(--dark)}
.trust-card-icon svg{width:30px;height:30px;fill:var(--gold);transition:fill 0.3s}
.trust-card h3{font-size:17px;margin-bottom:10px}
.trust-card p{font-size:14px;color:var(--muted);line-height:1.6}
.section-dark .trust-card p{color:rgba(255,255,255,0.5)}

/* ============================================
   TESTIMONIALS — Quote Style
   ============================================ */
.testimonials-grid{
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:24px;
}
.testimonial-card{flex:0 1 calc(33.333% - 16px);min-width:280px}
.testimonial-card{
  background:var(--white);border:1px solid var(--border-light);
  border-radius:var(--radius);padding:32px;
  position:relative;transition:all 0.4s;
}
.testimonial-card::before{
  content:'\201C';position:absolute;top:16px;right:24px;
  font-size:72px;color:rgba(200,168,78,0.12);
  font-family:Georgia,serif;line-height:1;
}
.testimonial-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-gold);
  border-color:rgba(200,168,78,0.3);
}
.section-dark .testimonial-card{
  background:rgba(255,255,255,0.04);
  border-color:rgba(255,255,255,0.06);
}
.testimonial-stars{color:var(--gold);font-size:18px;margin-bottom:16px;letter-spacing:3px}
.testimonial-card p{font-size:15px;font-style:italic;line-height:1.8;margin-bottom:20px}
.section-dark .testimonial-card p{color:rgba(255,255,255,0.7)}
.testimonial-author{
  font-size:14px;font-weight:700;color:var(--gold);
  padding-top:16px;border-top:1px solid var(--border-light);
}
.section-dark .testimonial-author{border-color:rgba(255,255,255,0.06)}

/* ============================================
   CTA BANNER — Bold Gradient
   ============================================ */
.cta-banner{
  background:var(--dark);
  padding:80px 0;text-align:center;color:var(--white);
  position:relative;overflow:hidden;
}
.cta-banner::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 50% 50%,rgba(200,168,78,0.08) 0%,transparent 70%);
}
.cta-banner .container{position:relative;z-index:1}
.cta-banner h2{color:var(--white);margin-bottom:16px}
.cta-banner p{
  color:rgba(255,255,255,0.5);font-size:17px;margin-bottom:36px;
  max-width:520px;margin-left:auto;margin-right:auto;line-height:1.7;
}
.cta-banner .btn{margin:0 8px}

/* ============================================
   FAQ — Clean Accordion
   ============================================ */
.faq-list{max-width:740px;margin:0 auto}
.faq-item{
  border-bottom:1px solid var(--border-light);padding:0;
  transition:all 0.3s;
}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;
  padding:22px 0;cursor:pointer;font-size:17px;font-weight:600;
  color:var(--dark);background:none;border:none;width:100%;text-align:left;
  font-family:inherit;transition:color 0.3s;
}
.faq-q:hover{color:var(--gold)}
.faq-q svg{width:22px;height:22px;fill:var(--muted);transition:all 0.3s;flex-shrink:0;margin-left:16px}
.faq-item.open .faq-q{color:var(--gold)}
.faq-item.open .faq-q svg{transform:rotate(180deg);fill:var(--gold)}
.faq-a{max-height:0;overflow:hidden;transition:max-height 0.4s ease}
.faq-a-inner{padding:0 0 22px;font-size:15px;color:var(--muted);line-height:1.8}

/* ============================================
   CONTENT PAGE
   ============================================ */
.content-section{padding:60px 0}
.content-section h2{margin:36px 0 18px}
.content-section h3{margin:28px 0 14px}
.content-section p{font-size:16px;line-height:1.85;color:#555}
.content-section ul{margin:0 0 24px 24px}
.content-section li{font-size:16px;color:#555;margin-bottom:10px;line-height:1.75}
.content-section strong{color:var(--dark)}

/* CONTENT + SIDEBAR */
.content-with-sidebar{
  display:grid;grid-template-columns:1fr 320px;gap:48px;
}
.sidebar-card{
  background:var(--off-white);border:1px solid var(--border-light);
  border-radius:var(--radius);padding:28px;margin-bottom:24px;
  transition:all 0.3s;
}
.sidebar-card:hover{box-shadow:var(--shadow)}
.sidebar-card h3{font-size:17px;margin-bottom:14px;color:var(--dark)}
.sidebar-card p{font-size:14px;color:var(--muted)}
.sidebar-card .btn{width:100%;margin-top:14px}
.sidebar-links a{
  display:block;padding:10px 0;font-size:14px;
  border-bottom:1px solid var(--border-light);color:var(--text);
  transition:all 0.2s;
}
.sidebar-links a:hover{color:var(--gold);padding-left:6px}

@media(max-width:768px){
  .content-with-sidebar{grid-template-columns:1fr}
}

/* ============================================
   BLOG CARDS
   ============================================ */
.blog-grid{
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:28px;
}
.blog-card{flex:0 1 calc(33.333% - 19px);min-width:280px}
.blog-card{
  background:var(--white);border:1px solid var(--border-light);
  border-radius:var(--radius);overflow:hidden;
  transition:all 0.4s;
}
.blog-card:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow-lg);
  border-color:rgba(200,168,78,0.2);
}
.blog-card-img{
  height:200px;background:var(--off-white);
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);font-size:14px;
  overflow:hidden;
}
.blog-card-img img,.blog-card img:first-child{
  width:100%;height:200px;object-fit:cover;
  transition:transform 0.5s;
}
.blog-card:hover img:first-child,.blog-card:hover .blog-card-img img{
  transform:scale(1.08);
}
.blog-card-body{padding:28px}
.blog-card-body .tag{
  font-size:11px;font-weight:700;color:var(--gold);
  text-transform:uppercase;letter-spacing:1.5px;margin-bottom:10px;
  display:inline-block;
}
.blog-card-body h3{font-size:19px;margin-bottom:10px}
.blog-card-body p{font-size:14px;color:var(--muted);margin-bottom:14px;line-height:1.7}
.blog-card-body .read-more{
  font-size:13px;font-weight:700;color:var(--gold);
  display:inline-flex;align-items:center;gap:4px;
  transition:gap 0.3s;
}
.blog-card:hover .read-more{gap:8px}

/* ============================================
   SERVICE AREAS — Modern Links
   ============================================ */
.areas-grid{
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:14px;
}
.area-link{flex:0 1 calc(20% - 12px);min-width:160px}
.area-link{
  display:block;padding:18px 24px;
  background:var(--white);border:1px solid var(--border-light);
  border-radius:var(--radius-sm);font-size:14px;font-weight:600;
  color:var(--text);transition:all 0.35s;text-align:center;
}
.area-link:hover{
  border-color:var(--gold);color:var(--gold);
  background:rgba(200,168,78,0.04);
  transform:translateY(-3px);
  box-shadow:var(--shadow-gold);
}

/* ============================================
   CONTACT
   ============================================ */
.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;
}
.contact-info-card{
  display:flex;align-items:flex-start;gap:16px;
  padding:24px 0;border-bottom:1px solid var(--border-light);
  transition:all 0.3s;
}
.contact-info-card:hover{padding-left:8px}
.contact-info-card svg{width:28px;height:28px;fill:var(--gold);flex-shrink:0;margin-top:2px}
.contact-info-card h3{font-size:16px;margin-bottom:4px}
.contact-info-card p{font-size:14px;color:var(--muted);margin:0}
.contact-form input,.contact-form textarea,.contact-form select{
  width:100%;padding:14px 18px;border:1px solid var(--border-light);
  border-radius:var(--radius-sm);font-size:14px;font-family:inherit;
  margin-bottom:14px;background:var(--white);
  transition:all 0.3s;
}
.contact-form input:focus,.contact-form textarea:focus{
  outline:none;border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(200,168,78,0.1);
}
.contact-form textarea{min-height:120px;resize:vertical}

@media(max-width:768px){
  .contact-grid{grid-template-columns:1fr}
}

/* ============================================
   FOOTER — Premium Dark
   ============================================ */
.site-footer{
  background:var(--dark);color:rgba(255,255,255,0.5);padding:64px 0 0;
  border-top:1px solid rgba(200,168,78,0.1);
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:40px;margin-bottom:48px;
}
.footer-brand p{font-size:14px;line-height:1.8;margin-top:16px}
.footer-col h4{
  color:var(--gold);font-size:12px;font-weight:700;
  text-transform:uppercase;letter-spacing:2px;margin-bottom:20px;
}
.footer-col a{
  display:block;font-size:14px;color:rgba(255,255,255,0.4);
  padding:5px 0;transition:all 0.2s;
}
.footer-col a:hover{color:var(--gold);padding-left:4px}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,0.06);padding:24px 0;
  text-align:center;font-size:13px;color:rgba(255,255,255,0.3);
}
@media(max-width:768px){
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr}
  .hero{padding:60px 0 50px}
  .section{padding:50px 0}
}

/* ============================================
   MOBILE OPTIMISATION
   ============================================ */
@media(max-width:900px){
  .header-logo img{height:52px}
  .header-inner{padding:8px 16px}
  .mobile-nav{top:68px}
}
@media(max-width:768px){
  .hero{padding:60px 0 48px}
  .hero h1{font-size:clamp(26px,7vw,38px)}
  .hero p{font-size:16px}
  .hero-btns{flex-direction:column;gap:10px}
  .hero-btns .btn{width:100%;text-align:center;justify-content:center}
  .hero-trust{gap:16px}
  .hero-trust-item{font-size:12px}
  .page-hero{padding:40px 0 32px}
  .page-hero h1{font-size:clamp(22px,6vw,32px)}
  .section{padding:48px 0}
  .section-header{margin-bottom:32px}
  .section-header h2{font-size:clamp(22px,6vw,30px)}
  .service-card{flex:0 1 100%;min-width:0;padding:24px 20px}
  .trust-card{flex:0 1 calc(50% - 12px);min-width:0;padding:24px 16px}
  .testimonial-card{flex:0 1 100%;min-width:0}
  .blog-card{flex:0 1 100%;min-width:0}
  .area-link{flex:0 1 calc(50% - 7px);min-width:0}
  .service-hero-img{max-height:220px;border-radius:var(--radius-sm);margin:16px 0}
  .blog-featured-img{max-height:240px;border-radius:var(--radius-sm)}
  .cta-banner{padding:48px 0}
  .cta-banner .btn{display:block;width:100%;margin:8px 0}
  .btn{padding:14px 24px;font-size:14px}
  .btn-lg{padding:16px 28px;font-size:15px}
  .faq-q{font-size:15px;padding:18px 0}
}
@media(max-width:480px){
  .header-logo img{height:44px}
  .promo-banner{font-size:12px;padding:10px 16px}
  .hero{padding:44px 0 36px}
  .hero-badge{font-size:10px;padding:6px 14px}
  .trust-card{flex:0 1 100%}
  .area-link{flex:0 1 100%}
  .container{padding:0 16px}
}

/* ============================================
   SCHEMA (hidden)
   ============================================ */
.visually-hidden{
  position:absolute;width:1px;height:1px;
  overflow:hidden;clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}

/* ============================================
   ANIMATIONS
   ============================================ */
/* Scroll reveal */
.reveal{
  opacity:0;transform:translateY(30px);
  transition:opacity 0.7s cubic-bezier(0.25,0.46,0.45,0.94),transform 0.7s cubic-bezier(0.25,0.46,0.45,0.94);
}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{
  opacity:0;transform:translateX(-40px);
  transition:opacity 0.7s ease,transform 0.7s ease;
}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{
  opacity:0;transform:translateX(40px);
  transition:opacity 0.7s ease,transform 0.7s ease;
}
.reveal-right.visible{opacity:1;transform:translateX(0)}

/* Stagger children */
.stagger-children .reveal:nth-child(1){transition-delay:0s}
.stagger-children .reveal:nth-child(2){transition-delay:0.08s}
.stagger-children .reveal:nth-child(3){transition-delay:0.16s}
.stagger-children .reveal:nth-child(4){transition-delay:0.24s}
.stagger-children .reveal:nth-child(5){transition-delay:0.32s}
.stagger-children .reveal:nth-child(6){transition-delay:0.4s}

/* Gold underline hover for nav */
.nav a::after{
  content:'';display:block;height:2px;
  background:linear-gradient(90deg,var(--gold),var(--gold-light));
  transform:scaleX(0);transition:transform 0.3s ease;margin-top:4px;
  border-radius:2px;
}
.nav a:hover::after,.nav a.active::after{transform:scaleX(1)}

/* Pulse ring on CTA buttons */
@keyframes pulse-ring{
  0%{box-shadow:0 0 0 0 rgba(200,168,78,0.4)}
  70%{box-shadow:0 0 0 14px rgba(200,168,78,0)}
  100%{box-shadow:0 0 0 0 rgba(200,168,78,0)}
}
.btn-gold:hover{animation:pulse-ring 1.5s ease infinite}

/* Counter animation */
.stat-number{
  font-size:clamp(36px,5vw,52px);font-weight:800;
  color:var(--gold);display:block;
  background:linear-gradient(135deg,var(--gold),var(--gold-light));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}

/* Hero text entrance */
@keyframes hero-fade-up{
  from{opacity:0;transform:translateY(24px)}
  to{opacity:1;transform:translateY(0)}
}
.hero-content > *{
  animation:hero-fade-up 0.7s cubic-bezier(0.25,0.46,0.45,0.94) forwards;
  opacity:0;
}
.hero-content > *:nth-child(1){animation-delay:0.1s}
.hero-content > *:nth-child(2){animation-delay:0.25s}
.hero-content > *:nth-child(3){animation-delay:0.4s}
.hero-content > *:nth-child(4){animation-delay:0.55s}
.hero-content > *:nth-child(5){animation-delay:0.7s}

/* Floating subtle animation for trust icons */
@keyframes float{
  0%,100%{transform:translateY(0) scale(1.1)}
  50%{transform:translateY(-8px) scale(1.1)}
}
.trust-card:hover .trust-card-icon{animation:float 2s ease infinite}

/* Page hero subtle gradient shift */
@keyframes hero-gradient{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}

/* Reduce motion for accessibility */
@media(prefers-reduced-motion:reduce){
  .reveal,.reveal-left,.reveal-right{opacity:1;transform:none;transition:none}
  .hero-content > *{animation:none;opacity:1}
  .trust-card:hover .trust-card-icon{animation:none}
  .btn-gold:hover{animation:none}
  .promo-banner{animation:none}
}
