/* ==========================================================================
   Laser Cleaning Experts LTD — Design System
   Fonts: Google Sans (with robust fallbacks)
   ========================================================================== */

@import url('https://fonts.cdnfonts.com/css/google-sans');

/* ---------- Design Tokens ---------- */
:root {
  /* Brand */
  --navy:        #12294a;
  --navy-2:      #1b3a63;
  --navy-dark:   #0c1c34;
  --green:       #6fae3d;
  --green-dark:  #4e8329;
  --green-light: #8cc63f;

  /* Neutrals */
  --ink:      #1c2733;
  --body:     #47535f;
  --muted:    #5c6672;
  --line:     #e5eaf1;
  --bg:       #ffffff;
  --bg-soft:  #f4f7fb;
  --bg-navy:  #0f223f;

  /* Effects */
  --shadow-sm: 0 2px 8px rgba(18, 41, 74, .06);
  --shadow:    0 12px 30px rgba(18, 41, 74, .10);
  --shadow-lg: 0 24px 60px rgba(18, 41, 74, .16);
  --radius:    16px;
  --radius-sm: 10px;
  --radius-lg: 26px;

  /* Layout */
  --container: 1200px;
  --gutter: clamp(20px, 5vw, 40px);

  /* Type */
  --font: 'Google Sans', 'Product Sans', -apple-system, BlinkMacSystemFont,
          'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;

  --header-h: 84px;
}

/* ---------- Reset / Base ---------- */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--font);
  color: var(--body);
  background: var(--bg);
  line-height: 1.65;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; transition: color .2s ease; }
ul { margin: 0; padding: 0; list-style: none; }
button { font-family: inherit; cursor: pointer; border: 0; background: none; }

h1, h2, h3, h4, h5 {
  font-family: var(--font);
  color: var(--ink);
  line-height: 1.15;
  margin: 0 0 .5em;
  font-weight: 700;
  letter-spacing: -0.02em;
}

h1 { font-size: clamp(2.3rem, 5vw, 3.7rem); }
h2 { font-size: clamp(1.9rem, 3.6vw, 2.8rem); }
h3 { font-size: clamp(1.25rem, 2vw, 1.6rem); }
p  { margin: 0 0 1rem; }

::selection { background: var(--green); color: #fff; }

/* ---------- Layout Helpers ---------- */
.container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--gutter);
}
.container-wide { max-width: 1360px; }

.section { padding: clamp(64px, 8vw, 112px) 0; }
.section-soft { background: var(--bg-soft); }
.section-navy {
  background:
    radial-gradient(900px 500px at 85% -10%, rgba(111,174,61,.18), transparent 60%),
    linear-gradient(160deg, var(--bg-navy), #0a1830);
  color: #d8e0ec;
}
.section-navy h1, .section-navy h2, .section-navy h3 { color: #fff; }

.narrow { max-width: 760px; }
.center { text-align: center; }
.mx-auto { margin-inline: auto; }

/* ---------- Section Heading ---------- */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: .82rem;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--green-dark);
  margin-bottom: 16px;
}
.eyebrow::before {
  content: "";
  width: 26px; height: 2px;
  background: var(--green);
  display: inline-block;
}
.eyebrow.center { justify-content: center; }
.section-navy .eyebrow { color: var(--green-light); }

