* { margin: 0; padding: 0; box-sizing: border-box; }
:root {
  --orange: #ff6b2b; --orange-light: #ff8c55;
  --dark: rgba(6,6,6,0.62); --dark2: rgba(6,6,6,0.62);
  --dark3: rgba(10,10,10,0.70); --dark4: rgba(18,18,18,0.80);
  --gray: #888; --gray-light: #aaa; --white: #fff;
  --divider: rgba(255,107,43,0.45);
}
html { scroll-behavior: smooth; }
body { font-family: 'Inter','Helvetica Neue',Arial,sans-serif; background:#050505; color:#fff; overflow-x:hidden; }
#aurora-canvas { position:fixed; top:0; left:0; width:100%; height:100%; z-index:0; pointer-events:none; background:#050505; overflow:hidden; }
#aurora-canvas span { position:absolute; color:#ffffff; font-size:clamp(13px,1.8vw,26px); font-weight:800; letter-spacing:0.08em; text-transform:uppercase; opacity:0; white-space:nowrap; animation:wordFloat linear infinite; text-shadow:0 0 18px rgba(255,255,255,0.3); }
#aurora-canvas span.accent { color:#ff6b2b; text-shadow:0 0 22px rgba(255,107,43,0.5); }
@keyframes wordFloat { 0%{opacity:0;transform:translateY(40px)} 8%{opacity:0.18} 50%{opacity:0.28} 92%{opacity:0.18} 100%{opacity:0;transform:translateY(-40px)} }
#page-wrap { position:relative; }
nav,section,.stats,.marquee-section,footer,#chat-bubble,#chat-window { position:relative; z-index:1; }

/* NAV */
nav { position:fixed; top:0; left:0; right:0; z-index:100; display:flex; align-items:center; justify-content:space-between; padding:0 60px; height:84px; background:rgba(10,10,10,0.92); backdrop-filter:blur(12px); border-bottom:1px solid rgba(255,255,255,0.06); }
.logo { display:flex; align-items:center; gap:12px; text-decoration:none; line-height:1; }
.logo-icon { flex-shrink:0; }
.logo-text { display:flex; flex-direction:column; gap:4px; }
.logo-name { font-size:20px; font-weight:900; letter-spacing:-0.5px; color:#fff; display:flex; align-items:baseline; }
.logo-flow { background:linear-gradient(90deg,#00b4d8,#00d4a8); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.logo-ia { background:linear-gradient(90deg,#00d4a8,#00e5a0); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.logo-sub { font-size:8px; letter-spacing:0.2em; color:#00b4d8; font-weight:700; display:block; white-space:nowrap; opacity:0.85; }
.logo-flow-orange { background:linear-gradient(90deg,#ff6b2b,#ff8c55); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.logo-ia-orange { background:linear-gradient(90deg,#ff8c55,#ffaa00); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.logo-sub-orange { color:rgba(255,107,43,0.7); }
.nav-links { display:flex; align-items:center; gap:36px; list-style:none; }
.nav-links a { color:var(--gray-light); text-decoration:none; font-size:14px; font-weight:500; transition:color 0.2s; }
.nav-links a:hover { color:#fff; }
.nav-cta { background:var(--orange); color:#fff!important; padding:10px 22px; border-radius:6px; font-weight:600!important; font-size:13px!important; }
.nav-cta:hover { background:var(--orange-light)!important; }
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:8px; border:none; background:transparent; }
.hamburger span { display:block; width:22px; height:2px; background:#fff; border-radius:2px; transition:transform 0.3s,opacity 0.3s; }
.mobile-menu { display:none; position:fixed; top:72px; left:0; right:0; background:rgba(6,6,6,0.98); backdrop-filter:blur(20px); z-index:99; padding:16px 30px 28px; border-bottom:1px solid rgba(255,107,43,0.25); flex-direction:column; }
.mobile-menu.open { display:flex; }
.mobile-menu a { color:var(--gray-light); text-decoration:none; font-size:15px; font-weight:500; padding:14px 0; border-bottom:1px solid rgba(255,255,255,0.06); transition:color 0.2s; }
.mobile-menu a.cta-mobile { color:var(--orange); font-weight:700; padding-top:20px; }

/* HERO */
.hero { min-height:100vh; display:flex; align-items:center; justify-content:center; flex-direction:column; text-align:center; padding:100px 40px 60px; position:relative; overflow:hidden; }
.hero::before { content:''; position:absolute; top:-200px; left:50%; transform:translateX(-50%); width:900px; height:900px; background:radial-gradient(circle,rgba(255,107,43,0.12) 0%,transparent 65%); pointer-events:none; }
.hero-badge { display:inline-flex; align-items:center; gap:8px; background:rgba(255,107,43,0.12); border:1px solid rgba(255,107,43,0.3); color:var(--orange); font-size:12px; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; padding:7px 16px; border-radius:100px; margin-bottom:32px; }
.hero h1 { font-size:clamp(36px,4.5vw,62px); font-weight:900; line-height:1.08; letter-spacing:-1.5px; max-width:820px; margin-bottom:20px; }
.hero h1 .highlight { color:var(--orange); }
.hero p { font-size:17px; color:var(--gray-light); max-width:540px; line-height:1.7; margin-bottom:36px; }
.hero-buttons { display:flex; gap:14px; flex-wrap:wrap; justify-content:center; }
.btn-primary { background:var(--orange); color:white; padding:16px 36px; border-radius:8px; font-size:15px; font-weight:700; text-decoration:none; transition:transform 0.2s,background 0.2s; display:inline-block; }
.btn-primary:hover { background:var(--orange-light); transform:translateY(-2px); }
.btn-secondary { background:transparent; color:#fff; padding:16px 36px; border-radius:8px; font-size:15px; font-weight:600; text-decoration:none; border:1px solid rgba(255,255,255,0.2); transition:border-color 0.2s,transform 0.2s; display:inline-block; }
.btn-secondary:hover { border-color:rgba(255,255,255,0.5); transform:translateY(-2px); }

/* MARQUEE */
.marquee-section { padding:40px 0; border-top:1px solid rgba(255,255,255,0.06); border-bottom:1px solid rgba(255,255,255,0.06); overflow:hidden; background:var(--dark2); }
.marquee-label { text-align:center; font-size:11px; letter-spacing:0.15em; text-transform:uppercase; color:var(--gray); margin-bottom:28px; }
.marquee-track { display:flex; gap:64px; animation:scroll 30s linear infinite; width:max-content; }
.marquee-track span { font-size:18px; font-weight:800; color:rgba(255,255,255,0.15); white-space:nowrap; letter-spacing:0.05em; text-transform:uppercase; }
@keyframes scroll { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* STATS */
.stats { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:rgba(255,255,255,0.06); }
.stat-item { background:var(--dark); padding:36px 40px; text-align:center; border-right:1px solid var(--divider); }
.stat-item:last-child { border-right:none; }
.stat-number { font-size:42px; font-weight:900; letter-spacing:-2px; color:#fff; line-height:1; margin-bottom:8px; }
.stat-number span { color:var(--orange); }
.stat-label { font-size:14px; color:var(--gray); font-weight:500; }

/* SECTION */
section { padding:70px 60px; }
.section-label { font-size:11px; letter-spacing:0.15em; text-transform:uppercase; color:var(--orange); font-weight:700; margin-bottom:12px; }
.section-title { font-size:clamp(26px,3vw,40px); font-weight:900; letter-spacing:-1px; line-height:1.1; margin-bottom:16px; }
.section-desc { font-size:15px; color:var(--gray-light); line-height:1.7; max-width:520px; margin-bottom:32px; }

/* PROCESS */
.process { background:#f5f5f5!important; }
.process-header { text-align:center; max-width:600px; margin:0 auto; }
.process-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:rgba(0,0,0,0.07); margin-top:40px; }
.process-step { background:#f5f5f5; padding:32px 24px; transition:background 0.2s; }
.process-step:hover { background:#fff; box-shadow:0 4px 20px rgba(0,0,0,0.07); }
.step-number { font-size:42px; font-weight:900; color:rgba(255,107,43,0.13); letter-spacing:-3px; line-height:1; margin-bottom:10px; }
.step-icon { font-size:24px; margin-bottom:8px; }
.step-title { font-size:15px; font-weight:800; margin-bottom:8px; color:#0d0d0d; }
.step-desc { font-size:13px; color:#666; line-height:1.6; }
.step-badge { display:inline-block; margin-top:14px; background:rgba(255,107,43,0.1); color:var(--orange); font-size:11px; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; padding:4px 12px; border-radius:100px; }

/* SERVICES */
.services { background:#fff!important; position:relative; overflow:visible; }
.services-peek-monkey { display:none; position:absolute; right:-18px; bottom:60px; flex-direction:column; align-items:center; gap:6px; z-index:10; animation:peekBounce 2.4s ease-in-out infinite; }
.peek-bubble { background:#fff; border:2.5px solid #111; border-radius:12px; padding:7px 11px; font-size:12px; font-weight:800; color:#111; box-shadow:3px 3px 0 #111; white-space:nowrap; position:relative; }
.peek-bubble::after { content:''; position:absolute; bottom:-12px; right:18px; border:7px solid transparent; border-top-color:#111; }
.peek-bubble::before { content:''; position:absolute; bottom:-8px; right:20px; border:5px solid transparent; border-top-color:#fff; z-index:1; }
@keyframes peekBounce { 0%,100%{transform:translateY(0) rotate(-4deg)} 50%{transform:translateY(-8px) rotate(4deg)} }
.services-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:36px; gap:40px; }
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:rgba(0,0,0,0.07); }
.service-card { background:#fff; padding:32px 28px; transition:box-shadow 0.3s; }
.service-card:hover { box-shadow:0 8px 36px rgba(255,107,43,0.15); }
.service-icon { width:48px; height:48px; background:rgba(255,107,43,0.12); border-radius:12px; display:flex; align-items:center; justify-content:center; margin-bottom:24px; font-size:22px; }
.service-card h3 { font-size:17px; font-weight:800; margin-bottom:10px; color:#0d0d0d; }
.service-card p { font-size:13px; color:#666; line-height:1.6; }
.service-price { font-size:12px; color:#888; margin-top:12px; padding-top:12px; border-top:1px solid rgba(0,0,0,0.08); }
.service-price span { color:var(--orange); font-weight:800; font-size:18px; }
.btn-contratar { margin-top:14px; background:transparent; border:1px solid rgba(255,107,43,0.55); color:var(--orange); padding:11px 20px; border-radius:6px; font-size:13px; font-weight:700; cursor:pointer; font-family:inherit; transition:background 0.2s,color 0.2s,transform 0.2s; display:block; width:100%; text-align:center; }
.btn-contratar:hover { background:var(--orange); color:white; transform:translateY(-1px); }

/* BLOG */
.blog-section { background:#f5f5f5; }
.blog-card { background:#fff; border-radius:12px; overflow:hidden; border:1px solid rgba(0,0,0,0.07); transition:box-shadow 0.25s,transform 0.25s; display:flex; flex-direction:column; flex-shrink:0; width:260px; }
.blog-card:hover { box-shadow:0 8px 24px rgba(0,0,0,0.1); transform:translateY(-3px); }
.blog-thumb { height:110px; display:flex; align-items:center; justify-content:center; font-size:40px; background:linear-gradient(135deg,rgba(255,107,43,0.08),rgba(255,107,43,0.02)); border-bottom:1px solid rgba(0,0,0,0.05); }
.blog-body { padding:16px 18px; flex:1; display:flex; flex-direction:column; }
.blog-tag { display:inline-block; background:rgba(255,107,43,0.1); color:var(--orange); font-size:10px; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; padding:3px 10px; border-radius:100px; margin-bottom:8px; }
.blog-title { font-size:14px; font-weight:800; color:#0d0d0d; line-height:1.35; margin-bottom:6px; }
.blog-excerpt { font-size:12.5px; color:#666; line-height:1.55; flex:1; margin-bottom:10px; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.blog-meta { font-size:11px; color:#aaa; display:flex; align-items:center; gap:8px; }
.blog-read { margin-top:10px; color:var(--orange); font-size:12px; font-weight:700; text-decoration:none; display:inline-flex; align-items:center; gap:5px; }
.blog-read:hover { gap:9px; }

/* CTA */
.cta-section { background:#f5f5f5!important; text-align:center; padding:72px 60px; }
.cta-section .section-title { color:#0d0d0d; max-width:600px; margin:0 auto 20px; }
.cta-section .section-desc { color:#555; max-width:480px; margin:0 auto 44px; }
.cta-section .btn-secondary { border-color:rgba(0,0,0,0.25); color:#0d0d0d; }

/* FORM */
.form-section { background:#fff!important; padding:70px 60px; }
.form-section .section-title { text-align:center; margin:0 auto 16px; max-width:600px; color:#0d0d0d; }
.form-section .section-desc { text-align:center; margin:0 auto 56px; max-width:520px; color:#555; }
.form-section .section-label { display:block; text-align:center; }
.form-card { background:#f5f5f5!important; border:1px solid rgba(0,0,0,0.08)!important; border-radius:20px; padding:36px 48px; max-width:900px; margin:0 auto; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:20px; }
.form-group { display:flex; flex-direction:column; gap:8px; }
.form-group.full { grid-column:1/-1; }
.form-group label { font-size:12px; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; color:#444; }
.form-group input,.form-group select,.form-group textarea { background:#fff!important; border:1px solid rgba(0,0,0,0.15)!important; border-radius:8px; padding:14px 16px; color:#0d0d0d!important; font-size:14px; font-family:inherit; outline:none; -webkit-appearance:none; transition:border-color 0.2s,box-shadow 0.2s; }
.form-group input::placeholder,.form-group textarea::placeholder { color:#bbb; }
.form-group input:focus,.form-group select:focus,.form-group textarea:focus { border-color:var(--orange)!important; box-shadow:0 0 0 3px rgba(255,107,43,0.12); }
.form-group textarea { resize:vertical; min-height:120px; }
.checkboxes-group { display:flex; flex-wrap:wrap; gap:10px; margin-top:4px; }
.checkbox-pill { display:flex; align-items:center; gap:8px; background:#fff!important; border:1px solid rgba(0,0,0,0.12)!important; border-radius:100px; padding:8px 16px; cursor:pointer; font-size:13px; color:#555!important; user-select:none; transition:border-color 0.2s,background 0.2s; }
.checkbox-pill input[type="checkbox"] { display:none; }
.checkbox-pill:has(input:checked) { background:rgba(255,107,43,0.15)!important; border-color:var(--orange)!important; color:#fff!important; }
.form-submit { margin-top:32px; text-align:center; }
.btn-submit { background:var(--orange); color:white; border:none; padding:18px 48px; border-radius:8px; font-size:16px; font-weight:700; cursor:pointer; transition:transform 0.2s,background 0.2s; font-family:inherit; }
.btn-submit:hover { background:var(--orange-light); transform:translateY(-2px); }
.form-note { font-size:12px; color:#999; margin-top:14px; }
.form-success { display:none; text-align:center; padding:40px 20px; }
.form-success.show { display:block; }
.form-success-icon { font-size:48px; margin-bottom:16px; }
.form-success h3 { font-size:24px; font-weight:800; margin-bottom:10px; color:#0d0d0d; }

/* FAQ */
.faq-section { max-width:760px; margin:0 auto; }
.faq-item { border-bottom:1px solid rgba(255,255,255,0.07); }
.faq-question { width:100%; background:none; border:none; color:#fff; font-size:15px; font-weight:600; font-family:inherit; padding:16px 0; text-align:left; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:16px; transition:color 0.2s; }
.faq-question:hover { color:var(--orange); }
.faq-icon { font-size:22px; color:var(--orange); flex-shrink:0; transition:transform 0.3s; }
.faq-question.open .faq-icon { transform:rotate(45deg); }
.faq-answer { font-size:15px; color:var(--gray-light); line-height:1.7; max-height:0; overflow:hidden; transition:max-height 0.4s ease,padding 0.3s; }
.faq-answer.open { max-height:300px; padding-bottom:20px; }

/* CONTACT BAR */
.contact-bar { background:var(--orange)!important; border-top:none; border-bottom:none; padding:24px 60px; display:flex; justify-content:center; align-items:center; gap:40px; flex-wrap:wrap; position:relative; z-index:1; }
.contact-item { display:flex; align-items:center; gap:12px; font-size:14px; color:rgba(255,255,255,0.88); text-decoration:none; transition:color 0.2s; }
.contact-item:hover { color:#fff; }
.contact-item-icon { width:40px; height:40px; background:rgba(255,255,255,0.2); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:18px; flex-shrink:0; }
.contact-item strong { display:block; font-size:13px; color:#fff; font-weight:700; }
.contact-item-text span { font-size:12px; color:rgba(255,255,255,0.75); }

/* FOOTER */
footer { background:#111!important; border-top:1px solid rgba(255,107,43,0.2); padding:56px 60px 32px; }
.footer-top { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:60px; margin-bottom:60px; }
.footer-top > div { border-right:1px solid rgba(255,255,255,0.07); padding-right:40px; }
.footer-top > div:last-child { border-right:none; }
.footer-brand .logo { font-size:20px; display:block; margin-bottom:16px; }
.footer-brand p { font-size:14px; color:var(--gray); line-height:1.7; max-width:260px; }
.footer-social { display:flex; gap:10px; margin-top:24px; }
.social-link { width:36px; height:36px; border-radius:8px; background:rgba(255,255,255,0.07); display:flex; align-items:center; justify-content:center; text-decoration:none; font-size:14px; color:var(--gray-light); transition:background 0.2s; }
.social-link:hover { background:var(--orange); color:white; }
.footer-col h4 { font-size:12px; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--gray); margin-bottom:20px; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:12px; }
.footer-col a { color:var(--gray-light); text-decoration:none; font-size:14px; transition:color 0.2s; }
.footer-col a:hover { color:#fff; }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; padding-top:32px; border-top:1px solid rgba(255,255,255,0.07); font-size:13px; color:var(--gray); }

/* DIVIDERS */
section,.stats,.marquee-section { border-bottom:1px solid var(--divider); }
.process,.services,.blog-section,.cta-section,.form-section { border-bottom-color:rgba(0,0,0,0.07)!important; }

/* REVEAL */
.reveal { opacity:0; transform:translateY(40px); transition:opacity 0.7s ease,transform 0.7s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal:nth-child(2){transition-delay:0.1s} .reveal:nth-child(3){transition-delay:0.2s} .reveal:nth-child(4){transition-delay:0.3s}

/* CHATBOT */
#chat-bubble { position:fixed; bottom:28px; right:28px; width:60px; height:60px; background:var(--orange); border-radius:50%; display:flex; align-items:center; justify-content:center; cursor:pointer; box-shadow:0 6px 24px rgba(255,107,43,0.45); z-index:999; transition:transform 0.2s; }
#chat-bubble:hover { transform:scale(1.08); }
#chat-bubble svg { width:26px; height:26px; }
#chat-bubble svg.icon-close { fill:white; }
#chat-bubble .icon-close { display:none; }
#chat-bubble.open .icon-chat { display:none; }
#chat-bubble.open .icon-close { display:block; }
#chat-dot { position:absolute; top:4px; right:4px; width:12px; height:12px; background:#fff; border-radius:50%; border:2px solid var(--orange); animation:pulse-dot 1.8s infinite; }
@keyframes pulse-dot { 0%,100%{transform:scale(1);opacity:1} 50%{transform:scale(1.3);opacity:0.7} }
#chat-window { position:fixed; bottom:100px; right:28px; width:318px; max-height:calc(100vh - 180px); background:var(--dark2); border:1px solid rgba(255,255,255,0.1); border-radius:20px; box-shadow:0 20px 60px rgba(0,0,0,0.6); z-index:998; display:flex; flex-direction:column; overflow:hidden; transform:translateY(20px) scale(0.95); opacity:0; pointer-events:none; transition:transform 0.3s ease,opacity 0.3s ease; }
#chat-window.open { transform:translateY(0) scale(1); opacity:1; pointer-events:all; }
.chat-header { background:var(--orange); padding:18px 20px; display:flex; align-items:center; gap:12px; flex-shrink:0; }
.chat-avatar { width:40px; height:40px; background:rgba(255,255,255,0.2); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0; }
.chat-header-info h4 { font-size:15px; font-weight:800; color:white; }
.chat-header-info span { font-size:12px; color:rgba(255,255,255,0.8); display:flex; align-items:center; gap:5px; }
.online-dot { width:7px; height:7px; background:#4ade80; border-radius:50%; display:inline-block; }
#chat-messages { flex:1; overflow-y:auto; padding:20px 16px 8px; display:flex; flex-direction:column; gap:12px; scrollbar-width:thin; }
.msg { display:flex; gap:8px; align-items:flex-end; animation:msg-in 0.3s ease; }
@keyframes msg-in { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }
.msg-bot .bubble { background:var(--dark3); border:1px solid rgba(255,255,255,0.08); color:#fff; border-radius:16px 16px 16px 4px; padding:10px 14px; font-size:13.5px; line-height:1.55; max-width:260px; }
.msg-user { flex-direction:row-reverse; }
.msg-user .bubble { background:var(--orange); color:white; border-radius:16px 16px 4px 16px; padding:10px 14px; font-size:13.5px; line-height:1.55; max-width:240px; }
.msg-avatar-bot { width:28px; height:28px; background:var(--orange); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:13px; flex-shrink:0; color:white; font-weight:800; }
.typing-bubble { background:var(--dark3); border:1px solid rgba(255,255,255,0.08); border-radius:16px 16px 16px 4px; padding:12px 16px; display:flex; gap:5px; align-items:center; }
.typing-bubble span { width:7px; height:7px; background:var(--gray); border-radius:50%; animation:typing 1.2s infinite; }
.typing-bubble span:nth-child(2){animation-delay:0.2s} .typing-bubble span:nth-child(3){animation-delay:0.4s}
@keyframes typing { 0%,60%,100%{transform:translateY(0)} 30%{transform:translateY(-5px)} }
#chat-quick { flex-shrink:0; border-top:1px solid rgba(255,255,255,0.06); }
.faq-tray-header { display:flex; align-items:center; justify-content:space-between; padding:10px 16px 8px; cursor:pointer; user-select:none; }
.faq-tray-label { font-size:10px; font-weight:700; color:var(--gray); letter-spacing:0.12em; text-transform:uppercase; }
.faq-tray-arrow { width:22px; height:22px; border-radius:50%; background:var(--orange); color:#fff; font-size:10px; font-weight:700; display:flex; align-items:center; justify-content:center; transition:transform 0.3s; }
#chat-quick.collapsed .faq-tray-arrow { transform:rotate(180deg); }
#faq-tray-body { padding:0 16px 12px; display:flex; flex-direction:column; gap:7px; overflow:hidden; max-height:400px; transition:max-height 0.35s ease,padding 0.3s; }
#chat-quick.collapsed #faq-tray-body { max-height:0; padding-bottom:0; }
.quick-btn { background:transparent; border:1px solid rgba(255,255,255,0.12); border-radius:20px; color:var(--gray-light); padding:8px 14px; font-size:12.5px; cursor:pointer; text-align:left; display:flex; align-items:center; gap:8px; transition:border-color 0.2s,color 0.2s,background 0.2s; font-family:inherit; text-decoration:none; }
.quick-btn:hover { border-color:var(--orange); color:#fff; background:rgba(255,107,43,0.08); }
.quick-btn-wa { background:rgba(37,211,102,0.08); border-color:rgba(37,211,102,0.22); color:#25d366; }
#chat-form-section { padding:12px 16px 16px; border-top:1px solid rgba(255,255,255,0.07); flex-shrink:0; display:none; }
#chat-form-section.show { display:block; }
.chat-form-title { font-size:13px; font-weight:700; color:#fff; margin-bottom:10px; }
.chat-input-row { display:flex; flex-direction:column; gap:8px; margin-bottom:8px; }
.chat-input-row input { background:var(--dark3); border:1px solid rgba(255,255,255,0.1); border-radius:8px; padding:10px 12px; color:#fff; font-size:13px; font-family:inherit; outline:none; }
.chat-input-row input::placeholder { color:var(--gray); }
.chat-input-row input:focus { border-color:var(--orange); }
.chat-send-btn { background:var(--orange); color:white; border:none; border-radius:8px; padding:11px; font-size:13px; font-weight:700; cursor:pointer; font-family:inherit; width:100%; }
.chat-input-bar { padding:10px 16px 14px; display:flex; gap:8px; border-top:1px solid rgba(255,255,255,0.07); flex-shrink:0; }
.chat-text-input { flex:1; background:var(--dark3); border:1px solid rgba(255,255,255,0.1); border-radius:20px; padding:10px 16px; color:#fff; font-size:13px; font-family:inherit; outline:none; }
.chat-text-input::placeholder { color:var(--gray); }
.chat-text-input:focus { border-color:var(--orange); }
.chat-send-icon { width:38px; height:38px; background:var(--orange); border:none; border-radius:50%; display:flex; align-items:center; justify-content:center; cursor:pointer; flex-shrink:0; }
.chat-send-icon svg { width:16px; height:16px; fill:white; }

/* MODAL */
.modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.82); z-index:2000; align-items:center; justify-content:center; padding:20px; backdrop-filter:blur(8px); }
.modal-overlay.open { display:flex; }
.modal-box { background:#0c0c0c; border:1px solid rgba(255,107,43,0.35); border-radius:20px; padding:44px 40px; max-width:500px; width:100%; position:relative; animation:modal-in 0.3s ease; }
@keyframes modal-in { from{opacity:0;transform:scale(0.95) translateY(20px)} to{opacity:1;transform:scale(1) translateY(0)} }
.modal-close { position:absolute; top:18px; right:18px; background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.12); color:var(--gray); width:32px; height:32px; border-radius:50%; cursor:pointer; font-size:18px; display:flex; align-items:center; justify-content:center; }
.modal-close:hover { background:rgba(255,107,43,0.15); color:var(--orange); }
.modal-service-icon { font-size:40px; margin-bottom:10px; }
.modal-service-name { font-size:26px; font-weight:900; margin-bottom:4px; color:white; }
.modal-service-price { color:var(--orange); font-size:20px; font-weight:800; margin-bottom:16px; }
.modal-service-desc { font-size:14px; color:var(--gray-light); line-height:1.7; margin-bottom:24px; border-top:1px solid rgba(255,255,255,0.07); padding-top:18px; }
.modal-btn-primary { display:flex; align-items:center; justify-content:center; gap:8px; background:var(--orange); color:white; border:none; padding:16px 24px; border-radius:8px; font-size:15px; font-weight:700; cursor:pointer; font-family:inherit; text-align:center; text-decoration:none; width:100%; margin-bottom:10px; transition:background 0.2s; }
.modal-btn-primary:hover { background:var(--orange-light); }
.modal-btn-secondary { display:block; background:transparent; color:var(--gray-light); border:1px solid rgba(255,255,255,0.12); padding:14px 24px; border-radius:8px; font-size:14px; font-weight:600; cursor:pointer; font-family:inherit; text-align:center; width:100%; transition:border-color 0.2s; }
.modal-btn-secondary:hover { border-color:rgba(255,255,255,0.35); color:#fff; }
.modal-guarantee { margin-top:16px; font-size:12px; color:var(--gray); text-align:center; }
.modal-guarantee span { color:var(--orange); }

/* RESPONSIVE */
@media(max-width:1024px){
  nav{padding:0 30px} section{padding:80px 30px} footer{padding:60px 30px 32px}
  .stats{grid-template-columns:repeat(2,1fr)} .services-grid{grid-template-columns:repeat(2,1fr)}
  .process-grid{grid-template-columns:repeat(2,1fr)} .footer-top{grid-template-columns:1fr 1fr;gap:32px}
  .blog-section{padding:52px 30px!important}
  .faq-section{padding:0 30px!important}
  .contact-bar{padding:20px 30px;gap:24px}
}
@media(max-width:768px){
  .nav-links{display:none} .hamburger{display:flex}
  section{padding:52px 20px!important} footer{padding:52px 20px 28px}
  .hero{padding:100px 20px 60px!important} .hero h1{font-size:clamp(30px,9vw,48px)}
  .hero p{font-size:15px}
  .hero-badge{font-size:9px!important;padding:4px 10px!important;letter-spacing:0.05em;margin-bottom:16px}
  .hero-buttons{flex-direction:column;align-items:stretch;max-width:320px;margin:0 auto}
  .btn-primary,.btn-secondary{padding:15px 24px;font-size:15px;text-align:center}
  .stats{grid-template-columns:repeat(2,1fr)} .stat-item{padding:28px 14px} .stat-number{font-size:36px}
  .services-grid{grid-template-columns:1fr} .services-header{flex-direction:column;gap:16px}
  .services-peek-monkey{display:flex}
  .process-grid{grid-template-columns:1fr 1fr}
  .form-grid{grid-template-columns:1fr} .form-card{padding:24px 18px!important}
  .blog-section{padding:48px 16px!important}
  #blog-scroll{gap:14px}
  .blog-card{width:230px}
  .faq-section{padding:0 20px!important}
  .contact-bar{padding:20px 16px!important;gap:16px;flex-direction:column;align-items:flex-start}
  .contact-item{width:100%}
  .footer-top{grid-template-columns:1fr;gap:28px} .footer-top>div{border-right:none!important;padding-right:0!important}
  .footer-bottom{flex-direction:column;gap:10px;text-align:center}
  #chat-window{width:calc(100vw - 24px);right:12px;bottom:72px;max-height:46vh;border-radius:14px}
  #chat-bubble{right:12px;bottom:10px}
  #chat-bubble svg.icon-chat{width:48px!important;height:58px!important}
  #monkey-speech{font-size:10px!important;padding:6px 9px!important;max-width:130px!important}
  #faq-tray-body{max-height:180px}
  #aurora-canvas span{font-size:clamp(10px,3.5vw,16px)}
}
@media(max-width:480px){
  section{padding:44px 16px!important} .hero{padding:84px 16px 44px!important}
  .hero h1{font-size:clamp(28px,8vw,40px);letter-spacing:-1px}
  .hero-badge{font-size:11px;padding:6px 13px}
  .stat-item{padding:22px 10px} .stat-number{font-size:32px}
  .process-grid{grid-template-columns:1fr}
  .form-card{padding:20px 14px!important}
  .blog-card{width:200px}
  .services-header .section-title{font-size:clamp(22px,7vw,32px)}
  .contact-bar{padding:16px!important}
  .footer-top{padding:0}
  #chat-window{max-height:75vh}
  #aurora-canvas span{font-size:clamp(12px,4vw,18px);font-weight:900}
}
