/*
Theme Name: Nacely Select Shop
Theme URI: https://www.nacelyselectshop.com/
Author: Nacely
Author URI: https://www.nacelyselectshop.com/
Description: 為都市女性挑選日常選品的精品電商主題 — 暖米色編輯式版面，含 hero、商品列、品牌故事、雜誌、購物車抽屜。可搭配 Elementor Pro 二次編輯。
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: nacely
Tags: e-commerce, editorial, minimal, beige, serif, woocommerce-ready
*/

/* ─────────────────────────────────────────────────────────────
   Design tokens
   ───────────────────────────────────────────────────────────── */
:root {
  --nc-cream: #f5f1ea;
  --nc-cream-2: #efe8db;
  --nc-card: #faf6ef;
  --nc-ink: #2b2620;
  --nc-ink-2: #3a3530;
  --nc-muted: #6e6357;
  --nc-muted-2: #8a7f72;
  --nc-line: #e7dfd2;
  --nc-line-2: #cdbfae;
  --nc-accent: #b48a6b;
  --nc-grid-gap: 26px;
  --nc-grid-cols: 4;
  --nc-card-pad: 16px;
  --nc-card-title: 15px;
  --nc-max: 1200px;
  --nc-serif: "Noto Serif TC", "Songti TC", "PingFang TC", "Times New Roman", serif;
  --nc-sans: "Noto Sans TC", "PingFang TC", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

/* Grid density modes (toggled via body class) */
body.nc-density-compact   { --nc-grid-gap: 16px; --nc-grid-cols: 4; --nc-card-pad: 12px; --nc-card-title: 14px; }
body.nc-density-spacious  { --nc-grid-gap: 40px; --nc-grid-cols: 3; --nc-card-pad: 22px; --nc-card-title: 17px; }

/* ─────────────────────────────────────────────────────────────
   Reset / base
   ───────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--nc-cream);
  color: var(--nc-ink);
  font-family: var(--nc-sans);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
button { font-family: inherit; cursor: pointer; }
h1, h2, h3, h4 { margin: 0; font-weight: 500; }

.nc-container { max-width: var(--nc-max); margin: 0 auto; padding: 0 32px; }
.nc-mono { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; }
.nc-serif { font-family: var(--nc-serif); }

/* ─────────────────────────────────────────────────────────────
   Promo + utility bar
   ───────────────────────────────────────────────────────────── */
.nc-promo {
  background: var(--nc-ink);
  color: var(--nc-cream);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-align: center;
  padding: 9px 16px;
}
.nc-utility {
  border-bottom: 1px solid var(--nc-line);
  color: var(--nc-muted);
  font-size: 11.5px;
  letter-spacing: 0.06em;
}
.nc-utility-row {
  display: flex;
  justify-content: space-between;
  padding: 9px 32px;
}
.nc-utility-right { display: flex; gap: 24px; }

/* ─────────────────────────────────────────────────────────────
   Header
   ───────────────────────────────────────────────────────────── */
.nc-header { background: var(--nc-cream); border-bottom: 1px solid var(--nc-line); }
.nc-header-bar {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 28px 32px 0;
  max-width: var(--nc-max);
  margin: 0 auto;
}
.nc-header-left,
.nc-header-right { display: flex; align-items: center; gap: 18px; color: var(--nc-ink-2); }
.nc-header-right { justify-content: flex-end; gap: 22px; }
.nc-header-left .nc-search-lbl { font-size: 13px; letter-spacing: 0.08em; }
.nc-logo { text-align: center; }
.nc-logo-mark {
  font-family: var(--nc-serif);
  font-size: 38px;
  letter-spacing: 0.32em;
  color: var(--nc-ink);
  padding-left: 0.32em;
  line-height: 1;
}
.nc-logo-tag {
  font-size: 10px;
  letter-spacing: 0.42em;
  color: var(--nc-muted-2);
  margin-top: 4px;
  padding-left: 0.42em;
}
.nc-icon-btn {
  background: none; border: 0; padding: 0; color: inherit;
  position: relative; display: inline-flex; align-items: center;
}
.nc-cart-badge {
  position: absolute;
  top: -6px; right: -10px;
  background: var(--nc-accent);
  color: var(--nc-card);
  font-size: 10px;
  font-weight: 600;
  line-height: 1;
  padding: 4px 6px;
  border-radius: 999px;
}
.nc-nav {
  display: flex;
  gap: 40px;
  justify-content: center;
  padding: 22px 32px 18px;
  max-width: var(--nc-max);
  margin: 0 auto;
  font-size: 14px;
  letter-spacing: 0.12em;
  color: var(--nc-muted);
}
.nc-nav a { padding-bottom: 4px; }
.nc-nav a.is-active { color: var(--nc-ink); border-bottom: 1px solid var(--nc-accent); }

/* ─────────────────────────────────────────────────────────────
   Hero
   ───────────────────────────────────────────────────────────── */
.nc-hero { background: var(--nc-cream); }
.nc-hero-grid {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 48px;
  align-items: stretch;
  padding: 56px 32px 64px;
  max-width: var(--nc-max);
  margin: 0 auto;
}
.nc-hero-image {
  position: relative;
  background: #cdbfae;
  aspect-ratio: 4 / 5;
  overflow: hidden;
}
.nc-hero-image .nc-edition {
  position: absolute; left: 28px; top: 28px;
  font-size: 11px; letter-spacing: 0.32em; color: var(--nc-ink);
}
.nc-hero-image .nc-hero-title {
  position: absolute; left: 28px; bottom: 28px;
  color: var(--nc-card);
  font-family: var(--nc-serif);
  font-size: 32px; line-height: 1.2; max-width: 320px;
}
.nc-hero-copy { display: flex; flex-direction: column; justify-content: space-between; padding: 8px 0; }
.nc-eyebrow { font-size: 11px; letter-spacing: 0.38em; color: var(--nc-muted-2); margin-bottom: 18px; }
.nc-h1 {
  font-family: var(--nc-serif);
  font-size: 64px; line-height: 1.05;
  color: var(--nc-ink);
  letter-spacing: 0.02em;
}
.nc-lede {
  font-size: 15px; line-height: 1.9;
  color: #5b5247; max-width: 440px; margin-top: 28px;
}
.nc-hero-ctas { display: flex; gap: 16px; align-items: center; margin-top: 40px; }
.nc-btn {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 16px 30px; border: 0;
  font-size: 13px; letter-spacing: 0.22em;
}
.nc-btn-primary { background: var(--nc-ink); color: var(--nc-card); }
.nc-btn-outline { background: transparent; color: var(--nc-ink); border: 1px solid var(--nc-ink-2); padding: 15px 28px; }
.nc-trust {
  display: flex; gap: 36px; margin-top: 40px;
  font-size: 11px; letter-spacing: 0.18em; color: var(--nc-muted-2);
}

/* ─────────────────────────────────────────────────────────────
   Section header
   ───────────────────────────────────────────────────────────── */
.nc-section { background: var(--nc-cream); }
.nc-section-inner { max-width: var(--nc-max); margin: 0 auto; padding: 70px 32px 30px; }
.nc-section-foot { padding-bottom: 90px; }
.nc-section-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  margin-bottom: 28px;
}
.nc-kicker { font-size: 11px; letter-spacing: 0.34em; color: var(--nc-muted-2); margin-bottom: 10px; }
.nc-h2 { font-family: var(--nc-serif); font-size: 30px; color: var(--nc-ink); letter-spacing: 0.02em; }
.nc-link {
  font-size: 13px; letter-spacing: 0.2em; color: var(--nc-ink-2);
  border-bottom: 1px solid var(--nc-accent); padding-bottom: 4px;
}

