/* ============================================================
   KAIREX — Stylesheet | kairex.co.uk design
============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Jost',sans-serif;font-weight:300;background:#fff;color:#222;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%;height:auto}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}

:root{
  --navy:#0b1c36;--navy2:#0d2144;
  --gold:#c8a96e;--gold2:#e0bc7a;
  --cream:#f5f3ee;--mid:#666;--border:#e0ddd7;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Jost',sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
}

/* LAYOUT */
.wrap{max-width:1240px;margin:0 auto;padding:0 44px}
.section{padding:88px 0}
.bg-cream{background:var(--cream)}
.bg-navy{background:var(--navy)}

/* REVEAL */
.sr{opacity:0;transform:translateY(22px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.sr.d1{transition-delay:.1s}.sr.d2{transition-delay:.2s}.sr.d3{transition-delay:.3s}.sr.d4{transition-delay:.4s}
.sr.vis{opacity:1;transform:none}

/* EYEBROW */
.eyebrow{display:inline-flex;align-items:center;gap:12px;font-size:10.5px;font-weight:500;color:var(--gold);letter-spacing:5px;text-transform:uppercase;margin-bottom:14px}
.eyebrow::before{content:'';display:block;width:26px;height:1px;background:var(--gold);flex-shrink:0}
.eyebrow.ctr{justify-content:center}.eyebrow.ctr::before{display:none}

/* HEADINGS */
.h{font-family:var(--serif);font-weight:700;line-height:1.08;letter-spacing:-.02em;color:var(--navy)}
.h.wh{color:#fff}
.h em{font-style:italic;font-weight:300;color:var(--gold)}
.sz1{font-size:clamp(40px,5.5vw,72px)}
.sz2{font-size:clamp(28px,3.2vw,48px)}
.sub{font-size:15.5px;font-weight:300;line-height:1.85;color:var(--mid);max-width:560px;margin-top:14px}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--sans);font-size:11.5px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;padding:16px 32px;cursor:pointer;transition:all .25s ease;white-space:nowrap;border:none}
.btn svg{flex-shrink:0;transition:transform .25s}
.btn:hover svg{transform:translateX(4px)}
.btn-gold{background:var(--gold);color:var(--navy)}
.btn-gold:hover{background:var(--gold2);transform:translateY(-2px);box-shadow:0 8px 28px rgba(200,169,110,.4)}
.btn-outline-wh{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.5)}
.btn-outline-wh:hover{border-color:var(--gold);color:var(--gold)}
.btn-outline{background:transparent;color:var(--navy);border:1.5px solid var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy2);transform:translateY(-2px)}
.btn-sm{padding:10px 22px;font-size:11px}

