/* =========================================================
   PLATILLO — Design System v2
   ========================================================= */
:root {
  --bg:        #07070E;
  --surface:   #0F0F1C;
  --surface2:  #161628;
  --border:    rgba(255,255,255,.07);
  --border2:   rgba(255,255,255,.14);
  --primary:   #FF4500;
  --primary2:  #FF6B30;
  --glow:      rgba(255,69,0,.35);
  --text:      #FFFFFF;
  --muted:     #8888AA;
  --subtle:    #3A3A55;
  --green:     #00E676;
  --yellow:    #FFD600;
  --r:    14px;
  --r-lg: 24px;
  --r-xl: 36px;
  --pad:  clamp(1.25rem, 5vw, 2.5rem);
  --max:  1200px;
  --ease: cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--text);font-family:'Manrope',system-ui,sans-serif;font-size:1rem;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{border:none;cursor:pointer;background:none;font:inherit;color:inherit}

/* ---- TOPBAR ---- */
.topbar{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.875rem var(--pad);background:rgba(7,7,14,.88);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid var(--border);transition:background .3s}
.brand{display:flex;align-items:center;gap:.625rem;flex-shrink:0}
.brand-mark{height:40px;width:auto;display:block}
.brand-copy{display:flex;flex-direction:column;line-height:1.2}
.brand-copy strong{display:none}
.brand-copy span{font-size:.75rem;color:var(--muted);font-weight:600}
.topnav{display:none;gap:.25rem;align-items:center}
@media(min-width:900px){.topnav{display:flex}}
.topnav a{font-size:.82rem;font-weight:600;color:var(--muted);padding:.4rem .7rem;border-radius:8px;transition:color .2s,background .2s}
.topnav a:hover,.topnav a[aria-current]{color:var(--text);background:var(--border2)}
.topbar-cta{display:none;background:var(--primary);color:#fff;padding:.55rem 1.25rem;border-radius:50px;font-size:.82rem;font-weight:700;transition:background .2s,transform .15s,box-shadow .2s;box-shadow:0 0 18px var(--glow);white-space:nowrap}
@media(min-width:640px){.topbar-cta{display:inline-flex}}
.topbar-cta:hover{background:var(--primary2);transform:translateY(-1px);box-shadow:0 0 28px var(--glow)}

/* Hamburger */
.hamburger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;padding:8px;border-radius:10px;transition:background .2s}
@media(min-width:900px){.hamburger{display:none}}
.hamburger:hover{background:var(--border2)}
.hamburger span{display:block;height:2px;background:var(--text);border-radius:2px;transition:transform .3s var(--ease),opacity .3s,width .3s}
.hamburger span:nth-child(3){width:60%}
.hamburger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.is-open span:nth-child(2){opacity:0}
.hamburger.is-open span:nth-child(3){width:100%;transform:translateY(-7px) rotate(-45deg)}

/* Mobile menu */
.mobile-menu{display:none;position:fixed;inset:0;z-index:99;background:rgba(7,7,14,.97);flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:2rem}
.mobile-menu.is-open{display:flex;animation:menuIn .25s var(--ease)}
@keyframes menuIn{from{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}
.mobile-menu a{font-family:'Sora',sans-serif;font-size:1.4rem;font-weight:700;color:var(--muted);padding:.75rem 2rem;border-radius:var(--r);transition:color .2s,background .2s;width:100%;text-align:center}
.mobile-menu a:hover{color:var(--text);background:var(--surface)}
.mobile-menu .btn-primary{margin-top:1rem;width:100%;justify-content:center;font-size:1rem}

/* ---- HERO ---- */
.hero{min-height:100svh;padding:calc(80px + 3rem) var(--pad) 4rem;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.hero::before,.hero::after{content:'';position:absolute;border-radius:50%;pointer-events:none;filter:blur(90px)}
.hero::before{width:clamp(280px,55vw,640px);height:clamp(280px,55vw,640px);background:radial-gradient(circle,var(--primary) 0%,transparent 70%);top:5%;right:-8%;opacity:.4;animation:blobA 12s ease-in-out infinite alternate}
.hero::after{width:clamp(200px,40vw,480px);height:clamp(200px,40vw,480px);background:radial-gradient(circle,#5C00CC 0%,transparent 70%);bottom:0;left:-5%;opacity:.35;animation:blobB 10s ease-in-out infinite alternate}
@keyframes blobA{from{transform:translate(0,0) scale(1)}to{transform:translate(-40px,35px) scale(1.1)}}
@keyframes blobB{from{transform:translate(0,0) scale(1)}to{transform:translate(30px,-25px) scale(1.08)}}

.hero-inner{position:relative;z-index:1;max-width:var(--max);margin:0 auto;width:100%;display:grid;grid-template-columns:1fr;gap:3rem;align-items:center}
@media(min-width:900px){.hero-inner{grid-template-columns:1fr 1fr}}

.hero-eyebrow{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,69,0,.12);border:1px solid rgba(255,69,0,.3);color:var(--primary2);font-size:.75rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:.35rem .85rem;border-radius:50px;margin-bottom:1.25rem}
.hero-eyebrow::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--primary);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.5)}}

