/* =====================
   THEME VARIABLES
   ===================== */
:root {
  /* Dark Theme (Default) */
  --bg: #0b0b0b;
  --card: #151515;
  --border: #262626;
  --text: #ffffff;
  --text-secondary: #a1a1a1;
  --accent: #ffffff;
  --glow-shadow: 0 0 20px rgba(255, 255, 255, 0.05);
}

.light-mode {
  /* Light Theme */
  --bg: #ffffff;
  --card: #f5f5f5;
  --border: #e5e5e5;
  --text: #111111;
  --text-secondary: #666666;
  --accent: #000000;
  --glow-shadow: 0 0 20px rgba(0, 0, 0, 0.05);
}

/* =====================
   GLOBAL
   ===================== */

*{
margin:0;
padding:0;
box-sizing:border-box;
font-family:'Inter', sans-serif;
}

body{
background:var(--bg);
color:var(--text);
overflow:visible;
transition: background 0.3s ease, color 0.3s ease;
}

.container{
display:flex;
}


/* SIDEBAR */

.sidebar{
width:76px;
background:var(--bg);
padding:40px 14px;
border-right:1px solid var(--border);
position:fixed;
top:0;
left:0;
height:100vh;
overflow-y:auto;
overflow-x:hidden;
white-space:nowrap;
display:flex;
flex-direction:column;
justify-content:center;
z-index:100;
transition:width 0.4s cubic-bezier(0.16, 1, 0.3, 1), background 0.3s ease, border-color 0.3s ease;
}

.sidebar:hover{
width:230px;
}

.logo{
font-size:22px;
margin-bottom:30px;
}

.sidebar ul{
list-style:none;
}

.sidebar li{
margin:8px 0;
color:var(--text-secondary);
cursor:pointer;
border-radius:12px;
transition:all 0.3s ease;
}

.sidebar li a{
display:flex;
align-items:center;
padding:12px 14px;
color:inherit;
text-decoration:none;
}

.sidebar li i{
font-size:18px;
width:20px;
text-align:center;
flex-shrink:0;
transition:color 0.3s ease;
}

.sidebar li span{
opacity:0;
margin-left:18px;
transition:opacity 0.3s ease, transform 0.3s ease;
transform:translateX(-10px);
font-weight:500;
}

.sidebar:hover li span{
opacity:1;
transform:translateX(0);
}

.sidebar li:hover,
.sidebar li.active{
background:var(--card);
color:var(--text);
}

.sidebar li:hover i,
.sidebar li.active i{
color:var(--accent);
}

/* Theme Toggle Button */
.theme-toggle {
  position: fixed;
  top: 30px;
  right: 30px;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--bg);
  border: 1px solid var(--border);
  color: var(--text-secondary);
  font-size: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 1000;
  transition: all 0.3s ease;
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
}
.theme-toggle:hover {
  background: var(--card);
  color: var(--text);
  transform: translateY(-2px);
}


/* MAIN */

.main{
flex:1;
padding:40px;
margin-left:76px;
min-height:100vh;
overflow-y:visible;
scroll-behavior:smooth;
transition:margin-left 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

/* When sidebar hovered, optionally push main or let it overlap. The prompt says "main content should resize automatically" so we adjust margin */
.sidebar:hover ~ .main{
margin-left:230px;
}

.main::-webkit-scrollbar{
width:5px;
}
.main::-webkit-scrollbar-track{
background:transparent;
}
.main::-webkit-scrollbar-thumb{
background:var(--border);
border-radius:10px;
}

.main h1{
font-size:32px;
margin-bottom:30px;
}


/* CARDS */

.cards{
display:grid;
grid-template-columns:repeat(2,1fr);
gap:25px;
}

.card{
background:var(--card);
padding:50px;
border-radius:16px;
text-align:center;
font-size:18px;
transition:0.3s;
border:1px solid var(--border);
}


.card:hover{
transform:translateY(-8px) scale(1.02);
box-shadow:var(--glow-shadow);
border:1px solid var(--accent);
transition:0.3s;
}
/* TOP BAR */

.topbar{
display:flex;
justify-content:space-between;
align-items:center;
margin-bottom:30px;
}

.btn{
background:transparent;
border:1px solid var(--accent);
color:var(--accent);
padding:10px 20px;
border-radius:10px;
cursor:pointer;
transition:0.3s;
}

.btn:hover{
background:var(--accent);
color:var(--bg);
}


/* STATS */

.stats{
display:grid;
grid-template-columns:repeat(4,1fr);
gap:20px;
margin-bottom:30px;
}

.stat{
background:var(--card);
padding:25px;
border-radius:14px;
border:1px solid var(--border);
text-align:center;
transition:0.3s;
}

.stat:hover{
box-shadow:var(--glow-shadow);
border:1px solid var(--accent);
}
/* PROFILE */

.profile{
text-align:center;
margin-bottom:30px;
}

.avatar{
width:60px;
height:60px;
border-radius:50%;
background:var(--accent);
margin:0 auto 10px;
}

.profile h3{
font-size:16px;
}

.profile p{
font-size:12px;
color:var(--text-secondary);
}


/* ACTIVE MENU */

.sidebar li.active{
background:var(--accent);
color:var(--bg);
}
.sidebar li.active i{
color:var(--bg);
}

.stat{
position:relative;
overflow:hidden;
}

.stat::after{

content:"";
position:absolute;
bottom:0;
left:0;
width:100%;
height:2px;

background:linear-gradient(
90deg,
transparent,
var(--accent),
transparent
);

opacity:0.6;

}
.sidebar a{
color:inherit;
text-decoration:none;
display:block;
}


/* PROJECT SECTION */

.project-section{
margin-top:40px;
}

.section-title{
font-size:20px;
font-weight:600;
color:var(--text);
margin-bottom:20px;
letter-spacing:0.03em;
}


/* PROJECT GRID */

.project-grid{
display:grid;
grid-template-columns:repeat(3, 1fr);
gap:24px;
}


/* PROJECT CARD */

.project-card{
display:block;
text-decoration:none;
color:inherit;
background:var(--card);
border:1px solid var(--border);
border-radius:18px;
overflow:hidden;
transition:transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease;
cursor:pointer;
}

.project-card:hover{
transform:translateY(-8px) scale(1.02);
box-shadow:var(--glow-shadow);
border-color:var(--accent);
}


/* IMAGE WRAPPER */

.project-card__img-wrap{
position:relative;
width:100%;
aspect-ratio:16/9;
overflow:hidden;
}

.project-card__img{
width:100%;
height:100%;
object-fit:cover;
display:block;
transition:transform 0.45s ease;
}

.project-card:hover .project-card__img{
transform:scale(1.07);
}

.project-card__overlay{
position:absolute;
inset:0;
background:linear-gradient(
180deg,
transparent 50%,
rgba(10,10,18,0.85) 100%
);
pointer-events:none;
}


/* CARD BODY */

.project-card__body{
padding:18px 20px;
}

.project-card__title{
font-size:16px;
font-weight:600;
color:var(--text);
margin-bottom:6px;
}

.project-card__tag{
font-size:12px;
color:var(--accent);
letter-spacing:0.05em;
opacity:0.85;
}


/* FADE-IN ANIMATION */

/* cardFadeIn removed — GSAP handles project-card entry animations */


/* =====================
   CASE STUDY PAGE
   ===================== */

/* Scrollable main for long content */
.case-scroll{
overflow-y:visible;
min-height:100vh;
scroll-behavior:smooth;
}

.case-scroll::-webkit-scrollbar{
width:5px;
}
.case-scroll::-webkit-scrollbar-track{
background:transparent;
}
.case-scroll::-webkit-scrollbar-thumb{
background:#2a2a38;
border-radius:10px;
}


/* CASE CONTAINER */

.case-container{
max-width:860px;
display:flex;
flex-direction:column;
gap:36px;
padding-bottom:60px;
}


/* HERO IMAGE */

.case-hero{
position:relative;
border-radius:20px;
overflow:hidden;
border:1px solid var(--border);
}

.case-hero:hover{
box-shadow:var(--glow-shadow);
}

.case-hero .case-image{
width:100%;
aspect-ratio:16/7;
object-fit:cover;
display:block;
transition:transform 0.5s ease;
}

.case-hero:hover .case-image{
transform:scale(1.03);
}

.case-hero__badge{
position:absolute;
bottom:18px;
left:18px;
background:var(--accent);
color:var(--bg);
font-size:12px;
font-weight:600;
letter-spacing:0.06em;
padding:6px 14px;
border-radius:30px;
backdrop-filter:blur(6px);
}


/* SECTIONS */

.case-section{
background:var(--card);
border:1px solid var(--border);
border-radius:18px;
padding:32px 36px;
transition:border-color 0.3s ease, box-shadow 0.3s ease;
}

.case-section:hover{
border-color:var(--accent);
box-shadow:var(--glow-shadow);
}

.case-section--last{
border-color:var(--border);
}


/* SECTION LABEL */

.case-label{
display:inline-block;
font-size:11px;
font-weight:700;
letter-spacing:0.12em;
text-transform:uppercase;
color:var(--accent);
margin-bottom:10px;
}


/* SECTION TITLE */

.case-section__title{
font-size:22px;
font-weight:700;
color:var(--text);
margin-bottom:14px;
}


/* SECTION BODY TEXT */

.case-section__text{
font-size:15px;
line-height:1.8;
color:var(--text-secondary);
margin-bottom:0;
}

.case-section__text + .case-grid,
.case-section__text + .case-list{
margin-top:24px;
}


/* BULLET LIST */

.case-list{
list-style:none;
display:flex;
flex-direction:column;
gap:10px;
}

.case-list li{
font-size:14px;
color:var(--text-secondary);
padding-left:18px;
position:relative;
}

.case-list li::before{
content:"▸";
position:absolute;
left:0;
color:var(--accent);
}


/* STATS GRID */

.case-grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:18px;
}


