/* ===================================================
   TOPTECH AIR — Master Stylesheet
   Blue #1F57C3 dominant · Red #E60908 accent
   =================================================== */

/* 1. DESIGN TOKENS */
:root{
  --blue:#1F57C3; --blue-deep:#1D3C77; --blue-mid:#2554AB;
  --red:#E60908; --red-deep:#BA1013;
  --ink:#0E1726; --slate:#475569; --mist:#F4F7FC; --cloud:#FFFFFF; --border:#E2E8F0;
  --grad-cool:linear-gradient(135deg,#2554AB,#1F57C3 50%,#1D3C77);
  --grad-hot:linear-gradient(135deg,#E60908,#BA1013);
  --grad-brand:linear-gradient(120deg,#1F57C3,#1D3C77 60%,#E60908 140%);
  --font-head:'Poppins',sans-serif; --font-body:'Inter',sans-serif;
  --r-sm:8px; --r-md:16px; --r-lg:24px; --r-xl:32px; --r-pill:999px;
  --sh-sm:0 2px 8px rgba(14,23,38,.06);
  --sh-md:0 12px 30px rgba(14,23,38,.10);
  --sh-lg:0 30px 60px rgba(29,60,119,.18);
  --sh-blue:0 18px 40px rgba(31,87,195,.28);
  --sh-red:0 18px 40px rgba(230,9,8,.26);
  --ease:cubic-bezier(.16,1,.3,1);
  --ease-bounce:cubic-bezier(.34,1.56,.64,1);
  --maxw:1240px; --gutter:clamp(16px,4vw,48px);
  --header-h:80px;
}

/* 2. RESET + BASE */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-size:16px;overflow-x:hidden}
body{font-family:var(--font-body);color:var(--ink);background:var(--cloud);line-height:1.65;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,textarea,select{font-family:inherit}

/* 3. TYPOGRAPHY */
h1,h2,h3,h4,h5{font-family:var(--font-head);font-weight:700;line-height:1.15;color:var(--ink)}
h1{font-size:clamp(2.4rem,6vw,4.5rem)}
h2{font-size:clamp(1.8rem,3.5vw,3rem)}
h3{font-size:clamp(1.25rem,2.5vw,1.75rem)}
h4{font-size:clamp(1.05rem,1.8vw,1.35rem)}
p{color:var(--slate);line-height:1.7;max-width:68ch}
.text-gradient{background:var(--grad-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.text-white{color:var(--cloud)!important}
.text-blue{color:var(--blue)}
.text-red{color:var(--red)}
.text-center{text-align:center}

/* 4. LAYOUT */
.container{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
.section{padding:clamp(60px,8vw,120px) 0}
.section-sm{padding:clamp(40px,5vw,80px) 0}
.section-label{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-head);font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);margin-bottom:1rem}
.section-label::before{content:'';display:block;width:24px;height:2px;background:var(--grad-hot);border-radius:2px}
.section-header{margin-bottom:clamp(40px,6vw,72px)}
.section-header p{margin-top:1rem;font-size:1.05rem}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,3vw,40px)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,40px)}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2.5vw,32px)}
.flex-center{display:flex;align-items:center;justify-content:center}
.flex-between{display:flex;align-items:center;justify-content:space-between}

