/* ============================================================
   RESET & VARIABLES
============================================================ */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --blk:#0a0a0a;--blk2:#111;--blk3:#161616;
  --grn:#22c55e;--grn2:#16a34a;--grn3:rgba(34,197,94,.1);--grn4:rgba(34,197,94,.05);
  --wh:#fff;--w2:rgba(255,255,255,.85);--w3:rgba(255,255,255,.45);--w4:rgba(255,255,255,.1);
  --lt:#f8f7f4;--lt2:#f0eeea;--lt3:#e8e6e1;
  --dk:#1c1c1c;--dk2:#2a2a2a;--dkm:rgba(28,28,28,.5);
  --bd-lt:rgba(0,0,0,.08);--bd-dk:rgba(255,255,255,.07);
  --sans:'Google Sans','Noto Sans Thai',sans-serif;
  --thai:'Noto Sans Thai','Google Sans',sans-serif;
}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--wh);color:var(--dk);font-family:var(--sans);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--lt3);border-radius:2px}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:0 52px;height:80px;background:rgba(255,255,255,.72);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid rgba(0,0,0,.06);transition:background .3s,box-shadow .3s}
nav.dark{background:rgba(10,10,10,.8);border-bottom-color:rgba(255,255,255,.06)}
.nav-logo{display:flex;align-items:center;gap:10px}
.nav-logo-txt{font-size:16px;font-weight:700;letter-spacing:2px;color:var(--dk)}
nav.dark .nav-logo-txt{color:var(--wh)}
.nav-logo-txt em{color:var(--grn);font-style:normal}
.nav-menu{display:flex;align-items:center;gap:0;list-style:none;position:relative}
.nav-item{position:relative}
.nav-link{display:flex;align-items:center;gap:4px;padding:0 16px;height:80px;font-size:15px;color:rgba(28,28,28,.6);letter-spacing:.2px;transition:color .2s;cursor:pointer;white-space:nowrap;border:none;background:transparent;font-family:var(--sans)}
nav.dark .nav-link{color:rgba(255,255,255,.55)}
.nav-link:hover,.nav-link.active{color:var(--dk)}
nav.dark .nav-link:hover,nav.dark .nav-link.active{color:var(--wh)}
.nav-link svg{width:12px;height:12px;transition:transform .2s;flex-shrink:0}
.nav-item:hover .nav-link svg{transform:rotate(180deg)}
.dropdown{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(-8px);background:rgba(255,255,255,.95);backdrop-filter:blur(20px);border:1px solid rgba(0,0,0,.08);border-radius:14px;padding:8px;min-width:240px;opacity:0;pointer-events:none;transition:all .2s;box-shadow:0 8px 40px rgba(0,0,0,.12)}
.nav-item:hover .dropdown,.dropdown.open{opacity:1;pointer-events:all;transform:translateX(-50%) translateY(0)}
.dd-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;transition:background .15s;cursor:pointer}
.dd-item:hover{background:rgba(0,0,0,.04)}
.dd-dot{width:5px;height:5px;background:var(--grn);border-radius:50%;flex-shrink:0}
.dd-text{font-size:13px;color:var(--dk);letter-spacing:.1px}
.nav-cta{background:var(--dk);color:var(--wh);padding:12px 30px;border-radius:999px;font-size:15px;font-weight:600;letter-spacing:.2px;transition:all .2s;white-space:nowrap;border:none;cursor:pointer;font-family:var(--sans)}
nav.dark .nav-cta{background:var(--grn);color:#000}
.nav-cta:hover{background:var(--grn);color:#000;transform:translateY(-1px)}
.hamburger{display:none;flex-direction:column;gap:6px;cursor:pointer;padding:12px;border:none;background:transparent;z-index:201;position:relative}
.hamburger span{width:26px;height:2.5px;background:var(--dk);transition:all .3s cubic-bezier(0.4,0,0.2,1);display:block;border-radius:2px}
nav.dark .hamburger span{background:var(--wh)}
.hamburger.active span{background:var(--dk) !important}
.hamburger.active span:nth-child(1){transform:translateY(8.5px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0;transform:translateX(10px)}
.hamburger.active span:nth-child(3){transform:translateY(-8.5px) rotate(-45deg)}
.mobile-nav{display:none;position:fixed;inset:0;background:var(--wh);z-index:199;flex-direction:column;padding:80px 28px 40px;overflow-y:auto}
.mobile-nav.open{display:flex}
.mob-link{font-size:22px;font-weight:600;color:var(--dk);padding:14px 0;border-bottom:1px solid var(--bd-lt)}
.mob-sub{font-size:14px;color:rgba(28,28,28,.5);padding:10px 0 10px 16px;cursor:pointer}

/* HERO HOME */
.hero{min-height:100vh;display:flex;align-items:center;padding:100px 52px 80px;position:relative;overflow:hidden;background:var(--blk)}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:80px 80px}
.hero-glow{position:absolute;right:-5%;top:15%;width:700px;height:700px;background:radial-gradient(circle,rgba(34,197,94,.05) 0%,transparent 65%)}
.hero-content{max-width:780px;position:relative;z-index:1}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(34,197,94,.3);background:rgba(34,197,94,.06);color:var(--grn);padding:6px 14px;border-radius:20px;font-size:11px;letter-spacing:2px;text-transform:uppercase;font-weight:500;margin-bottom:28px}
.hero-eyebrow::before{content:'';width:6px;height:6px;background:var(--grn);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.8)}}
.hero h1{font-size:clamp(48px,7vw,86px);font-weight:700;line-height:1.02;letter-spacing:-3px;color:var(--wh);margin-bottom:20px}
.hero h1 .g{color:var(--grn)}
.hero-sub{font-family:var(--thai);font-size:18px;color:var(--w3);margin-bottom:44px;max-width:520px;line-height:1.8}
.hero-sub strong{color:var(--w2);font-weight:400}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap}
.btn-dark{background:var(--grn);color:#000;padding:18px 40px;border-radius:999px;font-size:16px;font-weight:700;transition:all .2s;letter-spacing:.2px;display:inline-flex;align-items:center;gap:8px;border:none;cursor:pointer;font-family:var(--sans)}
.btn-dark:hover{background:var(--grn2);transform:translateY(-1px)}
.btn-ghost{color:var(--w3);padding:18px 36px;border-radius:999px;font-size:16px;border:1px solid rgba(255,255,255,.12);transition:all .2s;background:transparent;cursor:pointer;font-family:var(--sans)}
.btn-ghost:hover{color:var(--wh);border-color:rgba(255,255,255,.3)}
.hero-tags{display:flex;gap:24px;margin-top:64px;padding-top:28px;border-top:1px solid rgba(255,255,255,.06);flex-wrap:wrap}
.hero-tag{font-size:11px;color:var(--w3);letter-spacing:1.5px;text-transform:uppercase;display:flex;align-items:center;gap:6px}
.hero-tag::before{content:'';width:4px;height:4px;background:var(--grn);border-radius:50%}

/* CLIENTS */
.clients-home{padding:72px 52px;background:var(--wh)}
.clients-label{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:rgba(0,0,0,.3);text-align:center;margin-bottom:40px;font-weight:500}
.clients-logos{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:12px 24px}
.cl-logo{width:180px;height:80px;display:flex;align-items:center;justify-content:center;opacity:.5;transition:all .3s ease;cursor:pointer;position:relative}
.cl-logo:hover{opacity:1;transform:scale(1.1)}
.cl-logo img{max-width:100%;max-height:100%;object-fit:contain;filter:grayscale(100%) contrast(0.8);transition:all .3s ease}
.cl-logo:hover img{filter:grayscale(0%) contrast(1)}
.cl-logo-ph{width:80px;height:28px;background:rgba(0,0,0,.08);border-radius:4px;display:flex;align-items:center;justify-content:center}
.cl-logo-ph span{font-size:10px;color:rgba(0,0,0,.3);letter-spacing:1px}

/* SERVICES OVERVIEW */
.svc-overview{padding:96px 52px;background:var(--lt)}
.svc-ov-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:52px;border:2px solid var(--lt3);border-radius:16px;overflow:hidden}
.svc-ov-item{background:var(--wh);padding:36px 32px;cursor:pointer;transition:background .2s;position:relative;border:none;text-align:left;font-family:var(--sans)}
.svc-ov-item:hover{background:var(--blk);color:var(--wh)}
.svc-ov-item:hover .sov-num{color:rgba(255,255,255,.1)}
.svc-ov-item:hover .sov-name{color:var(--wh)}
.svc-ov-item:hover .sov-desc{color:rgba(255,255,255,.45)}
.svc-ov-item:hover .sov-arr{color:var(--grn)}
.sov-num{font-size:11px;color:rgba(0,0,0,.25);letter-spacing:2px;margin-bottom:16px;font-weight:500}
.sov-name{font-size:17px;font-weight:600;color:var(--dk);margin-bottom:8px;transition:color .2s}
.sov-desc{font-size:13px;color:rgba(0,0,0,.4);line-height:1.6;font-family:var(--thai);transition:color .2s}
.sov-arr{position:absolute;right:24px;bottom:28px;color:rgba(0,0,0,.2);font-size:18px;transition:color .2s}

