@charset "UTF-8";:root{--cream:#ECE8FA;--paper:#FCFBFF;--ink:#241D36;--ink-soft:#5d5573;--pink:#F368A8;--lime:#9FE0AE;--lilac:#C4B2F2;--sky:#A4D6FF;--tangerine:#FF8A5C;--sun:#FFD56B;--pine:#2F9E7E;--accent:#7A5AF0;--line:#e2dcf2;--shadow:14px 14px 0 rgba(36, 29, 54, 1);--shadow-sm:6px 6px 0 rgba(36, 29, 54, 1);--display:"Bricolage Grotesque", sans-serif;--body:"Hanken Grotesk", sans-serif;--hand:"Shantell Sans", cursive;--scrawl:"Caveat", cursive;--ease:cubic-bezier(.16, 1, .3, 1)}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{min-height:100vh;font-family:var(--body);font-size:16px;line-height:1.5;color:var(--ink);background:var(--cream);overflow-x:hidden;cursor:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIzMCIgdmlld0JveD0iMCAwIDI0IDMwIj48cGF0aCBkPSJNNCAzVjI1bDYtNiA0IDkgNC0yLTQtOGg3eiIgZmlsbD0iI2ZmZiIgc3Ryb2tlPSIjZmZmIiBzdHJva2Utd2lkdGg9IjQuNSIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCIvPjxwYXRoIGQ9Ik00IDNWMjVsNi02IDQgOSA0LTItNC04aDd6IiBmaWxsPSIjZmZmIiBzdHJva2U9IiMyNDFEMzYiIHN0cm9rZS13aWR0aD0iMi4yIiBzdHJva2UtbGluZWpvaW49InJvdW5kIi8+PC9zdmc+)4 3,auto}img,picture,video,svg{display:block;max-width:100%}a{color:inherit;text-decoration:none}ul,ol{list-style:none}button{font:inherit;cursor:pointer;border:none;background:0 0}input,textarea,select{font:inherit}a,button,.btn,.card,.note,.role,.pill,.tab,.socials a,.nav-link,.nav-links a,.hamburger,.back{cursor:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIzMCIgdmlld0JveD0iMCAwIDI0IDMwIj48cGF0aCBkPSJNNCAzVjI1bDYtNiA0IDkgNC0yLTQtOGg3eiIgZmlsbD0iI2ZmZiIgc3Ryb2tlPSIjZmZmIiBzdHJva2Utd2lkdGg9IjQuNSIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCIvPjxwYXRoIGQ9Ik00IDNWMjVsNi02IDQgOSA0LTItNC04aDd6IiBmaWxsPSIjZmZmIiBzdHJva2U9IiMyNDFEMzYiIHN0cm9rZS13aWR0aD0iMi4yIiBzdHJva2UtbGluZWpvaW49InJvdW5kIi8+PC9zdmc+)4 3,pointer}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}h1,h2,h3,h4,h5,h6{font-family:var(--display);font-weight:800;line-height:1.1;letter-spacing:-.02em;color:var(--ink)}p{margin-bottom:1em}p:last-child{margin-bottom:0}b,strong{font-weight:700}.kicker{font-family:var(--scrawl);font-size:1.5rem;color:var(--accent);transform:rotate(-2deg);display:inline-block}.margin-bottom-15{margin-bottom:15px}.margin-bottom-20{margin-bottom:20px}.margin-bottom-25{margin-bottom:25px}.margin-bottom-30{margin-bottom:30px}.margin-bottom-35{margin-bottom:35px}.margin-bottom-45{margin-bottom:45px}.margin-bottom-none{margin-bottom:0}.wrap{max-width:1180px;margin:0 auto;padding:0 28px}.narrow{max-width:820px;margin:0 auto;padding:0 28px}.position-relative{position:relative}.overflow-hidden{overflow:hidden}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}section[id],[id]{scroll-margin-top:90px}.scallop{display:block;width:100%;height:34px;line-height:0}.reveal{opacity:0;transform:translateY(38px);transition:opacity .9s var(--ease),transform .9s var(--ease),filter .9s var(--ease);will-change:opacity,transform}.reveal[data-anim=blur]{filter:blur(12px)}.reveal[data-anim=left]{transform:translateX(-44px)}.reveal[data-anim=scale]{transform:scale(.9)}.reveal.in{opacity:1;transform:none;filter:none}@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;filter:none;transition:none}}.background-pink,.background-red{background:var(--pink)}.background-lime,.background-green{background:var(--lime)}.background-sky,.background-blue{background:var(--sky)}.background-lilac,.background-purple{background:var(--lilac)}.background-tangerine,.background-orange{background:var(--tangerine)}.background-sun,.background-yellow{background:var(--sun)}.btn{font-family:var(--body);font-weight:700;font-size:1rem;cursor:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIzMCIgdmlld0JveD0iMCAwIDI0IDMwIj48cGF0aCBkPSJNNCAzVjI1bDYtNiA0IDkgNC0yLTQtOGg3eiIgZmlsbD0iI2ZmZiIgc3Ryb2tlPSIjZmZmIiBzdHJva2Utd2lkdGg9IjQuNSIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCIvPjxwYXRoIGQ9Ik00IDNWMjVsNi02IDQgOSA0LTItNC04aDd6IiBmaWxsPSIjZmZmIiBzdHJva2U9IiMyNDFEMzYiIHN0cm9rZS13aWR0aD0iMi4yIiBzdHJva2UtbGluZWpvaW49InJvdW5kIi8+PC9zdmc+)4 3,pointer;padding:14px 26px;border-radius:40px;border:2.5px solid var(--ink);background:var(--sun);color:var(--ink);box-shadow:var(--shadow-sm);transition:transform .14s,box-shadow .14s;display:inline-flex;align-items:center;gap:9px}.btn:hover{transform:translate(-2px,-2px);box-shadow:9px 9px 0 var(--ink)}.btn:active{transform:translate(3px,3px);box-shadow:1px 1px 0 var(--ink)}.btn.dark{background:var(--ink);color:var(--cream)}.btn.lime{background:var(--lime)}.btn.sky{background:var(--sky)}.btn.sun{background:var(--sun)}.btn.pink{background:var(--pink)}.back{font-weight:700;display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border:2px solid var(--ink);border-radius:30px;background:var(--cream);transition:.15s}.back:hover{background:var(--lime);transform:translateX(-3px)}.sticker{position:absolute;z-index:1;animation:bob 6s ease-in-out infinite}.sticker svg{display:block;filter:drop-shadow(4px 4px 0 #241d36)}@keyframes bob{0%,100%{transform:translateY(0)rotate(var(--r,0deg))}50%{transform:translateY(-14px)rotate(var(--r,0deg))}}.s1{top:60px;left:4%;--r:-10deg}.s2{top:120px;right:5%;--r:9deg;animation-delay:1.1s}.s3{top:300px;left:7%;--r:8deg;animation-delay:.7s}.s4{top:280px;right:8%;--r:-7deg;animation-delay:1.6s}.s5{bottom:30px;left:46%;--r:5deg;animation-delay:.4s}@media(max-width:780px){.sticker{transform:scale(.7)}.s1,.s3{left:-2%}.s2,.s4{right:-2%}}@media(prefers-reduced-motion:reduce){.sticker{animation:none}}.site-nav{position:sticky;top:0;z-index:60;background:rgba(236,232,250,.82);backdrop-filter:blur(10px);border-bottom:2px solid var(--ink)}.nav-in{display:flex;align-items:center;justify-content:space-between;height:74px}.logo{font-family:var(--display);font-weight:800;font-size:1.45rem;letter-spacing:-.02em;display:flex;align-items:center;gap:9px}.logo .blob{width:18px;height:18px;background:var(--pink);border:2px solid var(--ink);border-radius:60% 40% 55% 45%/55% 50% 50% 45%;display:inline-block}.logo .logo-dot{color:var(--pink)}.nav-links{display:flex;gap:6px;align-items:center}.nav-links a{font-weight:600;font-size:.95rem;padding:9px 15px;border-radius:30px;border:2px solid transparent;transition:.18s}.nav-links a:hover{border-color:var(--ink);background:var(--sun)}.nav-links .nav-cta{font-weight:700;background:var(--ink);color:var(--cream);border:2px solid var(--ink)}.nav-links .nav-cta:hover{background:var(--pink);color:var(--ink)}.burger{display:none;background:0 0;border:2px solid var(--ink);border-radius:10px;padding:8px 10px;cursor:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIzMCIgdmlld0JveD0iMCAwIDI0IDMwIj48cGF0aCBkPSJNNCAzVjI1bDYtNiA0IDkgNC0yLTQtOGg3eiIgZmlsbD0iI2ZmZiIgc3Ryb2tlPSIjZmZmIiBzdHJva2Utd2lkdGg9IjQuNSIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCIvPjxwYXRoIGQ9Ik00IDNWMjVsNi02IDQgOSA0LTItNC04aDd6IiBmaWxsPSIjZmZmIiBzdHJva2U9IiMyNDFEMzYiIHN0cm9rZS13aWR0aD0iMi4yIiBzdHJva2UtbGluZWpvaW49InJvdW5kIi8+PC9zdmc+)4 3,pointer}.burger span{display:block;width:22px;height:2.5px;background:var(--ink);margin:4px 0;border-radius:2px}@media(max-width:680px){.nav-links{display:none;position:absolute;top:74px;left:0;right:0;background:var(--cream);flex-direction:column;padding:18px;border-bottom:2px solid var(--ink)}.nav-links.open{display:flex}.burger{display:block}}.hero{padding:84px 0 40px;text-align:center;overflow:hidden;position:relative}.hello{font-family:var(--scrawl);font-size:2rem;color:var(--pink);transform:rotate(-4deg);display:inline-block;margin-bottom:6px}.hero h1{font-family:var(--display);font-weight:800;font-size:clamp(2.7rem,8vw,6rem);line-height:.96;letter-spacing:-.035em}.hero h1 .swap{color:var(--pink)}.hero h1 .ux{position:relative;white-space:nowrap}.hero h1 .ux svg{position:absolute;left:-6%;bottom:-12px;width:112%;height:auto}.hero p{max-width:560px;margin:26px auto 0;font-size:1.18rem;color:var(--ink-soft)}.hero p b{color:var(--ink);font-weight:700}.hero-cta{margin-top:34px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}.work{background:var(--paper);border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);padding:72px 0 84px}.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:40px}.sec-head .kicker{color:var(--accent)}.sec-head h2{font-family:var(--display);font-weight:800;font-size:clamp(2rem,5vw,3.3rem);letter-spacing:-.03em;line-height:1.02;max-width:9ch}.sec-head p{max-width:340px;color:var(--ink-soft)}.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px}.card{position:relative;border:2.5px solid var(--ink);border-radius:26px;padding:26px;min-height:230px;display:flex;flex-direction:column;justify-content:space-between;box-shadow:var(--shadow-sm);transition:transform .16s,box-shadow .16s;overflow:hidden;color:var(--ink)}.card:hover{transform:translate(-3px,-3px);box-shadow:11px 11px 0 var(--ink)}.card .num{font-family:var(--display);font-weight:700;font-size:.95rem;opacity:.65}.card .top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.card h3{font-family:var(--display);font-weight:800;font-size:1.7rem;letter-spacing:-.02em;line-height:1.05}.card .desc{font-size:.97rem;margin-top:10px;max-width:34ch;line-height:1.45}.card .tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}.card .tag{font-size:.78rem;font-weight:600;background:rgba(36,29,54,.1);padding:4px 11px;border-radius:30px}.card .card-thumb{margin-top:18px;border:2px solid var(--ink);border-radius:16px;overflow:hidden;background:var(--paper)}.card .card-thumb img{width:100%;height:180px;object-fit:cover;display:block}.card .card-cta{font-weight:700}.card .arrow{align-self:flex-end;width:40px;height:40px;border:2px solid var(--ink);border-radius:50%;display:grid;place-items:center;background:var(--cream);transition:.16s;font-size:1.05rem}.card:hover .arrow{background:var(--ink);color:var(--cream);transform:rotate(-45deg)}.card-bottom{display:flex;justify-content:space-between;align-items:flex-end;gap:14px;margin-top:14px}.c-pink{background:var(--pink)}.c-lime{background:var(--lime)}.c-lilac{background:var(--lilac)}.c-sky{background:var(--sky)}@media(max-width:680px){.grid{grid-template-columns:1fr}}.about{padding:78px 0 40px}.about-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:54px;align-items:center}.avatar{aspect-ratio:1;border:3px solid var(--ink);border-radius:34px;background:radial-gradient(circle at 30% 25%,var(--sun),transparent 42%),radial-gradient(circle at 75% 70%,var(--sky),transparent 46%),var(--lilac);box-shadow:var(--shadow);position:relative;overflow:hidden}.avatar .avatar-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.avatar .badge{position:absolute;top:-14px;right:-14px;z-index:2;background:var(--lime);border:2.5px solid var(--ink);border-radius:50%;width:104px;height:104px;display:grid;place-items:center;font-family:var(--scrawl);font-size:1.15rem;text-align:center;transform:rotate(12deg);line-height:1.05}.about h2{font-family:var(--display);font-weight:800;font-size:clamp(2rem,4.5vw,3rem);letter-spacing:-.03em;margin-bottom:18px;line-height:1.04}.about .kicker{color:var(--accent);margin-bottom:6px}.about p{color:var(--ink-soft);font-size:1.08rem;margin-bottom:16px;max-width:540px}.about p b{color:var(--ink)}.pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}.pill{font-weight:600;font-size:.92rem;padding:9px 16px;border:2px solid var(--ink);border-radius:30px;background:var(--cream);transition:.15s}.pill:hover{background:var(--pink);transform:rotate(-2deg)}@media(max-width:860px){.about-grid{grid-template-columns:1fr;gap:34px}.avatar{max-width:360px}}.exp{padding:30px 0 80px}.exp-head{text-align:center;margin-bottom:38px}.exp-head .kicker{color:var(--accent)}.exp-head h2{font-family:var(--display);font-weight:800;font-size:clamp(1.9rem,4.5vw,2.8rem);letter-spacing:-.03em}.timeline{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:16px}.role{display:flex;gap:20px;align-items:stretch;border:2.5px solid var(--ink);border-radius:20px;padding:20px 24px;background:var(--paper);box-shadow:var(--shadow-sm);transition:transform .15s}.role:hover{transform:translateX(4px)}.role .when{font-family:var(--display);font-weight:700;font-size:.85rem;color:var(--ink-soft);min-width:130px;padding-top:3px}.role .what h4{font-family:var(--display);font-weight:800;font-size:1.18rem;letter-spacing:-.01em;margin-bottom:5px}.role .what p{font-size:.95rem;color:var(--ink-soft);max-width:55ch}.role .dot{width:12px;height:12px;border-radius:50%;border:2px solid var(--ink);flex:none;margin-top:6px}.resume-row{text-align:center;margin-top:34px}@media(max-width:680px){.role{flex-direction:column;gap:8px}.role .when{min-width:0}}.desk{border-top:2px solid var(--ink);padding:70px 0 96px;background:radial-gradient(circle at 20% 10%,rgba(0,0,0,4%),transparent 25%),repeating-linear-gradient(45deg,#b3a7dd 0 2px,transparent 2px 9px),#c2b7e6;position:relative}.desk-head{text-align:center;margin-bottom:14px}.desk-head .kicker{color:var(--cream)}.desk-head h2{font-family:var(--display);font-weight:800;color:var(--cream);font-size:clamp(2.2rem,5.5vw,3.6rem);letter-spacing:-.03em;text-shadow:3px 3px 0 var(--ink)}.desk-head p{color:#f6f2ff;max-width:480px;margin:8px auto 0;font-family:var(--hand);font-size:1.1rem}.notes{display:grid;grid-template-columns:repeat(3,1fr);gap:30px 34px;margin-top:52px}.note{background:var(--paper);border:1px solid #e4def0;border-radius:3px;padding:30px 26px 26px;position:relative;cursor:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIzMCIgdmlld0JveD0iMCAwIDI0IDMwIj48cGF0aCBkPSJNNCAzVjI1bDYtNiA0IDkgNC0yLTQtOGg3eiIgZmlsbD0iI2ZmZiIgc3Ryb2tlPSIjZmZmIiBzdHJva2Utd2lkdGg9IjQuNSIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCIvPjxwYXRoIGQ9Ik00IDNWMjVsNi02IDQgOSA0LTItNC04aDd6IiBmaWxsPSIjZmZmIiBzdHJva2U9IiMyNDFEMzYiIHN0cm9rZS13aWR0aD0iMi4yIiBzdHJva2UtbGluZWpvaW49InJvdW5kIi8+PC9zdmc+)4 3,pointer;color:var(--ink);box-shadow:5px 8px 18px rgba(0,0,0,.28);background-image:linear-gradient(transparent 0 28px,#e7e3f2 28px 29px);background-size:100% 29px;background-position:0 16px;transition:transform .2s ease,box-shadow .2s ease}.note:nth-child(3n+1){transform:rotate(-2.4deg)}.note:nth-child(3n+2){transform:rotate(1.5deg)}.note:nth-child(3n){transform:rotate(-1deg)translateY(10px)}.note:hover{transform:rotate(0)translateY(-8px)scale(1.02);box-shadow:8px 16px 30px rgba(0,0,0,.34);z-index:5}.note .tape{position:absolute;top:-13px;left:50%;width:120px;height:30px;transform:translateX(-50%)rotate(-3deg);background:rgba(159,224,174,.6);border:1px dashed rgba(36,29,54,.25);box-shadow:0 1px 4px rgba(0,0,0,.15)}.note:nth-child(2n) .tape{background:rgba(243,104,168,.4);transform:translateX(-50%)rotate(4deg);left:60%}.note:nth-child(3n) .tape{background:rgba(164,214,255,.55)}.note .date{font-family:var(--scrawl);font-size:1.25rem;color:var(--pink);transform:rotate(-2deg);display:inline-block;margin-bottom:6px}.note h3{font-family:var(--hand);font-weight:600;font-size:1.32rem;line-height:1.25;margin-bottom:10px;color:var(--ink)}.note p{font-family:var(--hand);font-size:.96rem;color:#3a342e;line-height:1.55}.note .tagline{font-family:var(--scrawl);font-size:1.05rem;color:var(--pine);margin-top:14px;display:inline-block}.note .badge-real{position:absolute;top:8px;left:10px;font-family:var(--scrawl);font-size:.95rem;color:var(--tangerine);transform:rotate(-6deg)}.note .doodle-star{position:absolute;bottom:14px;right:16px;color:var(--tangerine);font-size:1.4rem;transform:rotate(12deg)}@media(max-width:860px){.notes{grid-template-columns:repeat(2,1fr)}}@media(max-width:680px){.notes{grid-template-columns:1fr}}.cta{background:var(--ink);color:var(--cream);text-align:center;padding:96px 0 70px;border-top:2px solid var(--ink)}.cta h2{font-family:var(--display);font-weight:800;font-size:clamp(2.2rem,6.5vw,4.6rem);letter-spacing:-.04em;line-height:.98;max-width:18ch;margin:0 auto;color:var(--cream)}.cta h2 em{font-family:var(--scrawl);font-style:normal;color:var(--sun)}.cta p{color:#b8b0a6;max-width:440px;margin:22px auto 30px;font-size:1.1rem}.contact-form{max-width:620px;margin:0 auto;text-align:left}.contact-form .form-fields-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:22px}.contact-form .text-field{width:100%;background:rgba(255,255,255,6%);border:2px solid #3a342e;border-radius:16px;padding:15px 18px;color:var(--cream);font-family:var(--body);font-size:1rem;transition:border-color .15s,background .15s}.contact-form .text-field::placeholder{color:#8d857b}.contact-form .text-field:focus{outline:none;border-color:var(--sun);background:rgba(255,255,255,.1)}.contact-form textarea.text-field{min-height:130px;resize:vertical}.contact-form .form-field-full{grid-column:1/-1}.contact-form .btn{margin-top:4px}@media(max-width:680px){.contact-form .form-fields-grid{grid-template-columns:1fr}}.site-footer{background:var(--ink);color:#8d857b;padding:0 0 40px}.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;padding-top:26px;border-top:1px solid #3a342e;color:#8d857b;font-size:.9rem}.socials{display:flex;gap:10px}.socials a{padding:0 14px;height:40px;border:2px solid #3a342e;border-radius:30px;display:grid;place-items:center;transition:.15s;color:var(--cream);font-weight:600;font-size:.85rem}.socials a:hover{background:var(--pink);border-color:var(--pink);color:var(--ink);transform:translateY(-3px)}.page-project .backbar{padding:26px 0 0}.page-project .p-hero{padding:34px 0 30px;text-align:center;position:relative;overflow:hidden}.page-project .p-hero .tag-type{font-weight:700;background:var(--lilac);border:2px solid var(--ink);padding:5px 16px;border-radius:30px;display:inline-block;transform:rotate(-2deg)}.page-project .p-hero h1{font-family:var(--display);font-weight:800;font-size:clamp(3rem,10vw,7rem);letter-spacing:-.04em;line-height:.92;margin:16px 0 12px}.page-project .p-hero .sub{font-size:1.25rem;color:var(--ink-soft);max-width:620px;margin:0 auto}.page-project .hero-shot{margin:38px auto 0;max-width:1e3px;border:3px solid var(--ink);border-radius:30px;box-shadow:var(--shadow);overflow:hidden;background:var(--lilac)}.page-project .hero-shot img{width:100%;height:auto;display:block}.page-project .meta{background:var(--paper);border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);padding:40px 0;margin-top:46px}.page-project .meta-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}.page-project .meta-cell .lab{font-family:var(--scrawl);font-size:1.25rem;color:var(--pink)}.page-project .meta-cell .val{font-family:var(--display);font-weight:700;font-size:1.1rem;margin-top:2px}.page-project .block{padding:64px 0}.page-project .eyebrow{font-family:var(--scrawl);font-size:1.5rem;color:var(--tangerine)}.page-project h2.big{font-family:var(--display);font-weight:800;font-size:clamp(1.9rem,4.5vw,2.9rem);letter-spacing:-.03em;line-height:1.05;margin:4px 0 18px}.page-project .prose p{font-size:1.08rem;color:#34302b;max-width:68ch;margin-bottom:16px;line-height:1.7}.page-project .prose p b,.page-project .prose strong{color:var(--ink)}.page-project .prose h2,.page-project .prose h3,.page-project .prose h4{font-family:var(--display);font-weight:800;letter-spacing:-.02em;margin:36px 0 12px;line-height:1.1}.page-project .prose h2{font-size:1.9rem}.page-project .prose h3{font-size:1.5rem}.page-project .prose h4{font-size:1.35rem}.page-project .prose ul,.page-project .prose ol{margin:0 0 18px 1.1em}.page-project .prose li{font-size:1.06rem;line-height:1.7;margin-bottom:6px}.page-project .prose ul li{list-style:none;padding-left:24px;position:relative}.page-project .prose ul li::before{content:"✦";position:absolute;left:0;color:var(--tangerine)}.page-project .prose blockquote{border-left:4px solid var(--pink);padding:6px 0 6px 22px;margin:24px 0;font-family:var(--display);font-weight:700;font-size:1.3rem;line-height:1.3;color:var(--ink)}.page-project .prose a{color:var(--accent);text-decoration:underline}.page-project .content-shot{margin:28px 0;border:3px solid var(--ink);border-radius:22px;box-shadow:var(--shadow-sm);overflow:hidden;background:var(--paper)}.page-project .content-shot img{width:100%;height:auto;display:block}.page-project .content-shot figcaption{font-family:var(--scrawl);font-size:1.15rem;color:var(--ink-soft);text-align:center;padding:10px 14px 14px}.page-project .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:30px}.page-project .step{border:2.5px solid var(--ink);border-radius:22px;padding:22px;box-shadow:var(--shadow-sm);position:relative;min-height:170px}.page-project .step:nth-child(4n+1){background:var(--pink)}.page-project .step:nth-child(4n+2){background:var(--lime)}.page-project .step:nth-child(4n+3){background:var(--sky)}.page-project .step:nth-child(4n){background:var(--sun)}.page-project .step .n{font-family:var(--display);font-weight:800;font-size:1.6rem}.page-project .step h4{font-family:var(--display);font-weight:800;font-size:1.15rem;margin:8px 0 6px}.page-project .step p{font-size:.92rem;line-height:1.45}.page-project .stats{background:var(--ink);color:var(--cream);border-radius:30px;padding:46px;display:grid;grid-template-columns:repeat(3,1fr);gap:24px;text-align:center;box-shadow:var(--shadow)}.page-project .stat .num{font-family:var(--display);font-weight:800;font-size:clamp(2.4rem,5vw,3.4rem);color:var(--sun);line-height:1}.page-project .stat .lab{color:#cfc7bc;margin-top:6px;font-weight:500}.page-project .quote{text-align:center;max-width:26ch;margin:0 auto;font-family:var(--display);font-weight:700;font-size:clamp(1.6rem,4vw,2.6rem);letter-spacing:-.02em;line-height:1.15}.page-project .quote .hl{background:linear-gradient(transparent 55%,var(--sun) 55%);padding:0 .1em}.page-project .next{border-top:2px solid var(--ink);background:var(--paper);padding:54px 0}.page-project .next a{display:flex;justify-content:space-between;align-items:center;gap:20px;border:2.5px solid var(--ink);border-radius:26px;padding:30px 34px;background:var(--sky);box-shadow:var(--shadow-sm);transition:transform .15s,box-shadow .15s}.page-project .next a:hover{transform:translate(-3px,-3px);box-shadow:11px 11px 0 var(--ink)}.page-project .next .lab{font-family:var(--scrawl);font-size:1.4rem;color:var(--ink)}.page-project .next h3{font-family:var(--display);font-weight:800;font-size:clamp(1.8rem,5vw,3rem);letter-spacing:-.02em}.page-project .next .arrow{font-size:2.6rem;font-weight:800}@media(max-width:860px){.page-project .meta-grid{grid-template-columns:repeat(2,1fr)}.page-project .steps{grid-template-columns:repeat(2,1fr)}.page-project .stats{grid-template-columns:1fr}}@media(max-width:680px){.page-project .next a{flex-direction:column;align-items:flex-start}}.page-blog .desk-page{background:radial-gradient(circle at 20% 8%,rgba(0,0,0,.045),transparent 26%),repeating-linear-gradient(45deg,#b3a7dd 0 2px,transparent 2px 9px),#c2b7e6;padding:36px 0 90px}.page-blog .back{color:var(--cream);border-color:var(--cream);background:0 0;margin-bottom:30px}.page-blog .back:hover{background:var(--cream);color:var(--ink)}.page-blog .sheet{position:relative;max-width:780px;margin:0 auto;background:var(--paper);border-radius:3px;padding:78px 72px 70px;box-shadow:0 30px 70px rgba(0,0,0,.45),0 4px rgba(0,0,0,8%);background-image:linear-gradient(transparent 0 37px,#e9e5f5 37px 38px);background-size:100% 38px;background-position:0 64px}.page-blog .tape{position:absolute;width:140px;height:34px;background:rgba(255,210,63,.55);border:1px dashed rgba(36,29,54,.22);box-shadow:0 1px 5px rgba(0,0,0,.15)}.page-blog .tape.tl{top:-16px;left:34px;transform:rotate(-5deg)}.page-blog .tape.tr{top:-16px;right:34px;transform:rotate(4deg);background:rgba(243,104,168,.4)}.page-blog .margin-line{position:absolute;top:0;bottom:0;left:54px;width:1.5px;background:rgba(243,104,168,.4)}.page-blog .punch{position:absolute;left:20px;width:14px;height:14px;border-radius:50%;background:var(--cream);box-shadow:inset 0 2px 3px rgba(0,0,0,.2)}.page-blog .punch.p1{top:120px}.page-blog .punch.p2{top:50%}.page-blog .punch.p3{bottom:120px}.page-blog .post-head .date{font-family:var(--scrawl);font-size:1.6rem;color:var(--pink);transform:rotate(-2deg);display:inline-block}.page-blog .post-head .readtime{font-family:var(--scrawl);font-size:1.2rem;color:var(--ink-soft);margin-left:6px}.page-blog .post-head h1{font-family:var(--display);font-weight:800;font-size:clamp(2.1rem,6vw,3.2rem);line-height:1.08;letter-spacing:-.02em;margin:6px 0 14px}.page-blog .post-head .tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:6px}.page-blog .post-head .tab{font-family:var(--scrawl);font-size:1.1rem;background:var(--lime);border:1.5px solid var(--ink);padding:1px 14px;border-radius:0 0 12px 12px;transform:rotate(-1.5deg)}.page-blog .post-head .tab:nth-child(2){background:var(--sky);transform:rotate(2deg)}.page-blog .post-head .tab:nth-child(3){background:var(--lilac);transform:rotate(-1deg)}.page-blog .post-body{margin-top:30px;font-family:var(--hand)}.page-blog .post-body p{font-size:1.12rem;line-height:1.9;color:#2e2a25;margin-bottom:22px}.page-blog .post-body>p:first-of-type{font-size:1.28rem;color:var(--ink)}.page-blog .post-body>p:first-of-type::first-letter{font-family:var(--display);font-weight:800;font-size:2.6em;float:left;line-height:.8;margin:6px 10px 0 0;color:var(--pink)}.page-blog .post-body h2,.page-blog .post-body h3{font-family:var(--display);font-weight:800;font-size:1.7rem;margin:38px 0 10px;letter-spacing:-.02em}.page-blog .post-body h3{font-size:1.4rem}.page-blog .post-body ul{margin:0 0 22px 4px;list-style:none}.page-blog .post-body li{font-size:1.1rem;line-height:1.8;padding-left:30px;position:relative;margin-bottom:4px}.page-blog .post-body li::before{content:"✦";position:absolute;left:4px;color:var(--tangerine)}.page-blog .post-body a{color:var(--accent);text-decoration:underline}.page-blog .post-body em{color:var(--ink-soft)}.page-blog .post-body blockquote{background:var(--sun);border:1px solid #e3b91f;padding:20px 24px;margin:28px auto;max-width:460px;transform:rotate(-1deg);box-shadow:4px 6px 14px rgba(0,0,0,.18);font-family:var(--display);font-weight:700;font-size:1.15rem;line-height:1.3;letter-spacing:-.01em;color:var(--ink)}.page-blog .post-body blockquote p{font-family:var(--display);font-size:1.15rem;line-height:1.3;color:var(--ink);margin-bottom:8px}.page-blog .polaroid{background:#fff;padding:12px 12px 42px;border:1px solid #e2dcf2;box-shadow:6px 8px 16px rgba(0,0,0,.22);max-width:420px;margin:30px auto;transform:rotate(-2.5deg);position:relative}.page-blog .polaroid .pic{width:100%;height:auto;display:block}.page-blog .polaroid .cap{font-family:var(--scrawl);font-size:1.25rem;text-align:center;margin-top:8px;color:var(--ink)}.page-blog .polaroid .clip{position:absolute;top:-12px;left:50%;width:36px;height:24px;transform:translateX(-50%)rotate(-4deg);background:rgba(243,104,168,.5);border:1px dashed rgba(36,29,54,.25)}.page-blog .polaroid:nth-of-type(2n){transform:rotate(1.8deg)}.page-blog .image-pair{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:28px 0}.page-blog .image-pair img{width:100%;height:auto;border:2px solid var(--ink);border-radius:12px;box-shadow:var(--shadow-sm)}.page-blog .video-embed{position:relative;margin:28px 0;aspect-ratio:16/9;border:2px solid var(--ink);border-radius:12px;overflow:hidden}.page-blog .video-embed iframe{position:absolute;inset:0;width:100%;height:100%}.page-blog .signoff{font-family:var(--scrawl);font-size:1.8rem;color:var(--pink);margin-top:38px;transform:rotate(-2deg);display:inline-block}.page-blog .related{max-width:980px;margin:70px auto 0}.page-blog .related h3{font-family:var(--display);font-weight:800;color:var(--cream);text-align:center;font-size:1.9rem;text-shadow:2px 2px 0 var(--ink);margin-bottom:30px}.page-blog .rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}.page-blog .related .note{background:var(--paper);border:1px solid #e4def0;border-radius:3px;padding:26px 22px;position:relative;cursor:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIzMCIgdmlld0JveD0iMCAwIDI0IDMwIj48cGF0aCBkPSJNNCAzVjI1bDYtNiA0IDkgNC0yLTQtOGg3eiIgZmlsbD0iI2ZmZiIgc3Ryb2tlPSIjZmZmIiBzdHJva2Utd2lkdGg9IjQuNSIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCIvPjxwYXRoIGQ9Ik00IDNWMjVsNi02IDQgOSA0LTItNC04aDd6IiBmaWxsPSIjZmZmIiBzdHJva2U9IiMyNDFEMzYiIHN0cm9rZS13aWR0aD0iMi4yIiBzdHJva2UtbGluZWpvaW49InJvdW5kIi8+PC9zdmc+)4 3,pointer;box-shadow:5px 8px 18px rgba(0,0,0,.26);transition:transform .2s,box-shadow .2s}.page-blog .related .note:nth-child(1){transform:rotate(-2deg)}.page-blog .related .note:nth-child(2){transform:rotate(1.5deg)}.page-blog .related .note:nth-child(3){transform:rotate(-1deg)}.page-blog .related .note:hover{transform:rotate(0)translateY(-7px);box-shadow:8px 16px 28px rgba(0,0,0,.32)}.page-blog .related .note .minitape{position:absolute;top:-12px;left:50%;width:90px;height:24px;transform:translateX(-50%)rotate(-3deg);background:rgba(164,214,255,.55);border:1px dashed rgba(36,29,54,.22)}.page-blog .related .note .date{font-family:var(--scrawl);font-size:1.1rem;color:var(--pink)}.page-blog .related .note h4{font-family:var(--hand);font-weight:600;font-size:1.2rem;line-height:1.25;margin-top:4px}@media(max-width:680px){.page-blog .sheet{padding:60px 26px 50px;background-position:0 50px}.page-blog .margin-line{left:24px}.page-blog .punch{display:none}.page-blog .image-pair{grid-template-columns:1fr}.page-blog .rel-grid{grid-template-columns:1fr}}