/* ============================================================
   Design Tokens
   ============================================================ */
:root {
  --primary: #6f5bff;
  --primary-light: #8a73ff;
  --primary-bg: #ede9ff;
  --primary-bg-light: #f5f2ff;
  --primary-bg-subtle: #faf8ff;

  --surface: #ffffff;
  --surface-2: #f7f8fc;
  --surface-3: #eef0f6;
  --border: #e6eaf2;
  --border-light: #f0f2f8;

  --text-primary: #1a1f36;
  --text-secondary: #6b7280;
  --text-muted: #9ca3af;

  --success: #22c55e;
  --success-bg: #dcfce7;
  --success-text: #16a34a;
  --warning: #f59e0b;
  --warning-bg: #fef3c7;
  --warning-text: #b45309;
  --danger: #ef4444;
  --danger-bg: #fee2e2;
  --danger-text: #dc2626;
  --info: #3b82f6;
  --info-bg: #dbeafe;
  --info-text: #1d4ed8;

  --sidebar-w: 228px;
  --r-sm: 6px;
  --r: 10px;
  --r-lg: 14px;
  --r-xl: 18px;
  --r-pill: 999px;
  --sh-sm: 0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --sh: 0 4px 12px rgba(0,0,0,.08),0 1px 3px rgba(0,0,0,.04);
  --sh-lg: 0 8px 32px rgba(0,0,0,.12),0 2px 8px rgba(0,0,0,.06);
  --sh-primary: 0 4px 16px rgba(111,91,255,.28);
}

/* ============================================================
   Reset
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter','Noto Sans JP',-apple-system,sans-serif;background:var(--surface-2);color:var(--text-primary);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}

/* ============================================================
   Layout
   ============================================================ */
.app-layout{display:flex;min-height:100vh}
.main-content{margin-left:var(--sidebar-w);flex:1;padding:28px 32px}

/* ============================================================
   Sidebar
   ============================================================ */
