/* ============================================================
   SERVEQUE — Inner pages (services, approach, about, contact)
   Builds on main.css tokens/components. Animated, not static.
   ============================================================ */

.breadcrumb{ display:flex; gap:8px; align-items:center; font-family:var(--font-head); font-size:.78rem; color:var(--muted-dim); margin-bottom:22px; }
.breadcrumb a{ color:var(--muted); transition:color .25s; } .breadcrumb a:hover{ color:var(--blue); }
.breadcrumb span{ color:var(--blue); }

/* ---- Page hero ---- */
.phero{ position:relative; padding:clamp(132px,17vh,190px) 0 clamp(48px,7vw,86px); overflow:hidden; }
.phero-grid{ display:grid; grid-template-columns:1.08fr .92fr; gap:clamp(34px,5vw,68px); align-items:center; }
.phero h1{ font-size:clamp(2.5rem,6vw,4.6rem); color:#fff; line-height:1.02; letter-spacing:-.03em; }
.phero h1 em{ color:var(--blue); }
.phero .lead{ font-size:clamp(1.05rem,1.7vw,1.28rem); color:var(--muted); max-width:60ch; margin-top:22px; }
.phero-actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:34px; }
.phero-media{ position:relative; border-radius:var(--r-xl); overflow:hidden; aspect-ratio:4/3.4; border:1px solid var(--line); }
.phero-media img{ width:100%; height:100%; object-fit:cover; transform:scale(1.08); will-change:transform; }
.phero-media::after{ content:''; position:absolute; inset:0; background:radial-gradient(60% 60% at 70% 30%, rgba(90,180,232,.18), transparent 70%); }

