/* Mochi — OpenClaw shared styles */
:root {
  --coral:       #E8635C;
  --coral-light: #EF8880;
  --coral-dark:  #C94A44;
  --coral-soft:  #FDF0EF;
  --coral-mid:   #F5C5C3;
  --bg:          #FEF5F4;
  --white:       #FFFFFF;
  --dark:        #2D1810;
  --dark-mid:    #5C3828;
  --mid:         #A07060;
  --light-text:  #C4957F;
  --green:       #4CAF82;
  --purple:      #9B7FD4;
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; scroll-padding-top:100px; }
html, body { overflow-x:hidden; width:100%; }
body { font-family:'Nunito Sans',sans-serif; background:var(--bg); color:var(--dark); }
img { max-width:100%; height:auto; }

/* BLOBS */
.blob-bg { position:fixed; inset:0; pointer-events:none; z-index:0; overflow:hidden; }
.blob { position:absolute; border-radius:50%; filter:blur(90px); opacity:0.15; }
.blob-1 { width:600px; height:600px; background:var(--coral); top:-200px; right:-200px; }
.blob-2 { width:400px; height:400px; background:var(--coral-light); bottom:10%; left:-150px; }

/* NAV */
nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  padding:14px 48px; display:flex; align-items:center; justify-content:space-between;
  background:rgba(254,245,244,0.92); backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(232,99,92,0.1);
}
.nav-logo { display:flex; align-items:center; gap:10px; text-decoration:none; }
.nav-logo img { width:80px; height:80px; object-fit:contain; }
.nav-logo-text { font-family:'Nunito',sans-serif; font-weight:900; font-size:20px; color:var(--coral); }
.nav-right { display:flex; align-items:center; gap:20px; }
.nav-link { font-size:14px; font-weight:600; color:var(--mid); text-decoration:none; transition:color 0.2s; padding:12px 8px; min-height:44px; display:flex; align-items:center; }
.nav-link:hover { color:var(--coral); }
.nav-cta {
  background:var(--coral); color:var(--white); border:none; padding:10px 22px; border-radius:100px;
  font-family:'Nunito',sans-serif; font-size:14px; font-weight:800; cursor:pointer;
  text-decoration:none; box-shadow:0 4px 16px rgba(232,99,92,0.28); transition:all 0.2s;
  min-height:44px; display:inline-flex; align-items:center;
}
.nav-cta:hover { background:var(--coral-dark); transform:translateY(-1px); }
a:focus-visible, button:focus-visible, input:focus-visible { outline:2px solid var(--coral); outline-offset:3px; border-radius:4px; }

/* MODAL */
.modal-overlay {
  display:none; position:fixed; inset:0; z-index:9999;
  background:rgba(45,24,16,0.5); backdrop-filter:blur(6px);
  align-items:center; justify-content:center; padding:24px;
}
.modal-overlay.open { display:flex; }
.modal-card {
  background:var(--white); border-radius:28px; padding:48px 40px 40px;
  max-width:460px; width:100%; position:relative;
  box-shadow:0 24px 80px rgba(45,24,16,0.25); text-align:center;
  animation:modalIn 0.25s ease-out;
}
@keyframes modalIn { from{opacity:0;transform:scale(0.95) translateY(12px)} to{opacity:1;transform:none} }
.modal-close { position:absolute; top:16px; right:20px; background:none; border:none; font-size:22px; color:var(--mid); cursor:pointer; padding:4px; }
.modal-close:hover { color:var(--dark); }
.modal-title { font-family:'Nunito',sans-serif; font-weight:900; font-size:24px; color:var(--dark); margin-bottom:8px; }
.modal-sub { font-size:15px; color:var(--mid); line-height:1.6; margin-bottom:24px; }
.modal-form { display:flex; background:var(--white); border:2px solid var(--coral-mid); border-radius:100px; padding:6px; overflow:hidden; }
.modal-form:focus-within { border-color:var(--coral); box-shadow:0 8px 32px rgba(232,99,92,0.18); }
.modal-input { flex:1; border:none; background:transparent; padding:14px 20px; font-family:'Nunito Sans',sans-serif; font-size:15px; color:var(--dark); outline:none; min-width:0; }
.modal-input:focus-visible { outline:none; }
.modal-input::placeholder { color:var(--light-text); }
.modal-btn { background:var(--coral); color:var(--white); border:none; padding:14px 24px; border-radius:100px; font-family:'Nunito',sans-serif; font-size:14px; font-weight:800; cursor:pointer; white-space:nowrap; transition:background 0.2s; }
.modal-btn:hover { background:var(--coral-dark); }
.modal-success { display:none; font-family:'Nunito',sans-serif; font-weight:700; font-size:16px; color:var(--green); padding:16px 0; }
.modal-note { font-size:13px; color:var(--light-text); margin-top:16px; }

