/* ============================================================
   鮮味鄉海產 — 設計系統 v2「老舖職人 × 漁市標籤」
   暖紙白底・墨藍字・烏魚子琥珀・印章紅（僅價格與印鑑使用）
   字體：Noto Serif TC（標題）/ Noto Sans TC（內文）/ IBM Plex Mono（標籤）
   簽名元素：紅印章、直排文字欄、漁市標籤式商品卡、單線浪紋
   ============================================================ */
:root{
  --paper:#FAF7F0; --white:#FFFEFB;
  --deep:#0B2B42; --tide:#004B84; --sky:#3E7CB1;
  --roe:#C07A1E; --roe-l:#F3E4C6;
  --seal:#B50706; --seal-d:#8C0504;
  --ink:#1C2E3D; --ink2:#5B6B77; --line:#DCD4C3; --line2:#C7CFD6;
  --r:6px;
  --font:'Noto Sans TC',-apple-system,'PingFang TC','Microsoft JhengHei',sans-serif;
  --serif:'Noto Serif TC','PMingLiU',serif;
  --mono:'IBM Plex Mono','Courier New',monospace;
  /* 相容舊變數名 */
  --ice:var(--paper); --spring:var(--sky); --coral:var(--seal); --coral-d:var(--seal-d);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font);color:var(--ink);background:var(--paper);line-height:1.85;font-size:16px;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:var(--font);cursor:pointer}
.wrap{max-width:1140px;margin:0 auto;padding:0 24px}
.brush{font-family:var(--serif);font-weight:900}

/* ---------- 印章（簽名元素） ---------- */
.seal{display:inline-grid;place-items:center;width:34px;height:34px;background:var(--seal);color:#fff;
  font-family:var(--serif);font-weight:900;font-size:16px;line-height:1;border-radius:4px;
  transform:rotate(-4deg);letter-spacing:0;box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.35)}
.seal.lg{width:46px;height:46px;font-size:21px}

/* ---------- 標籤 ---------- */
.tag-temp{font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;color:var(--ink2);
  border:1px solid var(--line);background:transparent;padding:2px 9px;display:inline-flex;align-items:center;gap:6px}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.3em;color:var(--roe);text-transform:uppercase;margin-bottom:14px}
.vtext{writing-mode:vertical-rl;font-family:var(--serif);font-weight:700;letter-spacing:.5em;color:var(--ink2)}

/* ---------- Header ---------- */
.topbar{background:var(--deep);color:#C8D6E2;font-size:12.5px;text-align:center;padding:8px 14px;
  font-family:var(--mono);letter-spacing:.08em}
