/*
Theme Name: MDX Electrical Light
Theme URI: 
Author: StarlitDevs
Author URI: 
Description: 
Requires at least: 6.9
Tested up to: 6.9
Requires PHP: 5.7
Version: 
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: mdx-electrical-light
Tags: 
*/

*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}
:root {
    --white: #ffffff;
    --bg: #f7fbff;
    --bg2: #eef6ff;
    --bg3: #e4f0ff;
    --ink: #0c1a2e;
    --ink2: #1a2d47;
    --ink3: #263d5c;
    --steel: #3b5270;
    --mid: #4f6d8a;
    --muted: #7a96b0;
    --pale: #a8bdd0;
    --border: rgba(22, 101, 192, 0.1);
    --border2: rgba(22, 101, 192, 0.18);
    --blue: #1664c0;
    --blue2: #1976d2;
    --blue3: #42a5f5;
    --bluet: rgba(22, 100, 192, 0.07);
    --blueb: rgba(22, 100, 192, 0.16);
    --grad: linear-gradient(135deg, #03ceef 0%, #057aba 100%);
    --gradh: linear-gradient(160deg, #f0f8ff 0%, #e8f4ff 50%, #edf6ff 100%);
}
html {
    scroll-behavior: smooth;
}
body {
    font-family: "Inter", sans-serif;
    color: var(--ink);
    background: var(--white);
    line-height: 1.6;
    overflow-x: hidden;
}
.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}
h1 {
    font-size: 58px;
}

/* NAV */
nav {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 300;
    height: 72px;
    display: flex;
    align-items: center;
    border-bottom: 1px solid var(--border);
}
nav::before {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(255, 255, 255, 0.94);
    backdrop-filter: blur(24px);
}
.nav-in {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
    position: relative;
    z-index: 1;
}
.nav-logo {
    display: flex;
    align-items: center;
    gap: 14px;
    text-decoration: none;
}
.nav-logo img{
    width: 100%;
}
.nav-logo-word {
    font-family: "Barlow Condensed", sans-serif;
    font-weight: 900;
    font-size: 26px;
    letter-spacing: 0.08em;
    color: var(--ink);
}
.nav-logo-word em {
    font-style: normal;
    background: var(--grad);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.nav-logo-rule {
    width: 1px;
    height: 28px;
    background: var(--border2);
}
.nav-logo-sub {
    font-size: 10px;
    font-weight: 300;
    color: var(--muted);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    line-height: 1.4;
}
.nav-links {
    display: flex;
    align-items: center;
    list-style: none;
    gap: 2px;
}
.nav-links a {
    color: var(--mid);
    text-decoration: none;
    font-size: 11px;
    font-weight: 400;
    padding: 8px 14px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    transition: color 0.2s;
}
.nav-links a:hover {
    color: var(--blue);
}
.nav-actions {
    display: flex;
    align-items: center;
    gap: 16px;
}
.nav-google {
    display: flex;
    align-items: center;
    gap: 8px;
    text-decoration: none;
}
.nav-google-right {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.nav-google-stars {
    display: flex;
    gap: 2px;
}
.nav-google-stars svg {
    width: 12px;
    height: 12px;
    fill: #fbbc05;
}
.nav-google-label {
    font-family: "Inter", sans-serif;
    font-size: 9px;
    font-weight: 600;
    letter-spacing: 0.06em;
    color: var(--muted);
}
.nav-google-logo {
    width: 44px;
    height: auto;
    display: block;
}
.nav-divider {
    width: 1px;
    height: 32px;
    background: var(--border);
}
.nav-phone {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    text-decoration: none;
    gap: 1px;
}
.nav-phone-label {
    font-family: "Inter", sans-serif;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--muted);
}
.nav-phone-num {
    font-family: "Inter", sans-serif;
    font-size: 14px;
    font-weight: 700;
    color: var(--ink);
    letter-spacing: 0.01em;
}
.nav-phone:hover .nav-phone-num {
    color: var(--blue);
}
.nav-cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--grad);
    color: var(--white);
    border: none;
    padding: 10px 22px;
    border-radius: 14px;
    font-family: "Inter", sans-serif;
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
    letter-spacing: 0;
    transition: opacity 0.2s;
}
.nav-cta:hover {
    opacity: 0.88;
}
.menu-btn {
    display: none;
}
.btn {
    border: none;
    display: grid;
    place-items: center;
    color: var(--white);
    background: var(--grad);
    padding: 5px 8px;
    border-radius: 4px;
    cursor: pointer;
}
.mobile-menu {
    display: none;
    position: absolute;
    top: 0;
    height: 100vh;
    width: 50%;
    background-color: var(--bg3);
    z-index: 10;
    padding: 40px;
    transition: all 0.6s ease;
}
.mobile-menu .nav-links li {
    width: 100%;
}
.mobile-menu .nav-links a {
    font-size: 14px;
    padding-inline: 0;
    display: block;
    padding-inline: 5px;
}
.menu-close {
    position: absolute;
    top: 20px;
    right: 20px;
}
.left-0 {
    left: 0;
}
.left-50 {
    left: -50%;
}
.overlay {
    position: fixed;
    inset: 0;
    background-color: #000;
    z-index: 50;
    opacity: 0;
    cursor: pointer;
    pointer-events: none;
    transition: all 0.5s ease;
}
.overlay.active {
    opacity: 0.5;
    pointer-events: auto;
}
body.no-scroll {
    overflow: hidden;
}

/* Responsive */
@media (max-width: 1199.98px) {
    .nav-links {
        display: none;
    }
    .menu-btn {
        display: block;
    }
    .mobile-menu {
        display: block;
    }
    .mobile-menu .nav-links {
        display: flex;
        flex-direction: column;
        align-items: start;
        padding-top: 20px;
    }
}
@media (max-width: 991.98px) {
    .left-50 {
        left: -60%;
    }
    .mobile-menu {
        width: 60%;
    }
}
@media (max-width: 767.98px) {
    .nav-logo {
        max-width: 160px;
    }
    .nav-google {
        display: none;
    }
    .nav-divider {
        display: none;
    }
    .nav-phone {
        display: none;
    }
    .nav-actions {
        gap: 7px;
    }
  .nav-cta {
	padding: 10px 16px;
}
    .left-50 {
        left: -100%;
    }
    .mobile-menu {
        width: 100%;
    }
}

