/* ==========================================================
   BP Ocean — Light Premium Theme
   Stripe meets Ship4wd. Clean, warm, modern.
   ========================================================== */

/* ======================== TOKENS ======================== */
:root {
  --white:       #FFFFFF;
  --gray-50:     #F7F8FA;
  --gray-100:    #EDF0F5;
  --gray-200:    #DEE3EB;
  --gray-300:    #CBD2DC;
  --gray-400:    #94A3B8;
  --gray-600:    #4A5568;
  --gray-800:    #1A1A2E;
  --navy:        #0A1628;
  --blue:        #0052CC;
  --blue-light:  #E8F0FE;
  --blue-glow:   rgba(0,82,204,0.12);
  --coral:       #FF6B35;
  --coral-dark:  #E55A28;
  --coral-glow:  rgba(255,107,53,0.15);
  --green:       #22C55E;
  --red:         #EF4444;
  --font-heading:'Plus Jakarta Sans', sans-serif;
  --font-body:   'DM Sans', sans-serif;
  --ease:        cubic-bezier(0.16, 1, 0.3, 1);
  --radius:      8px;
  --radius-lg:   16px;
  --radius-pill: 24px;
  --shadow-sm:   0 1px 3px rgba(0,0,0,0.06);
  --shadow-md:   0 4px 16px rgba(0,0,0,0.08);
  --shadow-lg:   0 12px 40px rgba(0,0,0,0.10);
  --shadow-xl:   0 20px 60px rgba(0,0,0,0.12);
}

/* ======================== RESET ======================== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:116px;scrollbar-width:thin;scrollbar-color:var(--blue) var(--gray-100)}
::-webkit-scrollbar{width:8px}
::-webkit-scrollbar-track{background:var(--gray-100)}
::-webkit-scrollbar-thumb{background:var(--blue);border-radius:4px}
body{font-family:var(--font-body);font-size:17px;line-height:1.7;color:var(--gray-600);background:var(--white);-webkit-font-smoothing:antialiased;overflow-x:hidden;touch-action:manipulation;-webkit-tap-highlight-color:transparent;padding-top:44px}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{font-family:inherit}

/* ======================== TOP BAR ======================== */
.top-bar{position:fixed;top:0;left:0;width:100%;z-index:99;background:var(--navy);height:44px;display:flex;align-items:center;font-size:14px;line-height:1.4}
.top-bar__inner{display:flex;align-items:center;justify-content:space-between;width:100%}
.top-bar__left{display:flex;align-items:center;gap:32px}
.top-bar__item{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,0.6);font-weight:500;transition:color .2s}
.top-bar__item:hover{color:#fff}
.top-bar__item i{font-size:0.85rem;color:rgba(255,255,255,0.45)}
.top-bar__right{color:rgba(255,255,255,0.5)}
@media(max-width:768px){.top-bar__item--desktop{display:none}.top-bar__text{font-size:13px}.top-bar__inner{justify-content:center}}

/* ======================== SKIP LINK ======================== */
.skip-link{position:absolute;top:-100%;left:16px;background:var(--blue);color:var(--white);padding:12px 24px;border-radius:var(--radius);font-weight:600;z-index:10000;transition:top 0.2s}
.skip-link:focus{top:12px}

/* ======================== FOCUS ======================== */
*:focus-visible{outline:2px solid var(--blue);outline-offset:3px}
input:focus-visible,select:focus-visible,textarea:focus-visible{outline:none}

/* ======================== UTILITIES ======================== */
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 28px}
.top-bar .container,.nav-header .container{max-width:1600px;padding:0 clamp(24px,4vw,64px)}
.req{color:var(--red);font-weight:400}

.section-label{display:inline-block;font-family:var(--font-heading);font-size:0.78rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--blue);margin-bottom:12px}
.section-heading{font-family:var(--font-heading);font-size:clamp(2rem,4.5vw,2.8rem);font-weight:700;color:var(--gray-800);line-height:1.2}
.section-header{text-align:center;margin-bottom:56px}
.section-header--left{text-align:left;margin-bottom:40px}
.heading-line{width:48px;height:3px;background:var(--coral);margin-top:16px;border-radius:2px}
.heading-line--center{margin-left:auto;margin-right:auto}

/* ======================== BUTTONS ======================== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 32px;font-family:var(--font-heading);font-size:0.9rem;font-weight:600;border-radius:var(--radius);border:2px solid transparent;cursor:pointer;transition:all 0.3s var(--ease);line-height:1;position:relative}

.btn--coral{background:var(--coral);color:var(--white);border-color:var(--coral);box-shadow:0 2px 8px var(--coral-glow)}
.btn--coral:hover{background:var(--coral-dark);border-color:var(--coral-dark);transform:translateY(-2px);box-shadow:0 6px 20px var(--coral-glow)}

.btn--filled{background:var(--blue);color:var(--white);border-color:var(--blue)}
.btn--filled:hover{background:#0047b3;transform:translateY(-2px);box-shadow:0 6px 20px var(--blue-glow)}

.btn--ghost{background:transparent;color:var(--white);border-color:rgba(255,255,255,0.35)}
.btn--ghost:hover{background:rgba(255,255,255,0.1);border-color:var(--white);transform:translateY(-2px)}

.btn--outline{background:transparent;color:var(--blue);border-color:var(--gray-200)}
.btn--outline:hover{border-color:var(--blue);transform:translateY(-2px)}

.btn--full{width:100%;padding:16px 32px;font-size:1rem}
.btn--sm{padding:10px 22px;font-size:0.85rem}
.btn--full .btn__loader{display:none}
.btn--full.loading .btn__text{display:none}
.btn--full.loading .btn__loader{display:inline-flex}
.btn--full:disabled{opacity:0.45;cursor:not-allowed;transform:none!important;box-shadow:none!important}

/* Nav CTA */
.nav-cta{display:inline-flex;align-items:center;padding:10px 22px;font-family:var(--font-heading);font-size:0.85rem;font-weight:600;color:var(--white);background:var(--coral);border-radius:var(--radius);transition:all 0.3s var(--ease);box-shadow:0 2px 8px var(--coral-glow)}
.nav-cta:hover{background:var(--coral-dark);transform:translateY(-1px);box-shadow:0 4px 16px var(--coral-glow)}

