/* GCC Command Centre — Member Dashboard Styles
 * Extracted from index.html for clean separation
 * Depends on CSS variables defined in main index.html <style> block
 * Load AFTER index.html base styles
 */

   GCC COMMAND CENTRE — MEMBER WORKSPACE
   Replaces the old getting-started checklist dashboard.
   Fonts: Cormorant Garamond (display) + Lexend (body) +
          Fira Code (mono) — all already loaded above.
═══════════════════════════════════════════════════════ */
:root{
  --cc-forest:#0a1208;
  --cc-card:#101e0d;
  --cc-border:rgba(142,255,66,.1);
  --cc-border-h:rgba(142,255,66,.28);
  --cc-gold:#f0c030;
  --cc-gold-dim:rgba(240,192,48,.18);
  --cc-emerald:#45a85a;
  --cc-emerald-glow:rgba(69,168,90,.18);
  --cc-amber:#d97706;
  --cc-amber-dim:rgba(217,119,6,.14);
  --cc-red:#dc2626;
  --cc-red-dim:rgba(220,38,38,.1);
}

/* ── STATUS BAR ── */
#cc-status-bar{
  display:none;
  background:linear-gradient(135deg,#101e0d,#0d1a0b);
  border:1px solid var(--cc-border);
  border-radius:10px;padding:12px 16px;
  margin-bottom:14px;
  align-items:center;gap:12px;flex-wrap:wrap;
}
#cc-status-bar.cc-active{display:flex}
.cc-avatar{
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,var(--cc-emerald),var(--cc-gold-dim));
  border:2px solid rgba(142,255,66,.25);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--fd);font-size:14px;font-weight:700;
  color:var(--ink);flex-shrink:0
}
.cc-name-block{flex:1;min-width:120px}
.cc-member-name{font-size:13px;font-weight:600;color:var(--t0);line-height:1.2}
.cc-tier-row{display:flex;align-items:center;gap:6px;margin-top:3px;flex-wrap:wrap}
.cc-tier-badge{
  font-family:var(--fm);font-size:9px;letter-spacing:.08em;text-transform:uppercase;
  padding:2px 8px;border-radius:20px;border:1px solid;
}
.cc-tier-badge.free{color:var(--t2);border-color:rgba(106,136,114,.3);background:rgba(106,136,114,.1)}
.cc-tier-badge.associate{color:var(--glow);border-color:rgba(142,255,66,.3);background:rgba(142,255,66,.08)}
.cc-tier-badge.professional{color:#4ec9c0;border-color:rgba(78,201,192,.3);background:rgba(78,201,192,.08)}
.cc-tier-badge.ecopreneur{color:var(--cc-gold);border-color:var(--cc-gold-dim);background:rgba(240,192,48,.07)}
.cc-tier-badge.green-team{color:#93c5fd;border-color:rgba(147,197,253,.3);background:rgba(147,197,253,.08)}
.cc-founding-badge{
  font-family:var(--fm);font-size:8px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--cc-gold);background:rgba(240,192,48,.1);
  border:1px solid var(--cc-gold-dim);padding:2px 7px;border-radius:20px;
}
.cc-credits-block{min-width:130px}
.cc-credits-label-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.cc-credits-label{font-family:var(--fm);font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:var(--t2)}
.cc-credits-count{font-family:var(--fm);font-size:11px;color:var(--t1)}
.cc-credits-count.warn{color:var(--cc-amber)}
.cc-credits-bar{height:4px;background:rgba(142,255,66,.1);border-radius:2px;overflow:hidden}
.cc-credits-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--cc-emerald),var(--glow));transition:width .8s ease}
.cc-credits-fill.warn{background:linear-gradient(90deg,var(--cc-amber),#fbbf24)}
.cc-status-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.cc-topup-btn{
  padding:5px 12px;background:linear-gradient(135deg,var(--cc-amber),#f59e0b);
  color:var(--ink);border:none;border-radius:5px;font-family:var(--fb);
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;
  cursor:pointer;transition:all .2s;animation:cc-pulse-amber 2s infinite;
}
.cc-topup-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(217,119,6,.35)}
@keyframes cc-pulse-amber{0%,100%{box-shadow:0 0 0 0 rgba(217,119,6,0)}50%{box-shadow:0 0 0 4px rgba(217,119,6,.15)}}
.cc-upgrade-hint{font-size:11px;color:var(--t2);cursor:pointer;transition:color .18s;white-space:nowrap}
.cc-upgrade-hint:hover{color:var(--cc-gold)}
.cc-upgrade-hint strong{color:var(--cc-gold);font-weight:600}

/* ── MOBILE BOTTOM NAV (member mode) ── */
#cc-mobile-nav{
  display:none;
  position:fixed;
  bottom:0;left:0;right:0;
  z-index:9500;
  background:rgba(15,28,13,.99);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-top:2px solid rgba(142,255,66,.35);
  height:calc(58px + env(safe-area-inset-bottom, 0px));
  padding-bottom:env(safe-area-inset-bottom, 0px);
  /* Scrollable for 8+ tabs */
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  box-shadow:0 -2px 20px rgba(142,255,66,.12);
}
#cc-mobile-nav::-webkit-scrollbar{display:none}
#cc-mobile-nav.cc-active{display:flex}
/* Hide on desktop — inline style on mobile wins over this */
@media(min-width:768px){#cc-mobile-nav{display:none!important}}
.cc-bn{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;cursor:pointer;border:none;background:none;
  color:rgba(142,255,66,.5);transition:all .18s;padding:8px 2px;
  border-top:2px solid transparent;
  -webkit-tap-highlight-color:transparent;
}
.cc-bn.on{color:var(--glow);border-top-color:var(--glow)}
.cc-bn-i{font-size:20px;line-height:1}
.cc-bn-l{font-family:var(--fm);font-size:8px;letter-spacing:.6px;text-transform:uppercase;font-weight:600}

/* ── GRID LAYOUT ── */
#cc-grid{
  display:none;
  gap:0;
}
#cc-grid.cc-active{display:block}
/* Single panel mode on all screen sizes — tabs control visibility */
@media(min-width:768px){
  #cc-grid.cc-active{
    display:block;
    min-height:calc(100vh - 220px);
  }
}
/* Mobile: ensure content scrolls past fixed bottom nav */
@media(max-width:767px){
  #cc-grid.cc-active{
    padding-bottom:calc(72px + env(safe-area-inset-bottom, 20px));
  }
}

/* ── PANELS ── */
.cc-panel{
  border-right:none;
  display:none;
}
.cc-panel:last-child{border-right:none}
/* Panels shown/hidden via element.style.display in JS — no CSS class needed */
@media(min-width:768px){
  /* Desktop: single panel, full width — tabs control what's visible */
  #cc-grid.cc-active{display:block}
}
.cc-panel-header{
  position:sticky;top:64px;z-index:10;
  background:rgba(13,26,11,.96);backdrop-filter:blur(8px);
  padding:12px 14px 10px;border-bottom:1px solid var(--cc-border);
  display:flex;align-items:center;justify-content:space-between;
}
/* On mobile the top nav is still 64px, so sticky top is correct */
.cc-panel-title{
  font-family:var(--fd);font-size:14px;font-weight:700;
  color:var(--t0);display:flex;align-items:center;gap:7px;
}
.cc-panel-sub{font-size:11px;color:var(--t2);margin-top:1px}
.cc-panel-body{padding:14px}

/* ── CARDS ── */
.cc-card{
  background:var(--cc-card);border:1px solid var(--cc-border);
  border-radius:10px;padding:13px;margin-bottom:10px;
  transition:border-color .2s,background .2s;position:relative;overflow:hidden;
}
.cc-card:hover{border-color:var(--cc-border-h)}
.cc-card::before{
  content:'';position:absolute;top:0;left:0;width:3px;height:100%;
  background:var(--cc-emerald);opacity:0;transition:opacity .2s;border-radius:10px 0 0 10px;
}
.cc-card:hover::before{opacity:1}
.cc-card-gold{border-color:var(--cc-gold-dim);background:linear-gradient(135deg,var(--cc-card),rgba(240,192,48,.03))}
.cc-card-gold::before{background:var(--cc-gold)}
.cc-card-gold:hover{border-color:rgba(240,192,48,.35)}
.cc-card-alert{border-color:rgba(217,119,6,.4)!important;background:linear-gradient(135deg,var(--cc-card),var(--cc-amber-dim))!important}
.cc-card-alert::before{background:var(--cc-amber);opacity:1!important}
.cc-card-danger{border-color:rgba(220,38,38,.4)!important;background:linear-gradient(135deg,var(--cc-card),var(--cc-red-dim))!important}
.cc-card-danger::before{background:var(--cc-red);opacity:1!important}

