*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --deep:   #020810;
  --navy:   #06101f;
  --mid:    #0b1836;
  --glass:  rgba(255,255,255,0.035);
  --border: rgba(196,153,30,0.18);

  --gd:  #6b4c0d;
  --gm:  #c4991e;
  --gl:  #e8c338;
  --gb:  #f4df78;

  --cream: #f9f4ea;
  --dim:   rgba(249,244,234,0.55);
  --dimr:  rgba(249,244,234,0.28);
}

html { scroll-behavior: smooth; }

body {
  font-family: 'Cormorant Garamond', Georgia, serif;
  background: var(--deep);
  color: var(--cream);
  overflow-x: hidden;
  cursor: none;
}

* { cursor: none !important; }

::-webkit-scrollbar { width: 3px; }
::-webkit-scrollbar-track { background: var(--deep); }
::-webkit-scrollbar-thumb { background: var(--gm); border-radius: 2px; }

/* ── CURSOR ── */
#cur {
  position: fixed; width: 10px; height: 10px;
  background: var(--gl); border-radius: 50%;
  pointer-events: none; z-index: 9999;
  transform: translate(-50%,-50%);
  transition: transform .15s, width .25s, height .25s, background .25s;
}
#cur-ring {
  position: fixed; width: 34px; height: 34px;
  border: 1px solid rgba(196,153,30,.42); border-radius: 50%;
  pointer-events: none; z-index: 9998;
  transform: translate(-50%,-50%);
  transition: width .3s, height .3s, border-color .3s;
}
body.hl #cur      { width: 18px; height: 18px; background: var(--gb); }
body.hl #cur-ring { width: 52px; height: 52px; border-color: var(--gm); }

/* ── CANVAS ── */
#cnv { position: fixed; inset: 0; pointer-events: none; z-index: 0; }

/* ── LOGO DORADO ── */
.logo-gold {
  filter: invert(1) sepia(.88) saturate(3.8) hue-rotate(5deg);
  mix-blend-mode: screen;
}

/* ── HERO ── */
.hero {
  position: relative; min-height: 100vh;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  overflow: hidden; z-index: 1;
}

.hero-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 75% 55% at 50% -5%,  rgba(196,153,30,.22) 0%, transparent 65%),
    radial-gradient(ellipse 38% 65% at 50%  -2%,  rgba(255,248,200,.09) 0%, transparent 50%),
    radial-gradient(ellipse 100% 55% at 50% 110%, var(--deep) 0%, transparent 70%),
    linear-gradient(180deg, #04091a 0%, #020810 100%);
}

.hero-grain {
  position: absolute; inset: 0; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.055'/%3E%3C/svg%3E");
  opacity: .5;
}

.rays { position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: 120vw; height: 100vh; overflow: hidden; pointer-events: none; }
.ray {
  position: absolute; top: 0; left: 50%;
  transform-origin: top center;
  background: linear-gradient(to bottom, rgba(196,153,30,.07), transparent 80%);
  clip-path: polygon(50% 0%, 100% 100%, 0% 100%);
}
.ray:nth-child(1) { width: 180px; height: 85vh; transform: translateX(-50%) rotate(-32deg); opacity: .75; }
.ray:nth-child(2) { width: 280px; height: 78vh; transform: translateX(-50%) rotate(-16deg); background: linear-gradient(to bottom, rgba(255,248,200,.05), transparent 70%); }
.ray:nth-child(3) { width: 240px; height: 96vh; transform: translateX(-50%) rotate(0deg); opacity: .85; }
.ray:nth-child(4) { width: 190px; height: 72vh; transform: translateX(-50%) rotate(16deg); }
.ray:nth-child(5) { width: 260px; height: 82vh; transform: translateX(-50%) rotate(30deg); opacity: .65; }
.ray:nth-child(6) { width: 140px; height: 68vh; transform: translateX(-50%) rotate(-47deg); opacity: .4; }
.ray:nth-child(7) { width: 165px; height: 75vh; transform: translateX(-50%) rotate(47deg); opacity: .4; }

.hero-content { position: relative; z-index: 2; text-align: center; padding: 2rem; }

