/* ============================================================
   IBC Trading Corporation (HK) Co., Limited — ibcexpo.com
   Shared stylesheet for all pages
   ============================================================ */

:root{
  /* brand */
  --ink:    #0C2D7A;   /* deep brand blue — headings */
  --blue:   #1B6FE8;   /* logo blue — primary actions */
  --blue-d: #1257C2;
  --cyan:   #00A6D6;   /* accent — kickers, hovers */
  --red:    #EF3340;   /* signature accent — highlights, underlines */
  /* surfaces */
  --bg:     #FFFFFF;
  --bg-soft:#F5F8FC;
  --card:   #FBFCFE;
  --line:   #E3EAF4;
  /* text */
  --text:   #3A4250;
  --muted:  #6A7280;
  /* type */
  --f-disp: 'Bebas Neue', 'Oswald', 'Arial Narrow', sans-serif;
  --f-body: 'Inter', 'Helvetica Neue', Arial, sans-serif;
  /* misc */
  --shadow:   0 4px 14px rgba(12, 45, 122, .08);
  --shadow-h: 0 12px 28px rgba(12, 45, 122, .14);
  --radius: 12px;
  --container: 1180px;
  --topbar-h: 38px;
  --nav-h: 74px;
}

/* ---------- reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; }            /* no scroll-behavior:smooth — Lenis owns scrolling */
body{
  font-family:var(--f-body);
  font-size:16px; line-height:1.6; color:var(--text);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; height:auto; }   /* height:auto keeps aspect ratio despite width/height attrs */
svg{ display:block; max-width:100%; }
a{ color:var(--blue); text-decoration:none; }
ul{ list-style:none; }
button{ font:inherit; border:0; background:none; cursor:pointer; }
input,select,textarea{ font:inherit; color:inherit; }
body.no-scroll{ overflow:hidden; }

::selection{ background:var(--blue); color:#fff; }

/* ---------- layout helpers ---------- */
.container{ width:min(var(--container), 92%); margin-inline:auto; }
.section{ padding-block:clamp(44px, 7.5vh, 78px); }
.section--soft{ background:var(--bg-soft); }
.grid{ display:grid; gap:clamp(14px, 1.8vw, 24px); }
.grid-2{ grid-template-columns:repeat(2, 1fr); }
.grid-3{ grid-template-columns:repeat(3, 1fr); }
.grid-4{ grid-template-columns:repeat(4, 1fr); }
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(24px, 4vw, 56px); align-items:center; }

/* ---------- type ---------- */
h1,h2,h3,h4{ color:var(--ink); line-height:1.12; }
.disp{ font-family:var(--f-disp); font-weight:400; letter-spacing:.02em; text-transform:uppercase; }

.kicker{
  display:inline-block;
  font-size:13px; font-weight:700; letter-spacing:.18em; text-transform:uppercase;
  color:var(--cyan); margin-bottom:10px;
}
.sec-head{ max-width:680px; margin-bottom:clamp(22px, 3.5vh, 36px); }
.sec-head--center{ margin-inline:auto; text-align:center; }
.sec-head h2{
  font-family:var(--f-disp); font-weight:400; text-transform:uppercase;
  font-size:clamp(30px, 4vw, 44px); letter-spacing:.02em;
}
.sec-head .bar{
  display:block; width:56px; height:3px; background:var(--red);
  border-radius:2px; margin-top:12px;
}
.sec-head--center .bar{ margin-inline:auto; }
.sec-head p{ margin-top:12px; color:var(--muted); font-size:15.5px; }

