/*
Theme Name:   Divi Child
Description:  Child theme for Divi
Author:       Luminous
Template:     Divi
Version:      1.0.1
*/


/* Für das MS Logo */
.gugi {
  font-family: 'Gugi' !important;
  letter-spacing: 1px;
  color: white !important;
}

/* ═══════════════════════════════════════
   SELF-HOSTED FONTS (DSGVO-konform)
   ═══════════════════════════════════════ */

/* outfit-200 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 200;
  src: url('../fonts/outfit-v15-latin-200.woff2') format('woff2');
}
/* outfit-300 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 300;
  src: url('../fonts/outfit-v15-latin-300.woff2') format('woff2');
}
/* outfit-regular - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/outfit-v15-latin-regular.woff2') format('woff2');
}
/* outfit-500 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 500;
  src: url('../fonts/outfit-v15-latin-500.woff2') format('woff2');
}
/* outfit-600 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 600;
  src: url('../fonts/outfit-v15-latin-600.woff2') format('woff2');
}
/* outfit-700 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/outfit-v15-latin-700.woff2') format('woff2');
}

/* jetbrains-mono-regular - latin */
@font-face {
  font-display: swap;
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/jetbrains-mono-v24-latin-regular.woff2') format('woff2');
}
/* jetbrains-mono-500 - latin */
@font-face {
  font-display: swap;
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  src: url('../fonts/jetbrains-mono-v24-latin-500.woff2') format('woff2');
}

/* ═══════════════════════════════════════
   Divi Standard-Navigation + Footer ausblenden
   ═══════════════════════════════════════ */
header#main-header,
header#main-header.et-fixed-header,
#top-header,
#main-header .et_menu_container,
#et-top-navigation,
.et_mobile_menu,
#page-container #main-header,
#main-footer,
#footer-info,
.et-l--footer,
.et-l--header {
  display: none !important;
  height: 0 !important;
  min-height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  visibility: hidden !important;
  overflow: hidden !important;
}

/* ═══════════════════════════════════════
   CRM SYNERGY — Page Styles
   ═══════════════════════════════════════ */

/* VARIABLES */
.crms-page {
  --bg:#0c0c0e; --bg-card:rgba(255,255,255,.04); --surface:#141416;
  --border:rgba(255,255,255,.07); --border-hi:rgba(255,255,255,.14);
  --text:rgba(255,255,255,.72); --text-dim:rgba(255,255,255,.38); --text-hi:rgba(255,255,255,.92);
  --accent:#3b82f6; --accent-dim:rgba(59,130,246,.12);
  --emerald:#34d399; --emerald-dim:rgba(52,211,153,.10);
  --rose:#fb7185; --radius:1.25rem; --radius-lg:2rem;

  font-family:'Outfit',sans-serif;
  background:var(--bg);
  color:var(--text);
  font-weight:300;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}

/* Force dark background everywhere */
body,
#page-container,
#et-main-area,
.et-l,
.et-l--body,
.et_builder_inner_content,
.crms-page {
  background-color:#0c0c0e !important;
}

/* Reset Divi defaults inside our page */
.crms-page *, .crms-page *::before, .crms-page *::after { margin:0; padding:0; box-sizing:border-box; }
.crms-page .et_pb_section { padding:0 !important; margin:0 !important; background:transparent !important; }
.crms-page .et_pb_row { padding:0 !important; width:100% !important; max-width:100% !important; margin:0 !important; }
.crms-page .et_pb_column { padding:0 !important; }
.crms-page .et_pb_code_inner { padding:0 !important; }
.crms-page #page-container { padding-top:0 !important; margin-top:0 !important; }
.crms-page .et_builder_inner_content { margin-top:0 !important; padding-top:0 !important; }
.crms-page .et_pb_section:first-child { padding-top:0 !important; margin-top:0 !important; }

/* Prevent Divi containers from creating stacking contexts */
.crms-page .et_pb_section,
.crms-page .et_pb_row,
.crms-page .et_pb_column,
.crms-page .et_pb_module,
.crms-page .et_pb_code,
.crms-page .et_pb_code_inner {
  z-index:auto !important;
  transform:none !important;
  overflow:visible !important;
  max-width:100vw !important;
}

/* Prevent horizontal scroll — use clip instead of hidden to preserve sticky */
#page-container { overflow-x:clip; max-width:100vw; }
.crms-mesh { max-width:100vw; }
.crms-pain-grid, .crms-features-grid, .crms-usp-strip, .crms-contact-layout { max-width:100%; }

