/*============================================================================
   11-room-detail.css — detail apartmánu (single tr_room)
   Zdroj: _Design/pronajem-detail.html. Vše scoped pod .nj-room-detail.
   Funkční části (kalendář/ceník/mapa/rezervace) = plugin Toret Rooms.
============================================================================*/
.nj-room-detail { background: var(--sand-1); }

/* breadcrumb */
.nj-room-detail .crumb-bar { background: var(--sand-1); padding: 12px 0; border-bottom: 1px solid var(--line); }
.nj-room-detail .crumb { font-size: .82rem; color: var(--muted); display: flex; gap: .4rem; align-items: center; flex-wrap: wrap; }
.nj-room-detail .crumb a { color: var(--muted); }
.nj-room-detail .crumb a:hover { color: var(--accent-deep); }
.nj-room-detail .crumb .sep { opacity: .6; }
.nj-room-detail .crumb .current { color: var(--navy); font-weight: 500; }

/* gallery hero */
.nj-room-detail .gallery-hero { padding: 24px 0; }
.nj-room-detail .gh-grid {
	display: grid;
	grid-template-columns: 2fr 1fr 1fr;
	grid-template-rows: 1fr 1fr;
	gap: 10px;
	height: 520px;
}
.nj-room-detail .gh-grid > a {
	background-size: cover;
	background-position: center;
	background-color: var(--sand-3);
	border-radius: var(--r-card);
	position: relative;
	overflow: hidden;
	display: block;
	transition: filter .2s;
}
.nj-room-detail .gh-grid > a:hover { filter: brightness(1.04); }
.nj-room-detail .gh-grid > a:nth-child(1) { grid-row: 1/3; grid-column: 1; }
.nj-room-detail .gh-grid > a.video-spot { grid-row: 1/3; grid-column: 2; }
.nj-room-detail .gh-grid > a:nth-child(3) { grid-column: 3; grid-row: 1; }
.nj-room-detail .gh-grid > a:nth-child(4) { grid-column: 3; grid-row: 2; }
/* bez videa: main vlevo + 2×2 fotky (prostřední sloupec jako pravý) */
.nj-room-detail .gh-grid--novideo > a:nth-child(2) { grid-column: 2; grid-row: 1; }
.nj-room-detail .gh-grid--novideo > a:nth-child(3) { grid-column: 2; grid-row: 2; }
.nj-room-detail .gh-grid--novideo > a:nth-child(4) { grid-column: 3; grid-row: 1; }
.nj-room-detail .gh-grid--novideo > a:nth-child(5) { grid-column: 3; grid-row: 2; }