.hl{ /* signature red highlight box around a word */
  display:inline-block; background:var(--red); color:#fff;
  padding:.04em .18em .0em; border-radius:6px; line-height:1.05;
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  padding:13px 28px; border-radius:50px;
  font-size:13.5px; font-weight:700; letter-spacing:.09em; text-transform:uppercase;
  transition:background-color .2s ease, color .2s ease, border-color .2s ease,
             box-shadow .25s ease, transform .25s ease;
  border:1.5px solid transparent; white-space:nowrap;
}
.btn svg{ width:16px; height:16px; flex:none; }
.btn-primary{ background:var(--blue); color:#fff; border-color:var(--blue); box-shadow:0 6px 16px rgba(27,111,232,.28); }
.btn-primary:hover{ background:var(--blue-d); border-color:var(--blue-d); transform:translateY(-2px); box-shadow:0 10px 22px rgba(27,111,232,.34); }
.btn-outline{ background:transparent; color:var(--blue); border-color:var(--blue); }
.btn-outline:hover{ background:var(--blue); color:#fff; transform:translateY(-2px); }
.btn-light{ background:#fff; color:var(--ink); border-color:#fff; }
.btn-light:hover{ background:transparent; color:#fff; border-color:#fff; transform:translateY(-2px); }
.btn-ghost-light{ background:transparent; color:#fff; border-color:rgba(255,255,255,.7); }
.btn-ghost-light:hover{ background:#fff; color:var(--ink); border-color:#fff; }

/* ---------- top bar ---------- */
.topbar{
  background:var(--ink); color:#fff;
  font-size:12.5px; height:var(--topbar-h);
  position:relative; z-index:60;
}
.topbar .container{ height:100%; display:flex; align-items:center; justify-content:space-between; gap:16px; }
.topbar a{ color:rgba(255,255,255,.88); display:inline-flex; align-items:center; gap:6px; transition:color .2s; }
.topbar a:hover{ color:var(--cyan); }
.topbar svg{ width:13px; height:13px; }
.topbar-group{ display:flex; align-items:center; gap:18px; min-width:0; }
.topbar .tagline{ color:rgba(255,255,255,.55); letter-spacing:.08em; text-transform:uppercase; font-size:11px; }

/* ---------- header / nav ---------- */
.header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.92);
  -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;
  transition:box-shadow .3s ease, border-color .3s ease;
}
.header.is-scrolled{ box-shadow:0 6px 22px rgba(12,45,122,.10); border-color:var(--line); }
.nav{
  height:var(--nav-h); display:flex; align-items:center; justify-content:space-between; gap:20px;
  transition:height .3s ease;
}
.header.is-scrolled .nav{ height:62px; }

.brand{ display:flex; align-items:center; gap:11px; min-width:0; }
.brand img{ width:46px; height:46px; border-radius:50%; object-fit:cover; flex:none; transition:width .3s ease, height .3s ease; }
.header.is-scrolled .brand img{ width:40px; height:40px; }
.brand-name{ display:flex; flex-direction:column; line-height:1.05; }
.brand-name b{
  font-family:var(--f-disp); font-weight:400; font-size:25px; letter-spacing:.04em;
  color:var(--ink); text-transform:uppercase;
}
.brand-name span{ font-size:9.5px; font-weight:600; letter-spacing:.13em; text-transform:uppercase; color:var(--muted); }

.nav-menu{ display:flex; align-items:center; gap:4px; }
.nav-menu > li{ position:relative; }
.nav-link{
  display:inline-flex; align-items:center; gap:5px;
  font-family:var(--f-disp); font-size:18px; letter-spacing:.05em; text-transform:uppercase;
  color:var(--ink); padding:10px 13px; border-radius:8px;
  transition:color .2s, background-color .2s;
}
.nav-link:hover{ color:var(--blue); background:var(--bg-soft); }
.nav-link.active{ color:var(--blue); }
.nav-link.active::after{
  content:""; position:absolute; left:13px; right:13px; bottom:2px; height:2px;
  background:var(--red); border-radius:2px;
}
.nav-link .chev{ width:13px; height:13px; transition:transform .25s; }

/* dropdown */
.has-drop:hover .nav-link .chev,
.has-drop.open .nav-link .chev{ transform:rotate(180deg); }
.dropdown{
  position:absolute; top:calc(100% + 8px); left:0; min-width:228px;
  background:#fff; border:1px solid var(--line); border-radius:12px;
  box-shadow:var(--shadow-h); padding:8px;
  opacity:0; visibility:hidden; transform:translateY(8px);
  transition:opacity .22s ease, transform .22s ease, visibility .22s;
}
.has-drop:hover .dropdown,
.has-drop.open .dropdown{ opacity:1; visibility:visible; transform:translateY(0); }
.dropdown a{
  display:flex; align-items:center; gap:10px;
  padding:10px 12px; border-radius:8px;
  font-size:14px; font-weight:600; color:var(--text);
  transition:background-color .18s, color .18s;
}
.dropdown a:hover{ background:var(--bg-soft); color:var(--blue); }
.dropdown a.active{ color:var(--blue); background:var(--bg-soft); }
.dropdown svg{ width:16px; height:16px; color:var(--cyan); flex:none; }

.nav-cta{ display:flex; align-items:center; gap:12px; }
.nav-cta .btn{ padding:11px 22px; font-size:12.5px; }

/* hamburger */
.burger{
  display:none; width:44px; height:44px; border-radius:10px;
  align-items:center; justify-content:center; flex-direction:column; gap:5px;
  background:var(--bg-soft);
}
.burger span{
  width:20px; height:2px; background:var(--ink); border-radius:2px;
  transition:transform .3s ease, opacity .3s ease;
}
.burger.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.burger.open span:nth-child(2){ opacity:0; }
.burger.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* mobile panel */
.mobile-panel{
  position:fixed; inset:0; top:0; z-index:49;
  background:rgba(10,22,52,.45);
  opacity:0; visibility:hidden; transition:opacity .3s ease, visibility .3s;
}
.mobile-panel.open{ opacity:1; visibility:visible; }
.mobile-panel-inner{
  position:absolute; top:0; right:0; height:100%; width:min(340px, 86%);
  background:#fff; padding:86px 22px 28px;
  overflow-y:auto; overscroll-behavior:contain; -webkit-overflow-scrolling:touch;
  transform:translateX(100%); transition:transform .38s cubic-bezier(.22,.8,.26,1);
  display:flex; flex-direction:column; gap:2px;
}
.mobile-panel.open .mobile-panel-inner{ transform:translateX(0); }
.mobile-panel a.m-link{
  display:flex; align-items:center; justify-content:space-between;
  padding:13px 12px; border-radius:10px;
  font-family:var(--f-disp); font-size:20px; letter-spacing:.05em; text-transform:uppercase;
  color:var(--ink); transition:background-color .2s, color .2s;
}
.mobile-panel a.m-link:hover, .mobile-panel a.m-link.active{ background:var(--bg-soft); color:var(--blue); }
.m-group{ margin:4px 0 2px; padding:10px 12px 4px; font-size:11px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); border-top:1px solid var(--line); }
.mobile-panel a.m-sub{
  display:flex; align-items:center; gap:10px;
  padding:10px 12px; border-radius:10px; font-size:14.5px; font-weight:600; color:var(--text);
}
.mobile-panel a.m-sub:hover, .mobile-panel a.m-sub.active{ background:var(--bg-soft); color:var(--blue); }
.mobile-panel a.m-sub svg{ width:16px; height:16px; color:var(--cyan); }
.mobile-panel .btn{ margin-top:14px; }

/* ---------- hero (home) ---------- */
.hero{
  position:relative; min-height:calc(100svh - var(--topbar-h) - var(--nav-h));
  display:flex; flex-direction:column; justify-content:center;
  background:url("../assets/img/hero-home.webp") center/cover no-repeat;
  overflow:hidden;
}
.hero::before{
  content:""; position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(255,255,255,.96) 0%, rgba(255,255,255,.86) 38%, rgba(255,255,255,.25) 75%, rgba(255,255,255,.05) 100%);
}
.hero .container{
  position:relative; z-index:1; padding-block:clamp(28px, 5vh, 56px);
  flex:1; display:flex; align-items:center;
}
.hero-content{ max-width:640px; }
.hero h1{
  font-family:var(--f-disp); font-weight:400; text-transform:uppercase;
  font-size:clamp(44px, 6.2vw, 78px); line-height:1.02; letter-spacing:.015em;
}
.hero .sub{
  margin-top:14px; color:var(--cyan);
  font-size:clamp(15px, 1.6vw, 19px); font-weight:700;
  letter-spacing:.12em; text-transform:uppercase;
}
.hero .lead{ margin-top:14px; max-width:520px; color:var(--text); font-size:clamp(14.5px, 1.4vw, 16.5px); }
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:clamp(20px, 3vh, 30px); }

.hero-points{
  position:relative; z-index:1;
  background:rgba(255,255,255,.86);
  -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
  border-top:1px solid var(--line);
}
.hero-points .container{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:14px;
  padding-block:clamp(14px, 2.2vh, 20px);
}
.hero-point{ display:flex; align-items:center; gap:11px; min-width:0; }
.hero-point svg{ width:22px; height:22px; color:var(--blue); flex:none; }
.hero-point b{ display:block; font-size:13.5px; color:var(--ink); letter-spacing:.02em; }
.hero-point span{ display:block; font-size:12px; color:var(--muted); line-height:1.35; }

/* ---------- page hero (inner pages) ---------- */
.page-hero{
  position:relative; min-height:clamp(240px, 36svh, 340px);
  display:flex; align-items:flex-end;
  background-position:center; background-size:cover;
}
.page-hero::before{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(8,22,58,.30) 0%, rgba(8,22,58,.66) 100%);
}
.page-hero .container{ position:relative; z-index:1; padding-block:clamp(26px, 4.5vh, 44px); }
.page-hero h1{
  color:#fff; font-family:var(--f-disp); font-weight:400; text-transform:uppercase;
  font-size:clamp(38px, 5vw, 60px); letter-spacing:.02em;
}
.crumbs{ display:flex; align-items:center; gap:8px; font-size:13px; color:rgba(255,255,255,.78); margin-bottom:6px; }
.crumbs a{ color:rgba(255,255,255,.78); transition:color .2s; }
.crumbs a:hover{ color:#fff; }
.crumbs svg{ width:12px; height:12px; opacity:.7; }

/* ---------- cards ---------- */
.card{
  background:var(--card); border:1px solid var(--line); border-radius:var(--radius);
  padding:clamp(18px, 2.2vw, 26px);
  box-shadow:var(--shadow);
  transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;
  display:flex; flex-direction:column; min-width:0;
}
.card:hover{ transform:translateY(-5px); box-shadow:var(--shadow-h); border-color:#D4E2F6; }
.card .icon{
  width:48px; height:48px; border-radius:12px; flex:none;
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg, #E8F1FE, #DCF4FB);
  margin-bottom:14px;
}
.card .icon svg{ width:23px; height:23px; color:var(--blue); }
.card h3{
  font-size:16px; font-weight:700; letter-spacing:.04em; text-transform:uppercase;
}
.card h3::after{
  content:""; display:block; width:34px; height:2px; background:var(--red);
  border-radius:2px; margin-top:8px;
}
.card p{ margin-top:10px; font-size:14px; color:var(--muted); flex:1; }
.card .more{
  margin-top:12px; display:inline-flex; align-items:center; gap:6px;
  font-size:12.5px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--blue);
}
.card .more svg{ width:14px; height:14px; transition:transform .25s; }
.card:hover .more svg{ transform:translateX(4px); }
a.card{ color:inherit; }

/* check list */
.checks{ display:grid; gap:9px; margin-top:14px; }
.checks li{ display:flex; gap:10px; align-items:flex-start; font-size:14.5px; }
.checks svg{ width:17px; height:17px; color:var(--cyan); flex:none; margin-top:3px; }
.checks b{ color:var(--ink); }

/* stats */
.stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.stat{
  text-align:center; padding:clamp(16px,2vw,24px) 10px;
  background:var(--card); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow);
}
.stat b{
  display:block; font-family:var(--f-disp); font-weight:400;
  font-size:clamp(30px, 3.4vw, 42px); color:var(--ink); line-height:1;
}
.stat b em{ font-style:normal; color:var(--red); }
.stat span{ display:block; margin-top:6px; font-size:12px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }

/* media block */
.media{ position:relative; }
.media img{ width:100%; border-radius:16px; box-shadow:var(--shadow-h); }
.media .tag{
  position:absolute; left:18px; bottom:18px;
  background:rgba(255,255,255,.94); border-radius:10px; padding:10px 16px;
  box-shadow:var(--shadow); display:flex; align-items:center; gap:10px;
}
.media .tag svg{ width:18px; height:18px; color:var(--blue); }
.media .tag b{ font-size:13px; color:var(--ink); letter-spacing:.03em; }

/* steps (process) */
.steps{ counter-reset:step; }
.step{ position:relative; }
.step .num{
  font-family:var(--f-disp); font-size:40px; color:transparent;
  -webkit-text-stroke:1.5px var(--cyan); line-height:1; margin-bottom:10px;
}
.step h3{ font-size:15.5px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; }
.step p{ margin-top:8px; font-size:13.8px; color:var(--muted); }

/* office / location cards */
.office{ display:flex; flex-direction:column; gap:6px; }
.office .flagline{ display:flex; align-items:center; gap:10px; margin-bottom:6px; }
.office .flagline svg{ width:20px; height:20px; color:var(--blue); }
.office h3{ font-size:16px; font-weight:700; text-transform:uppercase; letter-spacing:.04em; }
.office .role{ font-size:11.5px; font-weight:700; letter-spacing:.14em; color:var(--red); text-transform:uppercase; }
.office p{ font-size:14px; color:var(--muted); }
.office a{ font-size:14px; font-weight:600; display:inline-flex; align-items:center; gap:8px; }
.office a svg{ width:14px; height:14px; }