/* HERO */
#hero {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding-top: 72px;
    position: relative;
    overflow: hidden;
    background: var(--gradh);
}
.hero-bg {
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 55% 50% at 72% 38%, rgba(22, 100, 192, 0.07) 0%, transparent 65%),
        radial-gradient(ellipse 35% 55% at 8% 82%, rgba(41, 182, 232, 0.05) 0%, transparent 60%);
    pointer-events: none;
}
.hero-grid {
    position: absolute;
    inset: 0;
    background-image: linear-gradient(rgba(22, 101, 192, 0.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(22, 101, 192, 0.04) 1px, transparent 1px);
    background-size: 80px 80px;
    pointer-events: none;
}
.hero-accent-top {
    position: absolute;
    top: 72px;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--grad);
}
.hero-in {
    max-width: 1200px;
    margin: 0 auto;
    padding: 48px 20px;
    width: 100%;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 72px;
    align-items: center;
    position: relative;
    z-index: 2;
}
.hero-eyebrow {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 28px;
}
.hero-eyebrow-line {
    width: 36px;
    height: 1px;
    background: var(--blue);
    flex-shrink: 0;
}
.hero-eyebrow span {
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: var(--blue);
}
.hero-h1 {
    font-family: "Barlow Condensed", sans-serif;
    font-weight: 900;
    line-height: 0.88;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--ink);
    margin-bottom: 28px;
}
.hero-h1 em {
    display: block;
    font-style: normal;
    font-family: "Inter", sans-serif;
    font-weight: 300;
    font-size: 0.22em;
    letter-spacing: 0.06em;
    text-transform: none;
    color: var(--mid);
    -webkit-text-fill-color: var(--mid);
    background: none;
    margin-top: 14px;
}
.hero-desc p {
    font-size: 14px;
    font-weight: 400;
    color: var(--mid);
    line-height: 1.85;
    max-width: 500px;
    margin-bottom: 40px;
    letter-spacing: 0.01em;
}
.hero-desc p strong {
    color: var(--ink);
    font-weight: 500;
}
.hero-actions {
    display: flex;
    gap: 14px;
    align-items: center;
    margin-bottom: 52px;
}
.btn-gold {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: var(--grad);
    color: var(--white);
    font-family: "Inter", sans-serif;
    font-size: 13px;
    font-weight: 600;
    padding: 14px 28px;
    border-radius: 14px;
    text-decoration: none;
    letter-spacing: 0;
    text-transform: none;
    transition:
        opacity 0.2s,
        transform 0.15s;
}
.btn-gold:hover {
    opacity: 0.88;
    transform: translateY(-1px);
}
.btn-outline {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--blue);
    font-family: "Inter", sans-serif;
    font-size: 13px;
    font-weight: 500;
    padding: 14px 28px;
    border-radius: 14px;
    text-decoration: none;
    letter-spacing: 0;
    text-transform: none;
    border: 1px solid var(--border2);
    transition: all 0.2s;
}
.btn-outline:hover {
    background: var(--bluet);
    border-color: var(--blue);
}
.hero-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.hero-pill {
    font-size: 10px;
    font-weight: 400;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--muted);
    padding: 6px 12px;
    border: 1px solid var(--border);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.7);
    transition: all 0.2s;
}
.hero-pill:hover {
    border-color: var(--border2);
    color: var(--blue);
    background: var(--white);
}

/* Responsive */
@media (max-width: 991.98px) {
    .hero-in {
        display: flex;
        flex-direction: column;
        padding-inline: 20px;
    }
    .hero-eyebrow {
        margin-bottom: 18px;
    }
    .hero-h1 {
        margin-bottom: 20px;
    }
    .hero-desc p{
        margin-bottom: 30px;
    }
    .hero-trust {
        margin-bottom: 20px;
    }
    .hero-actions {
        margin-bottom: 32px;
    }
    .hero-form-box {
        width: 100%;
    }
}
@media (max-width: 767.98px) {
    h1 {
        font-size: 36px;
    }
    .hero-in {
        gap: 50px;
    }
    .hero-trust {
        gap: 10px !important;
        margin-bottom: 30px !important;
    }
}

/* HERO FORM */
.hero-form {
    background: var(--white);
    border: 1px solid var(--border2);
    border-radius: 20px;
    overflow: hidden;
    box-shadow:
        0 16px 48px rgba(22, 101, 192, 0.12),
        0 2px 8px rgba(22, 101, 192, 0.06);
}
.hf-head {
    padding: 22px 26px;
    border-bottom: 1px solid var(--border);
    background: var(--ink);
    display: flex;
    align-items: center;
    gap: 14px;
}
.hf-head-ico {
    width: 32px;
    height: 32px;
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.hf-head-ico svg {
    width: 15px;
    height: 15px;
    fill: none;
    stroke: rgba(255, 255, 255, 0.7);
    stroke-width: 1.5;
    stroke-linecap: round;
    stroke-linejoin: round;
}
.hf-title {
    font-family: "Inter", sans-serif;
    font-weight: 600;
    font-size: 16px;
    letter-spacing: 0;
    text-transform: none;
    color: var(--white);
    margin-bottom: 3px;
}
.hf-sub {
    font-size: 11px;
    font-weight: 300;
    color: rgba(255, 255, 255, 0.5);
    letter-spacing: 0.04em;
}
.hf-body {
    padding: 22px 26px;
}
.hf-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}
.hfg {
    margin-bottom: 10px;
}
.hfg label {
    display: block;
    font-size: 11px;
    font-weight: 500;
    color: var(--steel);
    margin-bottom: 5px;
    letter-spacing: 0;
    text-transform: none;
}
.hfg input,
.hfg select,
.hfg textarea {
    width: 100%;
    padding: 9px 12px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 14px;
    font-family: "Inter", sans-serif;
    font-size: 13px;
    color: var(--ink);
    outline: none;
    transition: all 0.15s;
    -webkit-appearance: none;
}
.hfg input::placeholder,
.hfg textarea::placeholder {
    color: var(--pale);
}
.hfg input:focus,
.hfg select:focus,
.hfg textarea:focus {
    border-color: var(--blue2);
    box-shadow: 0 0 0 3px rgba(22, 101, 192, 0.08);
}
.hfg textarea {
    resize: none;
    height: 60px;
}
.hf-submit {
    width: 100%;
    background: var(--grad);
    color: var(--white);
    border: none;
    padding: 13px;
    border-radius: 14px;
    font-family: "Inter", sans-serif;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    margin-top: 4px;
    transition: opacity 0.2s;
    letter-spacing: 0;
    text-transform: none;
}
.hf-submit:hover {
    opacity: 0.88;
}

