:root{--bg:#FDFCF9;--text-dark:#363431;--text-secondary:#4F4B43;--text-nav:#8d8b86;--text-subtitle:#DBD6CB;--text-muted:#9C927E;--bright-text-yellow:#FEC450;--accent-yellow:#FFDE9D;--accent-green:#DBFCB6;--accent-orange:#E8915C;--accent-red:#D66B6B;--dot-color:#F1EFEA;--dot-color-light:#F1EFEA;--footer-bg:#FDFCF9;--footer-dot:#171615;--footer-name:#EADCC2;--font:"Gantari",sans-serif;--page-padding:clamp(calc((100vw - 88rem) / 2),5vw,calc((100vw - 4rem) / 2));--asterisk-project:#59554C}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-family:var(--font);font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}body,html{min-height:100%;background:var(--bg)}body{color:var(--text-secondary);overflow-x:hidden}body.dot-cursor-enabled,body.dot-cursor-enabled *{cursor:none!important}#root{width:100%;max-width:none;margin:0;position:relative;overflow-x:hidden}img{display:block;max-width:100%}a{text-decoration:none;color:inherit}button{border:none;background:none;cursor:pointer;font-family:inherit}.app{min-height:100vh}.app,.page-shell{position:relative;width:100%;background:var(--bg)}.page-shell{padding-left:var(--page-padding);padding-right:var(--page-padding)}:root{--navbar-height:60px}.navbar{display:grid;grid-template-columns:minmax(180px,1fr) auto minmax(180px,1fr);align-items:center;min-height:var(--navbar-height);padding:20px var(--page-padding);grid-column-gap:24px;column-gap:24px;margin-left:calc(-1 * var(--page-padding));margin-right:calc(-1 * var(--page-padding));position:-webkit-sticky;position:sticky;top:0;z-index:160;transition:transform .28s ease,opacity .24s ease,background-color .24s ease,-webkit-backdrop-filter .24s ease;transition:transform .28s ease,opacity .24s ease,background-color .24s ease,backdrop-filter .24s ease;transition:transform .28s ease,opacity .24s ease,background-color .24s ease,backdrop-filter .24s ease,-webkit-backdrop-filter .24s ease;will-change:transform,opacity}.navbar.is-visible{transform:translateY(0);opacity:1;pointer-events:auto}.navbar.is-hidden{transform:translateY(calc(-100% - 12px));opacity:0;pointer-events:none}.navbar.is-at-top{background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;border-bottom:1px solid transparent}.navbar.is-floating{background:color-mix(in srgb,var(--bg) 72%,transparent);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.navbar-name{justify-self:start;font-size:18px;font-weight:500;color:var(--text-secondary);line-height:.88;letter-spacing:-.04em}.navbar-links{justify-self:center;display:flex;gap:22px}.navbar-link{font-size:16px;font-weight:400;color:var(--text-nav);transition:color .2s ease;letter-spacing:-.02em}.navbar-link.is-active,.navbar-link:hover{color:var(--text-secondary)}.navbar-social{justify-self:end;display:flex;align-items:center;gap:13px}.navbar-social-link{display:inline-flex;align-items:center;justify-content:center;transition:opacity .2s ease}.navbar-social-link:hover{opacity:.9}.navbar-social-icon{width:18px;height:18px;object-fit:contain;opacity:.88;filter:invert(61%) sepia(7%) saturate(402%) hue-rotate(9deg) brightness(80%) contrast(86%);transition:filter .2s ease,opacity .2s ease}.navbar-social-link:hover .navbar-social-icon{opacity:1;filter:invert(53%) sepia(7%) saturate(447%) hue-rotate(10deg) brightness(83%) contrast(90%)}@media (max-width:1024px){.navbar{grid-template-columns:minmax(120px,1fr) auto minmax(120px,1fr);column-gap:18px}.navbar-name{font-size:16px}.navbar-link{font-size:14px}.navbar-links{gap:20px}.navbar-social{gap:8px}}@media (max-width:900px){:root{--navbar-height:132px}.navbar{grid-template-columns:1fr auto;grid-template-areas:"name social" "links links";row-gap:10px;min-height:var(--navbar-height);padding:14px var(--page-padding) 18px}.navbar-name{grid-area:name}.navbar-links{grid-area:links}.navbar-social{grid-area:social}}@media (max-width:560px){:root{--navbar-height:140px}.navbar-links{gap:16px}.navbar-social-icon{width:16px;height:16px}}.hero{position:relative;display:flex;flex-direction:column;justify-content:center;box-sizing:border-box;padding:clamp(20px,4svh,52px) 0 clamp(36px,8svh,88px);min-height:calc(100svh - var(--navbar-height));overflow:visible}.hero-content{flex:0 1 auto;align-items:stretch;gap:24px;z-index:10;min-height:0}.hero-content,.hero-left{display:flex;justify-content:space-between;position:relative}.hero-left{flex:1 1;min-width:0;max-width:720px;flex-direction:column;align-items:flex-start;padding-top:clamp(0px,12svh,134px)}.hero-left-center{flex:0 0 auto;display:flex;flex-direction:column;justify-content:flex-start;align-items:flex-start;min-height:0;width:100%}.hero-title{font-size:75px;font-weight:600;color:var(--text-dark);line-height:.88;margin-bottom:0;letter-spacing:-.04em;transform-origin:left center;transition:transform .22s ease}.hero-title:hover{transform:scale(1.03)}.hero-subtitle{display:flex;flex-direction:column;gap:0}.subtitle-line{font-size:55px;font-weight:500;color:var(--text-dark);line-height:1;display:flex;align-items:center;flex-wrap:wrap;gap:0 8px;letter-spacing:-.04em}.western-img{width:50px;height:50px;border-radius:14px;border:3px solid var(--text-subtitle);object-fit:cover;display:inline-block;vertical-align:middle;margin:0 -4px 0 4px;transform:rotate(1.8deg)}.western-text{display:inline-flex;color:#d0b8eb;transform-origin:left center;transition:transform .2s ease}.western-text:hover{transform:scale(1.03)}.software-cluster{display:inline-flex;align-items:center;transform-origin:left center;transition:transform .2s ease}.software-cluster:hover{transform:scale(1.03)}.html-tag{width:20px;height:28px;display:inline-block;vertical-align:middle;flex-shrink:0;margin-top:8px;transition:transform .2s ease}.software-cluster:hover .html-tag:first-child{transform:translateX(-5px)}.software-cluster:hover .html-tag:last-child{transform:translateX(5px)}.software-text{color:var(--bright-text-yellow);font-weight:600;padding-left:3px;padding-right:3px}.and-text{color:var(--text-dark)}.design-text-wrapper{position:relative;display:inline-block;margin-left:6px;transform-origin:left bottom;transition:transform .2s ease}.design-text-wrapper:hover{transform:scale(1.03)}.design-text{color:#a7dd89;position:relative;z-index:1;font-weight:600;font-style:italic}.design-draw-svg,.design-line{position:absolute;bottom:-8px;left:-6px;width:110%;height:auto;z-index:0;pointer-events:auto}.design-draw-svg{overflow:visible}@keyframes drawLine{to{stroke-dashoffset:0}}.currently-section{margin-top:0;flex-shrink:0;margin-bottom:0}.currently-label{font-size:22px;font-weight:500;color:#9a978f;display:block;margin-bottom:4px;letter-spacing:-.03em}.currently-items{display:flex;flex-direction:column;gap:6px}.currently-item{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:500;color:#d1ccc1}.asterisk{width:14px;height:14px;flex-shrink:0}.highlight{padding:1.5px 7px;border-radius:8px;font-weight:600;font-size:18px}.highlight-yellow{background:var(--accent-yellow);color:#AA8F5A;border:1px solid #f6d38b}.highlight-green{background:var(--accent-green);color:#91A47C;border:1px solid #c7ec9e}.hero-right{display:flex;justify-content:flex-end;align-items:flex-end;flex-shrink:0}.hero-dot-grid{opacity:.9}.hero-scroll-button{position:absolute;left:50%;bottom:clamp(6px,1.8svh,20px);transform:translateX(-50%);width:34px;height:42px;display:grid;place-items:center;color:var(--text-nav);opacity:.92;z-index:20;transition:opacity .22s ease,transform .22s ease;animation:hero-scroll-nudge 1.7s ease-in-out infinite}.hero-scroll-button:hover{opacity:1}.hero-scroll-button:focus-visible{outline:2px solid var(--text-secondary);outline-offset:3px;border-radius:8px}.hero-scroll-dots{--dot-size:6px;--dot-gap:2px;display:inline-grid;grid-template-columns:repeat(3,var(--dot-size));grid-template-rows:repeat(5,var(--dot-size));gap:var(--dot-gap)}.hero-scroll-dot{width:var(--dot-size);height:var(--dot-size);border-radius:50%;background:#E0DAD0;transition:background-color .16s ease}.hero-scroll-dot--dark{background:#A6A39F}.hero-scroll-dot--stem-1{grid-column:2;grid-row:1}.hero-scroll-dot--stem-2{grid-column:2;grid-row:2}.hero-scroll-dot--stem-3{grid-column:2;grid-row:3}.hero-scroll-dot--head-left{grid-column:1;grid-row:4}.hero-scroll-dot--head-center{grid-column:2;grid-row:4}.hero-scroll-dot--head-right{grid-column:3;grid-row:4}.hero-scroll-dot--tip{grid-column:2;grid-row:5}@keyframes hero-scroll-nudge{0%,to{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(4px)}}@media (max-width:1550px){.hero-title{font-size:68px}.subtitle-line{font-size:50px}}@media (max-width:1024px){.hero{padding:clamp(16px,2.8svh,28px) 0 clamp(28px,5svh,40px);min-height:calc(100svh - var(--navbar-height))}.hero-content{min-height:0}.hero-left-center{flex:0 1 auto;justify-content:flex-start}.hero-title{font-size:56px}.subtitle-line{font-size:36px}.western-img{width:32px;height:32px}}@media (max-width:768px){.hero{padding:14px 0 26px;min-height:calc(100svh - var(--navbar-height))}.hero-content{flex-direction:column;align-items:stretch}.hero-left{max-width:100%;justify-content:flex-start;gap:32px}.hero-left-center{flex:0 1 auto;justify-content:flex-start}.hero-title{font-size:42px}.subtitle-line{font-size:28px}.western-img{width:26px;height:26px}.html-tag{width:10px;height:16px}.hero-right{margin-top:40px;justify-content:center}.hero-scroll-button{bottom:2px}.hero-dot-grid{transform:scale(.7);transform-origin:center}}.collection-canvas-page{position:fixed;inset:0;width:100vw;height:100vh;overflow:hidden;background:#FDFCF9;--collection-header-top:20px;--collection-header-height:44px;--collection-loading-gap:12px}.collection-floating-header{position:absolute;top:20px;left:50%;transform:translateX(-50%);z-index:100;display:flex;align-items:center;gap:8px}.collection-header-chip{background:#FFFFFF;border-radius:16px;box-shadow:0 1px 3px rgba(0,0,0,.07),0 2px 8px rgba(0,0,0,.06);display:flex;align-items:center;justify-content:center;height:42px;padding:0 18px;font-size:16px;font-weight:500;color:#59554C;border:none;cursor:default;transition:background-color .16s ease,box-shadow .16s ease;white-space:nowrap;-webkit-tap-highlight-color:transparent;font-family:inherit}.collection-header-back{padding:0 12px;cursor:pointer;text-decoration:none;color:inherit}.collection-header-back-dots{--dot-size:8px;--dot-gap:2px;display:inline-grid;grid-template-columns:repeat(5,var(--dot-size));grid-template-rows:repeat(3,var(--dot-size));gap:var(--dot-gap)}.collection-header-back-dot{width:var(--dot-size);height:var(--dot-size);border-radius:50%;transition:background-color .16s ease}.collection-header-back-dot--dark{background:#383530}.collection-header-back-dot--light{background:#E0DAD0}.collection-header-back-dot--middle-left{grid-column:1;grid-row:2}.collection-header-back-dot--middle-anchor{grid-column:2;grid-row:2}.collection-header-back-dot--middle-3{grid-column:3;grid-row:2}.collection-header-back-dot--middle-4{grid-column:4;grid-row:2}.collection-header-back-dot--middle-5{grid-column:5;grid-row:2}.collection-header-back-dot--top-anchor{grid-column:2;grid-row:1}.collection-header-back-dot--bottom-anchor{grid-column:2;grid-row:3}.collection-header-back:hover .collection-header-back-dot--dark{background:#FEC450}.collection-header-title{letter-spacing:-.01em}.collection-header-search{padding:0 14px;gap:8px;min-width:200px;justify-content:flex-start}.collection-header-search-icon{width:16px;height:16px;color:#8f8d89;flex-shrink:0}.collection-header-search-input{border:none;outline:none;background:transparent;font-size:14px;font-weight:400;color:#383530;width:100%;min-width:0;padding:0;font-family:inherit}.collection-header-search-input::placeholder{color:#CFCBC3}.collection-header-year{cursor:pointer;font-size:16px;font-weight:500;padding:0 16px}.collection-header-year:hover{background:#FEC450}.collection-header-year.is-active{background:#FEC450;color:#3F3626}.collection-header-year:focus,.collection-header-year:focus-visible{outline:none;box-shadow:none}.collection-canvas-viewport{width:100%;height:100%;overflow:auto;cursor:-webkit-grab;cursor:grab;touch-action:pan-x pan-y;-webkit-overflow-scrolling:touch;scrollbar-width:none}.collection-canvas-viewport::-webkit-scrollbar{display:none}.collection-canvas-viewport.is-panning{cursor:-webkit-grabbing;cursor:grabbing;-webkit-user-select:none;-moz-user-select:none;user-select:none}.collection-canvas-surface{position:relative;background-color:#FDFCF9;background-image:radial-gradient(circle,#E5E1DB 1.2px,transparent 0);background-size:28px 28px}.collection-freeform-card{position:absolute;background:#FFFFFF;border-radius:14px;padding:17px;display:flex;flex-direction:column;box-shadow:0 1px 4px rgba(0,0,0,.06),0 3px 10px rgba(0,0,0,.04);opacity:0;transform:scale(.55) rotate(var(--card-rotation,0deg));transition:opacity .35s ease,transform .32s cubic-bezier(.22,1,.36,1),box-shadow .25s ease;will-change:transform,opacity;cursor:default}.collection-freeform-card.is-visible{opacity:1;transform:scale(1) rotate(var(--card-rotation,0deg))}.collection-freeform-card.is-visible:hover{transform:scale(1.05) rotate(0deg);box-shadow:0 4px 16px rgba(0,0,0,.1),0 8px 24px rgba(0,0,0,.06);z-index:10}.collection-freeform-card-drawing{border-radius:0;background:#ffffff;width:100%;aspect-ratio:1/1;display:block;line-height:0;overflow:hidden;margin-bottom:12px}.collection-freeform-card-canvas{display:block;width:100%;height:100%;margin:0}.collection-freeform-card-title{color:#54524D;font-size:14px;font-weight:500;margin-bottom:3px}.collection-freeform-card-meta,.collection-freeform-card-title{line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.collection-freeform-card-meta{color:#BEBAB3;font-size:12px;font-weight:400}.collection-canvas-loading{position:absolute;top:calc(var(--collection-header-top) + var(--collection-header-height) + var(--collection-loading-gap));left:50%;transform:translateX(-50%);z-index:90;pointer-events:none}.collection-canvas-spinner{width:32px;height:32px;border:3px solid #e5e1db;border-top-color:#9f978a;border-radius:50%;animation:collectionCanvasSpin .7s linear infinite}@keyframes collectionCanvasSpin{to{transform:rotate(1turn)}}.collection-canvas-status{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:50;color:#8A816E;font-size:15px;pointer-events:none;text-align:center}@media (max-width:768px){.collection-canvas-page{--collection-header-top:14px;--collection-header-height:38px}.collection-floating-header{top:14px;gap:4px}.collection-header-chip{height:38px;padding:0 12px;font-size:13px;border-radius:12px}.collection-header-search{min-width:120px}}.case-study-page{--case-study-rail-top:calc(var(--navbar-height) + clamp(28px, 4.5vw, 56px));position:relative;width:100%;padding-top:clamp(28px,4.5vw,56px);padding-bottom:70px}.case-study-page.is-navbar-hidden{--case-study-rail-top:clamp(20px,2vw,40px)}.case-study-rail{position:fixed;left:var(--page-padding);top:var(--case-study-rail-top);width:min(180px,18vw);display:flex;flex-direction:column;align-items:flex-start;gap:22px;z-index:50;transition:top .24s ease;will-change:top}@media (prefers-reduced-motion:reduce){.case-study-rail{transition:none}}.case-study-back-button{display:inline-flex;align-items:center;justify-content:center;line-height:0}.case-study-back-button:focus-visible{outline:2px solid #FEC450;outline-offset:6px;border-radius:10px}.case-study-back-dots{--back-dot-size:12px;--back-dot-gap:2px;display:inline-grid;grid-template-columns:repeat(5,var(--back-dot-size));grid-template-rows:repeat(3,var(--back-dot-size));gap:var(--back-dot-gap)}.case-study-back-dot{width:var(--back-dot-size);height:var(--back-dot-size);border-radius:50%;transition:background-color .16s ease}.case-study-back-dot--dark{background:#383530}.case-study-back-dot--light{background:#E0DAD0}.case-study-back-dot--middle-left{grid-column:1;grid-row:2}.case-study-back-dot--middle-anchor{grid-column:2;grid-row:2}.case-study-back-dot--middle-3{grid-column:3;grid-row:2}.case-study-back-dot--middle-4{grid-column:4;grid-row:2}.case-study-back-dot--middle-5{grid-column:5;grid-row:2}.case-study-back-dot--top-anchor{grid-column:2;grid-row:1}.case-study-back-dot--bottom-anchor{grid-column:2;grid-row:3}.case-study-back-button:hover .case-study-back-dot--dark{background:#FEC450}.case-study-back-button:focus-visible .case-study-back-dot--dark{background:#FEC450}.case-study-toc{width:100%}.case-study-toc-list{list-style:none;display:flex;flex-direction:column;gap:12px}.case-study-toc-link{display:inline-flex;align-items:center;gap:10px;color:#8E867A;font-size:15px;line-height:1.25}.case-study-toc-dot{width:11px;height:11px;border-radius:50%;background:#E0DAD0;flex-shrink:0;transition:background-color .16s ease}.case-study-toc-link.is-active .case-study-toc-dot{background:#FEC450}.case-study-toc-link.is-active .case-study-toc-text{color:#5A554C}.case-study-main{width:min(100%,900px);min-width:0;margin-left:auto;margin-right:auto;padding-inline:clamp(0px,2.4vw,10px)}.case-study-header{margin-bottom:21px}.case-study-subtitle{color:#9F978A;font-size:clamp(13px,1.5vw,16px);font-weight:500;display:inline-flex;align-items:center;gap:8px;margin-bottom:12px}.case-study-subtitle-separator{color:#D2CDBF}.case-study-title{color:#3E3A34;font-weight:400;line-height:1.05;letter-spacing:-.03em;font-size:clamp(34px,5vw,55px)}.case-study-cover-frame{width:100%;margin:0;border-radius:14px;overflow:hidden;border:1px solid #f5f3ef;background:var(--dot-color-light);aspect-ratio:16/9}.case-study-cover-image{width:100%;height:100%;object-fit:cover}.case-study-info-grid{margin-top:22px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:12px;gap:12px;padding-bottom:24px;border-bottom:1px solid #f0ece4}.case-study-info-column{min-width:0}.case-study-info-title{color:#C0BAAD;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.02em;margin-bottom:7px}.case-study-info-list{list-style:none;display:flex;flex-direction:column;gap:4px}.case-study-info-item{color:#746C5F;font-size:15px;line-height:1.35}.case-study-sections{margin-top:38px;display:flex;flex-direction:column;gap:40px}.case-study-custom-content{margin-top:38px;width:100%}@media (max-width:1280px){.case-study-rail{position:-webkit-sticky;position:sticky;left:auto;top:var(--case-study-rail-top);width:-moz-fit-content;width:fit-content;max-width:100%;margin-bottom:26px;z-index:30;background:color-mix(in srgb,var(--bg) 86%,transparent);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border-radius:14px;padding:10px 12px}}@media (max-width:1100px){.case-study-back-dots{--back-dot-size:8px;--back-dot-gap:6px}}@media (max-width:880px){.case-study-rail{margin-bottom:22px}.case-study-main{padding-inline:0}.case-study-toc-list{gap:9px}.case-study-info-grid{grid-template-columns:repeat(2,minmax(0,1fr));row-gap:15px}}@media (max-width:620px){.case-study-info-grid{grid-template-columns:1fr;gap:14px}}.ripple-case-content{display:flex;flex-direction:column;gap:40px}.ripple-section-eyebrow{color:#B8B2A5;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}.ripple-section-title{color:#3F3A32;font-size:clamp(25px,3.3vw,40px);line-height:1.1;letter-spacing:-.03em;font-weight:400;margin-bottom:16px}.ripple-section-body{color:#757065;font-size:clamp(16px,2vw,18px);line-height:1.72;max-width:72ch}@media (max-width:620px){.ripple-section-body{max-width:none}}.projects{padding:40px 0 150px;position:relative;z-index:10;text-align:left}.projects,.projects-body{width:100%}.projects-main{min-width:0}.projects-header{display:flex;align-items:center;gap:10px;margin-bottom:32px;justify-content:center}.projects-title{font-size:22px;font-weight:400;color:#BDBBB5;letter-spacing:-.04em;text-align:center;margin-bottom:5px}.projects-grid{--projects-column-gap:30px;--project-col-max:900px;display:grid;grid-template-columns:repeat(2,minmax(0,var(--project-col-max)));grid-column-gap:var(--projects-column-gap);column-gap:var(--projects-column-gap);grid-row-gap:75px;row-gap:75px;justify-content:start;justify-items:stretch;width:-moz-fit-content;width:fit-content;max-width:100%}@media (max-width:1024px){.projects{padding:30px 0 40px}.projects-grid{--project-col-max:360px;row-gap:36px}}@media (max-width:768px){.projects{padding:24px 0 40px}.projects-grid{grid-template-columns:1fr;gap:36px}}.project-card{display:block;width:100%;min-width:0;position:relative}.project-card-link{text-decoration:none;color:inherit}.project-card-link:focus-visible{outline:2px solid #FEC450;outline-offset:6px;border-radius:18px}.project-card-bg{position:absolute;inset:-4px;border-radius:16px;background:rgba(0,0,0,.02);opacity:0;transition:opacity .3s ease;z-index:0}.project-card-bg.visible{opacity:1}.project-card-content{position:relative;z-index:1;transition:transform .3s ease}.project-card-content.hovered{transform:scale(.97)}.project-card-image{width:100%;aspect-ratio:16/9;border-radius:14px;overflow:hidden;display:flex;align-items:center;justify-content:center;margin-bottom:14px;background:var(--dot-color-light);border:1px solid #f5f3ef}.project-card-thumb{width:100%;height:100%;object-fit:cover}.project-card-info{padding:0 4px}.project-card-heading{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:8px}.project-card-title{font-size:21px;font-weight:600;color:#45433F;margin-bottom:0;min-width:0}.project-card-meta{font-size:17px;font-weight:500;color:#939393;flex-shrink:0;text-align:right;white-space:nowrap}.project-card-desc{font-size:14px;font-weight:400;color:#A6A29B;line-height:1.4;letter-spacing:-.02em}@media (max-width:768px){.project-card-title{font-size:16px}.project-card-image{aspect-ratio:16/9}}.footer,.footer-section{width:100%;background:var(--bg)}.footer{margin-top:100px}.footer-bottom{position:relative;display:flex;align-items:flex-end;justify-content:space-between;gap:24px;width:100%;padding:0 var(--page-padding) 20px}.footer-bottom-left{display:flex;flex-direction:row;align-items:flex-end;flex-wrap:wrap;row-gap:0;column-gap:clamp(10px,3vw,25px);min-width:0;flex:1 1 auto;padding-bottom:0}.footer-bottom-name{flex-shrink:0}.footer-name-text{font-size:43px;font-weight:500;color:#FEC450;line-height:1.15;white-space:nowrap;position:relative;letter-spacing:-.04em}.footer-name-text:before{content:"";position:absolute;inset:-8px -12px;background:transparent;z-index:-1;border-radius:4px}.footer-bottom-middle{display:flex;align-items:flex-end;justify-content:flex-start;flex-wrap:wrap;gap:4px;flex:0 1 auto;min-width:0;margin-left:0;padding-bottom:0}.footer-info-item{display:flex;flex-direction:column;gap:2px;background:transparent;padding:8px 0;border-radius:4px;position:relative;align-items:flex-start;justify-content:center}.footer-info-item-last{padding:8px 30px}.footer-info-label{margin-bottom:-2px}.footer-info-label,.footer-info-value{font-size:12px;font-weight:400;color:#DBD6CB;white-space:nowrap}.footer-info-spacer{display:flex;align-items:center;padding-bottom:4px;width:35px}.footer-info-dot{width:6px;height:6px;border-radius:50%;background:var(--footer-dot);flex-shrink:0}.footer-bottom-social{display:flex;gap:10px;align-items:flex-end;justify-content:flex-end;flex-shrink:0;padding-bottom:10px;margin-left:auto}.footer-social-link{display:flex;align-items:center;justify-content:center;transition:opacity .2s ease}.footer-social-link:hover{opacity:.7}.footer-social-badge{width:39px;height:39px;border-radius:50%;background:#F5F3EF;display:flex;align-items:center;justify-content:center;flex-shrink:0}.footer-social-icon{width:24px;height:24px}@media (max-width:1400px){.footer-name-text{font-size:80px}.footer-info-label,.footer-info-value{font-size:13px}}@media (max-width:1024px){.footer-bottom{padding:0 var(--page-padding) 36px;flex-wrap:wrap;gap:24px}.footer-name-text{font-size:48px}}@media (max-width:768px){.footer-bottom{flex-direction:column;align-items:flex-start;padding:0 var(--page-padding) 32px;gap:20px}.footer-name-text{font-size:32px}.footer-bottom-left{flex-direction:column;align-items:flex-start;gap:16px;width:100%}.footer-bottom-middle{gap:8px;flex-wrap:wrap}.footer-bottom-social{gap:20px;margin-left:0;align-self:flex-end;width:100%;justify-content:flex-end;padding-right:0}}.canvas-section{width:100%;background:var(--bg);padding:28px var(--page-padding) 0}.canvas-grid-shell{position:relative;overflow:hidden}.canvas-dots-layer{pointer-events:none}.canvas-dots-bg,.canvas-dots-layer{position:absolute;inset:0;z-index:1}.canvas-dots-bg{background-repeat:space}.canvas-dots-accents{position:absolute;inset:0;z-index:2;pointer-events:none}.canvas-dot-accent{position:absolute;border-radius:50%;box-sizing:border-box}.canvas-stage{position:relative;z-index:10;min-height:350px;height:350px;margin:0;width:100%;overflow:hidden}.canvas-mobile-list{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;align-items:center;padding:10px 0}.canvas-mobile-img{height:auto;border-radius:6px;pointer-events:none}@media (max-width:768px){.canvas-section{padding-top:20px}.canvas-stage{height:auto;min-height:auto;padding-top:12px}}.draggable-item{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;touch-action:none;z-index:20}.draggable-item.static{position:relative;cursor:default!important}.draggable-img{width:100%;height:auto;pointer-events:none;border-radius:6px}.selection-border{position:absolute;inset:-3px;border:2px solid #4d90fe;border-radius:8px;pointer-events:none}.resize-handle{position:absolute;width:12px;height:12px;background:#fff;border:2px solid #4d90fe;border-radius:2px;z-index:30;box-sizing:border-box}.resize-handle-nw{top:-6px;left:-6px;cursor:nwse-resize}.resize-handle-ne{top:-6px;right:-6px;cursor:nesw-resize}.resize-handle-sw{bottom:-6px;left:-6px;cursor:nesw-resize}.resize-handle-se{bottom:-6px;right:-6px;cursor:nwse-resize}.rotate-handle{position:absolute;top:-28px;left:50%;transform:translateX(-50%);width:22px;height:22px;background:#fff;border:1.5px solid #4d90fe;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:-webkit-grab;cursor:grab;z-index:30}.rotate-handle:active{cursor:-webkit-grabbing;cursor:grabbing}.floating-cursor{position:absolute;z-index:50;pointer-events:none;will-change:transform}.cursor-icon{display:block}.cursor-label{position:absolute;top:18px;left:16px;padding:6px 16px;border-radius:20px;border:1.5px solid;white-space:nowrap}.cursor-label-text{font-size:14px;font-weight:500;color:#fff;line-height:1}@media (max-width:768px){.floating-cursor{transform:scale(.7)!important}}.dot-grid{position:relative;flex-shrink:0}.dot-grid-dot{position:absolute;border-radius:50%;transition:background-color .15s ease,transform .2s ease,opacity .2s ease}.dot-grid-dot.is-clearing{animation:dot-grid-clear-wave .22s ease forwards}.dot-grid-dot.is-hover-preview{animation-name:dot-grid-hover-preview-wave;animation-timing-function:cubic-bezier(.2,.82,.22,1);animation-fill-mode:both}@keyframes dot-grid-clear-wave{0%{transform:scale(1);opacity:1}55%{transform:scale(1.25);opacity:.5}to{transform:scale(.2);opacity:0}}@keyframes dot-grid-hover-preview-wave{0%{transform:scale(.35);opacity:0}58%{transform:scale(1.16);opacity:1}to{transform:scale(1);opacity:1}}.dot-grid-tool-button{position:absolute;z-index:5;display:grid;place-items:center;border-radius:50%;background:#59554C;color:#FDFCF9;font-size:12px;font-weight:700;line-height:1;text-transform:lowercase;border:0;padding:0}.dot-grid-pencil-button{color:#FDFCF9}.dot-grid-pencil-icon{width:60%;height:60%}.dot-grid-share-icon{width:62%;height:62%}.dot-grid-clear-button:focus-visible{outline:2px solid #FDFCF9;outline-offset:3px}.dot-grid-pencil-button:focus-visible{outline:2px solid #FDFCF9;outline-offset:3px}.dot-grid-share-button:focus-visible{outline:2px solid #FDFCF9;outline-offset:3px}.dot-grid-export-button{font-size:10px;letter-spacing:-.04em}.dot-grid-export-button:focus-visible{outline:2px solid #FDFCF9;outline-offset:3px}.dot-grid-share-overlay{position:fixed;inset:0;z-index:120;display:grid;place-items:center;background:rgba(53,49,40,.16);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:dot-grid-share-fade .2s ease-out}.dot-grid-share-overlay.is-closing{animation:dot-grid-share-fade-out .22s ease forwards}.dot-grid-share-modal{width:min(90vw,400px);background:#FDFCF9;border-radius:22px;padding:20px;box-shadow:0 22px 60px rgba(53,49,40,.18);border:1px solid #eae4d8;animation:dot-grid-share-pop .28s cubic-bezier(.2,.8,.2,1)}.dot-grid-share-modal.is-closing{animation:dot-grid-share-pop-out .22s ease forwards}.dot-grid-share-preview-box{position:relative;border-radius:18px;border:1px solid #e2dbce;background:#ffffff;padding:22px;display:grid;place-items:center}.dot-grid-share-canvas{display:block;max-width:100%;height:auto}.dot-grid-share-close{position:absolute;top:10px;right:10px;width:28px;height:28px;border-radius:999px;display:grid;place-items:center;background:#59554C;color:#FDFCF9;font-size:13px;font-weight:700;line-height:1;text-transform:lowercase}.dot-grid-share-close:focus-visible{outline:2px solid #59554C;outline-offset:2px}.dot-grid-share-actions{margin-top:14px;display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px}.dot-grid-share-form{margin-top:12px;display:grid;grid-gap:10px;gap:10px}.dot-grid-share-field{display:grid;grid-gap:6px;gap:6px}.dot-grid-share-label{color:#7D7668;font-size:12px;font-weight:700;letter-spacing:.02em;text-transform:uppercase}.dot-grid-share-input{border:1px solid #e2dbce;background:#FFFDF7;color:#4F4B43;font-size:14px;font-weight:600;border-radius:12px;padding:10px 12px}.dot-grid-share-input::placeholder{color:#A89E8D}.dot-grid-share-input:focus-visible{outline:2px solid #CFC5B1;outline-offset:2px}.dot-grid-share-error{color:#B14E4E;font-size:12px;font-weight:600}.dot-grid-share-action{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 14px;border-radius:14px;border:1px solid #e2dbce;background:#FFFDF7;color:#4F4B43;font-size:14px;font-weight:600;transition:transform .15s ease,border-color .15s ease,background .15s ease}.dot-grid-share-action:hover{transform:translateY(-1px);border-color:#CFC5B1;background:#F8F3E7}.dot-grid-share-action:focus-visible{outline:2px solid #CFC5B1;outline-offset:2px}.dot-grid-share-action.is-confirm-share{background:#FEC450;border-color:#F1B638;color:#3F3626}.dot-grid-share-action.is-confirm-share:hover{background:#F9BB3E;border-color:#E2AA34}.dot-grid-share-save-action.is-loading,.dot-grid-share-save-action.is-success{transform:none}.dot-grid-share-save-action:disabled{cursor:default;opacity:.95}.dot-grid-share-spinner{width:14px;height:14px;border-radius:999px;border:2px solid rgba(79,75,67,.22);border-top-color:#4f4b43;animation:dot-grid-share-spin .7s linear infinite}.dot-grid-share-check{width:15px;height:15px;animation:dot-grid-share-check-pop .2s ease-out}@keyframes dot-grid-share-fade{0%{opacity:0}to{opacity:1}}@keyframes dot-grid-share-fade-out{0%{opacity:1}to{opacity:0}}@keyframes dot-grid-share-pop{0%{opacity:0;transform:translateY(8px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes dot-grid-share-pop-out{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(10px) scale(.97)}}@keyframes dot-grid-share-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes dot-grid-share-check-pop{0%{opacity:0;transform:scale(.65)}to{opacity:1;transform:scale(1)}}@media (max-width:640px){.dot-grid-share-modal{width:min(92vw,420px);padding:16px;border-radius:18px}.dot-grid-share-preview-box{padding:16px}.dot-grid-share-actions{grid-template-columns:1fr}}.global-dot-cursor{position:fixed;left:0;top:0;border-radius:50%;pointer-events:none;z-index:12000;opacity:0;will-change:transform,width,height,border-radius;display:grid;place-items:center;padding:0;box-sizing:border-box}.global-dot-cursor.is-pill{padding:0 4px}.global-dot-cursor-pill-label{color:#FDFCF9;font-size:15px;font-weight:500;line-height:1;letter-spacing:.01em;white-space:nowrap;opacity:0;transition:opacity .12s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.global-dot-cursor.is-pill .global-dot-cursor-pill-label{opacity:1}.global-toast{position:fixed;left:50%;bottom:24px;transform:translate(-50%);z-index:11000;background:#1f1e1d;border-radius:22px;padding:10px 14px;box-shadow:0 14px 36px rgba(24,21,16,.25)}.global-toast.is-opening{animation:global-toast-enter .22s ease forwards}.global-toast.is-closing{animation:global-toast-exit .22s ease forwards}@keyframes global-toast-enter{0%{transform:translate(-50%,16px);opacity:0}to{transform:translate(-50%);opacity:1}}@keyframes global-toast-exit{0%{transform:translate(-50%);opacity:1}to{transform:translate(-50%,16px);opacity:0}}.global-toast-message-row,.global-toast-row{display:flex;align-items:center;gap:10px}.global-toast-item-row{display:flex;align-items:center;gap:12px}.global-toast-item-image{width:48px;height:48px;padding:0;border-radius:10px;object-fit:contain;flex-shrink:0}.global-toast-item-copy{display:flex;flex-direction:column;gap:2px;min-width:0;padding-right:4px}.global-toast-item-title{color:#fff;font-size:16px;font-weight:500;line-height:1.2;white-space:nowrap}.global-toast-item-subtitle{color:#b8b6b0;font-size:12px;font-weight:400;line-height:1.2;white-space:nowrap}.global-toast-action{border-radius:999px;border:1px solid rgba(255,255,255,.35);color:#fff;font-size:12px;font-weight:700;padding:6px 10px;line-height:1}.global-toast-action:focus-visible{outline:2px solid #fff;outline-offset:3px}.global-toast-message{color:#fff;font-size:13px;font-weight:600;line-height:1.2}.global-toast-close{width:26px;height:26px;border-radius:999px;border:1px solid rgba(255,255,255,.3);color:#fff;font-size:12px;font-weight:700;line-height:1;display:grid;place-items:center}.global-toast-swatches{display:flex;align-items:center;gap:8px}.global-toast-swatch{width:26px;height:26px;border-radius:999px;border:1px solid rgba(255,255,255,.25);background:transparent;padding:0;display:grid;place-items:center}.global-toast-swatch-fill{width:16px;height:16px;border-radius:50%}.global-toast-eraser-fill{border:1px solid rgba(53,49,40,.22)}.global-toast-swatch.is-selected{border-color:#fff;box-shadow:0 0 0 1px rgba(255,255,255,.32)}.global-toast-close:focus-visible,.global-toast-swatch:focus-visible{outline:2px solid #fff;outline-offset:3px}