/* ===================================================
   small kitchens LINE Mini App — Design System
   Tone & Manner: Artisanal / Warm / Minimal / Japanese
   =================================================== */

/* ---- Reset & Base ---- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  /* Brand Colors */
  --color-ink:       #1A1A18;   /* ほぼ黒・テキスト主体 */
  --color-ink-mid:   #4A4A44;   /* ミドルグレー */
  --color-ink-soft:  #7A7A72;   /* ソフトグレー */
  --color-bg:        #FAFAF7;   /* 温かみのあるオフホワイト */
  --color-bg-card:   #FFFFFF;
  --color-bg-warm:   #F5F3EE;   /* ウォームベージュ */
  --color-border:    #E8E4DC;
  --color-border-light: #F0EDE6;

  /* Accent Colors — derived from food photography */
  --color-accent:    #1A1A18;   /* メインアクセントはほぼ黒 */
  --color-accent-warm: #8B6A2E; /* 温かみのあるアンバー */
  --color-accent-light: #C4A96B; /* ライトゴールド */
  --color-success:   #3A7A52;
  --color-success-bg: #EAF4EE;
  --color-warning:   #B85C1A;
  --color-warning-bg: #FEF3E8;

  /* Typography
     sans: システムフォント優先（読み込み不要・ネイティブで綺麗）
     serif: Noto Serif JP + 日本語明朝フォールバック
  */
  --font-serif: 'Noto Serif JP', 'Hiragino Mincho ProN', 'Yu Mincho', 'YuMincho', Georgia, serif;
  --font-sans:  -apple-system, BlinkMacSystemFont, 'Hiragino Sans', 'Hiragino Kaku Gothic ProN',
                'Noto Sans JP', 'Yu Gothic UI', 'Meiryo UI', sans-serif;

  /* Spacing */
  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 16px;
  --space-lg: 24px;
  --space-xl: 32px;
  --space-2xl: 48px;

  /* Radius */
  --radius-sm: 6px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-full: 9999px;

  /* Shadow */
  --shadow-sm: 0 1px 4px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.08), 0 2px 4px rgba(0,0,0,0.04);
  --shadow-lg: 0 8px 24px rgba(0,0,0,0.1), 0 4px 8px rgba(0,0,0,0.06);

  /* Bottom Nav height */
  --nav-h: 64px;
  --header-h: 56px;
}

html { font-size: 16px; -webkit-text-size-adjust: 100%; text-size-adjust: 100%; }

body {
  font-family: var(--font-sans);
  background: var(--color-bg);
  color: var(--color-ink);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
}

a { color: inherit; text-decoration: none; }
button { cursor: pointer; font-family: inherit; }
input, textarea, select { font-family: inherit; }

/* ---- App Shell ---- */
.app-shell {
  max-width: 480px;
  margin: 0 auto;
  min-height: 100vh;
  position: relative;
  background: var(--color-bg);
}


/* ---- Main ---- */
/* padding-bottom はBottom Navigation定義内で上書き */

/* ---- Bottom Navigation ---- */
.bottom-nav {
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  max-width: 480px;
  height: calc(var(--nav-h) + env(safe-area-inset-bottom, 0px));
  padding-bottom: env(safe-area-inset-bottom, 0px);
  background: var(--color-bg-card);
  border-top: 1px solid var(--color-border);
  display: flex;
  z-index: 100;
}

.app-main {
  padding-bottom: calc(var(--nav-h) + env(safe-area-inset-bottom, 0px) + 16px);
}

.nav-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  color: var(--color-ink-soft);
  font-size: 10px;
  letter-spacing: 0.03em;
  transition: color 0.15s;
}
.nav-item:active { color: var(--color-ink); }
.nav-item svg { opacity: 0.7; }
.nav-item:active svg { opacity: 1; }

/* ---- Buttons ---- */
.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  background: var(--color-ink);
  color: #fff;
  border: none;
  border-radius: var(--radius-md);
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  padding: 12px 20px;
  cursor: pointer;
  transition: opacity 0.15s, transform 0.1s;
  text-decoration: none;
  letter-spacing: 0.02em;
}
.btn-primary:active { opacity: 0.8; transform: scale(0.98); }

.btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  background: transparent;
  color: var(--color-ink);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  padding: 12px 20px;
  cursor: pointer;
  transition: background 0.15s, transform 0.1s;
  text-decoration: none;
  letter-spacing: 0.02em;
}
.btn-secondary:active { background: var(--color-bg-warm); transform: scale(0.98); }

.btn-large { font-size: 15px; padding: 14px 24px; border-radius: var(--radius-lg); }
.btn-sm { font-size: 12px; padding: 8px 14px; border-radius: var(--radius-sm); }
.btn-full { width: 100%; }

/* ---- Section Title ---- */
.section-title {
  font-family: var(--font-serif);
  font-size: 17px;
  font-weight: 600;
  color: var(--color-ink);
  margin-bottom: var(--space-md);
}
.section-title-sm {
  font-family: var(--font-serif);
  font-size: 13px;
  font-weight: 600;
  color: var(--color-ink-mid);
  margin-bottom: var(--space-sm);
  letter-spacing: 0.03em;
}

/* ---- Page Title ---- */
.page-title {
  font-family: var(--font-serif);
  font-size: 22px;
  font-weight: 600;
  color: var(--color-ink);
  letter-spacing: 0.02em;
  line-height: 1.3;
}
.page-subtitle {
  font-size: 13px;
  color: var(--color-ink-soft);
  margin-top: 6px;
  line-height: 1.6;
}

/* ---- Form ---- */
.text-input {
  width: 100%;
  background: var(--color-bg-card);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 12px var(--space-md);
  font-size: 16px;
  color: var(--color-ink);
  transition: border-color 0.15s;
  appearance: none;
  -webkit-appearance: none;
}
.text-input:focus {
  outline: none;
  border-color: var(--color-ink);
}
.text-input::placeholder { color: var(--color-ink-soft); }

.input-hint {
  font-size: 11px;
  color: var(--color-ink-soft);
  margin-top: 6px;
  padding-left: 4px;
}

/* ===================================================
   PAGE: 献立 (Menu) — 今週の献立テキストのみ
   =================================================== */
.page-menu {
  padding: var(--space-lg) var(--space-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-xl);
}

.menu-week-title {
  font-family: var(--font-serif);
  font-size: 22px;
  font-weight: 600;
  color: var(--color-ink);
  letter-spacing: 0.02em;
}

.menu-week-sub {
  font-size: 13px;
  color: var(--color-ink-soft);
  margin-top: 4px;
  letter-spacing: 0.02em;
}

/* 週リスト */
.week-list {
  display: flex;
  flex-direction: column;
  border-top: 1px solid var(--color-border);
}

