/* ========== AREA ========== */
.area-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: 1px; background: var(--color-border); border: 1px solid var(--color-border); }
.area-map { background: var(--color-bg); padding: 32px; color: var(--color-brand-ink); }
.fukuoka-svg { width: 100%; height: auto; max-height: 520px; display: block; }
body[data-dark="true"] .area-map { color: var(--color-text); }

.area-list { background: var(--color-bg); padding: 24px 0; }
.area-list-head { display: grid; grid-template-columns: 1fr 100px; padding: 0 32px 16px; font-size: 10px; letter-spacing: 0.14em; color: var(--color-text-mute); border-bottom: 1px solid var(--color-border); }
.area-list-row { display: grid; grid-template-columns: 1fr 100px; padding: 14px 32px; align-items: baseline; border-bottom: 1px solid var(--color-border); transition: 0.15s; }
.area-list-row:hover { background: var(--color-surface); }
.area-list-row.is-hq { background: rgba(201,168,106,0.08); }
.area-list-row.is-hq .area-city { font-weight: 600; color: var(--color-brand-ink); }
.area-city { font-size: 15px; color: var(--color-text); }
.area-tag { display: inline-block; margin-left: 10px; padding: 2px 8px; background: var(--color-accent); color: var(--color-brand); font-size: 10px; letter-spacing: 0.1em; border-radius: 3px; }
.area-dur { font-size: 13px; color: var(--color-text-sub); text-align: right; letter-spacing: 0.04em; }
.area-list-foot { padding: 24px 32px; border-top: 1px solid var(--color-border); }
.area-list-foot .eyebrow { display: block; margin-bottom: 8px; }
.area-list-foot p { font-size: 12px; color: var(--color-text-sub); line-height: 1.8; margin: 0; }
@media (max-width: 760px) { .area-grid { grid-template-columns: 1fr; } }

/* ========== FLOW ========== */
.flow-list { list-style: none; padding: 0; margin: 0; }
.flow-step { display: grid; grid-template-columns: 120px 1fr; gap: 40px; align-items: start; padding: 0; position: relative; }
.flow-rail { position: relative; padding-top: 4px; display: flex; flex-direction: column; align-items: center; height: 100%; }
.flow-num { font-family: var(--font-mono); font-size: 14px; color: var(--color-accent); letter-spacing: 0.1em; padding: 8px 14px; border: 1px solid var(--color-accent); border-radius: 50%; background: var(--color-bg); width: 52px; height: 52px; display: flex; align-items: center; justify-content: center; }
.flow-line { flex: 1; width: 1px; background: var(--color-border); margin-top: 12px; margin-bottom: -8px; }
.flow-step:last-child .flow-line { display: none; }
.flow-body { padding-bottom: 48px; }
.flow-head { display: flex; justify-content: space-between; align-items: baseline; border-bottom: 1px solid var(--color-border); padding-bottom: 12px; margin-bottom: 16px; }
.flow-t { font-family: var(--font-heading); font-size: clamp(20px, 2.2vw, 26px); color: var(--color-brand-ink); margin: 0; font-weight: 500; line-height: 1.4; }
.flow-time { font-size: 11px; color: var(--color-text-mute); letter-spacing: 0.1em; }
.flow-d { font-size: 15px; color: var(--color-text-sub); line-height: 1.9; margin: 0 0 20px; max-width: 62ch; }
.flow-means { display: flex; gap: 8px; flex-wrap: wrap; }
.flow-chip { display: inline-block; padding: 6px 12px; border: 1px solid var(--color-border-strong); border-radius: var(--radius-sm); font-size: 11px; letter-spacing: 0.04em; color: var(--color-text-sub); }
.flow-foot { margin-top: 40px; padding: 24px 32px; background: var(--color-surface); border-left: 3px solid var(--color-text-mute); }
.flow-foot .eyebrow { display: block; margin-bottom: 10px; }
.flow-foot p { font-size: 13px; color: var(--color-text-sub); line-height: 1.9; margin: 0; }
@media (max-width: 760px) {
  .flow-step { grid-template-columns: 60px 1fr; gap: 20px; }
  .flow-num { width: 44px; height: 44px; font-size: 12px; padding: 0; }
}

