﻿:root{--bg1:#121212;--bg2:#1e1e1e;--bg3:#2a2a2a;--glass:rgba(255,255,255,.03);--stroke:rgba(255,255,255,.08);--txt:#f1f5f9;--dim:#94a3b8;--acc:#34d399;--accbg:rgba(52,211,153,.12);--accbdr:rgba(52,211,153,.3);--acc-start:#34d399;--acc-end:#10b981}
*{box-sizing:border-box} html,body{height:100%;margin:0;overflow:hidden}
html.gp-transition,html.gp-transition *{transition:background .3s ease,border-color .3s ease,color .3s ease,box-shadow .3s ease !important}
.genpic-body{height:100vh;color:var(--txt);font-family:"Microsoft YaHei","PingFang SC",sans-serif;background:var(--bg1);}
.genpic-bg{position:fixed;inset:0;pointer-events:none}
.gp-shell{height:100vh;padding:8px;display:grid;grid-template-rows:60px 1fr;gap:8px}
.gp-glass{background:var(--bg2);border:1px solid var(--stroke);border-radius:14px;box-shadow:0 4px 20px rgba(0,0,0,.25)}
.gp-top{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;position:relative;z-index:100}
.gp-top-left,.gp-top-right{display:flex;align-items:center}.gp-top-left{gap:24px}.gp-top-right{gap:10px}
.gp-brand{display:flex;align-items:center;gap:6px}.gp-logo-dot{display:none}.gp-logo-text{font-size:30px;font-weight:700;line-height:1}
.gp-nav a{color:var(--dim);text-decoration:none;margin-right:16px;padding:6px 0;border-bottom:2px solid transparent;opacity:.8}.gp-nav a.active,.gp-nav a:hover{opacity:1;border-bottom-color:var(--acc)}
/* ── Top-bar page toggle ── */
.gp-page-toggle{display:flex;background:rgba(255,255,255,.08);border-radius:8px;padding:3px;gap:2px}
.gp-page-toggle a{padding:4px 14px;border-radius:6px;font-size:12px;font-weight:500;color:rgba(255,255,255,.55);text-decoration:none;transition:all .2s;line-height:1.4}
.gp-page-toggle a.active{background:rgba(255,255,255,.16);color:#f4f8ff;font-weight:600}
@keyframes gpPlanPulse{0%,100%{box-shadow:0 0 8px rgba(52,211,153,.12)}50%{box-shadow:0 0 16px rgba(52,211,153,.35)}}
.gp-plan{font-size:13px;padding:5px 14px;border-radius:999px;border:1px solid rgba(52,211,153,.8);background:linear-gradient(110deg,rgba(52,211,153,.3) 0%,rgba(52,211,153,.15) 25%,rgba(52,211,153,.35) 45%,rgba(52,211,153,.15) 55%,rgba(52,211,153,.3) 75%,rgba(52,211,153,.12) 100%);background-size:200% 100%;font-weight:700;cursor:pointer;transition:background .2s,border-color .2s,box-shadow .2s;animation:gpPlanPulse 3s ease-in-out infinite,gpShimmer 5s linear infinite}
.gp-stage{min-height:0;flex:1;display:grid;grid-template-columns:380px 1fr 310px;grid-template-rows:1fr;gap:8px}
.gp-col{min-height:0;height:100%;padding:12px}
.gp-left{display:flex;flex-direction:column;scrollbar-width:none;overflow:hidden}.gp-left::-webkit-scrollbar{display:none}.gp-left .gp-scroll{flex:1;min-height:0;overflow-y:auto;scrollbar-width:none}.gp-left .gp-scroll::-webkit-scrollbar{display:none}.gp-center{display:flex;flex-direction:column}.gp-right{display:flex;flex-direction:column}
.gp-scroll::-webkit-scrollbar{width:4px;height:4px}
.gp-scroll::-webkit-scrollbar-track{background:transparent}
.gp-scroll::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:4px}
.gp-scroll::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.4)}
[data-theme="light"] .gp-scroll::-webkit-scrollbar-thumb{background:rgba(0,0,0,.12)}
[data-theme="light"] .gp-scroll::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.3)}
.gp-left textarea::-webkit-scrollbar,.gp-block textarea::-webkit-scrollbar{width:4px;height:4px}
.gp-left textarea::-webkit-scrollbar-track,.gp-block textarea::-webkit-scrollbar-track{background:transparent}
.gp-left textarea::-webkit-scrollbar-thumb,.gp-block textarea::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:4px}
.gp-left textarea::-webkit-scrollbar-thumb:hover,.gp-block textarea::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.4)}
[data-theme="light"] .gp-left textarea::-webkit-scrollbar-thumb,[data-theme="light"] .gp-block textarea::-webkit-scrollbar-thumb{background:rgba(0,0,0,.12)}
[data-theme="light"] .gp-left textarea::-webkit-scrollbar-thumb:hover,[data-theme="light"] .gp-block textarea::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.3)}
.gp-left h2{margin:0 0 4px;font-size:36px}.gp-sub{margin:0 0 10px;color:var(--dim);font-size:12px}

