/* ─────────────────────────────────────────────────────────────
   Napi Program – Elementor widget styles
   Minden vizuális tulajdonság CSS változón vagy önálló selectoron
   keresztül felülírható az Elementor Style fülről.
   ───────────────────────────────────────────────────────────── */

.napi {
	--napi-o: #E85A25;
	--napi-dark: #0b1e35;
	--napi-cream: #f7f1e8;
	--napi-card: #ffffff;
	--napi-border: #e4dace;
	--napi-muted: #9a8a78;
	--napi-sidebar-w: 268px;
	--napi-gap: 40px;
	--napi-gallery-min: 150px;
	--napi-gallery-gap: 8px;
	--napi-gallery-ratio: 4 / 3;
	color: #1a1a1a;
	box-sizing: border-box;
}
.napi *,
.napi *::before,
.napi *::after { box-sizing: border-box; }

.napi-inner { max-width: 1200px; margin: 0 auto; }

.napi-body { display: flex; flex-direction: column; gap: 18px; }

/* ── NAV: mobil vízszintes pillek ── */
.napi-nav {
	display: flex; gap: 10px; overflow-x: auto; scroll-snap-type: x mandatory;
	padding-bottom: 8px; -webkit-overflow-scrolling: touch; scrollbar-width: none;
}
.napi-nav::-webkit-scrollbar { display: none; }

.napi-pill {
	flex: 0 0 auto; scroll-snap-align: start; cursor: pointer;
	background: var(--napi-card); border: 1px solid var(--napi-border);
	border-radius: 14px; width: 60px; height: 60px; font: inherit;
	display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 2px;
	transition: background .25s ease, border-color .25s ease;
}
.napi-num {
	font-family: 'Sofia Sans Extra Condensed', 'Inter', sans-serif; font-size: 26px;
	font-weight: 700; line-height: 1; color: var(--napi-dark); transition: color .25s ease;
}
.napi-loc { display: none; }
.napi-pill.is-active { background: var(--napi-dark); border-color: var(--napi-dark); }
.napi-pill.is-active .napi-num { color: #fff; }
.napi-pill.is-active .napi-loc { color: rgba(255,255,255,.65); }

/* ── PANEL ── */
.napi-stage { position: relative; }
.napi-panel {
	position: relative; background: var(--napi-card); border: 1px solid var(--napi-border);
	border-radius: 18px; padding: 30px 22px 26px; overflow: hidden; display: none;
}
.napi-panel.is-active { display: block; }
.napi-watermark {
	position: absolute; top: -22px; right: 4px;
	font-family: 'Sofia Sans Extra Condensed', 'Inter', sans-serif;
	font-size: 130px; font-weight: 700; line-height: 1; color: #f1e7d8;
	user-select: none; pointer-events: none; z-index: 0;
}
.napi-panel > *:not(.napi-watermark) { position: relative; z-index: 1; }
.napi-eyebrow {
	font-size: 11px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase;
	color: var(--napi-o); margin-bottom: 10px;
}
.napi-title {
	font-family: 'Sofia Sans Extra Condensed', 'Inter', sans-serif; font-size: 34px; font-weight: 700;
	line-height: 1.02; color: var(--napi-dark); text-transform: uppercase; letter-spacing: .01em; margin-bottom: 14px;
}
.napi-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 20px; }
.napi-tags span {
	font-size: 12px; font-weight: 600; color: #5a4a38; background: var(--napi-cream);
	border: 1px solid var(--napi-border); border-radius: 20px; padding: 6px 13px; white-space: nowrap;
}
.napi-prose { margin-bottom: 22px; }
.napi-prose p { font-size: 14.5px; line-height: 1.75; color: #555; text-wrap: pretty; }
.napi-prose p + p { margin-top: 13px; }

/* gallery */
.napi-gallery {
	display: grid; grid-template-columns: repeat(auto-fill, minmax(var(--napi-gallery-min), 1fr));
	gap: var(--napi-gallery-gap); margin-bottom: 24px;
}
.napi-shot {
	padding: 0; border: none; cursor: pointer; border-radius: 10px; overflow: hidden;
	background: #e9e0d2; aspect-ratio: var(--napi-gallery-ratio); position: relative; display: block;
}
.napi-shot img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s cubic-bezier(.2,.6,.2,1); }
.napi-shot:hover img { transform: scale(1.06); }
.napi-shot::after { content: ""; position: absolute; inset: 0; background: rgba(11,30,53,0); transition: background .3s ease; }
.napi-shot:hover::after { background: rgba(11,30,53,.12); }