/* STAT CARD */

.case-stat{
background:var(--card);
border:1px solid var(--border);
border-radius:14px;
padding:22px 20px;
text-align:center;
transition:border-color 0.3s ease, box-shadow 0.3s ease, transform 0.3s ease;
}

.case-stat:hover{
transform:translateY(-4px);
border-color:var(--accent);
box-shadow:var(--glow-shadow);
}

.case-stat--highlight .case-stat__value{
color:var(--accent);
}

.case-stat__value{
display:block;
font-size:28px;
font-weight:800;
color:var(--text);
margin-bottom:6px;
letter-spacing:-0.02em;
}

.case-stat__label{
display:block;
font-size:12px;
color:var(--text-secondary);
line-height:1.5;
}


/* IMAGE GRID */

.case-grid--images{
grid-template-columns:repeat(2,1fr);
}

.case-img-card{
border-radius:14px;
overflow:hidden;
border:1px solid var(--border);
background:var(--card);
transition:border-color 0.3s ease, box-shadow 0.3s ease, transform 0.3s ease;
}

.case-img-card:hover{
transform:translateY(-5px);
border-color:var(--accent);
box-shadow:var(--glow-shadow);
}

.case-img-card .case-image{
width:100%;
aspect-ratio:16/9;
object-fit:cover;
display:block;
transition:transform 0.45s ease;
}

.case-img-card:hover .case-image{
transform:scale(1.05);
}

.case-img-card__caption{
font-size:12px;
color:var(--text-secondary);
padding:10px 14px;
}


/* csFadeUp removed — GSAP handles case study entry animations */


/* =====================
   PAGE TRANSITION
   ===================== */

.page-transition{
position:fixed;
inset:0;
z-index:9999;
background:var(--bg);
pointer-events:none;
visibility:hidden;
opacity:0;
display:flex;
align-items:center;
justify-content:center;
}

/* Purple glow orb in the centre */
.page-transition::after{
content:"";
position:absolute;
width:400px;
height:400px;
border-radius:50%;
background:radial-gradient(
circle,
var(--accent) 0%,
transparent 70%
);
filter:blur(60px);
opacity:0;
transition:opacity 0.3s ease;
}

.page-transition.is-visible::after{
opacity:1;
}


/* =====================
   HERO SECTION
   ===================== */

.hero{
display:flex;
flex-direction:column;
align-items:center;
justify-content:center;
text-align:center;
min-height:82vh;
padding:60px 20px;
position:relative;
}



.hero > *{
position:relative;
z-index:1;
}

/* Designation label */
.hero__designation{
font-size:13px;
font-weight:700;
letter-spacing:0.18em;
text-transform:uppercase;
color:var(--accent);
margin-bottom:20px;
}

/* Big name */
.hero__name{
font-size:clamp(48px, 7vw, 80px);
font-weight:800;
line-height:1.05;
letter-spacing:-0.03em;
color:var(--text);
margin-bottom:24px;
/* Optional: remove the background clip text if you want solid theming, or keep it. I'll remove it so the light theme text color applies perfectly. */
}

/* Tagline */
.hero__tagline{
font-size:16px;
line-height:1.75;
color:var(--text-secondary);
max-width:480px;
margin-bottom:40px;
}

/* CTA buttons row */
.hero__actions{
display:flex;
gap:16px;
flex-wrap:wrap;
justify-content:center;
}

/* Solid filled button variant */
.btn--solid{
background:var(--accent);
border-color:var(--accent);
color:var(--bg);
}

.btn--solid:hover{
background:var(--text);
border-color:var(--text);
box-shadow:0 0 24px var(--card);
}

/* Sidebar nav label */
.sidebar__label{
font-size:10px;
font-weight:700;
letter-spacing:0.14em;
text-transform:uppercase;
color:var(--text-secondary);
padding:0 10px;
margin-bottom:8px;
margin-top:auto;
display:block;
}


/* =====================
   CASE STUDY LAYOUT (HRM)
   ===================== */

/* Center container with max-width for readibility */
.case-container{
max-width:1100px;
margin:0 auto;
padding:0 20px;
}

/* Large vertical spacing between sections */
.case-section{
padding:100px 0;
}

/* Clean, modern typography for section titles */
.case-title{
font-size:clamp(32px, 5vw, 48px);
font-weight:800;
letter-spacing:-0.02em;
margin-bottom:30px;
color:var(--text);
}

/* Base text styling */
.case-text{
font-size:18px;
line-height:1.8;
color:var(--text-secondary);
max-width:800px;
margin-bottom:40px;
}

/* Flexible grid layout */
.case-grid{
display:grid;
grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));
gap:40px;
margin-top:40px;
}

/* Rounded images with soft shadows */
.case-image{
width:100%;
height:auto;
border-radius:16px;
display:block;
box-shadow:0 20px 40px rgba(0,0,0,0.2);
}

/* =====================
   CASE STUDY HERO  (cs-hero)
   ===================== */

.cs-hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  padding: 80px 0;
  background: var(--bg);
}

/* Decorative radial orb */
.cs-hero__orb {
  position: absolute;
  top: 50%;
  right: -10%;
  transform: translateY(-50%);
  width: 720px;
  height: 720px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(200,200,200,0.06) 0%, transparent 65%);
  filter: blur(40px);
  pointer-events: none;
  z-index: 0;
}

/* Two-column inner wrapper */
.cs-hero__inner {
  position: relative;
  z-index: 1;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
  width: 100%;
}

/* ---- LEFT COLUMN ---- */
.cs-hero__text {
  display: flex;
  flex-direction: column;
  gap: 28px;
}

/* Small uppercase tag */
.cs-hero__tag {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text-secondary);
  border: 1px solid var(--border);
  padding: 6px 14px;
  border-radius: 100px;
  width: fit-content;
}

