/* =========================================================
   T – Studio — Editorial Portfolio (Graphéine/WYD style)
   Premium, minimal, confident, cultural
========================================================= */

/* =========================
   Table of contents
   1) Theme tokens
   2) Base
   3) Layout wrappers
   4) Header + Nav
   5) Mobile menu
   6) Hero
   7) Portfolio reel
   8) Manifesto
   9) Industries list
   10) Work (homepage)
   11) Services (homepage)
   12) Contact (homepage)
   13) Footer
   14) Pages (Portfolio, Services, About, Case)
   15) Responsive
========================= */

/* =========================
   1) Theme tokens
========================= */
:root{
  --orange:#FF3800;
  --black:#000000;
  --white:#ffffff;
  --nav-btn-size: 42px;

  --muted: rgba(255,255,255,.78);
  --hairline: rgba(255,255,255,.14);
}

/* =========================
   2) Base
========================= */
*{ box-sizing:border-box; }
html,body{
  height:100%;
  margin:0;
  padding:0;
}
body{
  font-family: system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  background: var(--black);
  overflow-x: hidden;
  padding-top: 48px;
}

body.page-shell{
  padding-top: 56px;
}
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; padding:0; margin:0; }

/* =========================
   3) Layout wrappers
========================= */
.dark{ background:var(--black); color:var(--white); }

.top{
  min-height:auto;
  display:flex;
  flex-direction:column;
  background: var(--black);
}

/* =========================
   3a) Generic pages
========================= */
.page{
  background:#fff;
  color:#111;
  padding: 140px 0 120px;
}

.page-inner{
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 22px;
}

.page-kicker{
  margin: 0 0 12px;
  color: rgba(0,0,0,.55);
  letter-spacing:.16em;
  text-transform: uppercase;
  font-weight: 800;
  font-size: 11px;
}

.page-title{
  margin: 0 0 18px;
  font-size: clamp(36px, 4.2vw, 64px);
  line-height: 1.05;
  font-weight: 600;
  letter-spacing: -.02em;
}

.page-sub{
  margin: 0;
  color: rgba(0,0,0,.65);
  line-height: 1.7;
  max-width: 60ch;
  font-size: 16px;
}

/* =========================
   3b) Portfolio page
========================= */
.portfolio-page{
  background:#fff;
  color:#111;
}

.portfolio-hero{
  padding: 140px 0 80px;
}

.portfolio-hero-inner{
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 22px;
}

.portfolio-kicker{
  margin: 0 0 12px;
  color: rgba(0,0,0,.55);
  letter-spacing:.16em;
  text-transform: uppercase;
  font-weight: 800;
  font-size: 11px;
}

.portfolio-title{
  margin: 0 0 18px;
  font-size: clamp(36px, 4.2vw, 64px);
  line-height: 1.05;
  font-weight: 600;
  letter-spacing: -.02em;
}

.portfolio-sub{
  margin: 0;
  color: rgba(0,0,0,.65);
  line-height: 1.7;
  max-width: 60ch;
  font-size: 16px;
}

.portfolio-accent{
  color: var(--orange);
}

.portfolio-list{
  padding: 0 0 140px;
}

.portfolio-list-inner{
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 22px;
}

.portfolio-items{
  margin: 0;
  padding: 0;
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 36px;
}

.portfolio-row{
  border-top: 1px solid rgba(0,0,0,.12);
  padding-top: 24px;
}

.portfolio-item{
  display:block;
  color: rgba(0,0,0,.72);
  transition: color .4s ease;
}

.portfolio-row.is-active .portfolio-item{
  color: var(--orange);
}

.portfolio-item:hover{
  color: rgba(0,0,0,.72);
}

.portfolio-name{
  display:block;
  font-size: clamp(22px, 2.6vw, 32px);
  line-height: 1.1;
  font-weight: 500;
  letter-spacing: -.03em;
  margin-bottom: 10px;
  color: var(--orange);
}

.portfolio-item-img{
  width:100%;
  aspect-ratio: 4 / 3;
  height:auto;
  object-fit: cover;
  margin-top: 16px;
  border: 1px solid rgba(0,0,0,.12);
}

.portfolio-meta{
  display:block;
  font-size: 12px;
  letter-spacing:.12em;
  text-transform: uppercase;
  color: rgba(0,0,0,.45);
  font-weight: 600;
}

/* =========================
   3d) Services page
========================= */
.services-page{
  background:#fff;
  color:#111;
}

.services-hero{
  padding: 140px 0 90px;
}

.services-hero-inner{
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 22px;
}

