*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:Arial,Helvetica,sans-serif;color:#262626;background:#f6f4ef;line-height:1.6}a{text-decoration:none;color:inherit}img{display:block;width:100%}button,input,textarea{font:inherit}button{cursor:pointer}.site-header{position:fixed;z-index:1000;top:0;left:0;right:0;height:82px;padding:0 5vw;display:flex;align-items:center;justify-content:space-between;background:rgba(8,8,8,.94);box-shadow:0 5px 30px rgba(0,0,0,.25)}.brand{font-weight:900;color:#d2a72b;letter-spacing:2px;line-height:1}.brand span,.brand small{display:block}.brand small{color:#fff;font-size:11px;letter-spacing:5px;margin-top:6px}.site-header nav{display:flex;gap:28px}.site-header nav a{color:#fff;font-weight:700;font-size:14px}.site-header nav a:hover{color:#d2a72b}.menu-btn{display:none;background:none;border:0;color:#fff;font-size:30px}.hero{min-height:100vh;background:url("assets/images/hero-approved.png") center top/cover no-repeat;position:relative}.trust{display:grid;grid-template-columns:repeat(4,1fr);padding:26px 6vw;background:#111;color:#fff}.trust div{text-align:center;border-right:1px solid #333}.trust div:last-child{border:0}.trust strong,.trust span{display:block}.trust strong{color:#d2a72b}.trust span{font-size:13px;color:#bbb}.section,.gallery-section,.about,.contact{padding:90px 6vw;scroll-margin-top:82px}.heading{text-align:center;max-width:780px;margin:0 auto 42px}.heading p,.eyebrow{color:#b68d1b;font-weight:800;letter-spacing:2px;font-size:13px}.heading h2,.about h2{font-size:clamp(34px,4vw,50px);line-height:1.15;margin:10px 0 14px}.heading span{color:#666}.service-grid{max-width:1200px;margin:auto;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.service-grid article{background:#fff;padding:26px;border-radius:16px;border:1px solid #ebe7dc;box-shadow:0 12px 35px rgba(0,0,0,.06)}.service-grid h3{margin-bottom:8px}.service-grid p{color:#666}.gallery-section{background:#ece8de}.category-grid{max-width:1450px;margin:auto;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.category-card{border-radius:16px;overflow:hidden;box-shadow:0 12px 30px rgba(0,0,0,.14)}.category-open{width:100%;height:330px;border:0;position:relative;overflow:hidden;background:#ddd}.category-open img{height:100%;object-fit:cover;transition:.35s}.category-open:hover img{transform:scale(1.04)}.category-overlay{position:absolute;inset:auto 0 0;padding:60px 20px 20px;text-align:left;color:#fff;background:linear-gradient(transparent,rgba(0,0,0,.9))}.category-overlay strong,.category-overlay small{display:block}.category-overlay strong{font-size:24px}.category-overlay small{color:#d2a72b}.about{display:grid;grid-template-columns:1.5fr 1fr;gap:40px;align-items:center;background:#fff}.about>div p:last-child{color:#666}.about aside{background:#111;color:#fff;border-radius:18px;padding:38px;display:grid;gap:10px}.about aside strong{color:#d2a72b;font-size:27px}.contact{background:#ece8de}.contact-grid{max-width:1050px;margin:auto;display:grid;grid-template-columns:1.3fr .7fr;gap:22px}.contact form,.contact aside{background:#fff;border-radius:16px;padding:28px;box-shadow:0 12px 35px rgba(0,0,0,.08)}label{display:block;font-weight:700;margin-bottom:14px}input,textarea{width:100%;display:block;margin-top:6px;border:1px solid #ccc;border-radius:8px;padding:12px}.form-actions{display:flex;gap:10px;flex-wrap:wrap}.form-actions button,.chat-body button{border:0;border-radius:8px;padding:12px 18px;background:#d2a72b;font-weight:800}.contact aside{display:flex;flex-direction:column;gap:14px}.contact aside a{color:#8b6a12;font-weight:700}footer{background:#090909;color:#bbb;padding:36px 6vw;text-align:center;display:grid;gap:7px}footer strong{color:#d2a72b}.gallery-modal{display:none;position:fixed;z-index:1800;inset:0;background:rgba(0,0,0,.88);padding:28px;overflow:auto}.gallery-modal.open{display:block}.modal-shell{max-width:1350px;margin:auto;background:#f7f5f0;border-radius:18px;padding:24px;position:relative}.modal-close{position:sticky;float:right;top:0;border:0;background:#111;color:#fff;width:44px;height:44px;border-radius:50%;font-size:28px;z-index:2}.modal-title{padding:8px 55px 24px 5px}.modal-title h3{font-size:34px}.modal-title span{color:#777}.modal-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.modal-grid button{border:0;border-radius:12px;overflow:hidden;background:#ddd}.modal-grid img{height:360px;object-fit:cover}.lightbox{display:none;position:fixed;z-index:2000;inset:0;background:rgba(0,0,0,.96);align-items:center;justify-content:center;padding:50px}.lightbox.open{display:flex}.lightbox img{max-width:90vw;max-height:82vh;object-fit:contain}.lightbox button{position:absolute;border:0;background:rgba(255,255,255,.12);color:#fff;width:50px;height:50px;border-radius:50%;font-size:32px}.lightbox #lbClose{right:18px;top:18px}.lightbox #lbPrev{left:18px}.lightbox #lbNext{right:18px}.lightbox #lbCaption{position:absolute;bottom:16px;color:#fff}@media(max-width:900px){.site-header nav{display:none;position:fixed;top:82px;left:0;right:0;background:#111;padding:24px;flex-direction:column}.site-header nav.open{display:flex}.menu-btn{display:block}.hero{min-height:75vh;background-position:center}.hero-actions{grid-template-columns:1fr 1fr}.service-grid,.category-grid{grid-template-columns:repeat(2,1fr)}.about,.contact-grid{grid-template-columns:1fr}.trust{grid-template-columns:1fr 1fr;gap:18px}.trust div{border:0}.modal-grid img{height:280px}}@media(max-width:560px){.site-header{height:72px}.site-header nav{top:72px}.hero{min-height:68vh}.hero-actions{left:12px;right:12px;bottom:12px;grid-template-columns:1fr 1fr}.hero-actions a,.hero-actions button{padding:10px}.hero-actions span{font-size:11px}.section,.gallery-section,.about,.contact{padding:62px 18px}.service-grid,.category-grid,.modal-grid{grid-template-columns:1fr}.category-open{height:280px}.modal-grid img{height:260px}.gallery-modal{padding:10px}.modal-shell{padding:14px}.heading h2,.about h2{font-size:34px}}
/* Approved hero layout with functional click areas */
.site-header{opacity:0;pointer-events:none;transform:translateY(-100%);transition:.25s}
.site-header.visible{opacity:1;pointer-events:auto;transform:translateY(0)}
.hero-hotspots{position:absolute;inset:0;z-index:3}
.hotspot{position:absolute;display:block;background:transparent;border:0;cursor:pointer}
.hs-home{left:27.5%;top:3.5%;width:6.5%;height:6%}.hs-services{left:35.5%;top:3.5%;width:8%;height:6%}.hs-process{left:44.5%;top:3.5%;width:10%;height:6%}.hs-gallery{left:55%;top:3.5%;width:7%;height:6%}.hs-about{left:63%;top:3.5%;width:6%;height:6%}.hs-contact{left:70%;top:3.5%;width:7%;height:6%}
.hs-call{left:5%;top:65%;width:15.5%;height:7.5%}.hs-whatsapp-main{left:21.4%;top:65%;width:11.2%;height:7.5%}.hs-quote{left:33.8%;top:65%;width:13.6%;height:7.5%}
.hs-chat{right:2.1%;top:72.5%;width:11%;height:6.8%}.hs-whatsapp-side{right:2.1%;top:81.4%;width:11%;height:6.8%}.hs-email{right:2.1%;top:90%;width:11%;height:6.8%}
.mobile-hero-actions{display:none}
.process{background:#111;color:#fff}.process .heading span{color:#bbb}.process-grid{max-width:1200px;margin:auto;display:grid;grid-template-columns:repeat(5,1fr);gap:14px}.process-grid article{background:#191919;border:1px solid #333;border-radius:14px;padding:22px}.process-grid b{display:grid;place-items:center;width:40px;height:40px;border-radius:50%;background:#d2a72b;color:#111}.process-grid h3{margin:12px 0 7px}.process-grid p{color:#bbb;font-size:14px}
.contact-stack{position:fixed;right:18px;bottom:18px;z-index:1250;display:flex;flex-direction:column;gap:9px}.contact-pill{width:142px;border:0;border-radius:999px;padding:12px 16px;font-weight:800;text-align:center;box-shadow:0 10px 28px rgba(0,0,0,.28)}.chat-pill{background:#090909;color:#fff;border:2px solid #d2a72b}.whatsapp-pill{background:#24c93f;color:#fff}.email-pill{background:#2f80ed;color:#fff}
.site-chat{position:fixed;right:18px;bottom:18px;z-index:1400}.chat-panel{display:none;position:absolute;right:0;bottom:164px;width:min(410px,calc(100vw - 36px));background:#fff;border-radius:18px;box-shadow:0 24px 70px rgba(0,0,0,.38);overflow:hidden}.chat-panel.open{display:block}.chat-header{background:#111;color:#fff;padding:16px;display:flex;justify-content:space-between;align-items:center}.chat-header strong,.chat-header span{display:block}.chat-header strong{color:#d2a72b}.chat-header span{font-size:12px;color:#ccc}.chat-close{background:none;border:0;color:#fff;font-size:24px}.language-selector{display:flex;gap:6px;flex-wrap:wrap;padding:10px 12px;border-bottom:1px solid #eee}.language-selector button{border:1px solid #ddd;border-radius:999px;padding:6px 9px;background:#fff;font-size:12px}.language-selector button.active{background:#111;color:#fff}.chat-messages{height:260px;overflow-y:auto;padding:14px;background:#f7f7f7}.chat-message{max-width:88%;margin-bottom:10px;padding:10px 12px;border-radius:14px;font-size:14px;white-space:pre-wrap}.bot-message{background:#fff;border:1px solid #e5e5e5}.user-message{margin-left:auto;background:#d2a72b;color:#111}.chat-quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:7px;padding:10px 12px}.chat-quick-actions button{border:1px solid #ddd;background:#fff;border-radius:8px;padding:8px;font-weight:700;font-size:12px}.chat-form{display:flex;gap:7px;padding:10px 12px;border-top:1px solid #eee}.chat-form input{flex:1;border:1px solid #ccc;border-radius:8px;padding:10px}.chat-form button,.chat-submit-enquiry{border:0;border-radius:8px;padding:10px 13px;background:#d2a72b;font-weight:800}.chat-direct-submit{padding:0 12px 10px}.chat-direct-submit[hidden]{display:none}.chat-submit-status{font-size:12px;margin-top:6px}.chat-contact-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;padding:10px 12px 13px;background:#fafafa}.chat-contact-buttons a{text-align:center;border-radius:8px;padding:9px;text-decoration:none;font-weight:800}.chat-whatsapp{background:#25d366;color:#092e12}.chat-email{background:#2f80ed;color:#fff}.chat-call{background:#111;color:#fff}
@media(max-width:900px){.site-header{opacity:1;pointer-events:auto;transform:none}.hero{min-height:72vh;background-position:center top}.hero-hotspots{display:none}.mobile-hero-actions{position:absolute;left:12px;right:12px;bottom:12px;display:grid;grid-template-columns:1fr;gap:8px}.mobile-hero-actions a{padding:12px;border-radius:8px;background:#d2a72b;color:#111;text-align:center;font-weight:800}.mobile-hero-actions .wa{background:#25d366}.process-grid{grid-template-columns:1fr 1fr}.contact-stack{right:10px}.contact-pill{width:52px;height:52px;padding:0;font-size:0}.contact-pill span{font-size:19px}}
@media(max-width:560px){.process-grid{grid-template-columns:1fr}.chat-panel{bottom:178px}}


/* Final approved corrections */
.contact-stack { display: none !important; }

.hero {
    background-image: url("assets/images/hero-approved.png");
    background-position: center top;
    background-size: cover;
    background-repeat: no-repeat;
}

/* Clickable transparent areas matching the approved hero image */
.hero-hotspots { position: absolute; inset: 0; z-index: 5; }
.hotspot { position: absolute; display: block; border: 0; background: transparent; }

/* Top navigation embedded in the hero mock-up */
.hs-home { left: 28.1%; top: 4.3%; width: 6.1%; height: 5.3%; }
.hs-services { left: 36.1%; top: 4.3%; width: 7.7%; height: 5.3%; }
.hs-process { left: 45.1%; top: 4.3%; width: 9.4%; height: 5.3%; }
.hs-gallery { left: 56.7%; top: 4.3%; width: 6.8%; height: 5.3%; }
.hs-about { left: 65.2%; top: 4.3%; width: 5.4%; height: 5.3%; }
.hs-contact { left: 73.7%; top: 4.3%; width: 6.8%; height: 5.3%; }

/* Main hero actions */
.hs-call { left: 5.0%; top: 65.0%; width: 16.0%; height: 7.5%; }
.hs-whatsapp-main { left: 21.7%; top: 65.0%; width: 11.9%; height: 7.5%; }
.hs-quote { left: 34.5%; top: 65.0%; width: 14.2%; height: 7.5%; }

/* The only right-side contact actions */
.hs-chat { right: 2.0%; top: 72.5%; width: 11.2%; height: 7.0%; cursor: pointer; }
.hs-whatsapp-side { right: 2.0%; top: 81.4%; width: 11.2%; height: 7.0%; }
.hs-email { right: 2.0%; top: 90.0%; width: 11.2%; height: 7.0%; }

/* Chat opens from the right-side visual button */
.site-chat {
    position: fixed;
    right: 18px;
    bottom: 18px;
    z-index: 1400;
}
.chat-panel {
    right: 0;
    bottom: 0;
    max-height: calc(100vh - 36px);
}
.chat-messages { min-height: 250px; }

select {
    width: 100%;
    display: block;
    margin-top: 6px;
    border: 1px solid #ccc;
    border-radius: 8px;
    padding: 12px;
    background: #fff;
}

.quote-actions button {
    min-width: 160px;
}
.quote-status {
    min-height: 24px;
    margin-top: 14px;
    font-weight: 700;
}
.quote-status.success { color: #18743a; }
.quote-status.error { color: #b3261e; }
.chat-submit-status.success { color: #18743a; }
.chat-submit-status.error { color: #b3261e; }
.typing-message { opacity: .72; font-style: italic; }
.chat-summary { white-space: pre-wrap; }

@media (max-width: 900px) {
    .hero-hotspots { display: none; }
    .mobile-hero-actions { display: grid; }
    .chat-panel {
        position: fixed;
        right: 10px;
        left: 10px;
        bottom: 10px;
        width: auto;
        max-height: calc(100vh - 20px);
    }
}


/* VERIFIED HERO — full image always visible; controls never crop or overlap */
.site-header { display: none !important; }
.hero {
  min-height: 100vh !important;
  height: auto !important;
  padding: 0 !important;
  background: #050505 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}
.hero-canvas {
  position: relative;
  width: min(100vw, calc(100vh * 1.5));
  aspect-ratio: 3 / 2;
  flex: 0 0 auto;
}
.hero-art {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  user-select: none;
  pointer-events: none;
}
.hero-hotspots { position:absolute; inset:0; z-index:10; }
.hotspot { position:absolute; display:block; border:0; background:transparent; cursor:pointer; }
.hotspot:focus-visible { outline: 3px solid #fff; outline-offset: 2px; border-radius: 10px; }

/* Navigation areas in the approved artwork */
.hs-home     { left:28.0%; top:4.2%; width:6.5%; height:6.2%; }
.hs-services { left:35.8%; top:4.2%; width:8.0%; height:6.2%; }
.hs-process  { left:44.5%; top:4.2%; width:10.2%; height:6.2%; }
.hs-gallery  { left:55.6%; top:4.2%; width:7.4%; height:6.2%; }
.hs-about    { left:64.3%; top:4.2%; width:6.0%; height:6.2%; }
.hs-contact  { left:72.8%; top:4.2%; width:7.2%; height:6.2%; }

/* Main three working buttons */
.hs-call          { left:4.7%; top:63.6%; width:16.5%; height:8.0%; }
.hs-whatsapp-main { left:21.7%; top:63.6%; width:12.0%; height:8.0%; }
.hs-quote         { left:34.4%; top:63.6%; width:14.7%; height:8.0%; }

/* Only the approved three actions on the right */
.hs-chat          { left:86.6%; top:70.6%; width:11.7%; height:8.0%; }
.hs-whatsapp-side { left:86.6%; top:79.4%; width:11.7%; height:8.0%; }
.hs-email         { left:86.6%; top:87.8%; width:11.7%; height:8.0%; }

.mobile-hero-actions { display:none !important; }

/* Chat stays above the page and never creates another visible launcher */
.site-chat { position: fixed !important; right: 18px !important; bottom: 18px !important; z-index: 1500 !important; pointer-events:none; }
.chat-panel { pointer-events:auto; }

@media (max-width: 760px) {
  .site-header { display:flex !important; }
  .hero { min-height:auto !important; padding-top:72px !important; display:block !important; }
  .hero-canvas { width:100%; aspect-ratio:3/2; }
  .hero-hotspots { display:none !important; }
  .mobile-hero-actions {
    display:grid !important;
    grid-template-columns:1fr 1fr;
    gap:10px;
    padding:14px;
    background:#111;
  }
  .mobile-hero-actions a, .mobile-hero-actions button {
    border:0; border-radius:10px; padding:13px 10px; text-align:center;
    text-decoration:none; font-weight:800; background:#d4af37; color:#111;
  }
  .mobile-hero-actions .wa { background:#25d366; }
  .mobile-hero-actions button { background:#fff; }
}
