:root{--bg:#0e192d;--tint:#8b8fc2;--surface:#12233f;--surface-2:#162845;--line:#8b8fc257;--text:#e8edff;--muted:#b7c2df;--radius-lg:24px;--radius-md:16px;--container:1120px}*{box-sizing:border-box}html,body{margin:0;padding:0}html{scroll-behavior:smooth}body{min-height:100vh;color:var(--text);background:radial-gradient(circle at 86% 4%, #8b8fc240, transparent 28%),radial-gradient(circle at 7% 28%, #8b8fc22e, transparent 30%),var(--bg);background-size:120% 120%;font-family:Avenir Next,Nunito Sans,Segoe UI,sans-serif;animation:16s ease-in-out infinite alternate bgShift}a{color:inherit;text-decoration:none}.portfolio-page{padding:clamp(1.1rem,2.4vw,2.1rem);position:relative}.section-shell{width:min(var(--container),100%);margin:0 auto}.section-space{margin-top:1.35rem}.ambient{filter:blur(70px);pointer-events:none;z-index:-1;border-radius:999px;width:320px;height:320px;position:fixed}.ambient-a{background:#8b8fc24d;animation:10s ease-in-out infinite floatA;top:-120px;right:-80px}.ambient-b{background:#8b8fc23d;animation:12s ease-in-out infinite floatB;bottom:-140px;left:-100px}.ambient-c{background:#2f436c33;width:220px;height:220px;animation:8s ease-in-out infinite pulse;top:34%;left:42%}.top-nav{z-index:30;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0e192d94;border:1px solid #8b8fc247;border-radius:999px;justify-content:space-between;align-items:center;margin-bottom:.95rem;padding:.6rem .8rem;animation:.6s both fadeDown;display:flex;position:sticky;top:0}.brand{background:#8b8fc21a;border:1px solid #8b8fc280;border-radius:999px;justify-content:center;align-items:center;min-height:42px;padding:.2rem .56rem;display:flex}.brand img{width:auto;height:21px;transform:scale(1.5)}.top-nav nav{gap:.15rem;display:inline-flex}.top-nav nav a{color:#d9e0fb;border-radius:999px;align-items:center;gap:.35rem;padding:.5rem .72rem;font-size:.92rem;transition:color .18s,background .18s;display:inline-flex;position:relative}.top-nav nav a:hover{color:#f1f4ff;background:#8b8fc21f}.top-nav nav a:after{content:"";transform-origin:0;background:var(--tint);border-radius:999px;height:2px;transition:transform .18s;position:absolute;bottom:.38rem;left:.72rem;right:.72rem;transform:scaleX(0)}.top-nav nav a:hover:after{transform:scaleX(1)}.hero{border:1px solid var(--line);border-radius:calc(var(--radius-lg) + 4px);background:linear-gradient(160deg,#14223ceb,#101d32f2 55%,#0d1728fa);padding:clamp(1.6rem,4vw,3.2rem);animation:.64s both fadeUp;position:relative;overflow:hidden;box-shadow:0 24px 60px #050a1673}.hero-layout{grid-template-columns:minmax(0,1.2fr) minmax(240px,.8fr);align-items:center;gap:1.1rem;display:grid}.hero-visual{justify-content:flex-end;display:flex}.profile-frame{border:1px solid #8b8fc280;border-radius:22px;width:min(340px,100%);animation:7s ease-in-out infinite profileFloat;position:relative;overflow:hidden;box-shadow:0 14px 32px #050a1680,inset 0 0 0 1px #ffffff0a}.profile-frame img{width:100%;height:auto;display:block}.profile-frame:after{content:"";background:linear-gradient(#0000,#0e192d85);height:36%;position:absolute;inset:auto 0 0}.hero:before{content:"";pointer-events:none;background:linear-gradient(90deg,#0000 0%,#ffffff1f 50%,#0000 100%);width:72%;height:220%;animation:8s linear infinite heroSweep;position:absolute;inset:-60% auto auto -25%;transform:rotate(28deg)}.eyebrow-tag{border:1px solid var(--line);color:#d5dcf7;letter-spacing:.06em;text-transform:uppercase;border-radius:999px;align-items:center;gap:.4rem;margin:0;padding:.34rem .68rem;font-size:.78rem;font-weight:700;display:inline-flex}.icon{stroke:currentColor;stroke-width:1.9px;stroke-linecap:round;stroke-linejoin:round;flex:none;width:1rem;height:1rem}.icon-nav-brand{width:.86rem;height:.86rem}.icon-nav{width:.88rem;height:.88rem}.icon-chip{width:.82rem;height:.82rem}.icon-btn,.icon-eyebrow{width:.86rem;height:.86rem}.icon-card{width:1.1rem;height:1.1rem}.icon-list{color:#bcc8ec;width:.9rem;height:.9rem;margin-top:.16rem}.icon-tag{color:#d0daf8;width:.88rem;height:.88rem}.icon-step{width:.88rem;height:.88rem}.hero h1{letter-spacing:-.04em;margin:1.1rem 0 0;font-family:Sora,Futura,Trebuchet MS,sans-serif;font-size:clamp(2.2rem,6vw,4.8rem);line-height:.96}.hero h1 span{color:#d5dcf7;letter-spacing:0;max-width:24ch;margin-top:.95rem;font-size:clamp(1rem,2.2vw,1.45rem);font-weight:450;line-height:1.4;animation:.9s both fadeUp;display:block}.lead{max-width:66ch;color:var(--muted);margin:1.05rem 0 0;line-height:1.75}.hero-actions{flex-wrap:wrap;gap:.7rem;margin-top:1.35rem;display:flex}.hero-actions .btn{gap:.28rem}.btn{border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;padding:.76rem 1.16rem;font-weight:700;transition:transform .17s,background .17s,border-color .17s,box-shadow .17s;display:inline-flex}.btn:hover{transform:translateY(-2px)}.btn-primary{background:var(--tint);color:#101b32;box-shadow:0 0 #8b8fc200}.btn-primary:hover{background:#9ea2d1;box-shadow:0 0 24px #8b8fc257}.btn-ghost{border-color:var(--line);color:#dfe5fc;background:#8b8fc214}.btn-ghost:hover{background:#8b8fc226;border-color:#8b8fc2ad}.section-head{margin-bottom:.9rem}.section-head h2{letter-spacing:-.02em;margin:.1rem 0 0;font-family:Sora,Futura,Trebuchet MS,sans-serif;font-size:clamp(1.45rem,3.2vw,2.2rem);animation:.62s both fadeUp}.eyebrow{color:#b7c1e3;text-transform:uppercase;letter-spacing:.08em;align-items:center;gap:.36rem;margin:0;font-size:.77rem;font-weight:700;animation:.52s both fadeUp;display:inline-flex}.project-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.86rem;display:grid}.workflow-grid{background:#111f3680;border:1px solid #8b8fc257;border-radius:20px;grid-template-columns:repeat(2,minmax(0,1fr));gap:0;display:grid;overflow:hidden}.split-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.86rem;display:grid}.focus-shell{width:100%}.focus-head{margin-bottom:.72rem}.focus-layout{grid-template-columns:minmax(220px,.7fr) minmax(0,1.3fr);align-items:stretch;gap:.92rem;display:grid}.focus-nav{gap:.5rem;display:grid}.focus-tab{color:#d3dcf9;text-align:left;white-space:nowrap;text-overflow:ellipsis;cursor:pointer;background:#12233fc2;border:1px solid #8b8fc23d;border-radius:14px;align-items:center;gap:.5rem;width:100%;height:56px;min-height:56px;max-height:56px;padding:.74rem .82rem;font-weight:650;transition:transform .17s,border-color .17s,background .17s,box-shadow .17s;display:inline-flex;overflow:hidden}.focus-tab:hover{background:#8b8fc229;border-color:#8b8fc28f;transform:translate(3px)}.focus-tab.is-active{background:#8b8fc23d;border-color:#8b8fc2b8;box-shadow:0 0 18px #8b8fc233}.focus-tab-icon{color:#c5d1f5;flex:none;width:.92rem;height:.92rem}.focus-tab.is-active .focus-tab-icon{color:#f0f3ff}.focus-card{min-height:100%;animation:.43s both fadeUp}.panel-swap{animation:.42s cubic-bezier(.2,.7,.2,1) both panelSwapIn}.focus-card h3{margin:.5rem 0 0;font-size:clamp(1.08rem,2vw,1.34rem)}.focus-list{gap:.5rem;margin:.95rem 0 0;padding:0;list-style:none;display:grid}.focus-list li{color:#d2daf5;opacity:0;animation:.36s both panelItemIn;animation-delay:var(--item-delay,0s);align-items:flex-start;gap:.48rem;line-height:1.58;display:inline-flex}.focus-list li:before{content:"";background:#8b8fc2db;border-radius:999px;flex:none;width:.5rem;height:.5rem;margin-top:.34rem}.card{border-radius:var(--radius-lg);border:1px solid var(--line);background:linear-gradient(165deg,#12233ff2,#11213ae6 65%,#0d1a2ef5);padding:1.12rem;transition:transform .22s,border-color .22s,box-shadow .22s;box-shadow:inset 0 1px #8b8fc224}.card:hover{border-color:#8b8fc294;transform:translateY(-4px);box-shadow:inset 0 1px #8b8fc229,0 14px 28px #050a1659}.card h3,.card h2{letter-spacing:-.02em;margin:0;font-family:Sora,Futura,Trebuchet MS,sans-serif}.project-card h3{font-size:1.15rem}.card-icon-wrap{background:#8b8fc224;border:1px solid #8b8fc273;border-radius:12px;justify-content:center;align-items:center;width:2rem;height:2rem;margin-bottom:.62rem;display:inline-flex}.card p{color:var(--muted);margin:.72rem 0 0;line-height:1.66}.project-card ul{gap:.45rem;margin:.88rem 0 0;padding:0;list-style:none;display:grid}.project-card li{color:#d2daf5;align-items:flex-start;gap:.42rem;line-height:1.5;transition:transform .14s;display:inline-flex}.project-card:hover li{transform:translate(2px)}.tag-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.54rem;margin:.86rem 0 0;padding:0;list-style:none;display:grid}.tag-grid li{color:#e3e8fd;background:#8b8fc21f;border:1px solid #8b8fc261;border-radius:12px;align-items:center;gap:.42rem;padding:.55rem .68rem;font-weight:600;transition:transform .17s,background .17s;display:inline-flex}.tag-grid li:hover{background:#8b8fc233;transform:translateY(-2px)}.workflow-card span{color:#dce4ff;letter-spacing:.07em;background:#8b8fc21f;border:1px solid #8b8fc273;border-radius:999px;align-items:center;gap:.35rem;padding:.3rem .56rem;font-size:.74rem;font-weight:800;display:inline-flex}.workflow-card{box-shadow:none;background:0 0;border:0;border-radius:0;min-height:196px}.workflow-grid .workflow-card:nth-child(odd){border-right:1px solid #8b8fc23d}.workflow-grid .workflow-card:nth-child(-n+2){border-bottom:1px solid #8b8fc23d}.workflow-grid .card:hover{box-shadow:none;background:#8b8fc214;border-color:#0000;transform:none}.workflow-card h3{margin-top:.62rem;font-size:1.06rem}.cta{align-items:start;gap:.82rem;display:grid}.contact-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.6rem;display:grid}.contact-item{color:#dce4ff;background:#8b8fc21a;border:1px solid #8b8fc26b;border-radius:12px;align-items:center;gap:.42rem;padding:.72rem .84rem;font-weight:600;transition:transform .17s,border-color .17s,background .17s;display:inline-flex}.contact-item:hover{background:#8b8fc233;border-color:#8b8fc2bd;transform:translateY(-2px)}.icon-contact{width:.9rem;height:.9rem}.fade-in{animation:.7s cubic-bezier(.2,.65,.2,1) both fadeUp}.stagger-item{animation:.8s cubic-bezier(.2,.65,.2,1) both fadeUp}.project-grid .stagger-item:nth-child(2),.workflow-grid .stagger-item:nth-child(2),.split-grid .stagger-item:nth-child(2){animation-delay:.12s}.project-grid .stagger-item:nth-child(3),.workflow-grid .stagger-item:nth-child(3){animation-delay:.24s}.workflow-grid .stagger-item:nth-child(4){animation-delay:.36s}@media (max-width:980px){.focus-layout{grid-template-columns:1fr}.hero-layout{grid-template-columns:1fr;gap:.95rem}.hero-visual{order:-1;justify-content:center}.profile-frame{width:min(320px,100%)}.top-nav{border-radius:18px;flex-direction:column;align-items:stretch;row-gap:.5rem;padding:.58rem .62rem;top:0}.top-nav .brand{align-self:center}.top-nav nav{grid-template-columns:repeat(4,minmax(0,1fr));gap:.34rem;width:100%;display:grid}.top-nav nav a{justify-content:center;padding:.5rem .48rem;font-size:.84rem}.project-grid,.workflow-grid,.split-grid{grid-template-columns:1fr}.workflow-grid{background:0 0;border:0;border-radius:0;gap:.78rem;overflow:visible}.workflow-card{border:1px solid var(--line);border-radius:var(--radius-lg);background:linear-gradient(165deg,#12233ff2,#11213ae6 65%,#0d1a2ef5);min-height:auto;box-shadow:inset 0 1px #8b8fc224}.workflow-grid .workflow-card:nth-child(odd),.workflow-grid .workflow-card:nth-child(-n+2){border-right:1px solid var(--line);border-bottom:1px solid var(--line)}.contact-grid,.tag-grid{grid-template-columns:1fr}}@media (max-width:720px){.portfolio-page{padding:.8rem}.top-nav{border-radius:20px;min-height:104px;padding:.65rem;display:block;position:sticky}.top-nav .brand{z-index:3;align-self:auto;margin:0;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.top-nav nav{width:100%;padding:0;display:block;position:absolute;inset:0;overflow:visible}.top-nav nav a{background:#8b8fc214;border:1px solid #8b8fc261;justify-content:center;min-width:112px;padding:.46rem .58rem;position:absolute}.top-nav nav a:after{display:none}.top-nav nav a:first-child{top:.72rem;left:.72rem}.top-nav nav a:nth-child(2){top:.72rem;right:.72rem}.top-nav nav a:nth-child(3){bottom:.72rem;left:.72rem}.top-nav nav a:nth-child(4){bottom:.72rem;right:.72rem}.section-space{margin-top:.95rem}.hero{padding:1.1rem}.eyebrow-tag{letter-spacing:.05em;font-size:.72rem}.hero h1{font-size:clamp(1.8rem,9.5vw,2.8rem);line-height:1.02}.hero h1 span{margin-top:.72rem;font-size:clamp(.95rem,4.2vw,1.2rem)}.lead{margin-top:.78rem;font-size:.96rem;line-height:1.62}.hero-actions{gap:.55rem;margin-top:1rem}.hero-actions .btn{width:100%;min-height:46px}.card{padding:.96rem}.project-card h3,.focus-card h3,.workflow-card h3{font-size:1rem}.workflow-card{min-height:170px}.focus-tab{height:52px;min-height:52px;max-height:52px;font-size:.92rem}.contact-item{min-height:46px;font-size:.94rem}}@media (max-width:480px){.top-nav{min-height:104px;padding:.58rem}.brand{min-height:38px;padding:.2rem .46rem}.brand img{height:18px}.icon-nav{width:.8rem;height:.8rem}.top-nav nav a{gap:.22rem;min-width:98px;padding:.4rem .42rem;font-size:.78rem}.section-head h2{font-size:clamp(1.22rem,6.3vw,1.6rem)}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition:none!important;animation:none!important}}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes panelSwapIn{0%{opacity:0;transform:translate(16px)scale(.99)}to{opacity:1;transform:translate(0)scale(1)}}@keyframes panelItemIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes heroSweep{0%{transform:translate(-55%)rotate(28deg)}to{transform:translate(165%)rotate(28deg)}}@keyframes floatA{0%,to{transform:translate(0)}50%{transform:translate(-16px,12px)}}@keyframes floatB{0%,to{transform:translate(0)}50%{transform:translate(14px,-16px)}}@keyframes pulse{0%,to{opacity:.45;transform:scale(1)}50%{opacity:.28;transform:scale(1.14)}}@keyframes bgShift{0%{background-position:0 0}to{background-position:100% 100%}}@keyframes profileFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}
