:root{
  --gold:#c9a961;
  --gold-light:#e0c88a;
  --gold-dark:#9c7f3d;
  --ink:#0d0d0d;
  --ink-soft:#1a1a1a;
  --cream:#f6f1e6;
  --cream-dark:#e8dfc9;
  --muted:#7a7368;
  --white:#ffffff;
  --serif:'Cormorant Garamond', 'Prompt', serif;
  --sans:'Prompt', 'Inter', system-ui, sans-serif;
  --shadow: 0 20px 60px rgba(0,0,0,.18);
  --radius: 4px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  font-weight:300;
  color:var(--ink);
  background:var(--cream);
  line-height:1.7;
  overflow-x:hidden;
}

/* ==== Typography ==== */
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;letter-spacing:.02em;line-height:1.2}
h1{font-size:clamp(2.5rem,6vw,5rem)}
h2{font-size:clamp(2rem,4vw,3.5rem)}
h3{font-size:clamp(1.4rem,2.2vw,1.9rem)}
.eyebrow{
  font-family:var(--sans);
  font-size:.75rem;
  font-weight:400;
  letter-spacing:.4em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:1rem;
  display:inline-block;
}
.divider{
  width:60px;height:1px;background:var(--gold);margin:1.5rem auto;
}
section .divider{margin:1.5rem 0 2.5rem}
.center .divider{margin:1.5rem auto 2.5rem}

/* ==== Navigation ==== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:1.2rem 3rem;
  display:flex;align-items:center;justify-content:space-between;
  transition:all .4s ease;
  background:rgba(13,13,13,.92);
  backdrop-filter:blur(8px);
}
.nav.scrolled{
  background:rgba(13,13,13,.98);
  padding:.8rem 3rem;
  box-shadow:0 2px 30px rgba(0,0,0,.3);
}
/* Transparent nav only on home hero */
body.home .nav{background:transparent;backdrop-filter:none}
body.home .nav.scrolled{
  background:rgba(13,13,13,.95);
  backdrop-filter:blur(12px);
}
.logo{
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:.9rem;
  min-width:0;
}
.logo-mark{
  width:68px;
  height:68px;
  object-fit:contain;
  object-position:center;
  filter:drop-shadow(0 10px 18px rgba(0,0,0,.2));
  flex:0 0 auto;
}
.logo-text{
  display:flex;
  flex-direction:column;
  line-height:.92;
  white-space:nowrap;
}
.logo-word{
  font-family:var(--serif);
  font-size:1.8rem;
  font-weight:500;
  letter-spacing:.18em;
  color:var(--cream);
}
.logo-city{
  color:var(--gold-light);
  font-style:italic;
}
.nav-menu{
  display:flex;gap:2.5rem;list-style:none;align-items:center;
}
.nav-menu a{
  color:var(--cream);
  text-decoration:none;
  font-size:.85rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  font-weight:300;
  transition:color .3s;
  position:relative;
}
.nav-menu a::after{
  content:'';position:absolute;bottom:-6px;left:0;
  width:0;height:1px;background:var(--gold);transition:width .3s;
}
.nav-menu a:hover,
.nav-menu a.active{color:var(--gold)}
.nav-menu a:hover::after,
.nav-menu a.active::after{width:100%}

.lang-toggle{
  display:flex;gap:.3rem;align-items:center;
  border:1px solid var(--gold);
  padding:.3rem;border-radius:2px;
}
.lang-toggle button{
  background:none;border:none;color:var(--cream);
  padding:.3rem .7rem;font-size:.75rem;cursor:pointer;
  font-family:var(--sans);letter-spacing:.1em;
  transition:all .3s;
}
.lang-toggle button.active{background:var(--gold);color:var(--ink)}

.hamburger{
  display:none;background:none;border:none;cursor:pointer;
  width:30px;height:22px;position:relative;
}
.hamburger span{
  display:block;position:absolute;left:0;width:100%;height:1px;
  background:var(--cream);transition:all .3s;
}
.hamburger span:nth-child(1){top:0}
.hamburger span:nth-child(2){top:50%}
.hamburger span:nth-child(3){bottom:0}