.h-logo-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.h-logo-glow {
  position: absolute;
  width: 120%; height: 60%;
  background: radial-gradient(ellipse, rgba(196,153,30,.35) 0%, transparent 70%);
  filter: blur(30px);
  pointer-events: none;
  animation: slideU 1.1s cubic-bezier(.16,1,.3,1) forwards .7s;
  opacity: 0;
}

.h-logo {
  width: clamp(220px, 46vw, 520px);
  position: relative;
  animation:
    slideU 1.1s cubic-bezier(.16,1,.3,1) forwards .7s,
    logoGlow 5s ease-in-out infinite 2.5s;
  opacity: 0;
}

@keyframes logoGlow {
  0%,100% {
    filter: invert(1) sepia(.88) saturate(3.8) hue-rotate(5deg)
            drop-shadow(0 0 40px rgba(196,153,30,.25));
    mix-blend-mode: screen;
  }
  50% {
    filter: invert(1) sepia(.88) saturate(3.8) hue-rotate(5deg) brightness(1.35)
            drop-shadow(0 0 80px rgba(244,223,120,.42));
    mix-blend-mode: screen;
  }
}

.h-line {
  width: 90px; height: 1px;
  background: linear-gradient(90deg, transparent, var(--gm), transparent);
  margin: 1.8rem auto;
  opacity: 0; animation: fadeI .8s ease forwards 1.65s;
}

.h-tagline {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.05rem,2.4vw,1.65rem); font-weight: 300; font-style: italic;
  color: var(--dim); letter-spacing: .04em;
  opacity: 0; animation: slideU .9s ease forwards 1.85s;
}

.h-scroll {
  position: absolute; bottom: 2.5rem; left: 50%; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: .55rem;
  opacity: 0; animation: fadeI 1s ease forwards 2.5s;
}
.h-scroll span { font-size: .62rem; letter-spacing: .35em; color: var(--dimr); text-transform: uppercase; }
.h-scroll-bar { width: 1px; height: 46px; background: linear-gradient(to bottom, var(--gm), transparent); animation: scrollP 2.5s ease-in-out infinite; }

/* ── MANIFESTO ── */
.manifesto {
  position: relative; z-index: 1; text-align: center;
  padding: 6.5rem 2rem;
  background: linear-gradient(180deg, var(--deep) 0%, var(--navy) 50%, var(--deep) 100%);
  overflow: hidden;
}
.manifesto::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse 55% 85% at 50% 50%, rgba(196,153,30,.055) 0%, transparent 70%);
}
.m-inner { position: relative; max-width: 860px; margin: 0 auto; }
.m-orn { font-size: 2rem; color: var(--gm); opacity: .45; display: block; margin-bottom: 1.6rem; }
.m-quote {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.8rem,4.2vw,3rem); font-weight: 300; font-style: italic;
  line-height: 1.4; color: var(--cream);
}
.m-quote em {
  font-style: normal;
  background: linear-gradient(95deg, var(--gl), var(--gb));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.m-ref { margin-top: 2rem; font-size: .75rem; letter-spacing: .32em; color: var(--dimr); text-transform: uppercase; }

/* ── RULE ── */
.rule { position: relative; z-index: 1; height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--border) 15%, var(--gm) 40%, rgba(196,153,30,.35) 65%, var(--border) 85%, transparent 100%); }
.rule-dot {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%) rotate(45deg);
  width: 7px; height: 7px; background: var(--gm);
}

/* ── GALLERY ── */
.gallery {
  position: relative; z-index: 1;
  background: linear-gradient(180deg, var(--deep) 0%, var(--mid) 60%, var(--deep) 100%);
  padding: 7rem 2.5rem;
}
.g-inner { max-width: 1100px; margin: 0 auto; }
.g-header { text-align: center; margin-bottom: 3rem; }
.g-title { font-family:'Cinzel',serif; font-size:clamp(2rem,4vw,3rem); font-weight:700; color:var(--cream); }

.g-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: 240px;
  gap: 1rem;
}