/* PAGE LAYOUT */
section { position:relative; z-index:1; }
.page-hero {
  padding:140px 24px 80px; text-align:center; position:relative; z-index:1;
  max-width:860px; margin:0 auto;
}
.page-eyebrow {
  display:inline-flex; align-items:center; gap:8px; background:var(--white);
  border:1.5px solid var(--coral-mid); border-radius:100px; padding:7px 18px;
  font-family:'Nunito',sans-serif; font-size:13px; font-weight:700; color:var(--coral);
  margin-bottom:24px; box-shadow:0 2px 12px rgba(232,99,92,0.1);
}
.page-headline {
  font-family:'Nunito',sans-serif; font-weight:900; font-size:clamp(34px,5.5vw,62px);
  line-height:1.05; letter-spacing:-2px; color:var(--dark); margin-bottom:20px;
}
.page-headline .coral { color:var(--coral); }
.page-sub { font-size:18px; color:var(--mid); line-height:1.7; max-width:640px; margin:0 auto 40px; }
.hero-cta {
  background:var(--coral); color:var(--white); border:none; padding:16px 36px; border-radius:100px;
  font-family:'Nunito',sans-serif; font-size:16px; font-weight:800; cursor:pointer;
  text-decoration:none; box-shadow:0 6px 24px rgba(232,99,92,0.35); transition:all 0.2s;
  display:inline-flex; align-items:center; min-height:52px;
}
.hero-cta:hover { background:var(--coral-dark); transform:translateY(-2px); box-shadow:0 10px 32px rgba(232,99,92,0.4); }

/* CONTENT SECTIONS */
.content-section { padding:80px 0; }
.content-inner { max-width:1060px; margin:0 auto; padding:0 24px; }
.section-label {
  display:inline-flex; align-items:center; gap:8px; font-family:'Nunito',sans-serif;
  font-size:13px; font-weight:900; letter-spacing:2.5px; text-transform:uppercase;
  color:var(--coral); margin-bottom:16px;
}
.section-headline {
  font-family:'Nunito',sans-serif; font-weight:900; font-size:clamp(26px,4vw,48px);
  line-height:1.1; letter-spacing:-1.5px; color:var(--dark); margin-bottom:16px;
}
.section-sub { font-size:17px; color:var(--mid); line-height:1.7; max-width:680px; margin-bottom:48px; }

/* CARDS */
.card-grid { display:grid; gap:16px; }
.card-grid-2 { grid-template-columns:repeat(2,1fr); }
.card-grid-3 { grid-template-columns:repeat(3,1fr); }
.card {
  background:var(--white); border:1.5px solid var(--coral-mid); border-radius:20px;
  padding:32px 28px;
}
.card-icon { font-size:32px; margin-bottom:14px; display:block; }
.card-title { font-family:'Nunito',sans-serif; font-weight:800; font-size:17px; color:var(--dark); margin-bottom:10px; }
.card-desc { font-size:14px; color:var(--mid); line-height:1.65; }

