@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400;1,600&family=Barlow+Condensed:wght@400;600;700;800;900&family=Barlow:wght@300;400;500;600&display=swap');

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

:root{
  --navy:#0D1B2A;
  --navy-mid:#162233;
  --navy-light:#1E2E42;
  --coral:#FF5C38;
  --coral-light:#FF7A5C;
  --coral-pale:#FFF1EE;
  --mint:#00C2A0;
  --mint-light:#E6FAF6;
  --cream:#FDFAF5;
  --warm:#F5EFE4;
  --offwhite:#FAF8F5;
  --slate:#4A5C6E;
  --muted:#7B8C9A;
  --border:#E2DDD5;
  --white:#FFFFFF;
  --fs-giant:clamp(52px,7vw,96px);
  --fs-hero:clamp(38px,5vw,68px);
  --fs-h2:clamp(28px,3.5vw,46px);
  --fs-h3:clamp(20px,2vw,26px);
}

html{scroll-behavior:smooth}
body{font-family:'Barlow',sans-serif;background:var(--offwhite);color:var(--navy);overflow-x:hidden;cursor:none}

/* CUSTOM CURSOR */
.cursor{position:fixed;width:12px;height:12px;background:var(--coral);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:transform 0.15s,width 0.2s,height 0.2s;mix-blend-mode:multiply}
.cursor-ring{position:fixed;width:36px;height:36px;border:1.5px solid var(--coral);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:left 0.08s,top 0.08s,width 0.2s,height 0.2s;opacity:0.5}
body:hover .cursor{opacity:1}

a,button{cursor:none}
h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;line-height:1.1}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  padding:0 40px;
  display:flex;align-items:center;justify-content:space-between;
  height:72px;
  transition:background 0.3s,box-shadow 0.3s;
}
nav.scrolled{background:rgba(13,27,42,0.97);backdrop-filter:blur(16px);box-shadow:0 2px 24px rgba(0,0,0,0.3)}

/* LOGO */
.logo{display:flex;align-items:center;gap:14px;text-decoration:none}
.logo-mark{width:52px;height:52px;flex-shrink:0}
.logo-text{display:flex;flex-direction:column;line-height:1;gap:1px}
.logo-line1{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:16px;color:rgba(255,255,255,0.7);letter-spacing:0.5px}
.logo-line2{font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:20px;color:white;letter-spacing:2px;text-transform:uppercase}
.logo-line2 span{color:var(--coral)}

.nav-links{display:flex;align-items:center;gap:4px;list-style:none}
.nav-links a{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.65);padding:8px 14px;border-radius:6px;transition:all 0.2s}
.nav-links a:hover,.nav-links a.active{color:white}
.nav-cta-pill{background:var(--coral)!important;color:white!important;border-radius:100px!important;padding:9px 22px!important;transition:all 0.2s!important}
.nav-cta-pill:hover{background:var(--coral-light)!important;transform:translateY(-1px)}

.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:none;padding:6px}
.hamburger span{display:block;width:22px;height:2px;background:white;border-radius:2px;transition:all 0.3s}

/* ── HOME HERO ── */
.home-hero{
  position:relative;min-height:100vh;
  background:var(--navy);
  display:grid;grid-template-columns:55% 45%;
  overflow:hidden;
}
.home-hero-left{
  position:relative;z-index:2;
  display:flex;flex-direction:column;justify-content:center;
  padding:120px 0 80px 60px;
}
.home-hero-right{
  position:relative;overflow:hidden;
}
.home-hero-right::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,var(--navy) 0%,transparent 40%);
  z-index:1;
}
.home-hero-right img{width:100%;height:100%;object-fit:cover;opacity:0.85}

.hero-tag{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;
  letter-spacing:3px;text-transform:uppercase;color:var(--coral);
  margin-bottom:32px;
}
.hero-tag::before{content:'';width:32px;height:2px;background:var(--coral)}