/* ─────────────────────────────────────────────────────────────
   Product grid + cards
   ───────────────────────────────────────────────────────────── */
.nc-grid {
  display: grid;
  grid-template-columns: repeat(var(--nc-grid-cols), 1fr);
  gap: var(--nc-grid-gap);
}
.nc-card { background: var(--nc-card); position: relative; display: flex; flex-direction: column; }
.nc-card-media { position: relative; aspect-ratio: 4 / 5; overflow: hidden; }
.nc-card-media svg { width: 100%; height: 100%; display: block; transition: transform 700ms ease; }
.nc-card:hover .nc-card-media svg { transform: scale(1.04); }
.nc-card-tag {
  position: absolute; top: 12px; left: 12px;
  background: var(--nc-ink); color: var(--nc-card);
  font-size: 10px; letter-spacing: 0.18em; padding: 4px 9px;
}
.nc-card-img-label {
  position: absolute; left: 12px; bottom: 10px;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 10px; letter-spacing: 0.04em;
  color: rgba(43,38,32,0.55);
  background: rgba(250,246,239,0.7);
  padding: 3px 8px;
}
.nc-card-add {
  position: absolute; left: 12px; right: 12px; bottom: 12px;
  background: var(--nc-ink); color: var(--nc-card);
  border: 0; padding: 12px 16px;
  font-size: 12px; letter-spacing: 0.22em;
  opacity: 0; transform: translateY(8px);
  transition: opacity 240ms ease, transform 240ms ease;
}
.nc-card:hover .nc-card-add { opacity: 1; transform: translateY(0); }
.nc-card-body { padding: var(--nc-card-pad) 4px 4px; }
.nc-card-title { font-family: var(--nc-serif); font-size: var(--nc-card-title); color: var(--nc-ink); line-height: 1.45; }
.nc-card-sub { font-size: 12px; color: var(--nc-muted-2); margin-top: 6px; letter-spacing: 0.06em; }
.nc-card-row { display: flex; align-items: center; gap: 12px; margin-top: 10px; }
.nc-price { font-size: 15px; color: var(--nc-ink); letter-spacing: 0.04em; }
.nc-price-compare { font-size: 12px; color: #a89784; text-decoration: line-through; }
.nc-swatches { margin-left: auto; display: flex; gap: 5px; }
.nc-swatch { width: 10px; height: 10px; border-radius: 999px; border: 1px solid var(--nc-line); }

/* ─────────────────────────────────────────────────────────────
   Collection strip
   ───────────────────────────────────────────────────────────── */
.nc-collections { background: var(--nc-cream-2); }
.nc-collections-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
  max-width: var(--nc-max); margin: 0 auto; padding: 64px 32px;
}
.nc-collection {
  position: relative; aspect-ratio: 4 / 5; overflow: hidden; display: block;
}
.nc-collection .nc-collection-label {
  position: absolute; left: 22px; bottom: 22px; color: var(--nc-card);
}
.nc-collection .nc-collection-sub { font-size: 10px; letter-spacing: 0.32em; }
.nc-collection .nc-collection-title { font-family: var(--nc-serif); font-size: 24px; margin-top: 6px; letter-spacing: 0.04em; }

