/*
Theme Name: TravelDom
Theme URI: https://web-seo.by
Author: web-seo.by
Author URI: https://web-seo.by
Description: Портал бронирования домиков, глэмпингов и кемпингов. Каталог объектов на CPT+ACF Pro, AJAX-фильтрация, форма бронирования с проверкой занятости по iCal, личный кабинет владельца на acf_form(), SEO-разметка Schema.org (LodgingBusiness/VacationRental).
Version: 1.0.0
Requires PHP: 7.4
Text Domain: traveldom
Tags: booking, real-estate, custom-post-type, acf
*/

/* ==========================================================================
   Design tokens
   Signature: топографические линии рельефа (контурные линии карты) —
   визуальная отсылка к местности, где стоят домики/кемпинги.
   ========================================================================== */
:root{
  --stone:        #EDEAE1;   /* фон */
  --stone-dim:    #E2DECF;   /* фон карточек/секций */
  --ink:          #1B2420;   /* текст, почти чёрно-зелёный */
  --ink-soft:     #465049;   /* второстепенный текст */
  --pine:         #2F4B3C;   /* основной акцент — глубокий хвойный */
  --pine-dark:    #1E332A;
  --ochre:        #C68A2E;   /* тёплый акцент — охра/костёр */
  --ochre-dark:   #A6721F;
  --sage:         #A9B8A0;   /* линии, разделители */
  --line:         #D3CDBC;
  --white:        #FBFAF6;
  --danger:       #A3402F;
  --success:      #3E6B4F;

  --font-display: "Fraunces", Georgia, "Times New Roman", serif;
  --font-body:    "Public Sans", "Segoe UI", Arial, sans-serif;
  --font-mono:    "IBM Plex Mono", "Courier New", monospace;

  --radius-s: 4px;
  --radius-m: 10px;
  --radius-l: 22px;
  --shadow-card: 0 1px 2px rgba(27,36,32,.06), 0 8px 24px rgba(27,36,32,.07);
  --container: 1180px;
}

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=Public+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap');