/* ======================== NAVIGATION ======================== */
.nav-header{position:fixed;top:44px;left:0;width:100%;z-index:100;background:var(--navy);transition:background 0.3s var(--ease),box-shadow 0.3s var(--ease);border-bottom:1px solid transparent}
.nav-header--solid{background:var(--white);box-shadow:0 1px 3px rgba(0,0,0,0.08);border-bottom-color:var(--gray-100)}
.nav-header__inner{display:flex;align-items:center;justify-content:space-between;height:80px}

/* Transparent state (homepage hero) — light text over dark hero overlay */
.nav-header:not(.nav-header--solid) .logo__wordmark{color:var(--white)}
.nav-header:not(.nav-header--solid) .logo__tagline{color:rgba(255,255,255,0.7)}
.nav-header:not(.nav-header--solid) .nav-link{color:rgba(255,255,255,0.85)}
.nav-header:not(.nav-header--solid) .nav-link:hover{color:var(--coral)}
.nav-header:not(.nav-header--solid) .nav-link--active{color:var(--white)}
.nav-header:not(.nav-header--solid) .nav-link--active::after,
.nav-header:not(.nav-header--solid) .nav-link:hover::after{background:var(--coral)}
.nav-header:not(.nav-header--solid) .nav-more__btn{color:rgba(255,255,255,0.8)}
.nav-header:not(.nav-header--solid) .nav-more__btn:hover{color:var(--white);background:rgba(255,255,255,0.1)}
.nav-header:not(.nav-header--solid) .nav-toggle__bar{background:var(--white)}

.logo{display:flex;align-items:center;gap:12px}
.logo__mark{width:44px;height:44px;flex-shrink:0;display:block}
.logo__wordmark{font-family:var(--font-heading);font-size:22px;font-weight:700;color:var(--gray-800);letter-spacing:0.02em;display:inline-flex;flex-direction:column;line-height:1.15;text-transform:uppercase}
.logo__tagline{font-size:11px;font-weight:500;color:var(--gray-400);letter-spacing:0.15em;text-transform:uppercase;margin-top:2px}

.nav-desktop{display:flex;align-items:center;gap:36px}
.nav-link{font-family:var(--font-heading);font-size:16px;font-weight:500;color:var(--gray-600);transition:color 0.15s ease;position:relative}
.nav-link::after{content:'';position:absolute;bottom:-6px;left:0;width:0;height:2px;background:var(--blue);transition:width 0.15s var(--ease)}
.nav-link:hover{color:var(--coral)}
.nav-link:hover::after{width:100%;background:var(--coral)}
.nav-link--active{color:var(--blue)}
.nav-link--active::after{width:100%;background:var(--blue)}

/* Services dropdown */
.nav-dropdown{position:relative}
.nav-dropdown__arrow{font-size:.55rem;margin-left:3px;transition:transform .25s}
.nav-dropdown.open .nav-dropdown__arrow{transform:rotate(180deg)}
.nav-dropdown__menu{position:absolute;top:100%;left:50%;transform:translateX(-50%);width:400px;padding:16px 0;background:var(--white);border:1px solid var(--gray-100);border-radius:12px;box-shadow:0 8px 28px rgba(0,0,0,0.1);opacity:0;visibility:hidden;transition:opacity .25s,visibility .25s;z-index:200;margin-top:12px;display:flex}
.nav-dropdown.open .nav-dropdown__menu{opacity:1;visibility:visible}
.nav-dropdown__col{flex:1;padding:0 8px}
.nav-dropdown__col:first-child{border-right:1px solid var(--gray-100)}
.nav-dropdown__label{display:block;padding:4px 16px 8px;font-family:var(--font-heading);font-size:.68rem;font-weight:700;color:var(--gray-400);text-transform:uppercase;letter-spacing:1px}
.nav-dropdown__menu a{display:block;padding:7px 16px;font-family:var(--font-heading);font-size:.83rem;font-weight:500;color:var(--gray-600);transition:background .15s,color .15s;border-radius:6px;margin:0 4px}
.nav-dropdown__menu a:hover{background:var(--gray-50);color:var(--blue)}

