/*
Theme Name: Top Tile BC
Theme URI: https://toptile.ca
Author: Top Tile BC Service
Author URI: https://toptile.ca
Description: Custom theme for Top Tile BC — tile and bathroom renovation specialists in Victoria, BC. European craftsmanship, Schluter-certified, 10-year warranty.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: Proprietary
License URI: https://toptile.ca
Text Domain: toptile
*/


*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --lime:#B8D400;
  --lime-dk:#93AA00;
  --gold:#C8A96E;
  --ink:#1A1916;
  --ink-mid:#6A655C;
  --ink-dim:#B0ACA5;
  --paper:#FAFAF7;
  --paper-2:#F4F2ED;
  --paper-3:#EAE7E0;
  --white:#FFFFFF;
  --bl:rgba(26,25,22,0.08);
  --bl2:rgba(26,25,22,0.14);
}

html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:'DM Sans',sans-serif;
  font-weight:300;
  line-height:1.65;
  overflow-x:hidden;
}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity 0.9s cubic-bezier(0.16,1,0.3,1),transform 0.9s cubic-bezier(0.16,1,0.3,1)}
.reveal.in{opacity:1;transform:translateY(0)}
.d1{transition-delay:.1s}.d2{transition-delay:.22s}.d3{transition-delay:.35s}.d4{transition-delay:.5s}

/* ════════════════════════════
   NAV — clean white, Horizon-style
════════════════════════════ */
nav#mainNav{
  position:fixed;top:0;left:0;right:0;z-index:900;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 64px;
  height:90px;
  background:transparent;
  transition:background 0.4s,border-bottom 0.4s,box-shadow 0.4s,top 0.2s;
}
/* WordPress admin bar offset — Chrome + all browsers */
.admin-bar nav#mainNav{top:32px;}
@media screen and (max-width:782px){.admin-bar nav#mainNav{top:46px;}}
@media screen and (max-width:782px){.admin-bar .hero{margin-top:46px;}}
nav#mainNav.solid{
  background:rgba(250,250,247,0.97);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--bl);
  box-shadow:0 1px 24px rgba(26,25,22,0.06);
}

/* T-mark logo */
.nav-logo{display:flex;align-items:center;gap:16px;text-decoration:none}
.tmark{width:50px;height:50px;position:relative;flex-shrink:0}
.tmark-box{
  position:absolute;inset:0;
  border:1.5px solid rgba(255,255,255,0.6);
  background:var(--ink);
  transition:border-color 0.3s;
}
nav#mainNav.solid .tmark-box{border-color:rgba(26,25,22,0.35);background:transparent}
.tmark-box::before{content:'';position:absolute;top:-2px;left:-2px;width:15px;height:15px;border-top:2px solid var(--lime);border-left:2px solid var(--lime)}
.tmark-box::after{content:'';position:absolute;bottom:-2px;right:-2px;width:15px;height:15px;border-bottom:2px solid var(--lime);border-right:2px solid var(--lime)}
.tmark-t{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;padding-top:11px}
.tmark-bar{width:28px;height:7px;background:var(--lime)}
.tmark-stem{width:7px;height:19px;background:var(--lime)}

.nav-name{
  font-family:'DM Sans',sans-serif;font-weight:600;font-size:1.1rem;letter-spacing:0.13em;text-transform:uppercase;
  color:#fff;transition:color 0.3s;
}
nav#mainNav.solid .nav-name{color:var(--ink)}
.nav-name span{color:var(--lime)}

.nav-links{display:flex;gap:36px;list-style:none}
.nav-links a{
  font-family:'DM Sans',sans-serif;font-size:0.88rem;font-weight:400;letter-spacing:0.08em;
  color:rgba(255,255,255,0.7);text-decoration:none;transition:color 0.2s;
}
.nav-links a:hover{color:#fff}
nav#mainNav.solid .nav-links a{color:var(--ink-mid)}
nav#mainNav.solid .nav-links a:hover{color:var(--ink)}

.nav-cta{
  font-family:'DM Sans',sans-serif;font-size:0.78rem;font-weight:500;letter-spacing:0.1em;
  background:var(--lime);color:var(--ink);
  padding:10px 26px;text-decoration:none;
  transition:background 0.2s;
}
.nav-cta:hover{background:var(--lime-dk)}

/* ════════════════════════════
   HERO — full-bleed photo, Horizon-style
════════════════════════════ */
.hero{
  position:relative;
  height:100vh;
  min-height:640px;
  display:flex;align-items:flex-end;
  overflow:hidden;
}
.hero-photo{
  position:absolute;inset:0;
}
.hero-photo img{
  width:100%;height:100%;object-fit:cover;object-position:center 30%;display:block;
}
.hero-photo::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top, rgba(20,18,14,0.82) 0%, rgba(20,18,14,0.3) 55%, rgba(20,18,14,0.1) 100%);
}

.hero-content{
  position:relative;z-index:2;
  padding:0 80px 88px;
  max-width:860px;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-family:'DM Sans',sans-serif;font-size:0.7rem;font-weight:500;letter-spacing:0.26em;text-transform:uppercase;
  color:var(--lime);margin-bottom:28px;
  opacity:0;animation:fadeUp 0.7s 0.4s forwards;
}
.hero-eyebrow::before{content:'';width:28px;height:1.5px;background:var(--lime)}

.hero-h1{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(3.2rem,6.5vw,7rem);
  font-weight:600;line-height:1.05;
  color:#fff;
  opacity:0;animation:fadeUp 1s 0.55s forwards cubic-bezier(0.16,1,0.3,1);
}
.hero-h1 em{font-style:italic;color:var(--lime);font-weight:300}

.hero-sub{
  font-size:1rem;font-weight:300;color:rgba(255,255,255,0.75);
  max-width:480px;line-height:1.8;margin-top:22px;
  opacity:0;animation:fadeUp 0.85s 0.75s forwards;
}

.hero-actions{
  display:flex;align-items:center;gap:16px;margin-top:44px;
  opacity:0;animation:fadeUp 0.75s 0.95s forwards;
}
.btn-primary{
  display:inline-block;background:var(--lime);color:var(--ink);
  padding:15px 40px;
  font-family:'DM Sans',sans-serif;font-size:0.82rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;
  text-decoration:none;transition:background 0.2s;
}
.btn-primary:hover{background:var(--lime-dk)}
.btn-outline{
  display:inline-block;
  border:1.5px solid rgba(255,255,255,0.35);color:rgba(255,255,255,0.85);
  padding:13px 36px;
  font-family:'DM Sans',sans-serif;font-size:0.8rem;font-weight:400;letter-spacing:0.1em;text-transform:uppercase;
  text-decoration:none;transition:border-color 0.2s,color 0.2s;
}
.btn-outline:hover{border-color:var(--lime);color:var(--lime)}
.btn-outline-dark{
  display:inline-block;
  border:1.5px solid var(--bl2);color:var(--ink-mid);
  padding:13px 36px;
  font-family:'DM Sans',sans-serif;font-size:0.8rem;font-weight:400;letter-spacing:0.1em;text-transform:uppercase;
  text-decoration:none;transition:border-color 0.2s,color 0.2s;
}
.btn-outline-dark:hover{border-color:var(--lime-dk);color:var(--lime-dk)}

/* Scroll indicator */
.hero-scroll{
  position:absolute;bottom:40px;right:80px;z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:8px;
  opacity:0;animation:fadeIn 0.7s 1.6s forwards;
}
.scroll-line{width:1px;height:48px;background:linear-gradient(to bottom,var(--lime),transparent)}
.scroll-label{
  font-family:'DM Sans',sans-serif;font-size:0.58rem;letter-spacing:0.2em;text-transform:uppercase;
  color:rgba(255,255,255,0.4);writing-mode:vertical-rl;
}

@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ════════════════════════════
   CREDENTIAL BAR — Island Floors style
════════════════════════════ */
.cred-bar{
  background:var(--ink);
  display:flex;
  border-bottom:2px solid var(--lime);
  list-style:none;
  padding:0;
  margin:0;
}
.cred-item{
  flex:1;display:flex;align-items:center;gap:14px;
  padding:22px 36px;
  border-right:1px solid rgba(255,255,255,0.06);
}
.cred-item:last-child{border-right:none}
.cred-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.cred-item:nth-child(1) .cred-dot{background:var(--lime)}
.cred-item:nth-child(2) .cred-dot{background:var(--gold)}
.cred-item:nth-child(3) .cred-dot{background:var(--lime)}
.cred-item:nth-child(4) .cred-dot{background:var(--gold)}
.cred-strong{
  font-family:'DM Sans',sans-serif;font-size:0.82rem;font-weight:500;color:#fff;
  display:block;
}
.cred-sub{
  font-family:'DM Sans',sans-serif;font-size:0.7rem;font-weight:300;
  color:rgba(255,255,255,0.45);letter-spacing:0.04em;display:block;margin-top:1px;
}

/* ════════════════════════════
   INTRO SECTION — Horizon-style copy block
════════════════════════════ */
.intro{
  display:grid;grid-template-columns:1fr 1fr;
  padding:120px 80px;
  gap:80px;
  background:var(--paper);
  border-bottom:1px solid var(--bl);
}
.intro-left{}
.intro-label{
  display:inline-flex;align-items:center;gap:12px;
  font-family:'DM Sans',sans-serif;font-size:0.68rem;font-weight:500;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--lime-dk);margin-bottom:20px;
}
.intro-label::before{content:'';width:24px;height:1.5px;background:var(--lime)}
.intro-h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.4rem,4vw,4rem);
  font-weight:600;line-height:1.1;color:var(--ink);
}
.intro-h2 em{font-style:italic;color:var(--lime-dk);font-weight:300}
.intro-right{
  display:flex;flex-direction:column;justify-content:center;
}
.intro-body{
  font-size:1.02rem;font-weight:300;color:var(--ink-mid);line-height:1.9;
}
.intro-sig{
  margin-top:36px;
  display:flex;align-items:center;gap:16px;
  padding-top:28px;
  border-top:1px solid var(--bl);
}
.intro-sig-line{width:30px;height:1.5px;background:var(--lime);flex-shrink:0}
.intro-sig-name{
  font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-weight:600;color:var(--ink);
}
.intro-sig-title{font-size:0.76rem;color:var(--ink-dim);margin-top:2px;letter-spacing:0.04em}

