.pw-modern {
    --pw-ink: #17143f;
    --pw-muted: #65677a;
    --pw-line: rgba(23, 20, 63, .14);
    --pw-indigo: #17143f;
    --pw-green: #1f1a67;
    --pw-teal: #2f6f90;
    --pw-gold: #c79a52;
    --pw-paper: #f6f4ef;
    --pw-white: #fff;
    color: var(--pw-ink);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    position: relative;
    width: 100vw;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    overflow-x: hidden;
    background: var(--pw-paper);
}

.pw-modern * {
    box-sizing: border-box;
}

.pw-modern [hidden] {
    display: none !important;
}

.pw-modern :where(a, button, input, textarea, select) {
    font: inherit;
}

body.pw-modern-active .wp-site-blocks > footer.wp-block-template-part,
body.pw-modern-active footer.wp-block-template-part {
    display: none !important;
}

body.pw-modern-active .wp-site-blocks > .wp-block-template-part:has(footer) {
    display: none !important;
}

.pw-shell {
    width: min(1180px, calc(100% - 32px));
    margin: 0 auto;
}

.pw-hero {
    position: relative;
    min-height: 780px;
    display: grid;
    align-items: end;
    isolation: isolate;
    background: #17143f;
}

.pw-hero__media,
.pw-hero__shade {
    position: absolute;
    inset: 0;
    z-index: -2;
}

.pw-hero__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 46%;
    transform: scale(1.015);
    animation: pwDrift 22s ease-in-out infinite alternate;
}

.pw-hero__shade {
    z-index: -1;
    background: linear-gradient(90deg, rgba(12, 10, 46, .96), rgba(18, 15, 63, .74) 50%, rgba(18, 15, 63, .22)), linear-gradient(0deg, rgba(12, 10, 46, .96), transparent 44%);
}

.pw-hero__content {
    padding: 34px 0 72px;
    color: var(--pw-white);
}

.pw-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 72px;
}

.pw-brandbar {
    display: flex;
    align-items: center;
    gap: 16px;
    color: rgba(255, 255, 255, .8);
}

.pw-brandmark {
    position: relative;
    overflow: hidden;
    width: 282px;
    min-height: 112px;
    display: grid;
    place-items: center;
    padding: 12px 16px;
    border: 1px solid rgba(255, 255, 255, .58);
    border-radius: 8px;
    background: linear-gradient(135deg, rgba(255, 255, 255, .88), rgba(255, 255, 255, .54));
    backdrop-filter: blur(24px) saturate(1.22);
    box-shadow: 0 28px 76px rgba(5, 4, 28, .36), 0 0 0 1px rgba(199, 154, 82, .16), inset 0 1px 0 rgba(255, 255, 255, .86);
}

.pw-brandmark::before {
    content: "";
    position: absolute;
    inset: -45%;
    background: linear-gradient(120deg, transparent 35%, rgba(255, 255, 255, .72), transparent 65%);
    transform: translateX(-55%) rotate(8deg);
    animation: pwLogoSheen 5.8s ease-in-out infinite;
    pointer-events: none;
}

.pw-brandmark::after {
    content: "";
    position: absolute;
    inset: 0;
    border: 1px solid rgba(255, 255, 255, .42);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .74), inset 0 -18px 38px rgba(23, 20, 63, .06);
    pointer-events: none;
}

.pw-brandmark img {
    position: relative;
    z-index: 1;
    max-width: 100%;
    max-height: 88px;
    height: auto;
    display: block;
    mix-blend-mode: normal;
    filter: saturate(1.18) contrast(1.08) drop-shadow(0 8px 14px rgba(23, 20, 63, .16));
}

.pw-footer {
    padding: 54px 0 38px;
    color: #fff;
    background: linear-gradient(135deg, #0d0b2e, #1f1a67 58%, #6c5631);
}

.pw-footer__grid {
    display: grid;
    grid-template-columns: minmax(0, 1.18fr) minmax(170px, .65fr) minmax(230px, .9fr) minmax(170px, .65fr);
    gap: 24px;
    align-items: start;
}

.pw-footer__logo {
    position: relative;
    overflow: hidden;
    width: 282px;
    max-width: 100%;
    min-height: 104px;
    display: grid;
    place-items: center;
    padding: 12px 16px;
    margin-bottom: 18px;
    border: 1px solid rgba(255, 255, 255, .58);
    border-radius: 8px;
    background: linear-gradient(135deg, rgba(255, 255, 255, .90), rgba(255, 255, 255, .56));
    backdrop-filter: blur(24px) saturate(1.22);
    box-shadow: 0 26px 68px rgba(5, 4, 28, .32), 0 0 0 1px rgba(199, 154, 82, .18), inset 0 1px 0 rgba(255, 255, 255, .86);
}

.pw-footer__logo::before {
    content: "";
    position: absolute;
    inset: -45%;
    background: linear-gradient(120deg, transparent 35%, rgba(255, 255, 255, .70), transparent 65%);
    transform: translateX(-55%) rotate(8deg);
    animation: pwLogoSheen 5.8s ease-in-out infinite;
    pointer-events: none;
}

.pw-footer__logo::after {
    content: "";
    position: absolute;
    inset: 0;
    border: 1px solid rgba(255, 255, 255, .42);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .74), inset 0 -18px 38px rgba(23, 20, 63, .06);
    pointer-events: none;
}

.pw-footer__logo img {
    position: relative;
    z-index: 1;
    max-width: 100%;
    max-height: 80px;
    height: auto;
    display: block;
    filter: saturate(1.18) contrast(1.08) drop-shadow(0 8px 14px rgba(23, 20, 63, .16));
}

