/* ============================================================
   Kurumsal Sporlar — offering detail page (tur / turnuva / deneyim)
   Builds on kurumsal.css + site.css. Cinematic hero + sticky
   request rail, adapted from the Sporara tour-detail pattern.
   ============================================================ */

.detail-wrap { max-width: 1240px; margin: 0 auto; padding: 0 32px; }
@media (max-width: 720px){ .detail-wrap { padding: 0 20px; } }

/* breadcrumb */
.crumb { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--sp-mute); padding: 20px 0 4px; flex-wrap: wrap; }
.crumb a { color: var(--sp-mute); text-decoration: none; font-weight: 500; }
.crumb a:hover { color: var(--pink); }
.crumb svg { width: 13px; height: 13px; opacity: 0.6; }
.crumb .now { color: var(--sp-ink); font-weight: 700; }

/* ---------- Cinema hero ---------- */
.cinema {
  border-radius: var(--radius-xl); overflow: hidden; margin: 12px 0 0; height: 540px; position: relative;
  color: #fff; background: var(--sp-ink);
}
.cinema[data-theme="water"]  { background: linear-gradient(155deg, #0090C8 0%, #0058A8 55%, #002F6B 100%); }
.cinema[data-theme="court"]  { background: linear-gradient(155deg, #14060F 0%, #2A0A20 45%, var(--sp-ink) 100%); }
.cinema[data-theme="field"]  { background: linear-gradient(155deg, #0066ff 0%, #0040A8 60%, #00205E 100%); }
.cinema[data-theme="energy"] { background: linear-gradient(155deg, #E0009B 0%, #8A0560 50%, var(--sp-ink) 100%); }
.cinema[data-theme="wellness"] { background: linear-gradient(155deg, #119C73 0%, #0C6A52 55%, #063A2E 100%); }
.cinema[data-theme="corporate"] { background: linear-gradient(155deg, #1B3A6B 0%, #0C2247 55%, var(--sp-ink) 100%); }
.cinema .glow { position: absolute; width: 420px; height: 420px; border-radius: 50%; filter: blur(10px); opacity: 0.4; pointer-events: none; }
.cinema .glow.a { top: -120px; right: -80px; background: radial-gradient(circle, var(--sp-lime) 0%, transparent 65%); }
.cinema .glow.b { bottom: -160px; left: -100px; background: radial-gradient(circle, var(--kp-pink) 0%, transparent 65%); opacity: 0.5; }
.cinema .scrim { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(10,15,28,0.1) 0%, transparent 30%, rgba(10,15,28,0.5) 78%, rgba(10,15,28,0.86) 100%); }
.cinema .wm-icon { position: absolute; right: 40px; bottom: 24px; width: 280px; opacity: 0.12; }
.cinema .wm-icon svg { width: 100%; height: 100%; }
.cinema .gallery-cta { position: absolute; top: 22px; left: 22px; padding: 8px 14px; background: rgba(255,255,255,0.16); backdrop-filter: blur(14px); border: 1px solid rgba(255,255,255,0.24); border-radius: var(--radius-pill); color: #fff; font-size: 13px; font-weight: 700; display: inline-flex; align-items: center; gap: 7px; cursor: pointer; }
.cinema .gallery-cta svg { width: 14px; height: 14px; }
.cinema .thumbs { position: absolute; top: 22px; right: 22px; display: flex; gap: 8px; }
.cinema .thumbs .th { width: 78px; height: 58px; border-radius: 10px; border: 2px solid rgba(255,255,255,0.35); background-size: cover; background-position: center; }
.cinema .content { position: relative; padding: 48px 48px 92px; max-width: 780px; height: 100%; display: flex; flex-direction: column; justify-content: flex-end; }
.cinema .badges { display: flex; gap: 8px; margin-bottom: 16px; flex-wrap: wrap; }
.cinema .b { display: inline-flex; align-items: center; gap: 6px; padding: 6px 13px; border-radius: var(--radius-pill); background: rgba(255,255,255,0.16); backdrop-filter: blur(8px); font-size: 12.5px; font-weight: 700; color: #fff; }
.cinema .b.pink { background: var(--kp-pink); }
.cinema .b.lime { background: var(--sp-lime); color: var(--sp-ink); }
.cinema .b svg { width: 14px; height: 14px; }
.cinema h1 { font-family: var(--font-display); font-weight: 700; font-size: clamp(38px, 5vw, 64px); letter-spacing: -0.04em; line-height: 0.98; margin: 0 0 14px; color: #fff; }
.cinema .lead { font-size: 18px; line-height: 1.5; color: rgba(255,255,255,0.86); margin: 0; max-width: 560px; }
@media (max-width: 720px){ .cinema { height: 460px; } .cinema .content { padding: 28px 28px 78px; } .cinema .thumbs { display: none; } }

/* ---------- Snapshot strip ---------- */
.snapshot { margin: -52px 24px 0; position: relative; z-index: 5; background: #fff; border: 1px solid var(--sp-line); border-radius: var(--radius-lg); box-shadow: var(--shadow-md); display: grid; grid-template-columns: repeat(4, 1fr); }
.snapshot .s { padding: 22px 24px; border-right: 1px solid var(--sp-line); display: flex; gap: 14px; align-items: center; }
.snapshot .s:last-child { border-right: 0; }
.snapshot .s .ic { width: 42px; height: 42px; border-radius: 12px; background: var(--sp-blue-50); display: grid; place-items: center; flex-shrink: 0; }
.snapshot .s .ic svg { width: 21px; height: 21px; color: var(--sp-blue); }
.snapshot .s.pink .ic { background: var(--kp-pink-50); } .snapshot .s.pink .ic svg { color: var(--pink); }
.snapshot .s.lime .ic { background: var(--sp-lime); } .snapshot .s.lime .ic svg { color: var(--sp-ink); }
.snapshot .s .l { font-size: 11px; letter-spacing: 0.07em; text-transform: uppercase; font-weight: 700; color: var(--sp-mute); }
.snapshot .s .v { font-family: var(--font-display); font-weight: 700; font-size: 18px; letter-spacing: -0.02em; margin-top: 3px; line-height: 1.05; }
@media (max-width: 820px){ .snapshot { grid-template-columns: 1fr 1fr; margin: -52px 0 0; } .snapshot .s:nth-child(2){ border-right:0; } .snapshot .s:nth-child(1),.snapshot .s:nth-child(2){ border-bottom: 1px solid var(--sp-line); } }

/* ---------- Two-column layout ---------- */
.detail-layout { display: grid; grid-template-columns: 1fr 380px; gap: 44px; padding: 48px 0 24px; align-items: start; }
.detail-main { min-width: 0; }
.detail-rail { position: sticky; top: 96px; }
@media (max-width: 940px){ .detail-layout { grid-template-columns: 1fr; gap: 32px; } .detail-rail { position: static; } }

.dblock { margin-bottom: 48px; }
.dblock h2 { font-family: var(--font-display); font-weight: 700; font-size: 26px; letter-spacing: -0.03em; margin: 0 0 16px; }
.dblock h3 { font-size: 17px; margin: 24px 0 10px; }
.dblock p { font-size: 16px; line-height: 1.65; color: var(--sp-ink-soft); margin: 0 0 14px; }
.dblock p.lead { font-size: 18.5px; line-height: 1.55; color: var(--sp-ink); }

/* highlight chips row */
.hl-row { display: flex; gap: 10px; flex-wrap: wrap; margin: 4px 0 8px; }
.hl-row .h { display: inline-flex; align-items: center; gap: 8px; padding: 9px 15px; background: #fff; border: 1px solid var(--sp-line); border-radius: var(--radius-pill); font-size: 13.5px; font-weight: 600; }
.hl-row .h svg { width: 16px; height: 16px; color: var(--pink); }

/* ---------- Program timeline ---------- */
.timeline { position: relative; }
.t-row { display: grid; grid-template-columns: 56px 1fr; gap: 18px; padding: 12px 0; position: relative; }
.t-row:not(:last-child)::after { content: ''; position: absolute; left: 27px; top: 40px; bottom: -10px; border-left: 2px dashed var(--sp-line-strong); }
.t-row .marker { width: 56px; height: 56px; border-radius: 16px; background: var(--sp-ink); color: #fff; display: grid; place-items: center; position: relative; z-index: 1; font-family: var(--font-display); font-weight: 700; font-size: 17px; }
.t-row:first-child .marker { background: var(--sp-blue); }
.t-row .marker.pink { background: var(--pink); }
.t-row .marker.lime { background: var(--sp-lime); color: var(--sp-ink); }
.t-row .tbody { background: #fff; border: 1px solid var(--sp-line); border-radius: var(--radius-md); padding: 16px 20px; }
.t-row .tbody .top { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; margin-bottom: 5px; }
.t-row .tbody .t { font-family: var(--font-display); font-weight: 700; font-size: 17px; letter-spacing: -0.015em; }
.t-row .tbody .when { font-size: 12.5px; color: var(--sp-mute); font-weight: 600; display: inline-flex; align-items: center; gap: 5px; flex-shrink: 0; }
.t-row .tbody .when svg { width: 13px; height: 13px; }
.t-row .tbody p { font-size: 14.5px; line-height: 1.55; color: var(--sp-ink-soft); margin: 0; }

/* ---------- Includes (2-col) ---------- */
.includes { display: grid; grid-template-columns: 1fr 1fr; gap: 24px 36px; }
.incl-col h4 { font-family: var(--font-display); font-size: 15px; font-weight: 700; margin: 0 0 12px; display: flex; align-items: center; gap: 8px; }
.incl-col h4 svg { width: 17px; height: 17px; }
.incl-col h4.yes svg { color: var(--sp-success); }
.incl-col h4.no svg { color: var(--sp-mute-2); }
.incl-col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 11px; }
.incl-col li { font-size: 14.5px; color: var(--sp-ink-soft); display: flex; align-items: flex-start; gap: 9px; line-height: 1.45; }
.incl-col li svg { width: 16px; height: 16px; flex-shrink: 0; margin-top: 2px; }
.incl-col li.yes svg { color: var(--sp-success); }
.incl-col li.no svg { color: var(--sp-mute-2); }
.incl-col li.no { color: var(--sp-mute); }
@media (max-width: 560px){ .includes { grid-template-columns: 1fr; } }

/* ---------- Gallery ---------- */
.gallery { display: grid; grid-template-columns: 2fr 1fr 1fr; grid-template-rows: 1fr 1fr; gap: 12px; height: 360px; }
.gallery .photo { border-radius: var(--radius-md); }
.gallery .g1 { grid-row: 1 / 3; }
@media (max-width: 560px){ .gallery { grid-template-columns: 1fr 1fr; height: auto; } .gallery .g1 { grid-row: auto; aspect-ratio: 16/10; grid-column: 1 / 3; } .gallery .photo:not(.g1){ aspect-ratio: 4/3; } }

/* ---------- FAQ ---------- */
.faq { display: grid; gap: 12px; }
.faq details { background: #fff; border: 1px solid var(--sp-line); border-radius: var(--radius-md); padding: 0; overflow: hidden; }
.faq summary { list-style: none; cursor: pointer; padding: 18px 20px; font-weight: 700; font-size: 15.5px; color: var(--sp-ink); display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary .pl { width: 22px; height: 22px; flex-shrink: 0; position: relative; transition: transform var(--dur-2); }
.faq summary .pl::before, .faq summary .pl::after { content: ''; position: absolute; background: var(--pink); border-radius: 2px; }
.faq summary .pl::before { left: 0; right: 0; top: 10px; height: 2px; }
.faq summary .pl::after { top: 0; bottom: 0; left: 10px; width: 2px; transition: opacity var(--dur-2); }
.faq details[open] summary .pl::after { opacity: 0; }
.faq details p { padding: 0 20px 20px; margin: 0; font-size: 14.5px; line-height: 1.6; color: var(--sp-ink-soft); }

/* ---------- Request rail ---------- */
.rail-card { background: #fff; border: 1px solid var(--sp-line); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); overflow: hidden; }
.rail-card .rhead { padding: 22px 22px 18px; border-bottom: 1px solid var(--sp-line); }
.rail-card .rhead .badge { display: inline-flex; align-items: center; gap: 6px; background: var(--kp-pink-50); color: var(--pink); font-weight: 700; font-size: 12px; padding: 5px 11px; border-radius: var(--radius-pill); }
.rail-card .rhead .badge svg { width: 13px; height: 13px; }
.rail-card .rhead .title { font-family: var(--font-display); font-weight: 700; font-size: 22px; letter-spacing: -0.025em; margin: 12px 0 4px; }
.rail-card .rhead .sub { font-size: 13.5px; color: var(--sp-mute); margin: 0; }
.rail-card .rform { padding: 16px 18px; display: flex; flex-direction: column; gap: 10px; }
.rail-card .rf { display: flex; flex-direction: column; gap: 4px; border: 1.5px solid var(--sp-line); border-radius: var(--radius-sm); padding: 9px 13px; transition: border-color var(--dur-1); }
.rail-card .rf:focus-within { border-color: var(--sp-blue); }
.rail-card .rf .l { font-size: 10px; letter-spacing: 0.07em; text-transform: uppercase; font-weight: 700; color: var(--sp-mute); }
.rail-card .rf input, .rail-card .rf select { border: none; background: transparent; font-family: var(--font-text); font-size: 14.5px; font-weight: 600; color: var(--sp-ink); outline: none; padding: 0; width: 100%; appearance: none; -webkit-appearance: none; }
.rail-card .rf input::placeholder { color: var(--sp-mute-2); font-weight: 500; }
.rail-card .rrow { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.rail-card .rfoot { padding: 4px 18px 18px; display: flex; flex-direction: column; gap: 9px; }
.rail-card .perks { padding: 16px 22px; border-top: 1px solid var(--sp-line); background: var(--sp-surface); display: grid; gap: 9px; }
.rail-card .perks .it { font-size: 13px; color: var(--sp-ink-soft); display: flex; align-items: center; gap: 9px; font-weight: 500; }
.rail-card .perks .it svg { width: 15px; height: 15px; color: var(--sp-success); flex-shrink: 0; }
.rail-aside { margin-top: 16px; display: flex; align-items: center; gap: 10px; justify-content: center; font-size: 13px; color: var(--sp-mute); }
.rail-aside svg { width: 15px; height: 15px; color: var(--sp-blue); }

/* ---------- Related offerings ---------- */
.related-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
@media (max-width: 860px){ .related-grid { grid-template-columns: 1fr; } }

/* divider */
.hr { border: none; border-top: 1px solid var(--sp-line); margin: 0 0 48px; }
