:root{--bg0:#070a10;--bg1:#0b1220;--border:rgba(148,163,184,.18);--text:#e5e7eb;--muted:#a3b1c6;--accent:#38bdf8;--accent2:#f59e0b;--good:#22c55e;--shadow:0 20px 60px rgba(0,0,0,.45);--radius:18px}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:
radial-gradient(1200px 600px at 10% 0%, rgba(56,189,248,.08), transparent 60%),
radial-gradient(1200px 700px at 90% 10%, rgba(245,158,11,.07), transparent 60%),
linear-gradient(180deg,var(--bg0),var(--bg1));color:var(--text);line-height:1.65}
a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}
.container{max-width:1120px;margin:0 auto;padding:24px}
header{position: static;z-index:20;background:rgba(7,10,16,.72);backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.logo{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:.2px;color:var(--text)}
.logo-mark{width:28px;height:28px;border-radius:10px;background:linear-gradient(135deg,rgba(56,189,248,.95),rgba(245,158,11,.85));box-shadow:0 10px 30px rgba(56,189,248,.18)}
.navlinks{display:flex;gap:14px;flex-wrap:wrap}
.navlinks a{color:rgba(229,231,235,.92);font-weight:600;font-size:.95rem}
.navlinks a:hover{text-decoration:none;color:#fff}
.badge{display:inline-flex;align-items:center;gap:10px;padding:8px 12px;border-radius:999px;border:1px solid var(--border);background:rgba(17,24,39,.45);color:var(--muted);font-size:.95rem}
.hero{position:relative;border:1px solid var(--border);border-radius:28px;overflow:hidden;box-shadow:var(--shadow);margin-top:18px}
.hero .bg{position:absolute;inset:0;background-image:url('images/hero-laser-cleaning.jpg');background-size:cover;background-position:center;filter:saturate(1.08) contrast(1.08);transform:scale(1.03)}
.hero .overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,10,16,.86) 0%,rgba(7,10,16,.62) 42%,rgba(7,10,16,.18) 100%),
radial-gradient(800px 420px at 20% 40%,rgba(56,189,248,.14),transparent 60%),
radial-gradient(900px 520px at 70% 40%,rgba(245,158,11,.12),transparent 60%)}
.hero .content{position:relative;padding:54px 44px 32px}
.hero h1{font-size:clamp(2.0rem,4vw,3.35rem);line-height:1.1;margin:10px 0 10px;letter-spacing:-.6px}
.hero p{max-width:72ch;color:rgba(229,231,235,.86);margin:0}
.hero .cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.btn{display:inline-flex;align-items:center;gap:10px;padding:12px 16px;border-radius:14px;border:1px solid var(--border);background:rgba(15,23,42,.7);color:var(--text);font-weight:800}
.btn:hover{text-decoration:none;filter:brightness(1.08)}
.btn.primary{background:linear-gradient(135deg,rgba(56,189,248,.22),rgba(245,158,11,.12));border-color:rgba(56,189,248,.35)}
.btn .dot{width:8px;height:8px;border-radius:999px;background:var(--accent)}.btn.primary .dot{background:var(--accent2)}
.section-title{margin:34px 0 12px;font-size:1.15rem;color:rgba(229,231,235,.92);letter-spacing:.2px}

