@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500;1,600&family=Outfit:wght@300;400;500;600;700&display=swap');

:root {
  --ink:           #0E0A1F;
  --purple:        #3B0FA0;
  --purple-dark:   #1E0660;
  --purple-mid:    #5A2BD6;
  --purple-soft:   #7B55E0;
  --purple-light:  #F0ECFB;
  --purple-pale:   #F8F6FE;
  --white:         #FFFFFF;
  --stone:         #F4F2EF;
  --off-white:     #FAFAF9;
  --text-dark:     #0E0A1F;
  --text-mid:      #4A4263;
  --text-light:    #8A7FAA;
  --border:        rgba(59,15,160,0.10);
  --border-strong: rgba(59,15,160,0.22);
  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body:    'Outfit', system-ui, sans-serif;
  --radius-sm: 6px; --radius-md: 14px; --radius-lg: 22px; --radius-xl: 32px;
  --shadow-sm: 0 1px 4px rgba(14,10,31,0.06);
  --shadow-md: 0 6px 24px rgba(14,10,31,0.08), 0 2px 8px rgba(14,10,31,0.04);
  --shadow-lg: 0 20px 60px rgba(14,10,31,0.10), 0 6px 20px rgba(14,10,31,0.06);
  --transition: 0.3s cubic-bezier(0.4,0,0.2,1);
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
body { font-family:var(--font-body); background:var(--white); color:var(--text-dark); line-height:1.6; }
a { color:inherit; text-decoration:none; }
img { max-width:100%; height:auto; display:block; }
.container { width:100%; max-width:1200px; margin:0 auto; padding-left:64px; padding-right:64px; }

/* NAVBAR */
.navbar { background:var(--purple-dark); padding:0; position:sticky; top:0; z-index:999; border-bottom:1px solid rgba(255,255,255,0.06); }
.nav-inner { display:flex; align-items:center; justify-content:space-between; height:70px; }
.logo { font-family:var(--font-display); font-size:24px; font-weight:500; letter-spacing:0.04em; color:white; }
.logo a { color:white; }
.nav-links { display:flex; gap:40px; align-items:center; }
.nav-links a { font-family:var(--font-body); font-size:12px; font-weight:500; color:rgba(255,255,255,0.62); letter-spacing:0.10em; text-transform:uppercase; transition:color var(--transition); position:relative; }
.nav-links a::after { content:''; position:absolute; bottom:-4px; left:0; width:0; height:1px; background:rgba(255,255,255,0.40); transition:width var(--transition); }
.nav-links a:hover { color:white; }
.nav-links a:hover::after { width:100%; }

/* HERO VIDEO */
.hero-video { position:relative; height:100vh; min-height:620px; overflow:hidden; }
.video-bg { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.hero-video::after { content:''; position:absolute; inset:0; background:linear-gradient(to bottom, rgba(14,6,50,0.00) 0%, rgba(14,6,50,0.00) 50%, rgba(14,6,50,0.05) 100%); z-index:1; }
.hero-description { position:absolute; bottom:80px; left:64px; max-width:580px; font-family:var(--font-body); font-size:16px; font-weight:300; line-height:1.85; color:rgba(255,255,255,0.90); z-index:2; border-left:1px solid rgba(255,255,255,0.32); padding-left:22px; animation:fadeInUp 0.9s ease 0.4s both; }

/* PAGE HEADER */
.page-header { background:var(--white); padding:90px 0 70px; border-bottom:1px solid var(--border); }
.page-header-inner { max-width:720px; }
.page-header h1 { font-family:var(--font-display); color:var(--ink); font-size:68px; font-weight:400; letter-spacing:-0.5px; line-height:1.0; margin-bottom:22px; }
.page-header p { color:var(--text-mid); font-size:16px; font-weight:300; line-height:1.8; max-width:600px; }

/* QUOTE */
.quote-section { background:var(--white); padding:130px 0 110px; }
.quote-text { font-family:var(--font-display); color:var(--ink); font-size:52px; font-weight:400; font-style:italic; line-height:1.2; letter-spacing:-0.3px; max-width:920px; animation:fadeInUp 0.7s ease 0.1s both; }
.quote-text::before { content:'\201C'; font-size:90px; line-height:0; vertical-align:-0.38em; color:rgba(59,15,160,0.12); margin-right:4px; font-family:var(--font-display); }
.quote-images { margin-top:56px; }
.quote-images img { width:100%; max-width:860px; border-radius:var(--radius-xl); box-shadow:var(--shadow-lg); }

/* EYEBROW */
.eyebrow { color:var(--purple-soft); font-size:11px; letter-spacing:0.16em; text-transform:uppercase; font-weight:600; margin-bottom:16px; display:block; }
.insights-eyebrow { color:var(--purple-soft); font-size:11px; letter-spacing:0.16em; text-transform:uppercase; font-weight:600; margin-bottom:16px; display:block; }

/* KEYWORDS */
.keywords-section { background:var(--stone); padding:90px 0; text-align:center; }
.keywords-title { font-family:var(--font-display); color:var(--ink); font-size:32px; font-weight:400; margin-bottom:10px; font-style:italic; }
.keywords-intro { color:var(--text-light); font-size:13px; font-weight:400; letter-spacing:0.04em; margin-bottom:32px; font-style:italic; }
.keywords-grid { display:flex; flex-wrap:wrap; justify-content:center; gap:10px; max-width:900px; margin:0 auto; }
.keyword-tag { border:1px solid var(--border-strong); color:var(--purple); background:white; padding:9px 20px; border-radius:999px; font-size:11.5px; font-weight:500; letter-spacing:0.05em; text-transform:uppercase; transition:all var(--transition); cursor:pointer; font-family:var(--font-body); }
.keyword-tag:hover { background:var(--purple); color:white; border-color:var(--purple); transform:translateY(-2px); box-shadow:var(--shadow-sm); }
.keyword-tag.active { background:var(--purple); color:white; border-color:var(--purple); box-shadow:var(--shadow-md); }
.keyword-panel { max-height:0; overflow:hidden; transition:max-height 0.45s cubic-bezier(0.4,0,0.2,1), opacity 0.35s ease, margin-top 0.35s ease; opacity:0; margin-top:0; text-align:left; }
.keyword-panel.open { max-height:200px; opacity:1; margin-top:32px; }
.keyword-panel-inner { border-left:2px solid var(--purple); padding:20px 28px; background:white; border-radius:0 var(--radius-md) var(--radius-md) 0; max-width:760px; margin:0 auto; }
.keyword-panel-text { font-family:var(--font-body); font-size:15px; font-weight:300; line-height:1.85; color:var(--text-mid); }

/* DIAGRAM */
.diagram-section { background:var(--white); padding:110px 0 90px; }
.diagram-title { font-family:var(--font-display); color:var(--ink); font-size:44px; font-weight:400; font-style:italic; letter-spacing:-0.3px; margin-bottom:18px; }
.diagram-text { color:var(--text-mid); font-size:16px; font-weight:300; line-height:1.85; margin-bottom:44px; max-width:780px; }
.diagram-wrap { margin-top:24px; }
.diagram-wrap img { width:60%; border-radius:0; box-shadow:none; display:block; margin:0 auto; }
.diagram-left { margin-top:60px; max-width:800px; padding:44px 48px; background:var(--purple-pale); border-radius:var(--radius-lg); border:1px solid var(--border); }
.diagram-left .diagram-title { font-size:30px; margin-bottom:10px; }
.diagram-left .diagram-text { font-size:15px; margin-bottom:14px; }
.diagram-left .diagram-text:last-child { margin-bottom:0; }

/* METHODOLOGY */
.methodology-section { background:var(--stone); padding:110px 0; }
.methodology-intro { max-width:680px; margin-bottom:72px; }
.methodology-intro h2 { font-family:var(--font-display); font-size:50px; font-weight:400; letter-spacing:-0.4px; color:var(--ink); line-height:1.05; margin-bottom:16px; }
.methodology-intro p { font-size:16px; font-weight:300; line-height:1.8; color:var(--text-mid); }
.methodology-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; background:var(--border); border-radius:var(--radius-lg); overflow:hidden; }
.method-card { background:var(--white); padding:44px 36px; transition:background var(--transition); }
.method-card:hover { background:var(--purple-pale); }
.method-number { font-family:var(--font-display); font-size:64px; font-weight:300; color:rgba(59,15,160,0.08); line-height:1; margin-bottom:20px; }
.method-card h3 { font-family:var(--font-display); font-size:26px; font-weight:500; color:var(--ink); margin-bottom:12px; line-height:1.2; }
.method-card p { font-size:14px; font-weight:300; color:var(--text-mid); line-height:1.8; }
.method-tag { display:inline-block; margin-top:16px; font-size:10px; font-weight:600; letter-spacing:0.12em; text-transform:uppercase; color:var(--purple-soft); border:1px solid var(--border-strong); padding:4px 12px; border-radius:999px; }

/* PROCESS */
.process-section { background:var(--white); padding:110px 0; }
.process-intro { max-width:680px; margin-bottom:72px; }
.process-intro h2 { font-family:var(--font-display); font-size:50px; font-weight:400; letter-spacing:-0.4px; color:var(--ink); line-height:1.05; margin-bottom:16px; }
.process-intro p { font-size:16px; font-weight:300; line-height:1.8; color:var(--text-mid); }
.process-timeline { display:flex; flex-direction:column; }
.process-step { display:grid; grid-template-columns:80px 1fr; gap:40px; align-items:start; padding:40px 0; border-bottom:1px solid var(--border); }
.process-step:last-child { border-bottom:none; }
.process-step-num { font-family:var(--font-display); font-size:52px; font-weight:300; color:rgba(59,15,160,0.12); line-height:1; padding-top:4px; }
.process-step-body h3 { font-family:var(--font-display); font-size:28px; font-weight:500; color:var(--ink); margin-bottom:10px; line-height:1.2; }
.process-step-body p { font-size:15px; font-weight:300; color:var(--text-mid); line-height:1.8; max-width:680px; }
.process-step-label { display:inline-block; margin-top:12px; font-size:10px; font-weight:600; letter-spacing:0.12em; text-transform:uppercase; color:var(--purple-soft); }

/* PACKAGES */
.packages-section { background:var(--stone); padding:110px 0; }
.packages-intro { max-width:680px; margin-bottom:72px; }
.packages-intro h2 { font-family:var(--font-display); font-size:50px; font-weight:400; letter-spacing:-0.4px; color:var(--ink); line-height:1.05; margin-bottom:16px; }
.packages-intro p { font-size:16px; font-weight:300; line-height:1.8; color:var(--text-mid); }
.packages-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; align-items:start; }
.package-card { background:var(--white); border-radius:var(--radius-lg); border:1px solid var(--border); overflow:hidden; transition:box-shadow var(--transition), transform var(--transition); }
.package-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-4px); }
.package-card.featured { border-color:var(--purple); box-shadow:0 0 0 1px var(--purple), var(--shadow-md); }
.package-header { padding:32px 36px 28px; border-bottom:1px solid var(--border); }
.package-label { font-size:10px; font-weight:600; letter-spacing:0.14em; text-transform:uppercase; color:var(--purple-soft); margin-bottom:10px; display:block; }
.package-featured-badge { display:inline-block; background:var(--purple); color:white; font-size:10px; font-weight:600; letter-spacing:0.08em; text-transform:uppercase; padding:4px 12px; border-radius:999px; margin-bottom:10px; }
.package-name { font-family:var(--font-display); font-size:30px; font-weight:500; color:var(--ink); line-height:1.2; margin-bottom:8px; }