/* WHY */
.why-sec{padding:96px 52px;background:var(--blk)}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;margin-top:52px}
.why-items{display:flex;flex-direction:column;gap:0;margin-top:32px}
.why-item{display:flex;gap:16px;padding:20px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.why-item:last-child{border-bottom:none}
.why-num{font-size:13px;font-weight:700;color:var(--grn);min-width:28px}
.why-title{font-size:15px;font-weight:500;color:var(--wh);margin-bottom:4px}
.why-desc{font-size:13px;color:var(--w3);line-height:1.65;font-family:var(--thai)}
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.stat-item{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);padding:32px;border-radius:12px}
.stat-num{font-size:44px;font-weight:700;color:var(--wh);letter-spacing:-2px;margin-bottom:4px;line-height:1}
.stat-num em{color:var(--grn);font-style:normal}
.stat-label{font-size:12px;color:var(--w3);text-transform:uppercase;letter-spacing:1px}

/* CTA HOME */
.cta-home{padding:96px 52px;background:var(--wh);text-align:center}
.cta-home h2{font-size:clamp(48px,7vw,80px);font-weight:700;letter-spacing:-3px;color:var(--dk);margin-bottom:14px;line-height:1.05}
.cta-home h2 span{color:var(--grn)}
.cta-home p{font-size:16px;color:rgba(0,0,0,.5);max-width:480px;margin:0 auto 36px;font-family:var(--thai);line-height:1.75}
.cta-home-btns{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.btn-blk{background:var(--dk);color:var(--wh);padding:18px 40px;border-radius:999px;font-size:16px;font-weight:700;transition:all .2s;border:none;cursor:pointer;font-family:var(--sans)}
.btn-blk:hover{background:var(--grn);color:#000;transform:translateY(-1px)}
.cta-contact-line{margin-top:48px;font-size:13px;color:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;max-width:none;word-break:break-word}
.cta-contact-line a{color:inherit;font-weight:600;text-decoration:none;white-space:nowrap;border-bottom:1px solid rgba(0,0,0,.1)}
.cta-contact-line a:hover{color:var(--dk);border-bottom-color:var(--dk)}

/* SERVICES PAGE */
.svc-page{min-height:100vh;padding-top:64px}
.svc-hero{height:100vh;display:flex;align-items:flex-end;padding:64px 52px;position:relative;overflow:hidden;background:var(--blk)}
.svc-hero-media{position:absolute;inset:0;z-index:0}
.svc-hero-media img,.svc-hero-media video{width:100%;height:100%;object-fit:cover;opacity:.35}
.svc-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.2) 60%,transparent 100%)}
.svc-hero-content{position:relative;z-index:1;max-width:680px}
.svc-eyebrow{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--grn);font-weight:500;margin-bottom:12px}
.svc-hero h1{font-size:clamp(36px,5.5vw,68px);font-weight:700;letter-spacing:-2px;color:var(--wh);margin-bottom:16px;line-height:1.05}
.svc-hero-sub{font-size:16px;color:var(--w3);line-height:1.75;font-family:var(--thai);max-width:520px;margin-bottom:28px}
.svc-hero-cta{display:inline-flex;align-items:center;gap:8px;background:var(--grn);color:#000;padding:16px 36px;border-radius:999px;font-size:16px;font-weight:700;transition:all .2s;border:none;cursor:pointer;font-family:var(--sans)}
.svc-hero-cta:hover{background:var(--grn2);transform:translateY(-1px)}
.svc-content{padding:80px 52px;background:var(--wh)}
.svc-content.dark{background:var(--blk);color:var(--wh)}
.btn-grn {
  background: var(--grn);
  color: #000;
  padding: 18px 40px;
  border-radius: 999px;
  font-size: 16px;
  font-weight: 700;
  transition: all .2s;
  border: none;
  cursor: pointer;
  font-family: var(--sans);
}
.btn-grn:hover {
  background: var(--grn2);
  transform: translateY(-1px);
}
.svc-content.light{background:var(--lt)}
.svc-2col{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.svc-2col.rev{direction:rtl}
.svc-2col.rev>*{direction:ltr}
.svc-block-title{font-size:clamp(28px,4vw,42px);font-weight:700;letter-spacing:-1.5px;line-height:1.1;margin-bottom:16px}
.svc-block-sub{font-size:16px;color:rgba(0,0,0,.55);line-height:1.75;font-family:var(--thai);margin-bottom:32px}
.svc-content.dark .svc-block-sub{color:var(--w3)}

/* PHASE CARDS */
.phase-row{display:grid;grid-template-columns:repeat(3,1fr);gap:60px;margin-top:60px;align-items:stretch}
.ph-card{
  background:var(--lt);
  border-radius:20px;
  padding:32px;
  display:flex;
  flex-direction:column;
  height:100%;
  transition:all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  border:1px solid transparent;
}
.ph-card:hover{
  transform:translateY(-8px);
  background:var(--wh);
  box-shadow:0 20px 40px rgba(0,0,0,0.05);
  border-color:var(--grn3);
}
.svc-content.dark .ph-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07)}
.svc-content.dark .ph-card:hover{background:rgba(255,255,255,.07);border-color:var(--grn)}
.ph-price{font-size:32px;font-weight:700;color:var(--grn);letter-spacing:-1.5px;line-height:1}
.ph-mo{font-size:11px;color:rgba(0,0,0,.4);text-transform:uppercase;letter-spacing:1px;margin:8px 0 12px}
.svc-content.dark .ph-mo{color:var(--w3)}
.ph-name{font-size:18px;font-weight:700;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid rgba(0,0,0,.08);color:var(--dk)}
.svc-content.dark .ph-name{border-bottom-color:rgba(255,255,255,.06);color:var(--wh)}
.ph-list{list-style:none;display:flex;flex-direction:column;gap:10px;margin-top:4px;flex:1}
.ph-list li{font-size:15px;color:rgba(0,0,0,.55);display:flex;gap:10px;line-height:1.5;font-family:var(--thai)}
.svc-content.dark .ph-list li{color:var(--w3)}
.ph-list li::before{content:'✓';color:var(--grn);font-weight:700;flex-shrink:0}

