@import"https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;500;600;700&family=Zen+Kaku+Gothic+New:wght@300;400;500;700&display=swap";:root{--color-bg: #faf9f7;--color-bg-warm: #f5f3ef;--color-bg-card: #ffffff;--color-text: #1a1a1a;--color-text-secondary: #5c5c5c;--color-text-muted: #8a8a8a;--color-accent: #c23a3a;--color-accent-hover: #a62e2e;--color-border: #e8e6e1;--color-border-light: #f0eeea;--font-serif: "Noto Serif JP", "Yu Mincho", serif;--font-sans: "Zen Kaku Gothic New", "Hiragino Sans", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 2.75rem;--font-size-5xl: 3.5rem;--font-size-6xl: 4.5rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--space-32: 8rem;--radius-sm: 2px;--radius-md: 4px;--radius-lg: 8px;--radius-xl: 12px;--transition-fast: .15s ease;--transition-base: .3s ease;--transition-slow: .5s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);font-size:var(--font-size-base);font-weight:400;line-height:1.8;color:var(--color-text);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;letter-spacing:.02em}#root{min-height:100vh;display:flex;flex-direction:column}::selection{background:var(--color-accent);color:#fff}h1,h2,h3,h4,h5,h6{font-family:var(--font-serif);font-weight:500;line-height:1.4;color:var(--color-text);letter-spacing:.04em}h1{font-size:var(--font-size-5xl)}h2{font-size:var(--font-size-4xl)}h3{font-size:var(--font-size-3xl)}h4{font-size:var(--font-size-2xl)}h5{font-size:var(--font-size-xl)}h6{font-size:var(--font-size-lg)}p{color:var(--color-text-secondary);margin-bottom:var(--space-4)}a{color:var(--color-text);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent)}.container{width:100%;max-width:1140px;margin:0 auto;padding:0 var(--space-6)}.section{padding:var(--space-24) 0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-4) var(--space-8);font-family:var(--font-sans);font-size:var(--font-size-sm);font-weight:500;letter-spacing:.05em;border:none;cursor:pointer;transition:all var(--transition-base);text-decoration:none}.btn-primary{background:var(--color-text);color:var(--color-bg);border:1px solid var(--color-text)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #1a1a1a4d;color:var(--color-bg)}.btn-outline{background:transparent;color:var(--color-text);border:1px solid var(--color-text)}.btn-outline:hover{transform:translateY(-2px);box-shadow:0 6px 20px #1a1a1a26;color:var(--color-text)}.card{background:var(--color-bg-card);border:1px solid var(--color-border);padding:var(--space-8);transition:all var(--transition-base)}.card:hover{border-color:var(--color-text)}.section-header{margin-bottom:var(--space-16)}.section-label{display:inline-block;font-family:var(--font-sans);font-size:var(--font-size-xs);font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:var(--space-4);position:relative;padding-left:var(--space-8)}.section-label:before{content:"";position:absolute;left:0;top:50%;width:24px;height:1px;background:var(--color-accent)}.section-title{font-size:var(--font-size-3xl);margin-bottom:var(--space-4)}.section-subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary);max-width:480px}.page-hero{padding:var(--space-32) 0 var(--space-16);text-align:center}.page-title{font-size:var(--font-size-4xl);margin-bottom:var(--space-4)}.page-subtitle{font-size:var(--font-size-lg);color:var(--color-text-secondary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes expandWidth{0%{width:0}to{width:100%}}.animate-fade-in{animation:fadeIn .8s cubic-bezier(.4,0,.2,1) forwards;opacity:0}.animate-delay-1{animation-delay:.1s}.animate-delay-2{animation-delay:.2s}.animate-delay-3{animation-delay:.3s}.animate-delay-4{animation-delay:.4s}.text-accent{color:var(--color-accent)}.font-serif{font-family:var(--font-serif)}@media(max-width:768px){html{font-size:15px}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}.container{padding:0 var(--space-5)}.section{padding:var(--space-16) 0}.page-hero{padding:var(--space-20) 0 var(--space-12)}}.header{position:fixed;top:0;left:0;right:0;z-index:100;background:#faf9f7e6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.header-inner{display:flex;align-items:center;justify-content:space-between;height:80px}.logo{font-family:var(--font-serif);font-size:var(--font-size-xl);font-weight:500;letter-spacing:.08em;text-decoration:none;display:flex;gap:0;transition:opacity var(--transition-fast)}.logo:hover{opacity:.7}.logo-text{color:var(--color-text)}.logo-accent{color:var(--color-accent)}.nav{display:flex;align-items:center;gap:var(--space-10)}.nav-link{font-family:var(--font-sans);font-size:var(--font-size-sm);font-weight:400;letter-spacing:.08em;color:var(--color-text-secondary);text-decoration:none;padding:var(--space-2) 0;position:relative;transition:color var(--transition-fast)}.nav-link:after{content:"";position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--color-accent);transition:width var(--transition-base)}.nav-link:hover,.nav-link.active{color:var(--color-text)}.nav-link.active:after{width:100%}@media(max-width:768px){.header-inner{height:64px}.nav{gap:var(--space-6)}.nav-link{font-size:var(--font-size-xs)}}.footer{background:var(--color-text);color:var(--color-bg);margin-top:auto;padding:var(--space-16) 0 var(--space-8)}.footer-inner{display:flex;justify-content:space-between;gap:var(--space-16);padding-bottom:var(--space-12);border-bottom:1px solid rgba(255,255,255,.1)}.footer-brand{max-width:280px}.footer-logo{font-family:var(--font-serif);font-size:var(--font-size-xl);font-weight:500;letter-spacing:.08em;color:var(--color-bg);text-decoration:none;display:inline-block;margin-bottom:var(--space-4);transition:opacity var(--transition-fast)}.footer-logo:hover{opacity:.7;color:var(--color-bg)}.footer-logo .text-accent{color:var(--color-accent)}.footer-tagline{font-size:var(--font-size-sm);line-height:1.8;color:#fff9;margin-bottom:0}.footer-links{display:flex;gap:var(--space-16)}.footer-column-title{font-family:var(--font-sans);font-size:var(--font-size-xs);font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:#fff6;margin-bottom:var(--space-4)}.footer-nav{display:flex;flex-direction:column;gap:var(--space-2)}.footer-nav a,.footer-contact a{font-size:var(--font-size-sm);color:#ffffffb3;text-decoration:none;transition:color var(--transition-fast)}.footer-nav a:hover,.footer-contact a:hover{color:var(--color-bg)}.footer-bottom{padding-top:var(--space-8)}.footer-bottom p{font-size:var(--font-size-xs);color:#fff6;text-align:center;margin-bottom:0}@media(max-width:768px){.footer-inner{flex-direction:column;gap:var(--space-10)}.footer-brand{max-width:none}.footer-links{flex-direction:column;gap:var(--space-8)}}.layout{min-height:100vh;display:flex;flex-direction:column}.main{flex:1;padding-top:80px}@media(max-width:768px){.main{padding-top:64px}}.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding-top:80px;position:relative;overflow:hidden}.hero-container{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-16);align-items:center}.hero-content{max-width:560px}.hero-label{font-family:var(--font-sans);font-size:var(--font-size-xs);font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:var(--space-6)}.hero-title{font-size:clamp(2.5rem,5vw,3.5rem);font-weight:500;line-height:1.3;margin-bottom:var(--space-8);letter-spacing:.04em}.hero-description{font-size:var(--font-size-base);line-height:2;color:var(--color-text-secondary);margin-bottom:var(--space-10)}.hero-actions{display:flex;gap:var(--space-4)}.hero-visual{display:flex;align-items:center;justify-content:center;position:relative}.hero-visual-text{font-family:var(--font-serif);font-size:clamp(4rem,12vw,10rem);font-weight:500;letter-spacing:.02em;color:var(--color-border);display:flex;flex-direction:column;line-height:.9;-webkit-user-select:none;user-select:none}.hero-visual-text .text-accent{color:#c23a3a26}.hero-scroll{position:absolute;bottom:var(--space-8);left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.hero-scroll span{font-size:var(--font-size-xs);letter-spacing:.15em;text-transform:uppercase;color:var(--color-text-muted)}.scroll-line{width:1px;height:48px;background:linear-gradient(to bottom,var(--color-text-muted),transparent);animation:scrollPulse 2s ease-in-out infinite}@keyframes scrollPulse{0%,to{opacity:.3;transform:scaleY(.5);transform-origin:top}50%{opacity:1;transform:scaleY(1)}}.services{background:var(--color-bg-warm)}.services-list{display:flex;flex-direction:column;gap:0}.service-item{display:grid;grid-template-columns:80px 1fr;gap:var(--space-8);padding:var(--space-10) 0;border-bottom:1px solid var(--color-border);transition:all var(--transition-base)}.service-item:first-child{border-top:1px solid var(--color-border)}.service-item:hover{padding-left:var(--space-4)}.service-number{font-family:var(--font-serif);font-size:var(--font-size-2xl);font-weight:400;color:var(--color-accent);letter-spacing:.05em}.service-content{max-width:600px}.service-title{font-size:var(--font-size-xl);font-weight:500;margin-bottom:var(--space-3)}.service-description{font-size:var(--font-size-sm);line-height:1.9;color:var(--color-text-secondary);margin-bottom:0}.works-preview{padding-bottom:var(--space-16)}.works-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}.work-card{cursor:pointer;transition:all var(--transition-base)}.work-card:hover .work-image{transform:scale(1.05)}.work-image-wrapper{aspect-ratio:4 / 3;overflow:hidden;background:var(--color-bg-warm);margin-bottom:var(--space-4)}.work-image{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.work-info{padding:0 var(--space-2)}.work-category{font-size:var(--font-size-xs);font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--color-accent);display:block;margin-bottom:var(--space-2)}.work-title{font-size:var(--font-size-lg);font-weight:500}.works-cta{text-align:center;margin-top:var(--space-16)}.cta{background:var(--color-bg-warm);padding:var(--space-32) 0}.cta-content{max-width:600px;margin:0 auto;text-align:center}.cta-content .section-label{padding-left:0}.cta-content .section-label:before{display:none}.cta-title{font-size:var(--font-size-3xl);margin-bottom:var(--space-6)}.cta-description{font-size:var(--font-size-base);line-height:2;color:var(--color-text-secondary);margin-bottom:var(--space-10)}@media(max-width:1024px){.works-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.hero{min-height:auto;padding:var(--space-32) 0 var(--space-16)}.hero-container{grid-template-columns:1fr;gap:var(--space-12)}.hero-visual{order:-1}.hero-visual-text{font-size:4rem;flex-direction:row;gap:var(--space-2)}.hero-description br{display:none}.hero-actions{flex-direction:column}.hero-actions .btn{width:100%;justify-content:center}.hero-scroll{display:none}.service-item{grid-template-columns:1fr;gap:var(--space-4)}.works-grid{grid-template-columns:1fr;gap:var(--space-10)}.cta-title br{display:none}}.about-story-section{background:var(--color-bg-warm)}.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-16);align-items:center}.about-visual{display:flex;align-items:center;justify-content:center}.about-visual-inner{aspect-ratio:1;width:100%;max-width:400px;background:var(--color-bg-card);border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center}.about-logo-text{font-family:var(--font-serif);font-size:clamp(2rem,5vw,3rem);font-weight:500;letter-spacing:.04em;color:var(--color-text)}.about-content{max-width:520px}.about-heading{font-size:var(--font-size-2xl);margin-bottom:var(--space-6);position:relative;padding-bottom:var(--space-4)}.about-heading:after{content:"";position:absolute;bottom:0;left:0;width:40px;height:2px;background:var(--color-accent)}.about-lead{margin-bottom:var(--space-6)}.about-lead strong{font-family:var(--font-serif);font-size:var(--font-size-xl);font-weight:500;color:var(--color-text)}.about-content p{font-size:var(--font-size-base);line-height:2;color:var(--color-text-secondary)}.skills-section{padding-bottom:var(--space-32)}.skills-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-6)}.skill-card{background:var(--color-bg-card);border:1px solid var(--color-border);padding:var(--space-8);transition:all var(--transition-base)}.skill-card:hover{border-color:var(--color-text)}.skill-category{font-family:var(--font-sans);font-size:var(--font-size-xs);font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--color-accent);margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border)}.skill-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-3)}.skill-item{font-size:var(--font-size-sm);color:var(--color-text-secondary);transition:color var(--transition-fast)}.skill-card:hover .skill-item{color:var(--color-text)}@media(max-width:1024px){.skills-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.about-grid{grid-template-columns:1fr;gap:var(--space-10)}.about-visual{order:-1}.about-visual-inner{aspect-ratio:16 / 9;max-width:none}.skills-grid{grid-template-columns:1fr;gap:var(--space-4)}}.works-list-section{padding-bottom:var(--space-32)}.works-list{display:flex;flex-direction:column;gap:var(--space-16)}.work-item{display:grid;grid-template-columns:1.2fr 1fr;gap:var(--space-12);align-items:center;padding:var(--space-8);background:var(--color-bg-card);border:1px solid var(--color-border);transition:all var(--transition-base)}.work-item:hover{border-color:var(--color-text)}.work-item:hover .work-item-image{transform:scale(1.03)}.work-item:nth-child(2n){direction:rtl}.work-item:nth-child(2n)>*{direction:ltr}.work-item-image-wrapper{aspect-ratio:16 / 10;overflow:hidden;background:var(--color-bg-warm)}.work-item-image{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.work-item-content{padding:var(--space-4)}.work-item-category{display:inline-block;font-size:var(--font-size-xs);font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--color-accent);margin-bottom:var(--space-4)}.work-item-title{font-size:var(--font-size-2xl);font-weight:500;margin-bottom:var(--space-4)}.work-item-description{font-size:var(--font-size-sm);line-height:1.9;color:var(--color-text-secondary);margin-bottom:var(--space-6)}.work-item-tech{display:flex;flex-wrap:wrap;gap:var(--space-2)}.tech-tag{font-size:var(--font-size-xs);font-weight:500;letter-spacing:.05em;color:var(--color-text-secondary);background:var(--color-bg-warm);padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);transition:all var(--transition-fast)}.work-item:hover .tech-tag{border-color:var(--color-text-muted)}@media(max-width:768px){.work-item{grid-template-columns:1fr;gap:var(--space-6)}.work-item:nth-child(2n){direction:ltr}.work-item-content{padding:var(--space-2)}}.contact-section{padding-bottom:var(--space-32)}.contact-notice{display:flex;gap:var(--space-6);align-items:flex-start;background:var(--color-bg-warm);border:1px solid var(--color-border);padding:var(--space-8);margin-bottom:var(--space-12)}.notice-badge{flex-shrink:0;font-size:var(--font-size-xs);font-weight:500;letter-spacing:.1em;color:#fff;background:var(--color-accent);padding:var(--space-2) var(--space-4)}.notice-content h3{font-family:var(--font-sans);font-size:var(--font-size-base);font-weight:500;color:var(--color-text);margin-bottom:var(--space-2)}.notice-content p{font-size:var(--font-size-sm);line-height:1.8;color:var(--color-text-secondary);margin-bottom:0}.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:var(--space-16);align-items:start}.contact-grid.disabled{opacity:.5;pointer-events:none}.contact-info-title{font-size:var(--font-size-3xl);line-height:1.4;margin-bottom:var(--space-6)}.contact-info-description{font-size:var(--font-size-base);line-height:1.9;color:var(--color-text-secondary);margin-bottom:var(--space-10)}.contact-methods{display:flex;flex-direction:column;gap:var(--space-6)}.contact-method{display:flex;flex-direction:column;gap:var(--space-1)}.method-label{font-size:var(--font-size-xs);font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--color-text-muted)}.method-value{font-size:var(--font-size-base);color:var(--color-text)}a.method-value:hover{color:var(--color-accent)}.contact-form{background:var(--color-bg-card);border:1px solid var(--color-border);padding:var(--space-10)}.form-group{margin-bottom:var(--space-6)}.form-group label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text);margin-bottom:var(--space-2)}.form-group input,.form-group textarea{width:100%;padding:var(--space-4);font-family:var(--font-sans);font-size:var(--font-size-base);color:var(--color-text);background:var(--color-bg);border:1px solid var(--color-border);transition:border-color var(--transition-fast)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--color-text-muted)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-text)}.form-group textarea{resize:vertical;min-height:140px}.submit-btn{width:100%;padding:var(--space-4) var(--space-8);margin-top:var(--space-4)}.submit-btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.contact-notice{flex-direction:column;gap:var(--space-4)}.contact-grid{grid-template-columns:1fr;gap:var(--space-10)}.contact-form{padding:var(--space-6)}}
