:root{--bg:#050508;--bg2:#08080f;--bg3:#0d0d18;--surf:#111118;--surf2:#1a1a2e;--bdr:rgba(255,255,255,.07);--bdr2:rgba(255,255,255,.15);--acc:#ff2d6b;--acc2:#c026a0;--cyan:#00f5ff;--violet:#9b5de5;--gold:#f5a623;--txt:#ffffff;--txt2:rgba(255,255,255,.6);--txt3:rgba(255,255,255,.3);--green:#00e5a0;--nav-h:50px;--r:8px;--r-lg:12px;--r-xl:18px;--t:.18s ease}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:'Space Grotesk',sans-serif;background:var(--bg);color:var(--txt);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit;border:none;background:none}
img,video{display:block}input,textarea,select{font-family:inherit}
::-webkit-scrollbar{width:3px;height:3px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--surf2)}
.hidden{display:none!important}
.nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:200;display:flex;align-items:center;justify-content:space-between;padding:0 16px;background:rgba(15,12,12,.96);backdrop-filter:blur(16px);border-bottom:1px solid var(--bdr)}
.nav-logo{display:flex;align-items:center;gap:6px;cursor:pointer;user-select:none;flex-shrink:0}
.nav-logo-text{font-family:'Space Grotesk',sans-serif;font-size:24px;font-weight:800;letter-spacing:-.5px;color:var(--txt)}
.nav-logo-text em{font-style:normal;color:var(--acc)}
.nav-logo-kana{font-size:9px;color:rgba(0,220,255,.35);letter-spacing:2px}
.nav-links{display:flex;align-items:center;gap:2px;list-style:none;position:absolute;left:50%;transform:translateX(-50%)}
.nav-links a{padding:6px 13px;border-radius:var(--r);font-size:13px;font-weight:500;color:var(--txt2);transition:all var(--t)}
.nav-links a:hover,.nav-links a.active{color:var(--txt);background:var(--surf)}
.nav-right{display:flex;align-items:center;gap:8px}
.lang-sw{display:flex;gap:1px;background:rgba(155,93,229,.06);border:1px solid var(--bdr);border-radius:var(--r);padding:2px}
.lang-btn{display:flex;align-items:center;gap:3px;padding:3px 8px;border-radius:6px;color:var(--txt3);font-size:10px;font-weight:700;letter-spacing:.3px;transition:all var(--t)}
.lang-btn:hover{color:var(--txt2)}.lang-btn.active{background:rgba(255,45,107,.2);color:var(--acc)}.lang-btn .flag{font-size:12px}
.nav-mana{display:none;align-items:center;gap:5px;padding:4px 10px;background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);font-size:13px;font-weight:600}
.nav-mana.show{display:flex}
.nav-mana-add{width:18px;height:18px;border-radius:50%;background:var(--acc);color:#fff;font-size:13px;font-weight:800;display:flex;align-items:center;justify-content:center}
.nav-mana-add:hover{background:var(--acc2)}
.nav-user{display:none;align-items:center;gap:7px;padding:3px 10px 3px 3px;background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);cursor:pointer;position:relative;transition:border-color var(--t)}
.nav-user.show{display:flex}.nav-user:hover{border-color:var(--bdr2)}
.nav-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--acc),var(--gold));display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;overflow:hidden}
.nav-avatar img{width:100%;height:100%;object-fit:cover}.nav-username{font-size:13px;font-weight:500}
.btn-signin{padding:6px 15px;background:transparent;border:1px solid var(--acc);color:var(--acc);font-size:12px;font-weight:700;border-radius:var(--r);transition:all var(--t)}
.btn-signin:hover{background:var(--acc);color:#fff}
.nav-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg3);border:1px solid var(--bdr2);border-radius:var(--r-lg);padding:6px;min-width:180px;box-shadow:0 16px 40px rgba(0,0,0,.6);opacity:0;visibility:hidden;transform:translateY(-6px);transition:all var(--t);z-index:300}
.nav-dropdown.open{opacity:1;visibility:visible;transform:translateY(0)}
.dd-item{display:flex;align-items:center;gap:9px;padding:8px 12px;border-radius:var(--r);font-size:13px;color:var(--txt2);cursor:pointer;width:100%;text-align:left;transition:all var(--t)}
.dd-item:hover{background:var(--surf2);color:var(--txt)}.dd-item.red{color:rgba(255,80,80,.8)}.dd-item.red:hover{background:rgba(255,80,80,.08);color:#ff5050}
.dd-sep{height:1px;background:var(--bdr);margin:4px 0}
.hamburger{display:none;flex-direction:column;gap:5px;padding:5px}
.hamburger span{display:block;width:20px;height:2px;background:var(--txt);border-radius:1px;transition:all var(--t)}
.mobile-menu{position:fixed;top:var(--nav-h);left:0;right:0;bottom:0;background:var(--bg);z-index:190;padding:16px;display:flex;flex-direction:column;gap:4px;overflow-y:auto;transform:translateX(100%);transition:transform .28s ease}
.mobile-menu.open{transform:translateX(0)}
.mm-user{display:flex;align-items:center;gap:10px;padding:12px;background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r-lg);margin-bottom:8px}
.mm-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--acc),var(--gold));display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;overflow:hidden}
.mm-avatar img{width:100%;height:100%;object-fit:cover}.mm-name{font-size:14px;font-weight:600}.mm-mana{font-size:12px;color:var(--txt2);margin-top:2px}
.mm-link{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:var(--r-lg);font-size:14px;font-weight:500;color:var(--txt2);cursor:pointer;width:100%;text-align:left;transition:all var(--t)}
.mm-link:hover,.mm-link.active{background:var(--surf);color:var(--txt)}.mm-sep{height:1px;background:var(--bdr);margin:6px 0}
.mm-lang{display:flex;gap:6px;padding:8px 0}
.mm-lang-btn{flex:1;padding:9px;border-radius:var(--r-lg);border:1px solid var(--bdr);background:var(--surf);color:var(--txt2);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:5px;transition:all var(--t)}
.mm-lang-btn.active{border-color:var(--acc);color:var(--acc);background:rgba(255,45,107,.08)}
.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:68px;background:rgba(15,12,12,.97);backdrop-filter:blur(16px);border-top:1px solid var(--bdr);z-index:190;align-items:center;justify-content:space-around;padding:0 8px;padding-bottom:env(safe-area-inset-bottom,0)}
.bn-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:4px 6px;color:var(--txt3);flex:1;transition:color var(--t);background:none;border:none;cursor:pointer;font-family:inherit}
.bn-item.active{color:var(--acc)}.bn-item:hover{color:var(--txt2)}.bn-svg{width:20px;height:20px;flex-shrink:0}.bn-label{font-size:9px;font-weight:600;letter-spacing:.02em}
.bn-center{width:40px;height:40px;border-radius:50%;background:var(--acc);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(255,45,107,.35);flex-shrink:0;border:none;cursor:pointer}
.bn-mana-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;flex:1;height:100%}
.bn-mana-icon{display:flex;align-items:center;justify-content:center;position:relative;width:20px;height:20px}
.bn-mana-plus{width:13px;height:13px;border-radius:50%;background:var(--acc);color:#fff;font-size:9px;font-weight:800;display:flex;align-items:center;justify-content:center;position:absolute;top:-4px;right:-7px;line-height:1}
.main{padding-top:var(--nav-h);min-height:100vh}.page{display:none}.page.active{display:block}
.landing-bg{position:fixed;bottom:0;left:0;right:0;height:260px;pointer-events:none;z-index:0;opacity:.7}
.landing-bg svg{width:100%;height:100%}
.landing-banner{background:rgba(155,93,229,.06);border-top:1px solid rgba(255,45,107,.2);border-bottom:1px solid rgba(255,45,107,.2);padding:10px 16px;text-align:center;font-size:13px;font-weight:800;letter-spacing:.15em;color:#f5a623;text-transform:uppercase;display:flex;align-items:center;justify-content:center;gap:12px}
.landing-banner-sep{width:4px;height:4px;border-radius:50%;background:rgba(155,93,229,.4);flex-shrink:0}
.landing-filters{display:flex;gap:6px;padding:9px 14px;background:rgba(15,12,12,.95);border-bottom:1px solid var(--bdr);overflow-x:auto;scrollbar-width:none;position:sticky;top:var(--nav-h);z-index:10}
.landing-filters::-webkit-scrollbar{display:none}
.fchip{display:flex;align-items:center;gap:5px;padding:5px 14px;border-radius:20px;border:1px solid var(--bdr);background:rgba(255,255,255,.03);color:var(--txt3);font-size:12px;font-weight:600;white-space:nowrap;cursor:pointer;flex-shrink:0;transition:all var(--t)}
.fchip:hover{border-color:var(--bdr2);color:var(--txt2)}.fchip.active{border-color:var(--acc);color:var(--acc);background:rgba(255,45,107,.1)}
.media-grid{columns:5;column-gap:3px;padding:3px;position:relative;z-index:1}
.media-card{break-inside:avoid;margin-bottom:3px;position:relative;overflow:hidden;cursor:pointer;border:1px solid rgba(255,255,255,.04);transition:border-color var(--t)}
.media-card:hover{border-color:rgba(255,45,107,.35)}
.media-card img,.media-card video{width:100%;height:auto;display:block;transition:transform .4s ease}
.media-card:hover img,.media-card:hover video{transform:scale(1.05)}
.media-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,12,12,.96) 0%,rgba(15,12,12,.1) 60%,transparent 100%);opacity:0;transition:opacity .22s;display:flex;align-items:center;justify-content:center}
.media-card:hover .media-overlay{opacity:1}
.btn-gen{padding:9px 22px;background:var(--acc);color:#fff;font-size:12px;font-weight:700;letter-spacing:.4px;border-radius:var(--r);transform:scale(.9);transition:transform .2s,background .15s;box-shadow:0 4px 16px rgba(255,45,107,.25)}
.media-card:hover .btn-gen{transform:scale(1)}.btn-gen:hover{background:var(--acc2)}
.media-badge{position:absolute;top:7px;left:7px;padding:3px 8px;font-size:9px;font-weight:700;letter-spacing:.5px;border-radius:4px}
.badge-new{background:rgba(232,0,45,.18);color:var(--acc2);border:1px solid rgba(255,45,107,.25)}
.badge-top{background:rgba(255,255,255,.07);color:#c9a8ff;border:1px solid rgba(255,45,107,.25)}
.badge-vid{background:rgba(15,12,12,.85);color:var(--txt2);border:1px solid var(--bdr);top:7px;left:auto;right:7px}
.media-skeleton{background:var(--surf2);animation:pulse 1.4s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.empty-state{text-align:center;padding:60px 20px;color:var(--txt3)}
.empty-state .icon{font-size:44px;margin-bottom:10px}.empty-state p{font-size:14px;margin-bottom:14px}
.studio-wrap{max-width:620px;margin:0 auto;padding:22px 16px;display:flex;flex-direction:column;gap:16px}
.studio-card{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r-xl);padding:22px 20px}
.studio-card::before{content:'';display:block;height:2px;background:linear-gradient(90deg,transparent,var(--acc),var(--gold),var(--acc),transparent);border-radius:2px;margin-bottom:18px}
.studio-card-title{font-family:'Space Grotesk',sans-serif;font-size:20px;font-weight:800;margin-bottom:3px}
.studio-card-sub{font-size:11px;color:var(--txt3);letter-spacing:.5px;margin-bottom:16px}
.studio-prompt{width:100%;background:var(--bg3);border:1px solid var(--bdr);border-radius:var(--r-lg);color:var(--txt);font-size:14px;padding:14px 16px;resize:none;outline:none;line-height:1.7;transition:border-color var(--t);font-family:'Space Grotesk',sans-serif;min-height:100px}
.studio-prompt:focus{border-color:var(--acc)}
.studio-prompt::placeholder{color:var(--txt3)}
@keyframes promptFlash{0%{border-color:var(--acc)}50%{border-color:var(--cyan)}100%{border-color:var(--bdr)}}
.studio-prompt.prompt-flash{animation:promptFlash .4s ease}
.studio-actions{display:grid;grid-template-columns:auto auto 1fr;gap:8px;margin-top:10px;align-items:center}
.btn-studio-mic{display:flex;align-items:center;gap:6px;padding:10px 14px;background:var(--surf2);border:1px solid var(--bdr);border-radius:var(--r);color:var(--txt2);font-size:12px;font-weight:600;cursor:pointer;transition:all var(--t);font-family:'Space Grotesk',sans-serif;white-space:nowrap}
.btn-studio-mic:hover{border-color:var(--violet);color:var(--violet)}
.btn-studio-mic.mic-active{border-color:var(--violet);color:var(--violet);background:rgba(255,45,107,.1);animation:micPulse 1s ease-in-out infinite}
@keyframes micPulse{0%,100%{box-shadow:0 0 0 0 rgba(155,93,229,.4)}50%{box-shadow:0 0 0 6px rgba(155,93,229,0)}}
.btn-studio-random{display:flex;align-items:center;gap:6px;padding:10px 14px;background:var(--surf2);border:1px solid var(--bdr);border-radius:var(--r);color:var(--txt2);font-size:12px;font-weight:600;cursor:pointer;transition:all var(--t);font-family:'Space Grotesk',sans-serif;white-space:nowrap}
.btn-studio-random:hover{border-color:var(--gold);color:var(--gold)}
.btn-studio-gen{display:flex;align-items:center;justify-content:center;gap:6px;padding:11px 20px;background:var(--acc);border:none;border-radius:var(--r);color:#fff;font-size:13px;font-weight:700;cursor:pointer;transition:all var(--t);font-family:'Space Grotesk',sans-serif;width:100%}
.btn-studio-gen:hover{background:var(--acc2);transform:translateY(-1px)}
.btn-studio-gen:disabled{opacity:.35;cursor:not-allowed;transform:none}
.studio-preview-wrap{display:flex;flex-direction:column;gap:16px}
.panel{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r-xl);overflow:hidden}
.panel-head{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:1px solid var(--bdr)}
.panel-head h3{font-size:13px;font-weight:600}
.step-n{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,var(--acc),#c026a0);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;color:#fff;flex-shrink:0}
.panel-body{padding:14px 16px}
.style-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px}
.style-card{position:relative;border-radius:var(--r-lg);overflow:hidden;cursor:pointer;border:2px solid transparent;aspect-ratio:3/4;background:var(--surf2);transition:border-color var(--t),transform var(--t)}
.style-card:hover{transform:translateY(-2px)}.style-card.active{border-color:var(--acc)}
.style-art{position:absolute;inset:0;background-size:cover;background-position:center top;transition:transform .4s ease}
.style-card:hover .style-art{transform:scale(1.06)}
.style-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,12,12,.75) 0%,rgba(15,12,12,.1) 60%)}
.style-label{position:absolute;bottom:8px;left:0;right:0;text-align:center;font-size:12px;font-weight:700;color:#fff}
.style-shonen .style-art{background-image:url('/assets/styles/shonen.jpg')}
.style-shojo  .style-art{background-image:url('/assets/styles/shojo.jpg')}
.style-fantasy .style-art{background-image:url('/assets/styles/fantasy.jpg')}
.sel-group{display:flex;flex-direction:column;gap:7px}
.sel-row{display:flex;align-items:center;gap:9px;background:var(--bg3);border:1px solid var(--bdr);border-radius:var(--r);padding:0 11px;transition:border-color var(--t)}
.sel-row:focus-within{border-color:var(--acc)}.sel-icon{font-size:15px;flex-shrink:0}
.sel-row select{flex:1;background:none;border:none;outline:none;color:var(--txt);font-size:13px;padding:9px 0;cursor:pointer}
.sel-row select option{background:var(--bg3)}.sel-arrow{color:var(--txt3);font-size:10px;flex-shrink:0}
.tag-group{display:flex;flex-wrap:wrap;gap:5px}
.tag{padding:5px 12px;border-radius:20px;font-size:12px;font-weight:500;color:var(--txt2);background:var(--bg3);border:1px solid var(--bdr);cursor:pointer;transition:all var(--t)}
.tag:hover{border-color:var(--acc);color:var(--txt)}.tag.active{background:rgba(255,255,255,.07);border-color:var(--acc);color:var(--txt)}
.scene-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:5px}
.scene-card{position:relative;border-radius:var(--r);overflow:hidden;cursor:pointer;border:2px solid transparent;aspect-ratio:4/3;background:var(--surf2);transition:border-color var(--t),transform var(--t)}
.scene-card:hover{transform:translateY(-2px)}.scene-card.active{border-color:var(--acc)}
.scene-art{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .4s ease}
.scene-card:hover .scene-art{transform:scale(1.08)}
.scene-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,12,12,.8) 0%,transparent 55%)}
.scene-label{position:absolute;bottom:6px;left:0;right:0;text-align:center;font-size:10px;font-weight:700;color:#fff}
.scene-school .scene-art{background-image:url('/assets/styles/school.jpg')}
.scene-temple .scene-art{background-image:url('/assets/styles/temple.jpg')}
.scene-forest .scene-art{background-image:url('/assets/styles/forest.jpg')}
.scene-beach  .scene-art{background-image:url('/assets/styles/beach.jpg')}
.scene-city   .scene-art{background-image:url('/assets/styles/city.jpg')}
.scene-space  .scene-art{background-image:url('/assets/styles/space.jpg')}
textarea{width:100%;background:var(--bg3);border:1px solid var(--bdr);border-radius:var(--r);color:var(--txt);font-size:13px;padding:10px 12px;resize:vertical;outline:none;line-height:1.6;transition:border-color var(--t)}
textarea:focus{border-color:var(--acc)}.free-desc{font-size:12px;color:var(--txt2);margin-bottom:8px;line-height:1.6}
.btn-row{display:flex;gap:8px;margin-top:12px}
.btn{display:flex;align-items:center;gap:6px;padding:10px 18px;border-radius:var(--r);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--t)}
.btn-primary{background:var(--acc);color:#fff;flex:1;justify-content:center}.btn-primary:hover{background:var(--acc2);transform:translateY(-1px)}
.btn-primary:disabled{opacity:.35;cursor:not-allowed;transform:none}
.btn-secondary{background:var(--surf2);border:1px solid var(--bdr);color:var(--txt2)}.btn-secondary:hover{border-color:var(--bdr2);color:var(--txt)}
.btn-icon{width:38px;height:38px;border-radius:var(--r);background:var(--surf2);border:1px solid var(--bdr);color:var(--txt2);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.btn-icon:hover{border-color:var(--bdr2);color:var(--txt)}
.status-txt{font-size:12px;color:var(--txt3);text-align:center;padding:6px;min-height:24px}.status-txt.err{color:#ff5050}
.preview-panel{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r-xl);overflow:hidden;position:sticky;top:calc(var(--nav-h) + 14px)}
.preview-area{position:relative;aspect-ratio:9/16;background:var(--bg3);overflow:hidden}
.preview-empty{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--txt3)}
.preview-empty .icon{font-size:44px}.preview-empty p{font-size:13px;text-align:center;line-height:1.6}
#previewImg{width:100%;height:100%;object-fit:cover;object-position:top;position:absolute;inset:0;cursor:zoom-in;animation:fadeIn .4s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.preview-loader{position:absolute;inset:0;background:rgba(15,12,12,.92);display:none;flex-direction:column;align-items:center;justify-content:center;gap:14px}
.preview-loader.show{display:flex}
.spinner{width:44px;height:44px;border:3px solid var(--surf2);border-top-color:var(--acc);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}.loader-msg{font-size:13px;color:var(--txt2)}
.preview-watermark{position:absolute;bottom:8px;right:10px;font-size:10px;font-weight:700;letter-spacing:1px;color:rgba(255,255,255,.25);background:rgba(15,12,12,.5);padding:2px 8px;border-radius:20px;pointer-events:none}
.char-card{padding:13px 16px;border-top:1px solid var(--bdr)}
.char-name{font-family:'Space Grotesk',sans-serif;font-size:17px;font-weight:800;margin-bottom:4px}
.char-universe{font-size:11px;color:var(--txt3);margin-bottom:8px}
.char-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}
.char-tag{font-size:11px;padding:2px 8px;border-radius:20px;background:var(--surf2);color:var(--txt2);border:1px solid var(--bdr)}
.voice-panel{background:linear-gradient(135deg,var(--surf) 0%,rgba(255,255,255,.04) 100%);border-color:rgba(255,45,107,.2)}
.voice-header{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--bdr)}
.voice-title{font-size:13px;font-weight:600;flex:1}
.voice-cost{font-size:11px;background:rgba(255,255,255,.07);border:1px solid rgba(255,45,107,.25);color:var(--violet);padding:2px 8px;border-radius:20px}
.voice-orb-wrap{display:flex;flex-direction:column;align-items:center;gap:7px;padding:18px}
.voice-orb{width:68px;height:68px;border-radius:50%;background:var(--surf2);border:2px solid var(--bdr);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--t)}
.voice-orb:hover{border-color:var(--violet)}.voice-orb.active{border-color:var(--violet);box-shadow:0 0 20px rgba(255,45,107,.3)}
.orb-emoji{font-size:26px}.voice-status{font-size:12px;color:var(--txt3)}
.voice-transcript{padding:0 16px 12px;display:flex;flex-direction:column;gap:5px}
.voice-line{font-size:12px;line-height:1.5;padding:6px 10px;border-radius:var(--r)}
.char-line{background:var(--surf2);color:var(--txt2)}.user-line{background:rgba(255,45,107,.08);color:var(--txt);text-align:right}
.voice-controls{padding:0 16px 14px;display:flex;gap:7px}.voice-timer{font-size:12px;color:var(--txt3);text-align:center;padding:0 16px 12px}
.upload-ref{display:flex;gap:8px;align-items:center;margin-bottom:10px}
.btn-upload{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;background:var(--surf2);border:1px dashed var(--bdr2);border-radius:var(--r);font-size:12px;color:var(--txt2);cursor:pointer;transition:all var(--t)}
.btn-upload:hover{border-color:var(--acc);color:var(--txt)}
.ref-bar{display:flex;align-items:center;gap:9px;padding:7px 11px;background:rgba(155,93,229,.06);border:1px solid rgba(255,45,107,.2);border-radius:var(--r);margin-bottom:9px;font-size:12px;color:var(--cyan)}
.ref-thumb{width:30px;height:30px;border-radius:4px;background:var(--surf2);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}
.ref-thumb img{width:100%;height:100%;object-fit:cover}
.vchips{display:flex;flex-wrap:wrap;gap:5px;margin:9px 0}
.vchip{padding:5px 11px;border-radius:20px;font-size:11px;background:var(--bg3);border:1px solid var(--bdr);color:var(--txt2);cursor:pointer;transition:all var(--t)}
.vchip:hover{border-color:var(--cyan);color:var(--cyan)}.vchip.active{background:rgba(0,220,255,.08);border-color:var(--cyan);color:var(--cyan)}
.lock-overlay{position:absolute;inset:0;background:rgba(15,12,12,.82);display:flex;align-items:center;justify-content:center;border-radius:var(--r-xl)}
.lock-label{font-size:12px;font-weight:700;color:var(--txt3);letter-spacing:.5px}
#videoResult video{width:100%;border-radius:var(--r-lg);margin-top:10px}
.section-wrap{max-width:1400px;margin:0 auto;padding:22px 16px}.section-head{margin-bottom:18px}
.section-head h1{font-family:'Space Grotesk',sans-serif;font-size:22px;font-weight:800}
.explore-filters{display:flex;align-items:center;gap:7px;margin-bottom:16px;flex-wrap:wrap}
.gen-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:7px}
.comm-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:7px}
.live-char-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:7px}
.gen-card{position:relative;aspect-ratio:9/16;border-radius:var(--r-lg);overflow:hidden;cursor:pointer;background:var(--surf);border:1px solid var(--bdr);transition:border-color var(--t)}
.comm-card{position:relative;aspect-ratio:9/16;border-radius:var(--r-lg);overflow:hidden;cursor:pointer;background:var(--surf);border:1px solid var(--bdr);transition:border-color var(--t)}
.gen-card:hover,.comm-card:hover{border-color:var(--bdr2)}
.gen-card img,.gen-card video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}
.comm-card img,.comm-card video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}
.gen-card:hover img,.gen-card:hover video,.comm-card:hover img,.comm-card:hover video{transform:scale(1.04)}
.card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,12,12,.92) 0%,transparent 55%);opacity:0;transition:opacity var(--t);display:flex;align-items:flex-end;padding:10px;gap:5px}
.gen-card:hover .card-overlay,.comm-card:hover .card-overlay{opacity:1}
.card-name{font-size:12px;font-weight:600;flex:1}.card-actions{display:flex;gap:3px}
.card-btn{width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.1);backdrop-filter:blur(4px);color:#fff;font-size:11px;display:flex;align-items:center;justify-content:center;transition:background var(--t)}
.card-btn:hover{background:var(--acc)}
.card-delete{position:absolute;top:6px;left:6px;z-index:3;display:flex;align-items:center;gap:4px;padding:4px 9px;border-radius:50px;background:rgba(200,40,40,.85);color:#fff;font-size:10px;font-weight:700;opacity:0;transition:opacity var(--t);pointer-events:none;white-space:nowrap}
.card-delete:hover{background:rgba(220,50,50,1)}
.gen-card:hover .card-delete,.gen-card.touched .card-delete{opacity:1;pointer-events:auto}
.select-mode-active .card-delete{opacity:0!important;pointer-events:none!important}
.select-mode-active .card-overlay{pointer-events:none!important;opacity:0!important}
.card-type-badge{position:absolute;top:7px;left:7px;font-size:9px;font-weight:700;padding:2px 7px;border-radius:4px;background:rgba(15,12,12,.75);color:var(--acc2);border:1px solid var(--bdr)}
.gen-card.selected{outline:2px solid var(--acc)}
.select-bar{position:sticky;bottom:18px;display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--bg3);border:1px solid var(--bdr2);border-radius:var(--r-xl);padding:11px 18px;box-shadow:0 12px 36px rgba(0,0,0,.5);z-index:50;margin-top:10px}
.pagination{display:flex;align-items:center;justify-content:center;gap:8px;padding:18px 0}
.pagination button{padding:7px 15px;border-radius:var(--r);border:1px solid var(--bdr);background:var(--surf);color:var(--txt2);font-size:13px;cursor:pointer;transition:all var(--t)}
.pagination button:hover{border-color:var(--acc);color:var(--txt)}.pagination button:disabled{opacity:.3;cursor:not-allowed}
.page-info{font-size:12px;color:var(--txt3)}
.comm-meta{display:flex;align-items:center;gap:6px;margin-bottom:3px}
.comm-avatar{width:18px;height:18px;border-radius:50%;background:var(--acc);display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700;overflow:hidden}
.comm-avatar img{width:100%;height:100%;object-fit:cover}.comm-username{font-size:11px;font-weight:600;color:rgba(255,255,255,.85)}.comm-likes{font-size:11px;color:var(--txt3)}
.profile-header{display:flex;align-items:center;gap:14px;padding:18px;background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r-xl);margin-bottom:18px}
.profile-avatar-lg{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--acc),var(--gold));display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;overflow:hidden;flex-shrink:0}
.profile-avatar-lg img{width:100%;height:100%;object-fit:cover}
.profile-name{font-family:'Space Grotesk',sans-serif;font-size:18px;font-weight:800;margin-bottom:3px}
.profile-bio{font-size:13px;color:var(--txt2);margin-bottom:7px}.profile-stats{display:flex;gap:14px;font-size:13px;color:var(--txt2)}
.profile-stats strong{color:var(--txt);font-weight:700}
.settings-wrap{max-width:620px;margin:0 auto;padding:22px 16px}
.settings-wrap h1{font-family:'Space Grotesk',sans-serif;font-size:22px;font-weight:800;margin-bottom:22px}
.settings-card{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r-xl);padding:18px 20px;margin-bottom:14px}
.settings-card-title{font-size:14px;font-weight:600;margin-bottom:14px;padding-bottom:9px;border-bottom:1px solid var(--bdr)}
.form-group{margin-bottom:12px}
.form-label{display:block;font-size:11px;font-weight:700;letter-spacing:.8px;color:var(--txt3);text-transform:uppercase;margin-bottom:5px}
.form-input{width:100%;background:var(--bg3);border:1px solid var(--bdr);border-radius:var(--r);color:var(--txt);font-size:13px;padding:9px 12px;outline:none;transition:border-color var(--t)}
.form-input:focus{border-color:var(--acc)}.form-input::placeholder{color:var(--txt3)}
.form-error{font-size:12px;color:#ff5050;margin-top:5px;min-height:16px}.form-hint{font-size:11px;color:var(--txt3);margin-top:3px}
.btn-submit{width:100%;padding:11px;background:var(--acc);border:none;border-radius:var(--r);color:#fff;font-size:13px;font-weight:700;cursor:pointer;transition:all var(--t);margin-top:4px}
.btn-submit:hover{background:var(--acc2);transform:translateY(-1px)}
.avatar-row{display:flex;align-items:center;gap:14px}
.avatar-preview{width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,var(--acc),var(--gold));display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;overflow:hidden;flex-shrink:0}
.avatar-preview img{width:100%;height:100%;object-fit:cover}
.btn-upload-avatar{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;background:var(--surf2);border:1px solid var(--bdr);border-radius:var(--r);font-size:12px;color:var(--txt2);cursor:pointer;transition:all var(--t)}
.btn-upload-avatar:hover{border-color:var(--bdr2);color:var(--txt)}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.78);backdrop-filter:blur(8px);z-index:500;display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;visibility:hidden;transition:opacity .22s ease,visibility .22s ease}
.modal-overlay.open{opacity:1;visibility:visible}
#choiceModalLegacy{z-index:600}
.modal-box{background:var(--bg3);border:1px solid var(--bdr2);border-radius:var(--r-xl);padding:26px;width:100%;max-width:400px;position:relative;box-shadow:0 20px 50px rgba(0,0,0,.6);transform:scale(.95) translateY(8px);transition:transform .22s ease}
.post-modal-box,.gen-detail-box{padding:0;width:auto;max-width:none;height:88vh;display:flex}
.modal-overlay.open .modal-box{transform:scale(1) translateY(0)}
.modal-box::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--acc),var(--gold),var(--acc),transparent);border-radius:var(--r-xl) var(--r-xl) 0 0}
.modal-close{position:absolute;top:13px;right:13px;width:26px;height:26px;border-radius:50%;background:var(--surf2);border:1px solid var(--bdr);color:var(--txt2);font-size:13px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--t);z-index:400}
.modal-close:hover{background:var(--acc);border-color:var(--acc);color:#fff}
.modal-logo{font-family:'Space Grotesk',sans-serif;font-size:20px;font-weight:800;text-align:center;margin-bottom:2px;color:var(--txt)}
.modal-logo em{font-style:normal;color:var(--acc)}.modal-kana{font-size:10px;color:rgba(0,220,255,.35);letter-spacing:3px;text-align:center;margin-bottom:14px}
.modal-sub{font-size:13px;color:var(--txt2);text-align:center;margin-bottom:16px}
.mana-banner{display:flex;align-items:center;gap:7px;padding:8px 12px;background:rgba(155,93,229,.06);border:1px solid rgba(0,220,255,.18);border-radius:var(--r);font-size:12px;color:rgba(0,220,255,.8);margin-bottom:14px}
.modal-tabs{display:flex;gap:3px;background:var(--surf);border-radius:var(--r);padding:3px;margin-bottom:14px}
.modal-tab{flex:1;padding:8px;border-radius:7px;background:transparent;color:var(--txt3);font-size:12px;font-weight:700;cursor:pointer;transition:all var(--t)}
.modal-tab.active{background:var(--surf2);color:var(--txt)}
.divider{display:flex;align-items:center;gap:10px;font-size:11px;color:var(--txt3);margin:14px 0}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:rgba(255,255,255,.07)}
.oauth-row{display:flex;gap:7px}
.oauth-row-top{flex-direction:column;gap:8px;margin-bottom:4px}
.oauth-col{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.btn-oauth{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;border:none;border-radius:50px;font-size:14px;font-weight:700;cursor:pointer;transition:all var(--t);font-family:'Space Grotesk',sans-serif}
.btn-oauth-google{background:#fff;color:#1a1a1a}
.btn-oauth-google:hover{background:#f0f0f0}
.btn-oauth-discord{background:#5865F2;color:#fff}
.btn-oauth-discord:hover{background:#4752c4}
.btn-oauth-x{background:#000;color:#fff;border:1px solid rgba(255,255,255,.15)}
.btn-oauth-x:hover{background:#111}
.choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.choice-card{padding:18px 12px;background:var(--surf);border:2px solid var(--bdr);border-radius:var(--r-lg);cursor:pointer;text-align:center;transition:all var(--t)}
.choice-card:hover{border-color:var(--acc);background:rgba(155,93,229,.05);transform:translateY(-2px)}
.choice-icon{font-size:28px;margin-bottom:8px}.choice-title{font-size:13px;font-weight:700;margin-bottom:3px}.choice-desc{font-size:11px;color:var(--txt2);line-height:1.5}
.shop-box{max-width:440px}.shop-header{text-align:center;margin-bottom:18px}
.shop-title{font-family:'Space Grotesk',sans-serif;font-size:18px;font-weight:800;margin-bottom:4px}
.shop-balance{display:inline-flex;align-items:center;gap:5px;padding:5px 14px;background:var(--surf2);border-radius:20px;font-size:13px;font-weight:600;margin-top:7px;color:var(--cyan)}
.shop-box{max-width:360px;margin:0 auto}
.packs-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}
.pack-card{padding:18px 8px;background:var(--surf2);border:1px solid var(--bdr);border-radius:var(--r-lg);cursor:pointer;text-align:center;transition:all var(--t);position:relative}
.pack-card:hover{border-color:var(--acc);transform:translateY(-2px)}.pack-card.featured{border-color:var(--acc);background:rgba(255,255,255,.04)}
.pack-bonus{position:absolute;top:-10px;left:50%;transform:translateX(-50%);background:var(--acc);color:#fff;font-size:9px;font-weight:800;padding:2px 8px;border-radius:20px;white-space:nowrap}
.pack-bonus.soft{background:var(--surf2);border:1px solid var(--acc);color:var(--acc)}
.pack-amount{display:flex;align-items:center;justify-content:center;gap:5px;margin-bottom:2px}
.pack-drop{font-size:18px;line-height:1}
.pack-mana-count{font-size:24px;font-weight:800;color:var(--cyan);line-height:1}
.pack-label{font-size:9px;color:var(--txt3);letter-spacing:.06em;text-transform:uppercase;margin-bottom:8px}
.pack-price{font-size:13px;font-weight:700;color:var(--txt2)}
.shop-info{font-size:11px;color:var(--txt3);text-align:center;line-height:1.8}
.gen-detail-box.video-mode{max-width:420px;height:auto;display:block}
.post-modal-inner{display:flex;height:88vh}
.post-modal-media{flex-shrink:0;background:var(--bg);overflow:hidden;position:relative;width:calc(88vh * 9 / 16);height:88vh;border-radius:var(--r-xl) 0 0 var(--r-xl)}
.post-modal-media img,.post-modal-media video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.post-modal-side{width:260px;flex-shrink:0;padding:52px 16px 16px;border-left:1px solid var(--bdr);display:flex;flex-direction:column;gap:10px;overflow-y:auto;border-radius:0 var(--r-xl) var(--r-xl) 0}
.video-mode .post-modal-side{width:100%;border-left:none}
.post-author{font-size:13px;font-weight:700}.post-comments{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:7px}
.comment-item{font-size:12px;padding:7px 9px;background:var(--surf2);border-radius:var(--r);line-height:1.5}
.comment-user{font-weight:700;color:var(--acc);margin-bottom:2px;font-size:11px}.comment-input textarea{height:58px;resize:none;margin-bottom:7px}
.btn-like{display:flex;align-items:center;gap:5px;padding:6px 13px;background:var(--surf2);border:1px solid var(--bdr);border-radius:20px;color:var(--txt2);font-size:13px;cursor:pointer;transition:all var(--t)}
.btn-like.liked,.btn-like:hover{color:var(--acc);border-color:rgba(255,45,107,.25);background:rgba(255,255,255,.04)}
/* Post modal — author row + action rows (desktop & drawer mobile) */
.post-author-row{display:flex;align-items:center;gap:10px;cursor:pointer;padding-bottom:12px;border-bottom:1px solid var(--bdr);flex-shrink:0;transition:opacity var(--t)}
.post-author-row:hover{opacity:.8}
.post-author-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--acc),var(--gold));display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;color:#fff;flex-shrink:0;overflow:hidden}
.post-author-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.post-author-info{display:flex;flex-direction:column;gap:1px;min-width:0}
.post-author{font-size:13px;font-weight:700;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.post-author-sub{font-size:11px;color:var(--txt3)}
.post-actions-list{display:flex;flex-direction:column;gap:6px;flex-shrink:0}
.post-action-row{display:flex;align-items:center;gap:9px;padding:8px 12px;background:var(--surf2);border:1px solid var(--bdr);border-radius:var(--r);color:var(--txt2);font-size:13px;cursor:pointer;width:100%;text-align:left;transition:all var(--t);font-family:'Space Grotesk',sans-serif}
.post-action-row:hover{background:var(--surf);border-color:var(--bdr2)}
.post-action-row.liked{color:var(--acc);border-color:rgba(255,45,107,.25);background:rgba(255,255,255,.04)}
.post-action-row.liked svg{fill:var(--acc);stroke:var(--acc)}
.post-action-row.favorited{color:var(--acc);border-color:rgba(255,45,107,.25);background:rgba(255,255,255,.04)}
.post-action-row.favorited svg{fill:var(--acc);stroke:var(--acc)}
.thank-box{max-width:360px;padding:0;overflow:hidden}.thank-img{width:100%;max-height:220px;object-fit:cover;display:block}
.thank-body{padding:22px;text-align:center}
.thank-title{font-family:'Space Grotesk',sans-serif;font-size:18px;font-weight:800;background:linear-gradient(135deg,var(--acc),#c026a0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:7px}
.mana-alert{position:fixed;bottom:18px;left:50%;transform:translateX(-50%) translateY(200px);background:var(--bg3);border:1px solid var(--bdr2);border-radius:var(--r-xl);padding:12px 16px;display:flex;align-items:center;gap:12px;box-shadow:0 12px 36px rgba(0,0,0,.5);z-index:600;transition:transform .28s ease;visibility:hidden;max-width:420px}
.mana-alert.show{transform:translateX(-50%) translateY(0);visibility:visible}.mana-alert-icon{font-size:22px;flex-shrink:0;line-height:1}
.mana-alert-body{flex:1;min-width:0}.mana-alert strong{font-size:13px;font-weight:700;display:block}.mana-alert span{font-size:11px;color:var(--txt2);white-space:normal}
.mana-alert-btn{padding:7px 14px;background:var(--acc);border:none;border-radius:20px;color:#fff;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;flex-shrink:0}
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:700;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s}
.lightbox.open{opacity:1;visibility:visible}.lightbox img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:var(--r-lg)}
.lightbox-close{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.1);color:#fff;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--t)}
.lightbox-close:hover{background:var(--acc)}
.lightbox-dl{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);padding:8px 18px;background:rgba(255,255,255,.08);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.18);border-radius:20px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:background var(--t)}
.lightbox-dl:hover{background:var(--acc);border-color:var(--acc)}
@media(max-width:1200px){.media-grid{columns:4}.comm-grid,.gen-grid,.live-char-grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:900px){.media-grid{columns:3}.comm-grid,.gen-grid,.live-char-grid{grid-template-columns:repeat(3,1fr)}.studio-grid{grid-template-columns:1fr}.nav-links{display:none}.hamburger{display:flex}.lang-sw{display:none}}
@media(max-width:600px){.select-bar{bottom:86px!important}.media-grid{columns:2}.comm-grid,.gen-grid,.live-char-grid{grid-template-columns:repeat(2,1fr)}.bottom-nav{display:flex}.main{padding-bottom:70px}.nav{padding:0 12px}.nav-mana{display:none!important}.post-modal-inner{flex-direction:column}.post-modal-media{width:100%;aspect-ratio:9/16;height:auto}.post-modal-side{width:100%;border-left:none;border-top:1px solid var(--bdr)}.packs-grid{grid-template-columns:1fr 1fr}.choice-grid{grid-template-columns:1fr}.modal-overlay{padding:6px}.nav-mana{display:none!important}.post-modal-box,.gen-detail-box{max-height:92vh;overflow-y:auto}.post-modal-inner{min-height:unset}.post-modal-media{width:100%}.post-modal-media img,.post-modal-media video{height:auto;max-height:none;object-fit:contain}.btn-like{align-self:flex-start}.modal-close{position:fixed;top:10px;right:10px;z-index:600}.btn-gen{display:none!important}.hamburger{display:none!important}#bn-community,#bn-explore{margin:0 6px}}
/* ── CHOICE GALLERY MODAL ── */
.choice-gallery-box{max-width:580px;padding:22px 20px 18px}
.choice-gallery{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:220px;gap:8px;max-height:75vh;overflow-y:auto;margin-top:2px;scrollbar-width:thin;scrollbar-color:var(--surf2) transparent}
.choice-gallery::-webkit-scrollbar{width:3px}.choice-gallery::-webkit-scrollbar-thumb{background:var(--surf2)}
.choice-gallery-loading{grid-column:1/-1;display:flex;align-items:center;justify-content:center;padding:40px 0}
.choice-gallery-empty{grid-column:1/-1;text-align:center;padding:30px 0;color:var(--txt3);font-size:13px;line-height:1.8}
.choice-img-card{position:relative;width:100%;height:100%;border-radius:var(--r);overflow:hidden;cursor:pointer;border:2px solid transparent;background:var(--surf2);transition:border-color var(--t),transform var(--t)}
.choice-img-card:hover{border-color:var(--acc);transform:translateY(-2px)}
.choice-img-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}
.choice-img-card:hover img{transform:scale(1.06)}
.choice-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,12,12,.92) 0%,transparent 55%);opacity:0;transition:opacity .18s;display:flex;align-items:flex-end;justify-content:center;padding-bottom:10px}
.choice-img-card:hover .choice-img-overlay{opacity:1}
.choice-vid-thumb{position:absolute;inset:0;background:#0a0a14}
.choice-vid-play-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:1;pointer-events:none}
.choice-img-btn{padding:6px 14px;background:var(--acc);color:#fff;font-size:11px;font-weight:700;border-radius:var(--r);border:none;cursor:pointer;white-space:nowrap;transition:background var(--t)}
.choice-img-btn:hover{background:var(--acc2)}
.choice-cta-card{position:relative;width:100%;height:100%;border-radius:var(--r);overflow:hidden;cursor:pointer;border:2px dashed var(--bdr2);background:rgba(255,255,255,.02);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;transition:border-color var(--t),background var(--t)}
.choice-cta-card:hover{border-color:var(--acc);background:rgba(255,255,255,.04)}
.choice-cta-card.choice-cta-locked{border-color:rgba(255,45,107,.3);background:rgba(255,255,255,.02);opacity:.7}
.choice-cta-card.choice-cta-locked:hover{border-color:var(--violet);background:rgba(155,93,229,.08);opacity:1}
.choice-cta-icon{font-size:26px;line-height:1}
.choice-cta-label{font-size:11px;font-weight:700;color:var(--txt2);text-align:center;padding:0 8px;line-height:1.4;transition:color var(--t)}
.choice-cta-card:hover .choice-cta-label{color:var(--acc)}
.choice-cta-card.choice-cta-locked:hover .choice-cta-label{color:var(--violet)}
/* ── SHARE PLATFORM BUTTONS ── */
.btn-share-platform{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:10px 6px;border-radius:var(--r);border:1px solid var(--bdr);background:var(--surf2);color:#fff;cursor:pointer;transition:all var(--t);font-family:'Space Grotesk',sans-serif}
.btn-share-platform:hover{transform:translateY(-2px);border-color:transparent}
.btn-share-comm{color:#fff}.btn-share-comm:hover{background:#ff2d6b;box-shadow:0 4px 14px rgba(255,45,107,.35)}.btn-share-comm-active{background:#ff2d6b !important;border-color:transparent;box-shadow:0 4px 14px rgba(255,45,107,.35)}
.btn-share-x{color:#fff}.btn-share-x:hover{background:#000;border-color:#fff2;box-shadow:0 4px 14px rgba(0,0,0,.5)}
.btn-share-reddit{color:#fff}.btn-share-reddit:hover{background:#FF4500;box-shadow:0 4px 14px rgba(255,69,0,.4)}
/* ── LANG DROPDOWN ── */
.lang-drop{position:relative}
.lang-drop-btn{display:flex;align-items:center;gap:5px;padding:5px 10px;background:rgba(155,93,229,.06);border:1px solid var(--bdr);border-radius:var(--r);color:var(--txt2);font-size:12px;font-weight:700;cursor:pointer;transition:all var(--t)}
.lang-drop-btn:hover{border-color:var(--bdr2);color:var(--txt)}
.lang-drop-arrow{font-size:9px;opacity:.6;transition:transform var(--t)}
.lang-drop.open .lang-drop-arrow{transform:rotate(180deg)}
.lang-drop-menu{position:absolute;top:calc(100% + 6px);right:0;background:var(--bg3);border:1px solid var(--bdr2);border-radius:var(--r-lg);padding:5px;min-width:130px;box-shadow:0 12px 32px rgba(0,0,0,.5);opacity:0;visibility:hidden;transform:translateY(-6px);transition:all var(--t);z-index:300}
.lang-drop.open .lang-drop-menu{opacity:1;visibility:visible;transform:translateY(0)}
.lang-drop-item{display:flex;align-items:center;gap:8px;padding:8px 11px;border-radius:var(--r);font-size:13px;color:var(--txt2);cursor:pointer;width:100%;text-align:left;transition:all var(--t)}
.lang-drop-item:hover{background:var(--surf2);color:var(--txt)}
.lang-drop-item.active{color:var(--acc)}

/* ── VIDEO GEN MODAL ── */
/* layout global de la modal */
.vgm-box{max-width:720px;padding:18px 20px 16px;width:100%;display:flex;flex-direction:column;max-height:92vh;overflow:hidden}
/* header */
.vgm-header{display:flex;align-items:center;gap:9px;margin-bottom:12px}
.vgm-header-left{display:flex;align-items:center;gap:9px;flex:1}
.vgm-scene-title{font-family:'Space Grotesk',sans-serif;font-size:18px;font-weight:800;color:var(--txt)}
.vgm-tag{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;background:rgba(255,45,107,.15);border:1px solid rgba(255,45,107,.35);color:var(--violet);font-size:11px;font-weight:700;letter-spacing:.4px;text-transform:uppercase}
/* engrenage footer */
.vgm-gear-btn{width:36px;height:36px;border-radius:50%;background:var(--surf2);border:1px solid var(--bdr);color:var(--txt3);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--t);flex-shrink:0}
.vgm-gear-btn:hover{border-color:var(--bdr2);color:var(--txt);background:var(--surf)}
.vgm-hd-btn{width:42px;height:36px;border-radius:var(--r);background:var(--surf2);border:1px solid var(--bdr);color:var(--txt3);font-size:11px;font-weight:800;letter-spacing:.5px;cursor:pointer;transition:all var(--t);flex-shrink:0;display:flex;align-items:center;justify-content:center}
.vgm-hd-btn:hover{border-color:var(--acc);color:var(--acc)}
.vgm-hd-btn.active{background:linear-gradient(135deg,var(--acc),var(--gold));border-color:transparent;color:#fff;box-shadow:0 2px 10px rgba(255,45,107,.35)}
.vgm-tab-soon{opacity:.5;cursor:not-allowed!important}
.vgm-tab-soon:hover{background:transparent!important;color:var(--txt3)!important}
.vgm-soon-badge{font-size:9px;font-weight:800;letter-spacing:.5px;padding:2px 5px;border-radius:20px;background:var(--surf2);color:var(--txt3);text-transform:uppercase;margin-left:2px}
/* onglets */
.vgm-tabs{display:flex;gap:3px;background:var(--surf);border-radius:var(--r);padding:3px;margin-bottom:12px}
.vgm-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;border-radius:7px;background:transparent;color:var(--txt3);font-size:12px;font-weight:700;cursor:pointer;transition:all var(--t)}
.vgm-tab.active{background:var(--surf2);color:var(--txt)}
/* corps — hauteur fixe pour que height:100% fonctionne dans les colonnes */
.vgm-body{display:flex;align-items:stretch;gap:12px;height:calc(92vh - 180px);min-height:340px;max-height:520px}
.vgm-left{flex:1;min-width:0;display:flex;flex-direction:column}
/* image wrap : position:relative pour l'overlay "Changer" */
.vgm-img-wrap{position:relative;width:100%;height:100%;border-radius:var(--r-lg);overflow:hidden;background:var(--surf2);border:1px solid var(--bdr)}
.vgm-img-wrap img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.vgm-img-loader{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:var(--surf2);z-index:2}
.vgm-img-loader span{font-size:12px;color:var(--txt3)}
/* zone upload (visible uniquement si pas d'image) */
.vgm-upload-zone{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:pointer}
.vgm-upload-label{display:flex;flex-direction:column;align-items:center;gap:7px;cursor:pointer;color:var(--txt3);transition:color var(--t)}
.vgm-upload-label:hover{color:var(--acc)}
.vgm-upload-label span{font-size:12px;font-weight:600}
/* bouton Changer — overlay bas-centre, visible quand image présente */
.vgm-change-btn{position:absolute;bottom:10px;left:10px;right:10px;display:flex;align-items:center;justify-content:center;gap:7px;padding:9px 16px;background:rgba(15,12,12,.82);backdrop-filter:blur(8px);border:1px solid rgba(155,93,229,.4);border-radius:var(--r-lg);color:var(--acc);font-size:12px;font-weight:700;cursor:pointer;transition:all var(--t);white-space:nowrap}
.vgm-change-btn:hover{background:rgba(232,0,45,.18);border-color:var(--acc)}
/* extend info */
/* ── Extend Video panel ── */
.vgm-extend-info{width:100%;height:100%;border-radius:var(--r-lg);border:1px dashed var(--bdr2);background:rgba(255,255,255,.03);flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:18px}
.vgm-extend-info.has-video{padding:0;border:1px solid var(--bdr);background:var(--surf2);border-radius:var(--r-lg);overflow:hidden;position:relative;justify-content:flex-start}
.vgm-extend-info p{font-size:12px;color:var(--txt3);text-align:center;line-height:1.6}
.vgm-extend-pick-btn{display:flex;align-items:center;gap:7px;padding:8px 16px;background:var(--surf2);border:1px solid var(--bdr2);border-radius:var(--r);color:var(--txt);font-size:12px;font-weight:700;cursor:pointer;transition:all var(--t)}
.vgm-extend-pick-btn:hover{border-color:var(--acc);color:var(--acc)}
#vgmExtendEmpty{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%}
/* Player : même structure que vgm-img-wrap (absolute inset) */
#vgmExtendPlayer{position:absolute;inset:0}
#vgmExtendPlayer video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
/* Bouton changer — top-right overlay */
.vgm-extend-change-btn{position:absolute;top:8px;right:8px;z-index:4;display:flex;align-items:center;gap:5px;padding:5px 10px;background:rgba(5,5,8,.72);border:1px solid rgba(255,255,255,.2);border-radius:20px;color:#fff;font-size:11px;font-weight:700;cursor:pointer;backdrop-filter:blur(6px);transition:border-color var(--t)}
.vgm-extend-change-btn:hover{border-color:var(--acc2)}
/* Contrôles bas : scrubber + badge en overlay */
.vgm-extend-controls{position:absolute;bottom:0;left:0;right:0;z-index:3;padding:28px 10px 8px;background:linear-gradient(transparent,rgba(5,5,8,.85));display:flex;flex-direction:column;gap:4px}
.vgm-extend-last-badge{display:flex;align-items:center;gap:5px;padding:3px 9px;background:rgba(5,5,8,.65);border:1px solid rgba(155,93,229,.5);border-radius:20px;font-size:10px;font-weight:700;color:var(--acc2);white-space:nowrap;backdrop-filter:blur(4px);width:fit-content;margin:0 auto 2px}
.vgm-extend-scrubber{-webkit-appearance:none;appearance:none;width:100%;height:4px;border-radius:2px;background:rgba(255,255,255,.25);outline:none;cursor:pointer}
.vgm-extend-scrubber::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--acc2);cursor:pointer;border:2px solid #fff}
.vgm-extend-scrubber::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--acc2);cursor:pointer;border:2px solid #fff}
.vgm-extend-time-row{display:flex;justify-content:space-between;font-size:10px;color:rgba(255,255,255,.6);padding:0 2px}
/* flèche centrale */
.vgm-arrow{display:flex;align-items:center;justify-content:center;width:28px;flex-shrink:0;color:var(--txt3)}
/* colonne droite */
.vgm-right{flex:1;min-width:0}
.vgm-video-wrap{position:relative;width:100%;height:100%;border-radius:var(--r-lg);overflow:hidden;background:var(--surf2);border:1px solid var(--bdr)}
.vgm-video-wrap video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.vgm-video-wrap img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.vgm-right-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
/* footer */
.vgm-footer{margin-top:12px;display:flex;align-items:center;gap:10px}
.vgm-footer-gear{flex-shrink:0}
.vgm-generate-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:10px;padding:11px 20px;background:linear-gradient(135deg,var(--acc),var(--gold));border:none;border-radius:var(--r-xl);color:#fff;font-size:14px;font-weight:700;cursor:pointer;transition:all var(--t);box-shadow:0 4px 18px rgba(255,45,107,.25)}
.vgm-generate-btn:hover{transform:translateY(-2px);box-shadow:0 8px 26px rgba(255,45,107,.35)}
.vgm-generate-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.vgm-mana-cost{display:flex;align-items:center;gap:4px;padding:3px 10px;background:rgba(0,0,0,.25);border-radius:20px;font-size:12px;font-weight:700}
@media(max-width:560px){.vgm-box{padding:12px 10px;max-height:98vh;overflow-y:auto}.vgm-body{flex-direction:row;height:260px;min-height:260px;max-height:260px}.vgm-left,.vgm-right{height:260px}.vgm-arrow{width:14px;flex-shrink:0}}

/* ── VIDEO SETTINGS MODAL ── */
.vsm-box{max-width:340px;padding:22px 20px 18px}
.vsm-title{display:flex;align-items:center;gap:8px;font-family:'Space Grotesk',sans-serif;font-size:16px;font-weight:800;margin-bottom:18px;color:var(--txt)}
.vsm-section{margin-bottom:16px}
.vsm-label{font-size:11px;font-weight:700;letter-spacing:.8px;color:var(--txt3);text-transform:uppercase;margin-bottom:8px}
.vsm-options{display:flex;gap:6px}
.vsm-opt{flex:1;position:relative;padding:9px 6px;border-radius:var(--r);background:var(--surf2);border:1px solid var(--bdr);color:var(--txt2);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--t);text-align:center}
.vsm-opt:hover:not(:disabled){border-color:var(--bdr2);color:var(--txt)}
.vsm-opt.active{background:rgba(255,45,107,.1);border-color:var(--acc);color:var(--acc)}
.vsm-opt:disabled,.vsm-opt.vsm-opt-locked{opacity:.45;cursor:not-allowed}
.vsm-badge{position:absolute;top:-7px;right:50%;transform:translateX(50%);padding:1px 5px;border-radius:4px;font-size:9px;font-weight:800;letter-spacing:.5px;line-height:1.6;white-space:nowrap}
.vsm-badge-premium{background:linear-gradient(135deg,var(--violet),#6d28d9);color:#fff}
.vsm-cost-row{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;background:var(--surf2);border-radius:var(--r-lg);margin-bottom:14px}
.vsm-cost-label{font-size:12px;color:var(--txt3);font-weight:600}
.vsm-cost-val{font-size:14px;color:var(--cyan);font-weight:700}

/* ── TOAST ── */
.fh-toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--bg3);border:1px solid var(--bdr2);border-radius:var(--r-xl);padding:11px 20px;font-size:13px;font-weight:600;color:var(--txt);box-shadow:0 12px 36px rgba(0,0,0,.5);z-index:700;white-space:nowrap;transition:transform .28s ease;pointer-events:none}
.fh-toast.show{transform:translateX(-50%) translateY(0)}

/* ── GEN CARD GENERATING STATE ── */
.gen-card-generating{overflow:hidden;border:1px solid rgba(255,45,107,.35)}
.gen-card .vid-loading-overlay{position:absolute;inset:0;background:var(--surf2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;z-index:2;border-radius:inherit;transition:opacity .3s}
.gen-card .vid-loading-overlay .gen-generating-spinner{width:28px;height:28px;border-width:2px}
.gen-card .vid-loading-overlay span{font-size:11px;color:var(--txt3);font-weight:600}
.comm-card .vid-loading-overlay{position:absolute;inset:0;background:var(--surf2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;z-index:2;transition:opacity .3s}
.comm-card .vid-loading-overlay .gen-generating-spinner{width:28px;height:28px;border-width:2px}
.comm-card .vid-loading-overlay span{font-size:11px;color:var(--txt3);font-weight:600}
.card-play-btn{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:32px;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.7);pointer-events:none;opacity:0;transition:opacity .2s}
.gen-card:hover .card-play-btn{opacity:1}
.gen-generating-overlay{position:absolute;inset:0;background:rgba(15,12,12,.72);backdrop-filter:blur(2px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:9px}
.gen-generating-icon{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--acc),var(--gold));display:flex;align-items:center;justify-content:center;color:#fff;animation:gen-pulse 1.8s ease-in-out infinite}
.gen-generating-spinner{width:40px;height:40px;border-radius:50%;border:3px solid rgba(255,255,255,.15);border-top-color:var(--acc);animation:spin .9s linear infinite}
.gen-generating-label{font-size:12px;font-weight:700;color:var(--txt2)}
.gen-queue-bottom{position:absolute;bottom:12px;left:8px;right:8px;display:flex;flex-direction:column;align-items:center;gap:7px}
.gen-queue-pos{font-size:14px;font-weight:700;color:var(--acc);text-align:center}
.gen-queue-libre-btn{font-size:11px;font-weight:700;color:rgba(242,237,228,.7);background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:20px;padding:8px 14px;cursor:pointer;text-align:center;width:100%;transition:all var(--t);font-family:'Space Grotesk',sans-serif}
.gen-queue-libre-btn:hover{background:rgba(155,93,229,.12);border-color:rgba(255,45,107,.35);color:#fff}
@keyframes gen-pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.08);opacity:.8}}

/* ── STUDIO PROMPT BOX ───────────────────────────────────── */
.prompt-wrap {
  position: relative;
}
.studio-prompt-ta {
  width: 100%;
  min-height: 220px;
  background: var(--bg3);
  border: 1.5px solid var(--bdr);
  border-radius: var(--r-lg);
  color: var(--txt);
  font-family: 'Space Grotesk', sans-serif;
  font-size: 15px;
  line-height: 1.7;
  padding: 16px 50px 52px 16px;
  resize: vertical;
  box-sizing: border-box;
  outline: none;
  transition: border-color var(--t), box-shadow var(--t);
}
.studio-prompt-ta:focus {
  border-color: var(--acc);
  box-shadow: 0 0 0 3px rgba(255,45,107,.1);
}
.studio-prompt-ta::placeholder {
  color: var(--txt3);
  font-style: italic;
  line-height: 1.7;
}
.btn-dice {
  position: absolute;
  bottom: 12px;
  right: 12px;
  background: var(--surf2);
  border: 1px solid var(--bdr);
  border-radius: var(--r);
  width: 38px;
  height: 38px;
  font-size: 20px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--t), border-color var(--t), transform .15s;
  line-height: 1;
  flex-shrink: 0;
}
.btn-dice:hover {
  background: rgba(155,93,229,.12);
  border-color: var(--acc);
  transform: rotate(20deg) scale(1.1);
}
.btn-dice:disabled {
  opacity: .45;
  cursor: not-allowed;
  transform: none;
  animation: diceSpinning .5s linear infinite;
}
.btn-mic {
  position: absolute;
  bottom: 10px;
  right: 10px;
  background: rgba(155,93,229,.12);
  border: 2px solid rgba(155,93,229,.4);
  border-radius: 50%;
  width: 36px;
  height: 36px;
  font-size: 16px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--t);
  color: #ff2d6b;
  flex-shrink: 0;
}
.btn-mic:hover { background: rgba(255,45,107,.25); border-color: #ff2d6b; }
.btn-mic.active { background: #dc2828; border-color: #ff4444; color: #fff; animation: micPulse 1.2s ease-in-out infinite; }
@keyframes micPulse { 0%,100%{box-shadow:0 0 0 0 rgba(220,40,40,.5)} 50%{box-shadow:0 0 0 8px rgba(220,40,40,0)} }
@keyframes diceSpinning {
  to { transform: rotate(360deg); }
}
.prompt-hint {
  font-size: 11px;
  color: var(--txt3);
  margin-top: 8px;
  text-align: center;
  letter-spacing: .2px;
}
@keyframes promptFlashNew {
  0%   { border-color: var(--acc); box-shadow: 0 0 0 4px rgba(255,45,107,.2); }
  100% { border-color: var(--bdr); box-shadow: none; }
}
.studio-prompt-ta.prompt-flash {
  animation: promptFlashNew .5s ease;
}

/* ── PREVIEW ACTIONS OVERLAY ─────────────────────────────── */
.preview-actions {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 14px 12px 12px;
  display: flex;
  gap: 8px;
  background: linear-gradient(to top, rgba(15,12,12,.95) 0%, rgba(15,12,12,.7) 55%, transparent 100%);
  animation: fadeIn .35s ease;
  z-index: 10;
}
.pa-btn {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  padding: 11px 12px;
  border-radius: var(--r-lg);
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: all var(--t);
  font-family: 'Space Grotesk', sans-serif;
  white-space: nowrap;
}
.pa-save {
  background: var(--acc);
  color: #050508;
  border: none;
}
.pa-save:hover {
  background: var(--acc2);
  transform: translateY(-1px);
}
.pa-regen {
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.16);
  color: var(--txt);
  backdrop-filter: blur(10px);
}
.pa-regen:hover {
  background: rgba(255,255,255,.07);
  border-color: var(--acc);
  color: var(--acc);
  transform: translateY(-1px);
}
.pa-regen:disabled {
  opacity: .4;
  cursor: not-allowed;
  transform: none;
}
.pa-regen-solo {
  max-width: 220px;
  margin: 0 auto;
}


/* ══════════════════════════════════════
   BOUTON PREMIUM (nav desktop + mobile)
══════════════════════════════════════ */
.btn-premium{display:none;align-items:center;gap:6px;padding:5px 13px;border-radius:var(--r);font-size:12px;font-weight:700;font-family:'Space Grotesk',sans-serif;cursor:pointer;transition:all var(--t);border:none}
.btn-premium.show{display:flex}
.btn-premium.state-free{background:linear-gradient(90deg,var(--acc),var(--violet));color:#fff;box-shadow:0 3px 12px rgba(255,45,107,.25)}
.btn-premium.state-free:hover{box-shadow:0 4px 18px rgba(232,0,45,.4);transform:translateY(-1px)}
.btn-premium.state-paid{background:var(--surf);border:1px solid var(--bdr);color:var(--txt)}
.btn-premium.state-paid:hover{border-color:var(--bdr2)}
.btn-mm-premium{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--acc),var(--gold));border:none;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--t)}
.btn-mm-premium:hover{transform:scale(1.1)}
.btn-mm-premium.state-paid{background:var(--surf2);border:1px solid var(--bdr)}