/* 5. BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 32px;border-radius:var(--r-pill);font-family:var(--font-head);font-weight:600;font-size:.95rem;transition:all .35s var(--ease);position:relative;overflow:hidden;white-space:nowrap;cursor:pointer;border:none;text-decoration:none;letter-spacing:.01em}
.btn::after{content:'';position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.30) 50%,transparent 70%);transform:translateX(-100%);transition:transform .6s var(--ease)}
.btn:hover::after{transform:translateX(100%)}
.btn-primary{background:var(--grad-hot);color:var(--cloud);box-shadow:var(--sh-red)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 24px 50px rgba(230,9,8,.40)}
.btn-secondary{background:var(--grad-cool);color:var(--cloud);box-shadow:var(--sh-blue)}
.btn-secondary:hover{transform:translateY(-3px);box-shadow:0 24px 50px rgba(31,87,195,.40)}
.btn-outline{background:transparent;color:var(--cloud);border:2px solid rgba(255,255,255,.6);backdrop-filter:blur(8px)}
.btn-outline:hover{background:rgba(255,255,255,.12);border-color:var(--cloud);transform:translateY(-3px)}
.btn-outline-blue{background:transparent;color:var(--blue);border:2px solid var(--blue)}
.btn-outline-blue:hover{background:var(--blue);color:var(--cloud);transform:translateY(-3px)}
.btn-lg{padding:18px 44px;font-size:1.05rem}
.btn-sm{padding:10px 22px;font-size:.875rem}

@keyframes pulse-ring{0%{box-shadow:0 0 0 0 rgba(230,9,8,.4)}70%{box-shadow:0 0 0 14px rgba(230,9,8,0)}100%{box-shadow:0 0 0 0 rgba(230,9,8,0)}}
.btn-pulse{animation:pulse-ring 2.5s ease-out infinite}

/* 6. PRELOADER */
#preloader{position:fixed;inset:0;z-index:9999;background:var(--ink);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;transition:opacity .5s ease,visibility .5s ease}
#preloader.loaded{opacity:0;visibility:hidden;pointer-events:none}
.preloader-logo{width:130px;animation:pl-scale .6s var(--ease-bounce) forwards}
.preloader-text{font-family:var(--font-head);font-weight:800;font-size:clamp(1.1rem,5vw,1.6rem);background:var(--grad-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:.1em;text-transform:uppercase;text-align:center;padding:0 24px;max-width:100%;opacity:0;animation:fade-in .4s .3s ease forwards}
.preloader-bar{width:150px;height:3px;background:rgba(255,255,255,.1);border-radius:var(--r-pill);overflow:hidden;margin-top:6px}
.preloader-bar-fill{height:100%;background:var(--grad-brand);border-radius:var(--r-pill);animation:pl-fill .65s .1s var(--ease) forwards;transform-origin:left;transform:scaleX(0)}
@keyframes pl-scale{from{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes pl-fill{to{transform:scaleX(1)}}
@keyframes fade-in{to{opacity:1}}

/* 7. ANNOUNCEMENT BAR */
.announce-bar{background:var(--grad-hot);color:var(--cloud);text-align:center;padding:10px var(--gutter);font-size:.875rem;font-weight:500;position:relative;z-index:100;letter-spacing:.01em}
.announce-bar a{color:var(--cloud);font-weight:700;text-decoration:underline}

/* 8. HEADER */
.site-header{position:sticky;top:0;z-index:90;background:rgba(255,255,255,.95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);transition:all .35s var(--ease);height:var(--header-h);display:flex;align-items:center}
.site-header.scrolled{height:64px;box-shadow:var(--sh-md);background:rgba(255,255,255,.98)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;width:100%}
.logo-wrap{display:flex;flex-direction:column;align-items:center;text-decoration:none;flex-shrink:0}
.logo-wrap img{height:48px;width:auto;max-width:200px;transition:height .35s var(--ease)}
.site-header.scrolled .logo-wrap img{height:40px}
.logo-slogan{font-size:.85rem;font-weight:800;font-family:var(--font-head);background:var(--grad-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:.1em;text-transform:uppercase;margin-top:3px}
.main-nav{display:flex;align-items:center;gap:2px}
.nav-link{font-family:var(--font-head);font-size:.875rem;font-weight:500;color:var(--ink);padding:8px 12px;border-radius:var(--r-sm);transition:all .25s ease;position:relative;text-decoration:none}
.nav-link:hover,.nav-link.active{color:var(--blue);background:rgba(31,87,195,.06)}
.nav-link.active::after{content:'';position:absolute;bottom:2px;left:50%;transform:translateX(-50%);width:18px;height:2px;background:var(--grad-hot);border-radius:var(--r-pill)}
.nav-dropdown{position:relative}
.nav-dropdown>.nav-link::before{content:'▾';font-size:.65rem;margin-left:3px;opacity:.6}
.dropdown-menu{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(8px);background:var(--cloud);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--sh-lg);min-width:210px;padding:8px;opacity:0;visibility:hidden;transition:all .25s var(--ease);pointer-events:none}
.nav-dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);pointer-events:all}
.dropdown-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--r-sm);font-family:var(--font-head);font-size:.875rem;font-weight:500;color:var(--ink);transition:all .2s ease;text-decoration:none}
.dropdown-item:hover{background:var(--mist);color:var(--blue)}
.dropdown-item .di{font-size:1.1rem;flex-shrink:0}
.header-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}
.phone-btn{display:flex;align-items:center;gap:6px;font-family:var(--font-head);font-weight:600;font-size:.875rem;color:var(--ink);padding:8px 16px;border-radius:var(--r-pill);border:1.5px solid var(--border);transition:all .25s ease;text-decoration:none}
.phone-btn:hover{color:var(--blue);border-color:var(--blue);background:rgba(31,87,195,.04)}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;border-radius:var(--r-sm);transition:background .2s;background:none;border:none}
.hamburger:hover{background:var(--mist)}
.hamburger span{display:block;width:24px;height:2px;background:var(--ink);border-radius:2px;transition:all .3s var(--ease)}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile nav */
.mobile-nav{display:none;position:fixed;inset:0;z-index:85;background:var(--cloud);flex-direction:column;padding:90px var(--gutter) 40px;transform:translateX(100%);transition:transform .4s var(--ease);overflow-y:auto}
.mobile-nav.open{transform:translateX(0)}
.mobile-nav-link{font-family:var(--font-head);font-size:1.4rem;font-weight:700;color:var(--ink);padding:18px 0;border-bottom:1px solid var(--border);display:block;transition:color .2s}
.mobile-nav-link:hover,.mobile-nav-link.active{color:var(--blue)}
.mobile-nav-sub{padding:8px 0 16px 16px;border-left:3px solid rgba(31,87,195,.3)}
.mobile-nav-sub a{font-family:var(--font-head);font-size:1.05rem;font-weight:500;color:var(--slate);padding:8px 0;display:block;transition:color .2s;text-decoration:none}
.mobile-nav-sub a:hover{color:var(--blue)}
.mobile-nav-footer{margin-top:32px;display:flex;flex-direction:column;gap:14px}
.mobile-nav-contact{font-family:var(--font-head);font-size:.95rem;font-weight:500;color:var(--slate);display:flex;align-items:center;gap:10px;text-decoration:none}
.mobile-nav-contact:hover{color:var(--blue)}

