  :root{
    --ink:#1B2952;        /* brand navy (design system GPT) */
    --ink-2:#243466;
    --ink-deep:#121C3E;
    --paper:#F2E8D5;      /* cream sepia */
    --paper-2:#E8DCC2;
    --paper-3:#FAF5E8;    /* lighter cream tło */
    --red:#B91C1C;        /* deep crimson z design system */
    --red-deep:#8F1414;
    --gold:#B89058;       /* sepia gold */
    --gold-light:#D4B989;
    --rule:rgba(242,232,213,.18);
    --rule-dark:rgba(27,41,82,.14);
    --shadow: 0 30px 60px -30px rgba(18,28,62,.55);
    --shadow-card: 0 6px 24px -8px rgba(18,28,62,.18);
    --maxw: 1280px;
    --font-serif: "Playfair Display", Georgia, serif;
    --font-body: "Lora", Georgia, serif;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{font-family:var(--font-body);background:var(--paper);color:var(--ink);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
  h1,h2,h3,h4{font-family:var(--font-serif);font-weight:600;line-height:1.05;letter-spacing:-.01em}
  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}

  .topo{position:absolute;inset:0;pointer-events:none;opacity:.10;
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='800' height='800'><g fill='none' stroke='%23F4EBD9' stroke-width='.7' opacity='.55'><path d='M0,180 Q200,80 400,200 T800,160'/><path d='M0,260 Q220,160 420,300 T800,260'/><path d='M0,360 Q200,260 420,400 T800,360'/><path d='M0,460 Q200,360 420,500 T800,460'/><path d='M0,560 Q200,460 420,600 T800,560'/><path d='M0,660 Q200,560 420,700 T800,660'/></g><g fill='%23F4EBD9' opacity='.35'><circle cx='120' cy='220' r='2'/><circle cx='480' cy='320' r='2.5'/><circle cx='680' cy='180' r='1.8'/><circle cx='220' cy='560' r='2'/><circle cx='600' cy='620' r='2.4'/></g></svg>");
  }

  .nav{
    position:fixed;top:0;left:0;right:0;z-index:50;
    padding:18px 36px;display:flex;align-items:center;justify-content:space-between;gap:24px;
    background:transparent;
    backdrop-filter:none;-webkit-backdrop-filter:none;
    border-bottom:1px solid transparent;
    transition:padding .3s, box-shadow .3s, background .3s, backdrop-filter .3s, border-color .3s;
  }
  .nav.scrolled{
    padding:10px 36px;
    background:rgba(250,245,232,.95);
    backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);
    border-bottom-color:rgba(27,41,82,.08);
    box-shadow:0 4px 20px -8px rgba(18,28,62,.16);
  }
  .brand{display:inline-flex;align-items:center;gap:10px;color:var(--ink);font-family:var(--font-serif);line-height:1;letter-spacing:-.005em}
  .brand-pin{
    color:var(--red);width:22px;height:26px;flex-shrink:0;
    filter:drop-shadow(0 1px 2px rgba(0,0,0,.15));
  }
  .brand-pin svg{width:100%;height:100%;display:block}
  .brand-text{font-size:24px;font-weight:600;color:var(--ink);position:relative;padding-bottom:3px}
  .brand-text em{font-family:var(--font-serif);font-style:italic;font-weight:500;color:var(--gold);font-size:18px;margin:0 3px;letter-spacing:.01em}
  .brand-text::after{
    content:"";position:absolute;bottom:0;left:0;right:6%;height:1.5px;
    background:linear-gradient(to right, var(--red), var(--red) 75%, transparent 75%);
    border-radius:2px;
  }
  .nav-links{display:flex;gap:32px;list-style:none}
  .nav-links a{
    color:var(--ink);font-size:15px;font-weight:500;font-family:var(--font-body);
    opacity:.85;transition:all .2s;position:relative;padding:6px 0;
    text-shadow:0 1px 2px rgba(250,245,232,.6);
  }
  .nav.scrolled .nav-links a{text-shadow:none;opacity:.78}
  .nav-links a:hover{opacity:1;color:var(--red)}
  .nav-cta{
    background:var(--red);color:#fff;padding:11px 22px;border-radius:6px;
    font-family:var(--font-body);font-size:14px;font-weight:600;letter-spacing:.01em;
    text-transform:none;transition:all .2s;border:0;
    display:inline-flex;align-items:center;gap:8px;
    box-shadow:0 4px 14px -4px rgba(185,28,28,.5);
  }
  .nav-cta:hover{background:var(--red-deep);transform:translateY(-1px);box-shadow:0 6px 18px -4px rgba(185,28,28,.6)}
  @media(max-width:880px){.nav{padding:14px 20px}.nav-links{display:none}.brand-text{font-size:20px}.brand-text em{font-size:15px}.nav-cta{padding:9px 16px;font-size:13px}
    /* mobile: w stanie transparentnym schowaj tekst brandu — zostaje sama pinezka, żeby nie kolidował z napisem na hero */
    .nav:not(.scrolled) .brand-text{display:none}
    .nav:not(.scrolled) .brand-pin{width:26px;height:32px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}
    .nav.scrolled .brand-text{display:inline}
  }

  .hero{position:relative;background:var(--paper);color:var(--ink);overflow:hidden}
  .hero-art{position:relative;width:100%;display:block;background:var(--paper)}
  .hero-art img{width:100%;height:auto;display:block;max-height:92vh;object-fit:cover;object-position:center}
  .hero-art::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:120px;background:linear-gradient(to bottom, rgba(242,232,213,0), var(--paper))}
  .hero-cta-bar{position:relative;z-index:2;max-width:var(--maxw);margin:-40px auto 0;padding:0 32px 80px;display:grid;grid-template-columns:1fr auto;gap:40px;align-items:end}
  .hero-cta-bar h1{display:none}
  .hero-tagline{font-family:var(--font-serif);font-size:clamp(22px,2.6vw,36px);font-weight:500;line-height:1.2;color:var(--ink);max-width:680px;margin-bottom:14px}
  .hero-tagline em{font-style:italic;color:var(--red)}
  .hero-sub{font-size:17px;color:rgba(27,41,82,.78);max-width:560px;line-height:1.6}
  .eyebrow{font-family:"Special Elite",monospace;font-size:13px;letter-spacing:.32em;text-transform:uppercase;color:var(--red);display:flex;align-items:center;gap:14px;margin-bottom:18px}
  .eyebrow::before{content:"";width:36px;height:1px;background:var(--red)}
  .hero-cta{display:flex;gap:14px;flex-wrap:wrap;flex-shrink:0}
  @media(max-width:880px){.hero-cta-bar{grid-template-columns:1fr;margin-top:-20px}}
  .btn-primary{background:var(--red);color:#fff;padding:18px 32px;border-radius:2px;font-size:14px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;display:inline-flex;align-items:center;gap:12px;transition:all .25s;border:1px solid var(--red);cursor:pointer}
  .btn-primary:hover{background:var(--red-deep);border-color:var(--red-deep);transform:translateY(-2px);box-shadow:0 12px 24px -8px rgba(201,67,58,.45)}
  .btn-ghost{background:transparent;color:var(--ink);padding:18px 32px;border-radius:2px;font-size:14px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;display:inline-flex;align-items:center;gap:10px;transition:all .25s;border:1.5px solid var(--ink);cursor:pointer}
  .btn-ghost:hover{background:var(--ink);color:var(--paper)}
  .arrow{transition:transform .25s}
  .btn-primary:hover .arrow{transform:translateX(4px)}

  .hero-stats{max-width:var(--maxw);margin:0 auto;padding:40px 32px 80px;display:grid;grid-template-columns:repeat(4,1fr);gap:24px;border-top:1px solid var(--rule-dark)}
  .stat{color:var(--ink);padding-top:24px}
  .stat-num{font-family:var(--font-serif);font-size:36px;font-weight:600;color:var(--red);font-style:italic}
  .stat-label{font-size:12px;letter-spacing:.16em;text-transform:uppercase;opacity:.7;margin-top:4px}
  @media(max-width:780px){.hero-stats{grid-template-columns:repeat(2,1fr);padding:24px 32px}}

  .about{padding:120px 32px;position:relative;background:var(--paper)}
  .about-inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:center}
  .about-photo{aspect-ratio:4/5;background:linear-gradient(135deg, rgba(27,41,82,.65), rgba(201,67,58,.45)),repeating-linear-gradient(45deg, var(--ink) 0 20px, var(--ink-2) 20px 40px);position:relative;border-radius:2px;box-shadow:var(--shadow);display:grid;place-items:center;color:var(--paper)}
  .about-photo::after{content:"PHOTO • DAWID";position:absolute;bottom:18px;left:18px;font-family:"Special Elite",monospace;font-size:11px;letter-spacing:.24em;color:var(--paper);opacity:.85}
  .about-photo .ph-icon{font-family:var(--font-serif);font-size:88px;font-style:italic;opacity:.4}
  .about-text .eyebrow{color:var(--red);margin-bottom:20px}
  .about-text .eyebrow::before{background:var(--red)}
  .about-text h2{font-size:clamp(36px,4.5vw,64px);margin-bottom:32px}
  .about-text h2 em{font-style:italic;color:var(--red)}
  .about-text p{font-size:17px;color:rgba(27,41,82,.78);margin-bottom:20px;max-width:580px}
  .about-quote{margin-top:36px;padding:24px 28px;border-left:3px solid var(--red);background:var(--paper-2);font-family:var(--font-serif);font-style:italic;font-size:19px}
  @media(max-width:880px){.about-inner{grid-template-columns:1fr;gap:48px}}

  .tours{position:relative;padding:120px 0 80px;background:var(--ink);color:var(--paper)}
  .tours-head{max-width:var(--maxw);margin:0 auto 80px;padding:0 32px;text-align:center}
  .tours-head .eyebrow{justify-content:center;color:var(--gold)}
  .tours-head .eyebrow::before,.tours-head .eyebrow::after{content:"";width:36px;height:1px;background:var(--gold)}
  .tours-head h2{font-size:clamp(40px,5vw,72px);margin:20px 0 16px}
  .tours-head h2 em{font-style:italic;color:var(--gold)}
  .tours-head p{font-size:17px;opacity:.78;max-width:600px;margin:0 auto}

  .tours-grid{max-width:var(--maxw);margin:0 auto;padding:0 32px;display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--rule)}
  .tour{padding:40px 32px;border-bottom:1px solid var(--rule);border-right:1px solid var(--rule);display:flex;gap:28px;cursor:pointer;transition:background .25s;position:relative}
  .tour:hover{background:var(--ink-2)}
  .tour:nth-child(2n){border-right:none}
  .tour-num{font-family:var(--font-serif);font-style:italic;font-size:64px;font-weight:400;color:var(--gold);opacity:.7;line-height:1;flex-shrink:0;width:80px}
  .tour-body{flex:1;min-width:0}
  .tour h3{font-size:24px;margin-bottom:6px;letter-spacing:-.01em}
  .tour-sub{font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);opacity:.85;margin-bottom:18px}
  .tour-meta{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:18px}
  .tour-meta span{font-size:12px;color:rgba(242,232,213,.7);letter-spacing:.04em}
  .tour-meta span strong{color:var(--paper);font-weight:600}
  .tour-price{font-family:var(--font-serif);font-size:28px;font-weight:600;color:var(--paper);margin-bottom:14px}
  .tour-price small{font-size:14px;opacity:.7;font-weight:400}
  .tour-desc{font-size:14px;color:rgba(242,232,213,.78);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
  .tour-more{display:inline-flex;align-items:center;gap:8px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--red);margin-top:18px;font-weight:600}
  .tour-more::after{content:"→";transition:transform .25s}
  .tour:hover .tour-more::after{transform:translateX(4px)}
  @media(max-width:880px){.tours-grid{grid-template-columns:1fr}.tour:nth-child(n){border-right:none}.tour-num{font-size:48px;width:60px}}

  .detail{display:none;background:var(--ink-2);padding:80px 32px;border-bottom:1px solid var(--rule)}
  .detail.open{display:block}
  .detail-inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1.2fr;gap:60px}
  .detail-img{aspect-ratio:4/3;background:linear-gradient(135deg, rgba(201,67,58,.4), rgba(27,41,82,.7)),repeating-linear-gradient(135deg, var(--ink) 0 14px, var(--ink-2) 14px 28px);border-radius:2px;display:grid;place-items:center;color:var(--paper);position:relative}
  .detail-img::after{content:"PHOTO COMING SOON";position:absolute;bottom:14px;left:14px;font-family:"Special Elite",monospace;font-size:10px;letter-spacing:.24em;opacity:.7}
  .detail-img-num{font-family:var(--font-serif);font-size:84px;font-style:italic;opacity:.4}
  .detail h3{font-size:36px;margin-bottom:8px}
  .detail .tour-sub{margin-bottom:24px}
  .detail-info{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 28px;margin-bottom:28px;padding:20px 0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
  .detail-info div{font-size:13px;color:rgba(242,232,213,.7)}
  .detail-info strong{display:block;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:4px;font-weight:600}
  .detail-section{margin-bottom:24px}
  .detail-section h4{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--red);margin-bottom:14px;font-weight:600;font-family:"Inter",sans-serif}
  .detail-section ul{list-style:none}
  .detail-section li{padding:8px 0;border-bottom:1px solid var(--rule);font-size:14px;color:rgba(242,232,213,.85)}
  .detail-section li::before{content:"◦ ";color:var(--gold);margin-right:8px}
  .detail-desc{margin-bottom:24px;color:rgba(242,232,213,.85);font-size:15px}
  .detail-cta{margin-top:24px;display:flex;gap:14px;flex-wrap:wrap}
  .detail-cta .btn-ghost{border-color:rgba(242,232,213,.4);color:var(--paper)}
  @media(max-width:880px){.detail-inner{grid-template-columns:1fr;gap:32px}.detail-info{grid-template-columns:1fr}}

  .how{padding:120px 32px;background:var(--paper)}
  .how-inner{max-width:var(--maxw);margin:0 auto;text-align:center}
  .how .eyebrow{justify-content:center;color:var(--red);margin-bottom:20px}
  .how .eyebrow::before,.how .eyebrow::after{content:"";width:36px;height:1px;background:var(--red)}
  .how h2{font-size:clamp(36px,4.5vw,56px);margin-bottom:64px}
  .how h2 em{font-style:italic;color:var(--red)}
  .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;text-align:left}
  .step{padding:28px 0;border-top:2px solid var(--ink);position:relative}
  .step-num{font-family:var(--font-serif);font-style:italic;font-size:14px;color:var(--red);font-weight:600;letter-spacing:.04em;margin-bottom:16px}
  .step h3{font-size:20px;margin-bottom:12px;font-family:var(--font-serif)}
  .step p{font-size:14px;color:rgba(27,41,82,.72)}
  @media(max-width:780px){.steps{grid-template-columns:1fr}}

  .cta-band{background:var(--red);color:var(--paper);padding:80px 32px;text-align:center;position:relative;overflow:hidden}
  .cta-band::before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='400' height='400'><g fill='none' stroke='%23F4EBD9' stroke-width='.5' opacity='.25'><circle cx='200' cy='200' r='80'/><circle cx='200' cy='200' r='130'/><circle cx='200' cy='200' r='180'/></g></svg>") center/600px;opacity:.6;pointer-events:none}
  .cta-band-inner{position:relative;max-width:var(--maxw);margin:0 auto}
  .cta-band h2{font-size:clamp(36px,5vw,64px);margin-bottom:20px;font-style:italic}
  .cta-band p{font-size:18px;margin-bottom:36px;opacity:.92;max-width:540px;margin-left:auto;margin-right:auto}
  .cta-band .btn-primary{background:var(--ink);border-color:var(--ink)}
  .cta-band .btn-primary:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}

  footer{background:var(--ink);color:var(--paper);padding:60px 32px 30px}
  .footer-inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;padding-bottom:40px;border-bottom:1px solid var(--rule)}
  footer h4{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:18px;font-weight:600;font-family:"Inter",sans-serif}
  footer ul{list-style:none}
  footer li{padding:6px 0;font-size:14px;opacity:.78}
  footer a:hover{opacity:1;color:var(--gold)}
  .footer-brand p{margin-top:16px;opacity:.7;font-size:14px;max-width:360px}
  .copy{max-width:var(--maxw);margin:30px auto 0;display:flex;justify-content:space-between;align-items:center;font-size:12px;opacity:.7;letter-spacing:.04em}
  .friend-credit{font-family:"Caveat", cursive;font-size:22px;font-style:normal;letter-spacing:.01em;color:var(--paper);opacity:.95;display:inline-flex;align-items:center;gap:8px;line-height:1}
  .friend-text{font-weight:500}
  .friend-heart{width:22px;height:22px;color:var(--red);animation:heart-beat 1.6s ease-in-out infinite;flex-shrink:0;filter:drop-shadow(0 0 4px rgba(185,28,28,.4));transform:rotate(-6deg)}
  @keyframes heart-beat{
    0%,100%{transform:rotate(-6deg) scale(1)}
    15%{transform:rotate(-6deg) scale(1.18)}
    30%{transform:rotate(-6deg) scale(1)}
    45%{transform:rotate(-6deg) scale(1.12)}
  }
  .friend-sign{font-family:"Caveat", cursive;font-style:normal;font-size:26px;color:var(--gold-light);font-weight:600;display:inline-block;transform:rotate(-3deg);letter-spacing:.02em;text-shadow:0 1px 2px rgba(0,0,0,.4)}
  @media(max-width:780px){.footer-inner{grid-template-columns:1fr;gap:32px}.copy{flex-direction:column;gap:10px}}

  .whatsapp{position:fixed;bottom:24px;right:24px;z-index:60;width:60px;height:60px;border-radius:50%;background:#25D366;display:grid;place-items:center;color:#fff;box-shadow:0 12px 30px -8px rgba(37,211,102,.6);transition:all .25s}
  .whatsapp:hover{transform:scale(1.08)}
  .whatsapp svg{width:28px;height:28px}

  .reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease, transform .8s ease}
  .reveal.in{opacity:1;transform:none}

