/* ── Local fonts ── */
@import url('https://fonts.googleapis.com/css2?family=Kanit:wght@300;400;500;600;700&display=swap');

@font-face{
  font-family:'SourceSans3';
  src:url('../fonts/Source_Sans_3/static/SourceSans3-Bold.ttf') format('truetype');
  font-weight:700;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'Anuphan';
  src:url('../fonts/Anuphan/static/Anuphan-Light.ttf') format('truetype');
  font-weight:300;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'Anuphan';
  src:url('../fonts/Anuphan/static/Anuphan-Regular.ttf') format('truetype');
  font-weight:400;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'Anuphan';
  src:url('../fonts/Anuphan/static/Anuphan-Medium.ttf') format('truetype');
  font-weight:500;font-style:normal;font-display:swap;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f4f4f6;
  --grey:#dcdcdf;
  --dark:#1f1f22;
  --muted:#8a8d92;
  --pink:#e94389;
  --pink-2:#a93c9b;
  --blue:#1f8af0;
  --blue-deep:#1357c6;
  --cyan:#15b3d6;
  --yellow:#f5b41a;
  --line:#d8d8dc;
}
html,body{background:var(--bg);color:var(--dark);font-family:'Anuphan','SourceSans3',sans-serif;font-weight:300;-webkit-font-smoothing:antialiased}
body{overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
:lang(th),.thai-text{font-family:'Kanit','Anuphan',sans-serif!important;letter-spacing:0!important}

.stage{position:relative;width:100%;max-width:1920px;margin:0 auto;background:var(--bg)}

/* ============ NAV ============ */
nav.top{
  position:fixed;top:0;left:0;right:0;z-index:200;
  height:96px;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  padding:0 60px;
  background:rgba(244,244,246,.85);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(0,0,0,.04);
}
.menu-left{display:flex;align-items:center;gap:36px}
.ic-menu{width:26px;height:18px;display:none;flex-direction:column;justify-content:space-between;cursor:pointer;background:none;border:none;padding:0}
.ic-menu span{display:block;height:2px;background:var(--dark);width:100%;transition:transform .3s,opacity .3s}
.ic-menu span:nth-child(2){width:70%}
body.menu-open .ic-menu span:nth-child(1){transform:translateY(8px) rotate(45deg)}
body.menu-open .ic-menu span:nth-child(2){opacity:0}
body.menu-open .ic-menu span:nth-child(3){transform:translateY(-8px) rotate(-45deg);width:100%}
.menu-links{display:flex;gap:28px;list-style:none;font-family:'Anuphan',sans-serif;font-size:13px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;color:var(--dark)}
.menu-links a{position:relative;padding:6px 0}
.menu-links a:hover{color:var(--pink)}
.menu-links a.active{color:var(--pink)}
.menu-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:var(--pink)}
.brand{justify-self:center;display:flex;flex-direction:column;align-items:center;gap:4px}
.menu-right{display:flex;justify-content:flex-end;align-items:center}
.ic-search{width:18px;height:18px;border:2px solid var(--dark);border-radius:50%;position:relative}
.ic-search::after{content:"";position:absolute;width:8px;height:2px;background:var(--dark);right:-6px;bottom:1px;transform:rotate(45deg);transform-origin:left}

