:root {
  --bg:#0e1726; --bg2:#142544; --card:#16223a; --card2:#1b2a47;
  --accent:#16c79a; --accent-d:#04231b; --text:#e8eef7; --muted:#9fb0c8;
  --border:#243a5c;
}
* { box-sizing: border-box; }
body { margin:0; font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif; background:var(--bg); color:var(--text); line-height:1.5; }
a { color:inherit; }

/* Header */
.site-header { background:linear-gradient(160deg,var(--bg2),var(--bg)); border-bottom:1px solid var(--border); }
.site-header .bar { max-width:1080px; margin:0 auto; padding:16px 20px; display:flex; align-items:center; justify-content:space-between; gap:16px; }
.brand { font-size:1.25rem; font-weight:700; text-decoration:none; white-space:nowrap; }
.brand small { display:block; font-size:.62rem; font-weight:400; color:var(--muted); letter-spacing:.04em; text-transform:uppercase; }
.hero { max-width:1080px; margin:0 auto; padding:28px 20px 8px; text-align:center; }
.hero h1 { margin:0 0 8px; font-size:2rem; }
.hero p { margin:0 0 14px; color:var(--muted); }
.chips { display:flex; flex-wrap:wrap; gap:8px; justify-content:center; max-width:760px; margin:0 auto; }
.chip { display:inline-flex; align-items:center; gap:6px; padding:7px 13px; border-radius:999px; background:var(--card2); border:1px solid var(--border); color:var(--text); text-decoration:none; font-size:.85rem; }
.chip span { color:var(--muted); font-size:.78rem; }
.chip:hover { border-color:var(--accent); }
.section-title { font-size:1.15rem; margin:8px 0 14px; }
.card.deal { border-color:var(--accent); }
.deal-badge { position:absolute; top:10px; left:10px; background:var(--accent); color:var(--accent-d); font-weight:700; font-size:.7rem; padding:3px 9px; border-radius:999px; z-index:2; }

/* Layout */
.wrap { max-width:1080px; margin:0 auto; padding:24px 20px 64px; }

/* Filter form */
form.filter { display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); gap:12px; align-items:end; margin:20px 0 8px; background:var(--card); border:1px solid var(--border); border-radius:14px; padding:16px; }
.filter label { display:flex; flex-direction:column; font-size:.74rem; color:var(--muted); gap:6px; }
.filter input, .filter select { padding:10px 12px; border-radius:8px; border:1px solid var(--border); background:#0f1b30; color:var(--text); font-size:.95rem; width:100%; }
.filter .range { display:flex; gap:6px; }
.filter .range input { width:50%; }
.filter .actions { display:flex; gap:8px; }
.filter button { flex:1; padding:11px 14px; border:0; border-radius:8px; background:var(--accent); color:var(--accent-d); font-weight:700; cursor:pointer; }
.filter a.reset { display:flex; align-items:center; padding:0 12px; border-radius:8px; border:1px solid var(--border); color:var(--muted); text-decoration:none; }

.count { color:var(--muted); margin:18px 2px; font-size:.92rem; }
.count strong { color:var(--text); }

/* Grid + cards */
.grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:18px; }
.card { background:var(--card); border:1px solid var(--border); border-radius:14px; overflow:hidden; display:flex; flex-direction:column; transition:transform .12s ease, border-color .12s ease; }
.card:hover { transform:translateY(-3px); border-color:var(--accent); }
.banner { height:140px; display:flex; align-items:center; justify-content:center; font-size:2.6rem; position:relative; overflow:hidden; }
.banner-emoji { display:flex; align-items:center; justify-content:center; }
.banner .nights { position:absolute; top:10px; right:10px; background:rgba(0,0,0,.45); color:#fff; font-size:.72rem; padding:3px 9px; border-radius:999px; backdrop-filter:blur(2px); }
.card-body { padding:16px; display:flex; flex-direction:column; gap:8px; flex:1; }
.tag { align-self:flex-start; font-size:.68rem; text-transform:uppercase; letter-spacing:.05em; padding:3px 9px; border-radius:999px; background:var(--card2); color:var(--muted); }
.card-body h3 { margin:2px 0 0; font-size:1.1rem; line-height:1.3; }
.card-body h3 a { text-decoration:none; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.card-body h3 a:hover { color:var(--accent); }
.ship { color:var(--text); font-size:.9rem; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.meta { color:var(--muted); font-size:.86rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.price { margin-top:auto; font-size:1.5rem; font-weight:700; color:var(--accent); }
.price small { font-size:.72rem; color:var(--muted); font-weight:400; }
.cta-row { display:flex; gap:8px; }
.btn { text-align:center; text-decoration:none; padding:10px; border-radius:8px; font-weight:600; font-size:.9rem; }
.btn-primary { flex:1; background:var(--accent); color:var(--accent-d); }
.btn-ghost { flex:1; background:var(--card2); color:var(--text); }
.btn-ghost:hover { background:#27497a; }
.btn-primary:hover { filter:brightness(1.08); }

.empty { text-align:center; color:var(--muted); padding:48px 20px; background:var(--card); border:1px solid var(--border); border-radius:14px; }

/* Lapozó */
.pager { display:flex; flex-wrap:wrap; gap:6px; justify-content:center; align-items:center; margin:28px 0 0; }
.pager a, .pager .gap { padding:9px 13px; border-radius:8px; border:1px solid var(--border); color:var(--text); text-decoration:none; font-size:.9rem; background:var(--card); }
.pager a:hover { border-color:var(--accent); }
.pager a.active { background:var(--accent); color:var(--accent-d); font-weight:700; border-color:var(--accent); }
.pager .gap { border:0; background:none; color:var(--muted); padding:9px 4px; }

/* Detail page */
.detail-hero { height:240px; border-radius:16px; position:relative; display:flex; align-items:center; justify-content:center; padding:0; font-size:4rem; overflow:hidden; }
.back { display:inline-block; margin-bottom:14px; color:var(--muted); text-decoration:none; font-size:.9rem; }
.back:hover { color:var(--text); }
.detail-grid { display:grid; grid-template-columns:1fr; gap:24px; margin-top:20px; }
@media (min-width:760px){ .detail-grid { grid-template-columns:1.6fr 1fr; } }
.detail h1 { margin:0 0 6px; }
.detail .sub { color:var(--muted); margin:0 0 16px; }
.detail .lead { font-size:1.05rem; }
.detail .orig-desc { color:var(--muted); font-size:.9rem; }
.highlights { list-style:none; padding:0; margin:16px 0; display:grid; gap:8px; }
.highlights li { padding:10px 12px; background:var(--card); border:1px solid var(--border); border-radius:10px; }
.highlights li::before { content:"✓ "; color:var(--accent); font-weight:700; }
.route { display:flex; flex-wrap:wrap; gap:6px; align-items:center; margin:8px 0 0; }
.route .port { background:var(--card2); padding:5px 10px; border-radius:8px; font-size:.85rem; }
.route .arrow { color:var(--muted); }
.booking-box { background:var(--card); border:1px solid var(--border); border-radius:14px; padding:20px; position:sticky; top:20px; }
.booking-box .big-price { font-size:2.2rem; font-weight:700; color:var(--accent); }
.booking-box .facts { margin:14px 0; display:grid; gap:8px; font-size:.92rem; }
.booking-box .facts div { display:flex; justify-content:space-between; color:var(--muted); }
.booking-box .facts strong { color:var(--text); }
.booking-box .btn-primary { display:block; margin-top:8px; }

footer.site-footer { text-align:center; color:var(--muted); font-size:.8rem; padding:24px; border-top:1px solid var(--border); }