/* Scoped to services page to avoid collision with homepage services */
.services-page .services-kicker{
  margin: 0 0 12px;
  color: rgba(0,0,0,.55);
  letter-spacing:.16em;
  text-transform: uppercase;
  font-weight: 800;
  font-size: 11px;
}

.services-page .services-title{
  margin: 0 0 18px;
  font-size: clamp(36px, 4.2vw, 64px);
  line-height: 1.05;
  font-weight: 600;
  letter-spacing: -.02em;
}

.services-sub{
  margin: 0;
  color: rgba(0,0,0,.65);
  line-height: 1.7;
  max-width: 60ch;
  font-size: 16px;
}

.services-accent{
  color: var(--orange);
}

.services-blocks{
  padding: 0 0 110px;
}

.services-blocks-inner{
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 22px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 36px;
}

.service-card{
  border-top: 1px solid rgba(0,0,0,.12);
  padding-top: 22px;
}

.service-title{
  margin: 0 0 12px;
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -.01em;
}

.services-page .service-desc{
  margin: 0 0 16px;
  color: rgba(0,0,0,.65);
  line-height: 1.6;
  font-size: 15px;
}

.process{
  padding: 90px 0 110px;
  background: #f7f7f7;
}

.process-inner{
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 22px;
}

.process-kicker{
  margin: 0 0 10px;
  color: rgba(0,0,0,.55);
  letter-spacing:.16em;
  text-transform: uppercase;
  font-weight: 800;
  font-size: 11px;
}

.process-title{
  margin: 0 0 40px;
  font-size: clamp(28px, 3.6vw, 46px);
  line-height: 1.1;
  font-weight: 600;
  letter-spacing: -.02em;
}

.process-steps{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 32px;
}

.process-step{
  border-top: 1px solid rgba(0,0,0,.12);
  padding-top: 18px;
}

.process-num{
  display:block;
  font-size: 12px;
  letter-spacing:.18em;
  color: rgba(0,0,0,.45);
  font-weight: 700;
}

.process-name{
  margin: 10px 0 8px;
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -.01em;
}

.process-desc{
  margin: 0;
  color: rgba(0,0,0,.65);
  line-height: 1.6;
  font-size: 14px;
}

.services-cta{
  padding: 100px 0 140px;
}

.services-cta-inner{
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 22px;
  text-align: left;
}

.services-cta-title{
  margin: 0 0 12px;
  font-size: clamp(28px, 3.8vw, 48px);
  line-height: 1.1;
  font-weight: 600;
  letter-spacing: -.02em;
}

.services-cta-sub{
  margin: 0 0 24px;
  color: rgba(0,0,0,.65);
  line-height: 1.7;
  max-width: 60ch;
  font-size: 16px;
}

.services-cta-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 12px 16px;
  border-radius:0;
  border: 1px solid rgba(0,0,0,.2);
  text-transform: uppercase;
  letter-spacing:.08em;
  font-weight:700;
  font-size:12px;
  background: transparent;
  color:#111;
  transition: transform .2s ease, color .2s ease, border-color .2s ease, background .2s ease;
}

.services-cta-btn:hover{
  color:#111;
  border-color: rgba(0,0,0,.2);
  transform: none;
}

/* =========================
   3e) About page
========================= */
.about-page{
  background:#fff;
  color:#111;
}

.about-hero{
  padding: 140px 0 90px;
}

.about-hero-inner{
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 22px;
}

.about-kicker{
  margin: 0 0 12px;
  color: rgba(0,0,0,.55);
  letter-spacing:.16em;
  text-transform: uppercase;
  font-weight: 800;
  font-size: 11px;
}

.about-title{
  margin: 0 0 18px;
  font-size: clamp(36px, 4.2vw, 64px);
  line-height: 1.05;
  font-weight: 600;
  letter-spacing: -.02em;
}

.about-pillars{
  margin: 0 0 22px;
  padding: 0;
  display:grid;
  grid-template-columns: 1fr;
  gap: 12px;
  font-size: clamp(22px, 2.6vw, 34px);
  line-height: 1.15;
  font-weight: 600;
  letter-spacing: -.01em;
}

.about-accent{
  color: var(--orange);
}

.about-sub{
  margin: 0;
  color: rgba(0,0,0,.65);
  line-height: 1.7;
  max-width: 60ch;
  font-size: 16px;
}

.about-section{
  padding: 80px 0;
}

.about-section-light{
  background: #f7f7f7;
}

.about-section-inner{
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 22px;
  display:grid;
  gap: 16px;
}

.about-heading{
  margin: 0;
  font-size: 22px;
  letter-spacing: -.01em;
  font-weight: 600;
}

