:root{
  --navy:#0a1120;
  --navy-2:#141f38;
  --navy-3:#1c2b4a;
  --gold:#c9a227;
  --gold-light:#f0d78c;
  --gold-deep:#8a6d1a;
  --cream:#f7f5ef;
  --ink:#1c1c1c;
  --line:#e4dfd0;
  --danger:#c0392b;
  --success:#1e6b46;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;font-family:"Noto Sans TC","PingFang TC","Microsoft JhengHei",sans-serif;background:var(--cream);color:var(--ink);}
.wrap{max-width:1180px;margin:0 auto;}
a{color:inherit;}
button{font-family:inherit;cursor:pointer;}
input,select,textarea{font-family:inherit;}
img{max-width:100%;display:block;}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;}
}

/* ---------- HEADER ---------- */
.site-header{background:var(--navy);color:#fff;padding:18px 24px;display:flex;align-items:center;gap:14px;max-width:1180px;margin:0 auto;}
.logo-badge{width:46px;height:46px;flex-shrink:0;}
.brand-name{font-family:"Noto Serif TC",serif;font-size:21px;font-weight:900;letter-spacing:2px;color:var(--gold-light);}
.brand-sub{font-size:11px;color:#b9c0cf;letter-spacing:2px;}

/* ---------- HERO ---------- */
.hero-section{
  position:relative;
  background:linear-gradient(155deg,var(--navy) 0%,var(--navy-2) 55%,var(--navy-3) 100%);
  overflow:hidden;
  padding-bottom:64px;
}
.hero-section::before{
  /* faint diagonal gold seam, signature structural device */
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(115deg, transparent 62%, rgba(201,162,39,.10) 63%, rgba(201,162,39,.10) 64%, transparent 65%);
  pointer-events:none;
}
.coin-motif{
  position:absolute; right:-40px; top:-30px; width:360px; height:360px; opacity:.16;
  pointer-events:none;
}
@media (max-width:880px){ .coin-motif{width:220px;height:220px;right:-60px;top:-20px;} }

.hero-row{
  position:relative; z-index:1;
  display:grid;grid-template-columns:1.15fr 380px;gap:28px;
  max-width:1180px;margin:0 auto;
  padding:36px 24px 0;
}
@media (max-width:880px){ .hero-row{grid-template-columns:1fr;padding:24px 16px 0;} }

.hero-content{color:#fff;}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;letter-spacing:3px;color:var(--gold-light);
  text-transform:uppercase;margin-bottom:14px;
  opacity:0; animation:fadeUp .6s ease forwards;
}
.hero-eyebrow::before{content:"";width:22px;height:1px;background:var(--gold);display:inline-block;}

.hero-kicker{font-size:19px;color:#dfe2e8;margin:0 0 8px;font-weight:500;
  opacity:0; animation:fadeUp .6s ease .08s forwards;}

.hero-title{
  font-family:"Noto Serif TC",serif;
  font-size:clamp(32px,5vw,48px);font-weight:900;line-height:1.2;margin:0 0 2px;letter-spacing:1px;
  background:linear-gradient(135deg,var(--gold-light),var(--gold) 60%,var(--gold-deep));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 2px 24px rgba(201,162,39,.25);
  opacity:0; animation:fadeUp .6s ease .16s forwards;
}
.hero-title2{
  font-family:"Noto Serif TC",serif;
  font-size:clamp(22px,3.2vw,30px);font-weight:700;color:#fff;margin:0 0 22px;letter-spacing:1px;
  opacity:0; animation:fadeUp .6s ease .24s forwards;
}

.strip-bar{
  display:inline-flex;flex-wrap:wrap;align-items:center;gap:10px;
  border:1px solid rgba(201,162,39,.55);
  background:rgba(201,162,39,.08);
  color:var(--gold-light);font-weight:700;font-size:13.5px;
  padding:11px 18px;border-radius:999px;margin-bottom:22px;letter-spacing:.3px;
  opacity:0; animation:fadeUp .6s ease .32s forwards;
}
.strip-bar .dot{width:4px;height:4px;border-radius:50%;background:var(--gold);display:inline-block;}

.hero-desc{
  font-size:14.5px;line-height:2;color:#d7dbe3;max-width:520px;
  opacity:0; animation:fadeUp .6s ease .4s forwards;
}
.hero-desc strong{color:var(--gold-light);font-weight:700;}

@keyframes fadeUp{ from{opacity:0;transform:translateY(14px);} to{opacity:1;transform:translateY(0);} }

.trust-emblem{
  position:absolute; top:30px; right:calc(380px + 46px);
  width:118px; text-align:center;
  opacity:0; animation:fadeUp .6s ease .5s forwards;
  display:none;
}
@media (min-width:1020px){ .trust-emblem{display:block;} }
.trust-emblem svg{width:56px;height:56px;margin-bottom:6px;}
.trust-emblem span{display:block;font-size:11.5px;font-weight:700;color:var(--gold-light);line-height:1.6;letter-spacing:.5px;}

/* ---------- FORM CARD ---------- */
.form-card{
  position:relative; z-index:1;
  background:#fff;border-radius:18px;box-shadow:0 24px 60px rgba(0,0,0,.4);
  padding:24px 22px 26px;align-self:start;
  border-top:3px solid var(--gold);
}
@media (min-width:881px){.form-card{margin-top:6px;}}
.form-card h2{text-align:center;font-family:"Noto Serif TC",serif;font-size:19px;font-weight:900;margin:2px 0 18px;color:var(--navy);}
.form-card h2::before,.form-card h2::after{content:"";display:inline-block;width:26px;height:2px;background:var(--gold);vertical-align:middle;margin:0 8px 3px;}
.field{margin-bottom:12px;}
.field label{display:block;font-size:13px;font-weight:700;color:var(--navy);margin-bottom:4px;}
.field input[type=text],.field input[type=tel],.field input[type=date],.field input[type=number],.field select,.field textarea{
  width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:8px;font-size:13.5px;background:#fbfaf6;color:var(--ink);}
.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--gold);outline-offset:1px;background:#fff;}
.field textarea{resize:vertical;min-height:64px;}
.radio-row{display:flex;gap:16px;font-size:13.5px;padding-top:2px;flex-wrap:wrap;}
.radio-row label{display:flex;align-items:center;gap:5px;font-weight:500;color:var(--ink);}
.hp-field{position:absolute;left:-9999px;top:-9999px;} /* honeypot */
.submit-btn{width:100%;background:linear-gradient(135deg,var(--gold-light),var(--gold));border:none;color:var(--navy);
  font-weight:900;font-size:15px;padding:13px;border-radius:10px;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:6px;
  box-shadow:0 8px 18px rgba(201,162,39,.4);}
.submit-btn:hover{filter:brightness(1.05);}
.privacy-note{font-size:11px;color:#8a8a8a;margin-top:10px;line-height:1.6;text-align:center;}
.alert{padding:12px;border-radius:8px;font-size:13.5px;margin-bottom:12px;font-weight:700;text-align:center;}
.alert-success{background:#eafaf1;border:1px solid #58c48a;color:var(--success);}
.alert-error{background:#fdecea;border:1px solid #f1a29b;color:var(--danger);}

/* ---------- GENERIC SECTIONS ---------- */
.section{padding:44px 24px;max-width:1000px;margin:0 auto;}
.section-title{text-align:center;font-family:"Noto Serif TC",serif;font-size:23px;font-weight:900;color:var(--navy);margin:0 0 26px;position:relative;}
.section-title::before,.section-title::after{content:"";display:inline-block;width:34px;height:3px;background:var(--gold);vertical-align:middle;margin:0 10px 4px;}

.targets-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px 14px;}
@media (max-width:700px){.targets-grid{grid-template-columns:repeat(2,1fr);}}
.target-item{text-align:center;}
.target-icon{width:66px;height:66px;border-radius:50%;background:radial-gradient(circle at 35% 30%,var(--gold-light),var(--gold));
  display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 8px;box-shadow:0 6px 14px rgba(201,162,39,.35);}
.target-item span{font-size:13px;font-weight:700;color:var(--navy);}

.callout-bar{background:var(--navy);color:var(--gold-light);text-align:center;font-weight:800;font-size:14.5px;
  padding:14px;border-radius:10px;margin-top:30px;}

.adv-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;}
@media (max-width:700px){.adv-grid{grid-template-columns:1fr;}}
.adv-item{display:flex;gap:14px;align-items:flex-start;}
.adv-icon{width:52px;height:52px;border-radius:12px;background:var(--navy);color:var(--gold-light);
  display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;}
.adv-item h3{margin:2px 0 4px;font-size:15.5px;color:var(--navy);}
.adv-item p{margin:0;font-size:13px;color:#666;line-height:1.6;}

.dark-banner{background:var(--navy);color:#fff;text-align:center;padding:50px 24px;}
.dark-banner .shield{font-size:34px;margin-bottom:10px;}
.dark-banner p.small{color:#c8c8c8;font-size:13.5px;margin:6px 0;}
.dark-banner h3{font-family:"Noto Serif TC",serif;color:var(--gold-light);font-size:22px;margin:4px 0;font-weight:900;}

.site-footer{background:var(--navy-2);color:#fff;padding:26px 20px;text-align:center;}
.footer-row{display:flex;justify-content:center;gap:34px;flex-wrap:wrap;margin-bottom:14px;}
.footer-item{font-size:13.5px;color:#eee;}
.footer-item strong{display:block;font-size:16px;color:var(--gold-light);margin-bottom:2px;}
.line-btn{display:inline-block;background:var(--gold);color:var(--navy);font-weight:800;font-size:12.5px;
  padding:6px 14px;border-radius:6px;margin-top:4px;}
.footer-bottom{font-size:12px;color:#999;border-top:1px solid #2a3450;padding-top:14px;}

/* ---------- ADMIN ---------- */
.admin-wrap{min-height:100vh;background:var(--cream);}
.admin-login-box{max-width:360px;margin:80px auto;background:#fff;padding:34px 30px;border-radius:14px;box-shadow:0 12px 30px rgba(0,0,0,.12);}
.admin-login-box h2{text-align:center;color:var(--navy);margin-top:0;font-family:"Noto Serif TC",serif;}
.admin-login-box .field{margin-bottom:14px;}
.admin-login-box input{width:100%;padding:10px;border:1px solid var(--line);border-radius:8px;font-size:14px;}
.admin-login-box button{width:100%;background:var(--navy);color:#fff;border:none;padding:11px;border-radius:8px;font-weight:800;margin-top:6px;}
.login-error{color:var(--danger);font-size:13px;text-align:center;margin-top:8px;}
.back-link{display:block;text-align:center;margin-top:16px;font-size:12.5px;color:#888;}

.admin-top{background:var(--navy);color:#fff;padding:16px 24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;}
.admin-top h1{font-size:17px;margin:0;color:var(--gold-light);font-family:"Noto Serif TC",serif;}
.admin-actions{display:flex;gap:10px;}
.admin-actions a,.admin-actions button{background:transparent;border:1px solid var(--gold);color:var(--gold-light);padding:7px 14px;border-radius:7px;font-size:13px;font-weight:700;text-decoration:none;display:inline-block;}
.admin-actions a:hover,.admin-actions button:hover{background:var(--gold);color:var(--navy);}
.admin-body{padding:20px;max-width:1300px;margin:0 auto;}
.admin-toolbar{display:flex;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap;align-items:center;}
.admin-toolbar form{display:flex;gap:8px;}
.admin-toolbar input[type=text]{padding:9px 12px;border:1px solid var(--line);border-radius:8px;min-width:220px;font-size:13.5px;}
.admin-toolbar button{padding:9px 14px;border:1px solid var(--navy);background:var(--navy);color:#fff;border-radius:8px;font-size:13px;font-weight:700;}
.admin-count{font-size:13px;color:#666;font-weight:700;}
table.subs{width:100%;border-collapse:collapse;background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 4px 14px rgba(0,0,0,.06);font-size:13px;}
table.subs th{background:var(--navy);color:#fff;text-align:left;padding:10px 12px;font-size:12.5px;white-space:nowrap;}
table.subs td{padding:10px 12px;border-bottom:1px solid #f0eee5;white-space:nowrap;}
table.subs tr:hover td{background:#faf8f0;}
.row-actions{display:flex;gap:4px;}
.row-actions button,.row-actions a{border:none;background:none;font-size:15px;padding:2px 5px;cursor:pointer;}
.empty-state{text-align:center;padding:60px 20px;color:#999;}
.table-scroll{overflow-x:auto;border-radius:10px;}
.pagination{display:flex;justify-content:center;gap:6px;margin-top:18px;}
.pagination a{padding:7px 12px;border:1px solid var(--line);border-radius:6px;font-size:13px;background:#fff;text-decoration:none;color:var(--ink);}
.pagination a.active{background:var(--navy);color:#fff;border-color:var(--navy);}

.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:50;padding:20px;}
.modal-box{background:#fff;border-radius:14px;padding:26px;max-width:480px;width:100%;max-height:85vh;overflow-y:auto;}
.modal-box h3{margin-top:0;color:var(--navy);font-family:"Noto Serif TC",serif;}
.modal-box dl{margin:0;}
.modal-box dt{font-size:12px;color:#888;margin-top:10px;font-weight:700;}
.modal-box dd{margin:2px 0 0;font-size:14px;color:var(--ink);}
.modal-close{width:100%;margin-top:18px;background:var(--navy);color:#fff;border:none;padding:10px;border-radius:8px;font-weight:700;cursor:pointer;}
