/* CultureCore — Light Theme (White + Purple, Refined & Unified) */
:root{
  /* Palette */
  --bg:#ffffff;
  --ink:#160f2c;
  --ink-2:#31255a;
  --muted:#6550a8;

  --brand-50:#faf7ff;
  --brand-100:#f2eaff;
  --brand-200:#e6d5ff;
  --brand-300:#d1b4ff;
  --brand-400:#b888ff;
  --brand-500:#984cff;
  --brand-600:#7a2dff;
  --brand-700:#5a19db;
  --brand-800:#4315a8;
  --brand-900:#2a0f6d;

  /* Surfaces */
  --panel:#ffffff;
  --panel-brd:#ebe6ff;

  /* Effects */
  --ring: rgba(122,45,255,.32);
  --shadow-1:0 6px 18px rgba(122,45,255,.10);
  --shadow-2:0 10px 28px rgba(122,45,255,.12);

  /* Shape */
  --radius:12px;
  --radius-lg:16px;
  --radius-xl:22px;
}

/* ---------- Global ---------- */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{overflow-x:clip}
body{
  margin:0;
  font-family:"Outfit", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial;
  color:var(--ink);
  background:var(--bg);
  font-size:16px;
  line-height:1.6;
}

.fa-light {
  margin-right: 4px;
}

/* A11y helper */
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ---------- Layout ---------- */
.ccn-container{max-width:1200px;width:100%;margin-inline:auto;padding-inline:clamp(16px,4vw,36px)}

/* ---------- Header ---------- */
.ccn-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.5);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--panel-brd);
}
.ccn-header-inner{display:flex;align-items:center;gap:1rem;padding:14px 0}
.ccn-logo{height:36px;display:block}
.ccn-brand{display:flex;align-items:center;gap:.5rem;text-decoration:none;color:var(--ink);font-weight:700}