.hero-title{font-family:'Sora',sans-serif;font-size:clamp(2rem,5.5vw,3.8rem);font-weight:800;line-height:1.1;letter-spacing:-.03em;margin-bottom:1.25rem}
.hero-title em{font-style:normal;background:linear-gradient(135deg,var(--primary),var(--yellow));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.hero-lead{font-size:clamp(.92rem,1.8vw,1.05rem);color:var(--muted);max-width:520px;margin-bottom:2rem;line-height:1.75}
.hero-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:2.5rem}
.hero-trust{display:flex;flex-wrap:wrap;gap:.75rem 1.25rem;font-size:.78rem;color:var(--muted)}
.hero-trust span{display:flex;align-items:center;gap:.35rem}
.hero-trust span::before{content:'✓';color:var(--green);font-weight:700}

/* Hero visual */
.hero-visual{position:relative;display:flex;justify-content:center;align-items:center}
.hero-screen-wrap{position:relative;z-index:1;animation:floatUp 7s ease-in-out infinite;width:100%;max-width:400px}
@keyframes floatUp{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

.hero-screen{background:var(--surface);border:1px solid var(--border2);border-radius:var(--r-lg);overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,.6),0 0 0 1px var(--border)}
.hs-bar{display:flex;justify-content:space-between;align-items:center;padding:.875rem 1rem;border-bottom:1px solid var(--border);background:rgba(255,255,255,.025);font-size:.78rem;font-weight:700}
.hs-chip{font-size:.68rem;font-weight:700;padding:.25rem .6rem;border-radius:50px;background:rgba(0,230,118,.12);color:var(--green);border:1px solid rgba(0,230,118,.25)}
.hs-chip::before{content:'● ';font-size:.5rem}
.hs-grid{padding:.875rem 1rem;display:flex;flex-direction:column;gap:.5rem}
.hs-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .875rem;border-radius:10px;background:rgba(255,255,255,.04);border:1px solid var(--border);font-size:.8rem}
.hs-item span:first-child{color:var(--muted);min-width:52px;font-size:.72rem}
.hs-item strong{flex:1;font-size:.8rem}
.hs-tag{font-size:.65rem;font-weight:700;padding:.2rem .5rem;border-radius:6px;text-transform:uppercase;letter-spacing:.04em}
.hs-tag.pending{background:rgba(255,214,0,.12);color:var(--yellow)}
.hs-tag.ready{background:rgba(0,230,118,.12);color:var(--green)}
.hs-tag.cooking{background:rgba(255,69,0,.12);color:var(--primary2)}
.hs-footer{display:flex;justify-content:space-between;align-items:center;padding:.875rem 1rem;border-top:1px solid var(--border);font-size:.78rem}
.hs-footer span{color:var(--muted)}
.hs-footer strong{font-family:'Sora',sans-serif;font-size:1.1rem;color:var(--primary2)}

.hs-float{position:absolute;z-index:2;background:var(--surface2);border:1px solid var(--border2);border-radius:12px;padding:.6rem .875rem;box-shadow:0 8px 32px rgba(0,0,0,.5);font-size:.75rem}
.hs-float span{color:var(--muted);display:block;font-size:.68rem}
.hs-float strong{font-weight:700;white-space:nowrap}
.hs-float-1{top:-1.25rem;left:-1.25rem;animation:floatUp 4.5s ease-in-out infinite}
.hs-float-2{bottom:-1rem;right:-1rem;animation:floatUp 5.5s ease-in-out infinite reverse}
@media(max-width:500px){.hs-float{display:none}}

/* ---- STATS BAR ---- */
.stats-bar{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:2.5rem var(--pad)}
.stats-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}
@media(min-width:640px){.stats-inner{grid-template-columns:repeat(4,1fr)}}
.stat-item{text-align:center}
.stat-num{font-family:'Sora',sans-serif;font-size:clamp(2rem,5vw,2.8rem);font-weight:800;line-height:1;display:block;background:linear-gradient(135deg,var(--primary),var(--yellow));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.stat-suffix{font-family:'Sora',sans-serif;font-size:1.6rem;font-weight:800;background:linear-gradient(135deg,var(--primary),var(--yellow));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.stat-label{font-size:.78rem;color:var(--muted);margin-top:.35rem;font-weight:600}

/* ---- GENERIC SECTION ---- */
.section{padding:clamp(4rem,8vw,6rem) var(--pad);max-width:var(--max);margin:0 auto}
.section-bg{background:var(--surface)}
.section-bg .section{max-width:var(--max)}
.section-bg-wrap{background:var(--surface);padding:clamp(4rem,8vw,6rem) var(--pad)}
.section-bg-wrap .section-inner{max-width:var(--max);margin:0 auto}

.section-head{text-align:center;margin-bottom:clamp(2.5rem,5vw,4rem)}
.section-head.left{text-align:left}
.eyebrow{display:inline-block;font-size:.72rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--primary2);margin-bottom:.75rem}
.section-head h2{font-family:'Sora',sans-serif;font-size:clamp(1.6rem,4vw,2.6rem);font-weight:800;line-height:1.2;letter-spacing:-.025em;max-width:720px;margin:0 auto .875rem}
.section-head.left h2{margin:0 0 .875rem}
.section-head p{font-size:1rem;color:var(--muted);max-width:580px;margin:0 auto;line-height:1.7}
.section-head.left p{margin:0}

/* ---- PAIN CARDS ---- */
.pain-grid{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:640px){.pain-grid{grid-template-columns:repeat(3,1fr)}}
.pain-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.75rem;transition:border-color .25s,transform .25s}
.pain-card:hover{border-color:var(--border2);transform:translateY(-2px)}
.pain-emoji{font-size:2rem;margin-bottom:1rem}
.pain-card h3{font-size:1rem;font-weight:700;margin-bottom:.5rem}
.pain-card p{font-size:.875rem;color:var(--muted);line-height:1.6}

