@import url("https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,600;700&family=Manrope:wght@400;500;600;700;800&display=swap");

:root{
  --bg:#fff8f6;
  --bg-soft:#fff2ef;
  --surface:rgba(255,255,255,.82);
  --surface-strong:#ffffff;
  --surface-tint:#fff3f1;
  --surface-deep:#ffe7e4;
  --text:#2e1f25;
  --muted:#71535d;
  --line:rgba(99,47,61,.12);
  --line-strong:rgba(99,47,61,.18);
  --brand:#d44b5f;
  --brand-dark:#9f273b;
  --accent:#f6b8c6;
  --accent-2:#ffd8c6;
  --accent-3:#f7e5a9;
  --success:#4f8b72;
  --shadow-lg:0 28px 80px rgba(77,27,42,.12);
  --shadow-md:0 18px 42px rgba(77,27,42,.10);
  --shadow-sm:0 10px 24px rgba(77,27,42,.08);
  --radius-xl:34px;
  --radius-lg:24px;
  --radius-md:18px;
  --radius-sm:14px;
  --max:1180px;
  --focus:0 0 0 4px rgba(244,170,187,.34);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Manrope", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color:var(--text);
  line-height:1.5;
  background:
    radial-gradient(900px 560px at 8% -6%, rgba(255,202,213,.7), transparent 60%),
    radial-gradient(780px 500px at 88% 8%, rgba(255,222,196,.75), transparent 58%),
    radial-gradient(620px 400px at 50% 26%, rgba(247,229,169,.25), transparent 62%),
    linear-gradient(180deg, #fffdfc 0%, var(--bg) 42%, var(--bg-soft) 100%);
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
main{position:relative;z-index:1}
.container{max-width:var(--max);margin:0 auto;padding:0 22px}
.sr{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip{position:absolute;left:-9999px;top:12px;background:#fff;padding:10px 14px;border-radius:12px;border:1px solid var(--line);z-index:30}
.skip:focus{left:12px;box-shadow:var(--focus);outline:none}

body::before,
body::after{
  content:"";
  position:fixed;
  inset:auto auto 12% -8%;
  width:300px;
  height:300px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(245,173,188,.26), transparent 70%);
  filter:blur(18px);
  pointer-events:none;
  z-index:0;
}
body::after{
  inset:6% -8% auto auto;
  width:360px;
  height:360px;
  background:radial-gradient(circle, rgba(255,214,198,.25), transparent 70%);
}

.announce{
  position:relative;
  z-index:5;
  border-bottom:1px solid rgba(255,255,255,.5);
  background:linear-gradient(90deg, rgba(255,255,255,.58), rgba(255,241,239,.78));
  backdrop-filter: blur(18px);
}
.announce .inner{
  display:flex;
  gap:16px;
  justify-content:space-between;
  align-items:center;
  padding:12px 0;
  color:var(--muted);
  font-size:14px;
  font-weight:700;
}
.announce .pill{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(212,75,95,.14);
  background:rgba(255,255,255,.72);
  color:var(--brand-dark);
}
.announce-right{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}
.announce-link{color:var(--brand-dark)}

.site-header{
  position:sticky;
  top:0;
  z-index:20;
  backdrop-filter: blur(18px);
  background:linear-gradient(180deg, rgba(255,252,251,.88), rgba(255,252,251,.76));
  border-bottom:1px solid rgba(255,255,255,.7);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:22px;
  padding:16px 0;
}
.brand{
  display:flex;
  align-items:center;
  gap:14px;
  min-width:0;
}
.brand img{width:54px;height:54px;flex:none}
.brand-copy{min-width:0}
.brand .name{
  font-family:"Fraunces", Georgia, serif;
  font-size:1.15rem;
  font-weight:700;
  letter-spacing:-0.02em;
}
.brand .tag{
  color:var(--muted);
  font-size:.83rem;
  font-weight:700;
}
.nav{
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px;
  border-radius:999px;
  background:rgba(255,255,255,.68);
  border:1px solid rgba(255,255,255,.78);
  box-shadow: var(--shadow-sm);
}
.nav a,
.mobile-nav a{
  position:relative;
  padding:10px 14px;
  border-radius:999px;
  color:var(--muted);
  font-size:.95rem;
  font-weight:700;
  transition:background-color .2s ease, color .2s ease, transform .2s ease;
}
.nav a:hover,
.nav a[aria-current="page"],
.mobile-nav a[aria-current="page"]{
  background:linear-gradient(180deg, rgba(255,255,255,.95), rgba(255,243,241,.95));
  color:var(--text);
}
.header-actions{display:flex;align-items:center;gap:12px;margin-left:auto}
.header-cta,
.cart-link,
.btn,
.btn-inline{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  border-radius:999px;
  font-weight:800;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background-color .18s ease;
}
.header-cta,
.btn{
  padding:14px 20px;
  border:1px solid transparent;
  color:#fff;
  background:linear-gradient(135deg, var(--brand) 0%, #e56f78 100%);
  box-shadow:0 16px 34px rgba(212,75,95,.23);
}
.header-cta:hover,
.btn:hover{transform:translateY(-1px);box-shadow:0 20px 40px rgba(212,75,95,.28)}
.btn.secondary,
.header-cta.secondary{
  color:var(--text);
  background:rgba(255,255,255,.84);
  border-color:var(--line);
  box-shadow:none;
}
.btn.ghost{
  color:var(--brand-dark);
  background:rgba(255,255,255,.54);
  border-color:rgba(212,75,95,.18);
  box-shadow:none;
}
.btn.small{padding:11px 15px;font-size:.92rem}
.icon-btn,
.cart-link{
  min-height:48px;
  border:1px solid rgba(255,255,255,.85);
  background:rgba(255,255,255,.76);
  box-shadow:var(--shadow-sm);
}
.cart-link{padding:0 16px;color:var(--text)}
.icon-btn{
  width:48px;
  border-radius:16px;
  display:none;
  align-items:center;
  justify-content:center;
  color:var(--text);
}
.cart-count{
  display:inline-grid;
  place-items:center;
  min-width:24px;
  height:24px;
  padding:0 6px;
  border-radius:999px;
  background:rgba(212,75,95,.12);
  color:var(--brand-dark);
  font-size:.82rem;
}
.mobile-nav{display:none;padding-bottom:16px}
.mobile-nav .inner{
  display:grid;
  gap:10px;
  padding:14px;
  border-radius:26px;
  background:rgba(255,255,255,.88);
  border:1px solid rgba(255,255,255,.9);
  box-shadow:var(--shadow-md);
}
.mobile-nav[data-open="true"]{display:block}
.site-header-storefront{
  background:linear-gradient(180deg, rgba(255,252,251,.96), rgba(255,249,247,.92));
  border-bottom:1px solid rgba(212,75,95,.12);
}
.site-header-storefront .header-inner{
  gap:18px;
  padding:14px 0 12px;
}
.site-header-storefront .brand{
  gap:12px;
}
.site-header-storefront .brand .name{
  font-size:1.02rem;
}
.site-header-storefront .brand .tag{
  display:none;
}
.site-header-storefront .nav{
  flex:1;
  justify-content:center;
  gap:6px;
  padding:6px;
  border-radius:22px;
  background:rgba(255,255,255,.9);
  border:1px solid rgba(212,75,95,.12);
  box-shadow:none;
}
.site-header-storefront .nav a{
  flex:1;
  text-align:center;
  padding:12px 14px;
  border-radius:16px;
  color:rgba(47,42,48,.72);
  font-size:.92rem;
  letter-spacing:.01em;
}
.site-header-storefront .nav a:hover,
.site-header-storefront .nav a[aria-current="page"]{
  background:rgba(212,75,95,.09);
  color:var(--brand-dark);
}
.store-rail{
  display:flex;
  align-items:center;
  gap:10px;
  padding:0 0 14px;
}
.store-rail-label{
  font-size:.76rem;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--muted);
}
.store-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(212,75,95,.12);
  background:rgba(255,255,255,.82);
  color:var(--text);
  font-size:.88rem;
  font-weight:800;
  box-shadow:var(--shadow-sm);
  transition:transform .18s ease, border-color .18s ease, background-color .18s ease;
}
.store-chip:hover{
  transform:translateY(-1px);
  border-color:rgba(212,75,95,.22);
  background:rgba(255,255,255,.96);
}
.store-chip-featured{
  color:var(--brand-dark);
  background:rgba(212,75,95,.12);
  border-color:rgba(212,75,95,.18);
}
.mobile-shop-links{
  display:none;
}

.section{
  padding:34px 0;
}
.section.alt{padding-top:0}
.section-shell,
.page-hero,
.panel,
.collection-card,
.product-card,
.feature-card,
.bento-card,
.info-card,
.contact-card,
.faq-card,
.notice-card,
.cart-summary,
.empty-card,
.detail-card{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.9);
  background:linear-gradient(180deg, rgba(255,255,255,.88), rgba(255,247,244,.88));
  box-shadow:var(--shadow-md);
}
.section-shell,
.page-hero{border-radius:var(--radius-xl)}
.panel,
.collection-card,
.product-card,
.feature-card,
.bento-card,
.info-card,
.contact-card,
.faq-card,
.notice-card,
.cart-summary,
.empty-card,
.detail-card{border-radius:var(--radius-lg)}
.section-shell::before,
.page-hero::before,
.panel::before,
.collection-card::before,
.product-card::before,
.feature-card::before,
.bento-card::before,
.info-card::before,
.contact-card::before,
.faq-card::before,
.notice-card::before,
.cart-summary::before,
.empty-card::before,
.detail-card::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.95), transparent);
}

