/* KaiLiving — estilos consolidados (subpáginas primero, home al final para la cascada) */
:root {
      --c-primary: #2563EB;
      --c-primary-dark: #1D4ED8;
      --c-primary-hover: #1E40AF;
      --c-primary-light: #EFF6FF;
      --c-primary-glow: rgba(37, 99, 235, 0.18);

      --c-navy: #0F172A;
      --c-navy-mid: #1E293B;
      --c-slate: #475569;
      --c-muted: #64748B;
      --c-subtle: #94A3B8;
      --c-body: #1E293B;
      --c-border: #E2E8F0;
      --c-bg: #F8FAFC;
      --c-white: #FFFFFF;

      --c-green: #059669;
      --c-green-light: #ECFDF5;
      --c-amber: #D97706;
      --c-amber-light: #FFFBEB;
      --c-red: #DC2626;
      --c-red-light: #FEF2F2;

      --font-display: 'Neo Sans Std', system-ui, sans-serif;
      --font-body: 'Neo Sans Std', system-ui, sans-serif;
      --font-serif: 'Neo Sans Std', system-ui, sans-serif;

      --r-sm: 8px;
      --r: 12px;
      --r-lg: 20px;
      --r-xl: 28px;

      --sh-xs: 0 1px 3px rgba(15, 23, 42, 0.06);
      --sh-sm: 0 2px 8px rgba(15, 23, 42, 0.08), 0 1px 3px rgba(15, 23, 42, 0.05);
      --sh-md: 0 8px 24px rgba(15, 23, 42, 0.10), 0 2px 8px rgba(15, 23, 42, 0.06);
      --sh-lg: 0 20px 48px rgba(15, 23, 42, 0.12), 0 8px 16px rgba(15, 23, 42, 0.06);
      --sh-blue: 0 12px 40px rgba(37, 99, 235, 0.28), 0 4px 12px rgba(37, 99, 235, 0.14);

      --w-max: 1320px;
      --pad-section: 96px;
      --t: 0.22s cubic-bezier(0.4, 0, 0.2, 1);
      --c-purple: #7C3AED;
      --c-purple-dark: #6D28D9;
      --c-purple-light: #F5F3FF;
      --c-green-dark: #047857;
      --c-indigo: #4F46E5;
      --c-indigo-dark: #4338CA;
      --c-indigo-light: #EEF2FF;
      --c-orange: #EA580C;
      --c-orange-dark: #C2410C;
      --c-orange-light: #FFF7ED;
      --c-cito: #0891B2;
      --c-cito-dark: #0E7490;
      --c-cito-light: #ECFEFF;
      --c-wa: #25D366;
      --c-wa-dark: #128C7E;
      --c-wa-light: #DCF8C6;
      --c-wa-bg: #ECE5DD;
      --c-wa-chat: #075E54;
      --sh-green: 0 12px 40px rgba(5, 150, 105, 0.28);
      --sh-indigo: 0 12px 40px rgba(79, 70, 229, 0.28);
      --sh-orange: 0 12px 40px rgba(234, 88, 12, 0.28);
      --sh-purple: 0 12px 40px rgba(124, 58, 237, 0.28);
      --sh-wa: 0 12px 40px rgba(37, 211, 102, 0.28);
}

/* ----- contacto.html ----- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);font-size:16px;line-height:1.6;color:var(--c-body);background:var(--c-white);-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font-family:inherit}
ul{list-style:none}
.container{max-width:var(--w-max);margin:0 auto;padding:0 24px}

/* ANN BAR */
.ann-bar{background:var(--c-navy-mid);color:#fff;padding:10px 24px;font-size:13.5px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:12px;position:relative}
.ann-bar a{color:#93C5FD;text-decoration:underline;text-underline-offset:2px}
.ann-badge{background:var(--c-primary);color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:2px 8px;border-radius:4px;white-space:nowrap}
.ann-close{position:absolute;right:20px;top:50%;transform:translateY(-50%);color:var(--c-subtle);font-size:18px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.ann-close:hover{color:#fff}

/* NAV */
.nav{position:sticky;top:0;z-index:900;background:rgba(255,255,255,0.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--c-border);box-shadow:0 1px 3px rgba(15,23,42,0.06)}
.nav-inner{max-width:var(--w-max);margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;gap:32px}
.nav-logo img{height:34px;width:auto}
.nav-links{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--c-slate);padding:8px 14px;border-radius:var(--r-sm);transition:color var(--t),background var(--t)}
.nav-links a:hover{color:var(--c-primary);background:var(--c-primary-light)}
.nav-links a.active{color:var(--c-primary);font-weight:700}
.nav-ctas{display:flex;align-items:center;gap:10px;margin-left:12px}
.btn-nav-login{font-size:14px;font-weight:600;color:var(--c-slate);padding:8px 16px;border-radius:var(--r-sm);border:1px solid var(--c-border);transition:all var(--t)}
.btn-nav-login:hover{color:var(--c-primary);border-color:var(--c-primary);background:var(--c-primary-light)}
.btn-nav-demo{font-size:14px;font-weight:700;color:#fff;background:var(--c-primary);padding:9px 20px;border-radius:var(--r-sm);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-nav-demo:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;margin-left:auto}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--c-navy-mid);border-radius:2px}
.mobile-menu{display:none;flex-direction:column;background:var(--c-white);padding:16px 24px 24px;border-top:1px solid var(--c-border)}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:15px;font-weight:500;color:var(--c-slate);padding:12px 0;border-bottom:1px solid var(--c-border)}
.mobile-menu a.active{color:var(--c-primary);font-weight:700}
.mobile-menu a:last-child{border-bottom:none}

/* BREADCRUMB */
.breadcrumb-bar{background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:10px 0}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--c-muted)}
.breadcrumb a{color:var(--c-muted);transition:color var(--t)}
.breadcrumb a:hover{color:var(--c-primary)}
.breadcrumb-sep{color:var(--c-subtle);font-size:11px}
.breadcrumb-current{color:var(--c-slate);font-weight:600}

/* ── HERO ─────────────────────────────────────── */
.contact-hero{
  background:var(--c-navy);
  padding:64px 0 56px;
  position:relative;overflow:hidden;
}
.contact-hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 80% at 30% 50%,rgba(37,99,235,0.18) 0%,transparent 60%);
  pointer-events:none;
}
.hero-inner{text-align:center;position:relative}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(37,99,235,0.20);border:1px solid rgba(37,99,235,0.38);color:#93C5FD;font-size:12px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:5px 14px;border-radius:100px;margin-bottom:22px}
.contact-hero h1{font-family:var(--font-display);font-size:clamp(32px,4.5vw,52px);font-weight:800;line-height:1.1;letter-spacing:-0.03em;color:#fff;margin-bottom:16px}
.contact-hero h1 em{font-style:normal;color:#60A5FA}
.contact-hero .sub{font-size:18px;line-height:1.60;color:rgba(255,255,255,0.65);max-width:500px;margin:0 auto}

/* ── CHANNEL CARDS ────────────────────────────── */
.channels-strip{
  background:var(--c-white);
  border-bottom:1px solid var(--c-border);
  padding:0;
}
.channels-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  border-left:1px solid var(--c-border);
}
.channel-card{
  padding:32px 28px;
  border-right:1px solid var(--c-border);
  border-bottom:1px solid var(--c-border);
  display:flex;flex-direction:column;
  transition:background var(--t);
  text-decoration:none;
  color:inherit;
  cursor:pointer;
}
.channel-card:hover{background:var(--c-bg)}
.channel-card.channel-wa:hover{background:#F0FDF9}
.channel-icon{
  width:52px;height:52px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;font-size:24px;
  flex-shrink:0;
}
.channel-label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px}
.channel-name{font-family:var(--font-display);font-size:20px;font-weight:800;color:var(--c-navy);letter-spacing:-0.02em;margin-bottom:8px;line-height:1.2}
.channel-desc{font-size:14px;color:var(--c-muted);line-height:1.55;margin-bottom:20px;flex:1}
.channel-cta{
  display:inline-flex;align-items:center;gap:7px;
  font-size:14px;font-weight:700;
  transition:gap var(--t);
}
.channel-card.channel-wa .channel-cta{color:var(--c-green)}
.channel-card.channel-email .channel-cta{color:var(--c-primary)}
.channel-card.channel-demo .channel-cta{color:var(--c-primary)}
.channel-card:hover .channel-cta{gap:11px}
.channel-availability{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;color:var(--c-muted);
  margin-top:12px;
}
.avail-dot{width:7px;height:7px;border-radius:50%;background:var(--c-green);animation:pulse-avail 2.5s infinite}
@keyframes pulse-avail{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}

/* ── CONTACT FORM SECTION ─────────────────────── */
.contact-section{padding:80px 0;background:var(--c-bg)}
.contact-grid{display:grid;grid-template-columns:380px 1fr;gap:64px;align-items:start}

/* Left: subject selector + info */
.contact-left{}
.contact-left-title{font-family:var(--font-display);font-size:22px;font-weight:800;color:var(--c-navy);letter-spacing:-0.02em;margin-bottom:8px}
.contact-left-sub{font-size:15px;color:var(--c-muted);line-height:1.60;margin-bottom:28px}

.subject-selector{margin-bottom:28px}
.subject-label{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--c-subtle);margin-bottom:12px}
.subject-btns{display:flex;flex-direction:column;gap:8px}
.subject-btn{
  display:flex;align-items:center;gap:12px;
  font-family:var(--font-body);font-size:14px;font-weight:500;
  color:var(--c-slate);text-align:left;
  background:var(--c-white);
  border:1.5px solid var(--c-border);
  border-radius:var(--r);padding:12px 14px;
  cursor:pointer;transition:all var(--t);width:100%;
}
.subject-btn:hover{border-color:rgba(37,99,235,0.30);color:var(--c-primary);background:var(--c-primary-light)}
.subject-btn.active{border-color:var(--c-primary);color:var(--c-primary);background:var(--c-primary-light);font-weight:600}
.subject-emoji{font-size:18px;flex-shrink:0;width:24px;text-align:center}
.subject-check{
  width:18px;height:18px;border-radius:50%;
  background:var(--c-primary);
  display:flex;align-items:center;justify-content:center;
  margin-left:auto;flex-shrink:0;
  opacity:0;transition:opacity var(--t);
}
.subject-btn.active .subject-check{opacity:1}

/* Contact info block */
.contact-info{
  background:var(--c-white);
  border:1.5px solid var(--c-border);
  border-radius:var(--r-lg);
  overflow:hidden;
}
.ci-header{
  background:var(--c-navy);padding:18px 20px;
  display:flex;align-items:center;gap:12px;
}
.ci-logo-mark{width:32px;height:32px;background:var(--c-primary);border-radius:8px;display:flex;align-items:center;justify-content:center}
.ci-title{font-family:var(--font-display);font-size:14px;font-weight:700;color:#fff}
.ci-sub{font-size:12px;color:rgba(255,255,255,0.55);margin-top:1px}
.ci-row{
  display:flex;align-items:center;gap:12px;
  padding:14px 18px;
  border-bottom:1px solid var(--c-border);
  font-size:14px;
  transition:background var(--t);
}
.ci-row:last-child{border-bottom:none}
.ci-row:hover{background:var(--c-bg)}
.ci-row-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ci-row-label{font-size:11.5px;color:var(--c-subtle);display:block;margin-bottom:1px}
.ci-row-value{font-weight:600;color:var(--c-navy-mid)}

/* Right: contact form */
.contact-form-box{
  background:var(--c-white);
  border:1.5px solid var(--c-border);
  border-radius:var(--r-xl);
  padding:36px 32px;
  box-shadow:var(--sh-md);
}
.form-title{font-family:var(--font-display);font-size:20px;font-weight:800;color:var(--c-navy);letter-spacing:-0.02em;margin-bottom:6px}
.form-subtitle{font-size:14px;color:var(--c-muted);margin-bottom:28px;line-height:1.5}
.cf-selected-topic{
  display:none;
  align-items:center;gap:10px;
  background:var(--c-primary-light);
  border:1.5px solid rgba(37,99,235,0.20);
  border-radius:var(--r);
  padding:12px 16px;
  margin-bottom:20px;
  font-size:13.5px;font-weight:600;color:var(--c-primary);
}
.cf-selected-topic.visible{display:flex}
.cf-topic-change{font-size:12px;color:var(--c-muted);margin-left:auto;cursor:pointer;text-decoration:underline;text-underline-offset:2px;font-weight:400}
.cf-topic-change:hover{color:var(--c-primary)}
.contact-form{display:flex;flex-direction:column;gap:16px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-field{display:flex;flex-direction:column;gap:5px}
.form-field label{font-size:12.5px;font-weight:700;color:var(--c-slate);letter-spacing:.02em}
.form-field input,.form-field select,.form-field textarea{
  font-family:var(--font-body);font-size:14px;color:var(--c-body);
  background:var(--c-bg);border:1.5px solid var(--c-border);
  border-radius:var(--r);padding:11px 14px;outline:none;
  transition:border-color var(--t),box-shadow var(--t);width:100%;
}
.form-field input::placeholder,.form-field textarea::placeholder{color:var(--c-subtle)}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(37,99,235,0.12)}
.form-field textarea{resize:vertical;min-height:100px;line-height:1.55}
.btn-contact-submit{
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-body);font-size:15px;font-weight:800;
  color:#fff;background:var(--c-primary);
  padding:15px 24px;border-radius:var(--r);
  border:none;cursor:pointer;width:100%;
  transition:all var(--t);margin-top:4px;
}
.btn-contact-submit:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}
.form-note{font-size:12px;color:var(--c-subtle);text-align:center;margin-top:10px;line-height:1.5}

/* Form success */
.form-success{
  display:none;text-align:center;padding:32px 20px;
}
.form-success-icon{font-size:48px;margin-bottom:16px}
.form-success h3{font-family:var(--font-display);font-size:22px;font-weight:800;color:var(--c-navy);margin-bottom:8px}
.form-success p{font-size:15px;color:var(--c-muted);line-height:1.6}

/* ── FAQ ──────────────────────────────────────── */
.faq-section{padding:80px 0}
.faq-inner{max-width:720px;margin:0 auto}
.faq-list{display:flex;flex-direction:column;margin-top:40px}
.faq-item{border-bottom:1px solid var(--c-border)}
.faq-item:first-child{border-top:1px solid var(--c-border)}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0;text-align:left;font-size:15px;font-weight:600;color:var(--c-navy-mid);background:none;cursor:pointer;transition:color var(--t)}
.faq-question:hover{color:var(--c-primary)}
.faq-question svg{flex-shrink:0;transition:transform var(--t);color:var(--c-subtle)}
.faq-item.open .faq-question{color:var(--c-primary)}
.faq-item.open .faq-question svg{transform:rotate(180deg);color:var(--c-primary)}
.faq-answer{overflow:hidden;max-height:0;transition:max-height 0.35s cubic-bezier(0.4,0,0.2,1)}
.faq-answer-inner{padding:0 0 22px;font-size:15px;color:var(--c-muted);line-height:1.70}

/* ── FINAL CTA ────────────────────────────────── */
.final-cta{background:linear-gradient(135deg,#1D4ED8 0%,var(--c-primary) 50%,#0284C7 100%);text-align:center;padding:80px 0;position:relative;overflow:hidden}
.final-cta::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.07) 1px,transparent 1px);background-size:28px 28px}
.final-cta h2{font-family:var(--font-display);font-size:clamp(26px,3.5vw,40px);font-weight:800;color:#fff;letter-spacing:-0.025em;line-height:1.1;margin-bottom:12px;position:relative}
.final-cta p{font-size:16px;color:rgba(255,255,255,0.72);max-width:440px;margin:0 auto 32px;line-height:1.6;position:relative}
.final-ctas{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;position:relative}
.btn-cta-white{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:800;color:var(--c-primary);background:#fff;padding:14px 28px;border-radius:var(--r);transition:all var(--t);box-shadow:0 4px 20px rgba(0,0,0,0.15)}
.btn-cta-white:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,0.20)}
.btn-cta-wa{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:700;color:#fff;background:rgba(255,255,255,0.15);border:1.5px solid rgba(255,255,255,0.35);padding:13px 24px;border-radius:var(--r);transition:all var(--t)}
.btn-cta-wa:hover{background:rgba(255,255,255,0.22);border-color:rgba(255,255,255,0.55)}

/* FOOTER */
.footer{background:var(--c-navy);padding:64px 0 32px}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,0.10);margin-bottom:32px}
.footer-logo img{height:32px;margin-bottom:16px;filter:brightness(0) invert(1)}
.footer-tagline{font-size:14px;color:rgba(255,255,255,0.50);line-height:1.6;max-width:240px;margin-bottom:20px}
.footer-social{display:flex;gap:10px}
.footer-social-link{width:36px;height:36px;background:rgba(255,255,255,0.08);border-radius:8px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.60);transition:all var(--t);font-size:13px;font-weight:700}
.footer-social-link:hover{background:var(--c-primary);color:#fff}
.footer-col h5{font-family:var(--font-display);font-size:13px;font-weight:700;color:rgba(255,255,255,0.85);letter-spacing:.04em;text-transform:uppercase;margin-bottom:16px}
.footer-col ul{display:flex;flex-direction:column;gap:10px}
.footer-col ul li a{font-size:14px;color:rgba(255,255,255,0.50);transition:color var(--t)}
.footer-col ul li a:hover{color:rgba(255,255,255,0.90)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.footer-bottom p{font-size:13px;color:rgba(255,255,255,0.35)}
.footer-contact-row{display:flex;gap:24px;flex-wrap:wrap}
.footer-contact-row a{display:flex;align-items:center;gap:7px;font-size:13px;color:rgba(255,255,255,0.50);transition:color var(--t)}
.footer-contact-row a:hover{color:rgba(255,255,255,0.90)}

.fade-up{opacity:0;transform:translateY(24px);transition:opacity 0.55s ease,transform 0.55s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up.d1{transition-delay:.08s}.fade-up.d2{transition-delay:.16s}.fade-up.d3{transition-delay:.24s}

/* RESPONSIVE */
@media(max-width:1000px){
  .contact-grid{grid-template-columns:1fr;gap:40px}
  .channels-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
}
@media(max-width:640px){
  .nav-links,.nav-ctas{display:none}
  .nav-hamburger{display:flex}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .channels-grid{grid-template-columns:1fr}
}

/* ----- casos.html ----- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);font-size:16px;line-height:1.6;color:var(--c-body);background:var(--c-white);-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font-family:inherit}
ul{list-style:none}
.container{max-width:var(--w-max);margin:0 auto;padding:0 24px}

/* ANN BAR */
.ann-bar{background:var(--c-navy-mid);color:#fff;padding:10px 24px;font-size:13.5px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:12px;position:relative}
.ann-bar a{color:#93C5FD;text-decoration:underline;text-underline-offset:2px}
.ann-badge{background:var(--c-primary);color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:2px 8px;border-radius:4px;white-space:nowrap}
.ann-close{position:absolute;right:20px;top:50%;transform:translateY(-50%);color:var(--c-subtle);font-size:18px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.ann-close:hover{color:#fff}

/* NAV */
.nav{position:sticky;top:0;z-index:900;background:rgba(255,255,255,0.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--c-border);box-shadow:0 1px 3px rgba(15,23,42,0.06)}
.nav-inner{max-width:var(--w-max);margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;gap:32px}
.nav-logo img{height:34px;width:auto}
.nav-links{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--c-slate);padding:8px 14px;border-radius:var(--r-sm);transition:color var(--t),background var(--t)}
.nav-links a:hover{color:var(--c-primary);background:var(--c-primary-light)}
.nav-links a.active{color:var(--c-primary);font-weight:700}
.nav-ctas{display:flex;align-items:center;gap:10px;margin-left:12px}
.btn-nav-login{font-size:14px;font-weight:600;color:var(--c-slate);padding:8px 16px;border-radius:var(--r-sm);border:1px solid var(--c-border);transition:all var(--t)}
.btn-nav-login:hover{color:var(--c-primary);border-color:var(--c-primary);background:var(--c-primary-light)}
.btn-nav-demo{font-size:14px;font-weight:700;color:#fff;background:var(--c-primary);padding:9px 20px;border-radius:var(--r-sm);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-nav-demo:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;margin-left:auto}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--c-navy-mid);border-radius:2px}
.mobile-menu{display:none;flex-direction:column;background:var(--c-white);padding:16px 24px 24px;border-top:1px solid var(--c-border)}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:15px;font-weight:500;color:var(--c-slate);padding:12px 0;border-bottom:1px solid var(--c-border)}
.mobile-menu a.active{color:var(--c-primary);font-weight:700}
.mobile-menu a:last-child{border-bottom:none}

/* BREADCRUMB */
.breadcrumb-bar{background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:10px 0}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--c-muted)}
.breadcrumb a{color:var(--c-muted);transition:color var(--t)}
.breadcrumb a:hover{color:var(--c-primary)}
.breadcrumb-sep{color:var(--c-subtle);font-size:11px}
.breadcrumb-current{color:var(--c-slate);font-weight:600}

/* ── HERO ─────────────────────────────────────── */
.casos-hero{
  background:var(--c-white);
  padding:72px 0 0;
  border-bottom:1px solid var(--c-border);
  overflow:hidden;position:relative;
}
.casos-hero::after{
  content:'';position:absolute;
  bottom:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--c-primary) 0%,var(--c-green) 50%,var(--c-primary) 100%);
}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:end;padding-bottom:52px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--c-green-light);border:1px solid rgba(5,150,105,0.25);color:var(--c-green);font-size:12px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:5px 14px;border-radius:100px;margin-bottom:22px}
.casos-hero h1{font-family:var(--font-display);font-size:clamp(30px,4vw,48px);font-weight:800;line-height:1.1;letter-spacing:-0.03em;color:var(--c-navy);margin-bottom:18px}
.casos-hero h1 em{font-style:normal;color:var(--c-primary)}
.casos-hero .sub{font-size:17px;line-height:1.65;color:var(--c-muted);max-width:480px;margin-bottom:32px}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap}
.btn-primary{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:700;color:#fff;background:var(--c-primary);padding:14px 28px;border-radius:var(--r);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-primary:hover{background:var(--c-primary-dark);transform:translateY(-2px);box-shadow:var(--sh-blue)}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:600;color:var(--c-slate);background:var(--c-bg);border:1.5px solid var(--c-border);padding:13px 22px;border-radius:var(--r);transition:all var(--t)}
.btn-ghost:hover{color:var(--c-primary);border-color:var(--c-primary);background:var(--c-primary-light)}

/* Hero right: impact numbers */
.hero-numbers{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.hero-num-card{background:var(--c-bg);border:1.5px solid var(--c-border);border-radius:var(--r-lg);padding:22px 20px;transition:border-color var(--t)}
.hero-num-card:hover{border-color:rgba(37,99,235,0.25)}
.hero-num-card.placeholder{border-style:dashed;border-color:rgba(37,99,235,0.20);background:var(--c-primary-light)}
.hn-value{font-family:var(--font-display);font-size:36px;font-weight:800;letter-spacing:-0.04em;line-height:1;margin-bottom:6px}
.hn-label{font-size:13px;color:var(--c-muted);line-height:1.4}
.hn-note{font-size:11px;color:var(--c-subtle);margin-top:4px;font-style:italic}

/* ── CASE STUDIES ─────────────────────────────── */
.cases-section{padding:88px 0}
.cases-header{max-width:580px;margin-bottom:56px}
.section-eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--c-primary);margin-bottom:14px}
.section-eyebrow-bar{width:24px;height:2px;background:var(--c-primary);border-radius:2px}
.section-h2{font-family:var(--font-display);font-size:clamp(26px,3vw,36px);font-weight:800;line-height:1.15;letter-spacing:-0.025em;color:var(--c-navy);margin-bottom:14px}
.section-sub{font-size:17px;line-height:1.65;color:var(--c-muted)}

/* Case study card */
.case-card{
  background:var(--c-white);
  border:1.5px solid var(--c-border);
  border-radius:var(--r-xl);
  overflow:hidden;
  margin-bottom:32px;
  box-shadow:var(--sh-sm);
  transition:box-shadow var(--t);
}
.case-card:hover{box-shadow:var(--sh-md)}
.case-card.placeholder-card{
  border-style:dashed;
  border-color:rgba(37,99,235,0.25);
  background:linear-gradient(160deg,var(--c-primary-light) 0%,var(--c-white) 50%);
}

/* Card header */
.cc-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 28px;
  border-bottom:1px solid var(--c-border);
  flex-wrap:wrap;gap:12px;
}
.cc-identity{display:flex;align-items:center;gap:14px}
.cc-avatar{
  width:48px;height:48px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;flex-shrink:0;
}
.cc-name{font-family:var(--font-display);font-size:17px;font-weight:800;color:var(--c-navy);letter-spacing:-0.01em}
.cc-location{font-size:13px;color:var(--c-muted);margin-top:2px}
.cc-tags{display:flex;gap:8px;flex-wrap:wrap}
.cc-tag{font-size:11.5px;font-weight:600;padding:4px 11px;border-radius:100px}

/* Card body: before/after */
.cc-body{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--c-border)}
.cc-before,.cc-after{padding:24px 28px}
.cc-before{background:#FFFAFA;border-right:1px solid var(--c-border)}
.cc-after{background:#F0FDF9}
.cc-section-label{
  display:flex;align-items:center;gap:7px;
  font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  margin-bottom:12px;
}
.cc-section-label.before{color:var(--c-red)}
.cc-section-label.after{color:var(--c-green)}
.cc-points{display:flex;flex-direction:column;gap:8px}
.cc-point{display:flex;align-items:flex-start;gap:8px;font-size:14px;color:var(--c-body);line-height:1.45}
.cc-point-icon{
  width:18px;height:18px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;margin-top:1px;font-size:10px;
}
.cc-point-icon.red{background:var(--c-red-light);color:var(--c-red)}
.cc-point-icon.green{background:var(--c-green-light);color:var(--c-green)}
.placeholder-line{
  height:14px;background:rgba(37,99,235,0.12);
  border-radius:4px;margin-bottom:8px;
}

/* Card footer: modules + quote */
.cc-footer{display:grid;grid-template-columns:1fr 1fr;padding:24px 28px;gap:24px}
.cc-modules-used h5{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--c-muted);margin-bottom:10px}
.cc-module-chips{display:flex;flex-wrap:wrap;gap:7px}
.cc-module-chip{font-size:11.5px;font-weight:600;color:var(--c-primary);background:var(--c-primary-light);padding:3px 10px;border-radius:100px;border:1px solid rgba(37,99,235,0.18)}
.cc-quote{background:var(--c-bg);border-radius:var(--r-lg);padding:18px 20px;border-left:3px solid var(--c-primary)}
.cc-quote-text{font-size:14px;font-style:italic;color:var(--c-body);line-height:1.60;margin-bottom:10px}
.cc-quote-author{font-size:12.5px;font-weight:700;color:var(--c-navy-mid)}
.cc-quote-role{font-size:12px;color:var(--c-muted)}

/* Placeholder quote */
.cc-quote.placeholder{
  border-left-color:rgba(37,99,235,0.25);
  background:var(--c-primary-light);
}
.cc-quote-placeholder{
  font-size:13px;color:var(--c-primary);
  border:2px dashed rgba(37,99,235,0.20);
  border-radius:var(--r);
  padding:14px;
  background:rgba(255,255,255,0.60);
  line-height:1.55;
}
.placeholder-note{display:inline-block;font-size:11px;font-weight:700;color:var(--c-primary);background:#DBEAFE;padding:3px 9px;border-radius:100px;margin-top:8px}

/* ── TESTIMONIALS ─────────────────────────────── */
.testimonials-section{padding:80px 0;background:var(--c-bg)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px}
.testi-card{
  background:var(--c-white);
  border:1.5px solid var(--c-border);
  border-radius:var(--r-xl);
  padding:28px 24px;
  box-shadow:var(--sh-sm);
}
.testi-card.placeholder{
  border-style:dashed;
  border-color:rgba(37,99,235,0.22);
  background:var(--c-primary-light);
}
.quote-mark{font-family:Georgia,serif;font-size:56px;line-height:0.7;color:var(--c-primary-light);margin-bottom:16px;display:block}
.testi-card.placeholder .quote-mark{color:rgba(37,99,235,0.18)}
.testi-text{font-size:15px;line-height:1.65;color:var(--c-body);margin-bottom:20px;font-style:italic}
.testi-placeholder-box{
  font-size:13px;color:var(--c-muted);font-style:normal;
  border:2px dashed rgba(37,99,235,0.18);
  border-radius:var(--r);padding:14px;
  background:rgba(255,255,255,0.60);line-height:1.55;
}
.testi-author{display:flex;align-items:center;gap:12px}
.testi-avatar{width:42px;height:42px;border-radius:50%;background:var(--c-border);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.testi-card.placeholder .testi-avatar{background:rgba(37,99,235,0.10)}
.testi-name{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.testi-role{font-size:12px;color:var(--c-muted)}

/* ── FAQ ──────────────────────────────────────── */
.faq-grid{display:grid;grid-template-columns:300px 1fr;gap:64px;align-items:start}
.faq-sidebar h3{font-family:var(--font-display);font-size:24px;font-weight:800;color:var(--c-navy);margin-bottom:12px;letter-spacing:-0.02em}
.faq-sidebar p{font-size:15px;color:var(--c-muted);line-height:1.6;margin-bottom:22px}
.faq-contact{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--c-primary);transition:gap var(--t)}
.faq-contact:hover{gap:12px}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--c-border)}
.faq-item:first-child{border-top:1px solid var(--c-border)}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0;text-align:left;font-size:15px;font-weight:600;color:var(--c-navy-mid);background:none;cursor:pointer;transition:color var(--t)}
.faq-question:hover{color:var(--c-primary)}
.faq-question svg{flex-shrink:0;transition:transform var(--t);color:var(--c-subtle)}
.faq-item.open .faq-question{color:var(--c-primary)}
.faq-item.open .faq-question svg{transform:rotate(180deg);color:var(--c-primary)}
.faq-answer{overflow:hidden;max-height:0;transition:max-height 0.35s cubic-bezier(0.4,0,0.2,1)}
.faq-answer-inner{padding:0 0 22px;font-size:15px;color:var(--c-muted);line-height:1.70}

/* FINAL CTA */
.final-cta{background:linear-gradient(135deg,#1D4ED8 0%,var(--c-primary) 50%,#0284C7 100%);text-align:center;padding:96px 0;position:relative;overflow:hidden}
.final-cta::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.07) 1px,transparent 1px);background-size:28px 28px}
.final-cta h2{font-family:var(--font-display);font-size:clamp(28px,4vw,44px);font-weight:800;color:#fff;letter-spacing:-0.025em;line-height:1.1;margin-bottom:14px;position:relative}
.final-cta p{font-size:17px;color:rgba(255,255,255,0.75);max-width:480px;margin:0 auto 36px;line-height:1.6;position:relative}
.final-ctas{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;position:relative}
.btn-cta-white{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:800;color:var(--c-primary);background:#fff;padding:16px 32px;border-radius:var(--r);transition:all var(--t);box-shadow:0 4px 20px rgba(0,0,0,0.15)}
.btn-cta-white:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,0.20)}
.btn-cta-wa{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:700;color:#fff;background:rgba(255,255,255,0.15);border:1.5px solid rgba(255,255,255,0.35);padding:15px 28px;border-radius:var(--r);transition:all var(--t)}
.btn-cta-wa:hover{background:rgba(255,255,255,0.22);border-color:rgba(255,255,255,0.55)}

/* FOOTER */
.footer{background:var(--c-navy);padding:64px 0 32px}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,0.10);margin-bottom:32px}
.footer-logo img{height:32px;margin-bottom:16px;filter:brightness(0) invert(1)}
.footer-tagline{font-size:14px;color:rgba(255,255,255,0.50);line-height:1.6;max-width:240px;margin-bottom:20px}
.footer-social{display:flex;gap:10px}
.footer-social-link{width:36px;height:36px;background:rgba(255,255,255,0.08);border-radius:8px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.60);transition:all var(--t);font-size:13px;font-weight:700}
.footer-social-link:hover{background:var(--c-primary);color:#fff}
.footer-col h5{font-family:var(--font-display);font-size:13px;font-weight:700;color:rgba(255,255,255,0.85);letter-spacing:.04em;text-transform:uppercase;margin-bottom:16px}
.footer-col ul{display:flex;flex-direction:column;gap:10px}
.footer-col ul li a{font-size:14px;color:rgba(255,255,255,0.50);transition:color var(--t)}
.footer-col ul li a:hover{color:rgba(255,255,255,0.90)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.footer-bottom p{font-size:13px;color:rgba(255,255,255,0.35)}
.footer-contact a{display:flex;align-items:center;gap:7px;font-size:13px;color:rgba(255,255,255,0.50);transition:color var(--t)}
.footer-contact a:hover{color:rgba(255,255,255,0.90)}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,0.70);backdrop-filter:blur(6px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity 0.25s ease}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{background:var(--c-white);border-radius:var(--r-xl);width:100%;max-width:560px;overflow:hidden;box-shadow:var(--sh-lg);transform:translateY(20px) scale(0.97);transition:transform 0.25s ease}
.modal-overlay.open .modal-box{transform:translateY(0) scale(1)}
.modal-header{background:linear-gradient(135deg,var(--c-navy) 0%,var(--c-navy-mid) 100%);padding:28px 32px 24px;position:relative}
.modal-header h2{font-family:var(--font-display);font-size:22px;font-weight:800;color:#fff;margin-bottom:6px;letter-spacing:-0.02em}
.modal-header p{font-size:14px;color:rgba(255,255,255,0.60)}
.modal-close{position:absolute;top:16px;right:20px;color:rgba(255,255,255,0.50);font-size:22px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.modal-close:hover{color:#fff}
.modal-body{padding:28px 32px 32px}
.modal-option-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:22px}
.modal-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 14px;border-radius:var(--r-lg);border:2px solid var(--c-border);cursor:pointer;text-align:center;transition:all var(--t);text-decoration:none;color:inherit}
.modal-option:hover{border-color:var(--c-primary);background:var(--c-primary-light)}
.modal-option.option-wa:hover{border-color:#25D366;background:#F0FDF4}
.modal-option-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px}
.opt-title{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.opt-sub{font-size:12px;color:var(--c-muted)}
.modal-divider{display:flex;align-items:center;gap:12px;color:var(--c-subtle);font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:20px}
.modal-divider::before,.modal-divider::after{content:'';flex:1;height:1px;background:var(--c-border)}
.modal-form{display:flex;flex-direction:column;gap:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-field{display:flex;flex-direction:column;gap:5px}
.form-field label{font-size:12.5px;font-weight:700;color:var(--c-slate);letter-spacing:.02em}
.form-field input,.form-field select{font-family:var(--font-body);font-size:14px;color:var(--c-body);background:var(--c-bg);border:1.5px solid var(--c-border);border-radius:var(--r);padding:11px 14px;outline:none;transition:border-color var(--t),box-shadow var(--t);width:100%}
.form-field input::placeholder{color:var(--c-subtle)}
.form-field input:focus,.form-field select:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(37,99,235,0.12)}
.btn-form-submit{font-family:var(--font-body);font-size:15px;font-weight:800;color:#fff;background:var(--c-primary);padding:14px 24px;border-radius:var(--r);border:none;cursor:pointer;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--t);margin-top:4px}
.btn-form-submit:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}
.modal-thanks{display:none;text-align:center;padding:32px}
.modal-thanks-icon{width:64px;height:64px;background:var(--c-green-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-size:32px}
.modal-thanks h3{font-family:var(--font-display);font-size:22px;font-weight:800;color:var(--c-navy);margin-bottom:8px}
.modal-thanks p{font-size:15px;color:var(--c-muted);line-height:1.6}

.fade-up{opacity:0;transform:translateY(24px);transition:opacity 0.55s ease,transform 0.55s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up.d1{transition-delay:.08s}.fade-up.d2{transition-delay:.16s}.fade-up.d3{transition-delay:.24s}

/* RESPONSIVE */
@media(max-width:1000px){
  .hero-inner{grid-template-columns:1fr;gap:40px}
  .hero-numbers{max-width:440px}
  .cc-body{grid-template-columns:1fr}
  .cc-before{border-right:none;border-bottom:1px solid var(--c-border)}
  .cc-footer{grid-template-columns:1fr}
  .testi-grid{grid-template-columns:1fr}
  .faq-grid{grid-template-columns:1fr;gap:40px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
}
@media(max-width:640px){
  .nav-links,.nav-ctas{display:none}
  .nav-hamburger{display:flex}
  .hero-numbers{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .modal-option-row,.form-row{grid-template-columns:1fr}
}

/* ----- blog.html ----- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);font-size:16px;line-height:1.6;color:var(--c-body);background:var(--c-white);-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font-family:inherit}
ul{list-style:none}
.container{max-width:var(--w-max);margin:0 auto;padding:0 24px}

/* ANN BAR */
.ann-bar{background:var(--c-navy-mid);color:#fff;padding:10px 24px;font-size:13.5px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:12px;position:relative}
.ann-bar a{color:#93C5FD;text-decoration:underline;text-underline-offset:2px}
.ann-badge{background:var(--c-primary);color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:2px 8px;border-radius:4px;white-space:nowrap}
.ann-close{position:absolute;right:20px;top:50%;transform:translateY(-50%);color:var(--c-subtle);font-size:18px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.ann-close:hover{color:#fff}

/* NAV */
.nav{position:sticky;top:0;z-index:900;background:rgba(255,255,255,0.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--c-border);box-shadow:0 1px 3px rgba(15,23,42,0.06)}
.nav-inner{max-width:var(--w-max);margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;gap:32px}
.nav-logo img{height:34px;width:auto}
.nav-links{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--c-slate);padding:8px 14px;border-radius:var(--r-sm);transition:color var(--t),background var(--t)}
.nav-links a:hover{color:var(--c-primary);background:var(--c-primary-light)}
.nav-links a.active{color:var(--c-primary);font-weight:700}
.nav-ctas{display:flex;align-items:center;gap:10px;margin-left:12px}
.btn-nav-login{font-size:14px;font-weight:600;color:var(--c-slate);padding:8px 16px;border-radius:var(--r-sm);border:1px solid var(--c-border);transition:all var(--t)}
.btn-nav-login:hover{color:var(--c-primary);border-color:var(--c-primary);background:var(--c-primary-light)}
.btn-nav-demo{font-size:14px;font-weight:700;color:#fff;background:var(--c-primary);padding:9px 20px;border-radius:var(--r-sm);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-nav-demo:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;margin-left:auto}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--c-navy-mid);border-radius:2px;transition:all var(--t)}
.mobile-menu{display:none;flex-direction:column;background:var(--c-white);padding:16px 24px 24px;border-top:1px solid var(--c-border)}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:15px;font-weight:500;color:var(--c-slate);padding:12px 0;border-bottom:1px solid var(--c-border)}
.mobile-menu a.active{color:var(--c-primary);font-weight:700}
.mobile-menu a:last-child{border-bottom:none}

/* BREADCRUMB */
.breadcrumb-bar{background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:10px 0}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--c-muted)}
.breadcrumb a{color:var(--c-muted);transition:color var(--t)}
.breadcrumb a:hover{color:var(--c-primary)}
.breadcrumb-sep{color:var(--c-subtle);font-size:11px}
.breadcrumb-current{color:var(--c-slate);font-weight:600}

/* ── BLOG MASTHEAD ───────────────────────────── */
.blog-masthead{
  background:var(--c-navy);
  padding:56px 0 0;
  position:relative;
  overflow:hidden;
}
.blog-masthead::before{
  content:'';
  position:absolute;inset:0;
  background:
    linear-gradient(rgba(37,99,235,0.12) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,235,0.12) 1px, transparent 1px);
  background-size:80px 80px;
  pointer-events:none;
}
.masthead-inner{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:end;
  position:relative;
  padding-bottom:48px;
}
.masthead-left{}
.masthead-kicker{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;font-weight:700;letter-spacing:.10em;text-transform:uppercase;
  color:#93C5FD;margin-bottom:18px;
}
.masthead-kicker-line{width:28px;height:1px;background:#93C5FD}
.masthead-title{
  font-family:var(--font-serif);
  font-size:clamp(36px,5vw,62px);
  font-weight:400;
  line-height:1.05;
  letter-spacing:-0.01em;
  color:#fff;
  margin-bottom:16px;
}
.masthead-title em{font-style:italic;color:#93C5FD}
.masthead-sub{
  font-size:16px;line-height:1.65;
  color:rgba(255,255,255,0.60);
  max-width:440px;
  margin-bottom:28px;
}
.masthead-meta{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.masthead-stat{
  display:flex;align-items:center;gap:7px;
  font-size:13px;color:rgba(255,255,255,0.50);
}
.masthead-stat strong{color:rgba(255,255,255,0.80);font-weight:700}

/* Featured article in masthead */
.masthead-featured{
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:var(--r-xl);
  padding:28px;
  position:relative;
  overflow:hidden;
  cursor:pointer;
  transition:background var(--t),border-color var(--t);
  text-decoration:none;
  display:block;
}
.masthead-featured:hover{
  background:rgba(255,255,255,0.10);
  border-color:rgba(255,255,255,0.22);
}
.mf-badge{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  background:rgba(37,99,235,0.30);
  border:1px solid rgba(37,99,235,0.50);
  color:#93C5FD;
  padding:3px 10px;border-radius:100px;
  margin-bottom:16px;
}
.mf-prox{background:rgba(217,119,6,0.30);border-color:rgba(217,119,6,0.50);color:#FCD34D}
.mf-title{
  font-family:var(--font-display);
  font-size:20px;font-weight:800;
  line-height:1.2;letter-spacing:-0.02em;
  color:#fff;margin-bottom:12px;
}
.mf-excerpt{
  font-size:14px;color:rgba(255,255,255,0.60);
  line-height:1.60;margin-bottom:20px;
}
.mf-meta{display:flex;align-items:center;gap:14px;font-size:12.5px;color:rgba(255,255,255,0.40)}
.mf-meta span{display:flex;align-items:center;gap:5px}
.mf-category-chip{
  display:inline-flex;align-items:center;gap:5px;
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;
  padding:3px 10px;border-radius:100px;
}

/* ── CATEGORY FILTER BAR ─────────────────────── */
.cat-bar{
  background:var(--c-white);
  border-bottom:1px solid var(--c-border);
  padding:14px 0;
  position:sticky;
  top:64px;
  z-index:700;
  box-shadow:0 2px 8px rgba(15,23,42,0.05);
}
.cat-bar-inner{
  display:flex;align-items:center;gap:10px;
  overflow-x:auto;scrollbar-width:none;
  padding:0 24px;max-width:var(--w-max);margin:0 auto;
}
.cat-bar-inner::-webkit-scrollbar{display:none}
.cat-btn{
  display:inline-flex;align-items:center;gap:7px;
  font-family:var(--font-body);font-size:13px;font-weight:600;
  color:var(--c-muted);background:var(--c-bg);
  border:1.5px solid var(--c-border);
  padding:7px 16px;border-radius:100px;
  white-space:nowrap;cursor:pointer;
  transition:all var(--t);
}
.cat-btn.active,.cat-btn:hover{border-color:var(--c-primary);color:var(--c-primary);background:var(--c-primary-light)}
.cat-btn.cat-all.active{background:var(--c-navy);border-color:var(--c-navy);color:#fff}
.cat-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}

/* ── BLOG GRID ───────────────────────────────── */
.blog-grid-section{padding:64px 0}
.blog-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}

/* Article card */
.article-card{
  background:var(--c-white);
  border:1.5px solid var(--c-border);
  border-radius:var(--r-lg);
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:border-color var(--t),box-shadow var(--t),transform var(--t);
  position:relative;
}
.article-card:hover{
  border-color:rgba(37,99,235,0.25);
  box-shadow:var(--sh-md);
  transform:translateY(-3px);
}
.article-card.coming{
  cursor:default;
  opacity:0.75;
}
.article-card.coming:hover{transform:none;box-shadow:none;border-color:var(--c-border)}

/* Category accent bar on top */
.ac-accent{height:4px;width:100%}

.ac-thumb{
  height:140px;
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.ac-thumb-icon{
  font-size:40px;
  opacity:0.18;
  position:absolute;
  right:20px;bottom:10px;
}
.ac-thumb-label{
  font-family:var(--font-display);
  font-size:clamp(14px,1.8vw,18px);
  font-weight:800;
  letter-spacing:-0.02em;
  line-height:1.2;
  color:rgba(255,255,255,0.90);
  padding:0 20px;
  text-align:left;
  width:100%;
  position:relative;
  z-index:1;
}

.ac-body{padding:20px;flex:1;display:flex;flex-direction:column}
.ac-category{
  display:inline-flex;align-items:center;gap:5px;
  font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  margin-bottom:10px;
}
.ac-title{
  font-family:var(--font-display);
  font-size:16px;font-weight:700;
  line-height:1.3;letter-spacing:-0.01em;
  color:var(--c-navy);margin-bottom:8px;
}
.ac-excerpt{
  font-size:13.5px;color:var(--c-muted);
  line-height:1.55;margin-bottom:16px;flex:1;
}
.ac-footer{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:auto;padding-top:14px;
  border-top:1px solid var(--c-border);
}
.ac-meta{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--c-subtle)}
.ac-avatar{
  width:24px;height:24px;border-radius:50%;
  background:var(--c-primary-light);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;color:var(--c-primary);
}
.ac-read{
  font-size:12.5px;font-weight:700;
  color:var(--c-primary);
  display:flex;align-items:center;gap:5px;
  transition:gap var(--t);
}
.article-card:not(.coming) .ac-read:hover{gap:8px}
.ac-coming-badge{
  font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
  background:var(--c-bg);color:var(--c-subtle);
  border:1px solid var(--c-border);
  padding:3px 9px;border-radius:100px;
}

/* ── TOPICS SECTION ──────────────────────────── */
.topics-section{padding:64px 0;background:var(--c-bg)}
.topics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:40px}
.topic-card{
  background:var(--c-white);
  border:1.5px solid var(--c-border);
  border-radius:var(--r-lg);
  padding:22px 18px;
  transition:border-color var(--t),box-shadow var(--t),transform var(--t);
}
.topic-card:hover{border-color:rgba(37,99,235,0.25);box-shadow:var(--sh-sm);transform:translateY(-2px)}
.topic-icon{
  width:40px;height:40px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:12px;
  font-size:20px;
}
.topic-name{font-family:var(--font-display);font-size:14.5px;font-weight:700;color:var(--c-navy-mid);margin-bottom:6px}
.topic-desc{font-size:13px;color:var(--c-muted);line-height:1.5;margin-bottom:12px}
.topic-count{
  font-size:12px;font-weight:600;
  color:var(--c-subtle);
}
.topic-count span{
  color:var(--c-primary);font-weight:700;
}

/* ── NEWSLETTER SECTION ──────────────────────── */
.newsletter-section{
  padding:72px 0;
  background:var(--c-navy);
  position:relative;overflow:hidden;
}
.newsletter-section::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 80% at 80% 50%,rgba(37,99,235,0.18) 0%,transparent 60%);
  pointer-events:none;
}
.newsletter-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:72px;align-items:center;position:relative;
}
.nl-left h2{
  font-family:var(--font-serif);
  font-size:clamp(28px,3.5vw,42px);
  font-weight:400;line-height:1.1;
  color:#fff;margin-bottom:14px;
}
.nl-left h2 em{font-style:italic;color:#93C5FD}
.nl-left p{font-size:16px;color:rgba(255,255,255,0.60);line-height:1.65;margin-bottom:20px}
.nl-bullets{display:flex;flex-direction:column;gap:10px}
.nl-bullet{display:flex;align-items:center;gap:10px;font-size:14px;color:rgba(255,255,255,0.70)}
.nl-bullet-dot{width:6px;height:6px;border-radius:50%;background:#93C5FD;flex-shrink:0}

.nl-form-box{
  background:rgba(255,255,255,0.07);
  border:1px solid rgba(255,255,255,0.15);
  border-radius:var(--r-xl);
  padding:32px 28px;
}
.nl-form-title{
  font-family:var(--font-display);
  font-size:18px;font-weight:800;
  color:#fff;margin-bottom:6px;letter-spacing:-0.02em;
}
.nl-form-sub{font-size:14px;color:rgba(255,255,255,0.55);margin-bottom:22px;line-height:1.5}
.nl-field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.nl-field label{font-size:12px;font-weight:700;color:rgba(255,255,255,0.60);letter-spacing:.03em}
.nl-field input,.nl-field select{
  font-family:var(--font-body);font-size:14px;
  color:var(--c-body);background:rgba(255,255,255,0.95);
  border:1.5px solid rgba(255,255,255,0.20);
  border-radius:var(--r);padding:11px 14px;
  outline:none;transition:border-color var(--t);width:100%;
}
.nl-field input:focus,.nl-field select:focus{border-color:var(--c-primary)}
.btn-nl-submit{
  width:100%;font-family:var(--font-body);
  font-size:15px;font-weight:700;
  color:#fff;background:var(--c-primary);
  padding:14px;border-radius:var(--r);
  border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:8px;
  transition:all var(--t);
}
.btn-nl-submit:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}
.nl-privacy{font-size:11.5px;color:rgba(255,255,255,0.35);text-align:center;margin-top:12px;line-height:1.5}
.nl-success{
  display:none;text-align:center;padding:24px 0;
}
.nl-success-icon{font-size:40px;margin-bottom:12px}
.nl-success h4{font-family:var(--font-display);font-size:18px;font-weight:800;color:#fff;margin-bottom:8px}
.nl-success p{font-size:14px;color:rgba(255,255,255,0.60);line-height:1.6}

/* ── FOOTER ───────────────────────────────────── */
.footer{background:var(--c-navy);padding:64px 0 32px;border-top:1px solid rgba(255,255,255,0.08)}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,0.10);margin-bottom:32px}
.footer-logo img{height:32px;margin-bottom:16px;filter:brightness(0) invert(1)}
.footer-tagline{font-size:14px;color:rgba(255,255,255,0.50);line-height:1.6;max-width:240px;margin-bottom:20px}
.footer-social{display:flex;gap:10px}
.footer-social-link{width:36px;height:36px;background:rgba(255,255,255,0.08);border-radius:8px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.60);transition:all var(--t);font-size:13px;font-weight:700}
.footer-social-link:hover{background:var(--c-primary);color:#fff}
.footer-col h5{font-family:var(--font-display);font-size:13px;font-weight:700;color:rgba(255,255,255,0.85);letter-spacing:.04em;text-transform:uppercase;margin-bottom:16px}
.footer-col ul{display:flex;flex-direction:column;gap:10px}
.footer-col ul li a{font-size:14px;color:rgba(255,255,255,0.50);transition:color var(--t)}
.footer-col ul li a:hover{color:rgba(255,255,255,0.90)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.footer-bottom p{font-size:13px;color:rgba(255,255,255,0.35)}
.footer-contact a{display:flex;align-items:center;gap:7px;font-size:13px;color:rgba(255,255,255,0.50);transition:color var(--t)}
.footer-contact a:hover{color:rgba(255,255,255,0.90)}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,0.70);backdrop-filter:blur(6px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity 0.25s ease}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{background:var(--c-white);border-radius:var(--r-xl);width:100%;max-width:560px;overflow:hidden;box-shadow:var(--sh-lg);transform:translateY(20px) scale(0.97);transition:transform 0.25s ease}
.modal-overlay.open .modal-box{transform:translateY(0) scale(1)}
.modal-header{background:linear-gradient(135deg,var(--c-navy) 0%,var(--c-navy-mid) 100%);padding:28px 32px 24px;position:relative}
.modal-header h2{font-family:var(--font-display);font-size:22px;font-weight:800;color:#fff;margin-bottom:6px;letter-spacing:-0.02em}
.modal-header p{font-size:14px;color:rgba(255,255,255,0.60)}
.modal-close{position:absolute;top:16px;right:20px;color:rgba(255,255,255,0.50);font-size:22px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.modal-close:hover{color:#fff}
.modal-body{padding:28px 32px 32px}
.modal-option-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:22px}
.modal-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 14px;border-radius:var(--r-lg);border:2px solid var(--c-border);cursor:pointer;text-align:center;transition:all var(--t);text-decoration:none;color:inherit}
.modal-option:hover{border-color:var(--c-primary);background:var(--c-primary-light)}
.modal-option.option-wa:hover{border-color:#25D366;background:#F0FDF4}
.modal-option-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px}
.modal-option .opt-title{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.modal-option .opt-sub{font-size:12px;color:var(--c-muted)}
.modal-divider{display:flex;align-items:center;gap:12px;color:var(--c-subtle);font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:20px}
.modal-divider::before,.modal-divider::after{content:'';flex:1;height:1px;background:var(--c-border)}
.modal-form{display:flex;flex-direction:column;gap:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-field{display:flex;flex-direction:column;gap:5px}
.form-field label{font-size:12.5px;font-weight:700;color:var(--c-slate);letter-spacing:.02em}
.form-field input,.form-field select{font-family:var(--font-body);font-size:14px;color:var(--c-body);background:var(--c-bg);border:1.5px solid var(--c-border);border-radius:var(--r);padding:11px 14px;outline:none;transition:border-color var(--t),box-shadow var(--t);width:100%}
.form-field input::placeholder{color:var(--c-subtle)}
.form-field input:focus,.form-field select:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(37,99,235,0.12)}
.btn-form-submit{font-family:var(--font-body);font-size:15px;font-weight:800;color:#fff;background:var(--c-primary);padding:14px 24px;border-radius:var(--r);border:none;cursor:pointer;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--t);margin-top:4px}
.btn-form-submit:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}
.modal-thanks{display:none;text-align:center;padding:32px}
.modal-thanks-icon{width:64px;height:64px;background:var(--c-green-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-size:32px}
.modal-thanks h3{font-family:var(--font-display);font-size:22px;font-weight:800;color:var(--c-navy);margin-bottom:8px}
.modal-thanks p{font-size:15px;color:var(--c-muted);line-height:1.6}

/* FADE */
.fade-up{opacity:0;transform:translateY(24px);transition:opacity 0.55s ease,transform 0.55s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up.d1{transition-delay:.07s}.fade-up.d2{transition-delay:.14s}.fade-up.d3{transition-delay:.21s}
.fade-up.d4{transition-delay:.28s}.fade-up.d5{transition-delay:.35s}.fade-up.d6{transition-delay:.42s}

/* RESPONSIVE */
@media(max-width:1060px){
  .masthead-inner{grid-template-columns:1fr;gap:36px}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
  .topics-grid{grid-template-columns:repeat(2,1fr)}
  .newsletter-grid{grid-template-columns:1fr;gap:40px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
}
@media(max-width:640px){
  .nav-links,.nav-ctas{display:none}
  .nav-hamburger{display:flex}
  .blog-grid{grid-template-columns:1fr}
  .topics-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .modal-option-row{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
}

/* ----- precios.html ----- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);font-size:16px;line-height:1.6;color:var(--c-body);background:var(--c-white);-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font-family:inherit}
ul{list-style:none}
.container{max-width:var(--w-max);margin:0 auto;padding:0 24px}

/* ANN BAR */
.ann-bar{background:var(--c-navy-mid);color:#fff;padding:10px 24px;font-size:13.5px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:12px;position:relative}
.ann-bar a{color:#93C5FD;text-decoration:underline;text-underline-offset:2px}
.ann-bar a:hover{color:#BFDBFE}
.ann-badge{background:var(--c-primary);color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:2px 8px;border-radius:4px;white-space:nowrap}
.ann-close{position:absolute;right:20px;top:50%;transform:translateY(-50%);color:var(--c-subtle);font-size:18px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.ann-close:hover{color:#fff}

/* NAV */
.nav{position:sticky;top:0;z-index:900;background:rgba(255,255,255,0.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--c-border);box-shadow:0 1px 3px rgba(15,23,42,0.06)}
.nav-inner{max-width:var(--w-max);margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;gap:32px}
.nav-logo img{height:34px;width:auto}
.nav-links{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--c-slate);padding:8px 14px;border-radius:var(--r-sm);transition:color var(--t),background var(--t)}
.nav-links a:hover{color:var(--c-primary);background:var(--c-primary-light)}
.nav-links a.active{color:var(--c-primary);font-weight:700}
.nav-ctas{display:flex;align-items:center;gap:10px;margin-left:12px}
.btn-nav-login{font-size:14px;font-weight:600;color:var(--c-slate);padding:8px 16px;border-radius:var(--r-sm);border:1px solid var(--c-border);transition:all var(--t)}
.btn-nav-login:hover{color:var(--c-primary);border-color:var(--c-primary);background:var(--c-primary-light)}
.btn-nav-demo{font-size:14px;font-weight:700;color:#fff;background:var(--c-primary);padding:9px 20px;border-radius:var(--r-sm);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-nav-demo:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;margin-left:auto}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--c-navy-mid);border-radius:2px;transition:all var(--t)}
.mobile-menu{display:none;flex-direction:column;background:var(--c-white);padding:16px 24px 24px;border-top:1px solid var(--c-border)}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:15px;font-weight:500;color:var(--c-slate);padding:12px 0;border-bottom:1px solid var(--c-border)}
.mobile-menu a.active{color:var(--c-primary);font-weight:700}
.mobile-menu a:last-child{border-bottom:none}

/* BREADCRUMB */
.breadcrumb-bar{background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:10px 0}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--c-muted)}
.breadcrumb a{color:var(--c-muted);transition:color var(--t)}
.breadcrumb a:hover{color:var(--c-primary)}
.breadcrumb-sep{color:var(--c-subtle);font-size:11px}
.breadcrumb-current{color:var(--c-slate);font-weight:600}

/* ── HERO ─────────────────────────────────────── */
.precio-hero{
  background:var(--c-white);
  padding:72px 0 64px;
  position:relative;
  overflow:hidden;
  border-bottom:1px solid var(--c-border);
}
.precio-hero::before{
  content:'';position:absolute;
  top:0;right:0;
  width:600px;height:100%;
  background:linear-gradient(135deg,transparent 40%,rgba(37,99,235,0.04) 100%);
  pointer-events:none;
}
.precio-hero-inner{text-align:center;position:relative}
.ph-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--c-primary-light);
  border:1px solid rgba(37,99,235,0.22);
  color:var(--c-primary);
  font-size:12px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  padding:5px 16px;border-radius:100px;margin-bottom:22px;
}
.precio-hero h1{
  font-family:var(--font-display);
  font-size:clamp(32px,4.5vw,52px);
  font-weight:800;
  line-height:1.1;
  letter-spacing:-0.03em;
  color:var(--c-navy);
  margin-bottom:18px;
}
.precio-hero h1 em{font-style:normal;color:var(--c-primary)}
.precio-hero h1 strong{color:var(--c-green)}
.precio-hero .sub{
  font-size:17.5px;line-height:1.65;
  color:var(--c-muted);max-width:540px;
  margin:0 auto 48px;
}

/* ── PLAN CARDS ───────────────────────────────── */
.plan-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  max-width:900px;
  margin:0 auto;
}
.plan-card{
  background:var(--c-white);
  border:2px solid var(--c-border);
  border-radius:var(--r-xl);
  padding:32px 28px;
  display:flex;
  flex-direction:column;
  position:relative;
  transition:border-color var(--t),box-shadow var(--t),transform var(--t);
}
.plan-card:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}
.plan-card.free{border-color:rgba(5,150,105,0.30);background:linear-gradient(160deg,var(--c-green-light) 0%,var(--c-white) 40%)}
.plan-card.free:hover{border-color:var(--c-green);box-shadow:0 12px 36px rgba(5,150,105,0.15)}
.plan-card.paid{border-color:rgba(37,99,235,0.30);background:linear-gradient(160deg,var(--c-primary-light) 0%,var(--c-white) 40%)}
.plan-card.paid:hover{border-color:var(--c-primary);box-shadow:var(--sh-blue)}
.plan-tag{
  display:inline-flex;align-items:center;gap:7px;
  font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  padding:4px 12px;border-radius:100px;margin-bottom:20px;align-self:flex-start;
}
.plan-tag.green{background:var(--c-green-light);color:var(--c-green);border:1px solid rgba(5,150,105,0.25)}
.plan-tag.blue{background:var(--c-primary-light);color:var(--c-primary);border:1px solid rgba(37,99,235,0.25)}
.plan-audience{
  font-family:var(--font-display);
  font-size:20px;font-weight:800;
  color:var(--c-navy);
  letter-spacing:-0.02em;
  margin-bottom:6px;
}
.plan-desc{font-size:14px;color:var(--c-muted);line-height:1.55;margin-bottom:24px}
.plan-price{margin-bottom:26px}
.plan-price-main{
  font-family:var(--font-display);
  font-size:42px;font-weight:800;
  letter-spacing:-0.04em;
  line-height:1;
}
.plan-price-main.green{color:var(--c-green)}
.plan-price-main.blue{color:var(--c-primary)}
.plan-price-sub{font-size:14px;color:var(--c-muted);margin-top:6px;line-height:1.4}
.plan-divider{height:1px;background:var(--c-border);margin:0 0 22px}
.plan-features{display:flex;flex-direction:column;gap:10px;margin-bottom:28px;flex:1}
.pf-item{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--c-body)}
.pf-icon{width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.pf-icon.yes{background:var(--c-green-light)}
.pf-icon.info{background:var(--c-primary-light)}
.pf-txt strong{font-weight:700;color:var(--c-navy-mid)}
.pf-txt .note{font-size:12px;color:var(--c-muted);display:block;margin-top:1px}
.btn-plan{
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-body);font-size:15px;font-weight:700;
  padding:14px 24px;border-radius:var(--r);
  width:100%;transition:all var(--t);
}
.btn-plan.green{color:#fff;background:var(--c-green)}
.btn-plan.green:hover{background:#047857;transform:translateY(-1px);box-shadow:0 8px 24px rgba(5,150,105,0.30)}
.btn-plan.blue{color:#fff;background:var(--c-primary)}
.btn-plan.blue:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}

/* Conector entre cards */
.plan-connector{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:0 12px;
  position:relative;
}
.plan-connector-line{
  width:1px;height:120px;
  background:linear-gradient(to bottom,transparent,var(--c-border),var(--c-border),transparent);
}
.plan-connector-badge{
  position:absolute;
  background:var(--c-white);
  border:1.5px solid var(--c-border);
  border-radius:100px;
  padding:6px 14px;
  font-size:12px;font-weight:700;
  color:var(--c-primary);
  white-space:nowrap;
  text-align:center;
  box-shadow:var(--sh-sm);
}

/* ── COMO SE COTIZA ───────────────────────────── */
.quote-section{padding:80px 0}
.quote-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.quote-left{}
.quote-right{}

/* Unit range selector */
.unit-selector{margin:28px 0}
.unit-selector-label{font-size:13px;font-weight:700;color:var(--c-muted);letter-spacing:.04em;text-transform:uppercase;margin-bottom:12px}
.unit-btns{display:flex;gap:10px;flex-wrap:wrap}
.unit-btn{
  font-family:var(--font-body);
  font-size:14px;font-weight:600;
  color:var(--c-slate);
  background:var(--c-bg);
  border:2px solid var(--c-border);
  padding:10px 20px;border-radius:var(--r);
  cursor:pointer;transition:all var(--t);
}
.unit-btn:hover{color:var(--c-primary);border-color:var(--c-primary);background:var(--c-primary-light)}
.unit-btn.active{color:var(--c-primary);border-color:var(--c-primary);background:var(--c-primary-light);font-weight:700}

/* Quote result panel */
.quote-result{
  background:var(--c-white);
  border:1.5px solid var(--c-border);
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--sh-md);
  transition:all var(--t);
}
.qr-header{
  background:var(--c-navy);
  padding:18px 22px;
  display:flex;align-items:center;justify-content:space-between;
}
.qr-title{font-family:var(--font-display);font-size:14px;font-weight:700;color:#fff}
.qr-range{font-size:13px;color:rgba(255,255,255,0.60)}
.qr-body{padding:20px 22px}
.qr-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 0;
  border-bottom:1px solid var(--c-border);
  font-size:14px;
}
.qr-row:last-child{border-bottom:none}
.qr-row-label{color:var(--c-slate);font-weight:500}
.qr-row-val{font-weight:700;color:var(--c-navy-mid)}
.qr-row-val.blue{color:var(--c-primary)}
.qr-cta{padding:0 22px 20px}
.btn-quote{
  display:flex;align-items:center;justify-content:center;gap:8px;
  width:100%;
  font-family:var(--font-body);font-size:14.5px;font-weight:700;
  color:#fff;background:var(--c-primary);
  padding:13px 20px;border-radius:var(--r);
  transition:all var(--t);
}
.btn-quote:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}
.quote-note{font-size:12.5px;color:var(--c-muted);text-align:center;margin-top:12px;line-height:1.5}

/* Process steps */
.quote-process{margin-top:32px}
.quote-process-title{font-size:15px;font-weight:700;color:var(--c-navy-mid);margin-bottom:18px}
.process-steps{display:flex;flex-direction:column;gap:14px}
.process-step{display:flex;align-items:flex-start;gap:14px}
.ps-num{
  width:32px;height:32px;
  border-radius:8px;
  background:var(--c-primary);
  color:#fff;
  font-family:var(--font-display);
  font-size:14px;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.ps-title{font-size:14px;font-weight:700;color:var(--c-navy-mid);margin-bottom:2px}
.ps-desc{font-size:13px;color:var(--c-muted);line-height:1.5}

/* ── FEATURE MATRIX ───────────────────────────── */
.matrix-section{padding:80px 0;background:var(--c-bg)}
.matrix-header{margin-bottom:44px}
.feat-matrix-wrap{border-radius:var(--r-xl);overflow:hidden;border:1.5px solid var(--c-border);box-shadow:var(--sh-md)}
.feat-matrix{width:100%;border-collapse:collapse;background:var(--c-white)}
.feat-matrix thead th{
  padding:16px 20px;
  font-family:var(--font-display);font-size:13px;font-weight:700;
  color:rgba(255,255,255,0.80);letter-spacing:.02em;
  background:var(--c-navy-mid);
}
.feat-matrix thead th:first-child{text-align:left;width:260px}
.feat-matrix thead th:nth-child(2){color:#6EE7B7}
.feat-matrix thead th:nth-child(3){color:#93C5FD}
.feat-matrix tbody tr{border-bottom:1px solid var(--c-border)}
.feat-matrix tbody tr:last-child{border-bottom:none}
.feat-matrix tbody tr:hover{background:rgba(37,99,235,0.025)}
.feat-matrix td{padding:13px 20px;text-align:center;font-size:14px;vertical-align:middle}
.feat-matrix td:first-child{
  text-align:left;
  display:flex;align-items:center;gap:10px;
  font-size:14px;font-weight:500;color:var(--c-navy-mid);
}
.feat-matrix td.group-row{
  background:var(--c-bg);
  font-size:11px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--c-subtle);
  padding:10px 20px;
  text-align:left;
}
.feat-matrix td.group-row svg{display:none}
.feat-icon-sm{width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fm-yes{color:var(--c-green);font-size:16px;font-weight:800}
.fm-no{color:var(--c-border);font-size:18px}
.fm-partial{font-size:12px;font-weight:600;color:var(--c-amber)}
.fm-enhanced{font-size:12px;font-weight:600;color:var(--c-green)}

/* ── IMPLEMENTATION ───────────────────────────── */
.impl-section{padding:80px 0}
.impl-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:24px}
.impl-card{
  background:var(--c-white);
  border:1.5px solid var(--c-border);
  border-radius:var(--r-lg);
  padding:28px 24px;
  position:relative;
  overflow:hidden;
  transition:border-color var(--t),box-shadow var(--t),transform var(--t);
}
.impl-card:hover{border-color:rgba(37,99,235,0.30);box-shadow:var(--sh-md);transform:translateY(-2px)}
.impl-num{
  font-family:var(--font-display);
  font-size:72px;font-weight:900;
  line-height:1;letter-spacing:-0.04em;
  color:var(--c-primary-light);
  position:absolute;top:-8px;right:12px;
  pointer-events:none;
}
.impl-icon{
  width:46px;height:46px;
  background:var(--c-primary-light);
  border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:16px;
  transition:background var(--t);
}
.impl-card:hover .impl-icon{background:var(--c-primary)}
.impl-card:hover .impl-icon svg{color:#fff}
.impl-icon svg{transition:color var(--t)}
.impl-card h4{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--c-navy-mid);margin-bottom:8px}
.impl-card p{font-size:13.5px;color:var(--c-muted);line-height:1.55}

/* ── FAQ ──────────────────────────────────────── */
.faq-grid{display:grid;grid-template-columns:300px 1fr;gap:64px;align-items:start}
.faq-sidebar h3{font-family:var(--font-display);font-size:24px;font-weight:800;color:var(--c-navy);margin-bottom:12px;letter-spacing:-0.02em}
.faq-sidebar p{font-size:15px;color:var(--c-muted);line-height:1.6;margin-bottom:22px}
.faq-contact{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--c-primary);transition:gap var(--t)}
.faq-contact:hover{gap:12px}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--c-border)}
.faq-item:first-child{border-top:1px solid var(--c-border)}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0;text-align:left;font-size:15px;font-weight:600;color:var(--c-navy-mid);background:none;cursor:pointer;transition:color var(--t)}
.faq-question:hover{color:var(--c-primary)}
.faq-question svg{flex-shrink:0;transition:transform var(--t);color:var(--c-subtle)}
.faq-item.open .faq-question{color:var(--c-primary)}
.faq-item.open .faq-question svg{transform:rotate(180deg);color:var(--c-primary)}
.faq-answer{overflow:hidden;max-height:0;transition:max-height 0.35s cubic-bezier(0.4,0,0.2,1)}
.faq-answer-inner{padding:0 0 22px;font-size:15px;color:var(--c-muted);line-height:1.70}

/* SECTION BASE */
.section{padding:80px 0}
.section-alt{background:var(--c-bg)}
.section-navy{background:var(--c-navy)}
.section-eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--c-primary);margin-bottom:14px}
.section-eyebrow-bar{width:24px;height:2px;background:var(--c-primary);border-radius:2px}
.section-h2{font-family:var(--font-display);font-size:clamp(24px,3vw,36px);font-weight:800;line-height:1.15;letter-spacing:-0.025em;color:var(--c-navy);margin-bottom:14px}
.section-h2.light{color:#fff}
.section-sub{font-size:17px;line-height:1.65;color:var(--c-muted);max-width:560px}

/* FINAL CTA */
.final-cta{background:linear-gradient(135deg,#1D4ED8 0%,var(--c-primary) 50%,#0284C7 100%);text-align:center;padding:96px 0;position:relative;overflow:hidden}
.final-cta::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.07) 1px,transparent 1px);background-size:28px 28px}
.final-cta h2{font-family:var(--font-display);font-size:clamp(28px,4vw,44px);font-weight:800;color:#fff;letter-spacing:-0.025em;line-height:1.1;margin-bottom:14px;position:relative}
.final-cta p{font-size:17px;color:rgba(255,255,255,0.75);max-width:480px;margin:0 auto 36px;line-height:1.6;position:relative}
.final-ctas{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;position:relative}
.btn-cta-white{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:800;color:var(--c-primary);background:#fff;padding:16px 32px;border-radius:var(--r);transition:all var(--t);box-shadow:0 4px 20px rgba(0,0,0,0.15)}
.btn-cta-white:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,0.20)}
.btn-cta-wa{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:700;color:#fff;background:rgba(255,255,255,0.15);border:1.5px solid rgba(255,255,255,0.35);padding:15px 28px;border-radius:var(--r);transition:all var(--t)}
.btn-cta-wa:hover{background:rgba(255,255,255,0.22);border-color:rgba(255,255,255,0.55)}

/* FOOTER */
.footer{background:var(--c-navy);padding:64px 0 32px}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,0.10);margin-bottom:32px}
.footer-logo img{height:32px;margin-bottom:16px;filter:brightness(0) invert(1)}
.footer-tagline{font-size:14px;color:rgba(255,255,255,0.50);line-height:1.6;max-width:240px;margin-bottom:20px}
.footer-social{display:flex;gap:10px}
.footer-social-link{width:36px;height:36px;background:rgba(255,255,255,0.08);border-radius:8px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.60);transition:all var(--t);font-size:13px;font-weight:700}
.footer-social-link:hover{background:var(--c-primary);color:#fff}
.footer-col h5{font-family:var(--font-display);font-size:13px;font-weight:700;color:rgba(255,255,255,0.85);letter-spacing:.04em;text-transform:uppercase;margin-bottom:16px}
.footer-col ul{display:flex;flex-direction:column;gap:10px}
.footer-col ul li a{font-size:14px;color:rgba(255,255,255,0.50);transition:color var(--t)}
.footer-col ul li a:hover{color:rgba(255,255,255,0.90)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.footer-bottom p{font-size:13px;color:rgba(255,255,255,0.35)}
.footer-contact a{display:flex;align-items:center;gap:7px;font-size:13px;color:rgba(255,255,255,0.50);transition:color var(--t)}
.footer-contact a:hover{color:rgba(255,255,255,0.90)}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,0.70);backdrop-filter:blur(6px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity 0.25s ease}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{background:var(--c-white);border-radius:var(--r-xl);width:100%;max-width:560px;overflow:hidden;box-shadow:var(--sh-lg);transform:translateY(20px) scale(0.97);transition:transform 0.25s ease}
.modal-overlay.open .modal-box{transform:translateY(0) scale(1)}
.modal-header{background:linear-gradient(135deg,var(--c-navy) 0%,var(--c-navy-mid) 100%);padding:28px 32px 24px;position:relative}
.modal-header h2{font-family:var(--font-display);font-size:22px;font-weight:800;color:#fff;margin-bottom:6px;letter-spacing:-0.02em}
.modal-header p{font-size:14px;color:rgba(255,255,255,0.60)}
.modal-close{position:absolute;top:16px;right:20px;color:rgba(255,255,255,0.50);font-size:22px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.modal-close:hover{color:#fff}
.modal-body{padding:28px 32px 32px}
.modal-option-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:22px}
.modal-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 14px;border-radius:var(--r-lg);border:2px solid var(--c-border);cursor:pointer;text-align:center;transition:all var(--t);text-decoration:none;color:inherit}
.modal-option:hover{border-color:var(--c-primary);background:var(--c-primary-light)}
.modal-option.option-wa:hover{border-color:#25D366;background:#F0FDF4}
.modal-option-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px}
.modal-option .opt-title{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.modal-option .opt-sub{font-size:12px;color:var(--c-muted)}
.modal-divider{display:flex;align-items:center;gap:12px;color:var(--c-subtle);font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:20px}
.modal-divider::before,.modal-divider::after{content:'';flex:1;height:1px;background:var(--c-border)}
.modal-form{display:flex;flex-direction:column;gap:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-field{display:flex;flex-direction:column;gap:5px}
.form-field label{font-size:12.5px;font-weight:700;color:var(--c-slate);letter-spacing:.02em}
.form-field input,.form-field select{font-family:var(--font-body);font-size:14px;color:var(--c-body);background:var(--c-bg);border:1.5px solid var(--c-border);border-radius:var(--r);padding:11px 14px;outline:none;transition:border-color var(--t),box-shadow var(--t);width:100%}
.form-field input::placeholder{color:var(--c-subtle)}
.form-field input:focus,.form-field select:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(37,99,235,0.12)}
.btn-form-submit{font-family:var(--font-body);font-size:15px;font-weight:800;color:#fff;background:var(--c-primary);padding:14px 24px;border-radius:var(--r);border:none;cursor:pointer;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--t);margin-top:4px}
.btn-form-submit:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}
.modal-thanks{display:none;text-align:center;padding:32px}
.modal-thanks-icon{width:64px;height:64px;background:var(--c-green-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-size:32px}
.modal-thanks h3{font-family:var(--font-display);font-size:22px;font-weight:800;color:var(--c-navy);margin-bottom:8px}
.modal-thanks p{font-size:15px;color:var(--c-muted);line-height:1.6}

/* FADE */
.fade-up{opacity:0;transform:translateY(24px);transition:opacity 0.55s ease,transform 0.55s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up.d1{transition-delay:.08s}.fade-up.d2{transition-delay:.16s}.fade-up.d3{transition-delay:.24s}

/* RESPONSIVE */
@media(max-width:960px){
  .plan-grid{grid-template-columns:1fr;max-width:500px}
  .plan-connector{display:none}
  .quote-grid{grid-template-columns:1fr;gap:40px}
  .impl-grid{grid-template-columns:1fr 1fr}
  .faq-grid{grid-template-columns:1fr;gap:40px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
  .feat-matrix td:first-child{font-size:13px}
  .feat-matrix td{padding:11px 14px;font-size:13px}
}
@media(max-width:640px){
  .nav-links,.nav-ctas{display:none}
  .nav-hamburger{display:flex}
  .impl-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .modal-option-row{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .feat-matrix thead th{font-size:11px;padding:10px}
  .feat-matrix td{padding:9px 10px;font-size:12px}
  .feat-matrix td:first-child{font-size:12px}
  .unit-btns{gap:8px}
  .unit-btn{font-size:13px;padding:8px 14px}
}

/* ----- contabilidad.html ----- */
/* ── HERO ─────────────────────────────────────── */
.acct-hero{
  background:var(--c-navy);
  background-image:
    radial-gradient(ellipse 60% 70% at 15% 50%, rgba(37,99,235,0.22) 0%, transparent 55%),
    radial-gradient(ellipse 40% 50% at 85% 15%, rgba(99,102,241,0.10) 0%, transparent 50%);
  padding:72px 0 80px;
  overflow:hidden;position:relative;
}
.acct-hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.04) 1px,transparent 1px);background-size:32px 32px;pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1fr 480px;gap:60px;align-items:center;position:relative}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(37,99,235,0.18);border:1px solid rgba(37,99,235,0.35);color:#93C5FD;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 14px;border-radius:100px;margin-bottom:22px}
.hero-tag-dot{width:6px;height:6px;border-radius:50%;background:#60A5FA;animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.75)}}
.acct-hero h1{font-family:var(--font-display);font-size:clamp(30px,4vw,50px);font-weight:800;line-height:1.1;letter-spacing:-0.03em;color:#fff;margin-bottom:20px}
.acct-hero h1 em{font-style:normal;color:#60A5FA}
.acct-hero .sub{font-size:17.5px;line-height:1.65;color:rgba(255,255,255,0.65);max-width:500px;margin-bottom:36px}
.acct-hero .sub strong{color:rgba(255,255,255,0.90);font-weight:600}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:36px}
.btn-primary{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:700;color:#fff;background:var(--c-primary);padding:14px 28px;border-radius:var(--r);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-primary:hover{background:var(--c-primary-dark);transform:translateY(-2px);box-shadow:var(--sh-blue)}
.btn-outline{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:600;color:rgba(255,255,255,0.80);background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.18);padding:14px 24px;border-radius:var(--r);transition:all var(--t)}
.btn-outline:hover{background:rgba(255,255,255,0.14);color:#fff;border-color:rgba(255,255,255,0.35)}
.hero-signals{display:flex;flex-direction:column;gap:9px}
.hero-signal{display:flex;align-items:center;gap:9px;font-size:13.5px;color:rgba(255,255,255,0.55)}
.hero-signal svg{flex-shrink:0;color:#4ADE80}

/* ── PANEL MOCKUP ────────────────────────────── */
.panel-frame{
  background:var(--c-white);border-radius:var(--r-xl);overflow:hidden;
  box-shadow:0 24px 64px rgba(0,0,0,.40),0 4px 16px rgba(37,99,235,.15);
  border:1px solid rgba(255,255,255,.10);
}
.panel-topbar{
  background:var(--c-navy-mid);padding:12px 16px;
  display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.panel-tb-id{display:flex;align-items:center;gap:9px}
.panel-tb-icon{width:26px;height:26px;background:rgba(37,99,235,.30);border:1px solid rgba(37,99,235,.45);border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:13px}
.panel-tb-name{font-family:var(--font-display);font-size:12px;font-weight:700;color:#fff}
.panel-tb-sub{font-size:10px;color:rgba(255,255,255,.40);margin-top:1px}
.panel-tabs{display:flex;gap:0;border-bottom:1px solid var(--c-border)}
.panel-tab{font-size:12px;font-weight:600;padding:9px 14px;color:var(--c-muted);cursor:pointer;border-bottom:2px solid transparent;transition:all .18s}
.panel-tab.active{color:var(--c-primary);border-bottom-color:var(--c-primary)}

/* KPI row */
.panel-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-bottom:1px solid var(--c-border)}
.panel-kpi{padding:12px 14px;border-right:1px solid var(--c-border)}
.panel-kpi:last-child{border-right:none}
.panel-kpi-label{font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--c-subtle);margin-bottom:3px}
.panel-kpi-val{font-family:var(--font-display);font-size:20px;font-weight:800;color:var(--c-navy-mid);line-height:1}
.panel-kpi-sub{font-size:10px;color:var(--c-muted);margin-top:2px}
.panel-kpi-val.green{color:var(--c-green)}
.panel-kpi-val.red{color:var(--c-red)}
.panel-kpi-val.amber{color:var(--c-amber)}

/* Account rows */
.panel-table{padding:10px 0}
.panel-table-head{display:grid;grid-template-columns:1fr 80px 80px 90px;gap:8px;padding:5px 14px;margin-bottom:2px}
.panel-table-head span{font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--c-subtle)}
.panel-row{display:grid;grid-template-columns:1fr 80px 80px 90px;gap:8px;padding:9px 14px;align-items:center;border-bottom:1px solid var(--c-border)}
.panel-row:last-child{border-bottom:none}
.panel-row:hover{background:var(--c-bg)}
.panel-row-id{font-size:11px;font-weight:700;color:var(--c-primary);font-family:var(--font-display)}
.panel-row-name{font-size:12px;font-weight:500;color:var(--c-navy-mid)}
.panel-row-owner{font-size:11px;color:var(--c-muted)}
.panel-row-amount{font-family:var(--font-display);font-size:13px;font-weight:700;text-align:right}
.amount-debt{color:var(--c-red)}
.amount-ok{color:var(--c-green)}
.panel-row-status{text-align:right}
.status-pill{display:inline-block;font-size:10px;font-weight:700;padding:2px 8px;border-radius:4px}
.sp-al-dia{background:var(--c-green-light);color:var(--c-green)}
.sp-vencida{background:var(--c-red-light);color:var(--c-red)}
.sp-parcial{background:var(--c-amber-light);color:var(--c-amber)}

/* Presupuesto bar */
.panel-budget{padding:10px 14px;border-top:1px solid var(--c-border)}
.panel-budget-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--c-subtle);margin-bottom:8px}
.budget-row{display:flex;align-items:center;gap:10px;margin-bottom:7px}
.budget-name{font-size:11.5px;color:var(--c-slate);min-width:110px}
.budget-track{flex:1;height:6px;background:var(--c-border);border-radius:100px;overflow:hidden}
.budget-fill{height:100%;border-radius:100px;background:var(--c-primary)}
.budget-fill.over{background:var(--c-red)}
.budget-fill.warn{background:var(--c-amber)}
.budget-pct{font-size:11px;font-weight:700;color:var(--c-slate);min-width:32px;text-align:right}

/* ── PROOF STRIP ──────────────────────────────── */
.proof-strip{background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:18px 0}
.proof-inner{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}
.proof-item{display:flex;align-items:center;gap:10px;padding:10px 28px;border-right:1px solid var(--c-border)}
.proof-item:last-child{border-right:none}
.proof-icon{width:34px;height:34px;background:var(--c-primary-light);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:17px}
.proof-text-main{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.proof-text-sub{font-size:11.5px;color:var(--c-muted)}

/* ── SECTIONS ─────────────────────────────────── */
.section{padding:88px 0}
.section-alt{background:var(--c-bg)}
.section-dark{background:var(--c-navy)}
.section-eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--c-primary);margin-bottom:14px}
.section-eyebrow-bar{width:24px;height:2px;background:var(--c-primary);border-radius:2px}
.section-eyebrow.light{color:#93C5FD}
.section-eyebrow-bar.light{background:#93C5FD}
.section-h2{font-family:var(--font-display);font-size:clamp(26px,3vw,38px);font-weight:800;line-height:1.15;letter-spacing:-0.025em;color:var(--c-navy);margin-bottom:14px}
.section-h2.light{color:#fff}
.section-sub{font-size:17px;line-height:1.65;color:var(--c-muted);max-width:560px}

/* ── PAIN CARDS ───────────────────────────────── */
.pain-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:48px}
.pain-card{background:var(--c-white);border:1.5px solid var(--c-border);border-radius:var(--r-lg);padding:24px 20px;border-top:4px solid var(--c-red)}
.pain-icon{font-size:28px;margin-bottom:12px}
.pain-h4{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--c-navy-mid);margin-bottom:7px}
.pain-p{font-size:13.5px;color:var(--c-muted);line-height:1.55}
.pain-consequence{margin-top:10px;padding-top:10px;border-top:1px solid var(--c-border);font-size:12.5px;font-weight:600;color:var(--c-red);display:flex;align-items:flex-start;gap:5px}

/* ── FEATURES DETAIL ──────────────────────────── */
.features-section{padding:88px 0}
.features-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:48px}
.feat-block{background:var(--c-white);border:1.5px solid var(--c-border);border-radius:var(--r-lg);padding:28px 24px;transition:border-color var(--t),box-shadow var(--t),transform var(--t)}
.feat-block:hover{border-color:rgba(37,99,235,.30);box-shadow:var(--sh-md);transform:translateY(-2px)}
.feat-block.full-w{grid-column:1/-1}
.feat-header{display:flex;align-items:flex-start;gap:14px;margin-bottom:14px}
.feat-icon{width:44px;height:44px;background:var(--c-primary-light);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:22px}
.feat-block h4{font-family:var(--font-display);font-size:17px;font-weight:700;color:var(--c-navy-mid);margin-bottom:5px}
.feat-block .feat-for{font-size:12px;font-weight:600;color:var(--c-primary);background:var(--c-primary-light);padding:2px 8px;border-radius:4px;display:inline-block;margin-bottom:0}
.feat-block p{font-size:14px;color:var(--c-muted);line-height:1.60}
.feat-sub-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:14px}
.feat-sub{background:var(--c-bg);border-radius:var(--r);padding:12px 14px;display:flex;align-items:flex-start;gap:8px}
.feat-sub-icon{font-size:16px;flex-shrink:0;margin-top:1px}
.feat-sub-text{font-size:13px;color:var(--c-muted);line-height:1.50}
.feat-sub-text strong{color:var(--c-navy-mid);font-weight:600}

/* ── NORMATIVA ────────────────────────────────── */
.norm-section{padding:88px 0;background:var(--c-navy)}
.norm-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:start;margin-top:52px}
.norm-text p{font-size:17px;line-height:1.70;color:rgba(255,255,255,.68);margin-bottom:20px}
.norm-text strong{color:#fff;font-weight:600}
.norm-badges{display:flex;flex-direction:column;gap:12px}
.norm-badge{display:flex;align-items:center;gap:14px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-lg);padding:16px 18px}
.norm-badge-icon{width:40px;height:40px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.norm-badge-title{font-family:var(--font-display);font-size:15px;font-weight:700;color:#fff;margin-bottom:3px}
.norm-badge-desc{font-size:13px;color:rgba(255,255,255,.55);line-height:1.45}
.norm-badge-tag{margin-left:auto;font-size:10px;font-weight:700;padding:2px 8px;border-radius:4px;white-space:nowrap;flex-shrink:0}
.tag-cumple{background:rgba(5,150,105,.20);border:1px solid rgba(5,150,105,.30);color:#4ADE80}

/* ── INTEGRATION FLOW ─────────────────────────── */
.integ-flow{margin-top:52px}
.flow-row{
  display:flex;align-items:center;gap:16px;
  background:var(--c-white);border:1.5px solid var(--c-border);
  border-radius:var(--r-lg);padding:18px 22px;margin-bottom:14px;
  transition:background var(--t),border-color var(--t),box-shadow var(--t);
}
.flow-row:hover{background:var(--c-bg);border-color:rgba(37,99,235,.25);box-shadow:var(--sh-sm)}
.flow-trigger{display:flex;align-items:center;gap:10px;flex:1}
.flow-icon{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:18px}
.flow-name{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.flow-desc{font-size:12px;color:var(--c-muted);margin-top:2px}
.flow-arrow{color:var(--c-subtle);font-size:20px;flex-shrink:0;padding:0 4px}
.flow-result{background:var(--c-primary-light);border:1px solid rgba(37,99,235,.25);border-radius:var(--r-sm);padding:8px 14px;flex-shrink:0;text-align:center}
.flow-result-main{font-size:13px;font-weight:700;color:var(--c-primary-dark)}
.flow-result-sub{font-size:10.5px;color:var(--c-muted);margin-top:2px}

/* ── FAQ ──────────────────────────────────────── */
.faq-grid{display:grid;grid-template-columns:300px 1fr;gap:64px;align-items:start}
.faq-sidebar h3{font-family:var(--font-display);font-size:24px;font-weight:800;color:var(--c-navy);margin-bottom:12px;letter-spacing:-0.02em}
.faq-sidebar p{font-size:15px;color:var(--c-muted);line-height:1.6;margin-bottom:22px}
.faq-contact{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--c-primary);transition:gap var(--t)}
.faq-contact:hover{gap:12px}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--c-border)}
.faq-item:first-child{border-top:1px solid var(--c-border)}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0;text-align:left;font-size:15px;font-weight:600;color:var(--c-navy-mid);background:none;cursor:pointer;transition:color var(--t)}
.faq-question:hover,.faq-item.open .faq-question{color:var(--c-primary)}
.faq-question svg{flex-shrink:0;transition:transform var(--t);color:var(--c-subtle)}
.faq-item.open .faq-question svg{transform:rotate(180deg);color:var(--c-primary)}
.faq-answer{overflow:hidden;max-height:0;transition:max-height 0.35s cubic-bezier(0.4,0,0.2,1)}
.faq-answer-inner{padding:0 0 22px;font-size:15px;color:var(--c-muted);line-height:1.70}

/* ── COUNTER CTA CALLOUT ──────────────────────── */
.counter-callout{
  background:var(--c-primary-light);
  border:1.5px solid rgba(37,99,235,.25);
  border-radius:var(--r-xl);
  padding:36px 44px;
  display:flex;align-items:center;gap:32px;
  margin-top:52px;
}
.counter-callout-text h3{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--c-navy);margin-bottom:8px}
.counter-callout-text p{font-size:15px;color:var(--c-muted);line-height:1.60;max-width:500px}
.counter-callout-cta{flex-shrink:0}
.btn-counter{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--c-primary);background:var(--c-white);border:1.5px solid rgba(37,99,235,.30);padding:12px 20px;border-radius:var(--r);transition:all var(--t);white-space:nowrap}
.btn-counter:hover{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}

/* ── FINAL CTA ────────────────────────────────── */
.final-cta{background:linear-gradient(135deg,#0F172A 0%,#1E3A8A 50%,#1D4ED8 100%);text-align:center;padding:96px 0;position:relative;overflow:hidden}
.final-cta::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.06) 1px,transparent 1px);background-size:28px 28px}
.final-cta h2{font-family:var(--font-display);font-size:clamp(26px,4vw,42px);font-weight:800;color:#fff;letter-spacing:-0.025em;line-height:1.1;margin-bottom:14px;position:relative}
.final-cta h2 span{color:#BAE6FD}
.final-cta p{font-size:17px;color:rgba(255,255,255,.72);max-width:480px;margin:0 auto 36px;line-height:1.65;position:relative}
.final-ctas{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;position:relative}
.btn-cta-main{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:800;color:#fff;background:var(--c-primary);padding:16px 32px;border-radius:var(--r);box-shadow:0 8px 32px rgba(37,99,235,.35);transition:all var(--t)}
.btn-cta-main:hover{background:var(--c-primary-dark);transform:translateY(-2px)}
.btn-cta-wa{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:700;color:#fff;background:rgba(255,255,255,.12);border:1.5px solid rgba(255,255,255,.25);padding:15px 28px;border-radius:var(--r);transition:all var(--t)}
.btn-cta-wa:hover{background:rgba(255,255,255,.20);border-color:rgba(255,255,255,.45)}
.final-note{font-size:13px;color:rgba(255,255,255,.40);margin-top:28px;position:relative}
.final-note strong{color:rgba(255,255,255,.72);font-weight:500}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.70);backdrop-filter:blur(6px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .25s ease}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{background:var(--c-white);border-radius:var(--r-xl);width:100%;max-width:560px;overflow:hidden;box-shadow:var(--sh-lg);transform:translateY(20px) scale(.97);transition:transform .25s ease}
.modal-overlay.open .modal-box{transform:translateY(0) scale(1)}
.modal-header{background:linear-gradient(135deg,var(--c-navy) 0%,var(--c-navy-mid) 100%);padding:28px 32px 24px;position:relative}
.modal-header h2{font-family:var(--font-display);font-size:22px;font-weight:800;color:#fff;margin-bottom:6px;letter-spacing:-.02em}
.modal-header p{font-size:14px;color:rgba(255,255,255,.60)}
.modal-close{position:absolute;top:16px;right:20px;color:rgba(255,255,255,.50);font-size:22px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.modal-close:hover{color:#fff}
.modal-body{padding:28px 32px 32px}
.modal-option-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:22px}
.modal-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 14px;border-radius:var(--r-lg);border:2px solid var(--c-border);cursor:pointer;text-align:center;transition:all var(--t);text-decoration:none;color:inherit}
.modal-option:hover{border-color:var(--c-primary);background:var(--c-primary-light)}
.modal-option.option-wa:hover{border-color:#25D366;background:#F0FDF4}
.modal-option-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px}
.opt-title{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.opt-sub{font-size:12px;color:var(--c-muted)}
.modal-divider{display:flex;align-items:center;gap:12px;color:var(--c-subtle);font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:20px}
.modal-divider::before,.modal-divider::after{content:'';flex:1;height:1px;background:var(--c-border)}
.modal-form{display:flex;flex-direction:column;gap:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-field{display:flex;flex-direction:column;gap:5px}
.form-field label{font-size:12.5px;font-weight:700;color:var(--c-slate);letter-spacing:.02em}
.form-field input,.form-field select{font-family:var(--font-body);font-size:14px;color:var(--c-body);background:var(--c-bg);border:1.5px solid var(--c-border);border-radius:var(--r);padding:11px 14px;outline:none;transition:border-color var(--t),box-shadow var(--t);width:100%}
.form-field input:focus,.form-field select:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(37,99,235,.12)}
.btn-form-submit{font-family:var(--font-body);font-size:15px;font-weight:800;color:#fff;background:var(--c-primary);padding:14px 24px;border-radius:var(--r);border:none;cursor:pointer;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--t);margin-top:4px}
.btn-form-submit:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}
.modal-thanks{display:none;text-align:center;padding:32px}
.modal-thanks-icon{width:64px;height:64px;background:var(--c-primary-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-size:32px}

.fade-up{opacity:0;transform:translateY(24px);transition:opacity .55s ease,transform .55s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up.d1{transition-delay:.08s}.fade-up.d2{transition-delay:.16s}.fade-up.d3{transition-delay:.24s}

@media(max-width:1060px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .pain-grid{grid-template-columns:1fr}
  .features-grid{grid-template-columns:1fr}
  .norm-grid{grid-template-columns:1fr}
  .faq-grid{grid-template-columns:1fr;gap:36px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
  .counter-callout{flex-direction:column;gap:20px;padding:28px 24px}
}
@media(max-width:640px){
  .nav-links,.nav-ctas{display:none}
  .nav-hamburger{display:flex}
  .footer-grid{grid-template-columns:1fr}
  .modal-option-row,.form-row{grid-template-columns:1fr}
  .proof-inner{flex-direction:column}
  .proof-item{border-right:none;border-bottom:1px solid var(--c-border);width:100%;justify-content:center}
  .proof-item:last-child{border-bottom:none}
  .feat-sub-grid{grid-template-columns:1fr}
  .panel-table-head,.panel-row{grid-template-columns:1fr 80px 90px}
  .panel-table-head span:nth-child(3),.panel-row > *:nth-child(3){display:none}
}

body.page-contabilidad .ann-bar{background:var(--c-primary);color:#fff}
body.page-contabilidad .ann-bar a{color:#BAE6FD}
body.page-contabilidad .ann-bar a:hover{color:#E0F2FE}
body.page-contabilidad .ann-badge{background:rgba(255,255,255,0.20);color:#fff}
body.page-contabilidad .ann-close{color:rgba(255,255,255,0.60)}
body.page-contabilidad .ann-close:hover{color:#fff}

/* ----- modulos.html ----- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);font-size:16px;line-height:1.6;color:var(--c-body);background:var(--c-white);-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font-family:inherit}
ul{list-style:none}
.container{max-width:var(--w-max);margin:0 auto;padding:0 24px}

/* ANN BAR */
.ann-bar{background:var(--c-navy-mid);color:#fff;padding:10px 24px;font-size:13.5px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:12px;position:relative}
.ann-bar a{color:#93C5FD;text-decoration:underline;text-underline-offset:2px}
.ann-bar a:hover{color:#BFDBFE}
.ann-badge{background:var(--c-primary);color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:2px 8px;border-radius:4px;white-space:nowrap}
.ann-close{position:absolute;right:20px;top:50%;transform:translateY(-50%);color:var(--c-subtle);font-size:18px;cursor:pointer;transition:color var(--t);background:none;border:none}
.ann-close:hover{color:#fff}

/* NAV */
.nav{position:sticky;top:0;z-index:900;background:rgba(255,255,255,0.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--c-border);box-shadow:0 1px 3px rgba(15,23,42,0.06)}
.nav-inner{max-width:var(--w-max);margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;gap:32px}
.nav-logo img{height:34px;width:auto}
.nav-links{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--c-slate);padding:8px 14px;border-radius:var(--r-sm);transition:color var(--t),background var(--t)}
.nav-links a:hover{color:var(--c-primary);background:var(--c-primary-light)}
.nav-links a.active{color:var(--c-primary);font-weight:700}
.nav-ctas{display:flex;align-items:center;gap:10px;margin-left:12px}
.btn-nav-login{font-size:14px;font-weight:600;color:var(--c-slate);padding:8px 16px;border-radius:var(--r-sm);border:1px solid var(--c-border);transition:all var(--t)}
.btn-nav-login:hover{color:var(--c-primary);border-color:var(--c-primary);background:var(--c-primary-light)}
.btn-nav-demo{font-size:14px;font-weight:700;color:#fff;background:var(--c-primary);padding:9px 20px;border-radius:var(--r-sm);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-nav-demo:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;margin-left:auto}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--c-navy-mid);border-radius:2px;transition:all var(--t)}
.mobile-menu{display:none;flex-direction:column;background:var(--c-white);padding:16px 24px 24px;border-top:1px solid var(--c-border)}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:15px;font-weight:500;color:var(--c-slate);padding:12px 0;border-bottom:1px solid var(--c-border)}
.mobile-menu a.active{color:var(--c-primary);font-weight:700}
.mobile-menu a:last-child{border-bottom:none}

/* BREADCRUMB */
.breadcrumb-bar{background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:10px 0}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--c-muted)}
.breadcrumb a{color:var(--c-muted);transition:color var(--t)}
.breadcrumb a:hover{color:var(--c-primary)}
.breadcrumb-sep{color:var(--c-subtle);font-size:11px}
.breadcrumb-current{color:var(--c-slate);font-weight:600}

/* HERO — dark navy, grid pattern */
.mod-hero{
  background-color:var(--c-navy);
  background-image:
    linear-gradient(rgba(37,99,235,0.10) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,235,0.10) 1px, transparent 1px);
  background-size:60px 60px;
  padding:72px 0 0;
  overflow:hidden;
  position:relative;
}
.mod-hero::before{
  content:'';position:absolute;
  top:-160px;left:-120px;
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(37,99,235,0.22) 0%,transparent 65%);
  border-radius:50%;pointer-events:none;
}
.mod-hero-inner{position:relative;text-align:center;padding-bottom:56px}
.mod-hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(37,99,235,0.20);border:1px solid rgba(37,99,235,0.40);color:#93C5FD;font-size:12px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:6px 16px;border-radius:100px;margin-bottom:24px}
.mod-hero h1{font-family:var(--font-display);font-size:clamp(36px,5vw,60px);font-weight:800;line-height:1.08;letter-spacing:-0.035em;color:#fff;margin-bottom:20px}
.mod-hero h1 em{font-style:normal;color:#60A5FA}
.mod-hero .sub{font-size:18px;line-height:1.65;color:rgba(255,255,255,0.68);max-width:580px;margin:0 auto 36px}
.mod-hero .sub strong{color:rgba(255,255,255,0.90);font-weight:600}
.mod-hero .hero-ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:56px}
.btn-hero-primary{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:700;color:#fff;background:var(--c-primary);padding:14px 28px;border-radius:var(--r);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-hero-primary:hover{background:var(--c-primary-dark);transform:translateY(-2px);box-shadow:var(--sh-blue)}
.btn-hero-secondary{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:600;color:rgba(255,255,255,0.85);background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.20);padding:14px 24px;border-radius:var(--r);transition:all var(--t)}
.btn-hero-secondary:hover{background:rgba(255,255,255,0.14);color:#fff}

/* MODULE TILES STRIP (hero bottom) */
.module-tiles-strip{
  background:rgba(255,255,255,0.06);
  border-top:1px solid rgba(255,255,255,0.10);
  padding:20px 0;
}
.module-tiles-inner{display:flex;align-items:center;justify-content:center;gap:0;flex-wrap:wrap}
.mod-tile{
  display:flex;align-items:center;gap:10px;
  padding:12px 24px;
  border-right:1px solid rgba(255,255,255,0.10);
  cursor:pointer;transition:background var(--t);
  text-decoration:none;
}
.mod-tile:last-child{border-right:none}
.mod-tile:hover{background:rgba(255,255,255,0.08)}
.mod-tile-num{font-family:var(--font-display);font-size:11px;font-weight:700;color:rgba(255,255,255,0.35);letter-spacing:.04em;white-space:nowrap}
.mod-tile-name{font-size:13px;font-weight:600;color:rgba(255,255,255,0.75);white-space:nowrap}
.mod-tile-icon{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0}

/* STICKY QUICKNAV */
.quicknav{
  position:sticky;top:64px;z-index:800;
  background:rgba(255,255,255,0.97);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--c-border);
  padding:12px 0;
  box-shadow:0 2px 8px rgba(15,23,42,0.06);
}
.quicknav-inner{display:flex;align-items:center;gap:8px;overflow-x:auto;scrollbar-width:none;padding:0 24px;max-width:var(--w-max);margin:0 auto}
.quicknav-inner::-webkit-scrollbar{display:none}
.qn-btn{
  display:inline-flex;align-items:center;gap:7px;
  font-family:var(--font-body);font-size:13px;font-weight:600;
  color:var(--c-muted);
  background:var(--c-bg);
  border:1.5px solid var(--c-border);
  padding:7px 14px;border-radius:100px;
  white-space:nowrap;cursor:pointer;
  transition:all var(--t);
}
.qn-btn:hover,.qn-btn.active{border-color:var(--c-primary);color:var(--c-primary);background:var(--c-primary-light)}
.qn-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}

/* SECTION BASE */
.section{padding:88px 0}
.section-alt{background:var(--c-bg)}
.section-navy{background:var(--c-navy)}
.section-eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--c-primary);margin-bottom:14px}
.section-eyebrow-bar{width:24px;height:2px;background:var(--c-primary);border-radius:2px}
.section-h2{font-family:var(--font-display);font-size:clamp(26px,3vw,38px);font-weight:800;line-height:1.15;letter-spacing:-0.025em;color:var(--c-navy);margin-bottom:14px}
.section-h2.light{color:#fff}
.section-sub{font-size:17px;line-height:1.65;color:var(--c-muted);max-width:560px}
.section-sub.light{color:rgba(255,255,255,0.68)}

/* MODULE SECTIONS */
.mod-section{
  padding:80px 0;
  border-bottom:1px solid var(--c-border);
  position:relative;
  overflow:hidden;
}
.mod-section:last-of-type{border-bottom:none}
.mod-section.alt{background:var(--c-bg)}

.mod-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.mod-grid.reverse{direction:rtl}
.mod-grid.reverse>*{direction:ltr}

/* Big background number */
.mod-bg-num{
  position:absolute;
  font-family:var(--font-display);
  font-size:clamp(120px,14vw,200px);
  font-weight:900;
  line-height:1;
  letter-spacing:-0.05em;
  color:rgba(37,99,235,0.05);
  top:-20px;
  pointer-events:none;
  user-select:none;
}
.mod-section.alt .mod-bg-num{color:rgba(37,99,235,0.07)}

.mod-label{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:4px 12px;border-radius:100px;margin-bottom:16px;
}
.mod-num-tag{font-family:var(--font-display);font-size:11px;font-weight:800;color:rgba(0,0,0,0.35)}
.mod-h2{font-family:var(--font-display);font-size:clamp(24px,2.8vw,34px);font-weight:800;line-height:1.12;letter-spacing:-0.025em;color:var(--c-navy);margin-bottom:14px}
.mod-desc{font-size:16px;line-height:1.70;color:var(--c-muted);margin-bottom:28px}
.mod-desc strong{color:var(--c-body);font-weight:600}

/* Feature 2x2 grid */
.mod-features{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:28px}
.mod-feat{
  display:flex;align-items:flex-start;gap:10px;
  padding:14px;background:var(--c-white);
  border:1.5px solid var(--c-border);
  border-radius:var(--r);
  transition:border-color var(--t);
}
.mod-section.alt .mod-feat{background:var(--c-white)}
.mod-feat:hover{border-color:rgba(37,99,235,0.25)}
.mod-feat-icon{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.mod-feat-title{font-size:13px;font-weight:700;color:var(--c-navy-mid);line-height:1.3;margin-bottom:2px}
.mod-feat-desc{font-size:12px;color:var(--c-muted);line-height:1.4}

/* Integration chips */
.mod-integra-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:24px}
.mod-integra-label{font-size:12px;font-weight:700;color:var(--c-subtle);letter-spacing:.03em}
.mod-integra-chip{font-size:12px;font-weight:600;color:var(--c-primary);background:var(--c-primary-light);padding:3px 10px;border-radius:100px;border:1px solid rgba(37,99,235,0.20)}
.mod-cta-link{display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:700;color:var(--c-primary);transition:gap var(--t)}
.mod-cta-link:hover{gap:11px}

/* Visual panels for each module */
.mod-visual{position:relative}
.mod-panel{
  background:var(--c-white);
  border:1.5px solid var(--c-border);
  border-radius:var(--r-xl);
  overflow:hidden;
  box-shadow:var(--sh-lg);
}
.mp-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px;border-bottom:1px solid var(--c-border);
}
.mp-header-left{display:flex;align-items:center;gap:10px}
.mp-icon-box{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center}
.mp-title{font-family:var(--font-display);font-size:13px;font-weight:700;color:var(--c-navy-mid)}
.mp-sub{font-size:11px;color:var(--c-muted);margin-top:1px}
.mp-status-dot{width:8px;height:8px;border-radius:50%}
.mp-body{padding:16px}
/* Shared panel row */
.mp-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--c-bg);border:1px solid var(--c-border);border-radius:var(--r);margin-bottom:8px;transition:border-color var(--t)}
.mp-row:last-child{margin-bottom:0}
.mp-row:hover{border-color:rgba(37,99,235,0.25)}
.mp-row-icon{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:13px}
.mp-row-title{font-size:13px;font-weight:600;color:var(--c-navy-mid);flex:1}
.mp-row-meta{font-size:11px;color:var(--c-muted)}
.mp-badge{font-size:10.5px;font-weight:700;padding:2px 8px;border-radius:100px}
.mp-badge.green{background:var(--c-green-light);color:var(--c-green)}
.mp-badge.blue{background:var(--c-primary-light);color:var(--c-primary)}
.mp-badge.amber{background:var(--c-amber-light);color:var(--c-amber)}
.mp-badge.purple{background:var(--c-purple-light);color:var(--c-purple)}

/* INTEGRATION MATRIX */
.matrix-section{padding:80px 0;background:var(--c-navy)}
.matrix-header{text-align:center;margin-bottom:52px}
.matrix-wrap{overflow-x:auto;border-radius:var(--r-lg);box-shadow:var(--sh-lg)}
.int-matrix{width:100%;border-collapse:collapse;background:var(--c-white)}
.int-matrix thead th{
  padding:14px 12px;font-family:var(--font-display);font-size:12px;font-weight:700;
  color:rgba(255,255,255,0.70);letter-spacing:.03em;text-align:center;
  background:var(--c-navy-mid);white-space:nowrap;
}
.int-matrix thead th:first-child{text-align:left;width:200px;padding-left:18px}
.int-matrix tbody tr{border-bottom:1px solid var(--c-border)}
.int-matrix tbody tr:last-child{border-bottom:none}
.int-matrix tbody tr:hover{background:rgba(37,99,235,0.03)}
.int-matrix td{padding:12px;text-align:center;font-size:13px;vertical-align:middle}
.int-matrix td:first-child{
  text-align:left;padding-left:18px;
  display:flex;align-items:center;gap:10px;
  font-weight:600;color:var(--c-navy-mid);
}
.int-icon-sm{width:26px;height:26px;border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.int-yes{color:var(--c-green);font-size:16px;font-weight:800}
.int-no{color:var(--c-border)}
.int-self{background:var(--c-bg)}

/* FAQ */
.faq-grid{display:grid;grid-template-columns:300px 1fr;gap:64px;align-items:start}
.faq-sidebar h3{font-family:var(--font-display);font-size:24px;font-weight:800;color:var(--c-navy);margin-bottom:12px;letter-spacing:-0.02em}
.faq-sidebar p{font-size:15px;color:var(--c-muted);line-height:1.6;margin-bottom:22px}
.faq-contact{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--c-primary);transition:gap var(--t)}
.faq-contact:hover{gap:12px}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--c-border)}
.faq-item:first-child{border-top:1px solid var(--c-border)}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0;text-align:left;font-size:15px;font-weight:600;color:var(--c-navy-mid);background:none;cursor:pointer;transition:color var(--t)}
.faq-question:hover{color:var(--c-primary)}
.faq-question svg{flex-shrink:0;transition:transform var(--t);color:var(--c-subtle)}
.faq-item.open .faq-question{color:var(--c-primary)}
.faq-item.open .faq-question svg{transform:rotate(180deg);color:var(--c-primary)}
.faq-answer{overflow:hidden;max-height:0;transition:max-height 0.35s cubic-bezier(0.4,0,0.2,1)}
.faq-answer-inner{padding:0 0 22px;font-size:15px;color:var(--c-muted);line-height:1.70}

/* CTA FINAL */
.final-cta{background:linear-gradient(135deg,#1D4ED8 0%,var(--c-primary) 50%,#0284C7 100%);text-align:center;padding:96px 0;position:relative;overflow:hidden}
.final-cta::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.07) 1px,transparent 1px);background-size:28px 28px}
.final-cta h2{font-family:var(--font-display);font-size:clamp(28px,4vw,44px);font-weight:800;color:#fff;letter-spacing:-0.025em;line-height:1.1;margin-bottom:14px;position:relative}
.final-cta p{font-size:17px;color:rgba(255,255,255,0.75);max-width:480px;margin:0 auto 36px;line-height:1.6;position:relative}
.final-ctas{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;position:relative}
.btn-cta-white{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:800;color:var(--c-primary);background:#fff;padding:16px 32px;border-radius:var(--r);transition:all var(--t);box-shadow:0 4px 20px rgba(0,0,0,0.15)}
.btn-cta-white:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,0.20)}
.btn-cta-wa{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:700;color:#fff;background:rgba(255,255,255,0.15);border:1.5px solid rgba(255,255,255,0.35);padding:15px 28px;border-radius:var(--r);transition:all var(--t)}
.btn-cta-wa:hover{background:rgba(255,255,255,0.22);border-color:rgba(255,255,255,0.55)}

/* FOOTER */
.footer{background:var(--c-navy);padding:64px 0 32px}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,0.10);margin-bottom:32px}
.footer-logo img{height:32px;margin-bottom:16px;filter:brightness(0) invert(1)}
.footer-tagline{font-size:14px;color:rgba(255,255,255,0.50);line-height:1.6;max-width:240px;margin-bottom:20px}
.footer-social{display:flex;gap:10px}
.footer-social-link{width:36px;height:36px;background:rgba(255,255,255,0.08);border-radius:8px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.60);transition:all var(--t);font-size:13px;font-weight:700}
.footer-social-link:hover{background:var(--c-primary);color:#fff}
.footer-col h5{font-family:var(--font-display);font-size:13px;font-weight:700;color:rgba(255,255,255,0.85);letter-spacing:.04em;text-transform:uppercase;margin-bottom:16px}
.footer-col ul{display:flex;flex-direction:column;gap:10px}
.footer-col ul li a{font-size:14px;color:rgba(255,255,255,0.50);transition:color var(--t)}
.footer-col ul li a:hover{color:rgba(255,255,255,0.90)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.footer-bottom p{font-size:13px;color:rgba(255,255,255,0.35)}
.footer-contact a{display:flex;align-items:center;gap:7px;font-size:13px;color:rgba(255,255,255,0.50);transition:color var(--t)}
.footer-contact a:hover{color:rgba(255,255,255,0.90)}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,0.70);backdrop-filter:blur(6px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity 0.25s ease}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{background:var(--c-white);border-radius:var(--r-xl);width:100%;max-width:560px;overflow:hidden;box-shadow:var(--sh-lg);transform:translateY(20px) scale(0.97);transition:transform 0.25s ease}
.modal-overlay.open .modal-box{transform:translateY(0) scale(1)}
.modal-header{background:linear-gradient(135deg,var(--c-navy) 0%,var(--c-navy-mid) 100%);padding:28px 32px 24px;position:relative}
.modal-header h2{font-family:var(--font-display);font-size:22px;font-weight:800;color:#fff;margin-bottom:6px;letter-spacing:-0.02em}
.modal-header p{font-size:14px;color:rgba(255,255,255,0.60);line-height:1.5}
.modal-close{position:absolute;top:16px;right:20px;color:rgba(255,255,255,0.50);font-size:22px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.modal-close:hover{color:#fff}
.modal-body{padding:28px 32px 32px}
.modal-option-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:22px}
.modal-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 14px;border-radius:var(--r-lg);border:2px solid var(--c-border);cursor:pointer;text-align:center;transition:all var(--t);text-decoration:none;color:inherit}
.modal-option:hover{border-color:var(--c-primary);background:var(--c-primary-light)}
.modal-option.option-wa:hover{border-color:#25D366;background:#F0FDF4}
.modal-option-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px}
.modal-option .opt-title{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.modal-option .opt-sub{font-size:12px;color:var(--c-muted)}
.modal-divider{display:flex;align-items:center;gap:12px;color:var(--c-subtle);font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:20px}
.modal-divider::before,.modal-divider::after{content:'';flex:1;height:1px;background:var(--c-border)}
.modal-form{display:flex;flex-direction:column;gap:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-field{display:flex;flex-direction:column;gap:5px}
.form-field label{font-size:12.5px;font-weight:700;color:var(--c-slate);letter-spacing:.02em}
.form-field input,.form-field select{font-family:var(--font-body);font-size:14px;color:var(--c-body);background:var(--c-bg);border:1.5px solid var(--c-border);border-radius:var(--r);padding:11px 14px;outline:none;transition:border-color var(--t),box-shadow var(--t);width:100%}
.form-field input::placeholder{color:var(--c-subtle)}
.form-field input:focus,.form-field select:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(37,99,235,0.12)}
.btn-form-submit{font-family:var(--font-body);font-size:15px;font-weight:800;color:#fff;background:var(--c-primary);padding:14px 24px;border-radius:var(--r);border:none;cursor:pointer;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--t);margin-top:4px}
.btn-form-submit:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}
.modal-thanks{display:none;text-align:center;padding:32px}
.modal-thanks-icon{width:64px;height:64px;background:var(--c-green-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-size:32px}
.modal-thanks h3{font-family:var(--font-display);font-size:22px;font-weight:800;color:var(--c-navy);margin-bottom:8px}
.modal-thanks p{font-size:15px;color:var(--c-muted);line-height:1.6}

/* FADE UP */
.fade-up{opacity:0;transform:translateY(24px);transition:opacity 0.55s ease,transform 0.55s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up.d1{transition-delay:.08s}
.fade-up.d2{transition-delay:.16s}
.fade-up.d3{transition-delay:.24s}

/* RESPONSIVE */
@media(max-width:1060px){
  .mod-grid{grid-template-columns:1fr;gap:40px}
  .mod-grid.reverse{direction:ltr}
  .mod-bg-num{font-size:120px}
  .matrix-wrap{font-size:12px}
  .faq-grid{grid-template-columns:1fr;gap:40px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
}
@media(max-width:760px){
  .mod-features{grid-template-columns:1fr}
  .module-tiles-inner{gap:0}
  .mod-tile{padding:10px 14px}
  .mod-tile-name{font-size:12px}
  .footer-grid{grid-template-columns:1fr}
  .modal-option-row{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
}
@media(max-width:640px){
  .nav-links,.nav-ctas{display:none}
  .nav-hamburger{display:flex}
  .section{padding:60px 0}
  .mod-section{padding:60px 0}
  .int-matrix td,.int-matrix th{padding:8px 6px;font-size:11px}
  .int-matrix td:first-child{padding-left:10px;font-size:12px}
  .int-matrix thead th:first-child{width:140px}
}

/* ----- modulos.html (keyframes) ----- */
@keyframes ring {
  0%,100%{box-shadow:0 0 0 0 rgba(37,99,235,0.40)}
  50%{box-shadow:0 0 0 14px rgba(37,99,235,0)}
}

/* ========== index.html (home) ========== */
/* ── VARIABLES ───────────────────────────────── */
    

    /* ── RESET & BASE ────────────────────────────── */
    *,
    *::before,
    *::after {
      box-sizing: border-box;
      margin: 0;
      padding: 0;
    }

    html {
      scroll-behavior: smooth;
    }

    body {
      font-family: var(--font-body);
      font-size: 16px;
      line-height: 1.6;
      color: var(--c-body);
      background: var(--c-white);
      -webkit-font-smoothing: antialiased;
    }

    img {
      max-width: 100%;
      display: block;
    }

    a {
      text-decoration: none;
      color: inherit;
    }

    button {
      cursor: pointer;
      border: none;
      background: none;
      font-family: inherit;
    }

   ul,
    ol {
      list-style: none;
      margin: 0;
      padding: 0;
    }

    li::marker {
      content: "";
    }

    .container {
      max-width: var(--w-max);
      margin: 0 auto;
      padding: 0 24px;
    }

    /* ── ANNOUNCEMENT BAR ───────────────────────── */
    .ann-bar {
      background: var(--c-navy-mid);
      color: var(--c-white);
      padding: 10px 24px;
      font-family: var(--font-body);
      font-size: 13.5px;
      font-weight: 500;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 12px;
      position: relative;
    }

    .ann-bar a {
      color: #93C5FD;
      text-decoration: underline;
      text-underline-offset: 2px;
    }

    .ann-bar a:hover {
      color: #BFDBFE;
    }

    .ann-bar .ann-badge {
      background: var(--c-primary);
      color: #fff;
      font-size: 10.5px;
      font-weight: 700;
      letter-spacing: .04em;
      text-transform: uppercase;
      padding: 2px 8px;
      border-radius: 4px;
      white-space: nowrap;
    }

    .ann-bar .ann-close {
      position: absolute;
      right: 20px;
      top: 50%;
      transform: translateY(-50%);
      color: var(--c-subtle);
      font-size: 18px;
      line-height: 1;
      cursor: pointer;
      transition: color var(--t);
    }

    .ann-bar .ann-close:hover {
      color: var(--c-white);
    }

    /* ── NAVIGATION ─────────────────────────────── */
    /* Barra clara por defecto: en subpáginas #mainNav no lleva .scrolled/.nav-hero (solo index). */
    .nav {
      position: sticky;
      top: 0;
      z-index: 900;
      transition: background var(--t), box-shadow var(--t), border-color var(--t);
      background: rgba(255, 255, 255, 0.96);
      backdrop-filter: blur(12px);
      -webkit-backdrop-filter: blur(12px);
      box-shadow: 0 1px 0 var(--c-border), var(--sh-xs);
      border-bottom: 1px solid var(--c-border);
    }

    .nav.scrolled {
      background: rgba(255, 255, 255, 0.96);
      backdrop-filter: blur(12px);
      -webkit-backdrop-filter: blur(12px);
      box-shadow: 0 1px 0 var(--c-border), var(--sh-xs);
      border-color: var(--c-border);
    }

    .nav.nav-hero {
      background: rgba(255, 255, 255, 0.96);
      backdrop-filter: blur(12px);
      -webkit-backdrop-filter: blur(12px);
      box-shadow: 0 1px 0 var(--c-border), var(--sh-xs);
      border-color: var(--c-border);
    }

    .nav-inner {
      max-width: var(--w-max);
      margin: 0 auto;
      padding: 0 24px;
      height: 64px;
      display: flex;
      align-items: center;
      gap: 32px;
    }

    #mainNav .nav-links > a,
    #mainNav .nav-links .nav-dropdown-trigger,
    #mainNav .nav-ctas .btn-nav-login,
    #mainNav .nav-ctas .btn-nav-demo {
      white-space: nowrap;
    }

    .nav-logo img {
      height: 34px;
      width: auto;
    }

    .nav-links {
      display: flex;
      align-items: center;
      gap: 4px;
      margin-left: auto;
    }

    .nav-links a {
      font-size: 14.5px;
      font-weight: 500;
      color: var(--c-slate);
      padding: 8px 14px;
      border-radius: var(--r-sm);
      transition: color var(--t), background var(--t);
    }

    .nav-links a:hover {
      color: var(--c-primary);
      background: var(--c-primary-light);
    }

    .nav.scrolled .nav-links a {
      color: var(--c-slate);
    }

    .nav.nav-hero .nav-links a {
      color: var(--c-slate);
    }

    .nav.scrolled .nav-links a:hover {
      color: var(--c-primary);
      background: var(--c-primary-light);
    }

    .nav.nav-hero .nav-links a:hover {
      color: var(--c-primary);
      background: var(--c-primary-light);
    }

    .nav-dropdown {
      position: relative;
    }

    .nav-links .nav-dropdown-trigger {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      font-family: inherit;
      font-size: 14.5px;
      font-weight: 500;
      color: var(--c-slate);
      padding: 8px 14px;
      border: none;
      border-radius: var(--r-sm);
      background: transparent;
      cursor: pointer;
      transition: color var(--t), background var(--t);
    }

    .nav-links .nav-dropdown-trigger:hover {
      color: var(--c-primary);
      background: var(--c-primary-light);
    }

    .nav.scrolled .nav-links .nav-dropdown-trigger {
      color: var(--c-slate);
    }

    .nav.nav-hero .nav-links .nav-dropdown-trigger {
      color: var(--c-slate);
    }

    .nav.scrolled .nav-links .nav-dropdown-trigger:hover {
      color: var(--c-primary);
      background: var(--c-primary-light);
    }

    .nav.nav-hero .nav-links .nav-dropdown-trigger:hover {
      color: var(--c-primary);
      background: var(--c-primary-light);
    }

    .nav-dropdown.is-open .nav-dropdown-trigger {
      color: var(--c-primary);
      background: var(--c-primary-light);
    }

    .nav-dropdown-chevron {
      display: inline-block;
      width: 0.42em;
      height: 0.42em;
      border-right: 2px solid currentColor;
      border-bottom: 2px solid currentColor;
      transform: rotate(45deg);
      margin-top: -0.2em;
      transition: transform var(--t);
    }

    .nav-dropdown.is-open .nav-dropdown-chevron {
      transform: rotate(-135deg);
      margin-top: 0.12em;
    }

    .nav-dropdown-panel {
      display: none;
      position: absolute;
      top: calc(100% + 4px);
      left: 0;
      min-width: 220px;
      padding: 8px 0;
      background: #fff;
      border-radius: var(--r-sm);
      box-shadow: 0 10px 40px rgba(15, 23, 42, 0.12), 0 0 0 1px var(--c-border);
      z-index: 950;
    }

    .nav-dropdown.is-open .nav-dropdown-panel {
      display: block;
    }

    .nav-dropdown-panel a {
      display: block;
      font-size: 14px;
      font-weight: 500;
      color: var(--c-slate);
      padding: 10px 16px;
      border-radius: 0;
      transition: color var(--t), background var(--t);
    }

    .nav-dropdown-panel a:hover {
      color: var(--c-primary);
      background: var(--c-primary-light);
    }

    .nav-ctas {
      display: flex;
      align-items: center;
      gap: 10px;
      margin-left: 12px;
    }

    .btn-nav-login {
      font-size: 14px;
      font-weight: 600;
      color: var(--c-slate);
      padding: 8px 16px;
      border-radius: var(--r-sm);
      border: 1px solid var(--c-border);
      transition: all var(--t);
    }

    .btn-nav-login:hover {
      color: var(--c-primary);
      border-color: var(--c-primary);
      background: var(--c-primary-light);
    }

    .nav.scrolled .btn-nav-login {
      color: var(--c-slate);
      border-color: var(--c-border);
    }

    .nav.nav-hero .btn-nav-login {
      color: var(--c-slate);
      border-color: var(--c-border);
    }

    .nav.scrolled .btn-nav-login:hover {
      color: var(--c-primary);
      border-color: var(--c-primary);
      background: var(--c-primary-light);
    }

    .nav.nav-hero .btn-nav-login:hover {
      color: var(--c-primary);
      border-color: var(--c-primary);
      background: var(--c-primary-light);
    }

    .btn-nav-demo {
      font-size: 14px;
      font-weight: 700;
      color: #fff;
      background: var(--c-primary);
      padding: 9px 20px;
      border-radius: var(--r-sm);
      transition: background var(--t), transform var(--t), box-shadow var(--t);
    }

    .btn-nav-demo:hover {
      background: var(--c-primary-dark);
      transform: translateY(-1px);
      box-shadow: var(--sh-blue);
    }

    .nav-hamburger {
      display: none;
      flex-direction: column;
      gap: 5px;
      padding: 8px;
      cursor: pointer;
      margin-left: auto;
    }

    .nav-hamburger span {
      display: block;
      width: 22px;
      height: 2px;
      background: var(--c-navy-mid);
      border-radius: 2px;
      transition: all var(--t);
    }

    .nav.scrolled .nav-hamburger span {
      background: var(--c-navy-mid);
    }

    .nav.nav-hero .nav-hamburger span {
      background: var(--c-navy-mid);
    }

    /* ── HERO ────────────────────────────────────── */
    .hero {
      background-color: var(--c-navy);
      background-image:
        radial-gradient(ellipse 70% 60% at 15% 50%, rgba(37, 99, 235, 0.20) 0%, transparent 60%),
        radial-gradient(ellipse 50% 40% at 85% 15%, rgba(37, 99, 235, 0.10) 0%, transparent 50%);
      position: relative;
      overflow: hidden;
      padding: 80px 0 96px;
    }

    .hero::before {
      content: '';
      position: absolute;
      inset: 0;
      background-image: radial-gradient(rgba(255, 255, 255, 0.055) 1px, transparent 1px);
      background-size: 32px 32px;
      pointer-events: none;
    }

    .hero-grid {
      display: grid;
      grid-template-columns: 1fr 355px;
      gap: 44px;
      align-items: start;
      position: relative;
    }

    .hero-eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      background: rgba(37, 99, 235, 0.18);
      border: 1px solid rgba(37, 99, 235, 0.35);
      color: #93C5FD;
      font-size: 12.5px;
      font-weight: 600;
      letter-spacing: .06em;
      text-transform: uppercase;
      padding: 6px 14px;
      border-radius: 100px;
      margin-bottom: 24px;
    }

    .hero-eyebrow-dot {
      width: 6px;
      height: 6px;
      border-radius: 50%;
      background: #60A5FA;
      animation: pulse-dot 2s infinite;
    }

    @keyframes pulse-dot {

      0%,
      100% {
        opacity: 1;
        transform: scale(1);
      }

      50% {
        opacity: .5;
        transform: scale(0.75);
      }
    }

    .hero h1 {
      font-family: var(--font-display);
      font-size: clamp(36px, 4.5vw, 54px);
      font-weight: 800;
      line-height: 1.1;
      color: var(--c-white);
      margin-bottom: 20px;
      letter-spacing: -0.03em;
    }

    .hero h1 em {
      font-style: normal;
      color: #60A5FA;
    }

    .hero-sub {
      font-size: 18px;
      line-height: 1.65;
      color: rgba(255, 255, 255, 0.68);
      max-width: 520px;
      margin-bottom: 36px;
    }

    .hero-sub strong {
      color: rgba(255, 255, 255, 0.90);
      font-weight: 600;
    }

    .hero .hero-ctas {
      display: flex;
      gap: 14px;
      flex-wrap: wrap;
      justify-content: flex-start;
      margin-bottom: 44px;
    }

    .btn-primary {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-family: var(--font-body);
      font-size: 15px;
      font-weight: 700;
      color: var(--c-white);
      background: var(--c-primary);
      padding: 14px 28px;
      border-radius: var(--r);
      transition: background var(--t), transform var(--t), box-shadow var(--t);
    }

    .btn-primary:hover {
      background: var(--c-primary-dark);
      transform: translateY(-2px);
      box-shadow: var(--sh-blue);
    }

    .btn-secondary {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-family: var(--font-body);
      font-size: 15px;
      font-weight: 600;
      color: rgba(255, 255, 255, 0.85);
      background: rgba(255, 255, 255, 0.08);
      border: 1px solid rgba(255, 255, 255, 0.18);
      padding: 14px 24px;
      border-radius: var(--r);
      transition: all var(--t);
    }

    .btn-secondary:hover {
      background: rgba(255, 255, 255, 0.14);
      color: #fff;
      border-color: rgba(255, 255, 255, 0.35);
    }

    .hero-trust {
      display: flex;
      flex-direction: column;
      gap: 10px;
    }

    .hero-trust-item {
      display: flex;
      align-items: center;
      gap: 10px;
      font-size: 13.5px;
      color: rgba(255, 255, 255, 0.58);
    }

    .hero-trust-item svg {
      flex-shrink: 0;
    }

    /* ── ADMIN PANEL HERO ───────────────────────── */
    .admin-panel-hero {
      background: var(--c-navy-mid);
      border-radius: var(--r-xl);
      overflow: hidden;
      position: sticky;
      top: 88px;
      border: 1px solid rgba(255, 255, 255, 0.08);
      box-shadow: 0 20px 60px rgba(0, 0, 0, 0.40), 0 4px 16px rgba(37, 99, 235, 0.20);
      transition: box-shadow var(--t);
    }

    .admin-panel-hero:hover {
      box-shadow: 0 24px 72px rgba(0, 0, 0, 0.48), 0 6px 20px rgba(37, 99, 235, 0.28);
    }

    .aph-topbar {
      background: var(--c-navy);
      padding: 12px 16px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      border-bottom: 1px solid rgba(255, 255, 255, 0.07);
    }

    .aph-identity {
      display: flex;
      align-items: center;
      gap: 10px;
    }

    .aph-logo-mark {
      width: 28px;
      height: 28px;
      background: var(--c-primary);
      border-radius: 7px;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
    }

    .aph-title {
      font-family: var(--font-display);
      font-size: 12.5px;
      font-weight: 700;
      color: #fff;
      line-height: 1.2;
    }

    .aph-subtitle {
      font-size: 10.5px;
      color: rgba(255, 255, 255, 0.45);
      margin-top: 1px;
    }

    .aph-live-badge {
      display: flex;
      align-items: center;
      gap: 5px;
      font-size: 10.5px;
      font-weight: 700;
      color: #4ADE80;
      background: rgba(74, 222, 128, 0.12);
      border: 1px solid rgba(74, 222, 128, 0.22);
      padding: 3px 9px;
      border-radius: 100px;
    }

    .aph-live-dot {
      width: 6px;
      height: 6px;
      border-radius: 50%;
      background: #4ADE80;
      animation: pulse-dot 2s infinite;
    }

    .aph-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 1px;
      background: rgba(255, 255, 255, 0.06);
    }

    .aph-widget {
      background: var(--c-navy-mid);
      padding: 14px 15px;
      position: relative;
      overflow: hidden;
      transition: background var(--t);
    }

    .aph-widget:hover {
      background: rgba(255, 255, 255, 0.05);
    }

    .aph-widget-accent {
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      height: 2px;
    }

    .aph-widget-label {
      font-size: 10px;
      font-weight: 700;
      letter-spacing: .07em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.38);
      margin-bottom: 7px;
      display: flex;
      align-items: center;
      gap: 5px;
    }

    .aph-widget-label svg {
      flex-shrink: 0;
    }

    .aph-value {
      font-family: var(--font-display);
      font-size: 22px;
      font-weight: 800;
      line-height: 1;
      letter-spacing: -0.03em;
      color: #fff;
      margin-bottom: 3px;
    }

    .aph-sub {
      font-size: 10.5px;
      color: rgba(255, 255, 255, 0.40);
      line-height: 1.4;
    }

    .aph-trend {
      display: flex;
      align-items: center;
      gap: 4px;
      font-size: 10.5px;
      color: #4ADE80;
      margin-top: 4px;
    }

    .aph-entry-list {
      display: flex;
      flex-direction: column;
      gap: 5px;
      margin-top: 3px;
    }

    .aph-entry {
      display: flex;
      align-items: center;
      gap: 6px;
    }

    .aph-entry-dot {
      width: 5px;
      height: 5px;
      border-radius: 50%;
      flex-shrink: 0;
    }

    .aph-entry-name {
      font-size: 10.5px;
      color: rgba(255, 255, 255, 0.65);
      flex: 1;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }

    .aph-entry-badge {
      font-size: 9.5px;
      font-weight: 700;
      padding: 1px 6px;
      border-radius: 3px;
      white-space: nowrap;
      flex-shrink: 0;
    }

    .entry-ok {
      background: rgba(74, 222, 128, 0.14);
      color: #4ADE80;
    }

    .entry-in {
      background: rgba(96, 165, 250, 0.14);
      color: #60A5FA;
    }

    .entry-warn {
      background: rgba(251, 191, 36, 0.14);
      color: #FBBF24;
    }

    .aph-pqrs-bars {
      display: flex;
      flex-direction: column;
      gap: 5px;
      margin-top: 4px;
    }

    .aph-bar-row {
      display: flex;
      align-items: center;
      gap: 6px;
    }

    .aph-bar-lbl {
      font-size: 10px;
      color: rgba(255, 255, 255, 0.45);
      width: 46px;
      flex-shrink: 0;
    }

    .aph-bar-track {
      flex: 1;
      height: 4px;
      background: rgba(255, 255, 255, 0.08);
      border-radius: 2px;
      overflow: hidden;
    }

    .aph-bar-fill {
      height: 100%;
      border-radius: 2px;
    }

    .aph-bar-num {
      font-size: 10px;
      color: rgba(255, 255, 255, 0.45);
      width: 12px;
      text-align: right;
      flex-shrink: 0;
    }

    .aph-chat {
      display: flex;
      flex-direction: column;
      gap: 5px;
      margin-top: 3px;
    }

    .aph-msg {
      padding: 5px 8px;
      border-radius: 6px;
      font-size: 10.5px;
      line-height: 1.4;
      max-width: 90%;
    }

    .aph-msg-in {
      background: rgba(255, 255, 255, 0.08);
      color: rgba(255, 255, 255, 0.70);
      align-self: flex-start;
    }

    .aph-msg-out {
      background: rgba(37, 99, 235, 0.35);
      color: rgba(255, 255, 255, 0.85);
      align-self: flex-end;
      text-align: right;
    }

    .aph-typing {
      display: flex;
      align-items: center;
      gap: 3px;
      padding: 6px 8px;
      background: rgba(255, 255, 255, 0.08);
      border-radius: 6px;
      align-self: flex-start;
    }

    .aph-typing span {
      width: 4px;
      height: 4px;
      border-radius: 50%;
      background: rgba(255, 255, 255, 0.50);
    }

    .aph-typing span:nth-child(1) {
      animation: typing-dot .8s ease-in-out infinite 0s;
    }

    .aph-typing span:nth-child(2) {
      animation: typing-dot .8s ease-in-out infinite .15s;
    }

    .aph-typing span:nth-child(3) {
      animation: typing-dot .8s ease-in-out infinite .30s;
    }

    @keyframes typing-dot {

      0%,
      100% {
        opacity: .3;
        transform: translateY(0);
      }

      50% {
        opacity: 1;
        transform: translateY(-2px);
      }
    }

    .aph-agent-status {
      display: flex;
      align-items: center;
      gap: 4px;
      font-size: 10px;
      color: #4ADE80;
      margin-top: 5px;
    }

    @media (max-width: 1080px) {
      .admin-panel-hero {
        position: static;
      }
    }

    /* ── DIRECTORIO ACCESS BAND ─────────────────── */
    .directorio-band {
      background: var(--c-navy);
      border-top: 1px solid rgba(37, 99, 235, 0.20);
      border-bottom: 1px solid rgba(37, 99, 235, 0.20);
      padding: 28px 0;
    }

    .dir-band-inner {
      display: flex;
      align-items: center;
      gap: 36px;
      flex-wrap: wrap;
    }

    .dir-band-left {
      display: flex;
      align-items: flex-start;
      gap: 18px;
      flex: 1;
      min-width: 280px;
    }

    .dir-band-icon {
      width: 44px;
      height: 44px;
      background: rgba(37, 99, 235, 0.25);
      border: 1px solid rgba(37, 99, 235, 0.40);
      border-radius: 11px;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      margin-top: 2px;
    }

    .dir-band-eyebrow {
      font-size: 10.5px;
      font-weight: 700;
      letter-spacing: .07em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.38);
      margin-bottom: 5px;
    }

    .dir-band-title {
      font-family: var(--font-display);
      font-size: 17px;
      font-weight: 800;
      color: #fff;
      letter-spacing: -0.02em;
      margin-bottom: 6px;
      line-height: 1.2;
    }

    .dir-band-desc {
      font-size: 14px;
      color: rgba(255, 255, 255, 0.60);
      line-height: 1.60;
      max-width: 540px;
    }

    .dir-band-desc strong {
      color: rgba(255, 255, 255, 0.85);
      font-weight: 600;
    }

    .dir-band-note {
      display: flex;
      align-items: center;
      gap: 6px;
      font-size: 12px;
      color: rgba(255, 255, 255, 0.38);
      margin-top: 8px;
    }

    .dir-band-right {
      display: flex;
      flex-direction: column;
      gap: 9px;
      flex-shrink: 0;
      min-width: 200px;
    }

    .btn-dir-band-primary {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      font-family: var(--font-body);
      font-size: 14px;
      font-weight: 700;
      color: #fff;
      background: var(--c-primary);
      padding: 11px 20px;
      border-radius: var(--r);
      transition: background var(--t), transform var(--t), box-shadow var(--t);
      white-space: nowrap;
    }

    .btn-dir-band-primary:hover {
      background: var(--c-primary-dark);
      transform: translateY(-1px);
      box-shadow: var(--sh-blue);
    }

    @media (max-width: 700px) {
      .dir-band-inner {
        flex-direction: column;
        gap: 20px;
      }

      .dir-band-right {
        width: 100%;
      }

      .btn-dir-band-primary {
        width: 100%;
      }
    }

    /* ── PROOF STRIP ─────────────────────────────── */
    .proof-strip {
      background: var(--c-white);
      border-bottom: 1px solid var(--c-border);
      padding: 20px 0;
    }

    .proof-inner {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 0;
      flex-wrap: wrap;
    }

    .proof-item {
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 10px 32px;
      border-right: 1px solid var(--c-border);
    }

    .proof-item:last-child {
      border-right: none;
    }

    .proof-icon {
      width: 36px;
      height: 36px;
      background: var(--c-primary-light);
      border-radius: var(--r-sm);
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
    }

    .proof-text-main {
      font-size: 14.5px;
      font-weight: 700;
      color: var(--c-navy-mid);
      line-height: 1.2;
    }

    .proof-text-sub {
      font-size: 11.5px;
      color: var(--c-muted);
    }

    /* ── SECTION BASE ────────────────────────────── */
    .section {
      padding: var(--pad-section) 0;
    }

    .section-alt {
      background: var(--c-bg);
    }

    .section-dark {
      background: var(--c-navy);
    }

    .section-blue {
      background: var(--c-primary);
    }

    .section-eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 7px;
      font-size: 12px;
      font-weight: 700;
      letter-spacing: .08em;
      text-transform: uppercase;
      color: var(--c-primary);
      margin-bottom: 14px;
    }

    .section-eyebrow-bar {
      width: 24px;
      height: 2px;
      background: var(--c-primary);
      border-radius: 2px;
    }

    .section-h2 {
      font-family: var(--font-display);
      font-size: clamp(28px, 3.5vw, 40px);
      font-weight: 800;
      line-height: 1.15;
      letter-spacing: -0.025em;
      color: var(--c-navy);
      margin-bottom: 14px;
    }

    .section-h2.light {
      color: var(--c-white);
    }

    .section-sub {
      font-size: 17px;
      line-height: 1.65;
      color: var(--c-muted);
      max-width: 560px;
    }

    .section-sub.light {
      color: rgba(255, 255, 255, 0.72);
    }

    /* ── PROBLEM SECTION ─────────────────────────── */
    .problem-header {
      margin-bottom: 52px;
    }

    .problem-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 16px;
    }

    .problem-card {
      background: var(--c-white);
      border: 1.5px solid var(--c-border);
      border-radius: var(--r-lg);
      padding: 24px 20px;
      transition: border-color var(--t), box-shadow var(--t), transform var(--t);
      cursor: default;
    }

    .problem-card:hover {
      border-color: rgba(37, 99, 235, 0.30);
      box-shadow: var(--sh-md);
      transform: translateY(-2px);
    }

    .problem-icon {
      width: 44px;
      height: 44px;
      background: var(--c-red-light);
      border-radius: var(--r-sm);
      display: flex;
      align-items: center;
      justify-content: center;
      margin-bottom: 14px;
    }

    .problem-card h4 {
      font-size: 14.5px;
      font-weight: 700;
      color: var(--c-navy-mid);
      line-height: 1.3;
      margin-bottom: 6px;
    }

    .problem-card p {
      font-size: 13px;
      color: var(--c-muted);
      line-height: 1.5;
    }

    /* ── ECOSYSTEM / MODULES ─────────────────────── */
    .ecosystem-intro {
      max-width: 640px;
      margin-bottom: 60px;
    }

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

    .module-card {
      background: var(--c-white);
      border: 1.5px solid var(--c-border);
      border-radius: var(--r-lg);
      padding: 28px 22px;
      position: relative;
      overflow: hidden;
      transition: border-color var(--t), box-shadow var(--t), transform var(--t);
    }

    a.module-card {
      display: block;
      text-decoration: none;
      color: inherit;
      cursor: pointer;
    }

    a.module-card:focus-visible {
      outline: 2px solid var(--c-primary);
      outline-offset: 3px;
    }

    .module-card::before {
      content: attr(data-n);
      position: absolute;
      top: -8px;
      right: 12px;
      font-family: var(--font-display);
      font-size: 72px;
      font-weight: 900;
      color: var(--c-primary-light);
      line-height: 1;
      pointer-events: none;
      transition: color var(--t);
      letter-spacing: -0.04em;
    }

    .module-card:hover {
      border-color: var(--c-primary);
      box-shadow: var(--sh-md);
      transform: translateY(-3px);
    }

    .module-card:hover::before {
      color: #DBEAFE;
    }

    .module-icon {
      width: 48px;
      height: 48px;
      background: var(--c-primary-light);
      border-radius: 12px;
      display: flex;
      align-items: center;
      justify-content: center;
      margin-bottom: 16px;
      transition: background var(--t);
    }

    .module-card:hover .module-icon {
      background: var(--c-primary);
    }

    .module-card:hover .module-icon svg {
      color: #fff;
    }

    .module-icon svg {
      transition: color var(--t);
    }

    .module-card h4 {
      font-family: var(--font-display);
      font-size: 15px;
      font-weight: 700;
      color: var(--c-navy-mid);
      margin-bottom: 8px;
      line-height: 1.25;
    }

    .module-card p {
      font-size: 13px;
      color: var(--c-muted);
      line-height: 1.5;
      margin-bottom: 14px;
    }

    .module-integra {
      display: flex;
      flex-wrap: wrap;
      gap: 5px;
    }

    .integra-chip {
      font-size: 11px;
      font-weight: 600;
      color: var(--c-primary);
      background: var(--c-primary-light);
      padding: 2px 8px;
      border-radius: 100px;
    }

    /* ── WHATSAPP FEATURE ────────────────────────── */
    .wa-section {
      background: linear-gradient(135deg, #064E3B 0%, #065F46 60%, #047857 100%);
      position: relative;
      overflow: hidden;
    }

    .wa-section::before {
      content: '';
      position: absolute;
      inset: 0;
      background-image: radial-gradient(rgba(255, 255, 255, 0.04) 1px, transparent 1px);
      background-size: 28px 28px;
    }

    .wa-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 80px;
      align-items: center;
      position: relative;
    }

    .wa-eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      background: rgba(255, 255, 255, 0.12);
      border: 1px solid rgba(255, 255, 255, 0.20);
      color: #6EE7B7;
      font-size: 12px;
      font-weight: 700;
      letter-spacing: .07em;
      text-transform: uppercase;
      padding: 6px 14px;
      border-radius: 100px;
      margin-bottom: 22px;
    }

    .wa-h2 {
      font-family: var(--font-display);
      font-size: clamp(26px, 3vw, 36px);
      font-weight: 800;
      color: #fff;
      letter-spacing: -0.025em;
      line-height: 1.15;
      margin-bottom: 18px;
    }

    .wa-sub {
      font-size: 16.5px;
      color: rgba(255, 255, 255, 0.70);
      line-height: 1.65;
      margin-bottom: 32px;
    }

    .wa-features {
      display: flex;
      flex-direction: column;
      gap: 14px;
    }

    .wa-feat {
      display: flex;
      align-items: flex-start;
      gap: 12px;
    }

    .wa-feat-icon {
      width: 32px;
      height: 32px;
      background: rgba(110, 231, 183, 0.18);
      border-radius: 8px;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      margin-top: 1px;
    }

    .wa-feat-text {
      font-size: 14.5px;
      color: rgba(255, 255, 255, 0.85);
      line-height: 1.5;
    }

    .wa-feat-text strong {
      color: #fff;
      font-weight: 700;
    }

    .wa-visual {
      display: flex;
      justify-content: center;
      align-items: center;
    }

    .wa-phone-mockup {
      background: var(--c-navy);
      border-radius: 32px;
      padding: 12px;
      box-shadow: 0 40px 80px rgba(0, 0, 0, 0.40);
      border: 2px solid rgba(255, 255, 255, 0.08);
      max-width: 280px;
      width: 100%;
    }

    .wa-phone-screen {
      background: #ECE5DD;
      border-radius: 24px;
      overflow: hidden;
    }

    .wa-phone-header {
      background: #075E54;
      padding: 14px 16px 12px;
      display: flex;
      align-items: center;
      gap: 10px;
    }

    .wa-phone-avatar {
      width: 36px;
      height: 36px;
      background: #25D366;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 16px;
    }

    .wa-phone-name {
      font-size: 14px;
      font-weight: 700;
      color: #fff;
    }

    .wa-phone-status {
      font-size: 11px;
      color: rgba(255, 255, 255, 0.70);
    }

    .wa-messages {
      padding: 14px 12px;
      display: flex;
      flex-direction: column;
      gap: 8px;
    }

    .wa-msg-recv,
    .wa-msg-sent {
      max-width: 90%;
      padding: 9px 12px;
      border-radius: 12px;
      font-size: 13px;
      line-height: 1.45;
    }

    .wa-msg-recv {
      background: #fff;
      color: #333;
      align-self: flex-start;
      border-top-left-radius: 4px;
      box-shadow: 0 1px 2px rgba(0, 0, 0, 0.10);
    }

    .wa-msg-sent {
      background: #DCF8C6;
      color: #333;
      align-self: flex-end;
      border-top-right-radius: 4px;
      box-shadow: 0 1px 2px rgba(0, 0, 0, 0.10);
    }

    .wa-msg-time {
      font-size: 10px;
      color: #999;
      text-align: right;
      margin-top: 3px;
    }

    /* ── ACCOUNTING FEATURE ──────────────────────── */
    .accounting-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 72px;
      align-items: center;
    }

    .accounting-badge {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      background: #FFF7ED;
      border: 1px solid #FED7AA;
      color: #C2410C;
      font-size: 12px;
      font-weight: 700;
      padding: 5px 12px;
      border-radius: 100px;
      margin-bottom: 20px;
    }

    .accounting-feat-list {
      display: flex;
      flex-direction: column;
      gap: 16px;
      margin: 24px 0 32px;
    }

    .acc-feat {
      display: flex;
      align-items: flex-start;
      gap: 14px;
      padding-bottom: 16px;
      border-bottom: 1px solid var(--c-border);
    }

    .acc-feat:last-child {
      border-bottom: none;
      padding-bottom: 0;
    }

    .acc-feat-num {
      width: 28px;
      height: 28px;
      background: var(--c-primary);
      color: #fff;
      border-radius: 7px;
      font-size: 13px;
      font-weight: 800;
      font-family: var(--font-display);
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
    }

    .acc-feat-title {
      font-size: 14.5px;
      font-weight: 700;
      color: var(--c-navy-mid);
      margin-bottom: 3px;
    }

    .acc-feat-desc {
      font-size: 13px;
      color: var(--c-muted);
      line-height: 1.5;
    }

    .acc-compliance-box {
      background: var(--c-primary-light);
      border: 1.5px solid rgba(37, 99, 235, 0.20);
      border-radius: var(--r-lg);
      padding: 18px 20px;
      display: flex;
      gap: 14px;
      align-items: flex-start;
    }

    .acc-compliance-box svg {
      flex-shrink: 0;
      margin-top: 1px;
    }

    .acc-compliance-title {
      font-size: 14px;
      font-weight: 700;
      color: var(--c-primary);
      margin-bottom: 4px;
    }

    .acc-compliance-text {
      font-size: 13px;
      color: var(--c-slate);
      line-height: 1.5;
    }

    .feature-visual {
      background: var(--c-bg);
      border: 1.5px solid var(--c-border);
      border-radius: var(--r-xl);
      overflow: hidden;
      box-shadow: var(--sh-lg);
    }

    .feature-visual.feature-visual-clean {
      background: transparent;
      border: 0;
      border-radius: 0;
      box-shadow: none;
    }

    .feature-visual img {
      width: 100%;
      display: block;
    }

    .feature-visual-placeholder {
      aspect-ratio: 4/3;
      display: flex;
      align-items: center;
      justify-content: center;
      background: linear-gradient(135deg, var(--c-primary-light) 0%, #DBEAFE 100%);
      color: var(--c-primary);
      font-family: var(--font-display);
      font-size: 14px;
      font-weight: 700;
    }

    /* ── COMPARISON TABLE ────────────────────────── */
    .comparison-intro {
      max-width: 580px;
      margin-bottom: 48px;
    }

    .comparison-table-wrap {
      border-radius: var(--r-xl);
      overflow: hidden;
      border: 1.5px solid var(--c-border);
      box-shadow: var(--sh-md);
    }

    .comparison-table {
      width: 100%;
      border-collapse: collapse;
    }

    .comparison-table thead tr {
      background: var(--c-navy);
    }

    .comparison-table thead th {
      padding: 18px 24px;
      text-align: left;
      font-family: var(--font-display);
      font-size: 13.5px;
      font-weight: 700;
      color: rgba(255, 255, 255, 0.70);
      letter-spacing: .02em;
      white-space: nowrap;
    }

    .comparison-table thead th.col-with {
      color: #86EFAC;
    }

    .comparison-table thead th.col-icon {
      width: 52px;
      text-align: center;
    }

    .comparison-table tbody tr {
      border-bottom: 1px solid var(--c-border);
      background: var(--c-white);
      transition: background var(--t);
    }

    .comparison-table tbody tr:last-child {
      border-bottom: none;
    }

    .comparison-table tbody tr:hover {
      background: var(--c-bg);
    }

    .comparison-table td {
      padding: 16px 24px;
      vertical-align: middle;
    }

    .td-icon {
      text-align: center;
      padding: 16px 12px;
    }

    .td-icon-inner {
      width: 36px;
      height: 36px;
      border-radius: var(--r-sm);
      background: var(--c-primary-light);
      display: flex;
      align-items: center;
      justify-content: center;
      margin: 0 auto;
    }

    .td-area {
      font-size: 14px;
      font-weight: 700;
      color: var(--c-navy-mid);
    }

    .td-without {
      font-size: 13px;
      color: var(--c-muted);
      background: #FFFBFB;
      text-decoration: line-through;
      text-decoration-color: rgba(220, 38, 38, 0.35);
    }

    .td-with {
      font-size: 13px;
      color: #065F46;
      font-weight: 500;
      background: #F0FDF9;
    }

    /* ── TESTIMONIALS ────────────────────────────── */
    .testimonials-header {
      max-width: 520px;
      margin-bottom: 48px;
    }

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

    .testimonial-card {
      background: var(--c-white);
      border: 1.5px solid var(--c-border);
      border-radius: var(--r-xl);
      padding: 28px 26px;
      position: relative;
      box-shadow: var(--sh-sm);
    }

    .testimonial-card.placeholder-card {
      border-style: dashed;
      border-color: rgba(37, 99, 235, 0.25);
      background: var(--c-primary-light);
    }

    .quote-mark {
      font-family: Georgia, serif;
      font-size: 64px;
      line-height: 0.7;
      color: var(--c-primary-light);
      margin-bottom: 16px;
      display: block;
    }

    .testimonial-card.placeholder-card .quote-mark {
      color: rgba(37, 99, 235, 0.20);
    }

    .testimonial-text {
      font-size: 15px;
      line-height: 1.65;
      color: var(--c-body);
      margin-bottom: 22px;
      font-style: italic;
    }

    .placeholder-card .testimonial-text {
      color: var(--c-muted);
      font-style: normal;
      font-size: 13.5px;
      border: 2px dashed rgba(37, 99, 235, 0.20);
      border-radius: var(--r);
      padding: 14px;
      background: rgba(255, 255, 255, 0.60);
    }

    .testimonial-author {
      display: flex;
      align-items: center;
      gap: 12px;
    }

    .testimonial-avatar {
      width: 44px;
      height: 44px;
      border-radius: 50%;
      background: var(--c-border);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 18px;
      flex-shrink: 0;
    }

    .placeholder-card .testimonial-avatar {
      background: rgba(37, 99, 235, 0.10);
      font-size: 22px;
    }

    .testimonial-name {
      font-size: 14px;
      font-weight: 700;
      color: var(--c-navy-mid);
    }

    .testimonial-role {
      font-size: 12.5px;
      color: var(--c-muted);
    }

    .placeholder-note {
      font-size: 11.5px;
      font-weight: 700;
      color: var(--c-primary);
      background: #DBEAFE;
      padding: 4px 10px;
      border-radius: 100px;
      margin-top: 8px;
      display: inline-block;
    }

    /* ── COMPLIANCE / TRUST ──────────────────────── */
    .compliance-section {
      background: var(--c-navy);
    }

    .compliance-header {
      text-align: center;
      margin-bottom: 56px;
    }

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

    .compliance-card {
      background: rgba(255, 255, 255, 0.05);
      border: 1px solid rgba(255, 255, 255, 0.10);
      border-radius: var(--r-lg);
      padding: 28px 24px;
      transition: background var(--t), border-color var(--t);
    }

    .compliance-card:hover {
      background: rgba(255, 255, 255, 0.08);
      border-color: rgba(37, 99, 235, 0.40);
    }

    .compliance-icon {
      width: 48px;
      height: 48px;
      background: rgba(37, 99, 235, 0.25);
      border-radius: 12px;
      display: flex;
      align-items: center;
      justify-content: center;
      margin-bottom: 16px;
    }

    .compliance-card h4 {
      font-family: var(--font-display);
      font-size: 15px;
      font-weight: 700;
      color: #fff;
      margin-bottom: 6px;
    }

    .compliance-card p {
      font-size: 13px;
      color: rgba(255, 255, 255, 0.55);
      line-height: 1.55;
    }

    /* ── APP DOWNLOAD ────────────────────────────── */
    .app-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 72px;
      align-items: center;
    }

    .app-badges {
      display: flex;
      gap: 14px;
      flex-wrap: wrap;
      margin-top: 28px;
    }

    .app-badges a {
      transition: transform var(--t), box-shadow var(--t);
      border-radius: 10px;
    }

    .app-badges a:hover {
      transform: translateY(-2px);
      box-shadow: var(--sh-md);
    }

    .app-badges img {
      height: 48px;
      width: auto;
      border-radius: 10px;
    }

    .app-features {
      display: flex;
      flex-direction: column;
      gap: 14px;
      margin-top: 24px;
    }

    .app-feat {
      display: flex;
      align-items: center;
      gap: 12px;
      font-size: 14.5px;
      color: var(--c-slate);
      font-weight: 500;
    }

    .app-feat svg {
      flex-shrink: 0;
      color: var(--c-green);
    }

    /* ── FAQ ─────────────────────────────────────── */
    .faq-grid {
      display: grid;
      grid-template-columns: 340px 1fr;
      gap: 64px;
      align-items: start;
    }

    .faq-sidebar h3 {
      font-family: var(--font-display);
      font-size: 26px;
      font-weight: 800;
      color: var(--c-navy);
      margin-bottom: 12px;
      letter-spacing: -0.02em;
    }

    .faq-sidebar p {
      font-size: 15px;
      color: var(--c-muted);
      line-height: 1.6;
      margin-bottom: 24px;
    }

    .faq-contact {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-size: 14px;
      font-weight: 700;
      color: var(--c-primary);
      transition: gap var(--t);
    }

    .faq-contact:hover {
      gap: 12px;
    }

    .faq-list {
      display: flex;
      flex-direction: column;
      gap: 0;
    }

    .faq-item {
      border-bottom: 1px solid var(--c-border);
    }

    .faq-item:first-child {
      border-top: 1px solid var(--c-border);
    }

    .faq-question {
      width: 100%;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
      padding: 20px 0;
      text-align: left;
      font-size: 15.5px;
      font-weight: 600;
      color: var(--c-navy-mid);
      background: none;
      cursor: pointer;
      transition: color var(--t);
    }

    .faq-question:hover {
      color: var(--c-primary);
    }

    .faq-question svg {
      flex-shrink: 0;
      transition: transform var(--t);
      color: var(--c-subtle);
    }

    .faq-item.open .faq-question {
      color: var(--c-primary);
    }

    .faq-item.open .faq-question svg {
      transform: rotate(180deg);
      color: var(--c-primary);
    }

    .faq-answer {
      overflow: hidden;
      max-height: 0;
      transition: max-height 0.35s cubic-bezier(0.4, 0, 0.2, 1);
    }

    .faq-answer-inner {
      padding: 0 0 22px;
      font-size: 15px;
      color: var(--c-muted);
      line-height: 1.70;
    }

    /* ── FINAL CTA ───────────────────────────────── */
    .final-cta {
      background: linear-gradient(135deg, #1D4ED8 0%, var(--c-primary) 50%, #0284C7 100%);
      text-align: center;
      padding: 100px 0;
      position: relative;
      overflow: hidden;
    }

    .final-cta::before {
      content: '';
      position: absolute;
      inset: 0;
      background-image: radial-gradient(rgba(255, 255, 255, 0.07) 1px, transparent 1px);
      background-size: 28px 28px;
    }

    .final-cta h2 {
      font-family: var(--font-display);
      font-size: clamp(30px, 4vw, 48px);
      font-weight: 800;
      color: #fff;
      letter-spacing: -0.025em;
      line-height: 1.1;
      margin-bottom: 16px;
      position: relative;
    }

    .final-cta p {
      font-size: 18px;
      color: rgba(255, 255, 255, 0.75);
      max-width: 500px;
      margin: 0 auto 40px;
      line-height: 1.6;
      position: relative;
    }

    .final-ctas {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 16px;
      flex-wrap: wrap;
      position: relative;
    }

    .btn-cta-white {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-family: var(--font-body);
      font-size: 15px;
      font-weight: 800;
      color: var(--c-primary);
      background: var(--c-white);
      padding: 16px 32px;
      border-radius: var(--r);
      transition: all var(--t);
      box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
    }

    .btn-cta-white:hover {
      transform: translateY(-2px);
      box-shadow: 0 8px 32px rgba(0, 0, 0, 0.20);
    }

    .btn-cta-wa {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-family: var(--font-body);
      font-size: 15px;
      font-weight: 700;
      color: #fff;
      background: rgba(255, 255, 255, 0.15);
      border: 1.5px solid rgba(255, 255, 255, 0.35);
      padding: 15px 28px;
      border-radius: var(--r);
      transition: all var(--t);
    }

    .btn-cta-wa:hover {
      background: rgba(255, 255, 255, 0.22);
      border-color: rgba(255, 255, 255, 0.55);
    }

    /* ── FOOTER ──────────────────────────────────── */
    .footer {
      background: var(--c-navy);
      padding: 64px 0 32px;
    }

    .footer-grid {
      display: grid;
      grid-template-columns: 1.8fr 1fr 1fr 1fr;
      gap: 48px;
      padding-bottom: 48px;
      border-bottom: 1px solid rgba(255, 255, 255, 0.10);
      margin-bottom: 32px;
    }

    .footer-logo img {
      height: 32px;
      width: auto;
      margin-bottom: 16px;
      filter: brightness(0) invert(1);
    }

    .footer-tagline {
      font-size: 14px;
      color: rgba(255, 255, 255, 0.50);
      line-height: 1.6;
      max-width: 240px;
      margin-bottom: 20px;
    }

    .footer-social {
      display: flex;
      gap: 10px;
    }

    .footer-social-link {
      width: 36px;
      height: 36px;
      background: rgba(255, 255, 255, 0.08);
      border-radius: 8px;
      display: flex;
      align-items: center;
      justify-content: center;
      color: rgba(255, 255, 255, 0.60);
      transition: all var(--t);
      font-size: 14px;
    }

    .footer-social-link:hover {
      background: var(--c-primary);
      color: #fff;
    }

    .footer-col h5 {
      font-family: var(--font-display);
      font-size: 13px;
      font-weight: 700;
      color: rgba(255, 255, 255, 0.85);
      letter-spacing: .04em;
      text-transform: uppercase;
      margin-bottom: 16px;
    }

    .footer-col ul {
      display: flex;
      flex-direction: column;
      gap: 10px;
    }

    .footer-col ul li a {
      font-size: 14px;
      color: rgba(255, 255, 255, 0.50);
      transition: color var(--t);
    }

    .footer-col ul li a:hover {
      color: rgba(255, 255, 255, 0.90);
    }

    .footer-bottom {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
      flex-wrap: wrap;
    }

    .footer-bottom p {
      font-size: 13px;
      color: rgba(255, 255, 255, 0.35);
    }

    .footer-bottom a {
      color: rgba(255, 255, 255, 0.50);
      transition: color var(--t);
    }

    .footer-bottom a:hover {
      color: rgba(255, 255, 255, 0.85);
    }

    .footer-contact {
      display: flex;
      gap: 24px;
      flex-wrap: wrap;
    }

    .footer-contact a {
      display: flex;
      align-items: center;
      gap: 7px;
      font-size: 13px;
      color: rgba(255, 255, 255, 0.50);
      transition: color var(--t);
    }

    .footer-contact a:hover {
      color: rgba(255, 255, 255, 0.85);
    }

    /* ── DEMO MODAL ──────────────────────────────── */
    .modal-overlay {
      position: fixed;
      inset: 0;
      background: rgba(15, 23, 42, 0.70);
      backdrop-filter: blur(6px);
      -webkit-backdrop-filter: blur(6px);
      z-index: 9000;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 20px;
      opacity: 0;
      pointer-events: none;
      transition: opacity 0.25s ease;
    }

    .modal-overlay.open {
      opacity: 1;
      pointer-events: all;
    }

    .modal-box {
      background: var(--c-white);
      border-radius: var(--r-xl);
      width: 100%;
      max-width: 560px;
      overflow: hidden;
      box-shadow: var(--sh-lg), 0 0 0 1px rgba(255, 255, 255, 0.10);
      transform: translateY(20px) scale(0.97);
      transition: transform 0.25s ease;
    }

    .modal-overlay.open .modal-box {
      transform: translateY(0) scale(1);
    }

    .modal-header {
      background: linear-gradient(135deg, var(--c-navy) 0%, var(--c-navy-mid) 100%);
      padding: 28px 32px 24px;
      position: relative;
    }

    .modal-header h2 {
      font-family: var(--font-display);
      font-size: 22px;
      font-weight: 800;
      color: #fff;
      margin-bottom: 6px;
      letter-spacing: -0.02em;
    }

    .modal-header p {
      font-size: 14px;
      color: rgba(255, 255, 255, 0.60);
      line-height: 1.5;
    }

    .modal-close {
      position: absolute;
      top: 16px;
      right: 20px;
      color: rgba(255, 255, 255, 0.50);
      font-size: 22px;
      line-height: 1;
      cursor: pointer;
      transition: color var(--t);
      background: none;
      border: none;
      font-family: inherit;
    }

    .modal-close:hover {
      color: #fff;
    }

    .modal-body {
      padding: 28px 32px 32px;
    }

    .modal-option-row {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 12px;
      margin-bottom: 24px;
    }

    .modal-option {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 8px;
      padding: 20px 16px;
      border-radius: var(--r-lg);
      border: 2px solid var(--c-border);
      cursor: pointer;
      text-align: center;
      transition: all var(--t);
    }

    .modal-option:hover {
      border-color: var(--c-primary);
      background: var(--c-primary-light);
    }

    .modal-option.option-wa:hover {
      border-color: #25D366;
      background: #F0FDF4;
    }

    .modal-option-icon {
      width: 48px;
      height: 48px;
      border-radius: 14px;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 24px;
    }

    .modal-option .opt-title {
      font-size: 14px;
      font-weight: 700;
      color: var(--c-navy-mid);
    }

    .modal-option .opt-sub {
      font-size: 12px;
      color: var(--c-muted);
    }

    .modal-divider {
      display: flex;
      align-items: center;
      gap: 12px;
      color: var(--c-subtle);
      font-size: 12px;
      font-weight: 600;
      letter-spacing: .05em;
      text-transform: uppercase;
      margin-bottom: 22px;
    }

    .modal-divider::before,
    .modal-divider::after {
      content: '';
      flex: 1;
      height: 1px;
      background: var(--c-border);
    }

    .modal-form {
      display: flex;
      flex-direction: column;
      gap: 14px;
    }

    .form-row {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 12px;
    }

    .form-field {
      display: flex;
      flex-direction: column;
      gap: 5px;
    }

    .form-field label {
      font-size: 12.5px;
      font-weight: 700;
      color: var(--c-slate);
      letter-spacing: .02em;
    }

    .form-field input,
    .form-field select {
      font-family: var(--font-body);
      font-size: 14px;
      color: var(--c-body);
      background: var(--c-bg);
      border: 1.5px solid var(--c-border);
      border-radius: var(--r);
      padding: 11px 14px;
      outline: none;
      transition: border-color var(--t), box-shadow var(--t);
      width: 100%;
    }

    .form-field input::placeholder {
      color: var(--c-subtle);
    }

    .form-field input:focus,
    .form-field select:focus {
      border-color: var(--c-primary);
      box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
    }

    .btn-form-submit {
      font-family: var(--font-body);
      font-size: 15px;
      font-weight: 800;
      color: #fff;
      background: var(--c-primary);
      padding: 14px 24px;
      border-radius: var(--r);
      border: none;
      cursor: pointer;
      width: 100%;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      transition: all var(--t);
      margin-top: 4px;
    }

    .btn-form-submit:hover {
      background: var(--c-primary-dark);
      transform: translateY(-1px);
      box-shadow: var(--sh-blue);
    }

    .modal-thanks {
      display: none;
      text-align: center;
      padding: 32px;
    }

    .modal-thanks-icon {
      width: 64px;
      height: 64px;
      background: var(--c-green-light);
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      margin: 0 auto 18px;
      font-size: 32px;
    }

    .modal-thanks h3 {
      font-family: var(--font-display);
      font-size: 22px;
      font-weight: 800;
      color: var(--c-navy);
      margin-bottom: 8px;
    }

    .modal-thanks p {
      font-size: 15px;
      color: var(--c-muted);
      line-height: 1.6;
    }

    /* ── MOBILE MENU ─────────────────────────────── */
    .mobile-menu {
      display: none;
      flex-direction: column;
      background: var(--c-navy);
      padding: 20px 24px 28px;
      border-top: 1px solid rgba(255, 255, 255, 0.10);
    }

    .mobile-menu.open {
      display: flex;
    }

    .mobile-menu a {
      font-size: 15px;
      font-weight: 500;
      color: rgba(255, 255, 255, 0.80);
      padding: 12px 0;
      border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    }

    .mobile-menu a:last-child {
      border-bottom: none;
    }

    .mobile-menu-group {
      border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    }

    .mobile-menu-group summary {
      list-style: none;
      font-size: 15px;
      font-weight: 500;
      color: rgba(255, 255, 255, 0.80);
      padding: 12px 0;
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
    }

    .mobile-menu-group summary::-webkit-details-marker {
      display: none;
    }

    .mobile-menu-group summary::after {
      content: '';
      width: 0.42em;
      height: 0.42em;
      border-right: 2px solid rgba(255, 255, 255, 0.45);
      border-bottom: 2px solid rgba(255, 255, 255, 0.45);
      transform: rotate(45deg);
      flex-shrink: 0;
      transition: transform var(--t);
    }

    .mobile-menu-group[open] summary::after {
      transform: rotate(-135deg);
      margin-top: 4px;
    }

    .mobile-menu-sub a {
      font-size: 14px;
      padding: 10px 0 10px 14px;
      color: rgba(255, 255, 255, 0.72);
      border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    }

    .mobile-menu-sub a:last-child {
      border-bottom: none;
      padding-bottom: 14px;
    }

    /* ── SCROLL FADE IN ──────────────────────────── */
    .fade-up {
      opacity: 0;
      transform: translateY(24px);
      transition: opacity 0.55s ease, transform 0.55s ease;
    }

    .fade-up.visible {
      opacity: 1;
      transform: translateY(0);
    }

    .fade-up.d1 {
      transition-delay: 0.08s;
    }

    .fade-up.d2 {
      transition-delay: 0.16s;
    }

    .fade-up.d3 {
      transition-delay: 0.24s;
    }

    .fade-up.d4 {
      transition-delay: 0.32s;
    }

    /* ── RESPONSIVE ──────────────────────────────── */
    @media (max-width: 1100px) {
      .hero-grid {
        grid-template-columns: 1fr 320px;
        gap: 32px;
      }

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

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

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

    @media (max-width: 900px) {
      :root {
        --pad-section: 64px;
      }

      .hero-grid {
        grid-template-columns: 1fr;
      }

      .admin-panel-hero {
        position: static;
        max-width: 100%;
      }

      .wa-grid,
      .accounting-grid,
      .app-grid {
        grid-template-columns: 1fr;
        gap: 40px;
      }

      .faq-grid {
        grid-template-columns: 1fr;
        gap: 40px;
      }

      .footer-grid {
        grid-template-columns: 1fr 1fr;
        gap: 40px;
      }

      .testimonials-grid {
        grid-template-columns: 1fr;
      }

      .proof-item {
        padding: 10px 18px;
      }
    }

    @media (max-width: 640px) {
      :root {
        --pad-section: 48px;
      }

      .nav-links,
      .nav-ctas {
        display: none;
      }

      .nav-hamburger {
        display: flex;
      }

      .module-grid {
        grid-template-columns: 1fr;
      }

      .problem-grid {
        grid-template-columns: 1fr;
      }

      .compliance-grid {
        grid-template-columns: 1fr;
      }

      .footer-grid {
        grid-template-columns: 1fr;
      }

      .modal-option-row {
        grid-template-columns: 1fr;
      }

      .form-row {
        grid-template-columns: 1fr;
      }

      .proof-inner {
        flex-direction: column;
      }

      .proof-item {
        border-right: none;
        border-bottom: 1px solid var(--c-border);
        width: 100%;
        justify-content: center;
      }

      .proof-item:last-child {
        border-bottom: none;
      }

      .comparison-table td,
      .comparison-table th {
        padding: 12px 14px;
        font-size: 12px;
      }
    }

/* ----- pqrs.html ----- */
/* ANN BAR */
.ann-bar{background:var(--c-navy-mid);color:#fff;padding:10px 24px;font-size:13.5px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:12px;position:relative}
.ann-bar a{color:#6EE7B7;text-decoration:underline;text-underline-offset:2px}
.ann-badge{background:var(--c-green);color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:2px 8px;border-radius:4px;white-space:nowrap}
.ann-close{position:absolute;right:20px;top:50%;transform:translateY(-50%);color:var(--c-subtle);font-size:18px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.ann-close:hover{color:#fff}

/* NAV */
.nav{position:sticky;top:0;z-index:900;background:rgba(255,255,255,0.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--c-border);box-shadow:0 1px 3px rgba(15,23,42,0.06)}
.nav-inner{max-width:var(--w-max);margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;gap:32px}
.nav-logo img{height:34px;width:auto}
.nav-links{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--c-slate);padding:8px 14px;border-radius:var(--r-sm);transition:color var(--t),background var(--t)}
.nav-links a:hover{color:var(--c-primary);background:var(--c-primary-light)}
.nav-links a.active{color:var(--c-primary);font-weight:700}
.nav-ctas{display:flex;align-items:center;gap:10px;margin-left:12px}
.btn-nav-login{font-size:14px;font-weight:600;color:var(--c-slate);padding:8px 16px;border-radius:var(--r-sm);border:1px solid var(--c-border);transition:all var(--t)}
.btn-nav-login:hover{color:var(--c-primary);border-color:var(--c-primary);background:var(--c-primary-light)}
.btn-nav-demo{font-size:14px;font-weight:700;color:#fff;background:var(--c-primary);padding:9px 20px;border-radius:var(--r-sm);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-nav-demo:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;margin-left:auto}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--c-navy-mid);border-radius:2px}
.mobile-menu{display:none;flex-direction:column;background:var(--c-white);padding:16px 24px 24px;border-top:1px solid var(--c-border)}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:15px;font-weight:500;color:var(--c-slate);padding:12px 0;border-bottom:1px solid var(--c-border)}
.mobile-menu a:last-child{border-bottom:none}

/* BREADCRUMB */
.breadcrumb-bar{background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:10px 0}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--c-muted)}
.breadcrumb a{color:var(--c-muted);transition:color var(--t)}
.breadcrumb a:hover{color:var(--c-primary)}
.breadcrumb-sep{color:var(--c-subtle);font-size:11px}
.breadcrumb-current{color:var(--c-slate);font-weight:600}

/* ── HERO ─────────────────────────────────────── */
.pqrs-hero{
  background:var(--c-navy);
  background-image:
    radial-gradient(ellipse 55% 70% at 20% 50%, rgba(5,150,105,0.15) 0%, transparent 55%),
    radial-gradient(ellipse 40% 50% at 80% 20%, rgba(37,99,235,0.08) 0%, transparent 50%);
  padding:72px 0 80px;
  overflow:hidden;
  position:relative;
}
.pqrs-hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.04) 1px,transparent 1px);background-size:32px 32px;pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1fr 420px;gap:64px;align-items:start;position:relative}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(5,150,105,0.18);border:1px solid rgba(5,150,105,0.35);color:#6EE7B7;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 14px;border-radius:100px;margin-bottom:22px}
.hero-tag-dot{width:6px;height:6px;border-radius:50%;background:#34D399;animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.75)}}
.pqrs-hero h1{font-family:var(--font-display);font-size:clamp(32px,4.2vw,50px);font-weight:800;line-height:1.1;letter-spacing:-0.03em;color:#fff;margin-bottom:20px}
.pqrs-hero h1 em{font-style:normal;color:#34D399}
.pqrs-hero .sub{font-size:17.5px;line-height:1.65;color:rgba(255,255,255,0.65);max-width:500px;margin-bottom:36px}
.pqrs-hero .sub strong{color:rgba(255,255,255,0.90);font-weight:600}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:36px}
.btn-primary{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:700;color:#fff;background:var(--c-green);padding:14px 28px;border-radius:var(--r);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-primary:hover{background:var(--c-green-dark);transform:translateY(-2px);box-shadow:var(--sh-green)}
.btn-outline{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:600;color:rgba(255,255,255,0.80);background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.18);padding:14px 24px;border-radius:var(--r);transition:all var(--t)}
.btn-outline:hover{background:rgba(255,255,255,0.14);color:#fff;border-color:rgba(255,255,255,0.35)}
.hero-signals{display:flex;flex-direction:column;gap:9px}
.hero-signal{display:flex;align-items:center;gap:9px;font-size:13.5px;color:rgba(255,255,255,0.55)}
.hero-signal svg{flex-shrink:0;color:#4ADE80}

/* ── PQRS BOARD MOCKUP ────────────────────────── */
.pqrs-board{
  background:var(--c-bg);
  border-radius:var(--r-xl);
  overflow:hidden;
  box-shadow:0 24px 64px rgba(0,0,0,0.40),0 4px 16px rgba(5,150,105,0.15);
  border:1px solid rgba(255,255,255,0.10);
}
.pb-header{
  background:var(--c-navy-mid);
  padding:13px 18px;
  display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.pb-title-row{display:flex;align-items:center;gap:10px}
.pb-icon{width:28px;height:28px;background:rgba(5,150,105,0.25);border:1px solid rgba(5,150,105,0.40);border-radius:7px;display:flex;align-items:center;justify-content:center}
.pb-name{font-family:var(--font-display);font-size:12.5px;font-weight:700;color:#fff}
.pb-sub{font-size:10.5px;color:rgba(255,255,255,0.40);margin-top:1px}
.pb-count{font-size:11px;font-weight:700;color:#6EE7B7;background:rgba(5,150,105,0.18);border:1px solid rgba(5,150,105,0.28);padding:2px 9px;border-radius:100px}
.pb-body{padding:14px;display:grid;grid-template-columns:repeat(3,1fr);gap:10px}

/* Column */
.pb-col{}
.pb-col-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:7px 10px;
  border-radius:var(--r-sm);
  margin-bottom:8px;
  font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
}
.pb-col-header.col-new{background:rgba(37,99,235,0.12);color:#93C5FD}
.pb-col-header.col-wip{background:rgba(217,119,6,0.12);color:#FCD34D}
.pb-col-header.col-done{background:rgba(5,150,105,0.12);color:#6EE7B7}
.pb-badge{width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800}
.pb-badge.new{background:rgba(37,99,235,0.25);color:#93C5FD}
.pb-badge.wip{background:rgba(217,119,6,0.25);color:#FCD34D}
.pb-badge.done{background:rgba(5,150,105,0.25);color:#6EE7B7}

/* PQRS Cards */
.pb-card{
  background:var(--c-white);
  border:1px solid var(--c-border);
  border-radius:var(--r);
  padding:10px 11px;
  margin-bottom:7px;
  transition:box-shadow var(--t),transform var(--t);
  cursor:pointer;
}
.pb-card:hover{box-shadow:var(--sh-sm);transform:translateY(-1px)}
.pb-card:last-child{margin-bottom:0}
.pb-card-type{font-size:9.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:5px;display:flex;align-items:center;gap:4px}
.pb-card-desc{font-size:11.5px;font-weight:600;color:var(--c-navy-mid);line-height:1.35;margin-bottom:6px}
.pb-card-meta{display:flex;align-items:center;justify-content:space-between}
.pb-card-unit{font-size:10px;color:var(--c-muted)}
.pb-card-time{font-size:10px;color:var(--c-subtle)}
.pb-card-notif{
  display:flex;align-items:center;gap:3px;
  font-size:9.5px;font-weight:600;
  color:var(--c-green);
  background:var(--c-green-light);
  padding:1.5px 6px;border-radius:3px;
  margin-top:5px;
}

/* ── PROOF STRIP ──────────────────────────────── */
.proof-strip{background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:18px 0}
.proof-inner{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}
.proof-item{display:flex;align-items:center;gap:10px;padding:10px 28px;border-right:1px solid var(--c-border)}
.proof-item:last-child{border-right:none}
.proof-icon{width:34px;height:34px;background:var(--c-green-light);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.proof-text-main{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.proof-text-sub{font-size:11.5px;color:var(--c-muted)}

/* ── SECTIONS ─────────────────────────────────── */
.section{padding:88px 0}
.section-alt{background:var(--c-bg)}
.section-navy{background:var(--c-navy)}
.section-eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--c-green);margin-bottom:14px}
.section-eyebrow-bar{width:24px;height:2px;background:var(--c-green);border-radius:2px}
.section-h2{font-family:var(--font-display);font-size:clamp(26px,3vw,38px);font-weight:800;line-height:1.15;letter-spacing:-0.025em;color:var(--c-navy);margin-bottom:14px}
.section-h2.light{color:#fff}
.section-sub{font-size:17px;line-height:1.65;color:var(--c-muted);max-width:560px}
.section-sub.light{color:rgba(255,255,255,.68)}

/* ── PROBLEM / SOLUTION ───────────────────────── */
.ps-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:52px}
.ps-card{border-radius:var(--r-xl);overflow:hidden;border:1.5px solid var(--c-border)}
.ps-card.before{background:#FFFAFA;border-color:rgba(220,38,38,.20)}
.ps-card.after{background:var(--c-green-light);border-color:rgba(5,150,105,.25)}
.ps-header{padding:16px 22px;border-bottom:1px solid var(--c-border);display:flex;align-items:center;gap:10px}
.ps-header.before{background:rgba(220,38,38,.05)}
.ps-header.after{background:rgba(5,150,105,.07)}
.ps-label{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.ps-label.before{color:#DC2626}
.ps-label.after{color:var(--c-green)}
.ps-body{padding:20px 22px;display:flex;flex-direction:column;gap:12px}
.ps-item{display:flex;align-items:flex-start;gap:10px;font-size:14px;line-height:1.50;color:var(--c-body)}
.ps-dot{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;font-size:11px}
.ps-dot.bad{background:#FEF2F2;color:#DC2626}
.ps-dot.good{background:var(--c-green-light);color:var(--c-green)}

/* ── STATES FLOW ──────────────────────────────── */
.states-section{padding:88px 0;background:var(--c-navy)}
.states-flow{display:grid;grid-template-columns:1fr 40px 1fr 40px 1fr;gap:0;align-items:center;margin-top:52px}
.state-card{
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.10);
  border-radius:var(--r-xl);
  padding:28px 22px;
  text-align:center;
  transition:background var(--t);
}
.state-card:hover{background:rgba(255,255,255,0.10)}
.state-num{
  width:52px;height:52px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:22px;font-weight:800;
  margin:0 auto 16px;
}
.state-num.s1{background:rgba(37,99,235,0.20);color:#93C5FD}
.state-num.s2{background:rgba(217,119,6,0.20);color:#FCD34D}
.state-num.s3{background:rgba(5,150,105,0.20);color:#6EE7B7}
.state-name{font-family:var(--font-display);font-size:18px;font-weight:800;color:#fff;margin-bottom:8px}
.state-desc{font-size:13.5px;color:rgba(255,255,255,0.55);line-height:1.55}
.state-notif{
  display:inline-flex;align-items:center;gap:5px;
  font-size:11px;font-weight:700;
  background:rgba(74,222,128,0.12);border:1px solid rgba(74,222,128,0.22);
  color:#4ADE80;padding:3px 10px;border-radius:100px;
  margin-top:12px;
}
.state-arrow{display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.20);font-size:22px}

/* ── FEATURES ─────────────────────────────────── */
.features-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:48px}
.feature-card{
  background:var(--c-white);border:1.5px solid var(--c-border);
  border-radius:var(--r-lg);padding:26px 22px;
  border-left:4px solid var(--c-green);
  transition:box-shadow var(--t),transform var(--t);
}
.feature-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}
.feature-icon{width:44px;height:44px;background:var(--c-green-light);border-radius:11px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.feature-card h4{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--c-navy-mid);margin-bottom:7px}
.feature-card p{font-size:14px;color:var(--c-muted);line-height:1.55}

/* ── INTEGRATION ──────────────────────────────── */
.integ-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:44px}
.integ-card{
  background:var(--c-white);border:1.5px solid var(--c-border);
  border-radius:var(--r-lg);padding:24px 20px;
  display:flex;align-items:flex-start;gap:14px;
  transition:border-color var(--t),box-shadow var(--t);
}
.integ-card:hover{border-color:rgba(5,150,105,0.35);box-shadow:var(--sh-sm)}
.integ-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.integ-title{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--c-navy-mid);margin-bottom:5px}
.integ-desc{font-size:13.5px;color:var(--c-muted);line-height:1.55}

/* ── FAQ ──────────────────────────────────────── */
.faq-grid{display:grid;grid-template-columns:300px 1fr;gap:64px;align-items:start}
.faq-sidebar h3{font-family:var(--font-display);font-size:24px;font-weight:800;color:var(--c-navy);margin-bottom:12px;letter-spacing:-0.02em}
.faq-sidebar p{font-size:15px;color:var(--c-muted);line-height:1.6;margin-bottom:22px}
.faq-contact{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--c-green);transition:gap var(--t)}
.faq-contact:hover{gap:12px}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--c-border)}
.faq-item:first-child{border-top:1px solid var(--c-border)}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0;text-align:left;font-size:15px;font-weight:600;color:var(--c-navy-mid);background:none;cursor:pointer;transition:color var(--t)}
.faq-question:hover,.faq-item.open .faq-question{color:var(--c-green)}
.faq-question svg{flex-shrink:0;transition:transform var(--t);color:var(--c-subtle)}
.faq-item.open .faq-question svg{transform:rotate(180deg);color:var(--c-green)}
.faq-answer{overflow:hidden;max-height:0;transition:max-height 0.35s cubic-bezier(0.4,0,0.2,1)}
.faq-answer-inner{padding:0 0 22px;font-size:15px;color:var(--c-muted);line-height:1.70}

/* ── FINAL CTA ────────────────────────────────── */
.final-cta{background:linear-gradient(135deg,#047857 0%,var(--c-green) 50%,#10B981 100%);text-align:center;padding:96px 0;position:relative;overflow:hidden}
.final-cta::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.07) 1px,transparent 1px);background-size:28px 28px}
.final-cta h2{font-family:var(--font-display);font-size:clamp(28px,4vw,44px);font-weight:800;color:#fff;letter-spacing:-0.025em;line-height:1.1;margin-bottom:14px;position:relative}
.final-cta p{font-size:17px;color:rgba(255,255,255,0.75);max-width:480px;margin:0 auto 36px;line-height:1.6;position:relative}
.final-ctas{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;position:relative}
.btn-cta-white{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:800;color:var(--c-green);background:#fff;padding:16px 32px;border-radius:var(--r);transition:all var(--t);box-shadow:0 4px 20px rgba(0,0,0,0.15)}
.btn-cta-white:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,0.20)}
.btn-cta-wa{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:700;color:#fff;background:rgba(255,255,255,0.15);border:1.5px solid rgba(255,255,255,0.35);padding:15px 28px;border-radius:var(--r);transition:all var(--t)}
.btn-cta-wa:hover{background:rgba(255,255,255,0.22);border-color:rgba(255,255,255,0.55)}

/* FOOTER */
/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,0.70);backdrop-filter:blur(6px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity 0.25s ease}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{background:var(--c-white);border-radius:var(--r-xl);width:100%;max-width:560px;overflow:hidden;box-shadow:var(--sh-lg);transform:translateY(20px) scale(0.97);transition:transform 0.25s ease}
.modal-overlay.open .modal-box{transform:translateY(0) scale(1)}
.modal-header{background:linear-gradient(135deg,var(--c-navy) 0%,var(--c-navy-mid) 100%);padding:28px 32px 24px;position:relative}
.modal-header h2{font-family:var(--font-display);font-size:22px;font-weight:800;color:#fff;margin-bottom:6px;letter-spacing:-0.02em}
.modal-header p{font-size:14px;color:rgba(255,255,255,0.60)}
.modal-close{position:absolute;top:16px;right:20px;color:rgba(255,255,255,0.50);font-size:22px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.modal-close:hover{color:#fff}
.modal-body{padding:28px 32px 32px}
.modal-option-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:22px}
.modal-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 14px;border-radius:var(--r-lg);border:2px solid var(--c-border);cursor:pointer;text-align:center;transition:all var(--t);text-decoration:none;color:inherit}
.modal-option:hover{border-color:var(--c-green);background:var(--c-green-light)}
.modal-option.option-wa:hover{border-color:#25D366;background:#F0FDF4}
.modal-option-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px}
.opt-title{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.opt-sub{font-size:12px;color:var(--c-muted)}
.modal-divider{display:flex;align-items:center;gap:12px;color:var(--c-subtle);font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:20px}
.modal-divider::before,.modal-divider::after{content:'';flex:1;height:1px;background:var(--c-border)}
.modal-form{display:flex;flex-direction:column;gap:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-field{display:flex;flex-direction:column;gap:5px}
.form-field label{font-size:12.5px;font-weight:700;color:var(--c-slate);letter-spacing:.02em}
.form-field input,.form-field select{font-family:var(--font-body);font-size:14px;color:var(--c-body);background:var(--c-bg);border:1.5px solid var(--c-border);border-radius:var(--r);padding:11px 14px;outline:none;transition:border-color var(--t),box-shadow var(--t);width:100%}
.form-field input:focus,.form-field select:focus{border-color:var(--c-green);box-shadow:0 0 0 3px rgba(5,150,105,0.12)}
.btn-form-submit{font-family:var(--font-body);font-size:15px;font-weight:800;color:#fff;background:var(--c-green);padding:14px 24px;border-radius:var(--r);border:none;cursor:pointer;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--t);margin-top:4px}
.btn-form-submit:hover{background:var(--c-green-dark);transform:translateY(-1px);box-shadow:var(--sh-green)}
.modal-thanks{display:none;text-align:center;padding:32px}
.modal-thanks-icon{width:64px;height:64px;background:var(--c-green-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-size:32px}

.fade-up{opacity:0;transform:translateY(24px);transition:opacity 0.55s ease,transform 0.55s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up.d1{transition-delay:.08s}.fade-up.d2{transition-delay:.16s}.fade-up.d3{transition-delay:.24s}

@media(max-width:1060px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .ps-grid{grid-template-columns:1fr}
  .states-flow{grid-template-columns:1fr;gap:16px}
  .state-arrow{display:none}
  .features-grid{grid-template-columns:1fr}
  .integ-grid{grid-template-columns:1fr}
  .faq-grid{grid-template-columns:1fr;gap:36px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
}
@media(max-width:640px){
  .nav-links,.nav-ctas{display:none}
  .nav-hamburger{display:flex}
  .pb-body{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .modal-option-row,.form-row{grid-template-columns:1fr}
  .proof-inner{flex-direction:column}
  .proof-item{border-right:none;border-bottom:1px solid var(--c-border);width:100%;justify-content:center}
  .proof-item:last-child{border-bottom:none}
}

/* ----- ecm.html ----- */
/* ANN / NAV / BREADCRUMB — same pattern */
.ann-bar{background:var(--c-navy-mid);color:#fff;padding:10px 24px;font-size:13.5px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:12px;position:relative}
.ann-bar a{color:#A5B4FC;text-decoration:underline;text-underline-offset:2px}
.ann-badge{background:var(--c-indigo);color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:2px 8px;border-radius:4px;white-space:nowrap}
.ann-close{position:absolute;right:20px;top:50%;transform:translateY(-50%);color:var(--c-subtle);font-size:18px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.ann-close:hover{color:#fff}
.nav{position:sticky;top:0;z-index:900;background:rgba(255,255,255,0.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--c-border);box-shadow:0 1px 3px rgba(15,23,42,0.06)}
.nav-inner{max-width:var(--w-max);margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;gap:32px}
.nav-logo img{height:34px;width:auto}
.nav-links{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--c-slate);padding:8px 14px;border-radius:var(--r-sm);transition:color var(--t),background var(--t)}
.nav-links a:hover{color:var(--c-primary);background:var(--c-primary-light)}
.nav-ctas{display:flex;align-items:center;gap:10px;margin-left:12px}
.btn-nav-login{font-size:14px;font-weight:600;color:var(--c-slate);padding:8px 16px;border-radius:var(--r-sm);border:1px solid var(--c-border);transition:all var(--t)}
.btn-nav-login:hover{color:var(--c-primary);border-color:var(--c-primary);background:var(--c-primary-light)}
.btn-nav-demo{font-size:14px;font-weight:700;color:#fff;background:var(--c-primary);padding:9px 20px;border-radius:var(--r-sm);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-nav-demo:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;margin-left:auto}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--c-navy-mid);border-radius:2px}
.mobile-menu{display:none;flex-direction:column;background:var(--c-white);padding:16px 24px 24px;border-top:1px solid var(--c-border)}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:15px;font-weight:500;color:var(--c-slate);padding:12px 0;border-bottom:1px solid var(--c-border)}
.mobile-menu a:last-child{border-bottom:none}
.breadcrumb-bar{background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:10px 0}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--c-muted)}
.breadcrumb a{color:var(--c-muted);transition:color var(--t)}
.breadcrumb a:hover{color:var(--c-primary)}
.breadcrumb-sep{color:var(--c-subtle);font-size:11px}
.breadcrumb-current{color:var(--c-slate);font-weight:600}

/* ── HERO ─────────────────────────────────────── */
.ecm-hero{
  background:var(--c-navy);
  background-image:
    radial-gradient(ellipse 55% 70% at 18% 55%, rgba(79,70,229,0.18) 0%, transparent 55%),
    radial-gradient(ellipse 40% 50% at 80% 20%, rgba(37,99,235,0.08) 0%, transparent 50%);
  padding:72px 0 80px;
  overflow:hidden;
  position:relative;
}
.ecm-hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.04) 1px,transparent 1px);background-size:32px 32px;pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1fr 460px;gap:60px;align-items:start;position:relative}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(79,70,229,0.18);border:1px solid rgba(79,70,229,0.35);color:#A5B4FC;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 14px;border-radius:100px;margin-bottom:22px}
.hero-tag-dot{width:6px;height:6px;border-radius:50%;background:#818CF8;animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.75)}}
.ecm-hero h1{font-family:var(--font-display);font-size:clamp(32px,4.2vw,50px);font-weight:800;line-height:1.1;letter-spacing:-0.03em;color:#fff;margin-bottom:20px}
.ecm-hero h1 em{font-style:normal;color:#818CF8}
.ecm-hero .sub{font-size:17.5px;line-height:1.65;color:rgba(255,255,255,0.65);max-width:500px;margin-bottom:36px}
.ecm-hero .sub strong{color:rgba(255,255,255,0.90);font-weight:600}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:36px}
.btn-primary{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:700;color:#fff;background:var(--c-indigo);padding:14px 28px;border-radius:var(--r);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-primary:hover{background:var(--c-indigo-dark);transform:translateY(-2px);box-shadow:var(--sh-indigo)}
.btn-outline{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:600;color:rgba(255,255,255,0.80);background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.18);padding:14px 24px;border-radius:var(--r);transition:all var(--t)}
.btn-outline:hover{background:rgba(255,255,255,0.14);color:#fff;border-color:rgba(255,255,255,0.35)}
.hero-signals{display:flex;flex-direction:column;gap:9px}
.hero-signal{display:flex;align-items:center;gap:9px;font-size:13.5px;color:rgba(255,255,255,0.55)}
.hero-signal svg{flex-shrink:0;color:#4ADE80}

/* ── ECM PANEL MOCKUP ─────────────────────────── */
.ecm-panel{
  background:var(--c-white);
  border-radius:var(--r-xl);
  overflow:hidden;
  box-shadow:0 24px 64px rgba(0,0,0,0.40),0 4px 16px rgba(79,70,229,0.15);
  border:1px solid rgba(255,255,255,0.10);
}
.ep-header{
  background:var(--c-navy-mid);
  padding:12px 16px;
  display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.ep-id{display:flex;align-items:center;gap:9px}
.ep-icon{width:27px;height:27px;background:rgba(79,70,229,0.25);border:1px solid rgba(79,70,229,0.40);border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:13px}
.ep-name{font-family:var(--font-display);font-size:12px;font-weight:700;color:#fff}
.ep-sub{font-size:10px;color:rgba(255,255,255,0.40);margin-top:1px}
.ep-search{
  display:flex;align-items:center;gap:7px;
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.15);
  border-radius:6px;padding:5px 10px;
  font-size:11px;color:rgba(255,255,255,0.45);
}

/* Unit list */
.ep-unit-list{display:flex;flex-direction:column;gap:0}
.ep-unit{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;
  border-bottom:1px solid var(--c-border);
  cursor:pointer;
  transition:background var(--t);
}
.ep-unit:last-child{border-bottom:none}
.ep-unit:hover{background:var(--c-indigo-light)}
.ep-unit-num{
  width:36px;height:36px;border-radius:9px;
  background:var(--c-indigo-light);
  color:var(--c-indigo);
  font-family:var(--font-display);font-size:13px;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.ep-unit-info{flex:1}
.ep-unit-title{font-size:13px;font-weight:700;color:var(--c-navy-mid)}
.ep-unit-meta{font-size:10.5px;color:var(--c-muted);margin-top:1px}
.ep-unit-docs{display:flex;gap:5px;flex-wrap:wrap}
.ep-doc-chip{
  display:inline-flex;align-items:center;gap:3px;
  font-size:10px;font-weight:600;
  padding:2px 7px;border-radius:3px;white-space:nowrap;
}
.chip-pqrs{background:var(--c-green-light);color:var(--c-green)}
.chip-paz{background:var(--c-indigo-light);color:var(--c-indigo)}
.chip-aut{background:var(--c-amber-light);color:var(--c-amber)}
.chip-fac{background:#F5F3FF;color:#6D28D9}
.ep-unit-arrow{color:var(--c-subtle);font-size:14px}

/* ── PROOF STRIP ──────────────────────────────── */
.proof-strip{background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:18px 0}
.proof-inner{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}
.proof-item{display:flex;align-items:center;gap:10px;padding:10px 28px;border-right:1px solid var(--c-border)}
.proof-item:last-child{border-right:none}
.proof-icon{width:34px;height:34px;background:var(--c-indigo-light);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.proof-text-main{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.proof-text-sub{font-size:11.5px;color:var(--c-muted)}

/* ── SECTIONS ─────────────────────────────────── */
.section{padding:88px 0}
.section-alt{background:var(--c-bg)}
.section-navy{background:var(--c-navy)}
.section-eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--c-indigo);margin-bottom:14px}
.section-eyebrow-bar{width:24px;height:2px;background:var(--c-indigo);border-radius:2px}
.section-h2{font-family:var(--font-display);font-size:clamp(26px,3vw,38px);font-weight:800;line-height:1.15;letter-spacing:-0.025em;color:var(--c-navy);margin-bottom:14px}
.section-h2.light{color:#fff}
.section-sub{font-size:17px;line-height:1.65;color:var(--c-muted);max-width:560px}

/* ── BEFORE/AFTER ─────────────────────────────── */
.ba-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:52px}
.ba-card{border-radius:var(--r-xl);overflow:hidden;border:1.5px solid var(--c-border)}
.ba-card.before{background:#FFFAFA;border-color:rgba(220,38,38,.20)}
.ba-card.after{background:var(--c-indigo-light);border-color:rgba(79,70,229,.20)}
.ba-head{padding:16px 22px;border-bottom:1px solid var(--c-border);display:flex;align-items:center;gap:10px}
.ba-head.before{background:rgba(220,38,38,.05)}
.ba-head.after{background:rgba(79,70,229,.08)}
.ba-label{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.ba-label.before{color:var(--c-red)}
.ba-label.after{color:var(--c-indigo)}
.ba-body{padding:20px 22px;display:flex;flex-direction:column;gap:11px}
.ba-item{display:flex;align-items:flex-start;gap:10px;font-size:14px;line-height:1.50;color:var(--c-body)}
.ba-dot{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;font-size:11px}
.ba-dot.bad{background:var(--c-red-light);color:var(--c-red)}
.ba-dot.good{background:var(--c-green-light);color:var(--c-green)}

/* ── FEATURES ─────────────────────────────────── */
.features-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:48px}
.feature-card{
  background:var(--c-white);border:1.5px solid var(--c-border);
  border-radius:var(--r-lg);padding:26px 22px;
  border-left:4px solid var(--c-indigo);
  transition:box-shadow var(--t),transform var(--t);
}
.feature-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}
.feature-icon{width:44px;height:44px;background:var(--c-indigo-light);border-radius:11px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.feature-card h4{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--c-navy-mid);margin-bottom:7px}
.feature-card p{font-size:14px;color:var(--c-muted);line-height:1.55}

/* ── AUTOMATIC FILING SECTION ─────────────────── */
.autofiling-section{padding:88px 0;background:var(--c-navy)}
.modules-feed{display:flex;flex-direction:column;gap:12px;margin-top:52px;max-width:680px;margin-left:auto;margin-right:auto}
.feed-row{
  display:flex;align-items:center;gap:16px;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.10);
  border-radius:var(--r-lg);
  padding:16px 20px;
  transition:background var(--t);
}
.feed-row:hover{background:rgba(255,255,255,0.10)}
.feed-origin{
  display:flex;align-items:center;gap:10px;
  flex:1;
}
.feed-origin-icon{
  width:36px;height:36px;border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;font-size:17px;
}
.feed-origin-name{font-size:13.5px;font-weight:700;color:#fff}
.feed-origin-doc{font-size:11.5px;color:rgba(255,255,255,0.50);margin-top:1px}
.feed-arrow{
  display:flex;align-items:center;gap:6px;
  font-size:11px;font-weight:700;color:rgba(255,255,255,0.30);
  flex-shrink:0;
}
.feed-destination{
  display:flex;align-items:center;gap:8px;
  background:rgba(79,70,229,0.20);
  border:1px solid rgba(79,70,229,0.30);
  border-radius:var(--r-sm);
  padding:7px 12px;
  flex-shrink:0;
}
.feed-dest-text{font-size:11.5px;font-weight:700;color:#A5B4FC}

/* ── INTEGRATION ──────────────────────────────── */
.integ-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:44px}
.integ-card{
  background:var(--c-white);border:1.5px solid var(--c-border);
  border-radius:var(--r-lg);padding:22px 18px;
  display:flex;align-items:flex-start;gap:14px;
  transition:border-color var(--t),box-shadow var(--t);
}
.integ-card:hover{border-color:rgba(79,70,229,0.35);box-shadow:var(--sh-sm)}
.integ-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.integ-title{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--c-navy-mid);margin-bottom:5px}
.integ-desc{font-size:13.5px;color:var(--c-muted);line-height:1.55}

/* ── FAQ ──────────────────────────────────────── */
.faq-grid{display:grid;grid-template-columns:300px 1fr;gap:64px;align-items:start}
.faq-sidebar h3{font-family:var(--font-display);font-size:24px;font-weight:800;color:var(--c-navy);margin-bottom:12px;letter-spacing:-0.02em}
.faq-sidebar p{font-size:15px;color:var(--c-muted);line-height:1.6;margin-bottom:22px}
.faq-contact{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--c-indigo);transition:gap var(--t)}
.faq-contact:hover{gap:12px}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--c-border)}
.faq-item:first-child{border-top:1px solid var(--c-border)}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0;text-align:left;font-size:15px;font-weight:600;color:var(--c-navy-mid);background:none;cursor:pointer;transition:color var(--t)}
.faq-question:hover,.faq-item.open .faq-question{color:var(--c-indigo)}
.faq-question svg{flex-shrink:0;transition:transform var(--t);color:var(--c-subtle)}
.faq-item.open .faq-question svg{transform:rotate(180deg);color:var(--c-indigo)}
.faq-answer{overflow:hidden;max-height:0;transition:max-height 0.35s cubic-bezier(0.4,0,0.2,1)}
.faq-answer-inner{padding:0 0 22px;font-size:15px;color:var(--c-muted);line-height:1.70}

/* ── FINAL CTA ────────────────────────────────── */
.final-cta{background:linear-gradient(135deg,#312E81 0%,var(--c-indigo) 50%,#6D28D9 100%);text-align:center;padding:96px 0;position:relative;overflow:hidden}
.final-cta::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.07) 1px,transparent 1px);background-size:28px 28px}
.final-cta h2{font-family:var(--font-display);font-size:clamp(28px,4vw,44px);font-weight:800;color:#fff;letter-spacing:-0.025em;line-height:1.1;margin-bottom:14px;position:relative}
.final-cta p{font-size:17px;color:rgba(255,255,255,0.75);max-width:480px;margin:0 auto 36px;line-height:1.6;position:relative}
.final-ctas{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;position:relative}
.btn-cta-white{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:800;color:var(--c-indigo-dark);background:#fff;padding:16px 32px;border-radius:var(--r);transition:all var(--t);box-shadow:0 4px 20px rgba(0,0,0,0.15)}
.btn-cta-white:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,0.20)}
.btn-cta-wa{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:700;color:#fff;background:rgba(255,255,255,0.15);border:1.5px solid rgba(255,255,255,0.35);padding:15px 28px;border-radius:var(--r);transition:all var(--t)}
.btn-cta-wa:hover{background:rgba(255,255,255,0.22);border-color:rgba(255,255,255,0.55)}

/* FOOTER */
/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,0.70);backdrop-filter:blur(6px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity 0.25s ease}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{background:var(--c-white);border-radius:var(--r-xl);width:100%;max-width:560px;overflow:hidden;box-shadow:var(--sh-lg);transform:translateY(20px) scale(0.97);transition:transform 0.25s ease}
.modal-overlay.open .modal-box{transform:translateY(0) scale(1)}
.modal-header{background:linear-gradient(135deg,var(--c-navy) 0%,var(--c-navy-mid) 100%);padding:28px 32px 24px;position:relative}
.modal-header h2{font-family:var(--font-display);font-size:22px;font-weight:800;color:#fff;margin-bottom:6px;letter-spacing:-0.02em}
.modal-header p{font-size:14px;color:rgba(255,255,255,0.60)}
.modal-close{position:absolute;top:16px;right:20px;color:rgba(255,255,255,0.50);font-size:22px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.modal-close:hover{color:#fff}
.modal-body{padding:28px 32px 32px}
.modal-option-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:22px}
.modal-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 14px;border-radius:var(--r-lg);border:2px solid var(--c-border);cursor:pointer;text-align:center;transition:all var(--t);text-decoration:none;color:inherit}
.modal-option:hover{border-color:var(--c-indigo);background:var(--c-indigo-light)}
.modal-option.option-wa:hover{border-color:#25D366;background:#F0FDF4}
.modal-option-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px}
.opt-title{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.opt-sub{font-size:12px;color:var(--c-muted)}
.modal-divider{display:flex;align-items:center;gap:12px;color:var(--c-subtle);font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:20px}
.modal-divider::before,.modal-divider::after{content:'';flex:1;height:1px;background:var(--c-border)}
.modal-form{display:flex;flex-direction:column;gap:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-field{display:flex;flex-direction:column;gap:5px}
.form-field label{font-size:12.5px;font-weight:700;color:var(--c-slate);letter-spacing:.02em}
.form-field input,.form-field select{font-family:var(--font-body);font-size:14px;color:var(--c-body);background:var(--c-bg);border:1.5px solid var(--c-border);border-radius:var(--r);padding:11px 14px;outline:none;transition:border-color var(--t),box-shadow var(--t);width:100%}
.form-field input:focus,.form-field select:focus{border-color:var(--c-indigo);box-shadow:0 0 0 3px rgba(79,70,229,0.12)}
.btn-form-submit{font-family:var(--font-body);font-size:15px;font-weight:800;color:#fff;background:var(--c-indigo);padding:14px 24px;border-radius:var(--r);border:none;cursor:pointer;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--t);margin-top:4px}
.btn-form-submit:hover{background:var(--c-indigo-dark);transform:translateY(-1px);box-shadow:var(--sh-indigo)}
.modal-thanks{display:none;text-align:center;padding:32px}
.modal-thanks-icon{width:64px;height:64px;background:var(--c-indigo-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-size:32px}

.fade-up{opacity:0;transform:translateY(24px);transition:opacity 0.55s ease,transform 0.55s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up.d1{transition-delay:.08s}.fade-up.d2{transition-delay:.16s}.fade-up.d3{transition-delay:.24s}

@media(max-width:1060px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .ba-grid{grid-template-columns:1fr}
  .features-grid{grid-template-columns:1fr}
  .integ-grid{grid-template-columns:1fr}
  .faq-grid{grid-template-columns:1fr;gap:36px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
}
@media(max-width:640px){
  .nav-links,.nav-ctas{display:none}
  .nav-hamburger{display:flex}
  .footer-grid{grid-template-columns:1fr}
  .modal-option-row,.form-row{grid-template-columns:1fr}
  .proof-inner{flex-direction:column}
  .proof-item{border-right:none;border-bottom:1px solid var(--c-border);width:100%;justify-content:center}
  .proof-item:last-child{border-bottom:none}
}

/* ----- porteria.html ----- */
/* ANN BAR */
.ann-bar{background:var(--c-navy-mid);color:#fff;padding:10px 24px;font-size:13.5px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:12px;position:relative}
.ann-bar a{color:#93C5FD;text-decoration:underline;text-underline-offset:2px}
.ann-badge{background:var(--c-primary);color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:2px 8px;border-radius:4px;white-space:nowrap}
.ann-close{position:absolute;right:20px;top:50%;transform:translateY(-50%);color:var(--c-subtle);font-size:18px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.ann-close:hover{color:#fff}

/* NAV */
.nav{position:sticky;top:0;z-index:900;background:rgba(255,255,255,0.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--c-border);box-shadow:0 1px 3px rgba(15,23,42,0.06)}
.nav-inner{max-width:var(--w-max);margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;gap:32px}
.nav-logo img{height:34px;width:auto}
.nav-links{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--c-slate);padding:8px 14px;border-radius:var(--r-sm);transition:color var(--t),background var(--t)}
.nav-links a:hover{color:var(--c-primary);background:var(--c-primary-light)}
.nav-links a.active{color:var(--c-primary);font-weight:700}
.nav-ctas{display:flex;align-items:center;gap:10px;margin-left:12px}
.btn-nav-login{font-size:14px;font-weight:600;color:var(--c-slate);padding:8px 16px;border-radius:var(--r-sm);border:1px solid var(--c-border);transition:all var(--t)}
.btn-nav-login:hover{color:var(--c-primary);border-color:var(--c-primary);background:var(--c-primary-light)}
.btn-nav-demo{font-size:14px;font-weight:700;color:#fff;background:var(--c-primary);padding:9px 20px;border-radius:var(--r-sm);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-nav-demo:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;margin-left:auto}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--c-navy-mid);border-radius:2px}
.mobile-menu{display:none;flex-direction:column;background:var(--c-white);padding:16px 24px 24px;border-top:1px solid var(--c-border)}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:15px;font-weight:500;color:var(--c-slate);padding:12px 0;border-bottom:1px solid var(--c-border)}
.mobile-menu a.active{color:var(--c-primary);font-weight:700}
.mobile-menu a:last-child{border-bottom:none}

/* BREADCRUMB */
.breadcrumb-bar{background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:10px 0}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--c-muted)}
.breadcrumb a{color:var(--c-muted);transition:color var(--t)}
.breadcrumb a:hover{color:var(--c-primary)}
.breadcrumb-sep{color:var(--c-subtle);font-size:11px}
.breadcrumb-current{color:var(--c-slate);font-weight:600}

/* ── HERO ─────────────────────────────────────── */
.porteria-hero{
  background:var(--c-navy);
  background-image:
    radial-gradient(ellipse 60% 80% at 20% 50%, rgba(217,119,6,0.12) 0%, transparent 55%),
    linear-gradient(rgba(37,99,235,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,235,0.06) 1px, transparent 1px);
  background-size: auto, 60px 60px, 60px 60px;
  padding:72px 0 0;
  overflow:hidden;
  position:relative;
}
.hero-grid{display:grid;grid-template-columns:1fr 440px;gap:60px;align-items:start;padding-bottom:56px;position:relative}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(217,119,6,0.18);border:1px solid rgba(217,119,6,0.35);color:#FCD34D;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 14px;border-radius:100px;margin-bottom:22px}
.hero-tag-dot{width:6px;height:6px;border-radius:50%;background:#FBBF24;animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.75)}}
.porteria-hero h1{font-family:var(--font-display);font-size:clamp(34px,4.5vw,52px);font-weight:800;line-height:1.1;letter-spacing:-0.03em;color:#fff;margin-bottom:20px}
.porteria-hero h1 em{font-style:normal;color:#FCD34D}
.porteria-hero .sub{font-size:17.5px;line-height:1.65;color:rgba(255,255,255,0.65);max-width:500px;margin-bottom:36px}
.porteria-hero .sub strong{color:rgba(255,255,255,0.90);font-weight:600}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:36px}
.btn-primary{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:700;color:#fff;background:var(--c-primary);padding:14px 28px;border-radius:var(--r);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-primary:hover{background:var(--c-primary-dark);transform:translateY(-2px);box-shadow:var(--sh-blue)}
.btn-outline{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:600;color:rgba(255,255,255,0.80);background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.18);padding:14px 24px;border-radius:var(--r);transition:all var(--t)}
.btn-outline:hover{background:rgba(255,255,255,0.14);color:#fff;border-color:rgba(255,255,255,0.35)}
.hero-signals{display:flex;flex-direction:column;gap:9px}
.hero-signal{display:flex;align-items:center;gap:9px;font-size:13.5px;color:rgba(255,255,255,0.55)}
.hero-signal svg{flex-shrink:0;color:#4ADE80}

/* ── BITÁCORA PANEL MOCKUP ────────────────────── */
.bitacora-panel{
  background:var(--c-white);
  border-radius:var(--r-xl);
  overflow:hidden;
  box-shadow:0 24px 64px rgba(0,0,0,0.40),0 4px 16px rgba(217,119,6,0.15);
  border:1px solid rgba(255,255,255,0.12);
}
.bp-header{
  background:var(--c-navy-mid);
  padding:14px 18px;
  display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.bp-header-left{display:flex;align-items:center;gap:10px}
.bp-icon{width:30px;height:30px;background:rgba(217,119,6,0.25);border:1px solid rgba(217,119,6,0.40);border-radius:8px;display:flex;align-items:center;justify-content:center}
.bp-title{font-family:var(--font-display);font-size:13px;font-weight:700;color:#fff}
.bp-sub{font-size:11px;color:rgba(255,255,255,0.40);margin-top:1px}
.bp-live{display:flex;align-items:center;gap:5px;font-size:10.5px;font-weight:700;color:#4ADE80;background:rgba(74,222,128,0.12);border:1px solid rgba(74,222,128,0.22);padding:3px 9px;border-radius:100px}
.bp-live-dot{width:6px;height:6px;border-radius:50%;background:#4ADE80;animation:pulse-dot 2s infinite}

.bp-filters{
  background:var(--c-bg);
  padding:10px 16px;
  display:flex;align-items:center;gap:8px;
  border-bottom:1px solid var(--c-border);
  overflow-x:auto;scrollbar-width:none;
}
.bp-filters::-webkit-scrollbar{display:none}
.bp-filter{font-size:11.5px;font-weight:600;padding:4px 12px;border-radius:100px;border:1.5px solid var(--c-border);color:var(--c-muted);background:var(--c-white);cursor:pointer;white-space:nowrap;transition:all var(--t)}
.bp-filter.active{border-color:var(--c-amber);color:var(--c-amber);background:var(--c-amber-light)}
.bp-filter:hover:not(.active){border-color:rgba(37,99,235,.30);color:var(--c-primary)}

.bp-entries{padding:12px 14px;display:flex;flex-direction:column;gap:8px}
.bp-entry{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;
  background:var(--c-bg);
  border:1px solid var(--c-border);
  border-left-width:3px;
  border-radius:var(--r);
  transition:all var(--t);
  cursor:pointer;
}
.bp-entry:hover{background:var(--c-white);box-shadow:var(--sh-sm)}
.bp-entry.type-visitante{border-left-color:#2563EB}
.bp-entry.type-domicilio{border-left-color:#059669}
.bp-entry.type-contratista{border-left-color:#D97706}
.bp-entry.type-paquete{border-left-color:#7C3AED}
.bp-entry.type-mudanza{border-left-color:#DC2626}
.bp-entry-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:15px}
.bp-entry-info{flex:1;min-width:0}
.bp-entry-name{font-size:13px;font-weight:600;color:var(--c-navy-mid);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bp-entry-meta{font-size:11px;color:var(--c-muted);margin-top:1px}
.bp-entry-right{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex-shrink:0}
.bp-entry-time{font-size:11px;font-weight:700;color:var(--c-slate)}
.bp-badge{font-size:10px;font-weight:700;padding:2px 7px;border-radius:3px;white-space:nowrap}
.badge-green{background:var(--c-green-light);color:var(--c-green)}
.badge-amber{background:var(--c-amber-light);color:var(--c-amber)}
.badge-blue{background:var(--c-primary-light);color:var(--c-primary)}
.badge-purple{background:#F5F3FF;color:#7C3AED}
.badge-red{background:var(--c-red-light);color:var(--c-red)}
.bp-footer{
  background:var(--c-bg);
  border-top:1px solid var(--c-border);
  padding:10px 16px;
  display:flex;align-items:center;justify-content:space-between;
  font-size:12px;color:var(--c-muted);
}
.bp-footer-count strong{color:var(--c-navy-mid);font-weight:700}

/* ── PROOF STRIP ──────────────────────────────── */
.proof-strip{background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:18px 0}
.proof-inner{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}
.proof-item{display:flex;align-items:center;gap:10px;padding:10px 28px;border-right:1px solid var(--c-border)}
.proof-item:last-child{border-right:none}
.proof-icon{width:34px;height:34px;background:var(--c-primary-light);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.proof-text-main{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.proof-text-sub{font-size:11.5px;color:var(--c-muted)}

/* ── SECTIONS ─────────────────────────────────── */
.section{padding:88px 0}
.section-alt{background:var(--c-bg)}
.section-navy{background:var(--c-navy)}
.section-eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--c-primary);margin-bottom:14px}
.section-eyebrow-bar{width:24px;height:2px;background:var(--c-primary);border-radius:2px}
.section-h2{font-family:var(--font-display);font-size:clamp(26px,3vw,38px);font-weight:800;line-height:1.15;letter-spacing:-0.025em;color:var(--c-navy);margin-bottom:14px}
.section-h2.light{color:#fff}
.section-sub{font-size:17px;line-height:1.65;color:var(--c-muted);max-width:560px}
.section-sub.light{color:rgba(255,255,255,.68)}

/* ── BEFORE/AFTER ─────────────────────────────── */
.ba-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:52px}
.ba-card{border-radius:var(--r-xl);overflow:hidden;border:1.5px solid var(--c-border)}
.ba-card.before{background:#FFFAFA;border-color:rgba(220,38,38,.20)}
.ba-card.after{background:var(--c-green-light);border-color:rgba(5,150,105,.25)}
.ba-header{padding:16px 22px;border-bottom:1px solid var(--c-border);display:flex;align-items:center;gap:10px}
.ba-header.before{background:rgba(220,38,38,.05)}
.ba-header.after{background:rgba(5,150,105,.07)}
.ba-header-label{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.ba-header-label.before{color:var(--c-red)}
.ba-header-label.after{color:var(--c-green)}
.ba-body{padding:20px 22px;display:flex;flex-direction:column;gap:12px}
.ba-item{display:flex;align-items:flex-start;gap:10px;font-size:14px;line-height:1.50;color:var(--c-body)}
.ba-item-icon{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;font-size:11px}
.ba-item-icon.bad{background:var(--c-red-light);color:var(--c-red)}
.ba-item-icon.good{background:var(--c-green-light);color:var(--c-green)}

/* ── ENTRY TYPES GRID ─────────────────────────── */
.entry-types-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:48px}
.entry-type-card{
  background:var(--c-white);
  border:1.5px solid var(--c-border);
  border-radius:var(--r-lg);
  padding:22px 20px;
  border-top-width:4px;
  transition:box-shadow var(--t),transform var(--t);
}
.entry-type-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}
.et-icon{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:14px}
.et-title{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--c-navy-mid);margin-bottom:6px}
.et-desc{font-size:13.5px;color:var(--c-muted);line-height:1.55}
.et-feature{font-size:12px;color:var(--c-primary);font-weight:600;margin-top:8px;display:flex;align-items:center;gap:5px}

/* ── AUTHORIZATION FLOW ───────────────────────── */
.flow-section{padding:88px 0;background:var(--c-navy)}
.flow-steps{display:grid;grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;gap:0;align-items:start;margin-top:56px}
.flow-step{text-align:center;padding:0 4px}
.flow-step-num{width:54px;height:54px;border-radius:14px;background:rgba(255,255,255,0.10);border:1px solid rgba(255,255,255,0.18);color:#fff;font-family:var(--font-display);font-size:20px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;transition:all var(--t)}
.flow-step:hover .flow-step-num{background:var(--c-primary);border-color:var(--c-primary)}
.flow-step h4{font-family:var(--font-display);font-size:15px;font-weight:700;color:#fff;margin-bottom:7px}
.flow-step p{font-size:13px;color:rgba(255,255,255,.55);line-height:1.5;max-width:180px;margin:0 auto}
.flow-arrow{display:flex;align-items:flex-start;padding-top:26px;color:rgba(255,255,255,0.25)}
.flow-arrow-line{width:32px;height:2px;background:rgba(255,255,255,0.18);position:relative;top:2px}

/* ── FEATURES GRID ────────────────────────────── */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.feature-card{
  background:var(--c-white);border:1.5px solid var(--c-border);
  border-radius:var(--r-lg);padding:26px 22px;
  position:relative;overflow:hidden;
  transition:border-color var(--t),box-shadow var(--t),transform var(--t);
}
.feature-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--c-amber);transform:scaleX(0);transform-origin:left;transition:transform var(--t)}
.feature-card:hover{border-color:rgba(217,119,6,.35);box-shadow:var(--sh-md);transform:translateY(-2px)}
.feature-card:hover::after{transform:scaleX(1)}
.feature-card-icon{width:44px;height:44px;background:var(--c-amber-light);border-radius:11px;display:flex;align-items:center;justify-content:center;margin-bottom:14px;transition:background var(--t)}
.feature-card:hover .feature-card-icon{background:var(--c-amber)}
.feature-card:hover .feature-card-icon svg{color:#fff}
.feature-card-icon svg{transition:color var(--t)}
.feature-card h4{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--c-navy-mid);margin-bottom:7px}
.feature-card p{font-size:13.5px;color:var(--c-muted);line-height:1.55}

/* ── INTEGRATION SECTION ──────────────────────── */
.integration-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-top:44px}
.integration-card{
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:var(--r-lg);
  padding:20px 18px;
  display:flex;align-items:flex-start;gap:14px;
  transition:background var(--t);
}
.integration-card:hover{background:rgba(255,255,255,0.10)}
.integration-icon{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.integration-title{font-family:var(--font-display);font-size:15px;font-weight:700;color:#fff;margin-bottom:5px}
.integration-desc{font-size:13px;color:rgba(255,255,255,.55);line-height:1.50}

/* ── FAQ ──────────────────────────────────────── */
.faq-grid{display:grid;grid-template-columns:300px 1fr;gap:64px;align-items:start}
.faq-sidebar h3{font-family:var(--font-display);font-size:24px;font-weight:800;color:var(--c-navy);margin-bottom:12px;letter-spacing:-0.02em}
.faq-sidebar p{font-size:15px;color:var(--c-muted);line-height:1.6;margin-bottom:22px}
.faq-contact{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--c-primary);transition:gap var(--t)}
.faq-contact:hover{gap:12px}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--c-border)}
.faq-item:first-child{border-top:1px solid var(--c-border)}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0;text-align:left;font-size:15px;font-weight:600;color:var(--c-navy-mid);background:none;cursor:pointer;transition:color var(--t)}
.faq-question:hover{color:var(--c-primary)}
.faq-question svg{flex-shrink:0;transition:transform var(--t);color:var(--c-subtle)}
.faq-item.open .faq-question{color:var(--c-primary)}
.faq-item.open .faq-question svg{transform:rotate(180deg);color:var(--c-primary)}
.faq-answer{overflow:hidden;max-height:0;transition:max-height 0.35s cubic-bezier(0.4,0,0.2,1)}
.faq-answer-inner{padding:0 0 22px;font-size:15px;color:var(--c-muted);line-height:1.70}

/* ── FINAL CTA ────────────────────────────────── */
.final-cta{background:linear-gradient(135deg,#1D4ED8 0%,var(--c-primary) 50%,#0284C7 100%);text-align:center;padding:96px 0;position:relative;overflow:hidden}
.final-cta::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.07) 1px,transparent 1px);background-size:28px 28px}
.final-cta h2{font-family:var(--font-display);font-size:clamp(28px,4vw,44px);font-weight:800;color:#fff;letter-spacing:-0.025em;line-height:1.1;margin-bottom:14px;position:relative}
.final-cta p{font-size:17px;color:rgba(255,255,255,0.75);max-width:480px;margin:0 auto 36px;line-height:1.6;position:relative}
.final-ctas{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;position:relative}
.btn-cta-white{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:800;color:var(--c-primary);background:#fff;padding:16px 32px;border-radius:var(--r);transition:all var(--t);box-shadow:0 4px 20px rgba(0,0,0,0.15)}
.btn-cta-white:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,0.20)}
.btn-cta-wa{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:700;color:#fff;background:rgba(255,255,255,0.15);border:1.5px solid rgba(255,255,255,0.35);padding:15px 28px;border-radius:var(--r);transition:all var(--t)}
.btn-cta-wa:hover{background:rgba(255,255,255,0.22);border-color:rgba(255,255,255,0.55)}

/* FOOTER */
/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,0.70);backdrop-filter:blur(6px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity 0.25s ease}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{background:var(--c-white);border-radius:var(--r-xl);width:100%;max-width:560px;overflow:hidden;box-shadow:var(--sh-lg);transform:translateY(20px) scale(0.97);transition:transform 0.25s ease}
.modal-overlay.open .modal-box{transform:translateY(0) scale(1)}
.modal-header{background:linear-gradient(135deg,var(--c-navy) 0%,var(--c-navy-mid) 100%);padding:28px 32px 24px;position:relative}
.modal-header h2{font-family:var(--font-display);font-size:22px;font-weight:800;color:#fff;margin-bottom:6px;letter-spacing:-0.02em}
.modal-header p{font-size:14px;color:rgba(255,255,255,0.60)}
.modal-close{position:absolute;top:16px;right:20px;color:rgba(255,255,255,0.50);font-size:22px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.modal-close:hover{color:#fff}
.modal-body{padding:28px 32px 32px}
.modal-option-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:22px}
.modal-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 14px;border-radius:var(--r-lg);border:2px solid var(--c-border);cursor:pointer;text-align:center;transition:all var(--t);text-decoration:none;color:inherit}
.modal-option:hover{border-color:var(--c-primary);background:var(--c-primary-light)}
.modal-option.option-wa:hover{border-color:#25D366;background:#F0FDF4}
.modal-option-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px}
.opt-title{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.opt-sub{font-size:12px;color:var(--c-muted)}
.modal-divider{display:flex;align-items:center;gap:12px;color:var(--c-subtle);font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:20px}
.modal-divider::before,.modal-divider::after{content:'';flex:1;height:1px;background:var(--c-border)}
.modal-form{display:flex;flex-direction:column;gap:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-field{display:flex;flex-direction:column;gap:5px}
.form-field label{font-size:12.5px;font-weight:700;color:var(--c-slate);letter-spacing:.02em}
.form-field input,.form-field select{font-family:var(--font-body);font-size:14px;color:var(--c-body);background:var(--c-bg);border:1.5px solid var(--c-border);border-radius:var(--r);padding:11px 14px;outline:none;transition:border-color var(--t),box-shadow var(--t);width:100%}
.form-field input::placeholder{color:var(--c-subtle)}
.form-field input:focus,.form-field select:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(37,99,235,0.12)}
.btn-form-submit{font-family:var(--font-body);font-size:15px;font-weight:800;color:#fff;background:var(--c-primary);padding:14px 24px;border-radius:var(--r);border:none;cursor:pointer;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--t);margin-top:4px}
.btn-form-submit:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}
.modal-thanks{display:none;text-align:center;padding:32px}
.modal-thanks-icon{width:64px;height:64px;background:var(--c-green-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-size:32px}
.modal-thanks h3{font-family:var(--font-display);font-size:22px;font-weight:800;color:var(--c-navy);margin-bottom:8px}
.modal-thanks p{font-size:15px;color:var(--c-muted);line-height:1.6}

.fade-up{opacity:0;transform:translateY(24px);transition:opacity 0.55s ease,transform 0.55s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up.d1{transition-delay:.08s}.fade-up.d2{transition-delay:.16s}.fade-up.d3{transition-delay:.24s}

@media(max-width:1060px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .ba-grid{grid-template-columns:1fr}
  .entry-types-grid{grid-template-columns:repeat(2,1fr)}
  .features-grid{grid-template-columns:repeat(2,1fr)}
  .flow-steps{grid-template-columns:1fr;gap:24px}
  .flow-arrow{display:none}
  .integration-grid{grid-template-columns:1fr}
  .faq-grid{grid-template-columns:1fr;gap:40px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
}
@media(max-width:640px){
  .nav-links,.nav-ctas{display:none}
  .nav-hamburger{display:flex}
  .entry-types-grid,.features-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .modal-option-row,.form-row{grid-template-columns:1fr}
  .proof-inner{flex-direction:column}
  .proof-item{border-right:none;border-bottom:1px solid var(--c-border);width:100%;justify-content:center}
  .proof-item:last-child{border-bottom:none}
}

/* ----- citofonia.html ----- */
/* ANN BAR */
.ann-bar{background:var(--c-navy-mid);color:#fff;padding:10px 24px;font-size:13.5px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:12px;position:relative}
.ann-bar a{color:#7DD3FC;text-decoration:underline;text-underline-offset:2px}
.ann-badge{background:var(--c-cito);color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:2px 8px;border-radius:4px;white-space:nowrap}
.ann-close{position:absolute;right:20px;top:50%;transform:translateY(-50%);color:var(--c-subtle);font-size:18px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.ann-close:hover{color:#fff}

/* NAV */
.nav{position:sticky;top:0;z-index:900;background:rgba(255,255,255,0.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--c-border);box-shadow:0 1px 3px rgba(15,23,42,0.06)}
.nav-inner{max-width:var(--w-max);margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;gap:32px}
.nav-logo img{height:34px;width:auto}
.nav-links{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--c-slate);padding:8px 14px;border-radius:var(--r-sm);transition:color var(--t),background var(--t)}
.nav-links a:hover{color:var(--c-primary);background:var(--c-primary-light)}
.nav-links a.active{color:var(--c-primary);font-weight:700}
.nav-ctas{display:flex;align-items:center;gap:10px;margin-left:12px}
.btn-nav-login{font-size:14px;font-weight:600;color:var(--c-slate);padding:8px 16px;border-radius:var(--r-sm);border:1px solid var(--c-border);transition:all var(--t)}
.btn-nav-login:hover{color:var(--c-primary);border-color:var(--c-primary);background:var(--c-primary-light)}
.btn-nav-demo{font-size:14px;font-weight:700;color:#fff;background:var(--c-primary);padding:9px 20px;border-radius:var(--r-sm);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-nav-demo:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;margin-left:auto}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--c-navy-mid);border-radius:2px}
.mobile-menu{display:none;flex-direction:column;background:var(--c-white);padding:16px 24px 24px;border-top:1px solid var(--c-border)}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:15px;font-weight:500;color:var(--c-slate);padding:12px 0;border-bottom:1px solid var(--c-border)}
.mobile-menu a:last-child{border-bottom:none}

/* BREADCRUMB */
.breadcrumb-bar{background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:10px 0}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--c-muted)}
.breadcrumb a{color:var(--c-muted);transition:color var(--t)}
.breadcrumb a:hover{color:var(--c-primary)}
.breadcrumb-sep{color:var(--c-subtle);font-size:11px}
.breadcrumb-current{color:var(--c-slate);font-weight:600}

/* ── HERO ─────────────────────────────────────── */
.cito-hero{
  background:var(--c-navy);
  background-image:
    radial-gradient(ellipse 55% 70% at 25% 50%, rgba(2,132,199,0.18) 0%, transparent 55%),
    radial-gradient(ellipse 40% 40% at 80% 20%, rgba(37,99,235,0.10) 0%, transparent 50%);
  padding:72px 0 80px;
  overflow:hidden;
  position:relative;
}
.cito-hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.04) 1px,transparent 1px);background-size:32px 32px;pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1fr 380px;gap:64px;align-items:center;position:relative}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(2,132,199,0.18);border:1px solid rgba(2,132,199,0.38);color:#7DD3FC;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 14px;border-radius:100px;margin-bottom:22px}
.hero-tag-dot{width:6px;height:6px;border-radius:50%;background:#38BDF8;animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.75)}}
.cito-hero h1{font-family:var(--font-display);font-size:clamp(32px,4.2vw,50px);font-weight:800;line-height:1.1;letter-spacing:-0.03em;color:#fff;margin-bottom:20px}
.cito-hero h1 em{font-style:normal;color:#38BDF8}
.cito-hero .sub{font-size:17.5px;line-height:1.65;color:rgba(255,255,255,0.65);max-width:500px;margin-bottom:36px}
.cito-hero .sub strong{color:rgba(255,255,255,0.90);font-weight:600}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:36px}
.btn-primary{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:700;color:#fff;background:var(--c-cito);padding:14px 28px;border-radius:var(--r);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-primary:hover{background:var(--c-cito-dark);transform:translateY(-2px);box-shadow:var(--sh-cito)}
.btn-outline{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:600;color:rgba(255,255,255,0.80);background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.18);padding:14px 24px;border-radius:var(--r);transition:all var(--t)}
.btn-outline:hover{background:rgba(255,255,255,0.14);color:#fff;border-color:rgba(255,255,255,0.35)}
.hero-signals{display:flex;flex-direction:column;gap:9px}
.hero-signal{display:flex;align-items:center;gap:9px;font-size:13.5px;color:rgba(255,255,255,0.55)}
.hero-signal svg{flex-shrink:0;color:#4ADE80}

/* ── PHONE MOCKUP ─────────────────────────────── */
.phone-wrap{position:relative;display:flex;justify-content:center}
.phone-frame{
  width:230px;
  background:var(--c-navy-mid);
  border-radius:32px;
  border:6px solid rgba(255,255,255,0.15);
  overflow:hidden;
  box-shadow:0 32px 80px rgba(0,0,0,0.50), 0 0 0 1px rgba(255,255,255,0.08);
  position:relative;
}
.phone-notch{width:80px;height:22px;background:var(--c-navy-mid);border-radius:0 0 14px 14px;position:absolute;top:0;left:50%;transform:translateX(-50%);z-index:2}
.phone-screen{padding-top:30px;min-height:460px;display:flex;flex-direction:column}

/* Lock screen caller card */
.caller-screen{
  background:linear-gradient(180deg, #0C4A6E 0%, #075985 60%, #0369A1 100%);
  flex:1;display:flex;flex-direction:column;align-items:center;padding:28px 16px 20px;
}
.caller-lock-info{font-size:10px;color:rgba(255,255,255,0.50);margin-bottom:20px;text-align:center;letter-spacing:.04em}
.caller-avatar{
  width:72px;height:72px;border-radius:50%;
  background:linear-gradient(135deg,#0284C7,#0369A1);
  border:3px solid rgba(255,255,255,0.30);
  display:flex;align-items:center;justify-content:center;
  font-size:28px;margin-bottom:12px;
  box-shadow:0 0 0 8px rgba(2,132,199,0.18);
}
.caller-name{font-family:var(--font-display);font-size:17px;font-weight:800;color:#fff;text-align:center;margin-bottom:3px}
.caller-sub{font-size:11px;color:rgba(255,255,255,0.60);text-align:center;margin-bottom:4px}
.caller-badge{
  display:inline-flex;align-items:center;gap:4px;
  font-size:10px;font-weight:700;
  background:rgba(74,222,128,0.20);border:1px solid rgba(74,222,128,0.35);
  color:#4ADE80;padding:2px 9px;border-radius:100px;margin-bottom:16px;
}
.caller-visitor-card{
  background:rgba(255,255,255,0.10);
  border:1px solid rgba(255,255,255,0.15);
  border-radius:12px;padding:10px 14px;width:100%;margin-bottom:18px;
}
.visitor-row{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.visitor-row:last-child{margin-bottom:0}
.visitor-label{font-size:10px;color:rgba(255,255,255,0.45);width:48px;flex-shrink:0}
.visitor-value{font-size:11px;font-weight:600;color:rgba(255,255,255,0.85)}
.caller-actions{display:flex;gap:24px;justify-content:center;margin-top:auto;padding-bottom:4px}
.call-btn{
  width:54px;height:54px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;cursor:pointer;
}
.call-btn.accept{background:#22C55E;box-shadow:0 4px 16px rgba(34,197,94,0.40)}
.call-btn.deny {background:#EF4444;box-shadow:0 4px 16px rgba(239,68,68,0.35)}
.call-btn.open  {background:#0284C7;box-shadow:0 4px 16px rgba(2,132,199,0.40)}
.caller-btn-labels{display:flex;gap:12px;justify-content:center;margin-top:6px}
.caller-btn-label{font-size:9.5px;color:rgba(255,255,255,0.45);width:54px;text-align:center}

/* Pre-visual alert notification */
.previsual-pill{
  position:absolute;top:18px;right:-20px;
  background:var(--c-white);
  border-radius:14px;
  padding:8px 10px;
  box-shadow:0 8px 28px rgba(0,0,0,0.22);
  width:160px;
  border:1px solid var(--c-border);
}
.pv-header{font-size:9px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--c-primary);margin-bottom:4px;display:flex;align-items:center;gap:4px}
.pv-header::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--c-primary);animation:pulse-dot 2s infinite;flex-shrink:0}
.pv-title{font-size:11px;font-weight:700;color:var(--c-navy-mid);margin-bottom:2px}
.pv-sub{font-size:10px;color:var(--c-muted)}

/* Floating feature badges */
.float-badge{
  position:absolute;
  background:var(--c-white);
  border-radius:10px;
  padding:7px 10px;
  box-shadow:0 4px 16px rgba(0,0,0,0.16);
  border:1px solid var(--c-border);
  font-size:10.5px;font-weight:600;color:var(--c-navy-mid);
  display:flex;align-items:center;gap:5px;
  white-space:nowrap;
}
.float-badge svg{flex-shrink:0}

/* ── PROOF STRIP ──────────────────────────────── */
.proof-strip{background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:18px 0}
.proof-inner{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}
.proof-item{display:flex;align-items:center;gap:10px;padding:10px 28px;border-right:1px solid var(--c-border)}
.proof-item:last-child{border-right:none}
.proof-icon{width:34px;height:34px;background:var(--c-cito-light);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.proof-text-main{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.proof-text-sub{font-size:11.5px;color:var(--c-muted)}

/* ── SECTIONS ─────────────────────────────────── */
.section{padding:88px 0}
.section-alt{background:var(--c-bg)}
.section-navy{background:var(--c-navy)}
.section-eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--c-cito);margin-bottom:14px}
.section-eyebrow-bar{width:24px;height:2px;background:var(--c-cito);border-radius:2px}
.section-h2{font-family:var(--font-display);font-size:clamp(26px,3vw,38px);font-weight:800;line-height:1.15;letter-spacing:-0.025em;color:var(--c-navy);margin-bottom:14px}
.section-h2.light{color:#fff}
.section-sub{font-size:17px;line-height:1.65;color:var(--c-muted);max-width:560px}
.section-sub.light{color:rgba(255,255,255,.68)}

/* ── HOW IT WORKS ─────────────────────────────── */
.how-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;margin-top:52px}
.how-steps{display:flex;flex-direction:column;gap:0}
.how-step{
  display:flex;align-items:flex-start;gap:18px;
  padding:22px 0;
  border-bottom:1px solid var(--c-border);
  position:relative;
}
.how-step:last-child{border-bottom:none}
.how-step-num{
  width:38px;height:38px;border-radius:10px;
  background:var(--c-cito-light);
  color:var(--c-cito);
  font-family:var(--font-display);font-size:16px;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  transition:background var(--t),color var(--t);
}
.how-step:hover .how-step-num{background:var(--c-cito);color:#fff}
.how-step-body h4{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--c-navy-mid);margin-bottom:5px}
.how-step-body p{font-size:14px;color:var(--c-muted);line-height:1.55}
.how-step-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:2px 8px;border-radius:4px;margin-top:6px}

/* How it works visual panel */
.how-visual{background:var(--c-navy);border-radius:var(--r-xl);overflow:hidden;border:1px solid rgba(255,255,255,0.08);box-shadow:var(--sh-lg)}
.hv-header{background:rgba(255,255,255,0.05);padding:14px 18px;border-bottom:1px solid rgba(255,255,255,0.08);display:flex;align-items:center;justify-content:space-between}
.hv-title{font-size:13px;font-weight:700;color:rgba(255,255,255,0.80)}
.hv-live{display:flex;align-items:center;gap:5px;font-size:10.5px;color:#4ADE80;font-weight:700}
.hv-live-dot{width:5px;height:5px;border-radius:50%;background:#4ADE80;animation:pulse-dot 2s infinite}
.hv-log{padding:14px 16px;display:flex;flex-direction:column;gap:10px}
.hv-log-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:rgba(255,255,255,0.05);border-radius:var(--r);border:1px solid rgba(255,255,255,0.07)}
.hv-row-icon{width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.hv-row-body{flex:1}
.hv-row-title{font-size:12px;font-weight:600;color:rgba(255,255,255,0.80)}
.hv-row-sub{font-size:11px;color:rgba(255,255,255,0.40);margin-top:1px}
.hv-row-time{font-size:10.5px;font-weight:700;color:rgba(255,255,255,0.40);flex-shrink:0}
.hv-row-status{font-size:10px;font-weight:700;padding:2px 7px;border-radius:3px;flex-shrink:0}
.status-open{background:rgba(74,222,128,0.15);color:#4ADE80}
.status-answered{background:rgba(2,132,199,0.20);color:#38BDF8}
.status-vm{background:rgba(251,191,36,0.15);color:#FBBF24}
.status-denied{background:rgba(239,68,68,0.15);color:#F87171}

/* ── DIFFERENTIATORS ──────────────────────────── */
.diff-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.diff-card{
  background:var(--c-white);border:1.5px solid var(--c-border);
  border-radius:var(--r-lg);padding:28px 22px;
  border-top:4px solid var(--c-cito);
  transition:box-shadow var(--t),transform var(--t);
}
.diff-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}
.diff-icon{width:48px;height:48px;background:var(--c-cito-light);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.diff-card h4{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--c-navy-mid);margin-bottom:8px}
.diff-card p{font-size:14px;color:var(--c-muted);line-height:1.55}
.diff-tag{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;font-weight:700;color:var(--c-cito);margin-top:10px}

/* ── COMPARISON TABLE ─────────────────────────── */
.comp-table{width:100%;border-collapse:collapse;margin-top:48px;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--c-border)}
.comp-table th{padding:14px 18px;font-family:var(--font-display);font-size:13px;font-weight:700;text-align:center}
.comp-table th:first-child{text-align:left;background:var(--c-bg)}
.comp-table th.th-old{background:#FEF2F2;color:#991B1B}
.comp-table th.th-new{background:var(--c-cito-light);color:var(--c-cito-dark)}
.comp-table td{padding:13px 18px;font-size:14px;border-top:1px solid var(--c-border);text-align:center}
.comp-table td:first-child{text-align:left;color:var(--c-slate);font-weight:500;background:var(--c-bg)}
.comp-table tr:nth-child(even) td:first-child{background:var(--c-white)}
.comp-check{color:var(--c-green);font-weight:700;font-size:16px}
.comp-cross{color:#DC2626;font-weight:700;font-size:16px}
.comp-partial{color:var(--c-amber);font-weight:700;font-size:13px}

/* ── FEATURES GRID ────────────────────────────── */
.feat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:48px}
.feat-item{
  display:flex;align-items:flex-start;gap:14px;
  background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.10);
  border-radius:var(--r-lg);padding:20px 18px;
  transition:background var(--t);
}
.feat-item:hover{background:rgba(255,255,255,0.10)}
.feat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.feat-title{font-family:var(--font-display);font-size:15px;font-weight:700;color:#fff;margin-bottom:5px}
.feat-desc{font-size:13px;color:rgba(255,255,255,0.55);line-height:1.55}

/* ── INTEGRATION ──────────────────────────────── */
.integ-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:44px}
.integ-card{background:var(--c-white);border:1.5px solid var(--c-border);border-radius:var(--r-lg);padding:22px 18px;display:flex;align-items:flex-start;gap:14px;transition:border-color var(--t),box-shadow var(--t)}
.integ-card:hover{border-color:rgba(2,132,199,0.35);box-shadow:var(--sh-sm)}
.integ-icon{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.integ-title{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--c-navy-mid);margin-bottom:5px}
.integ-desc{font-size:13px;color:var(--c-muted);line-height:1.50}

/* ── FAQ ──────────────────────────────────────── */
.faq-grid{display:grid;grid-template-columns:300px 1fr;gap:64px;align-items:start}
.faq-sidebar h3{font-family:var(--font-display);font-size:24px;font-weight:800;color:var(--c-navy);margin-bottom:12px;letter-spacing:-0.02em}
.faq-sidebar p{font-size:15px;color:var(--c-muted);line-height:1.6;margin-bottom:22px}
.faq-contact{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--c-cito);transition:gap var(--t)}
.faq-contact:hover{gap:12px}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--c-border)}
.faq-item:first-child{border-top:1px solid var(--c-border)}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0;text-align:left;font-size:15px;font-weight:600;color:var(--c-navy-mid);background:none;cursor:pointer;transition:color var(--t)}
.faq-question:hover,.faq-item.open .faq-question{color:var(--c-cito)}
.faq-question svg{flex-shrink:0;transition:transform var(--t);color:var(--c-subtle)}
.faq-item.open .faq-question svg{transform:rotate(180deg);color:var(--c-cito)}
.faq-answer{overflow:hidden;max-height:0;transition:max-height 0.35s cubic-bezier(0.4,0,0.2,1)}
.faq-answer-inner{padding:0 0 22px;font-size:15px;color:var(--c-muted);line-height:1.70}

/* ── FINAL CTA ────────────────────────────────── */
.final-cta{background:linear-gradient(135deg,#075985 0%,var(--c-cito) 50%,#0284C7 100%);text-align:center;padding:96px 0;position:relative;overflow:hidden}
.final-cta::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.07) 1px,transparent 1px);background-size:28px 28px}
.final-cta h2{font-family:var(--font-display);font-size:clamp(28px,4vw,44px);font-weight:800;color:#fff;letter-spacing:-0.025em;line-height:1.1;margin-bottom:14px;position:relative}
.final-cta p{font-size:17px;color:rgba(255,255,255,0.75);max-width:480px;margin:0 auto 36px;line-height:1.6;position:relative}
.final-ctas{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;position:relative}
.btn-cta-white{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:800;color:var(--c-cito);background:#fff;padding:16px 32px;border-radius:var(--r);transition:all var(--t);box-shadow:0 4px 20px rgba(0,0,0,0.15)}
.btn-cta-white:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,0.20)}
.btn-cta-wa{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:700;color:#fff;background:rgba(255,255,255,0.15);border:1.5px solid rgba(255,255,255,0.35);padding:15px 28px;border-radius:var(--r);transition:all var(--t)}
.btn-cta-wa:hover{background:rgba(255,255,255,0.22);border-color:rgba(255,255,255,0.55)}

/* FOOTER */
/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,0.70);backdrop-filter:blur(6px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity 0.25s ease}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{background:var(--c-white);border-radius:var(--r-xl);width:100%;max-width:560px;overflow:hidden;box-shadow:var(--sh-lg);transform:translateY(20px) scale(0.97);transition:transform 0.25s ease}
.modal-overlay.open .modal-box{transform:translateY(0) scale(1)}
.modal-header{background:linear-gradient(135deg,var(--c-navy) 0%,var(--c-navy-mid) 100%);padding:28px 32px 24px;position:relative}
.modal-header h2{font-family:var(--font-display);font-size:22px;font-weight:800;color:#fff;margin-bottom:6px;letter-spacing:-0.02em}
.modal-header p{font-size:14px;color:rgba(255,255,255,0.60)}
.modal-close{position:absolute;top:16px;right:20px;color:rgba(255,255,255,0.50);font-size:22px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.modal-close:hover{color:#fff}
.modal-body{padding:28px 32px 32px}
.modal-option-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:22px}
.modal-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 14px;border-radius:var(--r-lg);border:2px solid var(--c-border);cursor:pointer;text-align:center;transition:all var(--t);text-decoration:none;color:inherit}
.modal-option:hover{border-color:var(--c-cito);background:var(--c-cito-light)}
.modal-option.option-wa:hover{border-color:#25D366;background:#F0FDF4}
.modal-option-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px}
.opt-title{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.opt-sub{font-size:12px;color:var(--c-muted)}
.modal-divider{display:flex;align-items:center;gap:12px;color:var(--c-subtle);font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:20px}
.modal-divider::before,.modal-divider::after{content:'';flex:1;height:1px;background:var(--c-border)}
.modal-form{display:flex;flex-direction:column;gap:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-field{display:flex;flex-direction:column;gap:5px}
.form-field label{font-size:12.5px;font-weight:700;color:var(--c-slate);letter-spacing:.02em}
.form-field input,.form-field select{font-family:var(--font-body);font-size:14px;color:var(--c-body);background:var(--c-bg);border:1.5px solid var(--c-border);border-radius:var(--r);padding:11px 14px;outline:none;transition:border-color var(--t),box-shadow var(--t);width:100%}
.form-field input:focus,.form-field select:focus{border-color:var(--c-cito);box-shadow:0 0 0 3px rgba(2,132,199,0.12)}
.btn-form-submit{font-family:var(--font-body);font-size:15px;font-weight:800;color:#fff;background:var(--c-cito);padding:14px 24px;border-radius:var(--r);border:none;cursor:pointer;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--t);margin-top:4px}
.btn-form-submit:hover{background:var(--c-cito-dark);transform:translateY(-1px);box-shadow:var(--sh-cito)}
.modal-thanks{display:none;text-align:center;padding:32px}
.modal-thanks-icon{width:64px;height:64px;background:var(--c-cito-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-size:32px}

.fade-up{opacity:0;transform:translateY(24px);transition:opacity 0.55s ease,transform 0.55s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up.d1{transition-delay:.08s}.fade-up.d2{transition-delay:.16s}.fade-up.d3{transition-delay:.24s}

@media(max-width:1060px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .how-grid{grid-template-columns:1fr}
  .diff-grid{grid-template-columns:1fr 1fr}
  .feat-grid{grid-template-columns:1fr}
  .integ-grid{grid-template-columns:1fr}
  .faq-grid{grid-template-columns:1fr;gap:36px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
  .previsual-pill{display:none}
  .float-badge{display:none}
}
@media(max-width:640px){
  .nav-links,.nav-ctas{display:none}
  .nav-hamburger{display:flex}
  .diff-grid,.feat-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .modal-option-row,.form-row{grid-template-columns:1fr}
  .proof-inner{flex-direction:column}
  .proof-item{border-right:none;border-bottom:1px solid var(--c-border);width:100%;justify-content:center}
  .proof-item:last-child{border-bottom:none}
  .comp-table{font-size:12px}
}

/* ----- mantenimiento.html ----- */
.ann-bar{background:var(--c-navy-mid);color:#fff;padding:10px 24px;font-size:13.5px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:12px;position:relative}
.ann-bar a{color:#FED7AA;text-decoration:underline;text-underline-offset:2px}
.ann-badge{background:var(--c-orange);color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:2px 8px;border-radius:4px;white-space:nowrap}
.ann-close{position:absolute;right:20px;top:50%;transform:translateY(-50%);color:var(--c-subtle);font-size:18px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.ann-close:hover{color:#fff}
.nav{position:sticky;top:0;z-index:900;background:rgba(255,255,255,0.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--c-border);box-shadow:0 1px 3px rgba(15,23,42,0.06)}
.nav-inner{max-width:var(--w-max);margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;gap:32px}
.nav-logo img{height:34px;width:auto}
.nav-links{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--c-slate);padding:8px 14px;border-radius:var(--r-sm);transition:color var(--t),background var(--t)}
.nav-links a:hover{color:var(--c-primary);background:var(--c-primary-light)}
.nav-ctas{display:flex;align-items:center;gap:10px;margin-left:12px}
.btn-nav-login{font-size:14px;font-weight:600;color:var(--c-slate);padding:8px 16px;border-radius:var(--r-sm);border:1px solid var(--c-border);transition:all var(--t)}
.btn-nav-login:hover{color:var(--c-primary);border-color:var(--c-primary);background:var(--c-primary-light)}
.btn-nav-demo{font-size:14px;font-weight:700;color:#fff;background:var(--c-primary);padding:9px 20px;border-radius:var(--r-sm);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-nav-demo:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;margin-left:auto}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--c-navy-mid);border-radius:2px}
.mobile-menu{display:none;flex-direction:column;background:var(--c-white);padding:16px 24px 24px;border-top:1px solid var(--c-border)}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:15px;font-weight:500;color:var(--c-slate);padding:12px 0;border-bottom:1px solid var(--c-border)}
.mobile-menu a:last-child{border-bottom:none}
.breadcrumb-bar{background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:10px 0}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--c-muted)}
.breadcrumb a{color:var(--c-muted);transition:color var(--t)}
.breadcrumb a:hover{color:var(--c-primary)}
.breadcrumb-sep{color:var(--c-subtle);font-size:11px}
.breadcrumb-current{color:var(--c-slate);font-weight:600}

/* HERO */
.mnt-hero{background:var(--c-navy);background-image:radial-gradient(ellipse 55% 70% at 18% 55%,rgba(234,88,12,0.16) 0%,transparent 55%),radial-gradient(ellipse 40% 50% at 80% 20%,rgba(37,99,235,0.08) 0%,transparent 50%);padding:72px 0 80px;overflow:hidden;position:relative}
.mnt-hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.04) 1px,transparent 1px);background-size:32px 32px;pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1fr 460px;gap:60px;align-items:start;position:relative}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(234,88,12,0.18);border:1px solid rgba(234,88,12,0.35);color:#FED7AA;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 14px;border-radius:100px;margin-bottom:22px}
.hero-tag-dot{width:6px;height:6px;border-radius:50%;background:#FB923C;animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.75)}}
.mnt-hero h1{font-family:var(--font-display);font-size:clamp(32px,4.2vw,50px);font-weight:800;line-height:1.1;letter-spacing:-0.03em;color:#fff;margin-bottom:20px}
.mnt-hero h1 em{font-style:normal;color:#FB923C}
.mnt-hero .sub{font-size:17.5px;line-height:1.65;color:rgba(255,255,255,0.65);max-width:500px;margin-bottom:36px}
.mnt-hero .sub strong{color:rgba(255,255,255,0.90);font-weight:600}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:36px}
.btn-primary{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:700;color:#fff;background:var(--c-orange);padding:14px 28px;border-radius:var(--r);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-primary:hover{background:var(--c-orange-dark);transform:translateY(-2px);box-shadow:var(--sh-org)}
.btn-outline{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:600;color:rgba(255,255,255,0.80);background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.18);padding:14px 24px;border-radius:var(--r);transition:all var(--t)}
.btn-outline:hover{background:rgba(255,255,255,0.14);color:#fff;border-color:rgba(255,255,255,0.35)}
.hero-signals{display:flex;flex-direction:column;gap:9px}
.hero-signal{display:flex;align-items:center;gap:9px;font-size:13.5px;color:rgba(255,255,255,0.55)}
.hero-signal svg{flex-shrink:0;color:#4ADE80}

/* CMMS PANEL */
.cmms-panel{background:var(--c-white);border-radius:var(--r-xl);overflow:hidden;box-shadow:0 24px 64px rgba(0,0,0,0.40),0 4px 16px rgba(234,88,12,0.15);border:1px solid rgba(255,255,255,0.10)}
.cp-header{background:var(--c-navy-mid);padding:12px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,0.08)}
.cp-id{display:flex;align-items:center;gap:9px}
.cp-icon{width:27px;height:27px;background:rgba(234,88,12,0.25);border:1px solid rgba(234,88,12,0.40);border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:13px}
.cp-name{font-family:var(--font-display);font-size:12px;font-weight:700;color:#fff}
.cp-sub{font-size:10px;color:rgba(255,255,255,0.40);margin-top:1px}
.cp-counts{display:flex;gap:8px}
.cp-count{font-size:10.5px;font-weight:700;padding:2px 8px;border-radius:100px}
.cp-count.abiertas{background:rgba(220,38,38,0.18);color:#FCA5A5}
.cp-count.proceso{background:rgba(234,88,12,0.18);color:#FED7AA}
.cp-count.completadas{background:rgba(5,150,105,0.18);color:#6EE7B7}
.cp-ot-list{padding:12px 14px;display:flex;flex-direction:column;gap:8px}
.cp-ot{display:flex;align-items:flex-start;gap:10px;padding:11px 12px;background:var(--c-bg);border:1px solid var(--c-border);border-left:3px solid;border-radius:var(--r);transition:all var(--t);cursor:pointer}
.cp-ot:hover{background:var(--c-white);box-shadow:var(--sh-sm)}
.cp-ot.correctivo{border-left-color:#DC2626}
.cp-ot.preventivo{border-left-color:#2563EB}
.cp-ot-icon{width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px}
.cp-ot-body{flex:1;min-width:0}
.cp-ot-title{font-size:12.5px;font-weight:600;color:var(--c-navy-mid);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cp-ot-meta{font-size:10.5px;color:var(--c-muted);margin-top:1px;display:flex;align-items:center;gap:6px}
.cp-ot-tag{font-size:9px;font-weight:700;padding:1px 5px;border-radius:3px}
.tag-corr{background:var(--c-red-light);color:var(--c-red)}
.tag-prev{background:var(--c-primary-light);color:var(--c-primary)}
.cp-ot-right{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex-shrink:0}
.cp-ot-status{font-size:10px;font-weight:700;padding:2px 7px;border-radius:3px}
.status-abierta{background:var(--c-red-light);color:var(--c-red)}
.status-proceso{background:var(--c-orange-light);color:var(--c-orange)}
.status-completa{background:var(--c-green-light);color:var(--c-green)}
.cp-ot-date{font-size:10px;color:var(--c-subtle);font-weight:600}
.cp-assets{border-top:1px solid var(--c-border);padding:10px 14px}
.cp-assets-label{font-size:9.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--c-subtle);margin-bottom:8px}
.cp-asset-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--c-border)}
.cp-asset-row:last-child{border-bottom:none}
.cp-asset-icon{font-size:14px;width:24px;text-align:center}
.cp-asset-name{font-size:11.5px;font-weight:600;color:var(--c-slate);flex:1}
.cp-asset-badge{font-size:9.5px;font-weight:700;padding:1.5px 7px;border-radius:3px}
.asset-ok{background:var(--c-green-light);color:var(--c-green)}
.asset-due{background:var(--c-amber-light);color:var(--c-amber)}

/* PROOF STRIP */
.proof-strip{background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:18px 0}
.proof-inner{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}
.proof-item{display:flex;align-items:center;gap:10px;padding:10px 28px;border-right:1px solid var(--c-border)}
.proof-item:last-child{border-right:none}
.proof-icon{width:34px;height:34px;background:var(--c-orange-light);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:17px}
.proof-text-main{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.proof-text-sub{font-size:11.5px;color:var(--c-muted)}

/* SECTIONS */
.section{padding:88px 0}
.section-alt{background:var(--c-bg)}
.section-navy{background:var(--c-navy)}
.section-eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--c-orange);margin-bottom:14px}
.section-eyebrow-bar{width:24px;height:2px;background:var(--c-orange);border-radius:2px}
.section-h2{font-family:var(--font-display);font-size:clamp(26px,3vw,38px);font-weight:800;line-height:1.15;letter-spacing:-0.025em;color:var(--c-navy);margin-bottom:14px}
.section-h2.light{color:#fff}
.section-sub{font-size:17px;line-height:1.65;color:var(--c-muted);max-width:560px}

/* BEFORE/AFTER */
.ba-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:52px}
.ba-card{border-radius:var(--r-xl);overflow:hidden;border:1.5px solid var(--c-border)}
.ba-card.before{background:#FFFAFA;border-color:rgba(220,38,38,.20)}
.ba-card.after{background:var(--c-orange-light);border-color:rgba(234,88,12,.20)}
.ba-head{padding:16px 22px;border-bottom:1px solid var(--c-border);display:flex;align-items:center;gap:10px}
.ba-head.before{background:rgba(220,38,38,.05)}
.ba-head.after{background:rgba(234,88,12,.07)}
.ba-label{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.ba-label.before{color:var(--c-red)}
.ba-label.after{color:var(--c-orange)}
.ba-body{padding:20px 22px;display:flex;flex-direction:column;gap:11px}
.ba-item{display:flex;align-items:flex-start;gap:10px;font-size:14px;line-height:1.50;color:var(--c-body)}
.ba-dot{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;font-size:11px}
.ba-dot.bad{background:var(--c-red-light);color:var(--c-red)}
.ba-dot.good{background:var(--c-green-light);color:var(--c-green)}

/* THREE FEATURES */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.feature-card{background:var(--c-white);border:1.5px solid var(--c-border);border-radius:var(--r-lg);padding:28px 22px;border-top:4px solid var(--c-orange);transition:box-shadow var(--t),transform var(--t)}
.feature-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}
.feat-icon{font-size:36px;margin-bottom:14px}
.feature-card h4{font-family:var(--font-display);font-size:17px;font-weight:800;color:var(--c-navy-mid);margin-bottom:8px;letter-spacing:-0.02em}
.feature-card p{font-size:14px;color:var(--c-muted);line-height:1.55}

/* AUTO INTEGRATIONS */
.auto-section{padding:88px 0;background:var(--c-navy)}
.auto-flows{display:flex;flex-direction:column;gap:16px;margin-top:52px;max-width:680px;margin-left:auto;margin-right:auto}
.auto-row{display:flex;align-items:center;gap:16px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.10);border-radius:var(--r-lg);padding:18px 22px;transition:background var(--t)}
.auto-row:hover{background:rgba(255,255,255,0.10)}
.auto-trigger{display:flex;align-items:center;gap:10px;flex:1}
.auto-trigger-icon{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:18px}
.auto-trigger-name{font-size:14px;font-weight:700;color:#fff}
.auto-trigger-desc{font-size:12px;color:rgba(255,255,255,0.50);margin-top:2px}
.auto-arrow{color:rgba(255,255,255,0.25);font-size:20px;flex-shrink:0;padding:0 4px}
.auto-result{background:rgba(234,88,12,0.15);border:1px solid rgba(234,88,12,0.25);border-radius:var(--r-sm);padding:8px 14px;flex-shrink:0;text-align:center}
.auto-result-main{font-size:13px;font-weight:700;color:#FED7AA}
.auto-result-sub{font-size:10.5px;color:rgba(255,255,255,0.45);margin-top:2px}

/* INTEGRATION */
.integ-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;max-width:720px;margin:44px auto 0}
.integ-card{background:var(--c-white);border:1.5px solid var(--c-border);border-radius:var(--r-lg);padding:22px 18px;display:flex;align-items:flex-start;gap:14px;transition:border-color var(--t),box-shadow var(--t)}
.integ-card:hover{border-color:rgba(234,88,12,0.35);box-shadow:var(--sh-sm)}
.integ-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:20px}
.integ-title{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--c-navy-mid);margin-bottom:5px}
.integ-desc{font-size:13.5px;color:var(--c-muted);line-height:1.55}

/* FAQ */
.faq-grid{display:grid;grid-template-columns:300px 1fr;gap:64px;align-items:start}
.faq-sidebar h3{font-family:var(--font-display);font-size:24px;font-weight:800;color:var(--c-navy);margin-bottom:12px;letter-spacing:-0.02em}
.faq-sidebar p{font-size:15px;color:var(--c-muted);line-height:1.6;margin-bottom:22px}
.faq-contact{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--c-orange);transition:gap var(--t)}
.faq-contact:hover{gap:12px}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--c-border)}
.faq-item:first-child{border-top:1px solid var(--c-border)}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0;text-align:left;font-size:15px;font-weight:600;color:var(--c-navy-mid);background:none;cursor:pointer;transition:color var(--t)}
.faq-question:hover,.faq-item.open .faq-question{color:var(--c-orange)}
.faq-question svg{flex-shrink:0;transition:transform var(--t);color:var(--c-subtle)}
.faq-item.open .faq-question svg{transform:rotate(180deg);color:var(--c-orange)}
.faq-answer{overflow:hidden;max-height:0;transition:max-height 0.35s cubic-bezier(0.4,0,0.2,1)}
.faq-answer-inner{padding:0 0 22px;font-size:15px;color:var(--c-muted);line-height:1.70}

/* FINAL CTA */
.final-cta{background:linear-gradient(135deg,#9A3412 0%,var(--c-orange) 50%,#EA580C 100%);text-align:center;padding:96px 0;position:relative;overflow:hidden}
.final-cta::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.07) 1px,transparent 1px);background-size:28px 28px}
.final-cta h2{font-family:var(--font-display);font-size:clamp(26px,4vw,42px);font-weight:800;color:#fff;letter-spacing:-0.025em;line-height:1.15;margin-bottom:14px;position:relative}
.final-cta p{font-size:17px;color:rgba(255,255,255,0.75);max-width:480px;margin:0 auto 36px;line-height:1.6;position:relative}
.final-ctas{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;position:relative}
.btn-cta-white{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:800;color:var(--c-orange-dark);background:#fff;padding:16px 32px;border-radius:var(--r);transition:all var(--t);box-shadow:0 4px 20px rgba(0,0,0,0.15)}
.btn-cta-white:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,0.20)}
.btn-cta-wa{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:700;color:#fff;background:rgba(255,255,255,0.15);border:1.5px solid rgba(255,255,255,0.35);padding:15px 28px;border-radius:var(--r);transition:all var(--t)}
.btn-cta-wa:hover{background:rgba(255,255,255,0.22);border-color:rgba(255,255,255,0.55)}

/* FOOTER */
/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,0.70);backdrop-filter:blur(6px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity 0.25s ease}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{background:var(--c-white);border-radius:var(--r-xl);width:100%;max-width:560px;overflow:hidden;box-shadow:var(--sh-lg);transform:translateY(20px) scale(0.97);transition:transform 0.25s ease}
.modal-overlay.open .modal-box{transform:translateY(0) scale(1)}
.modal-header{background:linear-gradient(135deg,var(--c-navy) 0%,var(--c-navy-mid) 100%);padding:28px 32px 24px;position:relative}
.modal-header h2{font-family:var(--font-display);font-size:22px;font-weight:800;color:#fff;margin-bottom:6px;letter-spacing:-0.02em}
.modal-header p{font-size:14px;color:rgba(255,255,255,0.60)}
.modal-close{position:absolute;top:16px;right:20px;color:rgba(255,255,255,0.50);font-size:22px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.modal-close:hover{color:#fff}
.modal-body{padding:28px 32px 32px}
.modal-option-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:22px}
.modal-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 14px;border-radius:var(--r-lg);border:2px solid var(--c-border);cursor:pointer;text-align:center;transition:all var(--t);text-decoration:none;color:inherit}
.modal-option:hover{border-color:var(--c-orange);background:var(--c-orange-light)}
.modal-option.option-wa:hover{border-color:#25D366;background:#F0FDF4}
.modal-option-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px}
.opt-title{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.opt-sub{font-size:12px;color:var(--c-muted)}
.modal-divider{display:flex;align-items:center;gap:12px;color:var(--c-subtle);font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:20px}
.modal-divider::before,.modal-divider::after{content:'';flex:1;height:1px;background:var(--c-border)}
.modal-form{display:flex;flex-direction:column;gap:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-field{display:flex;flex-direction:column;gap:5px}
.form-field label{font-size:12.5px;font-weight:700;color:var(--c-slate);letter-spacing:.02em}
.form-field input,.form-field select{font-family:var(--font-body);font-size:14px;color:var(--c-body);background:var(--c-bg);border:1.5px solid var(--c-border);border-radius:var(--r);padding:11px 14px;outline:none;transition:border-color var(--t),box-shadow var(--t);width:100%}
.form-field input:focus,.form-field select:focus{border-color:var(--c-orange);box-shadow:0 0 0 3px rgba(234,88,12,0.12)}
.btn-form-submit{font-family:var(--font-body);font-size:15px;font-weight:800;color:#fff;background:var(--c-orange);padding:14px 24px;border-radius:var(--r);border:none;cursor:pointer;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--t);margin-top:4px}
.btn-form-submit:hover{background:var(--c-orange-dark);transform:translateY(-1px);box-shadow:var(--sh-org)}
.modal-thanks{display:none;text-align:center;padding:32px}
.modal-thanks-icon{width:64px;height:64px;background:var(--c-orange-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-size:32px}
.fade-up{opacity:0;transform:translateY(24px);transition:opacity 0.55s ease,transform 0.55s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up.d1{transition-delay:.08s}.fade-up.d2{transition-delay:.16s}.fade-up.d3{transition-delay:.24s}

@media(max-width:1060px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .ba-grid{grid-template-columns:1fr}
  .features-grid{grid-template-columns:1fr}
  .integ-grid{grid-template-columns:1fr}
  .faq-grid{grid-template-columns:1fr;gap:36px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
}
@media(max-width:640px){
  .nav-links,.nav-ctas{display:none}
  .nav-hamburger{display:flex}
  .footer-grid{grid-template-columns:1fr}
  .modal-option-row,.form-row{grid-template-columns:1fr}
  .proof-inner{flex-direction:column}
  .proof-item{border-right:none;border-bottom:1px solid var(--c-border);width:100%;justify-content:center}
  .proof-item:last-child{border-bottom:none}
}

/* ----- marketplace.html ----- */
/* ANN BAR */
.ann-bar{background:var(--c-navy-mid);color:#fff;padding:10px 24px;font-size:13.5px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:12px;position:relative}
.ann-bar a{color:#C4B5FD;text-decoration:underline;text-underline-offset:2px}
.ann-badge{background:var(--c-purple);color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:2px 8px;border-radius:4px;white-space:nowrap}
.ann-close{position:absolute;right:20px;top:50%;transform:translateY(-50%);color:var(--c-subtle);font-size:18px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.ann-close:hover{color:#fff}

/* NAV */
.nav{position:sticky;top:0;z-index:900;background:rgba(255,255,255,0.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--c-border);box-shadow:0 1px 3px rgba(15,23,42,0.06)}
.nav-inner{max-width:var(--w-max);margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;gap:32px}
.nav-logo img{height:34px;width:auto}
.nav-links{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--c-slate);padding:8px 14px;border-radius:var(--r-sm);transition:color var(--t),background var(--t)}
.nav-links a:hover{color:var(--c-primary);background:var(--c-primary-light)}
.nav-ctas{display:flex;align-items:center;gap:10px;margin-left:12px}
.btn-nav-login{font-size:14px;font-weight:600;color:var(--c-slate);padding:8px 16px;border-radius:var(--r-sm);border:1px solid var(--c-border);transition:all var(--t)}
.btn-nav-login:hover{color:var(--c-primary);border-color:var(--c-primary);background:var(--c-primary-light)}
.btn-nav-demo{font-size:14px;font-weight:700;color:#fff;background:var(--c-primary);padding:9px 20px;border-radius:var(--r-sm);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-nav-demo:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;margin-left:auto}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--c-navy-mid);border-radius:2px}
.mobile-menu{display:none;flex-direction:column;background:var(--c-white);padding:16px 24px 24px;border-top:1px solid var(--c-border)}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:15px;font-weight:500;color:var(--c-slate);padding:12px 0;border-bottom:1px solid var(--c-border)}
.mobile-menu a:last-child{border-bottom:none}

/* BREADCRUMB */
.breadcrumb-bar{background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:10px 0}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--c-muted)}
.breadcrumb a{color:var(--c-muted);transition:color var(--t)}
.breadcrumb a:hover{color:var(--c-primary)}
.breadcrumb-sep{color:var(--c-subtle);font-size:11px}
.breadcrumb-current{color:var(--c-slate);font-weight:600}

/* ── HERO ─────────────────────────────────────── */
.mkt-hero{
  background:var(--c-navy);
  background-image:
    radial-gradient(ellipse 55% 70% at 18% 55%, rgba(124,58,237,0.16) 0%, transparent 55%),
    radial-gradient(ellipse 40% 50% at 80% 25%, rgba(37,99,235,0.08) 0%, transparent 50%);
  padding:72px 0 80px;
  overflow:hidden;
  position:relative;
}
.mkt-hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.04) 1px,transparent 1px);background-size:32px 32px;pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1fr 480px;gap:60px;align-items:start;position:relative}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(124,58,237,0.18);border:1px solid rgba(124,58,237,0.35);color:#C4B5FD;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 14px;border-radius:100px;margin-bottom:22px}
.hero-tag-dot{width:6px;height:6px;border-radius:50%;background:#A78BFA;animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.75)}}
.mkt-hero h1{font-family:var(--font-display);font-size:clamp(32px,4.2vw,50px);font-weight:800;line-height:1.1;letter-spacing:-0.03em;color:#fff;margin-bottom:20px}
.mkt-hero h1 em{font-style:normal;color:#A78BFA}
.mkt-hero .sub{font-size:17.5px;line-height:1.65;color:rgba(255,255,255,0.65);max-width:500px;margin-bottom:36px}
.mkt-hero .sub strong{color:rgba(255,255,255,0.90);font-weight:600}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:36px}
.btn-primary{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:700;color:#fff;background:var(--c-purple);padding:14px 28px;border-radius:var(--r);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-primary:hover{background:var(--c-purple-dark);transform:translateY(-2px);box-shadow:var(--sh-purple)}
.btn-outline{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:600;color:rgba(255,255,255,0.80);background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.18);padding:14px 24px;border-radius:var(--r);transition:all var(--t)}
.btn-outline:hover{background:rgba(255,255,255,0.14);color:#fff;border-color:rgba(255,255,255,0.35)}
.hero-signals{display:flex;flex-direction:column;gap:9px}
.hero-signal{display:flex;align-items:center;gap:9px;font-size:13.5px;color:rgba(255,255,255,0.55)}
.hero-signal svg{flex-shrink:0;color:#4ADE80}

/* ── MARKETPLACE MOCKUP ───────────────────────── */
.mkt-panel{
  background:var(--c-white);
  border-radius:var(--r-xl);
  overflow:hidden;
  box-shadow:0 24px 64px rgba(0,0,0,0.40),0 4px 16px rgba(124,58,237,0.15);
  border:1px solid rgba(255,255,255,0.10);
}
.mkt-panel-header{
  background:var(--c-navy-mid);
  padding:13px 18px;
  display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.mkt-panel-id{display:flex;align-items:center;gap:10px}
.mkt-panel-icon{width:28px;height:28px;background:rgba(124,58,237,0.25);border:1px solid rgba(124,58,237,0.40);border-radius:7px;display:flex;align-items:center;justify-content:center}
.mkt-panel-name{font-family:var(--font-display);font-size:12.5px;font-weight:700;color:#fff}
.mkt-panel-sub{font-size:10.5px;color:rgba(255,255,255,0.40);margin-top:1px}
.mkt-panel-pill{font-size:11px;font-weight:700;color:#A78BFA;background:rgba(124,58,237,0.18);border:1px solid rgba(124,58,237,0.28);padding:2px 9px;border-radius:100px}

/* Listing grid */
.mkt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:14px}
.mkt-card{
  background:var(--c-bg);
  border:1px solid var(--c-border);
  border-radius:var(--r-lg);
  overflow:hidden;
  transition:box-shadow var(--t),transform var(--t);
  cursor:pointer;
}
.mkt-card:hover{box-shadow:var(--sh-sm);transform:translateY(-1px)}
.mkt-card-img{
  height:70px;
  display:flex;align-items:center;justify-content:center;
  font-size:28px;
}
.mkt-card-body{padding:8px 10px}
.mkt-card-name{font-size:11.5px;font-weight:700;color:var(--c-navy-mid);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mkt-card-price{font-size:13px;font-weight:800;color:var(--c-purple);font-family:var(--font-display)}
.mkt-card-seller{font-size:10px;color:var(--c-muted);margin-top:2px}
.mkt-card-badge{
  display:inline-flex;align-items:center;gap:3px;
  font-size:9px;font-weight:700;padding:1.5px 6px;border-radius:3px;margin-top:4px;
}
.badge-admin{background:rgba(124,58,237,0.12);color:var(--c-purple)}
.badge-res{background:var(--c-green-light);color:var(--c-green)}

/* ── PROOF STRIP ──────────────────────────────── */
.proof-strip{background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:18px 0}
.proof-inner{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}
.proof-item{display:flex;align-items:center;gap:10px;padding:10px 28px;border-right:1px solid var(--c-border)}
.proof-item:last-child{border-right:none}
.proof-icon{width:34px;height:34px;background:var(--c-purple-light);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.proof-text-main{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.proof-text-sub{font-size:11.5px;color:var(--c-muted)}

/* ── SECTIONS ─────────────────────────────────── */
.section{padding:88px 0}
.section-alt{background:var(--c-bg)}
.section-navy{background:var(--c-navy)}
.section-eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--c-purple);margin-bottom:14px}
.section-eyebrow-bar{width:24px;height:2px;background:var(--c-purple);border-radius:2px}
.section-h2{font-family:var(--font-display);font-size:clamp(26px,3vw,38px);font-weight:800;line-height:1.15;letter-spacing:-0.025em;color:var(--c-navy);margin-bottom:14px}
.section-h2.light{color:#fff}
.section-sub{font-size:17px;line-height:1.65;color:var(--c-muted);max-width:560px}

/* ── TWO AUDIENCES ────────────────────────────── */
.audiences-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:52px}
.audience-card{
  border-radius:var(--r-xl);
  padding:36px 32px;
  border:2px solid var(--c-border);
  transition:border-color var(--t),box-shadow var(--t),transform var(--t);
  position:relative;overflow:hidden;
}
.audience-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  border-radius:var(--r-xl) var(--r-xl) 0 0;
}
.audience-card.residents{background:var(--c-white)}
.audience-card.residents::before{background:var(--c-green)}
.audience-card.admin{background:var(--c-white)}
.audience-card.admin::before{background:var(--c-purple)}
.audience-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}
.audience-icon{font-size:40px;margin-bottom:18px}
.audience-eyebrow{font-size:11.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;margin-bottom:8px}
.audience-card.residents .audience-eyebrow{color:var(--c-green)}
.audience-card.admin .audience-eyebrow{color:var(--c-purple)}
.audience-card h3{font-family:var(--font-display);font-size:22px;font-weight:800;color:var(--c-navy);margin-bottom:12px;letter-spacing:-0.02em}
.audience-card p{font-size:15px;color:var(--c-muted);line-height:1.65;margin-bottom:20px}
.audience-examples{display:flex;flex-direction:column;gap:8px}
.audience-ex{
  display:flex;align-items:center;gap:10px;
  font-size:14px;color:var(--c-body);
  padding:9px 12px;
  border-radius:var(--r);
}
.audience-card.residents .audience-ex{background:var(--c-green-light)}
.audience-card.admin .audience-ex{background:var(--c-purple-light)}
.audience-ex-icon{font-size:18px;flex-shrink:0}

/* ── HOW IT WORKS ─────────────────────────────── */
.flow-section{padding:88px 0;background:var(--c-navy)}
.flow-steps{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;gap:0;align-items:start;margin-top:52px}
.flow-step{text-align:center;padding:0 8px}
.flow-num{width:52px;height:52px;border-radius:14px;background:rgba(124,58,237,0.20);border:1px solid rgba(124,58,237,0.35);color:#C4B5FD;font-family:var(--font-display);font-size:20px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;transition:all var(--t)}
.flow-step:hover .flow-num{background:var(--c-purple);border-color:var(--c-purple);color:#fff}
.flow-step h4{font-family:var(--font-display);font-size:16px;font-weight:700;color:#fff;margin-bottom:8px}
.flow-step p{font-size:13.5px;color:rgba(255,255,255,0.55);line-height:1.55;max-width:200px;margin:0 auto}
.flow-arrow{display:flex;align-items:flex-start;padding-top:24px;color:rgba(255,255,255,0.20);font-size:22px}

/* ── TRUST / CONTEXT ──────────────────────────── */
.trust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.trust-card{
  background:var(--c-white);border:1.5px solid var(--c-border);
  border-radius:var(--r-lg);padding:24px 20px;
  border-top:4px solid var(--c-purple);
  transition:box-shadow var(--t),transform var(--t);
}
.trust-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}
.trust-icon{width:44px;height:44px;background:var(--c-purple-light);border-radius:11px;display:flex;align-items:center;justify-content:center;margin-bottom:14px;font-size:22px}
.trust-card h4{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--c-navy-mid);margin-bottom:7px}
.trust-card p{font-size:14px;color:var(--c-muted);line-height:1.55}

/* ── INTEGRATION ──────────────────────────────── */
.integ-card{
  background:var(--c-white);border:1.5px solid var(--c-border);
  border-radius:var(--r-lg);padding:28px 24px;
  display:flex;align-items:flex-start;gap:16px;
  max-width:600px;margin:44px auto 0;
  transition:border-color var(--t);
}
.integ-card:hover{border-color:rgba(124,58,237,0.35)}
.integ-icon{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.integ-title{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--c-navy-mid);margin-bottom:6px}
.integ-desc{font-size:14.5px;color:var(--c-muted);line-height:1.60}

/* ── FAQ ──────────────────────────────────────── */
.faq-grid{display:grid;grid-template-columns:300px 1fr;gap:64px;align-items:start}
.faq-sidebar h3{font-family:var(--font-display);font-size:24px;font-weight:800;color:var(--c-navy);margin-bottom:12px;letter-spacing:-0.02em}
.faq-sidebar p{font-size:15px;color:var(--c-muted);line-height:1.6;margin-bottom:22px}
.faq-contact{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--c-purple);transition:gap var(--t)}
.faq-contact:hover{gap:12px}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--c-border)}
.faq-item:first-child{border-top:1px solid var(--c-border)}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0;text-align:left;font-size:15px;font-weight:600;color:var(--c-navy-mid);background:none;cursor:pointer;transition:color var(--t)}
.faq-question:hover,.faq-item.open .faq-question{color:var(--c-purple)}
.faq-question svg{flex-shrink:0;transition:transform var(--t);color:var(--c-subtle)}
.faq-item.open .faq-question svg{transform:rotate(180deg);color:var(--c-purple)}
.faq-answer{overflow:hidden;max-height:0;transition:max-height 0.35s cubic-bezier(0.4,0,0.2,1)}
.faq-answer-inner{padding:0 0 22px;font-size:15px;color:var(--c-muted);line-height:1.70}

/* ── FINAL CTA ────────────────────────────────── */
.final-cta{background:linear-gradient(135deg,#4C1D95 0%,var(--c-purple) 50%,#6D28D9 100%);text-align:center;padding:96px 0;position:relative;overflow:hidden}
.final-cta::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.07) 1px,transparent 1px);background-size:28px 28px}
.final-cta h2{font-family:var(--font-display);font-size:clamp(28px,4vw,44px);font-weight:800;color:#fff;letter-spacing:-0.025em;line-height:1.1;margin-bottom:14px;position:relative}
.final-cta p{font-size:17px;color:rgba(255,255,255,0.75);max-width:500px;margin:0 auto 36px;line-height:1.6;position:relative}
.final-ctas{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;position:relative}
.btn-cta-white{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:800;color:var(--c-purple);background:#fff;padding:16px 32px;border-radius:var(--r);transition:all var(--t);box-shadow:0 4px 20px rgba(0,0,0,0.15)}
.btn-cta-white:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,0.20)}
.btn-cta-wa{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:700;color:#fff;background:rgba(255,255,255,0.15);border:1.5px solid rgba(255,255,255,0.35);padding:15px 28px;border-radius:var(--r);transition:all var(--t)}
.btn-cta-wa:hover{background:rgba(255,255,255,0.22);border-color:rgba(255,255,255,0.55)}

/* FOOTER */
/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,0.70);backdrop-filter:blur(6px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity 0.25s ease}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{background:var(--c-white);border-radius:var(--r-xl);width:100%;max-width:560px;overflow:hidden;box-shadow:var(--sh-lg);transform:translateY(20px) scale(0.97);transition:transform 0.25s ease}
.modal-overlay.open .modal-box{transform:translateY(0) scale(1)}
.modal-header{background:linear-gradient(135deg,var(--c-navy) 0%,var(--c-navy-mid) 100%);padding:28px 32px 24px;position:relative}
.modal-header h2{font-family:var(--font-display);font-size:22px;font-weight:800;color:#fff;margin-bottom:6px;letter-spacing:-0.02em}
.modal-header p{font-size:14px;color:rgba(255,255,255,0.60)}
.modal-close{position:absolute;top:16px;right:20px;color:rgba(255,255,255,0.50);font-size:22px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.modal-close:hover{color:#fff}
.modal-body{padding:28px 32px 32px}
.modal-option-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:22px}
.modal-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 14px;border-radius:var(--r-lg);border:2px solid var(--c-border);cursor:pointer;text-align:center;transition:all var(--t);text-decoration:none;color:inherit}
.modal-option:hover{border-color:var(--c-purple);background:var(--c-purple-light)}
.modal-option.option-wa:hover{border-color:#25D366;background:#F0FDF4}
.modal-option-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px}
.opt-title{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.opt-sub{font-size:12px;color:var(--c-muted)}
.modal-divider{display:flex;align-items:center;gap:12px;color:var(--c-subtle);font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:20px}
.modal-divider::before,.modal-divider::after{content:'';flex:1;height:1px;background:var(--c-border)}
.modal-form{display:flex;flex-direction:column;gap:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-field{display:flex;flex-direction:column;gap:5px}
.form-field label{font-size:12.5px;font-weight:700;color:var(--c-slate);letter-spacing:.02em}
.form-field input,.form-field select{font-family:var(--font-body);font-size:14px;color:var(--c-body);background:var(--c-bg);border:1.5px solid var(--c-border);border-radius:var(--r);padding:11px 14px;outline:none;transition:border-color var(--t),box-shadow var(--t);width:100%}
.form-field input:focus,.form-field select:focus{border-color:var(--c-purple);box-shadow:0 0 0 3px rgba(124,58,237,0.12)}
.btn-form-submit{font-family:var(--font-body);font-size:15px;font-weight:800;color:#fff;background:var(--c-purple);padding:14px 24px;border-radius:var(--r);border:none;cursor:pointer;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--t);margin-top:4px}
.btn-form-submit:hover{background:var(--c-purple-dark);transform:translateY(-1px);box-shadow:var(--sh-purple)}
.modal-thanks{display:none;text-align:center;padding:32px}
.modal-thanks-icon{width:64px;height:64px;background:var(--c-purple-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-size:32px}

.fade-up{opacity:0;transform:translateY(24px);transition:opacity 0.55s ease,transform 0.55s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up.d1{transition-delay:.08s}.fade-up.d2{transition-delay:.16s}.fade-up.d3{transition-delay:.24s}

@media(max-width:1060px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .audiences-grid{grid-template-columns:1fr}
  .flow-steps{grid-template-columns:1fr;gap:24px}
  .flow-arrow{display:none}
  .trust-grid{grid-template-columns:1fr}
  .faq-grid{grid-template-columns:1fr;gap:36px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
}
@media(max-width:640px){
  .nav-links,.nav-ctas{display:none}
  .nav-hamburger{display:flex}
  .mkt-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr}
  .modal-option-row,.form-row{grid-template-columns:1fr}
  .proof-inner{flex-direction:column}
  .proof-item{border-right:none;border-bottom:1px solid var(--c-border);width:100%;justify-content:center}
  .proof-item:last-child{border-bottom:none}
}

/* ----- parqueaderos.html ----- */
/* ANN BAR */
.ann-bar{background:var(--c-navy-mid);color:#fff;padding:10px 24px;font-size:13.5px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:12px;position:relative}
.ann-bar a{color:#5EEAD4;text-decoration:underline;text-underline-offset:2px}
.ann-badge{background:var(--c-teal);color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:2px 8px;border-radius:4px;white-space:nowrap}
.ann-close{position:absolute;right:20px;top:50%;transform:translateY(-50%);color:var(--c-subtle);font-size:18px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.ann-close:hover{color:#fff}

/* NAV */
.nav{position:sticky;top:0;z-index:900;background:rgba(255,255,255,0.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--c-border);box-shadow:0 1px 3px rgba(15,23,42,0.06)}
.nav-inner{max-width:var(--w-max);margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;gap:32px}
.nav-logo img{height:34px;width:auto}
.nav-links{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--c-slate);padding:8px 14px;border-radius:var(--r-sm);transition:color var(--t),background var(--t)}
.nav-links a:hover{color:var(--c-primary);background:var(--c-primary-light)}
.nav-ctas{display:flex;align-items:center;gap:10px;margin-left:12px}
.btn-nav-login{font-size:14px;font-weight:600;color:var(--c-slate);padding:8px 16px;border-radius:var(--r-sm);border:1px solid var(--c-border);transition:all var(--t)}
.btn-nav-login:hover{color:var(--c-primary);border-color:var(--c-primary);background:var(--c-primary-light)}
.btn-nav-demo{font-size:14px;font-weight:700;color:#fff;background:var(--c-primary);padding:9px 20px;border-radius:var(--r-sm);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-nav-demo:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;margin-left:auto}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--c-navy-mid);border-radius:2px}
.mobile-menu{display:none;flex-direction:column;background:var(--c-white);padding:16px 24px 24px;border-top:1px solid var(--c-border)}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:15px;font-weight:500;color:var(--c-slate);padding:12px 0;border-bottom:1px solid var(--c-border)}
.mobile-menu a:last-child{border-bottom:none}

/* BREADCRUMB */
.breadcrumb-bar{background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:10px 0}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--c-muted)}
.breadcrumb a{color:var(--c-muted);transition:color var(--t)}
.breadcrumb a:hover{color:var(--c-primary)}
.breadcrumb-sep{color:var(--c-subtle);font-size:11px}
.breadcrumb-current{color:var(--c-slate);font-weight:600}

/* ── HERO ─────────────────────────────────────── */
.park-hero{
  background:var(--c-navy);
  background-image:
    radial-gradient(ellipse 55% 70% at 18% 55%, rgba(13,148,136,0.16) 0%, transparent 55%),
    radial-gradient(ellipse 40% 50% at 80% 20%, rgba(37,99,235,0.08) 0%, transparent 50%);
  padding:72px 0 80px;
  overflow:hidden;
  position:relative;
}
.park-hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.04) 1px,transparent 1px);background-size:32px 32px;pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1fr 460px;gap:60px;align-items:start;position:relative}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(13,148,136,0.18);border:1px solid rgba(13,148,136,0.35);color:#5EEAD4;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 14px;border-radius:100px;margin-bottom:22px}
.hero-tag-dot{width:6px;height:6px;border-radius:50%;background:#2DD4BF;animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.75)}}
.park-hero h1{font-family:var(--font-display);font-size:clamp(32px,4.2vw,50px);font-weight:800;line-height:1.1;letter-spacing:-0.03em;color:#fff;margin-bottom:20px}
.park-hero h1 em{font-style:normal;color:#2DD4BF}
.park-hero .sub{font-size:17.5px;line-height:1.65;color:rgba(255,255,255,0.65);max-width:500px;margin-bottom:36px}
.park-hero .sub strong{color:rgba(255,255,255,0.90);font-weight:600}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:36px}
.btn-primary{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:700;color:#fff;background:var(--c-teal);padding:14px 28px;border-radius:var(--r);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-primary:hover{background:var(--c-teal-dark);transform:translateY(-2px);box-shadow:var(--sh-teal)}
.btn-outline{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:600;color:rgba(255,255,255,0.80);background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.18);padding:14px 24px;border-radius:var(--r);transition:all var(--t)}
.btn-outline:hover{background:rgba(255,255,255,0.14);color:#fff;border-color:rgba(255,255,255,0.35)}
.hero-signals{display:flex;flex-direction:column;gap:9px}
.hero-signal{display:flex;align-items:center;gap:9px;font-size:13.5px;color:rgba(255,255,255,0.55)}
.hero-signal svg{flex-shrink:0;color:#4ADE80}

/* ── PARKING PANEL MOCKUP ─────────────────────── */
.park-panel{
  background:var(--c-white);
  border-radius:var(--r-xl);
  overflow:hidden;
  box-shadow:0 24px 64px rgba(0,0,0,0.40),0 4px 16px rgba(13,148,136,0.15);
  border:1px solid rgba(255,255,255,0.10);
}
.pp-header{
  background:var(--c-navy-mid);
  padding:13px 18px;
  display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.pp-id{display:flex;align-items:center;gap:10px}
.pp-icon{width:28px;height:28px;background:rgba(13,148,136,0.25);border:1px solid rgba(13,148,136,0.40);border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:14px}
.pp-name{font-family:var(--font-display);font-size:12.5px;font-weight:700;color:#fff}
.pp-sub{font-size:10.5px;color:rgba(255,255,255,0.40);margin-top:1px}
.pp-stats{display:flex;gap:8px}
.pp-stat{font-size:10.5px;font-weight:700;padding:2px 8px;border-radius:100px}
.pp-stat.occupied{background:rgba(220,38,38,0.18);color:#FCA5A5}
.pp-stat.free{background:rgba(13,148,136,0.18);color:#5EEAD4}
.pp-stat.reserved{background:rgba(217,119,6,0.18);color:#FCD34D}

/* Parking grid */
.pp-grid-section{padding:12px 14px 8px}
.pp-grid-label{font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--c-subtle);margin-bottom:8px}
.pp-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;margin-bottom:12px}
.pp-spot{
  height:36px;border-radius:6px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-size:9px;font-weight:700;
  border:1.5px solid;
  position:relative;
}
.pp-spot.resident{background:#EFF6FF;border-color:#BFDBFE;color:#1D4ED8}
.pp-spot.visitor-free{background:var(--c-teal-light);border-color:#99F6E4;color:var(--c-teal)}
.pp-spot.visitor-occupied{background:#FEF2F2;border-color:#FECACA;color:#DC2626}
.pp-spot.reserved{background:#FFFBEB;border-color:#FDE68A;color:#D97706}
.pp-spot-num{font-size:8px;opacity:.7;margin-top:1px}

/* Recent activity */
.pp-activity{padding:0 14px 12px}
.pp-activity-label{font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--c-subtle);margin-bottom:8px}
.pp-row{display:flex;align-items:center;gap:8px;padding:7px 10px;background:var(--c-bg);border:1px solid var(--c-border);border-radius:var(--r-sm);margin-bottom:5px}
.pp-row:last-child{margin-bottom:0}
.pp-row-icon{width:26px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.pp-row-body{flex:1}
.pp-row-title{font-size:11.5px;font-weight:600;color:var(--c-navy-mid)}
.pp-row-meta{font-size:10px;color:var(--c-muted)}
.pp-row-right{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.pp-row-time{font-size:10px;color:var(--c-subtle);font-weight:600}
.pp-badge{font-size:9.5px;font-weight:700;padding:1.5px 6px;border-radius:3px}
.badge-ingreso{background:var(--c-teal-light);color:var(--c-teal)}
.badge-pago{background:var(--c-green-light);color:var(--c-green)}
.badge-reserva{background:var(--c-amber-light);color:var(--c-amber)}

/* ── PROOF STRIP ──────────────────────────────── */
.proof-strip{background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:18px 0}
.proof-inner{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}
.proof-item{display:flex;align-items:center;gap:10px;padding:10px 28px;border-right:1px solid var(--c-border)}
.proof-item:last-child{border-right:none}
.proof-icon{width:34px;height:34px;background:var(--c-teal-light);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.proof-text-main{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.proof-text-sub{font-size:11.5px;color:var(--c-muted)}

/* ── SECTIONS ─────────────────────────────────── */
.section{padding:88px 0}
.section-alt{background:var(--c-bg)}
.section-navy{background:var(--c-navy)}
.section-eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--c-teal);margin-bottom:14px}
.section-eyebrow-bar{width:24px;height:2px;background:var(--c-teal);border-radius:2px}
.section-h2{font-family:var(--font-display);font-size:clamp(26px,3vw,38px);font-weight:800;line-height:1.15;letter-spacing:-0.025em;color:var(--c-navy);margin-bottom:14px}
.section-h2.light{color:#fff}
.section-sub{font-size:17px;line-height:1.65;color:var(--c-muted);max-width:560px}
.section-sub.light{color:rgba(255,255,255,.68)}

/* ── INGRESOS CALLOUT ─────────────────────────── */
.ingresos-callout{
  background:var(--c-navy);
  border-radius:var(--r-xl);
  padding:44px 48px;
  display:flex;align-items:flex-start;gap:32px;
  position:relative;overflow:hidden;
  margin-top:52px;
}
.ingresos-callout::before{
  content:'🅿️';
  position:absolute;right:32px;bottom:-12px;
  font-size:120px;opacity:.06;
  user-select:none;pointer-events:none;
  line-height:1;
}
.ingresos-icon{
  width:60px;height:60px;flex-shrink:0;
  background:rgba(13,148,136,0.20);
  border:1px solid rgba(13,148,136,0.35);
  border-radius:16px;
  display:flex;align-items:center;justify-content:center;
  font-size:28px;
}
.ingresos-body h3{font-family:var(--font-display);font-size:22px;font-weight:800;color:#fff;margin-bottom:10px;letter-spacing:-0.02em}
.ingresos-body p{font-size:16px;color:rgba(255,255,255,0.65);line-height:1.65;max-width:560px;margin-bottom:16px}
.ingresos-body p strong{color:rgba(255,255,255,0.90);font-weight:600}
.ingresos-tag{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12.5px;font-weight:700;
  background:rgba(13,148,136,0.18);
  border:1px solid rgba(13,148,136,0.30);
  color:#5EEAD4;padding:5px 14px;border-radius:100px;
}

/* ── THREE USE CASES ──────────────────────────── */
.use-cases{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:52px}
.use-card{
  background:var(--c-white);
  border:1.5px solid var(--c-border);
  border-radius:var(--r-lg);
  padding:28px 22px;
  border-top:4px solid var(--c-teal);
  transition:box-shadow var(--t),transform var(--t);
}
.use-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}
.use-icon{font-size:36px;margin-bottom:16px}
.use-card h4{font-family:var(--font-display);font-size:17px;font-weight:800;color:var(--c-navy-mid);margin-bottom:8px;letter-spacing:-0.02em}
.use-card p{font-size:14px;color:var(--c-muted);line-height:1.60}
.use-chip{
  display:inline-flex;align-items:center;gap:4px;
  font-size:11.5px;font-weight:700;
  background:var(--c-teal-light);color:var(--c-teal);
  padding:2px 10px;border-radius:100px;margin-top:12px;
}

/* ── RESERVATIONS FLOW ────────────────────────── */
.flow-section{padding:88px 0;background:var(--c-navy)}
.flow-grid{display:grid;grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;gap:0;align-items:start;margin-top:52px}
.flow-step{text-align:center;padding:0 6px}
.flow-num{width:50px;height:50px;border-radius:14px;background:rgba(13,148,136,0.20);border:1px solid rgba(13,148,136,0.35);color:#5EEAD4;font-family:var(--font-display);font-size:20px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;transition:all var(--t)}
.flow-step:hover .flow-num{background:var(--c-teal);border-color:var(--c-teal);color:#fff}
.flow-step h4{font-family:var(--font-display);font-size:15px;font-weight:700;color:#fff;margin-bottom:7px}
.flow-step p{font-size:13px;color:rgba(255,255,255,0.55);line-height:1.55;max-width:170px;margin:0 auto}
.flow-arrow{display:flex;align-items:flex-start;padding-top:22px;color:rgba(255,255,255,0.20);font-size:20px}

/* ── TREND SECTION ────────────────────────────── */
.trend-section{
  background:var(--c-teal);
  padding:56px 0;
  position:relative;overflow:hidden;
}
.trend-section::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.06) 1px,transparent 1px);background-size:24px 24px}
.trend-inner{display:flex;align-items:center;gap:48px;position:relative;flex-wrap:wrap}
.trend-text{flex:1;min-width:280px}
.trend-eyebrow{font-size:11.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:rgba(255,255,255,0.65);margin-bottom:10px}
.trend-text h2{font-family:var(--font-display);font-size:clamp(22px,2.8vw,32px);font-weight:800;color:#fff;letter-spacing:-0.025em;line-height:1.15;margin-bottom:14px}
.trend-text p{font-size:16px;color:rgba(255,255,255,0.75);line-height:1.65}
.trend-stat-box{
  background:rgba(255,255,255,0.12);
  border:1px solid rgba(255,255,255,0.20);
  border-radius:var(--r-xl);
  padding:28px 32px;
  min-width:220px;
  text-align:center;
  flex-shrink:0;
}
.trend-stat-num{font-family:var(--font-display);font-size:42px;font-weight:800;color:#fff;line-height:1;margin-bottom:6px}
.trend-stat-label{font-size:14px;color:rgba(255,255,255,0.70);line-height:1.45}

/* ── INTEGRATION ──────────────────────────────── */
.integ-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:44px}
.integ-card{
  background:var(--c-white);border:1.5px solid var(--c-border);
  border-radius:var(--r-lg);padding:22px 18px;
  display:flex;align-items:flex-start;gap:14px;
  transition:border-color var(--t),box-shadow var(--t);
}
.integ-card:hover{border-color:rgba(13,148,136,0.35);box-shadow:var(--sh-sm)}
.integ-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.integ-title{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--c-navy-mid);margin-bottom:5px}
.integ-desc{font-size:13.5px;color:var(--c-muted);line-height:1.55}

/* ── FAQ ──────────────────────────────────────── */
.faq-grid{display:grid;grid-template-columns:300px 1fr;gap:64px;align-items:start}
.faq-sidebar h3{font-family:var(--font-display);font-size:24px;font-weight:800;color:var(--c-navy);margin-bottom:12px;letter-spacing:-0.02em}
.faq-sidebar p{font-size:15px;color:var(--c-muted);line-height:1.6;margin-bottom:22px}
.faq-contact{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--c-teal);transition:gap var(--t)}
.faq-contact:hover{gap:12px}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--c-border)}
.faq-item:first-child{border-top:1px solid var(--c-border)}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0;text-align:left;font-size:15px;font-weight:600;color:var(--c-navy-mid);background:none;cursor:pointer;transition:color var(--t)}
.faq-question:hover,.faq-item.open .faq-question{color:var(--c-teal)}
.faq-question svg{flex-shrink:0;transition:transform var(--t);color:var(--c-subtle)}
.faq-item.open .faq-question svg{transform:rotate(180deg);color:var(--c-teal)}
.faq-answer{overflow:hidden;max-height:0;transition:max-height 0.35s cubic-bezier(0.4,0,0.2,1)}
.faq-answer-inner{padding:0 0 22px;font-size:15px;color:var(--c-muted);line-height:1.70}

/* ── FINAL CTA ────────────────────────────────── */
.final-cta{background:linear-gradient(135deg,#0F766E 0%,var(--c-teal) 50%,#0891B2 100%);text-align:center;padding:96px 0;position:relative;overflow:hidden}
.final-cta::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.07) 1px,transparent 1px);background-size:28px 28px}
.final-cta h2{font-family:var(--font-display);font-size:clamp(26px,4vw,42px);font-weight:800;color:#fff;letter-spacing:-0.025em;line-height:1.15;margin-bottom:14px;position:relative}
.final-cta p{font-size:17px;color:rgba(255,255,255,0.75);max-width:500px;margin:0 auto 36px;line-height:1.6;position:relative}
.final-ctas{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;position:relative}
.btn-cta-white{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:800;color:var(--c-teal-dark);background:#fff;padding:16px 32px;border-radius:var(--r);transition:all var(--t);box-shadow:0 4px 20px rgba(0,0,0,0.15)}
.btn-cta-white:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,0.20)}
.btn-cta-wa{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:700;color:#fff;background:rgba(255,255,255,0.15);border:1.5px solid rgba(255,255,255,0.35);padding:15px 28px;border-radius:var(--r);transition:all var(--t)}
.btn-cta-wa:hover{background:rgba(255,255,255,0.22);border-color:rgba(255,255,255,0.55)}

/* FOOTER */
/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,0.70);backdrop-filter:blur(6px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity 0.25s ease}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{background:var(--c-white);border-radius:var(--r-xl);width:100%;max-width:560px;overflow:hidden;box-shadow:var(--sh-lg);transform:translateY(20px) scale(0.97);transition:transform 0.25s ease}
.modal-overlay.open .modal-box{transform:translateY(0) scale(1)}
.modal-header{background:linear-gradient(135deg,var(--c-navy) 0%,var(--c-navy-mid) 100%);padding:28px 32px 24px;position:relative}
.modal-header h2{font-family:var(--font-display);font-size:22px;font-weight:800;color:#fff;margin-bottom:6px;letter-spacing:-0.02em}
.modal-header p{font-size:14px;color:rgba(255,255,255,0.60)}
.modal-close{position:absolute;top:16px;right:20px;color:rgba(255,255,255,0.50);font-size:22px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.modal-close:hover{color:#fff}
.modal-body{padding:28px 32px 32px}
.modal-option-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:22px}
.modal-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 14px;border-radius:var(--r-lg);border:2px solid var(--c-border);cursor:pointer;text-align:center;transition:all var(--t);text-decoration:none;color:inherit}
.modal-option:hover{border-color:var(--c-teal);background:var(--c-teal-light)}
.modal-option.option-wa:hover{border-color:#25D366;background:#F0FDF4}
.modal-option-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px}
.opt-title{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.opt-sub{font-size:12px;color:var(--c-muted)}
.modal-divider{display:flex;align-items:center;gap:12px;color:var(--c-subtle);font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:20px}
.modal-divider::before,.modal-divider::after{content:'';flex:1;height:1px;background:var(--c-border)}
.modal-form{display:flex;flex-direction:column;gap:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-field{display:flex;flex-direction:column;gap:5px}
.form-field label{font-size:12.5px;font-weight:700;color:var(--c-slate);letter-spacing:.02em}
.form-field input,.form-field select{font-family:var(--font-body);font-size:14px;color:var(--c-body);background:var(--c-bg);border:1.5px solid var(--c-border);border-radius:var(--r);padding:11px 14px;outline:none;transition:border-color var(--t),box-shadow var(--t);width:100%}
.form-field input:focus,.form-field select:focus{border-color:var(--c-teal);box-shadow:0 0 0 3px rgba(13,148,136,0.12)}
.btn-form-submit{font-family:var(--font-body);font-size:15px;font-weight:800;color:#fff;background:var(--c-teal);padding:14px 24px;border-radius:var(--r);border:none;cursor:pointer;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--t);margin-top:4px}
.btn-form-submit:hover{background:var(--c-teal-dark);transform:translateY(-1px);box-shadow:var(--sh-teal)}
.modal-thanks{display:none;text-align:center;padding:32px}
.modal-thanks-icon{width:64px;height:64px;background:var(--c-teal-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-size:32px}

.fade-up{opacity:0;transform:translateY(24px);transition:opacity 0.55s ease,transform 0.55s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up.d1{transition-delay:.08s}.fade-up.d2{transition-delay:.16s}.fade-up.d3{transition-delay:.24s}

@media(max-width:1060px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .use-cases{grid-template-columns:1fr}
  .flow-grid{grid-template-columns:1fr;gap:20px}
  .flow-arrow{display:none}
  .integ-grid{grid-template-columns:1fr}
  .faq-grid{grid-template-columns:1fr;gap:36px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
  .ingresos-callout{flex-direction:column;gap:20px;padding:32px 28px}
  .trend-inner{flex-direction:column;gap:32px}
}
@media(max-width:640px){
  .nav-links,.nav-ctas{display:none}
  .nav-hamburger{display:flex}
  .pp-grid{grid-template-columns:repeat(4,1fr)}
  .footer-grid{grid-template-columns:1fr}
  .modal-option-row,.form-row{grid-template-columns:1fr}
  .proof-inner{flex-direction:column}
  .proof-item{border-right:none;border-bottom:1px solid var(--c-border);width:100%;justify-content:center}
  .proof-item:last-child{border-bottom:none}
}

/* ----- app-residente.html ----- */
/* NAV, ANN, BREADCRUMB — same pattern */
.ann-bar{background:var(--c-navy-mid);color:#fff;padding:10px 24px;font-size:13.5px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:12px;position:relative}
.ann-bar a{color:#93C5FD;text-decoration:underline;text-underline-offset:2px}
.ann-badge{background:var(--c-primary);color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:2px 8px;border-radius:4px;white-space:nowrap}
.ann-close{position:absolute;right:20px;top:50%;transform:translateY(-50%);color:var(--c-subtle);font-size:18px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.ann-close:hover{color:#fff}
.nav{position:sticky;top:0;z-index:900;background:rgba(255,255,255,0.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--c-border);box-shadow:0 1px 3px rgba(15,23,42,0.06)}
.nav-inner{max-width:var(--w-max);margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;gap:32px}
.nav-logo img{height:34px;width:auto}
.nav-links{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--c-slate);padding:8px 14px;border-radius:var(--r-sm);transition:color var(--t),background var(--t)}
.nav-links a:hover{color:var(--c-primary);background:var(--c-primary-light)}
.nav-ctas{display:flex;align-items:center;gap:10px;margin-left:12px}
.btn-nav-login{font-size:14px;font-weight:600;color:var(--c-slate);padding:8px 16px;border-radius:var(--r-sm);border:1px solid var(--c-border);transition:all var(--t)}
.btn-nav-login:hover{color:var(--c-primary);border-color:var(--c-primary);background:var(--c-primary-light)}
.btn-nav-demo{font-size:14px;font-weight:700;color:#fff;background:var(--c-primary);padding:9px 20px;border-radius:var(--r-sm);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-nav-demo:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;margin-left:auto}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--c-navy-mid);border-radius:2px}
.mobile-menu{display:none;flex-direction:column;background:var(--c-white);padding:16px 24px 24px;border-top:1px solid var(--c-border)}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:15px;font-weight:500;color:var(--c-slate);padding:12px 0;border-bottom:1px solid var(--c-border)}
.mobile-menu a:last-child{border-bottom:none}
.breadcrumb-bar{background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:10px 0}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--c-muted)}
.breadcrumb a{color:var(--c-muted);transition:color var(--t)}
.breadcrumb a:hover{color:var(--c-primary)}
.breadcrumb-sep{color:var(--c-subtle);font-size:11px}
.breadcrumb-current{color:var(--c-slate);font-weight:600}

/* ── HERO ─────────────────────────────────────── */
.app-hero{
  background:var(--c-navy);
  background-image:
    radial-gradient(ellipse 55% 70% at 20% 50%, rgba(37,99,235,0.20) 0%, transparent 55%),
    radial-gradient(ellipse 40% 50% at 80% 20%, rgba(99,102,241,0.10) 0%, transparent 50%);
  padding:72px 0 0;
  overflow:hidden;
  position:relative;
}
.app-hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.04) 1px,transparent 1px);background-size:32px 32px;pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1fr 340px;gap:64px;align-items:end;padding-bottom:56px;position:relative}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(37,99,235,0.18);border:1px solid rgba(37,99,235,0.35);color:#93C5FD;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 14px;border-radius:100px;margin-bottom:22px}
.hero-tag-dot{width:6px;height:6px;border-radius:50%;background:#60A5FA;animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.75)}}
.app-hero h1{font-family:var(--font-display);font-size:clamp(32px,4.2vw,50px);font-weight:800;line-height:1.1;letter-spacing:-0.03em;color:#fff;margin-bottom:20px}
.app-hero h1 em{font-style:normal;color:#60A5FA}
.app-hero .sub{font-size:17.5px;line-height:1.65;color:rgba(255,255,255,0.65);max-width:500px;margin-bottom:36px}
.app-hero .sub strong{color:rgba(255,255,255,0.90);font-weight:600}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:32px}
.btn-primary{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:700;color:#fff;background:var(--c-primary);padding:14px 28px;border-radius:var(--r);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-primary:hover{background:var(--c-primary-dark);transform:translateY(-2px);box-shadow:var(--sh-blue)}
.btn-outline{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:600;color:rgba(255,255,255,0.80);background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.18);padding:14px 24px;border-radius:var(--r);transition:all var(--t)}
.btn-outline:hover{background:rgba(255,255,255,0.14);color:#fff;border-color:rgba(255,255,255,0.35)}
.hero-stores{display:flex;gap:12px;flex-wrap:wrap;margin-top:4px}
.store-btn{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(255,255,255,0.10);
  border:1px solid rgba(255,255,255,0.20);
  border-radius:var(--r);padding:10px 18px;
  transition:all var(--t);
}
.store-btn:hover{background:rgba(255,255,255,0.18);border-color:rgba(255,255,255,0.35)}
.store-icon{font-size:22px;line-height:1}
.store-text-top{font-size:10px;color:rgba(255,255,255,0.55)}
.store-text-bottom{font-size:14px;font-weight:700;color:#fff;font-family:var(--font-display)}

/* ── PHONE MOCKUP ─────────────────────────────── */
.phone-wrap{display:flex;justify-content:center;align-items:flex-end}
.phone-frame{
  width:220px;
  background:var(--c-navy-mid);
  border-radius:32px;
  border:5px solid rgba(255,255,255,0.15);
  overflow:hidden;
  box-shadow:0 32px 80px rgba(0,0,0,0.50),0 0 0 1px rgba(255,255,255,0.06);
  position:relative;
}
.phone-notch{width:70px;height:20px;background:var(--c-navy-mid);border-radius:0 0 12px 12px;position:absolute;top:0;left:50%;transform:translateX(-50%);z-index:2}
.phone-screen{padding-top:28px;background:var(--c-bg)}

/* App home screen */
.app-screen{background:var(--c-bg);min-height:420px;display:flex;flex-direction:column}
.app-top-bar{background:var(--c-navy-mid);padding:10px 14px 10px;display:flex;align-items:center;justify-content:space-between}
.app-greeting{font-size:10px;color:rgba(255,255,255,0.55)}
.app-user{font-size:12px;font-weight:700;color:#fff}
.app-notif-dot{width:8px;height:8px;border-radius:50%;background:#EF4444;position:relative}

/* Account balance card */
.app-balance-card{
  background:linear-gradient(135deg,var(--c-primary),#1D4ED8);
  margin:10px;border-radius:12px;padding:14px 16px;
  color:#fff;
}
.app-balance-label{font-size:9px;color:rgba(255,255,255,0.65);letter-spacing:.05em;text-transform:uppercase;margin-bottom:3px}
.app-balance-amount{font-family:var(--font-display);font-size:22px;font-weight:800;line-height:1}
.app-balance-status{display:flex;align-items:center;gap:4px;font-size:10px;color:rgba(255,255,255,0.75);margin-top:4px}
.app-balance-dot{width:5px;height:5px;border-radius:50%;background:#4ADE80}

/* Quick actions grid */
.app-actions-label{font-size:9.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--c-subtle);padding:8px 12px 4px}
.app-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:0 10px 6px}
.app-action{
  background:var(--c-white);border-radius:10px;padding:8px 4px;
  display:flex;flex-direction:column;align-items:center;gap:4px;
  box-shadow:0 1px 4px rgba(15,23,42,0.08);
  cursor:pointer;transition:all var(--t);
  border:1px solid var(--c-border);
}
.app-action:hover{border-color:rgba(37,99,235,.30);background:var(--c-primary-light)}
.app-action-icon{font-size:18px;line-height:1}
.app-action-label{font-size:8.5px;font-weight:600;color:var(--c-slate);text-align:center;line-height:1.2}

/* Notification item */
.app-notif-section{padding:0 10px 10px}
.app-notif-label{font-size:9.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--c-subtle);margin-bottom:6px}
.app-notif{
  background:var(--c-white);border-radius:10px;padding:9px 11px;
  border:1px solid var(--c-border);
  display:flex;align-items:center;gap:8px;margin-bottom:5px;
  box-shadow:0 1px 3px rgba(15,23,42,0.06);
}
.app-notif-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px}
.app-notif-title{font-size:10.5px;font-weight:600;color:var(--c-navy-mid)}
.app-notif-sub{font-size:9.5px;color:var(--c-muted)}
.app-notif-time{font-size:9px;color:var(--c-subtle);flex-shrink:0}

/* ── PROOF STRIP ──────────────────────────────── */
.proof-strip{background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:18px 0}
.proof-inner{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}
.proof-item{display:flex;align-items:center;gap:10px;padding:10px 28px;border-right:1px solid var(--c-border)}
.proof-item:last-child{border-right:none}
.proof-icon{width:34px;height:34px;background:var(--c-primary-light);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.proof-text-main{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.proof-text-sub{font-size:11.5px;color:var(--c-muted)}

/* ── SECTIONS ─────────────────────────────────── */
.section{padding:88px 0}
.section-alt{background:var(--c-bg)}
.section-navy{background:var(--c-navy)}
.section-eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--c-primary);margin-bottom:14px}
.section-eyebrow-bar{width:24px;height:2px;background:var(--c-primary);border-radius:2px}
.section-h2{font-family:var(--font-display);font-size:clamp(26px,3vw,38px);font-weight:800;line-height:1.15;letter-spacing:-0.025em;color:var(--c-navy);margin-bottom:14px}
.section-h2.light{color:#fff}
.section-sub{font-size:17px;line-height:1.65;color:var(--c-muted);max-width:560px}
.section-sub.light{color:rgba(255,255,255,.68)}

/* ── FEATURE TILES ────────────────────────────── */
.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:48px}
.feat-tile{
  background:var(--c-white);
  border:1.5px solid var(--c-border);
  border-radius:var(--r-lg);
  padding:24px 20px;
  transition:border-color var(--t),box-shadow var(--t),transform var(--t);
}
.feat-tile:hover{border-color:rgba(37,99,235,.35);box-shadow:var(--sh-md);transform:translateY(-2px)}
.feat-tile-icon{font-size:32px;margin-bottom:14px}
.feat-tile h4{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--c-navy-mid);margin-bottom:6px}
.feat-tile p{font-size:13px;color:var(--c-muted);line-height:1.55}
.feat-tile-link{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:700;color:var(--c-primary);margin-top:10px;transition:gap var(--t)}
.feat-tile:hover .feat-tile-link{gap:8px}

/* ── ECOSYSTEM HUB SECTION ────────────────────── */
.hub-section{padding:88px 0;background:var(--c-navy)}
.hub-grid{display:grid;grid-template-columns:1fr 340px;gap:64px;align-items:center;margin-top:52px}
.hub-modules{display:flex;flex-direction:column;gap:10px}
.hub-module{
  display:flex;align-items:center;gap:14px;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.10);
  border-radius:var(--r-lg);
  padding:14px 18px;
  transition:background var(--t);
}
.hub-module:hover{background:rgba(255,255,255,0.10)}
.hub-mod-icon{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:18px}
.hub-mod-name{font-family:var(--font-display);font-size:15px;font-weight:700;color:#fff;margin-bottom:3px}
.hub-mod-desc{font-size:12.5px;color:rgba(255,255,255,0.50)}
.hub-phone{
  width:200px;margin:0 auto;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.15);
  border-radius:28px;
  padding:20px 16px;
  text-align:center;
}
.hub-phone-icon{font-size:52px;margin-bottom:12px}
.hub-phone-label{font-family:var(--font-display);font-size:15px;font-weight:800;color:#fff;margin-bottom:6px}
.hub-phone-sub{font-size:12px;color:rgba(255,255,255,0.50);line-height:1.5}
.hub-arrow{color:rgba(255,255,255,0.25);font-size:18px;flex-shrink:0;margin-left:auto}

/* ── DOWNLOAD SECTION ─────────────────────────── */
.download-section{
  background:var(--c-primary);
  padding:64px 0;
  text-align:center;
  position:relative;overflow:hidden;
}
.download-section::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.07) 1px,transparent 1px);background-size:28px 28px}
.download-section h2{font-family:var(--font-display);font-size:clamp(26px,3.5vw,40px);font-weight:800;color:#fff;letter-spacing:-0.025em;margin-bottom:10px;position:relative}
.download-section p{font-size:17px;color:rgba(255,255,255,0.75);margin-bottom:32px;position:relative}
.download-btns{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap;position:relative}
.download-btn{
  display:inline-flex;align-items:center;gap:12px;
  background:rgba(255,255,255,0.12);
  border:1.5px solid rgba(255,255,255,0.30);
  border-radius:var(--r-lg);padding:14px 24px;
  transition:all var(--t);
}
.download-btn:hover{background:rgba(255,255,255,0.22);border-color:rgba(255,255,255,0.55)}
.download-btn-icon{font-size:28px}
.download-btn-top{font-size:11px;color:rgba(255,255,255,0.60);display:block}
.download-btn-name{font-family:var(--font-display);font-size:17px;font-weight:800;color:#fff;display:block;margin-top:1px}

/* ── FAQ ──────────────────────────────────────── */
.faq-grid{display:grid;grid-template-columns:300px 1fr;gap:64px;align-items:start}
.faq-sidebar h3{font-family:var(--font-display);font-size:24px;font-weight:800;color:var(--c-navy);margin-bottom:12px;letter-spacing:-0.02em}
.faq-sidebar p{font-size:15px;color:var(--c-muted);line-height:1.6;margin-bottom:22px}
.faq-contact{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--c-primary);transition:gap var(--t)}
.faq-contact:hover{gap:12px}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--c-border)}
.faq-item:first-child{border-top:1px solid var(--c-border)}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0;text-align:left;font-size:15px;font-weight:600;color:var(--c-navy-mid);background:none;cursor:pointer;transition:color var(--t)}
.faq-question:hover,.faq-item.open .faq-question{color:var(--c-primary)}
.faq-question svg{flex-shrink:0;transition:transform var(--t);color:var(--c-subtle)}
.faq-item.open .faq-question svg{transform:rotate(180deg);color:var(--c-primary)}
.faq-answer{overflow:hidden;max-height:0;transition:max-height 0.35s cubic-bezier(0.4,0,0.2,1)}
.faq-answer-inner{padding:0 0 22px;font-size:15px;color:var(--c-muted);line-height:1.70}

/* FOOTER */
/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,0.70);backdrop-filter:blur(6px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity 0.25s ease}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{background:var(--c-white);border-radius:var(--r-xl);width:100%;max-width:560px;overflow:hidden;box-shadow:var(--sh-lg);transform:translateY(20px) scale(0.97);transition:transform 0.25s ease}
.modal-overlay.open .modal-box{transform:translateY(0) scale(1)}
.modal-header{background:linear-gradient(135deg,var(--c-navy) 0%,var(--c-navy-mid) 100%);padding:28px 32px 24px;position:relative}
.modal-header h2{font-family:var(--font-display);font-size:22px;font-weight:800;color:#fff;margin-bottom:6px;letter-spacing:-0.02em}
.modal-header p{font-size:14px;color:rgba(255,255,255,0.60)}
.modal-close{position:absolute;top:16px;right:20px;color:rgba(255,255,255,0.50);font-size:22px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.modal-close:hover{color:#fff}
.modal-body{padding:28px 32px 32px}
.modal-option-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:22px}
.modal-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 14px;border-radius:var(--r-lg);border:2px solid var(--c-border);cursor:pointer;text-align:center;transition:all var(--t);text-decoration:none;color:inherit}
.modal-option:hover{border-color:var(--c-primary);background:var(--c-primary-light)}
.modal-option.option-wa:hover{border-color:#25D366;background:#F0FDF4}
.modal-option-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px}
.opt-title{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.opt-sub{font-size:12px;color:var(--c-muted)}
.modal-divider{display:flex;align-items:center;gap:12px;color:var(--c-subtle);font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:20px}
.modal-divider::before,.modal-divider::after{content:'';flex:1;height:1px;background:var(--c-border)}
.modal-form{display:flex;flex-direction:column;gap:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-field{display:flex;flex-direction:column;gap:5px}
.form-field label{font-size:12.5px;font-weight:700;color:var(--c-slate);letter-spacing:.02em}
.form-field input,.form-field select{font-family:var(--font-body);font-size:14px;color:var(--c-body);background:var(--c-bg);border:1.5px solid var(--c-border);border-radius:var(--r);padding:11px 14px;outline:none;transition:border-color var(--t),box-shadow var(--t);width:100%}
.form-field input:focus,.form-field select:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(37,99,235,0.12)}
.btn-form-submit{font-family:var(--font-body);font-size:15px;font-weight:800;color:#fff;background:var(--c-primary);padding:14px 24px;border-radius:var(--r);border:none;cursor:pointer;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--t);margin-top:4px}
.btn-form-submit:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}
.modal-thanks{display:none;text-align:center;padding:32px}
.modal-thanks-icon{width:64px;height:64px;background:var(--c-primary-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-size:32px}

.fade-up{opacity:0;transform:translateY(24px);transition:opacity 0.55s ease,transform 0.55s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up.d1{transition-delay:.08s}.fade-up.d2{transition-delay:.16s}.fade-up.d3{transition-delay:.24s}

@media(max-width:1060px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .features-grid{grid-template-columns:repeat(2,1fr)}
  .hub-grid{grid-template-columns:1fr}
  .hub-phone{display:none}
  .faq-grid{grid-template-columns:1fr;gap:36px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
}
@media(max-width:640px){
  .nav-links,.nav-ctas{display:none}
  .nav-hamburger{display:flex}
  .features-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .modal-option-row,.form-row{grid-template-columns:1fr}
  .proof-inner{flex-direction:column}
  .proof-item{border-right:none;border-bottom:1px solid var(--c-border);width:100%;justify-content:center}
  .proof-item:last-child{border-bottom:none}
  .download-btns{flex-direction:column;align-items:center}
}

/* ----- whatsapp-ia.html ----- */
/* ANN / NAV / BREADCRUMB */
.ann-bar{background:var(--c-wa-chat);color:#fff;padding:10px 24px;font-size:13.5px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:12px;position:relative}
.ann-bar a{color:#ACE9C4;text-decoration:underline;text-underline-offset:2px}
.ann-badge{background:var(--c-wa);color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:2px 8px;border-radius:4px;white-space:nowrap}
.ann-close{position:absolute;right:20px;top:50%;transform:translateY(-50%);color:rgba(255,255,255,0.50);font-size:18px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.ann-close:hover{color:#fff}
.nav{position:sticky;top:0;z-index:900;background:rgba(255,255,255,0.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--c-border);box-shadow:0 1px 3px rgba(15,23,42,0.06)}
.nav-inner{max-width:var(--w-max);margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;gap:32px}
.nav-logo img{height:34px;width:auto}
.nav-links{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--c-slate);padding:8px 14px;border-radius:var(--r-sm);transition:color var(--t),background var(--t)}
.nav-links a:hover{color:var(--c-primary);background:var(--c-primary-light)}
.nav-ctas{display:flex;align-items:center;gap:10px;margin-left:12px}
.btn-nav-login{font-size:14px;font-weight:600;color:var(--c-slate);padding:8px 16px;border-radius:var(--r-sm);border:1px solid var(--c-border);transition:all var(--t)}
.btn-nav-login:hover{color:var(--c-primary);border-color:var(--c-primary);background:var(--c-primary-light)}
.btn-nav-demo{font-size:14px;font-weight:700;color:#fff;background:var(--c-primary);padding:9px 20px;border-radius:var(--r-sm);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-nav-demo:hover{background:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--sh-blue)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;margin-left:auto}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--c-navy-mid);border-radius:2px}
.mobile-menu{display:none;flex-direction:column;background:var(--c-white);padding:16px 24px 24px;border-top:1px solid var(--c-border)}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:15px;font-weight:500;color:var(--c-slate);padding:12px 0;border-bottom:1px solid var(--c-border)}
.mobile-menu a:last-child{border-bottom:none}
.breadcrumb-bar{background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:10px 0}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--c-muted)}
.breadcrumb a{color:var(--c-muted);transition:color var(--t)}
.breadcrumb a:hover{color:var(--c-primary)}
.breadcrumb-sep{color:var(--c-subtle);font-size:11px}
.breadcrumb-current{color:var(--c-slate);font-weight:600}

/* ── HERO ─────────────────────────────────────── */
.wa-hero{
  background:var(--c-navy);
  background-image:
    radial-gradient(ellipse 55% 70% at 18% 55%, rgba(37,211,102,0.14) 0%, transparent 55%),
    radial-gradient(ellipse 40% 50% at 80% 20%, rgba(7,94,84,0.20) 0%, transparent 50%);
  padding:72px 0 80px;
  overflow:hidden;
  position:relative;
}
.wa-hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.04) 1px,transparent 1px);background-size:32px 32px;pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1fr 380px;gap:64px;align-items:center;position:relative}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(37,211,102,0.15);border:1px solid rgba(37,211,102,0.30);color:#ACE9C4;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 14px;border-radius:100px;margin-bottom:22px}
.hero-tag-dot{width:6px;height:6px;border-radius:50%;background:var(--c-wa);animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.75)}}
.wa-hero h1{font-family:var(--font-display);font-size:clamp(32px,4.2vw,50px);font-weight:800;line-height:1.1;letter-spacing:-0.03em;color:#fff;margin-bottom:20px}
.wa-hero h1 em{font-style:normal;color:#4ADE80}
.wa-hero .sub{font-size:17.5px;line-height:1.65;color:rgba(255,255,255,0.65);max-width:500px;margin-bottom:36px}
.wa-hero .sub strong{color:rgba(255,255,255,0.90);font-weight:600}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:36px}
.btn-primary{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:700;color:#fff;background:var(--c-wa);padding:14px 28px;border-radius:var(--r);transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-primary:hover{background:var(--c-wa-dark);transform:translateY(-2px);box-shadow:var(--sh-wa)}
.btn-outline{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:600;color:rgba(255,255,255,0.80);background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.18);padding:14px 24px;border-radius:var(--r);transition:all var(--t)}
.btn-outline:hover{background:rgba(255,255,255,0.14);color:#fff;border-color:rgba(255,255,255,0.35)}
.hero-signals{display:flex;flex-direction:column;gap:9px}
.hero-signal{display:flex;align-items:center;gap:9px;font-size:13.5px;color:rgba(255,255,255,0.55)}
.hero-signal svg{flex-shrink:0;color:#4ADE80}

/* ── WHATSAPP CHAT MOCKUP ─────────────────────── */
.wa-phone{
  background:var(--c-navy-mid);
  border-radius:32px;
  border:5px solid rgba(255,255,255,0.15);
  overflow:hidden;
  box-shadow:0 32px 80px rgba(0,0,0,0.50),0 0 0 1px rgba(255,255,255,0.06);
  max-width:260px;
  margin:0 auto;
}
.wa-phone-notch{width:70px;height:20px;background:var(--c-navy-mid);border-radius:0 0 12px 12px;position:absolute;top:0;left:50%;transform:translateX(-50%);z-index:2}
.wa-phone-wrap{position:relative}
.wa-chat-header{
  background:var(--c-wa-chat);
  padding:22px 14px 10px;
  display:flex;align-items:center;gap:10px;
}
.wa-avatar{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,0.15);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.wa-chat-name{font-size:14px;font-weight:700;color:#fff}
.wa-chat-status{font-size:11px;color:rgba(255,255,255,0.65)}
.wa-messages{
  background:var(--c-wa-bg);
  padding:12px 10px;
  display:flex;flex-direction:column;gap:6px;
  min-height:320px;
}
.wa-msg{
  max-width:82%;
  padding:7px 10px 4px;
  border-radius:8px;
  font-size:12px;line-height:1.45;
  position:relative;
}
.wa-msg-recv{
  background:#fff;
  border-radius:0 8px 8px 8px;
  align-self:flex-start;
  color:var(--c-body);
  box-shadow:0 1px 2px rgba(0,0,0,0.12);
}
.wa-msg-sent{
  background:var(--c-wa-light);
  border-radius:8px 0 8px 8px;
  align-self:flex-end;
  color:var(--c-body);
  box-shadow:0 1px 2px rgba(0,0,0,0.12);
}
.wa-msg-time{font-size:10px;color:var(--c-subtle);text-align:right;margin-top:2px}
.wa-msg-sent .wa-msg-time{color:rgba(7,94,84,0.6)}
.wa-pdf-chip{
  display:inline-flex;align-items:center;gap:5px;
  background:rgba(37,211,102,0.12);
  border:1px solid rgba(37,211,102,0.25);
  border-radius:5px;padding:4px 8px;
  font-size:10.5px;font-weight:700;color:var(--c-wa-dark);
  margin-top:4px;
}
.wa-input-bar{
  background:#F0F0F0;
  padding:8px 10px;
  display:flex;align-items:center;gap:8px;
}
.wa-input-field{
  flex:1;background:#fff;border-radius:20px;
  padding:7px 12px;font-size:11.5px;color:var(--c-muted);
  border:none;
}
.wa-send-btn{
  width:32px;height:32px;border-radius:50%;
  background:var(--c-wa);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:14px;flex-shrink:0;
}

/* ── PROOF STRIP ──────────────────────────────── */
.proof-strip{background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:18px 0}
.proof-inner{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}
.proof-item{display:flex;align-items:center;gap:10px;padding:10px 28px;border-right:1px solid var(--c-border)}
.proof-item:last-child{border-right:none}
.proof-icon{width:34px;height:34px;background:var(--c-green-light);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:17px}
.proof-text-main{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.proof-text-sub{font-size:11.5px;color:var(--c-muted)}

/* ── SECTIONS ─────────────────────────────────── */
.section{padding:88px 0}
.section-alt{background:var(--c-bg)}
.section-dark{background:var(--c-wa-chat)}
.section-eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--c-wa-dark);margin-bottom:14px}
.section-eyebrow-bar{width:24px;height:2px;background:var(--c-wa);border-radius:2px}
.section-h2{font-family:var(--font-display);font-size:clamp(26px,3vw,38px);font-weight:800;line-height:1.15;letter-spacing:-0.025em;color:var(--c-navy);margin-bottom:14px}
.section-h2.light{color:#fff}
.section-sub{font-size:17px;line-height:1.65;color:var(--c-muted);max-width:560px}
.section-sub.light{color:rgba(255,255,255,.68)}

/* ── WHY WA SECTION ───────────────────────────── */
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;margin-top:52px}
.why-stat{
  background:var(--c-navy);
  border-radius:var(--r-xl);
  padding:44px 40px;
  text-align:center;
  position:relative;overflow:hidden;
}
.why-stat::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.04) 1px,transparent 1px);background-size:24px 24px}
.why-emoji{font-size:52px;margin-bottom:16px;position:relative}
.why-claim{font-family:var(--font-display);font-size:20px;font-weight:800;color:#fff;line-height:1.25;margin-bottom:10px;position:relative}
.why-claim em{font-style:normal;color:#4ADE80}
.why-claim-sub{font-size:15px;color:rgba(255,255,255,0.60);line-height:1.55;position:relative}
.why-points{display:flex;flex-direction:column;gap:18px}
.why-point{display:flex;align-items:flex-start;gap:14px}
.why-point-num{
  width:32px;height:32px;border-radius:8px;
  background:var(--c-green-light);color:var(--c-green);
  font-family:var(--font-display);font-size:14px;font-weight:800;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.why-point h4{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--c-navy-mid);margin-bottom:4px}
.why-point p{font-size:13.5px;color:var(--c-muted);line-height:1.55}

/* ── CAPABILITIES ─────────────────────────────── */
.cap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:48px}
.cap-card{
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:var(--r-lg);
  padding:24px 20px;
  transition:background var(--t);
}
.cap-card:hover{background:rgba(255,255,255,0.14)}
.cap-icon{font-size:30px;margin-bottom:14px}
.cap-title{font-family:var(--font-display);font-size:16px;font-weight:700;color:#fff;margin-bottom:7px}
.cap-desc{font-size:13.5px;color:rgba(255,255,255,0.60);line-height:1.55}
.cap-detail{
  margin-top:10px;
  font-size:12px;color:rgba(255,255,255,0.40);
  border-top:1px solid rgba(255,255,255,0.10);
  padding-top:8px;
  font-style:italic;
  line-height:1.50;
}

/* ── HOW IDENTIFICATION WORKS ─────────────────── */
.id-section{padding:88px 0;background:var(--c-bg)}
.id-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;margin-top:52px}
.id-steps{display:flex;flex-direction:column;gap:0}
.id-step{
  display:flex;align-items:flex-start;gap:16px;
  padding:20px 0;
  border-bottom:1px solid var(--c-border);
}
.id-step:last-child{border-bottom:none}
.id-step-num{
  width:36px;height:36px;border-radius:9px;
  background:var(--c-green-light);color:var(--c-green);
  font-family:var(--font-display);font-size:15px;font-weight:800;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.id-step h4{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--c-navy-mid);margin-bottom:5px}
.id-step p{font-size:14px;color:var(--c-muted);line-height:1.55}
/* Second chat mockup */
.wa-phone-2{
  background:var(--c-navy-mid);
  border-radius:24px;
  border:4px solid rgba(255,255,255,0.10);
  overflow:hidden;
  box-shadow:var(--sh-lg);
}
.wc2-header{
  background:var(--c-wa-chat);
  padding:14px 14px 10px;
  display:flex;align-items:center;gap:9px;
}
.wc2-msgs{
  background:var(--c-wa-bg);
  padding:12px 10px;
  display:flex;flex-direction:column;gap:7px;
}
.wc2-msg{
  max-width:82%;padding:7px 10px 4px;border-radius:8px;
  font-size:11.5px;line-height:1.45;
}
.wc2-recv{background:#fff;border-radius:0 8px 8px 8px;align-self:flex-start;color:var(--c-body)}
.wc2-sent{background:var(--c-wa-light);border-radius:8px 0 8px 8px;align-self:flex-end;color:var(--c-body)}
.wc2-time{font-size:10px;color:var(--c-subtle);text-align:right;margin-top:2px}

/* ── INTEGRATION ──────────────────────────────── */
.integ-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;max-width:720px;margin:44px auto 0}
.integ-card{
  background:var(--c-white);border:1.5px solid var(--c-border);
  border-radius:var(--r-lg);padding:22px 18px;
  display:flex;align-items:flex-start;gap:14px;
  transition:border-color var(--t),box-shadow var(--t);
}
.integ-card:hover{border-color:rgba(37,211,102,0.40);box-shadow:var(--sh-sm)}
.integ-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:20px}
.integ-title{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--c-navy-mid);margin-bottom:5px}
.integ-desc{font-size:13.5px;color:var(--c-muted);line-height:1.55}

/* ── FAQ ──────────────────────────────────────── */
.faq-grid{display:grid;grid-template-columns:300px 1fr;gap:64px;align-items:start}
.faq-sidebar h3{font-family:var(--font-display);font-size:24px;font-weight:800;color:var(--c-navy);margin-bottom:12px;letter-spacing:-0.02em}
.faq-sidebar p{font-size:15px;color:var(--c-muted);line-height:1.6;margin-bottom:22px}
.faq-contact{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--c-wa-dark);transition:gap var(--t)}
.faq-contact:hover{gap:12px}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--c-border)}
.faq-item:first-child{border-top:1px solid var(--c-border)}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0;text-align:left;font-size:15px;font-weight:600;color:var(--c-navy-mid);background:none;cursor:pointer;transition:color var(--t)}
.faq-question:hover,.faq-item.open .faq-question{color:var(--c-wa-dark)}
.faq-question svg{flex-shrink:0;transition:transform var(--t);color:var(--c-subtle)}
.faq-item.open .faq-question svg{transform:rotate(180deg);color:var(--c-wa-dark)}
.faq-answer{overflow:hidden;max-height:0;transition:max-height 0.35s cubic-bezier(0.4,0,0.2,1)}
.faq-answer-inner{padding:0 0 22px;font-size:15px;color:var(--c-muted);line-height:1.70}

/* ── FINAL CTA ────────────────────────────────── */
.final-cta{background:linear-gradient(135deg,var(--c-wa-chat) 0%,var(--c-wa-dark) 50%,#1FA855 100%);text-align:center;padding:96px 0;position:relative;overflow:hidden}
.final-cta::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.07) 1px,transparent 1px);background-size:28px 28px}
.final-cta h2{font-family:var(--font-display);font-size:clamp(28px,4vw,44px);font-weight:800;color:#fff;letter-spacing:-0.025em;line-height:1.1;margin-bottom:14px;position:relative}
.final-cta p{font-size:17px;color:rgba(255,255,255,0.75);max-width:480px;margin:0 auto 36px;line-height:1.6;position:relative}
.final-ctas{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;position:relative}
.btn-cta-white{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:800;color:var(--c-wa-dark);background:#fff;padding:16px 32px;border-radius:var(--r);transition:all var(--t);box-shadow:0 4px 20px rgba(0,0,0,0.15)}
.btn-cta-white:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,0.20)}
.btn-cta-wa{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:700;color:#fff;background:rgba(255,255,255,0.15);border:1.5px solid rgba(255,255,255,0.35);padding:15px 28px;border-radius:var(--r);transition:all var(--t)}
.btn-cta-wa:hover{background:rgba(255,255,255,0.22);border-color:rgba(255,255,255,0.55)}

/* FOOTER */
/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,0.70);backdrop-filter:blur(6px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity 0.25s ease}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{background:var(--c-white);border-radius:var(--r-xl);width:100%;max-width:560px;overflow:hidden;box-shadow:var(--sh-lg);transform:translateY(20px) scale(0.97);transition:transform 0.25s ease}
.modal-overlay.open .modal-box{transform:translateY(0) scale(1)}
.modal-header{background:linear-gradient(135deg,var(--c-navy) 0%,var(--c-navy-mid) 100%);padding:28px 32px 24px;position:relative}
.modal-header h2{font-family:var(--font-display);font-size:22px;font-weight:800;color:#fff;margin-bottom:6px;letter-spacing:-0.02em}
.modal-header p{font-size:14px;color:rgba(255,255,255,0.60)}
.modal-close{position:absolute;top:16px;right:20px;color:rgba(255,255,255,0.50);font-size:22px;cursor:pointer;background:none;border:none;transition:color var(--t)}
.modal-close:hover{color:#fff}
.modal-body{padding:28px 32px 32px}
.modal-option-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:22px}
.modal-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 14px;border-radius:var(--r-lg);border:2px solid var(--c-border);cursor:pointer;text-align:center;transition:all var(--t);text-decoration:none;color:inherit}
.modal-option:hover,.modal-option.option-wa:hover{border-color:var(--c-wa);background:#F0FDF4}
.modal-option-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px}
.opt-title{font-size:14px;font-weight:700;color:var(--c-navy-mid)}
.opt-sub{font-size:12px;color:var(--c-muted)}
.modal-divider{display:flex;align-items:center;gap:12px;color:var(--c-subtle);font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:20px}
.modal-divider::before,.modal-divider::after{content:'';flex:1;height:1px;background:var(--c-border)}
.modal-form{display:flex;flex-direction:column;gap:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-field{display:flex;flex-direction:column;gap:5px}
.form-field label{font-size:12.5px;font-weight:700;color:var(--c-slate);letter-spacing:.02em}
.form-field input,.form-field select{font-family:var(--font-body);font-size:14px;color:var(--c-body);background:var(--c-bg);border:1.5px solid var(--c-border);border-radius:var(--r);padding:11px 14px;outline:none;transition:border-color var(--t),box-shadow var(--t);width:100%}
.form-field input:focus,.form-field select:focus{border-color:var(--c-wa);box-shadow:0 0 0 3px rgba(37,211,102,0.12)}
.btn-form-submit{font-family:var(--font-body);font-size:15px;font-weight:800;color:#fff;background:var(--c-wa);padding:14px 24px;border-radius:var(--r);border:none;cursor:pointer;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--t);margin-top:4px}
.btn-form-submit:hover{background:var(--c-wa-dark);transform:translateY(-1px);box-shadow:var(--sh-wa)}
.modal-thanks{display:none;text-align:center;padding:32px}
.modal-thanks-icon{width:64px;height:64px;background:var(--c-green-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-size:32px}

.fade-up{opacity:0;transform:translateY(24px);transition:opacity 0.55s ease,transform 0.55s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up.d1{transition-delay:.08s}.fade-up.d2{transition-delay:.16s}.fade-up.d3{transition-delay:.24s}

@media(max-width:1060px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .why-grid{grid-template-columns:1fr}
  .cap-grid{grid-template-columns:1fr 1fr}
  .id-grid{grid-template-columns:1fr}
  .integ-grid{grid-template-columns:1fr}
  .faq-grid{grid-template-columns:1fr;gap:36px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
}
@media(max-width:640px){
  .nav-links,.nav-ctas{display:none}
  .nav-hamburger{display:flex}
  .cap-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .modal-option-row,.form-row{grid-template-columns:1fr}
  .proof-inner{flex-direction:column}
  .proof-item{border-right:none;border-bottom:1px solid var(--c-border);width:100%;justify-content:center}
  .proof-item:last-child{border-bottom:none}
}
