/*
Theme Name: Ocean 7
Theme URI: https://innofcapemay.com/ocean-7/
Author: The Inn of Cape May
Author URI: https://innofcapemay.com
Description: Companion restaurant website theme for Ocean 7 at The Inn of Cape May. Dark editorial fine-dining aesthetic with tabbed menus, OpenTable integration, photo gallery, private dining section, DoorDash delivery, and full customizer control. Designed to work alongside the Inn of Cape May main theme.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: ocean7
Tags: one-column, custom-menu, featured-images, full-width-template, theme-options, restaurant
*/

/* ═══════════════════════════════════
   DESIGN TOKENS
═══════════════════════════════════ */
:root {
  --bg:        #0C0B09;
  --bg2:       #151310;
  --bg3:       #1E1B16;
  --bg4:       #28241D;
  --amber:     #C9944A;
  --amber-lt:  #DDB46E;
  --amber-pale:#EDD5A8;
  --amber-glow:rgba(201,148,74,.12);
  --copper:    #A87B52;
  --sage:      #7A9A7E;
  --cream:     #F5EFE4;
  --cream2:    #E8DFD0;
  --stone:     #8A837A;
  --stone-lt:  #B5AFA6;
  --white:     #FDFCFA;
  --ink:       #F2EDE4;
  --ink2:      #C4BDB2;
  --ink3:      #8A837A;
  --ink4:      #5C574F;
  --ff:        'Libre Caslon Text','Georgia',serif;
  --fd:        'Libre Caslon Display','Georgia',serif;
  --fb:        'Manrope','Helvetica Neue',sans-serif;
  --ease:      cubic-bezier(.22,1,.36,1);
  --s1:        0 1px 4px rgba(0,0,0,.15);
  --s2:        0 8px 32px rgba(0,0,0,.2);
  --s3:        0 24px 64px rgba(0,0,0,.3);
}

/* ═══ RESET ═══ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--fb);color:var(--ink2);background:var(--bg);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

/* Grain */
body::after{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:99999;opacity:.03;
  background: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='.7' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E") repeat;
}

/* ═══ UTILITY ═══ */
.wrap{max-width:1200px;margin:0 auto;padding:0 clamp(20px,5vw,64px)}
section{padding:clamp(80px,12vw,150px) 0}

/* Typography */
.eyebrow{
  font-family:var(--fb);font-size:.58rem;font-weight:600;
  letter-spacing:.5em;text-transform:uppercase;color:var(--amber);
}
.hdg{font-family:var(--fd);font-weight:400;line-height:1.06;color:var(--cream)}
.hdg em{font-family:var(--ff);font-style:italic;color:var(--amber-lt)}
.body-text{
  font-family:var(--ff);font-size:clamp(1rem,1.4vw,1.15rem);
  font-weight:400;line-height:1.7;color:var(--ink3);
}
.rule{width:40px;height:1px;background:var(--amber)}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 34px;font-family:var(--fb);font-size:.62rem;font-weight:600;
  letter-spacing:.24em;text-transform:uppercase;border:none;cursor:pointer;
  transition:all .4s var(--ease);
}
.btn--amber{background:var(--amber);color:var(--bg)}
.btn--amber:hover{background:var(--amber-lt);transform:translateY(-2px);box-shadow:0 12px 40px rgba(201,148,74,.2)}
.btn--outline{background:transparent;border:1px solid var(--amber);color:var(--amber)}
.btn--outline:hover{background:var(--amber);color:var(--bg)}
.btn--white{background:transparent;border:1px solid rgba(242,237,228,.2);color:var(--ink)}
.btn--white:hover{background:var(--cream);color:var(--bg)}

/* Reveal */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .85s var(--ease),transform .85s var(--ease)}
.reveal.visible{opacity:1;transform:none}
.reveal-d1{transition-delay:.1s}
.reveal-d2{transition-delay:.2s}
.reveal-d3{transition-delay:.3s}

/* Arrow icon */
.arrow-icon{width:11px;height:11px;stroke:currentColor;fill:none;stroke-width:2;vertical-align:middle}