/* PRICING CARDS */
.price-row{display:grid;grid-template-columns:repeat(3,1fr);gap:60px;margin-top:60px;align-items:stretch}
.pc{
  background:var(--lt);
  border-radius:20px;
  padding:32px;
  transition:all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  position:relative;
  border:1px solid transparent;
  display:flex;
  flex-direction:column;
  height:100%;
}
.pc:hover{
  transform:translateY(-8px);
  background:var(--wh);
  box-shadow:0 30px 60px rgba(0,0,0,0.08);
  border-color:var(--grn3);
}
.pc.hot{background:var(--dk);color:var(--wh)}
.pc-badge{position:absolute;top:-1px;left:50%;transform:translateX(-50%);background:var(--grn);color:#000;font-size:9px;font-weight:700;padding:3px 10px;border-radius:0 0 7px 7px;letter-spacing:1px}
.pc-plan{font-size:10px;color:rgba(0,0,0,.4);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:6px;margin-top:8px}
.pc.hot .pc-plan{color:rgba(255,255,255,.4)}
.pc-price{font-size:32px;font-weight:700;letter-spacing:-1px}
.pc-cur{font-size:14px;color:rgba(0,0,0,.4);font-weight:400}
.pc.hot .pc-cur{color:rgba(255,255,255,.4)}
.pc-per{font-size:13px;color:rgba(0,0,0,.4);margin-bottom:14px}
.pc.hot .pc-per{color:rgba(255,255,255,.35)}
.pc-div{border:none;border-top:1px solid rgba(0,0,0,.08);margin:12px 0}
.pc.hot .pc-div{border-top-color:rgba(255,255,255,.1)}
.pc-feats{list-style:none;display:flex;flex-direction:column;gap:10px;flex:1}
.pc-feats li{font-size:15px;color:rgba(0,0,0,.55);display:flex;gap:10px;line-height:1.4;font-family:var(--thai)}
.pc.hot .pc-feats li{color:rgba(255,255,255,.55)}
.pc-feats li::before{content:'✓';color:var(--grn);font-weight:700;flex-shrink:0}

/* CASE STUDY */
.cs-block{background:var(--lt);border-radius:16px;padding:32px;margin-top:40px;display:grid;grid-template-columns:1fr 1fr;gap:28px}
.svc-content.dark .cs-block{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07)}
.cs-eyebrow{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--grn);font-weight:500;margin-bottom:8px}
.cs-title{font-size:20px;font-weight:700;margin-bottom:8px}
.cs-desc{font-size:13px;color:rgba(0,0,0,.5);line-height:1.65;font-family:var(--thai)}
.svc-content.dark .cs-desc{color:var(--w3)}
.cs-approach{margin-top:14px}
.cs-ap-row{display:flex;gap:10px;padding:9px 0;border-bottom:1px solid rgba(0,0,0,.06);align-items:flex-start}
.svc-content.dark .cs-ap-row{border-bottom-color:rgba(255,255,255,.05)}
.cs-ap-row:last-child{border-bottom:none}
.cs-dot{width:5px;height:5px;background:var(--grn);border-radius:50%;margin-top:7px;flex-shrink:0}
.cs-txt{font-size:12px;color:rgba(0,0,0,.6);line-height:1.55;font-family:var(--thai)}
.svc-content.dark .cs-txt{color:var(--w2)}
.cs-metrics{display:flex;flex-direction:column;gap:9px}
.cs-met{background:var(--wh);border-radius:10px;padding:14px 18px;display:flex;align-items:center;gap:14px}
.svc-content.dark .cs-met{background:rgba(255,255,255,.05)}
.cs-met-icon{font-size:20px;flex-shrink:0}
.cs-met strong{display:block;font-size:14px;font-weight:600;color:var(--grn)}
.cs-met span{font-size:11px;color:rgba(0,0,0,.4);font-family:var(--thai)}
.svc-content.dark .cs-met span{color:var(--w3)}

