/* ===============================
   奄美の鶏飯 元祖 みなとや
   Base stylesheet (responsive)
   =============================== */

:root{
  --color-red: #b1361e;        /* 赤鶏の赤 */
  --color-red-dark: #8a2714;
  --color-red-soft: #e8d6cf;
  --color-white: #ffffff;
  --color-ivory: #fbf7f2;
  --color-text: #2a2320;
  --color-muted: #7a6f6a;
  --color-line: #e6ddd6;
  --font-jp: "Noto Serif JP", "Yu Mincho", "游明朝", "ヒラギノ明朝 ProN", serif;
  --font-sans: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif;
  --max-w: 1080px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-sans);
  color:var(--color-text);
  background:var(--color-white);
  line-height:1.8;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none;margin:0;padding:0}

.container{
  width:100%;
  max-width:var(--max-w);
  margin:0 auto;
  padding:0 24px;
}

/* ===== Header ===== */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--color-line);
}
.header-inner{
  max-width:var(--max-w);
  margin:0 auto;
  padding:14px 24px;
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;
}
.site-logo{
  margin:0;
  font-family:var(--font-jp);
  line-height:1.2;
  display:flex;flex-direction:column;
}
.logo-sub{font-size:.7rem;letter-spacing:.2em;color:var(--color-red)}
.logo-main{font-size:1.4rem;font-weight:700;letter-spacing:.12em}
.site-nav ul{display:flex;gap:22px}
.site-nav a{
  font-size:.9rem;letter-spacing:.08em;
  position:relative;padding:4px 0;transition:color .2s;
}
.site-nav a:hover{color:var(--color-red)}

/* ===== Hero ===== */
.hero{
  position:relative;
  background:
    linear-gradient(rgba(30,15,10,.45),rgba(30,15,10,.55)),
    linear-gradient(135deg,#6a1e10,#b1361e 60%,#d56b52);
  color:var(--color-white);
  display:flex;align-items:center;justify-content:center;
  text-align:center;
  padding:56px 24px;
}
.hero-simple{
  min-height:0;
  padding:48px 24px;
}
.hero-simple .hero-title{
  font-size:clamp(1.6rem,4.2vw,2.4rem);
  margin:0 0 18px;
}
.hero-simple .hero-desc{margin:0;font-size:.9rem}
.hero-sub{line-height:0;overflow:hidden}
.hero-sub img{
  width:100%;
  height:clamp(220px,38vw,460px);
  object-fit:cover;
  object-position:center;
  display:block;
}

/* Concept layout: 左カラムを広く、右側Top画像をコンパクトに */
.concept-layout{
  grid-template-columns:1.8fr 1fr;
  gap:48px;
  align-items:center;
}
.concept-figure{
  margin:0;
  max-width:240px;
  justify-self:center;
  align-self:center;
  background:transparent;
  box-shadow:none;
  border-radius:0;overflow:visible;
}
.concept-figure img{
  width:100%;height:auto;display:block;
}

/* 店舗情報 右カラム 80%縮小 */
.info-layout .two-col-side{
  max-width:336px;      /* 420 × 0.8 */
  margin-left:auto;      /* 右寄せ */
}
.info-figure-sm{max-width:336px}
.info-layout .map-wrap{max-width:336px}
.hero-inner{max-width:720px}
.hero-lead{
  font-family:var(--font-jp);
  letter-spacing:.4em;
  font-size:.85rem;
  margin:0 0 18px;
  opacity:.9;
}
.hero-title{
  font-family:var(--font-jp);
  font-size:clamp(1.8rem,5vw,2.8rem);
  line-height:1.5;
  font-weight:600;
  letter-spacing:.08em;
  margin:0 0 24px;
}
.hero-desc{
  font-size:.95rem;
  line-height:2;
  margin:0 0 36px;
  opacity:.95;
}

/* ===== Buttons ===== */
.btn{
  display:inline-block;
  padding:16px 40px;
  font-family:var(--font-jp);
  letter-spacing:.2em;
  border-radius:2px;
  transition:transform .2s, box-shadow .2s, background .2s;
  border:1px solid transparent;
}
.btn-primary{
  background:var(--color-white);
  color:var(--color-red);
  font-weight:600;
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.2)}

