/* ═══════════════════════════════════════════════════════════
   Panorama360 v2 — Main Styles
   ═══════════════════════════════════════════════════════════ */
:root {
    --bg:#08080d; --bg2:#0f0f16; --bg3:#16161f; --bg-card:#111119; --bg-hover:#1a1a26;
    --tx:#e4e4ee; --tx2:#8888a0; --tx3:#505068;
    --accent:#6366f1; --accent-l:#818cf8; --accent-g:rgba(99,102,241,.25); --accent-s:rgba(99,102,241,.08);
    --ok:#34d399; --err:#f87171; --warn:#fbbf24;
    --bdr:rgba(255,255,255,.06);
    --r:12px; --rs:8px; --rl:16px;
    --ff:'Manrope',-apple-system,sans-serif; --fm:'DM Mono',monospace;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:var(--ff);background:var(--bg);color:var(--tx);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}
a{color:var(--accent-l);text-decoration:none} img{max-width:100%;display:block}

/* ── Buttons ───────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border:none;border-radius:var(--rs);font-family:var(--ff);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none;white-space:nowrap}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 0 20px var(--accent-g)}
.btn-primary:hover{background:var(--accent-l);box-shadow:0 0 30px var(--accent-g);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--tx2);border:1px solid var(--bdr)}
.btn-ghost:hover{background:var(--bg-hover);color:var(--tx)}
.btn-sm{padding:6px 14px;font-size:.8rem} .btn-xs{padding:4px 10px;font-size:.72rem}
.btn-lg{padding:14px 28px;font-size:1rem} .btn-full{width:100%;justify-content:center}
.btn-danger{color:var(--err)}.btn-danger:hover{background:rgba(248,113,113,.1)}
.btn-success{background:var(--ok)!important;color:#000!important}

/* ── Alerts ────────────────────────────────────── */
.alert{padding:12px 16px;border-radius:var(--rs);font-size:.85rem;margin-bottom:16px}
.alert-error{background:rgba(248,113,113,.1);color:var(--err);border:1px solid rgba(248,113,113,.2)}
.alert-success{background:rgba(52,211,153,.1);color:var(--ok);border:1px solid rgba(52,211,153,.2)}

/* ── Topbar ────────────────────────────────────── */
.topbar{height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 20px;background:rgba(8,8,13,.95);backdrop-filter:blur(12px);border-bottom:1px solid var(--bdr);position:sticky;top:0;z-index:100}
.topbar-transparent{background:transparent;border-bottom:none}
.topbar-left,.topbar-right{display:flex;align-items:center;gap:12px}
.topbar-title{font-size:.95rem;font-weight:600}
.logo-sm{width:28px;height:28px;color:var(--accent)}
.user-badge{font-size:.85rem;color:var(--tx2);display:flex;align-items:center;gap:6px}
.role-tag{font-size:.65rem;padding:2px 6px;border-radius:4px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.role-tag,.role-user{background:rgba(136,136,160,.1);color:var(--tx3)}
.role-admin{background:rgba(99,102,241,.15);color:var(--accent-l)}

/* ═══ AUTH ═════════════════════════════════════════ */
.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px;overflow:hidden}
.auth-bg{position:fixed;inset:0;pointer-events:none}
.orb{position:absolute;border-radius:50%}
.orb-1{width:500px;height:500px;top:-150px;right:-150px;background:radial-gradient(circle,rgba(99,102,241,.06),transparent 70%);animation:drift 20s ease-in-out infinite}
.orb-2{width:400px;height:400px;bottom:-100px;left:-100px;background:radial-gradient(circle,rgba(99,102,241,.04),transparent 70%);animation:drift 16s ease-in-out infinite reverse}
.grid-lines{position:absolute;inset:0;background-image:linear-gradient(rgba(99,102,241,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(99,102,241,.025) 1px,transparent 1px);background-size:60px 60px}
@keyframes drift{0%,100%{transform:translate(0,0)}50%{transform:translate(20px,-20px)}}
.auth-container{width:100%;max-width:420px;position:relative;z-index:10}
.auth-brand{text-align:center;margin-bottom:28px}
.logo-mark{width:56px;height:56px;margin:0 auto 14px;color:var(--accent)}
.auth-brand h1{font-size:1.5rem;font-weight:800;letter-spacing:-.02em}
.tagline{color:var(--tx2);font-size:.88rem;margin-top:4px}
.auth-tabs{display:flex;gap:4px;background:var(--bg2);border-radius:var(--rs);padding:4px;margin-bottom:20px}
.tab-btn{flex:1;padding:10px;background:transparent;border:none;border-radius:6px;color:var(--tx3);font-family:var(--ff);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}
.tab-btn.active{background:var(--accent);color:#fff}
.auth-form{display:none}.auth-form.active{display:block}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:.72rem;font-weight:500;color:var(--tx2);margin-bottom:5px;text-transform:uppercase;letter-spacing:.06em;font-family:var(--fm)}
.form-group label small{text-transform:none;letter-spacing:normal;font-family:var(--ff);opacity:.7}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:11px 14px;background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--rs);color:var(--tx);font-family:var(--ff);font-size:.9rem;outline:none;transition:border .2s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-g)}
.form-group input::placeholder{color:var(--tx3)}
.form-group textarea{resize:vertical;font-size:.82rem;font-family:var(--fm)}
.auth-footer{margin-top:20px;text-align:center;color:var(--tx3);font-size:.78rem}