.week-row {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
  padding: var(--space-md) 0;
  border-bottom: 1px solid var(--color-border-light);
}

.week-day-col {
  flex-shrink: 0;
  width: 36px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  padding-top: 2px;
}

.week-day {
  font-family: var(--font-serif);
  font-size: 16px;
  font-weight: 600;
  color: var(--color-ink);
  line-height: 1;
}

.week-date {
  font-size: 10px;
  color: var(--color-ink-soft);
  letter-spacing: 0.03em;
}

.week-menu-col {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.week-main {
  font-family: var(--font-serif);
  font-size: 15px;
  font-weight: 500;
  color: var(--color-ink);
  line-height: 1.4;
}

.week-sub-items {
  font-size: 12px;
  color: var(--color-ink-soft);
  line-height: 1.5;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 2px;
}

.week-dot {
  opacity: 0.35;
  margin: 0 2px;
}

.menu-order-btn {
  margin-top: var(--space-sm);
}

/* Bento Card */
.bento-card {
  background: var(--color-bg-card);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.bento-card-header {
  padding: var(--space-md) var(--space-md) 0;
}

.bento-label-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: var(--space-md);
  border-bottom: 1px solid var(--color-border-light);
}

.bento-badge {
  font-family: var(--font-serif);
  font-size: 16px;
  font-weight: 600;
  color: var(--color-ink);
}

.bento-price {
  font-size: 20px;
  font-weight: 600;
  font-family: var(--font-serif);
  color: var(--color-ink);
}
.bento-price small {
  font-size: 12px;
  font-weight: 400;
  color: var(--color-ink-soft);
}

.bento-items {
  padding: var(--space-sm) var(--space-md) var(--space-md);
}

.bento-item {
  display: flex;
  gap: var(--space-md);
  padding: var(--space-md) 0;
  border-bottom: 1px solid var(--color-border-light);
}
.bento-item:last-child { border-bottom: none; }

.bento-item-icon {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  background: var(--color-bg-warm);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 500;
  color: var(--color-accent-warm);
  letter-spacing: 0.02em;
  line-height: 1.2;
  text-align: center;
}

.bento-item-content { flex: 1; }

.bento-item-name {
  font-family: var(--font-serif);
  font-size: 14px;
  font-weight: 600;
  color: var(--color-ink);
  margin-bottom: 3px;
}

.bento-item-desc {
  font-size: 12px;
  color: var(--color-ink-soft);
  line-height: 1.5;
}

/* Features Strip */
.features-strip {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.feature-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--color-bg-warm);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  padding: 5px 12px;
  font-size: 11px;
  font-weight: 500;
  color: var(--color-ink-mid);
  letter-spacing: 0.02em;
}
.feature-chip svg { opacity: 0.6; }

/* Nutrition Card */
.nutrition-card {
  background: var(--color-bg-card);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  padding: var(--space-md);
  box-shadow: var(--shadow-sm);
}

.nutrition-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-sm);
  margin-bottom: var(--space-md);
}

.nutrition-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  background: var(--color-bg-warm);
  border-radius: var(--radius-sm);
  padding: 10px 4px;
}

.n-val {
  font-family: var(--font-serif);
  font-size: 16px;
  font-weight: 600;
  color: var(--color-ink);
}
.n-label {
  font-size: 10px;
  color: var(--color-ink-soft);
}

.allergen-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-sm);
}
.allergen-label {
  font-size: 11px;
  color: var(--color-ink-soft);
  font-weight: 500;
}
.allergen-chip {
  background: var(--color-warning-bg);
  color: var(--color-warning);
  font-size: 11px;
  border-radius: var(--radius-full);
  padding: 2px 10px;
}

/* Order CTA */
.order-cta {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  align-items: stretch;
}

.order-deadline {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  justify-content: center;
  font-size: 13px;
  color: var(--color-warning);
  background: var(--color-warning-bg);
  border-radius: var(--radius-md);
  padding: 10px var(--space-md);
}

/* Shops Section */
.shops-section {
  margin-bottom: var(--space-md);
}

.shop-card {
  background: var(--color-bg-card);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  padding: var(--space-md);
  margin-bottom: var(--space-sm);
  box-shadow: var(--shadow-sm);
}

.shop-name {
  font-family: var(--font-serif);
  font-size: 14px;
  font-weight: 600;
  color: var(--color-ink);
  margin-bottom: 6px;
}

.shop-address, .shop-hours {
  display: flex;
  align-items: flex-start;
  gap: 5px;
  font-size: 12px;
  color: var(--color-ink-soft);
  line-height: 1.5;
  margin-bottom: 4px;
}
.shop-address svg, .shop-hours svg { flex-shrink: 0; margin-top: 2px; }

/* ===================================================
   PAGE: 注文 (Order)
   =================================================== */
.page-order {
  padding: var(--space-md);
}

.order-summary-header {
  padding: var(--space-lg) 0 var(--space-md);
}

.order-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.form-section {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.form-section-title {
  font-family: var(--font-serif);
  font-size: 14px;
  font-weight: 600;
  color: var(--color-ink);
  letter-spacing: 0.02em;
}

/* Order Product Card */
.order-product-card {
  background: var(--color-bg-card);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
}

.order-product-img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  object-position: center;
  display: block;
}

.order-product-card .order-product-info,
.order-product-card .order-product-price {
  /* inline layout inside the card bottom area */
}

.order-product-card > .order-product-info {
  padding: var(--space-md) var(--space-md) 0;
  flex: 1;
}

.order-product-card > .order-product-price {
  padding: var(--space-sm) var(--space-md) var(--space-md);
  font-family: var(--font-serif);
  font-size: 20px;
  font-weight: 600;
  color: var(--color-ink);
  text-align: right;
}

.order-product-badge {
  font-size: 10px;
  color: var(--color-accent-warm);
  background: var(--color-bg-warm);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  padding: 2px 10px;
  display: inline-block;
  margin-bottom: 6px;
}

.order-product-name {
  font-family: var(--font-serif);
  font-size: 15px;
  font-weight: 600;
  color: var(--color-ink);
  margin-bottom: 4px;
}

.order-product-meta {
  font-size: 11px;
  color: var(--color-ink-soft);
  line-height: 1.6;
}
.dot { margin: 0 4px; opacity: 0.4; }

