/* HOTEL — bespoke layout: премиум-гостиничный, sage + ivory, room categories, booking date-picker */
body[data-niche="hotel"] {
  --sage:#3F6B57; --sage-deep:#274839; --sage-soft:#DDE8DF;
  --ivory:#FAF8F1; --paper:#FFFFFF; --oat:#F1ECDF;
  --char:#1F2A23; --char-2:#3A4540; --slate:#56625A;
  --hairline:#E1DDCD; --gold:#B89766;
  --surface-page:var(--ivory); --surface-card:var(--paper); --surface-soft:var(--oat);
  --text-primary:var(--char); --text-secondary:var(--slate); --border-soft:var(--hairline);
  --accent:var(--sage); --accent-dark:var(--sage-deep);
  background:var(--ivory); color:var(--char); font-family:var(--font-sans);
}
body[data-niche="hotel"] h1, body[data-niche="hotel"] h2, body[data-niche="hotel"] h3 {
  font-family:'Cormorant Garamond',Georgia,serif; font-weight:400; font-style:italic;
  letter-spacing:-0.01em; color:var(--char); line-height:1.08;
}
.h-topbar { position:absolute; top:0; left:0; right:0; z-index:30; padding:22px 0; transition:background .3s, padding .3s; }
.h-topbar.scrolled { position:fixed; padding:14px 0; background:rgba(250,248,241,.94); backdrop-filter:saturate(160%) blur(14px); border-bottom:1px solid var(--hairline); }
.h-topbar-inner { display:flex; align-items:center; justify-content:space-between; gap:24px; }
.h-brand { color:#fff; transition:color .3s; }
.h-topbar.scrolled .h-brand { color:var(--char); }
.h-brand b { font-family:'Cormorant Garamond',serif; font-style:italic; font-size:26px; font-weight:500; }
.h-brand small { display:block; font-size:10px; letter-spacing:.3em; text-transform:uppercase; opacity:.7; margin-top:2px; font-family:var(--font-sans); }
.h-nav { display:flex; gap:32px; }
.h-nav a { color:rgba(255,255,255,.86); font-size:13px; letter-spacing:.06em; text-transform:uppercase; font-weight:500; }
.h-topbar.scrolled .h-nav a { color:var(--char-2); }
.h-nav a:hover { color:var(--gold); }
.h-cta { display:inline-flex; padding:11px 22px; background:var(--sage); color:#fff; font-size:12px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; }
.h-cta:hover { background:var(--sage-deep); }
.h-cta.outline { background:transparent; color:#fff; border:1px solid rgba(255,255,255,.6); }
.h-topbar.scrolled .h-cta.outline { color:var(--char); border-color:var(--char); }
@media (max-width:760px) { .h-nav { display:none; } }

.h-hero { position:relative; min-height:100vh; color:#fff; display:flex; align-items:end; padding-bottom:80px; overflow:hidden; }
.h-hero-photo { position:absolute; inset:0; background-size:cover; background-position:center; transform:scale(1.05); animation:h-zoom 16s ease-out forwards; background-color:#1F2A23; }
@keyframes h-zoom { to { transform:scale(1); } }
.h-hero-veil { position:absolute; inset:0; background:linear-gradient(to top, rgba(0,0,0,.88) 0%, rgba(0,0,0,.65) 35%, rgba(0,0,0,.2) 60%, rgba(0,0,0,.05) 100%); }
.h-hero-content { position:relative; z-index:2; max-width:980px; }
.h-hero-content .eyebrow { font-size:11px; letter-spacing:.3em; text-transform:uppercase; font-weight:700; color:var(--gold); margin-bottom:24px; display:inline-block; }
.h-hero h1 { color:#fff !important; text-shadow: 0 2px 12px rgba(0,0,0,.9), 0 0 40px rgba(0,0,0,.7); font-size:clamp(48px, 8vw, 130px); line-height:1.0; font-weight:400; font-style:italic; margin:0 0 22px; max-width:14ch; }
.h-hero p { color:rgba(255,255,255,.86); font-size:clamp(16px, 1.4vw, 19px); line-height:1.55; max-width:54ch; margin:0 0 36px; }
.h-hero-row { display:flex; gap:14px; flex-wrap:wrap; }

/* BOOKING bar */
.h-book-bar { background:var(--paper); border-top:6px solid var(--sage); padding:24px 0; box-shadow:0 -16px 32px -16px rgba(0,0,0,.18); }
.h-book-grid { display:grid; grid-template-columns:repeat(4,1fr) auto; gap:12px; align-items:end; }
.h-book-field { padding:6px 14px; border-right:1px solid var(--hairline); }
.h-book-field:last-of-type { border-right:0; }
.h-book-field label { display:block; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--slate); font-weight:700; margin-bottom:4px; }
.h-book-field input, .h-book-field select { width:100%; border:0; background:transparent; font:inherit; font-size:15px; padding:0; color:var(--char); outline:none; }
.h-book-go { background:var(--sage); color:#fff; border:0; padding:0 32px; height:50px; font:inherit; font-size:12px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; cursor:pointer; }
.h-book-go:hover { background:var(--sage-deep); }
@media (max-width:900px) { .h-book-grid { grid-template-columns:1fr 1fr; } .h-book-field { border-right:0; border-bottom:1px solid var(--hairline); padding:14px; } .h-book-go { grid-column:1 / -1; height:54px; } }

/* SECTIONS */
.h-sec { padding:clamp(72px, 9vw, 120px) 0; }
.h-eye { color:var(--sage); font-size:11px; letter-spacing:.26em; text-transform:uppercase; font-weight:700; margin-bottom:14px; display:inline-flex; align-items:center; gap:14px; }
.h-eye::before { content:''; width:32px; height:1px; background:var(--gold); }
.h-h2 { font-size:clamp(36px, 5vw, 64px); line-height:1.05; margin:0 0 14px; letter-spacing:-0.012em; }
.h-h2 i { color:var(--sage); }
.h-lead { color:var(--slate); font-size:clamp(15px, 1.2vw, 17px); line-height:1.65; max-width:60ch; }

/* ROOMS */
.h-rooms { display:grid; grid-template-columns:1fr 1fr; gap:32px; margin-top:40px; }
.h-room { background:var(--paper); border:1px solid var(--hairline); display:flex; flex-direction:column; transition:transform .3s, box-shadow .3s; }
.h-room:hover { transform:translateY(-4px); box-shadow:0 28px 56px -20px rgba(31,42,35,.18); }
.h-room-photo { aspect-ratio:16/10; background-size:cover; background-position:center; background-color:var(--oat); position:relative; }
.h-room-photo .tag { position:absolute; top:18px; left:18px; background:var(--paper); padding:4px 12px; font-size:10px; letter-spacing:.18em; text-transform:uppercase; font-weight:700; color:var(--sage-deep); }
.h-room-body { padding:28px 32px 32px; flex:1; display:flex; flex-direction:column; gap:14px; }
.h-room-body h3 { font-size:30px; margin:0; line-height:1.15; }
.h-room-meta { display:flex; gap:18px; flex-wrap:wrap; color:var(--slate); font-size:13px; }
.h-room-meta b { color:var(--char); font-weight:600; }
.h-room-feats { display:grid; grid-template-columns:1fr 1fr; gap:8px; padding-top:14px; border-top:1px solid var(--hairline); }
.h-room-feats span { color:var(--char-2); font-size:13px; display:flex; gap:8px; align-items:center; }
.h-room-feats span::before { content:'·'; color:var(--sage); font-weight:700; }
.h-room-foot { display:flex; align-items:baseline; justify-content:space-between; padding-top:18px; border-top:1px solid var(--hairline); margin-top:auto; }
.h-room-price { font-family:'Cormorant Garamond',serif; font-size:32px; line-height:1; font-style:italic; color:var(--char); }
.h-room-price small { font-style:normal; color:var(--slate); font-size:13px; margin-left:8px; font-family:var(--font-sans); }
.h-room-cta { color:var(--sage-deep); border-bottom:1px solid var(--sage-deep); padding-bottom:2px; font-weight:600; font-size:13px; letter-spacing:.04em; transition:padding .25s; }
.h-room-cta:hover { padding-right:8px; }
@media (max-width:900px) { .h-rooms { grid-template-columns:1fr; } }

/* AMENITIES */
.h-amen { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; margin-top:36px; }
.h-amen-tile { padding:28px 24px; background:var(--paper); border:1px solid var(--hairline); display:flex; flex-direction:column; gap:10px; transition:border-color .25s, transform .25s; }
.h-amen-tile:hover { border-color:var(--sage); transform:translateY(-3px); }
.h-amen-tile .ic { font-size:32px; line-height:1; margin-bottom:6px; }
.h-amen-tile h4 { font-family:'Cormorant Garamond',serif; font-style:italic; font-size:22px; margin:0; font-weight:500; line-height:1.15; }
.h-amen-tile p { font-size:13px; color:var(--slate); line-height:1.55; margin:0; }
@media (max-width:1000px) { .h-amen { grid-template-columns:1fr 1fr; } }

/* GALLERY mosaic */
.h-gal { display:grid; grid-template-columns:1.4fr 1fr 1fr; grid-auto-rows:clamp(220px, 28vw, 320px); gap:8px; margin-top:36px; }
.h-gal > div { position:relative; overflow:hidden; background-size:cover; background-position:center; background-color:var(--oat); }
.h-gal > div:hover { transform:scale(1.02); transition:transform .4s; }
.h-gal > div:nth-child(1) { grid-row:1/span 2; }
.h-gal > div:nth-child(4) { grid-column:2/span 2; }
.h-gal > div::after { content:attr(data-cap); position:absolute; left:18px; bottom:18px; background:rgba(0,0,0,.55); color:#fff; padding:4px 10px; font-size:11px; letter-spacing:.14em; text-transform:uppercase; }
@media (max-width:800px) { .h-gal { grid-template-columns:1fr 1fr; } .h-gal > div:nth-child(1) { grid-column:1/span 2; grid-row:auto; } .h-gal > div:nth-child(4) { grid-column:1/span 2; } }

/* CONCIERGE */
.h-conc { background:linear-gradient(135deg, var(--sage-deep), var(--sage)); color:var(--ivory); padding:clamp(56px, 7vw, 96px) 0; }
.h-conc h2 { color:var(--ivory); }
.h-conc-grid { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; }
.h-conc-grid p { color:rgba(250,248,241,.82); font-size:16px; line-height:1.65; }
.h-conc-list { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.h-conc-list div { padding:18px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); }
.h-conc-list div b { color:var(--gold); font-size:11px; letter-spacing:.16em; text-transform:uppercase; font-weight:700; display:block; margin-bottom:6px; }
.h-conc-list div span { font-family:'Cormorant Garamond',serif; font-style:italic; font-size:18px; }
@media (max-width:800px) { .h-conc-grid { grid-template-columns:1fr; } }

/* FAQ */
.h-faq { max-width:760px; margin:36px auto 0; }
.h-faq details { border-bottom:1px solid var(--hairline); padding:22px 0; }
.h-faq summary { list-style:none; cursor:pointer; display:flex; justify-content:space-between; gap:18px; font-family:'Cormorant Garamond',serif; font-style:italic; font-size:22px; font-weight:500; }
.h-faq summary::-webkit-details-marker { display:none; }
.h-faq summary::after { content:'+'; color:var(--sage); font-size:26px; font-style:italic; transition:transform .25s; }
.h-faq details[open] summary::after { transform:rotate(45deg); }
.h-faq details > div { padding-top:12px; color:var(--char-2); line-height:1.7; font-size:15px; }

/* FOOTER */
.h-foot { background:var(--char); color:var(--ivory); padding:64px 0 28px; }
.h-foot-top { display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:32px; margin-bottom:36px; }
.h-foot-brand b { font-family:'Cormorant Garamond',serif; font-style:italic; font-size:30px; color:#fff; display:block; }
.h-foot-brand p { color:rgba(250,248,241,.6); margin:12px 0 0; max-width:36ch; line-height:1.6; }
.h-foot h5 { color:var(--gold); font-size:11px; letter-spacing:.26em; text-transform:uppercase; margin:0 0 14px; font-weight:700; }
.h-foot a { color:rgba(250,248,241,.78); display:block; padding:4px 0; font-size:13px; }
.h-foot a:hover { color:var(--gold); }
.h-foot-bot { padding-top:20px; border-top:1px solid rgba(255,255,255,.1); display:flex; justify-content:space-between; flex-wrap:wrap; color:rgba(250,248,241,.4); gap:14px; font-size:12px; }
@media (max-width:800px) { .h-foot-top { grid-template-columns:1fr; } }

body[data-niche="hotel"] .reveal { opacity:0; transform:translateY(14px); transition:opacity 700ms var(--ease-smooth), transform 700ms var(--ease-smooth); }
body[data-niche="hotel"] .reveal.in { opacity:1; transform:none; }
