:root{--color-bg: #f0efeb;--color-surface: #ffffff;--color-text: #4a6275;--color-text-muted: #756f6a;--color-text-light: #9a9393;--color-border: #c7e4ca;--color-accent: #a793ac;--font-serif: "Georgia", "Times New Roman", serif;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--max-width: 1200px;--sidebar-width: 260px;--transition: all .4s cubic-bezier(.25, .46, .45, .94);--shadow: 0 1px 3px rgba(74, 98, 117, .06), 0 8px 24px rgba(74, 98, 117, .06)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}img{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none;transition:var(--transition)}a:hover{color:var(--color-accent)}.site-header{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background:var(--color-surface);border-right:1px solid var(--color-border);padding:3rem 2rem;display:flex;flex-direction:column;z-index:100;overflow-y:auto}.logo{font-family:var(--font-serif);font-size:1.5rem;font-weight:400;letter-spacing:.05em;text-transform:uppercase;margin-bottom:.25rem;color:var(--color-text)}.logo-sub{font-size:.75rem;color:var(--color-text-muted);letter-spacing:.1em;text-transform:uppercase;margin-bottom:3rem}.main-nav ul{list-style:none}.main-nav li{margin-bottom:.5rem}.main-nav a{display:block;padding:.3rem 0;font-size:.875rem;letter-spacing:.02em;color:var(--color-text-muted);border-bottom:1px solid transparent;transition:var(--transition)}.main-nav a:hover,.main-nav a[aria-current=page]{color:var(--color-text);border-bottom-color:var(--color-accent);padding-left:.5rem}.nav-section-title{font-size:.7rem;text-transform:uppercase;letter-spacing:.15em;color:var(--color-text-light);margin:2rem 0 .75rem}.external-link{margin-top:auto;padding-top:2rem;font-size:.8rem;color:var(--color-text-light)}.external-link a{border-bottom:1px solid var(--color-border)}.external-link a:hover{color:var(--color-accent);border-bottom-color:var(--color-accent)}.menu-toggle{display:none;position:fixed;top:1rem;right:1rem;z-index:200;width:48px;height:48px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:50%;cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:5px;box-shadow:var(--shadow)}.menu-toggle span{display:block;width:20px;height:1.5px;background:var(--color-text);transition:var(--transition)}.main-content{margin-left:var(--sidebar-width);min-height:100vh;display:flex;flex-direction:column}.page-section{flex:1;opacity:0;transform:translateY(20px);animation:fadeInUp .8s ease forwards}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}h1,h2,h3,h4{font-family:var(--font-serif);font-weight:400;line-height:1.2}h1{font-size:clamp(2rem,5vw,3.5rem);margin-bottom:1.5rem;letter-spacing:-.02em}h2{font-size:clamp(1.5rem,3vw,2.25rem);margin:3rem 0 1.5rem}h3{font-size:1.25rem;margin-bottom:.75rem;color:var(--color-text-muted)}p{margin-bottom:1.25rem;color:var(--color-text-muted);max-width:65ch}.lead{font-size:1.125rem;line-height:1.7;color:var(--color-text);max-width:60ch}.breadcrumb{display:flex;gap:.75rem;align-items:center;font-size:.8rem;color:var(--color-text-light);margin-bottom:2rem;text-transform:uppercase;letter-spacing:.05em;padding:6rem 4rem 0;max-width:var(--max-width);margin-left:var(--sidebar-width)}.breadcrumb a:hover{color:var(--color-accent)}.breadcrumb-separator{opacity:.4}.hero{padding:6rem 0 4rem;max-width:var(--max-width);margin-left:auto;margin-right:auto}.hero h1{font-size:clamp(2.5rem,6vw,4rem);line-height:1.1;margin-bottom:2rem}.hero h1 span{display:block;font-size:.5em;font-family:var(--font-sans);color:var(--color-text-muted);letter-spacing:.1em;text-transform:uppercase;margin-top:1rem;font-weight:400}.intro-text{padding:0 4rem 4rem;max-width:720px}.projects-grid{padding:0 0 6rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;max-width:var(--max-width);margin-left:auto;margin-right:auto}.project-card{position:relative;background:var(--color-surface);border-radius:2px;overflow:hidden;box-shadow:var(--shadow);transition:var(--transition)}.project-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #4a62751a}.project-card a{display:block}.project-card .thumb{aspect-ratio:4/3;background:var(--color-border);position:relative;overflow:hidden}.project-card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}.project-card:hover .thumb img{transform:scale(1.05)}.project-card .info{padding:1.5rem}.project-card h2{font-size:1.125rem;margin:0 0 .25rem;font-family:var(--font-serif)}.project-card .category{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-light)}.project-header{padding:6rem 4rem 2rem;max-width:800px}.banner-fade{width:100%;max-width:1240px;margin:0 auto;display:block;mask-image:linear-gradient(to bottom,#000 60%,#0000);-webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,1) 60%,rgba(0,0,0,0) 100%)}.project-header{position:relative;background-size:cover;background-position:center;overflow:hidden}.project-header.has-banner{max-width:none;padding:6rem 4rem 2rem}.banner-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.1;z-index:0}.banner-fade-bottom{position:absolute;bottom:0;left:0;width:100%;height:60%;background:linear-gradient(to bottom,transparent,var(--color-bg));pointer-events:none;z-index:1}.banner-fade-top{position:absolute;top:0;left:0;width:100%;height:40%;background:linear-gradient(to top,transparent,var(--color-bg));pointer-events:none;z-index:1}.project-header h1,.project-header .project-meta{position:relative;z-index:2}.header-banner{width:100%;max-width:1240px;margin:0 auto 2rem;border-radius:4px;overflow:hidden;aspect-ratio:1240 / 260}.header-banner img{width:100%;height:100%;object-fit:cover}.header-banner[data-position=top] img{object-position:top}.header-banner[data-position=center] img{object-position:center}.header-banner[data-position=bottom] img{object-position:bottom}.project-header h1{margin-bottom:.5rem}.project-meta{font-size:.875rem;color:var(--color-text-light);margin-bottom:2rem;text-transform:uppercase;letter-spacing:.05em}.project-description{padding:0 4rem;max-width:720px;margin-bottom:3rem}.project-description h2{margin-top:2.5rem;margin-bottom:1rem;font-size:1.5rem}.project-description ul,.project-description ol{margin-bottom:1.25rem;padding-left:1.5rem;color:var(--color-text-muted)}.project-description ul li{margin-bottom:.5rem}.gallery{padding:0 4rem 6rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;max-width:var(--max-width)}.gallery-item{position:relative;background:var(--color-border);border-radius:2px;overflow:hidden;aspect-ratio:3/2;opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}.gallery-item.visible{opacity:1;transform:translateY(0)}.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}.gallery-item:hover img{transform:scale(1.03)}.gallery-item figcaption{position:absolute;bottom:0;left:0;right:0;padding:1rem;background:linear-gradient(to top,rgba(74,98,117,.7),transparent);color:#f0efeb;font-size:.8rem;opacity:0;transition:opacity .4s ease}.gallery-item:hover figcaption{opacity:1}.video-section{padding:0 4rem 4rem;max-width:var(--max-width);margin-left:auto;margin-right:auto}.video-wrapper{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:4px;background:var(--color-border)}.video-wrapper iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.gallery-item[data-zoom]{cursor:zoom-in}.lightbox{display:none;position:fixed;inset:0;z-index:1000;background:#4a6275f2;backdrop-filter:blur(8px);align-items:center;justify-content:center;flex-direction:column;padding:2rem}.lightbox.active{display:flex}.lightbox-img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:2px;box-shadow:0 20px 60px #4a627566}.lightbox-caption{color:#fff;font-size:.9rem;margin-top:1rem;text-align:center;opacity:.8}.lightbox-close,.lightbox-prev,.lightbox-next{position:absolute;background:#f0efeb26;border:none;color:#f0efeb;cursor:pointer;width:48px;height:48px;border-radius:50%;font-size:1.5rem;display:flex;align-items:center;justify-content:center;transition:background .3s}.lightbox-close:hover,.lightbox-prev:hover,.lightbox-next:hover{background:#f0efeb4d}.lightbox-close{top:1rem;right:1rem;font-size:2rem}.lightbox-prev{left:1rem;top:50%;transform:translateY(-50%)}.lightbox-next{right:1rem;top:50%;transform:translateY(-50%)}.embed-section{padding:0 4rem 4rem;max-width:var(--max-width);margin-left:auto;margin-right:auto}.embed-wrapper{border-radius:4px;overflow:hidden;background:var(--color-surface);border:1px solid var(--color-border)}.embed-wrapper iframe{display:block;border:none;width:100%}.embed-source{margin-top:1rem;text-align:right}.embed-source a{color:var(--color-accent);font-size:.85rem}.embed-source a:hover{text-decoration:underline}.soundcloud-sets{margin:2rem 0}.soundcloud-sets h3{font-family:var(--font-sans);font-size:1rem;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-light);margin-bottom:1.5rem}.soundcloud-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem}.soundcloud-set{background:var(--color-surface);border-radius:4px;overflow:hidden;border:1px solid var(--color-border)}.soundcloud-set iframe{display:block;border:none}.soundcloud-set .set-title{font-family:var(--font-serif);font-size:1rem;font-weight:600;margin:1rem 1rem .25rem;color:var(--color-text)}.soundcloud-set .set-meta{font-size:.8rem;color:var(--color-text-light);margin:0 1rem 1rem}.soundcloud-link{margin-top:1.5rem}.soundcloud-link a{color:var(--color-accent);font-size:.9rem}.soundcloud-link a:hover{text-decoration:underline}.project-nav{padding:3rem 4rem;border-top:1px solid var(--color-border);display:flex;justify-content:space-between;max-width:var(--max-width)}.project-nav a{display:flex;flex-direction:column;gap:.5rem;padding:1rem;border-radius:4px;transition:var(--transition)}.project-nav a:hover{background:var(--color-surface)}.project-nav .label{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-light)}.project-nav .title{font-family:var(--font-serif);font-size:1.125rem}.site-footer{padding:3rem 4rem;border-top:1px solid var(--color-border);font-size:.8rem;color:var(--color-text-light);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-left:var(--sidebar-width)}.site-footer a:hover{color:var(--color-accent)}.footer-social{display:flex;gap:.75rem;align-items:center}.footer-social a{display:flex;align-items:center;justify-content:center;color:var(--color-text-light);transition:var(--transition)}.footer-social a:hover{color:var(--color-accent);transform:translateY(-2px)}.social-icon{width:20px;height:20px}.social-icon-sc{width:28px;height:28px;margin:-4px}.bio-portrait,.composer-portrait{float:left;max-width:320px;width:40%;margin:0 1.5rem 1rem 0;border-radius:4px}.bio-photo-inline,.composer-photo-inline{display:block;max-width:100%;width:600px;margin:1rem auto;border-radius:4px}@media(max-width:1023px)and (min-width:769px){:root{--sidebar-width: 200px}.site-header{padding:2rem 1.25rem;width:var(--sidebar-width)}.logo{font-size:1.25rem}.logo-sub{margin-bottom:1rem}.main-nav a{font-size:.8rem;padding:.2rem 0}.hero,.intro-text,.projects-grid,.project-header,.project-description,.gallery,.project-nav,.site-footer,.breadcrumb,.video-section,.embed-section,.soundcloud-sets{padding-left:2rem;padding-right:2rem}.project-nav,.site-footer{padding-top:2rem;padding-bottom:2rem}.projects-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}.gallery{grid-template-columns:repeat(2,1fr);gap:1rem}.soundcloud-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}.breadcrumb{margin-left:var(--sidebar-width);padding-top:4rem}.project-header{padding-top:4rem}.project-header.has-banner{padding-top:1.5rem}.header-banner{margin-bottom:1.5rem;border-radius:2px}}@media(max-width:768px){:root{--sidebar-width: 0}.bio-portrait,.composer-portrait{float:none;width:100%;max-width:100%;margin:0 0 1rem}.menu-toggle{display:flex}.site-header{transform:translate(-100%);width:80vw;max-width:300px;transition:transform .4s ease;box-shadow:4px 0 24px #4a62751a}.site-header.open{transform:translate(0)}.main-content{margin-left:0}.hero,.intro-text,.projects-grid,.project-header,.project-description,.gallery,.project-nav,.site-footer,.breadcrumb,.video-section,.embed-section,.soundcloud-sets{padding-left:1.5rem;padding-right:1.5rem}.projects-grid{grid-template-columns:1fr;gap:1.5rem}.gallery{grid-template-columns:1fr}.soundcloud-grid{grid-template-columns:1fr;gap:1.5rem}.header-banner{aspect-ratio:16 / 5;margin-bottom:1rem;border-radius:0;margin-left:-1.5rem;margin-right:-1.5rem;width:calc(100% + 3rem);max-width:none}h1{font-size:2rem}.project-nav{flex-direction:column;gap:1rem}}.overlay{display:none;position:fixed;inset:0;background:#4a627540;z-index:99;backdrop-filter:blur(2px)}.overlay.active{display:block}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}:focus-visible{outline:2px solid var(--color-accent);outline-offset:4px}.skip-link{position:absolute;top:-40px;left:0;background:#4a6275;color:#f0efeb;padding:8px;text-decoration:none;z-index:300}.skip-link:focus{top:0}
