/* ---------- Inspired Solutions , site styles ----------
   Colour palette derived from the logo:
   navy #0a2a5e · royal #1e6bd6 · sky #5aa3ff · grey #6c7785
*/

:root{
  --navy:      #0a2a5e;
  --navy-2:    #0e3a82;
  --royal:     #1e6bd6;
  --sky:       #5aa3ff;
  --grey:      #6c7785;
  --ink:       #0b1530;
  --ink-soft:  #2b3553;
  --line:      #e6ebf3;
  --bg:        #ffffff;
  --bg-soft:   #f5f7fb;
  --bg-tint:   #eef3fb;
  --green:     #22c55e;
  --green-2:   #16a34a;
  --shadow-sm: 0 2px 8px rgba(10,42,94,.06);
  --shadow:    0 18px 40px -18px rgba(10,42,94,.30);
  --shadow-lg: 0 28px 60px -20px rgba(10,42,94,.35);
  --radius:    16px;
  --radius-lg: 22px;
  --container: 1200px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:'Inter','Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  font-size:16px;line-height:1.55;color:var(--ink);background:var(--bg);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
h1,h2,h3,h4{font-family:'Plus Jakarta Sans','Inter',sans-serif;line-height:1.1;letter-spacing:-.02em;margin:0 0 .5em;color:var(--ink)}
h1{font-size:clamp(2.2rem,5.4vw,4rem);font-weight:800}
h2{font-size:clamp(1.7rem,3.2vw,2.6rem);font-weight:700}
h3{font-size:1.2rem;font-weight:700}
p{margin:0 0 1em}

.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.section{padding:96px 0}
.section--alt{background:linear-gradient(180deg,var(--bg-soft) 0%,var(--bg) 100%)}
.section__head{max-width:760px;margin:0 auto 56px;text-align:center}
.section__lead{color:var(--grey);font-size:1.075rem}

.skip-link{position:absolute;left:-999px;top:0;padding:8px 12px;background:var(--navy);color:#fff;z-index:1000}
.skip-link:focus{left:8px;top:8px}

/* ----- icons ----- */
.i{width:1em;height:1em;display:inline-block;vertical-align:-.18em;color:currentColor}
.i::before{content:"";display:inline-block;width:1em;height:1em;background:currentColor;
  -webkit-mask:var(--mask) center/contain no-repeat; mask:var(--mask) center/contain no-repeat;}
.i-phone   { --mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M6.6 10.8a15 15 0 0 0 6.6 6.6l2.2-2.2a1 1 0 0 1 1-.25 11.4 11.4 0 0 0 3.6.58 1 1 0 0 1 1 1V20a1 1 0 0 1-1 1A17 17 0 0 1 3 4a1 1 0 0 1 1-1h3.5a1 1 0 0 1 1 1 11.4 11.4 0 0 0 .58 3.6 1 1 0 0 1-.25 1l-2.23 2.2Z'/></svg>"); }
.i-whatsapp{ --mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M20.5 3.5A11.8 11.8 0 0 0 2.3 18.3L1 23l4.8-1.26A11.8 11.8 0 1 0 20.5 3.5Zm-8.5 18a9.5 9.5 0 0 1-4.84-1.32l-.35-.2-2.85.75.76-2.78-.22-.36A9.5 9.5 0 1 1 12 21.5Zm5.43-7.1c-.3-.15-1.75-.86-2.02-.96s-.47-.15-.66.15-.76.95-.93 1.14-.34.22-.64.08a7.8 7.8 0 0 1-3.84-3.35c-.29-.5.29-.46.83-1.55a.52.52 0 0 0-.02-.5c-.07-.14-.66-1.59-.9-2.18s-.48-.5-.66-.5h-.56a1.08 1.08 0 0 0-.78.36 3.27 3.27 0 0 0-1.03 2.44c0 1.44 1.05 2.83 1.2 3.02s2.08 3.17 5.05 4.45a17 17 0 0 0 1.69.62 4.06 4.06 0 0 0 1.86.12 3.04 3.04 0 0 0 2-1.41 2.48 2.48 0 0 0 .17-1.41c-.07-.13-.27-.21-.57-.35Z'/></svg>"); }
.i-mail    { --mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M3 5h18a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V6a1 1 0 0 1 1-1Zm9 8.6L4 7v11h16V7Z'/></svg>"); }
.i-arrow   { --mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M5 12h12.2l-4.6-4.6 1.4-1.4L21 12l-7 7-1.4-1.4 4.6-4.6H5z'/></svg>"); }
.i-card    { --mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M3 4h18a1 1 0 0 1 1 1v14a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V5a1 1 0 0 1 1-1Zm1 6h16V6H4Z'/></svg>"); }
.i-bolt    { --mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M13 2 4 14h6l-1 8 9-12h-6z'/></svg>"); }
.i-drop    { --mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M12 2s7 8 7 13a7 7 0 1 1-14 0c0-5 7-13 7-13Z'/></svg>"); }
.i-flame   { --mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M12 2s5 4 5 9a5 5 0 1 1-10 0c0-2 1-3 1-3s1 2 2 2c0-3 2-8 2-8Z'/></svg>"); }
.i-house   { --mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M3 11 12 3l9 8v10h-6v-6h-6v6H3z'/></svg>"); }
.i-extend  { --mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M3 11 9 6v3h6V6l6 5v10h-6v-6h-6v6H3z'/></svg>"); }
.i-bath    { --mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M5 11V6a2 2 0 1 1 4 0v1h2v2H4v3a3 3 0 0 0 1 2.2V17h2v-1h10v1h2v-2.8a3 3 0 0 0 1-2.2v-1H5Z'/></svg>"); }
.i-kitchen { --mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M4 3h16v6H4Zm0 8h16v10H4Z'/></svg>"); }
.i-brush   { --mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M20 3 8 15l-2-2L18 1Zm-13 14a3 3 0 1 1-3-3l3-2 2 2-2 3Z'/></svg>"); }
.i-window  { --mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M4 3h16v18H4Zm2 2v7h5V5Zm7 0v7h5V5ZM6 14v5h5v-5Zm7 0v5h5v-5Z'/></svg>"); }
.i-roof    { --mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='m2 12 10-8 10 8-2 2-8-6-8 6Zm2 2h16v6H4Z'/></svg>"); }
.i-tile    { --mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M3 3h8v8H3zm10 0h8v8h-8zM3 13h8v8H3zm10 0h8v8h-8z'/></svg>"); }
.i-tools   { --mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M22 7l-3-3-3 3 1 1-7 7-3-3-3 3 3 3 3-3 3 3 7-7 1 1 4-4Z'/></svg>"); }
.i-shield  { --mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M12 2 4 5v7c0 5 3.5 8.5 8 10 4.5-1.5 8-5 8-10V5Z'/></svg>"); }
.i-clock   { --mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M12 2a10 10 0 1 0 10 10A10 10 0 0 0 12 2Zm1 11h-5v-2h3V6h2Z'/></svg>"); }
.i-medal   { --mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M12 14a5 5 0 1 1 5-5 5 5 0 0 1-5 5Zm-3 1 3 7 3-7-3 1Z'/></svg>"); }

/* ----- buttons ----- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  padding:.85em 1.4em;border-radius:999px;font-weight:600;line-height:1;font-size:.95rem;
  transition:transform .15s ease,box-shadow .2s ease,background .2s ease,color .2s ease,border-color .2s ease;
  white-space:nowrap;border:1px solid transparent;
}
.btn--sm{padding:.6em 1em;font-size:.875rem}
.btn--lg{padding:1em 1.5em;font-size:1rem}
.btn--block{width:100%}
.btn--primary{background:linear-gradient(135deg,var(--royal) 0%,var(--navy-2) 100%);color:#fff;box-shadow:var(--shadow)}
.btn--primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}
.btn--ghost{background:#fff;color:var(--ink);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--royal);color:var(--royal)}
.btn--whatsapp{background:linear-gradient(135deg,#25d366 0%,#128c7e 100%);color:#fff;box-shadow:var(--shadow)}
.btn--whatsapp:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}
.btn .i{font-size:1.05em}

.btn__spinner{display:none;width:18px;height:18px;border:2px solid rgba(255,255,255,.5);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}
.btn[aria-busy="true"] .btn__label{opacity:.6}
.btn[aria-busy="true"] .btn__spinner{display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}

/* ----- eyebrows ----- */
.eyebrow{display:inline-flex;align-items:center;gap:.5em;font-size:.78rem;font-weight:600;color:var(--royal);
  letter-spacing:.08em;text-transform:uppercase;background:rgba(30,107,214,.08);padding:.45em .8em;border-radius:999px;margin-bottom:1.25em}
.eyebrow--light{background:rgba(255,255,255,.12);color:#fff}
.eyebrow__dot{width:6px;height:6px;border-radius:50%;background:var(--royal)}
.eyebrow--light .eyebrow__dot{background:#fff}

/* ----- header ----- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.85);backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid rgba(10,42,94,.06)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:14px 24px;max-width:var(--container);margin:0 auto}
.brand{display:flex;align-items:center;gap:12px}
.brand__logo{width:48px;height:48px;object-fit:contain}
.brand__text{display:flex;flex-direction:column;line-height:1.05}
.brand__name{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;color:var(--navy);font-size:1.05rem;letter-spacing:-.01em}
.brand__tag{font-size:.72rem;color:var(--grey);font-weight:500}
.nav__menu{display:flex;gap:24px;align-items:center}
.nav__menu a{font-weight:500;color:var(--ink-soft);font-size:.95rem;position:relative}
.nav__menu a:hover{color:var(--royal)}
.nav__menu a::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--royal);transform:scaleX(0);transform-origin:left;transition:transform .2s}
.nav__menu a:hover::after{transform:scaleX(1)}
.nav__cta{display:flex;gap:10px}
.nav__toggle{display:none;width:40px;height:40px;border-radius:10px;align-items:center;justify-content:center;flex-direction:column;gap:4px;border:1px solid var(--line)}
.nav__toggle span{width:18px;height:2px;background:var(--ink);border-radius:2px;transition:transform .2s,opacity .2s}
.nav__toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav__toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

.mobile-menu{display:none;flex-direction:column;padding:20px 24px;border-top:1px solid var(--line);background:#fff}
.mobile-menu a{padding:14px 0;border-bottom:1px solid var(--line);font-weight:600;color:var(--ink)}
.mobile-menu__cta{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:16px}

/* ----- hero ----- */
.hero{position:relative;overflow:hidden;padding:80px 0 100px;background:linear-gradient(180deg,#fff 0%,var(--bg-tint) 100%)}
.hero__bg{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.hero__grid{position:absolute;inset:0;
  background-image:linear-gradient(rgba(30,107,214,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(30,107,214,.06) 1px,transparent 1px);
  background-size:48px 48px;mask-image:radial-gradient(ellipse at 50% 0%,#000 0%,transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse at 50% 0%,#000 0%,transparent 70%);
}
.hero__blob{position:absolute;border-radius:50%;filter:blur(70px);opacity:.55}
.hero__blob--1{width:480px;height:480px;background:radial-gradient(circle,var(--sky),transparent 60%);top:-100px;right:-100px}
.hero__blob--2{width:380px;height:380px;background:radial-gradient(circle,var(--royal),transparent 60%);bottom:-80px;left:-60px;opacity:.35}

.hero__inner{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center}
.hero__copy h1{margin:0 0 .35em}
.hero__copy .grad{background:linear-gradient(135deg,var(--royal),var(--navy));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero__lead{font-size:1.125rem;color:var(--ink-soft);max-width:560px;margin-bottom:1.8em}
.hero__cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:2em}
.hero__trust{list-style:none;padding:0;margin:0;display:flex;gap:24px;flex-wrap:wrap;color:var(--grey);font-size:.92rem}
.hero__trust strong{color:var(--ink);font-weight:600}

.hero__card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:28px;border:1px solid var(--line);position:relative}
.hero__card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.status{display:inline-flex;align-items:center;gap:.5em;font-size:.82rem;font-weight:600;color:var(--green-2)}
.status__dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px rgba(34,197,94,.18);animation:pulse 1.8s ease-in-out infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 4px rgba(34,197,94,.18)}50%{box-shadow:0 0 0 8px rgba(34,197,94,0)}}
.hero__card-hint{font-size:.78rem;color:var(--grey)}
.hero__card h3{margin-top:6px}
.hero__card>p{color:var(--grey);margin-bottom:1.2em}

.quick-actions{display:grid;gap:10px}
.quick{display:flex;align-items:center;gap:14px;padding:12px;border:1px solid var(--line);border-radius:14px;transition:all .2s}
.quick:hover{border-color:var(--royal);background:var(--bg-tint);transform:translateX(2px)}
.quick__icon{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,var(--royal),var(--navy-2));color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.quick__icon--green{background:linear-gradient(135deg,#25d366,#128c7e)}
.quick__title{font-weight:700;display:block;font-size:.95rem}
.quick__sub{font-size:.82rem;color:var(--grey)}

.trust-strip{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-top:64px;padding:16px 20px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-sm)}
.trust-strip__label{font-size:.85rem;color:var(--grey);font-weight:600;margin-right:8px}
.trust-strip__chip{padding:6px 12px;background:var(--bg-tint);color:var(--navy);border-radius:999px;font-size:.82rem;font-weight:600}

/* ----- services grid ----- */
.grid{display:grid;gap:20px}
.services{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;transition:transform .2s,box-shadow .2s,border-color .2s}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:rgba(30,107,214,.25)}
.service__icon{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,rgba(30,107,214,.12),rgba(10,42,94,.08));color:var(--royal);display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:14px}
.service h3{margin-bottom:.4em}
.service p{margin:0;color:var(--grey);font-size:.95rem}
.services__note{text-align:center;margin-top:32px;color:var(--grey);font-size:.95rem}
.services__note a{color:var(--royal);font-weight:600;text-decoration:underline;text-decoration-color:rgba(30,107,214,.3);text-underline-offset:3px}
.services__note code{background:var(--bg-tint);padding:2px 6px;border-radius:4px;font-size:.85em}

/* ----- metrics ----- */
.metrics{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-2) 60%,var(--royal) 100%);color:#fff;padding:60px 0;position:relative;overflow:hidden}
.metrics::before{content:"";position:absolute;inset:0;background-image:
  radial-gradient(circle at 10% 30%,rgba(90,163,255,.18),transparent 40%),
  radial-gradient(circle at 90% 70%,rgba(90,163,255,.15),transparent 40%)}
.metrics__inner{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.metric{display:flex;flex-direction:column;align-items:center}
.metric__num{font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(2.2rem,4vw,3.4rem);font-weight:800;line-height:1;display:inline-block}
.metric__suffix{font-size:1.4rem;font-weight:700;vertical-align:top;margin-left:2px}
.metric__lbl{margin-top:8px;font-size:.92rem;color:rgba(255,255,255,.75)}

/* ----- before / after ----- */
.gallery{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}
.ba{position:relative;margin:0;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;background:#0e1c3a;cursor:ew-resize;box-shadow:var(--shadow);user-select:none}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
.ba__after{clip-path:inset(0 0 0 50%);transition:clip-path .05s linear}
.ba__handle{position:absolute;top:0;bottom:0;left:50%;width:3px;background:#fff;transform:translateX(-50%);pointer-events:none;box-shadow:0 0 0 1px rgba(0,0,0,.15)}
.ba__handle::before,.ba__handle::after{content:"";position:absolute;top:50%;left:50%;width:36px;height:36px;border-radius:50%;background:#fff;transform:translate(-50%,-50%);box-shadow:0 4px 14px rgba(0,0,0,.25)}
.ba__handle::after{width:18px;height:18px;background:transparent;border:2px solid var(--royal);border-top-color:transparent;border-bottom-color:transparent}
.ba__tag{position:absolute;top:12px;padding:4px 10px;border-radius:999px;font-size:.72rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;backdrop-filter:blur(6px);color:#fff}
.ba__tag--before{left:12px;background:rgba(11,21,48,.6)}
.ba__tag--after{right:12px;background:rgba(30,107,214,.85)}
.ba figcaption{position:absolute;left:0;right:0;bottom:0;padding:14px 16px;background:linear-gradient(0deg,rgba(11,21,48,.85),transparent);color:#fff;font-size:.92rem;font-weight:500}

/* ----- about ----- */
.about{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:center}
.about__copy h2{margin-bottom:.5em}
.about__copy p{color:var(--ink-soft)}
.ticks{list-style:none;padding:0;margin:1.5em 0;display:grid;gap:10px}
.ticks li{position:relative;padding-left:30px;color:var(--ink-soft)}
.ticks li::before{content:"";position:absolute;left:0;top:6px;width:18px;height:18px;border-radius:50%;background:var(--royal) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='m9.55 17.6-5.3-5.3 1.4-1.4 3.9 3.9 8.4-8.4 1.4 1.4Z'/></svg>") center/14px no-repeat}
.about__cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:1.5em}

.about__visual{position:relative;height:440px}
.about__card{position:absolute;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px 22px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:4px}
.about__card .i{font-size:1.5rem;color:var(--royal);margin-bottom:4px}
.about__card strong{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.05rem}
.about__card span{font-size:.85rem;color:var(--grey)}
.about__card--1{top:0;left:0;width:240px;transform:rotate(-3deg)}
.about__card--2{top:160px;right:0;width:240px;transform:rotate(2deg)}
.about__card--3{bottom:0;left:80px;width:240px;transform:rotate(-1deg)}
.about__card--1 .i{color:var(--royal)}
.about__card--2 .i{color:var(--green-2)}
.about__card--3 .i{color:var(--navy)}

/* ----- reviews ----- */
.reviews{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.review{margin:0;padding:28px}
.stars{color:#f59e0b;font-size:1.1rem;letter-spacing:.1em;margin-bottom:12px}
.review p{font-style:italic;color:var(--ink);font-size:1.02rem;margin-bottom:1em}
.review footer{font-size:.88rem;color:var(--grey)}

.reviews-placeholder{max-width:640px;margin:0 auto;text-align:center;padding:48px 32px}
.reviews-placeholder__icon{width:64px;height:64px;border-radius:18px;margin:0 auto 18px;
  background:linear-gradient(135deg,rgba(30,107,214,.15),rgba(10,42,94,.1));
  color:var(--royal);display:flex;align-items:center;justify-content:center;font-size:1.7rem}
.reviews-placeholder h3{font-size:1.35rem;margin-bottom:.5em}
.reviews-placeholder p{color:var(--ink-soft);max-width:480px;margin:0 auto 1.4em}
.reviews-placeholder__cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:1.4em}
.reviews-placeholder__hint{font-size:.82rem;color:var(--grey);margin:0}

/* ----- enquire ----- */
.enquire{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-2) 60%,var(--royal) 100%);color:#fff;position:relative;overflow:hidden}
.enquire::before{content:"";position:absolute;inset:0;background:
  radial-gradient(circle at 80% 20%,rgba(90,163,255,.25),transparent 50%),
  radial-gradient(circle at 10% 90%,rgba(255,255,255,.07),transparent 50%);
  pointer-events:none}
.enquire__inner{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.enquire h2{color:#fff;margin-bottom:.5em}
.enquire__copy>p{color:rgba(255,255,255,.85);max-width:480px}
.enquire__contacts{display:grid;gap:14px;margin-top:32px}
.contact-row{display:flex;align-items:center;gap:16px;padding:16px 20px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:14px;transition:all .2s}
.contact-row:hover{background:rgba(255,255,255,.12);transform:translateX(3px)}
.contact-row__ico{width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,.15);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.15rem;flex-shrink:0}
.contact-row__ico--green{background:linear-gradient(135deg,#25d366,#128c7e)}
.contact-row strong{display:block;font-size:1rem;color:#fff}
.contact-row small{color:rgba(255,255,255,.7);font-size:.82rem}

.enquire__form{background:#fff;color:var(--ink);padding:32px}
.enquire__form h3{margin-bottom:24px;font-size:1.35rem}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.field label{font-size:.85rem;font-weight:600;color:var(--ink-soft)}
.field input,.field select,.field textarea{
  width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;font:inherit;font-size:.95rem;color:var(--ink);background:#fff;transition:border-color .15s,box-shadow .15s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--royal);box-shadow:0 0 0 3px rgba(30,107,214,.15)}
.field textarea{resize:vertical;min-height:90px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field-row .field{margin-bottom:16px}
.form__small{font-size:.78rem;color:var(--grey);margin-top:10px;text-align:center}
.form__success{margin-top:14px;padding:14px 16px;background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.3);border-radius:10px;color:var(--green-2);display:flex;flex-direction:column;gap:4px}
.form__success strong{color:var(--green-2)}
.form__success span{font-size:.88rem;color:var(--ink-soft)}
.form__error{margin-top:14px;padding:14px 16px;background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.3);border-radius:10px;color:#b91c1c;font-size:.9rem}

/* ----- footer ----- */
.site-footer{background:var(--ink);color:rgba(255,255,255,.75);padding:56px 0 24px}
.footer__inner{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:48px;margin-bottom:32px}
.footer__brand{display:flex;align-items:center;gap:14px}
.footer__brand strong{display:block;color:#fff;font-family:'Plus Jakarta Sans',sans-serif;font-size:1.05rem}
.footer__brand span{font-size:.85rem}
.footer__nav,.footer__contact{display:flex;flex-direction:column;gap:8px;font-size:.9rem}
.footer__nav a:hover,.footer__contact a:hover{color:#fff}
.footer__base{display:flex;justify-content:space-between;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);font-size:.82rem;color:rgba(255,255,255,.5);flex-wrap:wrap;gap:12px}

/* ----- floating WhatsApp ----- */
.fab{position:fixed;right:20px;bottom:20px;z-index:60;display:inline-flex;align-items:center;gap:8px;padding:14px 18px;border-radius:999px;
  background:linear-gradient(135deg,#25d366,#128c7e);color:#fff;font-weight:600;box-shadow:0 12px 28px rgba(18,140,126,.4);font-size:.95rem;
  transition:transform .2s,box-shadow .2s}
.fab:hover{transform:translateY(-2px) scale(1.03);box-shadow:0 16px 36px rgba(18,140,126,.5)}
.fab .i{font-size:1.25rem}
.fab__label{display:inline}

/* ----- responsive ----- */
@media (max-width: 960px){
  .section{padding:72px 0}
  .nav__menu,.nav__cta{display:none}
  .nav__toggle{display:inline-flex}
  .hero{padding:48px 0 64px}
  .hero__inner{grid-template-columns:1fr;gap:36px}
  .hero__card{order:2}
  .about{grid-template-columns:1fr;gap:48px}
  .about__visual{height:auto;display:grid;grid-template-columns:1fr 1fr;gap:14px}
  .about__card{position:static;width:auto;transform:none!important}
  .about__card--3{grid-column:span 2}
  .enquire__inner{grid-template-columns:1fr;gap:40px}
  .metrics__inner{grid-template-columns:repeat(2,1fr);gap:32px}
  .footer__inner{grid-template-columns:1fr;gap:32px}
  .fab__label{display:none}
  .fab{padding:14px}
  .field-row{grid-template-columns:1fr}
}
@media (max-width:520px){
  .hero__trust{gap:14px;font-size:.82rem}
  .trust-strip{margin-top:40px}
  .ba{aspect-ratio:1.2/1}
}

/* ----- reveal on scroll ----- */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.is-visible{opacity:1;transform:none}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}