/* ===== TOUR PAGES ===== */
.hero-tour{position:relative;min-height:78vh;display:flex;align-items:flex-end;color:var(--paper);overflow:hidden;background:var(--ink)}
.hero-tour-bg{position:absolute;inset:0;z-index:0}
.hero-tour-bg img{width:100%;height:100%;object-fit:cover;display:block}
.hero-tour-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom, rgba(18,28,62,.30) 0%, rgba(18,28,62,.55) 60%, rgba(18,28,62,.92) 100%)}
.hero-tour-inner{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:160px 32px 60px;width:100%}
.hero-tour-num{font-family:var(--font-serif);font-style:italic;font-size:18px;color:var(--gold);letter-spacing:.16em;margin-bottom:16px}
.hero-tour h1{font-size:clamp(40px,6vw,84px);line-height:1.05;margin-bottom:14px;font-weight:600;letter-spacing:-.02em}
.hero-tour h1 em{font-style:italic;color:var(--gold);font-weight:400}
.hero-tour-sub{font-size:clamp(16px,1.6vw,22px);color:rgba(242,232,213,.86);max-width:680px;margin-bottom:28px}
.hero-tour-back{position:absolute;top:96px;left:32px;z-index:2;color:var(--paper);font-size:13px;letter-spacing:.16em;text-transform:uppercase;opacity:.85;display:inline-flex;align-items:center;gap:8px;transition:opacity .2s}
.hero-tour-back:hover{opacity:1;color:var(--gold)}