/* INVEST BOX */
.invest-box{background:var(--lt);border-radius:12px;padding:24px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px;margin-top:20px}
.svc-content.dark .invest-box{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06)}
.inv-label{font-size:12px;color:rgba(0,0,0,.4);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}
.svc-content.dark .inv-label{color:var(--w3)}
.inv-val{font-size:32px;font-weight:700;color:var(--grn);letter-spacing:-1.5px}
.inv-sub{font-size:14px;color:rgba(0,0,0,.45);font-family:var(--thai)}
.svc-content.dark .inv-sub{color:var(--w3)}
.invest-box.v{grid-template-columns:1fr;gap:32px}
.invest-box.v > div{padding-bottom:24px;border-bottom:1px solid rgba(0,0,0,.06)}
.invest-box.v > div:last-child{border-bottom:none;padding-bottom:0}

/* BRANDING */
.brand-rows{display:flex;flex-direction:column}
.br-row{display:flex;gap:18px;padding:18px 0;border-bottom:1px solid rgba(0,0,0,.06)}
.svc-content.dark .br-row{border-bottom-color:rgba(255,255,255,.05)}
.br-row:last-child{border-bottom:none}
.br-n{font-size:28px;font-weight:700;color:rgba(0,0,0,.08);line-height:1;flex-shrink:0;width:36px}
.svc-content.dark .br-n{color:rgba(255,255,255,.06)}
.br-name{font-size:14px;font-weight:600;color:var(--grn);margin-bottom:3px}
.br-desc{font-size:12px;color:rgba(0,0,0,.45);line-height:1.55;font-family:var(--thai)}
.svc-content.dark .br-desc{color:var(--w3)}

