/* ============================================
   RV TEXTILES — editorial fabric atelier
   ============================================ */

:root{
  --ink: #0e0c0a;
  --ink-soft: #2a2622;
  --paper: #f5efe6;
  --paper-2: #ece4d6;
  --cream: #fbf7f0;
  --rust: #b04a1f;
  --indigo: #1f2c44;
  --gold: #c69a4f;
  --line: rgba(14,12,10,.16);
  --line-soft: rgba(14,12,10,.08);
  --serif: 'Fraunces', 'Times New Roman', serif;
  --sans: 'Inter', system-ui, sans-serif;
  --mono: 'Space Mono', monospace;
  --ease: cubic-bezier(.2,.7,.2,1);
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-font-smoothing:antialiased; }
body{
  font-family: var(--sans);
  color: var(--ink);
  background: var(--paper);
  font-size: 16px;
  line-height: 1.55;
  overflow-x: hidden;
  cursor: none;
}

img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ border:none; font:inherit; cursor:pointer; background:none; color:inherit; }

/* ---------------- Custom cursor ---------------- */
.cursor{
  position: fixed; top:0; left:0;
  width: 36px; height:36px; border-radius:50%;
  border:1px solid var(--ink);
  pointer-events:none; z-index:9999;
  transform: translate(-50%,-50%);
  transition: width .25s var(--ease), height .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease);
  mix-blend-mode: difference;
}
.cursor-dot{
  position: fixed; top:0; left:0;
  width:5px; height:5px; border-radius:50%;
  background: var(--ink);
  pointer-events:none; z-index:9999;
  transform: translate(-50%,-50%);
  mix-blend-mode: difference;
}
.cursor.hover{ width:64px; height:64px; background: var(--ink); border-color:var(--ink); }
@media (max-width: 900px){
  .cursor, .cursor-dot{ display:none; }
  body{ cursor:auto; }
}

/* ---------------- Loader ---------------- */
.loader{
  position: fixed; inset:0; z-index:10000;
  background: var(--ink); color: var(--paper);
  display:flex; align-items:center; justify-content:center;
  transition: opacity .8s var(--ease), visibility .8s var(--ease);
}
.loader.gone{ opacity:0; visibility:hidden; }
.loader-inner{ text-align:center; }
.loader-text{
  display:block; font-family:var(--serif);
  font-size: clamp(2.5rem, 8vw, 6rem);
  font-weight: 300; line-height: .95;
  letter-spacing:-.02em;
}
.loader-text:nth-child(2){ font-style: italic; }
.loader-bar{
  margin-top: 2rem; width: 240px; height:2px;
  background: rgba(255,255,255,.15);
  overflow:hidden; margin-left:auto; margin-right:auto;
}
.loader-bar-fill{
  height:100%; width:0%;
  background: var(--paper);
  animation: loadBar 1.6s var(--ease) forwards;
}
@keyframes loadBar{ to{ width:100%; } }

/* ---------------- Topbar marquee ---------------- */
.topbar{
  background: var(--ink); color: var(--paper);
  border-bottom: 1px solid rgba(255,255,255,.12);
  overflow:hidden; position: relative; z-index: 60;
}
.marquee{ overflow:hidden; }
.marquee-track{
  display:inline-flex; align-items:center; gap: 2.5rem;
  padding: .65rem 0;
  white-space:nowrap;
  font-family: var(--mono); font-size:.72rem; letter-spacing:.18em;
  text-transform: uppercase;
  animation: marquee 38s linear infinite;
}
.marquee-track span{ display:inline-block; }
@keyframes marquee{
  from{ transform: translateX(0); }
  to{ transform: translateX(-50%); }
}