.btn-reserve{
  background:var(--color-red);
  color:var(--color-white);
  padding:22px 48px;
  display:inline-flex;flex-direction:column;align-items:center;gap:4px;
  min-width:280px;
}
.btn-reserve:hover{background:var(--color-red-dark);transform:translateY(-2px)}
.btn-label{font-size:.9rem;letter-spacing:.3em}
.btn-tel{font-size:1.4rem;letter-spacing:.1em;font-weight:700}

/* ===== Section base ===== */
.section{padding:90px 0}
.section-title{
  font-family:var(--font-jp);
  font-size:1.6rem;
  letter-spacing:.2em;
  text-align:center;
  margin:0 0 48px;
  position:relative;
  display:flex;flex-direction:column;align-items:center;gap:8px;
}
.section-title::after{
  content:"";width:40px;height:2px;background:var(--color-red);
  margin-top:14px;
}
.section-sub{
  font-family:var(--font-sans);
  font-size:.7rem;letter-spacing:.35em;
  color:var(--color-red);font-weight:400;
}
.section-title.light,
.section-title.light .section-sub{color:var(--color-white)}
.section-title.light::after{background:var(--color-white)}

/* ===== Concept ===== */
.concept{background:var(--color-ivory)}
.concept-text{
  text-align:center;
  font-family:var(--font-jp);
  font-size:1rem;
  line-height:2.2;
  margin:0 0 24px;
  color:#3d302a;
}

/* ===== Menu ===== */
.menu-list{
  max-width:720px;margin:0 auto;
  border-top:1px solid var(--color-line);
}
.menu-item{
  display:grid;
  grid-template-columns:1fr 2fr auto;
  gap:16px;
  align-items:center;
  padding:24px 8px;
  border-bottom:1px solid var(--color-line);
}
.menu-name{
  font-family:var(--font-jp);
  font-size:1.15rem;font-weight:600;
  letter-spacing:.1em;color:var(--color-red);
}
.menu-desc{font-size:.9rem;color:var(--color-muted);line-height:1.7}
.menu-price{
  font-family:var(--font-jp);
  font-size:1.05rem;letter-spacing:.05em;
  color:var(--color-text);
}

/* ===== Info ===== */
.info{background:var(--color-ivory)}
.info-list{max-width:640px;margin:0 auto}
.info-row{
  display:grid;
  grid-template-columns:140px 1fr;
  gap:16px;
  padding:20px 8px;
  border-bottom:1px solid var(--color-line);
}
.info-row dt{
  font-family:var(--font-jp);
  color:var(--color-red);
  letter-spacing:.15em;
  font-size:.95rem;
}
.info-row dd{margin:0;font-size:.95rem}
.info-row dd small{color:var(--color-muted);font-size:.82rem}
.info-row a{border-bottom:1px solid currentColor}

/* ===== Two-column layout (text left / visual right) ===== */
.two-col{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:start;
}
.two-col-body{min-width:0}
.two-col-figure,
.two-col-side{min-width:0}
.two-col-figure{
  margin:0;
  border-radius:4px;overflow:hidden;
  box-shadow:0 10px 30px rgba(0,0,0,.1);
  background:#fff;
}
.two-col-figure img{width:100%;height:auto;display:block}
.two-col-figure figcaption{
  text-align:center;
  font-family:var(--font-jp);
  font-size:1.05rem;letter-spacing:.3em;
  color:var(--color-red);
  padding:14px 12px;
  background:#fff;border-top:1px solid var(--color-line);
}

.info-figure-sm{
  margin:0 0 20px;
  max-width:420px;
  border-radius:4px;overflow:hidden;
  box-shadow:0 8px 20px rgba(0,0,0,.08);
}
.info-figure-sm img{width:100%;height:auto;display:block}

