*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#F7F4F0;
  --bg2:#EFEBE5;
  --fg:#2E2924;
  --fg2:#1A1714;
  --muted:#7A746C;
  --accent:#C2AB8E;
  --warm:#E8E2DA;
  --latte:#D5CCC1;
  --cream:#FDFBF8;
  --serif:'Cormorant',Georgia,serif;
  --sans:'Karla',system-ui,sans-serif;
}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--sans);color:var(--fg);background:var(--bg);-webkit-font-smoothing:antialiased;font-size:1.05rem}

/* LOADER */
.ld{position:fixed;inset:0;background:var(--bg);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity .5s ease .2s,visibility .5s ease .2s}
.ld.out{opacity:0;visibility:hidden;pointer-events:none}
.ld span{font-family:var(--serif);font-size:clamp(.9rem,2.5vw,1.2rem);color:var(--fg);letter-spacing:.55em;font-weight:400;text-transform:uppercase}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:16px 20px;display:flex;justify-content:space-between;align-items:center;background:rgba(247,244,240,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(160,154,146,.08)}
@media(min-width:768px){nav{padding:20px 40px}}
.n-logo{font-family:var(--serif);font-size:.9rem;letter-spacing:.25em;color:var(--fg2);text-decoration:none;font-weight:400;text-transform:uppercase}
.n-links{display:flex;align-items:center;gap:28px}
.n-links a{font-family:var(--sans);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);text-decoration:none;font-weight:400;transition:color .3s}
.n-links a:hover{color:var(--fg)}
.n-links .n-cta{color:var(--fg2);padding:8px 20px;border:1px solid var(--latte);transition:all .3s}
.n-links .n-cta:hover{background:var(--accent);border-color:var(--accent);color:#fff}
@media(max-width:600px){.n-links a:not(.n-cta){display:none}}

.page-spacer{height:64px}

/* SECTIONS */
section{padding:64px 20px}
@media(min-width:768px){section{padding:96px 40px}}
.inner{max-width:1020px;margin:0 auto}
.lbl{font-family:var(--sans);font-size:.48rem;letter-spacing:.4em;text-transform:uppercase;font-weight:400;margin-bottom:10px;display:block;color:var(--accent)}

/* HERO */
.hero{position:relative;height:100svh;min-height:560px;overflow:hidden;background:var(--fg2)}
.hero-vid{position:absolute;inset:0;z-index:1;overflow:hidden}
#yt-hero{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;height:100%;min-width:177.78vh;min-height:56.25vw;pointer-events:none}
#yt-hero iframe{position:absolute !important;top:0 !important;left:0 !important;width:100% !important;height:100% !important;border:none !important;pointer-events:none !important}
.hero-ov{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(42,37,33,.15) 0%,rgba(42,37,33,.4) 100%);z-index:2}
.hero-c{position:relative;z-index:3;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding:0 20px 11vh;text-align:center}
.hero h1{font-family:var(--serif);font-size:clamp(2.4rem,7vw,5rem);font-weight:300;color:var(--cream);line-height:1.08;letter-spacing:.12em;opacity:0;animation:up .8s ease .4s forwards}
.hero-sub{font-family:var(--sans);font-size:.6rem;color:rgba(253,251,248,.45);letter-spacing:.22em;text-transform:uppercase;font-weight:300;margin-top:14px;opacity:0;animation:up .7s ease .7s forwards}
.hero-btn{margin-top:24px;opacity:0;animation:up .7s ease .9s forwards}
.hero-btn a{font-family:var(--sans);font-size:.55rem;letter-spacing:.22em;text-transform:uppercase;color:var(--cream);text-decoration:none;font-weight:300;padding:11px 30px;border:1px solid rgba(194,171,142,.5);transition:.3s}
.hero-btn a:hover{background:var(--accent);border-color:var(--accent);color:var(--fg2)}
@keyframes up{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}