.pw-footer__brand p,
.pw-footer__links span {
    color: rgba(255, 255, 255, .74);
    line-height: 1.65;
}

.pw-footer__links {
    display: grid;
    align-content: start;
    gap: 10px;
}

.pw-footer__links strong {
    color: var(--pw-gold);
    text-transform: uppercase;
    font-size: 13px;
}

.pw-footer__links a {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    width: fit-content;
    max-width: 100%;
    color: #fff;
    text-decoration: none;
    font-weight: 800;
    overflow-wrap: anywhere;
}

.pw-footer__links a[href^="mailto:"],
.pw-footer__address {
    direction: ltr;
    text-align: left;
}

.pw-footer__links a[href^="mailto:"] {
    white-space: nowrap;
    overflow-wrap: normal;
    word-break: keep-all;
    font-size: 14px;
}

.pw-footer__links a:hover {
    color: #f1d39d;
}

.pw-footer__address {
    display: inline-flex;
    align-items: flex-start;
    gap: 8px;
    width: fit-content;
    min-width: 176px;
    margin-top: 8px;
    padding: 12px 14px;
    color: rgba(255,255,255,.82);
    text-decoration: none;
    line-height: 1.55;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.12);
}

.pw-footer__address span {
    color: rgba(255,255,255,.82);
}

.pw-address-link {
    display: inline-block;
    color: inherit;
    text-decoration: none;
}

.pw-address-link:hover {
    color: var(--pw-green);
}

.pw-brandmark__text {
    color: #fff;
    font-weight: 800;
    line-height: .9;
    text-transform: uppercase;
}

.pw-lang {
    display: inline-flex;
    gap: 6px;
    padding: 6px;
    border: 1px solid rgba(255, 255, 255, .18);
    background: rgba(255, 255, 255, .1);
    backdrop-filter: blur(14px);
}

.pw-lang button {
    min-width: 44px;
    min-height: 36px;
    border: 0;
    color: rgba(255, 255, 255, .78);
    font-weight: 900;
    cursor: pointer;
    background: transparent;
}

.pw-lang button[aria-pressed="true"] {
    color: #10201d;
    background: #fff;
}

.pw-lang-panel[dir="rtl"] {
    direction: rtl;
    text-align: right;
}

.pw-hero__grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: 48px;
    align-items: end;
}

.pw-kicker {
    margin: 0 0 14px;
    color: var(--pw-gold);
    font-size: 13px;
    font-weight: 800;
    letter-spacing: 0;
    text-transform: uppercase;
}

.pw-hero h1,
.pw-section h2,
.pw-section-head h2,
.pw-whatsapp-card h2,
.pw-form-card h2,
.pw-path-card h2 {
    margin: 0;
    letter-spacing: 0;
    line-height: 1.02;
}

.pw-hero h1 {
    max-width: 940px;
    font-size: clamp(42px, 6.5vw, 82px);
    overflow-wrap: anywhere;
}

.pw-lead {
    max-width: 760px;
    margin: 24px 0 0;
    color: rgba(255, 255, 255, .82);
    font-size: 20px;
    line-height: 1.6;
}

.pw-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 34px;
}

.pw-button {
    min-height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 13px 18px;
    border: 1px solid transparent;
    border-radius: 6px;
    font-weight: 800;
    text-decoration: none;
    transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}

.pw-button:hover {
    transform: translateY(-2px);
}

.pw-button--primary {
    color: #fff;
    background: var(--pw-green);
    box-shadow: 0 14px 34px rgba(15, 107, 85, .34);
}

.pw-button--dark {
    color: #fff;
    background: #17211f;
    box-shadow: 0 14px 34px rgba(23, 33, 31, .24);
}

.pw-button--whatsapp {
    color: #fff;
    border-color: rgba(255, 255, 255, .28);
    background: rgba(31, 154, 96, .52);
}

.pw-button--ghost {
    color: inherit;
    border-color: rgba(255, 255, 255, .34);
    background: rgba(255, 255, 255, .1);
}

.pw-proof-card {
    padding: 22px;
    border: 1px solid rgba(255, 255, 255, .22);
    background: rgba(255, 255, 255, .12);
    backdrop-filter: blur(18px);
}

.pw-proof-card__image {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    display: block;
    margin-bottom: 18px;
    border: 1px solid rgba(255, 255, 255, .2);
}

.pw-proof-card__label {
    display: block;
    margin-bottom: 16px;
    color: var(--pw-gold);
    font-weight: 800;
}

.pw-proof-card__line {
    padding: 16px 0;
    border-top: 1px solid rgba(255, 255, 255, .18);
}

.pw-proof-card strong,
.pw-proof-card span {
    display: block;
}

.pw-proof-card strong {
    margin-bottom: 4px;
}

.pw-proof-card span {
    color: rgba(255, 255, 255, .76);
    line-height: 1.5;
}

.pw-stats-band {
    position: relative;
    z-index: 3;
    background: #fff;
    border-bottom: 1px solid var(--pw-line);
}

