/* sortavala.city — places.css */

/* ── Сетка разделов (главная страница мест) ────────────────── */
.sorta_place_cats_grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:40px}
.sorta_place_cat_card{background:var(--c-white);border-radius:var(--r-xl);box-shadow:0 2px 14px rgba(0,0,0,.06);padding:28px 22px;display:flex;flex-direction:column;gap:8px;text-decoration:none;color:inherit;transition:box-shadow var(--trans),transform var(--trans)}
.sorta_place_cat_card:hover{box-shadow:0 10px 32px rgba(0,0,0,.1);transform:translateY(-3px)}
.sorta_place_cat_icon{font-size:36px;line-height:1}
.sorta_place_cat_name{font-size:16px;font-weight:800;color:var(--c-text);letter-spacing:-.02em}
.sorta_place_cat_count{font-size:12px;color:var(--c-accent);font-weight:700}
.sorta_place_cat_desc{font-size:12px;color:var(--c-muted);line-height:1.5;margin-top:2px}

/* ── Сетка мест внутри раздела ─────────────────────────────── */
.sorta_place_grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin-bottom:32px}
.sorta_place_card{background:var(--c-white);border-radius:var(--r-xl);box-shadow:0 2px 12px rgba(0,0,0,.06);overflow:hidden;text-decoration:none;color:inherit;display:flex;flex-direction:column;transition:box-shadow var(--trans),transform var(--trans)}
.sorta_place_card:hover{box-shadow:0 8px 28px rgba(0,0,0,.1);transform:translateY(-3px)}
.sorta_place_card_img{width:100%;height:180px;object-fit:cover;background:var(--c-surface2);display:block}
.sorta_place_card_img_empty{display:flex;align-items:center;justify-content:center;font-size:48px}
.sorta_place_card_body{padding:16px 18px;flex:1;display:flex;flex-direction:column;gap:6px}
.sorta_place_card_title{font-size:15px;font-weight:800;color:var(--c-text);letter-spacing:-.02em;line-height:1.25}
.sorta_place_card_desc{font-size:12px;color:var(--c-muted);line-height:1.5;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.sorta_place_card_foot{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:auto;padding-top:10px;border-top:1px solid rgba(0,0,0,.05)}
.sorta_place_badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.04em}
.sorta_place_badge_feat{background:#fef3c7;color:#b45309}
.sorta_place_rating{font-size:12px;font-weight:700;color:var(--c-text);display:flex;align-items:center;gap:3px}
.sorta_place_star{color:#f59e0b}
.sorta_place_rev_cnt{font-size:11px;font-weight:400;color:var(--c-muted)}
.sorta_place_price{font-size:13px;font-weight:800;color:var(--c-accent);margin-left:auto;white-space:nowrap}
.sorta_place_addr{font-size:11px;color:var(--c-dim);display:flex;align-items:center;gap:3px;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ── Детальная страница ────────────────────────────────────── */
.sorta_place_gallery{margin-bottom:28px}
.sorta_place_cover{width:100%;max-height:420px;object-fit:cover;border-radius:var(--r-xl);display:block;cursor:pointer}
.sorta_place_thumbs{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}
.sorta_place_thumb{width:120px;height:80px;object-fit:cover;border-radius:8px;cursor:pointer;transition:opacity var(--trans)}
.sorta_place_thumb:hover{opacity:.85}

/* ── Lightbox ──────────────────────────────────────────────── */
#sorta_lb{display:none;position:fixed;inset:0;z-index:10002;align-items:center;justify-content:center}
#sorta_lb.sorta_lb_open{display:flex}
#sorta_lb_bg{position:absolute;inset:0;background:rgba(0,0,0,.92)}
#sorta_lb_img{position:relative;max-width:90vw;max-height:88vh;object-fit:contain;border-radius:8px;z-index:1;display:block;box-shadow:0 8px 48px rgba(0,0,0,.6)}
#sorta_lb_close{position:fixed;top:20px;right:20px;z-index:2;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.15);border:none;color:#fff;font-size:22px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}
#sorta_lb_close:hover{background:rgba(255,255,255,.3)}
#sorta_lb_prev,#sorta_lb_next{position:fixed;top:50%;transform:translateY(-50%);z-index:2;width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.15);border:none;color:#fff;font-size:28px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}
#sorta_lb_prev{left:16px}
#sorta_lb_next{right:16px}
#sorta_lb_prev:hover,#sorta_lb_next:hover{background:rgba(255,255,255,.3)}
#sorta_lb_cnt{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.85);font-size:13px;font-weight:600;z-index:2;background:rgba(0,0,0,.5);padding:4px 14px;border-radius:20px;pointer-events:none}
@media(max-width:640px){
  #sorta_lb_prev{left:6px}
  #sorta_lb_next{right:6px}
  #sorta_lb_prev,#sorta_lb_next{width:38px;height:38px;font-size:22px}
}

.sorta_place_detail_rating{display:flex;align-items:center;gap:4px;margin:12px 0}
.sorta_place_star_lg{font-size:22px;color:#d1d5db;transition:color .1s}
.sorta_star_filled,.sorta_star_on{color:#f59e0b}
.sorta_star_off{color:#d1d5db}
.sorta_place_detail_rating_val{font-size:20px;font-weight:800;color:var(--c-text);margin-left:4px}
.sorta_place_detail_rating_cnt{font-size:13px;color:var(--c-muted);margin-left:4px}

/* ── Секции (отзывы / вопросы) ─────────────────────────────── */
.sorta_place_section{background:var(--c-white);border-radius:var(--r-xl);box-shadow:0 2px 10px rgba(0,0,0,.06);padding:28px;margin-top:16px}
.sorta_place_section_title{font-size:18px;font-weight:800;letter-spacing:-.03em;color:var(--c-text);margin-bottom:20px;display:flex;align-items:center;gap:8px}
.sorta_place_section_cnt{font-size:13px;font-weight:700;color:var(--c-accent);background:var(--c-accent-bg);padding:2px 8px;border-radius:20px}

/* Отзыв */
.sorta_place_review{padding:16px 0;border-bottom:1px solid rgba(0,0,0,.06)}
.sorta_place_review:last-of-type{border-bottom:none}
.sorta_place_review_head{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.sorta_place_review_author{font-size:13px;font-weight:700;color:var(--c-text)}
.sorta_place_review_date{font-size:11px;color:var(--c-muted);margin-top:2px}
.sorta_place_review_stars{margin-left:auto;font-size:15px;letter-spacing:1px}
.sorta_place_review_text{font-size:14px;color:var(--c-text);line-height:1.6}

/* Сводка рейтинга */
.sorta_place_rating_summary{display:flex;gap:28px;align-items:flex-start;padding:16px 0 20px;border-bottom:1px solid rgba(0,0,0,.06);margin-bottom:16px}
.sorta_place_rating_big{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:80px}
.sorta_place_rating_score{font-size:48px;font-weight:800;line-height:1;color:var(--c-text);letter-spacing:-.03em}
.sorta_place_rating_total{font-size:12px;color:var(--c-muted);white-space:nowrap}
.sorta_place_rating_bars{flex:1;display:flex;flex-direction:column;gap:6px;justify-content:center}
.sorta_place_rbar_row{display:flex;align-items:center;gap:8px}
.sorta_place_rbar_label{font-size:12px;font-weight:700;color:var(--c-text);width:24px;text-align:right;flex-shrink:0}
.sorta_place_rbar_track{flex:1;height:8px;background:var(--c-surface2);border-radius:4px;overflow:hidden}
.sorta_place_rbar_fill{height:100%;background:#f59e0b;border-radius:4px;transition:width .3s}
.sorta_place_rbar_cnt{font-size:12px;color:var(--c-muted);width:20px;flex-shrink:0}

/* Вакансии места */
.sorta_place_job_row{display:flex;flex-direction:column;align-items:flex-start;gap:6px;padding:12px 0;border-bottom:1px solid rgba(0,0,0,.06);text-decoration:none;color:inherit;transition:color var(--trans)}
.sorta_place_job_row:last-of-type{border-bottom:none}
.sorta_place_job_row:hover .sorta_place_job_title{color:var(--c-accent)}
.sorta_place_job_title{font-size:14px;font-weight:700;color:var(--c-text);width:100%}
.sorta_place_job_meta{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.sorta_place_job_salary{font-size:13px;font-weight:800;color:var(--c-accent);margin-left:4px}

/* Форма отзыва — интерактивные звёзды */
.sorta_place_form_wrap{border-top:1px solid rgba(0,0,0,.06);padding-top:24px}
.sorta_place_form_title{font-size:15px;font-weight:700;color:var(--c-text);margin-bottom:14px}
.sorta_place_stars_input{display:flex;gap:4px;font-size:32px;cursor:pointer;color:#d1d5db;user-select:none}
.sorta_star_label{transition:color .1s}
.sorta_star_label.sorta_star_hover,.sorta_star_label.sorta_star_selected{color:#f59e0b}

/* Ответ на отзыв */
.sorta_place_review_reply{margin-top:10px;padding:10px 14px;background:var(--c-surface2);border-radius:8px;border-left:3px solid var(--c-accent)}
.sorta_place_review_reply_label{font-size:11px;font-weight:700;color:var(--c-accent);text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:5px;margin-bottom:6px}
.sorta_place_review_reply_text{font-size:13px;color:var(--c-text);line-height:1.55}
.sorta_place_review_reply_form{margin-top:6px}

/* Вопрос-ответ */
.sorta_place_qa{padding:14px 0;border-bottom:1px solid rgba(0,0,0,.06)}
.sorta_place_qa:last-of-type{border-bottom:none}
.sorta_place_qa_q{display:flex;gap:10px;align-items:flex-start;color:var(--c-text)}
.sorta_place_qa_a{display:flex;gap:10px;align-items:flex-start;margin-top:10px;padding:10px 14px;background:var(--c-surface2);border-radius:8px;color:var(--c-muted);font-size:13px}
.sorta_place_qa_a svg{flex-shrink:0;margin-top:2px;color:var(--c-accent)}
.sorta_place_qa_q svg{flex-shrink:0;margin-top:3px;color:var(--c-accent)}
.sorta_place_qa_author{font-size:12px;font-weight:700;color:var(--c-text)}
.sorta_place_qa_date{font-weight:400;color:var(--c-muted)}
.sorta_place_qa_text{font-size:14px;line-height:1.5;margin-top:3px}
.sorta_place_qa_answer_form{margin-top:10px;padding:12px 14px;background:var(--c-surface2);border-radius:8px;border-left:3px solid var(--c-accent)}

/* ── Адаптив ───────────────────────────────────────────────── */
@media(max-width:1000px){
  .sorta_place_cats_grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .sorta_place_grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:640px){
  .sorta_place_cats_grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .sorta_place_grid{grid-template-columns:minmax(0,1fr)}
  .sorta_place_thumb{width:80px;height:56px}
  .sorta_place_section{padding:18px 16px}
  .sorta_place_rating_summary{flex-wrap:wrap;gap:16px}
  .sorta_place_rating_big{min-width:unset}
}

/* ── Афиша на странице места ────────────────────────────────── */
.sorta_place_afisha{background:var(--c-white);border-radius:var(--r-xl);box-shadow:0 2px 12px rgba(0,0,0,.06);padding:22px;margin-top:20px;margin-bottom:20px}
.sorta_place_afisha_head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.sorta_place_afisha_label{font-size:13px;font-weight:800;color:var(--c-text);letter-spacing:-.01em}
.sorta_place_afisha_cnt{font-size:12px;color:var(--c-muted);font-weight:600}
.sorta_place_afisha_grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}
.sorta_place_afisha_card{border-radius:var(--r-lg);overflow:hidden;background:var(--c-surface2);text-decoration:none;color:inherit;display:block;transition:box-shadow var(--trans),transform var(--trans)}
.sorta_place_afisha_card:hover{box-shadow:0 6px 24px rgba(0,0,0,.12);transform:translateY(-2px)}
.sorta_place_afisha_img{position:relative;height:130px;overflow:hidden}
.sorta_place_afisha_img img{width:100%;height:100%;object-fit:cover}
.sorta_place_afisha_img_ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:36px;background:var(--c-accent-bg)}
.sorta_place_afisha_badge{position:absolute;top:8px;left:8px;background:rgba(0,0,0,.65);backdrop-filter:blur(4px);border-radius:var(--r);padding:5px 8px;text-align:center;min-width:36px}
.sorta_place_afisha_day{font-size:15px;font-weight:800;color:#fff;line-height:1}
.sorta_place_afisha_mon{font-size:9px;font-weight:700;color:rgba(255,255,255,.8);text-transform:uppercase;letter-spacing:.05em;line-height:1;margin-top:2px}
.sorta_place_afisha_past_label{position:absolute;top:8px;right:8px;background:rgba(0,0,0,.55);color:rgba(255,255,255,.8);font-size:10px;font-weight:700;padding:3px 8px;border-radius:30px}
.sorta_place_afisha_body{padding:10px 12px 12px}
.sorta_place_afisha_title{font-size:13px;font-weight:700;color:var(--c-text);margin:5px 0 4px;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.sorta_place_afisha_meta{font-size:11px;color:var(--c-muted);display:flex;align-items:center;gap:4px}
.sorta_place_afisha_past{opacity:.65}
@media(max-width:640px){.sorta_place_afisha_grid{grid-template-columns:repeat(2,1fr)}}

/* ── Строка заголовок + кнопки (2/3 + 1/3) ─────────────────── */
.sorta_place_title_row{display:grid;grid-template-columns:2fr 1fr;gap:16px;align-items:start}
.sorta_place_title_main{}
.sorta_place_title_btns{display:flex;flex-direction:column;gap:8px;align-items:stretch}
@media(max-width:640px){.sorta_place_title_row{grid-template-columns:1fr}}

/* ── Партнёрские кнопки (в заголовке — столбик) ─────────────── */
.sorta_partner_btn{display:flex;align-items:center;justify-content:space-between;gap:8px;color:#fff;font-size:13px;font-weight:700;padding:10px 16px;border-radius:var(--r-lg);text-decoration:none;transition:opacity var(--trans),transform var(--trans);box-shadow:0 3px 10px rgba(0,0,0,.15)}
.sorta_partner_btn:hover{opacity:.88;transform:translateY(-1px)}
.sorta_partner_btn::after{content:"→";font-size:14px;flex-shrink:0}

/* ── Блок партнёрских кнопок перед вопросами ────────────────── */
.sorta_partner_block{background:var(--c-white);border-radius:var(--r-xl);padding:18px 20px;margin:20px 0;box-shadow:0 2px 12px rgba(0,0,0,.06)}
.sorta_partner_block_title{font-size:13px;font-weight:800;color:var(--c-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:12px}
.sorta_partner_block_btns{display:flex;flex-wrap:wrap;gap:10px}
.sorta_partner_block .sorta_partner_btn{padding:10px 20px;font-size:14px}

/* ── Карточка представителя в сайдбаре ─────────────────────── */
.sorta_owner_card{background:var(--c-white);border-radius:var(--r-xl);box-shadow:0 2px 12px rgba(0,0,0,.06);padding:14px 16px}
.sorta_owner_card_label{font-size:11px;font-weight:700;color:var(--c-accent);text-transform:uppercase;letter-spacing:.06em}
.sorta_owner_card_body{display:flex;align-items:center;gap:12px}
.sorta_owner_card_avatar{width:42px;height:42px;border-radius:50%;overflow:hidden;background:var(--c-surface2);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.sorta_owner_card_avatar img{width:100%;height:100%;object-fit:cover}
.sorta_owner_card_info{min-width:0}
.sorta_owner_card_name{font-size:14px;font-weight:700;color:var(--c-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sorta_owner_card_phone{display:block;font-size:13px;color:var(--c-accent);text-decoration:none;margin-top:2px}
.sorta_owner_card_phone:hover{text-decoration:underline}

/* ── Тултип «что такое представитель» ───────────────────────── */
.sorta_owner_tip_wrap{position:relative;display:inline-flex;align-items:center;cursor:default}
.sorta_owner_tip_icon{color:var(--c-muted);flex-shrink:0}
.sorta_owner_tip_popup{display:none;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:#1e293b;color:#fff;font-size:12px;font-weight:400;line-height:1.5;padding:8px 12px;border-radius:var(--r-lg);width:220px;text-align:left;pointer-events:none;z-index:10;box-shadow:0 4px 16px rgba(0,0,0,.25)}
.sorta_owner_tip_popup::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:#1e293b}
.sorta_owner_tip_wrap:hover .sorta_owner_tip_popup{display:block}
