.page{min-height:100vh;background:var(--c-bg-dark);color:var(--c-ink-invert);padding-top:var(--nav-h, 3.5rem)}.page-section{padding:5rem var(--page-px);max-width:var(--page-max);margin:0 auto}.page-section-title{font-family:var(--f-display);font-size:clamp(1.75rem,4vw,2.75rem);line-height:1.1;margin:0 0 2.5rem;color:var(--c-ink-invert)}.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(17rem,1fr));gap:1.25rem}.svc-card{padding:1.75rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:1rem;backdrop-filter:blur(.5rem);transition:border-color .25s ease,transform .25s ease}.svc-card:hover{border-color:#ffffff2e;transform:translateY(-2px)}.svc-card-icon{width:1.75rem;height:1.75rem;color:var(--c-accent);margin-bottom:1rem}.svc-card-title{font-family:var(--f-sans);font-size:1.15rem;font-weight:500;margin:0 0 .5rem;color:var(--c-ink-invert)}.svc-card-text{font-family:var(--f-serif);font-size:.95rem;line-height:1.55;color:#ffffffa6;margin:0}.portfolio-hero{position:relative;background:var(--c-bg-dark);color:var(--c-ink-invert);height:380vh}.ph-sticky{position:sticky;top:0;height:100vh;width:100%;overflow:hidden;display:flex;align-items:center;justify-content:center}.ph-gl{position:absolute;inset:0;z-index:1;pointer-events:none}.ph-title{position:relative;z-index:3;margin:0;padding:0 1rem;min-height:1.2em;contain:layout paint;font-family:var(--f-serif);font-weight:400;font-style:italic;font-size:clamp(3rem,10vw,7.5rem);line-height:1;letter-spacing:-.01em;color:#fff;text-align:center;text-shadow:0 .6rem 1.6rem rgba(0,0,0,.6);pointer-events:none;white-space:nowrap;opacity:0;transform:translateY(.4em);transition:opacity .7s var(--ease-out-expo, cubic-bezier(.22, 1, .36, 1)),transform .7s var(--ease-out-expo, cubic-bezier(.22, 1, .36, 1));will-change:opacity,transform}.ph-title.is-in{opacity:1;transform:translateY(0)}.ph-hint{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);z-index:3;font-family:var(--f-sans);font-size:.72rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:#ffffff80;pointer-events:none}.ph-video-section{position:relative;width:100%;height:100vh;background:var(--c-bg-dark)}.ph-video-frame{position:relative;width:100%;height:100%;box-sizing:border-box;padding:0;background:var(--c-bg-dark);will-change:padding}.ph-video-inner{position:relative;width:100%;height:100%;overflow:hidden;border-radius:0;will-change:border-radius}.ph-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}.ph-video-text{position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center;padding:0 1.5rem;pointer-events:none;mix-blend-mode:difference}.ph-st-title{color:#fff;margin:0;font-family:var(--f-display);font-weight:700;font-size:clamp(1.75rem,10vw,11rem);line-height:1;letter-spacing:.02em;text-transform:uppercase;text-align:center;display:flex;flex-direction:column;gap:.1em;max-width:min(100%,60rem)}.ph-st-word{display:flex;justify-content:space-between}.ph-st-char{display:inline-block;opacity:0;filter:blur(20px);will-change:opacity,filter}@media(prefers-reduced-motion:reduce){.portfolio-hero{height:auto}.ph-sticky{position:static;height:auto;overflow:visible;display:block;padding:3rem 0}.ph-gl{display:none}.ph-title{opacity:1;transform:none;transition:none}}.phone-notifier{position:sticky;top:0;width:100%;height:100vh;display:flex;justify-content:center;align-items:center}.phone{width:256px;height:537px;position:relative;border-radius:30px;box-shadow:0 30px 80px #00000059}.phone-bezel{width:100%;height:100%;background:linear-gradient(160deg,#2a2a30,#14141a,#1f1f26);border-radius:30px;padding:3px;position:relative}.phone-screen{width:100%;height:100%;background:#080808;border-radius:27px;overflow:hidden;position:relative}.phone-wallpaper{position:absolute;inset:0;z-index:1;background:radial-gradient(ellipse 55% 45% at 60% 35%,rgba(120,160,200,.6),transparent 70%),radial-gradient(ellipse 50% 55% at 35% 60%,rgba(80,100,160,.5),transparent 65%),linear-gradient(155deg,#0f1020,#1a1d3a 40%,#2a2f5a,#0f1020)}.phone-camera{position:absolute;top:10px;left:50%;transform:translate(-50%);width:11px;height:11px;border-radius:50%;background:#050505;z-index:30;box-shadow:inset 0 0 2px #1e1e3c99,0 0 0 .5px #ffffff0a}.phone-status{position:relative;z-index:10;display:flex;justify-content:space-between;align-items:center;padding:4px 16px 0;height:28px}.phone-time{font-family:Roboto,sans-serif;font-size:.62rem;font-weight:600;color:#ffffffeb}.phone-status-icons{display:flex;gap:3px}.phone-dot{width:3px;height:3px;border-radius:50%;background:#ffffffb3}.phone-notif-stack{position:relative;z-index:10;margin:38px 9px 0;display:flex;flex-direction:column;gap:8px}.phone-notif{background:#12101ab8;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-radius:18px;padding:12px 14px;animation:phoneNotifIn .45s ease-out both}@keyframes phoneNotifIn{0%{opacity:0;transform:translateY(14px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.phone-notif-header{display:flex;align-items:center;gap:6px;margin-bottom:5px}.phone-notif-icon{width:18px;height:18px;border-radius:5px;background:#3b82f6;display:grid;place-items:center;flex-shrink:0}.phone-notif-icon svg{display:block}.phone-notif-app{font-family:Roboto,sans-serif;font-size:.5rem;color:#ffffff73}.phone-notif-when{font-family:Roboto,sans-serif;font-size:.46rem;color:#ffffff47;margin-left:auto}.phone-notif-title{font-family:Roboto,sans-serif;font-size:.62rem;font-weight:600;color:#ffffffeb;margin-bottom:2px}.phone-notif-body{font-family:Roboto,sans-serif;font-size:.52rem;color:#ffffff85;line-height:1.45}.phone-home-bar{position:absolute;bottom:5px;left:50%;transform:translate(-50%);width:88px;height:3.5px;background:#ffffff59;border-radius:2px;z-index:10}.phone-stage{position:relative;min-height:700vh;contain:layout paint}@media(min-width:768px){.phone{width:min(36vh,65vw);aspect-ratio:256 / 537;height:auto}.phone-notif{padding:20px 22px;border-radius:26px}.phone-notif-icon{width:32px;height:32px;border-radius:9px}.phone-notif-icon svg{width:20px;height:20px}.phone-notif-app{font-size:.9rem}.phone-notif-when{font-size:.8rem}.phone-notif-title{font-size:1.1rem;margin-bottom:6px}.phone-notif-body{font-size:.95rem;line-height:1.5}.phone-notif-stack{margin:60px 14px 0;gap:14px}.phone-time{font-size:1rem}}@media(min-width:1024px){.phone{width:min(36vh,85vw);aspect-ratio:256 / 537;height:auto}.phone-notif{padding:20px 22px;border-radius:24px}.phone-notif-icon{width:32px;height:32px;border-radius:9px}.phone-notif-icon svg{width:20px;height:20px}.phone-notif-app{font-size:.85rem}.phone-notif-when{font-size:.78rem}.phone-notif-title{font-size:1.08rem;margin-bottom:5px}.phone-notif-body{font-size:.95rem;line-height:1.5}.phone-notif-stack{margin:58px 14px 0;gap:12px}.phone-time{font-size:.95rem}}.svc-slider-section{position:relative;height:100vh;background:var(--c-bg-dark);overflow:hidden;user-select:none;touch-action:pan-y}.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}.svc-slider-gl{position:absolute;inset:0;z-index:1;pointer-events:none;contain:strict;overflow:hidden}.svc-slider-gl canvas{display:block;width:100%;height:100%}.svc-slider-drag{position:absolute;inset:0;z-index:2;display:flex;align-items:center;padding:0 22.5vw;cursor:grab;contain:layout paint}.svc-slider-drag:active{cursor:grabbing}.svc-slider-inner{display:flex;position:relative}.svc-slide{overflow:hidden}.svc-slide:first-child{position:relative}.svc-slide:not(:first-child){position:absolute;top:0;height:100%}.svc-slide-inner{position:relative;width:65vw;height:70vh}.svc-slide img{display:none}.svc-titles{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);max-width:calc(100vw - 2 * var(--page-px));overflow:hidden;pointer-events:none;z-index:3;contain:layout paint}.svc-titles-list{position:absolute;top:0;left:0}.svc-title{display:flex;align-items:center;justify-content:center;font-family:Anta,sans-serif;font-size:clamp(3rem,10vw,7rem);font-weight:700;letter-spacing:-.02em;line-height:1.2;color:#fff;text-align:center;overflow-wrap:break-word;padding:0 .1em}.svc-titles-proxy{visibility:hidden}.svc-progress{position:absolute;bottom:0;left:0;width:100%;height:.25rem;overflow:hidden;pointer-events:none;z-index:4}.svc-progress-line,.svc-progress-line-2{position:absolute;top:0;left:0;width:100%;height:100%;transform:scaleX(0);transform-origin:left;background:#fff}.svc-progress-line-2{transform-origin:right}.svc-slider-hint{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);font-family:var(--f-sans);font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:#ffffff80;z-index:5;pointer-events:none}
