/* ===== AlbaniaForAll — premium design system ===== */
:root {
  --ion:    #0e9bb0;   /* ionian turquoise */
  --ion-d:  #0a6f7e;
  --deep:   #0b3a44;   /* deep teal */
  --sand:   #e9c98c;   /* warm sand accent */
  --sand-d: #c79a4f;
  --coral:  #e0603a;
  --ink:    #15242a;
  --muted:  #5d7077;
  --line:   #e3e9ea;
  --bg:     #f7fafb;
  --white:  #ffffff;
  --radius: 16px;
  --shadow:   0 10px 30px rgba(11,58,68,.10);
  --shadow-l: 0 20px 50px rgba(11,58,68,.18);
  --maxw: 1200px;
  --font-head: "Playfair Display", Georgia, serif;
  --font-body: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0; font-family: var(--font-body); color: var(--ink);
  background: var(--bg); line-height: 1.6; -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
h1,h2,h3 { font-family: var(--font-head); font-weight: 700; line-height: 1.15; margin: 0 0 .4em; }
.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 22px; }
.eyebrow { text-transform: uppercase; letter-spacing: .18em; font-size: .76rem; font-weight: 700; color: var(--ion); }
.sec-head { text-align: center; max-width: 640px; margin: 0 auto 36px; }
.sec-head h2 { font-size: clamp(1.8rem, 3.4vw, 2.7rem); color: var(--deep); }
.sec-head p { color: var(--muted); font-size: 1.05rem; margin: 0; }
section { padding: 72px 0; }

/* ===== Buttons ===== */
.btn { display: inline-flex; align-items: center; gap: .5em; padding: .85em 1.6em; border-radius: 999px;
  font-weight: 600; font-size: .98rem; cursor: pointer; border: 0; transition: transform .15s, box-shadow .15s, background .15s; }