/* Google badges under form */
.hf-badges {
    padding: 14px 26px;
    border-top: 1px solid var(--border);
    display: flex;
    align-items: center;
    gap: 24px;
    background: var(--bg);
}
.hf-badge-item {
    display: flex;
    align-items: center;
    gap: 8px;
}
.hf-badge-logo {
    font-size: 13px;
    font-weight: 700;
    letter-spacing: -0.01em;
}
.hf-badge-logo .g-g {
    color: #4285f4;
}
.hf-badge-logo .g-o1 {
    color: #ea4335;
}
.hf-badge-logo .g-o2 {
    color: #fbbc05;
}
.hf-badge-logo .g-l {
    color: #4285f4;
}
.hf-badge-logo .g-e {
    color: #34a853;
}
.hf-badge-logo .fb {
    color: #1877f2;
}
.hf-badge-stars {
    display: flex;
    gap: 2px;
}
.hf-badge-stars svg {
    width: 12px;
    height: 12px;
    fill: #fbbc05;
}
.hf-badge-divider {
    width: 1px;
    height: 28px;
    background: var(--border);
}
.hf-call {
    padding: 14px 26px;
    border-top: 1px solid var(--border);
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--white);
}
.hf-call-ico {
    width: 28px;
    height: 28px;
    border: 1px solid var(--border2);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.hf-call-ico svg {
    width: 13px;
    height: 13px;
    fill: none;
    stroke: var(--blue);
    stroke-width: 2;
    stroke-linecap: round;
}
.hf-call a {
    font-weight: 600;
    font-size: 14px;
    color: var(--ink);
    text-decoration: none;
}
.hf-call a:hover {
    color: var(--blue);
}
.hf-call span {
    font-size: 11px;
    color: var(--muted);
}

/* CREDENTIALS STRIP */
#cred-strip {
    background: var(--ink);
    padding: 0;
}
.cred-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    max-width: 1200px;
    margin: 0 auto;
}
.cred-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 28px 20px;
    border-right: 1px solid rgba(255, 255, 255, 0.07);
    text-align: center;
    transition: background 0.2s;
}
.cred-item:last-child {
    border-right: none;
}
.cred-item:hover {
    background: rgba(255, 255, 255, 0.04);
}
.cred-ico {
    width: 38px;
    height: 38px;
    border: 1px solid rgba(41, 182, 232, 0.25);
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(41, 182, 232, 0.06);
}
.cred-ico svg {
    width: 16px;
    height: 16px;
    fill: none;
    stroke: var(--blue3);
    stroke-width: 1.5;
    stroke-linecap: round;
    stroke-linejoin: round;
}
.cred-txt {
    font-size: 10px;
    font-weight: 400;
    color: rgba(255, 255, 255, 0.5);
    letter-spacing: 0.1em;
    text-transform: uppercase;
}
.cred-div {
    display: none;
}

/* STATS BAR */
#stats-bar {
    background: var(--grad);
    border-bottom: none;
    padding: 32px 0;
}
.stats-inner {
    max-width: 900px;
    margin: 0 auto;
    padding: 0 20px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}
.stat-tile {
    padding: 36px 32px;
    text-align: center;
    position: relative;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.18);
}
.stat-tile:last-child {
    border-right: none;
}
.stat-tile::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 2px;
    background: rgba(255, 255, 255, 0.5);
    transition: width 0.4s ease;
}
.stat-tile.visible::after {
    width: 40px;
}
.stat-tile-ico {
    width: 40px;
    height: 40px;
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 16px;
}
.stat-tile-ico svg {
    width: 19px;
    height: 19px;
    fill: none;
    stroke: rgba(255, 255, 255, 0.9);
    stroke-width: 1.5;
    stroke-linecap: round;
    stroke-linejoin: round;
}
.stat-num {
    font-family: "Inter", sans-serif;
    font-weight: 700;
    font-size: 48px;
    line-height: 1;
    color: var(--white);
    letter-spacing: -0.01em;
}
.stat-plus {
    font-size: 0.6em;
    color: rgba(255, 255, 255, 0.7);
    font-weight: 400;
}
.stat-label {
    font-size: 11px;
    font-weight: 300;
    color: rgba(255, 255, 255, 0.65);
    margin-top: 8px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

/* Responsive */
@media (max-width: 767.98px) {
    .stats-inner {
        grid-template-columns: repeat(1, 1fr);
    }
}

/* SHARED SECTION */
.sec {
    padding: 100px 0;
}
.sec-dark {
    background: var(--ink);
}
.sec-darker {
    background: var(--bg);
}
.sec-mid {
    background: var(--bg2);
}
.sec-light {
    background: var(--white);
}
.sh-eyebrow {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 18px;
}
.sh-eyebrow-line {
    width: 32px;
    height: 1px;
    background: var(--blue);
    flex-shrink: 0;
}
.sh-eyebrow span {
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--blue);
}
.sh-eyebrow--white span {
    color: rgba(255, 255, 255, 0.7);
}
.sh-eyebrow--center {
    justify-content: center;
}
.sh-h2 {
    font-family: "Barlow Condensed", sans-serif;
    font-weight: 900;
    font-size: clamp(32px, 4.5vw, 58px);
    line-height: 1;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    margin-bottom: 14px;
    color: var(--ink);
}
.sh-h2 em {
    font-style: normal;
    background: var(--grad);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.sh-h2--white {
    color: var(--white);
}
.sh-h2--white em {
    background: none;
    -webkit-text-fill-color: rgba(255, 255, 255, 0.7);
    color: rgba(255, 255, 255, 0.7);
}
.sh-p p {
    font-size: 14px;
    font-weight: 400;
    color: var(--mid);
    max-width: 520px;
    line-height: 1.85;
}
.sh-p--center {
	display: flex;
	justify-content: center;
}
.sh-mb {
    margin-bottom: 60px;
}
.center {
    text-align: center;
}

.ind-btn {
  display:inline-flex;
  align-items:center;
  gap:10px;
  background:var(--white);
  color:var(--blue);
  font-size:14px;
  font-weight:600;
  padding:16px 36px;
  border-radius:14px;
  text-decoration:none;
  letter-spacing:0;
  text-transform:none;
  transition:opacity .2s,transform .15s;
  box-shadow:0 4px 20px rgba(0,0,0,.15)
}

/* PILLARS */
.pillars {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}
.pillar {
    padding: 44px 40px;
    border: 1px solid var(--border);
    border-radius: 20px;
    position: relative;
    transition:
        background 0.25s,
        box-shadow 0.25s;
    background: var(--white);
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    overflow: hidden;
}
.pillar:last-child {
    border-right: 1px solid var(--border);
}
.pillar::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    border-radius: 20px 20px 0 0;
    background: transparent;
    transition: background 0.3s;
}
.pillar:hover::before {
    background: var(--grad);
}
.pillar:hover {
    background: var(--bluet);
    box-shadow: 0 8px 32px rgba(22, 101, 192, 0.1);
    border-color: var(--border2);
}
.pi-ico {
    width: 48px;
    height: 48px;
    background: var(--bluet);
    border: 1px solid var(--border);
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 14px;
    transition: background 0.25s;
}
.pillar:hover .pi-ico {
    background: var(--bg2);
}
.pi-ico svg {
    width: 22px;
    height: 22px;
    fill: none;
    stroke: var(--blue);
    stroke-width: 1.5;
    stroke-linecap: round;
    stroke-linejoin: round;
}
.pi-num {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: "Inter", sans-serif;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.04em;
    color: var(--blue);
    text-transform: none;
    margin-bottom: 16px;
    padding: 5px 12px 5px 8px;
    background: var(--bluet);
    border: 1px solid rgba(22, 100, 192, 0.15);
    border-radius: 99px;
}
.pi-num::before {
    content: "";
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--grad);
    flex-shrink: 0;
}
.pi-h3 {
    font-family: "Inter", sans-serif;
    font-weight: 700;
    font-size: 16px;
    color: var(--ink);
    margin-bottom: 12px;
    letter-spacing: 0;
    text-transform: none;
}
.pi-p {
    font-size: 13px;
    font-weight: 400;
    color: var(--mid);
    line-height: 1.8;
}

/* Responsive */
@media (max-width: 991.98px) {
    .pillars {
        grid-template-columns: repeat(2, 1fr);
    }
}
@media (max-width: 767.98px) {
    .pillars {
        grid-template-columns: repeat(1, 1fr);
    }
    .sh-mb {
        margin-bottom: 40px;
    }
}

