* { margin: 0; padding: 0; box-sizing: border-box; }
:root { --c: #14666b; --c2: #0e4a4e; --bg: #f6f9f9; --line: #dce6e6; --warn: #b03a2e; }
body { font-family: "PingFang TC", "Noto Sans TC", sans-serif; background: var(--bg); color: #1e2b2b; line-height: 1.65; }
.wrap { max-width: 720px; margin: 0 auto; padding: 0 16px; }
.top { background: var(--c); color: #fff; padding: 14px 0; }
.top .brand { font-weight: 700; font-size: 17px; }
.top .doctor { font-size: 13px; opacity: .85; }
main { padding: 20px 16px 40px; }
h1 { font-size: 24px; color: var(--c2); margin: 14px 0 8px; }
h3 { color: var(--c2); margin: 22px 0 8px; }
.lead { color: #445; margin-bottom: 14px; }
.fine { font-size: 12.5px; color: #667; }
a { color: var(--c); }

.notice { background: #fef9e7; border: 1px solid #f0e0a0; border-radius: 10px; padding: 12px 14px; margin: 12px 0; font-size: 14.5px; }
.notice.nhb { background: #eaf4f4; border-color: #bcd8d8; }
.notice.err { background: #fdedec; border-color: #e6b0aa; color: var(--warn); }

.pricebox, .card { background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 14px 16px; margin: 12px 0; }
.pricebox .row, .card .row { display: flex; justify-content: space-between; gap: 12px; padding: 6px 0; border-bottom: 1px dashed var(--line); }
.pricebox .row:last-of-type, .card .row:last-of-type { border-bottom: 0; }

.choose { display: flex; flex-direction: column; gap: 10px; margin: 18px 0; }
.btn { display: block; text-align: center; background: var(--c); color: #fff; text-decoration: none; border: 0; border-radius: 12px; padding: 12px 16px; font-size: 16px; cursor: pointer; }
.btn.big { padding: 16px; font-size: 18px; font-weight: 700; width: 100%; }
.btn.big .sub { display: block; font-size: 13px; font-weight: 400; opacity: .85; }
.btn.alt { background: #fff; color: var(--c); border: 2px solid var(--c); }
.btn.danger { background: var(--warn); }
.btn.submit { margin-top: 18px; }

.steps { display: flex; gap: 8px; font-size: 13px; color: #889; margin-top: 10px; }
.steps span { background: #fff; border: 1px solid var(--line); border-radius: 20px; padding: 3px 12px; }
.steps .on { background: var(--c); color: #fff; border-color: var(--c); }
.steps .done { color: var(--c); border-color: var(--c); }

.pills { display: flex; flex-wrap: wrap; gap: 8px; margin: 10px 0; }
.pill { background: #fff; border: 1.5px solid var(--line); border-radius: 22px; padding: 8px 16px; font-size: 15px; cursor: pointer; text-decoration: none; color: #1e2b2b; }
.pill.sel, .pill.radio:has(input:checked) { background: var(--c); color: #fff; border-color: var(--c); }
.pill.time { min-width: 76px; text-align: center; font-weight: 600; }
.pill input { position: absolute; opacity: 0; }
.pill.radio { position: relative; }

fieldset { background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 14px 16px 16px; margin: 14px 0; }
fieldset.warn { border-color: #e6b0aa; background: #fffafa; }
legend { font-weight: 700; color: var(--c2); padding: 0 6px; }
label { display: block; margin: 10px 0 4px; font-size: 15px; }
input, textarea, select { width: 100%; padding: 10px 12px; border: 1.5px solid var(--line); border-radius: 10px; font-size: 16px; font-family: inherit; margin-top: 4px; }
input:focus, textarea:focus { outline: none; border-color: var(--c); }
.chk { display: flex; gap: 10px; align-items: flex-start; font-size: 14.5px; }
.chk input { width: 20px; height: 20px; flex: none; margin-top: 2px; }
.q { margin: 12px 0; }
.qt { font-weight: 600; font-size: 15px; }
.otp { font-size: 28px; letter-spacing: 8px; text-align: center; max-width: 260px; }
.bigicon { font-size: 52px; text-align: center; margin-top: 20px; }

.foot { padding: 20px 16px 40px; font-size: 13.5px; color: #667; border-top: 1px solid var(--line); margin-top: 20px; }

.tbl { width: 100%; border-collapse: collapse; background: #fff; font-size: 13.5px; }
.tbl th, .tbl td { border: 1px solid var(--line); padding: 6px 8px; text-align: left; vertical-align: top; }
.tbl th { background: #eef4f4; }
.tbl .summary { max-width: 220px; }
.actions form { display: flex; gap: 4px; flex-wrap: wrap; }
.actions button { padding: 4px 8px; border: 1px solid var(--line); border-radius: 6px; background: #fff; cursor: pointer; font-size: 12.5px; }
.actions .warnbtn { border-color: var(--warn); color: var(--warn); }
.badge { background: var(--warn); color: #fff; border-radius: 10px; font-size: 11px; padding: 1px 7px; margin-left: 6px; }
.datehead.today { background: var(--c); color: #fff; padding: 4px 10px; border-radius: 8px; display: inline-block; }
.inline-form { display: flex; gap: 6px; flex-wrap: wrap; margin: 10px 0; }
.inline-form input, .inline-form select { width: auto; }
.rules { background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 14px 18px; margin: 16px 0; }
.rules ul { padding-left: 18px; }
.rules li { margin: 4px 0; font-size: 14.5px; }

.gate { display: flex; flex-direction: column; gap: 14px; margin: 20px 0; }
.gatecard { display: block; background: #fff; border: 2px solid var(--line); border-radius: 16px; padding: 22px 20px; text-decoration: none; color: #1e2b2b; transition: border-color .15s; }
.gatecard:hover { border-color: var(--c); }
.gatecard.hl { border-color: var(--c); box-shadow: 0 2px 10px rgba(20,102,107,.12); }
.gicon { font-size: 34px; }
.gtitle { font-size: 21px; font-weight: 800; color: var(--c2); margin-top: 4px; }
.gdesc { color: #556; font-size: 14.5px; margin: 2px 0 10px; }
.gact { color: var(--c); font-weight: 700; }
.center { text-align: center; }

@media (min-width: 600px) { .choose { flex-direction: row; } .choose .btn { flex: 1; } .gate { flex-direction: row; } .gatecard { flex: 1; } }
.grouplabel { font-size: 13px; font-weight: 700; color: #667; margin-top: 10px; }
.otherbox { margin-top: 6px; max-width: 340px; }