/* STEPS */
.steps { display:flex; flex-direction:column; gap:12px; }
.step {
  background:var(--white); border:1.5px solid var(--coral-mid); border-radius:20px;
  padding:28px 32px; display:grid; grid-template-columns:56px 1fr auto; align-items:center; gap:20px;
}
.step-num { font-family:'Nunito',sans-serif; font-weight:900; font-size:48px; color:var(--coral-mid); line-height:1; letter-spacing:-3px; }
.step-title { font-family:'Nunito',sans-serif; font-weight:800; font-size:16px; color:var(--dark); margin-bottom:4px; }
.step-desc { font-size:14px; color:var(--mid); line-height:1.5; }
.step-badge { background:rgba(232,99,92,0.08); border:1.5px solid var(--coral-mid); color:var(--coral); font-family:'Nunito',sans-serif; font-size:13px; font-weight:800; padding:6px 16px; border-radius:100px; white-space:nowrap; }

/* CALLOUT */
.callout {
  background:var(--white); border:2px solid var(--coral); border-radius:24px;
  padding:40px 48px; text-align:center; margin:0 auto;
}
.callout-headline { font-family:'Nunito',sans-serif; font-weight:900; font-size:clamp(24px,3.5vw,40px); color:var(--dark); margin-bottom:12px; letter-spacing:-1px; }
.callout-sub { font-size:16px; color:var(--mid); line-height:1.7; margin-bottom:28px; }

/* CHIP LINKS */
.chip-links { display:flex; flex-wrap:wrap; gap:10px; margin-top:24px; }
.chip-link {
  font-family:'Nunito',sans-serif; font-size:13px; font-weight:700; padding:8px 18px;
  border-radius:100px; background:rgba(232,99,92,0.07); color:var(--dark-mid);
  border:1.5px solid rgba(232,99,92,0.18); text-decoration:none; transition:all 0.2s;
  display:inline-flex; align-items:center; min-height:40px;
}
.chip-link:hover { background:rgba(232,99,92,0.14); color:var(--coral); border-color:var(--coral); }

/* EXAMPLE CHAT */
.chat-bubble {
  background:var(--coral-soft); border-left:3px solid var(--coral); border-radius:12px;
  padding:14px 18px; font-size:14px; color:var(--dark-mid); line-height:1.6;
  font-style:italic; margin-bottom:10px;
}
.chat-response {
  background:var(--white); border:1.5px solid var(--coral-mid); border-radius:12px;
  padding:14px 18px; font-size:14px; color:var(--dark-mid); line-height:1.6; margin-bottom:10px;
}
.chat-label { font-family:'Nunito',sans-serif; font-size:11px; font-weight:800; letter-spacing:1.5px; text-transform:uppercase; color:var(--light-text); margin-bottom:6px; }

/* FOOTER */
footer {
  position:relative; z-index:1; text-align:center; padding:48px 24px 36px;
  border-top:1px solid rgba(232,99,92,0.1); margin-top:80px;
}
.footer-logo { display:flex; align-items:center; justify-content:center; gap:10px; margin-bottom:12px; }
.footer-logo img { width:36px; height:36px; object-fit:contain; }
.footer-logo span { font-family:'Nunito',sans-serif; font-weight:900; font-size:18px; color:var(--coral); }
.footer-copy { font-size:13px; color:var(--light-text); }
.footer-nav { display:flex; justify-content:center; gap:24px; margin-bottom:20px; }
.footer-nav a { font-size:13px; color:var(--mid); text-decoration:none; transition:color 0.2s; }
.footer-nav a:hover { color:var(--coral); }

/* REVEAL */
.reveal { opacity:1; transform:translateY(20px); transition:opacity 0.6s ease, transform 0.6s ease; }
.reveal.visible { opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce) { .reveal { transition:none; } }

/* RESPONSIVE */
@media (max-width:768px) {
  nav { padding:12px 20px; }
  .nav-right .nav-link { display:none; }
  .card-grid-2, .card-grid-3 { grid-template-columns:1fr; }
  .step { grid-template-columns:48px 1fr; }
  .step-badge { display:none; }
  .callout { padding:32px 24px; }
  .content-inner { padding:0 16px; }
}
@media (max-width:480px) {
  .modal-card { padding:36px 20px 28px; }
  .modal-form { flex-direction:column; border-radius:16px; }
  .modal-btn { border-radius:10px; }
}
