@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@600&family=Be+Vietnam+Pro:wght@400;500;600&family=Noto+Serif+TC:wght@600&display=swap');

:root{
  --green:#0E6B54; --green-d:#0A4A3A; --green-l:#E4EFEA;
  --gold:#BFA15A; --gold-d:#7A5E1E; --gold-l:#F6EFDD;
  --sand:#F4F1E9; --ink:#1F2A26; --muted:#5C6B64;
  --paper:#FFFFFF; --line:rgba(31,42,38,.13);
  --red:#C0392B; --red-l:#FBE6E4; --amber:#B8770E; --amber-l:#FBEFD6;
  --disp:'Cormorant Garamond','Noto Serif TC',serif;
  --sans:'Be Vietnam Pro','Noto Sans TC','PingFang TC','Microsoft JhengHei',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:var(--sans);background:var(--sand);color:var(--ink);-webkit-font-smoothing:antialiased;}

/* ---------- 行動 App ---------- */
.app{max-width:480px;margin:0 auto;min-height:100vh;background:#F7F8F6;display:flex;flex-direction:column;position:relative;box-shadow:0 0 40px -20px rgba(0,0,0,.2);}
.scr{display:none;flex-direction:column;flex:1;}
.scr.active{display:flex;}
.appbar{background:var(--green);color:#fff;padding:16px 18px 18px;flex:none;}
.appbar.dk{background:var(--green-d);}
.appbar .top2{display:flex;align-items:center;justify-content:space-between;}
.appbar .hi{font-size:17px;font-weight:600;}
.appbar .sub{font-size:12px;color:#BFD6CC;margin-top:2px;}
.appbar .ttl{font-size:16px;font-weight:600;display:flex;align-items:center;gap:10px;cursor:pointer;}
.appbar i.r{font-size:21px;cursor:pointer;}
.body{flex:1;overflow-y:auto;padding:16px;padding-bottom:80px;}

.qgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:-36px;background:var(--paper);border-radius:16px;padding:16px 10px;border:1px solid var(--line);box-shadow:0 10px 26px -16px rgba(31,42,38,.25);}
.q{display:flex;flex-direction:column;align-items:center;gap:7px;font-size:11px;color:var(--ink);cursor:pointer;padding:5px 0;border-radius:10px;}
.q:active{background:var(--green-l);}
.q .ic{width:44px;height:44px;border-radius:13px;background:var(--green-l);color:var(--green-d);display:flex;align-items:center;justify-content:center;font-size:21px;}
.q .ic.gold{background:var(--gold-l);color:var(--gold-d);}
.secttl{font-size:12px;color:var(--muted);font-weight:600;margin:18px 4px 8px;}
.billcard{background:var(--green-d);color:#fff;border-radius:14px;padding:15px;}
.billcard .l{font-size:12px;color:#BCD2C9;}
.billcard .amt{font-size:26px;font-weight:600;margin:3px 0 2px;}
.billcard .due{font-size:12px;color:var(--gold);}
.cta{margin-top:12px;background:var(--gold);color:#3d2f08;text-align:center;border-radius:10px;padding:12px;font-size:14px;font-weight:600;cursor:pointer;border:none;width:100%;font-family:var(--sans);}
.cta:active{opacity:.85;} .cta.green{background:var(--green);color:#fff;}
.card{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:14px;}
.notice{display:flex;gap:10px;align-items:flex-start;}
.notice .dot{width:8px;height:8px;border-radius:50%;background:var(--gold);margin-top:6px;flex:none;}
.notice b{font-size:13px;font-weight:600;display:block;} .notice span{font-size:11px;color:var(--muted);}

.tabbar{position:fixed;bottom:0;left:0;right:0;max-width:480px;margin:0 auto;height:62px;background:var(--paper);border-top:1px solid var(--line);display:flex;z-index:10;}
.tabbar .t{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-size:10px;color:var(--muted);cursor:pointer;position:relative;}
.tabbar .t i{font-size:21px;} .tabbar .t.on{color:var(--green);}
.tabbar .t .nb{position:absolute;top:8px;left:55%;background:var(--red);color:#fff;font-size:9px;border-radius:999px;padding:1px 5px;font-weight:600;}

.list-row{display:flex;align-items:center;gap:12px;padding:13px 0;border-bottom:1px solid var(--line);cursor:pointer;}
.list-row:last-child{border-bottom:none;}
.list-row .li{width:38px;height:38px;border-radius:11px;background:var(--green-l);color:var(--green-d);display:flex;align-items:center;justify-content:center;font-size:19px;flex:none;}
.list-row .lt{flex:1;font-size:14px;} .list-row .lt small{display:block;color:var(--muted);font-size:11px;}
.list-row .ch{color:#b9c4be;}
.row{display:flex;align-items:center;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line);font-size:13px;}
.row:last-child{border-bottom:none;} .row .k{color:var(--muted);} .row .v{font-weight:500;}
.field{margin-bottom:13px;} .field label{font-size:12px;color:var(--muted);display:block;margin-bottom:5px;}
.field input,.field select,.field textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:11px 12px;font-size:14px;font-family:var(--sans);color:var(--ink);background:#fff;}
.field textarea{min-height:70px;resize:vertical;}
.uploader{border:1.5px dashed #c3cdc7;border-radius:10px;padding:18px;text-align:center;color:var(--muted);font-size:12.5px;}
.uploader i{font-size:24px;display:block;margin-bottom:5px;color:var(--green);}
.chips{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap;}
.chip-f{font-size:12px;padding:7px 13px;border-radius:999px;border:1px solid var(--line);color:var(--muted);cursor:pointer;}
.chip-f.on{background:var(--green);color:#fff;border-color:var(--green);}
.wo{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:13px;margin-bottom:10px;cursor:pointer;}
.wo .h{display:flex;justify-content:space-between;align-items:center;} .wo .t{font-size:14px;font-weight:600;}
.wo .loc{font-size:11px;color:var(--muted);margin-top:3px;display:flex;align-items:center;gap:5px;}
.badge{font-size:10px;padding:3px 9px;border-radius:999px;font-weight:600;white-space:nowrap;}
.b-amber{background:var(--amber-l);color:var(--amber);} .b-gray{background:#ECEEEA;color:#5c6b64;}
.b-green{background:var(--green-l);color:var(--green-d);} .b-red{background:var(--red-l);color:var(--red);}
.alert{border-radius:12px;padding:13px;margin-bottom:10px;display:flex;gap:11px;align-items:flex-start;cursor:pointer;border:1px solid;}
.alert.fire{background:var(--red-l);border-color:#e9b3ac;} .alert.door{background:var(--amber-l);border-color:#ecd29a;} .alert.cctv{background:#ECEEEA;border-color:#d6dbd6;}
.alert .ai{font-size:22px;flex:none;margin-top:1px;} .alert.fire .ai{color:var(--red);} .alert.door .ai{color:var(--amber);} .alert.cctv .ai{color:var(--muted);}
.alert .at{flex:1;} .alert .at b{font-size:13px;display:block;} .alert .at small{font-size:11px;color:var(--muted);} .alert .ago{font-size:10px;color:var(--muted);white-space:nowrap;}
.statusgrid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;}
.st{background:var(--paper);border:1px solid var(--line);border-radius:11px;padding:11px 8px;text-align:center;}
.st i{font-size:20px;color:var(--green);} .st.warn i{color:var(--amber);} .st .sl{font-size:11px;margin-top:5px;} .st .sv{font-size:10px;font-weight:600;margin-top:2px;color:var(--green-d);} .st.warn .sv{color:var(--amber);}
.apv{background:var(--paper);border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:12px;padding:13px;margin-bottom:11px;}
.apv .type{font-size:10px;color:var(--gold-d);font-weight:600;} .apv .t{font-size:14px;font-weight:600;margin:4px 0 2px;} .apv .who{font-size:11px;color:var(--muted);} .apv .amt{font-size:15px;font-weight:600;color:var(--green-d);margin-top:6px;}
.apv .acts{display:flex;gap:8px;margin-top:11px;} .apv .acts span{flex:1;text-align:center;font-size:12px;font-weight:600;border-radius:8px;padding:9px;cursor:pointer;}
.ap-ok{background:var(--green);color:#fff;} .ap-no{background:#fff;color:var(--red);border:1px solid #e3b6b0;}
.apv.done{opacity:.5;}
.prof{display:flex;align-items:center;gap:13px;} .prof .av{width:54px;height:54px;border-radius:50%;background:var(--gold-l);color:var(--gold-d);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600;} .prof b{font-size:16px;} .prof small{color:var(--muted);font-size:12px;display:block;}
.lang{display:flex;gap:6px;} .lang span{font-size:12px;border:1px solid var(--line);border-radius:8px;padding:7px 14px;cursor:pointer;} .lang span.on{background:var(--green);color:#fff;border-color:var(--green);}
.empty{color:var(--muted);font-size:13px;text-align:center;padding:36px 10px;} .empty i{font-size:30px;display:block;margin-bottom:8px;color:#c3cdc7;}
.prog{height:8px;background:#e3e7e3;border-radius:999px;overflow:hidden;margin-top:8px;} .prog>i{display:block;height:100%;background:var(--green);border-radius:999px;}
.toast{position:fixed;left:50%;bottom:80px;transform:translateX(-50%) translateY(20px);background:var(--green-d);color:#fff;font-size:13px;padding:12px 20px;border-radius:999px;opacity:0;transition:.25s;z-index:50;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.alarm-ov{position:fixed;inset:0;background:rgba(192,57,43,.97);color:#fff;display:none;flex-direction:column;align-items:center;justify-content:center;gap:10px;z-index:60;padding:34px;text-align:center;}
.alarm-ov.show{display:flex;}
.al-ic{width:96px;height:96px;border-radius:50%;background:rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;font-size:48px;animation:pulse 1.1s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,255,255,.45)}70%{box-shadow:0 0 0 24px rgba(255,255,255,0)}100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}}
.al-tt{font-size:12px;letter-spacing:.3em;color:#ffd9d3;} .al-sub{font-size:24px;font-weight:600;} .al-loc{font-size:13px;color:#ffd9d3;}
.al-btns{margin-top:18px;width:100%;max-width:300px;display:flex;flex-direction:column;gap:10px;}
.al-b{padding:14px;border-radius:11px;font-size:14px;font-weight:600;cursor:pointer;border:1px solid rgba(255,255,255,.55);color:#fff;} .al-b.primary{background:#fff;color:var(--red);border-color:#fff;}
.pushbar{background:var(--gold-l);color:var(--gold-d);font-size:12px;padding:9px 14px;text-align:center;cursor:pointer;}

/* ---------- 後台 APEX 版型 ---------- */
.admin{display:flex;min-height:100vh;}
.anav{width:212px;background:var(--green-d);color:#cfe0d8;flex:none;padding:14px 0;}
.anav .brand{padding:6px 18px 16px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:10px;}
.anav .brand b{color:#fff;font-size:15px;display:block;} .anav .brand span{font-size:10px;color:var(--gold);letter-spacing:.08em;}
.anav a{display:flex;align-items:center;gap:11px;padding:11px 18px;font-size:13.5px;color:#cfe0d8;text-decoration:none;cursor:pointer;}
.anav a i{font-size:18px;} .anav a.on{background:rgba(191,161,90,.16);color:#fff;border-left:3px solid var(--gold);padding-left:15px;}
.amain{flex:1;background:#F4F5F2;min-width:0;display:flex;flex-direction:column;}
.atop{background:#fff;border-bottom:1px solid var(--line);padding:12px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;}
.atop .logo{font-family:var(--disp);font-size:20px;color:var(--green-d);font-weight:600;}
.atop .sp{flex:1;} .atop .usr{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--muted);}
.atop .usr .av{width:32px;height:32px;border-radius:50%;background:var(--gold-l);color:var(--gold-d);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:12px;}
.acontent{padding:22px 26px;}
.crumb{font-size:12px;color:var(--muted);} .ahead{display:flex;align-items:center;justify-content:space-between;margin:4px 0 18px;} .ahead h3{font-size:21px;font-weight:600;}
.ahead .acts{display:flex;gap:10px;}
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px;}
.metric{background:#fff;border:1px solid var(--line);border-radius:11px;padding:15px 17px;} .metric .l{font-size:12px;color:var(--muted);} .metric .n{font-size:27px;font-weight:600;color:var(--green-d);margin-top:4px;} .metric .n.red{color:var(--red);} .metric .n.amber{color:var(--amber);}
.region{background:#fff;border:1px solid var(--line);border-radius:11px;overflow:hidden;margin-bottom:20px;}
.region .rh{padding:13px 16px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;} .region .rh b{font-size:14px;font-weight:600;}
.toolbar{display:flex;gap:8px;align-items:center;}
.search{display:flex;align-items:center;gap:7px;border:1px solid var(--line);border-radius:8px;padding:6px 11px;font-size:12px;color:var(--muted);background:#fff;}
.search input{border:none;outline:none;font-family:var(--sans);font-size:12px;width:120px;}
.tbtn{font-size:12px;border:1px solid var(--line);border-radius:8px;padding:7px 13px;color:var(--ink);background:#fff;cursor:pointer;display:inline-flex;align-items:center;gap:6px;} .tbtn.p{background:var(--green);color:#fff;border-color:var(--green);}
table.ir{width:100%;border-collapse:collapse;font-size:13px;}
table.ir th{text-align:left;padding:11px 16px;background:#EEF1ED;color:var(--muted);font-weight:600;font-size:11.5px;border-bottom:1px solid var(--line);}
table.ir td{padding:11px 16px;border-bottom:1px solid var(--line);} table.ir tr:last-child td{border-bottom:none;}
.mini{font-size:11px;border:1px solid var(--line);border-radius:7px;padding:5px 10px;cursor:pointer;background:#fff;margin-right:5px;} .mini.p{background:var(--green);color:#fff;border-color:var(--green);} .mini.r{color:var(--red);border-color:#e3b6b0;}
.banner{background:var(--amber);color:#3d2f08;padding:11px 16px;border-radius:10px;margin-bottom:14px;display:none;align-items:center;gap:10px;font-size:13px;font-weight:500;}
.banner.show{display:flex;}
.adsec{display:none;} .adsec.active{display:block;}
.adlang{display:flex;gap:6px;}
@media(max-width:760px){ .admin{flex-direction:column;} .anav{width:100%;} .metrics{grid-template-columns:repeat(2,1fr);} }

/* 儀表板圖表 / 設定元件 */
.barchart{display:flex;align-items:flex-end;gap:12px;height:140px;padding:6px 4px 0;}
.barchart .bar{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:7px;height:100%;}
.barchart .bar .col{width:62%;min-height:4px;background:linear-gradient(180deg,var(--green),var(--green-d));border-radius:6px 6px 0 0;}
.barchart .bar .vv{font-size:10px;color:var(--muted);} .barchart .bar .bl{font-size:11px;color:var(--muted);}
.hbar{margin-bottom:14px;} .hbar:last-child{margin-bottom:4px;}
.hbar .t{display:flex;justify-content:space-between;font-size:12.5px;margin-bottom:6px;} .hbar .t b{font-weight:600;}
.hbar .track{height:10px;background:#e8ebe7;border-radius:999px;overflow:hidden;} .hbar .fill{height:100%;border-radius:999px;}
.setrow{display:flex;align-items:center;justify-content:space-between;padding:13px 0;border-bottom:1px solid var(--line);font-size:13.5px;}
.setrow:last-child{border-bottom:none;}
.toggle{width:42px;height:23px;border-radius:999px;background:#cdd3ce;position:relative;cursor:pointer;transition:.2s;flex:none;}
.toggle::after{content:"";position:absolute;top:2px;left:2px;width:19px;height:19px;border-radius:50%;background:#fff;transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.2);}
.toggle.on{background:var(--green);} .toggle.on::after{left:21px;}
.anav .brand .emblem{display:block;margin:0 auto 9px;}
.anav .brand b.big{font-size:21px;font-weight:700;letter-spacing:.5px;line-height:1.25;}

/* 儀表板 — 甜甜圈狀態圖 */
.donutwrap{display:flex;align-items:center;gap:22px;flex-wrap:wrap;padding:4px 2px}
.donut{position:relative;width:124px;height:124px;border-radius:50%;flex:0 0 auto;box-shadow:0 1px 3px rgba(0,0,0,.08)}
.donut .hole{position:absolute;inset:19px;background:#fff;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center}
.donut .hole b{font-size:26px;color:var(--ink);line-height:1;font-weight:800}
.donut .hole span{font-size:11px;color:var(--muted);margin-top:2px}
.legend{display:flex;flex-direction:column;gap:9px;font-size:13px;color:var(--ink);min-width:130px}
.legend .lg{display:flex;align-items:center;gap:9px}
.legend .lg .dot{width:11px;height:11px;border-radius:3px;display:inline-block;flex:0 0 auto}
.legend .lg b{margin-left:auto;padding-left:16px;color:var(--ink)}