.about-text{
  margin: 0;
  color: rgba(0,0,0,.68);
  line-height: 1.7;
  max-width: 70ch;
  font-size: 16px;
}

.about-list{
  margin: 0;
  padding: 0;
  display:grid;
  gap: 10px;
  color: rgba(0,0,0,.68);
  font-size: 16px;
}

.portfolio-row.is-hidden{
  display:none;
}

.portfolio-load{
  margin-top: 48px;
  display:flex;
  justify-content:center;
}

.portfolio-load-btn{
  border: 1px solid rgba(0,0,0,.2);
  background: transparent;
  color:#111;
  text-transform: uppercase;
  letter-spacing:.12em;
  font-weight: 700;
  font-size: 11px;
  padding: 12px 18px;
  cursor:pointer;
  transition: color .2s ease, border-color .2s ease, transform .2s ease;
}

.portfolio-load-btn:hover{
  color:#111;
  border-color: rgba(0,0,0,.18);
  transform: none;
}

/* =========================
   3c) Case study pages
========================= */
.case{
  background:#fff;
  color:#111;
}

.case-hero{
  padding: 140px 0 80px;
}

.case-hero-inner{
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 22px;
}

.case-kicker{
  margin: 0 0 12px;
  color: rgba(0,0,0,.55);
  letter-spacing:.16em;
  text-transform: uppercase;
  font-weight: 800;
  font-size: 11px;
}

.case-title{
  margin: 0 0 18px;
  font-size: clamp(36px, 4.2vw, 64px);
  line-height: 1.05;
  font-weight: 600;
  letter-spacing: -.02em;
}

.case-sub{
  margin: 0 0 28px;
  color: rgba(0,0,0,.65);
  line-height: 1.7;
  max-width: 60ch;
  font-size: 16px;
}

.case-hero-media{
  margin-top: 30px;
  border: 1px solid rgba(0,0,0,.12);
  overflow:hidden;
}

.case-hero-media img{
  width:100%;
  display:block;
  object-fit:cover;
}

.case-section{
  padding: 70px 0;
}

.case-section-inner{
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 22px;
  display:grid;
  gap: 16px;
}

.case-section h2{
  margin: 0;
  font-size: 22px;
  letter-spacing: -.01em;
  font-weight: 600;
}

.case-section p{
  margin: 0;
  color: rgba(0,0,0,.68);
  line-height: 1.7;
  max-width: 70ch;
  font-size: 16px;
}

/* =========================
   4) Header + Nav (desktop)
========================= */
.site-header{
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;
  padding: 18px 28px;
  background: rgba(0,0,0,.95);
  backdrop-filter: blur(10px);
  border: 0;
  outline: 0;
  box-shadow: none;
  margin-bottom: 0;
}

body.page-shell .site-header{
  padding: 12px 24px;
}

.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}

.nav-left,
.nav-right{
  display:flex;
  align-items:center;
  gap:32px;
  font-size:13px;
  letter-spacing:.18em;
  text-transform: uppercase;
  font-weight: 600;
}

.nav-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 0;
  color: rgba(255,255,255,.86);
  transition: color .18s ease, opacity .18s ease;
}
.nav-link:hover{
  color: rgba(255,255,255,.86);
  opacity: 1;
}

.nav-logo{
  padding: 8px 16px;
  border: 1.5px solid rgba(255,255,255,.75);
  border-radius: 0;
  letter-spacing: .14em;
  font-weight: 700;
  font-size: 15px;
  text-transform: uppercase;
  white-space: nowrap;
  background: transparent;
  color: #fff;
  transition: color .18s ease, border-color .18s ease;
  animation: logo-pulse 3.2s ease-in-out infinite;
}
.nav-logo:hover{
  color: #fff;
  border-color: rgba(255,255,255,.75);
}

/* Logo border pulse */
@keyframes logo-pulse{
  0%, 60%, 100%{
    border-color: rgba(255,255,255,.75);
  }
  80%{
    border-color: rgba(255,56,0,.9);
  }
}

/* =========================
   5) Burger (mobile only)
========================= */
.nav-burger{
  display:none;
  width: var(--nav-btn-size);
  height: var(--nav-btn-size);
  border:1px solid rgba(255,255,255,.22);
  border-radius:0;
  background: rgba(255,255,255,.04);
  cursor:pointer;
  padding:10px;
  transition:border-color .18s ease, background .18s ease;
}

.nav-burger .line{
  display:block;
  height:2px;
  background:#fff;
  border-radius:999px;
  transition: transform .22s ease, background .18s ease, opacity .18s ease, width .22s ease;
}
.nav-burger .l1{ width:20px; margin:0 0 6px auto; }
.nav-burger .l2{ width:24px; margin:0 auto 6px; }
.nav-burger .l3{ width:18px; margin:0 auto 0 0; }

