/* =========================================================
   ユメックスオート緑ヶ丘店 初夏フェア LP
   Design system — calm green / warm orange / cream
   Aligned with youmex.co.jp tone (trustworthy, local)
   ========================================================= */

:root{
  --green:#1f6b46;          /* primary */
  --green-deep:#16472f;
  --green-mid:#2f7d4f;
  --green-soft:#e9f1ea;     /* tint bg */
  --green-line:#cfe2d4;
  --orange:#ef9a30;         /* accent / energy */
  --orange-dark:#d97a1f;
  --orange-soft:#fdf1df;
  --cream:#faf6ee;          /* warm base alt */
  --cream-deep:#f3ecdd;
  --pink:#d70071;           /* YOUMEX brand mark accent */
  --line:#06c755;           /* LINE official */
  --line-dark:#05a948;
  --ink:#27322d;
  --ink-soft:#5e6b64;
  --ink-faint:#8a958f;
  --white:#ffffff;
  --hair:#e7e3da;
  --shadow-sm:0 4px 16px rgba(31,107,70,.07);
  --shadow:0 12px 38px rgba(31,107,70,.10);
  --shadow-lg:0 22px 60px rgba(22,71,47,.16);
  --radius:20px;
  --radius-sm:14px;
  --maxw:1080px;
  --narrow:760px;
  --gothic:"Zen Kaku Gothic New",system-ui,sans-serif;
  --mincho:"Shippori Mincho",serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--gothic);
  color:var(--ink);
  background:var(--white);
  line-height:1.85;
  font-size:16px;
  letter-spacing:.01em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0;line-height:1.4;font-weight:700}
p{margin:0}
ul{margin:0;padding:0;list-style:none}
strong{font-weight:700}

.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}
.wrap.narrow{max-width:var(--narrow)}
.mincho{font-family:var(--mincho)}
.o{color:var(--orange-dark)}
.accent{color:var(--green)}
.pinkmark{color:var(--pink)}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* =========================================================
   HEADER
   ========================================================= */