/* ---------------- Header ---------------- */
.header{
  position: sticky; top:0; z-index:50;
  display:grid; grid-template-columns: auto 1fr auto;
  align-items:center;
  padding: 1.1rem 2rem;
  background: rgba(245,239,230,.86);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--line-soft);
  transition: padding .35s var(--ease), background .35s var(--ease);
}
.header.scrolled{ padding: .75rem 2rem; background: rgba(245,239,230,.96); }
.logo{
  display:flex; align-items:center; gap:.7rem;
}
.logo-mark{
  display:inline-grid; place-items:center;
  width: 38px; height:38px;
  border-radius:50%;
  background: var(--ink); color: var(--paper);
  font-family: var(--serif); font-weight: 700; font-style: italic;
  font-size: 1rem; letter-spacing: .02em;
}
.logo-text{
  font-family: var(--serif); font-size: 1.05rem;
  letter-spacing:.02em; font-weight:500;
}
.logo-text i{ font-style:normal; opacity:.5; margin: 0 .35rem; }
.logo-text em{ font-style: italic; font-weight: 400; }

.nav{
  justify-self:center;
  display:flex; align-items:center; gap: 1.6rem;
}
.nav a{
  font-size: .82rem; letter-spacing: .04em;
  position: relative;
  padding: .25rem 0;
  transition: color .25s var(--ease);
}
.nav a::after{
  content:""; position:absolute; left:0; right:0; bottom:-2px;
  height:1px; background: var(--ink);
  transform: scaleX(0); transform-origin: right center;
  transition: transform .35s var(--ease);
}
.nav a:hover::after{ transform: scaleX(1); transform-origin: left center; }
.nav-privacy{
  font-style: italic; font-family: var(--serif);
  border:1px solid var(--line); border-radius: 99px;
  padding: .35rem .85rem !important;
}
.nav-privacy::after{ display:none; }
.nav-privacy:hover{ background: var(--ink); color: var(--paper); border-color: var(--ink); }

.header-cta{
  display:inline-flex; align-items:center; gap:.55rem;
  background: var(--ink); color: var(--paper);
  padding: .7rem 1.1rem; border-radius: 99px;
  font-size: .82rem; letter-spacing: .03em;
  transition: transform .3s var(--ease), background .3s var(--ease);
}
.header-cta:hover{ transform: translateY(-2px); background: var(--rust); }
.header-cta .arrow{ display:inline-block; transition: transform .3s var(--ease); }
.header-cta:hover .arrow{ transform: translate(3px,-3px); }

@media (max-width: 1100px){
  .nav{ display:none; }
  .header{ grid-template-columns: auto 1fr auto; }
}

/* ---------------- Buttons ---------------- */
.btn{
  display:inline-flex; align-items:center; gap:.6rem;
  padding: .95rem 1.4rem;
  border-radius: 99px;
  font-size: .85rem; letter-spacing: .04em;
  border: 1px solid transparent;
  transition: transform .35s var(--ease), background .35s var(--ease), color .35s var(--ease), border-color .35s var(--ease);
}
.btn .arrow{ display:inline-block; transition: transform .35s var(--ease); }
.btn:hover{ transform: translateY(-3px); }
.btn:hover .arrow{ transform: translate(3px,-3px); }
.btn-dark{ background: var(--ink); color: var(--paper); }
.btn-dark:hover{ background: var(--rust); }
.btn-light{ background: var(--paper); color: var(--ink); }
.btn-light:hover{ background: var(--cream); }
.btn-ghost{ border-color: var(--ink); color: var(--ink); }
.btn-ghost:hover{ background: var(--ink); color: var(--paper); }
.btn-block{ width:100%; justify-content:center; padding: 1.1rem 1.4rem; }

/* ---------------- HERO ---------------- */
.hero{
  position: relative;
  padding: 3rem 2rem 5rem;
  min-height: calc(100vh - 80px);
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 2.5rem;
  align-items: center;
  overflow: hidden;
}
.hero-grid{
  position: relative;
  height: 78vh;
  min-height: 560px;
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-template-rows: repeat(8, 1fr);
  gap: .9rem;
}
.hero-img{ position: relative; overflow:hidden; border-radius: 4px; }
.hero-img img{ width:100%; height:100%; object-fit:cover; transition: transform 1.6s var(--ease); }
.hero-img:hover img{ transform: scale(1.06); }
.hero-img-1{ grid-column: 1/5; grid-row: 1/6; }
.hero-img-2{ grid-column: 5/7; grid-row: 1/4; }
.hero-img-3{ grid-column: 5/7; grid-row: 4/9; }
.hero-img-4{ grid-column: 1/5; grid-row: 6/9; }