/* Quantity Selector */
.qty-selector {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

.qty-btn {
  width: 44px;
  height: 44px;
  background: var(--color-bg-warm);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s;
}
.qty-btn:active { background: var(--color-border); }

.qty-input {
  width: 64px;
  text-align: center;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 10px;
  font-size: 20px;
  font-family: var(--font-serif);
  font-weight: 600;
  color: var(--color-ink);
  background: var(--color-bg-card);
  -moz-appearance: textfield;
}
.qty-input::-webkit-outer-spin-button,
.qty-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

.qty-total {
  font-size: 13px;
  color: var(--color-ink-mid);
  font-weight: 500;
}

/* Shop Radio */
.shop-radio-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.shop-radio-card {
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
  background: var(--color-bg-card);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  cursor: pointer;
  transition: border-color 0.15s;
  position: relative;
}

.shop-radio-card input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.shop-radio-card:has(input:checked) {
  border-color: var(--color-ink);
  background: var(--color-bg-warm);
}

.shop-radio-inner { flex: 1; }
.shop-radio-name {
  font-family: var(--font-serif);
  font-size: 14px;
  font-weight: 600;
  color: var(--color-ink);
  margin-bottom: 3px;
}
.shop-radio-address, .shop-radio-hours {
  font-size: 11px;
  color: var(--color-ink-soft);
  line-height: 1.5;
}

.shop-radio-check {
  width: 24px;
  height: 24px;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 2px;
  background: var(--color-bg);
  transition: all 0.15s;
  color: transparent;
}

.shop-radio-card:has(input:checked) .shop-radio-check {
  background: var(--color-ink);
  border-color: var(--color-ink);
  color: #fff;
}

/* Payment Info */
.payment-info-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  flex-wrap: wrap;
}

.payment-option {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: 15px;
  font-weight: 500;
}
.payment-icon { font-size: 20px; }
.payment-divider {
  font-size: 11px;
  color: var(--color-ink-soft);
  margin: 0 4px;
}
.payment-note {
  width: 100%;
  font-size: 11px;
  color: var(--color-ink-soft);
  margin-top: 6px;
  padding-top: 10px;
  border-top: 1px solid var(--color-border-light);
}

/* Submit Area */
.order-submit-area {
  padding: var(--space-lg) 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.order-total-display {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: var(--color-bg-warm);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  border: 1px solid var(--color-border);
}

.order-total-label { font-size: 14px; color: var(--color-ink-mid); }
.order-total-price {
  font-family: var(--font-serif);
  font-size: 22px;
  font-weight: 600;
  color: var(--color-ink);
}

.submit-note {
  text-align: center;
  font-size: 11px;
  color: var(--color-ink-soft);
}

/* ===================================================
   PAGE: 注文完了 (Complete)
   =================================================== */
.page-complete {
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-xl);
}

.complete-hero {
  text-align: center;
  padding: var(--space-xl) var(--space-md) var(--space-md);
}

.complete-icon {
  width: 80px;
  height: 80px;
  background: var(--color-success-bg);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--space-md);
  color: var(--color-success);
}

.complete-title {
  font-family: var(--font-serif);
  font-size: 20px;
  font-weight: 600;
  color: var(--color-ink);
  margin-bottom: 8px;
}

.complete-subtitle {
  font-size: 13px;
  color: var(--color-ink-soft);
}

/* Receipt */
.order-receipt {
  background: var(--color-bg-card);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.receipt-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-md);
  background: var(--color-bg-warm);
  border-bottom: 1px solid var(--color-border);
}

.receipt-label {
  font-size: 11px;
  color: var(--color-ink-soft);
  font-weight: 500;
}
.receipt-id {
  font-family: var(--font-serif);
  font-size: 15px;
  font-weight: 600;
  color: var(--color-ink);
  letter-spacing: 0.05em;
}

.receipt-body {
  padding: var(--space-sm) var(--space-md);
}

.receipt-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 10px 0;
  border-bottom: 1px solid var(--color-border-light);
  gap: var(--space-sm);
}
.receipt-row:last-child { border-bottom: none; }

.receipt-key {
  font-size: 12px;
  color: var(--color-ink-soft);
  flex-shrink: 0;
  padding-top: 1px;
}
.receipt-val {
  font-size: 13px;
  color: var(--color-ink);
  font-weight: 500;
  text-align: right;
  line-height: 1.4;
}

.receipt-row-total { padding: var(--space-md) 0; }
.receipt-total {
  font-family: var(--font-serif);
  font-size: 18px;
  font-weight: 600;
  color: var(--color-ink);
}

.receipt-footer {
  padding: var(--space-md);
  border-top: 1px solid var(--color-border-light);
  background: var(--color-bg-warm);
}

.receipt-payment-note {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: 12px;
  color: var(--color-ink-soft);
}

/* Complete Actions */
.complete-actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

/* Complete Notes */
.complete-notes {
  background: var(--color-bg-warm);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  border: 1px solid var(--color-border);
}

.notes-title {
  font-family: var(--font-serif);
  font-size: 13px;
  font-weight: 600;
  color: var(--color-ink);
  margin-bottom: var(--space-sm);
}

.notes-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.notes-list li {
  font-size: 12px;
  color: var(--color-ink-soft);
  padding-left: 14px;
  position: relative;
  line-height: 1.5;
}
.notes-list li::before {
  content: '·';
  position: absolute;
  left: 4px;
  color: var(--color-accent-warm);
  font-size: 16px;
  line-height: 1.2;
}

/* ===================================================
   PAGE: My Orders
   =================================================== */
.page-my-orders {
  padding: var(--space-md);
}

.my-orders-header {
  padding: var(--space-lg) 0 var(--space-md);
}

.empty-state {
  text-align: center;
  padding: var(--space-2xl) var(--space-md);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-md);
}

.empty-icon {
  color: var(--color-border);
}

.empty-text {
  font-size: 14px;
  color: var(--color-ink-soft);
}
.empty-sub {
  font-size: 12px;
  color: var(--color-ink-soft);
  font-family: monospace;
}

/* Orders List */
.orders-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  margin-bottom: var(--space-xl);
}

.order-card {
  background: var(--color-bg-card);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: opacity 0.2s;
}

.order-card-done { opacity: 0.65; }

.order-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-md);
  background: var(--color-bg-warm);
  border-bottom: 1px solid var(--color-border-light);
}

.order-card-id {
  font-family: var(--font-serif);
  font-size: 13px;
  font-weight: 600;
  color: var(--color-ink);
  letter-spacing: 0.05em;
}

.order-status-badge {
  font-size: 11px;
  font-weight: 500;
  border-radius: var(--radius-full);
  padding: 3px 10px;
}
.badge-ready {
  background: var(--color-warning-bg);
  color: var(--color-warning);
}
.badge-done {
  background: var(--color-success-bg);
  color: var(--color-success);
}

.order-card-body {
  padding: var(--space-sm) var(--space-md);
}

.order-card-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 0;
  border-bottom: 1px solid var(--color-border-light);
  gap: var(--space-sm);
}
.order-card-row:last-child { border-bottom: none; }