.sidebar{width:var(--sidebar-w);min-height:100vh;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;left:0;top:0;z-index:100;box-shadow:2px 0 8px rgba(0,0,0,.04)}
.sidebar-logo{display:flex;align-items:center;gap:10px;padding:20px 18px;border-bottom:1px solid var(--border-light)}
.logo-icon{width:32px;height:32px;background:linear-gradient(135deg,var(--primary),#a78bfa);border-radius:8px;display:flex;align-items:center;justify-content:center;color:white;font-size:14px;box-shadow:var(--sh-primary)}
.logo-text{font-size:15px;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}
.logo-ai{color:var(--primary)}
.sidebar-nav{flex:1;padding:12px 10px;overflow-y:auto}
.nav-section-label{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;padding:6px 10px 4px}
.nav-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:var(--r-sm);color:var(--text-secondary);font-size:13px;font-weight:500;text-decoration:none;cursor:pointer;transition:all .15s ease;position:relative}
.nav-item:hover{background:var(--surface-2);color:var(--text-primary)}
.nav-item.active{background:var(--primary-bg);color:var(--primary)}
.nav-icon{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0}
.nav-badge{margin-left:auto;background:var(--primary-bg);color:var(--primary);font-size:10px;font-weight:700;padding:1px 6px;border-radius:var(--r-pill);min-width:18px;text-align:center}
.nav-badge-red{background:var(--danger-bg);color:var(--danger)}
.sidebar-user{padding:14px;border-top:1px solid var(--border-light);display:flex;align-items:center;gap:9px;cursor:pointer}
.user-avatar{width:32px;height:32px;background:linear-gradient(135deg,var(--primary),#a78bfa);border-radius:50%;display:flex;align-items:center;justify-content:center;color:white;font-size:12px;font-weight:700;flex-shrink:0}
.user-name{font-size:12px;font-weight:600;color:var(--text-primary)}
.user-role{font-size:11px;color:var(--text-muted)}
.user-info{flex:1;min-width:0}
.user-more{color:var(--text-muted);font-size:12px}

/* ============================================================
   Page Header
   ============================================================ */
.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px}
.page-title{font-size:22px;font-weight:700;color:var(--text-primary);letter-spacing:-.5px}
.page-subtitle{font-size:13px;color:var(--text-secondary);margin-top:2px}

/* ============================================================
   Add Tool Button (primary CTA)
   ============================================================ */
.btn-add-tool{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:white;border:none;border-radius:var(--r-pill);padding:11px 24px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:var(--sh-primary);white-space:nowrap}
.btn-add-tool:hover{transform:translateY(-2px);box-shadow:0 6px 22px rgba(111,91,255,.38)}

/* ============================================================
   Section
   ============================================================ */
.section{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:20px 22px;box-shadow:var(--sh-sm)}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.section-title{font-size:15px;font-weight:700;color:var(--text-primary);display:flex;align-items:center}
.section-count{background:var(--surface-2);color:var(--text-secondary);font-size:11px;font-weight:600;padding:3px 10px;border-radius:var(--r-pill);border:1px solid var(--border)}

/* ============================================================
   Tools List (accordion cards)
   ============================================================ */
.tools-list{display:flex;flex-direction:column;gap:10px}
.tool-card{background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:border-color .2s ease}
.tool-card.open{border-color:var(--primary)}

/* Card header row */
.tool-card-header{display:flex;align-items:center;gap:12px;padding:13px 16px;cursor:pointer;user-select:none}
.tool-card-header:hover{background:rgba(111,91,255,.03)}
.tc-logo{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}
.tc-info{flex:1;min-width:0}
.tc-name{font-size:13px;font-weight:600;color:var(--text-primary)}
.tc-meta{font-size:11px;color:var(--text-muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tc-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.tc-chevron{color:var(--text-muted);font-size:12px;transition:transform .25s ease}
.tool-card.open .tc-chevron{transform:rotate(180deg)}

/* Card body */
.tool-card-body{border-top:1px solid var(--border);padding:0;max-height:0;overflow:hidden;transition:max-height .35s cubic-bezier(.4,0,.2,1),padding .35s ease}
.tool-card.open .tool-card-body{max-height:1200px;padding:16px 18px}

/* Schedule row inside card */
.tc-schedule-row{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:10px 14px;margin-bottom:14px}
.tc-schedule-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:2px}
.tc-schedule-value{font-size:13px;font-weight:500;color:var(--text-primary)}
.tc-edit-schedule-btn{display:inline-flex;align-items:center;gap:5px;background:var(--primary-bg);color:var(--primary);border:1px solid rgba(111,91,255,.2);border-radius:var(--r-pill);padding:6px 14px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s ease;white-space:nowrap}
.tc-edit-schedule-btn:hover{background:var(--primary);color:#fff}

/* Data items inside card */
.tc-data-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.tc-data-title{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px}
.tc-add-data-btn{display:inline-flex;align-items:center;gap:5px;background:transparent;color:var(--primary);border:1.5px solid var(--primary);border-radius:var(--r-pill);padding:5px 12px;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s ease}
.tc-add-data-btn:hover{background:var(--primary-bg)}

.data-items-list{display:flex;flex-direction:column;gap:7px}
.data-item-row{display:flex;align-items:center;justify-content:space-between;padding:9px 12px;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-sm)}
.dir-left{display:flex;align-items:center;gap:9px}
.dir-name{font-size:13px;font-weight:500;color:var(--text-primary)}
.dir-right{display:flex;align-items:center;gap:8px}

/* ============================================================
   Status Badges
   ============================================================ */
.s-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:3px 9px;border-radius:var(--r-pill);white-space:nowrap;text-transform:uppercase;letter-spacing:.3px}
.s-active{background:var(--success-bg);color:var(--success-text)}
.s-verifying{background:var(--warning-bg);color:var(--warning-text)}
.s-repair{background:var(--info-bg);color:var(--info-text)}
.s-error{background:var(--danger-bg);color:var(--danger-text)}

/* ============================================================
   Buttons
   ============================================================ */
.btn-primary{display:inline-flex;align-items:center;gap:7px;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:white;border:none;border-radius:var(--r-pill);padding:9px 20px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:var(--sh-primary);white-space:nowrap}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(111,91,255,.35)}
.btn-primary:disabled{background:var(--border);color:var(--text-muted);box-shadow:none;cursor:not-allowed;transform:none}
.btn-primary.btn-sm{padding:7px 14px;font-size:12px}

.btn-ghost{display:inline-flex;align-items:center;gap:6px;background:transparent;color:var(--text-secondary);border:none;border-radius:var(--r-pill);padding:9px 16px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease}
.btn-ghost:hover{background:var(--surface-2);color:var(--text-primary)}

.btn-outline-sm{background:transparent;color:var(--primary);border:1.5px solid var(--primary);border-radius:var(--r-pill);padding:6px 14px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s ease}
.btn-outline-sm:hover{background:var(--primary-bg)}

/* Other entry button — large & vibrant */
.btn-other-entry{display:inline-flex;align-items:center;gap:9px;background:linear-gradient(135deg,#ff6b6b,#ff8e53);color:white;border:none;border-radius:var(--r-pill);padding:13px 28px;font-size:14px;font-weight:700;cursor:pointer;transition:all .25s ease;box-shadow:0 4px 18px rgba(255,107,107,.4);white-space:nowrap;flex-shrink:0}
.btn-other-entry:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(255,107,107,.5)}

/* ============================================================
   Modal Base
   ============================================================ */
.modal-overlay{position:fixed;inset:0;background:rgba(26,31,54,.55);backdrop-filter:blur(4px);z-index:1000;display:none;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex;animation:fadeIn .2s ease}
.modal-container{background:var(--surface);border-radius:var(--r-xl);box-shadow:var(--sh-lg);width:100%;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;animation:slideUp .25s ease}
.modal-xl{max-width:820px}
.modal-step{display:flex;flex-direction:column}
.modal-step.hidden{display:none}
.modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:22px 28px 0;gap:16px}
.modal-title{font-size:18px;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}
.modal-subtitle{font-size:13px;color:var(--text-secondary);margin-top:4px}
.modal-close{width:32px;height:32px;background:var(--surface-2);border:1px solid var(--border);border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;transition:all .15s ease}
.modal-close:hover{background:var(--danger-bg);color:var(--danger);border-color:var(--danger)}
.modal-body{padding:20px 28px;flex:1}
.modal-footer{display:flex;align-items:center;justify-content:space-between;padding:16px 28px 24px;border-top:1px solid var(--border-light);gap:10px}

/* Step Navigator */
.modal-step-nav{display:flex;align-items:center;justify-content:center;padding:20px 24px 0;gap:0}
.step-item{display:flex;flex-direction:column;align-items:center;gap:5px;min-width:80px}
.step-dot{width:28px;height:28px;border-radius:50%;background:var(--border);color:var(--text-muted);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;transition:all .3s ease}
.step-item span{font-size:10px;font-weight:500;color:var(--text-muted);white-space:nowrap;transition:color .3s ease}
.step-item.active .step-dot{background:var(--primary);color:white;box-shadow:0 0 0 4px rgba(111,91,255,.15)}
.step-item.active span{color:var(--primary);font-weight:600}
.step-item.done .step-dot{background:var(--success);color:white}
.step-item.done span{color:var(--success)}
.step-connector{flex:1;height:2px;background:var(--border);margin-bottom:22px;max-width:60px;min-width:20px;transition:background .3s ease}
.step-connector.done{background:var(--success)}

/* ============================================================
   Entry Modal
   ============================================================ */
.entry-section{margin-bottom:20px}
.entry-section-label{font-size:12px;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.4px;display:flex;align-items:center;gap:7px;margin-bottom:12px}
.entry-tools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:9px;max-height:300px;overflow-y:auto;padding-right:2px;margin-bottom:12px}
.entry-tool-card{background:var(--surface-2);border:2px solid var(--border-light);border-radius:var(--r-lg);padding:12px 10px;cursor:pointer;transition:all .2s ease;text-align:center;position:relative;user-select:none}
.entry-tool-card:hover{border-color:var(--primary);background:var(--primary-bg-light);transform:translateY(-2px);box-shadow:var(--sh)}
.entry-tool-card.selected{border-color:var(--primary);background:var(--primary-bg);box-shadow:0 0 0 3px rgba(111,91,255,.12)}
.entry-tc-logo{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:16px;margin:0 auto 7px}
.entry-tc-name{font-size:11px;font-weight:600;color:var(--text-primary)}
.entry-tc-check{position:absolute;top:6px;right:6px;width:18px;height:18px;background:var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:8px;color:transparent;transition:all .2s ease}
.entry-tool-card.selected .entry-tc-check{background:var(--primary);color:white}
.entry-selected-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--primary-bg-light);border:1px solid rgba(111,91,255,.2);border-radius:var(--r);animation:slideUp .2s ease}