.tour-info-bar{background:var(--ink-deep);color:var(--paper);padding:24px 32px}
.tour-info-bar-inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(6,1fr);gap:24px}
.info-cell{font-size:13px;color:rgba(242,232,213,.7)}
.info-cell strong{display:block;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:6px;font-weight:600}
.info-cell .v{font-family:var(--font-serif);font-size:18px;color:var(--paper);font-weight:600}
@media(max-width:880px){.tour-info-bar-inner{grid-template-columns:repeat(2,1fr)}}

.tour-content{background:var(--paper);padding:90px 32px}
.tour-content-inner{max-width:920px;margin:0 auto}
.tour-content p{font-size:18px;color:rgba(27,41,82,.85);line-height:1.75;margin-bottom:22px}
.tour-content p.lead{font-size:22px;font-family:var(--font-serif);font-weight:500;color:var(--ink);margin-bottom:36px;line-height:1.5}
.tour-content h2{font-size:32px;margin:48px 0 24px;color:var(--ink)}
.tour-content h2 em{font-style:italic;color:var(--red)}
.tour-content ul{list-style:none;margin:0 0 32px}
.tour-content ul li{padding:14px 0;border-bottom:1px solid rgba(27,41,82,.10);font-size:17px;color:var(--ink);display:flex;gap:14px;align-items:flex-start}
.tour-content ul li::before{content:"◆";color:var(--red);font-size:14px;margin-top:4px;flex-shrink:0}

.tour-cta-inline{margin:48px 0;padding:36px;background:var(--paper-2);border-left:3px solid var(--red);display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.tour-cta-inline div{flex:1;min-width:240px}
.tour-cta-inline strong{display:block;font-family:var(--font-serif);font-size:24px;color:var(--ink);margin-bottom:6px}
.tour-cta-inline span{font-size:14px;color:rgba(27,41,82,.72)}

/* gallery */
.gallery{background:var(--ink);padding:90px 32px;color:var(--paper)}
.gallery-head{max-width:var(--maxw);margin:0 auto 50px;text-align:center}
.gallery-head .eyebrow{justify-content:center;color:var(--gold)}
.gallery-head .eyebrow::before,.gallery-head .eyebrow::after{content:"";width:36px;height:1px;background:var(--gold)}
.gallery-head h2{font-size:clamp(32px,4vw,52px);margin:14px 0 10px}
.gallery-head h2 em{font-style:italic;color:var(--gold)}
.gallery-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.gallery-grid figure{margin:0;cursor:pointer;overflow:hidden;background:var(--ink-2);aspect-ratio:1}
.gallery-grid img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.gallery-grid figure:hover img{transform:scale(1.06)}
@media(max-width:880px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}

/* lightbox */
.lightbox{position:fixed;inset:0;background:rgba(8,12,28,.96);z-index:100;display:none;align-items:center;justify-content:center;padding:32px}
.lightbox.open{display:flex}
.lightbox img{max-width:100%;max-height:88vh;display:block;box-shadow:0 30px 60px -20px rgba(0,0,0,.7)}
.lb-close{position:absolute;top:24px;right:32px;color:var(--paper);background:transparent;border:1px solid rgba(242,232,213,.4);width:44px;height:44px;border-radius:50%;cursor:pointer;font-size:20px;line-height:1}
.lb-close:hover{background:var(--paper);color:var(--ink)}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:transparent;border:1px solid rgba(242,232,213,.4);color:var(--paper);width:50px;height:50px;border-radius:50%;cursor:pointer;font-size:22px;line-height:1}
.lb-nav:hover{background:var(--paper);color:var(--ink)}
.lb-prev{left:32px}.lb-next{right:32px}
.lb-counter{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);font-family:"Special Elite",monospace;font-size:13px;letter-spacing:.16em;color:var(--paper);opacity:.6}

/* related */
.related{background:var(--paper);padding:90px 32px}
.related-inner{max-width:var(--maxw);margin:0 auto}
.related h2{font-size:clamp(28px,3.5vw,42px);margin-bottom:40px;text-align:center}
.related h2 em{font-style:italic;color:var(--red)}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.related-card{display:block;background:var(--ink);color:var(--paper);overflow:hidden;transition:transform .25s}
.related-card:hover{transform:translateY(-4px)}
.related-card-img{aspect-ratio:4/3;overflow:hidden;background:var(--ink-2)}
.related-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.related-card:hover .related-card-img img{transform:scale(1.05)}
.related-card-body{padding:20px 24px}
.related-card .num{font-family:var(--font-serif);font-style:italic;color:var(--gold);font-size:13px;letter-spacing:.12em;margin-bottom:6px}
.related-card h3{font-size:20px;margin-bottom:6px}
.related-card .meta{font-size:12px;color:rgba(242,232,213,.6);letter-spacing:.04em}
@media(max-width:880px){.related-grid{grid-template-columns:1fr}}

/* tour card with image (home) */
.tour{flex-direction:column;gap:0;padding:0;align-items:stretch;border-right:none}
.tour-thumb{aspect-ratio:16/10;overflow:hidden;background:var(--ink-2);position:relative}
.tour-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;display:block}
.tour:hover .tour-thumb img{transform:scale(1.04)}
.tour-thumb-num{position:absolute;top:18px;left:24px;font-family:var(--font-serif);font-style:italic;font-size:42px;font-weight:400;color:var(--paper);text-shadow:0 2px 12px rgba(0,0,0,.5);z-index:1}
.tour-thumb-num::before{content:"";position:absolute;top:0;left:-24px;width:14px;height:1px;background:var(--gold);top:50%}
.tour-body-wrap{padding:32px 32px 36px}

/* about portrait — real photo */
.about-photo{background:var(--ink-2);overflow:hidden;display:block}
.about-photo img{width:100%;height:100%;object-fit:cover;display:block}
.about-photo .ph-icon{display:none}
.about-photo::after{content:"";display:none}