/* 9. HERO */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden;background:var(--ink)}
.hero-video-wrap{position:absolute;inset:0;z-index:0}
.hero-video-wrap video,.hero-poster{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-poster{display:none}
.hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(14,23,38,.92) 0%,rgba(14,23,38,.65) 50%,rgba(14,23,38,.4) 100%)}
.hero-mesh{position:absolute;inset:0;z-index:2;background:radial-gradient(ellipse 60% 50% at 0% 0%,rgba(31,87,195,.22),transparent),radial-gradient(ellipse 50% 60% at 100% 100%,rgba(230,9,8,.14),transparent);animation:mesh-shift 14s ease-in-out infinite alternate}
@keyframes mesh-shift{from{opacity:.5;transform:scale(1)}to{opacity:1;transform:scale(1.06)}}
#hero-canvas{position:absolute;inset:0;z-index:3;pointer-events:none}
.hero-content{position:relative;z-index:4;width:100%;padding:clamp(100px,12vw,160px) 0 clamp(80px,10vw,120px)}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(8px);color:rgba(255,255,255,.92);font-family:var(--font-head);font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;padding:8px 18px;border-radius:var(--r-pill);margin-bottom:24px}
.hero-eyebrow::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--red);animation:blink 1.5s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}
.hero h1{color:var(--cloud);max-width:16ch;margin-bottom:24px;letter-spacing:-.02em}
.hero-sub{font-size:clamp(.975rem,2vw,1.2rem);color:rgba(255,255,255,.82);max-width:52ch;margin-bottom:12px;line-height:1.65}
.hero-slogan{font-family:var(--font-head);font-weight:700;font-size:clamp(.95rem,1.8vw,1.1rem);background:var(--grad-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:36px;display:block}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:44px}
.trust-strip{display:flex;flex-wrap:wrap;gap:20px}
.trust-item{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.8);font-size:.84rem;font-family:var(--font-head);font-weight:500}
.trust-dot{width:6px;height:6px;border-radius:50%;background:var(--red);flex-shrink:0}
.scroll-indicator{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:4;display:flex;flex-direction:column;align-items:center;gap:6px;color:rgba(255,255,255,.45);font-size:.7rem;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.12em;animation:scroll-bounce 2s ease-in-out infinite}
@keyframes scroll-bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* Page hero (inner pages) */
.page-hero{position:relative;min-height:clamp(300px,45vw,500px);display:flex;align-items:flex-end;overflow:hidden;background:var(--ink)}
.page-hero-img{position:absolute;inset:0;z-index:0}
.page-hero-img img{width:100%;height:100%;object-fit:cover;object-position:center}
.page-hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(14,23,38,.92) 0%,rgba(14,23,38,.55) 55%,rgba(14,23,38,.28) 100%)}
.page-hero-content{position:relative;z-index:2;width:100%;padding:clamp(44px,6vw,80px) 0 clamp(40px,5vw,60px)}
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:.78rem;font-family:var(--font-head);color:rgba(255,255,255,.55);margin-bottom:14px}
.breadcrumb a{color:rgba(255,255,255,.55);transition:color .2s;text-decoration:none}
.breadcrumb a:hover{color:var(--cloud)}
.breadcrumb-sep{opacity:.35}
.page-hero h1{color:var(--cloud);margin-bottom:12px}
.page-hero-slogan{font-family:var(--font-head);font-weight:600;font-size:.9rem;background:var(--grad-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:block}
.page-hero-sub{color:rgba(255,255,255,.75);font-size:1.05rem;max-width:60ch;margin-top:10px}

/* 10. SERVICES STRIP */
.services-strip{background:var(--cloud);position:relative;z-index:5;margin-top:-60px;padding:clamp(60px,7vw,100px) 0}

.service-card{background:var(--cloud);border-radius:var(--r-lg);padding:clamp(24px,3vw,36px);border:1px solid var(--border);box-shadow:var(--sh-sm);transition:all .35s var(--ease);position:relative;overflow:hidden;text-decoration:none;display:block}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad-cool);transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease)}
.service-card::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(31,87,195,.03),transparent);opacity:0;transition:opacity .35s}
.service-card:hover::before{transform:scaleX(1)}
.service-card:hover{box-shadow:var(--sh-blue);transform:translateY(-6px);border-color:rgba(31,87,195,.2)}
.service-card:hover::after{opacity:1}
.service-icon{width:56px;height:56px;border-radius:var(--r-md);background:var(--mist);display:flex;align-items:center;justify-content:center;margin-bottom:20px;transition:all .35s var(--ease)}
.service-card:hover .service-icon{background:var(--blue);transform:scale(1.1) rotate(-5deg)}
.service-card:hover .service-icon svg{filter:brightness(0) invert(1)}
.service-card h3{font-size:1.15rem;margin-bottom:8px}
.service-card p{font-size:.875rem;margin-bottom:20px;max-width:none}
.card-link{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-head);font-size:.85rem;font-weight:600;color:var(--blue);transition:gap .25s var(--ease)}
.service-card:hover .card-link{gap:10px}