/* Other block in entry modal */
.entry-other-block{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 22px;background:linear-gradient(135deg,#fff5f5,#fff8f0);border:2px solid rgba(255,107,107,.2);border-radius:var(--r-lg)}
.entry-other-left{display:flex;align-items:center;gap:14px;flex:1}
.entry-other-icon{width:44px;height:44px;background:linear-gradient(135deg,#ff6b6b,#ff8e53);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;color:white;flex-shrink:0;box-shadow:0 4px 14px rgba(255,107,107,.35)}
.entry-other-title{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:2px}
.entry-other-desc{font-size:12px;color:var(--text-secondary)}

/* ============================================================
   Auth Tool Block (in known modal)
   ============================================================ */
.auth-block{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 20px;margin-bottom:16px}
.auth-block-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.ab-logo{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:16px}
.ab-name{font-size:14px;font-weight:600;color:var(--text-primary)}
.ab-cat{font-size:11px;color:var(--text-muted)}
.two-col-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* ============================================================
   Schedule Widget
   ============================================================ */
.schedule-widget{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);padding:16px 18px}
.sw-freq-row{display:flex;gap:8px;margin-bottom:16px}
.sw-freq-btn{flex:1;padding:9px 0;border:2px solid var(--border);border-radius:var(--r);background:var(--surface-2);font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .15s ease;text-align:center}
.sw-freq-btn.active{border-color:var(--primary);background:var(--primary-bg);color:var(--primary);font-weight:700}
.sw-detail{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
.sw-label{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px;margin-bottom:6px}
.sw-select,.sw-time-input{width:100%;padding:8px 12px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:13px;color:var(--text-primary);outline:none;transition:border-color .15s;font-family:inherit;appearance:none;cursor:pointer}
.sw-select:focus,.sw-time-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(111,91,255,.1)}

/* ============================================================
   Data Items Block (known modal step 2)
   ============================================================ */
.data-block{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 20px;margin-bottom:16px}
.data-block-header{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.checkbox-grid-2col{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:16px}
.cb-item{display:flex;align-items:center;gap:8px;padding:9px 11px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-sm);cursor:pointer;transition:all .15s ease;user-select:none}
.cb-item:hover{border-color:var(--primary);background:var(--primary-bg-light)}
.cb-item.checked{border-color:var(--primary);background:var(--primary-bg)}
.cb-item input[type=checkbox]{width:15px;height:15px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}
.cb-item span{font-size:12px;font-weight:500;color:var(--text-primary)}

/* ============================================================
   File Drop Zone
   ============================================================ */
.drop-zone{border:2px dashed var(--border);border-radius:var(--r-lg);padding:24px 20px;text-align:center;cursor:pointer;transition:all .2s ease;background:var(--surface-2)}
.drop-zone:hover,.drop-zone.dz-over{border-color:var(--primary);background:var(--primary-bg-light)}
.drop-zone>i{font-size:26px;color:var(--text-muted);margin-bottom:8px;display:block}
.drop-zone>p{font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:4px}
.drop-zone>span{font-size:11px;color:var(--text-muted);display:block;margin-bottom:12px}
.file-name{font-size:12px;color:var(--primary);font-weight:500;margin-top:8px}

/* ============================================================
   Form Fields
   ============================================================ */
.form-field{margin-bottom:0}
.form-label{display:block;font-size:11px;font-weight:700;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.4px}
.form-input{width:100%;padding:9px 14px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);font-size:13px;color:var(--text-primary);outline:none;transition:all .15s ease;font-family:inherit}
.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(111,91,255,.1)}
.form-input::placeholder{color:var(--text-muted)}
.form-hint{font-size:11px;color:var(--text-muted);margin-top:5px;display:flex;align-items:center;gap:4px}
.required-badge{background:var(--danger-bg);color:var(--danger);font-size:10px;font-weight:600;padding:1px 7px;border-radius:var(--r-pill);margin-left:6px;text-transform:none;letter-spacing:0}
.pw-wrap{position:relative}
.pw-wrap .form-input{padding-right:42px}
.pw-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:13px;padding:4px;transition:color .15s}
.pw-toggle:hover{color:var(--text-primary)}
.url-input-wrapper{position:relative;display:flex;align-items:center}
.url-icon{position:absolute;left:13px;color:var(--text-muted);font-size:13px}
.url-input{padding-left:38px !important;padding-right:40px !important}
.url-validate-icon{position:absolute;right:12px;font-size:14px}