/* Primary nav */
.ccn-nav{display:flex;gap:1rem;margin-left:auto;}
.ccn-nav-link{
  padding:8px 12px;border-radius:0px;
  text-decoration:none;color:var(--ink);
  font-weight:600;text-transform:uppercase;font-size:14px;
}
.ccn-nav-link:hover{color:var(--brand-800);background:var(--brand-50)}
.ccn-nav-link.is-active{color:#fff;background:linear-gradient(135deg,var(--brand-700),var(--brand-500))}

/* ---------- Buttons ---------- */
.ccn-actions{display:flex;gap:1rem;align-items:center}
.ccn-btn{
  --pad-x:12px;--pad-y:8px;
  display:inline-flex;align-items:center;justify-content:center;
  padding:var(--pad-y) var(--pad-x);
  text-decoration:none;border:1px solid transparent;
  font-weight:600;font-size:14px;text-transform:uppercase;
  cursor:pointer;transition:transform .06s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
}
.ccn-btn:hover{transform:translateY(-1px)}
.ccn-btn:focus-visible{outline:3px solid var(--ring);outline-offset:2px}
.ccn-btn--primary{background:linear-gradient(135deg,var(--brand-700),var(--brand-500));color:#fff;box-shadow:var(--shadow-1)}
.ccn-btn--ghost{background:#fff;color:var(--brand-800);border:1px solid var(--panel-brd)}
.ccn-btn--outline{background:#fff;color:var(--brand-800);border:1px solid var(--brand-200)}
.ccn-btn--bare{background:transparent;color:var(--brand-700);padding:8px 12px;font-weight:600}
.ccn-btn--lg{--pad-x:20px;--pad-y:12px;border-radius:0px;font-size:18px}
.ccn-btn-join{width: 100%; margin-top: 18px;}
.ccn-btn-plans{padding-top: 1rem;}

/* ---------- Hero ---------- */
.ccn-hero{position:relative;padding:48px 0 48px;background:#fff}
.ccn-hero-inner{text-align:center;position:relative;z-index:2}
.ccn-hero-overline{
  display:inline-block;padding:6px 12px;border-radius:999px;
  background:var(--brand-50);color:var(--brand-800);
  font-weight:600;letter-spacing:.12em;text-transform:uppercase;font-size:.8rem;
}

.ccn-cta-row{
  display: flex;
  justify-content: center;
  gap: 1rem;
  margin: 1rem;
}
.ccn-hero-title{
  margin: 12px 0 12px; font-weight: 800; text-transform: uppercase; font-size: 5rem;
}
.ccn-gradient{background:linear-gradient(90deg,var(--brand-600),var(--brand-400));-webkit-background-clip:text;background-clip:text;color:transparent}
.ccn-hero-sub{color:var(--ink-2);font-weight:500;font-size: 18px;}
.ccn-hero-sub--bold{color:var(--brand-900);font-weight:600}
.ccn-hero-furniture{margin-top:14px;display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}
.chip{padding: 8px 12px; border-radius: 0; border: 1px dashed var(--brand-300); color: var(--brand-900); background: #fff; font-weight: 500; font-size: 14px;}

/* Decorative */
.ccn-hero-glow{position:absolute;left:0;right:0;top:-32px;height:220px;margin:0 auto;background:radial-gradient(520px 180px at 50% 20%, rgba(152,76,255,.22), transparent 65%);filter:blur(12px);z-index:1}
.ccn-hero-grid{position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px, rgba(122,45,255,.10) 1px, transparent 1px);background-size:22px 22px;mask-image: radial-gradient(80% 70% at 50% 0%, #000 50%, transparent 100%);opacity:.24}

/* ---------- Video band ---------- */
.ccn-video-wrap{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;background:#000}
.ccn-video-el{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ccn-video-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,0) 0%,rgba(255,255,255,.35) 60%,#fff 100%)}
.ccn-video-content{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-start;padding:0 clamp(16px,5vw,40px) clamp(22px,6vw,48px)}
.ccn-video-title{margin:0;font-size:48px;font-weight:800;color:var(--brand-900)}
.ccn-video-sub{margin:12px 0 12px;color:var(--ink-2);font-weight:600;font-size:18px;}
.ccn-video-cta{display:flex;gap:1rem;flex-wrap:wrap}

/* ---------- Divider ---------- */
.ccn-rule{width:min(1120px,96vw);margin:18px auto 18px;border:none;height:1px;background:linear-gradient(90deg,transparent,var(--brand-200),transparent)}

/* ---------- Sections ---------- */
.ccn-section{padding:26px 0 34px}

/* Toolbar (Overview only) */
.ccn-toolbar{display:flex;gap:.5rem;background:#fff;border:1px solid var(--panel-brd);padding:6px;border-radius:999px;width:fit-content}
.ccn-tab{appearance:none;background:transparent;border:0;color:var(--muted);font-weight:600;padding:8px 12px;border-radius:999px;cursor:pointer;text-transform:uppercase;font-size:.85rem}
.ccn-tab.is-active{background:var(--brand-50);color:var(--brand-900);border:1px solid var(--brand-200);padding: 8px 16px; font-size: 14px; border-radius: 999px;}

/* ---------- KPIs ---------- */
.ccn-kpis{margin-top:18px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.kpi-card{background:#fff;border:1px solid var(--panel-brd);border-radius:0px;padding:18px 18px;box-shadow:var(--shadow-2);opacity:0;transform:translateY(10px);transition:.5s ease}
.kpi-card.reveal-in{opacity:1;transform:none}
.kpi-num{margin:0;font-weight:800;font-size:34px;color:var(--brand-900);}
.kpi-label{margin:8px 0 0;color:var(--muted);font-weight:600;text-transform:uppercase;font-size:14px;}
.kpi-note{margin:.5rem 0 0;color:var(--ink-2);font-weight:500;font-size:14px}

/* ---------- Onboarding ---------- */
.ccn-section-head{margin:0 0 18px;display:flex;align-items:center;justify-content:space-between;gap:.75rem}
.ccn-overline{letter-spacing:.14em;text-transform:uppercase;color:var(--brand-900);font-weight:700;font-size:.86rem}
.ccn-head-actions{display:flex;gap:.5rem}

.feature-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;}
.feature-card{background:#fff;border:1px solid var(--panel-brd);border-radius:0px;padding:18px 18px;box-shadow:var(--shadow-1);opacity:0;transform:translateY(10px);transition:.5s ease}
.feature-card.reveal-in{opacity:1;transform:none}
.feature-card--accent{border-color:var(--brand-200);box-shadow:0 0 0 2px var(--brand-50) inset}
.feature-title{margin:0 0 8px;font-size:18px;font-weight:700;color:var(--brand-900);text-transform:uppercase;}
.feature-list{margin:0;display:grid;gap:8px;color:var(--ink-2);font-weight:500}
.feature-body{color:var(--ink-2);margin:6px 0 10px;font-weight:500}
.feature-furniture{display:flex;flex-wrap:wrap;gap:.4rem}
.pill{padding:6px 10px;border-radius:999px;background:var(--brand-50);border:1px solid var(--brand-200);color:var(--brand-900);font-weight:600;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase}

/* ---------- WHY JOIN ---------- */
.ccn-section--why{background:linear-gradient(180deg,#fff,var(--brand-50))}
.ccn-title{font-size:48px;font-weight:800;text-transform:uppercase;margin: 0;}
.ccn-now{background:linear-gradient(90deg,var(--brand-700),var(--brand-500));-webkit-background-clip:text;background-clip:text;color:transparent}

.why-cards{margin-top:18px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}
.why-card{position:relative;background:#fff;border:1px solid var(--brand-200);padding:18px 18px;box-shadow:var(--shadow-1);opacity:0;transform:translateY(10px);transition:.5s ease, box-shadow .2s ease, transform .12s ease}
.why-card.reveal-in{opacity:1;transform:none}
.why-card:hover{box-shadow:0 14px 30px rgba(122,45,255,.16);transform:translateY(-1px)}
.why-ribbon{position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--brand-600),var(--brand-400));}
.why-line{font-weight:700;color:var(--brand-900);text-transform:uppercase;font-size:14px;margin: 0;}

/* ---------- Groups ---------- */
.groups-tools{display:flex;gap:.5rem;align-items:center;justify-content:flex-end;margin-top:10px}
.groups-filter{
  flex:1 1 auto;min-width:240px;
  background:#fff;border:1px solid var(--panel-brd);padding:8px 12px;
  font:inherit;color:var(--ink-2)
}
.groups-grid{margin-top:18px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}
.group-card{position:relative;background:#fff;border:1px solid var(--panel-brd);border-radius:0;padding:18px;box-shadow:var(--shadow-1);opacity:0;transform:translateY(10px);transition:.5s ease, box-shadow .2s ease, transform .12s ease}
.group-card.reveal-in{opacity:1;transform:none}
.group-card:hover{box-shadow:0 14px 30px rgba(122,45,255,.16);transform:translateY(-1px)}
.group-ribbon{position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--brand-600),var(--brand-400));}
.group-head{display:flex;align-items:center;justify-content:space-between;}
.group-title{margin:0;font-size:14px;font-weight:700;color:var(--brand-900);text-transform:uppercase;}
.group-toggle{appearance:none;background:#fff;color:var(--brand-800);border:1px solid var(--brand-200);padding:8px 12px;border-radius:0;font-weight:600;cursor:pointer;text-transform:uppercase;font-size:.78rem;}
.group-body{display:none;padding:16px 0 0 0;color:var(--ink-2);font-weight:500}
.group-body p{font-size: 14px;}
.group-card.is-open .group-body{display:block}
.group-actions{margin-top:10px;display:flex;gap:.5rem;flex-wrap:wrap}

/* ---------- Footer ---------- */
.ccn-footer{margin-top:26px;border-top:1px solid var(--panel-brd);background:#faf7ff}
.ccn-footer-inner{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:18px 0}
.ccn-logo--sm{height:28px;display:block;margin-bottom:8px}
.ccn-footer-copy{color:var(--ink-2);max-width:600px;margin:0;font-weight:500;font-size:14px}
.ccn-footer-links{display:flex;gap:.75rem;flex-wrap:wrap}
.ccn-footer-links a{color:var(--brand-800);text-decoration:none;font-weight:600;text-transform:uppercase;font-size:14px}
.ccn-footer-links a:hover{text-decoration:underline}

/* ---------- Reveal Utility ---------- */
.reveal{opacity:0;transform:translateY(10px)}
.reveal.reveal-in{opacity:1;transform:none;transition:.5s ease}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .ccn-nav{display:none}
  .groups-grid{grid-template-columns:1fr}
}
@media (max-width:820px){
  .ccn-kpis{grid-template-columns:1fr 1fr}
  .why-cards{grid-template-columns:1fr 1fr}
}
@media (max-width:520px){
  .feature-grid{grid-template-columns:1fr}
  .why-cards{grid-template-columns:1fr}
  .ccn-btn--lg{width:100%}
  .ccn-header-inner{display:flex;align-items:center;gap:1rem;padding:14px;justify-content: space-between;}
  .ccn-footer-inner { display: flex ; align-items: flex-start; justify-content: space-between; gap: 1rem; padding: 18px; flex-direction: column; }
  .btn-collapse{display: none;}
  .ccn-video-cta{display:flex;gap:1rem;width: 100%; display: flex ; flex-direction: row; flex-wrap: nowrap; }
  .ccn-video{height: 512px;}
  .ccn-video-wrap{height: 512px;}
  .ccn-video-el{height: 512px;}
  .ccn-video-overlay{height: 512px;}
  .ccn-video-content .ccn-container{height: 512px;}
  .ccn-disconnect-nav{display: none;}
  .ccn-logo{height: 28px!important;}
  .ccn-cta-row {
      display: flex;
      justify-content: center;
      gap: 1rem;
      margin: 1rem 0;
  }
  .ccn-hero-title{
    margin: 12px 0 12px; font-weight: 800; text-transform: uppercase; font-size: 48px;
  }
}