/* PHOTO PROCESS */
.proc-row{display:grid;grid-template-columns:repeat(4,1fr);background:var(--lt);border-radius:12px;overflow:hidden;margin-top:16px}
.svc-content.dark .proc-row{background:rgba(255,255,255,.04)}
.proc-step{padding:20px;border-right:1px solid rgba(0,0,0,.06)}
.svc-content.dark .proc-step{border-right-color:rgba(255,255,255,.05)}
.proc-step:last-child{border-right:none}
.proc-n{font-size:32px;font-weight:700;color:rgba(34,197,94,.25);line-height:1}
.proc-name{font-size:16px;font-weight:700;margin-bottom:6px;color:var(--dk)}
.proc-desc{font-size:14px;color:rgba(0,0,0,.5);line-height:1.6;font-family:var(--thai)}
.svc-content.dark .proc-desc{color:var(--w3)}
.proc-row.v{grid-template-columns:1fr}
.proc-row.v .proc-step{border-right:none;border-bottom:1px solid rgba(0,0,0,.06);display:grid;grid-template-columns:60px 1fr;gap:20px;align-items:center}
.proc-row.v .proc-step:last-child{border-bottom:none}
.proc-row.v .proc-n{margin-bottom:0}

/* CONTACT */
.contact-page{padding-top:64px}
.contact-hero{position:relative;height:50vh;min-height:400px;display:flex;flex-direction:column;justify-content:center;padding:0 52px;background:var(--blk);overflow:hidden;color:var(--wh)}
.contact-hero-media{position:absolute;inset:0;z-index:0}
.contact-hero-media img{width:100%;height:100%;object-fit:cover;opacity:.35}
.contact-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top, rgba(0,0,0,0.8) 0%, rgba(0,0,0,0.3) 60%, transparent 100%);z-index:1}
.contact-hero-content{position:relative;z-index:2;max-width:800px}
.contact-hero h1{font-size:clamp(36px,5vw,60px);font-weight:700;letter-spacing:-2px;margin-bottom:14px;color:var(--wh)}
.contact-hero p{font-size:16px;color:rgba(255,255,255,0.7);max-width:460px;line-height:1.75;font-family:var(--thai)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;min-height:60vh}
.contact-form-side{padding:64px 52px;background:var(--wh)}
.contact-info-side{padding:64px 52px;background:var(--blk);color:var(--wh)}
.exp-in-contact{padding:80px 52px;background:var(--lt)}
.exp-grid-nc{display:grid;grid-template-columns:480px 1fr;gap:72px;align-items:start;margin-top:48px}
.exp-photo-nc{position:relative}
.exp-photo-nc img{width:100%;height:auto;display:block;object-fit:cover;object-position:top center}
.exp-overlay-card{position:absolute;bottom:68px;left:16px;right:100px;background:rgba(10,10,10,.85);backdrop-filter:blur(12px);border-radius:10px;padding:14px 16px}
.exp-card-tag{font-size:9px;color:var(--grn);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:3px;font-weight:500}
.exp-card-name{font-size:13px;font-weight:500;color:var(--wh)}
.exp-card-sub{font-size:11px;color:var(--w3);margin-top:2px;font-family:var(--thai)}
.tl-nc{display:grid;grid-template-columns:70px 1fr;padding:20px 0;border-bottom:1px solid rgba(0,0,0,.06)}
.tl-nc:last-child{border-bottom:none}
.tl-yr{font-size:22px;font-weight:700;color:var(--grn);line-height:1}
.tl-cat{font-size:10px;color:rgba(0,0,0,.35);margin-top:3px}
.tl-title{font-size:14px;font-weight:600;margin-bottom:4px}
.tl-body{font-size:13px;color:rgba(0,0,0,.5);line-height:1.65;font-family:var(--thai)}
.cf-label{font-size:11px;color:rgba(0,0,0,.5);letter-spacing:.5px;display:block;margin-bottom:6px;font-weight:500}
.cf-input,.cf-textarea,.cf-select{width:100%;background:var(--lt);border:1px solid rgba(0,0,0,.08);border-radius:8px;color:var(--dk);font-family:var(--thai);font-size:14px;padding:12px 16px;outline:none;transition:border-color .2s;appearance:none}
.cf-input:focus,.cf-textarea:focus,.cf-select:focus{border-color:var(--grn)}
.cf-textarea{min-height:120px;resize:vertical;line-height:1.6}
.cf-group{margin-bottom:18px}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cf-submit{width:100%;background:var(--dk);color:var(--wh);border:none;padding:18px;border-radius:999px;font-family:var(--sans);font-size:16px;font-weight:700;cursor:pointer;transition:all .2s;letter-spacing:.2px;margin-top:8px}
.cf-submit:hover{background:var(--grn);color:#000}
.ci-item{display:flex;gap:14px;align-items:flex-start;margin-bottom:24px}
.ci-icon{width:40px;height:40px;background:rgba(255,255,255,.06);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ci-icon svg{width:18px;height:18px;stroke:var(--grn);fill:none;stroke-width:1.5}
.ci-label{font-size:11px;color:var(--w3);margin-bottom:3px;letter-spacing:.5px}
.ci-val{font-size:14px;color:var(--wh);font-weight:500}

/* BLOG */
.blog-page{padding-top:64px;min-height:100vh;background:var(--wh)}
.blog-hero{padding:80px 52px 48px;background:var(--lt)}
.blog-hero h1{font-size:clamp(32px,4.5vw,54px);font-weight:700;letter-spacing:-1.5px;margin-bottom:10px}
.blog-coming{padding:80px 52px;text-align:center}
.blog-coming h2{font-size:28px;font-weight:700;margin-bottom:8px;color:var(--dk)}
.blog-coming p{color:rgba(0,0,0,.4);font-family:var(--thai);font-size:15px}

/* FOOTER */
footer{background:var(--blk);color:var(--wh);padding:52px 52px 28px}
.footer-top{display:grid;grid-template-columns:280px 1fr 1fr 1fr;gap:48px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.06)}
.f-brand{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.f-brand-txt{font-size:13px;font-weight:700;letter-spacing:2px}
.f-brand-txt em{color:var(--grn);font-style:normal}
.f-tagline{font-size:13px;color:var(--w3);line-height:1.65;font-family:var(--thai)}
.f-col-title{font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--w3);margin-bottom:16px}
.f-links{display:flex;flex-direction:column;gap:9px}
.f-link{font-size:13px;color:rgba(255,255,255,.45);transition:color .2s;cursor:pointer}
.f-link:hover{color:var(--wh)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;flex-wrap:wrap;gap:10px}
.f-copy{font-size:12px;color:rgba(255,255,255,.25)}
.f-social{display:flex;gap:16px}
.f-soc{width:34px;height:34px;background:rgba(255,255,255,.06);border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background .2s;cursor:pointer}
.f-soc:hover{background:rgba(255,255,255,.12)}
.f-soc svg{width:16px;height:16px;color:var(--w3);fill:currentColor;stroke-width:0}

/* UTILITY */
.fi{opacity:0;transform:translateY(20px);transition:opacity .6s,transform .6s}
.fi.v{opacity:1;transform:translateY(0)}
.section-tag{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--grn);font-weight:500;margin-bottom:10px}
.section-title-lt{font-size:clamp(28px,3.5vw,44px);font-weight:700;letter-spacing:-1.5px;margin-bottom:10px;color:var(--dk)}
.section-title-dk{font-size:clamp(28px,3.5vw,44px);font-weight:700;letter-spacing:-1.5px;margin-bottom:10px;color:var(--wh)}
.section-sub-lt{font-size:14px;color:rgba(0,0,0,.45);max-width:520px;line-height:1.75;font-family:var(--thai)}
.section-sub-dk{font-size:14px;color:var(--w3);max-width:520px;line-height:1.75;font-family:var(--thai)}