/* ═══ DASHBOARD ═══════════════════════════════════ */
.dashboard-main{max-width:1100px;margin:0 auto;padding:28px 20px 60px}
.dashboard-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:16px}
.dashboard-header h1{font-size:1.5rem;font-weight:800;letter-spacing:-.02em}
.subtitle{color:var(--tx3);font-size:.82rem;font-family:var(--fm);margin-top:3px}
.empty-state{text-align:center;padding:60px 20px;max-width:380px;margin:0 auto}
.empty-icon{width:80px;height:80px;margin:0 auto 20px;color:var(--tx3)}
.empty-state h2{font-size:1.15rem;margin-bottom:8px}
.empty-state p{color:var(--tx2);font-size:.88rem;margin-bottom:20px}
.panorama-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:18px}
.pano-card{background:var(--bg-card);border:1px solid var(--bdr);border-radius:var(--rl);overflow:hidden;transition:all .2s}
.pano-card:hover{border-color:rgba(255,255,255,.1);box-shadow:0 8px 32px rgba(0,0,0,.3)}
.pano-preview{aspect-ratio:2/1;background:var(--bg3);position:relative;overflow:hidden}
.pano-preview img{width:100%;height:100%;object-fit:cover}
.preview-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.4);opacity:0;transition:opacity .2s}
.pano-card:hover .preview-overlay{opacity:1}
.play-badge{background:rgba(255,255,255,.15);backdrop-filter:blur(8px);padding:8px 18px;border-radius:20px;font-size:.82rem;font-weight:600;color:#fff;border:1px solid rgba(255,255,255,.2)}
.pano-status{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;height:100%;color:var(--tx3);font-size:.82rem}
.pano-status.failed{color:var(--err)}
.pano-info{padding:14px 16px 6px}
.pano-info h3{font-size:.95rem;font-weight:600;margin-bottom:3px}
.pano-meta{display:flex;gap:5px;color:var(--tx3);font-size:.75rem;font-family:var(--fm)}
.pano-actions{padding:8px 16px 14px;display:flex;gap:6px;flex-wrap:wrap}

/* ── Stats ─────────────────────────────────────── */
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:24px}
.stat-card{background:var(--bg-card);border:1px solid var(--bdr);border-radius:var(--r);padding:16px 20px;text-align:center}
.stat-num{font-size:1.8rem;font-weight:800;color:var(--accent-l);font-family:var(--fm)}
.stat-label{font-size:.75rem;color:var(--tx3);margin-top:2px;text-transform:uppercase;letter-spacing:.05em}

/* ── Admin ─────────────────────────────────────── */
.admin-section{margin-bottom:32px}
.admin-section h2{font-size:1.1rem;font-weight:700;margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--bdr)}
.admin-form .form-row{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end}
.admin-form .form-group{flex:1;min-width:150px}
.admin-form .form-group-btn{flex:0 0 auto}
.admin-form .form-group-btn .btn{height:42px}
.admin-table-wrap{overflow-x:auto}
.admin-table{width:100%;border-collapse:collapse;font-size:.82rem}
.admin-table th{text-align:left;padding:8px 12px;color:var(--tx3);font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;font-family:var(--fm);border-bottom:1px solid var(--bdr);white-space:nowrap}
.admin-table td{padding:10px 12px;border-bottom:1px solid var(--bdr);vertical-align:middle}
.admin-table .mono{font-family:var(--fm);font-size:.78rem;color:var(--tx2)}
.admin-table .row-disabled td{opacity:.4}
.admin-table .actions-cell{white-space:nowrap}
.admin-table .actions-cell form{display:inline-block;margin-right:4px}
.status-dot{display:inline-flex;align-items:center;gap:5px;font-size:.75rem}
.status-dot::before{content:'';width:6px;height:6px;border-radius:50%;display:inline-block}
.status-dot.active::before{background:var(--ok);box-shadow:0 0 6px rgba(52,211,153,.4)}
.status-dot.inactive::before{background:var(--err)}
.text-muted{color:var(--tx3);font-size:.78rem}