/* Home page: reduce header-to-hero gap (email removed on home) */
body.home header .container{padding-top:12px;padding-bottom:12px;}
body.home .hero{margin-top:0;}
.grid{display:grid;gap:16px}.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
@media (max-width:920px){.grid.cols-3{grid-template-columns:1fr}.grid.cols-2{grid-template-columns:1fr}.hero .content{padding:34px 20px 24px}}
.card{border:1px solid var(--border);background:linear-gradient(180deg,rgba(17,24,39,.76),rgba(17,24,39,.54));border-radius:var(--radius);padding:18px;box-shadow:0 10px 30px rgba(0,0,0,.22)}
.card h3{margin:0 0 6px;font-size:1.05rem}
.small{color:var(--muted);font-size:.98rem}
.kicker{color:rgba(56,189,248,.92);font-weight:800;font-size:.92rem;letter-spacing:.24px;text-transform:uppercase}
.icon{width:34px;height:34px;border-radius:12px;border:1px solid rgba(56,189,248,.25);background:rgba(56,189,248,.08);display:grid;place-items:center;margin-bottom:10px}
.icon svg{opacity:.95}
.notice{border:1px solid rgba(56,189,248,.22);background:rgba(56,189,248,.06);border-radius:16px;padding:12px 14px;color:rgba(229,231,235,.82);margin-top:16px}
.triptych{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:12px}
@media (max-width:920px){.triptych{grid-template-columns:1fr}}
.shot{border-radius:18px;overflow:hidden;border:1px solid var(--border);background:rgba(17,24,39,.6);box-shadow:0 12px 40px rgba(0,0,0,.25)}
.shot img{width:100%;height:220px;object-fit:cover;display:block}
.shot .label{padding:10px 12px;font-weight:900;letter-spacing:.5px;color:rgba(229,231,235,.92);text-align:center}
.gallery{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-top:14px}
@media (max-width:1100px){.gallery{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:560px){.gallery{grid-template-columns:1fr}}
.tile{border-radius:18px;overflow:hidden;border:1px solid var(--border);background:rgba(17,24,39,.52);box-shadow:0 12px 36px rgba(0,0,0,.24)}
.tile img{width:100%;height:180px;object-fit:cover;display:block}
.tile .cap{padding:12px}.tile .cap strong{display:block;margin-bottom:4px}
.breadcrumbs{font-size:.95rem;color:rgba(163,177,198,.9);margin:8px 0 14px}.breadcrumbs a{color:rgba(163,177,198,.9)}
hr{border:none;border-top:1px solid var(--border);margin:22px 0}
footer{border-top:1px solid var(--border);margin-top:38px;color:var(--muted);background:rgba(7,10,16,.25)}
footer .cols{display:grid;grid-template-columns:2fr 1fr 1fr;gap:16px}
@media (max-width:920px){footer .cols{grid-template-columns:1fr}}
/* Logo */
.logo{display:flex;align-items:center;gap:12px;text-decoration:none}
.logo-img{height:140px;width:auto;display:block;border-radius:0;box-shadow:none}
.logo-text{font-weight:700;letter-spacing:-.02em}
@media (max-width: 780px){
  .logo-text{display:none}
  .logo-img{height:90px}
}


/* Header logo + contact */
.logo{gap:16px;}
.logo img{height:420px;width:auto;display:block;filter:drop-shadow(0 10px 24px rgba(0,0,0,.35));}
@media (max-width:920px){.logo img{height:220px}}
.logo-text{display:flex;flex-direction:column;line-height:1.1}
.logo-email{font-weight:800;color:rgba(229,231,235,.92);font-size:1.05rem}
@media (max-width:920px){.logo-email{font-size:1rem}}
/* Hide any old logo mark box if present */
.logo-mark{display:none !important;}


/* v8 header layout: logo left, email right, no sticky */
.site-header{position:static !important; top:auto !important;}
.header-inner{display:flex; align-items:center; justify-content:space-between; gap:18px;}
.brand{display:flex; align-items:center; gap:14px;}
.brand .logo img{height:240px; width:auto; display:block; background:transparent; border-radius:999px;}
@media (max-width:920px){ .brand .logo img{height:140px;} }
.header-email{font-weight:800; color:rgba(229,231,235,.92); font-size:1.05rem; white-space:nowrap;}
@media (max-width:920px){ .header-email{font-size:0.98rem;} }

/* v9 logo: tighter crop + remove any borders */
.brand .logo img{border:0 !important; box-shadow:none !important; background:transparent !important;}
/* v9 header alignment: logo left, nav centered, email right */
.header-inner{align-items:flex-start;}
.navlinks{margin-top:26px;}
.header-email{margin-top:26px;}
@media (max-width:920px){
  .header-inner{flex-wrap:wrap;}
  .navlinks{margin-top:0;}
  .header-email{margin-top:0;}
}


/* v10 gallery sizing: prevent stretched, low-res look */
.gallery{max-width:1080px;margin-left:auto;margin-right:auto;}
.gallery .tile img{width:100%;height:auto;aspect-ratio:4/3;object-fit:cover;}
/* make tiles a bit narrower on large screens */
@media (min-width:1100px){
  .gallery{grid-template-columns:repeat(3,1fr) !important;}
}


/* v11 gallery grid: 4-up desktop, balanced, no distortion */
.gallery-grid{display:grid; gap:18px; grid-template-columns:repeat(2,1fr);}
@media (min-width:900px){ .gallery-grid{grid-template-columns:repeat(4,1fr);} }
.tile{display:block; border-radius:18px; overflow:hidden; background:rgba(17,24,39,.6); border:1px solid rgba(255,255,255,.08);}
.tile img{display:block; width:100%; height:auto; aspect-ratio:4/3; object-fit:cover;}
.tile-label{padding:12px 14px; font-weight:800; color:rgba(255,255,255,.92);}


/* v11 header alignment fixes */
.header-inner{align-items:flex-start;}
.header-email{margin-top:18px;}
@media (max-width:920px){ .header-email{margin-top:10px;} }


/* v16 logo-only override */
.logo img, .logo-img, .brand .logo img{
  filter:none !important;
  box-shadow:none !important;
  background:transparent !important;
  border:0 !important;
  outline:0 !important;
  border-radius:0 !important;
  padding:0 !important;
}

/* v19 override: 3-column home grid */
.home-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}


