@charset "utf-8";

/* =========================================
   FAQ Detail PC - 二次会の虎テイスト
   ※faq詳細ページ専用
========================================= */

:root {
  --ntora-orange: #ff6200;
  --ntora-orange-dark: #e05000;
  --ntora-orange-light: #fff4eb;
  --ntora-orange-accent: #ff8c1a;
  --ntora-yellow: #ffd200;
  --ntora-gold: #ffb84d;

  --ntora-text: #222;
  --ntora-text-sub: #555;
  --ntora-text-muted: #888;
  --ntora-border: #ececec;
  --ntora-bg: #fafafa;
  --ntora-white: #fff;

  --fs-body: 15px;
  --fs-body-small: 13px;
  --fs-note: 12px;
  --fs-section-title: 28px;
  --fs-block-title: 22px;
  --fs-card-title: 18px;
  --fs-hero-title: 34px;
  --fs-hero-sub: 16px;
  --fs-button: 13px;

  --radius-card: 20px;
  --radius-box: 16px;
  --radius-btn: 12px;
  --radius-pill: 999px;

  --shadow-card: 0 8px 24px rgba(0, 0, 0, .07);
  --shadow-orange: 0 10px 28px rgba(255, 98, 0, .16);
}

#faq-detail {
  width: 970px;
  margin: 0 auto;
  color: var(--ntora-text);
  line-height: 1.75;
  font-size: var(--fs-body);
}

#faq-detail * {
  box-sizing: border-box;
}

#faq-detail a {
  color: var(--ntora-orange-dark);
  text-decoration: none;
  font-weight: 700;
}

#faq-detail a:hover {
  color: var(--ntora-orange);
  text-decoration: underline;
}

#faq-detail img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

#faq-detail .breadcrumb {
  margin-bottom: 18px;
}

/* -----------------------------------------
   Hero
----------------------------------------- */
#faq-detail .faq-detail-hero {
  position: relative;
  overflow: hidden;
  margin-bottom: 24px;
  padding: 34px 38px;
  border: 1px solid rgba(255, 98, 0, .18);
  border-radius: var(--radius-card);
  background:
    radial-gradient(circle at 88% 12%, rgba(255, 210, 0, .42) 0 13%, transparent 30%),
    radial-gradient(circle at 8% 18%, rgba(255, 184, 77, .32) 0 10%, transparent 28%),
    linear-gradient(135deg, #fffaf5 0%, #fff4eb 45%, #ffffff 100%);
  box-shadow: var(--shadow-orange);
}

#faq-detail .faq-detail-hero::before {
  content: "FAQ";
  position: absolute;
  right: 22px;
  bottom: -18px;
  color: rgba(255, 98, 0, .08);
  font-size: 90px;
  line-height: 1;
  font-weight: 900;
  letter-spacing: .04em;
  pointer-events: none;
}

#faq-detail .faq-detail-hero__eyebrow {
  display: inline-block;
  margin: 0 0 10px;
  padding: 4px 12px;
  border-radius: var(--radius-pill);
  background: linear-gradient(135deg, var(--ntora-orange-accent), var(--ntora-orange));
  color: var(--ntora-white);
  font-size: var(--fs-note);
  font-weight: 700;
  letter-spacing: .08em;
}

#faq-detail .faq-detail-hero__title {
  position: relative;
  z-index: 1;
  margin: 0 0 12px;
  color: var(--ntora-text);
  font-size: var(--fs-hero-title);
  line-height: 1.3;
  font-weight: 800;
}

#faq-detail .faq-detail-hero__title::after {
  content: "";
  display: block;
  width: 72px;
  height: 4px;
  margin-top: 12px;
  border-radius: var(--radius-pill);
  background: linear-gradient(90deg, var(--ntora-orange), var(--ntora-yellow));
}

#faq-detail .faq-detail-hero__lead {
  position: relative;
  z-index: 1;
  margin: 0;
  color: var(--ntora-text-sub);
  font-size: var(--fs-hero-sub);
}

/* -----------------------------------------
   Main Q&A Card
----------------------------------------- */
#faq-detail .faq-detail-card {
  margin-bottom: 30px;
  padding: 28px 30px;
  border: 1px solid var(--ntora-border);
  border-radius: var(--radius-card);
  background: var(--ntora-white);
  box-shadow: var(--shadow-card);
}

#faq-detail .faq-detail-q,
#faq-detail .faq-detail-a {
  display: flex;
  gap: 16px;
}

#faq-detail .faq-detail-q {
  margin-bottom: 22px;
  padding-bottom: 22px;
  border-bottom: 1px dashed rgba(255, 98, 0, .28);
}

#faq-detail .faq-detail-q__icon,
#faq-detail .faq-detail-a__icon {
  flex: 0 0 42px;
  width: 42px;
  height: 42px;
  border-radius: var(--radius-pill);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ntora-white);
  font-weight: 800;
  font-size: 18px;
  box-shadow: 0 6px 14px rgba(0, 0, 0, .10);
}