.nav-burger .l1{ animation: burger-scan 3.4s ease-in-out infinite; }
.nav-burger .l2{ animation: burger-scan 3.4s ease-in-out infinite .25s; }
.nav-burger .l3{ animation: burger-scan 3.4s ease-in-out infinite .5s; }

.nav-burger:hover{
  border-color: rgba(255,255,255,.22);
  background: rgba(255,255,255,.04);
}
.nav-burger:hover .line{ background: #fff; }

.nav-burger[aria-expanded="true"] .l1{
  width:24px;
  transform:translateY(8px) rotate(45deg);
  margin-right:auto;
  background:var(--orange);
}
.nav-burger[aria-expanded="true"] .l2{
  opacity:0;
  transform:scaleX(.6);
}
.nav-burger[aria-expanded="true"] .l3{
  width:24px;
  transform:translateY(-8px) rotate(-45deg);
  margin-left:auto;
  background:var(--orange);
}

/* =========================
   6) Mobile menu (fullscreen)
========================= */
.mnav{
  position: fixed;
  inset: 0;
  z-index: 999;
  background: var(--black);
  color: var(--white);
}
.mnav[hidden]{ display:none !important; }

.mnav{
  opacity: 0;
  transition: opacity .32s ease;
}

.mnav.is-open{
  opacity: 1;
}

.mnav-top{
  display:flex;
  justify-content:flex-end;
  padding: 18px 18px 0;
}

.mnav-close{
  width: var(--nav-btn-size);
  height: var(--nav-btn-size);
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius: 0;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.04);
  color: var(--white);
  font-size: 18px;
  line-height: 1;
  padding: 10px;
  cursor: pointer;
  transition: color .2s ease, border-color .2s ease;
}
.mnav-close:hover{
  color: var(--white);
  border-color: rgba(255,255,255,.22);
}

.mnav-inner{
  padding: 60px 26px 36px;
  display:grid;
  gap: 28px;
  opacity: 0;
  transform: translateY(18px);
  transition: opacity .55s ease, transform .55s ease;
}

.mnav-link{
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  font-size: 36px;
  line-height: 1.02;
  color: var(--white);
  transition: color .2s ease;
  opacity: 0;
  transform: translateY(8px);
  transition: transform .35s ease, opacity .35s ease, color .2s ease;
}
.mnav-link:hover{ color: var(--white); }
.mnav-link.is-active{ color: var(--orange); }

.mnav.is-open .mnav-inner{
  opacity: 1;
  transform: translateY(0);
}

.mnav.is-open .mnav-link{
  opacity: 1;
  transform: translateY(0);
}

/* Burger scan (top to bottom) */
@keyframes burger-scan{
  0%, 70%, 100%{
    background:#fff;
  }
  80%{
    background: var(--orange);
  }
}

.mnav-brand{
  margin-top: 30px;
  padding-top: 22px;
  border-top: 1px solid rgba(255,255,255,.18);
  font-size: 18px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--orange);
  opacity: .9;
}

.mnav-legal{
  margin-top: 12px;
  display:flex;
  gap: 18px;
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.7);
}

.mnav-legal a{
  color: inherit;
}

.mnav-legal a:hover{
  color: inherit;
}

@media (prefers-reduced-motion: reduce){
  .mnav-inner,
  .mnav-link{
    transition: none;
    transform: none;
    opacity: 1;
  }

  .mnav.is-open .mnav-link{
    animation: none;
  }
}

/* =========================
   7) Hero
========================= */
.hero{
  flex: 0 0 auto;
  display:flex;
  align-items:flex-start;
  padding: 60px 0 84px;
}

.hero-inner{
  width: min(1200px, calc(100% - 80px));
  margin: 0 auto;
  padding: 0;
}

.hero-title{
  margin:0 0 12px;
  font-weight:650;
  text-transform: uppercase;
  letter-spacing:.04em;
  line-height: 1.02;
  font-size: clamp(33px, 5vw, 63px);
}

.hero-title,
.hero-title *{
  cursor: default;
  user-select: none;
}

.swap{
  display:inline-flex;
  align-items: baseline;
  white-space: nowrap;
  width: auto;
  gap: .35ch;
}
.swap-word{
  color: var(--orange);
  font-weight:750;
  pointer-events:none;
}
.swap-amp{
  color: rgba(255,255,255,.86);
  font-weight:650;
  pointer-events:none;
}

