/* ===== ごはん処つばさ — mobile first / navy modern ===== */

:root{
  /* ロゴ準拠：ネイビー＋白 */
  --navy:        #14365E;   /* メイン濃紺 */
  --navy-deep:   #0E2742;   /* フッター等 */
  --navy-soft:   #2E63A0;   /* アクセント青 */
  --accent:      #B23A2E;   /* 翼マークの臙脂（ごく控えめに） */

  --bg:    #FFFFFF;         /* 基本背景：白 */
  --bg-alt:#F2F5F9;         /* 交互背景：クールな淡グレー */
  --ink:   #1B2A3D;         /* 本文（紺寄りの黒） */
  --ink-soft:#5C6B7D;       /* サブテキスト */
  --line:  #E3E9F1;         /* 罫線 */

  --maxw: 480px;
  --pad: 22px;
  --radius: 14px;
  --shadow: 0 8px 30px rgba(20,54,94,.08);
  --shadow-sm: 0 3px 14px rgba(20,54,94,.06);

  --font-sans: "Noto Sans JP", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  --font-serif: "Zen Old Mincho", "Yu Mincho", serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--ink);font-family:var(--font-sans);line-height:1.8;-webkit-text-size-adjust:100%;font-weight:400;width:100%;max-width:100%;overflow-x:hidden}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;background:none;border:none;color:inherit}
ul{list-style:none}

section{padding:64px var(--pad)}
body{padding-bottom:64px}

/* ===== ヘッダー ===== */
.site-header{
  position:sticky;top:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:13px var(--pad);
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
}
.logo{display:flex;align-items:center;gap:7px;font-family:var(--font-serif);font-weight:700;color:var(--navy)}
.logo-text{font-size:12px;color:var(--ink-soft);letter-spacing:.02em}
.logo-brand{font-size:21px;letter-spacing:.04em}
.logo-bird{width:21px;height:21px;color:var(--navy-soft)}
.logo-img{width:48px;height:48px;display:block;border-radius:50%}

.hamburger{display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 4px;color:var(--navy)}
.hamburger span{display:block;width:24px;height:2px;background:currentColor;border-radius:2px;transition:.25s}
.hamburger em{font-size:8px;letter-spacing:.18em;font-style:normal;margin-top:1px;color:var(--ink-soft)}

.nav{position:fixed;inset:62px 0 auto 0;background:#fff;transform:translateY(-115%);visibility:hidden;transition:transform .28s cubic-bezier(.4,0,.2,1),visibility .28s;border-bottom:1px solid var(--line);box-shadow:var(--shadow-sm)}
.nav.open{transform:translateY(0);visibility:visible}
.nav ul{padding:6px var(--pad)}
.nav li{border-bottom:1px solid var(--line)}
.nav li:last-child{border-bottom:0}
.nav a{display:block;padding:16px 4px;font-weight:500;font-size:15px}

/* ===== ファーストビュー ===== */
.hero{position:relative;height:82vh;min-height:520px;max-height:720px;overflow:hidden}
.hero-bg{position:absolute;inset:0}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,39,66,.15) 0%,rgba(14,39,66,.25) 45%,rgba(14,39,66,.82) 100%)}
.hero-inner{position:absolute;left:0;right:0;bottom:9%;padding:0 var(--pad);z-index:2;color:#fff}
.hero-eyebrow{font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.82);margin-bottom:16px;font-weight:500}
.hero-title{font-family:var(--font-serif);font-size:36px;line-height:1.42;font-weight:700;letter-spacing:.03em;text-shadow:0 2px 18px rgba(0,0,0,.28)}
.hero-sub{margin-top:16px;font-size:14px;color:rgba(255,255,255,.92);letter-spacing:.05em;line-height:1.9}
.hero-bird{margin-top:18px;width:78px;height:30px;color:#fff;opacity:.85}

/* ===== 周年バナー（スリム・ネイビー） ===== */
.anniv-banner{background:var(--navy);color:#fff;text-align:center;padding:13px var(--pad);font-size:12.5px;line-height:1.7;letter-spacing:.02em}
.anniv-banner strong{font-weight:700;font-size:14px;letter-spacing:.05em}

/* ===== 利用シーン2カード ===== */
.scenes{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:36px var(--pad);background:var(--bg)}
.scene-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px 12px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px;box-shadow:var(--shadow-sm);transition:.2s}
.scene-card:active{transform:scale(.98)}
.scene-icon{width:34px;height:34px;color:var(--navy);margin-bottom:4px}
.scene-card.dinner .scene-icon{color:var(--navy-soft)}
.scene-jp{font-size:14px;font-weight:700;color:var(--navy)}
.scene-en{font-size:9px;letter-spacing:.22em;color:var(--ink-soft)}

/* ===== セクション見出し（eyebrow + 和文） ===== */
.sec-head{margin-bottom:30px}
.eyebrow{display:block;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--navy-soft);font-weight:600;margin-bottom:10px;position:relative;padding-left:34px}
.eyebrow::before{content:"";position:absolute;left:0;top:50%;width:24px;height:1.5px;background:var(--navy-soft);transform:translateY(-50%)}
.section-h{font-family:var(--font-serif);font-size:25px;font-weight:700;color:var(--navy);letter-spacing:.04em;line-height:1.4}
.bowl{display:none}
.center .sec-head,.center .eyebrow{text-align:center}
.center .eyebrow{padding-left:0}
.center .eyebrow::before{display:none}