/* ========== FAQ ========== */
.faq-tabs { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 32px; padding-bottom: 20px; border-bottom: 1px solid var(--color-border); }
.faq-tab { background: transparent; border: 1px solid var(--color-border); padding: 8px 16px; border-radius: 999px; font-family: inherit; font-size: 12px; color: var(--color-text-sub); display: inline-flex; gap: 8px; align-items: center; cursor: pointer; transition: 0.15s; }
.faq-tab:hover { border-color: var(--color-brand-ink); color: var(--color-brand-ink); }
.faq-tab.is-active { background: var(--color-brand); color: #fff; border-color: var(--color-brand); }
.faq-tab.is-active .mono { color: #fff; }
.faq-tab .mono { letter-spacing: 0.04em; }
.faq-tab-n { padding: 1px 7px; border-radius: 999px; background: rgba(0,0,0,0.06); font-size: 10px; color: var(--color-text-mute); }
.faq-tab.is-active .faq-tab-n { background: rgba(255,255,255,0.2); color: #fff; }

.faq-list { border-top: 1px solid var(--color-border-strong); }
.faq-item { border-bottom: 1px solid var(--color-border); }
.faq-q { display: grid; grid-template-columns: 60px 60px 1fr 30px; gap: 16px; align-items: baseline; width: 100%; padding: 24px 0; background: transparent; border: 0; text-align: left; font-family: inherit; color: var(--color-text); cursor: pointer; transition: 0.15s; }
.faq-q:hover { color: var(--color-brand-ink); }
.faq-num { font-size: 11px; color: var(--color-accent); letter-spacing: 0.08em; }
.faq-cat { font-size: 10px; padding: 2px 8px; border: 1px solid var(--color-border-strong); color: var(--color-text-mute); border-radius: 3px; letter-spacing: 0.1em; display: inline-block; text-align: center; }
.faq-q-t { font-size: 16px; line-height: 1.6; font-weight: 500; }
.faq-mark { font-family: var(--font-mono); font-size: 20px; color: var(--color-text-mute); text-align: right; transition: 0.2s; }
.faq-item.is-open .faq-mark { color: var(--color-accent); transform: rotate(180deg); }
.faq-a-wrap { overflow: hidden; transition: max-height 0.3s ease; }
.faq-a { display: grid; grid-template-columns: 60px 1fr; gap: 16px; padding: 0 16px 28px 136px; color: var(--color-text-sub); }
.faq-a-mark { font-size: 11px; color: var(--color-accent); letter-spacing: 0.08em; }
.faq-a p { font-size: 14px; line-height: 1.95; margin: 0; max-width: 68ch; }
@media (max-width: 760px) {
  .faq-q { grid-template-columns: 50px 1fr 20px; }
  .faq-cat { display: none; }
  .faq-q-t { font-size: 14px; }
  .faq-a { grid-template-columns: 1fr; padding: 0 16px 24px 16px; }
}

/* ========== COMPANY ========== */
.company-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--color-border); border: 1px solid var(--color-border); margin-bottom: 40px; }
.company-greeting { background: var(--color-bg); padding: 40px 36px; }
.company-greet-body { font-family: var(--font-heading); font-size: 16px; line-height: 2.2; color: var(--color-text); margin: 20px 0 32px; font-weight: 400; }
.company-sign { display: flex; flex-direction: column; align-items: flex-end; border-top: 1px solid var(--color-border); padding-top: 20px; }
.company-sign .mono { font-size: 11px; color: var(--color-text-mute); letter-spacing: 0.1em; margin-bottom: 8px; }
.company-sign-name { font-family: var(--font-heading); font-size: 26px; color: var(--color-brand-ink); font-weight: 500; letter-spacing: 0.1em; }

.company-table { background: var(--color-bg); padding: 40px 36px; display: flex; flex-direction: column; }
.company-row { display: grid; grid-template-columns: 120px 1fr; gap: 20px; padding: 12px 0; border-bottom: 1px dotted var(--color-border); }
.company-row:last-child { border-bottom: 0; }
.company-k { font-size: 11px; color: var(--color-text-mute); letter-spacing: 0.1em; padding-top: 4px; }
.company-v { font-size: 14px; color: var(--color-text); line-height: 1.7; }

.company-map-visual { border: 1px solid var(--color-border); padding: 24px; color: var(--color-brand-ink); background: var(--color-bg); }
.map-svg { width: 100%; height: auto; display: block; }
body[data-dark="true"] .company-map-visual { color: var(--color-text); }
@media (max-width: 760px) { .company-grid { grid-template-columns: 1fr; } .company-greeting, .company-table { padding: 28px; } }

/* ========== CTA ========== */
.cta-section { background: var(--color-brand); color: #fff; }
.cta-section .idx { color: rgba(255,255,255,0.55); border-top-color: var(--color-accent); }
.cta-section h2 { color: #fff; }
.cta-section .lede { color: rgba(255,255,255,0.7); }
body[data-dark="true"] .cta-section { background: var(--color-surface-2); }

.cta-grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: 1px; background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.1); margin-bottom: 80px; }
.cta-tel, .cta-form { background: var(--color-brand); padding: 40px 36px; }
body[data-dark="true"] .cta-tel, body[data-dark="true"] .cta-form { background: var(--color-surface-2); }
.cta-tel .eyebrow { color: var(--color-accent); margin-bottom: 24px; display: block; }
.cta-tel-label { font-size: 13px; color: rgba(255,255,255,0.55); letter-spacing: 0.04em; margin-bottom: 8px; }
.cta-tel-num { display: block; font-family: var(--font-mono); font-size: clamp(28px, 4vw, 44px); color: #fff; margin: 0 0 28px; letter-spacing: 0.02em; line-height: 1.2; }
.cta-tel-num:hover { color: var(--color-accent); }
.cta-tel-hours { border-top: 1px solid rgba(255,255,255,0.15); padding-top: 20px; display: flex; flex-direction: column; gap: 8px; font-size: 13px; color: rgba(255,255,255,0.75); }
.cta-tel-hours .mono { display: inline-block; width: 44px; color: var(--color-accent); font-size: 11px; letter-spacing: 0.08em; }
.cta-tel-badges { margin-top: 28px; display: flex; gap: 10px; }
.cta-chip { display: inline-flex; align-items: center; gap: 8px; padding: 6px 12px; background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.15); border-radius: 999px; font-size: 11px; color: rgba(255,255,255,0.85); letter-spacing: 0.06em; }

.cta-form-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 28px; }
.cta-form-head .eyebrow { color: var(--color-accent); }
.cta-steps { display: flex; gap: 8px; font-size: 10px; }
.cta-step { display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px; border: 1px solid rgba(255,255,255,0.15); border-radius: 999px; color: rgba(255,255,255,0.4); }
.cta-step.is-on { color: rgba(255,255,255,0.8); border-color: rgba(255,255,255,0.4); }
.cta-step.is-now { background: var(--color-accent); color: var(--color-brand); border-color: var(--color-accent); }
.cta-step-l { letter-spacing: 0.08em; }
.cta-step-n { font-variant-numeric: tabular-nums; }

