/* =========================================================
   淨淨門市小幫手 store-reyway
   設計：小喬 × 墨子｜2026-04-26
   風格：薄荷綠 #61D0DF × 米白 × 點綴金 #C9A96A
   原則：手機優先、櫃姐單手操作、襯線優雅
   ========================================================= */

:root {
  --color-primary: #61D0DF;
  --color-primary-dark: #3FAFC4;
  --color-primary-deep: #1F6B5C;
  --color-primary-light: #E6F7FA;
  --color-primary-soft: #F4FCFD;
  --color-primary-mist: #FAFDFC;

  --color-text: #1F2A2D;
  --color-text-deep: #0E1718;
  --color-text-sub: #5A6B6E;
  --color-text-muted: #8A9999;

  --color-bg: #FAFBFB;
  --color-card: #FFFFFF;
  --color-border: #E5EBEB;
  --color-border-soft: #F0F4F4;

  --color-gold: #C9A96A;
  --color-gold-soft: #E5D4A8;
  --color-paper: #FAF6F0;
  --color-cream: #FCF9F4;

  --color-danger: #E55944;
  --color-danger-light: #FCEBE7;
  --color-warning: #E8A845;
  --color-success: #61D0DF;

  --radius-md: 8px;
  --radius-lg: 14px;
  --radius-xl: 20px;
  --radius-pill: 999px;

  --shadow-xs: 0 1px 2px rgba(31,42,45,.04);
  --shadow-sm: 0 2px 8px rgba(31,42,45,.05);
  --shadow-md: 0 6px 18px rgba(31,42,45,.06);
  --shadow-lg: 0 14px 36px rgba(31,42,45,.10);

  --ease: cubic-bezier(.4,0,.2,1);
  --ease-soft: cubic-bezier(.16,1,.3,1);
  --transition: 200ms var(--ease);

  --font-serif-tc: 'Noto Serif TC', "PingFang TC", "Songti TC", serif;
  --font-serif-en: 'Cormorant Garamond', 'Noto Serif TC', serif;
  --font-sans-tc: 'Noto Sans TC', "PingFang TC", "Microsoft JhengHei", sans-serif;

  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --safe-top: env(safe-area-inset-top, 0px);
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-sans-tc);
  font-size: 17px;
  line-height: 1.7;
  color: var(--color-text);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  letter-spacing: .01em;
  min-height: 100vh;
}
img { max-width: 100%; display: block; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
input, textarea, select {
  font-family: inherit;
  font-size: 17px;
  -webkit-appearance: none;
  appearance: none;
}
a { color: var(--color-primary-dark); text-decoration: none; }
.hidden { display: none !important; }

/* ---------- Container ---------- */
.shell {
  max-width: 480px;
  margin: 0 auto;
  min-height: 100vh;
  padding: calc(16px + var(--safe-top)) 16px calc(40px + var(--safe-bottom));
  background: var(--color-bg);
  position: relative;
}

/* =========================================================
   登入頁（login.html）
   ========================================================= */

.login-page {
  min-height: 100vh;
  background:
    radial-gradient(ellipse at top right, rgba(232,245,241,.95) 0%, transparent 55%),
    radial-gradient(ellipse at bottom left, rgba(250,246,240,.7) 0%, transparent 50%),
    linear-gradient(155deg, #F4FCFD 0%, #FCFBF8 45%, #FAF6F0 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: calc(40px + var(--safe-top)) 20px calc(40px + var(--safe-bottom));
}

.login-stamp {
  position: absolute;
  top: calc(20px + var(--safe-top));
  right: 20px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.login-stamp-mark {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--color-primary);
  color: #fff;
  font-family: var(--font-serif-tc);
  font-size: 16px;
  font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 14px rgba(61,170,148,.28);
}
.login-stamp-text { display: flex; flex-direction: column; line-height: 1.2; }
.login-stamp-line {
  font-family: var(--font-serif-en);
  font-size: 15px; font-weight: 600;
  color: var(--color-text-deep);
  letter-spacing: .04em;
}
.login-stamp-tag {
  font-size: 10px; font-weight: 500;
  color: var(--color-gold);
  letter-spacing: .18em;
  text-transform: uppercase;
}

.login-card {
  width: 100%;
  max-width: 420px;
  background: rgba(255,255,255,.85);
  backdrop-filter: blur(18px) saturate(180%);
  -webkit-backdrop-filter: blur(18px) saturate(180%);
  border: 1px solid rgba(255,255,255,.7);
  border-radius: var(--radius-xl);
  padding: 36px 24px 32px;
  box-shadow: var(--shadow-lg);
  position: relative;
  margin-top: 32px;
}

.login-eyebrow {
  font-family: var(--font-serif-en);
  font-size: 12px;
  color: var(--color-gold);
  letter-spacing: .22em;
  text-transform: uppercase;
  margin: 0 0 8px;
  text-align: center;
}
.login-title {
  font-family: var(--font-serif-tc);
  font-size: 28px;
  font-weight: 700;
  color: var(--color-text-deep);
  margin: 0 0 4px;
  text-align: center;
  letter-spacing: .02em;
}
.login-sub {
  font-size: 14px;
  color: var(--color-text-sub);
  text-align: center;
  margin: 0 0 28px;
  letter-spacing: .04em;
}
.login-divider-line {
  width: 40px; height: 1.5px;
  background: linear-gradient(90deg, transparent, var(--color-gold), transparent);
  margin: 0 auto 24px;
}

.field { margin-bottom: 20px; }
.field-label {
  display: block;
  font-size: 13px;
  font-weight: 500;
  color: var(--color-text-sub);
  margin-bottom: 8px;
  letter-spacing: .04em;
}
.field-input,
.field-select,
.field-textarea {
  width: 100%;
  padding: 14px 16px;
  font-size: 16px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: #fff;
  color: var(--color-text);
  transition: border-color var(--transition), box-shadow var(--transition);
}
.field-input:focus,
.field-select:focus,
.field-textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(61,170,148,.12);
}
.field-textarea { min-height: 96px; resize: vertical; line-height: 1.6; }
.field-select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none'%3E%3Cpath d='M3 4.5L6 7.5L9 4.5' stroke='%235A6B6E' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 16px center;
  padding-right: 40px;
}

