/* ============================================================
   IMG WEDDINGS — "CUTTING ROOM" cinematic system
   Bold dark film-house aesthetic for the Portal sign-in + Journal
   Layers on styles.css tokens (Bodoni Moda, clay, espresso)
   ============================================================ */

:root{
  --film-bg:    oklch(0.165 0.013 46);   /* near-black espresso     */
  --film-bg2:   oklch(0.205 0.018 44);   /* raised panel            */
  --film-bg3:   oklch(0.255 0.020 44);   /* card / hover            */
  --film-line:  oklch(0.42 0.020 50 / .34);
  --film-line2: oklch(0.50 0.022 52 / .55);
  --film-fg:    oklch(0.945 0.012 80);   /* parch text              */
  --film-mut:   oklch(0.700 0.018 66);   /* muted warm grey         */
  --film-dim:   oklch(0.560 0.018 56);   /* dimmer labels           */
  --gold:       oklch(0.800 0.095 73);   /* warm amber highlight    */
  --gold-deep:  oklch(0.700 0.110 60);
  --clay:       oklch(0.620 0.110 42);   /* lifted clay for dark bg */
}

/* ---------- base ---------- */
.cine{
  background:var(--film-bg);
  color:var(--film-fg);
  font-family:var(--sans);
  -webkit-font-smoothing:antialiased;
  min-height:100svh;
  position:relative;
  overflow-x:hidden;
}
.cine ::selection{ background:var(--gold); color:var(--film-bg); }
.cine a{ color:inherit; text-decoration:none; }

/* film grain over everything */
.cine::before{
  content:""; position:fixed; inset:0; z-index:60; pointer-events:none; opacity:.5; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");
}

.cine-wrap{ max-width:1480px; margin-inline:auto; padding-inline:clamp(1.4rem,5vw,5.5rem); }

/* ---------- shared type ---------- */
.cine h1,.cine h2,.cine h3,.cine h4{ font-family:var(--serif); font-weight:400; color:var(--film-fg); line-height:1; letter-spacing:-.01em; }
.cine .ital{ font-style:italic; }
.cine .lc{ text-transform:lowercase; }

/* mono technical annotations — timecode / reel marks */
.tcode{ font-family:var(--mono); font-size:.62rem; letter-spacing:.26em; text-transform:uppercase; color:var(--film-dim); }
.tcode--gold{ color:var(--gold); }
.cine .script{ font-family:var(--script); }
.cine .hand{ font-family:var(--hand); }

.cine .eyebrow{ font-family:var(--sans); font-weight:600; font-size:.66rem; letter-spacing:.36em; text-transform:uppercase; color:var(--gold); display:inline-flex; align-items:center; gap:.9em; }
.cine .eyebrow::before{ content:""; width:2.4em; height:1px; background:currentColor; opacity:.6; }
.cine .eyebrow.no-line::before{ display:none; }

/* ---------- buttons ---------- */
.cbtn{ display:inline-flex; align-items:center; gap:.7em; font-family:var(--sans); font-weight:600;
  font-size:.7rem; letter-spacing:.22em; text-transform:uppercase; padding:1.15em 2.1em; border-radius:0;
  background:var(--gold); color:var(--film-bg); transition:background .5s var(--ease), letter-spacing .5s var(--ease), color .5s var(--ease); }
.cbtn:hover{ background:var(--film-fg); letter-spacing:.3em; }
.cbtn .arrow{ transition:transform .5s var(--ease); }
.cbtn:hover .arrow{ transform:translateX(5px); }
.cbtn--ghost{ background:transparent; color:var(--film-fg); box-shadow:inset 0 0 0 1px var(--film-line2); }
.cbtn--ghost:hover{ background:var(--film-fg); color:var(--film-bg); box-shadow:none; }
.tlink{ display:inline-flex; align-items:center; gap:.5em; font-family:var(--sans); font-weight:500; font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--film-mut); border-bottom:1px solid var(--film-line); padding-bottom:.3em; transition:color .4s, border-color .4s; }
.tlink:hover{ color:var(--gold); border-color:var(--gold); }

