
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
h1,h2,h3,h4,h5,h6{font-weight:inherit;font-size:inherit}
:root{
  --dark:#111820;--navy:#1a2d3d;--blue:#2e6080;
  --steel:#4a8aa8;--mist:#8aacbc;--pale:#d8e6ee;
  --white:#fafafa;--rule:rgba(74,138,168,0.25);
}
html{scroll-behavior:smooth}
body{font-family:'Jost',sans-serif;background:var(--dark);color:var(--white);overflow-x:hidden}

/* LANGUAGE TOGGLE */
body .fr{display:none}
body .en{display:inline}
body.is-fr .fr{display:inline}
body.is-fr .en{display:none}
.lang-switch{display:flex;gap:2px;align-items:center;background:rgba(74,138,168,0.15);border-radius:3px;overflow:hidden;margin-left:16px}
.lang-btn{font-size:11px;font-weight:400;letter-spacing:0.18em;text-transform:uppercase;color:var(--mist);padding:5px 10px;cursor:pointer;border:none;background:transparent;transition:all 0.25s;font-family:'Jost',sans-serif}
.lang-btn.active{background:var(--steel);color:var(--dark);font-weight:500}
.lang-btn:hover:not(.active){color:var(--white)}


.film.featured { position: relative; overflow: hidden; }
.film-img { width: 100%; height: 260px; object-fit: cover; object-position: center; display: block; filter: grayscale(10%); }

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:20px 60px;background:rgba(17,24,32,0.96);border-bottom:1px solid var(--rule)}
.nav-brand{font-size:11px;font-weight:300;letter-spacing:0.28em;text-transform:uppercase;color:var(--mist);text-decoration:none}
.nav-brand strong{color:var(--white);font-weight:500}
.nav-links{display:flex;gap:32px;list-style:none}
.nav-links a{font-size:11px;font-weight:300;letter-spacing:0.22em;text-transform:uppercase;color:var(--mist);text-decoration:none;transition:color 0.25s}
.nav-links a:hover{color:var(--white)}

/* HERO */
.hero{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}
.hero-left{position:relative;overflow:hidden}
.hero-left img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;filter:grayscale(10%)}
.hero-left iframe{position:absolute;top:50%;left:50%;width:120%;height:120%;transform:translate(-50%,-50%);border:0;pointer-events:none}
.hero-left::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,transparent 50%,var(--dark) 100%),linear-gradient(to top,var(--dark) 0%,transparent 30%)}
.hero-right{display:flex;flex-direction:column;justify-content:flex-end;padding:120px 60px 80px 48px}
.hero-eyebrow{font-size:11px;letter-spacing:0.35em;text-transform:uppercase;color:var(--steel);margin-bottom:20px}
.hero-name{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(52px,6vw,88px);line-height:0.92;color:var(--white);letter-spacing:0.02em;margin-bottom:28px}
.hero-name em{display:block;font-style:italic;color:var(--mist)}
.hero-roles{border-left:1px solid var(--rule);padding-left:16px;margin-bottom:36px;display:flex;flex-direction:column;gap:6px}
.hero-roles span{font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--pale)}
.hero-bio{font-family:'Cormorant Garamond',serif;font-size:clamp(16px,1.5vw,19px);font-style:italic;line-height:1.8;color:var(--mist);max-width:380px;border-top:1px solid var(--rule);padding-top:24px}

/* WRAPPER */
.wrap{max-width:1200px;margin:0 auto;padding:0 60px}
.section{padding:90px 0;border-top:1px solid var(--rule)}
.section-label{font-size:11px;font-weight:500;letter-spacing:0.38em;text-transform:uppercase;color:var(--steel);margin-bottom:40px;display:flex;align-items:center;gap:14px}
.section-label::before{content:'';width:28px;height:1px;background:var(--steel);flex-shrink:0}
.section-title{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(34px,4vw,54px);line-height:1.1;color:var(--white);margin-bottom:52px}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:200px 1fr;gap:72px;align-items:start}
.about-stats{position:sticky;top:100px}
.stat{padding:28px 0;border-bottom:1px solid var(--rule)}
.stat:first-child{border-top:1px solid var(--rule)}
.stat-n{font-family:'Cormorant Garamond',serif;font-size:42px;font-weight:300;color:var(--steel);line-height:1;margin-bottom:6px}
.stat-n.sm{font-size:20px;padding-top:6px}
.stat-l{font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--mist)}
.about-body p{font-family:'Cormorant Garamond',serif;font-size:clamp(17px,1.6vw,21px);line-height:1.85;color:var(--pale);margin-bottom:22px}
.about-body p:first-child{font-size:clamp(19px,2vw,24px);color:var(--white)}
.about-body p:last-child{margin-bottom:0}

