:root{
  --ink:#070707;
  --ink-2:#131313;
  --paper:#faf6ee;
  --paper-2:#fffdf8;
  --warm:#efe4d4;
  --orange:#f37021;
  --orange-2:#ff8a37;
  --line:#06c755;
  --text:#111111;
  --muted:#6d675f;
  --muted-dark:rgba(255,255,255,.64);
  --border:rgba(7,7,7,.13);
  --border-dark:rgba(255,255,255,.14);
  --max:1360px;
  --header:74px;
  --ease:cubic-bezier(.16,1,.3,1);
  --shadow:0 30px 90px rgba(0,0,0,.18);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--paper)}
body{margin:0;color:var(--text);background:var(--paper);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;}
html[lang="th"] body,html[lang="th"] button,html[lang="th"] input{font-family:"Noto Sans Thai",Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}
a{color:inherit;text-decoration:none}button,input{font:inherit}button{cursor:pointer}img{display:block;max-width:100%}h1,h2,h3,p{margin:0}h1,h2,h3{font-family:"Space Grotesk",Inter,sans-serif;font-weight:800;line-height:.95;letter-spacing:-.075em}html[lang="th"] h1,html[lang="th"] h2,html[lang="th"] h3{font-family:"Noto Sans Thai",Inter,sans-serif;letter-spacing:-.045em;line-height:1.06}h1{font-size:clamp(44px,13vw,128px);max-width:1050px}h2{font-size:clamp(34px,9vw,88px);max-width:980px}h3{font-size:clamp(22px,5vw,34px)}p{color:var(--muted)}ul,ol{margin:0;padding:0}.shell{width:min(var(--max),calc(100% - 32px));margin-inline:auto}.section-pad{padding:80px 0}.skip-link{position:fixed;left:12px;top:-100px;background:var(--orange);color:#fff;padding:10px 14px;z-index:5000}.skip-link:focus{top:12px}.scroll-meter{position:fixed;left:0;top:0;height:2px;width:0;background:linear-gradient(90deg,var(--orange),#111);z-index:4500}.eyebrow{display:inline-flex;align-items:center;gap:10px;text-transform:uppercase;letter-spacing:.16em;font-size:11px;font-weight:900;color:var(--orange);margin-bottom:16px}.eyebrow:before{content:"";width:28px;height:1px;background:currentColor}html[lang="th"] .eyebrow{letter-spacing:.02em}.reveal{opacity:0;transform:translateY(28px);transition:opacity .75s var(--ease),transform .75s var(--ease)}.reveal.is-visible{opacity:1;transform:none}
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:0 18px;border:1px solid currentColor;font-weight:900;letter-spacing:-.02em;overflow:hidden;transition:transform .25s var(--ease),background .25s var(--ease),border-color .25s var(--ease),color .25s var(--ease),box-shadow .25s var(--ease);text-align:center}.btn:after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent 20%,rgba(255,255,255,.34),transparent 72%);transform:translateX(-120%);transition:transform .75s var(--ease)}.btn:hover{transform:translateY(-2px)}.btn:hover:after{transform:translateX(120%)}.btn-orange{background:var(--orange);border-color:var(--orange);color:#fff;box-shadow:0 18px 45px rgba(243,112,33,.22)}.btn-orange:hover{background:var(--orange-2);border-color:var(--orange-2)}.btn-dark{background:var(--ink);border-color:var(--ink);color:#fff}.btn-ghost{color:#fff;border-color:rgba(255,255,255,.35);background:rgba(255,255,255,.05);backdrop-filter:blur(10px)}.btn-line{background:var(--line);border-color:var(--line);color:#fff;box-shadow:0 18px 45px rgba(6,199,85,.18)}.btn-small{min-height:42px;padding:0 14px;font-size:13px}
.site-header{position:sticky;top:0;z-index:3000;background:rgba(250,246,238,.94);backdrop-filter:blur(18px);border-bottom:1px solid rgba(7,7,7,.12);box-shadow:0 18px 55px rgba(0,0,0,.07);transition:background .3s var(--ease),box-shadow .3s var(--ease)}.site-header.is-scrolled{background:rgba(250,246,238,.985);box-shadow:0 24px 70px rgba(0,0,0,.12)}.header-shell{height:var(--header);width:min(var(--max),calc(100% - 24px));margin:auto;display:grid;grid-template-columns:minmax(120px,158px) 1fr auto;align-items:center;gap:12px}.brand{position:relative;z-index:3200;display:inline-flex;align-items:center;max-width:154px}.brand img{width:148px;height:auto;object-fit:contain}.brand-fallback{display:none;font-family:"Space Grotesk",Inter,sans-serif;font-weight:800;font-size:24px;letter-spacing:-.07em;color:var(--ink);line-height:1}.brand-fallback span{color:var(--orange)}.desktop-nav{display:none}.header-actions{display:flex;align-items:center;gap:8px;justify-content:flex-end}.lang-switch{display:flex;border:1px solid rgba(7,7,7,.16);height:34px;background:rgba(255,255,255,.44)}.lang-switch a{min-width:34px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:900;color:rgba(7,7,7,.55);letter-spacing:.06em}.lang-switch a.is-active{background:var(--ink);color:#fff}.line-chip{display:none}.menu-toggle{position:relative;z-index:3200;width:46px;height:46px;background:transparent;border:1px solid rgba(7,7,7,.18);display:grid;place-items:center}.menu-toggle span{position:absolute;width:22px;height:2px;background:var(--ink);transition:transform .3s var(--ease),opacity .3s var(--ease),top .3s var(--ease)}.menu-toggle span:nth-child(1){top:15px}.menu-toggle span:nth-child(2){top:22px}.menu-toggle span:nth-child(3){top:29px}body.menu-open .menu-toggle span:nth-child(1){top:22px;transform:rotate(45deg)}body.menu-open .menu-toggle span:nth-child(2){opacity:0}body.menu-open .menu-toggle span:nth-child(3){top:22px;transform:rotate(-45deg)}body.menu-open{overflow:hidden}.mobile-menu{position:fixed;z-index:2990;inset:0;background:var(--ink);color:#fff;transform:translateY(-104%);opacity:0;pointer-events:none;transition:transform .55s var(--ease),opacity .35s var(--ease);overflow:hidden}.mobile-menu:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 82% 18%,rgba(243,112,33,.36),transparent 30%),linear-gradient(90deg,rgba(255,255,255,.055) 1px,transparent 1px),linear-gradient(0deg,rgba(255,255,255,.045) 1px,transparent 1px);background-size:auto,44px 44px,44px 44px;opacity:.7}.mobile-menu-inner{position:relative;z-index:1;height:100%;display:flex;flex-direction:column;justify-content:center;padding:100px 28px 48px}.mobile-menu a{font-family:"Space Grotesk",Inter,sans-serif;font-size:clamp(42px,13vw,78px);line-height:.92;letter-spacing:-.075em;font-weight:800;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.13);display:flex;justify-content:space-between;gap:18px}.mobile-menu a span{font-size:14px;letter-spacing:0;color:var(--orange)}body.menu-open .mobile-menu{transform:none;opacity:1;pointer-events:auto}
.hero{position:relative;background:var(--ink);color:#fff;overflow:hidden;isolation:isolate}.hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(0deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:46px 46px;mask-image:linear-gradient(to bottom,#000,transparent 92%);z-index:-2}.hero-art span{position:absolute;display:block;pointer-events:none}.hero-art span:nth-child(1){right:-18vw;top:8%;width:78vw;height:78vw;background:radial-gradient(circle,rgba(243,112,33,.35),transparent 62%);filter:blur(22px);animation:pulse 7s ease-in-out infinite;z-index:-1}.hero-art span:nth-child(2){left:0;top:0;bottom:0;width:1px;background:linear-gradient(transparent,var(--orange),transparent);animation:scanY 5s linear infinite}.hero-art span:nth-child(3){right:8%;bottom:8%;width:38vw;height:38vw;background:conic-gradient(from 180deg,transparent,rgba(255,255,255,.15),transparent,rgba(243,112,33,.18),transparent);filter:blur(18px);animation:spin 20s linear infinite;z-index:-1}.hero-grid{display:grid;gap:34px;padding:52px 0 22px}.hero-lead{font-size:clamp(17px,4.7vw,24px);line-height:1.48;color:rgba(255,255,255,.75);max-width:780px}.hero-actions{display:flex;flex-direction:column;gap:12px;margin-top:28px}.hero-work{position:relative;min-height:520px;margin:8px -16px 0;perspective:1200px}.project-card{position:relative;min-width:0;border-top:1px solid var(--border);background:var(--paper-2);transition:transform .35s var(--ease)}.hero-work .project-card{position:absolute;background:#111;border:1px solid rgba(255,255,255,.16);color:#fff;box-shadow:0 42px 140px rgba(0,0,0,.55)}.hero-work .project-card-large{left:0;right:8%;top:0;transform:rotateY(-6deg) rotateX(3deg);animation:floatA 6.2s ease-in-out infinite}.hero-work .project-card-small{width:58%;right:0;bottom:4%;transform:rotateY(7deg) rotateX(-2deg);animation:floatB 7s ease-in-out infinite}.project-media{position:relative;display:block;width:100%;padding:0;border:0;background:#111;overflow:hidden;aspect-ratio:4/3;text-align:left;color:#fff;clip-path:polygon(0 0,100% 0,100% calc(100% - 22px),calc(100% - 22px) 100%,0 100%)}.project-card-large .project-media{aspect-ratio:16/11}.project-card-small .project-media{aspect-ratio:4/3}.project-media img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease),filter .5s var(--ease);background:linear-gradient(135deg,#111,var(--orange))}.project-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.82),transparent 55%);display:flex;align-items:flex-end;justify-content:flex-start;padding:18px;opacity:0;transition:opacity .3s var(--ease)}.project-overlay span{font-size:12px;text-transform:uppercase;letter-spacing:.12em;font-weight:900;color:#fff;border-bottom:2px solid var(--orange)}.project-media:hover img{transform:scale(1.05);filter:saturate(1.08) contrast(1.04)}.project-media:hover .project-overlay{opacity:1}.project-info{padding:18px 0 0}.hero-work .project-info{padding:16px;background:rgba(5,5,5,.9);backdrop-filter:blur(12px)}.project-info p{font-size:11px;text-transform:uppercase;letter-spacing:.12em;font-weight:900;color:var(--orange);margin-bottom:6px}.project-info h3{font-size:clamp(22px,5.8vw,38px);margin-bottom:8px}.project-info span{display:block;color:var(--muted);font-size:14px}.hero-work .project-info span{color:rgba(255,255,255,.65)}.trust-strip{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));border-top:1px solid rgba(255,255,255,.14);margin-top:18px}.trust-strip div{padding:18px 4px;border-right:1px solid rgba(255,255,255,.12)}.trust-strip div:nth-child(2n){border-right:0}.trust-strip strong{display:block;font-family:"Space Grotesk";font-size:30px;letter-spacing:-.07em;color:#fff;line-height:1}.trust-strip span{font-size:12px;color:rgba(255,255,255,.62);font-weight:800;text-transform:uppercase;letter-spacing:.06em}.statement-grid{display:grid;gap:30px}.statement-number{font-family:"Space Grotesk";font-size:14px;font-weight:800;color:var(--orange);padding-top:8px}.statement-body p{font-size:18px;max-width:720px}.proof-list{display:grid;gap:0;margin-top:26px;border-top:1px solid var(--border)}.proof-list span{padding:16px 0;border-bottom:1px solid var(--border);font-weight:800;color:var(--ink)}.dark-feature{background:var(--ink);color:#fff;position:relative;overflow:hidden}.dark-feature:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(0deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:52px 52px;mask-image:linear-gradient(to bottom,#000,transparent 88%)}.section-heading{position:relative;display:grid;gap:16px;margin-bottom:34px}.dark-feature .section-heading p:not(.eyebrow){color:rgba(255,255,255,.64)}.featured-grid,.service-grid,.process-grid,.price-grid,.service-page-grid{display:grid;gap:18px;position:relative}.project-card-featured{background:#101010;color:#fff;border-color:rgba(255,255,255,.14);padding-bottom:18px}.project-card-featured .project-info{padding-inline:0}.project-card-featured .project-info span{color:rgba(255,255,255,.62)}.services-preview,.work-section{background:var(--paper)}.service-panel,.process-step,.price-plan{position:relative;border-top:2px solid var(--ink);padding:24px 0 0;background:transparent;transition:transform .32s var(--ease),border-color .32s var(--ease)}.service-panel:hover,.process-step:hover,.price-plan:hover{transform:translateY(-5px);border-color:var(--orange)}.service-panel>span,.process-step>span{display:block;font-family:"Space Grotesk";font-weight:800;font-size:14px;color:var(--orange);margin-bottom:16px}.service-panel h3,.process-step h3,.price-plan h3{margin-bottom:12px}.service-panel p,.process-step p,.price-plan p{font-size:16px}.service-panel ul,.price-plan ul{list-style:none;margin-top:20px;border-top:1px solid var(--border)}.service-panel li,.price-plan li{padding:11px 0;border-bottom:1px solid var(--border);font-weight:700;color:var(--ink)}.dark-feature .process-step{border-color:rgba(255,255,255,.2)}.dark-feature .process-step:hover{border-color:var(--orange)}.dark-feature .process-step p{color:rgba(255,255,255,.64)}.portfolio-band{overflow:hidden}.work-rail{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(260px,78vw);gap:16px;overflow-x:auto;padding:0 16px 26px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.work-rail .project-card{scroll-snap-align:start}.center-actions{text-align:center;margin-top:8px}.mockup-callout{background:var(--warm)}.mockup-grid{display:grid;gap:28px;align-items:center}.mockup-grid p{font-size:18px;max-width:720px;margin-bottom:24px}.mockup-card{background:var(--ink);color:#fff;min-height:260px;padding:30px;display:flex;flex-direction:column;justify-content:flex-end;position:relative;overflow:hidden;clip-path:polygon(0 0,100% 0,100% calc(100% - 32px),calc(100% - 32px) 100%,0 100%)}.mockup-card:before{content:"";position:absolute;inset:-30%;background:conic-gradient(from 90deg,transparent,rgba(243,112,33,.28),transparent 35%,rgba(255,255,255,.15),transparent 65%);animation:spin 15s linear infinite}.mockup-card strong{position:relative;font-family:"Space Grotesk";font-size:clamp(66px,22vw,118px);line-height:.8;letter-spacing:-.08em}.mockup-card span{position:relative;font-weight:900;font-size:22px;margin-top:10px}.mockup-card small{position:relative;color:rgba(255,255,255,.66);margin-top:10px}.page-hero{padding:58px 0 34px}.page-hero h1{margin-bottom:20px}.page-hero>p:not(.eyebrow){font-size:clamp(17px,4vw,22px);max-width:820px}.portfolio-tools{display:grid;gap:16px;margin-bottom:28px}.search-box{display:grid;gap:8px}.search-box span{font-size:12px;text-transform:uppercase;letter-spacing:.12em;font-weight:900;color:var(--orange)}.search-box input{height:54px;border:1px solid var(--border);background:#fff;padding:0 16px;color:var(--ink);outline:none}.search-box input:focus{border-color:var(--orange);box-shadow:0 0 0 4px rgba(243,112,33,.12)}.filter-row{display:flex;gap:8px;overflow:auto;padding-bottom:8px}.filter-row button{white-space:nowrap;border:1px solid var(--border);background:transparent;color:var(--ink);font-weight:900;padding:12px 14px}.filter-row button.is-active,.filter-row button:hover{background:var(--ink);color:#fff;border-color:var(--ink)}.project-grid{display:grid;gap:22px}.service-page-grid{gap:30px}.price-plan{background:#fff;padding:24px;border:1px solid var(--border);border-top:3px solid var(--ink);display:flex;flex-direction:column;gap:0}.price-plan.is-highlighted{border-top-color:var(--orange);box-shadow:0 28px 80px rgba(0,0,0,.12)}.price-plan h3{font-size:clamp(30px,8vw,54px)}.price-plan .btn{margin-top:auto}.pricing-note{margin-top:32px;background:var(--ink);color:#fff;padding:26px}.pricing-note p{color:rgba(255,255,255,.68);margin:14px 0 22px}.about-split,.seo-layout,.contact-grid,.mockup-detail-grid{display:grid;gap:32px}.about-copy p,.seo-article p{font-size:18px}.about-stats{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--border);margin-top:26px}.about-stats div{padding:18px 0;border-right:1px solid var(--border)}.about-stats div:last-child{border-right:0}.about-stats strong{display:block;font-family:"Space Grotesk";font-size:32px;letter-spacing:-.07em}.about-stats span{display:block;font-size:12px;font-weight:800;color:var(--muted);text-transform:uppercase}.mockup-hero .btn{margin-top:26px}.mockup-detail-grid{align-items:start}.free-card{background:var(--ink);color:#fff;padding:28px;clip-path:polygon(0 0,100% 0,100% calc(100% - 30px),calc(100% - 30px) 100%,0 100%)}.free-card strong{font-family:"Space Grotesk";font-size:72px;letter-spacing:-.08em;line-height:.8;color:var(--orange)}.free-card h2{margin:10px 0 14px}.free-card p{color:rgba(255,255,255,.68);margin-bottom:24px}.free-card img,.qr-large img,.footer-qr{width:160px;background:#fff;padding:10px}.free-steps{border-top:2px solid var(--ink);padding-top:24px}.free-steps ol{counter-reset:item;list-style:none;display:grid;gap:0;margin:20px 0;border-top:1px solid var(--border)}.free-steps li{counter-increment:item;padding:15px 0;border-bottom:1px solid var(--border);font-weight:800}.free-steps li:before{content:"0" counter(item);color:var(--orange);margin-right:14px;font-family:"Space Grotesk"}details{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:14px 0}summary{font-weight:900;cursor:pointer}.contact-grid ul,.seo-aside ul{list-style:none;border-top:1px solid var(--border);margin-top:20px}.contact-grid li,.seo-aside li{padding:14px 0;border-bottom:1px solid var(--border);font-weight:800}.qr-large{background:#fff;padding:24px;border:1px solid var(--border)}.qr-large strong{display:block;margin-top:16px}.seo-aside{background:#fff;border:1px solid var(--border);padding:24px}.seo-aside .btn{margin-top:24px}.final-cta{background:var(--ink);color:#fff;padding:80px 0}.final-cta-inner{width:min(var(--max),calc(100% - 32px));margin:auto;display:grid;gap:22px}.final-cta p:not(.eyebrow){color:rgba(255,255,255,.66);font-size:18px;max-width:720px}.site-footer{background:#030303;color:#fff;padding:54px 0 92px}.footer-grid{width:min(var(--max),calc(100% - 32px));margin:auto;display:grid;gap:30px}.footer-logo{width:160px;background:#fff;padding:10px;margin-bottom:18px}.site-footer p{color:rgba(255,255,255,.58)}.site-footer h3{font-family:Inter,sans-serif;letter-spacing:0;font-size:13px;text-transform:uppercase;margin-bottom:14px;color:var(--orange)}.site-footer a{display:block;color:rgba(255,255,255,.72);padding:6px 0}.site-footer a:hover{color:#fff}.footer-bottom{width:min(var(--max),calc(100% - 32px));margin:38px auto 0;padding-top:18px;border-top:1px solid rgba(255,255,255,.12);display:flex;flex-direction:column;gap:8px;color:rgba(255,255,255,.45);font-size:13px}.sticky-line{position:fixed;z-index:2600;left:16px;right:16px;bottom:12px;height:52px;background:var(--line);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;box-shadow:0 18px 50px rgba(6,199,85,.28)}.lightbox{position:fixed;z-index:5000;inset:0;background:rgba(0,0,0,.84);display:grid;place-items:center;padding:18px;opacity:0;pointer-events:none;transition:opacity .28s var(--ease)}.lightbox.is-open{opacity:1;pointer-events:auto}.lightbox-panel{width:min(1180px,100%);background:var(--paper);display:grid;max-height:90dvh;overflow:auto}.lightbox-panel img{width:100%;height:42dvh;object-fit:cover;background:linear-gradient(135deg,#111,var(--orange))}.lightbox-copy{padding:24px}.lightbox-copy h2{font-size:clamp(32px,8vw,74px);margin-bottom:14px}.lightbox-copy p{margin-bottom:22px}.lightbox-close{position:fixed;top:16px;right:16px;z-index:2;width:46px;height:46px;background:#fff;border:0;color:#111;font-size:32px;line-height:1}.image-fallback{background:linear-gradient(135deg,#111,var(--orange))!important}.image-fallback img{opacity:.08}
@keyframes pulse{0%,100%{opacity:.75;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}@keyframes scanY{0%{transform:translateY(-100%)}100%{transform:translateY(100%)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes floatA{0%,100%{transform:rotateY(-6deg) rotateX(3deg) translateY(0)}50%{transform:rotateY(-5deg) rotateX(2deg) translateY(-14px)}}@keyframes floatB{0%,100%{transform:rotateY(7deg) rotateX(-2deg) translateY(0)}50%{transform:rotateY(6deg) rotateX(-1deg) translateY(12px)}}
@media (prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition:none!important}.reveal{opacity:1;transform:none}}
@media (min-width:720px){body{padding-bottom:0}.hero-actions{flex-direction:row}.trust-strip{grid-template-columns:repeat(4,1fr)}.trust-strip div:nth-child(2n){border-right:1px solid rgba(255,255,255,.12)}.trust-strip div:last-child{border-right:0}.featured-grid,.service-grid,.service-page-grid,.process-grid,.price-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.work-rail{grid-auto-columns:minmax(340px,42vw)}.footer-grid{grid-template-columns:1.2fr .55fr .8fr .8fr}.footer-bottom{flex-direction:row;justify-content:space-between}.sticky-line{display:none}}
@media (min-width:980px){:root{--header:86px}.header-shell{width:min(var(--max),calc(100% - 48px));grid-template-columns:190px minmax(0,1fr) 306px;height:var(--header)}.brand img{width:176px}.desktop-nav{display:flex;justify-content:center;gap:2px}.desktop-nav a{position:relative;padding:34px 13px;font-size:12px;text-transform:uppercase;letter-spacing:.08em;font-weight:900;color:rgba(7,7,7,.62);transition:color .25s var(--ease)}html[lang="th"] .desktop-nav a{letter-spacing:.01em;font-size:13px}.desktop-nav a:after{content:"";position:absolute;left:13px;right:13px;bottom:26px;height:2px;background:var(--orange);transform:scaleX(0);transform-origin:left;transition:transform .28s var(--ease)}.desktop-nav a:hover,.desktop-nav a.is-active{color:var(--ink)}.desktop-nav a:hover:after,.desktop-nav a.is-active:after{transform:scaleX(1)}.line-chip{display:inline-flex;align-items:center;justify-content:center;height:44px;border:1px solid rgba(7,7,7,.17);padding:0 14px;font-size:12px;font-weight:900;background:rgba(255,255,255,.44)}.line-chip:hover{background:var(--line);border-color:var(--line);color:#fff}.menu-toggle{display:none}.mobile-menu{display:none}.hero-grid{grid-template-columns:minmax(0,.92fr) minmax(520px,1.08fr);align-items:center;min-height:calc(100svh - 200px);gap:74px;padding:54px 0 36px}.hero-work{min-height:680px;margin:0}.hero-work .project-card-small{width:46%}.trust-strip{margin-top:0}.trust-strip div{padding:24px 0}.trust-strip strong{font-size:46px}.section-pad{padding:118px 0}.statement-grid{grid-template-columns:90px .98fr .9fr;gap:48px;align-items:start}.section-heading{grid-template-columns:1fr .55fr;align-items:end;margin-bottom:48px}.section-heading .eyebrow{grid-column:1/-1}.featured-grid{gap:26px}.project-card-featured .project-media{aspect-ratio:16/10}.service-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:24px}.service-page-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:34px}.work-rail{width:min(var(--max),calc(100% - 48px));margin:auto;grid-auto-flow:row;grid-template-columns:repeat(4,minmax(0,1fr));overflow:visible;padding:0;gap:22px}.work-rail .project-card:nth-child(1),.work-rail .project-card:nth-child(8){grid-column:span 2}.work-rail .project-card:nth-child(1) .project-media,.work-rail .project-card:nth-child(8) .project-media{aspect-ratio:16/9}.mockup-grid{grid-template-columns:1fr 420px;gap:70px}.process-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:28px}.page-hero{padding:86px 0 50px}.portfolio-tools{grid-template-columns:360px 1fr;align-items:end}.project-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:24px}.project-grid .project-card:nth-child(12n+1),.project-grid .project-card:nth-child(12n+8){grid-column:span 2}.project-grid .project-card:nth-child(12n+1) .project-media,.project-grid .project-card:nth-child(12n+8) .project-media{aspect-ratio:16/9}.price-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:24px}.pricing-note{display:grid;grid-template-columns:1fr auto;gap:30px;align-items:center;padding:36px}.pricing-note p{margin-bottom:0}.about-split,.seo-layout,.contact-grid,.mockup-detail-grid{grid-template-columns:1.05fr .82fr;gap:70px;align-items:start}.final-cta-inner{grid-template-columns:1fr auto;align-items:end}.final-cta-inner .eyebrow{grid-column:1/-1}.lightbox-panel{grid-template-columns:1.45fr .75fr;overflow:hidden}.lightbox-panel img{height:82dvh}.lightbox-copy{align-self:center;padding:44px}}
@media (min-width:1220px){.desktop-nav a{padding-inline:18px}.desktop-nav a:after{left:18px;right:18px}.hero-grid{gap:92px}.project-grid{gap:26px}}

/* Pxil.Pro combined clean refinements */
.brand{max-width:176px}
.brand img{width:158px;filter:none}
.mobile-menu-logo{width:178px;height:auto;margin:0 0 34px;object-fit:contain}
.footer-logo{width:190px;background:transparent!important;padding:0!important;margin-bottom:20px}
.hero-logo-stamp{position:absolute;right:6%;top:52%;width:min(220px,38vw);opacity:.13;z-index:0;filter:saturate(1.08);animation:stampDrift 8s ease-in-out infinite;pointer-events:none}.hero-work .project-card{z-index:1}.site-header{background:rgba(250,246,238,.97)}
@keyframes stampDrift{0%,100%{transform:translate3d(0,0,0) rotate(-2deg)}50%{transform:translate3d(0,-12px,0) rotate(1deg)}}
.project-card,.price-plan,.service-panel,.process-step{will-change:transform}.project-card:after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(115deg,transparent 0 35%,rgba(255,255,255,.42),transparent 65%);transform:translateX(-125%);transition:transform .85s var(--ease)}.project-card:hover:after{transform:translateX(125%)}
.project-media{clip-path:none}.mockup-card,.free-card{clip-path:none}.btn,.line-chip,.lang-switch,.menu-toggle,.search-box input,.filter-row button,.price-plan,.seo-aside,.qr-large{border-radius:0}
.service-panel,.process-step{border-top-width:1px}.dark-feature{background:#070707}.hero{background:linear-gradient(135deg,#070707 0%,#111 52%,#201006 100%)}
@media (min-width:980px){.brand img{width:196px}.brand{max-width:210px}.header-shell{grid-template-columns:220px minmax(0,1fr) 306px}.mobile-menu-logo{display:none}.hero-logo-stamp{width:280px}}
@media (max-width:760px){.brand img{width:148px}.mobile-menu-inner{justify-content:flex-start;padding-top:104px}.mobile-menu a{font-size:clamp(38px,12vw,58px)}.hero-logo-stamp{right:2%;top:48%;opacity:.10}.hero-work{min-height:500px}}

/* Refined Work page */
.work-hero{position:relative;background:#070707;color:#fff;overflow:hidden;isolation:isolate}
.work-hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(0deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:42px 42px;mask-image:linear-gradient(to bottom,#000,rgba(0,0,0,.75),transparent 105%);z-index:-2}
.work-hero:after{content:"";position:absolute;right:-18vw;top:-18vw;width:72vw;height:72vw;background:radial-gradient(circle,rgba(243,112,33,.36),transparent 62%);filter:blur(24px);opacity:.9;animation:pulse 8s var(--ease) infinite;z-index:-1}
.work-hero-grid{display:grid;gap:36px;padding:56px 0 44px;min-height:calc(100svh - var(--header))}
.work-hero h1{max-width:920px}
.work-hero-lead{font-size:clamp(17px,4.6vw,23px);line-height:1.48;color:rgba(255,255,255,.72);max-width:780px;margin-top:22px}
.work-hero-actions{display:flex;flex-direction:column;gap:12px;margin-top:28px}
.work-statbar{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));margin-top:34px;border-top:1px solid rgba(255,255,255,.16);border-bottom:1px solid rgba(255,255,255,.16)}
.work-statbar div{padding:15px 10px 15px 0;border-right:1px solid rgba(255,255,255,.14)}
.work-statbar div:last-child{border-right:0}
.work-statbar strong{display:block;font-family:"Space Grotesk",Inter,sans-serif;font-size:clamp(22px,7vw,48px);letter-spacing:-.07em;line-height:.95;color:#fff}
.work-statbar span{display:block;margin-top:6px;font-size:11px;font-weight:850;line-height:1.25;text-transform:uppercase;letter-spacing:.05em;color:rgba(255,255,255,.56)}
html[lang="th"] .work-statbar span{letter-spacing:0;text-transform:none}
.work-showcase{position:relative;display:grid;grid-template-columns:1fr;gap:16px;align-content:center;min-height:510px}
.work-showcase:before{content:"";position:absolute;inset:8% 8% 8% auto;width:1px;background:linear-gradient(transparent,var(--orange),transparent);animation:scanY 5.5s linear infinite;opacity:.85}
.work-featured-card{position:relative;background:#101010;border:1px solid rgba(255,255,255,.16);box-shadow:0 30px 100px rgba(0,0,0,.45);overflow:hidden;transition:transform .45s var(--ease),border-color .45s var(--ease)}
.work-featured-card:hover{transform:translateY(-7px);border-color:rgba(243,112,33,.58)}
.work-featured-card.is-primary{z-index:2}
.work-featured-card.is-secondary{z-index:1;width:88%;margin-left:auto;margin-top:-8px}
.work-featured-media{display:block;position:relative;width:100%;border:0;background:#111;color:#fff;padding:0;overflow:hidden;aspect-ratio:16/11;text-align:left}
.work-featured-card.is-secondary .work-featured-media{aspect-ratio:16/10}
.work-featured-media img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease),filter .6s var(--ease)}
.work-featured-media span{position:absolute;left:16px;bottom:16px;background:rgba(7,7,7,.82);color:#fff;border-left:3px solid var(--orange);padding:9px 12px;font-size:12px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;transform:translateY(8px);opacity:0;transition:opacity .3s var(--ease),transform .3s var(--ease)}
html[lang="th"] .work-featured-media span{letter-spacing:0;text-transform:none}
.work-featured-card:hover .work-featured-media img{transform:scale(1.045);filter:saturate(1.08) contrast(1.04)}
.work-featured-card:hover .work-featured-media span{opacity:1;transform:none}
.work-featured-copy{padding:18px;background:rgba(5,5,5,.94)}
.work-featured-copy p{font-size:11px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;color:var(--orange);margin-bottom:7px}
html[lang="th"] .work-featured-copy p{letter-spacing:0;text-transform:none}
.work-featured-copy h2{font-size:clamp(28px,8.2vw,60px);margin-bottom:8px;color:#fff}
.work-featured-copy span{display:block;color:rgba(255,255,255,.63);font-size:14px;line-height:1.48}
.work-context{background:var(--paper)}
.work-context-grid{display:grid;gap:28px;border-bottom:1px solid var(--border);padding-bottom:42px}
.work-context-copy p{font-size:18px;line-height:1.65;max-width:720px}
.text-link{display:inline-flex;margin-top:18px;font-weight:900;color:var(--ink);border-bottom:2px solid var(--orange);padding-bottom:3px}
.work-browser{background:#fffdf8;border-top:1px solid var(--border)}
.work-browser-head{display:grid;gap:20px;margin-bottom:26px}
.work-browser-head>p{font-size:18px;line-height:1.6;max-width:680px}
.work-tools{position:sticky;top:var(--header);z-index:1200;background:rgba(255,253,248,.94);backdrop-filter:blur(16px);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:16px 0;margin-bottom:34px}
.filter-panel{display:grid;gap:13px;min-width:0}
.portfolio-count{display:flex;align-items:end;gap:8px;color:var(--ink)}
.portfolio-count strong{font-family:"Space Grotesk",Inter,sans-serif;font-size:38px;letter-spacing:-.08em;line-height:.84}
.portfolio-count span{font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);padding-bottom:3px}
html[lang="th"] .portfolio-count span{letter-spacing:0;text-transform:none}
.work-tools .filter-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:3px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.work-tools .filter-row button{flex:0 0 auto;scroll-snap-align:start;display:inline-flex;align-items:center;gap:8px;min-height:44px;padding:0 13px;background:#fff;border:1px solid var(--border);font-size:12px;font-weight:900;color:var(--ink);transition:background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease),transform .2s var(--ease)}
.work-tools .filter-row button small{font-size:10px;color:inherit;opacity:.52}
.work-tools .filter-row button:hover{transform:translateY(-1px);border-color:var(--orange)}
.work-tools .filter-row button.is-active{background:var(--ink);color:#fff;border-color:var(--ink)}
.work-grid{align-items:start}
.work-grid .project-card{background:transparent;border-top:1px solid var(--border);padding-top:0;transition:opacity .25s var(--ease),transform .38s var(--ease)}
.work-grid .project-card[hidden]{display:none!important}
.work-grid .project-media{border:1px solid rgba(7,7,7,.08);box-shadow:0 18px 54px rgba(0,0,0,.08)}
.work-grid .project-info{padding-top:16px;padding-bottom:18px;border-bottom:1px solid rgba(7,7,7,.09)}
.work-grid .project-info h3{font-size:clamp(24px,5.4vw,42px)}
.work-grid .project-info span{line-height:1.5}
.project-empty{background:var(--ink);color:#fff;padding:34px;margin-top:24px}
.project-empty h3{color:#fff;margin-bottom:12px}
.project-empty p{color:rgba(255,255,255,.65);margin-bottom:22px;max-width:720px}
.work-cta-band{background:var(--warm);padding:72px 0;border-top:1px solid var(--border)}
.work-cta-grid{display:grid;gap:28px;align-items:end}
.work-cta-grid p:not(.eyebrow){font-size:18px;line-height:1.62;max-width:720px;margin-bottom:22px}
@media (min-width:720px){.work-hero-actions{flex-direction:row}.work-showcase{grid-template-columns:1fr .86fr;gap:18px;min-height:420px}.work-featured-card.is-secondary{width:100%;margin-left:0;margin-top:80px}.work-statbar div{padding:18px 16px 18px 0}.work-tools .filter-row{flex-wrap:wrap;overflow:visible}.work-tools .filter-row button{min-height:42px}}
@media (min-width:980px){.work-hero-grid{grid-template-columns:minmax(0,.96fr) minmax(520px,1.04fr);gap:70px;align-items:center;padding:70px 0 64px;min-height:calc(100svh - var(--header))}.work-showcase{grid-template-columns:1fr .72fr;min-height:680px}.work-featured-card.is-primary{align-self:start}.work-featured-card.is-secondary{align-self:end;margin-top:0;transform:translateX(-46px)}.work-featured-card.is-secondary:hover{transform:translateX(-46px) translateY(-7px)}.work-context-grid{grid-template-columns:1fr .78fr;gap:70px;align-items:start;padding-bottom:70px}.work-browser-head{grid-template-columns:1fr .52fr;align-items:end;margin-bottom:34px}.work-tools{padding:18px 0;margin-bottom:46px}.work-tools.portfolio-tools{grid-template-columns:340px minmax(0,1fr);gap:24px;align-items:start}.filter-panel{grid-template-columns:112px minmax(0,1fr);gap:22px;align-items:start}.work-grid.project-grid{grid-template-columns:repeat(12,minmax(0,1fr));gap:30px}.work-grid .project-card{grid-column:span 3}.work-grid .project-card:nth-child(10n+1){grid-column:span 6}.work-grid .project-card:nth-child(10n+2),.work-grid .project-card:nth-child(10n+7){grid-column:span 3}.work-grid .project-card:nth-child(10n+5){grid-column:span 4}.work-grid .project-card:nth-child(10n+6){grid-column:span 5}.work-grid .project-card:nth-child(10n+9){grid-column:span 4}.work-grid .project-card:nth-child(10n+10){grid-column:span 5}.work-grid .project-card:nth-child(10n+1) .project-media,.work-grid .project-card:nth-child(10n+6) .project-media,.work-grid .project-card:nth-child(10n+10) .project-media{aspect-ratio:16/9}.work-grid .project-card:nth-child(10n+5) .project-media,.work-grid .project-card:nth-child(10n+9) .project-media{aspect-ratio:4/5}.work-cta-grid{grid-template-columns:1fr .62fr;gap:80px}.work-cta-band{padding:104px 0}}
@media (min-width:1220px){.work-hero-grid{gap:92px}.work-grid.project-grid{gap:34px}.work-tools.portfolio-tools{grid-template-columns:380px minmax(0,1fr)}}
@media (max-width:520px){.work-statbar{grid-template-columns:1fr}.work-statbar div{border-right:0;border-bottom:1px solid rgba(255,255,255,.14)}.work-statbar div:last-child{border-bottom:0}.work-tools{top:var(--header);margin-left:-16px;margin-right:-16px;padding:14px 16px}.portfolio-count strong{font-size:32px}.work-showcase{min-height:0}.work-featured-card.is-secondary{width:94%}}

/* Business barriers + verification — visitor-facing trust content */
.barrier-section{background:var(--paper-2);position:relative;overflow:hidden;border-top:1px solid var(--border)}
.barrier-section:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,7,7,.035) 1px,transparent 1px),linear-gradient(0deg,rgba(7,7,7,.025) 1px,transparent 1px);background-size:54px 54px;mask-image:linear-gradient(to bottom,transparent,#000 18%,#000 82%,transparent);pointer-events:none}
.barrier-intro{position:relative;display:grid;gap:22px;margin-bottom:38px}
.barrier-intro p:not(.eyebrow){font-size:clamp(17px,4.5vw,22px);line-height:1.62;max-width:760px}
.barrier-grid{position:relative;display:grid;gap:0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.barrier-card{position:relative;padding:26px 0;border-bottom:1px solid var(--border);overflow:hidden}
.barrier-card:last-child{border-bottom:0}
.barrier-card:before{content:"";position:absolute;left:0;top:0;width:0;height:2px;background:var(--orange);transition:width .55s var(--ease)}
.barrier-card:hover:before{width:100%}
.barrier-card span{display:block;font-family:"Space Grotesk",Inter,sans-serif;font-weight:800;font-size:13px;color:var(--orange);margin-bottom:14px}
.barrier-card h3{font-size:clamp(24px,6vw,42px);max-width:560px;margin-bottom:12px}
.barrier-card p{font-size:16px;line-height:1.68;max-width:640px}
.credibility-section{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.credibility-section:before{content:"";position:absolute;right:-20vw;top:-20vw;width:58vw;height:58vw;background:radial-gradient(circle,rgba(243,112,33,.28),transparent 64%);filter:blur(20px)}
.credibility-grid{position:relative;display:grid;gap:34px;align-items:start}
.credibility-grid h2{color:#fff;max-width:900px}
.credibility-list{display:grid;border-top:1px solid rgba(255,255,255,.16)}
.credibility-list div{padding:22px 0;border-bottom:1px solid rgba(255,255,255,.16)}
.credibility-list strong{display:block;font-family:"Space Grotesk",Inter,sans-serif;font-size:clamp(24px,6vw,46px);letter-spacing:-.07em;line-height:.98;color:#fff;margin-bottom:8px}
html[lang="th"] .credibility-list strong{font-family:"Noto Sans Thai",Inter,sans-serif;letter-spacing:-.04em;line-height:1.08}
.credibility-list span{display:block;color:rgba(255,255,255,.66);font-size:16px;line-height:1.62}
.footer-verify{margin-top:14px!important;color:rgba(255,255,255,.72)!important;font-weight:800;font-size:13px!important}
.work-type-grid{display:grid;gap:0;border-top:1px solid var(--border);margin-top:42px}
.work-type-card{position:relative;padding:22px 0;border-bottom:1px solid var(--border);overflow:hidden}
.work-type-card span{display:inline-flex;margin-bottom:12px;font-family:"Space Grotesk",Inter,sans-serif;font-weight:900;color:var(--orange);font-size:12px;text-transform:uppercase;letter-spacing:.11em}
.work-type-card h3{font-size:clamp(25px,6vw,46px);margin-bottom:10px;max-width:620px}
.work-type-card p{line-height:1.66;font-size:16px;max-width:670px}
.work-type-card:after{content:"";position:absolute;inset:auto 0 0 0;height:2px;background:var(--orange);transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease)}
.work-type-card:hover:after{transform:scaleX(1)}
@media (min-width:720px){
  .barrier-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .barrier-card{padding:30px 28px;border-right:1px solid var(--border)}
  .barrier-card:nth-child(2n){border-right:0}
  .barrier-card:nth-last-child(-n+2){border-bottom:0}
  .work-type-grid{grid-template-columns:repeat(2,minmax(0,1fr));border-left:1px solid var(--border)}
  .work-type-card{padding:26px;border-right:1px solid var(--border)}
  .work-type-card:nth-child(2n){border-right:0}
  .work-type-card:nth-last-child(-n+2){border-bottom:0}
}
@media (min-width:980px){
  .barrier-intro{grid-template-columns:1fr .62fr;align-items:end;margin-bottom:54px}
  .barrier-intro .eyebrow{grid-column:1/-1}
  .barrier-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
  .barrier-card{min-height:370px;padding:34px 24px 30px;border-bottom:0;border-right:1px solid var(--border)}
  .barrier-card:nth-child(2n){border-right:1px solid var(--border)}
  .barrier-card:last-child{border-right:0}
  .credibility-grid{grid-template-columns:1fr .72fr;gap:80px}
  .work-type-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
  .work-type-card{min-height:255px;padding:30px 24px;border-bottom:0;border-right:1px solid var(--border)}
  .work-type-card:nth-child(2n){border-right:1px solid var(--border)}
  .work-type-card:last-child{border-right:0}
}
.company-reg-note{margin-top:8px!important;font-size:13px!important;color:var(--muted)!important;font-weight:800!important;line-height:1.4!important}

/* --------------------------------------------------------------------------
   Pxil.Pro global premium clean-up: more breathing room, fewer boxes, cleaner work page
   -------------------------------------------------------------------------- */
:root{
  --max:1440px;
  --gutter:clamp(22px,4vw,56px);
  --section-lg:clamp(92px,13vw,184px);
  --section-md:clamp(72px,10vw,132px);
}
.shell{width:min(var(--max),calc(100% - var(--gutter) * 2))}
.section-pad{padding:var(--section-md) 0}
.site-header{background:rgba(251,247,239,.88);box-shadow:none;border-bottom:1px solid rgba(7,7,7,.09)}
.site-header.is-scrolled{background:rgba(251,247,239,.96);box-shadow:0 16px 52px rgba(0,0,0,.08)}
.header-shell{height:78px;grid-template-columns:minmax(132px,178px) 1fr auto;width:min(var(--max),calc(100% - var(--gutter) * 2))}
.brand{max-width:174px}.brand img{width:170px}.desktop-nav a{letter-spacing:-.01em}.line-chip{border-radius:0}.menu-toggle{border-radius:0;background:rgba(255,255,255,.28)}
.btn{border-radius:0;min-height:56px;padding:0 24px}.btn-dark-outline{background:transparent;color:var(--ink);border-color:rgba(7,7,7,.25)}.btn-dark-outline:hover{background:var(--ink);border-color:var(--ink);color:#fff}.btn-ghost{background:transparent}.clean-actions .btn-ghost,.clean-actions .btn-dark-outline{color:var(--ink)}
.eyebrow{margin-bottom:18px}.text-link{display:inline-flex;margin-top:24px;font-weight:900;color:var(--ink);border-bottom:2px solid var(--orange);padding-bottom:3px}

/* tasteful cursor spotlight */
.spotlight-zone{position:relative;isolation:isolate;overflow:hidden}.spotlight-zone:after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(620px circle at var(--mx,72%) var(--my,18%),rgba(243,112,33,.18),transparent 48%);mix-blend-mode:multiply;opacity:.9;z-index:-1;transition:opacity .2s var(--ease)}
body:not(.has-pointer) .spotlight-zone:after{opacity:.55}

/* homepage */
.home-splash{background:#fbf7ef;color:var(--ink);padding:clamp(58px,8vw,112px) 0 clamp(34px,6vw,92px);border-bottom:1px solid rgba(7,7,7,.1)}
.home-splash:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,7,7,.035) 1px,transparent 1px),linear-gradient(0deg,rgba(7,7,7,.025) 1px,transparent 1px);background-size:clamp(38px,5vw,72px) clamp(38px,5vw,72px);mask-image:linear-gradient(to bottom,#000,transparent 75%);z-index:-2}.ambient-orbit{position:absolute;right:-20vw;top:7vh;width:60vw;height:60vw;border:1px solid rgba(243,112,33,.22);border-radius:50%;z-index:-1}.ambient-orbit:before,.ambient-orbit:after{content:"";position:absolute;inset:12%;border:1px solid rgba(7,7,7,.08);border-radius:50%;animation:orbitPulse 10s ease-in-out infinite}.ambient-orbit:after{inset:28%;border-color:rgba(243,112,33,.28);animation-delay:-3s}
.home-splash-grid{display:grid;gap:clamp(46px,7vw,100px);align-items:center}.home-splash-copy h1{font-size:clamp(46px,11.2vw,136px);line-height:.94;max-width:1120px}.home-splash-copy .hero-lead{color:#4d4943;max-width:820px;margin-top:26px}.home-splash-visual{position:relative;min-height:440px}.hero-case{position:absolute;background:#0b0b0b;color:#fff;border:1px solid rgba(7,7,7,.18);box-shadow:0 36px 90px rgba(0,0,0,.16);transition:transform .45s var(--ease),box-shadow .45s var(--ease)}.hero-case button{display:block;width:100%;padding:0;border:0;background:#111;overflow:hidden}.hero-case img{width:100%;height:100%;object-fit:cover;aspect-ratio:16/10;transition:transform 1.2s var(--ease),filter .6s var(--ease)}.hero-case div{display:flex;justify-content:space-between;gap:18px;align-items:center;padding:16px 18px;border-top:1px solid rgba(255,255,255,.12)}.hero-case span{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--orange);font-weight:900}.hero-case strong{font-family:"Space Grotesk",Inter,sans-serif;font-size:clamp(20px,3vw,34px);letter-spacing:-.06em;line-height:1}.hero-case.is-front{left:0;right:8%;top:0;z-index:2}.hero-case.is-back{right:0;bottom:0;width:62%;z-index:3;transform:translateY(20px)}.hero-case:hover{transform:translateY(-8px);box-shadow:0 48px 120px rgba(0,0,0,.22)}.hero-case.is-back:hover{transform:translateY(12px)}.hero-case:hover img{transform:scale(1.045);filter:saturate(1.08) contrast(1.04)}.splash-logo-mark{position:absolute;right:2%;top:-8%;width:min(180px,28vw);opacity:.08;z-index:1;pointer-events:none}.clean-proof-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));border-top:1px solid rgba(7,7,7,.14);margin-top:clamp(38px,6vw,88px)}.clean-proof-row div{padding:20px 0;border-bottom:1px solid rgba(7,7,7,.1)}.clean-proof-row strong{display:block;font-family:"Space Grotesk",Inter,sans-serif;font-size:clamp(28px,7vw,58px);line-height:.9;letter-spacing:-.08em;color:var(--ink)}.clean-proof-row span{display:block;margin-top:8px;font-size:13px;color:var(--muted);font-weight:800}
.quiet-statement{background:#fffdf8}.quiet-grid{display:grid;gap:34px}.quiet-grid h2{max-width:980px}.quiet-copy p{font-size:clamp(18px,2.2vw,24px);line-height:1.65;color:#575149;max-width:760px}.section-intro-clean{margin-bottom:clamp(38px,6vw,72px)}.section-intro-clean h2{max-width:1050px}.showcase-clean{background:#fbf7ef}.editorial-work-list{display:grid;gap:clamp(62px,9vw,124px)}.editorial-work{display:grid;gap:28px;align-items:center}.editorial-work-media{position:relative;display:block;border:0;padding:0;background:#111;overflow:hidden;box-shadow:0 32px 86px rgba(0,0,0,.13)}.editorial-work-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:16/10;transition:transform 1.3s var(--ease),filter .5s var(--ease)}.editorial-work-media span{position:absolute;left:18px;bottom:18px;background:#fff;color:var(--ink);font-weight:900;font-size:12px;letter-spacing:.08em;text-transform:uppercase;padding:12px 14px;transform:translateY(12px);opacity:0;transition:transform .35s var(--ease),opacity .35s var(--ease)}.editorial-work-media:hover img{transform:scale(1.045);filter:saturate(1.05) contrast(1.04)}.editorial-work-media:hover span{transform:none;opacity:1}.editorial-work-copy h3{font-size:clamp(34px,7vw,82px);margin-bottom:18px}.editorial-work-copy p:not(.eyebrow){font-size:clamp(17px,2vw,22px);line-height:1.62;color:#59534b;max-width:620px}.center-action{display:flex;justify-content:center;margin-top:clamp(46px,7vw,84px)}
.barrier-clean{background:#111;color:#fff}.barrier-clean h2,.barrier-clean h3{color:#fff}.barrier-clean .eyebrow{color:var(--orange)}.barrier-clean-head{margin-bottom:clamp(42px,6vw,72px)}.barrier-lines{border-top:1px solid rgba(255,255,255,.16)}.barrier-line{display:grid;grid-template-columns:56px 1fr;gap:20px;padding:clamp(24px,4vw,42px) 0;border-bottom:1px solid rgba(255,255,255,.16);position:relative}.barrier-line:before{content:"";position:absolute;left:0;bottom:-1px;width:0;height:1px;background:var(--orange);transition:width .7s var(--ease)}.barrier-line:hover:before{width:100%}.barrier-line>span{font-family:"Space Grotesk",Inter,sans-serif;color:var(--orange);font-weight:900;letter-spacing:-.04em;font-size:22px}.barrier-line h3{font-size:clamp(25px,5.2vw,50px);margin-bottom:12px}.barrier-line p{font-size:clamp(16px,2vw,20px);line-height:1.66;color:rgba(255,255,255,.7);max-width:870px}.service-strip-clean{background:#efe4d4}.service-strip-grid{display:grid;gap:44px}.service-links-clean{display:grid;border-top:1px solid rgba(7,7,7,.16)}.service-links-clean a{display:flex;gap:18px;align-items:center;padding:24px 0;border-bottom:1px solid rgba(7,7,7,.16);font-size:clamp(22px,5vw,44px);font-family:"Space Grotesk",Inter,sans-serif;font-weight:800;letter-spacing:-.06em;line-height:1;color:var(--ink);transition:padding-left .3s var(--ease),color .3s var(--ease)}.service-links-clean a span{font-size:13px;letter-spacing:.1em;color:var(--orange);min-width:34px}.service-links-clean a:hover{padding-left:18px;color:var(--orange)}html[lang="th"] .service-links-clean a{font-family:"Noto Sans Thai",Inter,sans-serif;letter-spacing:-.035em;line-height:1.12}

/* work page */
.portfolio-hero-clean{padding:clamp(72px,11vw,164px) 0 clamp(50px,8vw,120px);background:#111;color:#fff;border-bottom:1px solid rgba(255,255,255,.12)}.portfolio-hero-clean h1{color:#fff;font-size:clamp(48px,11vw,132px)}.portfolio-hero-clean p{color:rgba(255,255,255,.72)}.portfolio-hero-grid{display:grid;gap:42px;align-items:end}.portfolio-hero-side p{font-size:clamp(17px,2.1vw,23px);line-height:1.62;max-width:720px}.portfolio-mini-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0;margin-top:34px;border-top:1px solid rgba(255,255,255,.16)}.portfolio-mini-stats div{padding:18px 0;border-right:1px solid rgba(255,255,255,.16)}.portfolio-mini-stats div:last-child{border-right:0;padding-left:16px}.portfolio-mini-stats strong{display:block;font-family:"Space Grotesk",Inter,sans-serif;font-size:clamp(28px,5vw,54px);line-height:.9;letter-spacing:-.08em;color:#fff}.portfolio-mini-stats span{display:block;margin-top:8px;color:rgba(255,255,255,.58);font-weight:800;font-size:12px}.featured-work-clean{background:#fbf7ef}.portfolio-browser-clean{background:#fffdf8;border-top:1px solid rgba(7,7,7,.1)}.portfolio-browser-heading{display:grid;gap:24px;align-items:end;margin-bottom:clamp(32px,5vw,64px)}.portfolio-browser-heading p:not(.eyebrow){font-size:18px;line-height:1.64;max-width:680px}.portfolio-control-bar{display:grid;gap:16px;align-items:end;margin-bottom:clamp(38px,6vw,76px);padding:0 0 24px;border-bottom:1px solid rgba(7,7,7,.14)}.clean-search,.select-box{display:grid;gap:10px}.clean-search span,.select-box span{font-size:11px;text-transform:uppercase;letter-spacing:.11em;font-weight:900;color:var(--muted)}.clean-search input,.select-box select{width:100%;min-height:56px;border:1px solid rgba(7,7,7,.18);background:#fff;color:var(--ink);padding:0 16px;border-radius:0;outline:0;font-weight:800}.clean-search input:focus,.select-box select:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(243,112,33,.12)}.clean-count{display:flex;align-items:flex-end;gap:10px;justify-content:flex-start}.clean-count strong{font-family:"Space Grotesk",Inter,sans-serif;font-size:48px;line-height:.85;letter-spacing:-.08em}.clean-count span{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:900;padding-bottom:3px}.portfolio-grid-clean{display:grid;gap:clamp(34px,5vw,70px)}.portfolio-grid-clean .project-card{background:transparent;border:0;padding:0}.portfolio-grid-clean .project-card[hidden]{display:none!important}.portfolio-grid-clean .project-media{clip-path:none;aspect-ratio:16/11;border:1px solid rgba(7,7,7,.08);box-shadow:0 24px 70px rgba(0,0,0,.08)}.portfolio-grid-clean .project-info{padding:18px 0 0;border:0}.portfolio-grid-clean .project-info h3{font-size:clamp(26px,4vw,46px)}.portfolio-grid-clean .project-info span{font-size:15px;line-height:1.55;color:#625d56}.clean-work-cta{background:#efe4d4}.project-card{will-change:transform}.project-card[hidden]{display:none!important}

/* mobile refinements */
@media (max-width:719px){
  :root{--gutter:20px}.home-splash-visual{min-height:390px}.hero-case.is-front{right:0}.hero-case.is-back{width:72%;bottom:6%}.clean-proof-row{grid-template-columns:1fr 1fr}.portfolio-mini-stats{grid-template-columns:1fr}.portfolio-mini-stats div{border-right:0;border-bottom:1px solid rgba(255,255,255,.16);padding-left:0!important}.portfolio-mini-stats div:last-child{border-bottom:0}.barrier-line{grid-template-columns:42px 1fr}.footer-grid{gap:34px}.sticky-line{left:20px;right:20px;justify-content:center}
}
@media (min-width:720px){
  .clean-proof-row{grid-template-columns:repeat(4,minmax(0,1fr))}.clean-proof-row div{border-right:1px solid rgba(7,7,7,.1);padding:24px 18px}.clean-proof-row div:last-child{border-right:0}.editorial-work{grid-template-columns:1.15fr .85fr;gap:clamp(38px,6vw,88px)}.editorial-work.is-reverse{grid-template-columns:.85fr 1.15fr}.editorial-work.is-reverse .editorial-work-media{order:2}.service-strip-grid{grid-template-columns:.9fr 1.1fr;gap:clamp(54px,7vw,100px)}.portfolio-control-bar{grid-template-columns:1fr minmax(220px,320px) auto}.portfolio-grid-clean{grid-template-columns:repeat(2,minmax(0,1fr))}.home-splash-visual{min-height:560px}
}
@media (min-width:980px){
  .home-splash-grid{grid-template-columns:minmax(0,1.05fr) minmax(520px,.95fr);min-height:calc(100svh - var(--header) - 160px)}.quiet-grid{grid-template-columns:1.05fr .75fr;gap:clamp(60px,8vw,118px)}.portfolio-hero-grid{grid-template-columns:1.05fr .72fr;gap:clamp(70px,8vw,128px)}.portfolio-browser-heading{grid-template-columns:1fr .56fr}.portfolio-grid-clean{grid-template-columns:repeat(3,minmax(0,1fr))}.portfolio-grid-clean .project-card:nth-child(8n+1),.portfolio-grid-clean .project-card:nth-child(8n+6){grid-column:span 2}.portfolio-grid-clean .project-card:nth-child(8n+1) .project-media,.portfolio-grid-clean .project-card:nth-child(8n+6) .project-media{aspect-ratio:16/9}.hero-case.is-back{bottom:4%;right:0}
}
@media (min-width:1280px){.portfolio-grid-clean{gap:76px 44px}.editorial-work-media img{aspect-ratio:16/9}}
@media (prefers-reduced-motion:reduce){.ambient-orbit:before,.ambient-orbit:after{animation:none}.hero-case,.editorial-work-media img,.project-media img{transition:none!important}}
@keyframes orbitPulse{0%,100%{transform:scale(1);opacity:.5}50%{transform:scale(1.08);opacity:1}}

/* v2026-06-07 desktop cleanup + mobile website preview treatment */
@media (min-width:980px){
  :root{--max:1280px;--header:82px}
  .section-pad{padding:clamp(112px,8.5vw,154px) 0}
  .home-splash{padding:clamp(86px,7vw,124px) 0 clamp(72px,6vw,110px)}
  .home-splash-grid{grid-template-columns:minmax(0,.92fr) minmax(420px,.78fr);gap:clamp(80px,9vw,140px);min-height:auto;align-items:center}
  .home-splash-copy h1{font-size:clamp(62px,6.6vw,104px);line-height:.98;max-width:900px;letter-spacing:-.07em}
  html[lang="th"] .home-splash-copy h1{line-height:1.08;letter-spacing:-.045em}
  .home-splash-copy .hero-lead{font-size:clamp(18px,1.45vw,22px);line-height:1.76;max-width:720px;margin-top:30px}
  .hero-actions.clean-actions{flex-direction:row;margin-top:38px;gap:14px}
  .quiet-grid,.portfolio-hero-grid{gap:clamp(86px,9vw,150px)}
  .section-intro-clean{margin-bottom:clamp(58px,6vw,92px)}
  .section-intro-clean h2{font-size:clamp(48px,5.4vw,78px);max-width:900px}
  html[lang="th"] .section-intro-clean h2{line-height:1.14}
  .editorial-work-list{gap:clamp(96px,9vw,142px)}
  .editorial-work{grid-template-columns:minmax(360px,.82fr) minmax(0,.9fr);gap:clamp(70px,8vw,128px)}
  .editorial-work.is-reverse{grid-template-columns:minmax(0,.9fr) minmax(360px,.82fr)}
  .editorial-work-copy h3{font-size:clamp(46px,5vw,72px);line-height:1.02}
  .editorial-work-copy p:not(.eyebrow){font-size:clamp(18px,1.35vw,21px);line-height:1.78;max-width:560px}
  .portfolio-hero-clean{padding:clamp(112px,9vw,166px) 0 clamp(88px,7vw,130px)}
  .portfolio-hero-clean h1{font-size:clamp(58px,6.8vw,106px);line-height:1;max-width:850px}
  html[lang="th"] .portfolio-hero-clean h1{line-height:1.12;letter-spacing:-.045em}
  .portfolio-browser-heading{margin-bottom:clamp(58px,6vw,92px)}
  .portfolio-grid-clean{grid-template-columns:repeat(3,minmax(0,1fr));gap:70px 34px}
  .portfolio-grid-clean .project-card:nth-child(n){grid-column:auto}
  .portfolio-grid-clean .project-media,.portfolio-grid-clean .project-card:nth-child(n) .project-media{aspect-ratio:4/3}
  .portfolio-grid-clean .project-info h3{font-size:clamp(24px,2vw,34px);line-height:1.08}
}

.home-splash-visual{display:grid;place-items:center;min-height:520px;perspective:1400px}
.home-splash-visual:before{content:"";position:absolute;inset:8% 0 0 0;background:linear-gradient(90deg,rgba(7,7,7,.06) 1px,transparent 1px),linear-gradient(0deg,rgba(7,7,7,.045) 1px,transparent 1px);background-size:28px 28px;mask-image:radial-gradient(circle at 50% 50%,#000 0 45%,transparent 72%);opacity:.6;pointer-events:none}
.hero-case{width:min(292px,62vw);border-radius:32px;background:#0a0a0a;border:1px solid rgba(255,255,255,.18);padding:10px;box-shadow:0 42px 110px rgba(0,0,0,.22),inset 0 0 0 1px rgba(255,255,255,.08);overflow:hidden;transform-style:preserve-3d}
.hero-case:before{content:"";position:absolute;z-index:3;left:50%;top:16px;width:64px;height:6px;border-radius:99px;background:rgba(255,255,255,.16);transform:translateX(-50%);pointer-events:none}
.hero-case:after{content:"";position:absolute;inset:10px;border-radius:24px;background:linear-gradient(115deg,rgba(255,255,255,.18),transparent 24%,transparent 68%,rgba(243,112,33,.14));opacity:.48;mix-blend-mode:screen;pointer-events:none;z-index:2}
.hero-case button{border-radius:24px;overflow:hidden;background:#111;position:relative}
.hero-case img{display:block;width:100%;aspect-ratio:9/19.2;height:auto;object-fit:cover;object-position:top center;filter:saturate(1.02) contrast(1.02);transition:transform 1.25s var(--ease),filter .5s var(--ease)}
.hero-case div{position:relative;z-index:4;display:block;padding:13px 6px 2px;border-top:0;text-align:center;background:transparent;color:#fff}
.hero-case div span{display:block;font-size:10px;letter-spacing:.14em;color:var(--orange);margin-bottom:4px}
.hero-case div strong{display:block;font-size:clamp(18px,2.2vw,24px);letter-spacing:-.055em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hero-case.is-front{left:calc(50% - 210px);right:auto;top:5%;z-index:4;transform:rotate(-7deg) translateZ(40px)}
.hero-case.is-back{right:calc(50% - 220px);bottom:1%;width:min(250px,54vw);z-index:2;transform:rotate(8deg) translateY(22px) translateZ(-20px);opacity:.94}
.hero-case:hover{transform:rotate(-5deg) translateY(-10px) translateZ(70px);box-shadow:0 58px 140px rgba(0,0,0,.28),inset 0 0 0 1px rgba(255,255,255,.08)}
.hero-case.is-back:hover{transform:rotate(6deg) translateY(8px) translateZ(20px)}
.hero-case:hover img{transform:scale(1.035);filter:saturate(1.08) contrast(1.04)}
.splash-logo-mark{right:2%;top:4%;width:min(190px,32vw);opacity:.055}

.editorial-work-media{position:relative;display:grid;place-items:center;background:linear-gradient(135deg,#111 0%,#18110d 46%,#2b1608 100%);padding:clamp(32px,5vw,64px);min-height:540px;border:1px solid rgba(7,7,7,.1);box-shadow:0 42px 118px rgba(0,0,0,.13);overflow:hidden}
.editorial-work-media:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 65% 25%,rgba(243,112,33,.32),transparent 34%),linear-gradient(90deg,rgba(255,255,255,.055) 1px,transparent 1px),linear-gradient(0deg,rgba(255,255,255,.045) 1px,transparent 1px);background-size:auto,30px 30px,30px 30px;opacity:.75;transition:opacity .45s var(--ease),transform .8s var(--ease)}
.editorial-work-media:after{content:"";position:relative;display:block;width:min(300px,74vw);aspect-ratio:9/19.2;border-radius:32px;border:10px solid #080808;box-shadow:0 30px 80px rgba(0,0,0,.42),inset 0 0 0 1px rgba(255,255,255,.14);pointer-events:none;z-index:2}
.editorial-work-media img{position:absolute;z-index:1;width:min(280px,calc(74vw - 20px));height:auto;aspect-ratio:9/19.2;object-fit:cover;object-position:top center;border-radius:23px;transition:transform 1.4s var(--ease),filter .5s var(--ease);box-shadow:none}
.editorial-work-media span{z-index:4;left:auto;right:22px;bottom:22px;background:#fff;color:var(--ink);opacity:1;transform:none;box-shadow:0 18px 42px rgba(0,0,0,.25)}
.editorial-work-media:hover:before{opacity:.95;transform:scale(1.04)}
.editorial-work-media:hover img{transform:translateY(-18px) scale(1.04);filter:saturate(1.08) contrast(1.04)}

@media (max-width:719px){
  .home-splash-visual{min-height:430px;margin-top:8px}
  .hero-case{width:min(238px,64vw);border-radius:28px;padding:8px}
  .hero-case button{border-radius:21px}.hero-case img{aspect-ratio:9/18.5}.hero-case:after{inset:8px;border-radius:21px}.hero-case:before{top:13px;width:52px;height:5px}
  .hero-case.is-front{left:2%;top:3%;transform:rotate(-6deg)}
  .hero-case.is-back{right:2%;bottom:7%;width:min(210px,56vw);transform:rotate(7deg) translateY(18px)}
  .editorial-work-media{min-height:460px;padding:32px 18px}
  .editorial-work-media:after{width:min(254px,76vw);border-width:8px;border-radius:28px}
  .editorial-work-media img{width:min(238px,calc(76vw - 16px));border-radius:21px}
  .editorial-work-media span{right:16px;bottom:16px}
}

@media (min-width:720px) and (max-width:979px){
  .home-splash-visual{min-height:560px}.hero-case.is-front{left:14%}.hero-case.is-back{right:13%;bottom:2%}
}

@media (min-width:1280px){
  .home-splash-visual{min-height:650px}.hero-case.is-front{left:calc(50% - 235px)}.hero-case.is-back{right:calc(50% - 250px)}
  .editorial-work-media{min-height:620px}.editorial-work-media:after{width:320px}.editorial-work-media img{width:300px}
}

/* keep the mobile screenshots locked inside the device frame even when JS parallax is active */
.editorial-work-media img{left:50%;top:50%;translate:-50% -50%}
.editorial-work-media:after{z-index:3}

/* v2026-06-07b: real mobile screenshots + quieter footer contact treatment */
.hero-case img,
.editorial-work-media img{
  object-position:top center;
}
.hero-case:after,
.editorial-work-media:after{
  pointer-events:none;
}
.editorial-work-media[data-lightbox-trigger]{
  cursor:zoom-in;
}
.lightbox-panel img{
  object-fit:contain;
  object-position:top center;
  background:#0a0a0a;
}
.site-footer{
  padding:clamp(64px,7vw,96px) 0 calc(92px + env(safe-area-inset-bottom));
}
.footer-grid{
  gap:clamp(34px,5vw,72px);
}
.footer-grid > div:last-child{
  display:flex;
  flex-direction:column;
  align-items:center;
}
.footer-qr{
  width:138px;
  padding:16px;
  margin:8px 0 14px;
  background:#fff;
  box-shadow:0 22px 56px rgba(0,0,0,.34);
}
.site-footer .btn-small.btn-line{
  display:inline-flex;
  min-height:38px;
  width:auto;
  padding:0 16px;
  font-size:12px;
  box-shadow:0 12px 30px rgba(6,199,85,.16);
}
.site-footer .btn-small.btn-line:after{
  display:none;
}
@media (max-width:719px){
  .site-footer{
    padding-top:72px;
    padding-bottom:calc(104px + env(safe-area-inset-bottom));
  }
  .footer-grid{
    width:min(100% - 44px,520px);
    text-align:center;
    justify-items:center;
    gap:42px;
  }
  .footer-grid > div{
    width:100%;
    display:flex;
    flex-direction:column;
    align-items:center;
  }
  .footer-grid > div:first-child p{
    max-width:360px;
    margin-inline:auto;
  }
  .footer-logo{
    margin-left:auto;
    margin-right:auto;
  }
  .site-footer h3{
    margin-bottom:12px;
  }
  .site-footer a:not(.btn){
    display:inline-flex;
    justify-content:center;
    padding:7px 4px;
  }
  .footer-qr{
    width:132px;
    padding:18px;
    margin:10px auto 14px;
  }
  .site-footer .btn-small.btn-line{
    min-height:36px;
    padding:0 14px;
    font-size:11px;
    margin-inline:auto;
  }
  .footer-bottom{
    width:min(100% - 44px,520px);
    text-align:center;
    align-items:center;
    margin-top:42px;
    gap:10px;
  }
}
@media (min-width:980px){
  .footer-grid{
    grid-template-columns:minmax(300px,1.35fr) minmax(120px,.45fr) minmax(190px,.7fr) minmax(170px,.55fr);
    align-items:start;
  }
  .site-footer .btn-small.btn-line:hover{
    transform:translateY(-1px);
  }
}

/* v2026-06-07c: cleaner recent work case studies + robust mobile navigation */
.hero-case button{
  aspect-ratio:9/18.5;
  height:auto;
}
.hero-case img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:top center;
}
.case-study-section{
  background:#fbf7ef;
  border-top:1px solid rgba(7,7,7,.08);
}
.case-study-section .section-intro-clean{
  max-width:980px;
}
.case-stack{
  display:grid;
  gap:clamp(22px,4vw,48px);
}
.case-feature{
  position:relative;
  display:grid;
  gap:clamp(28px,5vw,72px);
  align-items:center;
  padding:clamp(26px,5vw,70px);
  overflow:hidden;
  border:1px solid rgba(7,7,7,.09);
  isolation:isolate;
}
.case-feature:before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  background:radial-gradient(circle at var(--mx, 20%) var(--my, 20%),rgba(243,112,33,.20),transparent 34%);
  opacity:.72;
  transition:opacity .35s var(--ease);
}
.case-feature.is-dark{
  background:#0a0a0a;
  color:#fff;
  border-color:rgba(255,255,255,.12);
}
.case-feature.is-dark:after{
  content:"";
  position:absolute;
  inset:0;
  z-index:-2;
  background:linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(0deg,rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:44px 44px;
  mask-image:linear-gradient(to bottom,#000,transparent 84%);
}
.case-feature.is-warm{
  background:#fffaf2;
  color:var(--ink);
}
.case-device-wrap{
  display:flex;
  justify-content:center;
  align-items:center;
  min-height:clamp(430px,70vw,640px);
}
.case-device{
  position:relative;
  display:block;
  width:min(292px,72vw);
  aspect-ratio:9/18.8;
  padding:0;
  border:10px solid #090909;
  border-radius:34px;
  background:#090909;
  overflow:hidden;
  box-shadow:0 34px 86px rgba(0,0,0,.30),0 0 0 1px rgba(255,255,255,.08) inset;
  cursor:zoom-in;
  transform:translateZ(0);
}
.case-device:before{
  content:"";
  position:absolute;
  z-index:3;
  left:50%;
  top:10px;
  width:62px;
  height:6px;
  border-radius:999px;
  background:rgba(255,255,255,.18);
  transform:translateX(-50%);
  pointer-events:none;
}
.case-device:after{
  content:"";
  position:absolute;
  inset:0;
  z-index:2;
  background:linear-gradient(118deg,rgba(255,255,255,.18),transparent 18%,transparent 72%,rgba(243,112,33,.12));
  mix-blend-mode:screen;
  pointer-events:none;
}
.case-device img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:top center;
  transition:transform 1.15s var(--ease),filter .45s var(--ease);
}
.case-device:hover img{
  transform:scale(1.045);
  filter:saturate(1.08) contrast(1.04);
}
.case-content{
  max-width:680px;
}
.case-content h3{
  font-size:clamp(38px,8vw,92px);
  line-height:.96;
  letter-spacing:-.075em;
  margin:0 0 20px;
}
html[lang="th"] .case-content h3{
  line-height:1.04;
  letter-spacing:-.045em;
}
.case-content p:not(.eyebrow){
  font-size:clamp(17px,2vw,22px);
  line-height:1.7;
  color:#625d56;
}
.case-feature.is-dark .case-content p:not(.eyebrow){
  color:rgba(255,255,255,.68);
}
.case-feature.is-dark .text-link{
  color:#fff;
}
.case-tags{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:24px 0 24px;
}
.case-tags span{
  display:inline-flex;
  align-items:center;
  min-height:36px;
  padding:0 12px;
  border:1px solid rgba(7,7,7,.14);
  background:rgba(255,255,255,.54);
  font-size:12px;
  font-weight:900;
  color:var(--ink);
}
.case-feature.is-dark .case-tags span{
  border-color:rgba(255,255,255,.16);
  background:rgba(255,255,255,.08);
  color:#fff;
}
.mobile-menu{
  position:fixed!important;
  inset:0!important;
  z-index:9990!important;
  display:block;
  height:100dvh;
  min-height:100vh;
  background:#090909!important;
  color:#fff!important;
  transform:translateX(102%);
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  transition:transform .42s var(--ease),opacity .25s var(--ease),visibility .25s var(--ease);
}
.mobile-menu.is-open,
body.menu-open .mobile-menu{
  transform:translateX(0)!important;
  opacity:1!important;
  visibility:visible!important;
  pointer-events:auto!important;
}
.mobile-menu-inner{
  min-height:100dvh;
  height:auto;
  justify-content:flex-start;
  padding:calc(96px + env(safe-area-inset-top)) 24px calc(40px + env(safe-area-inset-bottom));
}
.mobile-menu-logo{
  display:block;
  width:min(190px,56vw);
  height:auto;
  margin:0 0 34px;
}
.mobile-menu a{
  color:#fff!important;
  font-size:clamp(32px,10vw,54px);
  line-height:1;
  letter-spacing:-.055em;
  padding:17px 0;
  border-bottom:1px solid rgba(255,255,255,.15);
}
.mobile-menu a span{
  color:var(--orange)!important;
  font-size:13px;
  letter-spacing:.03em;
}
.menu-toggle{
  z-index:10001!important;
}
body.menu-open .menu-toggle{
  border-color:rgba(255,255,255,.32);
  background:rgba(0,0,0,.35);
}
body.menu-open .menu-toggle span{
  background:#fff!important;
}
@media (min-width:860px){
  .case-feature{
    grid-template-columns:minmax(300px,.7fr) minmax(0,1fr);
  }
  .case-feature.is-warm{
    grid-template-columns:minmax(0,1fr) minmax(300px,.7fr);
  }
  .case-feature.is-warm .case-device-wrap{
    order:2;
  }
  .case-feature.is-warm .case-content{
    order:1;
  }
  .case-device-wrap{
    min-height:620px;
  }
  .case-device{
    width:min(320px,26vw);
  }
}
@media (min-width:980px){
  .mobile-menu{display:none!important;}
}
@media (max-width:719px){
  .case-feature{
    padding:28px 18px 32px;
  }
  .case-device-wrap{
    min-height:430px;
  }
  .case-content h3{
    font-size:clamp(36px,12vw,58px);
  }
  .case-tags{
    gap:8px;
  }
  .case-tags span{
    min-height:34px;
    font-size:11px;
  }
}

/* v2026-06-07d: rebuilt recent work with cleaner editorial mobile previews */
.home-splash-visual{
  display:grid;
  place-items:center;
  min-height:clamp(430px,52vw,680px);
}
.splash-showcase{
  position:relative;
  width:min(620px,100%);
  min-height:clamp(430px,52vw,640px);
  display:grid;
  align-items:center;
  padding:clamp(22px,3.5vw,42px);
  background:linear-gradient(145deg,#111 0%,#17110d 56%,#0a0a0a 100%);
  border:1px solid rgba(7,7,7,.16);
  box-shadow:0 38px 120px rgba(0,0,0,.18);
  overflow:hidden;
  isolation:isolate;
}
.splash-showcase:before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(255,255,255,.055) 1px,transparent 1px),linear-gradient(0deg,rgba(255,255,255,.045) 1px,transparent 1px);
  background-size:36px 36px;
  opacity:.34;
  mask-image:linear-gradient(120deg,#000,transparent 72%);
  pointer-events:none;
}
.splash-showcase:after{
  content:"";
  position:absolute;
  width:360px;
  height:360px;
  right:-150px;
  top:-140px;
  background:radial-gradient(circle,rgba(243,112,33,.52),transparent 68%);
  filter:blur(8px);
  opacity:.7;
  pointer-events:none;
}
.splash-showcase-copy{
  position:relative;
  z-index:3;
  align-self:start;
  max-width:330px;
}
.splash-showcase-copy span{
  display:block;
  color:var(--orange);
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:950;
  margin-bottom:10px;
}
.splash-showcase-copy strong{
  display:block;
  color:#fff;
  font-family:"Space Grotesk",Inter,sans-serif;
  font-size:clamp(24px,4vw,42px);
  line-height:.98;
  letter-spacing:-.07em;
}
.splash-mobile-row{
  position:absolute;
  inset:auto clamp(20px,4vw,54px) clamp(22px,4vw,54px) auto;
  z-index:4;
  display:flex;
  align-items:flex-end;
  gap:clamp(12px,2vw,22px);
}
.splash-mobile-preview{
  position:relative;
  display:block;
  width:clamp(148px,16vw,214px);
  height:clamp(286px,34vw,430px);
  overflow:hidden;
  border:8px solid #050505;
  border-radius:22px;
  background:#050505;
  box-shadow:0 30px 78px rgba(0,0,0,.34),0 0 0 1px rgba(255,255,255,.1) inset;
  cursor:zoom-in;
}
.splash-mobile-preview.is-secondary{
  width:clamp(124px,13vw,178px);
  height:clamp(244px,29vw,358px);
  opacity:.92;
  transform:translateY(18px);
}
.mobile-preview-top{
  position:absolute;
  z-index:4;
  top:9px;
  left:50%;
  width:46px;
  height:5px;
  border-radius:999px;
  background:rgba(255,255,255,.18);
  transform:translateX(-50%);
}
.splash-mobile-preview img{
  display:block;
  width:100%;
  height:auto;
  min-height:100%;
  transform:translateY(0);
  transition:transform 8s cubic-bezier(.2,.72,.18,1),filter .45s var(--ease);
}
.mobile-preview-name{
  position:absolute;
  z-index:4;
  left:10px;
  right:10px;
  bottom:10px;
  display:block;
  padding:8px 9px;
  background:rgba(0,0,0,.72);
  color:#fff;
  font-size:11px;
  font-weight:900;
  text-align:center;
  backdrop-filter:blur(10px);
}
.splash-mobile-preview:hover img,
.refined-phone-screen:hover img{
  transform:translateY(var(--screenshot-shift, -42%));
  filter:saturate(1.06) contrast(1.04);
}
.recent-work-refined{
  background:#fbf7ef;
  border-top:1px solid rgba(7,7,7,.08);
}
.recent-head{
  display:grid;
  gap:18px;
  max-width:1120px;
  margin-bottom:clamp(42px,7vw,88px);
}
.recent-head h2{
  max-width:1040px;
}
.recent-head>p:not(.eyebrow){
  max-width:760px;
  color:#5f5850;
  font-size:clamp(17px,2vw,22px);
  line-height:1.65;
}
.refined-case-list{
  display:grid;
  gap:clamp(34px,5vw,72px);
}
.refined-case{
  position:relative;
  display:grid;
  gap:clamp(28px,5vw,74px);
  align-items:center;
  padding:clamp(28px,5.2vw,86px);
  background:#fffdf8;
  border:1px solid rgba(7,7,7,.11);
  overflow:hidden;
  isolation:isolate;
}
.refined-case:before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  background:linear-gradient(90deg,rgba(7,7,7,.045) 1px,transparent 1px),linear-gradient(0deg,rgba(7,7,7,.035) 1px,transparent 1px);
  background-size:34px 34px;
  mask-image:radial-gradient(circle at 24% 18%,#000 0 32%,transparent 62%);
  opacity:.7;
}
.refined-case.is-blackcap{
  background:#0b0b0b;
  color:#fff;
  border-color:rgba(255,255,255,.13);
}
.refined-case.is-blackcap:before{
  background:linear-gradient(90deg,rgba(255,255,255,.055) 1px,transparent 1px),linear-gradient(0deg,rgba(255,255,255,.04) 1px,transparent 1px);
  mask-image:linear-gradient(135deg,#000,transparent 70%);
}
.refined-case.is-blackcap:after{
  content:"";
  position:absolute;
  width:520px;
  height:520px;
  right:-220px;
  bottom:-220px;
  z-index:-1;
  background:radial-gradient(circle,rgba(243,112,33,.26),transparent 62%);
  pointer-events:none;
}
.refined-screen-wrap{
  display:flex;
  justify-content:center;
  align-items:center;
}
.refined-phone-screen{
  position:relative;
  display:block;
  width:min(342px,78vw);
  height:clamp(470px,58vw,670px);
  overflow:hidden;
  padding:0;
  border:9px solid #070707;
  border-radius:22px;
  background:#070707;
  box-shadow:0 34px 92px rgba(0,0,0,.22),0 0 0 1px rgba(255,255,255,.1) inset;
  cursor:zoom-in;
}
.refined-phone-screen:after{
  content:"";
  position:absolute;
  inset:0;
  z-index:3;
  pointer-events:none;
  background:linear-gradient(120deg,rgba(255,255,255,.18),transparent 16%,transparent 76%,rgba(243,112,33,.12));
  opacity:.36;
  mix-blend-mode:screen;
}
.phone-status{
  position:absolute;
  top:10px;
  left:50%;
  z-index:4;
  display:flex;
  gap:5px;
  transform:translateX(-50%);
}
.phone-status i{
  display:block;
  width:6px;
  height:6px;
  border-radius:999px;
  background:rgba(255,255,255,.22);
}
.refined-phone-screen img{
  display:block;
  width:100%;
  height:auto;
  min-height:100%;
  transform:translateY(0);
  transition:transform 9s cubic-bezier(.2,.72,.18,1),filter .45s var(--ease);
}
.refined-case-copy{
  max-width:650px;
}
.refined-case-copy h3{
  margin:0 0 18px;
  font-size:clamp(38px,7.2vw,88px);
  line-height:.96;
  letter-spacing:-.075em;
}
html[lang="th"] .refined-case-copy h3{
  line-height:1.04;
  letter-spacing:-.045em;
}
.refined-case-copy p:not(.eyebrow){
  max-width:620px;
  color:#5c554d;
  font-size:clamp(17px,1.8vw,21px);
  line-height:1.72;
}
.refined-case.is-blackcap .refined-case-copy p:not(.eyebrow){
  color:rgba(255,255,255,.72);
}
.refined-case-points{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:0;
  margin:clamp(24px,3vw,38px) 0;
  border-top:1px solid rgba(7,7,7,.14);
  border-bottom:1px solid rgba(7,7,7,.14);
}
.refined-case.is-blackcap .refined-case-points{
  border-color:rgba(255,255,255,.16);
}
.refined-case-points div{
  padding:18px 18px 18px 0;
}
.refined-case-points div+div{
  padding-left:18px;
  border-left:1px solid rgba(7,7,7,.14);
}
.refined-case.is-blackcap .refined-case-points div+div{
  border-left-color:rgba(255,255,255,.16);
}
.refined-case-points dt{
  margin-bottom:6px;
  color:var(--orange);
  font-size:11px;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.13em;
}
.refined-case-points dd{
  margin:0;
  font-weight:900;
  letter-spacing:-.025em;
}
.refined-actions{
  display:flex;
  flex-wrap:wrap;
  gap:18px 26px;
  align-items:center;
}
.refined-case.is-blackcap .text-link{
  color:#fff;
}
.text-link.as-button{
  border:0;
  padding:0;
  background:transparent;
  cursor:pointer;
  font:inherit;
}
.work-recent{
  background:#fbf7ef;
}
.refined-case-list.compact .refined-case{
  padding:clamp(24px,4.4vw,70px);
}
.refined-case-list.compact .refined-phone-screen{
  height:clamp(430px,48vw,610px);
}
@media (min-width:860px){
  .refined-case{
    grid-template-columns:minmax(300px,.72fr) minmax(0,1fr);
  }
  .refined-case.is-melissa{
    grid-template-columns:minmax(0,1fr) minmax(300px,.72fr);
  }
  .refined-case.is-melissa .refined-screen-wrap{order:2;}
  .refined-case.is-melissa .refined-case-copy{order:1;}
}
@media (min-width:1180px){
  .refined-phone-screen{
    width:342px;
  }
  .splash-showcase{
    transform:translateX(14px);
  }
}
@media (max-width:859px){
  .splash-showcase{
    min-height:500px;
    padding:24px;
  }
  .splash-mobile-row{
    left:24px;
    right:24px;
    justify-content:center;
  }
  .splash-mobile-preview{
    width:min(46vw,178px);
    height:min(88vw,360px);
    border-radius:20px;
  }
  .splash-mobile-preview.is-secondary{
    width:min(38vw,150px);
    height:min(76vw,310px);
  }
  .recent-head{
    margin-bottom:34px;
  }
  .refined-case{
    padding:28px 18px 32px;
  }
  .refined-phone-screen{
    width:min(310px,82vw);
    height:min(124vw,570px);
  }
  .refined-case-points{
    grid-template-columns:1fr;
  }
  .refined-case-points div+div{
    border-left:0;
    border-top:1px solid rgba(7,7,7,.14);
    padding-left:0;
  }
  .refined-case.is-blackcap .refined-case-points div+div{
    border-top-color:rgba(255,255,255,.16);
  }
}
@media (max-width:520px){
  .splash-showcase{
    min-height:460px;
    padding:20px;
  }
  .splash-showcase-copy strong{
    max-width:260px;
  }
  .refined-phone-screen{
    width:min(286px,86vw);
    height:500px;
  }
  .refined-case-copy h3{
    font-size:clamp(35px,11vw,52px);
  }
}


/* v2026-06-07e: no-lightbox recent work + optional live website embed */
.live-preview-work{background:#faf5ec;}
.live-case-list{display:grid;gap:clamp(38px,6vw,86px);}
.live-case{position:relative;display:grid;gap:clamp(28px,5vw,74px);align-items:center;padding:clamp(26px,5vw,76px);background:#fffdf8;border:1px solid rgba(7,7,7,.10);overflow:hidden;isolation:isolate;}
.live-case:before{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(90deg,rgba(7,7,7,.035) 1px,transparent 1px),linear-gradient(0deg,rgba(7,7,7,.03) 1px,transparent 1px);background-size:42px 42px;mask-image:linear-gradient(120deg,#000,transparent 70%);opacity:.58;}
.live-case.is-odd{background:#090909;color:#fff;border-color:rgba(255,255,255,.13);}
.live-case.is-odd:before{background:linear-gradient(90deg,rgba(255,255,255,.055) 1px,transparent 1px),linear-gradient(0deg,rgba(255,255,255,.04) 1px,transparent 1px);opacity:.72;}
.live-case.is-odd:after{content:"";position:absolute;right:-16%;bottom:-28%;width:min(620px,70vw);aspect-ratio:1;background:radial-gradient(circle,rgba(243,112,33,.24),transparent 64%);z-index:-1;}
.live-device{width:min(390px,100%);margin-inline:auto;}
.live-device-top span{width:7px;height:7px;border-radius:999px;background:rgba(255,255,255,.32);}
.live-device-screen{position:relative;overflow:hidden;background:#101010;border:10px solid #0a0a0a;aspect-ratio:390/760;box-shadow:0 32px 80px rgba(0,0,0,.24),0 0 0 1px rgba(255,255,255,.09) inset;}
.live-shot{position:absolute;inset:0;width:100%;height:auto;min-height:100%;object-fit:cover;object-position:top center;transition:transform 9s cubic-bezier(.2,.72,.18,1),filter .4s var(--ease),opacity .25s var(--ease);}
.live-device:hover .live-shot{transform:translateY(var(--live-shot-shift,-42%));filter:saturate(1.05) contrast(1.03);}
.live-frame{position:absolute;inset:0;width:100%;height:100%;border:0;background:#fff;opacity:0;pointer-events:none;transition:opacity .24s var(--ease);}
.live-device.is-live .live-shot{opacity:0;pointer-events:none;transform:none;}
.live-device.is-live .live-frame{opacity:1;pointer-events:auto;}
.live-device-actions{display:flex;gap:8px;align-items:center;justify-content:center;padding-top:12px;}
.mini-action{height:34px;padding:0 12px;border:1px solid rgba(7,7,7,.18);background:#fff;color:#111;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.06em;cursor:pointer;transition:background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease),transform .2s var(--ease);}
html[lang="th"] .mini-action{letter-spacing:0;font-size:12px;}
.mini-action:hover{background:var(--orange);border-color:var(--orange);color:#fff;transform:translateY(-1px);}
.mini-action.is-muted{background:transparent;color:inherit;border-color:rgba(127,127,127,.32);}
.live-device:not(.is-live) .mini-action.is-muted{display:none;}
.live-case-copy{max-width:660px;}
.live-case-copy h3{margin:0 0 18px;font-size:clamp(38px,7vw,84px);line-height:.97;letter-spacing:-.075em;}
html[lang="th"] .live-case-copy h3{line-height:1.04;letter-spacing:-.045em;}
.live-case-copy p:not(.eyebrow){max-width:620px;color:#5c554d;font-size:clamp(17px,1.8vw,21px);line-height:1.72;}
.live-case.is-odd .live-case-copy p:not(.eyebrow),.live-case.is-odd .text-link{color:rgba(255,255,255,.76);}
.live-case.is-odd .text-link:hover{color:#fff;}
.project-media{display:block;border:0;padding:0;cursor:pointer;text-align:left;text-decoration:none;color:inherit;}
.project-media img{transition:transform .55s var(--ease),filter .45s var(--ease);}
.project-media:hover img{transform:scale(1.045);filter:saturate(1.04) contrast(1.04);}
@media (min-width:900px){.live-case{grid-template-columns:minmax(330px,.7fr) minmax(0,1fr);}.live-case.is-even{grid-template-columns:minmax(0,1fr) minmax(330px,.7fr);}.live-case.is-even .live-device{order:2}.live-case.is-even .live-case-copy{order:1}.live-case-list.compact .live-case{grid-template-columns:minmax(310px,.58fr) minmax(0,1fr);}.live-case-list.compact .live-case.is-even{grid-template-columns:minmax(0,1fr) minmax(310px,.58fr);}}
@media (min-width:1180px){.live-device{width:384px}.live-case{padding:82px}.live-case-list.compact .live-device{width:354px}.live-case-list.compact .live-device-screen{aspect-ratio:390/720}}
@media (max-width:640px){.live-case{padding:24px 18px 30px}.live-device{width:min(320px,92vw)}.live-device-screen{border-width:8px;aspect-ratio:390/730}.live-case-copy h3{font-size:clamp(34px,11vw,52px)}.live-device-actions{justify-content:flex-start}.mini-action{height:36px}}

/* v2026-06-07f: embedded website previews + horizontal overflow lock */
html,body{max-width:100%;overflow-x:hidden!important;}
body{position:relative;}
main,section,.site-header,.mobile-menu{max-width:100vw;overflow-x:clip;}
.shell{max-width:calc(100vw - 32px);}
iframe{display:block;max-width:100%;}
.home-splash,.recent-work-refined,.portfolio-browser-clean{contain:layout paint;}
.home-splash-grid,.portfolio-hero-grid,.quiet-grid,.work-cta-grid,.service-strip-grid,.portfolio-browser-heading{min-width:0;}

.splash-showcase{width:min(100%,660px);max-width:100%;min-height:clamp(560px,62vw,760px);padding:clamp(22px,4vw,42px);overflow:hidden;}
.splash-live-row{position:absolute;left:clamp(18px,4vw,52px);right:clamp(18px,4vw,52px);bottom:clamp(22px,5vw,54px);display:flex;align-items:flex-end;justify-content:center;gap:clamp(14px,3vw,34px);max-width:100%;}
.embed-phone{position:relative;min-width:0;filter:drop-shadow(0 34px 58px rgba(0,0,0,.28));}
.splash-embed-phone{width:min(260px,43vw);}
.splash-embed-phone.is-secondary{width:min(210px,34vw);transform:translateY(28px);opacity:.96;}
.embed-phone-chrome,.live-device-top{height:32px;background:#090909;border:1px solid rgba(255,255,255,.14);border-bottom:0;display:flex;align-items:center;gap:7px;padding-inline:14px;}
.embed-phone-chrome span,.live-device-top span{display:block;width:7px;height:7px;border-radius:99px;background:rgba(255,255,255,.38);}
.embed-phone-screen,.live-device-screen{position:relative;width:100%;aspect-ratio:390/760;overflow:hidden;background:#fff;border:9px solid #090909;border-top:0;box-shadow:0 0 0 1px rgba(255,255,255,.08) inset;}
.embed-phone-screen iframe,.live-device-screen iframe{position:absolute;inset:0;width:100%;height:100%;border:0;background:#fff;opacity:1;pointer-events:auto;}
.embed-phone-screen img,.live-device-screen img{width:100%;height:100%;object-fit:cover;object-position:top center;}
.embed-phone-caption{display:block;margin-top:10px;font-size:11px;font-weight:950;letter-spacing:.08em;text-transform:uppercase;text-align:center;color:rgba(7,7,7,.74);}
html[lang="th"] .embed-phone-caption{letter-spacing:0;text-transform:none;}

.live-preview-work{overflow:hidden;background:#faf5ec;}
.live-case-list{overflow:visible;}
.live-case{max-width:100%;overflow:hidden;padding:clamp(28px,5vw,76px);}
.live-device{width:min(390px,100%);max-width:100%;margin-inline:auto;filter:drop-shadow(0 34px 58px rgba(0,0,0,.24));}
.embedded-live-device .live-device-screen{border-top:0;aspect-ratio:390/760;}
.embedded-live-device .live-frame{opacity:1;pointer-events:auto;transition:none;}
.embedded-live-device .live-shot{display:none;}
.live-device-actions{display:none!important;}
.live-case-copy{min-width:0;}
.live-case-copy h3{overflow-wrap:anywhere;}
.live-case-copy p{overflow-wrap:break-word;}

.project-grid,.portfolio-grid-clean{max-width:100%;overflow:hidden;}
.project-card,.project-media,.project-info{min-width:0;}
.project-media{max-width:100%;}
.portfolio-control-bar{max-width:calc(100vw - 32px);}
.clean-search input,.select-box select{min-width:0;width:100%;}

@media (min-width:900px){
  .live-case{grid-template-columns:minmax(300px,.58fr) minmax(0,1fr);}
  .live-case.is-even{grid-template-columns:minmax(0,1fr) minmax(300px,.58fr);}
  .live-case-list.compact .live-case{grid-template-columns:minmax(300px,.54fr) minmax(0,1fr);}
  .live-case-list.compact .live-case.is-even{grid-template-columns:minmax(0,1fr) minmax(300px,.54fr);}
}
@media (min-width:1180px){
  .live-device{width:390px;}
  .live-case-list.compact .live-device{width:370px;}
  .splash-showcase{transform:none;}
}
@media (max-width:859px){
  .splash-showcase{min-height:560px;padding:22px;}
  .splash-live-row{left:18px;right:18px;bottom:28px;gap:12px;}
  .splash-embed-phone{width:min(230px,52vw);}
  .splash-embed-phone.is-secondary{width:min(168px,38vw);transform:translateY(20px);}
  .embed-phone-screen,.live-device-screen{border-width:7px;border-top:0;}
  .live-case{padding:24px 18px 32px;}
  .live-device{width:min(330px,88vw);}
  .live-case-copy h3{font-size:clamp(34px,10vw,52px);}
}
@media (max-width:520px){
  .shell{width:min(100% - 28px,var(--max));max-width:calc(100vw - 28px);}
  .splash-showcase{min-height:500px;}
  .splash-showcase-copy strong{max-width:280px;}
  .splash-live-row{bottom:24px;}
  .splash-embed-phone{width:min(218px,56vw);}
  .splash-embed-phone.is-secondary{width:min(152px,39vw);}
  .live-device{width:min(312px,88vw);}
  .portfolio-control-bar{max-width:calc(100vw - 28px);}
}
@supports not (overflow:clip){main,section,.site-header,.mobile-menu{overflow-x:hidden;}}


/* v2026-06-07g: project image migration + graceful fallback
   Old portfolio thumbnails can be restored by uploading them to assets/img/projects/
   with their original WordPress filenames. Until then, failed legacy images fall back
   to generated live-site screenshots; if those also fail, a branded preview card is shown. */
.project-media[data-fallback-title]{position:relative;background:linear-gradient(135deg,#111 0%,#201006 62%,#f37021 140%);}
.project-media.image-fallback{min-height:240px;display:flex;align-items:flex-end;overflow:hidden;border:1px solid rgba(7,7,7,.1);box-shadow:0 24px 70px rgba(0,0,0,.08);}
.project-media.image-fallback:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.055) 1px,transparent 1px),linear-gradient(0deg,rgba(255,255,255,.04) 1px,transparent 1px),radial-gradient(circle at 76% 18%,rgba(243,112,33,.45),transparent 35%);background-size:42px 42px,42px 42px,auto;opacity:.85;}
.project-media.image-fallback:after{content:attr(data-fallback-title) "\A" attr(data-fallback-category);position:relative;z-index:1;white-space:pre-line;color:#fff;padding:22px;font-family:"Space Grotesk",Inter,sans-serif;font-size:clamp(24px,4.5vw,42px);font-weight:800;line-height:1;letter-spacing:-.06em;text-shadow:0 10px 30px rgba(0,0,0,.28);}
html[lang="th"] .project-media.image-fallback:after{font-family:"Noto Sans Thai",Inter,sans-serif;letter-spacing:-.035em;line-height:1.08;}
.project-media.image-fallback img{display:none!important;}
.project-media.image-fallback .project-overlay{display:none!important;}
.portfolio-grid-clean .project-media.image-fallback,.work-grid .project-media.image-fallback{aspect-ratio:16/11;}
@media (min-width:980px){.work-grid .project-card:nth-child(10n+5) .project-media.image-fallback,.work-grid .project-card:nth-child(10n+9) .project-media.image-fallback{aspect-ratio:4/5;}}