/* highlights strip on home */
.highlights{background:var(--paper-2);padding:80px 0}
.highlights-head{max-width:var(--maxw);margin:0 auto 40px;padding:0 32px;display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap}
.highlights-head h2{font-size:clamp(28px,3.5vw,44px);max-width:520px}
.highlights-head h2 em{font-style:italic;color:var(--red)}
.highlights-head .eyebrow{color:var(--red);margin-bottom:14px}
.highlights-head .eyebrow::before{background:var(--red)}
.highlights-track{display:grid;grid-auto-flow:column;grid-auto-columns:280px;gap:14px;overflow-x:auto;padding:0 32px 12px;scroll-snap-type:x mandatory;scrollbar-width:thin}
.highlights-track figure{margin:0;aspect-ratio:3/4;overflow:hidden;scroll-snap-align:start;background:var(--ink-2)}
.highlights-track img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.highlights-track figure:hover img{transform:scale(1.05)}


/* ============== HOME LAYOUT (GPT design system) ============== */

/* filters chips */
.filters{max-width:var(--maxw);margin:60px auto 0;padding:0 32px;display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.filter-chip{padding:10px 22px;border:1.5px solid var(--ink);border-radius:30px;background:transparent;color:var(--ink);font-family:var(--font-body);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:8px}
.filter-chip:hover{background:var(--ink);color:var(--paper)}
.filter-chip.active{background:var(--red);border-color:var(--red);color:#fff}
.filter-chip .ico{font-size:14px;opacity:.75}

/* tour card v2 — miniaturka GPT z pinezką */
.tour-card-v2{
  background:var(--paper-3);border:1px solid rgba(27,41,82,.08);border-radius:8px;
  overflow:hidden;display:flex;flex-direction:column;transition:transform .3s ease, box-shadow .3s ease;
  box-shadow:var(--shadow-card);text-decoration:none;color:var(--ink);
}
.tour-card-v2:hover{transform:translateY(-6px);box-shadow:0 20px 40px -12px rgba(18,28,62,.28)}
.tcv2-img{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--ink-2)}
.tcv2-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
.tour-card-v2:hover .tcv2-img img{transform:scale(1.04)}
.tcv2-pin{position:absolute;top:14px;left:14px;width:38px;height:38px;background:var(--red);color:#fff;border-radius:50%;display:grid;place-items:center;font-family:var(--font-serif);font-weight:700;font-size:16px;box-shadow:0 4px 12px rgba(0,0,0,.3);z-index:2}
.tcv2-pin::after{content:"";position:absolute;bottom:-7px;left:50%;transform:translateX(-50%);border:7px solid transparent;border-top-color:var(--red);border-bottom-width:0}
.tcv2-body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.tcv2-body h3{font-family:var(--font-serif);font-size:22px;font-weight:600;line-height:1.15;margin-bottom:6px;color:var(--ink)}
.tcv2-sub{font-family:var(--font-body);font-size:13px;color:rgba(27,41,82,.7);line-height:1.45;margin-bottom:16px;flex:1}
.tcv2-meta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:14px;font-size:12px;color:rgba(27,41,82,.65)}
.tcv2-meta span{display:inline-flex;align-items:center;gap:5px}
.tcv2-foot{display:flex;justify-content:space-between;align-items:center;gap:10px;padding-top:14px;border-top:1px solid rgba(27,41,82,.10)}
.tcv2-price{font-family:var(--font-serif);font-size:22px;font-weight:700;color:var(--red)}
.tcv2-price small{font-size:13px;color:rgba(27,41,82,.6);font-weight:400}
.tcv2-btn{padding:9px 16px;background:var(--ink);color:var(--paper);font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;border-radius:4px;transition:background .2s}
.tour-card-v2:hover .tcv2-btn{background:var(--red)}

.tours-grid-v2{
  max-width:1600px;margin:50px auto 0;padding:0 48px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:32px;
}
.tcv2-body h3{font-size:26px;line-height:1.18}
.tcv2-sub{font-size:14px}
.tcv2-price{font-size:30px}
.tcv2-meta{font-size:13px}
@media(max-width:880px){.tours-grid-v2{grid-template-columns:repeat(2,1fr);gap:18px;padding:0 24px}.tcv2-body h3{font-size:22px}.tcv2-price{font-size:26px}}
@media(max-width:520px){.tours-grid-v2{grid-template-columns:1fr}}

/* WHY US — 4 ikony */
.why-us{padding:100px 32px;background:var(--paper-3)}
.why-inner{max-width:var(--maxw);margin:0 auto;text-align:center}
.why-inner > .eyebrow{justify-content:center;color:var(--red);margin-bottom:20px}
.why-inner > .eyebrow::before,.why-inner > .eyebrow::after{content:"";width:36px;height:1px;background:var(--red)}
.why-inner > h2{font-size:clamp(32px,4vw,48px);margin-bottom:50px;font-family:var(--font-serif);color:var(--ink)}
.why-inner > h2 em{font-style:italic;color:var(--red)}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:36px;text-align:center}
.why-item{display:flex;flex-direction:column;align-items:center;gap:14px}
.why-icon{width:72px;height:72px;border-radius:50%;background:var(--paper-2);display:grid;place-items:center;color:var(--red);margin-bottom:8px}
.why-icon svg{width:36px;height:36px;stroke-width:1.5}
.why-item h3{font-family:var(--font-serif);font-size:19px;color:var(--ink);font-weight:600}
.why-item p{font-size:14px;color:rgba(27,41,82,.7);max-width:240px;line-height:1.55}
@media(max-width:780px){.why-grid{grid-template-columns:repeat(2,1fr);gap:32px}}

/* about v2 — z prawdziwym zdjęciem */
.about-v2{padding:100px 32px;background:var(--paper)}
.about-v2-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:.9fr 1.2fr;gap:64px;align-items:center}
.about-v2-photo{aspect-ratio:4/5;overflow:hidden;border-radius:6px;box-shadow:var(--shadow);background:var(--ink-2)}
.about-v2-photo img{width:100%;height:100%;object-fit:cover;display:block}
.about-v2-text .eyebrow{color:var(--red);margin-bottom:18px}
.about-v2-text .eyebrow::before{background:var(--red)}
.about-v2-text h2{font-family:var(--font-serif);font-size:clamp(34px,4.5vw,56px);color:var(--ink);margin-bottom:26px;line-height:1.05}
.about-v2-text h2 em{font-style:italic;color:var(--red)}
.about-v2-text p{font-size:17px;color:rgba(27,41,82,.82);line-height:1.7;margin-bottom:18px;max-width:560px}
.about-v2-quote{margin-top:30px;padding:24px 28px;border-left:3px solid var(--red);background:var(--paper-2);font-family:var(--font-serif);font-style:italic;font-size:20px;color:var(--ink);line-height:1.5}
.about-sign{display:flex;align-items:center;gap:14px;margin-top:24px}
.about-sign-name{font-family:var(--font-serif);font-style:italic;font-size:24px;color:var(--ink)}
.about-sign-role{font-size:13px;color:rgba(27,41,82,.6);letter-spacing:.06em;text-transform:uppercase}
@media(max-width:880px){.about-v2-inner{grid-template-columns:1fr;gap:40px}}

/* opinions */
.opinions{padding:100px 32px;background:var(--paper-3)}
.opinions-inner{max-width:var(--maxw);margin:0 auto}
.opinions-head{text-align:center;margin-bottom:50px}
.opinions-head .eyebrow{justify-content:center;color:var(--red);margin-bottom:14px}
.opinions-head .eyebrow::before,.opinions-head .eyebrow::after{content:"";width:36px;height:1px;background:var(--red)}
.opinions-head h2{font-family:var(--font-serif);font-size:clamp(32px,4vw,48px);color:var(--ink)}
.opinions-head h2 em{font-style:italic;color:var(--red)}
.opinions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.opinion{background:var(--paper);padding:28px 26px;border-radius:6px;box-shadow:var(--shadow-card);position:relative}
.opinion::before{content:"❝";position:absolute;top:12px;right:24px;font-family:var(--font-serif);font-size:64px;color:var(--gold-light);line-height:1;opacity:.6}
.opinion-stars{color:var(--red);font-size:14px;margin-bottom:14px;letter-spacing:2px}
.opinion-text{font-family:var(--font-body);font-size:15px;color:var(--ink);line-height:1.65;margin-bottom:18px;position:relative;z-index:1}
.opinion-author{display:flex;align-items:center;gap:12px;border-top:1px solid rgba(27,41,82,.10);padding-top:14px}
.opinion-avatar{width:42px;height:42px;border-radius:50%;background:var(--paper-2);display:grid;place-items:center;color:var(--red);font-family:var(--font-serif);font-weight:700;font-size:18px;flex-shrink:0}
.opinion-author-info strong{font-family:var(--font-serif);font-size:15px;color:var(--ink);font-weight:600;display:block;line-height:1.2}
.opinion-author-info span{font-size:12px;color:rgba(27,41,82,.6)}
@media(max-width:880px){.opinions-grid{grid-template-columns:1fr}}