.hero{
  padding:34px 0 18px;
}
.hero-shell{padding:34px}
.hero-grid{
  display:grid;
  gap:26px;
  grid-template-columns:minmax(0,1.06fr) minmax(320px,.94fr);
  align-items:center;
}
.eyebrow,
.mini-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:9px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.9);
  border:1px solid rgba(212,75,95,.14);
  color:var(--brand-dark);
  font-size:.85rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.dot,
.spark{
  width:10px;
  height:10px;
  border-radius:999px;
  background:linear-gradient(135deg, var(--brand), #f4a5bc);
  box-shadow:0 0 0 8px rgba(244,165,188,.16);
}
.hero-copy{max-width:640px}
.h1,
.h2,
.h3,
.display,
.page-hero h1{
  font-family:"Fraunces", Georgia, serif;
  letter-spacing:-0.04em;
  line-height:1.02;
  margin:0;
}
.h1,.display{font-size:clamp(3rem, 5.2vw, 5rem)}
.h2,.page-hero h1{font-size:clamp(2rem, 3.5vw, 3rem)}
.h3{font-size:1.35rem}
.lead,
.page-hero p{font-size:1.09rem;color:var(--muted);max-width:62ch;margin:18px 0 0}
.cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px}
.hero-metrics,
.kpis,
.inline-list,
.meta-list,
.badge-row{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  list-style:none;
  padding:0;
  margin:0;
}
.hero-metrics{margin-top:24px}
.hero-metrics li,
.kpis li,
.inline-list li,
.meta-list li{
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border-radius:18px;
  background:rgba(255,255,255,.78);
  border:1px solid rgba(255,255,255,.9);
  color:var(--text);
  font-weight:700;
}
.hero-metrics strong{font-size:1.18rem;color:var(--brand-dark)}
.kpis{margin-top:18px}
.kpis li::before,
.bullets li::before,
.check-list li::before{
  content:"";
  width:9px;
  height:9px;
  border-radius:999px;
  background:linear-gradient(135deg, var(--brand), var(--accent));
  flex:none;
}
.hero-visual{
  display:grid;
  gap:16px;
}
.hero-stage{
  position:relative;
  min-height:560px;
  padding:24px;
  border-radius:32px;
  background:
    radial-gradient(circle at 22% 20%, rgba(255,255,255,.95), transparent 24%),
    linear-gradient(160deg, #fff6f3 0%, #ffeceb 44%, #ffe3de 100%);
  border:1px solid rgba(255,255,255,.94);
  box-shadow:var(--shadow-lg);
  overflow:hidden;
}
.hero-stage::before,
.hero-stage::after{
  content:"";
  position:absolute;
  border-radius:50%;
  filter:blur(10px);
}
.hero-stage::before{width:180px;height:180px;background:rgba(255,214,198,.54);right:-30px;top:-20px}
.hero-stage::after{width:220px;height:220px;background:rgba(244,165,188,.35);left:-48px;bottom:-80px}
.hero-card-large{
  position:absolute;
  inset:44px 40px 110px 52px;
  border-radius:30px;
  padding:18px;
  background:rgba(255,255,255,.82);
  border:1px solid rgba(255,255,255,.95);
  box-shadow:var(--shadow-md);
}
.hero-card-large img{width:100%;height:100%;object-fit:cover;border-radius:22px}
.floating-pill,
.floating-note,
.stage-badge,
.mini-stat{
  position:absolute;
  z-index:2;
  padding:12px 15px;
  border-radius:18px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(255,255,255,.95);
  box-shadow:var(--shadow-sm);
}
.floating-pill{top:26px;right:24px;font-weight:800;color:var(--brand-dark)}
.floating-note{left:24px;bottom:28px;max-width:220px;font-size:.92rem;color:var(--muted);font-weight:700}
.stage-badge{right:26px;bottom:40px;font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;font-weight:800;color:var(--brand-dark)}
.mini-stat{left:22px;top:26px;min-width:140px}
.mini-stat strong{display:block;font-size:1.2rem;color:var(--brand-dark)}
.hero-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.feature-card,.detail-card,.info-card,.contact-card,.bento-card,.notice-card,.panel{padding:24px}
.feature-card .icon,
.info-card .icon,
.contact-card .icon,
.bento-card .icon{
  display:grid;
  place-items:center;
  width:52px;
  height:52px;
  margin-bottom:16px;
  border-radius:18px;
  background:linear-gradient(135deg, rgba(244,165,188,.18), rgba(255,214,198,.55));
  color:var(--brand-dark);
}
.muted{color:var(--muted)}
.section-head{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-end;
  margin-bottom:18px;
}
.section-copy p{margin:10px 0 0;color:var(--muted);max-width:62ch}
.grid{display:grid;gap:18px}
.products{grid-template-columns:repeat(3,minmax(0,1fr))}
.collections{grid-template-columns:repeat(3,minmax(0,1fr))}
.product-card,
.collection-card{display:flex;flex-direction:column;height:100%}
.product-link,.collection-card{height:100%}
.product-media,
.collection-media{
  position:relative;
  isolation:isolate;
  padding:18px;
  aspect-ratio:1/1;
}
.collection-media{aspect-ratio:1.25/1;padding:16px}
.product-media::after,
.collection-media::after{
  content:"";
  position:absolute;
  inset:18px;
  border-radius:24px;
  background:linear-gradient(180deg, rgba(255,255,255,.4), rgba(255,255,255,0));
  pointer-events:none;
}
.product-media img,
.collection-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:24px;
  background:#fff;
}
.badge,
.collection-chip,
.tag-pill,
.filter-pill,
.policy-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border-radius:999px;
  font-size:.78rem;
  font-weight:800;
}
.badge{
  position:absolute;
  top:24px;
  left:24px;
  z-index:2;
  padding:8px 12px;
  color:var(--brand-dark);
  background:rgba(255,255,255,.92);
  border:1px solid rgba(255,255,255,.94);
}
.collection-body,
.product-body{padding:0 20px 20px}
.collection-card .arrow{margin-left:auto;color:var(--brand-dark);font-weight:800}
.collection-title,
.product-title{font-size:1.14rem;font-weight:800;letter-spacing:-0.02em}
.collection-desc,
.product-short{margin-top:8px;color:var(--muted);font-size:.96rem}
.product-top{display:flex;align-items:flex-start;gap:14px;justify-content:space-between}
.product-price{font-weight:900;color:var(--brand-dark);white-space:nowrap}
.product-meta{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:14px;
}
.tag-pill{
  padding:7px 11px;
  background:rgba(255,255,255,.8);
  border:1px solid var(--line);
  color:var(--muted);
}
.product-actions{display:flex;gap:10px;padding:0 20px 20px;margin-top:auto}
.product-actions .btn{flex:1}
.shop-layout{display:grid;gap:18px}
.shop-controls{
  display:grid;
  gap:14px;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:end;
}
.filters{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.filter-pill{
  padding:11px 14px;
  background:rgba(255,255,255,.72);
  border:1px solid var(--line);
  color:var(--muted);
}
.filter-pill.active{background:linear-gradient(180deg, rgba(255,255,255,.95), rgba(255,240,237,.95));color:var(--text);border-color:rgba(212,75,95,.18)}
.search{
  display:flex;
  align-items:center;
  gap:12px;
  min-height:54px;
  padding:0 16px;
  border-radius:18px;
  background:rgba(255,255,255,.78);
  border:1px solid var(--line);
}
.search input,
.field input,
.field select,
textarea{
  width:100%;
  border:0;
  outline:none;
  background:transparent;
  color:var(--text);
}
.field{display:grid;gap:8px}
.field span{font-size:.92rem;font-weight:800;color:var(--muted)}
.field select,
.field input,
textarea{
  min-height:52px;
  padding:0 14px;
  border-radius:16px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.78);
}
textarea{padding:14px;min-height:150px;resize:vertical}