.pw-stats {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.pw-stat {
    min-height: 152px;
    padding: 30px 24px;
    border-left: 1px solid var(--pw-line);
    overflow: hidden;
}

.pw-stat:last-child {
    border-right: 1px solid var(--pw-line);
}

.pw-stat__number,
.pw-stat__suffix {
    font-size: clamp(34px, 4vw, 58px);
    line-height: .95;
    font-weight: 900;
    color: var(--pw-green);
}

.pw-stat__label {
    display: block;
    max-width: 210px;
    margin-top: 12px;
    color: var(--pw-muted);
    line-height: 1.35;
}

.pw-stat__bar {
    display: block;
    width: 100%;
    height: 5px;
    margin-top: 20px;
    overflow: hidden;
    background: rgba(15, 107, 85, .12);
}

.pw-stat__bar i {
    display: block;
    width: 0;
    height: 100%;
    background: linear-gradient(90deg, var(--pw-green), var(--pw-gold));
    transition: width 1.2s ease;
}

.pw-stat.is-visible .pw-stat__bar i {
    width: var(--pw-bar, 80%);
}

.pw-section {
    padding: 92px 0;
}

.pw-section--split {
    display: grid;
    grid-template-columns: .9fr 1.1fr;
    gap: 56px;
    align-items: start;
}

.pw-section h2,
.pw-section-head h2,
.pw-whatsapp-card h2,
.pw-form-card h2 {
    font-size: clamp(30px, 4vw, 52px);
}

.pw-section p,
.pw-section-head p,
.pw-whatsapp-card p,
.pw-form-card p,
.pw-path-card p {
    color: var(--pw-muted);
    font-size: 17px;
    line-height: 1.7;
}

.pw-price-section,
.pw-shipping-section,
.pw-location-grid {
    display: grid;
    grid-template-columns: .95fr 1.05fr;
    gap: 28px;
    align-items: stretch;
}

.pw-price-copy,
.pw-price-comparison,
.pw-shipping-copy,
.pw-shipping-visual {
    padding: 34px;
    border: 1px solid var(--pw-line);
    background: rgba(255, 255, 255, .78);
    box-shadow: 0 24px 70px rgba(21, 32, 31, .06);
}

.pw-price-comparison {
    display: grid;
    align-content: center;
    gap: 14px;
}

.pw-price-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
    padding: 18px;
    border: 1px solid var(--pw-line);
    background: #fff;
}

.pw-price-row strong {
    font-size: clamp(34px, 5vw, 64px);
    line-height: .9;
}

.pw-price-row span,
.pw-price-row em {
    display: block;
}

.pw-price-row span {
    font-weight: 900;
}

.pw-price-row em {
    grid-column: 1 / -1;
    color: var(--pw-muted);
    font-style: normal;
}

.pw-price-row--premium strong {
    color: #9a3412;
}

.pw-price-row--stock strong {
    color: var(--pw-green);
}

.pw-keywords,
.pw-mini-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.pw-keywords span,
.pw-mini-list span {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 8px 12px;
    border: 1px solid rgba(15, 107, 85, .18);
    color: #173c35;
    font-size: 14px;
    font-weight: 800;
    line-height: 1.25;
    background: rgba(255, 255, 255, .74);
}

.pw-flow-band {
    padding: 24px 0 84px;
    background: var(--pw-paper);
}

.pw-process {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.pw-process div,
.pw-trust-grid div,
.pw-form-card,
.pw-whatsapp-card,
.pw-path-card {
    border: 1px solid var(--pw-line);
    background: rgba(255, 255, 255, .72);
    box-shadow: 0 24px 70px rgba(21, 32, 31, .06);
}

.pw-process div {
    padding: 22px;
}

.pw-process span {
    color: var(--pw-gold);
    font-weight: 900;
}

.pw-process strong,
.pw-process p {
    display: block;
}

.pw-process strong {
    margin-top: 10px;
    font-size: 22px;
}

.pw-process p {
    margin: 8px 0 0;
}

.pw-gallery-wrap {
    padding: 90px 0;
    color: #fff;
    background: #15123e;
}

.pw-product-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 14px;
    margin-bottom: 18px;
}

.pw-product-grid div {
    overflow: hidden;
    grid-column: span 2;
    background: rgba(255, 255, 255, .08);
    border: 1px solid rgba(255, 255, 255, .14);
}

.pw-product-grid img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    display: block;
}

.pw-product-grid strong,
.pw-product-grid span {
    display: block;
    padding: 0 16px;
}

.pw-product-grid strong {
    padding-top: 16px;
    font-size: 18px;
}

.pw-product-grid span {
    padding-bottom: 18px;
    color: rgba(255, 255, 255, .72);
    line-height: 1.5;
}

.pw-section-head {
    display: flex;
    justify-content: space-between;
    gap: 28px;
    align-items: end;
    margin-bottom: 30px;
}

.pw-section-head p {
    max-width: 430px;
    color: rgba(255, 255, 255, .68);
}

.pw-gallery {
    display: grid;
    grid-template-columns: 1.25fr .8fr .8fr;
    grid-auto-rows: 240px;
    gap: 14px;
}

.pw-gallery__item {
    position: relative;
    overflow: hidden;
    padding: 0;
    border: 0;
    border-radius: 0;
    color: #fff;
    cursor: pointer;
    background: #100e33;
}

.pw-gallery__item:first-child {
    grid-row: span 2;
}

.pw-gallery__item img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    transition: transform .55s ease, filter .55s ease;
}

.pw-gallery__item:hover img {
    transform: scale(1.07);
    filter: saturate(1.08) contrast(1.04);
}

.pw-gallery__item span {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
}

.pw-gallery__item strong {
    font-size: 16px;
}

.pw-gallery__item span {
    font-size: 13px;
}

.pw-section--trust {
    padding-bottom: 42px;
}

.pw-shipping-visual {
    position: relative;
    min-height: 420px;
    padding: 0;
    overflow: hidden;
}

