*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
    :root{
      --bg:#0D0D0D;--bg2:#111111;--surface:#161616;
      --border:rgba(255,255,255,0.07);
      --gold:#C9A96E;--gold2:#E8C98A;
      --white:#F5F0E8;--muted:rgba(245,240,232,0.45);
      --wa:#25D366;
    }
    html{scroll-behavior:smooth}
    body{font-family:'Jost',sans-serif;background:var(--bg);color:var(--white);overflow-x:hidden;cursor:none}

    /* CURSOR */
    .cursor{position:fixed;width:8px;height:8px;background:var(--gold);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);mix-blend-mode:difference}
    .cursor-ring{position:fixed;width:36px;height:36px;border:1px solid rgba(201,169,110,0.5);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .4s,height .4s,border-color .3s}
    @media(hover:none){.cursor,.cursor-ring{display:none}body{cursor:auto}}

    /* GRAIN */
    .grain{position:fixed;inset:-50%;width:200%;height:200%;z-index:1;pointer-events:none;opacity:.025;
      background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
      animation:grain .5s steps(2) infinite}
    @keyframes grain{0%{transform:translate(0,0)}25%{transform:translate(-2%,-1%)}50%{transform:translate(1%,2%)}75%{transform:translate(-1%,1%)}100%{transform:translate(2%,-2%)}}

    /* NAV */
    nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:1.4rem 5%;border-bottom:1px solid var(--border);background:rgba(13,13,13,0.88);backdrop-filter:blur(20px);animation:slideDown .8s ease both}
    @keyframes slideDown{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}
    .nav-logo{display:flex;flex-direction:column;text-decoration:none}
    .nav-logo-name{font-family:'Playfair Display',serif;font-size:1.05rem;color:var(--white);letter-spacing:.04em}
    .nav-logo-sub{font-size:.62rem;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin-top:1px}
    .nav-center{display:flex;gap:2.5rem;list-style:none;position:absolute;left:50%;transform:translateX(-50%)}
    .nav-center a{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color .3s;position:relative;padding-bottom:4px}
    .nav-center a::after{content:'';position:absolute;bottom:0;left:0;right:100%;height:1px;background:var(--gold);transition:right .3s}
    .nav-center a:hover{color:var(--gold)}
    .nav-center a:hover::after{right:0}
    .nav-cta{display:flex;align-items:center;gap:.5rem;background:transparent;border:1px solid var(--gold);color:var(--gold);padding:.55rem 1.3rem;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;text-decoration:none;transition:all .3s;font-family:'Jost',sans-serif}
    .nav-cta:hover{background:var(--gold);color:var(--bg)}
    .hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
    .hamburger span{width:24px;height:1px;background:var(--white);display:block;transition:all .3s}
    .mobile-menu{display:none;position:fixed;inset:0;background:var(--bg);z-index:99;flex-direction:column;align-items:center;justify-content:center;gap:3rem}
    .mobile-menu.open{display:flex}
    .mobile-menu a{font-family:'Playfair Display',serif;font-size:2.5rem;color:var(--white);text-decoration:none;font-style:italic}
    .mobile-menu a:hover{color:var(--gold)}
    .mobile-close{position:absolute;top:1.5rem;right:5%;font-size:2rem;background:none;border:none;cursor:pointer;color:var(--white)}

    /* HERO */
    #hero{min-height:100vh;display:grid;grid-template-columns:55% 45%;padding-top:80px;position:relative;overflow:hidden}
    #hero::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(201,169,110,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(201,169,110,0.04) 1px,transparent 1px);background-size:80px 80px;pointer-events:none}
    .hero-left{display:flex;flex-direction:column;justify-content:center;padding:8% 6% 8% 8%;position:relative;z-index:2}
    .hero-tag{display:inline-flex;align-items:center;gap:.7rem;font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin-bottom:2.5rem;border:1px solid rgba(201,169,110,0.3);padding:.45rem 1rem;width:fit-content;animation:fadeIn 1s .3s ease both}
    .hero-tag::before{content:'';width:16px;height:1px;background:var(--gold)}
    .hero-title{font-family:'Playfair Display',serif;font-size:clamp(3.2rem,5.5vw,6rem);font-weight:400;line-height:1.0;color:var(--white);margin-bottom:2rem;animation:fadeIn 1s .5s ease both}
    .hero-title em{font-style:italic;color:var(--gold);display:block}
    .hero-line{width:60px;height:1px;background:var(--gold);margin-bottom:1.8rem;animation:expandLine 1s .7s ease both}
    @keyframes expandLine{from{width:0}to{width:60px}}
    .hero-desc{font-size:.95rem;line-height:1.9;color:var(--muted);max-width:400px;margin-bottom:3.5rem;font-weight:300;animation:fadeIn 1s .8s ease both}
    .hero-buttons{display:flex;gap:1rem;flex-wrap:wrap;animation:fadeIn 1s 1s ease both}
    .btn-gold{display:inline-flex;align-items:center;gap:.6rem;background:var(--gold);color:var(--bg);padding:1rem 2rem;font-size:.78rem;letter-spacing:.15em;text-transform:uppercase;text-decoration:none;font-weight:500;transition:all .3s}
    .btn-gold:hover{background:var(--gold2);transform:translateY(-2px)}
    .btn-outline{display:inline-flex;align-items:center;gap:.5rem;border:1px solid var(--border);color:var(--muted);padding:1rem 1.8rem;font-size:.78rem;letter-spacing:.15em;text-transform:uppercase;text-decoration:none;transition:all .3s}
    .btn-outline:hover{border-color:var(--gold);color:var(--gold)}
    @keyframes fadeIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

    .hero-right{position:relative;overflow:hidden;animation:fadeIn 1.2s .4s ease both}
    .hero-photo{width:100%;height:100%;object-fit:cover;object-position:center top;filter:grayscale(15%) contrast(1.05);display:block}
    .hero-right::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,var(--bg) 0%,rgba(13,13,13,0.2) 30%,transparent 60%),linear-gradient(to top,var(--bg) 0%,transparent 25%)}
    .hero-card{position:absolute;bottom:3rem;right:2rem;z-index:3;background:rgba(22,22,22,0.92);border:1px solid rgba(201,169,110,0.25);backdrop-filter:blur(12px);padding:1.5rem 2rem;text-align:right}
    .hero-card-name{font-family:'Playfair Display',serif;font-size:1.3rem;color:var(--white);display:block}
    .hero-card-role{font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-top:.3rem;display:block}

    /* STRIP */
    .strip{
      border-top:1px solid var(--border);
      border-bottom:1px solid var(--border);
      padding:1.2rem 0; /* sacamos padding lateral */
      overflow:hidden;
      background:var(--surface);
    }

    /* pista que se mueve */
    .strip-track{
      display:flex;
      align-items:center;
      gap:3rem;
      width:max-content;
      padding:0 8%; /* mantenemos el espacio lateral acá */
      animation:scrollStrip 30s linear infinite;
    }

    /* items */
    .strip-item{
      display:flex;
      align-items:center;
      gap:.8rem;
      font-size:.68rem;
      letter-spacing:.18em;
      text-transform:uppercase;
      color:var(--muted);
      white-space:nowrap;
      flex-shrink:0;
    }

    .strip-item span{
      color:var(--gold);
      font-size:1rem;
    }

    .strip-sep{
      width:1px;
      height:20px;
      background:var(--border);
      flex-shrink:0;
    }

    /* animación correcta */
    @keyframes scrollStrip {
      0% { transform: translateX(0); }
      100% { transform: translateX(-50%); }
    }


    /* SERVICES */
    #servicios{padding:9rem 8%;position:relative}
    .sec-label{font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem;display:flex;align-items:center;gap:.8rem}
    .sec-label::before{content:'01';opacity:.35}
    .sec-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3.8rem);font-weight:400;color:var(--white);line-height:1.1;margin-bottom:5rem;max-width:500px}
    .sec-title em{font-style:italic;color:var(--gold)}
    .services-list{display:flex;flex-direction:column}
    .service-row{display:grid;grid-template-columns:60px 1fr auto;align-items:center;gap:2rem;padding:2rem 0;border-bottom:1px solid var(--border);cursor:default;transition:padding-left .3s;position:relative}
    .service-row::before{content:'';position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(90deg,rgba(201,169,110,0.06),transparent);transition:width .4s}
    .service-row:hover::before{width:100%}
    .service-row:hover{padding-left:.5rem}
    .service-num{font-family:'Playfair Display',serif;font-style:italic;font-size:1.8rem;color:rgba(201,169,110,0.25);line-height:1}
    .service-name{font-family:'Playfair Display',serif;font-size:1.2rem;color:var(--white);margin-bottom:.4rem}
    .service-desc{font-size:.82rem;color:var(--muted);line-height:1.6;font-weight:300}
    .service-arr{width:36px;height:36px;border:1px solid var(--border);display:none;align-items:center;justify-content:center;color:var(--gold);font-size:1rem;flex-shrink:0;transition:background .3s,border-color .3s}
    .service-row:hover .service-arr{background:var(--gold);color:var(--bg);border-color:var(--gold)}

    /* ABOUT */
    #sobre-mi{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);display:grid;grid-template-columns:1fr 1fr}
    .about-photo-col{position:relative;min-height:600px;overflow:hidden}
    .about-photo{width:100%;height:100%;object-fit:cover;object-position:center top;filter:grayscale(20%) contrast(1.05) brightness(.9);display:block}
    .about-photo-col::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,transparent 60%,var(--surface) 100%),linear-gradient(to bottom,transparent 50%,rgba(0,0,0,.5) 100%)}
    .about-text-col{padding:7rem 6% 7rem 7%;display:flex;flex-direction:column;justify-content:center}
    .about-text-col .sec-label::before{content:'02'}
    .about-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,3vw,3rem);font-weight:400;color:var(--white);margin-bottom:2rem;line-height:1.2}
    .about-title em{font-style:italic;color:var(--gold)}
    .about-body{font-size:.9rem;line-height:1.95;color:var(--muted);font-weight:300;margin-bottom:3rem}
    .pillars{display:flex;flex-direction:column;gap:1.2rem}
    .pillar{display:flex;align-items:flex-start;gap:1rem;font-size:.85rem;color:var(--muted);line-height:1.5}
    .pillar-dot{width:6px;height:6px;background:var(--gold);border-radius:50%;flex-shrink:0;margin-top:6px}

    /* CTA */
    #cta{padding:10rem 8%;text-align:center;position:relative;overflow:hidden}
    #cta::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(201,169,110,0.03) 1px,transparent 1px),linear-gradient(90deg,rgba(201,169,110,0.03) 1px,transparent 1px);background-size:60px 60px}
    #cta::after{content:'✦';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:40vw;color:rgba(201,169,110,0.025);pointer-events:none;line-height:1}
    .cta-label{font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:1.5rem;display:flex;align-items:center;justify-content:center;gap:.8rem}
    .cta-label::before,.cta-label::after{content:'';width:30px;height:1px;background:var(--gold);opacity:.5}
    .cta-title{font-family:'Playfair Display',serif;font-size:clamp(2.5rem,5vw,5rem);font-weight:400;color:var(--white);line-height:1.05;margin-bottom:1.5rem;position:relative;z-index:1}
    .cta-title em{font-style:italic;color:var(--gold)}
    .cta-sub{color:var(--muted);font-size:.9rem;font-weight:300;margin-bottom:3.5rem;position:relative;z-index:1}
    .btn-wa-cta{display:inline-flex;align-items:center;gap:.9rem;background:var(--wa);color:#fff;padding:1.1rem 2.8rem;font-size:.85rem;letter-spacing:.15em;text-transform:uppercase;text-decoration:none;font-weight:500;transition:all .3s;position:relative;z-index:1}
    .btn-wa-cta:hover{background:#1da851;transform:translateY(-3px);box-shadow:0 16px 48px rgba(37,211,102,.3)}
    .btn-wa-cta svg{width:22px;height:22px}

    /* FOOTER */
    footer{background:var(--bg);border-top:1px solid var(--border);padding:3rem 8%;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.5rem}
    .footer-name{font-family:'Playfair Display',serif;font-size:1rem;color:var(--white)}
    .footer-name span{font-style:italic;color:var(--gold)}
    .footer-meta{font-size:.68rem;letter-spacing:.1em;color:var(--muted);margin-top:.3rem}
    .footer-copy{font-size:.65rem;color:rgba(255,255,255,.18);letter-spacing:.08em}

    /* FLOAT WA */
    .float-wa{position:fixed;bottom:2rem;right:2rem;z-index:200;display:flex;align-items:center;gap:.7rem;background:var(--wa);color:#fff;text-decoration:none;padding:.85rem 1.5rem .85rem 1.1rem;font-size:.8rem;font-weight:500;letter-spacing:.06em;box-shadow:0 8px 32px rgba(37,211,102,.4);transition:all .3s;animation:waPulse 2.5s infinite;white-space:nowrap}
    .float-wa:hover{background:#1da851;transform:translateY(-3px);box-shadow:0 14px 44px rgba(37,211,102,.6);animation:none}
    .float-wa svg{width:24px;height:24px;flex-shrink:0}
    @keyframes waPulse{0%,100%{box-shadow:0 8px 32px rgba(37,211,102,.4)}50%{box-shadow:0 8px 44px rgba(37,211,102,.7)}}
    @media(max-width:480px){.float-wa span{display:none}.float-wa{padding:.9rem;width:56px;height:56px;justify-content:center;border-radius:50%}}

    /* REVEAL */
    .reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease}
    .reveal.visible{opacity:1;transform:translateY(0)}

    /* RESPONSIVE */
    @media (max-width: 900px) {

      #hero {
        grid-template-columns: 1fr;
        min-height: auto;
      }

      .hero-right {
        height: 75vw;
        order: -1;
      }

      .hero-left {
        padding: 4% 6% 6%;
      }

      .hero-card {
        bottom: 1.5rem;
        right: 1rem;
      }

      .nav-center,
      .nav-cta {
        display: none;
      }

      .hamburger {
        display: flex;
      }

      #sobre-mi {
        grid-template-columns: 1fr;
      }

      .about-photo-col {
        min-height: 60vw;
      }

      footer {
        flex-direction: column;
        text-align: center;
      }

      .strip {
        gap: 1.5rem;
        padding: 1.2rem 5%;
      }

      /* AJUSTES MOBILE FINOS */
      .hero-card {
        padding: 10px 14px;
        max-width: 80%;
      }

      .hero-card-name {
        font-size: 1rem;
      }

      .hero-card-role {
        font-size: 0.55rem;
      }

      .hero-photo {
        object-position: center 20%;
      }

    }

  
    /* REDES SOCIALES - FOOTER */
    .footer-social { display: flex; gap: .7rem; align-items: center; }
    .footer-social a {
      width: 36px; height: 36px;
      border: 1px solid var(--border);
      display: flex; align-items: center; justify-content: center;
      color: var(--muted); border-radius: 2px;
      transition: all .3s; text-decoration: none;
    }
    .footer-social a:hover { border-color: var(--gold); color: var(--gold); background: rgba(201,169,110,0.08); }
    .footer-social svg { width: 16px; height: 16px; }