.g-item {
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--glass);
  position: relative;
  transition: border-color .4s, box-shadow .4s;
}
.g-item:hover {
  border-color: rgba(196,153,30,.4);
  box-shadow: 0 0 30px rgba(196,153,30,.08);
}
.g-item::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 60% at 50% 50%, rgba(196,153,30,.04) 0%, transparent 70%),
    repeating-linear-gradient(45deg, rgba(196,153,30,.03) 0px, rgba(196,153,30,.03) 1px, transparent 1px, transparent 12px);
  pointer-events: none;
}
.g-item::after {
  content: '✦';
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem; color: var(--gm); opacity: .18;
  pointer-events: none;
}
.g-item img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform .65s cubic-bezier(.16,1,.3,1), opacity .4s;
}
.g-item img[src=""] { opacity: 0; }
.g-item:hover img { transform: scale(1.06); }
.g-tall { grid-row: span 2; }
.g-wide { grid-column: span 2; }

/* ── STREAMING ── */
.streaming { position: relative; z-index: 1; background: var(--navy); }
.s-wrap {
  max-width: 1200px; margin: 0 auto; padding: 7rem 2.5rem;
  display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center;
}
.s-label { font-family:'Cinzel',serif; font-size:.7rem; letter-spacing:.44em; text-transform:uppercase; color:var(--gm); display:block; margin-bottom:1rem; }
.s-title { font-family:'Cinzel',serif; font-size:clamp(2.1rem,4.2vw,3.6rem); font-weight:700; line-height:1.05; color:var(--cream); margin-bottom:1.5rem; }
.s-body  { font-size:1.12rem; font-weight:300; color:var(--dim); line-height:1.85; max-width:400px; }

.pcards { display:flex; flex-direction:column; gap:.85rem; }
.pcard {
  display:flex; align-items:center; gap:1rem; padding:1.1rem 1.5rem;
  background:var(--glass); border:1px solid var(--border); border-radius:14px;
  backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
  text-decoration:none; color:var(--cream);
  transition: all .4s cubic-bezier(.16,1,.3,1);
  position:relative; overflow:hidden;
}
.pcard::before { content:''; position:absolute; left:0; top:0; bottom:0; width:2px; transition:all .4s; }
.pcard::after  { content:''; position:absolute; inset:0; opacity:0; transition:opacity .4s; }
.pcard:hover { transform: translateX(10px); border-color:rgba(255,255,255,.07); }
.pcard:hover::after { opacity:.04; }