.home-hero h1{
  font-size:var(--fs-giant);font-weight:300;color:white;
  line-height:1.0;margin-bottom:12px;
}
.home-hero h1 em{font-style:italic;color:var(--coral)}
.home-hero h1 strong{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-style:normal;
  display:block;letter-spacing:-1px;
}

.hero-sub{
  font-size:17px;font-weight:300;color:rgba(255,255,255,0.65);
  line-height:1.75;max-width:480px;margin:28px 0 44px;
}

.btn-coral{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--coral);color:white;
  font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;
  padding:16px 36px;border-radius:4px;border:none;
  transition:all 0.25s;box-shadow:0 8px 32px rgba(255,92,56,0.35);
  text-decoration:none;
}
.btn-coral:hover{background:var(--coral-light);transform:translateY(-2px);box-shadow:0 14px 40px rgba(255,92,56,0.45)}

.btn-ghost{
  display:inline-flex;align-items:center;gap:10px;
  background:transparent;color:white;
  font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;
  padding:15px 36px;border-radius:4px;
  border:1.5px solid rgba(255,255,255,0.25);
  transition:all 0.25s;text-decoration:none;
}
.btn-ghost:hover{border-color:white;background:rgba(255,255,255,0.07)}

.hero-scroll{
  position:absolute;bottom:36px;left:60px;
  display:flex;align-items:center;gap:12px;
  font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;
  letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.3);
}
.hero-scroll::after{content:'';width:48px;height:1px;background:rgba(255,255,255,0.2)}

.hero-stat-strip{
  position:absolute;bottom:0;right:0;left:55%;z-index:3;
  background:var(--coral);
  display:flex;
  padding:20px 32px;gap:40px;
}
.hero-stat strong{
  display:block;font-family:'Barlow Condensed',sans-serif;
  font-size:28px;font-weight:900;color:white;line-height:1;
}
.hero-stat span{font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.75)}

/* ── MARQUEE STRIP ── */
.marquee-strip{
  background:var(--navy);border-top:1px solid rgba(255,255,255,0.07);
  padding:18px 0;overflow:hidden;white-space:nowrap;
}
.marquee-track{display:inline-flex;animation:marquee 24s linear infinite;gap:0}
.marquee-item{
  font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;
  letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.3);
  padding:0 32px;
}
.marquee-item.accent{color:var(--coral)}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ── ANGLED DIVIDER ── */
.angle-down{
  width:100%;overflow:hidden;line-height:0;
}
.angle-down svg{display:block;width:100%}

/* ── HOW IT WORKS (diagonal layout) ── */
.hiw{background:var(--cream);padding:100px 0 0;position:relative;overflow:hidden}
.hiw-inner{max-width:1300px;margin:0 auto;padding:0 60px}

.hiw-header{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end;
  margin-bottom:80px;
}
.hiw-label{
  font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;
  letter-spacing:3px;text-transform:uppercase;color:var(--coral);
  margin-bottom:16px;display:block;
}
.hiw-header h2{font-size:var(--fs-h2);font-weight:300;line-height:1.1}
.hiw-header h2 strong{font-weight:600;display:block}
.hiw-header p{font-size:16px;color:var(--slate);line-height:1.8;align-self:end;padding-bottom:8px}

.hiw-steps{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--border);
}
.hiw-step{
  padding:48px 36px;border-right:1px solid var(--border);
  position:relative;transition:background 0.3s;
}
.hiw-step:last-child{border-right:none}
.hiw-step:hover{background:var(--white)}
.step-num{
  font-family:'Barlow Condensed',sans-serif;font-size:80px;font-weight:900;
  color:rgba(13,27,42,0.06);line-height:1;margin-bottom:24px;
}
.step-dot{
  width:40px;height:40px;border-radius:50%;background:var(--navy);
  display:flex;align-items:center;justify-content:center;margin-bottom:20px;
}
.step-dot svg{width:18px;height:18px;stroke:white;fill:none;stroke-width:2}
.hiw-step h3{font-size:20px;font-weight:600;margin-bottom:12px;color:var(--navy)}
.hiw-step p{font-size:14px;color:var(--slate);line-height:1.8}
.hiw-step.featured{background:var(--navy)}
.hiw-step.featured .step-num{color:rgba(255,255,255,0.06)}
.hiw-step.featured .step-dot{background:var(--coral)}
.hiw-step.featured h3{color:white}
.hiw-step.featured p{color:rgba(255,255,255,0.6)}