/* Large title */
.cs-hero__title {
  font-size: clamp(40px, 5.5vw, 68px);
  font-weight: 800;
  line-height: 1.06;
  letter-spacing: -0.03em;
  color: var(--text);
  margin: 0;
}

/* Subtitle */
.cs-hero__subtitle {
  font-size: 17px;
  line-height: 1.75;
  color: var(--text-secondary);
  max-width: 460px;
  margin: 0;
}

/* Meta info definition list */
.cs-hero__meta {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin: 0;
  border-top: 1px solid var(--border);
  padding-top: 28px;
}

.cs-hero__meta-item {
  display: grid;
  grid-template-columns: 100px 1fr;
  align-items: baseline;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
}

.cs-hero__meta-item dt {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-secondary);
}

.cs-hero__meta-item dd {
  margin: 0;
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.cs-hero__meta-sub {
  font-size: 12px;
  font-weight: 400;
  color: var(--text-secondary);
  display: block;
  margin-top: 2px;
  width: 100%;
}

/* Tools icon row */
.cs-hero__tools {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.cs-hero__tool-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--card);
  padding: 5px;
  transition: border-color 0.2s ease, transform 0.2s ease;
  cursor: default;
}

.cs-hero__tool-icon:hover {
  border-color: var(--text);
  transform: translateY(-2px);
}

.cs-hero__tool-icon svg {
  width: 100%;
  height: 100%;
}

.cs-hero__tool-label {
  font-size: 12px;
  color: var(--text-secondary);
  letter-spacing: 0.02em;
}

/* ---- RIGHT COLUMN ---- */
.cs-hero__mockup-wrap {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}

/* The actual mockup image */
.cs-hero__mockup {
  width: 100%;
  max-width: 620px;
  border-radius: 16px;
  display: block;
  /* Soft shadow */
  box-shadow:
    0 32px 80px rgba(0, 0, 0, 0.45),
    0 8px 24px rgba(0, 0, 0, 0.25);
  /* Slight perspective tilt */
  transform: perspective(1200px) rotateY(-6deg) rotateX(2deg);
  transform-origin: center center;
  transition: transform 0.5s ease, box-shadow 0.5s ease;
}

.cs-hero__mockup-wrap:hover .cs-hero__mockup {
  transform: perspective(1200px) rotateY(-2deg) rotateX(0deg);
  box-shadow:
    0 40px 100px rgba(0, 0, 0, 0.5),
    0 12px 30px rgba(0, 0, 0, 0.3);
}

/* Light mode shadow adjustments */
.light-mode .cs-hero__mockup {
  box-shadow:
    0 32px 80px rgba(0, 0, 0, 0.18),
    0 8px 24px rgba(0, 0, 0, 0.10);
}
.light-mode .cs-hero__mockup-wrap:hover .cs-hero__mockup {
  box-shadow:
    0 40px 100px rgba(0, 0, 0, 0.22),
    0 12px 30px rgba(0, 0, 0, 0.14);
}

/* Responsive — stack on smaller screens */
@media (max-width: 900px) {
  .cs-hero__inner {
    grid-template-columns: 1fr;
    gap: 48px;
    padding: 0 24px;
  }
  .cs-hero__mockup {
    transform: none;
  }
  .cs-hero__mockup-wrap:hover .cs-hero__mockup {
    transform: none;
  }
  .cs-hero {
    padding: 80px 0;
  }
}

/* =====================
   PKG-OV: OVERVIEW V2
   ===================== */

.pkg-ov {
  padding: 140px 0;
  background: var(--bg);
  position: relative;
  overflow: visible;
  width: 100% !important;
  display: block !important;
}

.pkg-ov__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
  width: 100%;
}

.pkg-ov__title {
  font-size: 52px;
  font-weight: 800;
  text-align: center !important;
  display: block !important;
  width: 100% !important;
  margin: 0 auto 100px auto !important;
  color: var(--text);
  letter-spacing: -0.03em;
}

.pkg-ov__grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  align-items: center !important;
  gap: 100px;
  width: 100% !important;
}

/* Col 1: Mockup */
.pkg-ov__col-mock {
  display: flex !important;
  justify-content: flex-start !important;
}

.pkg-ov__mock-frame {
  position: relative;
  width: 100%;
  max-width: 600px;
  perspective: 2000px;
}

.pkg-ov__img {
  width: 100%;
  height: auto;
  border-radius: 20px;
  transform: perspective(2000px) rotateY(-18deg) rotateX(6deg);
  box-shadow: 
    -40px 60px 120px rgba(0, 0, 0, 0.5),
    0 20px 40px rgba(0, 0, 0, 0.2);
  transition: transform 0.6s cubic-bezier(0.2, 0.8, 0.2, 1), box-shadow 0.6s ease;
}

.pkg-ov__mock-frame:hover .pkg-ov__img {
  transform: perspective(2000px) rotateY(-8deg) rotateX(2deg) scale(1.04);
}

/* Col 2: Content area */
.pkg-ov__col-text {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
}

.pkg-ov__text-wrap {
  position: relative !important;
  width: 100% !important;
}

.pkg-ov__desc {
  font-size: 34px;
  line-height: 1.35;
  color: var(--text);
  font-weight: 500;
  margin: 0;
  position: relative;
  z-index: 1;
  letter-spacing: -0.015em;
}

.pkg-ov__desc strong {
  font-weight: 800;
  color: var(--text);
}

/* Floating labels (Images) */
.pkg-label {
  position: absolute !important;
  z-index: 10 !important;
  pointer-events: none;
}

.pkg-label__img {
  width: 190px;
  height: auto;
  filter: drop-shadow(0 20px 40px rgba(0,0,0,0.35));
}

.pkg-label--1 { top: -90px !important; right: -40px !important; }
.pkg-label--2 { top: 50% !important; left: -130px !important; transform: translateY(-50%) !important; }
.pkg-label--3 { bottom: -80px !important; right: 0 !important; }

/* Animation */
.pkg-label {
  animation: pkgLabelFloat 5s ease-in-out infinite;
}
.pkg-label--2 { animation: pkgLabelFloatBlue 5s ease-in-out infinite; }
.pkg-label--3 { animation-delay: -2s; }

@keyframes pkgLabelFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-20px); }
}

@keyframes pkgLabelFloatBlue {
  0%, 100% { transform: translateY(-50%) translateX(0); }
  50% { transform: translateY(-55%) translateX(-10px); }
}

/* RESPONSIVE PKG-OV */
@media (max-width: 1250px) {
  .pkg-label__img { width: 160px; }
  .pkg-label--2 { left: -80px !important; }
}

@media (max-width: 1024px) {
  .pkg-ov__grid {
    grid-template-columns: 1fr !important;
    gap: 140px !important;
    text-align: center !important;
  }
  .pkg-ov__col-mock { justify-content: center !important; }
  .pkg-ov__desc { font-size: 28px; max-width: 100%; margin: 0 auto; }
  
  .pkg-label { position: relative !important; inset: auto !important; transform: none !important; margin: 30px auto !important; animation: none !important; display: block !important; }
}

@media (max-width: 600px) {
  .pkg-ov { padding: 80px 0; }
  .pkg-ov__title { font-size: 36px; margin-bottom: 60px !important; }
  .pkg-ov__desc { font-size: 22px; }
  .pkg-label__img { width: 150px; }
}







/* =====================
   TOOLS CONSTELLATION
   ===================== */

.tools-section {
    position: relative;
    width: 100%;
    height: 680px;
    margin: 40px 0 0 0;
    overflow: hidden;
}

.constellation-wrapper {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    transform-origin: center center;
    animation: revolveForward 160s linear infinite;
}

@keyframes revolveForward {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

.constellation-lines {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 1;
}

.tool-node {
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    border: 1px solid var(--border);
    background: var(--card);
    cursor: pointer;
    z-index: 2;
    transform: translate(-50%, -50%);
    transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1),
                border-color 0.3s ease,
                box-shadow 0.3s ease;
    animation: gentleFloat var(--float-dur, 18s) ease-in-out infinite var(--float-delay, 0s);
}

