
    /* ── RESET & BASE ─────────────────────────────────────── */
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    :root {
      --gold: #c5a059;
      --gold-dark: #8f7035;
      --dark: #0a0e12;
      --gray: #6c757d;
      --light: #f5f6f8;
      --serif: 'Playfair Display', serif;
      
      --sans: 'Montserrat', sans-serif;
    }
    html { scroll-behavior: smooth; }
    body { font-family: var(--sans); color: var(--dark); background: #fff; overflow-x: hidden; -webkit-font-smoothing: antialiased; }
    img { display: block; max-width: 100%; }
    button { font-family: var(--sans); cursor: pointer; }
    a { text-decoration: none; }
    input, textarea { font-family: var(--sans); }

    /* ── UTILITY ──────────────────────────────────────────── */
    .hidden { display: none !important; }
    .gold-line-top { height: 2px; background: linear-gradient(to right, transparent, var(--gold), transparent); }

    /* ── SCROLL ANIMATIONS ────────────────────────────────── */
    .anim { opacity: 0; transform: translateY(28px); transition: opacity 0.9s ease, transform 0.9s ease; }
    .anim.from-left { transform: translateX(40px); }
    .anim.from-right { transform: translateX(-40px); }
    .anim.visible { opacity: 1; transform: translate(0); }
    .anim-d1 { transition-delay: 0.1s; }
    .anim-d2 { transition-delay: 0.2s; }
    .anim-d3 { transition-delay: 0.3s; }

    /* ── BUTTON SLIDE-FILL ────────────────────────────────── */
    .btn {
      position: relative;
      display: inline-block;
      padding: 18px 48px;
      font-family: var(--sans);
      font-size: 0.72rem;
      letter-spacing: 2.5px;
      text-transform: uppercase;
      border: 1px solid currentColor;
      background: transparent;
      cursor: pointer;
      overflow: hidden;
      transition: color 0.5s cubic-bezier(0.65,0,0.35,1), transform 0.38s cubic-bezier(0.34,1.4,0.64,1), box-shadow 0.4s ease;
    }
    .btn::before {
      content: '';
      position: absolute;
      inset: 0;
      transform: translateX(-101%);
      transition: transform 0.5s cubic-bezier(0.65,0,0.35,1);
      z-index: 0;
    }
    .btn:hover::before { transform: translateX(0); }
    .btn:hover { transform: translateY(-3px); box-shadow: 0 12px 32px rgba(0,0,0,0.11); }
    .btn span { position: relative; z-index: 1; }

    .btn-dark { color: var(--dark); border-color: var(--dark); }
    .btn-dark::before { background: var(--dark); }
    .btn-dark:hover { color: #fff; }

    .btn-light { color: #fff; border-color: #fff; }
    .btn-light::before { background: #fff; }
    .btn-light:hover { color: var(--dark); }

    .btn-gold { color: var(--gold); border-color: var(--gold); }
    .btn-gold::before { background: var(--gold); }
    .btn-gold:hover { color: #fff; }

    .btn-sm { padding: 12px 28px; font-size: 0.65rem; letter-spacing: 2px; }

    /* ── NAVBAR ───────────────────────────────────────────── */
    #navbar {
      position: fixed;
      top: 0; left: 0; right: 0;
      z-index: 2000;
      padding: 1.8rem 0;
      background: transparent;
      backdrop-filter: none;
      box-shadow: none;
      transition: all 0.5s cubic-bezier(0.4,0,0.2,1);
    }
    #navbar.scrolled {
      padding: 0.8rem 0;
      background: rgba(255,255,255,0.95);
      backdrop-filter: blur(10px);
      box-shadow: 0 4px 20px rgba(0,0,0,0.05);
    }
    .nav-inner {
      max-width: 1140px;
      margin: 0 auto;
      padding: 0 1.5rem;
      display: flex;
      align-items: center;
      justify-content: space-between;
    }
    .nav-logo { cursor: pointer; }
    .nav-logo-avet {
      font-family: var(--serif);
      font-size: clamp(1.2rem, 1.8vw, 1.6rem);
      font-weight: 700;
      letter-spacing: 3px;
      color: #fff;
      line-height: 1;
      margin-bottom: 3px;
      transition: color 0.4s ease;
    }
    .nav-logo-avet .imgW {
display: block;
    }
      .nav-logo-avet .imgC {
display: none;
    }
    #navbar.scrolled .nav-logo-avet  .imgW{
display: none;
    }
     #navbar.scrolled .nav-logo-avet  .imgC{
display: block;
    }
    #navbar.scrolled .nav-logo-avet { color: white }
    .nav-logo-cap {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 6px;
      font-size: 0.45rem;
      letter-spacing: 4px;
      text-transform: uppercase;
      color: #fff;
      transition: color 0.4s ease;
    }
    #navbar.scrolled .nav-logo-cap { color: var(--dark); }
    .nav-logo-cap .gold-rule { height: 1px; width: 12px; background: var(--gold); display: inline-block; }
    .nav-links { display: flex; align-items: center; gap: 0; }
    .nav-link {
      font-size: 0.68rem;
      letter-spacing: 1.5px;
      text-transform: uppercase;
      color: #fff;
      font-weight: 500;
      opacity: 0.75;
      background: none;
      border: none;
      margin-left: 2rem;
      padding: 4px 0;
      transition: all 0.3s ease;
    }
    #navbar.scrolled .nav-link { color: var(--dark); }
    .nav-link:hover { opacity: 1; transform: translateY(-1px); }
    .nav-cta {
      margin-left: 2rem;
      font-size: 0.6rem;
      letter-spacing: 2.5px;
      text-transform: uppercase;
      border: 1px solid rgba(255,255,255,0.35);
      color: #fff;
      background: transparent;
      padding: 12px 30px;
      transition: all 0.4s ease;
    }
    #navbar.scrolled .nav-cta { border-color: var(--dark); color: var(--dark); }
    .nav-cta:hover { background: #fff; color: var(--dark) !important; border-color: #fff !important; }
    #navbar.scrolled .nav-cta:hover { background: var(--dark); color: #fff !important; border-color: var(--dark) !important; }
    .nav-hamburger { display: none; background: none; border: none; color: #fff; padding: 4px; }
    #navbar.scrolled .nav-hamburger { color: var(--dark); }

    /* ── HERO ─────────────────────────────────────────────── */
    #hero {
      position: relative;
      height: 100vh;
      width: 100%;
      overflow: hidden;
      display: flex;
      align-items: center;
      justify-content: center;
      background: var(--dark);
    }
    #hero video {
      position: absolute;
      top: 50%; left: 50%;
      min-width: 100%; min-height: 100%;
      width: auto; height: auto;
      transform: translate(-50%, -50%);
      object-fit: cover;
      filter: brightness(0.35) grayscale(0.2);
      z-index: 0;
    }
    .hero-overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(to bottom, rgba(10,14,18,0.6) 0%, transparent 40%, rgba(10,14,18,0.6) 100%);
      z-index: 1;
    }
    .hero-content {
      position: relative;
      z-index: 10;
      text-align: center;
      color: #fff;
      max-width: 1080px;
      padding: 0 25px;
      margin-top: 40px;
    }
    .hero-tag {
      display: block;
      font-size: 0.65rem;
      letter-spacing: 5px;
      color: rgba(255,255,255,0.6);
      font-weight: 600;
      text-transform: uppercase;
      margin-bottom: 1.5rem;
      opacity: 0;
      transform: translateY(-15px);
      transition: opacity 0.9s ease, transform 0.9s ease;
    }
    .hero-tag.loaded { opacity: 1; transform: translateY(0); }
    .hero-h1 {
      font-family: var(--serif);
      font-size: clamp(2.2rem, 7vw, 5rem);
      line-height: 1.15;
      font-weight: 700;
      margin-bottom: 1.8rem;
      text-shadow: 0 4px 20px rgba(0,0,0,0.4);
      opacity: 0;
      transform: translateY(30px);
      transition: opacity 1.2s cubic-bezier(0.2,1,0.3,1), transform 1.2s cubic-bezier(0.2,1,0.3,1);
    }
    .hero-h1.loaded { opacity: 1; transform: translateY(0); }
    .hero-p {
      font-size: clamp(0.95rem, 1.4vw, 1.15rem);
      color: rgba(255,255,255,0.75);
      margin-bottom: 3rem;
      font-weight: 300;
      letter-spacing: 0.5px;
      max-width: 650px;
      margin-left: auto;
      margin-right: auto;
      opacity: 0;
      transform: translateY(20px);
      transition: opacity 1s ease 0.3s, transform 1s ease 0.3s;
    }
    .hero-p.loaded { opacity: 1; transform: translateY(0); }
    .hero-cta {
      opacity: 0;
      transform: translateY(20px);
      transition: opacity 1s ease 0.5s, transform 1s ease 0.5s;
    }
    .hero-cta.loaded { opacity: 1; transform: translateY(0); }
    .hero-scroll {
      position: absolute;
      bottom: 2.5rem;
      left: 50%;
      transform: translateX(-50%);
      z-index: 10;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 6px;
      cursor: pointer;
    }
    .hero-scroll span {
      font-size: 0.5rem;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: rgba(255,255,255,0.4);
    }
    .hero-scroll-line {
      width: 1px;
      height: 40px;
      background: linear-gradient(to bottom, var(--gold), transparent);
      animation: scrollLine 2s ease-in-out infinite;
    }
    @keyframes scrollLine { 0%,100%{ opacity:0.4; transform:scaleY(1);} 50%{ opacity:1; transform:scaleY(1.2);} }

    /* ── NOSOTROS ─────────────────────────────────────────── */
    #nosotros { padding: 140px 0 100px; background: #fff; overflow: hidden; }
    .section-tag {
      display: flex;
      align-items: center;
      gap: 1.5rem;
      margin-bottom: 5rem;
    }
    .section-tag-text {
      font-size: 0.7rem;
      letter-spacing: 5px;
      text-transform: uppercase;
      color: var(--gold);
      font-weight: 600;
      white-space: nowrap;
    }
    .section-tag-rule { flex: 1; height: 1px; background: #b4b4b4; max-width: 200px; }
    .nos-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 0;
      position: relative;
    }
    .nos-img-wrap {
      grid-column: 1;
      grid-row: 1 / 3;
      padding-right: 4rem;
    }
    .nos-img-frame {
      position: relative;
      overflow: hidden;
      height: 680px;
    }
    .nos-img-frame img { width: 100%; height: 100%; object-fit: cover; }
    .nos-frame-left {
      position: absolute;
      top: 0; left: 0;
      width: 34%; height: 100%;
      border-top: 55px solid #fff;
      border-bottom: 55px solid #fff;
      border-left: 14px solid #fff;
      border-right: 14px solid #fff;
      pointer-events: none;
      z-index: 2;
    }
    .nos-frame-right {
      position: absolute;
      top: 0; right: 0;
      width: 34%; height: 100%;
      border-top: 14px solid #fff;
      border-bottom: 80px solid #fff;
      border-left: 14px solid #fff;
      border-right: 14px solid #fff;
      pointer-events: none;
      z-index: 2;
    }
    .nos-text { grid-column: 2; grid-row: 1; padding-top: 3rem; }
    .nos-text h2 {
      font-family: var(--serif);
      font-size: clamp(2rem, 3.5vw, 3.2rem);
      line-height: 1.2;
      color: var(--dark);
      margin-bottom: 2rem;
          font-weight: 400;
    }
    .nos-text p { font-size: 0.92rem; color: var(--gray); line-height: 1.8; margin-bottom: 1.4rem; }
    .nos-stats {
      grid-column: 2;
      grid-row: 2;
      padding-top: 3.5rem;
      border-top: 1px solid #f0f0f0;
      margin-top: 2.5rem;
      display: flex;
      gap: 4rem;
    }
    .stat-value { font-family: var(--serif); font-size: clamp(2rem, 3.5vw, 2.8rem); color: var(--dark); line-height: 1; margin-bottom: 0.4rem; }
    .stat-label { font-size: 0.62rem; letter-spacing: 2px; text-transform: uppercase; color: var(--gold); font-weight: 600; }
    .nos-quote {
     margin-top: 8rem;
    padding-left: 5%;
    position: relative;
    max-width: 800px;
    }
    .nos-quote-mark {
      position: absolute;
          left: calc(9% - 3.5rem);
      top: -1rem;
      font-family: var(--serif);
      font-size: 6rem;
      color: var(--gold);
      opacity: 0.18;
      line-height: 1;
    }
    .nos-quote blockquote {
      font-family: var(--serif);
      font-size: clamp(1.1rem, 2vw, 1.5rem);
      font-style: italic;
      color: var(--dark);
      line-height: 1.6;
      border-left: 2px solid var(--gold);
      padding-left: 2rem;
    }

    /* ── SERVICIOS ────────────────────────────────────────── */
    #servicios { padding: 140px 0; background: #fff; overflow: hidden; }
    .svc-header {
      display: flex;
      align-items: flex-end;
      gap: 3rem;
      margin-bottom: 7rem;
    }
    .svc-bg-text {
      font-family: var(--serif);
      font-size: clamp(5rem, 12vw, 11rem);
      line-height: 0.85;
      color: var(--dark);
      opacity: 0.04;
      user-select: none;
      flex-shrink: 0;
      position: absolute;
    width: 100%;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    white-space: nowrap;
    left: -8%;
    }
    .svc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
    .svc-card {
      background: #fff;
      border: 1px solid #e8e8e8;
      border-top: 2px solid var(--dark);
      padding: 3.5rem;
      position: relative;
      overflow: hidden;
      transition: all 0.35s ease;
      box-shadow: 0 2px 12px rgba(0,0,0,0.04);
    }
    .svc-card:hover {
      border-color: var(--gold);
      border-top-color: var(--gold);
      box-shadow: 0 20px 50px rgba(197,160,89,0.1), 0 8px 20px rgba(0,0,0,0.06);
      transform: translateY(-6px);
    }
    .svc-num-bg {
      position: absolute;
      bottom: -30px;
      right: -10px;
      font-family: var(--serif);
      font-size: 12rem;
      line-height: 1;
      color: var(--dark);
      opacity: 0.025;
      user-select: none;
      pointer-events: none;
      transition: color 0.35s ease, opacity 0.35s ease;
    }
    .svc-card:hover .svc-num-bg { color: var(--gold); opacity: 0.04; }
    .svc-num-tag { font-size: 0.6rem; letter-spacing: 3px; color: var(--gold); font-weight: 600; margin-bottom: 2rem; }
    .svc-card h3 { font-family: var(--serif); font-size: clamp(1.8rem, 3vw, 2.6rem); color: var(--dark); margin-bottom: 1.4rem; line-height: 1.15;font-weight: 400; }
    .svc-card p { font-size: 0.88rem; color: var(--gray); line-height: 1.8; margin-bottom: 2.5rem; }
    .svc-items { list-style: none; margin-bottom: 3rem; display: flex; flex-direction: column; gap: 0.7rem; }
    .svc-items li { display: flex; align-items: center; gap: 10px; font-size: 0.78rem; color: var(--dark); opacity: 0.7; }
    .svc-items li::before { content:''; width: 16px; height: 1px; background: var(--gold); flex-shrink: 0; }

    /* ── CTA SECTION ──────────────────────────────────────── */
    #cta-section {
      position: relative;
      height: clamp(700px, 90vh, 940px);
      overflow: hidden;
    }
    .cta-bg { position: absolute; inset: 0; }
    .cta-bg img { width: 100%; height: 100%; object-fit: cover; }
    .cta-overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(155deg, rgba(10,14,18,0.88) 0%, rgba(10,14,18,0.70) 60%, rgba(10,14,18,0.82) 100%);
    }
    .cta-gold-bottom { position: absolute; bottom: 0; left: 0; right: 0; height: 2px; background: linear-gradient(to right, transparent, var(--gold), transparent); }
    .cta-inner {
      position: absolute;
      inset: 0;
      display: flex;
      align-items: center;
    }
    .cta-content {
      width: 100%;
      max-width: 1400px;
      margin: 0 auto;
      padding: 0 3rem;
          text-align: center;
    display: flex;
    justify-content: center;
    }
    .cta-box { margin:0 auto; max-width: 800px;    display: flex;
    flex-direction: column;
    align-items: center; }
    .cta-box h2 { font-family: var(--serif); font-size: clamp(2.2rem, 4vw, 3.8rem); color: #fff; line-height: 1.2; margin: 0 0 1.8rem;font-weight: 400;}
    .cta-box p { font-size: 0.9rem; color: rgba(255,255,255,0.6); line-height: 1.85; max-width: 560px; margin: 0 0 3.5rem; }
    .cta-props { display: flex; gap: 3rem; flex-wrap: wrap; margin-bottom: 3.5rem; }
    .cta-prop { display: flex; flex-direction: column;     align-items: center; gap: 0.5rem; }
    .cta-prop-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold); }
    .cta-prop span { font-size: 0.68rem; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,0.75); font-weight: 600; }

    /* ── CONTACT FORM ─────────────────────────────────────── */
    #contacto { background: #fff; padding: 120px 0 110px; position: relative; overflow: hidden; border-top: 1px solid #f0f0f0; }
    .form-grid { display: grid; grid-template-columns: 1fr 1.5fr; gap: 7rem; align-items: start; }
    .form-step { display: flex; gap: 1.2rem; align-items: flex-start; padding-left: 0.7rem; border-left: 1px solid #eee; padding-bottom: 1.8rem; }
    .form-step.active { border-left-color: var(--gold); }
    .form-step-num { font-size: 0.6rem; color: var(--gold); font-weight: 700; min-width: 20px; padding-top: 2px; }
    .form-step-title { font-size: 0.82rem; color: var(--dark); font-weight: 600; margin-bottom: 4px; }
    .form-step-desc { font-size: 0.75rem; color: #aaa; line-height: 1.6; }
    .field-group { display: flex; flex-direction: column; gap: 0.1rem; }
    .field-label { font-size: 0.7rem; letter-spacing: 3px; text-transform: uppercase; color: var(--gold); font-weight: 600; }
    .field-input, .field-textarea {
      background: transparent;
      border: none;
      border-bottom: 1px solid #ddd;
      padding: 14px 0;
      font-size: 0.88rem;
      color: var(--dark);
      outline: none;
      transition: border-color 0.3s ease;
      width: 100%;
      letter-spacing: 0.3px;
    }
    .field-input:focus, .field-textarea:focus { border-bottom-color: var(--gold); }
    .field-textarea { resize: none; }
    .form-success {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      padding: 5rem 2rem;
      border: 1px solid #f0f0f0;
      text-align: center;
      gap: 1.5rem;
    }
    .form-success-icon { width: 48px; height: 48px; border: 1px solid var(--gold); border-radius: 50%; display: flex; align-items: center; justify-content: center; }
    .form-success h3 { font-family: var(--serif); font-size: 1.8rem; color: var(--dark); }
    .form-success p { font-size: 0.85rem; color: #aaa; line-height: 1.75; }

    /* ── FOOTER ───────────────────────────────────────────── */
    footer { background: var(--dark); color: #fff; overflow: hidden; position: relative; }
    .footer-deco {
      position: absolute;
      bottom: -180px;
      left: 50%;
      transform: translateX(-50%);
      font-family: var(--serif);
      font-size: clamp(8rem, 20vw, 18rem);
      line-height: 1;
      color: #fff;
      opacity: 0.025;
      user-select: none;
      pointer-events: none;
      white-space: nowrap;
      letter-spacing: 0.05em;
    }
    .footer-grid {
      padding: 80px 0 60px;
      display: grid;
      grid-template-columns: 1.8fr 1fr 1fr;
      gap: 4rem;
      border-bottom: 1px solid rgba(255,255,255,0.07);
    }
    .footer-logo-avet { font-family: var(--serif); font-size: 2rem; font-weight: 700; letter-spacing: 4px; color: #fff; line-height: 1; margin-bottom: 6px; }
    .footer-logo-cap { display: flex; align-items: center; gap: 8px; font-size: 0.55rem; letter-spacing: 5px; text-transform: uppercase; color: rgba(255,255,255,0.65); margin-bottom: 2rem; }
    .footer-tagline { font-size: 0.88rem; color: rgba(255,255,255,0.65); line-height: 1.8; max-width: 320px; margin-bottom: 2.5rem; }
    .footer-col-title { font-size: 0.7rem; letter-spacing: 4px; text-transform: uppercase; color: var(--gold); font-weight: 600; margin-bottom: 2rem; }
    .footer-link { display: flex; align-items: center; gap: 6px; font-size: 0.82rem; color: rgba(255,255,255,0.65); margin-bottom: 1rem; background: none; border: none; cursor: pointer; letter-spacing: 0.5px; transition: color 0.3s ease; }
    .footer-link:hover { color: #fff; }
    .footer-link::before { content: '↗'; color: var(--gold); font-size: 1.1rem; }
    .footer-city { display: flex; align-items: center; gap: 8px; font-size: 0.82rem; color: rgba(255,255,255,0.65); margin-bottom: 0.9rem; }
    .footer-city::before { content: '◈'; color: var(--gold); font-size: 1rem; }
    .footer-email { display: flex; align-items: center; gap: 8px; font-size: 0.82rem; color: rgba(255,255,255,0.65); transition: color 0.3s ease; }
    .footer-email:hover { color: var(--gold); }
    .footer-email::before { content: '✉'; color: var(--gold); font-size: 1.1rem; }
    .footer-bottom { padding: 2rem 0; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem; position: relative; z-index: 1; }
    .footer-copy { font-size: 0.62rem; letter-spacing: 2px; color: rgba(255,255,255,0.5); text-transform: uppercase; }
    .footer-legal { display: flex; gap: 2rem; }
    .footer-legal a { font-size: 0.62rem; letter-spacing: 1px; color: rgba(255,255,255,0.5); text-transform: uppercase; transition: color 0.3s ease; }
    .footer-legal a:hover { color: var(--gold); }

    /* ── LOGIN MODAL ──────────────────────────────────────── */
    #modal-login {
      position: fixed;
      inset: 0;
      z-index: 9999;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 1rem;
    }
    .modal-backdrop { position: absolute; inset: 0; background: rgba(5,8,12,0.82); backdrop-filter: blur(6px); }
    .modal-panel {
      position: relative;
      background: #fff;
      width: 100%;
      max-width: 460px;
      box-shadow: 0 40px 80px rgba(0,0,0,0.28);
      animation: modalIn 0.32s cubic-bezier(0.4,0,0.2,1);
    }
    @keyframes modalIn { from { opacity:0; transform:translateY(-18px) scale(0.98); } to { opacity:1; transform:translateY(0) scale(1); } }
    .modal-header { padding: 2rem 2.5rem 1.5rem; border-bottom: 1px solid #f0f0f0; display: flex; align-items: center; justify-content: space-between; }
    .modal-close { background: none; border: none; cursor: pointer; color: rgba(10,14,18,0.35); padding: 4px; font-size: 1.2rem; line-height: 1; transition: color 0.2s ease; }
    .modal-close:hover { color: var(--dark); }
    .modal-body { padding: 2.5rem; }
    .modal-gold-bar { width: 28px; height: 1px; background: var(--gold); margin-bottom: 1.5rem; }
    .modal-title { font-family: var(--serif); font-size: 1.45rem; font-weight: 500; color: var(--dark); margin-bottom: 0.4rem; }
    .modal-sub { font-size: 0.78rem; color: var(--gray); line-height: 1.65; margin-bottom: 2rem; }
    .modal-form { display: flex; flex-direction: column; gap: 0; }
    .modal-field { margin-bottom: 1.6rem; }
    .modal-label { display: block; font-size: 0.52rem; letter-spacing: 3px; text-transform: uppercase; color: var(--gold); font-weight: 600; margin-bottom: 0.5rem; }
    .modal-input {
      width: 100%;
      background: transparent;
      border: none;
      border-bottom: 1px solid #ddd;
      padding: 12px 0;
      font-size: 0.88rem;
      color: var(--dark);
      outline: none;
      transition: border-color 0.3s ease;
      letter-spacing: 0.3px;
    }
    .modal-input:focus { border-bottom-color: var(--gold); }
    .modal-forgot { display: flex; justify-content: flex-end; margin-bottom: 2rem; }
    .modal-forgot a { font-size: 0.7rem; color: var(--gold); opacity: 0.85; transition: opacity 0.2s ease; }
    .modal-forgot a:hover { opacity: 1; }
    .modal-submit {
      width: 100%;
      padding: 18px;
      font-size: 0.65rem;
      letter-spacing: 2.5px;
      text-transform: uppercase;
      border: 1px solid var(--dark);
      background: transparent;
      color: var(--dark);
      cursor: pointer;
      transition: all 0.45s cubic-bezier(0.65,0,0.35,1);
      position: relative;
      overflow: hidden;
    }
    .modal-submit::before { content: ''; position: absolute; inset: 0; background: var(--dark); transform: translateX(-101%); transition: transform 0.45s cubic-bezier(0.65,0,0.35,1); z-index: 0; }
    .modal-submit:hover::before { transform: translateX(0); }
    .modal-submit:hover { color: #fff; }
    .modal-submit span { position: relative; z-index: 1; }
    .modal-submit.loading { opacity: 0.7; cursor: default; }
    .modal-submit.success { background: #2ecc71; border-color: #2ecc71; color: #fff; }
    .modal-submit.success::before { display: none; }
    .modal-footer-bar { padding: 1.2rem 2.5rem; border-top: 1px solid #f0f0f0; display: flex; align-items: center; gap: 8px; }
    .modal-footer-bar p { font-size: 0.65rem; color: #111111; letter-spacing: 0.5px; }
    @keyframes spin { to { transform: rotate(360deg); } }
    .spinner { display: inline-block; width: 14px; height: 14px; border: 1.5px solid var(--dark); border-top-color: transparent; border-radius: 50%; animation: spin 0.7s linear infinite; margin-right: 8px; vertical-align: middle; }

    /* ── DASHBOARD ────────────────────────────────────────── */
    .view-dashboard { display: flex; min-height: 100vh; background: var(--light); }
    #sidebar {
      width: 260px;
      min-height: 100vh;
      background: var(--dark);
      display: flex;
      flex-direction: column;
      position: fixed;
      top: 0; left: 0; bottom: 0;
      z-index: 100;
      transition: transform 0.3s ease;
    }
    .sidebar-logo-wrap { padding: 2rem 1.8rem 1.5rem; border-bottom: 1px solid rgba(255,255,255,0.06); }
    .sidebar-logo { cursor: pointer; background: none; border: none; text-align: left; padding: 0; }
    .sidebar-logo-avet { font-family: var(--serif); font-size: 1.5rem; font-weight: 700; letter-spacing: 4px; color: #fff; line-height: 1; margin-bottom: 5px; }
    .sidebar-logo-cap { display: flex; align-items: center; gap: 5px; font-size: 0.44rem; letter-spacing: 5px; text-transform: uppercase; color: rgba(255,255,255,0.35); }
    .sidebar-nav-label { padding: 1.5rem 1.8rem 0.6rem; font-size: 0.52rem; letter-spacing: 3px; text-transform: uppercase; color: rgba(255,255,255,0.25); font-weight: 600; }
    .sidebar-nav { flex: 1; padding: 0.4rem 0.8rem; }
    .sidebar-nav-item {
      display: flex;
      align-items: center;
      gap: 0.8rem;
      padding: 0.85rem 1rem;
      border-radius: 4px;
      margin-bottom: 2px;
      font-size: 0.75rem;
      letter-spacing: 0.8px;
      color: rgba(255,255,255,0.5);
      background: transparent;
      border: none;
      border-left: 2px solid transparent;
      cursor: pointer;
      width: 100%;
      text-align: left;
      transition: all 0.2s ease;
      gap: 0.8rem;
    }
    .sidebar-nav-item .nav-icon { font-size: 12px; opacity: 0.4; transition: opacity 0.2s ease; }
    .sidebar-nav-item:hover { color: rgba(255,255,255,0.8); background: rgba(255,255,255,0.04); }
    .sidebar-nav-item.active { color: #fff; font-weight: 600; background: rgba(197,160,89,0.12); border-left-color: var(--gold); }
    .sidebar-nav-item.active .nav-icon { opacity: 1; color: var(--gold); font-size: 12px; }
    .sidebar-user-wrap { padding: 1.2rem 1.5rem; border-top: 1px solid rgba(255,255,255,0.06); margin: 0 0.8rem 0.8rem; }
    .sidebar-user { display: flex; align-items: center; gap: 0.8rem; margin-bottom: 1rem; cursor: pointer; }
    .sidebar-avatar {
      width: 36px; height: 36px;
      border-radius: 50%;
      background: linear-gradient(135deg, var(--gold) 0%, #a07030 100%);
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      font-family: var(--serif);
      font-size: 0.85rem;
      font-weight: 700;
      color: #fff;
    }
    .sidebar-user-name { font-size: 0.72rem; font-weight: 600; color: #fff; }
    .sidebar-user-role { font-size: 0.6rem; color: rgba(255,255,255,0.35); }
    .sidebar-logout {
      display: flex;
      align-items: center;
      gap: 8px;
      width: 100%;
      background: none;
      border: none;
      cursor: pointer;
      padding: 0.6rem 0.2rem;
      font-size: 0.68rem;
      color: rgba(255,255,255,0.3);
      letter-spacing: 0.5px;
      transition: color 0.2s ease;
    }
    .sidebar-logout:hover { color: rgba(255,100,100,0.75); }

    /* Dashboard main */
    #dash-main { flex: 1; display: flex; flex-direction: column; margin-left: 260px; min-height: 100vh; }
    #dash-topbar {
      background: #fff;
      border-bottom: 1px solid #eaeaea;
      padding: 0 2rem;
      height: 64px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      position: sticky;
      top: 0;
      z-index: 50;
    }
    .topbar-breadcrumb { display: flex; align-items: center; gap: 4px; font-size: 0.7rem; letter-spacing: 0.5px; }
    .breadcrumb-sep { color: rgba(10,14,18,0.3); font-size: 0.7rem; margin: 0 2px; }
    .topbar-right { display: flex; align-items: center; gap: 1rem; }
    .topbar-bell { position: relative; width: 34px; height: 34px; border-radius: 50%; border: none; background: none; cursor: pointer; display: flex; align-items: center; justify-content: center; color: rgba(10,14,18,0.4); font-size: 1rem; transition: background 0.2s ease; }
    .topbar-bell:hover { background: var(--light); }
    .topbar-bell-dot { position: absolute; top: 5px; right: 5px; width: 7px; height: 7px; border-radius: 50%; background: var(--gold); border: 1.5px solid #fff; }
    .topbar-user { display: flex; align-items: center; gap: 8px; cursor: pointer; }
    .topbar-avatar { width: 32px; height: 32px; border-radius: 50%; background: linear-gradient(135deg, var(--gold) 0%, #a07030 100%); display: flex; align-items: center; justify-content: center; font-family: var(--serif); font-size: 0.75rem; font-weight: 700; color: #fff; }
    .topbar-name { font-size: 0.72rem; font-weight: 500; color: var(--dark); }
    #dash-content { flex: 1; padding: 2.5rem 2rem; }

    /* ── OPORTUNIDADES PAGE ───────────────────────────────── */
    .page-header { margin-bottom: 2rem; }
    .page-supertag { font-size: 0.55rem; letter-spacing: 4px; text-transform: uppercase; color: var(--gold); font-weight: 600; display: block; margin-bottom: 0.5rem; }
    .page-title { font-family: var(--serif); font-size: clamp(1.6rem, 3vw, 2.2rem); font-weight: 500; color: var(--dark); line-height: 1.2; }
    .opps-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 1.5rem; }

    /* Oportunidad Card */
    .opp-card {
      background: #fff;
      border: 1px solid #eaeaea;
      border-top: 2px solid var(--dark);
      overflow: hidden;
      transform: translateY(0);
      box-shadow: 0 2px 8px rgba(0,0,0,0.04);
      transition: all 0.35s cubic-bezier(0.34,1.2,0.64,1);
    }
    .opp-card:hover { border-top-color: var(--gold); transform: translateY(-5px); box-shadow: 0 20px 40px rgba(0,0,0,0.1); }
    .opp-card-img { height: 210px; position: relative; overflow: hidden; }
    .opp-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s cubic-bezier(0.2,1,0.3,1); }
    .opp-card:hover .opp-card-img img { transform: scale(1.06); }
    .opp-card-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(10,14,18,0.65) 0%, transparent 55%); transition: opacity 0.3s ease; }
    .opp-card:hover .opp-card-overlay { opacity: 0.85; }
    .opp-card-body { padding: 1.4rem 1.5rem; }
    .opp-card-name { font-family: var(--serif); font-size: 1.3rem; font-weight: 500; color: var(--dark); margin: 0 0 0.6rem; line-height: 1.2; }
    .opp-card-meta { display: flex; align-items: center; gap: 1.2rem; flex-wrap: wrap;     padding: 1.1rem 1.5rem; position:absolute; bottom:0}
    .opp-card-loc { font-size: 0.95rem;  display: flex; align-items: center; gap: 5px; color:white}
    /* .opp-card-loc::before { content: '◈'; color: var(--gold); font-size: 0.65rem; } */
    .opp-card-year { font-size: 0.9rem; color: var(--gold); display: flex; align-items: center; gap: 5px;   text-transform: uppercase; font-weight: 500;letter-spacing: 2px;}
    /* .opp-card-year::before { content: '◷'; color: var(--gold); font-size: 0.65rem; } */
    .opp-teaser-btn {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 10px 20px;
      font-size: 0.85rem;
      margin-top: 20px;
      letter-spacing: 2px;
      text-transform: uppercase;
      border: 1px solid var(--dark);
      background: transparent;
      color: var(--dark);
      cursor: pointer;
      position: relative;
      overflow: hidden;
      transition: color 0.45s cubic-bezier(0.65,0,0.35,1), transform 0.3s ease;
      font-family: var(--sans);
      font-weight: 600;
    }
    .opp-teaser-btn::before {
      content: '';
      position: absolute;
      inset: 0;
      background: var(--dark);
      transform: translateX(-101%);
      transition: transform 0.45s cubic-bezier(0.65,0,0.35,1);
      z-index: 0;
    }
    .opp-teaser-btn:hover::before { transform: translateX(0); }
    .opp-teaser-btn:hover { color: #fff; transform: translateY(-2px); }
    .opp-teaser-btn span { position: relative; z-index: 1; display: flex; align-items: center; gap: 8px; }

    /* ── PERFIL PAGE ──────────────────────────────────────── */

    /* ── PERFIL PAGE ──────────────────────────────────────── */
    .perfil-grid { display: grid; grid-template-columns: 280px 1fr; gap: 1.5rem; align-items: start; }
    .avatar-card { background: #fff; border: 1px solid #eaeaea; border-top: 2px solid var(--dark); padding: 2.5rem 2rem; text-align: center; }
    .avatar-big { width: 80px; height: 80px; border-radius: 50%; background: linear-gradient(135deg, var(--gold) 0%, #a07030 100%); display: flex; align-items: center; justify-content: center; margin: 0 auto 1.2rem; box-shadow: 0 8px 24px rgba(197,160,89,0.25); font-family: var(--serif); font-size: 1.8rem; font-weight: 700; color: #fff; }
    .avatar-name { font-family: var(--serif); font-size: 1.1rem; font-weight: 500; color: var(--dark); margin-bottom: 0.3rem; }
    .avatar-role { font-size: 0.68rem; color: rgba(10,14,18,0.45); margin-bottom: 1.2rem; }
    .validated-badge { display: inline-flex; align-items: center; gap: 5px; padding: 5px 12px; background: rgba(46,204,113,0.1); border: 1px solid rgba(46,204,113,0.25); margin-bottom: 1.5rem; }
    .validated-badge span { font-size: 0.58rem; letter-spacing: 1.5px; text-transform: uppercase; color: #1e8a4a; font-weight: 700; }
    .avatar-since { font-size: 0.62rem; color: rgba(10,14,18,0.35); letter-spacing: 0.5px; }
    .sectores-card { background: #fff; border: 1px solid #eaeaea; padding: 1.5rem; }
    .sectores-card-title { font-size: 0.55rem; letter-spacing: 3px; text-transform: uppercase; color: var(--gold); font-weight: 600; margin-bottom: 1rem; }
    .sector-item { display: flex; align-items: center; gap: 8px; padding: 0.5rem 0.6rem; background: var(--light); border-left: 2px solid var(--gold); font-size: 0.72rem; color: var(--dark); font-weight: 500; margin-bottom: 6px; }
    .sector-item::before { content: '›'; color: var(--gold); }
    .volumen-card { background: var(--dark); padding: 1.5rem; border-top: 2px solid var(--gold); }
    .volumen-label { font-size: 0.55rem; letter-spacing: 3px; text-transform: uppercase; color: rgba(255,255,255,0.35); font-weight: 600; margin-bottom: 0.6rem; }
    .volumen-value { font-family: var(--serif); font-size: 1rem; color: var(--gold); font-weight: 500; }
    .volumen-sub { font-size: 0.65rem; color: rgba(255,255,255,0.3); margin-top: 4px; }
    .info-card { background: #fff; border: 1px solid #eaeaea; border-top: 2px solid var(--dark); }
    .info-card-header { padding: 1.2rem 1.8rem; border-bottom: 1px solid #eaeaea; display: flex; align-items: center; justify-content: space-between; }
    .info-card-title { font-size: 0.7rem; font-weight: 600; color: var(--dark); letter-spacing: 0.5px; text-transform: uppercase; }
    .edit-btn { display: flex; align-items: center; gap: 5px; background: none; border: 1px solid #eaeaea; padding: 6px 14px; cursor: pointer; font-size: 0.62rem; color: rgba(10,14,18,0.5); transition: all 0.2s ease; }
    .edit-btn:hover { border-color: var(--dark); color: var(--dark); }
    .save-btn { display: flex; align-items: center; gap: 4px; background: var(--dark); border: 1px solid transparent; padding: 6px 14px; cursor: pointer; font-size: 0.62rem; color: #fff; font-weight: 600; }
    .cancel-btn { display: flex; align-items: center; gap: 4px; background: none; border: 1px solid #ddd; padding: 6px 12px; cursor: pointer; font-size: 0.62rem; color: rgba(10,14,18,0.5); }
    .info-card-body { padding: 1.5rem 1.8rem; }
    .fields-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem 2rem; }
    .perfil-field-label { display: flex; align-items: center; gap: 6px; font-size: 0.52rem; letter-spacing: 2.5px; text-transform: uppercase; color: var(--gold); font-weight: 600; margin-bottom: 0.4rem; }
    .perfil-field-label::before { content: attr(data-icon); color: var(--gold); }
    .perfil-field-value { font-size: 0.85rem; color: var(--dark); font-weight: 500; padding: 8px 0; border-bottom: 1px solid #f0f0f0; }
    .perfil-field-input { width: 100%; background: transparent; border: none; border-bottom: 1px solid #ddd; padding: 8px 0; font-size: 0.85rem; color: var(--dark); outline: none; transition: border-color 0.25s ease; }
    .perfil-field-input:focus { border-bottom-color: var(--gold); }
    .security-card { background: #fff; border: 1px solid #eaeaea; }
    .security-row { display: flex; align-items: center; justify-content: space-between; padding: 0.8rem 1.8rem; border-bottom: 1px solid #f5f5f5; gap: 1rem; }
    .security-row:last-child { border-bottom: none; }
    .security-info-row { display: flex; align-items: center; gap: 10px; }
    .security-icon { width: 32px; height: 32px; background: rgba(197,160,89,0.08); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
    .security-field-name { font-size: 0.72rem; font-weight: 600; color: var(--dark); }
    .security-field-val { font-size: 0.62rem; color: rgba(10,14,18,0.35); }
    .security-action-btn { padding: 6px 14px; font-size: 0.6rem; letter-spacing: 0.8px; border: 1px solid #eaeaea; background: transparent; color: rgba(10,14,18,0.5); cursor: pointer; white-space: nowrap; transition: all 0.2s ease; }
    .security-action-btn:hover { border-color: var(--dark); color: var(--dark); }
    .saved-notice { padding: 0.8rem 1.2rem; background: rgba(46,204,113,0.08); border: 1px solid rgba(46,204,113,0.25); display: flex; align-items: center; gap: 8px; animation: fadeIn 0.3s ease; }
    .saved-notice span { font-size: 0.75rem; color: #1e8a4a; font-weight: 600; }
    .access-notice { padding: 1rem 1.4rem; background: rgba(197,160,89,0.04); border: 1px solid rgba(197,160,89,0.2); display: flex; align-items: center; gap: 10px; }
    .access-notice p { font-size: 0.7rem; color: rgba(10,14,18,0.5); line-height: 1.6; }
    @keyframes fadeIn { from { opacity:0; transform:translateY(-8px); } to { opacity:1; transform:translateY(0); } }

    /* ── MOBILE NAV OVERLAY ───────────────────────────────── */
    #mobile-menu { background: #fff; padding: 1rem 1.5rem 1.5rem; border-top: 1px solid #f0f0f0; }
    .mobile-nav-link { display: block; width: 100%; text-align: center; font-size: 0.68rem; letter-spacing: 1.5px; text-transform: uppercase; color: var(--dark); padding: 12px 0; font-weight: 500; background: none; border: none; cursor: pointer; border-bottom: 1px solid #f5f5f5; }
    .mobile-nav-cta { display: block; width: 100%; margin-top: 1rem; font-size: 0.6rem; letter-spacing: 2.5px; text-transform: uppercase; border: 1px solid var(--dark); color: var(--dark); background: transparent; padding: 12px 30px; cursor: pointer; }

    /* ── SIDEBAR OVERLAY (mobile) ─────────────────────────── */
    #sidebar-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 99; }

    /* ── RESPONSIVE ───────────────────────────────────────── */
    @media (max-width: 900px) {
       .nav-logo-avet img {
width: 150px;
    }
    #cta-section {
    height: clamp(700px, 110vh, 940px);
}
      .nav-links { display: none; }
      .nav-hamburger { display: block; }
      #mobile-menu.hidden { display: none !important; }
      .svc-card {
        padding: 3.5rem 2rem;
      }
      .nos-grid { grid-template-columns: 1fr !important; display: flex;
        flex-direction: column;}
        #servicios {
          padding-top: 10px !important;
        }
      .nos-img-wrap { grid-column: auto !important; grid-row: auto !important; padding-right: 0 !important; }
      .nos-stats { grid-column: auto !important; grid-row: auto !important; }
      .svc-grid { grid-template-columns: 1fr !important; }
      .cta-box { margin-left: 0 !important; }
      .form-grid { grid-template-columns: 1fr !important; gap: 3rem !important; }
      .footer-grid { grid-template-columns: 1fr !important; gap: 2.5rem !important; }
      #sidebar { transform: translateX(-260px); }
      #sidebar.open { transform: translateX(0); }
      #sidebar-overlay.show { display: block; }
      #dash-main { margin-left: 0 !important; }
      .hamburger-dash { display: flex !important; }
      .topbar-name { display: none; }
      .perfil-grid { grid-template-columns: 1fr !important; }
      .fields-grid { grid-template-columns: 1fr !important; }
      .nos-quote { padding-left: 0 !important; }
    }
    .hamburger-dash { display: none; background: none; border: none; cursor: pointer; color: var(--dark); padding: 4px; font-size: 1.2rem; }
  /* Encapsulamiento bajo la clase .interior404 solo para el área principal */
        .interior404 {
            --avet-dark: #0a0b0c;
            --avet-gold: #c5a059;
            --avet-gray: #a1a1a1;
            
            font-family: 'Montserrat', sans-serif;
            background-color: var(--avet-dark);
            color: #ffffff;
            flex-grow: 1; /* Ocupa el espacio restante entre header y footer */
            display: flex;
            align-items: center;
            justify-content: center;
            position: relative;
            overflow: hidden;
        }

        .interior404 .serif {
            font-family: 'Playfair Display', serif;
        }

        .interior404 .hero-bg-overlay {
            position: absolute;
            top: 0; left: 0; width: 100%; height: 100%;
            background-image: url('https://images.unsplash.com/photo-1486406146926-c627a92ad1ab?q=80&w=2070&auto=format&fit=crop');
            background-size: cover;
            background-position: center;
            opacity: 0.12;
            z-index: 1;
        }

        .interior404 .error-code {
            font-size: clamp(10rem, 25vw, 15rem);
            font-weight: 700;
            color: rgba(255, 255, 255, 0.02);
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            z-index: 2;
            user-select: none;
        }

        .interior404 .content-box {
            position: relative;
            z-index: 10;
            max-width: 750px;
            padding: 80px 20px;
        }

        .interior404 h1 {
            font-size: clamp(2.5rem, 8vw, 4rem);
            margin-bottom: 1.5rem;
            font-weight: 400;
            color: #ffffff;
        }

        .interior404 h1 span {
            color: var(--avet-gold);
            font-style: italic;
        }

        .interior404 .description {
            color: var(--avet-gray);
            font-weight: 300;
            font-size: 1.15rem;
            line-height: 1.8;
            margin-bottom: 3.5rem;
            letter-spacing: 0.5px;
        }

        .interior404 .btn-avet {
            font-family: 'Montserrat', sans-serif;
            text-transform: uppercase;
            font-size: 0.75rem;
            font-weight: 600;
            letter-spacing: 2.5px;
            padding: 1.1rem 2.8rem;
            border-radius: 0;
            transition: all 0.5s cubic-bezier(0.2, 1, 0.3, 1);
            display: inline-block;
            text-decoration: none;
        }

        .interior404 .btn-avet-gold {
            background-color: transparent;
            color: white !important;
            border: 1px solid var(--avet-gold) !important;
        }

        .interior404 .btn-avet-gold:hover {
            background-color: var(--avet-gold);
            color: #000 !important;
            box-shadow: 0 10px 20px rgba(197, 160, 89, 0.2);
        }

        .interior404 .btn-outline-white {
            border: 1px solid rgba(255,255,255,0.2) !important;
            color: #fff !important;
        }

        .interior404 .btn-outline-white:hover {
            border-color: #fff !important;
            background-color: #fff;
            color: #000 !important;

        }



         /* Estilo de "Mensaje de Error" basado en captura de validación */
        .validation-summary-errors {
          --avet-danger: #dc3545; /* Rojo de validación visto en captura */
            background-color: rgba(220, 53, 69, 0.05);
            border-left: 3px solid var(--avet-danger);
            padding: 1.5rem;
            text-align: left;
            display: inline-block;
            max-width: 100%;
        }
      .form-text.text-danger {
    color: #dc3545;
    font-size: 0.75rem;
}

        .validation-summary-errors ul {
            margin: 0;
            padding-left: 1.2rem;
            color: var(--avet-danger);
            list-style-type: disc;
        }

        .validation-summary-errors li {
            font-size: 0.9rem;
            margin-bottom: 5px;
            font-weight: 400;
        }