/* ---- PILLAR CARDS ---- */
.pillars-grid{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:480px){.pillars-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.pillars-grid{grid-template-columns:repeat(4,1fr)}}
.pillar-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.75rem 1.5rem;transition:border-color .25s,transform .25s,box-shadow .25s;position:relative;overflow:hidden}
.pillar-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--primary),transparent);opacity:0;transition:opacity .3s;pointer-events:none}
.pillar-card:hover{border-color:rgba(255,69,0,.4);transform:translateY(-4px);box-shadow:0 12px 40px rgba(255,69,0,.12)}
.pillar-card:hover::before{opacity:.06}
.pillar-icon{width:48px;height:48px;border-radius:12px;background:rgba(255,69,0,.12);border:1px solid rgba(255,69,0,.2);display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:1.25rem}
.pillar-card h3{font-size:1rem;font-weight:700;margin-bottom:.5rem}
.pillar-card p{font-size:.85rem;color:var(--muted);line-height:1.6}

/* ---- WORKFLOW ---- */
.workflow-bg{background:var(--surface);padding:clamp(4rem,8vw,6rem) var(--pad)}
.workflow-inner{max-width:var(--max);margin:0 auto}
.workflow-tabs{display:flex;flex-wrap:wrap;gap:.5rem;padding:.375rem;background:var(--bg);border-radius:14px;border:1px solid var(--border);margin-bottom:2rem;width:fit-content;max-width:100%}
.workflow-tab{padding:.6rem 1.25rem;border-radius:10px;font-size:.82rem;font-weight:700;color:var(--muted);transition:background .2s,color .2s;white-space:nowrap}
.workflow-tab:hover{background:var(--surface2);color:var(--text)}
.workflow-tab.is-active{background:var(--primary);color:#fff}
.workflow-panel{display:grid;grid-template-columns:1fr;gap:2rem;align-items:start}
@media(min-width:768px){.workflow-panel{grid-template-columns:1fr 1fr}}
.workflow-label{font-size:.72rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--primary2);display:block;margin-bottom:.5rem}
#workflow-title{font-family:'Sora',sans-serif;font-size:clamp(1.2rem,2.5vw,1.6rem);font-weight:800;line-height:1.25;letter-spacing:-.02em;margin-bottom:.875rem}
#workflow-body{font-size:.9rem;color:var(--muted);line-height:1.7;margin-bottom:1.25rem}
.workflow-bullets{display:flex;flex-direction:column;gap:.5rem}
.workflow-bullets li{font-size:.875rem;color:var(--muted);padding-left:1.25rem;position:relative;line-height:1.5}
.workflow-bullets li::before{content:'→';position:absolute;left:0;color:var(--primary2);font-weight:700}
.workflow-panel-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.75rem}
.workflow-card-head{border-bottom:1px solid var(--border);padding-bottom:1rem;margin-bottom:1rem}
.workflow-card-head span{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:700;display:block;margin-bottom:.25rem}
.workflow-card-head strong{font-size:1rem;font-weight:700}
.workflow-metric{font-family:'Sora',sans-serif;font-size:1.2rem;font-weight:800;color:var(--primary2);margin-bottom:1rem}
.workflow-detail-list{display:flex;flex-direction:column;gap:.5rem}
.workflow-detail-list div{font-size:.82rem;color:var(--muted);padding-left:1rem;border-left:2px solid var(--border2)}

/* ---- STEPS ---- */
.steps-grid{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:640px){.steps-grid{grid-template-columns:repeat(3,1fr)}}
.step-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:2rem 1.75rem;transition:border-color .25s,transform .25s}
.step-card:hover{border-color:var(--border2);transform:translateY(-3px)}
.step-num{font-family:'Sora',sans-serif;font-size:3rem;font-weight:800;color:var(--subtle);line-height:1;margin-bottom:1rem}
.step-card h3{font-size:1.05rem;font-weight:700;margin-bottom:.5rem}
.step-card p{font-size:.875rem;color:var(--muted);line-height:1.6}

