
[x-cloak]{display:none!important}
*{margin:0;padding:0;box-sizing:border-box}
html{background:#06060e;scroll-behavior:smooth}
body{font-family:'Noto Sans JP',sans-serif;color:#fff;background:#06060e}

/* Cursor */
.cursor-dot{width:10px;height:10px;background:#1E90FF;border-radius:50%;mix-blend-mode:difference;transition:transform .2s cubic-bezier(.23,1,.32,1)}
.cursor-ring{width:40px;height:40px;border:1px solid rgba(30,144,255,.5);border-radius:50%;transition:all .3s cubic-bezier(.23,1,.32,1)}
.cursor-dot.hover{transform:scale(0)}
.cursor-ring.hover{width:80px;height:80px;border-color:#1E90FF;background:rgba(30,144,255,.08)}

/* Nav */
.nav-link .nav-ja{opacity:0;transition:opacity .3s ease}
.nav-link .nav-en{transition:opacity .3s ease}
.nav-link:hover .nav-ja{opacity:1}
.nav-link:hover .nav-en{opacity:0}

/* Scroll reveal */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .8s ease,transform .8s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.15s}
.reveal-delay-2{transition-delay:.3s}
.reveal-delay-3{transition-delay:.45s}
/* Slide from left (photos) */
.reveal-left{opacity:0;transform:translateX(-50px);transition:opacity .9s ease,transform .9s cubic-bezier(.25,.46,.45,.94)}
.reveal-left.visible{opacity:1;transform:translateX(0)}
/* Slide from right (photos) */
.reveal-right{opacity:0;transform:translateX(50px);transition:opacity .9s ease,transform .9s cubic-bezier(.25,.46,.45,.94)}
.reveal-right.visible{opacity:1;transform:translateX(0)}
/* Scale up (stats/numbers) */
.reveal-scale{opacity:0;transform:scale(.85);transition:opacity .7s ease,transform .7s cubic-bezier(.25,.46,.45,.94)}
.reveal-scale.visible{opacity:1;transform:scale(1)}
/* Tracking collapse (section headers) */
.reveal-tracking{opacity:0;letter-spacing:.4em;transition:opacity .9s ease,letter-spacing 1s cubic-bezier(.25,.46,.45,.94)}
.reveal-tracking.visible{opacity:1;letter-spacing:normal}

/* Interview card */
.interview-card{position:relative;overflow:hidden}
.interview-card .card-photo{filter:grayscale(1);transition:filter .8s cubic-bezier(.25,.46,.45,.94)}
.interview-card:hover .card-photo{filter:grayscale(0)}
.interview-card .card-overlay{transition:opacity .6s ease}
.interview-card:hover .card-overlay{opacity:1}

/* Individual portrait */
.portrait{position:relative;overflow:hidden}
.portrait .portrait-img{filter:grayscale(1);transition:filter .8s cubic-bezier(.25,.46,.45,.94)}
.portrait:hover .portrait-img{filter:grayscale(0)}

/* Divider line animation */
.divider-line{width:0;transition:width 1.2s cubic-bezier(.25,.46,.45,.94)}
.divider-line.visible{width:100%}

/* Quote mark */
.quote-mark{font-size:calc(120/16*1rem);line-height:0.6;color:rgba(30,144,255,.12);font-family:'Instrument Serif',serif;font-style:italic}

/* Background grain */
.bg-grain::after{content:'';position:absolute;inset:0;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='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");pointer-events:none;z-index:1}
