/* ============================================================
   HARENA — Award-Quality Artist Website
   Dusty Rose × Deep Dark × Collegiate Americana
   ============================================================ */

/* ── DESIGN TOKENS ── */
:root {
    --pink:       #c07090;
    --pink-hot:   #d4849e;
    --pink-muted: #9e5a72;
    --pink-pale:  #e8c5c5;
    --rose:       #b8607a;
    --blush:      rgba(192,112,144,.08);

    --bg:         #0c090a;
    --bg-soft:    #121011;
    --bg-card:    #181416;
    --bg-card2:   #1e1a1c;
    --border:     #2a2325;
    --border-light:#3a3335;

    --cream:      #ede6df;
    --cream-dim:  #d4cbc4;
    --text:       #b8aeaa;
    --text-muted: #7a706e;
    --text-dim:   #504848;

    --serif:      'Instrument Serif', Georgia, serif;
    --sans:       'Inter', -apple-system, system-ui, sans-serif;
    --heading:    'Bebas Neue', Impact, sans-serif;
    --mono:       'Space Grotesk', 'SF Mono', monospace;

    --ease:       cubic-bezier(.16,1,.3,1);
    --ease-out:   cubic-bezier(.33,1,.68,1);
    --ease-in:    cubic-bezier(.32,0,.67,0);
    --ease-expo:  cubic-bezier(.87,0,.13,1);

    --radius:     10px;
    --radius-lg:  18px;
    --gutter:     clamp(1.25rem, 4vw, 3rem);
    --max-w:      1320px;
}

/* ── RESET ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scrollbar-width:thin;scrollbar-color:var(--pink-muted) var(--bg)}
body{font-family:var(--sans);background:var(--bg);color:var(--text);line-height:1.65;overflow-x:hidden}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--pink-muted);border-radius:4px}
::selection{background:var(--pink);color:var(--bg)}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{border:none;background:none;cursor:pointer;font:inherit;color:inherit}
input,textarea,select{font:inherit;color:inherit;background:none;border:none;outline:none}

/* ── GRAIN OVERLAY ── */
body::after{
    content:'';position:fixed;inset:0;z-index:10000;pointer-events:none;
    opacity:.035;
    background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%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='1'/%3E%3C/svg%3E");
    background-size:200px 200px;
}

/* ── CONTAINER ── */
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 var(--gutter)}


/* ============================================================
   LOADER
   ============================================================ */
.loader{
    position:fixed;inset:0;z-index:9999;background:var(--bg);
    display:flex;align-items:center;justify-content:center;flex-direction:column;
}
.loader-inner{text-align:center;position:relative}
.loader-counter{
    font-family:var(--heading);font-size:clamp(5rem,15vw,12rem);
    color:var(--cream);line-height:1;letter-spacing:.02em;
    opacity:.15;
}
.loader-name{
    font-family:var(--heading);font-size:clamp(1.8rem,5vw,3rem);
    letter-spacing:.35em;text-transform:uppercase;color:var(--cream);
    display:flex;gap:.04em;justify-content:center;
    margin-top:1rem;overflow:hidden;
}
.loader-name span{display:inline-block;transform:translateY(120%)}
.loader-line{width:180px;height:1px;background:var(--border);margin:1.5rem auto 0;overflow:hidden}
.loader-line-fill{width:0;height:100%;background:var(--pink)}

/* ============================================================
   CURSOR
   ============================================================ */
.cursor{
    position:fixed;width:48px;height:48px;pointer-events:none;z-index:9998;
    opacity:0;transform:translate(-50%,-50%);
    display:flex;align-items:center;justify-content:center;
}
.cursor-circle{
    width:100%;height:100%;border:1px solid rgba(192,112,144,.5);border-radius:50%;
    transition:width .35s var(--ease),height .35s var(--ease),border-color .3s;
}
.cursor-label{
    position:absolute;font-size:.55rem;font-weight:600;letter-spacing:.15em;
    text-transform:uppercase;color:var(--pink);white-space:nowrap;
    opacity:0;transition:opacity .25s;
}
.cursor.has-label .cursor-circle{width:90px;height:90px;border-color:var(--pink)}
.cursor.has-label .cursor-label{opacity:1}
.cursor.hovering .cursor-circle{width:70px;height:70px;border-color:var(--pink-hot)}
.cursor-dot{
    position:fixed;width:5px;height:5px;background:var(--pink);border-radius:50%;
    pointer-events:none;z-index:9998;opacity:0;transform:translate(-50%,-50%);
}
@media(hover:none),(max-width:900px){.cursor,.cursor-dot{display:none!important}}