/* RESPONSIVE */
@media(max-width:960px){
  nav{padding:0 20px}
  .nav-menu{display:none}
  nav .nav-cta{display:none}
  .hamburger{display:flex}
  .hero,.clients-home,.svc-overview,.why-sec,.cta-home,.svc-content,
  .contact-hero,.exp-in-contact,.contact-form-side,.contact-info-side,
  .blog-hero,.blog-coming,footer{padding-left:20px;padding-right:20px}
  .footer-top{padding-left:20px;padding-right:20px}
  .hero h1{font-size:42px;letter-spacing:-2px}
  .svc-ov-grid,.why-grid,.svc-2col,.cs-block,.price-row,.phase-row,
  .invest-box,.proc-row,.exp-grid-nc,.contact-grid,.footer-top{grid-template-columns:1fr}
  .svc-2col.rev{direction:ltr}
  .clients-logos{
    gap: 0;
    flex-wrap: nowrap;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    justify-content: flex-start;
    -ms-overflow-style: none;
    scrollbar-width: none;
    padding: 0 10px;
  }
  .clients-logos::-webkit-scrollbar { display: none; }
  .cl-logo{
    flex: 0 0 33.33%;
    width: 33.33%;
    height: 70px;
    scroll-snap-align: center;
    padding: 0 10px;
    opacity: 1;
  }
  .cl-logo img { filter: none; }
  .svc-hero{padding:40px 20px;align-items:center;justify-content:center}
  .svc-hero-content{text-align:center}
  .svc-hero-sub{margin-left:auto;margin-right:auto}
  .stats-grid{grid-template-columns:1fr 1fr}
}

/* FREESTYLE SECTION IMPROVEMENTS */
.freestyle-section { padding: 100px 52px; background: var(--wh); position: relative; }
.freestyle-section.dark { background: var(--blk); color: var(--wh); }
.fs-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: stretch; margin-top: 48px; }
.fs-text-card { 
  background: var(--lt); 
  padding: 44px; 
  border-radius: 24px; 
  border: 1px solid rgba(0,0,0,0.04); 
  display: flex; 
  flex-direction: column; 
  justify-content: center; 
  transition: transform 0.4s;
}
.fs-text-card:hover { transform: translateY(-5px); }
.svc-content.dark .fs-text-card { background: rgba(255,255,255,0.03); border-color: rgba(255,255,255,0.06); }
.fs-text { font-family: var(--thai); font-size: 16px; color: rgba(0,0,0,0.6); line-height: 1.8; }
.svc-content.dark .fs-text { color: var(--w3); }
.fs-img-card { 
  position: relative; 
  border-radius: 24px; 
  overflow: hidden; 
  background: var(--lt); 
  border: 1px solid rgba(0,0,0,0.04); 
  min-height: 420px; 
  transition: all 0.4s;
}
.fs-img-card:hover { transform: translateY(-5px); box-shadow: 0 20px 40px rgba(0,0,0,0.05); }
.svc-content.dark .fs-img-card { background: rgba(255,255,255,0.03); border-color: rgba(255,255,255,0.06); }
.fs-img-card img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.8s; }
.fs-img-card:hover img { transform: scale(1.08); }
.fs-placeholder { 
  width: 100%; 
  height: 100%; 
  display: flex; 
  align-items: center; 
  justify-content: center; 
  color: rgba(0,0,0,0.25); 
  font-size: 13px; 
  letter-spacing: 1px; 
  text-align: center; 
  padding: 40px; 
  font-family: var(--thai);
}
.svc-content.dark .fs-placeholder { color: rgba(255,255,255,0.1); }

