/* ============================================================
 * MAPLE_CVD 样式表 v3.0
 * 设计语言：清爽医疗蓝、卡片化、移动优先、深色模式
 * ============================================================ */
:root{
  --bg:#F4F6F9; --bg2:#fff; --bg3:#F8FAFC;
  --fg:#1F2329; --fg2:#3A4250; --muted:#6B7280; --muted2:#9AA1AC;
  --border:#EAECEF; --border2:#F0F2F5;
  --primary:#2D6CDF; --primary-bg:#EEF4FF;
  --success:#2F9E44; --success-bg:#E6F4EA;
  --warn:#E8590C; --warn-bg:#FFF4E2;
  --danger:#E03131; --danger-bg:#FDECEC;
  --info:#1971C2; --info-bg:#E7F1FF;
  --purple:#7C5CFC; --purple-bg:#F1ECFF;
  --radius:14px; --radius-sm:10px; --radius-lg:20px;
  --shadow:0 2px 8px rgba(20,30,50,.06); --shadow-lg:0 8px 24px rgba(20,30,50,.12);
  --safe-b:env(safe-area-inset-bottom,0px);
  --safe-t:env(safe-area-inset-top,0px);
}
.dark{
  --bg:#0F1115; --bg2:#1A1D24; --bg3:#161A20;
  --fg:#E4E7EC; --fg2:#C0C5CE; --muted:#8B92A0; --muted2:#6B7280;
  --border:#2A2F38; --border2:#22262D;
  --primary-bg:#1B2436; --success-bg:#16261C; --warn-bg:#2A1F12; --danger-bg:#2A1517; --info-bg:#1B2436; --purple-bg:#221A36;
  --shadow:0 2px 8px rgba(0,0,0,.3); --shadow-lg:0 8px 24px rgba(0,0,0,.5);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0;height:100%}
body{font-family:-apple-system,BlinkMacSystemFont,"PingFang SC","Microsoft YaHei",sans-serif;background:var(--bg);color:var(--fg);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
input,textarea,select,button{font-family:inherit;font-size:inherit;color:inherit}
button{cursor:pointer;border:none;background:none}
a{color:inherit;text-decoration:none}
.muted{color:var(--muted)}

/* ============ App Shell ============ */
.app{max-width:520px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column;background:var(--bg);position:relative}
.appbar{position:sticky;top:0;z-index:50;background:var(--bg2);border-bottom:1px solid var(--border);padding:calc(var(--safe-t) + 10px) 16px 10px;display:flex;align-items:center;gap:10px}
.appbar h1{font-size:17px;font-weight:600;margin:0;flex:1}
.appbar .back{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;color:var(--fg)}
.appbar .back:active{background:var(--border2)}
.appbar .back[hidden]{display:none}
.view{flex:1;padding:14px 14px 90px;overflow-x:hidden}
.tabbar{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:520px;background:var(--bg2);border-top:1px solid var(--border);display:flex;padding:6px 0 calc(var(--safe-b) + 6px);z-index:50}
.tabbar a{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 0;color:var(--muted);font-size:11px;transition:color .2s}
.tabbar a .ico{font-size:20px;line-height:1}
.tabbar a.active{color:var(--primary)}

/* ============ Hero ============ */
.hero{background:linear-gradient(135deg,#2D6CDF 0%,#1F5BC4 100%);color:#fff;border-radius:var(--radius-lg);padding:18px 18px 14px;margin-bottom:14px;box-shadow:0 6px 18px rgba(45,108,223,.25)}
.hero-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}
.hero-date{font-size:12px;opacity:.85;margin-bottom:4px}
.hero-title{font-size:18px;font-weight:600}
.hero-ring{position:relative;width:56px;height:56px}
.hero-ring-txt{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff}
.hero-ring-txt b{font-size:13px;line-height:1}
.hero-ring-txt span{font-size:9px;opacity:.8;margin-top:1px}
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding-top:12px;border-top:1px solid rgba(255,255,255,.2)}
.hero-stats>div{display:flex;flex-direction:column;align-items:center}
.hero-stats b{font-size:18px;font-weight:700}
.hero-stats span{font-size:10px;opacity:.85;margin-top:2px}

/* ============ Block ============ */
.block{margin-bottom:14px}
.block-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding:0 4px}
.block-head h3{font-size:14px;font-weight:600;margin:0;color:var(--fg)}
.block-head a,.block-head .count{font-size:12px;color:var(--muted)}
.block-head .count{background:var(--border2);padding:2px 8px;border-radius:10px}

