:root{--color-bg: #111129;--color-bg-secondary: #1a1a3e;--color-bg-tertiary: #222254;--color-accent: #dcc25b;--color-accent-hover: #e8d06f;--color-accent-glow: rgba(220, 194, 91, .3);--color-text: #ffffff;--color-text-secondary: rgba(255, 255, 255, .7);--color-text-muted: rgba(255, 255, 255, .4);--color-border: rgba(255, 255, 255, .1);--color-glass: rgba(17, 17, 41, .75);--color-glass-border: rgba(220, 194, 91, .15);--color-overlay: rgba(17, 17, 41, .6);--font-primary: "Noto Sans JP", sans-serif;--font-weight-light: 300;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-bold: 700;--font-weight-black: 900;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 2rem;--space-xl: 3rem;--space-2xl: 5rem;--space-3xl: 8rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 16px;--radius-xl: 24px;--transition-fast: .2s cubic-bezier(.4, 0, .2, 1);--transition-normal: .3s cubic-bezier(.4, 0, .2, 1);--transition-slow: .5s cubic-bezier(.4, 0, .2, 1);--z-background: -1;--z-content: 1;--z-navbar: 100;--z-overlay: 200}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-primary);font-weight:var(--font-weight-regular);color:var(--color-text);background-color:var(--color-bg);line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto;display:block}ul,ol{list-style:none}button{cursor:pointer;border:none;background:none;font-family:inherit;color:inherit}input,textarea{font-family:inherit;color:inherit}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-accent);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-accent-hover)}::selection{background:var(--color-accent);color:var(--color-bg)}.container{max-width:1200px;margin:0 auto;padding:0 var(--space-lg)}.section-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:var(--font-weight-black);letter-spacing:.05em;margin-bottom:var(--space-xl);position:relative}.section-title:after{content:"";display:block;width:60px;height:3px;background:var(--color-accent);margin-top:var(--space-sm)}.accent-text{color:var(--color-accent)}.glass-card{background:var(--color-glass);border:1px solid var(--color-glass-border);border-radius:var(--radius-lg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.page-wrapper{min-height:100vh;position:relative}.canvas-container{position:fixed;top:0;left:0;width:100%;height:100%;z-index:var(--z-background);pointer-events:none}#root{min-height:100vh}.navbar{position:fixed;top:0;left:0;width:100%;z-index:var(--z-navbar);background:#111129d9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--color-border)}.navbar-inner{max-width:1200px;margin:0 auto;padding:0 var(--space-lg);display:flex;justify-content:space-between;align-items:center;height:70px}.navbar-logo{display:flex;align-items:center;gap:var(--space-sm)}.logo-text{font-size:1.3rem;font-weight:var(--font-weight-bold);color:var(--color-accent);letter-spacing:.1em}.navbar-links{display:flex;gap:var(--space-xl)}.nav-link{position:relative;font-size:.9rem;font-weight:var(--font-weight-medium);letter-spacing:.15em;text-transform:uppercase;padding:var(--space-sm) 0;color:var(--color-text-secondary);transition:color var(--transition-fast)}.nav-link:hover,.nav-link.active{color:var(--color-text)}.nav-indicator{position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--color-accent);border-radius:1px}.hamburger{display:none;flex-direction:column;gap:5px;padding:var(--space-sm);cursor:pointer}.hamburger-line{display:block;width:24px;height:2px;background:var(--color-text);transition:var(--transition-normal);transform-origin:center}.hamburger.is-open .hamburger-line:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger.is-open .hamburger-line:nth-child(2){opacity:0}.hamburger.is-open .hamburger-line:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.mobile-menu{display:none;flex-direction:column;padding:var(--space-lg);gap:var(--space-md);background:#111129f2;border-bottom:1px solid var(--color-border)}.mobile-link{font-size:1.1rem;font-weight:var(--font-weight-medium);letter-spacing:.1em;text-transform:uppercase;padding:var(--space-md) 0;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);transition:color var(--transition-fast)}.mobile-link:hover,.mobile-link.active{color:var(--color-accent)}@media(max-width:768px){.navbar-links{display:none}.hamburger,.mobile-menu{display:flex}}*,*:before,*:after{cursor:none!important}.custom-cursor.hidden{opacity:0!important;pointer-events:none}.custom-cursor{position:fixed;width:20px;height:20px;pointer-events:none;z-index:10000;transform:translate(-2px,-1px);transition:transform .1s ease-out,filter .2s ease;filter:drop-shadow(0 1px 3px rgba(0,0,0,.35))}.custom-cursor svg{width:100%;height:100%}.custom-cursor.hovering{transform:translate(-2px,-1px) scale(1.15);filter:drop-shadow(0 0 8px rgba(220,194,91,.5))}.custom-cursor.hovering svg path{fill:var(--color-accent)}.cursor-ring{display:none}.cursor-ripple{position:fixed;width:10px;height:10px;border-radius:50%;border:1.5px solid rgba(255,255,255,.6);pointer-events:none;z-index:9998;transform:translate(-50%,-50%) scale(0);animation:rippleExpand .7s ease-out forwards}@keyframes rippleExpand{0%{transform:translate(-50%,-50%) scale(0);opacity:1;border-width:2px}50%{opacity:.5}to{transform:translate(-50%,-50%) scale(8);opacity:0;border-width:.5px}}@media(hover:none)and (pointer:coarse){.custom-cursor,.cursor-ring,.cursor-ripple{display:none!important}*,*:before,*:after{cursor:auto!important}}.scroll-container{height:100vh;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.scroll-container::-webkit-scrollbar{display:none}.scroll-section{height:100vh}.hero-section{position:relative;height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}.hero-bg{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0}.hero-bg-image{width:100%;height:100%;object-fit:cover;filter:blur(12px) brightness(.4);transform:scale(1.1)}.hero-bg-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at center,#1111294d,#111129bf 60%,#111129f2)}.hero-bg:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:200px;background:linear-gradient(to bottom,#11112900,#111129);z-index:1}.hero-content{position:relative;z-index:1;text-align:left;padding:0 var(--space-lg);max-width:900px;width:100%}.hero-title{font-size:clamp(4rem,15vw,10rem);font-weight:var(--font-weight-black);letter-spacing:.05em;line-height:1;color:var(--color-text);text-shadow:0 0 80px rgba(220,194,91,.3);margin-bottom:var(--space-sm)}.hero-subtitle{font-size:clamp(1rem,2.5vw,1.5rem);font-weight:var(--font-weight-light);color:var(--color-text-secondary);letter-spacing:.3em;margin-bottom:var(--space-xl)}.hero-social{display:flex;flex-direction:column;gap:var(--space-md);align-items:flex-start}.social-link{display:flex;align-items:center;gap:var(--space-md);font-size:1rem;color:var(--color-text-secondary);transition:all var(--transition-normal);padding:var(--space-sm) 0}.social-link:hover{color:var(--color-accent);transform:translate(8px)}.social-icon{font-size:1.4rem;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--color-border);border-radius:50%;transition:all var(--transition-normal)}.social-link:hover .social-icon{border-color:var(--color-accent);background:#dcc25b1a;box-shadow:0 0 20px #dcc25b33}.social-label{font-weight:var(--font-weight-medium);letter-spacing:.05em}.scroll-indicator{position:absolute;bottom:40px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:var(--space-sm)}.scroll-text{font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--color-text-muted)}.scroll-line{width:1px;height:60px;background:var(--color-border);position:relative;overflow:hidden}.scroll-line-inner{width:100%;height:30px;background:var(--color-accent);animation:scrollDown 2s ease-in-out infinite}@keyframes scrollDown{0%{transform:translateY(-100%)}to{transform:translateY(200%)}}.profile-section{padding:var(--space-3xl) 0;min-height:100vh;display:flex;align-items:center}.profile-container{padding:var(--space-2xl)}.profile-content{margin-bottom:var(--space-2xl)}.profile-info{max-width:700px}.profile-name{font-size:1.8rem;font-weight:var(--font-weight-bold);color:var(--color-accent);margin-bottom:var(--space-md);letter-spacing:.05em}.profile-description{font-size:1.05rem;line-height:2;color:var(--color-text-secondary)}.tools-title{font-size:1.2rem;font-weight:var(--font-weight-bold);letter-spacing:.1em;margin-bottom:var(--space-lg);color:var(--color-text)}.tools-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md)}.tool-item{display:flex;align-items:center;gap:var(--space-sm);font-size:.95rem;color:var(--color-text-secondary);padding:var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-normal)}.tool-item:hover{border-color:var(--color-accent);background:#dcc25b0d}.tool-dot{width:6px;height:6px;border-radius:50%;background:var(--color-accent);flex-shrink:0}@media(max-width:768px){.hero-content{text-align:left}.hero-title{font-size:clamp(3rem,12vw,5rem)}.profile-container{padding:var(--space-lg)}.tools-grid{grid-template-columns:1fr}}.works-page{padding-top:120px;padding-bottom:var(--space-3xl)}.works-header{margin-bottom:var(--space-2xl)}.works-description{font-size:1.05rem;color:var(--color-text-secondary);letter-spacing:.1em}.works-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg)}.work-card{display:flex;flex-direction:column;border-radius:var(--radius-lg);overflow:hidden;background:var(--color-bg-secondary);border:1px solid var(--color-border);transition:all var(--transition-normal);cursor:pointer;height:100%}.work-card:hover{transform:translateY(-8px) scale(1.02);border-color:var(--color-accent);box-shadow:0 20px 60px #0006,0 0 30px #dcc25b1a}.work-thumbnail{position:relative;aspect-ratio:16 / 9;overflow:hidden;background:var(--color-bg-tertiary);flex-shrink:0}.work-thumbnail.placeholder{display:flex;align-items:center;justify-content:center}.work-thumbnail.placeholder:after{content:"🎬";font-size:3rem;opacity:.3}.work-image{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform var(--transition-slow)}.work-card:hover .work-image{transform:scale(1.08)}.work-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#111129b3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-sm);opacity:0;transition:opacity var(--transition-normal)}.work-card:hover .work-overlay{opacity:1}.work-play-icon{font-size:2.5rem;color:var(--color-accent);text-shadow:0 0 20px rgba(220,194,91,.5)}.work-view-text{font-size:.8rem;color:var(--color-text-secondary);letter-spacing:.1em;text-transform:uppercase}.work-info{padding:var(--space-md) var(--space-lg);flex:1;display:flex;flex-direction:column;justify-content:center}.work-category{display:inline-block;font-size:.7rem;font-weight:var(--font-weight-medium);letter-spacing:.15em;text-transform:uppercase;color:var(--color-accent);margin-bottom:var(--space-xs)}.work-title{font-size:.85rem;font-weight:var(--font-weight-medium);color:var(--color-text);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}@media(max-width:1024px){.works-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.works-page{padding-top:100px}.works-grid{grid-template-columns:1fr;gap:var(--space-md)}}.contact-page{padding-top:120px;padding-bottom:var(--space-3xl);min-height:100vh}.contact-header{margin-bottom:var(--space-2xl)}.contact-description{font-size:1.05rem;color:var(--color-text-secondary);letter-spacing:.05em}.contact-content{max-width:700px;display:flex;flex-direction:column;gap:var(--space-xl)}.contact-email{display:flex;align-items:center;gap:var(--space-lg);padding:var(--space-lg) var(--space-xl)}.email-icon{font-size:1.8rem;color:var(--color-accent);display:flex;align-items:center;justify-content:center;width:60px;height:60px;border:1px solid var(--color-glass-border);border-radius:50%;flex-shrink:0;background:#dcc25b0d}.email-label{display:block;font-size:.75rem;font-weight:var(--font-weight-medium);letter-spacing:.15em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:var(--space-xs)}.email-address{font-size:1.1rem;font-weight:var(--font-weight-medium);color:var(--color-accent);transition:all var(--transition-fast)}.email-address:hover{text-shadow:0 0 10px rgba(220,194,91,.3)}.contact-form-wrapper{padding:var(--space-xl)}.contact-form{display:flex;flex-direction:column;gap:var(--space-lg)}.form-group{display:flex;flex-direction:column;gap:var(--space-sm)}.form-label{font-size:.85rem;font-weight:var(--font-weight-medium);letter-spacing:.05em;color:var(--color-text-secondary)}.required{color:var(--color-accent)}.form-input,.form-textarea{background:#ffffff0d;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md);font-size:.95rem;color:var(--color-text);outline:none;transition:all var(--transition-fast)}.form-input:focus,.form-textarea:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #dcc25b1a;background:#ffffff14}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-muted)}.form-textarea{resize:vertical;min-height:120px}.has-error .form-input,.has-error .form-textarea{border-color:#e74c3c}.form-error{font-size:.8rem;color:#e74c3c;display:flex;align-items:center;gap:var(--space-xs)}.form-submit{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);background:var(--color-accent);color:var(--color-bg);font-size:.95rem;font-weight:var(--font-weight-bold);letter-spacing:.05em;border-radius:var(--radius-md);transition:all var(--transition-normal);align-self:flex-start}.form-submit:hover{background:var(--color-accent-hover);transform:translateY(-2px);box-shadow:0 10px 30px #dcc25b4d}.form-submit:active{transform:translateY(0)}.form-success{text-align:center;padding:var(--space-2xl) var(--space-lg)}.success-icon{width:60px;height:60px;border-radius:50%;background:var(--color-accent);color:var(--color-bg);font-size:1.5rem;font-weight:var(--font-weight-bold);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-lg)}.form-success h3{font-size:1.3rem;margin-bottom:var(--space-sm);color:var(--color-text)}.form-success p{color:var(--color-text-secondary);margin-bottom:var(--space-lg)}.btn-reset{padding:var(--space-sm) var(--space-lg);border:1px solid var(--color-accent);border-radius:var(--radius-md);font-size:.85rem;font-weight:var(--font-weight-medium);color:var(--color-accent);transition:all var(--transition-normal)}.btn-reset:hover{background:var(--color-accent);color:var(--color-bg)}@media(max-width:768px){.contact-page{padding-top:100px}.contact-email{flex-direction:column;text-align:center;padding:var(--space-lg)}.contact-form-wrapper{padding:var(--space-lg)}}.app{position:relative;min-height:100vh}