/* Meetings embed: prevent it from causing layout jumps */
.meetings-iframe-container { min-height:650px; }
.meetings-iframe-container iframe { min-height:600px; }

/* Wrapper */
.crms-wrapper { position:relative; z-index:1; overflow-x:clip; }
.crms-container { max-width:1280px; margin:0 auto; padding:0 2rem; }
.crms-section { padding:9rem 0 !important; }

/* MESH */
.crms-mesh { position:fixed; inset:0; z-index:0; pointer-events:none; overflow:hidden; }
.crms-mesh-orb { position:absolute; border-radius:50%; filter:blur(90px); opacity:.16; will-change:transform; }
.crms-mesh-orb:nth-child(1) { width:600px; height:600px; background:var(--accent); top:-10%; left:-8%; animation:crmsD1 22s ease-in-out infinite alternate; }
.crms-mesh-orb:nth-child(2) { width:500px; height:500px; background:var(--emerald); bottom:-15%; right:-10%; animation:crmsD2 26s ease-in-out infinite alternate; }
.crms-mesh-orb:nth-child(3) { width:400px; height:400px; background:var(--rose); top:50%; left:50%; animation:crmsD3 20s ease-in-out infinite alternate; }
@keyframes crmsD1{to{transform:translate(120px,80px) scale(1.1)}}
@keyframes crmsD2{to{transform:translate(-100px,-60px) scale(.9)}}
@keyframes crmsD3{to{transform:translate(-80px,60px) scale(1.15)}}

/* NAV */
.crms-nav {
  position:fixed; top:0; left:0; right:0; z-index:999999;
  display:flex; justify-content:space-between; align-items:center;
  padding:0 2.5rem; height:64px;
  background:rgba(12,12,14,.35); backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(255,255,255,.04);
}
.crms-nav-logo { display:flex; align-items:center; gap:.5rem; text-decoration:none; }
.crms-nav-logo svg { height:22px; width:auto; }
.crms-nav-logo-text { font-weight:600; font-size:1.05rem; letter-spacing:.3px; color:var(--text-hi); }
.crms-nav-logo-text span { color:var(--accent); }
.crms-nav-links { display:flex; gap:2rem; list-style:none; align-items:center; }
.crms-nav-links a { font-size:.75rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-dim); text-decoration:none; transition:color .3s; font-weight:400; }
.crms-nav-links a:hover { color:var(--accent); }
.crms-nav-cta {
  font-size:.72rem; letter-spacing:1.5px; text-transform:uppercase;
  padding:.5rem 1.2rem; border:1px solid var(--accent);
  color:var(--accent)!important; border-radius:.5rem;
  transition:background .25s,color .25s,transform .2s;
}
.crms-nav-cta:hover { background:var(--accent); color:var(--bg)!important; transform:translateY(-1px); }
.crms-nav-hamburger { display:none; background:none; border:none; cursor:pointer; padding:12px; flex-direction:column; gap:5px; z-index:99999999; position:relative; -webkit-tap-highlight-color:transparent; touch-action:manipulation; }
.crms-nav-hamburger span { display:block; width:20px; height:1.5px; background:var(--text-hi); transition:transform .35s cubic-bezier(.16,1,.3,1),opacity .25s; }
.crms-nav-hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.crms-nav-hamburger.open span:nth-child(2){opacity:0}
.crms-nav-hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.crms-mobile-nav {
  position:fixed; inset:0; z-index:9999999;
  background:rgba(12,12,14,.98); backdrop-filter:blur(28px);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:2rem;
  opacity:0; pointer-events:none; visibility:hidden; transition:opacity .4s,visibility .4s;
}
.crms-mobile-nav.open { opacity:1; pointer-events:all; visibility:visible; }
.crms-mobile-nav-close {
  position:absolute; top:1.25rem; right:1.25rem;
  background:none; border:1px solid var(--accent); border-radius:50%;
  width:40px; height:40px; display:flex; align-items:center; justify-content:center;
  cursor:pointer; color:var(--accent); transition:background .25s,transform .25s;
}
.crms-mobile-nav-close:hover { background:var(--accent-dim); transform:rotate(90deg); }
.crms-mobile-nav-close svg { width:18px; height:18px; }
.crms-mobile-nav a { font-size:clamp(1.4rem,5vw,2rem); font-weight:300; color:var(--text-dim); text-decoration:none; transition:color .3s; }
.crms-mobile-nav a:hover { color:var(--accent); }