/* ── BULLETIN CARDS ── */
.cc-bulletin{
  background:var(--cc-card);border:1px solid var(--cc-border);
  border-radius:10px;margin-bottom:12px;overflow:hidden;
  transition:border-color .2s;animation:cc-fadein .35s ease both;
}
.cc-bulletin:hover{border-color:var(--cc-border-h)}
@keyframes cc-fadein{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.cc-bul-head{padding:11px 13px 9px;display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.cc-officer-id{display:flex;align-items:center;gap:9px}
.cc-o-avatar{
  width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:17px;flex-shrink:0;border:1px solid rgba(142,255,66,.12)
}
.cc-o-name{font-size:13px;font-weight:600;color:var(--t0);line-height:1.2}
.cc-o-domain{font-size:10.5px;color:var(--t2);margin-top:1px}
.cc-bul-date{font-family:var(--fm);font-size:9.5px;color:var(--t2);flex-shrink:0;padding-top:2px}
.cc-bul-body{padding:0 13px 11px}
.cc-bul-headline{font-family:var(--fd);font-size:14px;font-weight:600;color:var(--t0);line-height:1.4;margin-bottom:5px}
.cc-bul-summary{font-size:12px;color:var(--t1);line-height:1.65}
/* ── Intelligence Feed — always-visible chips per bulletin ── */
.cc-bulletin-chips{
  display:flex;flex-direction:column;gap:7px;
  padding:10px 13px 13px;
  border-top:1px solid rgba(142,255,66,.06);
}
/* Specific question chips */
.cc-chip{
  display:flex;align-items:center;
  width:100%;padding:9px 14px;
  background:rgba(142,255,66,.05);
  border:1px solid rgba(142,255,66,.13);
  border-radius:8px;
  color:var(--t1);font-family:var(--fb);font-size:12.5px;
  cursor:pointer;transition:all .15s;
  text-align:left;line-height:1.4;
}
.cc-chip:hover{
  background:rgba(142,255,66,.11);
  border-color:rgba(142,255,66,.3);
  color:var(--glow);
  transform:translateX(2px);
}
.cc-chip:active{ transform:scale(.98); }
/* "Ask your own question" — visually distinct, full-width accent */
.cc-chip-own{
  background:rgba(142,255,66,.03);
  border:1px dashed rgba(142,255,66,.2);
  color:var(--t2);font-size:12px;
  margin-top:2px;
}
.cc-chip-own:hover{
  background:rgba(142,255,66,.08);
  border-color:rgba(142,255,66,.35);
  border-style:solid;
  color:var(--glow);
  transform:translateX(2px);
}

/* ═══════════════════════════════════════════════════════════════
   LIVE JOB CARDS — Adzuna + Luma scoring
   ═══════════════════════════════════════════════════════════════ */

/* Loading state */
.cc-jobs-loading{
  display:flex;flex-direction:column;align-items:center;
  padding:28px 16px;
}
.cc-jobs-loading-dots{
  display:flex;gap:6px;
}
.cc-jobs-loading-dots div{
  width:8px;height:8px;border-radius:50%;background:var(--glow);
  animation:cc-job-pulse 1.2s ease-in-out infinite;
}
.cc-jobs-loading-dots div:nth-child(2){ animation-delay:.2s; }
.cc-jobs-loading-dots div:nth-child(3){ animation-delay:.4s; }
@keyframes cc-job-pulse{
  0%,100%{ opacity:.25;transform:scale(.8); }
  50%{ opacity:1;transform:scale(1); }
}

/* Grid — single column on mobile, 2-col on wider screens */
.cc-jobs-grid{
  display:flex;flex-direction:column;gap:10px;margin-bottom:6px;
}
@media(min-width:640px){
  .cc-jobs-grid{
    display:grid;grid-template-columns:1fr 1fr;gap:10px;
  }
}

/* Individual job card */
.cc-job-card{
  background:var(--cc-card);border:1px solid var(--cc-border);
  border-radius:11px;padding:14px;display:flex;flex-direction:column;gap:6px;
  transition:border-color .2s;
}
.cc-job-card:hover{ border-color:rgba(142,255,66,.22); }

/* Company name + posted age */
.cc-job-header{
  display:flex;align-items:flex-start;justify-content:space-between;gap:8px;
}
.cc-job-company{
  font-family:var(--fd);font-size:12px;font-weight:700;
  color:var(--glow);line-height:1.3;flex:1;
}
.cc-job-age{
  font-family:var(--fm);font-size:9px;color:var(--t2);
  flex-shrink:0;padding-top:1px;
}

/* Role title */
.cc-job-title{
  font-size:13.5px;font-weight:600;color:var(--t0);
  line-height:1.35;
}

/* Location + salary + contract row */
.cc-job-meta{
  display:flex;flex-wrap:wrap;gap:6px;align-items:center;
}
.cc-job-loc,.cc-job-sal{
  font-size:11px;color:var(--t2);
}
.cc-job-type{
  font-family:var(--fm);font-size:9px;letter-spacing:.04em;
  color:var(--t2);background:rgba(142,255,66,.06);
  border:1px solid rgba(142,255,66,.1);border-radius:4px;
  padding:1px 6px;
}

/* Match score bar */
.cc-job-match-row{
  display:flex;align-items:center;gap:7px;margin:2px 0;
}
.cc-job-match-bar{
  flex:1;height:5px;background:rgba(142,255,66,.08);
  border-radius:3px;overflow:hidden;
}
.cc-job-match-fill{
  height:100%;border-radius:3px;
  transition:width .6s cubic-bezier(.4,0,.2,1);
}
.cc-job-match-score{
  font-family:var(--fd);font-size:15px;font-weight:700;
  flex-shrink:0;line-height:1;
}
.cc-job-match-label{
  font-family:var(--fm);font-size:9px;letter-spacing:.04em;
  flex-shrink:0;
}

/* Why this role */
.cc-job-why{
  font-size:11px;color:var(--t2);line-height:1.5;
  font-style:italic;
}

/* Gaps to close tags */
.cc-job-gaps{
  font-size:10.5px;color:var(--t2);display:flex;flex-wrap:wrap;
  align-items:center;gap:4px;
}
.cc-job-gap-tag{
  background:rgba(217,119,6,.1);border:1px solid rgba(217,119,6,.2);
  color:var(--cc-amber);border-radius:4px;padding:1px 6px;
  font-size:9.5px;font-weight:600;
}

/* Action buttons */
.cc-job-actions{
  display:flex;gap:6px;margin-top:4px;flex-wrap:wrap;
}
.cc-job-coach-btn{
  flex:1;padding:8px 10px;
  background:rgba(142,255,66,.07);border:1px solid rgba(142,255,66,.18);
  border-radius:7px;color:var(--glow);font-family:var(--fb);
  font-size:11.5px;font-weight:600;cursor:pointer;
  transition:all .15s;text-align:center;
}
.cc-job-coach-btn:hover{
  background:rgba(142,255,66,.14);border-color:rgba(142,255,66,.35);
}
.cc-job-apply-btn{
  padding:8px 12px;
  background:var(--glow);color:var(--ink) !important;
  border-radius:7px;font-family:var(--fb);font-size:11.5px;
  font-weight:700;text-decoration:none !important;
  transition:opacity .15s;white-space:nowrap;
  display:inline-flex;align-items:center;
}
.cc-job-apply-btn:hover{ opacity:.88; }

/* Footer: source + timestamp + refresh */
.cc-jobs-footer{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:6px;
  padding:8px 2px 0;border-top:1px solid rgba(142,255,66,.07);
  font-size:10px;color:var(--t2);
}
.cc-jobs-footer strong{ color:var(--t1); }
.cc-jobs-footer button{
  background:none;border:none;color:var(--glow);
  font-size:10px;cursor:pointer;padding:0;
  text-decoration:underline;
}

.cc-officer-card{
  background:var(--cc-card);border:1px solid var(--cc-border);
  border-radius:11px;padding:0 0 4px;margin-bottom:12px;
  overflow:hidden;transition:border-color .2s;
}
.cc-officer-card:hover{ border-color:rgba(142,255,66,.22); }
.cc-officer-card-head{
  display:flex;align-items:center;gap:12px;
  padding:13px 14px 10px;
  border-bottom:1px solid rgba(142,255,66,.06);
}
.cc-officer-chips{
  display:flex;flex-direction:column;gap:0;
  padding:6px 10px 8px;
}
/* Officer capability chip — fires question on tap (auto-send) */
.cc-officer-chip{
  display:flex;align-items:flex-start;
  width:100%;padding:9px 12px;margin-bottom:5px;
  background:rgba(142,255,66,.04);border:1px solid rgba(142,255,66,.1);
  border-radius:8px;color:var(--t1);font-family:var(--fb);
  font-size:12px;cursor:pointer;transition:all .15s;
  text-align:left;line-height:1.45;
}
.cc-officer-chip:hover{
  background:rgba(142,255,66,.1);border-color:rgba(142,255,66,.28);
  color:var(--glow);transform:translateX(2px);
}
.cc-officer-chip:active{ transform:scale(.98); }
/* "Ask your own" variant — dashed, dimmer */
.cc-officer-chip-own{
  background:transparent;border:1px dashed rgba(142,255,66,.15);
  color:var(--t2);font-size:11.5px;margin-bottom:0;
}
.cc-officer-chip-own:hover{
  background:rgba(142,255,66,.06);border-color:rgba(142,255,66,.3);
  border-style:solid;color:var(--glow);transform:translateX(2px);
}

/* ── Career — gap cards with action chips ── */
.cc-gap-card{
  background:var(--cc-card);border:1px solid var(--cc-border);
  border-radius:10px;margin-bottom:8px;overflow:hidden;transition:border-color .2s;
}
.cc-gap-card:hover{ border-color:rgba(142,255,66,.2); }
.cc-gap-card.working{ border-color:rgba(240,192,48,.25);background:rgba(240,192,48,.03); }
.cc-gap-card.closed{ border-color:rgba(52,211,153,.15);background:rgba(52,211,153,.03);opacity:.7; }
.cc-gap-chips{
  display:flex;flex-direction:column;gap:5px;
  padding:8px 11px 11px;border-top:1px solid rgba(142,255,66,.05);
}
/* Gap status buttons */
.cc-gap-status-btn{
  display:inline-flex;align-items:center;gap:5px;
  padding:6px 12px;border-radius:6px;border:none;
  font-family:var(--fb);font-size:11.5px;cursor:pointer;transition:all .15s;
}
.cc-gap-status-btn.working{
  background:rgba(240,192,48,.1);color:var(--cc-gold);border:1px solid rgba(240,192,48,.2);
}
.cc-gap-status-btn.working:hover{ background:rgba(240,192,48,.18); }
.cc-gap-status-btn.done{
  background:rgba(52,211,153,.1);color:var(--cc-emerald);border:1px solid rgba(52,211,153,.2);
}
.cc-gap-status-btn.done:hover{ background:rgba(52,211,153,.18); }

/* ── Career — Luma coaching panel ── */
.cc-luma-coaching-panel{
  background:linear-gradient(135deg,rgba(240,192,48,.07),rgba(142,255,66,.03));
  border:1px solid rgba(240,192,48,.2);border-radius:12px;
  padding:16px;margin:14px 0;
}
#cc-luma-career-chat{
  scrollbar-width:none;
}
#cc-luma-career-chat::-webkit-scrollbar{ display:none; }

/* ── Career — milestone chips in roadmap ── */
.cc-milestone-chips{
  display:flex;flex-direction:column;gap:5px;
  margin-top:9px;padding-top:9px;
  border-top:1px solid rgba(142,255,66,.07);
}

.cc-gip-stage-chips{
  background:rgba(142,255,66,.03);
  border:1px solid rgba(142,255,66,.1);
  border-radius:8px;padding:10px 11px;margin:8px 0;
}
.cc-gip-chips-label{
  font-family:var(--fm);font-size:9px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--glow);
  margin-bottom:8px;
}