/* ---------- CTA strip ---------- */
.cta-strip{
  background:linear-gradient(110deg, var(--ink) 0%, var(--blue) 60%, var(--cyan) 130%);
  color:#fff; position:relative; overflow:hidden;
}
.cta-strip::after{
  content:""; position:absolute; right:-80px; top:-90px; width:340px; height:340px;
  border-radius:50%; background:rgba(255,255,255,.07);
}
.cta-strip .container{
  position:relative; z-index:1;
  display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap;
  padding-block:clamp(30px, 5vh, 48px);
}
.cta-strip h2{
  color:#fff; font-family:var(--f-disp); font-weight:400; text-transform:uppercase;
  font-size:clamp(26px, 3.4vw, 38px); letter-spacing:.03em;
}
.cta-strip p{ margin-top:6px; color:rgba(255,255,255,.82); font-size:14.5px; max-width:520px; }
.cta-strip .actions{ display:flex; gap:12px; flex-wrap:wrap; }

/* ---------- gallery ---------- */
.gallery-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(12px,1.6vw,20px); }
.g-item{
  position:relative; border-radius:14px; overflow:hidden; cursor:pointer;
  box-shadow:var(--shadow); border:1px solid var(--line);
  aspect-ratio:4/3; background:var(--bg-soft);
}
.g-item img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.g-item:hover img{ transform:scale(1.05); }
.g-item .cap{
  position:absolute; inset-inline:0; bottom:0; padding:26px 14px 12px;
  background:linear-gradient(180deg, transparent, rgba(8,22,58,.78));
  color:#fff; font-size:13px; font-weight:600; letter-spacing:.04em;
  display:flex; align-items:flex-end; justify-content:space-between; gap:10px;
}
.g-item .cap svg{ width:16px; height:16px; opacity:.85; flex:none; }

