:root{
  --bg:#f4f8fc;--side:#0b1324;--panel:#fff;--text:#132238;--muted:#64748b;--line:#d9e3ef;
  --primary:#18b9c7;--blue:#2563eb;--green:#16a34a;--red:#dc2626;--amber:#f59e0b;--purple:#7c3aed;
  --shadow:0 18px 40px rgba(15,23,42,.08);--radius:20px;
}
*{box-sizing:border-box}body{margin:0;background:var(--bg);font-family:"Microsoft JhengHei",Segoe UI,Arial,sans-serif;color:var(--text)}a{color:inherit}.layout{min-height:100vh}.side{position:fixed;left:0;top:0;bottom:0;width:245px;background:linear-gradient(180deg,#052f3c,#0b1324);color:white;padding:24px 16px;z-index:5}.brand{display:flex;align-items:center;gap:14px;padding-bottom:24px;border-bottom:1px solid rgba(255,255,255,.12)}.mark{width:46px;height:46px;border-radius:14px;background:linear-gradient(135deg,#2dd4bf,#2563eb);display:flex;align-items:center;justify-content:center;font-weight:900}.brand h1{font-size:25px;margin:0;letter-spacing:3px}.brand p{margin:4px 0 0;color:#bbd6e6;font-size:12px}.quick{color:#dff8ff;margin:24px 8px 12px;font-weight:700}.nav{display:grid;gap:10px}.nav a{text-decoration:none;padding:14px 16px;border:1px solid rgba(255,255,255,.12);border-radius:13px;background:rgba(255,255,255,.04);color:#e5f8ff;font-weight:700}.nav a.active,.nav a:hover{background:linear-gradient(135deg,#1ccad8,#0ea5b2);box-shadow:0 10px 24px rgba(14,165,178,.28)}.side-note{position:absolute;bottom:18px;left:16px;right:16px;color:#9db4c8;font-size:12px;line-height:1.7}.main{margin-left:245px;padding:34px;min-height:100vh}.top{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:18px}.title h2{font-size:32px;margin:0 0 8px}.title p{margin:0;color:var(--muted);font-size:15px}.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}.card.flat{box-shadow:none}.card h3{margin:0 0 16px;font-size:20px}.grid{display:grid;grid-template-columns:minmax(360px,560px) 1fr;gap:18px}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.field{margin-bottom:15px}.field label{display:block;font-size:14px;font-weight:800;margin:0 0 7px;color:#26425b}.input,select,textarea{width:100%;border:1px solid #cbd8e7;border-radius:12px;background:#fff;font-size:16px;padding:12px 14px;outline:none;transition:.18s}textarea{min-height:90px;resize:vertical}.input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 4px rgba(24,185,199,.12)}small{color:var(--muted);line-height:1.6}.btn{border:1px solid var(--line);background:#fff;border-radius:12px;padding:12px 18px;font-weight:900;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;color:#24364b}.btn:hover{filter:brightness(.98)}.btn.primary{background:linear-gradient(135deg,#2563eb,#1d4ed8);border-color:#1d4ed8;color:white}.btn.green{background:linear-gradient(135deg,#16a34a,#15803d);border-color:#15803d;color:white}.btn.danger{background:#fee2e2;color:#991b1b;border-color:#fecaca}.btn.refresh{background:#0f172a;color:white}.btn.soft{background:#e0f2fe;color:#075985;border-color:#bae6fd}.btn.ghost{background:#f8fafc}.btn.wide{width:100%}.btn:disabled{opacity:.65;cursor:not-allowed}.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.alert{display:none;border-radius:14px;padding:13px 15px;margin-bottom:14px;border:1px solid var(--line);background:#f8fafc;white-space:pre-wrap}.alert.ok{background:#ecfdf5;border-color:#bbf7d0;color:#166534}.alert.error{background:#fef2f2;border-color:#fecaca;color:#991b1b}.alert.warn{background:#fffbeb;border-color:#fde68a;color:#92400e}.alert.info{background:#eff6ff;border-color:#bfdbfe;color:#1e40af}.pill,.badge{display:inline-flex;align-items:center;border-radius:999px;padding:6px 10px;background:#e0f2fe;color:#075985;font-size:12px;font-weight:900}.pill.live{background:#ecfdf5;color:#166534}.badge.warn{background:#fef3c7;color:#92400e}.badge.ok{background:#dcfce7;color:#166534}.stat{font-size:38px;font-weight:900;letter-spacing:-1px}.tabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}.table-wrap{overflow:auto}.table{width:100%;border-collapse:collapse;background:white;border:1px solid var(--line);border-radius:14px;overflow:hidden}.table th,.table td{padding:12px 14px;border-bottom:1px solid var(--line);text-align:left;font-size:14px;white-space:nowrap}.table th{background:#f8fafc;color:#475569}.empty{padding:24px;color:var(--muted);text-align:center;border:1px dashed var(--line);border-radius:14px}.login-panel{position:fixed;inset:0;background:rgba(15,23,42,.55);display:none;align-items:center;justify-content:center;z-index:20;padding:18px}.login-box{width:min(460px,100%);background:white;border-radius:24px;padding:28px;box-shadow:0 24px 80px rgba(15,23,42,.28)}.login-box h1{margin:0 0 8px}.login-box p{margin:0 0 20px;color:var(--muted)}

/* 專業管理介面 */
.pro-main{background:radial-gradient(circle at top right,#e0f7ff 0,#f4f8fc 34%,#f4f8fc 100%)}.admin-hero{display:flex;align-items:center;justify-content:space-between;gap:20px;background:linear-gradient(135deg,#06233d,#0f766e);border-radius:28px;padding:30px;color:white;box-shadow:0 20px 55px rgba(15,23,42,.18);margin-bottom:18px}.admin-hero h2{font-size:34px;margin:8px 0}.admin-hero p{margin:0;color:#d9f4ff;line-height:1.7}.hero-kicker{display:inline-flex;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);border-radius:999px;padding:6px 12px;font-weight:800}.hero-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.metric-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:18px}.metric-card{border-radius:22px;background:white;padding:22px;box-shadow:var(--shadow);position:relative;overflow:hidden;border:1px solid var(--line)}.metric-card:after{content:"";position:absolute;right:-28px;top:-28px;width:100px;height:100px;border-radius:999px;opacity:.12}.metric-card.blue:after{background:var(--blue)}.metric-card.green:after{background:var(--green)}.metric-card.purple:after{background:var(--purple)}.metric-card.orange:after{background:var(--amber)}.metric-card span{color:#64748b;font-weight:900}.metric-card b{display:block;font-size:42px;line-height:1.1;margin-top:8px}.metric-card small{font-weight:700}.admin-panel{background:white;border:1px solid var(--line);border-radius:26px;padding:18px;box-shadow:var(--shadow)}.pro-tabs{display:flex;gap:8px;flex-wrap:wrap;background:#f8fafc;border:1px solid #e2e8f0;border-radius:18px;padding:8px}.tab-btn{border:0;border-radius:13px;padding:12px 16px;background:transparent;font-weight:900;color:#475569;cursor:pointer}.tab-btn.active{background:#2563eb;color:white;box-shadow:0 10px 22px rgba(37,99,235,.22)}.tab-body{padding:18px 2px 4px}.section-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:14px}.section-head h3{margin:0 0 6px;font-size:22px}.section-head p{margin:0;color:var(--muted)}.info-card ul{margin:0;padding-left:20px;line-height:2;color:#334155}.rule b{font-size:18px}.rule p{color:#64748b;line-height:1.8}.mini-btn{border:1px solid #cbd5e1;background:#fff;border-radius:10px;padding:7px 10px;font-weight:900;cursor:pointer}.mini-btn.danger{background:#fee2e2;color:#991b1b;border-color:#fecaca}.pro-login{text-align:left}.login-icon{width:54px;height:54px;border-radius:18px;background:linear-gradient(135deg,#2563eb,#14b8a6);color:white;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:900;margin-bottom:14px}

/* 手機優先發放頁 */
.issue-body{background:linear-gradient(180deg,#e0f7ff 0,#f6fbff 34%,#edf4fb 100%)}.phone-page{width:min(560px,100%);margin:0 auto;padding:18px 14px 34px}.issue-hero{text-align:center;padding:10px 4px 18px}.brand-logo{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.8);border:1px solid #dbeafe;border-radius:18px;padding:10px 14px;box-shadow:0 10px 28px rgba(14,116,144,.1)}.logo-mark{width:40px;height:40px;border-radius:14px;background:linear-gradient(135deg,#14b8a6,#2563eb);color:white;display:flex;align-items:center;justify-content:center;font-weight:900}.brand-logo strong{display:block;font-size:21px;letter-spacing:2px;color:#064e5b}.brand-logo span{display:block;font-size:11px;color:#64748b}.issue-hero h1{margin:18px 0 8px;font-size:28px;letter-spacing:-.5px}.issue-hero p{margin:0 auto;color:#475569;line-height:1.7;max-width:520px}.mobile-stack{display:grid;gap:14px}.step-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:9px}.step-strip div{background:white;border:1px solid #dbeafe;border-radius:16px;padding:12px 8px;text-align:center;box-shadow:0 8px 20px rgba(15,23,42,.05)}.step-strip b{width:26px;height:26px;border-radius:999px;background:#2563eb;color:white;display:inline-flex;align-items:center;justify-content:center;margin-bottom:5px}.step-strip span{display:block;font-size:12px;font-weight:900;color:#334155}.issue-card{border-radius:28px;padding:20px;border:1px solid #d5e5f5;box-shadow:0 20px 55px rgba(15,23,42,.12)}.card-title-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.card-title-row h3{margin:0;font-size:23px}.need{background:#fee2e2;color:#991b1b;border-radius:999px;padding:3px 8px;font-size:11px}.big-input,.issue-card select{font-size:18px;padding:15px 15px;border-radius:16px}.qty-buttons{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.qty-btn{border:1px solid #cbd5e1;background:#fff;border-radius:16px;padding:13px 6px;font-weight:900;color:#334155;cursor:pointer}.qty-btn.active{background:linear-gradient(135deg,#06b6d4,#2563eb);border-color:#2563eb;color:white;box-shadow:0 12px 24px rgba(37,99,235,.2)}.hidden-input{position:absolute;opacity:0;pointer-events:none;width:1px;height:1px}.mobile-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px}.mobile-actions .issue-main{grid-column:1/-1;background:linear-gradient(135deg,#06b6d4,#2563eb 55%,#7c3aed);color:white;border:0;border-radius:18px;font-size:18px;padding:16px 18px;box-shadow:0 16px 30px rgba(37,99,235,.26)}.mobile-actions .soft,.mobile-actions .ghost{border-radius:16px}.qr-card{display:grid;grid-template-columns:1fr 116px;align-items:center;gap:14px;border-radius:22px;padding:16px;background:rgba(255,255,255,.78);box-shadow:0 10px 30px rgba(15,23,42,.06)}.qr-card img{width:110px;height:110px;border-radius:18px;background:white;border:1px solid var(--line);padding:8px}.qr-text b{font-size:18px}.qr-text span{display:block;color:#64748b;line-height:1.6;margin-top:5px}.result-area{margin-top:16px}.customer-card{border-radius:28px}.success-panel{display:flex;align-items:center;gap:18px;background:#ecfdf5;border:1px solid #bbf7d0;border-radius:18px;padding:18px;margin-bottom:16px}.success-icon{width:48px;height:48px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:#16a34a;color:white;font-weight:900;font-size:24px}.customer-help{background:#eff6ff;border-left:5px solid var(--blue);border-radius:14px;padding:14px;margin:14px 0;color:#1e3a8a}.coupon-grid{display:grid;grid-template-columns:1fr;gap:16px}.coupon-card{background:white;border:1px solid var(--line);border-radius:22px;padding:14px;box-shadow:var(--shadow);text-align:center}.coupon-card img{width:100%;max-width:380px;border:1px solid var(--line);border-radius:14px;background:white}.coupon-meta{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:12px}.share-box{display:grid;grid-template-columns:1fr;gap:10px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:18px;padding:16px;margin-top:16px}.customer-help b,.share-box b{color:#0f172a}.claim-mode .phone-page{max-width:620px}

@media(max-width:1100px){.metric-grid{grid-template-columns:repeat(2,1fr)}.grid{grid-template-columns:1fr}.admin-hero{display:block}.hero-actions{justify-content:flex-start;margin-top:16px}}
@media(max-width:900px){.side{display:none}.main{margin-left:0;padding:20px}.grid,.grid2,.grid3,.grid4,.share-box{grid-template-columns:1fr}.top{display:block}.title h2{font-size:26px}.coupon-meta{display:block}.coupon-meta .btn{margin-top:8px;width:100%}.admin-hero h2{font-size:28px}}
@media(max-width:560px){.phone-page{padding:12px 10px 28px}.issue-hero h1{font-size:24px}.metric-grid{grid-template-columns:1fr}.admin-panel{padding:12px}.pro-tabs{overflow-x:auto;display:flex;flex-wrap:nowrap}.tab-btn{white-space:nowrap}.mobile-actions{grid-template-columns:1fr}.qr-card{grid-template-columns:1fr;text-align:center}.qr-card img{margin:0 auto}.table th,.table td{font-size:13px;padding:10px}.login-box{padding:22px}.brand-logo strong{font-size:18px}}

/* 2026-06 service issue page simplified: agency code -> auto vendor/type -> quantity + plate only */
.pro-issue-card{background:linear-gradient(180deg,#ffffff 0,#f8fbff 100%);border:1px solid #bfdbfe}
.agency-field{background:#f0f9ff;border:1px solid #bae6fd;border-radius:20px;padding:14px;margin-bottom:14px}
.code-row{display:grid;grid-template-columns:1fr 98px;gap:10px;align-items:center}
.code-input{text-transform:uppercase;font-weight:900;letter-spacing:.5px;background:white}
.code-check-btn{height:56px;border-radius:16px;border:0;background:linear-gradient(135deg,#0ea5e9,#2563eb);color:#fff;font-size:17px;font-weight:900;box-shadow:0 12px 24px rgba(37,99,235,.22)}
.code-check-btn:disabled{opacity:.65;box-shadow:none}
.verified-box{border:1px solid #bbf7d0;background:linear-gradient(180deg,#f0fdf4,#ffffff);border-radius:22px;padding:15px;margin:14px 0;box-shadow:0 12px 25px rgba(22,163,74,.08)}
.verified-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}.verified-head b{font-size:18px;color:#166534}.verified-head p{margin:3px 0 0;color:#64748b;font-size:13px}
.verified-icon{width:42px;height:42px;border-radius:16px;background:#16a34a;color:white;display:inline-flex;align-items:center;justify-content:center;font-weight:900;font-size:22px}
.readonly-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.readonly-grid label{font-size:13px;color:#475569;font-weight:900}.readonly-value{min-height:46px;border-radius:15px;background:white;border:1px solid #dbeafe;color:#0f172a;font-weight:900;padding:12px 13px;margin-top:5px;display:flex;align-items:center}
.stock-line{margin-top:12px;padding:10px 12px;border-radius:14px;background:#eff6ff;color:#1e3a8a;font-weight:800}.stock-line b{font-size:21px;color:#2563eb}
.plate-input{font-size:22px;font-weight:900;text-transform:uppercase;letter-spacing:1px;text-align:center;background:#fff}
@media(max-width:560px){.code-row{grid-template-columns:1fr}.code-check-btn{width:100%}.readonly-grid{grid-template-columns:1fr}.agency-field{padding:12px}.verified-box{padding:13px}.plate-input{text-align:left}}

/* password eye toggle */
.password-wrap{position:relative;display:flex;align-items:center;width:100%}
.password-wrap .input{padding-right:54px;width:100%}
.eye-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);border:0;background:linear-gradient(135deg,#e8f4ff,#dff7f6);color:#0f3d5f;border-radius:12px;width:38px;height:34px;cursor:pointer;font-size:17px;box-shadow:0 6px 16px rgba(15,61,95,.12)}
.eye-btn:hover{filter:brightness(.96);box-shadow:0 8px 20px rgba(15,61,95,.18)}

/* DB self-check panel */
.metric-grid.compact{grid-template-columns:repeat(4,1fr);margin:8px 0 16px}.metric-card.red:after{background:var(--red)}.metric-card.red b{color:#991b1b}.badge.bad{background:#fee2e2;color:#991b1b}.check-summary{margin:14px 0}.check-table{display:grid;gap:16px}.sub-title{font-size:18px;margin:20px 0 10px}.check-rules{margin-top:18px}.table td .badge{white-space:nowrap}
.form-save-note{background:#f8fafc;border:1px dashed #cbd5e1;border-radius:14px;padding:10px 12px;color:#475569;font-size:13px;margin-top:10px;line-height:1.6}
@media(max-width:760px){.metric-grid.compact{grid-template-columns:1fr 1fr}.section-head{display:block}.section-head .btn{margin-top:12px;width:100%}}

/* v1.7 發放安全保護 / 進度視窗 / 完成提示 */
.secure-code-input{font-family:"Microsoft JhengHei",Arial,sans-serif;-webkit-text-security:disc;text-security:disc;letter-spacing:4px}
.code-hidden-note{background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af;border-radius:14px;padding:10px 12px;margin-top:8px;font-weight:800;display:none}
.issue-progress-mask{position:fixed;inset:0;background:rgba(15,23,42,.64);z-index:200;display:none;align-items:center;justify-content:center;padding:18px;backdrop-filter:blur(8px)}
.issue-progress-card{width:min(440px,100%);background:#fff;border-radius:28px;padding:26px;box-shadow:0 32px 90px rgba(15,23,42,.36);text-align:center;border:1px solid #dbeafe}
.issue-spinner{width:68px;height:68px;border-radius:50%;border:7px solid #dbeafe;border-top-color:#2563eb;margin:0 auto 16px;animation:spin .9s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.issue-progress-card h2{margin:0 0 8px;font-size:26px;color:#102033}.issue-progress-card p{margin:0 0 15px;color:#475569;line-height:1.7}.issue-progress-bar{height:12px;background:#e0f2fe;border-radius:999px;overflow:hidden;margin:14px 0}.issue-progress-bar i{display:block;height:100%;width:12%;background:linear-gradient(90deg,#06b6d4,#2563eb,#7c3aed);border-radius:999px;transition:width .35s ease}.issue-progress-steps{display:grid;gap:8px;margin-top:14px;text-align:left}.issue-progress-steps div{display:flex;gap:10px;align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:10px;color:#475569;font-weight:800}.issue-progress-steps div.done{background:#ecfdf5;border-color:#bbf7d0;color:#166534}.issue-progress-steps div.active{background:#eff6ff;border-color:#bfdbfe;color:#1e40af}.issue-progress-steps b{width:24px;height:24px;border-radius:50%;background:#dbeafe;color:#1e40af;display:inline-flex;align-items:center;justify-content:center;flex:0 0 24px}.issue-progress-steps div.done b{background:#16a34a;color:#fff}.issue-lock-note{background:#fffbeb;border:1px solid #fde68a;color:#92400e;border-radius:16px;padding:12px 14px;font-weight:800;line-height:1.7;margin:12px 0}.copy-row{display:grid;grid-template-columns:1fr auto;gap:8px}.copy-row .btn{white-space:nowrap}.coupon-no{display:block;color:#1e40af;font-weight:900;margin-top:4px}.success-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}.success-actions .btn{width:100%}
@media(max-width:560px){.success-actions{grid-template-columns:1fr}.copy-row{grid-template-columns:1fr}.issue-progress-card{padding:22px}.issue-progress-card h2{font-size:23px}}
.issue-filter-grid{grid-template-columns:repeat(3,1fr)}
@media(max-width:900px){.issue-filter-grid{grid-template-columns:1fr}}

/* v1.9 前台統一提示視窗：正常綠、資料異常黃、警告紅 */
.front-notice-host{position:fixed;inset:0;background:rgba(15,23,42,.58);z-index:260;align-items:center;justify-content:center;padding:18px;backdrop-filter:blur(7px)}
.front-notice-card{width:min(420px,100%);background:#fff;border-radius:24px;box-shadow:0 28px 90px rgba(15,23,42,.34);overflow:hidden;border:1px solid #e2e8f0;animation:noticePop .18s ease-out}
@keyframes noticePop{from{opacity:.2;transform:translateY(12px) scale(.98)}to{opacity:1;transform:none}}
.front-notice-head{height:52px;display:flex;align-items:center;gap:10px;padding:0 16px;color:#fff;font-weight:900}.front-notice-head button{margin-left:auto;border:0;background:transparent;color:inherit;font-size:24px;line-height:1;cursor:pointer;opacity:.9}
.front-notice-card.ok .front-notice-head{background:#16a34a}.front-notice-card.warn .front-notice-head{background:#f59e0b}.front-notice-card.error .front-notice-head{background:#dc2626}.front-notice-card.info .front-notice-head{background:#2563eb}
.front-notice-icon{width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.22);font-weight:900;flex:0 0 28px}
.front-notice-body{text-align:center;padding:24px 22px 8px}.front-big-icon{width:72px;height:72px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:34px;font-weight:900}.front-notice-card.ok .front-big-icon{background:#dcfce7;color:#16a34a}.front-notice-card.warn .front-big-icon{background:#fef3c7;color:#b45309}.front-notice-card.error .front-big-icon{background:#fee2e2;color:#dc2626}.front-notice-card.info .front-big-icon{background:#dbeafe;color:#2563eb}.front-notice-body h3{margin:0 0 8px;font-size:22px;color:#0f172a}.front-notice-body p{margin:0;color:#334155;line-height:1.75;white-space:pre-wrap}.front-notice-body pre{text-align:left;white-space:pre-wrap;background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:12px;margin:14px 0 0;max-height:180px;overflow:auto;color:#475569;font-family:"Microsoft JhengHei",Consolas,monospace;font-size:13px}.front-notice-actions{display:flex;justify-content:center;padding:12px 22px 22px}.front-notice-actions .btn{min-width:120px}
.loading-card{text-align:center;color:#475569;font-weight:900}.claim-success-panel{margin-top:10px}.claim-mode .success-actions,.claim-mode .share-box{display:none!important}.claim-mode .coupon-card{max-width:420px;margin:0 auto}.claim-mode .coupon-card img{max-width:360px}.claim-mode .coupon-grid{margin-top:14px}.claim-mode .customer-help{font-size:14px;line-height:1.75}.issue-body .alert.ok{display:none!important}
.table td{max-width:none}.table td:nth-child(9){white-space:normal;word-break:break-all;min-width:160px}


/* v2.0 2026-06-18 視覺校正 */
.issue-body{background:linear-gradient(180deg,#dff4ff 0,#eef8ff 34%,#edf5fb 100%)}
.issue-hero{padding:12px 4px 14px}
.brand-logo.image-only{display:inline-flex;justify-content:center;align-items:center;padding:12px 18px;border-radius:18px;background:rgba(255,255,255,.88)}
.brand-logo.image-only img{display:block;width:min(280px,72vw);height:auto}
.issue-hero h1{margin:16px 0 6px;font-size:32px;font-weight:900;color:#17324e}
.issue-hero p{font-size:15px;color:#51657c;max-width:420px}
.claim-mode .issue-hero{padding-bottom:8px}
.claim-mode .issue-hero h1{font-size:26px;margin-top:14px}
.claim-mode .issue-hero p{display:none}
.card-title-row:has(.pill.live){justify-content:flex-start}
.agency-field label{font-size:15px;color:#1e3a8a}
.code-hidden-note{font-size:13px}
.customer-help{background:linear-gradient(180deg,#f8fbff 0,#eef4ff 100%);border:1px solid #bfdbfe;border-left:5px solid #2563eb;border-radius:16px;padding:16px 18px;margin:14px 0 18px;color:#c81e1e;font-size:18px;line-height:1.85;font-family:"Microsoft JhengHei","微軟正黑體",sans-serif;box-shadow:0 10px 24px rgba(37,99,235,.08)}
.customer-help b{display:block;margin-bottom:6px;color:#1e40af;font-size:16px}
.claim-mode .customer-help{font-size:18px;line-height:1.85}
.claim-mode .customer-card{padding-top:8px}
.claim-mode .coupon-grid{margin-top:10px}
.claim-mode .coupon-card{max-width:430px;margin:0 auto;border-radius:20px;padding:14px 14px 12px}
.claim-mode .coupon-card img{max-width:360px}
.success-panel{border-radius:20px;padding:18px 16px 18px 14px}
.success-panel h2{margin:0 0 8px;font-size:22px;color:#17324e}
.success-panel p{margin:6px 0;color:#24364b;line-height:1.6}
.qr-card{display:none!important}
.side .brand.image-brand,.bo-logo{display:flex;align-items:center;justify-content:flex-start;background:none!important;border-bottom:1px solid rgba(255,255,255,.14);padding-bottom:20px}
.brand-side-logo{display:block;width:158px;height:auto;filter:brightness(0) invert(1)}
.bo-logo{padding:8px 10px 22px!important}
.bo-logo-img{display:block;width:168px;height:auto;filter:brightness(0) invert(1)}
.front-notice-card{border-radius:26px;overflow:hidden}
.front-notice-head{height:54px;font-size:16px}
.front-notice-body{padding:22px 24px 10px}
.front-notice-body h3{font-size:26px}
.front-notice-body p{font-size:17px;line-height:1.8}
.front-notice-actions{padding-bottom:24px}
.front-notice-actions .btn{min-width:132px;border-radius:14px}
@media(max-width:560px){
  .brand-logo.image-only img{width:min(235px,76vw)}
  .issue-hero h1{font-size:22px}
  .customer-help,.claim-mode .customer-help{font-size:16px;padding:14px 14px}
  .customer-help b{font-size:15px}
  .bo-logo-img{width:150px}
}


/* ================================
   客戶取券完成頁 - 上線固定版
   目的：LOGO 放入綠色完成框、移除「我的折扣券」、移除「給客人操作：」字眼
   ================================ */
.claim-mode .issue-hero{
  display:none!important;
}
.claim-mode .phone-page{
  max-width:620px;
  padding-top:18px;
}
.claim-mode .customer-card{
  border-radius:28px;
  border:1px solid #dbeafe;
  background:rgba(255,255,255,.94);
  box-shadow:0 18px 48px rgba(15,23,42,.10);
}
.claim-mode .claim-success-panel{
  display:block;
  background:#e9fff3;
  border:1px solid #b7f0d0;
  border-radius:18px;
  padding:18px 20px;
  margin:4px 0 14px;
  box-shadow:none;
}
.claim-success-logo-wrap{
  text-align:center;
  margin:0 0 14px;
}
.claim-success-logo{
  display:inline-block;
  width:min(300px,88%);
  height:auto;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
}
.success-main-row{
  display:flex;
  align-items:center;
  gap:14px;
}
.claim-mode .claim-success-panel h2{
  margin:0 0 8px;
  font-size:20px;
  font-weight:900;
  color:#17324e;
}
.claim-mode .claim-success-panel p{
  margin:6px 0;
  color:#24364b;
  line-height:1.65;
}
.claim-mode .customer-help{
  background:linear-gradient(180deg,#f8fbff 0,#eef4ff 100%);
  border:1px solid #bfdbfe;
  border-left:5px solid #2563eb;
  border-radius:16px;
  padding:16px 18px;
  margin:14px 0 18px;
  color:#c81e1e;
  font-size:18px;
  line-height:1.85;
  font-family:"Microsoft JhengHei","微軟正黑體",sans-serif;
  box-shadow:0 10px 24px rgba(37,99,235,.08);
}
.claim-mode .customer-help b{
  display:none!important;
}
@media(max-width:560px){
  .claim-mode .phone-page{padding:14px 10px 28px;}
  .claim-success-logo{width:min(270px,90%);}
  .success-main-row{gap:12px;}
  .claim-mode .claim-success-panel{padding:16px 14px;}
  .claim-mode .claim-success-panel h2{font-size:18px;}
  .claim-mode .claim-success-panel p{font-size:14px;}
  .claim-mode .customer-help{font-size:16px;padding:14px 14px;}
}