.topbar b{color:#fff;font-weight:600}
header.site{position:sticky;top:0;z-index:50;background:rgba(250,247,240,.95);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:30px;height:72px}
.logo{display:flex;align-items:center;gap:12px;font-family:var(--serif);font-weight:900;font-size:23px;color:var(--deep);letter-spacing:.1em}
.logo .mark{width:44px;height:44px;border-radius:50%;object-fit:cover;background:#fff}
.logo small{font-family:var(--mono);font-weight:400;font-size:9.5px;color:var(--ink2);letter-spacing:.28em;display:block;line-height:1.6}
.nav-links{display:flex;gap:26px;margin-left:auto;font-weight:500;font-size:15px;letter-spacing:.04em}
.nav-links a{padding:4px 0;border-bottom:1.5px solid transparent;transition:.2s}
.nav-links a:hover,.nav-links a.on{color:var(--tide);border-color:var(--tide)}
.cart-btn{position:relative;display:grid;place-items:center;width:42px;height:42px;border:1px solid var(--line);
  background:var(--white);transition:.2s;color:var(--deep)}
.cart-btn:hover{border-color:var(--tide);color:var(--tide)}
.cart-btn svg{width:20px;height:20px}
.cart-badge{position:absolute;top:-7px;right:-7px;min-width:18px;height:18px;background:var(--seal);color:#fff;
  font-size:11px;font-weight:700;display:none;align-items:center;justify-content:center;padding:0 5px;font-family:var(--mono)}
.menu-toggle{display:none;margin-left:auto;background:none;border:0;font-size:24px;color:var(--deep)}

/* ---------- 按鈕 ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid transparent;border-radius:var(--r);
  font-weight:600;font-size:15px;padding:13px 32px;transition:.2s;letter-spacing:.08em}
.btn-coral{background:var(--deep);color:#fff}
.btn-coral:hover{background:var(--tide)}
.btn-ghost{background:transparent;color:var(--deep);border-color:var(--ink2)}
.btn-ghost:hover{border-color:var(--tide);color:var(--tide)}
.btn-deep{background:var(--tide);color:#fff}
.btn-deep:hover{background:var(--deep)}
.btn-sm{padding:9px 20px;font-size:13.5px}
.btn[disabled]{opacity:.45;pointer-events:none}

/* ---------- 單線浪紋分隔 ---------- */
.waveline{display:block;width:100%;height:26px;color:var(--line2)}

/* ---------- 商品卡：漁市標籤 ---------- */
.grid-products{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:22px}
.card-p{background:var(--white);border:1px solid var(--line);transition:.22s;display:flex;flex-direction:column;position:relative}
.card-p:hover{border-color:var(--deep);transform:translateY(-3px);box-shadow:0 14px 34px rgba(11,43,66,.10)}
.card-p .ph{aspect-ratio:4/3;display:grid;place-items:center;font-size:58px;position:relative;border-bottom:1px solid var(--line)}
.ph.g1{background:linear-gradient(160deg,#F6ECD7,#EDDDB9)}
.ph.g2{background:linear-gradient(160deg,#E8EEF1,#D7E2E9)}
.ph.g3{background:linear-gradient(160deg,#E9EDF4,#D9E0EC)}
.ph.g4{background:linear-gradient(160deg,#F4EEDF,#EAE0C5)}
.ph.g5{background:linear-gradient(160deg,#EBEFE6,#DCE4D2)}
.badge-hot{position:absolute;top:10px;right:10px;width:36px;height:36px;background:var(--seal);color:#fff;
  font-family:var(--serif);font-weight:900;font-size:13px;display:grid;place-items:center;line-height:1.1;
  border-radius:4px;transform:rotate(4deg);box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.35);letter-spacing:0;padding:2px}
.card-p .no{position:absolute;top:10px;left:12px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--ink2)}
.card-p .body{padding:16px 18px 18px;display:flex;flex-direction:column;gap:7px;flex:1}
.card-p h3{font-family:var(--serif);font-size:18px;font-weight:700;color:var(--deep);letter-spacing:.04em}
.card-p .spec{font-size:13px;color:var(--ink2)}
.card-p .meta{display:flex;gap:6px;flex-wrap:wrap}
.card-p .foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px dashed var(--line)}
.price{font-family:var(--mono);font-weight:600;font-size:18px;color:var(--seal)}
.add-btn{width:38px;height:38px;border:1px solid var(--deep);background:transparent;color:var(--deep);font-size:18px;transition:.18s;border-radius:var(--r)}
.add-btn:hover{background:var(--deep);color:#fff}

/* ---------- 區塊 ---------- */
.section{padding:84px 0}
.sec-head{margin-bottom:42px}
.sec-head h2{font-family:var(--serif);font-size:clamp(26px,3.4vw,36px);font-weight:900;color:var(--deep);letter-spacing:.08em}
.sec-head p{color:var(--ink2);margin-top:10px;max-width:600px;font-size:15.5px}

/* ---------- FAQ ---------- */
.faq{max-width:760px;margin:0 auto}
.faq details{background:transparent;border-bottom:1px solid var(--line);overflow:hidden}
.faq details:first-of-type{border-top:1px solid var(--line)}
.faq summary{cursor:pointer;list-style:none;font-weight:600;padding:20px 4px;color:var(--deep);
  display:flex;justify-content:space-between;align-items:center;font-size:16.5px;letter-spacing:.03em}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'＋';color:var(--roe);font-size:17px;font-weight:400}
.faq details[open] summary::after{content:'－'}
.faq .a{padding:0 4px 22px;color:var(--ink2);font-size:15px;max-width:660px}

/* ---------- Footer ---------- */
footer.site{background:var(--deep);color:#A8BCCB;padding:60px 0 30px}
footer.site .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:38px}
footer.site h4{color:#fff;font-family:var(--serif);font-size:16px;margin-bottom:16px;font-weight:700;letter-spacing:.12em}
footer.site a{display:block;padding:4px 0;font-size:14.5px;transition:.2s}
footer.site a:hover{color:#fff}
footer.site .fine{border-top:1px solid rgba(255,255,255,.12);padding-top:22px;font-size:12.5px;
  font-family:var(--mono);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;letter-spacing:.06em}

/* ---------- 表單 ---------- */
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;font-size:14px;margin-bottom:6px;color:var(--deep);letter-spacing:.04em}
.field input,.field select,.field textarea{width:100%;border:1px solid var(--line);border-radius:var(--r);
  padding:11px 14px;font-size:15px;font-family:var(--font);background:var(--white);transition:.2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--tide);box-shadow:0 0 0 3px rgba(0,75,132,.10)}

/* ---------- 通用 ---------- */
.panel{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:28px}
.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--deep);color:#fff;
  padding:12px 28px;font-size:14px;opacity:0;pointer-events:none;transition:.3s;z-index:99;letter-spacing:.05em;border-radius:var(--r)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
:focus-visible{outline:2px solid var(--tide);outline-offset:2px}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ---------- RWD ---------- */
@media (max-width:860px){
  .nav-links{position:fixed;inset:72px 0 auto 0;background:var(--paper);flex-direction:column;gap:0;
    padding:8px 24px 18px;border-bottom:1px solid var(--line);display:none}
  .nav-links.open{display:flex}
  .nav-links a{padding:13px 0;border-bottom:1px solid var(--line)}
  .menu-toggle{display:block}
  footer.site .cols{grid-template-columns:1fr}
  .section{padding:56px 0}
}
