:root{
    --bg:#0b1622;
    --surface:#13212f;
    --raised:#1a2c3d;
    --border:#243648;
    --border-soft:#1d2e3f;
    --text:#e7eef5;
    --muted:#8499ad;
    --faint:#5d7088;
    --gold:#d4b46a;
    --gold-dim:#9a8447;
    --green:#6cc28e;
    --amber:#d9b15f;
    --red:#d3604a;
    --radius:14px;
    --mono:ui-monospace,"SF Mono",SFMono-Regular,Menlo,Consolas,monospace;
    --sans:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang TC","Noto Sans TC",sans-serif;
  }
  *{box-sizing:border-box}
  html,body{margin:0}
  html{-webkit-text-size-adjust:100%;text-size-adjust:100%}
  body{
    background:
      radial-gradient(900px 500px at 50% -10%, rgba(212,180,106,.07), transparent 60%),
      var(--bg);
    color:var(--text);
    font-family:var(--sans);
    line-height:1.5;
    -webkit-font-smoothing:antialiased;
    padding:max(20px,env(safe-area-inset-top)) 18px max(40px,env(safe-area-inset-bottom));
  }
  .wrap{max-width:580px;margin:0 auto}

  /* ---- header ---- */
  header{margin:8px 0 26px}
  .eyebrow{
    font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
    color:var(--gold-dim);display:flex;align-items:center;gap:9px;margin-bottom:14px;
  }
  .eyebrow .mark{width:9px;height:9px;border-radius:2px;background:var(--gold);
    box-shadow:0 0 14px rgba(212,180,106,.55);transform:rotate(45deg)}
  h1{font-size:27px;font-weight:680;letter-spacing:-.01em;margin:0 0 6px}
  .sub{color:var(--muted);font-size:14.5px;margin:0}

  /* ---- cards ---- */
  .card{
    background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
    padding:16px 16px 18px;margin-bottom:14px;
  }
  .card-label{
    font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
    color:var(--muted);display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;
  }
  .card-label a{color:var(--gold-dim);text-decoration:none;font-size:11px;letter-spacing:.04em;text-transform:none}
  .card-label a:hover{color:var(--gold)}

  label.field{display:block}
  .hint{color:var(--muted);font-size:12.5px;margin-top:9px;line-height:1.5}

  input[type=text],input[type=password]{
    width:100%;background:var(--raised);border:1px solid var(--border);color:var(--text);
    font-family:var(--mono);font-size:14px;border-radius:10px;padding:12px 13px;outline:none;
    transition:border-color .15s,box-shadow .15s;
  }
  input::placeholder{color:#4f6377}
  input:focus{border-color:var(--gold-dim);box-shadow:0 0 0 3px rgba(212,180,106,.12)}

  .pw{position:relative}
  .pw input{padding-right:46px}
  .eye{
    position:absolute;right:6px;top:50%;transform:translateY(-50%);width:34px;height:34px;
    border:0;background:transparent;color:var(--muted);cursor:pointer;border-radius:8px;
    display:grid;place-items:center;
  }
  .eye:hover{color:var(--gold);background:rgba(212,180,106,.08)}
  .eye svg{width:19px;height:19px}

  .row2{display:grid;grid-template-columns:1fr 150px;gap:10px}
  @media(max-width:430px){.row2{grid-template-columns:1fr}}

  /* 儲存庫輸入模式切換 */
  .seg{display:inline-flex;border:1px solid var(--border);border-radius:8px;overflow:hidden}
  .seg button{border:0;background:transparent;color:var(--muted);font-family:var(--mono);
    font-size:11px;letter-spacing:.04em;text-transform:none;padding:5px 10px;cursor:pointer}
  .seg button.on{background:var(--raised);color:var(--gold)}
  .repo-card #branch{margin-top:9px}
  .parts{display:flex;align-items:center;gap:8px;margin-top:0}
  .parts[hidden]{display:none}
  .parts input{flex:1;min-width:0}
  .parts .slash{flex:none;color:var(--muted);font-family:var(--mono);font-size:16px}

  /* ---- file picker ---- */
  .filepick{
    display:flex;align-items:center;gap:13px;width:100%;text-align:left;cursor:pointer;
    background:var(--raised);border:1px dashed var(--border);color:var(--text);
    border-radius:10px;padding:14px 14px;transition:border-color .15s,background .15s;
  }
  .filepick:hover{border-color:var(--gold-dim);background:#1d3043}
  .filepick .ico{width:38px;height:38px;border-radius:9px;background:rgba(212,180,106,.1);
    color:var(--gold);display:grid;place-items:center;flex:none}
  .filepick .ico svg{width:20px;height:20px}
  .filepick .t1{font-size:14.5px;font-weight:560}
  .filepick .t2{font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:2px;
    word-break:break-all}
  .filepick.has .t1{color:var(--gold)}

  /* ---- 不更新清單 ---- */
  details.adv summary{
    font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
    color:var(--muted);cursor:pointer;list-style:none;display:flex;align-items:center;gap:8px;
  }
  details.adv summary::-webkit-details-marker{display:none}
  details.adv summary::before{content:"+";color:var(--gold-dim);font-size:15px;width:11px;text-align:center}
  details.adv[open] summary::before{content:"\2013"}
  details.adv[open] summary{margin-bottom:12px}
  textarea{
    width:100%;background:var(--raised);border:1px solid var(--border);color:var(--text);
    font-family:var(--mono);font-size:13px;border-radius:10px;padding:11px 12px;outline:none;
    resize:vertical;line-height:1.7;min-height:78px;
  }
  textarea::placeholder{color:#4f6377}
  textarea:focus{border-color:var(--gold-dim);box-shadow:0 0 0 3px rgba(212,180,106,.12)}
  .hint code{font-family:var(--mono);background:rgba(212,180,106,.1);color:var(--gold);
    padding:1px 5px;border-radius:4px;font-size:12px}

  /* ---- buttons ---- */
  .btn{
    width:100%;border:0;border-radius:11px;padding:14px;font-family:var(--sans);font-size:15px;
    font-weight:620;cursor:pointer;transition:filter .15s,opacity .15s;letter-spacing:.01em;
  }
  .btn-ghost{background:var(--raised);color:var(--text);border:1px solid var(--border)}
  .btn-ghost:hover:not(:disabled){border-color:var(--gold-dim);color:var(--gold)}
  .btn-gold{background:linear-gradient(180deg,#e0c279,#c9a557);color:#241c08;
    box-shadow:0 6px 18px rgba(201,165,87,.22)}
  .btn-gold:hover:not(:disabled){filter:brightness(1.05)}
  .btn:disabled{opacity:.4;cursor:not-allowed}
  .btn-gap{margin-top:12px}
  .btn-link{background:transparent;color:var(--muted);font-weight:520;font-size:13.5px;
    padding:11px;margin-top:4px}
  .btn-link:hover{color:var(--gold)}

  /* ---- diff panel ---- */
  .diff{display:none;animation:fade .25s ease}
  .diff.show{display:block}
  .diff-head{
    display:flex;align-items:baseline;gap:10px;font-family:var(--mono);font-size:11px;
    letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:4px;
  }
  .diff-count{
    margin-left:auto;font-size:12px;letter-spacing:0;color:var(--bg);background:var(--gold);
    font-weight:700;border-radius:999px;padding:1px 9px;text-transform:none;
  }
  .diff-list{margin:12px 0 0;border-top:1px solid var(--border-soft)}
  .drow{
    display:flex;align-items:center;gap:10px;padding:9px 2px;border-bottom:1px solid var(--border-soft);
    font-family:var(--mono);font-size:13.5px;
  }
  .drow .name{color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .drow .dir{color:#5a6e82}
  .drow .ext{color:#5a6e82;margin-left:8px;flex:none}
  .drow .flag{margin-left:auto;flex:none;width:20px;text-align:center;font-weight:700;font-size:13px}
  .drow.A .flag{color:var(--green)} .drow.A .dot{background:var(--green)}
  .drow.M .flag{color:var(--amber)} .drow.M .dot{background:var(--amber)}
  .drow.D .name{color:#7d8a96;text-decoration:line-through;text-decoration-color:#80493e}
  .drow.D .flag{color:var(--red)} .drow.D .dot{background:var(--red)}
  .drow.U .dot,.drow.R .dot{background:#56697d}
  .drow.U .name,.drow.R .name{color:#9fb0c2}
  .drow .dot{width:7px;height:7px;border-radius:50%;flex:none}
  .diff-foot{color:var(--muted);font-size:12.5px;margin-top:12px;display:flex;
    flex-direction:column;gap:5px}
  .diff-foot .warn{color:var(--amber)}
  .nochange{color:var(--muted);font-size:14px;text-align:center;padding:14px 0}

  /* 我的專案選擇器 */
  #pickerSearch{margin-bottom:2px}
  .repo-row{display:flex;align-items:center;gap:9px;width:100%;text-align:left;
    border:0;border-bottom:1px solid var(--border-soft);background:transparent;color:var(--text);
    cursor:pointer;padding:11px 2px;font-family:var(--mono);font-size:13.5px}
  .repo-row:hover{background:rgba(212,180,106,.06)}
  .repo-row .repo-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .repo-badge{flex:none;font-family:var(--sans);font-size:10px;padding:2px 7px;border-radius:6px;letter-spacing:.02em}
  .repo-badge.priv{background:rgba(212,180,106,.16);color:var(--gold)}
  .repo-badge.pub{background:var(--raised);color:var(--muted)}
  .repo-when{flex:none;color:#5a6e82;font-size:11px}
  .unchanged-toggle{width:100%;text-align:left;background:transparent;border:0;cursor:pointer;
    color:var(--muted);font-size:12.5px;padding:11px 2px 3px;font-family:var(--mono);
    display:flex;align-items:center;gap:7px}
  .unchanged-toggle:hover{color:var(--gold)}
  .unchanged-toggle .tw{color:var(--gold-dim);font-size:10px;width:10px}
  .panel-close{flex:none;width:26px;height:26px;border:0;border-radius:7px;
    background:var(--raised);color:var(--muted);font-size:12px;cursor:pointer;margin-left:8px}
  .panel-close:hover{color:var(--gold)}

  /* ---- progress / status ---- */
  .bar{height:3px;background:var(--border);border-radius:3px;overflow:hidden;margin:14px 0 0;display:none}
  .bar.show{display:block}
  .bar i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--gold-dim),var(--gold));
    transition:width .3s ease}
  .status{font-family:var(--mono);font-size:12.5px;color:var(--muted);margin-top:10px;min-height:1px}
  .status.err{color:var(--red);white-space:pre-wrap}

  /* ---- success ---- */
  .done{display:none;border-color:var(--gold-dim);background:linear-gradient(180deg,#16261c,#13212f)}
  .done.show{display:block;animation:fade .3s ease}
  .done h3{margin:0 0 6px;font-size:17px;color:var(--green);display:flex;align-items:center;gap:9px}
  .done h3 svg{width:20px;height:20px}
  .done p{color:var(--muted);font-size:13.5px;margin:0 0 14px}
  .done a.link{
    display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:13px;
    color:var(--gold);text-decoration:none;border:1px solid var(--gold-dim);border-radius:9px;
    padding:9px 13px;word-break:break-all;
  }
  .done a.link:hover{background:rgba(212,180,106,.08)}

  footer{display:flex;align-items:center;justify-content:center;gap:7px;
    color:#4d6075;font-family:var(--mono);font-size:11.5px;
    letter-spacing:.05em;margin-top:30px}
  .brand-mark{flex:none;width:16px;height:16px;color:var(--gold-dim)}

  @keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

  /* ---- 點擊列 + 差異檢視 ---- */
  .drow{cursor:pointer}
  .drow:active{background:rgba(255,255,255,.035)}
  .drow .chev{margin-left:11px;flex:none;color:#3f5468;font-size:17px;line-height:1}
  .rowact{flex:none;width:24px;height:24px;margin-left:10px;border:1px solid var(--border);
    border-radius:6px;background:var(--raised);color:var(--muted);cursor:pointer;
    font-size:15px;line-height:1;display:grid;place-items:center;padding:0}
  .rowact:hover{color:var(--red);border-color:#5a3a34}
  .rowact.include{color:var(--green)}
  .rowact.include:hover{color:var(--green);border-color:#2f5a40;background:rgba(108,194,142,.1)}
  .modal{position:fixed;inset:0;background:rgba(4,9,15,.74);display:none;z-index:50}
  .modal.show{display:flex;flex-direction:column;animation:fade .2s ease}
  .modal-card{background:var(--surface);display:flex;flex-direction:column;
    width:100%;height:100%;max-width:780px;margin:0 auto}
  .modal-head{display:flex;align-items:center;gap:12px;padding:14px 16px;
    padding-top:max(14px,env(safe-area-inset-top));border-bottom:1px solid var(--border);flex:none}
  .modal-path{font-family:var(--mono);font-size:13px;color:var(--gold);
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .modal-close{margin-left:auto;flex:none;width:34px;height:34px;border:0;border-radius:8px;
    background:var(--raised);color:var(--muted);font-size:14px;cursor:pointer}
  .modal-close:hover{color:var(--gold)}
  .modal-actions{flex:none;padding:10px 16px;border-bottom:1px solid var(--border)}
  .ig-btn{width:100%;border:1px solid var(--border);background:var(--raised);color:var(--text);
    border-radius:9px;padding:10px;font-family:var(--sans);font-size:13.5px;font-weight:560;cursor:pointer}
  .ig-btn:hover{border-color:var(--gold-dim)}
  .ig-btn.on{background:rgba(212,180,106,.12);border-color:var(--gold-dim);color:var(--gold)}
  .modal-body{flex:1;overflow:auto;padding:10px 0 calc(40px + env(safe-area-inset-bottom));
    -webkit-overflow-scrolling:touch}
  .dl-wrap{width:max-content;min-width:100%}
  .dl{white-space:pre;font-family:var(--mono);font-size:12.5px;line-height:1.65;padding:0 14px}
  .dl.add{background:rgba(108,194,142,.13);color:#c4e8d3}
  .dl.del{background:rgba(211,96,74,.13);color:#f0b6a9}
  .dl.ctx{color:#7e92a6}
  .dl.gap{color:#5d7088;text-align:center;background:transparent;white-space:normal;
    padding:9px 14px;font-size:11.5px;letter-spacing:.05em;min-width:100%;box-sizing:border-box}
  .dl-wrap .dl.gap{text-align:left}
  @media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ---- 版本更新橫幅 ---- */
.update-banner{display:flex;align-items:center;gap:10px;background:rgba(212,180,106,.1);
  border:1px solid var(--gold-dim);border-radius:12px;padding:11px 13px;margin-bottom:16px;
  font-size:13.5px;color:var(--gold)}
.update-banner[hidden]{display:none}
.update-banner .ub-text{flex:1;line-height:1.4}
.update-banner .ub-more{flex:none;border:0;background:transparent;color:var(--gold);
  font-family:var(--sans);font-size:13px;font-weight:600;cursor:pointer;
  text-decoration:underline;text-underline-offset:2px;padding:0}
.update-banner .ub-x{flex:none;width:26px;height:26px;border:0;border-radius:7px;
  background:transparent;color:var(--gold-dim);cursor:pointer;font-size:12px}
.update-banner .ub-x:hover{color:var(--gold)}

/* 執行中偵測到新版的提示（加入主畫面後也能更新） */
.update-toast{position:fixed;left:50%;bottom:18px;transform:translateX(-50%);z-index:60;
  display:flex;align-items:center;gap:10px;max-width:calc(100% - 28px);
  background:var(--card);border:1px solid var(--gold-dim);border-radius:12px;
  padding:9px 11px;font-size:13px;color:var(--text);box-shadow:0 10px 30px rgba(0,0,0,.45)}
.update-toast[hidden]{display:none}
.update-toast b{color:var(--gold);font-weight:700}
.update-toast .ut-go{flex:none;border:0;background:var(--gold);color:#1a1205;font-weight:700;
  border-radius:8px;padding:6px 12px;cursor:pointer;font-family:var(--sans);font-size:12.5px}
.update-toast .ut-x{flex:none;border:0;background:transparent;color:var(--muted);
  cursor:pointer;font-size:12px;padding:2px 4px}
.update-toast .ut-x:hover{color:var(--text)}

/* ---- 壓縮檔清除鍵 ---- */
.filerow{display:flex;gap:10px;align-items:stretch}
.filerow .filepick{flex:1}
.fileclear{flex:none;width:50px;border:1px solid var(--border);background:var(--raised);
  color:var(--muted);border-radius:10px;cursor:pointer;font-size:15px}
.fileclear:hover{color:var(--red);border-color:#5a3a34}

/* ---- 不更新標籤 ---- */
.chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:11px}
.chips:empty{display:none}
.chip{display:inline-flex;align-items:center;gap:5px;background:var(--raised);
  border:1px solid var(--border);border-radius:999px;padding:5px 6px 5px 11px;
  font-family:var(--mono);font-size:12px;color:var(--text)}
.chip-x{border:0;background:transparent;color:var(--muted);cursor:pointer;font-size:10px;
  width:18px;height:18px;border-radius:50%;display:grid;place-items:center}
.chip-x:hover{color:var(--red);background:rgba(211,96,74,.14)}

/* ---- 頁尾版本鍵 ---- */
.ver-btn{border:0;background:transparent;color:#4d6075;font-family:var(--mono);
  font-size:11.5px;letter-spacing:.05em;cursor:pointer;padding:0;
  text-decoration:underline;text-underline-offset:2px}
.ver-btn:hover{color:var(--gold)}

/* ---- 更新紀錄 ---- */
.cl{padding:4px 16px 22px}
.cl-ver{display:flex;align-items:baseline;gap:10px;margin:20px 0 10px;padding-bottom:8px;
  border-bottom:1px solid var(--border-soft)}
.cl-ver:first-child{margin-top:6px}
.cl-v{font-family:var(--mono);font-size:15px;color:var(--gold);font-weight:600}
.cl-date{font-family:var(--mono);font-size:12px;color:var(--muted)}
.cl-item{display:flex;gap:10px;align-items:flex-start;padding:5px 0;font-size:13.5px;
  color:var(--text);line-height:1.55}
.cl-tag{flex:none;font-size:11px;border-radius:5px;padding:1px 8px;font-weight:600;margin-top:2px}
.cl-feat{background:rgba(108,194,142,.15);color:var(--green)}
.cl-change{background:rgba(217,177,95,.15);color:var(--amber)}
.cl-fix{background:rgba(211,96,74,.15);color:var(--red)}

/* ---- 常用儲存庫標籤 ---- */
.recents{margin-top:11px;align-items:center}
.recent-label{font-family:var(--mono);font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted);align-self:center}
.rchip{display:inline-flex;align-items:stretch;background:var(--raised);
  border:1px solid var(--border);border-radius:999px;overflow:hidden;
  font-family:var(--mono);font-size:12px}
.rchip-pick{border:0;background:transparent;color:var(--text);cursor:pointer;
  padding:6px 6px 6px 12px;font-family:inherit;font-size:inherit}
.rchip-pick:hover{color:var(--gold)}
.rchip-x{border:0;background:transparent;color:var(--muted);cursor:pointer;
  padding:0 10px 0 4px;font-size:10px}
.rchip-x:hover{color:var(--red);background:rgba(211,96,74,.14)}
