/* ============================================================
   Phoenix Epoxy — contractor marketing site
   Recreated from the Claude Design handoff (Phoenix Epoxy.dc.html).
   Breakpoints mirror the prototype: mobile < 768px, "narrow" < 1060px.
   ============================================================ */

/* ---------- reset / base ---------- */
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:'Hanken Grotesk',system-ui,sans-serif;
  background:#faf7f1;
  color:#1f1b15;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
button{font-family:inherit;cursor:pointer;border:none;}
input,select,textarea{font-family:inherit;}
a{color:inherit;text-decoration:none;}
select option{color:#16140f;}
::selection{background:#ff6a13;color:#fff;}
img{display:block;}

@keyframes feUp{from{opacity:0;transform:translateY(22px);}to{opacity:1;transform:translateY(0);}}
@keyframes feIn{from{opacity:0;}to{opacity:1;}}

.container{max-width:1240px;margin:0 auto;width:100%;}

/* ---------- shared type bits ---------- */
.eyebrow{
  font-size:13px;letter-spacing:3px;text-transform:uppercase;
  color:#c2761a;font-weight:700;font-family:'Archivo',sans-serif;margin-bottom:14px;
}
.eyebrow--dark{color:#e7a93a;margin-bottom:16px;}
.grad-gold{
  background:linear-gradient(135deg,#f5c542,#ff6a13);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.grad-num{
  background:linear-gradient(135deg,#e0a615,#ff6a13);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* ---------- buttons ---------- */
.btn{
  font-family:'Archivo',sans-serif;text-transform:uppercase;letter-spacing:.5px;
  font-weight:700;border-radius:7px;display:inline-flex;align-items:center;
  justify-content:center;line-height:1;transition:transform .15s,box-shadow .15s,background .15s;
}
.btn-primary{background:#e0671e;color:#fff;font-size:16px;padding:16px 28px;
  box-shadow:0 10px 30px rgba(255,106,19,.3);}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 14px 34px rgba(255,106,19,.4);}
.btn-outline{background:rgba(255,255,255,.08);color:#fff;font-weight:600;font-size:16px;
  padding:16px 28px;border:1px solid rgba(255,255,255,.2);}
.btn-outline:hover{background:rgba(255,255,255,.16);}
.btn-light{background:#fff;color:#1f1b15;border:1px solid #e2dccf;font-weight:700;
  padding:13px 24px;border-radius:6px;font-size:13px;white-space:nowrap;}
.btn-light:hover{background:#f7f3ea;}
.btn-dark{background:#16140f;color:#fff;font-weight:700;font-size:15px;padding:15px 28px;align-self:flex-start;}
.btn-dark:hover{background:#262119;}

/* ============================================================
   NAV
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(13,13,15,0.92);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(255,255,255,0.07);
}
.nav{
  max-width:1240px;margin:0 auto;padding:14px 32px;
  display:flex;align-items:center;justify-content:space-between;gap:18px;
}
.brand{display:flex;align-items:center;gap:12px;cursor:pointer;}
.brand img{height:44px;width:44px;border-radius:8px;object-fit:cover;}
.brand-name{
  font-family:'Archivo',sans-serif;font-weight:800;font-size:18px;
  letter-spacing:1.5px;color:#f5f3ef;line-height:1;
}
.brand-tag{
  font-size:10px;letter-spacing:3px;color:#8c887f;text-transform:uppercase;margin-top:3px;line-height:1;
}
.nav-right{display:flex;align-items:center;gap:24px;}
.nav-links{display:flex;align-items:center;gap:26px;}
.nav-link{
  font-family:'Archivo',sans-serif;font-weight:600;font-size:14px;letter-spacing:.5px;
  cursor:pointer;padding-bottom:4px;text-transform:uppercase;transition:color .15s;
  color:#cfcbc3;border-bottom:2px solid transparent;
}
.nav-link:hover{color:#f5c542;}
.nav-link.is-active{color:#f5c542;border-bottom-color:#f5c542;}
.hamburger{
  display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;
  width:42px;height:42px;background:transparent;border:1px solid rgba(255,255,255,0.16);border-radius:8px;
}
.hamburger span{display:block;width:20px;height:2px;background:#f0ece4;border-radius:2px;}

.mobile-menu{
  display:none;border-top:1px solid rgba(255,255,255,0.08);
  background:rgba(13,13,15,0.98);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
}
.mobile-menu.is-open{display:block;}
@media (min-width:1060px){.mobile-menu{display:none !important;}}
.mobile-menu .inner{max-width:1240px;margin:0 auto;padding:6px 20px 14px;display:flex;flex-direction:column;}
.menu-row{
  padding:15px 4px;font-family:'Archivo',sans-serif;font-weight:600;font-size:15px;
  letter-spacing:.5px;text-transform:uppercase;color:#e8e4dc;
  border-bottom:1px solid rgba(255,255,255,0.07);cursor:pointer;
}
.menu-row.is-active{color:#e9a23c;}
.menu-row--cta{color:#e9a23c;border-bottom:none;}

/* ============================================================
   VIEW SWITCHING
   ============================================================ */
.view{display:none;}
.view.is-active{display:block;}

/* ============================================================
   HERO A (full-bleed, auto-rotating background)
   ============================================================ */
.hero{position:relative;min-height:86vh;display:flex;align-items:center;overflow:hidden;background:#0d0d0f;}
.hero-bg{position:absolute;inset:0;z-index:0;}
.hero-slide{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:0;transition:opacity 1.2s ease;will-change:opacity;
}
.hero-slide.is-active{opacity:1;}
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg,rgba(8,8,10,0.9) 0%,rgba(8,8,10,0.7) 42%,rgba(8,8,10,0.26) 100%);
}
.hero-content{position:relative;z-index:2;max-width:1240px;margin:0 auto;padding:0 32px;width:100%;}
.hero-inner{max-width:680px;animation:feUp .7s ease both;}
.kicker{display:flex;align-items:center;gap:11px;margin-bottom:22px;}
.kicker .bar{width:26px;height:2px;background:#d98a2b;display:block;flex:none;}
.kicker .txt{font-size:12px;letter-spacing:2.5px;text-transform:uppercase;color:#e7c98a;font-weight:600;}
.hero h1{
  font-family:'Archivo',sans-serif;font-weight:600;font-size:clamp(33px,4.4vw,58px);
  line-height:1.02;letter-spacing:-0.3px;margin:0;color:#fff;text-wrap:balance;
}
.hero h1 .accent{color:#e9a23c;}
.hero p{font-size:19px;line-height:1.55;color:#d8d4cc;margin:24px 0 36px;max-width:540px;}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;}
.hero .btn-primary{padding:16px 30px;box-shadow:0 10px 30px rgba(255,106,19,0.32);}
.hero .btn-outline{padding:16px 30px;}

/* ============================================================
   TRUST BAR
   ============================================================ */
.trust{
  background:#141210;border-top:1px solid rgba(255,255,255,0.06);
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.trust .wrap{
  max-width:1240px;margin:0 auto;padding:22px 32px;display:flex;flex-wrap:wrap;
  gap:16px 48px;align-items:center;justify-content:center;
}
.trust .item{
  display:flex;align-items:center;gap:9px;color:#d6c6a2;font-weight:600;font-size:13px;
  font-family:'Archivo',sans-serif;text-transform:uppercase;letter-spacing:1px;
}
.trust .item .star{font-size:12px;color:#d98a2b;}

/* ============================================================
   SECTION SHELLS
   ============================================================ */
.section{padding:100px 32px;}
.section--light{background:#faf7f1;}
.section--alt{background:#f1ece2;}

.sec-head{
  display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:20px;margin-bottom:46px;
}
.sec-head h2{
  font-family:'Archivo',sans-serif;font-weight:700;font-size:clamp(30px,4vw,46px);
  line-height:1.06;letter-spacing:-0.5px;margin:0;max-width:620px;color:#1f1b15;
}
.sec-head-center{text-align:center;margin-bottom:50px;}
.sec-head-center h2{
  font-family:'Archivo',sans-serif;font-weight:700;font-size:clamp(28px,4vw,44px);
  line-height:1.08;letter-spacing:-0.5px;margin:0;color:#1f1b15;
}

/* ---------- services overview ---------- */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.service-card{
  background:#fff;border:1px solid #ebe5d9;border-radius:14px;overflow:hidden;cursor:pointer;
  transition:transform .2s,box-shadow .2s;box-shadow:0 1px 2px rgba(31,27,21,0.04);
}
.service-card:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(31,27,21,0.1);}
.service-card .thumb{height:160px;overflow:hidden;}
.service-card .thumb img{width:100%;height:100%;object-fit:cover;}
.service-card .body{padding:22px 24px 26px;}
.service-card .num{
  font-family:'Archivo',sans-serif;font-weight:800;font-size:14px;margin-bottom:10px;letter-spacing:1px;
}
.service-card h3{font-family:'Archivo',sans-serif;font-weight:700;font-size:20px;line-height:1.15;margin:0 0 10px;color:#1f1b15;}
.service-card p{font-size:14.5px;line-height:1.55;color:#6c665b;margin:0;}

/* ---------- metallic marble feature ---------- */
.marble{background:#f1ece2;color:#1f1b15;}
.marble-grid{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;}
.marble-img{position:relative;min-height:520px;}
.marble-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.marble-text{display:flex;flex-direction:column;justify-content:center;padding:84px 72px;}
.marble-text h2{
  font-family:'Archivo',sans-serif;font-weight:700;font-size:clamp(28px,3.6vw,42px);
  line-height:1.1;letter-spacing:-0.5px;margin:0 0 20px;
}
.marble-text p{font-size:17px;line-height:1.6;color:#5a554b;margin:0 0 26px;max-width:480px;}
.marble-points{display:flex;flex-direction:column;gap:14px;margin-bottom:32px;}
.point{display:flex;align-items:center;gap:12px;font-size:16px;font-weight:600;color:#2a2620;}
.point .tick{
  width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#f5c542,#ff6a13);
  color:#1a1206;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;flex:none;
}

/* ---------- process ---------- */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.process-card{
  background:#fff;border:1px solid #ebe5d9;border-radius:14px;padding:28px 24px;
  box-shadow:0 1px 2px rgba(31,27,21,0.04);
}
.process-card .num{font-family:'Archivo',sans-serif;font-weight:800;font-size:38px;line-height:1;margin-bottom:16px;}
.process-card h3{font-family:'Archivo',sans-serif;font-weight:700;font-size:18px;margin:0 0 10px;color:#1f1b15;}
.process-card p{font-size:14.5px;line-height:1.55;color:#6c665b;margin:0;}

/* ---------- gallery preview ---------- */
.galprev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.galprev-tile{position:relative;border-radius:14px;overflow:hidden;box-shadow:0 4px 16px rgba(31,27,21,0.08);}
.galprev-tile img{width:100%;height:280px;object-fit:cover;}
.galprev-tile .label{
  position:absolute;left:0;bottom:0;right:0;padding:16px;
  background:linear-gradient(0deg,rgba(8,8,10,0.82),transparent);pointer-events:none;
  font-weight:700;font-size:14px;letter-spacing:.5px;color:#fff;
  font-family:'Archivo',sans-serif;text-transform:uppercase;
}

/* ---------- testimonials ---------- */
.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.test-card{
  background:#fff;border:1px solid #ebe5d9;border-radius:14px;padding:30px 28px;
  box-shadow:0 1px 2px rgba(31,27,21,0.04);
}
.test-card .stars{color:#ff6a13;font-size:17px;letter-spacing:3px;margin-bottom:16px;}
.test-card p{font-size:16px;line-height:1.6;color:#3a352d;margin:0 0 22px;}
.test-foot{display:flex;align-items:center;gap:12px;border-top:1px solid #ece6da;padding-top:18px;}
.avatar{
  width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#f5c542,#ff6a13);
  color:#1a1206;display:flex;align-items:center;justify-content:center;font-weight:800;
  font-family:'Archivo',sans-serif;flex:none;
}
.test-foot .name{font-weight:700;font-size:15px;color:#1f1b15;}
.test-foot .loc{font-size:13px;color:#8c887f;}

/* ---------- service area ---------- */
.area{background:#f1ece2;padding:90px 32px;}
.area .container{text-align:center;}
.area h2{
  font-family:'Archivo',sans-serif;font-weight:700;font-size:clamp(26px,3.6vw,40px);
  line-height:1.08;letter-spacing:-0.5px;margin:0 0 34px;color:#1f1b15;
}
.chips{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;max-width:820px;margin:0 auto;}
.chip{
  border:1px solid #e2dccf;background:#fff;border-radius:100px;padding:11px 22px;
  font-weight:600;font-size:14.5px;color:#3a352d;font-family:'Archivo',sans-serif;letter-spacing:.5px;
  transition:border-color .15s,color .15s,transform .15s;
}
a.chip:hover{border-color:#e0671e;color:#16140f;transform:translateY(-1px);}
.service-card,.galprev-tile{text-decoration:none;color:inherit;}

/* ============================================================
   FAQ + city-page bits
   ============================================================ */
.subhead .hero-actions{margin-top:28px;}
.prose{max-width:860px;}
.prose p{font-size:17px;line-height:1.7;color:#5a554b;margin:0 0 18px;}
.prose p:last-child{margin-bottom:0;}
.faq{display:flex;flex-direction:column;gap:14px;max-width:860px;margin:0 auto;}
.faq-item{background:#fff;border:1px solid #ebe5d9;border-radius:14px;padding:22px 24px;box-shadow:0 1px 2px rgba(31,27,21,0.04);}
.faq-item h3{font-family:'Archivo',sans-serif;font-weight:700;font-size:17px;margin:0 0 8px;color:#1f1b15;}
.faq-item p{font-size:15px;line-height:1.6;color:#5a554b;margin:0;}

/* ============================================================
   SUB-PAGE HEADER (dark)
   ============================================================ */
.subhead{background:#0d0d0f;padding:88px 32px 64px;}
.subhead h1{
  font-family:'Archivo',sans-serif;font-weight:800;font-size:clamp(36px,5.4vw,64px);
  line-height:1.02;letter-spacing:-0.5px;margin:0;max-width:780px;color:#fff;
}
.subhead p{font-size:18px;line-height:1.6;color:#b5b1a8;margin:22px 0 0;max-width:620px;}

/* ---------- services page list ---------- */
.services-list{background:#faf7f1;padding:56px 32px 90px;}
.services-list .container{display:flex;flex-direction:column;gap:26px;}
.service-row{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:stretch;
  background:#fff;border:1px solid #ebe5d9;border-radius:16px;padding:18px;overflow:hidden;
  box-shadow:0 1px 2px rgba(31,27,21,0.04);
}
.service-row .row-img{position:relative;min-height:380px;border-radius:14px;overflow:hidden;}
.service-row .row-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.service-row.reverse .row-img{order:2;}
.service-row .row-text{display:flex;flex-direction:column;justify-content:center;padding:24px 12px;}
.service-row .num{font-family:'Archivo',sans-serif;font-weight:800;font-size:15px;margin-bottom:14px;letter-spacing:1px;}
.service-row h2{
  font-family:'Archivo',sans-serif;font-weight:700;font-size:clamp(24px,3.2vw,36px);
  line-height:1.1;letter-spacing:-0.5px;margin:0 0 16px;color:#1f1b15;
}
.service-row .lead{font-size:16.5px;line-height:1.6;color:#5a554b;margin:0 0 22px;max-width:520px;}
.feature-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 24px;margin-bottom:26px;}
.feature{display:flex;align-items:center;gap:10px;font-size:14.5px;color:#3a352d;font-weight:500;}
.feature .tick{
  width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,#f5c542,#ff6a13);
  color:#1a1206;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;flex:none;
}
.btn-quote{background:#e0671e;color:#fff;font-weight:700;font-size:15px;padding:15px 28px;
  align-self:flex-start;box-shadow:0 8px 24px rgba(255,106,19,.22);}
.btn-quote:hover{transform:translateY(-1px);box-shadow:0 12px 30px rgba(255,106,19,.32);}

/* ---------- gallery page ---------- */
.gallery-list{background:#faf7f1;padding:56px 32px 90px;}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.gallery-tile{position:relative;border-radius:14px;overflow:hidden;box-shadow:0 4px 16px rgba(31,27,21,0.08);}
.gallery-tile.span-2{grid-column:span 2;}
.gallery-tile img{width:100%;height:300px;object-fit:cover;}
.gallery-tile .label{position:absolute;left:0;bottom:0;right:0;padding:16px 18px;
  background:linear-gradient(0deg,rgba(8,8,10,0.82),transparent);pointer-events:none;}
.gallery-tile .label .t{font-weight:700;font-size:14px;letter-spacing:.5px;color:#fff;
  font-family:'Archivo',sans-serif;text-transform:uppercase;}
.gallery-tile .label .tag{font-size:12.5px;color:#cfcbc3;margin-top:3px;}

/* ---------- about page ---------- */
.about-hero{background:#faf7f1;padding:90px 32px 64px;}
.about-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center;}
.about-grid h1{
  font-family:'Archivo',sans-serif;font-weight:800;font-size:clamp(34px,4.8vw,56px);
  line-height:1.06;letter-spacing:-0.5px;margin:0 0 24px;color:#1f1b15;
}
.about-grid p{font-size:17.5px;line-height:1.65;color:#5a554b;margin:0 0 18px;}
.about-grid p:last-child{margin-bottom:0;}
.about-img{position:relative;min-height:440px;border-radius:16px;overflow:hidden;box-shadow:0 12px 32px rgba(31,27,21,0.12);}
.about-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.about-stats{background:#f1ece2;padding:100px 32px;}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.stat{text-align:center;background:#fff;border:1px solid #ebe5d9;border-radius:14px;padding:32px 18px;
  box-shadow:0 1px 2px rgba(31,27,21,0.04);}
.stat .v{font-family:'Archivo',sans-serif;font-weight:800;font-size:clamp(34px,5vw,50px);line-height:1;}
.stat .l{font-size:13px;color:#6c665b;text-transform:uppercase;letter-spacing:1.5px;margin-top:10px;font-weight:600;}
.values-head{text-align:center;margin:64px 0 40px;}
.values-head h2{font-family:'Archivo',sans-serif;font-weight:700;font-size:clamp(26px,3.6vw,40px);
  letter-spacing:-0.5px;margin:0;color:#1f1b15;}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.value{background:#fff;border:1px solid #ebe5d9;border-radius:14px;padding:28px 26px;box-shadow:0 1px 2px rgba(31,27,21,0.04);}
.value .dash{height:3px;width:40px;background:linear-gradient(135deg,#f5c542,#ff6a13);border-radius:3px;margin-bottom:20px;}
.value h3{font-family:'Archivo',sans-serif;font-weight:700;font-size:18px;margin:0 0 10px;color:#1f1b15;}
.value p{font-size:14.5px;line-height:1.55;color:#6c665b;margin:0;}

/* ---------- contact page ---------- */
.contact{background:#faf7f1;padding:90px 32px 100px;}
.contact-grid{display:grid;grid-template-columns:1fr 0.85fr;gap:64px;align-items:start;}
.contact-grid h1{
  font-family:'Archivo',sans-serif;font-weight:800;font-size:clamp(34px,5vw,56px);
  line-height:1.02;letter-spacing:-0.5px;margin:0 0 22px;color:#1f1b15;
}
.contact-lead{font-size:17.5px;line-height:1.6;color:#5a554b;margin:0 0 36px;max-width:480px;}
.contact-info{display:flex;flex-direction:column;gap:20px;}
.cinfo{display:flex;align-items:flex-start;gap:16px;}
.cinfo .ico{
  width:46px;height:46px;border-radius:10px;background:#fff;border:1px solid #e6e0d3;
  display:flex;align-items:center;justify-content:center;font-size:18px;flex:none;color:#c2761a;
  box-shadow:0 1px 2px rgba(31,27,21,0.04);
}
.cinfo .lbl{font-size:12.5px;letter-spacing:2px;text-transform:uppercase;color:#8c887f;font-weight:600;margin-bottom:4px;}
.cinfo .val{font-size:17px;font-weight:600;color:#1f1b15;}

.form-card{
  background:#fff;border:1px solid #e8e2d6;border-radius:16px;padding:36px;
  box-shadow:0 12px 34px rgba(31,27,21,0.08);
}
.form-fields{display:flex;flex-direction:column;gap:16px;}
.form-row2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.field label{display:block;font-size:13px;font-weight:600;color:#3a352d;margin-bottom:7px;text-transform:uppercase;letter-spacing:1px;}
.field input,.field select,.field textarea{
  width:100%;background:#faf7f1;border:1px solid #e2dccf;border-radius:8px;padding:14px 16px;
  color:#1f1b15;font-size:15px;outline:none;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:#e0671e;}
.field textarea{resize:vertical;}
.btn-submit{background:#e0671e;color:#fff;font-weight:700;font-size:16px;padding:17px;border-radius:8px;
  font-family:'Archivo',sans-serif;text-transform:uppercase;letter-spacing:.5px;margin-top:6px;
  box-shadow:0 8px 24px rgba(255,106,19,.24);width:100%;}
.btn-submit:hover{transform:translateY(-1px);box-shadow:0 12px 30px rgba(255,106,19,.34);}
.hp{position:absolute !important;left:-9999px !important;width:1px;height:1px;opacity:0;pointer-events:none;}
.form-error{
  margin:14px 0 0;color:#b23b2e;font-size:14px;line-height:1.5;
  background:#fdecea;border:1px solid #f4c7c0;border-radius:8px;padding:12px 14px;
}
.btn-submit:disabled{opacity:.65;cursor:default;transform:none;box-shadow:0 8px 24px rgba(255,106,19,.24);}
.form-success{text-align:center;padding:50px 10px;}
.form-success .check{
  width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#f5c542,#ff6a13);
  color:#1a1206;display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:800;margin:0 auto 22px;
}
.form-success h3{font-family:'Archivo',sans-serif;font-weight:700;font-size:24px;margin:0 0 12px;color:#1f1b15;}
.form-success p{font-size:16px;color:#6c665b;line-height:1.55;margin:0;}

/* ============================================================
   SHARED CTA BAND (dark)
   ============================================================ */
.cta-band{position:relative;background:linear-gradient(135deg,#1a1206,#0d0d0f);padding:84px 32px;overflow:hidden;}
.cta-band .inner{max-width:1000px;margin:0 auto;text-align:center;position:relative;z-index:1;}
.cta-band h2{
  font-family:'Archivo',sans-serif;font-weight:800;font-size:clamp(30px,4.6vw,52px);
  line-height:1.06;letter-spacing:-0.5px;margin:0 0 18px;color:#fff;
}
.cta-band p{font-size:18px;color:#cfcbc3;margin:0 0 32px;}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.cta-band .btn-primary{padding:17px 34px;border-radius:8px;}
.cta-band .btn-outline{padding:17px 34px;border-radius:8px;}

/* ============================================================
   FOOTER (dark)
   ============================================================ */
.site-footer{background:#08080a;padding:64px 32px 36px;border-top:1px solid rgba(255,255,255,0.06);}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:40px;}
.footer-brand .row{display:flex;align-items:center;gap:12px;margin-bottom:18px;}
.footer-brand img{height:44px;width:44px;border-radius:8px;object-fit:cover;}
.footer-brand .name{font-family:'Archivo',sans-serif;font-weight:800;font-size:18px;letter-spacing:1.5px;color:#f5f3ef;}
.footer-brand p{font-size:15px;line-height:1.6;color:#8c887f;margin:0 0 16px;max-width:300px;}
.badges{display:flex;gap:10px;flex-wrap:wrap;}
.badge{font-size:12px;color:#e7c98a;border:1px solid rgba(245,197,66,0.3);border-radius:5px;padding:5px 11px;font-weight:600;letter-spacing:.5px;}
.footer-col .h{font-family:'Archivo',sans-serif;font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:1.5px;color:#f5f3ef;margin-bottom:18px;}
.footer-col .links{display:flex;flex-direction:column;gap:11px;}
.footer-col .links div{font-size:14px;color:#8c887f;cursor:pointer;transition:color .15s;}
.footer-col .links div:hover{color:#e7c98a;}
.footer-area{font-size:14px;color:#8c887f;line-height:1.85;}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;
  padding-top:26px;border-top:1px solid rgba(255,255,255,0.07);margin-top:8px;}
.footer-bottom div{font-size:13px;color:#6f6b63;}

/* ============================================================
   RESPONSIVE — "narrow" < 1060px
   ============================================================ */
@media (max-width:1059px){
  .nav-links{display:none;}
  .hamburger{display:flex;}
  .services-grid{grid-template-columns:repeat(2,1fr);}
  .process-grid{grid-template-columns:repeat(2,1fr);}
  .test-grid{grid-template-columns:repeat(2,1fr);}
  .values-grid{grid-template-columns:repeat(2,1fr);}
}

/* ============================================================
   RESPONSIVE — mobile < 768px
   ============================================================ */
@media (max-width:767px){
  .nav{padding:12px 18px;}

  /* hero: full-bleed, sized to content on mobile */
  .hero{min-height:auto;padding:72px 0;}
  .hero-content{padding:0 24px;}
  .hero h1{font-size:clamp(36px,9vw,46px);}
  .hero p{font-size:17px;margin:22px 0 32px;}

  .trust .wrap{padding:18px 20px;gap:12px 22px;}

  .section{padding:56px 20px;}
  .sec-head{margin-bottom:32px;}
  .services-grid{grid-template-columns:1fr;gap:16px;}
  .process-grid{grid-template-columns:1fr;gap:14px;}
  .galprev-grid{grid-template-columns:1fr;}
  .test-grid{grid-template-columns:1fr;gap:16px;}

  .marble-grid{grid-template-columns:1fr;}
  .marble-img{min-height:280px;}
  .marble-text{padding:48px 24px;}

  .area{padding:52px 20px;}

  .subhead{padding:64px 20px 48px;}
  .services-list{padding:40px 20px 64px;}
  .service-row{display:block;padding:14px;}
  .service-row .row-img{min-height:240px;margin-bottom:0;}
  .service-row .row-text{padding:22px 6px 6px;}
  .service-row.reverse .row-img{order:0;}

  .gallery-list{padding:40px 20px 64px;}
  .gallery-grid{grid-template-columns:1fr;}
  .gallery-tile.span-2{grid-column:auto;}

  .about-hero{padding:56px 20px 40px;}
  .about-grid{display:block;}
  .about-img{min-height:300px;margin-top:28px;}
  .about-stats{padding:56px 20px;}
  .stats-grid{grid-template-columns:repeat(2,1fr);}
  .values-grid{grid-template-columns:1fr;gap:14px;}

  .contact{padding:56px 20px 72px;}
  .contact-grid{display:block;}
  .form-card{padding:24px 20px;margin-top:28px;}

  .cta-band{padding:64px 20px;}

  .site-footer{padding:48px 20px 32px;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px 20px;}
  .footer-brand{grid-column:span 2;}
}