/* ---------- film letterbox frame ---------- */
.lbox{ position:relative; overflow:hidden; background:#000; }
.lbox::before,.lbox::after{ content:""; position:absolute; left:0; right:0; height:6.5%; background:#000; z-index:3; pointer-events:none; }
.lbox::before{ top:0; } .lbox::after{ bottom:0; }
.lbox img,.lbox video{ width:100%; height:100%; object-fit:cover; filter:saturate(.94) contrast(1.04); }

/* sprocket strip */
.sprockets{ display:flex; gap:7px; }
.sprockets i{ width:13px; height:17px; border-radius:2px; background:var(--film-line2); flex:0 0 auto; }

/* ============================================================
   NAV (dark)
   ============================================================ */
.cnav{ position:absolute; top:0; left:0; right:0; z-index:50; display:flex; align-items:center; justify-content:space-between;
  padding:clamp(1.1rem,2.4vw,1.9rem) clamp(1.4rem,3.5vw,3.2rem); gap:1.5rem; }
.cnav__brand{ display:flex; align-items:center; gap:.7rem; }
.cnav__mark{ width:40px; height:auto; color:var(--film-fg); }
.cnav__lock{ display:flex; flex-direction:column; line-height:1; }
.cnav__lock b{ font-family:var(--serif); font-size:1.05rem; letter-spacing:.01em; }
.cnav__lock span{ font-family:var(--mono); font-size:.5rem; letter-spacing:.24em; text-transform:uppercase; color:var(--film-dim); margin-top:.25em; }
.cnav__links{ display:flex; align-items:center; gap:clamp(.8rem,1.6vw,1.6rem); }
.cnav__links a{ white-space:nowrap; }
.cnav__links a{ font-family:var(--sans); font-weight:500; font-size:.66rem; letter-spacing:.12em; text-transform:uppercase; color:var(--film-mut); transition:color .35s; }
.cnav__links a:hover,.cnav__links a.active{ color:var(--film-fg); }
.cnav__cta{ color:var(--film-bg) !important; background:var(--gold); padding:.7em 1.3em; font-size:.68rem !important; letter-spacing:.18em !important; transition:background .4s, letter-spacing .4s; }
.cnav__cta:hover{ background:var(--film-fg); letter-spacing:.24em !important; }
@media (max-width:880px){ .cnav__links a:not(.cnav__cta){ display:none; } }

/* ============================================================
   LOGIN — cinematic split
   ============================================================ */
.clogin{ display:grid; grid-template-columns:1.05fr 1fr; min-height:100svh; }

/* left: sign-in */
.clogin__form{ position:relative; z-index:2; display:flex; flex-direction:column; justify-content:center;
  padding:clamp(5rem,9vw,8rem) clamp(1.6rem,6vw,7rem) clamp(2.5rem,5vw,4rem); }
.clogin__top{ position:absolute; top:clamp(1.4rem,3vw,2.4rem); left:clamp(1.6rem,6vw,7rem); right:clamp(1.6rem,6vw,7rem);
  display:flex; align-items:center; justify-content:space-between; }
.clogin__back{ font-family:var(--sans); font-weight:500; font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--film-mut); display:inline-flex; gap:.6em; align-items:center; transition:color .35s; }
.clogin__back:hover{ color:var(--gold); }

.clogin__inner{ width:100%; max-width:27rem; }
.clogin__mark{ width:62px; height:auto; color:var(--film-fg); margin-bottom:2.2rem; }
.clogin__reel{ display:flex; align-items:center; gap:1rem; margin-bottom:1.5rem; }
.clogin h1{ font-size:clamp(2.8rem,5.5vw,4.4rem); line-height:.92; margin:.2rem 0 .9rem; }
.clogin h1 em{ font-style:italic; color:var(--gold); }
.clogin__sub{ font-family:var(--sans); font-weight:300; color:var(--film-mut); font-size:1.02rem; max-width:32ch; margin-bottom:2.4rem; }

.cfield{ display:block; margin-bottom:1.15rem; }
.cfield > span{ display:block; font-family:var(--mono); font-size:.58rem; letter-spacing:.22em; text-transform:uppercase; color:var(--film-dim); margin-bottom:.55rem; }
.cinwrap{ position:relative; display:flex; align-items:center; }
.cfield input{ width:100%; font-family:var(--sans); font-size:1rem; color:var(--film-fg);
  background:var(--film-bg2); border:1px solid var(--film-line); border-radius:0;
  padding:1.05em 1.1em; transition:border-color .4s, background .4s; }
.cfield input::placeholder{ color:var(--film-dim); }
.cfield input:focus{ outline:none; border-color:var(--gold); background:var(--film-bg3); }
.creveal{ position:absolute; right:.4rem; font-family:var(--mono); font-size:.58rem; letter-spacing:.18em; text-transform:uppercase; color:var(--film-dim); padding:.5em .7em; transition:color .35s; }
.creveal:hover{ color:var(--gold); }

.crow{ display:flex; align-items:center; justify-content:space-between; gap:1rem; margin:.3rem 0 1.8rem; flex-wrap:wrap; }
.ccheck{ display:inline-flex; align-items:center; gap:.6em; font-size:.8rem; color:var(--film-mut); cursor:pointer; }
.ccheck input{ position:absolute; opacity:0; width:0; height:0; }
.cbox{ width:17px; height:17px; border:1px solid var(--film-line2); display:inline-grid; place-items:center; transition:.3s; }
.cbox::after{ content:"✓"; font-size:.7rem; color:var(--film-bg); opacity:0; transition:.3s; }
.ccheck input:checked + .cbox{ background:var(--gold); border-color:var(--gold); }
.ccheck input:checked + .cbox::after{ opacity:1; }
.cforgot{ font-size:.78rem; color:var(--film-mut); border-bottom:1px solid var(--film-line); padding-bottom:.2em; transition:color .35s,border-color .35s; }
.cforgot:hover{ color:var(--gold); border-color:var(--gold); }

.clogin__btn{ width:100%; justify-content:center; }
.cmsg{ font-family:var(--mono); font-size:.66rem; letter-spacing:.08em; color:var(--gold); margin-top:1rem; min-height:1.2em; opacity:0; transition:opacity .4s; }
.cmsg.show{ opacity:1; }
.clogin__foot{ font-size:.84rem; color:var(--film-mut); margin-top:2.4rem; padding-top:1.6rem; border-top:1px solid var(--film-line); }
.clogin__foot a{ color:var(--gold); border-bottom:1px solid transparent; transition:border-color .35s; }
.clogin__foot a:hover{ border-color:var(--gold); }

/* right: cinematic photo */
.clogin__photo{ position:relative; overflow:hidden; background:#000; }
.clogin__photo img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; filter:saturate(.9) contrast(1.05) brightness(.82); }
.clogin__photo::after{ content:""; position:absolute; inset:0; background:linear-gradient(105deg, var(--film-bg) 0%, transparent 34%, transparent 66%, rgba(20,16,14,.55) 100%); }
.clogin__bars{ position:absolute; inset:0; z-index:3; pointer-events:none; }
.clogin__bars::before,.clogin__bars::after{ content:""; position:absolute; left:0; right:0; height:7%; background:#000; }
.clogin__bars::before{ top:0; } .clogin__bars::after{ bottom:0; }
.clogin__tc{ position:absolute; z-index:4; left:clamp(1.4rem,3vw,2.4rem); top:calc(7% + clamp(1rem,2vw,1.6rem)); display:flex; align-items:center; gap:.8rem; }
.clogin__tc i{ width:8px; height:8px; border-radius:50%; background:#e0654a; box-shadow:0 0 0 0 rgba(224,101,74,.6); animation:cpulse 1.7s infinite; }
@keyframes cpulse{ 0%{ box-shadow:0 0 0 0 rgba(224,101,74,.55); } 100%{ box-shadow:0 0 0 10px rgba(224,101,74,0); } }
.clogin__seal{ position:absolute; z-index:4; right:clamp(1.4rem,3vw,2.4rem); top:calc(7% + clamp(1rem,2vw,1.6rem)); width:78px; height:78px; border-radius:50%;
  border:1px dashed rgba(244,239,230,.45); display:grid; place-items:center; text-align:center; color:var(--film-fg); }
.clogin__seal i{ font-family:var(--serif); font-style:normal; font-size:1.05rem; line-height:1; }
.clogin__seal b{ display:block; font-family:var(--mono); font-size:.42rem; letter-spacing:.2em; text-transform:uppercase; color:rgba(244,239,230,.65); margin-top:.2em; }
.clogin__quote{ position:absolute; z-index:4; left:clamp(1.4rem,3vw,2.6rem); right:clamp(1.4rem,3vw,2.6rem); bottom:calc(7% + clamp(1.2rem,3vw,2.4rem)); }
.clogin__quote p{ font-family:var(--serif); font-style:italic; font-size:clamp(1.3rem,2vw,1.9rem); line-height:1.24; color:var(--film-fg); max-width:24ch; }
.clogin__quote cite{ display:block; font-family:var(--mono); font-style:normal; font-size:.6rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin-top:1rem; }

@media (max-width:860px){
  .clogin{ grid-template-columns:1fr; }
  .clogin__photo{ order:-1; min-height:38svh; }
  .clogin__photo img{ position:absolute; }
  .clogin__form{ padding-top:3.5rem; }
  .clogin__top{ position:static; margin-bottom:2rem; }
}

/* ============================================================
   JOURNAL — bold cinematic editorial
   ============================================================ */
.cj-hero{ position:relative; padding:clamp(8rem,16vw,13rem) 0 clamp(3rem,6vw,5rem); }
.cj-hero__wm{ position:absolute; right:-2%; top:38%; font-family:var(--serif); font-style:italic; font-size:clamp(8rem,28vw,26rem); line-height:.7; color:var(--film-bg2); z-index:0; pointer-events:none; user-select:none; }
.cj-hero__in{ position:relative; z-index:2; }
.cj-hero__sig{ font-family:var(--script); font-size:clamp(2rem,4vw,3.2rem); color:var(--gold); display:block; margin:.6rem 0 -.4rem; }
.cj-hero h1{ font-size:clamp(3.6rem,12vw,11rem); line-height:.84; }
.cj-hero h1 em{ font-style:italic; color:var(--gold); }
.cj-hero__lead{ font-family:var(--sans); font-weight:300; font-size:clamp(1.05rem,1.5vw,1.3rem); color:var(--film-mut); max-width:46ch; margin-top:1.8rem; }
.cj-hero__meta{ display:flex; gap:2rem; margin-top:2.2rem; flex-wrap:wrap; }
.cj-hero__meta span{ font-family:var(--mono); font-size:.62rem; letter-spacing:.2em; text-transform:uppercase; color:var(--film-dim); }
.cj-hero__meta b{ color:var(--gold); font-weight:400; }

/* featured story — cinematic poster */
.cj-feature{ position:relative; display:block; margin-bottom:clamp(4rem,8vw,7rem); }
.cj-feature__frame{ position:relative; aspect-ratio:21/9; overflow:hidden; background:#000; }
.cj-feature__frame img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease); filter:saturate(.92) contrast(1.05) brightness(.86); }
.cj-feature:hover .cj-feature__frame img{ transform:scale(1.045); }
.cj-feature__frame::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(18,14,12,.1) 30%, rgba(18,14,12,.82)); }
.cj-feature__tc{ position:absolute; top:clamp(1.1rem,2.5vw,2rem); left:clamp(1.1rem,2.5vw,2rem); right:clamp(1.1rem,2.5vw,2rem); z-index:3; display:flex; align-items:center; justify-content:space-between; }
.cj-feature__body{ position:absolute; left:0; bottom:0; z-index:3; padding:clamp(1.6rem,4vw,3.4rem); max-width:60rem; }
.cj-tag{ display:inline-flex; align-items:center; gap:.6em; font-family:var(--mono); font-size:.6rem; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); margin-bottom:1rem; }
.cj-tag::before{ content:""; width:1.6em; height:1px; background:currentColor; }
.cj-feature h2{ font-size:clamp(1.9rem,4.6vw,4rem); line-height:1.0; max-width:20ch; color:var(--film-fg); }
.cj-feature__rt{ font-family:var(--mono); font-size:.64rem; letter-spacing:.16em; text-transform:uppercase; color:var(--film-mut); margin-top:1.2rem; display:inline-flex; align-items:center; gap:.7em; }
.cj-feature__rt .arrow{ color:var(--gold); transition:transform .5s var(--ease); }
.cj-feature:hover .cj-feature__rt .arrow{ transform:translateX(6px); }

