/* style.css */
:root{
  --sage: #A9B0A3;
  --sage-deep: #8E9689;
  --cream: #F5F2EC;
  --paper: #FFFFFF;
  --ink: #141414;

  --container: 1120px;
  --edge: clamp(18px, 4vw, 44px);

  --serif: "Cormorant Garamond", serif;
  --sans: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --script: "Allura", cursive;

  --r: 18px;
  --shadow: 0 18px 50px rgba(0,0,0,.22);
}

*{ box-sizing: border-box; }
html, body { height: 100%; }

body{
  margin:0;
  color: var(--ink);
  font-family: var(--sans);
  background: var(--cream);
}

/* =========================
   Preloader
   ========================= */
body.is-loading{ overflow: hidden; }

.preloader{
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  background: var(--cream);
  opacity: 1;
  visibility: visible;
  transition: opacity .35s ease, visibility .35s ease;
}
body.is-ready .preloader{
  opacity: 0;
  visibility: hidden;
}

.preloader__inner{
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 18px 22px;
  /* border-radius: 999px; */
  border: 1px solid rgba(20,20,20,.10);
  background: rgba(255,255,255,.55);
  backdrop-filter: blur(8px);
}
.preloader__ring{
  width: 26px;
  height: 26px;
  border-radius: 999px;
  border: 2px solid rgba(20,20,20,.14);
  border-top-color: rgba(20,20,20,.55);
  animation: spin 1s linear infinite;
}
@keyframes spin{ to { transform: rotate(360deg); } }

.preloader__brand{ line-height: 1; }
.preloader__mark{
  font-family: var(--serif);
  font-weight: 600;
  font-size: 18px;
  letter-spacing: .2px;
  color: rgba(20,20,20,.88);
}
.preloader__sub{
  margin-top: 6px;
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(20,20,20,.58);
}

@media (prefers-reduced-motion: reduce){
  .preloader__ring{ animation: none; }
  .preloader{ transition: none; }
}

/* =========================
   Utilities
   ========================= */
.container{
  width: min(var(--container), 100% - (var(--edge) * 2));
  margin-inline: auto;
}
.srOnly{
  position:absolute !important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}
.script{ font-family: var(--script); font-weight: 400; }

/* =========================
   FULLSCREEN ONE PAGE
   ✅ Hero bigger, announce smaller
   ========================= */
.page--fullscreen{
  height: 100svh;
  display: grid;
  grid-template-rows: 1.6fr 0.4fr; /* ✅ much smaller green area */
  overflow: hidden;               /* ✅ no scroll */
}

/* =========================
   HERO
   ========================= */
.hero{
  position: relative;
  overflow: hidden;
  background: #0f0f0f;
}
.hero--compact{ min-height: auto; }

.hero__media{
  position:absolute; inset:0;
  background-image: url("../img/hero-image.jpg");
  background-size: cover;
  background-position: center;
  transform: scale(1.03);
  filter: saturate(.95) contrast(1.02);
}

.hero__overlay{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.55) 0%, rgba(0,0,0,.26) 50%, rgba(0,0,0,.62) 100%),
    radial-gradient(70% 80% at 20% 20%, rgba(0,0,0,.25) 0%, rgba(0,0,0,0) 60%);
  pointer-events:none;
}

.topbar{
  position:absolute; top:0; left:0; right:0;
  z-index: 5;
  padding: 16px 0;
}
.topbar__inner{
  width: min(var(--container), 100% - (var(--edge) * 2));
  margin-inline: auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 20px;
}

.brand{
  text-decoration:none;
  color: rgba(255,255,255,.92);
  display:flex;
  flex-direction:column;
  line-height:1;
}
.brand__mark{
  font-family: var(--serif);
  font-weight: 600;
  font-size: 22px;
  letter-spacing: .2px;
}
.brand__sub{
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  opacity: .78;
  margin-top: 6px;
}