.hero-sub{
  margin:0 0 18px;
  color: var(--muted);
  font-weight:600;
  letter-spacing:.06em;
  text-transform: uppercase;
  font-size:14px;
  max-width:760px;
  line-height:1.55;
}

.hero-cta{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 12px 16px;
  border-radius:0;
  border: 1px solid rgba(255,255,255,.20);
  text-transform: uppercase;
  letter-spacing:.08em;
  font-weight:700;
  font-size:12px;
  background: transparent;
  transition: transform .2s ease, color .2s ease, border-color .2s ease, background .2s ease;
}
.btn.primary{
  background: rgba(255,255,255,.08);
  color: #fff;
}
.btn.ghost{ background: transparent; }

.btn:hover{
  color: inherit;
  border-color: rgba(255,255,255,.20);
  transform: none;
}

.services-cta-btn,
.footer-cta{
  animation: cta-breathe 3.2s ease-in-out infinite;
}

/* CTA breathing loop */
@keyframes cta-breathe{
  0%, 75%, 100%{
    transform: translateY(0);
    box-shadow: none;
  }
  85%{
    transform: translateY(-3px);
    box-shadow: 0 12px 28px rgba(255,56,0,.18);
  }
}

/* =========================
   8) Portfolio Reel (video section)
========================= */
.reel{
  height: 100vh;
  background: #000;
  margin: 0;
  position: relative;
  padding-top: 32px;
}

.reel-sticky{
  position: sticky;
  top: 0;
  height: 100vh;
  overflow: hidden;
  padding: 40px;
  background:#000;
}

.reel-inner{
  width:100%;
  height:100%;
  margin:0;
  padding:0;
  max-width:none;
}

.reel-media{
  width: min(1200px, 100%);
  aspect-ratio: 16 / 9;
  margin: 0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#000;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 8px;
  box-shadow: 0 40px 120px rgba(0,0,0,.6);
  position: relative;
  z-index: 2;
  overflow:hidden;
}

.reel-video{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

@media (min-width:701px){
  .reel-media{
    max-height: calc(100vh - 120px);
  }

  .reel-video{
    object-fit: contain;
    object-position: center;
  }
}

/* =========================
   9) Manifesto
========================= */
.manifesto{
  background:#fff;
  color:#111;
  padding: 110px 0 80px;
}

.manifesto-inner{
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 22px;
  display:flex;
  justify-content:flex-start;
}

.manifesto-text{
  margin: 0;
  font-size: 16px;
  line-height: 1.7;
  max-width: 52ch;
  color: rgba(0,0,0,.72);
  text-align: left;
  font-weight: 400;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 1.4s ease, transform 1.4s ease;
}

.manifesto-text.is-revealed{
  opacity: 1;
  transform: translateY(0);
}

/* =========================
   10) Industries / Vertical list
========================= */
.sectors{
  background:#fff;
  color:#111;
  padding: 40px 0 120px;
}

.sectors-inner{
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 22px;
}

.sectors-list{
  display:grid;
  gap: 28px;
}

.sectors-item{
  font-family: "Sohne","Inter","Helvetica Neue",Arial,sans-serif;
  font-size: clamp(34px, 5.2vw, 86px);
  line-height: 1.05;
  font-weight: 400;
  letter-spacing: -0.01em;
  color: #111;
  transition: color .4s ease;
}

.sectors-item.is-active{
  color: var(--orange);
}

/* =========================
   9) EDITORIAL PORTFOLIO
========================= */
.work{
  background:#fff;
  color:#111;
  padding: 90px 0 50px;
  position: relative;
  z-index: 3;
  margin-top: -1px;
}

.work-inner{
  max-width: 1480px;
  margin: 0 auto;
  padding: 0 48px;
  display:grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 80px;
  align-items:start;
}

.work-preview{
  position: sticky;
  top: 100px;
  height: calc(100vh - 160px);
  display:flex;
  align-items:center;
}

.work-frame{
  width:100%;
  aspect-ratio: 4 / 3;
  overflow:hidden;
  background:#fafafa;
}

.work-img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
  transition: opacity 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.work-listWrap{ padding-top: 0; }

.work-kicker{
  margin:0 0 16px;
  color: rgba(0,0,0,.45);
  letter-spacing:.16em;
  text-transform: uppercase;
  font-weight: 600;
  font-size: 11px;
}

.work-title{
  margin:0 0 80px;
  font-size: clamp(28px, 3.2vw, 42px);
  line-height: 1.1;
  font-weight: 500;
  letter-spacing: -.01em;
  color: #111;
}

.work-list{
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap: 0;
}

.work-li{
  margin:0;
  padding:0;
  border-top: 1px solid rgba(0,0,0,.08);
}
.work-li:last-child{
  border-bottom: 1px solid rgba(0,0,0,.08);
}

.work-item{
  width:100%;
  text-align:left;
  background:transparent;
  border:0;
  cursor:pointer;
  padding: 56px 0;
  color: rgba(0,0,0,.65);
  transition: color .3s cubic-bezier(0.4, 0, 0.2, 1),
              padding-left .3s cubic-bezier(0.4, 0, 0.2, 1);
}

.work-name{
  display:block;
  font-size: clamp(48px, 5.5vw, 88px);
  line-height: 0.95;
  font-weight: 500;
  letter-spacing: -.03em;
  margin-bottom: 20px;
  color: inherit;
}

.work-meta{
  display:block;
  margin-bottom: 16px;
  font-size: 12px;
  letter-spacing:.12em;
  text-transform: uppercase;
  color: rgba(0,0,0,.40);
  font-weight: 500;
}

.work-item.is-active{
  color: var(--orange);
  padding-left: 16px;
}
.work-item:hover:not(.is-active){
  color: rgba(0,0,0,.40);
  padding-left: 0;
}

.work-mobileImg{ display:none; }

/* Breathing space for last project */
@media (min-width: 901px){
  .work-list::after{
    content:"";
    display:block;
    height: 14vh;
  }
}

/* =========================
   10) Services
========================= */
.services{
  background:#fff;
  color:#111;
  padding: 110px 0;
}

.services-inner{
  max-width:1180px;
  margin:0 auto;
  padding:0 22px;
}

.services-kicker{
  margin:0 0 10px;
  color: rgba(0,0,0,.55);
  letter-spacing:.14em;
  text-transform: uppercase;
  font-weight: 800;
  font-size: 12px;
}

.services-title{
  margin:0 0 46px;
  font-size: 30px;
  line-height: 1.15;
  font-weight: 850;
  letter-spacing: -.02em;
}

.services-word{
  color: #111;
  transition: color 1.2s ease;
}

.services.is-revealed .services-word{
  color: var(--orange);
}

.services-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 34px;
}