/* ── ABOUT DIAGONAL ── */
.about-diag{
  background:var(--offwhite);
  padding:0;overflow:hidden;
}
.about-diag-inner{
  display:grid;grid-template-columns:1fr 1fr;min-height:640px;
}
.about-diag-img{
  position:relative;overflow:hidden;
  clip-path:polygon(0 0,100% 0,88% 100%,0 100%);
}
.about-diag-img img{width:100%;height:100%;object-fit:cover}
.about-diag-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(13,27,42,0.3) 0%,transparent 60%);
}
.about-diag-content{
  padding:100px 80px 100px 60px;
  display:flex;flex-direction:column;justify-content:center;
}
.about-diag-content h2{font-size:var(--fs-h2);font-weight:300;margin-bottom:24px;line-height:1.1}
.about-diag-content h2 em{font-style:italic;color:var(--coral)}
.about-diag-content p{font-size:16px;color:var(--slate);line-height:1.85;margin-bottom:16px}

.pill-tags{display:flex;flex-wrap:wrap;gap:10px;margin:28px 0}
.pill{
  font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;
  padding:8px 18px;border-radius:100px;
  border:1.5px solid var(--navy);color:var(--navy);
  transition:all 0.2s;
}
.pill:hover,.pill.active{background:var(--navy);color:white}

/* ── SERVICES MASONRY-ESQUE ── */
.services{background:var(--navy);padding:100px 0;overflow:hidden}
.services-inner{max-width:1300px;margin:0 auto;padding:0 60px}
.services-header{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-bottom:64px;
}
.services-header h2{font-size:var(--fs-h2);font-weight:300;color:white;max-width:480px;line-height:1.1}
.services-header h2 em{font-style:italic;color:var(--coral)}
.services-header p{font-size:15px;color:rgba(255,255,255,0.5);max-width:300px;line-height:1.7;text-align:right}

.services-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr;
  grid-template-rows:auto auto;
  gap:20px;
}
.svc-card{
  background:var(--navy-mid);border:1px solid rgba(255,255,255,0.07);
  border-radius:12px;padding:40px 36px;
  transition:all 0.35s;position:relative;overflow:hidden;
}
.svc-card::before{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:var(--coral);transform:scaleX(0);transform-origin:left;
  transition:transform 0.35s;
}
.svc-card:hover{background:var(--navy-light);transform:translateY(-4px);border-color:rgba(255,92,56,0.2)}
.svc-card:hover::before{transform:scaleX(1)}
.svc-card.tall{grid-row:span 2;display:flex;flex-direction:column;justify-content:space-between}
.svc-card.featured{background:var(--coral);border-color:var(--coral)}
.svc-card.featured::before{background:white}

.svc-num{
  font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;
  letter-spacing:3px;color:rgba(255,255,255,0.25);margin-bottom:40px;display:block;
}
.svc-card.featured .svc-num{color:rgba(255,255,255,0.5)}
.svc-icon{
  width:48px;height:48px;border-radius:12px;background:rgba(255,255,255,0.07);
  display:flex;align-items:center;justify-content:center;margin-bottom:20px;
}
.svc-icon svg{width:22px;height:22px;stroke:rgba(255,255,255,0.7);fill:none;stroke-width:2}
.svc-card.featured .svc-icon{background:rgba(255,255,255,0.2)}
.svc-card.featured .svc-icon svg{stroke:white}
.svc-card h3{font-size:20px;font-weight:600;color:white;margin-bottom:12px}
.svc-card p{font-size:14px;color:rgba(255,255,255,0.5);line-height:1.8}
.svc-card.featured p{color:rgba(255,255,255,0.8)}
.svc-arrow{
  display:inline-flex;align-items:center;gap:8px;margin-top:24px;
  font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;color:var(--coral);
}
.svc-card.featured .svc-arrow{color:white}