/* SERVICES */
.svc-layout {
    display: grid;
    grid-template-columns: 1fr 1.65fr;
    gap: 64px;
    align-items: stretch;
}
.svc-list {
    display: flex;
    flex-direction: column;
    border: 1px solid var(--border);
    border-radius: 16px;
    overflow: hidden;
}
.svc-item {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 18px 22px;
    border-bottom: 1px solid var(--border);
    cursor: pointer;
    transition: all 0.18s;
    position: relative;
    background: var(--white);
}
.svc-item:last-child {
    border-bottom: none;
}
.svc-item::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 2px;
    background: transparent;
    transition: background 0.2s;
}
.svc-item:hover::before,
.svc-item.active::before {
    background: var(--grad);
}
.svc-item:hover,
.svc-item.active {
    background: var(--bluet);
}
.svc-item-ico {
    width: 36px;
    height: 36px;
    border: 1px solid var(--border);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: border-color 0.18s;
    background: var(--bg);
}
.svc-item:hover .svc-item-ico,
.svc-item.active .svc-item-ico {
    border-color: var(--border2);
    background: var(--white);
}
.svc-item-ico svg {
    width: 16px;
    height: 16px;
    fill: none;
    stroke: var(--blue);
    stroke-width: 1.5;
    stroke-linecap: round;
}
.svc-item-name {
    font-family: "Inter", sans-serif;
    font-weight: 600;
    font-size: 14px;
    color: var(--ink);
    letter-spacing: 0;
    text-transform: none;
}
.svc-item-tag {
    font-size: 10px;
    color: var(--muted);
    margin-top: 2px;
    letter-spacing: 0.06em;
}
.svc-item-arrow {
    margin-left: auto;
    color: var(--pale);
    transition: color 0.18s;
    flex-shrink: 0;
}
.svc-item:hover .svc-item-arrow,
.svc-item.active .svc-item-arrow {
    color: var(--blue);
}
.svc-item-arrow svg {
    width: 14px;
    height: 14px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.5;
    stroke-linecap: round;
}
.svc-detail {
    border: 1px solid var(--border);
    border-radius: 20px;
    overflow: hidden;
    background: var(--white);
    display: flex;
    flex-direction: column;
    height: 100%;
}
.svc-detail-body {
    padding: 28px 32px;
    flex: 1;
    display: flex;
    flex-direction: column;
}
.svc-detail-img {
    width: 100%;
    aspect-ratio: 16/9;
    background: var(--ink);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
}
.svc-detail-img::before {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--grad);
    opacity: 0.18;
}
.svc-detail-img::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, transparent 40%, rgba(12, 26, 46, 0.8));
}
.sdi-pattern {
    position: absolute;
    inset: 0;
    background-image: repeating-linear-gradient(
        135deg,
        rgba(255, 255, 255, 0.03) 0px,
        rgba(255, 255, 255, 0.03) 1px,
        transparent 1px,
        transparent 60px
    );
    z-index: 1;
}
.svc-big-ico {
    position: relative;
    z-index: 2;
    opacity: 0.2;
}
.svc-big-ico svg {
    width: 72px;
    height: 72px;
    fill: none;
    stroke: var(--white);
    stroke-width: 0.8;
    stroke-linecap: round;
}
.sdi-label {
    position: absolute;
    bottom: 18px;
    left: 22px;
    z-index: 3;
}
.sdi-badge {
    font-family: "Inter", sans-serif;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.02em;
    text-transform: none;
    color: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(255, 255, 255, 0.3);
    padding: 5px 14px;
    border-radius: 99px;
    background: rgba(22, 101, 192, 0.45);
    backdrop-filter: blur(6px);
}
.svc-detail-h3 {
    font-family: "Barlow Condensed", sans-serif;
    font-weight: 900;
    font-size: 26px;
    color: var(--ink);
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-bottom: 10px;
}
.svc-detail-p {
    font-size: 13px;
    font-weight: 400;
    color: var(--mid);
    line-height: 1.85;
    
}
.svc-detail-p p {
	margin-bottom: 22px;
}
.svc-detail-p ul {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.svc-detail-p ul li {
	position: relative;
  padding-left: 32px;
	font-size: 13px;
	font-weight: 400;
	color: var(--ink2);
	letter-spacing: .02em;  
  line-height: 1.6;
}
.svc-detail-p ul li::before {
	content: '';
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpolyline points='20 6 9 17 4 12' fill='none' stroke='currentColor' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3C/polyline%3E%3C/svg%3E");
	width: 20px;
	height: 20px;
	background-color: var(--bluet);
	border: 1px solid rgba(22,101,192,.2);
	position: absolute;
	top: 0;
	left: 0;
	border-radius: 50%;
	background-size: 12px;
	background-repeat: no-repeat;
	background-position: center;
}

.svc-pts {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.svc-pt {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 13px;
    font-weight: 400;
    color: var(--ink2);
    letter-spacing: 0.02em;
}
.svc-pt-tick {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--bluet);
    border: 1px solid rgba(22, 101, 192, 0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.svc-pt-tick svg {
    width: 11px;
    height: 11px;
    fill: none;
    stroke: var(--blue);
    stroke-width: 2.5;
    stroke-linecap: round;
    stroke-linejoin: round;
}


.svc-tab-panel {
  display: none;
}
.svc-tab-panel.active {
  display: block;
}

.svc-tab-img {
	position: absolute;
	width: 100%;
	height: 100%;
}
.svc-tab-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}






/* Responsive */
@media (max-width: 991.98px) {
    .svc-layout {
        grid-template-columns: 1fr;
    }
}
@media (max-width: 767.98px) {
    .svc-layout {
        gap: 40px;
    }
}

/* ABOUT */
.about-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
}
.about-img-wrap {
    position: relative;
}
.about-img-ph {
    width: 100%;
    aspect-ratio: 3/4;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 14px;
    position: relative;
    overflow: hidden;
}
.about-img-ph::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: linear-gradient(rgba(22, 101, 192, 0.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(22, 101, 192, 0.05) 1px, transparent 1px);
    background-size: 40px 40px;
}
.about-img-ph svg {
    width: 64px;
    height: 64px;
    fill: none;
    stroke: var(--border2);
    stroke-width: 1;
    position: relative;
    z-index: 1;
}
.about-img-ph p {
    font-size: 11px;
    letter-spacing: 0.1em;
    color: var(--pale);
    text-transform: uppercase;
    position: relative;
    z-index: 1;
}
.about-stat {
    position: absolute;
    bottom: -16px;
    left: -16px;
    background: var(--grad);
    padding: 18px 22px;
    border-radius: 16px;
}
.about-stat-num {
    font-family: "Inter", sans-serif;
    font-weight: 700;
    font-size: 28px;
    color: var(--white);
    line-height: 1;
}
.about-stat-label {
    font-size: 10px;
    color: rgba(255, 255, 255, 0.7);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    margin-top: 2px;
}
.stat-tile {
    padding: 36px 32px;
    text-align: center;
    position: relative;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.18);
    transition:
        background 0.25s,
        transform 0.25s,
        box-shadow 0.25s;
    cursor: default;
}
.stat-tile:hover {
    background: rgba(255, 255, 255, 0.2);
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.15);
}
.about-cert {
    position: absolute;
    top: -16px;
    right: -16px;
    background: var(--white);
    border: 1px solid var(--border2);
    padding: 12px 18px;
    display: flex;
    align-items: center;
    gap: 8px;
    box-shadow: 0 4px 16px rgba(22, 101, 192, 0.1);
}
.about-cert-dot {
    width: 7px;
    height: 7px;
    background: #22c55e;
    border-radius: 50%;
    flex-shrink: 0;
}
.about-cert-txt {
    font-family: "Inter", sans-serif;
    font-size: 12px;
    font-weight: 500;
    color: var(--ink);
    letter-spacing: 0;
    text-transform: none;
}
.about-h2 {
    font-family: "Barlow Condensed", sans-serif;
    font-weight: 900;
    font-size: clamp(34px, 4vw, 50px);
    line-height: 1;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: var(--ink);
    margin-bottom: 20px;
}
.about-h2 em {
    font-style: normal;
    background: var(--grad);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.about-content p {
    font-size: 14px;
    font-weight: 400;
    color: var(--mid);
    line-height: 1.85;
    margin-bottom: 14px;
}
.about-content ul {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin: 26px 0 36px;
}
.about-content ul li {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 13px;
    font-weight: 400;
    color: var(--ink2);
    letter-spacing: 0.02em;
}
.about-content ul li::before {
    content: "";
    width: 20px;
    height: 1px;
    background: var(--blue);
    flex-shrink: 0;
}





/* Responsive */
@media (max-width: 1199.98px) {
    .about-grid {
        gap: 60px;
    }
}
@media (max-width: 767.98px) {
    .about-grid {
        grid-template-columns: 1fr;
    }
    .about-img-ph {
        aspect-ratio: 1;
    }
    #about {
        padding-top: 100px;
    }
    .sec {
        padding-block: 60px;
    }
}