/* ---- PRICING ---- */
.pricing-wrap{display:flex;flex-direction:column;align-items:center;gap:1.25rem}
@media(min-width:768px){.pricing-wrap{flex-direction:row;align-items:stretch;justify-content:center}}
.price-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-xl);padding:2.5rem 2rem;width:100%;max-width:360px;transition:border-color .25s,transform .25s,box-shadow .25s}
.price-card.featured{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary),0 24px 60px rgba(255,69,0,.2);position:relative}
.price-card.featured::before{content:'Precio único';position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--primary);color:#fff;font-size:.7rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:.3rem .9rem;border-radius:50px}
.price-card:hover:not(.featured){border-color:var(--border2);transform:translateY(-4px)}
.price-card.featured:hover{box-shadow:0 0 0 1px var(--primary),0 32px 80px rgba(255,69,0,.3);transform:translateY(-4px)}
.price-tier{font-size:.72rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem}
.price-name{font-family:'Sora',sans-serif;font-size:1.3rem;font-weight:800;margin-bottom:1rem}
.price-line{display:flex;align-items:baseline;gap:.25rem;margin-bottom:.875rem}
.price-value{font-family:'Sora',sans-serif;font-size:3rem;font-weight:800;line-height:1}
.featured .price-value{color:var(--primary2)}
.price-period{font-size:.875rem;color:var(--muted)}
.price-desc{font-size:.875rem;color:var(--muted);line-height:1.6;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}
.price-list{display:flex;flex-direction:column;gap:.6rem;margin-bottom:2rem}
.price-list li{font-size:.84rem;color:var(--muted);display:flex;align-items:flex-start;gap:.5rem;line-height:1.5}
.price-list li::before{content:'✓';color:var(--green);font-weight:700;flex-shrink:0;margin-top:.1rem}

/* ---- USE CASES ---- */
.cases-grid{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:640px){.cases-grid{grid-template-columns:repeat(3,1fr)}}
.case-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.75rem;transition:border-color .25s,transform .25s}
.case-card:hover{border-color:var(--border2);transform:translateY(-3px)}
.case-tag{font-size:.7rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--primary2);margin-bottom:.875rem;display:block}
.case-card h3{font-size:1rem;font-weight:700;margin-bottom:.625rem;line-height:1.35}
.case-card p{font-size:.84rem;color:var(--muted);line-height:1.6;margin-bottom:1rem}
.case-list{display:flex;flex-direction:column;gap:.4rem}
.case-list li{font-size:.8rem;color:var(--muted);display:flex;gap:.4rem}
.case-list li::before{content:'→';color:var(--primary2);font-weight:700;flex-shrink:0}

/* ---- CTA FINAL ---- */
.cta-final{padding:clamp(5rem,10vw,8rem) var(--pad);text-align:center;position:relative;overflow:hidden}
.cta-final::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 100%,rgba(255,69,0,.18),transparent);pointer-events:none}
.cta-final h2{font-family:'Sora',sans-serif;font-size:clamp(2rem,5vw,3.2rem);font-weight:800;line-height:1.15;letter-spacing:-.03em;margin-bottom:1rem;position:relative}
.cta-final p{font-size:1rem;color:var(--muted);margin-bottom:2rem;position:relative;max-width:520px;margin-left:auto;margin-right:auto}
.cta-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem;position:relative}

/* ---- FOOTER ---- */
footer{background:var(--surface);border-top:1px solid var(--border);padding:3rem var(--pad) 2rem}
.footer-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr;gap:2.5rem}
@media(min-width:640px){.footer-inner{grid-template-columns:2fr 1fr 1fr}}
.footer-brand p{font-size:.84rem;color:var(--muted);margin-top:.5rem;max-width:260px;line-height:1.6}
.footer-col h4{font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:.875rem}
.footer-col a{display:block;font-size:.84rem;color:var(--muted);padding:.25rem 0;transition:color .2s}
.footer-col a:hover{color:var(--text)}
.footer-bottom{max-width:var(--max);margin:2rem auto 0;padding-top:1.5rem;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;font-size:.78rem;color:var(--muted)}