/* BUTTONS */
.crms-btn-primary {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.85rem 2rem; background:var(--accent);
  color:var(--bg); font-weight:500; font-size:.85rem;
  letter-spacing:.5px; text-decoration:none;
  border-radius:.65rem; border:none; cursor:pointer;
  transition:transform .25s cubic-bezier(.16,1,.3,1),box-shadow .3s;
}
.crms-btn-primary:hover { transform:translateY(-2px); box-shadow:0 12px 32px rgba(59,130,246,.25); }
.crms-btn-primary:active { transform:translateY(0) scale(.98); }
.crms-btn-ghost {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.85rem 2rem; background:transparent;
  color:var(--text-hi); font-weight:400; font-size:.85rem;
  letter-spacing:.5px; text-decoration:none;
  border-radius:.65rem; border:1px solid var(--border-hi);
  transition:border-color .3s,color .3s,transform .2s;
}
.crms-btn-ghost:hover { border-color:var(--accent); color:var(--accent); transform:translateY(-1px); }

/* SECTION HEADERS */
.crms-stag { font-family:'JetBrains Mono',monospace; font-size:.65rem; letter-spacing:3px; text-transform:uppercase; color:var(--accent); margin-bottom:.75rem; }
.crms-stitle { font-size:clamp(1.8rem,3.5vw,2.8rem); font-weight:600; line-height:1.12; letter-spacing:-.02em; color:var(--text-hi); margin-bottom:1rem; }
.crms-sdesc { font-size:1rem; color:var(--text); max-width:55ch; line-height:1.75; }