/* TILT CARD */
.tilt-card{transform-style:preserve-3d;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.card-glare{position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:10}

/* 11. VALUE BLURB */
.blurb-section{background:var(--mist)}
.blurb-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:center}
.blurb-img{border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-lg);position:relative}
.blurb-img img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;transition:transform .8s var(--ease)}
.blurb-img:hover img{transform:scale(1.04)}
.blurb-badge{position:absolute;bottom:20px;right:-10px;background:var(--grad-hot);color:var(--cloud);padding:18px 22px;border-radius:var(--r-md);box-shadow:var(--sh-red);text-align:center;font-family:var(--font-head)}
.blurb-badge .big{display:block;font-size:2rem;font-weight:800;line-height:1}
.blurb-badge .small{font-size:.72rem;font-weight:600;opacity:.92}
.blurb-content .section-label{margin-bottom:12px}
.blurb-content h2{margin-bottom:16px}
.blurb-content p{margin-bottom:16px}

/* 12. COUNTERS */
.counters-section{background:var(--cloud)}
.counters{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-md)}
.counter-item{text-align:center;padding:36px 20px;position:relative}
.counter-item+.counter-item{border-left:1px solid var(--border)}
.counter-num{font-family:var(--font-head);font-size:clamp(2rem,4vw,3.2rem);font-weight:800;background:var(--grad-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:8px;display:flex;align-items:baseline;justify-content:center;gap:2px}
.counter-label{font-family:var(--font-head);font-size:.82rem;font-weight:500;color:var(--slate)}

/* 13. ALTERNATING ROWS */
.alt-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,5vw,80px);align-items:center}
.alt-row+.alt-row{margin-top:clamp(60px,8vw,100px)}
.alt-row.reverse{direction:rtl}
.alt-row.reverse>*{direction:ltr}
.alt-img{border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-lg)}
.alt-img img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .8s var(--ease);display:block}
.alt-img:hover img{transform:scale(1.04)}
.alt-content .section-label{margin-bottom:12px}
.alt-content h2{margin-bottom:16px;font-size:clamp(1.5rem,3vw,2.2rem)}
.alt-content p{margin-bottom:20px}

/* 14. WHY CHOOSE US */
.why-section{background:var(--mist)}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,2vw,20px)}
.why-card{background:var(--cloud);border:1px solid var(--border);border-radius:var(--r-lg);padding:28px 22px;text-align:center;transition:all .35s var(--ease);position:relative;overflow:hidden}
.why-card:hover{transform:translateY(-5px);box-shadow:var(--sh-blue);border-color:rgba(31,87,195,.2)}
.why-icon{font-size:2rem;margin-bottom:14px;display:block}
.why-card h4{font-size:.9rem;margin-bottom:6px}
.why-card p{font-size:.8rem;max-width:none}