/* Three-dot more menu */
.nav-more{position:relative;margin-left:24px}
.nav-more__btn{background:none;border:none;cursor:pointer;color:var(--gray-400);font-size:1.1rem;padding:6px;border-radius:6px;transition:color .2s,background .2s;display:flex;align-items:center}
.nav-more__btn:hover{color:var(--gray-800);background:var(--gray-50)}
.nav-more__menu{position:absolute;top:calc(100% + 8px);right:0;min-width:180px;padding:6px 0;background:var(--white);border:1px solid var(--gray-100);border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,0.1);opacity:0;visibility:hidden;transition:opacity .15s,visibility .15s;z-index:200}
.nav-more.open .nav-more__menu{opacity:1;visibility:visible}
.nav-more__menu a{display:block;padding:10px 18px;font-family:var(--font-heading);font-size:.85rem;font-weight:500;color:var(--gray-600);transition:background .15s,color .15s}
.nav-more__menu a:hover{background:var(--gray-50);color:var(--blue)}

/* Hamburger */
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;background:none;border:none;cursor:pointer;z-index:200;padding:0}
.nav-toggle__bar{display:block;width:24px;height:2px;background:var(--gray-800);border-radius:2px;transition:all 0.35s var(--ease);transform-origin:center}
.nav-toggle.active .nav-toggle__bar:first-child{transform:translateY(3.5px) rotate(45deg)}
.nav-toggle.active .nav-toggle__bar:last-child{transform:translateY(-3.5px) rotate(-45deg)}

/* Mobile menu */
.mobile-menu{position:fixed;top:0;right:-100%;width:320px;height:100vh;height:100dvh;z-index:150;background:var(--white);box-shadow:-4px 0 30px rgba(0,0,0,0.1);transition:right 0.4s var(--ease);padding:100px 36px 40px;overflow-y:auto}
.mobile-menu.open{right:0}
.mobile-menu__nav{display:flex;flex-direction:column;gap:4px}
.mobile-menu__link{font-family:var(--font-heading);font-size:1.3rem;font-weight:700;color:var(--gray-800);padding:14px 0;border-bottom:1px solid var(--gray-100);transition:color 0.3s}
.mobile-menu__link:hover{color:var(--blue)}
.mobile-menu__cta{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-heading);font-size:1rem;font-weight:600;color:var(--white);background:var(--coral);padding:14px 28px;border-radius:var(--radius);margin-top:20px;transition:background 0.3s}
.mobile-menu__cta:hover{background:var(--coral-dark)}
.mobile-menu__divider{height:1px;background:var(--gray-100);margin:12px 0}
.mobile-menu__link--secondary{font-size:1.1rem!important;font-weight:600!important;color:var(--gray-400)!important;border-bottom:none!important}
.mobile-menu__link--secondary:hover{color:var(--blue)!important}

/* ======================== HERO ======================== */
.hero{position:relative;min-height:90vh;display:flex;align-items:center;justify-content:center;overflow:hidden;background-color:var(--navy)}

/* Rotating carousel */
.hero__carousel{position:absolute;inset:0;z-index:0}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;animation:heroFade 40s infinite}
.hero-slide:nth-child(1){animation-delay:0s}
.hero-slide:nth-child(2){animation-delay:8s}
.hero-slide:nth-child(3){animation-delay:16s}
.hero-slide:nth-child(4){animation-delay:24s}
.hero-slide:nth-child(5){animation-delay:32s}
@keyframes heroFade{0%{opacity:0}5%{opacity:1}20%{opacity:1}25%{opacity:0}100%{opacity:0}}

.hero__overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(10,22,40,0.75) 0%,rgba(10,22,40,0.55) 100%);z-index:1}
.hero__inner{position:relative;z-index:2;padding:95px 0 80px;text-align:center}
.hero__content{max-width:760px;margin:0 auto}
.hero__eyebrow{font-family:var(--font-heading);font-size:0.9rem;font-weight:700;letter-spacing:0.25em;text-transform:uppercase;color:var(--coral);margin-bottom:22px}
.hero__headline{font-family:var(--font-heading);font-size:clamp(4rem,8vw,7.5rem);font-weight:800;color:var(--white);line-height:1.05;margin-bottom:56px;letter-spacing:-0.02em;white-space:normal}
.hero__headline--accent{color:var(--coral)}
.btn--lg{padding:14px 32px;font-size:0.92rem}

/* Hero standalone CTA */
.hero-quote{max-width:760px;margin:0 auto;text-align:center}
.hero-quote__btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;height:64px;min-width:240px;padding:0 40px;background:var(--coral);color:var(--white);border:none;border-radius:32px;font-family:var(--font-heading);font-size:18px;font-weight:600;text-decoration:none;cursor:pointer;transition:background 0.3s,transform 0.3s,box-shadow 0.3s;box-shadow:0 8px 24px rgba(232,102,60,0.4)}
.hero-quote__btn:hover{background:var(--coral-dark);transform:scale(1.02);box-shadow:0 12px 32px rgba(232,102,60,0.55)}
.hero-quote__tagline{text-align:center;font-size:0.82rem;color:rgba(255,255,255,0.6);margin-top:16px}

@media(max-width:1024px){
  .hero__headline{font-size:clamp(3rem,6vw,5rem)}
}
@media(max-width:640px){
  .hero__headline{font-size:clamp(2.25rem,9vw,3.5rem);margin-bottom:40px}
}

