/*
Theme Name: Beluga Sushi
Theme URI: https://belugasushi.example
Author: WebVue
Author URI: https://webvue.com.lb
Description: Beluga Sushi — a dark, gold-accented restaurant theme. Hand-crafted sushi house in Hazmieh, Lebanon. Includes a home page, full menu, about, gallery and contact templates.
Version: 1.0.0
Requires at least: 5.9
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: beluga-sushi
Tags: restaurant, food, one-column, custom-menu, custom-logo, featured-images, full-width-template, rtl-language-support
*/

/* ============================================================
   BELUGA SUSHI — brand stylesheet
   Dark & moody · warm near-black · amber/gold accent
   ============================================================ */

:root{
  /* canvas */
  --bg:        #0b0907;
  --bg-2:      #100d09;
  --bg-3:      #16110b;
  --panel:     #1a140d;
  --panel-2:   #211a10;

  /* gold ramp (from the logo) */
  --gold:      #E0A24C;
  --gold-soft: #EAC07C;
  --gold-bright:#F4D79A;
  --gold-deep: #B97E33;

  /* ink / text */
  --cream:     #F4ECDC;
  --text:      #E8DFCC;
  --muted:     #A99D85;
  --faint:     #6E6450;

  /* accents */
  --lacquer:   #9E342A;   /* deep japanese red — used sparingly */

  /* lines */
  --line:      rgba(224,162,76,0.20);
  --line-soft: rgba(244,236,220,0.08);
  --line-strong: rgba(224,162,76,0.42);

  /* type */
  --f-display: 'Cormorant Garamond', Georgia, serif;
  --f-body:    'Jost', system-ui, sans-serif;
  --f-jp:      'Shippori Mincho', serif;

  /* layout */
  --container: 1240px;
  --gut: clamp(20px, 5vw, 56px);
  --radius: 14px;
  --radius-lg: 22px;

  --ease: cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--f-body);
  font-weight:400;
  font-size:17px;
  line-height:1.65;
  letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:clip;
}
html{ overflow-x:clip; }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