/* section label */
.cj-band{ display:flex; align-items:baseline; justify-content:space-between; gap:1.5rem; padding:clamp(2.2rem,5vw,4rem) 0 clamp(1.6rem,3vw,2.4rem); border-top:1px solid var(--film-line); flex-wrap:wrap; }
.cj-band h3{ font-size:clamp(1.6rem,3vw,2.6rem); }
.cj-band h3 em{ font-style:italic; color:var(--gold); }

/* post grid */
.cj-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.6rem,2.6vw,2.6rem) clamp(1.2rem,2.2vw,2rem); }
.cj-post{ display:flex; flex-direction:column; }
.cj-post__frame{ position:relative; aspect-ratio:4/3; overflow:hidden; background:#000; margin-bottom:1.2rem; }
.cj-post__frame img{ width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease); filter:saturate(.92) contrast(1.04) brightness(.9); }
.cj-post:hover .cj-post__frame img{ transform:scale(1.06); }
.cj-post__num{ position:absolute; top:0; left:0; z-index:2; font-family:var(--mono); font-size:.58rem; letter-spacing:.18em; color:var(--film-fg); background:rgba(18,14,12,.6); padding:.5em .8em; backdrop-filter:blur(4px); }
.cj-post__tag{ font-family:var(--mono); font-size:.6rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin-bottom:.7rem; }
.cj-post h4{ font-family:var(--serif); font-size:clamp(1.25rem,1.9vw,1.7rem); line-height:1.12; color:var(--film-fg); transition:color .4s; }
.cj-post:hover h4{ color:var(--gold); }
.cj-post__ex{ font-family:var(--sans); font-weight:300; font-size:.92rem; color:var(--film-mut); max-width:42ch; margin-top:.6rem; }
.cj-post__rt{ font-family:var(--mono); font-size:.58rem; letter-spacing:.16em; text-transform:uppercase; color:var(--film-dim); margin-top:.9rem; }
@media (max-width:900px){ .cj-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .cj-grid{ grid-template-columns:1fr; } }