.pw-logistics-map {
    position: relative;
    height: 100%;
    min-height: 520px;
    display: grid;
    place-items: center;
    overflow: hidden;
    color: #fff;
    background:
        radial-gradient(circle at 52% 47%, rgba(40, 156, 226, .28), transparent 34%),
        radial-gradient(circle at 50% 48%, rgba(199, 154, 82, .2), transparent 42%),
        radial-gradient(circle at 28% 22%, rgba(255, 255, 255, .16), transparent 24%),
        linear-gradient(135deg, #06091d, #101a39 58%, #201454);
}

.pw-logistics-map::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,.055) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.055) 1px, transparent 1px);
    background-size: 42px 42px;
    mask-image: radial-gradient(circle at center, #000, transparent 72%);
}

.pw-globe {
    position: relative;
    width: min(420px, 82vw);
    aspect-ratio: 1;
    border-radius: 50%;
    isolation: isolate;
    background: #071223;
    border: 1px solid rgba(255,255,255,.26);
    box-shadow:
        0 46px 130px rgba(0,0,0,.44),
        0 0 86px rgba(70, 170, 255, .32),
        inset -28px -28px 64px rgba(0,0,0,.28),
        inset 18px 18px 46px rgba(255,255,255,.12);
    overflow: hidden;
}

.pw-globe::after {
    content: "";
    position: absolute;
    inset: -1%;
    border-radius: 50%;
    background:
        radial-gradient(circle at 31% 20%, rgba(255,255,255,.24), transparent 14%),
        radial-gradient(circle at 62% 74%, transparent 48%, rgba(0,0,0,.38) 74%),
        linear-gradient(110deg, rgba(255,255,255,.14), transparent 24%, transparent 70%, rgba(4, 12, 28, .5));
    mix-blend-mode: screen;
    pointer-events: none;
}

.pw-globe__earth {
    position: absolute;
    inset: -1.5%;
    z-index: 0;
    width: 103%;
    height: 103%;
    object-fit: cover;
    border-radius: 50%;
    filter: saturate(1.08) contrast(1.06) brightness(.92);
    animation: pwEarthBreath 8s ease-in-out infinite;
}

.pw-globe__grid {
    position: absolute;
    inset: 5%;
    z-index: 1;
    border-radius: 50%;
    background:
        repeating-linear-gradient(90deg, transparent 0 34px, rgba(255,255,255,.08) 35px 36px),
        repeating-linear-gradient(0deg, transparent 0 34px, rgba(255,255,255,.06) 35px 36px);
    opacity: .34;
    mask-image: radial-gradient(circle, #000 60%, transparent 70%);
}

.pw-globe__land,
.pw-route,
.pw-node {
    position: absolute;
    display: block;
}

.pw-globe__land {
    display: none;
}

.pw-globe__land--eu { width: 25%; height: 18%; left: 45%; top: 28%; transform: rotate(-18deg); }
.pw-globe__land--af { width: 21%; height: 30%; left: 47%; top: 44%; transform: rotate(8deg); }
.pw-globe__land--as { width: 32%; height: 25%; left: 62%; top: 33%; transform: rotate(12deg); }
.pw-globe__land--am { width: 24%; height: 32%; left: 15%; top: 35%; transform: rotate(-16deg); opacity: .52; }

.pw-route-web {
    position: absolute;
    inset: 0;
    z-index: 3;
    width: 100%;
    height: 100%;
    pointer-events: none;
}

.pw-route-path {
    fill: none;
    stroke: rgba(255, 226, 164, .86);
    stroke-width: .72;
    stroke-linecap: round;
    stroke-dasharray: 5 5;
    filter: drop-shadow(0 0 2px rgba(255, 232, 178, .9)) drop-shadow(0 0 7px rgba(80, 190, 255, .42));
    animation: pwRouteFlow 4.2s linear infinite;
}

.pw-route-path--2,
.pw-route-path--5,
.pw-route-path--10 {
    stroke: rgba(119, 214, 255, .76);
}

.pw-route-path--3,
.pw-route-path--6,
.pw-route-path--8,
.pw-route-path--11 {
    animation-delay: -.9s;
}

.pw-route-path--4,
.pw-route-path--7,
.pw-route-path--9,
.pw-route-path--12 {
    animation-delay: -1.8s;
}

.pw-route-port {
    fill: #fff7df;
    stroke: var(--pw-gold);
    stroke-width: .7;
    transform-box: fill-box;
    transform-origin: center;
    filter: drop-shadow(0 0 4px rgba(255,255,255,.86)) drop-shadow(0 0 10px rgba(255, 210, 130, .65));
    animation: pwPortPulse 2.6s ease-in-out infinite;
}

.pw-route-hub {
    fill: #fff;
    stroke: var(--pw-gold);
    stroke-width: .95;
    filter: drop-shadow(0 0 5px rgba(255,255,255,.94)) drop-shadow(0 0 16px rgba(255, 210, 130, .88));
    animation: pwHubPulse 2.1s ease-in-out infinite;
}

.pw-route-port--2,
.pw-route-port--5,
.pw-route-port--7,
.pw-route-port--10 {
    animation-delay: .7s;
}

.pw-route-port--3,
.pw-route-port--6,
.pw-route-port--8,
.pw-route-port--11,
.pw-route-port--12 {
    animation-delay: 1.3s;
}

.pw-route {
    z-index: 3;
    height: 3px;
    transform-origin: left center;
    border-radius: 999px;
    background:
        repeating-linear-gradient(90deg, rgba(255,255,255,.12) 0 7px, rgba(255,255,255,.01) 7px 13px),
        linear-gradient(90deg, rgba(255,255,255,.08), #ffe5aa 42%, rgba(101, 210, 255, .7));
    box-shadow: 0 0 20px rgba(241, 211, 157, .75), 0 0 38px rgba(74, 180, 255, .28);
    animation: pwRoutePulse 3.8s ease-in-out infinite;
}

.pw-route::before {
    content: "";
    position: absolute;
    inset: -8px 0;
    border-radius: 999px;
    background: linear-gradient(90deg, transparent, rgba(255, 225, 167, .3), transparent);
    filter: blur(8px);
}

.pw-route::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: #fff7df;
    box-shadow: 0 0 0 4px rgba(255, 229, 170, .2), 0 0 22px rgba(255, 255, 255, .9);
    transform: translateY(-50%);
    animation: pwRouteDot 2.8s linear infinite;
}

.pw-route--af { width: 29%; left: 53%; top: 40%; transform: rotate(102deg); }
.pw-route--me { width: 25%; left: 53%; top: 40%; transform: rotate(42deg); }
.pw-route--as { width: 38%; left: 53%; top: 40%; transform: rotate(22deg); }
.pw-route--am { width: 37%; left: 53%; top: 40%; transform: rotate(196deg); }
.pw-route--me::after { animation-delay: .45s; }
.pw-route--as::after { animation-delay: .85s; }
.pw-route--am::after { animation-delay: 1.15s; }

.pw-node {
    z-index: 4;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: #fff9e8;
    border: 3px solid var(--pw-gold);
    box-shadow: 0 0 0 10px rgba(199,154,82,.16), 0 0 28px rgba(255,255,255,.78), 0 0 40px rgba(72,175,255,.25);
}

.pw-node i {
    position: absolute;
    left: 50%;
    top: 18px;
    transform: translateX(-50%);
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 8px;
    white-space: nowrap;
    font-size: 11px;
    font-style: normal;
    font-weight: 900;
    color: #fff;
    background:
        linear-gradient(135deg, rgba(255,255,255,.18), rgba(255,255,255,.04)),
        rgba(12, 10, 46, .62);
    border: 1px solid rgba(255,255,255,.28);
    border-radius: 8px;
    box-shadow: 0 10px 24px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.2);
    backdrop-filter: blur(12px) saturate(1.35);
}

