@charset "utf-8";
/* =========================================================
   デパートおせち予約ガイド — 共有スタイル
   可愛く元気・お正月らしく華やか（カラーブロック／丸ゴシック／市松／イラスト）
   UTF-8 / モバイルファースト
   ========================================================= */

:root{
  --red:#e8392a;          /* 主役の祝い赤 */
  --red-dark:#cc2b1e;
  --gold:#ecbb3e;         /* 明るい黄金色（黄色寄り） */
  --gold-deep:#d6a32c;
  --gold-ink:#5a420f;
  --orange:#f3922e;
  --green:#46ad6e;        /* 縁起の緑（差し色・イラスト） */
  --cream:#fdf3e3;        /* やさしいクリーム背景 */
  --pink:#f6a8b0;         /* 可愛いピンクの差し色 */
  --paper:#ffffff;
  --ink:#473b34;          /* 文字（温かいダークブラウン） */
  --ink-soft:#7d6e64;
  --ink-mute:#a99a8e;
  --line:#efe2d2;
  --radius:22px;
  --radius-sm:14px;
  --shadow:0 12px 30px rgba(120,80,40,.20);
  --shadow-sm:0 6px 18px rgba(120,80,40,.20);
  --maxw:1080px;
  --gray:#eef0f2;          /* 薄いグレー（セクション背景用） */
  --round:"M PLUS Rounded 1c","Hiragino Maru Gothic ProN","Rounded Mplus 1c","Hiragino Sans",sans-serif;
  --sans:"M PLUS Rounded 1c","Hiragino Maru Gothic ProN","Hiragino Sans","Yu Gothic",YuGothic,Meiryo,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);
  line-height:1.7;font-size:16px;-webkit-font-smoothing:antialiased}
@media (max-width:640px){body{font-size:14px;line-height:1.65}}  /* スマホは本文を小さめ・行間詰め */
img{max-width:100%;height:auto;display:block}
a{color:var(--red-dark);text-decoration:none}
.prose a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:var(--round);font-weight:800;line-height:1.4;color:var(--ink);letter-spacing:.01em}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px;position:relative;z-index:1}
.narrow{max-width:760px}
.center{text-align:center}
.mute{color:var(--ink-mute)}