.package-body { padding:32px 36px; }
.package-desc { font-size:14px; font-weight:300; color:var(--text-mid); line-height:1.8; margin-bottom:24px; }
.package-deliverables { list-style:none; display:flex; flex-direction:column; gap:10px; }
.package-deliverables li { font-size:13.5px; font-weight:300; color:var(--text-mid); padding-left:18px; position:relative; line-height:1.6; }
.package-deliverables li::before { content:'—'; position:absolute; left:0; color:var(--purple-soft); font-size:12px; }

/* VALUES */
.values-section { background:var(--white); padding:110px 0; }
.values-header { max-width:680px; margin-bottom:64px; }
.values-header h2 { font-family:var(--font-display); font-size:50px; font-weight:400; letter-spacing:-0.4px; color:var(--ink); line-height:1.05; margin-bottom:16px; }
.values-header p { font-size:16px; font-weight:300; line-height:1.8; color:var(--text-mid); }
.values-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:16px; }
.value-card { padding:32px 24px; border-radius:var(--radius-md); border:1px solid var(--border); background:var(--white); transition:all var(--transition); }
.value-card:hover { background:var(--purple-pale); border-color:var(--border-strong); transform:translateY(-3px); box-shadow:var(--shadow-md); }
.value-icon { font-size:22px; margin-bottom:16px; }
.value-card h3 { font-family:var(--font-display); font-size:19px; font-weight:500; color:var(--ink); margin-bottom:8px; line-height:1.3; }
.value-card p { font-size:13px; font-weight:300; color:var(--text-mid); line-height:1.75; }