/* COOKIE */
#ckBanner{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:#fff;border-top:1px solid var(--border);padding:14px 44px;display:flex;align-items:center;gap:20px;flex-wrap:wrap;box-shadow:0 -4px 24px rgba(0,0,0,.08)}
#ckBanner p{font-size:13px;font-weight:300;color:#444;line-height:1.6;flex:1;min-width:220px}
#ckBanner a{color:var(--navy);text-decoration:underline}
.ck-btns{display:flex;gap:10px}
.ck-acc,.ck-ess{padding:9px 20px;font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;border:none;transition:all .2s}
.ck-acc{background:var(--navy);color:#fff}
.ck-acc:hover{background:var(--navy2)}
.ck-ess{background:transparent;color:var(--navy);border:1px solid var(--navy)}
.ck-ess:hover{background:var(--cream)}
#ckBanner.gone{display:none!important}

/* TOPBAR */
.topbar{background:var(--navy);border-bottom:1px solid rgba(200,169,110,.1)}
.topbar-in{max-width:1240px;margin:0 auto;padding:0 44px;display:flex;justify-content:space-between;align-items:center;height:38px}
.tb-l{display:flex;align-items:center;gap:18px}
.tb-l a,.tb-l span{font-size:12px;font-weight:300;color:rgba(255,255,255,.48);display:flex;align-items:center;gap:6px;transition:color .2s}
.tb-l a:hover{color:rgba(255,255,255,.9)}
.tb-sep{color:rgba(255,255,255,.18)!important}
.tb-r{display:flex}
.tb-r a{font-size:12px;font-weight:400;color:rgba(255,255,255,.48);padding:0 16px;height:38px;display:flex;align-items:center;border-left:1px solid rgba(255,255,255,.07);transition:color .2s,background .2s}
.tb-r a:hover{color:#fff}
.tb-cta{background:var(--gold)!important;color:var(--navy)!important;font-weight:600!important}
.tb-cta:hover{background:var(--gold2)!important}

/* HEADER */
.site-header{position:sticky;top:0;z-index:800;background:rgba(255,255,255,.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(0,0,0,.07);transition:box-shadow .3s}
.site-header.up{box-shadow:0 2px 30px rgba(0,0,0,.1)}
.hdr{max-width:1240px;margin:0 auto;padding:0 44px;display:flex;align-items:center;height:78px}
.site-logo{display:flex;align-items:center;gap:14px;margin-right:auto;text-decoration:none;flex-shrink:0}
.logo-img{height:52px;width:auto;object-fit:contain;display:block}
.logo-name{font-family:var(--serif);font-size:24px;font-weight:700;color:var(--navy);letter-spacing:6px;line-height:1}

/* NAV */
.nav-list{display:flex;align-items:stretch;height:78px}
.ni{position:relative}
.ni>a,.ni>button{display:flex;align-items:center;gap:4px;height:78px;padding:0 16px;font-size:13px;font-weight:400;color:#333;letter-spacing:.3px;border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;transition:color .2s,border-color .2s;font-family:var(--sans);white-space:nowrap}
.ni:hover>a,.ni:hover>button,.ni.op>a,.ni.op>button{color:var(--navy);border-bottom-color:var(--gold)}
.nav-arr{font-size:9px;opacity:.5;transition:transform .25s;margin-left:2px}
.ni.op .nav-arr{transform:rotate(180deg)}
.drop{position:absolute;top:100%;left:0;min-width:215px;background:#fff;border:1px solid rgba(0,0,0,.08);border-top:2px solid var(--gold);box-shadow:0 8px 40px rgba(0,0,0,.12);opacity:0;visibility:hidden;transform:translateY(-6px);transition:all .2s ease;z-index:900}
.ni.op .drop{opacity:1;visibility:visible;transform:none}
.drop-lbl{font-size:9.5px;font-weight:600;color:var(--mid);letter-spacing:3px;text-transform:uppercase;padding:12px 20px 4px;display:block}
.drop a{display:flex;padding:10px 20px;font-size:13px;font-weight:300;color:#333;transition:background .15s,color .15s,padding-left .15s}
.drop a:hover{background:var(--cream);color:var(--navy);padding-left:26px}
.nav-ctas{display:flex;gap:10px;margin-left:20px;flex-shrink:0}
.burger{display:none;flex-direction:column;gap:5.5px;padding:8px;cursor:pointer;margin-left:12px;min-width:44px;min-height:44px;align-items:center;justify-content:center}
.burger span{display:block;width:22px;height:1.5px;background:var(--navy);transition:all .3s}
.burger.op span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.op span:nth-child(2){opacity:0}
.burger.op span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* MOBILE NAV */
.mnav{display:none;position:fixed;inset:0;background:var(--navy);z-index:9500;flex-direction:column;overflow-y:auto}
.mnav.op{display:flex}
.mnav-hdr{display:flex;justify-content:space-between;align-items:center;padding:18px 24px;border-bottom:1px solid rgba(255,255,255,.07)}
.mnav-logo{height:46px;width:auto;object-fit:contain}
.mnav-x{color:rgba(255,255,255,.5);font-size:30px;cursor:pointer;padding:8px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;background:none;border:none}
.mnav-links{padding:28px 24px;flex:1}
.mlink{display:block;font-family:var(--serif);font-size:26px;font-weight:600;color:#fff;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.06);transition:color .2s}
.mlink:hover{color:var(--gold)}
.msub{display:block;font-size:13px;font-weight:300;color:rgba(255,255,255,.42);padding:7px 0 7px 14px;border-bottom:1px solid rgba(255,255,255,.03);transition:color .2s}
.msub:hover{color:var(--gold)}
.mnav-foot{padding:24px;border-top:1px solid rgba(255,255,255,.07);display:flex;flex-direction:column;gap:10px}

/* HERO */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;will-change:transform}
.hero-ov{position:absolute;inset:0;background:linear-gradient(105deg,rgba(5,12,28,.88) 0%,rgba(5,12,28,.72) 45%,rgba(5,12,28,.42) 100%)}
.hero::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(to right,transparent,var(--gold) 25%,var(--gold) 75%,transparent);z-index:3}
.hero-content{position:relative;z-index:2;padding:120px 44px 80px;max-width:1240px;margin:0 auto;width:100%}
.hero-tag{display:inline-flex;align-items:center;gap:14px;margin-bottom:24px}
.hero-tag::before{content:'';display:block;width:36px;height:1px;background:var(--gold)}
.hero-tag span{font-size:10.5px;font-weight:500;color:var(--gold);letter-spacing:5px;text-transform:uppercase}
.hero h1{font-family:var(--serif);font-size:clamp(42px,6vw,76px);font-weight:700;color:#fff;line-height:1.06;letter-spacing:-.02em;margin-bottom:24px;max-width:680px}
.hero h1 em{font-style:italic;font-weight:300;color:var(--gold);display:block}
.hero-desc{font-size:16.5px;font-weight:300;color:rgba(255,255,255,.68);line-height:1.85;max-width:580px;margin-bottom:36px}
.hero-ctas{display:flex;flex-direction:column;gap:14px;max-width:320px}
.hero-ctas .btn{justify-content:center;padding:18px 32px;font-size:12px;letter-spacing:3px}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
.hero-tag{animation:fadeUp .8s .05s both}
.hero h1{animation:fadeUp .9s .13s both}
.hero-desc{animation:fadeUp .9s .21s both}
.hero-ctas{animation:fadeUp .9s .29s both}

/* TICKER */
.ticker{background:var(--navy);overflow:hidden;padding:10px 0;border-top:1px solid rgba(200,169,110,.12)}
.ticker-track{display:flex;white-space:nowrap;animation:tickerScroll 44s linear infinite}
.ticker-track:hover{animation-play-state:paused}
.t-item{display:inline-flex;align-items:center;gap:14px;padding:0 44px;border-right:1px solid rgba(255,255,255,.06);flex-shrink:0}
.t-item strong{font-size:11px;font-weight:600;color:var(--gold);letter-spacing:2px;text-transform:uppercase}
.t-item span{font-size:11px;font-weight:300;color:rgba(255,255,255,.38)}
@keyframes tickerScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* SERVICES */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;background:rgba(0,0,0,.1)}
.svc-card{position:relative;height:440px;overflow:hidden;display:block}
.svc-img{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.06);transition:transform .8s ease}
.svc-card:hover .svc-img{transform:scale(1)}
.svc-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(5,12,28,.97) 0%,rgba(5,12,28,.55) 50%,rgba(5,12,28,.18) 100%);transition:background .4s}
.svc-card:hover .svc-ov{background:linear-gradient(to top,rgba(5,12,28,.99) 0%,rgba(5,12,28,.72) 60%,rgba(5,12,28,.28) 100%)}
.svc-body{position:absolute;bottom:0;left:0;right:0;padding:32px 36px}
.svc-n{font-size:10px;font-weight:500;color:var(--gold);letter-spacing:3px;text-transform:uppercase;margin-bottom:8px}
.svc-title{font-family:var(--serif);font-size:26px;font-weight:700;color:#fff;line-height:1.18;margin-bottom:6px}
.svc-desc{font-size:13.5px;font-weight:300;color:rgba(255,255,255,.62);line-height:1.78;max-height:0;overflow:hidden;opacity:0;transition:max-height .55s ease,opacity .4s}
.svc-card:hover .svc-desc{max-height:120px;opacity:1}
.svc-link{display:inline-flex;align-items:center;gap:8px;font-size:10.5px;font-weight:500;color:var(--gold);letter-spacing:2.5px;text-transform:uppercase;margin-top:14px;opacity:0;transform:translateY(6px);transition:opacity .3s,transform .3s}
.svc-card:hover .svc-link{opacity:1;transform:none}
.svc-card::after{content:'';position:absolute;top:0;left:0;width:0;height:3px;background:var(--gold);transition:width .6s ease}
.svc-card:hover::after{width:100%}

/* TWO COL */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.feat-list{display:flex;flex-direction:column;gap:16px;margin-top:28px}
.feat{display:flex;gap:16px;padding:20px;border:1px solid var(--border);border-left:3px solid var(--gold);background:#fff;transition:transform .25s,box-shadow .25s}
.feat:hover{transform:translateX(4px);box-shadow:0 4px 24px rgba(0,0,0,.07)}
.feat-icon{width:42px;height:42px;flex-shrink:0;background:var(--cream);display:flex;align-items:center;justify-content:center;color:var(--gold)}
.feat h4{font-size:14px;font-weight:500;color:var(--navy);margin-bottom:3px}
.feat p{font-size:13px;font-weight:300;color:var(--mid);line-height:1.75}

/* PROPERTIES */
.prop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.prop-card{border:1px solid var(--border);overflow:hidden;display:block;transition:transform .3s,box-shadow .3s}
.prop-card:hover{transform:translateY(-6px);box-shadow:0 12px 48px rgba(0,0,0,.13)}
.prop-img{height:240px;overflow:hidden;background:var(--navy)}
.prop-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
.prop-card:hover .prop-img img{transform:scale(1.05)}
.prop-body{padding:22px}
.prop-type{font-size:10px;font-weight:600;color:var(--gold);letter-spacing:2.5px;text-transform:uppercase;margin-bottom:6px}
.prop-loc{font-family:var(--serif);font-size:17px;font-weight:700;color:var(--navy);margin-bottom:3px}
.prop-link{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:500;color:var(--gold);letter-spacing:2px;text-transform:uppercase;margin-top:16px;padding-top:16px;border-top:1px solid var(--border);width:100%}

/* LOCATIONS */
.loc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:rgba(0,0,0,.1)}
.loc-card{position:relative;height:360px;overflow:hidden;display:block}
.loc-img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .7s ease}
.loc-card:hover .loc-img{transform:scale(1.04)}
.loc-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(5,12,28,.95) 0%,rgba(5,12,28,.45) 55%,rgba(5,12,28,.15) 100%);transition:background .35s}
.loc-card:hover .loc-ov{background:linear-gradient(to top,rgba(5,12,28,.99) 0%,rgba(5,12,28,.62) 65%,rgba(5,12,28,.25) 100%)}
.loc-body{position:absolute;bottom:0;left:0;right:0;padding:28px 30px;z-index:2}
.loc-name{font-family:var(--serif);font-size:30px;font-weight:700;color:#fff;margin-bottom:8px}
.loc-desc{font-size:13px;font-weight:300;color:rgba(255,255,255,.55);line-height:1.65;margin-bottom:12px}
.loc-link{display:inline-flex;align-items:center;gap:8px;font-size:10.5px;font-weight:500;color:var(--gold);letter-spacing:2.5px;text-transform:uppercase;opacity:0;transform:translateY(5px);transition:opacity .3s,transform .3s}
.loc-card:hover .loc-link{opacity:1;transform:none}
.loc-card::after{content:'';position:absolute;top:0;left:0;width:0;height:3px;background:var(--gold);transition:width .55s ease;z-index:3}
.loc-card:hover::after{width:100%}

/* TESTIMONIALS */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.tcard{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);padding:30px;border-top:2px solid var(--gold);transition:background .3s,transform .3s}
.tcard:hover{background:rgba(255,255,255,.07);transform:translateY(-4px)}
.t-stars{font-size:14px;color:var(--gold);letter-spacing:2px;margin-bottom:14px}
.t-quote{font-size:14.5px;font-weight:300;color:rgba(255,255,255,.68);line-height:1.85;font-style:italic}
.t-author{display:flex;align-items:center;gap:13px;margin-top:18px;padding-top:16px;border-top:1px solid rgba(255,255,255,.07)}
.t-av{width:42px;height:42px;border-radius:50%;background:rgba(200,169,110,.14);border:1px solid rgba(200,169,110,.3);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;color:var(--gold);flex-shrink:0}
.t-name{font-size:13.5px;font-weight:500;color:#fff}
.t-role{font-size:11px;font-weight:300;color:rgba(255,255,255,.35);margin-top:2px}

/* PROCESS */
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.pstep{padding:30px 20px;border:1px solid var(--border);border-top:3px solid var(--gold);text-align:center;transition:transform .3s,box-shadow .3s}
.pstep:hover{transform:translateY(-5px);box-shadow:0 4px 24px rgba(0,0,0,.08)}
.ps-n{font-family:var(--serif);font-size:50px;font-weight:700;color:var(--gold);opacity:.26;line-height:1;margin-bottom:4px}
.ps-icon{display:flex;justify-content:center;color:var(--gold);margin-bottom:12px}
.pstep h4{font-size:15px;font-weight:500;color:var(--navy);margin-bottom:8px}
.pstep p{font-size:13px;font-weight:300;color:var(--mid);line-height:1.75}

/* FAQ */
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.faq{background:#fff;border:1px solid var(--border);border-top:3px solid var(--gold)}
.faq summary{padding:20px 22px;font-family:var(--serif);font-size:17px;font-weight:700;color:var(--navy);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px;line-height:1.28}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';font-family:var(--sans);font-size:22px;font-weight:300;color:var(--gold);flex-shrink:0;transition:transform .3s}
.faq[open] summary::after{transform:rotate(45deg)}
.faq-body{padding:0 22px 18px;font-size:13.5px;font-weight:300;color:#444;line-height:1.8}

/* CONTACT SECTION */
.cta-section{position:relative;overflow:hidden;padding:88px 0;background:var(--navy)}
.cta-section::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 79px,rgba(200,169,110,.022) 80px),repeating-linear-gradient(90deg,transparent,transparent 79px,rgba(200,169,110,.022) 80px)}
.cta-section::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(to right,transparent,var(--gold),transparent)}
.cta-inner{display:grid;grid-template-columns:1fr 460px;gap:60px;align-items:flex-start;position:relative;z-index:1}
.cta-bullets{display:flex;flex-direction:column;gap:10px;margin-top:18px}
.cta-bullets li{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:300;color:rgba(255,255,255,.65)}
.cta-bullets li svg{flex-shrink:0;color:var(--gold)}
.contact-box{display:flex;flex-direction:column;margin-top:28px;max-width:400px}
.cbox-item{display:flex;gap:14px;align-items:flex-start;padding:16px 18px;border:1px solid rgba(200,169,110,.2);border-bottom:none;background:rgba(255,255,255,.04)}
.cbox-item:last-child{border-bottom:1px solid rgba(200,169,110,.2)}
.cbox-icon{width:38px;height:38px;background:rgba(200,169,110,.12);border:1px solid rgba(200,169,110,.2);display:flex;align-items:center;justify-content:center;color:var(--gold);flex-shrink:0}
.cbox-lbl{font-size:9.5px;font-weight:600;color:var(--gold);letter-spacing:2.5px;text-transform:uppercase;margin-bottom:3px}
.cbox-val{font-size:14px;font-weight:300;line-height:1.6}
.cbox-val a{color:rgba(255,255,255,.75);transition:color .2s}
.cbox-val a:hover{color:var(--gold)}