.nj-room-detail .video-spot::before { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(20,57,88,.1), rgba(20,57,88,.55)); z-index: 1; }
.nj-room-detail .play-overlay { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; color: #fff; gap: 1rem; z-index: 2; }
.nj-room-detail .play-circle { width: 72px; height: 72px; border-radius: 50%; background: #fff; color: var(--accent-deep); display: grid; place-items: center; box-shadow: 0 10px 26px rgba(0,0,0,.35); transition: transform .2s; }
.nj-room-detail .video-spot:hover .play-circle { transform: scale(1.08); }
.nj-room-detail .play-label { font-weight: 600; font-size: .9rem; background: rgba(0,0,0,.45); padding: .5rem 1.1rem; border-radius: var(--r-pill); }
.nj-room-detail .video-spot-tag { position: absolute; top: 14px; left: 14px; background: var(--coral, #e54c2a); color: #fff; font-size: .7rem; font-weight: 700; letter-spacing: .1em; padding: .3rem .7rem; border-radius: var(--r-pill); z-index: 3; text-transform: uppercase; }
.nj-room-detail .show-all { position: absolute; right: 18px; bottom: 18px; background: #fff; color: var(--navy); padding: .6rem 1.1rem; border-radius: var(--r-btn); font-size: .88rem; font-weight: 600; display: inline-flex; align-items: center; gap: .5rem; box-shadow: var(--shadow); }
.nj-room-detail .show-all:hover { background: var(--navy); color: #fff; }

/* title */
.nj-room-detail .title-block { padding: 32px 0 16px; }
.nj-room-detail .title-block h1 { margin: 0 0 .5rem; }
.nj-room-detail .title-tags { display: flex; gap: .4rem; flex-wrap: wrap; margin-top: .6rem; }
.nj-room-detail .title-tag { padding: .3rem .75rem; border-radius: var(--r-pill); font-size: .78rem; font-weight: 600; background: #fff; border: 1px solid var(--line); color: var(--navy); }
.nj-room-detail .title-tag.top { background: var(--accent); color: #fff; border-color: var(--accent); }

/* main 2-col */
.nj-room-detail .main-wrap { padding: 30px 0 70px; }
.nj-room-detail .main-grid { display: grid; grid-template-columns: 1fr 380px; gap: 50px; align-items: start; }
.nj-room-detail .content-block { background: #fff; border-radius: var(--r-card); padding: 32px; margin-bottom: 24px; border: 1px solid var(--line); }
.nj-room-detail .content-block:last-child { margin-bottom: 0; }
.nj-room-detail .content-block h2 { margin-top: 0; }

/* facts */
.nj-room-detail .facts-row { display: grid; grid-template-columns: repeat(5, 1fr); gap: 1rem; padding: 24px; background: #fff; border-radius: var(--r-card); border: 1px solid var(--line); margin-bottom: 24px; }
.nj-room-detail .fact { display: flex; flex-direction: column; align-items: center; text-align: center; gap: .3rem; }
.nj-room-detail .fact strong { font-family: var(--font-serif); font-size: 1.25rem; color: var(--navy); font-weight: 600; line-height: 1.1; }
.nj-room-detail .fact small { font-size: .72rem; color: var(--muted); letter-spacing: .08em; text-transform: uppercase; }

/* description */
.nj-room-detail .desc p { color: var(--ink); margin: 0 0 1rem; font-size: 1.02rem; }
.nj-room-detail .desc p:last-child { margin-bottom: 0; }

/* dispozice */
.nj-room-detail .dispoz { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr 1fr; gap: .4rem 2rem; }
.nj-room-detail .dispoz li { padding: .5rem 0; border-bottom: 1px dashed var(--line); display: flex; justify-content: space-between; gap: 1rem; font-size: .95rem; }
.nj-room-detail .dispoz li strong { color: var(--navy); font-weight: 500; }
.nj-room-detail .dispoz li span { color: var(--muted); text-align: right; }

/* amenities */
.nj-room-detail .amen-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: .6rem 1.5rem; }
.nj-room-detail .amen { display: flex; gap: .6rem; align-items: center; padding: .45rem 0; border-bottom: 1px dashed var(--line); font-size: .92rem; }
.nj-room-detail .amen .ico { width: 30px; height: 30px; flex-shrink: 0; display: grid; place-items: center; color: var(--accent-deep); background: var(--sand-2); border-radius: var(--r-btn); font-weight: 700; }
.nj-room-detail .amen .lbl { flex: 1; color: var(--navy); }
.nj-room-detail .amen.no { opacity: .45; }
.nj-room-detail .amen.no .ico { color: var(--muted); background: var(--sand-1); }

/* plugin kalendář / ceník — lehké zarovnání do bloku (markup pluginu nemíchám) */
.nj-room-detail .nj-cal-block .toret-rooms,
.nj-room-detail .nj-pricelist-block .toret-rooms { margin: 0; }

/* lokalita */
.nj-room-detail .loc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: start; }
.nj-room-detail .loc-map { aspect-ratio: 4/3; background: linear-gradient(135deg, #a8c8d4, #7fa9b8); border-radius: var(--r-card); border: 1px solid var(--line); overflow: hidden; display: grid; place-items: center; }
.nj-room-detail .loc-map > * { width: 100%; height: 100%; }
.nj-room-detail .loc-info h3 { margin-bottom: .6rem; }
.nj-room-detail .loc-info .addr { color: var(--muted); font-size: .95rem; margin-bottom: 1.2rem; line-height: 1.5; }
.nj-room-detail .loc-distances { list-style: none; padding: 0; margin: 0; }
.nj-room-detail .loc-distances li { display: flex; justify-content: space-between; padding: .55rem 0; border-bottom: 1px dashed var(--line); font-size: .92rem; }
.nj-room-detail .loc-distances li strong { color: var(--navy); font-weight: 500; }
.nj-room-detail .loc-distances li span { color: var(--muted); }

/* „poznejte okolí" karty */
.nj-room-detail .loc-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.nj-room-detail .loc-card { background: var(--sand-1); border: 1px solid var(--line); border-radius: var(--r-card); overflow: hidden; transition: transform .25s, box-shadow .25s; display: block; color: inherit; }
.nj-room-detail .loc-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.nj-room-detail .loc-card-img { aspect-ratio: 16/10; background: var(--sand-3); background-size: cover; background-position: center; }
.nj-room-detail .loc-card-body { padding: 18px 20px; }
.nj-room-detail .loc-card-body h3 { margin: 0 0 .35rem; font-size: 1.25rem; }
.nj-room-detail .loc-card-body p { margin: 0 0 .8rem; color: var(--muted); font-size: .88rem; line-height: 1.5; }
.nj-room-detail .loc-card-body .more { color: var(--accent-deep); font-weight: 600; font-size: .82rem; }

/* placeholder marker (k dooživení) */
.nj-room-detail .nj-placeholder .addr,
.nj-room-detail .nj-placeholder li,
.nj-room-detail .loc-card .loc-card-body p { }

/* booking sidebar (sticky) */
.nj-room-detail .booking { position: sticky; top: calc(var(--adminbar-offset, 0px) + var(--nj-header-h, 90px) + 16px); background: #fff; border: 1px solid var(--line); border-radius: var(--r-card); box-shadow: var(--shadow-deep); padding: 24px; display: flex; flex-direction: column; gap: 1rem; }
.nj-room-detail .bk-head { display: flex; justify-content: space-between; align-items: baseline; padding-bottom: 1rem; border-bottom: 1px solid var(--line); }
.nj-room-detail .bk-price { font-family: var(--font-serif); font-weight: 700; font-size: 1.8rem; color: var(--navy); line-height: 1; }
.nj-room-detail .bk-price small { font-family: var(--font-sans); font-size: .85rem; color: var(--muted); font-weight: 400; }
.nj-room-detail .bk-from { font-size: .75rem; color: var(--muted); text-transform: uppercase; letter-spacing: .08em; margin-top: .2rem; }
.nj-room-detail .bk-form { display: flex; flex-direction: column; gap: 1rem; margin: 0; }
.nj-room-detail .bk-dates { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.nj-room-detail .bk-field { border: 1px solid var(--line); border-radius: var(--r-btn); padding: 8px 10px; transition: border-color .15s; }
.nj-room-detail .bk-field:focus-within { border-color: var(--accent); }
.nj-room-detail .bk-field label { display: block; font-size: .65rem; text-transform: uppercase; letter-spacing: .1em; color: var(--muted); font-weight: 600; margin-bottom: 2px; }
.nj-room-detail .bk-field input { width: 100%; border: none; padding: 0; font-family: inherit; font-size: .95rem; color: var(--navy); background: transparent; font-weight: 500; }
.nj-room-detail .bk-field input:focus { outline: none; }
.nj-room-detail .bk-note { font-size: .78rem; color: var(--muted); text-align: center; line-height: 1.4; margin: 0; }
.nj-room-detail .bk-contact { padding-top: 1rem; border-top: 1px solid var(--line); font-size: .85rem; color: var(--muted); text-align: center; }
.nj-room-detail .bk-contact strong { display: block; color: var(--navy); margin-bottom: .5rem; }
.nj-room-detail .bk-contact .ctas { display: flex; gap: .5rem; }
.nj-room-detail .bk-contact .ctas a { flex: 1; padding: .55rem; border-radius: var(--r-btn); border: 1px solid var(--line); font-weight: 500; color: var(--navy); display: inline-flex; align-items: center; justify-content: center; transition: all .15s; }
.nj-room-detail .bk-contact .ctas a:hover { border-color: var(--navy); background: var(--sand-1); }
.nj-room-detail .bk-contact .ctas a.wa { color: #25d366; border-color: #25d366; }
.nj-room-detail .bk-contact .ctas a.wa:hover { background: #25d366; color: #fff; }

/* tlačítka large/full (design rozšíření) */
.nj-room-detail .btn-full { width: 100%; }
.nj-room-detail .btn-large { padding: 1rem 2rem; font-size: 1.05rem; }

/* podobné apartmány */
.nj-room-detail .similar { padding: 60px 0; background: var(--sand-2); }
.nj-room-detail .similar-head { display: flex; justify-content: space-between; align-items: end; gap: 1rem; flex-wrap: wrap; margin-bottom: 1.5rem; }

/* mobilní rezervační lišta */
.nj-room-detail .mobile-book { display: none; }

@media (max-width: 1100px) {
	.nj-room-detail .main-grid { grid-template-columns: 1fr; gap: 30px; }
	.nj-room-detail .booking { position: static; }
	.nj-room-detail .facts-row { grid-template-columns: repeat(3, 1fr); }
	.nj-room-detail .gh-grid { grid-template-columns: 1fr 1fr; grid-template-rows: none; height: auto; }
	.nj-room-detail .gh-grid > a { aspect-ratio: 4/3; }
	.nj-room-detail .gh-grid > a:nth-child(1) { grid-column: 1/3; grid-row: 1; aspect-ratio: 16/9; }
	.nj-room-detail .gh-grid > a.video-spot { grid-column: 1/3; grid-row: 2; aspect-ratio: 16/9; }
	.nj-room-detail .gh-grid > a:nth-child(3) { grid-column: 1; grid-row: 3; }
	.nj-room-detail .gh-grid > a:nth-child(4) { grid-column: 2; grid-row: 3; }
	/* bez videa na mobilu: main přes celou šířku + 2×2 fotky */
	.nj-room-detail .gh-grid--novideo > a:nth-child(1) { grid-column: 1/3; grid-row: 1; aspect-ratio: 16/9; }
	.nj-room-detail .gh-grid--novideo > a:nth-child(2) { grid-column: 1; grid-row: 2; }
	.nj-room-detail .gh-grid--novideo > a:nth-child(3) { grid-column: 2; grid-row: 2; }
	.nj-room-detail .gh-grid--novideo > a:nth-child(4) { grid-column: 1; grid-row: 3; }
	.nj-room-detail .gh-grid--novideo > a:nth-child(5) { grid-column: 2; grid-row: 3; }
	.nj-room-detail .loc-grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
	.nj-room-detail .facts-row { grid-template-columns: repeat(2, 1fr); }
	.nj-room-detail .dispoz { grid-template-columns: 1fr; }
	.nj-room-detail .amen-grid { grid-template-columns: repeat(2, 1fr); }
	.nj-room-detail .loc-cards { grid-template-columns: 1fr; }
	.nj-room-detail .content-block { padding: 22px; }
	.nj-room-detail .booking { display: none; }
	.nj-room-detail .mobile-book { display: flex; position: fixed; bottom: 0; left: 0; right: 0; background: #fff; border-top: 1px solid var(--line); padding: 12px 16px; z-index: 45; box-shadow: 0 -8px 20px rgba(20,57,88,.1); justify-content: space-between; align-items: center; gap: 1rem; }
	.nj-room-detail .mobile-book .pr { font-family: var(--font-serif); font-weight: 700; color: var(--navy); font-size: 1.2rem; line-height: 1; }
	.nj-room-detail .mobile-book .pr small { font-family: var(--font-sans); font-size: .78rem; color: var(--muted); font-weight: 400; display: block; }
}

/* ── úpravy dle zpětné vazby ── */

/* štítky v titulku — plošší „labely", ne tlačítka */
.nj-room-detail .title-tag {
	background: var(--sand-2);
	border: none;
	color: var(--navy);
	padding: .28rem .7rem;
	font-size: .76rem;
	font-weight: 500;
	border-radius: var(--r-btn);
}
.nj-room-detail .title-tag.top { background: var(--accent); color: #fff; }
.nj-room-detail .title-tag.sold { background: var(--muted); color: #fff; }
/* prodej: mřížka podobných nemovitostí */
.nj-room-detail .similar .projects-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
@media (max-width: 1100px) { .nj-room-detail .similar .projects-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .nj-room-detail .similar .projects-grid { grid-template-columns: 1fr; } }

/* ikony rychlých faktů */
.nj-room-detail .fact svg { width: 24px; height: 24px; color: var(--accent-deep); }

/* ceník — sezónní (per-room) tabulka + poplatky */
.nj-room-detail .nj-price-intro { color: var(--muted); margin: 0 0 1.2rem; font-size: .95rem; }
.nj-room-detail .nj-seasons { list-style: none; margin: 0 0 1rem; padding: 0; display: flex; flex-direction: column; gap: .6rem; }
.nj-room-detail .nj-seasons li { display: flex; justify-content: space-between; align-items: center; gap: 1rem; padding: .9rem 1.1rem; background: var(--sand-1); border: 1px solid var(--line); border-radius: var(--r-card); transition: border-color .15s; }
.nj-room-detail .nj-seasons li:hover { border-color: var(--accent); }
.nj-room-detail .nj-seasons .se { font-weight: 600; color: var(--navy); }
.nj-room-detail .nj-seasons .pr { font-family: var(--font-serif); font-weight: 700; font-size: 1.25rem; color: var(--navy); white-space: nowrap; }
.nj-room-detail .nj-seasons .pr small { font-family: var(--font-sans); font-size: .72rem; color: var(--muted); font-weight: 400; text-transform: uppercase; letter-spacing: .05em; margin-left: .2rem; }
.nj-room-detail .nj-price-minstay { font-size: .85rem; color: var(--muted); margin: 0 0 1.2rem; }
.nj-room-detail .nj-price-extra { display: grid; grid-template-columns: repeat(2, 1fr); gap: .4rem 1.5rem; font-size: .88rem; color: var(--muted); }
.nj-room-detail .nj-price-extra div { display: flex; justify-content: space-between; gap: .5rem; padding: .35rem 0; border-bottom: 1px dashed var(--line); }
.nj-room-detail .nj-price-extra strong { color: var(--navy); font-weight: 600; white-space: nowrap; }
@media (max-width: 640px) {
	.nj-room-detail .nj-price-extra { grid-template-columns: 1fr; }
	.nj-room-detail .nj-seasons li { flex-direction: column; align-items: flex-start; gap: .3rem; }
}

/* tlačítko „Všechny apartmány" menší (dle designu) */
.nj-room-detail .similar-head .btn { padding: .55rem 1rem; font-size: .85rem; }

/* placeholder řádky (k dooživení) — decentně odlišit */
.nj-room-detail .nj-placeholder, .nj-room-detail .loc-distances .nj-placeholder span { opacity: .65; font-style: italic; }

/* plugin kalendář — ať se vejde do karty */
.nj-room-detail .tr-cal-wrap { max-width: 100%; }

/* ==========================================================================
   KALENDÁŘ OBSAZENOSTI [tr_room_calendar] — plugin nedodává CSS, stylujeme my.
   Markup: .tr-cal-wrap → .tr-cal-nav / .tr-cal-legend / .tr-cal-months
           → .tr-cal-month → table.tr-cal-table (th .tr-cal-th, td .tr-cal-td
           se stavovými třídami) → .tr-cal-cell (.tr-cal-num + .tr-cal-price)
   Stavy: tr-cal-free / -occupied / -checkin / -checkout / -checkin-checkout,
          td--empty / --past / --weekend.
   ========================================================================== */
.nj-room-detail .tr-cal-nav { display: flex; align-items: center; gap: .6rem; margin-bottom: 1rem; }
.nj-room-detail .tr-cal-nav-btn { width: 32px; height: 32px; border: 1px solid var(--line); background: #fff; border-radius: var(--r-btn); cursor: pointer; color: var(--navy); font-size: 1rem; line-height: 1; }
.nj-room-detail .tr-cal-nav-btn:hover:not(:disabled) { background: var(--sand-1); border-color: var(--navy); }
.nj-room-detail .tr-cal-nav-btn:disabled { opacity: .4; cursor: default; }
.nj-room-detail .tr-cal-nav-label { font-weight: 600; color: var(--navy); }

.nj-room-detail .tr-cal-legend { display: flex; gap: 1.2rem; flex-wrap: wrap; margin-bottom: 1.2rem; font-size: .85rem; color: var(--muted); }
.nj-room-detail .tr-cal-legend-item { display: inline-flex; align-items: center; gap: .4rem; }
.nj-room-detail .tr-cal-legend-dot { width: 16px; height: 16px; border-radius: 4px; display: inline-block; }
.nj-room-detail .tr-cal-legend-dot.tr-cal-free { background: #c2ebcf; border: 1px solid #7cd29a; }
.nj-room-detail .tr-cal-legend-dot.tr-cal-occupied { background: #fcd0bf; border: 1px solid #ee9678; }
.nj-room-detail .tr-cal-legend-dot.tr-cal-checkin { background: linear-gradient(135deg, #fcd0bf 50%, #c2ebcf 50%); border: 1px solid var(--line-2); }

/* 2 měsíce přes celou šířku bloku (kalendář zobrazuje 2 měsíce; 3 sloupce
   nechávaly prázdné místo vpravo). auto-fit drží roztažení i kdyby se počet změnil. */
.nj-room-detail .tr-cal-months { display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px; }
.nj-room-detail .tr-cal-month-title { text-align: center; margin: 0 0 .6rem; font-family: var(--font-serif); font-size: 1.1rem; color: var(--navy); font-weight: 600; }
.nj-room-detail .tr-cal-loading { color: var(--muted); padding: 1rem 0; }

.nj-room-detail .tr-cal-table { width: 100%; border-collapse: collapse; table-layout: fixed; }
.nj-room-detail .tr-cal-th { font-size: .7rem; color: var(--muted); text-transform: uppercase; letter-spacing: .05em; padding: .3rem 0; text-align: center; font-weight: 600; }
.nj-room-detail .tr-cal-td { padding: 2px; vertical-align: top; }
.nj-room-detail .tr-cal-cell { display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: 44px; border: 1px solid var(--line); border-radius: 6px; background: #fff; }
.nj-room-detail .tr-cal-num { font-size: .82rem; color: var(--ink); line-height: 1; }
.nj-room-detail .tr-cal-price { font-size: .56rem; font-weight: 600; opacity: .75; margin-top: 2px; line-height: 1; }

.nj-room-detail .tr-cal-free .tr-cal-cell { background: #c2ebcf; border-color: #7cd29a; }
.nj-room-detail .tr-cal-free .tr-cal-num, .nj-room-detail .tr-cal-free .tr-cal-price { color: #197040; }
.nj-room-detail .tr-cal-occupied .tr-cal-cell { background: #fcd0bf; border-color: #ee9678; }
.nj-room-detail .tr-cal-occupied .tr-cal-num { color: #a83515; text-decoration: line-through; }
.nj-room-detail .tr-cal-occupied .tr-cal-price { display: none; }
.nj-room-detail .tr-cal-checkin .tr-cal-cell,
.nj-room-detail .tr-cal-checkout .tr-cal-cell,
.nj-room-detail .tr-cal-checkin-checkout .tr-cal-cell { background: linear-gradient(135deg, #fcd0bf 50%, #c2ebcf 50%); border-color: var(--line-2); }
.nj-room-detail .tr-cal-td--empty .tr-cal-cell { display: none; }
.nj-room-detail .tr-cal-td--past .tr-cal-cell { opacity: .4; }

@media (max-width: 980px) {
	.nj-room-detail .tr-cal-months { grid-template-columns: 1fr; gap: 28px; max-width: 360px; }
}

/* ── vlastní kalendář: nápověda, výběr termínu, klikací dny ── */
.nj-room-detail .nj-cal-help { color: var(--muted); font-size: .95rem; margin: .2rem 0 1.2rem; }
.nj-room-detail .tr-cal-td[data-date] { cursor: pointer; }
.nj-room-detail .tr-cal-td[data-date] .tr-cal-cell:hover { outline: 2px solid var(--accent); outline-offset: -2px; }
.nj-room-detail .tr-cal-td.nj-cal-sel .tr-cal-cell { background: var(--accent); border-color: var(--accent-deep); }
.nj-room-detail .tr-cal-td.nj-cal-sel .tr-cal-num,
.nj-room-detail .tr-cal-td.nj-cal-sel .tr-cal-price { color: #fff; }
.nj-room-detail .tr-cal-td.nj-cal-inrange .tr-cal-cell { background: rgba(251, 173, 36, .25); border-color: rgba(251, 173, 36, .45); }
.nj-room-detail .tr-cal-td.nj-cal-inrange .tr-cal-num,
.nj-room-detail .tr-cal-td.nj-cal-inrange .tr-cal-price { color: var(--accent-deep); }
.nj-room-detail .tr-cal-legend-dot.nj-cal-sel-dot { background: var(--accent); border: 1px solid var(--accent-deep); }

/* ==========================================================================
   LIGHTBOX galerie detailu (.nj-glx) — appenduje se do <body>, proto MIMO
   scope .nj-room-detail. Ovládá room-gallery.js.
   ========================================================================== */
.nj-glx { position: fixed; inset: 0; z-index: 2000; display: flex; align-items: center; justify-content: center; gap: .5rem; padding: 4vmin; background: rgba(20, 57, 88, .92); opacity: 0; visibility: hidden; transition: opacity .25s; }
.nj-glx.is-open { opacity: 1; visibility: visible; }
.nj-glx-fig { margin: 0; display: flex; flex-direction: column; align-items: center; gap: .6rem; }
.nj-glx img { max-width: 86vw; max-height: 82vh; border-radius: var(--r-card); box-shadow: 0 20px 60px rgba(0, 0, 0, .5); transform: scale(.97); transition: transform .25s; }
.nj-glx.is-open img { transform: scale(1); }
.nj-glx-count { color: rgba(255, 255, 255, .85); font-size: .9rem; }
.nj-glx-video { display: none; }
.nj-glx-video iframe, .nj-glx-video video { width: 86vw; max-width: 1000px; height: 48.5vw; max-height: 80vh; border: 0; border-radius: var(--r-card); background: #000; display: block; }
.nj-glx-close { position: absolute; top: 18px; right: 22px; width: 44px; height: 44px; border: 0; border-radius: 50%; background: rgba(255, 255, 255, .14); color: #fff; font-size: 1.6rem; line-height: 1; cursor: pointer; transition: background .2s; }
.nj-glx-close:hover { background: var(--accent); }
.nj-glx-nav { width: 48px; height: 48px; flex-shrink: 0; border: 0; border-radius: 50%; background: rgba(255, 255, 255, .14); color: #fff; font-size: 1.8rem; line-height: 1; cursor: pointer; transition: background .2s; }
.nj-glx-nav:hover { background: var(--accent); }
@media (max-width: 640px) { .nj-glx-nav { width: 40px; height: 40px; font-size: 1.4rem; } }
