/* ============================================================
   Satya Rimbert — Business Technology portfolio
   Editorial / couture: ivory ground, fine serif + calligraphic
   script, generous whitespace, single restrained coral accent.
   ============================================================ */

:root{
  --ivory:#F4F2ED;
  --ivory-2:#ECE9E2;
  --ink:#171512;
  --ink-soft:#4a463f;
  --coral:#F0796B;
  --coral-deep:#d9594a;
  --line:rgba(23,21,18,.16);
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

body{
  background:var(--ivory);
  color:var(--ink);
  font-family:"Jost",system-ui,sans-serif;
  font-weight:300;
  font-size:18px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
strong{font-weight:500}

/* shared display faces */
.script-lg, .script-md{
  font-family:"Parisienne",cursive; font-weight:400; color:var(--ink);
  line-height:1; letter-spacing:.01em;
}
.script-lg{ font-size:clamp(3rem,9vw,6.5rem) }
.script-md{ font-size:clamp(2.4rem,6vw,4rem) }

.num{
  font-family:"Jost",sans-serif; font-weight:400; font-size:.78rem;
  letter-spacing:.34em; color:var(--coral-deep); margin-bottom:14px;
}

/* ---------- nav ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:60;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 32px; mix-blend-mode:difference;
}
.nav__mark{
  font-family:"Cormorant Garamond",serif; font-weight:500; font-size:1.4rem;
  letter-spacing:.1em; color:#fff; text-decoration:none;
}
.nav__links{ display:flex; gap:26px }
.nav__links a{
  font-family:"Jost",sans-serif; font-weight:300; font-size:.82rem;
  letter-spacing:.12em; text-transform:uppercase; color:#fff;
  text-decoration:none; opacity:.85; transition:opacity .25s;
}
.nav__links a:hover{ opacity:1 }
.nav__toggle{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:6px }
.nav__toggle span{ width:24px; height:2px; background:#fff; display:block; transition:.3s }

/* ---------- hero ---------- */
.hero{
  min-height:100vh; display:flex; flex-direction:column;
  align-items:center; justify-content:center; text-align:center;
  padding:80px 24px;
}
.hero__kicker{
  font-family:"Jost",sans-serif; font-weight:400; font-size:.82rem;
  letter-spacing:.34em; text-transform:uppercase; color:var(--ink-soft);
  margin-bottom:8px;
}
.hero__title{ position:relative }
.hero__script{
  font-family:"Cormorant Garamond",serif; font-weight:300; font-style:normal;
  font-size:clamp(4rem,18vw,13rem); letter-spacing:.04em; line-height:.9;
  color:var(--ink); text-transform:uppercase;
}
.hero__name{
  font-family:"Parisienne",cursive; font-size:clamp(2rem,6vw,3.4rem);
  color:var(--ink); margin-top:6px;
}
.hero__enter{
  margin-top:48px; display:inline-flex; align-items:center; gap:9px;
  font-family:"Jost",sans-serif; font-weight:400; font-size:.85rem;
  letter-spacing:.2em; text-transform:uppercase; color:var(--ink);
  text-decoration:none; padding-bottom:6px; border-bottom:1px solid var(--ink);
  transition:gap .3s var(--ease), color .3s;
}
.hero__enter span{ transition:transform .3s var(--ease) }
.hero__enter:hover{ color:var(--coral-deep); border-color:var(--coral-deep) }
.hero__enter:hover span{ transform:translateY(4px) }

/* ---------- contents ---------- */
.contents{
  max-width:760px; margin:0 auto; padding:90px 24px 110px; text-align:center;
}
.contents .script-lg{ margin-bottom:44px }
.contents__list{ list-style:none; display:flex; flex-direction:column; gap:0 }
.contents__list li{ border-top:1px solid var(--line) }
.contents__list li:last-child{ border-bottom:1px solid var(--line) }
.contents__list a{
  display:flex; align-items:baseline; justify-content:center; gap:16px;
  padding:18px 0; text-decoration:none; color:var(--ink);
  font-family:"Cormorant Garamond",serif; font-weight:400;
  font-size:clamp(1.3rem,3vw,1.8rem); letter-spacing:.02em;
  transition:color .25s, letter-spacing .3s var(--ease);
}
.contents__list a span{
  font-family:"Jost",sans-serif; font-weight:400; font-size:.7rem;
  letter-spacing:.2em; color:var(--coral-deep);
}
.contents__list a:hover{ color:var(--coral-deep); letter-spacing:.06em }

/* ---------- sections ---------- */
.section{ max-width:var(--maxw); margin:0 auto; padding:110px 32px }
.section--alt{
  max-width:none; background:var(--ivory-2);
  padding-left:max(32px,calc((100vw - var(--maxw))/2));
  padding-right:max(32px,calc((100vw - var(--maxw))/2));
}
.sec-head{ margin-bottom:36px }
.sec-head--center{ text-align:center }
.sec-lead{
  max-width:62ch; font-size:clamp(1.05rem,2.2vw,1.3rem);
  color:var(--ink-soft); margin-bottom:46px;
}
.sec-head--center + .reflect{ margin-top:10px }

.sec-grid{ display:grid; grid-template-columns:0.85fr 1fr; gap:64px; align-items:center }
.sec-grid--reverse .sec-figure{ order:2 }
.sec-grid--reverse .sec-body{ order:1 }
.sec-body .num{ margin-top:0 }
.sec-body .script-md{ margin-bottom:24px }
.sec-body p{ color:var(--ink-soft); margin-bottom:18px }

.sec-figure img{ width:100%; box-shadow:0 24px 50px rgba(23,21,18,.14) }
.sec-figure--portrait img{ aspect-ratio:3/4; object-fit:cover }
.sec-figure figcaption,
.wide-shot figcaption,
.sheets-grid figcaption,
.glide-grid figcaption,
.vayu-shots figcaption,
.make-form figcaption{
  font-family:"Jost",sans-serif; font-weight:300; font-size:.78rem;
  letter-spacing:.18em; text-transform:uppercase; color:var(--ink-soft);
  margin-top:14px; text-align:center;
}

.brand-tag{
  font-family:"Cormorant Garamond",serif !important; font-style:italic;
  font-size:1.4rem !important; color:var(--ink) !important; margin-top:6px !important;
}
.palette{ display:flex; gap:10px; margin-top:24px }
.palette span{ width:46px; height:46px; border-radius:50%; box-shadow:0 4px 12px rgba(0,0,0,.1) }

/* wide screenshots */
.wide-shot{ border:1px solid var(--line); background:#fff }
.wide-shot img{ width:100% }
.wide-shot--pad{ padding:24px; background:#fff }
.make-form{ max-width:560px; margin:46px auto 0; border:1px solid var(--line) }
.make-form img{ width:100% }

/* vayuapps */
.vayu-grid{ display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:start }
.vayu-email{
  background:#fff; border:1px solid var(--line); border-radius:4px;
  padding:34px 36px;
}
.vayu-email__label{
  font-family:"Jost",sans-serif; font-weight:400; font-size:.72rem;
  letter-spacing:.24em; text-transform:uppercase; color:var(--coral-deep);
  margin-bottom:16px !important;
}
.vayu-email p{ color:var(--ink-soft); font-size:.98rem; margin-bottom:12px }
.vayu-email__sign{ font-style:italic; color:var(--ink) !important }
.vayu-shots{ display:grid; grid-template-columns:1fr 1fr; gap:24px }
.vayu-shots figure:first-child{ grid-column:1 / -1 }
.vayu-shots img{ border:1px solid var(--line) }

/* sheets */
.sheets-grid{ display:grid; grid-template-columns:1.3fr 1fr; gap:40px; align-items:start }
.sheets-grid img{ border:1px solid var(--line); background:#fff }

/* glide */
.glide-grid{ display:grid; grid-template-columns:0.7fr 1.4fr 0.7fr; gap:32px; align-items:center }
.glide-phone img{ border-radius:14px }
.sec-link{
  display:inline-block; margin-top:40px;
  font-family:"Jost",sans-serif; font-weight:400; font-size:.85rem;
  letter-spacing:.16em; text-transform:uppercase; color:var(--coral-deep);
  text-decoration:none; border-bottom:1px solid rgba(217,89,74,.4); padding-bottom:4px;
  transition:color .25s, border-color .25s;
}
.sec-link:hover{ color:var(--ink); border-color:var(--ink) }

/* reflection */
.reflect{ max-width:720px; margin:0 auto }
.reflect p{ color:var(--ink-soft); margin-bottom:22px; font-size:1.08rem }
.reflect__subhead{
  font-family:"Cormorant Garamond",serif !important; font-style:italic;
  font-size:1.5rem !important; color:var(--ink) !important;
  margin:36px 0 14px !important;
}
.reflect__skills{ list-style:none; margin-bottom:30px }
.reflect__skills li{
  padding:14px 0 14px 28px; border-bottom:1px solid var(--line);
  color:var(--ink-soft); position:relative;
}
.reflect__skills li::before{
  content:"—"; position:absolute; left:0; color:var(--coral-deep);
}

/* footer */
.foot{ text-align:center; padding:120px 24px 90px }
.foot__merci{ color:var(--ink) }
.foot__sub{
  font-family:"Cormorant Garamond",serif; font-size:1.1rem;
  letter-spacing:.3em; text-transform:uppercase; color:var(--ink-soft); margin-top:10px;
}
.foot__meta{
  font-family:"Jost",sans-serif; font-weight:300; font-size:.76rem;
  letter-spacing:.18em; text-transform:uppercase; color:var(--ink-soft);
  margin-top:40px; opacity:.7;
}

/* reveal */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease) }
.reveal.in{ opacity:1; transform:none }

/* ---------- responsive ---------- */
@media (max-width:860px){
  .nav__links{
    position:fixed; inset:0 0 0 auto; width:min(70vw,300px);
    flex-direction:column; gap:0; background:var(--ink);
    padding:90px 32px; transform:translateX(100%); transition:transform .4s var(--ease);
    mix-blend-mode:normal;
  }
  .nav__links.open{ transform:none }
  .nav__links a{ padding:14px 0; font-size:1rem; border-bottom:1px solid rgba(255,255,255,.12) }
  .nav__toggle{ display:flex; z-index:61 }
  .nav{ mix-blend-mode:difference }

  .sec-grid, .sec-grid--reverse,
  .vayu-grid, .sheets-grid{ grid-template-columns:1fr; gap:40px }
  .sec-grid--reverse .sec-figure{ order:0 } .sec-grid--reverse .sec-body{ order:0 }
  .glide-grid{ grid-template-columns:1fr; gap:36px; max-width:420px; margin:0 auto }
  .vayu-shots{ grid-template-columns:1fr 1fr }
  .section{ padding:72px 24px }
}
@media (max-width:480px){
  body{ font-size:17px }
  .palette span{ width:38px; height:38px }
  .vayu-shots{ grid-template-columns:1fr }
  .vayu-email{ padding:26px }
}
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto }
  .reveal{ opacity:1; transform:none }
}