/* footer v2 z newsletterem */
.footer-newsletter{display:flex;gap:8px;margin-top:14px}
.footer-newsletter input{flex:1;padding:10px 14px;border:1px solid rgba(242,232,213,.25);background:transparent;color:var(--paper);font-family:var(--font-body);font-size:13px;border-radius:3px}
.footer-newsletter input::placeholder{color:rgba(242,232,213,.5)}
.footer-newsletter button{padding:10px 18px;background:var(--red);color:#fff;border:0;font-family:var(--font-body);font-size:13px;font-weight:600;letter-spacing:.04em;cursor:pointer;border-radius:3px;transition:background .2s}
.footer-newsletter button:hover{background:var(--red-deep)}


/* nav variant for tour pages — always dark backdrop */
.nav.on-tour{
  background:rgba(18,28,62,.55);
  backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom-color:rgba(242,232,213,.10);
}
.nav.on-tour.scrolled{background:rgba(18,28,62,.85);box-shadow:0 4px 20px -8px rgba(0,0,0,.35)}
.nav.on-tour .brand-text{color:var(--paper)}
.nav.on-tour .brand-text em{color:var(--gold-light)}
.nav.on-tour .brand-pin{color:var(--red)}
.nav.on-tour .nav-links a{color:var(--paper);opacity:.85;text-shadow:none}
.nav.on-tour .nav-links a:hover{color:var(--gold-light);opacity:1}

/* hero-tour-back — improved readability */
.hero-tour-back{
  position:absolute;top:96px;left:32px;z-index:3;
  color:var(--paper);font-family:var(--font-body);font-size:13px;
  letter-spacing:.14em;text-transform:uppercase;font-weight:500;
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;background:rgba(18,28,62,.45);border:1px solid rgba(242,232,213,.25);border-radius:30px;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  transition:all .2s;
}
.hero-tour-back:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}

/* ===== AUDIO TOGGLE — sticky bottom-left z animowanym equalizerem ===== */
/* Audio toggle — wersja dla niesłyszących (dostępność). Lampka świeci gdy gra. */
.audio-toggle{
  position:fixed;bottom:24px;left:24px;z-index:60;
  background:linear-gradient(135deg, var(--ink) 0%, var(--ink-2) 100%);color:var(--paper);
  padding:13px 20px 13px 16px;border-radius:32px;
  display:inline-flex;align-items:center;gap:12px;
  border:1.5px solid var(--gold-light);cursor:pointer;
  box-shadow:0 12px 32px -8px rgba(18,28,62,.6), 0 0 0 4px rgba(212,185,137,.15);
  font-family:var(--font-body);font-size:13px;font-weight:600;letter-spacing:.02em;
  transition:all .25s;
}
.audio-toggle:hover{background:linear-gradient(135deg, var(--red) 0%, var(--red-deep) 100%);border-color:var(--gold);transform:translateY(-2px);box-shadow:0 16px 36px -8px rgba(185,28,28,.55), 0 0 0 5px rgba(212,185,137,.2)}
/* Gdy gra: pulsujący red glow ring + zielona lampka */
.audio-toggle:not(.paused){
  border-color:#4ade80;
  box-shadow:0 12px 32px -8px rgba(18,28,62,.6), 0 0 0 4px rgba(74,222,128,.2), 0 0 24px rgba(74,222,128,.35)
}

/* LAMPKA — czerwona (off) → zielona pulsująca (gra) */
.audio-toggle .audio-light{
  width:10px;height:10px;border-radius:50%;flex-shrink:0;
  background:#dc2626;
  box-shadow:0 0 6px rgba(220,38,38,.6), inset 0 0 2px rgba(0,0,0,.3);
  transition:all .35s;
  position:relative;
}
.audio-toggle.paused .audio-light{background:#dc2626}
.audio-toggle:not(.paused) .audio-light{
  background:#4ade80;
  box-shadow:0 0 8px rgba(74,222,128,.95), 0 0 18px rgba(74,222,128,.6), inset 0 0 2px rgba(255,255,255,.4);
  animation:audio-light-pulse 1.4s ease-in-out infinite;
}
@keyframes audio-light-pulse{
  0%,100%{box-shadow:0 0 8px rgba(74,222,128,.95), 0 0 18px rgba(74,222,128,.6), inset 0 0 2px rgba(255,255,255,.4)}
  50%{box-shadow:0 0 12px rgba(74,222,128,1), 0 0 28px rgba(74,222,128,.85), inset 0 0 3px rgba(255,255,255,.6)}
}
.audio-toggle .eq{display:inline-flex;align-items:flex-end;gap:2px;height:18px;width:18px}
.audio-toggle .eq span{width:3px;background:var(--gold-light);border-radius:1px;height:30%;animation:eqBar 1s ease-in-out infinite}
.audio-toggle .eq span:nth-child(1){animation-delay:-1s}
.audio-toggle .eq span:nth-child(2){animation-delay:-0.7s}
.audio-toggle .eq span:nth-child(3){animation-delay:-0.4s}
.audio-toggle .eq span:nth-child(4){animation-delay:-0.2s}
.audio-toggle:hover .eq span{background:var(--paper)}
@keyframes eqBar{0%,100%{height:30%}50%{height:100%}}
.audio-toggle.paused .eq span{animation-play-state:paused;height:30%}
.audio-toggle .label-on{display:none}
.audio-toggle.paused .label-on{display:inline}
.audio-toggle.paused .label-off{display:none}

/* Progress bar — klikalny scrub */
.audio-toggle .audio-progress{
  width:140px;height:4px;background:rgba(242,232,213,.18);border-radius:2px;cursor:pointer;
  flex-shrink:0;overflow:hidden;margin-left:4px;position:relative;
  transition:height .2s
}
.audio-toggle .audio-progress:hover{height:6px}
.audio-toggle .audio-progress-fill{
  height:100%;width:0;background:linear-gradient(90deg, var(--gold-light) 0%, var(--gold) 100%);
  border-radius:2px;transition:width .2s linear;box-shadow:0 0 6px rgba(212,185,137,.4)
}
.audio-toggle .audio-time{
  font-family:var(--font-stamp);font-size:10px;letter-spacing:.08em;color:var(--gold-light);
  flex-shrink:0;min-width:36px;text-align:right;opacity:.85
}
.audio-toggle.paused .audio-progress,.audio-toggle.paused .audio-time{opacity:.5}
.audio-toggle .note-icon{width:18px;height:18px;color:var(--gold-light);transition:color .25s,transform .25s;flex-shrink:0}
.audio-toggle:hover .note-icon{color:var(--paper)}
.audio-toggle.paused .note-icon{opacity:.55}
.audio-toggle:not(.paused) .note-icon{animation:note-bobble 1.6s ease-in-out infinite}
@keyframes note-bobble{0%,100%{transform:rotate(-6deg)}50%{transform:rotate(6deg)}}

@media(max-width:880px){
  /* Mobile audio toggle — mały gdy paused, rozwijany gdy gra */
  .audio-toggle{
    bottom:90px;left:0;
    padding:8px 10px 8px 9px;font-size:0;
    border-radius:0 22px 22px 0;
    border-left:0;border-color:rgba(220,38,38,.4);
    background:rgba(18,28,62,.95);
    backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
    box-shadow:0 6px 18px -4px rgba(0,0,0,.4);
    gap:7px;
    transition:all .4s cubic-bezier(.2,.8,.2,1)
  }
  .audio-toggle .label-on,.audio-toggle.paused .label-on,.audio-toggle .label-off{display:none}
  .audio-toggle .eq{display:none}
  .audio-toggle .audio-progress,.audio-toggle .audio-time{display:none}
  .audio-toggle .note-icon{width:18px;height:18px}
  .audio-toggle .audio-light{width:7px;height:7px}

  /* Gdy gra — przycisk rozwija się: większy padding, equalizer pojawia się, gold-light border */
  .audio-toggle:not(.paused){
    padding:9px 16px 9px 12px;
    border-color:#4ade80;
    background:linear-gradient(135deg, var(--ink) 0%, var(--ink-2) 100%);
    gap:9px
  }
  .audio-toggle:not(.paused) .eq{display:inline-flex;width:14px;height:14px;gap:1.5px}
  .audio-toggle:not(.paused) .eq span{width:2.5px}

  .audio-toggle:hover{transform:none;background:var(--red);border-color:var(--red);box-shadow:0 8px 22px -6px rgba(185,28,28,.5)}
}

/* ============== MARQUEE belka ==============*/
.marquee{background:var(--ink-deep);color:var(--paper);padding:40px 0;overflow:hidden;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);position:relative;white-space:nowrap}
.marquee-track{display:inline-block;animation:scroll-x 60s linear infinite;will-change:transform}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{display:inline-block;font-family:"Special Elite",monospace;font-size:14px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-light);margin-right:64px;vertical-align:middle}
.marquee-item::after{content:"●";color:var(--red);font-size:10px;margin-left:34px;vertical-align:middle;opacity:.85}
@keyframes scroll-x{0%{transform:translate3d(0,0,0)}100%{transform:translate3d(-50%,0,0)}}