/* FORM */
.form-wrap{background:#fff;padding:36px;border-top:3px solid var(--gold)}
.form-title{font-family:var(--serif);font-size:21px;font-weight:700;color:var(--navy);margin-bottom:20px}
.fg{margin-bottom:12px}
.fg label{display:block;font-size:10px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--mid);margin-bottom:5px}
.fg input,.fg select,.fg textarea{width:100%;padding:11px 14px;border:1px solid var(--border);font-family:var(--sans);font-size:14px;font-weight:300;color:var(--navy);outline:none;appearance:none;background:#fff;transition:border-color .2s,box-shadow .2s;border-radius:0}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(200,169,110,.12)}
.fg textarea{min-height:80px;resize:vertical}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.gdpr{font-size:11px;color:var(--mid);line-height:1.65;margin-top:10px}
.gdpr a{color:var(--navy);text-decoration:underline}
.form-success{display:none;padding:14px;background:rgba(26,122,74,.08);border:1px solid rgba(26,122,74,.25);font-size:13px;color:#166534;margin-top:10px;line-height:1.6}
.form-error{display:none;padding:14px;background:rgba(185,28,28,.08);border:1px solid rgba(185,28,28,.25);font-size:13px;color:#b91c1c;margin-top:10px}
.field-err{font-size:11px;color:#b91c1c;margin-top:3px;display:none}
.fg.err input,.fg.err select,.fg.err textarea{border-color:#b91c1c}
.fg.err .field-err{display:block}

/* COMPLIANCE */
.comp-bar{background:var(--navy);border-top:1px solid rgba(200,169,110,.1);padding:20px 0}
.comp-in{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.comp-badge{display:flex;align-items:center;gap:10px;flex-shrink:0}
.comp-icon{width:36px;height:36px;background:rgba(200,169,110,.1);border:1px solid rgba(200,169,110,.2);display:flex;align-items:center;justify-content:center;color:var(--gold)}
.comp-t h5{font-size:9.5px;font-weight:600;color:var(--gold);letter-spacing:1.5px;text-transform:uppercase}
.comp-t p{font-size:10px;font-weight:300;color:rgba(255,255,255,.28);margin-top:1px}
.comp-div{width:1px;height:32px;background:rgba(255,255,255,.08);flex-shrink:0}
.comp-note{font-size:11px;font-weight:300;color:rgba(255,255,255,.24);line-height:1.75;flex:1;min-width:160px}
.comp-note a{color:var(--gold);text-decoration:underline}

/* FOOTER */
footer{background:#070e1c}
.footer-stripe{height:2px;background:linear-gradient(to right,rgba(7,14,28,0) 0%,var(--gold) 20%,var(--gold) 80%,rgba(7,14,28,0) 100%)}
.footer-main{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:44px;padding:56px 0 36px}
.fb-name{font-family:var(--serif);font-size:18px;font-weight:700;color:#fff;letter-spacing:5px}
.fb-tag{font-size:9px;color:rgba(255,255,255,.26);letter-spacing:2.5px;text-transform:uppercase;margin-top:2px;margin-bottom:14px}
.fb-desc{font-size:12.5px;font-weight:300;color:rgba(255,255,255,.3);line-height:1.85;max-width:240px;margin-bottom:18px}
.f-social{display:flex;gap:10px}
.f-social a{width:34px;height:34px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.32);transition:all .2s}
.f-social a:hover{background:var(--gold);border-color:var(--gold);color:var(--navy)}
.fc h5{font-family:var(--serif);font-size:14px;font-weight:700;color:#fff;margin-bottom:14px}
.fc ul li{margin-bottom:7px}
.fc ul a{font-size:12.5px;font-weight:300;color:rgba(255,255,255,.3);display:block;transition:color .2s,padding-left .15s}
.fc ul a:hover{color:var(--gold);padding-left:4px}
.fc-contact p{font-size:12.5px;font-weight:300;color:rgba(255,255,255,.3);line-height:1.75;margin-bottom:8px;display:flex;align-items:flex-start;gap:7px}
.fc-contact p svg{flex-shrink:0;margin-top:2px;color:var(--gold)}
.fc-contact a{color:var(--gold)}
.footer-bot{border-top:1px solid rgba(255,255,255,.05);padding:16px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.f-copy{font-size:11px;color:rgba(255,255,255,.17)}
.f-legal{display:flex;gap:14px;flex-wrap:wrap}
.f-legal a{font-size:11px;color:rgba(255,255,255,.17);transition:color .2s}
.f-legal a:hover{color:var(--gold)}

/* FLOATS */
.floats{position:fixed;bottom:24px;right:24px;z-index:8000;display:flex;flex-direction:column;gap:12px}
.fbtn{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,0,0,.28);transition:transform .2s;position:relative}
.fbtn:hover{transform:scale(1.1)}
.fbtn-wa{background:#25D366}
.fbtn-wa:hover{box-shadow:0 6px 28px rgba(37,211,102,.5)}
.fbtn-em{background:var(--navy);border:2px solid var(--gold)}
.ftip{position:absolute;right:66px;top:50%;transform:translateY(-50%);background:var(--navy);color:#fff;font-size:11px;padding:5px 12px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s;border-left:2px solid var(--gold)}
.fbtn:hover .ftip{opacity:1}

/* MOBILE BAR */
.mob-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:7999;background:var(--navy);border-top:2px solid var(--gold)}
.mob-bar-row{display:flex}
.mb-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px 4px;color:#fff;font-size:9px;font-weight:500;letter-spacing:1px;text-transform:uppercase;border-right:1px solid rgba(255,255,255,.08);gap:4px;text-decoration:none;min-height:56px;transition:background .2s}
.mb-btn:last-child{border-right:none}
.mb-btn:hover,.mb-btn:active{background:rgba(255,255,255,.08)}
.mb-btn.wa{background:#25D366}
.mb-btn.wa:hover{background:#1fb855}

/* RESPONSIVE */
@media(max-width:1100px){
  .wrap,.topbar-in,.hdr,.hero-content{padding-left:24px;padding-right:24px}
  .nav-list,.nav-ctas{display:none}
  .burger{display:flex}
  .two-col,.cta-inner{grid-template-columns:1fr;gap:40px}
  .prop-grid{grid-template-columns:repeat(2,1fr)}
  .proc-grid{grid-template-columns:repeat(2,1fr)}
  .faq-grid{grid-template-columns:1fr}
  .footer-main{grid-template-columns:1fr 1fr;gap:28px}
  .loc-grid,.svc-grid{grid-template-columns:1fr}
  .loc-card{height:260px}
  .svc-card{height:300px}
  .testi-grid{grid-template-columns:1fr}
  .floats{display:none}
  .mob-bar{display:block}
  body{padding-bottom:58px}
  #ckBanner{padding:12px 24px}
}
@media(max-width:767px){
  .wrap,.topbar-in,.hdr,.hero-content{padding-left:18px;padding-right:18px}
  .topbar{display:none}
  .section{padding:60px 0}
  .hero{min-height:100vh}
  .hero h1{font-size:clamp(38px,8vw,58px)}
  .hero-ctas{max-width:100%}
  .prop-grid,.proc-grid{grid-template-columns:1fr}
  .footer-main{grid-template-columns:1fr;gap:24px}
  .footer-bot{flex-direction:column;gap:8px;text-align:center}
  .f-legal{justify-content:center}
  .f-row{grid-template-columns:1fr}
  #ckBanner{flex-direction:column;align-items:flex-start;padding:12px 18px}
  .comp-in{flex-direction:column}
}