/* ABOUT */
.about-section { background:var(--white); padding:90px 0 110px; }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:100px; align-items:start; }
.about-left h2 { font-family:var(--font-display); font-size:52px; font-weight:400; font-style:italic; color:var(--ink); line-height:1.1; margin-bottom:32px; letter-spacing:-0.3px; }
.about-body { color:var(--text-mid); font-size:16px; font-weight:300; line-height:1.9; }
.about-body p { margin-bottom:22px; }
.about-body p:last-child { margin-bottom:0; }
.about-stat-block { padding:36px 0; border-bottom:1px solid var(--border); }
.about-stat-block:first-child { padding-top:0; }
.about-stat-block:last-child { border-bottom:none; }
.about-stat-label { font-size:10.5px; font-weight:600; letter-spacing:0.14em; text-transform:uppercase; color:var(--purple-soft); margin-bottom:8px; }
.about-stat-value { font-family:var(--font-display); font-size:22px; font-weight:400; color:var(--ink); line-height:1.4; }

/* FOUNDER */
.founder-section { background:var(--stone); padding:110px 0; }
.founder-inner { display:grid; grid-template-columns:1fr 1fr; gap:90px; align-items:center; }
.founder-quote { font-family:var(--font-display); font-size:38px; font-weight:400; font-style:italic; color:var(--ink); line-height:1.3; letter-spacing:-0.2px; margin-bottom:32px; }
.founder-quote::before { content:'\201C'; font-size:72px; line-height:0; vertical-align:-0.35em; color:rgba(59,15,160,0.12); margin-right:4px; }
.founder-name { font-size:14px; font-weight:500; color:var(--ink); letter-spacing:0.04em; margin-bottom:4px; }
.founder-title { font-size:13px; font-weight:300; color:var(--text-light); }
.founder-right { display:flex; flex-direction:column; gap:20px; }
.founder-belief { padding:28px 30px; background:var(--white); border-radius:var(--radius-md); border:1px solid var(--border); }
.founder-belief h4 { font-family:var(--font-display); font-size:19px; font-weight:500; color:var(--ink); margin-bottom:6px; }
.founder-belief p { font-size:13.5px; font-weight:300; color:var(--text-mid); line-height:1.75; }

