/* G Perks Tiling Services — bespoke build, May 2026 */

:root{
  --ink:#16181c;
  --ink-2:#3c424b;
  --teal:#0f5257;
  --teal-deep:#0a3b3f;
  --teal-bright:#1a8388;
  --paper:#f7f6f2;
  --sand:#ece7dc;
  --line:#ddd7c9;
  --white:#ffffff;
  --shadow:0 18px 50px -22px rgba(20,28,30,.45);
  --maxw:1240px;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  color:var(--ink);
  background:var(--paper);
  font-size:16px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{
  font-family:'Fraunces','Georgia',serif;
  font-weight:600;
  line-height:1.12;
  letter-spacing:-.01em;
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Inter',sans-serif;font-weight:600;font-size:.97rem;
  padding:16px 28px;border:0;cursor:pointer;
  border-radius:3px;transition:.2s;white-space:nowrap;
}
.btn-primary{background:var(--teal);color:#fff;}
.btn-primary:hover{background:var(--teal-bright);}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid rgba(20,24,28,.28);}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal);}
.btn-light{background:#fff;color:var(--teal-deep);}
.btn-light:hover{background:var(--sand);}
.btn-outline-light{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.55);}
.btn-outline-light:hover{background:rgba(255,255,255,.12);}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(247,246,242,.97);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.header-inner{
  display:flex;align-items:stretch;justify-content:space-between;
  max-width:var(--maxw);margin:0 auto;padding-left:28px;
  min-height:84px;
}
.brand{display:flex;align-items:center;gap:13px;padding:14px 0;}
.brand-mark{
  width:46px;height:46px;flex:none;border-radius:4px;
  background:var(--teal);position:relative;overflow:hidden;
}
.brand-mark::before,.brand-mark::after{
  content:"";position:absolute;background:rgba(255,255,255,.92);
}
.brand-mark::before{width:16px;height:16px;top:7px;left:7px;}
.brand-mark::after{width:16px;height:16px;bottom:7px;right:7px;}
.brand-mark span{
  position:absolute;width:16px;height:16px;background:var(--teal-bright);
  top:7px;right:7px;
}
.brand-mark i{
  position:absolute;width:16px;height:16px;background:var(--teal-bright);
  bottom:7px;left:7px;
}
.brand-text{display:flex;flex-direction:column;line-height:1;}
.brand-name{
  font-family:'Fraunces',serif;font-weight:600;font-size:1.34rem;
  color:var(--ink);letter-spacing:-.02em;
}
.brand-sub{
  font-size:.64rem;font-weight:600;letter-spacing:.22em;
  text-transform:uppercase;color:var(--teal);margin-top:4px;
}
.nav-wrap{display:flex;align-items:stretch;}
.nav-links{display:flex;align-items:center;gap:4px;list-style:none;}
.nav-links a{
  position:relative;padding:10px 16px;font-weight:500;font-size:.96rem;
  color:var(--ink-2);transition:color .18s;
}
.nav-links a::after{
  content:"";position:absolute;left:16px;right:16px;bottom:2px;height:2px;
  background:var(--teal);transform:scaleX(0);transform-origin:left;
  transition:transform .22s;
}
.nav-links a:hover,.nav-links a.active{color:var(--ink);}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1);}
.nav-phone{
  display:flex;flex-direction:column;justify-content:center;
  background:var(--teal);color:#fff;padding:0 30px;align-self:stretch;
  transition:background .2s;
}
.nav-phone:hover{background:var(--teal-deep);}
.nav-phone .np-label{
  font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;
  opacity:.8;font-weight:600;
}
.nav-phone .np-num{font-weight:700;font-size:1.16rem;white-space:nowrap;}
.nav-toggle{display:none;}