.pw-node i::before {
    content: "";
    width: 6px;
    height: 6px;
    flex: 0 0 6px;
    border-radius: 50%;
    background: var(--pw-gold);
    box-shadow: 0 0 10px rgba(255, 224, 162, .88);
}

.pw-node--de { left: 35.4%; top: 29.6%; }
.pw-node--af { left: 31.4%; top: 65.4%; }
.pw-node--me { left: 46.5%; top: 49.5%; }
.pw-node--as { left: 80.5%; top: 42.5%; }
.pw-node--am { left: 64.5%; top: 73.5%; }

.pw-logistics-panel {
    position: absolute;
    left: 22px;
    right: 22px;
    bottom: 22px;
    padding: 18px;
    color: #fff;
    background: rgba(12, 10, 46, .72);
    border: 1px solid rgba(255,255,255,.16);
    backdrop-filter: blur(16px);
}

.pw-logistics-panel strong,
.pw-logistics-panel span {
    display: block;
}

.pw-logistics-panel strong {
    font-size: 22px;
}

.pw-logistics-panel span {
    margin-top: 6px;
    color: rgba(255, 255, 255, .78);
}

.pw-option-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-top: 22px;
}

.pw-option-grid div {
    padding: 18px;
    border: 1px solid var(--pw-line);
    background: #fff;
}

.pw-option-grid strong,
.pw-option-grid span {
    display: block;
}

.pw-option-grid span {
    margin-top: 8px;
    color: var(--pw-muted);
    line-height: 1.5;
}

.pw-shipping-assurance {
    position: relative;
    margin-top: 18px;
    padding: 22px;
    overflow: hidden;
    color: #fff;
    background:
        radial-gradient(circle at 8% 15%, rgba(199, 154, 82, .28), transparent 26%),
        linear-gradient(135deg, rgba(21, 18, 62, .96), rgba(13, 24, 48, .92));
    border: 1px solid rgba(255,255,255,.16);
    box-shadow: 0 20px 54px rgba(15, 20, 42, .14);
}

.pw-shipping-assurance::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,.055) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.055) 1px, transparent 1px);
    background-size: 28px 28px;
    mask-image: linear-gradient(90deg, #000, transparent 78%);
    pointer-events: none;
}

.pw-shipping-assurance strong,
.pw-shipping-assurance p,
.pw-shipping-steps {
    position: relative;
    z-index: 1;
}

.pw-shipping-assurance > strong {
    display: block;
    max-width: 620px;
    color: #fff;
    font-size: 20px;
    line-height: 1.25;
}

.pw-shipping-assurance p {
    margin: 10px 0 0;
    color: rgba(255,255,255,.78);
    font-size: 15px;
    line-height: 1.65;
}

.pw-shipping-steps {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin-top: 16px;
}

.pw-shipping-steps span {
    display: flex;
    align-items: center;
    gap: 8px;
    min-height: 38px;
    padding: 8px 10px;
    color: #fff;
    font-size: 12px;
    font-weight: 900;
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(255,255,255,.16);
    backdrop-filter: blur(10px);
}

.pw-shipping-steps span::before {
    content: "";
    width: 7px;
    height: 7px;
    flex: 0 0 7px;
    border-radius: 50%;
    background: var(--pw-gold);
    box-shadow: 0 0 12px rgba(255, 224, 162, .72);
}

.pw-location-band {
    padding: 64px 0;
    color: #fff;
    background: #15123e;
}

.pw-location-grid {
    align-items: center;
}

.pw-location-grid h2 {
    margin: 0;
    font-size: clamp(30px, 4vw, 52px);
    line-height: 1.04;
}