/* ─────────────────────────────────────────────────────────────
   About strip
   ───────────────────────────────────────────────────────────── */
.nc-about { background: var(--nc-ink); color: var(--nc-cream); }
.nc-about-grid {
  display: grid; grid-template-columns: 1.2fr 1fr; gap: 64px; align-items: center;
  padding: 80px 32px; max-width: var(--nc-max); margin: 0 auto;
}
.nc-about-kicker { font-size: 11px; letter-spacing: 0.4em; color: var(--nc-accent); margin-bottom: 22px; }
.nc-about-h { font-family: var(--nc-serif); font-size: 40px; line-height: 1.25; font-weight: 400; }
.nc-about-p { font-size: 15px; line-height: 2; color: #cdbfae; margin-top: 24px; max-width: 520px; }
.nc-about-link {
  display: inline-block; margin-top: 32px; color: var(--nc-cream);
  font-size: 13px; letter-spacing: 0.24em;
  border-bottom: 1px solid var(--nc-accent); padding-bottom: 4px;
}
.nc-about-image { position: relative; aspect-ratio: 5 / 6; background: var(--nc-ink-2); overflow: hidden; }

/* ─────────────────────────────────────────────────────────────
   Journal
   ───────────────────────────────────────────────────────────── */
.nc-journal { background: var(--nc-cream); }
.nc-journal-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.nc-journal-item .nc-journal-media { aspect-ratio: 4 / 3; overflow: hidden; }
.nc-journal-item .nc-journal-kicker { margin-top: 16px; font-size: 10px; letter-spacing: 0.32em; color: var(--nc-muted-2); }
.nc-journal-item .nc-journal-h { font-family: var(--nc-serif); font-size: 20px; margin-top: 8px; color: var(--nc-ink); }
.nc-journal-item .nc-journal-link { margin-top: 12px; font-size: 12px; letter-spacing: 0.18em; color: var(--nc-muted); }

/* ─────────────────────────────────────────────────────────────
   Footer
   ───────────────────────────────────────────────────────────── */
.nc-footer { background: var(--nc-cream-2); color: var(--nc-ink-2); }
.nc-footer-cols {
  display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: 36px;
  max-width: var(--nc-max); margin: 0 auto; padding: 60px 32px 32px;
}
.nc-footer h4 { font-size: 11px; letter-spacing: 0.32em; color: var(--nc-ink); margin-bottom: 18px; font-weight: 500; }
.nc-footer-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; font-size: 13px; color: var(--nc-muted); }
.nc-newsletter { display: flex; margin-top: 16px; border: 1px solid var(--nc-line-2); }
.nc-newsletter input { flex: 1; padding: 12px 14px; border: 0; background: transparent; font-size: 13px; outline: none; font-family: inherit; }
.nc-newsletter button { background: var(--nc-ink); color: var(--nc-card); border: 0; padding: 0 18px; font-size: 12px; letter-spacing: 0.2em; }
.nc-footer-bottom { border-top: 1px solid var(--nc-line-2); }
.nc-footer-bottom-inner {
  display: flex; justify-content: space-between;
  max-width: var(--nc-max); margin: 0 auto; padding: 20px 32px;
  font-size: 11px; letter-spacing: 0.16em; color: var(--nc-muted-2);
}