/* ============== BUS animowany — scroll-driven ============== */
.bus-strip{position:relative;height:90px;background:linear-gradient(to bottom, var(--paper-3) 0%, var(--paper) 60%, transparent 100%);overflow:hidden;pointer-events:none;margin-top:-30px}
.bus-strip::before{content:"";position:absolute;bottom:18px;left:0;right:0;height:2px;background:repeating-linear-gradient(to right, var(--ink) 0 12px, transparent 12px 24px);opacity:.18}
.bus{position:absolute;bottom:14px;left:0;width:170px;height:70px;will-change:transform;transition:transform 0s linear}
.bus svg{width:100%;height:100%;display:block;filter:drop-shadow(0 6px 8px rgba(18,28,62,.25))}
.bus .wheel{transform-box:fill-box;transform-origin:center;animation:wheel-spin 1s linear infinite}
.bus.paused .wheel{animation-play-state:paused}
@keyframes wheel-spin{to{transform:rotate(360deg)}}

/* ============== COUNTERS ============== */
.stat-num{font-variant-numeric:tabular-nums}

/* ============== TILT na karcie ============== */
.tour-card-v2{transform-style:preserve-3d;transition:transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s}
.tour-card-v2 .tcv2-img img{transition:transform .5s ease, filter .5s ease}
.tour-card-v2:hover .tcv2-img img{filter:brightness(1.05)}

/* ============== MAGNETIC CTA — JS dodaje translate ============== */
.btn-primary, .btn-ghost{will-change:transform}

/* ============== Reduced motion respect ============== */
@media (prefers-reduced-motion: reduce){
  .marquee-track, .bus .wheel, .audio-toggle .eq span{animation:none !important}
  .bus{transform:none !important}
  .reveal{opacity:1 !important;transform:none !important}
}

/* ===== MASCOT — floating tematyczna ikonka, prawa krawędź ===== */
.mascot{
  position:fixed;right:-400px;top:50%;transform:translateY(-50%);z-index:55;
  background:var(--paper);border:2px solid var(--ink);border-right:0;border-radius:14px 0 0 14px;
  padding:14px 22px 14px 16px;
  display:flex;align-items:center;gap:14px;
  box-shadow:-14px 14px 36px -10px rgba(18,28,62,.32);
  transition:right .55s cubic-bezier(.2,.8,.2,1);
  font-family:var(--font-body);text-decoration:none;color:var(--ink);
  max-width:340px;
}
.mascot.show{right:0}
.mascot-link{display:flex;align-items:center;gap:14px;color:inherit;text-decoration:none;flex:1}
.mascot-icon{flex-shrink:0;width:60px;height:60px;background:var(--paper-2);border-radius:10px;display:grid;place-items:center;overflow:hidden}
.mascot-icon svg{width:46px;height:46px;display:block}
.mascot-text{display:flex;flex-direction:column;gap:2px;min-width:0}
.mascot-title{font-family:var(--font-serif);font-size:16px;font-weight:600;color:var(--ink);line-height:1.2}
.mascot-sub{font-size:13px;color:var(--red);font-weight:500;line-height:1.2}
.mascot-close{position:absolute;top:6px;right:8px;background:transparent;border:0;cursor:pointer;font-size:18px;line-height:1;color:rgba(27,41,82,.5);width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-family:var(--font-body)}
.mascot-close:hover{background:var(--ink);color:var(--paper)}
.mascot-link:hover .mascot-icon{background:var(--ink)}
.mascot-link:hover .mascot-title{color:var(--red)}
@media(max-width:780px){.mascot{max-width:80vw;padding:10px 18px 10px 12px}.mascot-icon{width:48px;height:48px}.mascot-icon svg{width:36px;height:36px}.mascot-title{font-size:14px}.mascot-sub{font-size:12px}}


/* ===== FOOTER: brand widoczne na granat tle, dziurka pinezki paper ===== */
footer .brand{color:var(--paper);gap:14px;position:relative}
footer .brand-text{color:var(--paper);font-size:30px}
footer .brand-text em{color:var(--gold-light);font-size:22px}
footer .brand-text::after{background:linear-gradient(to right, var(--red), var(--red) 70%, transparent 70%);height:2px}
footer .brand-pin{width:30px;height:36px;filter:drop-shadow(0 2px 6px rgba(185,28,28,.5));position:relative}
footer .brand-pin::after{content:"";position:absolute;top:8px;left:50%;transform:translateX(-50%);width:10px;height:10px;background:var(--paper);border-radius:50%;z-index:1}

/* ===== Większe karty tour na desktop ===== */
.tcv2-body h3{font-size:23px;line-height:1.18}
.tcv2-price{font-size:26px}
.tcv2-img{aspect-ratio:4/3}

/* ============================================================
   POCZTÓWKI — sticky stack z białymi ramkami, airmail border,
   handwritten Caveat, znaczek + okrągły stempel
   ============================================================ */
/* ============================================================
   TOUR CARDS — scroll-driven reveal (Chrome 115+/Safari 26+)
   ============================================================ */
@supports (animation-timeline: view()){
  .tour-card-v2{
    animation:tour-card-reveal linear both;
    animation-timeline:view();
    animation-range:entry 5% cover 35%;
    will-change:transform,opacity;
  }
  .tour-card-v2:nth-child(even){animation-name:tour-card-reveal-even}
  .tour-card-v2:nth-child(3n){animation-duration:1.05}
  @keyframes tour-card-reveal{
    0%{opacity:0;transform:translateY(70px) rotate(-1.2deg) scale(.94)}
    100%{opacity:1;transform:translateY(0) rotate(0) scale(1)}
  }
  @keyframes tour-card-reveal-even{
    0%{opacity:0;transform:translateY(70px) rotate(1.2deg) scale(.94)}
    100%{opacity:1;transform:translateY(0) rotate(0) scale(1)}
  }
  @media (prefers-reduced-motion: reduce){
    .tour-card-v2{animation:none}
  }
}

/* ============================================================
   HERO: tło (jednolite, BEZ rozmycia) + promienie + spadające
   ============================================================ */
.hero-art{position:relative;overflow:hidden}
.hero-bg{position:relative;z-index:0;width:100%;will-change:transform}
.hero-bg picture, .hero-bg img{display:block;width:100%;height:auto;max-height:92vh;object-fit:cover;object-position:center}

/* MIKRO RUCH: ambient breathing na obrazku tła — bardzo subtle pan + scale */
.hero-bg picture{animation:bg-ambient 14s ease-in-out infinite alternate;transform-origin:center center}
@keyframes bg-ambient{
  0%{transform:scale(1.02) translate(0, 0)}
  50%{transform:scale(1.028) translate(-.4%, .3%)}
  100%{transform:scale(1.022) translate(.5%, -.2%)}
}