/* ── TESTIMONIALS ── */
.testimonials{background:var(--warm);padding:100px 0;overflow:hidden}
.testimonials-inner{max-width:1300px;margin:0 auto;padding:0 60px}
.testimonials-label{
  font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;
  letter-spacing:3px;text-transform:uppercase;color:var(--coral);
  margin-bottom:16px;display:block;
}
.testimonials h2{font-size:var(--fs-h2);font-weight:300;margin-bottom:64px;max-width:560px;line-height:1.1}
.testimonials h2 em{font-style:italic}

.testi-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:24px;align-items:start}

.testi-card{
  background:white;border-radius:16px;padding:44px 40px;
  border:1px solid var(--border);
  transition:all 0.3s;
}
.testi-card:hover{transform:translateY(-4px);box-shadow:0 20px 56px rgba(0,0,0,0.08)}
.testi-card.large{padding:56px 48px}
.quote-mark{
  font-family:'Cormorant Garamond',serif;font-size:96px;font-weight:300;
  color:var(--coral);line-height:0.6;margin-bottom:20px;display:block;
}
.testi-text{
  font-family:'Cormorant Garamond',serif;font-size:20px;font-style:italic;
  font-weight:400;line-height:1.7;color:var(--navy);margin-bottom:28px;
}
.testi-card.large .testi-text{font-size:24px}
.testi-author{display:flex;align-items:center;gap:14px}
.testi-avatar{
  width:44px;height:44px;border-radius:50%;
  font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:800;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  letter-spacing:1px;
}
.av-coral{background:var(--coral-pale);color:var(--coral)}
.av-navy{background:var(--navy);color:white}
.av-mint{background:var(--mint-light);color:var(--mint)}
.testi-name{font-size:14px;font-weight:600;color:var(--navy)}
.testi-loc{font-size:12px;color:var(--muted);margin-top:2px;font-family:'Barlow Condensed',sans-serif;letter-spacing:1px;text-transform:uppercase}
.stars{color:var(--coral);font-size:14px;letter-spacing:2px;margin-bottom:16px}

/* ── CTA FULL BLEED ── */
.cta-fullbleed{
  position:relative;min-height:480px;
  display:flex;align-items:center;overflow:hidden;
}
.cta-bg{position:absolute;inset:0}
.cta-bg img{width:100%;height:100%;object-fit:cover}
.cta-bg::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(100deg,rgba(13,27,42,0.95) 45%,rgba(13,27,42,0.5) 100%);
}
.cta-content{
  position:relative;z-index:1;
  max-width:1300px;margin:0 auto;padding:80px 60px;
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
  width:100%;
}
.cta-content h2{font-size:var(--fs-h2);font-weight:300;color:white;line-height:1.1}
.cta-content h2 em{font-style:italic;color:var(--coral)}
.cta-right p{font-size:16px;color:rgba(255,255,255,0.65);line-height:1.8;margin-bottom:32px}
.btn-group{display:flex;gap:16px;flex-wrap:wrap}