/* ==== Hero ==== */
.hero{
  position:relative;height:100vh;min-height:700px;
  background-color:var(--ink);
  background-size:cover;background-position:center;
  display:flex;align-items:center;justify-content:center;
  text-align:center;color:var(--cream);
  overflow:hidden;
}
.hero::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(rgba(13,13,13,.55),rgba(13,13,13,.75));
  z-index:1;
}
.hero::before{
  content:'';position:absolute;inset:30px;
  border:1px solid rgba(201,169,97,.4);pointer-events:none;
  z-index:2;
}
.hero-content{max-width:900px;padding:0 2rem;z-index:3;position:relative;animation:fadeUp 1.4s ease both}
.hero h1{
  color:var(--cream);margin-bottom:1.5rem;
  font-weight:400;
}
.hero h1 em{font-style:italic;color:var(--gold-light)}
.hero p{
  font-size:1.1rem;font-weight:200;
  letter-spacing:.05em;opacity:.9;max-width:600px;margin:0 auto 2.5rem;
}
.hero-badges{
  display:flex;gap:3rem;justify-content:center;flex-wrap:wrap;
  margin-top:3rem;
}
.hero-badge{
  font-family:var(--serif);font-style:italic;
  font-size:1.15rem;color:var(--gold-light);
  letter-spacing:.1em;
}
.hero-badge::before{content:'✦ ';color:var(--gold)}

/* Page hero (smaller) */
.page-hero{height:55vh;min-height:420px}
.page-hero .hero-content{max-width:800px}

@keyframes fadeUp{
  from{opacity:0;transform:translateY(40px)}
  to{opacity:1;transform:translateY(0)}
}

.scroll-hint{
  position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);
  color:var(--cream);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;
  opacity:.7;z-index:3;
}
.scroll-hint::after{
  content:'';display:block;width:1px;height:30px;background:var(--gold);
  margin:.8rem auto 0;animation:scrollPulse 2s infinite;
}
@keyframes scrollPulse{
  0%,100%{transform:scaleY(1);opacity:.7}
  50%{transform:scaleY(.5);opacity:1}
}

/* ==== Buttons ==== */
.btn{
  display:inline-block;padding:1rem 2.5rem;
  font-family:var(--sans);font-size:.8rem;font-weight:400;
  letter-spacing:.25em;text-transform:uppercase;
  text-decoration:none;cursor:pointer;border:none;
  transition:all .4s;position:relative;overflow:hidden;
}
.btn-gold{background:var(--gold);color:var(--ink)}
.btn-gold:hover{background:var(--gold-dark);color:var(--cream)}
.btn-outline{
  background:transparent;color:var(--cream);
  border:1px solid var(--gold);
}
.btn-outline:hover{background:var(--gold);color:var(--ink)}
.btn-dark{background:var(--ink);color:var(--cream)}
.btn-dark:hover{background:var(--gold);color:var(--ink)}

/* ==== Sections ==== */
section{padding:6rem 3rem;position:relative}
.container{max-width:1200px;margin:0 auto}
.center{text-align:center}

/* About */
.about{background:var(--cream)}
.about-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;
}
.about-image{
  position:relative;height:500px;
  background:url('photos/restaurant/photo/173058_0.jpg') center/cover;
  box-shadow:var(--shadow);
}
.about-image::before{
  content:'';position:absolute;top:-20px;left:-20px;right:20px;bottom:20px;
  border:1px solid var(--gold);z-index:-1;
}
.about-text h2{margin-bottom:1rem}
.about-text p{color:var(--muted);margin-bottom:1.2rem;font-size:1.05rem}
.about-stats{
  display:flex;gap:3rem;margin-top:2.5rem;
}
.stat-num{
  font-family:var(--serif);font-size:2.8rem;color:var(--gold);font-weight:500;
  line-height:1;
}
.stat-label{font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:.3rem}

