:root{
  --bg:#f5f5f3;--bg2:#ffffff;--ink:#0b0b0c;--muted:#6f737a;--soft:#9ca3af;--card:#ffffff;--card2:#fafafa;--line:#e6e6e6;--line2:#d7d7d7;--black:#111214;--black2:#1c1d20;--white:#fff;--ok:#0f766e;--danger:#c0392b;--shadow:0 24px 70px rgba(0,0,0,.08);--shadow2:0 12px 34px rgba(0,0,0,.08);--radius:22px;--radius2:16px}
*{box-sizing:border-box}html{background:var(--bg)}body{margin:0;font-family:Inter,Arial,"Microsoft YaHei",sans-serif;background:linear-gradient(135deg,#f7f7f5 0%,#ededeb 48%,#fafafa 100%);color:var(--ink);letter-spacing:-.01em}a{text-decoration:none;color:inherit}button,input,select,textarea{font-family:inherit}.layout{display:grid;grid-template-columns:284px 1fr;min-height:100vh}.sidebar{background:rgba(255,255,255,.86);border-right:1px solid var(--line);padding:22px 18px;position:sticky;top:0;height:100vh;backdrop-filter:blur(18px);box-shadow:8px 0 38px rgba(0,0,0,.035)}.brand{display:flex;gap:12px;align-items:center;margin-bottom:28px;padding:8px 6px}.logo{width:46px;height:46px;border-radius:15px;background:linear-gradient(135deg,#050505,#1f1f22);color:#fff;display:grid;place-items:center;font-weight:900;box-shadow:0 16px 34px rgba(0,0,0,.22)}.brand h1{font-size:16px;margin:0;font-weight:900;letter-spacing:-.03em}.brand p{font-size:12px;margin:4px 0 0;color:var(--muted)}.nav{display:grid;gap:7px}.nav a{display:flex;gap:11px;align-items:center;padding:13px 14px;border-radius:15px;color:#34363a;font-weight:700;transition:.18s;border:1px solid transparent}.nav a.active,.nav a:hover{background:#111214;color:#fff;box-shadow:0 14px 32px rgba(0,0,0,.18);transform:translateX(2px)}.main{padding:24px 28px 42px}.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px}.pill{border:1px solid var(--line);background:#fff;border-radius:999px;padding:10px 15px;color:#111214;font-weight:800;box-shadow:0 10px 30px rgba(0,0,0,.05)}.grid{display:grid;grid-template-columns:1.05fr .95fr;gap:22px;align-items:start}.card{background:rgba(255,255,255,.92);border:1px solid var(--line);border-radius:26px;padding:24px;box-shadow:var(--shadow);backdrop-filter:blur(12px)}.card h2{margin:0 0 16px;font-size:21px;font-weight:950;letter-spacing:-.04em}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.field{margin-bottom:15px}label{font-size:13px;font-weight:900;color:#25262a;display:block;margin-bottom:8px}input,select,textarea{width:100%;padding:14px 15px;border:1px solid var(--line2);border-radius:15px;background:#fff;color:#111;outline:none;font-size:14px;transition:.18s;box-shadow:0 1px 0 rgba(0,0,0,.03)}input:focus,select:focus,textarea:focus{border-color:#111;box-shadow:0 0 0 4px rgba(0,0,0,.06)}textarea{min-height:145px;resize:vertical;line-height:1.55}.btn{border:0;border-radius:15px;padding:13px 17px;font-weight:900;cursor:pointer;background:linear-gradient(135deg,#050505,#24262a);color:#fff;box-shadow:0 16px 34px rgba(0,0,0,.18);transition:.18s;display:inline-flex;align-items:center;justify-content:center;gap:7px}.btn:hover{transform:translateY(-1px);box-shadow:0 20px 42px rgba(0,0,0,.22)}.btn.secondary{background:#fff;color:#111;border:1px solid var(--line);box-shadow:0 10px 28px rgba(0,0,0,.05)}.btn.secondary:hover{border-color:#111}.btn.danger{background:#c0392b;color:#fff}.actions{display:flex;gap:10px;flex-wrap:wrap}.preview{min-height:440px;border:1px dashed #cfcfcf;border-radius:24px;display:grid;place-items:center;background:linear-gradient(145deg,#fff,#f5f5f5);overflow:hidden;padding:14px}.preview img,.thumb{max-width:100%;border-radius:18px;box-shadow:0 18px 50px rgba(0,0,0,.12)}.tabs{display:grid;grid-template-columns:repeat(5,1fr);gap:9px;margin-bottom:14px}.tab{padding:12px;border-radius:14px;border:1px solid var(--line);background:#fff;text-align:center;cursor:pointer;font-weight:900;color:#232428;transition:.18s}.tab.active,.tab:hover{background:#111214;color:#fff;border-color:#111214;box-shadow:0 12px 28px rgba(0,0,0,.16)}.table{width:100%;border-collapse:separate;border-spacing:0 11px}.table th{font-size:12px;color:#45474c;text-align:left;text-transform:none;font-weight:950}.table td{background:#fff;padding:13px;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.table td:first-child{border-left:1px solid var(--line);border-radius:16px 0 0 16px}.table td:last-child{border-right:1px solid var(--line);border-radius:0 16px 16px 0}.login{min-height:100vh;display:grid;place-items:center;padding:20px}.loginbox{width:min(420px,100%)}.hint{color:var(--muted);font-size:13px;line-height:1.5}.mobilebar{display:none}.template-list{display:grid;gap:12px}.template-item{padding:16px;border:1px solid var(--line);border-radius:18px;background:#fff;box-shadow:0 10px 28px rgba(0,0,0,.04)}.badge{font-size:12px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:999px;padding:5px 9px;color:#111;font-weight:800}.result-wrap{width:100%;display:flex;flex-direction:column;align-items:center;gap:12px;padding:8px}.result-image-link{display:flex;justify-content:center;align-items:center;width:100%}.preview .result-img{display:block;width:auto;max-width:100%;max-height:62vh;object-fit:contain;border-radius:18px;box-shadow:0 18px 50px rgba(0,0,0,.12);background:#fff}.result-actions{width:100%;justify-content:center;margin-top:4px}.download-btn{min-width:220px;text-align:center}.download-badge{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:7px 11px;white-space:nowrap}.preview>img{max-height:62vh;width:auto;object-fit:contain}.upload-zone{position:relative;border:1.5px dashed #c9c9c9;border-radius:22px;background:linear-gradient(135deg,#fff,#f3f3f3);min-height:152px;display:grid;place-items:center;cursor:pointer;transition:.22s;overflow:hidden}.upload-zone:hover,.upload-zone.dragover{border-color:#111;box-shadow:0 18px 44px rgba(0,0,0,.10);transform:translateY(-1px)}.upload-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}.upload-zone-inner{text-align:center;padding:18px;pointer-events:none}.upload-icon{font-size:34px;margin-bottom:8px;filter:grayscale(1)}.upload-zone strong{display:block;color:#111;font-size:15px;font-weight:950}.upload-zone span{display:block;margin-top:6px;color:var(--muted);font-size:12px}.thumb-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:11px;margin-top:13px}.thumb-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:17px;padding:7px;box-shadow:0 10px 26px rgba(0,0,0,.06);overflow:hidden}.thumb-card img{display:block;width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:13px;box-shadow:none;cursor:zoom-in}.thumb-remove{position:absolute;top:5px;right:5px;width:25px;height:25px;border:0;border-radius:999px;background:rgba(17,18,20,.82);color:#fff;font-size:18px;line-height:20px;display:grid;place-items:center;cursor:pointer;z-index:2}.thumb-remove:hover{background:#c0392b}.thumb-name{font-size:11px;color:#555;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:6px}.upload-notice{margin:10px 0;padding:10px 12px;border-radius:13px;background:#f3f4f6;border:1px solid #e5e7eb;color:#111;font-size:13px}.image-preview-overlay,.history-image-overlay{position:fixed;inset:0;background:rgba(0,0,0,.9);z-index:9999;display:none;align-items:center;justify-content:center;padding:44px 16px}.image-preview-overlay.show,.history-image-overlay.show{display:flex}.preview-full-img,.history-full-img{max-width:96vw;max-height:86vh;object-fit:contain;border-radius:16px;background:#fff;box-shadow:0 18px 60px rgba(0,0,0,.35)}.preview-close,.history-preview-close{position:absolute;top:14px;right:16px;width:42px;height:42px;border:0;border-radius:999px;background:rgba(255,255,255,.18);color:#fff;font-size:30px;line-height:1;cursor:pointer}.preview-close:hover,.history-preview-close:hover{background:rgba(255,255,255,.28)}.preview-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:64px;border:0;border-radius:14px;background:rgba(255,255,255,.14);color:#fff;font-size:44px;line-height:1;cursor:pointer}.preview-prev{left:14px}.preview-next{right:14px}.preview-counter{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);padding:7px 12px;border-radius:999px;background:rgba(255,255,255,.16);color:#fff;font-size:13px}.progress-panel{width:min(460px,100%);background:#fff;border:1px solid var(--line);border-radius:24px;padding:22px;box-shadow:0 18px 48px rgba(0,0,0,.12);text-align:left}.progress-title{font-size:20px;font-weight:950;margin-bottom:16px;color:#111}.progress-main-bar{height:12px;border-radius:999px;background:#ececec;overflow:hidden}.progress-main-bar i{display:block;width:0;height:100%;border-radius:999px;background:linear-gradient(90deg,#050505,#444);transition:width .35s ease}.progress-percent{margin-top:10px;font-size:18px;font-weight:950;color:#111;text-align:right}.progress-status{margin-top:2px;font-size:14px;font-weight:900;color:#333}.progress-meta{margin-top:14px;display:grid;gap:7px;color:var(--muted);font-size:13px;line-height:1.35}.progress-meta div{position:relative;padding-left:14px}.progress-meta div:before{content:'•';position:absolute;left:0;color:#111}.history-table td{vertical-align:middle}.history-preview-head,.history-preview-cell{text-align:center}.history-thumb-btn{width:58px;height:58px;border:1px solid var(--line);border-radius:14px;padding:4px;background:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:zoom-in;box-shadow:0 8px 22px rgba(0,0,0,.07);transition:.18s}.history-thumb-btn:hover{transform:translateY(-1px);box-shadow:0 12px 28px rgba(0,0,0,.13);border-color:#111}.history-thumb-img{width:100%;height:100%;object-fit:cover;border-radius:10px;display:block}.history-no-thumb{color:var(--muted);font-size:13px}.history-delete-btn{width:44px;height:44px;border-radius:15px;padding:0;display:inline-grid;place-items:center}.history-template-name{font-weight:950;color:#111;margin-bottom:5px}.history-template-type{font-size:12px;color:#111;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:999px;display:inline-block;padding:4px 9px;font-weight:800}.history-table th:nth-child(3),.history-table td:nth-child(3){min-width:150px}.history-table th:nth-child(7),.history-table td:nth-child(7){min-width:170px;white-space:nowrap}
@media(max-width:900px){body{background:#f5f5f3}.layout{grid-template-columns:1fr}.sidebar{display:none}.mobilebar{display:flex;position:fixed;bottom:0;left:0;right:0;background:rgba(255,255,255,.95);border-top:1px solid var(--line);z-index:99;justify-content:space-around;padding:8px 6px env(safe-area-inset-bottom);backdrop-filter:blur(16px)}.mobilebar a{font-size:12px;padding:8px;color:#222;font-weight:800}.main{padding:14px 14px 86px}.grid,.form-row{grid-template-columns:1fr}.tabs{grid-template-columns:1fr 1fr}.topbar{gap:10px;align-items:flex-start}.topbar .actions{justify-content:flex-end}.card{padding:16px;border-radius:22px}.preview{min-height:300px}.table{font-size:13px;display:block;overflow:auto}.brand h1{font-size:14px}.preview{min-height:260px;padding:10px}.preview .result-img,.preview>img{max-height:52vh;max-width:100%}.result-wrap{gap:10px;padding:4px}.result-actions{position:sticky;bottom:0;background:linear-gradient(180deg,rgba(255,255,255,.65),#fff);padding:8px 0 2px}.download-btn{width:100%;min-width:0;padding:14px 12px}.download-badge{width:100%;font-size:12px}.table td{vertical-align:middle}.thumb-grid{grid-template-columns:repeat(3,1fr);gap:8px}.upload-zone{min-height:130px;border-radius:18px}.upload-zone-inner{padding:14px}.thumb-card{border-radius:14px;padding:5px}.thumb-remove{top:4px;right:4px;width:24px;height:24px}.thumb-name{font-size:10px}.preview-nav{display:none}.image-preview-overlay,.history-image-overlay{padding:38px 8px}.preview-full-img,.history-full-img{max-width:98vw;max-height:82vh;border-radius:12px}.progress-panel{padding:18px;border-radius:20px}.progress-title{font-size:18px}.progress-percent{font-size:16px}.history-card{padding:14px}.history-table{min-width:760px}.history-thumb-btn{width:50px;height:50px;border-radius:12px;padding:3px}.history-thumb-img{border-radius:9px}.history-delete-btn{width:40px;height:40px}}


/* ===== V5 Apple + Notion + Linear Dark Admin UI ===== */

/* ===== CAMELA V5.1 Theme System: default dark, localStorage toggle support ===== */
.theme-toggle{
  border:1px solid var(--line);
  border-radius:999px;
  min-height:42px;
  padding:9px 13px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:#fff;
  color:#111214;
  font-weight:950;
  cursor:pointer;
  box-shadow:0 10px 28px rgba(0,0,0,.05);
  transition:.18s;
}
.theme-toggle:hover{transform:translateY(-1px);box-shadow:0 16px 34px rgba(0,0,0,.10)}
.theme-toggle .theme-icon{font-size:15px;line-height:1}.theme-toggle .theme-label{font-size:13px;white-space:nowrap}
.sidebar-theme{position:absolute;left:18px;right:18px;bottom:22px;width:calc(100% - 36px);justify-content:center}
.login-theme{position:fixed;left:22px;bottom:22px;z-index:3}
.mobile-theme{display:none}
html[data-theme="dark"]{
  --bg:#0f0f0f;--bg2:#090909;--ink:#ffffff;--muted:#999999;--soft:#e5e5e5;--card:#171717;--card2:#111111;--line:#262626;--line2:#333333;--black:#ffffff;--black2:#e5e5e5;--white:#ffffff;--ok:#ffffff;--danger:#ef4444;--shadow:0 32px 90px rgba(0,0,0,.48);--shadow2:0 18px 48px rgba(0,0,0,.36);--radius:24px;--radius2:18px;color-scheme:dark;
}
html[data-theme="dark"]{background:#0f0f0f;color-scheme:dark}
html[data-theme="dark"] body{background:radial-gradient(circle at top,#1a1a1a 0%,#090909 64%,#0f0f0f 100%) !important;color:#ffffff}
html[data-theme="dark"] a{color:inherit}
html[data-theme="dark"] .layout,html[data-theme="dark"] .main{background:transparent}
html[data-theme="dark"] .sidebar{background:rgba(15,15,15,.86) !important;border-right:1px solid #262626;box-shadow:12px 0 50px rgba(0,0,0,.35)}
html[data-theme="dark"] .brand,html[data-theme="dark"] .brand h1{color:#fff}
html[data-theme="dark"] .brand p,html[data-theme="dark"] .hint{color:#999999!important}
html[data-theme="dark"] .logo{background:#ffffff !important;color:#0f0f0f !important;box-shadow:0 18px 45px rgba(255,255,255,.08)}
html[data-theme="dark"] .nav a{color:#999999;border:1px solid transparent;background:transparent}
html[data-theme="dark"] .nav a.active,html[data-theme="dark"] .nav a:hover{background:#ffffff !important;color:#000000 !important;border-color:#ffffff;box-shadow:0 18px 42px rgba(255,255,255,.10)}
html[data-theme="dark"] .pill,html[data-theme="dark"] .badge{background:#171717 !important;border:1px solid #262626 !important;color:#ffffff !important;box-shadow:none !important}
html[data-theme="dark"] .card,html[data-theme="dark"] .template-item,html[data-theme="dark"] .progress-panel{background:rgba(23,23,23,.84) !important;border:1px solid #262626 !important;border-radius:24px !important;box-shadow:0 32px 90px rgba(0,0,0,.48) !important;backdrop-filter:blur(20px)}
html[data-theme="dark"] .card h2,html[data-theme="dark"] .card h3,html[data-theme="dark"] .progress-title,html[data-theme="dark"] .history-template-name{color:#ffffff!important}
html[data-theme="dark"] label,html[data-theme="dark"] .table th{color:#e5e5e5!important}
html[data-theme="dark"] input,html[data-theme="dark"] select,html[data-theme="dark"] textarea{background:#0f0f0f !important;border:1px solid #262626 !important;color:#ffffff !important;box-shadow:none !important}
html[data-theme="dark"] input::placeholder,html[data-theme="dark"] textarea::placeholder{color:#777}
html[data-theme="dark"] input:focus,html[data-theme="dark"] select:focus,html[data-theme="dark"] textarea:focus{border-color:#ffffff !important;box-shadow:0 0 0 4px rgba(255,255,255,.08) !important}
html[data-theme="dark"] select option{background:#0f0f0f;color:#ffffff}
html[data-theme="dark"] .btn{background:#ffffff !important;color:#000000 !important;border:1px solid #ffffff !important;box-shadow:0 18px 46px rgba(255,255,255,.10) !important}
html[data-theme="dark"] .btn:hover{background:#e5e5e5 !important;color:#000000 !important;border-color:#e5e5e5 !important;box-shadow:0 22px 54px rgba(255,255,255,.13) !important}
html[data-theme="dark"] .btn.secondary,html[data-theme="dark"] .theme-toggle{background:#171717 !important;color:#ffffff !important;border:1px solid #262626 !important;box-shadow:none !important}
html[data-theme="dark"] .btn.secondary:hover,html[data-theme="dark"] .theme-toggle:hover{background:#262626 !important;border-color:#e5e5e5 !important}
html[data-theme="dark"] .btn.danger,html[data-theme="dark"] .history-delete-btn,html[data-theme="dark"] .thumb-remove{background:#ef4444 !important;color:#ffffff !important;border-color:#ef4444 !important}
html[data-theme="dark"] .preview,html[data-theme="dark"] .upload-zone{background:linear-gradient(145deg,#171717,#0f0f0f) !important;border-color:#333333 !important;color:#999999 !important}
html[data-theme="dark"] .upload-zone:hover,html[data-theme="dark"] .upload-zone.dragover{border-color:#ffffff!important;box-shadow:0 18px 44px rgba(255,255,255,.08)!important}
html[data-theme="dark"] .upload-zone strong{color:#ffffff!important}html[data-theme="dark"] .upload-zone span{color:#999999!important}
html[data-theme="dark"] .upload-icon{filter:grayscale(1) brightness(1.7)}
html[data-theme="dark"] .table td{background:#171717 !important;border-top:1px solid #262626 !important;border-bottom:1px solid #262626 !important;color:#ffffff !important}
html[data-theme="dark"] .table td:first-child{border-left:1px solid #262626!important}html[data-theme="dark"] .table td:last-child{border-right:1px solid #262626!important}
html[data-theme="dark"] .tab{background:#171717!important;color:#999999!important;border:1px solid #262626!important}
html[data-theme="dark"] .tab.active,html[data-theme="dark"] .tab:hover{background:#ffffff!important;color:#000000!important;border-color:#ffffff!important;box-shadow:0 16px 36px rgba(255,255,255,.10)!important}
html[data-theme="dark"] .thumb-card,html[data-theme="dark"] .history-thumb-btn{background:#171717!important;border:1px solid #262626!important;box-shadow:0 18px 48px rgba(0,0,0,.26)!important}
html[data-theme="dark"] .thumb-name{color:#999!important}
html[data-theme="dark"] .upload-notice,html[data-theme="dark"] .history-template-type{background:#0f0f0f!important;border:1px solid #262626!important;color:#e5e5e5!important}
html[data-theme="dark"] .progress-main-bar{background:#333!important}html[data-theme="dark"] .progress-main-bar i{background:#ffffff!important}html[data-theme="dark"] .progress-percent,html[data-theme="dark"] .progress-status{color:#fff!important}html[data-theme="dark"] .progress-meta{color:#999!important}html[data-theme="dark"] .progress-meta div:before{color:#fff!important}
html[data-theme="dark"] .result-actions{background:transparent}html[data-theme="dark"] .download-badge{background:#ffffff!important;color:#000!important;border-color:#ffffff!important}
html[data-theme="dark"] .login{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at top,#1a1a1a 0%,#090909 64%,#0f0f0f 100%) !important}
html[data-theme="dark"] .login:before{content:'';position:fixed;inset:0;pointer-events:none;background:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:44px 44px;mask-image:radial-gradient(circle at center,black,transparent 72%)}
html[data-theme="dark"] .loginbox{width:min(430px,100%);position:relative;z-index:1;padding:28px!important}
.login .brand{margin-bottom:26px;padding:0}.login h2{font-size:24px;margin-bottom:18px}.login .btn{height:50px;border-radius:16px}.login .field{margin-bottom:16px}
.login-lang{position:fixed;top:22px;right:22px;display:flex;gap:10px;z-index:2}.login-lang a{padding:10px 13px;border-radius:999px;font-weight:900;font-size:13px;background:#fff;border:1px solid var(--line);color:#111}.login-lang a:hover{background:#111;color:#fff}.login-subtitle{color:var(--muted);font-size:13px;margin:-8px 0 20px;line-height:1.55}
html[data-theme="dark"] .login-lang a{background:#171717;border:1px solid #262626;color:#fff}html[data-theme="dark"] .login-lang a:hover{background:#fff;color:#000}
@media(max-width:900px){
  .layout{display:block}.sidebar{position:relative;height:auto}.sidebar-theme{display:none}.mobile-theme{display:inline-flex}.topbar{gap:10px;align-items:flex-start}.topbar .actions{justify-content:flex-end}.main{padding:18px 16px 94px}.grid{grid-template-columns:1fr}.tabs{grid-template-columns:repeat(2,1fr)}.thumb-grid{grid-template-columns:repeat(3,1fr)}.mobilebar{display:grid;grid-template-columns:repeat(5,1fr);position:fixed;left:0;right:0;bottom:0;background:rgba(255,255,255,.92);backdrop-filter:blur(16px);border-top:1px solid var(--line);z-index:10}.mobilebar a{text-align:center;padding:10px 4px;font-size:12px;color:#111;font-weight:800}.login{padding:18px}.login-lang{top:14px;right:14px}.login-theme{left:14px;bottom:14px}.loginbox{padding:22px!important}
  html[data-theme="dark"] body{background:#0f0f0f!important}html[data-theme="dark"] .mobilebar{background:rgba(15,15,15,.92)!important;border-top:1px solid #262626}html[data-theme="dark"] .mobilebar a{color:#e5e5e5}html[data-theme="dark"] .card{box-shadow:none!important}html[data-theme="dark"] .result-actions{background:linear-gradient(180deg,rgba(23,23,23,.5),#171717)!important}html[data-theme="dark"] .topbar{background:transparent}html[data-theme="dark"] .login{padding:18px}html[data-theme="dark"] .login-lang{top:14px;right:14px}html[data-theme="dark"] .loginbox{padding:22px!important}
}

/* ===== V5.3 API后台排版修复：长URL不再把按钮挤到下一行 ===== */
.api-service-list{display:grid;gap:12px}
.api-service-item{overflow:hidden}
.api-service-row{display:flex;align-items:center;justify-content:space-between;gap:18px;width:100%}
.api-service-info{min-width:0;flex:1 1 auto;overflow:hidden}
.api-service-title{display:flex;align-items:center;gap:8px;min-width:0;font-weight:950;color:var(--ink)}
.api-service-meta{margin:8px 0 0;max-width:100%;overflow:hidden;text-overflow:ellipsis;overflow-wrap:anywhere;word-break:break-word;line-height:1.45}
.api-service-actions{flex:0 0 auto;display:flex;align-items:center;justify-content:flex-end;gap:10px;white-space:nowrap;margin-left:auto}
.api-service-actions form{margin:0;display:inline-flex}
.api-service-actions .btn{min-width:64px;justify-content:center}
@media(max-width:1100px){.api-service-row{align-items:flex-start;flex-direction:column}.api-service-actions{width:100%;justify-content:flex-start;flex-wrap:wrap;margin-left:0}}
@media(max-width:560px){.api-service-actions{display:grid;grid-template-columns:1fr 1fr 1fr;width:100%;gap:8px}.api-service-actions .btn{width:100%;padding-left:8px;padding-right:8px}.api-service-actions form{width:100%}}

/* ===== V5.8 Storage Cleanup Dashboard ===== */
.storage-cleanup-card{margin-bottom:22px}
.storage-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:18px}
.storage-head h2{margin-bottom:6px!important}
.storage-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.storage-box{border:1px solid var(--line);border-radius:18px;background:#fff;padding:16px;box-shadow:0 10px 28px rgba(0,0,0,.04)}
.storage-box span{display:block;font-size:12px;font-weight:950;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.storage-box b{display:block;margin-top:8px;font-size:24px;line-height:1.1;color:var(--ink);letter-spacing:-.04em}
.storage-box small{display:block;margin-top:7px;color:var(--muted);font-size:12px}
.cleanup-result{margin-top:14px;border:1px solid var(--line);border-radius:16px;background:#f6f7f8;padding:13px 14px;font-weight:900;color:#111;display:flex;gap:10px;flex-wrap:wrap;align-items:center}
html[data-theme="dark"] .storage-box{background:#171717!important;border:1px solid #262626!important;box-shadow:none!important}
html[data-theme="dark"] .storage-box b{color:#ffffff!important}
html[data-theme="dark"] .cleanup-result{background:#0f0f0f!important;border:1px solid #262626!important;color:#ffffff!important}
@media(max-width:900px){.storage-head{flex-direction:column}.storage-head form,.storage-head .btn{width:100%}.storage-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.storage-grid{grid-template-columns:1fr}}

/* ===== V6.0 System Maintenance Dashboard ===== */
.storage-grid-v6{grid-template-columns:repeat(3,1fr)}
.maintenance-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}
.maintenance-panel{border:1px solid var(--line);border-radius:18px;background:#fff;padding:16px;box-shadow:0 10px 28px rgba(0,0,0,.04)}
.maintenance-panel h3{margin:0 0 12px;font-size:16px;font-weight:950;color:var(--ink)}
.mini-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-bottom:12px}
.mini-stats span{border:1px solid var(--line);border-radius:14px;padding:10px;background:#fafafa;color:var(--muted);font-size:12px;font-weight:850}
.mini-stats b{display:block;margin-top:4px;color:var(--ink);font-size:18px;font-weight:950}
.maintenance-rules{margin:0;padding-left:18px;color:var(--muted);line-height:1.8;font-size:13px;font-weight:760}
html[data-theme="dark"] .maintenance-panel{background:#171717!important;border:1px solid #262626!important;box-shadow:none!important}
html[data-theme="dark"] .maintenance-panel h3,html[data-theme="dark"] .mini-stats b{color:#ffffff!important}
html[data-theme="dark"] .mini-stats{color:#999!important}
html[data-theme="dark"] .mini-stats span{background:#0f0f0f!important;border:1px solid #262626!important;color:#999!important}
html[data-theme="dark"] .maintenance-rules{color:#e5e5e5!important}
@media(max-width:1100px){.storage-grid-v6{grid-template-columns:repeat(2,1fr)}.maintenance-detail-grid{grid-template-columns:1fr}.mini-stats{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.storage-grid-v6{grid-template-columns:1fr}.mini-stats{grid-template-columns:1fr}}

/* ===== V6.3 ChatGPT-style Visual Generation Experience ===== */
.preview{position:relative}
.visual-generation-panel{width:min(620px,100%);border:1px solid rgba(0,0,0,.08);border-radius:28px;background:rgba(255,255,255,.92);box-shadow:0 28px 80px rgba(0,0,0,.12);padding:18px;backdrop-filter:blur(22px);animation:camelaPanelIn .35s ease both}
.visual-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:16px}.visual-kicker{font-size:11px;font-weight:950;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin-bottom:4px}.visual-title{font-size:22px;font-weight:950;letter-spacing:-.04em;color:var(--ink)}.status-badge{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:999px;background:#fff;padding:8px 12px;font-size:12px;font-weight:950;color:#111;white-space:nowrap}.status-badge i{width:8px;height:8px;border-radius:999px;background:#9ca3af;box-shadow:0 0 0 4px rgba(156,163,175,.15)}.status-badge.status-processing i{background:#2563eb;box-shadow:0 0 0 4px rgba(37,99,235,.14);animation:camelaPulse 1.2s infinite}.status-badge.status-done i{background:#0f766e;box-shadow:0 0 0 4px rgba(15,118,110,.14)}.status-badge.status-failed i{background:#dc2626;box-shadow:0 0 0 4px rgba(220,38,38,.14)}.visual-body{display:grid;grid-template-columns:190px 1fr;gap:16px;align-items:stretch}.visual-preview-card{position:relative;min-height:228px;border:1px solid var(--line);border-radius:24px;overflow:hidden;background:linear-gradient(145deg,#fafafa,#fff);display:grid;place-items:center}.visual-preview-card img{width:100%;height:100%;object-fit:cover;border-radius:0;box-shadow:none;position:absolute;inset:0;z-index:1}.visual-preview-card:after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 52%,rgba(0,0,0,.58));z-index:2;pointer-events:none}.visual-preview-caption{position:absolute;left:10px;right:10px;bottom:10px;z-index:3;border-radius:999px;background:rgba(255,255,255,.86);backdrop-filter:blur(12px);padding:7px 10px;font-size:12px;font-weight:900;text-align:center;color:#111}.visual-empty-preview{color:var(--muted);font-size:13px;font-weight:850}.visual-orb{position:absolute;width:120px;height:120px;border-radius:999px;background:radial-gradient(circle,rgba(17,17,17,.15),transparent 70%);filter:blur(6px);animation:camelaOrb 4s ease-in-out infinite}.visual-preview-card img.swap-in{animation:camelaImageSwap .38s ease both}.visual-progress-area{display:flex;flex-direction:column;justify-content:center;min-width:0}.visual-bar{height:14px;background:#ececec}.visual-progress-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:10px 0 14px}.visual-progress-row .progress-status{margin:0}.visual-progress-row .progress-percent{margin:0}.visual-step-list{display:grid;gap:8px}.visual-step{display:grid;grid-template-columns:28px 1fr auto;align-items:center;gap:9px;border:1px solid var(--line);border-radius:15px;background:#fff;padding:9px 10px;transition:.22s}.visual-step b{width:24px;height:24px;border-radius:999px;display:grid;place-items:center;background:#f1f1f1;color:#555;font-size:12px;font-weight:950}.visual-step span{font-size:13px;font-weight:950;color:var(--ink)}.visual-step em{font-style:normal;color:var(--muted);font-size:12px;font-weight:800;text-align:right;min-width:80px}.visual-step.active{border-color:#111;box-shadow:0 10px 28px rgba(0,0,0,.06);transform:translateY(-1px)}.visual-step.active b{background:#111;color:#fff}.visual-step.done b{background:#0f766e;color:#fff}.visual-step.failed b{background:#dc2626;color:#fff}.visual-log-wrap{margin-top:14px;border:1px solid var(--line);border-radius:18px;background:#fbfbfb;overflow:hidden}.visual-log-head{height:40px;display:flex;align-items:center;justify-content:space-between;padding:0 12px;border-bottom:1px solid var(--line);font-size:13px;font-weight:950;color:var(--ink)}.visual-log-head button{border:0;background:transparent;color:var(--muted);font-size:12px;font-weight:900;cursor:pointer}.visual-log{max-height:130px;overflow:auto;padding:10px 12px;display:grid;gap:7px;transition:.2s}.visual-log.collapsed{max-height:0;padding-top:0;padding-bottom:0;border:0}.visual-log div{display:grid;grid-template-columns:72px 1fr;gap:8px;align-items:start;font-size:12px;line-height:1.45}.visual-log time{color:var(--soft);font-weight:850}.visual-log span{color:var(--muted);font-weight:760}.success-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#ecfdf5;border:1px solid #bbf7d0;color:#047857;font-size:13px;font-weight:950;padding:8px 13px;margin-bottom:2px}.result-ready{animation:camelaResultIn .45s ease both}.result-fade-in{animation:camelaResultImageIn .5s ease both}.result-info-grid{width:min(560px,100%);display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.result-info-grid div{border:1px solid var(--line);border-radius:16px;background:#fff;padding:12px;text-align:center}.result-info-grid span{display:block;font-size:11px;font-weight:950;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.result-info-grid b{display:block;margin-top:5px;font-size:15px;color:var(--ink);font-weight:950}.result-action-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));width:min(620px,100%)}.result-action-grid .btn{width:100%;min-width:0;white-space:nowrap}.visual-error{width:min(460px,100%);border:1px solid #fecaca;background:#fff5f5;border-radius:22px;padding:20px;text-align:center;color:#991b1b;box-shadow:0 18px 48px rgba(220,38,38,.10)}.visual-error b{display:block;font-size:19px;margin-bottom:8px}.visual-error p{color:#7f1d1d;line-height:1.5;word-break:break-word}
@keyframes camelaPanelIn{from{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:none}}@keyframes camelaPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.35);opacity:.65}}@keyframes camelaOrb{0%,100%{transform:translate(-20px,-16px) scale(1)}50%{transform:translate(24px,18px) scale(1.2)}}@keyframes camelaImageSwap{from{opacity:.45;transform:scale(1.04)}to{opacity:1;transform:scale(1)}}@keyframes camelaResultIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}@keyframes camelaResultImageIn{from{opacity:0;transform:scale(.96);filter:blur(5px)}to{opacity:1;transform:scale(1);filter:blur(0)}}
html[data-theme="dark"] .visual-generation-panel{background:rgba(23,23,23,.88)!important;border:1px solid #262626!important;box-shadow:0 36px 100px rgba(0,0,0,.52)!important}html[data-theme="dark"] .visual-title,html[data-theme="dark"] .visual-step span,html[data-theme="dark"] .visual-log-head,html[data-theme="dark"] .result-info-grid b{color:#fff!important}html[data-theme="dark"] .status-badge,html[data-theme="dark"] .visual-step,html[data-theme="dark"] .visual-preview-card,html[data-theme="dark"] .visual-log-wrap,html[data-theme="dark"] .result-info-grid div{background:#171717!important;border-color:#262626!important;color:#fff!important}html[data-theme="dark"] .visual-step b{background:#262626;color:#e5e5e5}html[data-theme="dark"] .visual-step.active{border-color:#e5e5e5!important}html[data-theme="dark"] .visual-step.active b{background:#fff;color:#000}html[data-theme="dark"] .visual-step.done b{background:#10b981;color:#001b12}html[data-theme="dark"] .visual-step.failed b{background:#ef4444;color:#fff}html[data-theme="dark"] .visual-log-head{border-color:#262626!important}html[data-theme="dark"] .visual-log span,html[data-theme="dark"] .visual-step em,html[data-theme="dark"] .visual-kicker{color:#999!important}html[data-theme="dark"] .visual-preview-caption{background:rgba(23,23,23,.82);color:#fff;border:1px solid #262626}html[data-theme="dark"] .visual-bar{background:#333!important}html[data-theme="dark"] .success-badge{background:#06281e;border-color:#0f766e;color:#8ff5cf}html[data-theme="dark"] .visual-error{background:#2a1212;border-color:#7f1d1d;color:#fecaca}html[data-theme="dark"] .visual-error p{color:#fecaca}
@media(max-width:900px){.visual-generation-panel{padding:14px;border-radius:24px}.visual-head{align-items:flex-start}.visual-title{font-size:19px}.status-badge{padding:7px 10px}.visual-body{grid-template-columns:1fr}.visual-preview-card{min-height:220px;max-height:280px}.visual-step{grid-template-columns:26px 1fr}.visual-step em{grid-column:2 / 3;text-align:left;min-width:0}.result-info-grid{grid-template-columns:1fr 1fr}.result-action-grid{grid-template-columns:1fr 1fr}.visual-log{max-height:115px}.visual-log div{grid-template-columns:66px 1fr}}@media(max-width:520px){.visual-head{flex-direction:column}.status-badge{width:100%;justify-content:center}.result-info-grid,.result-action-grid{grid-template-columns:1fr}.visual-preview-card{min-height:190px}.visual-log div{grid-template-columns:1fr}.visual-log time{font-size:11px}.visual-log span{font-size:12px}.visual-step-list{gap:7px}}

/* V6.3.7: history prompt column and editable copy modal */
.history-prompt-cell{min-width:260px;max-width:380px}.history-prompt-btn{width:100%;border:1px solid var(--line);border-radius:16px;background:linear-gradient(135deg,#fff,#f8f8f8);padding:11px 12px;text-align:left;cursor:pointer;display:grid;gap:6px;box-shadow:0 10px 26px rgba(0,0,0,.05);transition:.18s}.history-prompt-btn:hover{transform:translateY(-1px);border-color:#111;box-shadow:0 14px 34px rgba(0,0,0,.12)}.history-prompt-label{display:inline-flex;width:max-content;align-items:center;border-radius:999px;background:#111214;color:#fff;font-size:11px;font-weight:950;padding:4px 9px;letter-spacing:.02em}.history-prompt-preview{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;color:#24262a;font-size:13px;line-height:1.42;font-weight:700;word-break:break-word}.history-prompt-modal{position:fixed;inset:0;z-index:10020;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.55);backdrop-filter:blur(10px);padding:18px}.history-prompt-modal.show{display:flex}.history-prompt-dialog{position:relative;width:min(760px,96vw);background:#fff;border:1px solid var(--line);border-radius:26px;padding:22px;box-shadow:0 34px 100px rgba(0,0,0,.28);animation:camelaPanelIn .2s ease}.history-prompt-close{position:absolute;top:14px;right:14px;width:38px;height:38px;border:0;border-radius:999px;background:#111214;color:#fff;font-size:25px;line-height:1;cursor:pointer;display:grid;place-items:center}.history-prompt-close:hover{background:#c0392b}.history-prompt-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding-right:46px;margin-bottom:14px}.history-prompt-kicker{font-size:11px;color:var(--muted);font-weight:950;letter-spacing:.12em}.history-prompt-head h3{margin:4px 0 0;font-size:22px;font-weight:950;letter-spacing:-.04em}.history-prompt-meta{color:var(--muted);font-size:12px;font-weight:800;line-height:1.4;text-align:right;max-width:360px}.history-prompt-textarea{min-height:310px;max-height:56vh;resize:vertical;font-size:14px;line-height:1.65;border-radius:18px;background:#fbfbfb}.history-prompt-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;margin-top:14px}.history-prompt-actions .btn{min-width:128px}.history-prompt-hint{margin:12px 0 0}.history-table th:nth-child(2),.history-table td:nth-child(2){min-width:280px}.history-table th:nth-child(3),.history-table td:nth-child(3){min-width:150px}
html[data-theme="dark"] .history-prompt-btn{background:linear-gradient(135deg,#161616,#101010)!important;border-color:#262626!important;box-shadow:0 12px 30px rgba(0,0,0,.28)!important}html[data-theme="dark"] .history-prompt-btn:hover{border-color:#e5e5e5!important}html[data-theme="dark"] .history-prompt-label{background:#fff!important;color:#000!important}html[data-theme="dark"] .history-prompt-preview,html[data-theme="dark"] .history-prompt-head h3{color:#fff!important}html[data-theme="dark"] .history-prompt-dialog{background:#171717!important;border-color:#262626!important;box-shadow:0 34px 100px rgba(0,0,0,.6)!important}html[data-theme="dark"] .history-prompt-textarea{background:#0f0f0f!important;border-color:#262626!important;color:#f4f4f5!important}html[data-theme="dark"] .history-prompt-close{background:#fff!important;color:#000!important}html[data-theme="dark"] .history-prompt-close:hover{background:#ef4444!important;color:#fff!important}
@media(max-width:900px){.history-prompt-cell{min-width:240px}.history-table{min-width:980px}.history-prompt-dialog{padding:18px;border-radius:22px}.history-prompt-head{flex-direction:column;padding-right:42px}.history-prompt-meta{text-align:left;max-width:100%}.history-prompt-textarea{min-height:260px;max-height:50vh}.history-prompt-actions{display:grid;grid-template-columns:1fr 1fr}.history-prompt-actions .btn{width:100%;min-width:0}}
