
:root{
--page-bg:#f5f5f8;
--card-bg:#ffffff;
--color-primary:#302c4d;
--text-main:var(--color-primary);
--text-sub:#6f6f80;
--accent:#ff4356;
--accent-hover:#ff5b6b;
--stock-ok:#029cde;
--border-soft:#e5e6ee;
--shadow-soft:0 18px 45px rgba(15,23,42,0.12);
--pill-bg:#f3f4fb;
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--page-bg);color:var(--color-primary)}
body.modal-open{overflow:hidden}
header,footer{padding:16px 24px;border-bottom:1px solid var(--border-soft);background:transparent}
footer{border-top:1px solid var(--border-soft);border-bottom:none;margin-top:48px}
.container{max-width:980px;margin:0 auto;padding:16px}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.card{border:1px solid var(--border-soft);border-radius:12px;overflow:hidden;background:var(--card-bg);display:flex;flex-direction:column}
.card img{width:100%;aspect-ratio:1/1;object-fit:cover;background:#f2f2f2}
.card .p{padding:12px}
.price{font-weight:700;margin-top:4px}
.btn,button{display:inline-block;border:1px solid var(--border-soft);padding:.6rem .9rem;border-radius:.8rem;cursor:pointer;background:var(--card-bg);text-decoration:none;color:var(--color-primary)}
.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-primary{border:none;cursor:pointer;padding:0 28px;height:42px;border-radius:999px;background:var(--accent);color:#fff;font-size:15px;font-weight:600;letter-spacing:.02em;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 14px 30px rgba(255,91,106,.45);transition:transform .16s ease,box-shadow .16s ease,background-color .16s ease;text-decoration:none}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 18px 36px rgba(255,91,106,.55);background:var(--accent-hover)}
.btn-primary.is-disabled,.btn-primary:disabled{background:#d4d4dd;box-shadow:none;cursor:not-allowed}
.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
nav a{margin-right:12px}
.badge{display:inline-flex;align-items:center;gap:.35rem;border:1px solid var(--border-soft);border-radius:999px;padding:.2rem .6rem}
table{width:100%;border-collapse:collapse}
th,td{padding:10px;border-bottom:1px solid var(--border-soft);text-align:left}
.total{font-size:1.1rem;font-weight:700;margin-top:12px}
note{display:block;padding:.75rem 1rem;border:1px dashed #bbb;border-radius:.75rem;background:#fafafa;margin:12px 0}
.share{display:flex;gap:.5rem;flex-wrap:wrap;margin:1rem 0}
.share .btn{font-size:.9rem}
small.muted{opacity:.7}
.history-page{background:linear-gradient(to bottom,var(--page-bg) 0,var(--page-bg) 76%,var(--page-bg) 76%);min-height:100vh;padding:16px 0 96px}
.history-shell{max-width:1320px;margin:0 auto;padding:0 24px}
.history-header{margin-bottom:24px}
.history-header-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.history-title{font-size:30px;margin:0;color:var(--text-main)}
.history-note{margin-top:8px;font-size:13px;color:var(--text-sub)}
.history-empty{font-size:14px;color:var(--text-sub);padding:32px 24px;text-align:center;border-radius:24px;background:var(--card-bg);border:1px solid var(--border-soft);box-shadow:0 10px 25px rgba(15,23,42,0.05)}
.history-orders{display:flex;flex-direction:column;gap:20px}
.history-card{background:var(--card-bg);border-radius:24px;border:1px solid var(--border-soft);box-shadow:0 12px 26px rgba(15,23,42,0.06);padding:18px 20px}
.history-card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;border-bottom:1px solid var(--border-soft);padding-bottom:10px}
.history-card-order-meta{display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--text-sub)}
.history-card-order-id{font-weight:600;color:var(--text-main)}
.history-card-date{font-size:12px;color:var(--text-sub)}
.history-card-total{font-size:14px;font-weight:600}
.history-card-items{list-style:none;margin:0;padding:12px 0 0;display:flex;flex-direction:column;gap:10px}
.history-item-row{display:grid;grid-template-columns:auto 1fr auto auto;gap:12px;align-items:center}
.history-thumb img{width:72px;height:72px;border-radius:18px;object-fit:cover;background:#f7f7fb}
.history-info{display:flex;flex-direction:column;gap:4px}
.history-name{font-size:14px;color:var(--text-main);text-decoration:none}
.history-name:hover{text-decoration:underline}
.history-meta{display:flex;flex-wrap:wrap;gap:4px}
.pill{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;background:var(--pill-bg);font-size:13px;color:var(--text-sub)}
.history-qty,.history-price{font-size:13px;text-align:right;color:var(--text-main)}
.history-card-footer{margin-top:12px;display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap}
.btn-outline{border-radius:999px;border:1px solid var(--border-soft);background:var(--card-bg);padding:7px 16px;font-size:13px;cursor:pointer;color:var(--text-main);text-decoration:none;display:inline-flex;align-items:center;gap:6px}
.btn-outline:hover{box-shadow:0 8px 18px rgba(15,23,42,0.08)}
.btn-ghost{border-radius:999px;border:none;background:transparent;padding:7px 14px;font-size:13px;cursor:pointer;color:var(--text-sub)}
.btn-ghost:hover{background:var(--pill-bg)}
.history-clear-all{font-size:12px}
.history-title{font-size:30px;line-height:1.25;margin:0;color:var(--text-main)}
.history-note{margin-top:10px;font-size:15px;line-height:1.7;color:var(--text-sub)}
.history-card-order-id{margin:4px 0 0;font-size:24px;font-weight:700;color:var(--text-main)}
.history-card-date{font-size:15px;line-height:1.7;color:var(--text-sub)}
.history-name{font-size:24px;font-weight:700;color:var(--text-main);text-decoration:none}
.history-name:hover{text-decoration:underline}
.history-empty,.history-meta,.history-qty,.history-price{font-size:15px;line-height:1.7;color:var(--text-sub)}
.cart-page{background:linear-gradient(to bottom,var(--page-bg) 0,var(--page-bg) 76%,var(--page-bg) 76%);min-height:100vh;padding:16px 0 96px}
.cart-shell{max-width:1320px;margin:0 auto;padding:0 24px}
.cart-header{margin-bottom:24px}
.cart-title{margin:0;font-size:30px;line-height:1.25;color:var(--text-main)}
.cart-note{margin-top:10px;font-size:15px;line-height:1.7;color:var(--text-sub)}
.cart-panel{background:var(--card-bg);border-radius:32px;border:1px solid var(--border-soft);box-shadow:var(--shadow-soft);padding:24px;margin-bottom:20px}
.cart-items{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:16px}
.cart-item-row{display:grid;grid-template-columns:auto 1fr auto auto auto;gap:12px;align-items:center}
.cart-thumb img{width:72px;height:72px;border-radius:18px;object-fit:cover;background:#f7f7fb}
.cart-info{display:flex;flex-direction:column;gap:4px}
.cart-name{font-size:24px;font-weight:700;color:var(--text-main);text-decoration:none}
.cart-name:hover{text-decoration:underline}
.cart-meta{display:flex;flex-wrap:wrap;gap:4px;font-size:15px;line-height:1.7;color:var(--text-sub)}
.cart-qty{display:flex;align-items:center;justify-content:flex-end;gap:6px}
.cart-qty input{width:72px;padding:6px 8px;border-radius:12px;border:1px solid var(--border-soft);text-align:center}
.cart-qty-step{width:28px;height:28px;border-radius:999px;border:1px solid var(--border-soft);background:var(--card-bg);font-size:16px;line-height:1;cursor:pointer;color:var(--color-primary)}
.cart-price,.cart-subtotal{text-align:right}
.cart-label{display:block;font-size:11px;color:var(--text-sub);margin-bottom:2px}
.cart-price-value{font-size:16px;font-weight:600;color:var(--text-main)}
.cart-subtotal-value{font-size:20px;font-weight:700;color:var(--text-main)}
.cart-subtotal-actions{margin-top:6px;display:flex;justify-content:flex-end;gap:6px}
.cart-subtotal .btn-outline{font-size:12px;padding:5px 12px}
.cart-empty{text-align:center;font-size:15px;color:var(--text-sub);padding:32px 24px;line-height:1.7}
.cart-total{font-size:22px;font-weight:700;text-align:right;margin-top:16px}
.cart-agreement{margin-top:16px;font-size:15px;line-height:1.7;color:var(--text-sub)}
.cart-agreement label{display:flex;align-items:flex-start;gap:8px}
.cart-agreement input{margin-top:4px}
.cart-agreement a{color:var(--accent);text-decoration:none}
.cart-agreement a:hover{text-decoration:underline}
.cart-actions{display:flex;justify-content:flex-start;margin-top:16px}
.cart-tooltip{margin-top:8px;font-size:13px;line-height:1.6;color:var(--text-sub);background:#fff;border:1px solid var(--border-soft);border-radius:999px;padding:6px 12px;max-width:360px;box-shadow:0 10px 24px rgba(15,23,42,0.12);opacity:0;transform:translateY(4px);transition:opacity .18s ease,transform .18s ease}
.cart-tooltip.is-visible{opacity:1;transform:translateY(0)}
.policy-page{background:var(--page-bg);min-height:100vh;padding:32px 0 96px}
.policy-shell{max-width:960px;margin:0 auto;padding:0 24px}
.policy-header{margin-bottom:24px}
.policy-title{font-size:30px;line-height:1.25;margin:0;color:var(--text-main)}
.policy-intro{margin-top:10px;font-size:15px;line-height:1.7;color:var(--text-sub)}
.policy-card{background:var(--card-bg);border-radius:32px;border:1px solid var(--border-soft);box-shadow:var(--shadow-soft);padding:24px 28px}
.policy-card h2{font-size:20px;margin:0 0 8px;color:var(--text-main)}
.policy-card p,.policy-card li{font-size:15px;line-height:1.7;color:var(--text-sub);margin:0 0 16px}
.policy-card ul{padding-left:20px;margin:0 0 16px}
.policy-date{font-size:15px;line-height:1.7;color:var(--text-sub);margin:8px 0 0}
.home-main{padding:24px 0 96px;background:linear-gradient(to bottom,var(--page-bg) 0,var(--page-bg) 70%,var(--page-bg) 70%)}
.home-hero.container{padding:32px 16px}
.home-hero-title{font-size:30px;line-height:1.25;margin:0 0 8px;color:var(--text-main)}
.home-hero-lead{font-size:15px;line-height:1.7;color:var(--text-sub);margin:0}
.home-products{max-width:1320px;margin:0 auto;padding:32px 24px}
.home-products-header{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.home-products-title{font-size:24px;margin:0;color:var(--text-main)}
.home-products-lead{font-size:15px;line-height:1.7;color:var(--text-sub);margin:0}
.home-products-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:20px}
.home-products-more{margin-top:24px;display:flex;justify-content:center}
/* =========================================================
   Product list / Tag list pages
   ====================================================== */
.product-list-body{background:linear-gradient(to bottom,var(--page-bg) 0,var(--page-bg) 76%,var(--page-bg) 76%);min-height:100vh}
.product-list-page{padding:32px 0 96px}
.product-list-shell{max-width:1320px;margin:0 auto;padding:0 24px}
.product-list-header{display:flex;justify-content:space-between;gap:32px;align-items:flex-start;margin-bottom:32px;flex-wrap:wrap}
.product-list-header-main{flex:1;min-width:280px}
.product-list-title{font-size:30px;line-height:1.25;margin:0;color:var(--text-main)}
.product-list-lead{margin-top:10px;font-size:15px;line-height:1.7;color:var(--text-sub)}
.product-list-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.tag-pill{display:inline-flex;align-items:center;justify-content:center;padding:4px 12px;border-radius:999px;font-size:13px;font-weight:600;letter-spacing:.02em;background:#ff4356;color:#fff;text-decoration:none;border:none;cursor:pointer;transition:background .16s ease,transform .12s ease}
.tag-pill:hover{background:#ff5b6b;color:#fff;transform:translateY(-1px)}
.product-list-pickup{max-width:320px;padding:20px;border-radius:24px;border:1px solid var(--border-soft);box-shadow:var(--shadow-soft);background:var(--card-bg)}
.product-list-pickup-title{margin:0 0 8px;font-size:18px;color:var(--text-main)}
.product-list-pickup-text{font-size:15px;line-height:1.7;color:var(--text-sub);margin:0}
.product-list-section{margin-top:16px}
.product-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px}
.product-card-grid>.product-card{height:100%}
.product-card{background:var(--card-bg);border-radius:24px;box-shadow:var(--shadow-soft);border:1px solid var(--border-soft);overflow:hidden;display:flex;flex-direction:column;transition:transform .16s ease,box-shadow .16s ease;position:relative}
.product-card:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(15,23,42,0.12)}
.product-card-link{text-decoration:none;color:inherit;display:flex;flex-direction:column;height:100%}
.product-card-thumb img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;background:#f7f7fb}
.product-card-body{padding:16px 20px 18px;display:flex;flex-direction:column;gap:6px;flex:1 1 auto}
.product-card-category{font-size:13px;color:var(--text-sub);margin:0}
.product-card-title{font-size:18px;line-height:1.4;margin:0;color:var(--text-main)}
.product-card-price{font-size:16px;font-weight:700;margin:4px 0 0;color:var(--text-main)}
.product-card-footer{margin-top:12px;display:flex;justify-content:flex-end;padding:0 20px 20px}
.favorite-remove-btn{font-size:12px;padding:6px 14px}

/* 商品カード：お気に入りバッジ */
.product-card-fav-indicator{position:absolute;top:16px;right:16px;z-index:3}
.product-card-fav-indicator-inner{width:40px;height:40px;border-radius:999px;background:var(--accent);display:flex;align-items:center;justify-content:center;box-shadow:0 12px 30px rgba(15,23,42,0.22)}
.product-card-fav-indicator-inner svg{width:20px;height:20px;display:block;color:#fff;stroke:currentColor}
.product-pagination{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:40px;flex-wrap:wrap}
.product-pagination-link{min-width:36px;height:36px;border-radius:999px;border:1px solid var(--border-soft);display:flex;align-items:center;justify-content:center;font-size:14px;text-decoration:none;color:var(--text-main);padding:0 12px}
.product-pagination-link.is-current{background:var(--accent);color:#fff;border-color:var(--accent)}
.product-pagination-link.is-disabled{opacity:.5;pointer-events:none}
@media (max-width:1024px){
  .history-shell,.cart-shell,.policy-shell,.product-list-shell{padding:0 16px}
  .history-card-header{flex-direction:column;align-items:flex-start}
  .history-item-row{grid-template-columns:auto 1fr;grid-template-rows:auto auto}
  .history-qty,.history-price{text-align:left}
  .history-header-title-row{align-items:flex-start}
  .cart-item-row{grid-template-columns:auto 1fr;grid-template-rows:auto auto auto}
  .cart-price,.cart-subtotal{text-align:left}
  .cart-panel,.policy-card{border-radius:24px;padding:20px}
  .product-list-layout{grid-template-columns:minmax(0,1fr)}
  .product-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .home-products-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:640px){
  .history-title,.cart-title,.policy-title{font-size:24px}
  .history-name,.cart-name{font-size:22px}
  .history-thumb img,.cart-thumb img{width:68px;height:68px;border-radius:18px}
  .history-card,.cart-panel,.policy-card{border-radius:24px}
  .history-card-header{gap:8px}
  .history-item-row,.cart-item-row{gap:10px}
  .product-list-title{font-size:24px}
  .product-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .product-card-title{font-size:16px}
  .product-card{border-radius:24px}
  .home-products-grid{grid-template-columns:1fr}
}
.site-header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;color:var(--color-primary)}
.site-logo{text-decoration:none;color:var(--color-primary);font-weight:700;font-size:1.05rem}
.site-nav{display:flex;gap:20px;flex:1}
.site-nav ul{display:flex;gap:20px;margin:0;padding:0;list-style:none;flex-wrap:wrap}
.site-nav a{text-decoration:none;color:var(--color-primary);font-weight:500;transition:color .15s ease}
.site-nav a:hover{color:var(--accent-hover)}
.site-nav a[aria-current="page"],.site-nav a.active,.site-nav a.is-current{color:var(--accent)}
.site-header-actions{display:flex;align-items:center;gap:12px}
.header-icon-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:999px;background:transparent;color:#302c4d;text-decoration:none;transition:background .16s ease,color .16s ease,transform .16s ease;cursor:pointer}
.header-icon-btn svg{display:block}
.header-icon-btn:hover{background:#302c4d;color:#fff;transform:translateY(-1px)}
.cart-count-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 4px;border-radius:999px;background:#ff4356;color:#fff;font-size:11px;font-weight:600;display:none;align-items:center;justify-content:center;box-shadow:0 0 0 2px var(--page-bg)}
.header-cart-btn{position:relative}
.floating-cart-btn{position:fixed;right:24px;bottom:24px;width:56px;height:56px;border-radius:999px;background:#302c4d;color:#fff;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;box-shadow:0 12px 30px rgba(0,0,0,.18);z-index:2000;transition:background .16s ease,transform .16s ease,box-shadow .16s ease;cursor:pointer}
.floating-cart-btn:hover{background:#423f59;transform:translateY(-3px);box-shadow:0 16px 40px rgba(0,0,0,.22)}
.mobile-menu-toggle{border:none;background:var(--card-bg);color:var(--color-primary);width:40px;height:40px;border-radius:999px;padding:8px;cursor:pointer;display:none;align-items:center;justify-content:center;transition:background .15s ease,transform .15s ease,box-shadow .15s ease}
.mobile-menu-toggle:hover,.mobile-menu-toggle.is-open{background:var(--accent);color:#fff}
.mobile-menu-toggle .icon-menu,.mobile-menu-toggle .icon-close{display:flex;align-items:center;justify-content:center}
.mobile-menu-toggle .icon-close{display:none}
.mobile-menu-toggle svg{width:24px;height:24px}
.mobile-menu-toggle.is-open .icon-menu{display:none}
.mobile-menu-toggle.is-open .icon-close{display:flex}
.mobile-menu-overlay{position:fixed;inset:0;background:rgba(15,23,42,.55);display:none;align-items:center;justify-content:center;z-index:1900}
.mobile-menu-overlay.is-open{display:flex}
.mobile-menu-panel{width:100%;max-width:360px;margin:16px;background:var(--card-bg);border-radius:32px;padding:24px 22px 28px;box-shadow:var(--shadow-soft)}
.mobile-menu-close{border:none;background:transparent;font-size:0;line-height:1;cursor:pointer;display:block;margin-left:auto}
.mobile-menu-close svg{width:24px;height:24px}
.mobile-menu-nav ul{list-style:none;margin:12px 0 0;padding:0;display:flex;flex-direction:column;gap:12px}
.mobile-menu-nav a{text-decoration:none;font-size:16px;line-height:1.6;color:var(--color-primary);padding:8px 10px;border-radius:999px;background:var(--pill-bg);display:block}
.mobile-menu-nav a[aria-current="page"],.mobile-menu-nav a.active,.mobile-menu-nav a.is-current{color:var(--accent)}
.mobile-menu-nav a:hover{background:#ececf7;color:var(--accent-hover)}
.no-scroll{overflow:hidden}
@media (max-width:768px){
  .site-nav{display:none}
  .header-desktop-only{display:none}
  .mobile-menu-toggle{display:inline-flex}
}

/* === Review List Page ========================================= */
.product-list-kicker{
  font-size:13px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--accent);
  margin:0 0 6px;
}
.product-list-controls{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-top:16px;
}
.form-label{
  font-size:13px;
  font-weight:600;
  color:var(--text-sub);
}
.form-select-pill{
  min-width:200px;
  padding:10px 16px;
  border-radius:999px;
  border:1px solid var(--border-soft);
  background:#f9fafb;
  font-size:14px;
  color:var(--text-main);
  appearance:none;
  outline:none;
}
.form-select-pill:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 1px rgba(255,91,106,.35);
}
.product-list-body.is-review .product-card{
  box-shadow:var(--shadow-soft);
  height:100%;
}
.product-list-body.is-review .product-card-thumb{
  position:relative;
}
.product-list-body.is-review .product-card-thumb img{
  aspect-ratio:1/1;
  object-fit:cover;
}
.product-list-body.is-review .product-card-body{
  padding:16px 20px;
  display:flex;
  flex-direction:column;
  gap:10px;
  flex:1 1 auto;
}
.product-list-body.is-review .product-card-link{
  display:flex;
  flex-direction:column;
  height:100%;
}
.product-list-body.is-review .product-card-title{
  font-size:18px;
  line-height:1.45;
  margin:0;
}
.product-list-body.is-review .product-card-category{
  font-size:13px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--text-sub);
  margin:0;
}
.review-like-badge{
  position:absolute;
  top:12px;
  right:12px;
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:4px 12px;
  border-radius:999px;
  background:rgba(255,91,106,.92);
  color:#fff;
  font-size:13px;
  letter-spacing:.03em;
}
.review-like-badge svg{
  width:16px;
  height:16px;
  fill:currentColor;
}
.review-card-variant,
.review-card-author,
.review-card-text{
  margin:0;
  font-size:15px;
  line-height:1.6;
  color:var(--text-main);
}
.review-card-author{
  display:flex;
  justify-content:space-between;
  gap:12px;
  font-size:14px;
  color:var(--text-sub);
  align-items:center;
}
.review-card-user{
  display:inline-flex;
  align-items:center;
  gap:6px;
}
.review-card-user svg{
  width:16px;
  height:16px;
}
.review-card-user svg path,
.review-card-user svg circle{
  stroke:currentColor;
  fill:none;
}
.review-card-date{
  font-size:13px;
  color:var(--text-sub);
}
.review-card-text{
  position:relative;
  margin-bottom:4px;
  max-height:96px;
  overflow:hidden;
}
.review-card-text::after{
  content:'…';
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:36px;
  background:linear-gradient(to bottom,rgba(255,255,255,0),var(--card-bg));
  display:flex;
  justify-content:flex-end;
  align-items:flex-end;
  padding-right:4px;
  color:var(--text-sub);
  pointer-events:none;
}
.review-card-readmore{
  font-size:13px;
  color:var(--accent);
  cursor:pointer;
  text-decoration:none;
  background:none;
  border:none;
  padding:0;
}
.review-card-readmore:hover{
  text-decoration:underline;
}
.review-card-text.is-expanded{
  max-height:none;
}
.review-card-text.is-expanded::after{
  opacity:0;
}
.review-card-footer{
  margin-top:auto;
  padding:0 20px 20px;
  display:flex;
  justify-content:flex-end;
}
.review-card-btn{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding-inline:20px;
  color:#fff;
}
.review-card-btn svg{
  width:16px;
  height:16px;
}
.review-card-btn svg path{
  stroke:currentColor;
  fill:none;
}

/* === Review List Page — レビュー専用拡張 ===================== */

/* 見出し周りの余白調整（商品一覧ヘッダとトーンを揃える） */
.review-header {
  padding: 0;
  margin-bottom: 28px;
}

/* サムネイル右上の ♡ x 数 バッジ */
.review-card-fav {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 3;
}
.review-card-fav-inner {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 12px;
  border-radius: 999px;
  background: rgba(255,91,106,.9);
  color: #fff;
  font-size: 13px;
  letter-spacing: .03em;
}
.review-card-fav-inner svg path {
  fill: currentColor;  /* バッジの文字色（#fff）をそのまま使う */
  stroke: none;
}

/* レビュワー名の前に丸アイコン */
.review-user-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: 999px;
  background: var(--pill-bg);
}
.review-user-icon svg {
  width: 16px;
  height: 16px;
}
.review-user-icon svg path,
.review-user-icon svg circle {
  stroke: currentColor;
  fill: none;
}

/* 「商品ページへ」ボタンのTシャツアイコン */
.review-card-btn-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.review-card-btn-icon svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  fill: none;
}

/* 長文レビューの3行制限＋グラデーション */
.review-text {
  margin: 0 0 4px;
  font-size: 15px;
  line-height: 1.6;
  color: var(--text-main);
  max-height: 5em;          /* おおよそ3行分 */
  overflow: hidden;
  position: relative;
}
.review-text::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 2em;
  background: linear-gradient(
    to bottom,
    rgba(255,255,255,0),
    var(--card-bg)
  );
}
.review-text.is-expanded {
  max-height: none;
}
.review-text.is-expanded::after {
  opacity: 0;
}

/* 「全文を読む」ボタン */
.review-readmore {
  font-size: 13px;
  color: var(--accent);
  cursor: pointer;
  text-decoration: none;
  background: none;
  border: none;
  padding: 0;
}
.review-readmore:hover {
  text-decoration: underline;
}

/* カード下部にボタンを固定（保険） */
.review-card-footer {
  margin-top: auto;
  padding: 0 20px 18px;
  display: flex;
  justify-content: center;
}
.review-card-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding-inline: 20px;
  color: #fff;
}

/* レビュー一覧はスマホだけ1列表示にする */
@media (max-width:640px){
  .is-review .product-card-grid{
    grid-template-columns:1fr;   /* レビューだけ 1 カラム */
  }

  /* カードを少し中央寄せに（お好みで） */
  .is-review .product-card{
    max-width:480px;
    margin:0 auto;
  }
}