.hero-img::after{
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,.18));
  pointer-events:none;
}

.hero-content{
  position: relative; z-index: 5;
  padding-right: 1rem;
}
.hero-meta{
  display:flex; gap: .7rem; align-items:center;
  font-family: var(--mono); font-size:.72rem;
  letter-spacing: .18em; text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: 2rem;
}
.hero-meta-dot{ font-size:.55rem; opacity:.55; }

.hero-title{
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(3.2rem, 8vw, 7.5rem);
  line-height: .92;
  letter-spacing: -.025em;
  color: var(--ink);
}
.hero-title .line{
  display:block; overflow:hidden;
}
.hero-title .line > *{
  display:inline-block;
  transform: translateY(110%);
  animation: riseIn 1.1s var(--ease) forwards;
}
.hero-title .line:nth-child(1) > *{ animation-delay: .1s; }
.hero-title .line:nth-child(2) > *{ animation-delay: .25s; }
.hero-title .line:nth-child(3) > *{ animation-delay: .4s; }
.hero-title .line:nth-child(4) > *{ animation-delay: .55s; }
@keyframes riseIn{ to{ transform: translateY(0); } }
.hero-title em{ font-style: italic; color: var(--rust); font-weight: 400; }
.hero-title strong{ font-weight: 700; font-style: italic; }

.hero-lede{
  margin-top: 1.6rem;
  font-size: 1.05rem; max-width: 480px;
  color: var(--ink-soft);
}
.hero-lede b{ font-weight:600; color: var(--ink); }

.hero-actions{
  display:flex; gap:.8rem; flex-wrap:wrap;
  margin-top: 2rem;
}
.hero-counters{
  margin-top: 3rem;
  display: grid;
  grid-template-columns: repeat(4, auto);
  gap: 2rem;
  border-top: 1px solid var(--line);
  padding-top: 1.6rem;
}
.hero-counters > div{ display:flex; flex-direction:column; gap:.2rem; }
.hero-counters .num{
  font-family: var(--serif);
  font-size: 2.4rem; font-weight:300; line-height:1;
  font-feature-settings: "lnum";
}
.hero-counters .cap{
  font-family: var(--mono);
  font-size:.7rem; letter-spacing:.18em;
  text-transform:uppercase; color: var(--ink-soft);
}
.hero-scroll{
  position: absolute; bottom: 1.5rem; left: 50%;
  transform: translateX(-50%);
  font-family: var(--mono); font-size:.7rem;
  letter-spacing: .25em; text-transform: uppercase;
}
.hero-scroll span{
  display:inline-block;
  animation: bounceY 2s var(--ease) infinite;
  margin-left: .4rem;
}
@keyframes bounceY{
  0%,100%{ transform: translateY(0); }
  50%{ transform: translateY(8px); }
}

@media (max-width: 1100px){
  .hero{ grid-template-columns: 1fr; }
  .hero-grid{ height: 60vh; min-height: 440px; order:2; }
  .hero-content{ order:1; }
  .hero-counters{ grid-template-columns: repeat(2, 1fr); gap: 1.4rem; }
}

/* ---------------- Statement ---------------- */
.statement{
  padding: 9rem 2rem;
  max-width: 1400px; margin: 0 auto;
  text-align: center;
  position: relative;
}
.statement-tag{
  font-family: var(--mono); font-size:.72rem;
  letter-spacing:.22em; text-transform:uppercase;
  color: var(--ink-soft); margin-bottom: 2rem;
}
.statement-text{
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(1.6rem, 3.6vw, 3.4rem);
  line-height: 1.18;
  letter-spacing: -.012em;
  max-width: 1100px; margin: 0 auto;
}
.statement-text em{ font-style: italic; color: var(--rust); }
.statement-text .hl{
  border-bottom: 2px solid var(--gold);
  padding-bottom: 2px;
}
.statement-foot{
  margin-top: 3rem;
  display:flex; justify-content:space-between; align-items:center;
  border-top: 1px solid var(--line);
  padding-top: 1.4rem;
  font-family: var(--mono);
  font-size: .72rem; letter-spacing: .18em;
  text-transform: uppercase; color: var(--ink-soft);
}
.statement-foot b{ color: var(--ink); font-family: var(--serif); font-weight:700; font-style:italic; }
@media (max-width: 700px){
  .statement{ padding: 5rem 1.5rem; }
  .statement-foot{ flex-direction:column; gap:.6rem; }
}