/* ════════════════════════════
   SERVICES — Island Floors grid style
════════════════════════════ */
.services{
  padding:120px 80px;
  background:var(--paper-2);
  border-bottom:1px solid var(--bl);
}
.section-header{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-bottom:64px;
}
.section-header-right{
  font-size:0.88rem;font-weight:300;color:var(--ink-mid);
  max-width:300px;line-height:1.8;text-align:right;
}
.svc-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  border:1px solid var(--bl);
}
.svc-card{
  padding:52px 44px;
  position:relative;
  overflow:hidden;
  border-right:1px solid rgba(255,255,255,0.06);
  border-bottom:1px solid rgba(255,255,255,0.06);
  background:var(--white);
  transition:background 0.3s;
  cursor:pointer;
}
.svc-card:nth-child(3n){border-right:none}
.svc-card:nth-child(n+4){border-bottom:none}
.svc-card::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  transform:scaleX(0);transform-origin:left;
  transition:transform 0.4s cubic-bezier(0.16,1,0.3,1);
}
.svc-card:nth-child(1)::after,.svc-card:nth-child(3)::after,.svc-card:nth-child(5)::after{background:var(--lime)}
.svc-card:nth-child(2)::after,.svc-card:nth-child(4)::after,.svc-card:nth-child(6)::after{background:var(--gold)}
.svc-card:hover::after{transform:scaleX(1)}
.svc-n{
  font-family:'DM Sans',sans-serif;font-size:0.6rem;font-weight:500;letter-spacing:0.22em;
  margin-bottom:22px;
}
.svc-name{
  font-family:'Cormorant Garamond',serif;
  font-size:1.5rem;font-weight:600;color:var(--ink);line-height:1.2;margin-bottom:16px;
}
.svc-desc{font-size:0.85rem;font-weight:300;color:var(--ink-mid);line-height:1.78}
.svc-arrow{
  display:inline-block;margin-top:24px;
  font-size:0.7rem;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--lime);opacity:0;transition:opacity 0.22s;text-decoration:none;
}
.svc-card:hover .svc-arrow{opacity:1}

/* ════════════════════════════
   PORTFOLIO — Island Floors filterable gallery
════════════════════════════ */
.portfolio{
  padding:120px 80px;
  background:var(--paper);
  border-bottom:1px solid var(--bl);
}
.filter-bar{
  display:flex;gap:6px;flex-wrap:wrap;margin-bottom:52px;margin-top:32px;
}
.filter-btn{
  font-family:'DM Sans',sans-serif;font-size:0.72rem;font-weight:400;letter-spacing:0.1em;text-transform:uppercase;
  padding:8px 20px;
  border:1px solid var(--bl2);background:transparent;color:var(--ink-mid);
  cursor:pointer;transition:all 0.2s;
}
.filter-btn:hover{border-color:var(--lime-dk);color:var(--lime-dk)}
.filter-btn.active{background:var(--lime);border-color:var(--lime);color:var(--ink)}


.pgrid-item{
  position:relative;overflow:hidden;
  cursor:pointer;
  background:var(--paper-3);
}
.pgrid-item.wide{grid-column:span 2}
.pgrid-item.tall{grid-row:span 2}
.pgrid-item img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 0.7s cubic-bezier(0.16,1,0.3,1);
  min-height:280px;
}
.pgrid-item.tall img{min-height:360px}
.pgrid-item:hover img{transform:scale(1.04)}
.pgrid-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(20,18,14,0.78) 0%,transparent 55%);
  opacity:0;transition:opacity 0.35s;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:28px 24px;
}
.pgrid-item:hover .pgrid-overlay{opacity:1}
.pgrid-title{
  font-family:'Cormorant Garamond',serif;
  font-size:1.15rem;font-weight:600;color:#fff;line-height:1.2;margin-bottom:5px;
}
.pgrid-cat{
  font-family:'DM Sans',sans-serif;font-size:0.65rem;font-weight:500;
  letter-spacing:0.16em;text-transform:uppercase;color:var(--lime);
}
.pgrid-accent{
  position:absolute;top:0;left:0;width:3px;height:0;
  transition:height 0.45s cubic-bezier(0.16,1,0.3,1);
}
.pgrid-item:hover .pgrid-accent{height:50%}
.pgrid-item:nth-child(1) .pgrid-accent,.pgrid-item:nth-child(3) .pgrid-accent,.pgrid-item:nth-child(5) .pgrid-accent{background:var(--lime)}
.pgrid-item:nth-child(2) .pgrid-accent,.pgrid-item:nth-child(4) .pgrid-accent{background:var(--gold)}

/* ════════════════════════════
   SPLIT — dark/light, Horizon-style
════════════════════════════ */
.split{display:grid;grid-template-columns:1fr 1fr}
.split-photo{position:relative;overflow:hidden;min-height:600px}
.split-photo img{width:100%;height:100%;object-fit:cover;display:block}
.split-text{
  background:var(--ink);
  padding:100px 80px;
  display:flex;flex-direction:column;justify-content:center;
}
.split-text .intro-label{color:var(--lime)}
.split-text .intro-label::before{background:var(--lime)}
.split-h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,3.5vw,3.4rem);
  font-weight:600;line-height:1.1;color:#fff;margin-bottom:24px;
}
.split-h2 em{font-style:italic;color:var(--lime);font-weight:300}
.split-body{font-size:0.95rem;font-weight:300;color:rgba(255,255,255,0.6);line-height:1.88}
.split-pillars{
  display:grid;grid-template-columns:1fr 1fr;
  gap:1px;background:rgba(255,255,255,0.07);
  margin-top:44px;
}
.pillar{background:var(--ink);padding:24px 20px}
.pillar-name{
  font-family:'DM Sans',sans-serif;font-size:0.72rem;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;
  margin-bottom:8px;
}
.pillar:nth-child(1) .pillar-name{color:var(--lime)}
.pillar:nth-child(2) .pillar-name{color:var(--gold)}
.pillar:nth-child(3) .pillar-name{color:var(--lime)}
.pillar:nth-child(4) .pillar-name{color:var(--gold)}
.pillar-desc{font-size:0.82rem;font-weight:300;color:rgba(255,255,255,0.5);line-height:1.65}

/* ════════════════════════════
   PROCESS
════════════════════════════ */
.process{
  padding:120px 80px;
  background:var(--paper-2);
  border-top:1px solid var(--bl);
  border-bottom:1px solid var(--bl);
}
.process-steps{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:var(--bl);
  margin-top:64px;
  border:1px solid var(--bl);
}
.pstep{background:var(--white);padding:48px 36px;position:relative;overflow:hidden}
.pstep::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  transform:scaleX(0);transform-origin:left;
  transition:transform 0.5s cubic-bezier(0.16,1,0.3,1);
}
.pstep:nth-child(1)::before,.pstep:nth-child(3)::before{background:var(--lime)}
.pstep:nth-child(2)::before,.pstep:nth-child(4)::before{background:var(--gold)}
.pstep:hover::before{transform:scaleX(1)}
.pstep-num{
  font-family:'Cormorant Garamond',serif;font-size:4rem;font-weight:300;
  color:var(--paper-3);line-height:1;margin-bottom:20px;
}
.pstep-title{
  font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:600;
  color:var(--ink);margin-bottom:12px;
}
.pstep-desc{font-size:0.83rem;font-weight:300;color:var(--ink-mid);line-height:1.8}

/* ════════════════════════════
   REVIEWS — Horizon-style
════════════════════════════ */
.reviews{
  padding:120px 80px;
  background:var(--paper);
  border-bottom:1px solid var(--bl);
}
.reviews-top{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:52px;
}
.reviews-rating{
  display:flex;align-items:center;gap:14px;
}
.stars{font-size:1.1rem;color:var(--lime-dk);letter-spacing:3px}
.rating-text{font-size:0.78rem;color:var(--ink-mid);font-weight:400}
.rating-text strong{color:var(--ink);font-weight:500}
.reviews-link{
  font-family:'DM Sans',sans-serif;font-size:0.74rem;font-weight:400;
  letter-spacing:0.08em;color:var(--lime-dk);text-decoration:none;
  display:flex;align-items:center;gap:8px;
  transition:color 0.2s;
}
.reviews-link:hover{color:var(--lime)}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--bl)}
.review-card{
  background:var(--white);padding:48px 40px;
  position:relative;overflow:hidden;
}
.review-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
}
.review-card:nth-child(1)::before{background:var(--lime)}
.review-card:nth-child(2)::before{background:var(--gold)}
.review-card:nth-child(3)::before{background:var(--lime-dk)}
.review-stars{color:var(--lime-dk);font-size:0.85rem;letter-spacing:2px;margin-bottom:20px}
.review-q{
  font-family:'Cormorant Garamond',serif;
  font-size:1.05rem;font-weight:400;font-style:italic;
  color:var(--ink);line-height:1.75;margin-bottom:28px;
}
.review-div{width:28px;height:1.5px;margin-bottom:16px}
.review-card:nth-child(1) .review-div{background:var(--lime)}
.review-card:nth-child(2) .review-div{background:var(--gold)}
.review-card:nth-child(3) .review-div{background:var(--lime-dk)}
.review-author{font-weight:500;font-size:0.88rem;color:var(--ink)}
.review-loc{font-size:0.75rem;color:var(--ink-mid);margin-top:3px}
.review-goog{
  display:flex;align-items:center;gap:6px;margin-top:10px;
  font-size:0.62rem;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink-dim);
}
.gdot{width:6px;height:6px;border-radius:50%;background:var(--lime-dk)}

/* ════════════════════════════
   CERTS STRIP
════════════════════════════ */
.certs{
  background:var(--paper-2);
  border-bottom:1px solid var(--bl);
  display:flex;align-items:stretch;
}
.cert-label-col{
  padding:44px 52px;border-right:1px solid var(--bl);
  flex-shrink:0;display:flex;align-items:center;
}
.cert-label-text{
  font-family:'DM Sans',sans-serif;font-size:0.72rem;font-weight:500;
  letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-mid);line-height:1.6;
}
.cert-items{display:flex;flex:1}
.cert-cell{
  flex:1;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:8px;padding:32px 20px;
  border-right:1px solid var(--bl);text-align:center;
}
.cert-cell:last-child{border-right:none}
.cdot{width:6px;height:6px;border-radius:50%}
.cert-cell:nth-child(1) .cdot{background:var(--lime)}
.cert-cell:nth-child(2) .cdot{background:var(--gold)}
.cert-cell:nth-child(3) .cdot{background:var(--lime)}
.cert-cell:nth-child(4) .cdot{background:var(--gold)}
.cert-cell:nth-child(5) .cdot{background:var(--lime)}
.cert-cell-name{font-size:0.7rem;font-weight:400;color:var(--ink-mid);line-height:1.5;letter-spacing:0.04em}
.cert-cell-name strong{display:block;font-weight:500}
.cert-cell:nth-child(1) .cert-cell-name strong{color:var(--lime-dk)}
.cert-cell:nth-child(2) .cert-cell-name strong{color:var(--gold)}
.cert-cell:nth-child(3) .cert-cell-name strong{color:var(--lime-dk)}
.cert-cell:nth-child(4) .cert-cell-name strong{color:var(--gold)}
.cert-cell:nth-child(5) .cert-cell-name strong{color:var(--lime-dk)}

