/*
Theme Name: Fortis Prima Solusi
Theme URI: https://fortis.titonkresna.my.id
Description: Custom WordPress theme for PT Fortis Prima Solusi — End-to-End Procurement Partner
Version: 1.0.0
Author: PT Fortis Prima Solusi
Text Domain: fortis
Requires at least: 6.0
Requires PHP: 7.4
*/

/* ═══════════════════════════════════════════════════════
   DESIGN TOKENS
   ═══════════════════════════════════════════════════════ */
:root {
  --blue:     #0E3BAA;
  --blue-dk:  #0a2e87;
  --blue-xdk: #060e38;
  --blue-lt:  #E6EAF2;
  --orange:   #F7612A;
  --orange-dk:#d94e1a;
  --black:    #0A0A0A;
  --gray-bg:  #F7F8FA;
  --g1:       #E6EAF2;
  --g2:       #D9DEE8;
  --g3:       #6B7280;
  --white:    #FFFFFF;
  --fh: 'Manrope', sans-serif;
  --fb: 'IBM Plex Sans', sans-serif;
  --mw: 1180px;
  --r:  10px;
  --spy: 96px;
}

/* ═══════════════════════════════════════════════════════
   RESET
   ═══════════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--fb);font-size:16px;line-height:1.75;color:var(--black);background:var(--white);-webkit-font-smoothing:antialiased;padding-top:104px}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
button{cursor:pointer;font-family:inherit;border:none;background:none;padding:0}

.wrap{width:100%;max-width:var(--mw);margin:0 auto;padding:0 40px}

/* ═══════════════════════════════════════════════════════
   SCROLL REVEAL
   ═══════════════════════════════════════════════════════ */
