@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:wght@400;500;600;700;800&display=swap');

:root { --blue:#123e6b; --deep:#061b31; --ink:#0f2742; --pale:#f4f8fc; --soft:#dce9f5; }
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin:0; background:var(--pale); color:var(--ink); font-family:"Bricolage Grotesque", Arial, sans-serif; }
a { color:inherit; text-decoration:none; }
.page { min-height:100vh; overflow-x:hidden; }
.header { position:fixed; inset:0 0 auto 0; z-index:50; border-bottom:1px solid rgba(0,0,0,.08); background:rgba(244,248,252,.88); backdrop-filter:blur(18px); }
.header-inner { max-width:1180px; margin:0 auto; padding:14px 20px; display:flex; align-items:center; justify-content:space-between; gap:18px; }
.header-logo img { width:130px; height:auto; display:block; }
.nav { display:none; gap:26px; font-size:12px; font-weight:800; letter-spacing:.18em; text-transform:uppercase; color:rgba(0,0,0,.58); }
.btn { display:inline-flex; align-items:center; justify-content:center; border-radius:999px; padding:13px 18px; font-size:12px; font-weight:800; line-height:1; letter-spacing:.12em; text-transform:uppercase; transition:transform .2s ease, background .2s ease; white-space:nowrap; }
.btn:hover { transform:translateY(-1px); }
.btn-dark { background:var(--blue); color:white; }
.btn-light { background:white; color:var(--ink); }
.btn-outline { color:white; border:1px solid rgba(255,255,255,.72); }
.hero { min-height:100vh; position:relative; display:flex; align-items:flex-end; overflow:hidden; padding:112px 20px 52px; color:white; }
.hero-image, .hero-overlay { position:absolute; inset:0; width:100%; height:100%; }
.hero-image { object-fit:cover; }
.hero-overlay { background:linear-gradient(to top, rgba(6,27,49,.98), rgba(6,27,49,.68) 45%, rgba(6,27,49,.22)), radial-gradient(circle at 72% 20%, rgba(184,212,238,.28), transparent 32%); }
.hero-content { position:relative; z-index:2; width:100%; max-width:1180px; margin:0 auto; }
.eyebrow, .label { margin:0 0 16px; font-size:12px; font-weight:800; letter-spacing:.24em; text-transform:uppercase; }
.eyebrow { color:#b8d4ee; }
.label { color:rgba(0,0,0,.46); }
.hero-brand { margin:0 0 26px; line-height:0; }
.hero-logo { width:min(82vw, 560px); height:auto; filter:brightness(0) invert(1) drop-shadow(0 6px 22px rgba(0,0,0,.34)); }
h1, h2 { margin:0; font-weight:800; letter-spacing:0; line-height:.96; }
h1 { max-width:760px; font-size:52px; color:#dce9f5; }
h2 { font-size:42px; }
.hero-actions { margin-top:30px; display:flex; flex-direction:column; gap:12px; max-width:360px; }
.section { max-width:1180px; margin:0 auto; padding:86px 20px; }
.concept, .reservation, .location { display:grid; gap:34px; }
.copy p, .menu-heading p, .location p { font-size:18px; line-height:1.65; color:rgba(0,0,0,.66); }
.features-section { background:var(--blue); padding:72px 20px; }
.features { max-width:1180px; margin:0 auto; display:grid; gap:18px; }
.card { border-radius:8px; border:1px solid rgba(0,0,0,.08); background:white; }
.feature { border-color:rgba(255,255,255,.12); background:rgba(255,255,255,.06); color:white; padding:28px; }
.feature h3 { margin:0 0 12px; font-size:30px; letter-spacing:0; }
.feature p { margin:0; color:rgba(255,255,255,.66); line-height:1.55; }
.menu-heading { display:grid; gap:24px; margin-bottom:34px; }
.menu-card { margin:0 auto; max-width:980px; overflow:hidden; border-radius:8px; border:1px solid rgba(0,0,0,.08); background:white; box-shadow:0 16px 40px rgba(18,62,107,.08); }
.menu-image { display:block; width:100%; height:auto; }
.note { margin:0; padding:14px 16px; color:rgba(0,0,0,.46); font-size:14px; background:white; }
.gallery { display:grid; grid-template-columns:repeat(2,1fr); background:var(--soft); }
.gallery img { width:100%; aspect-ratio:4/5; object-fit:cover; display:block; }
.gallery img:first-child { grid-column:span 2; aspect-ratio:16/11; }
.reserve-card { padding:28px; }
.phone { display:block; margin:0 0 22px; font-size:28px; font-weight:800; letter-spacing:0; }
.location { max-width:none; background:var(--soft); padding-left:max(20px, calc((100vw - 1180px)/2)); padding-right:max(20px, calc((100vw - 1180px)/2)); }
.map-box { min-height:310px; border-radius:8px; overflow:hidden; background:rgba(255,255,255,.7); }
.map-box iframe { width:100%; height:100%; min-height:310px; border:0; display:block; }
.footer { background:var(--blue); color:white; padding:38px max(20px, calc((100vw - 1180px)/2)); display:grid; gap:24px; }
.footer-main { display:flex; flex-direction:column; gap:24px; }
.footer-logo { width:150px; height:auto; filter:brightness(0) invert(1); }
.footer p { margin:10px 0 0; color:rgba(255,255,255,.55); }
.footer-links { display:flex; flex-wrap:wrap; gap:16px; color:rgba(255,255,255,.68); font-size:14px; }
.footer-legal { border-top:1px solid rgba(255,255,255,.18); padding-top:18px; display:grid; gap:8px; }
.footer-legal p { margin:0; max-width:900px; font-size:12px; line-height:1.5; color:rgba(255,255,255,.58); }
@media (max-width:520px) {
  .header-inner { padding:12px 14px; gap:12px; }
  .header-logo img { width:112px; }
  .header .btn { padding:11px 14px; font-size:11px; letter-spacing:.08em; }
  .hero { padding:96px 20px 42px; }
  .hero-logo { width:min(88vw, 420px); }
  h1 { font-size:44px; }
  h2 { font-size:36px; }
  .section { padding:64px 20px; }
  .menu-card { margin-left:-8px; margin-right:-8px; }
}
@media (min-width:760px) {
  .nav { display:flex; }
  h1 { font-size:76px; }
  h2 { font-size:64px; }
  .hero-actions { flex-direction:row; max-width:none; }
  .concept, .reservation, .location { grid-template-columns:1.1fr .9fr; align-items:start; }
  .features { grid-template-columns:repeat(3,1fr); }
  .menu-heading { grid-template-columns:1.2fr .8fr; align-items:end; }
  .menu-card .note { padding:18px 22px; }
  .gallery { grid-template-columns:repeat(5,1fr); }
  .gallery img:first-child { grid-column:auto; aspect-ratio:4/5; }
  .footer-main { flex-direction:row; justify-content:space-between; align-items:center; }
}
