/* ===================================================================
   Przewozy Polska ⇄ Włochy — landing pod Google Ads
   Paleta: granat nocny + błękit + akcent włoskiej zieleni/czerwieni
   =================================================================== */

:root{
  --bg:#0a0e1a;
  --bg2:#0e1426;
  --panel:#121a30;
  --panel2:#16203a;
  --line:rgba(255,255,255,.09);
  --txt:#eef2fb;
  --muted:#9fb0cf;
  --brand:#3b82f6;      /* błękit trasy */
  --brand2:#22d3ee;     /* cyjan */
  --it-green:#20c374;
  --it-red:#e5484d;
  --gold:#f6c453;
  --wa:#25d366;
  --radius:20px;
  --shadow:0 20px 50px -20px rgba(0,0,0,.7);
  --maxw:1140px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg);color:var(--txt);line-height:1.6;
  overflow-x:hidden;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
h1,h2,h3,h4,.brand-txt{font-family:'Sora',sans-serif;letter-spacing:-.02em;line-height:1.08}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.wrap.narrow{max-width:820px}
.grad{background:linear-gradient(100deg,var(--brand2),var(--brand) 55%,#8b5cf6);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;gap:.55em;justify-content:center;
  font-weight:700;font-family:'Sora',sans-serif;border-radius:999px;
  padding:.85em 1.35em;cursor:pointer;border:1px solid transparent;
  transition:transform .18s ease,box-shadow .25s ease,background .2s;
  white-space:nowrap;font-size:.98rem;
}
.btn:active{transform:scale(.97)}
.btn-lg{padding:1.05em 1.8em;font-size:1.06rem}
.btn-call{background:linear-gradient(135deg,var(--brand),#2563eb);color:#fff;box-shadow:0 12px 30px -8px rgba(59,130,246,.6)}
.btn-call:hover{transform:translateY(-2px);box-shadow:0 18px 40px -10px rgba(59,130,246,.75)}
.btn-wa{background:linear-gradient(135deg,#25d366,#1eb257);color:#04210f;box-shadow:0 12px 30px -8px rgba(37,211,102,.5)}
.btn-wa:hover{transform:translateY(-2px);box-shadow:0 18px 40px -10px rgba(37,211,102,.65)}

.ico-phone,.ico-wa{width:1.15em;height:1.15em;display:inline-block;background:currentColor;
  -webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-size:contain;mask-size:contain}
.ico-phone{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M6.6 10.8a15.5 15.5 0 006.6 6.6l2.2-2.2a1 1 0 011-.24 11.4 11.4 0 003.6.57 1 1 0 011 1V20a1 1 0 01-1 1A17 17 0 013 4a1 1 0 011-1h3.5a1 1 0 011 1 11.4 11.4 0 00.57 3.6 1 1 0 01-.24 1z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M6.6 10.8a15.5 15.5 0 006.6 6.6l2.2-2.2a1 1 0 011-.24 11.4 11.4 0 003.6.57 1 1 0 011 1V20a1 1 0 01-1 1A17 17 0 013 4a1 1 0 011-1h3.5a1 1 0 011 1 11.4 11.4 0 00.57 3.6 1 1 0 01-.24 1z'/%3E%3C/svg%3E")}
.ico-wa{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2a10 10 0 00-8.6 15l-1.3 4.7 4.8-1.3A10 10 0 1012 2zm5.3 14.1c-.2.6-1.3 1.2-1.8 1.2-.5.1-1 .1-1.7-.1-.4-.1-.9-.3-1.6-.6-2.8-1.2-4.6-4-4.7-4.2-.1-.2-1.1-1.4-1.1-2.7s.7-1.9.9-2.2c.2-.3.5-.3.7-.3h.5c.2 0 .4 0 .6.5l.8 1.9c.1.2.1.4 0 .5l-.4.6c-.2.2-.3.4-.1.7.2.3.9 1.4 1.9 2.3 1.3 1.1 2.3 1.4 2.6 1.6.2.1.4.1.6-.1l.7-.9c.2-.2.4-.2.6-.1l1.8.9c.3.1.4.2.5.3z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2a10 10 0 00-8.6 15l-1.3 4.7 4.8-1.3A10 10 0 1012 2zm5.3 14.1c-.2.6-1.3 1.2-1.8 1.2-.5.1-1 .1-1.7-.1-.4-.1-.9-.3-1.6-.6-2.8-1.2-4.6-4-4.7-4.2-.1-.2-1.1-1.4-1.1-2.7s.7-1.9.9-2.2c.2-.3.5-.3.7-.3h.5c.2 0 .4 0 .6.5l.8 1.9c.1.2.1.4 0 .5l-.4.6c-.2.2-.3.4-.1.7.2.3.9 1.4 1.9 2.3 1.3 1.1 2.3 1.4 2.6 1.6.2.1.4.1.6-.1l.7-.9c.2-.2.4-.2.6-.1l1.8.9c.3.1.4.2.5.3z'/%3E%3C/svg%3E")}

/* ===== NAV ===== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;gap:18px;
  padding:14px 22px;transition:background .3s,backdrop-filter .3s,border-color .3s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{background:rgba(10,14,26,.82);backdrop-filter:blur(14px);border-bottom-color:var(--line)}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:1.05rem}
.brand-mark{font-size:1.5rem;filter:drop-shadow(0 4px 10px rgba(59,130,246,.5))}
.brand-txt b{font-weight:800}
.nav-links{display:flex;gap:26px;margin-left:auto;font-weight:500;font-size:.95rem}
.nav-links a{color:var(--muted);transition:color .2s}
.nav-links a:hover{color:#fff}
.nav-cta{margin-left:8px}

/* ===== HERO ===== */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;
  background:radial-gradient(120% 90% at 70% 0%,#152249 0%,var(--bg) 55%),var(--bg);overflow:hidden}
#scene{position:absolute;inset:0;width:100%;height:100%;z-index:1}
.hero-veil{position:absolute;inset:0;z-index:2;pointer-events:none;
  background:radial-gradient(90% 70% at 25% 45%,rgba(10,14,26,.72),transparent 70%),
             linear-gradient(0deg,var(--bg) 3%,transparent 40%)}
.hero-inner{position:relative;z-index:3;max-width:var(--maxw);margin:0 auto;padding:110px 22px 90px;width:100%}
.award{display:inline-flex;align-items:center;gap:.6em;padding:.5em 1em;border-radius:999px;
  background:rgba(246,196,83,.1);border:1px solid rgba(246,196,83,.35);color:#f7d98a;
  font-size:.85rem;font-weight:600;margin-bottom:24px;backdrop-filter:blur(6px)}
.award-laur{font-size:1.05rem}
.hero h1{font-size:clamp(2.5rem,7vw,4.6rem);font-weight:800;margin-bottom:20px}
.hero h1 .arrow{color:var(--brand2);font-weight:700}
.lead{font-size:clamp(1.05rem,2.3vw,1.3rem);color:var(--muted);max-width:640px;margin-bottom:34px}
.lead b{color:#dbe6ff;font-weight:600}
.lead.center{margin-left:auto;margin-right:auto;text-align:center}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:30px}
.hero-cta.center{justify-content:center}
.hero-badges{list-style:none;display:flex;gap:12px;flex-wrap:wrap}
.hero-badges li{display:flex;align-items:center;gap:.5em;font-size:.9rem;font-weight:600;color:#cdd9f2;
  background:rgba(255,255,255,.05);border:1px solid var(--line);padding:.55em .95em;border-radius:12px;backdrop-filter:blur(6px)}

.scroll-hint{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:3;
  width:26px;height:42px;border:2px solid rgba(255,255,255,.35);border-radius:14px;display:flex;justify-content:center}
.scroll-hint span{width:4px;height:8px;background:#fff;border-radius:2px;margin-top:7px;animation:scr 1.6s infinite}
@keyframes scr{0%{opacity:0;transform:translateY(-4px)}50%{opacity:1}100%{opacity:0;transform:translateY(10px)}}

/* ===== SECTIONS ===== */
.section{padding:88px 0;position:relative}
.section.alt{background:linear-gradient(180deg,var(--bg2),var(--bg))}
.eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;font-weight:700;color:var(--brand2);margin-bottom:12px}
.h2{font-size:clamp(1.8rem,4.5vw,2.9rem);font-weight:800;margin-bottom:14px}
.sub{color:var(--muted);max-width:680px;margin-bottom:36px;font-size:1.05rem}
.sub b{color:#dbe6ff}
.note{color:var(--muted);margin-top:22px;font-size:.98rem}

/* ===== CARDS ===== */
.cards{display:grid;gap:22px;margin-top:34px}
.cards.two{grid-template-columns:repeat(2,1fr)}
.cards.three{grid-template-columns:repeat(3,1fr)}
.card{
  background:linear-gradient(180deg,var(--panel2),var(--panel));border:1px solid var(--line);
  border-radius:var(--radius);padding:34px 30px;box-shadow:var(--shadow);
  transition:transform .25s,border-color .25s;will-change:transform;transform-style:preserve-3d;
}
.card:hover{border-color:rgba(59,130,246,.5)}
.card-ico{font-size:2.4rem;margin-bottom:16px}
.card h3{font-size:1.5rem;margin-bottom:10px}
.card p{color:var(--muted);margin-bottom:18px}
.ticks{list-style:none;display:grid;gap:9px}
.ticks li{position:relative;padding-left:28px;color:#cfdaf1;font-size:.97rem}
.ticks li::before{content:"";position:absolute;left:0;top:.35em;width:16px;height:16px;border-radius:50%;
  background:var(--it-green);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.4-1.4z'/%3E%3C/svg%3E") center/95% no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.4-1.4z'/%3E%3C/svg%3E") center/95% no-repeat;
  background-color:#22d38a}

.mini{background:linear-gradient(180deg,var(--panel2),var(--panel));border:1px solid var(--line);
  border-radius:16px;padding:26px 24px;transition:transform .2s,border-color .2s}
.mini:hover{transform:translateY(-4px);border-color:rgba(34,211,238,.4)}
.mini-ico{font-size:1.8rem;display:block;margin-bottom:12px}
.mini h4{font-size:1.15rem;margin-bottom:8px}
.mini p{color:var(--muted);font-size:.95rem}

/* ===== TIMELINE ===== */
.timeline{display:flex;align-items:stretch;gap:0;margin-top:34px;flex-wrap:wrap}
.tl-step{flex:1;min-width:250px;background:linear-gradient(180deg,var(--panel2),var(--panel));
  border:1px solid var(--line);border-radius:var(--radius);padding:28px 26px;text-align:center;box-shadow:var(--shadow)}
.tl-day{font-family:'Sora';font-weight:800;letter-spacing:.1em;color:var(--brand2);font-size:.95rem;margin-bottom:8px}
.tl-ico{font-size:2rem;margin-bottom:10px}
.tl-txt{color:#cfdaf1}
.tl-line{flex:0 0 60px;align-self:center;height:3px;background:linear-gradient(90deg,var(--brand),var(--brand2));
  border-radius:3px;position:relative}
.tl-line::after{content:"";position:absolute;right:-2px;top:-4px;width:11px;height:11px;border-radius:50%;background:var(--brand2);box-shadow:0 0 12px var(--brand2)}

/* ===== ROUTES ===== */
.routes{display:grid;grid-template-columns:1fr auto 1fr;gap:26px;align-items:start;margin-top:14px}
.route-col{background:linear-gradient(180deg,var(--panel2),var(--panel));border:1px solid var(--line);
  border-radius:var(--radius);padding:30px 28px;box-shadow:var(--shadow)}
.route-col h3{font-size:1.3rem;margin-bottom:18px;display:flex;align-items:center;gap:.5em}
.flag{font-size:1.4rem}
.chips{list-style:none;display:flex;flex-wrap:wrap;gap:10px}
.chips li{background:rgba(59,130,246,.12);border:1px solid rgba(59,130,246,.3);color:#d5e2ff;
  padding:.5em .9em;border-radius:10px;font-size:.95rem;font-weight:600;transition:transform .15s,background .2s}
.chips li:hover{transform:translateY(-2px);background:rgba(59,130,246,.22)}
.chips.it li{background:rgba(32,195,116,.1);border-color:rgba(32,195,116,.32);color:#c8f5df}
.chips.it li:hover{background:rgba(32,195,116,.2)}
.route-mid{align-self:center;font-size:2.4rem;color:var(--brand2);text-shadow:0 0 20px rgba(34,211,238,.5)}

/* ===== FAQ ===== */
.faq{display:grid;gap:12px;margin-top:26px}
.faq details{background:linear-gradient(180deg,var(--panel2),var(--panel));border:1px solid var(--line);
  border-radius:14px;padding:2px 22px;transition:border-color .2s}
.faq details[open]{border-color:rgba(59,130,246,.5)}
.faq summary{cursor:pointer;font-family:'Sora';font-weight:700;font-size:1.06rem;padding:18px 0;
  list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--brand2);transition:transform .25s;flex:none}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq p{color:var(--muted);padding:0 0 18px;font-size:.98rem}

/* ===== CTA ===== */
.cta{padding:96px 0;text-align:center;
  background:radial-gradient(80% 120% at 50% 0%,#17265a,var(--bg) 65%);position:relative}
.cta .h2{margin-bottom:16px}

/* ===== FOOTER ===== */
.footer{padding:44px 0 120px;border-top:1px solid var(--line);background:var(--bg2);color:var(--muted);font-size:.9rem}
.footer p{margin-bottom:10px}
.footer .foot-seo{font-size:.82rem;opacity:.7;line-height:1.7}
.foot-contact a{color:#cfdaf1;font-weight:600}

/* ===== MOBILNY PASEK ===== */
.mobile-bar{position:fixed;bottom:0;left:0;right:0;z-index:60;display:none;gap:10px;padding:10px 12px calc(10px + env(safe-area-inset-bottom));
  background:rgba(10,14,26,.92);backdrop-filter:blur(14px);border-top:1px solid var(--line)}
.mobile-bar a{flex:1;display:flex;align-items:center;justify-content:center;gap:.5em;
  padding:.9em;border-radius:12px;font-weight:700;font-family:'Sora';font-size:1rem}
.mb-call{background:linear-gradient(135deg,var(--brand),#2563eb);color:#fff}
.mb-wa{background:linear-gradient(135deg,#25d366,#1eb257);color:#04210f}

/* ===== REVEAL ANIM ===== */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
[data-reveal].in{opacity:1;transform:none}

/* ===================================================================
   RESPONSIVE — ostry, czytelny mobile (pod Google Ads)
   =================================================================== */
@media (max-width:900px){
  .cards.three{grid-template-columns:repeat(2,1fr)}
  .routes{grid-template-columns:1fr;gap:16px}
  .route-mid{transform:rotate(90deg);justify-self:center}
  .nav-links{display:none}
}
@media (max-width:640px){
  .nav{padding:12px 16px}
  .nav-cta{font-size:.9rem;padding:.6em 1em}
  .brand-txt{font-size:.98rem}
  .hero-inner{padding:96px 18px 90px}
  .section{padding:64px 0}
  .cards.two,.cards.three{grid-template-columns:1fr}
  .hero-cta{flex-direction:column}
  .hero-cta .btn{width:100%}
  .btn-lg{font-size:1.02rem}
  .cta .hero-cta{flex-direction:row}
  .cta .hero-cta .btn{width:auto;flex:1}
  .tl-line{display:none}
  .mobile-bar{display:flex}
  .nav-cta{display:none}
  .footer{padding-bottom:96px}
  .award{font-size:.78rem}
}
@media (max-width:380px){
  .hero-badges li{font-size:.82rem;padding:.5em .75em}
}

/* Wysokie DPI — ostrość */
@media (min-resolution:2dppx){
  body{-webkit-font-smoothing:antialiased}
}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important}
  [data-reveal]{opacity:1;transform:none;transition:none}
}