/* Wave divider */
.hero__wave{position:absolute;bottom:-1px;left:0;width:100%;z-index:3;line-height:0}
.hero__wave svg{width:100%;height:70px;display:block}

/* Reduced motion: show only first slide, no rotation */
@media(prefers-reduced-motion:reduce){
  .hero-slide{animation:none}
  .hero-slide:nth-child(1){opacity:1}
}

/* Sticky mobile CTA */
.mobile-cta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:89;background:var(--white);box-shadow:0 -2px 12px rgba(0,0,0,0.08);padding:10px 16px}
.mobile-cta__btn{display:block;width:100%;height:48px;background:var(--coral);color:var(--white);border-radius:var(--radius);font-family:var(--font-heading);font-size:0.95rem;font-weight:700;text-align:center;line-height:48px;transition:background 0.3s}
.mobile-cta__btn:hover{background:var(--coral-dark)}

/* ======================== TRUST BAR ======================== */
.trust-bar{padding:32px 0}
.trust-bar__row{max-width:900px;margin:0 auto;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:6px 0}
.trust-badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-heading);font-size:0.8rem;font-weight:500;color:var(--gray-600);white-space:nowrap;padding:4px 0}
.trust-badge i{font-size:0.85rem;color:var(--gray-400)}
.trust-dot{color:var(--gray-300);font-size:1.2rem;padding:0 10px;line-height:1}
@media(max-width:768px){.trust-dot{display:none}.trust-bar__row{gap:8px 20px}.trust-badge{flex:0 0 auto}}

/* ======================== SERVICES (soft gray bg) ======================== */
.services{padding:110px 0;background:var(--gray-50)}

/* Tabs */
.svc-tabs{display:flex;gap:10px;margin-bottom:44px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:4px}
.svc-tabs::-webkit-scrollbar{display:none}
.svc-tab{position:relative;display:inline-flex;align-items:center;gap:7px;padding:10px 20px;font-family:var(--font-heading);font-size:0.84rem;font-weight:600;color:var(--gray-600);background:var(--white);border:1px solid var(--gray-200);border-radius:50px;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all 0.3s var(--ease);overflow:hidden}
.svc-tab:hover{color:var(--gray-800);border-color:var(--gray-300)}
.svc-tab.active{background:var(--blue);color:var(--white);border-color:var(--blue);box-shadow:0 2px 12px var(--blue-glow)}
.svc-tab i{font-size:0.78rem}
.svc-tab__progress{position:absolute;bottom:0;left:0;height:2px;width:0;background:rgba(255,255,255,0.4);border-radius:0 0 50px 50px;pointer-events:none}
.svc-tab.active.auto-playing .svc-tab__progress{animation:tabProgress 6s linear forwards}
@keyframes tabProgress{from{width:0}to{width:100%}}