.gp-chips{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:8px}.gp-chip{padding:5px 10px;border-radius:999px;border:1px solid var(--stroke);background:rgba(255,255,255,.04);color:var(--dim)}.gp-chip.active{background:var(--accbg);border-color:var(--accbdr)}
.gp-btn{border:0;border-radius:10px;padding:9px 12px;font-weight:700}.gp-generate{width:100%;background:linear-gradient(110deg,var(--acc-start) 0%,var(--acc-end) 25%,var(--acc) 45%,var(--acc-end) 55%,var(--acc-start) 75%,var(--acc-end) 100%);background-size:200% 100%;color:#fff;animation:gpShimmer 5s linear infinite}.gp-btn.ghost{background:rgba(255,255,255,.06);color:var(--txt);border:1px solid var(--stroke)}
.gp-center-tabs{display:flex;gap:2px;margin-bottom:10px;background:rgba(255,255,255,.03);border:1px solid var(--stroke);padding:3px;border-radius:10px}
.gp-center-tabs button{flex:1;border:0;border-radius:8px;padding:6px 0;background:transparent;color:var(--dim);font-weight:700;font-size:12px;cursor:pointer;transition:all .2s}
.gp-center-tabs button.active{background:linear-gradient(135deg,var(--acc-start),var(--acc-end));color:#fff}
[data-theme="light"] .gp-center-tabs{background:rgba(0,0,0,.05);border-color:rgba(0,0,0,.1)}
[data-theme="light"] .gp-center-tabs button{color:#475569}
[data-theme="light"] .gp-center-tabs button.active{background:linear-gradient(145deg,#3b82f6,#2563eb);color:#fff}
.gp-result-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--stroke)}
.gp-result-head h3{margin:0;font-size:15px;font-weight:700;color:var(--txt);display:flex;align-items:center;gap:6px}
.gp-result-icon{font-size:14px;color:var(--acc);opacity:.7}
.gp-status{font-size:11px;padding:3px 10px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid var(--stroke);color:var(--dim);font-weight:600}.gp-image{flex:1;min-height:0;border-radius:12px;border:1px dashed var(--stroke);display:flex;background:rgba(0,0,0,.15);padding:10px}.gp-image-placeholder{color:var(--dim)}.gp-actions{margin-top:8px;display:flex;gap:8px;flex-wrap:wrap}
.gp-history-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.gp-history-head h3{margin:0;font-size:15px;font-weight:700;color:var(--txt);display:flex;align-items:center;gap:6px}.gp-history-actions{display:flex;align-items:center;gap:8px}.gp-history-head a{font-size:12px;color:var(--acc);text-decoration:none}.gp-history-clear{font-size:11px;padding:3px 10px;border-radius:999px;border:1px solid rgba(248,113,113,.35);background:rgba(248,113,113,.1);color:#fca5a5;cursor:pointer;font-family:inherit;font-weight:600;transition:background .2s,border-color .2s}.gp-history-clear:hover{background:rgba(248,113,113,.22);border-color:rgba(248,113,113,.55)}[data-theme="light"] .gp-history-clear{border-color:rgba(239,68,68,.3);background:rgba(239,68,68,.06);color:#dc2626}[data-theme="light"] .gp-history-clear:hover{background:rgba(239,68,68,.14);border-color:rgba(239,68,68,.5)}
.gp-history-batch{font-size:11px;padding:3px 10px;border-radius:999px;border:1px solid var(--accbdr);background:var(--accbg);color:var(--acc);cursor:pointer;font-family:inherit;font-weight:600;transition:background .2s,border-color .2s}.gp-history-batch:hover{background:rgba(52,211,153,.22);border-color:rgba(52,211,153,.5)}[data-theme="light"] .gp-history-batch{border-color:rgba(59,130,246,.3);background:rgba(59,130,246,.06);color:#2563eb}[data-theme="light"] .gp-history-batch:hover{background:rgba(59,130,246,.14);border-color:rgba(59,130,246,.5)}
.gp-history-batch-bar{flex-shrink:0;display:flex;align-items:center;gap:8px;padding:8px 4px 2px;margin-top:4px;border-top:1px solid var(--stroke)}.gp-batch-select-all{font-size:12px;color:var(--dim);cursor:pointer;display:flex;align-items:center;gap:4px;user-select:none}
.gp-batch-select-all input{width:16px;height:16px;margin:0;cursor:pointer;appearance:none;-webkit-appearance:none;border:1px solid var(--stroke);border-radius:4px;background:transparent;transition:all .2s;flex-shrink:0}.gp-batch-select-all input:checked{background:var(--acc);border-color:var(--acc);background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' fill='%23fff' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M13.78 4.22a.75.75 0 0 1 0 1.06l-7.25 7.25a.75.75 0 0 1-1.06 0L2.22 9.28a.75.75 0 0 1 1.06-1.06L6 10.94l6.72-6.72a.75.75 0 0 1 1.06 0z'/%3E%3C/svg%3E");background-size:11px;background-position:center;background-repeat:no-repeat}.gp-batch-select-all input:hover{border-color:var(--accbdr)}.gp-batch-select-all input:focus{outline:none}.gp-batch-count{font-size:11px;color:var(--dim);flex:1}.gp-batch-delete-btn{font-size:11px;padding:4px 12px;border-radius:8px;border:0;background:rgba(248,113,113,.2);color:#fca5a5;font-weight:700;cursor:pointer;font-family:inherit;transition:background .2s}.gp-batch-delete-btn:hover:not(:disabled){background:rgba(248,113,113,.35)}.gp-batch-delete-btn:disabled{opacity:.4;cursor:not-allowed}.gp-batch-cancel-btn{font-size:11px;padding:4px 10px;border-radius:8px;border:1px solid var(--stroke);background:transparent;color:var(--dim);cursor:pointer;font-family:inherit;transition:background .2s}.gp-batch-cancel-btn:hover{background:rgba(255,255,255,.04)}[data-theme="light"] .gp-history-batch-bar{border-top-color:rgba(0,0,0,.08)}[data-theme="light"] .gp-batch-select-all{color:#64748b}[data-theme="light"] .gp-batch-select-all input{border-color:rgba(0,0,0,.3);background:transparent}[data-theme="light"] .gp-batch-select-all input:checked{background:#3b82f6;border-color:#3b82f6}[data-theme="light"] .gp-batch-select-all input:hover{border-color:rgba(59,130,246,.5)}[data-theme="light"] .gp-batch-count{color:#64748b}[data-theme="light"] .gp-batch-delete-btn{background:rgba(239,68,68,.12);color:#dc2626}[data-theme="light"] .gp-batch-delete-btn:hover:not(:disabled){background:rgba(239,68,68,.25)}[data-theme="light"] .gp-batch-cancel-btn{border-color:rgba(0,0,0,.16);color:#64748b}[data-theme="light"] .gp-batch-cancel-btn:hover{background:rgba(0,0,0,.06)}
/* Batch mode checkbox on history items */
.gp-batch-cb{display:none;position:absolute;left:6px;top:50%;transform:translateY(-50%);width:18px;height:18px;margin:0;cursor:pointer;z-index:3;flex-shrink:0;appearance:none;-webkit-appearance:none;border:1px solid var(--stroke);border-radius:4px;background:transparent;transition:all .2s}.gp-batch-cb:checked{background:var(--acc);border-color:var(--acc);background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' fill='%23fff' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M13.78 4.22a.75.75 0 0 1 0 1.06l-7.25 7.25a.75.75 0 0 1-1.06 0L2.22 9.28a.75.75 0 0 1 1.06-1.06L6 10.94l6.72-6.72a.75.75 0 0 1 1.06 0z'/%3E%3C/svg%3E");background-size:12px;background-position:center;background-repeat:no-repeat}.gp-batch-cb:hover{border-color:var(--accbdr)}.gp-batch-cb:focus{outline:none}.gp-batch-active .gp-history-item{padding-left:32px;padding-right:48px}.gp-batch-active .gp-batch-cb{display:block}.gp-batch-active .gp-history-del{right:4px}[data-theme="light"] .gp-batch-cb{border-color:rgba(0,0,0,.3)}[data-theme="light"] .gp-batch-cb:checked{background:#3b82f6;border-color:#3b82f6}[data-theme="light"] .gp-batch-cb:hover{border-color:rgba(59,130,246,.6)}.gp-history-list{flex:1;min-height:0;overflow-y:auto;padding-right:5px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.08) transparent}.gp-history-list::-webkit-scrollbar{width:3px;height:3px}.gp-history-list::-webkit-scrollbar-track{background:transparent}.gp-history-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:2px}.gp-history-list::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.4)}[data-theme="light"] .gp-history-list{scrollbar-color:rgba(0,0,0,.12) transparent}[data-theme="light"] .gp-history-list::-webkit-scrollbar-thumb{background:rgba(0,0,0,.12)}[data-theme="light"] .gp-history-list::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.3)}.gp-history-notice{padding:8px 4px 2px;font-size:11px;color:var(--dim);text-align:center;flex-shrink:0;opacity:.4}[data-theme="light"] .gp-history-notice{color:rgba(0,0,0,.2)}
.gp-history-item{display:flex;gap:8px;align-items:center;padding:7px;border:1px solid var(--stroke);border-radius:10px;background:rgba(255,255,255,.02);margin-bottom:7px}.gp-thumb{width:46px;height:46px;border-radius:8px;background:rgba(255,255,255,.06)}.gp-history-item p{margin:0;font-size:12px;color:var(--txt)}.gp-history-item span{font-size:11px;color:var(--dim)}
@media (max-width:1300px){html,body{overflow:auto}.gp-shell{height:auto;min-height:100vh;grid-template-rows:auto 1fr}.gp-stage{grid-template-columns:1fr}.gp-center,.gp-right{min-height:360px}}

/* Force reset FastAdmin frontend top spacing */
html, body, body.gp-body {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

.navbar-fixed-top,
.navbar,
#header,
#main,
#mainbody,
.main,
.container,
.container-fluid {
  margin-top: 0 !important;
}

.gp-shell {
  padding: 8px !important;
}


.gp-progress-wrap{display:inline-flex;align-items:center;gap:6px;flex-shrink:0}
.gp-progress-wrap .gp-progress-bar{width:120px;height:6px;border-radius:999px;background:rgba(255,255,255,.12);overflow:hidden}
.gp-progress-wrap .gp-progress-bar-fill{height:100%;width:0;background:linear-gradient(90deg,var(--acc-start),var(--acc-end));border-radius:999px;transition:width .4s ease}
.gp-progress-wrap .gp-progress-text{font-size:12px;font-weight:700;color:var(--acc);min-width:32px;text-align:right;font-variant-numeric:tabular-nums}
.gp-progress-wrap.active .gp-progress-bar-fill{animation:none}
.gp-progress-wrap.done .gp-progress-bar-fill{background:linear-gradient(90deg,var(--acc-start),var(--acc-end));width:100% !important}
.gp-progress-wrap.fail .gp-progress-bar-fill{background:linear-gradient(90deg,#f87171,#ef4444);width:100% !important}
.gp-progress-wrap.done .gp-progress-text{color:var(--acc)}
.gp-progress-wrap.fail .gp-progress-text{color:#f87171}
[data-theme="light"] .gp-progress-wrap .gp-progress-bar{background:rgba(0,0,0,.08)}
[data-theme="light"] .gp-progress-wrap .gp-progress-bar-fill{background:linear-gradient(90deg,#3b82f6,#60a5fa,#3b82f6);background-size:200% 100%}
[data-theme="light"] .gp-progress-wrap .gp-progress-text{color:#3b82f6}
[data-theme="light"] .gp-progress-wrap.done .gp-progress-text{color:#2563eb}
[data-theme="light"] .gp-progress-wrap.fail .gp-progress-text{color:#dc2626}
.gp-image-main{flex:1;min-height:0;display:flex;flex-direction:row;gap:10px;align-items:stretch}
.gp-image-card{flex:1;min-width:0;padding:14px;display:flex;flex-direction:column;position:relative}
.gp-image-preview{flex:1;border:1px dashed var(--stroke);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--dim);background:rgba(0,0,0,.12)}
.gp-image-tools{margin-top:10px;display:flex;gap:8px}
.gp-image-tools button{flex:1;padding:8px 0;font-size:13px;font-weight:700;border-radius:8px;border:1px solid var(--stroke);background:rgba(255,255,255,.04);color:var(--txt);cursor:pointer;transition:background .2s,border-color .2s}
.gp-image-tools button:hover{background:var(--accbg);border-color:var(--accbdr);color:var(--acc)}
[data-theme="light"] .gp-image-tools button{background:rgba(0,0,0,.06);border-color:rgba(0,0,0,.14);color:#334155}
[data-theme="light"] .gp-image-tools button:hover{background:rgba(59,130,246,.12);border-color:rgba(59,130,246,.4);color:#1d4ed8}
.gp-btn.sm{padding:6px 10px;font-size:12px;border-radius:8px}
.gp-history-item{position:relative;padding-right:56px}
.gp-history-item em{position:absolute;right:8px;top:8px;font-style:normal;font-size:10px;padding:2px 6px;border-radius:999px}
.gp-history-item.done em{background:rgba(52,211,153,.15);color:#6ee7b7;border:1px solid rgba(52,211,153,.3)}
@keyframes gpRunningPulse{0%,100%{box-shadow:inset 0 0 8px rgba(52,211,153,.04);border-color:rgba(52,211,153,.12)}50%{box-shadow:inset 0 0 18px rgba(52,211,153,.12);border-color:rgba(52,211,153,.3)}}
.gp-history-item.running{animation:gpRunningPulse 2.5s ease-in-out infinite}
.gp-history-item.running em{background:var(--accbg);color:var(--acc);border:1px solid var(--accbdr)}
.gp-history-item.fail em{background:rgba(248,113,113,.15);color:#fca5a5;border:1px solid rgba(248,113,113,.3)}
.gp-history-del{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:20px;height:20px;padding:0;border:0;border-radius:6px;background:rgba(255,255,255,.04);color:var(--dim);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s,background .2s;line-height:1;z-index:2}
.gp-history-item:hover .gp-history-del{opacity:1}
.gp-history-del:hover{background:rgba(248,113,113,.15);color:#fca5a5}
[data-theme="light"] .gp-history-del{background:rgba(0,0,0,.04);color:rgba(0,0,0,.2)}
[data-theme="light"] .gp-history-del:hover{background:rgba(239,68,68,.1);color:#dc2626}

/* History skeleton loading */
@keyframes gpSklPulse{0%,100%{opacity:.6}50%{opacity:1}}
.gp-history-sk{display:flex;gap:8px;align-items:center;padding:7px;border:1px solid var(--stroke);border-radius:10px;background:rgba(255,255,255,.02);margin-bottom:7px;animation:gpSklPulse 1.5s ease-in-out infinite}
.gp-sk-thumb{width:46px;height:46px;border-radius:8px;background:rgba(255,255,255,.06);flex-shrink:0}
.gp-sk-body{flex:1;display:flex;flex-direction:column;gap:5px}
.gp-sk-line{height:12px;border-radius:4px;background:rgba(255,255,255,.06)}
.gp-sk-line-w70{width:70%}
.gp-sk-line-w45{width:45%;height:10px}
.gp-sk-badge{width:44px;height:18px;border-radius:999px;background:rgba(255,255,255,.04);flex-shrink:0}
[data-theme="light"] .gp-history-sk{background:rgba(255,255,255,.65);border-color:rgba(0,0,0,.1)}
[data-theme="light"] .gp-history-end{color:rgba(0,0,0,.2)!important}
[data-theme="light"] .gp-sk-thumb{background:rgba(0,0,0,.05)}
[data-theme="light"] .gp-sk-line{background:rgba(0,0,0,.05)}
[data-theme="light"] .gp-sk-badge{background:rgba(0,0,0,.03)}
.gp-left-header{display:flex;align-items:baseline;gap:8px;margin:0 0 10px}
.gp-left-header h2{margin:0;font-size:20px;font-weight:700;color:var(--txt);line-height:1.2}
.gp-left-header .gp-sub{margin:0;font-size:12px;color:var(--dim)}
.gp-mode-body{display:flex;flex-direction:column;gap:10px}
.gp-mode-body.in{animation:gpFadeIn .25s ease both}
@keyframes gpFadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.gp-result-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;padding:10px}
.gp-result-grid-item{border-radius:9px;overflow:hidden;background:rgba(0,0,0,.2);aspect-ratio:1}
[data-theme="light"] .gp-result-grid-item{background:rgba(0,0,0,.04)}
.gp-inline-settings{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.gp-inline-setting label{display:block;font-size:12px;font-weight:600;color:var(--dim);margin-bottom:4px}
.gp-inline-setting select{width:100%;padding:7px 8px;border-radius:9px;border:1px solid var(--stroke);background:rgba(255,255,255,.04);color:var(--txt);appearance:none;font-size:12px}
.gp-inline-setting select:focus{outline:none;border-color:var(--acc);box-shadow:0 0 0 2px var(--accbg)}
/* ── Custom dropup selects ── */
.gp-cs{position:relative;display:block}
.gp-cs-trigger{display:flex;align-items:center;justify-content:space-between;gap:4px;width:100%;padding:7px 8px;border-radius:9px;border:1px solid var(--stroke);background:rgba(255,255,255,.04);color:var(--txt);font-size:12px;cursor:pointer;box-sizing:border-box;transition:border-color .15s}
.gp-cs-trigger:focus{outline:none;border-color:var(--acc);box-shadow:0 0 0 2px var(--accbg)}
.gp-cs-arrow{flex-shrink:0;opacity:.7;transition:transform .2s}
.gp-cs.open .gp-cs-arrow{transform:rotateX(180deg)}
.gp-cs-options{display:none;position:absolute;bottom:calc(100% + 4px);left:0;right:0;background:var(--bg2);border:1px solid var(--stroke);border-radius:9px;overflow:hidden;z-index:100;box-shadow:0 -4px 20px rgba(0,0,0,.35)}
.gp-cs.open .gp-cs-options{display:block}
.gp-cs-options div{padding:7px 10px;font-size:12px;color:var(--dim);cursor:pointer;transition:background .12s}
.gp-cs-options div:hover{background:var(--accbg)}
.gp-cs-options div.active{background:var(--accbg);color:#a7f3d0;font-weight:600}
[data-theme="light"] .gp-cs-trigger{background:linear-gradient(145deg,#fff,#f8fafc);color:#1e293b;border-color:rgba(0,0,0,.16)}
[data-theme="light"] .gp-cs-trigger:focus{border-color:rgba(59,130,246,.55);box-shadow:0 0 0 2px rgba(59,130,246,.12)}
[data-theme="light"] .gp-cs-options{background:rgba(255,255,255,.98);border-color:rgba(0,0,0,.12);box-shadow:0 -4px 20px rgba(0,0,0,.1)}
[data-theme="light"] .gp-cs-options div{color:#475569}
[data-theme="light"] .gp-cs-options div:hover{background:rgba(59,130,246,.06)}
[data-theme="light"] .gp-cs-options div.active{background:rgba(31,209,161,.1);color:#065f46;font-weight:600}
[data-theme="light"] .gp-inline-setting label{color:#475569}
[data-theme="light"] .gp-inline-setting select{background:linear-gradient(145deg,#fff,#f8fafc);color:#1e293b;border-color:rgba(0,0,0,.16)}
/* Force hide native file input UI in upload block */
.gp-left input[type="file"] {
  display: none !important;
  visibility: hidden !important;
  width: 0 !important;
  height: 0 !important;
  opacity: 0 !important;
  pointer-events: none !important;
}
/* Left panel redesign based on reference layout */
.gp-left{padding:12px;display:flex;flex-direction:column;gap:10px}
.gp-scroll{flex:1;overflow-y:auto;min-height:0;display:flex;flex-direction:column;gap:10px}
.gp-left label{display:block;margin:0 0 6px;color:var(--dim);font-size:12px;font-weight:700}
.gp-block{background:rgba(255,255,255,.02);border:1px solid var(--stroke);border-radius:12px;padding:10px}
.gp-left textarea,.gp-left input,.gp-left select{width:100%;border-radius:10px;border:1px solid var(--stroke);background:rgba(0,0,0,.2);color:var(--txt);padding:10px;font-size:16px}
.gp-left textarea{min-height:68px;resize:vertical}
.gp-pills{display:flex;flex-wrap:wrap;gap:8px}
.gp-pill{border:1px solid var(--stroke);background:rgba(255,255,255,.04);color:var(--dim);border-radius:999px;padding:6px 12px;font-size:12px}
.gp-pill.on{background:var(--accbg);border-color:var(--accbdr);color:#a7f3d0}
.gp-pill-custom{border-style:dashed;background:rgba(255,255,255,.02);border-color:var(--stroke);color:var(--dim);font-weight:400;opacity:1}
.gp-pill-custom:hover{border-color:var(--accbdr);color:var(--acc)}
.gp-pill-custom.on{border-style:solid;background:var(--accbg);border-color:var(--accbdr);color:#a7f3d0;font-weight:700}
.gp-pill-custom-input{width:100%;border-radius:8px;border:1px solid var(--stroke);background:rgba(0,0,0,.2);color:var(--txt);padding:8px 10px;margin-top:6px;display:none;font-size:16px;transition:border-color .2s,box-shadow .2s}
.gp-pill-custom-input:focus{outline:none;border-color:var(--acc);box-shadow:0 0 0 2px var(--accbg)}
[data-theme="light"] .gp-pill-custom{background:rgba(0,0,0,.02);border-color:rgba(0,0,0,.1);color:#94a3b8}
[data-theme="light"] .gp-pill-custom:hover{border-color:rgba(59,130,246,.3);color:#3b82f6}
[data-theme="light"] .gp-pill-custom.on{background:rgba(31,209,161,.16);border-color:rgba(31,209,161,.5);color:#065f46;border-style:solid}
[data-theme="light"] .gp-pill-custom-input{background:rgba(255,255,255,.75);border-color:rgba(0,0,0,.12);color:#1e293b}
[data-theme="light"] .gp-pill-custom-input:focus{border-color:rgba(59,130,246,.55);box-shadow:0 0 0 2px rgba(59,130,246,.12)}
/* Style pills expand/collapse */
.gp-style-wrap{position:relative}.gp-style-pills{overflow-x:auto;flex-wrap:nowrap;scrollbar-width:none;padding-bottom:2px;user-select:none;-webkit-user-select:none}.gp-style-pills::-webkit-scrollbar{display:none}.gp-style-pills .gp-pill{flex-shrink:0}.gp-style-pills.expanded{flex-wrap:wrap;overflow-x:visible}.gp-style-expand-btn{width:18px;height:18px;border-radius:4px;border:0;background:rgba(255,255,255,.08);color:rgba(255,255,255,.35);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .25s;flex-shrink:0}.gp-style-expand-btn:hover{background:rgba(52,211,153,.18);color:#6ee7b7}.gp-style-expand-btn svg{transition:transform .3s;width:12px;height:12px}.gp-style-expand-btn.open svg{transform:rotate(180deg)}[data-theme="light"] .gp-style-expand-btn{background:rgba(0,0,0,.06);color:rgba(0,0,0,.25)}[data-theme="light"] .gp-style-expand-btn:hover{background:rgba(59,130,246,.12);color:#3b82f6}[data-theme="light"] .gp-style-pills{scrollbar-color:rgba(0,0,0,.1) transparent}[data-theme="light"] .gp-style-pills::-webkit-scrollbar-thumb{background:rgba(0,0,0,.12)}
.gp-res-badge{position:absolute;top:-4px;right:-4px;font-size:8px;font-weight:700;border-radius:3px;padding:0 4px;line-height:1.5;z-index:1}.badge-2k{background:linear-gradient(135deg,#2dd4bf,#14b8a6);color:#042f2e}.badge-3k{background:linear-gradient(135deg,#a78bfa,#8b5cf6);color:#1e1b4b}.badge-4k{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#451a03}[data-theme="light"] .badge-2k{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff}[data-theme="light"] .badge-3k{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}[data-theme="light"] .badge-4k{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.gp-ratio-grid button{position:relative}.gp-ratio-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.gp-ratio-grid button{border:1px solid var(--stroke);background:rgba(255,255,255,.04);color:var(--txt);border-radius:9px;padding:5px 0;font-size:12px;line-height:1.3}
.gp-ratio-grid button small{display:block;font-size:9px;opacity:.6;font-weight:400;margin-top:1px}
.gp-ratio-grid .active{background:var(--accbg);border-color:var(--accbdr);color:#a7f3d0}
[data-theme="light"] .gp-ratio-grid button{border-color:rgba(0,0,0,.14);background:rgba(0,0,0,.03);color:#475569}
[data-theme="light"] .gp-ratio-grid .active{background:linear-gradient(145deg,#3b82f6,#2563eb);color:#fff;border-color:#2563eb}

.gp-generate{margin-top:auto}
.gp-generate:disabled{opacity:.4;cursor:not-allowed}
.gp-model-label{font-size:12px;font-weight:600;color:var(--dim);display:block;margin-bottom:6px}
.gp-model-pills{display:flex;flex-wrap:wrap;gap:6px}
.gp-model-pill{font-size:12px;padding:5px 12px!important}
.gp-credit-estimate{text-align:center;font-size:12px;color:var(--dim);margin-top:6px;padding:0 4px;min-height:18px}
.gp-theme-toggle{width:34px;height:34px;border-radius:999px;border:1px solid var(--stroke);background:rgba(255,255,255,.04);color:var(--dim);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;transition:background .3s,border-color .3s,color .3s;line-height:1;padding:0}
.gp-theme-toggle:hover{border-color:var(--accbdr);color:var(--acc)}
[data-theme="light"]{--bg1:#f1f5f9;--glass:rgba(255,255,255,.72);--stroke:rgba(0,0,0,.12);--txt:#1e293b;--dim:#64748b}
[data-theme="light"] .genpic-body{background:linear-gradient(145deg,#f0f8ff,#e6eefc,#f1f5f9)}
[data-theme="light"] .gp-glass{background:rgba(255,255,255,.78);box-shadow:0 8px 24px rgba(0,0,0,.07)}
[data-theme="light"] .gp-nav a{color:#334155}
[data-theme="light"] .gp-nav a.active,.gp-nav a:hover{border-bottom-color:#3b82f6}
[data-theme="light"] .gp-page-toggle{background:rgba(0,0,0,.06)}
[data-theme="light"] .gp-page-toggle a{color:rgba(0,0,0,.5)}
[data-theme="light"] .gp-page-toggle a.active{background:rgba(255,255,255,.8);color:#0f172a}
[data-theme="light"] .gp-logo-dot{background:#3b82f6;box-shadow:0 0 14px rgba(59,130,246,.5)}
[data-theme="light"] .gp-plan{border-color:rgba(59,130,246,.6);background:linear-gradient(145deg,rgba(59,130,246,.14),rgba(37,99,235,.08));color:#1d4ed8;box-shadow:0 0 10px rgba(59,130,246,.12)}
[data-theme="light"] .gp-left label{color:#475569}
[data-theme="light"] .gp-left textarea,[data-theme="light"] .gp-left input,[data-theme="light"] .gp-left select{background:rgba(255,255,255,.85);border-color:rgba(0,0,0,.16);color:#1e293b}
[data-theme="light"] .gp-left textarea::placeholder{color:#94a3b8}
[data-theme="light"] .gp-block{background:rgba(255,255,255,.5);border-color:rgba(0,0,0,.09)}
[data-theme="light"] .gp-pill{border-color:rgba(0,0,0,.14);background:rgba(0,0,0,.04);color:#475569}
[data-theme="light"] .gp-pill.on{background:rgba(31,209,161,.16);border-color:rgba(31,209,161,.5);color:#065f46}
[data-theme="light"] .gp-model-label{color:#475569}
[data-theme="light"] .gp-btn.ghost{background:rgba(0,0,0,.05);color:#334155;border-color:rgba(0,0,0,.16)}
[data-theme="light"] .gp-generate{color:#fff;background:linear-gradient(110deg,#3b82f6 0%,#2563eb 25%,#60a5fa 45%,#2563eb 55%,#3b82f6 75%,#2563eb 100%);background-size:200% 100%;animation:gpShimmer 5s linear infinite}
[data-theme="light"] .gp-credit-estimate{color:#64748b}
[data-theme="light"] .gp-image{background:rgba(0,0,0,.04);border-color:rgba(0,0,0,.12)}
[data-theme="light"] .gp-image-preview{background:rgba(0,0,0,.03);color:#64748b;border-color:rgba(0,0,0,.1)}
[data-theme="light"] .gp-history-item{background:rgba(255,255,255,.65);border-color:rgba(0,0,0,.1)}
[data-theme="light"] .gp-history-item p{color:#334155}
[data-theme="light"] .gp-history-item span{color:#64748b}
[data-theme="light"] .gp-result-head h3,[data-theme="light"] .gp-history-head h3{color:#1e293b}
[data-theme="light"] .gp-result-head{border-bottom-color:rgba(0,0,0,.06)}
[data-theme="light"] .gp-result-icon{color:#3b82f6}
[data-theme="light"] .gp-status{background:rgba(0,0,0,.04);border-color:rgba(0,0,0,.1);color:#64748b}
[data-theme="light"] .gp-theme-toggle{border-color:rgba(0,0,0,.12);background:rgba(0,0,0,.04);color:#64748b}
[data-theme="light"] .gp-theme-toggle:hover{border-color:rgba(59,130,246,.5);color:#3b82f6;transform:rotate(18deg) scale(1.08);box-shadow:0 0 14px rgba(59,130,246,.2)}
/* ── Input placeholder unified ── */
.gp-left textarea::placeholder,
.gp-left input::placeholder,
.gp-block textarea::placeholder,
.gp-block input::placeholder {
  color: #7A8CA8;
  opacity: 1;
}
[data-theme="light"] .gp-left textarea::placeholder,
[data-theme="light"] .gp-left input::placeholder,
[data-theme="light"] .gp-block textarea::placeholder,
[data-theme="light"] .gp-block input::placeholder {
  color: #94A3B8;
  opacity: 1;
}
/* ── Input focus state ── */
.gp-left textarea,
.gp-left input,
.gp-left select {
  transition: border-color .2s, box-shadow .2s, transform .15s;
}
.gp-left textarea:focus,
.gp-left input:focus,
.gp-left select:focus {
  outline: none;
  border-color: var(--acc);
  box-shadow: 0 0 0 3px var(--accbg);
  transform: translateY(-1px);
}
[data-theme="light"] .gp-left textarea:focus,
[data-theme="light"] .gp-left input:focus,
[data-theme="light"] .gp-left select:focus {
  border-color: rgba(59, 130, 246, 0.7);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15);
}
/* ── Upload card ── */
.gp-upload-card{border:1px dashed var(--stroke);border-radius:12px;background:rgba(255,255,255,.02);padding:12px;text-align:left;cursor:pointer;transition:border-color .2s,background .2s,transform .15s}
.gp-upload-card:hover{border-color:var(--accbdr);background:var(--accbg)}
.gp-upload-card.dragover{border-color:var(--acc);background:rgba(52,211,153,.08);transform:translateY(-1px)}
.gp-upload-row{display:flex;align-items:center;gap:10px}
.gp-upload-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--accbg);border:1px solid var(--accbdr);color:var(--acc);font-size:20px;font-weight:400;flex-shrink:0;line-height:1;transition:background .2s,border-color .2s}
.gp-upload-card:hover .gp-upload-icon{background:rgba(52,211,153,.2);border-color:rgba(52,211,153,.45)}
.gp-upload-card.dragover .gp-upload-icon{background:rgba(52,211,153,.3);border-color:var(--acc)}
.gp-upload-copy{flex:1;min-width:0}
.gp-upload-main{font-size:14px;font-weight:700;color:var(--txt);line-height:1.3;margin:0 0 1px}
.gp-upload-sub{font-size:12px;color:var(--dim);line-height:1.3;margin:0}
.gp-upload-dot{width:6px;height:6px;border-radius:50%;background:var(--acc);box-shadow:0 0 8px var(--accbg);flex-shrink:0;opacity:.6}
/* ── Upload preview (after file selected) ── */
.gp-upload-preview{margin-top:8px;padding:8px 10px;border:1px solid var(--stroke);border-radius:10px;background:rgba(255,255,255,.02);display:flex;align-items:center;gap:10px}
.gp-upload-preview img{width:48px;height:48px;border-radius:8px;object-fit:cover;border:1px solid var(--stroke);flex-shrink:0}
.gp-upload-thumb{position:relative;flex-shrink:0}
.gp-upload-badge{position:absolute;top:-6px;left:-6px;min-width:20px;height:20px;border-radius:999px;background:linear-gradient(135deg,var(--acc-start),var(--acc-end));color:#fff;font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center;line-height:1;padding:0 5px;box-shadow:0 0 8px rgba(52,211,153,.4);z-index:1;border:2px solid var(--bg1)}
[data-theme="light"] .gp-upload-badge{border-color:#fff}
.gp-upload-meta{flex:1;min-width:0}
.gp-upload-meta p{margin:0 0 1px;color:var(--txt);font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gp-upload-meta span{font-size:11px;color:var(--dim)}
.gp-upload-remove{background:none;border:0;color:var(--acc);padding:4px;cursor:pointer;border-radius:6px;transition:background .2s,color .2s;flex-shrink:0;display:flex;align-items:center;justify-content:center;width:28px;height:28px}
.gp-upload-remove:hover{background:rgba(248,113,113,.15);color:#fca5a5}
.gp-upload-preview{cursor:grab}
.gp-upload-preview:active{cursor:grabbing}
/* pointer-events: none on children bypasses native image drag in Chrome,
   so mousedown always reaches the preview div and initiates our custom drag */
.gp-upload-preview :not(.gp-upload-remove){pointer-events:none}
.gp-upload-preview.dragging{opacity:.4}
.gp-upload-preview.drag-over{border-color:#fca5a5;background:rgba(248,113,113,.08)}
/* ── Multiple upload previews container ── */
.gp-upload-previews{display:flex;flex-direction:column;gap:6px;margin-top:8px}
/* ── Upload light theme ── */
[data-theme="light"] .gp-upload-card{border-color:rgba(0,0,0,.14);background:rgba(0,0,0,.02)}
[data-theme="light"] .gp-upload-card:hover{border-color:rgba(59,130,246,.4);background:rgba(59,130,246,.04)}
[data-theme="light"] .gp-upload-card.dragover{border-color:rgba(59,130,246,.55);background:rgba(59,130,246,.08)}
[data-theme="light"] .gp-upload-icon{background:rgba(59,130,246,.1);border-color:rgba(59,130,246,.3);color:#3b82f6}
[data-theme="light"] .gp-upload-card:hover .gp-upload-icon{background:rgba(59,130,246,.16);border-color:rgba(59,130,246,.45)}
[data-theme="light"] .gp-upload-card.dragover .gp-upload-icon{background:rgba(59,130,246,.22);border-color:rgba(59,130,246,.55)}
[data-theme="light"] .gp-upload-main{color:#1e293b}
[data-theme="light"] .gp-upload-sub{color:#64748b}
[data-theme="light"] .gp-upload-dot{background:#3b82f6;box-shadow:0 0 8px rgba(59,130,246,.4)}
[data-theme="light"] .gp-upload-preview{background:rgba(255,255,255,.65);border-color:rgba(0,0,0,.1)}
[data-theme="light"] .gp-upload-preview img{border-color:rgba(0,0,0,.1)}
[data-theme="light"] .gp-upload-badge{background:linear-gradient(145deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 0 6px rgba(59,130,246,.4)}
[data-theme="light"] .gp-upload-meta p{color:#1e293b}
[data-theme="light"] .gp-upload-meta span{color:#64748b}
[data-theme="light"] .gp-upload-remove{color:#3b82f6}
[data-theme="light"] .gp-upload-remove:hover{background:rgba(239,68,68,.1);color:#dc2626}
/* ── Sidebar member card ── */
.gp-member-card{border:1px solid var(--stroke);border-radius:12px;background:rgba(255,255,255,.02);padding:12px 14px;margin-bottom:4px;cursor:pointer;transition:background .2s,border-color .2s}
.gp-member-card:hover{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.14)}
.gp-member-card-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.gp-member-card-info{display:flex;flex-direction:column;gap:2px}
.gp-member-card-plan{font-size:14px;font-weight:700;color:#e6f3ff}
.gp-member-card-label{font-size:11px;color:#94b4da}
.gp-member-card-label strong{font-size:13px;color:#a7f3d0;font-weight:700}
.gp-member-card-up{padding:4px 12px;border-radius:999px;background:linear-gradient(110deg,var(--acc-start) 0%,var(--acc-end) 25%,var(--acc) 45%,var(--acc-end) 55%,var(--acc-start) 75%,var(--acc-end) 100%);background-size:200% 100%;color:#fff;font-size:11px;font-weight:700;line-height:1;animation:gpShimmer 5s linear infinite}
.gp-member-card-track{height:4px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden}
.gp-member-card-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--acc-start),var(--acc-end));transition:width .4s}
.gp-member-card{position:relative;overflow:hidden}
.gp-member-card::before{content:'';position:absolute;inset:0;background:linear-gradient(110deg,transparent 0%,rgba(255,255,255,.05) 45%,rgba(255,255,255,.1) 50%,rgba(255,255,255,.05) 55%,transparent 100%);background-size:200% 100%;animation:gpShimmer 5s linear infinite;pointer-events:none;z-index:1}
.gp-member-card::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,.02);pointer-events:none;z-index:1}
[data-theme="light"] .gp-member-card{background:linear-gradient(135deg,rgba(59,130,246,.08),rgba(37,99,235,.04));border-color:rgba(59,130,246,.2)}
[data-theme="light"] .gp-member-card:hover{background:linear-gradient(135deg,rgba(59,130,246,.15),rgba(37,99,235,.08));border-color:rgba(59,130,246,.4);box-shadow:0 0 16px rgba(59,130,246,.08)}
[data-theme="light"] .gp-member-card-plan{color:#1e293b}
[data-theme="light"] .gp-member-card-label{color:#64748b}
[data-theme="light"] .gp-member-card-label strong{color:#1e293b}
[data-theme="light"] .gp-member-card-up{background:linear-gradient(145deg,#3b82f6,#2563eb);color:#fff}
[data-theme="light"] .gp-member-card-track{background:rgba(0,0,0,.06)}
/* ── Right sidebar sections ── */
.gp-right-section{padding:4px 0;margin-bottom:4px}
.gp-right-section:empty{display:none}
.gp-right-link{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:10px;background:rgba(255,255,255,.02);border:1px solid var(--stroke);color:var(--txt);text-decoration:none!important;font-size:13px;transition:background .2s,border-color .2s}
.gp-right-link:hover{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.14);color:var(--txt);text-decoration:none!important}
.gp-right-link-icon{font-size:14px;color:var(--acc);flex-shrink:0}
.gp-right-link-arrow{margin-left:auto;font-size:13px;color:var(--dim);transition:transform .2s}
.gp-right-link:hover .gp-right-link-arrow{transform:translateX(3px)}
[data-theme="light"] .gp-right-link{background:rgba(59,130,246,.06);border-color:rgba(0,0,0,.1);color:#1e293b}
[data-theme="light"] .gp-right-link:hover{background:rgba(59,130,246,.12);border-color:rgba(59,130,246,.3);color:#0f172a}
[data-theme="light"] .gp-right-link-icon{color:#3b82f6}
[data-theme="light"] .gp-right-link-arrow{color:#64748b}

/* ── Highlighted invite link (popup-style CTA) ── */
.gp-right-link.gp-invite-link{background:var(--accbg);border-color:var(--accbdr);position:relative;overflow:hidden}
.gp-right-link.gp-invite-link::before{content:'';position:absolute;inset:0;background:linear-gradient(110deg,transparent 0%,rgba(255,255,255,.06) 45%,rgba(255,255,255,.1) 50%,rgba(255,255,255,.06) 55%,transparent 100%);background-size:200% 100%;animation:gpShimmer 4s linear infinite;pointer-events:none}
.gp-right-link.gp-invite-link:hover{background:rgba(52,211,153,.18);border-color:rgba(52,211,153,.5)}
.gp-right-link.gp-invite-link > *{position:relative;z-index:1}
.gp-right-link.gp-invite-link .gp-right-link-icon{color:var(--acc)}
@keyframes gpInviteShimmer{0%{background-position:300% 0}100%{background-position:-300% 0}}
.gp-invite-badge{display:inline-block;font-size:10px;padding:1px 7px;border-radius:999px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-weight:800;line-height:1.4;margin-left:auto;animation:gpInvitePulse 6s ease-in-out infinite;position:relative;z-index:1}
@keyframes gpInvitePulse{0%,100%{box-shadow:0 0 6px rgba(245,158,11,.3)}50%{box-shadow:0 0 14px rgba(245,158,11,.6)}}
[data-theme="light"] .gp-right-link.gp-invite-link{background:linear-gradient(135deg,rgba(59,130,246,.18),rgba(37,99,235,.12),rgba(29,78,216,.06));border-color:rgba(59,130,246,.45);box-shadow:0 4px 16px rgba(59,130,246,.1)}
[data-theme="light"] .gp-right-link.gp-invite-link:hover{background:linear-gradient(135deg,rgba(59,130,246,.28),rgba(37,99,235,.2),rgba(29,78,216,.12));border-color:rgba(59,130,246,.65);box-shadow:0 6px 24px rgba(59,130,246,.2)}
[data-theme="light"] .gp-right-link.gp-invite-link .gp-right-link-icon{filter:drop-shadow(0 0 4px rgba(59,130,246,.4))}

/* ── Membership modal ── */
.gp-modal-overlay{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center}
.gp-modal{background:var(--bg2);border:1px solid var(--stroke);border-radius:18px;width:620px;max-width:94vw;max-height:90vh;overflow-y:auto;box-shadow:0 24px 60px rgba(0,0,0,.4)}
/* 磨玻璃效果弹窗 */
#gpMemberModal .gp-modal,
#gpAnnounceModal .gp-modal,
#gpPayModal .gp-modal{background:rgba(30,30,30,.75);backdrop-filter:blur(24px) saturate(1.2);-webkit-backdrop-filter:blur(24px) saturate(1.2);border:1px solid rgba(255,255,255,.08);box-shadow:0 32px 80px rgba(0,0,0,.45)}
#gpMemberModal.gp-modal-overlay{background:rgba(0,0,0,.4);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.gp-modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px 14px;border-bottom:1px solid var(--stroke)}
.gp-modal-head h2{margin:0;font-size:20px;color:var(--txt)}
.gp-modal-close{width:30px;height:30px;border-radius:8px;border:1px solid var(--stroke);background:rgba(255,255,255,.04);color:var(--dim);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.gp-modal-close:hover{background:rgba(248,113,113,.2);color:#fca5a5;border-color:rgba(248,113,113,.3)}
.gp-modal-body{padding:20px 22px 22px}
.gp-member-status{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.gp-member-label{font-size:12px;color:var(--dim);margin-bottom:4px}
.gp-member-badge{display:inline-block;padding:4px 12px;border-radius:999px;background:var(--accbg);border:1px solid var(--accbdr);color:var(--acc);font-size:13px;font-weight:700}
.gp-member-amount{font-size:32px;font-weight:700;color:var(--txt);line-height:1}
.gp-credit-section{margin-bottom:22px}
.gp-credit-label{font-size:12px;color:var(--dim);margin-bottom:6px}
.gp-credit-track{height:6px;border-radius:999px;background:rgba(255,255,255,.1);overflow:hidden}
.gp-credit-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--acc-start),var(--acc-end));transition:width .4s}
.gp-plans-label{font-size:14px;font-weight:700;color:var(--txt);margin-bottom:10px}
.gp-plans{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:22px}
.gp-plan-card{position:relative;border:1px solid var(--stroke);border-radius:14px;background:rgba(255,255,255,.02);padding:16px 14px;text-align:center;cursor:pointer;display:flex;flex-direction:column;transition:border-color .2s,background .2s,transform .15s}
.gp-plan-card:hover{border-color:var(--accbdr);background:var(--accbg);transform:translateY(-2px)}
.gp-plan-card.active{border-color:var(--acc);background:rgba(52,211,153,.08)}
.gp-plan-name{font-size:14px;font-weight:700;color:var(--txt);margin-bottom:6px}
.gp-plan-credits{font-size:32px;font-weight:700;color:var(--acc-start);line-height:1;margin-bottom:2px}
.gp-plan-credits small{font-size:13px;font-weight:400;color:var(--dim)}
.gp-plan-price{font-size:15px;font-weight:500;color:var(--dim);line-height:1;margin-bottom:8px}
.gp-plan-period{font-size:13px;font-weight:400;color:var(--dim)}
.gp-plan-features{font-size:11px;color:var(--dim);line-height:1.4;margin-bottom:12px;flex:1}
.gp-plan-btn{display:inline-block;padding:5px 16px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.07);color:#94b4da;font-size:12px;font-weight:700;cursor:pointer;transition:all .2s}
.gp-plan-card:not(.free) .gp-plan-btn:hover{background:rgba(52,211,153,.15);color:#6ee7b7;border-color:rgba(52,211,153,.35)}
.gp-plan-card.active .gp-plan-btn{background:#6ee7b7;color:#111111;border-color:#6ee7b7}
.gp-plan-card.free .gp-plan-btn{opacity:.5;cursor:default}
.gp-topup-label{font-size:14px;font-weight:700;color:var(--txt);margin-bottom:10px}
.gp-topup{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.gp-topup-opt{border:1px solid var(--stroke);border-radius:12px;background:rgba(255,255,255,.02);padding:12px 8px;text-align:center;cursor:pointer;color:var(--txt);font-size:13px;font-weight:700;line-height:1.3;transition:border-color .2s,background .2s}
.gp-topup-opt:hover{border-color:var(--accbdr);background:var(--accbg)}
.gp-plan-expire{font-size:12px;color:var(--dim);text-align:center;margin-bottom:10px}

/* ── Payment modal ── */
.gp-pay-body{text-align:center}
.gp-pay-info{margin:16px 0 20px}
.gp-pay-amount{font-size:44px;font-weight:800;color:var(--txt);letter-spacing:-1px;line-height:1.1}
.gp-pay-desc{font-size:14px;color:var(--dim);margin-top:6px;font-weight:500}
/* Payment method selection */
.gp-pay-methods{display:flex;gap:14px;justify-content:center;margin-bottom:22px}
.gp-pay-method{display:flex;align-items:center;gap:10px;padding:10px 22px;border:1.5px solid var(--stroke);border-radius:12px;background:rgba(255,255,255,.02);cursor:pointer;font-size:14px;color:var(--txt);transition:all .25s ease;position:relative;min-width:130px;justify-content:center}
.gp-pay-method.active,.gp-pay-method:hover{border-color:var(--accbdr);background:var(--accbg);transform:translateY(-1px)}
.gp-pay-method.active{border-color:var(--acc);box-shadow:0 0 20px var(--accbg)}
.gp-pay-method input[type="radio"]{display:none}
/* Payment method icons */
.gp-pay-icon{width:26px;height:26px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0;line-height:1}
.gp-pay-icon.wx{background:linear-gradient(135deg,#07c160,#06ad56);box-shadow:0 2px 8px rgba(7,193,96,.35)}
.gp-pay-icon.wx::after{content:"微"}
.gp-pay-icon.ali{background:linear-gradient(135deg,#1677ff,#0d6ae8);box-shadow:0 2px 8px rgba(22,119,255,.35)}
.gp-pay-icon.ali::after{content:"支"}
.gp-pay-method-label{font-weight:600}
/* QR code area */
.gp-pay-qr{padding:20px;margin-bottom:16px;background:rgba(0,0,0,.15);border-radius:16px;display:inline-block;width:100%;max-width:300px;border:1px solid var(--stroke)}
.gp-pay-qr-mock{display:flex;justify-content:center;align-items:center;padding:12px;background:#fff;border-radius:12px;box-shadow:0 4px 24px rgba(0,0,0,.2),0 0 0 1px var(--stroke)}
.gp-pay-qr-mock img,.gp-pay-qr-mock canvas{display:block;border-radius:4px}
.gp-pay-qr-tip{display:flex;align-items:center;justify-content:center;gap:8px;margin:14px 0 8px}
.gp-pay-qr-brand{font-size:16px;font-weight:700;color:var(--txt)}
.gp-pay-qr-hint{font-size:13px;color:var(--dim);font-weight:400}
/* Payment status with pulsing dot */
.gp-pay-status{font-size:13px;color:var(--dim);margin-top:8px;display:flex;align-items:center;justify-content:center;gap:8px;font-weight:500}
.gp-pay-dot{width:8px;height:8px;border-radius:50%;background:var(--acc);display:inline-block;animation:gpPayDotPulse 1.6s ease-in-out infinite;box-shadow:0 0 6px var(--accbg)}
@keyframes gpPayDotPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.75)}}
/* Pay button */
.gp-pay-btn{min-width:180px;padding:14px 0;font-size:16px;font-weight:700;background:linear-gradient(135deg,var(--acc-start),var(--acc-end));color:#fff;cursor:pointer;transition:all .25s ease;border:0;border-radius:12px;letter-spacing:.5px}
.gp-pay-btn:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 8px 24px rgba(52,211,153,.25)}
.gp-pay-btn:active{transform:translateY(0)}
.gp-pay-btn:disabled{opacity:.5;cursor:default;transform:none;box-shadow:none}
/* ── Payment modal: light theme ── */
[data-theme="light"] .gp-pay-amount{color:#1e293b}
[data-theme="light"] .gp-pay-desc{color:#64748b}
[data-theme="light"] .gp-pay-method{border-color:rgba(0,0,0,.1);background:rgba(255,255,255,.8);color:#475569}
[data-theme="light"] .gp-pay-method.active,[data-theme="light"] .gp-pay-method:hover{border-color:#3b82f6;background:rgba(59,130,246,.08);color:#1d4ed8}
[data-theme="light"] .gp-pay-method.active{box-shadow:0 0 20px rgba(59,130,246,.15)}
[data-theme="light"] .gp-pay-qr{background:rgba(0,0,0,.03);border-color:rgba(0,0,0,.08)}
[data-theme="light"] .gp-pay-qr-mock{box-shadow:0 4px 24px rgba(0,0,0,.06),0 0 0 1px rgba(0,0,0,.04)}
[data-theme="light"] .gp-pay-qr-brand{color:#1e293b}
[data-theme="light"] .gp-pay-qr-hint{color:#64748b}
[data-theme="light"] .gp-pay-status{color:#64748b}
[data-theme="light"] .gp-pay-dot{background:#3b82f6;box-shadow:0 0 6px rgba(59,130,246,.4)}
[data-theme="light"] .gp-pay-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}
[data-theme="light"] .gp-pay-btn:hover{box-shadow:0 8px 24px rgba(59,130,246,.3)}
[data-theme="light"] .gp-plan-expire{color:#475569}
/* ── Modal light theme ── */
[data-theme="light"] .gp-modal-overlay{background:rgba(15,23,42,.3)}
[data-theme="light"] .gp-modal{background:rgba(255,255,255,.97);border-color:rgba(0,0,0,.12)}
[data-theme="light"] #gpMemberModal .gp-modal,
[data-theme="light"] #gpAnnounceModal .gp-modal,
[data-theme="light"] #gpPayModal .gp-modal{background:rgba(255,255,255,.92);backdrop-filter:blur(24px) saturate(1.4);-webkit-backdrop-filter:blur(24px) saturate(1.4);border-color:rgba(255,255,255,.9);box-shadow:0 32px 80px rgba(0,0,0,.15)}
[data-theme="light"] .gp-modal-head{border-bottom-color:rgba(0,0,0,.08)}
[data-theme="light"] .gp-modal-head h2{color:#1e293b}
[data-theme="light"] .gp-modal-close{border-color:rgba(0,0,0,.12);background:rgba(0,0,0,.04);color:#64748b}
[data-theme="light"] .gp-modal-close:hover{background:rgba(239,68,68,.1);color:#dc2626}
[data-theme="light"] .gp-member-label{color:#475569}
[data-theme="light"] .gp-member-badge{background:rgba(59,130,246,.1);border-color:rgba(59,130,246,.3);color:#3b82f6}
[data-theme="light"] .gp-member-amount{color:#1e293b}
[data-theme="light"] .gp-credit-label{color:#475569}
[data-theme="light"] .gp-credit-track{background:rgba(0,0,0,.12)}
[data-theme="light"] .gp-plans-label{color:#1e293b}
[data-theme="light"] .gp-plan-card{border-color:rgba(0,0,0,.12);background:rgba(255,255,255,.5)}
[data-theme="light"] .gp-plan-card:hover{border-color:rgba(59,130,246,.35);background:rgba(59,130,246,.06)}
[data-theme="light"] .gp-plan-card.active{border-color:#3b82f6;background:rgba(59,130,246,.1)}
[data-theme="light"] .gp-plan-name{color:#1e293b}
[data-theme="light"] .gp-plan-price{color:#1e293b}
[data-theme="light"] .gp-plan-period{color:#475569}
[data-theme="light"] .gp-plan-features{color:#334155}
[data-theme="light"] .gp-plan-btn{border-color:rgba(0,0,0,.18);background:rgba(0,0,0,.06);color:#475569}
[data-theme="light"] .gp-plan-card:not(.free) .gp-plan-btn:hover{background:rgba(59,130,246,.12);color:#3b82f6;border-color:rgba(59,130,246,.35)}
[data-theme="light"] .gp-plan-card.active .gp-plan-btn{background:#3b82f6;color:#fff;border-color:#3b82f6}
[data-theme="light"] .gp-plan-card.free .gp-plan-btn{opacity:.5}
[data-theme="light"] .gp-topup-label{color:#1e293b}
[data-theme="light"] .gp-topup-opt{border-color:rgba(0,0,0,.12);background:rgba(255,255,255,.5);color:#1e293b}
[data-theme="light"] .gp-topup-opt:hover{border-color:rgba(59,130,246,.4);background:rgba(59,130,246,.06)}
[data-theme="light"] .gp-topup-opt small{color:#475569}
/* ── Modal responsive ── */
@media (max-width:768px){
  .gp-modal{width:100%;max-width:96vw;border-radius:14px}
  .gp-modal-body{padding:16px 14px}
  .gp-plans{grid-template-columns:1fr;gap:8px}
  .gp-plan-card{display:flex;align-items:center;gap:10px;padding:12px;text-align:left}
  .gp-plan-card .gp-plan-features{margin-bottom:0;flex:1}
  .gp-plan-card .gp-plan-btn{flex-shrink:0}
  .gp-plan-credits{font-size:22px;margin-bottom:0;min-width:70px;text-align:center}
  .gp-plan-credits small{font-size:11px}
  .gp-plan-price{font-size:13px;margin-bottom:0;text-align:center}
  .gp-topup{grid-template-columns:repeat(2,1fr);gap:6px}
  .gp-member-amount{font-size:26px}
  .gp-member-status{flex-wrap:wrap;gap:8px}
}
@media (max-width:480px){
  .gp-modal{border-radius:12px;max-width:98vw}
  .gp-plan-card{flex-wrap:wrap}
  .gp-topup{grid-template-columns:repeat(2,1fr)}
}
/* ── Conversion-optimized plan cards ── */
.gp-plan-card{position:relative;overflow:visible}
.gp-plan-card.free{opacity:.6;border-style:dashed}
.gp-plan-card.free:hover{opacity:.85}
.gp-plan-card .gp-plan-badge{position:absolute;top:-10px;right:-8px;font-size:10px;font-weight:800;padding:3px 10px;border-radius:999px;letter-spacing:.3px;z-index:2;line-height:1.3}
.gp-plan-card .gp-plan-badge.popular{background:linear-gradient(135deg,var(--acc-start),var(--acc-end));color:#fff}
.gp-plan-card .gp-plan-badge.free-badge{background:rgba(255,255,255,.04);color:var(--dim);border:1px solid var(--stroke);right:auto;left:-8px}
.gp-plan-card .gp-plan-save{display:block;font-size:12px;font-weight:700;color:var(--acc);margin:4px 0 6px}
.gp-plan-card .gp-plan-compare{display:block;font-size:11px;color:var(--dim);text-decoration:line-through;margin-top:-4px;margin-bottom:2px;opacity:.4}
.gp-plan-card .gp-plan-price{position:relative;z-index:1}
/* ── Social proof ── */
.gp-social-proof{text-align:center;margin:14px 0 0;padding:8px 0;border-top:1px solid var(--stroke);font-size:12px;color:var(--dim);opacity:.5}
.gp-social-proof strong{color:var(--acc);font-weight:700}
.gp-topup-badge{position:absolute;top:-8px;right:-6px;font-size:9px;font-weight:800;padding:2px 7px;border-radius:999px;color:#fff;line-height:1.3;z-index:2;pointer-events:none}
/* ── Light theme overrides ── */
[data-theme="light"] .gp-plan-card.free{opacity:.5}
[data-theme="light"] .gp-plan-card.free:hover{opacity:.8}
[data-theme="light"] .gp-plan-card .gp-plan-badge.popular{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}
[data-theme="light"] .gp-plan-card .gp-plan-badge.free-badge{background:rgba(0,0,0,.06);color:#94a3b8;border-color:rgba(0,0,0,.1)}
[data-theme="light"] .gp-plan-card .gp-plan-save{color:#d97706}
[data-theme="light"] .gp-plan-card .gp-plan-compare{color:rgba(0,0,0,.25)}
[data-theme="light"] .gp-social-proof{border-top-color:rgba(0,0,0,.08);color:rgba(0,0,0,.5)}
[data-theme="light"] .gp-social-proof strong{color:#3b82f6}
/* Logo branding (base: .gp-logo-* at top) */
.gp-logo-star{color:#eef6ff;font-size:16px;line-height:1;filter:drop-shadow(0 0 4px rgba(255,255,255,.45))}
.gp-logo-text{font-weight:800;font-size:22px;letter-spacing:.2px;color:#f4f8ff}
.gp-logo-text em{font-style:normal;color:#19d39c}
/* Logo hover + light/dark adaptation */
.gp-brand {
  cursor: pointer;
}

.gp-brand .gp-logo-star,
.gp-brand .gp-logo-text,
.gp-brand .gp-logo-text em {
  transition: color .18s ease, filter .18s ease;
}

.gp-brand:hover .gp-logo-star,
.gp-brand:hover .gp-logo-text,
.gp-brand:hover .gp-logo-text em {
  color: #19d39c !important;
  filter: drop-shadow(0 0 6px rgba(25, 211, 156, .35));
}

/* Theme-switch based light mode logo fix */
[data-theme="light"] .gp-logo-text {
  color: #1E293B !important;
}
[data-theme="light"] .gp-logo-text em {
  color: #0FAF7F !important;
}
[data-theme="light"] .gp-logo-star {
  color: #1E293B !important;
  filter: none !important;
}
[data-theme="light"] .gp-brand:hover .gp-logo-star,
[data-theme="light"] .gp-brand:hover .gp-logo-text,
[data-theme="light"] .gp-brand:hover .gp-logo-text em {
  color: #0FAF7F !important;
  filter: none !important;
}

/* ── Auth buttons in header ── */
@keyframes gpPulse{0%,100%{box-shadow:0 0 10px rgba(52,211,153,.2)}50%{box-shadow:0 0 20px rgba(52,211,153,.5)}}
.gp-btn-auth{background:linear-gradient(135deg,var(--acc-start),var(--acc-end));border:0;border-radius:8px;color:#fff;padding:5px 14px;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;transition:opacity .2s}
.gp-btn-auth:hover{opacity:.88}
[data-theme="light"] .gp-btn-auth{background:linear-gradient(145deg,#3b82f6,#2563eb);color:#fff;border-color:rgba(59,130,246,.5);box-shadow:0 0 12px rgba(59,130,246,.2)}
[data-theme="light"] .gp-btn-auth:hover{box-shadow:0 0 18px rgba(59,130,246,.35)}
/* ── Auth modal tabs ── */
.gp-auth-tabs{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--stroke);margin:0 28px}
.gp-auth-tab{background:none;border:0;border-bottom:2px solid transparent;padding:10px 0;font-size:13px;font-weight:700;color:var(--dim);cursor:pointer;font-family:inherit;transition:color .25s,border-color .25s}
.gp-auth-tab.active{color:var(--txt);border-bottom-color:var(--acc)}
.gp-auth-tab:hover{color:var(--txt)}
.gp-auth-panel{display:block}
.gp-auth-panel.in{animation:gpFadeIn .2s ease both}
[data-theme="light"] .gp-auth-tabs{border-bottom-color:rgba(0,0,0,.08)}
[data-theme="light"] .gp-auth-tab{color:#64748b}
[data-theme="light"] .gp-auth-tab.active{color:#1e293b;border-bottom-color:#3b82f6}
[data-theme="light"] .gp-auth-tab:hover{color:#334155}
/* ── Auth modal ── */
.gp-auth-modal{width:440px}
.gp-auth-modal .gp-modal-body{padding:24px 28px 28px}
.gp-auth-label{display:block;font-size:12px;font-weight:700;color:var(--dim);margin-bottom:4px;margin-top:14px}
.gp-auth-label:first-child{margin-top:0}
.gp-auth-input{width:100%;border-radius:10px;border:1px solid var(--stroke);background:rgba(0,0,0,.2);color:var(--txt);padding:10px 12px;font-size:16px;font-family:inherit;transition:border-color .2s,box-shadow .2s}
.gp-auth-input:focus{outline:none;border-color:var(--acc);box-shadow:0 0 0 3px var(--accbg)}
.gp-auth-input::placeholder{color:var(--dim);opacity:.6}
.gp-input-wrap{position:relative;display:block}
.gp-input-wrap .gp-auth-input{padding-right:34px}
.gp-resize-handle{height:8px;cursor:ns-resize;position:relative;margin-top:-2px;background:transparent;border-radius:0 0 6px 6px;transition:background .15s}
.gp-resize-handle:hover,.gp-resize-handle.active{background:rgba(52,211,153,.15)}
.gp-resize-handle::after{content:'';display:block;width:30px;height:3px;border-radius:2px;background:rgba(255,255,255,.15);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);transition:background .15s}
.gp-resize-handle:hover::after,.gp-resize-handle.active::after{background:rgba(52,211,153,.5)}
[data-theme="light"] .gp-resize-handle:hover,[data-theme="light"] .gp-resize-handle.active{background:rgba(59,130,246,.1)}
[data-theme="light"] .gp-resize-handle::after{background:rgba(0,0,0,.15)}
[data-theme="light"] .gp-resize-handle:hover::after,[data-theme="light"] .gp-resize-handle.active::after{background:rgba(59,130,246,.5)}
.gp-input-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:20px;height:20px;padding:0;border:0;border-radius:50%;background:rgba(255,255,255,.08);color:var(--dim);font-size:14px;line-height:20px;text-align:center;cursor:pointer;display:none;z-index:2;transition:background .2s}
.gp-input-clear:hover{background:rgba(255,255,255,.15)}
.gp-input-clear.visible{display:block}
[data-theme="light"] .gp-input-clear{background:rgba(0,0,0,.1);color:#64748b}
[data-theme="light"] .gp-input-clear:hover{background:rgba(0,0,0,.2)}
.gp-auth-row{display:flex;align-items:center;justify-content:space-between;margin-top:12px}
.gp-auth-checkbox{font-size:12px;color:var(--dim);cursor:pointer;display:flex;align-items:center;gap:5px}
.gp-auth-checkbox input{accent-color:var(--acc);width:14px;height:14px;margin:0}
.gp-auth-link{background:none;border:0;color:var(--acc);font-size:12px;cursor:pointer;text-decoration:none}
.gp-auth-link:hover{color:#6ee7b7}
@keyframes gpShimmer{0%{background-position:-200% center}100%{background-position:200% center}}
.gp-auth-submit{width:100%;margin-top:18px;padding:11px;border:0;border-radius:10px;background:linear-gradient(135deg,var(--acc-start),var(--acc-end));color:#fff;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;transition:opacity .2s,transform .2s}
.gp-auth-submit:hover{opacity:.9;transform:translateY(-1px)}
.gp-auth-submit:active{transform:translateY(0)}
.gp-auth-submit:disabled{opacity:.5;cursor:not-allowed;transform:none;animation:none}
.gp-auth-code-btn{height:auto;align-self:stretch;padding:10px 14px;border:1px solid var(--accbdr);border-radius:10px;background:var(--accbg);color:var(--acc);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap;transition:all .2s;flex-shrink:0;line-height:1.2}
.gp-auth-code-btn:hover:not(:disabled){background:rgba(52,211,153,.2);border-color:rgba(52,211,153,.5)}
.gp-auth-code-btn:disabled{opacity:.4;cursor:not-allowed}
.gp-auth-code-btn.countdown{background:rgba(255,255,255,.04);border-color:var(--stroke);color:var(--dim)}
.gp-auth-error{background:rgba(248,113,113,.1);border:1px solid rgba(248,113,113,.25);border-radius:8px;padding:8px 10px;font-size:12px;color:#fca5a5;margin-top:12px}
.gp-auth-switch{text-align:center;margin-top:18px;font-size:12px;color:var(--dim)}
[data-theme="light"] .gp-auth-modal .gp-modal-body{background:rgba(255,255,255,.97)}
[data-theme="light"] .gp-auth-label{color:#475569}
[data-theme="light"] .gp-auth-input{background:rgba(255,255,255,.85);border-color:rgba(0,0,0,.16);color:#1e293b}
[data-theme="light"] .gp-auth-input::placeholder{color:#94a3b8;opacity:1}
[data-theme="light"] .gp-auth-input:focus{border-color:rgba(59,130,246,.7);box-shadow:0 0 0 3px rgba(59,130,246,.15)}
[data-theme="light"] .gp-auth-checkbox{color:#64748b}
[data-theme="light"] .gp-auth-checkbox input{accent-color:#3b82f6}
[data-theme="light"] .gp-auth-link{color:#3b82f6}
[data-theme="light"] .gp-auth-link:hover{color:#1d4ed8}
[data-theme="light"] .gp-auth-submit{background:linear-gradient(110deg,#3b82f6 0%,#2563eb 25%,#60a5fa 45%,#2563eb 55%,#3b82f6 75%,#2563eb 100%);background-size:200% 100%;color:#fff;animation:gpShimmer 5s linear infinite}
[data-theme="light"] .gp-auth-error{background:rgba(239,68,68,.08);border-color:rgba(239,68,68,.25);color:#dc2626}
[data-theme="light"] .gp-auth-switch{color:#64748b}
[data-theme="light"] .gp-auth-code-btn{border-color:rgba(59,130,246,.35);background:rgba(59,130,246,.08);color:#3b82f6}
/* ── Change password modal ── */
.gp-chgpwd-modal{width:420px}
.gp-chgpwd-modal .gp-modal-body{padding:24px 28px 28px}
.gp-chgpwd-modal .gp-auth-submit{margin-top:18px}
[data-theme="light"] .gp-auth-code-btn:hover:not(:disabled){background:rgba(59,130,246,.18);border-color:rgba(59,130,246,.5)}
[data-theme="light"] .gp-auth-code-btn.countdown{background:rgba(0,0,0,.05);border-color:rgba(0,0,0,.12);color:#64748b}
/* ── Mobile sidebar ── */
.gp-menu-btn{display:none;width:34px;height:34px;border-radius:8px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.06);color:#dce8f5;cursor:pointer;align-items:center;justify-content:center;font-size:20px;padding:0;line-height:1;flex-shrink:0}
.gp-menu-btn:hover{border-color:rgba(52,211,153,.6);color:#6ee7b7}
[data-theme="light"] .gp-menu-btn{border-color:rgba(0,0,0,.12);background:rgba(0,0,0,.04);color:#64748b}
[data-theme="light"] .gp-menu-btn:hover{border-color:rgba(59,130,246,.5);color:#3b82f6}

.gp-sidebar-overlay{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,.3);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.gp-sidebar{position:fixed;top:8px;right:8px;bottom:8px;width:280px;background:var(--bg2);border:1px solid var(--stroke);border-radius:16px;display:flex;flex-direction:column;animation:gpSlideIn .25s ease}
@keyframes gpSlideIn{from{transform:translateX(100%)}to{transform:translateX(0)}}
.gp-sidebar-head{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid rgba(255,255,255,.1)}
.gp-sidebar-title{font-size:16px;font-weight:700;color:var(--txt)}
.gp-sidebar-close{width:30px;height:30px;border:0;background:rgba(255,255,255,.06);border-radius:6px;color:var(--dim);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.gp-sidebar-body{flex:1;padding:16px;overflow-y:auto}
.gp-sidebar-user{padding:12px;border-radius:10px;background:var(--accbg);border:1px solid var(--accbdr);color:var(--txt);font-weight:600;font-size:14px}
.gp-sidebar-auth-btn{width:100%;padding:12px;border:0;border-radius:10px;background:linear-gradient(135deg,var(--acc-start),var(--acc-end));color:#fff;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit}
.gp-sidebar-divider{height:1px;background:var(--stroke);margin:14px 0}
.gp-sidebar-plan{padding:4px 0}
.gp-sidebar-page-toggle{display:flex;flex-direction:column;gap:4px}
.gp-sidebar-page-toggle a{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:10px;font-size:14px;font-weight:500;color:rgba(255,255,255,.65);text-decoration:none;transition:all .2s}
.gp-sidebar-page-toggle a.active{background:var(--accbg);color:var(--acc);font-weight:600}
[data-theme="light"] .gp-sidebar-page-toggle a{color:rgba(0,0,0,.55)}
[data-theme="light"] .gp-sidebar-page-toggle a.active{background:rgba(59,130,246,.1);color:#2563eb}
.gp-sidebar-tools{display:flex;gap:10px}
[data-theme="light"] .gp-sidebar{background:rgba(241,245,249,.75);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border-color:rgba(0,0,0,.1)}
[data-theme="light"] .gp-sidebar-title{color:#1e293b}
[data-theme="light"] .gp-sidebar-close{background:rgba(0,0,0,.08);color:#64748b}
[data-theme="light"] .gp-sidebar-user{background:rgba(59,130,246,.08);border-color:rgba(59,130,246,.2);color:#1e293b}
[data-theme="light"] .gp-sidebar-auth-btn{background:linear-gradient(110deg,#3b82f6 0%,#2563eb 25%,#60a5fa 45%,#2563eb 55%,#3b82f6 75%,#2563eb 100%);background-size:200% 100%;color:#fff}
[data-theme="light"] .gp-sidebar-divider{background:rgba(0,0,0,.08)}
@media (max-width:768px){.gp-nav,.gp-page-toggle{display:none}.gp-logo-text{font-size:24px}.gp-menu-btn{display:flex;margin-left:auto}.gp-top-right{display:none}.gp-top-left{flex:1;justify-content:flex-start;gap:12px}}

/* ── Mobile history FAB + drawer ── */
@media (max-width:1300px){
  .gp-history-fab{position:fixed;bottom:80px;right:24px;z-index:9999;width:40px;height:40px;border-radius:50%;border:1px solid var(--stroke);background:var(--bg2);color:var(--dim);font-size:15px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 12px rgba(0,0,0,.3);transition:background .2s,color .2s,transform .2s;font-family:inherit;padding:0}
  .gp-history-fab:hover{color:var(--txt);background:var(--bg2);box-shadow:0 4px 16px rgba(0,0,0,.4);transform:scale(1.05)}
  .gp-history-fab:active{transform:scale(.95)}
  .gp-history-fab.gp-fab-running{border-color:var(--accbdr);box-shadow:0 0 20px var(--accbg)}
  .gp-history-fab .gp-fab-icon{display:block}
  .gp-history-fab.gp-fab-running .gp-fab-icon{display:none}
  .gp-fab-spinner{display:none}
  .gp-history-fab.gp-fab-running .gp-fab-spinner{display:block;width:16px;height:16px;border:2px solid rgba(255,255,255,.1);border-top-color:var(--acc);border-radius:50%;animation:gpSpin .7s linear infinite;box-sizing:border-box}
  .gp-right{display:none}
  body.gp-history-open .gp-right{display:flex;position:fixed;top:0;right:0;bottom:0;width:300px;max-width:85vw;z-index:10001;background:rgba(18,18,18,.92);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border-left:1px solid rgba(255,255,255,.1);border-radius:0;padding:12px 12px 8px;animation:gpSlideIn .25s ease;height:auto;margin:0;overflow-y:auto}
  .gp-history-overlay{display:none;position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,.35);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
  body.gp-history-open .gp-history-overlay{display:block}
  body.gp-history-open .gp-history-fab{opacity:0;pointer-events:none}
  .gp-history-fab-close{position:fixed;top:12px;right:12px;width:28px;height:28px;border:0;background:rgba(255,255,255,.08);border-radius:6px;color:#94b4da;font-size:14px;cursor:pointer;display:none;align-items:center;justify-content:center;padding:0;line-height:1;z-index:10002}
  body.gp-history-open .gp-history-fab-close{display:flex}
}
[data-theme="light"] .gp-history-fab{background:rgba(255,255,255,.7);border-color:rgba(0,0,0,.08);color:rgba(0,0,0,.35);box-shadow:0 2px 12px rgba(0,0,0,.08)}
[data-theme="light"] .gp-history-fab:hover{background:rgba(255,255,255,.85);color:#1e293b;box-shadow:0 4px 16px rgba(0,0,0,.1)}
[data-theme="light"] .gp-history-fab.gp-fab-running{border-color:rgba(59,130,246,.3);box-shadow:0 0 20px rgba(59,130,246,.12)}
[data-theme="light"] .gp-history-overlay{background:rgba(0,0,0,.12)}
[data-theme="light"] body.gp-history-open .gp-right{background:rgba(255,255,255,.96);border-left-color:rgba(0,0,0,.08)}
[data-theme="light"] .gp-history-fab-close{background:rgba(0,0,0,.06);color:#64748b}

/* ── Negative prompt selector ── */
.gp-negative-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.gp-negative-head label{margin:0}
.gp-neg-btn{width:18px;height:18px;border-radius:4px;border:1px solid var(--accbdr);background:var(--accbg);color:var(--acc);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1;transition:background .2s,border-color .2s,transform .2s;flex-shrink:0;font-family:inherit;font-weight:700}
.gp-neg-btn:hover{border-color:var(--acc);background:rgba(52,211,153,.2);color:var(--acc)}
.gp-neg-btn.on{background:var(--accbg);border-color:var(--acc);color:var(--acc);transform:rotate(45deg)}
[data-theme="light"] .gp-neg-btn{border-color:rgba(59,130,246,.35);background:rgba(59,130,246,.08);color:#3b82f6}
[data-theme="light"] .gp-neg-btn:hover,[data-theme="light"] .gp-neg-btn.on{border-color:#3b82f6;color:#1d4ed8;background:rgba(59,130,246,.16)}
.gp-input-wrap{position:relative}
.gp-block-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.gp-block-head label{margin:0}
.gp-block-actions{display:flex;gap:3px;align-items:center}
.gp-btn-divider{width:1px;height:14px;background:rgba(255,255,255,.12);margin:0 3px;flex-shrink:0}
[data-theme="light"] .gp-btn-divider{background:rgba(0,0,0,.1)}
.gp-io-btn{width:18px;height:18px;border-radius:4px;border:0;background:rgba(255,255,255,.08);color:rgba(255,255,255,.35);font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1;transition:background .2s,color .2s,opacity .2s;flex-shrink:0}
.gp-io-btn:hover{background:rgba(255,255,255,.18);color:#fff}
.gp-io-btn:disabled{opacity:.3;cursor:default;pointer-events:none}
.gp-io-btn.gp-clear-hover:hover{background:rgba(220,38,38,.2);color:#ef4444}
.gp-ai-btn{height:26px;padding:0 14px;border-radius:7px;border:0;font-size:12px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:4px;line-height:1;flex-shrink:0;background:linear-gradient(135deg,var(--acc-start),var(--acc-end));color:#fff;transition:opacity .2s;letter-spacing:.3px;font-family:inherit}
.gp-ai-btn:hover{opacity:.9}
.gp-ai-btn:disabled{opacity:.4;cursor:default;pointer-events:none}
.gp-ai-btn:disabled::after{display:none}
[data-theme="light"] .gp-ai-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 2px 8px rgba(59,130,246,.2)}
[data-theme="light"] .gp-ai-btn:hover{box-shadow:0 4px 14px rgba(59,130,246,.35)}
[data-theme="light"] .gp-io-btn{background:rgba(0,0,0,.06);color:rgba(0,0,0,.25)}
[data-theme="light"] .gp-io-btn:hover{background:rgba(0,0,0,.12);color:rgba(0,0,0,.5)}
[data-theme="light"] .gp-io-btn:disabled{opacity:.25}
[data-theme="light"] .gp-io-btn.gp-clear-hover:hover{background:rgba(220,38,38,.15);color:#dc2626}
.gp-negative-wrap{position:relative}
.gp-neg-panel{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:500;background:rgba(18,18,18,.95);backdrop-filter:blur(16px) saturate(150%);-webkit-backdrop-filter:blur(16px) saturate(150%);border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:12px;max-height:280px;overflow-y:auto;box-shadow:0 12px 40px rgba(0,0,0,.5)}
.gp-neg-panel::-webkit-scrollbar{width:4px}
.gp-neg-panel::-webkit-scrollbar-track{background:transparent}
.gp-neg-panel::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:4px}
.gp-neg-panel::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.4)}
.gp-neg-cat{margin-bottom:10px}
.gp-neg-cat:last-child{margin-bottom:0}
.gp-neg-cat-label{font-size:11px;font-weight:700;color:#94b4da;margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px}
.gp-neg-terms{display:flex;flex-wrap:wrap;gap:4px}
.gp-neg-term{display:inline-block;padding:4px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.06);color:#d7e8ff;font-size:11px;cursor:pointer;transition:background .15s,border-color .15s,color .15s;user-select:none}
.gp-neg-term:hover{border-color:rgba(52,211,153,.5);background:rgba(52,211,153,.12);color:#6ee7b7}
.gp-neg-term.active{background:rgba(52,211,153,.18);border-color:rgba(52,211,153,.55);color:#a7f3d0}
[data-theme="light"] .gp-neg-panel{background:rgba(255,255,255,.95);border-color:rgba(0,0,0,.12);box-shadow:0 12px 40px rgba(0,0,0,.12)}
[data-theme="light"] .gp-neg-panel::-webkit-scrollbar-thumb{background:rgba(0,0,0,.12)}
[data-theme="light"] .gp-neg-panel::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.3)}
[data-theme="light"] .gp-neg-cat-label{color:#64748b}
[data-theme="light"] .gp-neg-term{border-color:rgba(0,0,0,.14);background:rgba(0,0,0,.04);color:#475569}
[data-theme="light"] .gp-neg-term:hover{border-color:rgba(59,130,246,.4);background:rgba(59,130,246,.08);color:#2563eb}
[data-theme="light"] .gp-neg-term.active{background:rgba(31,209,161,.14);border-color:rgba(31,209,161,.45);color:#065f46}

/* ── Language dropdown ── */
.gp-lang-btn{width:34px;height:34px;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.06);color:#dce8f5;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;transition:background .3s,border-color .3s,color .3s,box-shadow .3s;line-height:1;padding:0}
.gp-lang-btn:hover{border-color:rgba(52,211,153,.6);color:#6ee7b7;box-shadow:0 0 14px rgba(52,211,153,.25)}
[data-theme="light"] .gp-lang-btn{border-color:rgba(0,0,0,.12);background:rgba(0,0,0,.04);color:#64748b}
[data-theme="light"] .gp-lang-btn:hover{border-color:rgba(59,130,246,.5);color:#3b82f6;box-shadow:0 0 14px rgba(59,130,246,.2)}
.gp-lang-wrap{position:relative;display:inline-flex}
.gp-lang-dropdown{position:absolute;top:100%;right:0;z-index:99999;min-width:120px;padding-top:4px;opacity:0;visibility:hidden;transform:translateY(-4px);transition:opacity .2s,transform .2s,visibility .2s;pointer-events:none}
.gp-lang-dropdown-inner{background:rgba(18,18,18,.65);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border:1px solid var(--stroke);border-radius:10px;padding:6px;box-shadow:0 12px 40px rgba(0,0,0,.5)}
.gp-lang-wrap:hover .gp-lang-dropdown,.gp-lang-wrap:focus-within .gp-lang-dropdown{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto}
.gp-lang-option{display:block;padding:7px 14px;border-radius:7px;color:var(--txt);font-size:13px;text-decoration:none;transition:background .15s;white-space:nowrap}
.gp-lang-option:hover{background:rgba(52,211,153,.15);color:#6ee7b7}
.gp-lang-option.active{background:rgba(52,211,153,.2);color:#6ee7b7;font-weight:600}
[data-theme="light"] .gp-lang-option{color:#334155}
[data-theme="light"] .gp-lang-option:hover{background:rgba(59,130,246,.08);color:#2563eb}
[data-theme="light"] .gp-lang-option.active{background:rgba(59,130,246,.12);color:#1d4ed8}
[data-theme="light"] .gp-lang-dropdown-inner{background:rgba(241,245,249,.85);border-color:rgba(0,0,0,.1)}

/* ── User avatar dropdown ── */
.gp-user-menu{position:relative;display:inline-flex;align-items:center}
.gp-user-avatar{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.2);background:linear-gradient(135deg,rgba(52,211,153,.25),rgba(52,211,153,.15));cursor:pointer;transition:background .2s,border-color .2s,box-shadow .2s;overflow:hidden;flex-shrink:0}
.gp-user-avatar:hover{border-color:rgba(52,211,153,.6);box-shadow:0 0 10px rgba(52,211,153,.25)}
.gp-avatar-letter{font-size:15px;font-weight:700;color:#e0f2ff;line-height:1}
[data-theme="light"] .gp-user-avatar{border-color:rgba(0,0,0,.12);background:linear-gradient(135deg,rgba(59,130,246,.18),rgba(37,99,235,.1))}
[data-theme="light"] .gp-user-avatar:hover{border-color:rgba(59,130,246,.45);box-shadow:0 0 10px rgba(59,130,246,.2)}
[data-theme="light"] .gp-avatar-letter{color:#1e40af}
.gp-user-dropdown{position:absolute;top:calc(100% + 4px);right:0;z-index:99999;min-width:150px;background:rgba(18,18,18,.65);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border:1px solid var(--stroke);border-radius:10px;padding:6px;box-shadow:0 12px 40px rgba(0,0,0,.5);display:none}
[data-theme="light"] .gp-user-dropdown{background:rgba(241,245,249,.85);border-color:rgba(0,0,0,.1)}
.gp-user-dd-name{padding:7px 14px 4px;font-size:13px;font-weight:600;color:var(--txt);border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:4px}
[data-theme="light"] .gp-user-dd-name{border-bottom-color:rgba(0,0,0,.08);color:#1e293b}
.gp-user-dd-item{padding:7px 14px;border-radius:7px;font-size:13px;color:var(--txt);cursor:pointer;transition:background .15s;white-space:nowrap}
.gp-user-dd-item:hover{background:rgba(52,211,153,.15);color:#6ee7b7}
[data-theme="light"] .gp-user-dd-item{color:#334155}
[data-theme="light"] .gp-user-dd-item:hover{background:rgba(59,130,246,.08);color:#2563eb}
.gp-user-dd-logout{color:#f87171 !important}
.gp-user-dd-logout:hover{background:rgba(248,113,113,.12) !important;color:#fca5a5 !important}
[data-theme="light"] .gp-user-dd-logout{color:#dc2626 !important}
[data-theme="light"] .gp-user-dd-logout:hover{background:rgba(220,38,38,.08) !important;color:#b91c1c !important}
.gp-user-dd-divider{height:1px;background:rgba(255,255,255,.08);margin:4px 0}
[data-theme="light"] .gp-user-dd-divider{background:rgba(0,0,0,.08)}

/* ── Announcement popup ── */
.gp-announce-modal{max-width:640px;width:90%}
.gp-announce-body{max-height:60vh;overflow-y:auto;padding:20px 24px;line-height:1.7;color:var(--txt);font-size:14px}
.gp-announce-body img{max-width:100%;height:auto;border-radius:8px;margin:10px 0;display:block}
.gp-announce-body a{color:#6ee7b7;text-decoration:underline}
.gp-announce-body h1,.gp-announce-body h2,.gp-announce-body h3,.gp-announce-body h4{margin:16px 0 8px;color:var(--txt)}
.gp-announce-body p{margin:0 0 10px}
.gp-announce-body ul,.gp-announce-body ol{padding-left:20px;margin:0 0 10px}
.gp-announce-body blockquote{border-left:3px solid rgba(52,211,153,.4);padding:8px 14px;margin:10px 0;background:rgba(255,255,255,.04);border-radius:0 8px 8px 0}
[data-theme="light"] .gp-announce-body a{color:#2563eb}
[data-theme="light"] .gp-announce-body blockquote{border-left-color:rgba(59,130,246,.4);background:rgba(0,0,0,.02)}
.gp-announce-foot{padding:14px 0 4px;border-top:1px solid rgba(255,255,255,.08);margin-top:14px;display:flex;align-items:center;justify-content:flex-end}
[data-theme="light"] .gp-announce-foot{border-top-color:rgba(0,0,0,.08)}
.gp-announce-checkbox{position:relative;display:inline-flex;align-items:center;gap:10px;cursor:pointer;user-select:none;padding:4px 0}
.gp-announce-checkbox input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.gp-announce-checkbox .gp-toggle-track{width:36px;height:20px;background:rgba(255,255,255,.12);border-radius:999px;position:relative;transition:background .25s;flex-shrink:0}
.gp-announce-checkbox .gp-toggle-track::after{content:'';position:absolute;top:2px;left:2px;width:16px;height:16px;background:#b8cef0;border-radius:50%;transition:transform .25s,background .25s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.gp-announce-checkbox input:checked + .gp-toggle-track{background:rgba(59,246,172,.3)}
.gp-announce-checkbox input:checked + .gp-toggle-track::after{transform:translateX(16px);background:#3bf6ac}
.gp-announce-checkbox .gp-toggle-label{font-size:12px;color:var(--dim);letter-spacing:.3px;white-space:nowrap}
.gp-announce-checkbox:hover .gp-toggle-track{background:rgba(255,255,255,.18)}
.gp-announce-checkbox:hover input:checked + .gp-toggle-track{background:rgba(59,246,172,.4)}
[data-theme="light"] .gp-announce-checkbox .gp-toggle-track{background:rgba(0,0,0,.14)}
[data-theme="light"] .gp-announce-checkbox .gp-toggle-track::after{background:#64748b}
[data-theme="light"] .gp-announce-checkbox input:checked + .gp-toggle-track{background:rgba(16,185,129,.25)}
[data-theme="light"] .gp-announce-checkbox input:checked + .gp-toggle-track::after{background:#10b981}
[data-theme="light"] .gp-announce-checkbox:hover .gp-toggle-track{background:rgba(0,0,0,.2)}
[data-theme="light"] .gp-announce-checkbox:hover input:checked + .gp-toggle-track{background:rgba(16,185,129,.35)}

/* ── Preview close button ── */
.gp-preview-close{position:absolute;top:20px;right:20px;width:28px;height:28px;border-radius:8px;border:1px solid rgba(255,255,255,.25);background:rgba(0,0,0,.5);color:#dce8f5;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1;z-index:10;transition:background .2s,border-color .2s,color .2s;backdrop-filter:blur(6px)}
.gp-preview-close:hover{background:rgba(248,113,113,.3);border-color:rgba(248,113,113,.5);color:#fff}
[data-theme="light"] .gp-preview-close{background:rgba(255,255,255,.8);border-color:rgba(0,0,0,.15);color:#475569}
[data-theme="light"] .gp-preview-close:hover{background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.3);color:#dc2626}

/* ── Loading overlay on preview ── */
.gp-loading-overlay{position:absolute;inset:14px;border-radius:10px;background:rgba(2,6,23,.6);backdrop-filter:blur(4px);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:5;gap:12px}
.gp-loading-overlay span{font-size:13px;color:#dce8f5;font-weight:600}
.gp-loading-hint{font-size:11px !important;color:rgba(255,255,255,.45) !important;font-weight:400 !important;max-width:200px;text-align:center;line-height:1.4}
@keyframes gpSpin{to{transform:rotate(360deg)}}
.gp-spinner{width:32px;height:32px;border:3px solid rgba(255,255,255,.15);border-top-color:#6ee7b7;border-radius:50%;animation:gpSpin .7s linear infinite}
[data-theme="light"] .gp-loading-overlay{background:rgba(255,255,255,.7)}
[data-theme="light"] .gp-loading-overlay span{color:#475569}
[data-theme="light"] .gp-spinner{border-color:rgba(0,0,0,.12);border-top-color:#3b82f6}
.gp-spinner-sm{width:18px;height:18px;border:2px solid rgba(255,255,255,.15);border-top-color:#6ee7b7;border-radius:50%;animation:gpSpin .7s linear infinite;display:inline-block;flex-shrink:0}
.gp-thumb-running{display:flex;align-items:center;justify-content:center}

@keyframes gpBarShimmerH{0%{background-position:-200% center}100%{background-position:200% center}}

/* ── Mask canvas overlay for inpainting ── */
.gp-image-preview{position:relative}

/* ── Confirm dialog ── */
.gp-confirm-overlay{position:fixed;inset:0;z-index:20000;background:rgba(2,6,23,.6);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center}
.gp-confirm-box{background:rgba(18,18,18,.95);border:1px solid rgba(255,255,255,.16);border-radius:16px;width:360px;max-width:90vw;padding:28px 24px 20px;box-shadow:0 24px 60px rgba(2,6,23,.5);text-align:center}
.gp-confirm-msg{margin:0 0 24px;font-size:15px;color:#e0efff;line-height:1.5}
.gp-confirm-actions{display:flex;gap:10px;justify-content:center}
.gp-confirm-btn{padding:8px 24px;border-radius:10px;border:0;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;transition:background .2s,opacity .2s,transform .15s}
.gp-confirm-cancel{background:rgba(255,255,255,.1);color:#c5d8f5}
.gp-confirm-cancel:hover{background:rgba(255,255,255,.18)}
.gp-confirm-ok{background:linear-gradient(145deg,var(--acc-start),var(--acc-end));color:#111111}
.gp-confirm-ok:hover{opacity:.88;transform:translateY(-1px)}
[data-theme="light"] .gp-confirm-overlay{background:rgba(15,23,42,.3)}
[data-theme="light"] .gp-confirm-box{background:rgba(255,255,255,.97);border-color:rgba(0,0,0,.12)}
[data-theme="light"] .gp-confirm-msg{color:#1e293b}
[data-theme="light"] .gp-confirm-cancel{background:rgba(0,0,0,.06);color:#475569}
[data-theme="light"] .gp-confirm-cancel:hover{background:rgba(0,0,0,.12)}
[data-theme="light"] .gp-confirm-ok{background:linear-gradient(145deg,#3b82f6,#2563eb);color:#fff}

/* ── Change password code row ── */
.gp-chgpwd-code-row{display:flex;gap:8px;align-items:center}
.gp-chgpwd-code-row .gp-auth-input{flex:1}
.gp-btn-code{flex-shrink:0;height:40px;padding:0 14px;border:0;border-radius:10px;background:linear-gradient(145deg,var(--acc-start),var(--acc-end));color:#111111;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;white-space:nowrap;transition:opacity .2s,background .2s;line-height:40px}
.gp-btn-code:hover{opacity:.85}
.gp-btn-code:disabled{opacity:.4;cursor:default}
.gp-btn-code.countdown{background:rgba(255,255,255,.1);color:#94b4da}
[data-theme="light"] .gp-btn-code{background:linear-gradient(145deg,#3b82f6,#2563eb);color:#fff}
[data-theme="light"] .gp-btn-code.countdown{background:rgba(0,0,0,.08);color:#64748b}
.gp-chgpwd-divider{height:1px;background:rgba(255,255,255,.08);margin:16px 0}
[data-theme="light"] .gp-chgpwd-divider{background:rgba(0,0,0,.08)}

/* ── 灵感画廊（瀑布流） ── */
.gp-gallery{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}
.gp-gallery-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.08)}
.gp-gallery-title{font-size:14px;font-weight:700;color:#e0efff;display:flex;align-items:center;gap:6px}
.gp-gallery-hint{font-size:11px;color:rgba(255,255,255,.4)}
.gp-gallery-header-left{display:flex;align-items:center;gap:10px}
/* 瀑布流容器 - CSS columns 实现 */
.gp-gallery-grid{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:row;align-items:flex-start;gap:12px;padding-right:4px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent}
.gp-gallery-grid::-webkit-scrollbar{width:3px}
.gp-gallery-grid::-webkit-scrollbar-track{background:transparent}
.gp-gallery-grid::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:2px}
/* 瀑布流列容器 */
.gp-masonry-col{flex:1;display:flex;flex-direction:column;gap:12px;min-width:0}
/* 瀑布流卡片 */
.gp-gallery-card{border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,.18);background:rgba(18,18,18,.35);transition:transform .2s,box-shadow .2s,border-color .2s;position:relative}
.gp-gallery-card:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(2,6,23,.5);border-color:rgba(52,211,153,.5)}
/* 图片区域 - aspect-ratio 由 JS 根据 ratio 字段设 */
.gp-gallery-card-img{width:100%;background:#111111;position:relative}
.gp-gallery-card-img img{position:absolute;top:0;left:0;width:100%;height:100%;display:block;object-fit:cover}
/* 图片加载前占位 - 铺满容器 */
.gp-gallery-card-img .gp-placeholder{position:absolute;inset:0;background:linear-gradient(145deg,rgba(255,255,255,.03),rgba(255,255,255,.08));display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.15);font-size:13px}
/* 右上角角标（模式+比例） */
.gp-gallery-img-badges{position:absolute;top:6px;right:6px;display:flex;gap:4px;z-index:2;pointer-events:none}
.gp-gallery-img-badge{padding:2px 8px;border-radius:999px;font-size:10px;font-weight:700;backdrop-filter:blur(4px);letter-spacing:.5px;white-space:nowrap;border:1px solid rgba(255,255,255,.15);line-height:1.5}
.gp-gallery-img-badge-ratio{background:rgba(0,0,0,.5);color:rgba(255,255,255,.85)}
/* 卡片底部信息 */
.gp-gallery-card-body{padding:10px 12px 12px}
.gp-gallery-card-prompt{font-size:12px;color:#c5d8f5;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-all;margin-bottom:8px}
/* 做同款按钮 - 圆润渐变 + 图标前缀 */
.gp-gallery-same-btn{display:flex;align-items:center;justify-content:center;gap:5px;width:100%;padding:7px 0;border-radius:8px;background:transparent;color:#6ee7b7;font-size:12px;font-weight:600;border:1px solid rgba(52,211,153,.3);cursor:pointer;font-family:inherit;transition:all .2s;letter-spacing:.5px}
.gp-gallery-same-btn::before{content:'✦';font-size:13px;line-height:1}
.gp-gallery-same-btn:hover{background:rgba(52,211,153,.12);border-color:rgba(52,211,153,.6);color:#6ee7b7}
/* 加载更多指示器 */
.gp-gallery-loading{text-align:center;padding:16px 0 8px;font-size:12px;color:rgba(255,255,255,.3);letter-spacing:2px}

/* ── Gallery skeleton loading ── */
.gp-skeleton-card{border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,.08);background:rgba(18,18,18,.25);position:relative}
.gp-skeleton-card .gp-skeleton-img{width:100%;padding-bottom:75%;background:rgba(255,255,255,.03)}
.gp-skeleton-card .gp-skeleton-body{padding:10px 12px 12px;display:flex;flex-direction:column;gap:8px}
.gp-skeleton-card .gp-skeleton-line{height:12px;border-radius:6px;background:rgba(255,255,255,.04)}
.gp-skeleton-card .gp-skeleton-line-sm{width:65%}
.gp-skeleton-card .gp-skeleton-btn{height:32px;border-radius:999px;background:rgba(255,255,255,.03)}
[data-theme="light"] .gp-skeleton-card{background:rgba(255,255,255,.5);border-color:rgba(0,0,0,.06)}
/* 响应式列数 */
@media (max-width:1300px){.gp-masonry-col{min-width:calc(50% - 6px)}}
@media (max-width:600px){.gp-gallery-grid{flex-direction:column}.gp-masonry-col{min-width:100%}}

[data-theme="light"] .gp-gallery-title{color:#1e293b}
[data-theme="light"] .gp-gallery-hint{color:rgba(0,0,0,.3)}
[data-theme="light"] .gp-gallery-card{background:rgba(255,255,255,.7);border-color:rgba(0,0,0,.1)}
[data-theme="light"] .gp-gallery-card:hover{border-color:rgba(59,130,246,.4);box-shadow:0 8px 20px rgba(0,0,0,.1)}
[data-theme="light"] .gp-gallery-card-prompt{color:#334155}
[data-theme="light"] .gp-gallery-same-btn{background:transparent;border-color:rgba(59,130,246,.3);color:#2563eb}
[data-theme="light"] .gp-gallery-same-btn:hover{background:rgba(59,130,246,.1);border-color:rgba(59,130,246,.5);color:#1d4ed8}

/* 灵动岛提示 */
.gp-toast-dynamic .gp-toast-icon{font-size:10px;opacity:.7}
[data-theme="light"] .gp-toast-dynamic{background:rgba(240,245,255,.92)!important;border-color:rgba(0,0,0,.08)!important;color:#1e293b!important;box-shadow:0 4px 20px rgba(0,0,0,.12), inset 0 1px 0 rgba(255,255,255,.6)!important}
[data-theme="light"] .gp-gallery-img-badge-ratio{background:rgba(0,0,0,.4);color:#fff}

/* ── 灵感画廊对比视图 ── */
.gp-gallery-card-compare{display:flex;flex-direction:row;align-items:stretch;width:100%;position:relative}
.gp-gallery-compare-half{flex:1;min-width:0;position:relative;overflow:hidden}
.gp-gallery-compare-half img{position:absolute;top:0;left:0;width:100%;height:100%;display:block;object-fit:cover;z-index:0}
.gp-gallery-compare-label{position:absolute;bottom:6px;left:50%;transform:translateX(-50%);font-size:10px;padding:2px 10px;border-radius:999px;background:rgba(0,0,0,.7);color:#fff;font-weight:700;letter-spacing:1px;white-space:nowrap;pointer-events:none;backdrop-filter:blur(4px);z-index:2;box-shadow:0 1px 4px rgba(0,0,0,.3)}
.gp-gallery-compare-divider{width:3px;background:rgba(255,255,255,.35);flex-shrink:0;position:relative;z-index:2}
.gp-gallery-compare-divider::after{content:'VS';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:9px;font-weight:800;color:#111111;background:linear-gradient(145deg,#fbbf24,#f59e0b);padding:2px 5px;border-radius:4px;line-height:1.3;z-index:3;box-shadow:0 1px 4px rgba(0,0,0,.3)}
[data-theme="light"] .gp-gallery-compare-label{background:rgba(0,0,0,.75)}
[data-theme="light"] .gp-gallery-compare-divider{background:rgba(0,0,0,.2)}
[data-theme="light"] .gp-gallery-compare-divider::after{color:#fff}
/* 多原图：flex 列等分，与右半高度一致 */
.gp-gallery-compare-half.gp-gallery-compare-sources{display:flex;flex-direction:column;gap:1px}
.gp-gallery-compare-half.gp-gallery-compare-sources img{flex:1;width:100%;min-height:0;object-fit:cover;position:static!important}

/* 卡片内标签 */
.gp-gallery-card-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}
.gp-gallery-tag-pill{font-size:10px;padding:1px 7px;border-radius:999px;background:rgba(255,255,255,.08);color:rgba(255,255,255,.5);border:1px solid rgba(255,255,255,.1);font-weight:500;white-space:nowrap}
[data-theme="light"] .gp-gallery-tag-pill{background:rgba(0,0,0,.05);color:rgba(0,0,0,.4);border-color:rgba(0,0,0,.1)}
/* 画廊点击预览大图 */
.gp-gallery-preview{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.85);z-index:10000;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:15px}
.gp-gallery-preview img{max-width:90%;max-height:90%;border-radius:8px;object-fit:contain;cursor:default}
.gp-gallery-preview-compare{display:flex;gap:1px;cursor:default;align-items:stretch}
.gp-gallery-preview-half{display:flex;flex-direction:column}
.gp-gallery-preview-half:first-child{flex:1;min-width:0}
.gp-gallery-preview-half:first-child img{flex:1;min-height:0;width:100%;max-height:none;object-fit:contain;border-radius:6px!important;background:none!important;overflow:hidden!important}
.gp-gallery-preview-half:last-child{flex:0 0 auto}
.gp-gallery-preview-half:last-child img{max-height:none;object-fit:contain;border-radius:6px!important;background:none!important;flex:none;overflow:hidden!important}
.gp-gallery-preview-half span{flex-shrink:0;font-size:14px;color:#94b4da;font-weight:600;text-align:center;padding:8px 0 0}
[data-theme="light"] .gp-gallery-preview-half span{color:#64748b}
.gp-magnifier{position:fixed;width:150px;height:150px;border-radius:50%;border:2px solid rgba(255,255,255,.8);pointer-events:none;z-index:10001;background-repeat:no-repeat;box-shadow:0 4px 24px rgba(0,0,0,.6);display:none;overflow:hidden}
.gp-magnifier::after{content:'';position:absolute;top:0;left:0;right:0;bottom:0;border-radius:50%;box-shadow:inset 0 0 12px rgba(0,0,0,.15)}
[data-theme="light"] .gp-loading-hint{color:rgba(0,0,0,.35) !important}

/* ===== 个人中心 ===== */
.gp-profile{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column;padding:16px}
.gp-profile-scroll{flex:1;min-height:0;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent}
.gp-profile-scroll::-webkit-scrollbar{width:4px}
.gp-profile-scroll::-webkit-scrollbar-track{background:transparent}
.gp-profile-scroll::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:4px}
.gp-profile-card{display:flex;align-items:center;gap:16px;padding:20px;background:var(--glass);border:1px solid var(--stroke);border-radius:12px;margin-bottom:12px}
.gp-profile-avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#8b5cf6);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:#fff;flex-shrink:0;overflow:hidden}
.gp-profile-info{flex:1;min-width:0}
.gp-profile-name{font-size:16px;font-weight:700;color:var(--txt);margin-bottom:2px}
.gp-profile-meta{font-size:12px;color:var(--dim);margin-bottom:4px}
.gp-profile-badge{display:inline-block;font-size:11px;padding:2px 10px;border-radius:999px;background:rgba(52,211,153,.15);color:#6ee7b7;border:1px solid rgba(52,211,153,.25)}
.gp-profile-stats{display:flex;gap:16px;text-align:center}
.gp-profile-stat-num{font-size:20px;font-weight:700;color:var(--txt)}
.gp-profile-stat-label{font-size:11px;color:var(--dim);margin-top:1px}
.gp-profile-section{margin-bottom:12px;padding:16px;background:var(--glass);border:1px solid var(--stroke);border-radius:12px}
.gp-profile-section-title{font-size:14px;font-weight:700;color:var(--txt);margin-bottom:6px}
.gp-profile-section-desc{font-size:12px;color:var(--dim);margin-bottom:10px;line-height:1.5}
.gp-profile-share-row{display:flex;gap:8px;align-items:center;margin-bottom:10px}
.gp-profile-share-input{flex:1;background:rgba(13,18,37,.6);border:1px solid var(--stroke);color:var(--txt);font-family:monospace;font-size:12px;padding:8px 10px;border-radius:6px;cursor:default;outline:none}
.gp-profile-share-btn{padding:8px 16px;font-size:13px;white-space:nowrap}
.gp-profile-invite-stats{display:flex;gap:16px;padding:10px 0}
.gp-profile-invite-stat{flex:1;text-align:center}
.gp-profile-invite-num{font-size:22px;font-weight:700;color:var(--txt);display:block}
.gp-profile-invite-label{font-size:11px;color:var(--dim);margin-top:2px}
.gp-profile-invite-divider{width:1px;background:var(--stroke)}
.gp-profile-tip{font-size:11px;color:var(--dim);padding:8px 10px;background:rgba(91,141,239,.08);border:1px solid rgba(91,141,239,.2);border-radius:6px;line-height:1.5}
.gp-profile-action-list{display:flex;flex-direction:column;gap:4px}
.gp-profile-action-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-radius:8px;cursor:pointer;font-size:13px;color:var(--txt);transition:background .15s}
.gp-profile-action-item:hover{background:rgba(255,255,255,.06)}
.gp-profile-action-item.gp-profile-action-logout{color:#f87171}
.gp-profile-action-arrow{font-size:14px;color:var(--dim)}
[data-theme="light"] .gp-profile-avatar{background:linear-gradient(135deg,#2563eb,#7c3aed)}
[data-theme="light"] .gp-profile-badge{background:rgba(37,99,235,.1);color:#2563eb;border-color:rgba(37,99,235,.2)}
[data-theme="light"] .gp-profile-tip{background:rgba(37,99,235,.06);border-color:rgba(37,99,235,.15)}
[data-theme="light"] .gp-profile-action-item:hover{background:rgba(0,0,0,.04)}
[data-theme="light"] .gp-profile-action-item.gp-profile-action-logout{color:#dc2626}

/* ── 移动端底部导航栏 ── */
.gp-mobile-tabs{display:none}
@media (max-width:1300px){
  .gp-mobile-tabs{display:flex;position:fixed;bottom:0;left:0;right:0;height:52px;background:var(--bg2);border-top:1px solid var(--stroke);z-index:9999;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
  .gp-mtab{flex:1;border:0;background:transparent;color:var(--dim);font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;font-family:inherit;transition:color .2s;padding:0}
  .gp-mtab.active{color:var(--acc)}
  .gp-mtab:hover{color:var(--txt)}
  /* 有底部导航时隐藏旧的 FAB */
  .gp-history-fab{display:none!important}
  /* 移动端面板切换：默认只显示画廊 */
  .gp-shell{padding-bottom:60px!important}
  .gp-stage .gp-left,.gp-stage .gp-right,.gp-stage .gp-my{display:none}
  .gp-stage .gp-center{display:flex!important;min-height:calc(100vh - 120px)}
  .gp-stage.mtab-generate .gp-left{display:flex!important}
  .gp-stage.mtab-generate .gp-center{display:none!important}
  .gp-stage.mtab-result .gp-center{display:flex!important}
  .gp-stage.mtab-result .gp-left,.gp-stage.mtab-result .gp-right,.gp-stage.mtab-result .gp-my{display:none!important}
  .gp-stage.mtab-history .gp-right{display:flex!important}
  .gp-stage.mtab-history .gp-center{display:none!important}
  .gp-stage.mtab-my .gp-my{display:flex!important}
  .gp-stage.mtab-my .gp-center{display:none!important}
}
[data-theme="light"] .gp-mobile-tabs{background:rgba(241,245,249,.92);border-top-color:rgba(0,0,0,.1)}
[data-theme="light"] .gp-mtab{color:#64748b}
[data-theme="light"] .gp-mtab.active{color:#3b82f6}
[data-theme="light"] .gp-mtab:hover{color:#1e293b}

/* ── 移动端「我的」面板 ── */
.gp-my{display:none;padding:12px;overflow:hidden}
.gp-my-scroll{flex:1;overflow-y:auto;min-height:0;display:flex;flex-direction:column;gap:12px}
.gp-my-header{display:flex;align-items:center;gap:12px;padding:16px;border:1px solid var(--stroke);border-radius:12px;background:rgba(255,255,255,.02)}
.gp-my-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--acc-start),var(--acc-end));display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;flex-shrink:0;overflow:hidden}
.gp-my-info{flex:1;min-width:0}
.gp-my-name{font-size:16px;font-weight:700;color:var(--txt);margin-bottom:2px}
.gp-my-plan{font-size:12px;color:var(--acc);font-weight:600}
.gp-my-credits{padding:14px 16px;border:1px solid var(--stroke);border-radius:12px;background:rgba(255,255,255,.02);text-align:center}
.gp-my-credits-num{font-size:32px;font-weight:800;color:var(--acc);line-height:1.1}
.gp-my-credits-label{font-size:12px;color:var(--dim);margin-bottom:8px}
.gp-my-credits-track{height:5px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden}
.gp-my-credits-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--acc-start),var(--acc-end));transition:width .4s}
.gp-my-menu{display:flex;flex-direction:column;gap:2px;border:1px solid var(--stroke);border-radius:12px;padding:4px;background:rgba(255,255,255,.02)}
.gp-my-menu-item{padding:12px 14px;border-radius:8px;font-size:14px;color:var(--txt);cursor:pointer;transition:background .15s}
.gp-my-menu-item:hover{background:rgba(255,255,255,.06)}
.gp-my-menu-item.gp-my-menu-logout{color:#f87171;margin-top:2px}
.gp-my-menu-item.gp-my-menu-logout:hover{background:rgba(248,113,113,.12)}
.gp-my-menu-divider{height:1px;background:var(--stroke);margin:4px 0}
.gp-my-auth{padding:16px 0}
.gp-my-auth-btn{width:100%;padding:12px;border:0;border-radius:10px;background:linear-gradient(135deg,var(--acc-start),var(--acc-end));color:#fff;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;transition:opacity .2s}
.gp-my-auth-btn:hover{opacity:.9}
[data-theme="light"] .gp-my-header{background:rgba(255,255,255,.5);border-color:rgba(0,0,0,.1)}
[data-theme="light"] .gp-my-credits{background:rgba(255,255,255,.5);border-color:rgba(0,0,0,.1)}
[data-theme="light"] .gp-my-menu{background:rgba(255,255,255,.5);border-color:rgba(0,0,0,.1)}
[data-theme="light"] .gp-my-menu-item{color:#334155}
[data-theme="light"] .gp-my-menu-item:hover{background:rgba(0,0,0,.04)}
[data-theme="light"] .gp-my-menu-item.gp-my-menu-logout{color:#dc2626}
[data-theme="light"] .gp-my-menu-item.gp-my-menu-logout:hover{background:rgba(220,38,38,.08)}
[data-theme="light"] .gp-my-auth-btn{background:linear-gradient(145deg,#3b82f6,#2563eb);color:#fff}


