  :root{
    --bg:#0a0814;
    --bg-soft:#120f1f;
    --surface:#16132a;
    --surface-2:#1f1a37;
    --violet-deep:#29124f;
    --violet:#4b1f8c;
    --magenta:#d44a93;
    --magenta-bright:#ef6cb6;
    --text:#f4f1fb;
    --text-muted:#9d93b8;
    --text-faint:#6e6589;
    --border:rgba(255,255,255,0.08);
    --grad: linear-gradient(135deg, #29124f 0%, #6a2f9e 45%, #d44a93 100%);
    --grad-soft: linear-gradient(135deg, rgba(106,47,158,0.18), rgba(212,74,147,0.18));
    --ease: cubic-bezier(.16,.84,.44,1);
  }

  *{margin:0;padding:0;box-sizing:border-box;}

  html{scroll-behavior:smooth;}

  body{
    background:var(--bg);
    color:var(--text);
    font-family:'Inter',sans-serif;
    overflow-x:hidden;
    -webkit-font-smoothing:antialiased;
  }

  h1,h2,h3,.display{
    font-family:'Plus Jakarta Sans',sans-serif;
    letter-spacing:-0.02em;
  }

  a{color:inherit;text-decoration:none;}
  img{max-width:100%;display:block;}
  ul{list-style:none;}

  ::selection{background:var(--magenta);color:#fff;}

  @media (prefers-reduced-motion: reduce){
    *{animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important; scroll-behavior:auto !important;}
  }

  .wrap{max-width:1200px;margin:0 auto;padding:0 32px;}

  /* background ambient glow */
  body::before{
    content:"";
    position:fixed;
    top:-20%;
    left:50%;
    transform:translateX(-50%);
    width:1200px;
    height:1200px;
    background:radial-gradient(circle, rgba(106,47,158,0.25) 0%, rgba(212,74,147,0.08) 40%, transparent 70%);
    pointer-events:none;
    z-index:0;
  }

  /* ===== LAYOUT (sidebar + content) ===== */
  .layout{
    display:flex;
    align-items:stretch;
    min-height:100vh;
    position:relative;
    z-index:1;
  }

  /* ===== SIDEBAR ===== */
  .sidebar{
    width:272px;
    flex-shrink:0;
    position:fixed;
    top:0;left:0;bottom:0;
    z-index:200;
    background:var(--bg-soft);
    border-right:1px solid var(--border);
    padding:30px 22px 26px;
    display:flex;
    flex-direction:column;
    overflow-y:auto;
    transition:transform .45s var(--ease);
  }
  .sidebar::-webkit-scrollbar{width:0;}
  .sidebar-brand{display:flex;align-items:center;gap:10px;margin-bottom:34px;padding:0 6px;}
  .sidebar-brand img{height:34px;width:auto;}

  .sidebar-section-label{
    font-size:11px;
    text-transform:uppercase;
    letter-spacing:.1em;
    color:var(--text-faint);
    font-weight:600;
    margin:0 6px 12px;
  }

  .sidebar-links{display:flex;flex-direction:column;gap:3px;margin-bottom:28px;}
  .sidebar-links a{
    display:flex;
    align-items:center;
    gap:13px;
    padding:11px 14px;
    border-radius:13px;
    font-size:14.5px;
    font-weight:500;
    color:var(--text-muted);
    transition:color .3s, background .3s, transform .3s var(--ease);
  }
  .sidebar-links a svg{width:18px;height:18px;flex-shrink:0;opacity:.8;transition:opacity .3s;}
  .sidebar-links a:hover{color:var(--text);background:rgba(255,255,255,0.05);}
  .sidebar-links a:hover svg{opacity:1;}
  .sidebar-links a.active{
    color:#fff;
    background:var(--grad);
    box-shadow:0 6px 18px rgba(212,74,147,0.3);
  }
  .sidebar-links a.active svg{opacity:1;}

  .sidebar-spacer{flex:1;min-height:24px;}

  .sidebar-promo{
    background:var(--grad);
    border-radius:18px;
    padding:22px 20px;
    margin-bottom:16px;
    position:relative;
    overflow:hidden;
  }
  .sidebar-promo::after{
    content:"";
    position:absolute;
    width:140px;height:140px;
    border-radius:50%;
    background:radial-gradient(circle, rgba(255,255,255,0.22), transparent 70%);
    top:-50px;right:-40px;
  }
  .sidebar-promo .dot-status{
    display:inline-flex;align-items:center;gap:6px;
    font-size:11.5px;font-weight:600;color:rgba(255,255,255,0.9);
    margin-bottom:10px;
    position:relative;z-index:1;
  }
  .sidebar-promo .dot-status span{
    width:7px;height:7px;border-radius:50%;background:#7CFFA0;
    box-shadow:0 0 0 4px rgba(124,255,160,0.25);
  }
  .sidebar-promo p{font-size:13.5px;color:rgba(255,255,255,0.92);line-height:1.5;margin-bottom:16px;position:relative;z-index:1;}
  .sidebar-promo .btn{width:100%;justify-content:center;position:relative;z-index:1;}
  .sidebar-promo .btn-light{
    background:rgba(255,255,255,0.95);
    color:#2a1255;
    box-shadow:none;
  }
  .sidebar-promo .btn-light:hover{background:#fff;transform:translateY(-2px);}

  .sidebar-socials{display:flex;gap:8px;padding:0 4px;}
  .sidebar-socials a{
    width:34px;height:34px;border-radius:50%;
    border:1px solid var(--border);
    display:flex;align-items:center;justify-content:center;
    transition:background .3s, border-color .3s, transform .3s var(--ease);
  }
  .sidebar-socials a svg{width:14px;height:14px;}
  .sidebar-socials a:hover{background:var(--grad);border-color:transparent;transform:translateY(-3px);}

  .sidebar-close{display:none;background:none;border:none;cursor:pointer;}

  .sidebar-overlay{
    display:none;
    position:fixed;inset:0;
    background:rgba(5,4,10,0.6);
    backdrop-filter:blur(2px);
    z-index:190;
    opacity:0;
    transition:opacity .35s var(--ease);
  }
  .sidebar-overlay.show{display:block;opacity:1;}

  /* ===== CONTENT (everything right of sidebar) ===== */
  .content{
    margin-left:272px;
    flex:1;
    min-width:0;
    display:flex;
    flex-direction:column;
  }

  /* ===== TOPBAR ===== */
  .topbar{
    position:sticky;
    top:0;
    z-index:80;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:20px;
    padding:18px 40px;
    background:rgba(10,8,20,0.6);
    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);
    border-bottom:1px solid transparent;
    transition:border-color .4s var(--ease), background .4s var(--ease);
  }
  .topbar.scrolled{background:rgba(10,8,20,0.85);border-bottom:1px solid var(--border);}
  .topbar-title{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:15.5px;color:var(--text-muted);}
  .topbar-title b{color:var(--text);}
  .topbar-right{display:flex;align-items:center;gap:16px;}

  .btn{
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:11px 22px;
    border-radius:100px;
    font-weight:600;
    font-size:14.5px;
    border:none;
    cursor:pointer;
    transition:transform .35s var(--ease), box-shadow .35s var(--ease), filter .3s;
    font-family:'Inter',sans-serif;
  }
  .btn-grad{
    background:var(--grad);
    color:#fff;
    box-shadow:0 4px 18px rgba(212,74,147,0.28);
  }
  .btn-grad:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 8px 28px rgba(212,74,147,0.42);}
  .btn-grad svg{transition:transform .35s var(--ease);}
  .btn-grad:hover svg{transform:translateX(3px);}
  .btn-ghost{
    background:transparent;
    color:var(--text);
    border:1px solid var(--border);
  }
  .btn-ghost:hover{background:rgba(255,255,255,0.06);border-color:rgba(255,255,255,0.2);}

  .burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;}
  .burger span{width:22px;height:2px;background:var(--text);border-radius:2px;}

  /* ===== HERO ===== */
  .hero{
    position:relative;
    padding:64px 0 100px;
    z-index:1;
  }
  .hero::before{
    content:"";
    position:absolute;
    inset:0;
    background-image:
      linear-gradient(180deg, rgba(10,8,20,0.55) 0%, rgba(10,8,20,0.3) 35%, rgba(10,8,20,0.88) 82%, var(--bg) 100%),
      url('hero-bg.png');
    background-size:cover;
    background-position:74% 38%;
    background-repeat:no-repeat;
    z-index:0;
    pointer-events:none;
  }
  .hero .wrap{
    position:relative;
    z-index:1;
  }
  .hero-grid{
    display:grid;
    grid-template-columns:1.05fr 0.95fr;
    gap:40px;
    align-items:center;
  }
  .eyebrow{
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:7px 14px 7px 8px;
    border-radius:100px;
    background:var(--surface);
    border:1px solid var(--border);
    font-size:13px;
    font-weight:500;
    color:var(--text-muted);
    margin-bottom:24px;
  }
  .eyebrow .dot{
    width:18px;height:18px;border-radius:50%;
    background:var(--grad);
    display:inline-flex;align-items:center;justify-content:center;
  }
  .hero h1{
    font-size:clamp(38px, 5.2vw, 68px);
    line-height:1.04;
    font-weight:800;
    margin-bottom:22px;
  }
  .hero h1 .grad-text{
    background:var(--grad);
    -webkit-background-clip:text;
    background-clip:text;
    color:transparent;
  }
  .hero p.lead{
    font-size:16px;
    color:var(--text-muted);
    max-width:520px;
    line-height:1.65;
    margin-bottom:34px;
  }
  .hero-actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-bottom:46px;}
  .play-link{display:flex;align-items:center;gap:10px;font-size:14.5px;font-weight:600;color:var(--text);}
  .play-circle{
    width:42px;height:42px;border-radius:50%;
    border:1px solid var(--border);
    display:flex;align-items:center;justify-content:center;
    transition:background .3s, border-color .3s;
  }
  .play-link:hover .play-circle{background:var(--surface-2);border-color:rgba(255,255,255,.2);}

  .trust{display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
  .trust-avatars{display:flex;}
  .trust-avatars .avatar-mini{
    width:34px;height:34px;
    border-radius:50%;
    border:2px solid var(--bg);
    margin-left:-10px;
    background:var(--grad);
    display:flex;align-items:center;justify-content:center;
    font-size:11px;font-weight:700;color:#fff;
    font-family:'Plus Jakarta Sans',sans-serif;
  }
  .trust-avatars .avatar-mini:first-child{margin-left:0;}
  .trust-rating{display:flex;flex-direction:column;gap:3px;}
  .trust-stars{display:flex;gap:2px;color:#facc15;}
  .trust-stars svg{width:13px;height:13px;}
  .trust-text{font-size:12.5px;color:var(--text-muted);}
  .trust-text b{color:var(--text);font-weight:700;}

  /* hero visual: robot hand image + status card + icon dock */
  .hero-visual{
    position:relative;
    height:560px;
    display:flex;
    align-items:center;
    justify-content:center;
  }
  .hero-visual::before{
    content:"";
    position:absolute;
    width:380px;height:380px;
    border-radius:50%;
    background:radial-gradient(circle, rgba(212,74,147,0.32) 0%, rgba(106,47,158,0.2) 50%, transparent 75%);
    filter:blur(30px);
    z-index:0;
  }
  .device-mock{
    position:relative;
    z-index:1;
    width:540px;
    max-width:76%;
    animation:floatSlow 7s ease-in-out infinite;
  }
  .device-tilt{
    transition:transform .3s var(--ease);
    will-change:transform;
  }
  .device-mock img{
    width:100%;
    height:auto;
    display:block;
    filter:drop-shadow(0 30px 60px rgba(212,74,147,0.3));
  }
  @keyframes floatSlow{
    0%,100%{transform:translateY(0);}
    50%{transform:translateY(-16px);}
  }

  .build-status-card{
    position:absolute;
    top:0%;
    right:-4%;
    width:210px;
    background:rgba(18,15,31,0.92);
    border:1px solid var(--border);
    border-radius:18px;
    padding:18px 18px 16px;
    backdrop-filter:blur(14px);
    box-shadow:0 20px 50px rgba(0,0,0,0.45);
    z-index:3;
    animation:floaty 7s ease-in-out infinite;
    animation-delay:.6s;
  }
  .bsc-live{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-faint);margin-bottom:12px;}
  .bsc-live .dot-live{
    width:7px;height:7px;border-radius:50%;
    background:#7CFFA0;
    box-shadow:0 0 0 3px rgba(124,255,160,.25);
    animation:dotPulse 2s ease-in-out infinite;
  }
  .bsc-title{display:flex;align-items:center;gap:7px;font-size:13.5px;font-weight:700;margin-bottom:16px;}
  .bsc-title svg{width:15px;height:15px;color:var(--magenta-bright);flex-shrink:0;}
  .bsc-item{margin-bottom:13px;}
  .bsc-item:nth-of-type(3){margin-bottom:16px;}
  .bsc-item-top{display:flex;justify-content:space-between;font-size:11.5px;color:var(--text-muted);margin-bottom:6px;}
  .bsc-item-top b{color:var(--text);font-weight:700;}
  .bsc-bar{height:5px;border-radius:10px;background:var(--surface-2);overflow:hidden;}
  .bsc-bar-fill{height:100%;border-radius:10px;background:var(--grad);animation:barGrow 1.8s var(--ease) both;}
  @keyframes barGrow{from{width:0;}}
  .bsc-link{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--magenta-bright);transition:opacity .25s;}
  .bsc-link:hover{opacity:.8;}
  .bsc-link svg{width:12px;height:12px;}

  .float-card{
    position:absolute;
    background:rgba(22,19,42,0.85);
    border:1px solid var(--border);
    backdrop-filter:blur(14px);
    border-radius:16px;
    padding:14px 16px;
    display:flex;
    align-items:center;
    gap:10px;
    box-shadow:0 16px 40px rgba(0,0,0,0.4);
    animation:floaty 6s ease-in-out infinite;
    z-index:2;
  }
  .float-card .ic{
    width:34px;height:34px;border-radius:10px;
    background:var(--grad);
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;
  }
  .float-card .ic svg{width:17px;height:17px;}
  .float-card .label{font-size:11px;color:var(--text-faint);}
  .float-card .value{font-size:14px;font-weight:700;}
  .fc-1{top:6%;left:-6%;animation-delay:0s;}
  .fc-2{bottom:16%;right:-10%;animation-delay:1.8s;}
  .fc-3{bottom:-2%;left:2%;animation-delay:3.2s;}
  @keyframes floaty{
    0%,100%{transform:translateY(0px);}
    50%{transform:translateY(-12px);}
  }

  /* ===== MARQUEE ===== */
  .marquee-section{
    position:relative;
    z-index:1;
    padding:34px 0;
    border-top:1px solid var(--border);
    border-bottom:1px solid var(--border);
    background:var(--bg-soft);
    overflow:hidden;
    -webkit-mask-image:linear-gradient(90deg, transparent 0%, black 14%, black 86%, transparent 100%);
    mask-image:linear-gradient(90deg, transparent 0%, black 14%, black 86%, transparent 100%);
  }
  .marquee-track{
    display:flex;
    width:max-content;
    animation:marqueeScroll 26s linear infinite;
  }
  .marquee-section:hover .marquee-track{animation-play-state:paused;}
  .marquee-group{
    display:flex;
    align-items:center;
    flex-shrink:0;
  }
  .marquee-group span.txt{
    font-family:'Plus Jakarta Sans',sans-serif;
    font-size:clamp(19px, 2.4vw, 30px);
    font-weight:700;
    color:var(--text);
    white-space:nowrap;
    padding:0 28px;
  }
  .marquee-group span.txt .grad-text{
    background:var(--grad);
    -webkit-background-clip:text;
    background-clip:text;
    color:transparent;
  }
  .marquee-group span.sep{
    font-size:16px;
    color:var(--magenta-bright);
    flex-shrink:0;
  }
  @keyframes marqueeScroll{
    from{transform:translateX(0);}
    to{transform:translateX(-50%);}
  }
  @media (prefers-reduced-motion: reduce){
    .marquee-track{animation:none;}
  }

  /* ===== LO QUE CREAMOS (services pills) ===== */
  .creamos-section{
    position:relative;
    z-index:1;
    padding:28px 0;
    border-bottom:1px solid var(--border);
    background:var(--bg-soft);
  }
  .creamos-wrap{display:flex;align-items:center;gap:28px;}
  .creamos-label{
    display:flex;align-items:center;gap:10px;
    font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
    color:var(--text-faint);
    flex-shrink:0;
    line-height:1.3;
    transition:color .3s;
  }
  .creamos-label:hover{color:var(--text-muted);}
  .creamos-label svg{width:14px;height:14px;color:var(--magenta-bright);flex-shrink:0;}
  .creamos-track-wrap{
    overflow-x:auto;
    flex:1;
    min-width:0;
    -ms-overflow-style:none;
    scrollbar-width:none;
  }
  .creamos-track-wrap::-webkit-scrollbar{display:none;}
  .creamos-track{display:flex;gap:12px;width:max-content;}
  .creamos-pill{
    display:flex;align-items:center;gap:9px;
    padding:10px 18px;
    border-radius:100px;
    border:1px solid var(--border);
    background:var(--surface);
    font-size:13.5px;font-weight:600;color:var(--text-muted);
    white-space:nowrap;
    transition:border-color .3s, color .3s, background .3s, transform .3s var(--ease);
  }
  .creamos-pill svg{width:15px;height:15px;color:var(--magenta-bright);flex-shrink:0;}
  .creamos-pill:hover{color:var(--text);border-color:rgba(212,74,147,0.4);background:var(--surface-2);transform:translateY(-2px);}

  /* ===== WIDGETS PREVIEW GRID ===== */
  .widgets-section{position:relative;z-index:1;padding:70px 0;}
  .widgets-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:20px;
  }
  .widget-card{
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:20px;
    padding:22px;
    display:flex;
    flex-direction:column;
    transition:transform .4s var(--ease), border-color .4s var(--ease);
  }
  .widget-card:hover{transform:translateY(-6px);border-color:rgba(255,255,255,0.16);}
  .widget-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px;gap:10px;}
  .widget-head h4{font-size:14.5px;font-weight:700;}
  .widget-head .sub{font-size:11.5px;color:var(--text-faint);margin-top:3px;line-height:1.4;}
  .widget-status{display:flex;align-items:center;gap:5px;font-size:11px;color:#7CFFA0;font-weight:600;flex-shrink:0;white-space:nowrap;margin-top:2px;}
  .widget-status .dot{width:6px;height:6px;border-radius:50%;background:#7CFFA0;box-shadow:0 0 0 3px rgba(124,255,160,.25);animation:dotPulse 2s ease-in-out infinite;}

  /* Widget 1: Consola IA */
  .console-body{
    background:var(--bg-soft);
    border:1px solid var(--border);
    border-radius:12px;
    padding:13px 14px;
    font-size:12px;
    color:var(--text-muted);
    flex:1;
    display:flex;
    flex-direction:column;
    gap:9px;
    min-height:180px;
  }
  .console-prompt{color:var(--magenta-bright);font-family:'SFMono-Regular',Menlo,Consolas,monospace;display:flex;align-items:center;gap:2px;}
  .console-prompt .blink-cursor{display:inline-block;width:6px;height:12px;background:var(--magenta-bright);margin-left:2px;animation:blinkCursor 1s step-end infinite;}
  @keyframes blinkCursor{50%{opacity:0;}}
  .console-msg-user{
    align-self:flex-end;
    background:var(--grad);
    color:#fff;
    padding:8px 12px;
    border-radius:11px 11px 3px 11px;
    font-family:'Inter',sans-serif;
    font-size:12px;
    line-height:1.5;
    max-width:90%;
  }
  .console-line{color:var(--text-faint);font-family:'SFMono-Regular',Menlo,Consolas,monospace;font-size:11.5px;display:flex;align-items:center;gap:3px;}
  .console-loading-row{display:flex;gap:4px;margin-top:2px;}
  .console-loading-row span{
    width:16px;height:6px;border-radius:3px;
    background:var(--grad);
    opacity:.3;
    animation:consoleChip 1.6s ease-in-out infinite;
  }
  .console-loading-row span:nth-child(1){animation-delay:0s;}
  .console-loading-row span:nth-child(2){animation-delay:.2s;}
  .console-loading-row span:nth-child(3){animation-delay:.4s;}
  .console-loading-row span:nth-child(4){animation-delay:.6s;}
  @keyframes consoleChip{0%,100%{opacity:.25;}50%{opacity:1;}}

  /* Widget 2: Proceso de trabajo (mini) */
  .mini-process{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    position:relative;
    margin-top:auto;
    padding-top:22px;
    flex:1;
  }
  .mini-process::before{
    content:"";
    position:absolute;
    top:19px;left:19px;right:19px;
    height:2px;
    background:var(--border);
    border-radius:2px;
  }
  .mini-process-progress{
    position:absolute;
    top:19px;left:19px;
    height:2px;
    background:var(--grad);
    border-radius:2px;
    box-shadow:0 0 10px rgba(212,74,147,.6);
    animation:miniProgress 6s ease-in-out infinite alternate;
  }
  @keyframes miniProgress{0%{width:8%;}100%{width:82%;}}
  .mini-step{
    display:flex;flex-direction:column;align-items:center;gap:8px;
    position:relative;z-index:1;
    flex:1;
  }
  .mini-step-ic{
    width:38px;height:38px;border-radius:50%;
    background:var(--bg-soft);
    border:1.5px solid var(--border);
    display:flex;align-items:center;justify-content:center;
    color:var(--text-muted);
    transition:background .4s, border-color .4s, color .4s;
  }
  .mini-step-ic svg{width:16px;height:16px;}
  .mini-step span{font-size:10px;color:var(--text-faint);font-weight:600;text-align:center;}
  .mini-step.active .mini-step-ic{background:var(--grad);border-color:transparent;color:#fff;}
  .mini-step.active span{color:var(--text);}

  /* Widget 3: Antes / Después slider */
  .compare-wrap{
    position:relative;
    flex:1;
    min-height:180px;
    border-radius:14px;
    overflow:hidden;
    margin-top:4px;
    cursor:ew-resize;
    user-select:none;
    touch-action:pan-y;
  }
  .compare-panel{position:absolute;inset:0;padding:16px;display:flex;flex-direction:column;justify-content:center;gap:10px;}
  .compare-after{background:linear-gradient(135deg, #3a1a63, #7a35ab);}
  .compare-before{
    background:linear-gradient(135deg, #232230, #34323f);
    filter:grayscale(.3) brightness(.9);
    clip-path:inset(0 50% 0 0);
    transition:clip-path .25s ease;
  }
  .cm-bar{height:9px;border-radius:5px;background:rgba(255,255,255,0.22);}
  .compare-after .cm-bar{background:rgba(255,255,255,0.35);}
  .cm-row{display:flex;gap:8px;}
  .cm-box{flex:1;height:34px;border-radius:8px;background:rgba(255,255,255,0.14);}
  .compare-after .cm-box{background:rgba(255,255,255,0.24);}
  .compare-label{
    position:absolute;top:10px;
    font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
    padding:4px 10px;border-radius:100px;
    background:rgba(0,0,0,.45);
    color:#fff;
    z-index:2;
  }
  .compare-label.left{left:10px;}
  .compare-label.right{right:10px;}
  .compare-handle{
    position:absolute;top:0;bottom:0;
    left:50%;
    width:2px;
    background:rgba(255,255,255,.65);
    z-index:3;
    pointer-events:none;
    transition:left .25s ease;
  }
  .compare-handle-btn{
    position:absolute;top:50%;left:50%;
    transform:translate(-50%,-50%);
    width:34px;height:34px;
    border-radius:50%;
    background:var(--grad);
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 8px 20px rgba(212,74,147,.5);
    pointer-events:none;
  }
  .compare-handle-btn svg{width:14px;height:14px;color:#fff;}

  /* Widget 4: Tecnologías */
  .tech-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:auto;}
  .tech-chip{
    display:flex;align-items:center;gap:7px;
    padding:8px 12px;
    border-radius:10px;
    background:var(--surface-2);
    border:1px solid var(--border);
    font-size:11.5px;font-weight:600;color:var(--text-muted);
    transition:border-color .3s, color .3s;
  }
  .tech-chip:hover{color:var(--text);border-color:rgba(255,255,255,0.2);}
  .tech-chip .dot{width:8px;height:8px;border-radius:3px;flex-shrink:0;}

  /* ===== TRUST LOGOS (expanded) ===== */
  .trust-logos-section{position:relative;z-index:1;padding:0 0 70px;}
  .trust-logos-row{
    display:flex;
    align-items:center;
    gap:30px;
    flex-wrap:wrap;
    justify-content:center;
    padding-top:40px;
    border-top:1px solid var(--border);
  }
  .trust-logos-label{
    font-size:11px;text-transform:uppercase;letter-spacing:.1em;
    color:var(--text-faint);font-weight:600;
    flex-shrink:0;
  }
  .trust-logos-list{display:flex;gap:36px;flex-wrap:wrap;justify-content:center;}
  .trust-logos-list span{
    font-family:'Plus Jakarta Sans',sans-serif;
    font-weight:700;font-size:16px;
    color:var(--text-faint);
    opacity:.7;
    transition:opacity .3s, color .3s;
  }
  .trust-logos-list span:hover{opacity:1;color:var(--text-muted);}

  /* ===== CURSOR FOLLOWER (logo motif) ===== */
  .cursor-follower{
    position:fixed;
    top:0;left:0;
    width:34px;height:34px;
    margin-left:-17px;
    margin-top:-17px;
    pointer-events:none;
    z-index:9999;
    opacity:0;
    transition:opacity .4s var(--ease);
    will-change:transform;
  }
  .cursor-follower.active{opacity:1;}
  .cursor-follower svg{
    width:100%;
    height:100%;
    animation:cursorSpin 7s linear infinite;
    filter:drop-shadow(0 4px 14px rgba(212,74,147,0.45));
  }
  @keyframes cursorSpin{ to{ transform:rotate(360deg); } }
  @media (hover:none), (pointer:coarse){
    .cursor-follower{display:none;}
  }

  /* ===== SECTION SHELL ===== */
  section{position:relative;z-index:1;padding:110px 0;}
  .section-head{max-width:620px;margin-bottom:64px;}
  .tag{
    display:inline-flex;align-items:center;gap:8px;
    font-size:13px;font-weight:600;letter-spacing:.05em;
    color:var(--magenta-bright);
    margin-bottom:16px;
    text-transform:uppercase;
  }
  .tag::before{
    content:"";width:7px;height:7px;border-radius:50%;background:var(--magenta-bright);
    box-shadow:0 0 0 4px rgba(212,74,147,0.18);
  }
  .section-head h2{font-size:clamp(28px,3.4vw,42px);font-weight:800;line-height:1.15;margin-bottom:14px;}
  .section-head p{color:var(--text-muted);font-size:16.5px;line-height:1.6;}

  .reveal{
    opacity:0;
    transform:translateY(28px);
    transition:opacity .8s var(--ease), transform .8s var(--ease);
  }
  .reveal.in{opacity:1;transform:translateY(0);}
  .reveal-stagger > *{transition-delay:calc(var(--i, 0) * 90ms);}

  /* ===== SERVICES ===== */
  .services-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:22px;
  }
  .service-card{
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:20px;
    padding:30px 26px;
    position:relative;
    overflow:hidden;
    transition:transform .45s var(--ease), border-color .45s var(--ease), background .45s var(--ease);
  }
  .service-card::before{
    content:"";
    position:absolute;inset:0;
    background:var(--grad-soft);
    opacity:0;
    transition:opacity .45s var(--ease);
  }
  .service-card:hover{
    transform:translateY(-8px);
    border-color:rgba(212,74,147,0.4);
  }
  .service-card:hover::before{opacity:1;}
  .service-card .num{
    position:absolute;top:22px;right:24px;
    font-size:13px;color:var(--text-faint);font-weight:600;
  }
  .service-icon{
    width:50px;height:50px;border-radius:14px;
    background:var(--grad);
    display:flex;align-items:center;justify-content:center;
    margin-bottom:24px;
    position:relative;z-index:1;
    transition:transform .45s var(--ease);
  }
  .service-card:hover .service-icon{transform:rotate(-8deg) scale(1.08);}
  .service-icon svg{width:24px;height:24px;color:#fff;}
  .service-card h3{font-size:18.5px;font-weight:700;margin-bottom:10px;position:relative;z-index:1;}
  .service-card p{font-size:14.5px;color:var(--text-muted);line-height:1.6;position:relative;z-index:1;}
  .service-card .more{
    display:inline-flex;align-items:center;gap:6px;
    margin-top:18px;font-size:13.5px;font-weight:600;color:var(--magenta-bright);
    position:relative;z-index:1;
  }
  .service-card .more svg{width:13px;height:13px;transition:transform .35s var(--ease);}
  .service-card:hover .more svg{transform:translateX(4px);}

  /* ===== PROCESS ===== */
  .process{background:var(--bg-soft);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}

  .process-grid{
    display:grid;
    grid-template-columns:1.05fr 0.95fr;
    gap:56px;
    align-items:center;
  }

  .process-list{
    position:relative;
    padding-left:0;
  }
  .process-line-track{
    position:absolute;
    top:25px;
    bottom:25px;
    left:25px;
    width:2px;
    background:linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.14) 50%, rgba(255,255,255,0.06));
    border-radius:2px;
    overflow:visible;
  }
  .process-line-pulse{
    position:absolute;
    left:50%;
    top:0;
    width:10px;height:10px;
    border-radius:50%;
    transform:translateX(-50%);
    background:radial-gradient(circle, #ffd9ef 0%, var(--magenta-bright) 45%, transparent 75%);
    box-shadow:
      0 0 8px 2px rgba(239,108,182,0.9),
      0 0 22px 6px rgba(212,74,147,0.65),
      0 0 44px 14px rgba(106,47,158,0.35);
    animation:neonTravel 8s linear infinite;
  }
  .process-line-pulse::after{
    content:"";
    position:absolute;
    top:-46px;left:50%;
    width:2px;height:46px;
    transform:translateX(-50%);
    background:linear-gradient(180deg, transparent, rgba(239,108,182,0.7));
    filter:blur(1px);
  }
  @keyframes neonTravel{
    0%{top:0%; opacity:0;}
    6%{opacity:1;}
    94%{opacity:1;}
    100%{top:100%; opacity:0;}
  }

  .process-step{
    display:flex;
    gap:22px;
    align-items:flex-start;
    position:relative;
    padding-bottom:46px;
  }
  .process-step:last-child{padding-bottom:0;}

  .step-ring{
    width:50px;height:50px;
    border-radius:50%;
    background:var(--bg-soft);
    border:1.5px solid var(--border);
    display:flex;align-items:center;justify-content:center;
    font-family:'Plus Jakarta Sans',sans-serif;
    font-weight:700;
    font-size:15px;
    position:relative;
    z-index:1;
    flex-shrink:0;
    transition:transform .4s var(--ease);
    animation:ringGlow 8s ease-in-out infinite;
  }
  .process-step:nth-child(1) .step-ring{animation-delay:0s;}
  .process-step:nth-child(2) .step-ring{animation-delay:2s;}
  .process-step:nth-child(3) .step-ring{animation-delay:4s;}
  .process-step:nth-child(4) .step-ring{animation-delay:6s;}

  @keyframes ringGlow{
    0%{
      background:var(--bg-soft);
      border-color:var(--border);
      box-shadow:none;
      color:var(--text);
    }
    6%{
      background:var(--grad);
      border-color:transparent;
      box-shadow:0 0 10px 2px rgba(239,108,182,0.8), 0 0 28px 8px rgba(212,74,147,0.5), 0 0 50px 16px rgba(106,47,158,0.3);
      color:#fff;
    }
    22%{
      background:var(--bg-soft);
      border-color:var(--border);
      box-shadow:none;
      color:var(--text);
    }
    100%{
      background:var(--bg-soft);
      border-color:var(--border);
      box-shadow:none;
      color:var(--text);
    }
  }

  .process-step:hover .step-ring{transform:scale(1.12);}

  .step-content{padding-top:6px;}
  .process-step h3{font-size:17px;font-weight:700;margin-bottom:8px;}
  .process-step p{font-size:14px;color:var(--text-muted);line-height:1.6;max-width:380px;}

  /* Process visual (dashboard image + animated overlay) */
  .process-visual{
    position:relative;
    display:flex;
    align-items:center;
    justify-content:center;
    height:460px;
  }
  .process-visual::before{
    content:"";
    position:absolute;
    width:340px;height:340px;
    border-radius:50%;
    background:radial-gradient(circle, rgba(212,74,147,0.26) 0%, rgba(106,47,158,0.16) 50%, transparent 75%);
    filter:blur(26px);
    z-index:0;
  }
  .process-image-wrap{
    position:relative;
    z-index:1;
    width:100%;
    max-width:550px;
  }
  .process-image{
    position:relative;
    z-index:1;
    width:100%;
    height:auto;
    display:block;
    filter:drop-shadow(0 26px 55px rgba(212,74,147,0.28));
  }
  .process-overlay-svg{
    position:absolute;
    inset:0;
    z-index:2;
    width:100%;
    height:100%;
    pointer-events:none;
  }
  .process-overlay-svg .flow-path{
    stroke-dasharray:14 16;
    animation:flowDash 2.4s linear infinite;
    filter:drop-shadow(0 0 6px rgba(232,95,174,0.65));
  }
  @keyframes flowDash{
    to{stroke-dashoffset:-60;}
  }
  .process-overlay-svg .flow-node-ring{
    animation:nodePulse 8s ease-in-out infinite;
    transform-origin:center;
    transform-box:fill-box;
  }
  .process-overlay-svg .flow-node{filter:drop-shadow(0 0 8px rgba(232,95,174,0.5));}
  .process-overlay-svg .fn-1{animation-delay:0s;}
  .process-overlay-svg .fn-2{animation-delay:2s;}
  .process-overlay-svg .fn-3{animation-delay:4s;}
  .process-overlay-svg .fn-4{animation-delay:6s;}
  @keyframes nodePulse{
    0%{opacity:.35;transform:scale(1);}
    6%{opacity:1;transform:scale(1.18);}
    22%{opacity:.35;transform:scale(1);}
    100%{opacity:.35;transform:scale(1);}
  }
  .process-float-card{
    position:absolute;
    bottom:6%;
    left:-4%;
    z-index:3;
  }

  @media (prefers-reduced-motion: reduce){
    .process-line-pulse,.step-ring,.flow-path,.flow-node-ring{animation:none !important;}
  }

  /* ===== PORTFOLIO ===== */
  .filter-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:36px;}
  .filter-btn{
    padding:9px 18px;border-radius:100px;
    font-size:13.5px;font-weight:600;
    border:1px solid var(--border);
    background:transparent;color:var(--text-muted);
    cursor:pointer;
    transition:all .3s var(--ease);
  }
  .filter-btn:hover{color:var(--text);border-color:rgba(255,255,255,0.25);}
  .filter-btn.active{background:var(--grad);color:#fff;border-color:transparent;}

  .portfolio-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:22px;
  }
  .pf-card{
    border-radius:20px;
    overflow:hidden;
    position:relative;
    aspect-ratio:4/3.1;
    background:var(--surface);
    border:1px solid var(--border);
    cursor:pointer;
  }
  .pf-card .pf-bg{
    position:absolute;inset:0;
    background:var(--grad-soft);
    transition:transform .6s var(--ease);
  }
  .pf-card .pf-shape{
    position:absolute;
    width:220px;height:220px;
    border-radius:50%;
    filter:blur(10px);
    opacity:.5;
    transition:transform .7s var(--ease);
  }
  .pf-card:hover .pf-shape{transform:scale(1.25) translate(10px,-10px);}
  .pf-card:hover .pf-bg{transform:scale(1.06);}
  .pf-overlay{
    position:absolute;inset:0;
    display:flex;flex-direction:column;justify-content:flex-end;
    padding:24px;
    background:linear-gradient(to top, rgba(10,8,20,0.92) 0%, rgba(10,8,20,0.35) 55%, transparent 100%);
  }
  .pf-overlay .pf-tag{
    align-self:flex-start;
    font-size:11.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;
    color:var(--magenta-bright);
    background:rgba(212,74,147,0.12);
    border:1px solid rgba(212,74,147,0.3);
    padding:5px 12px;border-radius:100px;
    margin-bottom:auto;
    opacity:0;
    transform:translateY(-6px);
    transition:opacity .4s var(--ease), transform .4s var(--ease);
  }
  .pf-card:hover .pf-tag{opacity:1;transform:translateY(0);}
  .pf-overlay h3{font-size:19px;font-weight:700;margin-bottom:4px;}
  .pf-overlay p{font-size:13.5px;color:var(--text-muted);}
  .pf-arrow{
    position:absolute;top:20px;right:20px;
    width:38px;height:38px;border-radius:50%;
    background:rgba(255,255,255,0.08);
    border:1px solid var(--border);
    display:flex;align-items:center;justify-content:center;
    opacity:0;
    transform:scale(.7) rotate(-30deg);
    transition:all .4s var(--ease);
  }
  .pf-card:hover .pf-arrow{opacity:1;transform:scale(1) rotate(0deg);background:var(--grad);border-color:transparent;}
  .pf-arrow svg{width:15px;height:15px;}

  /* ===== PORTFOLIO MODAL ===== */
  .pf-modal-overlay{
    position:fixed;inset:0;
    z-index:400;
    background:rgba(5,4,10,0.78);
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
    display:flex;
    align-items:center;
    justify-content:center;
    padding:24px;
    opacity:0;
    pointer-events:none;
    transition:opacity .35s var(--ease);
  }
  .pf-modal-overlay.show{opacity:1;pointer-events:all;}

  .pf-modal{
    width:560px;
    max-width:100%;
    max-height:86vh;
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:26px;
    overflow:hidden;
    display:flex;
    flex-direction:column;
    box-shadow:0 50px 100px rgba(0,0,0,0.6);
    transform:scale(.92) translateY(24px);
    transition:transform .4s var(--ease);
  }
  .pf-modal-overlay.show .pf-modal{transform:scale(1) translateY(0);}

  .pf-modal-image{
    position:relative;
    height:210px;
    flex-shrink:0;
    overflow:hidden;
  }
  .pf-modal-image .pf-modal-blob{
    position:absolute;
    width:280px;height:280px;
    border-radius:50%;
    filter:blur(6px);
    opacity:.75;
  }
  .pf-modal-image .pf-modal-blob.b1{top:-90px;left:-60px;}
  .pf-modal-image .pf-modal-blob.b2{bottom:-100px;right:-50px;opacity:.55;}
  .pf-modal-image-tag{
    position:absolute;
    top:18px;left:20px;
    font-size:11.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;
    color:#fff;
    background:rgba(255,255,255,0.16);
    border:1px solid rgba(255,255,255,0.3);
    padding:6px 13px;border-radius:100px;
    backdrop-filter:blur(6px);
  }
  .pf-modal-close{
    position:absolute;
    top:16px;right:16px;
    width:34px;height:34px;border-radius:50%;
    background:rgba(0,0,0,0.35);
    border:1px solid rgba(255,255,255,0.2);
    color:#fff;
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;
    transition:background .25s, transform .25s var(--ease);
  }
  .pf-modal-close:hover{background:rgba(0,0,0,0.55);transform:rotate(90deg);}
  .pf-modal-close svg{width:15px;height:15px;}
  .pf-modal-image h3{
    position:absolute;
    bottom:18px;left:22px;right:60px;
    font-size:24px;
    font-weight:800;
    color:#fff;
    text-shadow:0 4px 20px rgba(0,0,0,0.4);
  }

  .pf-modal-body{padding:26px 28px 30px;overflow-y:auto;}
  .pf-modal-meta{
    display:flex;
    gap:24px;
    margin-bottom:20px;
    padding-bottom:20px;
    border-bottom:1px solid var(--border);
  }
  .pf-modal-meta-item .label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint);margin-bottom:3px;}
  .pf-modal-meta-item .value{font-size:14.5px;font-weight:700;color:var(--text);}
  .pf-modal-body p.desc{font-size:14.5px;color:var(--text-muted);line-height:1.7;margin-bottom:22px;}
  .pf-modal-services-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint);font-weight:600;margin-bottom:10px;}
  .pf-modal-services{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:26px;}
  .pf-modal-services span{
    font-size:12.5px;font-weight:500;
    color:var(--text-muted);
    background:var(--surface-2);
    border:1px solid var(--border);
    padding:6px 12px;
    border-radius:100px;
  }
  .pf-modal-cta{display:flex;gap:12px;flex-wrap:wrap;}
  .pf-modal-cta .btn{flex:1;justify-content:center;min-width:180px;}

  /* ===== TEAM (glass + glow cards) ===== */
  .team-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:22px;
  }
  .team-card{
    position:relative;
    background:linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.015));
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
    border:1px solid rgba(255,255,255,0.1);
    border-radius:22px;
    padding:36px 24px 30px;
    text-align:center;
    overflow:hidden;
    box-shadow:0 8px 30px rgba(0,0,0,0.25);
    transition:transform .45s var(--ease), border-color .45s var(--ease), box-shadow .45s var(--ease);
  }
  .team-card::before{
    content:"";
    position:absolute;
    top:-70px;left:50%;
    width:220px;height:220px;
    border-radius:50%;
    background:radial-gradient(circle, rgba(212,74,147,0.4), rgba(106,47,158,0.28) 45%, transparent 72%);
    filter:blur(18px);
    transform:translateX(-50%) scale(.75);
    opacity:0;
    transition:opacity .5s var(--ease), transform .6s var(--ease);
    z-index:0;
    pointer-events:none;
  }
  .team-card::after{
    content:"";
    position:absolute;inset:0;
    border-radius:22px;
    padding:1px;
    background:linear-gradient(135deg, rgba(255,255,255,0.35), transparent 35%, transparent 65%, rgba(212,74,147,0.4));
    -webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite:xor;
    mask-composite:exclude;
    opacity:.5;
    transition:opacity .45s var(--ease);
    pointer-events:none;
  }
  .team-card:hover{
    transform:translateY(-10px);
    border-color:rgba(212,74,147,0.4);
    box-shadow:0 24px 55px rgba(212,74,147,0.22), 0 8px 30px rgba(0,0,0,0.3);
  }
  .team-card:hover::before{opacity:1;transform:translateX(-50%) scale(1.15);}
  .team-card:hover::after{opacity:1;}
  .team-avatar{
    position:relative;
    z-index:1;
    width:84px;height:84px;
    border-radius:50%;
    background:var(--grad);
    display:flex;align-items:center;justify-content:center;
    margin:0 auto 18px;
    font-family:'Plus Jakarta Sans',sans-serif;
    font-weight:800;
    font-size:23px;
    color:#fff;
    transition:transform .45s var(--ease), box-shadow .45s var(--ease);
    box-shadow:0 10px 26px rgba(212,74,147,0.3), 0 0 0 6px rgba(255,255,255,0.04);
  }
  .team-card:hover .team-avatar{
    transform:scale(1.08) rotate(-5deg);
    box-shadow:0 14px 34px rgba(212,74,147,0.45), 0 0 0 8px rgba(212,74,147,0.1);
  }
  .team-name{position:relative;z-index:1;font-size:16.5px;font-weight:700;margin-bottom:4px;}
  .team-role{position:relative;z-index:1;font-size:13px;color:var(--text-muted);margin-bottom:18px;line-height:1.4;}
  .team-socials{position:relative;z-index:1;display:flex;gap:8px;justify-content:center;}
  .team-socials a{
    width:32px;height:32px;border-radius:50%;
    border:1px solid rgba(255,255,255,0.12);
    background:rgba(255,255,255,0.03);
    color:var(--text-muted);
    display:flex;align-items:center;justify-content:center;
    transition:background .3s, border-color .3s, color .3s, transform .3s var(--ease);
  }
  .team-socials a svg{width:13px;height:13px;}
  .team-socials a:hover{background:var(--grad);border-color:transparent;color:#fff;transform:translateY(-2px);}

  /* ===== STATS ===== */
  .stats-panel{
    background:var(--grad);
    border-radius:28px;
    padding:54px 50px;
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:20px;
    position:relative;
    overflow:hidden;
  }
  .stats-panel::after{
    content:"";
    position:absolute;
    top:-60%;right:-10%;
    width:340px;height:340px;
    border-radius:50%;
    background:radial-gradient(circle, rgba(255,255,255,0.18), transparent 70%);
  }
  .stat-item{position:relative;z-index:1;}
  .stat-item .num{
    font-family:'Plus Jakarta Sans',sans-serif;
    font-size:clamp(32px,3.6vw,46px);
    font-weight:800;
    margin-bottom:6px;
  }
  .stat-item .label{font-size:14px;color:rgba(255,255,255,0.85);}

  /* ===== TESTIMONIALS ===== */
  .testi-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:22px;
  }
  .testi-card{
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:20px;
    padding:30px;
    transition:transform .4s var(--ease), border-color .4s var(--ease);
  }
  .testi-card:hover{transform:translateY(-6px);border-color:rgba(255,255,255,0.18);}
  .testi-card .quote-mark{font-size:36px;color:var(--magenta-bright);font-family:'Plus Jakarta Sans';line-height:1;margin-bottom:6px;}
  .testi-card p{font-size:15px;color:var(--text-muted);line-height:1.7;margin-bottom:24px;min-height:84px;}
  .testi-person{display:flex;align-items:center;gap:12px;}
  .avatar{
    width:42px;height:42px;border-radius:50%;
    background:var(--grad);
    display:flex;align-items:center;justify-content:center;
    font-weight:700;font-size:14px;color:#fff;
    flex-shrink:0;
  }
  .testi-person .name{font-size:14.5px;font-weight:700;}
  .testi-person .role{font-size:12.5px;color:var(--text-faint);}

  /* ===== CTA BAND ===== */
  .cta-band{
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:28px;
    padding:64px 56px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:30px;
    position:relative;
    overflow:hidden;
  }
  .cta-band::before{
    content:"";
    position:absolute;
    width:380px;height:380px;
    border-radius:50%;
    background:radial-gradient(circle, rgba(212,74,147,0.22), transparent 70%);
    top:-30%;right:-8%;
  }
  .cta-band h2{font-size:clamp(26px,3vw,38px);font-weight:800;margin-bottom:10px;max-width:460px;position:relative;z-index:1;}
  .cta-band p{color:var(--text-muted);font-size:15.5px;position:relative;z-index:1;}
  .cta-actions{display:flex;gap:14px;position:relative;z-index:1;flex-shrink:0;}

  /* ===== CONTACT (info + form) ===== */
  .contact-grid{
    display:grid;
    grid-template-columns:0.85fr 1.15fr;
    gap:32px;
    align-items:start;
  }
  .contact-info{
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:24px;
    padding:36px 30px;
    position:relative;
    overflow:hidden;
  }
  .contact-info::before{
    content:"";
    position:absolute;
    width:260px;height:260px;
    border-radius:50%;
    background:radial-gradient(circle, rgba(212,74,147,0.18), transparent 70%);
    top:-25%;right:-20%;
  }
  .contact-info h3{font-size:19px;font-weight:700;margin-bottom:8px;position:relative;z-index:1;}
  .contact-info > p{font-size:14px;color:var(--text-muted);line-height:1.6;margin-bottom:28px;position:relative;z-index:1;}
  .contact-info-list{display:flex;flex-direction:column;gap:18px;margin-bottom:30px;position:relative;z-index:1;}
  .contact-info-item{display:flex;align-items:center;gap:14px;}
  .contact-info-item .ic{
    width:42px;height:42px;border-radius:13px;
    background:var(--grad);
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;
  }
  .contact-info-item .ic svg{width:18px;height:18px;color:#fff;}
  .contact-info-item .label{font-size:11.5px;color:var(--text-faint);margin-bottom:2px;}
  .contact-info-item .value{font-size:14px;font-weight:600;color:var(--text);}
  .contact-info-divider{height:1px;background:var(--border);margin-bottom:24px;position:relative;z-index:1;}
  .contact-info .socials{position:relative;z-index:1;}

  .contact-form{
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:24px;
    padding:36px 34px;
  }
  .form-row{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:18px;
    margin-bottom:18px;
  }
  .form-field{display:flex;flex-direction:column;gap:7px;}
  .form-field.full{margin-bottom:18px;}
  .form-field label{
    font-size:12.5px;
    font-weight:600;
    color:var(--text-muted);
  }
  .form-field input,
  .form-field textarea{
    background:var(--surface-2);
    border:1px solid var(--border);
    border-radius:12px;
    padding:12px 14px;
    font-size:14px;
    color:var(--text);
    font-family:'Inter',sans-serif;
    transition:border-color .3s, box-shadow .3s, background .3s;
    width:100%;
  }
  .form-field input::placeholder,
  .form-field textarea::placeholder{color:var(--text-faint);}
  .form-field input:focus,
  .form-field textarea:focus{
    outline:none;
    border-color:rgba(212,74,147,0.55);
    box-shadow:0 0 0 3px rgba(212,74,147,0.15);
    background:var(--surface);
  }
  .form-field textarea{resize:vertical;min-height:110px;font-family:'Inter',sans-serif;}
  .contact-form .btn{width:100%;justify-content:center;margin-top:4px;}
  .contact-form .btn[disabled]{opacity:.7;cursor:default;transform:none;}
  .form-note{font-size:12px;color:var(--text-faint);text-align:center;margin-top:12px;}
  .form-success{
    display:none;
    align-items:center;
    gap:10px;
    margin-top:16px;
    padding:13px 16px;
    border-radius:12px;
    background:rgba(124,255,160,0.1);
    border:1px solid rgba(124,255,160,0.3);
    color:#bdfccf;
    font-size:13.5px;
    font-weight:500;
  }
  .form-success.show{display:flex;animation:bubbleIn .4s var(--ease);}
  .form-success svg{width:16px;height:16px;flex-shrink:0;}

  /* ===== COOKIE CONSENT ===== */
  .cookie-banner{
    position:fixed;
    bottom:24px;left:24px;
    z-index:250;
    width:380px;
    max-width:calc(100vw - 48px);
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:20px;
    padding:22px 24px;
    box-shadow:0 25px 60px rgba(0,0,0,0.5);
    opacity:0;
    transform:translateY(16px);
    pointer-events:none;
    transition:opacity .45s var(--ease), transform .45s var(--ease);
  }
  .cookie-banner.show{opacity:1;transform:translateY(0);pointer-events:all;}
  .cookie-icon{
    width:40px;height:40px;border-radius:12px;
    background:var(--grad);
    display:flex;align-items:center;justify-content:center;
    margin-bottom:14px;
  }
  .cookie-icon svg{width:19px;height:19px;color:#fff;}
  .cookie-banner h4{font-size:15px;font-weight:700;margin-bottom:8px;}
  .cookie-banner p{font-size:13px;color:var(--text-muted);line-height:1.55;margin-bottom:18px;}
  .cookie-banner p a{color:var(--magenta-bright);font-weight:600;}
  .cookie-actions{display:flex;gap:10px;}
  .cookie-actions .btn{flex:1;justify-content:center;padding:10px 14px;font-size:13.5px;}

  /* ===== FOOTER ===== */
  footer{border-top:1px solid var(--border);padding:64px 0 30px;position:relative;z-index:1;}
  .footer-grid{
    display:grid;
    grid-template-columns:1.4fr 1fr 1fr 1fr;
    gap:40px;
    margin-bottom:50px;
  }
  .footer-brand img{height:34px;margin-bottom:16px;}
  .footer-brand p{font-size:14px;color:var(--text-muted);max-width:280px;line-height:1.65;margin-bottom:20px;}
  .socials{display:flex;gap:10px;}
  .socials a{
    width:38px;height:38px;border-radius:50%;
    border:1px solid var(--border);
    display:flex;align-items:center;justify-content:center;
    transition:background .3s, border-color .3s, transform .3s var(--ease);
  }
  .socials a:hover{background:var(--grad);border-color:transparent;transform:translateY(-3px);}
  .socials svg{width:15px;height:15px;}
  .footer-col h4{font-size:14px;font-weight:700;margin-bottom:18px;}
  .footer-col a{
    display:block;
    font-size:14px;color:var(--text-muted);
    margin-bottom:12px;
    transition:color .3s, padding-left .3s;
  }
  .footer-col a:hover{color:var(--text);padding-left:4px;}
  .footer-bottom{
    border-top:1px solid var(--border);
    padding-top:26px;
    display:flex;
    justify-content:space-between;
    align-items:center;
    font-size:13px;
    color:var(--text-faint);
    flex-wrap:wrap;
    gap:12px;
  }

  /* back to top */
  .to-top{
    position:fixed;
    bottom:106px;right:28px;
    width:46px;height:46px;
    border-radius:50%;
    background:var(--surface);
    border:1px solid var(--border);
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;
    box-shadow:0 8px 24px rgba(0,0,0,0.35);
    opacity:0;
    visibility:hidden;
    transform:translateY(10px);
    transition:opacity .4s var(--ease), transform .4s var(--ease), visibility .4s, background .3s;
    z-index:90;
  }
  .to-top.show{opacity:1;visibility:visible;transform:translateY(0);}
  .to-top:hover{transform:translateY(-4px);background:var(--surface-2);}
  .to-top svg{width:18px;height:18px;color:var(--text);}

  /* ===== CHATBOT WIDGET ===== */
  .chatbot{
    position:fixed;
    bottom:28px;right:28px;
    z-index:300;
    font-family:'Inter',sans-serif;
  }

  .chat-teaser{
    position:absolute;
    bottom:76px;right:0;
    width:240px;
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:16px 16px 4px 16px;
    padding:14px 16px;
    font-size:13px;
    line-height:1.5;
    color:var(--text);
    box-shadow:0 16px 40px rgba(0,0,0,0.4);
    opacity:0;
    transform:translateY(10px) scale(.95);
    pointer-events:none;
    transition:opacity .4s var(--ease), transform .4s var(--ease);
  }
  .chat-teaser.show{opacity:1;transform:translateY(0) scale(1);pointer-events:all;}
  .chat-teaser button{
    position:absolute;top:6px;right:6px;
    width:20px;height:20px;border-radius:50%;
    background:transparent;border:none;color:var(--text-faint);
    display:flex;align-items:center;justify-content:center;cursor:pointer;
  }
  .chat-teaser button:hover{color:var(--text);}

  .chat-toggle{
    width:60px;height:60px;
    border-radius:50%;
    background:var(--grad);
    border:none;
    cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 10px 30px rgba(212,74,147,0.4);
    position:relative;
    transition:transform .35s var(--ease), box-shadow .35s var(--ease);
  }
  .chat-toggle:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 14px 38px rgba(212,74,147,0.5);}
  .chat-toggle svg{width:24px;height:24px;color:#fff;position:absolute;transition:opacity .25s var(--ease), transform .25s var(--ease);}
  .chat-toggle .ic-open{opacity:1;transform:scale(1) rotate(0deg);}
  .chat-toggle .ic-close{opacity:0;transform:scale(.5) rotate(-45deg);}
  .chatbot.open .chat-toggle .ic-open{opacity:0;transform:scale(.5) rotate(45deg);}
  .chatbot.open .chat-toggle .ic-close{opacity:1;transform:scale(1) rotate(0deg);}

  .chat-badge{
    position:absolute;
    top:-2px;right:-2px;
    width:20px;height:20px;
    border-radius:50%;
    background:#ef4444;
    color:#fff;
    font-size:11px;
    font-weight:700;
    display:flex;align-items:center;justify-content:center;
    border:2px solid var(--bg);
    animation:badgePulse 2.2s ease-in-out infinite;
  }
  .chat-badge.hide{display:none;}
  @keyframes badgePulse{
    0%,100%{transform:scale(1);}
    50%{transform:scale(1.15);}
  }

  .chat-panel{
    position:absolute;
    bottom:78px;right:0;
    width:368px;
    max-width:calc(100vw - 48px);
    height:520px;
    max-height:calc(100vh - 140px);
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:22px;
    box-shadow:0 30px 70px rgba(0,0,0,0.55);
    display:flex;
    flex-direction:column;
    overflow:hidden;
    transform-origin:bottom right;
    opacity:0;
    transform:scale(.85) translateY(16px);
    pointer-events:none;
    transition:opacity .35s var(--ease), transform .35s var(--ease);
  }
  .chatbot.open .chat-panel{opacity:1;transform:scale(1) translateY(0);pointer-events:all;}

  .chat-header{
    display:flex;
    align-items:center;
    gap:12px;
    padding:16px 18px;
    background:var(--grad);
    flex-shrink:0;
  }
  .chat-avatar{
    width:40px;height:40px;border-radius:50%;
    background:rgba(255,255,255,0.18);
    border:1.5px solid rgba(255,255,255,0.35);
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;
  }
  .chat-avatar svg{width:20px;height:20px;color:#fff;}
  .chat-header-info{flex:1;min-width:0;}
  .chat-name{font-size:14.5px;font-weight:700;color:#fff;display:flex;align-items:center;gap:6px;}
  .online-dot{
    width:8px;height:8px;border-radius:50%;
    background:#7CFFA0;
    box-shadow:0 0 0 3px rgba(124,255,160,0.3);
    flex-shrink:0;
    animation:dotPulse 2s ease-in-out infinite;
  }
  @keyframes dotPulse{0%,100%{opacity:1;}50%{opacity:.5;}}
  .chat-status{font-size:12px;color:rgba(255,255,255,0.85);margin-top:2px;}
  .chat-close{
    width:30px;height:30px;border-radius:50%;
    background:rgba(255,255,255,0.15);
    border:none;color:#fff;
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;
    transition:background .25s;
    flex-shrink:0;
  }
  .chat-close:hover{background:rgba(255,255,255,0.28);}
  .chat-close svg{width:14px;height:14px;}

  .chat-body{
    flex:1;
    padding:18px;
    overflow-y:auto;
    display:flex;
    flex-direction:column;
    gap:12px;
    background:
      radial-gradient(circle at 15% 10%, rgba(106,47,158,0.12), transparent 45%),
      var(--bg-soft);
  }
  .chat-body::-webkit-scrollbar{width:5px;}
  .chat-body::-webkit-scrollbar-thumb{background:var(--surface-2);border-radius:10px;}

  .chat-bubble{
    max-width:86%;
    padding:11px 14px;
    border-radius:14px;
    font-size:13.5px;
    line-height:1.55;
    animation:bubbleIn .35s var(--ease);
  }
  @keyframes bubbleIn{
    from{opacity:0;transform:translateY(8px) scale(.97);}
    to{opacity:1;transform:translateY(0) scale(1);}
  }
  .chat-bubble.bot{
    align-self:flex-start;
    background:var(--surface-2);
    color:var(--text);
    border-radius:14px 14px 14px 4px;
    border:1px solid var(--border);
  }
  .chat-bubble.user{
    align-self:flex-end;
    background:var(--grad);
    color:#fff;
    font-weight:500;
    border-radius:14px 14px 4px 14px;
  }

  .chat-typing{
    align-self:flex-start;
    display:flex;
    gap:4px;
    padding:13px 16px;
    background:var(--surface-2);
    border:1px solid var(--border);
    border-radius:14px 14px 14px 4px;
    animation:bubbleIn .3s var(--ease);
  }
  .chat-typing span{
    width:6px;height:6px;border-radius:50%;
    background:var(--text-faint);
    animation:typingDot 1.2s ease-in-out infinite;
  }
  .chat-typing span:nth-child(2){animation-delay:.15s;}
  .chat-typing span:nth-child(3){animation-delay:.3s;}
  @keyframes typingDot{
    0%,60%,100%{transform:translateY(0);opacity:.4;}
    30%{transform:translateY(-4px);opacity:1;}
  }

  .chat-questions{
    flex-shrink:0;
    display:flex;
    flex-direction:column;
    gap:7px;
    padding:14px 16px;
    border-top:1px solid var(--border);
    background:var(--surface);
  }
  .chat-questions-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint);font-weight:600;margin-bottom:2px;}
  .q-chip{
    text-align:left;
    width:100%;
    padding:9px 13px;
    border-radius:11px;
    border:1px solid var(--border);
    background:var(--surface-2);
    color:var(--text-muted);
    font-size:13px;
    font-weight:500;
    cursor:pointer;
    transition:border-color .25s, color .25s, background .25s, transform .25s var(--ease);
    font-family:'Inter',sans-serif;
  }
  .q-chip:hover{color:var(--text);border-color:rgba(212,74,147,0.4);transform:translateX(2px);}
  .q-chip.active{
    color:#fff;
    background:var(--grad);
    border-color:transparent;
  }

  .chat-footer{
    flex-shrink:0;
    padding:11px 16px;
    text-align:center;
    border-top:1px solid var(--border);
    background:var(--surface);
  }
  .chat-footer a{
    font-size:12.5px;
    font-weight:600;
    color:var(--magenta-bright);
    transition:opacity .25s;
  }
  .chat-footer a:hover{opacity:.8;}

  @media (max-width:480px){
    .chatbot{bottom:18px;right:18px;}
    .chat-panel{
      width:calc(100vw - 32px);
      height:min(74vh, 560px);
      bottom:74px;right:-6px;
    }
    .to-top{right:18px;bottom:100px;}
    .cookie-banner{left:16px;bottom:16px;width:calc(100vw - 32px);padding:18px 18px;}
    .contact-info,.contact-form{padding:26px 22px;}
    .pf-modal-image{height:170px;}
    .pf-modal-body{padding:22px 20px 24px;}
    .pf-modal-meta{gap:16px;flex-wrap:wrap;}
  }

  /* ===== RESPONSIVE ===== */
  @media (max-width:980px){
    .sidebar{transform:translateX(-100%);box-shadow:0 0 60px rgba(0,0,0,0.5);}
    .sidebar.open{transform:translateX(0);}
    .sidebar-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;border:1px solid var(--border);color:var(--text-muted);}
    .content{margin-left:0;}
    .burger{display:flex;}
    .topbar-title{display:none;}

    .hero-grid{grid-template-columns:1fr;}
    .hero-visual{height:420px;order:-1;}
    .device-mock{width:260px;}
    .build-status-card{right:2%;width:180px;padding:15px 15px 13px;}
    .services-grid{grid-template-columns:repeat(2,1fr);}
    .process-grid{grid-template-columns:1fr;gap:40px;}
    .process-visual{height:320px;order:-1;}
    .portfolio-grid{grid-template-columns:repeat(2,1fr);}
    .team-grid{grid-template-columns:repeat(2,1fr);}
    .stats-panel{grid-template-columns:repeat(2,1fr);row-gap:30px;}
    .testi-grid{grid-template-columns:1fr;}
    .footer-grid{grid-template-columns:1fr 1fr;}
    .cta-band{flex-direction:column;text-align:center;align-items:flex-start;}
    .contact-grid{grid-template-columns:1fr;}
    .widgets-grid{grid-template-columns:repeat(2,1fr);}
  }
  @media (max-width:720px){
    .wrap{padding:0 22px;}
    .topbar{padding:16px 20px;}
    .hero{padding:40px 0 60px;}
    .services-grid{grid-template-columns:1fr;}
    .portfolio-grid{grid-template-columns:1fr;}
    .team-grid{grid-template-columns:1fr;}
    .footer-grid{grid-template-columns:1fr;gap:30px;}
    .cta-band{padding:42px 28px;}
    .stats-panel{padding:40px 26px;grid-template-columns:1fr 1fr;}
    .form-row{grid-template-columns:1fr;}
    .process-visual{height:260px;}
    .widgets-grid{grid-template-columns:1fr;}
    .creamos-wrap{gap:16px;}
    .creamos-label{font-size:11px;}
    .fc-1,.fc-2,.fc-3{display:none;}
    .build-status-card{position:static;width:100%;margin-top:20px;}
    .hero-visual{height:auto;flex-direction:column;padding:20px 0;}
    .trust-logos-row{gap:18px;}
    .trust-logos-list{gap:22px;}
  }