/* ============================================================
   HEADER
   ============================================================ */
.header{
    position:fixed;top:0;left:0;right:0;z-index:1000;
    padding:0 var(--gutter);
    transition:background .5s,backdrop-filter .5s,-webkit-backdrop-filter .5s;
}
.header.is-scrolled{
    background:rgba(12,9,10,.82);
    backdrop-filter:blur(24px) saturate(1.6);
    -webkit-backdrop-filter:blur(24px) saturate(1.6);
}
.header.is-hidden{transform:translateY(-100%)}
.header{transition:background .5s,backdrop-filter .5s,transform .45s var(--ease)}

.nav{
    display:flex;align-items:center;justify-content:space-between;
    height:clamp(64px,8vw,80px);max-width:var(--max-w);margin:0 auto;
}
.nav-logo{position:relative;z-index:1001}
.nav-logo-text{
    font-family:var(--heading);font-size:1.35rem;letter-spacing:.18em;
    color:var(--cream);text-transform:uppercase;transition:color .4s var(--ease);
}
.nav-logo:hover .nav-logo-text{color:var(--pink)}

.nav-center{display:flex;gap:clamp(1.2rem,2.5vw,2.2rem)}
.nav-link{
    font-size:.7rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
    color:var(--text-muted);transition:color .4s var(--ease);position:relative;
}
.nav-link::after{
    content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;
    background:var(--pink);transition:width .5s var(--ease);
}
.nav-link:hover{color:var(--cream)}
.nav-link:hover::after{width:100%}

.nav-right{display:flex;align-items:center;gap:1.2rem}
.nav-cta{
    display:inline-flex;align-items:center;gap:.45rem;
    font-size:.65rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
    color:var(--pink);border:1px solid rgba(192,112,144,.25);
    padding:.5rem 1rem;border-radius:50px;
    transition:all .4s var(--ease);
}
.nav-cta:hover{background:rgba(192,112,144,.1);border-color:var(--pink)}

.nav-burger{display:none;position:relative;z-index:1001;width:30px;height:20px}
.burger-lines{position:relative;width:100%;height:100%}
.burger-lines span{
    position:absolute;left:0;width:100%;height:1.5px;background:var(--cream);
    transition:transform .4s var(--ease),opacity .3s;
}
.burger-lines span:nth-child(1){top:4px}
.burger-lines span:nth-child(2){bottom:4px}
.nav-burger.is-active .burger-lines span:nth-child(1){transform:translateY(5.5px) rotate(45deg)}
.nav-burger.is-active .burger-lines span:nth-child(2){transform:translateY(-5.5px) rotate(-45deg)}

@media(max-width:900px){
    .nav-center{display:none}
    .nav-burger{display:block}
}

/* ============================================================
   MOBILE MENU
   ============================================================ */
.mob-menu{position:fixed;inset:0;z-index:999;pointer-events:none}
.mob-menu.is-open{pointer-events:all}
.mob-menu-bg{position:absolute;inset:0;background:rgba(12,9,10,.97);opacity:0;transition:opacity .6s var(--ease)}
.mob-menu.is-open .mob-menu-bg{opacity:1}
.mob-menu-nav{
    position:absolute;inset:0;display:flex;flex-direction:column;
    align-items:flex-start;justify-content:center;padding:0 var(--gutter);
    opacity:0;transform:translateY(30px);
    transition:opacity .5s var(--ease) .15s,transform .5s var(--ease) .15s;
}
.mob-menu.is-open .mob-menu-nav{opacity:1;transform:none}
.mob-link{
    display:flex;align-items:baseline;gap:1rem;
    font-family:var(--heading);font-size:clamp(2.8rem,10vw,5rem);
    letter-spacing:.06em;text-transform:uppercase;color:var(--cream);
    padding:.15em 0;transition:color .3s var(--ease);
}
.mob-link:hover{color:var(--pink)}
.mob-link-num{font-family:var(--mono);font-size:.7rem;color:var(--text-dim);letter-spacing:.1em}
.mob-menu-footer{
    display:flex;flex-wrap:wrap;gap:1.2rem;margin-top:2.5rem;
}
.mob-menu-footer a{
    font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;
    color:var(--text-dim);transition:color .3s var(--ease);
}
.mob-menu-footer a:hover{color:var(--pink)}


