/* =============================================================================
   CONNECD — Global Styles (cleaned & consolidated)
   Order: Tokens → Base → Layout → Components → Sections → Utilities → Media
   ========================================================================== */

/* ========== Tokens / Design System ======================================= */
:root{
  /* Palette */
  --bg:#0A0A0B; --surface:#121214; --card:#16181C;
  --text:#F4F6F8; --sub:#AEB6C2; --border:#2B2F36;
  --pink:#AB0563; --pink-2:#C21875; --cyan:#58E1FF; --green:#22C55E;

  /* Elevation & Radius */
  --radius:14px;
  --shadow:0 10px 30px rgba(0,0,0,.45);

  /* Section helpers (renamed to avoid collisions) */
  --container-max:1200px;
  --pad-section-desktop:112px;
  --pad-section-mobile:72px;
  --section-hairline:rgba(255,255,255,.08);
  --section-surface:rgba(255,255,255,.035);
  --section-elev-bd:rgba(255,255,255,.06);
  --section-elev-shadow:0 12px 28px rgba(0,0,0,.35);
}

/* Thai body */
@font-face{
  font-family: 'Noto Sans Thai';
  src: url('/assets/fonts/noto-sans-thai-regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;  /* ป้องกัน FOIT เพิ่มคะแนน LCP */
}
@font-face{
  font-family: 'Noto Sans Thai';
  src: url('/assets/fonts/noto-sans-thai-500.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

/* English/heading */
@font-face{
  font-family: 'Prompt';
  src: url('/assets/fonts/prompt-regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face{
  font-family: 'Prompt';
  src: url('/assets/fonts/prompt-600.woff2') format('woff2');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

:root{
  --font-body: 'Noto Sans Thai', system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  --font-head: 'Prompt', system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
}

/* ใช้รวมทั้ง TH/EN ได้ */
html, body { font-family: var(--font-body); }
h1,h2,h3,h4,h5,h6, .section-title, .btn { font-family: var(--font-head); }
strong, b { font-weight: 600; }


/* ========== Base ========================================================== */
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:"Prompt","Noto Sans Thai",ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  background:var(--bg); color:var(--text); line-height:1.6;
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}
a,a:visited,a:hover,a:focus,a:active{text-decoration:none;outline:none}
a:hover{opacity:.9;transform:translateY(-1px);transition:all .2s ease}

/* ========== Layout ======================================================== */
.container{
  width:min(100% - 48px, var(--container-max));
  margin-inline:auto;
}
section{padding:66px 0}

/* Sticky header */
.header{
  position:sticky; top:0; z-index:50;
  backdrop-filter:blur(14px) saturate(140%); -webkit-backdrop-filter:blur(14px) saturate(140%);
  background:linear-gradient(180deg,rgba(12,12,14,.72),rgba(12,12,14,.58));
  border-bottom:1px solid rgba(255,255,255,.06);
  box-shadow:0 10px 30px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.06);
}
.header::after{
  content:""; position:absolute; left:0; right:0; bottom:-1px; height:2px;
  background:linear-gradient(90deg,rgba(171,5,99,.45),rgba(88,225,255,.35));
  filter:blur(1.2px); opacity:.7;
}

/* Nav */
.nav{display:flex;align-items:center;justify-content:space-between;gap:14px; padding:16px 24px}
.brand{display:flex;align-items:center;gap:14px}
.logo-img{height:64px;object-fit:contain;filter:drop-shadow(0 2px 8px rgba(0,0,0,.45));transition:transform .2s,filter .2s}
.brand:hover .logo-img{transform:translateY(-1px) scale(1.01);filter:drop-shadow(0 4px 14px rgba(171,5,99,.25))}
.nav-actions{display:flex;align-items:center;gap:14px}

/* Language toggle */
.lang{
  position:relative; display:inline-flex; gap:0; padding:4px; min-width:130px;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.09); border-radius:999px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}
.lang::after{
  content:""; position:absolute; top:4px; left:4px; width:56px; height:32px; border-radius:999px;
  background:linear-gradient(180deg,rgba(255,255,255,.16),rgba(255,255,255,.06));
  box-shadow:0 6px 16px rgba(0,0,0,.25), inset 0 1px 0 rgba(255,255,255,.18);
  transition:transform .25s cubic-bezier(.22,.61,.36,1);
}
.lang button{
  position:relative; z-index:1; width:56px; height:32px; padding:0; border:0; cursor:pointer;
  background:transparent; color:#C9D2DA; font-weight:700; border-radius:999px; letter-spacing:.2px;
}
.lang button.active{background:var(--pink); color:#fff; box-shadow:0 0 0 2px rgba(171,5,99,.25) inset}
.lang.lang-en::after{transform:translateX(62px)}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; gap:8px; padding:10px 16px;
  border-radius:14px; font-weight:700; border:1px solid transparent; cursor:pointer;
  transition:transform .18s, box-shadow .18s, background .18s; margin:0;
}
.btn-primary{
  color:#fff; background:linear-gradient(180deg,#C21875 0%,#AB0563 100%);
  border:1px solid rgba(255,255,255,.08); box-shadow:0 10px 22px rgba(171,5,99,.32), inset 0 1px 0 rgba(255,255,255,.18);
  position:relative; overflow:hidden;
}
.btn-primary::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.18) 30%,transparent 60%);
  transform:translateX(-120%); transition:transform .6s ease;
}
.btn-primary:hover{background:linear-gradient(180deg,#D51F83 0%,#B00769 100%); transform:translateY(-2px); box-shadow:0 14px 28px rgba(171,5,99,.38)}
.btn-primary:hover::after{transform:translateX(0)}
.btn-outline{border-color:rgba(88,225,255,.8); color:#BDEFFF; background:transparent; box-shadow:inset 0 1px 0 rgba(255,255,255,.12)}
.btn-outline:hover{background:rgba(88,225,255,.12); transform:translateY(-2px); box-shadow:0 10px 22px rgba(88,225,255,.18)}

/* ========== Hero ========================================================== */
.hero{
  position:relative; isolation:isolate; min-height:80vh; display:grid; place-items:center; text-align:center; overflow:hidden;
  background-image:url("../assets/connecd-hero.webp"),
    radial-gradient(800px 400px at 75% 15%,rgba(171,5,99,.18),transparent 60%),
    radial-gradient(900px 500px at 20% 80%,rgba(88,225,255,.12),transparent 60%);
  background-size:cover,auto,auto; background-position:center; background-repeat:no-repeat;
}
.hero::before{
  content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(180deg,rgba(10,10,11,.85) 0%,rgba(10,10,11,.65) 40%,rgba(10,10,11,.88) 100%),
             linear-gradient(135deg,rgba(171,5,99,.42) 0%,rgba(88,225,255,.32) 100%);
}
.hero::after{
  content:""; position:absolute; inset:-20%; z-index:-1;
  background:radial-gradient(40% 60% at 70% 20%,rgba(171,5,99,.18),transparent 60%),
             radial-gradient(50% 50% at 20% 80%,rgba(88,225,255,.18),transparent 60%);
  filter:blur(18px); animation:drift 18s ease-in-out infinite alternate;
}
@keyframes drift{0%{transform:translate3d(0,0,0) scale(1)}100%{transform:translate3d(2%,-2%,0) scale(1.05)}}
.hero-inner{padding:96px 0 64px; transition:transform .25s ease-out; will-change:transform}
.hero h2{margin:8px auto 10px; max-width:980px; font-size:clamp(28px,4vw,46px); line-height:1.15; font-weight:800; text-shadow:0 2px 18px rgba(0,0,0,.55),0 0 10px rgba(171,5,99,.25)}
.hero p.lead{margin:0 auto 24px; max-width:860px; color:#C9D2DA; font-size:clamp(16px,1.6vw,18px); letter-spacing:.2px}
.hero-ctas{display:flex; gap:12px; justify-content:center; flex-wrap:wrap}

/* ========== About / Metrics ============================================== */
.section-title{font-weight:800; font-size:clamp(20px,2.4vw,28px); margin:0 0 6px}
.section-sub{color:var(--sub); margin:0 0 30px}

.about-pro{position:relative; overflow:hidden}
.about-pro::before{
  content:""; position:absolute; right:-10%; top:10%; width:700px; height:700px; border-radius:50%;
  background:radial-gradient(closest-side,rgba(171,5,99,.10),transparent 70%),
             radial-gradient(closest-side,rgba(88,225,255,.08),transparent 80%);
  filter:blur(24px); pointer-events:none;
}
.about-grid{display:grid; grid-template-columns:1.15fr .85fr; gap:34px; align-items:start}
.about-copy .lead{color:#C8D0D8; margin:10px 0 14px; max-width:58ch}

.usp-list{margin:14px 0 0; padding:0; list-style:none; display:grid; gap:10px}
.usp-list li{position:relative; padding-left:28px; color:#B9C3CD}
.usp-list li::before{
  content:""; position:absolute; left:0; top:8px; width:16px; height:16px; border-radius:4px;
  background:linear-gradient(135deg,#AB0563,#58E1FF); box-shadow:0 0 0 2px rgba(255,255,255,.06) inset;
}

.metrics{display:grid; grid-template-columns:repeat(3,1fr); gap:16px}
.metric{
  position:relative; padding:22px 18px; text-align:center; border-radius:16px;
  background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.015));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04), 0 12px 30px rgba(0,0,0,.35);
  transition:transform .18s, box-shadow .18s, border-color .18s;
}
.metric::after{
  content:""; position:absolute; inset:-1px; border-radius:16px; padding:1px;
  background:linear-gradient(135deg,rgba(171,5,99,.35),rgba(88,225,255,.25));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; opacity:.55; pointer-events:none;
}
.metric:hover{transform:translateY(-4px); border-color:rgba(171,5,99,.35); box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 16px 36px rgba(171,5,99,.18),0 10px 28px rgba(0,0,0,.40)}
.metric .num{
  font-weight:800; font-size:36px; line-height:1;
  background:linear-gradient(90deg,#AB0563 0%,#58E1FF 100%); -webkit-background-clip:text; background-clip:text; color:transparent;
  text-shadow:0 0 24px rgba(171,5,99,.16); margin-bottom:8px;
}
.metric .cap{color:#C0C8D2; margin:0}

/* ========== Services Cards =============================================== */
.svc-section{position:relative}
.svc-section::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(800px 400px at 15% 10%,rgba(171,5,99,.10),transparent 60%),
             radial-gradient(900px 500px at 85% 80%,rgba(88,225,255,.08),transparent 60%);
  filter:blur(10px)
}
.svc-title{margin:0 0 6px; font-weight:800; font-size:clamp(22px,2.2vw,28px)}
.svc-sub{margin:0 0 22px; color:#AEB6C2}
.svc-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.svc-card{
  position:relative; border-radius:18px; padding:22px; overflow:hidden;
  background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.015));
  border:1px solid rgba(255,255,255,.08); box-shadow:0 14px 40px rgba(0,0,0,.35);
  transition:transform .18s, box-shadow .18s, border-color .18s;
}
.svc-card::after{
  content:""; position:absolute; inset:-1px; border-radius:18px; padding:1px;
  background:linear-gradient(135deg,rgba(171,5,99,.38),rgba(88,225,255,.28));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; opacity:.55; pointer-events:none;
}
.svc-card:hover{transform:translateY(-6px); border-color:rgba(171,5,99,.38); box-shadow:0 18px 46px rgba(171,5,99,.18),0 12px 34px rgba(0,0,0,.42)}
.svc-card-head{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.svc-icon{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;font-weight:900;color:#0a0a0b;background:linear-gradient(180deg,#58E1FF,#22C55E);border:1px solid rgba(255,255,255,.12);box-shadow:inset 0 1px 0 rgba(255,255,255,.25)}
.svc-icon-pink{background:linear-gradient(180deg,#AB0563,#58E1FF)}
.svc-icon-mint{background:linear-gradient(180deg,#22C55E,#58E1FF)}
.svc-card-title{margin:0;font-size:18px}
.svc-copy{margin:8px 0 12px;color:#C8D0D8}
.svc-meta{margin:0 0 14px;padding:0;list-style:none;display:grid;gap:6px}
.svc-meta li{position:relative;padding-left:22px;color:#B9C3CD;font-size:14px}
.svc-meta li::before{content:"";position:absolute;left:0;top:8px;width:12px;height:12px;border-radius:3px;background:linear-gradient(135deg,#AB0563,#58E1FF);box-shadow:0 0 0 2px rgba(255,255,255,.06) inset}
.svc-link{display:inline-flex;align-items:center;gap:6px;font-weight:700;color:#F4F6F8;padding:8px 12px;border-radius:10px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);transition:background .18s,transform .18s,box-shadow .18s}
.svc-card:hover .svc-link{background:rgba(171,5,99,.12);box-shadow:0 6px 18px rgba(171,5,99,.20)}
.svc-link span{transition:transform .18s}
.svc-link:hover span{transform:translateX(2px)}

/* ========== Logos / Clients ============================================== */
.logos{display:grid;grid-template-columns:repeat(5,1fr);gap:20px;align-items:center}
.logos .logo-item{height:46px;border-radius:12px;background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.015));border:1px solid var(--border);filter:grayscale(1) brightness(.9);transition:filter .2s,box-shadow .2s,border-color .2s}
.logos .logo-item:hover{filter:grayscale(0) brightness(1);box-shadow:0 0 0 3px rgba(171,5,99,.25);border-color:rgba(171,5,99,.45)}
.logo-grid.pro{--cell-min:200px;display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(var(--cell-min),1fr))}
.logo-card{position:relative;border-radius:18px;overflow:hidden;background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.015));border:1px solid rgba(255,255,255,.08);box-shadow:0 16px 44px rgba(0,0,0,.36);transform-style:preserve-3d;transition:transform .18s,box-shadow .18s,border-color .18s}
.logo-card::after{content:"";position:absolute;inset:-1px;border-radius:18px;padding:1px;background:linear-gradient(135deg,rgba(171,5,99,.38),rgba(88,225,255,.28));-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:.55;pointer-events:none}
.logo-card::before{content:"";position:absolute;inset:-40%;transform:translateX(-60%) rotate(20deg);background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.15) 40%,transparent 60%);transition:transform .6s ease;pointer-events:none}
.logo-card:hover{border-color:rgba(171,5,99,.38);box-shadow:0 22px 56px rgba(171,5,99,.2),0 14px 36px rgba(0,0,0,.44)}
.logo-card:hover::before{transform:translateX(0) rotate(20deg)}
.logo-wrap{display:flex;align-items:center;justify-content:center;height:96px;padding:8px 14px}
.logo-svg{height:48px;width:auto;filter:grayscale(1) brightness(.9);opacity:.85;transition:.25s}
.logo-card:hover .logo-svg{filter:none;opacity:1;transform:translateZ(10px) scale(1.03)}

/* ========== CTA (Panel + Card) =========================================== */
.cta-pro{position:relative;padding:64px 0}
.cta-pro::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(900px 500px at 20% 10%,rgba(171,5,99,.12),transparent 60%),
             radial-gradient(1000px 600px at 85% 90%,rgba(88,225,255,.10),transparent 60%);
  filter:blur(14px)
}
.cta-pro__panel{
  position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:24px;
  padding:36px clamp(18px,3vw,32px);border-radius:28px;overflow:hidden;
  background:linear-gradient(160deg,rgba(171,5,99,.65),rgba(28,29,36,.75));
  border:1px solid rgba(255,255,255,.10);box-shadow:0 24px 60px rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.08);
}
.cta-pro__panel::after{
  content:"";position:absolute;inset:-1px;border-radius:28px;padding:1px;
  background:linear-gradient(135deg,rgba(171,5,99,.38),rgba(88,225,255,.28));
  -webkit-mask:linear-gradient(#0000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:.5;pointer-events:none;
}
.cta-badge{display:inline-block;font-size:12px;letter-spacing:.6px;text-transform:uppercase;padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.08);color:#FFE3F1;border:1px solid rgba(255,255,255,.18);margin-bottom:10px}
.cta-head{margin:4px 0 8px;font-size:clamp(22px,2.2vw,28px);font-weight:800}
.cta-sub{margin:0 0 12px;color:#F6E8F1;opacity:.9}
.cta-list{margin:12px 0 18px;padding-left:0;list-style:none;display:grid;gap:8px}
.cta-list li{position:relative;padding-left:22px;color:#F4F6F8;opacity:.95}
.cta-list li::before{content:"";position:absolute;left:0;top:8px;width:10px;height:10px;border-radius:3px;background:linear-gradient(135deg,#AB0563,#58E1FF);box-shadow:0 0 0 2px rgba(255,255,255,.08) inset}
.cta-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:14px;font-weight:700;color:#EAF6FF;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);transition:transform .18s,background .18s,box-shadow .18s}
.btn-ghost:hover{transform:translateY(-1px);background:rgba(171,5,99,.18);box-shadow:0 10px 22px rgba(171,5,99,.22)}
.cta-btn{position:relative;overflow:hidden}
.cta-btn .cta-arrow{width:20px;height:20px;margin-left:6px}
.cta-btn::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.20) 35%,transparent 65%);transform:translateX(-130%);transition:transform .6s ease}
.cta-btn:hover::after{transform:translateX(0)}
.cta-micro{display:flex;gap:8px;align-items:center;color:#FCE6F1;opacity:.9;margin-top:10px;font-size:13px}
.cta-micro .micro{white-space:nowrap}
.cta-pro__visual{display:flex;align-items:center;justify-content:center}
.cta-card{position:relative;width:min(420px,100%);aspect-ratio:16/10;border-radius:18px;overflow:hidden;background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.12);box-shadow:0 20px 44px rgba(0,0,0,.4)}
.cta-card__ring{content:"";position:absolute;inset:-1px;border-radius:18px;padding:1px;background:linear-gradient(135deg,rgba(171,5,99,.35),rgba(88,225,255,.25));-webkit-mask:linear-gradient(#0000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:.6}
.cta-card__glow{position:absolute;width:320px;height:320px;border-radius:50%;background:radial-gradient(closest-side,rgba(171,5,99,.35),transparent 70%);filter:blur(24px);right:-20%;top:-20%;opacity:.7;animation:float 8s ease-in-out infinite alternate}
.cta-card__img{position:absolute;inset:10px;width:calc(100% - 20px);height:calc(100% - 20px);object-fit:cover;border-radius:12px;filter:contrast(1.03) saturate(1.02)}
.cta-card__meta{position:absolute;left:14px;bottom:12px;display:flex;gap:8px;align-items:center;background:rgba(0,0,0,.35);padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.14);color:#EAF0F6;font-weight:700;font-size:13px;backdrop-filter:blur(4px)}
.cta-card__meta .dot{width:8px;height:8px;border-radius:50%;background:#58E1FF;box-shadow:0 0 8px rgba(88,225,255,.8)}
@keyframes float{0%{transform:translateY(0)}100%{transform:translateY(-8px)}}

/* ========== Contact ======================================================= */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
.field label{font-weight:600;color:#E7ECF2}
.field input,.field textarea{background:#0f1114;border:1px solid #2a2f36;color:var(--text);border-radius:10px;padding:12px}
.field input::placeholder,.field textarea::placeholder{color:#9AA3AF}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--pink);box-shadow:0 0 0 3px rgba(171,5,99,.2)}
.form-hint{color:#CAD3DE;font-size:13px;margin-top:6px;opacity:.85}
.btn-submit{position:relative;overflow:hidden}
.btn-submit:active{transform:translateY(1px)}
.btn-submit::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.18) 28%,transparent 56%);transform:translateX(-130%);transition:transform .55s ease}
.btn-submit:hover::after{transform:translateX(0)}
.address{background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.015));border:1px solid var(--border);border-radius:18px;padding:18px;position:relative;box-shadow:0 14px 36px rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.06)}
.address::after{content:"";position:absolute;inset:-1px;border-radius:18px;padding:1px;background:linear-gradient(135deg,rgba(171,5,99,.35),rgba(88,225,255,.25));-webkit-mask:linear-gradient(#0000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:.55;pointer-events:none}
.contact-alt{margin-top:12px;display:grid;gap:6px;color:#CFE3F6}
.contact-alt a{color:#BDEFFF}
.socials{margin-top:12px;display:flex;gap:12px;flex-wrap:wrap}
.socials a{padding:6px 10px;border:1px solid rgba(255,255,255,.12);border-radius:999px;background:rgba(255,255,255,.04);color:#EAF4FF;font-weight:700;font-size:13px;transition:.18s}
.socials a:hover{background:rgba(171,5,99,.18);border-color:rgba(171,5,99,.45)}

/* Footer */
footer{padding:24px 0;color:var(--sub);border-top:1px solid rgba(255,255,255,.06);text-align:center}

/* ========== FAQ (single source of truth) ================================= */
.faq-pro{position:relative; padding:72px 0 56px; isolation:isolate}
.faq-pro::before{
  content:""; position:absolute; inset:-10% 0; z-index:-1; pointer-events:none;
  background:radial-gradient(900px 520px at 12% 10%, rgba(171,5,99,.12), transparent 60%),
             radial-gradient(900px 520px at 88% 90%, rgba(88,225,255,.10), transparent 60%);
  filter:blur(12px);
}
.faq-head{margin-bottom:20px}
.faq-head .section-title{margin:0 0 6px}
.faq-head .section-sub{margin:0;opacity:.9}
.faq-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(420px,1fr))}
@media (max-width:460px){.faq-grid{grid-template-columns:1fr}}
.faq-item{
  border-radius:16px; border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.02));
  box-shadow:0 10px 28px rgba(0,0,0,.33); overflow:hidden;
  transition:border-color .18s, box-shadow .18s, transform .18s;
}
.faq-item:hover{transform:translateY(-1px); border-color:rgba(171,5,99,.32); box-shadow:0 16px 40px rgba(171,5,99,.16),0 10px 28px rgba(0,0,0,.38)}
.faq-item[open]{border-color:rgba(88,225,255,.28)}
.faq-item summary{
  list-style:none; display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:16px 18px; cursor:pointer; user-select:none; font-weight:700; line-height:1.25;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item .chev{width:22px;height:22px;flex:0 0 22px;color:#DDE7F2;opacity:.9;transform:rotate(0);transition:transform .18s,opacity .18s}
.faq-item[open] .chev{transform:rotate(180deg);opacity:1}
.faq-body{padding:0 18px 16px;border-top:1px solid rgba(255,255,255,.06);color:#C8D0D8}
.faq-body p{margin:12px 0 0}
.faq-cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}


/* === LOGO GRID FIXES === */

/* ปรับ layout ให้มี gap เท่ากันและ flex align ปกติ */
.logo-grid.pro {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 18px;
  align-items: stretch;
}

/* Card พื้นฐาน */
.logo-card {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100px;
  padding: 10px 16px;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.015));
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 16px 44px rgba(0,0,0,.36);
  overflow: hidden;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

/* Hover effect */
.logo-card:hover {
  border-color: rgba(171,5,99,.38);
  box-shadow: 0 22px 56px rgba(171,5,99,.2), 0 14px 36px rgba(0,0,0,.44);
  transform: translateY(-2px);
}

/* เนื้อหาภายในการ์ด */
.logo-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  height: 80px;
  padding: 0 12px;
}

.logo-svg {
  height: 36px;
  width: auto;
  flex-shrink: 0;
  opacity: .9;
  filter: grayscale(1) brightness(.9);
  transition: opacity .2s ease, filter .2s ease;
}

.logo-card:hover .logo-svg {
  opacity: 1;
  filter: none;
}

/* ข้อความในโลโก้ */
.logo-card span,
.logo-card strong {
  font-weight: 700;
  color: #E8EDF2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* === CHIP (Filter Button) === */
.logo-filters {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
  margin: 10px 0 22px;
}

.chip {
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: #C9D2DA;
  font-weight: 700;
  cursor: pointer;
  transition: all .18s ease;
}

.chip:hover {
  background: rgba(171,5,99,.15);
  border-color: rgba(171,5,99,.45);
  color: #fff;
}

.chip.is-active {
  background: rgba(171,5,99,.22);
  border-color: rgba(171,5,99,.45);
  color: #fff;
}

/* === Showcase === */
.showcase-head { text-align:center; margin-bottom: 1.5rem; }
.showcase-filters { display:flex; gap:.5rem; justify-content:center; margin-bottom:1rem; flex-wrap:wrap; }
.showcase-filters .chip { padding:.5rem 1rem; border:1px solid var(--line,#e5e7eb); border-radius:999px; background:#0f1115; color:#e5e7eb; cursor:pointer; }
.showcase-filters .chip.is-active { background:linear-gradient(90deg,#AB0563,#58E1FF); color:#0a0a0b; border-color:transparent; }

.showcase-grid { 
  display:grid; 
  grid-template-columns: repeat(12, 1fr);
  gap:12px;
}
.showcase-card { 
  position:relative; 
  grid-column: span 4; 
  overflow:hidden; 
  border-radius:14px; 
  background:#0f1115; 
}
.showcase-card.wide { grid-column: span 8; }
.showcase-card.tall { grid-column: span 4; grid-row: span 2; }

.showcase-card img { width:100%; height:100%; object-fit:cover; display:block; aspect-ratio: 4/3; }
.showcase-card.wide img { aspect-ratio: 16/9; }
.showcase-card.tall img { aspect-ratio: 3/4; }

.showcase-overlay {
  position:absolute; inset:0; 
  background:linear-gradient(180deg, rgba(10,11,12,0) 40%, rgba(10,11,12,.9) 100%);
  color:#e5e7eb; 
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:14px; gap:4px;
  opacity:0; transition:opacity .18s ease;
}
.showcase-card:hover .showcase-overlay,
.showcase-card:focus-within .showcase-overlay { opacity:1; }

.showcase-overlay h4 { font-size:1rem; font-weight:700; line-height:1.3; }
.showcase-overlay p { font-size:.9rem; opacity:.9; }

@media (max-width: 1024px){
  .showcase-card, .showcase-card.wide, .showcase-card.tall { grid-column: span 6; grid-row:auto; }
}
@media (max-width: 640px){
  .showcase-grid { grid-template-columns: repeat(6, 1fr); }
  .showcase-card, .showcase-card.wide, .showcase-card.tall { grid-column: span 6; }
}

/* Lightbox */
.lightbox { 
  position:fixed; inset:0; background:rgba(10,11,12,.9); 
  display:none; align-items:center; justify-content:center; 
  z-index:1000; padding:24px;
}
.lightbox.is-open { display:flex; }
.lightbox-img { max-width: min(1200px, 90vw); max-height: 80vh; object-fit:contain; border-radius:10px; }
.lightbox-caption { color:#e5e7eb; margin-top:10px; text-align:center; font-size:.95rem; opacity:.85; }
.lightbox-close, .lightbox-prev, .lightbox-next {
  position:absolute; top:16px; background:#0f1115; color:#e5e7eb; border:1px solid #2a2f36; 
  width:40px; height:40px; border-radius:999px; display:grid; place-items:center; cursor:pointer;
}
.lightbox-close { right:16px; font-size:22px; }
.lightbox-prev, .lightbox-next { top:50%; transform:translateY(-50%); font-size:26px; }
.lightbox-prev { left:16px; }
.lightbox-next { right:16px; }

/* ========== Utilities ===================================================== */
[data-i18n="en"]{display:none}
.en-active [data-i18n="th"]{display:none}
.en-active [data-i18n="en"]{display:block}
@media (prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(14px);transition:opacity .7s,transform .7s}
  .reveal.show{opacity:1;transform:none}
  .reveal[d-delay="100"]{transition-delay:.1s}
  .reveal[d-delay="200"]{transition-delay:.2s}
  .reveal[d-delay="300"]{transition-delay:.3s}
  .reveal[d-delay="400"]{transition-delay:.4s}
}

/* ========== Mobile / Responsive ========================================== */
@media (max-width:1024px){
  .about-grid{grid-template-columns:1fr;gap:22px}
  .metrics{grid-template-columns:repeat(3,minmax(0,1fr))}
  .cards{grid-template-columns:1fr 1fr}
  .logos{grid-template-columns:repeat(3,1fr)}
  .contact-grid{grid-template-columns:1fr}
  .cta-pro__panel{grid-template-columns:1fr}
  .cta-pro__visual{order:-1}
}
@media (max-width:768px){
  .logo-grid.pro{--cell-min:160px}
  .logo-wrap{height:84px}
  .logo-svg{height:42px}
}
@media (max-width:680px){
  .metrics{grid-template-columns:1fr}
  .metric .num{font-size:32px}
  .cards{grid-template-columns:1fr}
  .logos{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:640px){
  .nav{padding:10px 14px;gap:10px}
  .logo-img{height:48px;filter:drop-shadow(0 1px 4px rgba(0,0,0,.35))}
  .lang{padding:2px;gap:2px;background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.08)}
  .lang button{padding:6px 10px;font-size:12px;line-height:1;min-width:40px}
  .nav-actions .btn.btn-primary{display:none}
  .hero-inner{padding:68px 0 40px}
  .hero h2{font-size:clamp(22px,5.6vw,30px)}
  .hero p.lead{font-size:14px}
  .svc-grid{grid-template-columns:1fr}
  .header{padding-top:env(safe-area-inset-top)}
  .cta-pro{padding:44px 0}
  .cta-pro__panel{padding:24px;border-radius:22px}
  .cta-head{font-size:22px}
}
/* Sticky mobile CTA */
.mobile-cta{display:none}
@media (max-width:640px){
  .mobile-cta{
    display:flex; position:sticky; bottom:0; z-index:60;
    padding:max(8px,env(safe-area-inset-bottom)) 12px 12px;
    background:linear-gradient(180deg,rgba(10,10,11,0) 0%,rgba(10,10,11,.75) 45%,rgba(10,10,11,.95) 100%);
    backdrop-filter:blur(8px); justify-content:center;
  }
  .mobile-cta__btn{
    display:inline-flex; align-items:center; justify-content:center; width:100%; max-width:520px; min-height:48px;
    border-radius:14px; font-weight:800; letter-spacing:.2px; color:#fff;
    background:linear-gradient(135deg,var(--pink) 0%,var(--pink-2) 100%);
    box-shadow:0 10px 22px rgba(171,5,99,.28); border:1px solid rgba(255,255,255,.08);
  }
  .mobile-cta__btn:active{transform:translateY(1px); box-shadow:0 6px 16px rgba(171,5,99,.28)}
}
@media (min-width:641px){.mobile-cta{display:none !important}}