.fu{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.fu.on{opacity:1;transform:none}
.fu:nth-child(2){transition-delay:.08s}.fu:nth-child(3){transition-delay:.15s}
.fu:nth-child(4){transition-delay:.22s}.fu:nth-child(5){transition-delay:.29s}
.fu:nth-child(6){transition-delay:.36s}.fu:nth-child(7){transition-delay:.43s}

/* ═══════════════════════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════════════════════ */
.btn{display:inline-flex;align-items:center;gap:7px;font-family:var(--fh);font-size:14px;font-weight:600;letter-spacing:.03em;padding:13px 26px;border-radius:7px;transition:background .2s,border-color .2s,transform .15s;cursor:pointer;white-space:nowrap}
.btn:hover{transform:translateY(-1px)}
.btn-orange{background:var(--orange);color:#fff}.btn-orange:hover{background:var(--orange-dk)}
.btn-ghost-w{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.38)}.btn-ghost-w:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.75)}
.btn-blue{background:var(--blue);color:#fff}.btn-blue:hover{background:var(--blue-dk)}
.btn-ghost-b{background:transparent;color:var(--blue);border:1.5px solid var(--blue)}.btn-ghost-b:hover{background:var(--blue);color:#fff}
.btn-sm{padding:9px 18px;font-size:13px}

/* ═══════════════════════════════════════════════════════
   SECTION LABELS
   ═══════════════════════════════════════════════════════ */
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--fh);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--blue);margin-bottom:14px}
.eyebrow::before{content:'';display:block;width:16px;height:2px;background:var(--orange);border-radius:2px;flex-shrink:0}
.eyebrow-c{justify-content:center}.eyebrow-c::before{display:none}
.eyebrow-lt{color:rgba(255,255,255,.7)}
.sec-title{font-family:var(--fh);font-size:clamp(26px,3vw,36px);font-weight:700;line-height:1.2;letter-spacing:-.4px;color:var(--black)}
.sec-title-lt{color:#fff}
.sec-intro{font-size:15px;line-height:1.8;color:var(--g3);max-width:540px;margin-top:12px}

/* ═══════════════════════════════════════════════════════
   TOP INFO BAR
   ═══════════════════════════════════════════════════════ */
.top-bar{background:var(--blue-xdk);height:36px;flex-shrink:0}
.top-bar-inner{display:flex;align-items:center;justify-content:space-between;height:36px;gap:16px}
.tb-contact{display:flex;align-items:center;gap:16px}
.tb-link{display:inline-flex;align-items:center;gap:6px;font-family:var(--fh);font-size:11.5px;font-weight:500;color:rgba(255,255,255,.58);transition:color .2s;white-space:nowrap}
.tb-link:hover{color:#fff}
.tb-link svg{flex-shrink:0}
.tb-sep{width:1px;height:11px;background:rgba(255,255,255,.16);flex-shrink:0}
.tb-right{display:flex;align-items:center;gap:10px}
.tb-social{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:4px;color:rgba(255,255,255,.4);transition:color .2s,background .2s}
.tb-social:hover{color:rgba(255,255,255,.9);background:rgba(255,255,255,.08)}
.nav-search-btn{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:6px;color:var(--g3);border:none;background:none;cursor:pointer;transition:color .2s,background .2s;margin-left:4px;flex-shrink:0}
.nav-search-btn:hover{color:var(--blue);background:var(--gray-bg)}
.search-overlay{position:fixed;inset:0;z-index:600;display:flex;flex-direction:column;align-items:center;opacity:0;pointer-events:none;transition:opacity .22s ease}
.search-overlay.so-open{opacity:1;pointer-events:auto}
.so-backdrop{position:absolute;inset:0;background:rgba(4,10,40,.72);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}
.so-panel{position:relative;z-index:1;width:100%;max-width:780px;padding:0 24px;margin-top:108px;transform:translateY(-12px);transition:transform .22s ease}
.search-overlay.so-open .so-panel{transform:translateY(0)}
.so-wrap{display:flex;align-items:center;background:#fff;border-radius:14px;padding:0 16px 0 22px;box-shadow:0 28px 72px rgba(0,0,0,.28);gap:14px}
.so-search-icon{color:var(--blue);flex-shrink:0}
.so-input{flex:1;height:66px;font-family:var(--fh);font-size:18px;font-weight:500;color:var(--black);border:none;outline:none;background:transparent}
.so-input::placeholder{color:var(--g3);font-weight:400}
.so-close-btn{width:36px;height:36px;border-radius:50%;border:1.5px solid var(--g2);display:flex;align-items:center;justify-content:center;color:var(--g3);flex-shrink:0;cursor:pointer;background:none;transition:border-color .15s,color .15s}
.so-close-btn:hover{border-color:var(--blue);color:var(--blue)}
.so-hint{text-align:center;margin-top:16px;font-family:var(--fh);font-size:12px;color:rgba(255,255,255,.42);letter-spacing:.03em}
@media(max-width:680px){.so-panel{margin-top:80px;padding:0 16px}.so-input{font-size:16px;height:56px}}

/* ═══════════════════════════════════════════════════════
   HEADER & NAV
   ═══════════════════════════════════════════════════════ */
#hdr{position:fixed;top:0;left:0;right:0;z-index:200}
.main-bar{background:#fff;border-bottom:1px solid var(--g2)}
.hdr-inner{display:flex;align-items:center;justify-content:space-between;height:88px}

.logo{display:inline-flex;align-items:center;padding:4px 0;transition:opacity .2s}
.logo:hover{opacity:.82}
.logo-img{height:56px;width:auto;display:block}
.ft-logo-mark{width:28px;height:28px;background:var(--blue);border-radius:4px;display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:14px;font-weight:800;color:#fff;flex-shrink:0}
.ft-logo-name{font-family:var(--fh);font-size:16px;font-weight:800;color:#fff;letter-spacing:-.2px;line-height:1}
.ft-logo-sub{font-family:var(--fh);font-size:7.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-top:3px;line-height:1}
.ft-logo-img{height:34px;width:auto;display:block;border-radius:6px;padding:5px 10px;background:rgba(255,255,255,.95)}

.hdr-nav{display:flex;align-items:center;gap:4px}
.nav-item{position:relative}
.nav-link{display:flex;align-items:center;gap:4px;font-family:var(--fh);font-size:13.5px;font-weight:500;color:var(--g3);padding:8px 12px;border-radius:6px;transition:color .2s,background .2s;letter-spacing:.02em;cursor:pointer;white-space:nowrap}
.nav-link svg{flex-shrink:0;opacity:.6;transition:transform .2s}
.nav-link:hover{color:var(--blue);background:var(--gray-bg)}
.nav-item:hover .nav-link svg{transform:rotate(180deg)}

.subnav{position:absolute;top:calc(100% + 10px);left:0;background:#fff;border:1px solid var(--g1);border-radius:10px;padding:8px 0;min-width:210px;box-shadow:0 8px 32px rgba(0,0,0,.1),0 2px 8px rgba(0,0,0,.06);opacity:0;pointer-events:none;transform:translateY(-6px);transition:opacity .2s ease .18s,transform .2s ease .18s;z-index:300}
.subnav::before{content:'';position:absolute;top:-20px;left:0;right:0;height:20px}
.nav-item:hover .subnav{opacity:1;pointer-events:auto;transform:translateY(0);transition-delay:0s}
.nav-item.mega-open .cat-mega{opacity:1;pointer-events:auto;transform:translateY(0);transition-delay:0s}
.subnav a{display:block;padding:9px 18px;font-size:13.5px;color:var(--g3);transition:color .15s,background .15s;font-family:var(--fb)}
.subnav a:hover{color:var(--blue);background:var(--gray-bg)}
.subnav-divider{height:1px;background:var(--g1);margin:6px 0}

.subnav-svc{min-width:440px;padding:16px 12px 12px}
.svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.svc-card{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:8px;transition:background .15s;text-decoration:none}
.svc-card:hover{background:var(--gray-bg)}
.svc-card:hover .svc-name{color:var(--blue)}
.svc-icon{width:30px;height:30px;border-radius:6px;background:var(--blue-lt);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;transition:background .15s}
.svc-card:hover .svc-icon{background:var(--blue)}
.svc-icon svg{color:var(--blue);transition:color .15s}
.svc-card:hover .svc-icon svg{color:#fff}
.svc-body{display:flex;flex-direction:column;gap:1px}
.svc-name{font-family:var(--fh);font-size:12.5px;font-weight:600;color:var(--black);line-height:1.3;transition:color .15s}
.svc-desc{font-size:11px;color:var(--g3);line-height:1.4}
.svc-footer{margin-top:10px;padding-top:10px;border-top:1px solid var(--g1);display:flex;align-items:center;justify-content:space-between;gap:12px}
.svc-footer-text{font-size:12px;color:var(--g3)}
.svc-footer-link{font-family:var(--fh);font-size:12px;font-weight:600;color:var(--blue);display:inline-flex;align-items:center;gap:4px;transition:gap .18s}
.svc-footer-link:hover{gap:7px}

.cat-mega{position:fixed;top:104px;left:0;right:0;width:100%;padding:0;overflow-x:hidden;overflow-y:auto;max-height:calc(100vh - 110px);border-radius:0 0 14px 14px;border-top:none;border-left:none;border-right:none}
.cat-mega-top{padding:16px 48px 12px}
.cat-mega-all{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:8px;background:var(--gray-bg);transition:background .15s;text-decoration:none}
.cat-mega-all:hover{background:var(--blue-lt)}
.cat-mega-all-icon{width:32px;height:32px;border-radius:7px;background:var(--blue);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}
.cat-mega-all:hover .cat-mega-all-icon{background:var(--blue-dk)}
.cat-mega-all-icon svg{color:#fff}
.cat-mega-all-body{flex:1}
.cat-mega-all-name{display:block;font-family:var(--fh);font-size:13.5px;font-weight:700;color:var(--black);line-height:1.2;transition:color .15s}
.cat-mega-all:hover .cat-mega-all-name{color:var(--blue)}
.cat-mega-all-desc{display:block;font-size:11.5px;color:var(--g3);margin-top:1px}
.cat-mega-all-arr{font-family:var(--fh);font-size:14px;font-weight:600;color:var(--blue);flex-shrink:0;opacity:.7;transition:opacity .15s,transform .15s}
.cat-mega-all:hover .cat-mega-all-arr{opacity:1;transform:translateX(-3px)}
.cat-mega-sep{height:1px;background:var(--g1);margin:0 48px}
.cat-mega-body{display:grid;grid-template-columns:1fr auto 1fr;padding:16px 48px 12px;gap:0}
.cat-mega-sec-head{font-family:var(--fh);font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--g3);margin-bottom:8px;padding:0 4px}
.cat-mega-cat-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:2px}
.cat-mega-brand-grid{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:2px}
.cat-mega-item{display:flex;align-items:flex-start;gap:9px;padding:8px 9px;border-radius:7px;transition:background .15s;text-decoration:none}
.cat-mega-item:hover{background:var(--gray-bg)}
.cat-mega-item:hover .cat-mega-item-icon{background:var(--blue)}
.cat-mega-item:hover .cat-mega-item-icon svg{color:#fff}
.cat-mega-item:hover .cat-mega-item-name{color:var(--blue)}
.cat-mega-item--brand{align-items:center;padding:6px 8px}
.cat-mega-item-icon{width:26px;height:26px;border-radius:5px;background:var(--blue-lt);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s;margin-top:1px}
.cat-mega-item--brand .cat-mega-item-icon{margin-top:0}
.cat-mega-item-icon svg{color:var(--blue);transition:color .15s}
.cat-mega-item-body{display:flex;flex-direction:column;gap:1px;min-width:0}
.cat-mega-item-name{font-family:var(--fh);font-size:12.5px;font-weight:600;color:var(--black);line-height:1.3;transition:color .15s}
.cat-mega-item-sub{font-size:11px;color:var(--g3);line-height:1.3;margin-top:1px}
.cat-mega-vsep{width:1px;background:var(--g1);margin:0 16px}
.cat-mega-footer{border-top:1px solid var(--g1);margin-top:4px;padding:12px 48px 16px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.cat-mega-footer-text{font-size:12px;color:var(--g3)}
.cat-mega-footer-link{font-family:var(--fh);font-size:12.5px;font-weight:600;color:var(--blue);display:inline-flex;align-items:center;gap:4px;transition:gap .18s}
.cat-mega-footer-link:hover{gap:8px}

.hdr-cta{font-family:var(--fh);font-size:13px;font-weight:600;letter-spacing:.04em;padding:9px 20px;background:var(--orange);color:#fff;border-radius:6px;transition:background .2s;margin-left:8px}
.hdr-cta:hover{background:var(--orange-dk)}

.nav-tog{display:none;align-items:center;justify-content:center;width:44px;height:44px;border-radius:6px;position:relative;flex-shrink:0;transition:background .2s}
.nav-tog:hover{background:var(--gray-bg)}
.nav-tog-bar{position:absolute;left:50%;top:50%;margin-left:-11px;margin-top:-1px;width:22px;height:2px;border-radius:2px;background:var(--black);transition:transform 280ms cubic-bezier(.4,0,.2,1),opacity 200ms ease}
.nav-tog-bar:nth-child(1){transform:translateY(-6px)}
.nav-tog-bar:nth-child(2){transform:translateY(0)}
.nav-tog-bar:nth-child(3){transform:translateY(6px)}
.nav-tog.is-open .nav-tog-bar:nth-child(1){transform:translateY(0) rotate(45deg)}
.nav-tog.is-open .nav-tog-bar:nth-child(2){transform:translateY(0) scaleX(0);opacity:0}
.nav-tog.is-open .nav-tog-bar:nth-child(3){transform:translateY(0) rotate(-45deg)}

.mnav-backdrop{position:fixed;inset:0;background:rgba(10,10,10,.3);z-index:185;opacity:0;pointer-events:none;visibility:hidden;transition:opacity 300ms ease,visibility 0s linear 300ms}
.mnav-backdrop.is-open{opacity:1;pointer-events:auto;visibility:visible;transition:opacity 300ms ease,visibility 0s linear 0s}

.mobile-nav{position:fixed;top:104px;left:0;right:0;bottom:0;background:#fff;z-index:190;overflow-y:auto;overflow-x:hidden;padding:20px 0 56px;opacity:0;transform:translateY(-14px);pointer-events:none;visibility:hidden;transition:opacity 300ms cubic-bezier(.25,.1,.25,1),transform 300ms cubic-bezier(.25,.1,.25,1),visibility 0s linear 300ms}
.mobile-nav.is-open{opacity:1;transform:translateY(0);pointer-events:auto;visibility:visible;transition:opacity 300ms cubic-bezier(.25,.1,.25,1),transform 300ms cubic-bezier(.25,.1,.25,1),visibility 0s linear 0s}

.mnav-item{border-bottom:1px solid var(--g1)}
.mnav-link{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 24px;min-height:54px;font-family:var(--fh);font-size:15px;font-weight:600;color:var(--black);cursor:pointer;transition:color .18s;-webkit-tap-highlight-color:transparent;user-select:none}
.mnav-link:hover{color:var(--blue)}
a.mnav-link{display:flex}
.mnav-chevron{flex-shrink:0;opacity:.38;transition:transform 280ms cubic-bezier(.4,0,.2,1),opacity 200ms ease}
.mnav-link.is-open .mnav-chevron{transform:rotate(180deg);opacity:.6}

.mnav-sub{display:grid;grid-template-rows:0fr;transition:grid-template-rows 280ms cubic-bezier(.4,0,.2,1);background:var(--gray-bg)}
.mnav-sub.is-open{grid-template-rows:1fr}
.mnav-sub-inner{overflow:hidden;min-height:0}
.mnav-sub a{display:flex;align-items:center;min-height:44px;padding:0 24px 0 34px;font-size:13.5px;font-family:var(--fb);color:var(--g3);border-bottom:1px solid rgba(230,234,242,.7);transition:color .18s,background .18s}
.mnav-sub a:last-child{border-bottom:none}
.mnav-sub a:hover{color:var(--blue);background:rgba(14,59,170,.04)}
.mnav-sub a.mnav-svc-row{align-items:flex-start;min-height:auto;padding:10px 24px;gap:10px}
.mnav-svc-icon{width:28px;height:28px;border-radius:6px;background:var(--blue-lt);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px;transition:background .18s}
.mnav-svc-icon svg{color:var(--blue);transition:color .18s}
.mnav-svc-body{display:flex;flex-direction:column;gap:1px}
.mnav-svc-name{font-family:var(--fh);font-size:13.5px;font-weight:600;color:var(--black);line-height:1.3;transition:color .18s}
.mnav-svc-desc{font-size:11.5px;color:var(--g3);line-height:1.4}
.mnav-sub a.mnav-svc-row:hover .mnav-svc-icon{background:var(--blue)}
.mnav-sub a.mnav-svc-row:hover .mnav-svc-icon svg{color:#fff}
.mnav-sub a.mnav-svc-row:hover .mnav-svc-name{color:var(--blue)}
.mnav-sub-head{padding:6px 24px 4px;font-family:var(--fh);font-size:10.5px;font-weight:700;color:var(--g3);letter-spacing:.08em;text-transform:uppercase;border-bottom:1px solid rgba(230,234,242,.5)}
.mnav-sub-divider{height:1px;background:var(--g2);margin:2px 0}
.mnav-sub a.mnav-cat-row{min-height:auto;padding:7px 24px;gap:10px}
.mnav-cat-icon{width:24px;height:24px;border-radius:5px;background:var(--blue-lt);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .18s}
.mnav-cat-icon svg{color:var(--blue);transition:color .18s}
.mnav-sub a.mnav-cat-row:hover .mnav-cat-icon{background:var(--blue)}
.mnav-sub a.mnav-cat-row:hover .mnav-cat-icon svg{color:#fff}
.mnav-sub a.mnav-all-link{font-family:var(--fh);font-size:13px;font-weight:700;color:var(--blue);justify-content:center;border-bottom:none;padding:10px 24px}

.mnav-cta{padding:22px 24px 0}
.mnav-cta .btn{width:100%;justify-content:center;padding:15px 24px;font-size:14px;border-radius:8px;transition:background .2s,transform .12s;-webkit-tap-highlight-color:transparent}
.mnav-cta .btn:active{transform:scale(.98)}

/* ═══════════════════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════════════════ */
#home{position:relative;background:var(--blue-xdk)}
.hero-wrap{position:relative;height:calc(100vh - 104px);min-height:520px;max-height:820px;overflow:hidden}
.hero-track{display:flex;height:100%;transition:transform .82s cubic-bezier(.4,0,.2,1);will-change:transform}
.hero-slide{flex:0 0 100%;min-width:100%;height:100%;position:relative}
.hero-slide img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}
.slide-overlay{position:absolute;inset:0;background:linear-gradient(100deg,rgba(4,10,38,.93) 0%,rgba(5,14,52,.86) 32%,rgba(5,14,52,.64) 56%,rgba(5,14,52,.26) 80%,rgba(5,14,52,.08) 100%)}
.hero-text-layer{position:absolute;inset:0;z-index:3;display:flex;align-items:center;pointer-events:auto}
.hero-text-wrap{width:100%;max-width:var(--mw);margin:0 auto;padding:0 40px;padding-top:56px}
.hero-text-inner{max-width:600px}
.hero-text-layer.htx-out{animation:htOut 220ms ease forwards}
.hero-text-layer.htx-in{animation:htIn 420ms cubic-bezier(.25,.1,.25,1) forwards}
@keyframes htOut{from{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-14px)}}
@keyframes htIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.hero-ey{display:inline-flex;align-items:center;gap:8px;font-family:var(--fh);font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--orange);margin-bottom:20px}
.hero-ey::before{content:'';display:block;width:14px;height:2px;background:var(--orange);border-radius:2px}
.hero-h1{font-family:var(--fh);font-size:clamp(34px,4.8vw,58px);font-weight:700;line-height:1.08;letter-spacing:-1.2px;color:#fff;margin-bottom:18px;text-wrap:balance}
.hero-p{font-size:15.5px;line-height:1.8;color:rgba(255,255,255,.74);max-width:490px;margin-bottom:34px}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap}
.hero-ctrl{position:absolute;bottom:28px;right:40px;z-index:4;display:flex;align-items:center;gap:14px}
.hero-arr{width:42px;height:42px;border-radius:50%;border:1.5px solid rgba(255,255,255,.32);color:#fff;font-size:15px;display:flex;align-items:center;justify-content:center;transition:background .2s,border-color .2s;cursor:pointer}
.hero-arr:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.7)}
.hero-dots{display:flex;gap:7px}
.hero-dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.3);cursor:pointer;border:none;transition:background .3s,transform .3s}
.hero-dot.on{background:var(--orange);transform:scale(1.4)}
.hero-slide-n{position:absolute;bottom:36px;left:40px;z-index:4;font-family:var(--fh);font-size:12px;font-weight:600;color:rgba(255,255,255,.4);letter-spacing:.08em}
.hero-slide-n strong{color:rgba(255,255,255,.75)}
.hero-stats{background:var(--blue-xdk);border-top:1px solid rgba(255,255,255,.1)}
.hero-stats-inner{display:flex;max-width:var(--mw);margin:0 auto;padding:0 40px}
.hstat{flex:1;padding:22px 0;border-right:1px solid rgba(255,255,255,.1)}
.hstat:last-child{border-right:none}
.hstat-num{font-family:var(--fh);font-size:26px;font-weight:700;color:#fff;letter-spacing:-.4px;line-height:1;margin-bottom:4px}
.hstat-lbl{font-size:12.5px;color:rgba(255,255,255,.5);line-height:1.4}
.hero-trust{background:#fff;border-bottom:1px solid var(--g1)}
.hero-trust-inner{display:flex;justify-content:center;gap:56px;max-width:var(--mw);margin:0 auto;padding:18px 40px}
.htrust-item{display:flex;align-items:center;gap:12px}
.htrust-check{width:26px;height:26px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.htrust-label{font-family:var(--fh);font-size:14px;font-weight:700;color:var(--black);line-height:1.2}
.htrust-sub{font-size:11.5px;color:var(--g3);margin-top:2px}
@media(max-width:680px){.hero-trust-inner{gap:28px;flex-wrap:wrap;padding:16px 22px}.htrust-item{flex:1;min-width:120px}}

/* ═══════════════════════════════════════════════════════
   SECTION BASE
   ═══════════════════════════════════════════════════════ */
.section{padding:var(--spy) 0}
.section-gray{background:#E9EDF7;background-image:linear-gradient(rgba(14,59,170,.022) 1px,transparent 1px),linear-gradient(90deg,rgba(14,59,170,.022) 1px,transparent 1px);background-size:52px 52px}
.section-blue{background:var(--blue);position:relative;overflow:hidden}
.section-dark{background:var(--black)}
.section-bt{border-top:1px solid var(--g1)}
.section-dark.section-bt{border-top:1px solid rgba(255,255,255,.07)}
.section-blue.section-bt{border-top:none}
.section-blue::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:60px 60px;pointer-events:none}
.section-dark .sec-title,.section-blue .sec-title{color:#fff}
.section-dark .sec-intro,.section-blue .sec-intro{color:rgba(255,255,255,.58)}
.section-dark .eyebrow,.section-blue .eyebrow{color:var(--orange)}
.section-dark .eyebrow::before,.section-blue .eyebrow::before{background:var(--orange)}
.section-blue .cap-card{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.13)}
.section-blue .cap-card:hover{background:rgba(255,255,255,.13);border-color:rgba(255,255,255,.28);box-shadow:0 6px 28px rgba(0,0,0,.25);transform:translateY(-3px)}
.section-blue .cap-num{color:var(--orange)}
.section-blue .cap-title{color:#fff}
.section-blue .cap-body{color:rgba(255,255,255,.62)}
.section-blue .cap-link{color:var(--orange)}
.section-dark .brand-chip{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.12);color:rgba(255,255,255,.65)}
.section-dark .brand-chip:hover{border-color:var(--orange);color:#fff;box-shadow:0 2px 16px rgba(247,97,42,.18)}
.section-dark .brands-note{color:rgba(255,255,255,.26)}
.section-blue .proc-steps::before{background:rgba(255,255,255,.18)}
.section-blue .step-ring{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.25)}
.section-blue .step-n{color:#fff}
.section-blue .step-title{color:#fff}
.section-blue .step-body{color:rgba(255,255,255,.62)}
.section-blue .proc-step:hover .step-ring{background:var(--orange);border-color:var(--orange)}
.section-blue .proc-step:hover .step-n{color:#fff}
.am{background:linear-gradient(135deg,#f0f4ff 0%,#fff 100%);border-left:3px solid var(--blue)}
.am:hover{border-color:var(--blue);border-left-color:var(--orange)}

/* ═══════════════════════════════════════════════════════
   ABOUT
   ═══════════════════════════════════════════════════════ */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.about-highlights{display:flex;flex-direction:column;border:1px solid var(--g1);border-radius:var(--r);overflow:hidden;margin-top:32px}
.ah{display:flex;gap:14px;padding:18px 22px;border-bottom:1px solid var(--g1);align-items:flex-start;transition:background .2s}
.ah:last-child{border-bottom:none}.ah:hover{background:var(--gray-bg)}
.ah-dot{width:7px;height:7px;border-radius:50%;background:var(--orange);flex-shrink:0;margin-top:8px}
.ah-title{font-family:var(--fh);font-size:14px;font-weight:700;color:var(--black);margin-bottom:2px}
.ah-body{font-size:13.5px;color:var(--g3);line-height:1.65}
.about-cta-row{margin-top:28px}
.about-right{display:flex;flex-direction:column;gap:18px}
.about-img{width:100%;aspect-ratio:4/3;border-radius:var(--r);overflow:hidden;position:relative;box-shadow:0 8px 32px rgba(0,0,0,.1)}
.about-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.about-metrics{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.am{border:1px solid var(--g1);border-radius:8px;padding:18px 20px;transition:border-color .2s}
.am:hover{border-color:var(--blue)}
.am-num{font-family:var(--fh);font-size:26px;font-weight:700;color:var(--blue);letter-spacing:-.4px;margin-bottom:3px}
.am-lbl{font-size:13px;color:var(--g3);line-height:1.4}

/* ═══════════════════════════════════════════════════════
   CAPABILITIES
   ═══════════════════════════════════════════════════════ */
.cap-hdr{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:end;margin-bottom:48px}
.cap-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.cap-card{background:var(--white);border:1px solid var(--g1);border-radius:var(--r);padding:28px 24px;display:flex;flex-direction:column;gap:10px;transition:border-color .25s,box-shadow .25s,transform .25s}
.cap-card:hover{border-color:var(--blue);box-shadow:0 4px 24px rgba(14,59,170,.08);transform:translateY(-3px)}
.cap-num{font-family:var(--fh);font-size:10px;font-weight:700;letter-spacing:.14em;color:var(--orange)}
.cap-title{font-family:var(--fh);font-size:15.5px;font-weight:700;color:var(--black);line-height:1.3}
.cap-body{font-size:13.5px;line-height:1.7;color:var(--g3);flex:1}
.cap-link{display:inline-flex;align-items:center;gap:5px;font-family:var(--fh);font-size:13px;font-weight:600;color:var(--blue);margin-top:4px;transition:gap .2s}
.cap-card:hover .cap-link{gap:8px}

/* ═══════════════════════════════════════════════════════
   CATEGORIES
   ═══════════════════════════════════════════════════════ */
.cat-hdr{display:flex;align-items:flex-end;justify-content:space-between;gap:40px;margin-bottom:40px}
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.cat-tile{position:relative;border-radius:var(--r);overflow:hidden;min-height:220px;display:flex;flex-direction:column;justify-content:flex-end;cursor:pointer}
.cat-tile--wide{grid-column:span 2;min-height:240px}
.cat-bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .5s ease}
.cat-tile:hover .cat-bg{transform:scale(1.05)}
.cat-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(4,10,40,.88) 0%,rgba(4,10,40,.5) 50%,rgba(4,10,40,.1) 100%);transition:background .35s ease}
.cat-tile:hover .cat-overlay{background:linear-gradient(to top,rgba(14,59,170,.90) 0%,rgba(14,59,170,.55) 55%,rgba(14,59,170,.12) 100%)}
.cat-content{position:relative;z-index:2;padding:20px 18px 18px}
.ct-label{font-family:var(--fh);font-size:10px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--orange);margin-bottom:6px}
.ct-title{font-family:var(--fh);font-size:16px;font-weight:700;color:#fff;line-height:1.25;margin-bottom:4px}
.ct-title-lg{font-size:19px}
.ct-desc{font-size:12.5px;color:rgba(255,255,255,.62);margin-bottom:14px;line-height:1.5}
.ct-cta{display:inline-flex;align-items:center;gap:5px;font-family:var(--fh);font-size:12.5px;font-weight:600;color:#fff;opacity:0;transform:translateY(4px);transition:opacity .25s,transform .25s,gap .2s}
.cat-tile:hover .ct-cta{opacity:1;transform:translateY(0)}
.cat-tile:hover .ct-cta:hover{gap:8px}

/* ═══════════════════════════════════════════════════════
   BRANDS
   ═══════════════════════════════════════════════════════ */
.brands-hdr{text-align:center;margin-bottom:44px}
.brands-hdr .sec-intro{margin:12px auto 0;text-align:center}
.brands-row{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.brand-chip{padding:13px 26px;background:var(--white);border:1px solid var(--g1);border-radius:8px;font-family:var(--fh);font-size:15px;font-weight:700;color:var(--g3);letter-spacing:.04em;transition:border-color .2s,color .2s,box-shadow .2s;min-width:100px;text-align:center}
.brand-chip:hover{border-color:var(--blue);color:var(--blue);box-shadow:0 2px 12px rgba(14,59,170,.07)}
.brands-note{text-align:center;margin-top:20px;font-size:12px;color:rgba(107,114,128,.55)}

/* ═══════════════════════════════════════════════════════
   WHY FORTIS
   ═══════════════════════════════════════════════════════ */
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.why-reasons{display:flex;flex-direction:column;border:1px solid var(--g1);border-radius:var(--r);overflow:hidden;margin-top:32px}
.wr{display:flex;gap:18px;padding:20px 24px;border-bottom:1px solid var(--g1);align-items:flex-start;transition:background .2s}
.wr:last-child{border-bottom:none}.wr:hover{background:var(--gray-bg)}
.wr-n{font-family:var(--fh);font-size:10px;font-weight:700;color:var(--orange);letter-spacing:.1em;min-width:22px;padding-top:3px}
.wr-title{font-family:var(--fh);font-size:14px;font-weight:700;color:var(--black);margin-bottom:3px}
.wr-body{font-size:13.5px;color:var(--g3);line-height:1.6}
.why-panel{display:flex;flex-direction:column;gap:16px;padding-top:8px}
.why-blue{background:var(--blue);border-radius:var(--r);padding:36px 32px;position:relative;overflow:hidden;min-height:230px;display:flex;flex-direction:column;justify-content:space-between}
.why-blue::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:40px 40px}
.wb-top{position:relative;z-index:1}
.wb-stat{font-family:var(--fh);font-size:48px;font-weight:800;color:#fff;letter-spacing:-2px;line-height:1}
.wb-lbl{font-size:13px;color:rgba(255,255,255,.58);margin-top:6px}
.wb-tag{position:relative;z-index:1;font-family:var(--fh);font-size:16px;font-weight:700;color:#fff;line-height:1.4;max-width:210px}
.why-img{border-radius:var(--r);overflow:hidden;height:196px;border:1px solid var(--g1);position:relative}
.why-img img{width:100%;height:100%;object-fit:cover}
.why-img-cap{position:absolute;bottom:0;left:0;right:0;padding:12px 16px;background:linear-gradient(transparent,rgba(10,10,10,.55));font-size:12px;color:rgba(255,255,255,.8);font-family:var(--fh);font-weight:500}

/* ═══════════════════════════════════════════════════════
   PROCESS
   ═══════════════════════════════════════════════════════ */
.proc-hdr{text-align:center;margin-bottom:60px}
.proc-hdr .sec-intro{margin:12px auto 0;text-align:center}
.proc-steps{display:grid;grid-template-columns:repeat(4,1fr);position:relative}
.proc-steps::before{content:'';position:absolute;top:36px;left:calc(12.5% + 2px);right:calc(12.5% + 2px);height:1px;background:var(--g2)}
.proc-step{display:flex;flex-direction:column;align-items:center;text-align:center;padding:0 20px;position:relative;z-index:1}
.step-ring{width:72px;height:72px;border-radius:50%;background:var(--white);border:2px solid var(--g2);display:flex;align-items:center;justify-content:center;margin-bottom:24px;flex-shrink:0;transition:border-color .3s,background .3s}
.proc-step:hover .step-ring{border-color:var(--blue);background:var(--blue)}
.step-n{font-family:var(--fh);font-size:20px;font-weight:700;color:var(--blue);transition:color .3s}
.proc-step:hover .step-n{color:#fff}
.step-title{font-family:var(--fh);font-size:15px;font-weight:700;color:var(--black);margin-bottom:10px;line-height:1.3}
.step-body{font-size:13.5px;color:var(--g3);line-height:1.7}

/* ═══════════════════════════════════════════════════════
   BLOG
   ═══════════════════════════════════════════════════════ */
.blog-hdr{display:flex;align-items:flex-end;justify-content:space-between;gap:40px;margin-bottom:44px}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.blog-card{border:1px solid var(--g1);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:border-color .25s,box-shadow .25s,transform .25s}
.blog-card:hover{border-color:var(--blue);box-shadow:0 6px 28px rgba(14,59,170,.08);transform:translateY(-3px)}
.blog-img{height:190px;overflow:hidden;background:var(--g1);position:relative}
.blog-img img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease}
.blog-card:hover .blog-img img{transform:scale(1.04)}
.blog-body{padding:22px 20px;display:flex;flex-direction:column;gap:9px;flex:1}
.blog-cat{font-family:var(--fh);font-size:10px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--orange)}
.blog-title{font-family:var(--fh);font-size:15px;font-weight:700;color:var(--black);line-height:1.4}
.blog-exc{font-size:13.5px;color:var(--g3);line-height:1.7;flex:1}
.blog-link{display:inline-flex;align-items:center;gap:5px;font-family:var(--fh);font-size:13px;font-weight:600;color:var(--blue);margin-top:8px;transition:gap .2s}
.blog-card:hover .blog-link{gap:9px}

/* ═══════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════ */
#site-footer{background:#071a4f;padding:72px 0 0}
.ft-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:40px;padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,.08)}
.ft-logo{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.logo-img-ft{height:28px;width:auto;display:block;border-radius:4px}
.ft-desc{font-size:13.5px;color:rgba(255,255,255,.42);line-height:1.75;max-width:240px;margin-bottom:18px}
.ft-addr{font-size:13px;color:rgba(255,255,255,.38);line-height:1.7}
.ft-col-ttl{font-family:var(--fh);font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:18px}
.ft-links{display:flex;flex-direction:column;gap:11px}
.ft-links a{font-size:13.5px;color:rgba(255,255,255,.52);transition:color .2s}
.ft-links a:hover{color:#fff}
.ft-ci{margin-bottom:14px}
.ft-ci-lbl{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:3px}
.ft-ci-val{font-size:13.5px;color:rgba(255,255,255,.65);line-height:1.55}
.ft-ci-val a{color:var(--orange);transition:color .2s}
.ft-ci-val a:hover{color:#ff7a4a}
.ft-inquiry{display:inline-flex;align-items:center;gap:5px;font-family:var(--fh);font-size:13px;font-weight:600;color:var(--orange);margin-top:8px;transition:gap .2s}
.ft-inquiry:hover{gap:8px}
.ft-bot{padding:24px 0;display:flex;justify-content:space-between;align-items:center;gap:20px;border-top:1px solid rgba(255,255,255,.06);margin-top:0}
.ft-copy{font-size:12.5px;color:rgba(255,255,255,.2)}
.ft-legal{font-size:12.5px;color:rgba(255,255,255,.18)}

/* ═══════════════════════════════════════════════════════
   FAQ
   ═══════════════════════════════════════════════════════ */
.faq-wrap{max-width:740px;margin:0 auto}
.faq-hdr{text-align:center;margin-bottom:52px}
.faq-hdr .sec-intro{margin:12px auto 0;text-align:center;max-width:480px}
.faq-item{border-bottom:1px solid var(--g1)}
.faq-item:first-child{border-top:1px solid var(--g1)}
.faq-q{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0;width:100%;cursor:pointer;font-family:var(--fh);font-size:15px;font-weight:600;color:var(--black);text-align:left;background:none;border:none;transition:color .18s;-webkit-tap-highlight-color:transparent;user-select:none}
.faq-q:hover{color:var(--blue)}
.faq-icon{flex-shrink:0;width:28px;height:28px;border-radius:50%;border:1.5px solid var(--g2);display:flex;align-items:center;justify-content:center;transition:border-color .22s,background .22s,transform .28s cubic-bezier(.4,0,.2,1)}
.faq-item.is-open .faq-icon{border-color:var(--blue);background:var(--blue);transform:rotate(45deg)}
.faq-icon svg{transition:stroke .2s}
.faq-item.is-open .faq-icon svg{stroke:#fff}
.faq-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows 280ms cubic-bezier(.4,0,.2,1)}
.faq-item.is-open .faq-body{grid-template-rows:1fr}
.faq-body-inner{overflow:hidden;min-height:0}
.faq-a{padding:0 44px 20px 0;font-size:14.5px;color:var(--g3);line-height:1.8}

/* ═══════════════════════════════════════════════════════
   CONTACT FORM
   ═══════════════════════════════════════════════════════ */
.cf-grid{display:grid;grid-template-columns:1fr 1.55fr;gap:80px;align-items:start}
.cf-info .sec-intro{margin-top:12px}
.cf-details{margin-top:36px;display:flex;flex-direction:column;gap:22px}
.cf-detail{display:flex;flex-direction:column;gap:4px}
.cf-detail-lbl{font-size:11px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--g3)}
.cf-detail-val{font-size:14px;color:var(--black);font-family:var(--fh);font-weight:500;line-height:1.55}
.cf-detail-val a{color:var(--blue);transition:color .2s}
.cf-detail-val a:hover{color:var(--blue-dk)}
.cf-form{display:flex;flex-direction:column;gap:16px}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cf-group{display:flex;flex-direction:column;gap:7px}
.cf-group label{font-family:var(--fh);font-size:12px;font-weight:600;color:var(--black);letter-spacing:.01em}
.cf-group label .req{color:var(--orange);margin-left:2px}
.cf-group input,.cf-group select,.cf-group textarea{width:100%;padding:11px 14px;border:1.5px solid var(--g2);border-radius:7px;font-family:var(--fb);font-size:14px;color:var(--black);background:#fff;transition:border-color .18s,box-shadow .18s;outline:none;appearance:none;-webkit-appearance:none}
.cf-group input:focus,.cf-group select:focus,.cf-group textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(14,59,170,.08)}
.cf-group input::placeholder,.cf-group textarea::placeholder{color:var(--g3);opacity:.65}
.cf-group select{background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236B7280' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;cursor:pointer}
.cf-group textarea{min-height:120px;resize:vertical;line-height:1.6}
.cf-footer{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:4px}
.cf-note{font-size:12.5px;color:var(--g3);line-height:1.5}
.cf-success{display:none;padding:20px 24px;background:rgba(14,59,170,.05);border:1px solid rgba(14,59,170,.14);border-radius:8px;font-family:var(--fh);font-size:14.5px;font-weight:600;color:var(--blue);line-height:1.6}
.cf-success.show{display:block}

/* ═══════════════════════════════════════════════════════
   CART ICON
   ═══════════════════════════════════════════════════════ */
.cart-icon-wrap{position:relative;display:inline-flex;align-items:center;margin-left:4px}
.cart-icon-btn{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:6px;color:var(--g3);transition:color .2s,background .2s}
.cart-icon-btn:hover{color:var(--blue);background:var(--gray-bg)}
.cart-badge{position:absolute;top:4px;right:4px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--orange);color:#fff;font-family:var(--fh);font-size:10px;font-weight:700;line-height:16px;text-align:center;display:none;pointer-events:none}
.cart-badge.has-items{display:block}

/* ═══════════════════════════════════════════════════════
   CATALOG PREVIEW
   ═══════════════════════════════════════════════════════ */
.cp-hdr{display:flex;align-items:flex-end;justify-content:space-between;gap:40px;margin-bottom:44px}
.cp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.cp-card{background:#fff;border:1px solid var(--g1);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;transition:border-color .2s,box-shadow .25s,transform .2s;box-shadow:0 1px 4px rgba(0,0,0,.05)}
.cp-card:hover{border-color:var(--blue);box-shadow:0 10px 36px rgba(14,59,170,.12);transform:translateY(-2px)}
.cp-img{aspect-ratio:4/3;overflow:hidden;background:#f4f6f8;position:relative;flex-shrink:0}
.cp-img img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease;display:block}
.cp-card:hover .cp-img img{transform:scale(1.06)}
.cp-body{padding:14px 16px 16px;display:flex;flex-direction:column;flex:1;border-top:1px solid var(--g1)}
.cp-meta-row{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}
.cp-cat-label{display:inline-flex;align-items:center;font-family:var(--fh);font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);background:var(--blue-lt);padding:2px 8px;border-radius:20px;width:fit-content}
.cp-title{font-family:var(--fh);font-size:14.5px;font-weight:700;color:var(--black);line-height:1.35;flex:1;margin-bottom:14px}
.cp-brand-tag{font-family:var(--fh);font-size:11px;font-weight:500;color:var(--g3)}
.cp-add{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;padding:11px 14px;border-radius:8px;background:var(--blue);color:#fff;font-family:var(--fh);font-size:13px;font-weight:700;border:none;cursor:pointer;transition:background .18s;-webkit-tap-highlight-color:transparent;margin-bottom:8px}
.cp-add:hover{background:var(--blue-dk)}
.cp-add.added{background:#16a34a}
.cp-view{display:flex;align-items:center;justify-content:center;gap:4px;font-family:var(--fh);font-size:12.5px;font-weight:600;color:var(--g3);padding:4px 0;transition:color .18s}
.cp-view:hover{color:var(--blue)}
.cp-cta-row{text-align:center;margin-top:44px}

.mnav-search{padding:16px 24px 0}
.mnav-search-wrap{display:flex;align-items:center;gap:10px;background:var(--gray-bg);border:1.5px solid var(--g2);border-radius:9px;padding:0 14px;height:42px}
.mnav-search-wrap svg{color:var(--g3);flex-shrink:0}
.mnav-search-input{flex:1;border:none;outline:none;background:transparent;font-family:var(--fh);font-size:13.5px;color:var(--black)}
.mnav-search-input::placeholder{color:var(--g3)}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════ */
@media(max-width:1100px){
  .cap-grid{grid-template-columns:repeat(2,1fr)}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .cat-tile--wide{grid-column:span 2}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
  .ft-top{grid-template-columns:1fr 1fr;gap:36px}
  .cp-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:960px){
  :root{--spy:68px}
  body{padding-top:104px}
  .tb-right{display:none}
  .top-bar-inner{justify-content:center}
  .mobile-nav{top:104px}
  .about-grid,.why-grid{grid-template-columns:1fr;gap:48px}
  .cap-hdr{grid-template-columns:1fr}
  .cat-hdr{flex-direction:column;align-items:flex-start;gap:16px}
  .blog-hdr{flex-direction:column;align-items:flex-start;gap:16px}
  .proc-steps{grid-template-columns:repeat(2,1fr);gap:40px}
  .proc-steps::before{display:none}
  .hero-h1{font-size:38px}
  .hdr-nav{display:none}
  .nav-tog{display:flex}
  .cf-grid{grid-template-columns:1fr;gap:48px}
}
@media(max-width:680px){
  .wrap{padding:0 22px}
  .hero-text-wrap{padding:40px 22px 0}
  .hero-h1{font-size:32px;letter-spacing:-1px}
  .hero-p{font-size:14.5px}
  .hero-stats-inner{padding:0 22px;flex-wrap:wrap}
  .hstat{flex:0 0 50%;border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}
  .hstat:nth-child(odd){border-right:1px solid rgba(255,255,255,.1)}
  .hstat:last-child{flex:0 0 100%;border-bottom:none}
  .hero-ctrl{right:22px;bottom:20px}
  .hero-slide-n{left:22px}
  .cap-grid{grid-template-columns:1fr}
  .cat-grid{grid-template-columns:1fr}
  .cat-tile--wide{grid-column:span 1}
  .blog-grid{grid-template-columns:1fr}
  .about-metrics{grid-template-columns:1fr 1fr}
  .ft-top{grid-template-columns:1fr;gap:32px}
  .ft-bot{flex-direction:column;text-align:center}
  .proc-steps{grid-template-columns:1fr;gap:36px}
  .cf-row{grid-template-columns:1fr}
  .faq-a{padding-right:12px}
  .cp-grid{grid-template-columns:1fr}
  .cp-hdr{flex-direction:column;align-items:flex-start;gap:16px}
}
@media(max-width:480px){
  .cp-grid{grid-template-columns:1fr}
}

/* ═══════════════════════════════════════════════════════
   WOOCOMMERCE OVERRIDES
   ═══════════════════════════════════════════════════════ */
.woocommerce-page .fortis-main,
.woocommerce .fortis-main {
  max-width: var(--mw);
  margin: 0 auto;
  padding: 60px 40px;
}
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .added_to_cart {
  background: var(--blue);
  color: #fff;
  border-radius: 8px;
  font-family: var(--fh);
  font-weight: 700;
  font-size: 13px;
  padding: 11px 14px;
  transition: background .18s;
}
.woocommerce ul.products li.product .button:hover {
  background: var(--blue-dk);
}
.woocommerce .single_add_to_cart_button {
  background: var(--blue) !important;
  border-radius: 8px !important;
  font-family: var(--fh) !important;
  font-weight: 700 !important;
}
.woocommerce .single_add_to_cart_button:hover {
  background: var(--blue-dk) !important;
}
.woocommerce-breadcrumb {
  font-family: var(--fh);
  font-size: 13px;
  color: var(--g3);
}