.oc-key {
  font-size: 11px;
  color: var(--color-ink-soft);
  flex-shrink: 0;
}
.oc-val {
  font-size: 13px;
  color: var(--color-ink);
  font-weight: 500;
  text-align: right;
}

.order-card-total { padding: 10px 0; }
.oc-price {
  font-family: var(--font-serif);
  font-size: 16px;
  font-weight: 600;
}

.order-card-actions {
  padding: var(--space-md);
  background: var(--color-bg-warm);
  border-top: 1px solid var(--color-border-light);
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

/* ---- QRスキャン受け取りボタン（my-orders ヘッダー） ---- */
.scan-pickup-btn {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 14px 16px;
  margin-top: 16px;
  background: var(--color-ink);
  color: #fff;
  border: none;
  border-radius: var(--radius-lg);
  cursor: pointer;
  text-align: left;
  transition: opacity 0.15s;
}
.scan-pickup-btn:active { opacity: 0.8; }
.scan-pickup-btn-icon {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  background: rgba(255,255,255,0.12);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.scan-pickup-btn-text {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.scan-pickup-btn-text strong {
  font-size: 14px;
  font-weight: 600;
  line-height: 1.3;
}
.scan-pickup-btn-text small {
  font-size: 11px;
  color: rgba(255,255,255,0.65);
  line-height: 1.4;
}

/* btn-outline（小ボタン用） */
.btn-outline {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  padding: 8px 14px;
  border-radius: var(--radius-sm);
  background: transparent;
  border: 1.5px solid var(--color-ink);
  color: var(--color-ink);
  cursor: pointer;
  transition: background 0.15s;
}
.btn-outline:active { background: var(--color-bg-warm); }

.my-orders-footer { margin-top: var(--space-md); }

/* ===================================================
   PAGE: 受け取り (Receive)
   =================================================== */
.page-receive { padding: var(--space-md); }

.receive-header {
  padding: var(--space-lg) 0 var(--space-md);
}

.receive-subtitle {
  font-size: 14px;
  color: var(--color-ink-mid);
  margin-top: 8px;
  line-height: 1.7;
}
.receive-subtitle strong { color: var(--color-ink); font-weight: 600; }

/* QR Display */
.qr-display-area {
  display: flex;
  justify-content: center;
  margin: var(--space-lg) 0;
}

.qr-card {
  background: var(--color-bg-card);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  padding: var(--space-lg);
  box-shadow: var(--shadow-md);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-md);
  width: 100%;
  max-width: 320px;
}

.qr-order-info {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}
.qr-order-id {
  font-family: var(--font-serif);
  font-size: 13px;
  font-weight: 600;
  color: var(--color-ink-soft);
  letter-spacing: 0.08em;
}
.qr-order-name {
  font-family: var(--font-serif);
  font-size: 16px;
  font-weight: 600;
  color: var(--color-ink);
}

.qr-code-wrapper {
  background: #fff;
  padding: var(--space-md);
  border-radius: var(--radius-md);
  border: 2px solid var(--color-border);
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 220px;
  min-width: 220px;
}

#qrcode canvas {
  display: block;
  max-width: 200px !important;
  max-height: 200px !important;
}

.qr-product-info {
  text-align: center;
  border-top: 1px solid var(--color-border-light);
  padding-top: var(--space-md);
  width: 100%;
}
.qr-product-name {
  font-size: 13px;
  color: var(--color-ink-mid);
  margin-bottom: 4px;
}
.qr-product-price {
  font-family: var(--font-serif);
  font-size: 20px;
  font-weight: 600;
  color: var(--color-ink);
}

.pickup-done-banner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  background: var(--color-success-bg);
  color: var(--color-success);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  font-weight: 500;
  margin-bottom: var(--space-md);
}

/* Receive Info Card */
.receive-info-card {
  background: var(--color-bg-card);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: var(--space-md);
  box-shadow: var(--shadow-sm);
}

.receive-info-row {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--color-ink-mid);
}
.receive-info-row svg { color: var(--color-ink-soft); flex-shrink: 0; }

/* Staff Demo */
.staff-demo-section { margin-top: var(--space-md); }
.staff-demo-details {
  background: var(--color-bg-warm);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.staff-demo-summary {
  padding: var(--space-md);
  font-size: 13px;
  color: var(--color-ink-mid);
  cursor: pointer;
  user-select: none;
  list-style: none;
}
.staff-demo-summary::-webkit-details-marker { display: none; }
.staff-demo-inner {
  padding: 0 var(--space-md) var(--space-md);
  border-top: 1px dashed var(--color-border);
}
.staff-demo-desc {
  font-size: 12px;
  color: var(--color-ink-soft);
  margin-bottom: var(--space-sm);
  line-height: 1.6;
}

/* Scan Mode */
.receive-scan-mode {}

.scan-area {
  display: flex;
  justify-content: center;
  margin: var(--space-lg) 0;
}

.scan-viewfinder {
  width: 240px;
  height: 240px;
  position: relative;
  background: var(--color-bg-warm);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
}

.scan-corner {
  position: absolute;
  width: 24px;
  height: 24px;
  border-color: var(--color-ink);
  border-style: solid;
}
.scan-corner.tl { top: 10px; left: 10px; border-width: 3px 0 0 3px; border-radius: 3px 0 0 0; }
.scan-corner.tr { top: 10px; right: 10px; border-width: 3px 3px 0 0; border-radius: 0 3px 0 0; }
.scan-corner.bl { bottom: 10px; left: 10px; border-width: 0 0 3px 3px; border-radius: 0 0 0 3px; }
.scan-corner.br { bottom: 10px; right: 10px; border-width: 0 3px 3px 0; border-radius: 0 0 3px 0; }

.scan-line {
  position: absolute;
  left: 14px;
  right: 14px;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--color-accent-warm), transparent);
  animation: scanMove 2s ease-in-out infinite;
  top: 50%;
}

@keyframes scanMove {
  0% { transform: translateY(-80px); opacity: 0; }
  20% { opacity: 1; }
  80% { opacity: 1; }
  100% { transform: translateY(80px); opacity: 0; }
}

.scan-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
  color: var(--color-border);
  text-align: center;
  padding: var(--space-md);
  z-index: 1;
}
.scan-placeholder p { font-size: 12px; line-height: 1.5; }

/* Scan Instructions */
.scan-instructions {
  margin-bottom: var(--space-lg);
}
.scan-inst-title {
  font-family: var(--font-serif);
  font-size: 14px;
  font-weight: 600;
  color: var(--color-ink);
  margin-bottom: var(--space-md);
}

.scan-steps {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}
.scan-steps li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
  font-size: 13px;
  color: var(--color-ink-mid);
  line-height: 1.5;
}