/* Content */
.svc-content{display:grid;grid-template-columns:1.1fr 0.9fr;gap:48px;align-items:center;min-height:380px;background:var(--white);border-radius:var(--radius-lg);padding:44px;box-shadow:var(--shadow-md)}
.svc-content__text{transition:opacity 0.4s var(--ease),transform 0.4s var(--ease)}
.svc-content__text.fading{opacity:0;transform:translateY(10px)}
.svc-content__title{font-family:var(--font-heading);font-size:clamp(1.3rem,2.5vw,1.7rem);font-weight:700;color:var(--gray-800);line-height:1.25;margin-bottom:14px}
.svc-content__desc{font-size:1rem;color:var(--gray-600);line-height:1.75;margin-bottom:24px}
.svc-content__benefits{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:28px}
.svc-content__benefits li{display:flex;align-items:center;gap:10px;font-size:0.93rem;color:var(--gray-600)}
.svc-content__benefits li i{color:var(--blue);font-size:0.7rem;width:20px;height:20px;border-radius:50%;background:var(--blue-light);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.svc-content__links{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.svc-content__cta{font-family:var(--font-heading);font-size:0.9rem;font-weight:600;color:var(--coral);display:inline-flex;align-items:center;gap:6px;transition:gap 0.3s var(--ease),color 0.3s}
.svc-content__cta:hover{gap:10px;color:var(--coral-dark)}
.svc-content__learn{font-family:var(--font-heading);font-size:0.9rem;font-weight:600;color:var(--blue);display:inline-flex;align-items:center;gap:6px;transition:gap 0.3s var(--ease),color 0.3s}
.svc-content__learn:hover{gap:10px}
.svc-content__image{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);aspect-ratio:4/3}
.svc-content__image img{width:100%;height:100%;object-fit:cover;transition:opacity 0.5s var(--ease),transform 0.6s var(--ease)}
.svc-content__image img.fading{opacity:0;transform:scale(1.04)}
.svc-fallback{width:100%;height:100%;min-height:260px;background:linear-gradient(135deg,var(--gray-50),var(--gray-100));display:flex;align-items:center;justify-content:center;color:var(--blue);font-size:3rem;opacity:0.25}

/* ======================== ABOUT (white) ======================== */
.about{padding:110px 0;background:var(--white)}
.about__inner{display:grid;grid-template-columns:1.15fr 0.85fr;gap:64px;align-items:center}
.about__globe-wrap{position:relative;width:100%;height:480px;border-radius:var(--radius-lg);overflow:hidden;background:radial-gradient(circle at center,var(--blue-light) 0%,var(--white) 70%)}
.about__globe-wrap canvas{display:block;width:100%!important;height:100%!important}
.globe-fallback{width:100%;height:100%;background:linear-gradient(135deg,var(--gray-50),var(--blue-light));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;position:absolute;inset:0}
.globe-fallback i{font-size:4rem;color:var(--blue);opacity:0.2}
.about__text{font-size:1.05rem;color:var(--gray-600);line-height:1.8;margin-bottom:36px}
.about__stats{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.stat-card{padding:24px;background:var(--white);border:1px solid var(--gray-100);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-sm);transition:box-shadow 0.3s,transform 0.3s}
.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.stat-card__number{font-family:var(--font-heading);font-size:clamp(1.8rem,3vw,2.4rem);font-weight:800;color:var(--blue);display:inline}
.stat-card__suffix{font-family:var(--font-heading);font-size:clamp(1.2rem,2vw,1.5rem);font-weight:800;color:var(--blue)}
.stat-card__label{display:block;font-size:0.82rem;color:var(--gray-400);margin-top:4px;font-weight:500}

/* ======================== PROCESS (sky blue bg) ======================== */
.process{padding:110px 0;background:var(--blue-light)}
.process__cards{display:flex;align-items:stretch;gap:0;margin-top:16px}
.process__arrow{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:36px;color:var(--gray-300);font-size:0.75rem;animation:arrowPulse 2.4s var(--ease) infinite}
@keyframes arrowPulse{0%,100%{opacity:0.3;transform:translateX(0)}50%{opacity:0.7;transform:translateX(3px)}}

.process-card{position:relative;flex:1;min-width:0;background:var(--white);border:1px solid var(--gray-100);border-radius:var(--radius-lg);padding:36px 28px 32px;overflow:hidden;box-shadow:var(--shadow-sm);transition:all 0.4s var(--ease)}
.process-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.process-card:hover .process-card__watermark{color:var(--coral);opacity:0.08}
.process-card__watermark{position:absolute;top:-16px;right:-6px;font-family:var(--font-heading);font-size:110px;font-weight:800;line-height:1;color:var(--blue);opacity:0.05;pointer-events:none;user-select:none;transition:color 0.4s,opacity 0.4s}
.process-card__icon{width:48px;height:48px;border-radius:var(--radius);background:var(--blue-light);color:var(--blue);font-size:1.1rem;display:flex;align-items:center;justify-content:center;margin-bottom:18px;transition:all 0.4s var(--ease)}
.process-card:hover .process-card__icon{background:var(--blue);color:var(--white)}
.process-card__title{font-family:var(--font-heading);font-size:1.05rem;font-weight:700;color:var(--gray-800);margin-bottom:6px}
.process-card__desc{font-size:0.88rem;color:var(--gray-400);line-height:1.55}

/* ======================== TESTIMONIALS (white) ======================== */
.testimonials{padding:90px 0;background:var(--white)}
.testimonials__grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:stretch}
.testimonial-card{background:var(--white);border:1px solid var(--gray-100);border-radius:12px;padding:32px 28px 28px;box-shadow:0 2px 12px rgba(0,0,0,0.06);display:flex;flex-direction:column;margin:0}
.testimonial-card__icon{color:var(--blue);font-size:1.3rem;margin-bottom:16px;opacity:0.6}
.testimonial-card__text{font-size:1rem;color:var(--gray-800);line-height:1.65;flex:1;margin-bottom:20px}
.testimonial-card__divider{height:1px;background:var(--gray-100);margin-bottom:20px}
.testimonial-card__author{display:flex;align-items:center;gap:12px}
.testimonial-card__avatar{width:48px;height:48px;border-radius:50%;background:var(--blue);color:var(--white);display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:0.9rem;font-weight:700;flex-shrink:0}
.testimonial-card__author strong{display:block;font-family:var(--font-heading);font-weight:700;color:var(--gray-800);font-size:0.92rem}
.testimonial-card__author span{font-size:0.8rem;color:var(--gray-400)}

/* ======================== FAQ (soft gray) ======================== */
.faq{padding:110px 0;background:var(--gray-50)}
.faq__list{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{background:var(--white);border:1px solid var(--gray-100);border-left:3px solid transparent;border-radius:var(--radius-lg);overflow:hidden;transition:border-color 0.3s,box-shadow 0.3s}
.faq-item.open{border-left-color:var(--coral);box-shadow:var(--shadow-sm)}
.faq-item__trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 24px;background:none;border:none;cursor:pointer;font-family:var(--font-heading);font-size:1rem;font-weight:600;color:var(--gray-800);text-align:left;transition:color 0.3s}
.faq-item__trigger:hover{color:var(--blue)}
.faq-item__icon{position:relative;width:24px;height:24px;flex-shrink:0}
.faq-item__icon::before,.faq-item__icon::after{content:'';position:absolute;top:50%;left:50%;width:14px;height:2px;background:var(--blue);border-radius:1px;transition:transform 0.35s var(--ease)}
.faq-item__icon::before{transform:translate(-50%,-50%)}
.faq-item__icon::after{transform:translate(-50%,-50%) rotate(90deg)}
.faq-item.open .faq-item__icon::after{transform:translate(-50%,-50%) rotate(0deg)}
.faq-item{contain:layout style}
.faq-item__body{max-height:0;overflow:hidden;transition:max-height 0.45s var(--ease)}
.faq-item__body p{padding:0 24px 22px;font-size:0.95rem;color:var(--gray-600);line-height:1.75}
.faq__cta{text-align:center;margin-top:48px}
.faq__cta p{font-size:1rem;color:var(--gray-400);margin-bottom:14px}