.pin-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.pin-input {
  width: 100%;
  height: 64px;
  text-align: center;
  font-size: 28px;
  font-weight: 600;
  font-family: var(--font-serif-en);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  background: #fff;
  color: var(--color-text-deep);
  transition: all var(--transition);
}
.pin-input:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(61,170,148,.18);
  background: var(--color-primary-soft);
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  min-height: 56px;
  padding: 14px 20px;
  font-family: var(--font-sans-tc);
  font-size: 17px;
  font-weight: 600;
  letter-spacing: .04em;
  border-radius: var(--radius-md);
  background: var(--color-primary);
  color: #fff;
  transition: all var(--transition);
  box-shadow: 0 4px 14px rgba(61,170,148,.18);
}
.btn:hover { background: var(--color-primary-dark); transform: translateY(-1px); }
.btn:active { transform: translateY(0); box-shadow: var(--shadow-xs); }
.btn:disabled {
  background: var(--color-border);
  color: var(--color-text-muted);
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}
.btn-ghost {
  background: transparent;
  color: var(--color-primary-dark);
  border: 1.5px solid var(--color-border);
  box-shadow: none;
}
.btn-ghost:hover {
  background: var(--color-primary-soft);
  border-color: var(--color-primary);
}
.btn-sm {
  min-height: 38px;
  padding: 8px 14px;
  font-size: 13px;
  width: auto;
  border-radius: var(--radius-pill);
}
.btn-block-tall { min-height: 64px; font-size: 18px; }

.error-msg {
  margin-top: 14px;
  padding: 12px 14px;
  background: var(--color-danger-light);
  color: var(--color-danger);
  border-radius: var(--radius-md);
  font-size: 14px;
  text-align: center;
  font-weight: 500;
}

.login-foot {
  margin-top: 28px;
  text-align: center;
  font-family: var(--font-serif-en);
  font-size: 11px;
  color: var(--color-text-muted);
  letter-spacing: .14em;
}

/* =========================================================
   主頁 Header
   ========================================================= */

.app-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
  padding: 6px 0 18px;
  border-bottom: 1px solid var(--color-border-soft);
}
.app-header-left { display: flex; flex-direction: column; gap: 4px; }
.store-name {
  font-family: var(--font-serif-tc);
  font-size: 20px;
  font-weight: 700;
  color: var(--color-text-deep);
  letter-spacing: .02em;
}
.store-meta {
  font-size: 12px;
  color: var(--color-text-muted);
  letter-spacing: .04em;
}
.store-meta .gold-tag {
  display: inline-block;
  margin-left: 6px;
  padding: 1px 8px;
  background: var(--color-paper);
  color: var(--color-gold);
  border-radius: var(--radius-pill);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: .1em;
}
.icon-btn {
  width: 38px; height: 38px;
  border-radius: 50%;
  background: var(--color-primary-soft);
  color: var(--color-primary-dark);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background var(--transition);
}
.icon-btn:hover { background: var(--color-primary-light); }
.icon-btn i { width: 18px; height: 18px; }