.step-num {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  background: var(--color-ink);
  color: #fff;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 600;
  margin-top: 1px;
}

/* Demo QR Section */
.demo-qr-section {
  margin-bottom: var(--space-lg);
}
.demo-label {
  text-align: center;
  font-size: 11px;
  color: var(--color-ink-soft);
  margin-bottom: var(--space-sm);
  letter-spacing: 0.05em;
}
.demo-shop-btns {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}
.demo-shop-btn { justify-content: flex-start; }

/* Or Divider */
.or-divider {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin: var(--space-md) 0;
}
.or-divider::before, .or-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--color-border);
}
.or-divider span {
  font-size: 11px;
  color: var(--color-ink-soft);
  padding: 0 var(--space-sm);
}

.manual-order-input { margin-bottom: var(--space-lg); }
.manual-hint {
  font-size: 12px;
  color: var(--color-ink-soft);
  margin-bottom: var(--space-sm);
}
.manual-form {
  display: flex;
  gap: var(--space-sm);
}
.manual-form .text-input { flex: 1; font-family: monospace; letter-spacing: 0.05em; }

/* ===================================================
   PAGE: Shop Verify
   =================================================== */
.page-shop-verify { padding: var(--space-md); }

.shop-verify-header {
  padding: var(--space-lg) 0 var(--space-md);
}

.shop-verify-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--color-success-bg);
  color: var(--color-success);
  font-size: 11px;
  font-weight: 500;
  border-radius: var(--radius-full);
  padding: 4px 14px;
  margin-bottom: var(--space-sm);
}

.verify-orders-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.verify-order-card {
  background: var(--color-bg-card);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  padding: var(--space-md);
  box-shadow: var(--shadow-sm);
}

.verify-order-header {
  display: flex;
  justify-content: space-between;
  margin-bottom: var(--space-sm);
}
.verify-order-id {
  font-size: 13px;
  color: var(--color-ink-soft);
  font-family: monospace;
  letter-spacing: 0.05em;
}
.verify-order-name {
  font-family: var(--font-serif);
  font-size: 15px;
  font-weight: 600;
}

.verify-order-details {
  display: flex;
  justify-content: space-between;
  font-size: 13px;
  color: var(--color-ink-mid);
  margin-bottom: var(--space-md);
  padding-top: var(--space-sm);
  border-top: 1px solid var(--color-border-light);
}
.verify-price {
  font-family: var(--font-serif);
  font-weight: 600;
  color: var(--color-ink);
}

.verify-btn { width: 100%; }

/* ===================================================
   PAGE: Staff Verify
   =================================================== */
.page-staff-verify { padding: var(--space-md); }

.staff-header-badge {
  display: inline-flex;
  background: var(--color-ink);
  color: #fff;
  font-size: 10px;
  font-weight: 500;
  border-radius: var(--radius-full);
  padding: 4px 14px;
  letter-spacing: 0.04em;
  margin: var(--space-md) 0;
}

.verify-already-done {
  text-align: center;
  padding: var(--space-xl) 0;
}
.done-icon {
  margin: 0 auto var(--space-md);
  background: var(--color-success-bg);
  color: var(--color-success);
}
.verify-done-title {
  font-family: var(--font-serif);
  font-size: 20px;
  font-weight: 600;
  color: var(--color-success);
  margin-bottom: 8px;
}
.verify-done-sub {
  font-size: 13px;
  color: var(--color-ink-soft);
}

.verify-confirm {}

.verify-order-display {
  background: var(--color-bg-card);
  border: 1.5px solid var(--color-ink);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  text-align: center;
  margin: var(--space-lg) 0;
}

.verify-order-number {
  font-size: 12px;
  color: var(--color-ink-soft);
  font-family: monospace;
  letter-spacing: 0.08em;
  margin-bottom: 6px;
}
.verify-customer-name {
  font-family: var(--font-serif);
  font-size: 22px;
  font-weight: 600;
  color: var(--color-ink);
  margin-bottom: var(--space-md);
}
.verify-order-summary {
  background: var(--color-bg-warm);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  margin-bottom: var(--space-sm);
}
.verify-product {
  font-size: 14px;
  color: var(--color-ink-mid);
  margin-bottom: 4px;
}
.verify-amount {
  font-family: var(--font-serif);
  font-size: 26px;
  font-weight: 600;
  color: var(--color-ink);
}
.verify-shop-tag {
  font-size: 12px;
  color: var(--color-ink-soft);
}

.verify-confirm-btn { margin-bottom: var(--space-md); }
.verify-note {
  text-align: center;
  font-size: 12px;
  color: var(--color-ink-soft);
}

/* ===================================================
   PAGE: Pickup Done
   =================================================== */
.page-pickup-done {
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-xl);
}

.pickup-done-hero {
  text-align: center;
  padding: var(--space-xl) var(--space-md) var(--space-md);
}

.pickup-done-animation {
  display: flex;
  justify-content: center;
  margin-bottom: var(--space-md);
}

.done-circle {
  width: 96px;
  height: 96px;
  background: var(--color-success-bg);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-success);
  animation: popIn 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

@keyframes popIn {
  from { transform: scale(0.5); opacity: 0; }
  to { transform: scale(1); opacity: 1; }
}

.pickup-done-title {
  font-family: var(--font-serif);
  font-size: 26px;
  font-weight: 600;
  color: var(--color-ink);
  margin-bottom: 10px;
}

.pickup-done-subtitle {
  font-size: 14px;
  color: var(--color-ink-mid);
  line-height: 1.8;
}

/* Pickup Done Message */
.pickup-done-message {}

.done-message-card {
  background: var(--color-bg-warm);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  text-align: center;
}

.done-message-card p {
  font-size: 13px;
  color: var(--color-ink-mid);
  line-height: 1.9;
  margin-bottom: var(--space-md);
}
.done-message-card p:last-child { margin-bottom: 0; }

.done-tagline {
  font-family: var(--font-serif);
  font-size: 14px;
  color: var(--color-accent-warm) !important;
  letter-spacing: 0.06em;
}

.pickup-done-actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  padding-bottom: var(--space-md);
}

/* ===================================================
   Utilities & Misc
   =================================================== */
.receive-with-order {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

/* ===================================================
   在庫バナー・売り切れ
   =================================================== */
.stock-banner {
  display: flex;
  align-items: center;
  gap: 8px;
  border-radius: var(--radius-md);
  padding: 10px 16px;
  font-size: 13px;
  font-weight: 500;
}
.stock-open {
  background: var(--color-success-bg);
  color: var(--color-success);
}
.stock-closed {
  background: #F3F3F3;
  color: var(--color-ink-soft);
}

.btn-disabled {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #E8E4DC;
  color: var(--color-ink-soft);
  border-radius: var(--radius-lg);
  padding: 14px 24px;
  font-size: 15px;
  font-weight: 500;
  pointer-events: none;
}

.sold-out-page {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-md);
  padding: 80px var(--space-md) var(--space-xl);
  text-align: center;
}
.sold-out-icon { color: var(--color-border); margin-bottom: 8px; }
.sold-out-title {
  font-family: var(--font-serif);
  font-size: 20px;
  font-weight: 600;
  color: var(--color-ink);
}
.sold-out-text { font-size: 13px; color: var(--color-ink-soft); }