/* HERO */
.crms-hero { min-height:100dvh; display:flex; align-items:center; padding-top:5rem; padding-bottom:4rem; }
.crms-hero-inner { display:grid; grid-template-columns:1.2fr 1fr; gap:4rem; align-items:center; width:100%; }
.crms-hero-tag { font-family:'JetBrains Mono',monospace; font-size:.7rem; letter-spacing:3px; text-transform:uppercase; color:var(--accent); margin-bottom:1.5rem; display:flex; align-items:center; gap:.75rem; }
.crms-hero-tag::before { content:''; width:32px; height:1px; background:var(--accent); }
.crms-hero h1 { font-size:clamp(2.4rem,5.5vw,3.8rem); font-weight:600; line-height:1.1; letter-spacing:-.03em; color:var(--text-hi); margin-bottom:1.5rem; }
.crms-hero h1 em { font-style:italic; font-weight:300; background:linear-gradient(135deg,var(--accent),var(--emerald)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.crms-hero p { font-size:1.05rem; max-width:50ch; color:var(--text); margin-bottom:2.5rem; line-height:1.75; }
.crms-hero-actions { display:flex; gap:1rem; align-items:center; flex-wrap:wrap; }
.crms-hero-canvas-wrap { position:relative; aspect-ratio:1; max-width:460px; width:100%; min-height:300px; margin-left:auto; }
#heroCanvas { width:100%; height:100%; display:block; cursor:crosshair; }

/* SCROLL STORY */
.crms-scroll-story { padding:0; position:relative; }
.crms-scroll-story-track { height:700vh; position:relative; }
.crms-scroll-story-sticky {
  position:sticky; top:0; height:100vh;
  display:grid; grid-template-columns:1fr 1fr; align-items:center;
  padding:0 2rem; max-width:1280px; margin:0 auto;
}
.crms-story-canvas-wrap { position:relative; width:100%; height:70vh; max-height:560px; overflow:hidden; }
.crms-story-canvas-wrap canvas { width:100%; height:100%; display:block; }
.crms-story-text-stack { position:relative; min-height:220px; }
.crms-story-panel {
  position:absolute; top:0; left:0; right:0;
  display:flex; flex-direction:column; justify-content:flex-start;
  pointer-events:none;
  padding:1.25rem 1.75rem;
  border-left:2px solid transparent;
  border-radius:0 var(--radius) var(--radius) 0;
  will-change:transform,opacity;
}
.crms-story-panel.active {
  pointer-events:auto;
}
.crms-story-panel .crms-stag { margin-bottom:.4rem; font-size:.7rem; font-family:'JetBrains Mono',monospace; letter-spacing:3px; text-transform:uppercase; color:#3b82f6; }
.crms-story-panel h3 { font-size:clamp(1.4rem,2.5vw,2rem); font-weight:700; color:#fff; margin-bottom:.75rem; letter-spacing:-.02em; line-height:1.15; }
.crms-story-panel p { color:rgba(255,255,255,.65); line-height:1.8; max-width:44ch; }
.crms-story-progress { position:absolute; bottom:2rem; left:50%; transform:translateX(-50%); display:flex; gap:.5rem; }
.crms-story-dot { width:32px; height:3px; border-radius:2px; background:var(--border); transition:background .4s,width .4s; cursor:pointer; }
.crms-story-dot.active { background:var(--accent); width:48px; }
.crms-scroll-hint {
  position:absolute; bottom:3.5rem; left:50%; transform:translateX(-50%);
  font-family:'JetBrains Mono',monospace; font-size:.6rem; letter-spacing:2px;
  text-transform:uppercase; color:var(--text-dim);
  display:flex; flex-direction:column; align-items:center; gap:.5rem;
  animation:crmsScrollHint 2s ease-in-out infinite;
}
.crms-scroll-hint svg { width:16px; height:16px; stroke:var(--accent); fill:none; stroke-width:1.5; }
@keyframes crmsScrollHint { 0%,100%{opacity:.4;transform:translateX(-50%) translateY(0)} 50%{opacity:.8;transform:translateX(-50%) translateY(4px)} }

/* PAIN POINTS */
.crms-pain-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.25rem; margin-top:3.5rem; }
.crms-pain-card {
  padding:2rem 1.5rem; border-radius:var(--radius);
  background:var(--bg-card); border:1px solid var(--border);
  position:relative; overflow:hidden; text-align:center;
  transition:border-color .35s,transform .35s cubic-bezier(.16,1,.3,1);
}
.crms-pain-card::before { content:''; position:absolute; inset:0; box-shadow:inset 0 1px 0 rgba(255,255,255,.07); border-radius:inherit; pointer-events:none; }
.crms-pain-card::after {
  content:''; position:absolute; inset:0; border-radius:inherit;
  background:radial-gradient(300px circle at var(--mx,50%) var(--my,50%),rgba(251,113,133,.06),transparent 60%);
  pointer-events:none; opacity:0; transition:opacity .35s;
}
.crms-pain-card:hover::after { opacity:1; }
.crms-pain-card:hover { border-color:var(--rose); transform:translateY(-3px); }
.crms-pain-icon { width:48px; height:48px; border-radius:.85rem; margin:0 auto 1rem; display:flex; align-items:center; justify-content:center; background:rgba(251,113,133,.08); }
.crms-pain-icon svg { width:22px; height:22px; stroke:var(--rose); fill:none; stroke-width:1.5; }
.crms-pain-card h4 { font-size:.95rem; font-weight:600; color:#fff; margin-bottom:.4rem; }
.crms-pain-card p { font-size:.82rem; color:rgba(255,255,255,.58); line-height:1.6; }

/* FEATURES */
.crms-features-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.25rem; margin-top:3.5rem; }
.crms-feature-card {
  padding:2rem; border-radius:var(--radius);
  background:var(--bg-card); border:1px solid var(--border);
  position:relative; overflow:hidden;
  transition:border-color .35s,transform .35s cubic-bezier(.16,1,.3,1);
}
.crms-feature-card::before { content:''; position:absolute; inset:0; box-shadow:inset 0 1px 0 rgba(255,255,255,.07); border-radius:inherit; pointer-events:none; }
.crms-feature-card::after {
  content:''; position:absolute; inset:0; border-radius:inherit;
  background:radial-gradient(400px circle at var(--mx,50%) var(--my,50%),rgba(59,130,246,.06),transparent 60%);
  pointer-events:none; opacity:0; transition:opacity .35s;
}
.crms-feature-card:hover::after { opacity:1; }
.crms-feature-card:hover { border-color:var(--border-hi); transform:translateY(-3px); }
.crms-feature-card.wide { grid-column:span 2; }
.crms-feature-icon { width:40px; height:40px; border-radius:.75rem; margin-bottom:1.25rem; display:flex; align-items:center; justify-content:center; background:var(--accent-dim); }
.crms-feature-icon svg { width:18px; height:18px; stroke:var(--accent); fill:none; stroke-width:1.5; }
.crms-feature-icon.em { background:var(--emerald-dim); }
.crms-feature-icon.em svg { stroke:var(--emerald); }
.crms-feature-card h4 { font-size:1rem; font-weight:600; color:var(--text-hi); margin-bottom:.5rem; }
.crms-feature-card p { font-size:.88rem; color:rgba(255,255,255,.55); line-height:1.65; }

/* USP */
.crms-usp-strip { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; margin-top:3.5rem; }
.crms-usp-card {
  padding:2.5rem; border-radius:var(--radius-lg);
  background:var(--bg-card); border:1px solid var(--border);
  position:relative; overflow:visible;
}
.crms-usp-card::before { content:''; position:absolute; inset:0; box-shadow:inset 0 1px 0 rgba(255,255,255,.07); border-radius:inherit; pointer-events:none; }
.crms-usp-card h3 { font-size:1.3rem; font-weight:600; color:var(--text-hi); margin-bottom:.75rem; }
.crms-usp-card p { font-size:.9rem; color:rgba(255,255,255,.6); line-height:1.75; }
.crms-usp-accent { border-color:var(--accent); }
.crms-usp-card img[alt*="Provider"], .crms-usp-card img[alt*="Badge"] { filter:invert(1) brightness(1.8); }

/* ROUTE */
.crms-route-steps { display:flex; flex-direction:column; margin-top:3.5rem; position:relative; }
.crms-route-steps::before { content:''; position:absolute; left:24px; top:0; bottom:0; width:1px; background:var(--border); }
.crms-route-step { display:grid; grid-template-columns:48px 1fr; gap:2rem; padding:2.5rem 0; position:relative; }
.crms-route-step:not(:last-child) { border-bottom:1px solid var(--border); }
.crms-step-num { width:48px; height:48px; border-radius:50%; display:flex; align-items:center; justify-content:center; background:var(--surface); border:1px solid var(--border); font-family:'JetBrains Mono',monospace; font-size:.8rem; color:var(--accent); font-weight:500; position:relative; z-index:1; }
.crms-route-step h4 { font-size:1.3rem; font-weight:600; color:var(--text-hi); margin-bottom:.75rem; }
.crms-route-step p { font-size:.92rem; color:rgba(255,255,255,.6); line-height:1.75; max-width:60ch; }
.crms-route-tag { display:inline-block; font-family:'JetBrains Mono',monospace; font-size:.6rem; letter-spacing:1.5px; text-transform:uppercase; padding:.2rem .6rem; border-radius:2rem; margin-bottom:.5rem; background:var(--accent-dim); color:var(--accent); }

/* CONTACT */
.crms-contact-layout { display:grid; grid-template-columns:1fr 1fr; gap:4rem; margin-top:3.5rem; align-items:start; }
.crms-contact-layout > div:last-child { position:sticky; top:6rem; }
.crms-contact-info h3 { font-size:1.6rem; font-weight:700; color:#fff; margin-bottom:1rem; letter-spacing:-.02em; }
.crms-contact-info p { color:var(--text); line-height:1.8; margin-bottom:2rem; }
.crms-contact-detail { display:flex; align-items:center; gap:.75rem; margin-bottom:1rem; color:var(--text-dim); font-size:.9rem; }
.crms-contact-detail svg { width:18px; height:18px; stroke:var(--accent); fill:none; stroke-width:1.5; flex-shrink:0; }
.crms-contact-form { display:flex; flex-direction:column; gap:1rem; }
.crms-form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.crms-form-group { display:flex; flex-direction:column; gap:.4rem; }
.crms-form-group label { font-size:.72rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-dim); }
.crms-form-group input,.crms-form-group textarea { padding:.85rem 1rem; background:var(--bg-card); border:1px solid var(--border); border-radius:.65rem; color:var(--text-hi); font-family:'Outfit',sans-serif; font-size:.9rem; outline:none; transition:border-color .3s; }
.crms-form-group input:focus,.crms-form-group textarea:focus { border-color:var(--accent); }
.crms-form-group textarea { resize:vertical; min-height:120px; }
.crms-form-or { text-align:center; font-size:.78rem; color:var(--text-dim); margin:.5rem 0; letter-spacing:1px; text-transform:uppercase; font-family:'JetBrains Mono',monospace; }

/* HubSpot Form Overrides */
.crms-page .hs-form label,
.crms-page .hs-form .hs-form-field > label { color:rgba(255,255,255,.55) !important; font-family:'Outfit',sans-serif !important; font-size:.78rem !important; letter-spacing:1px !important; text-transform:uppercase !important; font-weight:400 !important; }
.crms-page .hs-form input[type="text"],
.crms-page .hs-form input[type="email"],
.crms-page .hs-form input[type="tel"],
.crms-page .hs-form input[type="number"],
.crms-page .hs-form textarea,
.crms-page .hs-form select { background:rgba(255,255,255,.04) !important; border:1px solid rgba(255,255,255,.07) !important; border-radius:.65rem !important; color:rgba(255,255,255,.92) !important; font-family:'Outfit',sans-serif !important; font-size:.9rem !important; padding:.85rem 1rem !important; }
.crms-page .hs-form input:focus,
.crms-page .hs-form textarea:focus,
.crms-page .hs-form select:focus { border-color:#3b82f6 !important; outline:none !important; }
.crms-page .hs-form .hs-button,
.crms-page .hs-form input[type="submit"] { background:#3b82f6 !important; color:#0c0c0e !important; border:none !important; border-radius:.65rem !important; padding:.85rem 2rem !important; font-family:'Outfit',sans-serif !important; font-weight:500 !important; font-size:.85rem !important; letter-spacing:.5px !important; cursor:pointer !important; transition:transform .25s,box-shadow .3s !important; width:100% !important; }
.crms-page .hs-form .hs-button:hover,
.crms-page .hs-form input[type="submit"]:hover { transform:translateY(-2px) !important; box-shadow:0 12px 32px rgba(59,130,246,.25) !important; }
.crms-page .hs-form .hs-error-msgs label { color:#fb7185 !important; font-size:.75rem !important; }
.crms-page .hs-form .hs-richtext p { color:rgba(255,255,255,.5) !important; font-size:.85rem !important; }
.crms-page .hs-form fieldset { max-width:100% !important; }
.crms-page .hs-form .input { margin-right:0 !important; }
.crms-page .hs-form .hs-form-field { margin-bottom:.75rem !important; }

/* HubSpot Meetings Embed Override */
.crms-page .meetings-iframe-container iframe { border-radius:var(--radius) !important; }

/* FAQ */
.crms-faq-list { margin-top:3.5rem; max-width:780px; }
.crms-faq-item { border-bottom:1px solid var(--border); }
.crms-faq-q { width:100%; display:flex; justify-content:space-between; align-items:center; padding:1.5rem 0; background:none; border:none; cursor:pointer; color:var(--text-hi); font-family:'Outfit',sans-serif; font-size:1rem; font-weight:400; text-align:left; transition:color .3s; }
.crms-faq-q:hover { color:var(--accent); }
.crms-faq-q svg { width:18px; height:18px; stroke:var(--text-dim); fill:none; stroke-width:1.5; flex-shrink:0; transition:transform .35s cubic-bezier(.16,1,.3,1),stroke .3s; }
.crms-faq-item.open .crms-faq-q svg { transform:rotate(45deg); stroke:var(--accent); }
.crms-faq-a { max-height:0; overflow:hidden; transition:max-height .4s cubic-bezier(.16,1,.3,1),padding .3s; }
.crms-faq-item.open .crms-faq-a { max-height:300px; padding-bottom:1.5rem; }
.crms-faq-a p { font-size:.9rem; color:var(--text); line-height:1.75; }

/* FOOTER */
.crms-footer { padding:3rem 0; border-top:1px solid var(--border); margin-top:2rem; }
.crms-footer-inner { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem; }
.crms-footer-logo { display:flex; align-items:center; gap:.5rem; text-decoration:none; }
.crms-footer-logo svg { height:18px; width:auto; }
.crms-footer-logo-text { font-weight:600; font-size:.95rem; color:var(--text-hi); }
.crms-footer-logo-text span { color:var(--accent); }
.crms-footer-links { display:flex; gap:1.5rem; }
.crms-footer-links a { font-size:.78rem; color:var(--text-dim); text-decoration:none; transition:color .3s; }
.crms-footer-links a:hover { color:var(--accent); }
.crms-footer-copy { font-size:.72rem; color:var(--text-dim); width:100%; text-align:center; margin-top:1rem; }

/* REVEAL */
.crms-reveal { opacity:0; transform:translateY(28px); transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1); }
.crms-reveal.visible { opacity:1; transform:translateY(0); }

/* RESPONSIVE */
@media(max-width:960px){
  .crms-nav-links{display:none} .crms-nav-hamburger{display:flex}
  .crms-hero-inner{grid-template-columns:1fr} .crms-hero-canvas-wrap{display:none}
  .crms-scroll-story-track{height:550vh}
  .crms-scroll-story-sticky{
    grid-template-columns:1fr; padding:0 1.5rem;
    grid-template-rows:auto 1fr auto; gap:0;
  }
  .crms-story-canvas-wrap{height:40vh; max-height:280px; margin-top:80px;}
  .crms-story-text-stack{height:auto; min-height:160px;}
  .crms-story-progress{position:relative; bottom:auto; left:auto; transform:none; margin-top:auto; padding-bottom:1.5rem; justify-content:center;}
  .crms-scroll-hint{display:none}
  .crms-pain-grid{grid-template-columns:1fr 1fr}
  .crms-features-grid{grid-template-columns:1fr 1fr} .crms-feature-card.wide{grid-column:span 1}
  .crms-usp-strip{grid-template-columns:1fr}
  .crms-usp-card[style*="grid-column:span 2"], .crms-usp-card[style*="grid-column: span 2"] { grid-column:span 1 !important; }
  .crms-usp-card[style*="display:flex"] > div[style*="display:flex"], .crms-usp-card div[style*="display:flex"] { flex-direction:column !important; gap:1.25rem !important; }
  .crms-usp-card div[style*="min-width"] { min-width:0 !important; }
  .crms-contact-layout{grid-template-columns:1fr;gap:3rem}
  .crms-contact-layout > div:last-child { position:relative; top:auto; }
  .meetings-iframe-container { min-height:500px; }
}
@media(max-width:600px){
  .crms-section{padding:5rem 0} .crms-container{padding:0 1.25rem} .crms-nav{padding:0 1.25rem}
  .crms-hero{padding-top:4.5rem; padding-bottom:1.5rem; min-height:100dvh; align-items:flex-start; justify-content:center;}
  .crms-hero-tag{margin-bottom:.75rem; font-size:.6rem;}
  .crms-hero h1{font-size:clamp(1.6rem,6.5vw,2.2rem); margin-bottom:.75rem;}
  .crms-hero p{font-size:.88rem; margin-bottom:1.25rem; line-height:1.65;}
  .crms-hero-actions{flex-direction:column; gap:.75rem;}
  .crms-hero-actions a,.crms-hero-actions button{width:100%;justify-content:center;text-align:center; padding:.75rem 1.5rem; font-size:.8rem;}
  .crms-pain-grid{grid-template-columns:1fr} .crms-pain-card{text-align:left}
  .crms-pain-icon{margin:0 0 1rem 0}
  .crms-features-grid{grid-template-columns:1fr}
  .crms-form-row{grid-template-columns:1fr}
  .crms-route-step{grid-template-columns:40px 1fr;gap:1.25rem} .crms-step-num{width:40px;height:40px;font-size:.7rem}
  .crms-scroll-story-track{height:500vh}
  .crms-scroll-story-sticky{padding:0 1.25rem}
  .crms-story-canvas-wrap{height:35vh; max-height:220px; margin-top:72px}
  .crms-story-panel h3{font-size:1.2rem}
  .crms-story-panel p{font-size:.88rem}
  .crms-usp-card{padding:1.5rem}
  .crms-usp-card h3{font-size:1.1rem}
  .crms-usp-card p{font-size:.85rem}
  .crms-feature-card{padding:1.5rem}
  .crms-footer-inner{flex-direction:column; text-align:center}
  .crms-footer-links{justify-content:center; flex-wrap:wrap}
  .crms-mesh-orb{filter:blur(120px) !important; opacity:.1 !important}
  .crms-mesh-orb:nth-child(1){width:280px;height:280px}
  .crms-mesh-orb:nth-child(2){width:240px;height:240px}
  .crms-mesh-orb:nth-child(3){width:200px;height:200px}
}
@media(hover:none){
  .crms-feature-card:hover,.crms-pain-card:hover,.crms-usp-card:hover{transform:none;border-color:var(--border)}
  .crms-feature-card::after,.crms-pain-card::after{display:none}
  .crms-btn-primary:hover{transform:none;box-shadow:none}
  .crms-btn-ghost:hover{transform:none}
}
@supports(padding:env(safe-area-inset-bottom)){
  .crms-footer{padding-bottom:calc(3rem + env(safe-area-inset-bottom))}
  .crms-mobile-nav{padding-bottom:env(safe-area-inset-bottom)}
}