.tool-inner svg,
.tool-inner img {
    width: 50%;
    height: 50%;
    fill: var(--text-secondary);
    transition: fill 0.3s ease, transform 0.3s ease;
    pointer-events: none;
    object-fit: contain;
}

.tool-node:hover .tool-inner svg { fill: var(--bg); }
.tool-node:hover .tool-inner img { transform: scale(1.1); }

.tool-node:hover {
    border-color: var(--text);
    background: var(--text);
    box-shadow: 0 0 18px rgba(128,128,128,0.18);
    transform: translate(-50%, -50%) scale(1.13);
    z-index: 10;
}

/* Sizes */
.tool-center { width: 76px; height: 76px; --float-dur: 18s; }
.tool-middle  { width: 55px; height: 55px; --float-dur: 22s; }
.tool-outer   { width: 40px; height: 40px; --float-dur: 26s; }

.tool-inner { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; animation: revolveReverse 160s linear infinite; position: relative; }
@keyframes revolveReverse { from { transform: rotate(0deg); } to { transform: rotate(-360deg); } }

/* Staggered delays */
.tool-node:nth-child(2)  { --float-delay: -3s;  }
.tool-node:nth-child(3)  { --float-delay: -6s;  }
.tool-node:nth-child(4)  { --float-delay: -9s;  }
.tool-node:nth-child(5)  { --float-delay: -12s; }
.tool-node:nth-child(6)  { --float-delay: -2s;  }
.tool-node:nth-child(7)  { --float-delay: -5s;  }
.tool-node:nth-child(8)  { --float-delay: -8s;  }
.tool-node:nth-child(9)  { --float-delay: -11s; }
.tool-node:nth-child(10) { --float-delay: -14s; }
.tool-node:nth-child(11) { --float-delay: -17s; }
.tool-node:nth-child(12) { --float-delay: -1s;  }
.tool-node:nth-child(13) { --float-delay: -4s;  }
.tool-node:nth-child(14) { --float-delay: -7s;  }
.tool-node:nth-child(15) { --float-delay: -10s; }
.tool-node:nth-child(16) { --float-delay: -13s; }
.tool-node:nth-child(17) { --float-delay: -16s; }
.tool-node:nth-child(18) { --float-delay: -19s; }
.tool-node:nth-child(19) { --float-delay: -22s; }
.tool-node:nth-child(20) { --float-delay: -25s; }
.tool-node:nth-child(21) { --float-delay: -3s;  }
.tool-node:nth-child(22) { --float-delay: -7s;  }
.tool-node:nth-child(23) { --float-delay: -11s; }
.tool-node:nth-child(24) { --float-delay: -15s; }
.tool-node:nth-child(25) { --float-delay: -19s; }
.tool-node:nth-child(26) { --float-delay: -23s; }
.tool-node:nth-child(27) { --float-delay: -2s;  }
.tool-node:nth-child(28) { --float-delay: -6s;  }
.tool-node:nth-child(29) { --float-delay: -10s; }
.tool-node:nth-child(30) { --float-delay: -14s; }

@keyframes gentleFloat {
    0%   { translate: 0px  0px;  }
    25%  { translate: 2px  -3px; }
    50%  { translate: 3px  1px;  }
    75%  { translate: -2px 3px;  }
    100% { translate: 0px  0px;  }
}

/* Tooltip */
.tool-tooltip {
    position: absolute;
    top: -36px;
    left: 50%;
    transform: translateX(-50%) translateY(6px);
    background: var(--text);
    color: var(--bg);
    padding: 5px 12px;
    border-radius: 6px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.03em;
    white-space: nowrap;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s;
}

.tool-tooltip::after {
    content: '';
    position: absolute;
    bottom: -4px;
    left: 50%;
    transform: translateX(-50%);
    border: 4px solid transparent;
    border-top-color: var(--text);
    border-bottom: none;
}

.tool-node:hover .tool-tooltip {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
}

@media (max-width: 768px) {
    .tools-section { height: 480px; }
    .tool-center { width: 58px; height: 58px; }
    .tool-middle  { width: 42px; height: 42px; }
    .tool-outer   { width: 32px; height: 32px; }
}

/* =====================
   CS-REQUEST: CLIENT REQUEST
   ===================== */

.cs-request {
    position: relative;
    width: 100%;
    min-height: 95vh;
    display: flex;
    align-items: flex-start; /* Move card to top */
    justify-content: center;
    overflow: hidden;
    padding: 60px 40px; /* Adjust top padding */
    margin: 40px 0;
    border-radius: 30px;
}

.cs-request__bg-wrap {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.cs-request__bg {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 20%; /* Shift image down slightly if needed */
    display: block;
}

.cs-request__inner {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 1300px;
    display: flex;
    justify-content: center;
    align-items: flex-start;
}

.cs-request__card {
    background: rgba(255, 255, 255, 0.85); /* More visible white glass */
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.5);
    border-radius: 24px;
    padding: 60px 80px;
    max-width: 1100px;
    width: 100%;
    text-align: left; /* Left align text */
    box-shadow: 0 30px 60px rgba(0, 0, 0, 0.1);
    transition: transform 0.4s ease;
}

.light-mode .cs-request__card {
    background: rgba(255, 255, 255, 0.9);
    border-color: rgba(255, 255, 255, 0.8);
}

.cs-request__title {
    font-size: clamp(32px, 4vw, 48px);
    font-weight: 800;
    margin-bottom: 20px;
    line-height: 1.1;
    color: #1a1a2e; /* Specific dark color from screenshot */
    letter-spacing: -0.02em;
}

.cs-request__subtitle {
    display: block;
    font-size: 18px;
    font-weight: 500;
    color: #333;
    margin-bottom: 30px;
}

.cs-request__company {
    color: #1a1a2e;
    text-decoration: underline;
    font-weight: 600;
    cursor: pointer;
}

.cs-request__desc {
    font-size: 17px;
    line-height: 1.6;
    color: #444;
    max-width: 1000px;
    font-weight: 450;
}

/* Light/Dark mode specific overrides to keep it looking like the screenshot */
.light-mode .cs-request__title, 
.light-mode .cs-request__company { color: #1a1a2e; }
.light-mode .cs-request__subtitle { color: #333; }
.light-mode .cs-request__desc { color: #444; }

/* In dark mode, we keep a similar light card but slightly adjusted if needed */
/* But the user's screenshot is for "this is how i want the screen" which is a light themed card */
/* So we apply these colors specifically or use variables that resolve to these in dark mode */

/* Responsive adjustment */
@media (max-width: 900px) {
    .cs-request {
        min-height: 70vh;
        padding: 40px 20px;
    }
    .cs-request__card {
        padding: 40px 30px;
    }
    .cs-request__title {
        font-size: 28px;
    }
    .cs-request__subtitle {
        font-size: 16px;
    }
}


/* =====================
   PROJECT GOALS SECTION
   ===================== */

.pg-goals {
  padding: 100px 60px;
  background: var(--bg);
  transition: background 0.3s ease;
}

.pg-goals__inner {
  max-width: 960px;
  margin: 0 auto;
}

.pg-goals__heading {
  font-size: 36px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 48px;
  letter-spacing: -0.5px;
}

/* Grid: 2 cols, card 3 spans both centered */
.pg-goals__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}

/* Cards */
.pg-card {
  background: var(--pg-card-bg, #1a1a1a);
  border: 1px solid var(--pg-card-border, rgba(255,255,255,0.08));
  border-radius: 20px;
  padding: 28px 28px 32px;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.12);
  transition: background 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
}

/* Dark mode card vars (default) */
:root {
  --pg-card-bg: #1a1a1a;
  --pg-card-border: rgba(255,255,255,0.08);
  --pg-badge-bg: #2a2a2a;
  --pg-badge-color: #ffffff;
  --pg-list-color: #a1a1a1;
}

/* Light mode card vars */
.light-mode {
  --pg-card-bg: #ffffff;
  --pg-card-border: #e5e5e5;
  --pg-badge-bg: #f0f0f0;
  --pg-badge-color: #111111;
  --pg-list-color: #555555;
}

/* Card 3 centered below spanning both columns */
.pg-card--center {
  grid-column: 1 / -1;
  max-width: 460px;
  justify-self: center;
  width: 100%;
}

/* Card header row */
.pg-card__header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 18px;
}

/* Number badge */
.pg-card__badge {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--pg-badge-bg);
  color: var(--pg-badge-color);
  font-size: 14px;
  font-weight: 700;
  flex-shrink: 0;
  border: 1px solid var(--pg-card-border);
}