/* ======================== BLOG (white) ======================== */
.blog{padding:110px 0;background:var(--white)}
.blog__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.blog-card{display:flex;flex-direction:column;background:var(--white);border:1px solid var(--gray-100);border-radius:var(--radius-lg);padding:0;overflow:hidden;transition:all 0.4s var(--ease);text-decoration:none;box-shadow:var(--shadow-sm)}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--gray-200)}
.blog-card__img{width:100%;height:200px;object-fit:cover;display:block}
.blog-card__img-fallback{width:100%;height:200px;background:linear-gradient(135deg,var(--gray-50),var(--gray-100));display:flex;align-items:center;justify-content:center;color:var(--blue);font-size:2rem;opacity:.2}
.blog-card__tag,.blog-card__title,.blog-card__desc,.blog-card__link{padding-left:26px;padding-right:26px}
.blog-card__tag{margin-top:24px}
.blog-card__tag{display:inline-block;padding:4px 14px;border-radius:var(--radius-pill);font-family:var(--font-heading);font-size:0.72rem;font-weight:600;letter-spacing:0.5px;text-transform:uppercase;margin-bottom:16px;align-self:flex-start}
.blog-card__tag--blue{background:var(--blue-light);color:var(--blue)}
.blog-card__tag--gold{background:rgba(255,107,53,0.1);color:var(--coral)}
.blog-card__tag--teal{background:rgba(20,184,166,0.1);color:#0D9488}
.blog-card__title{font-family:var(--font-heading);font-size:1.1rem;font-weight:700;color:var(--gray-800);line-height:1.35;margin-bottom:10px}
.blog-card__desc{font-size:0.9rem;color:var(--gray-400);line-height:1.65;flex:1;margin-bottom:18px}
.blog-card__link{font-family:var(--font-heading);font-size:0.85rem;font-weight:600;color:var(--blue);display:inline-flex;align-items:center;gap:6px;transition:gap 0.3s var(--ease);padding-bottom:26px}
.blog-card:hover .blog-card__link{gap:10px}

/* ======================== CONTACT (dark navy) ======================== */
.contact{padding:110px 0;background:var(--navy);position:relative}
.contact__inner{display:grid;grid-template-columns:0.85fr 1.15fr;gap:56px;align-items:start}
.contact .section-label{color:var(--coral)}
.contact .section-heading{color:var(--white)}
.contact .heading-line{background:var(--coral)}
.contact__text{font-size:1rem;color:rgba(255,255,255,0.6);line-height:1.75;margin-bottom:36px}
.contact__details{display:flex;flex-direction:column;gap:22px}
.contact__detail{display:flex;align-items:flex-start;gap:14px}
.contact__detail>i{width:38px;height:38px;border-radius:var(--radius);background:rgba(0,82,204,0.15);color:var(--blue);display:flex;align-items:center;justify-content:center;font-size:0.85rem;flex-shrink:0;margin-top:2px}
.contact__detail-label{display:block;font-size:0.75rem;color:rgba(255,255,255,0.4);font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:2px}
.contact__detail a,.contact__detail span{font-size:0.95rem;color:var(--white)}
.contact__detail a:hover{color:var(--coral)}

/* Quote form card (white on dark bg) */
.contact__form-wrap{position:relative}
.quote-form{background:var(--white);border-radius:var(--radius-lg);padding:40px 36px;box-shadow:var(--shadow-xl)}
.quote-form__grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:28px}
.form-group--full{grid-column:1/-1}
.form-group label{display:block;font-family:var(--font-heading);font-size:0.82rem;font-weight:600;color:var(--gray-800);margin-bottom:6px;letter-spacing:0.3px}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 16px;background:var(--white);border:1.5px solid var(--gray-200);border-radius:var(--radius);font-family:var(--font-body);font-size:0.93rem;color:var(--gray-800);transition:border-color 0.3s,box-shadow 0.3s;outline:none}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--gray-400);opacity:0.7}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-glow)}
.form-group input.invalid,.form-group textarea.invalid,.form-group select.invalid{border-color:var(--red)}
.form-group input.invalid:focus,.form-group select.invalid:focus{box-shadow:0 0 0 3px rgba(239,68,68,0.1)}
.form-error{font-size:0.78rem;color:var(--red);margin-top:4px;min-height:1.1em}

.select-wrap{position:relative}
.select-wrap select{appearance:none;-webkit-appearance:none;cursor:pointer;padding-right:40px}
.select-wrap::after{content:'\f107';font-family:'Font Awesome 6 Free';font-weight:900;position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--gray-400);pointer-events:none;font-size:0.8rem}

