/* =============================================
   Caliente Casino MX — Site 1 Stylesheet
   CSS prefix: cal-
   Red/dark theme · CSS Grid + Flexbox
   Breakpoints: 320, 768, 1024, 1440
   ============================================= */

/* ---- Reset & Base ---- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body { font-family: 'Open Sans', sans-serif; background: #111111; color: #FFFFFF; line-height: 1.65; overflow-x: hidden; }
body.cal-nav-open { overflow: hidden; }
img { max-width: 100%; height: auto; display: block; }
a { color: #E30613; text-decoration: none; transition: color .25s; }
a:hover { color: #ff2233; }
ul { list-style: none; }
table { border-collapse: collapse; width: 100%; }

/* ---- Container ---- */
.cal-container { width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 20px; }

/* ---- Typography ---- */
h1, h2, h3, h4 { font-family: 'Oswald', sans-serif; font-weight: 700; line-height: 1.15; }
h1 { font-size: clamp(1.9rem, 4.5vw, 3.2rem); margin-bottom: .6em; color: #E30613; text-transform: uppercase; letter-spacing: .5px; }
h2 { font-size: clamp(1.5rem, 3vw, 2.4rem); margin-bottom: .5em; color: #FFFFFF; text-transform: uppercase; }
h3 { font-size: clamp(1.2rem, 2.5vw, 1.8rem); margin-bottom: .45em; color: #E30613; }
h4 { font-size: 1rem; color: #E30613; margin-bottom: .4em; }
.cal-segment__intro { color: #B0B0B0; max-width: 860px; margin-bottom: 2.2rem; font-size: 1rem; }

/* ---- Buttons ---- */
.cal-btn {
  display: inline-block;
  padding: 13px 30px;
  background: #E30613;
  color: #fff;
  font-family: 'Oswald', sans-serif;
  font-weight: 600;
  font-size: .95rem;
  letter-spacing: .5px;
  text-transform: uppercase;
  border-radius: 3px;
  border: none;
  cursor: pointer;
  transition: background .2s, transform .15s, box-shadow .2s;
  text-align: center;
  text-decoration: none;
  line-height: 1.3;
}
.cal-btn:hover { background: #c0000f; transform: translateY(-2px); box-shadow: 0 6px 18px rgba(227,6,19,.35); color: #fff; }
.cal-btn--green { background: #4CAF50; }
.cal-btn--green:hover { background: #3d9140; box-shadow: 0 6px 18px rgba(76,175,80,.35); }
.cal-btn--sm { padding: 9px 20px; font-size: .85rem; }
.cal-btn--header { padding: 10px 22px; font-size: .85rem; }

/* ---- Promo Bar (top) ---- */
.cal-promo-bar { background: #E30613; color: #fff; text-align: center; padding: 9px 50px; font-size: .84rem; font-weight: 600; position: relative; }
.cal-promo-bar a { color: #fff; text-decoration: underline; font-weight: 700; }
.cal-promo-bar__close { position: absolute; right: 14px; top: 50%; transform: translateY(-50%); background: none; border: none; color: rgba(255,255,255,.7); font-size: 1.1rem; cursor: pointer; padding: 4px; line-height: 1; }
.cal-promo-bar__close:hover { color: #fff; }

/* ---- Header ---- */
.cal-header { position: sticky; top: 0; z-index: 200; background: rgba(10,10,10,.97); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); border-bottom: 2px solid #E30613; transition: box-shadow .3s; }
.cal-header.is-scrolled { box-shadow: 0 3px 20px rgba(0,0,0,.6); }
.cal-header__inner { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 16px; height: 68px; }
.cal-logo img { height: 36px; width: auto; }
.cal-nav__list { display: flex; gap: 24px; justify-content: center; }
.cal-nav__list a { color: #ddd; font-family: 'Oswald', sans-serif; font-size: .9rem; font-weight: 500; letter-spacing: .5px; text-transform: uppercase; position: relative; }
.cal-nav__list a::after { content: ''; position: absolute; bottom: -3px; left: 0; width: 0; height: 2px; background: #E30613; transition: width .25s; }
.cal-nav__list a:hover { color: #fff; }
.cal-nav__list a:hover::after { width: 100%; }
.cal-header__actions { display: flex; align-items: center; gap: 12px; }

/* ---- Burger ---- */
.cal-burger { display: none; background: none; border: none; cursor: pointer; padding: 6px; flex-direction: column; gap: 5px; }
.cal-burger span { display: block; width: 24px; height: 2px; background: #fff; border-radius: 2px; transition: transform .3s, opacity .2s; }
.cal-burger.is-active span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
.cal-burger.is-active span:nth-child(2) { opacity: 0; }
.cal-burger.is-active span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }

/* ---- TOC ---- */
.cal-toc { background: #1A1A1A; border-bottom: 1px solid rgba(227,6,19,.2); padding: 12px 0; }
.cal-toc__label { display: inline; font-size: .8rem; color: #888; margin-right: 8px; font-family: 'Oswald', sans-serif; text-transform: uppercase; letter-spacing: .5px; }
.cal-toc__list { display: inline; padding: 0; }
.cal-toc__list li { display: inline; }
.cal-toc__list a { color: #aaa; font-size: .8rem; margin-right: 14px; }
.cal-toc__list a:hover { color: #E30613; }
.cal-toc__list li::after { content: '·'; color: #444; margin-left: 14px; }
.cal-toc__list li:last-child::after { display: none; }

/* ---- Sections ---- */
.cal-segment { padding: 72px 0; }
.cal-segment--dark { background: #161616; }
.cal-segment--registration { background: #0d0d0d; border-top: 1px solid rgba(227,6,19,.15); border-bottom: 1px solid rgba(227,6,19,.15); }

/* ---- Hero ---- */
.cal-hero { padding: 64px 0 56px; background: linear-gradient(135deg, #0a0a0a 0%, #1a0505 100%); border-bottom: 1px solid rgba(227,6,19,.2); }
.cal-hero__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
.cal-hero__text p { color: #B8B8B8; margin-bottom: 2rem; font-size: 1.05rem; }
.cal-hero__media img { border-radius: 6px; box-shadow: 0 16px 48px rgba(227,6,19,.18); width: 100%; }

/* ---- Split Layout ---- */
.cal-split { display: grid; grid-template-columns: 1fr 1fr; gap: 44px; align-items: center; margin-top: 2rem; }
.cal-split--reverse { }
.cal-split--reverse .cal-split__media { order: 2; }
.cal-split--reverse .cal-split__text { order: 1; }
.cal-split__media img { border-radius: 6px; width: 100%; box-shadow: 0 10px 32px rgba(0,0,0,.4); }
.cal-split__text p { color: #B0B0B0; margin-bottom: 1rem; }

/* ---- Sports badges ---- */
.cal-sports-icons { display: flex; flex-wrap: wrap; gap: 10px; margin: 1.4rem 0; }
.cal-sport-badge { background: rgba(227,6,19,.12); border: 1px solid rgba(227,6,19,.25); color: #ddd; padding: 6px 14px; border-radius: 20px; font-size: .82rem; font-weight: 600; white-space: nowrap; }

/* ---- Steps Grid (como funciona) ---- */
.cal-steps-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 2rem; }
.cal-step { background: #1A1A1A; border: 1px solid rgba(227,6,19,.12); border-radius: 6px; padding: 28px 24px; position: relative; transition: transform .3s, box-shadow .3s; }
.cal-step:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(227,6,19,.1); }
.cal-step__num { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; background: #E30613; color: #fff; font-family: 'Oswald', sans-serif; font-weight: 700; font-size: 1.1rem; border-radius: 50%; margin-bottom: 16px; }
.cal-step__title { font-family: 'Oswald', sans-serif; font-size: 1.05rem; color: #fff; margin-bottom: 10px; }
.cal-step p { color: #999; font-size: .9rem; line-height: 1.55; }

/* ---- Categories Grid ---- */
.cal-categories-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-bottom: 3rem; }
.cal-cat-card { position: relative; border-radius: 6px; overflow: hidden; display: block; transition: transform .3s; }
.cal-cat-card:hover { transform: scale(1.02); }
.cal-cat-card img { width: 100%; height: 220px; object-fit: cover; }
.cal-cat-card__label { position: absolute; bottom: 0; left: 0; right: 0; background: linear-gradient(transparent, rgba(0,0,0,.85)); padding: 28px 16px 14px; color: #fff; font-family: 'Oswald', sans-serif; font-size: 1.15rem; font-weight: 600; text-transform: uppercase; letter-spacing: .5px; }

/* ---- Subsections ---- */
.cal-subsection { margin-top: 3rem; padding-top: 2.5rem; border-top: 1px solid rgba(227,6,19,.12); }

/* ---- Slots Grid ---- */
.cal-slots-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 12px; margin-top: 1.6rem; }
.cal-slot-card { display: flex; flex-direction: column; position: relative; border-radius: 5px; overflow: hidden; transition: transform .25s, box-shadow .25s; border: none; background: #1a1a1a; }
.cal-slot-card img { flex-shrink: 0; }
.cal-slot-card:hover { transform: translateY(-4px); box-shadow: 0 8px 20px rgba(227,6,19,.2); }
.cal-slot-card img { width: 100%; height: 180px; object-fit: cover; display: block; }
.cal-slot-card__name { display: block; text-align: center; padding: 8px 4px; font-family: 'Oswald', sans-serif; font-size: .72rem; color: #ccc; text-transform: uppercase; letter-spacing: .5px; background: #1a1a1a; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ---- Live Grid ---- */
.cal-live-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 1.6rem; }
.cal-live-card { display: block; position: relative; border-radius: 5px; overflow: hidden; transition: transform .25s, box-shadow .25s; border: none; background: #1a1a1a; }
.cal-live-card:hover { transform: translateY(-4px); box-shadow: 0 8px 20px rgba(227,6,19,.25); }
.cal-live-card img { width: 100%; height: 170px; object-fit: cover; }
.cal-live-card__name { display: block; text-align: center; padding: 10px 4px; font-family: 'Oswald', sans-serif; font-size: .82rem; color: #ccc; text-transform: uppercase; letter-spacing: .5px; background: #1a1a1a; border-top: 1px solid rgba(227,6,19,.15); }

/* ---- Table Grid ---- */
.cal-table-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 1.6rem; }
.cal-table-card { display: block; position: relative; border-radius: 5px; overflow: hidden; transition: transform .25s, box-shadow .25s; border: none; background: #1a1a1a; }
.cal-table-card:hover { transform: translateY(-4px); box-shadow: 0 8px 20px rgba(76,175,80,.15); }
.cal-table-card img { width: 100%; height: 170px; object-fit: cover; }
.cal-table-card__name { display: block; text-align: center; padding: 10px 4px; font-family: 'Oswald', sans-serif; font-size: .82rem; color: #ccc; text-transform: uppercase; letter-spacing: .5px; background: #1a1a1a; border-top: 1px solid rgba(76,175,80,.15); }

/* ---- HTML Table ---- */
.cal-table { width: 100%; border-collapse: collapse; margin-top: 1rem; font-size: .9rem; }
.cal-table thead tr { background: #E30613; color: #fff; }
.cal-table th { padding: 12px 16px; text-align: left; font-family: 'Oswald', sans-serif; font-weight: 600; font-size: .85rem; text-transform: uppercase; letter-spacing: .5px; }
.cal-table td { padding: 11px 16px; border-bottom: 1px solid rgba(255,255,255,.06); color: #ccc; }
.cal-table tbody tr:hover { background: rgba(227,6,19,.05); }

/* ---- Payment Icons ---- */
.cal-payment-icons { display: flex; flex-wrap: wrap; align-items: center; gap: 16px; margin-bottom: 2.5rem; padding: 20px; background: #1A1A1A; border-radius: 6px; }
.cal-payment-icons img { height: 36px; width: auto; filter: grayscale(20%) brightness(1.1); transition: filter .2s, transform .2s; }
.cal-payment-icons img:hover { filter: none; transform: scale(1.08); }

/* ---- Payment blocks ---- */
.cal-payment-block { margin-bottom: 2.5rem; }
.cal-payment-block h3 { margin-bottom: 1rem; }
.cal-payment-block p { color: #B0B0B0; margin-bottom: 1rem; }

/* ---- How-to Steps ---- */
.cal-howto-steps { display: flex; flex-direction: column; gap: 16px; margin-top: 1.8rem; }
.cal-howto-step { display: grid; grid-template-columns: 64px 1fr; gap: 20px; align-items: start; background: #1A1A1A; border-radius: 6px; padding: 20px 24px; border-left: 3px solid #E30613; }
.cal-howto-step__number { font-family: 'Oswald', sans-serif; font-size: 1.8rem; font-weight: 700; color: #E30613; line-height: 1; padding-top: 2px; }
.cal-howto-step__content h4 { color: #fff; margin-bottom: 6px; font-size: .95rem; }
.cal-howto-step__content p { color: #999; font-size: .88rem; line-height: 1.6; }

/* ---- Bonus sections ---- */
.cal-bonus-section { margin-top: 3rem; padding-top: 2.5rem; border-top: 1px solid rgba(227,6,19,.12); }
.cal-bonus-section h3 { margin-bottom: 1rem; }
.cal-bonus-section > p { color: #B0B0B0; margin-bottom: 1.8rem; }

/* ---- Bonus Grid ---- */
.cal-bonus-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.cal-bonus-card { background: #1A1A1A; border-radius: 6px; overflow: hidden; border: 1px solid rgba(227,6,19,.12); transition: transform .3s, box-shadow .3s; }
.cal-bonus-card:hover { transform: translateY(-4px); box-shadow: 0 10px 28px rgba(227,6,19,.15); }
.cal-bonus-card img { width: 100%; height: 180px; object-fit: cover; }
.cal-bonus-card__body { padding: 18px; }
.cal-bonus-card__label { display: block; font-size: .75rem; color: #888; text-transform: uppercase; letter-spacing: .5px; margin-bottom: 6px; font-family: 'Oswald', sans-serif; }
.cal-bonus-card__amount { display: block; font-family: 'Oswald', sans-serif; font-size: 1.3rem; color: #E30613; margin-bottom: 8px; }
.cal-bonus-card__body p { color: #999; font-size: .82rem; margin-bottom: 14px; }

/* ---- No Deposit & Free Spins ---- */
.cal-bonus-nodeposit, .cal-bonus-freespins { display: grid; grid-template-columns: 1fr 1.4fr; gap: 32px; align-items: center; background: #1A1A1A; border-radius: 6px; overflow: hidden; padding: 0; }
.cal-bonus-nodeposit__img img, .cal-bonus-freespins__img img { width: 100%; height: 260px; object-fit: cover; }
.cal-bonus-nodeposit__text, .cal-bonus-freespins__text { padding: 28px 28px 28px 0; }
.cal-bonus-nodeposit__text strong, .cal-bonus-freespins__text strong { display: block; font-family: 'Oswald', sans-serif; font-size: 1.3rem; color: #fff; margin-bottom: 12px; }
.cal-bonus-nodeposit__text p, .cal-bonus-freespins__text p { color: #999; font-size: .9rem; margin-bottom: 18px; line-height: 1.6; }
.cal-bonus-freespins { margin-top: 2rem; }

/* ---- Tips List (Ganar) ---- */
.cal-tips-list { display: flex; flex-direction: column; gap: 16px; margin-top: 1.8rem; }
.cal-tip { display: grid; grid-template-columns: 56px 1fr; gap: 20px; align-items: start; background: #1A1A1A; border-radius: 6px; padding: 20px 24px; }
.cal-tip__icon { font-family: 'Oswald', sans-serif; font-size: 1.5rem; font-weight: 700; color: #E30613; line-height: 1; padding-top: 4px; }
.cal-tip strong { display: block; font-family: 'Oswald', sans-serif; font-size: 1rem; color: #fff; margin-bottom: 6px; }
.cal-tip p { color: #999; font-size: .88rem; line-height: 1.6; }

/* ---- FAQ ---- */
.cal-faq { margin-top: 1.8rem; }
.cal-faq__item { border-bottom: 1px solid rgba(255,255,255,.08); }
.cal-faq__item:first-child { border-top: 1px solid rgba(255,255,255,.08); }
.cal-faq__question { display: flex; justify-content: space-between; align-items: center; width: 100%; background: none; border: none; color: #fff; font-family: 'Oswald', sans-serif; font-size: 1rem; font-weight: 500; text-align: left; padding: 18px 0; cursor: pointer; gap: 16px; text-transform: uppercase; letter-spacing: .3px; }
.cal-faq__question:hover { color: #E30613; }
.cal-faq__arrow { display: inline-block; width: 20px; height: 20px; min-width: 20px; border: 2px solid #E30613; border-radius: 50%; position: relative; transition: transform .3s; }
.cal-faq__arrow::after { content: ''; position: absolute; top: 50%; left: 50%; width: 6px; height: 6px; border-right: 2px solid #E30613; border-bottom: 2px solid #E30613; transform: translate(-50%, -65%) rotate(45deg); transition: transform .3s; }
.cal-faq__question[aria-expanded="true"] .cal-faq__arrow { transform: rotate(180deg); }
.cal-faq__answer { padding: 0 0 18px; }
.cal-faq__answer p { color: #999; font-size: .92rem; line-height: 1.7; }

/* ---- Author Block ---- */
.cal-author-block { background: #161616; padding: 48px 0; border-top: 1px solid rgba(227,6,19,.12); }
.cal-author { display: grid; grid-template-columns: auto 1fr; gap: 24px; align-items: start; }
.cal-author__photo { width: 90px; height: 90px; border-radius: 50%; object-fit: cover; border: 3px solid #E30613; flex-shrink: 0; }
.cal-author__name { display: block; font-family: 'Oswald', sans-serif; font-size: 1.15rem; font-weight: 700; color: #fff; margin-bottom: 2px; }
.cal-author__title { display: block; font-size: .8rem; color: #E30613; text-transform: uppercase; letter-spacing: .5px; margin-bottom: 10px; }
.cal-author__bio { color: #999; font-size: .88rem; line-height: 1.65; }

/* ---- Footer ---- */
.cal-footer { background: #0a0a0a; padding: 52px 0 32px; border-top: 2px solid #E30613; }
.cal-footer__grid { display: grid; grid-template-columns: 1.2fr 0.8fr 1.5fr; gap: 40px; margin-bottom: 2.5rem; }
.cal-footer__brand img { margin-bottom: 14px; }
.cal-footer__brand p { color: #666; font-size: .84rem; line-height: 1.6; }
.cal-footer__links h4, .cal-footer__legal h4 { font-family: 'Oswald', sans-serif; font-size: .9rem; text-transform: uppercase; letter-spacing: .5px; color: #E30613; margin-bottom: 14px; }
.cal-footer__links ul li { margin-bottom: 8px; }
.cal-footer__links ul a { color: #666; font-size: .85rem; }
.cal-footer__links ul a:hover { color: #E30613; }
.cal-footer__legal p { color: #555; font-size: .78rem; line-height: 1.7; }
.cal-footer__bottom { border-top: 1px solid rgba(255,255,255,.06); padding-top: 20px; }
.cal-footer__disclaimer { color: #555; font-size: .78rem; line-height: 1.7; margin-bottom: 10px; }
.cal-footer__disclaimer a { color: #888; }
.cal-footer__disclaimer a:hover { color: #E30613; }
.cal-footer__copy { color: #444; font-size: .75rem; }

/* ---- Sticky Bottom Bar ---- */
.cal-sticky-bar { position: fixed; bottom: 0; left: 0; right: 0; z-index: 300; background: #1A1A1A; border-top: 2px solid #E30613; padding: 12px 20px; display: flex; align-items: center; justify-content: center; gap: 20px; box-shadow: 0 -4px 20px rgba(0,0,0,.5); }
.cal-sticky-bar__text { color: #fff; font-size: .88rem; }
.cal-sticky-bar__text strong { color: #E30613; }
.cal-sticky-bar__close { background: none; border: none; color: #666; font-size: 1.1rem; cursor: pointer; padding: 4px 8px; position: absolute; right: 16px; }
.cal-sticky-bar__close:hover { color: #fff; }

/* =============================================
   RESPONSIVE — 1024px (Tablets landscape)
   ============================================= */
@media (max-width: 1024px) {
  .cal-steps-grid { grid-template-columns: repeat(2, 1fr); }
  .cal-slots-grid { grid-template-columns: repeat(3, 1fr); }
  .cal-footer__grid { grid-template-columns: 1fr 1fr; }
  .cal-footer__legal { grid-column: 1 / -1; }
  .cal-bonus-nodeposit, .cal-bonus-freespins { grid-template-columns: 1fr 1.2fr; }
}

/* =============================================
   RESPONSIVE — 768px (Tablets portrait)
   ============================================= */
@media (max-width: 768px) {
  .cal-header__inner { grid-template-columns: auto auto; }
  .cal-nav { display: none; position: fixed; top: 68px; left: 0; right: 0; bottom: 0; background: rgba(10,10,10,.98); padding: 32px 20px; z-index: 199; overflow-y: auto; }
  .cal-nav.is-open { display: block; }
  .cal-nav__list { flex-direction: column; gap: 8px; }
  .cal-nav__list a { display: block; padding: 14px 0; font-size: 1.2rem; border-bottom: 1px solid rgba(255,255,255,.06); }
  .cal-burger { display: flex; }
  .cal-header__actions .cal-btn--header { display: none; }

  .cal-hero__grid { grid-template-columns: 1fr; gap: 28px; }
  .cal-hero__media { order: -1; }
  .cal-split { grid-template-columns: 1fr; gap: 24px; }
  .cal-split--reverse .cal-split__media { order: 0; }
  .cal-split--reverse .cal-split__text { order: 0; }

  .cal-categories-grid { grid-template-columns: 1fr 1fr; }
  .cal-slots-grid { grid-template-columns: repeat(2, 1fr); }
  .cal-live-grid { grid-template-columns: 1fr 1fr; }
  .cal-table-grid { grid-template-columns: 1fr 1fr; }
  .cal-steps-grid { grid-template-columns: 1fr 1fr; }
  .cal-bonus-grid { grid-template-columns: 1fr; max-width: 400px; margin: 0 auto; }
  .cal-bonus-nodeposit, .cal-bonus-freespins { grid-template-columns: 1fr; }
  .cal-bonus-nodeposit__img img, .cal-bonus-freespins__img img { height: 200px; }
  .cal-bonus-nodeposit__text, .cal-bonus-freespins__text { padding: 20px; }

  .cal-footer__grid { grid-template-columns: 1fr; gap: 28px; }
  .cal-footer__legal { grid-column: auto; }

  .cal-toc__list { display: flex; flex-wrap: wrap; gap: 4px 0; }
  .cal-toc__list li::after { display: none; }
  .cal-toc__list a { margin-right: 8px; }

  .cal-sticky-bar { flex-wrap: wrap; gap: 10px; padding: 12px 50px 12px 16px; }
  .cal-sticky-bar__text { font-size: .8rem; }
}

/* =============================================
   RESPONSIVE — 320px (Mobile small)
   ============================================= */
@media (max-width: 480px) {
  .cal-segment { padding: 48px 0; }
  .cal-hero { padding: 40px 0 36px; }
  .cal-categories-grid { grid-template-columns: 1fr; }
  .cal-slots-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .cal-live-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .cal-table-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .cal-steps-grid { grid-template-columns: 1fr; }
  .cal-howto-step { grid-template-columns: 48px 1fr; gap: 14px; padding: 16px; }
  .cal-tip { grid-template-columns: 44px 1fr; gap: 14px; padding: 16px; }
  .cal-author { grid-template-columns: 1fr; text-align: center; justify-items: center; }
  .cal-table { font-size: .78rem; }
  .cal-table th, .cal-table td { padding: 8px 10px; }
  .cal-payment-icons { gap: 10px; }
  .cal-payment-icons img { height: 28px; }
  .cal-promo-bar { font-size: .75rem; padding: 8px 40px; }
}

/* =============================================
   RESPONSIVE — 1440px (Wide screens)
   ============================================= */
@media (min-width: 1440px) {
  .cal-container { max-width: 1340px; }
  .cal-slots-grid { grid-template-columns: repeat(6, 1fr); }
}