/* Card title */
.pg-card__title {
  font-size: 16px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: -0.2px;
}

/* Bullet list */
.pg-card__list {
  list-style: disc;
  padding-left: 18px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.pg-card__list li {
  font-size: 14px;
  line-height: 1.6;
  color: var(--pg-list-color);
}

/* Responsive */
@media (max-width: 680px) {
  .pg-goals {
    padding: 60px 24px;
  }

  .pg-goals__grid {
    grid-template-columns: 1fr;
  }

  .pg-card--center {
    grid-column: auto;
    max-width: 100%;
    justify-self: stretch;
  }
}


/* =====================
   PROBLEM STATEMENT SECTION
   ===================== */

.ps-section {
  padding: 100px 60px;
  background: var(--bg);
  transition: background 0.3s ease;
}

.ps-inner {
  max-width: 960px;
  margin: 0 auto;
}

.ps-heading {
  font-size: 36px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 52px;
  letter-spacing: -0.5px;
}

/* 3-column grid */
.ps-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

/* Card */
.ps-card {
  background: var(--ps-card-bg, #1a1a1a);
  border: 1px solid var(--ps-card-border, rgba(255,255,255,0.08));
  border-radius: 20px;
  padding: 40px 24px 36px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
  text-align: center;
  box-shadow: 0 4px 20px rgba(0,0,0,0.12);
  transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.3s ease, border-color 0.3s ease;
  cursor: default;
}

.ps-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 36px rgba(0,0,0,0.22);
}

/* Icon wrapper */
.ps-card__icon {
  width: 60px;
  height: 60px;
  border-radius: 16px;
  background: var(--ps-icon-bg, rgba(255,255,255,0.06));
  border: 1px solid var(--ps-card-border, rgba(255,255,255,0.08));
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text);
  flex-shrink: 0;
  transition: background 0.3s ease;
}

/* Card title */
.ps-card__title {
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: -0.1px;
}

/* Dark mode vars (default) */
:root {
  --ps-card-bg: #1a1a1a;
  --ps-card-border: rgba(255,255,255,0.08);
  --ps-icon-bg: rgba(255,255,255,0.06);
}

/* Light mode vars */
.light-mode {
  --ps-card-bg: #ffffff;
  --ps-card-border: #e5e5e5;
  --ps-icon-bg: #f5f5f5;
}

.light-mode .ps-card:hover {
  box-shadow: 0 12px 36px rgba(0,0,0,0.10);
}

/* Responsive */
@media (max-width: 720px) {
  .ps-section {
    padding: 60px 24px;
  }

  .ps-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

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


/* =====================
   USER RESEARCH SECTION
   ===================== */

.ur-section {
  padding: 100px 60px;
  background: var(--bg);
  transition: background 0.3s ease;
}

.ur-inner {
  max-width: 960px;
  margin: 0 auto;
}

.ur-heading {
  font-size: 36px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 24px;
  letter-spacing: -0.5px;
}

.ur-intro {
  font-size: 15px;
  line-height: 1.8;
  color: var(--text-secondary);
  max-width: 720px;
  margin-bottom: 52px;
}

.ur-sub {
  font-size: 20px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 48px;
  letter-spacing: -0.2px;
}

/* ---- Diagram container ---- */
.ur-diagram {
  position: relative;
  width: 100%;
  min-height: 860px;
}

/* SVG connectors sit behind cards */
.ur-connectors {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: visible;
  color: var(--ur-dash-color, rgba(255,255,255,0.25));
  pointer-events: none;
  z-index: 0;
  display: block;
}

/* ---- Cards ---- */
.ur-card {
  position: absolute;
  width: 300px;
  background: var(--ur-card-bg, #1a1a1a);
  border: 1px solid var(--ur-card-border, rgba(255,255,255,0.08));
  border-radius: 20px;
  padding: 28px 26px 30px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.14);
  z-index: 1;
  transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.3s ease;
}

.ur-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 14px 40px rgba(0,0,0,0.22);
}

/* Positions — zigzag layout matching SVG viewBox 960px wide */
.ur-card--tl { top: 0;     left: 0; }
.ur-card--tr { top: 160px; left: 660px; }
.ur-card--ml { top: 360px; left: 0; }
.ur-card--mr { top: 440px; left: 660px; }
.ur-card--bc { top: 640px; left: 50%; transform: translateX(-50%); }
.ur-card--bc:hover { transform: translateX(-50%) translateY(-5px); }

/* Percentage */
.ur-card__pct {
  display: block;
  font-size: 38px;
  font-weight: 800;
  color: var(--ur-pct-color, #5b9cf6);
  margin-bottom: 12px;
  letter-spacing: -1px;
  line-height: 1;
}

/* Description */
.ur-card__desc {
  font-size: 14px;
  line-height: 1.7;
  color: var(--text-secondary);
}

.ur-card__desc strong {
  color: var(--text);
  font-weight: 600;
}

/* ---- Theme vars ---- */
:root {
  --ur-card-bg: #1a1a1a;
  --ur-card-border: rgba(255,255,255,0.08);
  --ur-dash-color: rgba(255,255,255,0.18);
  --ur-pct-color: #5b9cf6;
}

.light-mode {
  --ur-card-bg: #ffffff;
  --ur-card-border: #e5e5e5;
  --ur-dash-color: rgba(0,0,0,0.18);
  --ur-pct-color: #2563eb;
}

.light-mode .ur-card:hover {
  box-shadow: 0 14px 40px rgba(0,0,0,0.10);
}

/* ---- Responsive ---- */
@media (max-width: 760px) {
  .ur-section {
    padding: 60px 24px;
  }

  .ur-diagram {
    min-height: unset;
    display: flex;
    flex-direction: column;
    gap: 20px;
  }

  .ur-connectors { display: none; }

  .ur-card {
    position: static;
    width: 100%;
    transform: none !important;
  }

  .ur-card--bc {
    left: auto;
    transform: none;
  }

  .ur-card--bc:hover {
    transform: translateY(-5px);
  }
}


/* =====================
   USER PERSONA SECTION
   ===================== */

.up-section {
  padding: 100px 60px;
  background: var(--bg);
  transition: background 0.3s ease;
}

.up-inner {
  max-width: 960px;
  margin: 0 auto;
}

.up-heading {
  font-size: 36px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 52px;
  letter-spacing: -0.5px;
}

/* Two-column layout */
.up-layout {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 48px;
  align-items: start;
}

/* ---- LEFT ---- */
.up-left {
  display: flex;
  flex-direction: column;
  gap: 36px;
}

/* Profile card */
.up-profile {
  background: var(--up-card-bg);
  border: 1px solid var(--up-card-border);
  border-radius: 24px;
  padding: 36px 24px 28px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.10);
}

.up-avatar {
  width: 90px;
  height: 90px;
  border-radius: 50%;
  overflow: hidden;
  border: 3px solid var(--up-accent);
  flex-shrink: 0;
}

.up-avatar svg {
  width: 100%;
  height: 100%;
  display: block;
}

.up-name {
  font-size: 18px;
  font-weight: 700;
  color: var(--text);
  margin: 0;
}

.up-role {
  font-size: 14px;
  font-weight: 500;
  color: var(--up-accent);
}