/* ---- BUTTONS ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.75rem;border-radius:50px;font-size:.9rem;font-weight:700;transition:all .2s var(--ease);cursor:pointer;white-space:nowrap}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 0 20px var(--glow)}
.btn-primary:hover{background:var(--primary2);transform:translateY(-2px);box-shadow:0 0 32px var(--glow)}
.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border2)}
.btn-secondary:hover{background:var(--surface);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--text);border:1px solid var(--border2)}
.btn-outline:hover{background:var(--surface);transform:translateY(-2px)}
.btn-lg{padding:1rem 2.25rem;font-size:1rem}

/* ---- SCROLL REVEAL ---- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.is-visible{opacity:1;transform:none}

/* ---- INNER PAGES COMPAT ---- */
.site-shell{min-height:100vh}
.ambient{display:none}
.page-hero{padding:calc(80px + 3.5rem) var(--pad) 3.5rem;max-width:var(--max);margin:0 auto}
.page-hero-dark{padding:calc(80px + 3.5rem) var(--pad) 3.5rem;max-width:var(--max);margin:0 auto}
.page-hero-grid{display:grid;grid-template-columns:1fr;gap:2.5rem}
@media(min-width:900px){.page-hero-grid{grid-template-columns:1fr 1fr;align-items:center}}
.page-hero-copy .eyebrow{margin-bottom:.75rem}
.page-hero-copy h1,.hero-title{font-family:'Sora',sans-serif;font-size:clamp(1.8rem,5vw,3.2rem);font-weight:800;line-height:1.15;letter-spacing:-.03em;margin-bottom:1rem}
.page-hero-copy h1 span{display:block;background:linear-gradient(135deg,var(--primary),var(--yellow));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.hero-lead{font-size:clamp(.92rem,1.8vw,1.05rem);color:var(--muted);margin-bottom:2rem;line-height:1.75;max-width:560px}
.hero-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}
.hero-badges{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}
.hero-badge{font-size:.75rem;font-weight:700;padding:.35rem .875rem;border-radius:50px;background:var(--surface2);border:1px solid var(--border2);color:var(--muted)}
.hero-stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem;margin-top:1.5rem}
.hero-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:1rem 1.25rem}
.hero-stat-card span{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;font-weight:700;color:var(--muted);display:block;margin-bottom:.25rem}
.hero-stat-card strong{font-size:.95rem;font-weight:700;display:block;margin-bottom:.25rem}
.hero-stat-card p{font-size:.78rem;color:var(--muted);line-height:1.5}
.page-hero-panel .screen-grid{display:grid;grid-template-columns:1fr;gap:.75rem}
@media(min-width:480px){.page-hero-panel .screen-grid{grid-template-columns:1fr 1fr}}
.screen-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.25rem;font-size:.84rem}
.screen-card-dark{background:var(--surface2)}
.screen-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.875rem;font-size:.78rem}
.screen-chip{font-size:.68rem;font-weight:700;padding:.2rem .6rem;border-radius:50px;background:rgba(255,69,0,.12);color:var(--primary2)}
.screen-list{display:flex;flex-direction:column;gap:.5rem}
.screen-list article{padding:.5rem .75rem;border-radius:8px;background:rgba(255,255,255,.04);border:1px solid var(--border)}
.screen-list strong{display:block;font-size:.82rem;margin-bottom:.2rem}
.screen-list p{font-size:.75rem;color:var(--muted);margin:0}
.screen-note{font-size:.75rem;color:var(--muted);margin-top:.875rem;padding-top:.875rem;border-top:1px solid var(--border)}
.metric-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
.metric-card{background:rgba(255,255,255,.04);border-radius:8px;padding:.625rem .75rem}
.metric-card span{font-size:.7rem;color:var(--muted);display:block;margin-bottom:.2rem}
.metric-card strong{font-size:.95rem;font-weight:700}
.section-shell{padding:clamp(3.5rem,7vw,5.5rem) var(--pad);max-width:var(--max);margin:0 auto}
.section-copy{margin-bottom:2.5rem}
.section-copy h2{font-family:'Sora',sans-serif;font-size:clamp(1.5rem,3.5vw,2.4rem);font-weight:800;line-height:1.2;letter-spacing:-.025em;margin-bottom:.875rem}
.section-copy p{font-size:.95rem;color:var(--muted);max-width:600px;line-height:1.7}
.info-card-grid{display:grid;grid-template-columns:1fr;gap:.875rem}
@media(min-width:640px){.info-card-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.info-card-grid{grid-template-columns:repeat(4,1fr)}}
.info-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.75rem;transition:border-color .25s,transform .25s}
.info-card:hover{border-color:var(--border2);transform:translateY(-3px)}
.feature-index{font-size:.7rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--primary2);display:block;margin-bottom:.625rem}
.info-card h3{font-size:1rem;font-weight:700;margin-bottom:.5rem}
.info-card p{font-size:.84rem;color:var(--muted);line-height:1.6}
.info-card .hero-actions{margin-top:1.25rem;margin-bottom:0}
.story-grid{display:grid;grid-template-columns:1fr;gap:1.25rem}
@media(min-width:768px){.story-grid{grid-template-columns:1fr}}
.story-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:2rem;display:grid;grid-template-columns:1fr;gap:2rem;transition:border-color .25s}
@media(min-width:768px){.story-card{grid-template-columns:1fr 1fr}}
.story-card:hover{border-color:var(--border2)}
.story-copy .feature-index{margin-bottom:.75rem}
.story-copy h3{font-size:1.2rem;font-weight:700;margin-bottom:.625rem;line-height:1.3}
.story-copy p{font-size:.875rem;color:var(--muted);line-height:1.6;margin-bottom:1rem}
.story-points li{font-size:.84rem;color:var(--muted);padding:.3rem 0 .3rem 1.25rem;position:relative}
.story-points li::before{content:'→';position:absolute;left:0;color:var(--primary2);font-weight:700}
.story-window{background:var(--bg);border:1px solid var(--border2);border-radius:var(--r-lg);overflow:hidden;height:100%}
.story-window-top{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);font-size:.78rem}
.window-dots{display:flex;gap:5px}
.window-dots span{width:10px;height:10px;border-radius:50%;background:var(--subtle)}
.story-window-title{flex:1;font-weight:700}
.story-window-tag{font-size:.68rem;font-weight:700;padding:.2rem .5rem;border-radius:6px;background:rgba(255,69,0,.1);color:var(--primary2)}
.story-window-grid{display:grid;grid-template-columns:1fr;gap:.5rem;padding:1rem}
.story-window-grid article{padding:.625rem .875rem;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:8px;font-size:.8rem}
.story-window-grid span{font-size:.72rem;color:var(--muted);display:block;margin-bottom:.2rem}
.story-window-note{font-size:.75rem;color:var(--muted);margin:0 1rem 1rem;padding-top:.875rem;border-top:1px solid var(--border)}
.screen-stack{display:flex;flex-direction:column;gap:.5rem;padding:1rem}
.reservation-card{padding:.625rem .875rem;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:8px}
.reservation-card span{font-size:.72rem;color:var(--muted);display:block;margin-bottom:.2rem}
.reservation-card strong{font-size:.84rem;font-weight:700}
.pricing-grid{display:grid;grid-template-columns:1fr;gap:1rem;max-width:800px;margin:0 auto}
@media(min-width:768px){.pricing-grid-duo{grid-template-columns:repeat(2,1fr)}}
.price-card-featured{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary),0 24px 60px rgba(255,69,0,.2)}
.price-badge{background:var(--primary);color:#fff;font-size:.7rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:.3rem .9rem;border-radius:50px;display:inline-block;margin-bottom:1rem}
.pricing-copy{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1.5rem}
.page-cta-block{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:3rem 2.5rem;text-align:center;margin-top:3rem}
.page-cta-block h2{font-family:'Sora',sans-serif;font-size:clamp(1.5rem,3vw,2rem);font-weight:800;margin-bottom:.75rem}
.page-cta-block p{font-size:.95rem;color:var(--muted);margin-bottom:1.5rem}
.page-cta-block .hero-actions{justify-content:center}
.form-grid{display:flex;flex-direction:column;gap:1rem}
.form-grid label{font-size:.84rem;font-weight:600;display:flex;flex-direction:column;gap:.4rem}
.form-grid input,.form-grid textarea,.form-grid select{background:var(--surface);border:1px solid var(--border2);color:var(--text);padding:.75rem 1rem;border-radius:var(--r);font:inherit;font-size:.9rem;transition:border-color .2s}
.form-grid input:focus,.form-grid textarea:focus,.form-grid select:focus{outline:none;border-color:var(--primary)}
.form-grid textarea{min-height:120px;resize:vertical}
.contact-grid{display:grid;grid-template-columns:1fr;gap:2rem}
@media(min-width:768px){.contact-grid{grid-template-columns:1fr 1fr}}
.contact-info h2{font-family:'Sora',sans-serif;font-size:clamp(1.5rem,3vw,2.2rem);font-weight:800;margin-bottom:.875rem}
.contact-info p{font-size:.95rem;color:var(--muted);line-height:1.7;margin-bottom:1.5rem}
.contact-detail{display:flex;flex-direction:column;gap:.75rem;margin-top:1.5rem}
.contact-detail-item{display:flex;align-items:center;gap:.75rem;font-size:.875rem;color:var(--muted)}
.contact-detail-item strong{color:var(--text);font-size:.9rem}
.workflow-shell{padding:clamp(3.5rem,7vw,5.5rem) var(--pad);background:var(--surface)}

/* ---- FEATURE BLOCKS (caracteristicas) ---- */
.page-hero{padding:calc(80px + 3.5rem) var(--pad) 3.5rem;text-align:center;max-width:var(--max);margin:0 auto}
.feat-block{display:grid;grid-template-columns:auto 1fr;gap:2rem;align-items:start;padding:2rem 0;border-bottom:1px solid var(--border)}
.feat-block:last-child{border-bottom:none}
.feat-block-highlight{background:rgba(255,69,0,.04);border-radius:var(--r-lg);padding:2rem;border:1px solid rgba(255,69,0,.15);margin:1rem 0}
.feat-block-highlight + .feat-block{border-top:none}
.feat-icon-wrap{width:56px;flex-shrink:0}
.feat-icon{width:52px;height:52px;border-radius:14px;background:rgba(255,69,0,.12);border:1px solid rgba(255,69,0,.2);display:flex;align-items:center;justify-content:center;font-size:1.5rem}
.feat-content h3{font-family:'Sora',sans-serif;font-size:1.15rem;font-weight:800;margin-bottom:.5rem;display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}
.feat-badge{font-family:'Manrope',sans-serif;font-size:.65rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;background:rgba(255,69,0,.12);color:var(--primary2);border:1px solid rgba(255,69,0,.25);padding:.25rem .6rem;border-radius:50px}
.feat-content p{font-size:.9rem;color:var(--muted);line-height:1.7;margin-bottom:1rem}
.feat-list{display:flex;flex-wrap:wrap;gap:.4rem .75rem}
.feat-list span{font-size:.78rem;color:var(--text);padding:.35rem .875rem;background:var(--surface2);border:1px solid var(--border2);border-radius:50px;display:flex;align-items:center;gap:.35rem;flex-shrink:0}
.feat-list span::before{content:'✓';color:var(--green);font-weight:700;font-size:.7rem}
@media(max-width:480px){.feat-block{grid-template-columns:1fr}.feat-icon-wrap{display:none}.feat-block-highlight{padding:1.25rem}.feat-content{min-width:0}.feat-content h3{word-break:break-word}.feat-list span{flex-shrink:1;max-width:100%;box-sizing:border-box}}

/* ---- CASO DE ÉXITO ---- */
.caso-card{background:var(--surface);border:1px solid var(--border2);border-radius:var(--r-xl);overflow:hidden}
.caso-header{display:grid;grid-template-columns:1fr;gap:2rem;padding:2.5rem;border-bottom:1px solid var(--border);background:rgba(255,255,255,.02)}
@media(min-width:640px){.caso-header{grid-template-columns:140px 1fr;align-items:center}}
.caso-logo-wrap{display:flex;align-items:center;justify-content:center;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.5rem;min-height:120px}
.caso-logo-wrap img{max-width:120px;max-height:80px;object-fit:contain}
.caso-meta-header h2{font-family:'Sora',sans-serif;font-size:clamp(1.5rem,3vw,2.2rem);font-weight:800;margin:.5rem 0 .625rem}
.caso-subtitle{font-size:.9rem;color:var(--muted);line-height:1.6;margin-bottom:1rem}
.caso-tags{display:flex;flex-wrap:wrap;gap:.5rem}
.caso-tags span{font-size:.75rem;font-weight:700;padding:.3rem .75rem;background:var(--bg);border:1px solid var(--border);border-radius:50px;color:var(--muted)}
.caso-body{padding:2.5rem;display:flex;flex-direction:column;gap:2.5rem}
.caso-reto h3{font-family:'Sora',sans-serif;font-size:clamp(1.1rem,2.5vw,1.5rem);font-weight:800;line-height:1.25;margin:.5rem 0 .875rem}
.caso-reto p{font-size:.9rem;color:var(--muted);line-height:1.7}
.resultado-grid{display:grid;grid-template-columns:1fr;gap:1rem;margin-top:1rem}
@media(min-width:640px){.resultado-grid{grid-template-columns:1fr 1fr}}
.resultado-item{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.5rem;transition:border-color .25s,transform .25s}
.resultado-item:hover{border-color:var(--border2);transform:translateY(-2px)}
.resultado-icon{font-size:1.5rem;margin-bottom:.875rem}
.resultado-item h4{font-size:.95rem;font-weight:700;margin-bottom:.5rem}
.resultado-item p{font-size:.84rem;color:var(--muted);line-height:1.6;margin:0}
.caso-datos{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;padding-top:2rem;border-top:1px solid var(--border)}
@media(min-width:640px){.caso-datos{grid-template-columns:repeat(4,1fr)}}
.caso-dato{text-align:center;padding:.875rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--r)}
.caso-dato span{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);display:block;margin-bottom:.35rem}
.caso-dato strong{font-size:.88rem;font-weight:700}