/* ============ HERO (homepage) ============ */
.hero{position:relative;height:1140px;overflow:hidden;background:#f4f4f6}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(to right,#f4f4f6 0%,#f4f4f6 60%,#dcdcdf 60%,#dcdcdf 100%)}
.hero-photo{position:absolute;left:240px;top:240px;width:1260px;height:840px;background-size:cover;background-position:top center;box-shadow:0 30px 80px rgba(20,30,80,.18);transform:translate3d(0,0,0);will-change:transform}
.hero-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,rgba(233,67,137,.55) 0%,rgba(169,60,155,.45) 35%,rgba(31,138,240,.65) 100%);mix-blend-mode:multiply}
.hero-social{position:absolute;left:60px;top:280px;display:flex;flex-direction:column;gap:36px;z-index:5}
.hero-social a{font-size:14px;color:var(--dark);opacity:.7;transition:opacity .2s}
.hero-social a:hover{opacity:1}
.slide-num{position:absolute;left:55px;top:660px;display:flex;flex-direction:column;align-items:center;gap:80px;z-index:5;font-family:'SourceSans3',sans-serif}
.slide-num .bar{width:2px;height:64px;background:var(--dark);opacity:.6}
.slide-num .num{font-size:20px;font-weight:700}
.hero-text{position:absolute;left:240px;top:540px;z-index:6;color:#1f1f22}
.hero-text .eyebrow-line{width:60px;height:3px;background:#1f1f22;margin-bottom:32px;opacity:.85}
.hero-text h1{font-family:'SourceSans3',sans-serif;font-weight:700;font-size:130px;line-height:.96;letter-spacing:-2px;color:#1f1f22;max-width:860px}
.hero-text .sub{margin-top:44px;font-family:'Anuphan',sans-serif;font-size:11px;letter-spacing:5px;font-weight:500;color:#1f1f22;text-transform:uppercase}
.hero-pagination{position:absolute;right:50px;top:790px;z-index:5;display:flex;flex-direction:column;align-items:center;gap:14px;font-family:'SourceSans3',sans-serif;font-size:18px}
.hero-pagination .pg{color:var(--muted);opacity:.55}
.hero-pagination .pg.active{color:#1f1f22;opacity:1;display:flex;align-items:center;gap:14px}
.hero-pagination .pg.active::after{content:"";display:block;width:60px;height:2px;background:#1f1f22}
.hero-buttons{position:absolute;left:60px;bottom:60px;display:flex;z-index:6}
.btn-profile{width:262px;height:112px;background:#e94389;display:flex;align-items:center;justify-content:center;color:#fff;font-family:'Anuphan',sans-serif;font-size:11px;letter-spacing:4px;font-weight:500;text-transform:uppercase;transition:background .2s}
.btn-profile:hover{background:#d33279}
.btn-play{width:112px;height:112px;background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(20,30,80,.08)}
.btn-play .tri{width:0;height:0;border-style:solid;border-width:14px 0 14px 22px;border-color:transparent transparent transparent #1f1f22;margin-left:6px}

/* ============ PAGE HERO (sub pages) ============ */
.page-hero{position:relative;height:520px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;color:#fff;overflow:hidden;background:#1f1f22}
.page-hero .bg{position:absolute;inset:-6%;background-size:cover;background-position:center;z-index:0;will-change:transform;transition:transform .55s cubic-bezier(.16,1,.3,1)}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,rgba(233,67,137,.55) 0%,rgba(169,60,155,.45) 35%,rgba(31,138,240,.65) 100%);mix-blend-mode:multiply;z-index:1}
.page-hero .inner{position:relative;z-index:2;padding:0 24px;margin-top:60px}
.page-hero h1{font-family:'SourceSans3',sans-serif;font-weight:700;font-size:84px;line-height:1;letter-spacing:-1px}
.page-hero .crumbs{margin-top:22px;font-family:'Anuphan',sans-serif;font-weight:300;font-size:11px;letter-spacing:4px;text-transform:uppercase;opacity:.9}
.page-hero .crumbs a{opacity:.85}
.page-hero .crumbs a:hover{opacity:1}
.page-hero .crumbs .sep{display:inline-block;margin:0 12px;opacity:.5}

/* ============ TALENT GRID ============ */
.talent{position:relative;background:#fff;padding:100px 60px 130px}
.tabs{display:flex;justify-content:center;gap:60px;margin-bottom:80px;font-family:'Anuphan',sans-serif;font-size:11px;letter-spacing:3px;font-weight:500;text-transform:uppercase;color:var(--muted)}
.tabs .tab{padding-bottom:14px;cursor:pointer;position:relative}
.tabs .tab.active{color:var(--dark)}
.tabs .tab.active::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--dark)}
.talent-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;max-width:1680px;margin:0 auto}
.talent-card{position:relative;aspect-ratio:422/493;overflow:hidden;background:#222;cursor:pointer}
.talent-card .bg{position:absolute;inset:-8% -8%;background-size:cover;background-position:center;transition:transform .8s cubic-bezier(.2,.7,.2,1);will-change:transform}
.talent-card:hover .bg{transform:scale(1.06)}
.talent-card .overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 50%,rgba(0,0,0,.55) 100%);opacity:0;transition:opacity .35s}
.talent-card:hover .overlay{opacity:1}
.talent-card .arrow{position:absolute;top:24px;right:24px;width:44px;height:44px;border:2px solid #fff;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;opacity:0;transform:translate(-6px,6px);transition:opacity .35s,transform .35s}
.talent-card:hover .arrow{opacity:1;transform:translate(0,0)}
.talent-card .info{position:absolute;left:0;right:0;bottom:30px;text-align:center;color:#fff;opacity:0;transform:translateY(8px);transition:opacity .35s,transform .35s}
.talent-card:hover .info{opacity:1;transform:translateY(0)}
.talent-card .info .name{font-family:'SourceSans3',sans-serif;font-weight:700;font-size:24px}
.talent-card .info .role{font-family:'Anuphan',sans-serif;font-weight:300;font-size:10px;letter-spacing:3px;margin-top:6px;opacity:.85}

.btn-explore{margin:60px auto 0;display:flex;align-items:center;justify-content:center;width:222px;height:62px;background:#f5b41a;color:#fff;font-family:'Anuphan',sans-serif;font-size:11px;letter-spacing:3px;font-weight:500;text-transform:uppercase;border-radius:36px;cursor:pointer;transition:transform .2s,background .2s;border:none}
.btn-explore:hover{background:#e8a90c;transform:translateY(-2px)}

/* ============ NEWS SECTION (homepage) ============ */
.news{position:relative;background:#fff;padding:60px 60px 120px}
.news h2{text-align:center;font-family:'SourceSans3',sans-serif;font-weight:700;font-size:48px;color:#1f1f22}
.news h2 + .deco{width:150px;height:3px;background:#e94389;margin:30px auto 70px}
.small-news{display:grid;grid-template-columns:repeat(3,1fr);gap:50px;max-width:1680px;margin:0 auto 80px}
.news-item{display:flex;gap:24px;align-items:stretch}
.news-item .thumb{width:210px;height:140px;background-size:cover;background-position:center;flex-shrink:0;background-color:#1f8af0;position:relative}
.news-item .thumb.video::after{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:0;height:0;border-style:solid;border-width:10px 0 10px 16px;border-color:transparent transparent transparent #fff}
.news-item .body{display:flex;flex-direction:column;justify-content:space-between;padding:6px 0}
.news-item h3{font-family:'SourceSans3',sans-serif;font-weight:700;font-size:20px;line-height:1.3;color:#1f1f22}
.news-item h3.link{color:#1f8af0}
.news-item .date{font-family:'Anuphan',sans-serif;font-weight:300;font-size:10px;letter-spacing:2px;color:var(--muted);text-transform:uppercase}

.news-main{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;max-width:1680px;margin:0 auto}
.featured{position:relative;grid-column:span 2;height:540px;overflow:hidden;display:grid;grid-template-columns:1fr 1.2fr}
.featured .left{background:#1f8af0;color:#fff;padding:50px 40px;display:flex;flex-direction:column;justify-content:space-between}
.featured .play{width:46px;height:46px;border:2px solid #fff;border-radius:50%;display:flex;align-items:center;justify-content:center}
.featured .play::after{content:"";width:0;height:0;border-style:solid;border-width:7px 0 7px 11px;border-color:transparent transparent transparent #fff;margin-left:3px}
.featured .left h3{font-family:'SourceSans3',sans-serif;font-weight:700;font-size:32px;line-height:1.2}
.featured .left .date{font-family:'Anuphan',sans-serif;font-weight:300;font-size:10px;letter-spacing:2px;opacity:.85;text-transform:uppercase}
.featured .right{position:relative;overflow:hidden}
.featured .right .bg{position:absolute;inset:-6%;background-size:cover;background-position:center;will-change:transform;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.featured .badge{position:absolute;top:0;left:50%;transform:translateX(-50%);background:#f5b41a;color:#fff;padding:14px 36px;font-family:'Anuphan',sans-serif;font-size:11px;letter-spacing:3px;font-weight:500;text-transform:uppercase}

.news-slide{position:relative;height:540px;overflow:hidden;background:#222}
.news-slide .bg{position:absolute;inset:-6%;background-size:cover;background-position:center;will-change:transform;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.news-slide .dots{position:absolute;right:30px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:14px;z-index:2}
.news-slide .dots span{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.4)}
.news-slide .dots span.active{width:10px;height:10px;background:#fff;box-shadow:0 0 0 2px rgba(255,255,255,.4)}

.news-bottom{display:grid;grid-template-columns:1fr 1fr 1fr;gap:40px;max-width:1680px;margin:40px auto 0}
.big-card{display:flex;flex-direction:column;gap:24px}
.big-card .img{height:300px;background-size:cover;background-position:center;background-color:#222}
.big-card h3{font-family:'SourceSans3',sans-serif;font-weight:700;font-size:24px;line-height:1.25;color:#1f1f22}
.big-card .date{font-family:'Anuphan',sans-serif;font-weight:300;font-size:10px;letter-spacing:2px;color:var(--muted);text-transform:uppercase}

.video-card{position:relative;height:520px;overflow:hidden;display:flex;align-items:flex-end;justify-content:flex-start;padding:40px;background:#222}
.video-card .bg{position:absolute;inset:-6%;background-size:cover;background-position:center;z-index:0;will-change:transform;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.video-card::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 30%,rgba(0,0,0,.45) 100%);z-index:1}
.video-card .play-row{position:relative;z-index:2;display:flex;align-items:center;gap:18px;color:#fff}
.video-card .play-circ{width:90px;height:90px;border-radius:50%;background:rgba(255,255,255,.18);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;border:2px solid rgba(255,255,255,.6)}
.video-card .play-circ::after{content:"";width:0;height:0;border-style:solid;border-width:10px 0 10px 16px;border-color:transparent transparent transparent #fff;margin-left:4px}
.video-card .label{font-family:'Anuphan',sans-serif;font-size:11px;letter-spacing:3px;font-weight:500;text-transform:uppercase}
.video-card .v-dots{position:absolute;right:30px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:14px;z-index:2}
.video-card .v-dots span{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.4)}
.video-card .v-dots span.active{width:10px;height:10px;background:#fff}

/* ============ FOOTER ============ */
footer{background:#fff;padding:48px 60px 40px;border-top:1px solid var(--line)}
.footer-row{display:flex;align-items:center;justify-content:space-between;max-width:1800px;margin:0 auto 24px}
.footer-brand{display:flex;align-items:center;gap:16px}
.footer-newsletter{display:flex;align-items:center;gap:14px;font-family:'Anuphan',sans-serif;font-size:11px;letter-spacing:3px;font-weight:500;text-transform:uppercase;color:var(--muted)}
.footer-newsletter::before{content:"";width:1px;height:34px;background:var(--line);margin-right:14px}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:18px;border-top:1px solid var(--line);max-width:1800px;margin:0 auto;font-family:'Anuphan',sans-serif;font-size:11px;color:var(--muted)}
.footer-social{display:flex;gap:22px}
.footer-social a{color:var(--muted)}

/* ============ MOBILE DRAWER ============ */
.mobile-drawer{position:fixed;top:0;right:0;bottom:0;width:min(360px,82vw);z-index:190;background:#fff;transform:translateX(100%);transition:transform .45s cubic-bezier(.7,0,.2,1);box-shadow:-12px 0 60px rgba(0,0,0,.12);padding:120px 40px 40px;display:flex;flex-direction:column;gap:6px}
body.menu-open .mobile-drawer{transform:translateX(0)}
.mobile-drawer a{font-family:'Anuphan',sans-serif;font-weight:500;font-size:15px;letter-spacing:2.5px;text-transform:uppercase;color:var(--dark);padding:18px 0;border-bottom:1px solid var(--line)}
.mobile-drawer a:hover{color:var(--pink)}
.mobile-drawer a.active{color:var(--pink)}
.drawer-scrim{position:fixed;inset:0;z-index:180;background:rgba(20,20,30,.35);opacity:0;pointer-events:none;transition:opacity .35s}
body.menu-open .drawer-scrim{opacity:1;pointer-events:auto}

/* ============ CLIENTS PAGE ============ */
.section{padding:100px 60px;background:#fff}
.section.alt{background:var(--bg)}
.section-head{text-align:center;max-width:760px;margin:0 auto 70px}
.section-head .eyebrow{font-family:'Anuphan',sans-serif;font-weight:500;font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--pink);margin-bottom:18px}
.section-head h2{font-family:'SourceSans3',sans-serif;font-weight:700;font-size:48px;color:#1f1f22;line-height:1.05}
.section-head p{font-family:'Anuphan',sans-serif;font-weight:300;font-size:16px;line-height:1.7;color:var(--muted);margin-top:22px}

.client-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;max-width:1680px;margin:0 auto;border-top:1px solid var(--line);border-left:1px solid var(--line)}
.client-tile{aspect-ratio:5/3;display:flex;align-items:center;justify-content:center;border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff;position:relative;overflow:hidden;transition:background .3s}
.client-tile:hover{background:#f4f4f6}
.client-tile .name{font-family:'SourceSans3',sans-serif;font-weight:700;font-size:22px;letter-spacing:.5px;color:#1f1f22;transition:transform .35s}
.client-tile:hover .name{transform:translateY(-6px)}
.client-tile .industry{position:absolute;left:0;right:0;bottom:18px;text-align:center;font-family:'Anuphan',sans-serif;font-weight:300;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);opacity:0;transition:opacity .35s}
.client-tile:hover .industry{opacity:1}

.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;max-width:1680px;margin:0 auto}
.testimonial{background:#fff;padding:42px 36px;border:1px solid var(--line);position:relative}
.testimonial .quote{font-family:'SourceSans3',sans-serif;font-weight:700;font-size:80px;color:var(--pink);line-height:.6;margin-bottom:14px}
.testimonial p{font-family:'Anuphan',sans-serif;font-weight:300;font-size:15px;line-height:1.7;color:var(--dark);margin-bottom:28px}
.testimonial .person{display:flex;align-items:center;gap:14px}
.testimonial .person .av{width:48px;height:48px;border-radius:50%;background-size:cover;background-position:center;background-color:var(--grey)}
.testimonial .person .who{font-family:'SourceSans3',sans-serif;font-weight:700;font-size:15px}
.testimonial .person .role{font-family:'Anuphan',sans-serif;font-weight:300;font-size:11px;color:var(--muted);letter-spacing:2px;text-transform:uppercase}

/* ============ NEWS LISTING PAGE ============ */
.news-filters{display:flex;justify-content:center;gap:36px;flex-wrap:wrap;margin-bottom:60px;font-family:'Anuphan',sans-serif;font-size:12px;letter-spacing:2.5px;font-weight:500;text-transform:uppercase;color:var(--muted)}
.news-filters .f{padding:8px 4px;cursor:pointer;border-bottom:2px solid transparent;transition:color .2s,border-color .2s}
.news-filters .f.active,.news-filters .f:hover{color:var(--dark);border-color:var(--pink)}
.news-list{display:grid;grid-template-columns:repeat(3,1fr);gap:50px 32px;max-width:1680px;margin:0 auto}
.news-card{display:flex;flex-direction:column;gap:18px;cursor:pointer}
.news-card .img{aspect-ratio:5/3;background-size:cover;background-position:center;background-color:var(--grey);overflow:hidden}
.news-card .img .bg{width:100%;height:100%;background-size:cover;background-position:center;transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.news-card:hover .img .bg{transform:scale(1.05)}
.news-card .cat{font-family:'Anuphan',sans-serif;font-weight:500;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--pink)}
.news-card h3{font-family:'SourceSans3',sans-serif;font-weight:700;font-size:22px;line-height:1.3;color:#1f1f22}
.news-card .meta{font-family:'Anuphan',sans-serif;font-weight:300;font-size:11px;letter-spacing:2px;color:var(--muted);text-transform:uppercase}
.pagination{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:80px;font-family:'SourceSans3',sans-serif;font-weight:700}
.pagination .p{width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);transition:color .2s}
.pagination .p:hover{color:var(--dark)}
.pagination .p.active{color:#fff;background:var(--pink)}

/* ============ ABOUT PAGE ============ */
.story{display:grid;grid-template-columns:1.1fr 1fr;gap:80px;max-width:1680px;margin:0 auto;align-items:center}
.story .imgwrap{position:relative;aspect-ratio:5/6;overflow:hidden}
.story .imgwrap .bg{position:absolute;inset:-6%;background-size:cover;background-position:center;will-change:transform;transition:transform .55s cubic-bezier(.16,1,.3,1)}
.story .copy h2{font-family:'SourceSans3',sans-serif;font-weight:700;font-size:54px;line-height:1.05;color:#1f1f22;margin-bottom:28px}
.story .copy .eyebrow{font-family:'Anuphan',sans-serif;font-weight:500;font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--pink);margin-bottom:18px}
.story .copy p{font-family:'Anuphan',sans-serif;font-weight:300;font-size:16px;line-height:1.8;color:var(--muted);margin-bottom:18px}

.values{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;max-width:1680px;margin:0 auto}
.value{background:#fff;padding:48px 38px;border:1px solid var(--line);transition:transform .3s,box-shadow .3s}
.value:hover{transform:translateY(-6px);box-shadow:0 24px 60px rgba(20,30,80,.08)}
.value .num{font-family:'SourceSans3',sans-serif;font-weight:700;font-size:40px;color:var(--pink);margin-bottom:18px}
.value h3{font-family:'SourceSans3',sans-serif;font-weight:700;font-size:22px;line-height:1.3;color:#1f1f22;margin-bottom:14px}
.value p{font-family:'Anuphan',sans-serif;font-weight:300;font-size:14px;line-height:1.7;color:var(--muted)}

.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;max-width:1680px;margin:0 auto}
.member{display:flex;flex-direction:column}
.member .photo{aspect-ratio:4/5;background-size:cover;background-position:center;background-color:var(--grey);overflow:hidden;position:relative}
.member .photo .bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.member:hover .photo .bg{transform:scale(1.05)}
.member .nm{font-family:'SourceSans3',sans-serif;font-weight:700;font-size:20px;margin-top:18px}
.member .rl{font-family:'Anuphan',sans-serif;font-weight:300;font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);margin-top:6px}

.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;max-width:1680px;margin:0 auto;background:var(--dark);color:#fff}
.stat{padding:60px 30px;text-align:center;border-right:1px solid rgba(255,255,255,.08)}
.stat:last-child{border-right:none}
.stat .n{font-family:'SourceSans3',sans-serif;font-weight:700;font-size:64px;line-height:1;color:var(--pink)}
.stat .l{font-family:'Anuphan',sans-serif;font-weight:300;font-size:12px;letter-spacing:3px;text-transform:uppercase;margin-top:14px;opacity:.85}

/* ============ PRODUCTS PAGE ============ */
.product-intro{background:#fff}
.product-groups{display:grid;grid-template-columns:1fr;gap:42px;max-width:1680px;margin:0 auto}
.product-group{display:grid;grid-template-columns:1fr 1fr;min-height:560px;background:#fff;border:1px solid var(--line);overflow:hidden}
.product-group:nth-child(even) .product-image{order:2}
.product-image{position:relative;overflow:hidden;background:var(--grey)}
.product-image .bg{position:absolute;inset:-6%;background-size:cover;background-position:center;will-change:transform;transition:transform .65s cubic-bezier(.16,1,.3,1)}
.product-group.life .product-image::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,rgba(233,67,137,.38),rgba(31,138,240,.34));mix-blend-mode:multiply}
.product-group.nonlife .product-image::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,rgba(21,179,214,.38),rgba(245,180,26,.28));mix-blend-mode:multiply}
.product-copy{padding:64px 56px;display:flex;flex-direction:column;justify-content:center}
.product-kicker{font-family:'Anuphan',sans-serif;font-weight:500;font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--pink);margin-bottom:16px}
.product-copy h2{font-family:'SourceSans3',sans-serif;font-weight:700;font-size:56px;line-height:1.05;color:#1f1f22;margin-bottom:22px}
.product-copy p{font-family:'Anuphan',sans-serif;font-weight:300;font-size:16px;line-height:1.75;color:var(--muted);margin-bottom:32px}
.product-list{display:grid;grid-template-columns:1fr 1fr;gap:14px 18px;margin-bottom:38px}
.product-list div{position:relative;padding-left:20px;font-family:'Anuphan',sans-serif;font-weight:400;font-size:14px;line-height:1.5;color:var(--dark)}
.product-list div::before{content:"";position:absolute;left:0;top:.72em;width:7px;height:7px;border-radius:50%;background:var(--pink)}
.product-cta{display:inline-flex;align-items:center;justify-content:center;align-self:flex-start;min-height:56px;padding:0 32px;background:var(--dark);color:#fff;font-family:'Anuphan',sans-serif;font-weight:500;font-size:11px;letter-spacing:3px;text-transform:uppercase;transition:background .2s,transform .2s}
.product-cta:hover{background:var(--pink);transform:translateY(-2px)}
.product-process{display:grid;grid-template-columns:repeat(4,1fr);gap:0;max-width:1680px;margin:0 auto;border-top:1px solid var(--line);border-left:1px solid var(--line)}
.process-step{background:#fff;padding:44px 34px;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.process-step .num{font-family:'SourceSans3',sans-serif;font-weight:700;font-size:38px;color:var(--pink);margin-bottom:20px}
.process-step h3{font-family:'SourceSans3',sans-serif;font-weight:700;font-size:24px;color:#1f1f22;margin-bottom:12px}
.process-step p{font-family:'Anuphan',sans-serif;font-weight:300;font-size:14px;line-height:1.7;color:var(--muted)}
.product-quote{background:var(--dark);padding:92px 60px;display:grid;grid-template-columns:1fr auto;gap:60px;align-items:center;max-width:1920px;margin:0 auto}
.product-quote .eyebrow{font-family:'Anuphan',sans-serif;font-weight:500;font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--pink);margin-bottom:18px}
.product-quote h2{font-family:'SourceSans3',sans-serif;font-weight:700;font-size:56px;line-height:1.05;color:#fff}
.product-quote a{display:inline-flex;align-items:center;justify-content:center;min-height:62px;padding:0 48px;background:var(--pink);color:#fff;font-family:'Anuphan',sans-serif;font-weight:500;font-size:11px;letter-spacing:4px;text-transform:uppercase;white-space:nowrap;transition:background .2s,transform .2s}
.product-quote a:hover{background:#d33279;transform:translateY(-2px)}

/* ============ CONTACT PAGE ============ */
.contact{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;max-width:1680px;margin:0 auto}
.contact .info h2{font-family:'SourceSans3',sans-serif;font-weight:700;font-size:48px;line-height:1.05;color:#1f1f22;margin-bottom:24px}
.contact .info .lead{font-family:'Anuphan',sans-serif;font-weight:300;font-size:16px;line-height:1.7;color:var(--muted);margin-bottom:40px}
.contact-block{display:flex;gap:18px;margin-bottom:30px;align-items:flex-start}
.contact-block .ico{width:46px;height:46px;border-radius:50%;background:#f4f4f6;display:flex;align-items:center;justify-content:center;color:var(--pink);flex-shrink:0}
.contact-block .lbl{font-family:'Anuphan',sans-serif;font-weight:500;font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.contact-block .val{font-family:'SourceSans3',sans-serif;font-weight:700;font-size:18px;color:#1f1f22}

.contact-form{background:#fff;padding:50px 44px;border:1px solid var(--line)}
.contact-form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.contact-form .field{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
.contact-form label{font-family:'Anuphan',sans-serif;font-weight:500;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--muted)}
.contact-form input,.contact-form textarea,.contact-form select{font-family:'Anuphan',sans-serif;font-weight:300;font-size:15px;color:var(--dark);padding:14px 16px;border:1px solid var(--line);background:#fafafa;outline:none;transition:border-color .2s,background .2s;width:100%}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{border-color:var(--pink);background:#fff}
.contact-form textarea{resize:vertical;min-height:140px}
.contact-form .submit{width:100%;height:62px;background:var(--pink);color:#fff;border:none;cursor:pointer;font-family:'Anuphan',sans-serif;font-weight:500;font-size:11px;letter-spacing:4px;text-transform:uppercase;transition:background .2s,transform .2s;margin-top:6px}
.contact-form .submit:hover{background:#d33279;transform:translateY(-2px)}
.contact-form .submit[disabled]{cursor:wait;opacity:.68;transform:none}
.form-status{min-height:22px;margin-top:16px;font-family:'Anuphan',sans-serif;font-weight:400;font-size:13px;line-height:1.5;color:var(--muted)}
.form-status.ok{color:#187a45}
.form-status.error{color:#b3264f}

.map-strip{height:360px;background:url('https://images.unsplash.com/photo-1524661135-423995f22d0b?w=1600&q=70&auto=format&fit=crop') center/cover no-repeat;position:relative}
.map-strip::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,rgba(233,67,137,.45) 0%,rgba(31,138,240,.55) 100%);mix-blend-mode:multiply}

/* ============ RESPONSIVE ============ */
@media (max-width:1280px){
  .hero{height:auto;padding:160px 40px 60px}
  .hero::before{background:#f4f4f6}
  .hero-photo{position:relative;left:auto;top:auto;width:100%;height:60vw;max-height:560px}
  .hero-social{top:200px;left:24px;gap:20px}
  .hero-text{position:relative;left:auto;top:auto;margin-top:40px}
  .hero-text h1{font-size:88px}
  .slide-num,.hero-pagination{display:none}
  .hero-buttons{position:relative;left:auto;bottom:auto;margin-top:48px}
  .talent{padding:80px 32px 100px}
  .talent-grid{grid-template-columns:repeat(2,1fr)}
  .news{padding:60px 32px 100px}
  .small-news{grid-template-columns:1fr 1fr;gap:32px}
  .news-main{grid-template-columns:1fr;gap:32px}
  .featured{grid-column:span 1}
  .news-bottom{grid-template-columns:1fr 1fr;gap:32px}
  .video-card{grid-column:span 2}
  .section{padding:80px 32px}
  .client-grid,.team-grid{grid-template-columns:repeat(3,1fr)}
  .news-list,.testimonials,.values{grid-template-columns:repeat(2,1fr)}
  .story{grid-template-columns:1fr;gap:48px}
  .stats{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:none}
  .product-group{grid-template-columns:1fr;min-height:0}
  .product-group:nth-child(even) .product-image{order:0}
  .product-image{min-height:380px}
  .product-process{grid-template-columns:repeat(2,1fr)}
  .product-quote{grid-template-columns:1fr;gap:32px;padding:80px 32px}
  .product-quote h2{font-size:44px}
  .contact{grid-template-columns:1fr;gap:48px}
  .page-hero{height:420px}
  .page-hero h1{font-size:60px}
}
@media (max-width:1024px){
  nav.top{padding:0 32px;height:80px}
  .ic-menu{display:flex}
  .menu-links{display:none}
  .menu-right .ic-search{display:none}
}
@media (max-width:768px){
  .hero{padding:140px 20px 40px}
  .hero-photo{height:80vw;max-height:none}
  .hero-social{display:none}
  .hero-text h1{font-size:54px;line-height:1.02;letter-spacing:-1px}
  .hero-text .sub{margin-top:24px;letter-spacing:3px}
  .hero-buttons{flex-direction:row;width:100%}
  .btn-profile{flex:1;height:80px;font-size:11px;letter-spacing:3px;width:auto}
  .btn-play{width:80px;height:80px;flex-shrink:0}
  .tabs{gap:24px;flex-wrap:wrap;font-size:10px;margin-bottom:48px}
  .talent-grid{grid-template-columns:1fr 1fr;gap:0}
  .news h2{font-size:34px}
  .small-news{grid-template-columns:1fr;gap:28px;margin-bottom:50px}
  .news-item .thumb{width:130px;height:100px}
  .news-item h3{font-size:16px}
  .featured{grid-template-columns:1fr;height:auto}
  .featured .left{padding:36px 28px;min-height:200px}
  .featured .left h3{font-size:22px}
  .featured .right{height:240px}
  .news-slide{height:300px}
  .news-bottom{grid-template-columns:1fr;gap:32px;margin-top:32px}
  .video-card{grid-column:span 1;height:340px;padding:24px}
  .big-card .img{height:220px}
  .big-card h3{font-size:20px}
  footer{padding:32px 24px 28px}
  .footer-row{flex-direction:column;gap:18px;align-items:flex-start}
  .footer-newsletter::before{display:none}
  .footer-bottom{flex-direction:column;gap:14px;text-align:center}

  .page-hero{height:340px}
  .page-hero h1{font-size:42px}
  .section{padding:60px 20px}
  .section-head h2{font-size:34px}
  .client-grid,.team-grid{grid-template-columns:repeat(2,1fr)}
  .news-list,.testimonials,.values{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
  .stat{padding:40px 20px}
  .stat .n{font-size:48px}
  .product-copy{padding:42px 28px}
  .product-copy h2{font-size:38px}
  .product-list{grid-template-columns:1fr}
  .product-process{grid-template-columns:1fr}
  .product-quote{padding:64px 20px}
  .product-quote h2{font-size:36px}
  .product-quote a{width:100%;padding:0 24px}
  .contact-form{padding:32px 24px}
  .contact-form .row{grid-template-columns:1fr}
  .story .copy h2{font-size:36px}
}
@media (max-width:480px){
  nav.top{padding:0 20px;height:72px}
  .brand img{height:36px!important}
  .hero-text h1{font-size:42px}
  .talent-grid{grid-template-columns:1fr}
  .btn-profile{height:64px}
  .btn-play{width:64px;height:64px}
  .stats{grid-template-columns:1fr}
  .stat{border-right:none;border-bottom:1px solid rgba(255,255,255,.08)}
}

.px{will-change:transform;transition:transform .55s cubic-bezier(.16,1,.3,1)}