/* ============================================================
   Info Notice
   ============================================================ */
.info-notice{display:flex;gap:12px;padding:13px 16px;background:var(--primary-bg-light);border:1px solid rgba(111,91,255,.15);border-radius:var(--r);color:var(--text-secondary);font-size:12px;line-height:1.6}
.info-notice strong{display:block;color:var(--text-primary);margin-bottom:2px;font-size:13px}
.info-notice p{margin:0}

/* ============================================================
   Analysis Box
   ============================================================ */
.analysis-box{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden}
.analysis-top{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:var(--surface);border-bottom:1px solid var(--border)}
.analysis-domain{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text-primary)}
.analysis-badge{display:flex;align-items:center;gap:6px;background:var(--primary-bg);color:var(--primary);font-size:11px;font-weight:600;padding:5px 12px;border-radius:var(--r-pill);animation:pulse 2s infinite}
.analysis-steps{padding:16px 20px;display:flex;flex-direction:column;gap:10px}
.al-row{display:flex;gap:12px;align-items:flex-start;padding:11px 14px;border-radius:var(--r);background:var(--surface);border:1px solid var(--border-light);transition:all .3s ease}
.al-row.al-active{border-color:var(--primary);background:var(--primary-bg-light)}
.al-row.al-done{border-color:var(--success);background:#f0fdf4}
.al-row.al-wait{opacity:.45}
.al-dot{width:26px;height:26px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px}
.al-dot.pending{background:var(--primary-bg);color:var(--primary)}
.al-dot.waiting{background:var(--border);color:var(--text-muted)}
.al-dot.done-dot{background:var(--success-bg);color:var(--success)}
.al-text b{font-size:13px;font-weight:600;color:var(--text-primary);display:block}
.al-text span{font-size:11px;color:var(--text-secondary)}
.analysis-found{padding:4px 20px 16px;display:flex;flex-wrap:wrap;gap:6px}
.found-tag{display:inline-flex;align-items:center;gap:5px;background:var(--success-bg);color:var(--success-text);font-size:11px;font-weight:500;padding:4px 10px;border-radius:var(--r-pill);animation:fadeIn .3s ease}

/* ============================================================
   Setting Block (unknown modal step 3)
   ============================================================ */
.setting-block{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 20px;margin-bottom:16px}
.setting-block-title{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.4px;margin-bottom:14px}
.ai-badge{background:var(--primary-bg);color:var(--primary);font-size:10px;font-weight:600;padding:2px 8px;border-radius:var(--r-pill);text-transform:none;letter-spacing:0}

/* Data item checkboxes (unknown modal) */
.data-items-check-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:8px}
.dic-item{display:flex;align-items:center;gap:8px;padding:9px 12px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);cursor:pointer;transition:all .15s ease;user-select:none}
.dic-item:hover{border-color:var(--primary);background:var(--primary-bg-light)}
.dic-item.checked{border-color:var(--primary);background:var(--primary-bg)}
.dic-item input{width:15px;height:15px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}
.dic-item label{font-size:12px;font-weight:500;color:var(--text-primary);cursor:pointer;flex:1}