/* PROMIENIE SŁOŃCA — z-1 (ZA Dawidem) */
.hero-rays{position:absolute;inset:0;pointer-events:none;z-index:1;overflow:hidden}
.hero-rays::before{
  content:"";position:absolute;
  top:-15%;right:-8%;width:85%;height:125%;
  background:linear-gradient(218deg,
    rgba(255,220,140,0) 0%,
    rgba(255,220,140,.45) 12%,
    rgba(255,220,140,0) 16%,
    rgba(255,220,140,0) 26%,
    rgba(255,210,130,.55) 36%,
    rgba(255,210,130,0) 41%,
    rgba(255,210,130,0) 50%,
    rgba(255,225,150,.42) 58%,
    rgba(255,225,150,0) 62%,
    rgba(255,225,150,0) 72%,
    rgba(255,205,125,.50) 78%,
    rgba(255,205,125,0) 82%,
    rgba(255,205,125,0) 100%);
  filter:blur(7px);
  mix-blend-mode:soft-light;
  animation:rays-fade 8s ease-in-out infinite alternate;
}
.hero-rays::after{
  content:"";position:absolute;
  top:-8%;right:-3%;width:75%;height:115%;
  background:linear-gradient(212deg,
    transparent 30%,
    rgba(255,235,180,.30) 45%,
    transparent 50%,
    transparent 65%,
    rgba(255,235,180,.25) 75%,
    transparent 80%);
  filter:blur(11px);
  mix-blend-mode:overlay;
  animation:rays-fade2 11s ease-in-out infinite alternate;
}
@keyframes rays-fade{
  0%{opacity:.55;transform:translateX(0) translateY(0)}
  50%{opacity:.85;transform:translateX(.8%) translateY(-.4%)}
  100%{opacity:1;transform:translateX(1.6%) translateY(.3%)}
}
@keyframes rays-fade2{
  0%{opacity:.6;transform:translateX(0) translateY(0)}
  50%{opacity:.85;transform:translateX(-.6%) translateY(.5%)}
  100%{opacity:.95;transform:translateX(-1.2%) translateY(-.3%)}
}

/* PARALLAX scroll-driven: tło zoom+drift na scroll, spadające osobny shift */
@supports (animation-timeline: scroll()){
  .hero-bg{animation:hero-bg-parallax linear both;animation-timeline:scroll(root);animation-range:0 100vh}
  .hero-fall{animation:hero-fall-parallax linear both;animation-timeline:scroll(root);animation-range:0 100vh}
  @keyframes hero-bg-parallax{
    0%{transform:translateY(0) scale(1)}
    100%{transform:translateY(-5vh) scale(1.06)}
  }
  @keyframes hero-fall-parallax{
    0%{transform:translateY(0)}
    100%{transform:translateY(-10vh)}
  }
}

@media (prefers-reduced-motion: reduce){
  .hero-bg picture,.hero-rays::before,.hero-rays::after{animation:none}
  .hero-bg{animation:none}
}

/* Spadające kartki / konfetti / krople — z-2 (między promieniami a Dawidem) */
.hero-fall{position:absolute;inset:0;z-index:2;pointer-events:none;overflow:hidden}

/* Dawid wycięty — z-3 NAD promieniami; contain żeby zachować całą sylwetkę + idle float */
.hero-fg{position:absolute;inset:0;z-index:3;pointer-events:none;display:flex;align-items:flex-end;justify-content:center}
.hero-fg picture{display:block;height:100%;max-width:none}
.hero-fg img{display:block;height:100%;width:auto;max-height:92vh;object-fit:contain;object-position:center bottom;
  filter:drop-shadow(0 16px 28px rgba(0,0,0,.38)) drop-shadow(0 4px 8px rgba(0,0,0,.2));
  animation:fg-float 7s ease-in-out infinite alternate;
  transform-origin:center bottom;will-change:transform}
@keyframes fg-float{
  0%{transform:translate(0, 0)}
  50%{transform:translate(.3%, -.6%)}
  100%{transform:translate(-.4%, -1%)}
}

/* Bg ma większy ruch ambient — daje efekt ruchu MIĘDZY warstwami */
.hero-bg picture{animation:bg-ambient 16s ease-in-out infinite alternate;display:block;transform-origin:center center;will-change:transform}
.hero-fall .fall{position:absolute;top:-30px;animation:fall-down linear infinite;will-change:transform;opacity:0}
@keyframes fall-down{
  0%{transform:translateY(0) translateX(0) rotate(0);opacity:0}
  8%{opacity:1}
  92%{opacity:.85}
  100%{transform:translateY(110vh) translateX(var(--drift,30px)) rotate(var(--rot-end,540deg));opacity:0}
}