/* 15. BRANDS MARQUEE */
.marquee-section{background:var(--mist);padding:40px 0;overflow:hidden}
.marquee-label{text-align:center;font-family:var(--font-head);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--slate);margin-bottom:22px}
.marquee-track{display:flex;overflow:hidden;mask-image:linear-gradient(to right,transparent,black 8%,black 92%,transparent);-webkit-mask-image:linear-gradient(to right,transparent,black 8%,black 92%,transparent)}
.marquee-inner{display:flex;align-items:center;gap:14px;animation:marquee-scroll 28s linear infinite;flex-shrink:0;padding-right:14px}
.marquee-item{font-family:var(--font-head);font-weight:600;font-size:.875rem;color:var(--slate);white-space:nowrap;padding:10px 22px;background:var(--cloud);border-radius:var(--r-pill);border:1px solid var(--border);transition:all .2s;flex-shrink:0}
.marquee-item:hover{color:var(--blue);border-color:var(--blue);box-shadow:var(--sh-blue)}
@keyframes marquee-scroll{to{transform:translateX(-50%)}}

/* 16. PROCESS */
.process-section{background:var(--ink);position:relative;overflow:hidden}
.process-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 0% 50%,rgba(31,87,195,.14),transparent),radial-gradient(ellipse 40% 60% at 100% 50%,rgba(230,9,8,.09),transparent)}
.process-section .section-label{color:rgba(255,255,255,.55)}
.process-section h2{color:var(--cloud)}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;position:relative}
.process-steps::before{content:'';position:absolute;top:40px;left:12.5%;right:12.5%;height:2px;background:linear-gradient(to right,var(--blue-mid),rgba(230,9,8,.8));z-index:0}
.step{text-align:center;padding:0 clamp(8px,1.5vw,20px);position:relative;z-index:1}
.step-num{width:80px;height:80px;border-radius:50%;background:var(--grad-cool);display:flex;align-items:center;justify-content:center;margin:0 auto 24px;font-family:var(--font-head);font-size:1.5rem;font-weight:800;color:var(--cloud);box-shadow:var(--sh-blue);position:relative;transition:transform .3s var(--ease-bounce)}
.step:hover .step-num{transform:scale(1.1)}
.step-num.red{background:var(--grad-hot);box-shadow:var(--sh-red)}
.step h3{color:var(--cloud);font-size:.975rem;margin-bottom:8px}
.step p{font-size:.82rem;color:rgba(255,255,255,.55);max-width:none}

/* 17. AREAS TEASER */
.areas-teaser{background:var(--mist)}
.suburb-grid{display:flex;flex-wrap:wrap;gap:10px}
.suburb-chip{display:inline-flex;align-items:center;gap:5px;padding:8px 18px;background:var(--cloud);border:1px solid var(--border);border-radius:var(--r-pill);font-family:var(--font-head);font-size:.84rem;font-weight:500;color:var(--ink);transition:all .25s var(--ease);text-decoration:none}
.suburb-chip:hover{background:var(--blue);color:var(--cloud);border-color:var(--blue);transform:translateY(-2px);box-shadow:var(--sh-blue)}

/* 18. TESTIMONIALS */
.testimonials{background:var(--cloud)}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.5vw,28px)}
.review-card{background:var(--cloud);border-radius:var(--r-lg);padding:28px;box-shadow:var(--sh-sm);border:1px solid var(--border);transition:all .35s var(--ease);position:relative}
.review-card::before{content:'\201C';position:absolute;top:14px;right:20px;font-family:Georgia,serif;font-size:4.5rem;color:rgba(31,87,195,.07);line-height:1}
.review-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md);border-color:transparent}
.review-stars{color:#F59E0B;font-size:.85rem;margin-bottom:14px;letter-spacing:2px}
.review-text{font-size:.9rem;color:var(--slate);line-height:1.65;margin-bottom:20px;max-width:none}
.review-author{display:flex;align-items:center;gap:12px;font-family:var(--font-head)}
.review-avatar{width:42px;height:42px;border-radius:50%;background:var(--grad-cool);display:flex;align-items:center;justify-content:center;color:var(--cloud);font-weight:700;font-size:.95rem;flex-shrink:0}
.review-avatar.red{background:var(--grad-hot)}
.review-name{font-weight:600;font-size:.875rem;color:var(--ink)}
.review-sub{font-size:.75rem;color:var(--slate);font-weight:400}

/* 19. FAQ */
.faq-section{background:var(--mist)}
.faq-list{max-width:800px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border)}
.faq-question{width:100%;text-align:left;padding:22px 0;display:flex;justify-content:space-between;align-items:center;gap:16px;font-family:var(--font-head);font-size:.975rem;font-weight:600;color:var(--ink);background:none;border:none;cursor:pointer;transition:color .2s}
.faq-question:hover,.faq-question.open{color:var(--blue)}
.faq-icon{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:var(--cloud);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--blue);font-size:1rem;font-family:monospace;font-weight:700;line-height:1;transition:all .3s var(--ease);transform-origin:center}
.faq-question.open .faq-icon{background:var(--blue);color:var(--cloud);border-color:var(--blue);transform:rotate(45deg)}
.faq-answer{display:grid;grid-template-rows:0fr;transition:grid-template-rows .35s var(--ease)}
.faq-answer.open{grid-template-rows:1fr}
.faq-answer-inner{overflow:hidden}
.faq-answer-inner p{padding-bottom:22px;max-width:none;font-size:.9rem}