/* ============================================================
   HERO
   ============================================================ */
.hero{
    position:relative;min-height:100vh;min-height:100svh;
    display:flex;flex-direction:column;justify-content:center;
    overflow:hidden;padding:0 var(--gutter);
}

/* Ambient orbs */
.hero-ambient{position:absolute;inset:0;overflow:hidden;z-index:0}
.hero-orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.12}
.hero-orb-1{width:600px;height:600px;background:var(--pink);top:-15%;right:-5%;animation:orbFloat 12s ease-in-out infinite}
.hero-orb-2{width:400px;height:400px;background:var(--rose);bottom:5%;left:-8%;animation:orbFloat 16s ease-in-out infinite reverse}
.hero-orb-3{width:300px;height:300px;background:var(--pink-muted);top:40%;left:30%;animation:orbFloat 20s ease-in-out infinite 2s}
@keyframes orbFloat{
    0%,100%{transform:translate(0,0) scale(1)}
    33%{transform:translate(30px,-20px) scale(1.05)}
    66%{transform:translate(-20px,15px) scale(.95)}
}

/* Grid overlay */
.hero-grid-overlay{
    position:absolute;inset:0;
    background-image:
        linear-gradient(rgba(192,112,144,.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(192,112,144,.03) 1px, transparent 1px);
    background-size:80px 80px;
    mask-image:radial-gradient(ellipse 70% 60% at 50% 50%,black 0%,transparent 70%);
    -webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 50%,black 0%,transparent 70%);
}

.hero-content{position:relative;z-index:2;max-width:var(--max-w);margin:0 auto;width:100%;padding-top:clamp(80px,12vh,120px)}

.hero-tag{display:flex;align-items:center;gap:.8rem;margin-bottom:clamp(1rem,3vw,2rem);opacity:0}
.hero-tag-line{width:36px;height:1px;background:var(--pink)}
.hero-tag-text{font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--pink);font-weight:500}

.hero-title{
    font-family:var(--heading);
    font-size:clamp(5.5rem,16vw,14rem);
    line-height:.85;letter-spacing:.03em;
    color:var(--cream);text-transform:uppercase;
    position:relative;z-index:2;
}
.hero-title-row{display:block;overflow:hidden}
.hero-title-main{display:inline-block;transform:translateY(110%)}

/* Ghost outline text */
.hero-outline{
    font-family:var(--heading);
    font-size:clamp(5.5rem,16vw,14rem);
    line-height:.85;letter-spacing:.03em;
    text-transform:uppercase;
    -webkit-text-stroke:1px rgba(192,112,144,.15);
    color:transparent;
    position:absolute;
    top:50%;left:50%;
    transform:translate(-45%,-48%);
    z-index:1;white-space:nowrap;
    pointer-events:none;
    opacity:0;
}

.hero-bottom{
    display:flex;justify-content:space-between;align-items:flex-end;
    margin-top:clamp(2rem,5vw,4rem);gap:2rem;flex-wrap:wrap;
}
.hero-bottom-left{max-width:440px}
.hero-desc{
    font-family:var(--serif);font-style:italic;
    font-size:clamp(1rem,2vw,1.25rem);
    color:var(--text-muted);line-height:1.55;
    margin-bottom:1.5rem;opacity:0;
}
.hero-actions{display:flex;gap:.8rem;flex-wrap:wrap;opacity:0}
.hero-bottom-right{
    display:flex;flex-direction:column;align-items:flex-end;gap:.3rem;
    opacity:0;
}
.hero-year,.hero-based{
    font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-dim);
}

/* Hero visual */
.hero-visual{
    position:absolute;right:var(--gutter);bottom:0;
    width:clamp(260px,30vw,480px);z-index:1;overflow:hidden;
}
.hero-img-wrap{position:relative;overflow:hidden}
.hero-img-reveal{
    position:absolute;inset:0;background:var(--bg);z-index:2;
    transform-origin:bottom;
}
.hero-img{
    width:100%;height:auto;display:block;
    filter:grayscale(.12) contrast(1.06);
}

