/* ============================================================
   SO!RESORT — koncepcja strony
   Design system  |  granat + złoto  |  premium coastal
   ============================================================ */

:root{
  --navy:#14213D;
  --navy-2:#1D2E4F;
  --navy-soft:#33415C;
  --gold:#C69C6D;
  --gold-deep:#B08454;
  --gold-soft:#E4CBA8;
  --sand:#F4EEE4;
  --sand-2:#EDE4D5;
  --cream:#FBF8F2;
  --ink:#20242E;
  --muted:#6B6B63;
  --line:rgba(20,33,61,.12);
  --white:#ffffff;

  --serif:"Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans:"Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

  --wrap:1240px;
  --gut:clamp(20px,5vw,64px);
  --r:14px;
  --shadow:0 24px 60px -28px rgba(20,33,61,.45);
  --shadow-soft:0 18px 44px -30px rgba(20,33,61,.4);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
/* czytelne, wyrównane cyfry (lining) w kluczowych liczbach */
.hero-facts b,.stat-row .s b,.award b,.d-val,.intro-badge b,.intro-sign b,
table.units,.timeline .tl-date,.plan-legend b,.topbar,.nav-cta,.btn-phone,
.contact-info b{font-variant-numeric:lining-nums tabular-nums;font-feature-settings:"lnum" 1,"tnum" 1}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
::selection{background:var(--gold);color:var(--navy)}

/* ---------- typografia ---------- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.06;color:var(--navy);letter-spacing:-.01em}
.eyebrow{
  font-family:var(--sans);
  font-size:.8rem;font-weight:600;letter-spacing:.18em;text-transform:lowercase;
  color:var(--gold-deep);display:inline-flex;align-items:center;gap:.8em;
}
.eyebrow::before{content:"";width:28px;height:1px;background:var(--gold);opacity:.85}
.eyebrow.center::after{content:"";width:28px;height:1px;background:var(--gold);opacity:.85}
.eyebrow.center{justify-content:center}
.eyebrow .s-num{
  font-family:var(--sans);font-style:normal;font-size:.62rem;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:inherit;border:1px solid currentColor;border-radius:100px;
  min-width:2.35em;height:2.35em;padding:0 .5em;display:inline-flex;align-items:center;justify-content:center;
  line-height:1;opacity:.9;
}
.eyebrow i{color:var(--gold);font-size:1em}

.h-xl{font-size:clamp(2.6rem,6vw,5.2rem)}
.h-lg{font-size:clamp(2.1rem,4.4vw,3.6rem)}
.h-md{font-size:clamp(1.7rem,3vw,2.5rem)}
.lead{font-size:clamp(1.05rem,1.5vw,1.22rem);color:var(--muted);max-width:60ch}

/* ---------- layout ---------- */
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 var(--gut)}
section{position:relative}
.section-pad{padding:clamp(72px,10vw,140px) 0}
.pad-top-sm{padding-top:clamp(54px,7vw,98px)!important}
.center{text-align:center}
.grid{display:grid}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  padding:15px 30px;border-radius:100px;
  font-weight:700;font-size:.9rem;letter-spacing:.02em;
  transition:.35s var(--ease);white-space:nowrap;
}
.btn i{font-size:.82em;transition:transform .35s var(--ease)}
.btn-gold{background:var(--gold);color:var(--navy)}
.btn-gold:hover{background:var(--navy);color:var(--white);transform:translateY(-2px)}
.btn-gold:hover i.fa-arrow-right-long{transform:translateX(4px)}
.btn-navy{background:var(--navy);color:var(--white)}
.btn-navy:hover{background:var(--gold);color:var(--navy);transform:translateY(-2px)}
.btn-ghost{border:1.5px solid rgba(255,255,255,.5);color:#fff}
.btn-ghost:hover{background:#fff;color:var(--navy);border-color:#fff}
.btn-outline{border:1.5px solid var(--navy);color:var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff}
.link-arrow{display:inline-flex;align-items:center;gap:.55em;font-weight:700;color:var(--navy);font-size:.9rem}
.link-arrow i{font-size:.95em;color:var(--gold-deep);transition:transform .3s var(--ease)}
.link-arrow:hover{color:var(--gold-deep)}
.link-arrow:hover i{transform:translateX(3px)}

/* ============================================================
   TOPBAR + NAV
   ============================================================ */
.topbar{
  background:var(--navy);color:rgba(255,255,255,.82);
  font-size:.78rem;letter-spacing:.03em;
}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:40px;gap:24px}
.topbar a:hover{color:var(--gold-soft)}
.topbar .tb-left{display:flex;gap:26px;align-items:center}
.topbar .tb-right{display:flex;gap:20px;align-items:center}
.topbar .tb-right a{display:inline-flex;align-items:center;gap:7px}
.topbar .tb-right i{color:var(--gold);font-size:.9em}
.topbar .dot{color:var(--gold);font-size:.85em;margin-right:2px}
.topbar .stars{display:inline-flex;align-items:center;gap:3px}
.topbar .stars i{color:var(--gold);font-size:.72em}
@media(max-width:820px){.topbar .tb-left span.hide{display:none}.topbar .wrap{justify-content:center}.topbar .tb-right{display:none}}

.nav{
  position:sticky;top:0;z-index:60;
  background:rgba(251,248,242,.0);
  transition:background .4s var(--ease),box-shadow .4s var(--ease),padding .4s var(--ease);
  padding:14px 0;
}
.nav.solid{background:rgba(251,248,242,.92);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line),0 12px 30px -24px rgba(20,33,61,.4)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:68px;width:auto;transition:.4s var(--ease)}
.nav.solid .brand img{height:54px}
.brand .logo-light{display:block}
.brand .logo-dark{display:none}
.nav.solid .brand .logo-light{display:none}
.nav.solid .brand .logo-dark{display:block}

.menu{display:flex;align-items:center;gap:30px}
.menu a{
  font-size:.82rem;font-weight:600;letter-spacing:.02em;color:#fff;position:relative;padding:4px 0;
  transition:color .3s;
}
.nav.solid .menu a{color:var(--navy)}
.menu a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--gold);transition:width .3s var(--ease)}
.menu a:hover::after,.menu a.active::after{width:100%}
.menu a:hover{color:var(--gold)}
.nav.solid .menu a:hover{color:var(--gold-deep)}
.nav-cta{display:flex;align-items:center;gap:16px}
.nav-cta .btn{padding:11px 22px;font-size:.82rem}
.btn-phone{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:.84rem;color:#fff;letter-spacing:.01em}
.btn-phone i{color:var(--gold);font-size:.9em}
.nav.solid .btn-phone{color:var(--navy)}
.btn-phone:hover{color:var(--gold)}
.nav.solid .btn-phone:hover{color:var(--gold-deep)}

.burger{display:none;flex-direction:column;gap:5px;padding:8px}
.burger span{width:26px;height:2px;background:#fff;transition:.3s}
.nav.solid .burger span{background:var(--navy)}

@media(max-width:1080px){
  .menu{display:none}
  .nav-cta .btn-phone{display:none}
  .burger{display:flex}
}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:80;background:var(--navy);color:#fff;
  transform:translateX(100%);transition:transform .45s var(--ease);
  display:flex;flex-direction:column;padding:28px var(--gut)}
.drawer.open{transform:translateX(0)}
.drawer-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px}
.drawer-top img{height:46px}
.drawer .x{font-size:2rem;color:#fff;line-height:1}
.drawer nav{display:flex;flex-direction:column;gap:6px}
.drawer nav a{font-family:var(--serif);font-size:2rem;color:#fff;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.drawer nav a:hover{color:var(--gold)}
.drawer .drawer-foot{margin-top:auto;color:rgba(255,255,255,.7);font-size:.9rem;display:flex;flex-direction:column;gap:6px}
.drawer .drawer-foot a{color:var(--gold-soft)}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;color:#fff;margin-top:-96px;padding-top:96px}
.hero-bg{position:absolute;inset:0;z-index:-2;overflow:hidden}
.hero-bg .hb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1.8s ease;will-change:opacity}
.hero-bg .hb.active{opacity:1;animation:heroZoom 9s ease-out forwards}
@keyframes heroZoom{to{transform:scale(1)}}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:
    linear-gradient(95deg,rgba(16,26,50,.82) 0%,rgba(16,26,50,.55) 34%,rgba(16,26,50,.12) 60%,rgba(16,26,50,0) 78%),
    linear-gradient(180deg,rgba(16,26,50,.55) 0%,rgba(16,26,50,.25) 26%,rgba(16,26,50,.35) 62%,rgba(16,26,50,.9) 100%)}