/* ---- TRAZABILIDAD SHOWCASE ---- */
.trace-showcase{display:grid;grid-template-columns:1fr;gap:2rem;align-items:start;margin-top:2rem}
@media(min-width:900px){.trace-showcase{grid-template-columns:1fr 1fr}}
.trace-screen{background:var(--surface);border:1px solid var(--border2);border-radius:var(--r-lg);overflow:hidden;box-shadow:0 16px 48px rgba(0,0,0,.4)}
.trace-copy{display:flex;flex-direction:column;gap:1.5rem}
.trace-point{display:flex;align-items:flex-start;gap:1rem}
.trace-point-icon{font-size:1.5rem;flex-shrink:0;width:2.5rem;text-align:center;margin-top:.1rem}
.trace-point strong{display:block;font-size:.95rem;font-weight:700;margin-bottom:.35rem}
.trace-point p{font-size:.84rem;color:var(--muted);line-height:1.6;margin:0}

/* ---- BACKUP GRID ---- */
.backup-grid{display:grid;grid-template-columns:1fr;gap:1rem;margin-top:2rem}
@media(min-width:640px){.backup-grid{grid-template-columns:repeat(3,1fr)}}
.backup-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.75rem;transition:border-color .25s,transform .25s}
.backup-card:hover{border-color:var(--border2);transform:translateY(-3px)}
.backup-card h3{font-size:1rem;font-weight:700;margin:.875rem 0 .5rem}
.backup-card p{font-size:.85rem;color:var(--muted);line-height:1.6}