/* PROJECTS */
.proj-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}
.proj {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 20px;
    position: relative;
    overflow: hidden;
    cursor: pointer;
    transition:
        box-shadow 0.25s,
        border-color 0.25s;
}
.proj:hover {
    box-shadow: 0 10px 40px rgba(22, 101, 192, 0.1);
    border-color: var(--border2);
}
.proj:hover .proj-overlay {
    opacity: 1;
}
.proj-img {
    width: 100%;
    aspect-ratio: 3/2;
    background: var(--bg2);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
}
.proj-img svg {
    width: 64px;
    height: 64px;
    fill: none;
    stroke: var(--border2);
    stroke-width: 1;
    stroke-linecap: round;
}
.proj-img::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, transparent 40%, rgba(12, 26, 46, 0.55));
}
.proj-overlay {
    position: absolute;
    inset: 0;
    background: rgba(22, 101, 192, 0.06);
    opacity: 0;
    transition: opacity 0.3s;
    border: 1px solid var(--border2);
    z-index: 2;
}
.proj-tag {
    position: absolute;
    top: 14px;
    left: 14px;
    z-index: 3;
    font-family: "Inter", sans-serif;
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: none;
    color: var(--white);
    border: 1px solid rgba(255, 255, 255, 0.4);
    padding: 4px 10px;
    border-radius: 99px;
    background: rgba(22, 101, 192, 0.5);
    backdrop-filter: blur(4px);
}
.proj-body {
    padding: 22px 24px 24px;
}
.proj-h3 {
    font-family: "Inter", sans-serif;
    font-weight: 700;
    font-size: 15px;
    color: var(--ink);
    letter-spacing: 0;
    text-transform: none;
    margin-bottom: 6px;
}
.proj-loc {
    font-size: 11px;
    color: var(--blue);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    font-weight: 600;
    margin-bottom: 10px;
}
.proj-desc {
    font-size: 13px;
    color: var(--mid);
    line-height: 1.75;
}
#projects {
    padding-bottom: 0;
}

.proj-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* Responsive */
@media (max-width: 991.98px) {
    .proj-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}
@media (max-width: 767.98px) {
    .proj-grid {
        grid-template-columns: repeat(1, 1fr);
    }
}

/* GOOGLE REVIEWS */
#reviews {
    background: var(--white);
}
.reviews-header {
    text-align: center;
    margin-bottom: 56px;
}
.reviews-badges {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 24px;
    margin-bottom: 32px;
    flex-wrap: wrap;
}
.review-badge {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 20px;
    border: 1px solid rgba(0, 0, 0, 0.1);
    border-radius: 20px;
    background: var(--bg);
}
.rb-logo {
    font-size: 16px;
    font-weight: 700;
    letter-spacing: -0.01em;
}
.rb-logo .g-g {
    color: #4285f4;
}
.rb-logo .g-o1 {
    color: #ea4335;
}
.rb-logo .g-o2 {
    color: #fbbc05;
}
.rb-logo .g-l {
    color: #4285f4;
}
.rb-logo .g-e {
    color: #34a853;
}
.rb-logo .fb {
    color: #1877f2;
}
.rb-stars {
    display: flex;
    gap: 2px;
}
.rb-stars svg {
    width: 16px;
    height: 16px;
    fill: #fbbc05;
}
.reviews-h2 {
    font-family: "Barlow Condensed", sans-serif;
    font-weight: 900;
    font-size: clamp(36px, 4vw, 54px);
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: var(--ink);
    line-height: 1;
    margin-bottom: 10px;
}
.reviews-h2 em {
    font-style: normal;
    background: var(--grad);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.reviews-sub {
    font-size: 14px;
    font-weight: 400;
    color: var(--muted);
}
.reviews-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}
.rv-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 20px;
    padding: 24px;
    transition:
        box-shadow 0.2s,
        border-color 0.2s;
}
.rv-card:hover {
    box-shadow: 0 8px 32px rgba(22, 101, 192, 0.1);
    border-color: var(--border2);
}
.rv-stars {
    display: flex;
    gap: 3px;
    margin-bottom: 14px;
}
.rv-stars svg {
    width: 14px;
    height: 14px;
    fill: #fbbc05;
}
.rv-q {
    font-size: 13.5px;
    color: var(--mid);
    line-height: 1.75;
    margin-bottom: 18px;
    font-style: italic;
}
.rv-author {
    font-weight: 600;
    font-size: 14px;
    color: var(--ink);
}
.rv-role {
    font-size: 11px;
    color: var(--muted);
    margin-top: 2px;
}
.rv-google {
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid var(--border);
    display: flex;
    justify-content: flex-end;
}
.rv-google-logo {
    font-size: 13px;
    font-weight: 700;
    letter-spacing: -0.01em;
}
#reviews {
    padding-bottom: 0;
}

/* Responsive */
@media (max-width: 991.98px) {
    .reviews-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}
@media (max-width: 767.98px) {
    .reviews-grid {
        grid-template-columns: 1fr;
    }
    .reviews-badges {
        gap: 12px;
    }
}