.nav{
  display:flex;
  gap: 18px;
  align-items:center;
}
.nav__link{
  text-decoration:none;
  color: rgba(255,255,255,.86);
  font-size: 13px;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 8px 10px;
  border-radius: 999px;
  transition: background .2s ease, color .2s ease;
}
.nav__link:hover{
  background: rgba(255,255,255,.12);
  color: rgba(255,255,255,.95);
}

.hero__content{
  position: relative;
  z-index: 3;
  height: 100%;
  display:flex;
  align-items:flex-end;
  padding-bottom: clamp(14px, 2.8vh, 26px);
}

.heroCard{
  width: min(560px, 92vw);
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(6px);
  /* border-radius: var(--r); */
  box-shadow: var(--shadow);
  padding: clamp(16px, 2.1vw, 22px);
  border: 1px solid rgba(255,255,255,.55);
}
.heroCard__kicker{
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(20,20,20,.70);
  margin-bottom: 8px;
}
.heroCard__title{
  font-family: var(--serif);
  font-weight: 600;
  font-size: clamp(32px, 3.6vw, 52px);
  line-height: 1.02;
  margin: 0 0 8px;
}
.heroCard__script{
  display:block;
  font-family: var(--script);
  font-weight: 400;
  font-size: clamp(24px, 2.6vw, 38px);
  color: var(--sage-deep);
  margin-top: 8px;
}
.heroCard__desc{
  margin: 0;
  max-width: 52ch;
  font-size: 14px;
  line-height: 1.6;
  color: rgba(20,20,20,.75);
}

.hero__hint{
  position:absolute;
  left: var(--edge);
  bottom: 10px;
  z-index: 4;
  opacity: .55;
}
.hero__hintLine{
  display:block;
  width: 84px;
  height: 2px;
  background: rgba(255,255,255,.55);
  border-radius: 999px;
}

/* =========================
   ANNOUNCE (smaller)
   ========================= */
.announce{
  background: var(--sage);
  overflow: hidden;
}

/* tighter padding */
.announce--compact{
  padding: clamp(10px, 1.6vh, 18px) 0;
}

.announce__grid{
  display:grid;
  grid-template-columns: 3.05fr .95fr;
  gap: clamp(10px, 1.6vw, 20px);
  align-items: center;
}

.eyebrow{
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(20,20,20,.70);
  margin-bottom: 6px;
}

.announce__title{
  font-family: var(--serif);
  font-weight: 600;
  font-size: clamp(22px, 2.2vw, 32px);
  line-height: 1.05;
  margin: 0 0 6px;
}
.announce__lead{
  margin: 0;
  max-width: 60ch;
  color: rgba(20,20,20,.78);
  line-height: 1.5;
  font-size: 13px;
}

.announce__right{
  background: rgba(255,255,255,.22);
  border: 1px solid rgba(255,255,255,.28);
  /* border-radius: var(--r); */
  padding: clamp(25px, 1.2vw, 14px);
}
.announce__copy{
  margin: 0 0 8px;
  color: rgba(20,20,20,.78);
  line-height: 1.45;
  font-size: 13px;
}

/* CTA VERSION (VERSI 2) */
.announce__right--cta{
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap: 14px;
}

.enterBtn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height: 44px;
  padding: 0 26px;
  /* border-radius: 999px; */
  background: #ffffff;
  color: #141414;
  font-family: var(--sans);
  font-size: 13px;
  letter-spacing: .08em;
  text-transform: uppercase;
  text-decoration: none;
  border: 1px solid rgba(20,20,20,.25);
  transition: all .25s ease;
  /* width: fit-content; */
  width: auto;
}

.enterBtn:hover{
  background: rgba(255,255,255,.9);
  transform: translateY(-1px);
}

.enterBtn:active{
  transform: translateY(0);
}