.pw-location-grid p {
    color: rgba(255, 255, 255, .78);
    line-height: 1.65;
}

.pw-location-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: flex-end;
}

.pw-social-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 18px;
}

.pw-social-row a {
    padding: 8px 10px;
    color: var(--pw-green);
    font-weight: 900;
    text-decoration: none;
    background: rgba(15, 107, 85, .08);
}

.pw-trust-panel {
    padding: 54px;
    color: #fff;
    background: linear-gradient(135deg, #1f1a67, #15123e 62%, #7b6235);
}

.pw-trust-panel h2 {
    max-width: 900px;
}

.pw-trust-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin-top: 34px;
}

.pw-trust-grid div {
    padding: 22px;
    background: rgba(255, 255, 255, .1);
    border-color: rgba(255, 255, 255, .18);
}

.pw-trust-grid strong,
.pw-trust-grid span {
    display: block;
}

.pw-trust-grid span {
    margin-top: 8px;
    color: rgba(255, 255, 255, .76);
    line-height: 1.55;
}

.pw-contact-paths {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
    padding: 12px 0 42px;
}

.pw-path-card {
    position: relative;
    overflow: hidden;
    padding: 34px;
    background: #fff;
}

.pw-path-card h2 {
    font-size: clamp(28px, 3.2vw, 44px);
}

.pw-path-card--buyer {
    border-top: 5px solid var(--pw-green);
}

.pw-path-card--supplier {
    border-top: 5px solid var(--pw-gold);
}

.pw-supplier-direct {
    display: grid;
    gap: 8px;
    margin-top: 18px;
    padding: 14px 16px;
    color: var(--pw-muted);
    font-size: 14px;
    line-height: 1.55;
    border: 1px solid rgba(199, 154, 82, .24);
    background: linear-gradient(135deg, rgba(199, 154, 82, .10), rgba(255, 255, 255, .78));
}

.pw-supplier-direct a {
    color: var(--pw-indigo);
    font-size: 17px;
    font-weight: 1000;
    text-decoration: none;
    overflow-wrap: anywhere;
}

.pw-mini-list {
    margin: 20px 0 24px;
}

.pw-contact-grid {
    display: grid;
    grid-template-columns: .86fr 1.14fr;
    gap: 18px;
    padding: 48px 0 96px;
}

.pw-whatsapp-card,
.pw-form-card {
    position: relative;
    padding: 34px;
}

.pw-whatsapp-card {
    color: #fff;
    background: #15123e;
}

.pw-whatsapp-card p {
    color: rgba(255, 255, 255, .72);
}

.pw-live-dot {
    position: absolute;
    top: 26px;
    right: 26px;
    width: 14px;
    height: 14px;
    border-radius: 999px;
    background: #34d399;
    box-shadow: 0 0 0 0 rgba(52, 211, 153, .7);
    animation: pwPulse 1.8s infinite;
}

.pw-form-card .pw-button--ghost,
.pw-fallback-form .pw-button--ghost {
    color: var(--pw-green);
    border-color: rgba(15, 107, 85, .28);
    background: rgba(15, 107, 85, .07);
}

.pw-fallback-form {
    display: grid;
    gap: 12px;
    align-items: start;
}

.pw-existing-form .wpcf7 {
    margin-top: 18px;
}

.pw-existing-form form {
    display: grid;
    gap: 14px;
}

.pw-existing-form p {
    margin: 0;
}

.pw-existing-form label {
    display: grid;
    gap: 7px;
    color: var(--pw-indigo);
    font-size: 13px;
    font-weight: 900;
    line-height: 1.45;
}

.pw-existing-form input,
.pw-existing-form textarea,
.pw-existing-form select {
    width: 100%;
    min-height: 48px;
    padding: 12px 13px;
    color: var(--pw-indigo);
    border: 1px solid rgba(23, 20, 63, .16);
    border-radius: 6px;
    background: rgba(255, 255, 255, .94);
    outline: none;
}

.pw-existing-form textarea {
    min-height: 124px;
    resize: vertical;
}

.pw-existing-form input:focus,
.pw-existing-form textarea:focus,
.pw-existing-form select:focus {
    border-color: rgba(31, 26, 103, .56);
    box-shadow: 0 0 0 3px rgba(31, 26, 103, .10);
}

.pw-existing-form .wpcf7-radio,
.pw-existing-form .wpcf7-checkbox {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 6px;
}

.pw-existing-form .wpcf7-list-item {
    margin: 0;
}

.pw-existing-form .wpcf7-list-item label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 9px 12px;
    border: 1px solid rgba(23, 20, 63, .12);
    background: rgba(255, 255, 255, .78);
}

.pw-existing-form input[type="radio"],
.pw-existing-form input[type="checkbox"] {
    width: auto;
    min-height: 0;
}

.pw-existing-form input[type="submit"] {
    min-height: 56px;
    cursor: pointer;
    color: #fff;
    font-size: 15px;
    font-weight: 1000;
    letter-spacing: 0;
    border: 0;
    background: linear-gradient(135deg, var(--pw-green), var(--pw-indigo));
    box-shadow: 0 18px 42px rgba(21, 18, 62, .18);
}

.pw-existing-form .wpcf7-response-output {
    margin: 6px 0 0 !important;
    padding: 12px 14px !important;
    border-radius: 6px;
    line-height: 1.5;
}

.pw-fallback-form label {
    display: grid;
    gap: 6px;
    color: var(--pw-indigo);
    font-size: 13px;
    font-weight: 900;
}

.pw-fallback-form input {
    width: 100%;
    min-height: 46px;
    padding: 11px 12px;
    color: var(--pw-indigo);
    border: 1px solid rgba(23, 20, 63, .16);
    border-radius: 6px;
    background: rgba(255, 255, 255, .92);
    outline: none;
}

