:root{--bg: #e8e2d6;--bg-warm: #f0ebe3;--text: #2a2622;--text-muted: #6b6358;--surface: #f7f3ec;--surface-elevated: #fffdf9;--border: rgba(42, 38, 34, .1);--header-height: 72px;--section-pad: clamp(3rem, 8vw, 6rem);--max-width: 1200px;--eng-accent: #2a7ab8;--eng-accent-dim: rgba(42, 122, 184, .18);--eng-border: rgba(42, 122, 184, .3);--eng-radius: 8px;--eng-mono: "ui-monospace", "SFMono-Regular", "Menlo", monospace;--music-accent: #c47d28;--music-accent-dim: rgba(196, 125, 40, .2);--music-border: rgba(196, 125, 40, .35);--music-radius: 16px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;overflow-x:hidden}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}body{background-color:var(--bg);color:var(--text);min-height:100vh;line-height:1.5;overflow-x:hidden}h1,h2,.section__title{font-family:Bebas Neue,sans-serif;letter-spacing:.02em}body,p,a,li,button{font-family:Inter,sans-serif}a{color:inherit}.header{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;height:var(--header-height);padding:0 clamp(1.25rem,4vw,2.5rem);background:var(--bg);border-bottom:1px solid var(--border)}.header__logo{font-family:Bebas Neue,sans-serif;font-size:1.75rem;font-weight:400;text-decoration:none;color:var(--text)}.header__nav{display:flex;align-items:center;gap:clamp(1rem,3vw,2rem)}.header__nav a{text-decoration:none;font-size:.9rem;font-weight:500;color:var(--text-muted);transition:color .2s ease}.header__nav a:hover,.header__nav a.active{color:var(--text)}.header__nav a[data-theme=engineering]:hover{color:var(--eng-accent)}.header__nav a[data-theme=music]:hover{color:var(--music-accent)}.hero{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - var(--header-height));padding:var(--section-pad) clamp(1.25rem,4vw,2.5rem);text-align:center}.hero__headline{font-size:clamp(3.5rem,12vw,7rem);line-height:.95;background:linear-gradient(135deg,var(--eng-accent) 0%,var(--text) 45%,var(--music-accent) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.hero__tagline{max-width:36rem;margin-top:1.5rem;font-size:clamp(1rem,2.5vw,1.2rem);color:var(--text-muted);line-height:1.6}.hero__actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:2.5rem}.hero__btn{display:inline-flex;align-items:center;padding:.85rem 1.75rem;font-size:.95rem;font-weight:600;text-decoration:none;border-radius:999px;transition:transform .2s ease,box-shadow .2s ease}.hero__btn--eng{background:var(--eng-accent);color:#fff}.hero__btn--eng:hover{transform:translateY(-2px);box-shadow:0 8px 24px var(--eng-accent-dim)}.hero__btn--music{background:transparent;color:var(--music-accent);border:2px solid var(--music-accent)}.hero__btn--music:hover{transform:translateY(-2px);background:var(--music-accent-dim)}.section{scroll-margin-top:var(--header-height);padding:var(--section-pad) clamp(1.25rem,4vw,2.5rem)}.section__inner{max-width:var(--max-width);margin:0 auto}.section__label{font-family:var(--eng-mono);font-size:.75rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase}.section--engineering .section__label{color:var(--eng-accent)}.section--music .section__label{color:var(--music-accent)}.section__title{font-size:clamp(2.5rem,6vw,4rem);margin-top:.35rem}.section__subtitle{margin-top:.5rem;font-size:1.05rem;color:var(--text-muted)}.section--engineering{background:linear-gradient(180deg,var(--bg) 0%,#e2ddd2 100%)}.section--music{background:linear-gradient(180deg,#ebe5da 0%,var(--bg-warm) 100%)}.section--production{background:linear-gradient(180deg,var(--bg-warm) 0%,rgba(196,125,40,.12) 50%,var(--bg) 100%)}.production-panel{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:start;margin-top:.5rem;padding:clamp(2rem,5vw,3rem);background:var(--surface-elevated);border-radius:var(--music-radius);box-shadow:0 8px 40px var(--music-accent-dim)}.production-panel__title{font-family:Bebas Neue,sans-serif;font-size:clamp(2.25rem,5vw,3.5rem);line-height:1;color:var(--music-accent)}.production-panel__headline{margin-top:.75rem;font-size:clamp(1.25rem,3vw,1.6rem);font-weight:600;line-height:1.3;color:var(--text)}.production-panel__text{margin-top:1rem;font-size:1.05rem;line-height:1.65;color:var(--text-muted)}.production-services{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.5rem;list-style:none}.production-services li{padding:.45rem 1rem;font-size:.85rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--music-accent);background:var(--music-accent-dim);border-radius:999px}.production-panel__cta-row{display:flex;flex-wrap:wrap;align-items:center;gap:1.25rem 1.75rem;margin-top:2rem}.production-panel__cta-block{display:inline-flex;flex-direction:column;align-items:stretch;border-radius:999px;background:var(--music-accent);overflow:hidden;transition:border-radius .35s cubic-bezier(.4,0,.2,1),box-shadow .35s cubic-bezier(.4,0,.2,1)}.production-panel__cta-block.is-open{border-radius:16px;box-shadow:0 10px 28px var(--music-accent-dim)}.production-panel__cta{display:inline-flex;justify-content:center;padding:1rem 2rem;font-size:1rem;font-weight:700;color:#fff;background:transparent;border:none;border-bottom:1px solid transparent;cursor:pointer;font-family:inherit;transition:transform .25s cubic-bezier(.4,0,.2,1),border-color .35s cubic-bezier(.4,0,.2,1)}.production-panel__cta-block:not(.is-open) .production-panel__cta:hover{transform:translateY(-2px)}.production-panel__cta-block.is-open .production-panel__cta{border-bottom-color:#fff3}.production-panel__contact-reveal{display:grid;grid-template-rows:0fr;transition:grid-template-rows .35s cubic-bezier(.4,0,.2,1)}.production-panel__cta-block.is-open .production-panel__contact-reveal{grid-template-rows:1fr}.production-panel__contact-details{display:flex;flex-direction:column;gap:.35rem;min-height:0;overflow:hidden;padding:0 1.5rem;opacity:0;transform:translateY(-8px);transition:opacity .3s cubic-bezier(.4,0,.2,1),transform .35s cubic-bezier(.4,0,.2,1),padding .35s cubic-bezier(.4,0,.2,1)}.production-panel__cta-block.is-open .production-panel__contact-details{padding:.75rem 1.5rem 1.1rem;opacity:1;transform:translateY(0)}.production-panel__contact-details a{font-size:.95rem;font-weight:500;color:#fff;text-decoration:none}.production-panel__contact-details a:hover{text-decoration:underline}.production-panel__pricing{display:flex;flex-direction:column;align-items:center;gap:.5rem}.production-panel__price-tiers{display:flex;flex-direction:row;flex-wrap:wrap;align-items:flex-start;justify-content:center;gap:1.5rem 2.5rem}.production-panel__price{display:flex;flex-direction:column;gap:.25rem;min-width:7rem}.production-panel__price-label{font-size:.8rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.production-panel__price-amounts{display:flex;align-items:baseline;gap:.75rem}.production-panel__price-old{font-size:1.25rem;font-weight:600;color:var(--text-muted);text-decoration:line-through;text-decoration-thickness:2px}.production-panel__price-current{font-size:1.75rem;font-weight:700;color:var(--music-accent)}.hero__btn--production{background:var(--music-accent);color:#fff;border:none}.hero__btn--production:hover{transform:translateY(-2px);box-shadow:0 8px 24px var(--music-accent-dim)}.track-portfolio__title{font-family:Bebas Neue,sans-serif;font-size:1.75rem;color:var(--text)}.track-portfolio__empty{margin-top:.75rem;font-size:.95rem;line-height:1.5;color:var(--text-muted)}.track-list{display:flex;flex-direction:column;gap:1rem;margin-top:1.25rem;list-style:none}.track-player{display:flex;flex-direction:column;gap:.65rem}.track-player__meta{min-width:0}.track-player__title{font-size:.95rem;font-weight:600;color:var(--text);line-height:1.3}.track-player__artist{font-weight:500;color:var(--text-muted)}.track-player__year{color:var(--text-muted);font-weight:400}.track-player__controls{position:relative;display:flex;align-items:center;gap:.75rem;width:100%;padding:.5rem .75rem;background:var(--bg);border-radius:10px;transition:background .2s ease,box-shadow .2s ease}.track-player__controls.is-playing{background:var(--music-accent-dim);box-shadow:inset 0 0 0 1px var(--music-border)}.track-player__play{flex-shrink:0;width:2.25rem;height:2.25rem;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;color:var(--music-accent);background:var(--surface-elevated);border:1px solid var(--music-border);border-radius:50%;cursor:pointer;font-family:inherit;letter-spacing:-.05em;transition:transform .2s ease,background .2s ease}.track-player__play:hover:not(:disabled){transform:scale(1.05);background:#fff}.track-player__play:disabled{opacity:.45;cursor:wait}.track-player__wave{flex:1;min-width:0;cursor:pointer}.track-player__wave ::part(wrapper){cursor:pointer}.track-player__loading{position:absolute;right:.75rem;font-size:.75rem;color:var(--text-muted);pointer-events:none}@media(min-width:640px){.track-player{flex-direction:row;align-items:center;gap:1.25rem}.track-player__meta{flex:0 0 11rem}.track-player__controls{flex:1}}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-top:2.5rem}.project-grid--music{grid-template-columns:1fr;max-width:420px}.project-card{display:flex;flex-direction:column;text-decoration:none;overflow:hidden;opacity:0;transform:translateY(20px);transition:opacity .6s ease-out,transform .6s ease-out,box-shadow .25s ease}.project-card.revealed{opacity:1;transform:none}.project-card--engineering{background:var(--surface-elevated);border:none;box-shadow:0 2px 12px #2a26220f;border-radius:var(--eng-radius)}.project-card--engineering:hover{box-shadow:0 12px 40px var(--eng-accent-dim);transform:translateY(-4px)}.project-card--engineering.revealed:hover{transform:translateY(-4px)}.project-card--music{background:var(--surface-elevated);border:none;box-shadow:0 2px 12px #2a26220f;border-radius:var(--music-radius)}.project-card--music:hover{box-shadow:0 16px 48px var(--music-accent-dim);transform:translateY(-4px) scale(1.01)}.project-card--music.revealed:hover{transform:translateY(-4px) scale(1.01)}.project-card__image-wrap{overflow:hidden;line-height:0;display:block}.project-card--engineering .project-card__image-wrap{aspect-ratio:16 / 10}.project-card--music .project-card__image-wrap{aspect-ratio:1}.project-card__image{width:100%;height:100%;object-fit:cover;display:block;vertical-align:top;transition:transform .4s ease}.project-card--music .project-card__image{transform:scale(1.04);transform-origin:center center}.project-card--engineering:hover .project-card__image{transform:scale(1.03)}.project-card--music:hover .project-card__image{transform:scale(1.07)}.project-card__body{padding:1.25rem 1.5rem 1.5rem;display:flex;flex-direction:column;gap:.5rem;flex:1}.project-card__title{font-family:Bebas Neue,sans-serif;font-size:1.75rem;line-height:1.1}.project-card--engineering .project-card__title{color:var(--eng-accent)}.project-card--music .project-card__title{color:var(--music-accent)}.project-card__description{font-size:.95rem;color:var(--text-muted);line-height:1.5}.project-card__cta{margin-top:auto;padding-top:.75rem;font-size:.85rem;font-weight:600}.project-card--engineering .project-card__cta{color:var(--eng-accent)}.project-card--music .project-card__cta{color:var(--music-accent)}.footer{padding:2.5rem clamp(1.25rem,4vw,2.5rem) 3rem;border-top:1px solid var(--border);background:var(--bg-warm)}.footer__inner{max-width:var(--max-width);margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:1.25rem;text-align:center}.footer__links{display:flex;flex-wrap:wrap;justify-content:center;gap:1.25rem 2rem}.footer__links a{font-size:.95rem;font-weight:500;color:var(--text-muted);text-decoration:none;transition:color .2s ease}.footer__links a:hover{color:var(--text)}.footer__meta{font-size:.8rem;color:var(--text-muted)}.footer__meta a{color:var(--eng-accent);text-decoration:none}.footer__meta a:hover{text-decoration:underline}.page-main{padding:2rem clamp(1.25rem,4vw,2.5rem) 4rem}.page-main--detail{display:flex;flex-direction:column;align-items:center}.article,.content{background:var(--surface-elevated);border:1px solid var(--border);box-shadow:0 2px 12px #2a26220f;border-radius:var(--eng-radius);padding:clamp(1.5rem,4vw,2.5rem);max-width:800px;width:100%}.article+.article,.content+.content{margin-top:2rem}.article h1,.article h2,.content h2{font-family:Bebas Neue,sans-serif;font-size:clamp(2rem,5vw,2.75rem);color:var(--eng-accent);margin-bottom:.5rem}.article h3,.content h3{font-size:1.1rem;font-weight:600;margin-top:1.75rem}.article p,.content p{font-size:1.05rem;margin-top:.85rem;line-height:1.65;color:var(--text-muted)}.article ul,.content ul{font-size:1.05rem;padding-left:1.5rem;margin-top:.85rem;color:var(--text-muted);list-style-type:disc}.article li,.content li{margin-top:.35rem}.article img{max-width:100%;height:auto;margin:1.25rem 0;border-radius:var(--eng-radius)}.article a{color:var(--eng-accent);text-decoration:underline}.certchamps-embed{display:block;width:100%;height:100vh;min-height:800px;border:none;background:#fff}@media(max-width:900px){.production-panel{grid-template-columns:1fr}.production-panel__cta-row{flex-direction:column;align-items:center;justify-content:center;width:100%}.production-panel__cta-block{align-self:center}.production-panel__price-tiers{justify-content:center}.production-panel__price{align-items:center;text-align:center}.production-panel__price-amounts{justify-content:center}}@media(max-width:640px){.header__nav{gap:.75rem}.header__nav a{font-size:.8rem}.hero__actions{flex-direction:column;width:100%;max-width:280px}.hero__btn{justify-content:center;width:100%}}@media(prefers-reduced-motion:reduce){.project-card{transition:none;opacity:1;transform:none}.project-card:hover,.project-card.revealed:hover,.project-card--engineering:hover .project-card__image,.project-card--music:hover .project-card__image{transform:none}.project-card--music .project-card__image{transform:none;clip-path:inset(0 0 .8% 0)}.hero__btn:hover,.production-panel__cta:hover{transform:none}.production-panel__cta-block,.production-panel__cta,.production-panel__contact-reveal,.production-panel__contact-details{transition:none}.production-panel__cta-block:not(.is-open) .production-panel__contact-details{opacity:0;padding:0 1.5rem}.production-panel__cta-block.is-open .production-panel__contact-details{opacity:1;transform:none}}