/* ════════════════════════════
   CTA BAND
════════════════════════════ */
.cta-band{
  position:relative;overflow:hidden;
  padding:160px 80px;
  text-align:center;
}
.cta-photo{position:absolute;inset:0}
.cta-photo img{width:100%;height:100%;object-fit:cover;display:block}
.cta-photo::after{
  content:'';position:absolute;inset:0;
  background:rgba(14,12,8,0.78);
}
.cta-inner{position:relative;z-index:2}
.cta-eyebrow{
  font-family:'DM Sans',sans-serif;font-size:0.68rem;font-weight:500;letter-spacing:0.26em;text-transform:uppercase;
  color:var(--lime);margin-bottom:20px;
}
.cta-h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.8rem,5vw,5.5rem);
  font-weight:600;line-height:1.05;color:#fff;margin-bottom:16px;
}
.cta-h2 em{font-style:italic;color:var(--lime);font-weight:300}
.cta-sub{font-size:0.95rem;font-weight:300;color:rgba(255,255,255,0.6);margin-bottom:48px}
.cta-btns{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}
.cta-scarcity{
  margin-top:28px;
  font-family:'DM Sans',sans-serif;font-size:0.65rem;font-weight:400;letter-spacing:0.14em;text-transform:uppercase;
  color:rgba(255,255,255,0.35);
}
.cta-scarcity span{color:var(--lime)}
.btn-phone{
  display:inline-flex;align-items:center;gap:10px;
  border:1.5px solid rgba(255,255,255,0.25);color:rgba(255,255,255,0.8);
  padding:13px 34px;
  font-family:'DM Sans',sans-serif;font-size:0.8rem;font-weight:400;letter-spacing:0.1em;text-transform:uppercase;
  text-decoration:none;transition:border-color 0.2s,color 0.2s;
}
.btn-phone:hover{border-color:var(--lime);color:var(--lime)}