/* ===================================================
   注文フロー ステップ切り替え
   =================================================== */
.order-step { display: flex; flex-direction: column; gap: var(--space-lg); }

.qty-display {
  width: 64px;
  text-align: center;
  font-size: 28px;
  font-family: var(--font-serif);
  font-weight: 600;
  color: var(--color-ink);
}

/* ===================================================
   Stripe 決済フォーム
   =================================================== */
.payment-step-header { margin-bottom: 4px; }

.back-inline-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: none;
  border: none;
  font-size: 13px;
  color: var(--color-ink-soft);
  cursor: pointer;
  padding: 0;
  font-family: var(--font-sans);
}
.back-inline-btn:hover { color: var(--color-ink); }

.payment-order-summary {
  background: var(--color-bg-warm);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  margin-bottom: var(--space-md);
}
.ps-row {
  display: flex;
  justify-content: space-between;
  font-size: 13px;
  color: var(--color-ink-mid);
  padding: 6px 0;
  border-bottom: 1px solid var(--color-border-light);
}
.ps-row:last-child { border-bottom: none; }
.ps-total {
  font-weight: 600;
  color: var(--color-ink);
  font-size: 14px;
  padding-top: 10px;
}

#payment-element-container {
  background: var(--color-bg-card);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  min-height: 60px;
}

.payment-message {
  background: var(--color-warning-bg);
  color: var(--color-warning);
  border-radius: var(--radius-sm);
  padding: 10px 14px;
  font-size: 13px;
  margin-top: 8px;
}

/* ===================================================
   決済済みバッジ
   =================================================== */
.paid-note {
  color: var(--color-success) !important;
}
.qr-paid-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  font-weight: 500;
  color: var(--color-success);
  background: var(--color-success-bg);
  border-radius: var(--radius-full);
  padding: 3px 10px;
  margin-top: 4px;
}
.paid-info { color: var(--color-success) !important; }

.verify-paid-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 500;
  color: var(--color-success);
  background: var(--color-success-bg);
  border-radius: var(--radius-full);
  padding: 4px 12px;
  margin: 8px 0;
}

/* ===================================================
   献立ページ（シンプル週次リスト）
   =================================================== */
.menu-top {
  padding: 32px var(--space-md) 8px;
}

.menu-top-label {
  font-family: var(--font-serif);
  font-size: 22px;
  font-weight: 600;
  color: var(--color-ink);
  letter-spacing: 0.04em;
  margin-bottom: 6px;
}

.menu-price-note {
  font-size: 13px;
  color: var(--color-ink-soft);
}
.menu-price-note span { font-size: 11px; }

/* 週次リスト */
.weekly-list {
  border-top: 1px solid var(--color-border);
  margin: 0 0 4px;
}

.weekly-row {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
  padding: 14px var(--space-md);
  border-bottom: 1px solid var(--color-border-light);
  position: relative;
}

.weekly-row-today {
  background: var(--color-bg-warm);
}

.weekly-date {
  flex-shrink: 0;
  width: 76px;
  font-size: 12px;
  font-weight: 500;
  color: var(--color-ink-mid);
  padding-top: 2px;
  display: flex;
  align-items: center;
  gap: 6px;
}

.today-dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-accent-warm);
  flex-shrink: 0;
}

.weekly-items {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.weekly-main {
  font-size: 14px;
  font-weight: 500;
  color: var(--color-ink);
  line-height: 1.4;
}

.weekly-sub {
  font-size: 12px;
  color: var(--color-ink-soft);
  line-height: 1.4;
}

/* order-cta 調整 */
.order-cta {
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.order-deadline {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--color-ink-soft);
  justify-content: center;
}

/* ===================================================
   ログインプロンプトカード（注文ページ・未ログイン時）
   =================================================== */
.login-prompt-card {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--color-bg-warm);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 14px 16px;
}

.lp-icon {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-ink-soft);
}

.lp-text { flex: 1; }

.lp-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--color-ink);
  margin-bottom: 2px;
}

.lp-desc {
  font-size: 11px;
  color: var(--color-ink-soft);
  line-height: 1.5;
}

.lp-btn {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 16px;
  background: var(--color-ink);
  color: #fff;
  border-radius: var(--radius-sm);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.02em;
  white-space: nowrap;
  text-decoration: none;
}

/* ===================================================
   注文タイプセレクター（法人ユーザー：受け取り / デリバリー）
   =================================================== */
.order-type-selector {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.ot-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg-card);
  color: var(--color-ink-mid);
  font-size: 13px;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  transition: all 0.15s;
}

.ot-btn.active {
  border-color: var(--color-ink);
  background: var(--color-ink);
  color: #fff;
}

.ot-btn:not(.active):hover {
  background: var(--color-bg-warm);
  border-color: var(--color-ink-mid);
}

/* ===================================================
   メニュー/詳細 タブ（注文ページ）
   =================================================== */
.order-tabs {
  display: flex;
  border-bottom: 1px solid var(--color-border);
  gap: 0;
}

.order-tab-btn {
  flex: 1;
  padding: 10px 16px;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  font-size: 13px;
  font-weight: 500;
  color: var(--color-ink-soft);
  font-family: inherit;
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
  letter-spacing: 0.02em;
}

.order-tab-btn.active {
  color: var(--color-ink);
  border-bottom-color: var(--color-ink);
  font-weight: 600;
}

.tab-panel { display: none; }
.tab-panel.active { display: block; }

/* ===================================================
   今日のステータス（献立ページ内）
   =================================================== */
.today-info {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
  flex-shrink: 0;
  margin-left: auto;
}

.today-price {
  font-family: var(--font-serif);
  font-size: 14px;
  font-weight: 600;
  color: var(--color-ink);
}

.today-status {
  font-size: 11px;
  font-weight: 500;
  border-radius: var(--radius-full);
  padding: 2px 8px;
}

.status-open {
  background: var(--color-success-bg);
  color: var(--color-success);
}

.status-closed {
  background: #F3F3F3;
  color: var(--color-ink-soft);
}

/* ===================================================
   詳細タブ：フィーチャー一覧
   =================================================== */
.detail-features {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.feature-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}