/* WHY SECTION */
.section { padding:110px 0; background:var(--white); }
.section h2 { font-family:var(--font-display); font-size:50px; font-weight:400; letter-spacing:-0.4px; margin-bottom:16px; color:var(--ink); line-height:1.05; }
.section p { font-size:16px; font-weight:300; line-height:1.8; color:var(--text-mid); max-width:680px; margin-bottom:60px; }
.why-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.why-column { display:flex; flex-direction:column; gap:20px; }
.why-item { padding:30px 32px; border-radius:var(--radius-md); background:var(--purple-pale); border:1px solid var(--border); transition:background var(--transition), border-color var(--transition), transform var(--transition); }
.why-item:hover { background:var(--purple-light); border-color:var(--border-strong); transform:translateY(-2px); }
.why-item h3 { font-family:var(--font-display); color:var(--ink); font-size:21px; font-weight:400; margin-bottom:8px; }
.why-item p { color:var(--text-mid); font-size:14px; line-height:1.75; margin-bottom:0; font-weight:300; }

/* ENABLES */
.enables-section { background:var(--white); padding:110px 0; }
.enables-section h2 { font-family:var(--font-display); font-size:50px; font-weight:400; letter-spacing:-0.4px; margin-bottom:16px; color:var(--ink); line-height:1.05; }
.enables-section .section-intro { font-size:16px; font-weight:300; line-height:1.8; color:var(--text-mid); max-width:680px; margin-bottom:64px; }
.enables-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.enables-card { padding:36px 32px; border-radius:var(--radius-lg); background:var(--purple-pale); border:1px solid var(--border); transition:box-shadow var(--transition), border-color var(--transition), transform var(--transition); }
.enables-card:hover { box-shadow:var(--shadow-md); border-color:var(--border-strong); transform:translateY(-3px); }
.enables-card-number { font-family:var(--font-display); font-size:52px; font-weight:300; color:rgba(59,15,160,0.14); line-height:1; margin-bottom:16px; }
.enables-card h3 { font-family:var(--font-display); color:var(--ink); font-size:22px; font-weight:500; margin-bottom:10px; line-height:1.3; }
.enables-card p { color:var(--text-mid); font-size:14px; font-weight:300; line-height:1.8; }