/* v20 override: home page cards same size as applications cards */
.home-gallery, .home-grid {
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

.home-gallery .card, .home-grid .card {
  height: 420px;
}

.home-gallery .card img, .home-grid .card img {
  height: 100%;
  object-fit: cover;
}

/* v20 override: enlarge logo 2.5x */
.logo img {
  height: 600px !important;
}


/* --- v23 header tightening + absolute logo sizing --- */
.site-header{padding-top:18px !important; padding-bottom:0px !important;}
.header-inner{align-items:flex-start !important;}
.navlinks{margin-top:18px !important;}
/* Make logo large but reduce empty space */
.brand .logo img{height:336px !important; width:auto !important; margin:0 !important; padding:0 !important; border:0 !important; box-shadow:none !important; background:transparent !important; border-radius:0 !important; filter:none !important;}
@media (max-width:920px){.brand .logo img{height:176px !important;}}
/* Remove any halo-like effects from CSS (if present elsewhere) */
.logo img{border:0 !important; box-shadow:none !important; background:transparent !important; filter:none !important;}


/* --- Logo cleanup override (v25) --- */
.brand .logo img,
.logo img,
.logo-img{
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  filter: none !important;
}


/* v27: hide residual logo halo using circular clip and background match */
.logo img{
  background:#020b16;
  border-radius:50%;
  padding:0;
  clip-path:circle(49.2% at 50% 50%);
}

/* v29 contact form grid */
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:16px;}
@media (max-width:780px){.form-grid{grid-template-columns:1fr;}}


/* v30 contact page layout: make enquiry form full width and keep map above */
.contact-layout{display:grid;grid-template-columns:1fr;gap:22px;}
.contact-form{width:100%;}
.map-box{border:1px solid rgba(255,255,255,.08);border-radius:18px;overflow:hidden;background:rgba(17,24,39,.45);}
.map-placeholder{padding:18px;}
.map-placeholder .small{opacity:.8;font-size:.95rem;margin-top:8px;}
.contact-bullets{margin:14px 0 0 18px;}
.map-embed{
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  overflow:hidden;
  background:rgba(17,24,39,.45);
}

.map-embed iframe{
  width:100%;
  height:320px;
  border:0;
  display:block;
}