#faq-detail .faq-detail-q__icon {
  background: var(--ntora-text);
}

#faq-detail .faq-detail-a__icon {
  background: linear-gradient(135deg, var(--ntora-orange-accent), var(--ntora-orange));
}

#faq-detail .faq-detail-q__body,
#faq-detail .faq-detail-a__body {
  flex: 1 1 auto;
  min-width: 0;
}

#faq-detail .faq-detail-q__body h3 {
  margin: 2px 0 0;
  color: var(--ntora-text);
  font-size: 26px;
  line-height: 1.45;
  font-weight: 800;
}

#faq-detail .faq-answer-lead {
  display: inline;
  margin: 0;
  padding: 0 .15em;
  background: linear-gradient(transparent 60%, rgba(255, 210, 0, .55) 60%);
  color: var(--ntora-text);
  font-size: 18px;
  line-height: 1.7;
  font-weight: 800;
}

#faq-detail .faq-answer-note {
  margin: 12px 0 0;
  color: var(--ntora-text-sub);
}

/* -----------------------------------------
   Section
----------------------------------------- */
#faq-detail .faq-detail-section {
  margin-bottom: 28px;
  padding: 24px 26px;
  border: 1px solid var(--ntora-border);
  border-radius: var(--radius-card);
  background: var(--ntora-white);
  box-shadow: var(--shadow-card);
}

#faq-detail .faq-detail-section h3 {
  position: relative;
  margin: 0 0 16px;
  padding-left: 18px;
  color: var(--ntora-text);
  font-size: var(--fs-block-title);
  line-height: 1.4;
  font-weight: 800;
}

#faq-detail .faq-detail-section h3::before {
  content: "";
  position: absolute;
  left: 0;
  top: .25em;
  width: 6px;
  height: 1.2em;
  border-radius: var(--radius-pill);
  background: linear-gradient(180deg, var(--ntora-orange), var(--ntora-yellow));
}

#faq-detail .faq-detail-section__body>*:first-child {
  margin-top: 0;
}

#faq-detail .faq-detail-section__body>*:last-child {
  margin-bottom: 0;
}

#faq-detail .faq-detail-section__body p {
  margin: 0 0 14px;
  color: var(--ntora-text-sub);
}

#faq-detail .faq-detail-section--note {
  border-color: rgba(255, 98, 0, .22);
  background: var(--ntora-orange-light);
}

#faq-detail .faq-detail-section--note h3 {
  color: var(--ntora-orange-dark);
}

/* -----------------------------------------
   List / Step
----------------------------------------- */
#faq-detail .faq-detail-list,
#faq-detail .faq-detail-steps {
  margin: 0;
  padding-left: 0;
  list-style: none;
}

#faq-detail .faq-detail-list li,
#faq-detail .faq-detail-steps li {
  position: relative;
  margin-bottom: 9px;
  padding-left: 1.45em;
  color: var(--ntora-text-sub);
}

#faq-detail .faq-detail-list li::before {
  content: "●";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--ntora-orange);
  font-size: 11px;
}

#faq-detail .faq-detail-steps {
  counter-reset: faq-step;
}

#faq-detail .faq-detail-steps li {
  counter-increment: faq-step;
}

#faq-detail .faq-detail-steps li::before {
  content: counter(faq-step);
  position: absolute;
  left: 0;
  top: .2em;
  width: 18px;
  height: 18px;
  border-radius: var(--radius-pill);
  background: var(--ntora-orange);
  color: var(--ntora-white);
  font-size: 11px;
  line-height: 18px;
  text-align: center;
  font-weight: 700;
}

#faq-detail .faq-detail-steps li:last-child,
#faq-detail .faq-detail-list li:last-child {
  margin-bottom: 0;
}

/* -----------------------------------------
   Image
----------------------------------------- */
#faq-detail .faq-detail-image {
  margin: 6px 0 10px;
  text-align: center;
}

#faq-detail .faq-detail-image img {
  border: 1px solid var(--ntora-border);
  border-radius: var(--radius-box);
  background: var(--ntora-white);
}

#faq-detail .faq-detail-caption {
  margin: 0;
  color: var(--ntora-text-muted);
  text-align: center;
  font-size: var(--fs-body-small);
}

/* -----------------------------------------
   Related
----------------------------------------- */
#faq-detail .faq-related {
  margin-bottom: 30px;
  padding: 24px 26px;
  border: 1px solid rgba(255, 98, 0, .18);
  border-radius: var(--radius-card);
  background: #fffaf5;
}

#faq-detail .faq-related h3 {
  position: relative;
  margin: 0 0 14px;
  padding-left: 18px;
  color: var(--ntora-text);
  font-size: var(--fs-block-title);
  line-height: 1.4;
  font-weight: 800;
}