/* ---- Alternating feature rows ---- */
.frow{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,5vw,72px); align-items:center; }
.frow + .frow{ margin-top:clamp(50px,8vw,104px); }
.frow.rev .frow-text{ order:2; }
.frow-media{ position:relative; border-radius:var(--r-lg); overflow:hidden; aspect-ratio:4/3; border:1px solid var(--line); }
.frow-media img{ width:100%; height:100%; object-fit:cover; transform:scale(1.1); will-change:transform; }
.frow-text h2{ font-size:clamp(1.7rem,3.6vw,2.6rem); color:#fff; margin-bottom:14px; }
.frow-text p{ color:var(--muted); }

/* ---- Checklist ---- */
.checklist{ list-style:none; display:flex; flex-direction:column; gap:13px; margin-top:22px; }
.checklist li{ display:flex; gap:12px; color:var(--off-white); font-size:.98rem; }
.checklist .ck{ width:22px; height:22px; flex:none; border-radius:50%; background:rgba(90,180,232,.14); border:1px solid rgba(90,180,232,.3); display:flex; align-items:center; justify-content:center; margin-top:1px; }
.checklist .ck svg{ width:12px; height:12px; color:var(--blue); }

/* ---- Linkable service cards (overview) ---- */
.svc-card{ display:flex; flex-direction:column; }
.svc-card .card-arrow{ margin-top:auto; padding-top:22px; display:inline-flex; align-items:center; gap:7px; font-family:var(--font-head); font-size:.84rem; font-weight:600; color:var(--blue); }
.svc-card .card-arrow svg{ transition:transform .3s var(--ease); }
.svc-card:hover .card-arrow svg{ transform:translateX(5px); }

/* ---- FAQ ---- */
.faq{ display:flex; flex-direction:column; gap:12px; max-width:820px; }
.faq-item{ border:1px solid var(--line); border-radius:var(--r-md); background:rgba(255,255,255,.02); overflow:hidden; }
.faq-item summary{ list-style:none; cursor:pointer; padding:20px 24px; display:flex; justify-content:space-between; gap:16px; align-items:center;
  font-family:var(--font-head); font-weight:600; color:#fff; font-size:1.04rem; }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{ content:'+'; color:var(--blue); font-size:1.5rem; line-height:1; transition:transform .3s var(--ease); }
.faq-item[open] summary::after{ transform:rotate(45deg); }
.faq-item p{ padding:0 24px 22px; color:var(--muted); max-width:70ch; }

/* ---- Big stat band (reuses .stats look) ---- */
.statband{ border-block:1px solid var(--line); background:linear-gradient(180deg,rgba(90,180,232,.05),transparent); }

/* ---- Contact ---- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,5vw,64px); align-items:start; }
.contact-methods{ display:flex; flex-direction:column; gap:14px; margin-top:26px; }
.cmethod{ display:flex; gap:16px; align-items:center; padding:18px 20px; border:1px solid var(--line); border-radius:var(--r-md); background:rgba(255,255,255,.02); transition:border-color .3s, transform .4s var(--ease), background .3s; }
.cmethod:hover{ border-color:var(--line-2); transform:translateY(-3px); background:rgba(90,180,232,.05); }
.cmethod-ic{ width:46px; height:46px; flex:none; border-radius:12px; background:rgba(90,180,232,.12); border:1px solid rgba(90,180,232,.22); display:flex; align-items:center; justify-content:center; color:var(--blue); }
.cmethod-ic svg{ width:20px; height:20px; }
.cmethod b{ display:block; font-family:var(--font-head); color:#fff; font-size:1rem; }
.cmethod span{ color:var(--muted); font-size:.9rem; }
.cform{ border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(24px,4vw,38px); background:rgba(255,255,255,.02); }
.cform label{ display:block; font-family:var(--font-head); font-size:.8rem; letter-spacing:.04em; color:var(--muted); margin:0 0 8px; }
.cform .field{ margin-bottom:18px; }
.cform input,.cform textarea,.cform select{ width:100%; padding:13px 16px; border-radius:12px; border:1px solid var(--line-2); background:rgba(8,13,28,.6);
  color:var(--ink); font-family:var(--font-body); font-size:.96rem; transition:border-color .25s, background .25s; }
.cform input:focus,.cform textarea:focus,.cform select:focus{ outline:none; border-color:var(--blue); background:rgba(8,13,28,.85); }
.cform textarea{ min-height:130px; resize:vertical; }
.cform .btn{ width:100%; justify-content:center; }

/* ---- Responsive ---- */
@media (max-width:860px){
  .phero-grid,.frow,.contact-grid{ grid-template-columns:1fr; }
  .phero-media{ order:-1; aspect-ratio:16/10; }
  .frow.rev .frow-text{ order:0; }
  .frow-media{ order:-1; }
}

/* ============================================================
   Global presence (globe) · Recognition · Portfolio · Proof
   ============================================================ */

/* ---- Globe ---- */
.globe-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,64px); align-items:center; }
.globe-wrap{ position:relative; width:100%; max-width:520px; margin:0 auto; aspect-ratio:1/1; }
.globe-canvas{ width:100%; height:100%; display:block; touch-action:none; cursor:grab; }
.globe-canvas:active{ cursor:grabbing; }
.globe-fallback{ position:absolute; inset:0; width:100%; height:100%; object-fit:contain; }
.geo-chips{ display:flex; flex-wrap:wrap; gap:10px; margin-top:26px; }
.geo-chip{ display:inline-flex; align-items:center; gap:8px; padding:8px 15px; border-radius:50px; border:1px solid var(--line-2); background:rgba(255,255,255,.03); font-family:var(--font-head); font-size:.82rem; color:var(--off-white); }
.geo-chip .gd{ width:7px; height:7px; border-radius:50%; background:var(--blue); box-shadow:0 0 8px var(--blue); }
.geo-chip.hq{ border-color:var(--blue); color:#fff; background:rgba(90,180,232,.08); }
@media(max-width:860px){ .globe-grid{ grid-template-columns:1fr; } .globe-wrap{ order:-1; max-width:400px; } }

/* ---- Recognition / ratings ---- */
.rate-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.rate-card{ border:1px solid var(--line); border-radius:var(--r-lg); padding:28px 26px; background:rgba(255,255,255,.02); transition:transform .5s var(--ease), border-color .4s, background .4s; }
.rate-card:hover{ border-color:var(--line-2); transform:translateY(-4px); background:rgba(90,180,232,.05); }
.rate-top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.rate-src{ font-family:var(--font-head); font-weight:600; color:#fff; font-size:1.02rem; }
.rate-stars2{ color:#FFC75A; letter-spacing:2px; font-size:1.02rem; }
.rate-num{ font-family:var(--font-head); font-size:2.4rem; font-weight:700; color:#fff; line-height:1; }
.rate-num small{ font-size:1rem; color:var(--blue); font-weight:600; }
.rate-sub{ color:var(--muted); font-size:.9rem; margin-top:8px; }
@media(max-width:760px){ .rate-grid{ grid-template-columns:1fr; } }

.badges{ display:flex; flex-wrap:wrap; gap:14px; }
.badge2{ display:inline-flex; align-items:center; gap:13px; padding:14px 20px; border:1px solid var(--line); border-radius:var(--r-md); background:rgba(255,255,255,.02); transition:border-color .3s, transform .4s var(--ease), background .3s; }
.badge2:hover{ border-color:var(--line-2); transform:translateY(-3px); background:rgba(90,180,232,.05); }
.badge2 .bi{ width:38px; height:38px; border-radius:10px; flex:none; display:flex; align-items:center; justify-content:center; background:rgba(90,180,232,.1); border:1px solid rgba(90,180,232,.22); color:var(--blue); font-family:var(--font-head); font-weight:700; font-size:.82rem; }
.badge2 b{ font-family:var(--font-head); color:#fff; font-size:.95rem; display:block; line-height:1.2; }
.badge2 span{ color:var(--muted); font-size:.78rem; }

/* ---- Portfolio ---- */
.pf-tabs{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:36px; }
.pf-tab{ padding:10px 20px; border-radius:50px; border:1px solid var(--line-2); background:rgba(255,255,255,.02); font-family:var(--font-head); font-size:.86rem; font-weight:600; color:var(--muted); cursor:pointer; transition:color .25s, background .25s, border-color .25s; }
.pf-tab:hover{ color:#fff; }
.pf-tab.active{ background:var(--blue); color:#06101f; border-color:var(--blue); }
.pf-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.pf-item{ position:relative; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line); aspect-ratio:4/3; cursor:pointer; background:#0c1426; transition:transform .5s var(--ease), border-color .4s; }
.pf-item img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.pf-item:hover{ transform:translateY(-5px); border-color:var(--line-2); }
.pf-item:hover img{ transform:scale(1.06); }
.pf-cap{ position:absolute; left:0; right:0; bottom:0; padding:18px 20px; background:linear-gradient(transparent, rgba(5,8,16,.92)); transform:translateY(10px); opacity:0; transition:transform .4s var(--ease), opacity .4s; }
.pf-item:hover .pf-cap{ transform:none; opacity:1; }
.pf-cap b{ font-family:var(--font-head); color:#fff; display:block; font-size:1rem; }
.pf-cap span{ color:var(--blue); font-size:.74rem; font-family:var(--font-head); text-transform:uppercase; letter-spacing:.1em; }
.pf-item.hide{ display:none; }
.pf-empty{ color:var(--muted); padding:30px 0; }
@media(max-width:860px){ .pf-grid{ grid-template-columns:1fr 1fr; } }
@media(max-width:560px){ .pf-grid{ grid-template-columns:1fr; } }

/* ---- Proof gallery (service pages) ---- */
.proof-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
.proof-card{ border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; background:rgba(255,255,255,.02); cursor:pointer; transition:transform .5s var(--ease), border-color .4s; }
.proof-card:hover{ transform:translateY(-4px); border-color:var(--line-2); }
.proof-card .pimg{ aspect-ratio:16/10; overflow:hidden; background:#0c1426; border-bottom:1px solid var(--line); }
.proof-card .pimg img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.proof-card:hover .pimg img{ transform:scale(1.04); }
.proof-card .pmeta{ padding:16px 20px; }
.proof-card .pmeta b{ font-family:var(--font-head); color:#fff; display:block; }
.proof-card .pmeta span{ color:var(--muted); font-size:.86rem; }
@media(max-width:760px){ .proof-grid{ grid-template-columns:1fr; } }

/* ---- Lightbox ---- */
.lightbox{ position:fixed; inset:0; z-index:9000; background:rgba(4,6,12,.92); backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px); display:none; align-items:center; justify-content:center; padding:30px; opacity:0; transition:opacity .3s; }
.lightbox.open{ display:flex; opacity:1; }
.lightbox img{ max-width:min(1100px,92vw); max-height:88vh; border-radius:14px; border:1px solid var(--line-2); box-shadow:0 30px 90px rgba(0,0,0,.7); }
.lightbox-close{ position:absolute; top:22px; right:26px; width:46px; height:46px; border-radius:50%; border:1px solid var(--line-2); background:rgba(255,255,255,.06); color:#fff; font-size:1.5rem; line-height:1; cursor:pointer; display:flex; align-items:center; justify-content:center; }
.lightbox-close:hover{ background:rgba(90,180,232,.18); border-color:var(--blue); }

/* ---- Interactive world map (global presence) ---- */
.worldmap-wrap{ position:relative; width:100%; }
#world-map{ width:100%; height:clamp(340px,48vw,600px); position:relative; z-index:1; }
#world-map svg{ touch-action:pan-y; }
.jvm-zoom-btn{ display:none !important; }
/* glowing markers */
#world-map .jvm-marker{ filter:drop-shadow(0 0 5px rgba(90,180,232,.95)); animation:mk-pulse 2.6s ease-in-out infinite; }
#world-map .jvm-marker:nth-of-type(2n){ animation-delay:.6s; }
#world-map .jvm-marker:nth-of-type(3n){ animation-delay:1.2s; }
@keyframes mk-pulse{ 0%,100%{ opacity:.65; } 50%{ opacity:1; } }
/* animated connection lines */
#world-map .jvm-line{ stroke-dasharray:5 7; animation:line-flow 1.1s linear infinite; filter:drop-shadow(0 0 3px rgba(90,180,232,.6)); }
@keyframes line-flow{ to{ stroke-dashoffset:-24; } }
/* tooltip */
.jvm-tooltip{ position:absolute; z-index:120 !important; pointer-events:none !important;
  background:rgba(8,13,28,.97) !important; border:1px solid var(--blue) !important; color:#fff !important;
  font-family:var(--font-head) !important; font-weight:600 !important; border-radius:9px !important; padding:7px 13px !important; font-size:.82rem !important;
  box-shadow:0 10px 34px rgba(0,0,0,.6) !important; white-space:nowrap !important; transform:translateY(-6px); }
@media (prefers-reduced-motion:reduce){ #world-map .jvm-marker,#world-map .jvm-line{ animation:none; } }

/* ---- Recognition logo wall ---- */
.lg{ border-radius:11px; background:#fff; padding:7px; object-fit:contain; }
.rate-top .lg{ width:42px; height:42px; flex:none; }
.rate-top .rate-srcwrap{ display:flex; align-items:center; gap:11px; }
.logowall{ display:grid; grid-template-columns:repeat(auto-fill,minmax(190px,1fr)); gap:14px; }
.logo-card{ display:flex; align-items:center; gap:14px; padding:15px 18px; border:1px solid var(--line); border-radius:var(--r-md); background:rgba(255,255,255,.02); transition:border-color .3s, transform .4s var(--ease), background .3s; text-decoration:none; }
.logo-card:hover{ border-color:var(--line-2); transform:translateY(-3px); background:rgba(90,180,232,.05); }
.logo-card .lg{ width:48px; height:48px; flex:none; }
.logo-card b{ font-family:var(--font-head); color:#fff; font-size:.95rem; display:block; line-height:1.25; }
.logo-card span{ color:var(--muted); font-size:.77rem; }

/* ---- Contact (form removed — full-width methods + map) ---- */
.contact-methods-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
.contact-methods-grid .cmethod{ padding:26px 28px; }
.contact-methods-grid .cmethod-ic{ width:54px; height:54px; border-radius:14px; }
.contact-methods-grid .cmethod-ic svg{ width:24px; height:24px; }
.contact-methods-grid .cmethod b{ font-size:1.12rem; }
.contact-methods-grid .cmethod span{ font-size:.92rem; }
.map-embed{ margin-top:22px; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line); position:relative; }
.map-embed iframe{ width:100%; height:clamp(300px,40vw,440px); border:0; display:block; filter:grayscale(.4) contrast(1.05) brightness(.85); }
@media(max-width:680px){ .contact-methods-grid{ grid-template-columns:1fr; } }
