@import url('https://fonts.googleapis.com/css2?family=Quicksand:wght@400;500;600;700&display=swap');
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Quicksand',sans-serif;background:#fef6f9;color:#3d2c3e;line-height:1.7}
a{color:#c2185b}

.wrap{max-width:1000px;margin:0 auto;padding:0 18px}
header{padding:16px 0;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #f0dce4}
.brand{font-size:1.2rem;font-weight:700;color:#c2185b;text-decoration:none}
.brand i{font-style:normal;color:#bba}
nav a{font-size:.76rem;font-weight:600;color:#8a6a7a;text-decoration:none;margin-left:10px}
nav a:hover{color:#c2185b}

.hero{text-align:center;padding:36px 0 24px}
.hero h1{font-size:clamp(1.4rem,3.5vw,2.2rem);font-weight:700;color:#3d2c3e}
.hero h1 b{color:#c2185b}
.hero p{font-size:.88rem;color:#8a6a7a;max-width:440px;margin:6px auto 0}

.filter{display:flex;gap:6px;justify-content:center;flex-wrap:wrap;margin:18px 0 24px}
.fbtn{padding:5px 14px;font-size:.72rem;font-weight:700;border-radius:20px;cursor:pointer;border:1px solid #f0dce4;background:#fff;color:#8a6a7a;transition:.2s}
.fbtn:hover,.fbtn.on{background:#c2185b;color:#fff;border-color:#c2185b}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;padding-bottom:36px}
.gcard{background:#fff;border:1px solid #f0dce4;border-radius:12px;overflow:hidden;cursor:pointer;transition:.2s}
.gcard:hover{box-shadow:0 4px 16px rgba(194,24,91,.08);transform:translateY(-2px)}
.gcard img{width:100%;height:140px;object-fit:cover}
.gcard-b{padding:12px}
.gcard-b h3{font-size:.88rem;font-weight:700;margin-bottom:2px}
.gcard-b .r{font-size:.72rem;color:#c2185b}
.gcard-b p{font-size:.74rem;color:#8a6a7a;margin-top:4px;line-height:1.4}

/* Modal */
.modal-bg{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:100;justify-content:center;align-items:center;padding:20px}
.modal-bg.show{display:flex}
.modal{background:#fff;border-radius:14px;max-width:560px;width:100%;max-height:90vh;overflow-y:auto;padding:24px;position:relative}
.modal .x{position:absolute;top:12px;right:16px;font-size:1.2rem;cursor:pointer;color:#8a6a7a;background:0;border:0}
.modal h2{font-size:1.1rem;font-weight:700;margin-bottom:4px}
.modal .tags span{font-size:.6rem;font-weight:700;padding:2px 6px;border-radius:8px;margin-right:3px}
.modal .tags .mg{background:#fce4ec;color:#c2185b}
.modal .tags .mb{background:#e3f2fd;color:#1565c0}
.modal .gal{display:flex;gap:6px;overflow-x:auto;margin:10px 0}
.modal .gal img{width:140px;height:92px;border-radius:6px;object-fit:cover;border:1px solid #f0dce4;flex-shrink:0}
.modal>p{font-size:.84rem;color:#5a4a5a;margin-bottom:10px}
.modal .rate{font-size:.82rem;color:#c2185b;margin-bottom:10px}
.modal .pro,.modal .con{margin-bottom:8px}
.modal .pro h4{font-size:.66rem;color:#2e7d32;text-transform:uppercase;margin-bottom:2px}
.modal .con h4{font-size:.66rem;color:#c62828;text-transform:uppercase;margin-bottom:2px}
.modal li{font-size:.78rem;color:#6a5a6a;list-style:none;padding-left:12px;position:relative}
.modal .pro li::before{content:"\2713";position:absolute;left:0;color:#2e7d32;font-size:.65rem}
.modal .con li::before{content:"\2717";position:absolute;left:0;color:#c62828;font-size:.65rem}
.modal ul{padding:0;margin:0}
.btn-g{display:inline-flex;align-items:center;gap:4px;font-weight:700;font-size:.78rem;padding:7px 16px;border-radius:8px;background:#c2185b;color:#fff;text-decoration:none;margin-top:6px}
.btn-g:hover{background:#ad1457;color:#fff}

footer{border-top:1px solid #f0dce4;padding:18px;text-align:center;font-size:.66rem;color:#bba}
footer a{color:#8a6a7a;margin:0 5px;text-decoration:none}

.legal-p{max-width:600px;margin:0 auto;padding:30px 18px 50px}
.legal-p h1{font-size:1.3rem;font-weight:700;margin-bottom:4px}
.legal-p .dt{font-size:.72rem;color:#bba;margin-bottom:18px}
.legal-p h2{font-size:.9rem;font-weight:700;margin:16px 0 4px}
.legal-p p,.legal-p li{font-size:.82rem;color:#6a5a6a;margin-bottom:6px}
.legal-p ul{padding-left:14px}
@media(max-width:600px){.grid{grid-template-columns:1fr 1fr}}
@media(max-width:400px){.grid{grid-template-columns:1fr}}