/* ============ Card ============ */
.card{background:var(--bg2);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow)}
.chart-card{padding:12px 8px}

/* ============ Empty ============ */
.empty{padding:50px 20px;text-align:center;color:var(--muted)}
.empty-ico{font-size:48px;margin-bottom:10px;opacity:.7}
.empty-title{font-size:15px;font-weight:600;color:var(--fg2);margin-bottom:4px}
.empty-desc{font-size:13px}
.empty-inline{padding:24px;text-align:center;color:var(--muted);font-size:13px}

/* ============ Reminder ============ */
.reminder{display:flex;align-items:center;gap:10px;background:var(--bg2);border-radius:var(--radius);padding:12px 14px;margin-bottom:8px;box-shadow:var(--shadow);border-left:3px solid}
.reminder.danger{border-color:var(--danger)}
.reminder.warn{border-color:var(--warn)}
.reminder.info{border-color:var(--info)}
.reminder .rem-ico{font-size:20px}
.reminder b{font-size:13px;display:block}
.reminder span{font-size:12px;color:var(--muted)}

/* ============ Task ============ */
.task{display:flex;align-items:center;gap:10px;background:var(--bg2);border-radius:var(--radius);padding:12px 14px;margin-bottom:8px;box-shadow:var(--shadow);position:relative;overflow:hidden;transition:transform .15s}
.task:active{transform:scale(.98)}
.task .task-bar{position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--primary)}
.task.overdue .task-bar{background:var(--danger)}
.task.today .task-bar{background:var(--warn)}
.task.upcoming .task-bar{background:var(--info)}
.task-ico{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.task-main{flex:1;min-width:0}
.task-title{font-size:14px;font-weight:600;color:var(--fg);margin-bottom:2px}
.task-sub{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.task-cta{color:var(--muted2);font-size:18px}
.task-quick{width:32px;height:32px;border-radius:50%;border:2px solid var(--success);color:var(--success);font-size:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}
.task-quick:active{background:var(--success);color:#fff;transform:scale(.9)}

.task-toolbar{margin-bottom:12px}
.task-filter-row{margin-bottom:8px}
.task-actions-row{display:flex;gap:8px}

/* Segmented Control */
.seg-control{display:flex;background:var(--border2);border-radius:10px;padding:3px;gap:2px}
.seg-btn{flex:1;padding:7px 4px;border-radius:7px;font-size:12px;font-weight:500;color:var(--muted);transition:all .2s;white-space:nowrap}
.seg-btn.active{background:var(--bg2);color:var(--primary);box-shadow:0 1px 3px rgba(0,0,0,.08)}

.dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px;vertical-align:middle}
.dot.overdue{background:var(--danger)}
.dot.today{background:var(--warn)}
.dot.upcoming{background:var(--info)}

/* ============ Quick Actions ============ */
.quick{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.quick-btn{background:var(--bg2);border-radius:var(--radius);padding:14px 6px;display:flex;flex-direction:column;align-items:center;gap:6px;box-shadow:var(--shadow);transition:transform .15s}
.quick-btn:active{transform:scale(.95)}
.quick-btn span{font-size:22px}
.quick-btn{font-size:11px;color:var(--fg2)}

/* ============ Log ============ */
.log-list{padding:8px 14px}
.log-item{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:12px;border-bottom:1px solid var(--border2)}
.log-item:last-child{border-bottom:none}
.log-time{color:var(--muted2);width:60px;flex-shrink:0}
.log-action{color:var(--fg2);flex:1}
.log-target{color:var(--muted)}

/* ============ Toolbar / Search / Chips ============ */
.toolbar{margin-bottom:10px}
.search{background:var(--bg2);border-radius:var(--radius);padding:8px 14px;box-shadow:var(--shadow)}
.search input{width:100%;border:none;background:none;outline:none;font-size:14px}
.filter-row{margin-bottom:10px;overflow-x:auto;-webkit-overflow-scrolling:touch}
.filter-row::-webkit-scrollbar{display:none}
.chips{display:flex;gap:6px;padding:2px}
.chip{padding:6px 12px;border-radius:16px;background:var(--bg2);color:var(--muted);font-size:12px;white-space:nowrap;box-shadow:var(--shadow);transition:all .15s}
.chip.active{background:var(--primary);color:#fff}
.seg{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}

/* ============ Buttons ============ */
.btn{padding:10px 16px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;background:var(--bg2);color:var(--fg);box-shadow:var(--shadow);transition:transform .15s;display:inline-flex;align-items:center;justify-content:center;gap:4px}
.btn:active{transform:scale(.97)}
.btn.primary{background:var(--primary);color:#fff;box-shadow:0 4px 12px rgba(45,108,223,.3)}
.btn.success{background:var(--success);color:#fff}
.btn.warn{background:var(--warn-bg);color:var(--warn)}
.btn.danger{background:var(--danger-bg);color:var(--danger)}
.btn.ghost{background:transparent;box-shadow:none;border:1px solid var(--border)}
.btn.sm{padding:7px 12px;font-size:13px}
.btn.xs{padding:5px 10px;font-size:12px}

/* ============ Animal Cards ============ */
.cards{display:flex;flex-direction:column;gap:8px}
.acard{display:flex;align-items:stretch;background:var(--bg2);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:transform .15s}
.acard:active{transform:scale(.99)}
.acard.sel{box-shadow:0 0 0 2px var(--primary)}
.acheck{display:flex;align-items:center;padding:0 10px 0 12px;cursor:pointer}
.acheck input{width:18px;height:18px;accent-color:var(--primary)}
.acard-main{flex:1;padding:12px 14px 12px 0;min-width:0}
.acard-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.acode{font-size:15px;font-weight:600}
.badge{font-size:11px;padding:2px 8px;border-radius:10px;font-weight:500}
.acard-meta{font-size:12px;color:var(--muted);margin-bottom:6px}
.acard-foot{display:flex;gap:8px;align-items:center;font-size:11px}
.nextstep{color:var(--info)}
.nextstep.done{color:var(--success)}
.nextstep.custom{color:var(--purple);background:var(--purple-bg);padding:2px 6px;border-radius:8px}

/* ============ Selbar ============ */
.selbar{position:fixed;bottom:calc(70px + var(--safe-b));left:50%;transform:translateX(-50%);width:calc(100% - 28px);max-width:492px;background:var(--fg);color:#fff;border-radius:var(--radius);padding:10px 14px;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-lg);z-index:40}
.selbar span{font-size:13px}
.selbar-actions{display:flex;gap:6px}
.selbar .btn{padding:6px 10px;font-size:12px}
.selbar .btn.ghost{background:rgba(255,255,255,.15);color:#fff;border-color:transparent}
.selbar .btn.danger{background:rgba(224,49,49,.3);color:#fff}

/* ============ Detail ============ */
.detail-head{background:var(--bg2);border-radius:var(--radius);padding:16px;margin-bottom:14px;box-shadow:var(--shadow)}
.dh-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.dcode{font-size:18px;font-weight:700}
.dh-notes{font-size:13px;color:var(--muted);margin-bottom:10px;padding:8px 10px;background:var(--bg3);border-radius:8px}
.dh-actions{display:flex;gap:6px;flex-wrap:wrap}
.kvgrid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.kv{background:var(--bg2);padding:10px 12px;display:flex;flex-direction:column;gap:2px}
.kv span{font-size:11px;color:var(--muted)}
.kv b{font-size:13px;font-weight:500}

/* Callout */
.callout{padding:12px 14px;border-radius:var(--radius);font-size:13px;line-height:1.6}
.callout.danger{background:var(--danger-bg);color:var(--danger);border-left:3px solid var(--danger)}
.callout.warn{background:var(--warn-bg);color:var(--warn);border-left:3px solid var(--warn)}

/* Timeline */
.timeline{background:var(--bg2);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow)}
.tl{display:flex;gap:12px;padding:8px 0;position:relative}
.tl:not(:last-child)::before{content:'';position:absolute;left:17px;top:38px;bottom:-8px;width:2px;background:var(--border2)}
.tl-dot{width:34px;height:34px;border-radius:50%;background:var(--border2);color:var(--muted);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;z-index:1}
.tl.done .tl-dot{background:var(--success);color:#fff}
.tl.current .tl-dot{background:var(--c);color:#fff;box-shadow:0 0 0 4px var(--c)30}
.tl-body{flex:1;padding-top:4px}
.tl-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.tl-top b{font-size:14px}
.tl-detail{font-size:12px;color:var(--fg2);line-height:1.5}
.tl-detail.muted{color:var(--muted)}
.tl.locked .tl-body{opacity:.5}

/* Custom task list */
.custom-list{display:flex;flex-direction:column;gap:6px}
.ctask{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg3);border-radius:var(--radius-sm)}
.ctask.done{opacity:.6}
.ctask-ico{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.ctask-main{flex:1;min-width:0}
.ctask-title{font-size:13px;font-weight:500}
.ctask-title .done-tag{font-size:10px;color:var(--success);background:var(--success-bg);padding:1px 6px;border-radius:6px;margin-left:4px}
.ctask-sub{font-size:11px;color:var(--muted)}
.add-custom-btn{width:100%;padding:14px;border:1.5px dashed var(--border);color:var(--muted);font-size:13px}

/* ============ Form ============ */
.form{display:flex;flex-direction:column;gap:12px}
.form-section{font-size:12px;color:var(--muted);font-weight:600;margin-top:4px;padding-bottom:2px;border-bottom:1px solid var(--border2)}
.field{display:flex;flex-direction:column;gap:5px}
.field-label{font-size:12px;color:var(--muted);font-weight:500}
.field-label i{color:var(--danger);font-style:normal}
.input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg3);font-size:14px;outline:none;transition:border .15s}
.input:focus{border-color:var(--primary);background:var(--bg2)}
.input.sm{padding:7px 10px;font-size:13px}
.input.area{min-height:60px;resize:vertical;font-family:inherit}
select.input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236B7280' d='M6 8L2 4h8z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}
.row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.row3 .field-label{font-size:11px}
.preview{background:var(--bg3);border-radius:var(--radius-sm);padding:10px;min-height:48px;display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.pchip{background:var(--primary-bg);color:var(--primary);padding:3px 8px;border-radius:8px;font-size:12px}
.field-checks{display:flex;flex-wrap:wrap;gap:8px}
.field-checks label{display:flex;align-items:center;gap:4px;font-size:13px;padding:5px 10px;background:var(--bg3);border-radius:8px}
.field-checks input{accent-color:var(--primary)}

/* Icon/Color picker */
.icon-pick,.color-pick{display:flex;flex-wrap:wrap;gap:6px}
.icon-pick-btn{width:36px;height:36px;border-radius:8px;background:var(--bg3);font-size:18px;display:flex;align-items:center;justify-content:center;border:1.5px solid transparent}
.icon-pick-btn.active{border-color:var(--primary);background:var(--primary-bg)}
.color-pick-btn{width:28px;height:28px;border-radius:50%;border:2px solid transparent}
.color-pick-btn.active{border-color:var(--fg);box-shadow:0 0 0 2px var(--bg2)}

/* Template pick */
.tpl-pick{display:flex;flex-wrap:wrap;gap:6px}
.tpl-pick-btn{display:flex;align-items:center;gap:6px;padding:6px 10px;background:var(--bg3);border-radius:8px;font-size:12px;border:1px solid var(--border)}
.tpl-pick-btn span{width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:13px}
.tpl-pick-btn:active{background:var(--primary-bg)}

/* ============ Combo ============ */
.combo{position:relative}
.combo-input{width:100%;padding:10px 32px 10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg3);font-size:14px;outline:none;transition:border .15s}
.combo-input:focus{border-color:var(--primary);background:var(--bg2)}
.combo-caret{position:absolute;right:12px;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--muted);font-size:12px;transition:transform .2s}
.combo.open .combo-caret{transform:translateY(-50%) rotate(180deg)}
.combo-panel{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);max-height:200px;overflow-y:auto;z-index:100;padding:4px}
.combo-panel[hidden]{display:none}
.combo-opt{padding:8px 12px;border-radius:6px;font-size:13px;cursor:pointer}
.combo-opt:hover,.combo-opt.active{background:var(--primary-bg);color:var(--primary)}

/* ============ Modal / Sheet ============ */
#modalRoot{position:fixed;inset:0;z-index:200;pointer-events:none}
#modalRoot.show{pointer-events:auto}
.modal-mask{position:fixed;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:flex-end;justify-content:center;opacity:0;transition:opacity .25s}
#modalRoot.show .modal-mask{opacity:1}
.sheet{background:var(--bg2);width:100%;max-width:520px;border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:16px 16px calc(var(--safe-b) + 16px);max-height:88vh;overflow-y:auto;transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1)}
.sheet.large{max-height:92vh}
#modalRoot.show .sheet{transform:translateY(0)}
.sheet-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border2)}
.sheet-head b{font-size:16px;font-weight:600}
.sheet-close{width:30px;height:30px;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:18px;line-height:1}
.sheet-body{margin-bottom:14px}
.sheet-foot{display:flex;gap:8px;position:sticky;bottom:0;background:var(--bg2);padding-top:10px}
.sheet-foot.multi{flex-direction:column}
.sheet-foot .btn{flex:1;padding:12px}
.sheet-foot.multi .btn{width:100%}

/* Legacy modal classes (kept for compatibility) */
.modal{background:var(--bg2);width:100%;max-width:520px;border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:16px 16px calc(var(--safe-b) + 16px);max-height:88vh;overflow-y:auto;transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1)}
.modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.modal-head h2{font-size:16px;font-weight:600;margin:0}
.modal-close{width:30px;height:30px;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:16px}
.modal-body{margin-bottom:14px}
.modal-foot{display:flex;gap:8px}
.modal-foot .btn{flex:1;padding:12px}
.confirm-msg{font-size:14px;color:var(--fg2);line-height:1.6;margin:0}

/* ============ Toast ============ */
.toast{position:fixed;bottom:calc(100px + var(--safe-b));left:50%;transform:translateX(-50%) translateY(20px);background:rgba(31,35,41,.95);color:#fff;padding:10px 18px;border-radius:20px;font-size:13px;z-index:300;opacity:0;transition:all .25s;max-width:90%;text-align:center;box-shadow:var(--shadow-lg)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ============ Data ============ */
.data-tabs{margin-bottom:14px}
.metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}
.metric{background:var(--bg2);border-radius:var(--radius);padding:12px;text-align:center;box-shadow:var(--shadow)}
.metric b{font-size:22px;font-weight:700;display:block}
.metric span{font-size:11px;color:var(--muted);margin-top:2px;display:block}
.datagrid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.datagrid .btn{padding:12px;font-size:13px}

/* Donut / Legend */
.donut{display:flex;justify-content:center;padding:8px}
.legend{display:flex;flex-wrap:wrap;gap:8px 14px;justify-content:center;padding:8px 12px 4px;font-size:12px;color:var(--fg2)}
.legend span{display:flex;align-items:center;gap:4px}
.legend i{width:10px;height:10px;border-radius:3px;display:inline-block}

/* Bars */
.bars{display:flex;flex-direction:column;gap:8px;padding:6px 4px}
.bar-row{display:flex;align-items:center;gap:8px;font-size:12px}
.bar-label{width:60px;flex-shrink:0;color:var(--fg2)}
.bar-track{flex:1;height:18px;background:var(--border2);border-radius:9px;overflow:hidden}
.bar-fill{height:100%;border-radius:9px;transition:width .4s}
.bar-val{width:60px;flex-shrink:0;text-align:right;color:var(--muted);font-size:11px}

/* Distribution */
.dist-row{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:12px}
.dist-label{width:36px;flex-shrink:0;color:var(--fg2)}
.dist-bar{flex:1;height:14px;background:var(--border2);border-radius:7px;overflow:hidden}
.dist-fill{height:100%;border-radius:7px;transition:width .4s}
.dist-val{width:30px;text-align:right;color:var(--muted)}

/* Table */
.stable{width:100%;border-collapse:collapse;font-size:13px}
.stable th,.stable td{padding:8px 10px;text-align:left;border-bottom:1px solid var(--border2)}
.stable th{color:var(--muted);font-weight:500;font-size:12px}
.stable td{color:var(--fg2)}
.stable td i{display:inline-block;width:8px;height:8px;border-radius:2px;margin-right:6px;vertical-align:middle}

/* ============ Settings ============ */
.setting-list{padding:0}
.setting-row{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-bottom:1px solid var(--border2);gap:10px}
.setting-row:last-child{border-bottom:none}
.setting-row>div{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}
.setting-row b{font-size:13px;font-weight:500}
.setting-row span{font-size:11px;color:var(--muted)}
.tpl-ico{width:28px;height:28px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;font-size:14px;margin-right:8px;vertical-align:middle}

/* Switch */
.switch{position:relative;width:42px;height:24px;flex-shrink:0}
.switch input{opacity:0;width:0;height:0}
.slider{position:absolute;inset:0;background:var(--border);border-radius:12px;transition:.25s;cursor:pointer}
.slider::before{content:'';position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.25s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.switch input:checked + .slider{background:var(--primary)}
.switch input:checked + .slider::before{transform:translateX(18px)}

/* Icon picker */
.icon-picker{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;padding:0 14px 14px}
.icon-opt{padding:8px;border-radius:var(--radius-sm);border:2px solid transparent;background:var(--bg3);transition:all .15s}
.icon-opt.active{border-color:var(--primary);background:var(--primary-bg)}
.icon-opt img{width:100%;height:auto;border-radius:12px;display:block}

/* About */
.about{display:flex;align-items:center;gap:14px}
.about-logo img{width:56px;height:56px;border-radius:14px}
.about-info{display:flex;flex-direction:column;gap:2px}
.about-info b{font-size:15px}
.about-info span{font-size:11px;color:var(--muted)}
.about-info .ver{font-size:11px;color:var(--muted2);margin-top:4px}

/* Template list */
.tpl-list{padding:0}
.tpl-item{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-bottom:1px solid var(--border2);gap:8px}
.tpl-item:last-child{border-bottom:none}
.tpl-item-main{display:flex;align-items:center;gap:8px;flex:1;min-width:0}
.tpl-item-main>div{display:flex;flex-direction:column;gap:2px;min-width:0}
.tpl-item-main b{font-size:13px}
.tpl-item-main span{font-size:11px;color:var(--muted)}
.tpl-item-actions{display:flex;gap:4px;flex-shrink:0}

/* Progress ring SVG */
.pring{display:block}

/* ============ Responsive ============ */
@media (min-width:560px){
  .app{box-shadow:0 0 30px rgba(0,0,0,.08)}
}

/* ============ Animations ============ */
@keyframes slideUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.view > *{animation:slideUp .25s ease}