/* Prompts list */
.prompt-entry{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);padding:16px 18px;margin-bottom:12px}
.prompt-entry-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.prompt-entry-title{font-size:13px;font-weight:600;color:var(--text-primary)}
.prompt-textarea{width:100%;min-height:110px;padding:11px 14px;background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--r);font-size:13px;color:var(--text-primary);outline:none;resize:vertical;transition:border-color .15s ease;font-family:inherit;line-height:1.7}
.prompt-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(111,91,255,.08);background:var(--surface)}
.prompt-hint{margin-top:6px;font-size:11px;color:var(--text-muted);display:flex;align-items:center;gap:5px}

/* ============================================================
   Complete Screen
   ============================================================ */
.complete-body{text-align:center;padding:28px 40px 20px}
.complete-icon-wrap{display:flex;justify-content:center;margin-bottom:20px}
.complete-circle{width:70px;height:70px;background:linear-gradient(135deg,var(--success),#4ade80);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;color:white;box-shadow:0 8px 24px rgba(34,197,94,.35);animation:popIn .5s cubic-bezier(.34,1.56,.64,1)}
.complete-title{font-size:20px;font-weight:700;color:var(--text-primary);margin-bottom:10px;letter-spacing:-.3px}
.complete-message{font-size:14px;color:var(--text-secondary);line-height:1.8;margin-bottom:22px}
.complete-message strong{color:var(--primary)}
.complete-cards{display:flex;flex-direction:column;gap:8px;max-width:400px;margin:0 auto}
.complete-card{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r);text-align:left}
.cc-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.cc-name{font-size:13px;font-weight:600;color:var(--text-primary)}
.cc-status{font-size:11px;color:var(--text-secondary)}

/* ============================================================
   Search bar
   ============================================================ */
.modal-search-bar{display:flex;align-items:center;gap:9px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-pill);padding:8px 16px;color:var(--text-muted)}
.modal-search-bar input{border:none;background:transparent;font-size:13px;color:var(--text-primary);outline:none;width:100%}