.service{
  padding-top: 6px;
  border-top: 1px solid rgba(0,0,0,.12);
}

.service-name{
  margin:16px 0 10px;
  font-size: 20px;
  font-weight: 850;
  letter-spacing: -.01em;
}

.service-desc{
  margin:0 0 14px;
  color: rgba(0,0,0,.68);
  line-height: 1.55;
  font-size: 14px;
  max-width: 52ch;
}

.service-list{
  margin:0;
  padding:0;
  display:grid;
  gap: 8px;
  color: rgba(0,0,0,.78);
  font-size: 14px;
}

.service-list li{
  position: relative;
  padding-left: 14px;
}

.service-list li::before{
  content:"";
  width:6px;
  height:6px;
  border-radius:999px;
  background: var(--orange);
  position:absolute;
  left:0;
  top: 0.65em;
  transform: translateY(-50%);
}

/* =========================
   11) Contact
========================= */
.contact{
  background:#000;
  color:#fff;
  padding: 120px 0;
}

.contact-inner{
  max-width:1180px;
  margin:0 auto;
  padding:0 22px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items:start;
}

.contact-kicker{
  margin:0 0 10px;
  color: rgba(255,255,255,.65);
  letter-spacing:.14em;
  text-transform: uppercase;
  font-weight: 800;
  font-size: 12px;
}

.contact-title{
  margin:0 0 14px;
  color:#fff;
  font-size: 38px;
  line-height: 1.08;
  font-weight: 900;
  letter-spacing: -.02em;
}

.contact-sub{
  margin:0;
  color: rgba(255,255,255,.88);
  line-height: 1.65;
  max-width: 52ch;
}

.contact-form{
  display:grid;
  gap: 16px;
}

.field{
  display:grid;
  gap: 8px;
}

.field-label{
  font-size: 12px;
  letter-spacing:.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.70);
  font-weight: 800;
}

.field-input{
  width:100%;
  padding: 14px 16px;
  border-radius: 0;
  border: 1px solid rgba(255,255,255,.30);
  background: rgba(255,255,255,.06);
  color: #fff;
  outline: none;
  font-size: 14px;
}

.field-input::placeholder{
  color: rgba(255,255,255,.55);
}

.field-input:focus{
  border-color: rgba(255,56,0,.95);
  box-shadow: 0 0 0 3px rgba(255,56,0,.18);
}

.field-textarea{
  resize: vertical;
  min-height: 160px;
}