/* ===== Figures (how-to page) ===== */
.howto-figure{
  max-width:560px;margin:0 auto 40px;
  border-radius:4px;overflow:hidden;
  box-shadow:0 10px 30px rgba(0,0,0,.08);
  background:#fff;
}
.howto-figure img{
  width:100%;height:auto;display:block;
}
.howto-figure figcaption{
  text-align:center;padding:14px 12px;
  font-family:var(--font-jp);font-size:.9rem;
  letter-spacing:.2em;color:var(--color-red);
  border-top:1px solid var(--color-line);
  background:#fff;
}
.howto-figure{background:#000}
.howto-figure video{max-height:70vh;object-fit:contain}
.howto-figure figcaption{
  text-align:center;padding:10px 12px;
  font-family:var(--font-jp);font-size:.85rem;
  color:var(--color-muted);background:#fff;
  letter-spacing:.12em;
}

/* ===== Google Map ===== */
.map-wrap{
  max-width:420px;margin:0;
  border-radius:4px;overflow:hidden;
  box-shadow:0 8px 24px rgba(0,0,0,.08);
  background:#fff;
}
.map-wrap iframe{display:block;width:100%}
.map-link{
  text-align:right;margin:0;padding:10px 16px;
  font-size:.85rem;background:#fff;
  border-top:1px solid var(--color-line);
}
.map-link a{color:var(--color-red);border-bottom:1px solid currentColor}

/* ===== Menu note ===== */
.menu-note{
  max-width:720px;margin:28px auto 0;
  text-align:center;font-size:.88rem;
  color:var(--color-muted);line-height:1.9;
}

/* ===== Mail Order ===== */
.mailorder{
  background:linear-gradient(135deg,var(--color-red) 0%,var(--color-red-dark) 100%);
  color:var(--color-white);
  text-align:center;
}
.mailorder-lead{
  font-family:var(--font-jp);
  font-size:1.05rem;line-height:2;
  margin:0 0 32px;opacity:.95;
}
.price-box{
  max-width:640px;margin:0 auto 32px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.3);
  padding:28px 24px;border-radius:4px;
  text-align:left;
}
.price-row{
  display:flex;justify-content:space-between;align-items:baseline;
  gap:16px;padding:10px 0;
  border-bottom:1px dashed rgba(255,255,255,.25);
}
.price-row:last-of-type{border-bottom:none}
.price-label{font-family:var(--font-jp);letter-spacing:.08em;font-size:.95rem}
.price-value{font-family:var(--font-jp)}
.price-value strong{font-size:1.25rem;letter-spacing:.06em;margin:0 4px}
.price-value small{font-size:.85rem;opacity:.85}
.price-note{
  margin:16px 0 0;font-size:.82rem;opacity:.85;
  line-height:1.7;text-align:center;
}
.mailorder-text{
  font-family:var(--font-jp);
  max-width:720px;margin:0 auto 36px;
  line-height:2;opacity:.95;font-size:.95rem;
}

