/* ===== Wakacje 2026 — styl mobile-first ===== */
:root{
  --es:#E63946; --it:#2A9D8F; --hr:#3A86FF;
  --ink:#0f172a; --muted:#52606e; --bg:#f1f5f9; --card:#ffffff;
  --accent:#7c3aed; --good:#16a34a; --gold:#fbbf24;
  --shadow:0 8px 24px rgba(15,23,42,.10);
  --c:var(--accent);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
     color:var(--ink);background:var(--bg);line-height:1.6;font-size:16.5px;-webkit-font-smoothing:antialiased;
     overflow-x:hidden}
img{max-width:100%;display:block}
a{color:var(--accent)}
.wrap{width:100%;max-width:1100px;margin:0 auto;padding:0 16px}
.section{padding:38px 0}
.section.tight{padding-top:0}
h2{font-size:1.5rem;margin-bottom:8px;letter-spacing:-.02em;line-height:1.2}
h2 .sub{display:block;font-size:.9rem;font-weight:500;color:var(--muted);margin-top:6px}
h3{font-size:1.25rem}
p{margin:.5em 0}

/* ===== Top nav (mobile-first, scrollable) ===== */
.topbar{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);
        border-bottom:1px solid #e2e8f0}
.topbar .wrap{display:flex;align-items:center;gap:8px;height:52px}
.topbar .brand{font-weight:800;letter-spacing:-.02em;color:var(--ink);text-decoration:none;font-size:.98rem;
        white-space:nowrap;flex-shrink:0}
