/* Eric Francois, portfolio */
:root{
  --bone:#FAF8F3;
  --ink:#171513;
  --muted:#9A938A;
  --hair:#E6E1D7;
  --tone:#EFEAE0;
  --serif:'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --sans:'Inter', -apple-system, 'Helvetica Neue', Helvetica, Arial, sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scrollbar-gutter:stable}
body{
  background:var(--bone);
  color:var(--ink);
  font-family:var(--sans);
  font-size:15px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  min-height:100vh;
  display:flex;flex-direction:column;
}
main{flex:1 0 auto;width:100%}
header,footer,.ticker{flex-shrink:0}
::selection{background:var(--ink);color:var(--bone)}
:focus-visible{outline:1px solid var(--ink);outline-offset:4px}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* film grain */
body::after{
  content:'';position:fixed;inset:-50%;z-index:90;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='240' height='240' filter='url(%23n)' opacity='0.55'/%3E%3C/svg%3E");
  opacity:.045;
  animation:grain 9s steps(10) infinite;
}
@keyframes grain{
  0%,100%{transform:translate(0,0)} 10%{transform:translate(-2%,1%)} 20%{transform:translate(1%,-2%)}
  30%{transform:translate(-1%,2%)} 40%{transform:translate(2%,1%)} 50%{transform:translate(-2%,-1%)}
  60%{transform:translate(1%,2%)} 70%{transform:translate(2%,-1%)} 80%{transform:translate(-1%,-2%)} 90%{transform:translate(2%,2%)}
}

/* page transitions */
body{animation:pagein .55s ease both}
@keyframes pagein{from{opacity:0}to{opacity:1}}
body.pageout{opacity:0;transition:opacity .24s ease}


/* cursor square trail */
.trail-sq{
  position:fixed;z-index:80;pointer-events:none;
  width:6px;height:6px;background:var(--ink);
  opacity:.9;
  transition:opacity .6s ease, transform .6s ease;
}
.trail-sq.out{opacity:0;transform:scale(.2)}
@media (hover:none), (prefers-reduced-motion:reduce){.trail-sq{display:none}}

/* scroll reveal */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .7s ease, transform .8s cubic-bezier(.22,1,.36,1)}
.reveal.in{opacity:1;transform:none}

.wrap{max-width:1240px;margin:0 auto;padding:0 clamp(24px,4vw,48px);width:100%}

/* header */
header{padding:clamp(24px,3.5vw,40px) 0}
.head-row{display:flex;justify-content:space-between;align-items:baseline}
.mark{font-size:12px;font-weight:500;letter-spacing:.32em;text-transform:uppercase}
nav{display:flex;gap:28px}
nav a{
  position:relative;
  font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--muted);
  transition:color .35s ease;padding-bottom:4px;
}
nav a::after{
  content:'';position:absolute;left:0;bottom:0;height:1px;width:100%;
  background:var(--ink);transform:scaleX(0);transform-origin:left;
  transition:transform .45s cubic-bezier(.22,1,.36,1);
}
nav a:hover::after, nav a[aria-current="page"]::after{transform:scaleX(1)}
nav a:hover, nav a[aria-current="page"]{color:var(--ink)}

/* credits ticker */
.ticker{
  border-top:1px solid var(--hair);
  overflow:hidden;
  padding:clamp(18px,2.4vw,26px) 0;
}
.ticker-inner{
  display:flex;gap:0;width:max-content;
  animation:tick 60s linear infinite;
}
.ticker:hover .ticker-inner{animation-play-state:paused}
.ticker span{
  font-family:var(--serif);font-style:italic;
  font-size:clamp(17px,1.7vw,22px);color:var(--muted);
  white-space:nowrap;padding-right:3.2em;
}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* hero */
.hero{padding:clamp(44px,8vh,100px) 0 clamp(40px,7vh,84px)}
.hero h1{
  text-wrap:balance;
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(24px,3.4vw,42px);
  line-height:1.14;
  max-width:18em;
}
.hero h1 em{font-style:italic}
.hero p{margin-top:24px;font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--muted)}

/* index: list + sticky preview */
.board{
  display:grid;
  grid-template-columns:minmax(0,1fr) clamp(440px,48vw,660px);
  gap:clamp(32px,4.5vw,72px);
  align-items:start;
  margin-bottom:clamp(70px,12vh,150px);
}
.index{border-top:1px solid var(--hair)}
.row{
  display:block;
  padding:clamp(18px,2.2vw,26px) 0;
  border-bottom:1px solid var(--hair);
  transition:opacity .35s ease;
  cursor:pointer;
}
.row .t{
  display:block;
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(26px,3vw,40px);
  line-height:1.15;
  transition:transform .45s cubic-bezier(.22,1,.36,1), font-style .2s;
}
.row .m{
  display:block;
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);
  margin-top:6px;
  transition:transform .45s cubic-bezier(.22,1,.36,1);
}
.row:hover .m, .row.active .m{transform:translateX(10px)}
.index:hover .row{opacity:.38}
.index .row:hover, .index .row.active{opacity:1}
.row:hover .t, .row.active .t{transform:translateX(10px);font-style:italic}