/* lightbox modal */
.lightbox{
  position:fixed; inset:0; z-index:100;
  background:rgba(8,16,40,.82);
  -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
  display:flex; align-items:center; justify-content:center; padding:4vh 4vw;
  opacity:0; visibility:hidden; transition:opacity .28s ease, visibility .28s;
}
.lightbox.open{ opacity:1; visibility:visible; }
.lightbox-panel{
  position:relative; max-width:min(960px, 100%); max-height:100%; width:100%;
  background:#fff; border-radius:16px; overflow-y:auto;
  overscroll-behavior:contain; -webkit-overflow-scrolling:touch;
  box-shadow:0 24px 60px rgba(0,0,0,.35);
  transform:scale(.96); transition:transform .28s ease;
}
.lightbox.open .lightbox-panel{ transform:scale(1); }
.lightbox-panel img{ width:100%; }
.lightbox-meta{ padding:16px 20px 18px; display:flex; align-items:center; justify-content:space-between; gap:14px; }
.lightbox-meta h3{ font-size:15.5px; letter-spacing:.03em; text-transform:uppercase; }
.lightbox-meta p{ font-size:13px; color:var(--muted); margin-top:3px; }
.lightbox-close{
  position:absolute; top:12px; right:12px; z-index:2;
  width:38px; height:38px; border-radius:50%;
  background:rgba(8,22,58,.55); color:#fff;
  display:flex; align-items:center; justify-content:center;
  transition:background-color .2s;
}
.lightbox-close:hover{ background:var(--red); }
.lightbox-close svg{ width:18px; height:18px; }
.lightbox-nav{
  position:absolute; top:50%; transform:translateY(-50%); z-index:2;
  width:40px; height:40px; border-radius:50%;
  background:rgba(8,22,58,.5); color:#fff;
  display:flex; align-items:center; justify-content:center; transition:background-color .2s;
}
.lightbox-nav:hover{ background:var(--blue); }
.lightbox-nav svg{ width:18px; height:18px; }
.lightbox-prev{ left:12px; } .lightbox-next{ right:12px; }

