/* ===========================================================
   VirtuLink Travel & Tours — Shared Design System
   Navy + Teal · Plus Jakarta Sans + Inter
   Single source of truth for all pages.
   =========================================================== */

:root{
  --navy-900:#0E2238;--navy:#163A64;--navy-600:#1F4E84;
  --teal:#1796B8;--teal-d:#147F9D;--cyan:#5CC9DE;--cyan-tint:#E4F4F8;
  --ink:#16202E;--slate:#566677;--cloud:#F4F8FB;--line:#E3EAF1;--white:#fff;
  --grad:linear-gradient(120deg,var(--navy) 0%,var(--teal) 100%);
  --ff-head:'Plus Jakarta Sans',sans-serif;--ff-body:'Inter',sans-serif;--ff-mono:'IBM Plex Mono',monospace;
  --shadow-sm:0 1px 3px rgba(14,34,56,.06);--shadow-md:0 10px 34px rgba(14,34,56,.10);
  --shadow-lg:0 24px 60px rgba(14,34,56,.14);--shadow-teal:0 10px 28px rgba(23,150,184,.30);
  --r-md:14px;--r-lg:22px;--maxw:1180px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--ff-body);color:var(--ink);background:var(--white);-webkit-font-smoothing:antialiased;line-height:1.6;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px;}