/* inline thumb, mobile only */
.row .thumb{display:none}

/* sticky preview panel, wide like the source portfolio */
.preview{
  position:sticky;
  top:clamp(20px,4vh,44px);
  aspect-ratio:16/9;
  overflow:hidden;
  background:var(--tone);
}
.layer{
  position:absolute;inset:0;
  opacity:0;
  transform:scale(1.045);
  transition:opacity .6s ease, transform 1.1s cubic-bezier(.22,1,.36,1);
  will-change:opacity,transform;
}
.layer.on{opacity:1;transform:scale(1)}
.layer img{
  position:absolute;inset:0;
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.85) contrast(.99);
  transition:filter .7s ease, opacity .55s ease;
}
.layer.on img{filter:saturate(1) contrast(1)}
.layer img.b{opacity:0}
.layer.showb img.b{opacity:1}
/* typographic fallback while covers are pending */
.layer .ph{
  position:absolute;inset:0;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:26px 28px;
  background:linear-gradient(160deg,var(--tone) 0%,#E7E0D3 100%);
}
.layer .ph .ph-t{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:clamp(30px,3vw,44px);line-height:1.1;color:var(--ink);opacity:.55;
}

/* cursor tag */
#tag{
  position:fixed;top:0;left:0;z-index:50;
  pointer-events:none;
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  background:var(--ink);color:var(--bone);
  padding:8px 14px 7px;border-radius:999px;
  opacity:0;transform:translate(-50%,-130%) scale(.85);
  transition:opacity .25s ease, transform .25s ease;
  white-space:nowrap;
}
#tag.on{opacity:1;transform:translate(-50%,-130%) scale(1)}

/* footer */
.ticker + footer{border-top:0}
footer{border-top:1px solid var(--hair);padding:clamp(34px,5vh,56px) 0 clamp(40px,6vh,64px)}
.foot-row{display:flex;justify-content:space-between;flex-wrap:wrap;gap:18px}
footer a, footer span{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted)}
footer a{transition:color .35s ease}
footer a:hover{color:var(--ink)}

/* project page */
.proj-head{padding:clamp(40px,8vh,96px) 0 clamp(30px,5vh,56px)}
.crumb{font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--muted);transition:color .35s}
.crumb:hover{color:var(--ink)}
.proj-head h1{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(38px,6vw,76px);line-height:1.08;margin-top:22px;
}
.proj-head .sub{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:clamp(20px,2.4vw,30px);line-height:1.2;margin-top:10px;color:var(--ink);
}
.stills{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(16px,2.5vw,32px);
  margin:clamp(28px,4vw,56px) auto;
  max-width:880px;
}
.gallery{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2.5vw,32px);margin:clamp(28px,4vw,56px) auto;max-width:880px;align-items:start}
.gallery img{width:100%;display:block;background:var(--tone)}
.stills.one{grid-template-columns:1fr}
.stills img{width:100%;aspect-ratio:16/9;object-fit:cover;background:var(--tone)}
@media (max-width:640px){.stills{grid-template-columns:1fr}}
.meta{display:flex;flex-wrap:wrap;gap:8px 44px;margin-top:30px}
.meta div{font-size:11px;letter-spacing:.2em;text-transform:uppercase}
.meta .k{color:var(--muted);margin-right:10px}
.films{display:grid;gap:clamp(28px,4vw,56px);margin:clamp(16px,3vh,32px) auto;max-width:880px}
.film{position:relative;width:100%;aspect-ratio:16/9;background:#101010}
.film video{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;background:#101010}
.film[style*="1080/1060"]{max-width:620px;margin:0 auto;width:100%}
.proj-body{padding:clamp(36px,6vh,70px) 0 clamp(60px,10vh,120px)}
.proj-body p{
  font-family:var(--serif);font-size:clamp(19px,2vw,24px);line-height:1.55;
  max-width:34em;
}
.proj-body .ext{display:inline-block;margin-top:26px;font-family:var(--sans);font-size:11px;letter-spacing:.26em;text-transform:uppercase;border-bottom:1px solid var(--hair);padding-bottom:4px;transition:border-color .35s}
.proj-body .ext:hover{border-color:var(--ink)}
.pn{display:flex;justify-content:space-between;border-top:1px solid var(--hair);padding:clamp(26px,4vh,40px) 0 clamp(50px,7vh,72px)}
.pn a{font-family:var(--serif);font-size:clamp(18px,2vw,24px);transition:font-style .2s}
.pn a:hover{font-style:italic}
.pn .lab{display:block;font-family:var(--sans);font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.pn .next{text-align:right}

/* sites: case rows mirroring the home index, scaled down */
.cases{max-width:880px;margin:clamp(28px,4vw,56px) auto;border-top:1px solid var(--hair)}
.case{
  display:grid;grid-template-columns:minmax(0,1fr) clamp(240px,30vw,360px);
  gap:clamp(18px,3vw,40px);align-items:center;
  padding:clamp(20px,2.6vw,30px) 0;border-bottom:1px solid var(--hair);
}
.case .case-t{
  display:block;font-family:var(--serif);font-weight:400;
  font-size:clamp(22px,2.5vw,32px);line-height:1.15;
  transition:transform .45s cubic-bezier(.22,1,.36,1), font-style .2s;
}
.case .arrow{font-family:var(--sans);font-size:.55em;vertical-align:.35em;color:var(--muted);transition:color .35s}
.case .case-m{
  display:block;margin-top:6px;
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);
  transition:transform .45s cubic-bezier(.22,1,.36,1);
}
.case .case-img{display:block;aspect-ratio:16/10;overflow:hidden;background:var(--tone)}
.case .case-img img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.85);
  transition:filter .7s ease, transform 1.1s cubic-bezier(.22,1,.36,1);
}
.case:hover .case-t{transform:translateX(10px);font-style:italic}
.case:hover .case-m{transform:translateX(10px)}
.case:hover .arrow{color:var(--ink)}
.case:hover .case-img img{filter:saturate(1);transform:scale(1.03)}
@media (max-width:640px){.case{grid-template-columns:1fr}.case .case-img{order:-1}}
.cta{
  margin-top:clamp(30px,4vw,44px);
  padding-top:clamp(22px,3vw,30px);
  border-top:1px solid var(--hair);
  display:flex;flex-wrap:wrap;align-items:baseline;gap:12px 28px;
}
.cta span{font-family:var(--serif);font-style:italic;font-size:clamp(19px,2vw,24px)}
.cta a{
  font-size:11px;letter-spacing:.26em;text-transform:uppercase;
  border-bottom:1px solid var(--ink);padding-bottom:4px;transition:opacity .35s;
}
.cta a:hover{opacity:.6}