/* BRIDGE */
.bridge-section { background:var(--stone); padding:110px 0; }
.bridge-inner { display:grid; grid-template-columns:1fr 1fr; gap:90px; align-items:center; }
.bridge-label { color:var(--purple-soft); font-size:11px; letter-spacing:0.16em; text-transform:uppercase; font-weight:600; margin-bottom:18px; display:block; }
.bridge-title { font-family:var(--font-display); font-size:46px; font-weight:400; color:var(--ink); line-height:1.1; margin-bottom:22px; font-style:italic; }
.bridge-text { color:var(--text-mid); font-size:15px; font-weight:300; line-height:1.85; margin-bottom:16px; }
.bridge-right { display:flex; flex-direction:column; gap:18px; }
.bridge-card { display:flex; gap:18px; align-items:flex-start; padding:22px 24px; background:white; border-radius:var(--radius-md); border:1px solid var(--border); transition:box-shadow var(--transition), border-color var(--transition); }
.bridge-card:hover { box-shadow:var(--shadow-sm); border-color:var(--border-strong); }
.bridge-icon { width:40px; height:40px; border-radius:50%; background:var(--purple-light); display:flex; align-items:center; justify-content:center; flex-shrink:0; font-family:var(--font-display); font-size:17px; color:var(--purple); font-weight:500; }
.bridge-card-text h4 { font-family:var(--font-display); font-size:18px; font-weight:500; color:var(--ink); margin-bottom:4px; }
.bridge-card-text p { color:var(--text-mid); font-size:13.5px; font-weight:300; line-height:1.7; }

/* INSIGHTS */
.insights-section { background:var(--white); padding:110px 0 130px; }
.insights-header { max-width:700px; margin-bottom:64px; }
.insights-title { font-family:var(--font-display); color:var(--ink); font-size:50px; font-weight:400; line-height:1.05; margin-bottom:18px; letter-spacing:-0.4px; }
.insights-subtitle { color:var(--text-mid); font-size:15px; font-weight:300; line-height:1.8; }
.insights-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.insight-card { border:1px solid var(--border); border-radius:var(--radius-lg); overflow:hidden; background:var(--white); display:flex; flex-direction:column; transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition); }
.insight-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); border-color:var(--border-strong); }
.insight-image img { width:100%; height:215px; object-fit:cover; display:block; }
.insight-content { padding:26px 28px 30px; display:flex; flex-direction:column; flex:1; }
.insight-heading { font-family:var(--font-display); font-size:23px; font-weight:400; color:var(--ink); line-height:1.35; margin-bottom:12px; }
.insight-text { color:var(--text-mid); font-size:14px; font-weight:300; line-height:1.8; flex:1; margin-bottom:22px; }
.insight-tags { display:flex; flex-wrap:wrap; gap:7px; margin-top:auto; }
.tag { color:var(--purple); background:var(--purple-light); padding:5px 13px; border-radius:999px; font-size:11px; font-weight:600; letter-spacing:0.04em; text-transform:uppercase; }

/* SOLUTIONS */
.solutions-diagram { margin-top:60px; display:flex; justify-content:center; }
.solutions-diagram img { width:100%; max-width:1040px; border-radius:var(--radius-xl); box-shadow:var(--shadow-lg); }