.input-group{display:flex;border:1.5px solid var(--gray-200);border-radius:var(--radius);overflow:hidden;transition:border-color 0.3s,box-shadow 0.3s}
.input-group:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-glow)}
.input-group input{border:none!important;border-radius:0!important;flex:1;min-width:0}
.input-group input:focus{box-shadow:none!important}
.input-group__unit{width:68px;flex-shrink:0;border:none!important;border-left:1.5px solid var(--gray-200)!important;border-radius:0!important;background:var(--gray-50)!important;font-weight:600;font-size:0.82rem!important;color:var(--gray-600)!important;text-align:center;cursor:pointer;appearance:none;-webkit-appearance:none}

.form-success{text-align:center;padding:60px 24px}
.form-success__icon{font-size:3.2rem;color:var(--green);margin-bottom:20px;animation:successPop 0.5s var(--ease)}
@keyframes successPop{0%{transform:scale(0);opacity:0}60%{transform:scale(1.2)}100%{transform:scale(1);opacity:1}}
.form-success h3{font-family:var(--font-heading);font-size:1.5rem;color:var(--gray-800);margin-bottom:10px}
.form-success p{color:var(--gray-600);margin-bottom:24px}

.form-alert{padding:14px 20px;margin-bottom:20px;background:rgba(239,68,68,0.06);border:1px solid rgba(239,68,68,0.2);border-radius:var(--radius);color:var(--red);font-size:0.88rem;line-height:1.6;animation:alertSlideIn 0.35s var(--ease)}
@keyframes alertSlideIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}

/* ======================== GUIDE SECTION ======================== */
.guide-section{padding:80px 0;background:var(--white);border-left:4px solid var(--blue-light)}
.guide-section__inner{display:flex;align-items:center;gap:56px;max-width:960px;margin:0 auto}
.guide-section__mockup{flex-shrink:0;width:220px}
.guide-section__content{flex:1;min-width:0}
.guide-mockup{transform:rotate(-4deg);filter:drop-shadow(0 12px 32px rgba(0,0,0,0.12))}
.guide-mockup__cover{background:linear-gradient(135deg,#0A1628,#0052CC);border-radius:8px;padding:32px 24px;color:#fff;min-height:280px;display:flex;flex-direction:column;justify-content:center}
.guide-mockup__badge{display:inline-block;background:var(--coral);color:#fff;padding:4px 12px;border-radius:50px;font-family:var(--font-heading);font-size:0.65rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:16px;align-self:flex-start}
.guide-mockup__title{font-family:var(--font-heading);font-size:1rem;font-weight:700;line-height:1.3;margin-bottom:auto}
.guide-mockup__company{font-size:0.72rem;color:rgba(255,255,255,0.4);margin-top:20px}
.guide-form__row{display:flex;gap:10px}
.guide-form__row input{flex:1;height:48px;padding:0 16px;border:1.5px solid var(--gray-200);border-radius:var(--radius);font-family:var(--font-body);font-size:0.93rem;color:var(--gray-800);outline:none;transition:border-color .3s}
.guide-form__row input:focus{border-color:var(--blue)}
.guide-form__btn{flex-shrink:0;height:48px;padding:0 24px;background:var(--coral);color:#fff;border:none;border-radius:var(--radius);font-family:var(--font-heading);font-size:0.88rem;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:background .3s}
.guide-form__btn:hover{background:var(--coral-dark)}
.guide-form__note{font-size:0.78rem;color:var(--gray-400);margin-top:10px}
.guide-form__success{display:flex;align-items:center;font-family:var(--font-heading);font-size:0.95rem;font-weight:600;color:var(--gray-800)}
@media(max-width:768px){.guide-section__inner{flex-direction:column;gap:32px}.guide-section__mockup{width:180px}.guide-form__row{flex-direction:column}.guide-form__btn{width:100%}}

/* ======================== CHAT BUTTON ======================== */
.chat-btn{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:var(--coral);color:var(--white);border:none;font-size:1.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:91;box-shadow:0 4px 16px var(--coral-glow);transition:all 0.35s var(--ease);animation:chatPulse 1.5s var(--ease) 3}
@keyframes chatPulse{0%{box-shadow:0 4px 16px var(--coral-glow)}50%{box-shadow:0 4px 16px var(--coral-glow),0 0 0 10px rgba(255,107,53,0.12)}100%{box-shadow:0 4px 16px var(--coral-glow)}}
.chat-btn:hover{background:var(--coral-dark);transform:scale(1.08);box-shadow:0 6px 24px var(--coral-glow)}

/* ======================== FOOTER (dark navy) ======================== */
.footer{background:var(--navy);padding:0}
.footer__accent-line{height:3px;background:linear-gradient(90deg,transparent,var(--coral) 30%,var(--blue) 70%,transparent);opacity:0.6}
.footer__grid{display:grid;grid-template-columns:1.4fr 0.8fr 1fr 0.9fr 0.9fr;gap:32px;padding:64px 28px 48px;border-bottom:1px solid rgba(255,255,255,0.06)}
.footer__tagline{color:rgba(255,255,255,0.5);font-size:0.9rem;margin-top:16px;line-height:1.65;max-width:280px}
.footer .logo__wordmark{color:var(--white)}
.footer__social{display:flex;gap:10px;margin-top:24px}
.footer__social a{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,0.1);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.5);font-size:0.85rem;transition:all 0.3s var(--ease)}
.footer__social a:hover{color:var(--coral);border-color:var(--coral);transform:translateY(-2px)}
.footer__col h4{font-family:var(--font-heading);font-size:0.88rem;font-weight:600;color:var(--white);margin-bottom:18px}
.footer__col li{margin-bottom:11px;font-size:0.88rem;color:rgba(255,255,255,0.4)}
.footer__col a{color:rgba(255,255,255,0.4);transition:color 0.3s}
.footer__col a:hover{color:var(--coral)}
.footer__bottom{padding:22px 0}
.footer__bottom-inner{display:flex;justify-content:space-between;align-items:center;font-size:0.8rem;color:rgba(255,255,255,0.25)}
.footer__bottom-links{display:flex;gap:24px}
.footer__bottom-links a{color:rgba(255,255,255,0.25);transition:color 0.3s}
.footer__bottom-links a:hover{color:var(--coral)}

/* ======================== SCROLL TO TOP ======================== */
.scroll-top{position:fixed;bottom:92px;right:28px;width:44px;height:44px;border-radius:50%;background:var(--white);border:1px solid var(--gray-200);color:var(--blue);font-size:0.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:90;opacity:0;visibility:hidden;transform:translateY(12px);transition:all 0.35s var(--ease);box-shadow:var(--shadow-sm)}
.scroll-top.visible{opacity:1;visibility:visible;transform:translateY(0)}
.scroll-top:hover{color:var(--white);background:var(--blue);border-color:var(--blue);transform:translateY(-3px);box-shadow:var(--shadow-md)}

/* ======================== REVEAL ======================== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.8s var(--ease),transform 0.8s var(--ease);will-change:opacity,transform}
.reveal.revealed{opacity:1;transform:translateY(0)}
.process__cards .process-card.reveal:nth-of-type(2){transition-delay:0.12s}
.process__cards .process-card.reveal:nth-of-type(3){transition-delay:0.24s}
.process__cards .process-card.reveal:nth-of-type(4){transition-delay:0.36s}

/* ======================== REDUCED MOTION ======================== */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.01ms!important;transition-duration:0.01ms!important}
  .reveal,.reveal.revealed{opacity:1;transform:none}
  html{scroll-behavior:auto}
  .hero::before{animation:none!important;inset:0!important}
  .process__arrow{animation:none}
  .svc-tab__progress{animation:none!important}
  .svc-content__text,.svc-content__image img{transition:none!important}
  .chat-btn{animation:none!important}
  .faq-item__body{transition:none!important}
}

