*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#07071a;
  --s1:rgba(255,255,255,.05);
  --s2:rgba(255,255,255,.08);
  --b1:rgba(255,255,255,.09);
  --b2:rgba(255,255,255,.15);
  --t1:#f0f0f8;
  --t2:rgba(240,240,248,.5);
  --t3:rgba(240,240,248,.3);
  --purple:#8b5cf6;
  --pink:#ec4899;
  --blue:#0ea5e9;
  --green:#22c55e;
  --red:#ef4444;
  --r:18px;--rs:10px;
}

html{height:100%;background:var(--bg)}
body{
  min-height:100%;
  background:
    radial-gradient(ellipse 90% 50% at 75% -5%,rgba(139,92,246,.22) 0%,transparent 55%),
    radial-gradient(ellipse 60% 40% at 5%  90%,rgba(236,72,153,.14) 0%,transparent 50%),
    radial-gradient(ellipse 40% 40% at 95% 60%,rgba(14,165,233,.08) 0%,transparent 45%),
    #07071a;
  color:var(--t1);
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* Orbs */
.orb{position:fixed;border-radius:50%;filter:blur(110px);pointer-events:none;z-index:0;opacity:.16}
.orb-1{width:550px;height:550px;background:var(--purple);top:-200px;right:-150px;animation:drift 14s ease-in-out infinite alternate}
.orb-2{width:380px;height:380px;background:var(--pink);bottom:40px;left:-120px;animation:drift 18s ease-in-out infinite alternate-reverse}
.orb-3{width:280px;height:280px;background:var(--blue);top:55%;right:8%;animation:drift 10s ease-in-out infinite alternate}
@keyframes drift{to{transform:translate(28px,18px) scale(1.04)}}

/* Layout */
.app{position:relative;z-index:1;max-width:600px;margin:0 auto;padding:16px 16px 40px;display:flex;flex-direction:column;gap:16px}

/* Header */
.header{display:flex;align-items:center;justify-content:space-between;padding:6px 0}
.logo{display:flex;align-items:center;gap:9px}
.logo-gem{font-size:1.5rem;background:linear-gradient(135deg,var(--purple),var(--pink));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.logo-name{font-size:1.1rem;font-weight:700;letter-spacing:-.3px}
.logo-name em{font-style:normal;background:linear-gradient(135deg,var(--purple),var(--pink));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.header-right{display:flex;align-items:center;gap:10px}
.req-counter{font-size:.72rem;color:var(--t3);white-space:nowrap}

/* Hero */
.hero{text-align:center;padding:12px 0 4px}
.hero-title{font-size:clamp(1.6rem,5vw,2.2rem);font-weight:800;line-height:1.2;letter-spacing:-.5px}
.grad-text{background:linear-gradient(135deg,var(--purple),var(--pink) 60%,var(--blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.hero-sub{color:var(--t2);font-size:.88rem;margin-top:10px;line-height:1.6}
.hero-pills{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-top:14px}
.pill{background:var(--s2);border:1px solid var(--b2);border-radius:30px;padding:5px 13px;font-size:.73rem;color:var(--t2);white-space:nowrap}

/* ── Big Upload Section ── */
.upload-section{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.upload-section-single{grid-template-columns:1fr}
.upload-card{
  display:flex;align-items:center;gap:12px;
  background:var(--s1);
  border:1.5px solid var(--b1);
  border-radius:var(--r);
  padding:16px 14px;
  cursor:pointer;
  transition:border-color .2s,background .2s,transform .15s,box-shadow .2s;
  position:relative;overflow:hidden;
}
.upload-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(139,92,246,.07),transparent);
  opacity:0;transition:opacity .25s;pointer-events:none;
}
.upload-card:hover::before{opacity:1}
.upload-card:hover{border-color:rgba(139,92,246,.5);transform:translateY(-2px);box-shadow:0 8px 30px rgba(139,92,246,.15)}
.upload-card:active{transform:scale(.98)}
.upload-card.uc-accent{border-color:rgba(236,72,153,.25)}
.upload-card.uc-accent::before{background:linear-gradient(135deg,rgba(236,72,153,.07),transparent)}
.upload-card.uc-accent:hover{border-color:rgba(236,72,153,.55);box-shadow:0 8px 30px rgba(236,72,153,.15)}

.uc-icon-wrap{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.uc-purple{background:rgba(139,92,246,.18);color:var(--purple)}
.uc-pink{background:rgba(236,72,153,.18);color:var(--pink)}

.uc-body{flex:1;display:flex;flex-direction:column;gap:3px;min-width:0}
.uc-title{font-size:.9rem;font-weight:700}
.uc-sub{font-size:.72rem;color:var(--t2);line-height:1.4}
.uc-arrow{color:var(--t3);font-size:1rem;flex-shrink:0}

/* ── Static photo section ── */
.static-section{
  background:var(--s1);border:1px solid var(--b2);border-radius:var(--r);
  overflow:hidden;
}
.static-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 14px;border-bottom:1px solid var(--b1);
}
.static-label{font-size:.82rem;font-weight:600;color:var(--t2);text-transform:uppercase;letter-spacing:.7px}
.static-actions-top{display:flex;align-items:center;gap:10px}
.btn-text{background:none;border:none;color:var(--purple);font-size:.82rem;cursor:pointer;padding:0}
.btn-text:hover{text-decoration:underline}

.static-canvas-wrap{position:relative;background:#0c0c1e}
#staticCanvas{width:100%;display:block}
.static-loading,.static-no-face{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:8px;
  background:rgba(7,7,26,.75);font-size:.85rem;color:var(--t2);
}
.mini-spinner{width:20px;height:20px;border:2px solid var(--b2);border-top-color:var(--purple);border-radius:50%;animation:spin .7s linear infinite}

.static-hint{font-size:.78rem;color:var(--t3);text-align:center;padding:10px 14px 0}
#staticDownloadBtn{margin:10px 14px 14px;display:flex;align-items:center;justify-content:center;gap:8px}

/* Divider */
.divider{display:flex;align-items:center;gap:12px;color:var(--t3);font-size:.78rem}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--b1)}

/* ── Camera ── */
.camera-wrap{}
.camera-border{
  border-radius:calc(var(--r)+2px);padding:2px;
  background:linear-gradient(135deg,var(--purple),var(--pink),var(--blue),var(--purple));
  background-size:300% 300%;animation:bflow 4s linear infinite;
  box-shadow:0 0 40px rgba(139,92,246,.2),0 0 80px rgba(236,72,153,.1);
}
@keyframes bflow{0%{background-position:0 50%}50%{background-position:100% 50%}100%{background-position:0 50%}}

.camera-inner{position:relative;width:100%;aspect-ratio:4/3;border-radius:var(--r);overflow:hidden;background:#0a0a1a}
#video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}
#canvas{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

.overlay-msg{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  background:rgba(7,7,26,.72);backdrop-filter:blur(8px);
}
.overlay-cam-icon{color:rgba(139,92,246,.65)}
.overlay-msg p{text-align:center;color:var(--t2);font-size:.9rem;line-height:1.6}

.cam-loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;background:rgba(7,7,26,.88);font-size:.84rem;color:var(--t2)}
.pulse-ring{width:50px;height:50px;border-radius:50%;border:2px solid transparent;border-top-color:var(--purple);border-right-color:var(--pink);animation:spin .85s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

.no-face{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.5);color:var(--t2);font-size:.73rem;padding:4px 14px;border-radius:20px;pointer-events:none;white-space:nowrap}

.cam-badge{position:absolute;top:12px;right:12px;display:flex;align-items:center;gap:6px;background:rgba(0,0,0,.42);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:4px 10px;font-size:.7rem;color:var(--t2)}
.dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green);animation:blink 1.4s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}

/* ── Cam controls ── */
.cam-controls{display:flex;gap:10px}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border:none;border-radius:var(--rs);font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s,box-shadow .15s;white-space:nowrap;text-decoration:none}
.btn:active{transform:scale(.97)}
.btn:disabled{opacity:.3;cursor:not-allowed;pointer-events:none}

.btn-primary{flex:1;background:linear-gradient(135deg,var(--purple),var(--pink));color:#fff;box-shadow:0 4px 20px rgba(139,92,246,.35)}
.btn-primary:hover{opacity:.9;box-shadow:0 6px 28px rgba(139,92,246,.5)}

.btn-glass{background:var(--s2);backdrop-filter:blur(12px);border:1px solid var(--b2);color:var(--t1)}
.btn-glass:hover{background:rgba(255,255,255,.12)}

.btn-success{background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff;box-shadow:0 4px 14px rgba(34,197,94,.28)}
.btn-success:hover{opacity:.9}

.btn-full{width:100%}
.btn-sm{padding:8px 14px;font-size:.82rem;border-radius:8px}

/* Capture result */
.capture-result{background:var(--s1);border:1px solid var(--b2);border-radius:var(--r);padding:14px;display:flex;flex-direction:column;align-items:center;gap:12px}
.capture-hdr{width:100%;display:flex;justify-content:space-between;align-items:center;font-size:.82rem;color:var(--t2)}
#photoCanvas{width:100%;border-radius:10px;border:1px solid var(--b1)}

/* ── Gallery ── */
.gallery-section{background:var(--s1);border:1px solid var(--b2);border-radius:var(--r);padding:16px}
.gallery-hdr{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.gallery-title{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--t2)}
.gallery-count{font-size:.7rem;color:var(--t3);background:var(--s2);border:1px solid var(--b1);padding:2px 9px;border-radius:10px}

.gallery-scroll{display:flex;gap:10px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}
.gallery-scroll::-webkit-scrollbar{display:none}

.gcard{flex:0 0 108px;background:var(--s2);border:1.5px solid var(--b1);border-radius:14px;padding:10px 8px 8px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:6px;transition:border-color .2s,background .2s,transform .15s,box-shadow .2s;user-select:none;position:relative;overflow:hidden}
.gcard:hover{border-color:rgba(139,92,246,.5);transform:translateY(-2px)}
.gcard.active{border-color:var(--purple);background:rgba(139,92,246,.1);box-shadow:0 0 20px rgba(139,92,246,.18)}

.gcard-preview{width:100%;height:44px;display:flex;align-items:center;justify-content:center}
.gcard-preview svg{width:100%;height:44px}
.gcard-preview img{width:100%;height:44px;object-fit:contain}
.gcard-name{font-size:.7rem;color:var(--t2);text-align:center;line-height:1.3}
.gcard.active .gcard-name{color:var(--t1)}

.gcard-del{position:absolute;top:5px;right:5px;width:18px;height:18px;border-radius:50%;background:rgba(239,68,68,.75);color:#fff;font-size:.62rem;display:none;align-items:center;justify-content:center;cursor:pointer;border:none;z-index:2}
.gcard:hover .gcard-del{display:flex}

.gcard-add{border-style:dashed;border-color:rgba(139,92,246,.3);background:transparent;color:var(--purple)}
.gcard-add:hover{border-color:var(--purple);background:rgba(139,92,246,.08)}
.gcard-add .add-icon{width:34px;height:34px;border-radius:50%;background:rgba(139,92,246,.14);display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin:4px 0}
.gcard-add .gcard-name{color:var(--purple);font-weight:500}

/* Footer */
.footer{display:flex;align-items:center;justify-content:center;gap:8px;font-size:.72rem;color:var(--t3);padding-top:4px}
.footer a{color:var(--t3);text-decoration:none}
.footer a:hover{color:var(--t2)}

/* ── Icon buttons ── */
.icon-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--b2);background:var(--s1);backdrop-filter:blur(12px);color:var(--t2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .15s,border-color .15s}
.icon-btn:hover{color:var(--t1);border-color:var(--purple)}
.icon-btn-sm{width:26px;height:26px;border-radius:50%;border:1px solid var(--b1);background:var(--s1);color:var(--t2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.75rem}
.icon-btn-sm:hover{color:var(--t1)}

/* ── Modals ── */
.modal-back{position:fixed;inset:0;z-index:100;background:rgba(7,7,26,.78);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;padding:20px;animation:fade .15s ease}
@keyframes fade{from{opacity:0}}
.modal-box{width:100%;max-width:420px;background:#0e0e22;border:1px solid var(--b2);border-radius:var(--r);overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,.65);animation:sUp .2s ease}
@keyframes sUp{from{transform:translateY(14px);opacity:0}}

.modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:15px 18px;border-bottom:1px solid var(--b1);font-size:.9rem;font-weight:600}
.modal-body{padding:18px;display:flex;flex-direction:column;gap:12px}

.field-hint{font-size:.76rem;color:var(--t2);line-height:1.5}
.input-row{display:flex;gap:8px}
.field-input{flex:1;background:var(--s2);border:1px solid var(--b2);border-radius:8px;padding:9px 12px;color:var(--t1);font-size:.87rem;outline:none;transition:border-color .15s}
.field-input:focus{border-color:var(--purple)}
.field-input::placeholder{color:var(--t3)}

/* Key display (masked) */
.key-saved{display:flex;align-items:center;justify-content:space-between;background:var(--s2);border:1px solid var(--b1);border-radius:8px;padding:10px 14px}
.key-mask{font-size:.85rem;color:var(--t2);letter-spacing:2px}
.key-change{background:none;border:none;color:var(--purple);font-size:.8rem;cursor:pointer}
.key-change:hover{text-decoration:underline}

/* ── AI Modal steps ── */
.ai-step{display:flex;flex-direction:column}

.drop-zone{margin:16px;border:2px dashed rgba(139,92,246,.3);border-radius:14px;padding:30px 16px;display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer;transition:border-color .2s,background .2s}
.drop-zone:hover,.drop-zone.dz-over{border-color:var(--purple);background:rgba(139,92,246,.06)}
.dz-icon{color:rgba(139,92,246,.6)}
.dz-text{text-align:center;font-size:.9rem;line-height:1.6}
.dz-text span{color:var(--purple)}
.dz-hint{text-align:center;font-size:.75rem;color:var(--t2)}

/* URL row */
.url-row{padding:0 16px 16px;display:flex;flex-direction:column;gap:8px}
.or-sep{display:flex;align-items:center;gap:10px;color:var(--t3);font-size:.75rem}
.or-sep::before,.or-sep::after{content:'';flex:1;height:1px;background:var(--b1)}
.url-input-wrap{display:flex;gap:8px}

.prog-preview{margin:14px 18px 0;border-radius:12px;overflow:hidden;border:1px solid var(--b1);max-height:190px;display:flex;align-items:center;justify-content:center;background:var(--s2)}
.prog-preview img{width:100%;max-height:190px;object-fit:contain}

.prog-steps{padding:12px 18px 18px;display:flex;flex-direction:column}
.ps{display:flex;align-items:center;gap:14px;padding:11px 0;border-bottom:1px solid var(--b1);opacity:.3;transition:opacity .3s}
.ps:last-child{border-bottom:none}
.ps.ps-active{opacity:1}
.ps.ps-done{opacity:.65}

.ps-dot{width:28px;height:28px;border-radius:50%;border:2px solid var(--b2);background:var(--s2);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.75rem;position:relative;transition:border-color .3s,background .3s}
.ps.ps-active .ps-dot{border-color:var(--purple);background:rgba(139,92,246,.12)}
.ps.ps-active .ps-dot::after{content:'';position:absolute;width:10px;height:10px;border:2px solid transparent;border-top-color:var(--purple);border-radius:50%;animation:spin .7s linear infinite}
.ps.ps-done .ps-dot{border-color:var(--green);background:rgba(34,197,94,.1);color:var(--green)}
.ps.ps-done .ps-dot::after{display:none}
.ps-info{display:flex;flex-direction:column;gap:3px}
.ps-info b{font-size:.86rem;font-weight:600}
.ps-info span{font-size:.72rem;color:var(--t2)}

.result-chk{margin:14px 18px 8px;background:repeating-conic-gradient(rgba(255,255,255,.04) 0 25%,transparent 0 50%) 0 0/16px 16px;border-radius:12px;border:1px solid var(--b1);display:flex;align-items:center;justify-content:center;min-height:120px;overflow:hidden}
#resultCanvas{max-width:100%;max-height:170px;border-radius:10px}
.result-name-txt{text-align:center;font-size:.86rem;color:var(--t2);padding:0 18px}
#addToGalleryBtn{margin:10px 18px 18px}

.err-icon{font-size:2.2rem;text-align:center;color:var(--red);padding:20px 0 8px}
.err-msg{text-align:center;color:var(--t2);font-size:.86rem;padding:0 20px;line-height:1.6}
#retryBtn{margin:14px 18px 18px}

/* Toast */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);z-index:200;background:#12122a;border:1px solid var(--b2);color:var(--t1);font-size:.84rem;padding:9px 20px;border-radius:30px;box-shadow:0 8px 28px rgba(0,0,0,.45);white-space:nowrap;animation:tIn .2s ease}
@keyframes tIn{from{opacity:0;transform:translateX(-50%) translateY(8px)}}
.toast.success{border-color:var(--green);color:var(--green)}
.toast.error{border-color:var(--red);color:var(--red)}

.hidden{display:none!important}

@media(max-width:480px){
  .upload-section{grid-template-columns:1fr}
  .btn{font-size:.83rem;padding:11px 14px}
  .hero-title{font-size:1.5rem}
}
