/* ══════════════════════════════════════
   DOPIOUS+ — main.css
   โหลดแบบ async ไม่ block render
══════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--r:#ff2a14;--bg:#050505;--ln:rgba(255,255,255,.08);--t2:rgba(255,255,255,.55)}
html{-webkit-text-size-adjust:100%;overflow-x:hidden}
body{background:var(--bg);color:#fff;font-family:'DM Sans','Noto Sans Thai',Arial,sans-serif;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a,button{-webkit-tap-highlight-color:transparent;touch-action:manipulation;text-decoration:none;cursor:pointer}
img{max-width:100%;display:block}button{font-family:inherit}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:300;height:62px;display:flex;align-items:center;justify-content:space-between;padding:0 max(28px,env(safe-area-inset-left));background:rgba(5,5,5,.95);border-bottom:1px solid var(--ln)}
.logo{font-size:27px;font-weight:900;letter-spacing:-.06em;color:#fff}.logo em{color:var(--r);font-style:normal}
.nl{display:flex;gap:22px;align-items:center}
.nl button{background:none;border:none;color:rgba(255,255,255,.52);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:7px 0;transition:color .14s}
.nl button:hover{color:#fff}
.nbs{background:var(--r)!important;color:#fff!important;border-radius:999px!important;padding:8px 14px!important;font-size:11px!important;font-weight:900!important;letter-spacing:.09em!important}
.mbg{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:7px}
.mbg span{width:20px;height:2px;background:#fff;border-radius:2px}
.mpn{position:fixed;inset:0;z-index:400;background:rgba(5,5,5,.98);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;opacity:0;visibility:hidden;transition:.17s}
.mpn.on{opacity:1;visibility:visible}
.mpn button{background:none;border:none;color:#fff;font-size:20px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}
.mpn .mx{position:absolute;top:15px;right:15px;font-size:26px}

/* HERO */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;padding:104px max(36px,env(safe-area-inset-left)) 72px;overflow:hidden;background:radial-gradient(circle at 76% 8%,rgba(255,42,20,.13),transparent 32%) var(--bg)}
.hc{width:min(1060px,94vw);display:flex;flex-direction:column;align-items:center;text-align:center;transition:opacity .1s,transform .1s}
.hc.fd{opacity:0;transform:translateY(8px)}
.ey{font-size:11px;letter-spacing:.33em;text-transform:uppercase;color:rgba(255,255,255,.38);margin-bottom:12px}
.hero h1{font-size:clamp(50px,8vw,110px);font-weight:900;letter-spacing:-.07em;line-height:.92;text-wrap:balance}
.hero h1 em{display:block;font-style:normal;font-weight:300;margin-top:5px}
.hi{max-width:680px;margin:17px auto 0;color:var(--t2);font-size:16px;line-height:1.55;text-align:center}
.hi strong{display:block;color:#fff;font-size:clamp(15px,1.8vw,20px);font-weight:900;letter-spacing:-.02em;margin-bottom:4px}
.tg{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-top:11px}
.tg em{font-style:normal;border:1px solid rgba(255,255,255,.11);color:rgba(255,255,255,.66);border-radius:999px;padding:6px 10px;font-size:10px;font-weight:900;letter-spacing:.14em;text-transform:uppercase;background:rgba(255,255,255,.03)}
.cta{display:flex;gap:10px;margin-top:22px;justify-content:center;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;font-weight:900;font-size:12px;letter-spacing:.1em;text-transform:uppercase;padding:13px 22px;transition:.14s;min-height:48px;border:none}
.br{background:var(--r);color:#fff}.br:hover{background:#e0240f}
.bg2{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.23)}.bg2:hover{border-color:rgba(255,255,255,.54)}
.dots{display:flex;gap:8px;margin-top:24px}
.dots span{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.2);cursor:pointer;transition:.18s}
.dots span.on{background:#fff;width:16px;border-radius:3px}
.hero.hbg{background:radial-gradient(circle at 78%,rgba(255,42,20,.13),transparent 34%),linear-gradient(135deg,#050505,#0c0c0c 48%,#151515)!important}

/* MARQUEE */
.mq{border-top:1px solid var(--ln);border-bottom:1px solid var(--ln);background:#0a0a0a;overflow:hidden;white-space:nowrap}
.mq div{display:inline-block;padding:12px 0;font-weight:900;font-size:12px;letter-spacing:.12em;animation:mqa 28s linear infinite;color:#ccc;animation-play-state:var(--mqp,running)}
.mq span{color:var(--r);margin:0 14px}
@keyframes mqa{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* SECTION */
section{padding:64px max(36px,env(safe-area-inset-left))}
.shd{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:22px}
.stg{font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--r);font-weight:900}
.sti{font-size:clamp(34px,5vw,64px);font-weight:900;letter-spacing:-.06em;line-height:1;margin-top:3px}
.sct{font-size:11px;color:rgba(255,255,255,.3);letter-spacing:.11em;text-transform:uppercase}

/* SERVICE GRID */
#sG{display:grid;grid-template-columns:1fr;gap:12px}
.sc{position:relative;width:100%;aspect-ratio:16/9;border-radius:11px;overflow:hidden;background:#111;border:1px solid rgba(255,255,255,.07);-webkit-tap-highlight-color:transparent}
.sl{position:absolute;inset:0;opacity:0;transition:opacity .2s linear;z-index:1}
.sl.on{opacity:1;z-index:2}
.sl img{width:100%;height:100%;object-fit:cover;position:relative;z-index:1}
.sl .lq{position:absolute;inset:0;background-size:cover;background-position:center;filter:blur(14px);transform:scale(1.08);transition:opacity .4s;z-index:0}
.sov{position:absolute;inset:0;z-index:3;background:linear-gradient(to right,rgba(0,0,0,.58),rgba(0,0,0,.08) 55%),linear-gradient(to top,rgba(0,0,0,.68),transparent 52%);pointer-events:none}
.sp{position:absolute;left:20px;right:20px;top:18px;z-index:5;display:flex;align-items:center;justify-content:space-between;gap:8px}
.snm{font-size:11px;font-weight:950;letter-spacing:.16em;text-transform:uppercase;color:#fff;text-shadow:0 1px 10px rgba(0,0,0,.8);max-width:56%;pointer-events:none}
.sct2{display:flex;align-items:center;gap:7px}
.snv{width:46px;height:46px;border-radius:50%;border:1px solid rgba(255,255,255,.17);background:rgba(40,40,40,.88);color:#fff;font-size:18px;display:flex;align-items:center;justify-content:center;z-index:6;position:relative}
.scn{font-size:11px;font-weight:900;color:rgba(255,255,255,.62);min-width:30px;text-align:center;pointer-events:none}
.slb{position:absolute;left:20px;right:20px;bottom:18px;z-index:5;text-shadow:0 1px 12px rgba(0,0,0,.9);pointer-events:none}
.slb span{display:block;font-size:11px;font-weight:900;letter-spacing:.1em;text-transform:uppercase;color:#fff;line-height:1.2}
.stp{position:absolute;inset:0;z-index:4;background:transparent;border:none;outline:none;-webkit-appearance:none;touch-action:manipulation;-webkit-tap-highlight-color:transparent}
.sk{animation:ska 1.4s ease infinite}
@keyframes ska{0%,100%{opacity:.45}50%{opacity:.8}}

/* CLIENTS */
.cls{background:var(--bg);padding:56px max(36px,env(safe-area-inset-left));text-align:center;content-visibility:auto;contain-intrinsic-size:0 260px}
.cls-t{font-size:17px;margin-bottom:5px}.cls-t strong{font-weight:900}
.cls-s{font-size:14px;letter-spacing:.1em;margin-bottom:24px;color:var(--t2)}
.cg{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;max-width:840px;margin:0 auto}
.cl{height:60px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.06);background:#080808;border-radius:9px;overflow:hidden;padding:8px;filter:grayscale(1);transition:.18s;color:rgba(255,255,255,.35);font-size:11px;font-weight:700}
.cl:hover{filter:grayscale(.2);border-color:rgba(255,255,255,.13)}
.cl img{width:100%;height:100%;object-fit:contain;opacity:.62}.cl:hover img{opacity:1}

/* CONTACT */
.cs{background:var(--r);padding:42px max(36px,env(safe-area-inset-left)) 0;text-align:center;content-visibility:auto;contain-intrinsic-size:0 320px}
.cs h2{font-size:clamp(24px,4vw,46px);letter-spacing:.1em;font-weight:300;margin-bottom:12px}
.cs h2 strong{font-weight:950}
.cs p{font-size:clamp(12px,1.6vw,15px);line-height:1.5;max-width:620px;margin:0 auto 20px;text-transform:uppercase;font-weight:700}
.cr{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;margin-bottom:24px}
.eb{display:flex;background:#fff;border-radius:999px;padding:4px;max-width:340px;width:100%}
.eb input{flex:1;border:none;outline:none;background:transparent;padding:8px 12px;text-align:center;text-transform:uppercase;color:#333;font-family:inherit;font-size:12px;-webkit-appearance:none}
.eb button{border:none;background:transparent;color:var(--r);font-size:18px;width:36px}
.scs{display:flex;gap:10px}
.sc2{font-size:17px;font-weight:900;color:#fff;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}
.og{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid rgba(255,255,255,.2);padding:14px 0 12px;font-size:11px}
.of{padding:0 12px;border-right:1px solid rgba(255,255,255,.2)}.of:last-child{border-right:0}
.of b{font-size:10px;color:rgba(255,255,255,.54)}
.ft{display:flex;justify-content:space-between;align-items:center;background:var(--bg);padding:13px max(36px,env(safe-area-inset-left)) max(13px,calc(env(safe-area-inset-bottom)+7px));color:rgba(255,255,255,.36);font-size:12px}
.al{background:none;border:none;color:rgba(255,255,255,.07);font-size:10px;text-transform:uppercase;letter-spacing:.16em;padding:4px;min-height:44px}

/* OVERLAY */
.pg{position:fixed;inset:0;z-index:500;background:var(--bg);color:#fff;overflow-y:scroll;-webkit-overflow-scrolling:touch;opacity:0;visibility:hidden;transition:.15s;overscroll-behavior:contain}
.pg.on{opacity:1;visibility:visible}
.pt{position:sticky;top:0;z-index:5;height:62px;display:flex;align-items:center;justify-content:space-between;padding:0 max(26px,env(safe-area-inset-left));background:rgba(5,5,5,.97);border-bottom:1px solid var(--ln)}
.pbk{border:1px solid rgba(255,255,255,.14);background:#0d0d0d;color:#fff;border-radius:999px;padding:9px 13px;font-size:11px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;min-height:44px}

/* PROJECT DETAIL */
#pd .dh{padding:52px max(36px,env(safe-area-inset-left)) 24px;background:radial-gradient(circle at 72% 0%,rgba(255,42,20,.14),transparent 28%),var(--bg)}
#pd .dc{font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--r);font-weight:900;margin-bottom:10px}
#pd .dn{font-size:clamp(32px,5.5vw,70px);line-height:.92;letter-spacing:-.075em;font-weight:950;max-width:920px}
#pd .dm{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;max-width:740px;margin-top:14px}
#pd .db{border:1px solid rgba(255,255,255,.09);background:#0c0c0c;border-radius:10px;padding:12px}
#pd .db small{display:block;color:rgba(255,255,255,.28);font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:900}
#pd .db b{display:block;margin-top:4px;font-size:14px}
#pd .ds{padding:0 max(36px,env(safe-area-inset-left)) 26px;color:rgba(255,255,255,.55);font-size:15px;line-height:1.65;max-width:780px}
.di{width:100%;aspect-ratio:16/9;background:#111;overflow:hidden;position:relative;margin-bottom:5px}
.di img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.di .lq{position:absolute;inset:0;background-size:cover;background-position:center;filter:blur(12px);transform:scale(1.06);z-index:0;transition:opacity .4s}
.dv{position:relative;width:100%;aspect-ratio:16/9;background:#000;margin-bottom:5px}
.dv iframe,.dv video{position:absolute;inset:0;width:100%;height:100%;border:0}
.dsc{padding:30px max(36px,env(safe-area-inset-left));border-top:1px solid var(--ln)}
.dsc h3{font-size:clamp(18px,2.6vw,27px);letter-spacing:-.05em;font-weight:900;margin-bottom:6px}
.dsc p{color:rgba(255,255,255,.48);font-size:14px;line-height:1.6}

/* POPUP */
.pop{position:fixed;inset:0;z-index:600;background:rgba(0,0,0,.82);display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;visibility:hidden;transition:.15s;overflow:auto;-webkit-overflow-scrolling:touch}
.pop.on{opacity:1;visibility:visible}
.pc{background:#0d0d0d;border:1px solid rgba(255,255,255,.09);border-radius:22px;padding:24px 20px;max-width:440px;width:100%;position:relative}
.pc h3{font-size:clamp(25px,5vw,36px);font-weight:900;letter-spacing:-.06em;line-height:.93;margin-bottom:4px}
.pc h3 em{color:var(--r);font-style:normal}
.psb{font-size:11px;color:rgba(255,255,255,.38);letter-spacing:.07em;text-transform:uppercase;margin-bottom:18px}
.ccg{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:14px}
.ccb{display:flex;align-items:center;gap:10px;padding:11px 12px;border:1px solid rgba(255,255,255,.09);background:#111;border-radius:11px;color:#fff;text-align:left;transition:.14s;-webkit-tap-highlight-color:transparent;min-height:56px}
.ccb:hover{border-color:rgba(255,255,255,.2);background:#181818}
.cci{width:34px;height:34px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:900;flex-shrink:0}
.ccc b{display:block;font-size:12px;font-weight:900}
.ccc span{display:block;font-size:10px;color:rgba(255,255,255,.34);margin-top:1px}
.px2{position:absolute;top:12px;right:12px;background:rgba(255,255,255,.06);border:none;color:#fff;border-radius:50%;width:28px;height:28px;font-size:15px;display:flex;align-items:center;justify-content:center}
.poi{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;border-top:1px solid var(--ln);padding-top:12px;font-size:10px;color:rgba(255,255,255,.4)}
.poi b{display:block;color:#fff;font-size:11px;margin-top:2px}

/* PAGES */
.who-hero,.how-hero,.cont-hero{padding:52px max(36px,env(safe-area-inset-left)) 32px}
.who-hero h2,.how-hero h2,.cont-hero h2{font-size:clamp(36px,7vw,80px);font-weight:900;letter-spacing:-.07em;line-height:.9;margin-bottom:22px}
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;margin-top:28px}
.tm{display:flex;flex-direction:column;gap:8px}
.tm-ph{aspect-ratio:4/5;background:#111;border-radius:3px;overflow:hidden}
.tm-ph img{width:100%;height:100%;object-fit:cover;object-position:center top}
.tm b{font-size:11px;letter-spacing:.11em;text-transform:uppercase;display:block}
.tm span{font-size:10px;color:rgba(255,255,255,.4);display:block;margin-top:1px}
.steps{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;max-width:820px}
.step{border:1px solid rgba(255,255,255,.08);background:#0c0c0c;border-radius:13px;padding:18px}
.step-n{color:var(--r);font-size:11px;letter-spacing:.2em;text-transform:uppercase;font-weight:900;margin-bottom:5px}
.step b{font-size:17px;font-weight:900;display:block;margin-bottom:4px}
.step p{color:rgba(255,255,255,.46);font-size:13px;line-height:1.55}
.cont-links{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:9px;max-width:640px}
.cont-a{display:flex;align-items:center;gap:10px;border:1px solid rgba(255,255,255,.08);background:#0c0c0c;border-radius:13px;padding:14px;color:#fff;min-height:64px}
.cont-a:hover{border-color:rgba(255,255,255,.18)}
.ca-ic{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:900;flex-shrink:0}

/* ADMIN LOGIN */
.alo{position:fixed;inset:0;z-index:800;background:rgba(0,0,0,.88);display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;visibility:hidden;transition:.15s;overflow:auto}
.alo.on{opacity:1;visibility:visible}
.alc{background:#0d0d0d;border:1px solid rgba(255,255,255,.09);border-radius:18px;padding:26px 22px;max-width:340px;width:100%;position:relative}
.alc h3{font-size:30px;font-weight:900;letter-spacing:-.06em;margin-bottom:16px}
.alc h3 em{color:var(--r);font-style:normal}
.alf{display:flex;gap:7px;margin-bottom:5px}
.alf input{flex:1;background:#111;border:1px solid rgba(255,255,255,.1);color:#fff;border-radius:9px;padding:10px 12px;font-size:13px;font-family:inherit;outline:none;-webkit-appearance:none}
.alf input:focus{border-color:var(--r)}
.alf button{background:var(--r);border:none;color:#fff;border-radius:9px;padding:10px 15px;font-weight:900;font-size:12px;white-space:nowrap;min-height:42px}
.aerr{color:#ff6060;font-size:12px;margin-bottom:8px;display:none}
.xb{position:absolute;top:12px;right:12px;background:rgba(255,255,255,.06);border:none;color:#fff;border-radius:50%;width:27px;height:27px;font-size:14px;display:flex;align-items:center;justify-content:center}
.nt{color:rgba(255,255,255,.55);font-size:12px;background:rgba(255,42,20,.07);border:1px solid rgba(255,42,20,.18);border-radius:7px;padding:9px 12px;margin-bottom:12px;line-height:1.55}
.nt strong{color:var(--r)}

/* MOBILE */
@media(max-width:768px){
  nav{height:56px;padding:0 max(14px,env(safe-area-inset-left))}.logo{font-size:24px}.nl{display:none}.mbg{display:flex}
  .hero{padding:86px 16px 66px!important;min-height:100svh}.hero h1{font-size:46px!important}.hi{font-size:14px}
  .cta{width:100%}.cta .btn{flex:1}.tg em{font-size:9px;padding:5px 8px}
  section{padding:46px max(14px,env(safe-area-inset-left))}.shd{flex-direction:column;gap:4px}
  .sc{min-height:185px}.snv{width:48px;height:48px}
  .cg{grid-template-columns:repeat(3,1fr)}.cls{padding:42px 14px}
  .cs{padding:32px 14px 0}.og{grid-template-columns:1fr;gap:10px}
  .of{border-right:0;border-bottom:1px solid rgba(255,255,255,.17);padding-bottom:8px}
  .ft{padding:12px 14px;flex-direction:column;gap:4px}
  .pt{height:56px;padding:0 13px}
  #pd .dh{padding:24px 13px 14px}#pd .dn{font-size:32px}#pd .dm{grid-template-columns:1fr}
  #pd .ds{padding:0 13px 18px;font-size:14px}.dsc{padding:20px 13px}
  .who-hero,.how-hero,.cont-hero{padding:28px 13px 20px}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:1fr 1fr}
  .ccg{grid-template-columns:1fr}.poi{grid-template-columns:1fr;gap:6px}
}
@media(min-width:769px){.sc{min-height:300px}}
@media(max-width:860px){.cg{grid-template-columns:repeat(4,1fr)}}
@media(max-width:420px){.steps{grid-template-columns:1fr}}
@supports not(aspect-ratio:16/9){.sc{padding-top:56.25%;height:0}}


/* ══════════════════════════════
   admin.css — โหลดเฉพาะเมื่อ admin เปิด panel
══════════════════════════════ */
.ap{position:fixed;inset:0;z-index:800;background:#050505;overflow-y:scroll;-webkit-overflow-scrolling:touch;opacity:0;visibility:hidden;transition:.15s}
.ap.on{opacity:1;visibility:visible}
.apt{position:sticky;top:0;z-index:5;background:#080808;border-bottom:1px solid rgba(255,255,255,.08);padding:10px 16px;display:flex;align-items:center;gap:8px}
.aptt{font-size:13px;font-weight:900;flex:1}.aptt em{color:rgba(255,255,255,.34);font-size:10px;font-style:normal;font-weight:400;letter-spacing:.07em;margin-left:5px}
.apb{border:1px solid rgba(255,255,255,.1);background:transparent;color:#fff;border-radius:7px;padding:6px 10px;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;min-height:32px}
.apb.d{border-color:rgba(255,50,50,.32);color:#ff6060}
.ata{display:flex;gap:4px;padding:8px 16px;border-bottom:1px solid rgba(255,255,255,.08);overflow-x:auto;scrollbar-width:none;background:#080808}
.ata::-webkit-scrollbar{display:none}
.at{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);color:rgba(255,255,255,.45);border-radius:7px;padding:6px 11px;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;min-height:31px}
.at.on{background:#ff2a14;border-color:#ff2a14;color:#fff}
.ab{padding:16px;max-width:780px}
.apn{display:none}.apn.on{display:block}
.af{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.af label{display:flex;flex-direction:column;gap:4px;font-size:10px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:rgba(255,255,255,.42)}
.af input,.af select,.af textarea{background:#0f0f0f;border:1px solid rgba(255,255,255,.1);color:#fff;border-radius:9px;padding:9px 11px;font-size:13px;font-family:'DM Sans','Noto Sans Thai',Arial,sans-serif;outline:none;-webkit-appearance:none;resize:vertical}
.af input:focus,.af select:focus,.af textarea:focus{border-color:#ff2a14}
.af .fw{grid-column:1/-1}
.acv{min-height:130px;border:2px dashed rgba(255,255,255,.1);border-radius:11px;display:flex;align-items:center;justify-content:center;background:#0a0a0a;position:relative;overflow:hidden;cursor:pointer;color:rgba(255,255,255,.24);font-size:11px;text-align:center;padding:12px}
.acv img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.asv{background:#ff2a14;border:none;color:#fff;border-radius:11px;padding:11px 20px;font-size:13px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;width:100%;margin-top:2px;min-height:42px}
.ast{padding:8px 11px;border-radius:7px;font-size:11px;font-weight:700;margin-bottom:10px;display:none}
.ast.ok{background:rgba(40,190,70,.1);border:1px solid rgba(40,190,70,.24);color:#4dcf6a;display:block}
.ast.err{background:rgba(255,50,50,.08);border:1px solid rgba(255,50,50,.24);color:#ff6060;display:block}
.pr{display:flex;align-items:center;gap:9px;border:1px solid rgba(255,255,255,.07);background:rgba(255,255,255,.025);border-radius:11px;padding:9px 11px;margin-bottom:7px}
.pth{width:50px;height:34px;border-radius:6px;background:#111;flex-shrink:0;overflow:hidden}
.pth img{width:100%;height:100%;object-fit:cover}
.pin{flex:1;min-width:0}.pin b{display:block;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pin span{color:rgba(255,255,255,.34);font-size:10px}
@media(max-width:560px){.af{grid-template-columns:1fr}}

/* FAST PATCH: non-blocking loader + iOS/Windows safety */
#ld{position:fixed;inset:0;z-index:9999;background:#050505;display:flex;align-items:center;justify-content:center;flex-direction:column;pointer-events:none;transition:opacity .18s ease,visibility .18s ease}
#ld.out{opacity:0;visibility:hidden}
#ld .ll{font-size:32px;font-weight:900;letter-spacing:-.06em;color:#fff}
#ld .ll em{color:#ff2a14;font-style:normal}
#ld .lb{width:64px;height:2px;margin-top:14px;border-radius:3px;background:linear-gradient(90deg,#ff2a14,rgba(255,42,20,.18));animation:ldPulse .8s ease-in-out infinite alternate}
@keyframes ldPulse{from{opacity:.35;transform:scaleX(.45)}to{opacity:1;transform:scaleX(1)}}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001s!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.001s!important}.mq div{animation:none!important}}


/* Old Admin data import */
.arow{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}.arow .asv{flex:1 1 220px}.asv.ghost{background:#151515!important;border:1px solid rgba(255,255,255,.14)!important;color:#fff!important}.apb:disabled{opacity:.42;cursor:not-allowed;background:#151515!important;color:rgba(255,255,255,.55)!important;border-color:rgba(255,255,255,.1)!important}


/* Full legacy bridge UI */
.legacy-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:12px 0}
.legacy-card{border:1px solid rgba(255,255,255,.09);background:rgba(255,255,255,.035);border-radius:12px;padding:12px;text-align:center}
.legacy-card b{display:block;font-size:24px;color:#fff;letter-spacing:-.04em}.legacy-card span{display:block;color:rgba(255,255,255,.48);font-size:10px;text-transform:uppercase;letter-spacing:.1em;margin-top:3px}
.fcap{position:absolute;left:0;right:0;bottom:0;z-index:4;padding:10px 14px;background:linear-gradient(to top,rgba(0,0,0,.78),rgba(0,0,0,0));color:rgba(255,255,255,.82);font-size:12px;line-height:1.35}.di{position:relative}.drive-link{display:inline-flex;margin-top:14px;color:#ff6a20;font-weight:900;letter-spacing:.08em;text-transform:uppercase;font-size:12px}.gallery-layout{display:grid;grid-template-columns:1fr;gap:5px}.gallery-layout.layout-grid,.gallery-layout.layout-magazine,.gallery-layout.layout-hero-duo{grid-template-columns:1fr 1fr}.gallery-layout.layout-magazine .di:first-child,.gallery-layout.layout-hero-duo .di:first-child{grid-column:1/-1}.gallery-layout.layout-triple{grid-template-columns:repeat(3,1fr)}.gallery-layout.layout-film{grid-template-columns:repeat(4,1fr)}.gallery-layout.layout-panorama .di{aspect-ratio:21/9}@media(max-width:760px){.legacy-grid{grid-template-columns:1fr 1fr}.gallery-layout,.gallery-layout.layout-grid,.gallery-layout.layout-magazine,.gallery-layout.layout-hero-duo,.gallery-layout.layout-triple,.gallery-layout.layout-film{grid-template-columns:1fr}}


/* ═════════════════════════════════════════════════════════════
   UI PARITY PATCH — old layout / orange + / video cards / how works
═════════════════════════════════════════════════════════════ */
:root{--r:#ff2a14!important;--orange:#ff2a14!important}
.logo em,.logo span,.center-logo em,.mind-node em,.cat-slide-label em,.minimal-title small,.sub-panel-head small,.svc-cat-divider,.step-n{color:var(--r)!important;font-style:normal}
.hero h1 em{color:#fff}.hero .ey,.stg{color:var(--r)!important}
#sG{display:grid!important;grid-template-columns:1fr!important;gap:14px!important;width:100%}
.svc-cat-divider{grid-column:1/-1;display:flex;align-items:center;gap:12px;padding:20px 0 6px;font-size:10px;font-weight:900;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,42,20,.9)!important}
.svc-cat-divider:before{content:'';flex:1;height:1px;background:rgba(255,255,255,.1)}
.svc-cat-divider:first-child{padding-top:0}
.cat-slide-card{position:relative;display:block;width:100%;aspect-ratio:16/9;min-height:260px;border-radius:12px;overflow:hidden;background:#111;border:1px solid rgba(255,255,255,.10);cursor:pointer;grid-column:1/-1;-webkit-tap-highlight-color:transparent;box-shadow:0 24px 80px rgba(0,0,0,.18)}
.cat-slide-layer{position:absolute;inset:0;opacity:0;z-index:1;transition:opacity .22s ease;background:#111}
.cat-slide-layer.is-on{opacity:1;z-index:2}
.cat-slide-layer img,.cat-slide-layer video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.cat-slide-layer video{background:#000}
.cat-slide-layer .video-poster{position:absolute;inset:0;background-size:cover;background-position:center;filter:saturate(.95) brightness(.85)}
.cat-slide-layer .video-poster:after{content:'▶';position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:rgba(255,42,20,.9);color:#fff;font-size:22px;font-weight:900;box-shadow:0 12px 40px rgba(0,0,0,.45)}
.cat-slide-card:after{content:'';position:absolute;inset:0;z-index:3;pointer-events:none;background:linear-gradient(to right,rgba(0,0,0,.78) 0%,rgba(0,0,0,.25) 38%,rgba(0,0,0,.18) 100%),linear-gradient(to top,rgba(0,0,0,.82),transparent 55%)}
.cat-slide-top{position:absolute;left:24px;right:24px;top:20px;z-index:6;display:flex;align-items:center;justify-content:space-between;gap:12px}
.cat-slide-name{font-size:11px;font-weight:950;letter-spacing:.16em;text-transform:uppercase;color:#fff;text-shadow:0 1px 10px rgba(0,0,0,.9);max-width:58%;line-height:1.2}
.cat-slide-controls{display:flex;align-items:center;gap:7px;position:relative;z-index:12}
.cat-slide-btn{width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.18);background:rgba(14,14,14,.78);color:#fff;font-size:20px;line-height:1;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(10px)}
.cat-slide-count{font-size:11px;font-weight:900;color:rgba(255,255,255,.62);min-width:40px;text-align:center}
.cat-slide-label{position:absolute;left:26px;right:26px;bottom:24px;z-index:6;display:flex;flex-direction:column;align-items:flex-start;text-shadow:0 1px 14px rgba(0,0,0,.9);pointer-events:none;max-width:48%}
.cat-slide-label span{font-size:18px;line-height:1.1;font-weight:800;letter-spacing:.055em;text-transform:uppercase;color:rgba(255,255,255,.96)}
.cat-slide-label strong{display:block;font-size:22px;line-height:1.05;font-weight:950;text-transform:uppercase;margin-top:4px;letter-spacing:.02em;color:#fff}
.svc-desc{position:absolute;right:22px;bottom:24px;z-index:7;max-width:48%;text-align:right;pointer-events:none}
.svc-desc p{font-size:12px;line-height:1.45;color:rgba(255,255,255,.74);font-weight:400;letter-spacing:.03em;text-shadow:0 1px 8px rgba(0,0,0,.9);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}
.video-badge{position:absolute;left:22px;top:74px;z-index:7;border:1px solid rgba(255,255,255,.18);background:rgba(255,42,20,.82);color:#fff;border-radius:999px;padding:7px 11px;font-size:10px;font-weight:900;letter-spacing:.13em;text-transform:uppercase;backdrop-filter:blur(10px)}
.card-highlight{outline:2px solid var(--r);outline-offset:4px;box-shadow:0 0 0 9999px rgba(0,0,0,.38),0 0 52px rgba(255,42,20,.42)!important;z-index:20}
.detail-img-caption{color:rgba(255,255,255,.62);font-size:14px;line-height:1.45;margin:-2px max(36px,env(safe-area-inset-left)) 18px;padding:0 4px;word-break:break-word}
#hP{background:#050505!important;color:#fff!important;z-index:500}.how-top.minimal{position:sticky;top:0;z-index:30;height:66px;display:flex;align-items:center;justify-content:space-between;padding:0 34px;background:rgba(5,5,5,.90);backdrop-filter:blur(18px);border-bottom:1px solid rgba(255,255,255,.08)}
.minimal-works{min-height:calc(100vh - 66px);padding:58px 38px 38px;background:radial-gradient(circle at 50% 54%,rgba(255,92,20,.42),transparent 18%),radial-gradient(circle at 50% 54%,rgba(255,42,20,.22),transparent 32%),radial-gradient(circle at 72% 18%,rgba(255,42,20,.12),transparent 22%),#050505!important}
.minimal-title{text-align:center;margin-bottom:22px}.minimal-title small{display:block;font-size:10px;font-weight:900;letter-spacing:.32em;text-transform:uppercase;color:var(--r)!important;margin-bottom:12px}.minimal-title h2{font-size:clamp(40px,5.5vw,74px);line-height:.94;letter-spacing:-.055em;font-weight:800}.minimal-title p{max-width:640px;margin:14px auto 0;color:rgba(255,255,255,.58);font-size:15px;line-height:1.5}
.mind-map{position:relative;width:min(850px,92vw);aspect-ratio:1/1;margin:14px auto 0}.mind-bg{position:absolute;left:50%;top:52%;transform:translate(-50%,-50%);width:58%;height:58%;border-radius:50%;background:radial-gradient(circle,rgba(255,92,20,.34),rgba(255,42,20,.16) 48%,transparent 72%)}.mind-map:before{content:'';position:absolute;left:50%;top:52%;transform:translate(-50%,-50%);width:62%;height:62%;border:2px solid rgba(255,255,255,.46);border-left-color:transparent;border-bottom-color:rgba(255,255,255,.28);border-radius:50%}.mind-map:after{content:'';position:absolute;left:50%;top:52%;width:1px;height:34%;background:rgba(255,255,255,.45);transform:rotate(-24deg);transform-origin:top}
.mind-center{position:absolute;left:50%;top:52%;transform:translate(-50%,-50%);z-index:4;border:none;background:transparent;color:#fff;text-align:center;cursor:pointer}.mind-center .center-logo{display:block;font-size:clamp(26px,3.5vw,48px);line-height:.9;letter-spacing:-.075em;font-weight:950;color:#fff}.mind-center .center-logo em{color:var(--r)!important;font-size:1em}.mind-center span{display:block;margin-top:10px;font-size:clamp(24px,3.2vw,44px);line-height:.92;letter-spacing:-.055em;font-weight:950;color:#fff;text-transform:none}
.mind-node{position:absolute;max-width:154px;border:0;background:transparent;color:#fff;text-align:center;cursor:pointer;padding:0}.mind-node b{display:block;font-size:14px;font-weight:900;letter-spacing:-.02em;color:#fff;transition:.2s}.mind-node span{display:block;margin-top:2px;color:rgba(255,255,255,.62);font-size:11px;line-height:1.2}.mind-node:hover b,.mind-node.active b{color:var(--r)!important}.mind-node.n10{left:50%;top:20%;transform:translate(-50%,-50%)}.mind-node.n2{left:67.3%;top:25.1%;transform:translate(-50%,-50%)}.mind-node.n9{left:79.1%;top:38.7%;transform:translate(-50%,-50%)}.mind-node.n3{left:81.7%;top:56.6%;transform:translate(-50%,-50%)}.mind-node.n4{left:74.2%;top:73%;transform:translate(-50%,-50%)}.mind-node.n5{left:59%;top:82.7%;transform:translate(-50%,-50%)}.mind-node.n6{left:41%;top:82.7%;transform:translate(-50%,-50%)}.mind-node.n11{left:25.8%;top:73%;transform:translate(-50%,-50%)}.mind-node.n7{left:18.3%;top:56.6%;transform:translate(-50%,-50%)}.mind-node.n8{left:20.9%;top:38.7%;transform:translate(-50%,-50%)}.mind-node.n1{left:32.7%;top:25.1%;transform:translate(-50%,-50%)}
.service-sub-panel{width:min(860px,92vw);margin:28px auto 0;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.12);border-radius:28px;padding:22px;color:#fff;backdrop-filter:blur(14px)}.sub-panel-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:12px}.sub-panel-head small{display:block;font-size:10px;font-weight:900;letter-spacing:.24em;text-transform:uppercase;color:var(--r)!important;margin-bottom:8px}.sub-panel-head h3{font-size:clamp(24px,3vw,40px);line-height:.95;letter-spacing:-.055em}.sub-panel-head button{border:1px solid rgba(255,255,255,.16);background:#0d0d0d;color:#fff;border-radius:999px;padding:10px 14px;font-size:10px;font-weight:900;letter-spacing:.14em;text-transform:uppercase}.service-sub-panel p{color:rgba(255,255,255,.58);line-height:1.55;max-width:720px;margin-bottom:16px}.sub-chip-grid{display:flex;gap:9px;flex-wrap:wrap}.sub-chip-grid button{border:1px solid rgba(255,255,255,.13);background:rgba(255,255,255,.05);color:#fff;border-radius:999px;padding:10px 14px;font-size:11px;font-weight:900;letter-spacing:.12em;text-transform:uppercase}.sub-chip-grid button:hover{border-color:var(--r);color:var(--r)}.minimal-footer-note{max-width:820px;margin:18px auto 0;text-align:center;font-size:14px;color:rgba(255,255,255,.62)}.minimal-footer-note strong{display:block;color:#fff;margin-bottom:5px}
#aPw{-webkit-text-security:none!important;text-security:none!important;font-size:16px!important;letter-spacing:.02em!important}
@media(max-width:768px){#sG{gap:10px!important}.cat-slide-card{min-height:0!important;aspect-ratio:16/9!important;border-radius:10px}.cat-slide-top{left:14px;right:14px;top:12px}.cat-slide-name{font-size:9px;max-width:56%}.cat-slide-btn{width:38px;height:38px}.cat-slide-count{font-size:10px;min-width:34px}.cat-slide-label{left:14px;right:14px;bottom:12px;max-width:54%}.cat-slide-label span{font-size:11px}.cat-slide-label strong{font-size:13px}.svc-desc{right:12px;bottom:12px;max-width:52%}.svc-desc p{font-size:9px;-webkit-line-clamp:2}.video-badge{left:14px;top:56px;font-size:8px;padding:6px 8px}.how-top.minimal{height:58px;padding:0 16px}.minimal-works{padding:38px 16px 32px}.minimal-title h2{font-size:38px}.mind-map{width:100%;display:grid;grid-template-columns:1fr;gap:10px;aspect-ratio:auto;margin-top:28px}.mind-bg,.mind-map:before,.mind-map:after{display:none}.mind-center{position:relative;left:auto;top:auto;transform:none;background:radial-gradient(circle at 50% 35%,rgba(255,42,20,.28),transparent 58%),#111;border:1px solid rgba(255,255,255,.12);border-radius:26px;padding:28px 16px}.mind-node{position:relative!important;inset:auto!important;max-width:none;width:100%;transform:none!important;border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:15px;background:rgba(255,255,255,.04);text-align:left}.service-sub-panel{width:100%;margin-top:18px;padding:16px;border-radius:22px}.sub-panel-head{display:block}.sub-panel-head button{margin-top:14px}.sub-chip-grid{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none}.sub-chip-grid::-webkit-scrollbar{display:none}.sub-chip-grid button{flex-shrink:0;white-space:nowrap}}

/* Exact taxonomy patch: video preview badge removed from cards */
.video-badge{display:none!important}


/* Split special services: each service has one sub-head only */
.mind-node.n11{left:28%!important;top:74%!important;transform:translate(-50%,-50%)!important}
.mind-node.n12{left:18%!important;top:62%!important;transform:translate(-50%,-50%)!important}
.mind-node.n13{left:18%!important;top:46%!important;transform:translate(-50%,-50%)!important}
@media(max-width:768px){
  .mind-node.n11,.mind-node.n12,.mind-node.n13{left:auto!important;top:auto!important;transform:none!important}
}


/* FINAL CARD TAXONOMY: 1 Head + 1-3 selected Sub Heads per card */
.cat-slide-label.tax-card-label{align-items:flex-start!important;gap:8px!important;max-width:min(760px,82vw)!important;}
.cat-slide-label.tax-card-label .card-head{display:block!important;color:#fff!important;font-size:clamp(18px,3vw,36px)!important;line-height:.98!important;font-weight:950!important;letter-spacing:-.045em!important;text-transform:uppercase!important;text-shadow:0 2px 18px rgba(0,0,0,.78)!important;max-width:100%!important;}
.cat-slide-label.tax-card-label .card-head em{color:#ff2a14!important;font-style:normal!important;}
.card-sub-list{display:flex!important;flex-wrap:wrap!important;gap:7px!important;margin-top:9px!important;max-width:min(740px,82vw)!important;}
.card-sub-list em{font-style:normal!important;border:1px solid rgba(255,255,255,.18)!important;background:rgba(0,0,0,.38)!important;color:rgba(255,255,255,.9)!important;border-radius:999px!important;padding:7px 10px!important;font-size:10px!important;font-weight:900!important;letter-spacing:.10em!important;text-transform:uppercase!important;backdrop-filter:blur(8px)!important;line-height:1.1!important;}
.card-sub-list em:first-child{border-color:rgba(255,42,20,.7)!important;color:#ff2a14!important;background:rgba(255,42,20,.08)!important;}
@media(max-width:768px){
  .cat-slide-label.tax-card-label{left:16px!important;right:16px!important;bottom:14px!important;}
  .cat-slide-label.tax-card-label .card-head{font-size:18px!important;line-height:.96!important;letter-spacing:-.035em!important;}
  .card-sub-list{gap:5px!important;margin-top:7px!important;flex-wrap:nowrap!important;overflow-x:auto!important;scrollbar-width:none!important;}
  .card-sub-list::-webkit-scrollbar{display:none!important;}
  .card-sub-list em{font-size:7px!important;padding:5px 7px!important;white-space:nowrap!important;flex-shrink:0!important;}
}


/* HEAD SIZE TUNE — reduce Works/Services card Head size so long Head names fit better */
.cat-slide-label.tax-card-label .card-head{font-size:clamp(18px,3vw,36px)!important;line-height:.98!important;letter-spacing:-.045em!important;}
@media(max-width:768px){.cat-slide-label.tax-card-label .card-head{font-size:18px!important;line-height:.96!important;letter-spacing:-.035em!important;}.card-sub-list{margin-top:6px!important}.card-sub-list em{font-size:7px!important;padding:5px 7px!important}}


/* DATA ENTRY FINAL — sub head typography only */
.cat-slide-label.tax-card-label{gap:4px!important;max-width:min(720px,82vw)!important;}
.cat-slide-label.tax-card-label .card-head{display:block!important;color:#fff!important;font-size:clamp(18px,2.7vw,34px)!important;line-height:.98!important;font-weight:950!important;letter-spacing:-.045em!important;text-transform:uppercase!important;text-shadow:0 2px 18px rgba(0,0,0,.78)!important;}
.cat-slide-label.tax-card-label .card-head em{color:#ff2a14!important;font-style:normal!important;}
.card-sub-list{display:block!important;margin-top:4px!important;max-width:100%!important;}
.card-sub-list em{display:block!important;border:0!important;background:transparent!important;padding:0!important;border-radius:0!important;backdrop-filter:none!important;color:rgba(255,255,255,.72)!important;font-style:normal!important;font-size:11px!important;font-weight:800!important;letter-spacing:.12em!important;text-transform:uppercase!important;line-height:1.25!important;}
.card-sub-list em:first-child{border:0!important;color:rgba(255,255,255,.72)!important;background:transparent!important;}
@media(max-width:768px){.cat-slide-label.tax-card-label .card-head{font-size:17px!important;}.card-sub-list em{font-size:8px!important;letter-spacing:.10em!important;}}

/* Patch: card video, card subhead, gallery captions, team details */
.sl video.card-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;background:#111}
.slb .head{font-size:clamp(22px,3.1vw,36px);line-height:1;font-weight:950;letter-spacing:-.035em;color:#fff;text-transform:uppercase}
.slb em{display:block;margin-top:6px;color:rgba(255,255,255,.72);font-style:normal;font-size:clamp(9px,1.1vw,12px);font-weight:900;letter-spacing:.12em;text-transform:uppercase}
.df{margin:0 0 8px}.df figcaption{padding:8px max(24px,env(safe-area-inset-left)) 18px;color:rgba(255,255,255,.58);font-size:13px;line-height:1.45}.tm p{font-size:10px;color:rgba(255,255,255,.42);line-height:1.45;margin-top:2px}
@media(max-width:768px){.slb .head{font-size:18px}.slb em{font-size:8px;margin-top:4px}.df figcaption{font-size:12px;padding:7px 16px 14px}}
.card-sub-one{display:block!important;margin-top:5px!important;color:rgba(255,255,255,.72)!important;font-style:normal!important;font-size:clamp(9px,1vw,12px)!important;font-weight:900!important;letter-spacing:.13em!important;text-transform:uppercase!important;line-height:1.25!important;}
@media(max-width:768px){.card-sub-one{font-size:8px!important;margin-top:4px!important;}}

/* HOW IT WORKS — sync service heads with Works taxonomy and jump to exact card */
.mind-node b em{color:var(--r)!important;font-style:normal!important;display:inline!important}.mind-node span{max-width:170px;margin-left:auto;margin-right:auto}.how-sub-chip small{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;margin-left:7px;border-radius:999px;background:#ff2a14;color:#fff;font-size:10px;letter-spacing:0}.how-sub-chip.no-work{opacity:.55}.cat-slide-card.jump-focus{outline:2px solid #ff2a14!important;outline-offset:5px!important;box-shadow:0 0 0 9999px rgba(0,0,0,.24),0 0 44px rgba(255,42,20,.45)!important;z-index:9!important;transform:scale(1.01)}
@media(max-width:768px){.mind-node span{max-width:none}.cat-slide-card.jump-focus{outline-offset:3px!important;transform:none!important}}


/* CONTACT PAGE — cleaner admin-editable layout */
.contact-clean-page{padding:20px 0 40px;max-width:1180px}
.contact-intro small{display:block;color:var(--r);font-size:11px;font-weight:900;letter-spacing:.28em;text-transform:uppercase;margin-bottom:14px}
.contact-intro h2{font-size:clamp(48px,8vw,108px);line-height:.86;letter-spacing:-.075em;margin:0 0 18px;font-weight:950;color:#fff}
.contact-intro h2 span{color:var(--r)}
.contact-intro p{max-width:720px;color:rgba(255,255,255,.58);font-size:18px;line-height:1.5;margin:0 0 28px}
.contact-main-grid{display:grid;grid-template-columns:1.35fr .65fr;gap:18px;align-items:start}
.contact-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:12px}
.contact-card{display:flex;align-items:center;gap:14px;min-height:88px;border:1px solid rgba(255,255,255,.11);background:#0d0d0d;border-radius:18px;padding:17px;color:#fff;transition:border-color .15s,background .15s}
.contact-card:hover{border-color:rgba(255,42,20,.55);background:#141414}
.contact-ic{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;background:#222;color:#fff;font-size:13px;font-weight:950;flex:0 0 auto}
.contact-card.line .contact-ic{background:#06c755}.contact-card.whatsapp .contact-ic{background:#25d366}.contact-card.email .contact-ic{background:#ea4335}.contact-card.facebook .contact-ic{background:#1877f2}.contact-card.messenger .contact-ic{background:#0084ff}.contact-card.instagram .contact-ic{background:#c13584}.contact-card.linkedin .contact-ic{background:#0a66c2}.contact-card.behance .contact-ic{background:#1769ff}
.contact-card b{display:block;font-size:18px;line-height:1.1;color:#fff}.contact-card span+div span{display:block;margin-top:5px;color:rgba(255,255,255,.58);font-size:13px;line-height:1.3;word-break:break-word}
.contact-office-box{border:1px solid rgba(255,255,255,.11);background:radial-gradient(circle at 80% 0%,rgba(255,42,20,.12),transparent 38%),#0d0d0d;border-radius:22px;padding:24px;min-height:220px}
.contact-office-box small{display:block;color:var(--r);font-size:10px;letter-spacing:.22em;text-transform:uppercase;font-weight:900;margin-bottom:12px}.contact-office-box strong{display:block;color:#fff;font-size:28px;line-height:1.05;letter-spacing:-.04em}.contact-office-box p{color:rgba(255,255,255,.56);font-size:15px;line-height:1.55;margin:14px 0 20px}.contact-office-box a{display:inline-flex;border:1px solid rgba(255,255,255,.14);border-radius:999px;padding:12px 16px;color:#fff;font-size:11px;font-weight:900;letter-spacing:.12em;text-transform:uppercase}
@media(max-width:820px){.contact-main-grid{grid-template-columns:1fr}.contact-card-grid{grid-template-columns:1fr}.contact-intro h2{font-size:56px}.contact-intro p{font-size:16px}}

/* How It Works: show Sub Heads in default state */
.how-sub-group{width:100%;border-top:1px solid rgba(255,255,255,.08);padding:14px 0 4px}.how-sub-group:first-child{border-top:0;padding-top:0}.how-sub-group-title{font-size:11px;font-weight:950;letter-spacing:.18em;text-transform:uppercase;color:#fff;margin-bottom:10px}.how-sub-group-title em{color:var(--r);font-style:normal}.how-sub-group-chips{display:flex;flex-wrap:wrap;gap:8px}.how-sub-chip.has-work{border-color:rgba(255,42,20,.55)!important;color:#fff}.how-sub-chip.no-work{opacity:.45}@media(max-width:768px){.how-sub-group-chips{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none}.how-sub-group-chips::-webkit-scrollbar{display:none}.how-sub-group-title{font-size:10px}}


/* CONTACT PAGE: always show editable channel slots */
@media(min-width:821px){
  .contact-card-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
  .contact-office-box{min-height:100%;}
}
.contact-card.is-empty{opacity:.46;pointer-events:none;border-style:dashed;background:#0a0a0a;}
.contact-card.is-empty .contact-ic{background:#181818!important;color:rgba(255,255,255,.42)!important;}
.contact-card.is-empty b{color:rgba(255,255,255,.62)!important;}
.contact-card.is-empty span+div span{color:rgba(255,255,255,.34)!important;}

/* HOW IT WORKS — information only, no jump links */
.how-sub-chip.static,
.how-sub-chip.static:hover{
  cursor:default!important;
  pointer-events:none!important;
  border-color:rgba(255,255,255,.16)!important;
  color:rgba(255,255,255,.78)!important;
  background:rgba(255,255,255,.045)!important;
  opacity:1!important;
  box-shadow:none!important;
  transform:none!important;
}
.how-sub-chip.static small{display:none!important}
.how-contact-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:22px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.09);
}
.how-contact-actions button{
  border:none;
  border-radius:999px;
  background:#ff2a14;
  color:#fff;
  padding:14px 22px;
  min-height:46px;
  font-size:11px;
  font-weight:950;
  letter-spacing:.15em;
  text-transform:uppercase;
  cursor:pointer;
}
.how-contact-actions button.ghost{
  background:transparent;
  border:1px solid rgba(255,255,255,.18);
  color:#fff;
}
.how-contact-actions button:hover{filter:brightness(1.08)}
@media(max-width:768px){
  .how-contact-actions{display:grid;grid-template-columns:1fr;gap:8px}
  .how-contact-actions button{width:100%}
}

/* HOW IT WORKS — clearer service explanations */
.how-explain-grid{display:grid;grid-template-columns:1fr;gap:12px;width:100%}
.how-service-explain-card,.how-selected-explain{border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.035);border-radius:20px;padding:16px;overflow:hidden}
.how-service-explain-title{display:block;background:transparent;border:0;color:#fff;font-size:15px;font-weight:950;letter-spacing:.02em;text-align:left;margin:0 0 8px;padding:0;cursor:pointer}
.how-service-explain-title em,.how-selected-explain em{color:var(--r);font-style:normal}
.how-service-explain-card p,.how-selected-copy p{color:rgba(255,255,255,.58);font-size:13px;line-height:1.55;margin:0 0 12px;max-width:920px}
.how-selected-copy b,.how-sub-list-title{display:block;color:var(--r);font-size:10px;font-weight:950;letter-spacing:.18em;text-transform:uppercase;margin-bottom:8px}
.how-selected-explain .how-sub-group-chips,.how-service-explain-card .how-sub-group-chips{gap:7px}
.how-sub-chip.explain-chip{display:inline-flex;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.04);color:rgba(255,255,255,.78);border-radius:999px;padding:8px 11px;font-size:10px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap}
.how-sub-chip.explain-chip:hover{border-color:rgba(255,42,20,.55);color:#fff}
@media(min-width:900px){.how-explain-grid.all{grid-template-columns:1fr 1fr}.how-service-explain-card{min-height:160px}.how-service-explain-title{font-size:16px}}
@media(max-width:768px){.how-service-explain-card,.how-selected-explain{padding:14px;border-radius:18px}.how-service-explain-card p,.how-selected-copy p{font-size:12px}.how-selected-explain .how-sub-group-chips,.how-service-explain-card .how-sub-group-chips{display:flex;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none}.how-selected-explain .how-sub-group-chips::-webkit-scrollbar,.how-service-explain-card .how-sub-group-chips::-webkit-scrollbar{display:none}.how-sub-chip.explain-chip{flex-shrink:0;font-size:9px;padding:7px 10px}}


/* FINAL HOW PANEL — clearer selected Service Head details */
.service-sub-panel{max-width:980px!important;overflow:hidden!important;}
.service-sub-panel .sub-panel-head h3,#subTitle{font-size:clamp(32px,4.6vw,56px)!important;line-height:.92!important;letter-spacing:-.06em!important;word-break:normal!important;overflow-wrap:break-word!important;max-width:100%!important;}
#subDesc{max-width:780px!important;font-size:16px!important;line-height:1.5!important;color:rgba(255,255,255,.58)!important;}
.how-selected-explain.final-selected{margin-top:16px!important;border:1px solid rgba(255,255,255,.12)!important;background:rgba(255,255,255,.035)!important;border-radius:24px!important;padding:22px!important;}
.how-selected-copy b{display:block!important;color:#ff2a14!important;font-size:10px!important;letter-spacing:.22em!important;text-transform:uppercase!important;margin-bottom:10px!important;}
.how-selected-copy p{max-width:820px!important;font-size:15px!important;line-height:1.65!important;color:rgba(255,255,255,.68)!important;margin:0 0 18px!important;}
.how-sub-list-title{display:block!important;color:rgba(255,255,255,.42)!important;font-size:10px!important;font-weight:950!important;letter-spacing:.22em!important;text-transform:uppercase!important;margin:0 0 10px!important;}
.how-sub-group-chips{display:flex!important;flex-wrap:wrap!important;gap:8px!important;}
.how-sub-chip.final-chip{display:inline-flex!important;align-items:center!important;border:1px solid rgba(255,255,255,.13)!important;background:rgba(255,255,255,.05)!important;color:rgba(255,255,255,.82)!important;border-radius:999px!important;padding:9px 12px!important;font-size:11px!important;font-weight:900!important;letter-spacing:.1em!important;text-transform:uppercase!important;line-height:1!important;}
.how-all-hint{color:rgba(255,255,255,.58);font-size:14px;line-height:1.5;margin:12px 0 16px;}
.how-explain-grid.final-all{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:10px!important;}
.how-service-mini{display:block;text-align:left;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.035);color:#fff;border-radius:18px;padding:14px;cursor:pointer;}
.how-service-mini strong{display:block;font-size:14px;font-weight:950;letter-spacing:-.01em;margin-bottom:5px;}
.how-service-mini strong em{color:#ff2a14;font-style:normal;}
.how-service-mini span{display:block;font-size:11px;line-height:1.45;color:rgba(255,255,255,.52);}
.how-service-mini:hover{border-color:rgba(255,42,20,.5);background:rgba(255,42,20,.07);}
@media(max-width:768px){
  .service-sub-panel .sub-panel-head h3,#subTitle{font-size:34px!important;}
  #subDesc{font-size:14px!important;}
  .how-explain-grid.final-all{grid-template-columns:1fr!important;}
  .how-selected-explain.final-selected{padding:16px!important;border-radius:20px!important;}
  .how-sub-group-chips{flex-wrap:nowrap!important;overflow-x:auto!important;scrollbar-width:none!important;padding-bottom:2px!important;}
  .how-sub-group-chips::-webkit-scrollbar{display:none!important;}
  .how-sub-chip.final-chip{flex-shrink:0!important;font-size:9px!important;padding:8px 10px!important;}
}

/* PATCH 2026-05-27 — Reduce Works/Services card Head size on left side */
.cat-slide-label.tax-card-label .card-head,
.slb .head{
  font-size:clamp(16px,2.15vw,27px)!important;
  line-height:.98!important;
  letter-spacing:-.035em!important;
}
.card-sub-one,
.card-sub-list em,
.slb em{
  font-size:clamp(8px,.82vw,10px)!important;
  letter-spacing:.12em!important;
}
@media(max-width:768px){
  .cat-slide-label.tax-card-label .card-head,
  .slb .head{
    font-size:15px!important;
    line-height:1!important;
  }
  .card-sub-one,
  .card-sub-list em,
  .slb em{
    font-size:7px!important;
  }
}
