/* =========================================================================
   キッチンまんちゃん LP — production styles
   Derived from design_handoff_bento_lp/bento_lp.html (approved 案A).
   Colors / sizes / shadows kept faithful to the handoff design tokens.
   ========================================================================= */

:root{
  /* Brand palette (from logo) */
  --brown:#573636; --brown-dark:#3f2723; --caramel:#a26426;
  --gold:#e09a32; --gold-deep:#d98a25; --cream:#faf3e6; --cream-2:#f2e6d0;
  --paper:#fffdf8; --ink:#4a2c26; --ink-soft:#6b5142; --green:#6f8b3a; --red:#bf3f29;

  /* Supporting tones */
  --body-text:#5b4233; --aux:#8a6a4a; --label-inv:#e3b35e; --marker:#f4cf86;
  --badge-bg:#fbe6c4; --badge-text:#9a6418; --benefit-bg:#fceae6; --benefit-border:#efc3b8;
  --dash:#cdab78; --dash-2:#e0b878; --input-border:#d8c4a0; --on-gold:#3a221d; --on-brown:#fff7e9;

  --font-body:'Zen Maru Gothic',-apple-system,'Hiragino Kaku Gothic ProN','Noto Sans JP',sans-serif;
  --font-hand:'Yusei Magic',var(--font-body);
  --maxw:1080px;
}

*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
html,body{margin:0;}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  font-size:16px;
  line-height:1.7;
}
img{max-width:100%;}
a{color:inherit;}
h1,h2,h3,p,ul{margin:0;}
ul{list-style:none;padding:0;}
::placeholder{color:#b39a78;}
input,select,button,textarea{font-family:inherit;}

/* Visible focus for keyboard users */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible{
  outline:3px solid var(--gold-deep);
  outline-offset:2px;
}

.wrap{max-width:var(--maxw);margin:0 auto;padding-left:24px;padding-right:24px;}
.lift{transition:transform .15s ease;}
.lift:hover{transform:translateY(-2px);}
@media (prefers-reduced-motion:reduce){.lift{transition:none;}.lift:hover{transform:none;}}

.visually-hidden{
  position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0;
}
.skip-link{
  position:absolute;left:-9999px;top:0;z-index:100;
  background:var(--brown);color:var(--on-brown);padding:10px 16px;border-radius:0 0 8px 0;
}
.skip-link:focus{left:0;}

/* Section eyebrow + heading */
.eyebrow{font-size:13px;font-weight:700;color:var(--caramel);letter-spacing:.12em;}
.section-head{text-align:center;margin-bottom:34px;}
.section-title{font-family:var(--font-hand);font-size:33px;color:var(--brown);margin-top:6px;font-weight:400;}

/* ---------- Header ---------- */
.site-header{background:var(--cream);}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:20px;padding-top:18px;padding-bottom:10px;}
.site-header__logo{height:78px;width:auto;display:block;}
.header-tel{text-align:right;line-height:1.25;}
.header-tel__label{font-size:12px;color:var(--aux);letter-spacing:.04em;}
.header-tel__link{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-hand);font-size:27px;color:var(--brown);text-decoration:none;letter-spacing:.01em;}

/* ---------- Hero ---------- */
.hero{background:var(--cream);}
.hero__inner{padding-top:26px;padding-bottom:54px;}
.hero__grid{display:grid;grid-template-columns:1.04fr .96fr;gap:34px;align-items:center;}
.area-badge{display:inline-block;background:var(--badge-bg);color:var(--badge-text);font-size:13px;font-weight:700;padding:6px 14px;border-radius:999px;border:1.5px dashed var(--dash-2);}
.hero__title{font-family:var(--font-hand);font-size:50px;line-height:1.28;color:var(--brown);margin:16px 0 14px;font-weight:400;letter-spacing:.01em;}
.marker{background:linear-gradient(transparent 58%, var(--marker) 58%);padding:0 4px;}
.hero__lead{margin-bottom:22px;font-size:17px;color:var(--body-text);max-width:430px;}
.cta-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center;}

.btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:18px;padding:14px 24px;border-radius:999px;text-decoration:none;border:none;cursor:pointer;}
.btn--gold{background:var(--gold);color:var(--on-gold);box-shadow:0 7px 16px rgba(180,120,30,.34);}
.btn--brown{background:var(--brown);color:var(--on-brown);box-shadow:0 7px 16px rgba(60,35,25,.28);}

.benefit-pill{display:inline-flex;align-items:center;gap:9px;margin-top:20px;background:var(--benefit-bg);color:var(--red);border:1.5px solid var(--benefit-border);font-weight:700;font-size:15px;padding:10px 16px;border-radius:12px;}
.benefit-pill u{text-decoration:underline;}