h1,h2,h3,h4{font-family:var(--ff-head);letter-spacing:-0.025em;line-height:1.08;}
a{color:inherit;}
img{max-width:100%;display:block;}
.eyebrow{font-family:var(--ff-mono);font-size:11px;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;color:var(--teal);}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;height:52px;padding:0 28px;border-radius:var(--r-md);font-family:var(--ff-head);font-size:15px;font-weight:600;border:none;cursor:pointer;text-decoration:none;transition:transform .18s,box-shadow .18s,background .18s;white-space:nowrap;}
.btn-primary{background:var(--teal);color:#fff;box-shadow:var(--shadow-teal);}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(23,150,184,.4);background:var(--teal-d);}
.btn-navy{background:var(--navy);color:#fff;}
.btn-navy:hover{background:var(--navy-600);transform:translateY(-2px);}
.btn-glass{background:rgba(255,255,255,.12);color:#fff;border:1.5px solid rgba(255,255,255,.35);backdrop-filter:blur(6px);}
.btn-glass:hover{background:rgba(255,255,255,.22);}
.btn-outline{background:transparent;border:1.5px solid var(--teal);color:var(--teal);}
.btn-outline:hover{background:var(--cyan-tint);}
.btn-white{background:#fff;color:var(--navy);}
.btn-white:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);}

/* ---------- UTILITY BAR + HEADER ---------- */
.utility{background:var(--navy-900);color:rgba(255,255,255,.72);font-family:var(--ff-mono);font-size:11.5px;letter-spacing:.02em;}
.utility .wrap{display:flex;justify-content:flex-end;gap:22px;height:38px;align-items:center;}
.utility a{color:rgba(255,255,255,.72);text-decoration:none;display:inline-flex;align-items:center;gap:6px;}
.utility a:hover{color:var(--cyan);}
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);transition:box-shadow .2s;}
header.scrolled{box-shadow:var(--shadow-sm);}
.nav{display:flex;align-items:center;height:74px;gap:40px;}
.logo{font-family:var(--ff-head);font-weight:800;font-size:22px;letter-spacing:-0.03em;color:var(--navy);display:flex;align-items:center;gap:8px;text-decoration:none;}
.logo img{height:54px;width:auto;display:block;}
.logo .mark{width:34px;height:34px;border-radius:9px;background:var(--grad);display:flex;align-items:center;justify-content:center;color:#fff;font-size:15px;font-weight:800;box-shadow:var(--shadow-teal);}
.logo .ph{color:var(--teal);}
.nav nav{display:flex;gap:30px;flex:1;}
.nav nav a{font-size:15px;font-weight:500;color:var(--ink);text-decoration:none;transition:color .15s;}
.nav nav a:hover,.nav nav a.active{color:var(--teal);}
.nav .btn{height:44px;padding:0 22px;font-size:14px;}
.hamb{display:none;}

/* Mobile drawer */
.drawer{position:fixed;inset:0;z-index:60;background:rgba(14,34,56,.5);backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:.2s;}
.drawer.open{opacity:1;visibility:visible;}
.drawer-panel{position:absolute;right:0;top:0;height:100%;width:min(78vw,320px);background:#fff;padding:30px 26px;display:flex;flex-direction:column;gap:6px;transform:translateX(100%);transition:transform .25s;}
.drawer.open .drawer-panel{transform:none;}
.drawer-panel a{font-family:var(--ff-head);font-weight:600;font-size:17px;color:var(--ink);text-decoration:none;padding:13px 0;border-bottom:1px solid var(--line);}
.drawer-panel a:hover{color:var(--teal);}
.drawer-close{align-self:flex-end;background:none;border:none;font-size:28px;color:var(--navy);cursor:pointer;margin-bottom:8px;}

/* ---------- HOME BANNER (client masthead) ---------- */
.home-banner{background:var(--navy-900);line-height:0;}
.home-banner img{width:100%;height:auto;display:block;max-width:1942px;margin:0 auto;}
.home-cta-strip{background:var(--cloud);border-bottom:1px solid var(--line);}
.home-cta-strip .wrap{display:flex;align-items:center;justify-content:space-between;gap:20px 28px;padding:22px 32px;flex-wrap:wrap;}
.home-cta-strip p{font-family:var(--ff-head);font-weight:600;font-size:16.5px;color:var(--navy);max-width:560px;}
.home-cta-strip .cta-btns{display:flex;gap:12px;flex-wrap:wrap;}

/* ---------- HERO (home) ---------- */
.hero{position:relative;min-height:640px;display:flex;align-items:center;overflow:hidden;background:var(--navy-900);}
.hero-img{position:absolute;inset:0;background:url("https://images.unsplash.com/photo-1488646953014-85cb44e25828?auto=format&fit=crop&w=1600&q=80") center/cover;}
.hero-ov{position:absolute;inset:0;background:linear-gradient(110deg,rgba(14,34,56,.93) 36%,rgba(14,34,56,.55) 70%,rgba(23,150,184,.35));}
.hero-glow{position:absolute;right:-120px;top:-120px;width:480px;height:480px;border-radius:50%;background:var(--grad);opacity:.22;filter:blur(20px);}
.hero .wrap{position:relative;z-index:2;padding:96px 32px;}
.hero-inner{max-width:660px;color:#fff;}
.hero h1{font-size:clamp(2.6rem,5.4vw,4.1rem);font-weight:800;margin:18px 0 20px;}
.hero h1 .ac{background:linear-gradient(120deg,#fff,var(--cyan));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.hero p{font-size:18px;color:rgba(255,255,255,.78);font-weight:300;max-width:540px;margin-bottom:32px;}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;}
.hero-trust{display:flex;align-items:center;gap:10px;margin-top:34px;font-size:13.5px;color:rgba(255,255,255,.7);}
.hero-trust .dots{display:flex;}
.hero-trust .dots span{width:30px;height:30px;border-radius:50%;border:2px solid var(--navy-900);background:var(--cyan);margin-left:-8px;}
.hero-trust .dots span:first-child{margin-left:0;}

/* ---------- PAGE BANNER (inner pages) ---------- */
.banner{position:relative;background:var(--navy-900);color:#fff;overflow:hidden;}
.banner::before{content:"";position:absolute;right:-140px;top:-140px;width:460px;height:460px;border-radius:50%;background:var(--grad);opacity:.20;filter:blur(20px);}
/* Visa hero: on-brand photo behind the headline. Navy gradient keeps left-side text readable; imagery shows on the right. */
.banner.visa-hero{background-image:linear-gradient(90deg,rgba(11,26,45,.97) 0%,rgba(13,32,54,.90) 32%,rgba(14,34,56,.45) 58%,rgba(14,34,56,0) 82%),url('assets/visa-hero.jpg');background-size:cover;background-position:right center;}
.banner.visa-hero::before{display:none;}
@media(max-width:760px){.banner.visa-hero{background-image:linear-gradient(rgba(12,29,49,.86),rgba(12,29,49,.86)),url('assets/visa-hero.jpg');}}
.banner .wrap{position:relative;z-index:2;padding:84px 32px 76px;max-width:var(--maxw);}
.banner-inner{max-width:680px;}
.banner h1{font-size:clamp(2.2rem,4.4vw,3.3rem);font-weight:800;margin:16px 0 16px;}
.banner h1 .ac{background:linear-gradient(120deg,#fff,var(--cyan));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.banner p{font-size:17.5px;color:rgba(255,255,255,.78);font-weight:300;max-width:560px;}
.crumb{font-family:var(--ff-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--cyan);}
.crumb a{color:rgba(255,255,255,.6);text-decoration:none;}
.crumb a:hover{color:var(--cyan);}

/* ---------- SECTION SHELL ---------- */
.sec{padding:104px 0;}
.sec.cloud{background:var(--cloud);}
.sec.tight{padding:80px 0;}
.sec-head{max-width:620px;margin-bottom:56px;}
.sec-head.center{margin:0 auto 60px;text-align:center;}
.sec-head h2{font-size:clamp(2rem,3.6vw,2.8rem);font-weight:700;margin:14px 0 16px;}
.sec-head p{font-size:17px;color:var(--slate);}

/* ---------- PROBLEM → RELIEF (home) ---------- */
.prob{display:grid;grid-template-columns:1.05fr .95fr;gap:72px;align-items:center;}
.prob-list{margin-top:24px;display:flex;flex-direction:column;gap:16px;}
.prob-item{display:flex;gap:14px;align-items:flex-start;}
.prob-item .x{width:26px;height:26px;border-radius:7px;background:#FBEEEE;color:#C0594F;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;font-weight:700;}
.prob-item p{font-size:15px;color:var(--slate);}
.prob-card{background:var(--grad);border-radius:var(--r-lg);padding:40px;color:#fff;box-shadow:var(--shadow-lg);position:relative;overflow:hidden;}
.prob-card .ico{font-size:34px;margin-bottom:18px;}
.prob-card h3{font-size:24px;font-weight:700;margin-bottom:12px;}
.prob-card p{font-size:15px;color:rgba(255,255,255,.85);}
.prob-card .ring{position:absolute;right:-60px;bottom:-60px;width:200px;height:200px;border-radius:50%;border:30px solid rgba(255,255,255,.10);}

/* ---------- SERVICE CARDS (home) ---------- */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.scard{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px 26px;transition:transform .2s,box-shadow .2s,border-color .2s;position:relative;}
.scard:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent;}
.scard .tile{width:58px;height:58px;border-radius:15px;background:var(--cyan-tint);display:flex;align-items:center;justify-content:center;font-size:26px;margin-bottom:22px;transition:background .2s;}
.scard:hover .tile{background:var(--grad);}
.scard h3{font-size:20px;font-weight:600;margin-bottom:9px;}
.scard p{font-size:14px;color:var(--slate);margin-bottom:18px;}
.scard a{font-family:var(--ff-head);font-size:14px;font-weight:600;color:var(--teal);text-decoration:none;border-bottom:1.5px solid transparent;transition:border-color .15s;}
.scard:hover a{border-color:var(--teal);}

/* ---------- STEPS ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;position:relative;}
.steps::before{content:"";position:absolute;top:34px;left:16%;right:16%;height:2px;background:linear-gradient(90deg,var(--cyan),var(--teal));opacity:.4;}
.step{text-align:center;position:relative;}
.step .num{width:68px;height:68px;border-radius:50%;background:var(--white);border:2px solid var(--teal);color:var(--teal);font-family:var(--ff-head);font-weight:800;font-size:24px;display:flex;align-items:center;justify-content:center;margin:0 auto 22px;box-shadow:var(--shadow-sm);}
.step h3{font-size:19px;font-weight:600;margin-bottom:8px;}
.step p{font-size:14.5px;color:var(--slate);max-width:280px;margin:0 auto;}

/* ---------- TRUST ---------- */
.trust{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.tcard{background:var(--white);border-radius:var(--r-lg);padding:34px 30px;box-shadow:var(--shadow-md);border-top:3px solid var(--teal);}
.tcard .ico{width:52px;height:52px;border-radius:13px;background:var(--cyan-tint);display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:18px;}
.tcard h3{font-size:19px;font-weight:600;margin-bottom:9px;}
.tcard p{font-size:14.5px;color:var(--slate);}
.trust-note{text-align:center;margin-top:34px;font-size:14px;color:var(--slate);}

/* ---------- VISA FEATURE (home) ---------- */
.visa{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;}
.visa-img{height:440px;border-radius:var(--r-lg);background:url("https://images.unsplash.com/photo-1469854523086-cc02fe5d8800?auto=format&fit=crop&w=1100&q=80") center/cover;box-shadow:var(--shadow-lg);position:relative;}
.visa-img .tag{position:absolute;bottom:22px;left:22px;background:rgba(255,255,255,.95);backdrop-filter:blur(6px);padding:14px 18px;border-radius:13px;box-shadow:var(--shadow-md);font-family:var(--ff-head);font-weight:600;font-size:14px;color:var(--navy);display:flex;align-items:center;gap:9px;}
.visa h2{font-size:clamp(1.9rem,3.4vw,2.6rem);font-weight:700;margin:14px 0 18px;}
.visa p{font-size:16.5px;color:var(--slate);margin-bottom:26px;max-width:480px;}
.visa-pts{display:flex;flex-direction:column;gap:14px;margin-bottom:32px;}
.visa-pt{display:flex;gap:12px;align-items:center;font-size:15px;color:var(--ink);font-weight:500;}
.visa-pt .c{width:24px;height:24px;border-radius:50%;background:var(--cyan-tint);color:var(--teal);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;}

/* ---------- MID + FINAL CTA ---------- */
.midcta{background:var(--grad);padding:90px 0;position:relative;overflow:hidden;}
.midcta::before{content:"";position:absolute;right:-80px;top:-80px;width:340px;height:340px;border-radius:50%;border:40px solid rgba(255,255,255,.08);}
.midcta .wrap{position:relative;z-index:2;text-align:center;}
.midcta h2{font-size:clamp(2rem,3.6vw,2.7rem);font-weight:700;color:#fff;margin-bottom:16px;}
.midcta p{font-size:17px;color:rgba(255,255,255,.85);max-width:520px;margin:0 auto 34px;}
.midcta .btn-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.finalcta{text-align:center;}
.finalcta h2{font-size:clamp(2rem,3.6vw,2.7rem);font-weight:700;margin-bottom:14px;}
.finalcta p{font-size:17px;color:var(--slate);max-width:500px;margin:0 auto 30px;}
.social{display:flex;gap:12px;justify-content:center;margin-top:38px;}
.social a{width:46px;height:46px;border-radius:50%;border:1.5px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--navy);font-size:18px;text-decoration:none;transition:.18s;}
.social a:hover{background:var(--teal);color:#fff;border-color:var(--teal);transform:translateY(-3px);}
.social-lbl{font-family:var(--ff-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--slate);margin-top:42px;}

/* ===========================================================
   PAGE-SPECIFIC COMPONENTS
   =========================================================== */

/* ---------- SERVICE DETAIL BLOCKS (services.html) ---------- */
.svc-block{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;padding:64px 0;border-bottom:1px solid var(--line);}
.svc-block:last-child{border-bottom:none;}
.svc-block.flip .svc-visual{order:2;}
.svc-visual{background:var(--cloud);border:1px solid var(--line);border-radius:var(--r-lg);min-height:320px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.svc-visual .glyph{font-size:88px;filter:saturate(.9);}
.svc-visual .corner{position:absolute;right:-50px;bottom:-50px;width:180px;height:180px;border-radius:50%;background:var(--grad);opacity:.10;}
.svc-tag{display:inline-flex;align-items:center;gap:7px;height:30px;padding:0 14px;background:var(--cyan-tint);border-radius:100px;font-family:var(--ff-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);font-weight:500;margin-bottom:14px;}
.svc-block h2{font-size:clamp(1.7rem,3vw,2.3rem);font-weight:700;margin-bottom:14px;}
.svc-block .lead{font-size:16.5px;color:var(--slate);margin-bottom:24px;}
.svc-cols{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:28px;}
.svc-col h4{font-family:var(--ff-head);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--navy);margin-bottom:12px;}
.svc-col ul{list-style:none;display:flex;flex-direction:column;gap:9px;}
.svc-col li{position:relative;padding-left:24px;font-size:14.5px;color:var(--slate);line-height:1.5;}
.svc-col li::before{content:"✓";position:absolute;left:0;top:0;color:var(--teal);font-weight:700;}
.svc-col.req li::before{content:"•";color:var(--navy-600);font-size:18px;line-height:1.2;}
.price-pill{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:100px;background:var(--cloud);border:1px solid var(--line);font-family:var(--ff-head);font-weight:600;font-size:14px;color:var(--navy);margin-bottom:24px;}
.price-pill .dot{width:8px;height:8px;border-radius:50%;background:var(--teal);}

/* ---------- PROCESS TIMELINE (visa.html) ---------- */
.timeline{max-width:760px;margin:0 auto;position:relative;}
.timeline::before{content:"";position:absolute;left:27px;top:10px;bottom:10px;width:2px;background:linear-gradient(180deg,var(--cyan),var(--teal));opacity:.5;}
.tl-item{display:flex;gap:26px;padding:18px 0;position:relative;}
.tl-num{width:56px;height:56px;flex-shrink:0;border-radius:50%;background:#fff;border:2px solid var(--teal);color:var(--teal);font-family:var(--ff-head);font-weight:800;font-size:20px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);z-index:1;}
.tl-body h3{font-size:19px;font-weight:600;margin-bottom:6px;margin-top:6px;}
.tl-body p{font-size:15px;color:var(--slate);}

/* ---------- CHECKLIST GRID (visa.html) ---------- */
.check-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px 32px;}
.check-grid li{list-style:none;position:relative;padding-left:30px;font-size:15px;color:var(--ink);}
.check-grid li::before{content:"✓";position:absolute;left:0;top:-1px;width:20px;height:20px;border-radius:50%;background:var(--cyan-tint);color:var(--teal);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;}
.note-card{background:var(--cyan-tint);border-left:3px solid var(--teal);border-radius:var(--r-md);padding:22px 26px;margin-top:32px;font-size:14.5px;color:var(--slate);line-height:1.6;}
.note-card strong{color:var(--navy);}

/* ---------- ABOUT ---------- */
.about-lead{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:center;}
.about-lead p{font-size:17px;color:var(--slate);margin-bottom:18px;}
.about-lead p:first-of-type{font-size:19px;color:var(--ink);font-weight:500;}
.about-visual{height:420px;border-radius:var(--r-lg);background:var(--grad);position:relative;overflow:hidden;box-shadow:var(--shadow-lg);display:flex;align-items:flex-end;padding:34px;}
.about-visual img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0;}
.about-visual::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(9,22,38,.28) 0%,rgba(14,34,56,0) 32%);z-index:1;}
.about-visual .quote{color:#fff;font-family:var(--ff-head);font-weight:600;font-size:17px;line-height:1.35;position:relative;z-index:2;background:rgba(11,26,45,.62);backdrop-filter:blur(9px);-webkit-backdrop-filter:blur(9px);padding:12px 18px;border-radius:14px;border:1px solid rgba(255,255,255,.14);box-shadow:0 6px 20px rgba(0,0,0,.22);}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.vcard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:34px 30px;transition:transform .2s,box-shadow .2s;}
.vcard:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);}
.vcard .ico{width:54px;height:54px;border-radius:14px;background:var(--cyan-tint);display:flex;align-items:center;justify-content:center;font-size:25px;margin-bottom:18px;}
.vcard h3{font-size:20px;font-weight:600;margin-bottom:10px;}
.vcard p{font-size:14.5px;color:var(--slate);}

/* ---------- TEAM ---------- */
.team{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;max-width:920px;margin:0 auto;}
.tcard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:transform .2s,box-shadow .2s;}
.tcard:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);}
.tphoto{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:center;display:block;}
.tbody{padding:28px 30px 34px;}
.tcard h3{font-size:22px;font-weight:700;margin-bottom:2px;}
.tcard .role{font-family:var(--ff-head);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--teal);margin-bottom:16px;}
.tcard p{font-size:15px;color:var(--slate);margin-bottom:14px;}
.tcard p:last-child{margin-bottom:0;}

/* ---------- FAQ ACCORDION ---------- */
.faq{max-width:820px;margin:0 auto;}
.faq-group-title{font-family:var(--ff-head);font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--teal);margin:38px 0 14px;}
.faq-group-title:first-child{margin-top:0;}
.qa{border:1px solid var(--line);border-radius:var(--r-md);margin-bottom:12px;background:#fff;overflow:hidden;transition:box-shadow .18s,border-color .18s;}
.qa.open{box-shadow:var(--shadow-md);border-color:transparent;}
.qa-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:22px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;font-family:var(--ff-head);font-weight:600;font-size:16.5px;color:var(--ink);}
.qa-q .sign{width:26px;height:26px;flex-shrink:0;border-radius:50%;background:var(--cyan-tint);color:var(--teal);display:flex;align-items:center;justify-content:center;font-size:18px;transition:transform .2s,background .2s;}
.qa.open .qa-q .sign{transform:rotate(45deg);background:var(--teal);color:#fff;}
.qa-a{max-height:0;overflow:hidden;transition:max-height .28s ease;}
.qa-a p{padding:0 24px 22px;font-size:15px;color:var(--slate);line-height:1.65;}

/* ---------- CONTACT ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:start;}
.map-embed{max-width:940px;margin:0 auto;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-md);}
.map-embed iframe{width:100%;height:420px;border:0;display:block;}
.channel{display:flex;gap:16px;align-items:flex-start;padding:20px;border:1px solid var(--line);border-radius:var(--r-md);margin-bottom:14px;transition:border-color .18s,box-shadow .18s;text-decoration:none;color:inherit;}
.channel:hover{border-color:var(--teal);box-shadow:var(--shadow-sm);}
.channel .ico{width:48px;height:48px;flex-shrink:0;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;}
.channel.msg .ico{background:#E7F1FF;}
.channel.wa .ico{background:#E6F9EE;}
.channel.mail .ico{background:var(--cyan-tint);}
.channel.phone .ico{background:#FFF3E0;}
.channel h3{font-family:var(--ff-head);font-size:16px;font-weight:600;margin-bottom:3px;}
.channel p{font-size:13.5px;color:var(--slate);}
.channel .val{font-family:var(--ff-mono);font-size:12.5px;color:var(--teal);margin-top:4px;}
.priority{display:inline-flex;align-items:center;gap:6px;font-family:var(--ff-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);background:var(--cyan-tint);padding:3px 10px;border-radius:100px;margin-left:8px;}
.meta-row{display:flex;flex-wrap:wrap;gap:28px;margin-top:30px;padding-top:26px;border-top:1px solid var(--line);}
.meta{font-size:14px;color:var(--slate);}
.meta h4{font-family:var(--ff-head);font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--navy);margin-bottom:6px;}

/* ---------- FORM ---------- */
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:38px;box-shadow:var(--shadow-md);}
.form-card h3{font-size:22px;font-weight:700;margin-bottom:6px;}
.form-card .sub{font-size:14.5px;color:var(--slate);margin-bottom:26px;}
.field{margin-bottom:18px;}
.field label{display:block;font-family:var(--ff-head);font-size:13px;font-weight:600;color:var(--navy);margin-bottom:8px;}
.field input,.field select,.field textarea{width:100%;border:1.5px solid var(--line);border-radius:var(--r-md);background:#fff;padding:14px 16px;font-family:var(--ff-body);font-size:15px;color:var(--ink);transition:border-color .15s,box-shadow .15s;}
.field textarea{resize:vertical;min-height:120px;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(23,150,184,.12);}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.form-note{font-size:12.5px;color:var(--slate);margin-top:6px;display:flex;align-items:center;gap:7px;}
.form-note .lock{color:var(--teal);}

/* ---------- LEGAL / PRIVACY ---------- */
.legal{max-width:760px;margin:0 auto;}
.legal h2{font-size:23px;font-weight:700;margin:42px 0 14px;color:var(--navy);}
.legal h2:first-child{margin-top:0;}
.legal p,.legal li{font-size:15.5px;color:var(--slate);line-height:1.7;margin-bottom:14px;}
.legal ul{padding-left:22px;margin-bottom:14px;}
.legal li{margin-bottom:8px;}
.legal .updated{font-family:var(--ff-mono);font-size:12px;letter-spacing:.04em;color:var(--slate);margin-bottom:30px;}
.legal a{color:var(--teal);}

/* ---------- FOOTER ---------- */
footer{background:var(--navy-900);color:rgba(255,255,255,.6);padding:72px 0 32px;}
.fgrid{display:grid;grid-template-columns:2fr 1fr 1fr 1.3fr;gap:48px;margin-bottom:48px;}
footer .logo{color:#fff;margin-bottom:18px;}
footer .logo img{height:64px;}
footer .ftag{font-size:14px;color:rgba(255,255,255,.5);max-width:250px;margin-bottom:22px;}
footer h4{font-family:var(--ff-head);color:#fff;font-size:15px;font-weight:600;margin-bottom:18px;}
footer ul{list-style:none;display:flex;flex-direction:column;gap:12px;}
footer ul a{color:rgba(255,255,255,.55);text-decoration:none;font-size:14px;transition:color .15s;}
footer ul a:hover{color:var(--cyan);}
.fbar{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;align-items:center;font-family:var(--ff-mono);font-size:11px;letter-spacing:.04em;color:rgba(255,255,255,.4);gap:12px;}
.fbar a{color:rgba(255,255,255,.4);text-decoration:none;}
.fbar a:hover{color:var(--cyan);}

/* ---------- FLOATING CHAT ---------- */
.chat-fab{position:fixed;right:26px;bottom:26px;z-index:80;display:flex;flex-direction:column;gap:12px;}
.fab{width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:26px;box-shadow:var(--shadow-lg);cursor:pointer;text-decoration:none;transition:transform .18s;border:none;}
.fab:hover{transform:scale(1.08);}
.fab.msg{background:#0A7CFF;color:#fff;}
.fab.wa{background:#25D366;color:#fff;}

/* ---------- REVEAL ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease;}
.reveal.in{opacity:1;transform:none;}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media(max-width:900px){
  .prob,.visa,.svc-block,.about-lead,.contact-grid{grid-template-columns:1fr;gap:40px;}
  .svc-block.flip .svc-visual{order:0;}
  .cards{grid-template-columns:repeat(2,1fr);}
  .trust,.values,.team{grid-template-columns:1fr;}
  .map-embed iframe{height:320px;}
  .steps{grid-template-columns:1fr;gap:40px;}
  .steps::before{display:none;}
  .fgrid{grid-template-columns:1fr 1fr;gap:32px;}
  .check-grid,.svc-cols{grid-template-columns:1fr;}
}
@media(max-width:640px){
  .nav nav,.utility{display:none;}
  .hamb{display:flex;margin-left:auto;font-size:26px;color:var(--navy);background:none;border:none;cursor:pointer;}
  .cards{grid-template-columns:1fr;}
  .sec{padding:72px 0;}
  .sec.tight{padding:56px 0;}
  .hero .wrap{padding:72px 32px;}
  .banner .wrap{padding:60px 32px 56px;}
  .fgrid{grid-template-columns:1fr;}
  .fbar{flex-direction:column;gap:10px;}
  .field-row{grid-template-columns:1fr;}
}