.feature-icon {
  font-size: 20px;
  flex-shrink: 0;
  line-height: 1;
  margin-top: 2px;
}

.feature-item strong {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--color-ink);
  margin-bottom: 2px;
  font-family: var(--font-sans);
}

.feature-item p {
  font-size: 12px;
  color: var(--color-ink-soft);
  line-height: 1.5;
}

/* ===================================================
   デリバリー先カード
   =================================================== */
.delivery-address-card {
  background: var(--color-bg-warm);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.da-company {
  font-family: var(--font-serif);
  font-size: 15px;
  font-weight: 600;
  color: var(--color-ink);
}

.da-address {
  font-size: 13px;
  color: var(--color-ink-mid);
  line-height: 1.5;
}

.da-note {
  font-size: 11px;
  color: var(--color-ink-soft);
  margin-top: 4px;
}

/* ===================================================
   デリバリー完了ノート
   =================================================== */
.delivery-complete-note {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 16px;
  background: #EFF6FF;
  border: 1px solid #BFDBFE;
  border-radius: var(--radius-md);
  color: #1D4ED8;
  font-size: 14px;
  font-weight: 500;
}

/* デリバリーバッジ */
.badge-delivery {
  font-size: 11px;
  font-weight: 500;
  background: #EFF6FF;
  color: #1D4ED8;
  border-radius: var(--radius-full);
  padding: 3px 10px;
}

/* ===================================================
   マイページ (Profile)
   =================================================== */
.page-profile {
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-xl);
}

.profile-header {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-xl) 0 var(--space-sm);
}

.profile-avatar {
  flex-shrink: 0;
  width: 64px;
  height: 64px;
  border-radius: var(--radius-full);
  overflow: hidden;
  border: 2px solid var(--color-border);
  background: var(--color-bg-warm);
}

.avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.avatar-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-ink-soft);
}

.profile-info {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.profile-name {
  font-family: var(--font-serif);
  font-size: 20px;
  font-weight: 600;
  color: var(--color-ink);
  line-height: 1.3;
}

.profile-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  font-weight: 500;
  border-radius: var(--radius-full);
  padding: 3px 10px;
  width: fit-content;
}

.badge-corporate {
  background: #EEF2FF;
  color: #3730A3;
}

.badge-general {
  background: var(--color-bg-warm);
  color: var(--color-ink-mid);
}

.profile-section {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.profile-section-title {
  font-family: var(--font-serif);
  font-size: 14px;
  font-weight: 600;
  color: var(--color-ink);
  letter-spacing: 0.02em;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--color-border-light);
}

/* お届け先情報 */
.delivery-info-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.di-row {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
  padding: 12px var(--space-md);
  border-bottom: 1px solid var(--color-border-light);
}
.di-row:last-child { border-bottom: none; }

.di-label {
  flex-shrink: 0;
  width: 56px;
  font-size: 11px;
  color: var(--color-ink-soft);
  font-weight: 500;
  padding-top: 1px;
}

.di-val {
  flex: 1;
  font-size: 13px;
  color: var(--color-ink);
  font-weight: 500;
  line-height: 1.5;
}

.di-id {
  font-family: monospace;
  font-size: 12px;
  letter-spacing: 0.06em;
  color: var(--color-ink-mid);
}

/* 法人会員への切り替えカード */
.corp-join-card {
  background: var(--color-bg-warm);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.corp-join-desc {
  font-size: 13px;
  color: var(--color-ink-mid);
  line-height: 1.7;
}

/* ミニ注文一覧 */
.orders-mini-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.order-mini-card {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: 10px var(--space-md);
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}

.omc-id {
  font-family: monospace;
  font-size: 12px;
  font-weight: 600;
  color: var(--color-ink);
  flex: 1;
  letter-spacing: 0.05em;
}

.omc-date {
  font-size: 12px;
  color: var(--color-ink-soft);
}

.profile-empty {
  font-size: 13px;
  color: var(--color-ink-soft);
  text-align: center;
  padding: var(--space-lg) 0;
}

.profile-footer {
  padding-bottom: var(--space-md);
}

/* ログアウトボタン */
.btn-danger-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 20px;
  border: 1.5px solid #FCA5A5;
  border-radius: var(--radius-md);
  background: transparent;
  color: #B91C1C;
  font-size: 13px;
  font-weight: 500;
  font-family: inherit;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.15s;
  width: 100%;
}
.btn-danger-outline:hover { background: #FEF2F2; }

/* ===================================================
   企業コード設定ページ (Profile Setup)
   =================================================== */
.page-setup {
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-xl);
}

.setup-header {
  padding: var(--space-xl) 0 0;
}

.setup-title {
  font-family: var(--font-serif);
  font-size: 22px;
  font-weight: 600;
  color: var(--color-ink);
  margin-bottom: 8px;
  line-height: 1.3;
}

.setup-desc {
  font-size: 13px;
  color: var(--color-ink-mid);
  line-height: 1.8;
}

.setup-error {
  background: var(--color-warning-bg);
  color: var(--color-warning);
  border: 1px solid #F8C8A3;
  border-radius: var(--radius-md);
  padding: 12px var(--space-md);
  font-size: 13px;
  font-weight: 500;
}

.setup-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.text-input-mono {
  font-family: monospace;
  letter-spacing: 0.08em;
  font-size: 18px !important;
  text-transform: uppercase;
}

.setup-skip {
  text-align: center;
  padding-bottom: var(--space-md);
}

.setup-skip a {
  font-size: 13px;
  color: var(--color-ink-soft);
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* ===================================================
   認証ページ (Auth)
   =================================================== */
.page-auth {
  padding: var(--space-md);
  min-height: 80vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.auth-card {
  width: 100%;
  max-width: 360px;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-xl) var(--space-lg);
  box-shadow: var(--shadow-md);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-md);
  text-align: center;
}

.auth-error-icon {
  color: var(--color-warning);
  margin-bottom: 4px;
}

.auth-title {
  font-family: var(--font-serif);
  font-size: 20px;
  font-weight: 600;
  color: var(--color-ink);
}

.auth-subtitle {
  font-size: 13px;
  color: var(--color-ink-soft);
  line-height: 1.6;
}

/* ===================================================
   リンク系ユーティリティ
   =================================================== */
.link-underline {
  text-decoration: underline;
  text-underline-offset: 2px;
  color: var(--color-ink);
}

/* ===================================================
   QRモーダル（my-orders）
   =================================================== */
.qr-modal {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.55);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  z-index: 200;
  padding-bottom: env(safe-area-inset-bottom, 0);
}

.qr-sheet {
  background: var(--color-bg-card);
  border-radius: 20px 20px 0 0;
  width: 100%;
  max-width: 480px;
  padding: 24px 20px 32px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-md);
}