.polaroid-wrap{display:flex;justify-content:center;}
.polaroid{position:relative;}
.polaroid__frame{background:var(--paper);padding:14px 14px 46px;border-radius:6px;box-shadow:0 16px 34px rgba(60,35,25,.22);transform:rotate(-2.5deg);}
.polaroid__photo{display:block;width:330px;height:330px;object-fit:cover;border-radius:3px;}
.polaroid__caption{position:absolute;left:0;right:0;bottom:14px;text-align:center;font-family:var(--font-hand);font-size:19px;color:#6b4a2e;}
.polaroid__tape{position:absolute;top:-14px;left:50%;width:96px;height:26px;background:rgba(224,154,50,.55);transform:translateX(-50%) rotate(-3deg);border-radius:2px;}
.polaroid__seal{position:absolute;right:-26px;bottom:8px;width:120px;height:120px;border-radius:50%;background:var(--gold);color:var(--on-gold);display:flex;flex-direction:column;align-items:center;justify-content:center;transform:rotate(-8deg);box-shadow:0 9px 20px rgba(180,120,30,.4);border:3px dashed var(--on-brown);}
.polaroid__seal small{font-size:11px;font-weight:700;}
.polaroid__seal b{font-family:var(--font-hand);font-size:36px;line-height:1;font-weight:400;}

/* ---------- Strengths ---------- */
.strengths{background:var(--cream-2);}
.section-pad{padding-top:50px;padding-bottom:50px;}
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.card{background:var(--paper);border:1.5px dashed var(--dash);border-radius:16px;padding:28px 22px;text-align:center;box-shadow:0 8px 20px rgba(60,35,25,.08);}
.card__icon{width:64px;height:64px;margin:0 auto 14px;border-radius:50%;display:flex;align-items:center;justify-content:center;}
.card__icon--green{background:#eef0df;color:var(--green);}
.card__icon--caramel{background:#f6e6cb;color:var(--caramel);}
.card__icon--gold{background:#fbeacb;color:var(--gold-deep);}
.card__title{font-size:19px;color:var(--brown);margin-bottom:8px;font-weight:700;}
.card__text{font-size:15px;color:var(--ink-soft);}

/* ---------- Menu & Price ---------- */
.menu{background:var(--cream);}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center;}
.menu__photo{width:100%;height:320px;object-fit:cover;border-radius:14px;box-shadow:0 12px 28px rgba(60,35,25,.18);}
.menu__name{font-size:24px;color:var(--brown);margin-bottom:4px;font-weight:900;}
.price{display:flex;align-items:baseline;gap:6px;margin:6px 0 14px;}
.price__amount{font-family:var(--font-hand);font-size:52px;color:var(--gold-deep);line-height:1;}
.price__tax{font-size:16px;font-weight:700;color:var(--aux);}
.checklist li{display:flex;gap:10px;align-items:flex-start;margin-bottom:9px;font-size:16px;color:var(--body-text);}
.checklist li:last-child{margin-bottom:18px;}
.checklist .check{color:var(--green);font-weight:900;}
.benefit-box{background:var(--benefit-bg);border:1.5px solid var(--benefit-border);border-radius:12px;padding:14px 16px;color:var(--red);font-weight:700;font-size:16px;}
.benefit-box b{font-size:18px;font-weight:700;}

/* ---------- Delivery & Flow ---------- */
.delivery{background:var(--brown);color:#f7ead3;}
.delivery__grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:34px;}
.delivery .eyebrow{color:var(--label-inv);}
.delivery__title{font-family:var(--font-hand);font-size:30px;margin:6px 0 16px;font-weight:400;color:#fffdf8;}
.area-pills{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px;}
.area-pill{border-radius:999px;padding:8px 16px;font-size:15px;font-weight:700;background:#6b4a3f;border:1.5px solid #8a6450;}
.area-pill--gold{background:var(--gold);color:var(--on-gold);border-color:var(--gold);}
.delivery__note{font-size:15px;color:#dcc6a8;}
.steps{display:flex;flex-direction:column;gap:12px;}
.step{display:flex;gap:14px;align-items:center;background:#634339;border-radius:12px;padding:13px 16px;}
.step__num{flex:none;width:34px;height:34px;border-radius:50%;background:var(--gold);color:var(--on-gold);display:flex;align-items:center;justify-content:center;font-family:var(--font-hand);font-size:18px;}
.step__text{font-size:16px;}

/* ---------- Access (storefront + map) ---------- */
.access{background:var(--cream-2);}
.access .grid-2{align-items:start;}   /* 写真とマップの上端を揃える（中央揃え解除） */
.access__photo{width:100%;height:360px;object-fit:cover;border-radius:14px;box-shadow:0 12px 28px rgba(60,35,25,.18);}
.access__cap{margin-top:10px;font-size:14px;color:var(--ink-soft);}
.access__mapwrap{border-radius:14px;overflow:hidden;box-shadow:0 12px 28px rgba(60,35,25,.18);line-height:0;}
.access__map{width:100%;height:360px;border:0;display:block;}
.access__info{margin-top:14px;font-size:15px;color:var(--body-text);line-height:1.9;}
.access__info p{margin:0;}
.access__info strong{color:var(--brown);}
.access__feats{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 2px;}
.feat-pill{display:inline-flex;align-items:center;background:var(--badge-bg);color:var(--badge-text);font-size:13px;font-weight:700;padding:5px 12px;border-radius:999px;border:1.5px dashed var(--dash-2);}
.access__invite{margin-top:2px;font-size:14px;color:var(--ink-soft);}
.access__invite a{color:var(--caramel);font-weight:700;text-decoration:underline;}
.access__maplink{display:inline-block;margin-top:8px;color:var(--caramel);font-weight:700;text-decoration:underline;}

/* ---------- Form ---------- */
.form-section{background:var(--cream);}
.form-card{max-width:620px;margin:0 auto;background:var(--paper);border:1.5px dashed var(--dash);border-radius:18px;padding:34px 34px 30px;box-shadow:0 12px 30px rgba(60,35,25,.1);}
.form-card__head{text-align:center;margin-bottom:22px;}
.form-card__title{font-family:var(--font-hand);font-size:30px;color:var(--brown);margin-bottom:6px;font-weight:400;}
.form-card__sub{font-size:15px;color:var(--ink-soft);}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;}
.field label{display:block;font-size:13px;font-weight:700;color:var(--ink-soft);margin-bottom:6px;}
.field .req{color:var(--red);}
.field input,.field select,.field textarea{width:100%;padding:13px 14px;border:1.5px solid var(--input-border);border-radius:10px;background:var(--paper);font-size:16px;color:var(--ink);}
.field textarea{resize:vertical;min-height:84px;line-height:1.6;}
.field--full{margin-bottom:14px;}
.field input:invalid:not(:placeholder-shown){border-color:var(--red);}
.btn-submit{width:100%;background:var(--brown);color:var(--on-brown);border:none;font-weight:700;font-size:19px;padding:16px;border-radius:12px;cursor:pointer;box-shadow:0 8px 18px rgba(60,35,25,.28);}
.form-error{display:none;margin:0 0 14px;padding:12px 14px;border-radius:10px;background:var(--benefit-bg);border:1.5px solid var(--benefit-border);color:var(--red);font-size:14px;font-weight:700;}
.form-error.is-visible{display:block;}
/* Honeypot: hidden from humans, visible to dumb bots */
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;}

.thanks{text-align:center;padding:18px 6px;}
.thanks__icon{width:64px;height:64px;margin:0 auto 14px;border-radius:50%;background:#eef0df;color:var(--green);display:flex;align-items:center;justify-content:center;}
.thanks__title{font-size:21px;color:var(--brown);margin-bottom:8px;font-weight:900;}
.thanks__text{font-size:15px;color:var(--ink-soft);}

.form-tel{text-align:center;margin-top:18px;padding-top:18px;border-top:1px solid #ead9bd;}
.form-tel__label{font-size:14px;color:var(--aux);}
.form-tel__link{display:block;font-family:var(--font-hand);font-size:32px;color:var(--brown);text-decoration:none;margin-top:2px;}

/* ---------- Footer ---------- */
.site-footer{background:var(--brown-dark);color:#d7c2a8;}
.site-footer__inner{padding-top:34px;padding-bottom:34px;}
.site-footer__top{display:flex;flex-wrap:wrap;gap:20px 40px;justify-content:space-between;align-items:flex-start;}
.brandmark{font-family:var(--font-hand);font-size:24px;color:var(--on-brown);}
.brandmark__sub{font-size:13px;color:#b59e84;margin-top:2px;}
.site-footer__info{font-size:14px;line-height:1.9;}
.site-footer__bottom{margin-top:22px;padding-top:16px;border-top:1px solid #5a3d36;font-size:12px;color:#9c8369;display:flex;flex-wrap:wrap;gap:6px 18px;justify-content:space-between;align-items:center;}
.site-footer__bottom a{color:#c9b393;text-decoration:underline;}

/* ---------- Responsive ---------- */
@media (max-width:780px){
  .hero__grid,.cards-3,.grid-2,.delivery__grid,.form-grid{grid-template-columns:1fr;}
  .access__photo,.access__map{height:280px;}
  .hero__title{font-size:38px;}
  .section-title,.form-card__title,.delivery__title{font-size:27px;}
  .price__amount{font-size:44px;}
  .site-header__logo{height:62px;}
  .header-tel__link{font-size:23px;}
  .polaroid__seal{right:0;}
  .form-card{padding:26px 20px 24px;}
}
@media (max-width:420px){
  .wrap{padding-left:18px;padding-right:18px;}
  .btn{font-size:16px;padding:13px 20px;}
}