/* Scroll cue */
.hero-scroll-cue{
    position:absolute;bottom:clamp(60px,8vh,90px);left:var(--gutter);
    z-index:3;display:flex;flex-direction:column;align-items:center;gap:.6rem;
    opacity:0;
}
.scroll-text{
    font-size:.55rem;letter-spacing:.25em;text-transform:uppercase;
    color:var(--text-dim);writing-mode:vertical-rl;
}
.scroll-line{width:1px;height:50px;background:var(--border);position:relative;overflow:hidden}
.scroll-line-inner{
    position:absolute;top:-100%;left:0;width:100%;height:100%;background:var(--pink);
    animation:scrollPulse 2.2s ease-in-out infinite;
}
@keyframes scrollPulse{0%{top:-100%}50%{top:0}100%{top:100%}}

/* Ticker */
.hero-ticker{
    position:absolute;bottom:0;left:0;right:0;z-index:4;
    overflow:hidden;padding:.65rem 0;
    border-top:1px solid var(--border);
    background:rgba(12,9,10,.55);backdrop-filter:blur(12px);
}
.ticker-track{display:flex;white-space:nowrap;animation:ticker 35s linear infinite}
.ticker-track span{
    font-family:var(--heading);font-size:.75rem;letter-spacing:.28em;
    text-transform:uppercase;color:var(--text-dim);flex-shrink:0;
}
.ticker-reverse{animation-direction:reverse}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

@media(max-width:900px){
    .hero{justify-content:flex-end;padding-bottom:90px}
    .hero-content{padding-top:100px}
    .hero-visual{right:-5%;width:70%;opacity:.2;z-index:0}
    .hero-img-reveal{display:none}
    .hero-scroll-cue{display:none}
    .hero-bottom-right{display:none}
    .hero-outline{display:none}
}


/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
    display:inline-flex;align-items:center;gap:.55rem;
    font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
    padding:.85rem 1.8rem;border-radius:50px;
    position:relative;overflow:hidden;white-space:nowrap;
    transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.btn-fill{
    position:absolute;inset:0;border-radius:inherit;z-index:0;
    transition:transform .5s var(--ease);
}
.btn-text,.btn-arrow{position:relative;z-index:1}
.btn-arrow{display:flex;transition:transform .4s var(--ease)}
.btn:hover .btn-arrow{transform:translateX(3px)}
.btn:hover{transform:translateY(-2px)}

.btn-primary{color:var(--bg)}
.btn-primary .btn-fill{background:var(--pink)}
.btn-primary:hover{box-shadow:0 10px 40px rgba(192,112,144,.3)}
.btn-primary:hover .btn-fill{transform:scale(1.02)}

.btn-ghost{
    color:var(--pink);border:1px solid rgba(192,112,144,.2);
    background:rgba(192,112,144,.06);
}
.btn-ghost:hover{border-color:rgba(192,112,144,.45);background:rgba(192,112,144,.12)}

.btn-outline{
    color:var(--cream);border:1px solid var(--border);
}
.btn-outline:hover{border-color:var(--pink);color:var(--pink)}

.btn-full{width:100%;justify-content:center}
.btn-sm{padding:.65rem 1.3rem;font-size:.65rem}


/* ============================================================
   SECTION LABELS + TITLES
   ============================================================ */
.section-label{display:flex;align-items:center;gap:.8rem;margin-bottom:.6rem}
.label-idx{font-family:var(--mono);font-size:.6rem;font-weight:500;letter-spacing:.12em;color:var(--pink)}
.label-line{width:28px;height:1px;background:var(--border)}
.label-text{font-size:.6rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--text-dim)}

.section-title{
    font-family:var(--heading);
    font-size:clamp(2.8rem,6.5vw,5rem);
    letter-spacing:.04em;color:var(--cream);text-transform:uppercase;
    line-height:.95;margin-bottom:clamp(2.5rem,5vw,4rem);
}


/* ============================================================
   ABOUT
   ============================================================ */