.hero-inner{padding-bottom:clamp(40px,7vw,90px);width:100%}
.hero .eyebrow{color:#F3E9D8;text-shadow:0 1px 16px rgba(16,26,50,.6)}
.hero .eyebrow::before{background:var(--gold)}
.hero .eyebrow .s-num{color:var(--gold-soft)}
.hero h1{color:#fff;font-size:clamp(2.4rem,5.2vw,4.6rem);max-width:16ch;margin:20px 0 22px;
  text-shadow:0 2px 30px rgba(16,26,50,.6),0 1px 4px rgba(16,26,50,.4)}
.hero h1 em{font-style:italic;color:#EBC998}
.hero p.lead{color:#fff;max-width:46ch;margin-bottom:32px;font-weight:500;
  text-shadow:0 1px 3px rgba(16,26,50,.55),0 2px 22px rgba(16,26,50,.5)}
.hero p.lead strong{color:#fff}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.hero-facts{display:flex;gap:0;margin-top:clamp(40px,6vw,72px);border-top:1px solid rgba(255,255,255,.22);flex-wrap:wrap}
.hero-facts .f{padding:22px 40px 4px 0;margin-right:40px;border-right:1px solid rgba(255,255,255,.18)}
.hero-facts .f:last-child{border-right:none}
.hero-facts .f b{font-family:var(--serif);font-size:clamp(1.7rem,2.6vw,2.4rem);color:#fff;display:block;line-height:1}
.hero-facts .f span{font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-soft)}
.scroll-cue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;
  color:rgba(255,255,255,.7);font-size:.68rem;letter-spacing:.25em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-cue i{width:1px;height:40px;background:linear-gradient(var(--gold-soft),transparent);animation:cue 1.8s infinite}
@keyframes cue{0%{transform:scaleY(.3);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(.3);transform-origin:bottom}}
@media(max-width:720px){.hero-facts .f{margin-right:22px;padding-right:22px}}

/* marquee band */
.marquee{background:var(--navy);color:var(--gold-soft);overflow:hidden;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.marquee-track{display:flex;gap:60px;white-space:nowrap;animation:scroll 34s linear infinite;font-family:var(--serif);font-size:1.35rem;font-style:italic}
.marquee-track span{display:inline-flex;align-items:center;gap:60px;color:rgba(228,203,168,.85)}
.marquee-track span::after{content:"\f111";font-family:"Font Awesome 6 Free";font-weight:900;font-size:.4rem;color:var(--gold);transform:translateY(-4px)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ============================================================
   INTRO / O inwestycji
   ============================================================ */
.intro{background:var(--cream)}
.intro-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(40px,6vw,90px);align-items:center}
.intro-copy h2{margin:20px 0 22px}
.intro-copy .lead{margin-bottom:26px}
.intro-sign{margin-top:30px;display:flex;align-items:center;gap:16px;color:var(--muted);font-size:.9rem}
.intro-sign b{font-family:var(--serif);font-size:1.5rem;color:var(--navy)}
.intro-visual{position:relative}
.intro-visual img{border-radius:var(--r);box-shadow:var(--shadow);width:100%;height:560px;object-fit:cover}
.intro-badge{position:absolute;left:-26px;bottom:-26px;background:var(--gold);color:var(--navy);
  padding:26px 30px;border-radius:var(--r);box-shadow:var(--shadow-soft);max-width:230px}
.intro-badge b{font-family:var(--serif);font-size:2.6rem;line-height:1;display:block}
.intro-badge span{font-size:.82rem;font-weight:600}
@media(max-width:900px){.intro-grid{grid-template-columns:1fr}.intro-visual img{height:420px}.intro-badge{left:0}}

/* pillars */
.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:clamp(50px,7vw,84px)}
.pillar{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:32px 28px;transition:.4s var(--ease)}
.pillar:hover{transform:translateY(-6px);box-shadow:var(--shadow-soft);border-color:transparent}
.pillar .ic{width:52px;height:52px;border-radius:12px;background:var(--sand);display:grid;place-items:center;margin-bottom:20px;color:var(--gold-deep)}
.pillar:hover .ic{background:var(--navy);color:var(--gold)}
.pillar .ic i{font-size:23px}
.pillar h4{font-size:1.35rem;margin-bottom:8px}
.pillar p{font-size:.92rem;color:var(--muted)}
@media(max-width:900px){.pillars{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.pillars{grid-template-columns:1fr}}

/* ============================================================
   AMENITIES / lifestyle split
   ============================================================ */
.life{background:var(--navy);color:#fff;overflow:hidden}
.life-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch}
.life-media{position:relative;min-height:600px}
.life-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.life-copy{padding:clamp(50px,7vw,110px) clamp(30px,5vw,80px)}
.life-copy h2{color:#fff;margin:20px 0 24px}
.life-copy .lead{color:rgba(255,255,255,.75)}
.amen-list{list-style:none;margin-top:34px;display:grid;grid-template-columns:1fr 1fr;gap:16px 24px}
.amen-list li{display:flex;gap:14px;align-items:center;font-size:.94rem;color:rgba(255,255,255,.9)}
.amen-list li i{font-size:17px;color:var(--gold);flex:none;width:24px;text-align:center}
@media(max-width:900px){.life-grid{grid-template-columns:1fr}.life-media{min-height:380px}.amen-list{grid-template-columns:1fr}}

/* ============================================================
   OFERTA / apartamenty
   ============================================================ */
.offer{background:var(--sand)}
.offer-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:44px}
.offer-head h2{margin:16px 0 0}
.offer-head .lead{margin-top:14px}

.tabs{display:inline-flex;background:var(--white);border:1px solid var(--line);border-radius:100px;padding:5px}
.tabs button{padding:10px 26px;border-radius:100px;font-weight:700;font-size:.85rem;color:var(--muted);transition:.3s}
.tabs button.active{background:var(--navy);color:#fff}

.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:34px 0 40px}
.stat-row .s{position:relative;background:var(--white);border:1px solid var(--line);border-radius:12px;padding:24px 26px;transition:.35s var(--ease)}
.stat-row .s:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft);border-color:transparent}
.stat-row .s .s-ic{position:absolute;top:20px;right:20px;width:38px;height:38px;border-radius:10px;background:var(--sand);display:grid;place-items:center;color:var(--gold-deep);transition:.35s var(--ease)}
.stat-row .s:hover .s-ic{background:var(--navy);color:var(--gold)}
.stat-row .s .s-ic i{font-size:16px}
.stat-row .s b{display:block;font-family:var(--serif);font-size:2.4rem;color:var(--navy);line-height:1;margin-bottom:8px}
.stat-row .s span:last-child{display:block;font-size:.8rem;color:var(--muted);letter-spacing:.03em;text-transform:uppercase;font-weight:600}
@media(max-width:760px){.stat-row{grid-template-columns:1fr 1fr}}

.table-card{background:var(--white);border-radius:var(--r);box-shadow:var(--shadow-soft);overflow:hidden;border:1px solid var(--line)}
.table-scroll{overflow-x:auto}
table.units{width:100%;border-collapse:collapse;min-width:720px}
table.units thead th{
  text-align:left;font-family:var(--sans);font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold-deep);padding:20px 22px;background:var(--cream);border-bottom:1px solid var(--line);white-space:nowrap}
table.units tbody td{padding:17px 22px;border-bottom:1px solid var(--line);font-size:.92rem;white-space:nowrap}
table.units tbody tr{transition:background .25s}
table.units tbody tr:hover{background:var(--sand)}
table.units .u-id{font-weight:800;color:var(--navy);font-family:var(--serif);font-size:1.15rem}
table.units .u-price{font-weight:800;color:var(--navy)}
.badge{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:100px;font-size:.72rem;font-weight:700;letter-spacing:.02em}
.badge::before{content:"";width:7px;height:7px;border-radius:50%}
.b-avail{background:rgba(76,140,90,.12);color:#3d7a4c}.b-avail::before{background:#4c9a5f}
.b-sold{background:rgba(150,60,60,.1);color:#a3524f}.b-sold::before{background:#c06a66}
.b-hold{background:rgba(198,156,109,.15);color:var(--gold-deep)}.b-hold::before{background:var(--gold)}
.t-more{padding:20px 22px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;background:var(--cream)}
.t-more small{color:var(--muted)}
.u-cta{color:var(--gold-deep);font-weight:800;font-size:.82rem;display:inline-flex;align-items:center;gap:6px;transition:.25s}
.u-cta i{font-size:11px;transition:transform .25s var(--ease)}
.u-cta:hover{color:var(--navy)}
.u-cta:hover i{transform:translateX(3px)}

/* ===== interaktywna makieta 3D — tour ===== */
.tour{margin-top:26px;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);background:var(--navy)}
.tour-media{position:relative;min-height:clamp(340px,44vw,540px);overflow:hidden}
.tour-media>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.tour-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,33,61,.35),rgba(20,33,61,0) 30%,rgba(20,33,61,.55))}
.tour-flag{position:absolute;top:20px;left:20px;z-index:3;display:inline-flex;align-items:center;gap:9px;
  background:rgba(20,33,61,.7);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.18);
  color:#fff;padding:9px 16px;border-radius:100px;font-size:.78rem;font-weight:700;letter-spacing:.02em}
