:root{
  --pink:#F6B7C4;
  --pinkSoft:rgba(246,183,196,.22);
  --gold:rgba(215,180,106,.22);

  --ink:#0E0E10;
  --paper:#ffffff;
  --bg:#e9e3dc;

  --radius:22px;
  --radiusInner:18px;
  --line:rgba(255,255,255,.35);
  --lineDark:rgba(14,14,16,.10);
  --shadow:0 24px 80px rgba(0,0,0,.25);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--ink);
  background:#f3f1ee;
}

/* Outer “mat” */
.stage{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:26px 16px;
  position:relative;
  background:
    radial-gradient(1200px 520px at 50% 10%, rgba(0,0,0,.08), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.55), rgba(255,255,255,.15)),
    var(--bg);
}

/* blurred background image behind the frame */
.stage::before{
  content:"";
  position:absolute;
  inset:18px;
  border-radius:28px;
  background-image:var(--bg);
  background-size:cover;
  background-position:center;
  filter:blur(2px) saturate(.9);
  opacity:.35;
}

.stage__watermark{
  position:absolute;
  top:36px;
  left:0; right:0;
  text-align:center;
  font-family:"Playfair Display",serif;
  font-weight:600;
  letter-spacing:.24em;
  font-size:clamp(64px,10vw,150px);
  color:rgba(255,255,255,.35);
  pointer-events:none;
  user-select:none;
  z-index:1;
}

/* The rounded frame */
.frame{
  width:min(1200px, calc(100% - 20px));
  height:min(780px, calc(100vh - 70px));
  border-radius:28px;
  overflow:hidden;
  background:#1a1a1a;
  box-shadow:var(--shadow);
  position:relative;
  z-index:2;
}

/* Top nav */
.topnav{
  position:absolute;
  top:0; left:0; right:0;
  padding:18px 22px 12px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  z-index:5;
  color:#fff;
}

.logo{
  display:flex;
  align-items:center;
  gap:10px;
  cursor:pointer;
  user-select:none;
}
.logo__mark{
  width:34px;height:34px;border-radius:12px;
  background:linear-gradient(135deg, rgba(255,255,255,.20), rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.16);
  position:relative;
}
.logo__mark::after{
  content:"";
  position:absolute; inset:9px;
  border-radius:8px;
  border:1px solid var(--gold);
}
.logo__text{font-weight:600;letter-spacing:.02em}

.menu{
  display:flex;
  align-items:center;
  gap:22px;
  padding:10px 14px;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  width:min(760px, 62%);
  justify-content:center;
}
.menu__link{
  background:transparent;
  border:0;
  color:rgba(255,255,255,.86);
  letter-spacing:.16em;
  font-size:11px;
  cursor:pointer;
  padding:8px 6px;
  text-transform:uppercase;
}
.menu__link:hover{color:#fff}

@media (max-width:980px){
  .menu{display:none}
}

/* Views slider */
.views{
  height:100%;
  display:flex;
  width:600%;
  transform:translateX(0%);
  transition:transform 700ms cubic-bezier(.2,.8,.2,1);
}
.view{
  flex:0 0 calc(100% / 6);
  height:100%;
  position:relative;
}

/* HERO */
.view--hero{
  background-image:var(--bg);
  background-size:cover;
  background-position:center;
}
.heroBg{
  position:absolute; inset:0;
  background-image:var(--bg);
  background-size:cover;
  background-position:center;
  filter:saturate(.95);
  transform:scale(1.02);
}
.heroOverlay{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.25), rgba(0,0,0,.55)),
    radial-gradient(900px 420px at 65% 40%, rgba(0,0,0,.18), transparent 60%);
}

.heroInner{
  position:absolute;
  inset:0;
  display:grid;
  grid-template-columns: 1.25fr .75fr;
  align-items:center;
  padding: 92px 46px 86px;
  gap: 24px;
  color:#fff;
}
@media (max-width:980px){
  .heroInner{grid-template-columns:1fr;padding:96px 24px 86px}
}

.heroTitle{
  line-height:0.95;
  font-family:"Playfair Display",serif;
  letter-spacing:.02em;
}
.heroWord{
  font-size: clamp(46px, 6.2vw, 92px);
  font-weight:600;
  text-transform:uppercase;
  text-shadow: 0 10px 26px rgba(0,0,0,.30);
}
.heroWord--right{text-align:right}
.heroWord--script{
  font-family:"Cormorant Garamond",serif;
  font-style:italic;
  font-weight:600;
  letter-spacing:.02em;
  transform: translateX(10px);
  opacity:.95;
}

.heroCopy{
  max-width: 330px;
  color: rgba(255,255,255,.86);
  font-size: 12px;
}
.heroCopy p{margin:0 0 18px; line-height:1.55}

.ctaLine{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  background:transparent;
  border:0;
  color:#fff;
  cursor:pointer;
  padding:10px 0;
  letter-spacing:.18em;
  font-size:11px;
  text-transform:uppercase;
  border-bottom:1px solid rgba(255,255,255,.35);
}
.ctaLine:hover{border-bottom-color:rgba(255,255,255,.65)}
.ctaLine__arrow{opacity:.9}

.ctaPill{
  margin-top:12px;
  border:1px solid rgba(255,255,255,.28);
  background:rgba(255,255,255,.10);
  color:#fff;
  border-radius:999px;
  padding:10px 14px;
  cursor:pointer;
}
.ctaPill:hover{background:rgba(246,183,196,.12);border-color:rgba(255,255,255,.40)}

