/* 謄本開發名單 — 質感房仲工具風：深色頂欄＋亮色卡片 */
:root{
  --navy:#12233f;
  --navy2:#1b3155;
  --gold:#c9a24b;
  --bg:#eef1f6;
  --card:#ffffff;
  --ink:#22304a;
  --sub:#6b7a93;
  --line:#e2e7ef;
  --red:#e5484d;
  --orange:#f59e0b;
  --blue:#3b82f6;
  --purple:#8b5cf6;
  --gray:#9ca3af;
  --green:#16a34a;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{font-family:"Microsoft JhengHei","PingFang TC","Noto Sans TC",sans-serif;background:var(--bg);color:var(--ink);font-size:16px;line-height:1.55}
.hidden{display:none!important}
button{font-family:inherit;cursor:pointer}
input,select{font-family:inherit;font-size:16px}

/* ===== 登入 ===== */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,var(--navy) 0%,var(--navy2) 100%);padding:20px}
.login-card{background:var(--card);border-radius:18px;padding:36px 28px;width:100%;max-width:360px;text-align:center;box-shadow:0 18px 50px rgba(0,0,0,.35)}
.login-logo{font-size:44px}
.login-card h1{font-size:24px;margin:8px 0 2px;letter-spacing:2px}
.login-sub{color:var(--sub);font-size:14px;margin-bottom:22px}
.login-card input{width:100%;padding:13px 14px;border:1.5px solid var(--line);border-radius:12px;font-size:18px;text-align:center;letter-spacing:3px}
.login-card input:focus{outline:none;border-color:var(--gold)}
.login-card button{width:100%;margin-top:14px;padding:13px;border:none;border-radius:12px;background:var(--navy);color:#fff;font-size:17px;font-weight:700;letter-spacing:4px}
.login-card button:disabled{opacity:.6}
.login-err{color:var(--red);margin-top:12px;font-size:14px}

/* ===== 頂欄 ===== */
.topbar{background:var(--navy);color:#fff;padding:12px 14px 0;position:sticky;top:0;z-index:30;box-shadow:0 2px 10px rgba(0,0,0,.25)}
.topbar-row{display:flex;align-items:center;justify-content:space-between;gap:8px;max-width:1100px;margin:0 auto}
.brand{font-size:18px;font-weight:800;letter-spacing:1px;white-space:nowrap}
.topbar-right{display:flex;align-items:center;gap:10px}
.updated-at{font-size:12px;color:#9fb0ca}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.25);border-radius:10px;padding:7px 12px;font-size:14px}
.btn-ghost:active{background:rgba(255,255,255,.25)}
.tabs{display:flex;gap:4px;max-width:1100px;margin:10px auto 0}
.tab{flex:1;max-width:180px;background:transparent;border:none;color:#9fb0ca;font-size:16px;font-weight:700;padding:10px 0 12px;border-bottom:3px solid transparent}
.tab.on{color:#fff;border-bottom-color:var(--gold)}

/* ===== 版面 ===== */
.page{max-width:1100px;margin:0 auto;padding:14px 12px 90px}
.card{background:var(--card);border-radius:14px;padding:14px;margin-bottom:12px;box-shadow:0 1px 4px rgba(20,35,63,.08)}
.center-note{text-align:center;color:var(--sub);padding:24px 10px}
.hint{color:var(--sub);font-size:13px;margin-top:8px}
.row-flex{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.sel-label{font-weight:700;white-space:nowrap}
.big-select{flex:1;min-width:150px;padding:10px 12px;border:1.5px solid var(--line);border-radius:10px;background:#fff;font-size:16px}

/* 檢視切換 */
.view-toggle{display:flex;border:1.5px solid var(--line);border-radius:10px;overflow:hidden}
.vt{border:none;background:#fff;padding:9px 14px;font-size:14px;color:var(--sub);font-weight:700}
.vt.on{background:var(--navy);color:#fff}

/* 統計條 */
.stats-bar{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-bottom:12px}
.stat{background:var(--card);border-radius:12px;padding:10px 6px;text-align:center;box-shadow:0 1px 4px rgba(20,35,63,.08)}
.stat .num{font-size:24px;font-weight:800;line-height:1.2}
.stat .lbl{font-size:12px;color:var(--sub);white-space:nowrap}
.stat.s-red .num{color:var(--red)}
.stat.s-orange .num{color:var(--orange)}
.stat.s-blue .num{color:var(--blue)}
.stat.s-purple .num{color:var(--purple)}
@media (max-width:480px){.stat .num{font-size:20px}.stat .lbl{font-size:11px}}

/* 圖例 */
.legend{display:flex;flex-wrap:wrap;gap:12px;font-size:13px;color:var(--sub);padding:10px 14px}
.legend span{display:flex;align-items:center;gap:5px}
.dot{width:10px;height:10px;border-radius:50%;display:inline-block}
.d-red{background:var(--red)}.d-orange{background:var(--orange)}.d-blue{background:var(--blue)}.d-purple{background:var(--purple)}.d-gray{background:var(--gray)}

/* ===== 棟×樓格子圖 ===== */
.grid-card{padding:10px}
.grid-scroller{overflow-x:auto;-webkit-overflow-scrolling:touch}
.bgrid{border-collapse:separate;border-spacing:5px;margin:0 auto}
.bgrid th{font-size:13px;color:var(--sub);font-weight:700;padding:4px 2px;white-space:nowrap}
.bgrid th.floor-h{position:sticky;left:0;background:var(--card);z-index:2;text-align:right;padding-right:6px}
.cell{width:86px;min-width:86px;height:58px;border:1.5px solid var(--line);border-radius:10px;background:#f8fafc;position:relative;padding:6px 7px;vertical-align:top;cursor:pointer;transition:box-shadow .1s}
.cell:active{box-shadow:0 0 0 3px rgba(201,162,75,.4)}
.cell.empty{background:transparent;border:1.5px dashed #e8ecf3;cursor:default}
.cell .fl{font-size:12px;color:var(--sub);line-height:1}
.cell .nm{font-size:17px;font-weight:800;margin-top:3px;line-height:1.2;white-space:nowrap}
.cell .co{font-size:11px;color:var(--sub)}
.cell .dots{position:absolute;right:5px;top:5px;display:flex;gap:3px;flex-wrap:wrap;max-width:44px;justify-content:flex-end}
.cell .dots .dot{width:9px;height:9px;box-shadow:0 0 0 1.5px #fff}

/* ===== 表格 ===== */
.table-card{padding:8px}
.table-scroller{overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{padding:9px 8px;text-align:left;border-bottom:1px solid var(--line);white-space:nowrap}
th{color:var(--sub);font-size:13px;background:#f6f8fb;position:sticky;top:0}
th.sortable{cursor:pointer;user-select:none}
th.sortable:hover{color:var(--navy)}
tr.rowlink{cursor:pointer}
tr.rowlink:active{background:#f2f6ff}
.tagline{display:flex;gap:4px}
.mini-tag{font-size:11px;padding:1px 6px;border-radius:20px;color:#fff;white-space:nowrap}
.mt-red{background:var(--red)}.mt-orange{background:var(--orange)}.mt-blue{background:var(--blue)}.mt-purple{background:var(--purple)}.mt-gray{background:var(--gray)}.mt-green{background:var(--green)}

/* ===== 篩選 chips ===== */
.filter-group{margin-bottom:12px}
.filter-group:last-child{margin-bottom:2px}
.fg-label{font-size:13px;color:var(--sub);font-weight:700;margin-bottom:6px}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{border:1.5px solid var(--line);background:#fff;border-radius:999px;padding:8px 14px;font-size:14px;color:var(--ink)}
.chip.on{background:var(--navy);border-color:var(--navy);color:#fff;font-weight:700}
.chips-radio .chip.on{background:var(--gold);border-color:var(--gold);color:#1d1607}

/* ===== 動作列 ===== */
.action-bar{display:flex;flex-direction:column;gap:10px}
.sel-tools{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.chk-all{display:flex;align-items:center;gap:6px;font-weight:700}
.chk-all input,.mail-chk{width:20px;height:20px;accent-color:var(--navy)}
.btn-ghost2{background:#fff;border:1.5px solid var(--line);border-radius:10px;padding:7px 12px;font-size:14px}
.sel-count{color:var(--sub);font-size:14px;margin-left:auto}
.actions{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
@media (min-width:720px){.actions{grid-template-columns:repeat(4,1fr)}}
.btn-act{background:#fff;border:1.5px solid var(--line);border-radius:11px;padding:11px 8px;font-size:15px;font-weight:700;color:var(--ink)}
.btn-act:active{background:#f2f6ff}
.btn-act:disabled{opacity:.45;cursor:not-allowed}
.btn-primary{background:var(--navy);border-color:var(--navy);color:#fff}
.btn-block{width:100%;margin-top:14px;padding:13px}

/* 範本面板 */
.tpl-preview{background:#f6f8fb;border:1px solid var(--line);border-radius:10px;padding:12px;margin-top:10px;white-space:pre-wrap;word-break:break-word;font-family:inherit;font-size:14px;max-height:300px;overflow-y:auto}

/* ===== Modal ===== */
.overlay{position:fixed;inset:0;background:rgba(10,20,40,.55);z-index:50;display:flex;align-items:flex-end;justify-content:center}
@media (min-width:640px){.overlay{align-items:center}}
.modal{background:#fff;width:100%;max-width:560px;max-height:88vh;border-radius:18px 18px 0 0;display:flex;flex-direction:column;overflow:hidden}
@media (min-width:640px){.modal{border-radius:18px}}
.modal-sm{max-width:400px}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--navy);color:#fff;flex:0 0 auto}
.modal-title{font-size:17px;font-weight:800}
.modal-x{background:transparent;border:none;color:#fff;font-size:20px;padding:2px 6px}
.modal-body{padding:14px 16px 22px;overflow-y:auto}

/* 戶別卡片內容 */
.unit-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.unit-tag{font-size:13px;padding:3px 10px;border-radius:20px;color:#fff;font-weight:700}
.kv{display:grid;grid-template-columns:96px 1fr;gap:4px 10px;font-size:14px;margin-bottom:12px}
.kv dt{color:var(--sub)}
.kv dd{word-break:break-all}
.owner-block{border:1px solid var(--line);border-radius:12px;padding:10px 12px;margin-bottom:10px}
.owner-block h4{font-size:15px;margin-bottom:6px}
.pdf-link{display:inline-block;margin:4px 0 12px;color:var(--blue);font-weight:700;text-decoration:none;border:1.5px solid var(--blue);border-radius:10px;padding:7px 14px;font-size:14px}
.devlog-box{background:#f6f8fb;border-radius:10px;padding:10px 12px;font-size:13px;white-space:pre-wrap;word-break:break-word;color:var(--ink);margin-bottom:12px;max-height:160px;overflow-y:auto}
.sec-title{font-size:14px;font-weight:800;color:var(--navy);margin:14px 0 8px;border-left:4px solid var(--gold);padding-left:8px}
.quick-btns{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.qbtn{border:1.5px solid var(--line);background:#fff;border-radius:11px;padding:10px 4px;font-size:14px;font-weight:700}
.qbtn.on{background:var(--navy);border-color:var(--navy);color:#fff}
.qform{margin-top:12px;border-top:1px dashed var(--line);padding-top:12px}
.fld-label{display:block;font-size:13px;color:var(--sub);font-weight:700;margin:10px 0 4px}
.fld{width:100%;padding:10px 12px;border:1.5px solid var(--line);border-radius:10px;background:#fff}
textarea.fld{resize:vertical;min-height:64px}
.sent-summary{font-size:14px;color:var(--ink)}
.status-badge{display:inline-block;padding:2px 10px;border-radius:20px;font-size:13px;font-weight:700;background:#eef1f6;color:var(--ink)}

/* toast */
.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);background:var(--navy);color:#fff;padding:11px 20px;border-radius:12px;font-size:15px;z-index:99;box-shadow:0 8px 24px rgba(0,0,0,.3);max-width:90vw;text-align:center}

/* ===== 快速篩選（社區透視） ===== */
.qf-card{padding:12px 14px}
.qf-head{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px}
.qf-head .fg-label{margin:0}
.qchip{display:inline-flex;align-items:center;gap:6px}
.qchip .dot{width:9px;height:9px;flex:none}
.qchip .cnt{font-size:12px;color:var(--sub);font-weight:400;background:#eef1f6;border-radius:10px;padding:1px 7px;margin-left:2px}
.qchip.on .cnt{background:rgba(255,255,255,.22);color:#fff;font-weight:700}
.cell.dim{opacity:.22;filter:grayscale(.6)}
.cell.hit{border-color:var(--gold);box-shadow:0 0 0 2px rgba(201,162,75,.35)}
.stat-btn{cursor:pointer;user-select:none;transition:box-shadow .1s}
.stat-btn:active{box-shadow:0 0 0 3px rgba(201,162,75,.4)}
.stat-btn.on{outline:2.5px solid var(--gold);outline-offset:-2px}

/* ===== 桌機列印本頁時隱藏 UI（信封列印走獨立視窗）===== */
@media print{
  .topbar,.actions,.sel-tools,.legend,.qf-card{display:none}
}