.topbar nav{margin-left:auto;display:flex;gap:2px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.topbar nav::-webkit-scrollbar{display:none}
.topbar nav a{color:#334155;text-decoration:none;font-size:.85rem;font-weight:600;padding:8px 11px;
        border-radius:10px;white-space:nowrap;min-height:44px;display:inline-flex;align-items:center}
.topbar nav a.active{background:var(--c);color:#fff}

/* ===== Hero ===== */
.hero{position:relative;color:#fff;text-align:center;padding:48px 18px 52px;overflow:hidden;
      background:linear-gradient(135deg,#1e1b4b 0%,#4c1d95 45%,#be185d 100%)}
.hero.es{background:linear-gradient(135deg,#7a1d27 0%,#b91c1c 50%,#f59e0b 100%)}
.hero.it{background:linear-gradient(135deg,#064e3b 0%,#0d9488 50%,#dc2626 100%)}
.hero.hr{background:linear-gradient(135deg,#0c2a5b 0%,#1d4ed8 50%,#dc2626 100%)}
.hero.photo{background-size:cover;background-position:center}
.hero.photo::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,23,42,.55),rgba(15,23,42,.75))}
.hero::after{content:"";position:absolute;inset:0;
      background:radial-gradient(700px 320px at 80% -10%,rgba(255,255,255,.15),transparent 60%)}
.hero>*{position:relative;z-index:1}
.hero h1{font-size:2rem;font-weight:800;letter-spacing:-.03em;line-height:1.08;text-shadow:0 2px 18px rgba(0,0,0,.25)}
.hero p.lead{font-size:1.02rem;opacity:.95;margin-top:12px;text-shadow:0 1px 10px rgba(0,0,0,.3)}
.hero .flag-xl{font-size:3.2rem}
.flags{font-size:2.2rem;margin:16px 0 6px;letter-spacing:6px}
.badge{display:inline-block;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.28);
       backdrop-filter:blur(6px);padding:7px 15px;border-radius:999px;font-size:.82rem;margin:5px}
.back{display:inline-block;margin-top:16px;color:#fff;text-decoration:none;font-weight:600;
      background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.3);padding:11px 18px;
      border-radius:999px;font-size:.92rem;min-height:44px;line-height:1.5}
.back:active{background:rgba(255,255,255,.3)}

/* ===== Countdown ===== */
.countdown{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:24px}
.cd-box{background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.24);
        border-radius:14px;padding:12px 8px;min-width:72px;backdrop-filter:blur(8px)}
.cd-num{font-size:1.9rem;font-weight:800;line-height:1;font-variant-numeric:tabular-nums}
.cd-lab{font-size:.65rem;text-transform:uppercase;letter-spacing:1.2px;opacity:.85;margin-top:5px}

/* ===== Quick facts (2 cols on mobile) ===== */
.facts{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:-32px;position:relative;z-index:5}
.fact{background:var(--card);border-radius:14px;padding:14px 10px;box-shadow:var(--shadow);text-align:center}
.fact .ico{font-size:1.6rem}
.fact .big{font-size:1.02rem;font-weight:700;margin-top:3px}
.fact .lab{font-size:.76rem;color:var(--muted)}

/* ===== Destination cards (home) ===== */
.dest-grid{display:grid;grid-template-columns:1fr;gap:18px;margin-top:22px}
.dest{background:var(--card);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);
      border-top:5px solid var(--cc);display:flex;flex-direction:column;
      text-decoration:none;color:inherit}
.dest:active{transform:scale(.995)}
.dest-photo{width:100%;height:170px;object-fit:cover}
.dest .head{padding:16px 18px 6px}
.dest .flag{font-size:2.2rem}
.dest h3{font-size:1.35rem;margin:4px 0 2px}
.dest .region{color:var(--muted);font-size:.9rem}
.dest .body{padding:4px 18px 18px;flex:1}
.kv{display:flex;justify-content:space-between;gap:10px;padding:8px 0;border-bottom:1px dashed #e2e8f0;font-size:.92rem}
.kv:last-child{border-bottom:none}
.kv .k{color:var(--muted)} .kv .v{font-weight:600;text-align:right}
.tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}
.tag{background:#f1f5f9;border-radius:8px;padding:4px 9px;font-size:.76rem;color:#334155}
.pill{display:inline-block;color:#fff;background:var(--cc,var(--c));font-size:.7rem;font-weight:700;
      padding:3px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.5px}
.dest .more{padding:0 18px 18px;font-weight:700;color:var(--cc)}
.dest .more::after{content:" →"}

/* ===== Photo gallery (horizontal scroll-snap) ===== */
.gallery{display:flex;gap:12px;overflow-x:auto;padding:4px 16px 14px;margin:0 -16px;
         scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
.gallery figure{flex:0 0 78%;max-width:300px;scroll-snap-align:start;background:var(--card);
        border-radius:16px;overflow:hidden;box-shadow:var(--shadow)}
.gallery img{width:100%;height:180px;object-fit:cover}
.gallery figcaption{padding:10px 14px;font-size:.9rem;font-weight:600;color:#334155}
.gallery figcaption span{display:block;font-weight:500;color:var(--muted);font-size:.8rem}
.scroll-hint{font-size:.78rem;color:var(--muted);margin:2px 0 0 2px}
.scroll-hint::before{content:"👉 "}

/* ===== Generic card / table ===== */
.card{background:var(--card);border-radius:16px;padding:18px;box-shadow:var(--shadow)}
.card + .card{margin-top:18px}
.grid2{display:grid;grid-template-columns:1fr;gap:16px;margin-top:14px}
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -2px}
table{width:100%;border-collapse:collapse;font-size:.9rem;margin-top:12px;min-width:340px}
th,td{padding:10px 11px;text-align:left;border-bottom:1px solid #e9eef5;vertical-align:top}
th{background:#f8fafc;font-weight:700;font-size:.76rem;text-transform:uppercase;letter-spacing:.4px;color:#475569}
tr:last-child td{border-bottom:none}
td.es{color:var(--es);font-weight:700} td.it{color:var(--it);font-weight:700} td.hr{color:var(--hr);font-weight:700}
tr.sum td{font-weight:800;background:#faf5ff;border-top:2px solid var(--c)}

/* ===== POI (accommodation / attraction) ===== */
.item-list{display:grid;gap:14px;margin-top:16px}
.poi{background:var(--card);border-radius:14px;box-shadow:var(--shadow);padding:16px 16px;border-left:5px solid var(--c)}
.poi h4{font-size:1.08rem;margin-bottom:3px;line-height:1.3}
.poi h4 .rec{display:inline-block;vertical-align:middle}
.poi .addr{color:var(--muted);font-size:.84rem;margin-bottom:8px}
.poi .addr::before{content:"📍 "}
.poi .desc{font-size:.94rem;color:#334155}
.poi .meta{display:flex;flex-wrap:wrap;gap:7px;margin-top:12px;align-items:center}
.chip{font-size:.78rem;font-weight:600;padding:5px 11px;border-radius:999px;background:#f1f5f9;color:#334155}
.chip.cost{background:#ecfdf5;color:#047857}
.chip.age{background:#eff6ff;color:#1d4ed8}
.chip.kid{background:#fdf2f8;color:#be185d}
.rec{font-size:.68rem;font-weight:700;color:#fff;background:var(--good);
     padding:3px 9px;border-radius:999px;text-transform:uppercase;letter-spacing:.4px}
.map-link{display:inline-flex;align-items:center;gap:4px;font-size:.8rem;font-weight:700;
     text-decoration:none;color:#fff;background:var(--c);padding:8px 13px;border-radius:999px;
     min-height:38px;line-height:1}
.map-link:active{filter:brightness(.92)}

/* ===== Plan dzień po dniu ===== */
.day{background:var(--card);border-radius:14px;box-shadow:var(--shadow);padding:14px 16px;
     border-left:5px solid var(--c);margin-top:12px}
.day-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:8px}
.day-num{font-size:.7rem;font-weight:800;color:#fff;background:var(--c);border-radius:8px;padding:3px 8px;flex-shrink:0}
.day-date{font-weight:800;font-size:1.02rem}
.day-date .dow{color:var(--muted);font-weight:600;font-size:.92rem}
.day-tag{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px;
         padding:3px 9px;border-radius:999px;margin-left:auto}
.day-tag.beach{background:#ecfeff;color:#0891b2}
.day-tag.trip{background:#fef3c7;color:#b45309}
.day-tag.travel{background:#ede9fe;color:#6d28d9}
.day-tag.chill{background:#f0fdf4;color:#15803d}
.day-weather{font-size:.82rem;color:#475569;background:#f8fafc;border:1px solid #eef2f7;
             border-radius:9px;padding:6px 10px;margin-bottom:9px}
.day-parts{list-style:none;display:grid;gap:6px;margin:0}
.day-parts li{font-size:.93rem;color:#334155;padding-left:0}
.day-parts li b{color:inherit;font-weight:700}
.ac{display:inline-block;font-size:.7rem;font-weight:700;color:#0369a1;background:#e0f2fe;
    border-radius:6px;padding:1px 7px;white-space:nowrap}
.day-cost{margin-top:9px;font-size:.84rem;font-weight:700;color:#047857;background:#ecfdf5;
          border-radius:9px;padding:7px 10px}
.day-cost span{display:block;font-weight:500;color:#475569;font-size:.78rem;margin-top:2px}

/* ===== Stories ===== */
.story{background:linear-gradient(135deg,#fffbeb,#fef3c7);border-radius:14px;padding:16px 16px;
       border-left:5px solid var(--gold);margin-top:14px}
.story h4{font-size:1.05rem;margin-bottom:6px}
.story h4::before{content:"📖 "}
.story p{font-size:.94rem;color:#3f3a1f}

/* ===== Timeline ===== */
.tl{margin-top:18px;border-left:3px solid #e2e8f0;padding-left:20px}
.tl .item{position:relative;padding:0 0 20px 6px}
.tl .item::before{content:"";position:absolute;left:-29px;top:3px;width:13px;height:13px;border-radius:50%;
      background:var(--c);box-shadow:0 0 0 4px #ede9fe}
.tl .when{font-weight:800;color:var(--c)}
.tl .what{color:#334155}

/* ===== Checklist (1 col mobile) ===== */
.checks{columns:1;margin-top:12px;list-style:none}
.checks li{padding:7px 0 7px 26px;position:relative;font-size:.94rem}
.checks li::before{content:"⚡";position:absolute;left:0;top:7px;font-size:.85rem}

/* ===== Decision / CTA ===== */
.decision{background:linear-gradient(135deg,#0f172a,#312e81);color:#fff;border-radius:18px;
          padding:30px 18px;text-align:center;margin-top:24px}
.decision h2{color:#fff}
.decision .date{font-size:1.6rem;font-weight:800;margin:10px 0;color:var(--gold)}
.vote{display:flex;flex-direction:column;gap:10px;margin-top:18px}
.vote button{font:inherit;font-weight:700;border:none;cursor:pointer;color:#fff;padding:15px 20px;
      border-radius:13px;font-size:1.05rem;min-height:52px}
.vote button:active{filter:brightness(.92)}
.vote .b-es{background:var(--es)} .vote .b-it{background:var(--it)} .vote .b-hr{background:var(--hr)}
#voteMsg{margin-top:16px;font-size:1.02rem;min-height:1.4em;font-weight:600}

/* ===== Callout ===== */
.callout{background:#eff6ff;border:1px solid #bfdbfe;border-radius:13px;padding:14px 15px;margin-top:14px;font-size:.92rem}
.callout.warn{background:#fff7ed;border-color:#fed7aa}
.callout b{color:var(--ink)}

footer{text-align:center;color:var(--muted);font-size:.84rem;padding:32px 18px 50px}
.note{font-size:.82rem;color:var(--muted);margin-top:10px}

/* ===== Tablet / desktop enhancements ===== */
@media(min-width:600px){
  body{font-size:17px}
  .section{padding:52px 0}
  .wrap{padding:0 20px}
  h2{font-size:2rem}
  .hero{padding:70px 20px 62px}
  .hero h1{font-size:3rem}
  .hero p.lead{font-size:1.22rem}
  .hero .flag-xl{font-size:4.6rem}
  .flags{font-size:3rem;letter-spacing:8px}
  .facts{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-top:-42px}
  .cd-box{min-width:92px;padding:15px 11px}
  .cd-num{font-size:2.6rem}
  .grid2{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px}
  .card{padding:26px}
  .gallery figure{flex-basis:300px}
  .vote{flex-direction:row;gap:14px;justify-content:center;flex-wrap:wrap}
  .vote button{padding:14px 26px}
  .checks{columns:2;column-gap:30px}
  .checks li{break-inside:avoid}
}
@media(min-width:780px){
  .dest-grid{grid-template-columns:repeat(3,1fr)}
  .dest-photo{height:150px}
  .decision{padding:38px 28px}
  .decision .date{font-size:2.2rem}
}

/* ===== Flagi rysowane CSS (działają bez fontu emoji) ===== */
.flg{display:inline-block;width:1.5em;height:1.05em;border-radius:3px;vertical-align:-.15em;
     border:1px solid rgba(0,0,0,.18);box-shadow:0 1px 2px rgba(0,0,0,.18)}
.flg.es{background:linear-gradient(#c60b1e 0 27%,#ffc400 27% 73%,#c60b1e 73%)}
.flg.it{background:linear-gradient(90deg,#009246 0 33.34%,#fff 33.34% 66.67%,#ce2b37 66.67%)}
.flg.hr{background:linear-gradient(#ff0000 0 33.34%,#fff 33.34% 66.67%,#171796 66.67%)}
.flg.bg{background:linear-gradient(#fff 0 33.34%,#00966e 33.34% 66.67%,#d62612 66.67%)}
.flg.eg{background:linear-gradient(#ce1126 0 33.34%,#fff 33.34% 66.67%,#000 66.67%)}
.flg.gr{background:linear-gradient(#0d5eaf 0 20%,#fff 20% 40%,#0d5eaf 40% 60%,#fff 60% 80%,#0d5eaf 80%)}
.flg.tn{background:radial-gradient(circle at 50% 50%,#fff 0 20%,#e70013 20%)}
.flg.al{background:#b01e26}
.flg.tr{background:radial-gradient(circle at 44% 50%,#fff 0 19%,#e30a17 19%)}
.flags .flg{width:2.6em;height:1.8em;margin:0 5px;border-radius:5px;vertical-align:middle}
.dest .flag .flg{width:2.6em;height:1.8em;border-radius:5px}
.topbar nav a .flg{width:1.35em;height:.95em;margin-right:3px}
th .flg{margin-right:4px}
/* duża flaga w hero podstrony */
.flag-xl{display:inline-block!important;width:3.8em;height:2.6em;border-radius:9px;
   border:2px solid rgba(255,255,255,.65);box-shadow:0 5px 16px rgba(0,0,0,.3);margin:0 auto 8px;font-size:1.2rem}
.flag-xl.es{background:linear-gradient(#c60b1e 0 27%,#ffc400 27% 73%,#c60b1e 73%)}
.flag-xl.it{background:linear-gradient(90deg,#009246 0 33.34%,#fff 33.34% 66.67%,#ce2b37 66.67%)}
.flag-xl.hr{background:linear-gradient(#ff0000 0 33.34%,#fff 33.34% 66.67%,#171796 66.67%)}

/* ===== Pogoda na żywo ===== */
.live-weather{display:inline-block;margin:16px auto 0;background:rgba(255,255,255,.16);
   border:1px solid rgba(255,255,255,.32);border-radius:999px;padding:10px 18px;font-size:.92rem;
   backdrop-filter:blur(6px);color:#fff}
.live-weather .lw-val{font-weight:700}
.live-weather a{color:#fff;text-decoration:underline}
.lw-card{margin:8px 0 0;font-size:.86rem;color:#475569;font-weight:600}
.lw-card .lw-val{color:var(--cc,var(--accent))}

/* ===== Linkowanie: tytuły POI i galeria ===== */
.poi h4 a{color:inherit;text-decoration:none;border-bottom:1.5px dotted rgba(0,0,0,.22)}
.poi h4 a:hover{border-bottom-style:solid}
.gallery-link{display:block;color:inherit;text-decoration:none}

/* ===== Wstążka trasy (multi-stop) ===== */
.route{display:flex;gap:6px;overflow-x:auto;padding:12px 16px;margin:0 -16px 4px;align-items:stretch;
       -webkit-overflow-scrolling:touch;scrollbar-width:thin}
.route .stop{flex:0 0 auto;background:var(--card);border-radius:13px;box-shadow:var(--shadow);
       padding:9px 13px;font-size:.9rem;font-weight:700;min-width:90px;border-top:4px solid var(--c)}
.route .stop b{display:block;font-size:.68rem;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.4px;margin-bottom:2px}
.route .stop.base{border-top-color:var(--gold);background:linear-gradient(180deg,#fffbeb,#fff)}
.route .stop small{display:block;font-weight:600;color:var(--muted);font-size:.74rem;margin-top:2px}
.route .arrow{flex:0 0 auto;align-self:center;color:var(--muted);font-size:1.1rem}

/* ===== Dzień: zintegrowany nocleg + atrakcje ===== */
.day-stay{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:.9rem;
   background:linear-gradient(180deg,#faf5ff,#fff);border:1px solid #ede9fe;border-radius:11px;padding:9px 12px;margin-bottom:10px}
.day-stay .ds-ico{font-size:1.1rem}
.day-stay a{font-weight:700;color:var(--c);text-decoration:none;border-bottom:1.5px dotted var(--c)}
.day-stay .ds-cost{margin-left:auto;font-size:.8rem;font-weight:700;color:#047857;background:#ecfdf5;border-radius:999px;padding:3px 10px;white-space:nowrap}
.day-stay .ds-nav{flex-shrink:0;font-size:.76rem;font-weight:700;text-decoration:none;color:#fff;background:var(--c);
   padding:6px 11px;border-radius:999px;white-space:nowrap;display:inline-flex;align-items:center;gap:3px;min-height:30px}
.day-stay .ds-nav:active{filter:brightness(.92)}
.day-pois{display:grid;gap:8px;margin-top:10px}
.day-poi{display:flex;align-items:center;gap:9px;text-decoration:none;color:inherit;
   background:#f8fafc;border:1px solid #eef2f7;border-radius:12px;padding:10px 12px;font-size:.92rem;transition:border-color .12s,transform .12s}
.day-poi:hover{border-color:var(--c);transform:translateX(2px)}
.day-poi .pico{font-size:1.2rem;flex-shrink:0}
.day-poi .pbody{flex:1;min-width:0}
.day-poi .pname{font-weight:700}
.day-poi .pdesc{font-size:.8rem;color:var(--muted)}
.day-poi .pcost{font-size:.78rem;font-weight:700;color:#047857;background:#ecfdf5;border-radius:999px;padding:3px 9px;white-space:nowrap;flex-shrink:0}
.day-poi .pac{font-size:.66rem;font-weight:700;color:#0369a1;background:#e0f2fe;border-radius:5px;padding:1px 6px;margin-left:4px}
.day-poi .pmap{flex-shrink:0;color:var(--muted);font-size:1rem}
.day-poi .pwhere{font-size:.76rem;color:var(--muted);margin-top:2px}

/* ===== Zdjęcie w dniu + wyróżniona baza 6 nocy ===== */
.day-photo{width:100%;height:180px;object-fit:cover;border-radius:12px;margin:0 0 11px;display:block}
.day-stay.base{background:linear-gradient(180deg,#fff7ed,#fff);border-color:#fdba74}
.basetag{display:inline-block;font-size:.64rem;font-weight:800;color:#fff;background:#b45309;
  padding:2px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.4px;margin-right:5px;vertical-align:1px}
.basecard{border-left:6px solid #f59e0b;background:linear-gradient(180deg,#fffbeb,#fff)}
.basecard h2{margin-bottom:12px}
.basecard .day-stay{margin-bottom:8px}

/* ===== Ciekawostka w dniu (rozwijana) ===== */
.day-story{margin-top:10px;border:1px solid #fde68a;background:#fffbeb;border-radius:10px;overflow:hidden}
.day-story summary{cursor:pointer;font-weight:700;font-size:.86rem;color:#92400e;padding:10px 12px;list-style:none}
.day-story summary::-webkit-details-marker{display:none}
.day-story summary::before{content:"▸ "}
.day-story[open] summary::before{content:"▾ "}
.day-story p{padding:0 12px 11px;font-size:.9rem;color:#3f3a1f;margin:0}

/* ===== UX: klikalna wstążka, kotwice dni, do góry ===== */
.route a.stop{text-decoration:none;color:inherit;cursor:pointer;transition:box-shadow .12s,transform .12s}
.route a.stop:hover{box-shadow:0 9px 22px rgba(0,0,0,.15);transform:translateY(-2px)}
.day{scroll-margin-top:64px}
#toTop{position:fixed;left:14px;bottom:14px;z-index:60;width:46px;height:46px;border-radius:50%;border:none;
  background:rgba(15,23,42,.8);color:#fff;font-size:1.25rem;cursor:pointer;display:none;align-items:center;justify-content:center;
  box-shadow:0 6px 18px rgba(0,0,0,.3);backdrop-filter:blur(4px)}
#toTop.show{display:flex}
.day-photo{box-shadow:0 4px 14px rgba(15,23,42,.12)}

/* ===================================================================
   CZYSTY PLAN v2 — przejrzysty, mobile-first, zwijane dni
   =================================================================== */
.planbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin:10px 0 14px}
.planbar button{background:#f1f5f9;color:#334155;border:1px solid #e2e8f0;border-radius:10px;
   padding:10px 13px;font:inherit;font-weight:700;font-size:.85rem;cursor:pointer;min-height:42px}
.planbar button.primary{background:var(--c);color:#fff;border-color:var(--c)}

/* baza 6 nocy — wyraźna linia */
.base-line{display:flex;align-items:center;gap:9px;flex-wrap:wrap;background:linear-gradient(180deg,#fffbeb,#fff);
   border:1px solid #fde68a;border-left:6px solid #f59e0b;border-radius:12px;padding:12px 14px;margin:12px 0}
.base-line .bl-h{font-weight:800;font-size:.95rem}
.base-line a{color:var(--c);font-weight:700;text-decoration:none}
.base-line .bl-cost{margin-left:auto;font-weight:800;color:#b45309;white-space:nowrap}
.base-line .nav{display:inline-block;background:var(--c);color:#fff;text-decoration:none;border-radius:8px;
   padding:6px 11px;font-size:.8rem;font-weight:700;min-height:34px;line-height:22px}

/* dzień (zwijany) */
.day2{background:var(--card);border:1px solid #e6eaf0;border-radius:14px;margin-bottom:10px;overflow:hidden;
   box-shadow:0 1px 3px rgba(15,23,42,.06);scroll-margin-top:64px}
.day2>summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:9px;padding:14px;flex-wrap:wrap}
.day2>summary::-webkit-details-marker{display:none}
.day2>summary::before{content:"▸";color:var(--muted);flex-shrink:0;font-size:.85rem}
.day2[open]>summary::before{content:"▾"}
.day2[open]>summary{border-bottom:1px solid #eef2f7}
.day2 .dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.dot.travel{background:#8b5cf6}.dot.beach{background:#06b6d4}.dot.trip{background:#f59e0b}.dot.chill{background:#22c55e}.dot.transfer{background:#6366f1}
.d-n{font-weight:800;font-size:.95rem;flex-shrink:0}
.d-date{color:var(--muted);font-size:.85rem;flex-shrink:0}
.d-place{font-weight:600;font-size:.92rem;flex:1 1 120px;min-width:0}
.d-cost{font-weight:800;color:#047857;background:#ecfdf5;border-radius:999px;padding:4px 11px;font-size:.83rem;white-space:nowrap}
.d-body{padding:13px 14px 15px}
.d-photo2{width:100%;height:160px;object-fit:cover;border-radius:10px;margin-bottom:12px;display:block}
.d-meta{font-size:.9rem;color:#334155;background:#f8fafc;border:1px solid #eef2f7;border-radius:10px;padding:10px 12px;margin-bottom:13px}
.d-meta .row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.d-meta .row + .row{margin-top:7px;padding-top:7px;border-top:1px solid #eef2f7}
.d-meta a{color:var(--c);font-weight:700}
.d-meta .nav{display:inline-flex;align-items:center;gap:3px;background:var(--c);color:#fff;text-decoration:none;
   border-radius:8px;padding:6px 11px;font-size:.78rem;font-weight:700;margin-left:auto;min-height:32px}
.d-sub{font-size:.74rem;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin:0 0 8px}
.d-plan{list-style:none;display:grid;gap:8px;margin:0 0 15px}
.d-plan li{font-size:.94rem;color:#334155}
.d-plan li b{color:var(--c);margin-right:5px}

/* atrakcja (zwijana — klik = pełne szczegóły) */
.a{border:1px solid #e6eaf0;border-radius:11px;margin-bottom:7px;background:#fff}
.a>summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:9px;padding:12px;min-height:46px}
.a>summary::-webkit-details-marker{display:none}
.a .a-ico{font-size:1.15rem;flex-shrink:0}
.a .a-name{font-weight:600;font-size:.93rem;flex:1;min-width:0}
.a .a-cost{font-size:.8rem;font-weight:800;color:#047857;white-space:nowrap;flex-shrink:0}
.a .a-cost.free{color:#0369a1}
.a>summary::after{content:"▸";color:var(--muted);flex-shrink:0;margin-left:2px}
.a[open]>summary::after{content:"▾"}
.a-body{padding:0 12px 13px;border-top:1px solid #f1f5f9;margin-top:2px}
.a-body p{margin:9px 0;font-size:.91rem;color:#334155}
.a-addr{color:var(--muted);font-size:.85rem}
.a-link{display:inline-flex;align-items:center;gap:5px;background:var(--c);color:#fff!important;text-decoration:none;
   border-radius:9px;padding:10px 14px;font-weight:700;font-size:.88rem;min-height:42px}
.a-tags{font-size:.8rem;color:var(--muted)}
.a-fullcost{font-size:.82rem;color:var(--muted)}

/* kategorie zamiast ikon (mniej ikonek, więcej koloru) */
.a-cat{font-size:.64rem;font-weight:800;text-transform:uppercase;letter-spacing:.5px;padding:4px 9px;border-radius:6px;flex-shrink:0}
.cat-beach{background:#cffafe;color:#0e7490}.cat-water{background:#ffedd5;color:#c2410c}
.cat-nature{background:#dcfce7;color:#15803d}.cat-culture{background:#ede9fe;color:#6d28d9}
.cat-town{background:#fce7f3;color:#be185d}.cat-food{background:#fef9c3;color:#854d0e}.cat-other{background:#e2e8f0;color:#475569}
.a.b-beach{border-left:4px solid #06b6d4}.a.b-water{border-left:4px solid #f97316}.a.b-nature{border-left:4px solid #22c55e}
.a.b-culture{border-left:4px solid #8b5cf6}.a.b-town{border-left:4px solid #ec4899}.a.b-food{border-left:4px solid #eab308}.a.b-other{border-left:4px solid #94a3b8}
.a-desc{font-size:.93rem;color:#334155;margin:11px 0}
.a-facts{margin:0 0 11px;display:grid;gap:7px}
.a-facts > div{display:grid;grid-template-columns:92px 1fr;gap:8px;font-size:.88rem;align-items:start}
.a-facts dt{color:var(--muted);font-weight:800;margin:0;text-transform:uppercase;font-size:.7rem;letter-spacing:.4px;padding-top:1px}
.a-facts dd{margin:0;color:#334155}
.a-facts .muted{color:var(--muted);font-size:.82rem}
/* dzień: lewy akcent koloru wg typu */
.day2.t-travel{border-left:5px solid #8b5cf6}.day2.t-beach{border-left:5px solid #06b6d4}
.day2.t-trip{border-left:5px solid #f59e0b}.day2.t-chill{border-left:5px solid #22c55e}.day2.t-transfer{border-left:5px solid #6366f1}

.d-total{margin-top:14px;font-weight:800;color:#047857;background:#ecfdf5;border:1px solid #d1fae5;border-radius:11px;padding:11px 13px;font-size:.92rem}
.d-total small{display:block;font-weight:500;color:#475569;font-size:.79rem;margin-top:3px}
.day-note2{margin-top:12px}

/* ===== Oś czasu dnia (pory + miejsca) ===== */
.d-timeline{display:grid;gap:15px;margin:4px 0 14px}
.slot-time{display:inline-block;font-size:.73rem;font-weight:800;text-transform:uppercase;letter-spacing:.6px;
   color:#fff;padding:5px 12px;border-radius:8px;margin-bottom:9px}
.slot-time.rano{background:#f59e0b}.slot-time.poludnie{background:#0ea5e9}
.slot-time.wieczor{background:#7c3aed}.slot-time.caly{background:#16a34a}
.slot-items{display:grid;gap:7px}
.slot-note{font-size:.91rem;color:#475569;margin:0;padding:9px 12px;background:#f8fafc;border:1px solid #eef2f7;border-radius:10px}
.slot-note a{color:var(--c);font-weight:700}
/* czas zwiedzania w nagłówku atrakcji */
.a>summary{flex-wrap:wrap}
.a-time{font-size:.71rem;font-weight:700;color:#475569;background:#eef2f7;border-radius:6px;padding:3px 8px;white-space:nowrap;flex-shrink:0}
/* ramka „do wyboru" */
.choose{border:2px dashed #f59e0b;border-radius:13px;padding:11px;background:#fffbeb}
.choose-h{font-size:.76rem;font-weight:800;color:#b45309;margin:0 0 9px;text-transform:uppercase;letter-spacing:.4px}
.choose .slot-items{gap:7px}

/* budżet (zwijany) z sumą narastająco */
.budget2{background:var(--card);border:1px solid #e6eaf0;border-radius:14px;overflow:hidden;margin:8px 0 4px}
.budget2>summary{cursor:pointer;list-style:none;padding:15px 14px;font-weight:800;display:flex;gap:10px;align-items:center;font-size:1.02rem}
.budget2>summary::-webkit-details-marker{display:none}
.budget2>summary::before{content:"▸";color:var(--muted);font-weight:400}
.budget2[open]>summary::before{content:"▾"}
.budget2 .grand{margin-left:auto;color:#047857}
.budget2 .b-in{padding:0 14px 14px}
.budget2 table{margin-top:4px}
.budget2 td.run{color:var(--muted);text-align:right;white-space:nowrap}
.budget2 td.amt{text-align:right;font-weight:700;white-space:nowrap}
/* kalkulator budżetu (na żywo) */
.kalk-sec{margin:0 0 14px}
.kalk-h{font-size:.76rem;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin:0 0 7px}
.kalk-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:7px 0;border-bottom:1px solid #f1f5f9;font-size:.9rem}
.kalk-row > span{flex:1;min-width:130px}
.kalk-row small{color:var(--muted);font-weight:500}
.kalk-row input[type=number]{width:90px;border:1.5px solid #ddd6fe;border-radius:8px;padding:7px 9px;font:inherit;font-size:16px}
/* iOS: pola ≥16px nie powodują auto-zoomu przy fokusie */
@media (max-width:640px){ input,select,textarea{font-size:16px} }
.kalk-sub{color:#047857;font-weight:700;white-space:nowrap;min-width:74px;text-align:right}
.kalk-total{margin-top:14px;font-weight:800;font-size:1.1rem;text-align:right;color:#047857;background:#ecfdf5;border:1px solid #d1fae5;border-radius:11px;padding:13px 15px}
.a-pick{width:20px;height:20px;flex-shrink:0;accent-color:#16a34a;cursor:pointer;margin:0}

/* ===== DRUK / PDF ===== */
@media print{
  .topbar,.live-weather,.lw-card,.planbar,#notesToggle,#toTop,.back,.route .arrow,
  .d-meta .nav,.a-link,.note-slot,.day-note2{display:none!important}
  body{font-size:10.5pt;background:#fff}
  .wrap{max-width:100%}
  .hero{background:#fff!important;color:#000!important;padding:8px 0;text-align:left}
  .hero::before,.hero::after,.hero .flag-xl{display:none!important}
  .hero h1{color:#000!important;text-shadow:none}
  .hero p.lead{color:#333!important;text-shadow:none}
  .day2,.a,.budget2,.base-line,.card{box-shadow:none!important;border:1px solid #ccc!important;break-inside:avoid}
  .day2>summary::before,.a>summary::after,.budget2>summary::before{content:""!important}
  .a-body,.d-body,.b-in{display:block!important}
  .d-photo2{max-height:90px}
  a{color:#000!important;text-decoration:none}
  .a-addr{color:#333!important}
}

/* ===== Animacje „wow" ===== */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .55s ease,transform .55s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}
.hero h1{animation:pop .7s ease both}
@keyframes pop{from{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:none}}

/* ===== Notatki (edycja po haśle) ===== */
#notesToggle{position:fixed;right:14px;bottom:14px;z-index:60;background:var(--accent);color:#fff;border:none;
   border-radius:999px;padding:12px 17px;font:inherit;font-weight:700;font-size:.9rem;cursor:pointer;
   box-shadow:0 8px 22px rgba(124,58,237,.45)}
#notesToggle:active{transform:translateY(1px)}
.note-slot{margin-top:10px}
.note-slot.empty{display:none}
.note-label{font-size:.76rem;font-weight:700;color:var(--accent)}
.note-label::before{content:"📝 "}
.note-input{width:100%;min-height:56px;margin-top:5px;border:1.5px solid #ddd6fe;border-radius:11px;
   padding:9px 11px;font:inherit;font-size:.9rem;resize:vertical;background:#fffbeb}
.note-input:focus{outline:none;border-color:var(--accent)}
.note-text{margin-top:5px;font-size:.9rem;background:#fffbeb;border:1px solid #fde68a;border-radius:11px;padding:9px 11px;white-space:pre-wrap}
.note-saved{font-size:.7rem;color:var(--good);margin-top:3px;height:1em}

/* ===== Aktywna lista pakowania ===== */
.pack-head{display:flex;justify-content:flex-end;margin-bottom:8px}
.pack-prog{font-weight:700;color:var(--good);margin-bottom:10px;font-size:.95rem}
.pack-list{list-style:none;display:grid;grid-template-columns:1fr;gap:3px}
@media(min-width:600px){.pack-list{grid-template-columns:1fr 1fr;column-gap:24px}}
.pack-item{display:flex;align-items:center;gap:11px;padding:9px 8px;border-radius:10px;font-size:.96rem}
.pack-item:hover{background:#f8fafc}
.pack-item input[type=checkbox]{width:22px;height:22px;flex-shrink:0;accent-color:var(--good);cursor:pointer}
.pack-item.done .pack-text{text-decoration:line-through;color:var(--muted)}
.pack-text{flex:1;min-width:0}
.pack-text.editable{border-bottom:1px dashed #cbd5e1;outline:none;padding-bottom:1px}
.pack-del{background:#fee2e2;color:#b91c1c;border:none;border-radius:7px;width:28px;height:28px;cursor:pointer;font-weight:700;flex-shrink:0;font-size:.9rem}
.pack-bar{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.pack-add{flex:1;min-width:180px;border:1.5px solid #ddd6fe;border-radius:10px;padding:9px 12px;font:inherit;font-size:.92rem}
.pack-add:focus{outline:none;border-color:var(--accent)}
.pack-btn{background:var(--accent);color:#fff;border:none;border-radius:10px;padding:9px 14px;font:inherit;font-weight:700;cursor:pointer;font-size:.88rem}
.pack-btn.ghost{background:#f1f5f9;color:#334155}

/* ===== Sekcja: wakacje samolotem ===== */
.fly-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:14px;margin-top:12px}
.fly{background:var(--card);border:1px solid #e2e8f0;border-radius:16px;padding:15px 16px;box-shadow:0 2px 10px rgba(2,6,23,.05);display:flex;flex-direction:column}
.fly h3{margin:7px 0 2px;font-size:1.05rem;line-height:1.2}
.fly .sub{color:var(--muted);font-size:.82rem;margin-bottom:9px}
.fly .price{font-size:1.18rem;font-weight:800;color:#047857}
.fly .price small{font-weight:600;color:var(--muted);font-size:.68rem}
.fly .meta{font-size:.82rem;color:#475569;margin:7px 0 0}
.fly .tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:10px}
.fly .tags .tag{background:#eef2ff;color:#3730a3;border-radius:999px;padding:3px 9px;font-size:.72rem;font-weight:600}
.badge-ok{align-self:flex-start;background:#dcfce7;color:#166534;font-size:.72rem;font-weight:800;padding:2px 9px;border-radius:999px}
.badge-pp{align-self:flex-start;background:#fef3c7;color:#92400e;font-size:.72rem;font-weight:800;padding:2px 9px;border-radius:999px}
.fly-h{margin:20px 0 0;font-size:1rem;font-weight:800}

.fly-link{margin-top:11px;display:inline-flex;align-items:center;gap:5px;font-weight:700;font-size:.85rem;
          color:#fff;background:var(--accent);text-decoration:none;min-height:40px;padding:0 14px;border-radius:10px;align-self:flex-start}
.fly-link:active{opacity:.85}
.fly .price{margin-top:2px}

/* ===== Realne oferty (Booking) w kartach lotniczych ===== */
.fly-offers{margin-top:10px;font-size:.85rem}
.fly-offers>summary{cursor:pointer;font-weight:700;color:#fff;background:var(--accent);border-radius:10px;
        padding:9px 13px;min-height:40px;display:flex;align-items:center;list-style:none}
.fly-offers>summary::-webkit-details-marker{display:none}
.fly-offers>summary::before{content:"🏨 "}
.fly-offers[open]>summary{border-radius:10px 10px 0 0}
.fo-row{display:flex;justify-content:space-between;gap:10px;align-items:baseline;padding:8px 4px;border-bottom:1px dashed #e2e8f0}
.fo-row a{font-weight:600;text-decoration:none;color:var(--ink)}
.fo-row a .sc{display:inline-block;background:#1e3a8a;color:#fff;border-radius:6px;padding:1px 6px;font-size:.72rem;font-weight:800;margin-left:5px}
.fo-row .pr{white-space:nowrap;font-weight:800;color:#047857;text-align:right}
.fo-row .pr small{display:block;font-weight:500;color:var(--muted);font-size:.68rem}
.fo-foot{padding:10px 4px 2px;font-weight:700;font-size:.85rem}
.fo-foot a{text-decoration:none;color:var(--accent)}

.fly-plan{display:inline-block;margin:3px 0 7px;font-weight:800;font-size:.86rem;color:#fff;background:var(--accent);
          text-decoration:none;padding:7px 13px;border-radius:10px;min-height:38px}
.fly-plan:active{opacity:.85}
.nav.book{background:#0b6b3a;color:#fff}

/* ===== Rozwijana rozpiska kosztów (góra strony) ===== */
.koszty{margin:14px 0 0;background:var(--card);border-radius:14px;box-shadow:var(--shadow);overflow:hidden}
.koszty>summary{cursor:pointer;font-weight:800;padding:14px 16px;list-style:none;font-size:1rem}
.koszty>summary::-webkit-details-marker{display:none}
.koszty>summary::before{content:"▸ ";color:var(--accent)}
.koszty[open]>summary::before{content:"▾ "}
.kl-in{padding:0 16px 14px}
.kl-day{font-weight:800;font-size:.78rem;color:var(--accent);text-transform:uppercase;letter-spacing:.4px;margin:12px 0 4px;border-top:1px solid #eef2f7;padding-top:10px}
.kl-row{display:flex;gap:10px;align-items:baseline;padding:6px 0;font-size:.9rem;border-bottom:1px dashed #eef2f7}
.kl-n{flex:1 1 44%;font-weight:600}
.kl-w{flex:1 1 36%;color:var(--muted);font-size:.8rem}
.kl-c{flex:0 0 auto;font-weight:800;color:#047857;white-space:nowrap}
.kl-c.free{color:var(--muted);font-weight:600}
.kl-sum{border-top:2px solid var(--c);font-size:1rem;margin-top:4px}

/* ===== Przed wyjazdem (góra strony) ===== */
.przed{margin:14px 0 0;background:linear-gradient(180deg,#fffbeb,#ffffff);border:1px solid #fde68a;border-radius:14px;box-shadow:var(--shadow);overflow:hidden}
.przed>summary{cursor:pointer;font-weight:800;padding:14px 16px;list-style:none;font-size:1rem}
.przed>summary::-webkit-details-marker{display:none}
.przed>summary::before{content:"▾ ";color:#b45309}
.przed:not([open])>summary::before{content:"▸ "}
.pw-in{padding:0 16px 14px}
.pw-h{font-weight:800;font-size:.82rem;color:#b45309;text-transform:uppercase;letter-spacing:.4px;margin:13px 0 4px}
.pw-ul{margin:0 0 4px;padding-left:20px;font-size:.92rem}
.pw-ul li{margin:4px 0}
