/* ============================================================
   Ferro — settings.css
   ============================================================ */

.app-settings{flex:1;display:grid;grid-template-columns:260px 1fr;min-height:0;background:var(--paper)}

.set-nav{background:linear-gradient(180deg,var(--paper-2),color-mix(in srgb,var(--paper-2) 90%, #000 4%));border-right:1px solid var(--line);display:flex;flex-direction:column;min-height:0;overflow-y:auto}
.set-nav .sh{display:flex;align-items:center;gap:11px;padding:22px 20px 16px}
.set-nav .sh .back{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink-soft);border:1px solid var(--line);background:var(--card);transition:.12s}
.set-nav .sh .back:hover{color:var(--accent);border-color:var(--accent)}
.set-nav .sh .back svg{width:16px;height:16px}
.set-nav .sh h2{font-family:var(--serif);font-weight:600;font-size:21px}
.set-nav .grp{padding:0 12px}
.set-nav .gh{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);padding:14px 12px 7px}
.set-nav .si{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:9px;cursor:pointer;font-size:13.5px;color:var(--ink-soft);font-weight:500;position:relative;transition:.12s}
.set-nav .si:hover{background:color-mix(in srgb,var(--accent) 7%, transparent);color:var(--ink)}
.set-nav .si.active{background:var(--card);color:var(--ink);box-shadow:var(--shadow);font-weight:600}
.set-nav .si.active::before{content:"";position:absolute;left:-12px;top:8px;bottom:8px;width:3px;border-radius:0 3px 3px 0;background:var(--accent)}
.set-nav .si svg{width:17px;height:17px;color:var(--ink-faint)}
.set-nav .si.active svg{color:var(--accent)}

.set-body{overflow-y:auto;min-height:0;padding:34px 44px 60px}
.set-pane{max-width:760px;margin:0 auto;animation:fade .4s ease both}
.set-pane>h1{font-family:var(--serif);font-weight:600;font-size:28px;margin-bottom:6px}
.set-pane>.lead{font-size:13.5px;color:var(--ink-faint);line-height:1.55;margin-bottom:28px;max-width:520px}

.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow);margin-bottom:18px;overflow:hidden}
.card .ch{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--line-soft)}
.card .ch .ci{width:38px;height:38px;border-radius:10px;background:var(--accent-tint);color:var(--accent-deep);display:flex;align-items:center;justify-content:center;flex:0 0 38px}
.card .ch .ci svg{width:19px;height:19px}
.card .ch .ct{flex:1}
.card .ch .ct b{font-size:14.5px;display:block}
.card .ch .ct span{font-size:12px;color:var(--ink-faint)}
.card .ch .pill{font-family:var(--mono);font-size:10px;color:var(--accent-deep);background:var(--accent-tint);padding:3px 9px;border-radius:20px;font-weight:600}
.card .cb{padding:8px 20px 18px}

/* settings row */
.srow{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--line-soft)}
.srow:last-child{border-bottom:none}
.srow .info{flex:1;min-width:0}
.srow .info b{font-size:13.5px;display:block;margin-bottom:2px}
.srow .info span{font-size:12px;color:var(--ink-faint);line-height:1.5}

/* toggle */
.toggle{width:44px;height:25px;border-radius:20px;background:var(--line);position:relative;cursor:pointer;flex:0 0 44px;transition:background .2s}
.toggle::after{content:"";position:absolute;top:3px;left:3px;width:19px;height:19px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.2);transition:transform .2s}
.toggle.on{background:var(--accent)}
.toggle.on::after{transform:translateX(19px)}

/* select / input */
.sselect,.sinput{border:1px solid var(--line);background:var(--paper);border-radius:8px;padding:8px 12px;font-size:13px;color:var(--ink);outline:none;transition:border-color .12s}
.sselect:focus,.sinput:focus{border-color:var(--accent)}
.sinput.full{width:100%}

/* account list in settings */
.acct-card{display:flex;align-items:center;gap:13px;padding:13px 16px;border:1px solid var(--line);border-radius:var(--r-md);margin-bottom:10px;background:var(--paper);transition:.12s}
.acct-card:hover{border-color:var(--accent)}
.acct-card .dot{width:11px;height:11px;border-radius:50%;flex:0 0 11px}
.acct-card .m{flex:1;min-width:0}
.acct-card .m b{font-size:13.5px;display:block}
.acct-card .m span{font-size:12px;color:var(--ink-faint)}
.acct-card .st{font-size:11px;color:var(--green);font-weight:600;display:flex;align-items:center;gap:5px}
.acct-card .st i{width:6px;height:6px;border-radius:50%;background:var(--green)}