select.field-input{
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  padding-right:52px;
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(255,255,255,.95) 50%),
    linear-gradient(135deg, rgba(255,255,255,.95) 50%, transparent 50%);
  background-position:
    calc(100% - 22px) 50%,
    calc(100% - 16px) 50%;
  background-size:
    7px 7px,
    7px 7px;
  background-repeat:no-repeat;
}

.contact-btn{
  justify-self: start;
  background:#fff;
  color:#000;
  border: none;
  padding: 14px 22px;
  font-weight: 900;
  letter-spacing: .10em;
  text-transform: uppercase;
  border-radius: 0;
  cursor:pointer;
  transition: background .2s ease, color .2s ease, transform .2s ease;
}

.contact-btn:hover{
  background: transparent;
  color: var(--orange);
  transform: none;
}

/* =========================
   12) Mobile Responsive
========================= */
@media (max-width:700px){
  body{
    padding-top: 40px;
  }

  body.page-shell{
    padding-top: 44px;
  }

  body.page-shell .site-header{
    padding: 8px 20px;
  }

  .site-header{
    padding: 9px 20px;
  }

  body.page-shell .site-header{
    padding: 8px 20px;
  }

  .nav-left,.nav-right{
    display:none;
  }

  .nav-burger{
    display:inline-flex;
    flex-direction:column;
    justify-content:center;
  }

  .hero{ 
    padding-top: 48px;
    padding-bottom: 40px;
  }

  .hero-inner{
    padding: 0 20px;
  }

  .swap{
    width: auto;
  }

  .reel{
    height: 70vh;
    padding-top: 20px;
  }

  .reel-sticky{
    height: 70vh;
    padding: 14px;
  }

  .reel-media{
    aspect-ratio: 16 / 9;
    border-radius: 6px;
  }

}

@media (max-width:1200px){
  .hero-inner{
    width: calc(100% - 64px);
  }
}

@media (max-width:700px){
  .hero-inner{
    width: calc(100% - 40px);
  }
}