.notify{
  display:flex;
  gap: 8px;
  align-items:center;
  margin-bottom: 8px;
}
.notify input{
  flex: 1;
  height: 36px;
  border-radius: 999px;
  border: 1px solid rgba(20,20,20,.18);
  padding: 0 12px;
  outline: none;
  font-family: var(--sans);
  background: rgba(255,255,255,.72);
}
.notify button{
  height: 36px;
  border-radius: 999px;
  border: 1px solid rgba(20,20,20,.24);
  padding: 0 14px;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 12px;
  letter-spacing: .06em;
  text-transform: uppercase;
  cursor: pointer;
}

.announce__meta{
  display:flex;
  align-items:center;
  gap: 10px;
  font-size: 12px;
  color: rgba(20,20,20,.72);
}
.metaDot{
  width: 6px; height: 6px;
  border-radius: 999px;
  background: rgba(20,20,20,.35);
  display:inline-block;
}
.metaLink{
  color: rgba(20,20,20,.86);
  text-decoration: none;
  border-bottom: 1px solid rgba(20,20,20,.22);
  padding-bottom: 2px;
}

/* =========================
   Responsive
   ========================= */
@media (max-width: 920px){
  .nav{ display:none; }
  .announce__grid{ grid-template-columns: 1fr; }
  .heroCard{ width: min(720px, 100%); }
}

/* Mobile: give announce a bit more room to avoid cramping */
@media (max-width: 680px){
  .page--fullscreen{
    grid-template-rows: 1.25fr 0.75fr;
  }
}

@media (max-width: 520px){
  .notify{ flex-direction: column; align-items: stretch; }
  .notify button{ width: 100%; }
}

/* =========================
   MODAL (Versi 3)
   ========================= */
.modal{
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: grid;
  place-items: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity .2s ease, visibility .2s ease;
}
.modal.is-open{
  opacity: 1;
  visibility: visible;
}

.modal__overlay{
  position:absolute;
  inset:0;
  background: rgba(10,10,10,.55);
  backdrop-filter: blur(2px);
}

.modal__panel{
  position: relative;
  z-index: 2;
  width: min(560px, calc(100% - (var(--edge) * 2)));
  /* border-radius: var(--r); */
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(255,255,255,.55);
  box-shadow: var(--shadow);
  padding: clamp(18px, 2.6vw, 26px);
  outline: none;
}

.modal__close{
  position:absolute;
  top: 10px;
  right: 12px;
  width: 40px;
  height: 40px;
  /* border-radius: 999px; */
  border: 1px solid rgba(20,20,20,.14);
  background: rgba(255,255,255,.85);
  cursor: pointer;
  font-size: 20px;
  line-height: 1;
}

.modal__kicker{
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(20,20,20,.68);
  margin-bottom: 10px;
}
.modal__title{
  font-family: var(--serif);
  font-weight: 600;
  font-size: clamp(22px, 2.6vw, 30px);
  margin: 0 0 10px;
}
.modal__desc{
  margin: 0;
  color: rgba(20,20,20,.76);
  line-height: 1.7;
  font-size: 14px;
}
.modal__actions{
  margin-top: 16px;
  display:flex;
  justify-content:flex-end;
}
.modal__btn{
  height: 42px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid rgba(20,20,20,.22);
  background: #ffffff;
  font-family: var(--sans);
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  cursor:pointer;
}

/* Ensure no background scroll when modal open */
html.modal-open,
body.modal-open{
  overflow: hidden;
}

/* =========================
   Responsive
   ========================= */
@media (max-width: 920px){
  .nav{ display:none; }
  .announce__grid{ grid-template-columns: 1fr; }
  .heroCard{ width: min(720px, 100%); }
  .enterBtn{ width: fit-content; }
}

@media (max-width: 680px){
  .page--fullscreen{ grid-template-rows: 1.25fr 0.75fr; }
}

@media (max-width: 520px){
  .enterBtn{ width: 100%; }
}