/* ---------- forms ---------- */
.form{ display:grid; gap:14px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.field label{
  display:block; font-size:12px; font-weight:700; letter-spacing:.08em;
  text-transform:uppercase; color:var(--ink); margin-bottom:6px;
}
.field input, .field select, .field textarea{
  width:100%; border:1.5px solid var(--line); border-radius:10px;
  padding:12px 14px; background:#fff; font-size:14.5px;
  transition:border-color .2s, box-shadow .2s; outline:none;
}
.field textarea{ min-height:120px; resize:vertical; }
.field input:focus, .field select:focus, .field textarea:focus{
  border-color:var(--blue); box-shadow:0 0 0 3px rgba(27,111,232,.14);
}
.form-note{ font-size:12.5px; color:var(--muted); }

/* contact info list */
.c-list{ display:grid; gap:14px; }
.c-list li{ display:flex; gap:13px; align-items:flex-start; }
.c-list .ic{
  width:42px; height:42px; border-radius:11px; flex:none;
  background:linear-gradient(135deg,#E8F1FE,#DCF4FB);
  display:flex; align-items:center; justify-content:center;
}
.c-list .ic svg{ width:19px; height:19px; color:var(--blue); }
.c-list b{ display:block; font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); font-weight:700; }
.c-list a, .c-list span.val{ font-size:15px; font-weight:600; color:var(--ink); }
.c-list a:hover{ color:var(--blue); }

/* ---------- footer ---------- */
.footer{ background:#0A1F52; color:rgba(255,255,255,.78); }
.footer-main .container{
  display:grid; grid-template-columns:1.5fr 1fr 1fr 1.3fr; gap:clamp(22px, 3vw, 44px);
  padding-block:clamp(36px, 6vh, 60px);
}
.footer h4{
  color:#fff; font-size:13px; font-weight:700; letter-spacing:.14em;
  text-transform:uppercase; margin-bottom:14px;
}
.footer h4::after{ content:""; display:block; width:26px; height:2px; background:var(--red); border-radius:2px; margin-top:8px; }
.f-brand{ display:flex; align-items:center; gap:11px; margin-bottom:12px; }
.f-brand img{ width:44px; height:44px; border-radius:50%; object-fit:cover; }
.f-brand b{ font-family:var(--f-disp); font-weight:400; font-size:23px; letter-spacing:.05em; color:#fff; text-transform:uppercase; line-height:1; }
.f-brand span{ display:block; font-size:9px; letter-spacing:.13em; text-transform:uppercase; color:rgba(255,255,255,.55); }
.footer-main p.blurb{ font-size:13.5px; line-height:1.65; }
.f-social{ display:flex; gap:10px; margin-top:14px; }
.f-social a{
  width:36px; height:36px; border-radius:9px; background:rgba(255,255,255,.08);
  display:flex; align-items:center; justify-content:center; color:#fff;
  transition:background-color .2s, transform .2s;
}
.f-social a:hover{ background:var(--blue); transform:translateY(-2px); }
.f-social svg{ width:16px; height:16px; }
.f-links{ display:grid; gap:8px; }
.f-links a{
  color:rgba(255,255,255,.72); font-size:14px; display:inline-flex; align-items:center; gap:8px;
  transition:color .2s, transform .2s;
}
.f-links a:hover{ color:#fff; transform:translateX(3px); }
.f-links svg{ width:13px; height:13px; color:var(--cyan); flex:none; }
.f-contact{ display:grid; gap:11px; font-size:13.5px; }
.f-contact li{ display:flex; gap:10px; align-items:flex-start; }
.f-contact svg{ width:15px; height:15px; color:var(--cyan); flex:none; margin-top:3px; }
.f-contact a{ color:rgba(255,255,255,.78); } .f-contact a:hover{ color:#fff; }

.footer-bottom{ border-top:1px solid rgba(255,255,255,.1); }
.footer-bottom .container{
  display:flex; align-items:center; justify-content:space-between; gap:10px; flex-wrap:wrap;
  padding-block:16px; font-size:12.5px; color:rgba(255,255,255,.55);
}
.footer-bottom a{ color:rgba(255,255,255,.75); transition:color .2s; }
.footer-bottom a:hover{ color:var(--cyan); }
.dev-credit a{ font-weight:600; }

/* ---------- floating WhatsApp ---------- */
.wa-float{
  position:fixed; right:18px; bottom:18px; z-index:80;
  width:52px; height:52px; border-radius:50%;
  background:#25D366; color:#fff; display:flex; align-items:center; justify-content:center;
  box-shadow:0 10px 24px rgba(37,211,102,.4);
  transition:transform .25s ease, box-shadow .25s ease;
}
.wa-float:hover{ transform:translateY(-3px) scale(1.05); box-shadow:0 14px 30px rgba(37,211,102,.5); }
.wa-float svg{ width:26px; height:26px; }

/* ---------- responsive ---------- */
@media (max-width: 1060px){
  .nav-menu, .nav-cta .btn-outline{ display:none; }
  .burger{ display:flex; }
  .split{ grid-template-columns:1fr; }
  .footer-main .container{ grid-template-columns:1fr 1fr; }
}
@media (max-width: 860px){
  .grid-4{ grid-template-columns:repeat(2, 1fr); }
  .grid-3{ grid-template-columns:repeat(2, 1fr); }
  .topbar .tagline{ display:none; }
  .hero::before{
    background:linear-gradient(180deg, rgba(255,255,255,.95) 0%, rgba(255,255,255,.88) 55%, rgba(255,255,255,.62) 100%);
  }
}
@media (max-width: 640px){
  :root{ --nav-h: 64px; }
  .brand-name span{ display:none; }
  .brand-name b{ font-size:22px; }
  .topbar-group.right .hide-sm{ display:none; }
  .grid-3, .grid-2{ grid-template-columns:repeat(2, 1fr); }   /* small cards: keep 2-col, never 1fr serial */
  .gallery-grid{ grid-template-columns:repeat(2, 1fr); }
  .stats{ grid-template-columns:repeat(3, 1fr); }
  .hero-points .container{ grid-template-columns:repeat(3, 1fr); gap:8px; }
  .hero-point{ flex-direction:column; align-items:flex-start; gap:6px; }
  .hero-point span{ display:none; }
  .form-row{ grid-template-columns:1fr; }
  .footer-main .container{ grid-template-columns:1fr 1fr; }
  .cta-strip .container{ flex-direction:column; align-items:flex-start; }
  .nav-cta .btn-primary{ display:none; }
}
@media (max-width: 420px){
  .card{ padding:14px; }
  .card .icon{ width:40px; height:40px; border-radius:10px; margin-bottom:10px; }
  .card .icon svg{ width:19px; height:19px; }
  .card h3{ font-size:13.5px; }
  .card p{ font-size:12.5px; }
}

/* reveal targets stay visible without JS; GSAP sets initial states at runtime */

@media (max-width: 640px){
  .hero{ background-image:url("../assets/img/hero-home-960.webp"); }
}