::selection{ background:var(--gold); color:#1a1208; }

/* subtle warm grain / vignette on the body */
body::before{
  content:"";
  position:fixed; inset:0; z-index:-2;
  background:
    radial-gradient(120% 80% at 80% -10%, rgba(224,162,76,0.10), transparent 60%),
    radial-gradient(90% 70% at 0% 110%, rgba(158,52,42,0.08), transparent 55%),
    var(--bg);
}

/* ---------- layout helpers ---------- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--gut); }
.section{ padding-block:clamp(64px,9vw,128px); position:relative; }
.section--tight{ padding-block:clamp(48px,6vw,84px); }

.eyebrow{
  font-family:var(--f-body);
  font-weight:500;
  font-size:.72rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--gold);
  display:inline-flex; align-items:center; gap:.7em;
}
.eyebrow::before{
  content:""; width:30px; height:1px; background:var(--gold); opacity:.7;
}
.eyebrow--center::after{
  content:""; width:30px; height:1px; background:var(--gold); opacity:.7;
}

.jp{ font-family:var(--f-jp); color:var(--gold-soft); font-weight:500; letter-spacing:.18em; }

h1,h2,h3{ font-family:var(--f-display); font-weight:600; line-height:1.04; letter-spacing:-.01em; color:var(--cream); margin:0; }
.display{
  font-family:var(--f-display);
  font-weight:500;
  font-size:clamp(2.8rem,7.5vw,6rem);
  line-height:.98;
  letter-spacing:-.015em;
  color:var(--cream);
}
.h-sec{
  font-family:var(--f-display);
  font-weight:600;
  font-size:clamp(2.1rem,4.6vw,3.6rem);
  line-height:1.02;
  color:var(--cream);
}
.lead{ color:var(--muted); font-size:clamp(1.02rem,1.4vw,1.18rem); line-height:1.7; max-width:54ch; }
.gold{ color:var(--gold); }
.italic{ font-style:italic; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--f-body); font-weight:500; font-size:.86rem;
  letter-spacing:.13em; text-transform:uppercase;
  padding:15px 30px; border-radius:999px;
  border:1px solid var(--gold);
  transition:all .35s var(--ease);
  white-space:nowrap;
}
.btn--primary{ background:var(--gold); color:#1a1107; border-color:var(--gold); }
.btn--primary:hover{ background:var(--gold-bright); border-color:var(--gold-bright); box-shadow:0 10px 30px -10px rgba(224,162,76,.55); transform:translateY(-2px); }
.btn--ghost{ background:transparent; color:var(--gold-soft); }
.btn--ghost:hover{ background:rgba(224,162,76,.10); color:var(--gold-bright); transform:translateY(-2px); }
.btn svg{ width:16px; height:16px; }

/* ---------- header / nav ---------- */
.site-header{
  position:sticky; top:0; z-index:60;
  background:rgba(11,9,7,.72);
  backdrop-filter:blur(14px) saturate(120%);
  -webkit-backdrop-filter:blur(14px) saturate(120%);
  border-bottom:1px solid var(--line-soft);
  transition:background .3s var(--ease), border-color .3s var(--ease);
}
.nav{ display:flex; align-items:center; justify-content:space-between; height:78px; gap:24px; }
.brand{ display:flex; align-items:center; gap:12px; }
.brand-mark{ height:26px; width:auto; display:block; }
.brand-tag{ font-family:var(--f-body); font-weight:400; font-size:.56rem; letter-spacing:.42em; text-transform:uppercase; color:var(--gold); line-height:1; padding-left:12px; border-left:1px solid var(--line); }

.nav-links{ display:flex; align-items:center; gap:6px; list-style:none; margin:0; padding:0; }
.nav-links a{
  font-size:.82rem; letter-spacing:.06em; color:var(--text); font-weight:400;
  padding:10px 16px; border-radius:8px; position:relative; transition:color .25s var(--ease);
}
.nav-links a::after{
  content:""; position:absolute; left:16px; right:16px; bottom:4px; height:1px;
  background:var(--gold); transform:scaleX(0); transform-origin:left; transition:transform .3s var(--ease);
}
.nav-links a:hover{ color:var(--gold-soft); }
.nav-links a:hover::after,
.nav-links a.active::after{ transform:scaleX(1); }
.nav-links a.active{ color:var(--gold); }

.nav-cta{ display:flex; align-items:center; gap:14px; }
.nav-phone{ font-size:.82rem; color:var(--muted); letter-spacing:.04em; display:flex; align-items:center; gap:7px; }
.nav-phone:hover{ color:var(--gold-soft); }

.nav-toggle{
  display:none; width:46px; height:46px; border:1px solid var(--line); border-radius:10px;
  background:transparent; color:var(--gold); align-items:center; justify-content:center; flex-direction:column; gap:5px;
}
.nav-toggle span{ width:20px; height:1.5px; background:currentColor; transition:transform .3s var(--ease), opacity .3s var(--ease); }
body.nav-open .nav-toggle span:nth-child(1){ transform:translateY(6.5px) rotate(45deg); }
body.nav-open .nav-toggle span:nth-child(2){ opacity:0; }
body.nav-open .nav-toggle span:nth-child(3){ transform:translateY(-6.5px) rotate(-45deg); }

/* ---------- immersive mobile menu ---------- */
.mobile-menu{
  position:fixed; inset:0; z-index:55;
  display:flex; flex-direction:column; justify-content:center;
  padding:calc(78px + clamp(20px,7vw,52px)) var(--gut) clamp(28px,6vw,48px);
  background:
    radial-gradient(120% 80% at 85% -5%, rgba(224,162,76,0.16), transparent 55%),
    radial-gradient(100% 70% at 0% 108%, rgba(158,52,42,0.16), transparent 55%),
    rgba(8,6,4,0.985);
  -webkit-backdrop-filter:blur(18px); backdrop-filter:blur(18px);
  opacity:0; pointer-events:none;
  clip-path:circle(0% at calc(100% - 46px) 40px);
  transition:opacity .5s var(--ease), clip-path .6s var(--ease);
  overflow:hidden;
}
body.nav-open .mobile-menu{ opacity:1; pointer-events:auto; clip-path:circle(150% at calc(100% - 46px) 40px); }

/* faint whale watermark drifting behind */
.mobile-menu .mm-whale{
  position:absolute; right:-14%; top:8%; width:min(560px,86vw);
  opacity:.06; pointer-events:none; filter:saturate(1.4);
  animation:mm-drift 14s ease-in-out infinite;
}
@keyframes mm-drift{ 0%,100%{ transform:translateY(0) rotate(0) } 50%{ transform:translateY(-22px) rotate(-2deg) } }

.mobile-menu .mm-inner{ position:relative; display:flex; flex-direction:column; height:100%; }

.mobile-menu .mm-links{ display:flex; flex-direction:column; margin-top:auto; }
.mobile-menu .mm-links a{
  display:flex; align-items:baseline; justify-content:space-between; gap:18px;
  font-family:var(--f-display); font-weight:500; color:var(--cream);
  font-size:clamp(2.2rem,9vw,3.1rem); line-height:1.18; letter-spacing:-.01em;
  padding:clamp(10px,2.4vw,16px) 0; border-bottom:1px solid var(--line-soft);
  position:relative;
  opacity:0; transform:translateX(-26px);
  transition:color .3s var(--ease), transform .3s var(--ease);
}
.mobile-menu .mm-links a .jp{
  font-family:var(--f-jp); font-size:1rem; color:var(--gold-deep); letter-spacing:.14em;
  flex:none; transform:translateY(-2px); transition:color .3s var(--ease);
}
.mobile-menu .mm-links a::before{
  content:""; position:absolute; left:-18px; top:50%; width:7px; height:7px;
  background:var(--gold); transform:translateY(-50%) rotate(45deg) scale(0);
  transition:transform .3s var(--ease); opacity:.9;
}
.mobile-menu .mm-links a.active{ color:var(--gold); }
.mobile-menu .mm-links a.active .jp{ color:var(--gold); }
.mobile-menu .mm-links a.active::before{ transform:translateY(-50%) rotate(45deg) scale(1); }
@media (hover:hover){
  .mobile-menu .mm-links a:hover{ color:var(--gold-soft); transform:translateX(6px); }
  .mobile-menu .mm-links a:hover .jp{ color:var(--gold-soft); }
  .mobile-menu .mm-links a:hover::before{ transform:translateY(-50%) rotate(45deg) scale(1); }
}
/* staggered entrance — driven by --i set inline per link */
body.nav-open .mobile-menu .mm-links a{
  opacity:1; transform:none;
  transition:opacity .5s var(--ease), transform .5s var(--ease), color .3s var(--ease);
  transition-delay:calc(.16s + var(--i,0) * .07s);
}

.mobile-menu .mm-foot{
  margin-top:auto; padding-top:clamp(22px,5vw,34px);
  display:flex; flex-direction:column; gap:18px;
  opacity:0; transform:translateY(14px);
  transition:opacity .5s var(--ease), transform .5s var(--ease);
}
body.nav-open .mobile-menu .mm-foot{ opacity:1; transform:none; transition-delay:.5s; }
.mobile-menu .mm-socials{ display:flex; gap:12px; }
.mobile-menu .mm-socials a{
  width:46px; height:46px; border:1px solid var(--line); border-radius:50%;
  display:grid; place-items:center; color:var(--gold-soft); transition:all .3s var(--ease);
}
.mobile-menu .mm-socials a:active,
.mobile-menu .mm-socials a:hover{ background:var(--gold); color:#1a1107; border-color:var(--gold); }
.mobile-menu .mm-socials svg{ width:19px; height:19px; }
.mobile-menu .mm-meta{ color:var(--muted); font-size:.92rem; line-height:1.7; margin:0; }
.mobile-menu .mm-foot .btn{ align-self:flex-start; }

/* ---------- preloader ---------- */
.preloader{
  position:fixed; inset:0; z-index:200;
  display:grid; place-items:center;
  background:
    radial-gradient(120% 80% at 80% -10%, rgba(224,162,76,0.10), transparent 60%),
    radial-gradient(90% 70% at 0% 110%, rgba(158,52,42,0.08), transparent 55%),
    var(--bg);
  transition:opacity .7s var(--ease), visibility .7s var(--ease);
}
body.loaded .preloader{ opacity:0; visibility:hidden; pointer-events:none; }
.preloader .pl-inner{ display:flex; flex-direction:column; align-items:center; text-align:center; }
.preloader .pl-logo{ position:relative; width:clamp(120px,26vw,168px); overflow:hidden; border-radius:18px; }
.preloader .pl-logo--word{ width:clamp(220px,56vw,360px); border-radius:0; }
.preloader .pl-logo img{
  width:100%; height:auto; display:block;
  opacity:0; transform:scale(.82); animation:pl-pop 1s var(--ease) .1s forwards;
}
.preloader .pl-logo .pl-shine{
  position:absolute; inset:0;
  background:linear-gradient(110deg, transparent 30%, rgba(244,215,154,.55) 50%, transparent 70%);
  transform:translateX(-120%);
  animation:pl-shine 1.5s var(--ease) .65s infinite;
}
@keyframes pl-pop{ to{ opacity:1; transform:scale(1) } }
@keyframes pl-shine{ 0%{ transform:translateX(-120%) } 60%,100%{ transform:translateX(120%) } }
.preloader .pl-word{
  font-family:var(--f-display); font-weight:600; color:var(--cream);
  font-size:clamp(1.7rem,5vw,2.4rem); letter-spacing:.32em; text-indent:.32em;
  margin-top:24px; opacity:0; transform:translateY(12px);
  animation:pl-rise .7s var(--ease) .35s forwards;
}
.preloader .pl-sub{
  font-family:var(--f-body); font-size:.62rem; letter-spacing:.5em; text-indent:.5em;
  text-transform:uppercase; color:var(--gold); margin-top:10px;
  opacity:0; animation:pl-rise .7s var(--ease) .5s forwards;
}
@keyframes pl-rise{ to{ opacity:1; transform:none } }
.preloader .pl-bar{
  margin-top:30px; width:clamp(140px,40vw,210px); height:2px;
  background:var(--line-soft); border-radius:2px; overflow:hidden;
}
.preloader .pl-bar span{
  display:block; height:100%; width:0;
  background:linear-gradient(90deg,var(--gold-deep),var(--gold-bright));
  animation:pl-fill 1.5s var(--ease) .3s forwards;
}
@keyframes pl-fill{ 0%{ width:0 } 70%{ width:82% } 100%{ width:100% } }

/* ---------- scroll progress ---------- */
.scroll-progress{
  position:fixed; top:0; left:0; height:2px; width:0; z-index:80;
  background:linear-gradient(90deg,var(--gold-deep),var(--gold-bright));
  box-shadow:0 0 12px rgba(224,162,76,.5); pointer-events:none;
  transition:width .1s linear;
}

/* ---------- image hover life ---------- */
.dish .media,
.about-art > .media,
.why-art .media,
.story-art .media,
.member .media,
.mason .media,
.gal-teaser .media{
  transition:transform .7s var(--ease), filter .6s var(--ease);
}
.dish:hover .media{ transform:scale(1.06); }
@media (hover:hover){
  .mason .media:hover,
  .gal-teaser .media:hover{ transform:scale(1.05); filter:brightness(1.08) saturate(1.05); z-index:3; position:relative; }
  .about-art:hover > .media,
  .why-art:hover .media,
  .story-art:hover .media{ transform:scale(1.03); }
}

/* ---------- footer ---------- */
.site-footer{ background:var(--bg-2); border-top:1px solid var(--line-soft); padding-block:clamp(56px,7vw,88px) 36px; margin-top:0; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:48px; }
.footer-brand img{ height:42px; margin-bottom:18px; }
.footer-brand p{ color:var(--muted); max-width:30ch; font-size:.95rem; }
.footer-col h4{ font-family:var(--f-body); font-weight:500; font-size:.74rem; letter-spacing:.24em; text-transform:uppercase; color:var(--gold); margin:0 0 18px; }
.footer-col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px; }
.footer-col a, .footer-col li{ color:var(--muted); font-size:.95rem; transition:color .25s var(--ease); }
.footer-col a:hover{ color:var(--gold-soft); }
.footer-socials{ display:flex; gap:12px; margin-top:6px; }
.footer-socials a{ width:42px; height:42px; border:1px solid var(--line); border-radius:50%; display:grid; place-items:center; color:var(--gold-soft); transition:all .3s var(--ease); }
.footer-socials a:hover{ background:var(--gold); color:#1a1107; border-color:var(--gold); transform:translateY(-3px); }
.footer-socials svg{ width:18px; height:18px; }
.footer-bottom{ border-top:1px solid var(--line-soft); margin-top:48px; padding-top:24px; display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; color:var(--faint); font-size:.82rem; letter-spacing:.04em; }

/* ---------- image slots ---------- */
.media{
  --is-bg: var(--bg-3);
  display:block; object-fit:cover; border:0;
  background:var(--bg-3);
  color:rgba(234,192,124,.62);
  font-family:var(--f-body); font-size:.74rem; letter-spacing:.14em;
}

/* ---------- cards ---------- */
.card{
  background:linear-gradient(180deg, var(--panel), var(--bg-3));
  border:1px solid var(--line-soft);
  border-radius:var(--radius-lg);
  overflow:hidden;
  transition:border-color .4s var(--ease), transform .4s var(--ease), box-shadow .4s var(--ease);
}
.card:hover{ border-color:var(--line-strong); transform:translateY(-6px); box-shadow:0 24px 50px -28px rgba(0,0,0,.8); }

/* divider with kanji/diamond */
.rule{ display:flex; align-items:center; justify-content:center; gap:18px; color:var(--gold); }
.rule::before,.rule::after{ content:""; height:1px; width:min(90px,12vw); background:linear-gradient(90deg,transparent,var(--gold)); opacity:.55; }
.rule::after{ background:linear-gradient(90deg,var(--gold),transparent); }
.rule .diamond{ width:7px; height:7px; background:var(--gold); transform:rotate(45deg); }

/* ---------- scroll reveal ---------- */
[data-reveal]{ opacity:0; transform:translateY(26px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
[data-reveal].in{ opacity:1; transform:none; }
[data-reveal][data-delay="1"]{ transition-delay:.08s; }
[data-reveal][data-delay="2"]{ transition-delay:.16s; }
[data-reveal][data-delay="3"]{ transition-delay:.24s; }
[data-reveal][data-delay="4"]{ transition-delay:.32s; }
[data-reveal][data-delay="5"]{ transition-delay:.40s; }

@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition-duration:.001s !important; scroll-behavior:auto; }
  [data-reveal]{ opacity:1; transform:none; }
  .preloader .pl-logo img,
  .preloader .pl-word,
  .preloader .pl-sub{ opacity:1; transform:none; }
  .preloader .pl-bar span{ width:100%; }
  .preloader .pl-shine{ display:none; }
  .mobile-menu .mm-links a,
  .mobile-menu .mm-foot{ opacity:1; transform:none; }
}

/* lock scroll while overlays are up */
body.nav-open, body.preloading{ overflow:hidden; }

/* ---------- responsive ---------- */
@media (max-width: 980px){
  .footer-grid{ grid-template-columns:1fr 1fr; gap:36px; }
}
@media (max-width: 860px){
  .nav-links, .nav-phone{ display:none; }
  .nav-toggle{ display:flex; }
  .nav-cta .btn{ display:none; }
}
@media (max-width: 560px){
  body{ font-size:16px; }
  .footer-grid{ grid-template-columns:1fr; gap:32px; }
  .footer-bottom{ flex-direction:column; }
}