/* CONTACT */
.contact-section { background:var(--stone); padding:110px 0; }
.contact-title { font-family:var(--font-display); text-align:center; color:var(--ink); font-size:46px; font-weight:400; margin-bottom:12px; letter-spacing:-0.3px; font-style:italic; }
.contact-subtitle { text-align:center; margin-bottom:60px; color:var(--text-light); font-size:15px; font-weight:300; }
.contact-page-section { background:var(--stone); padding:100px 0 130px; }
.contact-page-grid { display:grid; grid-template-columns:1fr 1.9fr; gap:90px; align-items:start; }
.contact-info { display:flex; flex-direction:column; gap:44px; padding-top:4px; }
.contact-info-block { border-left:1px solid var(--border-strong); padding-left:22px; }
.contact-info-label { font-size:10.5px; font-weight:600; letter-spacing:0.14em; text-transform:uppercase; color:var(--purple-soft); margin-bottom:9px; }
.contact-info-value { font-size:15.5px; font-weight:300; color:var(--text-dark); line-height:1.7; }
a.contact-info-value { color:var(--purple); transition:color var(--transition); }
a.contact-info-value:hover { color:var(--purple-mid); }
.contact-info-list { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:9px; }
.contact-info-list li { font-size:14px; color:var(--text-mid); padding-left:16px; position:relative; font-weight:300; line-height:1.6; }
.contact-info-list li::before { content:'–'; position:absolute; left:0; color:var(--purple-soft); }
.contact-form { max-width:840px; margin:0 auto; background:white; border-radius:var(--radius-xl); padding:56px 60px; box-shadow:var(--shadow-md); border:1px solid var(--border); }
.contact-form-wrap { background:white; border-radius:var(--radius-xl); padding:52px 56px; box-shadow:var(--shadow-md); border:1px solid var(--border); }
.form-row { display:flex; gap:20px; margin-bottom:20px; }
.form-group { flex:1; display:flex; flex-direction:column; }
.form-group label { font-size:11px; font-weight:600; margin-bottom:8px; color:var(--text-dark); letter-spacing:0.06em; text-transform:uppercase; }
.form-group input, .form-group select, .form-group textarea { padding:13px 16px; border-radius:var(--radius-sm); border:1px solid #E0D8F0; font-size:14px; font-family:var(--font-body); font-weight:300; color:var(--text-dark); background:var(--purple-pale); transition:border-color var(--transition), box-shadow var(--transition), background var(--transition); }
.form-group input:focus, .form-group textarea:focus, .form-group select:focus { outline:none; border-color:var(--purple); background:white; box-shadow:0 0 0 3px rgba(59,15,160,0.07); }
.form-group textarea { min-height:130px; resize:vertical; }
.form-consent { display:flex; align-items:flex-start; gap:12px; font-size:13px; color:var(--text-mid); margin:26px 0; line-height:1.6; font-weight:300; }
.form-consent input[type="checkbox"] { margin-top:2px; width:16px; height:16px; accent-color:var(--purple); flex-shrink:0; }
.contact-button { background:var(--purple); color:white; border:none; padding:16px 40px; border-radius:var(--radius-sm); font-weight:500; font-size:12.5px; font-family:var(--font-body); letter-spacing:0.08em; text-transform:uppercase; cursor:pointer; transition:background var(--transition), transform var(--transition), box-shadow var(--transition); }
.contact-button:hover { background:var(--purple-mid); transform:translateY(-1px); box-shadow:0 6px 20px rgba(59,15,160,0.25); }
.hidden-field { display:none; }
/* DISCOVERY CALL BOOKING */
.booking-section {
  background: var(--stone);
  padding: 110px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.booking-intro { max-width: 680px; margin-bottom: 64px; }
.booking-intro h2 {
  font-family: var(--font-display);
  font-size: 50px; font-weight: 400;
  letter-spacing: -0.4px; color: var(--ink);
  line-height: 1.05; margin-top: 16px; margin-bottom: 16px;
}
.booking-intro p {
  font-size: 15px; font-weight: 300;
  color: var(--text-mid); line-height: 1.9;
}
.booking-grid {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: 64px; align-items: start;
}

/* Calendar shell */
.booking-calendar-wrap {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--white);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}
.booking-cal-header {
  display: flex; align-items: center;
  justify-content: space-between;
  padding: 22px 24px 18px;
  border-bottom: 1px solid var(--border);
}
.booking-month-label {
  font-family: var(--font-display);
  font-size: 20px; font-weight: 500; color: var(--ink);
}
.booking-nav {
  background: none; border: 1px solid var(--border-strong);
  color: var(--purple); width: 34px; height: 34px;
  border-radius: 50%; cursor: pointer; font-size: 14px;
  display: flex; align-items: center; justify-content: center;
  transition: all var(--transition); font-family: inherit;
}
.booking-nav:hover {
  background: var(--purple); color: white; border-color: var(--purple);
}
.booking-cal-days-header {
  display: grid; grid-template-columns: repeat(7, 1fr);
  padding: 14px 16px 8px; gap: 4px;
}
.booking-cal-days-header span {
  font-size: 10px; font-weight: 600; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--text-light); text-align: center;
}
.booking-cal-grid {
  display: grid; grid-template-columns: repeat(7, 1fr);
  padding: 4px 16px 20px; gap: 4px;
}
.booking-cal-cell {
  aspect-ratio: 1; display: flex; align-items: center;
  justify-content: center; font-size: 13px;
  font-weight: 300; border-radius: var(--radius-sm);
  color: var(--text-light);
}
.booking-cal-disabled {
  color: rgba(138,127,170,0.28); cursor: not-allowed;
}
.booking-cal-available {
  color: var(--ink); font-weight: 500; cursor: pointer;
  background: var(--purple-pale);
  border: 1px solid transparent;
  transition: all var(--transition);
}
.booking-cal-available:hover {
  background: var(--purple-light); border-color: var(--border-strong);
}
.booking-cal-selected {
  background: var(--purple) !important;
  color: white !important;
  border-color: var(--purple) !important;
}
.booking-cal-note {
  font-size: 11px; font-weight: 300; color: var(--text-light);
  text-align: center; padding: 0 16px 18px; letter-spacing: 0.03em;
}

