:root{--color-bg: #fdf8f9;--color-bg-alt: #f9f0f3;--color-text: #3d2a33;--color-text-muted: #6b5660;--color-accent: #c77d8e;--color-accent-dark: #a65d6e;--color-gold: #d4a5af;--color-border: #e8d5da;--color-highlight: #f0d8dd;--font-serif: "Shippori Mincho", "Noto Serif JP", serif;--font-body: "Noto Serif JP", serif}body{font-family:Shippori Mincho,"Noto Serif JP",Yu Mincho,YuMincho,Hiragino Mincho ProN,MS PMincho,serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-body);background-color:var(--color-bg);color:var(--color-text);line-height:1.9;letter-spacing:.05em;-webkit-font-smoothing:antialiased}header{position:fixed;top:0;left:0;right:0;z-index:1000;background:#faf8f5f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--color-border);transition:transform .3s ease}nav{max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.logo{font-family:var(--font-serif);font-size:1.25rem;font-weight:600;color:var(--color-text);text-decoration:none;letter-spacing:.15em}.nav-links{display:flex;gap:2.5rem;list-style:none}.nav-links a{color:var(--color-text-muted);text-decoration:none;font-size:.875rem;letter-spacing:.1em;transition:color .3s ease;position:relative}.nav-links a:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--color-accent);transition:width .3s ease}.nav-links a:hover{color:var(--color-accent)}.nav-links a:hover:after{width:100%}.mobile-menu-btn{display:none;background:none;border:none;cursor:pointer;padding:.5rem}.mobile-menu-btn span{display:block;width:24px;height:2px;background:var(--color-text);margin:5px 0;transition:.3s}.hero{min-height:100vh;display:flex;align-items:flex-end;justify-content:center;position:relative;overflow:hidden;background:var(--color-bg)}.hero-bg{position:absolute;inset:0;z-index:1;display:flex;justify-content:center;background-color:#e6b3c9}.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center top;max-width:1042px;-webkit-mask-image:linear-gradient(to right,transparent 0%,black 5%,black 95%,transparent 100%);mask-image:linear-gradient(to right,transparent 0%,black 5%,black 95%,transparent 100%)}.hero-gradient{position:absolute;bottom:0;left:0;right:0;height:60%;background:linear-gradient(to bottom,transparent 0%,rgba(253,248,249,.3) 30%,rgba(253,248,249,.7) 50%,rgba(253,248,249,.95) 70%,var(--color-bg) 100%);z-index:2}.hero-content{position:relative;z-index:3;text-align:center;padding:2rem 2rem 4rem;max-width:900px;animation:fadeInUp 1s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.hero-title{font-family:var(--font-serif);font-size:clamp(2.5rem,6vw,4rem);font-weight:600;letter-spacing:.3em;margin-bottom:.5rem;color:var(--color-text);text-shadow:0 2px 20px rgba(255,255,255,.5);animation:fadeInUp 1s ease-out .2s backwards}.hero-title-reading{font-size:1rem;color:var(--color-text-muted);letter-spacing:.2em;margin-bottom:1.5rem;animation:fadeInUp 1s ease-out .3s backwards}.hero-subtitle{font-size:1.125rem;color:var(--color-accent);letter-spacing:.15em;margin-bottom:1.5rem;animation:fadeInUp 1s ease-out .4s backwards}.hero-description{font-size:1rem;color:var(--color-text-muted);max-width:600px;margin:0 auto 2rem;animation:fadeInUp 1s ease-out .5s backwards}.cta-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;animation:fadeInUp 1s ease-out .6s backwards}.btn{display:inline-block;padding:1rem 2.5rem;font-family:var(--font-body);font-size:.875rem;letter-spacing:.15em;text-decoration:none;border-radius:2px;transition:all .3s ease;cursor:pointer}.btn-primary{background:var(--color-accent);color:#fff;border:1px solid var(--color-accent)}.btn-primary:hover{background:var(--color-accent-dark);border-color:var(--color-accent-dark);transform:translateY(-2px);box-shadow:0 10px 30px #8b451333}.btn-secondary{background:transparent;color:var(--color-accent);border:1px solid var(--color-accent)}.btn-secondary:hover{background:var(--color-accent);color:#fff;transform:translateY(-2px)}section{padding:6rem 2rem}.section-inner{max-width:900px;margin:0 auto}.section-title{font-family:var(--font-serif);font-size:1.75rem;font-weight:500;letter-spacing:.2em;text-align:center;margin-bottom:1rem;color:var(--color-text)}.section-title-en{font-size:.75rem;color:var(--color-text-muted);letter-spacing:.3em;text-transform:uppercase;text-align:center;margin-bottom:3rem}.section-divider{width:60px;height:1px;background:var(--color-gold);margin:0 auto 3rem}.section-alt,#profile{background:var(--color-bg-alt)}.profile-content p{margin-bottom:1.5rem;text-align:justify}.profile-highlight{background:var(--color-bg);padding:2rem;border-left:3px solid var(--color-gold);margin:2rem 0}.profile-highlight-title{font-weight:600;color:var(--color-accent);margin-bottom:.5rem;letter-spacing:.1em}.career-list{list-style:none}.career-item{display:grid;grid-template-columns:120px 1fr;gap:1.5rem;padding:1.5rem 0;border-bottom:1px solid var(--color-border)}.career-item:last-child{border-bottom:none}.career-year{font-size:.875rem;color:var(--color-accent);font-weight:500;letter-spacing:.05em}.career-desc{color:var(--color-text)}#discography{background:var(--color-bg-alt)}.disc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.disc-item{background:var(--color-bg);padding:2rem;border:1px solid var(--color-border);transition:transform .3s ease,box-shadow .3s ease}.disc-item:hover{transform:translateY(-5px);box-shadow:0 15px 40px #2c24201a}.disc-title{font-family:var(--font-serif);font-size:1.25rem;font-weight:500;margin-bottom:.5rem;color:var(--color-text)}.disc-reading{font-size:.875rem;color:var(--color-text-muted);margin-bottom:1rem}.disc-artist{font-size:.875rem;color:var(--color-accent)}.lesson-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.lesson-card{background:var(--color-bg);padding:2.5rem;border:1px solid var(--color-border);text-align:center;transition:transform .3s ease,box-shadow .3s ease}.lesson-card:hover{transform:translateY(-5px);box-shadow:0 15px 40px #2c24201a}.lesson-icon{font-size:2.5rem;margin-bottom:1.5rem}.lesson-name{font-family:var(--font-serif);font-size:1.25rem;font-weight:500;margin-bottom:1rem;color:var(--color-text)}.lesson-desc{font-size:.9375rem;color:var(--color-text-muted);margin-bottom:1rem}.lesson-role{font-size:.875rem;color:var(--color-accent);font-weight:500}#contact{background:var(--color-bg-alt)}.contact-intro{text-align:center;margin-bottom:3rem;color:var(--color-text-muted)}.contact-form{max-width:600px;margin:0 auto;background:var(--color-bg);padding:3rem;border:1px solid var(--color-border)}.form-group{margin-bottom:1.5rem}.form-label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem;color:var(--color-text);letter-spacing:.1em}.form-label .required{color:#c53030;margin-left:.25rem}.form-input,.form-textarea,.form-select{width:100%;padding:.875rem 1rem;font-family:var(--font-body);font-size:1rem;border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);transition:border-color .3s ease,box-shadow .3s ease}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #8b45131a}.form-textarea{min-height:150px;resize:vertical}.form-submit{width:100%;padding:1.125rem;font-family:var(--font-body);font-size:1rem;font-weight:500;letter-spacing:.15em;background:var(--color-accent);color:#fff;border:none;cursor:pointer;transition:background .3s ease,transform .3s ease}.form-submit:hover{background:var(--color-accent-dark);transform:translateY(-2px)}.form-submit:disabled{background:var(--color-text-muted);cursor:not-allowed;transform:none}.form-message{margin-top:1rem;padding:1rem;text-align:center;font-size:.9375rem}.form-message.success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.form-message.error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}footer{background:var(--color-text);color:#ffffffb3;padding:3rem 2rem;text-align:center}.footer-name{font-family:var(--font-serif);font-size:1.25rem;color:#fff;letter-spacing:.2em;margin-bottom:1rem}.footer-desc{font-size:.875rem;margin-bottom:2rem;letter-spacing:.1em}.footer-copy{font-size:.75rem;letter-spacing:.1em}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.gallery-item{position:relative;aspect-ratio:1;overflow:hidden;background:var(--color-bg);border:1px solid var(--color-border);cursor:pointer;transition:transform .3s ease,box-shadow .3s ease}.gallery-item:hover{transform:scale(1.02);box-shadow:0 15px 40px #3d2a3326}.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.gallery-item:hover img{transform:scale(1.1)}.gallery-item .gallery-caption{position:absolute;bottom:0;left:0;right:0;padding:1rem;background:linear-gradient(transparent,#000000b3);color:#fff;font-size:.875rem;opacity:0;transition:opacity .3s ease}.gallery-item:hover .gallery-caption{opacity:1}.video-container{position:relative;width:100%;max-width:800px;margin:0 auto;aspect-ratio:16 / 9;background:#000;border:1px solid var(--color-border);overflow:hidden}.video-container iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.video-caption{text-align:center;margin-top:1rem;font-size:.9375rem;color:var(--color-text-muted)}.audio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.audio-card{background:var(--color-bg);border:1px solid var(--color-border);padding:2rem;transition:transform .3s ease,box-shadow .3s ease}.audio-card:hover{transform:translateY(-5px);box-shadow:0 15px 40px #3d2a331a}.audio-card-title{font-family:var(--font-serif);font-size:1.25rem;font-weight:500;margin-bottom:.5rem;color:var(--color-text)}.audio-card-desc{font-size:.875rem;color:var(--color-text-muted);margin-bottom:1.5rem}.audio-player{width:100%}.audio-player audio{width:100%;height:48px;border-radius:24px}audio::-webkit-media-controls-panel{background:var(--color-bg-alt)}audio::-webkit-media-controls-play-button,audio::-webkit-media-controls-mute-button{filter:hue-rotate(320deg)}.lightbox{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000f2;z-index:2000;display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.lightbox.active{display:flex;opacity:1}.lightbox img{max-width:90%;max-height:90%;object-fit:contain}.lightbox-close{position:absolute;top:2rem;right:2rem;width:48px;height:48px;background:transparent;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:50%;cursor:pointer;font-size:1.5rem;transition:all .3s ease}.lightbox-close:hover{background:#ffffff1a;border-color:#fff9}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;background:transparent;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:50%;cursor:pointer;font-size:1.25rem;transition:all .3s ease}.lightbox-nav:hover{background:#ffffff1a;border-color:#fff9}.lightbox-prev{left:2rem}.lightbox-next{right:2rem}.lightbox-caption{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);color:#fff;font-size:1rem;text-align:center}@media(max-width:768px){.nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:#faf8f5fa;flex-direction:column;padding:1.5rem 2rem;gap:1.5rem;border-bottom:1px solid var(--color-border)}.nav-links.active{display:flex}.mobile-menu-btn{display:block}.hero-image{width:200px;height:200px}.career-item{grid-template-columns:1fr;gap:.5rem}.contact-form{padding:2rem 1.5rem}section{padding:5rem 1.5rem 2rem}.hero{min-height:110svh;position:relative}.hero-bg img{object-position:center top}.hero-gradient{height:70%}.hero-content{padding:0 1.5rem;width:100%}}.fade-in{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}.fade-in.visible{opacity:1;transform:translateY(0)}