.tour-flag i{color:var(--gold)}
.tour-drag{position:absolute;top:20px;right:20px;z-index:3;display:inline-flex;align-items:center;gap:9px;
  color:rgba(255,255,255,.85);font-size:.78rem;font-weight:600;background:rgba(20,33,61,.4);backdrop-filter:blur(6px);
  padding:9px 15px;border-radius:100px;border:1px solid rgba(255,255,255,.14)}
.tour-drag i{color:var(--gold-soft);animation:sway 2.6s ease-in-out infinite}
@keyframes sway{0%,100%{transform:translateX(-3px)}50%{transform:translateX(3px)}}
.tour-bar{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:4;display:flex;align-items:center;gap:10px;
  background:rgba(251,248,242,.95);backdrop-filter:blur(10px);border-radius:100px;padding:9px 12px;box-shadow:var(--shadow-soft);max-width:calc(100% - 32px);flex-wrap:wrap;justify-content:center}
.tour-bar button{width:42px;height:42px;border-radius:50%;background:transparent;color:var(--navy);display:grid;place-items:center;font-size:15px;transition:.25s}
.tour-bar button:hover{background:var(--navy);color:#fff}
.tour-360{display:flex;align-items:center;gap:4px;background:var(--white);border:1px solid var(--line);border-radius:100px;padding:4px}
.tour-360 button{width:34px;height:34px;font-size:13px}
.tour-360 span{font-weight:800;font-size:.82rem;color:var(--navy);padding:0 8px;font-variant-numeric:lining-nums}
.tour-dn{display:flex;align-items:center;gap:10px;background:var(--white);border:1px solid var(--line);border-radius:100px;padding:7px 8px 7px 16px}
.tour-dn>span{font-weight:700;font-size:.8rem;color:var(--navy)}
.tour-dn .dn{display:flex;background:var(--sand);border-radius:100px;padding:3px}
.tour-dn .dn i{width:30px;height:26px;display:grid;place-items:center;border-radius:100px;font-size:12px;color:var(--muted);transition:.25s}
.tour-dn .dn i.active{background:var(--gold);color:var(--navy)}
.tour-info{display:flex;align-items:center;justify-content:space-between;gap:30px;padding:clamp(24px,3vw,38px) clamp(24px,3vw,44px);flex-wrap:wrap}
.tour-info .eyebrow{color:var(--gold-soft)}.tour-info .eyebrow::before{background:var(--gold-soft)}
.tour-info .eyebrow i{color:var(--gold-soft)}
.tour-info h3{color:#fff;font-size:clamp(1.5rem,2.3vw,2.1rem);margin:12px 0 8px;max-width:20ch}
.tour-info p{color:rgba(255,255,255,.72);max-width:52ch;font-size:.95rem}
.tour-feats{list-style:none;display:flex;flex-direction:column;gap:12px}
.tour-feats li{display:flex;align-items:center;gap:11px;color:rgba(255,255,255,.9);font-size:.92rem;white-space:nowrap}
.tour-feats li i{color:var(--gold)}
@media(max-width:820px){.tour-info{flex-direction:column;align-items:flex-start;gap:18px}.tour-dn>span{display:none}}

/* ============================================================
   WNĘTRZA gallery
   ============================================================ */
.gallery{background:var(--cream)}
.gal-grid{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:210px;gap:16px;margin-top:44px}
.gal-grid figure{overflow:hidden;border-radius:var(--r);position:relative;cursor:pointer}
.gal-grid img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.gal-grid figure:hover img{transform:scale(1.07)}
.gal-grid figure::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(20,33,61,.55));opacity:0;transition:.4s}
.gal-grid figure:hover::after{opacity:1}
.gal-grid figcaption{position:absolute;left:20px;bottom:16px;color:#fff;font-family:var(--serif);font-size:1.25rem;z-index:2;
  opacity:0;transform:translateY(8px);transition:.4s;display:flex;align-items:center;gap:11px}
.gal-grid figcaption i{font-size:.9rem;color:var(--gold-soft)}
.gal-grid figure:hover figcaption{opacity:1;transform:translateY(0)}
.g-a{grid-column:span 7;grid-row:span 2}
.g-b{grid-column:span 5;grid-row:span 1}
.g-c{grid-column:span 5;grid-row:span 1}
.g-d{grid-column:span 4;grid-row:span 1}
.g-e{grid-column:span 4;grid-row:span 1}
.g-f{grid-column:span 4;grid-row:span 1}
.g-g{grid-column:span 6;grid-row:span 1}
.g-h{grid-column:span 6;grid-row:span 1}
@media(max-width:820px){.gal-grid{grid-template-columns:1fr 1fr;grid-auto-rows:180px}
  .g-a,.g-b,.g-c,.g-d,.g-e,.g-f,.g-g,.g-h{grid-column:span 1;grid-row:span 1}.g-a{grid-column:span 2;grid-row:span 2}}

/* ============================================================
   MASTERPLAN / PZT
   ============================================================ */
.plan{background:var(--sand-2)}
.plan-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(36px,5vw,70px);align-items:center}
.plan-visual{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);background:#fff;padding:18px;border:1px solid var(--line)}
.plan-visual img{border-radius:8px;width:100%}
.plan h2{margin:18px 0 20px}
.plan-legend{display:flex;flex-direction:column;gap:14px;margin-top:26px}
.plan-legend .pl{display:flex;gap:14px;align-items:center;font-size:.95rem}
.plan-legend .pl b{width:32px;height:32px;border-radius:8px;display:grid;place-items:center;color:#fff;font-family:var(--serif);font-size:1.1rem;flex:none}
@media(max-width:860px){.plan-grid{grid-template-columns:1fr}}

/* ============================================================
   OKOLICA / Dlaczego Sobieszewo
   ============================================================ */
.loc{background:var(--navy);color:#fff;overflow:hidden}
.loc .eyebrow{color:var(--gold-soft)}.loc .eyebrow::before,.loc .eyebrow.center::after{background:var(--gold-soft)}
.loc h2{color:#fff}
.loc-top{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:center;margin-bottom:60px}
.loc-top .lead{color:rgba(255,255,255,.78)}
.reels{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:34px}
.reel{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:9/13;background:#0d1526;cursor:pointer}
.reel img{width:100%;height:100%;object-fit:cover;opacity:.82;transition:.6s}
.reel:hover img{opacity:1;transform:scale(1.05)}
.reel .play{position:absolute;inset:0;display:grid;place-items:center}
.reel .play span{width:58px;height:58px;border-radius:50%;background:rgba(255,255,255,.18);backdrop-filter:blur(6px);
  border:1px solid rgba(255,255,255,.4);display:grid;place-items:center;transition:.3s}
.reel:hover .play span{background:var(--gold);border-color:var(--gold)}
.reel .play i{font-size:18px;color:#fff;margin-left:3px}
.reel:hover .play i{color:var(--navy)}
.reel .rl-cap{position:absolute;left:16px;bottom:14px;font-family:var(--serif);font-size:1.15rem;z-index:2;display:flex;align-items:center;gap:9px}
.reel .rl-cap i{font-size:.85rem;color:var(--gold-soft)}
.reel::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(13,21,38,.75));pointer-events:none}
.reel video{width:100%;height:100%;object-fit:cover;display:block;opacity:.94;transition:opacity .6s}
.reel:hover video{opacity:1}
.reel .rl-sound{position:absolute;top:12px;right:12px;z-index:3;width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.35);background:rgba(13,21,38,.55);backdrop-filter:blur(6px);color:#fff;cursor:pointer;display:grid;place-items:center;transition:.3s}
.reel .rl-sound:hover{background:var(--gold);border-color:var(--gold);color:var(--navy)}
.reel .rl-sound i{font-size:14px;line-height:1}

.dist-wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,6vw,70px);align-items:start;margin-top:0}
.dist-map{position:relative;border-radius:var(--r);overflow:hidden;min-height:420px;border:1px solid rgba(255,255,255,.14)}
.dist-map img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;opacity:.9}
.dist-map .pin{position:absolute;left:50%;top:46%;transform:translate(-50%,-50%);z-index:3}
.dist-map .pin b{display:grid;place-items:center;width:56px;height:56px;background:var(--gold);color:var(--navy);border-radius:50% 50% 50% 4px;transform:rotate(45deg);box-shadow:0 10px 30px rgba(0,0,0,.4)}
.dist-map .pin b img{width:26px;height:26px;transform:rotate(-45deg);position:static;opacity:1}
.dist-map .pin .pulse{position:absolute;inset:-10px;border:2px solid var(--gold);border-radius:50%;animation:pulse 2.4s infinite;opacity:.6}
@keyframes pulse{to{transform:scale(2.4);opacity:0}}
.dist-h{color:var(--gold-soft);font-family:var(--sans);font-size:.82rem;letter-spacing:.2em;text-transform:uppercase;font-weight:700;margin-bottom:18px}
.dist-list{list-style:none;display:flex;flex-direction:column;gap:11px}
.dist-list li{display:flex;align-items:center;gap:22px;padding:15px 22px;border:1px solid rgba(255,255,255,.12);border-left:2px solid var(--gold);border-radius:10px;background:rgba(255,255,255,.02);transition:.25s}
.dist-list li:hover{background:rgba(230,203,168,.06);border-left-color:var(--gold-soft);transform:translateX(3px)}
.dist-list li .d-num{font-family:var(--serif);font-size:2rem;color:#fff;line-height:1;min-width:84px;display:flex;align-items:baseline;gap:5px;font-variant-numeric:lining-nums}
.dist-list li .d-num small{font-family:var(--sans);font-size:.56rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-soft)}
.dist-list li .d-place{color:rgba(255,255,255,.92);font-size:1rem}
.dist-wrap .map-canvas{height:clamp(420px,52vw,600px)}