/* Services / 3 Businesses */
.services{background:var(--ink);color:var(--cream)}
.services h2{color:var(--cream)}
.services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3rem;
}
.service-card{
  background:var(--ink-soft);
  border:1px solid rgba(201,169,97,.2);
  overflow:hidden;position:relative;
  transition:transform .5s, border-color .5s;
  text-decoration:none;color:inherit;display:block;
}
.service-card:hover{transform:translateY(-10px);border-color:var(--gold)}
.service-img{
  height:260px;background-size:cover;background-position:center;
  position:relative;
}
.service-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom, transparent 60%, rgba(13,13,13,.8));
}
.service-body{padding:2.5rem 2rem}
.service-body h3{color:var(--gold-light);margin-bottom:.8rem}
.service-body p{color:#b8b0a0;font-size:.95rem;margin-bottom:1.5rem;min-height:84px}
.service-link{
  color:var(--gold);text-decoration:none;font-size:.8rem;
  letter-spacing:.2em;text-transform:uppercase;
  border-bottom:1px solid var(--gold);padding-bottom:3px;
  transition:all .3s;
  display:inline-block;
}
.service-card:hover .service-link{color:var(--gold-light);letter-spacing:.3em}

/* Detail sections */
.detail-section{padding:7rem 3rem}
.detail-section.dark{background:var(--ink);color:var(--cream)}
.detail-section.dark h2{color:var(--cream)}
.detail-section.dark p{color:#b8b0a0}
.detail-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;
}
.detail-grid.reverse{direction:rtl}
.detail-grid.reverse > *{direction:ltr}
.detail-img{
  height:520px;background-size:cover;background-position:center;
  box-shadow:var(--shadow);position:relative;
}
.detail-text h2{margin-bottom:1rem}
.features-list{list-style:none;margin:1.5rem 0}
.features-list li{
  padding:.6rem 0;padding-left:2rem;position:relative;
  border-bottom:1px dashed rgba(201,169,97,.25);
  font-size:.95rem;
}
.features-list li::before{
  content:'✦';position:absolute;left:0;color:var(--gold);
}

/* Menu (Restaurant) */
.menu-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:3rem 4rem;margin-top:3rem;
}
.menu-category h3{
  color:var(--gold);margin-bottom:1.5rem;padding-bottom:.6rem;
  border-bottom:1px solid rgba(201,169,97,.3);font-style:italic;
}
.menu-item{
  display:flex;justify-content:space-between;gap:1rem;align-items:baseline;
  padding:.8rem 0;border-bottom:1px dotted rgba(201,169,97,.15);
}
.menu-item-name{font-weight:400;font-size:1rem}
.menu-item-desc{font-size:.8rem;color:#9a9287;font-weight:300;margin-top:.2rem}
.menu-item-price{
  color:var(--gold);font-family:var(--serif);font-size:1.2rem;
  font-weight:500;white-space:nowrap;
}
.menu-item-main{flex:1}

/* Set Menu Cards */
.sets-wrap{
  display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;margin-top:3rem;
}
.set-card{
  background:var(--cream);
  border:1px solid rgba(201,169,97,.4);
  padding:0;overflow:hidden;
  display:flex;flex-direction:column;
  box-shadow:var(--shadow);
  position:relative;
  transition:transform .4s, box-shadow .4s;
}
.set-card:hover{transform:translateY(-6px);box-shadow:0 30px 80px rgba(0,0,0,.25)}
.set-badge{
  position:absolute;top:0;right:0;
  background:linear-gradient(135deg,#d9534f,#b73530);color:#fff;
  padding:1.5rem 2rem 2rem;
  font-family:var(--serif);font-size:2.2rem;font-weight:600;
  clip-path:polygon(0 0, 100% 0, 100% 100%, 20% 100%);
  padding-left:3.5rem;letter-spacing:.02em;
}
.set-header{
  background:var(--ink);color:var(--cream);
  padding:2rem 2rem 1.5rem;
  border-bottom:2px solid var(--gold);
}
.set-header .set-label{
  font-size:.75rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold);margin-bottom:.5rem;display:block;
}
.set-header h3{color:var(--cream);font-style:normal;border:none;padding:0;margin:0;font-size:1.5rem}
.set-header .set-serves{
  font-size:.8rem;color:#b8b0a0;margin-top:.4rem;font-style:italic;
}
.set-items{padding:1.8rem 2rem;flex:1}
.set-items li{
  list-style:none;padding:.7rem 0;padding-left:1.8rem;position:relative;
  border-bottom:1px dotted rgba(156,127,61,.25);
  font-size:.95rem;color:var(--ink);
}
.set-items li:last-child{border-bottom:none}
.set-items li::before{
  content:'✦';position:absolute;left:0;color:var(--gold-dark);
}
.set-items .item-en{
  display:block;font-size:.78rem;color:var(--muted);
  font-style:italic;margin-top:.1rem;
}

.menu-notes{
  margin-top:2.5rem;padding:1.2rem 1.5rem;
  background:rgba(201,169,97,.08);
  border-left:3px solid var(--gold);
  text-align:left;font-size:.9rem;color:var(--muted);
}

.menu-preview{
  margin-top:3.5rem;
  padding:2.5rem;
  background:linear-gradient(180deg, rgba(201,169,97,.08), rgba(255,255,255,.72));
  border:1px solid rgba(201,169,97,.3);
  box-shadow:var(--shadow);
  text-align:left;
}
.menu-preview-heading{
  max-width:760px;
  margin-bottom:2rem;
}
.menu-preview-heading h3{
  margin-bottom:.8rem;
  color:var(--ink);
}
.menu-preview-heading p{
  color:var(--muted);
  line-height:1.8;
}
.menu-preview-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
}
.menu-preview-card{
  background:#fff;
  border:1px solid rgba(13,13,13,.08);
  overflow:hidden;
}
.menu-preview-image{
  aspect-ratio:4/3;
  background-size:cover;
  background-position:center;
}
.menu-preview-body{
  padding:1.25rem 1.25rem 1.4rem;
}
.menu-preview-body h4{
  margin-bottom:.55rem;
  color:var(--ink);
}
.menu-preview-body p{
  color:var(--muted);
  font-size:.92rem;
  line-height:1.7;
}