.pw-fallback-form input:focus {
    border-color: rgba(31, 26, 103, .55);
    box-shadow: 0 0 0 3px rgba(31, 26, 103, .10);
}

.pw-fallback-form small {
    color: var(--pw-muted);
    line-height: 1.5;
}

.pw-contact-line {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin: 18px 0 0;
    padding-top: 16px;
    border-top: 1px solid var(--pw-line);
}

.pw-contact-chip {
    display: grid;
    gap: 4px;
    min-width: 0;
    padding: 12px;
    color: var(--pw-green);
    font-size: 14px !important;
    font-weight: 900;
    line-height: 1.35;
    text-decoration: none;
    direction: ltr;
    text-align: left;
    overflow-wrap: anywhere;
    background: rgba(255, 255, 255, .82);
    border: 1px solid rgba(21, 18, 62, .1);
    box-shadow: 0 12px 30px rgba(21, 32, 31, .06);
}

.pw-contact-chip__label {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    color: var(--pw-indigo);
    font-size: 12px;
    font-weight: 1000;
    text-transform: uppercase;
}

.pw-contact-chip:hover {
    transform: translateY(-1px);
}

.pw-social-row a {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 42px;
    padding: 8px 12px 8px 8px;
    color: #15123e;
    font-weight: 900;
    text-decoration: none;
    background: #fff;
    border: 1px solid rgba(21,18,62,.1);
    box-shadow: 0 12px 30px rgba(21, 32, 31, .06);
}

.pw-social-row a:hover,
.pw-footer__links a:hover .pw-social-icon {
    transform: translateY(-1px);
}