/* 3 STEPS */
#steps {
    background: var(--bg);
}
.steps-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    margin-top: 56px;
    position: relative;
}
.step {
    padding: 48px 40px;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 20px;
    position: relative;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    transition:
        background 0.25s,
        box-shadow 0.25s;
}
.step:hover {
    background: var(--bluet);
    box-shadow: 0 8px 32px rgba(22, 101, 192, 0.08);
}
.step-num {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: "Inter", sans-serif;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.04em;
    color: var(--blue);
    text-transform: none;
    margin-bottom: 16px;
    padding: 5px 12px 5px 8px;
    background: var(--bluet);
    border: 1px solid rgba(22, 100, 192, 0.15);
    border-radius: 99px;
}
.step-num::before {
    content: "";
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--grad);
    flex-shrink: 0;
}
.step-ico {
    width: 56px;
    height: 56px;
    border: 1px solid var(--border2);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 24px;
    background: var(--bg);
}
.step:hover .step-ico {
    background: var(--white);
}
.step-ico svg {
    width: 26px;
    height: 26px;
    fill: none;
    stroke: var(--blue);
    stroke-width: 1.5;
    stroke-linecap: round;
    stroke-linejoin: round;
}
.step-arrow {
    position: absolute;
    top: 50%;
    right: -1px;
    transform: translateY(-50%);
    z-index: 3;
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg2);
}
.step:last-child .step-arrow {
    display: none;
}
.step-arrow svg {
    width: 12px;
    height: 12px;
    fill: none;
    stroke: var(--blue);
    stroke-width: 1.5;
    stroke-linecap: round;
}
.step-h3 {
    font-family: "Barlow Condensed", sans-serif;
    font-weight: 800;
    font-size: 22px;
    color: var(--ink);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    margin-bottom: 12px;
}
.step-p {
    font-size: 13px;
    font-weight: 400;
    color: var(--mid);
    line-height: 1.8;
    max-width: 240px;
    margin: 0 auto 24px;
}
.step-cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--blue);
    text-decoration: none;
    border-bottom: 1px solid var(--border2);
    padding-bottom: 2px;
    transition: all 0.2s;
}
.step-cta:hover {
    border-color: var(--blue);
}

/* Responsive */
@media (max-width: 991.98px) {
    .steps-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}
@media (max-width: 767.98px) {
    .steps-grid {
        grid-template-columns: 1fr;
    }
}

/* FAQ */
#faq {
    background: var(--bg2);
}
.faq-layout {
    display: grid;
    grid-template-columns: 1fr 1.8fr;
    gap: 80px;
    align-items: start;
}
.faq-layout .sh-p p {
  color: var(--muted);
  margin-top: 14px;
}
.faq-layout .sh-p p a {
  color: var(--blue3);
  text-decoration: none;
}




.faq-list {
    display: flex;
    flex-direction: column;
    border: 1px solid var(--border);
    border-radius: 16px;
    overflow: hidden;
}
.faq-item {
    border-bottom: 1px solid var(--border);
    overflow: hidden;
    background: var(--white);
}
.faq-item:last-child {
    border-bottom: none;
}
.faq-q {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 20px 24px;
    cursor: pointer;
    transition: background 0.15s;
}
.faq-q:hover {
    background: var(--bluet);
}
.faq-q-text {
    font-family: "Inter", sans-serif;
    font-weight: 600;
    font-size: 14px;
    color: var(--ink);
    letter-spacing: 0;
    text-transform: none;
}
.faq-icon {
    width: 24px;
    height: 24px;
    border: 1px solid var(--border);
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: all 0.2s;
    background: var(--bg);
}
.faq-icon svg {
    width: 12px;
    height: 12px;
    fill: none;
    stroke: var(--mid);
    stroke-width: 1.5;
    stroke-linecap: round;
    transition: transform 0.3s;
}
.faq-item.open .faq-q {
    background: var(--bluet);
}
.faq-item.open .faq-icon {
    border-color: var(--border2);
    background: var(--white);
}
.faq-item.open .faq-icon svg {
    stroke: var(--blue);
    transform: rotate(45deg);
}
.faq-a {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.35s ease;
}
.faq-item.open .faq-a {
    max-height: 300px;
}
.faq-a-inner {
    padding: 16px 24px 20px;
    font-size: 13px;
    font-weight: 400;
    color: var(--mid);
    line-height: 1.85;
    border-top: 1px solid var(--border);
}

/* Responsive */
@media (max-width: 1199.98px) {
    .faq-layout {
        gap: 40px;
    }
}
@media (max-width: 991.98px) {
    .faq-layout {
        grid-template-columns: 1fr;
    }
}

/* CTA BAND */
.cta-bg-icon {
    position: absolute;
    right: -40px;
    top: 50%;
    transform: translateY(-50%);
    width: 420px;
    height: 420px;
    opacity: 0.13;
    pointer-events: none;
    z-index: 0;
}

#cta {
    background: var(--grad);
    padding: 80px 0;
    position: relative;
    overflow: hidden;
}
#cta::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: linear-gradient(rgba(255, 255, 255, 0.1) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.1) 1px, transparent 1px);
    background-size: 52px 52px;
    pointer-events: none;
}
.cta-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 48px;
    position: relative;
    z-index: 1;
}
.cta-eyebrow {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 16px;
}
.cta-eyebrow-line {
    width: 32px;
    height: 1px;
    background: rgba(255, 255, 255, 0.5);
}
.cta-eyebrow span {
    font-size: 10px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.7);
    font-weight: 300;
}
.cta-h2 {
    font-family: "Barlow Condensed", sans-serif;
    font-weight: 900;
    font-size: clamp(40px, 5vw, 68px);
    line-height: 1;
    text-transform: uppercase;
    color: var(--white);
    letter-spacing: 0.02em;
    margin-bottom: 8px;
}
.cta-h2 em {
    font-style: normal;
    color: rgba(255, 255, 255, 0.75);
}
.cta-content p {
    font-size: 13px;
    font-weight: 300;
    color: rgba(255, 255, 255, 0.65);
}
.cta-acts {
    display: flex;
    gap: 12px;
    align-items: center;
    flex-shrink: 0;
}
.btn-wh {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    background: var(--white);
    color: var(--blue);
    font-weight: 600;
    font-size: 11px;
    padding: 14px 26px;
    border-radius: 14px;
    text-decoration: none;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    transition: all 0.15s;
}
.btn-wh:hover {
    transform: translateY(-1px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
}
.btn-gh {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    color: var(--white);
    font-weight: 500;
    font-size: 11px;
    padding: 13px 24px;
    border-radius: 14px;
    text-decoration: none;
    border: 1px solid rgba(255, 255, 255, 0.4);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    transition: all 0.15s;
}
.btn-gh:hover {
    background: rgba(255, 255, 255, 0.12);
    border-color: rgba(255, 255, 255, 0.7);
}

/* Responsive */
@media (max-width: 767.98px) {
    .cta-inner {
        flex-direction: column;
        text-align: center;
        gap: 30px;
    }
    .cta-eyebrow {
        justify-content: center;
    }
    #cta {
        padding-block: 60px;
    }
}