/* ===== Instagram icon in nav ===== */
.nav-sns a{
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;
  color:var(--color-red);
  transition:background .2s,color .2s;
}
.nav-sns a:hover{background:var(--color-red);color:#fff}
.icon-ig{display:block}

/* ===== Order page ===== */
.order-hero{
  background:linear-gradient(180deg,#fbf7f2 0%,#f2e6dd 100%);
  color:var(--color-text);
  text-align:center;
  padding:44px 24px 36px;
  border-bottom:1px solid var(--color-line);
}
.order-hero .hero-lead{
  letter-spacing:.4em;font-size:.8rem;
  margin:0 0 16px;
  color:var(--color-red);
  font-family:var(--font-jp);
}
.order-title{
  font-family:var(--font-jp);
  font-size:clamp(1.6rem,4vw,2.2rem);
  letter-spacing:.15em;margin:0 0 18px;font-weight:600;
  color:var(--color-text);
}
.order-sub{
  font-size:.95rem;line-height:1.9;margin:0;
  color:var(--color-muted);
}

.guide-box{
  max-width:760px;margin:0 auto;
  background:var(--color-ivory);
  border:1px solid var(--color-line);
  padding:32px 28px;border-radius:4px;
}
.guide-head{
  font-family:var(--font-jp);
  font-size:1.05rem;letter-spacing:.15em;
  color:var(--color-red);
  margin:24px 0 12px;
  padding-left:12px;border-left:3px solid var(--color-red);
}
.guide-head:first-child{margin-top:0}
.guide-list{margin:0 0 8px}
.guide-list li{
  display:flex;justify-content:space-between;align-items:baseline;
  gap:16px;padding:10px 0;border-bottom:1px dashed var(--color-line);
  font-family:var(--font-jp);
}
.guide-list li:last-child{border-bottom:none}
.guide-list strong{color:var(--color-red);letter-spacing:.05em}
.guide-text{margin:0 0 4px;line-height:1.9;font-size:.95rem}
.guide-text small{color:var(--color-muted);font-size:.85rem}

/* ===== Order form ===== */
.order-form{
  max-width:760px;margin:0 auto;
}
.form-block{
  border:1px solid var(--color-line);
  border-radius:4px;
  padding:24px 24px 8px;
  margin:0 0 28px;
  background:#fff;
}
.form-block legend{
  font-family:var(--font-jp);
  padding:0 12px;
  color:var(--color-red);
  letter-spacing:.15em;font-size:1rem;font-weight:600;
}
.form-note{
  font-size:.85rem;color:var(--color-muted);
  margin:0 0 16px;line-height:1.7;
}
.form-row{
  display:flex;flex-direction:column;gap:8px;
  margin:0 0 18px;
}
.form-row label,
.form-row .label-like{
  font-family:var(--font-jp);
  font-size:.92rem;letter-spacing:.1em;
  color:var(--color-text);
  display:flex;align-items:center;gap:8px;
}
.req{
  background:var(--color-red);color:#fff;
  font-size:.7rem;letter-spacing:.1em;
  padding:2px 8px;border-radius:2px;font-weight:400;
}
.form-row input[type=text],
.form-row input[type=tel],
.form-row input[type=email],
.form-row input[type=number],
.form-row textarea{
  width:100%;
  padding:12px 14px;
  font-size:1rem;font-family:inherit;
  border:1px solid var(--color-line);
  border-radius:3px;background:#fff;
  transition:border-color .2s,box-shadow .2s;
}
.form-row input:focus,
.form-row textarea:focus{
  outline:none;
  border-color:var(--color-red);
  box-shadow:0 0 0 3px rgba(177,54,30,.12);
}
.radio-group{
  display:flex;flex-direction:column;gap:10px;
  padding:6px 0 2px;
}
.radio-group label{
  font-size:.92rem;font-family:var(--font-sans);
  letter-spacing:.05em;cursor:pointer;
}
.form-agree{
  text-align:center;font-size:.85rem;
  color:var(--color-muted);line-height:1.9;
  margin:0 0 24px;
}
.form-submit{text-align:center;margin:8px 0 0}

.mail-fallback{
  max-width:720px;margin:56px auto 0;
  padding:24px;background:var(--color-ivory);
  border-left:3px solid var(--color-red);
  font-size:.9rem;line-height:1.9;
}
.mail-fallback p{margin:0 0 10px;font-family:var(--font-jp)}
.mail-fallback ul{padding-left:0}
.mail-fallback li{list-style:none;color:var(--color-muted)}

/* Honeypot (Netlify) */
.hp-field{position:absolute;left:-9999px;opacity:0;pointer-events:none}

.form-hint{
  display:block;margin-top:6px;
  color:var(--color-muted);font-size:.82rem;line-height:1.6;
}

/* Price summary in order form */
.price-summary{
  margin:24px 0 8px;
  padding:20px 22px;
  background:var(--color-ivory);
  border:1px solid var(--color-line);
  border-left:3px solid var(--color-red);
  border-radius:3px;
}
.price-summary-title{
  font-family:var(--font-jp);
  margin:0 0 14px;font-size:1rem;letter-spacing:.15em;
  color:var(--color-red);font-weight:600;
}
.price-summary-list{margin:0}
.price-summary-list > div{
  display:flex;justify-content:space-between;align-items:baseline;
  gap:12px;padding:8px 0;
  border-bottom:1px dashed var(--color-line);
  font-family:var(--font-jp);
}
.price-summary-list > div:last-child{border-bottom:none}
.price-summary-list dt{margin:0;font-size:.92rem;color:var(--color-text)}
.price-summary-list dd{margin:0;font-size:.95rem;color:var(--color-text)}
.price-total{padding-top:12px !important;margin-top:4px;border-top:1px solid var(--color-line) !important}
.price-total strong{font-size:1.25rem;color:var(--color-red);letter-spacing:.05em}
.price-summary-note{
  margin:12px 0 0;font-size:.82rem;
  color:var(--color-red);line-height:1.7;
}
.price-summary-note:empty{display:none}

/* ===== How-to-eat page ===== */
.howto-hero{
  background:
    linear-gradient(rgba(30,15,10,.45),rgba(30,15,10,.55)),
    linear-gradient(135deg,#6a1e10,#b1361e 60%,#d56b52);
  color:#fff;text-align:center;
  padding:48px 24px 40px;
}
.howto-hero-inner{max-width:720px;margin:0 auto}
.howto-title{
  font-family:var(--font-jp);
  font-size:clamp(1.5rem,3.8vw,2.1rem);
  line-height:1.5;letter-spacing:.12em;
  margin:0 0 18px;font-weight:600;
}
.howto-sub{font-size:.95rem;line-height:2;margin:0;opacity:.95;font-family:var(--font-jp)}

.steps-list{
  max-width:760px;margin:0 auto;padding:0;
  counter-reset:step;
}
.step{
  display:grid;
  grid-template-columns:120px 1fr;
  gap:32px;
  padding:32px 0;
  border-bottom:1px solid var(--color-line);
  align-items:flex-start;
}
.step:last-child{border-bottom:none}
.step-num{
  display:flex;align-items:center;justify-content:center;
  width:96px;height:96px;border-radius:50%;
  background:var(--color-ivory);
  border:1px solid var(--color-red-soft);
  color:var(--color-red);
  font-family:var(--font-jp);
  font-size:1.6rem;letter-spacing:.05em;font-weight:600;
}
.step-final .step-num{
  background:var(--color-red);color:#fff;border-color:var(--color-red);
}
.step-title{
  font-family:var(--font-jp);
  font-size:1.25rem;letter-spacing:.12em;
  margin:6px 0 12px;color:var(--color-red);
  font-weight:600;
}
.step-desc{
  margin:0;line-height:2;font-size:.95rem;
  color:var(--color-text);
}

.howto-cta{
  max-width:640px;margin:64px auto 0;text-align:center;
  padding:40px 24px;
  background:var(--color-ivory);
  border-radius:4px;
}
.howto-cta p{
  font-family:var(--font-jp);
  font-size:1.05rem;letter-spacing:.15em;
  margin:0 0 20px;color:var(--color-red);
}

@media (max-width:768px){
  .howto-hero{padding:64px 20px 52px}
  .step{grid-template-columns:1fr;gap:12px;padding:28px 0;text-align:center}
  .step-num{margin:0 auto;width:72px;height:72px;font-size:1.3rem}
  .step-title{font-size:1.1rem}
  .howto-cta{padding:32px 20px}
}

/* ===== Confirm page ===== */
.confirm-list{margin:0 0 8px}
.confirm-list > div{
  display:grid;grid-template-columns:160px 1fr;gap:16px;
  padding:12px 0;border-bottom:1px dashed var(--color-line);
}
.confirm-list > div:last-child{border-bottom:none}
.confirm-total{padding-top:14px !important;margin-top:6px;border-top:1px solid var(--color-line) !important}
.confirm-total strong{color:var(--color-red);font-size:1.2rem;letter-spacing:.05em}
.confirm-list dt{
  font-family:var(--font-jp);
  color:var(--color-red);letter-spacing:.1em;
  font-size:.92rem;margin:0;
}
.confirm-list dd{margin:0;font-size:.95rem;word-break:break-all}
.confirm-note{
  margin:0;padding:12px 0;font-size:.95rem;line-height:1.9;
  white-space:pre-wrap;color:var(--color-text);
}
.sender-empty{
  margin:8px 0 0;color:var(--color-muted);
  font-size:.9rem;font-family:var(--font-jp);
}
.confirm-actions{
  max-width:760px;margin:36px auto 0;
  display:flex;gap:16px;justify-content:center;flex-wrap:wrap;
}
.btn-back{
  background:#fff;color:var(--color-red);
  border:1px solid var(--color-red);
  padding:20px 36px;
  font-family:var(--font-jp);letter-spacing:.2em;
}
.btn-back:hover{background:var(--color-red);color:#fff}

@media (max-width:768px){
  .confirm-list > div{grid-template-columns:1fr;gap:4px;padding:10px 0}
  .confirm-actions{flex-direction:column-reverse;align-items:stretch}
  .btn-back{padding:16px 24px;text-align:center}
}

/* ===== Thanks page ===== */
.thanks-hero{
  min-height:calc(100vh - 160px);
  background:linear-gradient(135deg,#6a1e10,#b1361e 60%,#d56b52);
  color:#fff;
  display:flex;align-items:center;justify-content:center;
  padding:80px 24px;text-align:center;
}
.thanks-inner{max-width:640px}
.thanks-eyebrow{
  font-family:var(--font-jp);
  letter-spacing:.45em;font-size:.85rem;
  margin:0 0 18px;opacity:.9;
}
.thanks-title{
  font-family:var(--font-jp);
  font-size:clamp(1.6rem,4.5vw,2.4rem);
  letter-spacing:.12em;margin:0 0 28px;font-weight:600;
}
.thanks-text{
  font-family:var(--font-jp);
  line-height:2.1;margin:0 0 24px;font-size:1rem;
}
.thanks-note{
  font-size:.85rem;line-height:1.9;
  opacity:.85;margin:0 0 40px;
}

/* ===== Footer ===== */
.site-footer{
  background:#1a0f0c;color:#c9bfb9;
  text-align:center;padding:28px 16px;
  font-size:.8rem;letter-spacing:.15em;
}
.site-footer p{margin:0}

/* ===== Responsive ===== */
@media (max-width:768px){
  .header-inner{flex-direction:column;gap:10px;padding:12px 16px}
  .site-nav ul{gap:14px;flex-wrap:wrap;justify-content:center}
  .site-nav a{font-size:.8rem}
  .logo-main{font-size:1.2rem}

  .hero{min-height:72vh;padding:60px 20px}
  .hero-title{font-size:1.7rem;line-height:1.6}
  .hero-desc{font-size:.9rem}

  .section{padding:64px 0}
  .section-title{font-size:1.35rem;margin-bottom:36px}
  .concept-text{font-size:.95rem;line-height:2;text-align:left}
  .concept-text br{display:none}

  .menu-item{
    grid-template-columns:1fr;
    gap:6px;padding:20px 4px;
  }
  .menu-price{text-align:left}

  .info-row{
    grid-template-columns:1fr;
    gap:4px;padding:16px 4px;
  }
  .info-row dt{font-size:.85rem}

  .btn-reserve{min-width:0;width:100%;padding:20px 24px}
  .btn-tel{font-size:1.2rem}

  .two-col{grid-template-columns:1fr;gap:28px}
  .hero-simple{min-height:auto;padding:56px 20px}
  .info-layout .two-col-side,
  .info-figure-sm,
  .info-layout .map-wrap{max-width:100%;margin:0}

  .price-row{flex-direction:column;align-items:flex-start;gap:4px}
  .guide-list li{flex-direction:column;align-items:flex-start;gap:4px}
  .guide-box{padding:24px 18px}
  .form-block{padding:20px 16px 4px}
  .order-hero{padding:60px 20px 48px}
}

@media (max-width:380px){
  .hero-title{font-size:1.5rem}
  .btn{padding:14px 28px}
}