/* hidden sites page */
.offer{max-width:880px;margin:0 auto}
.offer h1{font-family:var(--serif);font-weight:400;font-size:clamp(28px,3.8vw,48px);line-height:1.15;max-width:18em;text-wrap:balance;padding-top:clamp(36px,7vh,80px)}
.offer .support{margin-top:18px;font-family:var(--serif);font-style:italic;font-size:clamp(17px,1.8vw,21px);color:var(--ink)}
.sitecases{margin:clamp(40px,6vh,72px) 0;border-top:1px solid var(--hair)}
.sitecase{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.2fr);gap:clamp(20px,3vw,40px);align-items:center;padding:clamp(24px,3vw,36px) 0;border-bottom:1px solid var(--hair)}
.sitecase .sc-img{aspect-ratio:16/10;overflow:hidden;background:var(--tone)}
.sitecase .sc-img img{width:100%;height:100%;object-fit:cover;object-position:top}
.sitecase .sc-tile{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,var(--tone) 0%,#E7E0D3 100%)}
.sitecase .sc-tile span{font-family:var(--serif);font-style:italic;font-size:clamp(22px,2.4vw,32px);opacity:.7}
.sitecase .sc-t{font-family:var(--serif);font-size:clamp(22px,2.6vw,32px);line-height:1.15;transition:font-style .2s}
.sitecase:hover .sc-t{font-style:italic}
.sitecase .sc-m{display:block;margin-top:8px;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.tiers{display:grid;grid-template-columns:1fr 1fr 1fr;gap:clamp(20px,3vw,40px);margin:clamp(36px,5vh,60px) 0 0}
.tier{border-top:1px solid var(--ink);padding-top:18px}
.tier .t-name{font-size:11px;letter-spacing:.26em;text-transform:uppercase}
.tier .t-price{font-family:var(--serif);font-size:clamp(22px,2.4vw,32px);margin-top:8px}
.tier-notes{margin-top:22px;font-family:var(--serif);font-size:clamp(16px,1.6vw,19px);line-height:1.6;color:var(--ink);max-width:40em}
.tier-notes em{color:var(--muted)}
.enquire{margin:clamp(44px,7vh,80px) 0 clamp(60px,9vh,110px);border-top:1px solid var(--hair);padding-top:clamp(28px,4vh,44px)}
.enquire h2{font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--muted);font-weight:500;margin-bottom:26px}
.enquire form{display:grid;grid-template-columns:1fr 1fr;gap:22px clamp(20px,3vw,40px);max-width:760px}
.field{display:flex;flex-direction:column;gap:8px}
.field.full{grid-column:1/-1}
.field label{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted)}
.field input,.field select,.field textarea{
  font-family:var(--serif);font-size:18px;color:var(--ink);
  background:transparent;border:0;border-bottom:1px solid var(--hair);
  padding:6px 0;border-radius:0;appearance:none;-webkit-appearance:none;
}
.field textarea{min-height:96px;resize:vertical;line-height:1.5}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-bottom-color:var(--ink)}
.enquire button{
  grid-column:1/-1;justify-self:start;cursor:pointer;
  font-family:var(--sans);font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--bone);background:var(--ink);border:1px solid var(--ink);
  padding:14px 36px;margin-top:8px;transition:opacity .35s;
}
.enquire button:hover{opacity:.82}
.field input[type="file"]{
  font-family:var(--sans);font-size:11px;letter-spacing:.06em;color:var(--muted);
  border-bottom:1px solid var(--hair);padding:10px 0;cursor:pointer;
}
.field input[type="file"]::file-selector-button{
  font-family:var(--sans);font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink);background:transparent;border:1px solid var(--ink);
  padding:8px 16px;margin-right:14px;cursor:pointer;transition:opacity .35s;
}
.field input[type="file"]::file-selector-button:hover{opacity:.6}
.field input::placeholder,.field textarea::placeholder{color:var(--muted);font-style:italic;opacity:.8}
#ref-links{display:flex;flex-direction:column;gap:10px}
#ref-links .ref-link{
  font-family:var(--serif);font-size:18px;color:var(--ink);
  background:transparent;border:0;border-bottom:1px solid var(--hair);
  padding:6px 0;border-radius:0;
}
#ref-links .ref-link:focus{outline:0;border-bottom-color:var(--ink)}
.ref-controls{display:flex;gap:18px;margin-top:12px}
#add-ref,#rm-ref{
  width:24px;height:24px;padding:0;
  font-family:var(--sans);font-size:18px;line-height:1;color:var(--muted);
  background:transparent;border:0;
  cursor:pointer;transition:color .35s;
}
#add-ref:hover,#rm-ref:hover{color:var(--ink)}
@media (max-width:720px){.sitecase{grid-template-columns:1fr}.tiers{grid-template-columns:1fr}.enquire form{grid-template-columns:1fr}}