/* CONTACT */
#contact {
    background: var(--white);
}
.con-grid {
    display: grid;
    grid-template-columns: 1fr 1.6fr;
    gap: 80px;
    align-items: start;
}
.con-h2 {
    font-family: "Barlow Condensed", sans-serif;
    font-weight: 900;
    font-size: clamp(38px, 4vw, 54px);
    line-height: 1;
    text-transform: uppercase;
    color: var(--ink);
    letter-spacing: 0.03em;
    margin-bottom: 20px;
}
.con-h2 em {
    font-style: normal;
    background: var(--grad);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.con-p p{
    font-size: 14px;
    font-weight: 400;
    color: var(--mid);
    line-height: 1.85;
    margin-bottom: 40px;
}
.con-det {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 18px;
}
.con-ico {
    width: 40px;
    height: 40px;
    background: var(--bluet);
    border: 1px solid var(--border);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.con-ico svg {
    width: 17px;
    height: 17px;
    fill: none;
    stroke: var(--blue);
    stroke-width: 1.5;
    stroke-linecap: round;
}
.con-lbl {
    font-size: 10px;
    color: var(--muted);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}
.con-val {
    font-size: 15px;
    font-weight: 500;
    color: var(--ink);
    margin-top: 2px;
}
.enq {
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 20px;
    overflow: hidden;
}
.enq-head {
    background: var(--ink);
    padding: 20px 32px;
    display: flex;
    align-items: center;
    gap: 14px;
    border-bottom: 1px solid var(--border);
}
.enq-head-ico {
    width: 32px;
    height: 32px;
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.enq-head-ico svg {
    width: 15px;
    height: 15px;
    fill: none;
    stroke: rgba(255, 255, 255, 0.7);
    stroke-width: 1.5;
    stroke-linecap: round;
}
.enq-head-title {
    font-family: "Inter", sans-serif;
    font-weight: 600;
    font-size: 16px;
    color: var(--white);
    letter-spacing: 0;
    text-transform: none;
}
.enq-head-sub {
    font-size: 11px;
    color: rgba(255, 255, 255, 0.4);
    margin-top: 2px;
    font-weight: 300;
}
.enq-body {
    padding: 28px 32px;
}
.f2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}
.fg {
    margin-bottom: 14px;
}
.fg label {
    display: block;
    font-size: 10px;
    font-weight: 600;
    color: var(--steel);
    margin-bottom: 6px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}
.fg input,
.fg select,
.fg textarea {
    width: 100%;
    padding: 11px 14px;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 14px;
    font-family: "Inter", sans-serif;
    font-size: 13px;
    color: var(--ink);
    outline: none;
    transition: all 0.15s;
    -webkit-appearance: none;
}
.fg input::placeholder,
.fg textarea::placeholder {
    color: var(--pale);
}
.fg input:focus,
.fg select:focus,
.fg textarea:focus {
    border-color: var(--blue2);
    box-shadow: 0 0 0 3px rgba(22, 101, 192, 0.08);
}
.fg textarea {
    resize: vertical;
    min-height: 110px;
}
.enq-sub {
    width: 100%;
    background: var(--grad);
    color: var(--white);
    border: none;
    padding: 14px;
    border-radius: 14px;
    font-family: "Inter", sans-serif;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    margin-top: 8px;
    letter-spacing: 0;
    text-transform: none;
    transition: opacity 0.2s;
}
.enq-sub:hover {
    opacity: 0.88;
}

/* Responsive */
@media (max-width: 991.98px) {
    .con-grid {
        grid-template-columns: 1fr;
    }
}

/* FOOTER */
footer {
    background: var(--ink);
    padding: 56px 0 32px;
}
.ft-top {
    display: grid;
    grid-template-columns: 1.6fr 1fr 1fr 1fr;
    gap: 48px;
    margin-bottom: 48px;
    padding-bottom: 40px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}
.ft-brand {
    font-family: "Barlow Condensed", sans-serif;
    font-weight: 900;
    font-size: 28px;
    color: var(--white);
    margin-bottom: 12px;
    letter-spacing: 0.06em;
}
.ft-brand-logo {
    margin-bottom: 12px;
    display: flex;
    align-items: center;
}
.ft-brand em {
    font-style: normal;
    background: var(--grad);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.ft-brand-p p{
    font-size: 12px;
    font-weight: 300;
    color: rgba(255, 255, 255, 0.35);
    line-height: 1.75;
    max-width: 240px;
}
.ft-brand-p strong {
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 500;
}
.ft-col-title {
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.25);
    margin-bottom: 16px;
}
.ft-col a {
    display: block;
    font-size: 12px;
    font-weight: 300;
    color: rgba(255, 255, 255, 0.4);
    text-decoration: none;
    margin-bottom: 10px;
    transition: color 0.15s;
}
.ft-col a:hover {
    color: var(--blue3);
}
.ft-bot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
}
.ft-copy,
.ft-license {
    font-size: 11px;
    color: rgba(255, 255, 255, 0.18);
    font-weight: 300;
    letter-spacing: 0.04em;
}
.ft-socials {
    display: flex;
    gap: 10px;
    margin-top: 20px;
}
.ft-social {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(255, 255, 255, 0.35);
    text-decoration: none;
    transition: all 0.2s;
}
.ft-social:hover {
    border-color: var(--blue3);
    color: var(--blue3);
    background: rgba(66, 165, 245, 0.08);
}
.ft-social svg {
    width: 16px;
    height: 16px;
}

/* Responsive */
@media (max-width: 767.98px) {
    .ft-top {
        grid-template-columns: 1fr;
        gap: 30px;
        margin-bottom: 30px;
        padding-bottom: 30px;
    }
    .ft-bot {
        justify-content: center;
    }
    .ft-license {
        text-align: center;
    }
    .ft-license span {
        margin-top: 10px;
        display: inline-block;
    }
}

/* RATING TILES */
#rating-bar {
    background: var(--white);
    padding: 0;
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
}
.rating-inner {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
}
.rating-tile {
    padding: 32px 28px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    text-align: center;
    border-right: 1px solid var(--border);
    transition: background 0.2s;
    position: relative;
}
.rating-tile:last-child {
    border-right: none;
}
.rating-tile:hover {
    background: var(--bg);
}
.rating-tile::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 3px;
    background: var(--grad);
    border-radius: 99px;
    transition: width 0.3s;
}
.rating-tile:hover::after {
    width: 48px;
}
.rt-logo {
    font-size: 20px;
    font-weight: 800;
    letter-spacing: -0.01em;
    line-height: 1;
}
.rt-logo .g-g {
    color: #4285f4;
}
.rt-logo .g-o1 {
    color: #ea4335;
}
.rt-logo .g-o2 {
    color: #fbbc05;
}
.rt-logo .g-e {
    color: #34a853;
}
.rt-stars {
    display: flex;
    gap: 3px;
}
.rt-stars svg {
    width: 15px;
    height: 15px;
    fill: #fbbc05;
}
.rt-score {
    font-family: "Inter", sans-serif;
    font-weight: 700;
    font-size: 22px;
    color: var(--ink);
    line-height: 1;
}
.rt-count {
    font-size: 11px;
    font-weight: 400;
    color: var(--muted);
    letter-spacing: 0.04em;
}
.rt-divider {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 32px 0;
    border-right: 1px solid var(--border);
}
.rt-divider-line {
    width: 1px;
    height: 40px;
    background: var(--border);
}