.napi-meta { display: flex; flex-wrap: wrap; gap: 28px; padding-top: 18px; border-top: 1px solid var(--napi-border); }
.napi-meta > div { display: flex; flex-direction: column; gap: 3px; }
.napi-meta-l { font-size: 10px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--napi-muted); }
.napi-meta-v { font-size: 14px; font-weight: 600; color: #2a2a2a; }

.napi-foot { display: flex; align-items: center; justify-content: space-between; margin-top: 14px; padding: 0 4px; }
.napi-count { font-family: 'Sofia Sans Extra Condensed', 'Inter', sans-serif; font-size: 15px; font-weight: 700; color: var(--napi-dark); letter-spacing: .05em; }
.napi-count b { color: var(--napi-o); }
.napi-hint { font-size: 11px; color: var(--napi-muted); }
.napi-arrows { display: none; gap: 8px; }
.napi-arrows button {
	width: 38px; height: 38px; border-radius: 10px; border: 1px solid var(--napi-border);
	background: var(--napi-card); cursor: pointer; font-size: 18px; color: var(--napi-dark);
	display: flex; align-items: center; justify-content: center; transition: background .2s ease, border-color .2s ease;
}
.napi-arrows button:hover { background: var(--napi-cream); border-color: #cbb; }
.napi-arrows button:disabled { opacity: .3; cursor: default; }

/* entrance animation */
@media (prefers-reduced-motion: no-preference) {
	.napi-panel.is-active .napi-anim { animation: napi-in .5s cubic-bezier(.2,.7,.2,1) both; }
	.napi-panel.is-active .napi-anim:nth-child(2) { animation-delay: .03s; }
	.napi-panel.is-active .napi-anim:nth-child(3) { animation-delay: .06s; }
	.napi-panel.is-active .napi-anim:nth-child(4) { animation-delay: .09s; }
	.napi-panel.is-active .napi-anim:nth-child(5) { animation-delay: .12s; }
	.napi-panel.is-active .napi-anim:nth-child(6) { animation-delay: .15s; }
	.napi-panel.is-active .napi-watermark { animation: napi-wm .7s cubic-bezier(.2,.7,.2,1) both; }
}
@keyframes napi-in { from { opacity: 0; transform: translateX(var(--napi-dir, 34px)); } to { opacity: 1; transform: none; } }
@keyframes napi-wm { from { opacity: 0; transform: translateX(calc(var(--napi-dir, 34px) * 1.7)); } to { opacity: 1; transform: none; } }

/* ── DESKTOP ── */
@media (min-width: 860px) {
	.napi-body { display: grid; grid-template-columns: var(--napi-sidebar-w) 1fr; gap: var(--napi-gap); align-items: start; }
	.napi-nav { flex-direction: column; gap: 6px; overflow: visible; padding-bottom: 0; position: sticky; top: 24px; }
	.napi-pill {
		width: 100%; height: auto; flex-direction: row; justify-content: flex-start; align-items: center;
		gap: 14px; border-radius: 12px; padding: 13px 16px; text-align: left; border-color: transparent; background: transparent;
	}
	.napi-num { font-size: 22px; color: #c3b39e; width: 34px; text-align: center; flex: 0 0 auto; }
	.napi-loc { display: block; font-size: 14px; font-weight: 600; color: #7a6a58; line-height: 1.25; transition: color .25s ease; }
	.napi-pill:hover { background: var(--napi-card); }
	.napi-pill.is-active { background: var(--napi-card); border-color: var(--napi-border); box-shadow: 0 6px 18px rgba(11,30,53,.07); position: relative; }
	.napi-pill.is-active::before { content: ""; position: absolute; left: 0; top: 14%; bottom: 14%; width: 3px; border-radius: 0 3px 3px 0; background: var(--napi-o); }
	.napi-pill.is-active .napi-num { color: var(--napi-o); }
	.napi-pill.is-active .napi-loc { color: var(--napi-dark); }
	.napi-panel { padding: 42px 46px 36px; border-radius: 22px; }
	.napi-watermark { font-size: 200px; top: -34px; right: 24px; }
	.napi-eyebrow { font-size: 12px; }
	.napi-title { font-size: 50px; }
	.napi-prose { column-count: var(--napi-prose-cols, 1); column-gap: 48px; max-width: 760px; }
	.napi-prose p { font-size: 15.5px; }
	.napi-gallery { gap: 10px; }
	.napi-foot { margin-top: 18px; }
	.napi-arrows { display: flex; }
	.napi-hint { display: none; }
}

/* ── LIGHTBOX ── */
.napi-lb {
	position: fixed; inset: 0; z-index: 99999; background: rgba(8,14,24,.92);
	display: none; align-items: center; justify-content: center; padding: 24px;
	opacity: 0; transition: opacity .25s ease;
}
.napi-lb.is-on { display: flex; }
.napi-lb-img { max-width: 92vw; max-height: 82vh; border-radius: 8px; box-shadow: 0 30px 80px rgba(0,0,0,.6); }
.napi-lb-cap { position: absolute; bottom: 22px; left: 0; right: 0; text-align: center; color: rgba(255,255,255,.8); font-size: 13px; }
.napi-lb-x { position: absolute; top: 18px; right: 22px; width: 42px; height: 42px; border-radius: 50%; border: none; background: rgba(255,255,255,.12); color: #fff; font-size: 22px; cursor: pointer; }
.napi-lb-nav { position: absolute; top: 50%; transform: translateY(-50%); width: 48px; height: 48px; border-radius: 50%; border: none; background: rgba(255,255,255,.12); color: #fff; font-size: 24px; cursor: pointer; }
.napi-lb-prev { left: 18px; }
.napi-lb-next { right: 18px; }
.napi-lb-nav:hover, .napi-lb-x:hover { background: rgba(255,255,255,.24); }


/* No border on gallery thumbnails */
.napi-shot,
.napi-shot:hover,
.napi-shot:active,
.napi-shot:focus,
.napi-shot.is-active {
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  background: transparent !important;
}