/* ---------------- Section helpers ---------------- */
.eyebrow{
  font-family: var(--mono); font-size:.72rem;
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: 1.5rem;
  display: inline-block;
  border-top: 1px solid var(--line);
  padding-top: 1rem;
}
.eyebrow.light{ color: rgba(255,255,255,.7); border-top-color: rgba(255,255,255,.2); }
.section-title{
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(2.2rem, 5.4vw, 4.8rem);
  line-height: 1;
  letter-spacing: -.02em;
}
.section-title em{ font-style: italic; color: var(--rust); }
.section-title.light em{ color: var(--gold); }
.section-title.huge{ font-size: clamp(3rem, 9vw, 8rem); line-height:.92; }
.section-title.light{ color: var(--paper); }
.section-sub{
  margin-top: 1.2rem;
  max-width: 560px;
  color: var(--ink-soft);
  font-size: 1rem;
}

/* ---------------- COLLECTIONS ---------------- */
.collections{
  padding: 6rem 2rem 8rem;
  background: var(--cream);
  border-top: 1px solid var(--line);
}
.section-head{ max-width: 1400px; margin: 0 auto 4rem; }
.collection-grid{
  max-width: 1400px; margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1.5rem;
}
.col-card{
  grid-column: span 2;
  background: var(--paper);
  border: 1px solid var(--line-soft);
  overflow: hidden;
  position: relative;
  transition: transform .5s var(--ease), box-shadow .5s var(--ease);
}
.col-card:hover{
  transform: translateY(-6px);
  box-shadow: 0 30px 60px -30px rgba(14,12,10,.25);
}
.col-card.lg{ grid-column: span 3; }
.col-card-img{
  aspect-ratio: 4/3;
  overflow: hidden;
  position: relative;
}
.col-card.lg .col-card-img{ aspect-ratio: 16/10; }
.col-card-img img{
  width:100%; height:100%; object-fit:cover;
  transition: transform 1.4s var(--ease), filter .5s var(--ease);
}
.col-card:hover .col-card-img img{ transform: scale(1.07); }
.col-card-img::after{
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, transparent 60%, rgba(14,12,10,.22));
}
.col-card-body{
  padding: 1.5rem 1.5rem 1.8rem;
  display: flex; flex-direction:column; gap:.4rem;
}
.col-num{
  font-family: var(--mono);
  font-size: .7rem; letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink-soft);
}
.col-card h3{
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(1.4rem, 2.4vw, 2rem);
  line-height: 1.05;
  letter-spacing: -.01em;
}
.col-cat{
  font-size: .82rem;
  color: var(--ink-soft);
  font-style: italic;
}
.col-desc{
  font-size: .92rem;
  color: var(--ink-soft);
  margin-top:.4rem;
}
.col-tags{
  list-style:none; display:flex; flex-wrap:wrap; gap:.4rem;
  margin-top:.8rem;
}
.col-tags li{
  font-family: var(--mono);
  font-size:.65rem; letter-spacing:.12em;
  text-transform:uppercase;
  padding: .35rem .6rem;
  border:1px solid var(--line);
  border-radius: 99px;
  color: var(--ink-soft);
}

@media (max-width: 1000px){
  .collection-grid{ grid-template-columns: repeat(2, 1fr); }
  .col-card, .col-card.lg{ grid-column: span 1; }
}
@media (max-width: 600px){
  .collection-grid{ grid-template-columns: 1fr; }
}