/* 20. CTA BAND */
.cta-band{background:var(--grad-brand);padding:clamp(60px,8vw,100px) 0;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 50% 80% at 20% 50%,rgba(255,255,255,.05),transparent),radial-gradient(ellipse 30% 50% at 80% 50%,rgba(255,255,255,.04),transparent)}
.cta-band .container{position:relative}
.cta-band h2{color:var(--cloud);margin-bottom:12px}
.cta-band p{color:rgba(255,255,255,.8);font-size:1.05rem;margin:0 auto 36px;max-width:54ch}
.cta-btns{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}

/* 21. CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:clamp(40px,5vw,64px);align-items:start}
.contact-info-card{background:var(--cloud);border-radius:var(--r-lg);padding:24px;border:1px solid var(--border);box-shadow:var(--sh-sm);display:flex;align-items:flex-start;gap:16px;margin-bottom:14px;transition:all .3s var(--ease)}
.contact-info-card:hover{border-color:rgba(31,87,195,.3);transform:translateX(4px)}
.contact-icon{width:46px;height:46px;border-radius:var(--r-md);background:var(--mist);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0;transition:all .3s}
.contact-info-card:hover .contact-icon{background:rgba(31,87,195,.1)}
.ci-title{font-family:var(--font-head);font-size:.78rem;font-weight:600;color:var(--slate);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}
.ci-value{font-family:var(--font-head);font-weight:700;color:var(--ink);font-size:.975rem;line-height:1.4}
.ci-value a{text-decoration:none;color:var(--ink);transition:color .2s;display:block}
.ci-value a:hover{color:var(--blue)}
.quote-form{background:var(--cloud);border-radius:var(--r-xl);padding:clamp(28px,4vw,44px);box-shadow:var(--sh-lg);border:1px solid var(--border)}
.quote-form h3{margin-bottom:6px}
.form-sub{color:var(--slate);font-size:.875rem;margin-bottom:26px;max-width:none}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-family:var(--font-head);font-size:.82rem;font-weight:600;color:var(--ink);margin-bottom:5px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:.9rem;color:var(--ink);background:var(--mist);transition:all .2s ease;-webkit-appearance:none;appearance:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--blue);background:var(--cloud);box-shadow:0 0 0 3px rgba(31,87,195,.1)}
.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:var(--red)}
.form-group .error-msg{color:var(--red);font-size:.75rem;margin-top:4px;display:none;font-family:var(--font-head);font-weight:500}
.form-group .error-msg.show{display:block}
.form-group textarea{resize:vertical;min-height:110px}
#form-success{display:none;text-align:center;padding:36px 20px}
#form-success.show{display:block}
.success-icon{font-size:3rem;margin-bottom:14px;display:block}

/* 22. MAP */
.map-wrap{border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-lg);border:1px solid var(--border)}
.map-wrap iframe{width:100%;height:400px;border:0;display:block}

/* 23. REGIONS */
.region-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,24px)}
.region-block{background:var(--cloud);border-radius:var(--r-lg);padding:26px;border:1px solid var(--border);box-shadow:var(--sh-sm);transition:all .3s var(--ease)}
.region-block:hover{border-color:rgba(31,87,195,.3);box-shadow:var(--sh-blue);transform:translateY(-3px)}
.region-block h4{color:var(--blue);font-size:.9rem;margin-bottom:12px;display:flex;align-items:center;gap:8px;font-family:var(--font-head)}
.region-block h4 span{font-size:1.1rem}
.region-chips{display:flex;flex-wrap:wrap;gap:6px}
.region-chip{font-size:.78rem;font-family:var(--font-head);font-weight:500;color:var(--slate);padding:4px 12px;background:var(--mist);border-radius:var(--r-pill);transition:all .2s}
.region-chip:hover{background:var(--blue);color:var(--cloud)}