.cta-form-body { display: flex; flex-direction: column; gap: 20px; }
.field { display: flex; flex-direction: column; gap: 8px; }
.field label { font-family: var(--font-mono); font-size: 10px; color: rgba(255,255,255,0.5); letter-spacing: 0.12em; }
.field input, .field textarea { background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.15); border-radius: var(--radius-sm); padding: 14px 16px; color: #fff; font-family: inherit; font-size: 15px; outline: none; transition: 0.15s; }
.field input::placeholder, .field textarea::placeholder { color: rgba(255,255,255,0.3); }
.field input:focus, .field textarea:focus { border-color: var(--color-accent); background: rgba(255,255,255,0.08); }
.field textarea { resize: vertical; min-height: 100px; }

.radio-row { display: flex; gap: 8px; }
.radio-chip { display: inline-flex; padding: 10px 16px; border: 1px solid rgba(255,255,255,0.2); border-radius: var(--radius-sm); font-size: 13px; color: rgba(255,255,255,0.7); cursor: pointer; transition: 0.15s; }
.radio-chip input { position: absolute; opacity: 0; pointer-events: none; }
.radio-chip:hover { border-color: rgba(255,255,255,0.5); color: #fff; }
.radio-chip.is-on { background: var(--color-accent); color: var(--color-brand); border-color: var(--color-accent); font-weight: 600; }

.cta-form-foot { display: flex; justify-content: space-between; align-items: center; padding-top: 8px; gap: 16px; }
.form-note { font-size: 10px; color: rgba(255,255,255,0.4); letter-spacing: 0.1em; }
.cta-form-foot .btn-primary { background: var(--color-accent); color: var(--color-brand); }
.cta-form-foot .btn-primary:hover:not(:disabled) { background: #fff; }
.cta-form-foot .btn-primary:disabled { opacity: 0.4; cursor: not-allowed; }
.cta-form-foot .btn-ghost { color: #fff; border-color: rgba(255,255,255,0.3); }

.cta-confirm { border: 1px solid rgba(255,255,255,0.15); border-radius: var(--radius-sm); padding: 8px 20px; gap: 0; }
.confirm-row { display: grid; grid-template-columns: 100px 1fr; padding: 14px 0; border-bottom: 1px dotted rgba(255,255,255,0.1); gap: 16px; align-items: baseline; }
.confirm-row:last-of-type { border-bottom: 0; }
.confirm-row .mono { font-size: 10px; color: var(--color-accent); letter-spacing: 0.1em; }
.confirm-row span:last-child { color: #fff; font-size: 14px; }

.cta-final { text-align: center; padding: 40px 0 0; border-top: 1px solid rgba(255,255,255,0.15); }
.cta-final-quote { font-family: var(--font-heading); font-size: clamp(22px, 3vw, 34px); color: #fff; line-height: 1.8; margin: 0 0 16px; font-weight: 400; }
.cta-final-sign { font-size: 11px; color: var(--color-accent); letter-spacing: 0.2em; }

@media (max-width: 760px) { .cta-grid { grid-template-columns: 1fr; } }

/* ========== FOOTER ========== */
.site-footer { background: var(--color-brand-ink); color: rgba(255,255,255,0.7); padding: 64px 0 32px; }
body[data-dark="true"] .site-footer { background: #040b17; }
.footer-top { display: grid; grid-template-columns: 1.3fr 2fr; gap: 60px; padding-bottom: 40px; border-bottom: 1px solid rgba(255,255,255,0.1); margin-bottom: 24px; }
.footer-tag { font-family: var(--font-heading); font-size: 16px; color: rgba(255,255,255,0.9); margin: 16px 0 12px; }
.footer-brand .logo-word-2 { color: #fff; }
.footer-lic { font-size: 11px; color: rgba(255,255,255,0.45); letter-spacing: 0.06em; }
.footer-cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.footer-cols h4 { font-size: 11px; color: var(--color-accent); letter-spacing: 0.14em; margin: 0 0 16px; text-transform: uppercase; font-weight: 600; }
.footer-cols ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.footer-cols a, .footer-cols li { font-size: 13px; color: rgba(255,255,255,0.65); transition: 0.15s; }
.footer-cols a:hover { color: var(--color-accent); }
.footer-bottom { display: flex; justify-content: space-between; font-size: 11px; color: rgba(255,255,255,0.4); letter-spacing: 0.04em; flex-wrap: wrap; gap: 16px; }
@media (max-width: 760px) {
  .footer-top { grid-template-columns: 1fr; gap: 32px; }
  .footer-cols { grid-template-columns: 1fr 1fr; }
}

/* ========== STICKY MOBILE CTA ========== */
.sticky-cta { display: none; position: fixed; bottom: 0; left: 0; right: 0; background: var(--color-brand); z-index: 90; border-top: 1px solid rgba(255,255,255,0.1); }
.scta { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 4px; padding: 12px 8px; color: #fff; font-size: 11px; letter-spacing: 0.06em; border-right: 1px solid rgba(255,255,255,0.1); }
.scta:last-child { border-right: 0; }
.scta-icon { color: var(--color-accent); }
.scta-tel { background: var(--color-accent); color: var(--color-brand); }
.scta-tel .scta-icon { color: var(--color-brand); }
@media (max-width: 760px) {
  .sticky-cta { display: flex; }
  body { padding-bottom: 64px; }
}
