/* ============================================================
   Lalita Kominkova — portfolio
   Identity from her deck: near-black, crimson, elegant script,
   white starbursts. Elevated into a real interactive site.
   ============================================================ */

:root{
  --black:#0d0d0f;
  --black-2:#141416;
  --crimson:#B3121E;
  --crimson-bright:#d6202d;
  --bone:#EDE7DA;
  --bone-dim:#b9b3a7;
  --line:rgba(237,231,218,.14);
  --maxw:1180px;
  --ease:cubic-bezier(.2,.7,.2,1);
}

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

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

#stars{
  position:fixed; inset:0; z-index:0; pointer-events:none;
}

/* ---------- shared section ---------- */
.section{
  position:relative; z-index:1;
  max-width:var(--maxw); margin:0 auto;
  padding:120px 32px;
}
.section__head{ margin-bottom:54px }
.section__head--center{ text-align:center }
.kicker{
  display:inline-block; font-family:"Inter",sans-serif; font-weight:500;
  font-size:.8rem; letter-spacing:.32em; color:var(--crimson-bright);
  border:1px solid var(--crimson); border-radius:999px;
  padding:5px 14px; margin-bottom:20px;
}
.script-h{
  font-family:"Cormorant Garamond",serif; font-weight:500; font-style:italic;
  color:var(--crimson); font-size:clamp(2.6rem,6vw,4.6rem);
  line-height:1; letter-spacing:.005em;
}
.script-h--big{ font-size:clamp(3.2rem,9vw,6rem) }

/* ---------- hero ---------- */
.hero{
  position:relative; z-index:1; min-height:100vh;
  display:flex; align-items:center;
}
.hero__inner{ max-width:var(--maxw); margin:0 auto; padding:0 32px; width:100% }
.hero__year{
  font-family:"Inter",sans-serif; font-weight:400; font-size:.9rem;
  letter-spacing:.3em; color:var(--bone-dim); margin-bottom:22px;
}
.hero__eyebrow{
  font-family:"Cormorant Garamond",serif; font-style:italic; font-weight:400;
  font-size:clamp(1.4rem,3vw,2rem); color:var(--bone-dim); margin-bottom:6px;
}
.hero__title{ line-height:.92 }
.hero__line{
  display:block; font-family:"Cormorant Garamond",serif;
  font-weight:600; font-size:clamp(3.4rem,13vw,9rem);
  color:var(--bone); letter-spacing:-.01em;
}
.hero__line--script{
  font-style:italic; font-weight:500; color:var(--crimson);
  margin-top:-.06em;
}
.hero__sub{
  max-width:46ch; margin-top:30px;
  font-size:clamp(1rem,2vw,1.25rem); color:var(--bone-dim);
}
.hero__cta{
  display:inline-flex; align-items:center; gap:10px; margin-top:40px;
  font-family:"Inter",sans-serif; font-weight:500; font-size:.95rem;
  letter-spacing:.04em; color:var(--bone); text-decoration:none;
  padding:14px 26px; border:1px solid var(--line); border-radius:999px;
  transition:border-color .35s var(--ease), background .35s var(--ease);
}
.hero__cta span{ transition:transform .35s var(--ease) }
.hero__cta:hover{ border-color:var(--crimson); background:rgba(179,18,30,.08) }
.hero__cta:hover span{ transform:translateY(4px) }

/* starbursts */
.star{ position:absolute; fill:var(--bone); opacity:.9; pointer-events:none; z-index:0 }
.star--1{ width:90px; top:22%; right:9%; animation:twinkle 6s var(--ease) infinite }
.star--2{ width:56px; top:30%; left:52%; animation:twinkle 6s var(--ease) 2s infinite }
@keyframes twinkle{ 0%,100%{transform:scale(1) rotate(0);opacity:.85} 50%{transform:scale(1.18) rotate(20deg);opacity:1} }

/* ---------- about ---------- */
.about__grid{ display:grid; grid-template-columns:1.1fr 1fr; gap:64px; align-items:center }
.about__text p{ font-size:clamp(1.05rem,2.2vw,1.35rem); color:var(--bone-dim); margin-bottom:20px }
.about__pop{
  font-family:"Cormorant Garamond",serif !important; font-style:italic;
  font-size:1.7rem !important; color:var(--bone) !important;
}
.about__photos{ position:relative; min-height:440px }
.about__photo{
  position:absolute; border-radius:4px; object-fit:cover;
  box-shadow:0 30px 60px rgba(0,0,0,.6);
}
.about__photo--beach{
  width:62%; top:0; left:0; aspect-ratio:3/4; object-fit:cover;
  transform:rotate(-3deg);
}
.about__photo--portrait{
  width:52%; right:0; bottom:0; aspect-ratio:3/5; object-fit:cover;
  border:6px solid var(--crimson); transform:rotate(2.5deg);
}

