/* ============================================================
   INNOVATIVE CONSTRUCTIONS INC. — Global Styles
   Performance-first: system fonts fallback, CSS variables,
   minimal repaints, no render-blocking resources
   ============================================================ */

/* Fast-loading font stack: Google Fonts loads async via JS */
:root {
  --charcoal:    #1c1c1c;
  --charcoal-2:  #2a2a2a;
  --charcoal-3:  #383838;
  --orange:      #c8511a;
  --orange-h:    #df6020;
  --orange-dim:  #9e3f12;
  --cream:       #f7f3ed;
  --cream-d:     #ede7db;
  --white:       #ffffff;
  --text:        #3a3530;
  --text-lt:     #7a7268;
  --border:      #e2dbd0;
  --ff-head:     'Playfair Display', Georgia, 'Times New Roman', serif;
  --ff-body:     'Barlow', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --ff-ui:       'Barlow Condensed', 'Arial Narrow', Arial, sans-serif;
  --shadow-sm:   0 2px 12px rgba(0,0,0,.08);
  --shadow:      0 6px 32px rgba(0,0,0,.12);
  --r:           4px;
  --trans:       .25s ease;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--ff-body);background:var(--cream);color:var(--text);line-height:1.7;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font:inherit}

/* ── LAYOUT ── */
.wrap{max-width:1160px;margin:0 auto;padding:0 28px}
.pad{padding:88px 0}
.pad-sm{padding:60px 0}

/* ── TYPOGRAPHY ── */
.eyebrow{
  font-family:var(--ff-ui);
  font-size:.72rem;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--orange);
  display:inline-flex;align-items:center;gap:10px;
  margin-bottom:14px;
}
.eyebrow::before{content:'';width:28px;height:2px;background:var(--orange);display:block}

h2.sec-title{
  font-family:var(--ff-head);
  font-size:clamp(1.85rem,3vw,2.7rem);
  font-weight:700;color:var(--charcoal);
  line-height:1.2;margin-bottom:16px;
}
h2.sec-title span{color:var(--orange)}
h2.sec-title.light{color:var(--white)}
.sec-sub{font-size:1rem;color:var(--text-lt);max-width:560px;margin-bottom:48px;line-height:1.75}
.sec-sub.light{color:rgba(255,255,255,.55)}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--ff-ui);font-size:.82rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:15px 34px;border-radius:var(--r);
  transition:all var(--trans);border:2px solid transparent;
}
.btn-primary{background:var(--orange);color:#fff;border-color:transparent}
.btn-primary:hover{background:var(--orange-h);transform:translateY(-2px);box-shadow:0 8px 22px rgba(200,81,26,.3)}
.btn-outline-w{border-color:var(--orange);color:#fff;background:var(--orange)}
.btn-outline-w:hover{background:var(--orange-h);border-color:var(--orange-h)}
.btn-white{background:#fff;color:var(--orange)}
.btn-white:hover{background:var(--cream);transform:translateY(-2px);box-shadow:0 8px 22px rgba(0,0,0,.15)}
.btn-dark{background:var(--charcoal);color:#fff}
.btn-dark:hover{background:var(--charcoal-3);transform:translateY(-2px)}

/* ── NAV ── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:900;
  background:rgba(28,28,28,.98);backdrop-filter:blur(10px);
  box-shadow:0 2px 20px rgba(0,0,0,.25);
  transition:box-shadow var(--trans);
}
.nav.scrolled{background:rgba(28,28,28,.99);box-shadow:0 2px 28px rgba(0,0,0,.4)}
.nav-inner{max-width:1160px;margin:0 auto;padding:10px 28px;display:flex;align-items:center;justify-content:space-between;height:64px}
.nav-logo{display:flex;flex-direction:row;align-items:center;gap:10px;text-decoration:none}
.nav-logo-img{height:36px;width:auto;max-height:36px;display:block;object-fit:contain;flex-shrink:0}
.nav-logo-text{display:flex;flex-direction:column;gap:2px}
.nav-logo-name{font-family:var(--ff-head);font-size:.95rem;font-weight:700;color:#fff;line-height:1.2;white-space:nowrap}
.nav-logo-sub{font-family:var(--ff-ui);font-size:.62rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--orange);white-space:nowrap}
.nav-links{display:flex;align-items:center;gap:36px}
.nav-links a{font-family:var(--ff-ui);font-size:.92rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.75);padding-bottom:3px;border-bottom:2px solid transparent;transition:color var(--trans),border-color var(--trans)}
.nav-links a:hover{color:#fff;border-color:var(--orange)}
.nav-links a.active{color:var(--orange);border-color:var(--orange)}
.nav-cta{
  font-family:var(--ff-ui);font-size:.77rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  background:var(--orange);color:#fff;
  padding:11px 22px;border-radius:var(--r);
  transition:background var(--trans);
}
.nav-cta:hover{background:var(--orange-h)}
.hamburger{display:none;flex-direction:column;gap:5px;padding:4px}
.hamburger span{display:block;width:24px;height:2px;background:#fff;transition:all .3s}

/* Mobile menu */
.mob-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:901}
.mob-overlay.open{display:block}
.mob-menu{
  position:fixed;top:0;right:-290px;width:270px;height:100vh;
  background:var(--charcoal-2);z-index:902;
  padding:72px 28px 36px;
  display:flex;flex-direction:column;
  transition:right .35s ease;
  box-shadow:-8px 0 32px rgba(0,0,0,.3);
}
.mob-menu.open{right:0}
.mob-menu a{
  font-family:var(--ff-ui);font-size:1rem;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.7);
  padding:16px 0;border-bottom:1px solid rgba(255,255,255,.06);
  transition:color var(--trans);
}
.mob-menu a:hover{color:var(--orange)}
.mob-menu .mob-close{position:absolute;top:22px;right:22px;font-size:1.4rem;color:#fff}
.mob-menu .mob-cta{
  margin-top:24px;background:var(--orange);color:#fff !important;
  text-align:center;padding:15px !important;border-radius:var(--r);border:none !important;
}

/* ── PAGE HERO (inner pages) ── */
.page-hero{
  background:var(--charcoal);
  padding:148px 0 72px;
  position:relative;overflow:hidden;
}
.page-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--orange)}
.page-hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  opacity:.12;
}
.page-hero-inner{position:relative;z-index:1}
.breadcrumb{
  display:flex;align-items:center;gap:8px;
  font-family:var(--ff-ui);font-size:.72rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.35);margin-bottom:20px;
}
.breadcrumb a{color:var(--orange)}
.page-hero h1{
  font-family:var(--ff-head);
  font-size:clamp(2.2rem,4vw,3.4rem);
  font-weight:700;color:#fff;margin-bottom:14px;line-height:1.15;
}
.page-hero p{font-size:1rem;color:rgba(255,255,255,.55);max-width:500px}