/* ═══════════════════════════════════
   NAVIGATION
═══════════════════════════════════ */
.site-nav{
  position:fixed;top:0;left:0;right:0;z-index:9990;
  padding:0 clamp(20px,5vw,64px);transition:all .5s;
}
.site-nav.solid{
  background:rgba(12,11,9,.92);backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(201,148,74,.08);
}
.site-nav__inner{
  max-width:1400px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;height:72px;
}
.site-nav__logo{
  font-family:var(--fd);font-size:1.5rem;color:var(--cream);letter-spacing:.06em;
}
.site-nav__logo span{color:var(--amber)}
.site-nav__links{
  display:flex;gap:clamp(16px,2.5vw,32px);align-items:center;list-style:none;
}
.site-nav__links a{
  font-size:.68rem;font-weight:500;letter-spacing:.08em;
  text-transform:uppercase;color:var(--stone-lt);transition:color .3s;
}
.site-nav__links a:hover{color:var(--amber)}
.site-nav__reserve{
  padding:9px 22px!important;background:var(--amber)!important;color:var(--bg)!important;
  font-size:.6rem!important;font-weight:600!important;letter-spacing:.2em!important;
  text-transform:uppercase!important;transition:all .3s!important;border:none!important;
}
.site-nav__reserve:hover{background:var(--amber-lt)!important}
.site-nav__hamburger{
  display:none;background:none;border:none;cursor:pointer;padding:6px;
  flex-direction:column;gap:5px;
}
.site-nav__hamburger span{
  display:block;width:20px;height:1.5px;background:var(--cream);transition:.3s;
}

/* ═══════════════════════════════════
   HERO
═══════════════════════════════════ */
.hero{
  position:relative;height:100vh;min-height:680px;max-height:1000px;
  display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;
}
.hero__bg{position:absolute;inset:0}
.hero__bg img{width:100%;height:100%;object-fit:cover;filter:brightness(.35) saturate(.85)}
.hero__bg::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 60%,transparent 0%,rgba(12,11,9,.6) 70%,rgba(12,11,9,.9) 100%);
}
.hero__content{position:relative;z-index:2;max-width:720px;padding:0 24px}
.hero__eyebrow{
  font-size:.54rem;letter-spacing:.7em;color:var(--amber-lt);margin-bottom:28px;
  opacity:0;animation:hero-fade 1s var(--ease) .3s forwards;
}
.hero__eyebrow .rule{display:inline-block;vertical-align:middle;margin:0 16px;width:32px}
.hero h1{
  font-family:var(--fd);font-size:clamp(3.5rem,9vw,7.5rem);font-weight:400;
  color:var(--cream);line-height:.95;letter-spacing:.02em;margin-bottom:20px;
  opacity:0;animation:hero-fade 1s var(--ease) .5s forwards;
}
.hero h1 em{font-family:var(--ff);font-style:italic;color:var(--amber-lt);font-size:.85em}
.hero__subtitle{
  font-family:var(--ff);font-size:clamp(1rem,1.6vw,1.2rem);
  color:var(--stone-lt);line-height:1.7;margin-bottom:36px;
  opacity:0;animation:hero-fade 1s var(--ease) .7s forwards;
}
.hero__actions{
  display:flex;gap:14px;justify-content:center;flex-wrap:wrap;
  opacity:0;animation:hero-fade 1s var(--ease) .9s forwards;
}
@keyframes hero-fade{
  from{opacity:0;transform:translateY(28px)}
  to{opacity:1;transform:none}
}
.hero__scroll{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:8px;
  opacity:0;animation:hero-fade 1s var(--ease) 1.2s forwards;
}
.hero__scroll span{font-size:.52rem;letter-spacing:.3em;text-transform:uppercase;color:var(--stone)}
.hero__scroll-line{
  width:1px;height:40px;background:linear-gradient(to bottom,var(--amber),transparent);
  animation:scroll-pulse 2s ease-in-out infinite;
}
@keyframes scroll-pulse{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* ═══════════════════════════════════
   HOURS BAR
═══════════════════════════════════ */
.hours-bar{
  background:var(--bg3);
  border-top:1px solid rgba(201,148,74,.08);
  border-bottom:1px solid rgba(201,148,74,.08);
}
.hours-bar__grid{
  display:grid;grid-template-columns:repeat(4,1fr);max-width:1200px;margin:0 auto;
}
.hours-bar__item{
  padding:28px 24px;text-align:center;
  border-right:1px solid rgba(201,148,74,.06);
}
.hours-bar__item:last-child{border-right:none}
.hours-bar__item h4{
  font-family:var(--fb);font-size:.56rem;font-weight:600;
  letter-spacing:.35em;text-transform:uppercase;color:var(--amber);margin-bottom:8px;
}
.hours-bar__item p{font-family:var(--ff);font-size:.88rem;color:var(--ink3);line-height:1.6}
.hours-bar__item strong{color:var(--cream2);font-weight:400}

/* ═══════════════════════════════════
   ABOUT
═══════════════════════════════════ */
.about__grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,80px);align-items:center;
}
.about__image{position:relative}
.about__image img{width:100%;aspect-ratio:4/5;object-fit:cover}
.about__image::before{
  content:'';position:absolute;top:-16px;left:-16px;right:16px;bottom:16px;
  border:1px solid var(--amber);opacity:.2;pointer-events:none;
}

