*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#07060e;--text:#cbd5e1b3;--text-bright:#fffffff2;--accent-1:#a78bfa;--accent-2:#f472b6}html,body{height:100%}body{background:var(--bg);color:var(--text);font-family:Outfit,sans-serif;position:relative}.orb{filter:blur(120px);opacity:.4;will-change:transform, filter;pointer-events:none;border-radius:50%;animation:18s ease-in-out infinite alternate drift,12s linear infinite hueShift;position:fixed}.orb--1{background:linear-gradient(135deg,#6366f1,#a855f7,#ec4899);width:55vmax;height:55vmax;animation-duration:22s,12s;top:-18%;left:-12%}.orb--2{background:linear-gradient(315deg,#3b82f6,#8b5cf6,#d946ef);width:45vmax;height:45vmax;animation-duration:26s,15s;animation-delay:-4s,-3s;bottom:-20%;right:-10%}.orb--3{opacity:.25;background:linear-gradient(225deg,#2563eb,#7c3aed,#f472b6);width:30vmax;height:30vmax;animation-duration:20s,10s;animation-delay:-8s,-6s;top:40%;left:55%}@keyframes drift{0%{transform:translate(0)scale(1)}33%{transform:translate(6vw,-4vh)scale(1.08)}66%{transform:translate(-4vw,6vh)scale(.95)}to{transform:translate(3vw,3vh)scale(1.03)}}@keyframes hueShift{0%{filter:blur(120px)hue-rotate()}to{filter:blur(120px)hue-rotate(360deg)}}body:after{content:"";opacity:.035;pointer-events:none;z-index:10;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");background-size:128px 128px;position:fixed;inset:0}.particles{z-index:2;pointer-events:none;position:fixed;inset:0;overflow:hidden}.particle{background:#a88bfa80;border-radius:50%;width:2px;height:2px;animation:linear infinite float;position:absolute}@keyframes float{0%{opacity:0;transform:translateY(100vh)scale(0)}10%{opacity:1}90%{opacity:1}to{opacity:0;transform:translateY(-10vh)scale(1)}}.cursor-glow{pointer-events:none;z-index:3;opacity:0;background:radial-gradient(circle,#8b5cf614 0%,#0000 70%);border-radius:50%;width:300px;height:300px;transition:opacity .3s;position:fixed;transform:translate(-50%,-50%)}@keyframes fadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.nav{z-index:20;justify-content:space-between;align-items:center;padding:1.5rem 2rem;animation:1.2s cubic-bezier(.22,1,.36,1) both fadeUp;display:flex;position:fixed;top:0;left:0;right:0}.nav-brand{color:#fff;letter-spacing:-.02em;font-family:Sora,sans-serif;font-size:1.1rem;font-weight:600;text-decoration:none}.nav-links{gap:1.5rem;list-style:none;display:flex}.nav-links a{color:var(--text);letter-spacing:.04em;font-size:.9rem;font-weight:300;text-decoration:none;transition:color .3s}.nav-links a:hover{color:var(--text-bright)}.gradient-text{background:linear-gradient(135deg,#93c5fd 0%,#a78bfa 25%,#c084fc 50%,#f472b6 75%,#93c5fd 100%) 0 0/300% 300%;-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;animation:8s infinite gradientFlow}@keyframes gradientFlow{0%,to{background-position:0%}50%{background-position:100%}}.gradient-link{background:linear-gradient(135deg,#3b82f6,#8b5cf6,#f97316,#3b82f6) 0 0/300% 300%;-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:400;text-decoration:none;transition:filter .3s;animation:8s infinite gradientFlow}.gradient-link:hover{filter:brightness(1.3)}a.styled-link{color:var(--text);letter-spacing:.06em;font-family:Outfit,sans-serif;font-weight:300;text-decoration:none;transition:color .4s,letter-spacing .4s;position:relative}a.styled-link:after{content:"";background:linear-gradient(90deg, var(--accent-1), var(--accent-2));width:0;height:1px;transition:width .4s,left .4s;position:absolute;bottom:-3px;left:50%}a.styled-link:hover{color:var(--text-bright);letter-spacing:.09em}a.styled-link:hover:after{width:100%;left:0}.hero{z-index:5;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:2rem;height:100%;display:flex;position:relative;overflow:hidden}.logo{letter-spacing:-.03em;color:#fff;-webkit-user-select:none;user-select:none;will-change:transform;font-family:Sora,sans-serif;font-size:clamp(2.8rem,8vw,6.5rem);font-weight:600;line-height:1;transition:transform .35s cubic-bezier(.22,1,.36,1);animation:1.2s cubic-bezier(.22,1,.36,1) both fadeUp}.divider{background:linear-gradient(90deg,#0000,#a88bfa99,#0000);width:48px;height:1px;animation:1.2s cubic-bezier(.22,1,.36,1) .2s both fadeUp,4s ease-in-out infinite pulseGlow}@keyframes pulseGlow{0%,to{opacity:.5;width:48px}50%{opacity:1;width:64px}}.hero-project{letter-spacing:.18em;text-transform:uppercase;color:#0000;background:linear-gradient(135deg, var(--accent-1), var(--accent-2));-webkit-background-clip:text;background-clip:text;padding:.3rem 0;font-family:Sora,sans-serif;font-size:clamp(1rem,2.5vw,1.3rem);font-weight:300;text-decoration:none;transition:letter-spacing .4s cubic-bezier(.22,1,.36,1),filter .4s;animation:1.2s cubic-bezier(.22,1,.36,1) .3s both fadeUp;position:relative}.hero-project:after{content:"";background:linear-gradient(90deg, var(--accent-1), var(--accent-2));width:0;height:1px;transition:width .4s cubic-bezier(.22,1,.36,1),left .4s cubic-bezier(.22,1,.36,1);position:absolute;bottom:0;left:50%}.hero-project:hover{letter-spacing:.28em;filter:brightness(1.3)}.hero-project:hover:after{width:100%;left:0}.contact{flex-direction:column;gap:.6rem;animation:1.2s cubic-bezier(.22,1,.36,1) .5s both fadeUp;display:flex}.contact a{font-size:clamp(.85rem,2vw,1.05rem)}.macaroni{z-index:5;max-width:640px;margin:0 auto;padding:6rem 2rem 4rem;animation:1.2s cubic-bezier(.22,1,.36,1) both fadeUp;position:relative}.macaroni-header{margin-bottom:3rem}.macaroni-header h1{margin-bottom:.5rem;font-family:Sora,sans-serif;font-size:clamp(2rem,5vw,3rem);font-weight:600}.macaroni-header p{color:var(--text);letter-spacing:.02em;font-size:1rem;font-weight:300}.macaroni-posts{flex-direction:column;gap:2rem;display:flex}.macaroni-card{background:#ffffff05;border:1px solid #a88bfa1a;border-radius:12px;padding:1.5rem;transition:border-color .3s,background .3s}.macaroni-card:hover{background:#ffffff0a;border-color:#a88bfa40}.macaroni-card time{color:var(--accent-1);letter-spacing:.05em;font-size:.8rem;font-weight:300}.macaroni-card-toggle{all:unset;cursor:pointer;justify-content:space-between;align-items:flex-start;gap:1rem;width:100%;display:flex}.macaroni-card-header{flex:1;min-width:0}.macaroni-card-chevron{color:var(--text);flex-shrink:0;margin-top:1.4rem;transition:transform .3s,color .3s}.macaroni-card-toggle[aria-expanded=true] .macaroni-card-chevron{transform:rotate(180deg)}.macaroni-card-toggle:hover .macaroni-card-chevron{color:var(--accent-1)}.macaroni-card h2{color:#fff;margin:.4rem 0;font-family:Sora,sans-serif;font-size:1.2rem;font-weight:400;transition:color .3s}.macaroni-card-toggle:hover h2{color:var(--accent-1)}.macaroni-card-summary{color:var(--text);font-size:.9rem;font-weight:300;line-height:1.6}.macaroni-card-body{grid-template-rows:0fr;margin-top:0;transition:grid-template-rows .35s,margin-top .35s;display:grid}.macaroni-card-content{overflow:hidden}.macaroni-card.expanded .macaroni-card-body{grid-template-rows:1fr;margin-top:1rem}.macaroni-card-body p{color:var(--text);border-top:1px solid #a88bfa1a;padding-top:1rem;font-size:.9rem;font-weight:300;line-height:1.8}.macaroni-card-body p+p{border-top:none;padding-top:.8rem}.macaroni-card-body h3{color:var(--heading);margin-top:2rem;margin-bottom:.5rem;font-family:Sora,sans-serif;font-size:1.1rem;font-weight:600}.macaroni-card-body h3:first-child{margin-top:0}.macaroni-card-body h4{color:var(--heading);margin-top:1.4rem;margin-bottom:.3rem;font-family:Sora,sans-serif;font-size:.95rem;font-weight:400}.macaroni-card-body ul,.macaroni-card-body ol{color:var(--text);margin:.5rem 0;padding-left:1.4rem;font-size:.9rem;font-weight:300;line-height:1.8}.macaroni-card-body li{margin-bottom:.3rem}.macaroni-card-body strong{color:var(--heading);font-weight:600}.macaroni-card-body em{color:#a88bfad9;font-style:italic}.macaroni-card-body img{border:1px solid #a88bfa26;border-radius:12px;width:100%;max-width:640px;margin:1.2rem 0}.macaroni-card-body .img-row{flex-wrap:wrap;gap:1rem;margin:1.2rem 0;display:flex}.macaroni-card-body .img-row img{flex:200px;margin:0}.macaroni-card-body .img-caption{color:#fff6;text-align:center;margin-top:-.6rem;margin-bottom:1rem;font-size:.8rem}.macaroni-card-body .comparison-table{border-collapse:collapse;width:100%;margin:1rem 0;font-size:.85rem}.macaroni-card-body .comparison-table th,.macaroni-card-body .comparison-table td{text-align:left;color:var(--text);border-bottom:1px solid #a88bfa1a;padding:.6rem .8rem;font-weight:300}.macaroni-card-body .comparison-table th{color:var(--heading);font-weight:600}.macaroni-card-body .callout{color:var(--text);background:#a88bfa0f;border-left:3px solid #a88bfa66;border-radius:0 8px 8px 0;margin:1rem 0;padding:.8rem 1rem;font-size:.88rem;line-height:1.7}.macaroni-card-body hr{border:none;border-top:1px solid #a88bfa1a;margin:1.5rem 0}