/* 24. CHECKLIST */
.checklist{list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:24px 0}
.checklist li{display:flex;align-items:flex-start;gap:10px;font-family:var(--font-head);font-size:.875rem;font-weight:500;color:var(--ink)}
.check-icon{width:20px;height:20px;border-radius:50%;background:var(--blue);color:var(--cloud);display:flex;align-items:center;justify-content:center;font-size:.6rem;flex-shrink:0;margin-top:1px;font-weight:700}

/* 25. CROSS LINKS */
.cross-links{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:40px}
.cross-link-card{background:var(--mist);border:1px solid var(--border);border-radius:var(--r-lg);padding:24px;transition:all .3s var(--ease);text-decoration:none;display:block}
.cross-link-card:hover{background:var(--blue);border-color:var(--blue);transform:translateY(-4px);box-shadow:var(--sh-blue)}
.cross-link-card:hover h4,.cross-link-card:hover p{color:var(--cloud)!important}
.cross-link-card h4{font-size:.975rem;margin-bottom:6px;transition:color .3s}
.cross-link-card p{font-size:.82rem;max-width:none;transition:color .3s}
.cross-link-icon{font-size:1.5rem;margin-bottom:12px;display:block}

/* 26. WHAT'S INCLUDED CARDS */
.include-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin:24px 0}
.include-card{background:var(--mist);border:1px solid var(--border);border-radius:var(--r-md);padding:20px;display:flex;gap:14px;align-items:flex-start;transition:all .3s var(--ease)}
.include-card:hover{border-color:rgba(31,87,195,.3);background:rgba(31,87,195,.04)}
.include-card-icon{font-size:1.5rem;flex-shrink:0}
.include-card h4{font-size:.9rem;margin-bottom:4px;font-family:var(--font-head)}
.include-card p{font-size:.8rem;max-width:none}

/* 27. MINI PROCESS */
.mini-process{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}
.mini-step{text-align:center;padding:24px 20px;background:var(--cloud);border-radius:var(--r-lg);border:1px solid var(--border);transition:all .3s var(--ease)}
.mini-step:hover{border-color:rgba(31,87,195,.3);transform:translateY(-3px);box-shadow:var(--sh-md)}
.mini-step-num{width:52px;height:52px;border-radius:50%;background:var(--grad-cool);color:var(--cloud);font-family:var(--font-head);font-weight:800;font-size:1.1rem;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;box-shadow:var(--sh-blue)}
.mini-step h4{font-size:.9rem;margin-bottom:6px}
.mini-step p{font-size:.8rem;max-width:none}

/* 28. WAVE DIVIDER */
.wave-divider{overflow:hidden;line-height:0;display:block;margin:0}
.wave-divider svg{display:block;width:100%;height:auto}