/* About block */
.up-about {
  background: var(--up-card-bg);
  border: 1px solid var(--up-card-border);
  border-radius: 20px;
  padding: 24px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.08);
}

.up-about__title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 16px;
}

.up-about__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 12px;
}

.up-about__item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--text-secondary);
}

.up-about__icon {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--up-icon-bg);
  border: 1px solid var(--up-card-border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--up-accent);
  flex-shrink: 0;
}

/* Maslow Pyramid */
.up-maslow {
  background: var(--up-card-bg);
  border: 1px solid var(--up-card-border);
  border-radius: 20px;
  padding: 24px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.08);
}

.up-pyramid {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-top: 16px;
}

.up-pyramid__level {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 12px;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-secondary);
  border-bottom: 1px solid var(--up-card-border);
  text-align: center;
  position: relative;
  clip-path: polygon(8% 0%, 92% 0%, 100% 100%, 0% 100%);
  margin: 0 auto;
  transition: background 0.3s ease;
}

/* Pyramid widths — narrowest at top */
.up-pyramid__level--1 { width: 55%;  background: var(--up-accent); color: #fff; border-radius: 6px 6px 0 0; clip-path: polygon(10% 0%, 90% 0%, 100% 100%, 0% 100%); }
.up-pyramid__level--2 { width: 67%;  background: var(--up-pyramid-2); }
.up-pyramid__level--3 { width: 79%;  background: var(--up-pyramid-3); }
.up-pyramid__level--4 { width: 90%;  background: var(--up-pyramid-4); }
.up-pyramid__level--5 { width: 100%; background: var(--up-pyramid-5); border-radius: 0 0 6px 6px; clip-path: polygon(4% 0%, 96% 0%, 100% 100%, 0% 100%); }

.up-pyramid__level--active {
  background: var(--up-accent) !important;
  color: #fff !important;
  font-weight: 700;
}

/* ---- RIGHT ---- */
.up-right {
  display: flex;
  flex-direction: column;
  gap: 36px;
}

.up-block__title {
  font-size: 18px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 14px;
  letter-spacing: -0.2px;
}

.up-block__text {
  font-size: 14px;
  line-height: 1.8;
  color: var(--text-secondary);
}

/* Lists */
.up-list {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.up-list li {
  font-size: 14px;
  color: var(--text-secondary);
  padding-left: 16px;
  position: relative;
  line-height: 1.6;
}

.up-list li::before {
  content: "•";
  position: absolute;
  left: 0;
  color: var(--up-accent);
  font-weight: 700;
}

.up-list--pain li::before {
  content: "•";
  color: #ef4444;
}

/* Quote box */
.up-quote {
  background: var(--up-quote-bg);
  border: 1px solid var(--up-card-border);
  border-radius: 20px;
  padding: 32px 28px 28px;
  position: relative;
  box-shadow: 0 4px 20px rgba(0,0,0,0.08);
}

.up-quote__mark {
  display: block;
  font-size: 72px;
  line-height: 0.6;
  color: var(--up-accent);
  font-family: Georgia, serif;
  margin-bottom: 20px;
  opacity: 0.9;
}

.up-quote__text {
  font-size: 16px;
  font-weight: 600;
  color: var(--text);
  line-height: 1.7;
  font-style: italic;
}

/* ---- Theme vars ---- */
:root {
  --up-card-bg: #1a1a1a;
  --up-card-border: rgba(255,255,255,0.08);
  --up-icon-bg: rgba(91,156,246,0.12);
  --up-accent: #3b82f6;
  --up-quote-bg: rgba(59,130,246,0.07);
  --up-avatar-bg: #2a2a2a;
  --up-avatar-fg: #4a4a4a;
  --up-pyramid-2: rgba(59,130,246,0.55);
  --up-pyramid-3: rgba(59,130,246,0.38);
  --up-pyramid-4: rgba(59,130,246,0.22);
  --up-pyramid-5: rgba(59,130,246,0.12);
}

.light-mode {
  --up-card-bg: #ffffff;
  --up-card-border: #e5e5e5;
  --up-icon-bg: #eff6ff;
  --up-accent: #2563eb;
  --up-quote-bg: #eff6ff;
  --up-avatar-bg: #e5e7eb;
  --up-avatar-fg: #9ca3af;
  --up-pyramid-2: rgba(37,99,235,0.50);
  --up-pyramid-3: rgba(37,99,235,0.32);
  --up-pyramid-4: rgba(37,99,235,0.18);
  --up-pyramid-5: rgba(37,99,235,0.09);
}

/* ---- Responsive ---- */
@media (max-width: 760px) {
  .up-section { padding: 60px 24px; }
  .up-layout { grid-template-columns: 1fr; }
}


/* =====================
   EMPATHY MAP SECTION
   ===================== */

.em-section {
  padding: 100px 60px;
  background: var(--bg);
  transition: background 0.3s ease;
}

.em-inner {
  max-width: 960px;
  margin: 0 auto;
}

.em-heading {
  font-size: 36px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 52px;
  letter-spacing: -0.5px;
}

/* 2x2 grid with center overlay */
.em-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto;
  gap: 0;
  position: relative;
}

/* Cards */
.em-card {
  border: 2px solid var(--em-border);
  border-radius: 20px;
  padding: 52px 32px 36px;
  position: relative;
  background: var(--em-card-bg);
  transition: background 0.3s ease, border-color 0.3s ease;
}

/* Overlap borders at center so cards look connected */
.em-card--says  { border-radius: 20px 0 0 0; border-right-width: 1px; border-bottom-width: 1px; }
.em-card--thinks{ border-radius: 0 20px 0 0; border-left-width: 1px;  border-bottom-width: 1px; }
.em-card--does  { border-radius: 0 0 0 20px; border-right-width: 1px; border-top-width: 1px; }
.em-card--feels { border-radius: 0 0 20px 0; border-left-width: 1px;  border-top-width: 1px; }

/* Label badge */
.em-card__label {
  position: absolute;
  top: -1px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--em-accent);
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  padding: 6px 28px;
  border-radius: 0 0 12px 12px;
  letter-spacing: 0.2px;
  white-space: nowrap;
}

/* List */
.em-list {
  list-style: disc;
  padding-left: 18px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 8px;
}

.em-list li {
  font-size: 14px;
  line-height: 1.6;
  color: var(--text-secondary);
}

/* Center avatar — absolutely positioned over grid intersection */
.em-center {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
}

.em-avatar {
  width: 90px;
  height: 90px;
  border-radius: 50%;
  overflow: hidden;
  border: 3px solid var(--em-accent);
  background: var(--em-card-bg);
  box-shadow: 0 0 0 4px var(--em-card-bg);
}

.em-avatar svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* Theme vars */
:root {
  --em-card-bg: #1a1a1a;
  --em-border: #2563eb;
  --em-accent: #2563eb;
}

.light-mode {
  --em-card-bg: #ffffff;
  --em-border: #3b82f6;
  --em-accent: #2563eb;
}

/* Responsive */
@media (max-width: 640px) {
  .em-section { padding: 60px 24px; }

  .em-grid { grid-template-columns: 1fr; gap: 16px; }

  .em-card,
  .em-card--says,
  .em-card--thinks,
  .em-card--does,
  .em-card--feels {
    border-radius: 16px;
    border-width: 2px;
    padding: 48px 24px 28px;
  }

  .em-center { display: none; }
}


/* =====================
   USER JOURNEY MAP SECTION
   ===================== */

.jm-section {
  padding: 100px 60px;
  background: var(--bg);
  transition: background 0.3s ease;
}

.jm-inner {
  max-width: 1100px;
  margin: 0 auto;
}

.jm-heading {
  font-size: 36px;
  font-weight: 700;
  color: #7c3aed;
  margin-bottom: 48px;
  letter-spacing: -0.5px;
  text-align: center;
}

.jm-pin {
  font-style: normal;
}