/* ═══════════════════════════════════
   MENU TABS
═══════════════════════════════════ */
.menu-tabs__bar{
  display:flex;justify-content:center;gap:6px;margin-bottom:52px;flex-wrap:wrap;
}
.menu-tabs__button{
  padding:10px 28px;font-family:var(--fb);font-size:.62rem;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;background:none;
  border:1px solid var(--bg4);color:var(--stone);cursor:pointer;
  transition:all .3s var(--ease);
}
.menu-tabs__button:hover{border-color:var(--amber);color:var(--amber)}
.menu-tabs__button.active{background:var(--amber);color:var(--bg);border-color:var(--amber)}
.menu-panel{display:none;animation:tab-in .5s var(--ease)}
.menu-panel.active{display:block}
@keyframes tab-in{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* Menu Items */
.menu-section{margin-bottom:48px}
.menu-section__title{
  font-family:var(--fd);font-size:1.5rem;color:var(--amber-lt);
  margin-bottom:24px;padding-bottom:12px;border-bottom:1px solid var(--bg4);
}
.menu-items{display:grid;grid-template-columns:1fr 1fr;gap:12px 40px}
.menu-item{padding:14px 0;border-bottom:1px solid rgba(201,148,74,.05)}
.menu-item__top{display:flex;justify-content:space-between;align-items:baseline;gap:12px}
.menu-item__name{font-family:var(--ff);font-size:1rem;color:var(--cream);font-weight:700}
.menu-item__price{font-family:var(--fb);font-size:.82rem;color:var(--amber);font-weight:500;white-space:nowrap}
.menu-item__desc{font-size:.8rem;color:var(--stone);line-height:1.5;margin-top:4px}
.menu-item__dots{flex:1;border-bottom:1px dotted var(--bg4);min-width:20px;margin-bottom:4px}
.menu-download{text-align:center;margin-top:32px}
.menu-download a{
  font-size:.6rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  color:var(--amber);border-bottom:1px solid transparent;transition:border-color .3s;padding-bottom:2px;
}
.menu-download a:hover{border-color:var(--amber)}

/* ═══════════════════════════════════
   GALLERY
═══════════════════════════════════ */
.gallery{overflow:hidden}
.gallery__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}
.gallery__item{overflow:hidden;aspect-ratio:1;position:relative}
.gallery__item:nth-child(1){grid-column:span 2;grid-row:span 2;aspect-ratio:auto}
.gallery__item img{
  width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);
  filter:brightness(.85) saturate(.9);
}
.gallery__item:hover img{transform:scale(1.05);filter:brightness(1) saturate(1)}

/* ═══════════════════════════════════
   PRIVATE DINING
═══════════════════════════════════ */
.private{background:var(--bg2);position:relative;overflow:hidden}
.private::before{
  content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;
  border-radius:50%;background:radial-gradient(circle,var(--amber-glow),transparent 70%);
}
.private__grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,80px);align-items:center;
}
.private__features{list-style:none;margin-top:24px}
.private__features li{
  padding:10px 0;border-bottom:1px solid var(--bg4);font-size:.86rem;
  color:var(--stone-lt);display:flex;align-items:center;gap:10px;
}
.private__features li::before{content:'◆';color:var(--amber);font-size:.45rem}
.private__image img{width:100%;aspect-ratio:3/4;object-fit:cover}

/* ═══════════════════════════════════
   RESERVATION
═══════════════════════════════════ */
.reserve{background:var(--bg3);text-align:center}
.reserve__hours{display:inline-flex;gap:32px;margin:20px 0 36px;flex-wrap:wrap;justify-content:center}
.reserve__hours div{text-align:center}
.reserve__hours h5{
  font-size:.52rem;letter-spacing:.35em;text-transform:uppercase;
  color:var(--amber);margin-bottom:4px;font-weight:600;
}
.reserve__hours p{font-family:var(--ff);font-size:.88rem;color:var(--stone-lt)}
.reserve__actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ═══════════════════════════════════
   REVIEWS
