/* Contact action cards */
@layer components {
  .contact-card{
    position:relative;
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;
    padding:48px 32px;text-align:center;background:var(--surface);border:1px solid var(--border-subtle);
    border-radius:14px;color:var(--primary);font-family:'Poppins';font-weight:600;
    transition:transform .25s,background .25s,color .25s,box-shadow .25s,border-color .25s
  }
  .contact-card svg{
    width:40px; height:40px; color:inherit;
    /* match footer stroke-based icon styling */
    fill:none; stroke:currentColor; shape-rendering:geometricPrecision;
    stroke-width:2; stroke-linecap:round; stroke-linejoin:round;
  }
  .contact-card svg.brand-fill{ fill: currentColor; stroke: none; }
  .contact-card .icon{ display:block; width:40px; height:40px; }
  /* reuse the same GitHub mask style used in .btn-icon */
  .contact-card .icon-github{
    background-color: currentColor;
    -webkit-mask-image: url('../img/icons/github-icon.png');
            mask-image: url('../img/icons/github-icon.png');
    -webkit-mask-repeat: no-repeat;     mask-repeat: no-repeat;
    -webkit-mask-position: center;      mask-position: center;
    -webkit-mask-size: contain;         mask-size: contain;
  }
  .contact-card small{font-family:'Inter';color:var(--text-muted);transition:inherit}
  .contact-card:hover{
    background:var(--primary);color:var(--bg);transform:translateY(-3px);
    border-color:var(--primary);
    box-shadow:0 10px 24px color-mix(in srgb, var(--primary) 35%, transparent)
  }
  .contact-card:hover i,.contact-card:hover small{color:var(--bg)}
  .surface-band.reveal.active .contact-card{animation:focusIn .6s forwards}
  .contact-card-badge{
    position:absolute;
    top:16px;
    right:16px;
    padding:4px 10px;
    border-radius:999px;
    font-size:.72rem;
    letter-spacing:.08em;
    text-transform:uppercase;
    font-weight:600;
    background:color-mix(in srgb,var(--primary) 20%, #ffffff 80%);
    color:color-mix(in srgb,var(--primary) 80%, #031016 20%);
  }
  .contact-card.contact-card-recommended{
    background:linear-gradient(135deg,
      color-mix(in srgb,var(--primary) 22%, var(--surface) 78%) 0%,
      color-mix(in srgb,var(--primary) 38%, var(--surface) 62%) 100%);
    border-color:color-mix(in srgb,var(--primary) 48%, transparent);
    color:color-mix(in srgb,#ffffff 92%, var(--bg) 8%);
    box-shadow:0 24px 48px rgba(0,0,0,.35);
    isolation:isolate;
  }
  .contact-card.contact-card-recommended::after{
    content:"";
    position:absolute;
    inset:0;
    border-radius:inherit;
    background:var(--primary);
    opacity:0;
    transition:opacity .25s;
    z-index:-1;
    pointer-events:none;
  }
  .contact-card.contact-card-recommended small{
    color:color-mix(in srgb,#ffffff 88%, var(--bg) 12%);
  }
  .contact-card.contact-card-recommended:hover{
    color:var(--bg);
    border-color:var(--primary);
    transform:translateY(-3px);
    box-shadow:0 10px 24px color-mix(in srgb, var(--primary) 35%, transparent);
  }
  .contact-card.contact-card-recommended:hover::after{
    opacity:1;
  }
  .contact-card.contact-card-recommended:hover small{
    color:var(--bg);
  }
  .contact-options-heading{
    text-align:center;
    margin:0 auto 32px;
    max-width:min(640px, 90vw);
  }
  .contact-options-heading .section-title{
    margin:0 0 8px;
  }
  .contact-options-heading .section-subtitle{
    margin:0;
    color:var(--text-muted);
    font-size:1rem;
  }
}