.section-head { max-width: 720px; margin-bottom: 54px; }
.section-head.center { margin-inline: auto; }
.section-head p { font-size: 1.08rem; color: var(--muted); }
.section-navy .section-head p { color: #a9b6c9; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 15px 30px;
  border-radius: 100px;
  font-weight: 600;
  font-size: 1rem;
  letter-spacing: .01em;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
  white-space: nowrap;
  line-height: 1;
}
.btn svg { width: 18px; height: 18px; }
.btn-primary {
  background: linear-gradient(135deg, var(--green-light), var(--green-dark));
  color: #fff;
  box-shadow: 0 10px 24px rgba(78, 131, 41, .32);
}
.btn-primary:hover { transform: translateY(-3px); box-shadow: 0 16px 32px rgba(78,131,41,.42); color:#fff; }
.btn-navy { background: var(--navy); color: #fff; }
.btn-navy:hover { background: var(--navy-2); transform: translateY(-3px); color: #fff; }
.btn-outline {
  border: 2px solid var(--line);
  color: var(--ink);
  background: #fff;
}
.btn-outline:hover { border-color: var(--green); color: var(--green-dark); transform: translateY(-3px); }
.btn-ghost-light { border: 2px solid rgba(255,255,255,.35); color:#fff; }
.btn-ghost-light:hover { background: rgba(255,255,255,.1); border-color:#fff; color:#fff; transform: translateY(-3px); }
.btn-lg { padding: 18px 38px; font-size: 1.06rem; }
.btn-block { width: 100%; }

/* ---------- Header ---------- */
.site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  transition: background .3s ease, box-shadow .3s ease, padding .3s ease;
  padding: 14px 0;
}
.site-header.scrolled {
  background: rgba(255,255,255,.96);
  backdrop-filter: saturate(180%) blur(12px);
  box-shadow: var(--shadow-sm);
  padding: 8px 0;
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}
.brand { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.brand img { height: 54px; width: auto; transition: height .3s ease; display:block; }
.brand .logo-dark { display: none; }
.site-header.scrolled .brand .logo-light { display: none; }
.site-header.scrolled .brand .logo-dark { display: block; }
.site-header.scrolled .brand img { height: 46px; }
@media (max-width: 520px){ .brand img { height: 40px; } }

.nav { display: flex; align-items: center; gap: 4px; }
.nav-close { display: none; }
.nav a {
  padding: 10px 16px;
  font-weight: 500;
  font-size: .98rem;
  color: var(--navy);
  border-radius: 8px;
  position: relative;
}
.nav a:hover { color: var(--green-dark); }
.nav a.active { color: var(--green-dark); }
.nav a.active::after {
  content:""; position:absolute; left:16px; right:16px; bottom:4px;
  height:2px; background: var(--green); border-radius: 2px;
}

/* Header on transparent (top of page) uses white text unless scrolled */
.site-header:not(.scrolled) .nav a { color: #ffffff; text-shadow: 0 1px 8px rgba(0,0,0,.35); }
.site-header:not(.scrolled) .nav a:hover { color: var(--green-light); }
.site-header:not(.scrolled) .brand-fallback { color: #fff; }

.header-cta { display: flex; align-items: center; gap: 16px; flex-shrink: 0; }
.header-phone {
  display: inline-flex; align-items: center; gap: 9px;
  font-weight: 700; color: var(--navy); font-size: 1.02rem;
}
.header-phone .ph-icon {
  width: 38px; height: 38px; border-radius: 50%;
  background: var(--green); color:#fff; display:grid; place-items:center;
  flex-shrink: 0;
}
.header-phone .ph-icon svg { width: 18px; height: 18px; }
.site-header:not(.scrolled) .header-phone { color: #fff; }
.site-header:not(.scrolled) .header-phone span { text-shadow: 0 1px 8px rgba(0,0,0,.35); }

.nav-toggle { display: none; width: 46px; height: 46px; border-radius: 10px; }
.nav-toggle span { display:block; width: 24px; height: 2px; background: var(--navy); margin: 5px auto; border-radius: 2px; transition: .3s; }
.site-header:not(.scrolled) .nav-toggle span { background: #fff; }

/* ---------- Hero ---------- */
.hero {
  position: relative;
  color: #fff;
  padding: calc(var(--header-h) + 48px) 0 72px;
  overflow: hidden;
  background:
    radial-gradient(760px 460px at 88% 8%, rgba(111,174,61,.22), transparent 62%),
    radial-gradient(680px 520px at 6% 100%, rgba(27,58,99,.55), transparent 60%),
    linear-gradient(160deg, #102544 0%, #0a1830 100%);
}
.hero::before {
  content:""; position:absolute; inset:0; z-index:0; opacity:.5;
  background-image: radial-gradient(rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 26px 26px;
  -webkit-mask-image: linear-gradient(180deg, #000, transparent 70%);
          mask-image: linear-gradient(180deg, #000, transparent 70%);
}
.hero .container { position: relative; z-index: 1; }
.hero-grid { display: grid; grid-template-columns: 1.02fr .98fr; gap: clamp(32px, 5vw, 68px); align-items: center; }
.hero-content { max-width: 620px; }
.hero h1 { color: #fff; margin-bottom: 20px; }
.hero h1 .accent { color: var(--green-light); }
.hero-lead { font-size: 1.15rem; color: #cdd8e8; margin-bottom: 32px; max-width: 560px; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 34px; }
.hero-badges { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 26px; max-width: 500px; }
.hero-badge { display: flex; align-items: center; gap: 10px; font-weight: 500; font-size: .95rem; color: #eaf0f7; }
.hero-badge svg { width: 22px; height: 22px; color: var(--green-light); flex-shrink: 0; }

/* hero figure (real photo) */
.hero-figure { position: relative; }
.hero-figure > img {
  width: 100%; aspect-ratio: 4 / 4.4; object-fit: cover;
  border-radius: 22px; box-shadow: var(--shadow-lg);
  border: 1px solid rgba(255,255,255,.12);
}
.hero-figure .hf-badge {
  position: absolute; left: -18px; bottom: 26px;
  display: flex; align-items: center; gap: 13px;
  background: #fff; color: var(--ink); border-radius: 16px;
  padding: 14px 18px; box-shadow: var(--shadow-lg);
}
.hero-figure .hf-badge .hf-ico { width: 46px; height: 46px; border-radius: 12px; flex-shrink:0;
  background: linear-gradient(135deg, var(--green-light), var(--green-dark)); color:#fff; display:grid; place-items:center; }
.hero-figure .hf-badge .hf-ico svg { width: 26px; height: 26px; }
.hero-figure .hf-badge b { display:block; font-size: 1rem; line-height:1.1; }
.hero-figure .hf-badge small { color: var(--muted); font-size: .82rem; }
.hero-figure .hf-tag {
  position: absolute; top: 16px; right: 16px;
  background: rgba(12,28,52,.78); backdrop-filter: blur(6px);
  color:#fff; font-size:.74rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  padding: 7px 14px; border-radius: 100px; border:1px solid rgba(255,255,255,.18);
}

.hero-pill {
  display:inline-flex; align-items:center; gap:10px;
  background: rgba(140,198,63,.16);
  border: 1px solid rgba(140,198,63,.4);
  color: #eaf7d8; padding: 8px 16px; border-radius: 100px;
  font-size: .85rem; font-weight: 600; letter-spacing: .04em; margin-bottom: 26px;
}
.hero-pill .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green-light); box-shadow: 0 0 0 4px rgba(140,198,63,.25); }

/* page hero (interior pages) */
.page-hero {
  position: relative;
  padding: calc(var(--header-h) + 70px) 0 70px;
  color: #fff;
  overflow: hidden;
}
.page-hero-bg { position:absolute; inset:0; z-index:-2; }
.page-hero-bg img { width:100%; height:100%; object-fit:cover; }
.page-hero::after {
  content:""; position:absolute; inset:0; z-index:-1;
  background: linear-gradient(120deg, rgba(9,23,44,.93), rgba(12,30,55,.7));
}
.page-hero h1 { color:#fff; }
.page-hero p { color:#cdd7e5; font-size:1.12rem; max-width: 620px; }
.breadcrumb { display:flex; gap:8px; align-items:center; font-size:.9rem; color:#a9b6c9; margin-bottom:18px; }
.breadcrumb a:hover { color: var(--green-light); }
.breadcrumb span { opacity:.6; }

/* ---------- Trust strip ---------- */
.trust-strip { background: var(--navy); color:#fff; }
.trust-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px;
  padding: 28px 0;
}
.trust-item { display:flex; align-items:center; gap:14px; justify-content:center; }
.trust-item svg { width: 34px; height: 34px; color: var(--green-light); flex-shrink:0; }
.trust-item b { display:block; color:#fff; font-size: 1rem; line-height:1.2; }
.trust-item small { color:#9fb0c7; font-size:.82rem; }

/* ---------- Service Cards ---------- */
.grid { display: grid; gap: 28px; }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }

.service-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.service-card:hover { transform: translateY(-8px); box-shadow: var(--shadow-lg); border-color: transparent; }
.service-card .thumb { position: relative; aspect-ratio: 16 / 10; overflow: hidden; }
.service-card .thumb img { width:100%; height:100%; object-fit: cover; transition: transform .6s ease; }
.service-card:hover .thumb img { transform: scale(1.07); }
.service-card .thumb::after {
  content:""; position:absolute; inset:0;
  background: linear-gradient(to top, rgba(12,28,52,.35), transparent 55%);
}
.card-icon {
  position: absolute; left: 22px; top: -28px; z-index:3;
  width: 56px; height: 56px; border-radius: 14px;
  background: linear-gradient(135deg, var(--green-light), var(--green-dark));
  display: grid; place-items: center; color:#fff;
  box-shadow: 0 10px 20px rgba(78,131,41,.35);
}
.card-icon svg { width: 28px; height: 28px; }
.service-card .body { position: relative; padding: 44px 26px 26px; display:flex; flex-direction:column; flex:1; }
.service-card h3 { margin-bottom: 12px; }
.service-card .body > p { color: var(--muted); font-size: .97rem; }
.feature-list { margin: 6px 0 22px; display:flex; flex-direction:column; gap:9px; }
.feature-list li { display:flex; gap:10px; align-items:flex-start; font-size:.94rem; color: var(--body); }
.feature-list li svg { width:18px; height:18px; color: var(--green); flex-shrink:0; margin-top:3px; }
.service-card .card-link {
  margin-top: auto;
  display:inline-flex; align-items:center; gap:8px;
  font-weight:600; color: var(--green-dark); font-size:.95rem;
}
.service-card .card-link svg { width:16px; height:16px; transition: transform .2s ease; }
.service-card:hover .card-link svg { transform: translateX(4px); }

/* ---------- Feature Row (image + text) ---------- */
.feature-row { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(30px,5vw,64px); align-items:center; }
.feature-row.reverse .feature-media { order: 2; }
.feature-media { position: relative; }
.feature-media img { border-radius: var(--radius); box-shadow: var(--shadow); width:100%; aspect-ratio: 4/3; object-fit: cover; }
.feature-media .badge-float {
  position:absolute; background:#fff; border-radius: var(--radius-sm);
  box-shadow: var(--shadow); padding: 16px 20px; display:flex; align-items:center; gap:14px;
}
.feature-media .badge-float.bl { left:-18px; bottom:24px; }
.feature-media .badge-float .bf-ico { width:44px;height:44px;border-radius:12px;background:var(--green);display:grid;place-items:center;color:#fff;flex-shrink:0;}
.feature-media .badge-float .bf-ico svg{width:24px;height:24px;}
.feature-media .badge-float b{display:block;color:var(--ink);font-size:1.4rem;line-height:1;}
.feature-media .badge-float small{color:var(--muted);font-size:.82rem;}
.feature-text ul { display:grid; grid-template-columns: 1fr 1fr; gap: 12px 20px; margin: 22px 0 30px; }
.feature-text ul li { display:flex; gap:10px; align-items:flex-start; font-size:.97rem; color: var(--body); }
.feature-text ul li svg { width:20px;height:20px;color:var(--green);flex-shrink:0;margin-top:2px;}

/* ---------- Steps / Process ---------- */
.steps { display:grid; grid-template-columns: repeat(4,1fr); gap: 26px; counter-reset: step; }
.step { position: relative; padding-top: 12px; }
.step .num {
  width: 54px; height: 54px; border-radius: 50%;
  background: #fff; border: 2px solid var(--green);
  color: var(--green-dark); font-weight:700; font-size:1.3rem;
  display:grid; place-items:center; margin-bottom: 18px;
}
.section-navy .step .num { background: rgba(255,255,255,.06); border-color: var(--green-light); color:#fff; }
.step h3 { font-size: 1.2rem; margin-bottom: 8px; }
.step p { font-size:.95rem; color: var(--muted); }
.section-navy .step p { color:#a9b6c9; }
.steps.connected .step::before {
  content:""; position:absolute; top: 39px; left: 66px; right: -13px; height:2px;
  background: repeating-linear-gradient(90deg, var(--line) 0 8px, transparent 8px 16px);
}
.section-navy .steps.connected .step::before { background: repeating-linear-gradient(90deg, rgba(255,255,255,.2) 0 8px, transparent 8px 16px); }
.steps.connected .step:last-child::before { display:none; }

/* ---------- Stats ---------- */
.stats { display:grid; grid-template-columns: repeat(4,1fr); gap: 24px; }
.stat { text-align:center; }
.stat b { display:block; font-size: clamp(2.2rem,4vw,3rem); color: var(--green-light); font-weight:700; letter-spacing:-.02em; }
.stat span { color:#b9c5d6; font-size:.98rem; }

/* ---------- Why choose / icon list ---------- */
.perk { display:flex; gap:18px; align-items:flex-start; }
.perk .p-ico {
  width: 56px; height:56px; border-radius: 14px; flex-shrink:0;
  background: rgba(111,174,61,.12); color: var(--green-dark);
  display:grid; place-items:center;
}
.perk .p-ico svg { width: 28px; height:28px; }
.perk h3 { font-size: 1.18rem; margin-bottom:6px; }
.perk p { font-size:.96rem; color: var(--muted); margin:0; }

/* ---------- Gallery ---------- */
.gallery-grid { display:grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.gallery-item {
  position: relative; border-radius: var(--radius-sm); overflow:hidden;
  aspect-ratio: 4/3; cursor: pointer;
}
.gallery-item.tall { grid-row: span 2; aspect-ratio: 4/7; }
.gallery-item.gi-portrait { aspect-ratio: 3/4; }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition: transform .6s ease; }
.gallery-item:hover img { transform: scale(1.08); }
.gallery-item figcaption {
  position:absolute; inset:auto 0 0 0; padding: 30px 18px 16px; color:#fff;
  background: linear-gradient(to top, rgba(9,23,44,.9), transparent);
  font-weight:600; font-size:.98rem;
  transform: translateY(8px); opacity:0; transition:.3s;
}
.gallery-item:hover figcaption { transform:none; opacity:1; }
.gallery-item .tag {
  position:absolute; top:12px; left:12px; background: var(--green); color:#fff;
  font-size:.72rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase;
  padding:5px 12px; border-radius: 100px;
}

/* ---------- Before / After Slider ---------- */
.ba-slider {
  position: relative; border-radius: var(--radius); overflow: hidden;
  aspect-ratio: 16/10; user-select:none; box-shadow: var(--shadow);
}
.ba-slider img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.ba-after { clip-path: inset(0 0 0 50%); }
.ba-label {
  position:absolute; bottom:16px; padding:6px 14px; border-radius:100px;
  background: rgba(12,28,52,.75); color:#fff; font-size:.78rem; font-weight:700;
  letter-spacing:.06em; text-transform:uppercase;
}
.ba-label.before { left:16px; }
.ba-label.after  { right:16px; background: rgba(78,131,41,.9); }
.ba-handle {
  position:absolute; top:0; bottom:0; left:50%; width:3px; background:#fff;
  transform: translateX(-50%); cursor: ew-resize;
}
.ba-handle::after {
  content:""; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:46px; height:46px; border-radius:50%; background:#fff; box-shadow: var(--shadow);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none' stroke='%234e8329' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='15 18 9 12 15 6'/%3E%3Cpolyline points='9 18 3 12 9 6' transform='translate(12 0)'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:center;
}

/* ---------- Testimonials ---------- */
.testi-card {
  background:#fff; border:1px solid var(--line); border-radius: var(--radius);
  padding: 32px 30px; box-shadow: var(--shadow-sm); height:100%;
  display:flex; flex-direction:column;
}
.testi-stars { display:flex; gap:3px; margin-bottom:16px; color:#f5a623; }
.testi-stars svg { width:20px; height:20px; }
.testi-card blockquote { margin:0 0 22px; font-size:1.04rem; color: var(--ink); line-height:1.6; }
.testi-who { display:flex; align-items:center; gap:14px; margin-top:auto; }
.testi-who .avatar {
  width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--navy-2),var(--navy));
  color:#fff;display:grid;place-items:center;font-weight:700;flex-shrink:0;
}
.testi-who b { color: var(--ink); display:block; font-size:.98rem; }
.testi-who small { color: var(--muted); }

/* ---------- Industries / chips ---------- */
.chip-grid { display:grid; grid-template-columns: repeat(5,1fr); gap:16px; }
.chip {
  background:#fff; border:1px solid var(--line); border-radius: var(--radius-sm);
  padding: 26px 16px; text-align:center; transition:.25s;
}
.chip:hover { border-color: var(--green); box-shadow: var(--shadow-sm); transform: translateY(-4px); }
.chip .c-ico { width:52px;height:52px;margin:0 auto 12px;border-radius:12px;background: rgba(111,174,61,.12); color:var(--green-dark); display:grid;place-items:center;}
.chip .c-ico svg{width:26px;height:26px;}
.chip b { color: var(--ink); font-size:1rem; }

/* ---------- FAQ ---------- */
.faq { max-width: 820px; margin-inline:auto; }
.faq-item { border:1px solid var(--line); border-radius: var(--radius-sm); margin-bottom:14px; background:#fff; overflow:hidden; transition: box-shadow .2s; }
.faq-item.open { box-shadow: var(--shadow-sm); }
.faq-q { width:100%; display:flex; justify-content:space-between; align-items:center; gap:20px; padding: 20px 24px; text-align:left; font-weight:600; font-size:1.05rem; color: var(--ink); }
.faq-q .ico { flex-shrink:0; width:26px; height:26px; border-radius:50%; background: rgba(111,174,61,.12); color: var(--green-dark); display:grid; place-items:center; transition: transform .3s; }
.faq-item.open .faq-q .ico { transform: rotate(45deg); background: var(--green); color:#fff; }
.faq-q .ico svg{width:16px;height:16px;}
.faq-a { max-height:0; overflow:hidden; transition: max-height .35s ease; }
.faq-a .faq-a-inner { padding: 0 24px 22px; color: var(--muted); }

/* ---------- CTA band ---------- */
.cta-band {
  position: relative; overflow:hidden; color:#fff; border-radius: var(--radius-lg);
  padding: clamp(40px,6vw,68px) clamp(30px,6vw,72px);
  background:
    radial-gradient(700px 400px at 90% 10%, rgba(140,198,63,.28), transparent 60%),
    linear-gradient(140deg, var(--navy-2), var(--navy-dark));
}
.cta-band h2 { color:#fff; margin-bottom:14px; }
.cta-band p { color:#cbd6e6; font-size:1.1rem; max-width:560px; }
.cta-inner { display:flex; align-items:center; justify-content:space-between; gap:36px; flex-wrap:wrap; }
.cta-actions { display:flex; flex-direction:column; gap:14px; }
.cta-phone { font-size:1.7rem; font-weight:700; color:#fff; display:inline-flex; align-items:center; gap:12px; }
.cta-phone svg{width:26px;height:26px;color:var(--green-light);}

/* ---------- Contact ---------- */
.contact-grid { display:grid; grid-template-columns: 1fr 1.1fr; gap: clamp(30px,4vw,54px); align-items:start; }
.contact-info-card { }
.contact-line { display:flex; gap:16px; align-items:flex-start; padding: 18px 0; border-bottom:1px solid var(--line); }
.contact-line:last-child{border-bottom:0;}
.contact-line .ci-ico { width:50px;height:50px;border-radius:14px;flex-shrink:0;background: rgba(111,174,61,.12);color:var(--green-dark);display:grid;place-items:center;}
.contact-line .ci-ico svg{width:24px;height:24px;}
.contact-line b{display:block;color:var(--ink);font-size:1.05rem;margin-bottom:2px;}
.contact-line a, .contact-line span{color:var(--muted);}
.contact-line a:hover{color:var(--green-dark);}

.form-card { background:#fff; border:1px solid var(--line); border-radius: var(--radius); padding: clamp(26px,4vw,40px); box-shadow: var(--shadow); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.field { margin-bottom:18px; }
.field label { display:block; font-weight:600; font-size:.9rem; color: var(--ink); margin-bottom:7px; }
.field input, .field select, .field textarea {
  width:100%; padding: 13px 15px; border:1.5px solid var(--line); border-radius: 10px;
  font-family:inherit; font-size:.98rem; color: var(--ink); background:#fff; transition:.2s;
}
.field textarea { min-height: 130px; resize: vertical; }
.field input:focus, .field select:focus, .field textarea:focus { outline:none; border-color: var(--green); box-shadow: 0 0 0 4px rgba(111,174,61,.12); }
.form-note { font-size:.85rem; color: var(--muted); margin-top: 6px; }
.form-success { display:none; padding: 16px 18px; background: rgba(111,174,61,.12); border:1px solid var(--green); border-radius:10px; color: var(--green-dark); font-weight:600; margin-bottom: 18px; }
.form-success.show { display:block; }
.form-error { display:none; padding: 16px 18px; background: rgba(200,64,48,.10); border:1px solid #c9483a; border-radius:10px; color:#a5342a; font-weight:600; margin-bottom: 18px; }
.form-error.show { display:block; }
.hp-field { position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden; opacity:0; pointer-events:none; }

/* ---------- Footer ---------- */
.site-footer { background: var(--bg-navy); color:#a9b6c9; padding-top: 72px; }
.footer-grid { display:grid; grid-template-columns: 1.5fr 1fr 1fr 1.2fr; gap: 40px; padding-bottom: 50px; }
.footer-brand img { height: 58px; margin-bottom: 18px; filter: brightness(0) invert(1); }
.footer-brand p { color:#8ea0b8; font-size:.95rem; max-width: 300px; }
.footer-col h4 { color:#fff; font-size:1.05rem; margin-bottom:18px; }
.footer-col ul li { margin-bottom:11px; }
.footer-col ul a { color:#a9b6c9; font-size:.95rem; }
.footer-col ul a:hover { color: var(--green-light); }
.footer-contact li { display:flex; gap:12px; align-items:flex-start; margin-bottom:14px; font-size:.95rem; }
.footer-contact svg { width:20px;height:20px;color:var(--green-light);flex-shrink:0;margin-top:2px;}
.footer-contact a:hover { color:#fff; }
.footer-social { display:flex; gap:12px; margin-top:20px; }
.footer-social a { width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.07);display:grid;place-items:center;color:#cdd7e5;transition:.25s;}
.footer-social a:hover { background: var(--green); color:#fff; transform:translateY(-3px); }
.footer-social svg{width:18px;height:18px;}
.footer-bottom { border-top:1px solid rgba(255,255,255,.09); padding: 22px 0; display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:.88rem; color:#7f92ab; }
.footer-bottom a:hover{color:#fff;}

/* ---------- Before / After pair cards (real photos) ---------- */
.ba-pairs { display: grid; grid-template-columns: repeat(2, 1fr); gap: 26px; }
.ba-card { background:#fff; border:1px solid var(--line); border-radius: var(--radius); overflow:hidden; box-shadow: var(--shadow-sm); transition: transform .3s ease, box-shadow .3s ease; }
.ba-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.ba-duo { display: grid; grid-template-columns: 1fr 1fr; gap: 3px; background: var(--line); }
.ba-shot { position: relative; overflow: hidden; }
.ba-shot img { width:100%; aspect-ratio: 3/4; object-fit: cover; display:block; }
.ba-shot .lbl { position:absolute; top:12px; left:12px; font-size:.7rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; padding:5px 11px; border-radius:100px; color:#fff; }
.ba-shot.is-before .lbl { background: rgba(12,28,52,.85); }
.ba-shot.is-after .lbl { background: var(--green); }
.ba-card .ba-cap { padding: 16px 20px; display:flex; align-items:center; gap:12px; }
.ba-card .ba-cap .bc-ico { width:40px; height:40px; border-radius:11px; flex-shrink:0; background: rgba(111,174,61,.12); color:var(--green-dark); display:grid; place-items:center; }
.ba-card .ba-cap .bc-ico svg { width:22px; height:22px; }
.ba-card .ba-cap b { color:var(--ink); font-size:1.04rem; display:block; line-height:1.2; }
.ba-card .ba-cap span { color:var(--muted); font-size:.88rem; }

/* ---------- Video block ---------- */
.video-band { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(30px,5vw,60px); align-items:center; }
.video-wrap { position:relative; border-radius: var(--radius); overflow:hidden; box-shadow: var(--shadow-lg); background:#0a1830; }
.video-wrap video { width:100%; display:block; max-height: 62vh; }
.video-wrap .vw-tag { position:absolute; top:14px; left:14px; z-index:2; background: var(--green); color:#fff; font-size:.72rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; padding:6px 13px; border-radius:100px; }
@media (max-width: 860px){ .video-band { grid-template-columns: 1fr; } }
@media (max-width: 520px){ .ba-pairs { grid-template-columns: 1fr; } }

/* ---------- Credits ---------- */
.credits-list { display:grid; grid-template-columns: repeat(2,1fr); gap:16px; }
.credit { display:flex; gap:16px; align-items:center; background:#fff; border:1px solid var(--line); border-radius: var(--radius-sm); padding:14px; }
.credit img { width:88px; height:66px; object-fit:cover; border-radius:8px; flex-shrink:0; }
.credit .c-body b { display:block; color:var(--ink); font-size:.95rem; line-height:1.3; margin-bottom:3px; }
.credit .c-body span { display:block; color:var(--muted); font-size:.85rem; }
.credit .c-body small { display:block; color:var(--green-dark); font-size:.78rem; font-weight:600; margin-top:4px; text-transform:uppercase; letter-spacing:.04em; }
.credit a { color:var(--navy-2); font-weight:600; }
.credit a:hover { color:var(--green-dark); }
@media (max-width:720px){ .credits-list { grid-template-columns:1fr; } }

/* ---------- Floating call (mobile) ---------- */
.float-call {
  position: fixed; right: 18px; bottom: 18px; z-index: 900;
  width: 60px; height:60px; border-radius:50%;
  background: var(--green); color:#fff; display:none; place-items:center;
  box-shadow: 0 12px 26px rgba(78,131,41,.5);
  animation: pulse 2.2s infinite;
}
.float-call svg{width:26px;height:26px;}
@keyframes pulse { 0%{box-shadow:0 0 0 0 rgba(111,174,61,.55);} 70%{box-shadow:0 0 0 16px rgba(111,174,61,0);} 100%{box-shadow:0 0 0 0 rgba(111,174,61,0);} }

/* ---------- Scroll reveal ---------- */
.reveal { opacity:0; transform: translateY(28px); transition: opacity .7s ease, transform .7s ease; }
.reveal.in { opacity:1; transform:none; }
.reveal.d1{transition-delay:.08s;} .reveal.d2{transition-delay:.16s;} .reveal.d3{transition-delay:.24s;} .reveal.d4{transition-delay:.32s;}

/* ---------- Back to top ---------- */
.to-top { position:fixed; right:18px; bottom:88px; z-index:900; width:46px;height:46px;border-radius:12px; background:var(--navy); color:#fff; display:grid;place-items:center; opacity:0; pointer-events:none; transform:translateY(10px); transition:.3s; }
.to-top.show { opacity:1; pointer-events:auto; transform:none; }
.to-top svg{width:20px;height:20px;}

/* ---------- Responsive ---------- */
@media (max-width: 1024px) {
  .grid-4 { grid-template-columns: repeat(2,1fr); }
  .chip-grid { grid-template-columns: repeat(3,1fr); }
  .steps { grid-template-columns: repeat(2,1fr); }
  .steps.connected .step::before { display:none; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
}
@media (max-width: 860px) {
  :root { --header-h: 72px; }
  /* backdrop-filter on an ancestor breaks position:fixed children (the menu panel),
     so use a solid header on mobile instead */
  .site-header.scrolled { background: #fff; -webkit-backdrop-filter: none; backdrop-filter: none; }
  .nav, .header-phone { display: none; }
  .nav-toggle { display:block; }
  .nav {
    position: fixed; top:0; right:0; bottom:0; width: min(320px, 84vw);
    background:#fff; flex-direction:column; align-items:stretch; gap:0;
    padding: 90px 24px 30px; box-shadow: -20px 0 60px rgba(0,0,0,.18);
    transform: translateX(100%); transition: transform .35s ease; z-index: 1001;
  }
  .nav.open { transform:none; display:flex; }
  .nav-close {
    display:grid; place-items:center; position:absolute; top:16px; right:16px;
    width:44px; height:44px; border-radius:11px; background:var(--bg-soft);
    color:var(--navy); border:1px solid var(--line);
  }
  .nav-close svg { width:22px; height:22px; }
  .site-header:not(.scrolled) .nav a, .nav a { color: var(--navy) !important; text-shadow:none !important; }
  .nav a { padding: 14px 12px; border-bottom:1px solid var(--line); font-size:1.05rem; }
  .nav a.active::after{display:none;}
  .nav .btn { margin-top: 18px; }
  .nav-backdrop { position:fixed; inset:0; background:rgba(9,23,44,.5); z-index:1000; opacity:0; pointer-events:none; transition:.3s; }
  .nav-backdrop.show{opacity:1;pointer-events:auto;}
  .float-call { display:grid; }
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .feature-row, .feature-row.reverse .feature-media { grid-template-columns: 1fr; order: initial; }
  .feature-text ul { grid-template-columns: 1fr; }
  .trust-grid { grid-template-columns: repeat(2,1fr); gap: 22px; }
  .stats { grid-template-columns: repeat(2,1fr); gap: 30px; }
  .contact-grid { grid-template-columns: 1fr; }
  .gallery-grid { grid-template-columns: repeat(2,1fr); }
  .gallery-item.tall { grid-row: span 1; aspect-ratio:4/3; }
  .cta-inner { flex-direction:column; align-items:flex-start; }
  .cta-actions { width:100%; }
  .cta-phone { font-size:1.45rem; flex-wrap:wrap; }
  .hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .hero-figure { max-width: 460px; margin-inline: auto; width: 100%; }
  .hero-badges { max-width: none; }
  .hero { min-height: auto; }
}
@media (max-width: 520px) {
  body { font-size: 16px; }
  .form-row { grid-template-columns: 1fr; }
  .chip-grid { grid-template-columns: 1fr 1fr; }
  .gallery-grid { grid-template-columns: 1fr; }
  .trust-grid { grid-template-columns: 1fr 1fr; gap: 28px 14px; }
  .trust-item { flex-direction: column; text-align: center; gap: 10px; }
  .footer-grid { grid-template-columns: 1fr; }
  .hero-actions .btn { width: 100%; }
}