/* bottom “player” visual */
.player{
  position:absolute;
  left:24px;
  right:24px;
  bottom:18px;
  display:flex;
  align-items:center;
  gap:14px;
  z-index:4;
}
.playerBtn{
  width:52px;height:52px;border-radius:999px;
  background:rgba(255,255,255,.92);
  box-shadow:0 18px 50px rgba(0,0,0,.25);
  position:relative;
}
.playerBtn::after{
  content:"";
  position:absolute; inset:18px 18px 18px 22px;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
  background:rgba(14,14,16,.75);
}
.playerBtn--mute::after{
  inset:20px;
  clip-path:none;
  border-radius:6px;
  background:rgba(14,14,16,.75);
}
.playerTrack{
  flex:1;
  height:7px;
  border-radius:999px;
  background:rgba(255,255,255,.55);
  overflow:hidden;
}
.playerProg{
  width:9%;
  height:100%;
  background:var(--pink);
}

/* PORTFOLIO */
.view--portfolio{ background:#f1ede8; }
.portfolioBg{
  position:absolute; inset:0;
  background-image: var(--bg);
  background-size: cover;
  background-position:center;
  filter: blur(2px) saturate(.9);
  opacity:.35;
}
.folioCard{
  position:absolute;
  inset: 92px 54px 68px;
  background: rgba(255,255,255,.94);
  border-radius: var(--radiusInner);
  box-shadow: 0 24px 70px rgba(0,0,0,.18);
  border: 1px solid rgba(14,14,16,.08);
  padding: 22px 22px 18px;
}
@media (max-width:980px){
  .folioCard{inset:92px 18px 68px}
}
.folioCard::after{
  content:"";
  position:absolute;
  inset: 18px;
  border-radius: calc(var(--radiusInner) - 6px);
  border: 1px solid var(--gold);
  pointer-events:none;
}

.folioTop{
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  align-items:center;
  color: rgba(14,14,16,.55);
  font-size: 10px;
  letter-spacing: .16em;
  padding: 6px 10px 0;
}
.folioTop__left{justify-self:start}
.folioTop__center{justify-self:center;letter-spacing:.10em}
.folioTop__right{justify-self:end}

.folioHeadline{
  margin: 8px 0 14px;
  text-align:center;
  font-family:"Playfair Display",serif;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size: clamp(22px, 3.0vw, 38px);
  color: rgba(14,14,16,.86);
}
.folioHeadline .flourish{
  font-family:"Cormorant Garamond",serif;
  font-style:italic;
  font-weight:600;
  text-transform:none;
  letter-spacing:.02em;
}

.folioGrid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 18px;
  height: calc(100% - 74px);
  padding: 10px 10px 0;
}
@media (max-width:980px){
  .folioGrid{grid-template-columns:1fr; height:auto}
}

.folioImgLarge{
  border-radius: 14px;
  border:1px solid rgba(14,14,16,.10);
  background:
    linear-gradient(135deg, rgba(246,183,196,.12), rgba(215,180,106,.10));
  background-size: cover;
  background-position:center;
  min-height: 420px;
}

.folioRight{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap: 14px;
}
.folioTitle{
  margin: 8px 0 6px;
  font-family:"Playfair Display",serif;
  font-weight:600;
  font-size: 22px;
}
.folioDesc{
  margin:0 0 12px;
  color: rgba(14,14,16,.68);
  font-size: 12px;
  max-width: 46ch;
}
.folioNoteRow{
  display:grid;
  gap:10px;
  margin: 10px 0 14px;
}
.folioNote{
  font-size:10.5px;
  color: rgba(14,14,16,.55);
}
.folioAccent{
  display:flex; align-items:center; gap:10px;
  font-size:10.5px;
  color: rgba(14,14,16,.60);
}
.pinkDot{
  width:8px; height:8px; border-radius:99px;
  background: var(--pink);
  box-shadow: 0 0 0 6px rgba(246,183,196,.18);
}

.folioImgSmallWrap{
  width: min(240px, 100%);
  margin-left:auto;
}
.folioImgSmall{
  height: 160px;
  border-radius: 14px;
  border:1px solid rgba(14,14,16,.10);
  background:
    linear-gradient(135deg, rgba(246,183,196,.12), rgba(215,180,106,.10));
  background-size: cover;
  background-position:center;
}
.folioSmallCap{
  padding: 8px 10px;
  font-size: 10.5px;
  color: rgba(14,14,16,.55);
}

.folioNav{
  display:flex;
  justify-content:flex-end;
  gap: 10px;
}
.folioArrow{
  width:44px; height:44px;
  border-radius:999px;
  border:1px solid rgba(14,14,16,.12);
  background: rgba(255,255,255,.92);
  cursor:pointer;
}
.folioArrow:hover{background: rgba(246,183,196,.10)}

/* SIMPLE VIEWS */
.view--simple{
  background:#f1ede8;
  display:flex;
  align-items:center;
  justify-content:center;
}
.simpleCard{
  width:min(760px, calc(100% - 40px));
  background: rgba(255,255,255,.92);
  border:1px solid rgba(14,14,16,.10);
  border-radius: 18px;
  box-shadow: 0 24px 70px rgba(0,0,0,.14);
  padding: 28px;
}
.simpleCard h2{
  margin:0 0 10px;
  font-family:"Playfair Display",serif;
  font-weight:600;
}
.muted{color: rgba(14,14,16,.60)}
.cleanList{margin:10px 0 0; padding-left: 18px; color: rgba(14,14,16,.70)}
.cleanList li{margin:8px 0}
.ghostBtn{
  display:inline-flex;
  padding: 10px 12px;
  border-radius: 999px;
  border:1px solid rgba(14,14,16,.12);
  background:#fff;
  color:#111;
  text-decoration:none;
}