﻿
:root{
  --primary:#11224d;
  --accent:#e5631b;
  --accent2:#f5b041;
  --text:#24334f;
  --bg:#ffffff;
  --muted:#6b7280;
  --border:#e5e7eb;
  --success:#0c7a39;
  --error:#c0392b;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Montserrat",sans-serif;color:var(--text);background:#fff;line-height:1.6;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1240px, calc(100% - 40px));margin:0 auto}
.site-header{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);box-shadow:0 8px 24px rgba(17,34,77,.08)}
.header-bar{display:flex;align-items:center;justify-content:space-between;padding:16px 0;gap:20px}
.logo img{height:48px;width:auto}
.site-nav{display:flex;gap:24px;align-items:center}
.site-nav a{font-size:14px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;position:relative}
.site-nav a.is-active,.site-nav a:hover{color:var(--accent)}
.site-nav a.is-active::after,.site-nav a:hover::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--accent)}
.nav-toggle{display:none;background:none;border:0;font-size:26px}
.hero{position:relative;overflow:hidden;background:linear-gradient(135deg,#0e1d46 0%, #223c61 100%);color:#fff}
.hero::before{content:"";position:absolute;inset:0;background:url('../jpg/services_bg1az2dd.jpg') center/cover no-repeat;opacity:.22;transform:scale(1.06)}
.hero-inner{position:relative;padding:96px 0 84px;display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center}
.hero h1{font-size:clamp(34px,5vw,60px);line-height:1.05;margin:0 0 14px;font-weight:800}
.hero p{font-size:18px;max-width:620px;color:rgba(255,255,255,.92)}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-top:28px}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 22px;border-radius:999px;font-weight:800;letter-spacing:.02em;text-transform:uppercase;font-size:13px;border:1px solid transparent;transition:transform .28s ease, box-shadow .28s ease, background-color .28s ease, color .28s ease}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;box-shadow:0 14px 30px rgba(229,99,27,.25)}
.btn-primary:hover{box-shadow:0 18px 34px rgba(229,99,27,.3)}
.btn-secondary{border-color:rgba(255,255,255,.25);color:#fff}
.hero-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:24px;padding:24px;backdrop-filter:blur(12px);box-shadow:0 20px 40px rgba(0,0,0,.16)}
.hero-card img{border-radius:18px}
.section{padding:72px 0}
.section-sm{padding:56px 0}
.section-title{text-align:center;max-width:780px;margin:0 auto 40px}
.eyebrow{color:var(--accent);font-size:14px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px}
.section-title h2{margin:0;font-size:clamp(28px,4vw,44px);line-height:1.1;color:var(--primary)}
.section-title p{margin:14px 0 0;color:var(--muted)}
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{background:#fff;border-radius:24px;overflow:hidden;box-shadow:0 18px 36px rgba(17,34,77,.08);border:1px solid rgba(17,34,77,.06);transition:transform .3s ease, box-shadow .3s ease}
.card:hover{transform:translateY(-6px);box-shadow:0 22px 40px rgba(17,34,77,.12)}
.card-body{padding:22px}
.card h4{margin:0 0 8px;font-size:22px;color:var(--primary)}
.card p{margin:0;color:var(--muted)}
.split-banner{position:relative;color:#fff}
.split-banner .bg,.split-banner .bg-media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.split-banner .overlay{position:absolute;inset:0;background:linear-gradient(90deg, rgba(17,34,77,.06), rgba(17,34,77,.72))}
.split-content{position:relative;display:grid;grid-template-columns:1fr 1fr;min-height:620px;align-items:center}
.split-copy{grid-column:2;padding:72px 0 72px 44px}
.split-copy h2{font-size:clamp(32px,4vw,48px);line-height:1.1;margin:8px 0 14px}
.split-copy .desc{max-width:520px}
.table-wrap{display:grid;gap:18px;margin-top:26px}
.price-box{background:rgba(255,255,255,.94);color:var(--text);padding:20px;border-radius:22px;box-shadow:0 16px 28px rgba(0,0,0,.14)}
.price-box h5{margin:0 0 14px;font-size:18px;color:var(--primary);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{padding:12px;border:1px solid #d9dce6;text-align:left;background:#fff}
th{background:#f6f7fb;color:var(--primary)}
.note{text-align:right;font-size:13px;color:#475569;margin-top:10px}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.gallery-grid img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:16px;transition:transform .35s ease, box-shadow .35s ease}
.gallery-grid img:hover{transform:translateY(-4px) scale(1.01);box-shadow:0 16px 32px rgba(17,34,77,.14)}
.feature-band{background:#f7f8fc}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:center}
.location-box{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:center}
.location-copy .cta-line{display:flex;gap:14px;flex-wrap:wrap;margin-top:18px}
.appointment{position:relative;color:#fff}
.appointment .bg,.appointment .bg-media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.appointment .overlay{position:absolute;inset:0;background:rgba(17,34,77,.66)}
.appointment-inner{position:relative;padding:80px 0}
.form-shell{width:min(760px,100%);margin:0 auto;background:rgba(255,255,255,.96);color:var(--text);border-radius:24px;padding:28px;box-shadow:0 24px 48px rgba(0,0,0,.24)}
.form-title{text-align:center;color:var(--primary);font-size:34px;margin:0 0 8px}
.form-intro{text-align:center;max-width:620px;margin:0 auto 18px;color:var(--muted)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:8px}
.field.full{grid-column:1/-1}
label{font-weight:700;color:var(--primary)}
input,select,textarea{width:100%;padding:14px 16px;border:1px solid #d6dae5;border-radius:14px;font:inherit;transition:border-color .25s ease, box-shadow .25s ease, background-color .25s ease}
input:focus,select:focus,textarea:focus{outline:none;border-color:#6d8bdd;box-shadow:0 0 0 4px rgba(109,139,221,.15)}
input.is-invalid,select.is-invalid,textarea.is-invalid{border-color:#df6a5e;background:#fff8f7}
input.is-valid,select.is-valid,textarea.is-valid{border-color:#6bc18a;background:#f7fff9}
textarea{min-height:140px;resize:vertical}
.error-text{color:var(--error);font-size:13px;font-weight:600}
.form-helper{font-size:14px;color:var(--muted)}
.form-helper a{color:var(--accent);font-weight:700}
.submit-row{align-items:flex-start}
.alert{padding:14px 16px;border-radius:14px;margin-bottom:16px;font-weight:600}
.alert-success{background:#e9f9ef;color:var(--success)}
.alert-error{background:#fdecec;color:var(--error)}
.footer-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:32px;padding:48px 0}
.site-footer{background:#0f1d3f;color:#fff;margin-top:0}
.site-footer h5{margin:0 0 12px;font-size:18px}
.site-footer p,.site-footer li{color:rgba(255,255,255,.86)}
.footer-list{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.footer-bottom{padding:14px 20px;text-align:center;border-top:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.78);font-size:14px}
.small{font-size:11px;font-weight:500}
.floating-wa{position:fixed;right:20px;bottom:20px;z-index:60;width:52px;transition:transform .28s ease}
.floating-wa:hover{transform:scale(1.06)}
.page-hero{padding:78px 0;background:linear-gradient(180deg,#f7f8fc,#fff)}
.page-hero h1{text-align:center;color:var(--primary);font-size:clamp(34px,4vw,52px);margin:0}
.page-hero p{text-align:center;color:var(--muted);max-width:760px;margin:12px auto 0}
.hidden-hp{position:absolute;left:-9999px;opacity:0;pointer-events:none}
.reveal-up{opacity:0;transform:translateY(24px);transition:opacity .65s ease, transform .65s ease}
.reveal-up.is-visible{opacity:1;transform:none}
.reveal-delay-1{transition-delay:.08s}
.reveal-delay-2{transition-delay:.16s}
.reveal-delay-3{transition-delay:.24s}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
  .reveal-up{opacity:1;transform:none}
}
@media (max-width: 980px){
  .hero-inner,.split-content,.two-col,.location-box,.footer-grid{grid-template-columns:1fr}
  .split-copy{grid-column:auto;padding:56px 0}
  .cards-3,.gallery-grid,.form-grid{grid-template-columns:1fr 1fr}
  .hero-card{order:-1}
}
@media (max-width: 720px){
  .container{width:min(100% - 28px,1240px)}
  .nav-toggle{display:block}
  .site-nav{display:none;position:absolute;right:14px;top:74px;background:#fff;border:1px solid var(--border);border-radius:16px;padding:16px;box-shadow:0 18px 36px rgba(17,34,77,.12);flex-direction:column;align-items:flex-start;width:min(260px, calc(100% - 28px))}
  .site-nav.is-open{display:flex}
  .cards-3,.gallery-grid,.form-grid{grid-template-columns:1fr}
  .hero-inner{padding:72px 0 60px}
  .section{padding:56px 0}
  .hero h1{font-size:clamp(32px,11vw,46px)}
  .hero p{font-size:16px}
  .btn{width:100%}
  .hero-actions,.location-copy .cta-line{flex-direction:column;align-items:stretch}
  .form-shell{padding:22px}
  .form-title{font-size:28px}
  th,td{padding:10px;font-size:13px}
}

.gallery-item{display:block;position:relative;overflow:hidden;border-radius:16px}
.gallery-item::after{content:"View";position:absolute;inset:auto 12px 12px auto;background:rgba(17,34,77,.78);color:#fff;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:8px 10px;border-radius:999px;opacity:0;transform:translateY(8px);transition:opacity .28s ease, transform .28s ease}
.gallery-item:hover::after{opacity:1;transform:none}
.form-alert-client[hidden]{display:none!important}
.field input,.field select,.field textarea{background:#fff}
button[disabled]{opacity:.75;cursor:not-allowed;transform:none!important}


.bg-enquiry{background-image:url('../jpg/enquiry_bckbqnp0.jpg');}
.bg-services-one{background-image:url('../jpg/services_bg1az2dd.jpg');}
.bg-services-two{background-image:url('../jpg/services_bg2amztl.jpg');}
.btn-outline-light{border-color:#d6dae5;background:transparent;color:#1d2433;}
.btn-outline-light:hover,.btn-outline-light:focus-visible{background:#1d2433;color:#fff;border-color:#1d2433;}


/* Background image hardening for section wrappers */
.split-banner,
.appointment,
.hero{isolation:isolate}
.split-banner .bg,
.split-banner .bg-media,
.appointment .bg,
.appointment .bg-media,
.hero::before{z-index:-2}
.split-banner .overlay,
.appointment .overlay{z-index:-1}
.split-content,
.appointment-inner,
.hero-inner{z-index:1}
.split-banner .bg,
.split-banner .bg-media,
.appointment .bg,
.appointment .bg-media{transform:translateZ(0)}
.location-box img,
.two-col img,
.hero-card img{width:100%;height:auto;display:block}


/* Media-based background support */
.bg-media{pointer-events:none;user-select:none;}
.split-banner .bg-media,.appointment .bg-media{filter:none;}

.hero-slider{position:relative;min-height:430px}
.hero-slider-track{position:relative;min-height:380px}
.hero-slide{position:absolute;inset:0;opacity:0;pointer-events:none;transition:opacity .5s ease}
.hero-slide.is-active{opacity:1;pointer-events:auto}
.hero-slide img{width:100%;height:380px;object-fit:cover;border-radius:18px;display:block}
.hero-slider-btn{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:999px;border:none;background:rgba(17,34,77,.72);color:#fff;font-size:30px;line-height:1;display:grid;place-items:center;cursor:pointer;z-index:3}
.hero-slider-btn.prev{left:18px}
.hero-slider-btn.next{right:18px}
.hero-slider-dots{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);display:flex;gap:8px;z-index:3}
.hero-dot{width:10px;height:10px;border-radius:999px;border:none;background:rgba(255,255,255,.5);cursor:pointer}
.hero-dot.is-active{background:#fff}
.submit-row{align-items:center;text-align:center;justify-content:center}
.submit-btn{margin:0 auto 14px;min-width:220px}
.form-helper{text-align:center;width:100%}
.recaptcha-wrap{display:flex;justify-content:center;margin-top:4px}
.recaptcha-error{text-align:center;margin-top:10px}
.blog-highlight-section{background:#f7f8fc}
.section-cta{text-align:center;margin-top:28px}
.post-meta{font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}
.text-link{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:var(--primary);margin-top:10px}
.text-link:hover{color:var(--accent)}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.blog-card{background:#fff;border:1px solid rgba(17,34,77,.08);border-radius:24px;overflow:hidden;box-shadow:0 18px 36px rgba(17,34,77,.08)}
.blog-card-media img{width:100%;height:240px;object-fit:cover;display:block}
.blog-card-body{padding:22px}
.blog-card-body h2{font-size:24px;line-height:1.2;margin:0 0 12px;color:var(--primary)}
.blog-card-body h2 a{color:inherit}
.blog-post-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:30px;align-items:start}
.blog-post-content{background:#fff;border-radius:24px;padding:28px;box-shadow:0 18px 36px rgba(17,34,77,.08);border:1px solid rgba(17,34,77,.08)}
.blog-featured-image{width:100%;height:420px;object-fit:cover;border-radius:18px;margin-bottom:24px}
.blog-post-content h2{font-size:30px;color:var(--primary);margin:28px 0 12px}
.blog-post-content p{color:var(--text);margin:0 0 16px}
.blog-post-content ul{padding-left:20px;margin:0 0 18px}
.blog-post-content li{margin-bottom:10px}
.blog-sidebar{position:sticky;top:90px}
.sidebar-card{background:#fff;border-radius:24px;padding:22px;box-shadow:0 18px 36px rgba(17,34,77,.08);border:1px solid rgba(17,34,77,.08)}
.sidebar-card h3{margin:0 0 14px;color:var(--primary)}
.sidebar-list{list-style:none;padding:0;margin:0;display:grid;gap:12px}
.sidebar-list a{color:var(--text);font-weight:600}
.page-hero-blog,.page-hero-blog-post{background:linear-gradient(180deg,#eef3ff,#fff)}
.footer-logo{
  max-width:190px;
  margin-bottom:14px;
}
@media (max-width: 980px){
  .blog-grid{grid-template-columns:1fr 1fr}
  .blog-post-layout{grid-template-columns:1fr}
  .blog-sidebar{position:static}
}
@media (max-width: 720px){
  .hero-slider{min-height:320px}
  .hero-slider-track{min-height:280px}
  .hero-slide img{height:280px}
  .hero-slider-btn{width:38px;height:38px}
  .blog-grid{grid-template-columns:1fr}
  .blog-featured-image{height:240px}
  .g-recaptcha{transform:scale(.92);transform-origin:center top}
}

