:root{color:#171717;font-synthesis:none;text-rendering:optimizelegibility;--purple:#80549a;--purple-dark:#5d3573;--ink:#181818;--muted:#66666b;--line:#e8e5e1;--surface:#f5f5f2;--wood:#a46d42;--green:#247464;--shadow:0 18px 45px #1818181f;background:#fff;font-family:Inter,Noto Sans Thai,Helvetica Neue,Arial,system-ui,sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{min-width:320px;color:var(--ink);background:#fff;margin:0}:is(body:has(.modal-backdrop),body:has(.mobile-panel),body:has(.portfolio-carousel-backdrop)){overflow:hidden}a{color:inherit;text-decoration:none}button,input{font:inherit}img{max-width:100%;display:block}.site-header{z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff5;border-bottom:1px solid #e8e5e1cc;position:sticky;top:0}.header-inner{justify-content:space-between;align-items:center;gap:28px;width:min(100%,1180px);height:82px;margin:0 auto;padding:0 22px;display:flex}.logo-link{flex:none;justify-content:flex-start;align-items:center;min-width:194px;height:82px;margin:0 -18px 0 -10px;padding:0 34px 0 10px;display:inline-flex}.logo-link img{object-fit:contain;width:auto;height:64px}.desktop-nav{flex:auto;justify-content:flex-end;align-items:center;gap:10px;display:flex}.nav-link{color:#1d1d1f;border-radius:4px;align-items:center;gap:5px;min-height:42px;padding:10px 16px;font-weight:600;transition:color .16s,background-color .16s;display:inline-flex}.nav-link:hover,.nav-link.active,.nav-link[aria-current=page]{color:#fff;background:var(--purple)}.nav-parent{position:relative}.nav-dropdown{border:1px solid var(--line);width:230px;box-shadow:var(--shadow);opacity:0;visibility:hidden;background:#fff;border-radius:8px;gap:3px;padding:10px;transition:opacity .16s,transform .16s,visibility .16s;display:grid;position:absolute;top:calc(100% + 12px);left:0;transform:translateY(8px)}.nav-parent:hover .nav-dropdown,.nav-parent:focus-within .nav-dropdown{opacity:1;visibility:visible;transform:translateY(0)}.nav-dropdown a{color:var(--ink);border-radius:6px;padding:10px 12px;font-weight:600}.nav-dropdown a:hover,.nav-dropdown a[aria-current=page]{color:var(--purple-dark);background:#f4edf8}.header-actions{align-items:center;gap:8px;display:flex}.icon-button{width:42px;height:42px;color:var(--ink);cursor:pointer;background:0 0;border:0;border-radius:50%;place-items:center;transition:background-color .16s,color .16s;display:inline-grid}.icon-button:hover{color:var(--purple-dark);background:#f2edf5}.mobile-toggle{display:none}.mobile-panel,.modal-backdrop{z-index:80;background:#1212145c;position:fixed;inset:0}.mobile-panel{display:none}.mobile-panel-header{border-bottom:1px solid var(--line);background:#fff;justify-content:space-between;align-items:center;width:min(92vw,420px);margin-left:auto;padding:20px;display:flex}.mobile-panel-header img{object-fit:contain;width:auto;height:58px}.mobile-nav{background:#fff;align-content:start;gap:4px;width:min(92vw,420px);min-height:calc(100vh - 82px);margin-left:auto;padding:18px;display:grid}.mobile-nav-group{gap:4px;display:grid}.mobile-nav a{border-radius:6px;padding:13px 14px;font-weight:700}.mobile-nav a[aria-current=page]{color:#fff;background:var(--purple)}.mobile-child{color:var(--muted);margin-left:14px;font-weight:600!important}.modal-backdrop{place-items:start center;padding:110px 18px 24px;display:grid}.search-modal{width:min(760px,100%);box-shadow:var(--shadow);background:#fff;border-radius:8px;overflow:hidden}.search-modal-head{border-bottom:1px solid var(--line);grid-template-columns:42px 1fr 42px;align-items:center;gap:8px;padding:14px 18px;display:grid}.search-modal-head input{border:0;outline:0;width:100%;font-size:1.1rem}.search-results{max-height:62vh;padding:12px;overflow:auto}.search-result{border-radius:8px;gap:4px;min-height:66px;padding:13px 14px;display:grid}.search-result:hover{background:#f4edf8}.search-result span{font-weight:800}.search-result small{color:var(--muted);line-height:1.5}.empty-state{color:var(--muted);text-align:center;margin:0;padding:26px}.hero{color:#fff;background:#1d1714;place-items:center;min-height:640px;display:grid;position:relative;overflow:hidden}.hero-slides,.hero-slide{position:absolute;inset:0}.hero-slide{opacity:0;background-position:50%;background-size:cover;transition:opacity .9s;transform:scale(1.055)}.hero-slide.active{opacity:1;animation:6.5s ease-out both heroImageDrift}.hero-overlay{background:linear-gradient(#00000061,#00000061),radial-gradient(circle at 50% 45%,#00000014,#00000061);position:absolute;inset:0}.hero-content{text-align:center;justify-items:center;gap:24px;width:min(980px,100% - 32px);animation:.76s cubic-bezier(.2,.7,.2,1) both heroCopyIn;display:grid;position:relative}.hero h1{white-space:pre-line;max-width:800px;margin:0;font-size:4.25rem;font-weight:500;line-height:1.22}.hero-content p{color:#ffffffe0;max-width:760px;margin:-4px 0 30px;font-size:1.14rem;font-weight:600;line-height:1.8}.hero-cta,.button-link{cursor:pointer;border:0;border-radius:999px;justify-content:center;align-items:center;gap:10px;min-height:46px;padding:11px 24px;font-weight:800;transition:transform .16s,background-color .16s,color .16s;display:inline-flex}.hero-cta{color:var(--ink);background:#fff}.hero-cta:hover,.button-link:hover{transform:translateY(-1px)}.hero-dots{gap:9px;display:flex;position:absolute;bottom:28px;left:50%;transform:translate(-50%)}.hero-dots button{color:#0000;cursor:pointer;background:#ffffff38;border:1px solid #ffffffc7;border-radius:50%;width:12px;height:12px;padding:0}.hero-dots button span{clip:rect(0 0 0 0);width:1px;height:1px;position:absolute;overflow:hidden}.hero-dots button.active{background:#fff}.hero-progress{background:#ffffff38;height:4px;position:absolute;bottom:0;left:0;right:0}.hero-progress span{background:var(--purple);transform-origin:0;width:100%;height:100%;animation:6.5s linear forwards heroProgress;display:block;transform:scaleX(0)}@keyframes heroImageDrift{0%{transform:scale(1.055)}to{transform:scale(1)}}@keyframes heroCopyIn{0%{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}@keyframes heroProgress{0%{transform:scaleX(0)}to{transform:scaleX(1)}}@media (prefers-reduced-motion:reduce){.hero-slide,.hero-slide.active,.hero-content,.hero-progress span{transition:none;animation:none}.hero-slide{transform:scale(1)}.hero-progress span{transform:scaleX(1)}}.section{width:min(1180px,100% - 40px);margin:0 auto;padding:72px 0;scroll-margin-top:82px}.narrow-section{width:min(860px,100% - 40px)}.muted-band{background:var(--surface);width:100%;max-width:none;padding-left:max(20px,50% - 590px);padding-right:max(20px,50% - 590px)}.section-title{text-align:center;justify-items:center;gap:8px;margin:0 auto 38px;display:grid}.section-title h2{margin:0;font-size:2.1rem;font-weight:800;line-height:1.25}.section-title p{color:var(--muted);margin:0;font-size:1.02rem}.eyebrow{text-transform:uppercase;font-weight:900;color:var(--purple-dark)!important;font-size:.82rem!important}.lead-text{color:#333336;text-align:center;margin:0;font-size:1.16rem;line-height:2}.service-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:20px;display:grid}.service-card{border:1px solid var(--line);text-align:center;background:#fff;border-radius:8px;align-content:start;justify-items:center;gap:14px;min-height:250px;padding:28px 22px;display:grid}.service-card.compact{min-height:186px}.service-card img{object-fit:contain;width:86px;height:86px}.service-card h3,.category-card h3,.product-card h3,.feature-link h2,.prep-card h2,.property-card h2,.service-detail h2,.contact-panel h2,.product-copy h2{margin:0;line-height:1.35}.service-card p,.category-card p,.product-card p,.feature-link p,.prep-card p,.property-card p,.service-detail p,.contact-panel p,.product-copy p,.category-hero p{color:var(--muted);margin:0;line-height:1.75}.category-grid,.product-grid,.property-grid,.knowledge-grid,.contact-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;display:grid}.category-card,.product-card,.feature-link,.property-card,.prep-card,.contact-panel{border:1px solid var(--line);background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 12px 28px #1818180f}.category-card{transition:transform .16s,box-shadow .16s;display:grid}.category-card:hover,.product-card:hover,.feature-link:hover,.portfolio-item:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.category-card img,.product-image,.feature-link img,.property-card img,.prep-card img{aspect-ratio:16/10;object-fit:cover;background:#eee;width:100%}.category-card div,.product-body,.feature-link div,.property-card div,.prep-card div{gap:10px;padding:20px;display:grid}.category-card h3 span{color:var(--purple-dark)}.product-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.product-card{transition:transform .16s,box-shadow .16s;display:grid}.product-image{display:block;overflow:hidden}.product-image img{object-fit:cover;width:100%;height:100%}.text-link{color:var(--purple-dark);align-items:center;gap:8px;font-weight:900;display:inline-flex}.center-action{justify-content:center;margin-top:34px;display:flex}.button-link{color:#fff;background:var(--purple)}.button-link:hover{background:var(--purple-dark)}.page-banner{color:#fff;background:var(--purple);place-items:center;padding:34px 20px;display:grid}.page-banner h1{text-align:center;margin:0;font-size:2.5rem;font-weight:700;line-height:1.3}.knowledge-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.feature-link{transition:transform .16s,box-shadow .16s;display:grid}.feature-link span{color:var(--purple-dark);align-items:center;gap:8px;font-weight:900;display:inline-flex}.prep-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:24px;display:grid}.prep-card,.property-card{display:grid}.service-detail-grid{gap:18px;display:grid}.service-detail{border:1px solid var(--line);background:#fff;border-radius:8px;grid-template-columns:1fr 1fr;align-items:center;min-height:260px;display:grid;overflow:hidden}.service-detail.alt{background:var(--surface)}.service-detail img{object-fit:contain;width:100%;height:100%;max-height:300px;padding:56px}.service-detail div{gap:16px;padding:44px;display:grid}.category-detail{padding-bottom:40px}.category-hero,.product-detail{grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);align-items:center;gap:42px;display:grid}.category-hero img,.product-media img{aspect-ratio:16/11;object-fit:cover;width:100%;box-shadow:var(--shadow);border-radius:8px}.category-hero div,.product-copy{gap:16px;display:grid}.product-copy h2,.category-hero h2{font-size:2.2rem}.tag-row{flex-wrap:wrap;gap:9px;display:flex}.tag-row a{color:var(--purple-dark);background:#f4edf8;border-radius:999px;padding:8px 12px;font-size:.92rem;font-weight:800}.spec-list{gap:12px;margin:8px 0 10px;padding:0;list-style:none;display:grid}.spec-list li{color:#303033;grid-template-columns:22px 1fr;align-items:start;gap:10px;line-height:1.6;display:grid}.spec-list svg{color:var(--green);margin-top:3px}.portfolio-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;display:grid}.portfolio-item{aspect-ratio:4/5;background:var(--surface);cursor:zoom-in;border:0;border-radius:8px;padding:0;transition:transform .16s,box-shadow .16s;display:block;overflow:hidden;box-shadow:0 12px 26px #18181814}.portfolio-item img{object-fit:cover;width:100%;height:100%}.portfolio-carousel-backdrop{z-index:90;background:#0a0a0cdb;place-items:center;padding:28px;display:grid;position:fixed;inset:0}.carousel-dismiss{cursor:zoom-out;background:0 0;border:0;position:absolute;inset:0}.portfolio-carousel{z-index:1;grid-template-columns:58px minmax(0,1fr) 58px;align-items:center;gap:18px;width:min(1120px,100%);min-height:min(760px,100vh - 56px);display:grid;position:relative}.portfolio-carousel figure{justify-items:center;gap:12px;margin:0;display:grid}.portfolio-carousel figure img{object-fit:contain;background:#fff;border-radius:8px;max-width:100%;max-height:calc(100vh - 118px);box-shadow:0 24px 70px #00000059}.portfolio-carousel figcaption{color:#fff;text-align:center;background:#ffffff29;border-radius:999px;min-width:74px;padding:7px 13px;font-weight:800}.carousel-arrow,.carousel-close{color:#fff;cursor:pointer;background:#ffffff24;border:0;place-items:center;transition:transform .16s,background-color .16s;display:inline-grid}.carousel-arrow{border-radius:50%;width:58px;height:58px}.carousel-arrow:hover,.carousel-close:hover{background:#ffffff3d;transform:translateY(-1px)}.carousel-close{position:absolute;top:0;right:0}.contact-section{gap:28px;display:grid}.contact-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.contact-panel{gap:16px;padding:28px;display:grid}.contact-line{color:#333336;grid-template-columns:24px 1fr;align-items:start;gap:12px;min-width:0;line-height:1.65;display:grid}.contact-line:hover{color:var(--purple-dark)}.contact-line svg{color:var(--purple);margin-top:4px}.map-preview{border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow);border-radius:8px;overflow:hidden}.map-preview iframe{border:0;width:100%;height:min(58vw,460px);min-height:340px;display:block}.map-link{min-height:54px;color:var(--purple-dark);background:#fff;align-items:center;gap:8px;padding:14px 18px;font-weight:800;display:inline-flex}.map-link:hover{color:var(--purple)}.floating-actions{z-index:40;gap:10px;display:grid;position:fixed;bottom:22px;right:22px}.floating-actions a{color:#fff;background:var(--purple);width:52px;height:52px;box-shadow:var(--shadow);border-radius:50%;place-items:center;display:grid}.floating-actions a:last-child{background:var(--green)}.site-footer{color:#fff;background:#202024}.footer-inner{grid-template-columns:.85fr 1.3fr auto;align-items:start;gap:34px;width:min(1180px,100% - 40px);margin:0 auto;padding:46px 0;display:grid}.footer-inner img{object-fit:contain;background:#fff;border-radius:6px;width:auto;height:86px;padding:8px 10px}.footer-inner p{color:#ffffffc7;margin:14px 0 0}.footer-links{gap:10px;display:grid}.footer-links .contact-line{color:#ffffffd1}.footer-links .contact-line:hover{color:#fff}.footer-links .contact-line svg{color:#c7a7d7}.footer-service-icons{color:#c7a7d7;flex-wrap:wrap;gap:12px;display:flex}.footer-service-icons svg{width:26px;height:26px}@media (width<=980px){.desktop-nav{display:none}.mobile-toggle,.mobile-panel{display:block}.hero{min-height:560px}.hero h1{font-size:3.2rem}.hero-content p{font-size:1.04rem}.service-grid,.category-grid,.product-grid,.property-grid,.portfolio-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.service-detail,.category-hero,.product-detail,.footer-inner{grid-template-columns:1fr}.service-detail img{max-height:220px}.footer-service-icons{justify-content:flex-start}}@media (width<=720px){.header-inner{height:74px;padding:0 16px}.logo-link{min-width:166px;height:74px;margin:0 -12px 0 -8px;padding:0 24px 0 8px}.logo-link img{height:56px}.hero{min-height:500px}.hero-content{gap:20px}.hero h1{font-size:2.45rem}.hero-content p{margin-bottom:22px;font-size:.98rem;line-height:1.75}.hero-dots{bottom:22px;right:auto}.section,.narrow-section{width:min(100% - 28px,1180px);padding:52px 0}.muted-band{width:100%;padding-left:14px;padding-right:14px}.page-banner{padding:28px 14px}.page-banner h1{font-size:2rem}.section-title{margin-bottom:28px}.section-title h2{font-size:1.72rem}.lead-text{text-align:left;font-size:1.02rem;line-height:1.85}.service-grid,.category-grid,.product-grid,.property-grid,.knowledge-grid,.prep-grid,.portfolio-grid,.contact-grid{grid-template-columns:1fr}.service-detail div{padding:28px}.service-detail img{padding:32px}.product-copy h2,.category-hero h2{font-size:1.8rem}.floating-actions{bottom:16px;right:16px}.floating-actions a{width:48px;height:48px}.portfolio-carousel-backdrop{padding:16px}.portfolio-carousel{grid-template-columns:1fr 1fr;grid-template-areas:"image image""prev next";align-content:center;gap:14px;width:100%;min-height:calc(100vh - 32px)}.portfolio-carousel figure{grid-area:image}.portfolio-carousel figure img{max-height:calc(100vh - 150px)}.carousel-prev{grid-area:prev;justify-self:end}.carousel-next{grid-area:next;justify-self:start}.carousel-close{top:-4px;right:-4px}}@media (width<=430px){.hero h1{font-size:2.05rem}.hero-cta,.button-link{width:100%}.hero-dots button{width:10px;height:10px}.contact-panel,.category-card div,.product-body,.feature-link div,.property-card div,.prep-card div{padding:18px}}
