:root{
  --bg:#faf7f5;
  --surface:#ffffff;
  --text:#33302e;
  --muted:#8a817c;
  --accent:#c14b6e;
  --accent-bg:#fbeef2;
  --info:#3a6ea5;
  --info-bg:#eaf1fb;
  --border:#ece7e3;
  --radius:12px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{
  font-family:"Hiragino Sans","Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
.container{max-width:920px;margin:0 auto;padding:0 18px}
.nowrap{white-space:nowrap}

.topbar{
  background:var(--accent-bg);color:var(--accent);
  font-size:12px;text-align:center;padding:6px 12px;
}

.header{background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}
.header__inner{display:flex;align-items:center;justify-content:space-between;height:60px;gap:16px}
.logo{font-size:19px;font-weight:600;letter-spacing:.02em}
.logo__heart{color:var(--accent)}
.nav{display:flex;gap:18px;flex-wrap:wrap}
.nav a{font-size:14px;color:var(--muted);transition:color .15s}
.nav a:hover{color:var(--accent)}

.hero{
  background:var(--accent-bg);
  border-radius:var(--radius);
  padding:30px 28px;
  margin:24px 0;
}
.hero__title{font-size:26px;font-weight:600;margin:12px 0 6px;color:var(--accent)}
.hero__text{font-size:14px;color:var(--accent);opacity:.85;margin-bottom:18px}

.badge{display:inline-block;font-size:12px;font-weight:600;padding:4px 12px;border-radius:999px}
.badge--accent{background:var(--surface);color:var(--accent)}
.badge--off{background:var(--accent-bg);color:var(--accent);font-size:15px;padding:6px 12px}

.btn{display:inline-block;font-size:14px;font-weight:600;padding:10px 20px;border-radius:8px;border:none;cursor:pointer;transition:opacity .15s}
.btn--accent{background:var(--accent);color:#fff}
.btn--accent:hover{opacity:.88}
.btn--ghost{background:transparent;border:1px solid var(--border);color:var(--muted);font-weight:400}

.section{margin:34px 0}
.section__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.section__title{font-size:18px;font-weight:600}
.link{font-size:13px;color:var(--info);font-weight:500}
.link:hover{text-decoration:underline}

.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform .15s,box-shadow .15s}
.card:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,0,0,.06)}
.card__cover{display:flex;align-items:center;justify-content:center;aspect-ratio:3/4;background:#efe9e6;color:var(--muted);font-size:13px}
.card__body{padding:12px 13px}
.card__title{font-size:14px;font-weight:600;line-height:1.5;margin:7px 0 6px}
.tag{display:inline-block;font-size:11px;background:#f1ece9;color:var(--muted);padding:2px 9px;border-radius:999px}
.stars{color:#e6a23c;font-size:14px;letter-spacing:1px;margin-bottom:7px}
.stars__off{color:#dcd6d1}

.sale{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:13px 15px;margin-bottom:12px;flex-wrap:wrap}
.sale__body{flex:1;min-width:160px}
.sale__name{font-size:14px;font-weight:600;margin-bottom:6px}
.chip{display:inline-block;font-size:11px;background:#f1ece9;color:var(--muted);padding:2px 9px;border-radius:999px;margin-right:4px}
.chip--info{background:var(--info-bg);color:var(--info)}

.footer{background:var(--surface);border-top:1px solid var(--border);margin-top:40px;padding:22px 0 28px}
.footer__inner{display:flex;align-items:center;gap:16px;flex-wrap:wrap;font-size:12px;color:var(--muted)}
.footer__nav{display:flex;gap:14px;flex-wrap:wrap}
.footer__nav a:hover{color:var(--accent)}
.footer__copy{margin-left:auto}
.footer__pr{font-size:11px;color:var(--muted);margin-top:10px;text-align:center;opacity:.8}

.agegate{position:fixed;inset:0;z-index:100;background:rgba(40,30,30,.78);display:flex;align-items:center;justify-content:center;padding:20px}
.agegate__box{background:var(--surface);border-radius:var(--radius);padding:30px 26px;max-width:360px;text-align:center}
.agegate__title{font-size:17px;font-weight:600;margin-bottom:10px}
.agegate__text{font-size:13px;color:var(--muted);margin-bottom:20px}
.agegate__btns{display:flex;flex-direction:column;gap:10px}

@media(max-width:560px){
  .header__inner{height:auto;flex-direction:column;padding:10px 0;gap:8px}
  .hero{padding:24px 20px}
  .hero__title{font-size:21px}
  .footer__copy{margin-left:0}
}
