:root{
  --cream:#fdf8f2; --cream2:#fbeee2;
  --pink:#f6b8cf; --pink-d:#e88aae;
  --lav:#c9b6e4; --lav-d:#a98fd4;
  --mint:#a7dcc8; --sky:#a9cdec;
  --ink:#7a5a48; --ink-soft:#9a7d6c;
  --gold:#f2c879;
  --card:#fffdfb;
  --shadow:0 14px 40px -18px rgba(160,120,150,.45);
  --shadow-sm:0 8px 24px -14px rgba(160,120,150,.5);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Zen Maru Gothic','Kosugi Maru',sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at 12% 8%, #fce8f0 0, transparent 38%),
    radial-gradient(circle at 88% 22%, #ece2f8 0, transparent 42%),
    radial-gradient(circle at 70% 90%, #e4f4ec 0, transparent 40%),
    var(--cream);
  background-attachment:fixed;
  line-height:1.7; overflow-x:hidden;
}
.sparkle{position:fixed;pointer-events:none;z-index:0;opacity:.5;animation:float 9s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-22px) rotate(12deg)}}

header{position:sticky;top:0;z-index:50;backdrop-filter:saturate(1.3) blur(14px);background:rgba(253,248,242,.78);border-bottom:2px dotted #ecd3c4}
.nav{max-width:1180px;margin:0 auto;padding:10px 22px;display:flex;align-items:center;gap:18px}
.nav .logo{height:58px;filter:drop-shadow(0 4px 8px rgba(180,140,160,.3))}
.brand-txt{display:flex;flex-direction:column;line-height:1.15}
.brand-txt b{font-weight:900;font-size:1.15rem;letter-spacing:.04em}
.brand-txt span{font-size:.68rem;color:var(--ink-soft);letter-spacing:.25em}
.nav-spacer{flex:1}
.nav a.navlink{text-decoration:none;color:var(--ink);font-weight:500;font-size:.92rem;padding:7px 15px;border-radius:999px;transition:.25s;white-space:nowrap}
.nav a.navlink:hover{background:var(--pink);color:#fff}
.cart-btn{background:linear-gradient(135deg,var(--pink),var(--lav));color:#fff;border:none;font-family:inherit;font-weight:700;padding:9px 20px;border-radius:999px;cursor:pointer;font-size:.9rem;box-shadow:var(--shadow-sm);transition:.25s}
.cart-btn:hover{transform:translateY(-2px) scale(1.03)}
@media(max-width:720px){.nav .navlink{display:none}.brand-txt span{display:none}}

.hero{position:relative;max-width:1180px;margin:0 auto;padding:54px 22px 30px;text-align:center;z-index:1}
.hero .ring{width:188px;height:188px;margin:0 auto 6px;border-radius:50%;background:radial-gradient(circle,#fff,#fbeee2);display:grid;place-items:center;box-shadow:var(--shadow),inset 0 0 0 7px #fff,inset 0 0 0 9px #f3dcd0;animation:pop .9s cubic-bezier(.2,1.4,.4,1) both}
.hero .ring img{width:150px;animation:float 6s ease-in-out infinite}
@keyframes pop{from{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}
.hero h1{font-family:'Pacifico',cursive;font-weight:400;font-size:clamp(2.4rem,7vw,4.1rem);background:linear-gradient(100deg,var(--pink-d),var(--lav-d),var(--sky));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin:6px 0 2px;line-height:1.05}
.hero .jp{font-weight:900;font-size:clamp(1rem,3vw,1.4rem);letter-spacing:.32em;color:var(--ink)}
.hero p.lead{max-width:540px;margin:14px auto 0;color:var(--ink-soft);font-size:1rem}
.hero .pills{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:20px}
.hero .pills b{background:#fff;border:2px dotted #ecd3c4;border-radius:999px;padding:7px 16px;font-size:.82rem;font-weight:500;color:var(--ink-soft)}

.filterbar{position:sticky;top:80px;z-index:40;max-width:1180px;margin:26px auto 0;padding:12px 16px;display:flex;gap:9px;flex-wrap:wrap;justify-content:center;align-items:center;background:rgba(255,253,251,.85);backdrop-filter:blur(8px);border-radius:22px;box-shadow:var(--shadow-sm)}
.chip{font-family:inherit;font-weight:500;font-size:.85rem;color:var(--ink);background:#fff;border:2px solid #f3dcd0;border-radius:999px;padding:7px 16px;cursor:pointer;transition:.22s}
.chip:hover{border-color:var(--pink);transform:translateY(-1px)}
.chip.on{background:linear-gradient(135deg,var(--pink),var(--lav));color:#fff;border-color:transparent;box-shadow:var(--shadow-sm)}
.count{font-size:.78rem;color:var(--ink-soft);margin-left:4px}

.grid{max-width:1180px;margin:26px auto 60px;padding:0 22px;display:grid;grid-template-columns:repeat(auto-fill,minmax(245px,1fr));gap:24px}
.card{background:var(--card);border-radius:26px;overflow:hidden;cursor:pointer;box-shadow:var(--shadow-sm);position:relative;border:2px solid #fff;transition:.3s cubic-bezier(.2,.9,.3,1);opacity:0;transform:translateY(24px) scale(.97);animation:rise .6s forwards}
@keyframes rise{to{opacity:1;transform:none}}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:var(--pink)}
.card .ph{position:relative;aspect-ratio:1/1.16;overflow:hidden;background:#f3ece4}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:.5s}
.card:hover .ph img{transform:scale(1.07)}
.card .tag{position:absolute;top:12px;left:12px;background:rgba(255,255,255,.92);color:var(--ink);font-size:.72rem;font-weight:700;padding:4px 11px;border-radius:999px;box-shadow:var(--shadow-sm)}
.card .fav{position:absolute;top:11px;right:11px;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.9);border:none;cursor:pointer;font-size:1rem;display:grid;place-items:center;transition:.2s;color:#e88aae}
.card .fav:hover{transform:scale(1.2)}
.card .pcount{position:absolute;bottom:11px;right:11px;background:rgba(122,90,72,.78);color:#fff;font-size:.7rem;font-weight:700;padding:3px 9px;border-radius:999px;display:flex;align-items:center;gap:3px}
.card .body{padding:14px 16px 17px}
.card .nm{font-weight:700;font-size:.96rem;line-height:1.4;min-height:2.6em}
.card .colorrow{display:flex;gap:5px;margin:8px 0 9px}
.card .dot{width:14px;height:14px;border-radius:50%;box-shadow:inset 0 0 0 1.5px rgba(0,0,0,.06)}
.card .pr{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.card .pr .price{font-weight:900;font-size:1.18rem;color:var(--pink-d)}
.card .pr .add{background:var(--mint);border:none;color:#36705a;font-weight:700;font-family:inherit;padding:6px 13px;border-radius:999px;cursor:pointer;font-size:.8rem;transition:.2s}
.card .pr .add:hover{background:var(--lav);color:#fff}
.card .mercari-card{display:block;text-align:center;text-decoration:none;background:#fff;border:2px solid #f3dcd0;color:var(--ink);font-weight:700;font-size:.82rem;padding:8px;border-radius:14px;transition:.22s}
.card .mercari-card:hover{background:linear-gradient(135deg,#ff5e6c,#ff8a3d);color:#fff;border-color:transparent}

.modal{position:fixed;inset:0;z-index:100;display:none;align-items:center;justify-content:center;padding:18px}
.modal.open{display:flex}
.modal .ov{position:absolute;inset:0;background:rgba(122,90,72,.42);backdrop-filter:blur(4px)}
.sheet{position:relative;background:var(--card);border-radius:30px;max-width:820px;width:100%;max-height:90vh;overflow:auto;box-shadow:var(--shadow);display:grid;grid-template-columns:1fr 1fr;animation:pop .4s cubic-bezier(.2,1.4,.4,1)}
.sheet .mph{background:#f3ece4;display:flex;flex-direction:column}
.sheet .mph img#mImg{width:100%;height:100%;object-fit:cover;min-height:340px;flex:1}
.sheet .thumbs{display:flex;gap:7px;padding:9px;flex-wrap:wrap;background:#fff}
.sheet .thumbs img{width:54px;height:54px;object-fit:cover;border-radius:11px;cursor:pointer;border:2px solid transparent;transition:.2s;box-shadow:var(--shadow-sm)}
.sheet .thumbs img:hover{transform:translateY(-2px)}
.sheet .thumbs img.on{border-color:var(--pink)}
.sheet .minfo{padding:30px 28px}
.sheet .x{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:50%;border:none;background:#fff;cursor:pointer;font-size:1.1rem;box-shadow:var(--shadow-sm);z-index:2;color:var(--ink)}
.sheet .mtag{display:inline-block;background:var(--cream2);color:var(--ink-soft);font-size:.76rem;font-weight:700;padding:5px 13px;border-radius:999px;margin-bottom:12px}
.sheet h2{font-size:1.5rem;font-weight:900;line-height:1.35;margin-bottom:10px}
.sheet .mdesc{color:var(--ink-soft);font-size:.94rem;margin-bottom:18px}
.sheet .mcolor{display:flex;gap:7px;margin-bottom:18px}
.sheet .mcolor .dot{width:24px;height:24px;border-radius:50%;box-shadow:inset 0 0 0 2px rgba(0,0,0,.06)}
.sheet .mprice{font-size:2rem;font-weight:900;color:var(--pink-d);margin-bottom:4px}
.sheet .mnote{font-size:.78rem;color:var(--ink-soft);margin-bottom:18px}
.sheet .mercari-btn{display:block;text-align:center;text-decoration:none;background:linear-gradient(135deg,#ff5e6c,#ff8a3d);color:#fff;font-weight:700;font-size:1rem;padding:14px;border-radius:16px;cursor:pointer;box-shadow:var(--shadow-sm);transition:.25s;margin-bottom:10px}
.sheet .mercari-btn:hover{transform:translateY(-2px)}
.sheet .mbtn{width:100%;background:linear-gradient(135deg,var(--pink),var(--lav));color:#fff;border:none;font-family:inherit;font-weight:700;font-size:1rem;padding:14px;border-radius:16px;cursor:pointer;transition:.25s;box-shadow:var(--shadow-sm)}
.sheet .mbtn:hover{transform:translateY(-2px)}
.sheet .htags{margin-top:16px;display:flex;flex-wrap:wrap;gap:6px}
.sheet .htags span{font-size:.76rem;color:var(--lav-d);background:#f3eefb;padding:3px 10px;border-radius:999px}
@media(max-width:640px){.sheet{grid-template-columns:1fr}.sheet .mph img{min-height:240px}}

.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(120px);z-index:200;background:var(--ink);color:#fff;padding:13px 24px;border-radius:999px;font-weight:700;font-size:.9rem;box-shadow:var(--shadow);transition:.4s cubic-bezier(.2,1.4,.4,1)}
.toast.show{transform:translateX(-50%) translateY(0)}

#about{max-width:760px;margin:30px auto 10px;padding:0 22px;text-align:center}
.about-h{font-family:'Pacifico',cursive;font-size:2rem;color:var(--lav-d);font-weight:400}
.about-p{color:var(--ink-soft);margin-top:14px}
footer{background:linear-gradient(180deg,transparent,#fbeee2);padding:50px 22px 40px;text-align:center;position:relative;z-index:1}
footer .fl{font-family:'Pacifico',cursive;font-size:1.8rem;background:linear-gradient(100deg,var(--pink-d),var(--lav-d));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
footer p{color:var(--ink-soft);font-size:.85rem;margin-top:8px}
footer .socials{display:flex;gap:14px;justify-content:center;margin:18px 0}
footer .socials a{width:42px;height:42px;border-radius:50%;background:#fff;display:grid;place-items:center;text-decoration:none;font-size:1.1rem;box-shadow:var(--shadow-sm);transition:.25s}
footer .socials a:hover{transform:translateY(-3px) scale(1.08)}
footer .copy{margin-top:10px;opacity:.7}
.heartdivider{font-size:1rem;color:var(--pink);letter-spacing:.5em;margin:14px 0}

/* ---------- CART DRAWER ---------- */
.cart-overlay{position:fixed;inset:0;background:rgba(122,90,72,.42);backdrop-filter:blur(4px);z-index:90;opacity:0;pointer-events:none;transition:.3s}
.cart-overlay.open{opacity:1;pointer-events:auto}
.cart-drawer{position:fixed;top:0;right:0;height:100%;width:400px;max-width:92vw;background:var(--card);z-index:95;display:flex;flex-direction:column;box-shadow:-12px 0 40px -16px rgba(160,120,150,.5);transform:translateX(105%);transition:.36s cubic-bezier(.2,.9,.3,1)}
.cart-drawer.open{transform:none}
.cart-head{display:flex;align-items:center;justify-content:space-between;padding:20px 22px;border-bottom:2px dotted #ecd3c4}
.cart-head h3{font-size:1.18rem;font-weight:900}
.cart-head h3 span{font-size:.82rem;color:var(--ink-soft);font-weight:500;margin-left:4px}
.cart-x{width:36px;height:36px;border-radius:50%;border:none;background:var(--cream2);cursor:pointer;font-size:1rem;color:var(--ink);transition:.2s}
.cart-x:hover{background:var(--pink);color:#fff}
.cart-list{flex:1;overflow-y:auto;padding:14px 18px}
.cart-empty{text-align:center;color:var(--ink-soft);padding:70px 20px;font-size:2.6rem}
.cart-empty p{font-size:1rem;font-weight:700;color:var(--ink);margin-top:10px}
.cart-empty span{font-size:.84rem}
.cart-item{display:grid;grid-template-columns:64px 1fr auto;gap:12px;align-items:center;padding:13px 0;border-bottom:1px solid #f3e6dc}
.cart-item img{width:64px;height:64px;object-fit:cover;border-radius:14px;box-shadow:var(--shadow-sm)}
.ci-name{font-weight:700;font-size:.9rem;line-height:1.35}
.ci-price{font-size:.78rem;color:var(--ink-soft);margin:2px 0 6px}
.ci-qty{display:flex;align-items:center;gap:8px}
.ci-qty button{width:26px;height:26px;border-radius:50%;border:2px solid #f3dcd0;background:#fff;cursor:pointer;font-size:.95rem;color:var(--ink);font-weight:700;line-height:1;transition:.18s}
.ci-qty button:hover{background:var(--pink);color:#fff;border-color:transparent}
.ci-qty span{min-width:18px;text-align:center;font-weight:700}
.ci-qty .ci-del{border-color:transparent;font-size:.8rem;margin-left:2px}
.ci-qty .ci-del:hover{background:#ffe0e0}
.ci-sub{font-weight:900;color:var(--pink-d);font-size:.95rem;white-space:nowrap}
.cart-foot{padding:18px 22px 22px;border-top:2px dotted #ecd3c4;background:#fffdfb}
.cart-total-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.cart-total-row span{font-weight:700;font-size:.95rem}
.cart-total-row b{font-size:1.7rem;font-weight:900;color:var(--pink-d)}
.cart-note{font-size:.74rem;color:var(--ink-soft);margin-bottom:14px}
.pay-mercari,.pay-email{width:100%;border:none;font-family:inherit;font-weight:700;font-size:.98rem;padding:14px;border-radius:16px;cursor:pointer;transition:.25s;box-shadow:var(--shadow-sm)}
.pay-mercari{background:linear-gradient(135deg,#ff5e6c,#ff8a3d);color:#fff;margin-bottom:10px}
.pay-email{background:linear-gradient(135deg,var(--lav),var(--sky));color:#fff}
.pay-mercari:hover,.pay-email:hover{transform:translateY(-2px)}
@media(max-width:480px){.cart-drawer{width:100%}}

/* ---------- 今すぐ買う ボタン ---------- */
.pay-now{width:100%;border:none;font-family:inherit;font-weight:900;font-size:1.02rem;padding:15px;border-radius:16px;cursor:pointer;transition:.25s;box-shadow:var(--shadow-sm);background:linear-gradient(135deg,#ffcf5e,#ff9a3d);color:#7a4a10;margin-bottom:10px}
.pay-now:hover{transform:translateY(-2px)}
.sheet .mbuy{width:100%;border:none;font-family:inherit;font-weight:900;font-size:1rem;padding:14px;border-radius:16px;cursor:pointer;transition:.25s;box-shadow:var(--shadow-sm);background:linear-gradient(135deg,#ffcf5e,#ff9a3d);color:#7a4a10;margin-bottom:10px}
.sheet .mbuy:hover{transform:translateY(-2px)}

/* ---------- チェックアウト（Amazon風） ---------- */
.checkout{position:fixed;inset:0;z-index:120;display:none;background:rgba(122,90,72,.5);backdrop-filter:blur(5px);overflow-y:auto}
.checkout.open{display:block}
.co-inner{max-width:1000px;margin:34px auto;background:var(--card);border-radius:26px;box-shadow:var(--shadow);overflow:hidden;animation:pop .4s cubic-bezier(.2,1.4,.4,1)}
.co-head{display:flex;align-items:center;justify-content:space-between;padding:20px 28px;border-bottom:2px dotted #ecd3c4}
.co-head h2{font-size:1.4rem;font-weight:900}
.co-x{width:38px;height:38px;border-radius:50%;border:none;background:var(--cream2);cursor:pointer;font-size:1.05rem;color:var(--ink);transition:.2s}
.co-x:hover{background:var(--pink);color:#fff}
.co-body{display:grid;grid-template-columns:1fr 320px;gap:0}
.co-main{padding:24px 28px}
.co-block{margin-bottom:26px}
.co-block h3{font-size:1.05rem;font-weight:900;margin-bottom:14px;padding-bottom:8px;border-bottom:2px solid #f3e6dc}
.co-fields{display:grid;gap:13px}
.co-fields label{display:flex;flex-direction:column;font-size:.82rem;font-weight:700;color:var(--ink-soft);gap:5px}
.co-fields label span{color:#e8607a}
.co-fields input{font-family:inherit;font-size:.95rem;padding:11px 14px;border:2px solid #f0e0d4;border-radius:13px;background:#fffdfb;color:var(--ink);transition:.2s}
.co-fields input:focus{outline:none;border-color:var(--pink);box-shadow:0 0 0 3px rgba(246,184,207,.25)}
.co-pays{display:grid;gap:10px}
.co-pay{display:flex;align-items:center;gap:12px;padding:13px 16px;border:2px solid #f0e0d4;border-radius:14px;cursor:pointer;font-weight:700;font-size:.92rem;transition:.2s}
.co-pay:hover{border-color:var(--pink)}
.co-pay input{accent-color:var(--pink-d);width:18px;height:18px}
.co-pay:has(input:checked){border-color:var(--pink);background:#fdf1f6}
.co-items{display:grid;gap:12px}
.co-item{display:grid;grid-template-columns:54px 1fr auto auto;gap:13px;align-items:center;padding:11px;background:#fffdfb;border:1px solid #f3e6dc;border-radius:14px}
.co-item img{width:54px;height:54px;object-fit:cover;border-radius:11px}
.co-it-name{font-weight:700;font-size:.88rem;line-height:1.35;display:flex;flex-direction:column}
.co-it-name span{font-size:.7rem;color:var(--ink-soft);font-weight:500}
.co-it-qty{font-size:.8rem;color:var(--ink-soft)}
.co-it-price{font-weight:900;color:var(--pink-d);font-size:.92rem;white-space:nowrap}
.co-summary{background:linear-gradient(180deg,#fbeee2,#fdf8f2);padding:24px 24px;border-left:2px dotted #ecd3c4}
.co-summary h3{font-size:1rem;font-weight:900;margin-bottom:14px}
.co-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px;font-size:.9rem}
.co-row span{color:var(--ink-soft)}
.co-row b{font-weight:700}
.co-ship b{color:#3a9b6e}
.co-grand{border-top:2px solid #ecd3c4;padding-top:12px;margin-top:4px}
.co-grand span{font-weight:900;color:var(--ink)}
.co-grand b{font-size:1.6rem;font-weight:900;color:var(--pink-d)}
.co-place{width:100%;border:none;font-family:inherit;font-weight:900;font-size:1.05rem;padding:15px;border-radius:16px;cursor:pointer;transition:.25s;box-shadow:var(--shadow-sm);background:linear-gradient(135deg,#ffcf5e,#ff9a3d);color:#7a4a10;margin-top:8px}
.co-place:hover{transform:translateY(-2px)}
.co-fine{font-size:.72rem;color:var(--ink-soft);margin-top:12px;line-height:1.6}
@media(max-width:760px){.co-body{grid-template-columns:1fr}.co-summary{border-left:none;border-top:2px dotted #ecd3c4}.co-inner{margin:0;border-radius:0;min-height:100vh}}


/* ---------- v2: product page ---------- */
.pp{max-width:1080px;margin:30px auto 60px;padding:0 20px}
.crumbs{font-size:.82rem;color:var(--ink-soft);margin:14px 0 18px}
.crumbs a{color:var(--ink-soft);text-decoration:none}
.crumbs a:hover{color:var(--pink-d)}
.pp-grid{display:grid;grid-template-columns:1fr 1fr;gap:34px}
.pp-gallery .main{border-radius:24px;overflow:hidden;background:#f3ece4;box-shadow:var(--shadow)}
.pp-gallery .main picture,.pp-gallery .main img{width:100%;display:block;aspect-ratio:1/1.1;object-fit:cover}
.pp-thumbs{display:flex;gap:9px;margin-top:12px;flex-wrap:wrap}
.pp-thumbs picture,.pp-thumbs img{width:70px;height:70px;object-fit:cover;border-radius:13px;cursor:pointer;border:2px solid transparent;box-shadow:var(--shadow-sm);transition:.2s}
.pp-thumbs .ti.on img{border-color:var(--pink)}
.pp-info{align-self:start}
.pp-cat{display:inline-block;background:var(--cream2);color:var(--ink-soft);font-size:.78rem;font-weight:700;padding:5px 14px;border-radius:999px;margin-bottom:12px}
.pp-info h1{font-size:1.7rem;font-weight:900;line-height:1.4;margin-bottom:10px}
.pp-price{font-size:2.1rem;font-weight:900;color:var(--pink-d);margin:6px 0}
.pp-desc{color:var(--ink-soft);margin:14px 0;line-height:1.9}
.pp-tags{display:flex;flex-wrap:wrap;gap:7px;margin:14px 0}
.pp-tags span{font-size:.78rem;color:var(--lav-d);background:#f3eefb;padding:4px 11px;border-radius:999px}
.pp-note{font-size:.8rem;color:var(--ink-soft);margin:12px 0 20px}
.pp-actions{display:grid;gap:10px;max-width:420px}
.pp-buy{border:none;font-family:inherit;font-weight:900;font-size:1.02rem;padding:15px;border-radius:16px;cursor:pointer;transition:.25s;box-shadow:var(--shadow-sm);background:linear-gradient(135deg,#ffcf5e,#ff9a3d);color:#7a4a10}
.pp-cart{border:none;font-family:inherit;font-weight:700;font-size:1rem;padding:14px;border-radius:16px;cursor:pointer;transition:.25s;box-shadow:var(--shadow-sm);background:linear-gradient(135deg,var(--pink),var(--lav));color:#fff}
.pp-merc{text-align:center;text-decoration:none;font-weight:700;font-size:1rem;padding:14px;border-radius:16px;background:linear-gradient(135deg,#ff5e6c,#ff8a3d);color:#fff;box-shadow:var(--shadow-sm);transition:.25s}
.pp-buy:hover,.pp-cart:hover,.pp-merc:hover{transform:translateY(-2px)}
.pp-back{display:inline-block;margin:8px 0 0;text-decoration:none;color:var(--ink-soft);font-weight:700;font-size:.9rem}
.pp-back:hover{color:var(--pink-d)}
.related{margin-top:50px}
.related h2{font-family:Pacifico,cursive;font-size:1.5rem;color:var(--lav-d);font-weight:400;text-align:center;margin-bottom:20px}
.related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}
.related-grid a{text-decoration:none;color:var(--ink);background:var(--card);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-sm);transition:.25s;display:block}
.related-grid a:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.related-grid .rimg{aspect-ratio:1/1.05;overflow:hidden;background:#f3ece4}
.related-grid .rimg picture,.related-grid .rimg img{width:100%;height:100%;object-fit:cover}
.related-grid .rb{padding:10px 12px}
.related-grid .rn{font-size:.82rem;font-weight:700;line-height:1.35;min-height:2.4em}
.related-grid .rp{font-weight:900;color:var(--pink-d);font-size:.95rem;margin-top:4px}
.contact-sec{max-width:600px;margin:40px auto;padding:0 22px}
.contact-sec h2{font-family:Pacifico,cursive;font-size:1.9rem;color:var(--lav-d);font-weight:400;text-align:center;margin-bottom:8px}
.contact-sec p.cintro{text-align:center;color:var(--ink-soft);margin-bottom:20px;font-size:.9rem}
.cform{display:grid;gap:13px;background:var(--card);padding:26px;border-radius:24px;box-shadow:var(--shadow-sm)}
.cform label{display:flex;flex-direction:column;font-size:.82rem;font-weight:700;color:var(--ink-soft);gap:5px}
.cform input,.cform textarea{font-family:inherit;font-size:.95rem;padding:11px 14px;border:2px solid #f0e0d4;border-radius:13px;background:#fffdfb;color:var(--ink)}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--pink);box-shadow:0 0 0 3px rgba(246,184,207,.25)}
.cform textarea{min-height:120px;resize:vertical}
.cform button{border:none;font-family:inherit;font-weight:900;font-size:1rem;padding:14px;border-radius:16px;cursor:pointer;background:linear-gradient(135deg,var(--pink),var(--lav));color:#fff;box-shadow:var(--shadow-sm);transition:.25s}
.cform button:hover{transform:translateY(-2px)}
.cmsg{text-align:center;font-weight:700;padding:10px;border-radius:12px;display:none}
.cmsg.ok{display:block;background:#e4f4ec;color:#2f7a52}
.cmsg.err{display:block;background:#fdeaea;color:#b44}
@media(max-width:720px){.pp-grid{grid-template-columns:1fr}}