/* ════════════════════════════
   CONTACT
════════════════════════════ */
.contact-wrap{
  display:grid;grid-template-columns:1fr 1.3fr;
  border-top:3px solid var(--lime);
}
.contact-left{
  background:var(--ink);
  padding:100px 80px;
  display:flex;flex-direction:column;justify-content:space-between;
}
.contact-top{}
.contact-response{
  display:inline-flex;align-items:center;gap:10px;margin-top:22px;
  font-family:'DM Sans',sans-serif;font-size:0.65rem;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--lime);
}
.contact-dets{margin-top:60px;display:flex;flex-direction:column;gap:32px}
.cl-label{
  font-family:'DM Sans',sans-serif;font-size:0.6rem;font-weight:500;
  letter-spacing:0.22em;text-transform:uppercase;margin-bottom:5px;
}
.contact-dets>div:nth-child(1) .cl-label{color:var(--lime)}
.contact-dets>div:nth-child(2) .cl-label{color:var(--gold)}
.contact-dets>div:nth-child(3) .cl-label{color:var(--lime)}
.contact-dets>div:nth-child(4) .cl-label{color:var(--gold)}
.cl-val{font-size:1rem;font-weight:300;color:rgba(255,255,255,0.8);text-decoration:none;transition:color 0.2s}
.cl-val:hover{color:var(--lime)}
.contact-right{background:var(--paper-2);padding:100px 80px}
.fg{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
.fg label{
  font-family:'DM Sans',sans-serif;font-size:0.6rem;font-weight:500;
  letter-spacing:0.2em;text-transform:uppercase;color:var(--ink-mid);
}
.fg input,.fg select,.fg textarea{
  background:var(--white);border:1px solid var(--bl2);
  color:var(--ink);padding:14px 18px;
  font-family:'DM Sans',sans-serif;font-size:0.9rem;font-weight:300;
  outline:none;transition:border-color 0.25s;resize:none;appearance:none;
}
.fg input::placeholder,.fg textarea::placeholder{color:var(--ink-dim)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.btn-submit{
  width:100%;background:var(--lime);color:var(--ink);border:none;
  padding:17px;font-family:'DM Sans',sans-serif;font-size:0.82rem;font-weight:500;
  letter-spacing:0.12em;text-transform:uppercase;cursor:pointer;margin-top:8px;
  transition:background 0.2s;
}
.btn-submit:hover{background:var(--lime-dk)}
.form-note{
  font-size:0.68rem;color:var(--ink-dim);margin-top:12px;text-align:center;letter-spacing:0.06em;
}

/* ════════════════════════════
   FOOTER
════════════════════════════ */
footer{
  background:var(--ink);border-top:1px solid rgba(255,255,255,0.06);
  padding:52px 80px;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:40px;
  position:relative;z-index:1;
}
.f-logo{display:flex;align-items:center;gap:14px;text-decoration:none}
.f-tmark{width:28px;height:28px;position:relative;flex-shrink:0}
.f-tmark-box{position:absolute;inset:0;border:1.5px solid rgba(255,255,255,0.25)}
.f-tmark-box::before{content:'';position:absolute;top:-1px;left:-1px;width:9px;height:9px;border-top:2px solid var(--lime);border-left:2px solid var(--lime)}
.f-tmark-box::after{content:'';position:absolute;bottom:-1px;right:-1px;width:9px;height:9px;border-bottom:2px solid var(--lime);border-right:2px solid var(--lime)}
.f-tmark-t{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;padding-top:5px}
.f-tbar{width:16px;height:4px;background:var(--lime)}
.f-tstem{width:4px;height:10px;background:var(--lime)}
.f-name{font-family:'DM Sans',sans-serif;font-weight:500;font-size:0.82rem;letter-spacing:0.14em;text-transform:uppercase;color:rgba(255,255,255,0.55)}
.f-name span{color:var(--lime)}
.f-copy{font-size:0.68rem;color:rgba(255,255,255,0.2);text-align:center;line-height:1.8;letter-spacing:0.04em}
.f-links{display:flex;gap:24px;justify-content:flex-end;position:static !important;z-index:auto !important;}
.f-links a{
  font-family:'DM Sans',sans-serif;font-size:0.72rem;font-weight:400;letter-spacing:0.1em;text-transform:uppercase;
  color:rgba(255,255,255,0.28);text-decoration:none;transition:color 0.2s;
}
.f-links a:hover{color:var(--lime)}

/* Mobile sticky */
.mob-cta{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:800;
  background:var(--lime);color:var(--ink);
  padding:16px;text-align:center;
  font-family:'DM Sans',sans-serif;font-size:0.82rem;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;
  text-decoration:none;
  transform:translateY(100%);transition:transform 0.4s cubic-bezier(0.16,1,0.3,1);
  border-top:2px solid var(--lime-dk);
}
.mob-cta.show{transform:translateY(0)}

/* ════════════════════════════
   RESPONSIVE
════════════════════════════ */
@media(max-width:1100px){
  nav{padding:0 40px}
  .hero-content{padding:0 48px 72px}
  .hero-scroll{right:48px}
  .intro,.services,.portfolio,.process,.reviews,.cta-band{padding:88px 48px}
  .contact-left,.contact-right{padding:80px 48px}
  footer{padding:44px 48px}
  .intro{grid-template-columns:1fr;gap:48px}
  .svc-grid{grid-template-columns:1fr 1fr}
  .svc-card:nth-child(2n){border-right:none}
  .svc-card:nth-child(n+5){border-bottom:none}
  .process-steps{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr}
  .split-photo{min-height:400px}
  .contact-wrap{grid-template-columns:1fr}
  footer{grid-template-columns:1fr;text-align:center}
  .f-links{justify-content:center}
  .mob-cta{display:block}
}
@media(max-width:768px){
  nav{padding:0 24px;height:68px}
  .nav-links{display:none}
  .hero-content{padding:0 28px 64px}
  .hero-scroll{display:none}
  .intro,.services,.portfolio,.process,.reviews,.cta-band{padding:72px 28px}
  .contact-left,.contact-right{padding:64px 28px}
  footer{padding:40px 28px}
  .svc-grid,.process-steps{grid-template-columns:1fr}
  .svc-card:nth-child(n){border-right:none;border-bottom:1px solid var(--bl)}
  .portfolio-grid{grid-template-columns:1fr 1fr}
  .pgrid-item.wide{grid-column:span 1}
  .pgrid-item.tall{grid-row:span 1}
  .reviews-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  
  .cred-item{border-right:none;border-bottom:1px solid rgba(255,255,255,0.06)}
  .certs{flex-direction:column}
  .cert-label-col{border-right:none;border-bottom:1px solid var(--bl)}
  .cert-items{flex-wrap:wrap}
  .cert-cell{min-width:50%;border-bottom:1px solid var(--bl)}
  .cta-btns{flex-direction:column;align-items:center}
  .section-header{flex-direction:column;align-items:flex-start;gap:16px}
  .section-header-right{text-align:left}
  .split-pillars{grid-template-columns:1fr}
}

/* ── FORM STATES ── */
.fg input.invalid,.fg select.invalid,.fg textarea.invalid{
  border-color:#C0392B;
  background:#FFF8F7;
}
.field-error{
  font-size:0.68rem;color:#C0392B;margin-top:4px;display:none;
}
.field-error.show{display:block}

.btn-submit:disabled{opacity:0.7;cursor:not-allowed}
.spinner{
  display:inline-block;width:14px;height:14px;
  border:2px solid rgba(26,25,22,0.25);
  border-top-color:var(--ink);
  border-radius:50%;
  animation:spin 0.7s linear infinite;
  vertical-align:middle;margin-right:6px;
}
@keyframes spin{to{transform:rotate(360deg)}}

.form-success{
  margin-top:20px;
  padding:28px 24px;
  background:#F0F9E8;
  border:1px solid #A8D878;
  border-left:4px solid #639922;
  text-align:center;
}
.success-icon{
  width:48px;height:48px;border-radius:50%;
  background:#639922;color:#fff;
  font-size:22px;line-height:48px;
  margin:0 auto 14px;
}
.success-title{
  font-family:'Cormorant Garamond',serif;
  font-size:1.3rem;font-weight:600;color:#27500A;margin-bottom:8px;
}
.success-body{
  font-size:0.88rem;color:#3B6D11;line-height:1.7;
}
.success-body a{color:#27500A;font-weight:500}

.form-error{
  margin-top:16px;
  padding:14px 18px;
  background:#FEF2F2;
  border:1px solid #FECACA;
  border-left:4px solid #E24B4A;
}
.error-body{font-size:0.85rem;color:#A32D2D;line-height:1.65}
.error-body a{color:#791F1F;font-weight:500}

/* Input focus ring */
.fg input:focus,.fg select:focus,.fg textarea:focus{
  border-color:var(--lime-dk);
  box-shadow:0 0 0 3px rgba(184,212,0,0.15);
}


/* ══ NAV RIGHT GROUP ═══════════════════════════════════════════════ */
.nav-right{
  display:flex;align-items:center;gap:16px;
}

/* ══ HAMBURGER BUTTON ═══════════════════════════════════════════════ */
.nav-burger{
  display:none;
  flex-direction:column;justify-content:center;align-items:center;
  width:44px;height:44px;gap:5px;
  background:none;border:none;cursor:pointer;
  padding:8px;
  -webkit-tap-highlight-color:transparent;
  position:relative;z-index:1001;
}
.burger-line{
  display:block;width:22px;height:1.5px;
  background:var(--lime);
  transition:transform 0.38s cubic-bezier(0.23,1,0.32,1),
             opacity 0.25s ease,
             width 0.3s ease;
  transform-origin:center;
}
/* On dark hero — lines are lime. On solid nav — lines go dark */
nav#mainNav.solid .burger-line{background:var(--ink);}

/* Open state — morphs to X */
.nav-burger[aria-expanded="true"] .burger-top{
  transform:translateY(6.5px) rotate(45deg);
}
.nav-burger[aria-expanded="true"] .burger-mid{
  opacity:0;transform:scaleX(0);
}
.nav-burger[aria-expanded="true"] .burger-bot{
  transform:translateY(-6.5px) rotate(-45deg);
}

/* ══ MOBILE MENU OVERLAY ════════════════════════════════════════════ */
.mobile-menu{
  position:fixed;inset:0;z-index:9999;
  pointer-events:none;
}
.mobile-menu.open{pointer-events:all;}

/* Backdrop */
.mm-backdrop{
  position:absolute;inset:0;
  background:rgba(26,25,22,0.55);
  opacity:0;
  transition:opacity 0.38s ease;
  -webkit-backdrop-filter:blur(3px);
  backdrop-filter:blur(3px);
}
.mobile-menu.open .mm-backdrop{opacity:1;}

/* Slide panel */
.mm-panel{
  position:absolute;top:0;right:0;bottom:0;
  will-change:transform;
  width:min(340px, 88vw);
  background:var(--paper);
  display:flex;flex-direction:column;
  box-shadow:-8px 0 40px rgba(26,25,22,0.18);
  transform:translateX(100%);
  transition:transform 0.42s cubic-bezier(0.16,1,0.3,1);
  overflow-y:auto;
  overscroll-behavior:contain;
  z-index:960;
}
.mobile-menu.open .mm-panel{transform:translateX(0);}

/* Panel header */
.mm-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 28px;
  border-bottom:0.5px solid var(--bl);
  flex-shrink:0;
}
.mm-logo{
  display:flex;align-items:center;gap:12px;text-decoration:none;
}

/* Close button */
.mm-close{
  width:40px;height:40px;
  display:flex;align-items:center;justify-content:center;
  background:var(--paper-2);border:none;
  font-size:1rem;color:var(--ink-mid);
  cursor:pointer;
  border-radius:50%;
  transition:background 0.2s,color 0.2s;
  flex-shrink:0;
}
.mm-close:hover{background:var(--paper-3);color:var(--ink);}

/* Nav links in panel */
.mm-.mm-.mm-nav{padding:8px 0;flex:1;}
.mm-links{list-style:none;padding:0;margin:0;}
.mm-item{
  opacity:0;
  transform:translateX(20px);
  transition:opacity 0.35s ease,transform 0.35s cubic-bezier(0.16,1,0.3,1);
}
/* Stagger items when menu opens */
.mobile-menu.open .mm-item:nth-child(1){opacity:1;transform:none;transition-delay:0.08s}
.mobile-menu.open .mm-item:nth-child(2){opacity:1;transform:none;transition-delay:0.13s}
.mobile-menu.open .mm-item:nth-child(3){opacity:1;transform:none;transition-delay:0.18s}
.mobile-menu.open .mm-item:nth-child(4){opacity:1;transform:none;transition-delay:0.23s}
.mobile-menu.open .mm-item:nth-child(5){opacity:1;transform:none;transition-delay:0.28s}

.mm-link{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 28px;
  font-family:"DM Sans",sans-serif;
  font-size:1.1rem;font-weight:400;letter-spacing:0.02em;
  color:var(--ink);text-decoration:none;
  border-bottom:0.5px solid var(--bl);
  transition:color 0.18s,background 0.18s,padding-left 0.25s;
  position:relative;
}
.mm-link::after{
  content:"→";
  font-size:0.9rem;color:var(--lime-dk);
  opacity:0;transition:opacity 0.2s,transform 0.2s;
  transform:translateX(-6px);
}
.mm-link:hover{
  color:var(--lime-dk);
  background:var(--paper-2);
  padding-left:34px;
}
.mm-link:hover::after{opacity:1;transform:translateX(0);}

/* Panel footer */
.mm-footer{
  padding:28px;
  border-top:0.5px solid var(--bl);
  flex-shrink:0;
  background:var(--paper-2);
}
.mm-cta{
  display:block;
  background:var(--lime);color:var(--ink);
  padding:15px 24px;
  font-family:"DM Sans",sans-serif;font-size:0.85rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;
  text-decoration:none;text-align:center;
  transition:background 0.2s;
  margin-bottom:20px;
}
.mm-cta:hover{background:var(--lime-dk);}
.mm-contact{
  display:flex;align-items:center;gap:8px;
  flex-wrap:wrap;margin-bottom:14px;
}
.mm-phone,.mm-email{
  font-family:"DM Sans",sans-serif;font-size:0.8rem;font-weight:400;
  color:var(--ink-mid);text-decoration:none;
  transition:color 0.18s;
}
.mm-phone:hover,.mm-email:hover{color:var(--lime-dk);}
.mm-sep{color:var(--ink-dim);font-size:0.7rem;}
.mm-social{
  display:flex;gap:16px;
}
.mm-social a{
  font-family:"DM Sans",sans-serif;font-size:0.72rem;font-weight:500;
  letter-spacing:0.08em;text-transform:uppercase;
  color:var(--ink-dim);text-decoration:none;
  transition:color 0.18s;
}
.mm-social a:hover{color:var(--lime-dk);}

/* ══ SHOW BURGER AT BREAKPOINTS ════════════════════════════════════ */
@media(max-width:900px){
  .nav-links{display:none;}
  .nav-burger{display:flex;}
  /* Keep nav-cta text visible on tablet but hide on small mobile */
}
@media(max-width:480px){
  .nav-cta{display:none;}
}

/* Prevent body scroll when menu open */
body.menu-open{overflow:hidden;}


/* ══ ACCESSIBILITY ═══════════════════════════════════════════════ */
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

.skip-link{
  position:absolute;top:-100%;left:24px;z-index:9999;
  background:var(--lime);color:var(--ink);
  padding:12px 24px;
  font-family:"DM Sans",sans-serif;font-size:0.88rem;font-weight:500;
  text-decoration:none;letter-spacing:0.06em;
  transition:top 0.2s;
}
.skip-link:focus{top:16px;}

.form-sr-desc{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

.req-star{color:#C0392B;margin-left:2px;font-weight:500;}

/* :focus-visible — keyboard focus only, no mouse rings */
:focus{outline:none;}
:focus-visible{
  outline:3px solid var(--lime-dk);
  outline-offset:3px;
}
.fg input:focus-visible,
.fg select:focus-visible,
.fg textarea:focus-visible{
  outline:none;
  border-color:var(--lime-dk);
  box-shadow:0 0 0 3px rgba(184,212,0,0.2);
}
.filter-btn:focus-visible,
.nav-burger:focus-visible,
.mm-close:focus-visible{
  outline:3px solid var(--lime-dk);
  outline-offset:2px;
}
a:focus-visible{
  outline:3px solid var(--lime-dk);
  outline-offset:3px;
  border-radius:2px;
}

/* ol/ul resets for semantic lists used as grids */
.svc-grid,
.cert-items,
.process-steps,
ol.process-steps{list-style:none;}

/* dl reset for hero stats */
dl.hero-stats{display:flex;}
dl.hero-stats dt{order:2;font-size:inherit;}
dl.hero-stats dd{order:1;margin:0;}


/* ══ HERO CROSSFADE SLIDESHOW ═══════════════════════════════════ */
.hero-slides{position:absolute;inset:0;}
.hslide{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;opacity:0;
  animation:heroFade 40s linear infinite;
  will-change:opacity;
}
.hslide.s1{animation-delay:0s}
.hslide.s2{animation-delay:8s}
.hslide.s3{animation-delay:16s}
.hslide.s4{animation-delay:24s}
.hslide.s5{animation-delay:32s}
@keyframes heroFade{
  0%{opacity:0}3%{opacity:1}17%{opacity:1}20%{opacity:0}100%{opacity:0}
}
@media(prefers-reduced-motion:reduce){
  .hslide{animation:none;}
  .hslide.s1{opacity:1;}
}

/* ══ PORTFOLIO — 8-item grid ════════════════════════════════════ */
.portfolio-grid{
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:260px 220px 220px;
  gap:3px;
}

/* ══ MOBILE — comprehensive overrides ══════════════════════════ */
/* Touch targets */
@media(max-width:900px){
  .nav-burger{min-width:44px;min-height:44px;}
  .mm-link{min-height:52px;padding:14px 28px;}
  .mm-cta{padding:18px 24px;font-size:0.9rem;}
  .filter-btn{padding:10px 18px;min-height:44px;}
  .btn-primary,.btn-outline,.nav-cta{min-height:44px;display:inline-flex;align-items:center;justify-content:center;}
  .portfolio-grid{
    grid-template-columns:1fr 1fr;
    grid-template-rows:auto;
    gap:2px;
  }
  .pgrid-item.tall,.pgrid-item.wide{grid-row:auto;grid-column:auto;}
  .pgrid-item img{min-height:200px;max-height:280px;}
  .pgrid-overlay{transform:translateY(0);opacity:1;background:linear-gradient(to top,rgba(20,18,14,0.72),transparent);}
  .pgrid-label{display:block;}
}
@media(max-width:640px){
  .portfolio-grid{grid-template-columns:1fr;}
  .pgrid-item img{min-height:220px;max-height:300px;}
  .hero{min-height:100svh;}
  .hero-content{padding:0 24px 72px;}
  .hero-h1{font-size:2.8rem;}
  .hero-sub{font-size:0.9rem;}
  .hero-eyebrow{margin-bottom:24px;}
  .hero-actions{flex-direction:column;align-items:flex-start;gap:12px;margin-top:32px;}
  .btn-primary,.btn-outline{width:100%;text-align:center;justify-content:center;}
  .cred-bar{flex-direction:column;}
  .cred-item{border-right:none;border-bottom:1px solid rgba(255,255,255,0.06);padding:16px 24px;}
  .intro{padding:64px 24px;grid-template-columns:1fr;gap:32px;}
  .services{padding:64px 24px;}
  .svc-grid{grid-template-columns:1fr;}
  .svc-card{padding:36px 28px;}
  .portfolio{padding:64px 24px;}
  .filter-bar{gap:6px;}
  .filter-btn{font-size:0.68rem;padding:8px 14px;}
  .split{grid-template-columns:1fr;}
  .split-photo{min-height:260px;max-height:340px;}
  .split-text{padding:48px 24px;}
  .split-pillars{grid-template-columns:1fr 1fr;}
  .process{padding:64px 24px;}
  .process-steps{grid-template-columns:1fr;border:none;gap:2px;}
  .pstep{border:1px solid var(--bd);padding:32px 24px;}
  .pstep-num{font-size:3rem;}
  .reviews{padding:64px 24px;}
  .reviews-grid{grid-template-columns:1fr;}
  .review-card{padding:32px 24px;}
  .reviews-top{flex-direction:column;gap:12px;}
  .certs{flex-direction:column;}
  .cert-label-col{border-right:none;border-bottom:1px solid var(--bl);padding:24px;}
  .cert-items{flex-wrap:wrap;}
  .cert-cell{min-width:50%;}
  .cta-band{padding:100px 24px;}
  .cta-h2{font-size:2.4rem;}
  .cta-btns{flex-direction:column;align-items:center;}
  .btn-primary,.btn-phone{width:100%;max-width:320px;justify-content:center;}
  .contact-wrap{grid-template-columns:1fr;}
  .contact-left{padding:56px 24px;}
  .contact-right{padding:48px 24px;}
  .form-row{grid-template-columns:1fr;}
  footer{grid-template-columns:1fr;text-align:center;padding:40px 24px;gap:16px;}
  .f-logo{justify-content:center;}
  .f-links{justify-content:center;flex-wrap:wrap;gap:16px;}
  .section-header{flex-direction:column;align-items:flex-start;gap:12px;}
  .section-header-right{text-align:left;max-width:100%;}
  .about-pillars{grid-template-columns:1fr;}
  .split-pillars{grid-template-columns:1fr;}
  .mob-cta{display:block;padding:18px;}
}
/* Very small phones */
@media(max-width:380px){
  .hero-h1{font-size:2.4rem;}
  .nav{height:60px;}
  nav,.nav.solid{padding:0 20px;}
}
/* Safe area insets for iPhone notch / home indicator */
@supports(padding-bottom:env(safe-area-inset-bottom)){
  .mob-cta{padding-bottom:calc(16px + env(safe-area-inset-bottom));}
  footer{padding-bottom:calc(40px + env(safe-area-inset-bottom));}
}
/* Smooth scrolling — respect reduced motion */
@media(prefers-reduced-motion:no-preference){
  html{scroll-behavior:smooth;}
}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none;}
  .hslide{animation:none;}
  .hslide.s1{opacity:1;}
}


/* ── ACTIVE NAV LINK ──────────────────────────────────────────── */
.nav-links a.nav-active{color:#fff;}
nav#mainNav.solid .nav-links a.nav-active{color:var(--ink);font-weight:500;}
nav#mainNav.solid .nav-links a.nav-active::after{
  content:'';display:block;height:2px;background:var(--lime);
  margin-top:2px;border-radius:1px;
}


/* ── WHATSAPP BUTTON ─────────────────────────────────────────── */
.wa-btn{
  position:fixed;bottom:88px;right:24px;z-index:700;
  width:52px;height:52px;border-radius:50%;
  background:#25D366;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 16px rgba(37,211,102,0.4);
  text-decoration:none;
  opacity:0;transform:scale(0.8);
  transition:opacity 0.3s,transform 0.3s,background 0.2s;
  pointer-events:none;
}
.wa-btn.show{opacity:1;transform:scale(1);pointer-events:all;}
.wa-btn:hover{background:#20BA5A;transform:scale(1.1);}
.wa-btn svg{width:28px;height:28px;fill:#fff;}
.wa-tooltip{
  position:absolute;right:62px;top:50%;transform:translateY(-50%);
  background:var(--ink);color:#fff;
  font-family:'DM Sans',sans-serif;font-size:0.72rem;font-weight:500;
  padding:6px 12px;white-space:nowrap;border-radius:4px;
  opacity:0;pointer-events:none;transition:opacity 0.2s;
}
.wa-tooltip::after{
  content:'';position:absolute;left:100%;top:50%;transform:translateY(-50%);
  border:5px solid transparent;border-left-color:var(--ink);
}
.wa-btn:hover .wa-tooltip{opacity:1;}
@media(max-width:640px){
  .wa-btn{bottom:76px;right:16px;width:48px;height:48px;}
  .wa-tooltip{display:none;}
}


/* ── FAQ SECTION ─────────────────────────────────────────────── */
.faq-section{
  padding:120px 80px;
  background:var(--paper-2);
  border-top:1px solid var(--bl);
  border-bottom:1px solid var(--bl);
}
.faq-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:0 48px;
  margin-top:52px;
}
.faq-item{
  border-bottom:0.5px solid var(--bl);
  overflow:hidden;
}
.faq-q{
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;
  padding:20px 0;
  cursor:pointer;
  background:none;border:none;width:100%;text-align:left;
  font-family:'DM Sans',sans-serif;font-size:0.92rem;font-weight:500;
  color:var(--ink);line-height:1.45;
  transition:color 0.2s;
}
.faq-q:hover{color:var(--lime-dk);}
.faq-icon{
  flex-shrink:0;width:20px;height:20px;
  border:1.5px solid var(--bl2);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:0.85rem;font-weight:300;color:var(--ink-mid);
  transition:transform 0.3s,border-color 0.2s,color 0.2s;
  line-height:1;
}
.faq-item.open .faq-icon{
  transform:rotate(45deg);
  border-color:var(--lime-dk);
  color:var(--lime-dk);
}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height 0.4s cubic-bezier(0.16,1,0.3,1);
}
.faq-item.open .faq-a{max-height:400px;}
.faq-a-inner{
  padding:0 0 20px;
  font-size:0.88rem;font-weight:300;color:var(--ink-mid);line-height:1.8;
}
@media(max-width:900px){.faq-grid{grid-template-columns:1fr;gap:0;}}
@media(max-width:640px){.faq-section{padding:64px 24px;}}


/* ── EXIT INTENT POPUP ───────────────────────────────────────── */
.exit-overlay{
  position:fixed;inset:0;z-index:1100;
  background:rgba(26,25,22,0.6);
  backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  opacity:0;pointer-events:none;
  transition:opacity 0.3s ease;
}
.exit-overlay.show{opacity:1;pointer-events:all;}
.exit-modal{
  background:var(--paper);
  max-width:480px;width:100%;
  padding:52px 48px;
  position:relative;
  border-top:4px solid var(--lime);
  animation:exitPop 0.4s cubic-bezier(0.16,1,0.3,1);
}
@keyframes exitPop{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.exit-close{
  position:absolute;top:16px;right:16px;
  width:32px;height:32px;border-radius:50%;
  background:var(--paper-2);border:none;cursor:pointer;
  font-size:1rem;color:var(--ink-mid);
  display:flex;align-items:center;justify-content:center;
  transition:background 0.2s;
}
.exit-close:hover{background:var(--paper-3);}
.exit-eyebrow{
  font-family:"DM Sans",sans-serif;font-size:0.66rem;font-weight:500;
  letter-spacing:0.22em;text-transform:uppercase;color:var(--lime-dk);
  margin-bottom:12px;
}
.exit-h2{
  font-family:"Cormorant Garamond",serif;
  font-size:1.8rem;font-weight:600;line-height:1.15;
  color:var(--ink);margin-bottom:12px;
}
.exit-p{font-size:0.88rem;font-weight:300;color:var(--ink-mid);line-height:1.7;margin-bottom:28px;}
.exit-form{display:flex;gap:8px;}
.exit-input{
  flex:1;padding:12px 16px;
  background:var(--white);border:1px solid var(--bl2);
  font-family:"DM Sans",sans-serif;font-size:0.9rem;font-weight:300;
  color:var(--ink);outline:none;
  transition:border-color 0.2s;
}
.exit-input:focus{border-color:var(--lime-dk);}
.exit-btn{
  background:var(--lime);color:var(--ink);border:none;
  padding:12px 22px;cursor:pointer;
  font-family:"DM Sans",sans-serif;font-size:0.78rem;font-weight:500;
  letter-spacing:0.1em;text-transform:uppercase;
  transition:background 0.2s;white-space:nowrap;
}
.exit-btn:hover{background:var(--lime-dk);}
.exit-note{font-size:0.68rem;color:var(--ink-dim);margin-top:10px;text-align:center;}
.exit-success{text-align:center;padding:16px 0;}
.exit-success-icon{font-size:2rem;margin-bottom:10px;}
.exit-success-msg{font-size:0.9rem;color:var(--ink-mid);}
@media(max-width:480px){
  .exit-modal{padding:40px 28px;}
  .exit-form{flex-direction:column;}
  .exit-h2{font-size:1.5rem;}
}


/* ── GOOGLE MAP ──────────────────────────────────────────────── */
.contact-map{
  margin-top:40px;
  border:1px solid rgba(255,255,255,0.08);
  overflow:hidden;
}
.contact-map iframe{
  display:block;width:100%;height:240px;border:none;
  filter:grayscale(30%) contrast(1.05);
}
@media(max-width:640px){.contact-map iframe{height:180px;}}


/* ── SERVICE CARD PHOTO BACKGROUNDS ─────────────────────────── */
.svc-bg{
  position:absolute;inset:0;z-index:0;
  pointer-events:none;
}
.svc-bg img{
  width:100%;height:100%;object-fit:cover;display:block;
  filter:brightness(0.55) saturate(0.7);
  transition:transform 0.8s cubic-bezier(0.16,1,0.3,1),filter 0.5s;
}
.svc-card:hover .svc-bg img{
  transform:scale(1.07);
  filter:brightness(0.38) saturate(0.6);
}
.svc-card-inner{position:relative;z-index:1;}
/* Text colour flip when photo is visible */
.svc-card .svc-n{color:rgba(255,255,255,0.6);}
.svc-card .svc-name{color:#fff;text-shadow:0 2px 12px rgba(0,0,0,0.45);}
.svc-card .svc-desc{color:rgba(255,255,255,0.82);text-shadow:0 1px 6px rgba(0,0,0,0.35);}
.svc-card .svc-arrow{color:var(--lime);}
.svc-arrow:hover{
  background:var(--lime);
  color:var(--ink);
  border-color:var(--lime);
}


/* ── PIPEDA COOKIE CONSENT ───────────────────────────────────── */
.cookie-bar{
  position:fixed;bottom:0;left:0;right:0;z-index:1200;
  background:var(--ink);
  border-top:2px solid var(--lime);
  padding:14px 64px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  font-family:'DM Sans',sans-serif;
  transform:translateY(100%);
  transition:transform 0.4s cubic-bezier(0.16,1,0.3,1);
}
.cookie-bar.show{transform:translateY(0);}
.cookie-bar p{
  font-size:0.78rem;font-weight:300;color:rgba(255,255,255,0.72);
  line-height:1.6;flex:1;
}
.cookie-bar p a{color:var(--lime);text-decoration:none;}
.cookie-bar p a:hover{text-decoration:underline;}
.cookie-btns{display:flex;gap:8px;flex-shrink:0;}
.cookie-accept,.cookie-decline{
  font-family:'DM Sans',sans-serif;font-size:0.72rem;font-weight:500;
  letter-spacing:0.1em;text-transform:uppercase;
  padding:8px 18px;border:none;cursor:pointer;
  transition:background 0.2s,color 0.2s;
  white-space:nowrap;
}
.cookie-accept{background:var(--lime);color:var(--ink);}
.cookie-accept:hover{background:var(--lime-dk);}
.cookie-decline{background:transparent;color:rgba(255,255,255,0.4);border:1px solid rgba(255,255,255,0.15);}
.cookie-decline:hover{color:rgba(255,255,255,0.7);border-color:rgba(255,255,255,0.3);}
@media(max-width:640px){
  .cookie-bar{padding:14px 20px;flex-direction:column;align-items:flex-start;gap:12px;}
  .cookie-btns{width:100%;justify-content:flex-end;}
}
@supports(padding-bottom:env(safe-area-inset-bottom)){
  .cookie-bar{padding-bottom:calc(14px + env(safe-area-inset-bottom));}
}


/* ── BEFORE/AFTER COMPARISON SLIDER ─────────────────────────── */
.ba-section{
  padding:120px 80px;
  background:var(--ink);
  border-top:1px solid rgba(255,255,255,0.06);
}
/* Full-width variant */
.ba-section--fullwidth{
  padding:80px 0 0;
}
.ba-section--fullwidth .ba-label-row{
  padding:0 80px 48px;
}
.ba-section--fullwidth .ba-note{
  padding:24px 80px 80px;
}
.ba-section--fullwidth .ba-wrap{
  max-width:100%;
  margin:0;
  aspect-ratio:21/9;
  border-left:none;
  border-right:none;
}
.ba-label-row{margin-bottom:48px;}
.ba-section .intro-label{color:var(--lime);}
.ba-h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,3.5vw,3.2rem);font-weight:600;
  color:#fff;line-height:1.1;margin-top:12px;
}
.ba-h2 em{font-style:italic;color:var(--lime);font-weight:300;}
.ba-wrap{
  position:relative;
  width:100%;
  max-width:900px;
  margin:0 auto;
  aspect-ratio:16/9;
  overflow:hidden;
  cursor:col-resize;
  user-select:none;
  border:1px solid rgba(255,255,255,0.1);
}
.ba-img{
  position:absolute;inset:0;
  width:100%;height:100%;object-fit:cover;
}
.ba-after{z-index:1;}
.ba-before{z-index:2;}
.ba-before-wrap{
  position:absolute;inset:0;z-index:2;
  overflow:hidden;
  width:50%;
  transition:none;
}
.ba-before-wrap img{
  position:absolute;top:0;left:0;
  width:100vw;max-width:100vw;height:100%;
  object-fit:cover;
}
.ba-handle{
  position:absolute;top:0;bottom:0;z-index:3;
  left:50%;transform:translateX(-50%);
  width:3px;background:var(--lime);
  cursor:col-resize;
}
.ba-handle::before{
  content:'';
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:40px;height:40px;border-radius:50%;
  background:var(--lime);
  display:flex;align-items:center;justify-content:center;
}
.ba-handle::after{
  content:'◀ ▶';
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  font-size:0.6rem;color:var(--ink);
  white-space:nowrap;font-weight:700;letter-spacing:0.08em;
}
.ba-tag{
  position:absolute;bottom:16px;z-index:4;
  font-family:'DM Sans',sans-serif;font-size:0.65rem;
  font-weight:500;letter-spacing:0.2em;text-transform:uppercase;
  background:rgba(26,25,22,0.75);color:#fff;
  padding:5px 12px;
}
.ba-tag-before{left:16px;}
.ba-tag-after{right:16px;}
.ba-note{
  text-align:center;margin-top:24px;
  font-size:0.78rem;font-weight:300;color:rgba(255,255,255,0.35);
  font-family:'DM Sans',sans-serif;
}
@media(max-width:900px){
  .ba-section{padding:80px 40px;}
  .ba-section--fullwidth{padding:60px 0 0;}
  .ba-section--fullwidth .ba-label-row{padding:0 40px 40px;}
  .ba-section--fullwidth .ba-note{padding:20px 40px 60px;}
  .ba-section--fullwidth .ba-wrap{aspect-ratio:16/9;}
}
@media(max-width:640px){
  /* Before/After — повна ширина на мобільному */
  .ba-section{padding:48px 0;}
  .ba-section--fullwidth{padding:48px 0 0;}
  .ba-section--fullwidth .ba-label-row{padding:0 24px 32px;}
  .ba-section--fullwidth .ba-note{padding:16px 24px 48px;}
  .ba-wrap{aspect-ratio:4/3;}
  .ba-section--fullwidth .ba-wrap{
    aspect-ratio:4/3;
    border-left:none;
    border-right:none;
    width:100vw;
    margin-left:calc(-1 * var(--section-pad, 0px));
  }

  /* Instagram feed — показуємо на мобільному */
  .insta-feed-wrap{
    display:block !important;
    visibility:visible !important;
    opacity:1 !important;
  }
  .insta-feed-wrap > *{
    display:block !important;
  }

  /* Логотип — зменшуємо на мобільному */
  .tmark{width:36px;height:36px;}
  .tmark-bar{width:18px;height:5px;}
  .tmark-stem{width:5px;height:13px;}
  .tmark-t{padding-top:8px;}
  .tmark-box::before,.tmark-box::after{width:10px;height:10px;}
  .nav-name{font-size:0.78rem;letter-spacing:0.1em;}
  .nav-logo{gap:10px;}
  nav{height:72px;padding:0 20px;}
}
/* ── CALENDLY BOOKING LINK ───────────────────────────────────── */
.contact-booking{
  margin-top:36px;
  padding-top:28px;
  border-top:1px solid rgba(255,255,255,0.08);
}
.booking-label{
  font-family:'DM Sans',sans-serif;font-size:0.78rem;font-weight:300;
  color:rgba(255,255,255,0.45);letter-spacing:0.04em;margin-bottom:10px;
}
.booking-link{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'DM Sans',sans-serif;font-size:0.82rem;font-weight:500;
  letter-spacing:0.08em;text-transform:uppercase;
  color:var(--lime);text-decoration:none;
  border:1px solid rgba(184,212,0,0.3);
  padding:12px 20px;
  transition:background 0.2s,color 0.2s,border-color 0.2s;
}
.booking-link:hover{
  background:var(--lime);color:var(--ink);border-color:var(--lime);
}
.booking-note{
  font-family:'DM Sans',sans-serif;font-size:0.7rem;font-weight:300;
  color:rgba(255,255,255,0.28);margin-top:8px;letter-spacing:0.04em;
}


/* ── INSTAGRAM FEED SECTION ─────────────────────────────────── */
.insta-section{
  padding:0;
  background:var(--ink);
  border-top:1px solid rgba(255,255,255,0.06);
}
.insta-header{
  padding:48px 80px 36px;
  display:flex;align-items:flex-end;justify-content:space-between;gap:24px;
}
.insta-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.4rem,2.2vw,2rem);font-weight:600;color:#fff;line-height:1.1;
}
.insta-title em{font-style:italic;color:var(--lime);font-weight:300;}
.insta-handle{
  font-family:'DM Sans',sans-serif;font-size:0.72rem;font-weight:400;
  letter-spacing:0.18em;text-transform:uppercase;
  color:rgba(255,255,255,0.4);text-decoration:none;
  transition:color 0.2s;flex-shrink:0;
}
.insta-handle:hover{color:var(--lime);}
.insta-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:2px;
}
.insta-cell{
  position:relative;overflow:hidden;
  aspect-ratio:1/1;
  cursor:pointer;
}
.insta-cell img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 0.6s cubic-bezier(0.16,1,0.3,1);
  filter:brightness(0.88) saturate(0.9);
}
.insta-cell:hover img{
  transform:scale(1.05);
  filter:brightness(0.7) saturate(0.8);
}
.insta-cell-overlay{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  opacity:0;
  transition:opacity 0.3s;
}
.insta-cell:hover .insta-cell-overlay{opacity:1;}
.insta-icon{
  font-size:1.4rem;color:#fff;
}
.insta-cta-bar{
  padding:24px 80px;
  text-align:center;
  border-top:1px solid rgba(255,255,255,0.06);
}
.insta-cta-bar a{
  font-family:'DM Sans',sans-serif;font-size:0.75rem;font-weight:500;
  letter-spacing:0.16em;text-transform:uppercase;
  color:rgba(255,255,255,0.4);text-decoration:none;
  transition:color 0.2s;
}
.insta-cta-bar a:hover{color:var(--lime);}
@media(max-width:900px){
  .insta-header{padding:40px 40px 28px;}
  .insta-cta-bar{padding:20px 40px;}
  .insta-grid{grid-template-columns:repeat(3,1fr);}
}
@media(max-width:640px){
  .insta-header{padding:36px 24px 20px;flex-direction:column;align-items:flex-start;gap:8px;}
  .insta-cta-bar{padding:18px 24px;}
  .insta-grid{grid-template-columns:repeat(3,1fr);}
}