/* CRAFT / APPROACH SECTION */
.craft{background:var(--bg2);text-align:center;padding:72px 20px}
@media(min-width:768px){.craft{padding:96px 40px}}
.craft-inner{max-width:620px;margin:0 auto}
.craft h2{font-family:var(--serif);font-size:clamp(1.9rem,4vw,2.8rem);font-weight:300;color:var(--fg2);margin-top:8px;margin-bottom:20px;line-height:1.2}
.craft h2 em{font-style:italic}
.craft-body{font-family:var(--sans);font-size:.92rem;line-height:1.9;color:var(--muted);font-weight:300;max-width:520px;margin:0 auto}
.craft-body p+p{margin-top:14px}

/* FILMS */
.films{background:var(--cream)}
.films-head{text-align:center;margin-bottom:36px}
.films-head h2{font-family:var(--serif);font-size:clamp(1.9rem,4vw,2.8rem);font-weight:300;color:var(--fg2);margin-top:4px}
.films-sub{font-family:var(--sans);font-size:.78rem;color:var(--muted);font-weight:300;margin-top:8px;max-width:400px;margin-left:auto;margin-right:auto}
.films-grid{display:grid;gap:28px}
@media(min-width:520px){.films-grid{grid-template-columns:1fr 1fr;gap:28px}}
.fc{display:flex;flex-direction:column;gap:8px}
.fc-meta{padding:0 2px}
.fc-venue{font-family:var(--sans);font-size:.42rem;letter-spacing:.28em;text-transform:uppercase;color:var(--accent);font-weight:300;display:block;margin-bottom:2px}
.fc-name{font-family:var(--serif);font-size:clamp(.95rem,2vw,1.2rem);font-weight:300;color:var(--fg2);font-style:italic;display:block}
.fc-embed{position:relative;aspect-ratio:16/9;background:var(--latte);overflow:hidden}
.fc-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:none}
.films-more{text-align:center;margin-top:28px}
.films-more a{font-family:var(--sans);font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;color:var(--fg);text-decoration:none;font-weight:400;padding-bottom:2px;border-bottom:1px solid var(--accent);transition:color .3s}
.films-more a:hover{color:var(--accent)}

/* TESTIMONIAL */
.test{background:var(--bg);text-align:center}
.test-q{font-family:var(--serif);font-size:clamp(1.3rem,2.8vw,1.8rem);font-weight:300;font-style:italic;line-height:1.65;color:var(--fg2);max-width:600px;margin:14px auto 18px}
.test-a{font-family:var(--sans);font-size:.48rem;letter-spacing:.3em;text-transform:uppercase;color:var(--accent);font-weight:400}
.test-divider{width:40px;height:1px;background:var(--latte);margin:36px auto}
.test-q2{font-family:var(--serif);font-size:clamp(.95rem,2vw,1.2rem);font-weight:300;font-style:italic;line-height:1.65;color:var(--muted);max-width:520px;margin:0 auto 18px}

/* ABOUT */
.about{background:var(--cream)}
.about-wrap{display:grid;gap:36px;align-items:center}
@media(min-width:680px){.about-wrap{grid-template-columns:5fr 7fr;gap:48px}}
.about-img{aspect-ratio:3/4;background:var(--latte);position:relative;max-height:400px}
.about-txt h2{font-family:var(--serif);font-size:clamp(1.8rem,3.5vw,2.5rem);font-weight:300;line-height:1.25;margin-bottom:14px;color:var(--fg2)}
.about-txt h2 em{font-style:italic}
.about-txt p{font-family:var(--sans);font-size:.92rem;line-height:1.9;color:var(--muted);font-weight:300;margin-bottom:10px;max-width:460px}
.about-txt strong{color:var(--fg);font-weight:400}
.tl{display:inline-flex;align-items:center;gap:7px;font-family:var(--sans);font-size:.52rem;letter-spacing:.2em;text-transform:uppercase;color:var(--fg);text-decoration:none;font-weight:400;margin-top:10px;transition:gap .3s}
.tl:hover{gap:13px;color:var(--accent)}
.tl::after{content:'→'}