/* ---------------- PROCESS ---------------- */
.process{
  padding: 7rem 2rem 8rem;
  background: var(--ink);
  color: var(--paper);
  position: relative;
  overflow: hidden;
}
.process::before{
  content:""; position:absolute; inset:0;
  background-image:
    repeating-linear-gradient(0deg, rgba(255,255,255,.04) 0 1px, transparent 1px 60px),
    repeating-linear-gradient(90deg, rgba(255,255,255,.04) 0 1px, transparent 1px 60px);
  pointer-events:none;
  mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
}
.process-head{ max-width: 1400px; margin: 0 auto 4rem; position:relative; z-index:2; }
.section-title.light br{ display:block; }
.process-track{
  max-width: 1400px; margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 1rem;
  position: relative; z-index:2;
}
.step{
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  padding: 1rem;
  display:flex; flex-direction:column; gap: 1rem;
  transition: background .35s var(--ease), transform .35s var(--ease), border-color .35s var(--ease);
}
.step:hover{
  background: rgba(255,255,255,.08);
  border-color: rgba(198,154,79,.5);
  transform: translateY(-6px);
}
.step-img{
  aspect-ratio: 4/5; overflow:hidden;
}
.step-img img{
  width:100%; height:100%; object-fit:cover;
  filter: grayscale(.3) contrast(1.05);
  transition: transform 1.2s var(--ease), filter .6s var(--ease);
}
.step:hover .step-img img{ transform: scale(1.08); filter: grayscale(0); }
.step-num{
  font-family: var(--mono);
  font-size: .7rem; letter-spacing: .2em;
  color: var(--gold);
}
.step-meta h4{
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.15rem;
  margin: .3rem 0 .5rem;
}
.step-meta p{
  font-size: .82rem;
  color: rgba(255,255,255,.65);
  line-height: 1.5;
}
@media (max-width: 1100px){
  .process-track{ grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 700px){
  .process-track{ grid-template-columns: repeat(2, 1fr); }
}

/* ---------------- MATERIAL ---------------- */
.material{
  padding: 8rem 2rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  max-width: 1400px;
  margin: 0 auto;
  align-items: center;
}
.material-img-wrap{
  position: relative;
  height: 660px;
}
.m-img{
  position: absolute;
  border-radius: 4px;
  object-fit: cover;
  box-shadow: 0 20px 50px -30px rgba(14,12,10,.4);
  transition: transform .8s var(--ease);
}
.m-img-a{
  width: 70%; height: 70%;
  top: 0; left: 0;
}
.m-img-b{
  width: 50%; height: 50%;
  bottom: 0; right: 0;
  z-index: 2;
}
.m-img-c{
  width: 38%; height: 38%;
  top: 8%; right: 0;
  z-index: 3;
}
.material-img-wrap:hover .m-img-a{ transform: translate(-6px, -6px); }
.material-img-wrap:hover .m-img-b{ transform: translate(6px, 6px); }
.material-img-wrap:hover .m-img-c{ transform: translate(-4px, 8px); }

.material-lede{
  margin-top: 1.5rem;
  font-size: 1.05rem; color: var(--ink-soft);
  max-width: 500px;
}
.material-stats{
  margin-top: 3rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.4rem;
}
.material-stats > div{
  border-top: 1px solid var(--ink);
  padding-top: 1rem;
}
.material-stats span{
  font-family: var(--serif);
  font-weight: 300;
  font-size: 2.2rem;
  display:block; line-height: 1;
  letter-spacing: -.02em;
}
.material-stats p{
  margin-top: .6rem;
  font-size: .85rem;
  color: var(--ink-soft);
  line-height: 1.5;
}

@media (max-width: 1000px){
  .material{ grid-template-columns: 1fr; gap: 3rem; padding: 5rem 1.5rem; }
  .material-img-wrap{ height: 460px; }
}

/* ---------------- GALLERY ---------------- */
.gallery{
  padding: 8rem 2rem;
  background: var(--paper-2);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.gallery-head{ max-width: 1400px; margin: 0 auto 4rem; text-align: center; }
.gallery-head .eyebrow{ display:inline-block; }
.gallery-head .section-sub{ margin: 1.4rem auto 0; }
.gallery-grid{
  max-width: 1400px; margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.4rem;
}
.g-item{
  position: relative;
  overflow: hidden;
  aspect-ratio: 3/4;
  cursor: none;
}
.g-item img{
  width:100%; height:100%; object-fit:cover;
  transition: transform 1.4s var(--ease), filter .6s var(--ease);
}
.g-item::before{
  content:"";
  position: absolute; inset:0;
  background: var(--c);
  mix-blend-mode: multiply;
  opacity: 0;
  transition: opacity .5s var(--ease);
  z-index: 2;
}
.g-item:hover::before{ opacity:.5; }
.g-item:hover img{ transform: scale(1.08); }
.g-item figcaption{
  position: absolute; left: 1rem; bottom: 1rem;
  z-index: 3;
  color: var(--paper);
  transform: translateY(20px);
  opacity: 0;
  transition: transform .4s var(--ease), opacity .4s var(--ease);
}
.g-item:hover figcaption{ transform: translateY(0); opacity: 1; }
.g-item figcaption b{
  display:block;
  font-family: var(--serif);
  font-weight: 500;
  font-size: 1.4rem;
  font-style: italic;
}
.g-item figcaption span{
  font-family: var(--mono);
  font-size:.7rem;
  letter-spacing:.18em;
  text-transform:uppercase;
}

@media (max-width: 900px){
  .gallery-grid{ grid-template-columns: repeat(2, 1fr); }
}

/* ---------------- EXPERTISE ---------------- */
.expertise{
  padding: 8rem 2rem;
  background: var(--paper);
}
.exp-row{ max-width: 1400px; margin: 0 auto 4rem; }
.exp-tag{
  font-family: var(--mono); font-size:.72rem;
  letter-spacing:.22em; text-transform:uppercase;
  color: var(--ink-soft); margin-bottom: 1.5rem;
  border-top: 1px solid var(--line); padding-top: 1rem;
  display:inline-block;
}
.exp-title{
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(2.4rem, 6.5vw, 6rem);
  line-height: .98;
  letter-spacing: -.02em;
  display:flex; flex-wrap: wrap; gap: 1.2rem 1.8rem;
}
.exp-title span{ display:inline-block; }
.exp-title em{ font-style: italic; color: var(--rust); }

.exp-grid{
  max-width: 1400px; margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.4rem;
}
.exp-card{
  background: var(--cream);
  border: 1px solid var(--line-soft);
  overflow:hidden;
  display:flex; flex-direction:column;
  transition: transform .5s var(--ease);
}
.exp-card:hover{ transform: translateY(-6px); }
.exp-card img{
  width:100%; aspect-ratio: 4/3; object-fit:cover;
  transition: transform 1.2s var(--ease);
}
.exp-card:hover img{ transform: scale(1.06); }
.exp-body{
  padding: 1.4rem 1.4rem 1.8rem;
}
.exp-body span{
  font-family: var(--mono); font-size: .7rem;
  letter-spacing:.2em; color: var(--ink-soft);
  text-transform: uppercase;
}
.exp-body h4{
  font-family: var(--serif);
  font-weight: 500;
  font-size: 1.4rem;
  margin: .4rem 0 .6rem;
}
.exp-body p{
  font-size: .9rem;
  color: var(--ink-soft);
  line-height: 1.5;
}
@media (max-width: 1000px){
  .exp-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px){
  .exp-grid{ grid-template-columns: 1fr; }
}

/* ---------------- CUSTOM ---------------- */
.custom{
  position: relative;
  padding: 8rem 2rem;
  color: var(--paper);
  overflow: hidden;
}
.custom-bg{
  position: absolute; inset:0;
  z-index: 0;
}
.custom-bg img{
  width:100%; height:100%; object-fit:cover;
  filter: brightness(.42) saturate(1.1);
}
.custom-bg::after{
  content:""; position: absolute; inset: 0;
  background: linear-gradient(160deg, rgba(14,12,10,.7), rgba(14,12,10,.55));
}
.custom-inner{
  position: relative; z-index: 2;
  max-width: 1400px; margin: 0 auto;
}
.custom-title{
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(2rem, 5.5vw, 5rem);
  line-height: 1.05;
  letter-spacing: -.02em;
  margin-bottom: 3rem;
  max-width: 1100px;
}
.custom-title em{ font-style: italic; color: var(--gold); }
.custom-cols{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  margin-bottom: 3rem;
}
.custom-cols > div{
  border-top: 1px solid rgba(255,255,255,.25);
  padding-top: 1rem;
}
.custom-cols h5{
  font-family: var(--serif);
  font-weight: 500;
  font-size: 1.15rem;
  margin-bottom:.6rem;
}
.custom-cols p{
  font-size: .88rem;
  color: rgba(255,255,255,.72);
  line-height: 1.55;
}
@media (max-width: 1000px){
  .custom-cols{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px){
  .custom-cols{ grid-template-columns: 1fr; }
}

/* ---------------- PRESS ---------------- */
.press{
  padding: 7rem 2rem 7rem;
  max-width: 1400px; margin: 0 auto;
}
.press-head{ margin-bottom: 3rem; }
.press-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
}
.press blockquote{
  border-top: 1px solid var(--ink);
  padding-top: 1.5rem;
}
.press blockquote p{
  font-family: var(--serif);
  font-weight: 300;
  font-size: 1.4rem;
  line-height: 1.4;
  letter-spacing: -.01em;
  color: var(--ink);
}
.press blockquote cite{
  display:block;
  margin-top: 1.4rem;
  font-family: var(--mono);
  font-size: .72rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-style: normal;
  color: var(--ink-soft);
}
@media (max-width: 900px){
  .press-grid{ grid-template-columns: 1fr; }
}

/* ---------------- CONTACT ---------------- */
.contact{
  padding: 8rem 2rem;
  background: var(--cream);
  border-top: 1px solid var(--line);
}
.contact-grid{
  max-width: 1400px; margin: 0 auto;
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 5rem;
  align-items: start;
}
.contact-title{
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(2.4rem, 6vw, 5rem);
  line-height: 1;
  letter-spacing: -.02em;
}
.contact-title em{ font-style: italic; color: var(--rust); }
.contact-lede{
  margin-top: 1.4rem;
  max-width: 480px;
  color: var(--ink-soft);
}
.contact-blocks{
  margin-top: 3rem;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
}
.cb{
  border-top: 1px solid var(--ink);
  padding-top: 1rem;
}
.cb-label{
  font-family: var(--mono);
  font-size: .72rem;
  letter-spacing: .2em;
  color: var(--ink-soft);
  text-transform: uppercase;
  margin-bottom: .6rem;
}
.cb-value{
  font-family: var(--serif);
  font-size: 1.25rem;
  line-height: 1.35;
  font-weight: 400;
}
.cb-link{
  border-bottom: 1px solid var(--ink);
  display: inline-block;
  transition: color .3s var(--ease), border-color .3s var(--ease);
}
.cb-link:hover{ color: var(--rust); border-color: var(--rust); }

.contact-right{
  background: var(--paper);
  padding: 2rem;
  border: 1px solid var(--line-soft);
  display:flex; flex-direction:column; gap: 1.2rem;
  position: relative;
}
.contact-right label{
  display:flex; flex-direction:column; gap:.5rem;
}
.contact-right span{
  font-family: var(--mono);
  font-size: .68rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink-soft);
}
.contact-right input,
.contact-right textarea{
  font-family: var(--serif);
  font-size: 1.1rem;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--line);
  padding: .55rem 0;
  color: var(--ink);
  resize: vertical;
  transition: border-color .3s var(--ease);
  outline: none;
}
.contact-right input::placeholder,
.contact-right textarea::placeholder{
  color: rgba(14,12,10,.35);
  font-style: italic;
}
.contact-right input:focus,
.contact-right textarea:focus{
  border-color: var(--ink);
}
.thanks{
  margin-top: 1rem;
  padding: 1rem;
  background: var(--ink);
  color: var(--paper);
  font-size: .9rem;
  text-align: center;
  display:none;
}
.thanks.show{ display:block; animation: fadeIn .5s var(--ease); }
@keyframes fadeIn{ from{ opacity:0; transform:translateY(8px); } to{ opacity:1; transform:translateY(0); } }