/* FILMS */
.films-grid{display:grid;grid-template-columns:1fr 1fr;gap:3px}
.film{padding:36px 32px;border:1px solid var(--rule);position:relative;transition:background 0.3s}
.film::before{content:'';position:absolute;top:0;left:0;width:2px;height:0;background:var(--steel);transition:height 0.4s}
.film:hover{background:rgba(46,96,128,0.07)}
.film:hover::before{height:100%}
.film.featured{grid-column:1/-1;display:grid;grid-template-columns:1fr 1fr;gap:0;padding:0}
.film.featured .film-left{padding:48px 40px;border-right:1px solid var(--rule)}
.film.featured .film-right{padding:48px 40px}
.film-year{font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--steel);margin-bottom:12px}
.film-title{font-family:'Cormorant Garamond',serif;font-size:26px;font-style:italic;color:var(--white);line-height:1.2;margin-bottom:8px}
.film.featured .film-title{font-size:36px}
.film-role{font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--mist);margin-bottom:14px}
.film-desc{font-size:13.5px;font-weight:300;line-height:1.75;color:var(--pale);margin-bottom:14px}
.film-screen{font-size:11.5px;color:var(--mist);line-height:1.7}
.film-award{font-size:11px;font-style:italic;color:var(--mist);margin-top:10px}
.film-link{display:inline-block;margin-top:18px;font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--steel);border-bottom:1px solid var(--rule);padding-bottom:2px;text-decoration:none;transition:all 0.25s}
.film-link:hover{color:var(--white);border-color:var(--steel)}

/* MEDIA */
.media-grid{display:grid;grid-template-columns:1fr 1fr;gap:3px}
.media-item{padding:36px 32px;border:1px solid var(--rule);transition:background 0.3s}
.media-item:hover{background:rgba(46,96,128,0.07)}
.media-client{font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--steel);margin-bottom:10px}
.media-title{font-family:'Cormorant Garamond',serif;font-size:22px;font-style:italic;color:var(--white);margin-bottom:12px}
.media-desc{font-size:13px;font-weight:300;line-height:1.75;color:var(--mist)}

/* PRESS */
.press-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 56px}
.press-item{padding:22px 0;border-bottom:1px solid var(--rule)}
.press-outlet{font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--steel);margin-bottom:7px}
.press-title{font-family:'Cormorant Garamond',serif;font-size:16px;font-style:italic;color:var(--white);line-height:1.4}.press-title a{color:inherit;text-decoration:none;border-bottom:1px solid var(--rule);transition:border-color 0.25s}.press-title a:hover{border-color:var(--steel)}

/* TEACHING */
.t-list{border-top:1px solid var(--rule)}
.t-item{display:grid;grid-template-columns:120px 1fr 180px;gap:24px;padding:32px 0;border-bottom:1px solid var(--rule);transition:padding-left 0.3s}
.t-item:hover{padding-left:10px}
.t-years{font-size:11px;letter-spacing:0.16em;color:var(--steel);padding-top:2px}
.t-title{font-family:'Cormorant Garamond',serif;font-size:20px;color:var(--white);margin-bottom:6px}
.t-sub{font-size:12.5px;font-weight:300;color:var(--mist);line-height:1.65}
.t-inst{font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--steel);text-align:right;padding-top:2px;line-height:1.6}

/* CLIENTS */
.clients{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.client-pill{font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--mist);border:1px solid var(--rule);padding:8px 18px;transition:all 0.25s}
.client-pill:hover{color:var(--white);border-color:var(--steel)}