.page-hero{padding:30px}
.page-hero.compact{padding:26px}
.page-hero-grid{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:end}
.page-hero-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-end}
.policy-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px}
.policy-chip{
  padding:10px 13px;
  border:1px solid rgba(212,75,95,.14);
  background:rgba(255,255,255,.75);
  color:var(--muted);
}

.split{display:grid;gap:18px;grid-template-columns:minmax(0,1.1fr) minmax(280px,.9fr)}
.bento-grid{display:grid;gap:18px;grid-template-columns:repeat(3,minmax(0,1fr))}
.story-grid{display:grid;gap:18px;grid-template-columns:1.15fr .85fr}
.mosaic{display:grid;gap:18px;grid-template-columns:repeat(2,minmax(0,1fr))}
.check-list,.bullets{list-style:none;padding:0;margin:18px 0 0;display:grid;gap:12px}
.check-list li,.bullets li{display:flex;align-items:flex-start;gap:12px;color:var(--text)}
.process-list{display:grid;gap:14px}
.process-item{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:flex-start;padding:14px 0;border-top:1px solid var(--line)}
.process-item:first-child{border-top:0;padding-top:0}
.step-number{
  width:34px;height:34px;border-radius:999px;display:grid;place-items:center;
  background:linear-gradient(135deg, rgba(212,75,95,.18), rgba(255,214,198,.6));color:var(--brand-dark);font-weight:900
}

