/* Home page enhancements for KokoBet2025 */

/* Header */
.site-header { position: sticky; top: 0; z-index: 50; background: var(--color-surface); border-bottom: 1px solid var(--gray-200); box-shadow: var(--shadow-sm); }
.header-inner { display: flex; align-items: center; justify-content: space-between; min-height: 64px; }
.brand__link { font-family: var(--font-serif); font-weight: 800; font-size: 1.25rem; color: var(--color-text); }

/* Navigation */
.site-nav { display: flex; }
.site-nav__list { display: flex; align-items: center; gap: var(--space-6); }
.site-nav a { color: var(--color-text); font-weight: 600; }
.site-nav a:hover { color: var(--color-primary); text-decoration: none; }

/* Mobile nav toggle */
.nav-toggle { display: none; width: 44px; height: 44px; border-radius: var(--radius-md); border: 1px solid var(--gray-300); background-color: var(--color-surface); }
.nav-toggle:focus-visible { box-shadow: var(--focus-ring); }
.nav-toggle__bar { display: block; width: 20px; height: 2px; margin: 4px auto; background: var(--color-text); border-radius: 2px; transition: transform var(--dur-base) var(--ease-out); }

@media (max-width: 900px) {
  .nav-toggle { display: inline-flex; align-items: center; justify-content: center; }
  .site-nav { position: fixed; inset: 64px 0 auto 0; background: var(--color-surface); border-bottom: 1px solid var(--gray-200); transform: translateY(-120%); transition: transform var(--dur-base) var(--ease-out); }
  .site-nav.is-open { transform: translateY(0); }
  .site-nav__list { padding: var(--space-6) var(--container-gutter); flex-direction: column; align-items: flex-start; gap: var(--space-5); }
  .small-hide { display: none; }
}

/* Skip link */
.skip-link { position: absolute; left: -9999px; top: auto; }
.skip-link:focus { left: 16px; top: 16px; background: var(--color-primary); color: #fff; padding: 8px 12px; border-radius: var(--radius-md); z-index: 100; }

/* Hero */
.hero { background: linear-gradient(180deg, var(--gray-100), transparent 60%); padding: var(--space-14) 0 var(--space-12); }
.hero__content { max-width: 52rem; }
.hero__actions { display: flex; gap: var(--space-4); flex-wrap: wrap; margin-top: var(--space-6); }
.pill { display: inline-block; background: var(--gray-100); color: var(--gray-800); border: 1px solid var(--gray-200); padding: 6px 10px; border-radius: var(--radius-round); font-size: var(--fs-sm); margin-top: var(--space-4); margin-right: var(--space-3); }

/* Sections */
.section { padding: var(--space-14) 0; }
.figcaption { color: var(--gray-700); margin-top: var(--space-4); font-size: var(--fs-sm); }
.cta-row { display: flex; gap: var(--space-4); flex-wrap: wrap; margin-top: var(--space-6); }

/* Lists */
.list { padding-left: 1.25rem; }
.list li { margin-bottom: var(--space-3); }

/* Community grid fix */
.community__grid { align-items: center; }

/* FAQ */
.faq__items { display: grid; gap: var(--space-6); }
.faq details > summary { cursor: pointer; font-weight: 700; font-family: var(--font-serif); list-style: none; }
.faq details > summary::-webkit-details-marker { display: none; }
.faq details > summary span { position: relative; padding-left: 24px; }
.faq details > summary span::before { content: "+"; position: absolute; left: 0; top: 0; color: var(--color-primary); font-weight: 800; }
.faq details[open] > summary span::before { content: "–"; }
.faq p { margin-top: var(--space-4); }

/* Blog */
.blog__header { margin-bottom: var(--space-6); }

/* Forms */
.form .form-status { min-height: 1.25rem; color: var(--color-primary-700); margin-top: var(--space-3); font-size: var(--fs-sm); }
.input.error { border-color: var(--color-danger); }

/* Contact */
.contact__grid { align-items: start; }
.contact-list { display: grid; gap: var(--space-3); }

/* Footer */
.site-footer { background: var(--gray-100); border-top: 1px solid var(--gray-200); padding-top: var(--space-10); }
.footer__inner { display: grid; gap: var(--space-8); grid-template-columns: 1.2fr 1fr 1fr; }
.footer-links { display: grid; gap: var(--space-3); }
.footer__bottom { border-top: 1px solid var(--gray-200); padding: var(--space-6) 0; margin-top: var(--space-8); }
@media (max-width: 900px) { .footer__inner { grid-template-columns: 1fr; } }

/* Cookie banner */
.cookie-banner { position: fixed; left: 0; right: 0; bottom: 0; background: var(--color-surface); border-top: 1px solid var(--gray-200); box-shadow: 0 -6px 20px rgba(20,16,12,0.08); z-index: 60; padding: var(--space-6) 0; }
.cookie-banner__inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-6); }
.cookie-banner__text { margin: 0; max-width: 70ch; }
.cookie-banner__actions { display: flex; gap: var(--space-4); flex-wrap: wrap; }
@media (max-width: 700px) {
  .cookie-banner__inner { flex-direction: column; align-items: stretch; }
  .cookie-banner__actions { justify-content: flex-end; }
}

/* Chat widget */
.chat-toggle { position: fixed; right: 16px; bottom: 90px; z-index: 55; background: var(--color-primary); color: #fff; border: 0; padding: 10px 14px; border-radius: var(--radius-round); box-shadow: var(--shadow-md); font-weight: 700; }
.chat-toggle:hover { background: var(--color-primary-600); }
.chat-panel { position: fixed; right: 16px; bottom: 90px; width: min(360px, 92vw); max-height: 70vh; background: var(--color-surface); border: 1px solid var(--gray-300); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); display: none; flex-direction: column; overflow: hidden; z-index: 56; }
.chat-panel[aria-hidden="false"] { display: flex; }
.chat-panel__header { display: flex; align-items: center; justify-content: space-between; padding: var(--space-5) var(--space-6); background: var(--gray-100); border-bottom: 1px solid var(--gray-200); }
.chat-panel__body { padding: var(--space-6); }
.chat-close { background: transparent; border: 0; font-size: 1.5rem; line-height: 1; }

/* Utility */
.small { font-size: var(--fs-sm); }

