@charset "UTF-8";
/* ============================================================
   thanks.css — お問い合わせ完了ページ（TimeRex日程調整）
   llmo LP のトンマナ準拠：白ベース＋オレンジ#e77f32＋ティール#2f7e89＋紺#25329d
   本文 Noto Sans JP／英字 futura-pt。.ty スコープ自己完結・テーマ .ty--ai/.ty--pro
   フォントはLP本体（本文約16-17px）に合わせて底上げ。
   ============================================================ */

.ty, .ty * { box-sizing: border-box; }

.ty {
  --ink-1:#1b2030; --ink-2:#4d5562; --ink-3:#646c79; --ink-4:#737a85;
  --radius-lg:16px; --radius-md:12px; --pill:999px;
  --sh-card:0 2px 8px rgba(20,24,40,.07);
  --sh-step:0 16px 40px rgba(231,127,50,.16);
  font-family:'Noto Sans JP', "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", sans-serif;
  font-size:15.5px; color:var(--ink-2); line-height:1.8; background:#e9ecf0; padding:36px 16px; margin:0;
  -webkit-font-smoothing:antialiased;
}
.ty--ai  { --acc:#e77f32; --acc-d:#d2641c; --sub:#2f7e89; --navy:#25329d; --cream:#fff7ef; --mark:#ffd9a8; }
.ty--pro { --acc:#e77f32; --acc-d:#d2641c; --sub:#2f7e89; --navy:#2b2f3a; --cream:#fdf6ee; --mark:#ffd9a8; }
.ty-en { font-family:"futura-pt","Futura","Century Gothic",sans-serif; }
.pc { display:inline; }

.ty-card { max-width:900px; margin:0 auto; background:#fff; border-radius:var(--radius-lg); box-shadow:0 16px 54px rgba(20,24,40,.12); overflow:hidden; }
.ty-step .ty-meet { margin:2px 0 20px; }
.ty-band { height:6px; background:linear-gradient(90deg,var(--acc),var(--sub)); }
.ty-inner { padding:34px 44px 44px; background:linear-gradient(180deg,var(--cream) 0%,#fff 250px); }

/* hero */
.ty-hero { position:relative; margin-bottom:18px; }
.ty-hero > * { position:relative; z-index:1; }
.ty-hero .ghost { position:absolute; top:-16px; left:50%; transform:translateX(-50%); font-size:92px; font-weight:800; letter-spacing:.04em; color:var(--ink-1); opacity:.05; white-space:nowrap; pointer-events:none; z-index:0; }

/* progress */
.ty-prog { display:flex; align-items:center; justify-content:center; gap:11px; margin:0; }
.ty-prog .st { display:flex; align-items:center; gap:8px; font-size:13.5px; color:var(--ink-4); font-weight:600; }
.ty-prog .st .nm { width:28px; height:28px; border-radius:50%; background:#eef0f3; color:var(--ink-4); display:grid; place-items:center; font-size:14px; font-weight:700; }
.ty-prog .st.is-done .nm { background:var(--sub); color:#fff; }
.ty-prog .st.is-now { color:var(--acc-d); }
.ty-prog .st.is-now .nm { background:var(--acc); color:#fff; box-shadow:0 4px 10px rgba(231,127,50,.35); }
.ty-prog .ln { width:32px; height:2px; background:#e2e5ea; }

/* heading */
.ty-title { text-align:center; font-size:34px; font-weight:900; letter-spacing:.01em; line-height:1.35; margin:14px 0 0; color:var(--ink-1); }
.ty-subtitle { text-align:center; font-size:14.5px; color:var(--ink-2); line-height:1.7; margin:14px auto 0; max-width:620px; }

/* prefill */
.ty-prefill { display:flex; align-items:center; justify-content:center; gap:10px; max-width:620px; margin:20px auto 26px; background:var(--cream); border:1px solid #f3d9bd; border-radius:var(--radius-md); padding:13px 20px; font-size:14.5px; color:#7a5230; text-align:center; }
.ty-prefill .ck { flex:0 0 auto; width:22px; height:22px; border-radius:50%; background:var(--acc); color:#fff; display:grid; place-items:center; font-size:13px; font-weight:700; }
.ty-prefill strong { color:var(--acc-d); font-weight:700; }

/* section label */
.ty-sec { text-align:center; margin-bottom:14px; }
.ty-sec .en { display:block; font-size:12.5px; letter-spacing:.2em; font-weight:700; color:var(--sub); text-transform:uppercase; }
.ty-sec .ja { font-size:18px; font-weight:800; color:var(--ink-1); margin:3px 0 0; }

/* hosts */
.ty-hosts { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:14px; }
.ty-hosts--solo { grid-template-columns:1fr; max-width:480px; margin-left:auto; margin-right:auto; }
.ty-host { display:flex; align-items:center; gap:14px; background:#fff; border:1px solid #ededf0; border-radius:var(--radius-md); padding:16px; box-shadow:var(--sh-card); }
.ty-host img { width:68px; height:68px; border-radius:50%; object-fit:cover; object-position:center 20%; flex-shrink:0; }
.ty-host .role { font-size:12.5px; font-weight:700; color:var(--sub); letter-spacing:.02em; }
.ty-host .nm { font-size:16.5px; font-weight:800; color:var(--ink-1); margin:3px 0 6px; }
.ty-host .nm small { font-size:12px; color:var(--ink-4); font-weight:500; margin-left:5px; }
.ty-host .bio { font-size:13.5px; color:var(--ink-2); line-height:1.65; }
.ty-host .bio b { color:var(--acc-d); font-weight:700; }
.ty-meet { text-align:center; font-size:13.5px; color:var(--ink-3); margin:0 0 22px; }
.ty-meet b { color:var(--ink-1); }

/* step — page hero CTA block */
.ty-step { background:var(--cream); border:2px solid var(--acc); border-radius:var(--radius-lg); padding:28px 28px; margin-bottom:24px; box-shadow:var(--sh-step); }
.ty-step h2 { text-align:center; font-size:24px; font-weight:900; color:var(--ink-1); margin:0 0 8px; }

/* PC embed / SP button */
.ty-embed { display:block; }
.ty-mobile { display:none; }
.ty-cal { display:block; width:100%; border:1px solid #e7e3df; border-radius:var(--radius-md); min-height:680px; background:#fff; }
#timerex_calendar { min-height:680px; }
#timerex_calendar iframe { border:0; border-radius:var(--radius-md); width:100%; }

.ty-cta { display:block; text-align:center; background:#27a657; color:#fff; text-decoration:none; font-weight:700; font-size:17.5px; padding:17px 24px; border-radius:12px; box-shadow:0 5px 14px rgba(31,139,72,.28); }
.ty-cta:active { transform:translateY(1px); }
.ty-cta-note { text-align:center; font-size:13px; color:var(--ink-3); margin:11px 0 2px; }

.ty-ask { margin-top:18px; background:#fff; border:1px solid #f0d8bd; border-radius:var(--radius-md); padding:15px 18px; font-size:13.5px; color:#7a5230; }
.ty-ask b { display:block; margin-bottom:7px; color:#5a3a18; }
.ty-ask ul { margin:0; padding-left:18px; }

/* phone (sub) */
.ty-phone { text-align:center; margin:8px 0 28px; padding-top:24px; border-top:1px solid #eee; }
.ty-phone .tt { font-size:13.5px; font-weight:700; color:var(--ink-2); margin-bottom:6px; }
.ty-phone .num { font-size:27px; font-weight:700; color:var(--acc-d); text-decoration:none; letter-spacing:.03em; }
.ty-phone .hr { font-size:12.5px; color:var(--ink-4); margin-top:4px; }

/* company */
.ty-company { background:#f6f7f9; border-radius:var(--radius-md); padding:22px 26px; font-size:14px; }
.ty-company h3 { font-size:12px; font-weight:700; color:var(--sub); letter-spacing:.16em; text-transform:uppercase; margin:0 0 14px; }
.ty-company dl { display:grid; grid-template-columns:96px 1fr; gap:10px 14px; margin:0; }
.ty-company dt { color:var(--ink-4); }
.ty-company dd { margin:0; color:var(--ink-1); }

/* back */
.ty-back { text-align:center; margin-top:26px; }
.ty-back a { display:inline-block; padding:14px 38px; background:#fff; color:var(--ink-3); border:1px solid #dfe2e7; border-radius:var(--pill); font-size:14px; text-decoration:none; }

/* calendar mock (preview only) */
.ty-calmock { border:1px solid #ece8e2; border-radius:var(--radius-md); padding:18px; background:#fff; }
.ty-calmock .hd { display:flex; justify-content:space-between; align-items:center; margin-bottom:12px; }
.ty-calmock .who { font-weight:700; font-size:13.5px; color:var(--ink-1); }
.ty-calmock .who small { display:block; font-size:11.5px; color:var(--ink-4); font-weight:400; }
.ty-calmock .brand { font-size:12px; color:var(--sub); font-weight:700; }
.ty-calmock .bar { display:flex; gap:7px; margin:12px 0 14px; }
.ty-calmock .bar div { flex:1; text-align:center; font-size:11.5px; padding:8px 0; border-radius:6px; background:#f1f2f5; color:var(--ink-4); }
.ty-calmock .bar .on { background:#fdebdc; color:var(--acc-d); font-weight:700; }
.ty-calmock .bar .skip { background:#e6f2f1; color:var(--sub); }
.ty-calmock .grid { display:grid; grid-template-columns:repeat(5,1fr); gap:7px; }
.ty-calmock .grid .d { text-align:center; font-size:11.5px; color:var(--ink-4); padding-bottom:3px; }
.ty-calmock .grid .s { font-size:12.5px; text-align:center; padding:10px 2px; border-radius:6px; background:var(--acc); color:#fff; font-weight:600; }
.ty-calmock .grid .s.off { background:#f1f2f5; color:#c8ccd2; font-weight:400; }

@media all and (max-width:600px) {
  .ty { padding:16px 10px; font-size:15px; }
  .ty-inner { padding:26px 20px 34px; background:linear-gradient(180deg,var(--cream) 0%,#fff 200px); }
  .ty-title { font-size:27px; }
  .ty-hero .ghost { font-size:60px; top:-8px; }
  .ty-hosts { grid-template-columns:1fr; }
  .ty-embed { display:none; }
  .ty-mobile { display:block; }
  .pc { display:none; }
}