@media (max-width:900px){
  .page{
    padding: 120px 0 90px;
  }

  .page-title{
    font-size: clamp(30px, 8vw, 48px);
  }

  .portfolio-hero{
    padding: 120px 0 60px;
  }

  .portfolio-list{
    padding-bottom: 100px;
  }

  .portfolio-item{
    padding: 0;
  }

  .portfolio-name{
    font-size: clamp(28px, 6.5vw, 42px);
  }

  .portfolio-items{
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .services-hero{
    padding: 120px 0 70px;
  }

  .services-blocks-inner{
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .process{
    padding: 70px 0 90px;
  }

  .process-steps{
    grid-template-columns: 1fr;
    gap: 22px;
  }

  .services-cta{
    padding: 80px 0 110px;
  }

  .about-hero{
    padding: 120px 0 70px;
  }

  .about-section{
    padding: 60px 0;
  }

  .about-pillars{
    font-size: clamp(22px, 6.5vw, 30px);
  }

  .case-hero{
    padding: 120px 0 60px;
  }

  .case-section{
    padding: 50px 0;
  }

  .manifesto{
    padding: 90px 0 60px;
  }

  .manifesto-inner{
    justify-content:flex-start;
  }

  .manifesto-text{
    text-align: left;
    max-width: none;
  }

  .sectors{
    padding: 90px 0;
  }

  .sectors-list{
    gap: 20px;
  }

  .sectors-item{
    font-size: clamp(28px, 8.5vw, 48px);
  }

  .work{
    padding: 80px 0 70px;
  }

  .work-inner{
    grid-template-columns: 1fr;
    gap: 0;
    padding: 0;
  }

  .work-preview{
    display:none;
  }

  .work-listWrap{
    padding: 0 20px;
  }

  .work-kicker{
    margin-bottom: 12px;
  }

  .work-title{
    margin-bottom: 48px;
    font-size: 32px;
  }

  .work-li{
    border-top: none;
    border-bottom: none;
    margin-bottom: 72px;
  }

  .work-li:last-child{
    margin-bottom: 0;
    border-bottom: none;
  }

  .work-listWrap.is-swipe-mode .work-li{
    display: none;
    margin-bottom: 0;
  }

  .work-listWrap.is-swipe-mode .work-li.is-mobile-visible{
    display: block;
  }

  .work-item{
    padding: 0;
    transform: none !important;
    cursor: default;
  }

  .work-item:hover{
    padding-left: 0;
  }

  .work-item.is-active{
    padding-left: 0;
    color: rgba(0,0,0,.65);
  }

  .work-mobileImg{
    display:block;
    width: 100%;
    aspect-ratio: 4 / 3;
    height: auto;
    object-fit: cover;
    margin-bottom: 24px;
    border-radius: 8px;
  }

  .work-name{
    font-size: clamp(36px, 9vw, 52px);
    margin-bottom: 14px;
    line-height: 1;
  }

  .work-meta{
    margin-bottom: 12px;
    font-size: 11px;
  }

  .services{
    padding: 85px 0; 
  }

  .services .services-title{ 
    margin-bottom: 34px; 
  }

  .services .services-grid{ 
    grid-template-columns: 1fr; 
    gap: 26px; 
  }

  .contact{
    padding: 90px 0;
  }

  .contact-inner{
    grid-template-columns: 1fr;
    gap: 28px;
  }
}

@media (min-width:901px) and (max-width:1200px){
  .work-inner{
    gap: 60px;
    padding: 0 32px;
  }

  .work-preview{
    top: 80px;
  }

  .work-name{
    font-size: clamp(42px, 5vw, 68px);
  }
}

/* =========================================================
   FOOTER (ORANGE)
========================================================= */
.footer{
  background: var(--orange);
  color: #fff;
  padding: 92px 0 60px;
}

.footer-inner{
  max-width:1180px;
  margin:0 auto;
  padding:0 22px;
}

.footer-top{
  display:flex;
  justify-content:space-between;
  gap: 64px;
  align-items:flex-start;
  padding-bottom: 42px;
  border-bottom: 1px solid rgba(255,255,255,.28);
}

.footer-kicker{
  margin:0 0 14px;
  font-size: 12px;
  letter-spacing:.18em;
  text-transform: uppercase;
  font-weight: 900;
  color: rgba(255,255,255,.85);
}

.footer-title{
  margin:0 0 14px;
  font-size: clamp(30px, 3.2vw, 48px);
  line-height: 1.02;
  font-weight: 900;
  letter-spacing: -.03em;
}

.footer-sub{
  margin:0 0 26px;
  font-size: 16px;
  line-height: 1.6;
  color: rgba(255,255,255,.92);
  max-width: 52ch;
}

/* CTA */
.footer-cta{
  display:inline-flex;
  align-items:center;
  gap: 14px;
  padding: 14px 18px;
  border: 1px solid rgba(255,255,255,.65);
  background: rgba(255,255,255,.12);
  color:#fff;
  text-transform: uppercase;
  letter-spacing:.12em;
  font-weight: 900;
  font-size: 12px;
  transition: transform .2s ease, background .2s ease, border-color .2s ease;
}
.footer-cta:hover{
  transform: none;
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.65);
}
.footer-ctaArrow{
  font-size: 16px;
  line-height: 1;
}

/* Nav right */
.footer-nav{
  display:grid;
  gap: 18px;
  text-transform: uppercase;
  letter-spacing:.14em;
  font-weight: 900;
  font-size: 12px;
}
.footer-link{
  color: rgba(255,255,255,.92);
}
.footer-link:hover{
  color: rgba(255,255,255,.92);
  text-decoration: none;
}

/* Bottom */
.footer-bottom{
  padding-top: 26px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 24px;
}

.footer-copy{
  margin:0;
  font-weight: 900;
  letter-spacing:.10em;
  text-transform: uppercase;
  font-size: 12px;
  color: rgba(255,255,255,.92);
}

.footer-socials{
  display:flex;              /* desktop: en ligne à droite */
  gap: 22px;
}
.footer-social{
  color: rgba(255,255,255,.92);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing:.12em;
  font-size: 12px;
  text-decoration: underline;
  text-underline-offset: 7px;
  text-decoration-thickness: 2px;
  text-decoration-color: rgba(255,255,255,.35);
}
.footer-social:hover{
  text-decoration-color: rgba(255,255,255,.35);
}

/* Mobile */
@media (max-width:900px){
  .footer{ padding: 64px 0 48px; }

  .footer-top{
    flex-direction: column;
    gap: 28px;
  }

  .footer-nav{
    display: grid;
    grid-template-rows: repeat(2, auto);
    grid-auto-flow: column;
    column-gap: 34px;
    row-gap: 12px;
    width: fit-content;
  }

  .footer-bottom{
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
  }

  .footer-socials{
    flex-direction: row;
    gap: 14px;
    align-items:center;
  }
}

/* Contact section margin reset */
#contact.contact p,
#contact.contact h2,
#contact.contact form{
  margin-bottom: 0;
}

/* Mobile work title accent */

@media (max-width:900px){
  .work-name{
    color: var(--orange);
  }
}

.footer{
  margin-top: -1px;
  margin-bottom: 0;
}