/* big CTA band → package builder */
.cj-cta{ position:relative; margin:clamp(4rem,9vw,8rem) 0 0; padding:clamp(3.5rem,8vw,7rem) 0; border-top:1px solid var(--film-line); overflow:hidden; }
.cj-cta__wm{ position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); font-family:var(--serif); font-style:italic; font-size:clamp(7rem,22vw,20rem); color:var(--film-bg2); z-index:0; white-space:nowrap; pointer-events:none; }
.cj-cta__in{ position:relative; z-index:2; text-align:center; display:flex; flex-direction:column; align-items:center; }
.cj-cta h2{ font-size:clamp(2.4rem,6vw,5.2rem); line-height:.96; }
.cj-cta h2 em{ font-style:italic; color:var(--gold); }
.cj-cta p{ font-family:var(--sans); font-weight:300; color:var(--film-mut); max-width:42ch; margin:1.4rem 0 2.2rem; }

/* newsletter */
.cj-news{ border-top:1px solid var(--film-line); padding:clamp(3rem,6vw,5rem) 0; text-align:center; }
.cj-news h3{ font-size:clamp(1.8rem,3.4vw,2.8rem); max-width:18ch; margin:.6rem auto 1.8rem; line-height:1.04; }
.cj-news form{ display:flex; gap:.7rem; max-width:30rem; margin-inline:auto; flex-wrap:wrap; justify-content:center; }
.cj-news input{ flex:1; min-width:14rem; font-family:var(--sans); font-size:.95rem; color:var(--film-fg); background:var(--film-bg2); border:1px solid var(--film-line); padding:1.05em 1.3em; }
.cj-news input::placeholder{ color:var(--film-dim); }
.cj-news input:focus{ outline:none; border-color:var(--gold); }

/* dark footer tweaks */
.cine .foot{ background:transparent; border-top:1px solid var(--film-line); color:var(--film-mut); }
.cine .foot a{ color:var(--film-mut); }
.cine .foot a:hover{ color:var(--gold); }
.cine .foot__brand.lc{ color:var(--film-fg); }
.cine .foot h4{ color:var(--film-fg); }

/* reveal */
.crv{ opacity:0; }
.crv.in{ animation:crvIn .9s var(--ease) both; }
.crv.in[data-d="1"]{ animation-delay:.12s; } .crv.in[data-d="2"]{ animation-delay:.24s; } .crv.in[data-d="3"]{ animation-delay:.36s; }
@keyframes crvIn{ from{ opacity:0; transform:translateY(28px); } to{ opacity:1; transform:none; } }
@media (prefers-reduced-motion:reduce){ .crv{ opacity:1; } .crv.in{ animation:none; } .clogin__tc i{ animation:none; } }