/* ── FOOTER ── */
footer{background:var(--navy);padding:80px 0 0}
.footer-inner{max-width:1300px;margin:0 auto;padding:0 60px}
.footer-top{
  display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:60px;
  padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,0.08);
}
.footer-brand-tag{
  font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;
  font-size:15px;color:rgba(255,255,255,0.4);margin-top:16px;margin-bottom:20px;
  line-height:1.6;max-width:300px;
}
.footer-col h5{
  font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;
  letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.3);
  margin-bottom:20px;
}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col ul li a{
  font-size:14px;color:rgba(255,255,255,0.55);
  transition:color 0.2s;
}
.footer-col ul li a:hover{color:white}
.footer-contact-line{
  display:flex;align-items:flex-start;gap:10px;margin-bottom:14px;
}
.footer-contact-line svg{width:16px;height:16px;stroke:var(--coral);fill:none;stroke-width:2;flex-shrink:0;margin-top:2px}
.footer-contact-line a,.footer-contact-line span{font-size:14px;color:rgba(255,255,255,0.55);line-height:1.6;transition:color 0.2s}
.footer-contact-line a:hover{color:white}
.footer-bottom{
  padding:24px 0;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;
}
.footer-bottom p{font-size:12px;color:rgba(255,255,255,0.3);letter-spacing:0.5px}
.footer-legal{display:flex;gap:24px}
.footer-legal a{font-size:12px;color:rgba(255,255,255,0.3);transition:color 0.2s;letter-spacing:0.5px}
.footer-legal a:hover{color:rgba(255,255,255,0.7)}

/* ── PAGE HEROS (inner pages — each unique) ── */
.ph-split{
  min-height:52vh;display:grid;grid-template-columns:1fr 1fr;
  background:var(--navy);padding-top:72px;overflow:hidden;
}
.ph-split-content{
  padding:80px 60px 80px 60px;
  display:flex;flex-direction:column;justify-content:center;
}
.ph-split-content .ph-label{
  font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;
  letter-spacing:4px;text-transform:uppercase;color:var(--coral);margin-bottom:20px;display:block;
}
.ph-split-content h1{font-size:clamp(32px,4vw,54px);font-weight:300;color:white;line-height:1.1;margin-bottom:16px}
.ph-split-content h1 em{font-style:italic;color:var(--coral)}
.ph-split-content p{font-size:16px;color:rgba(255,255,255,0.55);line-height:1.75;max-width:440px}
.ph-split-img{position:relative;overflow:hidden}
.ph-split-img img{width:100%;height:100%;object-fit:cover;opacity:0.7}
.ph-split-img::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,var(--navy) 0%,transparent 50%);z-index:1;
}

.ph-wide{
  min-height:44vh;background:var(--navy);
  display:flex;align-items:flex-end;
  padding:72px 0 0;overflow:hidden;position:relative;
}
.ph-wide-bg{position:absolute;inset:0}
.ph-wide-bg img{width:100%;height:100%;object-fit:cover;opacity:0.15}
.ph-wide-content{
  max-width:1300px;width:100%;margin:0 auto;padding:80px 60px;
  position:relative;z-index:1;
}
.ph-wide-content .ph-label{
  font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;
  letter-spacing:4px;text-transform:uppercase;color:var(--coral);margin-bottom:20px;display:block;
}
.ph-wide-content h1{font-size:clamp(36px,5vw,64px);font-weight:300;color:white;line-height:1.05;max-width:800px}
.ph-wide-content h1 em{font-style:italic;color:var(--coral-light)}
.ph-wide-content p{font-size:17px;color:rgba(255,255,255,0.55);line-height:1.75;max-width:600px;margin-top:18px}

/* ── SECTIONS ── */
.section{padding:100px 0}
.section-inner{max-width:1300px;margin:0 auto;padding:0 60px}
.section-label{
  font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;
  letter-spacing:4px;text-transform:uppercase;color:var(--coral);
  margin-bottom:18px;display:block;
}
.section-title{font-size:var(--fs-h2);font-weight:300;line-height:1.1;margin-bottom:20px}
.section-title em{font-style:italic;color:var(--coral)}
.section-sub{font-size:16px;color:var(--slate);line-height:1.8;max-width:580px}