/* ---- CONTACT PAGE ---- */
.contact-hero{padding:calc(80px + 4rem) var(--pad) 3.5rem;position:relative;overflow:hidden;text-align:center}
.contact-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 50% at 50% 0%,rgba(255,69,0,.2),transparent);pointer-events:none}
.contact-hero-inner{max-width:680px;margin:0 auto;position:relative;z-index:1}
.contact-hero-title{font-family:'Sora',sans-serif;font-size:clamp(2.4rem,6vw,4rem);font-weight:800;line-height:1.1;letter-spacing:-.035em;margin:.875rem 0 1rem}
.contact-hero-title em{font-style:normal;background:linear-gradient(135deg,var(--primary),var(--yellow));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.contact-hero-lead{font-size:clamp(.95rem,2vw,1.1rem);color:var(--muted);line-height:1.7;margin-bottom:1.5rem}
.contact-trust{display:flex;flex-wrap:wrap;justify-content:center;gap:.625rem 1.5rem;font-size:.8rem;font-weight:600;color:var(--muted)}
.contact-trust span{display:flex;align-items:center;gap:.35rem}

.contact-section{padding:0 var(--pad) clamp(4rem,8vw,6rem);max-width:var(--max);margin:0 auto}
.contact-layout{display:grid;grid-template-columns:1fr;gap:2.5rem;align-items:start}
@media(min-width:900px){.contact-layout{grid-template-columns:1fr 420px}}

/* Form card */
.contact-form-wrap{background:var(--surface);border:1px solid var(--border2);border-radius:var(--r-xl);padding:clamp(1.75rem,4vw,2.5rem);box-shadow:0 24px 60px rgba(0,0,0,.4)}
.contact-form{display:flex;flex-direction:column;gap:1.25rem}
.cf-row{display:grid;grid-template-columns:1fr;gap:1.25rem}
@media(min-width:520px){.cf-row{grid-template-columns:1fr 1fr}}
.cf-field{display:flex;flex-direction:column;gap:.5rem}
.cf-field-full{grid-column:1/-1}
.cf-field label{display:flex;align-items:center;gap:.5rem;font-size:.82rem;font-weight:700;color:var(--muted)}
.cf-icon{font-size:1rem;line-height:1}
.cf-field input,.cf-field select,.cf-field textarea{
  background:var(--bg);
  border:1.5px solid var(--border2);
  color:var(--text);
  padding:.875rem 1rem;
  border-radius:var(--r);
  font:inherit;font-size:.92rem;
  transition:border-color .2s,box-shadow .2s,background .2s;
  outline:none;
  width:100%;
  -webkit-appearance:none;
}
.cf-field input::placeholder,.cf-field textarea::placeholder{color:var(--subtle)}
.cf-field select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238888AA' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}
.cf-field select option{background:#16162A;color:#FFFFFF}
.cf-field input:focus,.cf-field select:focus,.cf-field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(255,69,0,.18),0 0 20px rgba(255,69,0,.08);background:rgba(255,69,0,.03)}
.cf-field textarea{resize:vertical;min-height:110px;line-height:1.6}
.cf-submit{
  display:flex;align-items:center;justify-content:center;gap:.625rem;
  background:var(--primary);color:#fff;
  padding:1.1rem 2rem;border-radius:50px;
  font-family:'Sora',sans-serif;font-size:1rem;font-weight:700;
  cursor:pointer;border:none;
  box-shadow:0 0 28px var(--glow),0 4px 16px rgba(255,69,0,.3);
  transition:background .2s,transform .2s,box-shadow .2s;
  width:100%;margin-top:.25rem;
}
.cf-submit:hover{background:var(--primary2);transform:translateY(-2px);box-shadow:0 0 40px var(--glow),0 8px 24px rgba(255,69,0,.35)}
.cf-submit svg{transition:transform .2s}
.cf-submit:hover svg{transform:translateX(4px)}

/* Aside */
.contact-aside{display:flex;flex-direction:column;gap:1.25rem}
.contact-aside h2{font-family:'Sora',sans-serif;font-size:clamp(1.5rem,3vw,2rem);font-weight:800;line-height:1.2;letter-spacing:-.025em;margin:.5rem 0 .75rem}
.contact-aside p{font-size:.9rem;color:var(--muted);line-height:1.7}
.contact-steps{display:flex;flex-direction:column;gap:.875rem;margin-top:.5rem}
.contact-step{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);transition:border-color .25s}
.contact-step:hover{border-color:var(--border2)}
.cs-num{font-family:'Sora',sans-serif;font-size:1.4rem;font-weight:800;color:var(--subtle);line-height:1;flex-shrink:0;width:2.5rem}
.cs-body strong{display:block;font-size:.9rem;font-weight:700;margin-bottom:.3rem}
.cs-body p{font-size:.82rem;color:var(--muted);line-height:1.55;margin:0}
.contact-aside-note{display:flex;align-items:center;gap:.875rem;background:rgba(255,69,0,.08);border:1px solid rgba(255,69,0,.2);border-radius:var(--r);padding:1rem 1.25rem;margin-top:.25rem}
.contact-aside-note span{font-size:1.4rem;flex-shrink:0}
.contact-aside-note p{font-size:.82rem;color:var(--muted);margin:0;line-height:1.5}