/* ─── PORTFOLIO SPLIDE SLIDER ────────────────────────────────── */
.portfolio-splide{margin-top:48px;}
.portfolio-splide .splide__track{overflow:visible;}
.portfolio-splide .pgrid-item{
  position:relative;
  overflow:hidden;
  height:480px;
  cursor:pointer;
  flex-shrink:0;
}
.portfolio-splide .pgrid-item img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 0.8s cubic-bezier(0.16,1,0.3,1);
}
.portfolio-splide .pgrid-item:hover img{transform:scale(1.04);}
.portfolio-splide .pgrid-overlay{
  position:absolute;bottom:0;left:0;right:0;
  padding:32px 28px;
  background:linear-gradient(to top, rgba(20,18,14,0.82) 0%, transparent 100%);
  opacity:0;
  transform:translateY(8px);
  transition:opacity 0.3s, transform 0.3s;
}
.portfolio-splide .pgrid-item:hover .pgrid-overlay{opacity:1;transform:translateY(0);}
.portfolio-splide .pgrid-title{
  font-family:'Cormorant Garamond',serif;
  font-size:1.25rem;font-weight:600;color:#fff;margin-bottom:6px;
}
.portfolio-splide .pgrid-cat{
  font-family:'DM Sans',sans-serif;
  font-size:0.65rem;font-weight:500;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--lime);
}
/* Splide arrows — custom style */
.portfolio-splide .splide__arrow{
  width:48px;height:48px;
  background:var(--ink);border-radius:0;
  opacity:1;top:auto;bottom:-72px;
  transition:background 0.2s;
}
.portfolio-splide .splide__arrow:hover{background:var(--lime);}
.portfolio-splide .splide__arrow svg{fill:#fff;width:16px;height:16px;}
.portfolio-splide .splide__arrow--prev{left:0;}
.portfolio-splide .splide__arrow--next{left:64px;}
.portfolio{padding-bottom:120px;}

/* ─── INSTAGRAM FEED WRAP (Social Feed Gallery) ─────────────── */
.insta-feed-wrap{
  margin-top:48px;
}
/* Скидаємо можливі відступи плагіну */
.insta-feed-wrap > div{
  margin:0 !important;
  padding:0 !important;
}
/* Обмежуємо до 2 рядків по 3 фото */
.insta-feed-wrap .igfe-item:nth-child(n+7){
  display:none !important;
}
/* Висота фото */
.insta-feed-wrap .igfe-item img,
.insta-feed-wrap .igfe-item video{
  height:320px !important;
  object-fit:cover !important;
  width:100% !important;
}
}