/* DELIVERABLES GRID */
.deliverables{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;max-width:760px;margin:0 auto}
.del-item{font-family:var(--sans);font-size:.72rem;color:var(--fg);font-weight:300;padding:16px 20px;background:var(--cream);border:1px solid var(--warm);text-align:center;letter-spacing:.05em}

/* INVESTMENT */
.invest{background:var(--bg2);text-align:center;padding:56px 20px}
@media(min-width:768px){.invest{padding:72px 40px}}
.invest h2{font-family:var(--serif);font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:300;color:var(--fg2);margin-top:4px;margin-bottom:8px}
.invest p{font-family:var(--sans);font-size:.92rem;line-height:1.9;color:var(--muted);font-weight:300;margin-bottom:24px}
.btn{display:inline-block;padding:11px 34px;font-family:var(--sans);font-size:.52rem;letter-spacing:.22em;text-transform:uppercase;text-decoration:none;font-weight:400;transition:.3s}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:var(--fg2)}

/* CONTACT */
.contact{background:var(--cream)}
.c-top{text-align:center;margin-bottom:40px}
.c-top h2{font-family:var(--sans);font-size:.7rem;letter-spacing:.35em;text-transform:uppercase;font-weight:300;color:var(--fg2);margin-top:8px;margin-bottom:10px}
.c-top p{font-family:var(--sans);font-size:.92rem;color:var(--muted);font-weight:300;line-height:1.9}
.c-form{max-width:560px;margin:0 auto;display:flex;flex-direction:column;gap:18px}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:480px){.fr{grid-template-columns:1fr}}
.fg{display:flex;flex-direction:column;gap:5px}
.fg label{font-family:var(--sans);font-size:.52rem;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);font-weight:300}
.fg input,.fg textarea,.fg select{background:transparent;border:none;border-bottom:1px solid var(--latte);padding:10px 0;font-family:var(--sans);font-size:.9rem;color:var(--fg);font-weight:300;outline:none;transition:border-color .3s;border-radius:0;-webkit-appearance:none}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-bottom-color:var(--accent)}
.fg textarea{resize:none;height:72px}
.fg select{color:var(--muted);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23A09A92'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 2px center;padding-right:18px}
.fg select.has-value{color:var(--fg)}
.c-sub{margin-top:8px;padding:13px 40px;background:var(--fg2);color:var(--cream);border:none;font-family:var(--sans);font-size:.52rem;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;font-weight:300;transition:.3s;align-self:center;-webkit-appearance:none;border-radius:0}
.c-sub:hover{background:var(--accent)}
.c-info{text-align:center;margin-top:36px}
.c-info p{font-family:var(--sans);font-size:.82rem;color:var(--muted);font-weight:300;margin-bottom:4px;line-height:1.9}
.c-info a{color:var(--fg);text-decoration:none;border-bottom:1px solid var(--accent)}

/* FOOTER */
footer{background:var(--bg2);padding:40px 20px 24px;border-top:1px solid var(--warm)}
@media(min-width:768px){footer{padding:48px 40px 24px}}
.f-top{max-width:1020px;margin:0 auto;display:grid;gap:28px;margin-bottom:28px}
@media(min-width:520px){.f-top{grid-template-columns:2fr 1fr 1fr;gap:36px}}
.f-brand h3{font-family:var(--serif);font-size:1rem;letter-spacing:.1em;color:var(--fg2);font-weight:300;margin-bottom:6px}
.f-brand p{font-family:var(--sans);font-size:.68rem;color:var(--muted);font-weight:300;line-height:1.7;max-width:260px}
.f-col h4{font-family:var(--sans);font-size:.44rem;letter-spacing:.32em;text-transform:uppercase;color:var(--accent);font-weight:400;margin-bottom:10px}
.f-col a{display:block;font-family:var(--sans);font-size:.68rem;color:var(--muted);text-decoration:none;font-weight:300;margin-bottom:7px;transition:color .3s}
.f-col a:hover{color:var(--fg)}
.f-bot{max-width:1020px;margin:0 auto;padding-top:14px;border-top:1px solid var(--warm);display:flex;justify-content:space-between;flex-wrap:wrap;gap:5px}
.f-bot span{font-family:var(--sans);font-size:.48rem;color:var(--muted);font-weight:300;letter-spacing:.06em}

/* REVEAL */
.rv{opacity:0;transform:translateY(18px);transition:opacity .55s ease,transform .55s ease}
.rv.vis{opacity:1;transform:translateY(0)}

/* HAMBURGER */
.n-ham{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;background:none;border:none;cursor:pointer;padding:8px;min-width:44px;min-height:44px;margin-left:4px}
.n-ham span{display:block;width:20px;height:1px;background:var(--fg2);transition:transform .3s,opacity .3s}
.n-ham.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.n-ham.open span:nth-child(2){opacity:0}
.n-ham.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
@media(max-width:600px){
  .n-ham{display:flex}
  .n-links.open{position:fixed;top:53px;left:0;right:0;flex-direction:column;background:rgba(247,244,240,.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:8px 20px 20px;gap:0;border-bottom:1px solid var(--warm);z-index:99}
  .n-links.open a:not(.n-cta){display:block;padding:14px 0;font-size:.65rem;letter-spacing:.18em;border-bottom:1px solid rgba(160,154,146,.15);color:var(--fg)}
  .n-links.open .n-cta{margin-top:14px;text-align:center;padding:12px 20px;display:block}
}

/* MODAL */
.modal-ov{position:fixed;inset:0;background:rgba(42,37,33,.88);z-index:9000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
.modal-ov.open{opacity:1;visibility:visible}
.modal-wrap{width:min(92vw,960px);aspect-ratio:16/9;position:relative}
.modal-wrap iframe{width:100%;height:100%;border:none}
.modal-close{position:absolute;top:-40px;right:0;background:none;border:none;color:var(--cream);font-size:1.6rem;cursor:pointer;opacity:.6;transition:opacity .2s;line-height:1;padding:4px 8px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:flex-end}
.modal-close:hover,.modal-close:focus-visible{opacity:1;outline:none}

/* FOCUS STATES */
a:focus-visible,button:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}
.fg input:focus-visible,.fg textarea:focus-visible,.fg select:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* REDUCED MOTION */
@media(prefers-reduced-motion:reduce){
  .rv{opacity:1;transform:none;transition:none}
  .hero h1,.hero-sub,.hero-btn{animation:none;opacity:1;transform:none}
  .ld{transition:none}
  .fc-bg{transition:none}
  .modal-ov{transition:none}
}

/* FORM MESSAGE */
.form-msg{font-family:var(--sans);font-size:.68rem;font-weight:300;padding:12px 0;text-align:center;min-height:24px;line-height:1.6}
.form-msg.success{color:var(--accent)}
.form-msg.error{color:#b05252}

/* DATE INPUT */
.fg input[type="date"]{color:var(--fg);cursor:pointer}
.fg input[type="date"]::-webkit-calendar-picker-indicator{opacity:.35;cursor:pointer;filter:invert(60%)}

/* FILM CARD TAG */
.fc-tag{font-family:var(--sans);font-size:.38rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);font-weight:300;margin-bottom:2px;display:block}

/* MID-PAGE CTA */
.mid-cta{background:var(--cream);text-align:center;padding:0 20px 48px}
.mid-cta p{font-family:var(--sans);font-size:.72rem;color:var(--muted);font-weight:300;margin-bottom:20px;line-height:1.7}

/* DELIVERABLES MOBILE */
@media(max-width:480px){.deliverables{grid-template-columns:1fr 1fr}}