/* Right column */
.booking-right { display: flex; flex-direction: column; gap: 24px; }
.booking-slots-placeholder {
  font-size: 14px; font-weight: 300;
  color: var(--text-light); font-style: italic;
  padding: 20px 0; border-top: 1px solid var(--border);
}
.booking-slots-date {
  font-size: 11px; font-weight: 600; letter-spacing: 0.10em;
  text-transform: uppercase; color: var(--purple-soft);
  margin-bottom: 16px; padding-top: 20px;
  border-top: 1px solid var(--border);
}
.booking-slots-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px;
  margin-bottom: 8px;
}
.booking-slot-btn {
  background: var(--purple-pale); border: 1px solid var(--border);
  color: var(--ink); padding: 11px 6px;
  border-radius: var(--radius-sm);
  font-size: 13px; font-weight: 400;
  font-family: var(--font-body); cursor: pointer;
  transition: all var(--transition); text-align: center;
}
.booking-slot-btn:hover {
  background: var(--purple-light); border-color: var(--border-strong);
}
.booking-slot-btn.active {
  background: var(--purple); color: white; border-color: var(--purple);
}

/* Booking form */
.booking-form-summary {
  font-size: 13px; font-weight: 500; color: var(--purple);
  background: var(--purple-pale); border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm); padding: 14px 18px;
  margin-bottom: 24px; letter-spacing: 0.02em;
}
.booking-label-note {
  font-weight: 300; text-transform: none; letter-spacing: 0;
  color: var(--text-light); font-size: 10.5px;
}
.booking-form-actions {
  display: flex; gap: 16px; align-items: center; flex-wrap: wrap;
}
.booking-back-btn {
  background: none; border: none; color: var(--text-light);
  font-size: 12.5px; font-family: var(--font-body);
  cursor: pointer; padding: 0; transition: color var(--transition);
}
.booking-back-btn:hover { color: var(--purple); }

/* Success state */
.booking-success-inner {
  padding: 44px 40px;
  background: var(--purple-pale);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-lg);
  text-align: center;
}
.booking-success-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 48px; height: 48px; border-radius: 50%;
  background: var(--purple); color: white;
  font-size: 20px; margin-bottom: 20px;
}
.booking-success-inner h3 {
  font-family: var(--font-display); font-size: 28px;
  font-weight: 500; color: var(--ink); margin-bottom: 12px;
}
.booking-success-inner p {
  font-size: 14px; font-weight: 300;
  color: var(--text-mid); line-height: 1.8;
}

