/* ============================================================
   Robin's Nest Belmar — Homepage + page-hero sections
   ============================================================ */

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;isolation:isolate;background:var(--ink)}
.hero__media{position:absolute;inset:0;z-index:-2}
.hero__media img{width:100%;height:100%;object-fit:cover;will-change:transform}
.hero__media::after{content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(42,28,20,.42) 0%,rgba(42,28,20,.12) 30%,rgba(42,28,20,.28) 62%,rgba(42,28,20,.86) 100%),
    radial-gradient(80% 60% at 15% 90%,rgba(110,29,19,.5),transparent 70%);
}
/* paper grain */
.hero__grain{position:absolute;inset:0;z-index:-1;opacity:.5;mix-blend-mode:overlay;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E")}

.hero__inner{position:relative;width:min(var(--container),100% - var(--gutter)*2);margin-inline:auto;padding-bottom:clamp(3rem,8vh,6rem);padding-top:calc(var(--header-h) + 2rem);color:var(--cream)}
.hero__eyebrow{display:inline-flex;align-items:center;gap:.6rem;color:var(--cream);font-weight:700;text-transform:uppercase;letter-spacing:.2em;font-size:.78rem;background:rgba(255,255,255,.12);backdrop-filter:blur(6px);padding:.5rem 1rem;border-radius:var(--r-pill);border:1px solid rgba(255,255,255,.18)}
.hero__eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--yolk);box-shadow:0 0 0 4px rgba(242,163,60,.35)}
.hero h1{color:#fff;margin:1.2rem 0 1rem;max-width:16ch;text-shadow:0 2px 30px rgba(0,0,0,.35)}
.hero h1 .script{color:var(--yolk)}
.hero__sub{font-size:clamp(1.1rem,1rem + .7vw,1.5rem);max-width:44ch;color:rgba(255,255,255,.92);line-height:1.5}
.hero__cta{margin-top:2rem;display:flex;flex-wrap:wrap;gap:.9rem;align-items:center}
.hero__meta{margin-top:2.4rem;display:flex;flex-wrap:wrap;gap:1.4rem 2rem;align-items:center;color:rgba(255,255,255,.9);font-weight:600;font-size:.95rem}
.hero__meta span{display:inline-flex;align-items:center;gap:.55rem}
.hero__meta .ic{color:var(--yolk)}
.hero__meta .sep{width:1px;height:20px;background:rgba(255,255,255,.25)}
/* hero kinetic words */
.kinetic .word{display:inline-block;opacity:0;transform:translateY(40px) rotate(3deg);animation:kin .9s var(--ease) forwards}
.kinetic .word:nth-child(1){animation-delay:.15s}.kinetic .word:nth-child(2){animation-delay:.28s}
.kinetic .word:nth-child(3){animation-delay:.41s}.kinetic .word:nth-child(4){animation-delay:.54s}
.kinetic .word:nth-child(5){animation-delay:.67s}
@keyframes kin{to{opacity:1;transform:none}}
html.qa .kinetic .word{opacity:1;transform:none;animation:none}

.scroll-hint{position:absolute;left:50%;bottom:1.4rem;translate:-50% 0;z-index:2;color:rgba(255,255,255,.7);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:.5rem}
.scroll-hint .line{width:1px;height:34px;background:linear-gradient(rgba(255,255,255,.7),transparent);animation:scrolline 2s ease-in-out infinite}
@keyframes scrolline{0%,100%{transform:scaleY(.4);opacity:.4;transform-origin:top}50%{transform:scaleY(1);opacity:1;transform-origin:top}}
@media(prefers-reduced-motion:reduce){.kinetic .word{opacity:1;transform:none;animation:none}}

/* ---------- welcome / story split ---------- */
.welcome-media{position:relative}
.welcome-media .frame{aspect-ratio:4/5}
.welcome-media .badge-float{position:absolute;bottom:-1.2rem;left:-1.2rem;background:var(--brick);color:#fff;border-radius:var(--r);padding:1rem 1.3rem;box-shadow:var(--shadow);max-width:14rem}
.welcome-media .badge-float b{font-family:var(--serif);font-size:1.7rem;display:block;line-height:1;color:var(--yolk)}
.welcome-media .badge-float span{font-size:.82rem;color:rgba(255,255,255,.85)}
.welcome-media .stamp{position:absolute;top:-1.4rem;right:-.6rem;width:104px;height:104px;border-radius:50%;background:var(--yolk);color:var(--ink);display:grid;place-items:center;text-align:center;font-family:var(--serif);font-weight:600;line-height:1.05;font-size:.92rem;box-shadow:var(--shadow);transform:rotate(8deg)}

/* ---------- why-us features ---------- */
.why-grid{display:grid;gap:1.6rem}
@media(min-width:760px){.why-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1040px){.why-grid{grid-template-columns:repeat(3,1fr)}}

/* ---------- menu highlights ---------- */
.menu-hl{position:relative}
.menu-hl .card__media{aspect-ratio:4/3}

/* ---------- events ---------- */
.event-card{position:relative;border-radius:var(--r-lg);overflow:hidden;color:#fff;min-height:340px;display:flex;flex-direction:column;justify-content:flex-end;padding:1.8rem;box-shadow:var(--shadow)}
.event-card::before{content:"";position:absolute;inset:0;z-index:-1;background:var(--ink)}
.event-card.music::before{background:linear-gradient(160deg,#2b4a63,#16242f)}
.event-card.bingo::before{background:linear-gradient(160deg,#7a2418,#3c130c)}
.event-card .when{font-weight:700;text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;color:var(--yolk);margin-bottom:.5rem}
.event-card h3{color:#fff;font-size:1.6rem}
.event-card p{color:rgba(255,255,255,.85);margin-top:.5rem;font-size:.97rem}
.event-card .btn{margin-top:1.2rem;align-self:flex-start}
.event-card .deco{position:absolute;top:1.2rem;right:1.3rem;font-size:2rem;opacity:.8}

/* ---------- visit / location ---------- */
.visit-card{background:var(--cream-card);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);border:1px solid var(--line-soft);padding:clamp(1.6rem,3vw,2.4rem)}
.hours-list{display:grid;gap:.5rem}
.hours-list li{display:flex;justify-content:space-between;padding:.55rem 0;border-bottom:1px dashed var(--line-soft);font-weight:600}
.hours-list li span:last-child{color:var(--brick)}
.hours-list li.today{background:var(--cream-deep);margin-inline:-.7rem;padding-inline:.7rem;border-radius:8px;border-bottom-color:transparent}
.map-frame{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);min-height:320px;height:100%}
.map-frame iframe{width:100%;height:100%;min-height:320px;border:0;display:block}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;text-align:center;color:#fff}
.cta-band::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--brick),var(--brick-deep))}
.cta-band::after{content:"";position:absolute;inset:0;opacity:.5;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.4'/%3E%3C/svg%3E")}
.cta-band .container{position:relative}
.cta-band h2{color:#fff;max-width:20ch;margin-inline:auto}
.cta-band p{color:rgba(255,255,255,.88);max-width:46ch;margin:1rem auto 2rem}

/* ---------- menu page sections ---------- */
.menu-section{margin-bottom:clamp(2.4rem,5vw,4rem)}
.menu-section > h2{display:flex;align-items:baseline;gap:1rem;margin-bottom:1.4rem}
.menu-section > h2::after{content:"";flex:1;height:2px;background:repeating-linear-gradient(90deg,var(--line),var(--line) 6px,transparent 6px,transparent 12px)}
.menu-list{display:grid;gap:1.2rem 2.6rem}
@media(min-width:760px){.menu-list{grid-template-columns:1fr 1fr}}
.menu-item{display:flex;justify-content:space-between;gap:1rem;align-items:baseline;padding-bottom:.7rem;border-bottom:1px dotted var(--line)}
.menu-item .mi-name{font-family:var(--serif);font-weight:600;font-size:1.12rem}
.menu-item .mi-desc{font-size:.9rem;color:var(--ink-soft);margin-top:.15rem}
.menu-item .mi-price{font-family:var(--serif);font-weight:600;color:var(--brick);white-space:nowrap;font-size:1.08rem}
.menu-note{font-size:.86rem;color:var(--ink-soft);font-style:italic;margin-top:.8rem}

/* gallery */
.gallery{display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}
@media(min-width:760px){.gallery{grid-template-columns:repeat(4,1fr)}}
.gallery a{border-radius:var(--r);overflow:hidden;aspect-ratio:1;box-shadow:var(--shadow-sm)}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.gallery a:hover img{transform:scale(1.08)}
.gallery a.tall{grid-row:span 2;aspect-ratio:auto}

/* contact layout */
.contact-grid{display:grid;gap:2.4rem}
@media(min-width:900px){.contact-grid{grid-template-columns:1fr 1fr}}
.contact-info li{display:flex;gap:.9rem;align-items:flex-start;padding:.9rem 0;border-bottom:1px solid var(--line-soft)}
.contact-info .ic{flex:none;width:44px;height:44px;border-radius:12px;background:var(--cream-deep);color:var(--brick);display:grid;place-items:center}
.contact-info b{display:block}
.contact-info a{color:var(--brick);font-weight:600}

/* bingo / event detail hero */
.event-detail .ticket{background:var(--cream-card);border:2px dashed var(--brick);border-radius:var(--r-lg);padding:clamp(1.6rem,3vw,2.4rem);position:relative;box-shadow:var(--shadow-sm)}
.event-detail .price-big{font-family:var(--serif);font-weight:600;font-size:clamp(3rem,8vw,4.6rem);color:var(--brick);line-height:1}
.incl-list li{display:flex;gap:.7rem;align-items:center;padding:.5rem 0;font-weight:600}
.incl-list .ic{color:var(--leaf)}