*,*::before,*::after{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body.traveldom{
  margin:0;
  background: var(--stone);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}
img{ max-width:100%; display:block; }
a{ color: inherit; text-decoration: none; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4{ font-family: var(--font-display); font-weight:600; margin:0 0 .5em; color: var(--pine-dark); }
h1{ font-size: clamp(2rem, 3.4vw, 3.4rem); line-height:1.05; letter-spacing:-.01em; }
h2{ font-size: clamp(1.5rem, 2.4vw, 2.2rem); line-height:1.15; }
h3{ font-size: 1.25rem; }
p{ margin:0 0 1em; }
.container{ max-width: var(--container); margin:0 auto; padding:0 24px; }
:focus-visible{ outline: 3px solid var(--ochre); outline-offset: 2px; }
button{ font-family: var(--font-body); cursor:pointer; }

/* Topographic contour signature -- used as section dividers / texture */
.contour-divider{
  height: 34px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 400 34'%3E%3Cg fill='none' stroke='%23A9B8A0' stroke-width='1'%3E%3Cpath d='M0 27 Q50 5 100 27 T200 27 T300 27 T400 27'/%3E%3Cpath d='M0 20 Q50 -2 100 20 T200 20 T300 20 T400 20' opacity='.6'/%3E%3Cpath d='M0 33 Q50 14 100 33 T200 33 T300 33 T400 33' opacity='.4'/%3E%3C/g%3E%3C/svg%3E");
  background-repeat: repeat-x;
  background-size: 400px 34px;
  opacity:.55;
}

/* ==========================================================================
   Header
   ========================================================================== */
.site-header{
  position: sticky; top:0; z-index: 40;
  background: var(--stone); border-bottom: 1px solid var(--line);
}
.site-header .container{
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  height: 76px;
}
.site-logo{ font-family: var(--font-display); font-weight:700; font-size:1.4rem; color: var(--pine-dark); }
.site-logo span{ color: var(--ochre); }
.main-nav ul{ display:flex; gap: 28px; }
.main-nav a{ font-weight:500; font-size:.95rem; }
.main-nav a:hover{ color: var(--pine); }
.header-actions{ display:flex; align-items:center; gap:12px; }
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding: 11px 22px; border-radius: var(--radius-m); border:1px solid transparent;
  font-weight:600; font-size:.92rem; transition: transform .15s ease, background .15s ease;
}
.btn-primary{ background: var(--pine); color: var(--white); }
.btn-primary:hover{ background: var(--pine-dark); transform: translateY(-1px); }
.btn-accent{ background: var(--ochre); color: var(--white); }
.btn-accent:hover{ background: var(--ochre-dark); }
.btn-ghost{ border-color: var(--pine); color: var(--pine); background: transparent; }
.btn-ghost:hover{ background: rgba(47,75,60,.08); }
.btn-sm{ padding: 7px 14px; font-size:.82rem; }
.btn-block{ width:100%; }
.btn[disabled]{ opacity:.5; cursor:not-allowed; transform:none; }

/* ==========================================================================
   Hero / homepage search
   ========================================================================== */
.hero{
  position:relative; padding: 72px 0 40px; overflow:hidden;
  background: linear-gradient(180deg, var(--stone) 0%, var(--stone-dim) 100%);
}
.hero .eyebrow{
  font-family: var(--font-mono); text-transform:uppercase; letter-spacing:.12em;
  font-size:.75rem; color: var(--pine); margin-bottom: 14px; display:block;
}
.hero p.lead{ max-width: 560px; color: var(--ink-soft); font-size:1.1rem; }

.search-card{
  margin-top: 34px; background: var(--white); border-radius: var(--radius-l);
  box-shadow: var(--shadow-card); padding: 22px; display:grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr auto; gap:14px; align-items:end;
}
.search-field label{ display:block; font-size:.72rem; text-transform:uppercase; letter-spacing:.08em; color: var(--ink-soft); margin-bottom:6px; font-weight:600; }
.search-field select, .search-field input{
  width:100%; padding:11px 12px; border:1px solid var(--line); border-radius: var(--radius-s);
  font-family: var(--font-body); font-size:.95rem; background: var(--white); color: var(--ink);
}
@media (max-width: 900px){ .search-card{ grid-template-columns: 1fr 1fr; } }

/* ==========================================================================
   Filters + catalog (archive-listing / taxonomy)
   ========================================================================== */
.catalog-layout{ display:grid; grid-template-columns: 280px 1fr; gap: 36px; padding: 40px 0 80px; align-items:start; }
@media (max-width: 880px){ .catalog-layout{ grid-template-columns: 1fr; } }

.filters{
  background: var(--white); border-radius: var(--radius-m); padding: 22px;
  border: 1px solid var(--line); position: sticky; top: 96px;
}
.filters h3{ font-size:1rem; text-transform:uppercase; letter-spacing:.06em; font-family: var(--font-body); font-weight:700; color: var(--pine-dark); }
.filter-group{ padding: 16px 0; border-bottom: 1px solid var(--line); }
.filter-group:last-child{ border-bottom:none; }
.filter-group legend{ font-weight:600; font-size:.88rem; margin-bottom:8px; }
.filter-group label{ display:flex; gap:8px; align-items:center; font-size:.9rem; padding:4px 0; color: var(--ink-soft); }
.price-range{ display:flex; gap:10px; }
.price-range input{ width:100%; padding:8px 10px; border:1px solid var(--line); border-radius: var(--radius-s); }
.results-meta{ display:flex; justify-content:space-between; align-items:center; margin-bottom:18px; color: var(--ink-soft); font-size:.9rem; }
.results-meta select{ border:1px solid var(--line); border-radius: var(--radius-s); padding:8px 10px; }

.listing-grid{ display:grid; grid-template-columns: repeat(2, 1fr); gap: 22px; }
@media (max-width: 620px){ .listing-grid{ grid-template-columns: 1fr; } }
.listing-grid.grid-3{ grid-template-columns: repeat(3, 1fr); }
@media (max-width: 880px){ .listing-grid.grid-3{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px){ .listing-grid.grid-3{ grid-template-columns: 1fr; } }

.listing-card{
  background: var(--white); border-radius: var(--radius-m) var(--radius-m) 6px 6px;
  overflow:hidden; border:1px solid var(--line); box-shadow: var(--shadow-card);
  transition: transform .18s ease, box-shadow .18s ease;
}
.listing-card:hover{ transform: translateY(-3px); box-shadow: 0 14px 30px rgba(27,36,32,.12); }
.listing-card .thumb{ position:relative; aspect-ratio: 4/3; background: var(--sage); overflow:hidden; }
.listing-card .thumb img{ width:100%; height:100%; object-fit:cover; }
.listing-card .tag{
  position:absolute; top:12px; left:12px; background: var(--pine); color:var(--white);
  font-size:.72rem; font-weight:600; padding: 4px 10px; border-radius: 100px;
}
.listing-card .price-badge{
  position:absolute; bottom:12px; right:12px; background: var(--ochre); color: var(--white);
  font-family: var(--font-mono); font-weight:600; padding:5px 11px; border-radius: var(--radius-s); font-size:.85rem;
}
.listing-card .body{ padding: 16px 18px 18px; }
.listing-card .region{ font-size:.78rem; color: var(--ink-soft); text-transform:uppercase; letter-spacing:.04em; margin-bottom:4px; }
.listing-card h3{ margin-bottom:8px; }
.listing-card h3 a:hover{ color: var(--pine); }
.listing-card .amenities{ display:flex; flex-wrap:wrap; gap:6px; margin-top:10px; }
.listing-card .amenities span{ font-size:.72rem; background: var(--stone-dim); padding:3px 9px; border-radius:100px; color: var(--ink-soft); }
.empty-state{ padding: 60px 20px; text-align:center; color: var(--ink-soft); background: var(--white); border-radius: var(--radius-m); border:1px dashed var(--line); }

.pagination{ display:flex; gap:8px; justify-content:center; margin-top: 36px; }
.pagination a, .pagination span{ padding:9px 14px; border-radius: var(--radius-s); border:1px solid var(--line); font-size:.9rem; }
.pagination .current{ background: var(--pine); color: var(--white); border-color: var(--pine); }

/* ==========================================================================
   Single listing
   ========================================================================== */
.listing-hero-gallery{ display:grid; grid-template-columns: 2fr 1fr; gap: 8px; border-radius: var(--radius-l); overflow:hidden; height: 440px; }
.listing-hero-gallery .main-img{ height:100%; overflow:hidden; }
.listing-hero-gallery .side-imgs{ display:grid; grid-template-rows: 1fr 1fr; gap:8px; }
.listing-hero-gallery img{ width:100%; height:100%; object-fit:cover; }
@media (max-width: 760px){ .listing-hero-gallery{ grid-template-columns:1fr; height:auto; } .listing-hero-gallery .side-imgs{ display:none; } }

.listing-layout{ display:grid; grid-template-columns: 1fr 380px; gap: 44px; padding: 36px 0 80px; align-items:start; }
@media (max-width: 940px){ .listing-layout{ grid-template-columns:1fr; } }

.listing-meta-row{ display:flex; flex-wrap:wrap; gap: 22px; padding: 18px 0; margin-bottom: 8px; border-bottom:1px solid var(--line); color: var(--ink-soft); font-size:.92rem; }
.listing-meta-row b{ color: var(--ink); }
.listing-section{ padding: 26px 0; border-bottom:1px solid var(--line); }
.listing-section:last-child{ border-bottom:none; }
.amenity-grid{ display:grid; grid-template-columns: repeat(2,1fr); gap: 10px 20px; }
.amenity-grid li{ display:flex; align-items:center; gap:10px; font-size:.94rem; }
.amenity-grid li::before{ content:"✓"; color: var(--pine); font-weight:700; }

.faq-item{ border-bottom: 1px solid var(--line); padding: 14px 0; }
.faq-item summary{ cursor:pointer; font-weight:600; }

.host-card{ display:flex; gap:14px; align-items:center; padding: 16px 0; }
.host-card .avatar{ width:52px; height:52px; border-radius:50%; background: var(--sage); flex-shrink:0; }

/* Booking widget */
.booking-widget{
  background: var(--white); border:1px solid var(--line); border-radius: var(--radius-m);
  padding: 24px; position: sticky; top: 96px; box-shadow: var(--shadow-card);
}
.booking-widget .price-line{ display:flex; align-items:baseline; gap:6px; margin-bottom:18px; }
.booking-widget .price-line .amount{ font-family: var(--font-display); font-size:1.7rem; font-weight:700; color: var(--pine-dark); }
.booking-widget .price-line .unit{ color: var(--ink-soft); font-size:.9rem; }
.booking-form .row2{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.booking-form label{ display:block; font-size:.78rem; font-weight:600; margin: 12px 0 5px; text-transform:uppercase; letter-spacing:.04em; color: var(--ink-soft); }
.booking-form input, .booking-form textarea{
  width:100%; padding: 10px 12px; border:1px solid var(--line); border-radius: var(--radius-s);
  font-family: var(--font-body); font-size:.95rem;
}
.booking-form textarea{ min-height: 80px; resize: vertical; }
.booking-form .form-msg{ margin-top:12px; padding:10px 12px; border-radius: var(--radius-s); font-size:.88rem; display:none; }
.booking-form .form-msg.success{ display:block; background:#E6EFE8; color: var(--success); }
.booking-form .form-msg.error{ display:block; background:#F5E4E0; color: var(--danger); }
.booking-form .note{ font-size:.78rem; color: var(--ink-soft); margin-top:12px; }
.legend-dates{ display:flex; gap:14px; font-size:.78rem; color: var(--ink-soft); margin-top:10px; }
.legend-dates i{ display:inline-block; width:10px; height:10px; border-radius:2px; margin-right:5px; vertical-align:middle; }
.legend-dates .free i{ background: var(--sage); } .legend-dates .busy i{ background: var(--danger); }

/* ==========================================================================
   Dashboard (кабинет владельца)
   ========================================================================== */
.dashboard-shell{ display:grid; grid-template-columns: 240px 1fr; gap: 36px; padding: 40px 0 80px; }
@media (max-width: 820px){ .dashboard-shell{ grid-template-columns:1fr; } }
.dash-nav{ background: var(--white); border:1px solid var(--line); border-radius: var(--radius-m); padding: 10px; height:fit-content; }
.dash-nav a{ display:block; padding: 12px 14px; border-radius: var(--radius-s); font-weight:500; color: var(--ink-soft); }
.dash-nav a.is-active, .dash-nav a:hover{ background: var(--stone-dim); color: var(--pine-dark); }
.dash-panel{ background: var(--white); border:1px solid var(--line); border-radius: var(--radius-m); padding: 28px; }
.dash-header{ display:flex; justify-content:space-between; align-items:center; margin-bottom:22px; }
.status-pill{ font-size:.72rem; font-weight:700; padding:4px 10px; border-radius:100px; text-transform:uppercase; letter-spacing:.03em; }
.status-new{ background:#FBEFDD; color: var(--ochre-dark); }
.status-confirmed{ background:#E1EDE4; color: var(--success); }
.status-cancelled{ background:#F5E4E0; color: var(--danger); }
table.dash-table{ width:100%; border-collapse: collapse; }
table.dash-table th{ text-align:left; font-size:.75rem; text-transform:uppercase; letter-spacing:.05em; color: var(--ink-soft); padding: 10px 8px; border-bottom:2px solid var(--line); }
table.dash-table td{ padding: 14px 8px; border-bottom:1px solid var(--line); font-size:.92rem; }
.myrow-actions{ display:flex; gap:8px; }
.acf-form-wrap .acf-field{ margin-bottom:18px; }
.acf-form-wrap label{ font-weight:600; display:block; margin-bottom:6px; }

/* ==========================================================================
   Reviews
   ========================================================================== */
.review-item{ padding: 16px 0; border-bottom: 1px solid var(--line); }
.review-item:last-child{ border-bottom:none; }
.review-head{ display:flex; align-items:center; gap:10px; margin-bottom:6px; flex-wrap:wrap; }
.review-stars{ color: var(--ochre-dark); letter-spacing:1px; }
.review-date{ color: var(--ink-soft); font-size:.8rem; margin-left:auto; }
.review-form-toggle summary{ list-style:none; cursor:pointer; }
.review-form-toggle summary::-webkit-details-marker{ display:none; }
.star-picker{ display:flex; gap:4px; font-size:1.6rem; color: var(--line); margin-bottom:6px; }
.star-picker .star{ cursor:pointer; transition: color .1s ease; }
.star-picker .star.is-filled{ color: var(--ochre); }

/* ==========================================================================
   Blog
   ========================================================================== */
.article-card{ background: var(--white); border:1px solid var(--line); border-radius: var(--radius-m); overflow:hidden; box-shadow: var(--shadow-card); transition: transform .18s ease; }
.article-card:hover{ transform: translateY(-3px); }
.article-card .thumb{ aspect-ratio: 16/10; overflow:hidden; background: var(--sage); }
.article-card .thumb img{ width:100%; height:100%; object-fit:cover; }
.article-card .body{ padding:16px 18px 20px; }
.article-card .eyebrow-sm{ font-size:.72rem; text-transform:uppercase; letter-spacing:.06em; color: var(--pine); font-weight:700; margin-bottom:6px; display:block; }
.article-card h3{ margin-bottom:8px; font-size:1.1rem; }
.article-card .excerpt{ color: var(--ink-soft); font-size:.9rem; }
.article-body{ max-width: 760px; margin:0 auto; font-size:1.05rem; line-height:1.7; }
.article-body h2{ margin-top:1.6em; }
.article-body img{ border-radius: var(--radius-m); margin: 1.2em 0; }
.article-hero-meta{ color: var(--ink-soft); font-size:.9rem; margin-bottom: 24px; }

/* ==========================================================================
   Homepage extras
   ========================================================================== */
.steps-grid{ display:grid; grid-template-columns: repeat(3,1fr); gap:24px; }
@media (max-width: 760px){ .steps-grid{ grid-template-columns:1fr; } }
.step-card{ position:relative; padding: 28px 22px; background: var(--white); border-radius: var(--radius-m); border:1px solid var(--line); }
.step-card .step-num{ font-family: var(--font-mono); font-size:.8rem; color: var(--ochre-dark); font-weight:700; display:block; margin-bottom:10px; }
.category-tiles{ display:grid; grid-template-columns: repeat(4,1fr); gap:16px; }
@media (max-width: 820px){ .category-tiles{ grid-template-columns: repeat(2,1fr); } }
.category-tile{ position:relative; aspect-ratio: 4/3; border-radius: var(--radius-m); overflow:hidden; background: var(--pine); display:flex; align-items:flex-end; padding:16px; }
.category-tile::before{ content:""; position:absolute; inset:0; background: linear-gradient(180deg, rgba(27,36,32,0) 40%, rgba(27,36,32,.75) 100%); }
.category-tile img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.category-tile span{ position:relative; color: var(--white); font-weight:600; font-family: var(--font-display); font-size:1.15rem; }
.testimonial-card{ background: var(--white); border:1px solid var(--line); border-radius: var(--radius-m); padding:22px; }
.testimonial-card .review-stars{ display:block; margin-bottom:10px; }
.testimonial-card p{ color: var(--ink-soft); font-size:.94rem; }
.testimonial-card .who{ font-weight:600; color: var(--ink); font-size:.9rem; margin-top:10px; }
.section-head{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom:22px; flex-wrap:wrap; gap:12px; }

/* ==========================================================================
   Footer
   ========================================================================== */
.site-footer{ background: var(--pine-dark); color: var(--stone); padding: 54px 0 28px; margin-top: 60px; }
.site-footer a{ color: var(--stone); opacity:.85; }
.site-footer a:hover{ opacity:1; }
.footer-grid{ display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 30px; padding-bottom: 30px; border-bottom: 1px solid rgba(255,255,255,.14); }
@media (max-width: 720px){ .footer-grid{ grid-template-columns: 1fr 1fr; } }
.footer-grid h4{ color: var(--white); font-family: var(--font-body); font-size:.85rem; text-transform:uppercase; letter-spacing:.06em; margin-bottom:14px; }
.footer-grid li{ padding: 5px 0; font-size:.9rem; }
.footer-bottom{ padding-top: 22px; display:flex; justify-content:space-between; font-size:.8rem; opacity:.7; flex-wrap:wrap; gap:10px; }

/* Utility */
.badge{ display:inline-block; font-size:.72rem; font-weight:700; padding:4px 10px; border-radius:100px; background: var(--stone-dim); color: var(--ink-soft); }
.skeleton{ background: linear-gradient(90deg, var(--stone-dim) 25%, var(--line) 37%, var(--stone-dim) 63%); background-size: 400% 100%; animation: shimmer 1.4s infinite; border-radius: var(--radius-s); }
@keyframes shimmer{ 0%{background-position:100% 50%;} 100%{background-position:0 50%;} }
.is-loading{ opacity:.5; pointer-events:none; }
