@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Sans+Thai:wght@400;500;600;700;800&family=Inter:wght@400;500;600;700;800&display=swap";:root{--bg: #f7fbff;--surface: #ffffff;--surface-soft: #eef7ff;--ink: #111827;--muted: #667085;--line: rgba(37, 99, 235, .14);--line-strong: rgba(37, 99, 235, .24);--brand: #2563eb;--brand-2: #0ea5e9;--shadow: 0 24px 70px rgba(37, 99, 235, .12);color:var(--ink);background:var(--bg);font-family:IBM Plex Sans Thai,Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:96px}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at 76% 10%,rgba(14,165,233,.2),transparent 28%),linear-gradient(180deg,#fff 0,#f7fbff 720px),var(--bg);color:var(--ink)}body:has(.gallery-modal),body:has(.process-modal),body:has(.contact-modal){overflow:hidden}#home,#work,#skills,#workflow,#contact{scroll-margin-top:104px}button,input{font:inherit}button{border:0}button,a{-webkit-tap-highlight-color:transparent}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}main{overflow:clip;--mx: 0;--my: 0}.route-loader{min-height:100vh;background:radial-gradient(circle at 76% 10%,rgba(14,165,233,.2),transparent 28%),linear-gradient(180deg,#fff 0,#f7fbff 720px),var(--bg)}main:before{position:fixed;inset:0;z-index:-1;background-image:linear-gradient(rgba(37,99,235,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(37,99,235,.045) 1px,transparent 1px);background-size:46px 46px;mask-image:linear-gradient(to bottom,#000,transparent 82%);content:"";pointer-events:none}.topbar{position:fixed;top:14px;left:50%;z-index:20;display:flex;width:min(760px,calc(100% - 36px));min-height:58px;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:999px;padding:8px;background:#ffffffd6;box-shadow:0 18px 48px #2563eb1f;backdrop-filter:blur(18px);transform:translate(-50%)}.brand{display:inline-flex;align-items:center;gap:10px;font-weight:800}.brand span{display:grid;width:38px;height:38px;place-items:center;border-radius:50%;background:linear-gradient(135deg,#0f172a,#2563eb 58%,#38bdf8);color:#fff;font-size:.85rem;letter-spacing:0}.brand strong{font-size:1rem}.nav-links{display:flex;width:100%;justify-content:center;gap:5px}.nav-links a{position:relative;display:inline-flex;min-height:40px;align-items:center;justify-content:center;border-radius:999px;padding:10px 22px;color:var(--muted);font-size:.94rem;font-weight:800;white-space:nowrap;transition:background .16s ease,color .16s ease,box-shadow .16s ease,transform .16s ease}.nav-links a:hover,.nav-links a:focus-visible{background:#2563eb1c;color:#1d4ed8;box-shadow:inset 0 0 0 1px #2563eb24;transform:translateY(-1px)}.nav-links a:focus-visible{outline:2px solid rgba(37,99,235,.38);outline-offset:3px}.hero{position:relative;display:grid;grid-template-columns:minmax(0,.82fr) minmax(360px,.48fr);gap:clamp(28px,6vw,80px);align-items:center;width:100%;min-height:92svh;margin:0;padding:128px max(20px,calc((100vw - 1180px)/2)) 86px}.hero:after{position:absolute;right:0;bottom:-1px;left:0;height:120px;background:linear-gradient(180deg,rgba(247,251,255,0),var(--bg));content:"";pointer-events:none}.hero-scene{position:absolute;inset:0;z-index:0}.hero-scene canvas{display:block;width:100%;height:100%}.hero-scene-fallback{background:radial-gradient(circle at 72% 34%,rgba(37,99,235,.12),transparent 28%),linear-gradient(135deg,#0ea5e914,#fff0)}.hero-copy{position:relative;z-index:2;max-width:740px;padding-left:clamp(0px,2vw,26px);border-left:3px solid rgba(37,99,235,.18)}.hero-copy [data-hero-copy]{opacity:1}.eyebrow{display:inline-flex;min-height:34px;align-items:center;gap:8px;margin:0;border:1px solid rgba(37,99,235,.16);border-radius:8px;padding:7px 10px;background:#ffffffb8;color:#1d4ed8;font-size:.78rem;font-weight:800;letter-spacing:.02em;text-transform:uppercase}.hero h1{margin:18px 0 0;max-width:780px;font-size:clamp(3.6rem,9vw,7.8rem);line-height:.88;letter-spacing:0;color:var(--ink);overflow-wrap:break-word}.role{margin:18px 0 0;color:#1d4ed8;font-size:clamp(1.2rem,2.2vw,1.75rem);font-weight:800}.seo-alias{margin:14px 0 0;color:#475467;font-size:clamp(1rem,1.8vw,1.28rem);font-weight:800}.hero-action-note{position:absolute;top:58px;left:0;z-index:80;display:block!important;width:min(700px,100%);max-width:700px;margin:0;border:1px solid rgba(37,99,235,.16);border-left:3px solid rgba(37,99,235,.45);border-radius:8px;padding:12px 14px;background:#ffffffe0;box-shadow:0 14px 34px #2563eb14;opacity:1!important;transform:none!important;visibility:visible!important}.hero-action-note{color:#344054;font-size:clamp(.98rem,1.3vw,1.1rem);font-weight:600;line-height:1.7}.hero-actions{position:relative;z-index:24;display:flex;flex-wrap:wrap;gap:12px;margin-top:24px;padding-bottom:104px;opacity:1!important;pointer-events:auto;transform:none!important;visibility:visible;overflow:visible}.hero-actions a{opacity:1!important;transform:none!important;visibility:visible}.contact-popup-trigger{cursor:pointer}.primary-action,.secondary-action,.project-actions button,.project-actions a,.modal-footer a,.contact-links a{display:inline-flex;min-height:44px;align-items:center;justify-content:center;gap:8px;border-radius:8px;padding:10px 14px;font-weight:800;transition:transform .16s ease,background .16s ease,border-color .16s ease,color .16s ease}.primary-action{background:linear-gradient(135deg,#0f172a,#2563eb);color:#fff;box-shadow:0 18px 36px #2563eb3d}.secondary-action,.project-actions a,.modal-footer a,.contact-links a{border:1px solid var(--line);background:#ffffffc2;color:var(--ink)}.primary-action:hover,.secondary-action:hover,.project-actions button:hover,.project-actions a:hover,.modal-footer a:hover,.contact-links a:hover{transform:translateY(-2px)}.profile-panel{position:relative;z-index:2;display:grid;gap:20px;border:1px solid var(--line);border-radius:8px;padding:16px;background:#ffffffbd;box-shadow:var(--shadow);backdrop-filter:blur(18px);transform:translate3d(calc(var(--mx) * -10px),calc(var(--my) * -8px),0);transition:transform .16s ease-out}.profile-panel img{width:100%;aspect-ratio:4 / 3;border-radius:8px;object-fit:cover;object-position:center;background:#f2f4f7}.profile-panel p{margin:0;color:var(--muted);line-height:1.72}.profile-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}.profile-meta span,.project-kicker span,.stack-list span,.image-count,.featured-media span,.result-count{display:inline-flex;min-height:30px;align-items:center;gap:7px;border:1px solid var(--line);border-radius:8px;padding:6px 9px;background:#f9fafb;color:#475467;font-size:.78rem;font-weight:800}.stats-band{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1px;width:min(1180px,calc(100% - 40px));position:relative;z-index:4;margin:-26px auto 0;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:#2563eb1f;box-shadow:var(--shadow)}.stats-band div{padding:20px;background:#ffffffd1;backdrop-filter:blur(16px)}.stats-band strong{display:block;font-size:clamp(1.85rem,4vw,3rem);line-height:1}.stats-band span{display:block;margin-top:8px;color:var(--muted);font-weight:700}.featured-section,.process-section,.work-section,.skills-section{width:min(1180px,calc(100% - 40px));margin:0 auto;padding:78px 0 0}.section-heading{margin-bottom:24px}.section-heading h2{margin:14px 0 0;font-size:clamp(2rem,4.2vw,4rem);line-height:1.04;letter-spacing:0}.section-heading.split{display:grid;grid-template-columns:minmax(0,.62fr) minmax(280px,.38fr);gap:24px;align-items:end}.section-heading.split>p{margin:0;color:var(--muted);line-height:1.72}.featured-card{display:grid;grid-template-columns:minmax(0,.95fr) minmax(320px,.7fr);gap:0;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:#ffffffd1;box-shadow:var(--shadow);backdrop-filter:blur(18px);transform:perspective(1200px) rotateY(calc(var(--mx) * -2deg)) rotateX(calc(var(--my) * 1.5deg));transition:transform .16s ease-out}.process-section{position:relative;padding-top:72px}.process-section:before{position:absolute;top:118px;right:6%;left:6%;height:1px;background:linear-gradient(90deg,transparent,rgba(37,99,235,.18),transparent);content:"";pointer-events:none}.process-section .section-heading{margin-bottom:16px}.clean-process-section .section-heading h2{font-size:clamp(1.25rem,2.2vw,1.8rem);line-height:1}.clean-process-section .section-heading.split{gap:12px;align-items:center}.clean-process-section .section-heading.split>p{max-width:520px;font-size:.76rem;line-height:1.42}.clean-process-section .eyebrow{min-height:26px;padding:5px 8px;font-size:.68rem}.process-board{position:relative;display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:8px}.process-board:before{display:none}.process-card{position:relative;display:grid;align-content:start;gap:8px;border:1px solid var(--line);border-radius:8px;padding:13px;background:linear-gradient(180deg,#fffffff0,#f4faffd1),#ffffffdb;box-shadow:0 10px 30px #2563eb0f;backdrop-filter:blur(12px);transform:perspective(900px) translateZ(0);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.process-card:hover{border-color:#2563eb47;box-shadow:0 18px 42px #2563eb1a;transform:translateY(-3px) perspective(900px) rotateX(1deg)}.process-card span{display:grid;width:30px;aspect-ratio:1;place-items:center;border:1px solid rgba(37,99,235,.2);border-radius:8px;background:linear-gradient(135deg,#0f172a,#2563eb);color:#fff;font-size:.72rem;font-weight:900;box-shadow:0 9px 20px #2563eb29}.process-card h3{margin:2px 0 0;font-size:.95rem;line-height:1.2}.process-card p{display:-webkit-box;overflow:hidden;margin:0;color:var(--muted);font-size:.82rem;line-height:1.55;-webkit-box-orient:vertical;-webkit-line-clamp:3}.payment-strip{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.payment-strip div{display:flex;min-width:0;align-items:center;gap:8px;border:1px solid var(--line);border-radius:8px;padding:9px 11px;background:#ffffffc7;box-shadow:0 10px 24px #2563eb0d}.payment-strip strong{color:#1d4ed8;font-size:.95rem;line-height:1}.payment-strip span{color:var(--muted);font-size:.84rem;font-weight:750}.clean-process-section:before{display:none}.process-clean-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.process-clean-panel{display:grid;gap:7px;border:1px solid var(--line);border-radius:8px;padding:8px;background:#ffffffc7;box-shadow:0 10px 28px #2563eb0f;backdrop-filter:blur(14px)}.process-clean-heading{display:grid;grid-template-columns:auto 1fr;gap:7px;align-items:start}.process-clean-heading>span{display:grid;width:26px;aspect-ratio:1;place-items:center;border-radius:8px;background:linear-gradient(135deg,#0f172a,#2563eb);color:#fff;font-size:.66rem;font-weight:900}.process-clean-heading h3{margin:0;font-size:.86rem;line-height:1.22}.process-clean-heading p{display:none;margin:3px 0 0;color:var(--muted);font-size:.78rem;line-height:1.45}.step-button-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:5px}.step-pill{display:grid;grid-template-columns:auto auto minmax(0,1fr) auto;min-height:30px;align-items:center;gap:5px;border:1px solid var(--line);border-radius:8px;padding:4px 6px;background:#ffffffc2;color:var(--ink);cursor:pointer;text-align:left;transition:transform .16s ease,border-color .16s ease,background .16s ease,box-shadow .16s ease}.step-pill span{display:grid;width:22px;aspect-ratio:1;place-items:center;border-radius:8px;background:#2563eb1a;color:#1d4ed8;font-size:.62rem;font-weight:900}.step-pill strong{min-width:0;overflow:hidden;font-size:.7rem;text-overflow:ellipsis;white-space:nowrap}.step-pill svg{color:#1d4ed8;width:12px;height:12px}.step-pill:hover,.step-pill:focus-visible{border-color:#2563eb5c;background:#fff;box-shadow:0 12px 28px #2563eb1a;outline:0;transform:translateY(-2px)}.payment-strip.compact{margin-top:0}.payment-strip.compact div{flex:1 1 auto;min-height:28px;padding:4px 7px}.payment-strip.compact strong,.payment-strip.compact span{font-size:.68rem}.process-modal{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:20px;animation:modalShellIn .16s ease-out}.process-modal-backdrop{position:absolute;inset:0;cursor:pointer;background:#111827a3;backdrop-filter:blur(10px)}.process-modal-card{position:relative;z-index:1;width:min(560px,100%);border:1px solid rgba(37,99,235,.18);border-radius:8px;padding:20px;background:#fffffff5;box-shadow:0 28px 90px #0f172a3d;animation:modalCardIn .22s cubic-bezier(.22,1,.36,1)}.process-modal-kicker{width:fit-content;border:1px solid rgba(37,99,235,.16);border-radius:8px;padding:7px 10px;background:#eff8ffdb;color:#1d4ed8;font-size:.78rem;font-weight:900}.process-modal-heading{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:14px;align-items:start;margin-top:16px}.process-modal-heading>span{display:grid;width:44px;aspect-ratio:1;place-items:center;border-radius:8px;background:linear-gradient(135deg,#0f172a,#2563eb);color:#fff;font-weight:900}.process-modal-heading h3{margin:0;font-size:clamp(1.35rem,3vw,2rem);line-height:1.15}.process-modal-heading p{margin:12px 0 0;color:var(--muted);font-size:1rem;line-height:1.78}.process-modal-heading button{display:grid;width:40px;height:40px;place-items:center;border-radius:8px;background:#f2f4f7;color:var(--ink);cursor:pointer}.contact-modal{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:20px;animation:modalShellIn .16s ease-out}.contact-modal-backdrop{position:absolute;inset:0;cursor:pointer;background:radial-gradient(circle at 50% 36%,rgba(37,99,235,.2),transparent 32%),#1118279e;backdrop-filter:blur(12px)}.contact-modal-card{position:relative;z-index:1;width:min(460px,100%);overflow:hidden;border:1px solid rgba(37,99,235,.18);border-radius:8px;padding:20px;background:linear-gradient(135deg,#fffffffa,#eff8fff0),#fff;box-shadow:0 30px 100px #0f172a47;animation:modalCardIn .22s cubic-bezier(.22,1,.36,1)}.contact-modal-card:before{position:absolute;top:0;right:20px;left:20px;height:2px;background:linear-gradient(90deg,#0f172a,#2563eb,#38bdf8);content:""}.contact-modal-top{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:start}.contact-modal-kicker{margin:0;color:#1d4ed8;font-size:.76rem;font-weight:900;letter-spacing:.04em;text-transform:uppercase}.contact-modal-top h3{margin:6px 0 0;font-size:clamp(1.45rem,3vw,2rem);line-height:1.1}.contact-modal-top span{display:block;margin-top:8px;color:var(--muted);font-size:.92rem;line-height:1.58}.contact-modal-top button{display:grid;width:40px;height:40px;place-items:center;border-radius:8px;background:#f2f4f7e6;color:var(--ink);cursor:pointer}.contact-modal-options{display:grid;gap:10px;margin-top:18px}.contact-modal-options a{display:grid;grid-template-columns:42px minmax(0,1fr) auto;min-height:68px;align-items:center;gap:12px;border:1px solid rgba(37,99,235,.14);border-radius:8px;padding:12px;background:#ffffffc7;box-shadow:0 12px 30px #2563eb0f;transition:transform .16s ease,border-color .16s ease,background .16s ease,box-shadow .16s ease}.contact-modal-options a:hover,.contact-modal-options a:focus-visible{border-color:#2563eb5c;background:#fff;box-shadow:0 18px 42px #2563eb1f;outline:0;transform:translateY(-2px)}.contact-modal-options a>svg:first-child{display:grid;width:42px;height:42px;place-items:center;border:1px solid rgba(37,99,235,.16);border-radius:8px;padding:10px;background:#eff8ffe6;color:#1d4ed8}.contact-modal-options a>svg:last-child{color:#1d4ed8}.contact-modal-options span{display:grid;gap:3px;min-width:0;color:var(--muted);font-size:.86rem;line-height:1.35}.contact-modal-options strong{color:var(--ink);font-size:1rem;line-height:1.2}.delivery-flow{margin-top:42px}.delivery-flow .section-heading{margin-bottom:18px}.delivery-flow .section-heading h2{font-size:clamp(2rem,3.5vw,3.3rem)}.delivery-board{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px}.delivery-card{position:relative;display:grid;align-content:start;gap:9px;min-height:178px;border:1px solid var(--line);border-radius:8px;padding:14px;background:linear-gradient(180deg,#fffffff0,#eff8ffd6),#ffffffdb;box-shadow:0 12px 34px #2563eb12;backdrop-filter:blur(12px)}.delivery-card:after{position:absolute;top:33px;right:-10px;z-index:2;width:10px;height:1px;background:#2563eb3d;content:""}.delivery-card:last-child:after{display:none}.delivery-card-top{display:flex;align-items:center;justify-content:space-between;gap:10px}.delivery-card-top span,.delivery-card-top svg{display:grid;width:34px;height:34px;flex:0 0 auto;place-items:center;border-radius:8px}.delivery-card-top span{background:linear-gradient(135deg,#0f172a,#2563eb);color:#fff;font-size:.76rem;font-weight:900}.delivery-card-top svg{border:1px solid rgba(37,99,235,.16);padding:8px;background:#ffffffbd;color:#1d4ed8}.delivery-card h3{margin:2px 0 0;font-size:.98rem;line-height:1.2}.delivery-card p{margin:0;color:var(--muted);font-size:.84rem;line-height:1.58}.featured-media,.project-image{position:relative;display:block;width:100%;overflow:hidden;cursor:pointer;background:#eef2f6}.featured-media{min-height:420px}.featured-media img,.project-image img{width:100%;height:100%;object-fit:cover;transition:transform .22s ease}.cover-fallback{display:grid;width:100%;height:100%;min-height:inherit;align-content:end;gap:8px;padding:18px;background:linear-gradient(180deg,#ffffff1f,#111827d1),linear-gradient(135deg,color-mix(in srgb,var(--accent),#ffffff 30%),#111827);color:#fff;text-align:left}.cover-fallback:before{display:block;width:46px;height:46px;border:1px solid rgba(255,255,255,.38);border-radius:8px;background:linear-gradient(rgba(255,255,255,.18) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.18) 1px,transparent 1px);background-size:12px 12px;content:""}.cover-fallback span,.cover-fallback small{color:#ffffffc2;font-weight:800}.cover-fallback strong{max-width:420px;font-size:clamp(1.3rem,2.2vw,2rem);line-height:1.1}.cover-fallback.large{min-height:420px;padding:clamp(24px,4vw,44px)}.modal-fallback{min-height:min(520px,calc(100svh - 210px))}.featured-media:hover img,.project-image:hover img{transform:scale(1.025)}.featured-media span,.image-count{position:absolute;right:12px;bottom:12px;border-color:#ffffff6b;background:#111827d1;color:#fff;backdrop-filter:blur(10px)}.featured-copy{display:grid;align-content:center;padding:clamp(24px,4vw,46px)}.featured-copy small{width:fit-content;border-radius:8px;padding:7px 10px;background:color-mix(in srgb,var(--accent),#ffffff 84%);color:color-mix(in srgb,var(--accent),#111827 24%);font-weight:800}.featured-copy h3,.project-card h3{margin:14px 0 0;font-size:clamp(1.35rem,2.5vw,2.35rem);line-height:1.16;letter-spacing:0}.featured-copy p,.project-card p{margin:14px 0 0;color:var(--muted);line-height:1.72}.work-toolbar{display:grid;grid-template-columns:minmax(260px,360px) 1fr;gap:14px;align-items:start;margin-bottom:16px}.search-box{display:flex;min-height:48px;align-items:center;gap:10px;border:1px solid var(--line);border-radius:8px;padding:0 13px;background:#ffffffdb;box-shadow:0 14px 40px #2563eb0f}.search-box svg{color:#98a2b3;flex:0 0 auto}.search-box input{width:100%;border:0;outline:0;background:transparent;color:var(--ink);font-size:.95rem}.category-tabs{display:flex;flex-wrap:wrap;gap:8px}.category-tab{min-height:40px;border:1px solid var(--line);border-radius:8px;padding:8px 12px;background:#ffffffc2;color:#475467;cursor:pointer;font-size:.88rem;font-weight:800}.category-tab:hover,.category-tab.active{border-color:#2563eb73;background:linear-gradient(135deg,#0f172a,#2563eb);color:#fff}.result-count{position:static;width:fit-content;margin-bottom:18px}.portfolio-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.project-card{--tilt-x: 0deg;--tilt-y: 0deg;--glare-x: 50%;--glare-y: 50%;display:flex;min-height:100%;flex-direction:column;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:#ffffffd1;box-shadow:0 18px 48px #2563eb14;backdrop-filter:blur(12px);transform:perspective(900px) rotateX(var(--tilt-y)) rotateY(var(--tilt-x));transform-style:preserve-3d;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.project-card:before{position:absolute;inset:0;z-index:2;background:radial-gradient(circle at var(--glare-x) var(--glare-y),rgba(255,255,255,.62),rgba(255,255,255,.12) 18%,transparent 42%);content:"";opacity:0;pointer-events:none;transition:opacity .18s ease}.project-card:hover{border-color:color-mix(in srgb,var(--accent),#d0d5dd 54%);box-shadow:var(--shadow);transform:perspective(900px) translateY(-6px) rotateX(var(--tilt-y)) rotateY(var(--tilt-x))}.project-card:hover:before{opacity:1}.project-image{aspect-ratio:16 / 10;transform:translateZ(20px)}.project-body{display:flex;flex:1;flex-direction:column;padding:18px;transform:translateZ(12px)}.project-kicker,.stack-list{display:flex;flex-wrap:wrap;gap:8px}.stack-list{margin-top:16px}.stack-list span{min-height:28px;border-color:color-mix(in srgb,var(--accent, #2563eb),#e4e7ec 72%);background:color-mix(in srgb,var(--accent, #2563eb),#ffffff 92%);color:#344054}.project-actions{display:flex;flex-wrap:wrap;gap:9px;margin-top:auto;padding-top:20px}.project-actions button{background:var(--ink);color:#fff;cursor:pointer}.skills-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.skill-card{display:flex;min-height:112px;align-items:center;gap:12px;border:1px solid var(--line);border-radius:8px;padding:16px;background:#ffffffc7;box-shadow:0 16px 42px #2563eb0f;backdrop-filter:blur(12px);transform:perspective(900px);transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.skill-card:hover{border-color:color-mix(in srgb,var(--skill),#2563eb 24%);box-shadow:0 22px 58px #2563eb1f;transform:translateY(-4px) rotateX(2deg)}.skill-mark{position:relative;display:grid;width:48px;height:48px;flex:0 0 auto;place-items:center;border:1px solid color-mix(in srgb,var(--skill),#ffffff 56%);border-radius:8px;background:color-mix(in srgb,var(--skill),#ffffff 88%)}.skill-mark img{position:relative;z-index:2;width:30px;height:30px;object-fit:contain}.skill-mark span{position:relative;z-index:2;font-weight:900}.skill-mark i{display:none}.skill-card strong{font-size:1rem}.site-footer{position:relative;display:grid;grid-template-columns:minmax(360px,.9fr) minmax(420px,.72fr);gap:clamp(28px,6vw,88px);align-items:stretch;margin-top:96px;border-top:1px solid rgba(37,99,235,.18);padding:58px max(20px,calc((100vw - 1180px)/2));background:radial-gradient(circle at 84% 12%,rgba(14,165,233,.16),transparent 28%),linear-gradient(135deg,#fffffffa,#eff8ffdb),var(--surface);box-shadow:0 -22px 70px #2563eb12}.site-footer:before{position:absolute;top:0;right:max(20px,calc((100vw - 1180px)/2));left:max(20px,calc((100vw - 1180px)/2));height:1px;background:linear-gradient(90deg,#2563eb,rgba(14,165,233,.38),transparent);content:""}.footer-intro,.footer-contact{min-width:0}.footer-brand span{width:42px;height:42px}.footer-intro h2{margin:22px 0 0;font-size:clamp(1.75rem,3vw,3rem);line-height:1.04;letter-spacing:0}.site-footer p{max-width:680px;margin:18px 0 0;color:var(--muted);line-height:1.72}.footer-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px}.footer-meta span{border:1px solid rgba(37,99,235,.16);border-radius:8px;padding:7px 10px;background:#ffffffbd;color:#344054;font-size:.78rem;font-weight:850}.footer-contact{display:grid;align-content:start;gap:14px;border:1px solid rgba(37,99,235,.14);border-radius:8px;padding:18px;background:#ffffff9e;box-shadow:0 18px 48px #2563eb14;backdrop-filter:blur(16px)}.footer-contact-heading span{display:block;color:#1d4ed8;font-size:.76rem;font-weight:900;letter-spacing:.04em;text-transform:uppercase}.footer-contact-heading strong{display:block;margin-top:4px;font-size:1.08rem}.contact-links{display:grid;grid-template-columns:1fr;gap:9px}.contact-links a{position:relative;display:grid;grid-template-columns:38px minmax(0,1fr);justify-content:stretch;min-width:0;min-height:64px;align-items:center;border-color:#2563eb2e;padding:12px 14px;background:#ffffffd1;box-shadow:0 10px 28px #2563eb0d;font-size:.95rem;overflow:hidden}.contact-links a svg{display:grid;width:38px;height:38px;place-items:center;border:1px solid rgba(37,99,235,.14);border-radius:8px;padding:9px;background:#eff8ffe0;color:#1d4ed8}.contact-links a span{display:grid;gap:2px;min-width:0;overflow:hidden;color:var(--muted);font-size:.82rem;line-height:1.32;overflow-wrap:anywhere}.contact-links a strong{overflow:hidden;color:var(--ink);font-size:.95rem;line-height:1.2;text-overflow:ellipsis;white-space:nowrap}.contact-links a:hover{border-color:#2563eb57;background:#fff}.gallery-modal{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:20px;animation:modalShellIn .18s ease-out}.modal-backdrop{position:absolute;inset:0;cursor:pointer;background:#111827b8;backdrop-filter:blur(10px);animation:backdropIn .18s ease-out}.modal-card{position:relative;z-index:1;display:grid;grid-template-rows:auto minmax(0,1fr) auto;width:min(1120px,100%);height:min(820px,calc(100svh - 40px));max-height:calc(100svh - 40px);overflow:hidden;border-radius:8px;background:var(--surface);box-shadow:0 30px 100px #0f172a47;animation:modalCardIn .26s cubic-bezier(.22,1,.36,1);transform-origin:center}@keyframes modalShellIn{0%{opacity:0}to{opacity:1}}@keyframes backdropIn{0%{opacity:0;backdrop-filter:blur(0)}to{opacity:1;backdrop-filter:blur(10px)}}@keyframes modalCardIn{0%{opacity:0;transform:translateY(24px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-topbar,.modal-footer{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 16px}.modal-topbar{border-bottom:1px solid var(--line)}.modal-topbar span,.modal-footer span{display:block;color:var(--muted);font-size:.82rem;font-weight:800}.modal-topbar strong{display:block;margin-top:2px;font-size:1rem}.modal-topbar button{display:grid;width:40px;height:40px;flex:0 0 auto;place-items:center;border-radius:8px;background:#f2f4f7;color:var(--ink);cursor:pointer}.modal-media{position:relative;display:grid;min-height:0;place-items:center;background:#0b1220;overflow:hidden}.modal-media img{width:auto;height:auto;max-width:100%;max-height:calc(min(820px,calc(100svh - 40px)) - 158px);object-fit:contain}.modal-nav{position:absolute;top:50%;display:grid;width:44px;height:44px;place-items:center;border-radius:8px;background:#ffffffe6;color:var(--ink);cursor:pointer;transform:translateY(-50%)}.modal-nav.prev{left:14px}.modal-nav.next{right:14px}.modal-footer{border-top:1px solid var(--line);background:#fff}.admin-shell{min-height:100vh;padding:32px max(18px,calc((100vw - 1180px)/2)) 48px;background:radial-gradient(circle at 18% 4%,rgba(14,165,233,.18),transparent 26%),radial-gradient(circle at 82% 12%,rgba(37,99,235,.16),transparent 24%),var(--bg)}.admin-hero{display:flex;align-items:end;justify-content:space-between;gap:24px;margin-bottom:28px}.admin-hero h1{margin:14px 0 0;font-size:clamp(2.1rem,5vw,4rem);line-height:.98}.admin-hero p:not(.eyebrow){max-width:680px;margin:14px 0 0;color:var(--muted);line-height:1.7}.admin-back,.admin-sidebar-actions button,.admin-submit-row button,.admin-danger{display:inline-flex;min-height:40px;align-items:center;justify-content:center;gap:8px;border-radius:8px;padding:10px 14px;font-weight:800;cursor:pointer}.admin-back{flex:0 0 auto;border:1px solid var(--line);background:#ffffffc7;color:#1d4ed8}.admin-auth-card,.admin-locked-panel{border:1px solid var(--line);border-radius:8px;background:#ffffffdb;box-shadow:var(--shadow);backdrop-filter:blur(18px)}.admin-auth-card{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:18px;padding:16px}.admin-auth-copy span,.admin-google-user,.admin-google-user button{display:inline-flex;align-items:center;gap:8px}.admin-auth-copy span{color:#1d4ed8;font-size:.78rem;font-weight:900;text-transform:uppercase}.admin-auth-copy h2{margin:8px 0 4px;font-size:1.15rem}.admin-auth-copy p,.admin-google-login span{margin:0;color:var(--muted);font-size:.92rem}.admin-google-login{display:grid;justify-items:end;gap:8px}.admin-google-user{justify-content:flex-end;flex-wrap:wrap}.admin-google-user img{width:38px;height:38px;border-radius:999px}.admin-google-user div{display:grid;min-width:160px}.admin-google-user strong{color:var(--ink);font-size:.92rem}.admin-google-user span{color:var(--muted);font-size:.8rem}.admin-google-user button{min-height:38px;border:1px solid var(--line);border-radius:8px;padding:9px 12px;background:#fff;color:#1d4ed8;font-weight:800;cursor:pointer}.admin-locked-panel{display:grid;justify-items:center;gap:10px;padding:36px 18px;text-align:center;color:#1d4ed8}.admin-locked-panel h2{margin:0;color:var(--ink)}.admin-locked-panel p{margin:0;color:var(--muted)}.admin-layout{display:grid;grid-template-columns:minmax(260px,.34fr) minmax(0,1fr);gap:18px;align-items:start}.admin-sidebar,.admin-form{border:1px solid var(--line);border-radius:8px;background:#ffffffd6;box-shadow:var(--shadow);backdrop-filter:blur(18px)}.admin-sidebar{position:sticky;top:18px;padding:14px}.admin-token-card,.admin-form label,.admin-field{display:grid;gap:8px;color:#344054;font-size:.82rem;font-weight:800}.admin-token-card input,.admin-form input,.admin-form textarea{width:100%;border:1px solid var(--line);border-radius:8px;padding:11px 12px;background:#fff;color:var(--ink);font-size:.95rem;font-weight:600;outline:none;transition:border .16s ease,box-shadow .16s ease}.admin-form input:focus,.admin-form textarea:focus,.admin-token-card input:focus{border-color:#2563eb6b;box-shadow:0 0 0 4px #2563eb1a}.admin-sidebar-actions{display:grid;gap:8px;margin:12px 0}.admin-sidebar-actions button{border:1px solid var(--line);background:#f8fbff;color:#1d4ed8}.admin-sidebar-actions button:disabled,.admin-submit-row button:disabled,.admin-danger:disabled{cursor:not-allowed;opacity:.56}.admin-project-list{display:grid;gap:8px;max-height:58vh;overflow:auto;padding-right:2px}.admin-project-list button{display:grid;gap:5px;border:1px solid var(--line);border-radius:8px;padding:11px;background:#fff;text-align:left;cursor:pointer}.admin-project-list button.active{border-color:#2563eb75;background:#eef6ff}.admin-project-list strong{color:var(--ink);font-size:.9rem}.admin-project-list span,.admin-muted{color:var(--muted);font-size:.78rem;font-weight:700}.admin-form{padding:clamp(16px,3vw,28px)}.admin-form-top{display:flex;align-items:start;justify-content:space-between;gap:18px;margin-bottom:18px}.admin-form-top span{color:#1d4ed8;font-size:.74rem;font-weight:900;text-transform:uppercase}.admin-form-top h2{margin:6px 0 0;font-size:clamp(1.45rem,3vw,2.2rem)}.admin-danger{border:1px solid rgba(220,38,38,.22);background:#fff1f2;color:#be123c}.admin-alert{margin:0 0 14px;border-radius:8px;padding:11px 12px;font-weight:800}.admin-alert.error{border:1px solid rgba(220,38,38,.22);background:#fff1f2;color:#be123c}.admin-alert.success{border:1px solid rgba(5,150,105,.22);background:#ecfdf5;color:#047857}.admin-grid,.admin-media-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.admin-grid .span-2{grid-column:span 2}.admin-field{margin:14px 0}.admin-media-grid{grid-template-columns:minmax(0,.7fr) minmax(0,.8fr) minmax(220px,.5fr);align-items:stretch}.admin-preview{min-height:188px;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:#f8fbff}.admin-preview img{width:100%;height:100%;object-fit:cover}.admin-preview div{display:grid;height:100%;min-height:188px;place-items:center;gap:8px;color:var(--muted);font-weight:800}.admin-submit-row{display:flex;justify-content:flex-end;margin-top:18px}.admin-submit-row button{border:1px solid rgba(37,99,235,.18);background:linear-gradient(135deg,#1d4ed8,#0ea5e9);color:#fff;box-shadow:0 16px 32px #2563eb33}.spin{animation:spin .85s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 1020px){.hero,.featured-card,.section-heading.split,.work-toolbar,.site-footer,.admin-layout,.admin-media-grid{grid-template-columns:1fr}.admin-sidebar{position:static}.admin-auth-card{display:grid}.admin-google-login{justify-items:start}.portfolio-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.process-board{grid-template-columns:repeat(3,minmax(0,1fr))}.process-clean-grid{grid-template-columns:1fr}.delivery-board{grid-template-columns:repeat(3,minmax(0,1fr))}.delivery-card:nth-child(3n):after{display:none}.process-board:before{display:none}.skills-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.featured-media{min-height:340px}}@media (max-width: 720px){.admin-shell{padding:18px 12px 34px}.admin-hero,.admin-form-top{display:grid;align-items:start}.admin-back,.admin-submit-row button,.admin-danger{width:100%}.admin-grid{grid-template-columns:1fr}.admin-grid .span-2{grid-column:auto}.topbar{top:10px;width:min(460px,calc(100% - 18px));min-height:56px;padding:6px}.nav-links{gap:3px}.nav-links a{flex:1 1 0;min-height:38px;padding:8px 5px;font-size:.78rem}.hero,.stats-band,.featured-section,.process-section,.work-section,.skills-section{width:calc(100% - 28px)}.hero{padding-top:38px}.hero h1{font-size:clamp(3rem,16vw,4.6rem)}.hero-actions a,.contact-popup-trigger{width:100%}.stats-band,.process-board,.portfolio-grid,.skills-grid,.contact-links{grid-template-columns:1fr}.process-board{grid-template-columns:repeat(2,minmax(0,1fr))}.process-clean-panel{padding:10px}.step-button-grid{grid-template-columns:1fr}.process-modal{padding:12px}.contact-modal{padding:14px}.contact-modal-card{padding:18px}.process-modal-card{padding:16px}.process-modal-heading{grid-template-columns:auto minmax(0,1fr)}.process-modal-heading button{position:absolute;top:14px;right:14px}.delivery-flow{margin-top:34px}.delivery-board{grid-template-columns:1fr}.delivery-card{min-height:auto}.delivery-card:after{display:block;inset:auto auto -10px 31px;width:1px;height:10px}.delivery-card:last-child:after{display:none}.payment-strip div{flex:1 1 100%}.stats-band div{padding:16px}.featured-section,.work-section,.skills-section{padding-top:54px}.featured-media{min-height:260px}.project-card h3,.featured-copy h3{font-size:1.45rem}.category-tabs{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px;scrollbar-width:thin}.category-tab{flex:0 0 auto}.project-actions button,.project-actions a{width:100%}.site-footer{margin-top:58px;padding:28px 14px}.contact-links{grid-template-columns:1fr}.gallery-modal{padding:10px}.modal-card{height:calc(100svh - 20px);max-height:calc(100svh - 20px)}.modal-media img{width:auto;height:auto;max-width:100%;max-height:calc(100svh - 178px)}}@media (max-width: 380px){.topbar{width:calc(100% - 12px);padding:5px}.nav-links{gap:2px}.nav-links a{min-height:36px;padding:7px 2px;font-size:.72rem}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
