:root{
  --bg1:#fff7ec; --bg2:#ffe8d6;
  --ink:#4a3527; --sub:#8a6f5c;
  --accent:#ff7a3d; --accent2:#ffb35c;
  --card:#ffffff; --line:#f3dfc9;
  --good:#2f9e63; --bad:#c75555;
}
*{margin:0;padding:0;box-sizing:border-box;}
body{
  font-family:"Hiragino Maru Gothic ProN","Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,sans-serif;
  background:linear-gradient(160deg,var(--bg1),var(--bg2));
  color:var(--ink); min-height:100vh; padding-bottom:60px;
}
a{color:var(--accent);}
.site-header{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 20px;max-width:760px;margin:0 auto;
}
.site-header .logo{font-weight:800;font-size:18px;color:var(--ink);text-decoration:none;}
.site-header nav a{font-size:13px;font-weight:700;text-decoration:none;margin-left:14px;}
.wrap{width:100%;max-width:560px;margin:0 auto;padding:10px 16px 0;}
.wide{max-width:720px;}
.card{
  background:var(--card); border-radius:24px; padding:32px 28px;
  box-shadow:0 10px 30px rgba(180,110,50,.12);
  animation:pop .35s ease;
}
@keyframes pop{from{opacity:0;transform:translateY(14px) scale(.98);}to{opacity:1;transform:none;}}
@keyframes bounce{0%,100%{transform:translateY(0);}50%{transform:translateY(-12px);}}
@keyframes wiggle{0%,100%{transform:rotate(-4deg);}50%{transform:rotate(4deg);}}
@keyframes spin{to{transform:rotate(360deg);}}