/* ─────────────────────────────────────────────────────────────
   Cart drawer
   ───────────────────────────────────────────────────────────── */
.nc-cart-root { position: fixed; inset: 0; z-index: 9999; pointer-events: none; }
.nc-cart-root.is-open { pointer-events: auto; }
.nc-cart-scrim {
  position: absolute; inset: 0; background: rgba(43,38,32,0.4);
  opacity: 0; transition: opacity 240ms ease;
}
.nc-cart-root.is-open .nc-cart-scrim { opacity: 1; }
.nc-cart-drawer {
  position: absolute; top: 0; right: 0; bottom: 0;
  width: 420px; max-width: 100%;
  background: var(--nc-card);
  box-shadow: -30px 0 60px rgba(43,38,32,0.18);
  transform: translateX(110%);
  transition: transform 320ms cubic-bezier(.6,.05,.2,1);
  display: flex; flex-direction: column;
}
.nc-cart-root.is-open .nc-cart-drawer { transform: translateX(0); }
.nc-cart-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 22px; border-bottom: 1px solid var(--nc-line);
}
.nc-cart-head .nc-kicker { margin-bottom: 4px; }
.nc-cart-head .nc-cart-title { font-family: var(--nc-serif); font-size: 22px; color: var(--nc-ink); }
.nc-cart-body { flex: 1; overflow-y: auto; padding: 8px 22px; }
.nc-cart-empty {
  text-align: center; padding: 60px 0; color: var(--nc-muted-2);
  font-size: 14px; line-height: 1.9;
}
.nc-cart-empty-mark { font-size: 36px; color: var(--nc-line-2); margin-bottom: 12px; }
.nc-cart-item {
  display: grid; grid-template-columns: 78px 1fr auto;
  gap: 16px; padding: 18px 0; border-bottom: 1px solid var(--nc-line);
}
.nc-cart-item-thumb { width: 78px; height: 96px; overflow: hidden; }
.nc-cart-item-title { font-family: var(--nc-serif); font-size: 14px; color: var(--nc-ink); line-height: 1.4; }
.nc-cart-item-sub { font-size: 11px; color: var(--nc-muted-2); margin-top: 4px; }
.nc-cart-item-actions { display: flex; align-items: center; gap: 8px; margin-top: 12px; font-size: 13px; }
.nc-qty-btn { width: 22px; height: 22px; background: transparent; border: 1px solid var(--nc-line-2); color: var(--nc-ink-2); line-height: 1; font-size: 14px; }
.nc-remove { margin-left: auto; background: none; border: 0; font-size: 11px; color: var(--nc-muted-2); letter-spacing: 0.16em; }
.nc-cart-foot { padding: 20px 22px 22px; border-top: 1px solid var(--nc-line); background: var(--nc-cream); }
.nc-cart-row { display: flex; justify-content: space-between; font-size: 13px; color: var(--nc-muted); }
.nc-cart-row-sub { font-size: 12px; color: var(--nc-muted-2); margin-top: 6px; }
.nc-checkout {
  width: 100%; margin-top: 16px; padding: 16px 0;
  background: var(--nc-ink); color: var(--nc-card);
  border: 0; font-size: 13px; letter-spacing: 0.28em;
}
.nc-checkout[disabled] { background: var(--nc-line-2); cursor: not-allowed; }
.nc-payments { text-align: center; margin-top: 10px; font-size: 10px; letter-spacing: 0.2em; color: var(--nc-muted-2); }