/* Responsive */
@media (max-width: 900px) {
  .booking-grid { grid-template-columns: 1fr; gap: 40px; }
  .booking-intro h2 { font-size: 36px; }
  .booking-slots-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 640px) {
  .booking-intro h2 { font-size: 30px; }
  .booking-slots-grid { grid-template-columns: repeat(2, 1fr); }
}

/* PHASE FLOW */
.phase-flow {
  display: flex;
  align-items: center;
  gap: 0;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--white);
  box-shadow: var(--shadow-sm);
}
.phase-card {
  flex: 1;
  padding: 48px 36px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  border-right: 1px solid var(--border);
  transition: background var(--transition);
}
.phase-card:last-child { border-right: none; }
.phase-card:hover { background: var(--purple-pale); }
.phase-number {
  font-family: var(--font-display);
  font-size: 52px;
  font-weight: 300;
  color: rgba(59,15,160,0.08);
  line-height: 1;
}
.phase-title {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 500;
  color: var(--ink);
  line-height: 1.2;
  margin: 0;
}
.phase-desc {
  font-size: 14px;
  font-weight: 300;
  color: var(--text-mid);
  line-height: 1.7;
  margin: 0;
}
.phase-arrow {
  font-size: 20px;
  color: var(--purple-soft);
  padding: 0 4px;
  flex-shrink: 0;
  background: var(--white);
}

/* Responsive */
@media (max-width: 900px) {
  .phase-flow {
    flex-direction: column;
  }
  .phase-card {
    border-right: none;
    border-bottom: 1px solid var(--border);
    padding: 36px 28px;
  }
  .phase-card:last-child { border-bottom: none; }
  .phase-arrow {
    transform: rotate(90deg);
    padding: 4px 0;
  }
}


/* FOOTER */
.footer { background:var(--purple-dark); padding:32px 0; border-top:1px solid rgba(255,255,255,0.06); }
.footer-inner { display:flex; justify-content:space-between; align-items:center; gap:20px; flex-wrap:wrap; color:rgba(255,255,255,0.42); font-size:12.5px; font-weight:400; letter-spacing:0.02em; }
.footer-links { display:flex; gap:28px; align-items:center; }
.footer-links a { color:rgba(255,255,255,0.55); transition:color var(--transition); }
.footer-links a:hover { color:rgba(255,255,255,0.90); }

/* ANIMATION */
@keyframes fadeInUp { from { opacity:0; transform:translateY(24px); } to { opacity:1; transform:translateY(0); } }

/* RESPONSIVE */
@media (max-width:1024px) {
  .container { padding-left:40px; padding-right:40px; }
  .enables-grid, .services-grid, .packages-grid { grid-template-columns:repeat(2,1fr); }
  .values-grid { grid-template-columns:repeat(3,1fr); }
  .methodology-grid { grid-template-columns:1fr 1fr; }
}
@media (max-width:900px) {
  .container { padding-left:24px; padding-right:24px; }
  .nav-links { display:none; }
  .page-header h1 { font-size:50px; }
  .quote-text { font-size:36px; }
  .insights-title, .enables-section h2, .section h2 { font-size:38px; }
  .insights-grid, .enables-grid, .why-grid, .services-grid, .packages-grid { grid-template-columns:1fr; }
  .values-grid { grid-template-columns:1fr 1fr; }
  .methodology-grid { grid-template-columns:1fr; }
  .bridge-inner, .contact-page-grid, .about-grid, .founder-inner { grid-template-columns:1fr; gap:48px; }
  .contact-form, .contact-form-wrap { padding:36px 28px; }
  .form-row { flex-direction:column; }
  .hero-description { left:24px; right:24px; max-width:none; bottom:44px; font-size:15px; }
  .diagram-left { padding:30px 26px; }
  .process-step { grid-template-columns:50px 1fr; gap:24px; }
}
@media (max-width:640px) {
  .page-header h1 { font-size:40px; }
  .quote-text { font-size:28px; }
  .contact-title { font-size:32px; }
  .insights-title, .enables-section h2, .section h2 { font-size:30px; }
  .bridge-title { font-size:34px; }
  .values-grid { grid-template-columns:1fr; }
  .diagram-wrap img { width:90%; }
}