/* 子頁 back header */
.sub-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 18px;
  padding: 6px 0 16px;
  border-bottom: 1px solid var(--color-border-soft);
}
.back-btn {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--color-card);
  border: 1px solid var(--color-border);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text);
  flex-shrink: 0;
}
.back-btn i { width: 18px; height: 18px; }
.sub-header-title {
  font-family: var(--font-serif-tc);
  font-size: 19px;
  font-weight: 700;
  color: var(--color-text-deep);
  letter-spacing: .02em;
}
.sub-header-sub {
  display: block;
  font-size: 12px;
  color: var(--color-text-muted);
  font-weight: 400;
  letter-spacing: .04em;
  margin-top: 2px;
}

/* =========================================================
   業績登記大卡片（首頁第一區）
   ========================================================= */

.sales-hero {
  display: block;
  background: linear-gradient(135deg, #fff 0%, var(--color-cream) 100%);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 22px 20px;
  box-shadow: var(--shadow-sm);
  margin-bottom: 18px;
  position: relative;
  transition: all var(--transition);
  color: inherit;
}
.sales-hero:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: var(--color-primary-light);
}
.sales-hero.is-empty {
  border-left: 4px solid var(--color-danger);
}
.sales-hero.is-filled {
  border-left: 4px solid var(--color-primary);
}
.sales-hero-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 10px;
}
.sales-hero-label {
  font-family: var(--font-serif-tc);
  font-size: 14px;
  color: var(--color-text-sub);
  letter-spacing: .06em;
}
.sales-hero-date {
  font-size: 12px;
  color: var(--color-text-muted);
  font-family: var(--font-serif-en);
  letter-spacing: .08em;
}
.sales-hero-amount {
  font-family: var(--font-serif-en);
  font-size: 38px;
  font-weight: 700;
  color: var(--color-text-deep);
  line-height: 1.1;
  letter-spacing: .01em;
  margin: 4px 0 6px;
}
.sales-hero.is-empty .sales-hero-amount {
  color: var(--color-danger);
}
.sales-hero.is-filled .sales-hero-amount {
  color: var(--color-primary-deep);
}
.sales-hero-amount .currency {
  font-size: 18px;
  font-weight: 500;
  margin-right: 4px;
  color: var(--color-text-muted);
}
.sales-hero-foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 13px;
  color: var(--color-text-sub);
}
.sales-hero-foot .cta {
  color: var(--color-primary-dark);
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.sales-hero-foot .cta i { width: 14px; height: 14px; }
.empty-dot {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--color-danger);
  margin-right: 6px;
  animation: pulse 1.6s ease-in-out infinite;
}
@keyframes pulse {
  0%,100% { opacity: 1; transform: scale(1); }
  50% { opacity: .4; transform: scale(1.2); }
}

/* =========================================================
   功能卡片 grid
   ========================================================= */

.section-eyebrow {
  font-family: var(--font-serif-en);
  font-size: 11px;
  color: var(--color-gold);
  letter-spacing: .22em;
  text-transform: uppercase;
  margin: 22px 0 10px;
  text-align: left;
}
.section-title {
  font-family: var(--font-serif-tc);
  font-size: 16px;
  font-weight: 600;
  color: var(--color-text-deep);
  margin: 0 0 14px;
  letter-spacing: .02em;
}

.fn-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-bottom: 24px;
}
.fn-card {
  display: flex;
  flex-direction: column;
  gap: 8px;
  background: var(--color-card);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-lg);
  padding: 18px 16px;
  transition: all var(--transition);
  color: inherit;
  min-height: 130px;
  position: relative;
  overflow: hidden;
}
.fn-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: var(--color-primary-light);
}
.fn-card-icon {
  width: 44px; height: 44px;
  border-radius: 12px;
  background: var(--color-primary-soft);
  color: var(--color-primary-dark);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.fn-card-icon i { width: 22px; height: 22px; }
.fn-card-title {
  font-family: var(--font-serif-tc);
  font-size: 16px;
  font-weight: 600;
  color: var(--color-text-deep);
  letter-spacing: .02em;
}
.fn-card-sub {
  font-size: 12px;
  color: var(--color-text-muted);
  letter-spacing: .04em;
  line-height: 1.5;
}
.fn-card.span-2 { grid-column: span 2; }

/* =========================================================
   月達標進度條
   ========================================================= */

.goal-card {
  background: var(--color-card);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-lg);
  padding: 18px;
  box-shadow: var(--shadow-xs);
}
.goal-card-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 6px;
}
.goal-card-label {
  font-family: var(--font-serif-tc);
  font-size: 14px;
  color: var(--color-text-sub);
  letter-spacing: .04em;
}
.goal-card-pct {
  font-family: var(--font-serif-en);
  font-size: 22px;
  font-weight: 700;
  color: var(--color-primary-deep);
  letter-spacing: .02em;
}
.progress-bar {
  width: 100%;
  height: 8px;
  background: var(--color-primary-soft);
  border-radius: var(--radius-pill);
  overflow: hidden;
  margin: 8px 0;
}
.progress-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  border-radius: var(--radius-pill);
  transition: width 800ms var(--ease-soft);
}
.goal-card-amount {
  font-size: 13px;
  color: var(--color-text-sub);
  letter-spacing: .02em;
}
.goal-card-amount strong {
  color: var(--color-text-deep);
  font-weight: 600;
}

