/* ══════════════════════════════════════════════════
   HOME PAGE — ported 1:1 from home.html prototype
   All values are exact matches from the source file
══════════════════════════════════════════════════ */

/* ── Utilities ── */
.teal-gradient     { background: linear-gradient(90deg, #0a7f7d 0%, #10b3b0 45%, #5fc7c4 100%); }
.red-gradient      { background: linear-gradient(90deg, #f2896e 0%, #ea4a35 55%, #a8281d 100%); }
.red-gradient-diag { background: linear-gradient(135deg, #f2896e 0%, #ea4a35 55%, #a8281d 100%); }
.gradient-text     { background: linear-gradient(135deg, #0a7f7d 0%, #10b3b0 50%, #5fc7c4 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.cover-img         { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.clearfix          { clear: both; }
.fw-bold           { font-weight: 700; }
.inline-mid        { display: inline-block; vertical-align: middle; }
.text-center       { text-align: center; }
.mt-56             { margin-top: 56px; }

/* scroll offset for sticky nav */
#tournaments, #championship, #cruises, #spajongg { scroll-margin-top: 80px; }

/* ── Hero ── */
.hero-wrap          { padding: 0 24px 24px 40px; }
.hero-inner         { height: 460px; border-radius: 16px; position: relative; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.hero-slide         { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: opacity 1.2s ease; }
.hero-overlay       { position: absolute; inset: 0; background: linear-gradient(155deg, rgba(10,127,125,0.86) 0%, rgba(16,179,176,0.62) 38%, rgba(242,137,110,0.72) 65%, rgba(217,58,44,0.84) 100%); }
.hero-content       { position: relative; text-align: center; color: #ffffff; z-index: 2; padding: 0 24px; }
.hero-season-label  { font-size: 12px; letter-spacing: 4px; text-transform: uppercase; margin-bottom: 20px; font-weight: 600; }
.hero-title         { font-family: "Cormorant Garamond", Georgia, serif; font-size: 68px; font-weight: 500; font-style: italic; line-height: 1.05; letter-spacing: -1px; margin: 0 auto 24px; text-shadow: 0 2px 4px rgba(0,0,0,0.45), 0 6px 24px rgba(0,0,0,0.35); max-width: 820px; }
.hero-buttons       { display: flex; gap: 12px; justify-content: center; }
.hero-btn-primary   { background: #ffffff; color: #0a7f7d; border: none; padding: 16px 32px; border-radius: 40px; font-size: 13px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; cursor: pointer; text-decoration: none; display: inline-block; transition: opacity .18s, transform .18s; }
.hero-btn-primary:hover  { opacity: .9; transform: translateY(-2px); text-decoration: none; color: #0a7f7d; }
.hero-btn-secondary { background: transparent; color: #ffffff; border: 2px solid #ffffff; padding: 16px 32px; border-radius: 40px; font-size: 13px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; cursor: pointer; text-decoration: none; display: inline-block; transition: background .18s; }
.hero-btn-secondary:hover { background: rgba(255,255,255,.15); text-decoration: none; color: #fff; }
.hero-dots          { position: absolute; bottom: 24px; left: 0; right: 0; display: flex; justify-content: center; gap: 8px; z-index: 3; }
.hero-dot           { width: 8px; height: 8px; border-radius: 4px; background: #ffffff; opacity: 0.55; transition: all 0.4s ease; }
.hero-dot.active    { width: 24px; opacity: 1; }

/* ── Marquee ── */
@keyframes bbmarquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.marquee-wrap       { color: #ffffff; padding: 16px 0; overflow: hidden; }
.bb-marquee-track   { display: flex; gap: 40px; width: max-content; animation: bbmarquee 40s linear infinite; }
.marquee-item       { display: flex; align-items: center; gap: 40px; font-family: "Cormorant Garamond", Georgia, serif; font-size: 34px; font-weight: 500; font-style: italic; white-space: nowrap; letter-spacing: -0.5px; }
.marquee-div        { font-size: 20px; font-style: normal; opacity: 0.85; }

/* ── Section helpers ── */
.section-h          { text-align: center; font-family: "Cormorant Garamond", Georgia, serif; font-weight: 500; font-style: italic; color: #1f1f2e; letter-spacing: -0.5px; display: flex; align-items: center; justify-content: center; gap: 16px; line-height: 1; }
.section-h--lg      { font-size: 44px; }
.section-h--md      { font-size: 36px; }
.section-sub        { text-align: center; font-size: 14px; color: #7e7a8b; margin-top: 12px; max-width: 560px; margin-left: auto; margin-right: auto; }
.section-eyebrow    { font-size: 11px; letter-spacing: 3px; text-transform: uppercase; color: #0a7f7d; font-weight: 700; margin-bottom: 16px; text-align: center; }

/* ── Sections ── */
.section-tournaments { padding: 72px 48px 80px; background: #fdfaf3; }
.section-season      { padding: 48px; }
.section-championship{ padding: 0 24px 48px; }
.section-cruises     { padding: 80px 48px; background: #eef6f6; }
.section-countdown   { padding: 88px 48px; background: linear-gradient(180deg, #cdecec 0%, #e6f5f5 100%); text-align: center; position: relative; overflow: hidden; }
.section-testimonial { padding: 48px; text-align: center; }
.section-letter      { padding: 96px 48px; background: #ffffff; color: #1f1f2e; }
.section-stories     { padding: 88px 48px; background: #fcf8ee; }
.section-virtual     { padding: 96px 48px; text-align: center; position: relative; overflow: hidden; }

/* ── Grids ── */
.tournaments-grid   { display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; margin-top: 48px; }
.season-grid        { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 32px; }
.championship-grid  { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
.cruises-grid       { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.stories-grid       { display: grid; grid-template-columns: 2fr 1fr 1fr; grid-template-rows: auto auto; gap: 20px; }
.stories-featured   { grid-row: span 2; }

/* ── Tournament cards ── */
.t-card             { cursor: pointer; transition: transform 0.3s ease; }
.t-card:hover       { transform: rotate(0deg) !important; }
.t-card-inner       { background: #ffffff; padding: 8px; box-shadow: 0 12px 30px rgba(0,0,0,0.08), 0 1px 3px rgba(0,0,0,0.04); border-radius: 2px; display: block; text-decoration: none; color: inherit; }
.t-card-inner:hover { text-decoration: none; color: inherit; }
.t-card-img         { position: relative; aspect-ratio: 4/3; overflow: hidden; background: #eee; }
.t-card-img img     { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.t-date-badge       { position: absolute; top: 8px; left: 8px; background: #d93a2c; color: #ffffff; padding: 6px 8px; text-align: center; border-radius: 2px; transform: rotate(-4deg); box-shadow: 0 4px 12px rgba(0,0,0,0.15); }
.t-date-month       { font-size: 8px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; line-height: 1; }
.t-date-day         { font-size: 14px; font-weight: 800; margin: 3px 0; line-height: 1; }
.t-date-year        { font-size: 8px; font-weight: 600; letter-spacing: 1px; line-height: 1; }
.t-card-body        { padding: 16px 4px 10px; text-align: center; display: flex; flex-direction: column; align-items: center; }
.t-city             { font-family: "Cormorant Garamond", Georgia, serif; font-size: 24px; font-style: italic; font-weight: 500; color: #1f1f2e; line-height: 1.1; letter-spacing: -0.3px; }
.t-venue            { font-family: "Cormorant Garamond", Georgia, serif; font-size: 9px; letter-spacing: 1.5px; text-transform: uppercase; color: #7e7a8b; margin-top: 6px; font-style: italic; }
.t-desc             { font-family: "Cormorant Garamond", Georgia, serif; font-size: 12px; font-style: italic; color: #5a5665; margin-top: 10px; line-height: 1.3; }

/* ── Badges ── */
.badge              { padding: 3px 8px; font-size: 8px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; border-radius: 20px; margin-bottom: 10px; }
.badge-open         { background: #cdecec; color: #0a7f7d; }
.badge-tba          { background: #fbcfe8; color: #be185d; }
.badge-new          { background: #fde68a; color: #b45309; }
.badge-sold         { position: absolute; top: 8px; right: 8px; background: #d93a2c; color: #ffffff; padding: 4px 8px; font-size: 8px; font-weight: 800; letter-spacing: 1px; text-transform: uppercase; border-radius: 20px; box-shadow: 0 4px 12px rgba(0,0,0,0.15); }

/* ── Card tilts ── */
.tilt-n14 { transform: rotate(-1.4deg); }
.tilt-p11 { transform: rotate( 1.1deg); }
.tilt-n08 { transform: rotate(-0.8deg); }
.tilt-p14 { transform: rotate( 1.4deg); }
.tilt-n11 { transform: rotate(-1.1deg); }
.tilt-p09 { transform: rotate( 0.9deg); }
.tilt-n13 { transform: rotate(-1.3deg); }
.tilt-p12 { transform: rotate( 1.2deg); }
.tilt-n07 { transform: rotate(-0.7deg); }
.tilt-p13 { transform: rotate( 1.3deg); }
.tilt-n09 { transform: rotate(-0.9deg); }

/* ── Calendar button ── */
.btn-calendar { background: transparent; color: #0a7f7d; border: 1.5px solid #10b3b0; padding: 14px 32px; border-radius: 40px; font-size: 13px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; cursor: pointer; text-decoration: none; display: inline-block; }
.btn-calendar:hover { background: #0a7f7d; color: #fff; text-decoration: none; }

/* ── Championship ── */
.champ-box          { border-radius: 16px; padding: 48px; position: relative; overflow: hidden; color: #ffffff; }
.champ-orb-tr       { position: absolute; top: -60px; right: -60px; width: 240px; height: 240px; border-radius: 50%; background: #f4d58d; opacity: 0.35; }
.champ-orb-bl       { position: absolute; bottom: -40px; left: -40px; width: 180px; height: 180px; border-radius: 50%; background: #f2896e; opacity: 0.4; }
.champ-content      { position: relative; z-index: 2; }
.champ-eyebrow      { font-size: 11px; letter-spacing: 3px; text-transform: uppercase; font-weight: 700; margin-bottom: 16px; opacity: 0.95; }
.champ-title        { font-family: "Cormorant Garamond", Georgia, serif; font-size: 68px; font-style: italic; font-weight: 500; letter-spacing: -1.5px; line-height: 0.95; margin-bottom: 20px; }
.champ-desc         { font-size: 15px; line-height: 1.6; margin-bottom: 24px; opacity: 0.95; }
.champ-stats        { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; padding: 20px 0; border-top: 1px solid rgba(255,255,255,0.3); border-bottom: 1px solid rgba(255,255,255,0.3); margin-bottom: 24px; }
.champ-stat-num     { font-family: "Cormorant Garamond", Georgia, serif; font-size: 36px; font-style: italic; font-weight: 600; line-height: 1; }
.champ-stat-label   { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; margin-top: 6px; opacity: 0.85; font-weight: 600; }
.champ-btns         { display: flex; gap: 10px; }
.btn-white-red      { background: #ffffff; color: #d93a2c; border: none; padding: 14px 28px; border-radius: 40px; font-size: 13px; font-weight: 700; cursor: pointer; text-decoration: none; display: inline-block; }
.btn-white-red:hover { opacity: .9; text-decoration: none; color: #d93a2c; }
.btn-ghost-white    { background: transparent; color: #ffffff; border: 1px solid #ffffff; padding: 14px 28px; border-radius: 40px; font-size: 13px; font-weight: 600; cursor: pointer; text-decoration: none; display: inline-block; }
.btn-ghost-white:hover { background: rgba(255,255,255,.15); text-decoration: none; color: #fff; }
.champ-photo-wrap   { position: relative; z-index: 2; height: 360px; border-radius: 12px; overflow: hidden; background: #0a7f7d; }
.champ-img-tint     { position: absolute; inset: 0; background: #0a7f7d; mix-blend-mode: multiply; opacity: 0.2; }

/* ── Season cards ── */
.season-card        { cursor: pointer; }
.season-card-wrap   { height: 180px; border-radius: 12px; position: relative; overflow: hidden; }
.season-overlay     { position: absolute; inset: 0; mix-blend-mode: multiply; opacity: 0.55; }
.season-label-wrap  { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; color: #ffffff; }
.season-name        { font-family: "Cormorant Garamond", Georgia, serif; font-size: 40px; font-style: italic; font-weight: 500; text-shadow: 0 2px 8px rgba(0,0,0,0.3); }
.season-count       { font-size: 12px; opacity: 0.95; margin-top: 4px; text-shadow: 0 2px 8px rgba(0,0,0,0.3); }
.season-spring      { background: #b5dbc5; }
.season-summer      { background: #f2896e; }
.season-fall        { background: #f4d58d; }
.season-winter      { background: #10b3b0; }

/* ── Cruises ── */
.cruises-intro      { text-align: center; font-size: 16px; color: #5a5665; margin-bottom: 48px; font-style: italic; line-height: 1.5; }
.cruises-grid       { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 340px)); gap: 28px; justify-content: center; max-width: 1100px; margin: 0 auto; }
.cruise-card        { background: #ffffff; border-radius: 16px; overflow: hidden; box-shadow: 0 4px 24px rgba(0,0,0,0.07); display: flex; flex-direction: column; transition: transform 0.25s ease, box-shadow 0.25s ease; }
.cruise-card:hover  { transform: translateY(-4px); box-shadow: 0 12px 40px rgba(0,0,0,0.12); }
.cruise-card-link   { display: flex; flex-direction: column; height: 100%; text-decoration: none; color: inherit; }
.cruise-card-link:hover { text-decoration: none; color: inherit; }
.cruise-img         { height: 220px; position: relative; overflow: hidden; flex-shrink: 0; }
.cruise-img img     { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease; }
.cruise-card:hover .cruise-img img { transform: scale(1.04); }
.cruise-border-red    { border-bottom: 4px solid #f2896e; }
.cruise-border-yellow { border-bottom: 4px solid #f4d58d; }
.cruise-border-purple { border-bottom: 4px solid #6b21a8; }
.cruise-border-teal   { border-bottom: 4px solid #10b3b0; }
.cruise-body          { padding: 24px 24px 20px; flex: 1; display: flex; flex-direction: column; gap: 8px; }
.cruise-title         { font-family: "Cormorant Garamond", Georgia, serif; font-size: 22px; font-style: italic; font-weight: 600; color: #1f1f2e; line-height: 1.2; }
.cruise-date          { font-size: 13px; color: #7e7a8b; flex: 1; }
.cruise-status-open   { display: inline-block; align-self: flex-start; margin-top: 12px; padding: 5px 14px; border-radius: 20px; font-size: 10px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; background: #cdecec; color: #0a7f7d; }
.cruise-status-sold   { display: inline-block; align-self: flex-start; margin-top: 12px; padding: 5px 14px; border-radius: 20px; font-size: 10px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; background: #fde8e8; color: #d93a2c; }

/* ── Spa Jongg ── */
.section-spajongg   { padding: 80px 48px; background: #fff8f5; }
.spajongg-meta      { display: flex; align-items: stretch; justify-content: center; max-width: 800px; margin: 32px auto 52px; background: #ffffff; border-radius: 16px; box-shadow: 0 4px 24px rgba(0,0,0,0.07); overflow: hidden; }
.spajongg-meta-item { flex: 1; padding: 24px 28px; text-align: center; }
.spajongg-meta-sep  { width: 1px; background: #ece5da; }
.spajongg-meta-label { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: #7e7a8b; font-weight: 700; margin-bottom: 8px; }
.spajongg-meta-value { font-family: "Cormorant Garamond", Georgia, serif; font-size: 20px; font-style: italic; font-weight: 600; color: #1f1f2e; line-height: 1.25; }
.spajongg-meta-value small { font-size: 13px; font-weight: 400; color: #7e7a8b; }
.spajongg-cards     { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; max-width: 700px; margin: 0 auto 52px; }
.spajongg-card      { border-radius: 20px; overflow: hidden; box-shadow: 0 8px 32px rgba(0,0,0,0.09); background: #ffffff; }
.spajongg-card-top  { padding: 36px 28px 28px; color: #ffffff; text-align: center; }
.spajongg-card-top--open { background: linear-gradient(135deg, #0a7f7d 0%, #10b3b0 60%, #5fc7c4 100%); }
.spajongg-card-top--sold { background: linear-gradient(135deg, #9e9aab 0%, #b5b0c0 100%); }
.spajongg-week      { font-size: 10px; letter-spacing: 3px; text-transform: uppercase; font-weight: 700; opacity: 0.85; margin-bottom: 12px; }
.spajongg-dates     { font-family: "Cormorant Garamond", Georgia, serif; font-size: 28px; font-style: italic; font-weight: 500; line-height: 1.1; }
.spajongg-status    { display: inline-block; margin-top: 14px; padding: 4px 14px; border-radius: 20px; font-size: 9px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; }
.spajongg-status--open { background: rgba(255,255,255,0.25); color: #ffffff; }
.spajongg-status--sold { background: rgba(0,0,0,0.15); color: rgba(255,255,255,0.8); }
.spajongg-card-body { padding: 24px 28px 28px; }
.spajongg-price-row { display: flex; gap: 0; border-radius: 10px; overflow: hidden; background: #f0eee9; margin-bottom: 20px; }
.spajongg-price-col { flex: 1; padding: 16px 12px; text-align: center; }
.spajongg-price-col + .spajongg-price-col { border-left: 1px solid #ece5da; }
.spajongg-price-label { font-size: 9px; letter-spacing: 2px; text-transform: uppercase; color: #7e7a8b; font-weight: 700; margin-bottom: 4px; }
.spajongg-price     { font-family: "Cormorant Garamond", Georgia, serif; font-size: 26px; font-style: italic; font-weight: 600; color: #1f1f2e; }
.spajongg-btn       { width: 100%; padding: 14px; border: none; border-radius: 40px; font-size: 12px; font-weight: 700; cursor: pointer; letter-spacing: 0.5px; transition: opacity 0.2s; text-decoration: none; display: block; text-align: center; }
.spajongg-btn:hover { text-decoration: none; opacity: 0.88; }
.spajongg-btn--open { background: linear-gradient(90deg, #f2896e 0%, #ea4a35 55%, #a8281d 100%); color: #ffffff; }
.spajongg-btn--open:hover { color: #ffffff; }
.spajongg-btn--sold { background: #e0dde8; color: #9e9aab; cursor: not-allowed; }
.spajongg-perks     { display: flex; flex-wrap: wrap; gap: 14px 32px; justify-content: center; max-width: 680px; margin: 0 auto; }
.spajongg-perk      { font-size: 14px; color: #5a5665; display: flex; align-items: center; gap: 8px; }
.spajongg-perk-icon { font-size: 18px; }

/* ── Countdown ── */
.countdown-orb-tl   { position: absolute; top: -80px; left: -80px; width: 260px; height: 260px; border-radius: 50%; background: #fce4ec; opacity: 0.6; }
.countdown-orb-br   { position: absolute; bottom: -60px; right: -60px; width: 220px; height: 220px; border-radius: 50%; background: #fbeccc; opacity: 0.7; }
.countdown-inner    { position: relative; }
.countdown-title    { font-family: "Cormorant Garamond", Georgia, serif; font-size: 88px; font-style: italic; font-weight: 500; letter-spacing: -2px; line-height: 0.98; margin-bottom: 12px; }
.countdown-sub      { font-size: 14px; color: #7e7a8b; margin-bottom: 32px; font-style: italic; }
.countdown-boxes    { display: flex; gap: 18px; justify-content: center; margin-bottom: 32px; flex-wrap: wrap; }
.countdown-box      { background: #ffffff; border-radius: 12px; padding: 28px 24px; min-width: 110px; box-shadow: 0 8px 24px rgba(16,179,176,0.12); }
.countdown-num      { font-family: "Cormorant Garamond", Georgia, serif; font-size: 62px; font-style: italic; font-weight: 600; line-height: 1; color: #0a7f7d; font-variant-numeric: tabular-nums; }
.countdown-label    { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: #7e7a8b; margin-top: 8px; font-weight: 700; }
.btn-claim          { color: #ffffff; border: none; padding: 16px 36px; border-radius: 40px; font-size: 13px; font-weight: 700; cursor: pointer; text-decoration: none; display: inline-block; }

/* ── Testimonial ── */
.testimonial-quote  { font-family: "Cormorant Garamond", Georgia, serif; font-size: 38px; font-style: italic; font-weight: 500; line-height: 1.3; max-width: 760px; margin: 0 auto; color: #1f1f2e; }
.testimonial-attr   { font-size: 12px; color: #7e7a8b; margin-top: 16px; letter-spacing: 2px; text-transform: uppercase; }

/* ── Letter ── */
.letter-inner       { max-width: 720px; margin: 0 auto; }
.letter-title       { font-family: "Cormorant Garamond", Georgia, serif; font-size: 84px; font-style: italic; font-weight: 500; letter-spacing: -2px; line-height: 0.98; text-align: center; margin-bottom: 20px; }
.letter-byline      { font-size: 12px; letter-spacing: 2px; text-transform: uppercase; color: #7e7a8b; font-weight: 600; text-align: center; margin-bottom: 56px; }
.letter-drop-cap    { font-family: "Cormorant Garamond", Georgia, serif; font-size: 110px; float: left; line-height: 0.85; margin-right: 14px; margin-top: 10px; color: #f2896e; font-weight: 600; font-style: italic; }
.letter-opening-p   { font-size: 23px; line-height: 1.5; color: #1f1f2e; font-weight: 400; margin: 0; font-style: italic; }
.letter-body-p      { font-size: 19px; line-height: 1.7; color: #1f1f2e; margin: 0 0 24px; }
.letter-figure      { margin: 44px 0; text-align: center; }
.letter-fig-inner   { border-radius: 12px; overflow: hidden; height: 380px; position: relative; }
.letter-fig-tint    { position: absolute; inset: 0; background: #10b3b0; opacity: 0.18; }
.letter-blockquote  { margin: 48px -24px 48px; padding: 36px 40px 36px 44px; border-left: 4px solid #f2896e; background: #fce4ec; border-radius: 0 12px 12px 0; }
.letter-bq-text     { font-family: "Cormorant Garamond", Georgia, serif; font-size: 38px; font-style: italic; font-weight: 500; line-height: 1.25; color: #a8281d; }
.letter-sign        { border-top: 1px solid #ece5da; padding-top: 36px; font-family: "Cormorant Garamond", Georgia, serif; font-size: 36px; font-style: italic; font-weight: 500; line-height: 1.3; color: #1f1f2e; white-space: pre-line; }

/* ── Stories ── */
.stories-header     { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 40px; flex-wrap: wrap; gap: 16px; }
.stories-from       { font-size: 11px; letter-spacing: 3px; text-transform: uppercase; color: #0a7f7d; font-weight: 700; margin-bottom: 8px; }
.stories-title      { font-family: "Cormorant Garamond", Georgia, serif; font-size: 56px; font-style: italic; font-weight: 500; letter-spacing: -1.5px; line-height: 1; }
.btn-all-stories    { background: transparent; color: #0a7f7d; border: 1.5px solid #10b3b0; padding: 12px 22px; border-radius: 40px; font-size: 12px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; cursor: pointer; text-decoration: none; display: inline-block; }
.btn-all-stories:hover { background: #0a7f7d; color: #fff; text-decoration: none; }
.story-card         { background: #ffffff; border-radius: 14px; overflow: hidden; border: 1px solid #ece5da; cursor: pointer; display: block; text-decoration: none; color: inherit; }
.story-card:hover   { text-decoration: none; color: inherit; }
.story-card-flex    { display: flex; flex-direction: column; }
.story-img          { position: relative; }
.story-img-lg       { height: 380px; }
.story-img-sm       { height: 140px; }
.story-tag          { position: absolute; top: 16px; left: 16px; background: #ffffff; padding: 4px 10px; font-size: 10px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: #a8281d; border-radius: 20px; z-index: 1; }
.story-tag-sm       { top: 12px; left: 12px; font-size: 9px; padding: 3px 8px; }
.story-tint-yellow  { position: absolute; inset: 0; background: #f4d58d; opacity: 0.35; }
.story-tint-pink    { position: absolute; inset: 0; background: #f4a8c0; opacity: 0.45; }
.story-tint-teal    { position: absolute; inset: 0; background: #10b3b0; opacity: 0.45; }
.story-tint-orange  { position: absolute; inset: 0; background: #f2896e; opacity: 0.45; }
.story-body-lg      { padding: 32px; }
.story-body-sm      { padding: 20px; flex: 1; display: flex; flex-direction: column; }
.story-title-lg     { font-family: "Cormorant Garamond", Georgia, serif; font-size: 34px; font-style: italic; font-weight: 600; line-height: 1.15; margin-bottom: 12px; color: #1f1f2e; }
.story-title-sm     { font-size: 17px; font-weight: 600; line-height: 1.25; margin-bottom: 8px; flex: 1; color: #1f1f2e; }
.story-excerpt      { font-size: 15px; color: #7e7a8b; line-height: 1.5; margin-bottom: 16px; }
.story-meta         { font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; color: #7e7a8b; font-weight: 600; }
.story-meta-sm      { font-size: 10px; }

/* ── Virtual Tournaments ── */
.virtual-inner      { position: relative; z-index: 2; max-width: 720px; margin: 0 auto; }
.virtual-title      { font-family: "Cormorant Garamond", Georgia, serif; font-size: 80px; font-weight: 500; font-style: italic; color: #ffffff; letter-spacing: -2px; line-height: 0.95; margin: 12px 0 20px; text-shadow: 0 2px 12px rgba(0,0,0,0.15); }
.virtual-sub        { font-size: 16px; color: rgba(255,255,255,0.9); line-height: 1.6; margin-bottom: 36px; max-width: 480px; margin-left: auto; margin-right: auto; }
.virtual-platforms  { display: flex; align-items: center; justify-content: center; gap: 16px; flex-wrap: wrap; }
.virtual-pill       { background: #ffffff; color: #d93a2c; border: none; padding: 14px 32px; border-radius: 40px; font-size: 14px; font-weight: 700; letter-spacing: 0.5px; cursor: pointer; text-decoration: none; transition: transform 0.2s ease, box-shadow 0.2s ease; box-shadow: 0 4px 16px rgba(0,0,0,0.12); display: inline-block; }
.virtual-pill:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,0.18); text-decoration: none; color: #d93a2c; }
.virtual-or         { color: rgba(255,255,255,0.75); font-size: 15px; font-style: italic; font-family: "Cormorant Garamond", Georgia, serif; }

/* ── Mobile ── */
@media (max-width: 768px) {
  .hero-wrap          { padding: 12px 12px 20px; }
  .hero-title         { font-size: 34px; letter-spacing: -0.5px; margin-bottom: 18px; }
  .hero-buttons       { flex-direction: column; gap: 8px; }
  .hero-btn-primary,
  .hero-btn-secondary { width: 100%; padding: 13px; font-size: 11px; }

  .tournaments-grid   { grid-template-columns: repeat(1, 1fr); gap: 16px; margin-top: 20px; }
  .season-grid        { grid-template-columns: repeat(2, 1fr); }
  .championship-grid  { grid-template-columns: 1fr; gap: 0; }
  .champ-photo-wrap   { display: none; }
  .cruises-grid       { grid-template-columns: repeat(1, 1fr); gap: 16px; justify-content: stretch; }
  .stories-grid       { grid-template-columns: 1fr; }
  .stories-featured   { grid-row: auto; }

  .section-tournaments { padding: 32px 16px 24px; }
  .section-season      { padding: 24px 16px; }
  .section-championship{ padding: 0 16px 32px; }
  .section-cruises     { padding: 40px 16px; }
  .section-countdown   { padding: 56px 16px; }
  .section-testimonial { padding: 32px 16px; }
  .section-letter      { padding: 56px 16px; }
  .section-stories     { padding: 40px 16px; }
  .section-spajongg    { padding: 40px 16px; }
  .section-virtual     { padding: 56px 20px; }

  .section-h--lg      { font-size: 30px; }
  .section-h--md      { font-size: 28px; }

  .countdown-title    { font-size: clamp(36px, 10vw, 56px); }
  .countdown-box      { min-width: 72px; padding: 18px 16px; }
  .countdown-num      { font-size: 38px; }

  .season-card-wrap   { height: 140px; }
  .season-name        { font-size: 28px; }
  .season-count       { font-size: 10px; }

  .champ-box          { padding: 20px; }
  .champ-title        { font-size: 40px; }

  .cruise-img         { height: 160px; }
  .cruise-body        { padding: 20px; }
  .cruise-title       { font-size: 22px; }
  .cruise-date        { font-size: 12px; margin-bottom: 16px; }
  .cruises-intro      { font-size: 14px; margin-bottom: 32px; }

  .testimonial-quote  { font-size: 22px; }

  .letter-title       { font-size: 44px; letter-spacing: -1.5px; margin-bottom: 14px; }
  .letter-drop-cap    { font-size: 72px; margin-right: 10px; margin-top: 6px; }
  .letter-opening-p   { font-size: 18px; }
  .letter-body-p      { font-size: 16px; line-height: 1.65; }
  .letter-fig-inner   { height: 220px; }
  .letter-blockquote  { margin: 32px -12px 32px; padding: 24px 20px 24px 28px; }
  .letter-bq-text     { font-size: 28px; }
  .letter-byline      { margin-bottom: 36px; }
  .letter-sign        { font-size: 28px; padding-top: 28px; }

  .stories-header     { margin-bottom: 24px; }
  .stories-title      { font-size: 36px; }
  .story-img-lg       { height: 220px; }
  .story-img-sm       { height: 160px; }
  .story-body-lg      { padding: 20px; }
  .story-title-lg     { font-size: 26px; }
  .story-excerpt      { font-size: 13px; }

  .virtual-title      { font-size: 48px; letter-spacing: -1px; margin: 10px 0 16px; }
  .virtual-sub        { font-size: 14px; margin-bottom: 28px; }
  .virtual-pill       { padding: 12px 24px; font-size: 13px; }

  .spajongg-meta      { flex-direction: column; }
  .spajongg-meta-sep  { width: auto; height: 1px; }
  .spajongg-cards     { grid-template-columns: 1fr; max-width: 380px; }
  .spajongg-perks     { gap: 12px 20px; }
  .spajongg-perk      { font-size: 13px; }
}
