/* ============================================================
   Зона отдыха «Фурор» — прототип структуры сайта
   Дизайн-система (лесная палитра Борового)
   ============================================================ */

:root{
  --forest:#2f5d3a;
  --forest-dark:#1f3d27;
  --forest-light:#3f7a4d;
  --sand:#f6f1e8;
  --sand-2:#ece2d1;
  --gold:#c8a35b;
  --gold-dark:#a9863f;
  --ink:#222820;
  --muted:#6b7568;
  --line:#e3dccf;
  --white:#ffffff;
  --radius:16px;
  --radius-sm:10px;
  --shadow:0 10px 30px rgba(31,61,39,.10);
  --shadow-sm:0 4px 14px rgba(31,61,39,.08);
  --maxw:1180px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Manrope',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  color:var(--ink);
  background:var(--sand);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;line-height:1.2;font-weight:700;color:var(--forest-dark)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}

/* -------- Прототип-лента -------- */
.proto-ribbon{
  background:var(--forest-dark);color:#dfe9df;text-align:center;
  font-size:13px;letter-spacing:.3px;padding:7px 14px;
}
.proto-ribbon b{color:var(--gold)}

/* -------- Шапка -------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.92);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.header-inner{display:flex;align-items:center;gap:18px;padding:12px 22px;max-width:var(--maxw);margin:0 auto}
.logo{display:flex;align-items:center;gap:10px;font-family:'Playfair Display',serif;font-weight:700;font-size:22px;color:var(--forest-dark)}
.logo .mark{
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,var(--forest),var(--forest-light));
  display:grid;place-items:center;color:#fff;font-size:18px;
}
.nav{display:flex;align-items:center;gap:4px;margin-left:auto;flex-wrap:wrap}
.nav a{
  padding:8px 11px;border-radius:8px;font-size:14.5px;font-weight:600;color:#3a4435;
  transition:.15s;
}
.nav a:hover{background:var(--sand-2)}
.nav a.active{color:var(--forest);background:var(--sand-2)}
.header-tools{display:flex;align-items:center;gap:10px}
.lang{display:flex;border:1px solid var(--line);border-radius:8px;overflow:hidden}
.lang button{border:0;background:#fff;padding:6px 9px;font-size:13px;font-weight:700;color:var(--muted);cursor:pointer}
.lang button.on{background:var(--forest);color:#fff}
.btn{
  display:inline-flex;align-items:center;gap:8px;justify-content:center;
  border:0;cursor:pointer;font-weight:700;font-size:15px;
  padding:12px 20px;border-radius:12px;transition:.18s;font-family:inherit;
}
.btn-primary{background:var(--gold);color:#2a2310;box-shadow:0 6px 16px rgba(200,163,91,.35)}
.btn-primary:hover{background:var(--gold-dark);transform:translateY(-1px)}
.btn-ghost{background:rgba(255,255,255,.15);color:#fff;border:1.5px solid rgba(255,255,255,.6)}
.btn-ghost:hover{background:rgba(255,255,255,.25)}
.btn-outline{background:#fff;color:var(--forest);border:1.5px solid var(--forest)}
.btn-outline:hover{background:var(--forest);color:#fff}
.btn-sm{padding:9px 14px;font-size:13.5px;border-radius:10px}
.burger{display:none;background:none;border:0;cursor:pointer;font-size:26px;color:var(--forest-dark);margin-left:auto}

/* -------- Хлебные крошки / заголовок страницы -------- */
.page-head{
  background:linear-gradient(120deg,var(--forest-dark),var(--forest));
  color:#fff;padding:46px 0 40px;position:relative;overflow:hidden;
}
.page-head::after{content:"🌲";position:absolute;right:-10px;bottom:-26px;font-size:160px;opacity:.10}
.page-head .crumbs{font-size:13px;opacity:.8;margin-bottom:8px}
.page-head h1{color:#fff;font-size:clamp(28px,4vw,42px)}
.page-head p{max-width:640px;margin-top:10px;opacity:.92}

/* -------- Hero (главная) -------- */
.hero{
  position:relative;min-height:78vh;display:flex;align-items:center;
  background:
    linear-gradient(180deg,rgba(20,40,25,.55),rgba(20,40,25,.65)),
    linear-gradient(135deg,#2f5d3a,#16301f 60%,#0e2415);
  color:#fff;text-align:center;overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;opacity:.18;
  background-image:radial-gradient(circle at 20% 30%,#fff 0 1px,transparent 1px),radial-gradient(circle at 70% 60%,#fff 0 1px,transparent 1px);
  background-size:90px 90px,120px 120px;
}
.hero-inner{position:relative;max-width:820px;margin:0 auto;padding:60px 22px}
.hero .eyebrow{letter-spacing:3px;text-transform:uppercase;font-size:13px;color:var(--gold);font-weight:700;margin-bottom:14px}
.hero h1{color:#fff;font-size:clamp(32px,6vw,60px);margin-bottom:18px}
.hero p{font-size:clamp(16px,2.4vw,20px);opacity:.92;max-width:600px;margin:0 auto 28px}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.scroll-hint{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);color:#fff;opacity:.7;font-size:13px}

/* -------- Виджет брони -------- */
.booking-bar{
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);
  margin:-46px auto 0;max-width:980px;position:relative;z-index:5;
  display:grid;grid-template-columns:repeat(3,1fr) auto;gap:14px;padding:18px;align-items:end;
}
.booking-bar .fld{display:flex;flex-direction:column;gap:6px}
.booking-bar label{font-size:12.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
.booking-bar .box{border:1px solid var(--line);border-radius:10px;padding:12px 12px;color:#3a4435;background:var(--sand);font-weight:600}
.booking-note{text-align:center;color:var(--muted);font-size:13px;margin-top:12px}

/* -------- Секции -------- */
section{padding:64px 0}
.section-head{text-align:center;max-width:680px;margin:0 auto 38px}
.section-head .eyebrow{letter-spacing:2px;text-transform:uppercase;font-size:12.5px;color:var(--gold-dark);font-weight:800;margin-bottom:10px}
.section-head h2{font-size:clamp(26px,3.4vw,38px)}
.section-head p{color:var(--muted);margin-top:10px}
.alt{background:var(--white)}
.alt-2{background:var(--sand-2)}

/* -------- Сетки и карточки -------- */
.grid{display:grid;gap:22px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}

.card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:.2s;border:1px solid var(--line)}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card .body{padding:18px}
.card h3{font-size:21px;margin-bottom:6px}
.card .price{color:var(--forest);font-weight:800;font-family:'Manrope',sans-serif;font-size:18px}
.card .meta{color:var(--muted);font-size:14px;margin:6px 0 12px;display:flex;gap:14px;flex-wrap:wrap}
.card .meta span{display:inline-flex;align-items:center;gap:5px}

/* -------- Фото-заглушки (прототип) -------- */
.ph{
  position:relative;display:grid;place-items:center;color:#fff;text-align:center;
  background:linear-gradient(135deg,var(--forest-light),var(--forest-dark));
  font-weight:700;letter-spacing:.3px;
}
.ph.tall{aspect-ratio:4/5}
.ph.wide{aspect-ratio:16/9}
.ph.sq{aspect-ratio:1/1}
.ph .ph-ic{font-size:34px;margin-bottom:4px}
.ph .ph-tag{
  position:absolute;top:10px;left:10px;background:rgba(0,0,0,.35);
  font-size:11px;font-weight:700;padding:4px 8px;border-radius:6px;letter-spacing:.3px;
}
.ph.v2{background:linear-gradient(135deg,#5e7d52,#2f4a2a)}
.ph.v3{background:linear-gradient(135deg,#6f8a9a,#33485a)}
.ph.v4{background:linear-gradient(135deg,#b08d57,#6e5325)}

/* -------- Иконочные плитки -------- */
.feature{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;text-align:center}
.feature .ic{font-size:34px;margin-bottom:10px}
.feature h3{font-size:18px;margin-bottom:6px}
.feature p{font-size:14px;color:var(--muted)}

/* -------- Блок-аннотация «что здесь будет» -------- */
.note{
  border-left:3px solid var(--gold);background:#fff;border-radius:0 10px 10px 0;
  padding:12px 16px;color:#55604f;font-size:14px;box-shadow:var(--shadow-sm);
}
.note b{color:var(--forest-dark)}
.note-grid{display:grid;gap:12px}

/* -------- Сплит (текст + фото) -------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.split.rev .split-media{order:-1}
.split h2{margin-bottom:14px}
.split p{color:#4a5444;margin-bottom:12px}
.tick{list-style:none;display:grid;gap:9px}
.tick li{padding-left:28px;position:relative;color:#3f4a3a}
.tick li::before{content:"✓";position:absolute;left:0;color:var(--forest);font-weight:800;background:var(--sand-2);width:20px;height:20px;border-radius:50%;display:grid;place-items:center;font-size:12px;top:2px}

/* -------- Цены / таблица -------- */
.ptable{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.ptable th,.ptable td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--line)}
.ptable th{background:var(--forest);color:#fff;font-size:14px;font-weight:700}
.ptable td{font-size:15px}
.ptable tr:last-child td{border-bottom:0}
.ptable .price{color:var(--forest);font-weight:800}

/* -------- Отзывы -------- */
.review{background:#fff;border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.review .stars{color:var(--gold);margin-bottom:8px}
.review p{font-size:15px;color:#44503f}
.review .who{margin-top:12px;font-weight:700;color:var(--forest-dark);font-size:14px}

/* -------- Полоса доверия -------- */
.trust{display:flex;flex-wrap:wrap;gap:14px 30px;justify-content:center;align-items:center;color:var(--muted);font-size:14px;font-weight:600}
.trust .pay{background:#fff;border:1px solid var(--line);border-radius:8px;padding:8px 14px}

/* -------- CTA-блок -------- */
.cta-band{background:linear-gradient(120deg,var(--forest),var(--forest-dark));color:#fff;text-align:center;border-radius:var(--radius);padding:48px 24px}
.cta-band h2{color:#fff;margin-bottom:12px}
.cta-band p{opacity:.9;max-width:520px;margin:0 auto 22px}

/* -------- Меню кафе -------- */
.menu-cat{background:#fff;border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.menu-cat h3{font-size:20px;margin-bottom:14px;padding-bottom:10px;border-bottom:2px solid var(--sand-2)}
.menu-row{display:flex;justify-content:space-between;gap:14px;padding:8px 0;border-bottom:1px dashed var(--line)}
.menu-row:last-child{border-bottom:0}
.menu-row .nm{font-weight:600}
.menu-row .pr{color:var(--forest);font-weight:800;white-space:nowrap}

/* -------- Карта-заглушка -------- */
.map-ph{aspect-ratio:21/9;border-radius:var(--radius);background:
  linear-gradient(135deg,#cfe0cf,#aac6b0);display:grid;place-items:center;color:var(--forest-dark);font-weight:700;border:1px solid var(--line)}

/* -------- Подвал -------- */
.site-footer{background:var(--forest-dark);color:#cfdace;padding:50px 0 26px;margin-top:10px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:30px}
.site-footer h4{color:#fff;font-family:'Manrope',sans-serif;font-size:15px;text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px}
.site-footer a{color:#bcc9bc;font-size:14.5px;display:block;padding:4px 0}
.site-footer a:hover{color:var(--gold)}
.site-footer .about p{color:#aab8aa;font-size:14px}
.foot-pay{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.foot-pay span{background:rgba(255,255,255,.1);border-radius:6px;padding:5px 10px;font-size:12px;color:#dfe9df}
.foot-bottom{border-top:1px solid rgba(255,255,255,.15);margin-top:30px;padding-top:18px;text-align:center;color:#9fb09f;font-size:13px}

/* -------- Плавающая кнопка -------- */
.fab{
  position:fixed;right:18px;bottom:18px;z-index:60;display:flex;gap:10px;
}
.fab a{
  display:inline-flex;align-items:center;gap:8px;padding:13px 18px;border-radius:30px;
  font-weight:700;font-size:15px;box-shadow:0 8px 22px rgba(0,0,0,.22);
}
.fab .book{background:var(--gold);color:#2a2310}
.fab .wa{background:#25d366;color:#fff}
.fab-mobile{display:none}

/* -------- Утилиты -------- */
.center{text-align:center}
.mt-l{margin-top:34px}
.tag{display:inline-block;background:var(--sand-2);color:var(--forest-dark);font-size:12.5px;font-weight:700;padding:4px 11px;border-radius:20px;margin-bottom:14px}
.lead{font-size:18px;color:#4a5444}

/* ============================================================
   Адаптив
   ============================================================ */
@media(max-width:980px){
  .nav{
    position:fixed;top:0;right:0;height:100vh;width:min(82vw,330px);
    background:#fff;flex-direction:column;align-items:flex-start;gap:2px;
    padding:80px 22px 22px;box-shadow:-10px 0 40px rgba(0,0,0,.15);
    transform:translateX(100%);transition:.25s;z-index:55;overflow-y:auto;
  }
  .nav.open{transform:translateX(0)}
  .nav a{width:100%;padding:12px 12px;font-size:16px}
  .burger{display:block}
  .header-tools .btn{display:none}
  .booking-bar{grid-template-columns:1fr 1fr;}
  .cols-4{grid-template-columns:repeat(2,1fr)}
  .cols-3{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr}
  .split.rev .split-media{order:0}
  .footer-grid{grid-template-columns:1fr 1fr}
  .fab .book span,.fab .wa span{display:none}
  .nav-overlay.show{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:54}
}
@media(max-width:560px){
  .booking-bar{grid-template-columns:1fr;margin-top:-30px}
  .cols-2,.cols-3,.cols-4{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  section{padding:46px 0}
  .hero{min-height:80vh}
}