.pc-sp { color:#1DB954; } .pc-sp::before,.pc-sp::after { background:#1DB954; } .pc-sp:hover { box-shadow:-4px 0 24px rgba(29,185,84,.15); }
.pc-am { color:#ff6b6b; } .pc-am::before,.pc-am::after { background:#ff6b6b; } .pc-am:hover { box-shadow:-4px 0 24px rgba(255,107,107,.15); }
.pc-yt { color:#FF4444; } .pc-yt::before,.pc-yt::after { background:#FF4444; } .pc-yt:hover { box-shadow:-4px 0 24px rgba(255,68,68,.15); }

.pcard-ico { width:42px; height:42px; border-radius:10px; background:currentColor; flex-shrink:0; display:flex; align-items:center; justify-content:center; }
.pcard-ico svg { width:22px; height:22px; fill:var(--deep); }
.pcard-info { flex:1; }
.pcard-name { font-family:'Cinzel',serif; font-size:.86rem; font-weight:600; letter-spacing:.05em; color:var(--cream); display:block; }
.pcard-sub  { font-size:.82rem; color:var(--dim); font-style:italic; }
.pcard-arr  { color:currentColor; opacity:.5; font-size:1.1rem; transition:transform .3s, opacity .3s; }
.pcard:hover .pcard-arr { transform:translateX(5px); opacity:1; }

/* ── SPOTIFY EMBED ── */
.spotify-section {
  position: relative; z-index: 1;
  background: linear-gradient(180deg, var(--navy) 0%, var(--deep) 100%);
  padding: 7rem 2.5rem;
}
.sp-inner { max-width: 900px; margin: 0 auto; }
.sp-header { text-align: center; margin-bottom: 3rem; }
.sp-title { font-family:'Cinzel',serif; font-size:clamp(2rem,4vw,3rem); font-weight:700; color:var(--cream); }
.sp-frame-wrap {
  border-radius: 20px; overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: 0 20px 60px rgba(0,0,0,.5), 0 0 40px rgba(196,153,30,.06);
}
.sp-frame-wrap iframe { display: block; width: 100%; border: none; }

/* ── YOUTUBE SECTION ── */
.yt-section {
  position: relative; z-index: 1;
  background: var(--deep);
  padding: 7rem 2.5rem;
}
.yt-inner { max-width: 1100px; margin: 0 auto; }
.yt-header { text-align: center; margin-bottom: 3rem; }
.yt-title { font-family:'Cinzel',serif; font-size:clamp(2rem,4vw,3rem); font-weight:700; color:var(--cream); }
.yt-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
.yt-item {
  border-radius: 16px; overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: 0 8px 30px rgba(0,0,0,.4);
  aspect-ratio: 16/9;
  position: relative; display: block;
  text-decoration: none;
  transition: border-color .4s, box-shadow .4s, transform .4s;
  cursor: pointer !important;
}
.yt-item:hover {
  border-color: rgba(196,153,30,.4);
  box-shadow: 0 16px 50px rgba(196,153,30,.12), 0 4px 20px rgba(0,0,0,.5);
  transform: translateY(-4px);
}
.yt-thumb {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform .5s cubic-bezier(.16,1,.3,1), filter .4s;
  filter: brightness(.85);
}
.yt-item:hover .yt-thumb { transform: scale(1.04); filter: brightness(1); }
.yt-play { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; pointer-events: none; }
.yt-play-btn {
  width: 64px; height: 64px; border-radius: 50%;
  background: rgba(255,0,0,.88);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 24px rgba(0,0,0,.5);
  transition: transform .3s, background .3s, box-shadow .3s;
}
.yt-item:hover .yt-play-btn { transform: scale(1.12); background: #FF0000; box-shadow: 0 8px 40px rgba(255,0,0,.4); }
.yt-play-btn svg { width: 26px; height: 26px; fill: white; margin-left: 4px; }

/* ── SOCIAL ── */
.social { position:relative; z-index:1; padding:7rem 2.5rem; background:linear-gradient(180deg,var(--deep) 0%,var(--mid) 50%,var(--deep) 100%); }
.soc-inner { max-width:880px; margin:0 auto; text-align:center; }
.soc-title { font-family:'Cinzel',serif; font-size:clamp(2rem,4vw,3rem); font-weight:700; color:var(--cream); margin-bottom:3.5rem; }
.soc-grid  { display:grid; grid-template-columns:1.2fr 1fr; gap:1.25rem; }

.scard {
  display:flex; flex-direction:column; align-items:center; gap:.75rem;
  padding:3rem 2rem 2.5rem; border-radius:24px;
  border:1px solid rgba(255,255,255,.06);
  text-decoration:none; color:var(--cream);
  transition:all .45s cubic-bezier(.16,1,.3,1);
  position:relative; overflow:hidden;
}
.scard::before { content:''; position:absolute; inset:0; opacity:0; transition:opacity .45s; }
.scard:hover { transform:translateY(-9px) scale(1.01); }
.scard:hover::before { opacity:1; }

.sc-ig { background:linear-gradient(145deg, rgba(88,20,120,.2), rgba(185,30,50,.12), rgba(240,150,30,.15)); }
.sc-ig::before { background:linear-gradient(145deg, rgba(131,58,180,.09), rgba(253,29,29,.07), rgba(252,176,69,.09)); }
.sc-ig:hover { box-shadow:0 28px 70px rgba(131,58,180,.24), 0 0 0 1px rgba(131,58,180,.18); }
.sc-fb { background:rgba(24,119,242,.1); }
.sc-fb::before { background:rgba(24,119,242,.07); }
.sc-fb:hover { box-shadow:0 28px 70px rgba(24,119,242,.2), 0 0 0 1px rgba(24,119,242,.18); }

.scard-logo { width:56px; height:56px; border-radius:16px; display:flex; align-items:center; justify-content:center; margin-bottom:.4rem; flex-shrink:0; }
.sc-ig .scard-logo { background:linear-gradient(135deg, #833AB4, #FD1D1D, #FCB045); }
.sc-fb .scard-logo { background:#1877F2; }
.scard-logo svg { width:28px; height:28px; fill:#fff; }

.scard-plat { font-family:'Cinzel',serif; font-size:1rem; font-weight:600; letter-spacing:.08em; }
.scard-hndl { font-size:.88rem; color:var(--dim); font-style:italic; }
.scard-cta {
  margin-top:.85rem; display:inline-flex; align-items:center; gap:.4rem;
  padding:.48rem 1.15rem; border:1px solid rgba(255,255,255,.1); border-radius:999px;
  font-family:'Cinzel',serif; font-size:.62rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--dim); transition:all .3s;
}
.scard:hover .scard-cta { border-color:rgba(255,255,255,.25); color:var(--cream); }

/* ── FOOTER ── */
footer {
  position:relative; z-index:1; background:var(--deep);
  border-top:1px solid var(--border); padding:2.5rem 2.5rem 1.5rem;
}
.ft-wrap {
  max-width:1200px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:2rem;
}
.ft-brand { display:flex; flex-direction:column; gap:.5rem; }
.ft-logo-img { height: 34px; display: block; transition: filter .35s; }
.ft-logo-img:hover { filter: invert(1) sepia(.88) saturate(3.8) hue-rotate(5deg) brightness(1.3); }
.ft-sub { font-size:.72rem; color:var(--dimr); letter-spacing:.12em; text-transform:uppercase; }
.ft-links { display:flex; gap:1.2rem; flex-wrap:wrap; align-items:center; }
.ft-link { font-family:'Cinzel',serif; font-size:.67rem; letter-spacing:.1em; text-transform:uppercase; color:var(--dim); text-decoration:none; transition:color .3s; }
.ft-link:hover { color:var(--gl); }
.ft-copy { font-size:.72rem; color:var(--dimr); }

.ft-credit-bar {
  max-width:1200px; margin:0 auto;
  padding-top:1.25rem; margin-top:1.25rem;
  border-top:1px solid rgba(196,153,30,.08);
  display:flex; justify-content:center;
}
.ft-credit {
  font-family:'Cinzel',serif;
  font-size:.6rem; letter-spacing:.25em; text-transform:uppercase;
  color:var(--dimr); text-decoration:none; transition:color .3s;
}
.ft-credit span { color: var(--gm); font-weight:600; }
.ft-credit:hover { color:var(--dim); }
.ft-credit:hover span { color:var(--gl); }

/* ── ANIMATIONS ── */
@keyframes fadeI  { from{opacity:0} to{opacity:1} }
@keyframes slideD { from{opacity:0;transform:translateY(-20px)} to{opacity:1;transform:translateY(0)} }
@keyframes slideU { from{opacity:0;transform:translateY(35px)} to{opacity:1;transform:translateY(0)} }
@keyframes scrollP { 0%,100%{opacity:.3;transform:scaleY(.7)} 50%{opacity:1;transform:scaleY(1)} }

.rv { opacity:0; transform:translateY(36px); transition:opacity .85s ease, transform .85s ease; }
.rv.on { opacity:1; transform:translateY(0); }
.d1{transition-delay:.1s} .d2{transition-delay:.2s} .d3{transition-delay:.3s} .d4{transition-delay:.42s}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .s-wrap { grid-template-columns:1fr; gap:3rem; padding:5rem 1.5rem; }
  .soc-grid { grid-template-columns:1fr; max-width:400px; margin:0 auto; }
  .g-grid { grid-template-columns:1fr 1fr; }
  .g-wide { grid-column:span 2; }
  .g-tall { grid-row:span 1; }
  .yt-grid { grid-template-columns:1fr; }
}
@media(max-width:600px){
  .g-grid { grid-template-columns:1fr; }
  .g-wide,.g-tall { grid-column:span 1; grid-row:span 1; }
  .ft-wrap { flex-direction:column; align-items:center; text-align:center; }
  .ft-links { justify-content:center; }
}
@media(hover:none){
  body { cursor:auto; } * { cursor:auto !important; }
  #cur, #cur-ring { display:none; }
}