/* ============================================================
   Toast
   ============================================================ */
#toastWrap{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{display:flex;align-items:center;gap:9px;padding:11px 18px;border-radius:var(--r);box-shadow:var(--sh-lg);font-size:13px;font-weight:500;animation:slideInRight .3s ease;min-width:260px;color:white}
.toast-success{background:#15803d}
.toast-error{background:#dc2626}
.toast-info{background:var(--primary)}

/* ============================================================
   Animations
   ============================================================ */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideInRight{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
@keyframes popIn{from{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.65}}

/* ============================================================
   Scrollbar
   ============================================================ */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}
::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}

/* ============================================================
   Multi-file Upload Component
   ============================================================ */
.upload-zone-wrap{display:flex;flex-direction:column;gap:16px}

/* upload block per tool */
.upload-block{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}
.upload-block-header{display:flex;align-items:center;gap:10px;padding:14px 18px;background:var(--surface);border-bottom:1px solid var(--border)}
.upload-block-logo{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.upload-block-name{font-size:13px;font-weight:600;color:var(--text-primary)}
.upload-block-body{padding:16px 18px}

/* drop area */
.multi-drop{border:2px dashed var(--border);border-radius:var(--r-lg);padding:22px 16px;text-align:center;transition:all .2s ease;background:var(--surface);cursor:pointer}
.multi-drop:hover,.multi-drop.dz-over{border-color:var(--primary);background:var(--primary-bg-light)}
.multi-drop-icon{font-size:28px;color:var(--text-muted);margin-bottom:8px}
.multi-drop-text{font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:3px}
.multi-drop-hint{font-size:11px;color:var(--text-muted);margin-bottom:12px}

/* file list */
.file-list{display:flex;flex-direction:column;gap:8px;margin-top:14px}
.file-list-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r)}
.fli-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;background:var(--primary-bg);color:var(--primary)}
.fli-info{flex:1;min-width:0}
.fli-name{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fli-size{font-size:11px;color:var(--text-muted)}
.fli-right{display:flex;align-items:center;gap:6px;flex-shrink:0}
.fli-upload-btn{display:inline-flex;align-items:center;gap:5px;background:var(--primary);color:white;border:none;border-radius:var(--r-pill);padding:6px 14px;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s ease;white-space:nowrap}
.fli-upload-btn:hover{background:var(--primary-dark)}
.fli-upload-btn.uploaded{background:var(--success);cursor:default}
.fli-upload-btn:disabled{background:var(--border);color:var(--text-muted);cursor:not-allowed}
.fli-remove-btn{width:26px;height:26px;background:transparent;border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--text-muted);cursor:pointer;transition:all .15s ease}
.fli-remove-btn:hover{background:var(--danger-bg);color:var(--danger);border-color:var(--danger)}
.fli-progress{width:100%;height:3px;background:var(--border);border-radius:99px;margin-top:4px;overflow:hidden;display:none}
.fli-progress-bar{height:100%;background:var(--primary);border-radius:99px;width:0;transition:width .4s ease}
.fli-progress.show{display:block}