header.site{
  position:sticky;top:0;z-index:60;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--hair);
}
.hdr-inner{
  max-width:var(--maxw);margin:0 auto;padding:10px 22px;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
}
.logo{display:flex;align-items:center;gap:11px;min-width:0}
.logo-img{height:26px;width:auto}
.logo-txt{display:flex;flex-direction:column;line-height:1.25;min-width:0}
.logo-txt b{font-size:.86rem;font-weight:700;color:var(--ink);white-space:nowrap}
.logo-txt small{font-size:.66rem;color:var(--green);font-weight:600;letter-spacing:.04em}
.hdr-cta{
  flex-shrink:0;
  background:var(--green);color:#fff;font-weight:700;font-size:.82rem;
  padding:9px 16px;border-radius:999px;white-space:nowrap;
  transition:background .2s,transform .2s;
}
.hdr-cta:hover{background:var(--green-deep);transform:translateY(-1px)}

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative;
  background:
    radial-gradient(120% 90% at 85% -10%, #f4ddc6 0%, rgba(244,221,198,0) 55%),
    linear-gradient(180deg,var(--cream) 0%, #f4efe3 100%);
  padding:46px 0 58px;
  overflow:hidden;
}
.hero::before{
  content:"";position:absolute;right:-120px;top:-120px;width:360px;height:360px;
  background:radial-gradient(circle,rgba(215,0,113,.07),rgba(215,0,113,0) 70%);
  border-radius:50%;pointer-events:none;
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:42px;align-items:center;position:relative}
.hero-copy{min-width:0}

.eyebrow{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.tag{
  font-size:.74rem;font-weight:700;letter-spacing:.02em;white-space:nowrap;
  padding:6px 13px;border-radius:999px;
  background:#fff;border:1px solid var(--green-line);color:var(--green);
  display:inline-flex;align-items:center;gap:6px;
}
.tag.solid{background:var(--green);color:#fff;border-color:var(--green)}
.tag.pink{background:#fff;border-color:#f3bcd6;color:var(--pink)}

.hero h1{
  font-family:var(--mincho);
  font-size:clamp(1.9rem,5.6vw,3.05rem);
  line-height:1.34;font-weight:800;color:var(--green-deep);
  letter-spacing:.01em;margin-bottom:6px;text-wrap:balance;
}
.hero h1 .u{
  background:linear-gradient(transparent 64%, #fbe0a3 64%);
  padding:0 .08em;
}
.hero .ttl-sub{
  display:block;font-family:var(--gothic);font-weight:700;
  font-size:clamp(1.05rem,2.8vw,1.45rem);color:var(--ink);
  margin-top:10px;line-height:1.5;
}

.date-strip{
  display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;
  margin:20px 0 16px;padding:14px 18px;
  background:#fff;border-radius:var(--radius-sm);
  border:1px solid var(--hair);box-shadow:var(--shadow-sm);
}
.date-strip .d-main{display:inline-flex;align-items:baseline;gap:2px;white-space:nowrap}
.date-strip .d-day{font-family:var(--mincho);font-weight:800;font-size:clamp(1.4rem,4vw,1.95rem);color:var(--green);letter-spacing:.01em}
.date-strip .d-dow{font-weight:700;font-size:1rem;color:var(--orange-dark)}
.date-strip .d-time{font-weight:600;color:var(--ink-soft);font-size:.92rem;white-space:nowrap}
.date-strip .d-rain{margin-left:auto;font-size:.74rem;font-weight:700;color:var(--green);background:var(--green-soft);padding:5px 11px;border-radius:999px}

.lead{font-size:clamp(.98rem,2.3vw,1.08rem);color:var(--ink);font-weight:500;margin-bottom:14px;line-height:1.9;text-wrap:pretty}
.lead b{color:var(--orange-dark);font-weight:700}

.hero-quick{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:18px 0 22px}
.hero-quick .q{background:#fff;border:1px solid var(--hair);border-radius:12px;padding:11px 8px;text-align:center}
.hero-quick .q .ic{width:22px;height:22px;color:var(--green);margin:0 auto 4px}
.hero-quick .q small{display:block;font-size:.66rem;color:var(--ink-faint);font-weight:600;margin-bottom:1px}
.hero-quick .q b{display:block;font-size:.82rem;color:var(--ink);font-weight:700;line-height:1.3}

/* Hero visual */
.hero-visual{position:relative}
.hero-photo{
  position:relative;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-lg);background:var(--green-soft);
  border:6px solid #fff;
}
.photo-ph{
  aspect-ratio:4/3.2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  background:
    repeating-linear-gradient(135deg,rgba(31,107,70,.05) 0 14px,rgba(31,107,70,0) 14px 28px),
    linear-gradient(160deg,#eef4ee,#e3eee6);
  color:var(--green);text-align:center;padding:24px;
}
.photo-ph svg{width:46px;height:46px;opacity:.7}
.photo-ph span{font-size:.82rem;font-weight:700;color:var(--green-mid);letter-spacing:.02em;line-height:1.6}
.photo-ph small{font-size:.7rem;color:var(--ink-faint);font-weight:500}
.hero-float{
  position:absolute;left:-14px;bottom:-18px;
  background:var(--orange);color:#fff;font-weight:800;
  font-family:var(--mincho);font-size:.92rem;line-height:1.35;text-align:center;
  padding:14px 16px;border-radius:16px;box-shadow:var(--shadow);
  border:3px solid #fff;
}
.hero-float .y{display:block;font-size:1.5rem;line-height:1}
.hero-float .s{display:block;font-size:.66rem;font-weight:700;opacity:.92;letter-spacing:.04em}

/* =========================================================
   BUTTONS / CTA
   ========================================================= */
.cta-stack{display:flex;flex-direction:column;align-items:stretch;gap:12px;max-width:430px}
.cta-stack.center{margin-left:auto;margin-right:auto}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-weight:800;font-size:1.02rem;padding:16px 22px;border-radius:14px;
  transition:transform .18s,box-shadow .18s,background .18s;cursor:pointer;
  text-align:center;line-height:1.35;
}
.btn .bimg{width:24px;height:24px;border-radius:6px}
.btn-line{background:var(--line);color:#fff;box-shadow:0 8px 22px rgba(6,199,85,.32)}
.btn-line:hover{background:var(--line-dark);transform:translateY(-2px);box-shadow:0 12px 26px rgba(6,199,85,.4)}
.btn-line .sm{display:block;font-size:.7rem;font-weight:600;opacity:.92;margin-top:2px}
.btn-line .line-ico{display:inline-flex}
.btn-ghost{background:#fff;color:var(--green);border:1.5px solid var(--green-line)}
.btn-ghost:hover{background:var(--green-soft)}
.btn-ig{background:linear-gradient(135deg,#fa7e1e,#d62976 50%,#962fbf);color:#fff}
.btn-ig:hover{transform:translateY(-2px)}
.subcta{font-size:.86rem;color:var(--ink-soft);text-align:center;margin-top:14px;line-height:1.8}
.subcta .tel{color:var(--green);font-weight:800;font-size:1.02rem;letter-spacing:.02em}
.subcta a{text-decoration:underline;text-underline-offset:2px}
.cta-note{font-size:.78rem;color:var(--ink-faint);text-align:center;margin-top:8px}

/* =========================================================
   SECTION BASICS
   ========================================================= */
.sec{padding:64px 0}
.sec.alt{background:var(--cream)}
.sec.tint{background:var(--green-soft)}
.sec.green{background:linear-gradient(160deg,var(--green) 0%,var(--green-deep) 100%);color:#fff}
.sec-head{text-align:center;margin-bottom:38px}
.kicker{
  display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.22em;white-space:nowrap;
  color:var(--orange-dark);margin-bottom:12px;
}
.sec.green .kicker{color:#ffd79a}
.sec-head h2{
  font-family:var(--mincho);font-weight:800;
  font-size:clamp(1.55rem,4.4vw,2.3rem);line-height:1.42;color:var(--green-deep);
  text-wrap:balance;
}
.sec.green .sec-head h2{color:#fff}
.sec-head .lede{margin-top:14px;color:var(--ink-soft);font-size:.98rem;text-wrap:pretty}
.sec.green .sec-head .lede{color:rgba(255,255,255,.85)}
.ic{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}

/* =========================================================
   SECTION 2 — WHAT YOU CAN DO (できること)
   ========================================================= */
.do-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.do-card{
  background:#fff;border:1px solid var(--hair);border-radius:var(--radius);
  padding:26px 22px;box-shadow:var(--shadow-sm);
  transition:transform .25s,box-shadow .25s;position:relative;overflow:hidden;
}
.do-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.do-card .num{
  font-family:var(--mincho);font-weight:800;font-size:.8rem;color:var(--orange-dark);
  letter-spacing:.1em;
}
.do-card .di{
  width:54px;height:54px;border-radius:15px;display:flex;align-items:center;justify-content:center;
  background:var(--green-soft);color:var(--green);margin:12px 0 14px;
}
.do-card .di .ic{width:28px;height:28px;stroke-width:1.6}
.do-card h3{font-size:1.12rem;font-weight:700;color:var(--green-deep);margin-bottom:8px;line-height:1.5}
.do-card p{font-size:.9rem;color:var(--ink-soft);line-height:1.85}
.do-card .badge{
  display:inline-block;margin-top:12px;font-size:.72rem;font-weight:700;
  color:var(--orange-dark);background:var(--orange-soft);padding:4px 11px;border-radius:999px;
}
.do-card.fun{background:linear-gradient(160deg,#fff,var(--orange-soft))}
.do-card.fun .di{background:#fce6cb;color:var(--orange-dark)}

/* =========================================================
   SECTION 3 — CONCERNS (モヤモヤ)
   ========================================================= */
.concern-intro{text-align:center;max-width:640px;margin:0 auto 34px;color:var(--ink-soft);font-size:1rem;line-height:1.95}
.concern-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;max-width:840px;margin:0 auto}
.concern{
  background:#fff;border:1px solid var(--hair);border-radius:var(--radius-sm);
  padding:20px 22px 20px 56px;position:relative;box-shadow:var(--shadow-sm);
  font-size:.96rem;color:var(--ink);line-height:1.75;font-weight:500;
}
.concern::before{
  content:"“";position:absolute;left:18px;top:8px;
  font-family:var(--mincho);font-size:2.4rem;color:var(--green-line);line-height:1;
}
.concern b{color:var(--green);font-weight:700}
.concern-resolve{
  text-align:center;margin:34px auto 0;max-width:660px;
  background:var(--green-soft);border-radius:var(--radius);padding:28px 26px;
}
.concern-resolve p{font-size:1.05rem;font-weight:700;color:var(--green-deep);line-height:1.7;font-family:var(--mincho)}
.concern-resolve small{display:block;margin-top:8px;font-size:.9rem;color:var(--ink-soft);font-weight:500;font-family:var(--gothic)}

/* =========================================================
   SECTION 4 — WHY YOUMEX (reasons, green band)
   ========================================================= */
.reason-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.reason{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);
  border-radius:var(--radius);padding:24px 24px;display:flex;gap:16px;align-items:flex-start;
  backdrop-filter:blur(2px);
}
.reason .rn{
  flex-shrink:0;width:42px;height:42px;border-radius:12px;
  background:var(--orange);color:#fff;font-family:var(--mincho);font-weight:800;
  display:flex;align-items:center;justify-content:center;font-size:1.1rem;
}
.reason h4{font-size:1.08rem;color:#fff;margin-bottom:7px;line-height:1.5}
.reason p{font-size:.9rem;color:rgba(255,255,255,.82);line-height:1.85}
.reason p strong{color:#ffe3b3;font-weight:700}
.why-foot{
  text-align:center;margin-top:32px;color:rgba(255,255,255,.92);
  font-family:var(--mincho);font-size:1.1rem;font-weight:600;line-height:1.7;
}
.why-stat{display:flex;justify-content:center;gap:30px;flex-wrap:wrap;margin-top:30px}
.why-stat .st{text-align:center}
.why-stat .st b{display:block;font-family:var(--mincho);font-weight:800;font-size:2.2rem;color:#ffd79a;line-height:1}
.why-stat .st small{display:block;font-size:.78rem;color:rgba(255,255,255,.8);margin-top:6px;font-weight:600}

/* =========================================================
   SECTION 5 — AUCTION (white base, bordered, accent)
   ========================================================= */
.auction{background:linear-gradient(180deg,#fff 0%,var(--cream) 100%)}
.auc-head{text-align:center;margin-bottom:30px}
.auc-flag{
  display:inline-flex;align-items:center;gap:8px;white-space:nowrap;
  background:var(--green-deep);color:#fff;font-weight:700;font-size:.78rem;letter-spacing:.08em;
  padding:8px 18px;border-radius:999px;margin-bottom:18px;
}
.auc-flag .dot{width:7px;height:7px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 4px rgba(239,154,48,.3)}
.auc-price-row{
  display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap;
  margin:6px 0 10px;
}
.auc-price{
  font-family:var(--mincho);font-weight:800;color:var(--green);
  font-size:clamp(2.6rem,9vw,4.4rem);line-height:1;letter-spacing:.01em;
  display:inline-flex;align-items:baseline;gap:2px;
}
.auc-price .yen{font-size:.42em;color:var(--orange-dark)}
.auc-price .st{font-size:.26em;color:var(--ink);font-weight:700;font-family:var(--gothic);margin-left:6px}
.auc-sub{text-align:center;color:var(--ink-soft);font-size:.98rem;max-width:560px;margin:0 auto 22px;line-height:1.85}
.auc-times{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:8px}
.auc-pill{
  display:inline-flex;align-items:center;gap:9px;background:#fff;white-space:nowrap;
  border:1.5px solid var(--green-line);border-radius:999px;padding:11px 18px;
  font-weight:700;color:var(--green-deep);font-size:.92rem;box-shadow:var(--shadow-sm);
}
.auc-pill b{color:var(--orange-dark)}
.auc-pill .ic{color:var(--green)}

/* auction detail cards */
.auc-cols{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:34px}
.auc-box{
  background:#fff;border:1px solid var(--hair);border-radius:var(--radius);
  padding:26px 26px;box-shadow:var(--shadow-sm);
}
.auc-box h3{display:flex;align-items:center;gap:10px;font-size:1.08rem;color:var(--green-deep);margin-bottom:14px}
.auc-box h3 .ic{color:var(--orange-dark);width:22px;height:22px}
.auc-box ul li{
  position:relative;padding:8px 0 8px 24px;font-size:.92rem;color:var(--ink);line-height:1.8;
  border-bottom:1px dashed var(--hair);
}
.auc-box ul li:last-child{border-bottom:none}
.auc-box ul li::before{content:"";position:absolute;left:4px;top:15px;width:8px;height:8px;border-radius:50%;background:var(--green-mid)}
.auc-box.rules dl div{display:grid;grid-template-columns:88px 1fr;gap:10px;padding:11px 0;border-bottom:1px dashed var(--hair);align-items:start}
.auc-box.rules dl div:last-child{border-bottom:none}
.auc-box.rules dt{font-weight:700;color:var(--green);font-size:.9rem}
.auc-box.rules dd{font-size:.9rem;color:var(--ink-soft);line-height:1.75}
.auc-box.rules dd strong{color:var(--ink);font-weight:700}

.auc-caution{
  margin-top:18px;background:var(--cream-deep);border:1px solid #e3d8bf;border-radius:var(--radius);
  padding:22px 24px;
}
.auc-caution .ct{display:flex;align-items:center;gap:9px;font-weight:700;color:var(--orange-dark);margin-bottom:12px;font-size:.96rem}
.auc-caution ul li{position:relative;padding:6px 0 6px 20px;font-size:.84rem;color:var(--ink-soft);line-height:1.75}
.auc-caution ul li::before{content:"※";position:absolute;left:0;top:6px;color:var(--orange-dark);font-weight:700}
.auc-caution ul li strong{color:var(--ink);font-weight:700}

/* cars */
.cars-label{text-align:center;margin:40px 0 18px}
.cars-label .tg{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:var(--green);background:var(--green-soft);padding:8px 16px;border-radius:999px;font-size:.86rem}
.cars-label p{margin-top:10px;color:var(--ink-soft);font-size:.92rem}
.car-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.car-card{background:#fff;border:1px solid var(--hair);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .25s,box-shadow .25s}
.car-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.car-photo{position:relative;aspect-ratio:16/10;background:linear-gradient(160deg,#eef4ee,#e3eee6);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;color:var(--green)}
.car-photo svg{width:52px;height:52px;opacity:.6}
.car-photo span{font-size:.78rem;font-weight:700;color:var(--green-mid)}
.car-ribbon{position:absolute;top:14px;left:14px;display:inline-flex;align-items:center;gap:6px;background:var(--orange);color:#fff;font-weight:700;font-size:.78rem;padding:6px 13px;border-radius:999px;box-shadow:var(--shadow-sm)}
.car-ribbon .ic{width:15px;height:15px;color:#fff}
.car-body{padding:20px 22px 22px}
.car-name{font-family:var(--mincho);font-weight:800;font-size:1.3rem;color:var(--green-deep);line-height:1.3}
.car-grade{font-size:.86rem;color:var(--ink-soft);font-weight:600;margin:3px 0 14px}
.spec{width:100%;border-collapse:collapse;margin-bottom:16px}
.spec th,.spec td{text-align:left;padding:7px 0;font-size:.82rem;border-bottom:1px solid var(--hair);vertical-align:top}
.spec th{color:var(--ink-faint);font-weight:600;width:88px;white-space:nowrap}
.spec td{color:var(--ink);font-weight:600}
.spec tr.equip td{font-weight:500;color:var(--ink-soft);font-size:.78rem;line-height:1.6}
.price-box{background:var(--green-soft);border-radius:var(--radius-sm);padding:14px 16px}
.price-box .row{display:flex;justify-content:space-between;font-size:.86rem;color:var(--ink-soft);padding:3px 0}
.price-box .row.total{border-top:1px solid var(--green-line);margin-top:6px;padding-top:9px;color:var(--ink);font-weight:700}
.price-box .row.total .big{font-family:var(--mincho);font-weight:800;font-size:1.3rem;color:var(--green)}
.price-box .plan{text-align:right;font-size:.72rem;color:var(--ink-faint);margin-top:3px}

/* =========================================================
   SECTION 6 — BENEFITS (特典)
   ========================================================= */
.ben-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.ben{background:#fff;border:1px solid var(--hair);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.ben-head{padding:20px 22px 16px;border-bottom:2px solid var(--green-soft);background:linear-gradient(160deg,#fff,#fbfdfb)}
.ben-head small{display:block;font-size:.7rem;font-weight:700;color:var(--orange-dark);letter-spacing:.04em;margin-bottom:6px}
.ben-head b{font-size:1.16rem;font-weight:700;color:var(--green-deep);font-family:var(--mincho)}
.ben-list{padding:16px 22px 22px;display:flex;flex-direction:column;gap:0}
.ben-list li{position:relative;padding:8px 0 8px 24px;font-size:.9rem;color:var(--ink);line-height:1.7;border-bottom:1px dashed var(--hair)}
.ben-list li:last-child{border-bottom:none}
.ben-list li::before{content:"";position:absolute;left:4px;top:15px;width:8px;height:8px;border-radius:50%;background:var(--orange)}
.ben-list li.big-prize{font-weight:700;color:var(--green-deep)}
.ben-list li.big-prize::before{background:var(--green)}
.ben-list .qty{font-size:.74rem;color:var(--ink-faint);font-weight:600}
.ben-list li b{color:var(--green);font-weight:700}
.ben .ben-cta{padding:0 22px 22px;display:flex;flex-direction:column;gap:8px;margin-top:auto}
.ben .ben-cta .btn{font-size:.9rem;padding:12px 16px}

.food-band{
  margin-top:24px;background:linear-gradient(160deg,var(--orange-soft),#fff);
  border:1px solid #f0dcc0;border-radius:var(--radius);padding:26px 26px;text-align:center;
}
.food-band h3{display:inline-flex;align-items:center;gap:10px;font-size:1.2rem;color:var(--orange-dark);margin-bottom:8px;font-family:var(--mincho)}
.food-band p{color:var(--ink-soft);font-size:.92rem;margin-bottom:16px}
.food-items{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.food-items span{background:#fff;border:1px solid #f0dcc0;color:var(--orange-dark);font-weight:700;font-size:.86rem;padding:8px 18px;border-radius:999px}
.ben-note{text-align:center;font-size:.78rem;color:var(--ink-faint);margin-top:20px;line-height:1.7}

/* =========================================================
   SECTION 7 — FLOW (当日の流れ) green band
   ========================================================= */
.flow{display:flex;flex-direction:column;gap:0;max-width:680px;margin:0 auto}
.fstep{display:flex;gap:20px;position:relative;padding-bottom:26px}
.fstep:not(:last-child)::after{content:"";position:absolute;left:21px;top:46px;bottom:0;width:2px;background:rgba(255,255,255,.25)}
.fstep .sn{
  flex-shrink:0;width:44px;height:44px;border-radius:50%;
  background:#fff;color:var(--green);font-family:var(--mincho);font-weight:800;font-size:1.2rem;
  display:flex;align-items:center;justify-content:center;z-index:1;box-shadow:0 4px 12px rgba(0,0,0,.15);
}
.fstep .fb{padding-top:4px}
.fstep h4{color:#fff;font-size:1.08rem;margin-bottom:6px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.fstep h4 .opt{font-size:.68rem;font-weight:700;background:var(--orange);color:#fff;padding:3px 9px;border-radius:999px;white-space:nowrap}
.fstep p{color:rgba(255,255,255,.85);font-size:.9rem;line-height:1.85}
.fstep p .em{color:#ffe3b3;font-weight:700}
.flow-cta{margin-top:14px}

/* =========================================================
   SECTION 8 — ACCESS
   ========================================================= */
.access-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:26px;align-items:stretch}
.map-box{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3;border:5px solid #fff;background:var(--green-soft)}
.map-box iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.access-info{background:#fff;border:1px solid var(--hair);border-radius:var(--radius);padding:26px 28px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;justify-content:center}
.access-info .store{font-family:var(--mincho);font-weight:800;font-size:1.25rem;color:var(--green-deep);margin-bottom:16px;line-height:1.4}
.access-info dl{display:grid;grid-template-columns:74px 1fr;gap:6px 14px;padding:12px 0;border-bottom:1px solid var(--hair);margin:0}
.access-info dl:last-of-type{border-bottom:none}
.access-info dt{font-size:.78rem;font-weight:700;color:var(--green);padding-top:2px}
.access-info dd{margin:0;font-size:.92rem;color:var(--ink);line-height:1.7;font-weight:500}
.access-info dd .tel{color:var(--green);font-weight:800;font-size:1.1rem;letter-spacing:.02em}
.map-link{display:inline-flex;align-items:center;gap:6px;color:var(--green);font-weight:700;text-decoration:underline;text-underline-offset:2px;font-size:.88rem;margin-top:6px}

/* =========================================================
   SECTION 9 — FAQ
   ========================================================= */
.faq-list{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq{background:#fff;border:1px solid var(--hair);border-radius:var(--radius-sm);overflow:hidden;box-shadow:var(--shadow-sm)}
.faq summary{
  list-style:none;cursor:pointer;padding:18px 52px 18px 22px;position:relative;
  font-weight:700;font-size:.96rem;color:var(--green-deep);line-height:1.6;display:flex;gap:10px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary .q{color:var(--orange-dark);font-family:var(--mincho);font-weight:800;flex-shrink:0}
.faq summary::after{
  content:"";position:absolute;right:22px;top:50%;width:11px;height:11px;
  border-right:2px solid var(--green);border-bottom:2px solid var(--green);
  transform:translateY(-65%) rotate(45deg);transition:transform .25s;
}
.faq[open] summary::after{transform:translateY(-35%) rotate(225deg)}
.faq .ans{padding:0 22px 20px 44px;font-size:.9rem;color:var(--ink-soft);line-height:1.9}
.faq .ans strong{color:var(--green);font-weight:700}

/* =========================================================
   FINAL CTA
   ========================================================= */
.final{
  background:linear-gradient(160deg,var(--green) 0%,var(--green-deep) 100%);
  color:#fff;padding:70px 0 76px;text-align:center;position:relative;overflow:hidden;
}
.final::before{content:"";position:absolute;left:-100px;bottom:-100px;width:320px;height:320px;background:radial-gradient(circle,rgba(239,154,48,.18),transparent 70%);border-radius:50%}
.final::after{content:"";position:absolute;right:-90px;top:-90px;width:280px;height:280px;background:radial-gradient(circle,rgba(215,0,113,.14),transparent 70%);border-radius:50%}
.final .fdate{display:inline-block;font-weight:700;font-size:.84rem;letter-spacing:.1em;color:#ffd79a;background:rgba(255,255,255,.1);padding:7px 18px;border-radius:999px;margin-bottom:18px;position:relative}
.final h2{font-family:var(--mincho);font-weight:800;font-size:clamp(1.6rem,5vw,2.5rem);line-height:1.45;margin-bottom:14px;position:relative;text-wrap:balance}
.final .sub{color:rgba(255,255,255,.86);font-size:1rem;max-width:560px;margin:0 auto 26px;line-height:1.9;position:relative}
.final-merit{display:inline-flex;flex-direction:column;gap:4px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:var(--radius);padding:20px 28px;margin-bottom:28px;position:relative}
.final-merit .star{font-family:var(--mincho);font-weight:700;font-size:1.08rem;color:#fff}
.final-merit .pts{font-size:.88rem;color:rgba(255,255,255,.82)}
.final-merit .note{font-size:.76rem;color:rgba(255,255,255,.62);margin-top:4px}
.final .cta-stack{position:relative;margin-left:auto;margin-right:auto}
.final .btn-line{box-shadow:0 10px 30px rgba(0,0,0,.25)}
.final .subcta{color:rgba(255,255,255,.78)}
.final .subcta .tel{color:#fff}
.final .subcta a{color:#ffd79a}

/* =========================================================
   FOOTER
   ========================================================= */
footer.site{background:var(--green-deep);color:rgba(255,255,255,.7);text-align:center;padding:40px 0 110px}
footer.site .footer-logo{height:30px;width:auto;margin:0 auto 16px;filter:brightness(0) invert(1);opacity:.92}
footer.site p{font-size:.86rem;line-height:1.7}
footer.site .tagline{opacity:.6;margin-top:4px;font-size:.78rem}
footer.site .fl{margin-top:16px;font-size:.78rem;display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
footer.site .fl a{text-decoration:underline;text-underline-offset:2px;opacity:.85}
footer.site .copy{opacity:.5;margin-top:16px;font-size:.74rem}

/* =========================================================
   STICKY MOBILE CTA
   ========================================================= */
.sticky-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:80;display:none;gap:10px;
  padding:9px 12px calc(9px + env(safe-area-inset-bottom));
  background:rgba(255,255,255,.95);backdrop-filter:blur(8px);border-top:1px solid var(--hair);
  box-shadow:0 -6px 22px rgba(0,0,0,.08);
}
.sticky-cta .s-book{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;
  background:var(--line);color:#fff;font-weight:800;font-size:.92rem;border-radius:12px;padding:9px;
}
.sticky-cta .s-book .line-ico{display:inline-flex;align-items:center;gap:7px}
.sticky-cta .s-book .bimg{width:18px;height:18px;border-radius:4px;display:inline-block;vertical-align:middle}
.sticky-cta .s-book small{font-size:.6rem;font-weight:600;opacity:.92}
.sticky-cta .s-tel{
  flex-shrink:0;width:62px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  background:#fff;border:1.5px solid var(--green-line);color:var(--green);border-radius:12px;font-weight:700;
}
.sticky-cta .s-tel .ic{width:22px;height:22px}
.sticky-cta .s-tel small{font-size:.6rem}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:920px){
  .hero-grid{grid-template-columns:1fr;gap:30px}
  .hero-visual{order:-1;max-width:440px;margin:0 auto}
  .access-grid{grid-template-columns:1fr}
}
@media (max-width:760px){
  body{font-size:15.5px}
  .sec{padding:50px 0}
  .hero{padding:32px 0 46px}
  .do-grid{grid-template-columns:1fr}
  .concern-grid{grid-template-columns:1fr}
  .reason-grid{grid-template-columns:1fr}
  .auc-cols{grid-template-columns:1fr}
  .car-grid{grid-template-columns:1fr}
  .ben-grid{grid-template-columns:1fr}
  .cta-stack{max-width:none}
  .sticky-cta{display:flex}
  .hdr-cta{display:none}
  .hero-quick{grid-template-columns:repeat(2,1fr)}
  .why-stat{gap:20px}
  footer.site{padding-bottom:120px}
}
@media (max-width:420px){
  .wrap{padding:0 16px}
  .date-strip{gap:8px}
  .date-strip .d-rain{margin-left:0}
}
