/* ── Demo Lab — Partner Demo Environment ──────────────────── */

/* Access Gate */
.demo-gate{position:fixed;inset:0;z-index:500;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:22px}
.demo-gate-box{width:100%;max-width:400px;text-align:center}
.demo-gate-logo{margin-bottom:28px}
.demo-gate-logo b{font-size:18px;letter-spacing:.06em;color:#fff;display:block}
.demo-gate-logo span{font-size:11px;color:var(--muted);letter-spacing:.04em}
.demo-gate-box h1{font-size:24px;margin:0 0 8px;color:#fff}
.demo-gate-box .lede{font-size:14px;color:var(--muted);margin:0 0 28px;line-height:1.5}
.demo-gate-form{display:flex;flex-direction:column;gap:12px}
.demo-gate-input{width:100%;border-radius:12px;padding:14px 16px;background:rgba(181,183,185,.06);border:1px solid rgba(181,183,185,.14);color:var(--text);outline:none;font-size:15px;text-align:center;letter-spacing:.08em;transition:border-color .2s}
.demo-gate-input:focus{border-color:rgba(140,106,62,.55)}
.demo-gate-input::placeholder{letter-spacing:.02em;color:var(--muted)}
.demo-gate-submit{display:inline-flex;align-items:center;justify-content:center;width:100%;border-radius:999px;padding:14px 16px;font-weight:650;font-size:14px;border:1px solid rgba(140,106,62,.65);background:var(--bronze);color:var(--ink);cursor:pointer;transition:transform .15s,box-shadow .15s}
.demo-gate-submit:hover{transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.2)}
.demo-gate-error{color:#e87c7c;font-size:13px;min-height:20px;margin-top:4px}
.demo-gate-note{font-size:11px;color:var(--muted);margin-top:18px;line-height:1.5}

/* Lab Hub — tile grid */
.demo-hub-header{padding:42px 0 32px;border-bottom:1px solid rgba(140,106,62,.18)}
.demo-hub-header h1{font-size:32px;margin:0 0 10px;color:#fff}
.demo-hub-header .lede{font-size:15px;color:var(--muted);margin:0;max-width:60ch;line-height:1.6}
.demo-mission-note{margin:10px 0 0;font-size:12px;color:rgba(181,183,185,.78);line-height:1.55;max-width:68ch}
.demo-mission-note a{color:rgba(140,106,62,.9);text-decoration:none;border-bottom:1px solid rgba(140,106,62,.4)}
.demo-mission-note a:hover{color:var(--bronze);border-bottom-color:rgba(140,106,62,.75)}
.demo-hub-kicker{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:var(--bronze);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}
.demo-hub-kicker svg{width:16px;height:16px;opacity:.7}
.demo-tile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.demo-tile{background:linear-gradient(180deg,rgba(46,49,54,.96),rgba(46,49,54,.82));border:1px solid rgba(181,183,185,.10);border-radius:var(--r);padding:28px 24px;cursor:pointer;transition:border-color .2s,transform .15s;text-decoration:none;display:flex;flex-direction:column}
.demo-tile:hover{border-color:rgba(140,106,62,.45);transform:translateY(-2px);color:inherit}
.demo-tile-icon{width:48px;height:48px;border-radius:14px;background:rgba(140,106,62,.12);border:1px solid rgba(140,106,62,.25);display:flex;align-items:center;justify-content:center;margin-bottom:18px;color:var(--bronze)}
.demo-tile-icon svg{width:24px;height:24px}
.demo-tile h3{margin:0 0 8px;font-size:17px;color:#fff;font-weight:700}
.demo-tile p{margin:0 0 14px;font-size:13px;color:var(--muted);line-height:1.55}
.demo-tile-tag{display:inline-block;font-size:11px;font-weight:600;letter-spacing:.04em;padding:4px 10px;border-radius:999px;border:1px solid rgba(140,106,62,.3);color:var(--bronze);background:rgba(140,106,62,.08)}
.demo-tile-status{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted);margin-top:12px}
.demo-tile-status .dot{width:6px;height:6px;border-radius:50%;background:var(--bronze);flex-shrink:0}
.demo-tile-status .dot.live{background:#4ade80}
.demo-tile-status .dot.draft{background:rgba(181,183,185,.4)}

/* Category sections */
.demo-category-section{padding:32px 0 0}
.demo-category-section:last-of-type{padding-bottom:24px}
.demo-category-header{display:flex;align-items:center;gap:14px;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid rgba(140,106,62,.12)}
.demo-category-icon{width:36px;height:36px;border-radius:10px;background:rgba(140,106,62,.08);border:1px solid rgba(140,106,62,.18);display:flex;align-items:center;justify-content:center;color:var(--bronze);flex-shrink:0}
.demo-category-icon svg{width:18px;height:18px}
.demo-category-title{font-size:18px;font-weight:700;color:#fff;margin:0 0 2px}
.demo-category-count{font-size:11px;color:var(--muted);letter-spacing:.03em}

/* Partner label */
.demo-tile-partner{font-size:11px;font-weight:600;color:var(--bronze);letter-spacing:.03em;margin:-4px 0 8px;opacity:.8}

/* Coming Soon badge */
.demo-coming-soon-badge{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:3px 10px;border-radius:999px;border:1px solid rgba(251,191,36,.3);color:#fbbf24;background:rgba(251,191,36,.08);margin-bottom:10px}

/* Disabled tile */
.demo-tile-disabled{opacity:.55}
.demo-tile-disabled:hover{border-color:rgba(181,183,185,.10);transform:none}

/* Hub stats */
.demo-hub-stats{display:flex;align-items:center;gap:16px;margin-top:20px}
.demo-stat{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:6px}
.demo-stat-num{font-weight:700;color:var(--bronze);font-size:15px}
.demo-stat-sep{width:1px;height:16px;background:rgba(140,106,62,.2)}

/* Start Your Demo */
.demo-start-section{padding:24px 0 0}
.demo-start-card{padding:22px;background:linear-gradient(180deg,rgba(46,49,54,.96),rgba(46,49,54,.84));border:1px solid rgba(181,183,185,.10);border-radius:var(--r)}
.demo-start-card h2{margin:0 0 8px;font-size:22px;color:#fff}
.demo-start-card p{margin:0 0 18px;font-size:14px;color:var(--muted);line-height:1.6;max-width:68ch}
.demo-start-grid{display:grid;grid-template-columns:1fr;gap:12px}
.demo-start-option{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:14px 15px;border-radius:10px;border:1px solid rgba(140,106,62,.24);background:rgba(140,106,62,.08);text-decoration:none;color:#fff;transition:border-color .2s,transform .15s,background .2s}
.demo-start-option:hover{border-color:rgba(140,106,62,.42);background:rgba(140,106,62,.13);transform:translateY(-1px)}
.demo-start-option-copy{display:flex;flex-direction:column;gap:4px;min-width:0}
.demo-start-option-title{font-size:13px;font-weight:650;line-height:1.35;color:#fff}
.demo-start-option-desc{font-size:12px;font-weight:500;line-height:1.5;color:var(--muted)}
.demo-start-option svg{width:14px;height:14px;color:var(--bronze);flex-shrink:0;margin-top:3px}

/* Credibility section */
.demo-credibility-section{padding-top:10px;padding-bottom:0}
.demo-credibility-section p{margin:0;padding:12px 16px;border-left:2px solid rgba(140,106,62,.36);background:rgba(181,183,185,.04);font-size:12px;line-height:1.65;color:rgba(181,183,185,.9)}

/* Demo page back-link */
.demo-back{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);font-weight:500;padding:14px 0;transition:color .15s;text-decoration:none}
.demo-back:hover{color:var(--bronze)}
.demo-back svg{width:16px;height:16px}

/* Demo context header */
.tf-demo-context{padding:20px 0 0}
.tf-demo-context-role{margin:0 0 8px;padding:12px 16px;border-radius:12px;background:rgba(140,106,62,.10);border:1px solid rgba(140,106,62,.22);font-size:13px;font-weight:650;color:var(--ash);line-height:1.55}
.tf-demo-context-summary{margin:0;padding:0 2px;font-size:13px;color:var(--muted);line-height:1.6;max-width:78ch}
.tf-demo-context-lookfor{margin-top:12px;padding:14px 16px;border-radius:12px;background:rgba(46,49,54,.78);border:1px solid rgba(181,183,185,.14)}
.tf-demo-context-lookfor h2{margin:0 0 8px;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--bronze)}
.tf-demo-context-lookfor ul{margin:0;padding-left:18px;display:grid;gap:6px}
.tf-demo-context-lookfor li{font-size:12px;color:var(--ash);line-height:1.55}

/* Guided flow steps */
.tf-demo-guided{margin-top:10px;padding:14px 16px;border-radius:12px;background:rgba(46,49,54,.58);border:1px solid rgba(181,183,185,.10)}
.tf-demo-guided h2{margin:0 0 8px;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--bronze)}
.tf-demo-guided ol{margin:0;padding-left:20px;display:grid;gap:6px;list-style:decimal}
.tf-demo-guided li{font-size:12px;color:var(--ash);line-height:1.55}

/* Demo footer */
.demo-lab-disclaimer{padding:20px 0 8px}
.demo-lab-disclaimer p{margin:0;text-align:center;font-size:11px;line-height:1.6;color:rgba(181,183,185,.72)}
.demo-lab-footer{padding:28px 0;border-top:1px solid rgba(140,106,62,.12);text-align:center;font-size:12px;color:var(--muted)}
.demo-lab-footer a{color:var(--bronze)}

/* CTA button hover */
.demo-cta-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(140,106,62,.35)}

/* ── Responsive ─────────────────────────────── */
@media(max-width:900px){
  .demo-tile-grid{grid-template-columns:repeat(2,1fr)}
  .demo-hub-header h1{font-size:26px}
  .demo-hub-stats{flex-wrap:wrap;gap:12px}
}
@media(max-width:520px){
  .demo-tile-grid{grid-template-columns:1fr}
  .demo-hub-header{padding:28px 0 22px}
  .demo-gate-box{padding:0 8px}
  .demo-hub-stats{gap:10px}
  .tf-demo-context{padding-top:16px}
  .tf-demo-context-role{font-size:12px;padding:10px 12px}
  .tf-demo-context-lookfor{padding:12px}
  .tf-demo-context-lookfor ul{gap:5px}
  .tf-demo-context-lookfor li{font-size:11px}
  .tf-demo-guided{padding:12px;margin-top:8px}
  .tf-demo-guided ol{gap:5px}
  .tf-demo-guided li{font-size:11px}
  .demo-start-option{padding:13px 14px}
  .demo-start-option-desc{font-size:11px}
}
@media(min-width:700px){
  .demo-start-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}


/* Live project activity block */
.tf-recent-activity{padding-top:0}
.tf-recent-activity-head{display:flex;align-items:flex-end;justify-content:space-between;gap:10px;margin-bottom:12px}
.tf-recent-activity-head h2{margin:0;font-size:18px;color:#fff}
.tf-recent-activity-head p{margin:0;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.tf-recent-activity-list{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.tf-recent-activity-item{display:flex;gap:10px;align-items:flex-start;padding:12px 14px;border-radius:12px;border:1px solid rgba(181,183,185,.12);background:linear-gradient(180deg,rgba(46,49,54,.9),rgba(40,42,46,.78))}
.tf-recent-activity-label{display:inline-flex;align-items:center;justify-content:center;min-width:78px;padding:4px 8px;border-radius:999px;border:1px solid rgba(181,183,185,.2);font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ash);background:rgba(181,183,185,.08)}
.tf-recent-activity-label.update{border-color:rgba(96,165,250,.32);background:rgba(96,165,250,.1);color:#60a5fa}
.tf-recent-activity-label.delivery{border-color:rgba(74,222,128,.32);background:rgba(74,222,128,.1);color:#4ade80}
.tf-recent-activity-label.issue{border-color:rgba(248,113,113,.32);background:rgba(248,113,113,.1);color:#f87171}
.tf-recent-activity-label.coordination{border-color:rgba(140,106,62,.38);background:rgba(140,106,62,.12);color:var(--bronze)}
.tf-recent-activity-body{min-width:0;flex:1}
.tf-recent-activity-body p{margin:0;font-size:13px;color:var(--ash);line-height:1.5}
.tf-recent-activity-body time{display:block;margin-top:4px;font-size:11px;color:var(--muted)}
@media(max-width:520px){
  .tf-recent-activity-item{padding:11px 12px;gap:8px}
  .tf-recent-activity-label{min-width:70px;font-size:9px;padding:3px 7px}
  .tf-recent-activity-body p{font-size:12px}
}

/* Share This Demo */
.share-demo{margin:0;padding:28px 0;border-top:1px solid rgba(140,106,62,.12);text-align:center}
.share-demo-inner{max-width:420px;margin:0 auto}
.share-demo-inner h3{font-size:14px;color:#fff;font-weight:700;margin:0 0 6px;display:flex;align-items:center;justify-content:center;gap:8px}
.share-demo-inner h3 svg{width:16px;height:16px;color:var(--bronze)}
.share-demo-inner p{font-size:12px;color:var(--muted);margin:0 0 14px;line-height:1.5}
.share-demo-url{display:flex;gap:8px;align-items:center}
.share-demo-url input{flex:1;padding:9px 12px;border-radius:8px;background:rgba(181,183,185,.06);border:1px solid rgba(181,183,185,.14);color:var(--ash);font-size:12px;font-family:inherit;outline:none;min-width:0;transition:border-color .2s}
.share-demo-url input:focus{border-color:rgba(140,106,62,.55)}
.share-demo-url button{display:inline-flex;align-items:center;gap:5px;padding:9px 14px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;border:1px solid rgba(140,106,62,.4);background:rgba(140,106,62,.12);color:var(--bronze);white-space:nowrap;transition:background .15s,transform .15s}
.share-demo-url button:hover{background:rgba(140,106,62,.22);transform:translateY(-1px)}
.share-demo-url button svg{width:14px;height:14px}
.share-demo-url button.copied{border-color:rgba(74,222,128,.4);background:rgba(74,222,128,.12);color:#4ade80}
@media(max-width:520px){.share-demo-url{flex-direction:column}.share-demo-url button{width:100%;justify-content:center}}

/* Platform contribution indicator */
.tf-platform-contribution{display:flex;align-items:center;gap:8px;margin-top:14px;padding:10px 14px;border-radius:8px;border:1px solid rgba(140,106,62,.12);background:rgba(140,106,62,.04);font-size:11px;color:var(--muted);line-height:1.5;text-align:left}
.tf-platform-contribution svg{width:14px;height:14px;color:var(--bronze);flex-shrink:0;opacity:.7}
.tf-platform-contribution strong{color:var(--ash);font-weight:600}

.demo-structure-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.demo-structure-card{padding:18px;background:linear-gradient(180deg,rgba(46,49,54,.95),rgba(40,42,46,.86));border:1px solid rgba(181,183,185,.12);border-radius:12px}
.demo-structure-card h3{margin:0 0 8px;font-size:15px;color:#fff}
.demo-structure-card p{margin:0 0 12px;font-size:12px;line-height:1.55;color:var(--muted)}
.demo-admin-reference{padding:18px;background:linear-gradient(180deg,rgba(46,49,54,.95),rgba(40,42,46,.86));border:1px solid rgba(140,106,62,.24);border-radius:12px}
.demo-admin-header h2{margin:0 0 6px;font-size:18px;color:#fff}
.demo-admin-header p{margin:0 0 12px;font-size:12px;color:var(--muted)}
.demo-admin-table-wrap{overflow-x:auto}
.demo-admin-table{width:100%;border-collapse:collapse;min-width:920px}
.demo-admin-table th,.demo-admin-table td{padding:10px 12px;border-bottom:1px solid rgba(181,183,185,.12);font-size:12px;text-align:left;vertical-align:top}
.demo-admin-table th{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}
.demo-admin-table td{color:var(--ash)}
.demo-admin-table td a{color:var(--bronze);text-decoration:none}

@media(max-width:900px){
  .demo-structure-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:520px){
  .demo-structure-grid{grid-template-columns:1fr}
}

/* Controlled demo access experience */
.demo-access-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.demo-access-card{padding:22px;background:linear-gradient(180deg,rgba(46,49,54,.95),rgba(40,42,46,.84));border:1px solid rgba(181,183,185,.12);border-radius:12px;display:flex;flex-direction:column;gap:12px}
.demo-access-card h2{margin:0;font-size:18px;color:#fff;line-height:1.3}
.demo-access-card p{margin:0;font-size:13px;line-height:1.6;color:var(--muted)}
.demo-auth-form{display:flex;flex-direction:column;gap:10px}
.demo-auth-label{font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);font-weight:700}
.demo-auth-form .demo-gate-input{text-align:left;padding:12px 14px;border-radius:10px;font-size:13px}
.demo-auth-form .demo-gate-submit{padding:11px 14px;font-size:12px}
.demo-auth-form .demo-gate-error{margin:0;min-height:16px;font-size:12px;line-height:1.4}

.demo-qualification-block{padding:24px;background:linear-gradient(135deg,rgba(140,106,62,.1),rgba(140,106,62,.03));border:1px solid rgba(140,106,62,.26);border-radius:14px}
.demo-qualification-block h2{margin:0 0 10px;font-size:20px;color:#fff;line-height:1.3}
.demo-qualification-block p{margin:0 0 12px;font-size:14px;line-height:1.65;color:rgba(181,183,185,.9);max-width:72ch}
.demo-qualification-block ul{margin:0;padding-left:18px;display:grid;gap:6px}
.demo-qualification-block li{font-size:13px;line-height:1.55;color:var(--ash)}
.demo-qualification-actions{margin-top:16px;display:flex;gap:10px;flex-wrap:wrap}

@media(max-width:900px){
  .demo-access-grid{grid-template-columns:1fr}
}

@media(max-width:520px){
  .demo-access-card{padding:18px}
  .demo-qualification-block{padding:18px}
  .demo-qualification-block h2{font-size:18px}
  .demo-qualification-block p,.demo-qualification-block li{font-size:12px}
}

/* Guided demo flow and role entry points */
.demo-flow-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.demo-flow-card{padding:16px;background:linear-gradient(180deg,rgba(46,49,54,.95),rgba(40,42,46,.86));border:1px solid rgba(181,183,185,.12);border-radius:12px}
.demo-flow-step{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;font-size:11px;font-weight:700;color:var(--ink);background:var(--bronze);margin-bottom:8px}
.demo-flow-card h3{margin:0 0 6px;font-size:15px;color:#fff}
.demo-flow-card p{margin:0;font-size:12px;color:var(--muted);line-height:1.55}
.demo-role-entry-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.demo-role-entry-card{padding:18px;background:linear-gradient(180deg,rgba(46,49,54,.95),rgba(40,42,46,.84));border:1px solid rgba(181,183,185,.12);border-radius:12px;display:flex;flex-direction:column;gap:10px}
.demo-role-entry-card h3{margin:0;font-size:16px;color:#fff}
.demo-role-entry-card p{margin:0;font-size:12px;color:var(--muted);line-height:1.6}
.demo-role-entry-links{display:grid;gap:8px;margin-top:auto}
.demo-role-entry-link{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 10px;border-radius:8px;border:1px solid rgba(140,106,62,.22);background:rgba(140,106,62,.08);font-size:12px;color:var(--ash);text-decoration:none;transition:border-color .15s,background .15s}
.demo-role-entry-link:hover{border-color:rgba(140,106,62,.45);background:rgba(140,106,62,.14)}
.demo-role-entry-link svg{width:14px;height:14px;color:var(--bronze);flex-shrink:0}

/* Role switch navigation shown in demos */
.tf-demo-role-nav{padding:14px 0 0}
.tf-demo-role-nav-wrap{display:flex;flex-wrap:wrap;gap:8px;padding:10px;border:1px solid rgba(140,106,62,.2);border-radius:12px;background:rgba(46,49,54,.58)}
.tf-demo-role-nav-label{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--bronze);border:1px solid rgba(140,106,62,.3);background:rgba(140,106,62,.08)}
.tf-demo-role-nav-link{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border-radius:8px;border:1px solid rgba(181,183,185,.15);background:rgba(28,30,33,.45);font-size:12px;color:var(--muted);text-decoration:none;transition:border-color .15s,color .15s,background .15s}
.tf-demo-role-nav-link:hover{border-color:rgba(140,106,62,.35);color:var(--ash)}
.tf-demo-role-nav-link.active{border-color:rgba(140,106,62,.45);background:rgba(140,106,62,.12);color:var(--bronze)}
.tf-demo-role-nav-link svg{width:13px;height:13px;flex-shrink:0}

@media(max-width:900px){
  .demo-flow-grid,.demo-role-entry-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:520px){
  .demo-flow-grid,.demo-role-entry-grid{grid-template-columns:1fr}
}