@media(max-width:960px) {
  .freestyle-section { padding: 60px 20px 80px; }
  .fs-grid { grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 32px; }
  .fs-text-card { padding: 20px; border-radius: 16px; min-height: 200px; }
  .fs-text { font-size: 13.5px; line-height: 1.6; }
  .fs-img-card { min-height: 200px; border-radius: 16px; }
  .fs-placeholder { padding: 20px; font-size: 11px; }
}

/* ── BLOG ─────────────────────────────────────────────── */
.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
  gap: 40px;
  padding: 80px 52px 100px;
  background: var(--wh);
}

.bc {
  background: #fff;
  border-radius: 28px; /* Large modern radius */
  overflow: hidden;
  cursor: pointer;
  border: 1px solid rgba(0,0,0,0.04);
  box-shadow: 0 2px 4px rgba(0,0,0,0.02), 0 10px 20px rgba(0,0,0,0.04);
  transition: all 0.5s cubic-bezier(0.16, 1, 0.3, 1);
  display: flex;
  flex-direction: column;
  position: relative;
}

.bc:hover {
  transform: translateY(-10px) scale(1.01);
  box-shadow: 0 20px 40px rgba(0,0,0,0.08), 0 0 0 1px rgba(34,197,94,0.1);
}

.bc-img {
  width: 100%;
  aspect-ratio: 16/10;
  overflow: hidden;
  background: #f7f6f5;
  position: relative;
  flex-shrink: 0;
}

.bc-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 1.2s cubic-bezier(0.16, 1, 0.3, 1);
}

.bc:hover .bc-img img {
  transform: scale(1.1);
}

.bc-pill {
  position: absolute;
  top: 18px;
  left: 18px;
  background: rgba(255, 255, 255, 0.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  color: var(--dk);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: 6px 16px;
  border-radius: 40px;
  z-index: 2;
  box-shadow: 0 4px 12px rgba(0,0,0,0.06);
  border: 1px solid rgba(255,255,255,0.3);
}

.bc-body {
  padding: 32px 32px 40px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.bc-date {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  color: rgba(0,0,0,0.35);
  letter-spacing: 0.5px;
  margin-bottom: 14px;
  font-weight: 500;
  text-transform: uppercase;
}

.bc-date::before {
  content: '';
  width: 6px;
  height: 6px;
  background: var(--grn);
  border-radius: 50%;
}

.bc-title {
  font-family: var(--sans);
  font-size: 22px;
  font-weight: 700;
  color: var(--dk);
  line-height: 1.35;
  letter-spacing: -0.8px;
  margin-bottom: 16px;
  transition: color 0.3s;
}

.bc:hover .bc-title {
  color: var(--grn);
}

.bc-desc {
  font-size: 14.5px;
  color: rgba(0,0,0,0.5);
  line-height: 1.75;
  font-family: var(--thai);
  margin-bottom: 28px;
}

.bc-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 24px;
  border-top: 1px solid rgba(0,0,0,0.05);
  margin-top: auto;
}

.bc-rm {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--dk);
  display: flex;
  align-items: center;
  gap: 8px;
  transition: all 0.3s;
}

.bc-rm svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2.5;
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.bc:hover .bc-rm {
  color: var(--grn);
}

.bc:hover .bc-rm svg {
  transform: translateX(6px);
}

.bc-admin {
  display: flex;
  gap: 8px;
}

.bc-admin a {
  padding: 6px 14px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 600;
  text-decoration: none;
  background: rgba(0,0,0,0.04);
  color: rgba(0,0,0,0.55);
  transition: all 0.2s;
}

.bc-admin a:hover {
  background: rgba(0,0,0,0.08);
  color: var(--dk);
}

.blog-coming {
  padding: 100px 52px;
  text-align: center;
  background: var(--lt);
}

@media(max-width:960px) {
  .blog-grid {
    grid-template-columns: 1fr;
    padding: 40px 20px 80px;
    gap: 32px;
  }
}

/* ── TESTIMONIALS HOME ────────────────────────────────── */
.testimonials-home {
  padding: 100px 52px;
  background: var(--blk);
}
.test-grid {
  display: flex;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  gap: 32px;
  max-width: 1244px; /* 3 cards + gaps */
  margin: 0 auto;
  padding: 20px 0 40px;
  -ms-overflow-style: none;
  scrollbar-width: none;
  scroll-behavior: smooth;
  justify-content: start; /* Changed from center to avoid scroll issues on overflow */
}
.test-grid::-webkit-scrollbar { display: none; }
.test-card {
  position: relative;
  aspect-ratio: 9/16;
  background: #111;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(0,0,0,0.4);
  cursor: pointer;
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  flex: 0 0 calc(33.333% - 22px);
  scroll-snap-align: center;
  min-width: 300px;
}
.test-card:hover {
  transform: translateY(-8px) scale(1.02);
}
.test-vid {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.8;
  transition: opacity 0.3s;
}
.test-card:hover .test-vid {
  opacity: 1;
}
.test-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,0.1);
  font-size: 11px;
  letter-spacing: 1px;
}
.test-play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 64px;
  height: 64px;
  background: rgba(255,255,255,0.1);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s;
  z-index: 2;
  border: 1px solid rgba(255,255,255,0.1);
}
.test-play svg {
  width: 28px;
  height: 28px;
  fill: #ff3b30; /* Red play button as requested in screenshot */
  margin-left: 4px;
}
.test-card:hover .test-play {
  background: var(--grn);
  transform: translate(-50%, -50%) scale(1.1);
}
.test-card:hover .test-play svg {
  fill: #000;
}
.test-overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 40px 24px 24px;
  background: linear-gradient(to top, rgba(0,0,0,0.8), transparent);
  z-index: 1;
}
.test-msg {
  color: #fff;
  font-size: 15px;
  font-weight: 500;
  line-height: 1.4;
  font-family: var(--thai);
  text-shadow: 0 2px 4px rgba(0,0,0,0.4);
}