/* =========================================================
   搜尋列 + chip 篩選
   ========================================================= */

.search-bar {
  position: relative;
  margin-bottom: 14px;
}
.search-bar input {
  width: 100%;
  padding: 14px 16px 14px 44px;
  font-size: 16px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: #fff;
  color: var(--color-text);
}
.search-bar input:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(61,170,148,.12);
}
.search-bar i {
  position: absolute;
  top: 50%;
  left: 14px;
  width: 18px; height: 18px;
  transform: translateY(-50%);
  color: var(--color-text-muted);
  pointer-events: none;
}

.chip-row {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 4px 0 14px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.chip-row::-webkit-scrollbar { display: none; }
.chip {
  flex-shrink: 0;
  padding: 8px 16px;
  font-size: 13px;
  font-weight: 500;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  color: var(--color-text-sub);
  letter-spacing: .04em;
  transition: all var(--transition);
  cursor: pointer;
}
.chip:hover {
  border-color: var(--color-primary);
  color: var(--color-primary-dark);
}
.chip.is-active {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
}

/* =========================================================
   產品卡（products.html）
   ========================================================= */

.product-list { display: flex; flex-direction: column; gap: 12px; }
.product-card {
  background: #fff;
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-lg);
  padding: 16px;
  box-shadow: var(--shadow-xs);
  transition: all var(--transition);
}
.product-card.is-open {
  box-shadow: var(--shadow-md);
  border-color: var(--color-primary-light);
}
.product-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  cursor: pointer;
}
.product-name {
  font-family: var(--font-serif-tc);
  font-size: 17px;
  font-weight: 600;
  color: var(--color-text-deep);
  letter-spacing: .02em;
  line-height: 1.4;
  margin-bottom: 4px;
}
.product-tagline {
  font-size: 12px;
  color: var(--color-gold);
  letter-spacing: .04em;
  font-family: var(--font-serif-tc);
}
.product-price {
  font-family: var(--font-serif-en);
  font-size: 26px;
  font-weight: 700;
  color: var(--color-primary-deep);
  white-space: nowrap;
  letter-spacing: .01em;
}
.product-price .currency {
  font-size: 13px;
  font-weight: 500;
  color: var(--color-text-muted);
  margin-right: 2px;
}
.product-points {
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.product-point {
  display: flex;
  gap: 8px;
  font-size: 14px;
  color: var(--color-text-sub);
  line-height: 1.5;
}
.product-point::before {
  content: '';
  flex-shrink: 0;
  width: 4px; height: 4px;
  border-radius: 50%;
  background: var(--color-primary);
  margin-top: 9px;
}
.product-toggle {
  margin-top: 12px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 13px;
  color: var(--color-primary-dark);
  font-weight: 600;
}
.product-toggle i { width: 14px; height: 14px; transition: transform var(--transition); }
.product-card.is-open .product-toggle i { transform: rotate(180deg); }
.product-detail {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px dashed var(--color-border);
  display: none;
}
.product-card.is-open .product-detail { display: block; }
.product-detail h4 {
  font-family: var(--font-serif-tc);
  font-size: 14px;
  font-weight: 600;
  color: var(--color-text-deep);
  margin: 12px 0 6px;
  letter-spacing: .04em;
}
.product-detail h4:first-child { margin-top: 0; }
.product-detail p,
.product-detail li {
  font-size: 14px;
  color: var(--color-text-sub);
  line-height: 1.7;
}
.product-detail ul {
  margin: 0;
  padding-left: 18px;
}
.faq-item {
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--color-border-soft);
}
.faq-item:last-child { border-bottom: none; padding-bottom: 0; margin-bottom: 0; }
.faq-q {
  display: block;
  font-size: 14px;
  color: var(--color-text-deep);
  font-weight: 600;
  margin-bottom: 4px;
}
.faq-q::before { content: 'Q. '; color: var(--color-primary); font-weight: 700; }
.faq-a { font-size: 14px; color: var(--color-text-sub); line-height: 1.7; }
.faq-a::before { content: 'A. '; color: var(--color-gold); font-weight: 700; }