.cc-bul-actions{display:flex;gap:6px;padding:0 13px 12px;flex-wrap:wrap}
.cc-action-btn{
  flex:1;min-width:80px;padding:6px 8px;font-size:11px;font-weight:600;
  background:rgba(142,255,66,.06);border:1px solid rgba(142,255,66,.15);
  color:var(--t1);border-radius:5px;cursor:pointer;transition:all .15s;font-family:var(--fb);
}
.cc-action-btn:hover{color:var(--glow);border-color:rgba(142,255,66,.35);background:rgba(142,255,66,.12)}
.cc-reg-flag{
  display:flex;align-items:flex-start;gap:7px;padding:7px 10px;
  background:var(--cc-amber-dim);border:1px solid rgba(217,119,6,.3);
  border-radius:6px;font-size:11px;color:var(--cc-amber);
  font-weight:500;margin-top:9px;cursor:pointer;transition:background .15s;
}
.cc-reg-flag:hover{background:rgba(217,119,6,.2)}
.cc-reg-flag.critical{background:var(--cc-red-dim);border-color:rgba(220,38,38,.3);color:#f87171}

/* ── SESSIONS ── */
.cc-session{
  display:flex;align-items:flex-start;gap:9px;padding:11px 12px;
  background:var(--cc-card);border:1px solid var(--cc-border);
  border-radius:8px;margin-bottom:7px;cursor:pointer;transition:all .18s;
  animation:cc-fadein .25s ease both;
}
.cc-session:hover{border-color:var(--cc-border-h);background:#121f10}
.cc-session-dot{
  width:30px;height:30px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;flex-shrink:0;border:1px solid rgba(142,255,66,.12)
}
.cc-session-name{font-size:12px;font-weight:600;color:var(--t0);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}
.cc-session-meta{display:flex;align-items:center;gap:7px;margin-top:3px}
.cc-session-date{font-family:var(--fm);font-size:9.5px;color:var(--t2)}
.cc-session-acts{display:flex;gap:3px;flex-shrink:0;margin-left:auto}

/* ── SCORE CIRCLE ── */
.cc-score-block{
  display:flex;align-items:center;gap:14px;
  background:linear-gradient(135deg,var(--cc-card),rgba(69,168,90,.06));
  border:1px solid var(--cc-border);border-radius:10px;
  padding:14px;margin-bottom:12px;
}
.cc-score-circle{width:68px;height:68px;flex-shrink:0;position:relative}
.cc-score-circle svg{transform:rotate(-90deg)}
.cc-score-track{fill:none;stroke:rgba(142,255,66,.1);stroke-width:5}
.cc-score-fill{fill:none;stroke:url(#ccScoreGrad);stroke-width:5;stroke-linecap:round;stroke-dasharray:188;transition:stroke-dashoffset 1.4s cubic-bezier(.4,0,.2,1)}
.cc-score-num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:20px;font-weight:700;color:var(--glow)}
.cc-score-info{}
.cc-score-title{font-size:12px;font-weight:600;color:var(--t0);margin-bottom:2px}
.cc-score-change{font-family:var(--fm);font-size:10.5px;color:var(--cc-emerald)}
.cc-score-date{font-size:10px;color:var(--t2);margin-top:1px}

/* ── GAP ITEMS ── */
.cc-gap{
  display:flex;align-items:flex-start;gap:9px;padding:9px 11px;
  background:var(--cc-card);border:1px solid var(--cc-border);
  border-radius:8px;margin-bottom:5px;transition:border-color .18s;
}
.cc-gap:hover{border-color:var(--cc-border-h)}
.cc-gap-num{font-family:var(--fm);font-size:10px;color:var(--t2);flex-shrink:0;width:18px;padding-top:1px}
.cc-gap-title{font-size:12px;font-weight:600;color:var(--t1)}
.cc-gap-desc{font-size:10.5px;color:var(--t2);line-height:1.5;margin-top:2px}

/* ── ROADMAP ── */
.cc-roadmap{position:relative;padding-left:18px;margin-top:10px}
.cc-roadmap::before{content:'';position:absolute;left:5px;top:0;bottom:0;width:1px;background:linear-gradient(180deg,var(--cc-emerald),var(--cc-gold-dim),transparent)}
.cc-milestone{position:relative;margin-bottom:14px;padding-left:13px}
.cc-milestone::before{content:'';position:absolute;left:-14px;top:4px;width:8px;height:8px;border-radius:50%;background:rgba(142,255,66,.1);border:2px solid rgba(142,255,66,.2);transition:all .2s}
.cc-milestone.done::before{background:var(--cc-emerald);border-color:var(--cc-emerald)}
.cc-milestone.active::before{background:var(--cc-gold);border-color:var(--cc-gold);box-shadow:0 0 8px rgba(240,192,48,.4);animation:cc-ms-pulse 1.5s infinite}
@keyframes cc-ms-pulse{0%,100%{box-shadow:0 0 0 0 rgba(240,192,48,.3)}50%{box-shadow:0 0 0 5px rgba(240,192,48,.08)}}
.cc-ms-week{font-family:var(--fm);font-size:9.5px;color:var(--t2);text-transform:uppercase}
.cc-ms-title{font-size:12px;font-weight:600;color:var(--t1);margin-top:1px}
.cc-ms-desc{font-size:11px;color:var(--t2);margin-top:2px;line-height:1.5}

/* ── GIP CARDS ── */
.cc-gip{
  background:var(--cc-card);border:1px solid var(--cc-border);
  border-radius:10px;padding:13px;margin-bottom:10px;transition:border-color .2s;
}
.cc-gip:hover{border-color:rgba(240,192,48,.25)}
.cc-gip-title{font-family:var(--fd);font-size:13px;font-weight:700;color:var(--t0);line-height:1.3;flex:1}
.cc-gip-meta{display:flex;align-items:center;gap:7px;margin:7px 0 9px;flex-wrap:wrap}
.cc-gip-cat{font-family:var(--fm);font-size:9px;letter-spacing:.05em;text-transform:uppercase;color:var(--t2)}
.cc-version-tag{font-family:var(--fm);font-size:9px;color:var(--t2);background:#0a1509;border:1px solid rgba(142,255,66,.1);padding:1px 6px;border-radius:3px}
.cc-status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:3px}
.cc-status-dot.live{background:var(--glow);box-shadow:0 0 5px var(--glow);animation:cc-pulse-dot 2s infinite}
.cc-status-dot.flagged{background:var(--cc-amber)}
.cc-status-dot.delisted{background:var(--cc-red)}
.cc-status-dot.draft{background:var(--t2)}
@keyframes cc-pulse-dot{0%,100%{box-shadow:0 0 0 0 rgba(142,255,66,.3)}50%{box-shadow:0 0 0 4px rgba(142,255,66,.08)}}

/* Pipeline dots */
.cc-pipe{margin:9px 0}
.cc-pipe-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}
.cc-pipe-label{font-family:var(--fm);font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:var(--t2)}
.cc-pipe-stage{font-family:var(--fm);font-size:10px;color:var(--cc-gold)}
.cc-pipe-dots{display:flex;gap:3px;padding-bottom:14px}
.cc-pd{flex:1;height:5px;border-radius:2px;background:rgba(142,255,66,.1);transition:background .25s;position:relative}
.cc-pd.done{background:var(--cc-emerald)}
.cc-pd.active{background:var(--cc-gold);animation:cc-pd-pulse 1.5s infinite}
@keyframes cc-pd-pulse{0%,100%{opacity:1}50%{opacity:.55}}
.cc-pd-tip{position:absolute;bottom:-13px;left:50%;transform:translateX(-50%);font-size:7.5px;color:var(--cc-gold);white-space:nowrap;font-family:var(--fm)}
.cc-delist-notice{
  display:flex;align-items:center;gap:7px;padding:7px 9px;
  background:var(--cc-red-dim);border:1px solid rgba(220,38,38,.25);
  border-radius:5px;font-size:10.5px;color:#f87171;margin-top:7px;
}

/* ── VIRTUAL CLUB ── */
.cc-rooms-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:10px}
@media(min-width:480px) and (max-width:767px){.cc-rooms-grid{grid-template-columns:repeat(3,1fr)}}
.cc-room{
  background:var(--cc-card);border:1px solid var(--cc-border);border-radius:8px;
  padding:11px 9px;text-align:center;cursor:pointer;transition:all .2s;
  text-decoration:none;display:flex;flex-direction:column;align-items:center;gap:5px;
}
.cc-room:hover{border-color:rgba(240,192,48,.3);transform:translateY(-2px);box-shadow:0 6px 20px rgba(240,192,48,.1)}
.cc-room-icon{font-size:20px}
.cc-room-name{font-size:10.5px;font-weight:600;color:var(--t1);line-height:1.3}
.cc-room-type{font-family:var(--fm);font-size:8.5px;color:var(--t2)}
.cc-invite-status{
  display:flex;align-items:center;gap:7px;padding:9px 11px;
  background:rgba(69,168,90,.1);border:1px solid rgba(69,168,90,.3);
  border-radius:6px;font-size:11px;color:var(--cc-emerald);margin-bottom:11px;
}

/* ── LOCK OVERLAY ── */
.cc-locked{position:relative;overflow:hidden;border-radius:10px}
.cc-locked .cc-blur{filter:blur(4px);pointer-events:none;user-select:none;opacity:.45}
.cc-lock-cta{
  position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:9px;
  background:rgba(10,18,8,.72);backdrop-filter:blur(2px);
  border-radius:10px;text-align:center;padding:18px;
}
.cc-lock-cta p{font-size:11.5px;color:var(--t1);max-width:200px;line-height:1.55}

/* ── CHAT MODAL ── */
#cc-chat-modal{
  display:none;position:fixed;inset:0;z-index:9000;
  background:rgba(5,12,5,.9);backdrop-filter:blur(10px);
  align-items:flex-end;justify-content:center;padding:0;
}
#cc-chat-modal.open{display:flex}
@media(min-width:768px){#cc-chat-modal{align-items:center;padding:20px}}
.cc-modal-box{
  background:#101e0d;border:1px solid rgba(142,255,66,.15);
  border-radius:14px 14px 0 0;width:100%;max-width:580px;
  max-height:90vh;overflow-y:auto;
  transform:translateY(40px);transition:transform .28s cubic-bezier(.34,1.56,.64,1);
}
@media(min-width:768px){.cc-modal-box{border-radius:14px;transform:scale(.96)}}
#cc-chat-modal.open .cc-modal-box{transform:translateY(0)}
@media(min-width:768px){#cc-chat-modal.open .cc-modal-box{transform:scale(1)}}
.cc-modal-handle{width:34px;height:3px;background:rgba(142,255,66,.15);border-radius:2px;margin:11px auto 0;display:block}
@media(min-width:768px){.cc-modal-handle{display:none}}
.cc-modal-head{
  padding:13px 16px 11px;border-bottom:1px solid rgba(142,255,66,.1);
  display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;background:#101e0d;z-index:2;
}
.cc-modal-title{font-family:var(--fd);font-size:16px;font-weight:700;color:#fff;display:flex;align-items:center;gap:8px}
.cc-modal-close{
  width:28px;height:28px;border-radius:50%;background:#0a1509;
  border:1px solid rgba(142,255,66,.15);color:var(--t2);
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  font-size:14px;transition:all .15s;
}
.cc-modal-close:hover{color:var(--t0);border-color:rgba(142,255,66,.3)}
.cc-modal-body{padding:16px}
.cc-chat-msgs{min-height:180px;max-height:42vh;overflow-y:auto;margin-bottom:13px;display:flex;flex-direction:column;gap:11px}
.cc-msg{display:flex;gap:9px;animation:cc-fadein .22s ease}
.cc-msg.user{flex-direction:row-reverse}
.cc-msg-avatar{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;border:1px solid rgba(142,255,66,.12)}
.cc-bubble{max-width:82%;padding:8px 11px;border-radius:9px;font-size:13px;line-height:1.6}
.cc-msg.officer .cc-bubble{background:#0a1509;border:1px solid rgba(142,255,66,.1);color:var(--t0);border-bottom-left-radius:3px}
.cc-msg.user .cc-bubble{background:var(--cc-emerald);color:#fff;border-bottom-right-radius:3px}
.cc-typing{display:flex;gap:3px;align-items:center;padding:4px 0}
.cc-typing-dot{width:5px;height:5px;border-radius:50%;background:var(--t2);animation:cc-type 1.2s infinite}
.cc-typing-dot:nth-child(2){animation-delay:.2s}
.cc-typing-dot:nth-child(3){animation-delay:.4s}
@keyframes cc-type{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}
.cc-chat-input-row{display:flex;gap:7px;align-items:flex-end}
.cc-chat-input{
  flex:1;background:#0a1509;border:1px solid rgba(142,255,66,.15);border-radius:8px;
  padding:8px 11px;color:var(--t0);font-family:var(--fb);font-size:13px;
  resize:none;min-height:40px;max-height:96px;outline:none;transition:border-color .18s;
}
.cc-chat-input:focus{border-color:rgba(142,255,66,.35)}
.cc-chat-input::placeholder{color:var(--t2)}
.cc-send-btn{
  width:38px;height:38px;border-radius:6px;background:var(--cc-emerald);border:none;
  color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;
  font-size:16px;transition:all .18s;flex-shrink:0;
}
.cc-send-btn:hover{background:var(--glow);color:var(--ink)}
.cc-send-btn:disabled{background:rgba(142,255,66,.15);cursor:not-allowed}

/* ── TOP-UP MODAL ── */
#cc-topup-modal{display:none;position:fixed;inset:0;z-index:9000;background:rgba(5,12,5,.9);backdrop-filter:blur(10px);align-items:flex-end;justify-content:center;padding:0}
#cc-topup-modal.open{display:flex}
@media(min-width:768px){#cc-topup-modal{align-items:center;padding:20px}}
.cc-topup-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:13px}
.cc-topup-opt{
  background:#0a1509;border:1px solid rgba(142,255,66,.12);border-radius:8px;
  padding:14px 10px;text-align:center;cursor:pointer;transition:all .2s;
}
.cc-topup-opt:hover{border-color:rgba(142,255,66,.3)}
.cc-topup-opt.best{border-color:var(--cc-gold-dim)}
.cc-topup-asks{font-family:var(--fd);font-size:22px;font-weight:700;color:var(--glow);line-height:1}
.cc-topup-price{font-size:13px;font-weight:600;color:var(--t1);margin-top:2px}
.cc-topup-per{font-family:var(--fm);font-size:8.5px;color:var(--t2);margin-top:2px}
.cc-topup-best-tag{font-family:var(--fm);font-size:8px;font-weight:700;text-transform:uppercase;color:var(--cc-gold);letter-spacing:.08em;margin-bottom:3px}

/* ── SECTION LABEL ── */
.cc-sec-label{
  font-family:var(--fm);font-size:8.5px;font-weight:700;text-transform:uppercase;
  letter-spacing:.1em;color:var(--t2);padding:7px 0 5px;
  display:flex;align-items:center;gap:6px;
}
.cc-sec-label::after{content:'';flex:1;height:1px;background:rgba(142,255,66,.07)}

/* ── BADGES ── */
.cc-badge{display:inline-flex;align-items:center;gap:3px;font-family:var(--fm);font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:2px 7px;border-radius:20px}
.cc-badge-green{background:var(--cc-emerald-glow);color:var(--cc-emerald);border:1px solid rgba(69,168,90,.35)}
.cc-badge-gold{background:rgba(240,192,48,.1);color:var(--cc-gold);border:1px solid var(--cc-gold-dim)}
.cc-badge-amber{background:var(--cc-amber-dim);color:var(--cc-amber);border:1px solid rgba(217,119,6,.3)}
.cc-badge-red{background:var(--cc-red-dim);color:#f87171;border:1px solid rgba(220,38,38,.3)}
.cc-badge-grey{background:rgba(106,136,114,.12);color:var(--t2);border:1px solid rgba(106,136,114,.2)}

/* ── BUTTONS ── */
.cc-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:5px;font-size:12px;font-weight:600;cursor:pointer;transition:all .18s;border:none;font-family:var(--fb);white-space:nowrap}
.cc-btn-primary{background:var(--cc-emerald);color:#fff}
.cc-btn-primary:hover{background:var(--glow);color:var(--ink);transform:translateY(-1px)}
.cc-btn-gold{background:linear-gradient(135deg,var(--cc-gold),#fbbf24);color:var(--ink);font-weight:700}
.cc-btn-gold:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(240,192,48,.25)}
.cc-btn-ghost{background:transparent;color:var(--t1);border:1px solid rgba(142,255,66,.15)}
.cc-btn-ghost:hover{color:var(--t0);border-color:rgba(142,255,66,.3);background:#0a1509}
.cc-btn-sm{padding:4px 9px;font-size:11px}
.cc-btn-xs{padding:3px 7px;font-size:10px}

/* ── SHIMMER LOADER ── */
.cc-shimmer{background:linear-gradient(90deg,#101e0d 25%,#142213 50%,#101e0d 75%);background-size:200% 100%;animation:cc-shimmer 1.4s infinite;border-radius:5px;height:12px;margin-bottom:5px}
@keyframes cc-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.cc-loading-card{background:var(--cc-card);border:1px solid var(--cc-border);border-radius:10px;padding:14px;margin-bottom:10px}

/* ── TOAST ── */
#cc-toast-wrap{position:fixed;bottom:calc(68px + var(--safe-b));left:50%;transform:translateX(-50%);z-index:2000;display:flex;flex-direction:column;gap:5px;pointer-events:none;width:92%;max-width:360px}
@media(min-width:768px){#cc-toast-wrap{bottom:20px}}
.cc-toast{background:var(--cc-card);border:1px solid var(--cc-border);border-radius:8px;padding:9px 13px;font-size:13px;color:var(--t0);display:flex;align-items:center;gap:9px;box-shadow:0 4px 16px rgba(0,0,0,.4);animation:cc-fadein .25s ease}
.cc-toast.ok{border-color:rgba(69,168,90,.35)}
.cc-toast.warn{border-color:rgba(217,119,6,.35)}

/* ── EMPTY STATE ── */
.cc-empty{text-align:center;padding:28px 16px;color:var(--t2)}
.cc-empty .cc-ei{font-size:28px;margin-bottom:9px;opacity:.45}
.cc-empty p{font-size:11.5px;line-height:1.6;max-width:190px;margin:0 auto}

/* ── CV INTAKE MODAL INPUT METHOD CARDS ── */
.cc-cv-imc{
  display:flex;align-items:flex-start;gap:11px;padding:11px 13px;
  background:#0a1509;border:1px solid rgba(142,255,66,.1);border-radius:8px;
  cursor:pointer;transition:all .18s;
}
.cc-cv-imc:hover{border-color:rgba(142,255,66,.25);background:#0d1a0b}
.cc-cv-imc.on{border-color:rgba(142,255,66,.35);background:rgba(142,255,66,.05)}
.cc-imc-check{font-size:11px;color:var(--glow);font-weight:700;flex-shrink:0;padding-top:2px;transition:opacity .15s}

/* ── CC MOBILE PADDING & NAV DISPLAY ── */
/* On mobile, when member is logged in:
   - Hide the legacy bottom nav via JS (bnav.style.display='none')
   - CSS also enforces it as backup */
body.cc-member-mode #bnav{display:none!important}

/* MOBILE MEMBER NAV — show unconditionally when member mode is active.
   This CSS rule is the primary trigger (class + inline style are backups).
   body.cc-member-mode is set synchronously in ccInit before any paint. */
@media(max-width:767px){
  body.cc-member-mode #cc-mobile-nav{
    display:flex !important;
    position:fixed !important;
    bottom:0 !important;
    left:0 !important;
    right:0 !important;
    z-index:9500 !important;
  }
}

/* ══════════════════════════════════════════════════════════════
   MEMBER MODE — nuclear hide of ALL public content
   Nothing from the public home page should ever be visible
   when a member is logged in.
══════════════════════════════════════════════════════════════ */

/* Hide public top nav links and CTA buttons — member has the CC tab bar */
body.cc-member-mode #nav .nav-links{display:none!important}
body.cc-member-mode #nav .nav-cta{display:none!important}
body.cc-member-mode #nav .nav-login{display:none!important}

/* Every direct child of pg-home except the dashboard = gone */
body.cc-member-mode #pg-home > *:not(#member-dashboard){
  display:none!important;
  visibility:hidden!important;
  height:0!important;
  min-height:0!important;
  overflow:hidden!important;
  pointer-events:none!important;
}
/* All other public .pg pages = gone */
body.cc-member-mode .pg:not(#pg-home){
  display:none!important;
}
/* Hero section targeted directly in case specificity loses */
body.cc-member-mode .hero-welcome,
body.cc-member-mode .home-intel-feed,
body.cc-member-mode .home-news-cards,
body.cc-member-mode .home-gip-scroll{
  display:none!important;
  min-height:0!important;
}
/* Prevent pg-home itself from creating extra space */
body.cc-member-mode #pg-home{
  min-height:0;
}
/* On mobile: push member dashboard content above the fixed bottom nav */
@media(max-width:767px){
  body.cc-member-mode #member-dashboard{
    padding-bottom:calc(72px + env(safe-area-inset-bottom,0px)) !important;
  }
}

/* Tab bar buttons — desktop only */
.cc-tab{background:none;border:none;border-bottom:2px solid transparent;padding:8px 14px 10px;font-family:var(--fm);font-size:11px;letter-spacing:.4px;text-transform:uppercase;color:rgba(142,255,66,.4);cursor:pointer;transition:all .18s;white-space:nowrap;flex-shrink:0}
.cc-tab.on{color:var(--glow);border-bottom-color:var(--glow)}
.cc-tab:hover:not(.on){color:rgba(142,255,66,.7)}
/* Tab bar is scrollable on narrow desktops */
#cc-tab-bar{display:none;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
#cc-tab-bar::-webkit-scrollbar{display:none}
/* Mobile nav buttons: fixed width so 8 items scroll cleanly */
#cc-mobile-nav .cc-bn{min-width:54px;flex:0 0 auto}
/* Mobile nav: fade right edge to hint scrollability when 8+ tabs present */
#cc-mobile-nav::after{
  content:'';
  position:fixed;
  bottom:0;
  right:0;
  width:28px;
  height:calc(58px + env(safe-area-inset-bottom, 0px));
  background:linear-gradient(to right, transparent, rgba(15,28,13,.95));
  pointer-events:none;
  z-index:9501;
}
body.cc-member-mode #cc-mobile-nav::after{display:block}
.cc-mf-btn{background:rgba(142,255,66,.04);border:1px solid rgba(142,255,66,.12);color:var(--t2);border-radius:20px;padding:4px 11px;font-size:11px;font-family:var(--fb);cursor:pointer;transition:all .18s;white-space:nowrap}
.cc-mf-btn:hover{color:var(--t1);border-color:rgba(142,255,66,.3)}
.cc-mf-btn.cc-mf-active{background:rgba(142,255,66,.12);border-color:rgba(142,255,66,.4);color:var(--glow)}
/* Tab bar hidden on mobile — mobile uses bottom nav */
/* Tab bar hidden on mobile — mobile nav takes over */
@media(max-width:767px){#cc-tab-bar{display:none!important}}
/* In member mode: old fixed officer-chat-modal replaced by inline chat */
body.cc-member-mode #officer-chat-modal{display:none!important}
/* CV intake method buttons */
.cc-imt-btn{flex:1;background:rgba(142,255,66,.04);border:1px solid rgba(142,255,66,.1);color:var(--t2);border-radius:7px;padding:7px 10px;font-family:var(--fm);font-size:11px;cursor:pointer;transition:all .18s}
.cc-imt-btn.on{background:rgba(142,255,66,.14);border-color:rgba(142,255,66,.35);color:var(--glow)}

/* Member mode: full-width no-card layout on mobile */
@media(max-width:767px){
  /* Remove card chrome from member-dashboard container on mobile */
  #member-dashboard.visible{
    padding:0!important;
    margin:0!important;
    border:none!important;
    border-radius:0!important;
    background:#0a1208!important;
  }
  /* Status bar: NOT sticky on mobile — sticky causes layout gap under iOS nav */
  #cc-status-bar.cc-active{
    position:relative;
    border-radius:0;
    border-left:none;
    border-right:none;
    margin-bottom:0;
  }
  /* Remove border between panels on mobile */
  .cc-panel{border-right:none}
  /* Bottom padding so content always clears the CC mobile nav.
     The nav is 58px + safe-area. Add extra 20px breathing room.
     max() handles all iPhone models including notched ones. */
  #cc-grid.cc-active{
    padding-bottom:max(110px, calc(78px + env(safe-area-inset-bottom, 34px)));
  }
  /* Also pad member-dashboard container itself */
  #member-dashboard.visible{
    padding-bottom:max(110px, calc(78px + env(safe-area-inset-bottom, 34px)))!important;
  }
}

/* ── MODAL DESKTOP ROUNDING (CV + Rebuild) ── */
@media(min-width:768px){
  #cc-cv-modal{align-items:center;padding:20px}
  #cc-cv-modal .cc-modal-box{border-radius:14px}
  #cc-rebuild-modal{align-items:center;padding:20px}
  #cc-rebuild-modal .cc-modal-box{border-radius:14px}
}


/* ─── PRE-PURCHASE EMAIL CAPTURE ────────────────────────── */
#prepurchase-modal{
  display:none;position:fixed;inset:0;z-index:9000;
  background:rgba(0,0,0,.88);align-items:center;
  justify-content:center;padding:16px
}
#prepurchase-modal.open{display:flex}
.pp-box{
  background:#101e0d;border:1px solid rgba(142,255,66,.2);
  border-radius:14px;max-width:420px;width:100%;
  padding:28px;position:relative;
  box-shadow:0 40px 100px rgba(0,0,0,.7)
}
.pp-close{
  position:absolute;top:12px;right:12px;background:none;
  border:1px solid rgba(142,255,66,.18);color:var(--t2);
  width:28px;height:28px;border-radius:5px;cursor:pointer;
  font-size:14px;display:flex;align-items:center;
  justify-content:center;transition:all .2s
}
.pp-close:hover{border-color:var(--glow);color:var(--glow)}


/* ─── ECOPRENEUR ACCESS GATE ────────────────────────────── */
#eco-gate-modal{
  display:none;position:fixed;inset:0;z-index:1300;
  background:rgba(0,0,0,.92);align-items:center;
  justify-content:center;padding:16px;overflow-y:auto
}
#eco-gate-modal.open{display:flex}
.eco-box{
  background:linear-gradient(160deg,#0e1c0c,#121f10);
  border:1px solid rgba(240,192,48,.25);border-radius:16px;
  max-width:460px;width:100%;padding:32px 28px;
  box-shadow:0 48px 120px rgba(0,0,0,.8),
             0 0 0 1px rgba(240,192,48,.1);
  position:relative
}
.eco-close{
  position:absolute;top:14px;right:14px;background:none;
  border:1px solid rgba(255,255,255,.12);color:var(--t2);
  width:28px;height:28px;border-radius:5px;cursor:pointer;
  font-size:14px;display:flex;align-items:center;
  justify-content:center;transition:all .2s
}
.eco-close:hover{border-color:var(--gold);color:var(--gold)}
.eco-emblem{
  width:64px;height:64px;border-radius:50%;margin:0 auto 16px;
  background:linear-gradient(135deg,rgba(240,192,48,.2),rgba(142,255,66,.1));
  border:2px solid rgba(240,192,48,.4);
  display:flex;align-items:center;justify-content:center;font-size:28px
}
.eco-title{
  font-family:var(--fd);font-size:22px;font-weight:700;
  color:#fff;text-align:center;margin-bottom:6px;line-height:1.2
}
.eco-sub{
  font-size:13px;color:var(--t1);text-align:center;
  line-height:1.7;margin-bottom:22px
}
.eco-price-row{
  display:flex;align-items:center;justify-content:center;
  gap:10px;margin-bottom:20px
}
.eco-price{
  font-family:var(--fd);font-size:36px;font-weight:700;
  color:var(--gold);line-height:1
}
.eco-price-note{font-size:12px;color:var(--t2);line-height:1.4}
.eco-includes{
  background:#0a1509;border:1px solid rgba(142,255,66,.1);
  border-radius:8px;padding:14px 16px;margin-bottom:18px
}
.eco-include-item{
  display:flex;gap:8px;align-items:flex-start;
  font-size:12.5px;color:var(--t1);line-height:1.55;
  padding:4px 0
}
.eco-include-item::before{
  content:'✓';color:var(--gold);font-weight:700;
  flex-shrink:0;font-size:11px;margin-top:1px
}
.eco-gip-input{
  width:100%;background:#0e1b0b;border:1px solid rgba(240,192,48,.25);
  color:var(--t0);padding:12px 14px;border-radius:8px;font-size:13.5px;
  font-family:var(--fb);outline:none;transition:border-color .2s;
  margin-bottom:10px
}
.eco-gip-input:focus{border-color:var(--gold)}
.eco-gip-input::placeholder{color:var(--t2)}
.eco-launch-btn{
  width:100%;background:linear-gradient(135deg,var(--gold),#e8a020);
  color:var(--ink);border:none;padding:15px;border-radius:9px;
  font-family:var(--fd);font-size:16px;font-weight:700;
  cursor:pointer;transition:all .2s;margin-bottom:10px;
  letter-spacing:.3px
}
.eco-launch-btn:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 24px rgba(240,192,48,.3)
}
.eco-note{font-size:11px;color:var(--t2);text-align:center;line-height:1.6}

/* ─── ECOPRENEUR UNLOCK SCREEN ──────────────────────────── */
.eco-unlock{
  display:none;text-align:center;padding:8px 0
}
.eco-unlock.visible{display:block}
.eco-unlock-emblem{
  font-size:52px;margin-bottom:12px;
  animation:ecobounce .6s ease
}
@keyframes ecobounce{
  0%{transform:scale(0)}50%{transform:scale(1.2)}100%{transform:scale(1)}
}
.eco-unlock-title{
  font-family:var(--fd);font-size:22px;font-weight:700;
  color:var(--gold);margin-bottom:8px;line-height:1.2
}
.eco-unlock-msg{
  font-size:13px;color:var(--t1);line-height:1.75;
  margin-bottom:18px
}
.eco-gip-name-badge{
  display:inline-block;font-family:var(--fm);font-size:10px;
  letter-spacing:1px;text-transform:uppercase;padding:5px 14px;
  border-radius:20px;background:rgba(240,192,48,.12);
  color:var(--gold);border:1px solid rgba(240,192,48,.3);
  margin-bottom:16px
}


/* ─── TIER USP STATEMENT ────────────────────────────────── */
.tier-usp{
  font-family:var(--fd);font-size:14.5px;font-weight:700;
  color:#ffffff;line-height:1.4;margin-bottom:7px;
  border-left:3px solid var(--glow);padding-left:11px
}
.tier.pop .tier-usp{border-color:var(--gold)}
.tier-usp-detail{
  font-size:12px;color:var(--t2);line-height:1.65;
  margin-bottom:16px;padding-left:14px
}

/* ─── OFFICER CARDS ─── */
.officers-scroll{display:flex;gap:12px;overflow-x:auto;padding-bottom:12px;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin-bottom:28px}
.officers-scroll::-webkit-scrollbar{display:none}
.oc{flex-shrink:0;width:200px;background:#101e0d;border:1px solid rgba(142,255,66,.1);border-radius:var(--r);padding:18px;display:flex;flex-direction:column;transition:all .25s}
.oc:hover{border-color:rgba(142,255,66,.25);transform:translateY(-2px)}
.oc-ask{margin-top:auto;padding-top:12px;border-top:1px solid rgba(142,255,66,.07);font-family:var(--fm);font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--glow);cursor:pointer;transition:color .18s;text-align:center}
.oc-detail{margin-top:7px;font-family:var(--fm);font-size:8.5px;letter-spacing:1px;text-transform:uppercase;color:var(--t2);cursor:pointer;transition:color .18s;text-align:center;padding-top:7px;border-top:1px solid rgba(255,255,255,.04)}
.oc-detail:hover{color:var(--gold)}
.oc-ask:hover{color:var(--sprout)}
@media(min-width:960px){.officers-scroll{display:grid;grid-template-columns:repeat(4,1fr);overflow-x:visible;padding-bottom:0}.oc{width:auto}}

/* ─── ANSWER PREVIEW WALL ─── */
.preview-wrap{position:relative;margin-top:4px}
.preview-text{position:relative;overflow:hidden;max-height:90px}
.preview-text::after{content:'';position:absolute;bottom:0;left:0;right:0;height:52px;
  background:linear-gradient(transparent,#182e18 85%);pointer-events:none}
.preview-blur{filter:blur(3.5px);user-select:none;pointer-events:none;opacity:.6;font-size:inherit;line-height:inherit;margin-top:6px}
.preview-wall{margin-top:10px;background:#142413;border:1px solid rgba(142,255,66,.22);
  border-radius:8px;padding:16px;text-align:center}
.pw-lock{font-size:22px;margin-bottom:6px}
.pw-title{font-size:14px;font-weight:700;color:#ffffff;margin-bottom:4px}
.pw-sub{font-size:12px;color:var(--t1);line-height:1.6;margin-bottom:14px}
.pw-btns{display:flex;flex-direction:column;gap:8px}
.pw-free{background:rgba(142,255,66,.1);color:var(--glow);border:1px solid rgba(142,255,66,.3);
  padding:10px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;font-family:var(--fb)}
.pw-free:hover{background:rgba(142,255,66,.18)}
.pw-silver{background:var(--glow);color:var(--ink);border:none;padding:10px;border-radius:6px;
  font-size:13px;font-weight:700;cursor:pointer;transition:all .2s;font-family:var(--fb)}
.pw-silver:hover{background:var(--sprout)}
.pw-note{font-size:10.5px;color:var(--t2);margin-top:8px;line-height:1.5}

/* Legacy classes kept for compatibility */
.hub-filters{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:16px}
.hub-pill{font-family:var(--fm);font-size:9px;letter-spacing:1px;text-transform:uppercase;padding:6px 14px;border-radius:20px;border:1px solid rgba(142,255,66,.1);background:#131c10;color:var(--t2);cursor:pointer;transition:all .18s}
.hub-pill.on{background:rgba(142,255,66,.1);color:var(--glow);border-color:rgba(142,255,66,.28)}

/* ═══════════════════════════════════════════════════════
   FLYWHEEL
═══════════════════════════════════════════════════════ */
.flywheel{position:relative;padding-left:40px}
.flywheel::before{content:'';position:absolute;left:18px;top:26px;bottom:26px;width:1px;background:rgba(142,255,66,.1)}
.fw-step{display:flex;gap:16px;padding:14px 0;align-items:flex-start}
.fw-num{width:36px;height:36px;border-radius:50%;background:#1a341a;border:1px solid rgba(142,255,66,.22);display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:17px;font-weight:700;color:var(--glow);flex-shrink:0;z-index:1;margin-left:-40px}
.fw-title{font-size:14px;font-weight:600;color:var(--t0);margin-bottom:3px}
.fw-desc{font-size:12.5px;color:var(--t1);line-height:1.6}
.fw-tag{font-family:var(--fm);font-size:9px;color:var(--sprout);margin-top:5px;letter-spacing:.5px}

/* ═══════════════════════════════════════════════════════
   HUBS SECTION
═══════════════════════════════════════════════════════ */
.hubs-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.hub-card{background:#101e0d;border:1px solid rgba(142,255,66,.08);border-radius:var(--r);padding:16px;text-align:center;transition:all .25s;cursor:pointer;position:relative;overflow:hidden}
.hub-card:hover{border-color:rgba(142,255,66,.2);transform:translateY(-2px)}
.hub-card.active{border-color:rgba(142,255,66,.3);background:#131f11}
.hub-card.coming{opacity:.45;cursor:default}
.hub-card.coming:hover{transform:none}
.hub-flag{font-size:26px;margin-bottom:8px}
.hub-name{font-family:var(--fd);font-size:14px;font-weight:600;color:var(--t0);margin-bottom:3px;line-height:1.3}
.hub-card.active .hub-name{color:var(--glow)}
.hub-tag{font-family:var(--fm);font-size:8px;color:var(--t2);letter-spacing:.5px}
.hub-soon{font-family:var(--fm);font-size:7.5px;color:var(--amber);position:absolute;bottom:6px;right:8px}

/* ═══════════════════════════════════════════════════════
   ROADMAP TEASER
═══════════════════════════════════════════════════════ */
.roadmap-preview{background:#101e0d;border:1px solid rgba(142,255,66,.08);border-radius:var(--r);overflow:hidden}
.rp-head{background:#142413;padding:14px 20px;display:flex;align-items:center;justify-content:space-between}
.rp-title{font-family:var(--fd);font-size:18px;font-weight:600;color:var(--t0)}
.rp-sub{font-size:12px;color:var(--sprout)}
.rp-items{padding:0}
.rp-item{display:flex;align-items:center;gap:14px;padding:13px 20px;border-bottom:1px solid rgba(142,255,66,.05);cursor:pointer;transition:background .2s}
.rp-item:last-child{border-bottom:none}
.rp-item:hover{background:rgba(142,255,66,.03)}
.rp-icon{font-size:20px;flex-shrink:0}
.rp-info{flex:1}
.rp-name{font-size:13.5px;font-weight:600;color:var(--t0);margin-bottom:2px}
.rp-desc{font-size:11.5px;color:var(--t2)}
.rp-prog{width:120px;flex-shrink:0}
.rp-bar{height:4px;background:rgba(255,255,255,.05);border-radius:2px;overflow:hidden;margin-bottom:3px}
.rp-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--fern),var(--glow))}
.rp-pct{font-family:var(--fm);font-size:9px;color:var(--glow);text-align:right}

/* ═══════════════════════════════════════════════════════
   REGISTRATION MODAL
═══════════════════════════════════════════════════════ */
#reg-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:1000;align-items:center;justify-content:center;padding:12px;box-sizing:border-box}
#reg-modal.open{display:flex;animation:fadeUp .2s ease}
.reg-box{background:#101e0d;border:1px solid rgba(142,255,66,.18);border-radius:12px;max-width:460px;width:100%;max-height:90vh;overflow-y:auto;padding:52px 24px 24px;position:relative;box-shadow:0 40px 80px rgba(0,0,0,.7)}
.reg-close{position:absolute;top:14px;right:14px;background:none;border:1px solid rgba(142,255,66,.15);color:var(--t2);width:28px;height:28px;cursor:pointer;font-size:14px;border-radius:4px;transition:all .2s;display:flex;align-items:center;justify-content:center}
.reg-close:hover{border-color:var(--glow);color:var(--glow)}
.reg-icon{font-size:32px;margin-bottom:10px}
.reg-title{font-family:var(--fd);font-size:26px;font-weight:700;color:var(--t0);margin-bottom:5px;line-height:1.2}
.reg-title em{color:var(--glow);font-style:italic;font-weight:300}
.reg-desc{font-size:13px;color:var(--t1);line-height:1.7;margin-bottom:18px}
.reg-perks{background:rgba(142,255,66,.05);border:1px solid rgba(142,255,66,.12);border-radius:6px;padding:14px 16px;margin-bottom:18px;display:flex;flex-direction:column;gap:7px}
.rp-i{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--t1)}
.rp-i::before{content:'✓';color:var(--glow);font-weight:700;flex-shrink:0;font-size:11px}
.reg-fields{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.reg-input{background:#0e1b0b;border:1px solid rgba(142,255,66,.15);color:var(--t0);padding:11px 14px;font-size:13.5px;border-radius:5px;outline:none;transition:border-color .2s;width:100%;color-scheme:dark}
.reg-input:focus{border-color:rgba(142,255,66,.35)}.reg-input::placeholder{color:var(--t2)}
.reg-cta{width:100%;padding:13px;border:none;font-weight:700;font-size:14px;cursor:pointer;border-radius:5px;transition:all .2s;margin-bottom:10px}
.rc-free{background:var(--glow);color:var(--ink)}.rc-free:hover{background:var(--sprout);transform:translateY(-1px)}
.rc-associate{background:linear-gradient(135deg,var(--gold),var(--amber));color:var(--ink)}.rc-associate:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(240,192,48,.28)}
.reg-skip{text-align:center;font-size:12px;color:var(--t2);cursor:pointer}.reg-skip:hover{color:var(--t1)}
.reg-fine{font-size:11px;color:var(--t3);text-align:center;margin-top:8px;line-height:1.5}

/* ═══════════════════════════════════════════════════════
   MISC UTILITY
═══════════════════════════════════════════════════════ */
.divider{border:none;border-top:1px solid rgba(142,255,66,.07);margin:48px 0}
.tag{display:inline-block;font-family:var(--fm);font-size:8px;letter-spacing:1.5px;text-transform:uppercase;padding:2px 8px;border-radius:3px}
.tag-g{background:rgba(142,255,66,.1);color:var(--glow);border:1px solid rgba(142,255,66,.2)}
.tag-o{background:rgba(240,192,48,.1);color:var(--gold);border:1px solid rgba(240,192,48,.2)}
.tag-b{background:rgba(62,196,232,.1);color:var(--sky);border:1px solid rgba(62,196,232,.2)}
.tag-r{background:rgba(224,68,104,.1);color:var(--rose);border:1px solid rgba(224,68,104,.2)}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--amber));color:var(--ink);border:none;padding:12px 24px;font-weight:700;font-size:13.5px;cursor:pointer;border-radius:6px;transition:all .2s;display:inline-flex;align-items:center;gap:7px}
.btn-gold:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(240,192,48,.28)}
.footnote{font-size:12px;color:var(--t2);line-height:1.65;padding:14px 18px;background:rgba(255,255,255,.02);border-radius:5px;border-left:3px solid rgba(142,255,66,.15);margin-top:14px}

/* ── ADMIN ── */
.dur-btn{padding:7px 14px;background:#131c10;border:1px solid rgba(142,255,66,.12);color:var(--t2);border-radius:4px;cursor:pointer;font-size:12.5px;transition:all .18s;font-family:var(--fb)}
.dur-btn:hover{border-color:rgba(142,255,66,.25);color:var(--t1)}
.dur-btn.on{background:rgba(142,255,66,.12);color:var(--glow);border-color:rgba(142,255,66,.3)}
.log-entry{padding:13px 18px;border-bottom:1px solid rgba(142,255,66,.05);display:flex;gap:12px;align-items:flex-start;transition:background .2s}
.log-entry:last-child{border-bottom:none}
.log-entry:hover{background:rgba(142,255,66,.03)}
.le-icon{font-size:20px;flex-shrink:0;margin-top:1px}
.le-main{flex:1;min-width:0}
.le-email{font-size:13px;font-weight:600;color:var(--t0);margin-bottom:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.le-detail{font-size:12px;color:var(--t1);line-height:1.55}
.le-note{font-size:11px;color:var(--t2);margin-top:3px;font-style:italic}
.le-time{font-family:var(--fm);font-size:9px;color:var(--t2);flex-shrink:0;white-space:nowrap;margin-top:2px}
.le-undo{background:none;border:1px solid rgba(224,68,104,.15);color:var(--rose);padding:3px 8px;border-radius:3px;cursor:pointer;font-size:10px;margin-top:6px;transition:all .18s}
.le-undo:hover{background:rgba(224,68,104,.08)}

/* ═══════════════════════════════════════════════════════
   TOAST
═══════════════════════════════════════════════════════ */
#toast{position:fixed;bottom:80px;right:16px;z-index:9000;background:var(--glow);color:var(--ink);font-weight:700;font-size:13px;padding:11px 18px;border-radius:5px;transform:translateY(60px);opacity:0;transition:all .4s cubic-bezier(.34,1.56,.64,1);box-shadow:0 5px 22px rgba(0,0,0,.5);max-width:300px;pointer-events:none}
#toast.show{transform:translateY(0);opacity:1}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE BREAKPOINTS
═══════════════════════════════════════════════════════ */
@media(max-width:1100px){
  #nl-clubhouse,#nl-roadmap,#nl-directory,#nl-about{display:none}
}
@media(max-width:820px){
  #nl-career,#nl-marketplace{display:none}
}
@media(max-width:960px){
  .hero-content{grid-template-columns:1fr;padding:0 20px;gap:32px}.hero-card{display:none}
  .tiers-grid{grid-template-columns:1fr 1fr}
  .tier:nth-child(1){border-bottom:1px solid rgba(142,255,66,.08)}.tier:nth-child(2){border-bottom:1px solid rgba(142,255,66,.08)}
  .hubs-grid{grid-template-columns:repeat(2,1fr)}
  .g3{grid-template-columns:1fr 1fr}
  .rooms-grid{grid-template-columns:1fr}
  .officer-tiers{grid-template-columns:1fr}
  .be-metrics{grid-template-columns:1fr 1fr}
}


/* ── HERO SPLIT LAYOUT ─────────────────────────────── */
.hero-eyebrow-green {
  font-family: var(--fm);
  font-size: 8.5px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--glow);
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.hero-eyebrow-gold {
  font-family: var(--fm);
  font-size: 8.5px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.eyebrow-line-green {
  display: inline-block;
  width: 28px; height: 2px;
  background: var(--glow);
  flex-shrink: 0;
}
.eyebrow-line-gold {
  display: inline-block;
  width: 28px; height: 2px;
  background: var(--gold);
  flex-shrink: 0;
}
.hero-h1 {
  font-family: var(--fd);
  font-size: clamp(28px,4vw,48px);
  font-weight: 700;
  color: #fff;
  line-height: 1.15;
  margin-bottom: 16px;
}
.hero-sub {
  font-size: 15px;
  color: rgba(240,236,226,.72);
  line-height: 1.75;
  margin-bottom: 24px;
  max-width: 420px;
}
.hero-trust {
  font-size: 11.5px;
  color: rgba(240,236,226,.45);
}
.brand-stat {
  font-family: var(--fm);
  font-size: 9px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: rgba(142,255,66,.45);
}

/* ── CORPORATE PRICING CARDS ─────────────────────────── */
.corp-card {
  background: rgba(240,192,48,.05);
  border: 1px solid rgba(240,192,48,.18);
  border-radius: 10px;
  padding: 16px 20px;
  text-align: center;
  min-width: 140px;
  position: relative;
}
.corp-card-pop {
  background: rgba(240,192,48,.10);
  border: 2px solid rgba(240,192,48,.35);
}
.corp-badge {
  position: absolute;
  top: -10px; left: 50%;
  transform: translateX(-50%);
  background: var(--gold);
  color: var(--ink);
  font-family: var(--fm);
  font-size: 8.5px;
  font-weight: 700;
  letter-spacing: 1px;
  padding: 3px 10px;
  border-radius: 10px;
  white-space: nowrap;
}
.corp-price {
  font-family: var(--fd);
  font-size: 24px;
  font-weight: 700;
  color: var(--gold);
}
.corp-price span { font-size: 13px; font-weight: 400; }
.corp-label  { font-size: 11px; color: var(--t2); margin-top: 3px; }
.corp-credits{ font-size: 10px; color: var(--t3); margin-top: 2px; }

/* ── MOBILE ─────────────────────────────────────────── */
@media(max-width:640px) {
  
  
  .hero-h1 { font-size: 28px !important; }
  .hero-sub { font-size: 14px !important; }
  .corp-card { min-width: 110px; padding: 12px 14px; }
  .corp-price { font-size: 20px; }
}

/* ══════════════════════════════════════════════════════
   LANDING PAGE — GOLD DIVIDERS + HERO SPLIT + CORP CARDS
   Added for new landing page structure
══════════════════════════════════════════════════════ */

/* Gold divider between sections */
.lp-divider {
  height: 4px;
  border: none;
  margin: 0;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(240,192,48,.12) 5%,
    rgba(240,192,48,.65) 25%,
    var(--gold) 50%,
    rgba(240,192,48,.65) 75%,
    rgba(240,192,48,.12) 95%,
    transparent 100%);
}

/* Hero two-column split */
.hero-eyebrow-green {
  font-family: var(--fm);
  font-size: 8.5px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--glow);
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.hero-eyebrow-gold {
  font-family: var(--fm);
  font-size: 8.5px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.eyebrow-line-green {
  display: inline-block;
  width: 28px; height: 2px;
  background: var(--glow);
  flex-shrink: 0;
}
.eyebrow-line-gold {
  display: inline-block;
  width: 28px; height: 2px;
  background: var(--gold);
  flex-shrink: 0;
}
.hero-h1 {
  font-family: var(--fd);
  font-size: clamp(28px,4vw,48px);
  font-weight: 700;
  color: #fff;
  line-height: 1.15;
  margin-bottom: 16px;
}
.hero-sub {
  font-size: 15px;
  color: rgba(240,236,226,.72);
  line-height: 1.75;
  margin-bottom: 24px;
  max-width: 420px;
}
.hero-trust {
  font-size: 11.5px;
  color: rgba(240,236,226,.45);
}
.brand-stat {
  font-family: var(--fm);
  font-size: 9px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: rgba(142,255,66,.45);
}

/* Corporate pricing cards */
.corp-card {
  background: rgba(240,192,48,.05);
  border: 1px solid rgba(240,192,48,.18);
  border-radius: 10px;
  padding: 16px 20px;
  text-align: center;
  min-width: 140px;
  position: relative;
}
.corp-card-pop {
  background: rgba(240,192,48,.10);
  border: 2px solid rgba(240,192,48,.35);
}
.corp-badge {
  position: absolute;
  top: -10px; left: 50%;
  transform: translateX(-50%);
  background: var(--gold);
  color: var(--ink);
  font-family: var(--fm);
  font-size: 8.5px;
  font-weight: 700;
  letter-spacing: 1px;
  padding: 3px 10px;
  border-radius: 10px;
  white-space: nowrap;
}
.corp-price {
  font-family: var(--fd);
  font-size: 24px;
  font-weight: 700;
  color: var(--gold);
}
.corp-price span { font-size: 13px; font-weight: 400; }
.corp-label  { font-size: 11px; color: var(--t2); margin-top: 3px; }
.corp-credits{ font-size: 10px; color: var(--t3); margin-top: 2px; }

/* Mobile overrides */
@media(max-width:640px) {
  
  
  .hero-h1 { font-size: 26px !important; }
  .hero-sub { font-size: 13.5px !important; }
  .corp-card { min-width: 100px; padding: 12px 10px; }
  .corp-price { font-size: 20px; }
  .corp-badge { font-size: 7.5px; }

  .hero-split-grid {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
    padding-top: 32px !important;
  }
  .hero-right-col {
    border-left: none !important;
    border-top: 1px solid rgba(142,255,66,.1) !important;
    padding-left: 0 !important;
    padding-top: 24px !important;
  }}
@media(min-width:641px) and (max-width:960px) {
  
  .hero-h1 { font-size: 32px; }
}

/* ── HERO SPLIT LAYOUT ─────────── */



/* ── HERO SPLIT LAYOUT ─────────────────────────────── */
.hero-split-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
  padding-top: 72px;
}
.hero-right-col {
  border-left: 1px solid rgba(142,255,66,.12);
  padding-left: 48px;
}

@media(min-width:641px) and (max-width:960px) {
  .hero-split-grid { gap: 32px; padding-top: 52px; }
}

/* ── PREMIUM HOT GIP CARD ─────────────────────────── */
.gip-card.premium-card {
  border:1px solid rgba(240,192,48,.35) !important;
  background:linear-gradient(135deg,#0f1c0a,#1c1800) !important;
  position:relative;
}
.gip-card.premium-card::before {
  content:'🔥 HIGH VALUE';
  position:absolute;top:0;right:0;
  font-family:var(--fm);font-size:7px;letter-spacing:1.5px;
  background:var(--gold);color:var(--ink);
  padding:3px 10px;border-radius:0 12px 0 6px;font-weight:700;
  z-index:2;
}
.gip-card.premium-card .gip-band {
  background:linear-gradient(90deg,var(--gold),var(--amber)) !important;
}
.gip-card.premium-card .gip-title { color:var(--gold) !important; }
.gip-card.premium-card .gip-buy-btn {
  background:var(--gold) !important;color:var(--ink) !important;
}

/* ── GIP GRID ──────────────────────────────────────── */
.gip-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  align-items: start;
}
@media(max-width:1024px) { .gip-grid { grid-template-columns: repeat(2,1fr); } }
@media(max-width:640px)  { .gip-grid { grid-template-columns: 1fr !important; } }

/* ── GIP CARD BODY ──────────────────────────────── */
.gip-card { min-height:300px; }
.gip-body { padding:16px;box-sizing:border-box;min-width:0; }
.gip-footer { display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:nowrap;min-width:0;margin-top:auto;padding-top:12px;border-top:1px solid rgba(142,255,66,.06); }
.gip-price-block { min-width:0;flex-shrink:1; }
.gip-buy-btn { flex-shrink:0;white-space:nowrap; }
.gip-title { word-break:break-word;overflow-wrap:anywhere;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;min-height:3.9em; }
.gip-desc-line { display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.6em; }
@media(max-width:640px) {
  .gip-body { padding:12px; }
  .gip-metrics-strip { flex-wrap:wrap; }
  .gm-strip { flex:1;min-width:56px; }
  .gip-buy-btn { font-size:12px;padding:8px 12px; }
}

.gip-status-badge.gs-rb{background:rgba(70,190,224,.1);color:#46bee0;border:1px solid rgba(70,190,224,.25)}
.gip-status-badge.gs-cbd{background:rgba(142,255,66,.08);color:var(--sprout);border:1px solid rgba(142,255,66,.15)}
.gip-status-badge.gs-cb{background:rgba(168,108,232,.1);color:#a86ce8;border:1px solid rgba(168,108,232,.25)}

.gip-status-badge.gs-rb,.gip-status.gs-rb{background:rgba(70,190,224,.1);color:#46bee0;border:1px solid rgba(70,190,224,.3)}
.gip-status-badge.gs-cb,.gip-status.gs-cb{background:rgba(168,108,232,.1);color:#a86ce8;border:1px solid rgba(168,108,232,.3)}

  /* ── OFFICER CHAT MODAL ──────────────────────────────── */
  #officer-chat-modal {
    display:none; position:fixed; inset:0; z-index:2000;
    background:rgba(0,0,0,.75); backdrop-filter:blur(4px);
    align-items:flex-end; justify-content:center;
  }
  #officer-chat-modal.open { display:flex; }
  .ocm-sheet {
    background:#0d1a0b; border-top:2px solid rgba(142,255,66,.2);
    border-radius:16px 16px 0 0; width:100%; max-width:720px;
    height:90vh; display:flex; flex-direction:column;
    box-shadow:0 -8px 40px rgba(0,0,0,.6);
  }
  .ocm-header {
    display:flex; align-items:center; gap:12px;
    padding:16px 20px 12px; border-bottom:1px solid rgba(142,255,66,.1);
    flex-shrink:0;
  }
  .ocm-avatar { font-size:28px; flex-shrink:0; }
  .ocm-title  { flex:1; }
  .ocm-title strong { font-size:15px; color:#fff; font-family:var(--fd); }
  .ocm-title span   { display:block; font-size:11px; color:var(--t2); margin-top:2px; }
  .ocm-credits  { font-size:10.5px; color:rgba(255,255,255,.3); margin-left:auto;
                  padding:3px 10px; background:rgba(255,255,255,.04);
                  border-radius:20px; white-space:nowrap; flex-shrink:0; }
  .ocm-credits.low { color:var(--gold); background:rgba(240,192,48,.08); }
  .ocm-close {
    background:rgba(255,255,255,.08); border:none; color:var(--t1);
    width:32px; height:32px; border-radius:50%; font-size:16px;
    cursor:pointer; display:flex; align-items:center; justify-content:center;
    flex-shrink:0; transition:background .2s;
  }
  .ocm-close:hover { background:rgba(255,255,255,.15); }
  .ocm-msgs {
    flex:1; overflow-y:auto; padding:20px 16px;
    display:flex; flex-direction:column; gap:16px;
    -webkit-overflow-scrolling:touch;
  }
  .ocm-msg-user {
    display:flex; gap:10px; justify-content:flex-end;
  }
  .ocm-msg-user .ocm-bubble {
    background:rgba(142,255,66,.1); border:1px solid rgba(142,255,66,.2);
    border-radius:16px 16px 4px 16px; padding:12px 16px;
    font-size:14px; color:var(--t0); max-width:80%; line-height:1.65;
  }
  .ocm-msg-ai { display:flex; gap:10px; align-items:flex-start; }
  .ocm-msg-ai .ocm-av {
    font-size:22px; flex-shrink:0; width:36px; height:36px;
    background:rgba(142,255,66,.08); border-radius:50%;
    display:flex; align-items:center; justify-content:center;
  }
  .ocm-msg-ai .ocm-bubble {
    background:#101e0d; border:1px solid rgba(142,255,66,.12);
    border-radius:4px 16px 16px 16px; padding:14px 16px;
    font-size:14px; color:var(--t0); line-height:1.75;
    max-width:90%; white-space:pre-wrap;
  }
  .ocm-msg-ai .ocm-bubble strong { color:var(--glow); }
  .ocm-typing { display:flex; gap:5px; align-items:center; padding:4px 0; }
  .ocm-typing span {
    width:7px; height:7px; border-radius:50%;
    background:var(--glow); opacity:.4; animation:ocmPulse 1.2s infinite;
  }
  .ocm-typing span:nth-child(2) { animation-delay:.2s; }
  .ocm-typing span:nth-child(3) { animation-delay:.4s; }
  @keyframes ocmPulse { 0%,100%{opacity:.3;transform:scale(.8)} 50%{opacity:1;transform:scale(1.1)} }
  .ocm-input-bar {
    display:flex; gap:10px; padding:12px 16px 20px;
    border-top:1px solid rgba(142,255,66,.08); flex-shrink:0;
    padding-bottom:max(20px, env(safe-area-inset-bottom));
  }
  .ocm-input {
    flex:1; background:#0a1208; border:1px solid rgba(142,255,66,.2);
    border-radius:24px; padding:11px 18px; color:#fff; font-size:14px;
    font-family:inherit; outline:none; resize:none;
  }
  .ocm-input:focus { border-color:rgba(142,255,66,.4); }
  .ocm-send {
    background:var(--glow); color:var(--ink); border:none;
    border-radius:24px; padding:11px 20px; font-weight:700;
    font-size:13px; cursor:pointer; white-space:nowrap;
    font-family:var(--fb); flex-shrink:0;
  }
  .ocm-toolbar {
    display:flex; align-items:center; gap:8px;
    padding:8px 16px; border-bottom:1px solid rgba(142,255,66,.06);
    background:rgba(0,0,0,.15); flex-shrink:0; flex-wrap:wrap;
  }
  .ocm-tool-btn {
    background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1);
    color:rgba(255,255,255,.6); padding:5px 12px; border-radius:20px;
    font-size:11.5px; cursor:pointer; font-family:var(--fb);
    transition:all .2s; white-space:nowrap;
  }
  .ocm-tool-btn:hover { background:rgba(142,255,66,.1); border-color:rgba(142,255,66,.3); color:var(--glow); }
  .ocm-tool-btn.saved { background:rgba(142,255,66,.12); border-color:rgba(142,255,66,.3); color:var(--glow); }
  .ocm-session-status {
    font-size:11px; color:rgba(255,255,255,.3); margin-left:auto;
    white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:160px;
  }
  .ocm-upgrade {
    margin:8px 0; padding:12px 16px;
    background:rgba(240,192,48,.08); border:1px solid rgba(240,192,48,.2);
    border-radius:10px; text-align:center; font-size:12.5px; color:var(--t1);
  }
  .ocm-upgrade button {
    background:var(--gold); color:var(--ink); border:none;
    padding:8px 18px; border-radius:6px; font-weight:700;
    font-size:12px; cursor:pointer; margin-top:8px; font-family:var(--fb);
  }

  .gip-status{font-family:var(--fm);font-size:8px;letter-spacing:1px;text-transform:uppercase;padding:2px 7px;border-radius:3px;white-space:nowrap}

/* ── Career tab: input method cards (matching non-member page) ── */
.cc-imc{display:flex;align-items:center;gap:12px;padding:12px 14px;background:#101e0d;border:1px solid rgba(142,255,66,.1);border-radius:8px;cursor:pointer;transition:all .2s}
.cc-imc.on{background:#162813;border-color:rgba(142,255,66,.35);box-shadow:0 0 0 1px rgba(142,255,66,.2)}
.cc-imc:hover:not(.on){background:#131f11;border-color:rgba(142,255,66,.2)}
/* Career Luma chat */
#cc-luma-career-chat{scrollbar-width:thin;max-height:320px;overflow-y:auto}

/* ── Directory inline cards ── */
.cc-dir-card{background:var(--cc-card);border:1px solid var(--cc-border);border-radius:10px;padding:14px;transition:border-color .2s}
.cc-dir-card:hover{border-color:rgba(142,255,66,.22)}

/* ── VIRTUAL CLUB — rich room links (Ecopreneur) ── */
.cc-room-rich{
  display:flex;gap:12px;padding:14px 16px;
  background:rgba(142,255,66,.05);border:1px solid rgba(142,255,66,.12);
  border-radius:9px;cursor:pointer;text-decoration:none;
  transition:all .2s;
}
.cc-room-rich:hover{
  border-color:rgba(142,255,66,.3);
  background:rgba(142,255,66,.08);
  transform:translateY(-1px);
}

/* ── BULLETIN ACTIVE indicator — shown in feed when officer has live bulletin ── */
.cc-bulletin-live-badge{
  display:inline-flex;align-items:center;gap:4px;
  font-family:var(--fm);font-size:8.5px;letter-spacing:.5px;
  color:rgba(142,255,66,.7);background:rgba(142,255,66,.06);
  border:1px solid rgba(142,255,66,.15);border-radius:20px;
  padding:2px 7px;flex-shrink:0;
}
.cc-bulletin-live-dot{
  width:5px;height:5px;border-radius:50%;
  background:var(--glow);box-shadow:0 0 4px var(--glow);
  animation:cc-pulse-dot 2s infinite;
}

/* ── INLINE CHAT PANEL — contains the OCM chat inside the CC panel ── */
/* The inline chat reuses ocm-* classes from index.html for the message bubbles.
   These rules handle the panel-level layout within the CC grid. */
#cc-inline-chat{
  display:none;
  flex-direction:column;
  height:100%;
  min-height:440px;
}
#cc-inline-chat .ocm-msgs{
  flex:1;
  min-height:200px;
  max-height:calc(100vh - 340px);
}
/* On mobile: more height for the message area */
@media(max-width:767px){
  #cc-inline-chat .ocm-msgs{
    max-height:calc(100vh - 280px);
    min-height:240px;
  }
  #cc-inline-chat .ocm-input-bar{
    padding-bottom:max(14px, env(safe-area-inset-bottom, 10px));
  }
}

/* ── CC PANEL HEADER (title + subtitle + optional action) ── */
.cc-panel-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 14px 10px;border-bottom:1px solid rgba(142,255,66,.07);
  flex-shrink:0;gap:10px;
}
.cc-panel-title{font-family:var(--fd);font-size:15px;font-weight:700;color:var(--t0);line-height:1.2}
.cc-panel-sub{font-size:10.5px;color:var(--t2);margin-top:1px}

/* ── GIP WORKSHOP — publish / version forms ── */
.cc-pub-form,.cc-ver-form{
  background:rgba(142,255,66,.04);
  border:1px solid rgba(142,255,66,.18);
  border-radius:8px;padding:14px;margin-top:10px;
}
.cc-pub-form input,.cc-pub-form textarea,
.cc-ver-form input,.cc-ver-form textarea{
  width:100%;background:#0a1509;
  border:1px solid rgba(142,255,66,.15);border-radius:6px;
  padding:8px 10px;color:var(--t0);font-family:var(--fb);font-size:12.5px;
  outline:none;margin-bottom:8px;box-sizing:border-box;
  transition:border-color .18s;
}
.cc-pub-form input:focus,.cc-pub-form textarea:focus,
.cc-ver-form input:focus,.cc-ver-form textarea:focus{
  border-color:rgba(142,255,66,.35);
}
.cc-pub-form textarea,.cc-ver-form textarea{resize:none;line-height:1.6}

/* ── GIP buyer/seller earnings card ── */
.cc-earnings-card{
  background:rgba(240,192,48,.07);
  border:1px solid rgba(240,192,48,.15);
  border-radius:6px;padding:9px 12px;margin-bottom:8px;
}

/* ── Assessment question progress ── */
.cc-assessment-q{
  background:var(--cc-card);border:1px solid var(--cc-border);
  border-radius:8px;padding:14px;margin-bottom:8px;
}
.cc-assessment-q.selected{
  border-color:rgba(142,255,66,.35);
  background:rgba(142,255,66,.04);
}
.cc-assessment-opt{
  display:flex;align-items:flex-start;gap:10px;
  padding:9px 11px;border-radius:6px;cursor:pointer;
  border:1px solid rgba(142,255,66,.1);background:#0a1509;
  margin-bottom:6px;font-size:12.5px;color:var(--t1);
  transition:all .18s;
}
.cc-assessment-opt:hover{border-color:rgba(142,255,66,.28);background:#0d1a0b}
.cc-assessment-opt.on{border-color:rgba(142,255,66,.4);background:rgba(142,255,66,.07);color:var(--t0)}

/* ── Directory hub filter pills ── */
.cc-dir-hub-pill{
  background:rgba(142,255,66,.04);border:1px solid rgba(142,255,66,.1);
  color:var(--t2);border-radius:20px;padding:4px 11px;
  font-size:11px;font-family:var(--fb);cursor:pointer;
  transition:all .18s;white-space:nowrap;flex-shrink:0;
}
.cc-dir-hub-pill.on{
  background:rgba(142,255,66,.12);border-color:rgba(142,255,66,.4);color:var(--glow);
}

/* ── GIP delist notice ── */
.cc-delist-notice{
  background:rgba(220,38,38,.08);border:1px solid rgba(220,38,38,.25);
  border-radius:6px;padding:9px 12px;margin:8px 0;
  font-size:12px;color:#f87171;line-height:1.55;
}

/* ── CC CARD (member-mode generic card) ── */
.cc-card{
  background:var(--cc-card);border:1px solid var(--cc-border);
  border-radius:10px;padding:14px;margin-bottom:8px;
  position:relative;overflow:hidden;transition:border-color .2s;
}
.cc-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:rgba(142,255,66,.15);
}
.cc-card:hover{border-color:var(--cc-border-h)}

/* ── CC INLINE CHAT: autosize textarea ── */
#ocm-input{min-height:44px;max-height:120px;overflow-y:auto}

/* ── Feed session strip (compact) ── */
.cc-feed-session{
  display:flex;align-items:center;gap:8px;padding:8px 10px;
  background:rgba(142,255,66,.03);border:1px solid rgba(142,255,66,.08);
  border-radius:7px;cursor:pointer;transition:all .18s;margin-bottom:5px;
}
.cc-feed-session:hover{border-color:rgba(142,255,66,.2);background:rgba(142,255,66,.06)}
.cc-feed-session-dot{font-size:14px;flex-shrink:0}
.cc-feed-session-name{font-size:12px;color:var(--t0);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}
.cc-feed-session-meta{font-size:10px;color:var(--t2);flex-shrink:0}

/* ── Sessions panel — full session cards ── */
.cc-session{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;background:var(--cc-card);
  border:1px solid var(--cc-border);border-radius:9px;
  cursor:pointer;transition:all .18s;margin-bottom:7px;
}
.cc-session:hover{border-color:rgba(142,255,66,.25);background:rgba(142,255,66,.04)}
.cc-session-dot{font-size:18px;flex-shrink:0}
.cc-session-name{
  font-size:12.5px;font-weight:600;color:var(--t0);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  margin-bottom:3px;
}
.cc-session-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.cc-session-date{font-family:var(--fm);font-size:9.5px;color:var(--t2)}
.cc-session-acts{display:flex;gap:4px;flex-shrink:0;margin-left:auto}