/* ── REVIEWS ── */
.reviews-bg{background:var(--cream-d)}
.stars{display:flex;gap:3px;margin-bottom:14px}
.stars svg{width:16px;height:16px;fill:var(--orange)}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.review-card{
  background:#fff;border-radius:var(--r);
  padding:32px 28px;
  border-left:4px solid var(--orange);
  box-shadow:var(--shadow-sm);
  transition:transform var(--trans),box-shadow var(--trans);
}
.review-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.review-quote{
  font-size:.94rem;color:var(--text);
  line-height:1.8;margin-bottom:22px;font-style:italic;
  position:relative;padding-top:10px;
}
.review-quote::before{
  content:'\201C';
  font-family:var(--ff-head);font-size:2.8rem;
  color:var(--orange);line-height:.4;
  display:block;margin-bottom:10px;
}
.review-author{display:flex;align-items:center;gap:12px}
.review-avatar{
  width:42px;height:42px;border-radius:50%;
  background:var(--charcoal);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-head);font-size:1rem;font-weight:700;
  color:var(--orange);flex-shrink:0;
}
.review-name{
  font-family:var(--ff-ui);font-size:.84rem;font-weight:700;
  letter-spacing:.05em;text-transform:uppercase;color:var(--charcoal);
}
.review-loc{font-size:.78rem;color:var(--text-lt)}

/* ── FOOTER ── */
.footer{background:var(--charcoal);color:rgba(255,255,255,.55);padding:68px 0 28px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:44px;margin-bottom:52px}
.footer-brand-name{font-family:var(--ff-head);font-size:1.3rem;font-weight:700;color:#fff;margin-bottom:4px}
.footer-brand-tag{font-family:var(--ff-ui);font-size:.6rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--orange);margin-bottom:18px}
.footer-desc{font-size:.87rem;line-height:1.8;color:rgba(255,255,255,.4);margin-bottom:20px}
.footer-lic{
  font-family:var(--ff-ui);font-size:.68rem;letter-spacing:.08em;
  color:rgba(255,255,255,.25);
  padding:6px 14px;border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r);display:inline-block;
}
.footer-col h4{
  font-family:var(--ff-ui);font-size:.72rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;
  color:#fff;margin-bottom:18px;padding-bottom:10px;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.footer-col ul{display:flex;flex-direction:column;gap:9px}
.footer-col ul a{
  font-size:.85rem;color:rgba(255,255,255,.45);
  display:flex;align-items:center;gap:7px;
  transition:color var(--trans);
}
.footer-col ul a::before{content:'›';color:var(--orange)}
.footer-col ul a:hover{color:#fff}
.footer-contact-row{display:flex;gap:12px;margin-bottom:14px;font-size:.85rem;align-items:flex-start}
.footer-contact-row svg{width:15px;height:15px;color:var(--orange);flex-shrink:0;margin-top:3px}
.footer-contact-row a:hover{color:#fff}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.07);
  padding-top:24px;
  display:flex;justify-content:space-between;align-items:center;
  font-size:.77rem;color:rgba(255,255,255,.25);
  flex-wrap:wrap;gap:10px;
}
.footer-bottom a{color:var(--orange)}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .reviews-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .wrap{padding:0 18px}
  .pad{padding:60px 0}
  .nav-links,.nav-cta{display:none}
  .hamburger{display:flex}
  .nav-inner{padding:6px 16px;height:52px}
  .nav-logo-img{height:28px;max-height:28px}
  .nav-logo-name{font-size:.82rem}
  .nav-logo-sub{font-size:.55rem}
  .footer-grid{grid-template-columns:1fr}
  .reviews-grid{grid-template-columns:1fr}
}
@media(max-width:540px){
  .pad{padding:48px 0}
}