.compliance-box {
  margin-top: 14px;
  padding: 12px 14px;
  background: var(--color-paper);
  border: 1px solid var(--color-gold-soft);
  border-radius: var(--radius-md);
  font-size: 13px;
  color: var(--color-text);
  line-height: 1.6;
}
.compliance-box-label {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  font-weight: 700;
  color: var(--color-gold);
  letter-spacing: .14em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.compliance-box-label i { width: 12px; height: 12px; }
.compliance-box ul { margin: 0; padding-left: 16px; }

.empty-state {
  text-align: center;
  padding: 48px 20px;
  color: var(--color-text-muted);
  font-size: 14px;
}
.empty-state i { width: 36px; height: 36px; margin: 0 auto 10px; display: block; }

/* =========================================================
   話術生成（scripts.html）
   ========================================================= */

.form-card {
  background: #fff;
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-lg);
  padding: 18px;
  margin-bottom: 18px;
  box-shadow: var(--shadow-xs);
}
.chip-pick {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.chip-pick .chip {
  flex-shrink: 0;
}
.script-result {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.script-card {
  background: #fff;
  border: 1px solid var(--color-border-soft);
  border-left: 4px solid var(--color-primary);
  border-radius: var(--radius-lg);
  padding: 18px;
  box-shadow: var(--shadow-xs);
}
.script-card-tone {
  font-family: var(--font-serif-en);
  font-size: 11px;
  font-weight: 600;
  color: var(--color-gold);
  letter-spacing: .22em;
  text-transform: uppercase;
  margin-bottom: 4px;
}
.script-card-title {
  font-family: var(--font-serif-tc);
  font-size: 16px;
  font-weight: 600;
  color: var(--color-text-deep);
  margin-bottom: 10px;
  letter-spacing: .02em;
}
.script-card-text {
  font-size: 15px;
  line-height: 1.85;
  color: var(--color-text);
  white-space: pre-wrap;
}
.script-card-foot {
  margin-top: 12px;
  display: flex;
  justify-content: flex-end;
}

.copy-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  background: var(--color-primary-soft);
  color: var(--color-primary-dark);
  border-radius: var(--radius-pill);
  font-size: 13px;
  font-weight: 600;
  border: 1px solid var(--color-primary-light);
  transition: all var(--transition);
}
.copy-btn:hover { background: var(--color-primary-light); }
.copy-btn.is-done {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
}
.copy-btn i { width: 14px; height: 14px; }

.skeleton {
  background: linear-gradient(90deg, var(--color-border-soft) 0%, var(--color-primary-soft) 50%, var(--color-border-soft) 100%);
  background-size: 200% 100%;
  animation: shimmer 1.4s linear infinite;
  border-radius: var(--radius-md);
  height: 14px;
  margin-bottom: 8px;
}
@keyframes shimmer {
  from { background-position: 200% 0; }
  to { background-position: -200% 0; }
}

/* =========================================================
   LINE@ 助手
   ========================================================= */

.tab-row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 6px;
  background: var(--color-primary-soft);
  border-radius: var(--radius-pill);
  padding: 4px;
  margin-bottom: 18px;
}
.tab-btn {
  padding: 10px 14px;
  font-size: 14px;
  font-weight: 600;
  border-radius: var(--radius-pill);
  background: transparent;
  color: var(--color-text-sub);
  letter-spacing: .04em;
  transition: all var(--transition);
}
.tab-btn.is-active {
  background: #fff;
  color: var(--color-primary-deep);
  box-shadow: var(--shadow-xs);
}

.template-list { display: flex; flex-direction: column; gap: 10px; }
.template-card {
  background: #fff;
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-lg);
  padding: 14px 16px;
  box-shadow: var(--shadow-xs);
}
.template-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
}
.template-name {
  font-family: var(--font-serif-tc);
  font-size: 15px;
  font-weight: 600;
  color: var(--color-text-deep);
  letter-spacing: .02em;
}
.template-cat {
  font-size: 11px;
  color: var(--color-gold);
  background: var(--color-paper);
  padding: 2px 10px;
  border-radius: var(--radius-pill);
  letter-spacing: .1em;
  font-weight: 600;
}
.template-body {
  display: none;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px dashed var(--color-border);
}
.template-card.is-open .template-body { display: block; }
.template-text {
  font-size: 14px;
  line-height: 1.8;
  color: var(--color-text);
  background: var(--color-primary-soft);
  border-radius: var(--radius-md);
  padding: 12px 14px;
  white-space: pre-wrap;
  margin-bottom: 10px;
}