/* ─── METASLIDER HERO FIX ────────────────────────────────────── */
.hero-photo [id^="metaslider-id-"],
.hero-photo [id^="metaslider-id-"] .metaslider,
.hero-photo [id^="metaslider-id-"] .flexslider{
  position:absolute !important;
  inset:0 !important;
  width:100% !important;
  height:100% !important;
  max-width:none !important;
  margin:0 auto !important;
}
.hero-photo [id^="metaslider-id-"] ul.slides,
.hero-photo [id^="metaslider-id-"] ul.slides li{
  height:100% !important;
  width:100% !important;
  max-width:none !important;
}
.hero-photo [id^="metaslider-id-"] ul.slides li img{
  width:100% !important;
  height:100% !important;
  max-width:none !important;
  object-fit:cover !important;
  object-position:center 30% !important;
  display:block !important;
}
/* Перебиваємо inline style max-width на мобільному */
@media(max-width:640px){
  #metaslider-id-1892{
    max-width:100% !important;
    width:100% !important;
    margin-right:0 !important;
    transform:none !important;
  }
  #metaslider-id-1892 .flexslider,
  #metaslider-id-1892 ul.slides,
  #metaslider-id-1892 ul.slides li{
    height:100vh !important;
    width:100% !important;
    max-width:none !important;
  }
  #metaslider-id-1892 ul.slides li img{
    width:100% !important;
    height:100% !important;
    object-fit:cover !important;
    object-position:center 30% !important;
  }
}
/* Ховаємо підписи і навігацію */
.hero-photo .caption-wrap,
.hero-photo .flex-direction-nav,
.hero-photo .flex-control-nav{
  display:none !important;
}