@media (max-width: 1000px){
  .contact-grid{ grid-template-columns: 1fr; gap: 3rem; }
  .contact-blocks{ grid-template-columns: 1fr; }
}

/* ---------------- FOOTER ---------------- */
.footer{
  background: var(--ink);
  color: var(--paper);
  padding: 5rem 2rem 0;
  position: relative;
  overflow: hidden;
}
.footer-mark{
  font-family: var(--serif);
  font-size: 1.4rem;
  letter-spacing: .02em;
  font-style: italic;
}
.footer-mark i{ font-style:normal; opacity:.5; margin: 0 .35rem; }
.footer-grid{
  max-width: 1400px; margin: 3rem auto 4rem;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2.5rem;
}
.footer-grid h6{
  font-family: var(--mono);
  font-size: .7rem; letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
  margin-bottom: 1rem;
  font-weight: 400;
}
.footer-grid p{
  font-family: var(--serif);
  font-size: 1.05rem;
  line-height: 1.7;
  font-weight: 300;
}
.footer-grid a{
  border-bottom: 1px solid transparent;
  transition: border-color .3s var(--ease), color .3s var(--ease);
}
.footer-grid a:hover{ border-color: var(--gold); color: var(--gold); }
.footer-big{
  font-family: var(--serif);
  font-size: clamp(4rem, 18vw, 18rem);
  font-weight: 300;
  line-height: .85;
  letter-spacing: -.04em;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  border-top: 1px solid rgba(255,255,255,.12);
  padding-top: 2rem;
  font-style: italic;
}
.footer-bottom{
  max-width: 1400px; margin: 0 auto;
  border-top: 1px solid rgba(255,255,255,.12);
  padding: 1.5rem 0;
  font-family: var(--mono);
  font-size: .7rem; letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
  display:flex; justify-content:space-between; align-items: center;
}
.footer-privacy{
  color: var(--gold);
  border-bottom: 1px solid var(--gold);
  padding-bottom: 2px;
  transition: opacity .3s var(--ease);
}
.footer-privacy:hover{ opacity: .8; }
@media (max-width: 800px){
  .footer-grid{ grid-template-columns: repeat(2, 1fr); }
  .footer-bottom{ flex-direction:column; gap:1rem; text-align:center; }
}