.tag-row { display: flex; gap: 8px; margin-top: 4px; }
.tag-pick {
  flex: 1;
  padding: 8px 12px;
  font-size: 13px;
  font-weight: 500;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  color: var(--color-text-sub);
  text-align: center;
}
.tag-pick.is-active {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
}

/* =========================================================
   檔期 campaigns
   ========================================================= */

.campaign-list { display: flex; flex-direction: column; gap: 14px; }
.campaign-card {
  background: #fff;
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-lg);
  padding: 18px;
  box-shadow: var(--shadow-xs);
  position: relative;
}
.campaign-card.is-active { border-left: 4px solid var(--color-primary); }
.campaign-card.is-upcoming { border-left: 4px solid var(--color-gold); }
.campaign-card.is-ended { opacity: .6; border-left: 4px solid var(--color-border); }
.campaign-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 8px;
  gap: 10px;
}
.campaign-name {
  font-family: var(--font-serif-tc);
  font-size: 17px;
  font-weight: 600;
  color: var(--color-text-deep);
  letter-spacing: .02em;
  line-height: 1.4;
}
.campaign-badge {
  flex-shrink: 0;
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 600;
  border-radius: var(--radius-pill);
  letter-spacing: .08em;
}
.badge-active { background: var(--color-primary-light); color: var(--color-primary-deep); }
.badge-upcoming { background: var(--color-paper); color: var(--color-gold); }
.badge-ended { background: var(--color-border-soft); color: var(--color-text-muted); }
.campaign-period {
  font-size: 12px;
  color: var(--color-text-muted);
  font-family: var(--font-serif-en);
  letter-spacing: .06em;
  margin-bottom: 10px;
}
.campaign-desc {
  font-size: 14px;
  color: var(--color-text);
  line-height: 1.7;
  margin-bottom: 8px;
}
.campaign-detail {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed var(--color-border);
  font-size: 13px;
  color: var(--color-text-sub);
}
.campaign-detail strong { color: var(--color-text-deep); margin-right: 4px; }

/* =========================================================
   業績登記頁 / 歷史
   ========================================================= */

.input-big {
  width: 100%;
  padding: 18px 18px;
  font-size: 32px;
  font-weight: 700;
  font-family: var(--font-serif-en);
  text-align: center;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: #fff;
  color: var(--color-primary-deep);
  letter-spacing: .04em;
}
.input-big:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 4px rgba(61,170,148,.16);
}
.input-prefix-wrap {
  position: relative;
}
.input-prefix-wrap .prefix {
  position: absolute;
  top: 50%;
  left: 18px;
  transform: translateY(-50%);
  font-family: var(--font-serif-en);
  font-size: 22px;
  font-weight: 600;
  color: var(--color-text-muted);
  pointer-events: none;
}
.input-prefix-wrap input { padding-left: 60px; text-align: left; }

.big-date {
  font-family: var(--font-serif-tc);
  font-size: 22px;
  font-weight: 700;
  color: var(--color-text-deep);
  text-align: center;
  margin: 6px 0 24px;
  letter-spacing: .04em;
}
.big-date small {
  display: block;
  font-family: var(--font-serif-en);
  font-size: 13px;
  font-weight: 400;
  color: var(--color-gold);
  letter-spacing: .14em;
  text-transform: uppercase;
  margin-top: 4px;
}