/* information */
.info{padding:clamp(40px,8vh,100px) 0 clamp(70px,11vh,140px)}
.info h1{font-family:var(--serif);font-weight:400;font-size:clamp(38px,5.4vw,68px);line-height:1.1;max-width:16em}
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);margin-top:clamp(46px,7vh,80px)}
.info-grid h2{font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--muted);font-weight:500;margin-bottom:22px}
.info-grid p{font-family:var(--serif);font-size:clamp(18px,1.6vw,21px);line-height:1.6;max-width:30em}
.info-grid p + p{margin-top:1em}
.creds{list-style:none}
.creds li{font-family:var(--serif);font-size:clamp(18px,1.6vw,21px);padding:9px 0;border-bottom:1px solid var(--hair)}
.contact-list{list-style:none}
.contact-list li{padding:8px 0}
.contact-list a{font-size:12px;letter-spacing:.2em;text-transform:uppercase;border-bottom:1px solid var(--hair);padding-bottom:3px;transition:border-color .35s}
.contact-list a:hover{border-color:var(--ink)}

/* entrance */
.fade{opacity:0;transform:translateY(14px);animation:up .9s cubic-bezier(.22,1,.36,1) forwards}
.d1{animation-delay:.08s}.d2{animation-delay:.16s}.d3{animation-delay:.24s}
@keyframes up{to{opacity:1;transform:none}}

@media (prefers-reduced-motion:reduce){
  .fade{animation:none;opacity:1;transform:none}
  .row .t, .row, .layer, .layer img{transition:none}
  #tag{display:none}
}
@media (hover:none){
  #tag{display:none}
}
@media (max-width:900px){
  .board{grid-template-columns:1fr}
  .preview{display:none}
  #tag{display:none}
  .row .thumb{
    display:block;
    aspect-ratio:16/9;overflow:hidden;background:var(--tone);
    margin-bottom:14px;position:relative;
  }
  .row .thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
  .row .thumb img.b{display:none}
  .row .thumb .ph{
    position:absolute;inset:0;display:flex;align-items:flex-end;padding:16px 18px;
    background:linear-gradient(160deg,var(--tone) 0%,#E7E0D3 100%);
  }
  .row .thumb .ph span{font-family:var(--serif);font-style:italic;font-size:24px;opacity:.5}
  .row{padding:26px 0}
  .index:hover .row{opacity:1}
  .info-grid{grid-template-columns:1fr}
}