/* ---------------- Reveal animation ---------------- */
.reveal{
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 1s var(--ease), transform 1s var(--ease);
}
.reveal.in{ opacity: 1; transform: translateY(0); }

/* ---------------- Privacy page ---------------- */
.privacy-page{
  padding: 7rem 2rem 6rem;
  max-width: 920px;
  margin: 0 auto;
}
.privacy-page h1{
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(2.6rem, 6vw, 5rem);
  line-height: 1;
  letter-spacing: -.02em;
  margin-bottom: 1rem;
}
.privacy-page h1 em{ font-style: italic; color: var(--rust); }
.privacy-page .meta{
  font-family: var(--mono);
  font-size: .72rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: 3rem;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 1rem 0;
  display: flex; justify-content: space-between;
}
.privacy-page h2{
  font-family: var(--serif);
  font-weight: 500;
  font-size: 1.5rem;
  margin: 2.4rem 0 .8rem;
  letter-spacing: -.01em;
}
.privacy-page h3{
  font-family: var(--serif);
  font-weight: 500;
  font-size: 1.1rem;
  margin: 1.5rem 0 .5rem;
}
.privacy-page p,
.privacy-page li{
  font-size: 1rem;
  color: var(--ink-soft);
  line-height: 1.7;
  margin-bottom: 1rem;
}
.privacy-page ul{ padding-left: 1.4rem; margin-bottom: 1rem; }
.privacy-page a{
  color: var(--rust);
  border-bottom: 1px solid var(--rust);
}
.privacy-page strong{ color: var(--ink); font-weight: 600; }
.privacy-back{
  display: inline-flex; align-items: center; gap: .5rem;
  margin-top: 3rem;
  padding: .9rem 1.4rem;
  border: 1px solid var(--ink);
  border-radius: 99px;
  font-size: .85rem;
  letter-spacing: .04em;
  transition: background .3s var(--ease), color .3s var(--ease);
}
.privacy-back:hover{ background: var(--ink); color: var(--paper); }

/* ---------------- Selection ---------------- */
::selection{
  background: var(--rust);
  color: var(--paper);
}