.about{padding:clamp(6rem,12vw,12rem) 0;position:relative}
.about::before{
    content:'';position:absolute;top:0;left:0;right:0;height:1px;
    background:linear-gradient(90deg,transparent,var(--border) 20%,var(--border) 80%,transparent);
}
.about-layout{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(3rem,8vw,9rem);align-items:start}
.about-col-left{position:sticky;top:110px}
.about-img-block{margin-top:1.5rem}
.about-img-frame{
    position:relative;overflow:hidden;border-radius:var(--radius);
    aspect-ratio:3/4;background:var(--bg-card);
}
.about-img-frame img{
    width:100%;height:100%;object-fit:cover;
    transition:transform 1s var(--ease);
}
.about-img-block:hover .about-img-frame img{transform:scale(1.04)}
.about-img-frame::after{
    content:'';position:absolute;inset:0;pointer-events:none;
    background:linear-gradient(180deg,transparent 40%,rgba(12,9,10,.5));
}
.about-img-meta{
    display:flex;justify-content:space-between;padding:.7rem 0;
    font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);
    border-bottom:1px solid var(--border);margin-top:.7rem;
}
.about-headline{
    font-family:var(--serif);font-size:clamp(1.8rem,3.5vw,2.8rem);
    line-height:1.2;color:var(--cream);font-weight:400;
    margin-bottom:clamp(2rem,4vw,3.5rem);
}
.about-text{margin-bottom:1.5rem}
.about-text p{font-size:.92rem;line-height:1.85;color:var(--text);margin-bottom:1.1rem}
.about-text p:last-child{margin-bottom:0}

.about-quote{
    border-left:2px solid var(--pink);padding:1.5rem 0 1.5rem 2rem;
    margin:2rem 0;position:relative;
}
.quote-mark{
    font-family:var(--serif);font-size:4rem;color:var(--pink);
    position:absolute;top:-.5rem;left:2rem;line-height:1;opacity:.3;
}
.about-quote p{
    font-family:var(--serif);font-style:italic;
    font-size:clamp(1.15rem,2vw,1.45rem);
    line-height:1.55;color:var(--pink-pale);
}

@media(max-width:900px){
    .about-layout{grid-template-columns:1fr;gap:3rem}
    .about-col-left{position:relative;top:0}
    .about-img-frame{aspect-ratio:4/3}
}


/* ============================================================
   MUSIC / TRACKS
   ============================================================ */
.music{padding:clamp(6rem,12vw,12rem) 0 0;position:relative}
.music::before{
    content:'';position:absolute;top:0;left:0;right:0;height:1px;
    background:linear-gradient(90deg,transparent,var(--border) 20%,var(--border) 80%,transparent);
}

.tracks{margin-top:1rem}
.track{border-top:1px solid var(--border);transition:background .5s var(--ease)}
.track:last-child{border-bottom:1px solid var(--border)}
.track:hover{background:var(--bg-card)}

.track-inner{
    display:grid;grid-template-columns:auto 140px 1fr;
    gap:clamp(1.5rem,3vw,3rem);align-items:center;
    padding:clamp(1.5rem,3vw,2.5rem) 0;
}

.track-idx{
    font-family:var(--mono);font-size:.7rem;font-weight:500;
    letter-spacing:.1em;color:var(--text-dim);
    min-width:2rem;
}

.track-art{
    width:140px;height:140px;border-radius:var(--radius);
    overflow:hidden;position:relative;flex-shrink:0;
    background:var(--bg-card);
}
.track-art img{
    width:100%;height:100%;object-fit:cover;
    transition:transform .6s var(--ease);
}
.track:hover .track-art img{transform:scale(1.07)}

.track-info{display:flex;flex-direction:column;gap:.5rem}
.track-type{
    font-size:.6rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
    color:var(--pink);
}
.track-title{
    font-family:var(--serif);font-size:clamp(1.3rem,2.5vw,2rem);
    color:var(--cream);font-weight:400;line-height:1.1;
}
.track-desc{font-size:.8rem;color:var(--text-muted);line-height:1.5}

.track-links{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.5rem}
.track-link{
    display:inline-flex;align-items:center;gap:.4rem;
    font-size:.62rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
    color:var(--text-muted);
    padding:.45rem .9rem;border:1px solid var(--border);border-radius:50px;
    transition:all .35s var(--ease);
}
.track-link svg{width:14px;height:14px;flex-shrink:0}
.track-link:hover{
    color:var(--cream);border-color:var(--pink-muted);
    background:rgba(192,112,144,.08);
}

@media(max-width:700px){
    .track-inner{
        grid-template-columns:1fr;gap:1rem;
        padding:1.5rem 0;
    }
    .track-idx{font-size:.6rem}
    .track-art{width:100%;height:auto;aspect-ratio:1}
}


/* ============================================================
   PINK MARQUEE
   ============================================================ */
.pink-marquee{
    padding:.85rem 0;overflow:hidden;background:var(--pink);
    margin:clamp(4rem,8vw,8rem) 0;
}
.pink-marquee .ticker-track span{
    color:var(--bg);font-weight:400;font-size:.85rem;
}


/* ============================================================
   VIDEOS
   ============================================================ */