#faq-detail .faq-related h3::before {
  content: "";
  position: absolute;
  left: 0;
  top: .25em;
  width: 6px;
  height: 1.2em;
  border-radius: var(--radius-pill);
  background: linear-gradient(180deg, var(--ntora-orange), var(--ntora-yellow));
}

#faq-detail .faq-related__list {
  margin: 0;
  padding: 0;
  border-top: 1px solid rgba(255, 98, 0, .16);
  list-style: none;
}

#faq-detail .faq-related__list li {
  border-bottom: 1px solid rgba(255, 98, 0, .16);
}

#faq-detail .faq-related__list li a {
  position: relative;
  display: block;
  padding: 13px 28px 13px 4px;
  color: var(--ntora-text);
  font-weight: 700;
}

#faq-detail .faq-related__list li a::after {
  content: "›";
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--ntora-orange);
  font-size: 24px;
  line-height: 1;
}

/* -----------------------------------------
   Contact
----------------------------------------- */
#faq-detail .faq-contact-box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 10px;
  padding: 30px;
  border-radius: var(--radius-card);
  background:
    radial-gradient(circle at 92% 10%, rgba(255, 210, 0, .32) 0 12%, transparent 28%),
    linear-gradient(135deg, var(--ntora-orange-dark), var(--ntora-orange) 70%, var(--ntora-orange-accent));
  color: var(--ntora-white);
  box-shadow: var(--shadow-orange);
}

#faq-detail .faq-contact-box__body {
  flex: 1 1 auto;
}

#faq-detail .faq-contact-box__body h3 {
  margin: 0 0 8px;
  color: var(--ntora-white);
  font-size: 25px;
  line-height: 1.4;
  font-weight: 800;
}

#faq-detail .faq-contact-box__body p {
  margin: 0;
  color: rgba(255, 255, 255, .92);
}

#faq-detail .faq-contact-box__actions {
  display: flex;
  gap: 12px;
  flex-shrink: 0;
}

#faq-detail .faq-btn {
  display: inline-block;
  min-width: 190px;
  padding: 13px 18px;
  border-radius: var(--radius-btn);
  text-align: center;
  font-size: var(--fs-button);
  font-weight: 800;
  line-height: 1.4;
  transition: opacity .2s ease, transform .2s ease;
}

#faq-detail .faq-btn:hover {
  opacity: .9;
  text-decoration: none;
  transform: translateY(-1px);
}

#faq-detail .faq-btn--line {
  border: 1px solid rgba(255, 255, 255, .72);
  color: var(--ntora-white);
  background: rgba(255, 255, 255, .08);
}

#faq-detail .faq-btn--fill {
  border: 1px solid var(--ntora-white);
  background: var(--ntora-white);
  color: var(--ntora-orange-dark);
}

/* -----------------------------------------
   Utility
----------------------------------------- */
#faq-detail .is-narrow {
  max-width: 760px;
}

#faq-detail .is-center {
  text-align: center;
}

#faq-detail .is-small {
  color: var(--ntora-text-muted);
  font-size: var(--fs-body-small);
}

/* -----------------------------------------
   Long Manual Style Support
----------------------------------------- */
#faq-detail .faq-manual-block {
  margin-bottom: 20px;
  padding: 18px 20px;
  border: 1px solid var(--ntora-border);
  border-radius: var(--radius-box);
  background: var(--ntora-white);
}

#faq-detail .faq-manual-block h4 {
  margin: 0 0 10px;
  color: var(--ntora-orange-dark);
  font-size: var(--fs-card-title);
  line-height: 1.5;
  font-weight: 800;
}

#faq-detail .faq-manual-block p {
  margin: 0;
  color: var(--ntora-text-sub);
}

/* -----------------------------------------
   Prevent overflow
----------------------------------------- */
#faq-detail,
#faq-detail .faq-detail-card,
#faq-detail .faq-detail-section,
#faq-detail .faq-related,
#faq-detail .faq-contact-box,
#faq-detail .faq-detail-hero {
  word-break: break-word;
}

#faq-detail .faq-contact-box .faq-detail-list {
  margin-top: 12px;
  padding-left: 0;
}

#faq-detail .faq-contact-box .faq-detail-list li {
  color: rgba(255, 255, 255, .94);
  margin-bottom: 6px;
}

#faq-detail .faq-contact-box .faq-detail-list li::before {
  color: var(--ntora-yellow);
}

#faq-detail .faq-contact-box .faq-detail-list li:last-child {
  margin-bottom: 0;
}

/* -----------------------------------------
   Narrow PC / Tablet insurance
----------------------------------------- */
@media screen and (max-width: 1000px) {
  #faq-detail {
    width: auto;
    margin: 0 12px;
  }

  #faq-detail .faq-contact-box {
    display: block;
  }

  #faq-detail .faq-contact-box__actions {
    margin-top: 18px;
  }
}