@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;900&family=Crimson+Pro:ital,wght@0,300;0,400;1,300&display=swap');

/* ═══════════════════════════════════
   CSS VARIABLES & RESET
═══════════════════════════════════ */
:root {
  --void:#07020f; --deep:#0d0520; --chamber:#150a2e;
  --p1:#2d1060; --p2:#4a1d96; --p3:#7c3aed; --p4:#a78bfa;
  --g1:#78350f; --g2:#b45309; --g3:#d97706; --g4:#f59e0b; --g5:#fbbf24; --g6:#fde68a;
  --text:#e9d5ff; --dim:#8b5cf6; --r:14px;
  --gg:linear-gradient(135deg,#78350f,#b45309,#f59e0b,#fde68a,#f59e0b,#b45309);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --safe-top: env(safe-area-inset-top, 0px);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{height:100%;height:-webkit-fill-available}
body{height:100%;height:-webkit-fill-available;background:var(--void);color:var(--text);
  font-family:'Crimson Pro',Georgia,serif;font-size:17px;overflow:hidden;
  -webkit-tap-highlight-color:transparent;user-select:none}

/* ═══ ANIMATIONS ═══ */
@keyframes aura{0%{opacity:.7}100%{opacity:1}}
@keyframes d1{0%{transform:translate(0,0)}100%{transform:translate(60px,40px)}}
@keyframes d2{0%{transform:translate(0,0)}100%{transform:translate(-40px,-60px)}}
@keyframes shimmer{0%{background-position:0% center}100%{background-position:200% center}}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes pdot{0%,100%{opacity:1;box-shadow:0 0 6px var(--g4)}50%{opacity:.5;box-shadow:0 0 14px var(--g4)}}
@keyframes bounce{0%,80%,100%{transform:translateY(0);opacity:.4}40%{transform:translateY(-8px);opacity:1}}
@keyframes pglow{0%{background-position:0% 50%}100%{background-position:200% 50%}}
@keyframes wv{0%,100%{transform:scaleY(.3)}50%{transform:scaleY(1)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes slideUp{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes slideDown{from{transform:translateY(0);opacity:1}to{transform:translateY(100%);opacity:0}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.06)}}

/* ═══ BACKGROUND ═══ */
body::before{content:'';position:fixed;inset:0;z-index:0;
  background:radial-gradient(ellipse 80% 60% at 20% 10%,#2d106055,transparent 60%),
             radial-gradient(ellipse 60% 80% at 80% 90%,#4a1d9633,transparent 60%),
             radial-gradient(ellipse 40% 40% at 50% 50%,#1a0a3020,transparent 70%);
  animation:aura 8s ease-in-out infinite alternate;pointer-events:none}
.orb{position:fixed;border-radius:50%;filter:blur(70px);pointer-events:none;z-index:0}
.orb-1{width:400px;height:400px;background:radial-gradient(circle,#7c3aed33,transparent 70%);top:-100px;left:-100px;animation:d1 12s ease-in-out infinite alternate}
.orb-2{width:300px;height:300px;background:radial-gradient(circle,#f59e0b22,transparent 70%);bottom:-80px;right:-80px;animation:d2 10s ease-in-out infinite alternate}
.orb-3{width:200px;height:200px;background:radial-gradient(circle,#a78bfa22,transparent 70%);top:40%;left:60%;animation:d1 15s ease-in-out infinite alternate-reverse}

/* ═══════════════════════════════════
   DEVICE BANNER
═══════════════════════════════════ */
#device-banner{
  position:fixed;top:0;left:0;right:0;z-index:9999;
  padding:6px 16px;
  display:flex;align-items:center;justify-content:space-between;
  font-family:'Cinzel',serif;font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;
  backdrop-filter:blur(20px);
  border-bottom:1px solid #4a1d9630;
  transition:transform .4s ease;
}
#device-banner.mobile-banner{background:#150a2edd;color:var(--p4)}
#device-banner.desktop-banner{background:#0d052099;color:#4a1d9688}
.banner-left{display:flex;align-items:center;gap:8px}
.banner-dot{width:6px;height:6px;border-radius:50%}
.banner-dot.mobile-dot{background:#a78bfa;box-shadow:0 0 8px #a78bfa88;animation:pdot 2s infinite}
.banner-dot.desktop-dot{background:var(--g4);box-shadow:0 0 8px #f59e0b88;animation:pdot 2s infinite}
.banner-ver{
  font-size:9px;letter-spacing:.14em;
  background:var(--gg);background-size:200% auto;animation:shimmer 4s linear infinite;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  font-weight:900;
}
#banner-close{background:none;border:none;color:#4a1d9688;cursor:pointer;font-size:14px;padding:2px 6px;transition:color .2s}
#banner-close:hover{color:var(--p4)}

/* ═══════════════════════════════════
   SHARED COMPONENTS
═══════════════════════════════════ */
.gold-text{background:var(--gg);background-size:200% auto;animation:shimmer 4s linear infinite;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.logo-icon{background:var(--gg);background-size:200% auto;animation:shimmer 4s linear infinite;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2L9.5 8.5 3 9.5l4.5 4.3L6.2 20 12 17l5.8 3-1.3-6.2L21 9.5l-6.5-1z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2L9.5 8.5 3 9.5l4.5 4.3L6.2 20 12 17l5.8 3-1.3-6.2L21 9.5l-6.5-1z'/%3E%3C/svg%3E") center/contain no-repeat}

/* ── Media Result Cards (shared) ── */
.r-card{border-radius:12px;overflow:hidden;max-width:100%}
.r-card.photo-card{border:1px solid #7c3aed50}
.r-card.audio-card{border:1px solid #06b6d450}
.r-card.video-card{border:1px solid #f59e0b50}
.photo-canvas-wrap{width:100%;aspect-ratio:16/9;background:#07020f}
.photo-canvas-wrap canvas,.video-thumb-wrap canvas{width:100%;height:100%;display:block}
.card-footer{padding:9px 12px;background:#0d052290;display:flex;align-items:center;gap:8px}
.card-meta{font-size:11px;color:var(--p4);font-family:'Cinzel',serif;letter-spacing:.05em;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ext-badge{font-size:9px;color:var(--g4);font-family:'Cinzel',serif;letter-spacing:.12em;background:#f59e0b18;border:1px solid #f59e0b40;padding:2px 7px;border-radius:12px;white-space:nowrap}
.dl-btn{padding:5px 11px;border-radius:7px;border:none;font-family:'Cinzel',serif;font-size:9.5px;letter-spacing:.1em;cursor:pointer;transition:all .2s;font-weight:700;white-space:nowrap}
.dl-btn.pdl{background:var(--gg);background-size:200% auto;animation:shimmer 3s linear infinite;color:#1a0a30}
.dl-btn.adl{background:linear-gradient(135deg,#0e7490,#06b6d4);color:#ecfeff}
.dl-btn.vdl{background:var(--gg);background-size:200% auto;animation:shimmer 3s linear infinite;color:#1a0a30}
.dl-btn:hover{transform:scale(1.04)}
.audio-wave-wrap{background:linear-gradient(135deg,#0f172a,#0e7490,#0f172a);padding:14px;display:flex;align-items:center;gap:2px;justify-content:center;height:62px}
.wbar{width:3px;border-radius:3px;background:linear-gradient(to top,#06b6d4,#67e8f9);animation:wv .8s ease-in-out infinite}
.audio-ctrl{padding:9px 12px;background:#0d052290;display:flex;align-items:center;gap:10px}
.play-btn{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#0e7490,#06b6d4);border:none;cursor:pointer;color:#fff;font-size:11px;transition:all .2s;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.play-btn:hover{box-shadow:0 0 14px #06b6d455;transform:scale(1.08)}
.audio-name{font-size:12px;color:var(--text);font-family:'Cinzel',serif;letter-spacing:.05em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.audio-dur{font-size:11px;color:#06b6d4}
.video-thumb-wrap{width:100%;aspect-ratio:16/9;position:relative;overflow:hidden;background:#07020f}
.video-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.video-play-circle{width:54px;height:54px;border-radius:50%;background:var(--gg);background-size:200% auto;animation:shimmer 3s linear infinite;display:flex;align-items:center;justify-content:center;font-size:20px;color:#1a0a30;box-shadow:0 0 32px #f59e0b55;cursor:pointer;border:none;transition:transform .2s}
.video-play-circle:hover{transform:scale(1.1)}
.video-dur-badge{position:absolute;bottom:10px;right:12px;background:#0d0520cc;border:1px solid #f59e0b40;border-radius:6px;padding:3px 8px;font-family:'Cinzel',serif;font-size:10px;color:var(--g5)}
.video-info-wrap{flex:1;min-width:0}
.video-ititle{font-size:12px;color:var(--text);font-family:'Cinzel',serif;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.video-isub{font-size:11px;color:var(--g4)}

/* ── Message bubbles (shared) ── */
.msg{display:flex;gap:10px;animation:fadeUp .3s ease;width:100%}
.msg.user{flex-direction:row-reverse}
.msg.ai{align-self:flex-start}
.msg-av{width:30px;height:30px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:14px}
.msg.ai .msg-av{background:var(--gg);background-size:200% auto;animation:shimmer 4s linear infinite;box-shadow:0 0 14px #f59e0b33}
.msg.user .msg-av{background:linear-gradient(135deg,#4a1d96,#7c3aed);box-shadow:0 0 10px #7c3aed33}
.msg-bub{padding:11px 15px;border-radius:var(--r);font-size:14.5px;line-height:1.78;max-width:min(580px,75%);overflow-wrap:break-word;word-break:break-word}
.msg.ai .msg-bub{background:linear-gradient(135deg,#150a2ecc,#0d0520cc);border:1px solid #4a1d9640;color:var(--text);border-top-left-radius:4px;backdrop-filter:blur(10px);position:relative}
.msg.ai .msg-bub::before{content:'';position:absolute;inset:0;border-radius:inherit;background:linear-gradient(135deg,#f59e0b07,transparent 50%);pointer-events:none}
.msg.user .msg-bub{background:linear-gradient(135deg,#4a1d96cc,#2d1060cc);border:1px solid #7c3aed50;color:var(--text);border-top-right-radius:4px;backdrop-filter:blur(10px)}
.typ-bub{display:flex;align-items:center;gap:5px;padding:13px 15px;background:linear-gradient(135deg,#150a2ecc,#0d0520cc);border:1px solid #4a1d9640;border-radius:var(--r);border-top-left-radius:4px}
.tdot{width:7px;height:7px;border-radius:50%;background:var(--g4);animation:bounce 1.2s ease-in-out infinite}
.tdot:nth-child(2){animation-delay:.2s;background:var(--g5)}
.tdot:nth-child(3){animation-delay:.4s;background:var(--g6)}
.src-badge{display:inline-flex;align-items:center;gap:4px;background:#2d106080;border:1px solid #f59e0b40;border-radius:20px;padding:2px 9px;font-size:11px;color:var(--g5);margin-top:6px;font-family:'Cinzel',serif;letter-spacing:.05em}

/* ── Welcome screen ── */
.welcome{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;text-align:center;padding:30px;animation:fadeUp .8s ease;user-select:none}
.welcome-star{font-size:52px;background:var(--gg);background-size:200% auto;animation:shimmer 3s linear infinite;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:14px;filter:drop-shadow(0 0 24px #f59e0b44)}
.welcome h2{font-family:'Cinzel',serif;font-size:24px;font-weight:900;margin-bottom:8px}
.welcome h2 span{background:var(--gg);background-size:200% auto;animation:shimmer 4s linear infinite;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.welcome p{color:var(--dim);font-size:14.5px;max-width:480px;line-height:1.75;font-style:italic}
.wchips{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px;justify-content:center}
.wchip{background:#2d106060;border:1px solid #4a1d9650;border-radius:30px;padding:7px 15px;font-size:13px;color:var(--p4);cursor:pointer;transition:all .25s;font-style:italic;user-select:none}
.wchip:hover,.wchip:active{background:#4a1d9440;border-color:var(--g4);color:var(--g5);transform:translateY(-2px)}

/* ── Input box (shared) ── */
.input-box{display:flex;align-items:flex-end;gap:8px;background:#150a2e99;border:1px solid #4a1d9660;border-radius:16px;padding:8px 9px 8px 15px;transition:border-color .25s,box-shadow .25s;backdrop-filter:blur(20px);position:relative}
.input-box::before{content:'';position:absolute;inset:0;border-radius:inherit;background:linear-gradient(135deg,#f59e0b05,transparent 50%);pointer-events:none}
.input-box:focus-within{border-color:var(--g4);box-shadow:0 0 0 2px #f59e0b16}
.user-input{flex:1;background:transparent;border:none;outline:none;resize:none;color:var(--text);font-family:'Crimson Pro',serif;font-size:15px;line-height:1.6;max-height:120px;overflow-y:auto;padding:3px 0;user-select:text}
.user-input::placeholder{color:#6d4eaa55;font-style:italic}
.send-btn{width:36px;height:36px;border-radius:10px;background:var(--gg);background-size:200% auto;animation:shimmer 4s linear infinite;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 18px #f59e0b28;flex-shrink:0}
.send-btn:hover{transform:scale(1.08);box-shadow:0 4px 26px #f59e0b55}
.send-btn:active{transform:scale(.94)}
.send-btn svg{width:15px;height:15px;fill:#1a0a30}
.iicon-btn{width:30px;height:30px;border-radius:8px;background:transparent;border:1px solid #4a1d9440;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;transition:all .2s;color:#6d4eaa;flex-shrink:0}
.iicon-btn:hover{background:#2d106060;border-color:#7c3aed80}

/* ── Modal ── */
.overlay{position:fixed;inset:0;z-index:500;background:#000000bb;backdrop-filter:blur(12px);display:none;align-items:center;justify-content:center}
.overlay.open{display:flex;animation:fadeIn .25s ease}
.modal{background:linear-gradient(145deg,#0d0520,#150a2e);border:1px solid #4a1d9660;border-radius:20px;width:min(580px,95vw);max-height:88vh;overflow-y:auto;padding:24px;box-shadow:0 40px 100px #000000cc,0 0 60px #7c3aed18;animation:fadeUp .25s ease}
.modal::-webkit-scrollbar{width:3px}
.modal::-webkit-scrollbar-thumb{background:#4a1d9660;border-radius:3px}
.modal-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.modal-close{width:28px;height:28px;border-radius:8px;border:1px solid #4a1d9640;background:transparent;color:var(--p4);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;transition:all .2s}
.modal-close:hover{background:#2d106060;color:var(--text)}
.modal-tabs{display:flex;gap:6px;margin-bottom:18px}
.m-tab{flex:1;padding:10px 6px;border-radius:11px;border:1px solid #4a1d9640;background:transparent;cursor:pointer;transition:all .22s;display:flex;flex-direction:column;align-items:center;gap:4px}
.m-tab-ic{font-size:20px}
.m-tab-lb{font-family:'Cinzel',serif;font-size:9px;letter-spacing:.1em;text-transform:uppercase}
.m-tab[data-t=photo]{color:#a78bfa}.m-tab[data-t=audio]{color:#67e8f9}.m-tab[data-t=video]{color:var(--g5)}
.m-tab.active[data-t=photo]{background:#4a1d9430;border-color:#a78bfa}
.m-tab.active[data-t=audio]{background:#0e749020;border-color:#06b6d4}
.m-tab.active[data-t=video]{background:#2d106050;border-color:var(--g4)}
.m-form{display:none;flex-direction:column;gap:12px}
.m-form.active{display:flex}
.fl{font-family:'Cinzel',serif;font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--g4);margin-bottom:3px;display:block;opacity:.85}
.fta{width:100%;background:#0d052280;border:1px solid #4a1d9650;border-radius:11px;padding:11px 13px;color:var(--text);font-family:'Crimson Pro',serif;font-size:14.5px;outline:none;resize:none;line-height:1.6;transition:border-color .25s;min-height:78px}
.fta:focus{border-color:var(--g4);box-shadow:0 0 0 2px #f59e0b16}
.fta::placeholder{color:#6d4eaa55;font-style:italic}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.fsel{width:100%;background:#0d052280;border:1px solid #4a1d9650;border-radius:9px;padding:8px 10px;color:var(--p4);font-family:'Cinzel',serif;font-size:9.5px;letter-spacing:.06em;outline:none;cursor:pointer}
.fsel option{background:#150a2e}
.dur-wrap{background:#0d052280;border:1px solid #4a1d9650;border-radius:11px;padding:13px}
.dur-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.dur-cur{font-family:'Cinzel',serif;font-size:20px;color:var(--g5);font-weight:900}
.dur-max{font-size:10px;color:#6d4eaa;font-family:'Cinzel',serif}
input[type=range]{width:100%;-webkit-appearance:none;appearance:none;height:4px;border-radius:4px;background:linear-gradient(90deg,var(--g4),#4a1d96);outline:none;cursor:pointer;margin:3px 0 9px}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--g5);box-shadow:0 0 8px #f59e0b88;cursor:pointer}
.dur-presets{display:flex;gap:4px;flex-wrap:wrap}
.dp{padding:4px 10px;border-radius:20px;border:1px solid #4a1d9640;background:transparent;color:#6d4eaa;font-family:'Cinzel',serif;font-size:9px;cursor:pointer;transition:all .2s}
.dp.active{background:#f59e0b20;border-color:var(--g4);color:var(--g5)}
.gen-btn{width:100%;padding:12px;border-radius:11px;border:none;cursor:pointer;font-family:'Cinzel',serif;font-size:11px;letter-spacing:.15em;text-transform:uppercase;font-weight:700;transition:transform .2s}
.gen-btn:hover{transform:translateY(-2px)}
.gen-btn.pg{background:linear-gradient(135deg,#4a1d96,#7c3aed,#a78bfa,#7c3aed,#4a1d96);background-size:200% auto;animation:shimmer 3s linear infinite;color:#f3e8ff;box-shadow:0 4px 20px #7c3aed33}
.gen-btn.ag{background:linear-gradient(135deg,#0e7490,#06b6d4,#67e8f9,#06b6d4,#0e7490);background-size:200% auto;animation:shimmer 3s linear infinite;color:#ecfeff;box-shadow:0 4px 20px #06b6d433}
.gen-btn.vg{background:var(--gg);background-size:200% auto;animation:shimmer 4s linear infinite;color:#1a0a30;box-shadow:0 4px 20px #f59e0b33}

/* ── Queue items ── */
.q-empty{font-size:12px;color:#4a2d70;font-style:italic;padding:4px 2px}
.q-item{background:#150a2e88;border:1px solid #4a1d9630;border-radius:10px;padding:9px 11px;margin-bottom:7px}
.q-hdr{display:flex;align-items:center;gap:7px;margin-bottom:5px}
.q-badge{padding:2px 7px;border-radius:20px;font-family:'Cinzel',serif;font-size:8.5px;letter-spacing:.1em;font-weight:600}
.bphoto{background:#4a1d9440;border:1px solid #a78bfa50;color:#c4b5fd}
.baudio{background:#0e749020;border:1px solid #06b6d450;color:#67e8f9}
.bvideo{background:#2d106040;border:1px solid #f59e0b40;color:var(--g5)}
.q-prompt{font-size:11px;color:var(--text);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.q-st{font-size:9px;font-family:'Cinzel',serif}
.st-gen{color:var(--g4);animation:pdot 1.5s infinite}
.st-done{color:#4ade80}
.pb-wrap{height:3px;background:#2d106060;border-radius:3px;overflow:hidden}
.pb-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,#78350f,#f59e0b,#fde68a,#f59e0b,#78350f);background-size:200% auto;animation:pglow 2s linear infinite;transition:width .4s ease}
.pb-fill.af{background:linear-gradient(90deg,#0e7490,#06b6d4,#67e8f9,#06b6d4,#0e7490);background-size:200% auto}
.pb-fill.pf{background:linear-gradient(90deg,#4a1d96,#7c3aed,#a78bfa,#7c3aed,#4a1d96);background-size:200% auto}

/* ── History items ── */
.hist-item{padding:9px 11px;border-radius:9px;font-size:13px;color:#8b5cf680;cursor:pointer;transition:all .2s;margin-bottom:3px;display:flex;align-items:center;gap:8px;user-select:none}
.hist-item:hover{background:#2d106060;color:var(--p4)}
.hist-item.active{background:#4a1d9440;color:var(--text);border-left:2px solid var(--g4)}
.hist-item-text{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hist-item-time{font-size:9.5px;color:#4a2d7088;font-family:'Cinzel',serif;flex-shrink:0}
.hist-del{background:none;border:none;color:#4a2d7060;cursor:pointer;font-size:12px;padding:2px 4px;transition:color .2s;flex-shrink:0}
.hist-del:hover{color:#ef444488}

/* ═══════════════════════════════════
   DESKTOP LAYOUT
═══════════════════════════════════ */
#desktop-app{
  position:relative;z-index:1;
  display:grid;grid-template-columns:274px 1fr;
  height:100vh;overflow:hidden;
}
#desktop-sidebar{
  display:flex;flex-direction:column;
  width:274px;min-width:274px;max-width:274px;
  background:linear-gradient(180deg,#0d052299,#07020f99);
  border-right:1px solid #4a1d9640;
  backdrop-filter:blur(20px);overflow:hidden;
  z-index:2;position:relative;
}
.desk-logo-wrap{padding:20px 20px 14px;border-bottom:1px solid #4a1d9630;position:relative;flex-shrink:0}
.desk-logo-wrap::after{content:'';position:absolute;bottom:0;left:20px;right:20px;height:1px;background:var(--gg);opacity:.4}
.desk-logo{font-family:'Cinzel',serif;font-size:19px;font-weight:900;letter-spacing:.12em;display:flex;align-items:center;gap:8px}
.desk-logo .logo-icon{width:26px;height:26px}
.desk-logo-tagline{display:flex;align-items:center;justify-content:space-between;margin-top:4px}
.desk-logo-sub{font-size:9.5px;color:var(--dim);letter-spacing:.2em;font-family:'Cinzel',serif;text-transform:uppercase}
.desk-ver{font-size:9px;font-family:'Cinzel',serif;letter-spacing:.12em;background:var(--gg);background-size:200% auto;animation:shimmer 4s linear infinite;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:900;padding:2px 8px;border-radius:20px;border:1px solid #f59e0b30;position:relative}
.desk-ver::before{content:'';position:absolute;inset:0;border-radius:inherit;background:linear-gradient(135deg,#f59e0b10,transparent);pointer-events:none}
.desk-nav{display:flex;gap:3px;padding:8px 10px 6px;flex-shrink:0}
.desk-nav-btn{flex:1;padding:7px 4px;border-radius:9px;border:1px solid #4a1d9440;background:transparent;color:#6d4eaa;font-family:'Cinzel',serif;font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:3px}
.desk-nav-btn .ti{font-size:14px}
.desk-nav-btn:hover{background:#2d106050;color:var(--p4)}
.desk-nav-btn.active{background:#4a1d9440;border-color:var(--g4);color:var(--g5)}
.desk-panel{display:none;flex-direction:column;flex:1;overflow:hidden}
.desk-panel.active{display:flex}
.panel-title{font-family:'Cinzel',serif;font-size:9px;letter-spacing:.25em;text-transform:uppercase;color:var(--g4);padding:11px 18px 6px;opacity:.8;flex-shrink:0}
.side-div{height:1px;background:var(--gg);opacity:.15;margin:3px 10px 8px;flex-shrink:0}
.settings-section{padding:0 10px;flex-shrink:0}
.setting-row{display:flex;align-items:center;justify-content:space-between;padding:5px 2px;border-bottom:1px solid #2d106030}
.setting-label{font-family:'Cinzel',serif;font-size:9.5px;letter-spacing:.08em;color:var(--p4)}
.setting-value{font-size:10.5px;color:var(--g5);background:#2d106040;padding:2px 8px;border-radius:20px;border:1px solid #4a1d9640;cursor:pointer;transition:all .2s}
.setting-value:hover{background:#4a1d9040;border-color:var(--g4)}
.scraper-section{padding:0 10px 10px;flex-shrink:0}
.sc-wrap{position:relative}
.sc-input{width:100%;background:#150a2e88;border:1px solid #4a1d9650;border-radius:10px;padding:8px 38px 8px 11px;color:var(--text);font-family:'Crimson Pro',serif;font-size:12.5px;outline:none;height:42px}
.sc-input:focus{border-color:var(--g4);box-shadow:0 0 0 2px #f59e0b22}
.sc-input::placeholder{color:#6d4eaa88}
.sc-btn{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:var(--gg);background-size:200% auto;animation:shimmer 4s linear infinite;border:none;border-radius:7px;width:24px;height:24px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.sc-btn svg{width:11px;height:11px;fill:#1a0a30}
.sc-status{font-size:10.5px;color:var(--g5);padding:4px 10px 0;min-height:17px;font-style:italic}
.sc-result{background:#0d052280;border:1px solid #4a1d9630;border-radius:9px;margin:5px 0 0;padding:7px 10px;font-size:11.5px;color:var(--p4);max-height:64px;overflow-y:auto;display:none;line-height:1.5}
.sc-result.visible{display:block}
.history-section{flex:1;overflow-y:auto;padding:0 10px 12px}
.history-section::-webkit-scrollbar{width:3px}
.history-section::-webkit-scrollbar-thumb{background:#4a1d9660;border-radius:3px}
.new-chat-btn{width:100%;margin:4px 0 8px;padding:8px;background:linear-gradient(135deg,#2d106060,#4a1d9440);border:1px dashed #7c3aed50;border-radius:9px;color:var(--p4);font-family:'Cinzel',serif;font-size:9.5px;letter-spacing:.1em;cursor:pointer;transition:all .25s;text-transform:uppercase}
.new-chat-btn:hover{border-color:var(--g4);color:var(--g5)}
.media-quick-btns{padding:0 10px 10px;flex-shrink:0;display:flex;flex-direction:column;gap:5px}
.mqb{width:100%;padding:9px 11px;border-radius:10px;border:none;cursor:pointer;font-family:'Cinzel',serif;font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;transition:transform .2s;display:flex;align-items:center;gap:7px}
.mqb:hover{transform:translateY(-1px)}
.mqb.pm{background:linear-gradient(135deg,#4a1d96,#7c3aed,#a78bfa,#7c3aed,#4a1d96);background-size:200% auto;animation:shimmer 4s linear infinite;color:#f3e8ff}
.mqb.am{background:linear-gradient(135deg,#0e7490,#06b6d4,#67e8f9,#06b6d4,#0e7490);background-size:200% auto;animation:shimmer 4s linear infinite;color:#ecfeff}
.mqb.vm{background:var(--gg);background-size:200% auto;animation:shimmer 4s linear infinite;color:#1a0a30}
.queue-section{flex:1;overflow-y:auto;padding:0 10px 10px}
.queue-section::-webkit-scrollbar{width:3px}
.queue-section::-webkit-scrollbar-thumb{background:#4a1d9660;border-radius:3px}
#desktop-main{display:flex;flex-direction:column;overflow:hidden;position:relative;min-width:0;height:100vh}
#desk-topbar{display:flex;align-items:center;justify-content:space-between;padding:11px 22px;border-bottom:1px solid #4a1d9630;background:#0d052260;backdrop-filter:blur(20px);flex-shrink:0;position:relative}
#desk-topbar::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--gg);opacity:.2}
.desk-topbar-title{font-family:'Cinzel',serif;font-size:13px}
.model-badge{display:flex;align-items:center;gap:7px;background:#2d106060;border:1px solid #4a1d9650;border-radius:30px;padding:5px 13px;font-size:10.5px;color:var(--p4);font-family:'Cinzel',serif;letter-spacing:.08em;cursor:pointer;transition:all .25s}
.model-badge:hover{border-color:var(--g4);color:var(--g5)}
.mdot{width:6px;height:6px;border-radius:50%;background:var(--g4);box-shadow:0 0 8px var(--g4);animation:pdot 2s ease-in-out infinite}
.model-dd{position:absolute;top:calc(100% + 6px);right:22px;background:#150a2eee;border:1px solid #4a1d9660;border-radius:13px;padding:6px;min-width:190px;backdrop-filter:blur(30px);z-index:100;display:none;animation:fadeUp .2s ease;box-shadow:0 20px 60px #00000080}
.model-dd.open{display:block}
.mopt{padding:8px 10px;border-radius:9px;cursor:pointer;transition:all .2s}
.mopt:hover{background:#2d106070}
.mopt.sel{background:#4a1d9440}
.mopt-name{font-size:11.5px;color:var(--text);font-family:'Cinzel',serif}
.mopt-desc{font-size:10px;color:var(--dim)}
.qcbar{display:flex;gap:5px;padding:7px 22px 6px;flex-shrink:0;background:#07020f60;border-bottom:1px solid #4a1d9618}
.qcb{display:flex;align-items:center;gap:4px;padding:5px 11px;border-radius:20px;border:1px solid #4a1d9440;background:transparent;color:#7c4da0;font-family:'Cinzel',serif;font-size:9px;letter-spacing:.1em;cursor:pointer;transition:all .2s;text-transform:uppercase}
.qcb.pq:hover{border-color:#a78bfa;color:#c4b5fd;background:#2d106050}
.qcb.aq:hover{border-color:#06b6d4;color:#67e8f9;background:#2d106050}
.qcb.vq:hover{border-color:var(--g4);color:var(--g5);background:#2d106050}
#desk-messages{flex:1;min-height:0;overflow-y:auto;padding:20px 28px;display:flex;flex-direction:column;gap:14px;scroll-behavior:smooth;max-width:100%}
#desk-messages::-webkit-scrollbar{width:4px}
#desk-messages::-webkit-scrollbar-thumb{background:#4a1d9650;border-radius:4px}
#desk-input-area{padding:12px 22px 16px;flex-shrink:0;position:relative;min-width:0;max-width:100%;overflow:hidden}
#desk-input-area::before{content:'';position:absolute;top:0;left:22px;right:22px;height:1px;background:var(--gg);opacity:.18}
.desk-input-footer{text-align:center;margin-top:6px;font-size:10px;color:#4a2d7030;font-family:'Cinzel',serif;letter-spacing:.12em}

/* ═══════════════════════════════════
   MOBILE LAYOUT
═══════════════════════════════════ */
#mobile-app{
  position:relative;z-index:1;
  display:flex;flex-direction:column;
  height:100vh;height:-webkit-fill-available;
  overflow:hidden;
}
/* Mobile topbar */
#mob-topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;
  padding-top:calc(10px + var(--safe-top));
  background:#0d052290;backdrop-filter:blur(20px);
  border-bottom:1px solid #4a1d9630;flex-shrink:0;position:relative;z-index:10;
}
#mob-topbar::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--gg);opacity:.25}
.mob-logo{font-family:'Cinzel',serif;font-size:16px;font-weight:900;letter-spacing:.1em;display:flex;align-items:center;gap:7px}
.mob-logo .logo-icon{width:22px;height:22px}
.mob-logo-ver{font-size:8.5px;font-family:'Cinzel',serif;letter-spacing:.1em;background:var(--gg);background-size:200% auto;animation:shimmer 4s linear infinite;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:900;padding:2px 7px;border-radius:12px;border:1px solid #f59e0b30}
.mob-topbar-right{display:flex;align-items:center;gap:8px}
.mob-icon-btn{width:34px;height:34px;border-radius:9px;border:1px solid #4a1d9440;background:transparent;color:var(--p4);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;transition:all .2s}
.mob-icon-btn:hover,.mob-icon-btn:active{background:#2d106060}

/* Mobile messages */
#mob-messages{
  flex:1;min-height:0;overflow-y:auto;padding:14px 14px 8px;
  display:flex;flex-direction:column;gap:12px;scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch;
}
#mob-messages::-webkit-scrollbar{display:none}

/* Mobile input */
#mob-input-area{
  padding:8px 12px;
  padding-bottom:calc(8px + var(--safe-bottom));
  flex-shrink:0;position:relative;
  background:#07020f90;backdrop-filter:blur(20px);
  border-top:1px solid #4a1d9630;
}
.mob-qcbar{display:flex;gap:5px;margin-bottom:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px}
.mob-qcbar::-webkit-scrollbar{display:none}
.mob-qcb{display:flex;align-items:center;gap:4px;padding:5px 10px;border-radius:20px;border:1px solid #4a1d9440;background:transparent;color:#7c4da0;font-family:'Cinzel',serif;font-size:8.5px;letter-spacing:.08em;cursor:pointer;white-space:nowrap;transition:all .2s;text-transform:uppercase;flex-shrink:0}
.mob-qcb.mpq{border-color:#a78bfa40;color:#a78bfa88}
.mob-qcb.maq{border-color:#06b6d440;color:#67e8f988}
.mob-qcb.mvq{border-color:#f59e0b40;color:#f59e0b88}
.mob-qcb:active{opacity:.7}

/* Mobile bottom nav */
#mob-bottom-nav{
  display:flex;align-items:center;
  background:#0d052299;backdrop-filter:blur(30px);
  border-top:1px solid #4a1d9640;
  padding-bottom:var(--safe-bottom);
  flex-shrink:0;position:relative;z-index:10;
  overflow-x:auto;overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:thin;
  scrollbar-color:#4a1d9660 transparent;
}
#mob-bottom-nav::-webkit-scrollbar{height:3px}
#mob-bottom-nav::-webkit-scrollbar-track{background:transparent}
#mob-bottom-nav::-webkit-scrollbar-thumb{background:#4a1d9660;border-radius:3px}
#mob-bottom-nav::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:var(--gg);opacity:.25}
.mob-nav-btn{flex:0 0 60px;min-width:60px;padding:10px 4px 8px;border:none;background:transparent;display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;transition:all .2s}
.mob-nav-ic{font-size:18px;transition:transform .2s}
.mob-nav-lb{font-family:'Cinzel',serif;font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:#6d4eaa;transition:color .2s}
.mob-nav-btn.active .mob-nav-lb{color:var(--g5)}
.mob-nav-btn.active .mob-nav-ic{transform:scale(1.15)}
.mob-nav-btn:active{opacity:.7}

/* Mobile drawers */
.mob-drawer{
  position:fixed;inset:0;z-index:400;
  display:none;flex-direction:column;
}
.mob-drawer.open{display:flex;animation:fadeIn .2s ease}
.mob-drawer-backdrop{position:absolute;inset:0;background:#000000aa;backdrop-filter:blur(8px)}
.mob-drawer-panel{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(180deg,#150a2eee,#07020fee);
  border-top:1px solid #4a1d9650;
  border-radius:20px 20px 0 0;
  max-height:85vh;overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  animation:slideUp .3s ease;
  padding-bottom:var(--safe-bottom);
}
.mob-drawer-panel::-webkit-scrollbar{display:none}
.mob-drawer-handle{width:36px;height:4px;background:#4a1d9660;border-radius:4px;margin:12px auto 16px}
.mob-drawer-title{font-family:'Cinzel',serif;font-size:13px;font-weight:900;padding:0 18px 14px;border-bottom:1px solid #4a1d9630;margin-bottom:0;display:flex;align-items:center;justify-content:space-between}
.mob-drawer-close{background:none;border:none;color:var(--p4);cursor:pointer;font-size:16px;padding:2px 6px}
.mob-drawer-body{padding:14px 16px;overflow-y:auto;-webkit-overflow-scrolling:touch}
/* Sessions panel in drawer */
.mob-sess-new{width:100%;padding:11px;background:linear-gradient(135deg,#2d106060,#4a1d9440);border:1px dashed #7c3aed50;border-radius:10px;color:var(--p4);font-family:'Cinzel',serif;font-size:10px;letter-spacing:.1em;cursor:pointer;text-transform:uppercase;margin-bottom:12px}
.mob-sess-new:active{opacity:.7}
/* Settings rows in mobile drawer */
.mob-setting-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid #2d106030}
.mob-setting-label{font-family:'Cinzel',serif;font-size:11px;letter-spacing:.08em;color:var(--p4)}
.mob-setting-value{font-size:11px;color:var(--g5);background:#2d106040;padding:4px 12px;border-radius:20px;border:1px solid #4a1d9640;cursor:pointer}
/* Mobile media btns */
.mob-media-btns{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.mob-mqb{width:100%;padding:13px 16px;border-radius:12px;border:none;cursor:pointer;font-family:'Cinzel',serif;font-size:11px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;display:flex;align-items:center;gap:10px;transition:transform .2s}
.mob-mqb:active{transform:scale(.97)}
.mob-mqb.mpm{background:linear-gradient(135deg,#4a1d96,#7c3aed,#a78bfa,#7c3aed,#4a1d96);background-size:200% auto;animation:shimmer 4s linear infinite;color:#f3e8ff}
.mob-mqb.mam{background:linear-gradient(135deg,#0e7490,#06b6d4,#67e8f9,#06b6d4,#0e7490);background-size:200% auto;animation:shimmer 4s linear infinite;color:#ecfeff}
.mob-mqb.mvm{background:var(--gg);background-size:200% auto;animation:shimmer 4s linear infinite;color:#1a0a30}

/* ── Responsive: hide the right UI ── */
body.is-desktop #mobile-app{display:none!important}
body.is-mobile #desktop-app{display:none!important}

*{scrollbar-width:thin;scrollbar-color:#4a1d9650 transparent}

/* ═══════════════════════════════════
   USAGE PANEL
═══════════════════════════════════ */
.usage-panel{display:flex;flex-direction:column;gap:10px;padding:0 10px 14px;flex:1;overflow-y:auto}
.usage-panel::-webkit-scrollbar{width:3px}
.usage-panel::-webkit-scrollbar-thumb{background:#4a1d9660;border-radius:3px}

.usage-metric{background:#0d052288;border:1px solid #4a1d9638;border-radius:12px;padding:11px 13px}
.usage-metric-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.usage-metric-name{font-family:'Cinzel',serif;font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--p4)}
.usage-metric-val{font-family:'Cinzel',serif;font-size:12px;font-weight:900;background:var(--gg);background-size:200% auto;animation:shimmer 4s linear infinite;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.usage-bar-track{height:6px;background:#2d106050;border-radius:6px;overflow:hidden;position:relative}
.usage-bar-fill{height:100%;border-radius:6px;transition:width .8s cubic-bezier(.4,0,.2,1)}
.usage-bar-fill.ram-fill{background:linear-gradient(90deg,#4a1d96,#7c3aed,#a78bfa)}
.usage-bar-fill.cpu-fill{background:linear-gradient(90deg,#0e7490,#06b6d4,#67e8f9)}
.usage-bar-fill.vram-fill{background:linear-gradient(90deg,#78350f,#f59e0b,#fde68a)}
.usage-bar-fill.warn{background:linear-gradient(90deg,#991b1b,#dc2626,#f87171)!important}
.usage-bar-limit{position:absolute;top:0;bottom:0;width:2px;background:#fbbf24;box-shadow:0 0 6px #f59e0b;transition:left .3s ease}
.usage-sub{font-size:10.5px;color:#6d4eaa;margin-top:4px;font-style:italic}
.usage-sub strong{color:var(--g5);font-style:normal}

/* Limit controls */
.limit-section{background:#0d052260;border:1px solid #f59e0b22;border-radius:11px;padding:11px 12px}
.limit-section-title{font-family:'Cinzel',serif;font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--g4);margin-bottom:10px;opacity:.85;display:flex;align-items:center;gap:6px}
.limit-section-title::after{content:'';flex:1;height:1px;background:var(--gg);opacity:.2}
.limit-row{margin-bottom:10px}
.limit-row:last-child{margin-bottom:0}
.limit-row-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}
.limit-label{font-family:'Cinzel',serif;font-size:9.5px;letter-spacing:.1em;color:var(--p4)}
.limit-val-badge{font-family:'Cinzel',serif;font-size:10px;color:var(--g5);background:#f59e0b15;border:1px solid #f59e0b30;padding:1px 8px;border-radius:12px}
.limit-slider{width:100%;-webkit-appearance:none;appearance:none;height:4px;border-radius:4px;background:linear-gradient(90deg,var(--g4),#4a1d96);outline:none;cursor:pointer}
.limit-slider::-webkit-slider-thumb{-webkit-appearance:none;width:13px;height:13px;border-radius:50%;background:var(--g5);box-shadow:0 0 7px #f59e0b88;cursor:pointer}
.limit-note{font-size:10px;color:#4a2d7055;font-style:italic;margin-top:3px}

/* UI exempt badge */
.ui-exempt{display:flex;align-items:center;gap:6px;background:#4ade8012;border:1px solid #4ade8030;border-radius:8px;padding:7px 10px;margin-top:2px}
.ui-exempt-dot{width:6px;height:6px;border-radius:50%;background:#4ade80;box-shadow:0 0 8px #4ade80;animation:pdot 2s infinite;flex-shrink:0}
.ui-exempt-text{font-size:10px;color:#4ade8099;font-family:'Cinzel',serif;letter-spacing:.08em}

/* Throttle warning */
.throttle-warn{background:#dc262614;border:1px solid #dc262640;border-radius:9px;padding:8px 11px;display:none;animation:fadeUp .3s ease}
.throttle-warn.active{display:block}
.throttle-warn-text{font-size:11px;color:#f87171;font-family:'Cinzel',serif;letter-spacing:.06em;display:flex;align-items:center;gap:6px}

/* ═══════════════════════════════════
   TRAINING PANEL
═══════════════════════════════════ */
@keyframes tr-scan{0%{background-position:0% 50%}100%{background-position:200% 50%}}
@keyframes tr-pulse{0%,100%{box-shadow:0 0 0 0 #7c3aed44}50%{box-shadow:0 0 0 6px #7c3aed00}}
@keyframes tr-spin{to{transform:rotate(360deg)}}
@keyframes tr-fadeSlide{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes tr-waveBar{0%,100%{transform:scaleY(.3)}50%{transform:scaleY(1)}}
@keyframes tr-progressPulse{0%{background-position:0% 50%}100%{background-position:200% 50%}}
@keyframes tr-scanLine{0%{transform:translateY(-100%)}100%{transform:translateY(100%)}}

.tr-dropzone{border:2px dashed #4a1d9660;border-radius:14px;background:linear-gradient(135deg,#0d052230,#150a2e20);padding:20px 14px;text-align:center;cursor:pointer;transition:all .25s;position:relative;overflow:hidden;flex-shrink:0}
.tr-dropzone::before{content:'';position:absolute;inset:0;border-radius:inherit;background:linear-gradient(135deg,#7c3aed08,#f59e0b05);pointer-events:none}
.tr-dropzone:hover,.tr-dropzone.drag-over{border-color:var(--g4);background:linear-gradient(135deg,#2d106040,#4a1d9428);box-shadow:0 0 0 3px #f59e0b12,inset 0 0 30px #f59e0b08}
.tr-dropzone.drag-over .tr-dz-icon{transform:scale(1.15);filter:drop-shadow(0 0 12px #f59e0b88)}
.tr-dz-icon{font-size:26px;margin-bottom:6px;transition:transform .25s,filter .25s;display:block}
.tr-dz-title{font-family:'Cinzel',serif;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--g4);margin-bottom:3px}
.tr-dz-sub{font-size:11px;color:#6d4eaa;font-style:italic;line-height:1.5}
.tr-dz-types{display:flex;flex-wrap:wrap;gap:3px;justify-content:center;margin-top:8px}
.tr-type-chip{padding:2px 7px;border-radius:20px;font-family:'Cinzel',serif;font-size:8px;letter-spacing:.08em;font-weight:600;border:1px solid;transition:all .2s}
.tr-type-chip.img{background:#4a1d9420;border-color:#a78bfa50;color:#c4b5fd}
.tr-type-chip.aud{background:#0e749018;border-color:#06b6d450;color:#67e8f9}
.tr-type-chip.vid{background:#2d106038;border-color:#f59e0b40;color:var(--g5)}
.tr-type-chip.txt{background:#16313118;border-color:#34d39940;color:#6ee7b7}
#desk-tr-file-input,#mob-tr-file-input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.tr-stats{display:flex;gap:5px;flex-shrink:0}
.tr-stat{flex:1;background:#0d052280;border:1px solid #4a1d9630;border-radius:10px;padding:6px 5px;text-align:center}
.tr-stat-val{font-family:'Cinzel',serif;font-size:15px;font-weight:900;display:block;line-height:1}
.tr-stat-val.img{background:linear-gradient(135deg,#a78bfa,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.tr-stat-val.aud{background:linear-gradient(135deg,#67e8f9,#06b6d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.tr-stat-val.vid{background:var(--gg);background-size:200% auto;animation:tr-scan 4s linear infinite;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.tr-stat-val.txt{background:linear-gradient(135deg,#6ee7b7,#34d399);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.tr-stat-lb{font-family:'Cinzel',serif;font-size:7px;letter-spacing:.14em;text-transform:uppercase;color:#4a2d7088;margin-top:2px;display:block}
.tr-items-wrap{flex:1;overflow-y:auto;min-height:0;padding-right:2px}
.tr-items-wrap::-webkit-scrollbar{width:3px}
.tr-items-wrap::-webkit-scrollbar-thumb{background:#4a1d9660;border-radius:3px}
.tr-empty{text-align:center;padding:20px 10px;color:#4a2d70;font-style:italic;font-size:11.5px;font-family:'Crimson Pro',serif}
.tr-empty-icon{font-size:26px;display:block;margin-bottom:6px;opacity:.4}
.tr-item{background:#0d052270;border:1px solid #4a1d9630;border-radius:10px;margin-bottom:6px;overflow:hidden;animation:tr-fadeSlide .3s ease;transition:border-color .2s}
.tr-item:hover{border-color:#4a1d9680}
.tr-item.tr-analyzing{border-color:#f59e0b40;animation:tr-fadeSlide .3s ease,tr-pulse 2s ease-in-out infinite}
.tr-item.tr-done{border-color:#22c55e30}
.tr-item.tr-error{border-color:#dc262640}
.tr-item-top{display:flex;align-items:center;gap:7px;padding:7px 9px 5px}
.tr-thumb{width:34px;height:34px;border-radius:7px;flex-shrink:0;overflow:hidden;background:#150a2e;display:flex;align-items:center;justify-content:center;font-size:15px;position:relative}
.tr-thumb canvas,.tr-thumb img{width:100%;height:100%;object-fit:cover;border-radius:inherit}
.tr-thumb-audio{display:flex;align-items:center;justify-content:center;gap:1.5px;height:100%;padding:4px}
.tr-wbar2{width:2.5px;border-radius:2px;background:linear-gradient(to top,#06b6d4,#67e8f9);animation:tr-waveBar .7s ease-in-out infinite}
.tr-thumb-txt{background:linear-gradient(135deg,#1a3a28,#0d2218);display:flex;align-items:center;justify-content:center;font-size:16px}
.tr-item-meta{flex:1;min-width:0}
.tr-item-name{font-size:11.5px;color:var(--text);font-family:'Cinzel',serif;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:.03em}
.tr-item-sub{font-size:10px;color:#6d4eaa;margin-top:1px;display:flex;align-items:center;gap:4px}
.tr-item-size{font-size:9px;color:#4a2d7088;font-family:'Cinzel',serif}
.tr-status-badge{padding:1px 6px;border-radius:12px;font-family:'Cinzel',serif;font-size:7.5px;letter-spacing:.08em;font-weight:600;flex-shrink:0}
.tr-status-badge.analyzing{background:#f59e0b20;border:1px solid #f59e0b50;color:var(--g4)}
.tr-status-badge.done{background:#22c55e18;border:1px solid #22c55e40;color:#4ade80}
.tr-status-badge.error{background:#dc262618;border:1px solid #dc262640;color:#f87171}
.tr-status-badge.pending{background:#4a1d9420;border:1px solid #7c3aed40;color:#a78bfa}
.tr-remove-btn{width:20px;height:20px;border-radius:5px;border:none;background:#2d106040;color:#6d4eaa;cursor:pointer;font-size:10px;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}
.tr-remove-btn:hover{background:#dc262630;color:#f87171}
.tr-item-body{padding:0 9px 8px}
.tr-summary{font-size:11px;color:#8b7aa8;font-style:italic;line-height:1.5;margin-bottom:5px}
.tr-tags{display:flex;flex-wrap:wrap;gap:3px}
.tr-tag{padding:1px 6px;border-radius:12px;font-family:'Cinzel',serif;font-size:7.5px;letter-spacing:.05em;color:#a78bfa;background:#2d106050;border:1px solid #4a1d9640}
.tr-tag.img{color:#c4b5fd;background:#4a1d9428;border-color:#7c3aed40}
.tr-tag.aud{color:#67e8f9;background:#0e749018;border-color:#06b6d430}
.tr-tag.vid{color:var(--g5);background:#2d106038;border-color:#f59e0b30}
.tr-tag.txt{color:#6ee7b7;background:#14312018;border-color:#34d39930}
.tr-progress-bar{height:2px;background:#150a2e;border-radius:1px;margin-top:4px;overflow:hidden;display:none}
.tr-progress-bar.active{display:block}
.tr-progress-fill{height:100%;border-radius:1px;background:linear-gradient(90deg,#f59e0b,#fde68a,#f59e0b);background-size:200% auto;animation:tr-progressPulse 1.5s linear infinite;transition:width .4s ease}
.tr-influence-wrap{background:#0d052260;border:1px solid #f59e0b18;border-radius:11px;padding:10px 11px;flex-shrink:0}
.tr-influence-title{font-family:'Cinzel',serif;font-size:8px;letter-spacing:.22em;text-transform:uppercase;color:var(--g4);margin-bottom:9px;opacity:.85;display:flex;align-items:center;gap:6px}
.tr-influence-title::after{content:'';flex:1;height:1px;background:var(--gg);opacity:.2}
.tr-slider-row{display:flex;align-items:center;gap:6px;margin-bottom:6px}
.tr-slider-row:last-child{margin-bottom:0}
.tr-slider-icon{font-size:11px;flex-shrink:0;width:16px;text-align:center}
.tr-slider-label{font-family:'Cinzel',serif;font-size:8.5px;letter-spacing:.07em;color:var(--p4);flex:1;white-space:nowrap}
.tr-slider-val{font-family:'Cinzel',serif;font-size:9.5px;color:var(--g5);width:26px;text-align:right;flex-shrink:0}
input.tr-range{width:64px;-webkit-appearance:none;appearance:none;height:3px;border-radius:3px;outline:none;cursor:pointer;flex-shrink:0}
input.tr-range.img-range{background:linear-gradient(90deg,#7c3aed,#a78bfa)}
input.tr-range.aud-range{background:linear-gradient(90deg,#0e7490,#06b6d4)}
input.tr-range.vid-range{background:linear-gradient(90deg,#78350f,#f59e0b)}
input.tr-range.txt-range{background:linear-gradient(90deg,#065f46,#34d399)}
input.tr-range::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:10px;border-radius:50%;background:var(--g5);box-shadow:0 0 5px #f59e0b88;cursor:pointer}
.tr-actions{display:flex;gap:5px;flex-shrink:0}
.tr-apply-btn{flex:1;padding:9px;border-radius:9px;border:none;cursor:pointer;font-family:'Cinzel',serif;font-size:9px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;background:linear-gradient(135deg,#4a1d96,#7c3aed,#a78bfa,#7c3aed,#4a1d96);background-size:200% auto;animation:tr-scan 3s linear infinite;color:#f3e8ff;box-shadow:0 4px 14px #7c3aed33;transition:transform .2s,box-shadow .2s}
.tr-apply-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #7c3aed55}
.tr-apply-btn:active{transform:scale(.97)}
.tr-apply-btn:disabled{opacity:.45;cursor:not-allowed;animation:none;background:#2d106060}
.tr-icon-btn{width:34px;height:34px;border-radius:9px;border:1px solid #4a1d9640;background:transparent;color:var(--p4);cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.tr-icon-btn:hover{background:#2d106060;border-color:var(--g4);color:var(--g5)}
.tr-apply-overlay{position:absolute;inset:0;z-index:50;background:#07020fcc;backdrop-filter:blur(12px);display:none;flex-direction:column;align-items:center;justify-content:center;border-radius:inherit;gap:12px}
.tr-apply-overlay.active{display:flex}
.tr-apply-spinner{width:38px;height:38px;border-radius:50%;border:3px solid #2d106060;border-top-color:var(--g4);animation:tr-spin .8s linear infinite;box-shadow:0 0 18px #f59e0b28}
.tr-apply-label{font-family:'Cinzel',serif;font-size:10.5px;letter-spacing:.18em;color:var(--g5);text-transform:uppercase}
.tr-apply-sublabel{font-size:11px;color:#6d4eaa;font-style:italic}
.tr-toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,#150a2eee,#0d0520ee);border:1px solid #7c3aed60;border-radius:12px;padding:9px 16px;font-family:'Cinzel',serif;font-size:10.5px;letter-spacing:.1em;color:var(--g5);z-index:9999;backdrop-filter:blur(20px);box-shadow:0 8px 40px #00000080,0 0 20px #7c3aed22;animation:tr-fadeSlide .3s ease;white-space:nowrap;pointer-events:none}
.tr-toast.success{border-color:#22c55e60;color:#4ade80}
.tr-toast.error{border-color:#dc262660;color:#f87171}
.tr-panel-inner{display:flex;flex-direction:column;gap:9px;padding:0 10px 12px;flex:1;overflow:hidden;position:relative}
.tr-div{height:1px;background:var(--gg);opacity:.15;flex-shrink:0}
.tr-thumb-scan::after{content:'';position:absolute;inset:0;border-radius:inherit;background:linear-gradient(to bottom,transparent,rgba(167,139,250,.4),transparent);animation:tr-scanLine 1s linear infinite;pointer-events:none}

/* ── Plus button ── */
.plus-btn{width:34px;height:34px;border-radius:10px;border:1px solid #4a1d9640;background:#150a2e60;color:var(--p4);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:300;line-height:1;transition:all .2s;flex-shrink:0;backdrop-filter:blur(8px)}
.plus-btn:hover{background:linear-gradient(135deg,#2d106080,#4a1d9440);border-color:var(--g4);color:var(--g5);box-shadow:0 0 12px #f59e0b22}
.plus-btn:active{transform:scale(.92)}

/* ═══════════════════════════════════
   LOADING SCREEN
═══════════════════════════════════ */
@keyframes ls-spin{to{transform:rotate(360deg)}}
@keyframes ls-pulse{0%,100%{opacity:.5;transform:scale(.9)}50%{opacity:1;transform:scale(1)}}
@keyframes ls-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
#loading-screen{
  position:fixed;inset:0;z-index:99999;
  background:var(--void);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;
  transition:opacity .6s ease;
}
#loading-screen.fade-out{opacity:0;pointer-events:none}
.ls-logo{display:flex;flex-direction:column;align-items:center;gap:12px;animation:ls-float 3s ease-in-out infinite}
.ls-star{font-size:48px;background:var(--gg);background-size:200% auto;animation:shimmer 3s linear infinite;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 20px #f59e0b66)}
.ls-title{font-family:'Cinzel',serif;font-size:22px;font-weight:900;letter-spacing:.25em;text-transform:uppercase;background:var(--gg);background-size:200% auto;animation:shimmer 3s linear infinite;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.ls-sub{font-family:'Cinzel',serif;font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:#4a2d70;margin-top:-8px}
.ls-ring{width:56px;height:56px;position:relative}
.ls-ring-track{width:100%;height:100%;border-radius:50%;border:3px solid #2d106050}
.ls-ring-spin{position:absolute;inset:0;border-radius:50%;border:3px solid transparent;border-top-color:var(--g4);border-right-color:var(--g4);animation:ls-spin .9s linear infinite;box-shadow:0 0 18px #f59e0b44}
.ls-steps{display:flex;flex-direction:column;align-items:center;gap:6px;min-height:52px}
.ls-step{font-family:'Cinzel',serif;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:#6d4eaa;transition:color .3s}
.ls-step.active{color:var(--g5)}
.ls-step.done{color:#22c55e}
.ls-step.done::before{content:'✓ '}
.ls-track{width:220px;height:3px;background:#150a2e;border-radius:3px;overflow:hidden}
.ls-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,#7c3aed,var(--g4),#7c3aed);background-size:200% auto;animation:shimmer 1.5s linear infinite;transition:width .4s cubic-bezier(.4,0,.2,1)}

/* ── Text paste box ── */
.tr-text-wrap{display:flex;flex-direction:column;gap:7px}
.tr-text-label{font-family:'Cinzel',serif;font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:#6d4eaa}
.tr-text-area{width:100%;min-height:72px;max-height:180px;resize:vertical;background:#0d0520;border:1px solid #4a1d9650;border-radius:10px;color:#d4b8ff;font-family:inherit;font-size:12px;line-height:1.5;padding:9px 11px;box-sizing:border-box;outline:none;transition:border-color .2s}
.tr-text-area::placeholder{color:#4a2d6080}
.tr-text-area:focus{border-color:#7c3aed80;box-shadow:0 0 0 2px #7c3aed18}
.tr-text-row{display:flex;gap:7px;align-items:flex-end}
.tr-text-row .tr-text-area{flex:1}
.tr-text-name{flex:0 0 110px;background:#0d0520;border:1px solid #4a1d9650;border-radius:8px;color:#a78bfa;font-size:11px;padding:7px 9px;outline:none;box-sizing:border-box}
.tr-text-name::placeholder{color:#4a2d6060}
.tr-text-submit{height:34px;padding:0 14px;border-radius:9px;border:1px solid #7c3aed60;background:linear-gradient(135deg,#2d1060,#4a1d94);color:#d4b8ff;font-family:'Cinzel',serif;font-size:10px;letter-spacing:.1em;cursor:pointer;flex-shrink:0;transition:all .2s;white-space:nowrap}
.tr-text-submit:hover{background:linear-gradient(135deg,#4a1d94,#7c3aed);border-color:var(--g4);color:var(--g5);box-shadow:0 0 12px #7c3aed44}
.tr-text-submit:active{transform:scale(.95)}

/* ── Element Library ── */
.el-library-slot{display:flex;flex-direction:column;gap:8px;min-height:60px}
.el-empty{font-family:'Cinzel',serif;font-size:10px;color:#6d4eaa;text-align:center;padding:18px 12px;line-height:1.7;border:1px dashed #4a1d9640;border-radius:10px}
.el-filter-bar{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:6px}
.el-filter-btn{font-family:'Cinzel',serif;font-size:8px;letter-spacing:.1em;text-transform:uppercase;padding:3px 7px;border-radius:6px;border:1px solid #4a1d9640;background:transparent;color:#6d4eaa;cursor:pointer;transition:all .2s}
.el-filter-btn.active,.el-filter-btn:hover{background:#4a1d9440;color:var(--g5);border-color:var(--g4)}
.el-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:7px}
.el-card{background:#0d052288;border:1px solid #4a1d9630;border-radius:10px;overflow:hidden;cursor:pointer;transition:border-color .2s}
.el-card:hover{border-color:#7c3aed60}
.el-thumb{position:relative;width:100%;padding-bottom:65%;background:#07020f}
.el-cat-badge{position:absolute;top:5px;left:5px;font-family:'Cinzel',serif;font-size:7px;letter-spacing:.08em;text-transform:uppercase;padding:2px 6px;border-radius:4px;border:1px solid;backdrop-filter:blur(4px)}
.el-actions{position:absolute;top:4px;right:4px;display:flex;gap:3px;opacity:0;transition:opacity .2s}
.el-thumb:hover .el-actions{opacity:1}
.el-act-btn{width:20px;height:20px;border-radius:4px;border:1px solid #4a1d9660;background:#07020f99;color:#a78bfa;cursor:pointer;font-size:10px;display:flex;align-items:center;justify-content:center;padding:0}
.el-act-btn:hover{background:#4a1d9480;color:#fff}
.el-act-btn.el-del:hover{background:#991b1b80;border-color:#f87171;color:#f87171}
.el-label{font-family:'Cinzel',serif;font-size:9px;letter-spacing:.08em;color:#c4b5fd;padding:5px 7px 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.el-meta{font-size:9px;color:#6d4eaa;padding:0 7px 6px}
.el-edit-panel{display:none;flex-direction:column;gap:5px;padding:6px 7px 7px;border-top:1px solid #4a1d9630;background:#07020f88}
.el-card.editing .el-edit-panel{display:flex}
.el-card.editing .el-label,.el-card.editing .el-meta{display:none}
.el-edit-input{width:100%;background:#0d0522;border:1px solid #4a1d9660;border-radius:5px;color:#c4b5fd;font-family:'Cinzel',serif;font-size:9px;padding:4px 6px;letter-spacing:.06em;box-sizing:border-box}
.el-edit-input:focus{outline:none;border-color:var(--g4)}
.el-edit-select{width:100%;background:#0d0522;border:1px solid #4a1d9660;border-radius:5px;color:#a78bfa;font-family:'Cinzel',serif;font-size:9px;padding:3px 5px;box-sizing:border-box}
.el-edit-row{display:flex;gap:4px}
.el-edit-save{flex:1;padding:3px 0;border-radius:5px;border:1px solid var(--g4);background:#4a1d9440;color:var(--g5);font-family:'Cinzel',serif;font-size:8px;letter-spacing:.1em;cursor:pointer}
.el-edit-save:hover{background:#4a1d9470}
.el-edit-cancel{padding:3px 7px;border-radius:5px;border:1px solid #4a1d9640;background:transparent;color:#6d4eaa;font-family:'Cinzel',serif;font-size:8px;cursor:pointer}
.el-act-btn.el-edit-btn:hover{background:#1d4ed840;border-color:#60a5fa80;color:#93c5fd}
/* ── Desktop Widget Bar ── */
.desk-panel-wrap{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;position:relative}
.desk-panel-wrap .desk-panel{flex:1;min-height:0}
.desk-nav-divider{width:1px;background:#4a1d9640;margin:4px 2px;flex-shrink:0}
.desk-wgrid-btn{flex:0 0 auto !important;padding:6px 8px !important;gap:2px !important;position:relative}
.wgrid-icon{display:block;opacity:.8;transition:opacity .2s}
.desk-wgrid-btn:hover .wgrid-icon,.desk-wgrid-btn.active .wgrid-icon{opacity:1}
.wgrid-menu{
  overflow-y:auto;
  max-height:80vh;
  scrollbar-width:thin;
  scrollbar-color:#4a1d9660 transparent;
  position:fixed;left:0;bottom:80px;width:274px;
  background:linear-gradient(160deg,#0d0520f4,#07020ff5);
  border:1px solid #4a1d9660;border-top:1px solid #4a1d9660;
  border-radius:0 16px 0 0;
  padding:12px;
  box-shadow:8px -8px 40px #00000090,0 0 0 1px #7c3aed10;
  backdrop-filter:blur(24px);
  display:none;flex-direction:column;gap:10px;
  z-index:300;animation:slideUp .18s ease;
}
.wgrid-menu.open{display:flex}
.wgrid-menu-title{font-family:'Cinzel',serif;font-size:8px;letter-spacing:.22em;text-transform:uppercase;color:#6d4eaa;padding:0 2px 4px;border-bottom:1px solid #4a1d9630}
.wgrid-menu-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.wgrid-card{background:#0d052260;border:1px solid #4a1d9440;border-radius:10px;padding:10px 6px;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;transition:all .2s}
.wgrid-card:hover{background:#2d106060;border-color:#7c3aed60;transform:translateY(-1px)}
.wgrid-card.w-open{background:#4a1d9440;border-color:var(--g4)}
.wgrid-card-icon{font-size:20px;line-height:1}
.wgrid-card-label{font-family:'Cinzel',serif;font-size:8px;letter-spacing:.12em;text-transform:uppercase;color:#a78bfa}
.desk-nav .desk-wbtn{flex:1;padding:7px 4px;border-radius:9px;border:1px solid #4a1d9440;background:transparent;color:#6d4eaa;font-family:'Cinzel',serif;font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:3px}
.desk-nav .desk-wbtn span:first-child{font-size:14px;line-height:1}
.desk-nav .desk-wbtn .wbtn-lb{color:#6d4eaa;font-size:8.5px;letter-spacing:.1em}
.desk-nav .desk-wbtn:hover{background:#2d106050;color:var(--p4)}
.desk-nav .desk-wbtn:hover .wbtn-lb{color:var(--p4)}
.desk-nav .desk-wbtn.w-open{background:#4a1d9440;border-color:var(--g4);color:var(--g5)}
.desk-nav .desk-wbtn.w-open .wbtn-lb{color:var(--g5)}
.desk-wbtn{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:8px 4px;border-radius:10px;border:1px solid #4a1d9440;
  background:transparent;color:#6d4eaa;cursor:pointer;
  font-family:'Cinzel',serif;font-size:7.5px;letter-spacing:.08em;
  text-transform:uppercase;transition:all .2s;
}
.desk-wbtn span:first-child{font-size:16px;line-height:1}
.desk-wbtn .wbtn-lb{color:#6d4eaa}
.desk-wbtn:hover{background:#2d106050;color:var(--p4);border-color:#7c3aed50}
.desk-wbtn:hover .wbtn-lb{color:var(--p4)}
.desk-wbtn.w-open{background:#4a1d9440;border-color:var(--g4);color:var(--g5)}
.desk-wbtn.w-open .wbtn-lb{color:var(--g5)}
/* ── Floating Widget Panels ── */
.desk-widget{
  position:fixed;
  left:274px;bottom:0;
  width:340px;
  max-height:calc(100vh - 60px);
  background:linear-gradient(160deg,#0d0520f0,#07020ff2);
  border:1px solid #4a1d9660;
  border-bottom:none;
  border-radius:16px 16px 0 0;
  box-shadow:8px 0 40px #00000080,0 0 0 1px #7c3aed10;
  backdrop-filter:blur(24px);
  display:none;flex-direction:column;
  z-index:200;
  animation:slideUp .22s cubic-bezier(.22,1,.36,1);
  transform-origin:bottom left;
}
.desk-widget.w-open{display:flex}

/* ── Overlay widget full reset (overrides .desk-widget inheritance) ── */
/* Studio: full-screen fullscreen, separate from sidebar widgets */
#widget-mag-studio {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  max-height: 100vh !important;
  min-height: 0 !important;
  border-radius: 0 !important;
  border: none !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  z-index: 600 !important;
  background: #03000d !important;
  overflow: hidden !important;
}
#widget-mag-studio.w-open { display: flex !important; flex-direction: column !important; }

#widget-mag-3d,
#widget-mag-viewer,
#widget-mag-code,
#widget-magplay,
#widget-mag-audio {
  position: fixed !important;
  top: 0 !important;
  bottom: 0 !important;
  left: 274px !important;
  right: 0 !important;
  width: calc(100vw - 274px) !important;
  height: 100vh !important;
  max-height: 100vh !important;
  min-height: 0 !important;
  border-radius: 0 !important;
  border-bottom: 1px solid #4a1d9660 !important;
  border-top: none !important;
  z-index: 300;
  display: none;
  flex-direction: column;
  overflow: hidden;
  animation: fadeIn .18s ease;
}
#widget-mag-3d.w-open,
#widget-mag-viewer.w-open,
#widget-mag-code.w-open,
#widget-magplay.w-open,
#widget-mag-audio.w-open { display: flex !important; }

body.is-mobile #widget-mag-3d,
body.is-mobile #widget-mag-viewer,
body.is-mobile #widget-mag-code,
body.is-mobile #widget-magplay,
body.is-mobile #widget-mag-audio {
  left: 0 !important;
  width: 100vw !important;
  right: 0 !important;
  top: 0 !important;
  bottom: 0 !important;
  height: 100vh !important;
  max-height: 100vh !important;
  border-radius: 0 !important;
  z-index: 500;
}

.desk-widget-hdr{
  display:flex;align-items:center;justify-content:space-between;
  padding:13px 16px 10px;
  border-bottom:1px solid #4a1d9630;
  flex-shrink:0;
}
.desk-widget-title{
  font-family:'Cinzel',serif;font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--g5);font-weight:700;
}
.desk-widget-close{
  background:transparent;border:1px solid #4a1d9640;border-radius:7px;
  color:#6d4eaa;width:22px;height:22px;cursor:pointer;font-size:12px;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;
}
.desk-widget-close:hover{background:#ef444420;border-color:#ef444460;color:#f87171}
.desk-widget-body{
  overflow-y:auto;padding:12px 14px 16px;
  flex:1;display:flex;flex-direction:column;gap:8px;
}
.desk-widget-body::-webkit-scrollbar{width:3px}
.desk-widget-body::-webkit-scrollbar-thumb{background:#4a1d9650;border-radius:3px}
/* Stack widgets side by side if multiple open */
/* Widget stacking handled by openWidget() JS */


.vpg-card{background:#0d052288;border:1px solid #4a1d9630;border-radius:12px;padding:9px 10px;cursor:pointer;transition:border-color .2s;margin-bottom:6px}
.vpg-card:hover{border-color:#7c3aed50}
.vpg-card.vpg-active{border-color:var(--g4);background:#2d106040}
.vpg-header{display:flex;align-items:center;gap:6px;margin-bottom:8px}
.vpg-name{font-family:'Cinzel',serif;font-size:10px;font-weight:700;color:#c4b5fd;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vpg-filled{font-size:9px;color:#6d4eaa;white-space:nowrap}
.vpg-acts{display:flex;gap:3px;flex-shrink:0}
.vpg-slots{display:grid;grid-template-columns:repeat(3,1fr);gap:5px}
.vpg-slot{background:#07020f80;border:1px dashed #4a1d9640;border-radius:8px;padding:5px 4px;display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;transition:all .2s;min-height:42px;justify-content:center}
.vpg-slot:hover{border-color:#7c3aed60;background:#2d106040}
.vpg-slot-filled{border-style:solid;border-color:#7c3aed50;background:#2d106030}
.vpg-slot-icon{font-size:13px;line-height:1}
.vpg-slot-f0{font-size:8px;color:#6d4eaa;font-family:'Cinzel',serif;letter-spacing:.05em}
.vpg-slot-filled .vpg-slot-f0{color:#a78bfa}
.vpg-slot-type-badge{font-family:'Cinzel',serif;font-size:8px;letter-spacing:.08em;color:#a78bfa;background:#2d106040;border:1px solid #7c3aed40;border-radius:6px;padding:4px 8px;white-space:nowrap;flex-shrink:0}
/* ── Pitch Timeline ── */
.ptl-wrap{display:flex;flex-direction:column;gap:5px}
.ptl-canvas{width:100%;height:80px;border-radius:10px;border:1px solid #4a1d9640;cursor:crosshair;touch-action:none;display:block}
.ptl-canvas:hover{border-color:#7c3aed60}
.ptl-presets{display:flex;flex-wrap:wrap;gap:4px}
.ptl-btn{font-family:'Cinzel',serif;font-size:8px;letter-spacing:.06em;padding:3px 7px;border-radius:6px;border:1px solid #4a1d9640;background:transparent;color:#6d4eaa;cursor:pointer;transition:all .2s;white-space:nowrap}
.ptl-btn:hover{background:#4a1d9440;color:var(--g5);border-color:#7c3aed60}
.ptl-btn:active{transform:scale(.95)}
.voice-phrase-box{background:#07020f80;border:1px solid #7c3aed40;border-radius:11px;padding:11px 13px;display:flex;flex-direction:column;gap:5px}
.voice-phrase-title{font-family:'Cinzel',serif;font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:#a78bfa;font-weight:700}
.voice-phrase-text{font-size:11px;color:#e2d9ff;line-height:1.6;font-style:italic;border-left:2px solid #7c3aed60;padding-left:8px;margin:2px 0}
.voice-phrase-hint{font-size:9px;color:#6d4eaa;line-height:1.5}
.voice-phrase-copy{align-self:flex-start;background:transparent;border:1px solid #4a1d9650;border-radius:6px;color:#6d4eaa;font-size:9px;padding:3px 8px;cursor:pointer;font-family:'Cinzel',serif;letter-spacing:.08em;transition:all .2s}
.voice-phrase-copy:hover{border-color:#7c3aed80;color:#a78bfa}
/* ── TTS / Voice Clone ── */
.tts-panel{display:flex;flex-direction:column;gap:10px}
.tts-voice-slot{display:flex;flex-direction:column;gap:6px;max-height:200px;overflow-y:auto}
.vp-card{display:flex;align-items:center;gap:8px;padding:7px 9px;background:#0d052288;border:1px solid #4a1d9630;border-radius:10px;cursor:pointer;transition:border-color .2s}
.vp-card:hover{border-color:#7c3aed60}
.vp-card.vp-active{border-color:var(--g4);background:#2d106040}
.vp-wave{width:70px;height:30px;flex-shrink:0;border-radius:6px;border:1px solid #4a1d9640}
.vp-info{flex:1;min-width:0}
.vp-name{font-family:'Cinzel',serif;font-size:10px;font-weight:700;color:#c4b5fd;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vp-meta{font-size:9px;color:#6d4eaa;margin-top:2px}
.vp-acts{display:flex;flex-direction:column;gap:3px;flex-shrink:0}
.tts-upload-zone{border:1px dashed #7c3aed50;border-radius:10px;padding:12px;text-align:center;cursor:pointer;transition:all .2s;background:#07020f40}
.tts-upload-zone:hover,.tts-upload-zone.drag-over{border-color:var(--g4);background:#2d106040}
.tts-upload-icon{font-size:20px;margin-bottom:4px}
.tts-upload-label{font-family:'Cinzel',serif;font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:#6d4eaa}
.tts-upload-sub{font-size:9px;color:#4a2d70;margin-top:2px}
.tts-textarea{width:100%;min-height:68px;resize:vertical;background:#0d0520;border:1px solid #4a1d9650;border-radius:10px;color:#d4b8fd;padding:9px 11px;font-size:11px;font-family:inherit;box-sizing:border-box}
.tts-textarea:focus{outline:none;border-color:#7c3aed80;box-shadow:0 0 0 2px #7c3aed20}
.tts-controls{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.tts-select{background:#0d0520;border:1px solid #4a1d9650;border-radius:8px;color:#a78bfa;padding:5px 8px;font-family:'Cinzel',serif;font-size:9px;letter-spacing:.08em;cursor:pointer;flex:1;min-width:80px}
.tts-speak-btn{padding:7px 14px;border-radius:9px;border:1px solid #7c3aed60;background:linear-gradient(135deg,#2d1060,#4a1d94);color:#d4b8ff;font-family:'Cinzel',serif;font-size:10px;letter-spacing:.1em;cursor:pointer;transition:all .2s;white-space:nowrap}
.tts-speak-btn:hover{background:linear-gradient(135deg,#4a1d94,#7c3aed);border-color:var(--g4);box-shadow:0 0 12px #7c3aed40}
.tts-speak-btn:active{transform:scale(.96)}
.tts-result{margin-top:4px;display:none}
.tts-result.visible{display:block}
.tts-progress{width:100%;height:2px;background:#4a1d9640;border-radius:2px;overflow:hidden;margin-bottom:6px}
.tts-progress-bar{height:100%;background:var(--gg);background-size:200% auto;animation:shimmer 2s linear infinite;width:0%;transition:width .4s}
.tts-audio-wrap{background:#0d052280;border:1px solid #4a1d9638;border-radius:10px;padding:10px 12px;display:flex;align-items:center;gap:10px}
.tts-audio-wave{display:flex;align-items:center;gap:2px;height:28px;flex:1}
.tts-audio-bar{width:2px;background:var(--gg);background-size:200% auto;animation:shimmer 3s linear infinite;border-radius:2px}
/* ── Device spec card ── */
.dev-card{background:#0d052288;border:1px solid #4a1d9638;border-radius:12px;padding:12px 13px;margin-bottom:2px}
.dev-card-name{font-family:'Cinzel',serif;font-size:11px;font-weight:700;color:var(--g5);margin-bottom:8px;line-height:1.3}
.dev-card-grid{display:flex;flex-direction:column;gap:3px}
.dev-card-row{display:flex;justify-content:space-between;align-items:baseline;gap:4px}
.dev-lbl{font-family:'Cinzel',serif;font-size:8.5px;letter-spacing:.12em;text-transform:uppercase;color:#6d4eaa;flex-shrink:0}
.dev-val{font-size:10px;color:#c4b5fd;text-align:right;word-break:break-all}
.dev-tier-row{display:flex;justify-content:space-between;align-items:center;margin-top:8px;padding-top:7px;border-top:1px solid #4a1d9630}
.dev-tier-lbl{font-family:'Cinzel',serif;font-size:8.5px;letter-spacing:.12em;text-transform:uppercase;color:#6d4eaa}
.dev-tier-badge{font-family:'Cinzel',serif;font-size:10px;font-weight:700;border:1px solid;border-radius:6px;padding:2px 8px;letter-spacing:.08em}
.dev-card-slot{margin-bottom:4px}

/* ── Sparkline graph ── */
.usage-graph{width:100%;height:36px;display:block;border-radius:6px;background:#07020f60;margin-top:4px}
.usage-graph-row{display:flex;gap:8px;margin:8px 0 4px}
.usage-graph-panel{flex:1;background:#07020f60;border-radius:8px;padding:5px 7px;border:1px solid #4a1d9628}
.usage-graph-label{font-family:'Cinzel',serif;font-size:7.5px;letter-spacing:.14em;text-transform:uppercase;color:#6d4eaa;margin-bottom:3px}
/* ══ SPLIT AI PIPELINE ══════════════════════════════════════════════ */
.sai-card{background:linear-gradient(160deg,#07020f 0%,#0d052299 100%);border:1px solid #4a1d9650;border-radius:16px;overflow:hidden;font-family:'Cinzel',serif;width:100%;box-sizing:border-box;box-shadow:0 8px 40px #00000060}
.sai-hdr{display:flex;align-items:center;gap:10px;padding:11px 15px 9px;border-bottom:1px solid #4a1d9628;background:linear-gradient(90deg,#4a1d9410,transparent)}
.sai-hdr-icon{font-size:18px;filter:drop-shadow(0 0 6px #a78bfa80)}
.sai-hdr-title{font-size:10px;letter-spacing:.22em;color:var(--g5);flex:1;text-transform:uppercase}
.sai-hdr-prompt{font-size:8.5px;color:#6d4eaa;letter-spacing:.06em;max-width:160px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sai-pipeline{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-bottom:1px solid #4a1d9620}
.sai-agent{padding:9px 5px 8px;display:flex;flex-direction:column;align-items:center;gap:3px;border-right:1px solid #4a1d9618;transition:background .35s,box-shadow .35s;position:relative;cursor:default;min-width:0}
.sai-agent:last-child{border-right:none}
.sai-agent-icon{font-size:18px;line-height:1;transition:transform .3s,filter .3s}
.sai-agent.running .sai-agent-icon{animation:sai-pulse 1.2s ease-in-out infinite;filter:drop-shadow(0 0 8px currentColor)}
.sai-agent-name{font-size:6.5px;letter-spacing:.1em;text-transform:uppercase;color:#4a2d70;text-align:center;transition:color .3s;white-space:nowrap;overflow:hidden;width:100%;text-overflow:ellipsis;padding:0 2px}
.sai-agent.running .sai-agent-name{color:var(--agent-color,#a78bfa)}
.sai-agent.done .sai-agent-name{color:#34d399}
.sai-agent.error .sai-agent-name{color:#f87171}
.sai-agent-badge{font-size:6px;letter-spacing:.06em;color:#2d1060;text-align:center;transition:color .3s;white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis;padding:0 2px}
.sai-agent.running .sai-agent-badge{color:var(--agent-color,#a78bfa)}
.sai-agent.done .sai-agent-badge{color:#34d39988}
.sai-pip{width:4px;height:4px;border-radius:50%;background:#1a0a2e;margin-top:2px;transition:background .3s,box-shadow .3s}
.sai-agent.running .sai-pip{box-shadow:0 0 6px var(--agent-color,#a78bfa)}
.sai-agent.done .sai-pip{background:#34d399;box-shadow:0 0 4px #34d39980}
.sai-agent.error .sai-pip{background:#f87171}
.sai-flow{display:flex;flex-direction:column;gap:0}
.sai-log{max-height:110px;overflow-y:auto;padding:7px 13px;border-bottom:1px solid #4a1d9618;scrollbar-width:thin;scrollbar-color:#4a1d9640 transparent}
.sai-log-entry{display:flex;gap:7px;align-items:flex-start;padding:3px 0;border-bottom:1px solid #4a1d9610;animation:sai-fadein .3s ease}
.sai-log-entry:last-child{border-bottom:none}
.sai-log-icon{font-size:10px;flex-shrink:0;margin-top:1px}
.sai-log-agent{font-size:7px;letter-spacing:.1em;text-transform:uppercase;flex-shrink:0;padding-top:1px;min-width:52px}
.sai-log-text{font-size:9px;color:#8b7ab8;line-height:1.45;flex:1;font-family:inherit}
.sai-status-bar{padding:7px 13px;font-size:8.5px;color:#6d4eaa;letter-spacing:.07em;line-height:1.5;background:linear-gradient(90deg,#4a1d9408,transparent);min-height:28px;display:flex;align-items:center;gap:7px}
.sai-status-dot{width:5px;height:5px;border-radius:50%;background:#4a1d9480;flex-shrink:0;animation:sai-blink 1.1s ease infinite}
.sai-status-bar.done-bar{color:#34d39988}
.sai-status-bar.done-bar .sai-status-dot{background:#34d399;animation:none;box-shadow:0 0 5px #34d39980}
@keyframes sai-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}
@keyframes sai-fadein{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
@keyframes sai-blink{0%,100%{opacity:.4}50%{opacity:1}}

/* ══ MAGICIUM IMAGE EDITOR ══════════════════════════════════════════ */
#widget-magicium{
  position:fixed;left:274px;top:0;
  width:calc(100vw - 274px);height:100vh;
  max-height:100vh;
  border-radius:0;border-bottom:none;border-top:none;border-right:none;
  z-index:300;
  animation:fadeIn .18s ease;
}
body.is-mobile #widget-magicium{left:0;width:100vw;height:100vh}
.mag-tabs{display:flex;gap:0;border-bottom:1px solid #4a1d9630;flex-shrink:0;background:#07020f80}
.mag-tab{flex:1;padding:9px 6px;border:none;background:transparent;color:#6d4eaa;font-family:'Cinzel',serif;font-size:9px;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:3px}
.mag-tab .mt-icon{font-size:16px;line-height:1}
.mag-tab:hover{color:#a78bfa;background:#4a1d9410}
.mag-tab.active{color:var(--g5);border-bottom-color:var(--g4);background:#4a1d9418}
.mag-pane{display:none;flex:1;overflow:hidden}
.mag-pane.active{display:flex}

/* ── Shared editor layout ── */
.mag-editor{display:flex;flex:1;overflow:hidden;gap:0}
.mag-toolbar{width:42px;background:#07020fcc;border-right:1px solid #4a1d9628;display:flex;flex-direction:column;align-items:center;padding:6px 0;gap:2px;flex-shrink:0}
.mag-tool-btn{width:32px;height:32px;border-radius:8px;border:1px solid transparent;background:transparent;color:#6d4eaa;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .18s;position:relative}
.mag-tool-btn:hover{background:#4a1d9430;color:#a78bfa;border-color:#7c3aed40}
.mag-tool-btn.active{background:#4a1d9450;border-color:var(--g4);color:var(--g5)}
.mag-tool-btn[title]:hover::after{content:attr(title);position:absolute;left:38px;top:50%;transform:translateY(-50%);background:#0d0520ee;border:1px solid #4a1d9660;border-radius:6px;padding:3px 8px;font-family:'Cinzel',serif;font-size:8px;letter-spacing:.08em;white-space:nowrap;color:#c4b5fd;z-index:999;pointer-events:none}
.mag-tool-div{width:24px;height:1px;background:#4a1d9630;margin:3px 0}
.mag-canvas-area{flex:1;overflow:hidden;position:relative;background:repeating-conic-gradient(#0d052220 0% 25%,transparent 0% 50%) 0 0/20px 20px}
.mag-canvas-wrap{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;overflow:auto}
.mag-canvas{border:1px solid #4a1d9640;box-shadow:0 0 40px #00000080;cursor:crosshair;display:block;max-width:100%;max-height:100%}
.mag-sidebar{width:200px;background:#07020fcc;border-left:1px solid #4a1d9628;overflow-y:auto;flex-shrink:0;display:flex;flex-direction:column}
.mag-sidebar::-webkit-scrollbar{width:3px}
.mag-sidebar::-webkit-scrollbar-thumb{background:#4a1d9650;border-radius:3px}
.mag-section{border-bottom:1px solid #4a1d9620;padding:8px 10px;display:flex;flex-direction:column;gap:5px}
.mag-section-title{font-family:'Cinzel',serif;font-size:7.5px;letter-spacing:.18em;text-transform:uppercase;color:#6d4eaa}
.mag-row{display:flex;align-items:center;gap:6px}
.mag-label{font-size:9px;color:#8b7ab8;flex-shrink:0;min-width:44px}
.mag-input{background:#0d0520;border:1px solid #4a1d9650;border-radius:6px;color:#d4b8fd;padding:4px 6px;font-size:9px;width:100%;font-family:inherit;box-sizing:border-box}
.mag-input:focus{outline:none;border-color:#7c3aed80}
.mag-color-row{display:flex;align-items:center;gap:6px}
.mag-color-swatch{width:26px;height:26px;border-radius:6px;border:1px solid #4a1d9660;cursor:pointer;flex-shrink:0;position:relative;overflow:hidden}
.mag-color-swatch input[type=color]{position:absolute;inset:-4px;opacity:0;cursor:pointer;width:calc(100%+8px);height:calc(100%+8px)}
.mag-btn{padding:5px 10px;border-radius:7px;border:1px solid #4a1d9650;background:#0d052260;color:#a78bfa;font-family:'Cinzel',serif;font-size:8px;letter-spacing:.08em;cursor:pointer;transition:all .18s;width:100%;text-align:center}
.mag-btn:hover{background:#4a1d9440;border-color:#7c3aed80;color:#c4b5fd}
.mag-btn.primary{background:linear-gradient(135deg,#4a1d94,#7c3aed);border-color:#a78bfa40;color:#f3e8ff}
.mag-btn.primary:hover{background:linear-gradient(135deg,#6d28d9,#9d4edd);box-shadow:0 0 12px #7c3aed40}
.mag-btn.danger{border-color:#ef444450;color:#f87171}
.mag-btn.danger:hover{background:#ef444420}
.mag-statusbar{height:22px;background:#07020f;border-top:1px solid #4a1d9620;display:flex;align-items:center;padding:0 10px;gap:12px;flex-shrink:0}
.mag-stat{font-size:8px;color:#4a2d70;font-family:'Cinzel',serif;letter-spacing:.06em}
.mag-stat span{color:#8b7ab8}

/* ── Generate pane (merged image gen + elements) ── */
.mag-gen-pane{display:flex;flex-direction:column;gap:0;overflow:hidden;flex:1}
.mag-gen-top{display:grid;grid-template-columns:1fr 1fr;gap:0;flex:1;overflow:hidden}
.mag-gen-left{border-right:1px solid #4a1d9620;padding:12px;overflow-y:auto;display:flex;flex-direction:column;gap:8px}
.mag-gen-right{padding:10px;overflow-y:auto;display:flex;flex-direction:column;gap:6px}
.mag-gen-right-title{font-family:'Cinzel',serif;font-size:8px;letter-spacing:.16em;text-transform:uppercase;color:#6d4eaa}
.mag-gen-canvas-wrap{width:100%;aspect-ratio:16/9;background:#07020f;border-radius:10px;overflow:hidden;border:1px solid #4a1d9640;position:relative}
.mag-gen-canvas-wrap canvas{width:100%;height:100%;display:block}
.mag-gen-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:#4a2d70}
.mag-gen-placeholder-icon{font-size:32px;opacity:.4}
.mag-gen-placeholder-text{font-family:'Cinzel',serif;font-size:9px;letter-spacing:.1em;opacity:.5}

/* ── Layer panel ── */
.mag-layers{display:flex;flex-direction:column;gap:2px}
.mag-layer{display:flex;align-items:center;gap:6px;padding:4px 6px;border-radius:6px;border:1px solid transparent;cursor:pointer;transition:all .15s}
.mag-layer:hover{background:#4a1d9420;border-color:#4a1d9640}
.mag-layer.selected{background:#4a1d9440;border-color:#7c3aed60}
.mag-layer-icon{font-size:11px;flex-shrink:0}
.mag-layer-name{font-size:9px;color:#a78bfa;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mag-layer-vis{font-size:10px;color:#6d4eaa;cursor:pointer;flex-shrink:0}

/* ── Colour palette ── */
.mag-palette{display:flex;flex-wrap:wrap;gap:4px}
.mag-swatch{width:20px;height:20px;border-radius:4px;border:1px solid #00000040;cursor:pointer;transition:transform .15s;flex-shrink:0}
.mag-swatch:hover{transform:scale(1.2);z-index:1}
.mag-swatch.active{outline:2px solid var(--g4);outline-offset:1px}

/* ── Vector node handles ── */
.mag-node{position:absolute;width:8px;height:8px;border-radius:50%;background:#f59e0b;border:1.5px solid #fff;cursor:move;transform:translate(-50%,-50%);z-index:10}
.mag-seg{position:absolute;height:1.5px;background:#f59e0b80;transform-origin:left center;pointer-events:none}

/* ── Element grid inside magicium ── */
.mag-el-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:5px}
.mag-el-card{background:#0d052260;border:1px solid #4a1d9440;border-radius:7px;overflow:hidden;cursor:pointer;transition:all .18s;position:relative}
.mag-el-card:hover{border-color:#7c3aed70;background:#2d106040}
.mag-el-card.selected{border-color:var(--g4);background:#4a1d9440}
.mag-el-card img{width:100%;aspect-ratio:1;object-fit:cover;display:block}
.mag-el-label{font-size:7px;font-family:'Cinzel',serif;letter-spacing:.06em;color:#6d4eaa;padding:2px 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mag-el-badge{position:absolute;top:2px;right:2px;font-size:7px;padding:1px 4px;border-radius:4px;font-family:'Cinzel',serif;background:#0d052299}

/* ── Mag Create vector objects ── */
.mag-obj-list{display:flex;flex-direction:column;gap:3px;max-height:160px;overflow-y:auto}
.mag-obj-item{display:flex;align-items:center;gap:5px;padding:3px 5px;border-radius:5px;font-size:9px;color:#8b7ab8;cursor:pointer;border:1px solid transparent}
.mag-obj-item:hover{background:#4a1d9420;border-color:#4a1d9640}
.mag-obj-item.selected{background:#4a1d9440;border-color:#7c3aed60;color:#c4b5fd}
.mag-obj-icon{font-size:11px;flex-shrink:0}

/* Mag toolbar label */
.mag-tool-label{font-family:'Cinzel',serif;font-size:6px;letter-spacing:.12em;text-transform:uppercase;color:#4a2d70;padding:2px 0 1px;text-align:center;width:100%;margin-top:2px}
.mag-toolbar::-webkit-scrollbar{width:2px}
.mag-toolbar::-webkit-scrollbar-thumb{background:#4a1d9640;border-radius:2px}
/* Magicium overlay dims content behind */
#widget-magicium.w-open ~ #desktop-main, body.mag-open #desk-messages{pointer-events:none}

/* ── Mobile Magicium Editor ──────────────────────────────── */
.mob-mag-tab{background:transparent;border:none;color:#6d4eaa;font-size:16px;padding:5px 10px;cursor:pointer;border-radius:6px;transition:all .15s}
.mob-mag-tab.active{background:#4a1d9450;color:#f3e8ff}
.mob-mpane{display:none;flex-direction:column;overflow:hidden}
.mob-mpane.active{display:flex}
.mob-mtool{min-width:36px;height:36px;border-radius:8px;border:1px solid #4a1d9428;background:transparent;color:#6d4eaa;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;padding:0 4px}
.mob-mtool.active{background:#4a1d9450;border-color:var(--g4);color:var(--g5)}
.mob-mtool:active{background:#4a1d9430;transform:scale(.92)}
.mob-mtool-sep{width:1px;height:28px;background:#4a1d9430;flex-shrink:0;margin:4px 2px;align-self:center}
.mob-mag-action-btn{background:#0d0520;border:1px solid #4a1d9440;border-radius:8px;color:#a78bfa;font-family:'Cinzel',serif;font-size:8.5px;letter-spacing:.06em;padding:7px 6px;cursor:pointer;text-align:center;transition:all .15s;white-space:nowrap}
.mob-mag-action-btn:active{background:#4a1d9430;transform:scale(.95)}
#mob-mag-editor.open{display:flex!important}
/* hide desktop scroll on mobile tools */
#mob-mac-tools::-webkit-scrollbar,#mob-mad-tools::-webkit-scrollbar{display:none}
#mob-mac-tools,#mob-mad-tools{scrollbar-width:none}

/* Toggle switch */
.toggle-sw{position:relative;display:inline-block;width:34px;height:18px;flex-shrink:0}
.toggle-sw input{opacity:0;width:0;height:0}
.toggle-track{position:absolute;inset:0;background:#1a0a3a;border:1px solid #4a1d9640;border-radius:18px;cursor:pointer;transition:.2s}
.toggle-track::before{content:'';position:absolute;width:12px;height:12px;left:2px;top:2px;background:#4a1d94;border-radius:50%;transition:.2s}
.toggle-sw input:checked + .toggle-track{background:#4a1d9460;border-color:#a78bfa60}
.toggle-sw input:checked + .toggle-track::before{transform:translateX(16px);background:var(--g5)}

/* Audio Library */
.audlib-item{background:#150a2e88;border:1px solid #4a1d9630;border-radius:9px;padding:8px 10px;margin-bottom:6px;cursor:pointer;transition:all .18s}
.audlib-item:hover{background:#1e0a40cc;border-color:#4a1d9660}
.audlib-item-name{font-family:'Cinzel',serif;font-size:9.5px;color:#c4b5fd;letter-spacing:.06em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.audlib-item-meta{font-size:8px;color:#4a2d70;margin-top:2px;display:flex;gap:8px;align-items:center}
.audlib-item-dur{color:#6d4eaa}
.audlib-tag{background:#4a1d9430;border-radius:4px;padding:1px 5px;color:#7c4da0;font-size:7.5px}
.audlib-item-btns{display:flex;gap:4px;margin-top:6px}
.audlib-btn{background:transparent;border:1px solid #4a1d9440;border-radius:5px;color:#6d4eaa;font-size:8px;padding:2px 7px;cursor:pointer;font-family:'Cinzel',serif;transition:all .15s}
.audlib-btn:hover{background:#4a1d9430;color:#a78bfa}
.audlib-btn.danger:hover{background:#7f1d1d40;color:#f87171;border-color:#f8717160}
.audlib-wave{display:flex;align-items:center;gap:1px;height:20px;margin:4px 0}
.audlib-wbar{width:2px;background:#4a1d9460;border-radius:1px;transition:background .15s}
.audlib-item.playing .audlib-wbar{background:#a78bfa;animation:wbar-play .8s ease-in-out infinite alternate}
@keyframes wbar-play{from{transform:scaleY(.5)}to{transform:scaleY(1.2)}}

/* Mag Audio Studio widget */
border-radius:0;border-bottom:none;border-top:none;border-right:none;
  z-index:300;animation:fadeIn .18s ease;
  display:flex;flex-direction:column;overflow:hidden;
}
body.is-mobile 

/* 3D Viewer / Code / MagPlay widgets */
#widget-mag-viewer,#widget-mag-code,#widget-magplay{
  position:fixed;left:274px;top:0;width:calc(100vw - 274px);height:100vh;max-height:100vh;
  z-index:300;animation:fadeIn .18s ease;display:flex;flex-direction:column;overflow:hidden;
}
body.is-mobile #widget-mag-viewer,body.is-mobile #widget-mag-code,body.is-mobile #widget-magplay{left:0;width:100vw}
#widget-mag-viewer.w-open,#widget-mag-code.w-open,#widget-magplay.w-open{display:flex!important}
.code-tab{background:#0d0520;border:1px solid #4a1d9628;border-bottom:none;padding:4px 10px;font-family:'Cinzel',serif;font-size:9px;color:#6d4eaa;cursor:pointer;white-space:nowrap;display:flex;align-items:center;gap:6px;transition:all .15s}
.code-tab.active{background:#07020f;color:#c4b5fd;border-bottom-color:#07020f}
.code-tab .code-tab-close{opacity:.4;font-size:9px;margin-left:4px;cursor:pointer;border:none;background:none;color:inherit;padding:0}
.code-tab .code-tab-close:hover{opacity:1;color:#f87171}
.mp-obj{padding:4px 10px;font-family:'Cinzel',serif;font-size:9px;color:#6d4eaa;cursor:pointer;display:flex;align-items:center;gap:5px;border-radius:4px;margin:0 3px;transition:background .12s}
.mp-obj:hover{background:#4a1d9420}
.mp-obj.selected{background:#4a1d9440;color:#c4b5fd}
.mp-asset{width:60px;height:60px;background:#0d052060;border:1px solid #4a1d9430;border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer;flex-shrink:0;transition:all .15s}
.mp-asset:hover{background:#4a1d9430;border-color:#7c3aed60}
.mp-asset-icon{font-size:20px}
.mp-asset-name{font-family:'Cinzel',serif;font-size:7px;color:#6d4eaa;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:56px}



/* ── Mobile full-screen widget overrides ──────────────────────────── */
body.is-mobile .desk-widget {
  left: 0!important;
  width: 100vw!important;
  max-width: 100vw!important;
  right: 0!important;
}
/* These open as bottom sheets on mobile */
body.is-mobile #widget-training,
body.is-mobile #widget-usage {
  bottom: 0; top: auto;
  height: 90vh; max-height: 90vh!important;
  border-radius: 20px 20px 0 0;
}
/* These open as full-screen overlays on mobile */
body.is-mobile #widget-magicium,
body.is-mobile #widget-mag-audio,
body.is-mobile #widget-mag-3d,
body.is-mobile #widget-mag-viewer,
body.is-mobile #widget-mag-code,
body.is-mobile #widget-magplay {
  top: 0!important; bottom: 0!important;
  height: 100vh!important; max-height: 100vh!important;
  border-radius: 0!important;
}

/* Body-level overlay widgets on mobile */
body.is-mobile 

/* MagPlay engine menu */
.mp-engine-group { border-bottom: 1px solid #4a1d9620; padding: 3px 0; }
.mp-engine-hdr { padding: 4px 12px 2px; font-family:'Cinzel',serif; font-size:7.5px; color:#4a2d70; letter-spacing:.1em; }
.mp-engine-item { padding: 5px 18px; font-family:'Cinzel',serif; font-size:9px; color:#a78bfa; cursor:pointer; transition:background .12s; }
.mp-engine-item:hover { background:#4a1d9430; color:#c4b5fd; }

/* Mag Code menus */
.magcode-menu { display:none; position:absolute; top:100%; left:0; z-index:700; background:#0d0520; border:1px solid #4a1d9640; border-radius:8px; min-width:220px; margin-top:2px; box-shadow:0 8px 24px #000c; padding:4px 0; }
.magcode-menu.open { display:block; }
.magcode-menu-item { padding:5px 14px; font-family:'Cinzel',serif; font-size:9px; color:#a78bfa; cursor:pointer; display:flex; justify-content:space-between; align-items:center; transition:background .12s; }
.magcode-menu-item:hover { background:#4a1d9430; color:#c4b5fd; }
.magcode-shortcut { font-size:7.5px; color:#4a2d70; margin-left:16px; }
.magcode-menu-div { height:1px; background:#4a1d9628; margin:3px 0; }

/* Autocomplete dropdown */
#code-autocomplete { position:absolute; z-index:800; background:#0d0520; border:1px solid #4a1d9640; border-radius:6px; max-height:160px; overflow-y:auto; font-family:'Fira Code',monospace; font-size:11px; box-shadow:0 6px 20px #000a; min-width:180px; }
.ac-item { padding:3px 10px; cursor:pointer; color:#c4b5fd; display:flex; align-items:center; gap:8px; }
.ac-item:hover, .ac-item.selected { background:#4a1d9430; }
.ac-kind { font-size:9px; color:#4a2d70; }
.ac-label { color:#67e8f9; font-size:9px; }

/* Mobile widget sheets */
.mob-widget-sheet {
  position:fixed; inset:0; z-index:500; display:none;
  flex-direction:column; background:#07020f;
  animation:slideUp .2s ease;
}
.mob-widget-sheet.open { display:flex; }
.mob-ws-hdr {
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 14px; border-bottom:1px solid #4a1d9628;
  background:#0d0520; flex-shrink:0;
}
.mob-ws-title { font-family:'Cinzel',serif; font-size:13px; color:#c4b5fd; font-weight:700; }
.mob-ws-close { background:none; border:1px solid #4a1d9640; border-radius:6px; color:#6d4eaa; font-size:14px; padding:2px 10px; cursor:pointer; }
.mob-ws-tabs { display:flex; background:#0a0318; border-bottom:1px solid #4a1d9628; flex-shrink:0; overflow-x:auto; scrollbar-width:none; }
.mob-ws-tab { flex:0 0 auto; padding:8px 14px; font-family:'Cinzel',serif; font-size:9px; color:#4a2d70; cursor:pointer; border-bottom:2px solid transparent; white-space:nowrap; }
.mob-ws-tab.active { color:#a78bfa; border-bottom-color:#7c3aed; }
.mob-ws-body { flex:1; overflow:hidden; display:flex; flex-direction:column; }
.mob-ws-pane { flex:1; overflow-y:auto; display:none; padding:12px 14px; }
.mob-ws-pane.active { display:block; }

/* SLN file tree special styling */
.code-sln-badge { background:#5c2d91; color:#fff; font-size:7px; padding:1px 5px; border-radius:3px; margin-left:4px; font-family:'Cinzel',serif; }
.code-unity-badge { background:#222c37; color:#aaa; font-size:7px; padding:1px 5px; border-radius:3px; margin-left:4px; }
.code-ue-badge { background:#1a0a00; color:#f90; font-size:7px; padding:1px 5px; border-radius:3px; margin-left:4px; }

/* ── Blender-style 3D editor UI ────────────────────────────────────── */
.blnd-mode-btn {
  background:transparent; border:none; color:#6d4eaa;
  font-family:'Cinzel',serif; font-size:8.5px; padding:3px 8px;
  cursor:pointer; border-radius:4px; transition:all .12s;
}
.blnd-mode-btn.active { background:#4a1d9440; color:#c4b5fd; }
.blnd-mode-btn:hover  { background:#4a1d9420; }

.blnd-shade-btn {
  background:transparent; border:none; color:#6d4eaa;
  font-size:11px; padding:2px 6px; cursor:pointer;
  border-radius:3px; transition:all .12s; line-height:1;
}
.blnd-shade-btn:hover  { background:#4a1d9420; }
.blnd-shade-btn.active { background:#4a1d9440; color:#c4b5fd; }

.blnd-npanel-cat { border-bottom:1px solid #4a1d9618; }
.blnd-npanel-hdr {
  padding:4px 8px; font-family:'Cinzel',serif; font-size:8px;
  color:#6d4eaa; cursor:pointer; letter-spacing:.1em;
  user-select:none;
}
.blnd-npanel-hdr:hover { background:#4a1d9418; }
.blnd-npanel-body { padding:6px 8px; }
.blnd-vec-inp {
  background:#0d0520; border:1px solid #4a1d9630; border-radius:3px;
  color:#a78bfa; font-family:'Fira Code',monospace; font-size:9px;
  padding:2px 3px; width:100%; text-align:center; box-sizing:border-box;
}
.blnd-vec-inp:focus { outline:none; border-color:#7c3aed80; }

.blnd-ed-tab {
  padding:4px 10px; font-family:'Cinzel',serif; font-size:8px;
  color:#4a2d70; cursor:pointer; border:none; background:transparent;
  border-bottom:2px solid transparent; transition:all .12s;
}
.blnd-ed-tab.active { color:#a78bfa; border-bottom-color:#7c3aed; }
.blnd-ed-tab:hover  { color:#6d4eaa; background:#4a1d9418; }

/* Dope sheet diamond keyframes */
.dope-channel { padding:1px 6px; font-family:'Cinzel',serif; font-size:8px; color:#6d4eaa; height:20px; display:flex; align-items:center; cursor:pointer; }
.dope-channel.active { background:#4a1d9430; color:#c4b5fd; }
.dope-channel:hover { background:#4a1d9418; }

/* NLA strip */
.nla-strip { border-radius:3px; height:16px; position:absolute; cursor:pointer; display:flex; align-items:center; overflow:hidden; }
.nla-strip-label { font-family:'Cinzel',serif; font-size:7px; color:rgba(255,255,255,.8); padding:0 4px; white-space:nowrap; overflow:hidden; }

/* Shape key row */
.sk-row { padding:3px 6px; font-family:'Cinzel',serif; font-size:8px; color:#6d4eaa; display:flex; align-items:center; gap:6px; cursor:pointer; }
.sk-row:hover { background:#4a1d9418; }
.sk-row.active { background:#4a1d9430; color:#c4b5fd; }
.sk-row input[type=range] { flex:1; }

/* ── Mobile 3D widget layout: column stack (viewport top, sidebar bottom) ── */
@media (max-width: 767px) {
  /* The inner flex row becomes a column */
  #widget-mag-3d > div > div[style*="display:flex;flex:1;overflow:hidden"] {
    flex-direction: column !important;
  }
  /* Viewport: fixed height on top */
  #widget-mag-3d .mag-sidebar {
    width: 100% !important;
    max-width: 100% !important;
    border-left: none !important;
    border-top: 1px solid #4a1d9628;
    flex-shrink: 0;
    max-height: 44vh;
    overflow-y: auto;
  }
  /* Viewport takes remaining height */
  #widget-mag-3d > div > div[style*="display:flex;flex:1;overflow:hidden"] > div[style*="flex:1;position:relative"] {
    min-height: 40vh;
    flex-shrink: 0;
  }
  /* Sidebar tab strip: scrollable horizontal */
  #widget-mag-3d .mag-sidebar > div[style*="display:flex;background:#07020f"] {
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  /* Header: wrap export buttons */
  #widget-mag-3d .desk-widget-hdr {
    flex-wrap: wrap;
    gap: 4px;
  }
  #widget-mag-3d .desk-widget-hdr > div {
    flex-wrap: wrap;
    gap: 3px;
  }
}

/* ── Magicium AI Studio ─────────────────────────────────────── */
#widget-mag-studio { font-family:'Cinzel',serif; }

/* Studio topbar */
.studio-topbar {
  height:42px; flex-shrink:0;
  background:linear-gradient(135deg,#0d0520dd,#07020fdd);
  border-bottom:1px solid #7c3aed40;
  display:flex; align-items:center;
  padding:0 12px; gap:10px;
  backdrop-filter:blur(20px);
}
.studio-logo {
  display:flex; align-items:center; gap:6px;
  font-size:12px; font-weight:900; letter-spacing:.15em;
  color:transparent;
  background:linear-gradient(135deg,#c4b5fd,#7c3aed,#f59e0b);
  -webkit-background-clip:text; background-clip:text;
}
.studio-logo-icon { font-size:18px; }
.studio-topbar-mid { flex:1; display:flex; align-items:center; justify-content:center; gap:4px; }
.studio-menu-btn {
  background:transparent; border:none; color:#6d4eaa;
  font-family:'Cinzel',serif; font-size:9px; padding:4px 10px;
  cursor:pointer; border-radius:4px; transition:all .12s;
  letter-spacing:.08em;
}
.studio-menu-btn:hover { background:#4a1d9420; color:#a78bfa; }
.studio-topbar-right { display:flex; align-items:center; gap:6px; }
.studio-action-btn {
  background:#4a1d9430; border:1px solid #4a1d9440;
  border-radius:5px; color:#a78bfa; font-family:'Cinzel',serif;
  font-size:8.5px; padding:3px 10px; cursor:pointer;
  transition:all .12s; letter-spacing:.06em;
}
.studio-action-btn:hover { background:#4a1d9460; }
.studio-action-btn.primary { background:linear-gradient(135deg,#4a1d94,#7c3aed); color:#f3e8ff; border-color:#7c3aed80; }

/* Studio body */
.studio-body { flex:1; display:flex; overflow:hidden; }

/* Left panel — tool dock */
.studio-dock {
  width:64px; background:#07020fcc; border-right:1px solid #4a1d9628;
  display:flex; flex-direction:column; align-items:center;
  padding:8px 0; gap:2px; overflow-y:auto; flex-shrink:0;
}
.studio-dock-btn {
  width:48px; height:48px; border-radius:10px;
  border:1px solid transparent;
  background:transparent; cursor:pointer;
  display:flex; flex-direction:column; align-items:center;
  justify-content:center; gap:3px; transition:all .18s;
  position:relative;
}
.studio-dock-btn:hover { background:#4a1d9430; border-color:#4a1d9440; }
.studio-dock-btn.active { background:linear-gradient(135deg,#4a1d9440,#7c3aed30); border-color:#7c3aed70; box-shadow:0 0 12px #7c3aed30; }
.studio-dock-icon { font-size:20px; line-height:1; }
.studio-dock-label { font-family:'Cinzel',serif; font-size:6px; color:#4a2d70; letter-spacing:.06em; text-align:center; }
.studio-dock-btn.active .studio-dock-label { color:#a78bfa; }
.studio-dock-sep { width:32px; height:1px; background:#4a1d9628; margin:4px 0; }

/* Main content */
.studio-main { flex:1; display:flex; overflow:hidden; }

/* Home dashboard */
#studio-home {
  flex:1; overflow-y:auto; padding:24px;
  display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:16px; align-content:start;
}
.studio-tool-card {
  background:linear-gradient(135deg,#0d052090,#07020f90);
  border:1px solid #4a1d9630; border-radius:14px;
  padding:18px; cursor:pointer; transition:all .2s;
  position:relative; overflow:hidden;
}
.studio-tool-card::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(circle at 30% 30%, var(--card-glow,#7c3aed18), transparent 70%);
}
.studio-tool-card:hover {
  border-color:#7c3aed80; transform:translateY(-2px);
  box-shadow:0 8px 32px #7c3aed20;
}
.studio-tool-card-icon { font-size:32px; margin-bottom:10px; }
.studio-tool-card-name { font-size:11px; font-weight:700; color:#c4b5fd; letter-spacing:.1em; margin-bottom:5px; }
.studio-tool-card-desc { font-size:8.5px; color:#6d4eaa; line-height:1.5; }
.studio-tool-card-tag { display:inline-block; background:#7c3aed30; border:1px solid #7c3aed40; border-radius:10px; font-size:7px; color:#a78bfa; padding:1px 7px; margin-top:8px; }

/* Recent projects panel */
.studio-recent { width:280px; background:#07020fcc; border-left:1px solid #4a1d9628; display:flex; flex-direction:column; flex-shrink:0; }
.studio-section-hdr { padding:10px 14px; font-size:8px; color:#4a2d70; letter-spacing:.12em; border-bottom:1px solid #4a1d9628; }
.studio-recent-item { padding:10px 14px; border-bottom:1px solid #4a1d9615; cursor:pointer; transition:background .12s; }
.studio-recent-item:hover { background:#4a1d9420; }
.studio-recent-icon { font-size:16px; }
.studio-recent-name { font-size:9px; color:#a78bfa; }
.studio-recent-meta { font-size:7.5px; color:#4a2d70; margin-top:2px; }

/* Embedded tool frame */
#studio-tool-frame {
  flex:1; display:none; flex-direction:column; overflow:hidden;
}
#studio-tool-frame.visible { display:flex; }

/* Studio status bar */
.studio-statusbar {
  height:22px; flex-shrink:0;
  background:#07020fcc; border-top:1px solid #4a1d9628;
  display:flex; align-items:center; padding:0 12px; gap:16px;
}
.studio-stat { font-family:'Cinzel',serif; font-size:7.5px; color:#4a2d70; }
.studio-stat span { color:#6d4eaa; }

/* Studio notifications / progress */
#studio-progress {
  position:absolute; bottom:30px; left:50%; transform:translateX(-50%);
  background:#0d0520ee; border:1px solid #7c3aed60; border-radius:10px;
  padding:8px 16px; font-family:'Cinzel',serif; font-size:9px; color:#a78bfa;
  display:none; gap:8px; align-items:center; z-index:10;
  box-shadow:0 4px 20px #7c3aed30; white-space:nowrap;
}
#studio-progress.visible { display:flex; }

/* Mobile studio dock — horizontal at bottom */
/* ── Mobile studio styles — scoped to body.is-mobile ONLY ───────────── */
/* Uses body.is-mobile (JS-detected) NOT @media width, so desktop narrow */
/* browser windows never get mobile layout                                */
body.is-mobile #widget-mag-studio .studio-topbar {
  height:auto; padding:8px 10px; gap:6px;
}
body.is-mobile #widget-mag-studio .studio-topbar-mid { display:none; }
body.is-mobile #widget-mag-studio .studio-topbar-right { gap:4px; }
body.is-mobile #widget-mag-studio .studio-topbar-right .studio-action-btn { font-size:7.5px; padding:2px 7px; }
body.is-mobile #studio-project-name { font-size:8px; max-width:100px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
body.is-mobile #widget-mag-studio .studio-body { flex-direction:column; }
body.is-mobile #widget-mag-studio .studio-main { position:relative; }
body.is-mobile #widget-mag-studio .studio-dock {
  width:100%; height:60px; flex-direction:row;
  border-right:none; border-top:1px solid #4a1d9640;
  background:#07020fee; overflow-x:auto; overflow-y:hidden;
  padding:4px 6px; order:10;
  -webkit-overflow-scrolling:touch; scrollbar-width:none;
  flex-shrink:0; gap:2px; backdrop-filter:blur(16px);
}
body.is-mobile #widget-mag-studio .studio-dock::-webkit-scrollbar { display:none; }
body.is-mobile #widget-mag-studio .studio-dock-sep { width:1px; height:32px; margin:0 3px; align-self:center; }
body.is-mobile #widget-mag-studio .studio-dock-btn { width:50px; height:50px; flex-shrink:0; border-radius:12px; flex-direction:column; gap:2px; padding:4px; }
body.is-mobile #widget-mag-studio .studio-dock-icon { font-size:18px; }
body.is-mobile #widget-mag-studio .studio-dock-label { font-size:6.5px; }
body.is-mobile #widget-mag-studio .studio-recent { display:none; }
body.is-mobile #studio-home { padding:12px 10px; gap:10px; }
body.is-mobile #studio-home > div:first-child { display:none; }
body.is-mobile .studio-tool-card { padding:12px; }
body.is-mobile .studio-tool-card-icon { font-size:22px; margin-bottom:6px; }
body.is-mobile .studio-tool-card-name { font-size:9px; }
body.is-mobile .studio-tool-card-desc,
body.is-mobile .studio-tool-card-tag { display:none; }
body.is-mobile #studio-assets-grid { grid-template-columns:repeat(2,1fr); padding:10px; gap:8px; }
body.is-mobile #widget-mag-studio .studio-statusbar { display:none; }
body.is-mobile #studio-progress { bottom:68px; font-size:8px; padding:6px 12px; }


/* Studio home cards grid — 2 col on narrow mobile */
@media (max-width:767px) {
  #studio-cards-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
  }
  #studio-cards-grid .studio-tool-card { padding: 12px 10px; }
  #studio-cards-grid .studio-tool-card-icon { font-size: 24px; margin-bottom: 4px; }
  #studio-cards-grid .studio-tool-card-name { font-size: 8.5px; margin-bottom: 2px; }
  #studio-cards-grid .studio-tool-card-desc { font-size: 0; height: 0; overflow: hidden; margin: 0; }
  #studio-cards-grid .studio-tool-card-tag { display: none; }
}

/* Studio embedded widget overlay */
.studio-embedded { box-shadow:none!important; border-radius:0!important; border:none!important; }

/* ── Message Rating ─────────────────────────────────────── */
.msg-rating {
  display:flex; align-items:center; gap:6px;
  margin-top:8px; padding-top:6px;
  border-top:1px solid rgba(74,29,150,.18);
}
.msg-rate-btn {
  background:transparent; border:1px solid #4a1d9628;
  border-radius:6px; padding:2px 8px; cursor:pointer;
  font-size:12px; color:#4a2d70; transition:all .15s;
  line-height:1.4;
}
.msg-rate-btn:hover { background:#4a1d9420; color:#a78bfa; border-color:#7c3aed40; }
.msg-rate-btn.rated-up   { background:#0a1a0a; border-color:#4ade8060; color:#4ade80; }
.msg-rate-btn.rated-down { background:#1a0a0a; border-color:#f8717160; color:#f87171; }
.msg-rate-lbl {
  font-family:'Cinzel',serif; font-size:7px; color:#3a1d60;
  letter-spacing:.06em; flex:1; text-align:right;
  opacity:0; transition:opacity .3s;
}
.msg-rating:has(.rated-up)   .msg-rate-lbl,
.msg-rating:has(.rated-down) .msg-rate-lbl { opacity:1; }

/* ══ Magicium One launcher: offset widgets below the 36px back bar ══ */
body.m1-launcher-active #widget-mag-studio {
  top: 36px !important;
  height: calc(100vh - 36px) !important;
  max-height: calc(100vh - 36px) !important;
}
body.m1-launcher-active #widget-mag-3d,
body.m1-launcher-active #widget-mag-viewer,
body.m1-launcher-active #widget-mag-code,
body.m1-launcher-active #widget-magplay,
body.m1-launcher-active #widget-mag-audio {
  top: 36px !important;
  height: calc(100vh - 36px) !important;
  max-height: calc(100vh - 36px) !important;
}
/* Prevent "← Magicium One" button from wrapping or clipping */
#m1-back-bar button {
  white-space: nowrap;
  flex-shrink: 0;
  overflow: visible;
}
