:root {
    --brand-navy: #0A192F;
    --brand-gold: #C5A059;
    --brand-gold-dark: #a88446;
    --text-main: #2D3748;
    --text-muted: #718096;
    --bg-light: #F8FAFC;
    --bg-soft: #F3F6FA;
    --border: #E2E8F0;
    --white: #ffffff;
    --radius: 12px;
    --radius-lg: 18px;
    --radius-xl: 24px;
    --shadow-sm: 0 8px 24px rgba(10, 25, 47, 0.06);
    --shadow-md: 0 16px 40px rgba(10, 25, 47, 0.08);
    --shadow-lg: 0 22px 50px rgba(10, 25, 47, 0.10);
    --step-anim: 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
    font-family: 'IBM Plex Sans Arabic', 'Segoe UI', Tahoma, Arial, sans-serif;
    background: var(--bg-light);
    color: var(--text-main);
}
a { color: inherit; text-decoration: none; }
button, input, select, textarea, table, th, td, label, a, span, p, div, strong, small, h1, h2, h3, h4 {
    font-family: 'IBM Plex Sans Arabic', 'Segoe UI', Tahoma, Arial, sans-serif;
}
body.auth-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: linear-gradient(135deg, rgba(10,25,47,1) 0%, rgba(10,25,47,.95) 58%, rgba(197,160,89,.95) 100%);
}
.dashboard {
    display: grid;
    grid-template-columns: 350px 1fr;
    min-height: 100vh;
    background: var(--white);
}
.side-info {
    background: var(--brand-navy);
    color: var(--white);
    padding: 42px 34px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    position: sticky;
    top: 0;
    min-height: 100vh;
    overflow-y: auto;
}
.side-info h1, .brand-title {
    font-weight: 600;
    font-size: 1.65rem;
    border-right: 4px solid var(--brand-gold);
    padding-right: 14px;
    margin: 0 0 10px;
    line-height: 1.4;
}
.brand-subtitle, .side-info .intro-copy {
    opacity: 0.78;
    font-size: 0.92rem;
    line-height: 1.9;
}
.track-list {
    list-style: none;
    margin: 34px 0 0;
    padding: 0;
}
.track-item {
    position: relative;
    padding: 0 30px 32px 0;
    border-right: 2px solid rgba(255,255,255,0.11);
    transition: 0.3s;
    color: rgba(255,255,255,0.48);
    font-size: 0.95rem;
    line-height: 1.8;
}
.track-item.active {
    color: var(--brand-gold);
    border-right-color: var(--brand-gold);
    font-weight: 600;
}
.track-item::after {
    content: '';
    position: absolute;
    top: 0.15rem;
    right: -7px;
    width: 12px;
    height: 12px;
    background: var(--brand-navy);
    border: 2px solid currentColor;
    border-radius: 50%;
    z-index: 2;
}
.side-footer {
    font-size: 0.78rem;
    opacity: 0.55;
    line-height: 1.9;
}
.main-form {
    padding: 40px 4%;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    position: relative;
    background: linear-gradient(180deg, #fff 0%, #fbfcfe 100%);
}
.main-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 28px;
    flex-wrap: wrap;
}
.brand-inline {
    display: flex;
    align-items: center;
    gap: 14px;
}
.brand-inline img, .logo-thumb {
    width: 64px;
    height: 64px;
    object-fit: contain;
    border-radius: 16px;
    background: #fff;
    border: 1px solid var(--border);
    padding: 8px;
}
.brand-inline h2 {
    margin: 0;
    color: var(--brand-navy);
    font-size: 1.35rem;
    line-height: 1.35;
}
.brand-inline p {
    margin: 4px 0 0;
    color: var(--text-muted);
    font-size: 0.92rem;
}
.badge-soft {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    border-radius: 999px;
    border: 1px solid rgba(197,160,89,.26);
    background: rgba(197,160,89,.08);
    color: var(--brand-gold-dark);
    font-weight: 600;
    font-size: 0.92rem;
}
.badge-soft::before {
    content: '';
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--brand-gold);
}
.form-section { display: none; max-width: 980px; animation: slideIn var(--step-anim); }
.form-section.active { display: block; }
@keyframes slideIn { from { opacity: 0; transform: translateX(-18px); } to { opacity: 1; transform: translateX(0); } }
.section-head { margin-bottom: 30px; }
.section-head h2 {
    font-size: 1.8rem;
    color: var(--brand-navy);
    margin: 0 0 8px;
    line-height: 1.4;
    font-weight: 600;
}
.section-head p { color: var(--text-muted); font-size: 0.95rem; line-height: 1.85; margin: 0; }
.grid-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 18px; }
.full-width { grid-column: span 2; }
.field { margin-bottom: 4px; }
.field label { display: block; font-weight: 600; margin-bottom: 8px; font-size: 0.86rem; color: #4A5568; }
.input-ctrl, .input, .select, .textarea {
    width: 100%;
    padding: 14px;
    border: 1.5px solid var(--border);
    border-radius: var(--radius);
    font-size: 0.95rem;
    transition: all 0.2s;
    background: var(--bg-light);
    font-family: inherit;
    color: var(--text-main);
}
.textarea { min-height: 120px; resize: vertical; }
.input-ctrl:focus, .input:focus, .select:focus, .textarea:focus {
    outline: none;
    border-color: var(--brand-navy);
    background: #fff;
    box-shadow: 0 0 0 4px rgba(10, 25, 47, 0.05);
}
.select { appearance: none; background-image: linear-gradient(45deg, transparent 50%, #64748b 50%), linear-gradient(135deg, #64748b 50%, transparent 50%); background-position: calc(100% - 18px) calc(50% - 2px), calc(100% - 12px) calc(50% - 2px); background-size: 6px 6px; background-repeat: no-repeat; padding-inline-end: 34px; }
.action-bar {
    margin-top: 28px;
    padding: 26px 0 0;
    display: flex;
    gap: 15px;
    border-top: 1px solid var(--border);
    flex-wrap: wrap;
}
.btn {
    padding: 14px 24px;
    border-radius: var(--radius);
    font-weight: 600;
    cursor: pointer;
    transition: 0.3s;
    border: none;
    font-size: 0.95rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}
.btn-primary { background: var(--brand-navy); color: #fff; }
.btn-primary:hover { background: #162a4d; transform: translateY(-2px); box-shadow: 0 5px 15px rgba(0,0,0,0.1); }
.btn-ghost, .btn-light { background: transparent; color: #718096; border: 1px solid var(--border); }
.btn-ghost:hover, .btn-light:hover { background: #f1f5f9; }
.btn-danger { background: #9B2C2C; color: #fff; }
.btn-success { background: #166534; color: #fff; }
.alert { padding: 14px 18px; border-radius: var(--radius); margin-bottom: 18px; font-weight: 600; line-height: 1.8; }
.alert-success { background: #EDFDF3; color: #166534; }
.alert-error { background: #FEF2F2; color: #991B1B; }
.chip, .pill, .tag {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 7px 12px;
    border-radius: 999px;
    border: 1px solid rgba(197,160,89,.20);
    background: rgba(197,160,89,.10);
    color: var(--brand-gold-dark);
    font-weight: 600;
    font-size: 0.86rem;
}
.card {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 18px;
    padding: 22px;
    box-shadow: var(--shadow-sm);
    margin-bottom: 18px;
}
.section-title { margin: 0 0 12px; color: var(--brand-navy); font-size: 1.18rem; }
.muted { color: var(--text-muted); line-height: 1.8; }
.grid { display: grid; gap: 16px; }
.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.filters { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 14px; }
.kpi, .kpi-card, .mini-card {
    background: var(--bg-light);
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 18px;
}
.kpi .label, .kpi-label { color: var(--text-muted); font-size: 0.86rem; }
.kpi .value, .kpi-value { font-size: 1.7rem; font-weight: 600; color: var(--brand-navy); margin-top: 6px; }
.table-wrap { overflow: auto; width: 100%; }
table { width: 100%; border-collapse: collapse; }
th, td { padding: 12px; border-bottom: 1px solid var(--border); text-align: right; vertical-align: top; font-size: 0.93rem; }
th { background: var(--bg-light); color: var(--brand-navy); font-weight: 600; }
.metric-bar, .bar { height: 10px; background: #e5e7eb; border-radius: 999px; overflow: hidden; }
.metric-bar span, .bar span { display: block; height: 100%; background: linear-gradient(90deg, var(--brand-gold), var(--brand-navy)); }
.actions { display: flex; gap: 10px; flex-wrap: wrap; }
.option-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.option-item { position: relative; }
.option-item input { position: absolute; opacity: 0; pointer-events: none; }
.option-card {
    display: block;
    border: 1.5px solid var(--border);
    border-radius: 16px;
    padding: 16px;
    background: var(--bg-light);
    cursor: pointer;
    transition: 0.2s;
    min-height: 88px;
}
.option-item input:checked + .option-card {
    border-color: var(--brand-gold);
    background: rgba(197,160,89,.10);
    box-shadow: 0 0 0 4px rgba(197,160,89,.10);
}
.option-card strong { display: block; color: var(--brand-navy); font-size: 0.96rem; margin-bottom: 6px; }
.option-card span { color: var(--text-muted); font-size: 0.9rem; line-height: 1.7; display: block; }
.status-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.status-list li { padding: 12px 14px; border-radius: 14px; background: var(--bg-light); border: 1px solid var(--border); }
.sidebar-nav { list-style: none; padding: 0; margin: 28px 0 0; display: grid; gap: 10px; }
.sidebar-nav a {
    display: block;
    padding: 12px 16px;
    border-radius: 16px;
    background: rgba(255,255,255,0.06);
    color: rgba(255,255,255,0.92);
    transition: 0.2s;
    font-size: 0.98rem;
    font-weight: 600;
}
.sidebar-nav a.active, .sidebar-nav a:hover { background: rgba(197,160,89,.15); color: #fff; }
.no-print {}
.print-head { display: flex; justify-content: space-between; align-items: center; gap: 20px; flex-wrap: wrap; }
.summary-box, .insight {
    padding: 14px 16px;
    border-radius: 16px;
    background: var(--bg-light);
    border: 1px dashed rgba(197,160,89,.35);
    line-height: 2;
}
@media (max-width: 1200px) {
    .filters { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 1000px) {
    .dashboard { grid-template-columns: 1fr; }
    body { overflow: auto; }
    .side-info { padding: 28px 24px; min-height: auto; position: relative; }
    .track-list { display: none; }
    .main-form { padding: 30px 20px; }
    .grid-fields, .grid-4, .grid-3, .grid-2, .filters, .option-grid { grid-template-columns: 1fr; }
    .full-width { grid-column: span 1; }
}
@media print {
    .no-print, .action-bar, .main-topbar, .sidebar-nav { display: none !important; }
    .dashboard { display: block; }
    .side-info { min-height: auto; position: static; }
    .card { box-shadow: none; }
}


:root {
  --question-bg-odd: #f3f6fb;
  --question-bg-even: #edf2f8;
  --question-border: #d6dfeb;

  --option-bg: #eef2f7;
  --option-border: #d3dce7;
  --option-hover: #e6edf5;
  --option-selected: #dde8f6;

  --evidence-bg: #edf2f8;
  --evidence-border: #c7d7ea;
}

/* =========================
   ألوان أغمق لبطاقات الأسئلة
   ========================= */

.question-card,
.question-block,
.eval-question-card {
  background: #f6eef1 !important;
  border: 1px solid #d9b2c1 !important;
  box-shadow: inset 0 0 0 1px #cf9fb0;
}

/* لو عندك بطاقات متناوبة */
.question-card:nth-of-type(even),
.question-block:nth-of-type(even),
.eval-question-card:nth-of-type(even) {
  background: #f3eaee !important;
  border-color: #d3a7b7 !important;
}

/* عنوان كود السؤال الصغير */
.question-card .question-code,
.question-block .question-code,
.eval-question-card .question-code,
.question-badge,
.question-tag {
  border: 1px solid #d3a7b7 !important;
  background: #f8f1f4 !important;
}

/* الخيارات */
.answer-option,
.option-card {
  background: #eef2f6 !important;
  border: 1px solid #c3d0de !important;
}

.answer-option:hover,
.option-card:hover {
  background: #e5ebf2 !important;
  border-color: #aebfd2 !important;
}

/* الخيار المحدد */
.answer-option.selected,
.answer-option.is-selected,
.option-card.selected,
.option-card.is-selected {
  background: #dce6f2 !important;
  border-color: #8faaca !important;
  box-shadow: inset 0 0 0 1px #7f9cbe;
}

/* منطقة الشواهد */
.evidence-box,
.evidence-container,
.question-evidence-box {
  background: #f3f6fb !important;
  border: 1px dashed #9eb7d6 !important;
}
/* --- Virtual Tour PHP edition additions --- */
.landing-shell{padding:40px;display:grid;gap:28px}.landing-hero{display:grid;grid-template-columns:1.15fr .85fr;gap:24px;align-items:center}.hero-copy h1{font-size:clamp(2rem,5vw,4rem);margin:.4rem 0 1rem}.hero-copy p{font-size:1.05rem;color:var(--muted,#64748b);max-width:62ch}.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}.hero-card{padding:22px;border-radius:26px}.hero-logo{max-width:260px;margin-inline:auto}.listing-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.card-tour{padding:0;overflow:hidden}.card-cover{height:180px;background-size:cover;background-position:center}.card-body{padding:18px}.inline-meta{display:flex;gap:10px;flex-wrap:wrap;color:#64748b;font-size:.9rem}.admin-profile-card{background:rgba(255,255,255,.08)!important;border-color:rgba(255,255,255,.12)!important;color:white!important}.admin-name{font-size:1rem;font-weight:700;margin-top:8px}.admin-role,.muted-label{font-size:.85rem;color:rgba(255,255,255,.72)}.public-app{background:#020617;color:white}.tour-shell{min-height:100vh}.tour-stage{position:relative;min-height:100vh}#panorama-viewer{position:absolute;inset:0}.tour-sidebar{position:absolute;top:20px;right:20px;width:min(380px,calc(100vw - 40px));max-height:calc(100vh - 40px);overflow:auto;z-index:12;padding:18px;border-radius:24px;color:white;background:rgba(15,23,42,.72);backdrop-filter:blur(16px)}.sidebar-section{padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.12);margin-bottom:16px}.scene-strip{display:flex;gap:10px;overflow:auto;padding-bottom:4px}.scene-thumb{min-width:130px;border:none;border-radius:16px;overflow:hidden;background:rgba(255,255,255,.08);color:white;cursor:pointer;padding:0}.scene-thumb img{height:72px;width:100%;object-fit:cover}.scene-thumb span{display:block;padding:10px;font-size:.88rem}.scene-thumb.active{outline:2px solid #f59e0b}.panel-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:14px}.floating-map,.floating-gallery,.floating-modal{position:absolute;left:20px;bottom:20px;z-index:14;width:min(460px,calc(100vw - 40px));padding:18px;border-radius:24px;background:rgba(15,23,42,.82);color:white;backdrop-filter:blur(16px)}.floating-modal{top:50%;left:50%;bottom:auto;transform:translate(-50%,-50%);width:min(860px,calc(100vw - 40px))}.hidden{display:none!important}.map-canvas{position:relative;border-radius:18px;overflow:hidden}.map-canvas img{width:100%;display:block}.map-point{position:absolute;transform:translate(-50%,-50%);background:#f59e0b;color:#111827;border:none;border-radius:999px;padding:8px 12px;font-weight:700;cursor:pointer;box-shadow:0 10px 20px rgba(0,0,0,.25)}.map-point.active{background:white}.gallery-card{border:none;padding:0;background:#0b1220;border-radius:16px;overflow:hidden;color:white;text-align:right;cursor:pointer}.gallery-card img{height:130px;width:100%;object-fit:cover}.gallery-card strong,.gallery-card span{display:block;padding:0 12px 12px}.gallery-card strong{padding-top:12px}.responsive-video{position:relative;padding-top:56.25%}.responsive-video iframe{position:absolute;inset:0;width:100%;height:100%}.modal-photo{width:100%;border-radius:18px;margin-bottom:12px}.intro-overlay{position:absolute;inset:0;background:rgba(2,6,23,.82);display:flex;align-items:center;justify-content:center;z-index:20;padding:20px}.intro-card{width:min(920px,100%);padding:24px;border-radius:28px;color:white;background:linear-gradient(135deg,rgba(37,99,235,.3),rgba(15,23,42,.9));backdrop-filter:blur(16px)}.intro-slide{display:grid;grid-template-columns:.9fr 1.1fr;gap:18px;align-items:center}.intro-slide img{width:100%;border-radius:22px;object-fit:cover;max-height:320px}.intro-actions{display:flex;justify-content:flex-end;margin-top:18px}.custom-hotspot .hotspot-badge{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:999px;background:rgba(15,23,42,.78);color:white;border:1px solid rgba(255,255,255,.16);font-size:1.15rem;cursor:pointer}.gallery-thumb-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:18px;overflow:hidden}.gallery-thumb-card img{aspect-ratio:16/10;object-fit:cover}.gallery-thumb-card figcaption{padding:12px;font-size:.9rem}.map-preview-admin img{max-height:360px;object-fit:contain;border-radius:18px;border:1px solid #e5e7eb;margin-top:16px}@media (max-width:980px){.landing-hero,.content-grid,.intro-slide{grid-template-columns:1fr}.tour-sidebar{position:static;width:100%;max-height:none;border-radius:0;background:rgba(15,23,42,.96)}#panorama-viewer{position:relative;height:56vh}.floating-map,.floating-gallery{left:12px;right:12px;bottom:12px;width:auto}}

.permission-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}.permission-card{background:#fff;border:1px solid rgba(148,163,184,.2);border-radius:18px;padding:18px}.checkbox-inline{display:flex;gap:10px;align-items:center;margin:10px 0}.mini-chart{display:flex;align-items:flex-end;gap:12px;min-height:180px;padding:12px 0}.chart-col{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1}.chart-bar{width:100%;max-width:34px;border-radius:12px 12px 4px 4px;background:linear-gradient(180deg,var(--brand-primary),var(--brand-accent))}.micro-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}.muted-text{color:#64748b;line-height:1.8}.modal-video{width:100%;border-radius:16px;display:block}.field-span-2{grid-column:span 2}.custom-hotspot{cursor:pointer}.hotspot-badge{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:999px;background:rgba(15,23,42,.85);color:#fff;font-size:18px;box-shadow:0 8px 20px rgba(15,23,42,.2)}


.template-check-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
.template-check-item{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1px solid rgba(148,163,184,.18);border-radius:14px;background:rgba(15,23,42,.04)}
.template-check-item input{accent-color:var(--brand-primary)}
.stat-card em{display:block;font-style:normal;font-size:.8rem;margin-top:6px;color:#64748b}
.muted-list{display:grid;gap:10px}
.muted-item{padding:12px 14px;border:1px solid rgba(148,163,184,.18);border-radius:14px;background:rgba(15,23,42,.03)}
.floating-share{position:absolute;left:20px;top:20px;z-index:15;width:min(460px,calc(100vw - 40px));padding:18px;border-radius:24px;background:rgba(15,23,42,.82);color:white;backdrop-filter:blur(16px)}
.share-panel-body,.share-actions-wrap{display:grid;gap:12px}.share-actions-wrap{grid-template-columns:repeat(auto-fit,minmax(130px,1fr))}.share-qr-box{display:grid;justify-items:center;gap:10px;padding:14px;border:1px dashed rgba(148,163,184,.3);border-radius:18px;background:rgba(255,255,255,.04)}.share-preview-card,.share-landing-card{display:grid;grid-template-columns:.95fr 1.05fr;gap:18px;align-items:center}.share-preview-card img,.share-landing-media img{width:100%;border-radius:18px;max-height:240px;object-fit:cover}.share-link-preview code{display:block;white-space:normal;word-break:break-all;background:#0f172a;color:#fff;padding:12px;border-radius:12px}.info-chip{display:inline-flex;padding:8px 12px;border-radius:999px;background:rgba(37,99,235,.12);color:#1d4ed8;font-weight:700}.scene-share-shell{max-width:1120px;margin:0 auto}.share-landing-content{display:grid;gap:16px}.share-landing-content h1{margin:0}.share-landing-content p{margin:0;color:#cbd5e1}.share-landing-card{padding:22px}.landing-shell .glass-card{background:rgba(15,23,42,.82);color:#fff}.share-preview strong{display:block;margin-bottom:6px}.share-preview p{color:#cbd5e1;margin:0}@media (max-width:980px){.share-preview-card,.share-landing-card{grid-template-columns:1fr}.floating-share{left:12px;right:12px;top:12px;width:auto}}
.marketing-landing-shell{max-width:1180px;margin:0 auto}.marketing-landing-shell .hero-card{padding:28px}.marketing-landing-shell .muted-list{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.marketing-landing-shell .muted-item{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12);color:#fff}.marketing-landing-shell .muted-item .muted-text{color:#cbd5e1}.marketing-landing-shell .gallery-card span,.marketing-landing-shell .gallery-card strong{color:#fff}.marketing-landing-shell .hero-copy .micro-actions{gap:10px}.marketing-landing-shell .hero-copy .info-chip{background:rgba(255,255,255,.1);color:#fff}.marketing-landing-shell .hero-logo{width:100%;max-width:420px;border-radius:26px;object-fit:cover;max-height:360px}.marketing-landing-shell .section-head h3{color:#fff}.marketing-landing-shell .section-head .muted-text{color:#cbd5e1}
.branded-qr{position:relative;display:grid;place-items:center;min-height:168px}.branded-qr img.qr-overlay-logo,.campaign-qr-preview img.qr-overlay-logo{position:absolute;inset:50% auto auto 50%;transform:translate(-50%,-50%);width:34px;height:34px;object-fit:contain;border-radius:10px;background:#fff;padding:4px;box-shadow:0 8px 18px rgba(15,23,42,.18)}.qr-logo-preview img{width:64px;height:64px;object-fit:contain;border-radius:16px;background:#fff;padding:8px;border:1px solid #e2e8f0}.campaign-link-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}.campaign-link-card{display:grid;grid-template-columns:1fr 132px;gap:16px;align-items:center;padding:18px;border:1px solid #e2e8f0;border-radius:20px;background:#fff}.campaign-link-card code{display:block;white-space:normal;word-break:break-all;background:#0f172a;color:#fff;padding:10px;border-radius:12px;margin-top:10px}.campaign-qr-preview{position:relative;display:grid;place-items:center;min-height:118px;border-radius:18px;background:linear-gradient(135deg,#eff6ff,#f8fafc);border:1px dashed #bfdbfe}.compact-stats{grid-template-columns:repeat(3,minmax(0,1fr))}.landing-block-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px}.landing-block-card{padding:18px;border-radius:22px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);display:grid;gap:10px}.landing-block-card h4{margin:0;font-size:1.08rem}.landing-block-card p{margin:0;color:#cbd5e1}.landing-template-cinematic .hero-card{background:linear-gradient(135deg,rgba(37,99,235,.18),rgba(15,23,42,.92))}.landing-template-executive .hero-card{background:linear-gradient(180deg,rgba(15,23,42,.96),rgba(30,41,59,.92))}.landing-template-immersive .hero-card{background:radial-gradient(circle at top right,rgba(245,158,11,.18),transparent 32%),linear-gradient(135deg,rgba(2,6,23,.92),rgba(30,41,59,.94))}.landing-surface-solid .landing-surface-card{background:#0f172a!important}.landing-surface-gradient .landing-surface-card{background:linear-gradient(135deg,rgba(37,99,235,.16),rgba(15,23,42,.92))!important}.landing-surface-glass .landing-surface-card{background:rgba(15,23,42,.82)!important}.landing-metrics .info-chip{border:1px solid rgba(255,255,255,.12)}.ar-launch-card .micro-actions{margin-top:8px}@media (max-width:980px){.campaign-link-card{grid-template-columns:1fr}.compact-stats{grid-template-columns:repeat(2,minmax(0,1fr))}}

.campaign-series-chart{padding:16px;border:1px dashed #dbeafe;border-radius:18px;background:linear-gradient(180deg,#f8fbff,#ffffff)}
.series-legend{display:flex;gap:18px;flex-wrap:wrap;color:#64748b;font-size:.88rem;margin-bottom:12px}.legend-dot{display:inline-block;width:10px;height:10px;border-radius:999px;margin-left:6px}.legend-dot.current{background:#2563eb}.legend-dot.previous{background:#94a3b8}.series-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(24px,1fr));align-items:end;gap:10px;min-height:150px}.series-col{display:grid;gap:8px;justify-items:center}.series-col small{color:#64748b;font-size:.74rem}.series-bars{display:flex;align-items:end;gap:5px;min-height:126px}.series-bar{display:block;width:10px;border-radius:999px 999px 4px 4px}.series-bar.current{background:linear-gradient(180deg,#60a5fa,#2563eb)}.series-bar.previous{background:linear-gradient(180deg,#cbd5e1,#94a3b8)}
.compare-stat-card{position:relative}.delta-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;font-size:.78rem;font-weight:700;margin-top:8px}.delta-up{background:rgba(16,185,129,.12);color:#047857}.delta-down{background:rgba(239,68,68,.12);color:#b91c1c}.delta-flat{background:rgba(148,163,184,.15);color:#475569}.campaign-qr-preview.compact{min-height:92px;max-width:92px;margin-inline:auto}
.landing-block-card.block-type-metric{background:linear-gradient(135deg,rgba(37,99,235,.16),rgba(15,23,42,.86));border-color:rgba(96,165,250,.28)}.landing-block-card.block-type-step{background:linear-gradient(135deg,rgba(16,185,129,.12),rgba(15,23,42,.88));border-color:rgba(52,211,153,.22)}.landing-block-card.block-type-quote{background:linear-gradient(135deg,rgba(245,158,11,.14),rgba(15,23,42,.88));border-color:rgba(251,191,36,.2)}.landing-block-metric{font-size:1.2rem;font-weight:700;color:#93c5fd}.landing-step-tag{display:inline-flex;padding:6px 10px;border-radius:999px;background:rgba(16,185,129,.14);color:#6ee7b7;font-size:.82rem;font-weight:700}.landing-quote-mark{font-size:2.1rem;line-height:1;color:#fde68a;opacity:.9}


.dashboard-main-grid{grid-template-columns:minmax(0,1.45fr) minmax(320px,.75fr);align-items:start}
.dashboard-chart-card .mini-chart{min-height:128px;padding:14px 8px 4px;border:1px dashed rgba(148,163,184,.24);border-radius:18px;background:linear-gradient(180deg,rgba(248,250,252,.9),rgba(255,255,255,1))}
.dashboard-chart-card .mini-chart.is-empty{background:linear-gradient(180deg,rgba(248,250,252,.8),rgba(248,250,252,.95))}
.chart-bar.is-zero{background:linear-gradient(180deg,#cbd5e1,#94a3b8);opacity:.6}
.dashboard-summary-strip{display:grid;gap:12px;margin-bottom:14px}
.dashboard-summary-strip .muted-item{background:rgba(15,23,42,.03)}
.dashboard-empty-state{margin-top:14px;padding:14px 16px;border-radius:16px;background:rgba(37,99,235,.06);border:1px solid rgba(37,99,235,.12)}
.dashboard-empty-state strong{display:block;margin-bottom:6px;color:#0f172a}
.soft-separator{margin:18px 0;border:none;border-top:1px solid rgba(148,163,184,.2)}
.compact-stack{gap:10px}
.compact-stack .quick-link{padding:12px 14px;border-radius:14px;background:rgba(15,23,42,.03);border:1px solid rgba(148,163,184,.14)}
.empty-inline{padding:14px 16px;border-radius:14px;background:rgba(15,23,42,.03);border:1px dashed rgba(148,163,184,.28);color:#64748b;text-align:center}
@media (max-width:980px){.dashboard-main-grid{grid-template-columns:1fr}}
.hotspot-layer-stack{display:grid;gap:14px}
.hotspot-layer-card{padding:16px;border-radius:18px;background:rgba(15,23,42,.04);border:1px solid rgba(148,163,184,.18)}
.hotspot-layer-card h3{margin:0 0 8px;font-size:1.05rem}
.hotspot-layer-card p{margin:0;color:#475569;line-height:1.8}
.hotspot-layer-card audio{width:100%;margin-top:10px}
.hotspot-layer-html{line-height:1.9}
.hotspot-hover-card{position:fixed;z-index:35;max-width:300px;padding:14px 16px;border-radius:18px;background:rgba(15,23,42,.92);color:#fff;backdrop-filter:blur(16px);box-shadow:0 18px 48px rgba(15,23,42,.3);pointer-events:auto}
.hotspot-hover-card.hidden{display:none!important}
.hotspot-hover-card__title{font-weight:700;margin-bottom:6px}
.hotspot-hover-card__body{font-size:.9rem;line-height:1.6;color:#cbd5e1}
.tour-overlay-anchor-spot,.tour-overlay-helper-spot{overflow:visible!important}.tour-overlay-anchor{transform:translate(-50%,-50%);pointer-events:auto}.tour-overlay-helper{width:8px;height:8px;border-radius:999px;background:transparent;pointer-events:none}.tour-embed{position:relative;display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:flex-start;padding:14px 16px;border-radius:20px;box-shadow:0 18px 54px rgba(15,23,42,.24);backdrop-filter:blur(16px);overflow:hidden;color:#fff;transform-origin:50% 50%;pointer-events:auto}.tour-embed.theme-glass{background:rgba(15,23,42,.68);border:1px solid rgba(255,255,255,.14)}.tour-embed.theme-note{background:rgba(255,248,196,.96);color:#1f2937;border:1px solid rgba(217,119,6,.18)}.tour-embed.theme-plain{background:#fff;color:#0f172a;border:1px solid rgba(148,163,184,.2)}.tour-embed.theme-dark{background:rgba(2,6,23,.92);border:1px solid rgba(255,255,255,.08)}.tour-embed.family-poi{box-shadow:0 18px 54px rgba(217,119,6,.22)}.tour-embed.family-embed{box-shadow:0 18px 54px rgba(109,40,217,.22)}.tour-embed.is-video .tour-embed__icon{background:rgba(239,68,68,.18)}.tour-embed.is-image .tour-embed__icon{background:rgba(59,130,246,.18)}.tour-embed__icon{width:40px;height:40px;border-radius:999px;background:rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;overflow:hidden}.tour-embed.theme-note .tour-embed__icon,.tour-embed.theme-plain .tour-embed__icon{background:rgba(15,23,42,.08)}.tour-embed__body{display:grid;gap:10px;min-width:0}.tour-embed__media{border-radius:14px;overflow:hidden;min-height:112px;background:rgba(255,255,255,.08)}.tour-embed__media img,.tour-embed__media video,.tour-embed__media iframe{display:block;width:100%;height:100%;object-fit:cover}.tour-embed__media.is-video .responsive-video{padding-top:56.25%}.tour-embed__media.is-video iframe{position:absolute;inset:0;width:100%;height:100%}.tour-embed__text{display:grid;gap:6px}.tour-embed__title{font-weight:800;line-height:1.4;font-size:1rem}.tour-embed__copy{font-size:.9rem;line-height:1.7;opacity:.94}.tour-embed__actions{display:flex;gap:10px;flex-wrap:wrap}.tour-embed__button{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:999px;border:none;background:var(--brand-primary,#2563eb);color:#fff;font-weight:700;text-decoration:none;cursor:pointer}.tour-embed.theme-note .tour-embed__button,.tour-embed.theme-plain .tour-embed__button{background:#0f172a}.tour-embed__html{line-height:1.8}.tour-embed__html *{max-width:100%}.custom-hotspot .hotspot-badge.family-marker.is-exit,.hotspot-badge.family-marker.is-exit{background:rgba(37,99,235,.88)}.custom-hotspot .hotspot-badge.family-poi,.hotspot-badge.family-poi{background:rgba(217,119,6,.88)}.custom-hotspot .hotspot-badge.family-embed,.hotspot-badge.family-embed{background:rgba(109,40,217,.88)}@media (max-width:980px){.tour-embed{max-width:min(84vw,360px);grid-template-columns:1fr}.tour-embed__icon{width:34px;height:34px}.tour-embed__media{min-height:92px}}
@media (max-width:980px){.hotspot-hover-card{left:12px!important;right:12px;top:auto!important;bottom:12px;max-width:none}}

/* === Phase 5: Mobile-first UX refinements === */
:root {
    --safe-top: env(safe-area-inset-top, 0px);
    --safe-right: env(safe-area-inset-right, 0px);
    --safe-bottom: env(safe-area-inset-bottom, 0px);
    --safe-left: env(safe-area-inset-left, 0px);
}
button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
    outline: 2px solid var(--brand-primary, #2563eb);
    outline-offset: 2px;
}
.mobile-only { display: none !important; }
.desktop-only { display: inherit; }
.tour-panel-backdrop,
.admin-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(2, 6, 23, 0.56);
    backdrop-filter: blur(6px);
    z-index: 26;
}
body.tour-panel-open,
body.admin-nav-open { overflow: hidden; }
.tour-sidebar-toggle,
.admin-nav-toggle {
    border: none;
    width: 48px;
    height: 48px;
    border-radius: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(15, 23, 42, 0.82);
    color: #fff;
    backdrop-filter: blur(16px);
    box-shadow: 0 14px 30px rgba(2, 6, 23, 0.24);
    cursor: pointer;
    font-size: 1.15rem;
}
.topbar-title-wrap { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; width: 100%; }
.topbar-copy { display: grid; gap: 8px; min-width: 0; }
.topbar-copy h2 { margin: 0; font-size: clamp(1.7rem, 2.8vw, 2.4rem); }
.topbar-copy p { margin: 0; max-width: 62ch; color: #475569; }
.topbar-tour-badge { width: fit-content; }
.btn i,
.icon-btn i,
.tour-mobile-action i,
.tour-sidebar-toggle i,
.admin-nav-toggle i { pointer-events: none; }
.tour-mobile-action {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
}
.tour-mobile-action .action-icon {
    font-size: 1rem;
    line-height: 1;
}
.tour-mobile-action .action-label {
    font-size: 0.75rem;
    line-height: 1.2;
}
.ar-capability-card {
    display: grid;
    gap: 10px;
    padding: 14px 16px;
    margin-top: 14px;
    border: 1px solid rgba(148,163,184,.2);
    border-radius: 18px;
    background: rgba(15,23,42,.05);
}
.ar-capability-card.is-dark {
    background: rgba(255,255,255,.04);
    border-color: rgba(255,255,255,.12);
}
.ar-capability-title {
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 700;
}
.ar-capability-title i {
    color: var(--brand-primary, #2563eb);
}
.ar-capability-meta,
.ar-capability-tips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.ar-capability-copy {
    margin: 0;
    line-height: 1.8;
    color: #475569;
}
.ar-capability-card.is-dark .ar-capability-copy {
    color: #cbd5e1;
}
.status-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 12px;
    border-radius: 999px;
    font-size: 0.82rem;
    font-weight: 700;
}
.status-badge i { font-size: 0.8rem; }
.status-badge.status-ready { background: rgba(37,99,235,.12); color: #1d4ed8; }
.status-badge.status-success { background: rgba(16,185,129,.12); color: #047857; }
.status-badge.status-warning { background: rgba(245,158,11,.14); color: #b45309; }
.status-badge.status-muted { background: rgba(148,163,184,.16); color: #475569; }
.ar-model-stage {
    width: 100%;
    min-height: 420px;
    background: #0f172a;
    border-radius: 18px;
    overflow: hidden;
}
.ar-model-stage model-viewer {
    width: 100%;
    height: 420px;
    display: block;
    background: #0f172a;
}
.ar-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 14px;
}
.ar-note-list {
    margin: 0;
    padding-inline-start: 18px;
    color: #64748b;
    line-height: 1.8;
}
.ar-capability-card.is-dark .ar-note-list {
    color: #cbd5e1;
}
.landing-inline-modal-copy {
    margin-top: 12px;
}
.tour-mobile-bar {
    position: fixed;
    right: max(12px, var(--safe-right));
    left: max(12px, var(--safe-left));
    bottom: calc(12px + var(--safe-bottom));
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 8px;
    padding: 10px;
    border-radius: 22px;
    background: rgba(15, 23, 42, 0.88);
    backdrop-filter: blur(18px);
    box-shadow: 0 20px 44px rgba(2, 6, 23, 0.28);
    z-index: 31;
}
.tour-mobile-action {
    min-height: 48px;
    border: none;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.08);
    color: #fff;
    font-weight: 600;
    font-size: 0.83rem;
    cursor: pointer;
}
.tour-mobile-action.is-active { background: rgba(37, 99, 235, 0.36); }
.floating-modal .modal-card {
    max-height: min(84vh, 860px);
    overflow: auto;
}
.toolbar .btn,
.micro-actions .btn,
.share-actions-wrap .btn,
.share-actions-wrap a.btn {
    min-height: 44px;
}
@media (max-width:980px) {
    .mobile-only { display: flex !important; }
    .desktop-only { display: none !important; }
    .dashboard {
        display: block;
        min-height: 100dvh;
    }
    .side-info {
        position: fixed;
        top: 0;
        bottom: 0;
        right: 0;
        width: min(88vw, 360px);
        min-height: 100dvh;
        transform: translateX(110%);
        transition: transform 0.22s ease;
        z-index: 61;
        padding: calc(16px + var(--safe-top)) 18px calc(24px + var(--safe-bottom));
        box-shadow: -20px 0 48px rgba(2, 6, 23, 0.24);
    }
    .side-info.is-open { transform: translateX(0); }
    .mobile-admin-toolbar { justify-content: flex-end; margin-bottom: 12px; }
    .main-form {
        padding: 18px 16px calc(32px + var(--safe-bottom));
        min-height: 100dvh;
    }
    .main-topbar {
        position: sticky;
        top: 0;
        z-index: 18;
        background: rgba(255, 255, 255, 0.92);
        backdrop-filter: blur(14px);
        padding: calc(4px + var(--safe-top)) 0 14px;
        margin: -18px -16px 20px;
        padding-inline: 16px;
        border-bottom: 1px solid rgba(226, 232, 240, 0.9);
    }
    .main-topbar p { margin-top: 4px; }
    .grid-fields,
    .content-grid,
    .dashboard-main-grid,
    .campaign-link-grid,
    .landing-block-grid,
    .permission-grid {
        grid-template-columns: 1fr !important;
    }
    .action-bar,
    .toolbar,
    .share-actions-wrap {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .field-span-2,
    .full-width { grid-column: 1 / -1; }
    .card { padding: 18px; border-radius: 18px; }
    .table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }

    .tour-shell {
        min-height: 100dvh;
        padding-bottom: calc(94px + var(--safe-bottom));
    }
    .tour-stage {
        min-height: 100dvh;
        overflow: hidden;
        padding: 0;
    }
    #panorama-viewer {
        position: fixed;
        inset: 0;
        height: 100dvh !important;
    }
    .tour-sidebar-toggle {
        position: fixed;
        top: calc(12px + var(--safe-top));
        right: calc(12px + var(--safe-right));
        z-index: 32;
    }
    .tour-sidebar,
    .floating-map,
    .floating-gallery,
    .floating-share {
        position: fixed;
        left: max(12px, var(--safe-left));
        right: max(12px, var(--safe-right));
        bottom: calc(84px + var(--safe-bottom));
        top: auto;
        width: auto;
        max-height: min(72dvh, 640px);
        margin: 0;
        border-radius: 24px;
        overflow: auto;
        -webkit-overflow-scrolling: touch;
        transform: translateY(calc(100% + 32px));
        opacity: 0;
        transition: transform 0.22s ease, opacity 0.22s ease;
        z-index: 30;
        background: rgba(15, 23, 42, 0.96);
    }
    .tour-sidebar.is-open,
    .floating-map.is-open,
    .floating-gallery.is-open,
    .floating-share.is-open {
        transform: translateY(0);
        opacity: 1;
    }
    .tour-sidebar .panel-head,
    .floating-map .panel-head,
    .floating-gallery .panel-head,
    .floating-share .panel-head,
    .floating-modal .panel-head {
        position: sticky;
        top: 0;
        z-index: 2;
        background: rgba(15, 23, 42, 0.98);
        padding-bottom: 10px;
        margin-bottom: 14px;
    }
    .tour-sidebar .toolbar {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .scene-strip {
        gap: 12px;
        padding-bottom: 6px;
        scroll-snap-type: x proximity;
    }
    .scene-thumb {
        min-width: 148px;
        scroll-snap-align: start;
    }
    .scene-thumb img { height: 88px; }
    .custom-hotspot .hotspot-badge,
    .hotspot-badge {
        width: 42px;
        height: 42px;
        font-size: 1.05rem;
    }
    .floating-modal {
        position: fixed;
        inset: 0;
        z-index: 34;
        padding: 16px 12px calc(12px + var(--safe-bottom));
        background: rgba(2, 6, 23, 0.56);
    }
    .floating-modal .modal-card {
        margin-top: auto;
        width: 100%;
        max-height: min(82dvh, 760px);
        border-radius: 24px;
        background: rgba(15, 23, 42, 0.98);
        color: #fff;
        padding: 18px;
        transform: translateY(110%);
        transition: transform 0.22s ease;
    }
    .floating-modal.is-open .modal-card { transform: translateY(0); }
    .gallery-grid { display: grid; gap: 12px; }
    .gallery-card img { height: 150px; }
    .share-actions-wrap { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .share-qr-box { padding: 12px; }
    .intro-overlay {
        padding: 16px;
        align-items: flex-end;
    }
    .intro-card {
        padding: 18px;
        border-radius: 24px;
        margin-bottom: calc(84px + var(--safe-bottom));
    }
    .intro-actions { justify-content: stretch; }
    .intro-actions .btn { width: 100%; }
}
@media (max-width:680px) {
    .tour-mobile-bar { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .action-bar,
    .toolbar,
    .share-actions-wrap { grid-template-columns: 1fr; }
    .main-topbar p { display: none; }
    .tour-sidebar,
    .floating-map,
    .floating-gallery,
    .floating-share { max-height: min(78dvh, 720px); }
}

.icon-btn {
    border: none;
    width: 40px;
    height: 40px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    background: rgba(255,255,255,.1);
    color: inherit;
}

/* === Phase 10: admin shell + context menu + card fixes === */
.content-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
    align-items: start;
    width: 100%;
}
.content-grid > * { min-width: 0; }
.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 14px;
}
.admin-stats .stat-card,
.stat-card {
    background: linear-gradient(180deg, rgba(248,250,252,.98), rgba(255,255,255,1));
    border: 1px solid rgba(148,163,184,.18);
    border-radius: 18px;
    padding: 18px;
    min-height: 92px;
    display: grid;
    align-content: start;
    gap: 8px;
}
.admin-stats .stat-card span,
.stat-card span {
    color: #64748b;
    font-size: .87rem;
    font-weight: 600;
}
.admin-stats .stat-card strong,
.stat-card strong {
    color: var(--brand-navy);
    font-size: 1.55rem;
    line-height: 1.2;
}
.section-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}
.section-head h3 { margin: 0; }
.stack-list {
    display: grid;
    gap: 12px;
}
.quick-link {
    display: block;
    padding: 14px 16px;
    border: 1px solid rgba(148,163,184,.16);
    border-radius: 16px;
    background: rgba(15,23,42,.03);
}
.dashboard {
    grid-template-columns: minmax(280px, 320px) minmax(0, 1fr);
    align-items: stretch;
}
.main-form {
    min-width: 0;
}
.main-topbar {
    position: sticky;
    top: 0;
    z-index: 14;
    padding: 8px 0 18px;
    background: linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(255,255,255,.92) 72%, rgba(255,255,255,0) 100%);
    backdrop-filter: blur(12px);
}
.side-info {
    max-height: 100vh;
}
.hotspot-context-menu {
    position: fixed;
    z-index: 80;
    width: min(280px, calc(100vw - 24px));
    padding: 10px;
    border-radius: 18px;
    background: rgba(15,23,42,.96);
    color: #fff;
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: 0 22px 48px rgba(2,6,23,.34);
    backdrop-filter: blur(18px);
}
.hotspot-context-menu.hidden { display: none !important; }
.hotspot-context-title {
    padding: 8px 10px 10px;
    font-size: .83rem;
    color: rgba(255,255,255,.72);
}
.hotspot-context-menu button {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    border: none;
    background: transparent;
    color: inherit;
    padding: 12px 14px;
    border-radius: 14px;
    cursor: pointer;
    font: inherit;
}
.hotspot-context-menu button:hover,
.hotspot-context-menu button:focus-visible {
    background: rgba(255,255,255,.08);
    outline: none;
}
.hotspot-context-menu button small {
    color: rgba(255,255,255,.62);
    font-size: .74rem;
}
.hotspot-context-menu button i {
    width: 20px;
    text-align: center;
}
.hotspot-context-menu .context-divider {
    height: 1px;
    margin: 8px 0;
    background: rgba(255,255,255,.08);
}
.hotspot-viewer-shell {
    position: relative;
}
@media (min-width: 1201px) {
    .main-form {
        padding: 28px min(3vw, 34px) 40px;
    }
    .side-info {
        position: sticky;
        top: 0;
        min-height: 100vh;
        padding: 28px 26px;
    }
}
@media (max-width: 1200px) {
    .content-grid,
    .stats-grid {
        grid-template-columns: 1fr !important;
    }
    .main-topbar {
        margin-bottom: 16px;
    }
    .hotspot-context-menu {
        left: 12px !important;
        right: 12px;
        width: auto;
        top: auto !important;
        bottom: calc(84px + var(--safe-bottom));
    }
}


/* === Phase 11: header / sidebar / map stability fixes === */
.main-topbar {
    border-bottom: 1px solid rgba(226,232,240,.72);
}
.side-info {
    border-left: 1px solid rgba(255,255,255,.06);
}
.side-info .brand-inline {
    align-items: center !important;
}
.sidebar-nav a {
    min-height: 52px;
}
.card,
.glass-card,
.floating-map,
.floating-gallery,
.floating-share,
.floating-modal .modal-card {
    overflow: hidden;
}
.scene-thumb img.is-broken,
.gallery-card img.is-broken {
    opacity: 0.22;
    filter: grayscale(1);
}
.map-canvas {
    display: grid;
    gap: 12px;
}
.map-canvas__stage {
    position: relative;
    min-height: 280px;
    border-radius: 18px;
    overflow: hidden;
    background: linear-gradient(180deg, rgba(15,23,42,.06), rgba(15,23,42,.02));
    border: 1px solid rgba(148,163,184,.16);
}
.map-canvas__stage img {
    width: 100%;
    display: block;
    object-fit: contain;
    max-height: min(58vh, 560px);
    margin: 0 auto;
    background: #fff;
}
.map-canvas__empty {
    position: absolute;
    inset: 0;
    display: grid;
    place-content: center;
    gap: 6px;
    padding: 20px;
    text-align: center;
    color: #cbd5e1;
    background: radial-gradient(circle at top, rgba(37,99,235,.14), rgba(15,23,42,.92));
}
.map-canvas__empty span {
    color: rgba(226,232,240,.82);
    font-size: .9rem;
}
.map-preview-admin {
    margin-top: 18px;
}
.map-editor {
    display: grid;
    gap: 10px;
}
.map-editor__hint,
.map-editor__coords {
    font-size: .9rem;
    color: #475569;
}
.map-editor__stage {
    position: relative;
    border-radius: 22px;
    overflow: hidden;
    border: 1px solid rgba(148,163,184,.18);
    background:
      linear-gradient(45deg, rgba(226,232,240,.55) 25%, transparent 25%, transparent 75%, rgba(226,232,240,.55) 75%),
      linear-gradient(45deg, rgba(226,232,240,.55) 25%, transparent 25%, transparent 75%, rgba(226,232,240,.55) 75%);
    background-position: 0 0, 14px 14px;
    background-size: 28px 28px;
}
.map-editor__stage img {
    width: 100%;
    display: block;
    object-fit: contain;
    max-height: min(52vh, 520px);
    background: rgba(255,255,255,.92);
}
.map-editor__marker,
.map-editor__point {
    position: absolute;
    transform: translate(-50%, -50%);
}
.map-editor__marker {
    width: 18px;
    height: 18px;
    border-radius: 999px;
    border: 3px solid #fff;
    background: #2563eb;
    box-shadow: 0 0 0 6px rgba(37,99,235,.2);
    pointer-events: none;
}
.map-editor__point {
    border: none;
    min-width: 28px;
    max-width: 132px;
    min-height: 28px;
    border-radius: 999px;
    padding: 6px 10px;
    font-size: .76rem;
    font-weight: 700;
    cursor: pointer;
    color: #111827;
    background: rgba(245,158,11,.92);
    box-shadow: 0 12px 28px rgba(15,23,42,.2);
}
@media (max-width: 1200px) {
    .main-topbar {
        margin-bottom: 18px;
    }
    .side-info {
        width: min(90vw, 360px);
    }
}
@media (max-width: 680px) {
    .topbar-copy h2 { font-size: 1.85rem; }
    .map-editor__point { max-width: 92px; padding: 5px 8px; }
}

/* ===== Admin layout fix ===== */
.dashboard {
    display: grid;
    grid-template-columns: 320px minmax(0, 1fr);
    min-height: 100vh;
    background: #f8fafc;
}

.side-info {
    position: sticky;
    top: 0;
    height: 100vh;
    background: #041c43;
    color: #fff;
    overflow: hidden;
    border-left: 1px solid rgba(255,255,255,0.08);
}

.side-shell {
    height: 100%;
    display: flex;
    flex-direction: column;
}

.side-body {
    flex: 1;
    overflow-y: auto;
    padding: 24px 20px 18px;
}

.side-footer {
    padding: 14px 20px;
    border-top: 1px solid rgba(255,255,255,0.08);
    color: rgba(255,255,255,0.72);
    font-size: 13px;
}

.brand-inline-admin {
    align-items: center !important;
    gap: 14px;
    margin-bottom: 18px;
}

.admin-profile-card {
    margin-bottom: 18px;
}

.sidebar-nav {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 8px;
}

.sidebar-nav li {
    margin: 0;
}

.sidebar-nav a {
    display: block;
    padding: 12px 14px;
    border-radius: 12px;
    color: rgba(255,255,255,0.88);
    text-decoration: none;
    transition: background .25s ease, color .25s ease, transform .25s ease;
}

.sidebar-nav a:hover {
    background: rgba(255,255,255,0.08);
    color: #fff;
    transform: translateX(-2px);
}

.sidebar-nav a.active {
    background: rgba(255,255,255,0.14);
    color: #fff;
    font-weight: 700;
}

.main-form {
    min-width: 0;
    padding: 28px;
}

.main-topbar {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: 24px;
    padding: 0;
    background: transparent;
    border: none;
    box-shadow: none;
}

.topbar-title-wrap {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    min-width: 0;
}

.topbar-copy {
    min-width: 0;
}

.topbar-copy h2 {
    margin: 0 0 8px;
    font-size: 2rem;
    line-height: 1.2;
    color: #0f172a;
}

.topbar-copy p {
    margin: 0;
    color: #475569;
    line-height: 1.8;
}

.topbar-tour-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 12px;
}

.mobile-admin-toolbar {
    display: none;
}

.admin-nav-toggle {
    width: 44px;
    height: 44px;
    border: 1px solid rgba(15,23,42,0.12);
    border-radius: 12px;
    background: #fff;
    color: #0f172a;
    flex: 0 0 auto;
}

.admin-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(2,6,23,0.45);
    z-index: 80;
}

.admin-backdrop.hidden {
    display: none;
}

@media (max-width: 1024px) {
    .dashboard {
        grid-template-columns: 1fr;
    }

    .side-info {
        position: fixed;
        top: 0;
        right: 0;
        width: min(320px, 88vw);
        transform: translateX(100%);
        transition: transform .3s ease;
        z-index: 100;
    }

    .side-info.is-open {
        transform: translateX(0);
    }

    .mobile-admin-toolbar {
        display: flex;
        justify-content: flex-start;
        padding: 16px 16px 0;
    }

    .main-form {
        padding: 20px 16px 24px;
    }

    .main-topbar {
        margin-bottom: 18px;
    }

    .topbar-copy h2 {
        font-size: 1.6rem;
    }
}