/* Konfetti — małe prostokąciki w 4 kolorach brand */
.hero-fall .confetti{width:8px;height:14px;border-radius:1px;box-shadow:0 1px 2px rgba(0,0,0,.18)}
.hero-fall .c-red{background:#B91C1C}
.hero-fall .c-gold{background:#B89058}
.hero-fall .c-ink{background:#1B2952}
.hero-fall .c-paper{background:#F2E8D5;border:1px solid rgba(184,144,88,.5)}

/* Mini-pocztówki spadające — białe karteczki */
.hero-fall .card{width:20px;height:26px;background:#fff;border:1px solid rgba(0,0,0,.08);box-shadow:0 3px 8px rgba(0,0,0,.25);border-radius:2px;
  /* mini airmail border */
  background-image:
    linear-gradient(90deg, transparent 0 1px, transparent 0),
    repeating-linear-gradient(90deg, #B91C1C 0 2px, transparent 2px 4px, #1B2952 4px 6px, transparent 6px 8px);
  background-size:100% 100%, 100% 2px;
  background-repeat:no-repeat;
  background-position:0 0, 0 0;
}

/* Krople deszczu */
.hero-fall .rain{width:1.5px;height:14px;background:linear-gradient(180deg, transparent, rgba(200,215,230,.7));border-radius:2px;box-shadow:0 0 2px rgba(255,255,255,.3)}

@media (prefers-reduced-motion: reduce){
  .hero-fall{display:none}
}

/* UWAGA: NIE dodawaj overflow:hidden — zabija position:sticky pocztówek */
.postcards{padding:80px 32px 140px;background:linear-gradient(180deg, var(--paper) 0%, var(--paper-2) 100%);position:relative}
.postcards-head{max-width:760px;margin:0 auto 50px;text-align:center}
.postcards-head h2{font-family:var(--font-serif);font-size:clamp(36px,5vw,64px);line-height:1.05;margin-bottom:14px;color:var(--ink)}
.postcards-head h2 em{color:var(--red);font-style:italic}
.postcards-head p{color:rgba(27,41,82,.7);font-size:17px;max-width:520px;margin:0 auto}

.postcards-stack{max-width:1100px;margin:0 auto;perspective:1800px}

.postcard{
  position:sticky;
  height:78vh;min-height:540px;max-height:720px;
  margin-bottom:40px;
  background:#fff;
  padding:22px;
  box-shadow:
    0 2px 4px rgba(0,0,0,.06),
    0 10px 22px rgba(0,0,0,.18),
    0 28px 60px -20px rgba(0,0,0,.35);
  border-radius:2px;
  display:grid;grid-template-columns:1.15fr 1fr;
  gap:0;
  transform-origin:center top;
  transform-style:preserve-3d;
  will-change:transform;
}
.postcard:nth-child(1){top:80px;transform:rotate(-2.2deg)}
.postcard:nth-child(2){top:100px;transform:rotate(1.5deg)}
.postcard:nth-child(3){top:120px;transform:rotate(-1deg)}
.postcard:nth-child(4){top:140px;transform:rotate(2.2deg)}
.postcard:nth-child(5){top:160px;transform:rotate(-1.7deg)}

/* Airmail red/blue border */
.postcard::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    repeating-linear-gradient(90deg, #B91C1C 0 12px, #fff 12px 24px, #1B2952 24px 36px, #fff 36px 48px) 0 0/100% 8px no-repeat,
    repeating-linear-gradient(90deg, #B91C1C 0 12px, #fff 12px 24px, #1B2952 24px 36px, #fff 36px 48px) 0 100%/100% 8px no-repeat,
    repeating-linear-gradient(0deg, #B91C1C 0 12px, #fff 12px 24px, #1B2952 24px 36px, #fff 36px 48px) 0 0/8px 100% no-repeat,
    repeating-linear-gradient(0deg, #B91C1C 0 12px, #fff 12px 24px, #1B2952 24px 36px, #fff 36px 48px) 100% 0/8px 100% no-repeat;
}

.postcard-img{position:relative;overflow:hidden;background:var(--ink);border:1px solid rgba(0,0,0,.08)}
.postcard-img img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1.02);transition:transform .85s cubic-bezier(.2,.8,.2,1)}
.postcard:hover .postcard-img img{transform:scale(1.08)}

.postcard .greetings{position:absolute;bottom:14px;left:14px;right:14px;
  font-family:"Caveat", cursive;font-size:42px;line-height:1;color:#fff;font-weight:600;
  text-shadow:0 2px 8px rgba(0,0,0,.55), 0 1px 2px rgba(0,0,0,.8);
  pointer-events:none}
.postcard .greetings small{display:block;font-size:14px;font-family:var(--font-stamp);letter-spacing:.2em;text-transform:uppercase;margin-top:6px;opacity:.9;font-weight:400}

.postcard-back{position:relative;padding:30px 28px 28px 32px;display:flex;flex-direction:column;
  background:#fefefe;
  background-image:linear-gradient(180deg, #fefefe, #faf8f3);
  border-left:1px dashed rgba(27,41,82,.18)}

.postcard-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(27,41,82,.12);gap:12px}
.postcard-from{font-family:var(--font-stamp);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:rgba(27,41,82,.55)}
.postcard-city{font-family:var(--font-serif);font-style:italic;font-size:22px;color:var(--red);font-weight:600;line-height:1}

.postcard-message{font-family:"Caveat", cursive;font-size:24px;line-height:1.4;color:#1B2952;flex:1;padding-right:120px;transform:rotate(-.4deg)}
.postcard-message p{margin-bottom:10px}
.postcard-message p:last-of-type{margin-bottom:0}
.postcard-signature{margin-top:14px;font-size:28px;color:var(--red);font-weight:600}

/* Dyskretny link do wycieczki — handwritten z czerwoną podkreślniczką */
.postcard-link{display:inline-block;margin-top:18px;padding:6px 0;font-family:"Caveat", cursive;font-size:20px;color:var(--red);text-decoration:none;border-bottom:1.5px solid var(--red);align-self:flex-start;transition:all .25s;transform:rotate(-.4deg);font-weight:500}
.postcard-link:hover{color:var(--red-deep);border-bottom-color:var(--red-deep);padding-left:6px}

/* Znaczek */
.postcard-stamp{position:absolute;top:30px;right:28px;width:90px;height:108px;
  background:#fff;
  border:1px dashed rgba(27,41,82,.4);
  padding:4px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  transform:rotate(2deg);box-shadow:1px 2px 4px rgba(0,0,0,.1)}
.postcard-stamp .stamp-art{width:100%;flex:1;background:linear-gradient(135deg, var(--red) 0%, var(--red-deep) 100%);display:flex;align-items:center;justify-content:center;padding:6px;border-radius:1px}
.postcard-stamp .stamp-art svg{width:100%;height:100%;color:#fff}
.postcard-stamp .stamp-price{font-family:var(--font-stamp);font-size:9px;color:var(--ink);letter-spacing:.08em;font-weight:bold}

/* Okrągły stempel "London" */
.postcard-cancel{position:absolute;top:50px;right:18px;width:90px;height:90px;
  border:2px solid rgba(27,41,82,.55);border-radius:50%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-family:var(--font-stamp);color:rgba(27,41,82,.6);
  transform:rotate(-12deg);
  pointer-events:none}
.postcard-cancel::before{content:"";position:absolute;inset:5px;border:1px solid rgba(27,41,82,.4);border-radius:50%}
.cancel-top{font-size:11px;letter-spacing:.18em;font-weight:bold;text-transform:uppercase}
.cancel-mid{font-size:18px;font-family:var(--font-serif);font-style:italic;line-height:1;margin:1px 0}
.cancel-bot{font-size:8px;letter-spacing:.16em;text-transform:uppercase}
.cancel-waves{position:absolute;left:-44px;top:50%;width:42px;height:14px;background:
  linear-gradient(rgba(27,41,82,.4), rgba(27,41,82,.4)) center 3px/100% 1.5px no-repeat,
  linear-gradient(rgba(27,41,82,.4), rgba(27,41,82,.4)) center 8px/100% 1.5px no-repeat,
  linear-gradient(rgba(27,41,82,.4), rgba(27,41,82,.4)) center 13px/100% 1.5px no-repeat;
  transform:translateY(-50%)}

/* === MOBILE — pocztówki PIONOWO (portrait orientation) === */
@media (max-width: 880px){
  .postcards{padding:60px 14px 70px}
  .postcards-head{margin-bottom:36px}
  .postcards-stack{perspective:none;display:flex;flex-direction:column;align-items:center}
  .postcard{
    grid-template-columns:1fr;
    grid-template-rows:auto 1fr;
    width:100%;max-width:380px;
    height:auto;min-height:auto;
    padding:12px;
    margin-bottom:22px;
  }
  /* 5 cards mobile — sticky różne top, mniejsze rotacje */
  .postcard:nth-child(1){top:70px;transform:rotate(-1.4deg)}
  .postcard:nth-child(2){top:84px;transform:rotate(1deg)}
  .postcard:nth-child(3){top:98px;transform:rotate(-.7deg)}
  .postcard:nth-child(4){top:112px;transform:rotate(1.3deg)}
  .postcard:nth-child(5){top:126px;transform:rotate(-1deg)}
  .postcard-link{font-size:18px;margin-top:14px}

  /* Zdjęcie portrait — góra pocztówki */
  .postcard-img{aspect-ratio:4/5;border-bottom:1px dashed rgba(27,41,82,.18)}
  .postcard .greetings{font-size:32px;left:12px;right:12px;bottom:12px}
  .postcard .greetings small{font-size:10px;letter-spacing:.18em}

  /* Tył pocztówki — pod zdjęciem */
  .postcard-back{padding:20px 18px 18px;border-left:0}
  .postcard-head{margin-bottom:12px;padding-bottom:10px}
  .postcard-from{font-size:9px;letter-spacing:.18em}
  .postcard-city{font-size:18px}

  .postcard-message{font-size:19px;padding-right:0;line-height:1.4;transform:rotate(-.3deg)}
  .postcard-message p{margin-bottom:8px}
  .postcard-signature{font-size:22px;margin-top:10px}

  /* Znaczek przeniesiony pod wiadomość, bez okrągłego stempla na mobile */
  .postcard-stamp{position:relative;top:0;right:0;align-self:flex-end;margin:12px 0 0;width:68px;height:80px;transform:rotate(2.5deg)}
  .postcard-stamp .stamp-price{font-size:8px}
  .postcard-cancel{display:none}
}

@media (prefers-reduced-motion: reduce){
  .postcard-img img{transition:none}
}

/* ===== HERO mobile — pełnoekranowy 9:16 z obrazem cover + tekst overlay ===== */
@media (max-width: 880px){
  /* grid: row 1 = hero-art + cta-bar (overlay), row 2 = stats normalnie */
  .hero{position:relative;display:grid;grid-template-rows:100vh auto;grid-template-rows:100dvh auto;min-height:560px}
  .hero-art{grid-area:1/1;position:relative;width:100%;height:100%;overflow:hidden}
  .hero-bg, .hero-fg{position:absolute;inset:0;width:100%;height:100%}
  .hero-bg picture, .hero-bg img{width:100%;height:100%;max-height:none;object-fit:cover;object-position:center}
  /* mobile: cutout teraz osobny — bg jest BEZ Dawida (drugi GPT) */
  .hero-fg{display:flex}
  .hero-fg picture{display:block;height:100%}
  .hero-fg img{height:100%;width:auto;max-height:none;object-fit:contain;object-position:center bottom}
  .hero-art::after{content:"";position:absolute;left:0;right:0;top:35%;bottom:0;height:auto;background:linear-gradient(to bottom, rgba(18,28,62,0) 0%, rgba(18,28,62,.45) 45%, rgba(18,28,62,.92) 100%);pointer-events:none;z-index:4}
  /* CTA bar overlay — w tej samej grid-area co art, dołem. z-10 nad gradient */
  .hero-cta-bar{grid-area:1/1;align-self:end;position:relative;z-index:10;margin:0;padding:0 22px 28px;grid-template-columns:1fr;gap:18px}
  /* mobile: ukryj tagline i sub — za dużo tekstu na małym ekranie */
  .hero-tagline,.hero-sub{display:none}
  .eyebrow{color:var(--gold-light);font-size:11px;letter-spacing:.24em;margin-bottom:14px}
  .eyebrow::before{background:var(--gold-light);width:24px}
  .hero-cta{gap:10px}
  .hero-cta .btn-primary{padding:14px 22px;font-size:12px;flex:1;justify-content:center}
  .hero-cta .btn-ghost{padding:14px 22px;font-size:12px;color:var(--paper);border-color:rgba(242,232,213,.85);flex:1;justify-content:center}
  .hero-cta .btn-ghost:hover{background:var(--paper);color:var(--ink)}
  /* stats w drugim wierszu, normalny flow */
  .hero-stats{grid-area:2/1;padding:32px 22px;border-top:none}
}