/* ── FAQ ── */
.faq-layout{display:grid;grid-template-columns:1fr 2fr;gap:80px;align-items:start}
.faq-sticky{position:sticky;top:100px}
.faq-sticky h2{font-size:var(--fs-h2);font-weight:300;line-height:1.1;margin-bottom:20px}
.faq-sticky p{font-size:15px;color:var(--slate);line-height:1.8}
.faq-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--border)}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;gap:20px;
  padding:24px 0;cursor:none;
  font-size:17px;font-weight:500;color:var(--navy);
  font-family:'Cormorant Garamond',serif;
  user-select:none;
}
.faq-icon{
  width:32px;height:32px;border-radius:50%;border:1.5px solid var(--border);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:all 0.3s;
}
.faq-icon svg{width:12px;height:12px;stroke:var(--navy);fill:none;stroke-width:2.5;transition:transform 0.3s}
.faq-item.open .faq-icon{background:var(--coral);border-color:var(--coral)}
.faq-item.open .faq-icon svg{stroke:white;transform:rotate(45deg)}
.faq-a{
  display:none;padding:0 0 24px;
  font-size:15px;color:var(--slate);line-height:1.85;
}
.faq-item.open .faq-a{display:block}

/* ── CONTACT ── */
.contact-layout{display:grid;grid-template-columns:1fr 1.8fr;gap:80px;align-items:start}
.contact-aside{
  background:var(--navy);border-radius:16px;padding:52px 44px;
  position:sticky;top:100px;
}
.contact-aside h3{
  font-size:28px;font-weight:300;color:white;margin-bottom:16px;
}
.contact-aside p{font-size:14px;color:rgba(255,255,255,0.5);line-height:1.8;margin-bottom:36px}
.cdet{display:flex;gap:14px;align-items:flex-start;margin-bottom:24px}
.cdet-ico{
  width:40px;height:40px;background:rgba(255,255,255,0.07);border-radius:10px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.cdet-ico svg{width:18px;height:18px;stroke:var(--coral);fill:none;stroke-width:2}
.cdet strong{display:block;font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,0.4);margin-bottom:4px;font-family:'Barlow Condensed',sans-serif}
.cdet a,.cdet span{font-size:14px;color:rgba(255,255,255,0.7);line-height:1.6}
.cdet a:hover{color:white}