/* 月曆 grid（業績歷史） */
.month-stat {
  background: linear-gradient(135deg, var(--color-primary-soft), #fff);
  border: 1px solid var(--color-primary-light);
  border-radius: var(--radius-lg);
  padding: 18px;
  margin-bottom: 18px;
  text-align: center;
}
.month-stat-label {
  font-size: 12px;
  color: var(--color-text-sub);
  font-family: var(--font-serif-en);
  letter-spacing: .14em;
  text-transform: uppercase;
}
.month-stat-amount {
  font-family: var(--font-serif-en);
  font-size: 36px;
  font-weight: 700;
  color: var(--color-primary-deep);
  margin: 4px 0;
}
.month-stat-meta {
  font-size: 13px;
  color: var(--color-text-sub);
}

.cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
  margin-bottom: 18px;
}
.cal-head {
  font-size: 11px;
  text-align: center;
  color: var(--color-text-muted);
  padding: 6px 0;
  font-family: var(--font-serif-en);
  letter-spacing: .12em;
  text-transform: uppercase;
}
.cal-cell {
  aspect-ratio: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-md);
  background: var(--color-card);
  border: 1px solid var(--color-border-soft);
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text);
  position: relative;
}
.cal-cell.has-sale {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
}
.cal-cell.no-sale {
  background: var(--color-danger-light);
  border-color: var(--color-danger-light);
  color: var(--color-danger);
}
.cal-cell.future {
  background: var(--color-bg);
  color: var(--color-text-muted);
  opacity: .5;
}
.cal-cell.is-today {
  outline: 2px solid var(--color-gold);
  outline-offset: 1px;
}

.recent-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.recent-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #fff;
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-md);
  padding: 12px 14px;
  font-size: 14px;
}
.recent-row .left {
  display: flex;
  flex-direction: column;
}
.recent-row .date {
  font-family: var(--font-serif-en);
  font-size: 14px;
  font-weight: 600;
  color: var(--color-text-deep);
}
.recent-row .meta {
  font-size: 11px;
  color: var(--color-text-muted);
  letter-spacing: .04em;
}
.recent-row .amount {
  font-family: var(--font-serif-en);
  font-size: 18px;
  font-weight: 700;
  color: var(--color-primary-deep);
}

/* =========================================================
   Toast 通知
   ========================================================= */

.toast {
  position: fixed;
  top: calc(20px + var(--safe-top));
  left: 50%;
  transform: translate(-50%, -120%);
  background: var(--color-text-deep);
  color: #fff;
  padding: 12px 22px;
  border-radius: var(--radius-pill);
  font-size: 14px;
  font-weight: 500;
  box-shadow: var(--shadow-lg);
  z-index: 1000;
  transition: transform 320ms var(--ease-soft);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  letter-spacing: .04em;
}
.toast.is-show { transform: translate(-50%, 0); }
.toast.is-error { background: var(--color-danger); }
.toast i { width: 16px; height: 16px; }

/* =========================================================
   底部版本號 footer
   ========================================================= */

.app-foot {
  margin-top: 32px;
  padding-top: 18px;
  border-top: 1px solid var(--color-border-soft);
  text-align: center;
  font-family: var(--font-serif-en);
  font-size: 11px;
  color: var(--color-text-muted);
  letter-spacing: .12em;
}

/* =========================================================
   Util
   ========================================================= */

.row-between { display: flex; justify-content: space-between; align-items: center; }
.gap-8 { gap: 8px; }
.gap-12 { gap: 12px; }
.mt-8 { margin-top: 8px; }
.mt-16 { margin-top: 16px; }
.mt-24 { margin-top: 24px; }
.mb-8 { margin-bottom: 8px; }
.mb-16 { margin-bottom: 16px; }
.mb-24 { margin-bottom: 24px; }
.w-full { width: 100%; }
.text-center { text-align: center; }
.text-sub { color: var(--color-text-sub); }
.text-muted { color: var(--color-text-muted); font-size: 13px; }
.flex { display: flex; }
.flex-col { display: flex; flex-direction: column; }
.items-center { align-items: center; }

/* lucide icon 預設大小 */
[data-lucide] { width: 18px; height: 18px; flex-shrink: 0; }

/* 螢幕大於 480 時保持窄版手感 */
@media (min-width: 481px) {
  .shell { box-shadow: var(--shadow-md); border-radius: 0; }
}

/* 暗黑模式預留（門市環境通常常亮，暫不啟用） */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
}