.qr-sheet-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}

.qr-sheet-title {
  font-family: var(--font-serif);
  font-size: 16px;
  font-weight: 600;
  color: var(--color-ink);
}

.qr-sheet-close {
  background: var(--color-bg-warm);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  color: var(--color-ink-mid);
  cursor: pointer;
}

.qr-sheet-desc {
  font-size: 13px;
  color: var(--color-ink-soft);
  text-align: center;
  line-height: 1.6;
}

.qr-code-wrap {
  background: #fff;
  padding: 12px;
  border: 2px solid var(--color-border);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
}

.qr-code-wrap svg {
  display: block;
  width: 180px !important;
  height: 180px !important;
}

.qr-order-num {
  font-family: var(--font-serif);
  font-size: 14px;
  font-weight: 600;
  color: var(--color-ink-soft);
  letter-spacing: 0.1em;
}

/* ===================================================
   my-ordersフッター
   =================================================== */
.my-orders-footer {
  margin-top: var(--space-md);
  padding-bottom: var(--space-lg);
}

/* ===================================================
   注文ページ：注文ステップ .active クラス
   =================================================== */
.order-step.active { display: flex; }

/* ===================================================
   プロフィールページ joined バナー
   =================================================== */
.profile-joined-banner {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--color-success-bg);
  color: var(--color-success);
  border: 1px solid #A7F3D0;
  border-radius: var(--radius-md);
  padding: 12px var(--space-md);
  font-size: 13px;
  font-weight: 500;
}


/* ===================================================
   注文完了ページ：QRコードセクション
   =================================================== */
.complete-qr-section {
  background: var(--color-bg-warm);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-md) var(--space-md) 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  margin-bottom: var(--space-md);
}

.complete-qr-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-serif);
  font-size: 15px;
  font-weight: 600;
  color: var(--color-ink);
  align-self: flex-start;
}

.complete-qr-desc {
  font-size: 13px;
  color: var(--color-ink-soft);
  align-self: flex-start;
  margin-top: -6px;
}

.complete-qr-canvas-wrap {
  background: #fff;
  border: 2px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.complete-qr-canvas-wrap canvas {
  display: block;
  width: 200px !important;
  height: 200px !important;
}

.complete-qr-id {
  font-family: monospace;
  font-size: 13px;
  color: var(--color-ink-soft);
  letter-spacing: 0.1em;
}

/* btn-ghost */
.btn-ghost {
  background: transparent;
  border: 1px solid var(--color-border);
  color: var(--color-ink-soft);
  border-radius: var(--radius-md);
  padding: 12px 20px;
  font-size: 14px;
  font-family: var(--font-serif);
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s, color 0.15s;
}
.btn-ghost:hover { background: var(--color-bg-warm); color: var(--color-ink); }

/* ===================================================
   受け取りスポットページ（場所固定QR用）
   =================================================== */
.page-pickup-spot {
  padding: var(--space-md) var(--space-md) 100px;
  max-width: 480px;
  margin: 0 auto;
}

.ps-header {
  margin-bottom: var(--space-lg);
  padding-bottom: var(--space-md);
  border-bottom: 1px solid var(--color-border);
}

.ps-shop-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: var(--color-amber);
  background: var(--color-bg-warm);
  border: 1px solid #E8C97A;
  border-radius: 20px;
  padding: 4px 10px;
  margin-bottom: 10px;
}

.ps-shop-badge-delivery {
  color: #C2410C;
  background: #FFF7ED;
  border-color: #FED7AA;
}

.ps-shop-name {
  font-family: var(--font-serif);
  font-size: 22px;
  font-weight: 600;
  color: var(--color-ink);
  margin-bottom: 6px;
}

.ps-shop-address {
  font-size: 13px;
  color: var(--color-ink-soft);
  margin-bottom: 2px;
}

.ps-shop-hours {
  font-size: 12px;
  color: var(--color-ink-muted);
}

/* ログインプロンプト */
.ps-login-prompt {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  padding: var(--space-lg) 0;
  text-align: center;
}

.ps-login-icon {
  color: var(--color-ink-muted);
}

.ps-login-text {
  font-size: 15px;
  color: var(--color-ink);
  line-height: 1.7;
}

/* LINEボタン */
.btn-line {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: #06C755;
  color: #fff;
  border-radius: var(--radius-md);
  padding: 14px 28px;
  font-size: 15px;
  font-weight: 600;
  text-decoration: none;
  width: 100%;
  transition: background 0.15s;
}
.btn-line:hover { background: #05b34c; }

/* 注文カード */
.ps-order-found {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.ps-order-card {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.ps-order-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px var(--space-md);
  background: var(--color-bg-warm);
  border-bottom: 1px solid var(--color-border);
}

.ps-order-id {
  font-family: monospace;
  font-size: 13px;
  color: var(--color-ink-soft);
  letter-spacing: 0.06em;
}

.ps-order-status {
  font-size: 12px;
  font-weight: 600;
  color: var(--color-amber);
  background: #FFF8E6;
  border: 1px solid #F5DFA0;
  border-radius: 20px;
  padding: 3px 10px;
}

.ps-order-body {
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ps-order-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 14px;
}

.ps-key { color: var(--color-ink-soft); }
.ps-val { color: var(--color-ink); font-weight: 500; }

.ps-order-total {
  padding-top: 8px;
  border-top: 1px solid var(--color-border);
  margin-top: 4px;
}

.ps-price {
  font-family: var(--font-serif);
  font-size: 18px;
  font-weight: 600;
  color: var(--color-ink);
}

.ps-pickup-btn {
  margin-top: 4px;
  font-size: 17px;
  padding: 18px;
}

/* 注文なし */
.ps-no-order {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: var(--space-lg) 0;
  text-align: center;
}

.ps-no-order-icon {
  color: var(--color-ink-muted);
}

.ps-no-order-text {
  font-size: 15px;
  color: var(--color-ink);
  line-height: 1.7;
}

.ps-no-order-sub {
  font-size: 13px;
  color: var(--color-ink-soft);
}

/* ===================================================
   注文カード：お弁当日付バナー
   =================================================== */
.order-card-date-banner {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 9px var(--space-md);
  background: var(--color-bg-warm);
  border-bottom: 1px solid var(--color-border);
  font-family: var(--font-serif);
  font-size: 14px;
  font-weight: 600;
  color: var(--color-ink);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}

.order-card-date-banner svg {
  flex-shrink: 0;
  color: var(--color-amber);
}

.oc-done-mark {
  margin-left: auto;
  font-size: 11px;
  font-weight: 600;
  color: var(--color-success);
  background: var(--color-success-bg);
  border-radius: 20px;
  padding: 2px 8px;
  font-family: var(--font-sans);
}
