/* Link Biz - ファイル管理スタイル */

.files-layout{display:grid;grid-template-columns:16rem 1fr;gap:1rem;align-items:start}

/* フォルダツリー */
.folder-tree{background:var(--bg-surface);border-radius:var(--border-radius-lg);border:1px solid var(--border-color);overflow:hidden;box-shadow:var(--shadow-sm)}
.folder-tree-header{padding:.75rem 1rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}
.folder-tree-title{font-size:var(--font-size-sm);font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}
.folder-list{padding:.5rem 0}
.folder-item{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;cursor:pointer;font-size:var(--font-size-sm);color:var(--text-secondary);transition:background var(--transition),color var(--transition);position:relative}
.folder-item:hover{background:var(--bg-muted);color:var(--text-primary)}
.folder-item.active{background:var(--color-primary-light);color:var(--color-primary);font-weight:600}
.folder-item i{font-size:.9rem;flex-shrink:0}
.folder-item-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.folder-item-count{font-size:var(--font-size-xs);color:var(--text-muted);background:var(--bg-muted);border-radius:var(--border-radius-full);padding:0 .4rem;min-width:1.25rem;text-align:center}
.folder-item-actions{display:none;gap:.25rem}
.folder-item:hover .folder-item-actions{display:flex}
.folder-children{padding-left:1rem}

/* ファイルリスト */
.files-main{display:flex;flex-direction:column;gap:1rem}
.files-toolbar{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}
.files-search-wrap{flex:1;min-width:12rem;position:relative}
.files-search-wrap i{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:var(--font-size-sm)}
.files-search{padding-left:2.25rem !important}
.view-toggle{display:flex;border:1px solid var(--border-color);border-radius:var(--border-radius);overflow:hidden}
.view-toggle-btn{background:none;border:none;padding:.4rem .65rem;color:var(--text-muted);cursor:pointer;transition:background var(--transition),color var(--transition)}
.view-toggle-btn.active{background:var(--color-primary);color:#fff}

/* ファイルグリッド表示 */
.files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(10rem,1fr));gap:.75rem}
.file-card{background:var(--bg-surface);border-radius:var(--border-radius-lg);border:1px solid var(--border-color);padding:1rem;cursor:pointer;transition:box-shadow var(--transition),border-color var(--transition);display:flex;flex-direction:column;align-items:center;gap:.6rem;text-align:center}
.file-card:hover{box-shadow:var(--shadow-lg);border-color:var(--color-primary)}
.file-card-icon{font-size:2.5rem;line-height:1}
.file-card-name{font-size:var(--font-size-xs);font-weight:600;color:var(--text-primary);word-break:break-all;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.file-card-meta{font-size:.7rem;color:var(--text-muted)}

/* ファイルリスト表示 */
.files-list{}

/* ファイルアイコンカラー */
.fa-file-pdf{color:#ef4444}
.fa-file-word{color:#2563eb}
.fa-file-excel{color:#16a34a}
.fa-file-powerpoint{color:#ea580c}
.fa-file-image{color:#8b5cf6}
.fa-file-video{color:#0891b2}
.fa-file-audio{color:#d97706}
.fa-file-zipper{color:#92400e}
.fa-file-code{color:#0f766e}
.fa-file-csv{color:#16a34a}
.fa-file-lines{color:#64748b}
.fa-file{color:#94a3b8}

/* ファイル詳細モーダル */
.file-detail-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}
.file-detail-icon{font-size:3rem;flex-shrink:0}
.file-detail-info{}
.file-detail-name{font-size:var(--font-size-lg);font-weight:700;word-break:break-all;margin-bottom:.25rem}
.file-detail-meta{font-size:var(--font-size-sm);color:var(--text-secondary);display:flex;flex-wrap:wrap;gap:.5rem 1rem}
.file-detail-meta span{display:flex;align-items:center;gap:.3rem}

/* バージョン履歴 */
.version-list{display:flex;flex-direction:column;gap:.5rem}
.version-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;background:var(--bg-muted);border-radius:var(--border-radius);font-size:var(--font-size-sm)}
.version-num{font-weight:700;color:var(--color-primary);width:2rem;flex-shrink:0}
.version-info{flex:1;min-width:0}
.version-info-name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.version-info-meta{font-size:var(--font-size-xs);color:var(--text-muted)}
.version-current{font-size:var(--font-size-xs);font-weight:700;background:var(--color-primary-light);color:var(--color-primary);padding:.1rem .4rem;border-radius:var(--border-radius-full)}

/* コメント */
.comment-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}
.comment-item{display:flex;gap:.75rem}
.comment-avatar{width:2rem;height:2rem;border-radius:50%;background:var(--color-primary-light);color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}
.comment-content{flex:1;min-width:0}
.comment-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem;flex-wrap:wrap}
.comment-author{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary)}
.comment-time{font-size:var(--font-size-xs);color:var(--text-muted)}
.comment-body{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.6;white-space:pre-wrap;word-break:break-word}
.comment-form{display:flex;gap:.5rem;align-items:flex-end}
.comment-form .form-textarea{min-height:4rem;margin-bottom:0}

/* ドロップゾーン */
.drop-zone{border:2px dashed var(--border-color);border-radius:var(--border-radius-lg);padding:2rem;text-align:center;color:var(--text-muted);transition:border-color var(--transition),background var(--transition);cursor:pointer}
.drop-zone:hover,.drop-zone.drag-over{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary)}
.drop-zone i{font-size:2.5rem;margin-bottom:.75rem;display:block}
.drop-zone-text{font-size:var(--font-size-sm);margin-bottom:.25rem}
.drop-zone-hint{font-size:var(--font-size-xs)}

/* アップロード進捗 */
.upload-progress{margin-top:.75rem}
.progress-bar-wrap{height:.5rem;background:var(--border-color);border-radius:var(--border-radius-full);overflow:hidden}
.progress-bar{height:100%;background:var(--color-primary);border-radius:var(--border-radius-full);transition:width .2s ease}
.upload-filename{font-size:var(--font-size-xs);color:var(--text-secondary);margin-top:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* パンくずリスト */
.breadcrumb{display:flex;align-items:center;gap:.35rem;font-size:var(--font-size-sm);color:var(--text-secondary);flex-wrap:wrap;margin-bottom:.5rem}
.breadcrumb a{color:var(--color-primary);cursor:pointer}
.breadcrumb a:hover{text-decoration:underline}
.breadcrumb-sep{color:var(--text-muted);font-size:var(--font-size-xs)}
.breadcrumb-current{color:var(--text-primary);font-weight:600}

/* レスポンシブ */
@media(max-width:1024px){
  .files-layout{grid-template-columns:1fr}
  .folder-tree{display:none}
  .folder-tree.mobile-open{display:block;position:fixed;inset:0 0 0 0;z-index:300;border-radius:0;overflow-y:auto}
}
@media(max-width:640px){.files-grid{grid-template-columns:repeat(auto-fill,minmax(8rem,1fr))}}
