:root{--font-xl:3em;--font-900:2.2em;--font-800:2em;--font-700:1.8em;--font-600:1.5em;--font-500:1.2em;--font-400:clamp(14px,1vw,2em);--ink:#292929;--muted:#536071;--line:rgba(18,24,38,0.12);--surface:#ffffff;--soft:#f4f6f8;--mint:#c9f0e8;--coral:#ffb8a0;--blue:#bce8ff;--accent:#0d7a75;--accent-strong:hsl(177,78%,11%)}*,:after,:before{box-sizing:border-box}body,html{margin:0;padding:0;min-height:100vh;width:100%;overflow-x:hidden;font-size:var(--font-400)}body{background:linear-gradient(180deg,#fbfbf8,#f7faf9 42%,#fbfbf8);color:var(--ink)}.bg-white{background:white}a,h1,h2,h3,p{font-family:Inter,sans-serif}html{scroll-behavior:smooth}.relative-c{position:relative}.border{width:80%;align-self:center;border:1px solid black}.nomargin{margin:0}.under-construction{flex:1 1;height:50vh;width:100vw;display:flex;justify-content:center;align-items:center;flex-direction:column;gap:10px}.under-construction h1{color:black}.portfolio-page{min-height:100vh;background:linear-gradient(135deg,rgba(201,240,232,.42),transparent 32rem),linear-gradient(220deg,rgba(255,184,160,.22),transparent 28rem)}.portfolio-eyebrow{width:-moz-fit-content;width:fit-content;margin:0 0 18px;padding:7px 11px;border:1px solid rgba(13,122,117,.22);border-radius:999px;background:rgba(255,255,255,.68);color:var(--accent-strong);font-size:.82rem;font-weight:800;letter-spacing:0;text-transform:uppercase}.portfolio-band{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;padding:18px clamp(20px,5vw,72px);border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:linear-gradient(90deg,rgba(201,240,232,.1),rgba(255,184,160,.08)),#101522}.portfolio-band span{padding:7px 11px;border:1px solid rgba(255,255,255,.2);border-radius:999px;color:white;font-size:.82rem;font-weight:700}.portfolio-section{width:min(1120px,calc(100% - 40px));margin:0 auto;padding:clamp(72px,9vw,118px) 0}@media screen and (max-width:560px){.portfolio-section{width:min(100% - 32px,1120px)}}.reveal-appear{opacity:0;transition:all 1s ease}.reveal-appear.active{opacity:1}.reveal-up{transform:translateY(30px);opacity:0;transition:all 1s ease}.reveal-up.active{transform:translateY(0);opacity:1}.reveal-right{transform:translateX(-30px);opacity:0;transition:all 1s ease}.reveal-right.active{transform:translateX(0);opacity:1}.reveal{position:relative;transform:translateX(50px);opacity:0;transition:all 1s ease}.reveal.active{transform:translate(0);opacity:1}.portfolio-hero{width:min(1120px,calc(100% - 40px));min-height:calc(100vh - 58px);display:grid;grid-template-columns:minmax(0,1.18fr) minmax(300px,.82fr);align-items:center;grid-gap:clamp(34px,6vw,88px);gap:clamp(34px,6vw,88px);margin:0 auto}.portfolio-hero__content h1{max-width:820px;margin:0;font-size:clamp(3.4rem,8.2vw,7.2rem);line-height:.9;letter-spacing:0}.portfolio-lead{max-width:760px;margin:30px 0 0;color:var(--muted);font-size:clamp(1.05rem,2vw,1.35rem);line-height:1.6;font-weight:500}.portfolio-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:32px}.portfolio-actions a{min-height:42px;display:inline-flex;align-items:center;justify-content:center;padding:0 17px;border:1px solid var(--ink);border-radius:8px;color:var(--ink);font-size:.95rem;font-weight:500;text-decoration:none;transition:transform .18s ease,box-shadow .18s ease,background .18s ease}.portfolio-actions a:first-child{background:var(--ink);color:white}.portfolio-actions a:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(16,21,34,.14)}.portfolio-highlights{position:relative;align-self:center;padding:8px 0 8px 26px}.portfolio-highlights:before{content:"";position:absolute;top:12px;bottom:12px;left:6px;width:1px;background:linear-gradient(180deg,rgba(16,21,34,0),rgba(16,21,34,.28),rgba(16,21,34,0))}.portfolio-highlights ul{display:grid;grid-gap:18px;gap:18px;margin:0;padding:0;list-style:none}.portfolio-highlights li{position:relative;display:grid;grid-template-columns:auto 1fr;grid-gap:14px;gap:14px;align-items:start;padding:2px 0}.portfolio-highlights li>span{width:11px;height:11px;margin-top:6px;border-radius:999px;background:var(--surface);border:2px solid var(--accent-strong);box-shadow:0 0 0 6px rgba(175,175,175,.08)}.portfolio-highlights p{margin:0}.portfolio-highlights strong{display:block;color:var(--ink);font-size:clamp(.98rem,1.4vw,1.08rem);font-weight:820;line-height:1.2}.portfolio-highlights small{display:block;max-width:300px;margin-top:5px;color:var(--muted);font-size:.86rem;font-weight:560;line-height:1.45}@media screen and (max-width:860px){.portfolio-hero{grid-template-columns:1fr;min-height:auto}.portfolio-highlights:before{display:none}}@media screen and (max-width:560px){.portfolio-hero{width:min(100% - 32px,1120px)}.portfolio-hero__content h1{font-size:clamp(3rem,16vw,4.4rem)}.portfolio-actions a{width:100%}}.personal-section{position:relative;isolation:isolate;width:min(1120px,calc(100% - 40px));margin:0 auto;padding:clamp(72px,9vw,118px) 0}.personal-section:before{z-index:-2;border-block:1px solid rgba(13,122,117,.08);background:linear-gradient(135deg,rgba(201,240,232,.36),transparent 34rem),linear-gradient(220deg,rgba(255,184,160,.22),transparent 30rem),rgba(255,255,255,.52)}.personal-section:after,.personal-section:before{position:absolute;inset:clamp(28px,4vw,54px) calc(50% - 50vw);content:""}.personal-section:after{z-index:-1;opacity:.58;background-image:url("data:image/svg+xml,%3Csvg width='52' height='52' viewBox='0 0 52 52' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%230d7a75' stroke-opacity='0.18' stroke-width='1.45' stroke-linecap='round'%3E%3Ccircle cx='26' cy='26' r='9.5'/%3E%3Cpath d='M22.4 23.8h.1'/%3E%3Cpath d='M29.5 23.8h.1'/%3E%3Cpath d='M21.8 28.2c2.2 2 6.2 2 8.4 0'/%3E%3C/g%3E%3C/svg%3E");background-size:52px 52px;-webkit-mask-image:linear-gradient(90deg,transparent,black 12%,black 88%,transparent);mask-image:linear-gradient(90deg,transparent,black 12%,black 88%,transparent);pointer-events:none}.personal-section__intro{display:grid;max-width:760px;grid-gap:14px;gap:14px;margin-bottom:34px}.personal-section__intro h2{margin:0;font-size:clamp(1.9rem,3.6vw,3.4rem);line-height:1;overflow-wrap:anywhere}.personal-section__intro p:not(.portfolio-eyebrow){max-width:620px;margin:0;color:var(--muted);font-size:.94rem;font-weight:500;line-height:1.65}.personal-section__grid{display:grid;grid-template-columns:repeat(3,minmax(190px,260px));justify-content:center;grid-gap:clamp(18px,3vw,34px);gap:clamp(18px,3vw,34px);perspective:1200px;scroll-margin-top:120px}.personal-card{position:relative;aspect-ratio:5/7;min-width:0;padding:10px;border:1px solid rgba(139,94,76,.16);border-radius:18px;background:linear-gradient(145deg,#f0c6b6,#f6e2d6 48%,#d7d2c7),#f4ded4;box-shadow:0 24px 70px rgba(16,21,34,.1),inset 0 0 0 1px rgba(255,255,255,.58);-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;overflow:hidden;transition:opacity 1s ease,transform .26s ease,box-shadow .22s ease,border-color .22s ease,background .22s ease}.personal-card:after,.personal-card:before{position:absolute;width:24px;height:24px;border-radius:50%;background:radial-gradient(circle,currentColor 0 22%,transparent 24%),linear-gradient(currentColor,currentColor) 50% /2px 16px no-repeat,linear-gradient(90deg,currentColor,currentColor) 50% /16px 2px no-repeat;color:rgba(139,94,76,.36);content:"";pointer-events:none}.personal-card:before{top:18px;left:18px}.personal-card:after{right:18px;bottom:18px;transform:rotate(180deg)}.personal-card--selected,.personal-card:hover{transform:translateY(-8px) rotateX(4deg);border-color:rgba(255,184,160,.34);background:linear-gradient(145deg,#f7ddd2,#c9f0e8 54%,#bce8ff),#dff2ef;box-shadow:0 34px 96px rgba(16,21,34,.14),inset 0 0 0 1px rgba(255,255,255,.58)}.personal-card--selected:after,.personal-card--selected:before,.personal-card:hover:after,.personal-card:hover:before{color:rgba(13,122,117,.42)}.personal-card:focus-visible{outline:3px solid rgba(13,122,117,.34);outline-offset:5px}.personal-card__inner{position:relative;display:grid;place-items:center;width:100%;height:100%;border:1px solid rgba(139,94,76,.14);border-radius:13px;background:radial-gradient(circle at 22% 18%,rgba(255,255,255,.52),transparent 34%),radial-gradient(circle at 80% 78%,rgba(255,184,160,.3),transparent 34%),linear-gradient(135deg,rgba(255,248,240,.72),rgba(219,203,190,.54)),#f7eee7;overflow:hidden;transition:border-color .22s ease,background .22s ease}.personal-card--selected .personal-card__inner,.personal-card:hover .personal-card__inner{border-color:rgba(13,122,117,.14);background:radial-gradient(circle at 24% 18%,rgba(255,184,160,.46),transparent 34%),radial-gradient(circle at 78% 80%,rgba(188,232,255,.5),transparent 32%),linear-gradient(135deg,rgba(255,247,241,.82),rgba(201,240,232,.62)),#edf8f5}.personal-card__inner:before{position:absolute;inset:12px;content:"";transition:border-color .22s ease}.personal-card--selected .personal-card__inner:before,.personal-card:hover .personal-card__inner:before{border-color:rgba(13,122,117,.12)}.personal-card__inner img{display:block;position:relative;z-index:1;width:auto;height:auto;max-width:calc(100% - 24px);max-height:calc(100% - 24px);object-fit:contain}.personal-card--dump .personal-card__inner img{max-width:calc(100% - 42px);max-height:calc(100% - 42px)}.personal-section__article-anchor{scroll-margin-top:0}.personal-section__article{width:min(820px,100%);margin:clamp(24px,4vw,42px) auto 0;padding:clamp(18px,2.6vw,28px);border:1px solid rgba(13,122,117,.12);border-radius:16px;background:linear-gradient(135deg,rgba(255,255,255,.9),rgba(247,238,231,.74)),rgba(255,255,255,.78);box-shadow:0 20px 70px rgba(16,21,34,.08);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.personal-section__article--dump{position:relative;min-height:clamp(420px,48vw,560px);overflow:hidden;background:radial-gradient(circle at 16% 18%,rgba(255,184,160,.3),transparent 30%),radial-gradient(circle at 80% 72%,rgba(188,232,255,.42),transparent 34%),linear-gradient(135deg,rgba(255,247,241,.96),rgba(201,240,232,.34)),rgba(255,255,255,.78)}.personal-section__article--dump:before{position:absolute;inset:18px;border:1px solid rgba(13,122,117,.1);border-radius:12px;content:"";pointer-events:none}.personal-section__dump-copy{position:absolute;z-index:2;min-width:0;padding:0}.personal-section__dump-copy--intro{top:clamp(72px,10vw,112px);right:clamp(24px,5vw,58px);width:min(350px,48%)}.personal-section__dump-copy--brand{left:clamp(250px,32vw,340px);bottom:clamp(48px,7vw,80px);width:min(330px,42%)}.personal-section__dump-logo{display:block;position:absolute;top:clamp(24px,4vw,42px);left:clamp(24px,4vw,42px);z-index:2;width:min(210px,100%);height:auto;filter:drop-shadow(0 18px 26px rgba(16,21,34,.1))}.personal-section__article span{display:block;color:var(--accent-strong);font-size:.76rem;font-weight:850;line-height:1}.personal-section__article p{margin:0;color:var(--muted);font-size:clamp(.92rem,1.2vw,1.02rem);font-weight:500;line-height:1.7}.personal-section__article--cjca{position:relative;overflow:hidden;background:radial-gradient(circle at 92% 18%,rgba(201,240,232,.38),transparent 28%),radial-gradient(circle at 8% 85%,rgba(188,232,255,.32),transparent 30%),linear-gradient(135deg,rgba(255,255,255,.94),rgba(247,238,231,.72)),rgba(255,255,255,.82)}.personal-section__cjca-logo{position:absolute;right:50%;top:50%;width:min(760px,96%);opacity:.075;pointer-events:none;transform:translate(50%,-50%) rotate(-4deg)}.personal-section__cjca-copy{position:relative;z-index:1;display:flex;flex-direction:column;gap:14px}.personal-section__cjca-second{display:grid;grid-template-columns:minmax(0,1fr) minmax(230px,.42fr);grid-gap:clamp(18px,3vw,30px);gap:clamp(18px,3vw,30px);align-items:start}.personal-section__cjca-report{min-width:0}.personal-section__linkedin-preview{position:relative;z-index:1;display:grid;grid-template-columns:34px minmax(0,1fr);grid-gap:12px;gap:12px;min-width:0;padding:14px;border:1px solid rgba(13,122,117,.14);border-radius:12px;background:rgba(255,255,255,.7);color:var(--ink);text-decoration:none;transition:transform .18s ease,border-color .18s ease,background .18s ease}.personal-section__linkedin-preview:hover{transform:translateY(-2px);border-color:rgba(13,122,117,.28);background:rgba(255,255,255,.88)}.personal-section__linkedin-preview img{width:34px;height:34px}.personal-section__linkedin-preview strong{display:block;font-size:.88rem;line-height:1.1}.personal-section__linkedin-preview span{display:block;margin-top:4px;color:var(--muted);font-size:.72rem;font-weight:700;text-transform:none}.personal-section__linkedin-preview p{margin-top:6px;font-size:.78rem;line-height:1.4}.personal-section__article--applytics{position:relative;display:grid;grid-template-columns:minmax(0,1fr) minmax(220px,.44fr);grid-gap:clamp(18px,3vw,30px);gap:clamp(18px,3vw,30px);overflow:hidden;background:radial-gradient(circle at 88% 18%,rgba(255,184,160,.24),transparent 30%),radial-gradient(circle at 18% 88%,rgba(201,240,232,.36),transparent 32%),linear-gradient(135deg,rgba(255,255,255,.94),rgba(188,232,255,.22)),rgba(255,255,255,.82)}.personal-section__applytics-preview{position:absolute;right:-8%;bottom:-16%;width:min(420px,54%);opacity:.1;pointer-events:none}.personal-section__applytics-copy{position:relative;z-index:1;display:grid;grid-gap:14px;gap:14px}.personal-section__applytics-copy a{color:var(--accent-strong);font-weight:800;text-decoration:none}.personal-section__applytics-links{position:relative;z-index:1;display:grid;grid-gap:12px;gap:12px;align-self:end}.personal-section__applytics-links a{display:grid;grid-template-columns:30px minmax(0,1fr);grid-gap:12px;gap:12px;align-items:center;min-width:0;padding:14px;border:1px solid rgba(13,122,117,.14);border-radius:12px;background:rgba(255,255,255,.72);color:var(--ink);text-decoration:none;transition:transform .18s ease,border-color .18s ease,background .18s ease}.personal-section__applytics-links a:first-child{grid-template-columns:1fr}.personal-section__applytics-links a:hover{transform:translateY(-2px);border-color:rgba(13,122,117,.28);background:rgba(255,255,255,.9)}.personal-section__applytics-links img{width:30px;height:30px}.personal-section__applytics-links strong{display:block;font-size:.9rem;line-height:1.1}.personal-section__applytics-links span{display:block;margin-top:4px;color:var(--muted);font-size:.74rem;font-weight:700}.personal-section__dump-copy--intro p{color:#45505a;font-size:clamp(1rem,1.35vw,1.14rem)}.personal-section__dump-copy--brand p{color:#45505a;font-size:clamp(.92rem,1.12vw,1.02rem);line-height:1.65}.personal-section__dump-art{display:block;position:absolute;object-fit:contain;filter:drop-shadow(0 18px 24px rgba(16,21,34,.12))}.personal-section__dump-art--death{right:clamp(6px,2vw,28px);bottom:clamp(-28px,-3vw,-10px);z-index:1;width:min(360px,48%);max-height:330px;opacity:.82}.personal-section__dump-flower{position:absolute;left:clamp(24px,4vw,62px);bottom:clamp(36px,6vw,74px);z-index:1;width:min(250px,32%);aspect-ratio:1;border-radius:999px;background:radial-gradient(ellipse at 50% 5%,rgba(255,184,160,.9) 0 18%,transparent 19%),radial-gradient(ellipse at 95% 50%,rgba(188,232,255,.84) 0 18%,transparent 19%),radial-gradient(ellipse at 50% 95%,rgba(201,240,232,.92) 0 18%,transparent 19%),radial-gradient(ellipse at 5% 50%,rgba(255,184,160,.68) 0 18%,transparent 19%);filter:drop-shadow(0 20px 28px rgba(16,21,34,.12));animation:personal-flower-spin 16s linear infinite;pointer-events:none}.personal-section__dump-flower:after,.personal-section__dump-flower:before{position:absolute;border-radius:inherit;content:""}.personal-section__dump-flower:before{inset:10%;background:radial-gradient(ellipse at 50% 0,rgba(201,240,232,.72) 0 20%,transparent 21%),radial-gradient(ellipse at 100% 50%,rgba(255,184,160,.58) 0 20%,transparent 21%),radial-gradient(ellipse at 50% 100%,rgba(188,232,255,.66) 0 20%,transparent 21%),radial-gradient(ellipse at 0 50%,rgba(201,240,232,.64) 0 20%,transparent 21%);transform:rotate(45deg)}.personal-section__dump-flower:after{inset:37%;background:radial-gradient(circle at 38% 34%,rgba(255,255,255,.8),transparent 24%),linear-gradient(135deg,rgba(13,122,117,.68),rgba(255,184,160,.72));box-shadow:0 8px 18px rgba(16,21,34,.08)}.personal-section__dump-art--john{left:clamp(18px,4vw,54px);bottom:clamp(26px,5vw,64px);z-index:2;width:min(210px,28%);max-height:230px;transform:rotate(-3deg)}@keyframes personal-flower-spin{to{transform:rotate(1turn)}}@media screen and (max-width:900px){.personal-section__grid{grid-template-columns:repeat(3,minmax(160px,1fr))}.personal-section__article--dump{min-height:620px}.personal-section__article--cjca{display:block}.personal-section__article--applytics,.personal-section__cjca-second{grid-template-columns:1fr}.personal-section__applytics-links{align-self:auto}.personal-section__dump-logo{width:min(180px,42%)}.personal-section__dump-copy--intro{top:132px;right:28px;width:min(410px,calc(100% - 56px))}.personal-section__dump-copy--brand{left:32px;bottom:54px;width:min(390px,52%)}.personal-section__dump-art--death{width:min(340px,56%);max-height:310px}.personal-section__dump-flower{width:min(220px,40%)}.personal-section__dump-art--john{width:min(190px,34%)}}@media screen and (max-width:620px){.personal-section{width:min(100% - 32px,1120px)}.personal-section__grid{grid-template-columns:minmax(190px,280px)}.personal-section__article--dump{min-height:760px}.personal-section__cjca-logo{right:50%;top:42%;width:420px;transform:translate(50%,-50%) rotate(-4deg)}.personal-section__dump-art--death,.personal-section__dump-art--john,.personal-section__dump-copy--brand,.personal-section__dump-copy--intro,.personal-section__dump-flower,.personal-section__dump-logo{position:absolute}.personal-section__dump-logo{top:22px;left:22px;width:min(160px,60%)}.personal-section__dump-copy--intro{top:150px;left:22px;right:22px;width:auto}.personal-section__dump-copy--brand{left:22px;right:22px;bottom:34px;width:auto}.personal-section__dump-art--death{right:-18px;bottom:96px;width:min(320px,82%);max-height:310px}.personal-section__dump-flower{left:10px;bottom:232px;width:min(210px,56%)}.personal-section__dump-art--john{left:16px;bottom:238px;width:min(170px,46%)}}@media (prefers-reduced-motion:reduce){.personal-section__dump-flower{animation:none}}.site-header{position:-webkit-sticky;position:sticky;top:0;z-index:20;min-height:58px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;grid-gap:24px;gap:24px;padding:9px clamp(18px,5vw,64px);background:rgba(251,251,248,.78);border-bottom:1px solid rgba(18,24,38,.09);-webkit-backdrop-filter:blur(18px) saturate(1.2);backdrop-filter:blur(18px) saturate(1.2)}.site-header__brand{width:38px;height:34px;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;transition:transform .18s ease,opacity .18s ease}.site-header__brand:hover{transform:translateY(-1px);opacity:.78}.site-header__home-icon{width:24px;height:24px;fill:none;stroke:#101522;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.site-header__nav{width:-moz-fit-content;width:fit-content;display:flex;justify-self:center;justify-content:center;gap:6px;padding:4px;border:1px solid rgba(18,24,38,.08);border-radius:999px;background:rgba(255,255,255,.72);box-shadow:0 10px 30px rgba(16,21,34,.05)}.site-header__back,.site-header__nav a,.site-header__socials a{color:#101522;text-decoration:none}.site-header__nav a{min-height:30px;display:inline-flex;align-items:center;padding:0 13px;border-radius:999px;font-size:.92rem;font-weight:600;transition:background .18s ease,color .18s ease,transform .18s ease}.site-header__nav a:hover{background:#101522;color:white;transform:translateY(-1px)}.site-header__back{width:-moz-fit-content;width:fit-content;min-height:34px;display:inline-flex;align-items:center;justify-self:center;gap:8px;padding:0 14px;border:1px solid rgba(18,24,38,.08);border-radius:999px;background:rgba(255,255,255,.72);box-shadow:0 10px 30px rgba(16,21,34,.05);font-size:.92rem;font-weight:700;transition:background .18s ease,color .18s ease,transform .18s ease}.site-header__back:hover{background:#101522;color:white;transform:translateY(-1px)}.site-header__socials{display:flex;align-items:center;justify-content:flex-end;gap:8px}.site-header__socials a{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;opacity:.8;transition:opacity .18s ease,transform .18s ease}.site-header__socials a:hover{opacity:1;transform:translateY(-1px)}.site-header__socials img{max-width:100%;max-height:100%}@media screen and (max-width:720px){.site-header{grid-template-columns:1fr;gap:10px}.site-header__nav{justify-content:center;flex-wrap:wrap;gap:4px}.site-header__socials{display:none}}@media screen and (max-width:460px){.site-header{padding:8px 14px}.site-header__brand{display:none}.site-header__nav a{padding:0 9px;font-size:.78rem}}.portfolio-school-band{position:relative;isolation:isolate;margin-top:clamp(24px,5vw,72px);background:linear-gradient(135deg,rgba(13,122,117,.2),transparent 34rem),linear-gradient(225deg,rgba(188,232,255,.18),transparent 28rem),#101522;color:white;overflow:hidden}.portfolio-school-band:after{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.34),transparent)}.portfolio-school{width:min(1120px,calc(100% - 40px));display:grid;grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);align-items:center;grid-gap:clamp(36px,7vw,88px);gap:clamp(36px,7vw,88px);margin:0 auto;padding:clamp(72px,9vw,118px) 0}.portfolio-school__text{min-width:0}.portfolio-school__eyebrow{width:-moz-fit-content;width:fit-content;margin:0 0 18px;padding:7px 11px;border:1px solid rgba(255,255,255,.18);border-radius:999px;background:rgba(255,255,255,.08);color:#c9f0e8;font-size:.82rem;font-weight:800;letter-spacing:0;text-transform:uppercase}.portfolio-school__text h2{margin:0;font-size:clamp(2rem,4.6vw,4.4rem);line-height:.98;overflow-wrap:anywhere}.portfolio-school__text p:not(.portfolio-school__eyebrow){margin:24px 0 0;color:rgba(255,255,255,.72);font-size:1.05rem;line-height:1.75;font-weight:500}.portfolio-school__visual{width:min(440px,100%);min-width:0;height:auto;justify-self:center;display:block;filter:drop-shadow(0 22px 22px rgba(16,21,34,.16))}@media screen and (max-width:860px){.portfolio-school{grid-template-columns:1fr}.portfolio-school__visual{width:min(340px,100%)}}@media screen and (max-width:560px){.portfolio-school{width:min(100% - 32px,1120px)}}.projects-section__heading{max-width:760px;margin-bottom:34px}.projects-section__heading h2{margin:0;font-size:clamp(1.8rem,3.4vw,3.2rem);line-height:.98;overflow-wrap:anywhere}.projects-section__heading>p:not(.portfolio-eyebrow){max-width:520px;margin:12px 0 0;color:var(--muted);font-size:.94rem;font-weight:500;line-height:1.55}.portfolio-projects{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,360px));justify-content:center;grid-gap:16px;gap:16px}.portfolio-project{display:flex;flex-direction:column;gap:12px;min-width:0;padding:clamp(8px,1vw,12px);border:1px solid var(--line);border-radius:10px;background:rgba(255,255,255,.82);box-shadow:0 22px 70px rgba(16,21,34,.07);color:var(--ink);cursor:pointer;overflow:hidden;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);text-decoration:none;transition:opacity 1s ease,transform .22s ease,box-shadow .22s ease,border-color .22s ease}.portfolio-project:hover{transform:translateY(-4px);border-color:rgba(13,122,117,.28);box-shadow:0 28px 90px rgba(16,21,34,.1)}.portfolio-project__copy{display:flex;flex:1 1;flex-direction:column;min-width:0}.portfolio-project__title-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.portfolio-project__title-row span{flex:0 0 auto;padding:4px 7px;border:1px solid rgba(13,122,117,.18);border-radius:999px;background:rgba(13,122,117,.08);color:var(--accent-strong);font-size:.66rem;font-weight:800;line-height:1;text-transform:uppercase}.portfolio-project h3{margin:0;font-size:clamp(1.05rem,1.45vw,1.35rem);line-height:1}.portfolio-project p{margin:8px 0 0;color:var(--muted);font-size:.82rem;line-height:1.45;font-weight:500}.portfolio-project__preview{width:100%;height:-moz-fit-content;height:fit-content;padding:4px;border-radius:12px}.portfolio-project__preview img{display:block;width:100%;object-fit:cover;border:1px solid var(--line);border-radius:10px}.portfolio-project__placeholder{min-height:190px;display:grid;place-items:center;border:1px dashed rgba(18,24,38,.2);border-radius:10px;background:linear-gradient(135deg,rgba(201,240,232,.45),rgba(188,232,255,.28)),#f6f8fa}.portfolio-project__placeholder span{color:var(--muted);font-size:.82rem;font-weight:800;text-transform:uppercase}.portfolio-tech{display:flex;flex-wrap:wrap;gap:7px;margin-top:auto;padding-top:12px}.portfolio-tech img{width:28px;height:28px;object-fit:contain;padding:4px;border:1px solid rgba(18,24,38,.08);border-radius:8px;background:white}@media screen and (max-width:860px){.portfolio-projects{grid-template-columns:minmax(0,420px)}}@media screen and (max-width:460px){.portfolio-projects{grid-template-columns:1fr}}.site-footer{position:relative;overflow:hidden;background:radial-gradient(circle at 18% 18%,rgba(201,240,232,.16),transparent 32%),radial-gradient(circle at 84% 78%,rgba(255,184,160,.14),transparent 30%),#101522;color:white}.site-footer__inner{display:grid;width:min(1120px,calc(100% - 40px));margin:0 auto;padding:clamp(42px,6vw,72px) 0 28px;grid-gap:26px;gap:26px}.site-footer__eyebrow{margin:0 0 10px;color:rgba(201,240,232,.78);font-size:.78rem;font-weight:850;text-transform:uppercase}.site-footer h2{margin:0;font-size:clamp(1.8rem,3vw,3rem);line-height:1}.site-footer__links{display:flex;flex-wrap:wrap;gap:12px}.site-footer__links a{display:grid;grid-template-columns:34px minmax(0,1fr);grid-gap:12px;gap:12px;align-items:center;min-width:min(100%,260px);padding:13px 15px;border:1px solid rgba(255,255,255,.14);border-radius:12px;background:rgba(255,255,255,.06);color:rgba(255,255,255,.74);text-decoration:none;transition:transform .18s ease,border-color .18s ease,background .18s ease}.site-footer__links a:hover{transform:translateY(-2px);border-color:rgba(201,240,232,.34);background:rgba(255,255,255,.1)}.site-footer__links img{width:34px;height:34px;padding:6px;border-radius:9px;background:white;object-fit:contain}.site-footer__links strong{display:block;margin-bottom:3px;color:white;font-size:.88rem}.site-footer__copyright{margin:8px 0 0;padding-top:22px;border-top:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.52);font-size:.78rem}@media screen and (max-width:560px){.site-footer__inner{width:min(100% - 32px,1120px)}.site-footer__links{flex-direction:column}}.dump{position:relative;isolation:isolate;padding:100px 0 0;display:flex;flex-direction:column;overflow-x:auto;overflow:hidden;background:white}.dump-c1{display:flex;flex-direction:row;align-items:flex-end;gap:15%}.dump-c1-text{width:300px;padding-bottom:5%;font-size:var(--font-500)}#dump-logo{height:350px}.dump-c2{position:relative;isolation:isolate;display:flex;flex-direction:row;align-items:center;padding:0 15%}.dump-c2-title{font-size:var(--font-700)}.dump-c2-t{flex:1 1;display:flex;flex-direction:column;justify-content:center;gap:3%}.dump-c2-text{width:80%}.dump-tshirts{flex:1 1;display:flex;flex-direction:row;position:relative}.dump-tshirt1,.dump-tshirt2{height:400px;width:300px}.dump-tshirt2{position:absolute;left:170px;top:-15px;transform:rotate(5deg)}.dump-c2-wave{position:absolute;left:0;top:0;z-index:-1}.dump-c3{display:flex;flex-direction:row;padding-top:5%}.dump-c3-c1{flex:1 1;display:flex;flex-direction:column}.dump-c3-c1,.dump-c3-tshirts{align-self:flex-start}.dump-c3-c1-text{padding-top:10%}.dump-c3-c2{flex:1 1;position:relative;isolation:isolate;display:flex;flex-direction:column;align-items:center;padding-top:7%;gap:80px}.dump-c3-wave2{position:absolute;top:0;right:15%;z-index:-1}.dump-c3-text{width:60%}.dump-c3-beetle{height:400px;width:600px}#bottom-border-line{width:0;opacity:0;transition:all 1s ease}#bottom-border-line.active{width:80%;opacity:1}.dump-c4{display:flex;flex-direction:row;justify-content:space-around;align-items:center;position:relative;z-index:0}.dump-c4-square{position:relative;height:300px;width:400px;margin-right:200px;align-self:flex-start;border:2px solid black}.dump-c4-rose{height:400px;width:200px;position:absolute;top:-200px;left:-100px}.dump-c4-text{position:absolute;bottom:-140px;right:-195px;width:350px;height:200px;background-color:rgb(255,255,255);display:flex;padding:20px 0 0 20px}.dump-c4-death{height:450px;width:500px;z-index:1}.dump-c5{position:relative;display:flex;flex-direction:row;padding-bottom:0}.dump-c5-dragon{flex:2 1;position:relative;isolation:isolate;height:auto;width:700px;margin-top:90px}.dump-c5-dragon-shape{position:absolute;width:500px;height:auto;top:10px;left:-50px;z-index:0}.dump-c5-c1{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center}.dump-c5-c1-text{width:min(78%,520px)}.dump-c5-john{height:550px;padding-top:10%}.dump-c1,.dump-c3,.dump-c4,.dump-c5{padding-right:15%;padding-left:15%}@media screen and (max-width:1500px){.dump{padding:100px 0 45px}#dump-logo{width:clamp(200px,70vw,550px);height:clamp(150px,30vw,450px)}.dump-tshirt1,.dump-tshirt2{height:clamp(200px,40vw,350px);width:clamp(150px,30vw,250px)}.dump-tshirt2{position:absolute;left:10vw;top:-15px;transform:rotate(5deg)}.dump-c3-beetle,.dump-c3-tshirts{width:100%;height:50%}.dump-c3-c2{gap:6vw}.dump-c4-rose{height:30vw;width:15vw;position:absolute;top:-15vw;left:-2vw}.dump-c5-john{width:100%;height:45%}}@media screen and (max-width:900px){.dump{padding:20vw 0}.dump-c1{flex-direction:column;align-items:center}.dump-c1-text{width:clamp(150px,70%,300px);align-self:flex-end}#dump-logo{width:clamp(200px,70vw,450px);height:clamp(150px,50vw,350px)}.dump-c2{flex-direction:column;overflow:hidden}.dump-c2-t{flex:1 1;display:flex;flex-direction:column;justify-content:center;align-self:flex-start;gap:3%;width:60%;min-width:220px}.dump-tshirts{flex:1 1;display:flex;flex-direction:row;position:relative;width:clamp(150px,50%,350px);align-self:flex-end}.dump-c3{display:flex;flex-direction:column-reverse;gap:10vw;padding:5vw 7vw}.dump-c3-c1{width:100%}.dump-c3-c2{flex:1 1;position:relative;isolation:isolate;display:flex;flex-direction:column;align-items:stretch;padding-top:0;gap:5vw}.dump-c3-wave2{position:absolute;top:-5vw;left:-7vw;height:25vw;min-height:200px;z-index:-1}.dump-c3-text{width:60%;padding:0 10vw}.dump-c3-beetle{width:100%}.dump-c4{height:auto;flex-direction:column-reverse;justify-content:center;gap:5vw;align-items:center;z-index:0;padding:0}.dump-c4,.dump-c4-square{display:flex;position:relative}.dump-c4-square{flex-direction:column;height:100vw;width:60vw;border:2px solid black;margin:30vw 15vw min(10vw,150px)}.dump-c4-rose{position:absolute;height:60vw;width:auto;top:-30vw}.dump-c4-text{position:absolute;bottom:max(-15vw,-150px);right:-10vw;height:auto;width:40vw;background-color:rgb(255,255,255);padding:max(2vw,20px);text-align:center;display:flex;justify-content:center;align-items:center}.dump-c4-death{width:100%;height:90vw;padding:0;margin:0;z-index:1}.dump-c5{position:relative;display:flex;flex-direction:column;padding:5vw}#dump-dragon{width:90%;height:100%}.dump-c5-dragon{flex:2 1;position:relative;isolation:isolate;height:auto;width:100%}.dump-c5-dragon-shape{position:absolute;height:100%;width:100%;top:0;left:0;z-index:0}.dump-c5-c1{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center}.dump-c5-c1-text{width:60%}.dump-c5-john{height:auto;width:100%;padding-top:10%}}@keyframes dump-logo-shadow{0%{transform:rotate(0) translateY(0) translateX(0)}25%{transform:rotate(-3deg) translateY(-7px) translateX(15px)}50%{transform:rotate(-1deg) translateY(-10px) translateX(0)}50%{transform:rotate(2deg) translateY(-13px) translateX(17px)}to{transform:rotate(1deg) translateY(7px) translateX(8px)}}#dump-logo-shadow{fill:#656565;transform-origin:center;animation:dump-logo-shadow 5s ease-in-out infinite;animation-direction:alternate}@keyframes dragon{0%{transform:rotate(0) translateY(0) translateX(5px)}to{transform:rotate(2deg) translateY(-10px) translateX(-5px)}}#dump-dragon{position:relative;z-index:1;transform-origin:center;animation:dragon 5s ease-in-out infinite;animation-direction:alternate}@keyframes rotate{0%{transform:rotate(0deg) translateY(-10px) translateX(0)}20%{transform:rotate(1deg) translateY(-12px) translateX(-3px)}50%{transform:rotate(1deg) translateY(-14px) translateX(-2px)}75%{transform:rotate(3deg) translateY(-16px) translateX(3px)}to{transform:rotate(3deg) translateY(-13px) translateX(-6px)}}#shadow{transform-origin:center;animation:rotate 7s ease-in-out infinite;animation-direction:alternate}@media screen and (max-width:900px){.dump{padding:5rem 0;gap:2rem}.dump-c1{flex-direction:column;align-items:center}.dump-c1-text{font-size:1rem}.dump-c2{flex-direction:column;align-items:center;overflow:none;padding:2rem;gap:4rem}.dump-c2,.dump-c2-t{justify-content:center;margin:0;width:100%}.dump-c2-t{flex:1 1;display:flex;flex-direction:column;align-self:flex-start;gap:0;padding:0}.dump-c2-text{width:100%}.dump-c2-title{font-size:1.5rem;margin-bottom:2rem}.dump-c2-text,.dump-c3-c1-text,.dump-c3-text,.dump-c4-text,.dump-c5-c1-text{font-size:14px}.dump-tshirts{flex:1 1;display:flex;flex-direction:row;position:relative;width:auto;align-self:center}.dump-tshirt1,.dump-tshirt2{height:250px;width:auto}.dump-c3{display:flex;flex-direction:column-reverse;gap:2rem;justify-content:center;align-items:center;padding:2rem 1rem}.dump-c3-c1{width:100%;display:flex;flex-direction:column;gap:2rem}.dump-c3-c2{flex:1 1;position:relative;isolation:isolate;display:flex;flex-direction:column;align-items:stretch;padding-top:0;gap:2rem}.dump-c3-wave2{position:absolute;top:-5vw;left:-7vw;height:25vw;min-height:200px;z-index:-1}.dump-c3-c1-text,.dump-c3-text{width:100%;padding:0 10vw}.dump-c3-beetle,.dump-c3-tshirts{width:80%;align-self:center}}