/* ============================================================
   Sygnatura: subtelna złota ramka za zdjęciem + ornament-kółka
   ============================================================ */
.framed{position:relative;overflow:visible}
.framed>*{position:relative;z-index:1}
.framed::after{content:"";position:absolute;inset:0;transform:translate(15px,15px);border:1px solid rgba(198,156,109,.5);border-radius:var(--r);z-index:0;pointer-events:none}
@media(max-width:860px){.framed::after{transform:translate(9px,9px)}}

.intro,.gallery,.offer,.plan,.about,.diary{position:relative;overflow:hidden}
.intro .wrap,.gallery .wrap,.offer .wrap,.plan .wrap,.about .wrap,.diary .wrap{position:relative;z-index:1}
.intro::before,.gallery::before,.offer::before,.about::before,.plan::before,.diary::before{
  content:"";position:absolute;z-index:0;pointer-events:none;top:-13%;right:-7%;
  width:min(48vw,600px);height:min(48vw,600px);border-radius:50%;border:1px solid rgba(20,33,61,.06)}
.intro::after,.about::after{content:"";position:absolute;z-index:0;pointer-events:none;
  top:-13%;right:-7%;width:min(30vw,380px);height:min(30vw,380px);border-radius:50%;
  border:1px solid rgba(20,33,61,.05);transform:translate(110px,110px)}

/* ornament-kółka na sekcjach GRANATOWYCH (złote, subtelne) — bez .contact (sticky) */
.life,.partner{position:relative;overflow:hidden}
.loc{position:relative}
.life .wrap,.life .life-grid,.partner .wrap,.loc .wrap{position:relative;z-index:1}
.life::before,.partner::before,.loc::before{content:"";position:absolute;z-index:0;pointer-events:none;
  top:-13%;right:-7%;width:min(48vw,600px);height:min(48vw,600px);border-radius:50%;border:1px solid rgba(230,203,168,.16)}
.partner::after,.loc::after{content:"";position:absolute;z-index:0;pointer-events:none;
  top:-13%;right:-7%;width:min(30vw,380px);height:min(30vw,380px);border-radius:50%;border:1px solid rgba(230,203,168,.11);transform:translate(110px,110px)}
/* złota ramka-offset wokół slidera Moon Yachts */
.partner-frame{align-self:stretch;height:100%}

/* etykieta wyspy Sobieszewskiej na mapie */
.map-mk--island .mk-island{font-family:var(--serif);font-style:italic;font-size:1.05rem;color:var(--gold-deep);font-weight:600;white-space:nowrap;text-shadow:0 1px 4px rgba(255,255,255,.95),0 0 2px rgba(255,255,255,.95)}
@media(max-width:860px){.loc-top,.dist-wrap{grid-template-columns:1fr}.reels{grid-template-columns:1fr 1fr}.dist-map{min-height:300px}}

/* ============================================================
   DZIENNIK BUDOWY
   ============================================================ */
.diary{background:var(--cream)}
.diary-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,64px);align-items:center}
.diary-media{position:relative}
.diary-media img{border-radius:var(--r);box-shadow:var(--shadow);width:100%;height:500px;object-fit:cover}
.diary-media .cap{position:absolute;left:20px;bottom:20px;background:rgba(20,33,61,.85);backdrop-filter:blur(6px);color:#fff;padding:10px 18px;border-radius:100px;font-size:.8rem;font-weight:600;display:flex;align-items:center;gap:9px}
.diary-media .cap i{color:var(--gold-soft)}
.diary-media .cap b{color:var(--gold-soft)}
.timeline{list-style:none;margin-top:34px;position:relative;padding-left:34px}
.timeline::before{content:"";position:absolute;left:9px;top:6px;bottom:6px;width:2px;background:var(--line)}
.timeline li{position:relative;padding:0 0 26px}
.timeline li::before{content:"";position:absolute;left:-34px;top:3px;width:20px;height:20px;border-radius:50%;background:var(--cream);border:2px solid var(--gold);}
.timeline li.done::before{background:var(--gold)}
.timeline li.now::before{border-color:var(--navy);box-shadow:0 0 0 5px rgba(20,33,61,.1)}
.timeline .tl-date{font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep);font-weight:700}
.timeline h4{font-size:1.3rem;margin:3px 0 4px}
.timeline p{font-size:.9rem;color:var(--muted)}
.diary-thumbs{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px}
.diary-thumbs img{border-radius:8px;height:100px;width:100%;object-fit:cover}
@media(max-width:860px){.diary-grid{grid-template-columns:1fr}.diary-media img{height:340px}}

/* ---- animowana oś czasu / roadmap ---- */
.roadmap{margin-top:clamp(30px,5vw,58px)}
.rm-track{position:relative;height:3px;background:var(--line);border-radius:3px;margin:11px clamp(6px,3vw,40px) 0}
.rm-fill{position:absolute;left:0;top:0;height:100%;width:0;background:linear-gradient(90deg,var(--gold-deep),var(--gold));border-radius:3px;transition:width 1.9s var(--ease)}
.roadmap.in .rm-fill{width:var(--progress,45%)}
.rm-steps{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2.5vw,34px);margin-top:-11px;padding:0 clamp(6px,3vw,40px)}
.rm-steps li{position:relative;padding-top:36px}
.rm-node{position:absolute;top:0;left:0;width:22px;height:22px;border-radius:50%;background:#fff;border:2px solid var(--gold);transition:.5s .3s}
.roadmap.in .rm-steps li.done .rm-node{background:var(--gold);border-color:var(--gold)}
.roadmap.in .rm-steps li.now .rm-node{border-color:var(--navy);background:var(--navy);box-shadow:0 0 0 6px rgba(20,33,61,.12)}
.rm-steps li.now .rm-node::after{content:"";position:absolute;inset:-2px;border-radius:50%;border:2px solid var(--navy);opacity:0}
.roadmap.in .rm-steps li.now .rm-node::after{animation:rmPulse 2.2s ease-out 1.6s infinite}
@keyframes rmPulse{0%{transform:scale(1);opacity:.55}100%{transform:scale(2.5);opacity:0}}
.rm-when{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep);font-weight:700}
.rm-steps li.now .rm-when{color:var(--navy)}
.rm-steps h4{font-size:1.18rem;margin:5px 0 6px;line-height:1.15}
.rm-steps p{font-size:.9rem;color:var(--muted);line-height:1.55;margin:0}
.rm-now-tag{display:inline-flex;align-items:center;gap:6px;margin-top:10px;font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--navy);background:var(--gold-soft);padding:4px 11px;border-radius:100px}
.rm-now-tag i{font-size:.72rem}
@media(max-width:860px){
  .rm-track{display:none}
  .rm-steps{grid-template-columns:1fr;gap:0;margin-top:6px;padding:0 0 0 0;position:relative}
  .rm-steps::before{content:"";position:absolute;left:10px;top:10px;bottom:14px;width:2px;background:var(--line)}
  .rm-steps li{padding:0 0 26px 40px}
  .rm-node{left:0;top:2px}
}

/* ---- box wyróżnienia inwestora (o nas) ---- */
.about-award{margin-top:28px;display:flex;gap:16px;align-items:flex-start;padding:18px 22px;background:rgba(198,156,109,.09);border:1px solid rgba(198,156,109,.28);border-left:3px solid var(--gold);border-radius:12px}
.about-award .aw-ic2{width:44px;height:44px;flex:none;border-radius:11px;background:var(--navy);color:var(--gold-soft);display:grid;place-items:center;font-size:1.05rem}
.about-award .aw-tt{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);font-weight:700}
.about-award h5{font-family:var(--serif);font-size:1.14rem;margin:2px 0 4px;color:var(--navy);font-weight:600}
.about-award p{font-size:.9rem;color:var(--muted);line-height:1.5;margin:0}
.about-visual.single{display:block}
.about-visual.single img{width:100%;height:100%;min-height:440px;max-height:600px;object-fit:cover;border-radius:var(--r)}

/* ============================================================
   O NAS
   ============================================================ */
