/* ===========================================================================
   PMW GLOBAL — premium K-beauty + medical brand house
   Dusty rose · champagne · ink. Montserrat (codebase font).
   Scoped under .pnw
   =========================================================================== */
.pnw {
    --ink: #221a1d;
    --ink-2: #5b4f53;
    --muted: #8a7d81;
    --paper: #ffffff;
    --cream: #faf5f2;
    --cream-2: #f4eae5;
    --rose: #c0808c;
    --rose-d: #a6606e;
    --rose-soft: #e7c9cd;
    --rose-bg: #f8ebec;
    --gold: #b6905f;
    --gold-soft: #e7d4bb;
    --line: rgba(34, 26, 29, .10);
    --line-2: rgba(34, 26, 29, .06);
    --d: "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
    --b: "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
    --ease: cubic-bezier(.22, .61, .36, 1);
    --shadow: 0 24px 60px -28px rgba(40, 22, 28, .35);
    --shadow-sm: 0 12px 30px -18px rgba(40, 22, 28, .30);
    font-family: var(--b);
    color: var(--ink);
    background: var(--cream);
    -webkit-font-smoothing: antialiased;
    line-height: 1.65;
    overflow-x: hidden;
}
.pnw *, .pnw *::before, .pnw *::after { box-sizing: border-box; }
.pnw img { max-width: 100%; display: block; }
.pnw ::selection { background: var(--rose); color: #fff; }
.pnw .container { width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 28px; }
.pnw h1, .pnw h2, .pnw h3 { font-family: var(--d); font-weight: 500; line-height: 1.1; letter-spacing: -.01em; margin: 0; }
.pnw em { font-style: italic; color: var(--rose-d); }
.pnw p { margin: 0; }
.pnw a { color: inherit; text-decoration: none; }

/* eyebrow / klabel */
.pnw .klabel { display: inline-flex; align-items: center; gap: 10px; font-size: .72rem; font-weight: 600;
    letter-spacing: .18em; text-transform: uppercase; color: var(--rose-d); }
.pnw .klabel::before { content: ""; width: 26px; height: 1px; background: var(--rose); opacity: .7; }
.pnw .klabel.c { justify-content: center; }
.pnw .klabel.light { color: var(--gold-soft); }
.pnw .klabel.light::before { background: var(--gold-soft); }

/* section head */
.pnw .shead { max-width: 720px; margin: 0 auto 52px; text-align: center; }
.pnw .shead h2 { font-size: clamp(1.9rem, 3.6vw, 3rem); margin: 16px 0 14px; }
.pnw .shead p { color: var(--ink-2); font-size: 1.03rem; }

/* buttons */
.pnw .btn { display: inline-flex; align-items: center; gap: 9px; padding: 13px 24px; border-radius: 100px;
    font-family: var(--b); font-weight: 600; font-size: .92rem; cursor: pointer; border: 1px solid transparent;
    background: var(--ink); color: #fff; transition: all .35s var(--ease); }
.pnw .btn svg { width: 17px; height: 17px; transition: transform .35s var(--ease); }
.pnw .btn:hover { background: var(--rose-d); transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.pnw .btn:hover svg { transform: translateX(4px); }
.pnw .btn.ghost { background: transparent; color: var(--ink); border-color: var(--line); }
.pnw .btn.ghost:hover { background: var(--ink); color: #fff; border-color: var(--ink); }
.pnw .btn.light { background: #fff; color: var(--ink); }
.pnw .btn.light:hover { background: var(--rose-bg); color: var(--rose-d); }

/* section rhythm */
.pnw section { padding: clamp(64px, 9vw, 120px) 0; }

/* ============================ NAV ============================ */
.pnw .nav { position: sticky; top: 0; z-index: 50; background: rgba(250, 245, 242, .82);
    backdrop-filter: blur(16px); border-bottom: 1px solid var(--line-2); }
.pnw .nav-in { display: flex; align-items: center; gap: 20px; height: 74px; }
.pnw .brand { display: inline-flex; align-items: baseline; gap: 8px; }
.pnw .brand b { font-family: var(--d); font-weight: 600; font-size: 1.4rem; letter-spacing: .02em; color: var(--ink); }
.pnw .brand span { font-size: .64rem; font-weight: 700; letter-spacing: .34em; text-transform: uppercase; color: var(--rose-d); }
.pnw .nav-links { margin-left: auto; display: flex; align-items: center; gap: 30px; }
.pnw .nav-links a { font-size: .9rem; font-weight: 500; color: var(--ink-2); transition: color .25s; }
.pnw .nav-links a:not(.btn):hover { color: var(--rose-d); }
.pnw .nav-links .btn { padding: 11px 20px; }
.pnw .burger { display: none; margin-left: auto; width: 44px; height: 44px; border: 1px solid var(--line);
    border-radius: 12px; background: #fff; color: var(--ink); cursor: pointer; }
.pnw .burger svg { width: 22px; height: 22px; margin: auto; }

/* ============================ HERO ============================ */
.pnw .hero { position: relative; padding: clamp(40px, 6vw, 84px) 0 clamp(64px, 8vw, 110px);
    background:
        radial-gradient(60% 80% at 88% 8%, var(--rose-bg) 0%, transparent 60%),
        radial-gradient(50% 60% at 6% 92%, var(--cream-2) 0%, transparent 55%),
        var(--cream); }
.pnw .hero-in { display: grid; grid-template-columns: 1.04fr .96fr; gap: 56px; align-items: center; }
.pnw .hero-badge { display: inline-flex; align-items: center; gap: 9px; padding: 7px 15px; border-radius: 100px;
    background: #fff; border: 1px solid var(--line); font-size: .76rem; font-weight: 600; color: var(--ink-2); box-shadow: var(--shadow-sm); }
.pnw .hero-badge .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--rose); box-shadow: 0 0 0 4px var(--rose-bg); }
.pnw .hero h1 { font-size: clamp(2.6rem, 5.6vw, 4.5rem); margin: 22px 0 0; letter-spacing: -.02em; }
.pnw .hero-lead { margin: 22px 0 30px; max-width: 30em; color: var(--ink-2); font-size: 1.08rem; }
.pnw .hero-cta { display: flex; flex-wrap: wrap; gap: 12px; }
.pnw .hero-stats { display: grid; grid-template-columns: repeat(4, auto); gap: 30px; margin-top: 44px;
    padding-top: 30px; border-top: 1px solid var(--line); }
.pnw .hero-stat strong { display: block; font-family: var(--d); font-size: 1.7rem; font-weight: 600; color: var(--ink); line-height: 1; }
.pnw .hero-stat span { display: block; margin-top: 7px; font-size: .8rem; color: var(--muted); }

/* hero art collage */
.pnw .hero-art { position: relative; aspect-ratio: 1/1.04; }
.pnw .hero-art .a { position: absolute; border-radius: 22px; overflow: hidden; box-shadow: var(--shadow); background: #fff; }
.pnw .hero-art .a img { width: 100%; height: 100%; object-fit: cover; }
.pnw .hero-art .main { inset: 0 0 22% 24%; }
.pnw .hero-art .sub { width: 46%; aspect-ratio: 3/4; left: 0; bottom: 0; border: 5px solid var(--cream); }
.pnw .hero-art .blob { position: absolute; inset: -8% 8% 30% -6%; border-radius: 50%;
    background: radial-gradient(circle at 40% 40%, var(--rose-soft), var(--rose-bg)); filter: blur(8px); z-index: -1; }
.pnw .hero-art .chip { position: absolute; top: 6%; right: -2%; background: #fff; border-radius: 14px; padding: 12px 16px;
    box-shadow: var(--shadow); display: flex; align-items: center; gap: 10px; font-size: .8rem; font-weight: 600; }
.pnw .hero-art .chip i { width: 34px; height: 34px; border-radius: 9px; background: var(--rose-bg); color: var(--rose-d);
    display: grid; place-items: center; }
.pnw .hero-art .chip i svg { width: 18px; height: 18px; }

/* ============================ ABOUT ============================ */
.pnw .about { background: var(--paper); }
.pnw .about-grid { display: grid; grid-template-columns: .92fr 1.08fr; gap: 56px; align-items: center; }
.pnw .about-photo { position: relative; border-radius: 24px; overflow: hidden; box-shadow: var(--shadow); aspect-ratio: 4/3.4; }
.pnw .about-photo img { width: 100%; height: 100%; object-fit: cover; }
.pnw .about-photo .tagq { position: absolute; left: 18px; bottom: 18px; right: 18px; color: #fff;
    font-family: var(--d); font-style: italic; font-size: 1.15rem; text-shadow: 0 2px 16px rgba(0,0,0,.4); }
.pnw .about-body h2 { font-size: clamp(1.8rem, 3.4vw, 2.7rem); margin: 16px 0 18px; }
.pnw .about-body p { color: var(--ink-2); margin-bottom: 16px; }
.pnw .values { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; margin-top: 28px; }
.pnw .value { padding: 18px 18px 16px; border: 1px solid var(--line); border-radius: 16px; background: var(--cream); transition: all .3s var(--ease); }
.pnw .value:hover { border-color: var(--rose-soft); transform: translateY(-3px); box-shadow: var(--shadow-sm); }
.pnw .value .vk { font-family: var(--d); font-size: .78rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--rose-d); }
.pnw .value h4 { font-family: var(--b); font-size: 1.02rem; font-weight: 700; margin: 6px 0 6px; color: var(--ink); }
.pnw .value p { font-size: .86rem; color: var(--muted); line-height: 1.55; }

/* ============================ BRANDS ============================ */
.pnw .brands { background: linear-gradient(180deg, var(--cream) 0%, var(--rose-bg) 120%); }
.pnw .brand-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.pnw .bcard { --ac: var(--rose); background: #fff; border-radius: 20px; overflow: hidden; border: 1px solid var(--line-2);
    box-shadow: var(--shadow-sm); display: flex; flex-direction: column; transition: all .4s var(--ease); }
.pnw .bcard:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.pnw .bcard-media { position: relative; aspect-ratio: 4/3.3; overflow: hidden; background: var(--cream-2); }
.pnw .bcard-media img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.pnw .bcard:hover .bcard-media img { transform: scale(1.06); }
.pnw .bcard-media::after { content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 3px; background: var(--ac); }
.pnw .bcard-body { padding: 20px 20px 22px; display: flex; flex-direction: column; flex: 1; }
.pnw .bcard h3 { font-size: 1.32rem; letter-spacing: .01em; }
.pnw .bcard .slogan { font-size: .6rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--ac); margin-top: 5px; }
.pnw .bcard .cat { display: inline-block; margin: 12px 0 10px; font-size: .76rem; font-weight: 600; color: var(--ink-2);
    padding: 4px 11px; border-radius: 100px; background: color-mix(in srgb, var(--ac) 12%, #fff); align-self: flex-start; }
.pnw .bcard .bdesc { font-size: .88rem; color: var(--ink-2); line-height: 1.55; }
.pnw .bcard .pts { list-style: none; margin: 14px 0 0; padding: 14px 0 0; border-top: 1px solid var(--line-2); display: grid; gap: 8px; }
.pnw .bcard .pts li { display: flex; gap: 9px; font-size: .82rem; color: var(--ink-2); }
.pnw .bcard .pts svg { width: 16px; height: 16px; flex: none; color: var(--ac); margin-top: 2px; }

/* ============================ CELIGIN spotlight ============================ */
.pnw .celigin { background: var(--paper); }
.pnw .feat { display: grid; grid-template-columns: 1fr 1fr; gap: 52px; align-items: center; margin-top: 36px; }
.pnw .feat + .feat { margin-top: 70px; }
.pnw .feat.flip .feat-media { order: 2; }
.pnw .feat-media { border-radius: 22px; overflow: hidden; box-shadow: var(--shadow); aspect-ratio: 7/5; background: var(--cream-2); }
.pnw .feat-media img { width: 100%; height: 100%; object-fit: cover; }
.pnw .feat-body h3 { font-size: clamp(1.5rem, 2.6vw, 2.05rem); margin: 14px 0 14px; }
.pnw .feat-body > p { color: var(--ink-2); }
.pnw .chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }
.pnw .chips span { font-size: .8rem; font-weight: 500; color: var(--ink-2); padding: 7px 13px; border-radius: 100px;
    background: var(--rose-bg); border: 1px solid var(--rose-soft); }

/* Seawater sub-band */
.pnw .seawater { margin-top: 76px; border-radius: 28px; overflow: hidden; position: relative;
    background: linear-gradient(135deg, #2f6fb5 0%, #4a92cf 55%, #6fb6e6 100%); color: #fff; }
.pnw .sea-grid { display: grid; grid-template-columns: 1.02fr .98fr; gap: 44px; align-items: center; padding: clamp(34px, 4vw, 56px); }
.pnw .seawater .klabel { color: #dcefff; }
.pnw .seawater .klabel::before { background: #bfe6ff; }
.pnw .sea-grid h2 { color: #fff; font-size: clamp(1.7rem, 3vw, 2.4rem); margin: 14px 0 14px; }
.pnw .sea-grid h2 em { color: #d6f0ff; }
.pnw .sea-grid > div > p { color: rgba(255, 255, 255, .9); }
.pnw .sea-pts { list-style: none; margin: 22px 0 0; padding: 0; display: grid; gap: 14px; }
.pnw .sea-pts li { display: flex; gap: 13px; }
.pnw .sea-pts svg { width: 22px; height: 22px; flex: none; color: #d6f0ff; }
.pnw .sea-pts b { display: block; font-weight: 600; }
.pnw .sea-pts span { font-size: .88rem; color: rgba(255, 255, 255, .82); }
.pnw .sea-media { display: grid; grid-template-columns: 1.2fr 1fr; gap: 14px; }
.pnw .sea-media img { width: 100%; height: 100%; object-fit: cover; border-radius: 16px; box-shadow: 0 20px 40px -20px rgba(0, 30, 60, .5); }
.pnw .sea-media img:first-child { grid-row: span 2; }

/* ============================ MEDICAL (dark clinical) ============================ */
.pnw .medical { background: radial-gradient(80% 120% at 80% 0%, #2a2226 0%, #181316 70%); color: #efe7ea; }
.pnw .medical .shead h2, .pnw .medical .feat-body h3 { color: #fff; }
.pnw .medical .shead p { color: rgba(255, 255, 255, .66); }
.pnw .medical .klabel { color: var(--rose-soft); }
.pnw .medical .klabel::before { background: var(--rose-soft); }
.pnw .med-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-bottom: 40px; }
.pnw .mcard { background: rgba(255, 255, 255, .04); border: 1px solid rgba(255, 255, 255, .10); border-radius: 18px;
    overflow: hidden; transition: all .35s var(--ease); }
.pnw .mcard:hover { transform: translateY(-5px); border-color: var(--rose-soft); background: rgba(255, 255, 255, .07); }
.pnw .mcard-media { aspect-ratio: 16/10; overflow: hidden; background: #0d0a0c; }
.pnw .mcard-media img { width: 100%; height: 100%; object-fit: cover; }
.pnw .mcard-body { padding: 20px; }
.pnw .mcard h3 { font-size: 1.18rem; color: #fff; }
.pnw .mcard .items { margin: 9px 0 11px; font-size: .78rem; font-weight: 600; letter-spacing: .02em; color: var(--gold-soft); }
.pnw .mcard p { font-size: .86rem; color: rgba(255, 255, 255, .68); line-height: 1.55; }
.pnw .med-foot { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 22px;
    padding-top: 30px; border-top: 1px solid rgba(255, 255, 255, .12); }
.pnw .med-foot .lbl { font-size: .74rem; letter-spacing: .16em; text-transform: uppercase; color: rgba(255, 255, 255, .55); }
.pnw .cert-chips { display: flex; flex-wrap: wrap; gap: 10px; }
.pnw .cert-chips span { font-family: var(--d); font-weight: 600; font-size: .9rem; color: #fff; padding: 8px 18px;
    border: 1px solid rgba(255, 255, 255, .22); border-radius: 100px; }
.pnw .medical .btn.light { background: #fff; color: var(--ink); }

/* ============================ GLOBAL / awards ============================ */
.pnw .global { background: var(--cream); }
.pnw .glob-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 50px; }
.pnw .awards { list-style: none; margin: 0; padding: 0; }
.pnw .awards li { display: flex; gap: 18px; padding: 18px 0; border-bottom: 1px solid var(--line); align-items: baseline; }
.pnw .awards li:first-child { padding-top: 0; }
.pnw .awards .yr { font-family: var(--d); font-weight: 600; font-size: 1.1rem; color: var(--rose-d); flex: none; width: 54px; }
.pnw .awards .aw { font-size: .98rem; color: var(--ink); font-weight: 500; }
.pnw .glob-side .blk + .blk { margin-top: 30px; }
.pnw .glob-side .lbl { font-size: .74rem; letter-spacing: .16em; text-transform: uppercase; color: var(--muted); margin-bottom: 14px; }
.pnw .pills { display: flex; flex-wrap: wrap; gap: 9px; }
.pnw .pills span { font-size: .84rem; font-weight: 500; color: var(--ink-2); padding: 8px 14px; border-radius: 100px;
    background: #fff; border: 1px solid var(--line); }
.pnw .pills.gold span { background: #fff; }
.pnw .expos { list-style: none; margin: 0; padding: 0; display: grid; gap: 10px; }
.pnw .expos li { display: flex; gap: 10px; font-size: .9rem; color: var(--ink-2); }
.pnw .expos svg { width: 17px; height: 17px; color: var(--gold); flex: none; margin-top: 3px; }

/* ============================ CONTACT ============================ */
.pnw .contact { background: var(--paper); }
.pnw .contact-card { border-radius: 28px; overflow: hidden; display: grid; grid-template-columns: 1.1fr .9fr;
    background: linear-gradient(135deg, var(--ink) 0%, #3a2c30 100%); color: #fff; box-shadow: var(--shadow); }
.pnw .contact-main { padding: clamp(34px, 4vw, 58px); }
.pnw .contact-main .klabel { color: var(--rose-soft); }
.pnw .contact-main .klabel::before { background: var(--rose-soft); }
.pnw .contact-main h2 { font-size: clamp(1.8rem, 3vw, 2.6rem); color: #fff; margin: 16px 0 14px; }
.pnw .contact-main p { color: rgba(255, 255, 255, .78); max-width: 34em; margin-bottom: 26px; }
.pnw .contact-detail { padding: clamp(30px, 3.4vw, 48px); background: rgba(255, 255, 255, .05);
    border-left: 1px solid rgba(255, 255, 255, .12); display: flex; flex-direction: column; gap: 18px; font-style: normal; }
.pnw .cl small { display: block; font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--rose-soft); margin-bottom: 4px; }
.pnw .cl span, .pnw .cl a { font-size: .94rem; color: #fff; }
.pnw .cl a:hover { color: var(--rose-soft); }
.pnw .foot { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 12px; margin-top: 40px;
    padding-top: 26px; border-top: 1px solid var(--line); font-size: .82rem; color: var(--muted); }

/* ============================ PRODUCT CATALOGUE ============================ */
.pnw .catalogue { background: linear-gradient(180deg, #fff 0%, var(--cream) 100%); }
.pnw .pfilters { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px; margin: 0 0 40px; }
.pnw .pfilter { padding: 9px 18px; border-radius: 100px; border: 1px solid var(--line); background: #fff;
    font-family: var(--b); font-weight: 600; font-size: .85rem; color: var(--ink-2); cursor: pointer; transition: all .3s var(--ease); }
.pnw .pfilter:hover { border-color: var(--rose-soft); color: var(--rose-d); }
.pnw .pfilter.on { background: var(--ink); color: #fff; border-color: var(--ink); }
.pnw .pgrid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.pnw .pcard { background: #fff; border: 1px solid var(--line-2); border-radius: 16px; overflow: hidden;
    box-shadow: var(--shadow-sm); transition: all .4s var(--ease); }
.pnw .pcard:hover { transform: translateY(-5px); box-shadow: var(--shadow); }
.pnw .pcard-media { aspect-ratio: 1/1; overflow: hidden; background: var(--cream-2); }
.pnw .pcard-media img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.pnw .pcard:hover .pcard-media img { transform: scale(1.05); }
.pnw .pcard-body { padding: 16px 16px 18px; }
.pnw .ptag { font-size: .63rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--rose-d); }
.pnw .pcard h3 { font-family: var(--b); font-weight: 700; font-size: .96rem; margin: 6px 0 6px; color: var(--ink); letter-spacing: 0; }
.pnw .pcard p { font-size: .81rem; color: var(--muted); line-height: 1.5; }
.pnw .pmeta { display: flex; align-items: baseline; justify-content: space-between; gap: 8px;
    margin-top: 13px; padding-top: 11px; border-top: 1px solid var(--line-2); }
.pnw .pmeta .price { font-family: var(--d); font-weight: 600; font-size: 1rem; color: var(--ink); }
.pnw .pmeta .spec { font-size: .73rem; color: var(--muted); letter-spacing: .01em; }
.pnw .pnote { text-align: center; margin-top: 34px; font-size: .85rem; color: var(--muted); }
/* clickable card — persistent affordances (badge on image + "see ingredients" link) */
.pnw .pcard { cursor: pointer; }
.pnw .pcard:focus-visible { outline: 2px solid var(--rose-d); outline-offset: 3px; }
.pnw .pcard-media { position: relative; }
.pnw .pview { position: absolute; top: 12px; right: 12px; width: 36px; height: 36px; border-radius: 50%;
    background: rgba(255, 255, 255, .92); color: var(--ink); display: grid; place-items: center;
    box-shadow: 0 6px 16px -6px rgba(40, 22, 28, .35); backdrop-filter: blur(4px);
    transition: background .3s var(--ease), color .3s var(--ease), transform .3s var(--ease); }
.pnw .pview svg { width: 18px; height: 18px; }
.pnw .pcard:hover .pview, .pnw .pcard:focus-visible .pview { background: var(--rose-d); color: #fff; transform: scale(1.1); }
.pnw .pmore { display: inline-flex; align-items: center; gap: 6px; margin-top: 14px; font-size: .8rem; font-weight: 600; color: var(--rose-d); }
.pnw .pmore svg { width: 15px; height: 15px; transition: transform .25s var(--ease); }
.pnw .pcard:hover .pmore svg, .pnw .pcard:focus-visible .pmore svg { transform: translateX(4px); }
/* product modal */
body.pnw-modal-open { overflow: hidden; }
.pnw .pmodal { position: fixed; inset: 0; z-index: 200; display: flex; align-items: center; justify-content: center; padding: 20px; }
.pnw .pmodal[hidden] { display: none; }
.pnw .pmodal-scrim { position: absolute; inset: 0; background: rgba(28, 18, 22, .55); backdrop-filter: blur(6px); animation: pmf .3s var(--ease); }
.pnw .pmodal-card { position: relative; z-index: 1; width: 100%; max-width: 860px; max-height: 90vh; overflow: auto;
    background: #fff; border-radius: 22px; box-shadow: 0 40px 90px -30px rgba(28, 18, 22, .6); animation: pms .4s var(--ease); }
@keyframes pmf { from { opacity: 0; } to { opacity: 1; } }
@keyframes pms { from { opacity: 0; transform: translateY(24px) scale(.98); } to { opacity: 1; transform: none; } }
.pnw .pmodal-x { position: absolute; top: 14px; right: 14px; z-index: 2; width: 40px; height: 40px; border-radius: 50%;
    border: 1px solid var(--line); background: rgba(255, 255, 255, .9); color: var(--ink); cursor: pointer; display: grid; place-items: center; transition: all .25s; }
.pnw .pmodal-x:hover { background: var(--rose-bg); color: var(--rose-d); }
.pnw .pmodal-x svg { width: 20px; height: 20px; }
.pnw .pmodal-grid { display: grid; grid-template-columns: .9fr 1.1fr; }
.pnw .pmodal-media { background: var(--cream-2); }
.pnw .pmodal-media img { width: 100%; height: 100%; object-fit: cover; min-height: 300px; }
.pnw .pmodal-info { padding: clamp(24px, 3vw, 40px); }
.pnw .pmodal-info .ptag { font-size: .66rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--rose-d); }
.pnw .pmodal-info h3 { font-size: clamp(1.4rem, 2.4vw, 1.9rem); margin: 8px 0 12px; }
.pnw .pmodal-info .pmeta { margin: 0 0 16px; padding: 0 0 16px; }
.pnw .pchip { display: inline-block; margin: 0 0 13px; font-size: .73rem; font-weight: 600; color: #8a6a3a;
    padding: 5px 13px; border-radius: 100px; background: var(--gold-soft); }
.pnw .plead { color: var(--ink-2); font-size: .92rem; margin-bottom: 18px; }
.pnw .pih { font-family: var(--b); font-size: .72rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); margin: 4px 0 10px; }
.pnw .ingr { width: 100%; border-collapse: collapse; margin-bottom: 24px; }
.pnw .ingr th, .pnw .ingr td { text-align: left; vertical-align: top; padding: 9px 0; border-bottom: 1px solid var(--line-2); }
.pnw .ingr th { width: 42%; padding-right: 14px; font-weight: 600; font-size: .85rem; color: var(--ink); }
.pnw .ingr td { font-size: .84rem; color: var(--ink-2); }
.pnw .pmodal-info .btn { width: 100%; justify-content: center; }
@media (max-width: 720px) { .pnw .pmodal-grid { grid-template-columns: 1fr; } .pnw .pmodal-media img { min-height: 200px; max-height: 260px; } }
@media (max-width: 980px) { .pnw .pgrid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 700px) { .pnw .pgrid { grid-template-columns: repeat(2, 1fr); gap: 14px; } }

/* ============================ reveal ============================ */
.pnw .reveal { opacity: 0; transform: translateY(26px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.pnw .reveal.in { opacity: 1; transform: none; }

/* ============================ responsive ============================ */
@media (max-width: 980px) {
    .pnw .nav-links { position: fixed; inset: 74px 0 auto 0; flex-direction: column; align-items: stretch; gap: 0;
        background: rgba(250, 245, 242, .98); backdrop-filter: blur(18px); border-bottom: 1px solid var(--line);
        padding: 10px 20px 20px; transform: translateY(-130%); transition: transform .4s var(--ease); }
    body.menu-open .pnw .nav-links { transform: none; }
    .pnw .nav-links a { padding: 13px 0; border-bottom: 1px solid var(--line-2); }
    .pnw .nav-links .btn { margin-top: 12px; justify-content: center; }
    .pnw .burger { display: grid; place-items: center; }
    .pnw .hero-in, .pnw .about-grid, .pnw .feat, .pnw .feat.flip .feat-media, .pnw .sea-grid,
    .pnw .glob-grid, .pnw .contact-card { grid-template-columns: 1fr; }
    .pnw .feat.flip .feat-media { order: 0; }
    .pnw .brand-grid { grid-template-columns: repeat(2, 1fr); }
    .pnw .med-grid { grid-template-columns: 1fr; }
    .pnw .hero-art { max-width: 460px; margin: 0 auto; }
}
@media (max-width: 560px) {
    .pnw .container { padding: 0 18px; }
    .pnw .hero-stats { grid-template-columns: repeat(2, 1fr); gap: 22px; }
    .pnw .values, .pnw .brand-grid, .pnw .sea-media { grid-template-columns: 1fr; }
    .pnw .nav-links { gap: 0; }
}