/* LOGO SLIDER */
.logo-slider-wrap {
    overflow: hidden;
    position: relative;
    padding: 40px 0;
    border-top: 1px solid var(--border);
    margin-top: 40px;
    display: none;
}
.logo-slider-wrap::before,
.logo-slider-wrap::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    width: 120px;
    z-index: 2;
    pointer-events: none;
}
.logo-slider-wrap::before {
    left: 0;
    background: linear-gradient(90deg, var(--white), transparent);
}
.logo-slider-wrap::after {
    right: 0;
    background: linear-gradient(-90deg, var(--white), transparent);
}
.logo-slider-label {
    text-align: center;
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--pale);
    margin-bottom: 28px;
}
.logo-track {
    display: flex;
    gap: 0;
    animation: slide 28s linear infinite;
    width: max-content;
  will-change: transform;
}
.logo-set {
    display: flex;
    align-items: center;
    flex-shrink: 0;
}

.logo-track:hover {
    animation-play-state: paused;
}
@keyframes slide {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}
.logo-tile {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 48px;
    height: 64px;
    flex-shrink: 0;
}
.logo-tile-inner {
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0.35;
    filter: grayscale(1);
    transition:
        opacity 0.3s,
        filter 0.3s;
}
.logo-tile-inner:hover {
    opacity: 0.8;
    filter: grayscale(0);
}
.logo-wordmark {
    font-family: "Inter", sans-serif;
    font-weight: 600;
    font-size: 15px;
    letter-spacing: 0.02em;
    text-transform: none;
    color: var(--ink);
    white-space: nowrap;
}
.logo-wordmark span {
    color: var(--blue);
}
.logo-sep {
    width: 1px;
    height: 24px;
    background: var(--border);
    flex-shrink: 0;
    margin: auto 0;
}

/* HERO TRUST BADGES */
.hero-trust {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 40px;
    flex-wrap: wrap;
}
.hero-trust-badge {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 8px 14px;
    background: rgba(255, 255, 255, 0.75);
    border: 1px solid var(--border);
    border-radius: 99px;
    backdrop-filter: blur(8px);
}
.htb-logo {
    font-size: 13px;
    font-weight: 800;
    letter-spacing: -0.01em;
    line-height: 1;
}
.htb-logo .g-g {
    color: #4285f4;
}
.htb-logo .g-o1 {
    color: #ea4335;
}
.htb-logo .g-o2 {
    color: #fbbc05;
}
.htb-logo .g-e {
    color: #34a853;
}
.htb-fb {
    color: #1877f2;
}
.htb-stars {
    display: flex;
    gap: 1px;
}
.htb-stars svg {
    width: 11px;
    height: 11px;
    fill: #fbbc05;
}
.htb-score {
    font-size: 12px;
    font-weight: 700;
    color: var(--ink);
    margin-left: 2px;
}
.hero-trust-div {
    width: 1px;
    height: 20px;
    background: var(--border);
}

/* CRED TILES */
.cred-tiles {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    max-width: 1100px;
    margin: 0 auto;
}
.cred-tile {
    background: var(--white);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 20px;
    padding: 36px 32px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0;
    transition:
        box-shadow 0.25s,
        border-color 0.25s,
        background 0.25s;
    position: relative;
    overflow: hidden;
}
.cred-tile::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: transparent;
    border-radius: 20px 20px 0 0;
    transition: background 0.3s;
}
.cred-tile:hover::before {
    background: var(--grad);
}
.cred-tile:hover {
    border-color: var(--border2);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
}
.cred-tile--dark {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.15);
    backdrop-filter: blur(8px);
}
.cred-tile--dark .cred-tile-ico svg {
    stroke: rgba(255, 255, 255, 0.9);
}
.cred-tile--dark .cred-tile-title {
    color: var(--white);
}
.cred-tile--dark .cred-tile-sub {
    color: rgba(255, 255, 255, 0.65);
}
.cred-tile-ico {
    width: 48px;
    height: 48px;
    background: var(--bluet);
    border: 1px solid var(--border);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    margin-bottom: 20px;
    transition: background 0.25s;
}
.cred-tile:hover .cred-tile-ico {
    background: var(--bg2);
}
.cred-tile-ico svg {
    width: 22px;
    height: 22px;
    fill: none;
    stroke: var(--blue);
    stroke-width: 1.5;
    stroke-linecap: round;
    stroke-linejoin: round;
}
.cred-tile-title {
    font-family: "Inter", sans-serif;
    font-weight: 700;
    font-size: 14px;
    color: var(--ink);
    letter-spacing: 0;
    text-transform: none;
    margin-bottom: 8px;
}
.cred-tile-sub {
    font-size: 13px;
    color: var(--mid);
    line-height: 1.75;
}

/* Responsive */
@media (max-width: 991.98px) {
    .cred-tiles {
        grid-template-columns: repeat(2, 1fr);
    }
}
@media (max-width: 767.98px) {
    .cred-tiles {
        grid-template-columns: repeat(1, 1fr);
    }
}

/* FORM TRUST BADGES */
.form-trust {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    padding: 12px 20px;
    border-top: 1px solid var(--border);
    background: var(--bg);
}
.ftb {
    display: flex;
    align-items: center;
    gap: 6px;
}
.ftb-logo {
    font-size: 12px;
    font-weight: 800;
    letter-spacing: -0.01em;
}
.ftb-logo .g-g {
    color: #4285f4;
}
.ftb-logo .g-o1 {
    color: #ea4335;
}
.ftb-logo .g-o2 {
    color: #fbbc05;
}
.ftb-logo .g-e {
    color: #34a853;
}
.ftb-fb {
    color: #1877f2;
    font-size: 12px;
    font-weight: 700;
}
.ftb-stars {
    display: flex;
    gap: 1px;
}
.ftb-stars svg {
    width: 10px;
    height: 10px;
    fill: #fbbc05;
}
.ftb-div {
    width: 1px;
    height: 16px;
    background: var(--border);
}


.ft-color span {
	background:var(--grad);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  font-weight:500;
}
.heading-color span{
  background:var(--grad);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

form span.wpcf7-spinner {
	display: none !important;
}


/* REVEAL */
.reveal {
    opacity: 1;
    transform: none;
    transition:
        opacity 0.65s ease,
        transform 0.65s ease;
}
.reveal.pre-reveal {
    opacity: 0;
    transform: translateY(18px);
}
.reveal.pre-reveal.visible {
    opacity: 1;
    transform: translateY(0);
}
.rd1 {
    transition-delay: 0.1s;
}
.rd2 {
    transition-delay: 0.2s;
}
.rd3 {
    transition-delay: 0.3s;
}
.rd4 {
    transition-delay: 0.4s;
}

.admin-bar #nav {
    top: 32px;
}

@media all and (max-width: 782px) {
    .admin-bar #nav {
        top: 46px;
    }
}