/* ══════════════════════════════════════
   PAGE ABONNEMENT
══════════════════════════════════════ */
.sub-wrap{max-width:740px;margin:0 auto;padding:28px 16px 60px}
.sub-mana-empty-banner{background:linear-gradient(90deg,rgba(255,45,107,.08),rgba(155,93,229,.08));border:1px solid rgba(255,45,107,.25);border-radius:var(--r-lg);padding:13px 16px;margin-bottom:20px;display:flex;align-items:flex-start;gap:10px}
.sub-mana-empty-icon{font-size:20px;flex-shrink:0}
.sub-mana-empty-text{font-size:13px;color:var(--txt2);line-height:1.5}
.sub-current-card{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r-xl);padding:16px 18px;margin-bottom:10px}
.sub-current-top{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.sub-current-plan-name{display:flex;align-items:center;gap:7px;font-size:14px;font-weight:700}
.sub-plan-badge{font-size:10px;font-weight:700;letter-spacing:.4px;padding:3px 8px;border-radius:20px;background:rgba(242,237,228,.07);border:1px solid var(--bdr);color:var(--txt3)}
.sub-plan-badge.badge-sakura{background:rgba(255,255,255,.07);border-color:rgba(255,45,107,.25);color:var(--acc)}
.sub-plan-badge.badge-oni{background:rgba(155,93,229,.12);border-color:rgba(255,45,107,.35);color:#c9a8ff}
.sub-info-icon{width:15px;height:15px;border-radius:50%;border:1px solid var(--bdr2);color:var(--txt3);font-size:9px;display:inline-flex;align-items:center;justify-content:center;cursor:help;flex-shrink:0}
.sub-current-mana{font-size:14px;font-weight:700}
.sub-drop-btn{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--txt3);cursor:pointer;padding:0;background:none;border:none;font-family:inherit;transition:color var(--t);margin-top:12px;padding-top:12px;border-top:1px solid var(--bdr);width:100%}
.sub-drop-btn:hover{color:var(--txt2)}
.sub-billing-row{display:flex;align-items:center;justify-content:center;gap:12px;margin:24px 0;flex-wrap:wrap}
.sub-billing-label{font-size:13px;font-weight:600;color:var(--txt2);transition:color var(--t);display:flex;align-items:center;gap:6px}
.sub-billing-active{color:var(--txt)}
.sub-toggle-pill{width:44px;height:24px;border-radius:20px;background:var(--surf2);border:1px solid var(--bdr2);cursor:pointer;position:relative;transition:background var(--t);flex-shrink:0}
.sub-toggle-pill.on{background:linear-gradient(90deg,var(--acc),var(--violet))}
.sub-toggle-knob{width:18px;height:18px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;transition:transform .22s ease;box-shadow:0 2px 6px rgba(0,0,0,.3)}
.sub-toggle-pill.on .sub-toggle-knob{transform:translateX(20px)}
.sub-saving-tag{display:inline-flex;align-items:center;background:linear-gradient(90deg,var(--cyan),var(--violet));color:#fff;font-size:11px;font-weight:800;padding:3px 10px;border-radius:20px;white-space:nowrap;box-shadow:0 3px 10px rgba(255,45,107,.25)}
.sub-plans-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;grid-template-rows:repeat(6,auto);align-items:start}
.sub-plan-card{border-radius:var(--r-xl);padding:24px 20px;position:relative;overflow:hidden;border:1px solid var(--bdr);display:grid;grid-row:span 6;grid-template-rows:subgrid;transition:transform .22s ease,border-color .22s ease}
.sub-plan-card:hover{transform:translateY(-3px)}
.sub-plan-sakura{border-color:rgba(255,45,107,.25);background:linear-gradient(145deg,#130d24 0%,#1a0d1f 100%)}
.sub-plan-sakura::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--acc),transparent)}
.sub-plan-oni{border-color:rgba(255,45,107,.35);background:linear-gradient(145deg,#110d2a 0%,#130a2e 100%)}
.sub-plan-oni::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--violet),var(--cyan),transparent)}
.sub-popular-badge{position:absolute;top:-1px;left:50%;transform:translateX(-50%);background:linear-gradient(90deg,var(--violet),var(--acc));color:#fff;font-size:9px;font-weight:800;letter-spacing:.6px;padding:4px 14px;border-radius:0 0 10px 10px;white-space:nowrap;text-transform:uppercase}
.sub-plan-target{font-size:10px;font-weight:700;letter-spacing:.6px;color:var(--txt3);text-transform:uppercase;margin-bottom:8px}
.sub-plan-name{font-family:'Space Grotesk',sans-serif;font-size:28px;font-weight:800;margin-bottom:14px}
.sub-sakura-name{color:var(--acc)}
.sub-oni-name{background:linear-gradient(90deg,var(--violet),var(--cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.sub-price-wrap{margin-bottom:18px}
.sub-price-row{display:flex;align-items:baseline;gap:5px}
.sub-price-orig{font-size:13px;color:var(--txt3);text-decoration:line-through}
.sub-price-val{font-size:32px;font-weight:800;line-height:1}
.sub-price-period{font-size:12px;color:var(--txt2)}
.sub-price-note{font-size:11px;color:var(--txt3);margin-top:3px;transition:opacity .2s}
.sub-btn-plan{width:100%;padding:12px;border-radius:var(--r-lg);font-size:13px;font-weight:700;font-family:'Space Grotesk',sans-serif;cursor:pointer;transition:all .2s;margin-bottom:20px;border:none;min-height:46px}
.sub-btn-sakura{background:var(--acc);color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.25)}
.sub-btn-sakura:hover{background:var(--acc2);transform:translateY(-1px)}
.sub-btn-oni{background:linear-gradient(90deg,var(--violet),#7c3aed);color:#fff;box-shadow:0 5px 18px rgba(155,93,229,.25)}
.sub-btn-oni:hover{box-shadow:0 7px 24px rgba(155,93,229,.4);transform:translateY(-1px)}
.sub-btn-unsub{background:transparent;border:1.5px solid rgba(255,255,255,.25);color:rgba(255,255,255,.6)}
.sub-btn-unsub:hover{border-color:rgba(255,80,80,.7);color:rgba(255,100,100,.9);transform:translateY(-1px)}
.sub-recharge-btn{display:inline-block;margin-left:10px;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:700;font-family:'Space Grotesk',sans-serif;cursor:pointer;background:transparent;border:1.5px solid var(--acc);color:var(--acc);transition:all .2s;vertical-align:middle}
.sub-recharge-btn:hover{background:var(--acc);color:#fff;transform:translateY(-1px)}
.sub-divider{height:1px;background:var(--bdr);margin-bottom:16px}
.sub-features{list-style:none;display:flex;flex-direction:column;gap:9px;align-self:start}
.sub-feat{display:flex;align-items:flex-start;gap:9px;font-size:12px;color:var(--txt2)}
.sub-feat-icon{width:16px;height:16px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:8px;margin-top:1px}
.sub-feat-pink{background:rgba(155,93,229,.12);color:var(--acc)}
.sub-feat-purple{background:rgba(155,93,229,.12);color:#c9a8ff}
.sub-feat strong{color:var(--txt);font-weight:600}
.sub-free-note{margin-top:20px;padding:12px 16px;background:rgba(242,237,228,.03);border:1px solid var(--bdr);border-radius:var(--r-lg);display:flex;align-items:flex-start;gap:10px;font-size:12px;color:var(--txt3);line-height:1.6}
.sub-free-note strong{color:var(--txt2)}
@media(max-width:600px){.sub-plans-grid{grid-template-columns:1fr}}

/* ── Studio background filigrane ── */
#page-create {
  position: relative;
}
#page-create::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image: var(--studio-bg, url('/assets/studio-bg.jpg'));
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  opacity: .07;
  pointer-events: none;
  z-index: 0;
  transition: background-image .4s ease;
}
#page-create .studio-wrap {
  position: relative;
  z-index: 1;
}

/* ── Studio mode tabs ── */
.studio-mode-tabs{display:flex;gap:6px;background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r-xl);padding:5px;margin-bottom:4px}
.smt-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;padding:10px 14px;border:none;border-radius:calc(var(--r-xl) - 4px);background:transparent;color:var(--txt3);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;font-family:'Space Grotesk',sans-serif;position:relative}
.smt-tab:hover{color:var(--txt);background:var(--surf2)}
.smt-tab.active{background:var(--bg);color:var(--txt);box-shadow:0 2px 8px rgba(0,0,0,.25)}
.smt-tab.active .smt-icon{filter:none}
.smt-icon{font-size:16px;line-height:1}
.smt-pro-badge{font-size:9px;font-weight:800;letter-spacing:.8px;padding:2px 6px;border-radius:20px;background:linear-gradient(135deg,#ff6b35,var(--violet));color:#fff;text-transform:uppercase;flex-shrink:0}
.smt-tab:not(.active) .smt-pro-badge{background:var(--surf2);color:var(--txt3)}
.smt-tab#smtForge:not(.active){position:relative}
.smt-tab#smtForge:not(.active)::after{content:'';position:absolute;inset:0;border-radius:inherit;background:linear-gradient(135deg,rgba(232,0,45,.06),rgba(155,93,229,.06));pointer-events:none}

/* ── Mode Libre layout ── */
.studio-wrap.libre-mode{max-width:900px}
.libre-layout{display:grid;grid-template-columns:280px 1fr;gap:24px;align-items:start;background:var(--surf);border:1px solid var(--bdr2);border-radius:var(--r-xl);padding:22px}
@media(min-width:601px){
  .studio-wrap.libre-mode .libre-layout{align-items:stretch}
  .studio-wrap.libre-mode .libre-char-col{display:flex;flex-direction:column;position:static}
  .studio-wrap.libre-mode .libre-char-card{flex:1;aspect-ratio:unset!important;min-height:0;display:flex!important;flex-direction:column}
  .studio-wrap.libre-mode .libre-slots-grid{flex:1;min-height:0}
  .studio-wrap.libre-mode .libre-slot{min-height:80px}
}
.libre-char-col{position:sticky;top:80px}
.libre-char-card{position:relative;width:100%;aspect-ratio:9/16;background:#120f1e;border:2px dashed rgba(255,45,107,.25);border-radius:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;transition:border-color .2s}
.libre-char-card:hover{border-color:rgba(232,0,45,.5)}
.libre-char-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}
.libre-char-hover{position:absolute;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;opacity:0;transition:opacity .2s;border-radius:14px}
.libre-char-card:hover .libre-char-hover{opacity:1}
.libre-slot{aspect-ratio:9/16;background:#120f1e;border:1px dashed rgba(255,45,107,.2);border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;overflow:hidden;transition:border-color .2s;width:100%}
.libre-slot:hover{border-color:rgba(155,93,229,.4)}
.libre-slot.filled{border-color:rgba(155,93,229,.4)}
.libre-slot-remove{position:absolute;top:3px;right:3px;width:16px;height:16px;border-radius:50%;background:rgba(220,40,40,.85);color:#fff;font-size:9px;font-weight:700;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:3;line-height:1}
.libre-slots-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;width:100%}
.libre-controls-col{display:flex;flex-direction:column}
.libre-step-header{display:none;align-items:center;gap:10px;margin-bottom:10px}
.libre-step-num{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--acc),var(--gold));color:#fff;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.libre-step-title{font-size:13px;font-weight:700;color:var(--txt)}
.libre-step-sub{font-size:11px;color:var(--txt3);margin-top:2px}
.libre-sep-top{margin-top:14px;padding-top:14px;border-top:1px solid var(--bdr)}
@media(max-width:700px){
  .libre-layout{grid-template-columns:1fr;gap:0;padding:16px}
  .libre-char-col{position:static}
  .libre-char-card{max-width:none;margin:0}
  .libre-label-desktop{display:none!important}
  .libre-hide-mobile{display:none!important}
  .libre-step-header{display:flex}
  .libre-slot{aspect-ratio:3/4}
  .libre-controls-col .prompt-wrap{margin-top:4px}
}

.settings-notif-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:4px 0}
.settings-notif-label{font-size:14px;font-weight:600;color:var(--txt);margin-bottom:3px}
.settings-notif-desc{font-size:12px;color:var(--txt3)}
.settings-notif-sep{height:1px;background:var(--bdr);margin:12px 0}
.notif-toggle{width:44px;height:24px;border-radius:20px;background:var(--surf2);border:1px solid var(--bdr2);cursor:pointer;position:relative;transition:background var(--t);flex-shrink:0;padding:0}
.notif-toggle[aria-pressed="true"]{background:var(--acc);border-color:transparent}
.notif-toggle-knob{width:18px;height:18px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;transition:transform .22s ease;display:block;box-shadow:0 2px 4px rgba(0,0,0,.3)}
.notif-toggle[aria-pressed="true"] .notif-toggle-knob{transform:translateX(20px)}
.settings-danger-card{background:rgba(255,79,79,.07);border:1px solid rgba(255,79,79,.3)!important}
.settings-danger-title{color:#ff5050!important;border-bottom-color:rgba(255,79,79,.2)!important}
.settings-danger-desc{font-size:13px;color:var(--txt2);line-height:1.55;margin:0 0 16px}
.btn-danger-zone{width:100%;padding:11px;background:transparent;border:1px solid #ff5050;border-radius:var(--r);color:#ff5050;font-size:13px;font-weight:700;cursor:pointer;transition:all var(--t);font-family:inherit}
.btn-danger-zone:hover{background:#ff5050;color:#fff}
.modal-box-danger{border-color:rgba(255,79,79,.35)!important}
.modal-danger-icon{font-size:26px;margin-bottom:10px}
.modal-danger-title{font-size:17px;font-weight:800;color:#ff5050;margin-bottom:8px}
.modal-danger-desc{font-size:13px;color:var(--txt2);line-height:1.6;margin-bottom:18px}
.modal-danger-label{font-size:12px;color:var(--txt2);margin-bottom:8px}
.modal-danger-label strong{color:var(--txt)}
.modal-danger-actions{display:flex;gap:10px;margin-top:14px}
.btn-secondary-outline{flex:1;padding:10px;background:transparent;border:1px solid var(--bdr2);border-radius:var(--r);color:var(--txt2);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all var(--t)}
.btn-secondary-outline:hover{border-color:var(--txt2);color:var(--txt)}
.btn-danger-confirm{flex:1;padding:10px;background:#ff5050;border:none;border-radius:var(--r);color:#fff;font-size:13px;font-weight:700;cursor:pointer;opacity:.35;transition:opacity var(--t);font-family:inherit}
.btn-danger-confirm:not(:disabled){opacity:1}
.choice-cta-badge{font-size:9px;font-weight:800;padding:3px 10px;border-radius:20px;background:rgba(255,255,255,.07);border:1px solid rgba(255,45,107,.25);color:#ff2d6b;letter-spacing:.04em;margin-top:2px}
.choice-cta-premium{margin-top:8px;padding:6px 14px;background:#fff;color:#0d0a1a;font-size:11px;font-weight:800;border-radius:50px;white-space:nowrap;pointer-events:none;display:inline-block}
.otp-inputs{display:flex;gap:10px;justify-content:center;margin:20px 0}
.otp-digit{width:44px;height:54px;border-radius:var(--r-lg);background:var(--bg3);border:1.5px solid var(--bdr);color:var(--txt);font-size:24px;font-weight:700;text-align:center;outline:none;transition:border-color var(--t);caret-color:transparent}
.otp-digit:focus{border-color:var(--acc)}
.otp-resend{display:block;margin:10px auto 0;background:none;border:none;color:var(--txt3);font-size:12px;cursor:pointer;text-decoration:underline;font-family:inherit;transition:color var(--t)}
.otp-resend:hover{color:var(--acc)}
.site-footer{display:flex;align-items:center;justify-content:center;gap:8px;padding:20px 24px;border-top:1px solid var(--bdr);font-size:12px;color:var(--txt3)}.site-footer a{color:var(--txt3);transition:color .15s}.site-footer a:hover{color:var(--acc)}.footer-sep{color:var(--txt3);opacity:.4}

/* ═══════════════════════════════════════════════════════
   MOBILE FULL-SCREEN MODAL (post / gen detail) ≤600px
═══════════════════════════════════════════════════════ */
@media(max-width:600px){
  /* Écrase le padding de l'overlay pour ces modals */
  #postModal.open,#genDetailModal.open{padding:0}
  /* Box full-screen */
  .post-modal-box,.gen-detail-box{width:100vw;height:100dvh;max-height:100dvh;border-radius:0;overflow:hidden;position:relative;display:block}
  /* Inner relatif, plein écran */
  .post-modal-inner{position:relative;width:100%;height:100dvh;flex-direction:row;min-height:unset}
  /* Média absolu, plein écran, cover */
  .post-modal-media{position:absolute;inset:0;width:100%!important;height:100%!important;aspect-ratio:unset!important;border-radius:0}
  .post-modal-media img,.post-modal-media video{object-fit:cover;height:100%!important;max-height:none!important}
  /* Side panel → drawer slide-up */
  .post-modal-side{position:absolute;bottom:0;left:0;right:0;width:auto!important;border-left:none!important;border-top:none;border-radius:var(--r-xl) var(--r-xl) 0 0;background:rgba(9,6,15,.96);backdrop-filter:blur(16px);max-height:72vh;overflow-y:auto;padding:8px 18px 28px;transform:translateY(101%);transition:transform .32s cubic-bezier(.4,0,.2,1);z-index:6}
  .post-modal-side.mob-open{transform:translateY(0)}
  /* Handle + backdrop */
  .mob-drawer-backdrop{display:block;position:absolute;inset:0;background:rgba(0,0,0,.5);z-index:5;opacity:0;visibility:hidden;transition:opacity .28s ease,visibility .28s ease}
  .mob-drawer-backdrop.visible{opacity:1;visibility:visible}
  .mob-drawer-handle{width:38px;height:4px;border-radius:2px;background:rgba(255,255,255,.2);margin:0 auto 14px;cursor:pointer;flex-shrink:0}
  /* Bottom action bar — colonne droite TikTok-style */
  .mob-bottom-bar{display:flex!important;position:absolute;bottom:0;right:0;top:0;width:auto;z-index:4;padding:20px 10px 48px;align-items:flex-end;pointer-events:none}
  .mob-bottom-bar>*{pointer-events:auto}
  .mob-bar-right{display:flex;flex-direction:column;align-items:center;gap:14px}
  .mob-author-wrap{display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer;margin-bottom:4px}
  .mob-author-avatar{width:44px;height:44px;border-radius:50%;border:2px solid #fff;overflow:hidden;background:linear-gradient(135deg,var(--acc),var(--gold));display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:700;color:#fff;flex-shrink:0}
  .mob-author-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}
  .mob-bar-author{font-size:13px;font-weight:700;color:#fff;text-shadow:0 1px 6px rgba(0,0,0,.7);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .mob-action-btn{width:46px;height:46px;border-radius:50%;background:rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.18);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;backdrop-filter:blur(6px);transition:background var(--t);padding:0}
  .mob-action-btn:active{background:rgba(255,45,107,.35)}
  .mob-action-btn.liked svg{fill:var(--acc);stroke:var(--acc)}
  .mob-action-btn.favorited svg{fill:var(--acc);stroke:var(--acc)}
  .mob-action-label{font-size:11px;font-weight:700;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.7);margin-top:-10px;min-height:14px}
  #postMobAuthor{margin-top:0;font-size:10px;max-width:52px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}
  /* Masquer les éléments desktop inutiles dans le drawer mobile */
  .post-modal-side .post-author-sub{display:none}
  /* Bouton fermeture en position fixe */
  #postModal .modal-close,#genDetailModal .modal-close{position:fixed;top:14px;right:14px;z-index:400}
  /* Mode gen : masquer auteur, afficher download/share */
  .mob-gen-only{display:none!important}
  #postModal[data-mode="gen"] .mob-author-wrap{display:none!important}
  #postModal[data-mode="gen"] .mob-gen-only{display:flex!important}
  #postModal[data-mode="gen"] #btnPostMobLike{order:1}
  #postModal[data-mode="gen"] #postMobLikeCount{order:2}
  #postModal[data-mode="gen"] #btnPostMobComment{order:3}
  #postModal[data-mode="gen"] #postMobCommentCount{order:4}
  #postModal[data-mode="gen"] #btnPostMobFav{order:5}
  #postModal[data-mode="gen"] #postMobFavLabel{order:6}
  #postModal[data-mode="gen"] #btnPostMobShare{order:7}
  #postModal[data-mode="gen"] #mobLabelShare{order:8}
  #postModal[data-mode="gen"] #btnPostMobDownload{order:9}
  #postModal[data-mode="gen"] #mobLabelDownload{order:10}
}
@media(min-width:601px){
  .mob-bottom-bar{display:none!important}
  .mob-drawer-backdrop{display:none!important}
  .mob-drawer-handle{display:none!important}
}
@media(max-width:600px){
  .mob-bar-share-row{display:flex;gap:6px;margin-top:8px}
  .mob-bar-share-row .btn-share-platform{padding:7px 10px;min-width:52px;background:rgba(0,0,0,.45);backdrop-filter:blur(6px);border-color:rgba(255,255,255,.15)}
}
.libre-hint-box{font-size:11px;font-weight:600;color:rgba(255,200,80,.85);background:rgba(255,200,80,.07);border:1px solid rgba(255,200,80,.2);border-radius:var(--r);padding:7px 10px;margin:6px 0 14px;line-height:1.5}
.mob-sound-wrap{position:relative;display:flex;align-items:center;justify-content:center;width:46px;height:46px;cursor:pointer;}
.mob-sound-slash{position:absolute;width:2.5px;height:32px;background:var(--acc);border-radius:2px;transform:rotate(40deg);pointer-events:none;transition:opacity .15s;}
.mob-sound-slash.hidden{opacity:0;}
.studio-wrap.creer-mode{max-width:900px}
.creer-layout{display:grid;grid-template-columns:1fr 2fr;gap:18px;align-items:stretch;background:var(--surf);border:1px solid var(--bdr2);border-radius:var(--r-xl);padding:20px}
.creer-left{display:flex;flex-direction:column;gap:10px}
.creer-right{display:flex;flex-direction:column;gap:10px}
.creer-step-header{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.creer-char-pick{position:relative;width:100%;flex:1;min-height:200px;background:#120f1e;border:2px dashed rgba(255,45,107,.25);border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;transition:border-color .2s}
.creer-char-pick:hover{border-color:rgba(232,0,45,.5)}
.creer-char-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;color:rgba(155,93,229,.4);text-align:center;padding:12px;gap:6px}
.creer-char-remove{position:absolute;top:6px;right:6px;width:20px;height:20px;border-radius:50%;background:rgba(220,40,40,.85);color:#fff;font-size:10px;font-weight:700;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:3}
.creer-videos-grid{flex:1;display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr);gap:6px}
.creer-video-card{position:relative;aspect-ratio:9/16;border-radius:var(--r);overflow:hidden;cursor:pointer;background:#120f1e;transition:transform .18s,border-color .18s;border:2px solid transparent}
.creer-video-card:hover{transform:translateY(-2px);border-color:var(--acc)}
.creer-video-card video,.creer-video-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.creer-loading{grid-column:1/-1;text-align:center;padding:20px;color:var(--txt3);font-size:12px}
.creer-right-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:8px;flex-wrap:nowrap}
.creer-right-head .creer-step-header{flex:1;min-width:0}
.creer-right-head .creer-step-header .libre-step-sub{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.creer-right-nav{display:flex;align-items:center;gap:6px;flex-shrink:0;white-space:nowrap}
.creer-videos-wrap{position:relative;padding:0 18px}
.creer-arr{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,.6);border:1.5px solid rgba(255,255,255,.2);color:#fff;font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;transition:background var(--t),border-color var(--t);font-family:inherit;line-height:1}
.creer-arr:hover:not(:disabled){background:var(--acc);border-color:var(--acc)}
.creer-arr:disabled{opacity:.25;cursor:default}
.creer-arr.arr-left{left:0}
.creer-arr.arr-right{right:0}
.creer-nav-btn{width:28px;height:28px;border-radius:50%;background:var(--surf2);border:1px solid var(--bdr);color:var(--txt2);font-size:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--t);font-family:inherit}
.creer-nav-btn:hover:not(:disabled){border-color:var(--acc);color:var(--acc)}
.creer-nav-btn:disabled{opacity:.3;cursor:default}
@media(max-width:700px){.creer-layout{grid-template-columns:1fr}.creer-char-pick{min-height:unset;aspect-ratio:3/4}.creer-videos-grid{grid-template-rows:auto}}
/* ── Studio tab long/short labels ── */
.smt-label-short{display:none}
@media(max-width:700px){.smt-label-long{display:none}.smt-label-short{display:inline}}
/* ── Creer animation selected ── */
.creer-video-card.selected{border-color:var(--acc);box-shadow:0 0 0 1px var(--acc)}
.creer-video-card .creer-vid-name{position:absolute;bottom:0;left:0;right:0;padding:28px 10px 8px;background:linear-gradient(to top,rgba(0,0,0,.9) 60%,transparent);font-size:12px;font-weight:800;color:#fff;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;letter-spacing:.02em;text-shadow:0 1px 4px rgba(0,0,0,.8)}
.creer-video-card .creer-vid-check{position:absolute;top:5px;left:5px;width:18px;height:18px;border-radius:50%;background:var(--acc);color:#fff;font-size:11px;font-weight:800;display:none;align-items:center;justify-content:center;z-index:3}
.creer-video-card.selected .creer-vid-check{display:flex}
.creer-hd-btn{padding:10px 14px;background:var(--surf2);border:1px solid var(--bdr2);border-radius:var(--r);color:var(--txt2);font-size:12px;font-weight:800;cursor:pointer;font-family:inherit;transition:all var(--t);white-space:nowrap}

.creer-gear-btn{width:36px;height:36px;border-radius:var(--r-md);border:1px solid var(--bdr);background:var(--surf2);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--t);position:relative;color:var(--txt2)}
.creer-gear-btn:hover,.creer-gear-btn.active{border-color:var(--acc);color:var(--acc);background:rgba(155,93,229,.1)}
.creer-gear-btn.active svg{transform:rotate(60deg)}
.creer-gear-btn svg{transition:transform .4s}
.creer-gear-dot{width:6px;height:6px;border-radius:50%;background:var(--acc);position:absolute;top:5px;right:5px;display:none}
.creer-gear-btn.has-opts .creer-gear-dot{display:block}
.creer-section-label{font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--txt3)}
.creer-thumb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:6px}
.creer-thumb{aspect-ratio:1;border-radius:var(--r-md);border:1.5px solid var(--bdr);background:var(--surf1);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--txt3);transition:all var(--t);padding:4px;text-align:center;user-select:none}
.creer-thumb:hover{border-color:var(--acc2);color:var(--txt2)}
.creer-thumb.selected{border-color:var(--acc);background:rgba(155,93,229,.1);color:var(--acc)}
.creer-ti{font-size:18px;line-height:1;display:block}
.creer-tl{font-size:9px;line-height:1.2;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.creer-hd-btn.active{background:rgba(155,93,229,.12);border-color:var(--acc);color:var(--acc)}
@media(min-width:601px){#studioPageTitle{display:none}}

/* ── Character Studio desktop layout ── */
.studio-wrap.character-mode{max-width:900px}
@media(min-width:601px){
  /* Box unique englobante */
  .studio-wrap.character-mode .studio-grid{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:stretch;background:var(--surf);border:1px solid var(--bdr2);border-radius:var(--r-xl);padding:20px}
  /* Left col : contenu poussé vers le bas */
  .studio-wrap.character-mode .studio-col:first-child{display:flex;flex-direction:column;gap:10px;height:100%;box-sizing:border-box}
  .studio-wrap.character-mode .panel{background:transparent;border:none;border-radius:0;padding:0;flex:1;display:flex;flex-direction:column;box-sizing:border-box}
  .studio-wrap.character-mode .panel-body{padding:0;flex:1;display:flex;flex-direction:column;gap:10px}
  .studio-wrap.character-mode .prompt-wrap{flex:1;display:flex;flex-direction:column}
  .studio-wrap.character-mode .studio-prompt-ta{flex:1;min-height:200px;resize:none}
  .studio-wrap.character-mode .char-gen-row{margin-top:0!important}
  /* Right col : image remplit toute la hauteur, angles arrondis */
  .studio-wrap.character-mode #studioColPreview{display:flex;flex-direction:column;width:220px;flex-shrink:0}
  .studio-wrap.character-mode .preview-area{flex:1;aspect-ratio:unset;height:100%;width:100%;border-radius:14px;overflow:hidden;min-height:300px}
  .studio-wrap.character-mode .preview-area img{width:100%;height:100%;object-fit:cover;border-radius:14px}
  .studio-wrap.character-mode #btnRegenDesktop{display:none}
}
@media(max-width:600px){
  .studio-wrap.character-mode #studioColPreview{display:none}
  .studio-wrap.character-mode #studioColPreview.visible{display:block}
}

/* ═══════════════════════════════════════════════════════════
   LIVE FEATURE
═══════════════════════════════════════════════════════════ */

/* ── Badge Live next to logo (mobile only) ── */
#liveNavBadge{display:none}
@media(max-width:767px){
  #liveNavBadge.live-visible{display:flex!important}
  #bn-live{display:none!important}
}
@media(min-width:768px){
  #liveNavBadge{display:none!important}
}

/* ── Page Live (listing) ── */
.live-empty{text-align:center;padding:60px 20px;color:var(--txt3);font-size:14px}

.live-char-card{position:relative;aspect-ratio:9/16;border-radius:var(--r-lg);overflow:hidden;cursor:pointer;background:var(--surf2)}
.live-char-card:hover .live-card-overlay{opacity:1}
.live-card-img{width:100%;height:100%;object-fit:cover;display:block}
.live-card-placeholder{width:100%;height:100%;background:linear-gradient(160deg,#1a0a2e,#6b1060);display:flex;align-items:center;justify-content:center;font-size:48px;color:rgba(255,255,255,.2)}
.live-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.75) 0%,transparent 50%);transition:opacity var(--t)}
.live-card-dot{position:absolute;top:10px;right:10px;width:8px;height:8px;border-radius:50%;background:#00e07a;box-shadow:0 0 0 2px rgba(0,224,122,.3);animation:livePulse 1.5s ease-in-out infinite}
.live-card-name{position:absolute;bottom:12px;left:12px;right:12px;font-size:14px;font-weight:700;color:#fff}
.live-card-meta{font-size:11px;color:rgba(255,255,255,.55);margin-top:2px}
@keyframes livePulse{0%,100%{opacity:1}50%{opacity:.4}}

/* ── Plein écran — base mobile ── */
.live-fullscreen{position:fixed;inset:0;z-index:400;background:#0a0010;transform:translateX(100%);transition:transform .3s ease}
.live-fullscreen.open{transform:translateX(0)}
.live-fs-inner{position:relative;width:100%;height:100%}

/* Video col — mobile: prend tout l'écran */
.live-fs-video-col{position:absolute;inset:0}
#liveVideo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.live-fs-gradient-top{position:absolute;top:0;left:0;right:0;height:140px;background:linear-gradient(to bottom,rgba(0,0,0,.7),transparent);z-index:1;pointer-events:none}
.live-fs-gradient-bot{position:absolute;bottom:0;left:0;right:0;height:300px;background:linear-gradient(to top,rgba(0,0,0,.88),transparent);z-index:1;pointer-events:none}

/* Top bar */
.live-topbar{position:absolute;top:0;left:0;right:0;z-index:2;display:flex;align-items:center;justify-content:space-between;padding:14px 14px;padding-top:calc(14px + env(safe-area-inset-top))}
.live-back-btn{width:34px;height:34px;border-radius:50%;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}
.live-topbar-info{display:flex;align-items:center;gap:7px}
.live-topbar-name{font-size:15px;font-weight:700;color:#fff}
.live-pill{font-size:10px;font-weight:700;background:#ff2d6b;color:#fff;padding:2px 7px;border-radius:10px;letter-spacing:.3px}
/* Bouton action dans topbar sur mobile */
.live-action-btn{background:rgba(232,0,45,.88);border:none;border-radius:20px;padding:6px 12px;color:#fff;font-size:13px;font-weight:700;cursor:pointer}
.live-eye-btn{width:32px;height:32px;border-radius:50%;background:rgba(0,0,0,.4);border:none;display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;flex-shrink:0}

/* Chat panel — mobile: overlay bas */
.live-fs-chat-panel{position:absolute;bottom:0;left:0;right:0;z-index:2;padding:0 14px calc(14px + env(safe-area-inset-bottom))}
.live-msgs{max-height:180px;overflow-y:auto;display:flex;flex-direction:column;gap:7px;margin-bottom:10px}
.live-msgs::-webkit-scrollbar{display:none}
.live-msg{font-size:13px;line-height:1.45;padding:7px 11px;border-radius:12px;max-width:82%;word-wrap:break-word}
.live-msg-char{background:rgba(0,0,0,.65);color:#fff;align-self:flex-start;border-radius:12px 12px 12px 3px;backdrop-filter:blur(2px)}
.live-msg-user{background:rgba(232,0,45,.65);color:#fff;align-self:flex-end;border-radius:12px 12px 3px 12px}
.live-typing{display:flex;align-items:center;gap:4px;padding:9px 13px}
.live-typing span{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.5);animation:typingDot 1.2s ease-in-out infinite}
.live-typing span:nth-child(2){animation-delay:.2s}
.live-typing span:nth-child(3){animation-delay:.4s}
@keyframes typingDot{0%,80%,100%{transform:scale(.8);opacity:.4}40%{transform:scale(1);opacity:1}}
.live-chat-row{display:flex;gap:8px;align-items:center}
.live-chat-input{flex:1;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:22px;padding:9px 15px;font-size:16px;color:#fff;outline:none;backdrop-filter:blur(8px)}
.live-chat-input::placeholder{color:rgba(255,255,255,.35)}
.live-chat-input:focus{border-color:rgba(155,93,229,.4)}
.live-send-btn{width:36px;height:36px;border-radius:50%;background:var(--acc);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;cursor:pointer}
.live-chat-hint{font-size:11px;color:rgba(255,255,255,.3);text-align:center;margin-top:5px;min-height:15px}

/* ── Desktop : layout côte à côte ── */
@media(min-width:768px){
  .live-fullscreen{background:rgba(0,0,0,.85);display:flex;align-items:center;justify-content:center;transform:none;opacity:0;pointer-events:none;transition:opacity .25s}
  .live-fullscreen.open{opacity:1;pointer-events:all}
  .live-fs-inner{position:static;width:auto;height:auto;display:flex;gap:20px;align-items:flex-start;height:85vh}
  .live-fs-video-col{position:relative;height:100%;aspect-ratio:9/16;border-radius:16px;overflow:hidden;flex-shrink:0}
  #liveVideo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
  .live-fs-gradient-bot{height:200px}
  .live-topbar{padding:14px}
  .live-action-btn{padding:7px 14px}
  /* Chat panel desktop : panneau à droite */
  .live-fs-chat-panel{position:static;width:300px;height:100%;display:flex;flex-direction:column;background:var(--surf);border-radius:16px;padding:16px;border:1px solid var(--bdr)}
  .live-msgs{max-height:none;flex:1;overflow-y:auto;padding-right:0}
  .live-msgs::-webkit-scrollbar{width:2px}
  .live-msgs::-webkit-scrollbar-thumb{background:var(--surf2)}
  .live-msg-char{background:var(--surf2);color:var(--txt);backdrop-filter:none}
  .live-msg-user{background:rgba(255,45,107,.3);color:var(--txt)}
  .live-chat-input{background:var(--bg3);border-color:var(--bdr);color:var(--txt)}
  .live-chat-input::placeholder{color:var(--txt3)}
  .live-chat-hint{color:var(--txt3)}
}

/* ── Picker scènes ── */
.live-picker-overlay{position:fixed;inset:0;z-index:500;background:rgba(0,0,0,0);pointer-events:none;transition:background .25s}
.live-picker-overlay.open{background:rgba(0,0,0,.5);pointer-events:all}
.live-picker-sheet{position:absolute;bottom:0;left:0;right:0;background:#0d0d18;border-radius:18px 18px 0 0;padding:14px 16px calc(20px + env(safe-area-inset-bottom));transform:translateY(100%);transition:transform .3s ease}
.live-picker-overlay.open .live-picker-sheet{transform:translateY(0)}
@media(min-width:768px){
  .live-picker-sheet{position:fixed;bottom:auto;top:50%;left:50%;right:auto;transform:translate(-50%,60%);width:460px;border-radius:18px;transition:transform .25s,opacity .25s;opacity:0}
  .live-picker-overlay.open .live-picker-sheet{transform:translate(-50%,-50%);opacity:1}
}
.live-picker-handle{width:36px;height:3px;background:rgba(255,255,255,.2);border-radius:2px;margin:0 auto 14px}
.live-picker-title{font-size:14px;font-weight:700;color:var(--txt);margin-bottom:14px}
.live-scenes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:4px}
.live-scene-card{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r-lg);overflow:hidden;cursor:pointer;transition:border-color var(--t)}
.live-scene-card:hover{border-color:var(--bdr2)}
.live-scene-thumb{width:100%;aspect-ratio:9/16;object-fit:cover;display:block}
.live-scene-thumb-placeholder{background:linear-gradient(135deg,var(--surf2),var(--surf));display:flex;align-items:center;justify-content:center;font-size:22px}
.live-scene-info{padding:6px 8px 8px}
.live-scene-name{font-size:11px;font-weight:600;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.live-scene-cost{font-size:11px;color:var(--acc);margin-top:2px}
.live-picker-cancel{width:100%;margin-top:14px;padding:12px;border-radius:var(--r-lg);border:1px solid var(--bdr);color:var(--txt3);font-size:13px;font-weight:600;background:transparent;cursor:pointer;transition:all var(--t)}
.live-picker-cancel:hover{border-color:var(--bdr2);color:var(--txt2)}

/* ── Gen share bottom sheet ── */
.gen-share-sheet{position:absolute;inset:0;z-index:10;background:rgba(0,0,0,.6);display:none;align-items:flex-end}
.gen-share-sheet.open{display:flex}
.gen-share-inner{width:100%;background:#0d0d18;border-radius:18px 18px 0 0;padding:14px 16px 32px}
.gen-share-handle{width:36px;height:3px;background:rgba(255,255,255,.2);border-radius:2px;margin:0 auto 14px}
.gen-share-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.gen-share-item{display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer}
.gen-share-ico{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center}
.gen-share-name{font-size:10px;color:rgba(242,237,228,.5);text-align:center}
}
#gdMobEditBtn{display:none}
@media(max-width:600px){
  #genDetailModal.image-gen #gdMobEditBtn{display:flex;position:absolute;bottom:80px;left:14px;z-index:10;align-items:center;gap:6px;padding:9px 16px;background:rgba(255,45,107,.15);border:1px solid rgba(255,45,107,.4);border-radius:20px;color:#ff2d6b;font-size:12px;font-weight:800;cursor:pointer;font-family:'Space Grotesk',sans-serif}
}
.landing-filter-sep{width:1px;height:16px;background:var(--bdr);flex-shrink:0;align-self:center;margin:0 4px}