/* ---------- generic project ---------- */
.project__grid{ display:grid; grid-template-columns:1fr 1.05fr; gap:60px; align-items:center }
.project__grid--reverse .project__text{ order:2 }
.project__grid--reverse .shot,
.project__grid--reverse .brand-board{ order:1 }
.project__text p{ color:var(--bone-dim); margin-bottom:18px }
.project__link{
  display:inline-block; margin-top:10px;
  font-family:"Inter",sans-serif; font-weight:500; font-size:.95rem;
  color:var(--crimson-bright); text-decoration:none;
  border-bottom:1px solid rgba(214,32,45,.4); padding-bottom:3px;
  transition:border-color .3s, color .3s;
}
.project__link:hover{ color:var(--bone); border-color:var(--bone) }
.howitworks-label{
  font-family:"Inter",sans-serif; font-weight:600; font-size:.8rem;
  letter-spacing:.2em; text-transform:uppercase; color:var(--crimson-bright);
  margin:10px 0 8px !important;
}

.shot{
  border-radius:6px; overflow:hidden;
  border:1px solid var(--line);
  box-shadow:0 30px 70px rgba(0,0,0,.55);
}
.shot img{ width:100% }
.shot--dark{ background:#05060a }
.shot--phone{ max-width:380px; margin:0 auto; border:none; box-shadow:none }
.shot--phone img{ border-radius:6px }

/* ---------- brand board ---------- */
.brand-board{
  background:var(--black-2); border:1px solid var(--line);
  border-radius:8px; padding:32px; display:flex; flex-direction:column; gap:28px;
}
.brand-board__row{ display:flex; flex-direction:column; gap:12px }
.brand-board__label{
  font-family:"Inter",sans-serif; font-weight:500; font-size:.72rem;
  letter-spacing:.24em; text-transform:uppercase; color:var(--bone-dim);
}
.brand-board__logo{
  font-family:"Inter",sans-serif; font-weight:600; font-size:2.4rem;
  color:var(--bone); letter-spacing:-.02em; display:inline-flex; align-items:center;
}
.brand-board__star{ color:var(--crimson); font-size:1.3rem; margin:0 1px }
.swatches{ display:flex; height:46px; border-radius:4px; overflow:hidden }
.swatches span{ flex:1 }
.brand-board__type{
  font-family:"Inter",sans-serif; font-weight:600; font-style:italic;
  font-size:2.2rem; color:var(--bone);
}

/* ---------- reflection ---------- */
.reflection{ text-align:center; padding-top:140px; padding-bottom:120px }
.reflection__body{ max-width:760px; margin:0 auto }
.reflection__body p{ font-size:clamp(1.05rem,2.2vw,1.3rem); color:var(--bone-dim); margin-bottom:26px }
.reflection__thanks{
  font-family:"Cormorant Garamond",serif !important; font-style:italic;
  font-size:clamp(1.3rem,3vw,1.7rem) !important; color:var(--bone) !important;
}

/* ---------- footer ---------- */
.foot{
  position:relative; z-index:1; text-align:center;
  border-top:1px solid var(--line); padding:70px 32px 80px;
  background:linear-gradient(180deg, transparent, rgba(179,18,30,.06));
}
.foot__name{
  font-family:"Cormorant Garamond",serif; font-style:italic; font-weight:500;
  font-size:clamp(2rem,5vw,3rem); color:var(--crimson);
}
.foot__meta{
  margin-top:10px; font-size:.8rem; letter-spacing:.2em;
  color:var(--bone-dim); text-transform:uppercase;
}

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

/* ---------- responsive ---------- */
@media (max-width:840px){
  .about__grid,
  .project__grid,
  .project__grid--reverse{ grid-template-columns:1fr; gap:40px }
  .project__grid--reverse .project__text{ order:0 }
  .project__grid--reverse .shot,
  .project__grid--reverse .brand-board{ order:0 }
  .about__photos{ min-height:420px; max-width:420px }
  .section{ padding:80px 24px }
  .star--1{ width:64px } .star--2{ width:42px }
}
@media (max-width:480px){
  body{ font-size:17px }
  .about__photo--beach{ width:58% } .about__photo--portrait{ width:50% }
  .brand-board{ padding:24px }
}
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto }
  .reveal{ opacity:1; transform:none }
}