/* ─── MOBILE MENU STACKING FIX ──────────────────────────────── */
/* Ізолюємо hero від stacking context щоб mobile-menu міг перекрити */
.hero-photo{isolation:isolate;}
.hero{isolation:auto;}
/* Переконуємось що mobile-menu завжди зверху */
#mobileMenu{
  position:fixed !important;
  inset:0 !important;
  z-index:99999 !important;
}

/* ─── CONTACT FORM 7 — стиль під наш дизайн ─────────────────── */
.wpcf7-form .fg-row{
  display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;
}
.wpcf7-form .fg{margin-bottom:16px;}
.wpcf7-form .fg-row .fg{margin-bottom:0;}

.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form select,
.wpcf7-form textarea{
  width:100%;
  padding:14px 16px;
  border:1px solid var(--bl);
  background:var(--white);
  font-family:'DM Sans',sans-serif;
  font-size:0.9rem;
  color:var(--ink);
  outline:none;
  border-radius:0;
  transition:border-color 0.2s;
  -webkit-appearance:none;
}
.wpcf7-form input:focus,
.wpcf7-form select:focus,
.wpcf7-form textarea:focus{
  border-color:var(--ink);
}
.wpcf7-form input::placeholder,
.wpcf7-form textarea::placeholder{
  color:var(--ink-dim);
}
.wpcf7-form textarea{
  resize:vertical;min-height:120px;
}
.wpcf7-form select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%231a1916' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 16px center;
  padding-right:40px;
  cursor:pointer;
}
.wpcf7-form .btn-submit{
  width:100%;
  padding:18px 32px;
  background:var(--lime);
  color:var(--ink);
  border:none;
  font-family:'DM Sans',sans-serif;
  font-size:0.82rem;
  font-weight:500;
  letter-spacing:0.12em;
  text-transform:uppercase;
  cursor:pointer;
  transition:background 0.2s;
}
.wpcf7-form .btn-submit:hover{background:var(--lime-dk);}
.wpcf7-form .form-note{
  font-size:0.75rem;
  color:var(--ink-dim);
  text-align:center;
  margin-top:12px;
  letter-spacing:0.04em;
}
/* Validation */
.wpcf7-form input.wpcf7-not-valid,
.wpcf7-form select.wpcf7-not-valid,
.wpcf7-form textarea.wpcf7-not-valid{
  border-color:#C0392B;
  background:#FFF8F7;
}
.wpcf7-not-valid-tip{
  font-size:0.72rem;
  color:#C0392B;
  margin-top:4px;
  display:block;
}
.wpcf7-response-output{
  margin-top:16px;
  padding:12px 16px;
  font-size:0.82rem;
  border:none !important;
}
.wpcf7-mail-sent-ok{
  background:rgba(164,190,48,0.12);
  color:var(--ink);
}
.wpcf7-validation-errors{
  background:#FFF8F7;
  color:#C0392B;
}
@media(max-width:640px){
  .wpcf7-form .fg-row{grid-template-columns:1fr;}
}

/* ─── TRUSTINDEX REVIEWS ─────────────────────────────────────── */
.trustindex-wrap{margin-top:48px;}
.trustindex-wrap .ti-widget{background:transparent !important;}
.trustindex-wrap .ti-review-item{
  background:var(--paper) !important;
  border:1px solid var(--bl) !important;
  border-radius:0 !important;
}
.trustindex-wrap .ti-review-content{
  font-family:'DM Sans',sans-serif !important;
  font-size:0.88rem !important;
  color:var(--ink-mid) !important;
}
.trustindex-wrap .ti-name{
  font-family:'DM Sans',sans-serif !important;
  font-weight:500 !important;
  color:var(--ink) !important;
}

/* ─── SIMPLY SCHEDULE APPOINTMENTS — стиль під наш дизайн ───── */
.ssa-booking-form-wrap{
  margin-top:32px;
  font-family:'DM Sans',sans-serif !important;
}
/* Заголовок типу */
.ssa-appointment-type-name{
  font-family:'Cormorant Garamond',serif !important;
  font-size:1.4rem !important;
  font-weight:600 !important;
  color:var(--ink) !important;
  margin-bottom:4px !important;
}
.ssa-appointment-type-duration{
  font-size:0.78rem !important;
  color:var(--ink-mid) !important;
  letter-spacing:0.08em !important;
}
/* Календар */
.ssa-calendar-header{
  font-family:'DM Sans',sans-serif !important;
  font-weight:500 !important;
  color:var(--ink) !important;
  font-size:0.9rem !important;
}
.ssa-calendar-day--available{
  border:0.5px solid var(--bl) !important;
  border-radius:0 !important;
  font-family:'DM Sans',sans-serif !important;
  color:var(--ink) !important;
}
.ssa-calendar-day--available:hover{
  background:var(--ink) !important;
  color:#fff !important;
  border-color:var(--ink) !important;
}
.ssa-calendar-day--selected{
  background:var(--ink) !important;
  color:#fff !important;
  border-radius:0 !important;
  border-color:var(--ink) !important;
}
.ssa-calendar-day--unavailable{
  color:var(--ink-dim) !important;
  border-radius:0 !important;
}
/* Часові слоти */
.ssa-time-slot{
  border:0.5px solid var(--bl) !important;
  border-radius:0 !important;
  font-family:'DM Sans',sans-serif !important;
  font-size:0.85rem !important;
  font-weight:400 !important;
  color:var(--ink) !important;
  padding:12px 16px !important;
}
.ssa-time-slot:hover{
  border-color:var(--ink) !important;
  background:var(--ink) !important;
  color:#fff !important;
}
.ssa-time-slot--selected{
  background:var(--ink) !important;
  color:#fff !important;
  border-color:var(--ink) !important;
}
/* Кнопка */
.ssa-submit-btn,
.ssa-booking-form-wrap input[type="submit"],
.ssa-booking-form-wrap button[type="submit"]{
  background:var(--lime) !important;
  color:var(--ink) !important;
  border:none !important;
  border-radius:0 !important;
  font-family:'DM Sans',sans-serif !important;
  font-size:0.82rem !important;
  font-weight:500 !important;
  letter-spacing:0.12em !important;
  text-transform:uppercase !important;
  padding:16px 32px !important;
  width:100% !important;
}
.ssa-submit-btn:hover,
.ssa-booking-form-wrap input[type="submit"]:hover{
  background:var(--lime-dk) !important;
}
/* Поля форми */
.ssa-booking-form-wrap input[type="text"],
.ssa-booking-form-wrap input[type="email"],
.ssa-booking-form-wrap input[type="tel"],
.ssa-booking-form-wrap textarea{
  border:1px solid var(--bl) !important;
  border-radius:0 !important;
  font-family:'DM Sans',sans-serif !important;
  font-size:0.9rem !important;
  color:var(--ink) !important;
  padding:14px 16px !important;
}
.ssa-booking-form-wrap input:focus,
.ssa-booking-form-wrap textarea:focus{
  border-color:var(--ink) !important;
  outline:none !important;
}
/* Навігація календаря */
.ssa-calendar-nav-btn{
  border:0.5px solid var(--bl) !important;
  border-radius:0 !important;
  color:var(--ink) !important;
}
.ssa-calendar-nav-btn:hover{
  background:var(--ink) !important;
  color:#fff !important;
}

/* ─── BOOKING HEADER ─────────────────────────────────────────── */
.booking-h3{
  font-family:'Cormorant Garamond',serif;
  font-size:2rem;font-weight:600;
  color:var(--ink);line-height:1.1;
  margin-bottom:10px;
}
.booking-h3 em{font-style:italic;color:var(--lime);font-weight:300;}
.booking-sub{
  font-family:'DM Sans',sans-serif;
  font-size:0.82rem;color:var(--ink-mid);
  margin-bottom:24px;
}

/* Прибираємо білий фон з SSA букінгу */
.ssa-booking-form-wrap,
.ssa-booking-form-wrap > div,
.ssa__form,
.ssa-appointment-types-wrap{
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
}

/* SSA — прибираємо білий фон mdc-card */
.booking-app .mdc-card,
.booking-app .md-card,
.booking-app .mdc-card.md-card{
  background:transparent !important;
  box-shadow:none !important;
  border:none !important;
}

/* SSA — override mdc-card через високу специфічність */
div.booking-app div.mdc-card,
div.booking-app div.md-card,
div.ssa-booking-form-wrap div.mdc-card{
  background-color:transparent !important;
  background:transparent !important;
  box-shadow:none !important;
  border:none !important;
}

/* ═══════════════════════════════════════════════
   SERVICE PAGE — page-service.php
═══════════════════════════════════════════════ */

/* Hero */
.svc-hero{
  position:relative;
  min-height:100vh;
  display:flex;align-items:flex-end;
  overflow:hidden;
  background:var(--ink);
}
.svc-hero-photo{
  position:absolute;inset:0;
}
.svc-hero-photo img{
  width:100%;height:100%;object-fit:cover;object-position:center 30%;display:block;
  opacity:0.55;
}
.svc-hero-content{
  position:relative;z-index:2;
  padding:0 80px 80px;
  max-width:760px;
}
.svc-hero-h1{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.8rem,5vw,5rem);
  font-weight:600;color:#fff;
  line-height:1.05;margin:16px 0 20px;
}
.svc-hero-sub{
  font-family:'DM Sans',sans-serif;
  font-size:1rem;font-weight:300;
  color:rgba(255,255,255,0.75);
  margin-bottom:36px;line-height:1.6;
  max-width:540px;
}
.svc-hero-ctas{display:flex;gap:16px;flex-wrap:wrap;}

/* Intro */
.svc-intro{padding:100px 80px;}
.svc-intro-inner{
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:start;
}
.svc-intro-body{
  font-size:0.95rem;line-height:1.85;
  color:var(--ink-mid);margin-top:24px;
}
.svc-intro-body p{margin-bottom:16px;}
.svc-feature-item{
  display:flex;align-items:flex-start;gap:14px;
  margin-bottom:16px;
  font-size:0.88rem;color:var(--ink);line-height:1.5;
}
.svc-feature-dot{
  width:8px;height:8px;
  background:var(--lime);
  flex-shrink:0;margin-top:5px;
}

/* Process */
.svc-process{
  padding:100px 80px;
  background:var(--paper-2);
}
.svc-process-steps{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:40px;margin-top:56px;
}

/* FAQ */
.svc-faq{padding:100px 80px;}
.svc-faq .faq-inner{max-width:760px;margin:0 auto;}

/* Contact */
.svc-contact{
  padding:0;
}

