/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:Arial,Helvetica,sans-serif;font-size:14px;line-height:1.6;color:#333;background:#f4f6f9}
a{color:#4DB7FE;text-decoration:none}
a:hover{color:#3a9bd9}
img{max-width:100%;display:block}

/* ── Layout ── */
.container{max-width:1200px;margin:0 auto;padding:0 20px}

/* ── Header ── */
.site-header{background:#fff;border-bottom:1px solid #e5e7f2;padding:12px 0;position:sticky;top:0;z-index:100}
.site-header .container{display:flex;align-items:center;gap:24px}
.logo img{height:36px}
.main-nav{display:flex;gap:20px;margin-left:auto}
.main-nav a{color:#566985;font-weight:500;font-size:14px}
.main-nav a:hover{color:#4DB7FE}
.header-actions{margin-left:16px}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:4px;font-size:13px;font-weight:600;border:none;cursor:pointer;transition:background .2s}
.btn-primary{background:#4DB7FE;color:#fff}
.btn-primary:hover{background:#3a9bd9;color:#fff}
.btn-open{background:#5ed0b1;color:#fff}
.btn-open:hover{background:#4bc49a;color:#fff}

/* ── Badges ── */
.badge{display:inline-flex;align-items:center;gap:3px;padding:3px 7px;border-radius:3px;font-size:11px;font-weight:700;text-transform:uppercase}
.badge-verified{background:transparent}
.badge-featured{background:#5ed0b1;color:#fff}
.listing-card .badge{position:absolute;z-index:2}
.listing-card .badge-verified{top:8px;right:8px}
.listing-card .badge-featured{top:8px;right:32px}

/* ── Breadcrumbs ── */
.breadcrumbs{font-size:13px;color:#878C9F;margin-bottom:16px}
.breadcrumbs a{color:#566985}
.breadcrumbs a::after{content:" / ";color:#aaa;margin:0 4px}
.breadcrumbs span{color:#aaa}

/* ══════════════════════════════
   CATALOG PAGE
══════════════════════════════ */
.cat-hero{background:linear-gradient(135deg,#1a2a4a 0%,#2d4a7a 100%);padding:40px 0 30px;color:#fff}
.cat-hero h1{font-size:28px;font-weight:700;margin:8px 0 0}
.cat-hero .breadcrumbs a{color:rgba(255,255,255,.7)}
.cat-hero .breadcrumbs a::after{color:rgba(255,255,255,.4)}
.cat-hero .breadcrumbs span{color:rgba(255,255,255,.5)}
.cat-description{background:rgba(255,255,255,.08);border-radius:8px;padding:20px;margin-top:16px;font-size:13px;line-height:1.7;color:rgba(255,255,255,.85);max-width:860px}

.cat-body{padding:30px 0 60px}

/* Подкатегории */
.subcats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:30px}
.subcat-card{background:#fff;border:1px solid #e5e7f2;border-radius:8px;padding:24px 16px;text-align:center;color:#566985;transition:box-shadow .2s,border-color .2s}
.subcat-card:hover{border-color:#4DB7FE;box-shadow:0 4px 16px rgba(77,183,254,.15);color:#4DB7FE}
.subcat-card h3{font-size:14px;font-weight:600;margin:8px 0 4px}
.subcat-card span{font-size:12px;color:#aaa}
.subcat-icon{width:40px;height:40px;margin:0 auto 8px;border-radius:6px;object-fit:cover}

/* Фильтры */
.filters-bar{display:flex;align-items:center;flex-wrap:wrap;gap:16px;background:#fff;border:1px solid #e5e7f2;border-radius:8px;padding:14px 20px;margin-bottom:24px}
.filter-group{display:flex;align-items:center;gap:8px}
.filter-group label{font-size:12px;color:#878C9F;white-space:nowrap}
.filter-group select{border:1px solid #ddd;border-radius:4px;padding:5px 10px;font-size:13px;background:#fff;cursor:pointer}
.results-count{margin-left:auto;font-size:13px;color:#878C9F}

/* Сетка листингов */
.listings-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:1100px){.listings-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:768px){.listings-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.listings-grid{grid-template-columns:1fr}}

/* Карточка листинга */
.listing-card{background:#fff;border:1px solid #e5e7f2;border-radius:8px;overflow:hidden;position:relative;transition:box-shadow .2s,transform .2s}
.listing-card:hover{box-shadow:0 6px 20px rgba(0,0,0,.1);transform:translateY(-2px)}
.card-thumb{display:block;aspect-ratio:16/10;overflow:hidden;background:#f0f2f5}
.card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.listing-card:hover .card-thumb img{transform:scale(1.04)}
.card-body{padding:12px 14px 14px}
.card-title{font-size:14px;font-weight:600;line-height:1.4;margin-bottom:6px}
.card-title a{color:#333}
.card-title a:hover{color:#4DB7FE}
.card-desc{font-size:12px;color:#878C9F;line-height:1.5;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-meta{display:flex;gap:10px;font-size:12px;color:#aaa;flex-wrap:wrap}
.card-meta span{display:flex;align-items:center;gap:3px}
.no-results{color:#878C9F;padding:40px 0;text-align:center;grid-column:1/-1}

/* Пагинация */
.pagination{display:flex;gap:8px;justify-content:center;margin:36px 0 0;flex-wrap:wrap}
.page-btn{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 12px;border:1px solid #ddd;border-radius:4px;font-size:13px;color:#566985;background:#fff;transition:all .2s}
.page-btn:hover{border-color:#4DB7FE;color:#4DB7FE}
.page-btn.active{background:#4DB7FE;border-color:#4DB7FE;color:#fff}

/* ══════════════════════════════
   LISTING PAGE
══════════════════════════════ */
.listing-hero{position:relative;background:#1a2a4a center/cover no-repeat;padding:60px 0 0;color:#fff;min-height:260px}
.listing-hero-overlay{position:absolute;inset:0;background:rgba(0,0,0,.6)}
.listing-hero .container{position:relative}
.listing-hero-content{padding-bottom:20px}
.listing-header-main h1{font-size:26px;font-weight:700;line-height:1.3;display:flex;align-items:center;gap:10px}
.verified-badge img{vertical-align:middle}
.listing-meta-top{display:flex;flex-wrap:wrap;gap:16px;margin-top:10px;font-size:13px;color:rgba(255,255,255,.8)}
.listing-meta-top a{color:rgba(255,255,255,.8)}
.listing-meta-top a:hover{color:#fff}
.listing-hero-bottom{display:flex;align-items:center;gap:16px;padding:14px 0;border-top:1px solid rgba(255,255,255,.15);flex-wrap:wrap}
.cat-badge{background:rgba(255,255,255,.12);color:#fff;border-radius:4px;padding:5px 12px;font-size:12px;font-weight:600}
.cat-badge:hover{background:rgba(255,255,255,.2);color:#fff}
.listing-stats{margin-left:auto;font-size:13px;color:rgba(255,255,255,.6)}

/* Навигация по секциям */
.section-nav{background:#fff;border-bottom:1px solid #e5e7f2;position:sticky;top:60px;z-index:90}
.section-nav .container{display:flex;gap:0}
.section-nav a{padding:13px 18px;font-size:13px;color:#566985;border-bottom:2px solid transparent;display:inline-block}
.section-nav a:hover{color:#4DB7FE;border-bottom-color:#4DB7FE}

/* Основной layout */
.listing-body{padding:24px 0 60px;background:#f4f6f9}
.listing-layout{display:grid;grid-template-columns:1fr 300px;gap:24px;align-items:start}
@media(max-width:900px){.listing-layout{grid-template-columns:1fr}}

/* Блоки контента */
.content-block{background:#fff;border:1px solid #e5e7f2;border-radius:8px;margin-bottom:20px;overflow:hidden}
.content-block h3{font-size:15px;font-weight:600;padding:14px 20px;border-bottom:1px solid #f0f2f5;color:#566985}
.block-body{padding:20px;font-size:14px;line-height:1.7;color:#555}

/* Telegram посты */
.tg-posts{display:flex;flex-direction:column;gap:12px}
.tg-post{display:block;padding:12px;border:1px solid #f0f2f5;border-radius:6px;color:#333;transition:border-color .2s}
.tg-post:hover{border-color:#4DB7FE}
.tg-post-text{font-size:13px;line-height:1.5;color:#555;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.tg-post small{font-size:11px;color:#aaa;margin-top:6px;display:block}

/* Keywords */
.keywords{margin-top:12px;font-size:12px;color:#4DB7FE}

/* Video */
.video-wrap{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:6px}
.video-wrap iframe{position:absolute;top:0;left:0;width:100%;height:100%}

/* Reviews */
.reviews-list{display:flex;flex-direction:column;gap:16px}
.review-item{display:flex;gap:12px}
.review-avatar{flex-shrink:0}
.avatar-placeholder{width:40px;height:40px;border-radius:50%;background:#4DB7FE;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px}
.review-content{flex:1}
.review-header{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.review-header strong{font-size:14px;color:#333}
.stars{display:flex;gap:1px}
.star{color:#ddd;font-size:14px}
.star.filled{color:#ffc107}
.review-score{font-size:12px;color:#aaa}
.review-content p{font-size:13px;color:#555;line-height:1.6}
.review-content small{font-size:11px;color:#aaa}

/* Форма отзыва */
.review-form{display:flex;flex-direction:column;gap:12px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.review-form input,.review-form textarea{width:100%;border:1px solid #ddd;border-radius:4px;padding:9px 12px;font-size:13px;font-family:inherit}
.review-form input:focus,.review-form textarea:focus{outline:none;border-color:#4DB7FE}
.star-rating-input{display:flex;align-items:center;gap:4px;direction:rtl;width:fit-content}
.star-rating-input span{direction:ltr;font-size:13px;color:#878C9F;margin-right:6px}
.star-rating-input input{display:none}
.star-rating-input label{font-size:22px;color:#ddd;cursor:pointer;transition:color .1s}
.star-rating-input input:checked~label,.star-rating-input label:hover,.star-rating-input label:hover~label{color:#ffc107}

/* Sidebar */
.listing-sidebar{display:flex;flex-direction:column;gap:16px}
.sidebar-block{background:#fff;border:1px solid #e5e7f2;border-radius:8px;padding:16px 18px}
.sidebar-block h4{font-size:14px;font-weight:600;color:#566985;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #f0f2f5}
.similar-list{list-style:none;display:flex;flex-direction:column;gap:10px}
.similar-item{display:flex;gap:10px;align-items:center;color:#333}
.similar-item img{width:48px;height:48px;border-radius:6px;object-fit:cover;flex-shrink:0}
.similar-item div strong{display:block;font-size:13px;line-height:1.3;margin-bottom:2px}
.similar-item div span{font-size:11px;color:#aaa}
.tags-cloud{display:flex;flex-wrap:wrap;gap:6px}
.tag{background:#f0f2f5;color:#566985;border-radius:3px;padding:4px 9px;font-size:12px;transition:background .2s}
.tag:hover{background:#4DB7FE;color:#fff}

/* ══════════════════════════════
   INDEX PAGE
══════════════════════════════ */
.index-hero{background:linear-gradient(135deg,#0d1b2a 0%,#1e3a5f 100%);padding:70px 0;text-align:center;color:#fff}
.index-hero h1{font-size:36px;font-weight:700;margin-bottom:12px}
.index-hero p{font-size:16px;color:rgba(255,255,255,.7);max-width:520px;margin:0 auto 28px}
.index-hero-search{display:flex;max-width:500px;margin:0 auto;gap:0}
.index-hero-search input{flex:1;border:none;border-radius:4px 0 0 4px;padding:12px 16px;font-size:14px}
.index-hero-search button{background:#4DB7FE;color:#fff;border:none;border-radius:0 4px 4px 0;padding:0 22px;font-weight:600;cursor:pointer}

.root-cats{padding:50px 0}
.root-cats h2{font-size:22px;font-weight:700;color:#333;margin-bottom:24px}
.root-cats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}
.root-cat-card{background:#fff;border:1px solid #e5e7f2;border-radius:8px;padding:28px 16px;text-align:center;color:#566985;transition:box-shadow .2s,border-color .2s}
.root-cat-card:hover{border-color:#4DB7FE;box-shadow:0 4px 16px rgba(77,183,254,.15);color:#4DB7FE}
.root-cat-card h3{font-size:15px;font-weight:600;margin:8px 0 4px}
.root-cat-card span{font-size:12px;color:#aaa}

.latest-section{padding:0 0 60px}
.latest-section h2{font-size:22px;font-weight:700;color:#333;margin-bottom:24px}

/* ── Footer ── */
.site-footer{background:#1a2a4a;color:rgba(255,255,255,.6);padding:50px 0 20px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-grid p{font-size:13px;margin-top:10px;line-height:1.6}
.footer-grid h4{color:#fff;font-size:14px;font-weight:600;margin-bottom:12px}
.footer-grid a{display:block;color:rgba(255,255,255,.6);font-size:13px;margin-bottom:6px}
.footer-grid a:hover{color:#4DB7FE}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:20px;font-size:12px}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr}}

/* ── Icons (простые символы вместо icon font) ── */
.icon-users::before{content:"👥";font-size:12px}
.icon-eye::before{content:"👁";font-size:12px}
.icon-star::before{content:"★";color:#ffc107}
.icon-map::before{content:"📍";font-size:11px}
.icon-folder::before{content:"📁";font-size:11px}
.icon-send::before{content:"✈";font-size:12px}