/* ---------- hero ---------- */
.hero{position:relative;background:var(--ink);overflow:hidden;}
.hero-img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;opacity:.72;
}
.hero::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(105deg,rgba(10,30,32,.92) 0%,rgba(10,30,32,.55) 46%,rgba(10,30,32,.15) 100%);
}
.hero-inner{
  position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;
  padding:96px 28px 104px;
}
.hero-card{max-width:660px;}
.kicker{
  display:inline-flex;align-items:center;gap:9px;
  font-size:.74rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
}
.kicker::before{content:"";width:13px;height:13px;background:var(--teal-bright);flex:none;}
.hero .kicker{color:#9fd6d7;}
.hero h1{
  color:#fff;font-size:clamp(2.5rem,5.4vw,4.1rem);margin:22px 0 18px;
}
.hero h1 em{font-style:italic;color:#7fcccd;}
.hero p{
  color:rgba(255,255,255,.86);font-size:1.12rem;max-width:540px;margin-bottom:32px;
}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;}
.est-stamp{
  position:absolute;z-index:3;right:46px;bottom:46px;
  width:130px;height:130px;border-radius:50%;
  border:1.5px solid rgba(255,255,255,.4);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;color:#fff;
}
.est-stamp .es-since{font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;opacity:.75;}
.est-stamp .es-year{font-family:'Fraunces',serif;font-size:2.3rem;line-height:1;margin:3px 0;}
.est-stamp .es-tag{font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;opacity:.75;}

/* ---------- trust strip ---------- */
.trust{background:var(--ink);border-top:1px solid rgba(255,255,255,.08);}
.trust-inner{
  display:flex;flex-wrap:wrap;max-width:var(--maxw);margin:0 auto;
}
.trust-item{
  flex:1 1 220px;display:flex;align-items:center;gap:13px;
  padding:22px 28px;color:#e8e6df;
  border-right:1px solid rgba(255,255,255,.08);
}
.trust-item:last-child{border-right:0;}
.trust-item svg{width:24px;height:24px;flex:none;stroke:var(--teal-bright);}
.trust-item b{font-weight:600;font-size:.95rem;color:#fff;display:block;}
.trust-item span{font-size:.8rem;color:#9aa3a3;}

/* ---------- section frame ---------- */
.section{padding:96px 0;}
.section.alt{background:var(--sand);}
.sec-head{max-width:680px;margin-bottom:52px;}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.sec-head.center .kicker{justify-content:center;}
.sec-head .kicker{color:var(--teal);}
.sec-head h2{font-size:clamp(2rem,3.8vw,3rem);margin:18px 0 14px;}
.sec-head p{color:var(--ink-2);font-size:1.05rem;}

/* ---------- stats ---------- */
.stats{background:var(--teal);color:#fff;}
.stats-inner{
  display:grid;grid-template-columns:repeat(4,1fr);
  max-width:var(--maxw);margin:0 auto;
}
.stat{padding:54px 28px;text-align:center;border-right:1px solid rgba(255,255,255,.15);}
.stat:last-child{border-right:0;}
.stat .num{font-family:'Fraunces',serif;font-size:clamp(2.6rem,4.4vw,3.7rem);line-height:1;}
.stat .lbl{
  margin-top:10px;font-size:.82rem;letter-spacing:.06em;
  text-transform:uppercase;color:#bfe0e1;font-weight:500;
}

/* ---------- about ---------- */
.about-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:64px;align-items:center;}
.about-copy p{color:var(--ink-2);margin-bottom:18px;}
.about-copy p.lead{
  font-family:'Fraunces',serif;font-size:1.4rem;color:var(--ink);
  line-height:1.4;margin-bottom:22px;
}
.about-sign{
  margin-top:26px;padding-top:22px;border-top:1px solid var(--line);
  display:flex;align-items:center;gap:14px;
}
.about-sign .sig{font-family:'Fraunces',serif;font-style:italic;font-size:1.5rem;color:var(--teal);}
.about-sign .role{font-size:.82rem;color:var(--ink-2);}
.about-media{position:relative;}
.about-media img{
  width:100%;height:520px;object-fit:cover;border-radius:4px;box-shadow:var(--shadow);
}
.about-media .badge{
  position:absolute;left:-26px;bottom:-26px;background:var(--ink);color:#fff;
  padding:24px 28px;border-radius:4px;max-width:220px;
}
.about-media .badge .bn{font-family:'Fraunces',serif;font-size:1.9rem;line-height:1;}
.about-media .badge .bt{font-size:.8rem;color:#b9c0c0;margin-top:6px;}

/* ---------- services ---------- */
.services-list{display:flex;flex-direction:column;gap:30px;}
.service-row{
  display:grid;grid-template-columns:0.85fr 1.15fr;gap:0;
  background:#fff;border:1px solid var(--line);border-radius:5px;overflow:hidden;
}
.service-row:nth-child(even){grid-template-columns:1.15fr 0.85fr;}
.service-row:nth-child(even) .sr-media{order:2;}
.service-row:nth-child(even) .sr-body{order:1;}
.sr-media{overflow:hidden;min-height:300px;}
.sr-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s;}
.service-row:hover .sr-media img{transform:scale(1.05);}
.sr-body{padding:46px 48px;display:flex;flex-direction:column;justify-content:center;}
.sr-index{
  font-family:'Fraunces',serif;font-size:.95rem;color:var(--teal);
  letter-spacing:.05em;margin-bottom:14px;
}
.sr-body h3{font-size:1.7rem;margin-bottom:12px;}
.sr-body p{color:var(--ink-2);font-size:1rem;margin-bottom:18px;}
.sr-tags{display:flex;flex-wrap:wrap;gap:8px;}
.sr-tags span{
  font-size:.76rem;font-weight:600;letter-spacing:.04em;
  background:var(--sand);color:var(--teal-deep);padding:6px 12px;border-radius:3px;
}
.surfaces{
  margin-top:46px;background:var(--ink);color:#fff;border-radius:5px;
  padding:38px 44px;display:flex;flex-wrap:wrap;align-items:center;
  justify-content:space-between;gap:24px;
}
.surfaces .sf-lead{font-family:'Fraunces',serif;font-size:1.45rem;max-width:330px;}
.surfaces .sf-items{display:flex;flex-wrap:wrap;gap:30px;}
.surfaces .sf-items div{text-align:center;}
.surfaces .sf-items .sfn{font-family:'Fraunces',serif;font-size:1.2rem;color:#7fcccd;}
.surfaces .sf-items .sfd{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:#9aa3a3;}

/* ---------- gallery ---------- */
.gallery-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:8px;
}
.gallery-grid.preview{grid-template-columns:repeat(4,1fr);}
.gal-item{
  position:relative;overflow:hidden;cursor:pointer;border:0;padding:0;
  background:var(--ink);aspect-ratio:1/1;
}
.gal-item img{
  width:100%;height:100%;object-fit:cover;transition:transform .55s,opacity .3s;
}
.gal-item:hover img{transform:scale(1.07);opacity:.85;}
.gal-item::after{
  content:"";position:absolute;inset:0;
  border:0 solid var(--teal-bright);transition:border-width .18s;
}
.gal-item:hover::after{border-width:4px;}
.gal-tall{grid-row:span 2;aspect-ratio:auto;}
.gallery-cta{text-align:center;margin-top:42px;}

/* ---------- why choose ---------- */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:5px;overflow:hidden;}
.why-card{background:var(--paper);padding:38px 32px;}
.section.alt .why-card{background:var(--sand);}
.why-card .wc-ico{
  width:46px;height:46px;border-radius:4px;background:var(--teal);
  display:flex;align-items:center;justify-content:center;margin-bottom:18px;
}
.why-card .wc-ico svg{width:23px;height:23px;stroke:#fff;}
.why-card h3{font-size:1.18rem;margin-bottom:8px;}
.why-card p{color:var(--ink-2);font-size:.95rem;}

/* ---------- testimonials ---------- */
.tst-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.tst-card{
  background:#fff;border:1px solid var(--line);border-radius:5px;
  padding:34px 32px;display:flex;flex-direction:column;
}
.section.alt .tst-card{background:var(--paper);}
.tst-stars{color:#d99b3c;letter-spacing:3px;font-size:.95rem;margin-bottom:14px;}
.tst-quote{
  font-family:'Fraunces',serif;font-size:1.08rem;line-height:1.5;
  color:var(--ink);margin-bottom:20px;flex:1;
}
.tst-by{display:flex;align-items:center;gap:13px;}
.tst-av{
  width:44px;height:44px;border-radius:50%;background:var(--teal);
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-weight:600;font-size:.95rem;flex:none;
}
.tst-by .tn{font-weight:600;font-size:.95rem;}
.tst-by .tl{font-size:.82rem;color:var(--ink-2);}

/* ---------- cta band ---------- */
.cta-band{
  background:var(--teal);color:#fff;position:relative;overflow:hidden;
}
.cta-band::before{
  content:"";position:absolute;right:-60px;top:-60px;width:280px;height:280px;
  background:repeating-linear-gradient(45deg,rgba(255,255,255,.06) 0 18px,transparent 18px 36px);
}
.cta-inner{
  position:relative;max-width:var(--maxw);margin:0 auto;padding:78px 28px;
  display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:30px;
}
.cta-inner h2{font-size:clamp(1.9rem,3.6vw,2.7rem);max-width:560px;}
.cta-inner h2 em{font-style:italic;color:#9fd6d7;}
.cta-actions{display:flex;flex-direction:column;gap:12px;}
.cta-actions .cta-phone{font-family:'Fraunces',serif;font-size:1.7rem;}
.cta-actions .cta-phone span{font-size:.8rem;font-family:'Inter';letter-spacing:.12em;
  text-transform:uppercase;color:#9fd6d7;display:block;margin-bottom:2px;}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:start;}
.contact-detail{display:flex;flex-direction:column;gap:4px;}
.cd-row{
  display:flex;gap:16px;padding:20px 0;border-bottom:1px solid var(--line);
}
.cd-row:first-of-type{padding-top:0;}
.cd-ico{
  width:44px;height:44px;flex:none;border-radius:4px;background:var(--sand);
  display:flex;align-items:center;justify-content:center;
}
.cd-ico svg{width:21px;height:21px;stroke:var(--teal);}
.cd-row .cd-l{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-2);font-weight:600;}
.cd-row .cd-v{font-size:1.06rem;font-weight:600;}
.cd-row .cd-v a:hover{color:var(--teal);}
.contact-form{
  background:#fff;border:1px solid var(--line);border-radius:5px;padding:38px;
}
.contact-form h3{font-size:1.4rem;margin-bottom:6px;}
.contact-form .cf-sub{color:var(--ink-2);font-size:.92rem;margin-bottom:24px;}
.field{margin-bottom:18px;}
.field label{display:block;font-size:.8rem;font-weight:600;
  letter-spacing:.05em;text-transform:uppercase;margin-bottom:7px;color:var(--ink-2);}
.field input,.field textarea{
  width:100%;font-family:'Inter',sans-serif;font-size:1rem;
  padding:13px 15px;border:1.5px solid var(--line);border-radius:3px;
  background:var(--paper);color:var(--ink);
}
.field input:focus,.field textarea:focus{outline:0;border-color:var(--teal);background:#fff;}
.field textarea{resize:vertical;min-height:130px;}
.map-embed{margin-top:14px;border-radius:5px;overflow:hidden;border:1px solid var(--line);}
.map-embed iframe{width:100%;height:340px;border:0;display:block;}

/* ---------- footer ---------- */
.site-footer{background:var(--ink);color:#c5cccc;padding:64px 0 30px;}
.footer-top{
  display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px;
  padding-bottom:42px;border-bottom:1px solid rgba(255,255,255,.1);
}
.footer-brand .brand-name{color:#fff;}
.footer-brand p{margin-top:16px;font-size:.92rem;color:#9aa3a3;max-width:330px;}
.footer-col h4{font-family:'Inter',sans-serif;font-size:.78rem;letter-spacing:.16em;
  text-transform:uppercase;color:#7fcccd;margin-bottom:16px;font-weight:700;}
.footer-col a,.footer-col p{display:block;font-size:.94rem;color:#c5cccc;
  margin-bottom:9px;}
.footer-col a:hover{color:#fff;}
.footer-bottom{
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;
  padding-top:24px;font-size:.83rem;color:#7e8787;
}

/* ---------- page hero (sub pages) ---------- */
.page-hero{background:var(--ink);color:#fff;padding:74px 0 66px;position:relative;overflow:hidden;}
.page-hero::before{
  content:"";position:absolute;right:-40px;bottom:-40px;width:230px;height:230px;
  background:repeating-linear-gradient(45deg,rgba(127,204,205,.09) 0 16px,transparent 16px 32px);
}
.page-hero .kicker{color:#7fcccd;}
.page-hero h1{font-size:clamp(2.3rem,4.6vw,3.4rem);margin:18px 0 12px;}
.page-hero p{color:rgba(255,255,255,.8);max-width:560px;}
.crumb{font-size:.85rem;color:#7e8787;margin-top:16px;}
.crumb a:hover{color:#fff;}

/* ---------- lightbox ---------- */
.lightbox{
  position:fixed;inset:0;z-index:200;background:rgba(12,16,17,.94);
  display:none;align-items:center;justify-content:center;
}
.lightbox.open{display:flex;}
.lightbox img{max-width:90vw;max-height:84vh;object-fit:contain;box-shadow:0 30px 80px rgba(0,0,0,.6);}
.lb-btn{
  position:absolute;background:rgba(255,255,255,.1);border:0;color:#fff;
  width:54px;height:54px;font-size:1.6rem;cursor:pointer;border-radius:3px;
  display:flex;align-items:center;justify-content:center;transition:background .15s;
}
.lb-btn:hover{background:var(--teal);}
.lb-prev{left:24px;top:50%;transform:translateY(-50%);}
.lb-next{right:24px;top:50%;transform:translateY(-50%);}
.lb-close{right:24px;top:24px;}

/* ---------- testimonials full ---------- */
.tst-masonry{columns:3;column-gap:24px;}
.tst-masonry .tst-card{break-inside:avoid;margin-bottom:24px;display:block;}

/* ---------- responsive ---------- */
@media(max-width:1080px){
  .nav-links{gap:0;}
  .nav-links a{padding:10px 11px;font-size:.9rem;}
  .nav-phone{padding:0 20px;}
  .about-grid,.contact-grid{grid-template-columns:1fr;gap:40px;}
  .about-media .badge{left:18px;}
  .why-grid,.tst-grid,.stats-inner{grid-template-columns:repeat(2,1fr);}
  .tst-masonry{columns:2;}
}
@media(max-width:860px){
  .nav-toggle{
    display:flex;align-items:center;justify-content:center;
    width:50px;background:var(--teal);border:0;cursor:pointer;align-self:stretch;
  }
  .nav-toggle span{position:relative;width:22px;height:2px;background:#fff;display:block;}
  .nav-toggle span::before,.nav-toggle span::after{
    content:"";position:absolute;left:0;width:22px;height:2px;background:#fff;
  }
  .nav-toggle span::before{top:-7px;}
  .nav-toggle span::after{top:7px;}
  .nav-wrap{
    position:fixed;inset:84px 0 auto 0;background:var(--paper);
    flex-direction:column;border-bottom:1px solid var(--line);
    max-height:0;overflow:hidden;transition:max-height .3s;
  }
  .nav-wrap.open{max-height:520px;}
  .nav-links{flex-direction:column;width:100%;padding:8px 0;}
  .nav-links a{width:100%;padding:15px 28px;font-size:1rem;}
  .nav-links a::after{display:none;}
  .nav-phone{padding:20px 28px;width:100%;}
  .header-inner{position:relative;}
  .service-row,.service-row:nth-child(even){grid-template-columns:1fr;}
  .service-row .sr-media,.service-row .sr-body,
  .service-row:nth-child(even) .sr-media,.service-row:nth-child(even) .sr-body{order:0;}
  .sr-media{min-height:230px;}
  .gallery-grid,.gallery-grid.preview{grid-template-columns:repeat(2,1fr);}
  .gal-tall{grid-row:span 1;}
  .footer-top{grid-template-columns:1fr;gap:32px;}
  .est-stamp{display:none;}
}
@media(max-width:540px){
  .wrap{padding:0 20px;}
  .section{padding:64px 0;}
  .hero-inner{padding:64px 20px 72px;}
  .stats-inner,.why-grid,.tst-grid{grid-template-columns:1fr;}
  .tst-masonry{columns:1;}
  .sr-body{padding:32px 26px;}
  .cta-inner{padding:54px 20px;}
  .surfaces{flex-direction:column;align-items:flex-start;}
  .contact-form{padding:26px;}
}