/* ─────────────────────────────────────────────────────────────
   Responsive — mobile
   ───────────────────────────────────────────────────────────── */
@media (max-width: 860px) {
  .nc-utility { display: none; }
  .nc-promo { font-size: 10px; letter-spacing: 0.12em; padding: 7px 14px; }
  .nc-header-bar { padding: 14px 18px 0; }
  .nc-header-left .nc-search-lbl { display: none; }
  .nc-logo-mark { font-size: 22px; letter-spacing: 0.32em; }
  .nc-logo-tag { font-size: 8px; letter-spacing: 0.4em; }
  .nc-nav { gap: 18px; font-size: 12px; padding: 10px 18px 12px; overflow-x: auto; white-space: nowrap; justify-content: flex-start; -webkit-overflow-scrolling: touch; }
  .nc-hero-grid { grid-template-columns: 1fr; gap: 24px; padding: 0 0 32px; }
  .nc-hero-image { aspect-ratio: 4 / 5; }
  .nc-hero-image .nc-hero-title { font-size: 28px; }
  .nc-hero-copy { padding: 22px 18px 0; }
  .nc-h1 { font-size: 36px; }
  .nc-section-inner { padding: 40px 18px 16px; }
  .nc-section-foot { padding-bottom: 40px; }
  .nc-h2 { font-size: 22px; }
  .nc-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  body.nc-density-compact .nc-grid { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  body.nc-density-spacious .nc-grid { grid-template-columns: 1fr; gap: 24px; }
  .nc-collections-grid { grid-template-columns: 1fr; gap: 14px; padding: 32px 18px; }
  .nc-about-grid { grid-template-columns: 1fr; gap: 32px; padding: 48px 22px; }
  .nc-about-h { font-size: 26px; }
  .nc-journal-grid { grid-template-columns: 1fr; gap: 22px; }
  .nc-footer-cols { grid-template-columns: 1fr 1fr; gap: 22px; padding: 36px 22px 28px; }
  .nc-footer-bottom-inner { flex-direction: column; gap: 10px; padding: 16px 22px; }
  .nc-trust { flex-wrap: wrap; gap: 18px; }
  .nc-cart-drawer { width: 85%; }
}
