/* ─── MIRAI HEADER + DRAWER + SEARCH ─── */

/* Hide Storefront defaults */
.storefront-handheld-footer-bar, .site-search, .secondary-navigation, .main-navigation { display:none !important; }
.site-header { display:none !important; }

/* Announcement bar (rotating) */
.mh-announce { background:#111; color:#fff; padding:10px; text-align:center; font-size:14px; letter-spacing:.04em; font-family:"Noto Sans JP","Poppins",system-ui,sans-serif; }
.mh-announce__inner { max-width:1400px; margin:0 auto; position:relative; height:1.5em; overflow:hidden; }
.mh-announce__item { position:absolute; left:0; right:0; top:0; opacity:0; transform:translateY(8px); transition:opacity .4s ease, transform .4s ease; pointer-events:none; }
.mh-announce__item.is-active { opacity:1; transform:translateY(0); pointer-events:auto; }

/* Header */
.mh-header { background:#fff; border-bottom:1px solid #eee; padding:18px 10px; position:sticky; top:0; z-index:50; }
.mh-header__inner { max-width:1400px; margin:0 auto; display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:16px; }

.mh-menu-btn { background:none; border:none; padding:8px; cursor:pointer; color:#111; justify-self:start; display:inline-flex; align-items:center; }
.mh-menu-btn:hover { color:#D42B2B; }
.mh-menu-btn svg { display:block; }

.mh-logo { justify-self:center; }
.mh-logo a { display:block; text-decoration:none; }
.mh-logo img { height:46px; width:auto; display:block; }

.mh-icons { justify-self:end; display:flex; align-items:center; gap:14px; }
.mh-icon { background:none; border:none; padding:6px; color:#111; cursor:pointer; text-decoration:none; display:inline-flex; align-items:center; position:relative; }
.mh-icon:hover { color:#D42B2B; }
.mh-icon svg { display:block; }
.mh-cart-count { position:absolute; top:-2px; right:-4px; background:#D42B2B; color:#fff; font-size:10px; font-weight:700; min-width:16px; height:16px; border-radius:8px; display:inline-flex; align-items:center; justify-content:center; padding:0 4px; }

/* Drawer (slide-in menu) */
.mh-drawer-backdrop { position:fixed; inset:0; background:rgba(0,0,0,.5); opacity:0; pointer-events:none; transition:opacity .2s; z-index:998; }
.mh-drawer-backdrop.is-open { opacity:1; pointer-events:auto; }
.mh-drawer { position:fixed; top:0; left:0; width:300px; max-width:85vw; height:100%; background:#fff; transform:translateX(-100%); transition:transform .25s ease; z-index:999; display:flex; flex-direction:column; }
.mh-drawer.is-open { transform:translateX(0); }
.mh-drawer__head { display:flex; justify-content:space-between; align-items:center; padding:16px 20px; border-bottom:1px solid #eee; font-weight:700; }
.mh-drawer__close { background:none; border:none; font-size:24px; cursor:pointer; color:#555; line-height:1; padding:0; width:28px; height:28px; }
.mh-drawer__nav { padding:8px 0; overflow-y:auto; }
.mh-drawer__list { list-style:none; padding:0; margin:0; }
.mh-drawer__list li { border-bottom:1px solid #f5f5f5; }
.mh-drawer__list a { display:block; padding:16px 20px; color:#111; text-decoration:none; font-weight:500; }
.mh-drawer__list a:hover { background:#f5f5f7; color:#D42B2B; }

/* Search overlay */
.mh-search { position:fixed; inset:0; background:rgba(255,255,255,.97); opacity:0; pointer-events:none; transition:opacity .2s; z-index:999; display:flex; align-items:flex-start; padding-top:100px; justify-content:center; }
.mh-search.is-open { opacity:1; pointer-events:auto; }
.mh-search__inner { width:100%; max-width:600px; padding:0 20px; position:relative; }
.mh-search form { display:flex; align-items:center; border-bottom:2px solid #111; padding:10px 0; }
.mh-search input { flex:1; border:none; outline:none; font-size:18px; background:transparent; font-family:"Noto Sans JP", "Poppins", sans-serif; color:#111; }
.mh-search button[type=submit] { background:none; border:none; padding:0; color:#111; cursor:pointer; }
.mh-search__close { position:fixed; top:20px; right:20px; background:none; border:none; font-size:30px; color:#111; cursor:pointer; line-height:1; }

@media (max-width:640px) {
  .mh-header { padding:14px 10px; }
  .mh-logo img { height:36px; }
  .mh-icons { gap:8px; }
  .mh-announce { font-size:12px; padding:8px 10px; }
}

/* ─── CART DRAWER (slide-in from right) ─── */
.mc-cart-backdrop { position:fixed; inset:0; background:rgba(0,0,0,.5); opacity:0; pointer-events:none; transition:opacity .25s; z-index:9998; }
.mc-cart-backdrop.is-open { opacity:1; pointer-events:auto; }
.mc-cart-drawer { position:fixed; top:0; right:0; width:420px; max-width:100vw; height:100%; background:#fff; transform:translateX(100%); transition:transform .3s ease; z-index:9999; display:flex; flex-direction:column; font-family:"Noto Sans JP","Poppins",system-ui,sans-serif; box-shadow:-4px 0 20px rgba(0,0,0,.1); }
.mc-cart-drawer.is-open { transform:translateX(0); }

.mc-cart__head { display:flex; justify-content:space-between; align-items:center; padding:16px 18px; border-bottom:1px solid #eee; flex-shrink:0; }
.mc-cart__title { font-size:18px; font-weight:800; margin:0; color:#111; }
.mc-cart__close { background:none; border:none; font-size:26px; line-height:1; color:#111; cursor:pointer; padding:4px 8px; }

.mc-cart__shipping { padding:16px 18px 14px; border-bottom:1px solid #f3f3f3; }
.mc-cart__shipping-wrap {
  position:relative;
  height:30px;
  padding-right:36px;
}
.mc-cart__shipping-bar {
  position:absolute;
  left:0;
  right:36px;
  top:50%;
  transform:translateY(-50%);
  height:8px;
  border-radius:4px;
  border:1px solid #D42B2B;
  overflow:hidden;
  background-image:repeating-linear-gradient(-45deg,#D42B2B 0 6px,#fff 6px 12px);
  background-size:17px 17px;
  animation:mc-stripes 0.6s linear infinite;
}
.mc-cart__shipping-icon {
  position:absolute;
  right:0;
  top:50%;
  transform:translateY(-50%);
  width:30px;
  height:30px;
  background:#D42B2B;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
}
.mc-cart__shipping-icon svg { width:16px; height:16px; display:block; }
.mc-cart__shipping-text { text-align:center; font-size:13px; color:#333; margin:10px 0 0; font-weight:600; line-height:1.4; }
.mc-cart__shipping-text strong { color:#D42B2B; font-weight:800; }

@keyframes mc-stripes {
  from { background-position: 0 0; }
  to   { background-position: 17px 0; }
}

.mc-cart__items { flex:1; overflow-y:auto; padding:0; -webkit-overflow-scrolling:touch; }
.mc-cart__empty { text-align:center; padding:40px 20px; color:#888; font-size:14px; }

.mc-citem { display:grid; grid-template-columns:80px 1fr auto; gap:12px; padding:16px 18px; border-bottom:1px solid #f3f3f3; align-items:flex-start; }
.mc-citem__thumb { width:80px; height:80px; object-fit:cover; border-radius:6px; background:#f5f5f7; }
.mc-citem__body { min-width:0; }
.mc-citem__title { font-size:13px; font-weight:700; color:#111; line-height:1.4; margin:0 0 6px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.mc-citem__price { font-size:13px; margin-bottom:4px; }
.mc-citem__price strong { color:#D42B2B; font-weight:700; }
.mc-citem__strike { color:#999; text-decoration:line-through; font-size:11px; margin-right:4px; }
.mc-citem__var { font-size:12px; color:#555; margin:0 0 6px; }
.mc-citem__qty { display:inline-flex; align-items:center; border:1px solid #ddd; border-radius:6px; overflow:hidden; }
.mc-citem__qty button { background:#fff; border:none; width:28px; height:28px; cursor:pointer; font-size:16px; color:#111; padding:0; }
.mc-citem__qty button:hover { background:#f5f5f5; }
.mc-citem__qty span { padding:0 10px; font-weight:700; font-size:14px; min-width:30px; text-align:center; }
.mc-citem__right { text-align:right; display:flex; flex-direction:column; align-items:flex-end; gap:2px; }
.mc-citem__remove { background:none; border:none; cursor:pointer; font-size:16px; color:#999; padding:0 0 8px; }
.mc-citem__remove:hover { color:#D42B2B; }
.mc-citem__line-strike { color:#999; text-decoration:line-through; font-size:12px; }
.mc-citem__line-total { color:#D42B2B; font-weight:800; font-size:15px; }
.mc-citem__saved { color:#D42B2B; font-size:11px; font-weight:600; margin-top:2px; }

.mc-cart__foot { border-top:1px solid #eee; padding:14px 18px calc(20px + env(safe-area-inset-bottom,0px)); flex-shrink:0; background:#fff; }
.mc-cart__trust { display:grid; grid-template-columns:1fr 1fr 1fr; gap:8px; padding:10px 0 16px; border-bottom:1px solid #f3f3f3; margin-bottom:16px; }
.mc-cart__trust-col { text-align:center; font-size:14px; line-height:1.55; color:#222; font-weight:600; }
.mc-cart__trust-col span { display:block; font-size:28px; margin-bottom:8px; line-height:1; }
.mc-cart__checkout { display:flex; align-items:center; justify-content:center; gap:6px; background:#D42B2B; color:#fff; text-decoration:none; padding:16px; border-radius:6px; font-weight:800; font-size:15px; transition:background .15s; }
.mc-cart__checkout:hover { background:#b21f1f; color:#fff; }
.mc-cart__pay { display:flex; flex-wrap:wrap; justify-content:center; align-items:center; gap:6px; margin-top:16px; padding-bottom:4px; }
.mc-cart__pay img { width:38px !important; height:24px !important; display:block; flex-shrink:0; object-fit:contain; max-width:38px !important; max-height:24px !important; }
.mc-cart__pay svg { width:38px; height:24px; display:block; flex-shrink:0; }

@media (max-width:640px) {
  .mc-cart-drawer { width:100vw; }
  .mc-citem { grid-template-columns:64px 1fr auto; gap:10px; padding:14px 12px; }
  .mc-citem__thumb { width:64px; height:64px; }
}