/* Careers / Jobs */
.careers-intro{padding-bottom:2rem}
.careers{background:var(--cream);padding:7rem 3rem}
.careers-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:3rem;
}
.job-card{
  background:#fff;
  border:1px solid rgba(201,169,97,.3);
  padding:2.5rem;text-align:left;
  position:relative;overflow:hidden;
  transition:transform .4s, box-shadow .4s;
}
.job-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--gold),var(--gold-dark),var(--gold));
}
.job-card:hover{
  transform:translateY(-8px);
  box-shadow:0 30px 70px rgba(0,0,0,.15);
}
.job-tag{
  display:inline-block;
  font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;
  color:var(--gold-dark);background:rgba(201,169,97,.12);
  padding:.35rem .8rem;border-radius:2px;margin-bottom:1rem;
}
.job-card h3{color:var(--ink);margin-bottom:.5rem;font-size:1.6rem}
.job-dept{
  font-size:.85rem;color:var(--muted);font-style:italic;margin-bottom:1.2rem;
}
.job-section{margin-bottom:1rem}
.job-section h4{
  font-family:var(--sans);font-size:.75rem;letter-spacing:.25em;
  text-transform:uppercase;color:var(--gold-dark);
  font-weight:500;margin-bottom:.5rem;
}
.job-list{list-style:none;margin:0;padding:0}
.job-list li{
  padding:.3rem 0;padding-left:1.3rem;position:relative;
  font-size:.92rem;color:#4a4a4a;line-height:1.55;
}
.job-list li::before{
  content:'◆';position:absolute;left:0;top:.3rem;font-size:.6rem;color:var(--gold);
}
.job-meta{
  display:flex;gap:1.5rem;padding:1rem 0;margin:1rem 0;
  border-top:1px solid rgba(201,169,97,.25);
  border-bottom:1px solid rgba(201,169,97,.25);
  font-size:.85rem;color:var(--muted);flex-wrap:wrap;
}
.job-meta span{display:inline-flex;align-items:center;gap:.4rem}
.job-meta strong{color:var(--ink);font-weight:500}
.job-apply{
  display:inline-block;margin-top:1rem;
  padding:.8rem 2rem;background:var(--ink);color:var(--cream);
  text-decoration:none;font-size:.8rem;letter-spacing:.2em;
  text-transform:uppercase;transition:all .3s;
}
.job-apply:hover{background:var(--gold);color:var(--ink)}

/* Apply info block (careers page) */
.apply-info{
  max-width:760px;margin:4rem auto 0;text-align:center;
  padding:3rem 2rem;background:#fff;
  border:1px solid rgba(13,13,13,.08);
}
.apply-info h3{
  font-family:'Cormorant Garamond',serif;font-weight:400;
  font-size:1.8rem;color:var(--ink);margin-bottom:.5rem;
}
.apply-info .divider{margin-left:auto;margin-right:auto}
.apply-info p{color:var(--muted);margin-bottom:1.5rem;line-height:1.8}
.apply-contacts{
  display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;
}

