:root{
  --ink:#172033;--muted:#647084;--line:#d8deea;--bg:#f4f6fa;--head:#172033;
  --sub:#edf2f8;--red:#bd3b33;--blue:#235ecf;--sb:#edf4ff;
  --bar-grad:linear-gradient(125deg,#18244f 0%,#2950cf 50%,#4a86ff 100%);
  --bar-sheen:radial-gradient(130% 130% at 10% -30%, rgba(255,255,255,.22), rgba(255,255,255,0) 55%);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-thumb{background:var(--line);border-radius:5px}
body{background:var(--bg);color:var(--ink);font-family:Arial,Helvetica,sans-serif;
  height:100vh;display:flex;flex-direction:column;overflow:hidden;font-size:14px}

.app-head{background:var(--bar-sheen),var(--bar-grad);color:#fff;padding:15px 18px;display:flex;
  align-items:center;justify-content:space-between;flex-shrink:0;
  margin:8px 8px 4px;border-radius:18px;box-shadow:0 8px 22px rgba(24,40,90,.30)}
.app-head h1{font-size:17px;letter-spacing:-.3px;display:flex;align-items:center;gap:8px;
  text-shadow:0 1px 2px rgba(0,0,0,.18)}
.live{display:flex;align-items:center;gap:6px;font-size:11px;color:#eaf1ff;font-weight:bold;
  background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.22);
  padding:5px 11px;border-radius:20px;backdrop-filter:blur(2px)}
.live .dot{width:7px;height:7px;border-radius:50%;background:#3ce08a;
  box-shadow:0 0 8px #3ce08a;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

.dash-region{flex:1;overflow-y:auto;min-height:0}
.dash-region::-webkit-scrollbar{width:5px}
.dash-region::-webkit-scrollbar-thumb{background:var(--line);border-radius:5px}

#chatDock{flex-shrink:0;background:#1e2330;border-radius:20px 20px 0 0;overflow:hidden;
  display:flex;flex-direction:column;box-shadow:0 -6px 22px rgba(0,0,0,.3)}
.dock-head{display:flex;align-items:center;justify-content:space-between;
  padding:12px 16px;cursor:pointer;background:var(--bar-sheen),var(--bar-grad);color:#fff;flex-shrink:0;
  border-radius:20px 20px 0 0}
.dock-head .dh-left{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:bold}
.dock-head .dh-dot{width:7px;height:7px;border-radius:50%;background:#3ce08a;box-shadow:0 0 8px #3ce08a;animation:pulse 2s infinite}
.dock-chev{font-size:12px;transition:transform .25s}
#chatDock.expanded .dock-chev{transform:rotate(180deg)}
.chat-msgs{display:none}
#chatDock.expanded .chat-msgs{display:flex}

.dash{padding:12px}

.card{background:#fff;border:1px solid var(--line);border-radius:12px;
  padding:14px;margin-bottom:10px;box-shadow:0 1px 3px rgba(20,32,51,.04)}
.card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.card-head > div:first-child{min-width:min(100%,160px);flex:1 1 160px}
.card-name{font-size:clamp(13px,3.8vw,16px);font-weight:bold;margin-bottom:3px}
.card-cat{font-size:clamp(10px,3vw,12px);color:var(--muted)}
.card-mkt{background:var(--sb);color:var(--blue);font-size:clamp(10px,2.9vw,12.5px);font-weight:bold;
  padding:4px 9px;border-radius:6px;border:1px solid #b8c7e6;
  min-width:58px;flex:0 1 auto;overflow-wrap:break-word;line-height:1.3}
.rank-badge{display:inline-grid;place-items:center;
  width:clamp(20px,5.6vw,24px);height:clamp(20px,5.6vw,24px);
  background:var(--sub);border-radius:50%;font-size:clamp(10px,3vw,12px);font-weight:bold;margin-right:8px;color:var(--ink)}

.metrics{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
.success-box{display:flex;align-items:center;gap:10px;background:var(--sub);
  border:1px solid var(--line);border-radius:9px;padding:9px 12px;margin-bottom:12px}
.success-label{font-size:12px;font-weight:bold;color:var(--head);white-space:nowrap}
.success-box .bar{height:10px}
.pct-edit{outline:none;cursor:text;color:var(--blue);min-width:34px;text-align:center;
  font-weight:bold;padding:2px 7px;border-radius:999px;line-height:1.3;display:inline-block;
  background:var(--sb);transition:background .25s,color .25s}
.pct-edit:focus{box-shadow:0 0 0 2px rgba(35,94,207,.35)}
.card-mkt[contenteditable]{cursor:text;outline:none}
.card-mkt[contenteditable]:focus{border-color:var(--blue);box-shadow:0 0 0 2px rgba(35,94,207,.15)}
.head-right{display:flex;align-items:center;gap:clamp(5px,1.6vw,8px);flex-shrink:0;flex-wrap:wrap;justify-content:flex-end;margin-left:auto;max-width:100%}
.collapse-btn{width:clamp(24px,7vw,30px);height:clamp(24px,7vw,30px);border-radius:7px;border:1px solid var(--line);
  background:var(--sub);color:var(--muted);font-size:clamp(10px,2.6vw,12px);cursor:pointer;flex-shrink:0;flex-grow:0;
  display:grid;place-items:center;transition:background-color .2s,color .2s,border-color .2s,transform .2s;padding:0;line-height:1}
.collapse-btn:active{background:var(--line)}
.star-btn{width:clamp(24px,7vw,30px);height:clamp(24px,7vw,30px);border-radius:7px;border:1px solid var(--line);
  background:var(--sub);color:var(--muted);font-size:clamp(12px,3.6vw,15px);cursor:pointer;flex-shrink:0;flex-grow:0;
  display:grid;place-items:center;transition:background-color .2s,color .2s,border-color .2s,transform .2s;padding:0;line-height:1;margin-right:2px}
.star-btn:active{transform:scale(.9)}
.star-btn.starred{color:#f59e0b;border-color:#fce38a;background:#fff3cd;text-shadow:0 0 4px rgba(245,158,11,0.5)}
@keyframes sparkleStar{
  0%,100%{transform:scale(1);filter:drop-shadow(0 0 2px rgba(245,158,11,0.3))}
  50%{transform:scale(1.2) rotate(10deg);filter:drop-shadow(0 0 10px rgba(245,158,11,0.9)) brightness(1.2)}
}

.card.collapsed{padding:10px 14px}
.card.collapsed .card-cat,
.card.collapsed .card-mkt,
.card.collapsed .success-box,
.card.collapsed .metrics,
.card.collapsed .card-foot{display:none}
.card.collapsed .card-head{margin-bottom:0}
.card.collapsed .card-name{font-size:13.5px}

.card.collapsed .card-head{flex-wrap:nowrap;overflow:hidden;align-items:center}
.card.collapsed > .card-head > div:first-child{min-width:0;flex-shrink:1;overflow:hidden}
.card.collapsed .card-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card.collapsed .head-right{flex-shrink:0;flex-wrap:nowrap}
.collapse-summary{display:none;align-items:center;gap:7px;font-size:12px;font-weight:bold;white-space:nowrap}
.card.collapsed .collapse-summary{display:flex}
.cs-mkt{color:var(--blue);background:var(--sb);border:1px solid #b8c7e6;padding:2px 7px;border-radius:5px;font-size:11px;white-space:nowrap}
.cs-pill{font-size:10.5px!important;padding:2px 8px!important;white-space:nowrap}
.m-row{display:grid;grid-template-columns:110px 1fr 50px;align-items:center;gap:8px}
.m-label{font-size:11px;font-weight:bold;cursor:pointer;white-space:nowrap;
  padding:4px 8px;border-radius:999px;display:inline-block;
  background:var(--sb);color:var(--blue);border:1px solid transparent;transition:background-color .2s,color .2s,border-color .2s,transform .2s}
.m-label:active{transform:scale(.96)}
.bar{height:8px;background:#e9edf4;border-radius:999px;overflow:hidden}
.bar i{display:block;height:100%;border-radius:999px;transition:width .6s cubic-bezier(.4,0,.2,1)}
.m-val{font-size:11.5px;font-weight:bold;text-align:right}

.card-foot{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.pill{font-size:11px;font-weight:bold;padding:5px 10px;border-radius:999px;
  background:var(--sb);color:var(--blue);border:1px solid #b8c7e6}
.dec1{position:relative;overflow:hidden;animation:glow1 1.9s ease-in-out infinite}
.dec1::after{content:'';position:absolute;left:-120%;width:55%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.85),transparent);animation:shine 2.4s infinite}
@keyframes shine{0%{left:-120%}55%,100%{left:170%}}
@keyframes glow1{0%,100%{box-shadow:0 0 0 0 rgba(0,115,49,0)}50%{box-shadow:0 0 9px 1px rgba(0,115,49,.45)}}
.card-actions{margin-left:auto;display:flex;gap:6px}
.mini-btn{font-size:11px;font-weight:bold;color:var(--blue);background:var(--sb);
  border:1px solid #b8c7e6;border-radius:999px;padding:5px 12px;cursor:pointer;transition:background-color .2s,color .2s,border-color .2s,transform .2s;
  box-shadow:0 1px 3px rgba(0,0,0,.08)}
.mini-btn:active{transform:scale(.95);box-shadow:none}

.add-card{width:100%;padding:14px;background:var(--head);color:#fff;border:none;
  border-radius:12px;font-size:14px;font-weight:bold;cursor:pointer;margin-top:4px;
  display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 10px rgba(23,32,51,.2)}
.add-card:active{transform:scale(.99)}

.chat{display:flex;flex-direction:column}
.chat-msgs{flex-direction:column;gap:18px;max-height:42vh;overflow-y:auto;padding:16px 14px}
.chat-msgs::-webkit-scrollbar{width:5px}
.chat-msgs::-webkit-scrollbar-thumb{background:var(--line);border-radius:5px}

.msg{animation:fade .3s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

.msg-ai{display:flex;gap:10px;align-items:flex-start}
.av{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;
  font-size:14px;flex-shrink:0;color:#fff}
.av-ai{background:linear-gradient(135deg,#235ecf,#5b8def)}
.ai-body{flex:1;min-width:0}
.ai-name{font-size:11px;font-weight:bold;color:#8a99b5;margin-bottom:4px}
.ai-text{font-size:13.5px;line-height:1.65;color:#d8deea;white-space:pre-wrap;word-break:break-word}
.ai-text b{color:#fff}
.ai-text ul{margin:6px 0 6px 18px}
.ai-text li{margin:4px 0}
.ai-text p{margin:8px 0}

.msg-user{display:flex;justify-content:flex-end}
.bubble{background:linear-gradient(135deg,#2f6ae0,#235ecf);color:#fff;
  border-radius:16px 16px 4px 16px;padding:10px 14px;font-size:13.5px;line-height:1.5;
  max-width:80%;box-shadow:0 2px 8px rgba(35,94,207,.25);white-space:pre-wrap;word-break:break-word}

.act-chip{display:inline-flex;align-items:center;gap:5px;margin-top:10px;padding:7px 11px;
  background:rgba(22,131,90,0.15);border:1px solid rgba(22,131,90,0.3);border-radius:8px;font-size:11.5px;
  color:#3ce08a;font-weight:bold}

.ai-typing-new {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(35, 94, 207, 0.08);
  border: 1px solid rgba(35, 94, 207, 0.15);
  padding: 8px 16px;
  border-radius: 18px;
  color: var(--blue);
  font-size: 13px;
  font-weight: 600;
  box-shadow: 0 4px 12px rgba(35, 94, 207, 0.05);
}
.ai-typing-icon {
  font-size: 15px;
  animation: spinPulse 2s infinite linear;
}
@keyframes spinPulse {
  0% { transform: scale(1) rotate(0deg); opacity: 0.8; }
  50% { transform: scale(1.2) rotate(180deg); opacity: 1; filter: drop-shadow(0 0 6px rgba(35, 94, 207, 0.4)); }
  100% { transform: scale(1) rotate(360deg); opacity: 0.8; }
}
.ai-typing-text {
  background: linear-gradient(90deg, var(--blue) 0%, #41d3ff 50%, var(--blue) 100%);
  background-size: 200% 100%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: shimmerText 2s infinite linear;
}
@keyframes shimmerText {
  0% { background-position: 100% 0; }
  100% { background-position: -100% 0; }
}

.ai-think-indicator-new {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(139, 155, 180, 0.1);
  border: 1px solid rgba(139, 155, 180, 0.2);
  padding: 8px 16px;
  border-radius: 18px;
  color: #8b9bb4;
  font-size: 13px;
  font-weight: 600;
  margin-bottom: 12px;
}
.ai-think-icon {
  font-size: 15px;
  animation: brainPulse 2s infinite ease-in-out;
}
@keyframes brainPulse {
  0%, 100% { transform: scale(1); opacity: 0.8; filter: drop-shadow(0 0 2px rgba(139, 155, 180, 0.4)); }
  50% { transform: scale(1.15); opacity: 1; filter: drop-shadow(0 0 8px rgba(139, 155, 180, 0.8)); }
}
.ai-think-text {
  opacity: 0.9;
  animation: pulseOpacity 2s infinite ease-in-out;
}
@keyframes pulseOpacity {
  0%, 100% { opacity: 0.5; }
  50% { opacity: 1; }
}

.chat-input{padding:10px 12px;background:#151a24;border-top:1px solid #2f3646;flex-shrink:0}
.chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:9px;padding-bottom:2px;justify-content:center}
.chips::-webkit-scrollbar{display:none}
.chip{flex:1;text-align:center;white-space:nowrap;font-size:11.5px;color:#93a5c4;background:#1e2330;
  border:1px solid #2f3646;border-radius:999px;padding:6px 12px;cursor:pointer;}
.chip:active{background:#2a3142}
.in-row{display:flex;gap:8px;align-items:flex-end}
.attach-preview{display:none;gap:6px;flex-wrap:wrap;padding:0 4px 10px;max-height:80px;overflow-y:auto}
.file-chip{display:flex;align-items:center;gap:6px;background:#2a3142;color:#d8deea;
  font-size:11.5px;padding:4px 8px;border-radius:6px;border:1px solid #434c5e;animation:fade .2s}
.file-chip span{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.file-del{cursor:pointer;color:#93a5c4;font-size:16px;line-height:1;margin-top:-2px}
.file-del:hover{color:#fff}
.txt{flex:1;border:1px solid #2f3646;border-radius:22px;padding:11px 16px;background:#1e2330;color:#fff;
  font-family:inherit;font-size:16px;resize:none;height:44px;max-height:100px;
  line-height:1.4;outline:none;transition:border-color .2s}
.txt:focus{border-color:var(--blue)}
.ibtn{width:44px;height:44px;border-radius:50%;border:none;display:grid;place-items:center;
  cursor:pointer;flex-shrink:0;font-size:18px;transition:transform .15s}
.ibtn:active{transform:scale(.92)}
.b-attach{background:transparent;color:#93a5c4;font-size:22px}
.b-send{background:var(--head);color:#fff}

.overview-page{position:fixed;inset:0;background:var(--bg);z-index:9998;display:none;
  flex-direction:column;overflow:hidden;animation:ovSlide .28s cubic-bezier(.32,.72,0,1)}
.overview-page.open{display:flex}
@keyframes ovSlide{from{transform:translateX(100%);opacity:.4}to{transform:translateX(0);opacity:1}}
.ov-header{background:var(--bar-sheen),var(--bar-grad);color:#fff;padding:14px 16px;
  display:flex;align-items:center;gap:12px;flex-shrink:0;
  margin:8px 8px 4px;border-radius:18px;box-shadow:0 8px 22px rgba(24,40,90,.30)}
.ov-back{background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.22);
  color:#fff;font-size:13px;font-weight:bold;padding:7px 13px;border-radius:999px;
  cursor:pointer;display:inline-flex;align-items:center;gap:5px;font-family:inherit;flex-shrink:0}
.ov-back:active{background:rgba(255,255,255,.28)}
.ov-title{font-size:15px;font-weight:bold;line-height:1.3;flex:1;
  text-shadow:0 1px 2px rgba(0,0,0,.18);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ov-body{flex:1;overflow-y:auto;padding:0 14px 14px;-webkit-overflow-scrolling:touch}
.ov-body::-webkit-scrollbar{width:5px}
.ov-body::-webkit-scrollbar-thumb{background:var(--line);border-radius:5px}
.ov-meta{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 14px;
  margin-bottom:12px;display:flex;flex-direction:column;gap:8px;box-shadow:0 1px 3px rgba(20,32,51,.04)}
.ov-meta-row{display:flex;align-items:center;gap:8px;font-size:13px}
.ov-meta-label{color:var(--muted);font-size:12px;min-width:90px}
.ov-meta-val{font-weight:bold;color:var(--ink)}
.ov-metrics{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.ov-metric{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px;
  box-shadow:0 1px 3px rgba(20,32,51,.04)}
.ov-metric-label{font-size:11.5px;color:var(--muted);margin-bottom:6px;font-weight:bold}
.ov-metric-val{font-size:22px;font-weight:bold;color:var(--ink);line-height:1}
.ov-metric .ov-bar{height:6px;background:var(--sub);border-radius:999px;margin-top:8px;overflow:hidden}
.ov-metric .ov-bar i{display:block;height:100%;background:var(--bar-grad);border-radius:999px}
.ov-body > :first-child{margin-top:14px} .ov-section{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 16px;
  margin-bottom:12px;box-shadow:0 1px 3px rgba(20,32,51,.04)}
.ov-section h2{font-size:14px;color:var(--head);margin-bottom:10px;padding-bottom:8px;
  border-bottom:1px solid var(--line);display:flex;align-items:center;gap:6px}
.ov-section .ov-content{font-size:13.5px;line-height:1.6;color:var(--ink)}
.ov-section .ov-content h4{font-size:13.5px;margin:14px 0 6px;color:var(--head);
  padding-bottom:4px;border-bottom:1px dashed var(--line)}
.ov-section .ov-content h4:first-child{margin-top:0}
.ov-section .ov-content ul{margin:4px 0 10px 18px}
.ov-section .ov-content li{margin:5px 0}
.ov-section .ov-content table{width:100%;border-collapse:collapse;margin-top:6px;font-size:12.5px}
.ov-section .ov-content table th{position:-webkit-sticky;position:sticky;top:0;z-index:10;background:var(--sub);text-align:left;padding:8px;font-size:11px;text-transform:uppercase;border:1px solid var(--line); box-shadow: inset 0 -1px 0 var(--line), inset 0 1px 0 var(--line);}
.ov-section .ov-content table td{padding:8px;border:1px solid var(--line);vertical-align:top}
.ov-section[contenteditable="true"]{outline:none}

.ov-content.ov-editable{outline:none;border:1px dashed transparent;border-radius:8px;
  padding:6px 8px;margin:-6px -8px;transition:border-color .2s,background .2s}
.ov-content.ov-editable:hover{border-color:var(--line)}
.ov-content.ov-editable:focus{border-color:var(--blue);background:var(--sb)}

.ov-pct{outline:none;cursor:text;border-radius:8px;padding:0 4px;
  border:1px dashed transparent;transition:border-color .2s,background .2s}
.ov-pct:hover{border-color:var(--line)}
.ov-pct:focus{border-color:var(--blue);background:var(--sb)}
.ov-edit-hint{text-align:center;font-size:11px;color:var(--muted);font-style:italic;
  padding:8px 0 18px}

.backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(10,16,28,.6);
  z-index:9999;display:none;align-items:center;justify-content:center;padding:16px}
.backdrop.open{display:flex}
.sheet{background:#fff;width:100%;max-width:520px;max-height:85vh;border-radius:16px; margin: auto !important;
  display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.4);
  animation:popIn .25s cubic-bezier(.4,0,.2,1)}
@keyframes popIn{from{opacity:0;transform:scale(.92) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}
.sheet-grip{display:none}
.sheet-head{padding:16px 18px;border-bottom:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;gap:12px;background:var(--head);color:#fff}
.sheet-title{font-size:16px;font-weight:bold;line-height:1.3}
.sheet-close{width:32px;height:32px;border-radius:50%;border:1px solid rgba(255,255,255,.3);
  background:transparent;color:#fff;font-size:16px;cursor:pointer;flex-shrink:0;display:grid;place-items:center}
.sheet-close:active{background:rgba(255,255,255,.15)}
.sheet-body{flex: 1; padding:0px 18px 12px;overflow-y:auto;font-size:13.5px;line-height:1.6;outline:none}
.sheet-body h4{font-size:14px;margin:16px 0 7px;color:var(--head);padding-bottom:4px;border-bottom:1px solid var(--line)}
.sheet-body > :first-child{margin-top:16px} .sheet-body h4:first-child{margin-top:16px}
.sheet-body ul{margin:6px 0 12px 18px}
.sheet-body li{margin:6px 0}
.src-tbl{ width:100%;border-collapse:collapse;margin-top:8px;font-size:12.5px}
.src-tbl th{position:-webkit-sticky;position:sticky;top:0;z-index:10;background:var(--sub);text-align:left;padding:8px;font-size:11px;text-transform:uppercase;border:1px solid var(--line);box-shadow:inset 0 -1px 0 var(--line), inset 0 1px 0 var(--line), 0 1px 2px rgba(0,0,0,0.05)}
.src-tbl td{padding:8px;border:1px solid var(--line);vertical-align:top}
.src-tbl td b{font-size:12.5px}
.src-type{font-size:10.5px;color:var(--muted);display:block;margin-top:2px}
.link-cell{color:var(--blue);font-style:italic;font-size:11.5px}
.src-tbl .ph{color:#a0aec0;font-style:italic}
.add-src-btn{margin-top:10px;padding:7px 14px;font-size:12px;background:var(--sb);
  border:1px solid #b8c7e6;color:var(--blue);border-radius:7px;cursor:pointer;font-weight:bold}
.add-src-btn:active{background:#dfeaff}
.note-box{margin-top:18px;padding-top:6px;border-top:1px dashed var(--line)}
.note-box h4{color:var(--blue)!important;border:none!important}
.edit-hint{padding:8px 18px 14px;font-size:11px;color:var(--muted);font-style:italic;
  background:#fff;border-top:1px solid var(--line)}

.m-backdrop{position:fixed;inset:0;background:rgba(10,16,28,.55);z-index:10000;
  display:none;align-items:flex-end;justify-content:center}
.m-backdrop.open{display:flex}
.m-sheet{background:#fff;width:100%;max-width:520px;border-radius:20px 20px 0 0;
  padding:6px 0 calc(14px + env(safe-area-inset-bottom));box-shadow:0 -16px 50px rgba(0,0,0,.35);
  animation:sheetUp .28s cubic-bezier(.32,.72,0,1)}
@keyframes sheetUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.m-grip{width:38px;height:4px;border-radius:999px;background:var(--line);margin:8px auto 4px}
.m-sheet-head{display:flex;align-items:center;gap:10px;padding:8px 16px 12px}
.m-sheet-title{flex:1;text-align:center;font-size:16px;font-weight:bold;color:var(--head)}
.m-head-spacer{width:34px;flex-shrink:0}
.m-close{width:34px;height:34px;border-radius:50%;border:1px solid var(--line);
  background:var(--sub);color:var(--muted);font-size:15px;cursor:pointer;
  display:grid;place-items:center;flex-shrink:0}
.m-close:active{background:var(--line)}
.m-list{padding:0 10px}
.m-opt,.m-row-more{display:flex;align-items:center;justify-content:space-between;gap:12px;
  width:100%;font-family:inherit;text-align:left;background:none;border:none;cursor:pointer;
  padding:13px 12px;border-radius:12px;transition:background .15s}
.m-opt:active,.m-row-more:active{background:var(--sub)}
.m-opt-text{display:flex;flex-direction:column;gap:3px;min-width:0}
.m-opt-text b{font-size:15px;color:var(--head)}
.m-opt-text span{font-size:12.5px;color:var(--muted)}
.m-check{color:var(--blue);font-size:18px;font-weight:bold;flex-shrink:0;opacity:0;
  transition:opacity .15s}
.m-opt.selected .m-check{opacity:1}
.m-div{height:1px;background:var(--line);margin:6px 14px}
.m-row-toggle{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 12px}
.m-switch{position:relative;width:46px;height:27px;border-radius:999px;border:none;
  background:#cfd6e2;cursor:pointer;flex-shrink:0;transition:background .2s;padding:0}
.m-switch.on{background:var(--blue)}
.m-knob{position:absolute;top:3px;left:3px;width:21px;height:21px;border-radius:50%;
  background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.3);transition:transform .2s}
.m-switch.on .m-knob{transform:translateX(19px)}
.m-row-more span:first-child{font-size:15px;font-weight:bold;color:var(--head)}
.m-more-chev{font-size:20px;color:var(--muted)}

.chk-badge { font-size: 11px; font-weight: bold; padding: 5px 12px; border-radius: 999px; cursor: pointer; user-select: none; transition: background-color 0.2s, color 0.2s, border-color 0.2s, transform 0.2s; display: inline-block; font-family: inherit; line-height: 1.4; border: 1px solid transparent; }
.chk-badge.pass { background: #e6f5ea; color: #007331; border-color: #b3e0c4; }
.chk-badge.fail { background: #fee2e2; color: #991b1b; border-color: #fecaca; }
.chk-badge:active { transform: scale(0.95); }

.chk-badge.chk-badge-lg{font-size:13px;padding:6px 14px;letter-spacing:.2px}

.ov-section:has(.chk-badge.chk-badge-lg.pass){
  background:linear-gradient(180deg,#f0fdf4,#fff);
  border-color:#b3e0c4;
}
.ov-section:has(.chk-badge.chk-badge-lg.fail){
  background:linear-gradient(180deg,#fef2f2,#fff);
  border-color:#fecaca;
}

#sheetBody div:has(> .chk-badge.chk-badge-lg){
  margin:16px 0 0 !important;padding:10px 12px 6px !important;
  border:1px solid transparent;border-bottom:0;border-radius:12px 12px 0 0;
  transition:background .2s,border-color .2s;
}

#sheetBody div:has(> .chk-badge.chk-badge-lg) + :is(div,ul,ol,p){
  margin:0 0 6px !important;padding:6px 12px 12px !important;
  border:1px solid transparent;border-border-radius:0 0 12px 12px;
  transition:background .2s,border-color .2s;
}

#sheetBody div:has(> .chk-badge.chk-badge-lg.pass),
#sheetBody div:has(> .chk-badge.chk-badge-lg.pass) + :is(div,ul,ol,p){
  background:#f0fdf4 !important;border-color:#b3e0c4 !important;
}

#sheetBody div:has(> .chk-badge.chk-badge-lg.fail),
#sheetBody div:has(> .chk-badge.chk-badge-lg.fail) + :is(div,ul,ol,p){
  background:#fef2f2 !important;border-color:#fecaca !important;
}

.m-row.risk.risk-danger .m-label{
  background:linear-gradient(135deg,#fee2e2,#fecaca) !important;
  color:#991b1b !important;
  border-color:#fca5a5 !important;
  position:relative;overflow:hidden;
  animation:riskGlow 1.6s ease-in-out infinite;
}
.m-row.risk.risk-danger .m-label::after{
  content:'';position:absolute;left:-120%;width:55%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.9),transparent);
  animation:riskShine 2.2s infinite;pointer-events:none;
}
.m-row.risk.risk-danger .m-val{
  background:#991b1b !important;color:#fff !important;border-color:#991b1b !important;
  animation:riskPulse 1.6s ease-in-out infinite;
}
.m-row.risk.risk-danger .bar i{
  background:linear-gradient(90deg,#bd3b33,#e26a63,#bd3b33) !important;
  background-size:200% 100% !important;
  animation:riskBarFlow 2s linear infinite;
}
@keyframes riskGlow{
  0%,100%{box-shadow:0 0 0 0 rgba(220,38,38,0)}
  50%{box-shadow:0 0 12px 2px rgba(220,38,38,.55)}
}
@keyframes riskPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(220,38,38,0);transform:scale(1)}
  50%{box-shadow:0 0 10px 1px rgba(220,38,38,.6);transform:scale(1.05)}
}
@keyframes riskShine{0%{left:-120%}55%,100%{left:170%}}
@keyframes riskBarFlow{0%{background-position:0% 0}100%{background-position:200% 0}}

.ov-metric.risk-danger .ov-metric-val{
  color:#991b1b !important;animation:riskPulse 1.6s ease-in-out infinite;
  padding:2px 8px;border-radius:8px;display:inline-block;
}
.ov-metric.risk-danger .ov-bar i{
  background:linear-gradient(90deg,#bd3b33,#e26a63,#bd3b33) !important;
  background-size:200% 100% !important;animation:riskBarFlow 2s linear infinite;
}

.card-wrapper {
  position: relative;
  overflow: hidden;
  border-radius: 12px;
  margin-bottom: 10px;
}
.card-actions-bg {
  position: absolute;
   top: 0; right: 0; bottom: 0; left: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: var(--line);
  border-radius: 12px;
  overflow: hidden;
  z-index: 0;
}
.action-btn {
  width: 70px;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: bold;
  font-size: 13px;
  border: none;
  cursor: pointer;
  border-radius: 12px !important;
}
.btn-pin { background: #f59e0b; }
.btn-del { background: #ef4444; }

.card-wrapper .card {
  margin-bottom: 0;
  position: relative;
  z-index: 1;
  transition: transform 0.25s ease-out;
  background: #fff;
}
.card-wrapper .card.swiping {
  transition: none;
  will-change: transform;
}
.pin-indicator {
  display: none;
  font-size: clamp(11px,3.2vw,14px);
  cursor: pointer;
  background: #fff3cd;
  border: 1px solid #ffe69c;
  border-radius: 50%;
  width: clamp(22px,6vw,26px);
  height: clamp(22px,6vw,26px);
  align-items: center;
  justify-content: center;
  margin-right: 4px;
  transition: transform 0.2s;
  flex-shrink: 0;
}
.pin-indicator:hover { transform: scale(1.1); }
.card-wrapper.pinned .pin-indicator { display: flex; }

.plan-tag {
  padding: 8px 16px;
  border-radius: 16px;
  font-family: 'Be Vietnam Pro', sans-serif;
  font-size: 14px;
  font-weight: 800;
  text-transform: uppercase;
  color: #fff;
  letter-spacing: 0.8px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.3);
  border: 1px solid rgba(255,255,255,0.25);
  text-shadow: 0 1px 2px rgba(0,0,0,0.5);
  position: relative;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.plan-tag span {
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.6)) saturate(1.5) contrast(1.2);
  margin-right: 5px;
}

.plan-none {
  background: rgba(255,255,255,0.2);
}

.plan-basic {
  background: linear-gradient(135deg, #3b82f6, #2563eb);
  color: #fff;
  border-color: #60a5fa;
}

.plan-pro {
  background: linear-gradient(135deg, #ec4899, #db2777);
  color: #fff;
  border-color: #f472b6;
}

.plan-elite {
  background: linear-gradient(135deg, #f59e0b, #d97706);
  color: #fff;
  border-color: #fbbf24;
}

.plan-bronze {
  background: linear-gradient(135deg, #cd7f32, #8b5a2b);
  border-color: #ffcba4;
}

.plan-silver {
  background: linear-gradient(135deg, #e0e0e0, #9e9e9e);
  color: #333;
  text-shadow: none;
  border-color: #fff;
}

.plan-gold {
  background: linear-gradient(135deg, #ffd700, #daa520);
  color: #5c3a00;
  text-shadow: none;
  border-color: #fff4ca;
}

.plan-diamond {
  background: linear-gradient(135deg, #b9f2ff, #2bc0e4);
  color: #004d61;
  text-shadow: none;
  border-color: #fff;
  animation: diamondShine 2s infinite linear;
}
@keyframes diamondShine {
  0% { box-shadow: 0 0 5px #b9f2ff; }
  50% { box-shadow: 0 0 15px #b9f2ff, 0 0 5px #fff inset; }
  100% { box-shadow: 0 0 5px #b9f2ff; }
}

.sparkle-eff::before {
  content: '';
  position: absolute;
  top: -50%; left: -50%; width: 200%; height: 200%;
  background: radial-gradient(circle, rgba(255,255,255,0.8) 0%, rgba(255,255,255,0) 60%);
  opacity: 0;
  transform: scale(0.5);
  animation: sparkleStar 3s infinite ease-in-out;
  pointer-events: none;
}
.plan-diamond.sparkle-eff::before {
  animation-delay: 0.5s;
}

.plan-imperial {
  background: #110b1a !important;
  border: 2px solid #b285e6 !important;
  border-radius: 50px !important;
  padding: 8px 30px 8px 15px !important;
  display: inline-flex !important;
  align-items: center !important;
  box-shadow: 0 0 15px rgba(178, 133, 230, 0.4), inset 0 0 15px rgba(178, 133, 230, 0.2) !important;
  position: relative !important;
  overflow: visible !important;
  text-shadow: none !important;
}
.plan-imperial::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  border-radius: 50px;
  background-image: radial-gradient(circle at 10% 20%, #b285e6 1px, transparent 1px),
                    radial-gradient(circle at 80% 80%, #b285e6 1px, transparent 1px),
                    radial-gradient(circle at 20% 70%, #b285e6 1px, transparent 1px);
  background-size: 80px 80px;
  opacity: 0.4;
  pointer-events: none;
}
.imperial-icon {
  margin-right: 15px;
  filter: drop-shadow(0 5px 10px rgba(0,0,0,0.8));
  z-index: 2;
}
.imperial-text-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  z-index: 2;
}
.imperial-title {
  font-family: 'Be Vietnam Pro', sans-serif;
  font-size: 20px;
  font-weight: 900;
  letter-spacing: 2px;
  background: linear-gradient(to bottom, #ffffff 40%, #e0c8fa 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.8));
  margin-bottom: 2px;
}
.imperial-divider {
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, transparent, #b285e6, transparent);
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}
.imperial-divider::after {
  content: '';
  width: 6px;
  height: 6px;
}

.plan-admin {
  background: linear-gradient(135deg, #4b0082, #800080);
  color: #fff;
  border-color: #dda0dd;
}

.bubble-eff {
  position: relative;
  overflow: hidden;
  transition: transform 0.2s ease, filter 0.2s ease, box-shadow 0.2s ease !important;
}
.bubble-eff:hover {
  transform: scale(1.05) !important;
  filter: brightness(1.1) !important;
  box-shadow: 0 0 30px rgba(178, 133, 230, 0.7) !important;
}
.bubble-eff:active {
  transform: scale(0.95) !important;
  filter: brightness(0.9) !important;
}
.bubble-eff::before, .bubble-eff::after {
  content: '';
  position: absolute;
  bottom: -10px;
  width: 6px;
  height: 6px;
  background: rgba(255,255,255,0.4);
  border-radius: 50%;
  animation: bubbleRise 2s infinite ease-in;
}
.bubble-eff::before {
  left: 20%;
  animation-duration: 1.5s;
  animation-delay: 0.2s;
}
.bubble-eff::after {
  left: 70%;

  animation-duration: 2s;
  animation-delay: 0.8s;
  width: 4px;
  height: 4px;
}
@keyframes bubbleRise {
  0% { transform: translateY(0) scale(1); opacity: 0; }
  20% { opacity: 1; }
  100% { transform: translateY(-40px) scale(1.5); opacity: 0; }
}

@keyframes imperialFlash {
  0%, 100% { border-color: #333; }
  50% { border-color: #666; }
}
@keyframes sparkleStar {
  0%, 100% { opacity: 0; transform: scale(0.5) translate(0, 0); }
  50% { opacity: 1; transform: scale(1.2) translate(10px, -10px); }
}

.pearl-fx-container {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  border-radius: 999px;
  z-index: 10;
}

.pearl-bubble {
  position: absolute;
  bottom: -15px;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,0.9), rgba(255,255,255,0.2) 60%, rgba(255,255,255,0.5) 100%);
  border-radius: 50%;
  box-shadow: 0 0 6px rgba(255,255,255,0.6);
  animation: ultraBubbleRise 2.5s infinite ease-in;
  opacity: 0;
}
.pb-1 { left: 10%; width: 7px; height: 7px; animation-duration: 2s; animation-delay: 0.1s; }
.pb-2 { left: 30%; width: 5px; height: 5px; animation-duration: 1.8s; animation-delay: 0.5s; }
.pb-3 { left: 45%; width: 9px; height: 9px; animation-duration: 2.2s; animation-delay: 1.2s; }
.pb-4 { left: 65%; width: 6px; height: 6px; animation-duration: 1.9s; animation-delay: 0.8s; }
.pb-5 { left: 85%; width: 8px; height: 8px; animation-duration: 2.4s; animation-delay: 1.5s; }
.pb-6 { left: 20%; width: 6px; height: 6px; animation-duration: 2.1s; animation-delay: 1.8s; }
.pb-7 { left: 75%; width: 5px; height: 5px; animation-duration: 1.7s; animation-delay: 0.3s; }
.pb-8 { left: 55%; width: 7px; height: 7px; animation-duration: 2.3s; animation-delay: 2.0s; }

@keyframes ultraBubbleRise {
  0% { transform: translateY(0) scale(0.8); opacity: 0; }
  20% { opacity: 0.9; }
  80% { opacity: 0.7; }
  100% { transform: translateY(-60px) scale(1.5); opacity: 0; }
}

.pearl-sparkle {
  position: absolute;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 0 8px 3px #fff, 0 0 16px 6px #e0c8fa;
  animation: ultraSparkle 2s infinite ease-in-out;
  opacity: 0;
}
.ps-1 { top: 25%; left: 15%; width: 3px; height: 3px; animation-delay: 0s; }
.ps-2 { top: 65%; left: 85%; width: 4px; height: 4px; animation-delay: 0.7s; }
.ps-3 { top: 35%; left: 55%; width: 2px; height: 2px; animation-delay: 1.3s; }
.ps-4 { top: 75%; left: 35%; width: 3px; height: 3px; animation-delay: 0.4s; }
.ps-5 { top: 15%; left: 75%; width: 2px; height: 2px; animation-delay: 1.1s; }

@keyframes ultraSparkle {
  0%, 100% { transform: scale(0.2) rotate(0deg); opacity: 0; }
  50% { transform: scale(1.5) rotate(180deg); opacity: 1; }
}

.sparkle-btn-eff {
  animation: btnBlinkSparkle 1.1s infinite ease-in-out !important;
  font-weight: 800 !important;
  position: relative;
  z-index: 3;
}
@keyframes btnBlinkSparkle {
  0%, 100% { background:#ff7a00 !important; color:#fff !important; border-color:#ff7a00 !important; box-shadow:0 0 4px 1px rgba(255,140,0,.85), inset 0 0 5px rgba(255,255,255,.45) !important; transform:scale(1); }
  50% { background:#ffd21a !important; color:#7a3d00 !important; border-color:#ffb300 !important; box-shadow:0 0 14px 4px rgba(255,179,0,.95), inset 0 0 10px rgba(255,255,255,.8) !important; transform:scale(1.07); }
}