/* ===== リード ===== */
.lead{background:var(--bg-alt)}
.lead-text{font-size:15px;line-height:2.1;color:var(--ink);margin-bottom:26px}
.lead-photos{margin:26px 0}
.lead-photos img{border-radius:var(--radius);box-shadow:var(--shadow)}

/* ===== 共通ボタン ===== */
.btn-outline{display:inline-flex;align-items:center;gap:9px;padding:14px 26px;border:1.5px solid var(--navy);border-radius:999px;font-size:13.5px;font-weight:600;color:var(--navy);background:transparent;transition:.2s}
.btn-outline:hover{background:var(--navy);color:#fff}
.btn-outline .arrow{color:var(--accent);font-weight:700;transition:.2s}
.btn-outline:hover .arrow{color:#fff}

.btn-pill{display:inline-flex;align-items:center;justify-content:center;height:56px;padding:0 44px;background:#fff;color:var(--navy);border-radius:999px;font-weight:700;font-size:15px;box-shadow:0 6px 20px rgba(0,0,0,.16)}

/* ===== おしながき カード ===== */
.oshinagaki{background:var(--bg);padding:64px 0}
.oshinagaki .sec-head{margin:0 var(--pad) 30px}
.card-big{display:block;background:#fff;margin:0 var(--pad) 18px;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);position:relative;border:1px solid var(--line)}
.card-img{aspect-ratio:16/10;overflow:hidden;background:var(--bg-alt)}
.card-img img{width:100%;height:100%;object-fit:cover}
.card-body{padding:20px 20px 24px;position:relative}
.card-tag{display:inline-block;font-size:10.5px;font-weight:700;padding:5px 12px;border-radius:999px;margin-bottom:10px;letter-spacing:.08em}
.lunch-tag{background:var(--navy);color:#fff}
.dinner-tag{background:var(--navy-soft);color:#fff}
.card-lead{font-size:14.5px;font-weight:500;line-height:1.75;color:var(--ink)}
.card-arrow{position:absolute;right:20px;bottom:20px;width:36px;height:36px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px}

/* ===== 人気メニュー ===== */
.menu{background:var(--bg-alt)}
.menu-item{background:#fff;border-radius:var(--radius);overflow:hidden;margin-bottom:22px;padding-bottom:18px;position:relative;box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.menu-img{aspect-ratio:4/3;overflow:hidden}
.menu-img img{width:100%;height:100%;object-fit:cover}
.badge{position:absolute;top:14px;left:14px;padding:5px 13px;background:var(--navy);color:#fff;font-size:11px;font-weight:700;border-radius:999px;letter-spacing:.06em;box-shadow:var(--shadow-sm)}
.badge.meibutsu{background:var(--accent)}
.badge.ninki{background:var(--navy)}
.badge.osusume{background:var(--navy-soft)}
.menu-name{font-family:var(--font-serif);font-size:18px;font-weight:700;color:var(--navy);padding:16px 20px 4px}
.menu-desc{padding:0 20px;font-size:13.5px;color:var(--ink-soft);line-height:1.8}
.menu-price{padding:10px 20px 0;font-size:17px;font-weight:700;color:var(--navy);text-align:right;font-variant-numeric:tabular-nums}
.note-mini{text-align:center;font-size:12.5px;color:var(--ink-soft);margin-top:18px}

/* メニュー：テキスト一覧 */
.menu-list{margin:0 0 12px;border-top:1px solid var(--line)}
.menu-list li{display:flex;align-items:baseline;gap:10px;padding:13px 2px;border-bottom:1px solid var(--line)}
.m-name{font-weight:600;font-size:14.5px;color:var(--ink)}
.m-badge{font-size:10px;font-weight:700;color:#fff;background:var(--navy-soft);padding:2px 8px;border-radius:999px;white-space:nowrap}
.m-price{margin-left:auto;font-weight:700;color:var(--navy);font-variant-numeric:tabular-nums;white-space:nowrap}
/* メニュー：人気の一皿グリッド */
.dish-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:24px 0 8px}
.dish{margin:0;border-radius:var(--radius);overflow:hidden;background:#fff;box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.dish img{width:100%;aspect-ratio:4/3;object-fit:cover}
.dish figcaption{padding:10px 12px;font-size:12.5px;font-weight:600;color:var(--navy);text-align:center;line-height:1.45}
/* メニュー：公式メニュー表 */
.menu-board{display:block;margin:20px 0 6px;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.menu-board img{width:100%;display:block}
.board-note{text-align:center;font-size:11.5px;color:var(--ink-soft)}

/* ===== つばさのこと ===== */
.about{background:var(--bg)}
.about-text p{font-size:15px;line-height:2.1;margin-bottom:14px}
.about-text strong{color:var(--navy)}
.about-photo{margin-top:28px}
.about-photo img{border-radius:var(--radius);max-height:420px;width:100%;object-fit:cover;box-shadow:var(--shadow)}

/* ===== お知らせ ===== */
.news{background:var(--bg-alt)}
.news-list li{display:grid;grid-template-columns:auto auto 1fr;gap:12px;align-items:center;padding:16px 0;border-bottom:1px solid var(--line)}
.news-list time{font-size:12px;color:var(--ink-soft);font-variant-numeric:tabular-nums}
.news-tag{font-size:10px;background:var(--navy);color:#fff;padding:3px 9px;border-radius:999px;letter-spacing:.04em}
.news-list p{font-size:13.5px;font-weight:500}
.news-note{font-size:12.5px;color:var(--ink-soft);margin-top:20px}
.news-note a{color:var(--navy-soft);text-decoration:underline}
.news-tag.campaign{background:var(--accent)}

/* ===== お弁当 ===== */
.bento{background:var(--bg)}
.bento-photos{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:24px}
.bento-photos img{border-radius:12px;aspect-ratio:1/1;object-fit:cover;box-shadow:var(--shadow-sm)}
.bento-lead{font-size:15px;line-height:2;margin-bottom:22px}
.bento-points{margin:0 0 18px;padding:0}
.bento-points li{position:relative;padding:10px 0 10px 24px;border-bottom:1px solid var(--line);font-size:14px;line-height:1.6}
.bento-points li::before{content:"";position:absolute;left:2px;top:17px;width:8px;height:8px;border-radius:50%;background:var(--navy-soft)}
.bento-note{font-size:13px;color:var(--ink-soft);margin-bottom:18px;line-height:1.8}
.bento-cta{display:flex;flex-wrap:wrap;gap:10px}

/* 子連れ枠 */
.kids-note{display:flex;gap:14px;align-items:flex-start;margin-top:24px;padding:18px 20px;background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--radius)}
.kids-emoji{font-size:26px;line-height:1.2;flex-shrink:0}
.kids-note p{font-size:14px;line-height:1.85;color:var(--ink)}
.kids-note strong{color:var(--navy)}

/* 営業カレンダーボタン */
.cal-btn{margin-top:4px;white-space:normal;text-align:center;max-width:100%}
.btn-outline{max-width:100%}

/* ===== Instagram ===== */
.instagram{background:var(--bg-alt)}
.ig-lead{font-size:14px;color:var(--ink-soft);margin-bottom:22px}
.ig-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:26px}
.ig-grid img{aspect-ratio:1/1;object-fit:cover;border-radius:8px}

/* ===== 店舗情報 ===== */
.info{background:var(--bg)}
.info-list{display:flex;flex-direction:column;gap:0;margin-bottom:20px}
.info-list>div{display:grid;grid-template-columns:84px 1fr;gap:14px;font-size:14.5px;padding:16px 0;border-bottom:1px solid var(--line)}
.info-list>div:first-child{padding-top:0}
.info-list dt{font-weight:700;color:var(--navy)}
.info-list dd a{color:var(--navy-soft);font-weight:700}
.info-note{font-size:12.5px;color:var(--ink-soft);line-height:2;margin:18px 0 22px}
.info-note a{text-decoration:underline;color:var(--navy-soft)}
.map iframe{display:block;width:100%;max-width:100%;border-radius:var(--radius);box-shadow:var(--shadow-sm)}

/* ===== 予約CTA ===== */
.reserve{background:var(--navy);color:#fff;text-align:center;padding:60px var(--pad)}
.reserve-h{font-family:var(--font-serif);font-size:23px;margin-bottom:8px;font-weight:700;letter-spacing:.05em}
.reserve-phone{display:block;font-size:33px;font-weight:700;margin:18px 0 14px;letter-spacing:.02em;font-variant-numeric:tabular-nums;color:#fff}
.reserve-text{font-size:13.5px;line-height:2;margin-bottom:26px;color:rgba(255,255,255,.88)}

/* ===== フッター ===== */
.site-footer{background:var(--navy-deep);color:#fff;padding:40px var(--pad);text-align:center}
.footer-logo{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-serif);margin-bottom:12px}
.footer-logo .logo-text{color:rgba(255,255,255,.65);font-size:12px}
.footer-logo .logo-brand{font-size:19px;color:#fff;font-weight:700}
.footer-logo .logo-bird{color:#fff;width:19px;height:19px}
.footer-logo-img{width:76px;height:76px;border-radius:50%;display:block;margin:0 auto 14px;background:#fff;box-shadow:0 4px 16px rgba(0,0,0,.25)}
.copy{font-size:11px;color:rgba(255,255,255,.55);letter-spacing:.04em}

/* ===== 固定下部CTA ===== */
.sticky-cta{position:fixed;bottom:0;left:0;right:0;display:grid;grid-template-columns:1fr 1.2fr;background:var(--navy);z-index:50;box-shadow:0 -4px 18px rgba(14,39,66,.22)}
.sticky-cta a{padding:17px 0;text-align:center;font-size:13.5px;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center;gap:6px}
.sticky-ig{border-right:1px solid rgba(255,255,255,.16)}
.sticky-tel{background:var(--accent)}

/* ===== PC幅 ===== */
@media(min-width:720px){
  body{padding-bottom:0}
  .sticky-cta{display:none}
  .hero-title{font-size:46px}
  .hero{max-height:760px}
  section,.scenes,.oshinagaki,.menu,.lead,.about,.news,.bento,.instagram,.info{max-width:var(--maxw);margin:0 auto}
  .reserve,.site-footer{max-width:none}
}