/* Gallery */
.gallery{background:var(--cream)}
.gallery-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem;margin-top:3rem;
}
.gallery-item{
  position:relative;overflow:hidden;aspect-ratio:1;cursor:pointer;
  background-size:cover;background-position:center;
  transition:all .5s;
}
.gallery-item:nth-child(1){grid-column:span 2;grid-row:span 2}
.gallery-item::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(13,13,13,.3),rgba(201,169,97,.2));
  opacity:0;transition:opacity .4s;
}
.gallery-item:hover{transform:scale(1.02)}
.gallery-item:hover::after{opacity:1}

/* Lightbox */
.lightbox{
  display:none;position:fixed;inset:0;z-index:200;
  background:rgba(13,13,13,.95);
  align-items:center;justify-content:center;padding:2rem;
  cursor:pointer;
}
.lightbox.active{display:flex}
.lightbox img{max-width:90%;max-height:90vh;box-shadow:var(--shadow)}
.lightbox-close{
  position:absolute;top:2rem;right:2rem;color:var(--gold);
  font-size:2rem;background:none;border:none;cursor:pointer;
  font-family:var(--serif);
}

/* Footer */
footer{
  background:var(--ink);color:#8a8272;text-align:center;
  padding:3rem 2rem 2rem;font-size:.85rem;
}
footer .logo{display:inline-flex;margin-bottom:1rem}
footer .logo-mark{
  width:74px;
  height:74px;
}
footer .logo-word{
  font-size:1.5rem;
}
footer p{margin:.3rem 0}
.footer-line{
  width:40px;height:1px;background:var(--gold);margin:1.5rem auto;
}
.footer-quick{
  display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap;
  margin:1rem 0 .5rem;
}
.footer-quick a{color:var(--gold);text-decoration:none;font-size:.85rem}
.footer-quick a:hover{color:var(--gold-light)}

/* Toast */
.toast{
  position:fixed;bottom:2rem;left:50%;transform:translateX(-50%) translateY(100px);
  background:var(--ink);color:var(--gold);padding:1rem 2rem;
  border:1px solid var(--gold);z-index:300;
  font-size:.85rem;letter-spacing:.15em;text-transform:uppercase;
  transition:transform .4s;
}
.toast.show{transform:translateX(-50%) translateY(0)}

/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(30px);transition:all 1s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ==== Responsive ==== */
@media (max-width: 900px){
  .nav{padding:1rem 1.5rem}
  .nav.scrolled{padding:.7rem 1.5rem}
  .logo-mark{
    width:54px;
    height:54px;
  }
  .logo{
    gap:.65rem;
  }
  .logo-word{
    font-size:1.35rem;
    letter-spacing:.12em;
  }
  .nav-menu{
    position:fixed;top:0;right:-100%;width:70%;height:100vh;
    background:var(--ink);flex-direction:column;padding:5rem 2rem;
    transition:right .4s;gap:1.5rem;
  }
  .nav-menu.open{right:0}
  .hamburger{display:block;z-index:110}
  section{padding:4rem 1.5rem}
  .about-grid,.detail-grid{grid-template-columns:1fr;gap:2.5rem}
  .about-image,.detail-img{height:380px}
  .detail-grid.reverse{direction:ltr}
  .services-grid{grid-template-columns:1fr}
  .menu-grid{grid-template-columns:1fr;gap:2rem}
  .sets-wrap{grid-template-columns:1fr;gap:1.5rem}
  .menu-preview{padding:1.5rem}
  .menu-preview-grid{grid-template-columns:1fr}
  .set-badge{font-size:1.6rem;padding:1rem 1.5rem 1.5rem 2.5rem}
  .careers-intro{padding-bottom:1rem}
  .careers{padding:4rem 1.5rem}
  .careers-grid{grid-template-columns:1fr;gap:1.5rem}
  .job-card{padding:1.8rem}
  .job-meta{gap:.8rem;flex-direction:column}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-item:nth-child(1){grid-column:span 2;grid-row:span 1}
  .form-row{grid-template-columns:1fr}
  .about-stats{gap:1.5rem;flex-wrap:wrap}
  .hero-badges{gap:1.5rem}
  footer .logo-mark{
    width:62px;
    height:62px;
  }
  footer .logo-word{
    font-size:1.2rem;
  }
}