/* theme picker */
.theme-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:4px}
.theme-opt{border:2px solid var(--line);border-radius:var(--r-lg);overflow:hidden;cursor:pointer;transition:.15s;position:relative}
.theme-opt:hover{border-color:var(--accent)}
.theme-opt.active{border-color:var(--accent)}
.theme-opt.active::after{content:"✓";position:absolute;top:8px;right:8px;width:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}
.theme-opt .pv{height:96px;display:flex}
.theme-opt .pv .a{width:34%;}
.theme-opt .pv .b{flex:1}
.theme-opt .lbl{padding:10px 14px;font-size:13px;font-weight:600;background:var(--card)}
.theme-opt.light .pv .a{background:#efe8dc}.theme-opt.light .pv .b{background:#f6f1e9}
.theme-opt.dark .pv .a{background:#211e1a}.theme-opt.dark .pv .b{background:#1c1a17}
.theme-opt .pv .strip{height:8px;margin:14px 12px 0;border-radius:4px;background:var(--accent)}

.accent-row{display:flex;gap:12px;margin-top:6px}
.accent-dot{width:34px;height:34px;border-radius:10px;cursor:pointer;border:2px solid transparent;transition:.15s;position:relative}
.accent-dot:hover{transform:scale(1.08)}
.accent-dot.active{border-color:var(--ink)}
.accent-dot.active::after{content:"";position:absolute;inset:0;margin:auto;width:10px;height:10px;border-radius:50%;background:#fff}

/* signatures */
.sig-list .sig-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--line);border-radius:var(--r-md);margin-bottom:10px;cursor:pointer;background:var(--paper);transition:.12s}
.sig-list .sig-item:hover{border-color:var(--accent)}
.sig-list .sig-item.active{border-color:var(--accent);background:var(--accent-tint)}
.sig-item .si-name{font-size:13.5px;font-weight:600;display:flex;align-items:center;gap:8px}
.sig-item .si-name .def{font-family:var(--mono);font-size:9px;background:var(--accent);color:#fff;padding:2px 6px;border-radius:5px}
.sig-item .si-acct{font-size:11.5px;color:var(--ink-faint);margin-top:2px}
.sig-item .si-meta{margin-left:auto;text-align:right;font-size:11px;color:var(--ink-faint)}
.sig-preview{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);padding:18px;font-size:13px;color:var(--ink-soft);line-height:1.6}
.sig-preview b{color:var(--ink)}

/* rules */
.rule{border:1px solid var(--line);border-radius:var(--r-md);margin-bottom:12px;background:var(--paper);overflow:hidden}
.rule .rh{display:flex;align-items:center;gap:12px;padding:13px 16px}
.rule .rh .grip{color:var(--ink-faint);cursor:grab}
.rule .rh .grip svg{width:16px;height:16px}
.rule .rh .rn{font-size:13.5px;font-weight:600;flex:1}
.rule .rb{padding:0 16px 14px;display:flex;flex-wrap:wrap;gap:8px;align-items:center;font-size:12.5px;color:var(--ink-faint)}
.rule .cond{display:inline-flex;align-items:center;gap:6px;background:var(--card);border:1px solid var(--line-soft);border-radius:20px;padding:4px 11px}
.rule .cond b{color:var(--ink-soft)}
.rule .arrow{color:var(--accent)}
.rule .act{display:inline-flex;align-items:center;gap:6px;background:var(--accent-tint);color:var(--accent-deep);border-radius:20px;padding:4px 11px;font-weight:600}

/* labels */
.label-chip{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:20px;padding:6px 13px;font-size:12.5px;font-weight:600;margin:0 8px 8px 0;background:var(--paper)}
.label-chip .lc{width:11px;height:11px;border-radius:50%}
.label-chip .x{cursor:pointer;color:var(--ink-faint);display:flex}
.label-chip .x:hover{color:#c0392b}
.label-chip .x svg{width:12px;height:12px}

.btn-add{display:inline-flex;align-items:center;gap:8px;border:1px dashed var(--line);color:var(--ink-faint);border-radius:var(--r-md);padding:10px 16px;cursor:pointer;font-size:13px;font-weight:600;transition:.12s}
.btn-add:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-tint)}
.btn-add svg{width:15px;height:15px}

.kbd-table{width:100%;border-collapse:collapse}
.kbd-table td{padding:10px 0;border-bottom:1px solid var(--line-soft);font-size:13px;color:var(--ink-soft)}
.kbd-table td:last-child{text-align:right}
.kbd-table tr:last-child td{border-bottom:none}

.statgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:18px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px 20px;box-shadow:var(--shadow)}
.stat .n{font-family:var(--serif);font-weight:600;font-size:30px;color:var(--accent-deep);line-height:1}
.stat .l{font-size:12px;color:var(--ink-faint);margin-top:6px}