/* upload all button */
.upload-all-row{display:flex;align-items:center;justify-content:space-between;margin-top:12px;padding-top:12px;border-top:1px solid var(--border-light)}
.upload-all-count{font-size:12px;color:var(--text-muted)}
.btn-upload-all{display:inline-flex;align-items:center;gap:6px;background:var(--primary-bg);color:var(--primary);border:1.5px solid rgba(111,91,255,.25);border-radius:var(--r-pill);padding:7px 16px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s ease}
.btn-upload-all:hover{background:var(--primary);color:white;border-color:var(--primary)}

/* data item delete button in tool card */
.dir-del-btn{width:22px;height:22px;background:transparent;border:1px solid transparent;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--text-muted);cursor:pointer;transition:all .15s ease;flex-shrink:0}
.dir-del-btn:hover{background:var(--danger-bg);color:var(--danger);border-color:var(--danger)}

/* ============================================================
   Empty state
   ============================================================ */
.empty-state{text-align:center;padding:48px 20px;color:var(--text-muted)}
.empty-state i{font-size:40px;margin-bottom:12px;display:block;opacity:.4}
.empty-state p{font-size:14px}

/* ============================================================
   Responsive
   ============================================================ */
@media(max-width:768px){
  :root{--sidebar-w:0px}
  .sidebar{display:none}
  .main-content{margin-left:0;padding:20px 16px}
  .page-header{flex-direction:column;gap:12px}
  .modal-xl{max-width:100%}
  .two-col-grid,.checkbox-grid-2col{grid-template-columns:1fr}
}