.btn-primary { background: var(--ion); color: #fff; box-shadow: 0 8px 20px rgba(14,155,176,.35); }
.btn-primary:hover { background: var(--ion-d); transform: translateY(-2px); }
.btn-ghost { background: rgba(255,255,255,.14); color: #fff; border: 1px solid rgba(255,255,255,.5); backdrop-filter: blur(6px); }
.btn-ghost:hover { background: rgba(255,255,255,.26); }
.btn-sand { background: var(--sand); color: #4a3a16; }
.btn-sand:hover { background: var(--sand-d); }

/* ===== Header ===== */
.site-head { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px); border-bottom: 1px solid var(--line); }
.site-head .wrap { display: flex; align-items: center; gap: 15px; height: 70px; }
.brand { display: flex; align-items: center; gap: 10px; font-family: var(--font-head); font-weight: 800;
  font-size: 1.35rem; color: var(--deep); letter-spacing: -.01em; }
.brand .mark { width: 34px; height: 34px; border-radius: 9px; display: grid; place-items: center;
  background: linear-gradient(135deg, var(--ion), var(--deep)); color: #fff; font-size: 1.1rem; }
.brand b { color: var(--ion); }
.nav { display: flex; gap: 17px; margin-left: auto; }
.nav a { font-weight: 600; font-size: .95rem; color: var(--ink); padding: 6px 0; position: relative; white-space: nowrap; }
.nav a:hover { color: var(--ion); }
.langs { display: flex; align-items: center; gap: 2px; }
.langs a { font-size: .8rem; font-weight: 700; padding: 5px 8px; border-radius: 7px; color: var(--muted); text-transform: uppercase; }
.langs a.on { background: var(--ion); color: #fff; }
.burger { display: none; }

/* ===== Dropdowny w nawigacji (Poznaj kraj + języki) ===== */
.dd { position: relative; }
.dd > summary { list-style: none; cursor: pointer; font-weight: 600; font-size: .96rem; color: var(--ink);
  padding: 6px 0; display: inline-flex; align-items: center; gap: 5px; white-space: nowrap; }
.dd > summary::-webkit-details-marker { display: none; }
.dd > summary::marker { content: ""; }
.dd > summary:hover { color: var(--ion); }
.dd .caret { font-size: .62rem; line-height: 1; transition: transform .2s; }
.dd[open] .caret { transform: rotate(180deg); }
.dd .dd-menu { position: absolute; top: calc(100% + 12px); left: 0; min-width: 210px; background: #fff;
  border: 1px solid var(--line); border-radius: 14px; box-shadow: var(--shadow-l); padding: 8px; z-index: 60;
  display: flex; flex-direction: column; gap: 2px; }
.dd .dd-menu.dd-right { left: auto; right: 0; }
.dd .dd-menu a { font-size: .92rem; font-weight: 600; color: var(--ink); padding: 9px 12px; border-radius: 9px;
  display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.dd .dd-menu a:hover { background: var(--bg); color: var(--ion); }
.dd .dd-menu a.on { color: var(--ion); background: var(--bg); }
.dd .dd-menu .lc { font-size: .7rem; color: var(--muted); font-weight: 700; }
/* Pigułka przełącznika języków */
.lang-dd { margin-left: 2px; }
.lang-dd > summary { font-size: .82rem; font-weight: 700; text-transform: uppercase; letter-spacing: .03em;
  border: 1px solid var(--line); border-radius: 9px; padding: 7px 11px; color: var(--deep); }
.lang-dd[open] > summary, .lang-dd > summary:hover { border-color: var(--ion); color: var(--ion); }

/* Pasek nagłówka: wyszukiwarka + konto */
.head-search { position: relative; display: inline-flex; }
.hs-toggle { background: none; border: 0; cursor: pointer; color: var(--ink); display: inline-flex; align-items: center; padding: 7px; border-radius: 8px; }
.hs-toggle:hover { color: var(--ion); background: var(--bg); }
.hs-panel { position: absolute; top: calc(100% + 12px); right: 0; width: 330px; background: #fff; border: 1px solid var(--line);
  border-radius: 14px; box-shadow: var(--shadow-l); padding: 10px; z-index: 60; }
.hs-panel input { width: 100%; padding: .62em .85em; border: 1px solid var(--line); border-radius: 9px; font: inherit; }
.hs-results { margin-top: 6px; max-height: 340px; overflow-y: auto; }
.hs-results a { display: flex; flex-direction: column; gap: 1px; padding: 8px 10px; border-radius: 8px; color: var(--ink); font-weight: 700; font-size: .9rem; }
.hs-results a span { font-weight: 400; font-size: .75rem; color: var(--muted); }
.hs-results a:hover { background: var(--bg); color: var(--ion); }
.head-acc { font-weight: 600; font-size: .92rem; color: var(--ink); white-space: nowrap; }
.head-acc:hover { color: var(--ion); }
.head-acc-cta { background: var(--ion); color: #fff; padding: 7px 14px; border-radius: 9px; }
.head-acc-cta:hover { background: #11b0c7; color: #fff; }
.head-acc-muted { color: var(--muted); }

/* ===== Górny pasek (topbar) — kontakt + utility ===== */
.topbar { background: var(--deep); color: rgba(255,255,255,.82); font-size: .82rem; }
.topbar-inner { display: flex; align-items: center; justify-content: space-between; min-height: 40px; gap: 14px; }
.topbar-left { display: flex; align-items: center; gap: 20px; }
.topbar-right { display: flex; align-items: center; gap: 12px; }
.tb-item { display: inline-flex; align-items: center; gap: 6px; color: rgba(255,255,255,.82); }
.tb-item:hover { color: var(--sand); }
.tb-social svg { display: block; }
.tb-sep { color: rgba(255,255,255,.22); }
.hs-lbl { font-size: .82rem; }
.topbar .hs-toggle { color: rgba(255,255,255,.85); gap: 6px; padding: 5px 8px; }
.topbar .hs-toggle:hover { color: #fff; background: rgba(255,255,255,.12); }
.topbar .head-acc { color: rgba(255,255,255,.9); font-size: .85rem; font-weight: 600; }
.topbar .head-acc:hover { color: var(--sand); }
.topbar .head-acc-cta { background: var(--ion); color: #fff; padding: 5px 13px; border-radius: 8px; }
.topbar .head-acc-cta:hover { background: #11b0c7; color: #fff; }
.topbar .head-acc-muted { color: rgba(255,255,255,.6); }
.topbar .lang-dd > summary { color: rgba(255,255,255,.9); border-color: rgba(255,255,255,.28); padding: 4px 9px; font-size: .78rem; }
.topbar .lang-dd[open] > summary, .topbar .lang-dd > summary:hover { color: #fff; border-color: var(--sand); }
@media (max-width: 900px) {
  .site-head .wrap { gap: 12px; }
  .hs-panel { width: calc(100vw - 32px); right: -6px; }
}
@media (max-width: 720px) {
  .topbar-left { display: none; }
  .hs-lbl { display: none; }
}
@media (max-width: 520px) { .topbar .head-acc-cta { display: none; } }

/* ===== City sub-nav ===== */
.city-nav { position: sticky; top: 70px; z-index: 40; background: var(--deep); color: #fff;
  box-shadow: 0 4px 14px rgba(11,58,68,.18); }
.city-nav .wrap { display: flex; align-items: center; gap: 18px; min-height: 54px; padding: 7px 0; flex-wrap: wrap; }
.city-nav-home { display: flex; flex-direction: column; line-height: 1.05; padding-right: 18px;
  border-right: 1px solid rgba(255,255,255,.18); white-space: nowrap; }
.city-nav-home .cn-name { font-family: var(--font-head); font-weight: 700; font-size: 1.05rem; }
.city-nav-home .cn-region { font-size: .7rem; opacity: .7; letter-spacing: .04em; }
.city-nav-links { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; row-gap: 6px; }
.city-nav-links a { white-space: nowrap; font-size: .9rem; font-weight: 600; color: rgba(255,255,255,.82);
  padding: 7px 13px; border-radius: 999px; }
.city-nav-links a:hover { background: rgba(255,255,255,.12); color: #fff; }
.city-nav-links a.on { background: var(--ion); color: #fff; }

/* ===== Listing / detail ===== */
.listing-bar { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; margin-bottom: 26px; }
.listing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.obj-card { background:#fff; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow);
  transition: transform .2s, box-shadow .2s; display: flex; flex-direction: column; }
.obj-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-l); }
.obj-card .photo { height: 180px; position: relative; background-size: cover; background-position: center; background-color:#d6e6e9; }
.obj-card .photo::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, transparent 45%, rgba(0,0,0,.4)); }
.ph-ico { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); font-size:3.8rem; opacity:.45;
  z-index:1; text-shadow:0 3px 14px rgba(0,0,0,.3); pointer-events:none; }
.obj-card .photo .badge { position:absolute; top:12px; left:12px; z-index:2; background: rgba(255,255,255,.92);
  color: var(--deep); font-size:.72rem; font-weight:700; padding:4px 10px; border-radius:999px; }
.obj-card .photo .plan { position:absolute; top:12px; right:12px; z-index:2; font-size:.66rem; font-weight:800;
  letter-spacing:.06em; text-transform:uppercase; padding:4px 9px; border-radius:999px; background: var(--sand); color:#4a3a16; }
.obj-card .body { padding: 16px 18px 18px; flex:1; display:flex; flex-direction:column; }
.obj-card h3 { font-size: 1.2rem; color: var(--deep); margin: 0 0 6px; }
.obj-card .body p { color: var(--muted); font-size:.9rem; margin: 0 0 14px; flex:1; }
.obj-card .meta { display:flex; justify-content:space-between; align-items:center; }
.obj-card .price { font-weight:700; color: var(--ion); }
.obj-card .price small { color: var(--muted); font-weight:500; }
.rating-pill { background:#eef6f7; color: var(--ion-d); font-weight:700; font-size:.82rem; padding:3px 9px; border-radius:8px; }

/* search availability box */
.avail-box { background:#fff; border-radius: var(--radius); padding: 18px 20px; box-shadow: var(--shadow);
  display:flex; gap:12px; flex-wrap:wrap; align-items:flex-end; margin-bottom: 30px; }
.avail-box .fld { display:flex; flex-direction:column; gap:4px; }
.avail-box label { font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em; color:var(--muted); }
.avail-box input, .avail-box select { padding:.6em .8em; border:1px solid var(--line); border-radius:10px; font-size:.95rem; }
.avail-flag { display:inline-block; font-size:.8rem; font-weight:700; padding:3px 10px; border-radius:999px; }
.avail-free { background:#e3f5e8; color:#1f7a3d; }
.avail-busy { background:#fde3df; color:#b23b22; }

/* detail */
.obj-hero { display:grid; grid-template-columns: 1.4fr 1fr; gap: 10px; height: 380px; margin-bottom: 30px; border-radius: var(--radius); overflow:hidden; }
.obj-hero .main { background-size:cover; background-position:center; background-color:#cfe1e4; }
.obj-hero .side { display:grid; grid-template-rows: 1fr 1fr; gap:10px; }
.obj-hero .side div { background-size:cover; background-position:center; background-color:#dbe8ea; }
.obj-hero--2 .side { grid-template-rows: 1fr; }
.obj-hero-single { height: 380px; margin-bottom: 30px; border-radius: var(--radius); background-size: cover; background-position: center; background-color: #cfe1e4; }
.obj-hero-empty { height: 210px; margin-bottom: 30px; border-radius: var(--radius); position: relative; overflow: hidden;
  background: linear-gradient(150deg, var(--ion), #0b3a44); }
.detail-grid { display:grid; grid-template-columns: 1fr 360px; gap: 30px; align-items:start; }
.amen { display:flex; flex-wrap:wrap; gap:8px; margin:14px 0; }
.amen span { background:#eef6f7; color:var(--ion-d); font-size:.82rem; font-weight:600; padding:6px 12px; border-radius:999px; }
#obj-map { height:220px; border-radius:12px; overflow:hidden; }

/* ===== Hero ===== */
.hero { position: relative; min-height: 76vh; display: flex; align-items: center; color: #fff; overflow: hidden; }
/* Ruchomy pokaz zdjęć w hero */
.hero-slides { position: absolute; inset: 0; z-index: -2; overflow: hidden; background: #0b3a44; }
.hero-slide { position: absolute; inset: 0; background-size: cover; background-position: center; opacity: 0;
  animation-name: af-slideshow; animation-timing-function: ease; animation-iteration-count: infinite;
  will-change: opacity, transform; }
@keyframes af-slideshow {
  0%   { opacity: 0; transform: scale(1.08); }
  4%   { opacity: 1; }
  18%  { opacity: 1; }
  24%  { opacity: 0; transform: scale(1.14); }
  100% { opacity: 0; transform: scale(1.08); } }
.hero::after { content:""; position: absolute; inset:0; z-index:-1;
  background: linear-gradient(105deg, rgba(11,58,68,.88) 0%, rgba(11,58,68,.62) 44%, rgba(11,58,68,.28) 100%); }
@media (prefers-reduced-motion: reduce) { .hero-slide { animation: none; } .hero-slide:first-child { opacity: 1; } }
.hero .wrap { padding-top: 40px; padding-bottom: 56px; }
.hero h1 { font-size: clamp(2.4rem, 6vw, 4.6rem); max-width: 14ch; text-shadow: 0 4px 30px rgba(0,0,0,.25); }
.hero p.lead { font-size: clamp(1.05rem, 2vw, 1.35rem); max-width: 42ch; opacity: .96; margin-bottom: 28px; }
.hero .eyebrow { color: var(--sand); }

/* search bar */
.searchbar { display: flex; background: #fff; border-radius: 999px; padding: 7px 7px 7px 22px; max-width: 560px;
  box-shadow: var(--shadow-l); align-items: center; }
.searchbar input { border: 0; outline: 0; flex: 1; font-size: 1rem; color: var(--ink); background: transparent; }
.searchbar .btn { white-space: nowrap; }
.hero-cta { display: flex; gap: 14px; margin-top: 22px; flex-wrap: wrap; }

/* hero stats */
.hero-stats { display: flex; gap: 38px; margin-top: 40px; }
.hero-stats div { }
.hero-stats b { display: block; font-family: var(--font-head); font-size: 2rem; line-height: 1; }
.hero-stats span { font-size: .85rem; opacity: .85; letter-spacing: .04em; }

/* hero — układ tekst + kolaż zdjęć */
.hero-wrap { display: flex; align-items: center; justify-content: space-between; gap: 48px; }
.hero-text { flex: 1 1 0; max-width: 600px; }
.hero-collage { flex: 0 0 auto; display: grid; grid-template-columns: 1.15fr 1fr; grid-auto-rows: 1fr;
  gap: 14px; width: min(440px, 40vw); height: 400px; }
.hero-collage a { position: relative; display: block; border-radius: 18px; overflow: hidden;
  background-size: cover; background-position: center; background-color: rgba(255,255,255,.08);
  box-shadow: 0 20px 48px rgba(0,0,0,.42); text-decoration: none; animation: af-float 7s ease-in-out infinite; }
.hero-collage a:first-child { grid-row: 1 / span 2; }
.hero-collage a:nth-child(2) { animation-delay: .8s; }
.hero-collage a:nth-child(3) { animation-delay: 1.5s; }
.hero-collage a::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, transparent 52%, rgba(0,0,0,.55)); }
.hero-collage .hc-cap { position:absolute; left:13px; bottom:11px; z-index:2; color:#fff; font-weight:700;
  font-size:.92rem; text-shadow:0 2px 10px rgba(0,0,0,.5); }
@keyframes af-float { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }
@media (prefers-reduced-motion: reduce) { .hero-collage a { animation: none; } }
@media (max-width: 900px) { .hero-collage { display: none; } .hero-text { max-width: none; } }

/* ===== Region cards ===== */
.regions-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.region-card { position: relative; border-radius: var(--radius); overflow: hidden; min-height: 230px;
  padding: 26px; display: flex; flex-direction: column; justify-content: flex-end; color: #fff;
  box-shadow: var(--shadow); transition: transform .2s, box-shadow .2s; isolation: isolate; }
.region-card::before { content:""; position:absolute; inset:0; z-index:-1; opacity:.96;
  background: linear-gradient(145deg, var(--rc, #0e9bb0), #0b3a44); }
.region-card::after { content:""; position:absolute; inset:0; z-index:-1;
  background: linear-gradient(180deg, transparent 30%, rgba(0,0,0,.35)); }
.region-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-l); }
.region-card .ico { font-size: 2rem; margin-bottom: auto; }
.region-card h3 { font-size: 1.5rem; margin-bottom: 4px; }
.region-card p { margin: 0; font-size: .92rem; opacity: .92; }
.region-card .cnt { margin-top: 12px; font-size: .8rem; font-weight: 700; letter-spacing: .04em; opacity: .9; }

/* ===== Featured destinations ===== */
.dest-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.dest-card { background: #fff; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow);
  transition: transform .2s, box-shadow .2s; }
.dest-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-l); }
.dest-card .photo { height: 170px; position: relative; background-size: cover; background-position: center;
  background-color: #d6e6e9; }
.dest-card .photo::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, transparent 40%, rgba(0,0,0,.45)); }
.dest-card .photo .badge { position: absolute; top: 12px; left: 12px; z-index: 2; background: rgba(255,255,255,.9);
  color: var(--deep); font-size: .72rem; font-weight: 700; padding: 4px 10px; border-radius: 999px; }
.dest-card .photo .badge.tour-badge { left: auto; right: 12px; background: var(--ion); color: #fff; }
.dest-card .photo .ttl { position: absolute; bottom: 12px; left: 14px; z-index: 2; color: #fff;
  font-family: var(--font-head); font-size: 1.3rem; font-weight: 700; text-shadow: 0 2px 12px rgba(0,0,0,.4); }
.dest-card .body { padding: 14px 16px 18px; }
.dest-card .body p { margin: 0 0 12px; color: var(--muted); font-size: .9rem; }
.dest-card .go { color: var(--ion); font-weight: 700; font-size: .9rem; }

/* ===== Map section ===== */
.map-sec { background: var(--deep); color: #fff; }
.map-sec .sec-head h2 { color: #fff; }
.map-sec .sec-head p { color: rgba(255,255,255,.75); }
#albania-map { height: 560px; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-l);
  border: 1px solid rgba(255,255,255,.1); }
.leaflet-popup-content-wrapper { border-radius: 12px; }
.map-pop { font-family: var(--font-body); min-width: 170px; }
.map-pop b { font-family: var(--font-head); font-size: 1.05rem; color: var(--deep); }
.map-pop small { color: var(--muted); display: block; margin: 2px 0 8px; }
.map-pop a { color: var(--ion); font-weight: 700; font-size: .85rem; }

/* ===== Collections ===== */
.coll-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.coll-card { border-radius: var(--radius); padding: 26px 22px; background: #fff; box-shadow: var(--shadow);
  border-top: 4px solid var(--ion); transition: transform .2s; }
.coll-card:hover { transform: translateY(-4px); }
.coll-card .ico { font-size: 1.9rem; }
.coll-card h3 { font-size: 1.2rem; color: var(--deep); margin: 12px 0 6px; }
.coll-card p { margin: 0; color: var(--muted); font-size: .9rem; }

/* ===== Region / City pages ===== */
.page-hero { position: relative; isolation: isolate; min-height: 44vh; display: flex; align-items: flex-end; color:#fff; overflow:hidden;
  background: #0b3a44 center/cover no-repeat; }
.page-hero-bg { position:absolute; inset:0; z-index:-2; background-size:cover; background-position:center; }
.page-hero-bg[style*="url"] { animation: af-kenburns 24s ease-in-out infinite alternate; will-change: transform; }
@keyframes af-kenburns { from { transform: scale(1); } to { transform: scale(1.12); } }
/* Zaprojektowany placeholder dla miejsc bez zdjęcia: gradient regionu + warstwice + poświata.
   Region podaje --np (kolor); brak koloru → brandowy teal. Wygląda celowo, nie „brak foto". */
.np-bg { background-color: var(--np, #1f6f8c);
  background-image:
    radial-gradient(135% 115% at 15% 6%, rgba(255,255,255,.17), rgba(255,255,255,0) 52%),
    url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%27%20width%3D%27600%27%20height%3D%27360%27%3E%3Cg%20fill%3D%27none%27%20stroke%3D%27%23ffffff%27%20stroke-width%3D%271.4%27%3E%3Cpath%20d%3D%27M0%2C20%20q%20100%2C-22%20200%2C0%20t%20200%2C0%20t%20200%2C0%27%20stroke-opacity%3D%270.08%27%2F%3E%3Cpath%20d%3D%27M0%2C50%20q%20100%2C22%20200%2C0%20t%20200%2C0%20t%20200%2C0%27%20stroke-opacity%3D%270.05%27%2F%3E%3Cpath%20d%3D%27M0%2C80%20q%20100%2C-22%20200%2C0%20t%20200%2C0%20t%20200%2C0%27%20stroke-opacity%3D%270.05%27%2F%3E%3Cpath%20d%3D%27M0%2C110%20q%20100%2C22%20200%2C0%20t%20200%2C0%20t%20200%2C0%27%20stroke-opacity%3D%270.08%27%2F%3E%3Cpath%20d%3D%27M0%2C140%20q%20100%2C-22%20200%2C0%20t%20200%2C0%20t%20200%2C0%27%20stroke-opacity%3D%270.05%27%2F%3E%3Cpath%20d%3D%27M0%2C170%20q%20100%2C22%20200%2C0%20t%20200%2C0%20t%20200%2C0%27%20stroke-opacity%3D%270.05%27%2F%3E%3Cpath%20d%3D%27M0%2C200%20q%20100%2C-22%20200%2C0%20t%20200%2C0%20t%20200%2C0%27%20stroke-opacity%3D%270.08%27%2F%3E%3Cpath%20d%3D%27M0%2C230%20q%20100%2C22%20200%2C0%20t%20200%2C0%20t%20200%2C0%27%20stroke-opacity%3D%270.05%27%2F%3E%3Cpath%20d%3D%27M0%2C260%20q%20100%2C-22%20200%2C0%20t%20200%2C0%20t%20200%2C0%27%20stroke-opacity%3D%270.05%27%2F%3E%3Cpath%20d%3D%27M0%2C290%20q%20100%2C22%20200%2C0%20t%20200%2C0%20t%20200%2C0%27%20stroke-opacity%3D%270.08%27%2F%3E%3Cpath%20d%3D%27M0%2C320%20q%20100%2C-22%20200%2C0%20t%20200%2C0%20t%20200%2C0%27%20stroke-opacity%3D%270.05%27%2F%3E%3Cpath%20d%3D%27M0%2C350%20q%20100%2C22%20200%2C0%20t%20200%2C0%20t%20200%2C0%27%20stroke-opacity%3D%270.05%27%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E"),
    linear-gradient(150deg, var(--np, #1f6f8c) 0%, #0b3a44 82%);
  background-size: cover, 600px 360px, cover;
  background-position: center, center, center;
  background-repeat: no-repeat, repeat, no-repeat; }
.dest-card .photo.np-bg::before, .page-hero-bg.np-bg::before { content:""; position:absolute; inset:0;
  background: radial-gradient(80% 120% at 100% 100%, rgba(0,0,0,.22), transparent 60%); }
.page-hero::after { content:""; position:absolute; inset:0; z-index:-1;
  background: linear-gradient(180deg, rgba(11,58,68,.18), rgba(11,58,68,.74)); }
.page-hero .wrap { padding: 40px 22px 38px; animation: af-hero-in .8s cubic-bezier(.2,.7,.2,1) both; }
@keyframes af-hero-in { from { opacity: 0; transform: translateY(24px); } to { opacity: 1; transform: none; } }
.page-hero .crumbs { font-size: .85rem; opacity: .9; margin-bottom: 10px; }
.page-hero .crumbs a { color: var(--sand); font-weight: 600; }
.page-hero h1 { font-size: clamp(2rem, 5vw, 3.4rem); margin: 0; }
.page-hero .sub { font-size: 1.1rem; opacity: .95; margin-top: 6px; }
@media (prefers-reduced-motion: reduce) {
  .page-hero, .page-hero-bg[style*="url"], .page-hero .wrap { animation: none !important; } }
.local-name { font-size: 1rem; opacity: .8; font-style: italic; }

.section-tabs { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 30px; }
.section-tabs a { padding: 9px 16px; border-radius: 999px; background: #fff; border: 1px solid var(--line);
  font-weight: 600; font-size: .9rem; color: var(--ink); }
.section-tabs a:hover { border-color: var(--ion); color: var(--ion); }

.soon-box { background: #fff; border: 1px dashed var(--ion); border-radius: var(--radius); padding: 40px;
  text-align: center; color: var(--muted); }
.soon-box .ico { font-size: 2.4rem; }
.soon-box h3 { color: var(--deep); margin: 10px 0 6px; }

.city-grid { display: grid; grid-template-columns: 1fr 360px; gap: 30px; align-items: start; }
.aside-card { background:#fff; border-radius: var(--radius); padding: 22px; box-shadow: var(--shadow); margin-bottom: 22px; }
.aside-card h3 { color: var(--deep); font-size: 1.15rem; }
#city-map { height: 240px; border-radius: 12px; overflow: hidden; }

/* ===== Panel (CM) ===== */
.cal-wrap { display:flex; gap:18px; flex-wrap:wrap; }
.cal { flex:1; min-width:210px; }
.cal-title { font-weight:700; color:var(--deep); margin-bottom:8px; font-size:.95rem; }
.cal-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:3px; }
.cal-grid span { text-align:center; font-size:.78rem; padding:6px 0; border-radius:6px; }
.cal-h { color:var(--muted); font-weight:700; }
.cal-free { background:#eef6f7; color:var(--ink); }
.cal-busy { background:#fde3df; color:#b23b22; font-weight:700; }
.dot { display:inline-block; width:11px; height:11px; border-radius:3px; vertical-align:middle; margin-right:4px; }
.dot-free { background:#eef6f7; border:1px solid var(--line); }
.dot-busy { background:#fde3df; }
.ptable { width:100%; border-collapse:collapse; font-size:.88rem; }
.ptable th { text-align:left; color:var(--muted); font-weight:700; font-size:.72rem; text-transform:uppercase; letter-spacing:.04em; padding:6px 8px; border-bottom:1px solid var(--line); }
.ptable td { padding:9px 8px; border-bottom:1px solid var(--line); }
.ptable-wide td, .ptable-wide th { padding:12px 16px; }
.src { display:inline-block; font-size:.72rem; font-weight:700; text-transform:uppercase; padding:2px 8px; border-radius:999px; background:#eef6f7; color:var(--ion-d); }
.src-manual { background:#ede8f7; color:#5a3fb0; }
.src-booking { background:#e3eefe; color:#2a5fb0; }
.src-airbnb { background:#fde7ec; color:#c0395a; }
.xbtn { background:none; border:0; color:var(--coral); cursor:pointer; font-size:1rem; }
.pform { display:flex; flex-direction:column; gap:10px; margin-top:14px; padding:16px; background:#f7fafb; border-radius:12px; }
.pform label { display:flex; flex-direction:column; gap:4px; font-size:.8rem; font-weight:600; color:var(--muted); }
.pform input, .pform select { padding:.55em .7em; border:1px solid var(--line); border-radius:9px; font-size:.92rem; }
.pform summary { cursor:pointer; }
details > summary { list-style:none; }
details > summary::-webkit-details-marker { display:none; }

/* ===== Plany / cennik ===== */
.plans-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(210px,1fr)); gap:20px; align-items:stretch; }
.plan-card { position:relative; background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:26px 22px;
  display:flex; flex-direction:column; box-shadow:var(--shadow); }
.plan-card.plan-top { border:2px solid var(--ion); box-shadow:var(--shadow-l); transform:translateY(-4px); }
.plan-badge { position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--ion); color:#fff;
  font-size:.72rem; font-weight:700; padding:4px 14px; border-radius:999px; white-space:nowrap; }
.plan-card h3 { color:var(--deep); font-size:1.5rem; margin:4px 0 8px; }
.plan-price { margin-bottom:10px; }
.plan-price strong { font-family:var(--font-head); font-size:1.9rem; color:var(--ion-d); }
.plan-price span { color:var(--muted); font-size:.9rem; }
.plan-desc { color:var(--muted); font-size:.9rem; margin:0 0 12px; }
.plan-ben { list-style:none; padding:0; margin:0 0 18px; flex:1; }
.plan-ben li { padding:6px 0 6px 24px; position:relative; font-size:.92rem; border-bottom:1px solid var(--line); }
.plan-ben li:before { content:"✓"; position:absolute; left:0; color:var(--ion); font-weight:700; }

/* ===== Footer ===== */
.site-foot { background: var(--deep); color: rgba(255,255,255,.8); padding: 60px 0 28px; }
/* Newsletter w stopce */
.ft-newsletter { display: grid; grid-template-columns: 1fr 1.1fr; gap: 30px; align-items: center;
  background: linear-gradient(120deg, rgba(14,155,176,.22), rgba(233,201,140,.12));
  border: 1px solid rgba(255,255,255,.14); border-radius: 18px; padding: 26px 30px; margin-bottom: 46px; }
.ft-nl-kicker { display:block; color: var(--sand); font-weight:700; font-size:.78rem; letter-spacing:.06em; text-transform:uppercase; }
.ft-newsletter h3 { color:#fff; font-family: var(--font-head); font-size: 1.6rem; margin: 6px 0 6px; }
.ft-newsletter p { margin:0; color: rgba(255,255,255,.75); font-size: .95rem; }
.ft-nl-row { display:flex; gap:10px; }
.ft-nl-row input[type="email"] { flex:1; padding:.8em 1em; border:1px solid rgba(255,255,255,.2); border-radius:10px;
  background: rgba(255,255,255,.08); color:#fff; font:inherit; }
.ft-nl-row input[type="email"]::placeholder { color: rgba(255,255,255,.55); }
.ft-nl-row button { background: var(--ion); color:#fff; border:0; border-radius:10px; padding:.8em 1.3em; font-weight:700; cursor:pointer; white-space:nowrap; }
.ft-nl-row button:hover { background:#11b0c7; } .ft-nl-row button:disabled { opacity:.6; cursor:default; }
.ft-nl-consent { display:flex; gap:8px; align-items:flex-start; margin-top:12px; font-size:.8rem; color:rgba(255,255,255,.7); }
.ft-nl-consent a { display:inline; color: var(--sand); padding:0; }
.ft-nl-msg { margin-top:12px; padding:9px 13px; border-radius:9px; font-size:.9rem; font-weight:600; }
.ft-nl-msg.ok { background: rgba(95,200,130,.18); color:#bff0cf; }
.ft-nl-msg.err { background: rgba(224,96,58,.2); color:#ffc9ba; }
@media (max-width:760px){ .ft-newsletter { grid-template-columns: 1fr; gap:18px; padding:22px; } }
.foot-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 36px; }
.site-foot h4 { color: #fff; font-family: var(--font-body); font-size: .95rem; letter-spacing: .04em;
  text-transform: uppercase; margin: 0 0 14px; }
.site-foot a { display: block; color: rgba(255,255,255,.72); padding: 5px 0; font-size: .92rem; }
.site-foot a:hover { color: var(--sand); }
.site-foot .brand { color: #fff; margin-bottom: 12px; }
.site-foot .brand b { color: var(--sand); }
.foot-about { font-size: .92rem; max-width: 34ch; }
.foot-seller { margin-top: 40px; font-size: .82rem; color: rgba(255,255,255,.6); line-height: 1.6; }
.foot-bottom { border-top: 1px solid rgba(255,255,255,.12); margin-top: 40px; padding-top: 20px;
  display: flex; justify-content: space-between; font-size: .82rem; flex-wrap: wrap; gap: 10px; }
.foot-seller + .foot-bottom { margin-top: 14px; }
.preview-flag { background: var(--coral); color:#fff; font-size:.72rem; font-weight:700; padding:3px 10px; border-radius:999px; }

/* ===== Responsive ===== */
@media (max-width: 900px) {
  .nav { display: none; }
  .nav.open { display: flex; flex-direction: column; align-items: flex-start; gap: 14px;
    position: absolute; top: 70px; left: 0; right: 0; background: #fff; padding: 18px 22px;
    box-shadow: var(--shadow-l); border-top: 1px solid var(--line); }
  .nav.open .dd, .nav.open .dd > summary { width: 100%; }
  .nav.open .dd .dd-menu { position: static; box-shadow: none; border: 0; padding: 4px 0 4px 14px; min-width: 0; }
  .burger { display: block; margin-left: auto; background: none; border: 0; font-size: 1.6rem; cursor: pointer; }
  .regions-grid, .dest-grid, .coll-grid { grid-template-columns: repeat(2, 1fr); }
  .foot-grid { grid-template-columns: 1fr 1fr; }
  .city-grid { grid-template-columns: 1fr; }
  .hero-stats { gap: 24px; flex-wrap: wrap; }
}
@media (max-width: 560px) {
  .regions-grid, .dest-grid, .coll-grid { grid-template-columns: 1fr; }
  .foot-grid { grid-template-columns: 1fr; }
  section { padding: 50px 0; }
}

/* ===== Poznaj kraj (Historia / Kultura / Kuchnia) ===== */
.discover-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.discover-card { display: flex; flex-direction: column; background: #fff; border-radius: var(--radius);
  overflow: hidden; box-shadow: var(--shadow); text-decoration: none; color: inherit; transition: transform .2s, box-shadow .2s; }
.discover-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-l); }
.discover-card .photo { height: 190px; position: relative; background-size: cover; background-position: center; }
.discover-card .photo::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, transparent 45%, rgba(0,0,0,.5)); }
.discover-card .photo .ico { position: absolute; bottom: 12px; left: 16px; z-index: 2; font-size: 2rem;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,.4)); }
.discover-card .body { padding: 18px 20px 22px; display: flex; flex-direction: column; flex: 1; }
.discover-card .body h3 { font-size: 1.3rem; color: var(--deep); margin: 0 0 8px; }
.discover-card .body p { margin: 0 0 14px; color: var(--muted); font-size: .94rem; line-height: 1.55; flex: 1; }
.discover-card .go { color: var(--ion); font-weight: 700; font-size: .92rem; }

/* ===== Przydatne informacje ===== */
.info-band { background: linear-gradient(160deg, #f3f8f9, #e7f1f2); }
.facts-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 14px; }
.fact { background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 14px 16px;
  display: flex; flex-direction: column; gap: 3px; box-shadow: var(--shadow); }
.fact .fk { font-size: .72rem; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); font-weight: 700; }
.fact .fv { font-size: 1.02rem; color: var(--deep); font-weight: 600; }

/* ===== Treść artykułu (Historia / Kultura / Kuchnia / Informacje) ===== */
.prose { font-size: 1.06rem; line-height: 1.8; color: #2b3a3d; }
.prose h2 { font-family: var(--serif, Georgia, serif); font-size: 1.6rem; color: var(--deep); margin: 1.6em 0 .5em; }
.prose h3 { font-size: 1.22rem; color: var(--ion); margin: 1.4em 0 .4em; }
.prose p { margin: 0 0 1.05em; }
.prose ul { margin: 0 0 1.2em; padding-left: 1.2em; }
.prose li { margin-bottom: .4em; }
.prose a { color: var(--ion); }
.prose .src-note { font-size: .82rem; color: var(--muted); font-style: italic; margin-top: 2em; }

/* Panoramy 360° (embedy Street View) w treści */
.pano-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin: 26px 0; }
.pano { position: relative; padding-bottom: 64%; border-radius: 14px; overflow: hidden; box-shadow: var(--shadow); background: #dbe8ea; }
.pano iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
@media (max-width: 700px) { .pano-grid { grid-template-columns: 1fr; } .pano { padding-bottom: 72%; } }

/* Galeria zdjęć w treści (np. kuchnia) */
.content-gallery { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin: 34px 0 10px; }
.content-gallery .cg-item { display: block; height: 200px; border-radius: 14px; background-size: cover;
  background-position: center; box-shadow: var(--shadow); transition: transform .2s, box-shadow .2s; }
.content-gallery .cg-item:hover { transform: translateY(-4px) scale(1.01); box-shadow: var(--shadow-l); }
@media (max-width: 900px) { .content-gallery { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .content-gallery { grid-template-columns: 1fr; } .content-gallery .cg-item { height: 220px; } }
.content-gallery .cg-item, .gal-photo { cursor: zoom-in; }
.content-gallery .cg-item { overflow: hidden; }
.content-gallery .cg-item img { width: 100%; height: 100%; object-fit: cover; display: block; }
.obj-card img.photo { width: 100%; height: 180px; object-fit: cover; display: block; background: #d6e6e9; }

/* ===== Lightbox galerii ===== */
.lb-overlay { position: fixed; inset: 0; z-index: 1000; background: rgba(8,30,35,.93); display: none;
  align-items: center; justify-content: center; }
.lb-overlay.on { display: flex; }
.lb-fig { margin: 0; max-width: 92vw; max-height: 90vh; display: flex; flex-direction: column; align-items: center; gap: 12px; }
.lb-img { max-width: 92vw; max-height: 82vh; border-radius: 10px; box-shadow: 0 18px 50px rgba(0,0,0,.55); object-fit: contain; }
.lb-cap { color: #fff; font-size: .95rem; opacity: .92; text-align: center; }
.lb-close { position: absolute; top: 16px; right: 24px; background: none; border: 0; color: #fff; font-size: 2.6rem;
  line-height: 1; cursor: pointer; }
.lb-nav { position: absolute; top: 50%; transform: translateY(-50%); background: rgba(255,255,255,.12); border: 0;
  color: #fff; font-size: 2.2rem; width: 54px; height: 54px; border-radius: 50%; cursor: pointer; display: flex;
  align-items: center; justify-content: center; }
.lb-prev { left: 20px; } .lb-next { right: 20px; }
.lb-nav:hover, .lb-close:hover { color: var(--sand); background: rgba(255,255,255,.2); }
@media (max-width: 560px) { .lb-nav { width: 42px; height: 42px; font-size: 1.7rem; } .lb-prev { left: 8px; } .lb-next { right: 8px; } }

/* Paginacja krajowych list (/noclegi /atrakcje ...) */
.pager { display: flex; align-items: center; justify-content: center; gap: 18px; margin: 36px 0 6px; }
.pager a { color: var(--ion); font-weight: 700; padding: 9px 18px; border: 1px solid var(--line); border-radius: 10px; }
.pager a:hover { background: var(--bg); border-color: var(--ion); }
.pager-info { color: var(--muted); font-weight: 600; }

@media (max-width: 900px) { .discover-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .discover-grid { grid-template-columns: 1fr; } }