.pw-social-icon {
    display: inline-grid;
    place-items: center;
    width: 28px;
    height: 28px;
    flex: 0 0 28px;
    color: #fff;
    background: linear-gradient(135deg, #17143f, #0f6b55);
    border: 1px solid rgba(255,255,255,.24);
    border-radius: 999px;
    box-shadow: 0 10px 22px rgba(21, 18, 62, .18);
    transition: transform .2s ease;
}

.pw-social-icon svg {
    width: 16px;
    height: 16px;
    display: block;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.9;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.pw-social-icon--facebook svg,
.pw-social-icon--tiktok svg {
    fill: currentColor;
    stroke: none;
}

.pw-social-icon--whatsapp {
    background: linear-gradient(135deg, #25d366, #128c7e);
}

.pw-social-icon--facebook {
    background: linear-gradient(135deg, #1877f2, #0b4aa2);
}

.pw-social-icon--tiktok {
    background: linear-gradient(135deg, #111, #ee1d52);
}

.pw-social-icon--map {
    background: linear-gradient(135deg, #4285f4, #34a853);
}

.pw-social-icon--mail {
    background: linear-gradient(135deg, #c79a52, #1f1a67);
}

.pw-social-icon--channel,
.pw-social-icon--phone {
    background: linear-gradient(135deg, #1f1a67, #2f6f90);
}

.pw-footer__links .pw-social-icon {
    color: #fff;
    line-height: 1;
}

.pw-floating-contact {
    position: fixed;
    right: 18px;
    bottom: 18px;
    z-index: 99990;
    display: grid;
    justify-items: end;
    gap: 10px;
}

.pw-modern[dir="rtl"] .pw-floating-contact {
    right: auto;
    left: 18px;
    justify-items: start;
}

.pw-floating-contact__button {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 46px;
    padding: 9px 13px 9px 9px;
    color: #fff;
    font-weight: 900;
    border: 1px solid rgba(255, 255, 255, .28);
    border-radius: 999px;
    cursor: pointer;
    background: linear-gradient(135deg, #25d366, #128c7e);
    box-shadow: 0 18px 46px rgba(18, 140, 126, .32);
}

.pw-floating-contact__panel {
    width: min(300px, calc(100vw - 36px));
    display: grid;
    gap: 8px;
    padding: 10px;
    color: #fff;
    border: 1px solid rgba(255, 255, 255, .18);
    border-radius: 10px;
    background: rgba(17, 14, 58, .94);
    backdrop-filter: blur(18px) saturate(1.2);
    box-shadow: 0 24px 70px rgba(5, 4, 28, .34);
}

.pw-floating-contact__panel a {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px;
    color: #fff;
    text-decoration: none;
    font-weight: 900;
    border-radius: 8px;
    background: rgba(255, 255, 255, .08);
}

.pw-floating-contact__panel small {
    display: block;
    margin-top: 2px;
    color: rgba(255,255,255,.74);
    font-size: 12px;
    line-height: 1.4;
}

.pw-lightbox {
    position: fixed;
    inset: 0;
    z-index: 99999;
    display: grid;
    place-items: center;
    padding: 28px;
    color: #fff;
    background: rgba(8, 14, 13, .88);
}

.pw-lightbox[hidden] {
    display: none;
}

.pw-lightbox img {
    max-width: min(980px, 94vw);
    max-height: 78vh;
    object-fit: contain;
    box-shadow: 0 30px 90px rgba(0, 0, 0, .36);
}

.pw-lightbox strong {
    margin-top: 14px;
}

.pw-lightbox__close {
    position: absolute;
    top: 18px;
    right: 18px;
    width: 44px;
    height: 44px;
    border: 1px solid rgba(255, 255, 255, .24);
    color: #fff;
    font-size: 30px;
    line-height: 1;
    cursor: pointer;
    background: rgba(255, 255, 255, .1);
}

@keyframes pwDrift {
    from {
        transform: scale(1.04) translate3d(0, 0, 0);
    }
    to {
        transform: scale(1.1) translate3d(-18px, -8px, 0);
    }
}

@keyframes pwPulse {
    70% {
        box-shadow: 0 0 0 14px rgba(52, 211, 153, 0);
    }
    100% {
        box-shadow: 0 0 0 0 rgba(52, 211, 153, 0);
    }
}

@keyframes pwLogoSheen {
    0%, 55% {
        transform: translateX(-58%) rotate(8deg);
        opacity: 0;
    }
    68% {
        opacity: .85;
    }
    100% {
        transform: translateX(58%) rotate(8deg);
        opacity: 0;
    }
}

@keyframes pwRouteDot {
    from {
        left: 0;
        opacity: 0;
    }
    12%, 82% {
        opacity: 1;
    }
    to {
        left: calc(100% - 7px);
        opacity: 0;
    }
}

@keyframes pwRouteFlow {
    from {
        stroke-dashoffset: 24;
        opacity: .62;
    }
    50% {
        opacity: 1;
    }
    to {
        stroke-dashoffset: 0;
        opacity: .62;
    }
}

@keyframes pwPortPulse {
    0%, 100% {
        opacity: .72;
        transform: scale(1);
    }
    50% {
        opacity: 1;
        transform: scale(1.35);
    }
}

@keyframes pwHubPulse {
    0%, 100% {
        opacity: .92;
        transform: scale(1);
    }
    50% {
        opacity: 1;
        transform: scale(1.22);
    }
}

@keyframes pwRoutePulse {
    0%, 100% {
        opacity: .74;
        filter: saturate(1);
    }
    50% {
        opacity: 1;
        filter: saturate(1.28);
    }
}

@keyframes pwEarthBreath {
    0%, 100% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.025);
    }
}

@keyframes pwOrbit {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}

@media (prefers-reduced-motion: reduce) {
    .pw-hero__media img,
    .pw-live-dot,
    .pw-globe__earth,
    .pw-route-path,
    .pw-route-port,
    .pw-route,
    .pw-route::after,
    .pw-globe::after {
        animation: none;
    }

    .pw-button,
    .pw-gallery__item img,
    .pw-brandmark::before {
        transition: none;
        animation: none;
    }
}

@media (max-width: 980px) {
    .pw-hero {
        min-height: 740px;
    }

    .pw-hero__grid,
    .pw-section--split,
    .pw-contact-grid,
    .pw-contact-paths,
    .pw-price-section,
    .pw-shipping-section,
    .pw-location-grid {
        grid-template-columns: 1fr;
    }

    .pw-footer__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .pw-topbar {
        margin-bottom: 46px;
    }

    .pw-proof-card {
        max-width: 560px;
    }

    .pw-stats,
    .pw-trust-grid,
    .pw-process,
    .pw-product-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .pw-product-grid div {
        grid-column: auto;
    }

    .pw-location-actions {
        justify-content: flex-start;
    }

    .pw-section-head {
        display: block;
    }

    .pw-gallery {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        grid-auto-rows: 220px;
    }
}

@media (max-width: 640px) {
    .pw-shell {
        width: min(100% - 22px, 1180px);
    }

    .pw-hero {
        min-height: 700px;
    }

    .pw-hero__content {
        padding-bottom: 42px;
    }

    .pw-topbar,
    .pw-brandbar {
        align-items: flex-start;
        flex-direction: column;
        gap: 10px;
    }

    .pw-brandbar span {
        font-size: 14px;
    }

    .pw-brandmark {
        width: 230px;
        min-height: 92px;
    }

    .pw-footer__logo {
        width: 230px;
        min-height: 92px;
    }

    .pw-brandmark img {
        max-height: 72px;
    }

    .pw-footer__logo img {
        max-height: 72px;
    }

    .pw-lang {
        width: 100%;
        justify-content: space-between;
    }

    .pw-lang button {
        flex: 1;
    }

    .pw-hero h1 {
        font-size: 36px;
    }

    .pw-lead {
        font-size: 17px;
    }

    .pw-actions,
    .pw-button {
        width: 100%;
    }

    .pw-stats,
    .pw-process,
    .pw-gallery,
    .pw-trust-grid,
    .pw-product-grid,
    .pw-option-grid {
        grid-template-columns: 1fr;
    }

    .pw-stat {
        min-height: 128px;
        border-right: 1px solid var(--pw-line);
    }

    .pw-section {
        padding: 62px 0;
    }

    .pw-flow-band {
        padding-bottom: 62px;
    }

    .pw-gallery-wrap {
        padding: 64px 0;
    }

    .pw-gallery {
        grid-auto-rows: 250px;
    }

    .pw-gallery__item:first-child {
        grid-row: span 1;
    }

    .pw-logistics-map {
        min-height: 500px;
    }

    .pw-globe {
        width: min(330px, 88vw);
    }

    .pw-node i {
        font-size: 10px;
        padding: 3px 6px;
    }

    .pw-shipping-assurance {
        padding: 18px;
    }

    .pw-shipping-steps {
        grid-template-columns: 1fr;
    }

    .pw-trust-panel,
    .pw-whatsapp-card,
    .pw-form-card,
    .pw-path-card,
    .pw-price-copy,
    .pw-price-comparison,
    .pw-shipping-copy {
        padding: 24px;
    }

    .pw-location-actions,
    .pw-location-actions .pw-button {
        width: 100%;
    }

    .pw-contact-grid {
        padding-bottom: 64px;
    }

    .pw-contact-line {
        grid-template-columns: 1fr;
    }

    .pw-footer__grid {
        grid-template-columns: 1fr;
    }
}