.videos{padding:clamp(4rem,8vw,8rem) 0;position:relative}
.vids-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:clamp(1rem,2vw,2rem)}
.vid-card{position:relative}
.vid-frame{
    position:relative;padding-bottom:56.25%;height:0;overflow:hidden;
    border-radius:var(--radius);background:var(--bg-card);
}
.vid-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:none}
.vid-meta{padding:.9rem 0 0}
.vid-meta h3{font-family:var(--serif);font-size:1.15rem;color:var(--cream);font-weight:400}
.vid-meta span{font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim)}
.vids-cta{margin-top:clamp(2rem,4vw,3.5rem);text-align:center}

@media(max-width:768px){.vids-grid{grid-template-columns:1fr}}


/* ============================================================
   GALLERY (horizontal scroll)
   ============================================================ */
.gallery{padding:clamp(6rem,12vw,12rem) 0;position:relative;overflow:hidden}
.gallery::before{
    content:'';position:absolute;top:0;left:0;right:0;height:1px;
    background:linear-gradient(90deg,transparent,var(--border) 20%,var(--border) 80%,transparent);
}

.gallery-scroll{
    position:relative;overflow:hidden;
    margin-top:1rem;
}
.gallery-track{
    display:flex;gap:clamp(.8rem,1.5vw,1.5rem);
    padding:0 var(--gutter);
    /* Will be animated by GSAP on desktop */
}
.gallery-card{
    flex-shrink:0;overflow:hidden;border-radius:var(--radius);
    width:clamp(260px,28vw,380px);
    height:clamp(320px,35vw,450px);
    position:relative;
}
.gallery-card-tall{height:clamp(380px,42vw,540px)}
.gallery-card-wide{width:clamp(340px,36vw,500px);height:clamp(280px,28vw,380px)}
.gallery-card img{
    width:100%;height:100%;object-fit:cover;
    transition:transform .8s var(--ease);
}
.gallery-card:hover img{transform:scale(1.05)}
.gallery-card::after{
    content:'';position:absolute;inset:0;pointer-events:none;
    background:linear-gradient(180deg,transparent 50%,rgba(12,9,10,.35));
    opacity:0;transition:opacity .5s;
}
.gallery-card:hover::after{opacity:1}

@media(max-width:768px){
    .gallery-track{
        overflow-x:auto;-webkit-overflow-scrolling:touch;
        scroll-snap-type:x mandatory;
        padding-bottom:1rem;
    }
    .gallery-card{scroll-snap-align:start}
    .gallery-track::-webkit-scrollbar{height:3px}
    .gallery-track::-webkit-scrollbar-thumb{background:var(--pink-muted);border-radius:2px}
}


/* ============================================================
   CONTACT
   ============================================================ */
.contact{padding:clamp(6rem,12vw,12rem) 0;position:relative;background:var(--bg-card)}
.contact::before{
    content:'';position:absolute;top:0;left:0;right:0;height:1px;
    background:linear-gradient(90deg,transparent,var(--border) 20%,var(--border) 80%,transparent);
}
.contact-top{margin-bottom:clamp(2.5rem,5vw,4rem)}
.contact-title{
    font-family:var(--heading);
    font-size:clamp(3.5rem,10vw,8rem);
    line-height:.9;letter-spacing:.03em;text-transform:uppercase;
    color:var(--cream);margin-top:.5rem;
}

.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(3rem,6vw,7rem)}

.contact-info{display:flex;flex-direction:column;gap:2rem}
.contact-block{}
.contact-label{
    display:block;font-size:.6rem;font-weight:600;letter-spacing:.16em;
    text-transform:uppercase;color:var(--text-dim);margin-bottom:.4rem;
}
.contact-val{
    font-family:var(--serif);font-style:italic;font-size:1.05rem;
    color:var(--cream);transition:color .3s var(--ease);
}
.contact-val:hover{color:var(--pink)}
.contact-socials{display:flex;gap:1.2rem;flex-wrap:wrap}
.contact-socials a{
    font-family:var(--serif);font-style:italic;font-size:1rem;
    color:var(--cream);transition:color .3s var(--ease);
}
.contact-socials a:hover{color:var(--pink)}