/* Mobile */
@media(max-width:768px){
  .svc-hero-content{padding:0 24px 60px;}
  .svc-intro{padding:64px 24px;}
  .svc-intro-inner{grid-template-columns:1fr;}
  .svc-process{padding:64px 24px;}
  .svc-process-steps{grid-template-columns:1fr 1fr;}
  .svc-faq{padding:64px 24px;}
}
@media(max-width:480px){
  .svc-process-steps{grid-template-columns:1fr;}
}

.svc-gallery-section{
  padding:0 80px 80px;
  background:var(--paper);
}
.svc-gallery-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:24px;
}
.svc-gallery-link{
  font-size:0.75rem;font-weight:500;letter-spacing:0.1em;
  text-transform:uppercase;color:var(--lime);
  text-decoration:none;
}
.svc-gallery-link:hover{color:var(--lime-dk);}
/* FooGallery overrides */
.svc-gallery-wrap .foogallery{
  display:grid !important;
  grid-template-columns:repeat(3,1fr) !important;
  gap:4px !important;
  margin:0 !important;
  padding:0 !important;
}
.svc-gallery-wrap .foogallery .fg-item{
  margin:0 !important;
  padding:0 !important;
  overflow:hidden;
  border:none !important;
  box-shadow:none !important;
  background:none !important;
}
.svc-gallery-wrap .foogallery .fg-item a{
  display:block !important;
  border:none !important;
  box-shadow:none !important;
  padding:0 !important;
  margin:0 !important;
}
.svc-gallery-wrap .foogallery .fg-item img{
  width:100% !important;
  height:260px !important;
  object-fit:cover !important;
  object-position:center !important;
  display:block !important;
  border:none !important;
  box-shadow:none !important;
  transition:transform 0.6s cubic-bezier(0.16,1,0.3,1) !important;
  margin:0 !important;
  padding:0 !important;
}
.svc-gallery-wrap .foogallery .fg-item:hover img{
  transform:scale(1.05) !important;
}
@media(max-width:640px){
  .svc-gallery-section{padding:0 24px 56px;}
  .svc-gallery-wrap .foogallery{
    grid-template-columns:repeat(2,1fr) !important;
  }
  .svc-gallery-wrap .foogallery .fg-item img{
    height:180px !important;
  }
}

/* ─── CONTACT INSTAGRAM MINI FEED ───────────────────────────── */
.contact-insta{margin-top:32px;}
.contact-insta-label{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:12px;
  font-family:'DM Sans',sans-serif;
  font-size:0.72rem;letter-spacing:0.1em;text-transform:uppercase;
}
.contact-insta-label span{color:rgba(255,255,255,0.5);}
.contact-insta-label a{color:var(--lime);text-decoration:none;}
.contact-insta-label a:hover{color:var(--lime-dk);}
/* Обмежуємо до 3 фото в ряд */
.contact-insta .igfe-wrapper,
.contact-insta > div > div{
  display:grid !important;
  grid-template-columns:repeat(3,1fr) !important;
  gap:3px !important;
}
.contact-insta .igfe-item:nth-child(n+4){display:none !important;}
.contact-insta .igfe-item img,
.contact-insta .igfe-item video{
  height:120px !important;
  width:100% !important;
  object-fit:cover !important;
}

/* ─── CONTACT STATS ──────────────────────────────────────────── */
.contact-stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:24px;margin-top:40px;
  border-top:0.5px solid rgba(255,255,255,0.1);
  padding-top:32px;
}
.contact-stat-num{
  font-family:'Cormorant Garamond',serif;
  font-size:2.2rem;font-weight:600;
  color:var(--lime);line-height:1;
  margin-bottom:6px;
}
.contact-stat-label{
  font-family:'DM Sans',sans-serif;
  font-size:0.65rem;font-weight:500;
  letter-spacing:0.14em;text-transform:uppercase;
  color:rgba(255,255,255,0.45);
}

/* ─── CONTACT INSTAGRAM WRAP ─────────────────────────────────── */
.contact-insta-wrap{margin-top:40px;}
.contact-insta-header{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-bottom:16px;
}
.contact-insta-wrap .insta-title{
  font-family:'Cormorant Garamond',serif;
  font-size:1.2rem;font-weight:600;
  color:#fff;line-height:1.2;
}
.contact-insta-wrap .insta-title em{
  font-style:italic;color:var(--lime);font-weight:300;
}
.contact-insta-wrap .insta-handle{
  font-size:0.72rem;letter-spacing:0.1em;
  text-transform:uppercase;color:var(--lime);
  text-decoration:none;
}

/* ─── CONTACT INSTAGRAM WRAP ─────────────────────────────────── */
.contact-insta-wrap{
  margin-top:32px;
  overflow:hidden;
  max-width:100%;
}
.contact-insta-header{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:12px;
}
.contact-insta-label{
  font-size:0.65rem;font-weight:500;letter-spacing:0.14em;
  text-transform:uppercase;color:rgba(255,255,255,0.4);
}
/* Force carousel to stay within container */
.contact-insta-wrap > div,
.contact-insta-wrap .igfe-wrapper,
.contact-insta-wrap .sfg-feed-wrapper{
  max-width:100% !important;
  overflow:hidden !important;
}
.contact-insta-wrap img,
.contact-insta-wrap video{
  max-width:100% !important;
}

/* ─── CONTACT TABS ───────────────────────────────────────────── */
.contact-tabs{
  display:grid;grid-template-columns:1fr 1fr;
  gap:12px;margin-bottom:40px;
}
.contact-tab{
  padding:22px 28px;
  background:var(--paper-2);
  border:1.5px solid var(--bl);
  border-bottom:3px solid var(--ink);
  font-family:'DM Sans',sans-serif;
  font-size:0.78rem;font-weight:500;
  letter-spacing:0;text-transform:none;
  color:var(--ink-mid);
  cursor:pointer;
  transition:all 0.2s;
  text-align:left;
  display:flex;flex-direction:column;gap:4px;
}
.contact-tab:hover{color:var(--ink);}
.contact-tab.active{
  border-bottom:3px solid var(--lime);
  color:var(--ink);
}
.contact-tab--booking{background:var(--paper-2);color:var(--ink);}
.contact-tab--booking.active{border-bottom:3px solid var(--lime);}
.tab-booking-label{
  font-size:0.7rem;font-weight:500;
  letter-spacing:0.14em;text-transform:uppercase;
  color:var(--lime);margin-bottom:4px;
}
.tab-booking-title{
  font-family:'Cormorant Garamond',serif;
  font-size:1.25rem;font-weight:600;
  color:var(--ink);line-height:1.2;
}
.tab-booking-title em{font-style:italic;color:var(--lime);font-weight:300;}
.tab-booking-sub{
  font-size:0.78rem;font-weight:300;
  color:var(--ink-mid);margin-top:4px;
}
.contact-tab-panel{display:none;}
.contact-tab-panel.active{display:block;}

/* ─── BOOKING TAB PANEL — світлий стиль ──────────────────────── */
#tab-booking{
  background:transparent;
  color:var(--ink);
}
#tab-booking .ssa-booking-form-wrap{
  margin-top:24px;
}

/* ─── HIDE CF7 SPAM FIELD ────────────────────────────────────── */
.wpcf7-form .wpcf7-response-output{margin-top:16px;}
span.wpcf7-not-valid-tip{font-size:0.72rem;color:#C0392B;}
/* Hide delta/honeypot field */
.wpcf7-form p:empty{display:none;}
.wpcf7 form .wpcf7-response-output{border:none;}
input[name="_wpcf7_ak_hp_textarea"],
.wpcf7 .akismet-fields-container{display:none !important;}

/* ═══════════════════════════════════════════════
   TRADE PARTNERS SECTION
═══════════════════════════════════════════════ */
.trade-section{
  position:relative;
  padding:120px 80px;
  overflow:hidden;
}
.trade-bg{
  position:absolute;inset:0;
  background:url('https://toptile.ca/wp-content/uploads/2026/04/image-16.jpg') center/cover no-repeat;
  z-index:0;
}
.trade-bg::after{
  content:'';position:absolute;inset:0;
  background:rgba(20,18,14,0.88);
}
.trade-content{position:relative;z-index:1;}
.trade-h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,3.5vw,3rem);
  font-weight:600;color:#fff;line-height:1.1;
  margin-bottom:20px;margin-top:12px;
}
.trade-h2 em{font-style:italic;color:var(--lime);font-weight:300;}
.trade-intro{
  font-size:0.95rem;color:rgba(255,255,255,0.55);
  line-height:1.75;max-width:560px;margin-bottom:56px;
}

/* Cards */
.trade-cards{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:2px;margin-bottom:2px;
}
.trade-card{
  background:rgba(255,255,255,0.04);
  border:0.5px solid rgba(255,255,255,0.08);
  padding:32px 28px;
}
.trade-card-icon{
  width:40px;height:40px;
  border:0.5px solid rgba(164,188,0,0.35);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:20px;
}
.trade-card-icon svg{width:18px;height:18px;}
.trade-card-title{
  font-family:'DM Sans',sans-serif;
  font-size:0.95rem;font-weight:500;
  color:#fff;margin-bottom:10px;
}
.trade-card-text{
  font-size:0.82rem;color:rgba(255,255,255,0.45);
  line-height:1.75;
}

/* Benefits */
.trade-benefits{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:2px;margin-bottom:40px;
}
.trade-benefit{
  display:flex;align-items:flex-start;gap:14px;
  padding:22px 24px;
  background:rgba(255,255,255,0.03);
  border:0.5px solid rgba(255,255,255,0.07);
}
.trade-benefit-icon{
  width:34px;height:34px;flex-shrink:0;
  border:0.5px solid rgba(164,188,0,0.35);
  display:flex;align-items:center;justify-content:center;
}
.trade-benefit-icon svg{width:15px;height:15px;}
.trade-benefit-title{
  display:block;
  font-family:'DM Sans',sans-serif;
  font-size:0.82rem;font-weight:500;
  color:#fff;margin-bottom:4px;
}
.trade-benefit-text{
  font-size:0.75rem;color:rgba(255,255,255,0.45);
  line-height:1.65;
}

/* CTA */
.trade-cta{
  display:flex;align-items:center;justify-content:space-between;
  padding:32px 36px;
  border:0.5px solid rgba(164,188,0,0.3);
  background:rgba(255,255,255,0.03);
}
.trade-cta-h3{
  font-family:'Cormorant Garamond',serif;
  font-size:1.4rem;font-weight:600;color:#fff;
  margin-bottom:6px;
}
.trade-cta-sub{font-size:0.78rem;color:rgba(255,255,255,0.45);}

/* Mobile */
@media(max-width:900px){
  .trade-section{padding:80px 40px;}
  .trade-cards{grid-template-columns:1fr;}
  .trade-benefits{grid-template-columns:repeat(2,1fr);}
  .trade-cta{flex-direction:column;gap:24px;text-align:center;}
}
@media(max-width:640px){
  .trade-section{padding:64px 24px;}
  .trade-benefits{grid-template-columns:1fr;}
}

/* ─── TRADE SECTION — темний фон без фото ─── */
.trade-bg{
  background:#1A1916 !important;
}
.trade-bg::after{
  display:none !important;
}