/* Scrollable wrapper for wide table */
.jm-wrap {
  overflow-x: auto;
  border-radius: 16px;
  border: 1px solid var(--jm-border);
  box-shadow: 0 4px 24px rgba(0,0,0,0.10);
}

.jm-table {
  width: 100%;
  min-width: 860px;
  border-collapse: collapse;
  background: var(--jm-bg);
  font-size: 12px;
  color: var(--text);
}

/* Header cells */
.jm-th {
  padding: 16px 12px 8px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  text-align: center;
  border-bottom: 1px solid var(--jm-border);
  white-space: nowrap;
}

.jm-th--row-label {
  width: 90px;
  min-width: 90px;
}

/* Color bar row */
.jm-colorbar-row td { padding: 0 8px 8px; }

.jm-bar {
  height: 5px;
  border-radius: 4px;
}
.jm-bar--purple { background: #7c3aed; }
.jm-bar--orange { background: #f97316; }
.jm-bar--green  { background: #22c55e; }

/* Row label column */
.jm-row-label {
  padding: 16px 12px;
  font-size: 12px;
  color: var(--text-secondary);
  vertical-align: middle;
  border-right: 1px solid var(--jm-border);
  white-space: nowrap;
  line-height: 2;
}

.jm-row-label--bold {
  font-weight: 700;
  font-size: 13px;
  color: var(--text);
  line-height: 1.4;
}

.jm-emoji {
  font-style: normal;
  display: inline-block;
  margin-right: 4px;
}

/* Emotion SVG row */
.jm-emotion-row td { border-bottom: 1px solid var(--jm-border); }

.jm-emotion-cell {
  padding: 8px 0;
}

.jm-emotion-svg {
  width: 100%;
  height: 100px;
  display: block;
}

/* Data rows */
.jm-row {
  border-top: 1px solid var(--jm-border);
  vertical-align: top;
}

.jm-row:last-child { border-bottom: none; }

.jm-cell {
  padding: 16px 12px;
  border-right: 1px solid var(--jm-border);
  vertical-align: top;
  color: var(--text-secondary);
}

.jm-cell:last-child { border-right: none; }

.jm-cell ul {
  list-style: disc;
  padding-left: 14px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.jm-cell ul li {
  line-height: 1.5;
}

/* Theme vars */
:root {
  --jm-bg: #161616;
  --jm-border: rgba(255,255,255,0.08);
}

.light-mode {
  --jm-bg: #ffffff;
  --jm-border: #e5e5e5;
}

/* Responsive */
@media (max-width: 640px) {
  .jm-section { padding: 60px 16px; }
  .jm-heading { font-size: 26px; }
}


/* =====================
   DESIGN PROCESS SECTION
   ===================== */

.dp-section {
  padding: 100px 60px;
  background: var(--bg);
  transition: background 0.3s ease;
}

.dp-inner {
  max-width: 960px;
  margin: 0 auto;
}

.dp-heading {
  font-size: 36px;
  font-weight: 700;
  color: var(--text);
  text-align: center;
  margin-bottom: 64px;
  letter-spacing: -0.5px;
}

/* Horizontal steps row */
.dp-steps {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 0;
}

/* Each step: circle + connector + label stacked */
.dp-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  flex: 1;
  position: relative;
}

/* Circle */
.dp-circle {
  width: 96px;
  height: 96px;
  border-radius: 50%;
  background: var(--dp-circle-bg);
  border: 1px solid var(--dp-circle-border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--dp-icon-color);
  box-shadow: 0 4px 20px rgba(0,0,0,0.10);
  transition: background 0.3s ease, transform 0.25s ease, box-shadow 0.25s ease;
  flex-shrink: 0;
  z-index: 1;
}

.dp-step:hover .dp-circle {
  transform: translateY(-6px);
  box-shadow: 0 12px 32px rgba(59,130,246,0.20);
  background: var(--dp-circle-hover);
}

/* Horizontal connector line between circles */
.dp-connector {
  position: absolute;
  top: 48px; /* vertically centered on circle (96/2) */
  left: calc(50% + 48px); /* starts at right edge of circle */
  width: calc(100% - 96px);
  height: 2px;
  background: var(--dp-line-color);
  background-image: repeating-linear-gradient(
    to right,
    var(--dp-line-color) 0,
    var(--dp-line-color) 6px,
    transparent 6px,
    transparent 12px
  );
  z-index: 0;
}

/* Label */
.dp-label {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  text-align: center;
  letter-spacing: 0.1px;
}

/* Theme vars */
:root {
  --dp-circle-bg: #1e1e1e;
  --dp-circle-border: rgba(255,255,255,0.08);
  --dp-circle-hover: #1d3a6e;
  --dp-icon-color: #3b82f6;
  --dp-line-color: rgba(255,255,255,0.15);
}

.light-mode {
  --dp-circle-bg: #f0f4ff;
  --dp-circle-border: #dbeafe;
  --dp-circle-hover: #dbeafe;
  --dp-icon-color: #2563eb;
  --dp-line-color: rgba(0,0,0,0.12);
}

/* Responsive */
@media (max-width: 640px) {
  .dp-section { padding: 60px 24px; }

  .dp-steps {
    flex-direction: column;
    align-items: center;
    gap: 32px;
  }

  .dp-connector {
    display: none;
  }
}


/* =====================
   TYPOGRAPHY SECTION
   ===================== */

.ty-section {
  padding: 100px 60px;
  background: var(--bg);
  transition: background 0.3s ease;
  font-family: 'Poppins', sans-serif;
}

.ty-inner {
  max-width: 960px;
  margin: 0 auto;
}

.ty-heading {
  font-family: 'Poppins', sans-serif;
  font-size: 36px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 60px;
  letter-spacing: -0.5px;
}

/* Two-column layout */
.ty-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}

/* ---- LEFT ---- */
.ty-left {
  display: flex;
  flex-direction: column;
  gap: 48px;
}

/* Weight list */
.ty-weights {
  display: flex;
  flex-direction: column;
  gap: 0;
  border: 1px solid var(--ty-border);
  border-radius: 16px;
  overflow: hidden;
}

.ty-weight {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 24px;
  border-bottom: 1px solid var(--ty-border);
  font-family: 'Poppins', sans-serif;
  transition: background 0.2s ease;
}

.ty-weight:last-child { border-bottom: none; }

.ty-weight:hover { background: var(--ty-row-hover); }

.ty-weight__name {
  font-size: 15px;
  color: var(--text);
}

.ty-weight__sample {
  font-size: 13px;
  color: var(--text-secondary);
}

/* Alphabet preview */
.ty-alphabet {
  font-family: 'Poppins', sans-serif;
  font-weight: 300;
  font-size: 16px;
  line-height: 2;
  color: var(--ty-alpha-color);
  letter-spacing: 0.5px;
}

/* ---- RIGHT ---- */
.ty-right {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
}

.ty-font-name {
  font-family: 'Poppins', sans-serif;
  font-size: 28px;
  font-weight: 600;
  color: var(--text-secondary);
  letter-spacing: 1px;
  text-transform: uppercase;
}

.ty-big-aa {
  font-family: 'Poppins', sans-serif;
  font-size: clamp(120px, 18vw, 200px);
  font-weight: 700;
  color: #00AEEF;
  line-height: 0.85;
  letter-spacing: -4px;
  display: block;
}

/* Theme vars */
:root {
  --ty-border: rgba(255,255,255,0.08);
  --ty-row-hover: rgba(255,255,255,0.03);
  --ty-alpha-color: rgba(255,255,255,0.18);
}

.light-mode {
  --ty-border: #e5e5e5;
  --ty-row-hover: #f9fafb;
  --ty-alpha-color: #d1d5db;
}

/* Responsive */
@media (max-width: 680px) {
  .ty-section { padding: 60px 24px; }
  .ty-layout { grid-template-columns: 1fr; gap: 40px; }
  .ty-big-aa { font-size: 100px; }
}


/* =====================
   COLOR PALETTE SECTION
   ===================== */

.cp-section {
  padding: 100px 60px;
  background: var(--cp-bg);
  position: relative;
  overflow: hidden;
  transition: background 0.3s ease;
}

.cp-inner {
  max-width: 960px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

.cp-heading {
  font-size: 36px;
  font-weight: 700;
  color: var(--text);
  text-align: center;
  margin-bottom: 12px;
  letter-spacing: -0.5px;
}

.cp-sub {
  font-size: 15px;
  color: var(--text-secondary);
  text-align: center;
  margin-bottom: 72px;
}

/* Ambient glow orbs */
.cp-glow {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0.25;
  pointer-events: none;
  animation: cp-pulse 6s ease-in-out infinite alternate;
}

.cp-glow--1 {
  width: 400px;
  height: 400px;
  background: #00AEEF;
  top: -80px;
  left: -100px;
  animation-delay: 0s;
}

.cp-glow--2 {
  width: 360px;
  height: 360px;
  background: #4CAF50;
  bottom: -60px;
  right: -80px;
  animation-delay: 3s;
}

@keyframes cp-pulse {
  from { opacity: 0.18; transform: scale(1); }
  to   { opacity: 0.32; transform: scale(1.12); }
}

/* Cards row */
.cp-cards {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  gap: 20px;
  padding: 40px 0 60px;
}

/* Individual card */
.cp-card {
  width: 128px;
  flex-shrink: 0;
  border-radius: 20px;
  overflow: hidden;
  background: var(--cp-card-bg);
  border: 1px solid var(--cp-card-border);
  box-shadow:
    0 8px 32px rgba(0,0,0,0.18),
    0 0 0 1px rgba(255,255,255,0.04);
  transform: rotate(var(--r, 0deg)) translateY(var(--ty, 0px));
  animation: cp-float 4s ease-in-out infinite alternate;
  animation-delay: var(--delay, 0s);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  position: relative;
}

.cp-card::before {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: 22px;
  background: radial-gradient(circle at 50% 0%, var(--glow, #ffffff), transparent 70%);
  opacity: 0.15;
  pointer-events: none;
  z-index: 0;
}

.cp-card:hover {
  transform: rotate(0deg) translateY(calc(var(--ty, 0px) - 8px)) scale(1.06);
  box-shadow:
    0 20px 48px rgba(0,0,0,0.28),
    0 0 28px color-mix(in srgb, var(--glow, #fff) 40%, transparent);
}

@keyframes cp-float {
  from { transform: rotate(var(--r, 0deg)) translateY(var(--ty, 0px)); }
  to   { transform: rotate(var(--r, 0deg)) translateY(calc(var(--ty, 0px) - 10px)); }
}

/* Swatch */
.cp-card__swatch {
  width: 100%;
  height: 100px;
  display: block;
  position: relative;
  z-index: 1;
}

/* Info area */
.cp-card__info {
  padding: 14px 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  position: relative;
  z-index: 1;
}

.cp-card__hex {
  font-size: 12px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: 0.5px;
  font-family: 'Courier New', monospace;
}

.cp-card__name {
  font-size: 11px;
  color: var(--text-secondary);
  line-height: 1.4;
}

/* Theme vars */
:root {
  --cp-bg: #0d0d0d;
  --cp-card-bg: rgba(30,30,30,0.85);
  --cp-card-border: rgba(255,255,255,0.10);
}

.light-mode {
  --cp-bg: #f0f4f8;
  --cp-card-bg: rgba(255,255,255,0.90);
  --cp-card-border: rgba(0,0,0,0.08);
}

.light-mode .cp-glow { opacity: 0.12; }

/* Responsive */
@media (max-width: 640px) {
  .cp-section { padding: 60px 24px; }
  .cp-cards { flex-wrap: wrap; gap: 20px; padding: 20px 0; }
  .cp-card { width: 110px; transform: rotate(0deg) translateY(0) !important; }
  .cp-card:hover { transform: translateY(-6px) scale(1.03) !important; }
}


/* =====================
   USER FLOW SECTION
   ===================== */

.uf-section {
  padding: 100px 60px;
  background: var(--bg);
  transition: background 0.3s ease;
}

.uf-inner {
  max-width: 760px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.uf-heading {
  font-size: 36px;
  font-weight: 700;
  color: var(--text);
  text-align: center;
  margin-bottom: 12px;
  letter-spacing: -0.5px;
}

.uf-sub {
  font-size: 15px;
  color: var(--text-secondary);
  text-align: center;
  margin-bottom: 60px;
}

/* Main vertical flow */
.uf-flow {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}

/* Step wrapper */
.uf-step {
  display: flex;
  justify-content: center;
  width: 100%;
}

/* Box */
.uf-box {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 32px;
  background: var(--uf-box-bg);
  border: 1px solid var(--uf-box-border);
  border-radius: 50px;
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
  box-shadow: 0 4px 16px rgba(0,0,0,0.08);
  min-width: 220px;
  justify-content: center;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.3s ease;
  white-space: nowrap;
}

.uf-box:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0,174,239,0.15);
}

.uf-box__icon {
  color: #00AEEF;
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

/* Start / end special styles */
.uf-step--start .uf-box {
  background: #00AEEF;
  border-color: #00AEEF;
  color: #fff;
  font-weight: 600;
}
.uf-step--start .uf-box__icon { color: #fff; }

.uf-step--end .uf-box {
  background: var(--uf-end-bg);
  border-color: var(--uf-end-border);
  color: var(--uf-end-text);
  font-weight: 600;
}
.uf-step--end .uf-box__icon { color: var(--uf-end-text); }

/* Active (Dashboard) */
.uf-step--active .uf-box {
  border-color: #00AEEF;
  box-shadow: 0 0 0 3px rgba(0,174,239,0.15), 0 4px 16px rgba(0,0,0,0.08);
}

/* Arrow */
.uf-arrow {
  width: 2px;
  height: 32px;
  background: var(--uf-arrow-color);
  position: relative;
  margin: 0 auto;
  flex-shrink: 0;
}

.uf-arrow::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 50%;
  transform: translateX(-50%);
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 7px solid var(--uf-arrow-color);
}

/* Branch layout */
.uf-branch {
  display: flex;
  justify-content: center;
  gap: 40px;
  width: 100%;
  position: relative;
  padding: 0 20px;
}

.uf-branch__col {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
  max-width: 280px;
}

/* Horizontal branch lines from center to each column */
.uf-branch__line {
  position: absolute;
  top: 0;
  height: 2px;
  background: var(--uf-arrow-color);
  width: calc(25% - 20px);
}

.uf-branch__line--left  { left: calc(25% + 10px); }
.uf-branch__line--right { right: calc(25% + 10px); }

/* Theme vars */
:root {
  --uf-box-bg: #1e1e1e;
  --uf-box-border: rgba(255,255,255,0.10);
  --uf-arrow-color: rgba(255,255,255,0.20);
  --uf-end-bg: #1e1e1e;
  --uf-end-border: rgba(255,255,255,0.15);
  --uf-end-text: #a1a1a1;
}

.light-mode {
  --uf-box-bg: #ffffff;
  --uf-box-border: #e5e5e5;
  --uf-arrow-color: #c0ccd8;
  --uf-end-bg: #f4f7fa;
  --uf-end-border: #dde3ea;
  --uf-end-text: #6b7280;
}

/* Responsive */
@media (max-width: 640px) {
  .uf-section { padding: 60px 20px; }

  .uf-branch {
    flex-direction: column;
    align-items: center;
    gap: 0;
  }

  .uf-branch__line { display: none; }

  .uf-branch__col {
    max-width: 100%;
    width: 100%;
  }
}

/* =====================
   HRM FULL-WIDTH IMAGE SECTIONS
   ===================== */

.hrm-img-section {
  margin: 0;
  padding: 0;
  width: 100%;
  border-radius: 0;
}

.hrm-img-full {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 0;
}