.contact-note{font-size:.82rem;color:var(--text-muted);margin-bottom:.8rem}
.notify-wrap{
    display:flex;gap:.5rem;
    background:var(--bg);border:1px solid var(--border);
    border-radius:50px;padding:.3rem .3rem .3rem 1.3rem;
    transition:border-color .4s var(--ease);
}
.notify-wrap:focus-within{border-color:var(--pink-muted)}
.notify-wrap input{flex:1;font-size:.82rem;color:var(--cream);min-width:0}
.notify-wrap input::placeholder{color:var(--text-dim)}

/* Form */
.contact-form{display:flex;flex-direction:column;gap:1.6rem}
.form-field label{
    display:block;font-size:.6rem;font-weight:600;letter-spacing:.16em;
    text-transform:uppercase;color:var(--text-dim);margin-bottom:.5rem;
}
.form-field input,
.form-field textarea,
.form-field select{
    width:100%;padding:.85rem 0;font-size:.92rem;color:var(--cream);
    border-bottom:1px solid var(--border);border-radius:0;
    transition:border-color .4s var(--ease);background:transparent;
    -webkit-appearance:none;
}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{border-bottom-color:var(--pink)}
.form-field input::placeholder,.form-field textarea::placeholder{color:var(--text-dim)}
.form-field select{cursor:pointer}
.form-field select option{background:var(--bg-card);color:var(--cream)}
.form-field textarea{resize:vertical;min-height:90px}

@media(max-width:900px){.contact-grid{grid-template-columns:1fr;gap:3rem}}


/* ============================================================
   FOOTER
   ============================================================ */
.footer{padding:clamp(4rem,8vw,6rem) 0 2rem;border-top:1px solid var(--border)}
.footer-main{
    display:grid;grid-template-columns:1fr 2fr;gap:3rem;
    padding-bottom:clamp(3rem,5vw,5rem);border-bottom:1px solid var(--border);
}
.footer-logo{
    font-family:var(--heading);font-size:2.2rem;letter-spacing:.18em;
    color:var(--cream);text-transform:uppercase;
}
.footer-tagline{font-family:var(--serif);font-style:italic;color:var(--text-dim);margin-top:.4rem;font-size:.92rem}
.footer-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.footer-col{display:flex;flex-direction:column;gap:.55rem}
.footer-col-title{
    font-size:.6rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
    color:var(--text-dim);margin-bottom:.4rem;
}
.footer-col a{font-size:.82rem;color:var(--text-muted);transition:color .3s var(--ease)}
.footer-col a:hover{color:var(--pink)}

.footer-bottom{
    display:flex;justify-content:space-between;align-items:center;
    padding-top:1.5rem;flex-wrap:wrap;gap:1rem;
}
.footer-bottom p{font-size:.7rem;color:var(--text-dim)}
.footer-bottom-links{display:flex;gap:1.5rem}
.footer-bottom-links a{font-size:.7rem;color:var(--text-dim);transition:color .3s var(--ease)}
.footer-bottom-links a:hover{color:var(--text)}

.back-to-top{
    display:inline-flex;align-items:center;gap:.4rem;
    font-size:.6rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
    color:var(--text-dim);
    padding:.5rem 1rem;border:1px solid var(--border);border-radius:50px;
    transition:all .4s var(--ease);
}
.back-to-top:hover{color:var(--pink);border-color:var(--pink-muted)}

@media(max-width:768px){
    .footer-main{grid-template-columns:1fr;gap:2rem}
    .footer-cols{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:480px){
    .footer-cols{grid-template-columns:1fr 1fr}
    .footer-bottom{flex-direction:column;align-items:flex-start}
}


/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
[data-reveal]{opacity:0;transform:translateY(50px)}
[data-reveal].is-visible{opacity:1;transform:none;transition:opacity .9s var(--ease),transform .9s var(--ease)}
[data-reveal]:nth-child(2).is-visible{transition-delay:.1s}
[data-reveal]:nth-child(3).is-visible{transition-delay:.2s}

[data-reveal-lines]{opacity:0}
[data-reveal-lines].is-visible{opacity:1;transition:opacity .6s var(--ease)}

/* ============================================================
   ACCESSIBILITY
   ============================================================ */
@media(prefers-reduced-motion:reduce){
    *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
    .ticker-track{animation:none!important}
    [data-reveal],[data-reveal-lines]{opacity:1;transform:none}
    .hero-title-main{transform:none}
    .hero-img-reveal{display:none}
}
:focus-visible{outline:2px solid var(--pink);outline-offset:3px}
a:focus:not(:focus-visible),button:focus:not(:focus-visible){outline:none}