.product-page{
  display:grid;
  gap:22px;
  grid-template-columns:minmax(0,1fr) minmax(360px,.94fr);
}
.pp-media-wrap{display:grid;gap:14px}
.pp-media{
  position:relative;
  min-height:540px;
  padding:20px;
  border-radius:32px;
  background:linear-gradient(180deg, #fffaf8, #fff0ed);
  border:1px solid rgba(255,255,255,.95);
  box-shadow:var(--shadow-lg);
}
.pp-media img{width:100%;height:100%;object-fit:cover;border-radius:24px}
.pp-info{display:grid;gap:18px}
.pp-head{padding:26px;border-radius:30px;background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,246,243,.9));border:1px solid rgba(255,255,255,.95);box-shadow:var(--shadow-md)}
.pp-head .price{margin-top:16px;font-size:1.9rem;font-weight:900;color:var(--brand-dark)}
.pp-actions,
.pp-sections{display:grid;gap:16px}
.pp-actions .panel,
.pp-sections .panel{padding:22px}
.variant-grid{display:grid;gap:14px}
.qty-row{display:grid;grid-template-columns:120px 1fr 1fr;gap:12px;align-items:end}
.field.inline{display:flex;align-items:center;gap:8px}
.field.inline input{max-width:92px}
.breadcrumbs{display:flex;gap:10px;flex-wrap:wrap;color:var(--muted);font-size:.92rem;font-weight:700;margin-bottom:14px}
.breadcrumbs span{opacity:.56}
.cart{
  display:grid;
  gap:18px;
  grid-template-columns:minmax(0,1fr) 320px;
}
.cart-list{
  display:grid;
  gap:14px;
}
.cart-row{
  display:grid;
  grid-template-columns:110px minmax(0,1fr) auto;
  gap:16px;
  align-items:center;
  padding:16px;
  border-radius:24px;
  background:rgba(255,255,255,.74);
  border:1px solid rgba(255,255,255,.95);
}
.cart-img{width:110px;height:110px;border-radius:20px;object-fit:cover;background:#fff}
.cart-title{font-weight:800;font-size:1.04rem}
.cart-variant{color:var(--muted);font-size:.92rem;margin-top:6px}
.cart-actions{display:flex;align-items:center;gap:12px;margin-top:14px;flex-wrap:wrap}
.cart-price{font-weight:900;color:var(--brand-dark);font-size:1.08rem}
.summary-row{display:flex;justify-content:space-between;gap:12px;padding:8px 0}
.summary-actions{display:grid;gap:12px;margin-top:18px}
.link{padding:0;border:0;background:none;color:var(--brand-dark);font-weight:800}
.link.danger{color:#a83b4b}
.fineprint{font-size:.88rem;line-height:1.6}
.empty-card{padding:30px;text-align:center}

.faq-grid{display:grid;gap:18px;grid-template-columns:repeat(2,minmax(0,1fr))}
.faq-card h2{margin-bottom:14px}
details{
  border-top:1px solid var(--line);
  padding:14px 0;
}
details:first-of-type{border-top:0;padding-top:0}
summary{
  list-style:none;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  cursor:pointer;
  font-weight:800;
}
summary::-webkit-details-marker{display:none}
summary::after{content:"＋";color:var(--brand-dark);font-size:1.15rem;line-height:1;transition:transform .18s ease}
details[open] summary::after{content:"–"}
details p{color:var(--muted);margin:10px 0 0}

.notice-grid{display:grid;gap:18px;grid-template-columns:repeat(3,minmax(0,1fr))}
.site-footer{padding:22px 0 34px}
.footer-shell{padding:28px}
.footer-grid{display:grid;gap:18px;grid-template-columns:1.2fr repeat(3,minmax(0,1fr))}
.footer-brand{display:flex;align-items:center;gap:14px}
.footer-brand img{width:56px;height:56px}
.footer-title{font-weight:900;letter-spacing:-0.02em}
.footer-links{display:grid;gap:10px;color:var(--muted)}
.footer-links a:hover{color:var(--brand-dark)}
.footer-bottom{padding-top:18px;color:var(--muted);font-size:.92rem}
.toast{
  position:fixed;
  right:20px;
  bottom:20px;
  z-index:40;
  opacity:0;
  transform:translateY(14px);
  transition:opacity .22s ease, transform .22s ease;
  padding:14px 16px;
  border-radius:18px;
  color:var(--text);
  font-weight:800;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(255,255,255,.95);
  box-shadow:var(--shadow-md);
}
.toast.show{opacity:1;transform:translateY(0)}
.empty{padding:34px;border-radius:26px;background:rgba(255,255,255,.72);border:1px solid rgba(255,255,255,.95);text-align:center;color:var(--muted)}

[hidden]{display:none!important}
:focus-visible{outline:none;box-shadow:var(--focus)}

@media (max-width: 1080px){
  .products,.collections,.bento-grid,.notice-grid,.footer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .hero-grid,.product-page,.story-grid,.split,.cart{grid-template-columns:1fr}
  .hero-stage{min-height:500px}
  .page-hero-grid{grid-template-columns:1fr}
  .page-hero-actions{justify-content:flex-start}
}

@media (max-width: 820px){
  .announce .inner{flex-direction:column;align-items:flex-start}
  .nav,.header-cta,.store-rail{display:none}
  .icon-btn{display:grid}
  .header-inner{gap:14px}
  .mobile-shop-links{display:flex;flex-wrap:wrap;gap:10px;padding-top:8px}
  .cart-link{padding:0 12px}
  .hero-shell,.page-hero,.feature-card,.detail-card,.info-card,.contact-card,.bento-card,.notice-card,.panel,.cart-summary,.empty-card,.faq-card{padding:22px}
  .hero-stage{min-height:420px}
  .hero-card-large{inset:50px 20px 108px 20px}
  .hero-cards,.faq-grid,.mosaic,.notice-grid,.bento-grid{grid-template-columns:1fr}
  .shop-controls{grid-template-columns:1fr}
  .products,.collections,.footer-grid{grid-template-columns:1fr}
  .cart-row{grid-template-columns:88px minmax(0,1fr)}
  .cart-price{grid-column:2}
  .qty-row{grid-template-columns:1fr}
}

@media (max-width: 560px){
  .container{padding:0 16px}
  .site-header-storefront .brand .name{font-size:.95rem}
  .mobile-shop-links .store-chip{width:100%}
  .section{padding:22px 0}
  .hero{padding-top:20px}
  .brand img{width:48px;height:48px}
  .brand .tag{display:none}
  .h1,.display{font-size:clamp(2.4rem, 12vw, 3.4rem)}
  .h2,.page-hero h1{font-size:clamp(1.8rem, 8vw, 2.45rem)}
  .hero-stage{min-height:360px;padding:18px}
  .floating-pill,.floating-note,.stage-badge,.mini-stat{padding:10px 12px;font-size:.82rem}
  .mini-stat strong{font-size:1rem}
}