/* ── Modal ─────────────────────────────────────── */
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(6px);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px}
.modal{background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--rl);width:100%;max-width:540px;max-height:90vh;overflow-y:auto}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--bdr)}
.modal-header h3{font-size:1rem;font-weight:700}
.modal-close{background:none;border:none;color:var(--tx2);font-size:1.4rem;cursor:pointer;line-height:1}
.modal-body{padding:20px}
.share-section{margin-bottom:20px}
.share-section label{display:block;font-size:.72rem;font-weight:500;color:var(--tx2);margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em;font-family:var(--fm)}
.copy-field{display:flex;gap:8px;align-items:flex-start}
.copy-field input,.copy-field textarea{flex:1;padding:10px 12px;background:var(--bg);border:1px solid var(--bdr);border-radius:var(--rs);color:var(--tx);font-family:var(--fm);font-size:.8rem;outline:none}
.embed-preview{background:var(--bg);border:1px solid var(--bdr);border-radius:var(--rs);overflow:hidden;min-height:100px}
.embed-preview iframe{display:block}

/* ═══ CAPTURE PAGE (shared with capture.css) ═════ */
.capture-page{background:#000;overflow:hidden}
.capture-step{display:none;width:100%;min-height:100vh}
.capture-step.active{display:flex;flex-direction:column}
#step-setup{background:var(--bg)}
.setup-content{flex:1;max-width:480px;margin:0 auto;padding:16px 24px 40px}
.setup-icon{width:70px;height:70px;margin:12px auto;color:var(--accent);animation:pulse-spin 10s linear infinite}
@keyframes pulse-spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}
.setup-content h1{text-align:center;font-size:1.3rem;margin-bottom:6px}
.setup-content>p{text-align:center;color:var(--tx2);font-size:.88rem;margin-bottom:24px}
.setup-options{margin-bottom:20px}
.option-group{margin-bottom:18px}
.option-group label{display:block;font-size:.72rem;font-weight:500;color:var(--tx2);margin-bottom:6px;text-transform:uppercase;letter-spacing:.06em;font-family:var(--fm)}
.option-group input[type="text"],.option-group select{width:100%;padding:11px 14px;background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--rs);color:var(--tx);font-family:var(--ff);font-size:.9rem;outline:none}
.range-group{display:flex;align-items:center;gap:12px}
.range-group input[type="range"]{flex:1;accent-color:var(--accent)}
.range-group span{font-family:var(--fm);font-size:.85rem;color:var(--accent-l);min-width:75px;text-align:right}
.hint{font-size:.73rem;color:var(--tx3);margin-top:4px}
.setup-tips{margin-top:20px;padding:14px 16px;background:var(--accent-s);border:1px solid rgba(99,102,241,.15);border-radius:var(--r)}
.setup-tips h3{font-size:.75rem;color:var(--accent-l);margin-bottom:6px;font-family:var(--fm);text-transform:uppercase}
.setup-tips p{color:var(--tx2);font-size:.82rem;line-height:1.8}

/* ── Processing / Result (shared) ──────────────── */
#step-processing{background:var(--bg);align-items:center;justify-content:center}
.processing-content{text-align:center;padding:40px;max-width:380px}
.processing-animation{width:100px;height:100px;margin:0 auto 28px;position:relative}
.processing-ring{position:absolute;inset:0;border:2px solid transparent;border-radius:50%}
.ring-1{border-top-color:var(--accent);animation:spin 2s linear infinite}
.ring-2{inset:10px;border-right-color:var(--accent-l);animation:spin 1.5s linear infinite reverse}
.ring-3{inset:20px;border-bottom-color:rgba(99,102,241,.3);animation:spin 3s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.processing-content h2{font-size:1.15rem;margin-bottom:6px}
#processing-status{color:var(--tx2);font-size:.88rem;margin-bottom:20px}
.progress-bar{width:100%;height:3px;background:var(--bg3);border-radius:2px;overflow:hidden;margin-bottom:14px}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-l));border-radius:2px;transition:width .3s;width:0}
.processing-hint{color:var(--tx3);font-size:.78rem}
#step-result{background:var(--bg);align-items:center;justify-content:center}
.result-content{text-align:center;padding:40px;max-width:380px}
.result-icon{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin:0 auto 20px}
.success-icon{background:rgba(52,211,153,.1);color:var(--ok);border:2px solid rgba(52,211,153,.3)}
.error-icon{background:rgba(248,113,113,.1);color:var(--err);border:2px solid rgba(248,113,113,.3)}
.result-content h2{font-size:1.2rem;margin-bottom:8px}
.result-content p{color:var(--tx2);font-size:.88rem;margin-bottom:20px}
.result-actions{display:flex;flex-direction:column;gap:8px}
.spinner{width:28px;height:28px;border:2px solid var(--bdr);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}

/* ── Responsive ────────────────────────────────── */
@media(max-width:640px){
    .dashboard-header{flex-direction:column}
    .panorama-grid{grid-template-columns:1fr}
    .admin-form .form-row{flex-direction:column}
    .topbar-right{gap:6px}
    .topbar-right .user-badge{display:none}
}