/* ---------- カラーブロック ---------- */
.block{padding:56px 0;position:relative;overflow:hidden}
.block--red{background:var(--red);color:#fff}
.block--gold{background:var(--gold);color:var(--gold-ink)}
.block--cream{background:var(--cream)}
.block--gray{background:var(--gray)}
.block--white{background:#fff}

/* からし色などの帯：左テキスト＋右ボタン */
.band-split{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.band-split .bs-text{flex:1;min-width:260px}
.band-split .bs-text h2{margin:0 0 .35em}
.band-split .bs-text p{margin:0}
@media(max-width:680px){.band-split{flex-direction:column;align-items:stretch}}
.block--red h1,.block--red h2,.block--red h3{color:#fff}
.block--gold h2,.block--gold h3{color:var(--gold-ink)}

/* 市松ボーダー（帯の上下） */
.ichimatsu{height:16px;background:repeating-conic-gradient(var(--c1,#fff) 0% 25%, var(--c2,#f3922e) 0% 50%) 0 0/16px 16px}

/* 波（ブロック間のかわいい区切り） */
.wave{display:block;width:100%;height:34px}

/* ---------- ヘッダー / ナビ ---------- */
.site-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:3px solid var(--gold)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;height:62px}
.brand{font-family:var(--round);font-size:1.2rem;font-weight:800;color:var(--red);display:flex;align-items:center;gap:.4em}
.brand:hover{text-decoration:none}
.brand .mark{font-size:1.1em}
.nav-toggle{display:inline-flex;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:24px;height:3px;background:var(--red);border-radius:3px;transition:.25s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
.site-nav ul{list-style:none;margin:0;padding:0}
.site-nav a{color:var(--ink);font-size:.95rem;font-weight:700;font-family:var(--round)}
.site-nav a:hover{color:var(--red);text-decoration:none}
@media (max-width:880px){
  .site-nav{position:fixed;inset:62px 0 auto 0;background:#fff;border-bottom:3px solid var(--gold);
    box-shadow:var(--shadow);transform:translateY(-130%);transition:transform .3s;max-height:calc(100vh - 62px);overflow:auto}
  .site-nav ul{padding:8px 20px 20px}
  .site-nav li{border-bottom:1px solid var(--line)}
  .site-nav a{display:block;padding:14px 4px;font-size:1.02rem}
}
@media (min-width:881px){.nav-toggle{display:none}.site-nav ul{display:flex;gap:22px;align-items:center}}

/* ---------- 広告表示バー（ファーストビュー・全ページ） ---------- */
.ad-bar{background:var(--cream);color:#6b5e54;font-size:12px;line-height:1.5;
  padding:7px 16px;text-align:center;border-bottom:1px solid var(--line)}
.ad-bar .ad-tag{display:inline-block;background:#5f544c;color:#fff;font-weight:700;
  font-size:11px;padding:1px 9px;border-radius:5px;margin-right:8px;vertical-align:1px}

/* ---------- ヒーロー（赤ブロック） ---------- */
.hero{background:var(--red);color:#fff;position:relative;overflow:hidden}
.hero .wrap{padding:40px 20px 48px}
.hero-top{display:grid;gap:22px;align-items:start}
.hero h1{font-family:var(--round);font-weight:800;font-size:1.35rem;line-height:1.4;margin:.1em 0 .3em;color:#fff;
  text-shadow:0 2px 0 rgba(0,0,0,.08)}
.hero h1 br{display:none}            /* スマホ：改行を無効化して2行に自然折返し */
.hero h1 .pop{color:#ffd84d;display:inline-block}   /* 黄色で目立たせる */
.hero p{font-size:1.05rem;color:#fff;opacity:.97;margin:0 0 1.4em}
.hero .hero-lead{font-size:14px;line-height:1.65;color:#fff;opacity:.97;margin:36px 0 26px;max-width:none}  /* スマホ14px。PCは16px（本文標準と同じ）。.hero pに勝つ詳細度 */
.hero-media{position:relative;isolation:isolate}
/* 手でちぎったような白フチ（ノイズで外縁を揺らす） */
.hero-media::before{content:"";position:absolute;inset:-9px;background:#fff;border-radius:14px;
  filter:url(#deckle);box-shadow:var(--shadow);z-index:0}
.hero-media .pine-deco{position:absolute;right:-10px;bottom:-14px;width:86px;height:auto;z-index:2;filter:drop-shadow(0 3px 5px rgba(0,0,0,.18))}
.hero-media img{position:relative;z-index:1;border-radius:8px;width:100%;aspect-ratio:5/2;object-fit:cover;object-position:center}
.hero .mascot{position:absolute;right:18px;bottom:6px;width:94px;height:auto;z-index:2;filter:drop-shadow(0 6px 8px rgba(0,0,0,.18))}
@media (min-width:881px){
  .hero .wrap{padding:50px 20px 58px}
  .hero-top{grid-template-columns:1.02fr .98fr;gap:30px}
  .hero h1{font-size:2.1rem;line-height:1.5}
  .hero h1 br{display:inline}         /* PC：指定どおり3行に */
  .hero .hero-lead{font-size:16px;line-height:1.7}   /* PCは本文標準と同サイズ */
}

/* ---------- セクション見出し ---------- */
.sec-head{text-align:center;max-width:720px;margin:0 auto 32px}
.sec-head h2{font-size:1.7rem;margin:.15em 0 .3em}
.sec-head .kicker{display:inline-block;background:#fff;color:var(--red);font-family:var(--round);font-weight:800;
  font-size:.8rem;padding:.3em 1em;border-radius:999px;box-shadow:var(--shadow-sm);margin-bottom:.6em}
.block--cream .sec-head .kicker,.block--gray .sec-head .kicker{background:var(--red);color:#fff}
.sec-head p{color:var(--ink-soft);margin:.5em 0 0;font-size:.98rem}
.block--red .sec-head p{color:#fff;opacity:.95}

/* ---------- ボタン ---------- */
.cta{display:inline-flex;align-items:center;justify-content:center;gap:.5em;font-family:var(--round);font-weight:800;
  font-size:1.02rem;padding:15px 30px;border-radius:999px;border:0;cursor:pointer;transition:.18s;box-shadow:var(--shadow-sm);
  background:var(--red);color:#fff;text-decoration:none}
.cta:hover{background:var(--red-dark);text-decoration:none;transform:translateY(-2px)}
.cta--primary{background:var(--red);color:#fff}
.cta--primary:hover{background:var(--red-dark);text-decoration:none;transform:translateY(-2px)}
.cta--white{background:#fff;color:var(--red)}
.cta--white:hover{background:#fff;color:var(--red-dark);text-decoration:none;transform:translateY(-2px)}
.cta--gold{background:var(--gold);color:var(--gold-ink)}
.cta--gold:hover{background:var(--gold-deep);color:#fff;text-decoration:none;transform:translateY(-2px)}
.cta::after{content:"›";font-size:1.3em;line-height:0}
.cta-row{display:flex;gap:12px;flex-wrap:wrap}
.hero .cta-row{justify-content:center}   /* PC・スマホとも中央寄せ */
.cta-note{font-size:.82rem;color:var(--ink-mute);margin-top:.7em}
.block--red .cta-note{color:#fff;opacity:.9}
.hero .cta-note{margin-top:18px;font-size:12px}   /* ボタンと下の注記の隙間＋小さめ */

/* ---------- カード ---------- */
.grid{display:grid;gap:18px}
.grid-2{grid-template-columns:1fr}
.grid-3{grid-template-columns:1fr}
@media (min-width:640px){.grid-2{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:1fr 1fr}}
@media (min-width:920px){.grid-3{grid-template-columns:repeat(3,1fr)}}

.card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;border:2px solid #fff}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);text-decoration:none}
.card .thumb{aspect-ratio:16/10;background:var(--cream);overflow:hidden}
.card .thumb img{width:100%;height:100%;object-fit:cover}
.card .body{padding:16px 18px 20px;display:flex;flex-direction:column;gap:7px;flex:1}
.card h3{font-size:1.12rem;margin:0}
.card p{margin:0;color:var(--ink-soft);font-size:.92rem}
.card .more{margin-top:auto;align-self:flex-end;display:inline-flex;align-items:center;gap:.3em;
  background:#ffe1dd;color:var(--red-dark);font-weight:800;font-family:var(--round);font-size:.88rem;
  padding:.5em 1.1em;border-radius:999px;transition:.18s}
.card:hover .more{background:var(--red);color:#fff}

/* ポイント風の数字カード */
.statcard{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:22px 20px;text-align:center}
.statcard .lab{font-family:var(--round);font-weight:800;color:var(--ink);font-size:1rem;margin-bottom:.3em}
.statcard .big{font-family:var(--round);font-weight:800;color:var(--red);font-size:2.4rem;line-height:1.1}
.statcard .big small{font-size:1rem;color:var(--ink-soft)}
.statcard .sub{font-size:.85rem;color:var(--ink-soft);margin-top:.3em}

/* 店舗ボタン（丸い） */
.shopgrid{display:grid;gap:14px;grid-template-columns:1fr 1fr}
@media (min-width:720px){.shopgrid{grid-template-columns:repeat(4,1fr)}}
.shopbtn{display:flex;flex-direction:column;align-items:center;gap:8px;background:#fff;border-radius:var(--radius);
  padding:18px 12px;box-shadow:var(--shadow-sm);transition:.2s;text-align:center}
.shopbtn:hover{transform:translateY(-3px);box-shadow:var(--shadow);text-decoration:none}
.shopbtn .ic{width:54px;height:54px;border-radius:50%;background:var(--cream);display:grid;place-items:center;
  font-family:var(--round);font-weight:800;color:var(--red);font-size:1.3rem}
.shopbtn b{color:var(--ink);font-size:.98rem;font-family:var(--round)}
.shopbtn span{color:var(--ink-mute);font-size:.78rem}

/* ---------- ランキング ---------- */
.rank{display:flex;gap:16px;padding:16px;border-radius:var(--radius-sm);background:#fff;box-shadow:var(--shadow-sm);align-items:stretch;transition:.2s;position:relative}
.rank:hover{transform:translateY(-3px);box-shadow:var(--shadow);text-decoration:none}
.rank .rbadge{position:absolute;top:8px;left:8px;z-index:3;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;
  font-family:var(--round);font-weight:800;color:#fff;background:var(--ink-mute);font-size:1.15rem;box-shadow:0 2px 6px rgba(0,0,0,.2)}
.rank .rbadge--1{background:var(--gold)}
.rank .rbadge--2{background:var(--pink)}
.rank .rbadge--3{background:var(--green)}
.rank .thumb{flex:none;width:140px;align-self:flex-start;aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;background:var(--cream)}
.rank .thumb img{width:100%;height:100%;object-fit:cover}
.rank .meta{flex:1;min-width:0;display:flex;flex-direction:column}
.rank .meta h3{margin:.1em 0 .3em;font-size:1.1rem}
.rank .meta p{margin:0;font-size:.9rem;color:var(--ink-soft)}
.rank .price{font-family:var(--round);color:var(--red);font-weight:800;font-size:1.2rem;margin:.5em 0 .55em}
.rank-go{align-self:flex-end;margin-top:auto;display:inline-flex;align-items:center;gap:.15em;background:var(--red);color:#fff;font-family:var(--round);
  font-weight:800;font-size:.82rem;padding:.5em 1.15em;border-radius:999px;white-space:nowrap;box-shadow:0 0 0 5px #fff,0 8px 16px rgba(232,57,42,.22)}
.rank:hover .rank-go{background:var(--red-dark)}
@media (max-width:520px){.rank .thumb{width:120px}}

/* ---------- 比較表 / タイムライン ---------- */
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius);box-shadow:var(--shadow-sm)}
table.tbl{width:100%;border-collapse:collapse;font-size:.92rem;background:#fff;min-width:560px;border-radius:var(--radius);overflow:hidden}
table.tbl th,table.tbl td{padding:13px 15px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}
table.tbl thead th{background:var(--red);color:#fff;font-family:var(--round);font-weight:800;white-space:nowrap}
table.tbl tbody tr:nth-child(even){background:var(--cream)}
table.tbl .store{font-weight:800;white-space:nowrap;font-family:var(--round)}
.pill{display:inline-block;font-size:.76rem;font-weight:800;font-family:var(--round);padding:.2em .7em;border-radius:999px;background:#ffe1dd;color:var(--red-dark)}
.pill--gold{background:#fcefcf;color:var(--gold-deep)}
.pill--ok{background:#dff3e6;color:#1f7a4d}

/* ---------- 匠本舗おすすめ（オレンジ帯） ---------- */
.promo{border-radius:var(--radius);background:var(--orange);color:#fff;padding:26px 24px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.promo .tag{display:inline-block;background:#fff;color:var(--orange);font-family:var(--round);font-weight:800;font-size:.82rem;padding:.3em 1em;border-radius:999px;margin-bottom:.6em}
.promo h3{color:#fff;margin:.15em 0 .4em;font-size:1.35rem}
.promo p{margin:0 0 1.1em;color:#fff;opacity:.97;font-size:.95rem}
.promo .mute,.promo .note{color:#fff;opacity:.92;background:transparent}
.promo-grid{display:grid;gap:18px;align-items:center}
.promo-img{position:relative;isolation:isolate}
.promo-img::before{content:"";position:absolute;inset:-8px;background:#fff;border-radius:12px;filter:url(#deckle);box-shadow:var(--shadow-sm);z-index:0}
.promo-img img{position:relative;z-index:1;border-radius:7px;width:100%;aspect-ratio:16/10;object-fit:cover}
.promo-body .mute{display:block;margin-top:.6em}
@media(min-width:720px){.promo-grid{grid-template-columns:.9fr 1.1fr}}

/* ---------- 注記 / 早わかり ---------- */
.note{font-size:.83rem;color:var(--ink-soft);background:var(--cream);border-radius:var(--radius-sm);padding:12px 16px;margin:14px 0}
.callout{background:#fff;border:3px dashed var(--gold);border-radius:var(--radius);padding:20px 22px;margin:20px 0}
.callout h3{margin:0 0 .6em;font-size:1.12rem;color:var(--red)}
.callout dl{margin:0;display:grid;grid-template-columns:auto 1fr;gap:8px 16px;font-size:.93rem}
.callout dt{color:var(--gold-deep);white-space:nowrap;font-family:var(--round);font-weight:800}
.callout dd{margin:0;font-weight:700;color:var(--ink)}

/* ---------- FAQ ---------- */
.faq details{border:2px solid var(--cream);border-radius:var(--radius-sm);background:#fff;margin-bottom:10px;overflow:hidden}
.faq summary{cursor:pointer;list-style:none;padding:16px 18px;font-weight:800;font-family:var(--round);display:flex;justify-content:space-between;gap:1em;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"＋";color:var(--red);font-weight:800;flex:none}
.faq details[open] summary::after{content:"−"}
.faq details[open] summary{background:var(--cream)}
.faq .ans{padding:15px 18px;color:var(--ink-soft);font-size:.94rem}

/* ---------- パンくず ---------- */
.crumbs{font-size:.8rem;color:var(--ink-mute);padding:14px 0}
.crumbs a{color:var(--ink-mute)}
.crumbs a:hover{color:var(--red)}
.crumbs span{margin:0 .4em}

/* ---------- 本文（記事） ---------- */
.prose h2{font-family:var(--round);font-size:1.5rem;margin:1.8em 0 .6em;color:var(--ink);
  background:var(--cream);padding:.5em .7em;border-radius:var(--radius-sm);border-left:7px solid var(--red)}
.prose h3{font-family:var(--round);font-size:1.2rem;margin:1.5em 0 .5em;color:var(--red-dark)}
.prose p{margin:0 0 1.2em}
.prose ul,.prose ol{margin:0 0 1.4em;padding-left:1.3em}
.prose li{margin:.35em 0}
.prose img{border-radius:var(--radius);box-shadow:var(--shadow-sm);margin:1.2em 0}
.prose strong{color:var(--red-dark)}

/* ---------- フッター ---------- */
.site-footer{background:#fff;color:var(--ink-soft);margin-top:0;border-top:1px solid var(--line)}
.site-footer .wrap{padding:40px 20px 28px}
.site-footer .cols{display:grid;gap:24px;grid-template-columns:1fr}
@media(min-width:680px){.site-footer .cols{grid-template-columns:2fr 1fr 1fr}}
.site-footer h4{color:var(--ink);font-family:var(--round);font-size:1rem;margin:0 0 .8em}
.site-footer a{color:var(--ink-soft)}
.site-footer a:hover{color:var(--red-dark)}
.site-footer ul{list-style:none;margin:0;padding:0;font-size:.9rem;line-height:2}
.site-footer .copyright{border-top:1px solid var(--line);margin-top:26px;padding-top:18px;font-size:.8rem;color:var(--ink-mute)}
.site-footer .disc{font-size:.8rem;color:var(--ink-mute);line-height:1.8}

/* ---------- 飾り（イラスト） ---------- */
.deco{position:absolute;pointer-events:none;user-select:none;opacity:.95;z-index:0}
.section-deco{position:relative}

/* ---------- ユーティリティ ---------- */
.btn-wide{display:block;width:100%;text-align:center}
.stack>*+*{margin-top:1rem}
.hr{height:2px;background:var(--line);border:0;margin:34px 0}