/* === 業績速覽卡（昨日／本月）=== */
.perf-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 32px; }
.perf-card { background: #fff; border: 1px solid #E6F2F4; border-radius: 14px; padding: 18px 16px 14px; box-shadow: 0 2px 10px rgba(97,208,223,.04); }
.perf-card-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 14px; padding-bottom: 10px; border-bottom: 1px solid #F0F6F7; }
.perf-card-title { font-family: 'Noto Serif TC', serif; font-size: 15px; font-weight: 600; color: #2A3A38; }
.perf-card-sub { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 11px; color: #6B7B7E; letter-spacing: .05em; }
.perf-row { display: grid; grid-template-columns: 50px 1fr auto; gap: 6px; align-items: baseline; padding: 6px 0; font-family: 'Noto Sans TC', sans-serif; }
.perf-row-label { font-size: 11px; color: #6B7B7E; }
.perf-row-val { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 18px; font-weight: 600; color: #2A3A38; text-align: right; }
.perf-row-delta { font-size: 10.5px; font-weight: 500; padding: 2px 6px; border-radius: 999px; min-width: 56px; text-align: center; }
.perf-up { background: rgba(97,208,223,.14); color: #2E97AB; }
.perf-down { background: rgba(229,89,68,.12); color: #B53A28; }
.perf-flat { background: rgba(108,117,125,.12); color: #495057; }
.perf-foot { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 10.5px; color: #C9A96A; text-align: right; margin-top: 8px; padding-top: 8px; border-top: 1px dashed #F0E8D6; letter-spacing: .03em; }
@media (max-width: 480px) {
  .perf-grid { grid-template-columns: 1fr; }
  .perf-row-val { font-size: 17px; }
}

/* === LINE@ 群發推播 + 通知提醒 === */
.field-hint { font-family: 'Noto Sans TC', sans-serif; font-size: 12.5px; color: #6B7B7E; }
.link-btn { background: none; border: none; color: #2E97AB; font-family: 'Noto Sans TC'; font-size: 12.5px; cursor: pointer; padding: 0; }
.link-btn:hover { text-decoration: underline; }
.bc-result { padding: 0 16px; }
.bc-preview { background: #fff; border: 1px solid #E6F2F4; border-radius: 14px; padding: 16px 18px; margin-top: 14px; box-shadow: 0 2px 10px rgba(97,208,223,.06); }
.bc-preview-title { font-family: 'Noto Serif TC', serif; font-weight: 600; color: #2E97AB; margin-bottom: 12px; padding-bottom: 8px; border-bottom: 1px solid #F0F6F7; font-size: 14px; }
.bc-preview-row { display: flex; justify-content: space-between; padding: 4px 0; font-family: 'Noto Sans TC'; font-size: 13px; color: #6B7B7E; }
.bc-preview-row strong { color: #2A3A38; font-weight: 500; }
.bc-preview-msg { background: #F4FCFD; border-left: 3px solid #61D0DF; padding: 12px 14px; border-radius: 6px; margin: 10px 0; font-family: 'Noto Sans TC'; font-size: 14px; line-height: 1.6; color: #2A3A38; }
.bc-preview-foot { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 11px; color: #C9A96A; text-align: right; margin-top: 8px; }
.field-input.hidden { display: none; }

.sched-section-title { font-family: 'Noto Serif TC', serif; font-weight: 600; font-size: 15px; color: #2A3A38; margin-bottom: 12px; padding-bottom: 8px; border-bottom: 1px solid #F0F6F7; }
.sched-rule { display: flex; align-items: center; justify-content: space-between; padding: 12px 0; border-bottom: 1px dashed #F0F6F7; }
.sched-rule:last-child { border-bottom: none; }
.sched-rule-info { display: flex; align-items: center; gap: 12px; flex: 1; }
.sched-rule-info i { color: #61D0DF; flex-shrink: 0; }
.sched-rule-info i, .sched-rule-info svg { width: 22px; height: 22px; }
.sched-rule-title { font-family: 'Noto Sans TC'; font-size: 13.5px; font-weight: 500; color: #2A3A38; line-height: 1.4; }
.sched-rule-sub { font-family: 'Noto Sans TC'; font-size: 11.5px; color: #6B7B7E; margin-top: 2px; }
.switch { position: relative; display: inline-block; width: 44px; height: 24px; flex-shrink: 0; }
.switch input { opacity: 0; width: 0; height: 0; }
.switch span { position: absolute; cursor: pointer; inset: 0; background: #E0E6E7; border-radius: 999px; transition: .2s; }
.switch span::before { content: ''; position: absolute; height: 18px; width: 18px; left: 3px; top: 3px; background: #fff; border-radius: 50%; transition: .2s; box-shadow: 0 1px 3px rgba(0,0,0,.15); }
.switch input:checked + span { background: #61D0DF; }
.switch input:checked + span::before { transform: translateX(20px); }

.sched-upcoming { display: flex; flex-direction: column; gap: 10px; }
.sched-event { display: flex; align-items: center; gap: 12px; padding: 10px 12px; background: #F4FCFD; border-radius: 8px; }
.sched-event i, .sched-event svg { width: 20px; height: 20px; color: #C9A96A; flex-shrink: 0; }
.sched-event div { display: flex; flex-direction: column; }
.sched-event strong { font-family: 'Noto Sans TC'; font-size: 13.5px; font-weight: 500; color: #2A3A38; }
.sched-event-meta { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 11.5px; color: #6B7B7E; margin-top: 2px; }
