/* Akariya full menu — Archival Index */

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;600;700&family=Noto+Serif+JP:wght@600;700&display=swap');

*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--aka-bg);
  color: var(--aka-text);
  font-family: var(--font-jp-sans);
  line-height: 1.6;
}

a { color: var(--aka-primary); text-decoration: none; }

h1, h2, h3 {
  font-family: var(--font-jp-serif);
  font-weight: 700;
}

.menu-skip {
  position: absolute;
  top: -100%;
  left: 16px;
  z-index: 200;
  padding: 12px 20px;
  background: var(--aka-primary);
  color: var(--aka-bg);
  font-weight: 700;
  border-radius: var(--radius-sm);
}

.menu-skip:focus { top: 16px; }

.menu-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(47, 42, 36, 0.94);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--glass-border-aka);
}

.menu-header-inner {
  max-width: var(--aka-max-width);
  margin: 0 auto;
  padding: 14px clamp(20px, 4vw, 32px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.menu-brand {
  color: var(--aka-white);
  font-family: var(--font-jp-serif);
  font-weight: 700;
  font-size: 18px;
}

.menu-header nav {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  font-size: 13px;
  font-weight: 600;
}

.menu-header nav a { color: var(--aka-muted); }
.menu-header nav a:hover { color: var(--aka-primary); }

.menu-hero {
  padding: clamp(48px, 8vw, 72px) clamp(20px, 4vw, 32px) clamp(32px, 5vw, 48px);
  max-width: var(--aka-max-width);
  margin: 0 auto;
  border-bottom: 1px solid var(--glass-border-aka);
}

.menu-hero h1 {
  margin: 0;
  font-size: clamp(32px, 5vw, 44px);
  color: var(--aka-white);
}

.menu-hero p {
  margin: 12px 0 0;
  color: var(--aka-muted);
  max-width: 48ch;
}

.menu-tabs {
  position: sticky;
  top: 53px;
  z-index: 90;
  display: flex;
  gap: 8px;
  padding: 12px clamp(20px, 4vw, 32px);
  max-width: var(--aka-max-width);
  margin: 0 auto;
  background: rgba(47, 42, 36, 0.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--glass-border-aka);
}

.menu-tab {
  padding: 10px 20px;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 700;
  color: var(--aka-muted);
  border: 1px solid transparent;
  transition: color 0.15s, background 0.15s, border-color 0.15s;
}

.menu-tab:hover,
.menu-tab.is-active {
  color: var(--aka-bg);
  background: var(--aka-primary);
  border-color: var(--aka-primary);
}

.menu-section {
  padding: clamp(40px, 6vw, 56px) clamp(20px, 4vw, 32px);
  max-width: var(--aka-max-width);
  margin: 0 auto;
}

.menu-section-alt { background: rgba(60, 53, 46, 0.35); }

.menu-section-head {
  margin-bottom: 32px;
}

.menu-section-label {
  margin: 0 0 6px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--aka-primary);
}

.menu-section-title {
  margin: 0;
  font-size: clamp(26px, 4vw, 32px);
  color: var(--aka-white);
}

.menu-section-lead {
  margin: 10px 0 0;
  color: var(--aka-muted);
  font-size: 15px;
}

.menu-category {
  margin-bottom: 36px;
}

.menu-category h3 {
  margin: 0 0 12px;
  padding-bottom: 8px;
  font-size: 1.15rem;
  color: var(--aka-primary);
  border-bottom: 2px solid rgba(214, 154, 77, 0.25);
  letter-spacing: 0.04em;
}

/* Archival Index table */
.menu-index {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid var(--glass-border-aka);
  border-radius: var(--radius-sm);
  overflow: hidden;
  font-size: 0.9rem;
}

.menu-index thead {
  background: var(--aka-surface);
}

.menu-index th {
  padding: 12px 14px;
  text-align: left;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--aka-primary);
  border-bottom: 1px solid var(--glass-border-aka);
}

.menu-index td {
  padding: 12px 14px;
  vertical-align: top;
  color: var(--aka-text);
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.menu-index tbody tr:hover td {
  background: rgba(214, 154, 77, 0.06);
}

.menu-index .price-col {
  white-space: nowrap;
  text-align: right;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--aka-primary);
  width: 88px;
}

.menu-index .name-col { min-width: 140px; }

.jp {
  display: block;
  margin-top: 3px;
  font-size: 0.72rem;
  color: var(--aka-muted);
  font-weight: 400;
}

.menu-footer {
  border-top: 1px solid var(--glass-border-aka);
  padding: 32px clamp(20px, 4vw, 32px);
  text-align: center;
  font-size: 13px;
  color: var(--aka-muted);
}

.menu-footer a { color: var(--aka-primary); }

@media (max-width: 720px) {
  .menu-header nav { display: none; }

  .menu-index {
    display: block;
    border: none;
  }

  .menu-index thead { display: none; }

  .menu-index tbody,
  .menu-index tr,
  .menu-index td {
    display: block;
  }

  .menu-index tr {
    margin-bottom: 12px;
    border: 1px solid var(--glass-border-aka);
    border-radius: var(--radius-sm);
    overflow: hidden;
  }

  .menu-index td {
    border: none;
    padding: 10px 14px;
  }

  .menu-index td.price-col {
    text-align: left;
    background: rgba(214, 154, 77, 0.08);
    font-size: 1rem;
  }

  .menu-index td.price-col::before {
    content: "Price · ";
    color: var(--aka-muted);
    font-weight: 600;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
  }
}