.test-carousel-container {
  position: relative;
  width: 100%;
}
.test-dots {
  display: flex;
  justify-content: center;
  gap: 12px;
  margin-top: 24px;
}
.test-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,0.2);
  border: none;
  padding: 0;
  cursor: pointer;
  transition: all 0.3s;
}
.test-dot.active {
  background: var(--grn);
  transform: scale(1.2);
}

@media(max-width:1100px) {
  .test-card {
    flex: 0 0 calc(50% - 16px); /* 2 items on tablets */
  }
}

.test-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 50px;
  height: 50px;
  background: rgba(255,255,255,0.05);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 10;
  transition: all 0.3s;
  color: #fff;
}
.test-nav:hover {
  background: var(--grn);
  color: #000;
  border-color: var(--grn);
  transform: translateY(-50%) scale(1.1);
}
.test-nav svg { width: 24px; height: 24px; stroke: currentColor; fill: none; stroke-width: 2.5; }
.test-nav.prev { left: -20px; }
.test-nav.next { right: -20px; }

@media(max-width:1380px) {
  .test-nav.prev { left: 10px; }
  .test-nav.next { right: 10px; }
}
@media(max-width:768px) {
  .test-nav { display: none; }
}

@media(max-width:768px) {
  .test-grid {
    gap: 16px;
    padding: 20px;
    justify-content: flex-start;
  }
  .test-card {
    flex: 0 0 280px;
    min-width: 280px;
  }
  .test-dots { gap: 8px; }
}

/* ── PORTFOLIO HOME ───────────────────────────────────── */
.portfolio-home {
  padding: 100px 52px;
  background: var(--wh);
}
.port-grid { 
  display: grid; 
  grid-template-columns: repeat(4, 1fr); 
  grid-auto-rows: 250px; 
  grid-auto-flow: dense; 
  gap: 16px; 
  margin-top: 48px;
}
.port-item.port-hidden { display: none; }
.port-item { 
  position: relative; 
  overflow: hidden; 
  background: #eee; 
  border-radius: 0; 
  border: 1px solid rgba(0,0,0,.03);
}
.port-btn-wrap {
  text-align: center;
  margin-top: 60px;
  position: relative;
  z-index: 10;
  clear: both;
}
.port-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}
.port-item:hover img {
  transform: scale(1.05);
}

/* Aspect Ratios */
.ratio-1-1 { aspect-ratio: 1/1; }
.ratio-4-5 { aspect-ratio: 4/5; }
.ratio-16-9 { aspect-ratio: 16/9; }

/* Masonry Helpers */
.w2 { grid-column: span 2; }
.h2 { grid-row: span 2; }

@media(max-width:960px) {
  .port-grid {
    grid-template-columns: 1fr;
    grid-auto-rows: auto;
    padding: 0;
  }
  .port-item.w2, .port-item.h2 { grid-column: auto; grid-row: auto; }
}

/* ── HERO SLIDER ────────────────────────────────────────── */
.hero-media-container {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.hero-slider {
  width: 100%;
  height: 100%;
  position: relative;
}
.hero-slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 1s ease-in-out;
}
.hero-slide.active { opacity: 1; }
.hero-static-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
}
.hero-static-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
}
[data-img] { cursor: pointer; }
[data-img]:hover { opacity: 0.85; transition: opacity 0.2s; }

/* VIDEO PORTAL (LIGHTBOX) */
.vid-portal {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.95);
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity .4s cubic-bezier(0.16, 1, 0.3, 1);
  backdrop-filter: blur(10px);
}
.vid-portal.open {
  opacity: 1;
  pointer-events: auto;
}
.v-port-inner {
  width: 90%;
  max-width: 450px; /* Portrait style for vertical videos */
  position: relative;
  transform: scale(0.9);
  transition: transform .4s cubic-bezier(0.16, 1, 0.3, 1);
}
.vid-portal.open .v-port-inner {
  transform: scale(1);
}
.v-port-inner video {
  width: 100%;
  border-radius: 24px;
  box-shadow: 0 30px 60px rgba(0,0,0,0.5);
  display: block;
}
.v-port-close {
  position: absolute;
  top: -60px;
  right: 0;
  background: rgba(255,255,255,.1);
  border: none;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.1);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: #fff;
  transition: all .2s;
}
.v-port-close:hover {
  background: var(--grn);
  color: #000;
  transform: rotate(90deg);
}
.v-port-close svg {
  width: 20px;
  height: 20px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2.5;
}