/* 29. FOOTER */
.site-footer{background:var(--ink);position:relative;overflow:hidden}
.footer-wave{line-height:0;overflow:hidden;display:block}
.footer-wave svg{display:block;width:100%}
.footer-inner{padding:clamp(56px,8vw,90px) 0 0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:clamp(28px,4vw,56px);margin-bottom:56px}
.footer-brand img{height:46px;width:auto;max-width:200px;object-fit:contain;object-position:left top;margin-bottom:12px;filter:brightness(0) invert(1);opacity:.8}
.footer-slogan{font-family:var(--font-head);font-weight:700;font-size:.85rem;background:var(--grad-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:12px;display:block}
.footer-brand p{font-size:.84rem;color:rgba(255,255,255,.5);line-height:1.65;max-width:28ch}
.footer-socials{display:flex;gap:8px;margin-top:20px}
.social-btn{width:36px;height:36px;border-radius:var(--r-sm);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);font-size:.85rem;transition:all .25s ease;text-decoration:none}
.social-btn:hover{background:var(--blue);border-color:var(--blue);color:var(--cloud);transform:translateY(-3px)}
.footer-col h5{color:var(--cloud);font-size:.8rem;font-family:var(--font-head);font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:18px}
.footer-links li{margin-bottom:9px}
.footer-links a{color:rgba(255,255,255,.5);font-size:.84rem;transition:color .2s;display:flex;align-items:center;gap:5px;text-decoration:none}
.footer-links a::before{content:'›';color:var(--red);font-size:.95rem;flex-shrink:0}
.footer-links a:hover{color:rgba(255,255,255,.9)}
.footer-contact-item{display:flex;align-items:flex-start;gap:10px;margin-bottom:14px}
.footer-ci-icon{font-size:.95rem;color:var(--red);flex-shrink:0;margin-top:2px}
.footer-ci-text{font-size:.84rem;color:rgba(255,255,255,.5);line-height:1.5}
.footer-ci-text a{color:rgba(255,255,255,.78);display:block;transition:color .2s;text-decoration:none}
.footer-ci-text a:hover{color:var(--cloud)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding:22px 0;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.footer-copy{font-size:.78rem;color:rgba(255,255,255,.35)}
.footer-copy b{color:rgba(255,255,255,.55)}
.footer-bottom-slogan{font-family:var(--font-head);font-size:.78rem;font-weight:700;background:var(--grad-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* 30. FLOATING MOBILE BAR */
.mobile-cta-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:80;padding:10px 14px;background:rgba(255,255,255,.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 -4px 20px rgba(14,23,38,.12);gap:10px}
.mobile-cta-bar .btn{flex:1;text-align:center;padding:14px 12px;font-size:.9rem}

/* 31. CURSOR GLOW */
#cursor-glow{position:fixed;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(31,87,195,.07),transparent 70%);pointer-events:none;z-index:9998;transform:translate(-50%,-50%);display:none}
@media(hover:hover) and (pointer:fine){#cursor-glow{display:block}}

/* 32. REVEAL ANIMATIONS */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .35s var(--ease),transform .35s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-24px);transition:opacity .35s var(--ease),transform .35s var(--ease)}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(24px);transition:opacity .35s var(--ease),transform .35s var(--ease)}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-scale{opacity:0;transform:scale(.96);transition:opacity .35s var(--ease),transform .35s var(--ease)}
.reveal-scale.visible{opacity:1;transform:scale(1)}
[data-delay="1"]{transition-delay:.06s}[data-delay="2"]{transition-delay:.12s}[data-delay="3"]{transition-delay:.18s}[data-delay="4"]{transition-delay:.24s}[data-delay="5"]{transition-delay:.30s}[data-delay="6"]{transition-delay:.36s}[data-delay="7"]{transition-delay:.42s}

/* 33. FEATURE BAND */
.feature-band{background:var(--grad-cool);padding:clamp(40px,5vw,64px) 0}
.feature-band .grid-3 .f-card{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:var(--r-lg);padding:28px;text-align:center;backdrop-filter:blur(8px)}
.f-card h3,.f-card p{color:var(--cloud)}
.f-card p{opacity:.8;max-width:none;font-size:.875rem}
.f-card-icon{font-size:2rem;margin-bottom:12px;display:block}

/* 34. BG UTILITIES */
.bg-mist{background:var(--mist)}
.bg-ink{background:var(--ink)}
.section-dark .section-label{color:rgba(255,255,255,.55)}
.section-dark h2,.section-dark h3{color:var(--cloud)}
.section-dark p{color:rgba(255,255,255,.65)}

/* 35. KEYFRAMES */
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes gradient-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}

/* 36. RESPONSIVE */
@media(max-width:1024px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .process-steps{grid-template-columns:repeat(2,1fr);gap:40px}
  .process-steps::before{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
  .reviews-grid{grid-template-columns:repeat(2,1fr)}
  .counters{grid-template-columns:repeat(2,1fr)}
  .counter-item+.counter-item{border-left:none}
  .counter-item:nth-child(2){border-left:1px solid var(--border)}
  .region-grid{grid-template-columns:repeat(2,1fr)}
  .mini-process{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .main-nav,.phone-btn,.header-actions .btn:not(.mobile-show){display:none}
  .logo-wrap{max-width:calc(100% - 70px);overflow:hidden}
  .logo-slogan{font-size:.62rem;letter-spacing:.03em;white-space:nowrap;overflow:hidden;max-width:100%}
  .hamburger{display:flex}
  .mobile-nav{display:flex}
  .mobile-cta-bar{display:flex}
  body{padding-bottom:70px}
  .grid-2,.grid-3,.blurb-grid,.contact-grid,.form-row,.alt-row,.cross-links,.include-grid{grid-template-columns:1fr}
  .alt-row.reverse{direction:ltr}
  .checklist{grid-template-columns:1fr}
  .reviews-grid{grid-template-columns:1fr}
  .counters{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .region-grid{grid-template-columns:1fr}
  .process-steps{grid-template-columns:1fr;gap:28px}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .hero-ctas{flex-direction:column;align-items:flex-start}
  .cta-btns{flex-direction:column;align-items:center}
  .footer-bottom{flex-direction:column;text-align:center}
  .mini-process{grid-template-columns:1fr}
  .blurb-badge{bottom:12px;right:12px}
}
@media(max-width:480px){
  .grid-4{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
  .counters{grid-template-columns:1fr}
  .counter-item+.counter-item{border-left:none;border-top:1px solid var(--border)}
  .counter-item:nth-child(2){border-left:none;border-top:1px solid var(--border)}
}

/* 37. PREFERS-REDUCED-MOTION */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .reveal,.reveal-left,.reveal-right,.reveal-scale{opacity:1;transform:none;transition:none}
}