═══════════════════════════════════ */
.reviews__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.review-card{
  background:var(--bg2);padding:32px 28px;border-left:2px solid transparent;
  transition:all .4s var(--ease);
}
.review-card:hover{border-left-color:var(--amber);background:var(--bg3)}
.review-card__stars{color:var(--amber);font-size:.75rem;letter-spacing:2px;margin-bottom:12px}
.review-card__text{
  font-family:var(--ff);font-size:.95rem;font-style:italic;
  color:var(--ink3);line-height:1.6;margin-bottom:14px;
}
.review-card__author{font-size:.68rem;color:var(--stone);font-weight:500}
.review-card__source{font-size:.52rem;color:var(--ink4);letter-spacing:.15em;text-transform:uppercase;margin-top:2px}

/* ═══════════════════════════════════
   DELIVERY BANNER
═══════════════════════════════════ */
.delivery-banner{
  background:linear-gradient(135deg,var(--amber) 0%,var(--copper) 100%);
  padding:clamp(48px,7vw,72px) 0;text-align:center;position:relative;overflow:hidden;
}
.delivery-banner::before{
  content:'';position:absolute;inset:0;opacity:.04;
  background-image:repeating-linear-gradient(45deg,transparent,transparent 20px,#000 20px,#000 21px);
}
.delivery-banner h2{
  font-family:var(--fd);font-size:clamp(1.8rem,3.5vw,2.4rem);
  color:var(--bg);margin-bottom:8px;position:relative;
}
.delivery-banner p{font-size:.9rem;color:rgba(12,11,9,.65);margin-bottom:24px;position:relative}

/* ═══════════════════════════════════
   FOOTER
═══════════════════════════════════ */
.site-footer{background:var(--bg);border-top:1px solid rgba(201,148,74,.06);padding:60px 0 32px}
.site-footer__grid{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:40px;margin-bottom:48px;
}
.site-footer__brand p{font-size:.82rem;color:var(--stone);line-height:1.7;margin-bottom:16px}
.site-footer__inn-link{
  display:inline-flex;align-items:center;gap:6px;font-size:.6rem;
  letter-spacing:.15em;text-transform:uppercase;color:var(--amber);font-weight:600;
  margin-top:8px;border-bottom:1px solid transparent;transition:border-color .3s;
}
.site-footer__inn-link:hover{border-color:var(--amber)}
.site-footer__col h4{
  font-size:.54rem;letter-spacing:.35em;text-transform:uppercase;
  color:var(--cream2);margin-bottom:14px;font-weight:600;
}
.site-footer__col a{display:block;font-size:.82rem;color:var(--stone);margin-bottom:8px;transition:color .3s}
.site-footer__col a:hover{color:var(--amber)}
.site-footer__bottom{
  border-top:1px solid rgba(201,148,74,.04);padding-top:20px;
  display:flex;justify-content:space-between;font-size:.62rem;
  color:var(--ink4);flex-wrap:wrap;gap:8px;
}
.site-footer__bottom a{color:var(--ink4);transition:color .3s}
.site-footer__bottom a:hover{color:var(--amber)}

/* ═══════════════════════════════════
   RESPONSIVE
═══════════════════════════════════ */
@media(max-width:1024px){
  .about__grid,.private__grid{grid-template-columns:1fr}
  .menu-items{grid-template-columns:1fr}
  .reviews__grid{grid-template-columns:1fr 1fr}
  .gallery__grid{grid-template-columns:repeat(3,1fr)}
  .gallery__item:first-child{grid-column:span 2;grid-row:auto}
  .site-footer__grid{grid-template-columns:1fr 1fr}
  .hours-bar__grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .site-nav__links{display:none!important}
  .site-nav__hamburger{display:flex}
  .site-nav__links.open{
    display:flex!important;flex-direction:column;position:fixed;
    top:72px;left:0;right:0;background:rgba(12,11,9,.97);
    padding:24px;gap:14px;border-bottom:1px solid var(--bg4);
  }
  .hours-bar__grid{grid-template-columns:1fr}
  .reviews__grid{grid-template-columns:1fr}
  .gallery__grid{grid-template-columns:1fr 1fr}
  .gallery__item:first-child{grid-column:auto}
  .site-footer__grid{grid-template-columns:1fr}
  .menu-tabs__bar{gap:4px}
  .menu-tabs__button{padding:8px 16px;font-size:.56rem}
}
