/* Spotsheet — Files tab (#3495). Scoped .ft-* under [data-page] not needed:
   all selectors are .ft-prefixed and self-contained. */

.ft-page { flex: 1; min-height: 0; display: flex; flex-direction: column; padding: 22px 26px; overflow-y: auto; background: var(--bg-app); color: var(--fg); }
.ft-page.mobile { padding: 16px 14px 90px; }

.ft-top { display: flex; align-items: flex-end; justify-content: space-between; gap: 12px; margin-bottom: 18px; }
.ft-h { font-size: 20px; font-weight: 600; letter-spacing: -0.01em; margin: 0; }
.ft-sub { display: block; font-size: 12px; color: var(--fg-dim); margin-top: 3px; }

.ft-btn { background: var(--teal); color: #06201f; border: none; border-radius: var(--r-btn, 6px); font: 600 13px/1 var(--ui); padding: 10px 16px; cursor: pointer; white-space: nowrap; }
.ft-btn:hover { filter: brightness(1.06); }
.ft-btn:disabled { opacity: .45; cursor: default; }
.ft-btn.ghost { background: transparent; color: var(--teal); border: 1px solid var(--teal-line, var(--line)); }
.ft-btn.danger { background: transparent; color: var(--st-danger, #f04747); border: 1px solid color-mix(in srgb, var(--st-danger, #f04747) 40%, transparent); }
.ft-btn.sm { padding: 6px 11px; font-size: 12px; }

.ft-loading, .ft-empty-sm { color: var(--fg-dim); font-size: 13px; }
.ft-empty { text-align: center; padding: 60px 20px; color: var(--fg-dim); }
.ft-empty-ic { font-size: 34px; margin-bottom: 10px; opacity: .7; }
.ft-empty-h { font-size: 15px; color: var(--fg); font-weight: 600; margin-bottom: 4px; }
.ft-empty-p { font-size: 12.5px; max-width: 340px; margin: 0 auto; }
.ft-err { color: var(--st-danger, #f04747); font-size: 12.5px; margin: 8px 0; }

.ft-list { display: flex; flex-direction: column; gap: 10px; }

/* avatars */
.ft-av { display: inline-flex; align-items: center; justify-content: center; border-radius: 50%; color: #06201f; font-weight: 700; font-family: var(--mono); flex: none; line-height: 1; }

/* card */
.ft-card { border: 1px solid var(--line); border-radius: var(--r-panel, 8px); background: var(--bg-panel); overflow: hidden; transition: border-color .15s; }
.ft-card.open { border-color: var(--teal-line, var(--line)); }
.ft-card-head { display: flex; align-items: center; gap: 12px; padding: 13px 15px; cursor: pointer; }
.ft-card-head:hover { background: var(--bg-row-hover); }
.ft-status { font: 600 9.5px/1 var(--mono); letter-spacing: .1em; text-transform: uppercase; padding: 5px 8px; border-radius: var(--r-micro, 4px); flex: none; }
.ft-status.ok { color: var(--teal); background: var(--teal-bg); }
.ft-status.wait { color: var(--st-flagged, #e0a52e); background: var(--st-flagged-bg, rgba(224,165,46,.1)); }
.ft-status.bad { color: var(--st-danger, #f04747); background: var(--st-danger-bg, rgba(240,71,71,.1)); }
.ft-card-title { flex: 1; min-width: 0; }
.ft-card-name { display: block; font-size: 14px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ft-card-meta { display: block; font-size: 11.5px; color: var(--fg-dim); font-family: var(--mono); margin-top: 2px; }
.ft-card-by { flex: none; }
.ft-caret { color: var(--fg-faint); font-size: 12px; flex: none; width: 14px; text-align: center; }

.ft-card-body { padding: 4px 15px 15px; border-top: 1px solid var(--line-soft, var(--line)); }
.ft-msg { font-size: 13px; color: var(--fg); background: var(--bg-sub, var(--bg-row)); border-radius: var(--r-2, 6px); padding: 9px 11px; margin: 12px 0; white-space: pre-wrap; }

.ft-files { display: flex; flex-direction: column; gap: 2px; margin: 10px 0; }
.ft-file { display: flex; align-items: center; gap: 10px; padding: 8px 4px; border-bottom: 1px solid var(--line-soft, var(--line)); }
.ft-file:last-child { border-bottom: none; }
.ft-file-dot { width: 7px; height: 7px; border-radius: 50%; flex: none; }
.ft-file-dot.ok { background: var(--teal); }
.ft-file-dot.wait { background: var(--st-flagged, #e0a52e); }
.ft-file-dot.bad { background: var(--st-danger, #f04747); }
.ft-file-name { flex: 1; min-width: 0; font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ft-file-size { font-size: 11.5px; color: var(--fg-dim); font-family: var(--mono); flex: none; }
.ft-file-state { font-size: 11px; color: var(--fg-faint); font-family: var(--mono); flex: none; }
.ft-dl { background: transparent; color: var(--teal); border: 1px solid var(--teal-line, var(--line)); border-radius: var(--r-micro, 4px); font: 600 11.5px/1 var(--ui); padding: 6px 11px; cursor: pointer; flex: none; }
.ft-dl:hover { background: var(--teal-bg); }

.ft-card-foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 10px; flex-wrap: wrap; }
.ft-recip-strip { display: flex; align-items: center; gap: 5px; flex-wrap: wrap; }
.ft-dlcount { font-size: 11px; color: var(--fg-dim); font-family: var(--mono); margin-left: 6px; }
.ft-card-actions { display: flex; align-items: center; gap: 8px; position: relative; }

.ft-link-wrap { position: relative; }
.ft-linkmenu { position: absolute; right: 0; bottom: calc(100% + 6px); width: 230px; background: var(--bg-panel); border: 1px solid var(--line-strong, var(--line)); border-radius: var(--r-2, 6px); box-shadow: var(--float, 0 8px 28px rgba(0,0,0,.45)); z-index: 30; padding: 5px; }
.ft-linkmenu-head { font: 600 9.5px/1 var(--mono); letter-spacing: .12em; text-transform: uppercase; color: var(--fg-dim); padding: 7px 8px 6px; }
.ft-linkmenu-row { display: flex; align-items: center; gap: 8px; width: 100%; background: transparent; border: none; color: var(--fg); padding: 7px 8px; border-radius: var(--r-micro, 4px); cursor: pointer; text-align: left; }
.ft-linkmenu-row:hover { background: var(--bg-row-hover); }
.ft-linkmenu-copy { margin-left: auto; font-size: 11px; color: var(--teal); font-family: var(--mono); }
.ft-recip-name { font-size: 12.5px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.ft-receipts { margin-top: 14px; border-top: 1px solid var(--line-soft, var(--line)); padding-top: 10px; }
.ft-receipts-head { font: 600 9.5px/1 var(--mono); letter-spacing: .12em; text-transform: uppercase; color: var(--fg-dim); margin-bottom: 8px; }
.ft-receipt { display: flex; align-items: center; gap: 8px; padding: 4px 0; }
.ft-receipt-at { margin-left: auto; font-size: 11px; color: var(--fg-faint); font-family: var(--mono); }

/* modal */
.ft-modal-wrap { position: fixed; inset: 0; background: rgba(0,0,0,.55); display: flex; align-items: center; justify-content: center; z-index: 200; padding: 18px; }
.ft-modal { width: 100%; max-width: 520px; max-height: 90vh; display: flex; flex-direction: column; background: var(--bg-panel); border: 1px solid var(--line-strong, var(--line)); border-radius: var(--r-sheet, 10px); box-shadow: var(--float, 0 18px 50px rgba(0,0,0,.5)); overflow: hidden; }
.ft-modal-head { display: flex; align-items: center; justify-content: space-between; padding: 16px 18px; border-bottom: 1px solid var(--line); font-size: 15px; font-weight: 600; }
.ft-x { background: transparent; border: none; color: var(--fg-dim); font-size: 22px; line-height: 1; cursor: pointer; padding: 0 4px; }
.ft-x:hover { color: var(--fg); }
.ft-modal-body { padding: 16px 18px; overflow-y: auto; }
.ft-modal-foot { display: flex; align-items: center; justify-content: flex-end; gap: 10px; padding: 14px 18px; border-top: 1px solid var(--line); }

.ft-lbl { display: block; font: 600 9.5px/1 var(--mono); letter-spacing: .13em; text-transform: uppercase; color: var(--fg-dim); margin: 16px 0 7px; }
.ft-lbl:first-child { margin-top: 0; }
.ft-opt { color: var(--fg-faint); font-weight: 500; text-transform: none; letter-spacing: 0; margin-left: 6px; }
.ft-in, .ft-ta { width: 100%; background: var(--inset-input, var(--bg-app)); border: 1px solid var(--line); border-radius: var(--r-2, 6px); color: var(--fg); font: 14px var(--ui); padding: 10px 12px; }
.ft-in:focus, .ft-ta:focus { outline: none; border-color: var(--teal); }
.ft-ta { resize: vertical; min-height: 44px; }

.ft-recips { display: flex; flex-wrap: wrap; gap: 7px; }
.ft-recip { display: inline-flex; align-items: center; gap: 7px; background: var(--bg-row); border: 1px solid var(--line); border-radius: 999px; padding: 5px 11px 5px 6px; cursor: pointer; color: var(--fg); }
.ft-recip:hover { border-color: var(--line-strong, var(--line)); }
.ft-recip.on { background: var(--teal-bg); border-color: var(--teal); }
.ft-recip-kind { font: 600 8.5px/1 var(--mono); letter-spacing: .08em; text-transform: uppercase; color: var(--fg-faint); }

.ft-drop { border: 1.5px dashed var(--line-strong, var(--line)); border-radius: var(--r-2, 6px); padding: 22px; text-align: center; cursor: pointer; color: var(--fg-dim); transition: border-color .12s, background .12s; }
.ft-drop:hover, .ft-drop.drag { border-color: var(--teal); background: var(--teal-bg); }
.ft-drop-ic { font-size: 22px; margin-bottom: 6px; opacity: .8; }
.ft-drop-link { color: var(--teal); }

.ft-sel { margin-top: 12px; }
.ft-sel-row { display: flex; align-items: center; gap: 10px; padding: 7px 2px; border-bottom: 1px solid var(--line-soft, var(--line)); }
.ft-sel-name { flex: 1; min-width: 0; font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ft-sel-size { font-size: 11.5px; color: var(--fg-dim); font-family: var(--mono); }
.ft-sel-x { background: transparent; border: none; color: var(--fg-faint); font-size: 18px; line-height: 1; cursor: pointer; }
.ft-sel-x:hover { color: var(--st-danger, #f04747); }

.ft-meter { margin-top: 10px; }
.ft-meter-bar { height: 5px; background: var(--bg-row); border-radius: 3px; overflow: hidden; }
.ft-meter-fill { height: 100%; background: var(--teal); transition: width .2s; }
.ft-meter.over .ft-meter-fill { background: var(--st-danger, #f04747); }
.ft-meter-txt { display: block; font-size: 11px; color: var(--fg-dim); font-family: var(--mono); margin-top: 5px; }
.ft-meter.over .ft-meter-txt { color: var(--st-danger, #f04747); }

.ft-upbar { flex: 1; position: relative; height: 38px; background: var(--bg-row); border-radius: var(--r-btn, 6px); overflow: hidden; }
.ft-upbar-fill { position: absolute; inset: 0; width: 0; background: var(--teal-bg); border-right: 2px solid var(--teal); transition: width .2s; }
.ft-upbar-txt { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font: 600 12.5px/1 var(--ui); color: var(--fg); }
