

:root{
  --bg:#F9F8F6;
  --panel:#ffffff;
  --panel2:rgba(255,255,255,0.9);
  --line:rgba(0,0,0,0.05);
  --line-m:rgba(0,0,0,0.09);
  --ink0:#1d1c1a;
  --ink1:#5c5a56;
  --ink2:#9e9c98;
  --primary:#4f46e5;
  --primary-lt:rgba(79,70,229,0.12);
  --primary-bd:rgba(79,70,229,0.3);
  --blue:#6B8EAD;
  --blue-lt:rgba(107,142,173,0.10);
  --teal:#759F98;
  --teal-lt:rgba(117,159,152,0.10);
  --nav-w:220px;
  --nav-w-sm:56px;
  --top-h:52px;
  --r6:6px;--r10:10px;--r14:14px;--r20:20px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden}
body{
  font-family:"PingFang SC","Hiragino Sans GB","Microsoft YaHei",sans-serif;
  background:var(--bg);
  color:var(--ink0);
  display:flex;
  flex-direction:column;
}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-thumb{background:rgba(0,0,0,0.12);border-radius:4px}
::-webkit-scrollbar-track{background:transparent}

/* ═══════════════════════════
   TOP BAR
═══════════════════════════ */
.topbar{
  height:var(--top-h);
  flex-shrink:0;
  display:flex;
  align-items:center;
  background:var(--panel);
  border-bottom:0.5px solid var(--line);
  z-index:100;
  position:relative;
}