.about{background:var(--white)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:center}
.about h2{margin:18px 0 22px}
.awards{display:flex;gap:20px;flex-wrap:wrap;margin-top:38px}
.award{flex:1;min-width:150px;display:flex;flex-direction:column;gap:4px;padding:22px 22px;background:var(--cream);border:1px solid var(--line);border-radius:12px;transition:.35s var(--ease)}
.award:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft)}
.award .aw-ic{width:40px;height:40px;border-radius:10px;background:var(--white);border:1px solid var(--line);display:grid;place-items:center;color:var(--gold-deep);margin-bottom:8px}
.award .aw-ic i{font-size:17px}
.award b{font-family:var(--serif);font-size:3.4rem;color:var(--navy);line-height:1;display:flex;align-items:baseline;gap:1px}
.award b .suf{font-size:.42em;color:var(--gold-deep);font-weight:700}
.award span{font-size:.82rem;color:var(--muted)}
.about-visual{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.about-visual img{border-radius:var(--r);width:100%;height:100%;object-fit:cover}
.about-visual img:first-child{grid-row:span 2;height:100%}
@media(max-width:860px){.about-grid{grid-template-columns:1fr}.about-visual img:first-child{grid-row:auto;height:280px}}

/* ============================================================
   KONTAKT
   ============================================================ */
.contact{background:var(--navy);color:#fff}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(40px,6vw,80px)}
.contact .eyebrow{color:var(--gold-soft)}.contact .eyebrow::before{background:var(--gold-soft)}
.contact h2{color:#fff;margin:18px 0 22px}
.contact-lead{color:rgba(255,255,255,.75);margin-bottom:34px}
.contact-info{list-style:none;display:flex;flex-direction:column;gap:22px}
.contact-info li{display:flex;gap:16px;align-items:flex-start}
.contact-info .ci-ic{width:46px;height:46px;border-radius:12px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);display:grid;place-items:center;color:var(--gold);flex:none}
.contact-info .ci-ic i{font-size:18px}
.contact-info small{color:rgba(255,255,255,.55);font-size:.76rem;letter-spacing:.1em;text-transform:uppercase;display:block;margin-bottom:2px}
.contact-info b{font-size:1.08rem;font-weight:600}
.c-advisor{display:flex;flex-direction:column;margin-top:4px}
.c-advisor-photo{position:relative;margin:0;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);max-width:300px}
.c-advisor-photo img{width:100%;display:block;aspect-ratio:4/3.7;object-fit:cover;object-position:top center;transition:transform .8s var(--ease)}
.c-advisor-photo:hover img{transform:scale(1.05)}
.c-advisor-badge{position:absolute;left:14px;bottom:14px;background:rgba(20,33,61,.82);backdrop-filter:blur(6px);color:#fff;font-size:.74rem;font-weight:700;padding:7px 13px;border-radius:100px;display:flex;align-items:center;gap:7px}
.c-advisor-badge i{color:var(--gold-soft)}
.c-advisor-data{margin-top:20px}
.c-advisor-name{font-family:var(--serif);font-size:1.55rem;color:#fff;display:block;line-height:1}
.c-advisor-role{color:var(--gold-soft);font-size:.86rem;display:block;margin:6px 0 22px}
.c-advisor .contact-info{gap:16px}

/* ============================================================
   MULTI-PAGE — divider sekcji (jak Dekpol), header podstron,
   teasery, pasek CTA, prawdziwe logo Moon Yachts
   ============================================================ */
/* centralny divider sekcji — „— o inwestycji —" */
.sec-divider{display:flex;align-items:center;justify-content:center;gap:clamp(16px,2.5vw,28px);margin:clamp(4px,1.2vw,14px) 0 clamp(38px,5vw,62px)}
.sec-divider::before,.sec-divider::after{content:"";width:clamp(42px,7vw,88px);height:2px;background:var(--navy);border-radius:2px}
.sec-divider span{font-family:var(--serif);font-weight:600;color:var(--navy);font-size:clamp(1.7rem,3.3vw,2.5rem);line-height:1;white-space:nowrap;text-transform:lowercase;letter-spacing:.005em;text-align:center}
.sec-divider.on-dark span{color:#fff}
.sec-divider.on-dark::before,.sec-divider.on-dark::after{background:var(--gold-soft)}
.sec-sub{text-align:center;color:var(--muted);max-width:62ch;margin:calc(-1 * clamp(20px,3vw,36px)) auto clamp(38px,5vw,58px);font-size:clamp(1.02rem,1.4vw,1.18rem)}
.sec-divider.on-dark + .sec-sub{color:rgba(255,255,255,.75)}

/* aktywny link w nawigacji + solidny header na podstronach */
.menu a.active::after{width:100%}
body.inner .nav{background:rgba(251,248,242,.96);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line),0 12px 30px -24px rgba(20,33,61,.4)}
body.inner .nav .brand .logo-light{display:none}
body.inner .nav .brand .logo-dark{display:block}
body.inner .nav .brand img{height:56px}
body.inner .nav .menu a{color:var(--navy)}
body.inner .nav .menu a.active{color:var(--gold-deep)}
body.inner .nav .menu a:hover{color:var(--gold-deep)}
body.inner .nav .btn-phone{color:var(--navy)}
body.inner .nav .btn-phone:hover{color:var(--gold-deep)}
body.inner .nav .burger span{background:var(--navy)}

/* banner podstrony */
/* banner podstrony — asymetryczny hero: panel z tekstem + kadr w złotej ramce */
.page-hero{position:relative;overflow:hidden;color:#fff;padding:clamp(38px,5.5vw,76px) 0 clamp(46px,6.5vw,90px);
  background:linear-gradient(118deg,#0F1A31,var(--navy) 46%,var(--navy-2))}
.page-hero::before{content:"";position:absolute;inset:0;opacity:.07;background:radial-gradient(circle at 86% 16%,var(--gold),transparent 44%)}
.page-hero .ph-orn{position:absolute;right:-70px;top:-60px;width:360px;height:360px;border:1px solid rgba(230,203,168,.14);border-radius:50%;z-index:1;pointer-events:none}
.page-hero .ph-orn::after{content:"";position:absolute;inset:38px;border:1px solid rgba(230,203,168,.1);border-radius:50%}
.ph-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.06fr .94fr;gap:clamp(30px,5vw,64px);align-items:center}
.page-hero .crumbs{font-size:.8rem;color:rgba(255,255,255,.62);margin-bottom:22px;display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.page-hero .crumbs a{color:rgba(255,255,255,.62)}
.page-hero .crumbs a:hover{color:var(--gold-soft)}
.page-hero .crumbs i{font-size:.66em;color:var(--gold-soft)}
.crumbs-dark{font-size:.8rem;color:rgba(255,255,255,.6);margin-bottom:18px;display:flex;align-items:center;justify-content:center;gap:9px;flex-wrap:wrap}
.crumbs-dark a{color:rgba(255,255,255,.6)}
.crumbs-dark a:hover{color:var(--gold-soft)}
.crumbs-dark i{font-size:.66em;color:var(--gold-soft)}
.page-hero .ph-kick{color:var(--gold-soft);font-weight:600;letter-spacing:.2em;text-transform:lowercase;font-size:.8rem;display:inline-flex;align-items:center;gap:.7em;margin-bottom:16px}
.page-hero .ph-kick::before{content:"";width:30px;height:1px;background:var(--gold-soft)}
.page-hero h1{color:#fff;font-size:clamp(2.3rem,4.9vw,3.9rem);line-height:1.02;margin-bottom:18px;letter-spacing:-.01em}
.page-hero h1 em{font-style:italic;color:var(--gold-soft)}
.page-hero .ph-lead{color:rgba(255,255,255,.8);max-width:56ch;font-size:clamp(1.02rem,1.4vw,1.18rem)}
.ph-meta{display:flex;flex-wrap:wrap;gap:11px;margin-top:28px}
.ph-meta span{display:inline-flex;align-items:center;gap:9px;padding:10px 16px;border:1px solid rgba(255,255,255,.16);border-radius:100px;background:rgba(255,255,255,.04);font-size:.82rem;font-weight:600;color:rgba(255,255,255,.9)}
.ph-meta i{color:var(--gold-soft);font-size:.95em}
.ph-media{position:relative}
.ph-media img{width:100%;aspect-ratio:4/3.5;object-fit:cover;border-radius:var(--r);display:block;position:relative;z-index:2;box-shadow:0 34px 70px -34px rgba(0,0,0,.7)}
.ph-media::after{content:"";position:absolute;inset:0;transform:translate(16px,16px);border:1px solid rgba(230,203,168,.55);border-radius:var(--r);z-index:1}
.ph-badge{position:absolute;left:-16px;bottom:26px;z-index:3;background:var(--gold);color:var(--navy);border-radius:14px;padding:12px 20px;display:flex;flex-direction:column;line-height:1.06;box-shadow:0 18px 34px -16px rgba(20,33,61,.6)}
.ph-badge b{font-family:var(--serif);font-size:1.5rem;font-variant-numeric:lining-nums}
.ph-badge small{font-size:.72rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;opacity:.85}
@media(max-width:860px){.ph-grid{grid-template-columns:1fr;gap:22px}.ph-media{order:-1;max-width:520px}.ph-media::after{transform:translate(10px,10px)}.ph-badge{left:8px}}

/* prawdziwe logo Moon Yachts (białe SVG na granacie) */
.moon-logo-real{width:210px;max-width:62%;height:auto;display:block;margin-bottom:26px}

/* Home — kafle teaser do podstron */
.teasers{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.teaser{position:relative;border-radius:var(--r);overflow:hidden;min-height:300px;display:flex;align-items:flex-end;box-shadow:var(--shadow-soft);isolation:isolate}
.teaser img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform .8s var(--ease)}
.teaser::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(16,26,50,.08),rgba(16,26,50,.84))}
.teaser:hover img{transform:scale(1.06)}
.teaser-in{padding:24px;color:#fff}
.teaser-in .tn{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-soft);font-weight:700}
.teaser-in h3{color:#fff;font-size:1.35rem;margin:7px 0 6px;letter-spacing:-.01em}
.teaser-in .tgo{font-size:.88rem;color:rgba(255,255,255,.82);display:inline-flex;align-items:center;gap:8px;font-weight:600}
.teaser-in .tgo i{color:var(--gold-soft);transition:transform .3s var(--ease)}
.teaser:hover .teaser-in .tgo i{transform:translateX(4px)}
@media(max-width:980px){.teasers{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.teasers{grid-template-columns:1fr}.teaser{min-height:230px}}

/* Home — pasek CTA do kontaktu */
.cta-band{background:var(--navy);color:#fff;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;opacity:.05;background:radial-gradient(circle at 80% 20%,var(--gold),transparent 45%)}
.cta-band .wrap{position:relative}
.cta-band h2{color:#fff}
.cta-band .lead{color:rgba(255,255,255,.8);margin:14px auto 0}
.cta-band .cta-actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:26px}
.map-teaser{position:relative}
.map-teaser .map-canvas{height:420px}

/* ============================================================
   SLIDER / CAROUSEL (jak na LP) + sticky formularz
   ============================================================ */
.slider{position:relative;overflow:hidden;border-radius:var(--r);box-shadow:var(--shadow)}
.slider .slides{display:flex;transition:transform .7s var(--ease);will-change:transform}
.slider .slide{position:relative;flex:0 0 100%;min-width:100%}
.slider .slide img{width:100%;height:100%;object-fit:cover;display:block}
.slider .slide-cap{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:56px 30px 30px;color:#fff;
  font-family:var(--serif);font-style:italic;font-size:clamp(1.05rem,1.8vw,1.55rem);text-align:center;
  background:linear-gradient(transparent,rgba(16,26,50,.78))}
.sl-prev,.sl-next{position:absolute;top:50%;transform:translateY(-50%);z-index:4;width:52px;height:52px;border-radius:50%;
  border:1px solid rgba(255,255,255,.5);background:rgba(16,26,50,.32);backdrop-filter:blur(4px);color:#fff;
  display:grid;place-items:center;cursor:pointer;transition:.25s;font-size:1rem}
.has-cursor .sl-prev,.has-cursor .sl-next{cursor:none}
.sl-prev:hover,.sl-next:hover{background:var(--gold);color:var(--navy);border-color:var(--gold)}
.sl-prev{left:18px}.sl-next{right:18px}
.sl-dots{position:absolute;left:0;right:0;bottom:16px;z-index:4;display:flex;gap:9px;justify-content:center}
.sl-dot{width:9px;height:9px;border-radius:50%;border:none;background:rgba(255,255,255,.5);cursor:pointer;transition:.3s;padding:0}
.sl-dot.active{background:var(--gold);width:26px;border-radius:10px}
.loc-slider .slide img{height:clamp(340px,50vw,600px)}
.partner-slider{height:100%}
.partner-slider .slides,.partner-slider .slide{height:100%}
.partner-slider .slide img{height:100%;min-height:clamp(340px,42vw,520px)}
.partner-slider .pm-tag{z-index:4}

/* sticky formularz kontaktu (bez pustego białego pola) */
.contact-grid{align-items:start}
@media(min-width:861px){.form-card{position:sticky;top:92px}}
.form-card{background:var(--white);border-radius:var(--r);padding:clamp(28px,4vw,44px);box-shadow:var(--shadow);color:var(--ink)}
.form-card h3{font-size:1.6rem;margin-bottom:6px}
.form-card p{color:var(--muted);font-size:.9rem;margin-bottom:24px}
.field{margin-bottom:16px}
.field label{display:block;font-size:.78rem;font-weight:700;color:var(--navy);margin-bottom:7px;letter-spacing:.02em}
.field input,.field select,.field textarea{
  width:100%;padding:13px 16px;border:1.5px solid var(--line);border-radius:10px;font-family:inherit;font-size:.92rem;color:var(--ink);
  background:var(--cream);transition:.25s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);background:#fff}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-card .btn{width:100%;justify-content:center;margin-top:8px}
.consent{font-size:.72rem;color:var(--muted);margin-top:14px;display:flex;gap:8px;align-items:flex-start}
.consent input{margin-top:3px}
.form-ok{background:rgba(76,140,90,.12);color:#3d7a4c;padding:14px;border-radius:10px;font-size:.9rem;font-weight:600;text-align:center;margin-top:14px;display:none}
.form-ok.show{display:block}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr}.field-row{grid-template-columns:1fr}}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:#0F1930;color:rgba(255,255,255,.7);padding:70px 0 30px}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand img{height:64px;margin-bottom:18px}
.footer-brand p{font-size:.9rem;max-width:34ch;color:rgba(255,255,255,.55)}
.footer h5{color:#fff;font-family:var(--sans);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:18px;font-weight:700}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.footer ul a{font-size:.9rem;color:rgba(255,255,255,.6)}
.footer ul a:hover{color:var(--gold-soft)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:26px;font-size:.8rem;color:rgba(255,255,255,.45);flex-wrap:wrap;gap:14px}
.footer-bottom .socials{display:flex;gap:12px}
.footer-bottom .socials a{width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.15);display:grid;place-items:center;transition:.3s}
.footer-bottom .socials a:hover{background:var(--gold);border-color:var(--gold);color:var(--navy)}
.footer-bottom .socials i{font-size:15px}
.footer ul a{display:flex;align-items:center;gap:10px}
.footer ul a i{color:var(--gold-deep);font-size:.72em;transition:transform .3s var(--ease)}
.footer ul a:hover i{transform:translateX(3px)}
.footer .foot-contact li{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.6);font-size:.9rem}
.footer .foot-contact li i{color:var(--gold);font-size:.85em;width:16px;text-align:center}
@media(max-width:860px){.footer-top{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.footer-top{grid-template-columns:1fr}}

/* concept ribbon */
.concept-ribbon{position:fixed;left:0;bottom:0;z-index:70;background:var(--gold);color:var(--navy);
  font-size:.72rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;padding:8px 18px;border-top-right-radius:10px;
  box-shadow:0 -6px 20px -8px rgba(0,0,0,.3);display:flex;align-items:center;gap:8px}
.concept-ribbon span{width:7px;height:7px;border-radius:50%;background:var(--navy);animation:blink 1.6s infinite}
@keyframes blink{50%{opacity:.25}}
@media(max-width:600px){.concept-ribbon{font-size:.62rem;padding:6px 12px}}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}.reveal.d4{transition-delay:.4s}

/* lightbox */
.lb{position:fixed;inset:0;z-index:100;background:rgba(15,25,48,.94);display:none;align-items:center;justify-content:center;padding:30px}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:88vh;border-radius:8px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lb .lb-x{position:absolute;top:24px;right:30px;color:#fff;font-size:2.4rem;line-height:1}
.lb .lb-cap{position:absolute;bottom:26px;left:0;right:0;text-align:center;color:var(--gold-soft);font-family:var(--serif);font-size:1.3rem}

/* ===== dodatkowe elementy (ikony / etykiety) ===== */
.life-tag{position:absolute;left:20px;bottom:20px;z-index:3;display:inline-flex;align-items:center;gap:9px;
  background:rgba(20,33,61,.72);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.16);
  color:#fff;padding:9px 16px;border-radius:100px;font-size:.78rem;font-weight:700}
.life-tag i{color:var(--gold)}
.plan-visual{position:relative}
.zoom-hint{position:absolute;right:30px;bottom:30px;z-index:3;display:inline-flex;align-items:center;gap:8px;
  background:var(--navy);color:#fff;padding:9px 16px;border-radius:100px;font-size:.76rem;font-weight:700;
  opacity:0;transform:translateY(6px);transition:.35s var(--ease);pointer-events:none}
.plan-visual:hover .zoom-hint{opacity:1;transform:translateY(0)}
.zoom-hint i{color:var(--gold)}
.consent{align-items:flex-start}
.consent span{flex:1}
.form-ok{display:none;align-items:center;justify-content:center;gap:9px}
.form-ok.show{display:flex}
.form-ok i{font-size:1.05em}
.topbar .lang{border:1px solid rgba(255,255,255,.25);border-radius:6px;padding:2px 9px;font-weight:700;font-size:.72rem}
.topbar .lang:hover{border-color:var(--gold);color:var(--gold-soft)}

/* ============================================================
   CUSTOM CURSOR
   ============================================================ */
.has-cursor,
.has-cursor a,.has-cursor button,.has-cursor .apt-row,
.has-cursor input,.has-cursor select,.has-cursor textarea,
.has-cursor label,.has-cursor [data-lb],.has-cursor .reel,
.has-cursor .tabs button,.has-cursor .dn i{cursor:none}
.cursor-dot{position:fixed;top:0;left:0;width:7px;height:7px;margin:-3.5px 0 0 -3.5px;border-radius:50%;
  background:var(--gold);z-index:99998;pointer-events:none}
.cursor-ring{position:fixed;top:0;left:0;width:36px;height:36px;margin:-18px 0 0 -18px;border:1.5px solid var(--gold);
  border-radius:50%;z-index:99998;pointer-events:none;
  transition:width .32s var(--ease),height .32s var(--ease),margin .32s var(--ease),background .32s var(--ease),opacity .3s}
.cursor-ring.hover{width:58px;height:58px;margin:-29px 0 0 -29px;background:rgba(198,156,109,.14)}
.cursor-ring.down{width:26px;height:26px;margin:-13px 0 0 -13px;background:rgba(198,156,109,.2)}
@media (hover:none){.cursor-dot,.cursor-ring{display:none}}

/* magnetic buttons need smooth return */
.btn-gold,.btn-navy,.nav-cta .btn{will-change:transform}

/* ---------- tour: night mode + grab ---------- */
.tour-media>img{transition:opacity .35s var(--ease),filter .6s var(--ease)}
.tour-media{cursor:grab}
.has-cursor .tour-media{cursor:none}
.tour-media.grabbing{cursor:grabbing}
.tour-media.is-night>img{filter:brightness(.5) saturate(1.15) hue-rotate(205deg) contrast(1.08)}
.tour-media.is-night::after{background:linear-gradient(180deg,rgba(10,18,40,.5),rgba(10,18,40,.1) 30%,rgba(8,14,32,.8))}
.tour-media.is-night .tour-flag i{color:var(--gold-soft)}
.apt-row{cursor:pointer}
table.units tbody tr.apt-row:hover .u-id{color:var(--gold-deep)}

/* subtle premium float for hero facts numbers on load handled by reveal already */
.hero-facts .f b{transition:color .3s}

/* ============================================================
   PODSTRONA LOKALU (apartament.html)
   ============================================================ */
.aptx-top{background:var(--navy);position:sticky;top:0;z-index:60;border-bottom:1px solid rgba(255,255,255,.08)}
.aptx-top .wrap{display:flex;align-items:center;justify-content:space-between;height:76px;gap:20px}
.aptx-top .brand img{height:44px}
.aptx-back{display:inline-flex;align-items:center;gap:9px;color:#fff;font-weight:700;font-size:.86rem}
.aptx-back i{color:var(--gold);transition:transform .3s var(--ease)}
.aptx-back:hover i{transform:translateX(-4px)}
.aptx-top .aptx-phone{color:#fff;font-weight:700;font-size:.86rem;display:inline-flex;gap:8px;align-items:center}
.aptx-top .aptx-phone i{color:var(--gold)}
@media(max-width:640px){.aptx-top .aptx-phone{display:none}}

.aptx-hero{background:var(--sand);padding:36px 0 0}
.aptx-crumb{font-size:.8rem;color:var(--muted);display:flex;gap:8px;align-items:center;margin-bottom:18px}
.aptx-crumb a{color:var(--muted)}.aptx-crumb a:hover{color:var(--gold-deep)}
.aptx-crumb i{font-size:.6rem;color:var(--gold)}
.aptx-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;padding-bottom:34px}
.aptx-head .eyebrow{margin-bottom:14px}
.aptx-head h1{font-size:clamp(2.6rem,6vw,4.4rem);color:var(--navy);line-height:1}
.aptx-head h1 span{color:var(--gold)}
.aptx-head .aptx-badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}

.aptx-main{padding:clamp(40px,6vw,72px) 0}
.aptx-grid{display:grid;grid-template-columns:1.25fr .9fr;gap:clamp(30px,4vw,56px);align-items:start}
@media(max-width:900px){.aptx-grid{grid-template-columns:1fr}}

.aptx-gallery{display:grid;grid-template-columns:2fr 1fr;grid-auto-rows:150px;gap:12px;margin-bottom:30px}
.aptx-gallery figure{overflow:hidden;border-radius:var(--r);position:relative;cursor:pointer}
.aptx-gallery img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.aptx-gallery figure:hover img{transform:scale(1.06)}
.aptx-gallery .big{grid-column:1;grid-row:span 2}
.aptx-plan{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px;box-shadow:var(--shadow-soft)}
.aptx-plan h3{font-size:1.5rem;margin-bottom:6px}
.aptx-plan p{color:var(--muted);font-size:.92rem;margin-bottom:18px}
.aptx-plan-canvas{position:relative;border:1px dashed var(--gold);border-radius:10px;background:
  repeating-linear-gradient(45deg,var(--sand),var(--sand) 12px,var(--cream) 12px,var(--cream) 24px);
  min-height:280px;display:grid;place-items:center;overflow:hidden}
.aptx-plan-canvas .pc-rooms{position:absolute;inset:18px;display:grid;gap:10px}
.aptx-plan-canvas .rm{border:1.5px solid rgba(20,33,61,.35);border-radius:6px;background:rgba(255,255,255,.6);
  display:flex;align-items:flex-end;padding:8px 10px;font-size:.72rem;font-weight:700;color:var(--navy);letter-spacing:.02em}
.aptx-plan-badge{position:absolute;top:14px;right:14px;background:var(--navy);color:#fff;font-size:.7rem;font-weight:700;
  padding:6px 12px;border-radius:100px;letter-spacing:.06em}

.aptx-side{position:sticky;top:100px;background:#fff;border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--shadow);overflow:hidden}
.aptx-side-head{background:var(--navy);color:#fff;padding:24px 26px}
.aptx-side-head .as-id{font-family:var(--serif);font-size:2rem;line-height:1}
.aptx-side-head .as-sub{color:var(--gold-soft);font-size:.85rem;margin-top:4px}
.aptx-specs{list-style:none;padding:8px 26px}
.aptx-specs li{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--line);font-size:.95rem}
.aptx-specs li:last-child{border-bottom:none}
.aptx-specs .sp-ic{width:38px;height:38px;border-radius:10px;background:var(--sand);display:grid;place-items:center;color:var(--gold-deep);flex:none}
.aptx-specs .sp-l{color:var(--muted);font-size:.82rem}
.aptx-specs .sp-v{margin-left:auto;font-weight:800;color:var(--navy)}
.aptx-finish{margin:0 26px 20px;background:var(--sand);border-radius:12px;padding:16px 20px;display:flex;justify-content:space-between;align-items:center;gap:10px}
.aptx-finish .af-l{font-size:.78rem;color:var(--muted);max-width:16ch}
.aptx-finish .af-v{font-family:var(--serif);font-size:1.5rem;color:var(--navy);white-space:nowrap}
.aptx-cta{padding:0 26px 26px;display:flex;flex-direction:column;gap:12px}
.aptx-cta .btn{width:100%;justify-content:center}

.aptx-form{background:var(--navy);border-radius:var(--r);padding:clamp(26px,3vw,40px);color:#fff;margin-top:30px}
.aptx-form h3{color:#fff;font-size:1.6rem;margin-bottom:6px}
.aptx-form p{color:rgba(255,255,255,.7);font-size:.9rem;margin-bottom:22px}
.aptx-form .field label{color:#fff}
.aptx-form .field input,.aptx-form .field textarea{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.16);color:#fff}
.aptx-form .field input::placeholder,.aptx-form .field textarea::placeholder{color:rgba(255,255,255,.4)}
.aptx-form .field input:focus,.aptx-form .field textarea:focus{background:rgba(255,255,255,.1);border-color:var(--gold)}
.aptx-form .btn{width:100%;justify-content:center;margin-top:6px}
.aptx-form .consent{color:rgba(255,255,255,.6)}

.aptx-info{background:var(--cream);border-top:1px solid var(--line);padding:clamp(40px,6vw,72px) 0}
.aptx-info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.aptx-info .ii{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:28px}
.aptx-info .ii i{font-size:22px;color:var(--gold-deep);margin-bottom:14px;display:block}
.aptx-info .ii h4{font-size:1.3rem;margin-bottom:8px}
.aptx-info .ii p{font-size:.92rem;color:var(--muted)}
@media(max-width:820px){.aptx-info-grid{grid-template-columns:1fr}.aptx-gallery{grid-template-columns:1fr;grid-auto-rows:180px}.aptx-gallery .big{grid-column:1;grid-row:span 1}}

/* ============================================================
   LIGHTBOX — nawigacja galerii
   ============================================================ */
.lb-nav{position:fixed;top:50%;transform:translateY(-50%);width:56px;height:56px;border-radius:50%;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.32);color:#fff;display:grid;place-items:center;
  z-index:101;transition:.25s var(--ease)}
.lb-nav:hover{background:var(--gold);border-color:var(--gold);color:var(--navy)}
.lb-nav i{font-size:18px}
.lb-prev{left:clamp(14px,3vw,40px)}.lb-next{right:clamp(14px,3vw,40px)}
.lb-counter{position:fixed;top:26px;left:50%;transform:translateX(-50%);color:var(--gold-soft);
  font-weight:700;font-size:.9rem;letter-spacing:.14em;z-index:101}
.has-cursor .lb-nav,.has-cursor .lb-x{cursor:none}

/* ============================================================
   MAPA (Leaflet) — okolica
   ============================================================ */
.dist-map{padding:0}
.map-canvas{height:460px;width:100%;border-radius:var(--r);z-index:1}
.dist-map .map-gmaps{position:absolute;right:16px;bottom:16px;z-index:500;display:inline-flex;align-items:center;gap:8px;
  background:var(--navy);color:#fff;padding:9px 16px;border-radius:100px;font-size:.78rem;font-weight:700;box-shadow:var(--shadow-soft)}
.dist-map .map-gmaps:hover{background:var(--gold);color:var(--navy)}
.dist-map .map-gmaps i{color:var(--gold)}.dist-map .map-gmaps:hover i{color:var(--navy)}
.leaflet-container{font-family:var(--sans);background:#e8e4db}
.leaflet-popup-content{font-weight:600;color:var(--navy)}
.leaflet-popup-content b{font-family:var(--serif);font-size:1.05rem}
/* markery */
.map-mk{background:none;border:none}
.map-mk--main{display:flex;align-items:center;gap:8px}
.map-mk--main .mk-pin{width:20px;height:20px;border-radius:50% 50% 50% 3px;background:var(--gold);
  border:2.5px solid #fff;transform:rotate(45deg);box-shadow:0 5px 14px rgba(0,0,0,.4);flex:none}
.map-mk--main .mk-lbl{background:var(--navy);color:#fff;font-weight:800;font-size:.74rem;letter-spacing:.02em;
  padding:5px 11px;border-radius:100px;white-space:nowrap;box-shadow:0 4px 12px rgba(0,0,0,.3)}
.map-mk--poi{display:flex;align-items:center;gap:7px}
.map-mk--poi .mk-dot{width:12px;height:12px;border-radius:50%;background:var(--gold-deep);border:2px solid #fff;
  box-shadow:0 2px 6px rgba(0,0,0,.35);flex:none}
.map-mk--poi .mk-lbl2{background:rgba(255,255,255,.94);color:var(--navy);font-weight:700;font-size:.68rem;
  padding:3px 8px;border-radius:6px;white-space:nowrap;opacity:0;transform:translateX(-4px);transition:.25s;box-shadow:0 2px 8px rgba(0,0,0,.18)}
.map-mk--poi:hover{z-index:600!important}
.map-mk--poi:hover .mk-lbl2{opacity:1;transform:translateX(0)}

/* ============================================================
   SYGNATURA — ornament fali (morski akcent pod nagłówkami)
   ============================================================ */
.wave-orn{display:block;width:132px;height:12px;margin:22px auto 0;color:var(--gold)}
.section-header-c{max-width:820px;margin:0 auto}

/* ============================================================
   PARTNER WYKOŃCZENIA — MOON YACHTS
   ============================================================ */
.partner{background:var(--navy);color:#fff;overflow:hidden;position:relative}
.partner::before{content:"";position:absolute;inset:0;opacity:.05;
  background:radial-gradient(circle at 82% 18%,var(--gold),transparent 42%)}
.partner .eyebrow{color:var(--gold-soft)}.partner .eyebrow i{color:var(--gold-soft)}
.partner h2{color:#fff}.partner h2 em{color:var(--gold-soft);font-style:italic}
.partner-head{max-width:780px;margin:0 auto clamp(40px,6vw,64px);position:relative}
.partner-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,5vw,66px);align-items:center;position:relative}
.partner-media{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);cursor:pointer;position:relative}
.partner-media img{width:100%;height:100%;min-height:440px;object-fit:cover;transition:transform .8s var(--ease)}
.partner-media:hover img{transform:scale(1.05)}
.partner-media .pm-tag{position:absolute;left:18px;bottom:18px;background:rgba(20,33,61,.8);backdrop-filter:blur(6px);
  color:#fff;font-size:.76rem;font-weight:700;padding:8px 15px;border-radius:100px;display:flex;align-items:center;gap:8px}
.partner-media .pm-tag i{color:var(--gold-soft)}
.moon-logo{display:inline-flex;align-items:center;gap:15px;padding:15px 24px;border:1px solid rgba(255,255,255,.2);
  border-radius:12px;margin-bottom:28px;background:rgba(255,255,255,.03)}
.moon-logo>i{font-size:27px;color:var(--gold)}
.moon-logo .ml-text{display:flex;flex-direction:column;line-height:1}
.moon-logo .ml-text b{font-family:var(--serif);font-size:1.55rem;letter-spacing:.34em;color:#fff;font-weight:600}
.moon-logo .ml-text span{font-size:.58rem;letter-spacing:.4em;color:var(--gold-soft);margin-top:4px}
.partner-copy>p{color:rgba(255,255,255,.8);max-width:52ch;margin-bottom:24px;font-size:1.02rem}
.partner-feats{list-style:none;display:flex;flex-direction:column;gap:13px;margin-bottom:28px}
.partner-feats li{display:flex;align-items:center;gap:12px;color:rgba(255,255,255,.92);font-size:.96rem}
.partner-feats li i{color:var(--gold);font-size:1.05em}
.partner-quote{font-family:var(--serif);font-style:italic;font-size:clamp(1.4rem,2.2vw,1.75rem);color:#fff;
  border-left:3px solid var(--gold);padding-left:22px;margin:0 0 26px;line-height:1.3}
.partner-link{display:inline-flex;align-items:center;gap:9px;color:var(--gold-soft);font-weight:700;font-size:.92rem}
.partner-link i{font-size:.85em}
.partner-link:hover{color:var(--gold)}
@media(max-width:860px){.partner-grid{grid-template-columns:1fr}.partner-media img{min-height:320px}}

/* ============================================================
   OPIEKUN INWESTYCJI — Julia
   ============================================================ */
.advisor{background:var(--sand)}
.advisor-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(36px,5vw,72px);align-items:center}
.advisor-photo{position:relative;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
.advisor-photo img{width:100%;display:block;aspect-ratio:1/1.04;object-fit:cover;object-position:top center;transition:transform .8s var(--ease)}
.advisor-photo:hover img{transform:scale(1.04)}
.advisor-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 60%,rgba(20,33,61,.35))}
.advisor-badge{position:absolute;left:18px;bottom:18px;z-index:2;background:var(--navy);color:#fff;font-size:.76rem;font-weight:700;padding:8px 15px;border-radius:100px;display:flex;align-items:center;gap:8px}
.advisor-badge i{color:var(--gold)}
.advisor-copy h2{margin:18px 0 20px}.advisor-copy h2 em{font-style:italic;color:var(--gold-deep)}
.advisor-stats{display:flex;gap:30px;flex-wrap:wrap;margin:28px 0 30px}
.advisor-stats>div{display:flex;flex-direction:column}
.advisor-stats b{font-family:var(--serif);font-size:2.3rem;color:var(--navy);line-height:1;font-variant-numeric:lining-nums}
.advisor-stats span{font-size:.8rem;color:var(--muted);margin-top:4px}
.advisor-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:24px 28px;box-shadow:var(--shadow-soft);max-width:460px}
.advisor-card .ac-head{margin-bottom:18px;padding-bottom:16px;border-bottom:1px solid var(--line)}
.advisor-card .ac-head b{font-family:var(--serif);font-size:1.45rem;color:var(--navy);display:block}
.advisor-card .ac-head span{font-size:.85rem;color:var(--muted)}
.advisor-card .ac-links{display:flex;flex-direction:column;gap:11px;margin-bottom:20px}
.advisor-card .ac-links a{display:flex;align-items:center;gap:12px;font-weight:700;color:var(--navy);font-size:.98rem;font-variant-numeric:lining-nums}
.advisor-card .ac-links a i{color:var(--gold-deep);width:18px;text-align:center}
.advisor-card .ac-links a:hover{color:var(--gold-deep)}
.advisor-card .btn{width:100%;justify-content:center}
@media(max-width:860px){.advisor-grid{grid-template-columns:1fr}.advisor-photo{max-width:420px;margin:0 auto}}