/* CONTACT */
.contact-section{background:var(--navy)}
.contact-section .section-title{margin-bottom:20px}
.contact-links{display:flex;flex-wrap:wrap;gap:32px;margin-top:40px}
.contact-link{font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--mist);text-decoration:none;border-bottom:1px solid var(--rule);padding-bottom:4px;transition:all 0.25s}
.contact-link:hover{color:var(--white);border-color:var(--steel)}

/* FOOTER */
footer{background:#080e14;padding:32px 60px;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--rule)}
.footer-brand{font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--steel)}
.footer-copy{font-size:11px;color:var(--steel)}

/* NEWS STRIP */
.news-strip{background:var(--steel);padding:10px 0;text-align:center;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--dark);font-weight:500;overflow:hidden;white-space:nowrap}
.news-strip span{display:inline-block;animation:marquee 28s linear infinite}
@keyframes marquee{0%{transform:translateX(100vw)}100%{transform:translateX(-100%)}}

/* HAMBURGER */
.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;z-index:200}
.nav-hamburger span{width:22px;height:1.5px;background:var(--mist);transition:all 0.3s}
.nav-hamburger.open span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.nav-hamburger.open span:nth-child(2){opacity:0}
.nav-hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* BACK TO TOP */
.btt{position:fixed;bottom:32px;right:32px;width:44px;height:44px;border-radius:50%;background:var(--steel);color:var(--dark);border:none;cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:all 0.35s;z-index:90;box-shadow:0 4px 16px rgba(0,0,0,0.3)}
.btt.show{opacity:1;pointer-events:auto}
.btt:hover{background:var(--white);transform:translateY(-3px)}

/* SCROLL ANIMATIONS */
.reveal{opacity:0;transform:translateY(32px);transition:opacity 0.7s ease,transform 0.7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

@media(max-width:900px){
  nav{padding:16px 24px}
  .nav-hamburger{display:flex}
  .nav-links{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(17,24,32,0.98);flex-direction:column;align-items:center;justify-content:center;gap:28px;z-index:150}
  .nav-links.open{display:flex}
  .nav-links .lang-switch{margin-left:0;margin-top:12px}
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-left{height:60vw}
  .hero-right{padding:48px 24px 60px}
  .wrap{padding:0 24px}
  .about-grid{grid-template-columns:1fr;gap:40px}
  .about-stats{position:static;display:grid;grid-template-columns:1fr 1fr;gap:0}
  .films-grid,.media-grid,.press-grid{grid-template-columns:1fr}
  .film.featured{grid-template-columns:1fr}
  .film.featured .film-left{border-right:none;border-bottom:1px solid var(--rule)}
  .t-item{grid-template-columns:1fr;gap:8px}
  .t-inst{text-align:left}
  .services-grid{grid-template-columns:1fr !important}
  .news-strip span{animation-duration:16s}
  footer{flex-direction:column;gap:12px;text-align:center;padding:24px}
  .contact-intro{font-size:16px}
}

/* VISUALLY HIDDEN — accessible but not painted */
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* SECTION BACKGROUNDS */
.bg-navy{background:var(--navy)}

/* HERO CTA LINK */
.hero-cta{display:inline-block;margin-top:18px;font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--steel);text-decoration:none;border-bottom:1px solid var(--rule);padding-bottom:3px;transition:all 0.25s}
.hero-cta:hover{color:var(--white);border-color:var(--steel)}

/* HERO LOCATION */
.hero-location{margin-top:24px;font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--mist)}

/* CONTACT TOP */
.contact-top{padding-top:20px}
.contact-label{font-size:11px;letter-spacing:0.28em;text-transform:uppercase;color:var(--steel);margin-bottom:20px}
.contact-email{font-family:'Cormorant Garamond',serif;font-size:clamp(24px,3vw,36px);font-style:italic;color:var(--white);text-decoration:none;border-bottom:1px solid var(--rule);padding-bottom:4px;transition:all 0.3s;display:inline-block}
.contact-email:hover{border-color:var(--steel)}
.contact-links{display:flex;flex-wrap:wrap;gap:32px;margin-top:28px}