/* logo zone — same width as sidebar */
.tb-logo{
  width: auto; justify-content:flex-start;
  flex-shrink:0;
  display:flex;
  align-items:center;
  gap:10px;
  padding:0 18px;
  border-right:0.5px solid var(--line);
  height:100%;
  cursor:pointer;
  transition:width .25s ease;
}
.tb-logo.collapsed{ width:var(--nav-w-sm); }
.lmark{
  width:28px;height:28px;border-radius:8px;flex-shrink:0;
  background:linear-gradient(135deg, #818cf8, #4f46e5);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 6px rgba(184,147,90,0.3);
  overflow:hidden;
}
.ltxt-wrap{ display:none; }
.ltxt{ font-size:13px;font-weight:500;color:var(--ink0);letter-spacing:.02em; }
.lsub{ font-size:10px;color:var(--ink2);letter-spacing:.05em;margin-top:1px; }
.tb-logo.collapsed .ltxt-wrap{ opacity:0;width:0; }

/* center: three-segment tab */
.tb-center{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:2px;
}
.seg-tabs{
  display:flex;
  background:var(--bg);
  border-radius:var(--r20);
  padding:3px;
  border:0.5px solid var(--line-m);
}
.seg-tab{
  padding:5px 22px;
  border-radius:var(--r20);
  font-size:13px;
  color:var(--ink1);
  cursor:pointer;
  border:none;
  background:transparent;
  font-family:inherit;
  transition:all .15s;
  white-space:nowrap;
  letter-spacing:.01em;
}
.seg-tab:hover{ color:var(--ink0); }
.seg-tab.active{
  background:var(--panel);
  color:var(--ink0);
  font-weight:500;
  box-shadow:0 1px 4px rgba(0,0,0,0.08);
}

/* right actions */
.tb-right{
  display:flex;align-items:center;gap:8px;
  padding:0 20px;
  margin-left:auto;
}
.tb-btn{
  padding:6px 14px;border-radius:var(--r20);
  font-size:12px;font-weight:500;cursor:pointer;
  border:none;font-family:inherit;transition:all .15s;white-space:nowrap;
}
.tb-ghost{
  background:transparent;color:var(--ink1);
  border:0.5px solid var(--line-m);
}
.tb-ghost:hover{background:rgba(0,0,0,0.04);color:var(--ink0);}
.tb-credit{
  background:var(--primary-lt);color:var(--primary);
  border:0.5px solid var(--primary-bd);font-size:12px;
}
.tb-pri{
  background:linear-gradient(135deg, #818cf8, #4f46e5);
  color:#fff;font-weight:600;
  box-shadow:0 2px 8px rgba(184,147,90,0.28);
}
.tb-pri:hover{opacity:.9;transform:translateY(-1px);}
.tb-ava{
  width:28px;height:28px;border-radius:50%;
  background:linear-gradient(135deg,#e8e4dc,#d0cbc2);
  border:0.5px solid var(--line-m);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:500;color:var(--ink1);cursor:pointer;
}

/* ═══════════════════════════
   BODY LAYOUT
═══════════════════════════ */
.app-body{
  flex:1;
  display:flex;
  overflow:hidden;
  position:relative;
}

/* ═══════════════════════════
   LEFT NAV
═══════════════════════════ */
.leftnav{
  width:var(--nav-w);
  flex-shrink:0;
  background:var(--panel);
  border-right:0.5px solid var(--line);
  display:flex;
  flex-direction:column;
  padding:12px 0;
  overflow:hidden;
  transition:width .25s ease;
}
.leftnav.collapsed{ width:var(--nav-w-sm); }

.nav-section{ margin-bottom:4px; }
.nav-section-title{
  font-size:10px;font-weight:600;letter-spacing:.1em;
  color:var(--ink2);text-transform:uppercase;
  padding:8px 18px 4px;white-space:nowrap;overflow:hidden;
  transition:opacity .2s;
}
.leftnav.collapsed .nav-section-title{ opacity:0; }

.nav-item{
  display:flex;align-items:center;gap:10px;
  padding:9px 16px;cursor:pointer;
  border:none;background:transparent;
  font-family:inherit;font-size:13px;color:var(--ink1);
  transition:all .12s;white-space:nowrap;
  width:100%;text-align:left;letter-spacing:.01em;
  border-radius:0;position:relative;
}
.nav-item:hover{ background:rgba(0,0,0,0.04);color:var(--ink0); }
.nav-item.active{ background:var(--primary-lt);color:var(--primary);font-weight:500; }
.nav-item.active::before{
  content:'';position:absolute;left:0;top:4px;bottom:4px;
  width:3px;border-radius:0 2px 2px 0;background:var(--primary);
}
.nav-ico{
  width:20px;height:20px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;
}
.nav-label{ transition:opacity .2s;white-space:nowrap; }
.leftnav.collapsed .nav-label{ opacity:0;width:0;overflow:hidden; }

.nav-badge{
  margin-left:auto;font-size:9px;padding:1px 6px;
  border-radius:6px;background:var(--blue-lt);color:var(--blue);
  font-weight:600;letter-spacing:.04em;
}
.leftnav.collapsed .nav-badge{ display:none; }

.nav-divider{ height:.5px;background:var(--line);margin:8px 12px; }

.nav-collapse{
  margin-top:auto;padding:8px 16px;
  display:flex;align-items:center;gap:10px;
  cursor:pointer;font-size:12px;color:var(--ink2);
  transition:color .12s;border:none;background:transparent;
  font-family:inherit;width:100%;
}
.nav-collapse:hover{ color:var(--ink0); }
.nav-collapse-ico{ font-size:14px;flex-shrink:0;transition:transform .25s; }
.leftnav.collapsed .nav-collapse-ico{ transform:rotate(180deg); }
.leftnav.collapsed .nav-collapse-lbl{ opacity:0;width:0;overflow:hidden; }

/* ═══════════════════════════
   MAIN CONTENT AREA
═══════════════════════════ */
.main{
  flex:1;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  position:relative;
}

/* page views */
.view{ display:none;flex:1;overflow:hidden;flex-direction:column; }
.view.active{ display:flex !important; }

/* ─── SQUARE / HOME VIEW ─── */
.home-scroll{
  flex:1;overflow-y:auto;
  padding:0 32px 60px;
}

/* home hero — see overrides in mode section */
.home-hero-bg{
  position:absolute;inset:0;pointer-events:none;
  background: transparent; /* Rely on body background instead */
}
.home-hero>*{position:relative;z-index:1;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.65)}}

/* search bar */
.hero-search{
  max-width:580px;margin:0 auto 12px;position:relative;
}
.hsbar{
  width:100%;height:50px;border-radius:25px;
  background:var(--panel);
  border:0.5px solid var(--line-m);
  padding:0 104px 0 48px;
  font-size:14px;color:var(--ink0);outline:none;
  font-family:inherit;transition:all .2s;
  box-shadow:0 2px 16px rgba(0,0,0,0.07),0 1px 4px rgba(0,0,0,0.04);
  letter-spacing:.01em;
}
.hsbar::placeholder{color:var(--ink2);}
.hsbar:focus{
  border-color:var(--primary-bd);
  box-shadow:0 4px 24px rgba(0,0,0,0.08),0 0 0 3px rgba(184,147,90,0.07);
}
.hs-ico{position:absolute;left:18px;top:50%;transform:translateY(-50%);color:var(--ink2);font-size:16px;pointer-events:none;}
.hs-btn{
  position:absolute;right:6px;top:50%;transform:translateY(-50%);
  height:38px;padding:0 20px;border-radius:20px;
  background:linear-gradient(135deg, #818cf8, #4f46e5);
  color:#fff;font-size:12px;font-weight:600;
  border:none;cursor:pointer;font-family:inherit;
  box-shadow:0 2px 8px rgba(79,70,229,0.3);transition:all .15s;
}
.hs-btn:hover{opacity:.88;transform:translateY(calc(-50% - 1px));}

/* ── INTEGRATED SEARCH BLOCK ── */
.search-block{
  max-width:620px;margin:24px auto 0;
  background:var(--panel);
  border:0.5px solid var(--line-m);
  border-radius:var(--r20);
  overflow:visible;
  box-shadow:0 2px 20px rgba(0,0,0,0.07),0 1px 4px rgba(0,0,0,0.04);
  position:relative;
  z-index:50;
}
.search-block:focus-within{
  border-color:var(--primary-bd);
  box-shadow:0 4px 28px rgba(0,0,0,0.08),0 0 0 3px rgba(184,147,90,0.07);
}

/* mode tabs at top of search block */
.mode-tabs{
  display:flex;
  border-bottom:0.5px solid var(--line);
  padding:2px 6px 0;
  gap:0;
}
.mtab{
  display:flex;align-items:center;gap:5px;
  padding:9px 14px 8px;
  font-size:12px;color:var(--ink1);
  cursor:pointer;border:none;background:transparent;
  font-family:inherit;transition:all .15s;white-space:nowrap;
  border-bottom:2px solid transparent;margin-bottom:-0.5px;
  letter-spacing:.01em;
  position:relative;
}
.mtab:hover{color:var(--ink0);}
.mtab.active{
  color:var(--primary);
  border-bottom-color:var(--primary);
  font-weight:500;
}
.mtab svg{flex-shrink:0;transition:opacity .15s;}
.mtab:not(.active) svg{opacity:.6;}
.mtab-new{
  font-size:9px;padding:1px 4px;border-radius:4px;
  background:var(--blue-lt);color:var(--blue);
  font-weight:700;letter-spacing:.03em;margin-left:2px;
}

/* search input row */
.search-row{
  display:flex;align-items:center;
  padding:0 8px 0 16px;
  height:48px;
  position:relative;
}
.sr-ico{font-size:16px;color:var(--ink2);flex-shrink:0;margin-right:8px;}
.srbar{
  flex:1;border:none;outline:none;background:transparent;
  font-size:14px;color:var(--ink0);font-family:inherit;
  letter-spacing:.01em;
}
.srbar::placeholder{color:var(--ink2);}
.sr-btn{
  height:34px;padding:0 18px;border-radius:20px;
  background:linear-gradient(135deg, #818cf8, #4f46e5);
  color:#fff;font-size:12px;font-weight:600;
  border:none;cursor:pointer;font-family:inherit;
  flex-shrink:0;
  box-shadow:0 2px 8px rgba(184,147,90,0.22);
  transition:all .15s;
}
.sr-btn:hover{opacity:.88;}

/* dropdown — anchored to search-row */
.hs-drop{
  display:none;
  position:absolute;
  top:calc(100% + 6px);
  left:0; right:0;
  background:var(--panel);
  border:0.5px solid var(--line-m);
  border-radius:var(--r14);
  padding:10px;
  z-index:400;
  box-shadow:0 14px 40px rgba(0,0,0,0.11),0 4px 12px rgba(0,0,0,0.06);
}
.hs-drop.open{display:block;animation:dropIn .16s ease;}
@keyframes dropIn{from{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}

/* hot search small pills */
.hot-tags{
  display:flex;align-items:center;justify-content:center;
  gap:7px;flex-wrap:wrap;margin-top:0;
}
.htag{
  font-size:10px;padding:5px 13px;border-radius:20px;
  border:1px solid rgba(0,0,0,0.09);
  color:var(--ink0);font-weight:400;
  cursor:pointer;
  background:rgba(255,255,255,0.82);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  font-family:inherit;
  transition:all .18s;white-space:nowrap;
  box-shadow:0 1px 4px rgba(0,0,0,0.06);
}
.htag:hover{border-color:var(--primary-bd);color:var(--primary);background:#fff;box-shadow:0 2px 8px rgba(79,70,229,0.10);}

/* home hero layout */
.home-hero{
  padding:44px 32px 28px;
  text-align:center;position:relative;overflow:visible;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.home-hero h1{
  font-size:28px;font-weight:500;letter-spacing:-.02em;
  color:var(--ink0);
}
.home-hero>*{position:relative;z-index:1;}
.drop-lbl{font-size:10px;font-weight:600;letter-spacing:.1em;color:var(--ink2);text-transform:uppercase;padding:7px 8px 4px;}
.drop-item{display:flex;align-items:center;gap:11px;padding:8px 8px;border-radius:var(--r10);cursor:pointer;transition:background .12s;}
.drop-item:hover{background:rgba(0,0,0,0.04);}
.drop-ico{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;}
.drop-name{font-size:13px;color:var(--ink0);font-weight:500;}
.drop-sub{font-size:11px;color:var(--ink2);margin-top:1px;}
.drop-tags{display:flex;gap:6px;flex-wrap:wrap;padding:5px 8px 7px;}
.dtag{
  font-size:11px;padding:3px 10px;border-radius:20px;
  border:0.5px solid var(--line-m);color:var(--ink1);
  cursor:pointer;background:transparent;font-family:inherit;transition:all .15s;
}
.dtag:hover{border-color:var(--primary-bd);color:var(--primary);background:var(--primary-lt);}

/* AI capability strip */
.ai-strip{
  display:inline-flex;align-items:center;gap:18px;
  padding:9px 20px;border-radius:var(--r14);
  background:rgba(255,255,255,0.55);border:0.5px solid var(--line);
  backdrop-filter:blur(10px);
}
.ai-feat{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--ink1);}
.ai-ico{
  width:20px;height:20px;border-radius:5px;
  display:flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:700;letter-spacing:-.02em;
}
.ai-blue{background:var(--blue-lt);color:var(--blue);}
.ai-gold{background:var(--primary-lt);color:var(--primary);}
.ai-teal{background:var(--teal-lt);color:var(--teal);}
.ai-sep{width:.5px;height:14px;background:var(--line-m);}

/* category tab strip */
.cat-strip{
  display:flex;align-items:center;gap:6px;
  margin:28px 0 20px;flex-wrap:wrap;
}
.ctab{
  display:flex;align-items:center;gap:5px;
  padding:6px 14px;border-radius:20px;
  font-size:12px;color:var(--ink1);
  cursor:pointer;border:0.5px solid var(--line-m);
  background:var(--panel);font-family:inherit;
  transition:all .18s;white-space:nowrap;
  box-shadow:0 1px 3px rgba(0,0,0,0.04);letter-spacing:.01em;
}
.ctab:hover{color:var(--ink0);border-color:rgba(0,0,0,.18);}
.ctab.active{
  color:#fff;
  background:linear-gradient(135deg, #818cf8, #4f46e5);
  border-color:transparent;font-weight:500;
  box-shadow:0 2px 10px rgba(184,147,90,0.28);
}
.ctab-ct{
  font-size:9px;padding:1px 5px;border-radius:7px;
  background:rgba(0,0,0,0.08);opacity:.8;
}
.ctab.active .ctab-ct{background:rgba(255,255,255,.25);opacity:1;}

/* featured banner */
.feat-banner{
  background:var(--panel);border:0.5px solid var(--line);
  border-radius:var(--r20);padding:20px 24px;
  margin-bottom:24px;
  display:flex;align-items:center;gap:22px;
  position:relative;overflow:hidden;
  box-shadow:0 1px 12px rgba(0,0,0,0.05);
}
.feat-banner::after{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--primary),transparent 55%);
  border-radius:var(--r20) var(--r20) 0 0;
}
.fb-badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:2px 8px;border-radius:20px;margin-bottom:7px;
  background:var(--primary-lt);border:0.5px solid var(--primary-bd);
  font-size:10px;color:var(--primary);font-weight:600;letter-spacing:.05em;
}
.fb-cont{flex:1;position:relative;z-index:1;}
.fb-title{font-size:15px;font-weight:500;color:var(--ink0);margin-bottom:5px;letter-spacing:-.01em;}
.fb-desc{font-size:12px;color:var(--ink1);line-height:1.6;max-width:360px;}
.fb-thumbs{display:flex;gap:7px;flex-shrink:0;}
.fb-th{
  width:64px;height:64px;border-radius:10px;
  border:0.5px solid var(--line-m);overflow:hidden;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-size:18px;gap:2px;
}
.fb-tl{font-size:9px;color:var(--ink2);}
.fb-btn{
  padding:8px 20px;border-radius:20px;
  background:linear-gradient(135deg, #818cf8, #4f46e5);
  color:#fff;font-size:12px;font-weight:600;
  border:none;cursor:pointer;flex-shrink:0;
  font-family:inherit;transition:all .15s;
  box-shadow:0 2px 8px rgba(79,70,229,0.3);
}
.fb-btn:hover{opacity:.9;transform:translateY(-1px);}

/* section header */
.sec-hd{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:14px;
}
.sec-t{font-size:14px;font-weight:500;color:var(--ink0);letter-spacing:-.01em;}
.sec-s{font-size:11px;color:var(--ink2);margin-top:2px;}
.sec-more{
  font-size:12px;color:var(--primary);background:none;border:none;
  cursor:pointer;font-family:inherit;transition:opacity .15s;
}
.sec-more:hover{opacity:.65;}

/* sub-tabs (精选/最新/最多) */
.sub-tabs{
  display:flex;align-items:center;gap:0;
  border-bottom:0.5px solid var(--line);
  margin-bottom:20px;
}
.stab{
  padding:9px 16px;font-size:13px;color:var(--ink1);
  cursor:pointer;border:none;background:none;font-family:inherit;
  border-bottom:2px solid transparent;margin-bottom:-.5px;
  transition:color .15s;letter-spacing:.01em;
}
.stab:hover{color:var(--ink0);}
.stab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:500;}
.stab-ct{
  font-size:10px;background:rgba(0,0,0,.05);color:var(--ink2);
  padding:1px 5px;border-radius:5px;margin-left:4px;
}
.stab.active .stab-ct{background:var(--primary-lt);color:var(--primary);}
.stabs-r{margin-left:auto;display:flex;align-items:center;gap:7px;}
.sort-sel{
  font-size:12px;color:var(--ink1);background:var(--panel);
  border:0.5px solid var(--line-m);border-radius:var(--r10);
  padding:5px 9px;cursor:pointer;outline:none;font-family:inherit;
}

/* ─── WATERFALL ─── */
.wfall{ columns:4;column-gap:13px;margin-bottom:36px; }
.wfall.c3{ columns:3; }

.wc{
  break-inside:avoid;border-radius:var(--r14);overflow:hidden;
  background:var(--panel);border:0.5px solid var(--line);
  cursor:pointer;transition:border-color .18s,transform .2s,box-shadow .2s;
  margin-bottom:13px;
  box-shadow:0 1px 4px rgba(0,0,0,0.04);
}
.wc:hover{
  border-color:var(--primary-bd);
  transform:translateY(-2px);
  box-shadow:0 6px 22px rgba(0,0,0,0.08),0 2px 6px rgba(184,147,90,0.08);
}
.wc:hover .wov{opacity:1;}
.wc:hover .wacts{opacity:1;transform:translateY(0);}

.wkv{width:100%;position:relative;overflow:hidden;display:flex;align-items:flex-end;}
.h130{height:130px}.h160{height:160px}.h190{height:190px}
.h220{height:220px}.h265{height:265px}.h310{height:310px}.h350{height:350px}

/* KV light palettes */
.c-res1{background:linear-gradient(175deg,#dce4ed 0%,#c6d2e0 45%,#aec0d2 100%);}
.c-res2{background:linear-gradient(175deg,#d6dee8 0%,#c2ccd6 45%,#aabbcb 100%);}
.c-res3{background:linear-gradient(165deg,#e0dbd4 0%,#ccc3b6 45%,#baafa0 100%);}
.c-res4{background:linear-gradient(175deg,#d8dfd8 0%,#c2ccc2 50%,#aebcae 100%);}
.c-com1{background:linear-gradient(180deg,#181410 0%,#261c14 35%,#301e0e 60%,#201808 100%);}
.c-com2{background:linear-gradient(165deg,#14121a 0%,#201c26 40%,#2a2016 70%,#1c180e 100%);}
.c-com3{background:linear-gradient(180deg,#120e16 0%,#1c1620 40%,#261c12 70%,#180e06 100%);}
.c-apt1{background:linear-gradient(175deg,#dedad4 0%,#ccc6be 50%,#bcb3aa 100%);}
.c-grn1{background:linear-gradient(175deg,#d4e0d4 0%,#bccebb 50%,#a6bca6 100%);}
.c-grn2{background:linear-gradient(165deg,#d0dcd0 0%,#bacabb 50%,#a4b8a5 100%);}
.c-brd1{background:linear-gradient(175deg,#e8e0d0 0%,#d4c8b4 50%,#c0b49a 100%);}
.c-brd2{background:linear-gradient(165deg,#e4dcea 0%,#d0c6d8 50%,#bcaec6 100%);}

.wkv svg{position:absolute;inset:0;width:100%;height:100%;}
.kvfd{
  position:absolute;bottom:0;left:0;right:0;height:65%;
  background:linear-gradient(transparent,rgba(255,255,255,.85));
  pointer-events:none;z-index:1;
}
.c-com1 .kvfd,.c-com2 .kvfd,.c-com3 .kvfd{
  background:linear-gradient(transparent,rgba(22,16,8,.7));
}
.kvlbs{position:absolute;bottom:0;left:0;right:0;padding:9px 12px;z-index:2;}
.kvn{font-size:12px;font-weight:500;color:var(--ink0);letter-spacing:-.01em;}
.c-com1 .kvn,.c-com2 .kvn,.c-com3 .kvn{color:rgba(255,255,255,.9);}
.kvt{font-size:10px;color:var(--ink2);margin-top:1px;}
.c-com1 .kvt,.c-com2 .kvt,.c-com3 .kvt{color:rgba(255,255,255,.45);}

.wov{
  position:absolute;inset:0;opacity:0;transition:opacity .2s;z-index:5;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.32);backdrop-filter:blur(2px);
}
.c-com1 .wov,.c-com2 .wov,.c-com3 .wov{background:rgba(0,0,0,.3);}
.wacts{
  display:flex;gap:8px;opacity:0;
  transform:translateY(6px);transition:all .2s;
}
.wa{
  padding:7px 14px;border-radius:20px;
  font-size:11px;font-weight:600;cursor:pointer;
  border:none;font-family:inherit;transition:all .15s;
}
.wa-u{background:linear-gradient(135deg, #818cf8, #4f46e5);color:#fff;box-shadow:0 2px 8px rgba(184,147,90,.3);}
.wa-p{background:rgba(255,255,255,.92);color:var(--ink0);border:0.5px solid var(--line-m);}
.wa:hover{opacity:.85;transform:translateY(-1px);}

.wi{padding:10px 12px 11px;}
.wn{font-size:12px;font-weight:500;color:var(--ink0);margin-bottom:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.wm{display:flex;align-items:center;gap:5px;}
.wtg{font-size:10px;padding:2px 6px;border-radius:4px;}
.wtg.f{background:var(--primary-lt);color:var(--primary);}
.wtg.h{background:rgba(210,70,50,.08);color:#c05040;}
.wtg.n{background:var(--teal-lt);color:var(--teal);}
.wtg.b{background:var(--blue-lt);color:var(--blue);}
.wu{margin-left:auto;font-size:10px;color:var(--ink2);}
.sdiv{height:.5px;background:var(--line);margin:6px 0 24px;}


/* ═══════════════════════════
   GENERATE VIEW
═══════════════════════════ */
.gen-view{
  display:none;flex:1;overflow:hidden;flex-direction:column;
}
.gen-view.active{display:flex;}

/* ═══════════════════════════════════════════
   IMAGE SET GENERATION VIEW (gsv)
═══════════════════════════════════════════ */
.gsv-hd {
  display:flex; align-items:center; gap:12px; padding:0 16px;
  height:52px; flex-shrink:0; background:#fff;
  border-bottom:1px solid var(--line-m);
}
.gsv-hd-tabs {
  display:flex; background:#f3f4f6; border-radius:8px; padding:2px; gap:0;
}
.gsv-hd-tab {
  padding:4px 14px; border-radius:6px; border:none; background:none;
  font-size:12px; font-weight:500; color:var(--ink2); cursor:pointer; transition:all 0.18s;
}
.gsv-hd-tab.active { background:#fff; color:var(--ink0); box-shadow:0 1px 4px rgba(0,0,0,0.08); }
.gsv-hd-r { margin-left:auto; display:flex; align-items:center; gap:8px; }
.gsv-hd-btn {
  display:flex; align-items:center; gap:6px; padding:6px 14px; border-radius:8px;
  border:1px solid var(--line-m); background:#fff; font-size:12px; font-weight:600;
  color:var(--ink0); cursor:pointer; transition:all 0.18s; white-space:nowrap;
}
.gsv-hd-btn:hover { border-color:var(--primary-bd); color:var(--primary); }
.gsv-hd-btn.primary { background:linear-gradient(135deg,#4f46e5,#9333ea); color:#fff; border:none; box-shadow:0 2px 8px rgba(79,70,229,0.25); }
.gsv-hd-btn.primary:hover { opacity:0.88; }

.gsv-body { display:flex; flex:1; overflow:hidden; }

/* ── Left panel ── */
.gsv-left {
  width:256px; flex-shrink:0; background:#fff; border-right:1px solid var(--line-m);
  display:flex; flex-direction:column; overflow-y:auto; scrollbar-width:thin;
}
.gsv-section { padding:16px 16px 0; }
.gsv-section-label {
  font-size:11px; font-weight:700; color:var(--ink2); text-transform:uppercase;
  letter-spacing:0.5px; margin-bottom:10px; display:flex; align-items:center;
}

/* Preset 2×2 grid */
.gsv-presets-grid { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.gsp-card {
  padding:10px 8px; border-radius:10px; border:2px solid var(--line-m);
  background:#fff; cursor:pointer; transition:all 0.2s; text-align:center;
}
.gsp-card:hover { border-color:var(--primary-bd); background:var(--primary-lt); }
.gsp-card.active { border-color:var(--primary); background:var(--primary-lt); }
.gsp-card-icon { font-size:20px; line-height:1; margin-bottom:4px; }
.gsp-card-name { font-size:11px; font-weight:700; color:var(--ink0); }
.gsp-card-count { font-size:10px; color:var(--ink2); margin-top:1px; }

/* Size chips */
.gsv-sizes-list { display:flex; flex-direction:column; gap:5px; }
.gsv-size-chip {
  display:flex; align-items:center; gap:7px; padding:6px 9px;
  background:#f8f9fb; border-radius:8px; border:1px solid var(--line-m);
}
.gsv-size-ratio {
  font-size:10px; font-weight:700; color:var(--primary);
  background:var(--primary-lt); padding:2px 6px; border-radius:5px; flex-shrink:0;
}
.gsv-size-name { font-size:12px; font-weight:600; color:var(--ink0); flex:1; min-width:0; }
.gsv-size-px { font-size:10px; color:var(--ink2); flex-shrink:0; }

/* Upload area */
.gsv-upload-area {
  border:2px dashed #d4b8fd; border-radius:10px; height:96px;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all 0.2s; overflow:hidden; position:relative;
  background:#faf5ff;
}
.gsv-upload-area:hover { border-color:var(--primary); background:var(--primary-lt); }

/* Prompt */
.gsv-prompt-ta {
  width:100%; box-sizing:border-box; border:1px solid var(--line-m); border-radius:10px;
  padding:10px 12px; font-size:12px; color:var(--ink0); line-height:1.65; resize:none;
  font-family:inherit; background:#f8f9fb; outline:none; transition:border-color 0.2s;
}
.gsv-prompt-ta:focus { border-color:var(--primary-bd); background:#fff; }

/* Generate button */
.gsv-gen-btn {
  margin:16px; padding:11px; border-radius:12px; border:none;
  background:linear-gradient(135deg,#4f46e5,#9333ea); color:#fff;
  font-size:13px; font-weight:700; cursor:pointer;
  transition:all 0.2s; box-shadow:0 4px 14px rgba(79,70,229,0.28);
  display:flex; align-items:center; justify-content:center; gap:7px; flex-shrink:0;
}
.gsv-gen-btn:hover:not(:disabled) { transform:translateY(-1px); box-shadow:0 6px 20px rgba(79,70,229,0.35); }
.gsv-gen-btn:disabled { opacity:0.65; cursor:not-allowed; transform:none; }

/* ── Right panel ── */
.gsv-right { flex:1; display:flex; flex-direction:column; overflow:hidden; background:#f0f2f5; }

.gsv-filter-bar {
  padding:10px 20px; display:flex; gap:7px; align-items:center;
  border-bottom:1px solid var(--line-m); background:#fff; flex-shrink:0;
}
.gsv-filter-tab {
  padding:5px 14px; border-radius:20px; border:1px solid var(--line-m);
  background:#fff; font-size:12px; font-weight:500; color:var(--ink2);
  cursor:pointer; transition:all 0.18s; white-space:nowrap;
}
.gsv-filter-tab.active { background:var(--primary); color:#fff; border-color:var(--primary); }
.gsv-filter-tab:hover:not(.active) { border-color:var(--primary-bd); color:var(--primary); }

/* Image grid */
.gsv-img-grid {
  flex:1; overflow-y:auto; padding:20px; display:flex; flex-wrap:wrap; gap:14px;
  align-content:flex-start; scrollbar-width:thin;
}

/* Image card */
.gsi-card {
  background:#fff; border-radius:14px; border:1px solid var(--line-m);
  overflow:hidden; box-shadow:0 2px 8px rgba(0,0,0,0.04);
  transition:all 0.22s; flex-shrink:0; display:flex; flex-direction:column;
}
.gsi-card:hover { box-shadow:0 6px 22px rgba(0,0,0,0.1); transform:translateY(-2px); }
.gsi-card-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:9px 12px 7px;
}
.gsi-badge { font-size:11px; font-weight:700; color:var(--ink0); }
.gsi-ratio-badge {
  font-size:10px; padding:2px 7px; border-radius:7px;
  background:var(--primary-lt); color:var(--primary); font-weight:700;
}
.gsi-img-area {
  background:#f3f4f6; margin:0 10px; border-radius:8px;
  display:flex; align-items:center; justify-content:center; overflow:hidden;
}
.gsi-placeholder { display:flex; flex-direction:column; align-items:center; gap:4px; }
.gsi-card-footer {
  padding:7px 12px 10px; display:flex; align-items:center;
  justify-content:space-between; min-height:30px; flex-shrink:0;
}
.gsi-px-label { font-size:10px; color:var(--ink2); font-weight:500; }
.gsi-action {
  width:26px; height:26px; border-radius:7px; border:1px solid var(--line-m);
  background:#fff; font-size:11px; color:var(--ink1); cursor:pointer;
  display:flex; align-items:center; justify-content:center; transition:all 0.18s;
}
.gsi-action:hover { background:var(--primary); color:#fff; border-color:var(--primary); }

/* Shimmer */
@keyframes gsiShimmer { 0%{background-position:-400% 0} 100%{background-position:400% 0} }
.gsi-shimmer {
  background:linear-gradient(90deg,#ececec 25%,#e0e0e0 50%,#ececec 75%) !important;
  background-size:400% 100% !important;
  animation:gsiShimmer 1.4s ease infinite !important;
}
@keyframes gsiFadeIn { from{opacity:0;transform:scale(0.95)} to{opacity:1;transform:scale(1)} }
.gsi-img { animation:gsiFadeIn 0.45s ease; }

/* Action bar */
.gsv-action-bar {
  display:flex; align-items:center; justify-content:center; gap:8px; flex-wrap:wrap;
  padding:12px 20px; border-top:1px solid var(--line-m); background:#fff; flex-shrink:0;
  animation:acSlideUp 0.3s ease;
}
.gsv-action-btn {
  display:flex; align-items:center; gap:6px; padding:8px 18px; border-radius:10px;
  border:1px solid var(--line-m); background:#fff; font-size:13px; font-weight:600;
  color:var(--ink0); cursor:pointer; transition:all 0.18s;
}
.gsv-action-btn:hover { border-color:var(--primary-bd); color:var(--primary); background:var(--primary-lt); }
.gsv-action-btn.primary { background:linear-gradient(135deg,#4f46e5,#9333ea); color:#fff; border:none; box-shadow:0 2px 8px rgba(79,70,229,0.25); }
.gsv-action-btn.primary:hover { opacity:0.88; color:#fff; }
.gsv-action-sep { width:1px; height:20px; background:var(--line-m); flex-shrink:0; }

/* left param panel */
.gen-panel{
  width:280px;flex-shrink:0;
  background:var(--panel);
  border-right:0.5px solid var(--line);
  overflow-y:auto;padding:16px;
  display:flex;flex-direction:column;gap:20px;
}
.gp-section{}
.gp-hd{
  display:flex;align-items:center;justify-content:space-between;
  font-size:12px;font-weight:600;color:var(--ink0);
  margin-bottom:12px;cursor:pointer;letter-spacing:.01em;
}
.gp-arrow{font-size:10px;color:var(--ink2);transition:transform .15s;}
.gp-hd.open .gp-arrow{transform:rotate(180deg);}

.gp-field{margin-bottom:10px;}
.gp-label{font-size:11px;color:var(--ink1);margin-bottom:5px;display:block;}
.gp-select{
  width:100%;padding:8px 10px;border-radius:var(--r10);
  background:var(--bg);border:0.5px solid var(--line-m);
  font-size:12px;color:var(--ink0);font-family:inherit;
  outline:none;cursor:pointer;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%23999690' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 10px center;
  padding-right:28px;
}
.gp-select:focus{border-color:var(--primary-bd);}

/* ratio pills */
.ratio-pills{display:flex;gap:6px;flex-wrap:wrap;}
.rpill{
  padding:5px 12px;border-radius:20px;font-size:11px;
  border:0.5px solid var(--line-m);color:var(--ink1);
  cursor:pointer;background:transparent;font-family:inherit;transition:all .15s;
}
.rpill:hover{border-color:var(--primary-bd);color:var(--primary);}
.rpill.active{background:var(--primary-lt);border-color:var(--primary-bd);color:var(--primary);font-weight:500;}

/* ref image upload */
.ref-area{
  border:1px dashed var(--line-m);border-radius:var(--r10);
  padding:16px;display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:6px;cursor:pointer;transition:all .15s;
  min-height:80px;
}
.ref-area:hover{border-color:var(--primary-bd);background:var(--primary-lt);}
.ref-ico{font-size:20px;color:var(--ink2);}
.ref-txt{font-size:11px;color:var(--ink2);text-align:center;}
.ref-count{font-size:10px;color:var(--ink2);margin-top:2px;}

/* toggle row */
.toggle-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:6px 0;
}
.toggle-lbl{font-size:12px;color:var(--ink0);}
.toggle{
  width:32px;height:18px;border-radius:9px;
  background:rgba(0,0,0,0.15);
  position:relative;cursor:pointer;transition:background .15s;
  flex-shrink:0;
}
.toggle.on{background:var(--primary);}
.toggle::after{
  content:'';position:absolute;top:2px;left:2px;
  width:14px;height:14px;border-radius:50%;background:#fff;
  transition:transform .15s;box-shadow:0 1px 3px rgba(0,0,0,0.2);
}
.toggle.on::after{transform:translateX(14px);}

/* gen canvas */
.gen-canvas{
  flex:1;overflow:hidden;
  display:flex;flex-direction:column;
  background:var(--bg);
}

/* result area */
.gen-result{
  flex:1;overflow-y:auto;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
}
.gen-empty{text-align:center;}
.gen-empty-ico{
  width:64px;height:64px;border-radius:16px;
  background:linear-gradient(135deg,var(--primary-lt),rgba(184,147,90,0.18));
  display:flex;align-items:center;justify-content:center;
  font-size:28px;margin:0 auto 14px;
}
.gen-empty h3{font-size:16px;font-weight:500;color:var(--ink0);margin-bottom:6px;}
.gen-empty p{font-size:13px;color:var(--ink1);line-height:1.65;max-width:300px;}

/* generated image result */
.gen-img-wrap{
  display:none;
  max-width:720px;width:100%;
  border-radius:var(--r20);overflow:hidden;
  border:0.5px solid var(--line);
  box-shadow:0 8px 32px rgba(0,0,0,0.08);
  position:relative;
}
.gen-img-wrap.show{display:block;}
.gen-img-placeholder{
  width:100%;aspect-ratio:16/9;
  display:flex;align-items:center;justify-content:center;
  font-size:48px;
}
.gen-img-actions{
  position:absolute;top:12px;right:12px;
  display:flex;gap:7px;
}
.gia{
  padding:6px 12px;border-radius:20px;
  background:rgba(255,255,255,.92);
  border:0.5px solid var(--line-m);
  font-size:11px;color:var(--ink0);font-weight:500;
  cursor:pointer;font-family:inherit;
  backdrop-filter:blur(8px);transition:all .15s;
}
.gia:hover{background:#fff;}

/* prompt bar at bottom */
.gen-prompt-bar{
  padding:12px 16px;
  background:var(--panel);
  border-top:0.5px solid var(--line);
}
.gpb-inner{
  display:flex;align-items:flex-end;gap:10px;
  background:var(--bg);
  border:0.5px solid var(--line-m);
  border-radius:var(--r14);
  padding:10px 12px;
  transition:border-color .2s;
}
.gpb-inner:focus-within{border-color:var(--primary-bd);}
.gpb-label{
  font-size:10px;font-weight:600;letter-spacing:.06em;
  color:var(--ink2);text-transform:uppercase;
  margin-bottom:4px;
}
.gpb-textarea{
  flex:1;border:none;outline:none;background:transparent;
  font-size:13px;color:var(--ink0);font-family:inherit;
  resize:none;line-height:1.6;min-height:20px;max-height:80px;
  letter-spacing:.01em;
}
.gpb-textarea::placeholder{color:var(--ink2);}
.gpb-submit{
  padding:8px 20px;border-radius:20px;
  background:linear-gradient(135deg, #818cf8, #4f46e5);
  color:#fff;font-size:12px;font-weight:600;
  border:none;cursor:pointer;font-family:inherit;
  flex-shrink:0;align-self:flex-end;
  box-shadow:0 2px 8px rgba(79,70,229,0.3);transition:all .15s;
}
.gpb-submit:hover{opacity:.88;transform:translateY(-1px);}
.gpb-submit:disabled{opacity:.5;cursor:not-allowed;transform:none;}

/* loading spinner */
.gen-loading{
  display:none;
  flex-direction:column;align-items:center;gap:16px;
}
.gen-loading.show{display:flex;}
.spinner{
  width:40px;height:40px;border-radius:50%;
  border:2px solid var(--line-m);
  border-top-color:var(--primary);
  animation:spin .8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-txt{font-size:13px;color:var(--ink1);}

/* ═══════════════════════════
   GALLERY VIEW (图库)
═══════════════════════════ */
.gallery-view{display:none;flex:1;overflow:hidden;}
.gallery-view.active{display:flex;flex-direction:column;}

.gallery-top{
  display:flex;align-items:center;gap:8px;
  padding:14px 24px;
  background:var(--panel);border-bottom:0.5px solid var(--line);
  flex-shrink:0;
}
.gallery-search{
  flex:1;max-width:380px;position:relative;
}
.gall-sbar{
  width:100%;height:36px;border-radius:18px;
  background:var(--bg);border:0.5px solid var(--line-m);
  padding:0 36px 0 34px;font-size:13px;color:var(--ink0);
  outline:none;font-family:inherit;
}
.gall-sbar:focus{border-color:var(--primary-bd);}
.gall-ico{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:14px;color:var(--ink2);pointer-events:none;}
.gallery-filters{display:flex;gap:6px;}
.gfilt{
  padding:5px 12px;border-radius:20px;
  font-size:11px;border:0.5px solid var(--line-m);
  color:var(--ink1);cursor:pointer;background:var(--panel);
  font-family:inherit;transition:all .15s;
}
.gfilt:hover{color:var(--ink0);}
.gfilt.active{background:var(--primary-lt);border-color:var(--primary-bd);color:var(--primary);font-weight:500;}
.gallery-scroll{flex:1;overflow-y:auto;padding:16px 24px 40px;}
.gallery-wfall{columns:4;column-gap:13px;}
.gcard{
  break-inside:avoid;margin-bottom:13px;
  border-radius:var(--r14);overflow:hidden;
  cursor:pointer;position:relative;
  box-shadow:0 1px 4px rgba(0,0,0,0.05);
  transition:transform .18s,box-shadow .18s;
}
.gcard:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,0.1);}
.gcard:hover .gc-overlay{opacity:1;}
.gc-img{
  width:100%;display:block;object-fit:cover;
}
.gc-img-ph{
  width:100%;display:flex;align-items:center;justify-content:center;font-size:30px;
}
.gc-overlay{
  position:absolute;inset:0;
  background:rgba(0,0,0,0.22);
  opacity:0;transition:opacity .18s;
  display:flex;align-items:flex-end;padding:12px;
}
.gc-overlay-inner{display:flex;align-items:center;justify-content:space-between;width:100%;}
.gc-prompt{font-size:11px;color:rgba(255,255,255,.85);flex:1;margin-right:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.gc-view-btn{
  padding:5px 12px;border-radius:20px;
  background:rgba(255,255,255,.9);
  font-size:11px;font-weight:600;color:var(--ink0);
  border:none;cursor:pointer;flex-shrink:0;font-family:inherit;
}

/* ═══════════════════════════
   MODAL
═══════════════════════════ */
.modal-bg{
  display:none;position:fixed;inset:0;z-index:500;
  background:rgba(242,241,238,.65);
  backdrop-filter:blur(16px) saturate(1.2);
  align-items:center;justify-content:center;
}
.modal-bg.open{display:flex;animation:mfade .2s ease;}
@keyframes mfade{from{opacity:0}to{opacity:1}}
.modal{
  width:500px;max-width:calc(100vw - 32px);
  background:#fff;border:0.5px solid var(--line-m);
  border-radius:var(--r20);overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,0.13);
  animation:mslide .22s ease;position:relative;
}
@keyframes mslide{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.modal-thumb{width:100%;height:240px;position:relative;overflow:hidden;}
.modal-thumb svg{position:absolute;inset:0;width:100%;height:100%;}
.modal-thumb-fade{
  position:absolute;bottom:0;left:0;right:0;height:45%;
  background:linear-gradient(transparent,#fff);z-index:2;pointer-events:none;
}
.modal-close{
  position:absolute;top:12px;right:12px;
  width:28px;height:28px;border-radius:50%;
  background:rgba(255,255,255,.9);border:0.5px solid var(--line-m);
  color:var(--ink1);font-size:13px;cursor:pointer;z-index:10;
  display:flex;align-items:center;justify-content:center;
  backdrop-filter:blur(6px);transition:all .15s;
}
.modal-close:hover{background:#fff;color:var(--ink0);}
.modal-body{padding:20px 22px 22px;}
.modal-title{font-size:16px;font-weight:500;color:var(--ink0);margin-bottom:5px;letter-spacing:-.01em;}
.modal-desc{font-size:13px;color:var(--ink1);line-height:1.7;margin-bottom:14px;font-weight:300;}
.modal-tags{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:16px;}
.mt{font-size:11px;padding:2px 9px;border-radius:20px;background:rgba(0,0,0,0.04);color:var(--ink1);border:0.5px solid var(--line);}
.modal-btns{display:flex;gap:9px;}
.mbtn{
  flex:1;padding:10px;border-radius:10px;
  font-size:13px;font-weight:600;cursor:pointer;
  border:none;font-family:inherit;transition:all .15s;
}
.mbtn-p{background:linear-gradient(135deg, #818cf8, #4f46e5);color:#fff;box-shadow:0 2px 10px rgba(184,147,90,.25);}
.mbtn-g{background:rgba(0,0,0,0.05);color:var(--ink0);border:0.5px solid var(--line-m);}
.mbtn:hover{opacity:.88;transform:translateY(-1px);}

/* anim */
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.home-hero{animation:fadeUp .5s ease both;}
.feat-banner{animation:fadeUp .5s .06s ease both;}
.wfall{animation:fadeUp .5s .1s ease both;}

/* ─── NEW SEARCH BLOCK STYLES ─── */
.search-block {
  width: 100%;
  max-width: 830px;
  margin: 24px auto 0;
  border-radius: 24px;
  overflow: visible;
  position: relative;
  z-index: 50;
  padding: 0;
  background: transparent;
  border: none;
  box-shadow: none;
}
.search-block:focus-within {
  border-color: transparent;
  box-shadow: none;
}
.mode-tabs {
  display: flex;
  gap: 12px;
  margin-bottom: 0;
  padding: 0 16px;
  border: none;
  position: relative;
  z-index: 1; /* Move tabs behind the search container */
  top: 32px; /* Push further down so it overlaps search container deeply */
  align-items: flex-end; /* Align tabs to the bottom */
  height: 124px; /* Fix the container height to prevent layout shift/jitter */
}

/* NEW TAB STYLES (Matching new reference image) */
.mtab-wrap {
  position: relative;
  flex: 1;
  height: 80px; /* Increased base height */
  cursor: pointer;
  border-radius: 16px 16px 0 0;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.6);
  border-bottom: none;
  background: linear-gradient(180deg, rgba(255,255,255,0.6) 0%, rgba(255,255,255,0.9) 100%);
  box-shadow: inset 0 2px 4px rgba(255,255,255,0.5);
  transform-origin: bottom center;
}

.mtab-bg {
  position: absolute;
  inset: 0;
  background: transparent;
  backdrop-filter: blur(16px);
  border-radius: 16px 16px 0 0;
  transition: all 0.3s;
}

.mtab-content {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column; /* Changed to column to align with user instruction */
  align-items: flex-start; /* Align text to left */
  justify-content: center;
  padding-left: 16px;
  gap: 0px; /* Further reduced gap to allow overlap */
  height: 100%;
}

.mtab-bg-text {
  position: absolute;
  left: 12px;
  top: 12px;
  font-size: 32px;
  font-weight: 800;
  color: rgba(255, 255, 255, 0.6);
  z-index: -1;
  letter-spacing: 1px;
  pointer-events: none;
  transition: all 0.3s;
  font-family: Arial, Helvetica, sans-serif;
}

.mtab-text {
  font-size: 14px;
  font-weight: 600;
  color: var(--ink0);
  transition: all 0.3s;
  margin-top: 10px; /* Push text slightly down */
  margin-bottom: 10px; /* Added based on user instruction */
  position: relative;
  z-index: 2;
}

.mtab-icon-img {
  position: absolute;
  right: 12px;
  bottom: 0;
  width: 52px;
  height: auto;
  opacity: 0.6;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  transform: translateY(16px) rotate(5deg);
}

/* Hover States */
.mtab-wrap:hover {
  background: linear-gradient(180deg, rgba(255,255,255,0.7) 0%, rgba(255,255,255,1) 100%);
  height: 90px; /* Pull up slightly on hover */
}
.mtab-wrap:hover .mtab-icon-img {
  opacity: 0.8;
  transform: translateY(8px) rotate(0deg);
}

/* Active State */
.mtab-wrap.active {
  flex: 1;
  height: 124px; /* Significantly increase height to show the whole card and title clearly above the input */
  background: linear-gradient(180deg, #e0e7ff 0%, #ffffff 100%);
  border: 1.5px solid #fff;
  border-bottom: none;
  box-shadow: 0 -4px 16px rgba(79, 70, 229, 0.08), inset 0 2px 6px rgba(255,255,255,0.8);
  z-index: 2; /* Keep behind search container */
}

.mtab-wrap.active .mtab-bg {
  backdrop-filter: blur(20px);
}

.mtab-wrap.active .mtab-text {
  color: var(--ink0);
  font-size: 18px; /* 文字变大 */
  margin-top: -12px; /* 向上移动，形成重叠 */
  position: relative; /* 为了与背景文案重叠 */
  z-index: 2;
}

.mtab-wrap.active .mtab-bg-text {
  color: rgba(255, 255, 255, 0.9);
  font-size: 32px; /* 背景文案变小 */
  top: 12px;
  left: 12px;
  z-index: 1; /* 保证在前景文字后方 */
}

.mtab-wrap.active .mtab-icon-img {
  width: 72px;
  opacity: 1;
  transform: translateY(-28px) rotate(-5deg); /* Pull image up significantly */
  filter: drop-shadow(0 4px 8px rgba(0,0,0,0.15));
}

/* Ensure the search row connects seamlessly */
.search-row-container {
  border: 0px solid #5c63c1;
  border-radius: 24px;
  padding: 16px 20px;
  background-color: rgba(255, 255, 255, 0.9);
  backdrop-filter: blur(20px);
  box-shadow: 0 4px 20px rgba(79, 70, 229, 0.06), inset 0 0 0 1px rgba(255, 255, 255, 0.9), 0 12px 40px rgba(0, 0, 0, 0.04);
  position: relative;
  z-index: 5;
  margin-top: -12px; /* Pull up slightly to hide the gap and connect with tabs */
}
.search-row-container::before {
  content: ''; position: absolute; inset: -3px; border-radius: 27px;
  padding: 3px; background: linear-gradient(135deg, rgba(129, 140, 248, 0.6), rgba(168, 85, 247, 0.55), rgba(236, 72, 153, 0.4));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude; pointer-events: none;
}
.search-input-wrap { margin-bottom: 12px; }
.ptd-btn {
  background: #f4f5f8; border: none; border-radius: 8px; padding: 6px 14px;
  font-size: 13px; color: var(--ink1); cursor: pointer; display: flex; align-items: center; gap: 4px;
  transition: all 0.2s;
}
.ptd-btn:hover { background: #eef0f4; color: var(--ink0); }
.srbar-multi {
  width: 100%;
  min-height: 24px;
  height: auto;
  max-height: 160px;
  border: none;
  resize: none;
  outline: none;
  overflow-y: hidden;
  font-size: 14px;
  color: var(--ink0);
  font-family: inherit;
  line-height: 1.6;
  background: transparent;
  display: block;
}
.srbar-multi::placeholder {
  color: #999999;
}
.search-bottom-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.sba-left, .sba-right { display: flex; align-items: center; gap: 8px; }
.sba-add-btn {
  width: 24px; height: 24px; border-radius: 50%;
  border: 1px solid var(--line-m); background: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; color: var(--ink1); cursor: pointer;
}
.sba-dropdown-wrap { position: relative; }
.sba-select-btn {
  background: #f3f4f6; color: var(--ink0);
  display: flex; align-items: center; gap: 6px;
  padding: 6px 12px; border-radius: 16px;
  border: none; font-size: 12px;
  font-weight: 500; cursor: pointer;
}
.sba-auto-btn {
  display: flex; align-items: center; gap: 4px;
  padding: 6px 12px; border-radius: 16px;
  background: #fff; border: 1px solid var(--line-m);
  font-size: 12px; color: var(--ink0); cursor: pointer;
}
.sba-magic-btn {
  width: 24px; height: 24px; border-radius: 8px;
  background: transparent; border: none; font-size: 20px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--ink1);
}
.sr-btn {
  height: 36px; padding: 0 24px; border-radius: 18px;
  background: linear-gradient(135deg, #4f46e5, #9333ea); /* Blue-purple gradient */
  color: #fff; font-size: 14px; font-weight: 500;
  border: none; cursor: pointer; transition: all 0.2s;
  box-shadow: 0 4px 12px rgba(147, 51, 234, 0.3);
}
.sr-btn:hover { opacity: 0.9; box-shadow: 0 6px 16px rgba(147, 51, 234, 0.4); transform: translateY(-1px); }

/* 生成模式下拉菜单 */
.gen-mode-drop {
  display: none; position: absolute; bottom: calc(100% + 8px); left: 0;
  width: 200px; background: #fff; border-radius: 16px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.1); padding: 12px;
  border: 1px solid var(--line-m); z-index: 100;
}
.gen-mode-drop.show { display: block; animation: dropUp 0.2s ease; }
@keyframes dropUp { from{opacity:0; transform:translateY(10px)} to{opacity:1; transform:translateY(0)} }
.gmd-title { font-size: 11px; color: var(--ink2); margin-bottom: 8px; padding-left: 4px; }
.gmd-item {
  display: flex; align-items: center; gap: 10px; padding: 10px;
  border-radius: 12px; cursor: pointer; transition: all 0.2s;
  border: 1.5px solid transparent;
}
.gmd-item:hover { background: #f5f6f8; }
.gmd-item.active { 
  background: var(--primary-lt); 
  border-color: var(--primary);
  box-shadow: 0 0 12px rgba(79, 70, 229, 0.15);
}
.gmd-item.active .gmd-icon {
  animation: pulse-ai 2s infinite;
}
@keyframes pulse-ai {
  0% { transform: scale(1); opacity: 1; filter: drop-shadow(0 0 2px var(--primary)); }
  50% { transform: scale(1.1); opacity: 0.8; filter: drop-shadow(0 0 6px var(--primary)) hue-rotate(45deg); }
  100% { transform: scale(1); opacity: 1; filter: drop-shadow(0 0 2px var(--primary)); }
}
.gmd-icon { font-size: 16px; }
.gmd-text { flex: 1; }
.gmd-t { font-size: 13px; font-weight: 500; color: var(--ink0); }
.gmd-s { font-size: 11px; color: var(--ink2); margin-top: 2px; }
.gmd-check { display: none; color: var(--primary); font-weight: bold; }
.gmd-item.active .gmd-check { display: block; }

/* ─── NEW HORIZONTAL GALLERY STYLES ─── */
.h-gallery-wrap {
  display: flex; gap: 20px; background: var(--panel);
  border-radius: 20px; padding: 20px; border: 1px solid var(--line);
  box-shadow: 0 2px 12px rgba(0,0,0,0.03); align-items: center;
}
.hg-left-info { width: 140px; flex-shrink: 0; }
.hg-title { font-size: 16px; font-weight: 600; color: var(--ink0); margin-bottom: 8px; line-height: 1.3; }
.hg-desc { font-size: 12px; color: var(--ink2); line-height: 1.6; margin-bottom: 16px; }
.hg-navs { display: flex; gap: 8px; }
.hg-nav-btn {
  width: 28px; height: 28px; border-radius: 50%;
  border: 1px solid var(--line-m); background: #fff;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; font-size: 16px; color: var(--ink1);
}
.hg-nav-btn:hover { border-color: var(--ink0); color: var(--ink0); }
/* hg-scroll: clipping wrapper (overflow hidden); inner strip slides via transform */
.hg-scroll {
  flex: 1; min-width: 0; overflow: hidden; position: relative;
}
.hg-scroll-inner {
  display: flex; gap: 12px;
  transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: transform;
}
.hg-item {
  width: 170px; height: 230px; flex-shrink: 0; border-radius: 12px;
  overflow: hidden; position: relative; cursor: pointer;
}
.hg-img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s; }
.hg-item:hover .hg-img { transform: scale(1.05); }
.hg-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.8) 0%, transparent 50%);
  display: flex; flex-direction: column; justify-content: flex-end; padding: 16px;
}
.hg-tag {
  font-size: 10px; color: #fff; background: rgba(255,255,255,0.2);
  padding: 2px 8px; border-radius: 4px; width: fit-content; margin-bottom: 6px;
}
.hg-name { font-size: 14px; font-weight: 500; color: #fff; }

.hg-make-btn {
  position: absolute; top: 40%; left: 50%; transform: translate(-50%, -50%);
  background: rgba(255,255,255,0.95); color: var(--ink0);
  border: none; border-radius: 20px; padding: 6px 16px;
  font-size: 12px; font-weight: 600; opacity: 0; transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 4px 12px rgba(0,0,0,0.1); pointer-events: none;
}
.hg-item:hover .hg-make-btn {
  opacity: 1; top: 50%;
}

/* ─── SMART AI STYLES & GEN VIEW FF ─── */
body {
  background: #e6e9f5; /* Light blue-purple base from user image */
  background-image: 
    radial-gradient(circle at 20% 30%, rgba(255, 255, 255, 0.6) 0%, transparent 60%),
    radial-gradient(circle at 80% 70%, rgba(255, 255, 255, 0.4) 0%, transparent 60%);
  background-attachment: fixed;
}
.home-hero-bg {
  position: absolute; inset: 0; pointer-events: none;
  background: url('data:image/svg+xml;utf8,<svg viewBox="0 0 100 100" xmlns="http://www.w3.org/2000/svg"><path d="M0,50 Q25,20 50,50 T100,50" fill="none" stroke="rgba(255,255,255,0.8)" stroke-width="0.8"/><path d="M0,60 Q30,30 60,60 T100,60" fill="none" stroke="rgba(255,255,255,0.6)" stroke-width="1.2"/><circle cx="50" cy="50" r="2" fill="rgba(255,255,255,0.9)"/></svg>') no-repeat center center;
  background-size: cover;
  opacity: 1;
}
.app-body {
  background: transparent;
}
.leftnav {
  background: rgba(255, 255, 255, 0.6);
  backdrop-filter: blur(20px);
}
.topbar {
  background: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(20px);
}
.gen-main-layout {
  display: flex; flex: 1; overflow: hidden;
  padding: 16px; gap: 16px;
  background: #f3f4f6; /* light gray background for the workspace */
}
.gen-panel-ff {
  width: 280px; flex-shrink: 0;
  background: #fff; border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.03);
  display: flex; flex-direction: column; overflow-y: auto;
}
.gp-section-ff {
  border-bottom: 1px solid var(--line);
}
.gp-hd-ff {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px; font-size: 13px; font-weight: 600; color: var(--ink0);
  cursor: pointer; user-select: none;
}
.gp-body-ff {
  padding: 0 20px 20px; display: flex; flex-direction: column; gap: 16px;
}
.gp-field-ff { display: flex; flex-direction: column; gap: 8px; }
.gp-label-ff { font-size: 12px; color: var(--ink1); }
.gp-select-ff {
  display: flex; align-items: center; justify-content: space-between;
  background: #f9fafb; border-radius: 8px; padding: 10px 12px;
  font-size: 13px; color: var(--ink0); cursor: pointer; border: 1px solid transparent;
  transition: all 0.2s;
}
.gp-select-ff:hover { background: #f3f4f6; }
.gp-select-ff:active { border-color: #d1d5db; }

.ref-upload-ff {
  display: flex; align-items: center; gap: 16px;
  background: #f9fafb; border-radius: 12px; padding: 16px;
  cursor: pointer; transition: all 0.2s;
}
.ref-upload-ff:hover { background: #f3f4f6; }
.ref-placeholder-ff {
  width: 48px; height: 48px; border-radius: 8px;
  border: 1px dashed var(--ink2); display: flex; align-items: center; justify-content: center;
  background: #fff;
}
.ref-btn-ff {
  background: #374151; color: #fff; border: none; border-radius: 20px;
  padding: 8px 16px; font-size: 12px; font-weight: 500; cursor: pointer;
  display: flex; align-items: center; gap: 6px;
}
.ref-btn-ff:hover { background: #1f2937; }

.gen-canvas-ff {
  flex: 1; display: flex; flex-direction: column; gap: 16px; overflow: hidden;
}
.gen-result-ff {
  flex: 1; display: flex; align-items: center; justify-content: center;
  background: transparent; overflow: hidden; border-radius: 12px;
  position: relative;
}
.gen-prompt-bar-ff {
  background: #fff; border-radius: 16px; padding: 16px 24px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.05);
  display: flex; flex-direction: column; gap: 12px;
}
.gpb-top-ff { display: flex; flex-direction: column; gap: 4px; }
.gpb-label-ff { font-size: 11px; color: var(--ink2); }
.gpb-textarea-ff {
  width: 100%; border: none; outline: none; resize: none;
  font-size: 14px; color: var(--ink0); line-height: 1.6; font-family: inherit;
  background: transparent;
}
.gpb-bottom-ff {
  display: flex; justify-content: flex-end; align-items: center;
}
.gpb-try-btn {
  display: flex; align-items: center; background: #eef2ff; color: #4f46e5;
  padding: 4px 12px 4px 4px; border-radius: 20px; font-size: 12px; font-weight: 500;
  cursor: pointer; transition: all 0.2s;
}
.gpb-try-btn:hover { background: #e0e7ff; }

/* Font Awesome already imported at top of file */

.prompt-top-dropdowns {
  display: flex; gap: 8px; margin-bottom: 12px;
}
.ptd-btn {
  background: #f4f5f8; border: none; border-radius: 8px; padding: 6px 14px;
  font-size: 13px; color: var(--ink1); cursor: pointer; display: flex; align-items: center; gap: 4px;
  transition: all 0.2s;
}
.ptd-btn:hover { background: #eef0f4; color: var(--ink0); }
/* .srbar-multi — canonical definition above, no override needed */
.sba-select-btn {
  background: #f3f4f6; color: var(--ink0);
}
.sba-magic-btn {
  background: transparent; font-size: 20px; color: var(--ink1);
}
.sr-btn {
  background: linear-gradient(90deg, #84cc16, #22c55e, #14b8a6); /* Greenish gradient like image 2 */
  color: #fff; box-shadow: 0 4px 12px rgba(34,197,94,0.3);
}
.sr-btn:hover { opacity: 0.9; box-shadow: 0 6px 16px rgba(34,197,94,0.4); }

/* Updated dropdowns for prompt bar (Image 2 style) */
.prompt-top-dropdowns {
  display: flex; gap: 8px; margin-bottom: 12px;
}
.ptd-btn {
  background: #f3f4f6; border: none; border-radius: 6px; padding: 6px 12px;
  font-size: 12px; color: var(--ink1); cursor: pointer; display: flex; align-items: center; gap: 4px;
}
.ptd-btn:hover { background: #e5e7eb; color: var(--ink0); }

.ptd-input {
  background: #f4f5f8; border: none; border-radius: 8px; padding: 6px 14px;
  font-size: 13px; color: var(--ink0); outline: none; width: 140px; transition: all 0.2s;
}
.ptd-input:focus { background: #eef0f4; box-shadow: 0 0 0 1px var(--primary-bd); }
.ptd-menu {
  display: none; position: absolute; top: calc(100% + 4px); left: 0;
  background: #fff; border: 1px solid var(--line-m); border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1); padding: 4px; min-width: 120px; z-index: 200;
}
.ptd-menu.show { display: block; animation: dropUp 0.2s ease; }
.ptd-menu-item {
  padding: 8px 12px; font-size: 13px; color: var(--ink0); border-radius: 6px; cursor: pointer;
}
.ptd-menu-item:hover { background: #f4f5f8; color: var(--primary); font-weight: 500; }
.hover-primary:hover { color: var(--primary); }

/* ═══════════════════════════
   TEMPLATES VIEW
═══════════════════════════ */
.tpl-filter-row { display: flex; align-items: center; font-size: 13px; margin-bottom: 16px; }
.tpl-filter-label { color: var(--ink2); width: 48px; flex-shrink: 0; }
.tpl-filter-items { display: flex; flex-wrap: wrap; gap: 8px; flex: 1; align-items: center; }
.tpl-tag { padding: 4px 12px; border-radius: 16px; color: var(--ink1); cursor: pointer; transition: all 0.2s; white-space: nowrap; }
.tpl-tag:hover { color: var(--primary); }
.tpl-tag.active { background: #eef2ff; color: var(--primary); font-weight: 600; }
.tpl-tag.vip { display: flex; align-items: center; gap: 4px; }

.tpl-waterfall { columns: 4; column-gap: 16px; margin-top: 16px; }
.tpl-card {
  break-inside: avoid; margin-bottom: 16px; border-radius: 16px;
  overflow: hidden; background: #fff;
  box-shadow: 0 4px 16px rgba(0,0,0,0.04); border: 1px solid var(--line-m);
  cursor: pointer; transition: all 0.25s; position: relative;
}
.tpl-card:hover { transform: translateY(-4px); box-shadow: 0 12px 24px rgba(0,0,0,0.08); border-color: var(--primary-bd); }
.tpl-card-img-wrap { position: relative; width: 100%; overflow: hidden; }
.tpl-card-img { width: 100%; display: block; object-fit: cover; transition: transform 0.4s; }
.tpl-card:hover .tpl-card-img { transform: scale(1.05); }
.tpl-set-badge {
  position: absolute; top: 12px; right: 12px;
  background: rgba(0,0,0,0.6); backdrop-filter: blur(4px);
  color: #fff; font-size: 11px; font-weight: 500;
  padding: 4px 8px; border-radius: 8px;
  display: flex; align-items: center; gap: 4px;
  border: 1px solid rgba(255,255,255,0.2); z-index: 2;
}
.tpl-hover-overlay {
  position: absolute; inset: 0; background: rgba(0,0,0,0.2);
  opacity: 0; transition: opacity 0.25s;
  display: flex; align-items: center; justify-content: center; z-index: 1;
}
.tpl-card:hover .tpl-hover-overlay { opacity: 1; }
.tpl-make-btn {
  background: #fff; color: var(--ink0); border: none;
  padding: 8px 20px; border-radius: 20px; font-size: 13px; font-weight: 600;
  cursor: pointer; box-shadow: 0 4px 12px rgba(0,0,0,0.1);
  transform: translateY(10px); transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}
.tpl-card:hover .tpl-make-btn { transform: translateY(0); }
.tpl-card-info { padding: 14px 16px; }
.tpl-card-title {
  font-size: 14px; font-weight: 600; color: var(--ink0); margin-bottom: 6px; line-height: 1.4;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.tpl-card-stats { display: flex; align-items: center; justify-content: space-between; font-size: 12px; color: var(--ink2); }
.tpl-author { display: flex; align-items: center; gap: 6px; }
.tpl-author img { width: 16px; height: 16px; border-radius: 50%; }

/* ═══════════════════════════
   TEMPLATE DETAIL VIEW
═══════════════════════════ */
.tpl-detail-wrap {
  display: flex; flex: 1; overflow: hidden; height: 100%;
}
.tpl-detail-left {
  flex: 1; overflow-y: auto; padding: 32px;
  display: flex; flex-direction: column; gap: 20px;
  background: #f3f4f8;
}
.tpl-detail-main-img {
  width: 100%; border-radius: 16px; overflow: hidden;
  box-shadow: 0 8px 32px rgba(0,0,0,0.1); position: relative;
  background: #e8eaf0;
}
.tpl-detail-main-img img {
  width: 100%; display: block; object-fit: cover;
  max-height: 480px;
}
.tpl-detail-thumbs {
  display: flex; gap: 10px; overflow-x: auto; padding-bottom: 4px;
}
.tpl-detail-thumbs::-webkit-scrollbar { display: none; }
.tpl-thumb {
  width: 80px; height: 80px; flex-shrink: 0; border-radius: 10px;
  overflow: hidden; cursor: pointer; border: 2px solid transparent;
  transition: all 0.2s; background: #e0e4f0;
}
.tpl-thumb img { width: 100%; height: 100%; object-fit: cover; }
.tpl-thumb.active { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(79,70,229,0.15); }
.tpl-thumb:hover { border-color: var(--primary-bd); }

.tpl-detail-right {
  width: 360px; flex-shrink: 0; overflow-y: auto;
  background: #fff; border-left: 0.5px solid var(--line);
  display: flex; flex-direction: column;
}
.tpl-detail-hd {
  padding: 20px 24px 0;
  display: flex; align-items: center; gap: 10px;
  border-bottom: 0.5px solid var(--line); padding-bottom: 16px;
}
.tpl-detail-back {
  width: 32px; height: 32px; border-radius: 50%;
  border: 1px solid var(--line-m); background: #fff;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; font-size: 16px; color: var(--ink1);
  flex-shrink: 0; transition: all 0.15s;
}
.tpl-detail-back:hover { background: var(--primary-lt); color: var(--primary); border-color: var(--primary-bd); }
.tpl-detail-breadcrumb { font-size: 13px; color: var(--ink2); display: flex; align-items: center; gap: 4px; }
.tpl-detail-breadcrumb span { color: var(--ink0); font-weight: 500; }

/* ═══════════════════════════
   UNIFIED BREADCRUMB BAR
═══════════════════════════ */
#breadcrumb {
  display: none;
  align-items: center;
  gap: 2px;
  padding: 0 24px;
  height: 40px;
  flex-shrink: 0;
  background: var(--panel);
  border-bottom: 1px solid var(--line);
  position: relative;
  z-index: 10;
}
.bc-link {
  display: inline-flex;
  align-items: center;
  font-size: 13px;
  color: var(--ink2);
  background: none;
  border: none;
  cursor: pointer;
  padding: 3px 6px;
  border-radius: 6px;
  font-family: inherit;
  transition: color 0.15s, background 0.15s;
  line-height: 1;
}
.bc-link:hover { color: var(--ink0); background: var(--line); }
.bc-sep {
  font-size: 12px;
  color: var(--ink2);
  opacity: 0.4;
  user-select: none;
  padding: 0 1px;
}
.bc-cur {
  font-size: 13px;
  color: var(--ink0);
  font-weight: 500;
  padding: 3px 6px;
}

/* ═══════════════════════════
   UNIFIED VIEW HEADER BAR
═══════════════════════════ */
.agent-chat-hd {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 20px;
  height: 52px;
  background: var(--panel);
  border-bottom: 1px solid var(--line);
  flex-shrink: 0;
}
.agent-chat-hd-r {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 10px;
}
.back-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: none;
  border: none;
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink0);
  padding: 6px 10px 6px 6px;
  border-radius: 8px;
  font-family: inherit;
  transition: background 0.15s, color 0.15s;
  line-height: 1;
  flex-shrink: 0;
}
.back-btn:hover { background: var(--line); }
.back-btn svg { flex-shrink: 0; }
.ach-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 16px;
  border-radius: 20px;
  border: 1px solid var(--line-m);
  background: var(--panel);
  font-size: 12px;
  font-weight: 500;
  color: var(--ink0);
  cursor: pointer;
  font-family: inherit;
  transition: all 0.15s;
}
.ach-btn:hover {
  background: var(--primary-lt);
  color: var(--primary);
  border-color: var(--primary-bd);
}

.tpl-detail-body { padding: 24px; flex: 1; display: flex; flex-direction: column; gap: 20px; }
.tpl-detail-title { font-size: 18px; font-weight: 700; color: var(--ink0); line-height: 1.4; letter-spacing: -0.02em; }
.tpl-detail-meta { display: flex; align-items: center; gap: 12px; }
.tpl-detail-badge {
  font-size: 11px; padding: 3px 10px; border-radius: 20px;
  background: var(--primary-lt); color: var(--primary); font-weight: 600;
}
.tpl-detail-stats { display: flex; gap: 16px; font-size: 12px; color: var(--ink2); }
.tpl-detail-stat { display: flex; align-items: center; gap: 4px; }

.tpl-detail-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.tpl-detail-tag {
  font-size: 11px; padding: 4px 10px; border-radius: 20px;
  border: 1px solid var(--line-m); color: var(--ink1); background: var(--bg);
}

.tpl-prompt-box {
  background: var(--bg); border-radius: 12px; border: 1px solid var(--line-m);
  padding: 14px 16px;
}
.tpl-prompt-label { font-size: 11px; color: var(--ink2); font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 8px; }
.tpl-prompt-text {
  font-size: 13px; color: var(--ink0); line-height: 1.7;
  border: none; outline: none; background: transparent;
  resize: none; width: 100%; min-height: 72px; font-family: inherit;
}
.tpl-prompt-actions { display: flex; gap: 8px; margin-top: 10px; justify-content: flex-end; }
.tpl-prompt-btn {
  font-size: 11px; padding: 5px 12px; border-radius: 20px;
  border: 1px solid var(--line-m); background: #fff;
  cursor: pointer; color: var(--ink1); font-family: inherit; transition: all 0.15s;
}
.tpl-prompt-btn:hover { color: var(--primary); border-color: var(--primary-bd); }

.tpl-detail-actions { display: flex; flex-direction: column; gap: 10px; }
.tpl-action-primary {
  width: 100%; padding: 13px; border-radius: 12px;
  background: linear-gradient(135deg, #818cf8, #4f46e5);
  color: #fff; font-size: 14px; font-weight: 700;
  border: none; cursor: pointer; font-family: inherit;
  box-shadow: 0 4px 16px rgba(79,70,229,0.3); transition: all 0.15s;
  display: flex; align-items: center; justify-content: center; gap: 8px;
}
.tpl-action-primary:hover { opacity: 0.9; transform: translateY(-1px); box-shadow: 0 6px 20px rgba(79,70,229,0.35); }
.tpl-action-row { display: flex; gap: 10px; }
.tpl-action-secondary {
  flex: 1; padding: 10px; border-radius: 10px;
  background: var(--bg); border: 1px solid var(--line-m);
  color: var(--ink0); font-size: 13px; font-weight: 500;
  cursor: pointer; font-family: inherit; transition: all 0.15s;
  display: flex; align-items: center; justify-content: center; gap: 6px;
}
.tpl-action-secondary:hover { background: var(--primary-lt); border-color: var(--primary-bd); color: var(--primary); }

.tpl-divider { height: 0.5px; background: var(--line); }

.tpl-related-title { font-size: 13px; font-weight: 600; color: var(--ink0); margin-bottom: 12px; }
.tpl-related-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.tpl-related-card {
  border-radius: 10px; overflow: hidden; cursor: pointer;
  border: 1px solid var(--line-m); transition: all 0.2s; position: relative;
}
.tpl-related-card:hover { transform: translateY(-2px); box-shadow: 0 6px 16px rgba(0,0,0,0.08); border-color: var(--primary-bd); }
.tpl-related-card img { width: 100%; display: block; object-fit: cover; height: 100px; }
.tpl-related-card-title { font-size: 11px; padding: 8px 10px; color: var(--ink0); font-weight: 500; line-height: 1.3; }
.tpl-related-card-overlay {
  position: absolute; inset: 0; background: rgba(79,70,229,0.08);
  opacity: 0; transition: opacity 0.2s; border-radius: 10px;
}
.tpl-related-card:hover .tpl-related-card-overlay { opacity: 1; }

/* ═══════════════════════════════════════════
   AGENT SWITCH POPUP
═══════════════════════════════════════════ */
#agentSwitchPop {
  display: none;
  position: absolute;
  top: 38px;
  right: -4px;
  width: 216px;
  background: #fff;
  border: 1px solid var(--line-m);
  border-radius: 14px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.12), 0 2px 8px rgba(0,0,0,0.06);
  padding: 6px;
  z-index: 300;
  animation: popIn 0.15s ease;
}
@keyframes popIn {
  from { opacity:0; transform:translateY(-6px) scale(0.97); }
  to   { opacity:1; transform:translateY(0)    scale(1); }
}
#agentSwitchPop.open { display: block; }

.agent-sw-head {
  font-size: 10px; font-weight: 700; color: var(--ink2);
  letter-spacing: 0.08em; text-transform: uppercase;
  padding: 6px 10px 8px;
}
.agent-sw-item {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 10px; border-radius: 9px; cursor: pointer;
  transition: background 0.15s;
}
.agent-sw-item:hover { background: var(--bg); }
.agent-sw-item.active { background: var(--primary-lt); }
.agent-sw-icon {
  width: 30px; height: 30px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 15px; flex-shrink: 0;
}
.agent-sw-name {
  flex: 1; font-size: 13px; font-weight: 500; color: var(--ink0); line-height: 1.3;
}
.agent-sw-check {
  color: var(--primary); font-size: 11px; flex-shrink: 0; display: none;
}
.agent-sw-item.active .agent-sw-check { display: block; }
.agent-sw-divider { height: 1px; background: var(--line); margin: 4px 0; }

/* ═══════════════════════════════════════════
   COMMERCIAL SET RESULT — image grid cards
═══════════════════════════════════════════ */
.gen-img-card {
  border-radius: 10px; overflow: hidden; cursor: pointer;
  border: 2px solid transparent; transition: all 0.18s;
  background: #fff; box-shadow: 0 2px 8px rgba(0,0,0,0.06);
  position: relative;
}
.gen-img-card:hover { border-color: var(--primary-bd); box-shadow: 0 4px 16px rgba(79,70,229,0.12); }
.gen-img-card.selected { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(79,70,229,0.15); }
.gen-img-card img { width: 100%; display: block; object-fit: cover; }
.gen-img-card-label {
  padding: 6px 10px 8px; font-size: 11px; font-weight: 600;
  color: var(--ink1); background: #fff; line-height: 1.4;
}
.gen-img-card-check {
  position: absolute; top: 6px; right: 6px; width: 20px; height: 20px;
  border-radius: 50%; background: var(--primary); color: #fff;
  display: none; align-items: center; justify-content: center; font-size: 11px;
}
.gen-img-card.selected .gen-img-card-check { display: flex; }

/* ═══════════════════════════════════════════
   COMMERCIAL SET RESULT — edit toolbar
═══════════════════════════════════════════ */
.edit-tool-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 10px; border-radius: 20px; border: none; background: transparent;
  font-size: 12px; color: var(--ink1); cursor: pointer; white-space: nowrap;
  font-family: inherit; transition: all 0.15s; flex-shrink: 0;
}
.edit-tool-btn:hover { background: var(--line); color: var(--ink0); }
.edit-tool-btn.active { background: var(--primary-lt); color: var(--primary); font-weight: 600; }
.edit-tool-btn.processing { opacity: 0.6; pointer-events: none; }

.edit-tool-sep {
  width: 1px; height: 16px; background: var(--line-m); flex-shrink: 0; margin: 0 4px;
}
.edit-tool-chat {
  color: var(--primary); font-weight: 600;
}
.edit-tool-chat:hover { background: var(--primary-lt); }

.edit-tool-dl {
  width: 30px; height: 30px; padding: 0; border-radius: 50%;
  justify-content: center; color: var(--ink1);
}
.edit-tool-dl:hover { background: var(--line); color: var(--ink0); }

/* ═══════════════════════════════════════════
   AI STRATEGY ANALYSIS CARD
═══════════════════════════════════════════ */
.strategy-card {
  background: #fff;
  border: 1px solid var(--line-m);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}
.strategy-card-hd {
  display: flex; align-items: center; gap: 7px;
  padding: 11px 14px 10px;
  background: linear-gradient(135deg, #f5f3ff, #eef2ff);
  font-size: 12px; font-weight: 700; color: var(--primary);
  border-bottom: 1px solid rgba(79,70,229,0.1);
}
.strategy-row {
  display: flex; align-items: flex-start; gap: 8px;
  padding: 9px 14px; border-bottom: 1px solid var(--line);
}
.strategy-row:last-of-type { border-bottom: none; }
.strategy-lbl {
  font-size: 11px; font-weight: 600; color: var(--ink2);
  width: 56px; flex-shrink: 0; padding-top: 2px;
}
.strategy-tags { display: flex; flex-wrap: wrap; gap: 5px; }
.stag {
  font-size: 11px; padding: 3px 9px; border-radius: 20px;
  font-weight: 500; white-space: nowrap;
}
.stag-blue   { background: #eff6ff; color: #1d4ed8; }
.stag-purple { background: #f5f3ff; color: #7c3aed; }
.stag-green  { background: #f0fdf4; color: #15803d; }
.stag-orange { background: #fff7ed; color: #c2410c; }

.strategy-plan {
  padding: 10px 14px 12px;
  background: #fafafa;
  border-top: 1px solid var(--line);
}
.strategy-plan-hd {
  font-size: 10px; font-weight: 700; color: var(--ink2);
  letter-spacing: 0.07em; text-transform: uppercase; margin-bottom: 8px;
}
.strategy-plan-items { display: flex; gap: 16px; }
.strategy-plan-item  { display: flex; align-items: baseline; gap: 4px; }
.spi-num  { font-size: 22px; font-weight: 800; color: var(--primary); line-height: 1; }
.spi-desc { font-size: 11px; color: var(--ink1); }

/* ═══════════════════════════════════════════
   COMMERCIAL SET — horizontal image cards
═══════════════════════════════════════════ */
.gen-img-card-h {
  display: flex; flex-direction: column; gap: 8px;
  cursor: pointer; flex-shrink: 0;
  transition: transform 0.18s;
}
.gen-img-card-h:hover { transform: translateY(-3px); }
.gen-img-card-h img {
  border-radius: 10px;
  transition: box-shadow 0.2s;
  display: block;
}
.gen-img-card-h.selected img,
.gen-img-card-h:hover img {
  box-shadow: 0 0 0 2.5px var(--primary), 0 8px 28px rgba(79,70,229,0.22);
}

.gen-img-h-label {
  display: flex; flex-direction: column; gap: 1px; padding: 0 2px;
}
.gen-img-h-label b  { font-size: 12px; font-weight: 700; color: var(--ink0); }
.gen-img-h-label span { font-size: 11px; color: var(--ink2); }

/* click overlay */
.gen-img-h-overlay {
  position: absolute; inset: 0; border-radius: 10px;
  background: rgba(12, 12, 18, 0.68);
  backdrop-filter: blur(3px);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 12px; padding: 12px;
  opacity: 0; pointer-events: none;
  transition: opacity 0.2s;
}
.gen-img-h-overlay.visible {
  opacity: 1; pointer-events: all;
}
.ov-tools {
  display: flex; flex-wrap: wrap; gap: 5px; justify-content: center;
}
.ov-tool-btn {
  font-size: 11px; padding: 4px 10px; border-radius: 14px;
  background: rgba(255,255,255,0.14); border: 1px solid rgba(255,255,255,0.22);
  color: #fff; cursor: pointer; font-family: inherit;
  transition: background 0.15s; white-space: nowrap;
}
.ov-tool-btn:hover { background: rgba(255,255,255,0.26); }
.ov-actions { display: flex; gap: 8px; }
.ov-action-btn {
  display: flex; align-items: center; gap: 5px;
  font-size: 11px; font-weight: 500; padding: 6px 14px;
  border-radius: 18px; border: none;
  background: rgba(255,255,255,0.92); color: var(--ink0);
  cursor: pointer; font-family: inherit;
  transition: background 0.15s;
}

/* ═══════════════════════════════════════════════
   BRAND ASSETS CENTER  (.ba-*)
═══════════════════════════════════════════════ */

/* ensure the view shows as flex column when active */
#view-templates.active { display: flex !important; }

/* ── Header bar ── */
.ba-header {
  height: 72px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 28px;
  background: #fff;
  border-bottom: 1px solid var(--line-m);
}
.ba-header-left { display: flex; flex-direction: column; gap: 3px; }
.ba-title {
  font-size: 18px;
  font-weight: 700;
  color: var(--ink0);
  letter-spacing: 0.01em;
}
.ba-subtitle {
  font-size: 12px;
  color: var(--ink2);
}
.ba-header-right {
  display: flex;
  align-items: center;
  gap: 12px;
}
.ba-search-wrap {
  position: relative;
  width: 220px;
}
.ba-search-icon {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--ink2);
  font-size: 13px;
  pointer-events: none;
}
.ba-search-input {
  width: 100%;
  height: 36px;
  border: 1px solid var(--line-m);
  border-radius: 18px;
  padding: 0 14px 0 34px;
  font-size: 13px;
  font-family: inherit;
  color: var(--ink0);
  background: var(--bg);
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.ba-search-input:focus {
  border-color: var(--primary-bd);
  box-shadow: 0 0 0 3px rgba(79,70,229,0.08);
}
.ba-upload-btn {
  height: 36px;
  padding: 0 16px;
  border-radius: 18px;
  border: none;
  background: var(--primary);
  color: #fff;
  font-size: 13px;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: opacity 0.15s, transform 0.15s;
  white-space: nowrap;
}
.ba-upload-btn:hover { opacity: 0.88; transform: translateY(-1px); }

/* ── Category nav ── */
.ba-cat-nav {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 28px;
  background: #fff;
  border-bottom: 1px solid var(--line-m);
}
.ba-cat-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 18px;
  border-radius: 10px;
  border: 1.5px solid transparent;
  background: #f3f4f6;
  cursor: pointer;
  transition: all 0.18s;
  user-select: none;
}
.ba-cat-card:hover { background: #eef2ff; border-color: var(--primary-bd); }
.ba-cat-active {
  background: #fff !important;
  border-color: var(--primary) !important;
}
.ba-cat-active .ba-cat-name { color: var(--primary); }
.ba-cat-active .ba-cat-count { color: var(--primary); opacity: 0.7; }
.ba-cat-icon { font-size: 20px; line-height: 1; }
.ba-cat-info { display: flex; flex-direction: column; gap: 1px; }
.ba-cat-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--ink0);
  white-space: nowrap;
}
.ba-cat-count {
  font-size: 11px;
  color: var(--ink2);
  white-space: nowrap;
}

/* ── Stats strip ── */
.ba-stats-strip {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  padding: 0 28px;
  height: 64px;
  background: #fff;
  border-bottom: 1px solid var(--line-m);
  gap: 0;
}
.ba-stat-block {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 0 32px 0 0;
}
.ba-stat-block:first-child { padding-left: 0; }
.ba-stat-label {
  font-size: 11px;
  color: var(--ink2);
}
.ba-stat-value {
  font-size: 20px;
  font-weight: 700;
  color: var(--primary);
  display: flex;
  align-items: baseline;
  gap: 3px;
}
.ba-stat-unit {
  font-size: 12px;
  font-weight: 500;
  color: var(--ink1);
}
.ba-stat-up {
  font-size: 13px;
  color: #16a34a;
  font-weight: 700;
}
.ba-stat-new-badge {
  display: inline-flex;
  align-items: center;
  background: #f0fdf4;
  color: #15803d;
  border: 1px solid #bbf7d0;
  border-radius: 10px;
  padding: 2px 10px;
  font-size: 15px;
  font-weight: 700;
}
.ba-stat-divider {
  width: 1px;
  height: 32px;
  background: var(--line-m);
  margin: 0 28px 0 0;
  flex-shrink: 0;
}

/* ── Scrollable content ── */
.ba-content {
  flex: 1;
  overflow-y: auto;
  padding: 20px 28px 40px;
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* ── Section ── */
.ba-section {
  margin-bottom: 28px;
}
.ba-section-hd {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}
.ba-section-hd-left {
  display: flex;
  align-items: center;
  gap: 8px;
}
.ba-section-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 3px;
  flex-shrink: 0;
}
.ba-section-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--ink0);
}
.ba-section-cnt {
  font-size: 12px;
  color: var(--ink2);
  background: var(--line-m);
  border-radius: 10px;
  padding: 1px 8px;
}
.ba-view-all {
  font-size: 12px;
  color: var(--primary);
  text-decoration: none;
  cursor: pointer;
  white-space: nowrap;
}
.ba-view-all:hover { text-decoration: underline; }

/* ── Horizontal row ── */
.ba-row {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  padding-bottom: 6px;
  /* hide scrollbar */
  scrollbar-width: none;
}
.ba-row::-webkit-scrollbar { display: none; }

/* ── Asset card ── */
.ba-card {
  width: 180px;
  flex-shrink: 0;
  background: #fff;
  border: 1px solid var(--line-m);
  border-radius: 12px;
  overflow: hidden;
  cursor: pointer;
  transition: transform 0.18s, box-shadow 0.18s, border-color 0.18s;
}
.ba-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.10);
  border-color: var(--primary-bd);
}

/* thumbnail */
.ba-card-thumb-wrap {
  position: relative;
  width: 180px;
  height: 120px;
  overflow: hidden;
  background: #f3f4f6;
}
.ba-card-thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.22s;
}
.ba-card:hover .ba-card-thumb { transform: scale(1.04); }

/* hot badge */
.ba-badge-hot {
  position: absolute;
  top: 8px;
  right: 8px;
  background: #fff3e0;
  color: #d97706;
  border: 1px solid #fed7aa;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 10px;
  z-index: 1;
  pointer-events: none;
}

/* new badge */
.ba-badge-new {
  position: absolute;
  top: 8px;
  right: 8px;
  background: #f0fdf4;
  color: #15803d;
  border: 1px solid #bbf7d0;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 10px;
  z-index: 1;
  pointer-events: none;
}

/* card body */
.ba-card-body {
  padding: 10px 10px 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.ba-card-name {
  font-size: 13px;
  font-weight: 700;
  color: var(--ink0);
  line-height: 1.3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ba-card-fmts {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.ba-fmt-tag {
  font-size: 10px;
  color: var(--ink2);
  background: #f3f4f6;
  border: 1px solid var(--line-m);
  border-radius: 4px;
  padding: 1px 5px;
  white-space: nowrap;
}
.ba-card-stats {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 2px;
}
.ba-card-dl {
  font-size: 11px;
  color: var(--ink2);
  display: flex;
  align-items: center;
  gap: 3px;
}
.ba-card-dl i { font-size: 10px; color: var(--primary); }
.ba-card-use {
  font-size: 10px;
  color: var(--ink2);
  white-space: nowrap;
}
.ov-action-btn:hover { background: #fff; }


/* ── Persona chips (home page) ── */
.persona-card {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 14px 7px 10px;
  border-radius: 20px;
  border: 1.5px solid var(--line-m);
  background: #fff;
  cursor: pointer;
  flex-shrink: 0;
  transition: border-color 0.18s, background 0.18s;
}
.persona-card:hover { border-color: var(--primary-bd); }
.persona-card.active { border-color: var(--primary); background: var(--primary-lt); }
.persona-card-icon { font-size: 16px; line-height: 1; }
.persona-card-info { display: flex; flex-direction: column; gap: 1px; }
.persona-card-name { font-size: 12px; font-weight: 600; color: var(--ink0); white-space: nowrap; }
.persona-card-role { font-size: 10px; color: var(--ink2); white-space: nowrap; }

/* ── Welcome persona cards (agent chat welcome screen) ── */
.welcome-persona-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid var(--line-m);
  background: #fff;
  cursor: pointer;
  transition: border-color 0.18s, background 0.18s;
}
.welcome-persona-card:hover { border-color: var(--primary-bd); background: var(--primary-lt); }
.wpc-icon {
  width: 36px;
  height: 36px;
  border-radius: 9px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
}
.wpc-body { flex: 1; min-width: 0; }
.wpc-name { font-size: 13px; font-weight: 600; color: var(--ink0); }
.wpc-desc { font-size: 11px; color: var(--ink2); margin-top: 2px; }
.wpc-arrow { color: var(--ink2); font-size: 11px; flex-shrink: 0; }

/* ── Agent switch popup: name + role sub-text ── */
.agent-sw-info { display: flex; flex-direction: column; gap: 1px; flex: 1; min-width: 0; }
.agent-sw-role { font-size: 10px; color: var(--ink2); }

/* ══════════════════════════════════════════
   TEAM WORKFLOW VIEW
══════════════════════════════════════════ */

#view-team-workflow { display:none; flex:1; overflow:hidden; }
#view-team-workflow.active { display:flex !important; }

/* ── Pipeline bar ── */
.pa-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
  width: 58px;
}
.pa-av {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 17px;
  border: 2px solid transparent;
  transition: all 0.3s;
  flex-shrink: 0;
}
.pa-step.active .pa-av {
  border-color: currentColor;
  box-shadow: 0 0 0 4px rgba(0,0,0,0.06);
  transform: scale(1.1);
}
.pa-step.done .pa-av { opacity: 0.85; }
.pa-nm {
  font-size: 9.5px;
  font-weight: 600;
  color: var(--ink2);
  text-align: center;
  white-space: nowrap;
  line-height: 1.2;
}
.pa-rl {
  font-size: 9px;
  color: var(--ink3, #c0c4cc);
  text-align: center;
  white-space: nowrap;
}
.pa-step.active .pa-nm { color: var(--ink0); }
.pa-conn {
  flex: 1;
  min-width: 12px;
  height: 1.5px;
  background: var(--line-m);
  margin: 0 2px;
  position: relative;
  top: -22px;
  align-self: center;
  transition: background 0.3s;
}
.pa-conn.done { background: #16a34a44; }

/* ── Brief card ── */
.wf-brief-card {
  background: #fff;
  border-radius: 12px;
  border: 1px solid var(--line-m);
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.wf-brief-lbl {
  font-size: 10px;
  font-weight: 600;
  color: var(--ink2);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.wf-brief-txt {
  font-size: 14px;
  font-weight: 600;
  color: var(--ink0);
  line-height: 1.4;
}

/* ── Agent card ── */
.wf-card {
  background: #fff;
  border-radius: 14px;
  border: 1px solid var(--line-m);
  overflow: hidden;
  transition: opacity 0.3s, box-shadow 0.3s;
  box-shadow: 0 1px 4px rgba(0,0,0,0.04);
}
.wf-card.wf-collapsed { opacity: 0.55; }
.wf-card.wf-collapsed .wf-card-bd { display: none; }

.wf-card-hd {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  background: #fafbfc;
}
.wf-card-av {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
}
.wf-card-meta { flex: 1; min-width: 0; }
.wf-card-nm { font-size: 13px; font-weight: 700; color: var(--ink0); }
.wf-card-rl { font-size: 11px; color: var(--ink2); margin-top: 1px; }

/* Status badges */
.wf-badge {
  font-size: 10px;
  font-weight: 600;
  padding: 3px 9px;
  border-radius: 10px;
  white-space: nowrap;
  flex-shrink: 0;
}
.wf-badge.thinking   { background: #f3f4f6; color: var(--ink2); }
.wf-badge.asking     { background: #eff6ff; color: #2563eb; }
.wf-badge.analyzing  { background: #fef9c3; color: #a16207; }
.wf-badge.generating { background: #fff7ed; color: #c2410c; }
.wf-badge.done       { background: #f0fdf4; color: #16a34a; }

/* Card body */
.wf-card-bd {
  padding: 4px 14px 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.wf-intro {
  font-size: 12px;
  color: var(--ink1);
  line-height: 1.6;
  padding: 2px 0 2px;
}

/* Dot loader */
.wf-dots {
  display: flex;
  gap: 5px;
  align-items: center;
  padding: 6px 0;
}
.wf-dots span {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--ink3, #d1d5db);
  animation: wfBounce 1.2s infinite;
}
.wf-dots span:nth-child(2) { animation-delay: 0.2s; }
.wf-dots span:nth-child(3) { animation-delay: 0.4s; }
@keyframes wfBounce {
  0%,60%,100% { transform: translateY(0); }
  30%          { transform: translateY(-5px); }
}

/* Questions */
.wf-q-block { display: flex; flex-direction: column; gap: 8px; }
.wf-q-txt { font-size: 12px; font-weight: 600; color: var(--ink0); }
.wf-opts { display: flex; flex-wrap: wrap; gap: 6px; }
.wf-opt {
  font-size: 11px;
  padding: 5px 13px;
  border-radius: 20px;
  border: 1.5px solid var(--line-m);
  background: #fff;
  color: var(--ink1);
  cursor: pointer;
  transition: all 0.15s;
  line-height: 1.3;
}
.wf-opt:hover:not(:disabled) {
  border-color: var(--primary-bd);
  color: var(--primary);
  background: var(--primary-lt);
}
.wf-opt.selected {
  border-color: var(--primary);
  background: var(--primary-lt);
  color: var(--primary);
  font-weight: 600;
}
.wf-opt:disabled { cursor: default; }

/* Generating row */
.wf-gen-row {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: var(--ink2);
  padding: 2px 0;
}
.wf-gen-txt { color: var(--ink2); }

/* Output card */
.wf-out-card {
  border-radius: 10px;
  border: 1px solid #e9eaf0;
  background: #f8f9fb;
  overflow: hidden;
}
.wf-out-row {
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 9px 12px;
  border-bottom: 1px solid #eef0f4;
}
.wf-out-row:last-child { border-bottom: none; }
.wf-out-row.hint .wf-out-val { color: #b45309; }
.wf-out-lbl {
  font-size: 9.5px;
  font-weight: 700;
  color: var(--ink2);
  text-transform: uppercase;
  letter-spacing: 0.4px;
}
.wf-out-val {
  font-size: 12px;
  color: var(--ink0);
  line-height: 1.55;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  align-items: center;
}
.wf-tag {
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 10px;
  font-weight: 500;
}

/* KV image thumbs */
.wf-img-row {
  display: flex;
  gap: 8px;
  padding: 10px 12px 4px;
  overflow-x: auto;
  scrollbar-width: none;
  align-items: center;
}
.wf-img-thumb {
  flex-shrink: 0;
  border-radius: 7px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.wf-img-lbl {
  font-size: 9px;
  font-weight: 600;
  color: rgba(0,0,0,0.35);
}

/* Brand audit score */
.wf-audit-row {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 12px 4px;
}
.wf-score-wrap {
  width: 54px;
  height: 54px;
  position: relative;
  flex-shrink: 0;
}
.wf-score-svg {
  width: 100%;
  height: 100%;
  transform: rotate(-90deg);
}
.wf-score-num {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  font-weight: 800;
  color: var(--ink0);
}
.wf-score-lbl { font-size: 12px; font-weight: 600; color: var(--ink0); }
.wf-score-sub { font-size: 10px; color: var(--ink2); margin-top: 2px; }

/* Actions */
.wf-actions {
  display: flex;
  gap: 8px;
  padding: 12px 14px;
}
.wf-next-btn {
  flex: 1;
  height: 40px;
  border: none;
  border-radius: 10px;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  transition: opacity 0.15s, transform 0.15s;
}
.wf-next-btn:hover { opacity: 0.9; transform: translateY(-1px); }
.wf-adj-btn {
  height: 40px;
  padding: 0 14px;
  border: 1.5px solid var(--line-m);
  border-radius: 10px;
  background: #fff;
  color: var(--ink2);
  font-size: 11px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 5px;
  white-space: nowrap;
  transition: all 0.15s;
}
.wf-adj-btn:hover { border-color: var(--primary-bd); color: var(--primary); }
.wf-export-btn {
  flex: 1;
  height: 44px;
  border: none;
  border-radius: 12px;
  background: linear-gradient(135deg, #e84c4c 0%, #f97316 100%);
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  box-shadow: 0 4px 16px rgba(232,76,76,0.28);
  transition: all 0.2s;
}
.wf-export-btn:hover { transform: translateY(-1px); box-shadow: 0 6px 22px rgba(232,76,76,0.36); }

/* ══════════════════════════════════════════
   SPLIT-PANE CHAT + CANVAS
══════════════════════════════════════════ */

/* ── Pipeline pills (header) ── */
.pip-step {
  display: flex;
  align-items: center;
  gap: 5px;
  flex-shrink: 0;
}
.pip-dot {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: all 0.3s;
}
.pip-lbl {
  font-size: 11px;
  color: var(--ink2);
  white-space: nowrap;
  transition: color 0.3s;
}
.pip-line {
  width: 18px;
  height: 1.5px;
  background: #e0e2e7;
  flex-shrink: 0;
  margin: 0 2px;
  transition: background 0.3s;
}
.pip-line.done { background: #bbf7d0; }

/* ── Chat panel ── */
.chat-brief {
  font-size: 12px;
  font-weight: 600;
  color: var(--ink0);
  background: #f8f9fb;
  border: 1px solid var(--line-m);
  border-radius: 10px;
  padding: 10px 12px;
  line-height: 1.4;
}

/* Agent message row */
.chat-agent-row {
  display: flex;
  align-items: flex-start;
  gap: 8px;
}
.chat-av {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  flex-shrink: 0;
  margin-top: 2px;
}
.chat-agent-body {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
  flex: 1;
}
.chat-agent-name {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.2px;
}
.chat-bbl {
  background: #f3f4f6;
  border-radius: 4px 12px 12px 12px;
  padding: 9px 12px;
  font-size: 12px;
  color: var(--ink1);
  line-height: 1.55;
  display: inline-block;
  max-width: 100%;
  word-break: break-word;
}
.chat-q-bbl { display: block; }
.gen-bbl {
  display: flex;
  align-items: center;
}
.done-bbl {
  background: #f0fdf4;
  border: 1px solid #bbf7d0;
  color: var(--ink0);
  font-size: 12px;
  display: flex;
  align-items: center;
}

/* User message */
.chat-user-row {
  display: flex;
  justify-content: flex-end;
}
.chat-user-bbl {
  background: var(--primary);
  color: #fff;
  border-radius: 12px 4px 12px 12px;
  padding: 8px 13px;
  font-size: 12px;
  font-weight: 500;
  max-width: 80%;
  line-height: 1.4;
  word-break: break-word;
}

/* Question options */
.cq-txt {
  font-size: 12px;
  color: var(--ink0);
  font-weight: 600;
  margin-bottom: 8px;
}
.cq-opts {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}
.cq-opt {
  font-size: 11px;
  padding: 4px 11px;
  border-radius: 16px;
  border: 1.5px solid var(--line-m);
  background: #fff;
  color: var(--ink1);
  cursor: pointer;
  transition: all 0.15s;
  line-height: 1.35;
}
.cq-opt:hover:not(:disabled) {
  border-color: var(--primary-bd);
  color: var(--primary);
  background: var(--primary-lt);
}
.cq-opt.selected {
  border-color: var(--primary);
  background: var(--primary-lt);
  color: var(--primary);
  font-weight: 600;
}
.cq-opt:disabled { cursor: default; }

/* Confirm row */
.chat-confirm-row {
  display: flex;
  gap: 7px;
  padding-left: 38px;
  transition: opacity 0.3s;
}
.chat-next-btn {
  flex: 1;
  height: 36px;
  border: none;
  border-radius: 9px;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  transition: opacity 0.15s, transform 0.15s;
}
.chat-next-btn:hover { opacity: 0.88; transform: translateY(-1px); }
.chat-adj-btn {
  height: 36px;
  padding: 0 12px;
  border: 1.5px solid var(--line-m);
  border-radius: 9px;
  background: #fff;
  color: var(--ink2);
  font-size: 11px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 4px;
  white-space: nowrap;
  transition: all 0.15s;
}
.chat-adj-btn:hover { border-color: var(--primary-bd); color: var(--primary); }
.chat-export-btn {
  flex: 1;
  height: 38px;
  border: none;
  border-radius: 10px;
  background: linear-gradient(135deg, #e84c4c, #f97316);
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  box-shadow: 0 3px 12px rgba(232,76,76,0.25);
}

/* ── Canvas cards ── */
.cv-empty {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: #b0b7c3;
  font-size: 13px;
  text-align: center;
  padding: 40px 20px;
  min-height: 240px;
}

.cv-card {
  background: #fff;
  border-radius: 14px;
  border: 1px solid var(--line-m);
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}
.cv-hd {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 14px;
  background: #fafbfc;
}
.cv-hd-av {
  width: 34px;
  height: 34px;
  border-radius: 9px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  flex-shrink: 0;
}
.cv-hd-name {
  font-size: 13px;
  font-weight: 700;
  color: var(--ink0);
  line-height: 1.2;
}
.cv-hd-role {
  font-size: 10px;
  color: var(--ink2);
  margin-top: 1px;
}
.cv-hd-tag {
  font-size: 10px;
  font-weight: 600;
  padding: 3px 9px;
  border-radius: 10px;
  flex-shrink: 0;
}
.cv-body { padding: 2px 0 0; }
.cv-img-row {
  display: flex;
  gap: 8px;
  padding: 12px 14px 6px;
  overflow-x: auto;
  scrollbar-width: none;
  align-items: center;
}
.cv-audit-row {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 14px 4px;
}
.cv-score-wrap {
  width: 52px;
  height: 52px;
  position: relative;
  flex-shrink: 0;
}
.cv-score-lbl { font-size: 12px; font-weight: 600; color: var(--ink0); }
.cv-score-sub { font-size: 10px; color: var(--ink2); margin-top: 2px; }
.cv-items { display: flex; flex-direction: column; }
.cv-item {
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 8px 14px;
  border-top: 1px solid #f0f1f4;
}
.cv-item.hint .cv-item-val { color: #b45309; }
.cv-item-lbl {
  font-size: 9.5px;
  font-weight: 700;
  color: var(--ink2);
  text-transform: uppercase;
  letter-spacing: 0.4px;
}
.cv-item-val {
  font-size: 12px;
  color: var(--ink0);
  line-height: 1.5;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  align-items: center;
}
.cv-tag {
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 10px;
  font-weight: 500;
}
.cv-ft {
  display: flex;
  gap: 7px;
  padding: 10px 14px;
  border-top: 1px solid #f0f1f4;
  background: #fafbfc;
}
.cv-edit-btn {
  height: 32px;
  padding: 0 13px;
  border: 1.5px solid var(--line-m);
  border-radius: 8px;
  background: #fff;
  color: var(--ink1);
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 5px;
  transition: all 0.15s;
}
.cv-edit-btn:hover { border-color: var(--primary-bd); color: var(--primary); background: var(--primary-lt); }
.cv-regen-btn {
  height: 32px;
  padding: 0 13px;
  border: 1.5px solid var(--line-m);
  border-radius: 8px;
  background: #fff;
  color: var(--ink1);
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 5px;
  transition: all 0.15s;
}
.cv-regen-btn:hover { border-color: #d97706; color: #d97706; background: rgba(245,158,11,0.06); }
.cv-export-btn {
  height: 32px;
  padding: 0 13px;
  border: none;
  border-radius: 8px;
  background: linear-gradient(135deg, #e84c4c, #f97316);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 5px;
  margin-left: auto;
}

/* ══════════════════════════════════════════
   CANVAS CARD SPECIALIZED TYPES
══════════════════════════════════════════ */

/* ── Editable field ── */
.cv-editing {
  outline: 2px solid var(--primary-bd) !important;
  border-radius: 4px;
  background: var(--primary-lt) !important;
  cursor: text;
}

/* ── Copy / edit micro buttons ── */
.cvf-edit {
  width: 22px; height: 22px; border-radius: 5px;
  border: 1px solid var(--line-m); background: #fff;
  color: var(--ink2); cursor: pointer; display: inline-flex;
  align-items: center; justify-content: center; font-size: 9px;
  transition: all 0.15s;
}
.cvf-edit:hover { border-color: var(--primary-bd); color: var(--primary); background: var(--primary-lt); }
.cvf-copy {
  height: 22px; padding: 0 8px; border-radius: 5px;
  border: 1px solid var(--line-m); background: #fff;
  color: var(--ink2); cursor: pointer; font-size: 10px;
  display: inline-flex; align-items: center; gap: 3px;
  transition: all 0.15s;
}
.cvf-copy:hover { border-color: var(--primary-bd); color: var(--primary); background: var(--primary-lt); }

/* ── Strategy Card ── */
.cv-strategy { display: flex; flex-direction: column; gap: 0; }
.cvs-theme-wrap {
  padding: 14px 14px 10px;
  border-bottom: 1px solid #f0f1f4;
}
.cvs-theme-lbl {
  font-size: 9.5px; font-weight: 700; color: var(--ink2);
  text-transform: uppercase; letter-spacing: .5px; margin-bottom: 6px;
}
.cvs-theme-val {
  font-size: 18px; font-weight: 800; color: var(--ink0);
  line-height: 1.25; cursor: text; border-radius: 6px;
  padding: 2px 4px; margin: 0 -4px;
  transition: background 0.15s;
}
.cvs-theme-val:hover { background: #f3f4f6; }
.cvs-theme-hint { font-size: 10px; color: #bbb; margin-top: 4px; }
.cvs-row { padding: 10px 14px; border-bottom: 1px solid #f0f1f4; }
.cvs-field { display: flex; flex-direction: column; gap: 5px; }
.cvs-lbl {
  font-size: 9.5px; font-weight: 700; color: var(--ink2);
  text-transform: uppercase; letter-spacing: .4px;
  display: flex; align-items: center; gap: 5px;
}
.cvs-val {
  font-size: 13px; color: var(--ink0); line-height: 1.5;
  cursor: text; border-radius: 5px; padding: 2px 4px; margin: 0 -4px;
  transition: background 0.15s;
}
.cvs-val:hover { background: #f3f4f6; }
.cvs-slogan {
  font-size: 15px; font-weight: 700; color: #e84c4c;
  font-style: italic;
}
.cvs-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 4px; }
.cvs-kw {
  font-size: 11px; font-weight: 600; padding: 3px 10px;
  border-radius: 12px; cursor: default;
}

/* ── KV Card ── */
.cv-kv { padding: 12px 14px; display: flex; flex-direction: column; gap: 8px; }
.cvk-section-lbl {
  font-size: 9.5px; font-weight: 700; color: var(--ink2);
  text-transform: uppercase; letter-spacing: .4px;
}
.cvk-main {
  border-radius: 8px; height: 120px; display: flex;
  align-items: center; justify-content: center; overflow: hidden;
}
.cvk-main-inner { text-align: center; }
.cvk-grid { display: flex; gap: 8px; align-items: flex-end; }
.cvk-thumb {
  border-radius: 7px; display: flex; flex-direction: column;
  align-items: center; justify-content: flex-end;
  padding-bottom: 6px; gap: 2px; flex-shrink: 0;
}
.cvk-thumb-lbl { font-size: 9px; font-weight: 600; color: rgba(0,0,0,.35); }
.cvk-thumb-name { font-size: 9px; color: rgba(0,0,0,.3); }
.cvk-meta {
  display: flex; flex-wrap: wrap; gap: 8px;
  padding-top: 6px; border-top: 1px solid #f0f1f4; margin-top: 4px;
}
.cvk-meta-item { font-size: 11px; color: var(--ink2); display: flex; align-items: center; }

/* ── Video Card ── */
.cv-video { padding: 12px 14px; display: flex; flex-direction: column; gap: 8px; }
.cvv-thumbs { display: flex; gap: 10px; align-items: flex-end; }
.cvv-thumb {
  border-radius: 8px; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 6px;
  flex-shrink: 0; cursor: pointer; position: relative;
  transition: opacity 0.15s;
}
.cvv-thumb:hover { opacity: .85; }
.cvv-play {
  width: 32px; height: 32px; border-radius: 50%;
  background: rgba(255,255,255,.85); display: flex;
  align-items: center; justify-content: center;
  color: #333; font-size: 11px; padding-left: 2px;
}
.cvv-play-sm { width: 24px; height: 24px; font-size: 9px; }
.cvv-fmt {
  font-size: 9px; font-weight: 600; color: rgba(0,0,0,.4);
  position: absolute; bottom: 6px;
}
.cvv-script {
  font-size: 12px; color: var(--ink0); line-height: 1.65;
  background: #f8f9fb; border-radius: 8px; padding: 10px 12px;
  cursor: text; border: 1px solid transparent;
  transition: border-color 0.15s;
  white-space: pre-line;
}
.cvv-script:hover { border-color: var(--line-m); }
.cvv-assets { display: flex; flex-direction: column; gap: 5px; }
.cvv-asset { font-size: 12px; color: var(--ink1); display: flex; align-items: center; }

/* ── Social Card ── */
.cv-social { display: flex; flex-direction: column; }
.cvso-field {
  padding: 10px 14px;
  border-bottom: 1px solid #f0f1f4;
}
.cvso-field:last-child { border-bottom: none; }
.cvso-lbl-row {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 5px;
}
.cvso-lbl {
  font-size: 9.5px; font-weight: 700; color: var(--ink2);
  text-transform: uppercase; letter-spacing: .4px;
}
.cvso-val {
  font-size: 12px; color: var(--ink0); line-height: 1.6;
  cursor: text; border-radius: 5px; padding: 3px 4px; margin: 0 -4px;
  white-space: pre-line; transition: background 0.15s;
}
.cvso-val:hover { background: #f3f4f6; }

/* ── Audit Card ── */
.cv-audit { padding: 14px; display: flex; flex-direction: column; gap: 10px; }
.cva-score-row {
  display: flex; align-items: center; gap: 14px;
  padding-bottom: 12px; border-bottom: 1px solid #f0f1f4;
}
.cva-section {
  font-size: 10px; font-weight: 700; color: var(--ink2);
  text-transform: uppercase; letter-spacing: .5px;
}
.cva-checks { display: flex; flex-direction: column; gap: 8px; }
.cva-check {
  display: flex; align-items: flex-start; gap: 10px;
}
.cva-check-lbl { font-size: 12px; font-weight: 600; color: var(--ink0); }
.cva-check-desc { font-size: 11px; color: var(--ink2); margin-top: 1px; line-height: 1.4; }
.cva-suggestions { display: flex; flex-direction: column; gap: 6px; }
.cva-sg { display: flex; align-items: flex-start; gap: 8px; }
.cva-sg-num {
  width: 18px; height: 18px; border-radius: 50%; background: #fef3c7;
  color: #d97706; font-size: 10px; font-weight: 800;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  margin-top: 1px;
}
.cva-sg-txt {
  font-size: 12px; color: var(--ink1); line-height: 1.5;
  cursor: text; border-radius: 4px; padding: 1px 3px; margin: 0 -3px;
  transition: background 0.15s;
}
.cva-sg-txt:hover { background: #fef9c3; }

/* ═══════════════════════════════════════════
   HOME MODE CONTENT SECTIONS
═══════════════════════════════════════════ */
.home-mode-content { display: none; }
.home-mode-content.active { display: block; }

/* ── X-Agent mode: 数字员工 + 案例 ── */
.da-section { padding: 28px 32px 0; }
.da-section:last-child { padding-bottom: 32px; }
.da-section-hd { display: flex; align-items: baseline; gap: 12px; margin-bottom: 20px; }
.da-section-title { font-size: 18px; font-weight: 700; color: var(--ink0); }
.da-section-sub { font-size: 13px; color: var(--ink2); }

/* ── Digital Agent Grid ── */
.da-agents-grid {
  display: flex; gap: 16px; align-items: flex-start;
  overflow-x: auto; padding-bottom: 6px; scrollbar-width: none;
}
.da-agents-grid::-webkit-scrollbar { display: none; }

.da-agent-card {
  min-width: 196px; flex: 1;
  background: #fff; border-radius: 20px; overflow: hidden; cursor: pointer;
  border: 1.5px solid rgba(0,0,0,0.07);
  transition: transform 0.30s cubic-bezier(0.34,1.46,0.64,1),
              box-shadow 0.28s ease, border-color 0.22s;
  box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}
.da-agent-card:hover {
  transform: translateY(-6px);
  border-color: rgba(79,70,229,0.30);
  box-shadow: 0 16px 40px rgba(79,70,229,0.11);
}

/* ── Portrait photo section ── */
.da-agent-portrait {
  position: relative; height: 232px; overflow: hidden;
  background: #d1cfc8;
}
.da-agent-photo {
  width: 100%; height: 100%; object-fit: cover; object-position: top center;
  transition: transform 0.60s ease;
  filter: brightness(1.02) saturate(0.96) warm;
}
.da-agent-card:hover .da-agent-photo { transform: scale(1.05); }

/* Soft gradient — warm dark brown, not cold black */
.da-agent-portrait-grad {
  position: absolute; inset: 0;
  background: linear-gradient(
    to top,
    rgba(28,18,12,0.78) 0%,
    rgba(28,18,12,0.18) 50%,
    transparent 74%
  );
}

/* Name + role overlaid on photo */
.da-agent-name-overlay {
  position: absolute; bottom: 13px; left: 14px; right: 14px;
}
.da-agent-name {
  font-size: 15px; font-weight: 800; color: #fff; line-height: 1.2;
  margin-bottom: 3px; text-shadow: 0 1px 8px rgba(0,0,0,0.35);
}
.da-agent-role-sm {
  font-size: 11px; color: rgba(255,255,255,0.78); font-weight: 500;
}

/* Top-left: online status pill */
.da-agent-status-pill {
  position: absolute; top: 11px; left: 11px;
  display: flex; align-items: center; gap: 5px;
  background: rgba(255,255,255,0.18); backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.28);
  border-radius: 20px; padding: 4px 10px 4px 8px;
  font-size: 10px; font-weight: 600; color: rgba(255,255,255,0.95);
}
.da-online-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: #4ade80; flex-shrink: 0;
  box-shadow: 0 0 0 0 rgba(74,222,128,0.55);
  animation: da-pulse 2.4s ease-in-out infinite;
}
@keyframes da-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(74,222,128,0.55); }
  60%  { box-shadow: 0 0 0 6px rgba(74,222,128,0); }
  100% { box-shadow: 0 0 0 0 rgba(74,222,128,0); }
}

/* Top-right: specialty emoji — frosted dark glass */
.da-agent-spec-badge {
  position: absolute; top: 11px; right: 11px;
  width: 32px; height: 32px; border-radius: 50%;
  background: rgba(20,15,10,0.50); backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.20);
  display: flex; align-items: center; justify-content: center;
  font-size: 15px;
}

/* ── Footer info strip ── */
.da-agent-foot {
  padding: 12px 14px 16px;
  background: #fff;
}
.da-agent-tags { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 12px; }
.da-agent-tag {
  font-size: 10px; padding: 2px 9px; border-radius: 20px;
  background: #f1f0f8; color: #6259a8; font-weight: 600;
}
.da-agent-id {
  font-size: 9px; color: #c5c2d0; letter-spacing: 0.8px; text-transform: uppercase;
  font-weight: 500; margin-bottom: 10px;
}
/* Button wrapper — collapses to zero height so the card hugs content */
.da-start-wrap {
  overflow: hidden;
  max-height: 0;
  margin-top: 0;
  transition: max-height 0.28s ease, margin-top 0.24s ease;
}
.da-agent-card:hover .da-start-wrap {
  max-height: 44px;
  margin-top: 11px;
}
.da-agent-start-btn {
  width: 100%; padding: 8px 0; border-radius: 10px; border: none;
  background: #4f46e5;
  color: #fff; font-size: 12px; font-weight: 700; letter-spacing: 0.3px;
  cursor: pointer; display: block;
  transition: filter 0.16s;
}
.da-agent-start-btn:hover { filter: brightness(1.10); }

.da-cases-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.da-case-card {
  background: #fff; border-radius: 14px; overflow: hidden;
  border: 1px solid var(--line-m); cursor: pointer;
  transition: all 0.22s; box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}
.da-case-card:hover { transform: translateY(-3px); box-shadow: 0 8px 24px rgba(0,0,0,0.1); }
.da-case-cover { height: 130px; overflow: hidden; position: relative; }
.da-case-cover img { width: 100%; height: 100%; object-fit: cover; }
.da-case-type-badge {
  position: absolute; top: 10px; left: 10px; font-size: 10px; font-weight: 700;
  padding: 3px 10px; border-radius: 12px; background: rgba(255,255,255,0.92);
  color: var(--primary); backdrop-filter: blur(4px);
}
.da-case-body { padding: 13px 14px 14px; }
.da-case-title { font-size: 14px; font-weight: 700; color: var(--ink0); margin-bottom: 7px; }
.da-case-meta { display: flex; flex-direction: column; gap: 3px; margin-bottom: 11px; }
.da-case-meta-tag { font-size: 11px; color: var(--ink2); }
.da-case-btn {
  font-size: 11px; padding: 5px 14px; border-radius: 8px;
  border: 1px solid var(--primary-bd); color: var(--primary);
  background: var(--primary-lt); cursor: pointer; font-weight: 600;
  transition: all 0.18s;
}
.da-case-btn:hover { background: var(--primary); color: #fff; }

/* ── Video mode: 瀑布流 ── */
.vid-waterfall-wrap { padding: 24px 32px 32px; }
.vid-wf-hd { display: flex; align-items: baseline; gap: 12px; margin-bottom: 18px; }
.vid-wf-title { font-size: 18px; font-weight: 700; color: var(--ink0); }
.vid-wf-sub { font-size: 13px; color: var(--ink2); }
.vid-waterfall { columns: 4; column-gap: 12px; }
.vid-card {
  break-inside: avoid; margin-bottom: 12px;
  border-radius: 10px; overflow: hidden;
  cursor: pointer; position: relative;
  transition: transform 0.22s, box-shadow 0.22s;
  box-shadow: 0 2px 10px rgba(0,0,0,0.10);
}
.vid-card:hover { transform: scale(1.022); box-shadow: 0 8px 28px rgba(0,0,0,0.18); }
.vid-thumb { width: 100%; height: auto; display: block; }
/* hover overlay */
.vid-hover-overlay {
  position: absolute; inset: 0;
  background: rgba(0,0,0,0);
  transition: background 0.22s;
  display: flex; align-items: center; justify-content: center;
}
.vid-card:hover .vid-hover-overlay { background: rgba(0,0,0,0.38); }
.vid-play-circle {
  width: 40px; height: 40px; border-radius: 50%;
  background: rgba(255,255,255,0.88);
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; padding-left: 3px;
  opacity: 0; transition: opacity 0.22s;
  box-shadow: 0 2px 10px rgba(0,0,0,0.3);
}
.vid-card:hover .vid-play-circle { opacity: 1; }
.vid-make-btn {
  position: absolute; bottom: 10px; right: 10px;
  padding: 5px 13px; border-radius: 20px; border: none;
  background: rgba(255,255,255,0.92); color: #1a1a2e;
  font-size: 12px; font-weight: 600; cursor: pointer;
  opacity: 0; transform: translateY(4px);
  transition: opacity 0.22s, transform 0.22s;
  box-shadow: 0 2px 8px rgba(0,0,0,0.18);
  white-space: nowrap;
}
.vid-card:hover .vid-make-btn { opacity: 1; transform: translateY(0); }

/* ── Copy mode: 渠道场景 ── */
.copy-scene-wrap { padding: 24px 32px 32px; }
.copy-scene-hd { display: flex; align-items: baseline; gap: 12px; margin-bottom: 18px; }
.copy-scene-title { font-size: 18px; font-weight: 700; color: var(--ink0); }
.copy-scene-sub { font-size: 13px; color: var(--ink2); }
.copy-channels-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.copy-channel-card {
  background: #fff; border-radius: 16px; overflow: hidden;
  border: 1px solid var(--line-m); cursor: pointer;
  transition: all 0.22s; box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}
.copy-channel-card:hover { transform: translateY(-3px); box-shadow: 0 8px 28px rgba(0,0,0,0.1); border-color: var(--primary-bd); }
.ccc-header { padding: 16px 18px 13px; border-bottom: 1px solid var(--line-m); display: flex; align-items: center; gap: 12px; }
.ccc-icon { width: 42px; height: 42px; border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 22px; flex-shrink: 0; }
.ccc-name { font-size: 15px; font-weight: 700; color: var(--ink0); line-height: 1.2; }
.ccc-platform { font-size: 11px; color: var(--ink2); margin-top: 2px; }
.ccc-preview { padding: 13px 18px; }
.ccc-preview-label { font-size: 10px; font-weight: 700; color: var(--ink2); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 7px; }
.ccc-sample-text {
  font-size: 12px; color: var(--ink1); line-height: 1.65;
  background: #f8f9fb; border-radius: 8px; padding: 10px 12px;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
}
.ccc-tags { display: flex; gap: 6px; flex-wrap: wrap; padding: 0 18px 13px; }
.ccc-tag { font-size: 10px; padding: 2px 9px; border-radius: 10px; background: var(--primary-lt); color: var(--primary); font-weight: 500; }
.ccc-footer { padding: 0 18px 16px; }
.ccc-gen-btn {
  width: 100%; padding: 8px; border-radius: 10px; border: none;
  background: linear-gradient(135deg, #4f46e5, #9333ea);
  color: #fff; font-size: 13px; font-weight: 600;
  cursor: pointer; transition: opacity 0.18s;
}
.ccc-gen-btn:hover { opacity: 0.85; }