.form-panel{background:white;border-radius:16px;padding:56px 52px;border:1px solid var(--border)}
.form-title{font-size:32px;font-weight:300;margin-bottom:8px;line-height:1.1}
.form-title em{font-style:italic;color:var(--coral)}
.form-sub{font-size:14px;color:var(--muted);margin-bottom:36px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.fg{margin-bottom:22px}
.fg label{
  display:block;font-family:'Barlow Condensed',sans-serif;
  font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;
  color:var(--slate);margin-bottom:8px;
}
.fg input,.fg select,.fg textarea{
  width:100%;padding:14px 18px;
  border:1.5px solid var(--border);border-radius:8px;
  font-family:'Barlow',sans-serif;font-size:15px;color:var(--navy);
  background:var(--offwhite);outline:none;transition:border-color 0.2s,background 0.2s;
}
.fg input:focus,.fg select:focus,.fg textarea:focus{
  border-color:var(--coral);background:white;
}
.fg textarea{resize:vertical;min-height:120px}

.sms-box{
  background:var(--cream);border-radius:12px;
  padding:28px 30px;margin-bottom:28px;
  border-left:4px solid var(--coral);
}
.sms-box h4{
  font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:800;
  letter-spacing:2px;text-transform:uppercase;color:var(--navy);margin-bottom:18px;
}
.cbwrap{display:flex;gap:12px;align-items:flex-start;margin-bottom:16px}
.cbwrap:last-child{margin-bottom:0}
.cbwrap input[type=checkbox]{
  width:18px;height:18px;min-width:18px;
  border:2px solid var(--border);border-radius:4px;
  appearance:none;background:white;cursor:none;margin-top:2px;
  transition:all 0.15s;position:relative;
}
.cbwrap input[type=checkbox]:checked{background:var(--coral);border-color:var(--coral)}
.cbwrap input[type=checkbox]:checked::after{
  content:'';position:absolute;left:3px;top:0;
  width:8px;height:11px;border:2px solid white;
  border-top:none;border-left:none;transform:rotate(45deg);
}
.cbwrap label{font-size:13px;color:var(--slate);line-height:1.65;cursor:none}
.cbwrap label strong a{color:var(--coral);text-decoration:underline;font-weight:700}

.submit-btn{
  width:100%;background:var(--navy);color:white;
  font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;
  letter-spacing:3px;text-transform:uppercase;
  padding:18px;border-radius:8px;border:none;cursor:none;
  transition:all 0.25s;
}
.submit-btn:hover{background:var(--coral);transform:translateY(-1px);box-shadow:0 8px 28px rgba(255,92,56,0.3)}

.success-msg{
  display:none;background:var(--mint-light);border:1.5px solid var(--mint);
  border-radius:12px;padding:24px 28px;text-align:center;margin-top:20px;
}
.success-msg p{font-size:16px;font-weight:600;color:#00836C}
.success-msg span{font-size:14px;color:var(--slate);display:block;margin-top:6px}

/* ── NOTIFICATIONS PAGE ── */
.notif-layout{max-width:740px;margin:0 auto}
.notif-cards{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:40px}
.notif-card{
  border-radius:12px;padding:28px 26px;
}
.notif-card.card-navy{background:var(--navy);border:1px solid rgba(255,255,255,0.07)}
.notif-card.card-coral{background:var(--coral-pale);border:1px solid rgba(255,92,56,0.15)}
.notif-card-icon{font-size:28px;margin-bottom:12px}
.notif-card h3{font-size:18px;font-weight:600;margin-bottom:10px}
.notif-card.card-navy h3{color:white}
.notif-card.card-coral h3{color:var(--coral)}
.notif-card p{font-size:13px;line-height:1.7}
.notif-card.card-navy p{color:rgba(255,255,255,0.5)}
.notif-card.card-coral p{color:var(--slate)}

.notif-form{background:white;border-radius:16px;padding:52px 48px;border:1px solid var(--border)}

/* ── LEGAL PAGES ── */
.legal-inner{max-width:820px;margin:0 auto}
.legal-inner h2{
  font-size:24px;font-weight:600;
  margin:44px 0 14px;padding-top:8px;
  border-top:1px solid var(--border);
  font-family:'Barlow Condensed',sans-serif;
  letter-spacing:0.5px;text-transform:uppercase;
  color:var(--navy);font-size:14px;letter-spacing:2px;
}
.legal-inner h2:first-of-type{margin-top:0;border-top:none}
.legal-inner p{font-size:15px;color:var(--slate);margin-bottom:16px;line-height:1.85}
.legal-inner ul{padding-left:20px;margin-bottom:18px;display:flex;flex-direction:column;gap:8px}
.legal-inner ul li{font-size:15px;color:var(--slate);line-height:1.7}
.legal-highlight{
  background:var(--navy);color:white;
  border-radius:10px;padding:20px 24px;margin:28px 0;
  font-size:15px;line-height:1.7;font-weight:400;
}
.legal-highlight strong{color:var(--coral)}

/* ── SERVICES PAGE ── */
.svc-page-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:2px;
  background:var(--border);border-radius:16px;overflow:hidden;
}
.svc-page-card{
  background:white;padding:44px 36px;
  transition:all 0.3s;position:relative;
}
.svc-page-card:hover{background:var(--navy);z-index:1}
.svc-page-card:hover h3,.svc-page-card:hover p{color:white}
.svc-page-card:hover .svc-page-card-icon{background:var(--coral)}
.svc-page-card:hover .svc-page-card-icon svg{stroke:white}
.svc-page-card-icon{
  width:52px;height:52px;background:var(--warm);border-radius:14px;
  display:flex;align-items:center;justify-content:center;margin-bottom:20px;
  transition:all 0.3s;
}
.svc-page-card-icon svg{width:24px;height:24px;stroke:var(--navy);fill:none;stroke-width:2;transition:stroke 0.3s}
.svc-page-card h3{font-size:19px;font-weight:600;margin-bottom:12px;transition:color 0.3s;color:var(--navy)}
.svc-page-card p{font-size:14px;color:var(--slate);line-height:1.8;transition:color 0.3s}

/* ── ABOUT PAGE ── */
.values-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:0;border-top:1px solid var(--border);border-left:1px solid var(--border)}
.val-block{
  padding:40px 28px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);
  text-align:center;transition:all 0.3s;
}
.val-block:hover{background:var(--navy)}
.val-block:hover h4{color:white}
.val-block:hover p{color:rgba(255,255,255,0.5)}
.val-block:hover .val-ico svg{stroke:var(--coral)}
.val-ico{width:44px;height:44px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center}
.val-ico svg{width:28px;height:28px;stroke:var(--navy);fill:none;stroke-width:1.5;transition:stroke 0.3s}
.val-block h4{font-size:15px;font-weight:600;margin-bottom:8px;transition:color 0.3s}
.val-block p{font-size:12px;color:var(--muted);line-height:1.7;transition:color 0.3s}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .home-hero{grid-template-columns:60% 40%}
  .hiw-steps{grid-template-columns:1fr 1fr}
  .hiw-step{border-bottom:1px solid var(--border)}
  .services-grid{grid-template-columns:1fr 1fr}
  .svc-card.tall{grid-row:auto}
  .testi-grid{grid-template-columns:1fr 1fr}
  .cta-content{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr;gap:40px}
  .svc-page-grid{grid-template-columns:1fr 1fr}
  .values-strip{grid-template-columns:repeat(3,1fr)}
  .faq-layout{grid-template-columns:1fr}
  .faq-sticky{position:static}
}
@media(max-width:768px){
  nav{padding:0 20px}
  .nav-links{display:none}
  .nav-links.open{
    display:flex;flex-direction:column;
    position:absolute;top:72px;left:0;right:0;
    background:var(--navy);padding:16px 20px;gap:4px;z-index:99;
  }
  .hamburger{display:flex}
  .home-hero{grid-template-columns:1fr;min-height:auto}
  .home-hero-right{height:300px}
  .home-hero-left{padding:100px 24px 60px}
  .hero-stat-strip{left:0;position:relative;grid-column:1}
  .hiw-inner,.services-inner,.testimonials-inner,.cta-content,.footer-inner,.section-inner{padding:0 24px}
  .hiw-header{grid-template-columns:1fr}
  .hiw-steps{grid-template-columns:1fr}
  .about-diag-inner{grid-template-columns:1fr}
  .about-diag-img{clip-path:none;height:320px}
  .about-diag-content{padding:60px 24px}
  .services-grid{grid-template-columns:1fr}
  .services-header{flex-direction:column;align-items:flex-start}
  .services-header p{text-align:left;max-width:none}
  .testi-grid{grid-template-columns:1fr}
  .contact-layout{grid-template-columns:1fr}
  .contact-aside{position:static}
  .form-row{grid-template-columns:1fr}
  .form-panel{padding:36px 24px}
  .ph-split{grid-template-columns:1fr}
  .ph-split-img{height:240px}
  .ph-split-content{padding:80px 24px 48px}
  .ph-wide-content{padding:60px 24px}
  .footer-top{grid-template-columns:1fr}
  .svc-page-grid{grid-template-columns:1fr}
  .values-strip{grid-template-columns:1fr 1fr}
  .notif-cards{grid-template-columns:1fr}
  .notif-form{padding:36px 24px}
}