.hero-emoji{font-size:64px;text-align:center;animation:bounce 1.6s ease-in-out infinite;}
.badge{display:inline-block;background:#fff1e0;color:var(--accent);font-size:12px;font-weight:700;border-radius:999px;padding:6px 14px;margin-bottom:12px;}
h1{font-size:26px;text-align:center;line-height:1.5;margin:14px 0 8px;}
.lead{color:var(--sub);text-align:center;font-size:14px;line-height:1.9;}
.center{text-align:center;}
.btn{
  display:block;width:100%;border:none;cursor:pointer;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:#fff;font-size:18px;font-weight:700;font-family:inherit;
  padding:16px;border-radius:999px;margin-top:24px;
  box-shadow:0 6px 16px rgba(255,122,61,.35);
  transition:transform .15s, box-shadow .15s;
  text-align:center;text-decoration:none;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(255,122,61,.45);}
.btn.ghost{background:#fff;color:var(--accent);border:2px solid var(--accent);box-shadow:none;}
.btn.x{background:#1a1a1a;box-shadow:0 6px 16px rgba(0,0,0,.25);}

.progress-track{height:10px;background:#f6e7d6;border-radius:999px;overflow:hidden;margin-bottom:8px;}
.progress-fill{height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:999px;transition:width .3s ease;}
.progress-label{font-size:12px;color:var(--sub);text-align:right;margin-bottom:18px;}
.q-emoji{font-size:44px;text-align:center;margin-bottom:10px;animation:wiggle 1.8s ease-in-out infinite;}
.q-text{font-size:19px;font-weight:700;text-align:center;line-height:1.6;margin-bottom:24px;min-height:60px;}
.choice{
  display:block;width:100%;cursor:pointer;text-align:left;
  background:#fffaf3;border:2px solid var(--line);border-radius:18px;
  padding:15px 18px;font-size:15px;font-weight:600;font-family:inherit;color:var(--ink);
  margin-bottom:12px;line-height:1.6;transition:all .15s;
}
.choice:hover{border-color:var(--accent);background:#fff3e6;transform:translateX(4px);}

.cook-emoji{font-size:72px;text-align:center;animation:spin 1.2s linear infinite;}
.cook-text{text-align:center;font-weight:700;font-size:17px;margin-top:18px;}
.cook-sub{text-align:center;color:var(--sub);font-size:13px;margin-top:8px;}

.r-emoji{font-size:84px;text-align:center;animation:bounce 1.4s ease-in-out infinite;}
.r-type{text-align:center;color:var(--accent);font-size:13px;font-weight:700;letter-spacing:.2em;margin-top:6px;}
.r-name{font-size:26px;font-weight:800;text-align:center;margin:6px 0 2px;}
.r-tag{text-align:center;color:var(--sub);font-size:14px;margin-bottom:18px;}
.r-desc{font-size:14.5px;line-height:2;background:#fffaf3;border-radius:16px;padding:18px;}
.r-caution{font-size:13px;line-height:1.8;color:#a3552a;background:#fff1e0;border-radius:12px;padding:12px 14px;margin-top:10px;}
.sec-title{font-size:16px;font-weight:800;margin:30px 0 12px;display:flex;align-items:center;gap:8px;}

.axis{margin-bottom:16px;}
.axis-labels{display:flex;justify-content:space-between;font-size:12px;font-weight:700;color:var(--sub);margin-bottom:4px;}
.axis-labels .on{color:var(--accent);}
.axis-track{height:14px;background:#f6e7d6;border-radius:999px;position:relative;overflow:hidden;}
.axis-fill{position:absolute;top:0;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:999px;transition:width .8s ease;}
.axis-pct{font-size:11px;color:var(--sub);text-align:center;margin-top:3px;}
.axis-note{font-size:13px;line-height:1.9;color:var(--ink);background:#fffaf3;border-radius:12px;padding:10px 14px;margin-top:6px;}

.cols{display:flex;gap:12px;flex-wrap:wrap;}
.col{flex:1;min-width:200px;background:#fffaf3;border-radius:16px;padding:14px 16px;}
.col h4{font-size:13.5px;margin-bottom:8px;}
.col.good h4{color:var(--good);}
.col.bad h4{color:var(--bad);}
.col ul{list-style:none;}
.col li{font-size:13.5px;line-height:1.8;padding-left:1.3em;text-indent:-1.3em;margin-bottom:4px;}

.aruaru{list-style:none;background:#fffaf3;border-radius:16px;padding:16px 18px;}
.aruaru li{font-size:14px;line-height:2;padding-left:1.6em;text-indent:-1.6em;}

.life-box{background:#fffaf3;border-radius:16px;padding:14px 16px;margin-bottom:12px;font-size:14px;line-height:2;}
.life-box b{display:block;font-size:13.5px;color:var(--accent);margin-bottom:4px;}

.match-row{display:flex;gap:12px;}
.match{flex:1;text-align:center;background:#fffaf3;border:2px solid var(--line);border-radius:16px;padding:14px 8px;}
.match .m-label{font-size:11px;font-weight:700;margin-bottom:6px;}
.match .m-emoji{font-size:36px;}
.match .m-name{font-size:12.5px;font-weight:700;margin-top:6px;line-height:1.5;}
.match.good .m-label{color:var(--good);}
.match.bad .m-label{color:var(--bad);}
.match-reason{font-size:13px;line-height:1.9;color:var(--sub);background:#fffaf3;border-radius:12px;padding:10px 14px;margin-top:10px;}

.grid16{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:8px;}
.g-cell{background:#fffaf3;border:1.5px solid var(--line);border-radius:12px;text-align:center;padding:8px 2px;}
.g-cell.me{border-color:var(--accent);background:#fff1e0;}
.g-cell .g-emoji{font-size:24px;}
.g-cell .g-sym{font-size:13px;font-weight:800;margin-top:2px;}
.g-cell .g-name{font-size:9.5px;color:var(--sub);margin-top:2px;line-height:1.3;}
.legend{font-size:11.5px;color:var(--sub);line-height:1.9;margin-top:8px;}

.ad-slot{
  margin:26px 0 0;min-height:100px;border:2px dashed #d9c3aa;border-radius:14px;
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  color:#c9ab8f;font-size:12px;letter-spacing:.1em;background:#fffdf9;gap:4px;
}
.item-card{display:flex;align-items:center;gap:14px;background:#fffaf3;border:2px solid var(--line);border-radius:16px;padding:14px 16px;margin-bottom:10px;}
.item-card .i-emoji{font-size:32px;}
.item-card .i-body{flex:1;}
.item-card .i-name{font-size:14px;font-weight:700;line-height:1.5;}
.item-card .i-links{display:flex;gap:8px;margin-top:6px;}
.item-card a{font-size:11.5px;font-weight:700;text-decoration:none;border-radius:999px;padding:5px 12px;}
.item-card a.am{background:#ffb35c33;color:#a3552a;border:1.5px solid #ffb35c;}
.item-card a.rk{background:#c7555522;color:#c75555;border:1.5px solid #c7555588;}
.pr-note{font-size:10.5px;color:#c9ab8f;text-align:right;margin-top:4px;}

.share-box{background:#fffaf3;border:2px dashed var(--accent2);border-radius:16px;padding:14px;font-size:13px;line-height:1.8;white-space:pre-wrap;color:var(--sub);}
.copied{position:fixed;left:50%;bottom:30px;transform:translateX(-50%);background:var(--ink);color:#fff;font-size:13px;padding:10px 22px;border-radius:999px;opacity:0;pointer-events:none;transition:opacity .3s;z-index:9;}
.copied.show{opacity:1;}
.foot{text-align:center;color:#c9ab8f;font-size:11px;margin:18px 0;line-height:1.8;}

/* index */
.quiz-card{
  display:flex;align-items:center;gap:14px;background:var(--card);
  border-radius:18px;padding:16px 18px;margin-bottom:12px;text-decoration:none;color:var(--ink);
  box-shadow:0 6px 18px rgba(180,110,50,.10);transition:transform .15s;
}
.quiz-card:hover{transform:translateY(-2px);}
.quiz-card .qc-emoji{font-size:38px;}
.quiz-card .qc-body{flex:1;}
.quiz-card .qc-title{font-size:16px;font-weight:800;}
.quiz-card .qc-desc{font-size:12.5px;color:var(--sub);line-height:1.7;margin-top:2px;}
.quiz-card .qc-tag{font-size:10.5px;font-weight:700;color:var(--accent);background:#fff1e0;border-radius:999px;padding:3px 10px;white-space:nowrap;}
.notice18{font-size:12px;font-weight:700;color:#c75555;background:#fff0f0;border-radius:12px;padding:10px 14px;margin:8px 0 14px;line-height:1.8;}
.cat-title{font-size:18px;font-weight:800;margin:30px 0 14px;}

/* articles */
.article{background:var(--card);border-radius:24px;padding:34px 30px;box-shadow:0 10px 30px rgba(180,110,50,.12);}
.article h1{font-size:24px;text-align:left;line-height:1.6;}
.article h2{font-size:18px;margin:34px 0 12px;padding-left:12px;border-left:5px solid var(--accent);line-height:1.5;}
.article h3{font-size:15px;margin:20px 0 8px;}
.article p{font-size:14.5px;line-height:2.1;margin-bottom:14px;}
.article ul,.article ol{margin:0 0 14px 1.4em;}
.article li{font-size:14px;line-height:2;}
.article table{width:100%;border-collapse:collapse;font-size:13px;margin-bottom:16px;}
.article th,.article td{border:1px solid var(--line);padding:8px 10px;line-height:1.7;text-align:left;}
.article th{background:#fff7ec;}
.summary-box{background:#fffaf3;border:2px solid var(--accent2);border-radius:16px;padding:16px 18px;margin:18px 0;font-size:14px;line-height:2;}
.summary-box b{color:var(--accent);}
.faq-q{font-weight:800;margin-top:14px;font-size:14.5px;}
.faq-a{font-size:14px;line-height:2;color:var(--sub);margin-top:4px;}
.breadcrumb{font-size:11.5px;color:var(--sub);margin-bottom:14px;}
.breadcrumb a{color:var(--sub);}
.related-links{list-style:none;margin:0!important;}
.related-links li{padding-left:0;text-indent:0;margin-bottom:6px;}

/* 診断中ヘッダーのLINE導線 */
.line-cta{display:inline-block;background:#06C755;color:#fff;font-size:12.5px;font-weight:700;text-decoration:none;border-radius:999px;padding:8px 14px;box-shadow:0 4px 12px rgba(6,199,85,.3);}
.line-cta:hover{opacity:.9;}

/* リクエスト導線POP(フッター上) */
.req-pop{max-width:560px;margin:26px auto 0;padding:14px 18px;background:#fffaf3;border:2px dashed var(--accent2);border-radius:16px;font-size:13.5px;line-height:1.9;text-align:center;}
.req-pop a{display:inline-block;margin-top:7px;font-weight:700;}

/* COMING SOONカード */
.quiz-card.soon{cursor:default;background:#f3ead8;border:2px dashed #c79b62;box-shadow:none;}
.quiz-card.soon:hover{transform:none;}
.quiz-card.soon .qc-title{color:#9a7a55;letter-spacing:.06em;}
.quiz-card.soon .qc-desc{color:#a98f6e;}
.quiz-card.soon .qc-emoji{opacity:.9;}
.quiz-card.soon .qc-tag{color:#fff;background:#c79b62;}

/* 広告枠(未稼働時): 文字なしでスペースだけ確保 */
.ad-slot-empty{height:36px;margin:14px 0 0;}

/* フローティングLINEボタン(全ページ右下) */
.line-float{
  position:fixed;right:16px;bottom:16px;z-index:50;
  display:flex;align-items:center;gap:9px;
  background:#06C755;color:#fff;text-decoration:none;
  font-size:17px;font-weight:700;
  padding:15px 24px;border-radius:999px;
  box-shadow:0 6px 18px rgba(6,199,85,.4);
  transition:transform .15s;
}
.line-float:hover{transform:translateY(-2px);}
.line-float .lf-t{display:flex;flex-direction:column;line-height:1.25;text-align:left;}
.line-float .lf-t small{font-size:13px;font-weight:700;opacity:.92;}
@media (max-width:480px){
  .line-float{padding:13px 20px;}
  .line-float .lf-t small{display:none;}
}

/* ===== スマホ最終調整 ===== */
@media (max-width:480px){
  .site-header{padding:12px 14px;}
  .site-header .logo{font-size:16px;}
  .site-header nav a{font-size:12px;margin-left:10px;}
  .wrap{padding:8px 12px 0;}
  .card{padding:26px 18px;border-radius:20px;}
  h1{font-size:22px;}
  .q-text{font-size:17px;}
  .choice{font-size:14px;padding:13px 15px;}
  .r-name{font-size:22px;}
  .grid16{gap:6px;}
  .g-cell .g-name{font-size:8.5px;}
  .match-row{gap:8px;}
}
/* 記事内テーブルは横スクロールで崩れ防止 */
.article table{display:block;overflow-x:auto;white-space:nowrap;}
.article table th,.article table td{white-space:normal;min-width:90px;}
/* 入力とボタンのタップ領域確保 */
input,button,.btn{min-height:44px;}

/* ===== トップページのカードをスリム化 ===== */
.hero-card{padding:20px 22px 18px;}
.hero-card .hero-emoji{font-size:40px;animation:none;}
.hero-card h1{font-size:21px;margin:8px 0 6px;}
.hero-card .lead{font-size:12.5px;line-height:1.7;}
.quiz-card{padding:13px 15px;gap:12px;margin-bottom:10px;border-radius:16px;border:1.5px solid #f0e0c8;}
.quiz-card .qc-emoji{font-size:30px;}
.quiz-card .qc-title{font-size:14.5px;}
.quiz-card .qc-desc{font-size:12px;line-height:1.55;margin-top:2px;}
.cat-title{font-size:15px;margin:20px 0 10px;}
.notice18{font-size:11px;padding:8px 12px;margin:6px 0 10px;}

.line-float .lf-t b{display:flex;align-items:center;gap:4px;font-weight:700;}
.line-float .lf-e{font-style:normal;font-size:30px;line-height:1;}

/* 診断回答中はLINEボタン・リクエストPOPを非表示(集中モード) */
.quiz-focus .line-float,.quiz-focus .req-pop{display:none;}

/* 引き継ぎコードのヘルプ */
.help-q{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;min-height:22px;border-radius:50%;border:2px solid var(--accent);color:var(--accent);background:#fff;font-weight:800;font-size:13px;cursor:pointer;margin-left:8px;padding:0;line-height:1;}
.help-pop{background:#fffaf3;border:2px solid var(--accent2);border-radius:14px;padding:12px 14px;font-size:13px;line-height:1.9;margin:8px 0;}
