/**
 * Zavix — Minimal Frontend CSS
 * Basic alignment and structure only. No design styling.
 *
 * @package Zavix
 */

/* RESET */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--zavix-body-font, 'Nunito', sans-serif); line-height: 1.6; }
h1, h2, h3, h4, h5, h6 { font-family: var(--zavix-heading-font, 'Nunito', sans-serif); }
a { text-decoration: none; color: var(--zavix-primary, #3bc469); }
img { max-width: 100%; height: auto; display: block; }
ul, ol { list-style: none; }

/* CONTAINER */
.zavix-container { max-width: 1200px; margin: 0 auto; padding: 0 16px; }

/* SR ONLY (hidden visually, kept for SEO) */
.zavix-sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* HIDDEN */
.hidden { display: none !important; }

/* ===== HEADER ===== */
.zavix-header { display: flex; flex-direction: column; border-bottom: 1px solid #e8eaed; }
.zavix-header-inner { max-width: 1200px; margin: 0 auto; padding: 0 16px; display: flex; align-items: center; height: 56px; width: 100%; gap: 12px; }
.zavix-logo img { height: 36px; width: auto; }
.zavix-logo-text { font-size: 20px; font-weight: 800; }
.zavix-nav { flex: 1; }
.zavix-nav-list { display: flex; gap: 4px; list-style: none; }
.zavix-nav-list li a { display: block; padding: 8px 12px; font-size: 14px; font-weight: 600; color: inherit; }
.zavix-header-actions { display: flex; align-items: center; gap: 8px; }
.zavix-icon-btn { width: 36px; height: 36px; border: none; background: #f0f1f3; border-radius: 50%; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.zavix-header-btn { padding: 8px 16px; font-size: 13px; font-weight: 700; background: var(--zavix-primary, #3bc469); color: #fff; border-radius: 8px; }
.zavix-hamburger { display: none; border: none; background: none; cursor: pointer; padding: 8px; }
.zavix-header-mobile-left { display: none; gap: 4px; }
.zavix-mobile-panel { display: none; }
.zavix-mobile-panel.open { display: block; padding: 8px 16px; border-top: 1px solid #e8eaed; }
.zavix-mobile-nav { list-style: none; }
.zavix-mobile-nav li a { display: block; padding: 10px 0; font-size: 15px; font-weight: 600; color: inherit; }
.zavix-desktop-only { display: flex; }

/* Dark mode icon toggle */
body:not(.dark-mode) .icon-moon { display: none; }
body.dark-mode .icon-sun { display: none; }

/* Search Overlay */
.zavix-search-overlay { position: fixed; top: 0; left: 0; right: 0; background: #fff; padding: 16px 0; z-index: 1001; transform: translateY(-100%); transition: transform 0.3s; box-shadow: 0 4px 12px rgba(0,0,0,0.1); }
.zavix-search-overlay.active { transform: translateY(0); }
.zavix-search-form { display: flex; gap: 8px; align-items: center; }
.zavix-search-input { flex: 1; padding: 10px 14px; border: 1px solid #e8eaed; border-radius: 8px; font-size: 16px; }
.zavix-search-submit { padding: 10px 20px; background: var(--zavix-primary, #3bc469); color: #fff; border: none; border-radius: 8px; font-weight: 700; cursor: pointer; }
.zavix-search-close { font-size: 28px; background: none; border: none; cursor: pointer; padding: 0 8px; }

/* ===== MAIN / SECTIONS ===== */
.zavix-main { padding: 24px 0 40px; }
.zavix-section { margin-top: 32px; }
.zavix-section-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.zavix-section-btn { font-size: 13px; font-weight: 700; }
.zavix-hero { margin-bottom: 24px; }
.zavix-hero h1 { margin-bottom: 8px; }

/* ===== GRIDS ===== */
.zavix-grid { display: grid; gap: 12px; }
.zavix-grid--4 { grid-template-columns: repeat(4, 1fr); }
.zavix-grid--8 { grid-template-columns: repeat(4, 1fr); }

/* ===== CARD ===== */
.zavix-card { border: 1px solid #e8eaed; border-radius: 12px; overflow: hidden; }
.zavix-card-link { display: block; color: inherit; }
.zavix-card-thumb { position: relative; overflow: hidden; }
.zavix-card-thumb img { width: 100%; height: auto; }
.zavix-card-placeholder { aspect-ratio: 1; background: #f0f1f3; }
.zavix-card-body { padding: 8px 10px 10px; }
.zavix-card-title { font-size: 13px; font-weight: 700; overflow: hidden; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
.zavix-card-meta { font-size: 11px; color: #6b7280; margin-top: 2px; }
.zavix-card-label { position: absolute; top: 6px; left: 6px; padding: 1px 6px; font-size: 9px; font-weight: 700; border-radius: 4px; color: #fff; }
.zavix-card-label--new { background: var(--zavix-primary, #3bc469); }
.zavix-card-label--updated { background: #6366f1; }
.zavix-card-readmore { font-size: 12px; font-weight: 700; color: var(--zavix-primary, #3bc469); }

/* Top rated card extras */
.zavix-card--top-rated .zavix-card-cover { aspect-ratio: 16/9; overflow: hidden; }
.zavix-card--top-rated .zavix-card-cover img { width: 100%; height: 100%; object-fit: cover; }
.zavix-card-dl-btn { display: block; padding: 8px; text-align: center; font-size: 13px; font-weight: 700; background: var(--zavix-primary, #3bc469); color: #fff; }

/* ===== SINGLE PAGE ===== */
.zavix-row { display: flex; gap: 24px; margin-bottom: 24px; }
.zavix-col-left { flex: 2; min-width: 0; }
.zavix-col-right { flex: 1; min-width: 0; }

.zavix-breadcrumbs { font-size: 13px; color: #6b7280; margin-bottom: 12px; }
.zavix-breadcrumbs a { color: var(--zavix-primary, #3bc469); }
.zavix-breadcrumbs .sep { margin: 0 6px; }

.zavix-single-title { font-size: 24px; margin-bottom: 16px; }

.zavix-info-table { width: 100%; border-collapse: collapse; margin-bottom: 16px; }
.zavix-info-table th, .zavix-info-table td { padding: 8px 12px; border: 1px solid #e8eaed; text-align: left; font-size: 14px; }
.zavix-info-table th { width: 140px; font-weight: 600; }

.zavix-featured-img { width: 100%; border-radius: 12px; }

/* Buttons */
.zavix-btn { display: inline-block; padding: 8px 16px; font-size: 14px; font-weight: 700; background: var(--zavix-primary, #3bc469); color: #fff; border: none; border-radius: 8px; cursor: pointer; }
.zavix-btn--outline { background: transparent; border: 1px solid #e8eaed; color: inherit; }
.zavix-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 24px; }

/* Gallery */
.zavix-gallery { margin-bottom: 24px; overflow: hidden; }
.zavix-gallery-track { display: flex; gap: 12px; overflow-x: auto; scroll-snap-type: x mandatory; scrollbar-width: none; }
.zavix-gallery-track::-webkit-scrollbar { display: none; }
.zavix-gallery-slide { flex: 0 0 260px; scroll-snap-align: start; border-radius: 8px; overflow: hidden; cursor: pointer; }
.zavix-gallery-slide img { width: 100%; height: auto; }

/* Description collapsible */
.zavix-description .zavix-desc-inner { max-height: 250px; overflow: hidden; transition: max-height 0.4s; }
.zavix-description.expanded .zavix-desc-inner { max-height: none; }
.zavix-desc-toggle { display: block; margin-top: 8px; padding: 6px 16px; border: 1px solid #e8eaed; border-radius: 6px; background: none; cursor: pointer; font-weight: 600; font-size: 13px; }
.zavix-description.expanded .show-more { display: none; }
.zavix-description:not(.expanded) .show-less { display: none; }

/* FAQ */
.zavix-faq-section { margin-top: 24px; }
.zavix-faq-item { border: 1px solid #e8eaed; border-radius: 8px; margin-bottom: 6px; overflow: hidden; }
.zavix-faq-q { display: flex; justify-content: space-between; align-items: center; width: 100%; padding: 12px; background: none; border: none; font-size: 14px; font-weight: 600; cursor: pointer; text-align: left; }
.zavix-faq-q svg { flex-shrink: 0; transition: transform 0.2s; }
.zavix-faq-item.active .zavix-faq-q svg { transform: rotate(180deg); }
.zavix-faq-a { max-height: 0; overflow: hidden; transition: max-height 0.3s, padding 0.3s; padding: 0 12px; }
.zavix-faq-item.active .zavix-faq-a { max-height: 500px; padding: 0 12px 12px; }
.zavix-faq-a p { font-size: 14px; color: #6b7280; }

/* Vote results */
.zavix-vote-results { padding: 16px; border: 1px solid #e8eaed; border-radius: 8px; }
.zavix-vote-bar { height: 12px; background: #ef4444; border-radius: 6px; overflow: hidden; margin: 12px 0; }
.zavix-vote-fill { height: 100%; background: var(--zavix-primary, #3bc469); transition: width 0.3s; }
.zavix-vote-stats { display: flex; justify-content: space-between; font-size: 13px; }

/* Download Section */
.zavix-download-section { margin: 32px 0; padding: 24px; border: 2px dashed #e8eaed; border-radius: 12px; text-align: center; }
.zavix-dl-buttons { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; margin-top: 12px; }
.zavix-dl-desc { margin-top: 12px; font-size: 13px; color: #6b7280; }

/* ===== DOWNLOAD POPUP ===== */
.zavix-popup { position: fixed; inset: 0; z-index: 9999; display: none; align-items: center; justify-content: center; }
.zavix-popup.active { display: flex; }
.zavix-popup-overlay { position: absolute; inset: 0; background: rgba(0,0,0,0.75); }
.zavix-popup-content { position: relative; z-index: 1; background: #fff; border-radius: 16px; padding: 40px; text-align: center; max-width: 460px; width: 90%; }
.zavix-popup-close { position: absolute; top: 12px; right: 16px; font-size: 28px; background: none; border: none; cursor: pointer; }
.zavix-popup-icon img { width: 80px; height: 80px; border-radius: 16px; margin: 0 auto 12px; object-fit: cover; }
.zavix-popup-title { font-size: 18px; font-weight: 700; margin-bottom: 16px; }
.zavix-popup-progress { height: 8px; background: #e8eaed; border-radius: 4px; overflow: hidden; margin-bottom: 8px; }
.zavix-popup-bar { height: 100%; width: 0; background: var(--zavix-primary, #3bc469); transition: width 0.1s linear; }
.zavix-popup-timer { font-size: 14px; color: #6b7280; margin-bottom: 16px; }
.zavix-popup-buttons { display: flex; flex-direction: column; gap: 8px; }
.zavix-popup-buttons a { display: block; padding: 12px; background: var(--zavix-primary, #3bc469); color: #fff; border-radius: 8px; font-weight: 700; text-align: center; }
.zavix-popup-thanks { font-size: 14px; color: var(--zavix-primary, #3bc469); font-weight: 700; margin-top: 8px; }
.zavix-popup-ad { margin: 12px 0; text-align: center; overflow: hidden; }

/* ===== FOOTER ===== */
.zavix-footer { border-top: 1px solid #e8eaed; padding: 24px 0; margin-top: 32px; text-align: center; }
.zavix-footer-logo img { height: 36px; margin: 0 auto 12px; }
.zavix-footer-menu { display: flex; justify-content: center; gap: 16px; flex-wrap: wrap; list-style: none; margin-bottom: 12px; }
.zavix-footer-menu li a { font-size: 13px; color: #6b7280; }
.zavix-footer-social { display: flex; justify-content: center; gap: 12px; flex-wrap: wrap; margin-bottom: 12px; }
.zavix-social-icon { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; border-radius: 50%; color: #6b7280; transition: color 0.2s ease; }
.zavix-social-icon:hover { color: var(--zavix-primary, #3bc469); }
.zavix-social-icon svg { width: 18px; height: 18px; }
.zavix-copyright { font-size: 12px; color: #9ca3af; }

/* ===== AD SLOTS ===== */
.zavix-ad-slot { margin: 16px 0; text-align: center; overflow: hidden; }

/* ===== ADVANCED FOOTER ===== */
.zavix-footer--advanced { padding: 32px 0 0; }
.zavix-footer-grid { display: grid; grid-template-columns: 1.2fr 1fr 1fr; gap: 32px; padding-bottom: 24px; }
.zavix-footer-desc { font-size: 13px; color: #6b7280; margin-top: 12px; line-height: 1.7; }
.zavix-footer-heading { display: block; font-size: 15px; font-weight: 700; margin-bottom: 14px; }
.zavix-footer-links { list-style: none; }
.zavix-footer-links li { margin-bottom: 6px; }
.zavix-footer-links li a { font-size: 13px; color: #6b7280; transition: color 0.2s; }
.zavix-footer-links li a:hover { color: var(--zavix-primary, #3bc469); }
.zavix-footer-contact { display: flex; flex-direction: column; gap: 8px; }
.zavix-footer-contact-item { display: flex; align-items: center; gap: 8px; font-size: 13px; color: #6b7280; }
.zavix-footer-contact-item a { color: #6b7280; transition: color 0.2s; }
.zavix-footer-contact-item a:hover { color: var(--zavix-primary, #3bc469); }
.zavix-footer-contact-item svg { flex-shrink: 0; color: #9ca3af; }
.zavix-footer-bottom { border-top: 1px solid #e8eaed; padding: 16px 0; text-align: center; }
.zavix-footer-bottom p { font-size: 12px; color: #9ca3af; margin: 0; }

/* ===== CONTACT FORM ===== */
.zavix-contact-section { margin-top: 24px; }
.zavix-contact-info { display: flex; gap: 24px; flex-wrap: wrap; margin-bottom: 20px; }
.zavix-contact-info-item { display: flex; align-items: center; gap: 8px; font-size: 14px; color: #374151; }
.zavix-contact-info-item a { color: var(--zavix-primary, #3bc469); }
.zavix-contact-info-item svg { flex-shrink: 0; color: #6b7280; }
.zavix-contact-form { max-width: 640px; }
.zavix-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.zavix-form-field { margin-bottom: 16px; }
.zavix-form-field label { display: block; font-size: 13px; font-weight: 600; margin-bottom: 6px; }
.zavix-form-field label .required { color: #ef4444; }
.zavix-form-field input,
.zavix-form-field textarea { width: 100%; padding: 10px 14px; border: 1px solid #e8eaed; border-radius: 8px; font-size: 14px; font-family: inherit; transition: border-color 0.2s; }
.zavix-form-field input:focus,
.zavix-form-field textarea:focus { border-color: var(--zavix-primary, #3bc469); outline: none; box-shadow: 0 0 0 2px rgba(59,196,105,0.12); }
.zavix-contact-submit { margin-top: 4px; }
.zavix-contact-status { margin-top: 12px; padding: 10px 16px; border-radius: 8px; font-size: 13px; font-weight: 500; }
.zavix-contact-status--success { background: #ecfdf5; border: 1px solid #a7f3d0; color: #065f46; }
.zavix-contact-status--error { background: #fef2f2; border: 1px solid #fecaca; color: #991b1b; }

/* ===== MENU ICONS ===== */
.zavix-menu-icon { font-size: 16px; width: 16px; height: 16px; vertical-align: middle; }

/* ===== ARCHIVE ===== */
.zavix-archive-header { margin-bottom: 20px; }

/* ===== PAGINATION ===== */
.nav-links { display: flex; justify-content: center; gap: 6px; margin-top: 24px; }
.page-numbers { display: inline-flex; align-items: center; justify-content: center; min-width: 36px; height: 36px; padding: 0 10px; border: 1px solid #e8eaed; border-radius: 6px; font-size: 14px; }
.page-numbers.current { background: var(--zavix-primary, #3bc469); color: #fff; border-color: var(--zavix-primary, #3bc469); }

/* ===== RESPONSIVE ===== */
@media (max-width: 1024px) {
	.zavix-grid--4 { grid-template-columns: repeat(2, 1fr); }
	.zavix-grid--8 { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
	/* Header: mobile layout */
	.zavix-nav { display: none; }
	.zavix-desktop-only { display: none !important; }
	.zavix-hamburger { display: block; }
	.zavix-header-mobile-left { display: flex; }
	.zavix-header-inner { justify-content: space-between; }
	.zavix-header-btn { display: none; }

	/* Grids */
	.zavix-grid--4 { grid-template-columns: repeat(2, 1fr); }
	.zavix-grid--8 { grid-template-columns: repeat(2, 1fr); }

	/* Single page columns stack */
	.zavix-row { flex-direction: column; }

	/* Advanced footer stack */
	.zavix-footer-grid { grid-template-columns: 1fr; gap: 24px; }

	/* Contact form row stack */
	.zavix-form-row { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
	.zavix-grid--4 { grid-template-columns: 1fr; }
	.zavix-grid--8 { grid-template-columns: repeat(2, 1fr); }
}

/* ===== SIDEBAR ===== */
.zavix-layout-with-sidebar { display: grid; grid-template-columns: 1fr 300px; gap: 32px; }
.zavix-layout-with-sidebar > .zavix-content { min-width: 0; }
.zavix-sidebar { position: sticky; top: 80px; align-self: start; }
.zavix-sidebar-section { background: var(--zavix-card-bg, #fff); border-radius: 12px; padding: 20px; margin-bottom: 20px; }
.zavix-sidebar-title { font-size: 16px; font-weight: 700; margin: 0 0 16px; padding-bottom: 10px; border-bottom: 1px solid #e8eaed; }
.zavix-sidebar-list { list-style: none; padding: 0; margin: 0; }
.zavix-sidebar-item { margin-bottom: 12px; }
.zavix-sidebar-link { display: flex; align-items: center; gap: 12px; text-decoration: none; color: inherit; }
.zavix-sidebar-icon { border-radius: 10px; object-fit: cover; }
.zavix-sidebar-meta { display: flex; flex-direction: column; gap: 2px; }
.zavix-sidebar-name { font-size: 14px; font-weight: 600; }
.zavix-sidebar-rating { font-size: 12px; color: #757575; }
.zavix-sidebar-cats { list-style: none; padding: 0; margin: 0; }
.zavix-sidebar-cats li { margin-bottom: 8px; }
.zavix-sidebar-cats a { display: flex; justify-content: space-between; text-decoration: none; color: inherit; font-size: 14px; padding: 6px 0; border-bottom: 1px solid #f0f0f0; }
.zavix-sidebar-cats a span { color: #757575; font-size: 12px; }

@media (max-width: 768px) {
	.zavix-layout-with-sidebar { grid-template-columns: 1fr; }
	.zavix-sidebar { position: static; }
}