/* SERVICES GRID */
.services-grid{display:grid;grid-template-columns:1fr 1fr;gap:3px;margin-bottom:56px}
.service-card{border:1px solid var(--rule);padding:32px;transition:background 0.3s;cursor:default}
.service-card:hover{background:rgba(46,96,128,0.07)}
.service-card-label{font-size:11px;letter-spacing:0.28em;text-transform:uppercase;color:var(--steel);margin-bottom:14px}
.service-card-body{font-size:13px;font-weight:300;line-height:1.75;color:var(--mist)}

/* SHOWREEL WRAPPER */
.showreel-wrap{padding:56.25% 0 0 0;position:relative}
.showreel-wrap iframe{position:absolute;top:0;left:0;width:100%;height:100%}

/* ABOUT RESUME LINKS */
.about-cta{margin-top:20px;display:flex;gap:20px;flex-wrap:wrap}
.about-cta-link{font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--steel);text-decoration:none;border-bottom:1px solid var(--rule);padding-bottom:2px;font-family:'Jost',sans-serif;transition:all 0.25s}
.about-cta-link:hover{color:var(--white);border-color:var(--steel)}

/* SERVICE CARD TITLE */
.service-card-title{font-family:'Cormorant Garamond',serif;font-size:20px;font-style:italic;color:var(--white);margin-bottom:12px}

/* THESIS CARD */
.thesis-card{border:1px solid var(--rule);padding:40px;margin-bottom:48px;position:relative;transition:background 0.3s}
.thesis-card:hover{background:rgba(46,96,128,0.07)}
.thesis-card::before{content:'';position:absolute;top:0;left:0;width:2px;height:100%;background:var(--steel);opacity:0.6}
.thesis-card-tag{font-size:11px;letter-spacing:0.32em;text-transform:uppercase;color:var(--steel);margin-bottom:14px}
.thesis-card-title{font-family:'Cormorant Garamond',serif;font-size:28px;font-style:italic;color:var(--white);margin-bottom:6px}
.thesis-card-meta{font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--mist);margin-bottom:20px}
.thesis-card-body{font-size:13.5px;font-weight:300;line-height:1.8;color:var(--pale);max-width:760px;margin-bottom:20px}
.thesis-card-advisors{font-size:11.5px;color:var(--mist);margin-bottom:18px}

/* contact-intro — audience-targeting line under "Get in touch" */
.contact-intro{font-family:'Cormorant Garamond',serif;font-size:clamp(16px,1.6vw,20px);font-style:italic;line-height:1.7;color:var(--mist);max-width:580px;margin-bottom:12px}

/* CONTACT FORM */
.contact-form{margin-top:40px;max-width:640px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}
.form-group label{font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--steel)}
.form-group input,.form-group select,.form-group textarea{font-family:'Jost',sans-serif;font-size:14px;font-weight:300;color:var(--white);background:rgba(74,138,168,0.08);border:1px solid var(--rule);padding:12px 14px;border-radius:0;transition:border-color 0.25s;-webkit-appearance:none;appearance:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--steel)}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--mist);opacity:0.5}
.form-group select{cursor:pointer;color:var(--mist)}
.form-group select option{background:var(--navy);color:var(--white)}
.form-group textarea{resize:vertical;min-height:120px}
.form-submit{font-family:'Jost',sans-serif;font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--dark);background:var(--steel);border:none;padding:14px 36px;cursor:pointer;transition:all 0.25s}
.form-submit:hover{background:var(--white);color:var(--dark)}
.form-msg{margin-top:16px;font-size:13px;font-weight:300;padding:12px 16px;border:1px solid var(--rule)}
.form-msg.success{color:#7ecfa0;border-color:rgba(126,207,160,0.3)}
.form-msg.error{color:#e07070;border-color:rgba(224,112,112,0.3)}
@media(max-width:900px){
  .form-row{grid-template-columns:1fr}
}

/* FOCUS INDICATORS */
a:focus-visible,button:focus-visible{outline:2px solid var(--steel);outline-offset:3px;border-radius:2px}

/* MARQUEE PAUSE ON HOVER / FOCUS */
.news-strip:hover span,.news-strip:focus-within span{animation-play-state:paused}

/* REDUCED MOTION */
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .news-strip span{animation:none}
  html{scroll-behavior:auto}
  .btt{transition:none}
  .film::before{transition:none}
  .film,.media-item,.service-card,.t-item{transition:none}
}