/* ======================== RESPONSIVE: 1280px (tighten header) ======================== */
@media(min-width:1025px) and (max-width:1280px){
  .nav-desktop{gap:24px}
  .logo__wordmark{font-size:20px}
}

/* ======================== RESPONSIVE: 1024px (collapse header to hamburger) ======================== */
@media(max-width:1024px){
  .nav-desktop{display:none}
  .nav-toggle{display:flex}
  .logo__tagline{display:none}
}

/* ======================== RESPONSIVE: 1200px ======================== */
@media(max-width:1200px){}

/* ======================== RESPONSIVE: 992px ======================== */
@media(max-width:992px){
  .svc-content{grid-template-columns:1fr;gap:36px;padding:32px}
  .svc-content__image{order:-1}
  .about__inner{grid-template-columns:1fr;gap:48px}
  .about__globe-wrap{height:380px}
  .process__cards{flex-wrap:wrap;gap:20px}
  .process__arrow{display:none}
  .process-card{flex:1 1 calc(50% - 10px);min-width:220px}
  .contact__inner{grid-template-columns:1fr;gap:48px}
  .blog__grid{grid-template-columns:repeat(2,1fr)}
  .blog__grid .blog-card:last-child{grid-column:1/-1;max-width:420px;margin:0 auto}
  .footer__grid{grid-template-columns:1fr 1fr;gap:36px}
}

/* ======================== RESPONSIVE: 768px ======================== */
@media(max-width:768px){
  .container{padding:0 20px}
  .hero__inner{padding:90px 0 70px}
  .mobile-cta[hidden]{display:none}
  .mobile-cta:not([hidden]){display:block}
  .chat-btn{bottom:80px}
  .scroll-top{bottom:140px}
  .svc-tabs{gap:8px}
  .svc-tab{padding:9px 16px;font-size:0.78rem}
  .process-card{flex:1 1 calc(50% - 10px)}
  .testimonials__grid{grid-template-columns:1fr;gap:16px}
  .faq-item__trigger{padding:18px 20px;font-size:0.93rem}
  .faq-item__body p{padding:0 20px 18px}
  .blog__grid{grid-template-columns:1fr}
  .blog__grid .blog-card:last-child{grid-column:auto;max-width:none}
  .quote-form{padding:28px 22px}
  .quote-form__grid{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr;gap:32px}
  .footer__bottom-inner{flex-direction:column;gap:10px;text-align:center}
  .chat-btn{width:48px;height:48px;font-size:1.1rem;bottom:20px;right:20px}
  .scroll-top{bottom:80px;right:22px;width:40px;height:40px}
}

/* ======================== RESPONSIVE: 480px ======================== */
@media(max-width:480px){
  .hero__headline{font-size:clamp(2rem,8vw,2.6rem);letter-spacing:-0.5px}
  .trust-bar__inner{gap:20px}
  .about__stats{grid-template-columns:1fr 1fr;gap:10px}
  .process-card{flex:1 1 100%}
}
