/* HOW TO SIGN UP */
.howto-section { padding: 48px 0; border-bottom: 1px solid #E0E0E0; }
.howto-section .steps-list { display: flex; flex-direction: column; gap: 0; counter-reset: none; }
.howto-section .step-item { display: flex; gap: 16px; padding: 20px 0; border-bottom: 1px solid #F0F0F0; }
.howto-section .step-item:last-child { border-bottom: none; }
.howto-section .step-num-wrap { flex-shrink: 0; }
.howto-section .step-num { display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; background-color: #C9A84C; color: #FFFFFF; font-size: 18px; font-weight: 900; border-radius: 50%; }
.howto-section .step-body { flex: 1; }
.howto-section .step-title { font-size: 16px; font-weight: 700; color: #1A1A1A; margin-bottom: 6px; }
.howto-section .step-desc { font-size: 15px; color: #444444; line-height: 1.6; }

/* HOW WE RANK */
.criteria-section { padding: 48px 0; background-color: #FAFAFA; border-bottom: 1px solid #E0E0E0; }
.criteria-section .criteria-grid { display: grid; grid-template-columns: 1fr; gap: 16px; }
.criteria-section .criteria-card { background-color: #FFFFFF; border: 1px solid #E0E0E0; border-radius: 8px; padding: 20px; }
.criteria-section .criteria-icon { margin-bottom: 12px; }
.criteria-section .criteria-title { font-size: 15px; font-weight: 700; color: #1A1A1A; margin-bottom: 8px; }
.criteria-section .criteria-desc { font-size: 14px; color: #555555; line-height: 1.6; }

@media (min-width: 768px) {
  .criteria-section .criteria-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
  .criteria-section .criteria-grid { grid-template-columns: repeat(3, 1fr); }
}

/* EDITORIAL SECTIONS (trends, bet types) */
.editorial-section { padding: 48px 0; border-bottom: 1px solid #E0E0E0; }
.editorial-section .editorial-grid { display: grid; grid-template-columns: 1fr; gap: 16px; }
.editorial-section .editorial-card { background-color: #FFFFFF; border: 1px solid #E0E0E0; border-left: 4px solid #C9A84C; border-radius: 4px; padding: 20px; }
.editorial-section .editorial-title { font-size: 15px; font-weight: 700; color: #1A1A1A; margin-bottom: 8px; }
.editorial-section .editorial-text { font-size: 14px; color: #555555; line-height: 1.7; }
.bettypes-section .bettypes-grid { }

@media (min-width: 768px) {
  .editorial-section .editorial-grid { grid-template-columns: repeat(2, 1fr); }
  .bettypes-section .bettypes-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
  .editorial-section .editorial-grid { grid-template-columns: repeat(3, 1fr); }
}

/* NEWS */
.news-section { padding: 48px 0; background-color: #FAFAFA; border-bottom: 1px solid #E0E0E0; }
.news-section .news-grid { display: grid; grid-template-columns: 1fr; gap: 16px; }
.news-section .news-card { background-color: #FFFFFF; border: 1px solid #E0E0E0; border-radius: 8px; padding: 20px; }
.news-section .news-img-wrap { margin-bottom: 12px; border-radius: 6px; overflow: hidden; }
.news-section .news-img { display: block; width: 100%; height: 180px; object-fit: cover; }
.news-section .news-meta { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.news-section .news-date { font-size: 12px; color: #888888; }
.news-section .news-tag { font-size: 11px; font-weight: 700; color: #C9A84C; background-color: #FDF9EE; padding: 2px 8px; border-radius: 3px; text-transform: uppercase; letter-spacing: 0.5px; }
.news-section .news-title { font-size: 16px; font-weight: 700; color: #1A1A1A; margin-bottom: 8px; line-height: 1.4; }
.news-section .news-excerpt { font-size: 14px; color: #555555; line-height: 1.6; margin-bottom: 12px; }
.news-section .news-more-wrap { }
.news-section .news-readmore { font-size: 13px; font-weight: 700; color: #C9A84C; text-decoration: none; }
.news-section .news-readmore:hover { text-decoration: underline; }

@media (min-width: 768px) {
  .news-section .news-grid { grid-template-columns: repeat(3, 1fr); }
}

/* LEGAL PROVINCES */
.states-section { padding: 48px 0; border-bottom: 1px solid #E0E0E0; }
.states-section .states-intro { font-size: 15px; color: #444444; margin-bottom: 24px; line-height: 1.6; }

/* EVENTS TABLE */
.events-section { padding: 48px 0; background-color: #FAFAFA; border-bottom: 1px solid #E0E0E0; }
.events-section .table-scroller { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.events-section .events-table { width: 100%; min-width: 480px; border: 1px solid #E0E0E0; border-radius: 8px; overflow: hidden; }
.events-section .events-table thead tr { background-color: #1A1A1A; }
.events-section .events-table th { padding: 12px 16px; font-size: 13px; font-weight: 700; color: #FFFFFF; text-align: left; }
.events-section .events-table td { padding: 14px 16px; font-size: 14px; color: #1A1A1A; border-bottom: 1px solid #E0E0E0; }
.events-section .events-table .row-alt td { background-color: #F5F5F5; }
.events-section .events-table .event-name { font-weight: 700; }

/* FAQ */
.faq-section { padding: 48px 0; border-bottom: 1px solid #E0E0E0; }
.faq-section .faq-list { display: flex; flex-direction: column; gap: 0; border: 1px solid #E0E0E0; border-radius: 8px; overflow: hidden; }
.faq-section .faq-item { border-bottom: 1px solid #E0E0E0; }
.faq-section .faq-item:last-child { border-bottom: none; }
.faq-section .faq-trigger-wrap { }
.faq-section .faq-trigger { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 16px 20px; cursor: pointer; background-color: #FFFFFF; transition: background-color 0.15s ease; }
.faq-section .faq-trigger:hover { background-color: #FDF9EE; }
.faq-section .faq-q-text { font-size: 15px; font-weight: 600; color: #1A1A1A; flex: 1; }
.faq-section .faq-icon-wrap { flex-shrink: 0; display: flex; align-items: center; transition: transform 0.2s ease; }
.faq-section .faq-item.open .faq-icon-wrap { transform: rotate(180deg); }
.faq-section .faq-answer { display: none; padding: 0 20px 16px; background-color: #FAFAFA; }
.faq-section .faq-item.open .faq-answer { display: block; }
.faq-section .faq-answer p { font-size: 14px; color: #444444; line-height: 1.7; }

/* PROVINCE ACCORDION */
.states-section .province-accordion { display: flex; flex-direction: column; border: 1px solid #E0E0E0; border-radius: 8px; overflow: hidden; }
.states-section .province-item { border-bottom: 1px solid #E0E0E0; }
.states-section .province-item:last-child { border-bottom: none; }
.states-section .province-trigger { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 14px 20px; cursor: pointer; background-color: #FFFFFF; transition: background-color 0.15s ease; user-select: none; }
.states-section .province-trigger:hover { background-color: #FDF9EE; }
.states-section .province-item.open .province-trigger { background-color: #FDF9EE; }
.states-section .province-name { font-size: 15px; font-weight: 600; color: #1A1A1A; }
.states-section .province-trigger-right { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.states-section .province-age-badge { font-size: 11px; font-weight: 700; color: #666666; background-color: #F0F0F0; padding: 2px 7px; border-radius: 3px; }
.states-section .province-chevron { transition: transform 0.2s ease; flex-shrink: 0; }
.states-section .province-item.open .province-chevron { transform: rotate(180deg); }
.states-section .province-panel { background-color: #FAFAFA; border-top: 1px solid #F0F0F0; }
.states-section .province-panel-inner { padding: 20px; display: flex; flex-direction: column; gap: 16px; }
.states-section .province-illustration { border-radius: 6px; overflow: hidden; line-height: 0; }
.states-section .province-illustration svg { width: 100%; max-width: 100%; height: auto; display: block; border-radius: 6px; }
.states-section .province-content-title { font-size: 16px; font-weight: 700; color: #1A1A1A; margin-bottom: 8px; }
.states-section .province-content-text { font-size: 14px; color: #444444; line-height: 1.7; margin-bottom: 0; }
.states-section .province-editors-pick { margin-top: 14px; border: 1px solid #E8D99A; border-radius: 6px; overflow: hidden; }
.states-section .pick-label-row { display: flex; align-items: center; gap: 6px; padding: 8px 14px; background-color: #FDF9EE; border-bottom: 1px solid #E8D99A; }
.states-section .pick-label-text { font-size: 11px; font-weight: 700; color: #C9A84C; text-transform: uppercase; letter-spacing: 0.5px; }
.states-section .pick-body { padding: 14px; }
.states-section .pick-brand { display: inline-block; font-size: 12px; font-weight: 800; padding: 3px 10px; border-radius: 3px; margin-bottom: 8px; letter-spacing: 0.3px; }
.states-section .pick-reason { font-size: 13px; color: #444444; line-height: 1.6; margin-bottom: 10px; }
.states-section .pick-link { display: inline-block; font-size: 13px; font-weight: 700; color: #C9A84C; text-decoration: none; border: 1px solid #C9A84C; padding: 5px 14px; border-radius: 4px; transition: all 0.15s ease; }
.states-section .pick-link:hover { background-color: #C9A84C; color: #FFFFFF; }

@media (min-width: 768px) {
  .states-section .province-panel-inner { flex-direction: row; align-items: flex-start; }
  .states-section .province-illustration { width: 200px; flex-shrink: 0; }
  .states-section .province-content { flex: 1; }
}
