/* Root + layout */
:root{
  --bg:#0b0f1a; --card:#111827; --muted:#9aa4b2; --text:#e5e7eb;
  --brand:#22c55e; --ring:rgba(34,197,94,.35);
  --shadow:0 10px 20px rgba(0,0,0,.35),0 6px 6px rgba(0,0,0,.25);
  --radius-2xl:26px
}
body{
  margin:0; font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial;
  background:radial-gradient(1200px 600px at 20% -10%,rgba(34,197,94,.15),transparent),
             radial-gradient(800px 500px at 120% 10%,rgba(34,197,94,.12),transparent),
             var(--bg);
  color:var(--text); display:grid; place-items:center; padding:24px; line-height:1.5
}
.wrap{ width:min(980px,100%); display:grid; gap:24px }
.card{
  position:relative; display:grid; gap:20px; padding:28px; border-radius:var(--radius-2xl);
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02)),var(--card);
  box-shadow:var(--shadow); border:1px solid rgba(255,255,255,.06)
}
.row{ display:grid; grid-template-columns:128px 1fr; gap:18px; align-items:center }
.avatar{ width:128px; height:128px; border-radius:50%; object-fit:cover; border:2px solid rgba(255,255,255,.15) }
.id h1{ margin:0 0 4px; font-size:clamp(22px,3vw,32px) }
.id p{ margin:0; color:var(--muted) }
.tags{ display:flex; flex-wrap:wrap; gap:8px; margin-top:10px }
.tag{ font-size:14px; padding:6px 10px; background:rgba(255,255,255,.06); border-radius:999px; border:1px solid rgba(255,255,255,.08) }
.actions{ display:grid; grid-template-columns:repeat(2,1fr); gap:12px }
.btn{
  display:flex; align-items:center; justify-content:center; gap:10px;
  padding:14px 16px; border-radius:14px; font-weight:600; text-decoration:none;
  color:var(--text); background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.08); min-height:44px;
  transition: transform .12s ease, border-color .12s ease, box-shadow .12s ease;
}
.btn.primary{ background:linear-gradient(180deg,rgba(34,197,94,.16),rgba(34,197,94,.08)); border:1px solid var(--ring) }
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:12px }
.mini{ padding:12px; border-radius:12px; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); text-align:center; font-size:14px; color:var(--muted) }
.footer{ display:flex; justify-content:space-between; flex-wrap:wrap; color:var(--muted); font-size:14px }
.chip{ position:absolute; top:14px; right:14px; padding:8px 10px; border-radius:999px; font-weight:600; font-size:13px; border:1px solid rgba(255,255,255,.12); background:rgba(255,255,255,.06) }
.qr-wrap{ display:grid; gap:12px; place-items:center }
.qr-wrap img{ width:200px; height:200px; background:#fff; padding:8px; border-radius:12px }

@media(max-width:560px){
  .row{ grid-template-columns:96px 1fr }
  .avatar{ width:96px; height:96px }
  .actions{ grid-template-columns:1fr }
  .grid-3{ grid-template-columns:1fr }
}

/* Contact mini-card link polish */
.grid-3 .mini a{
  color:var(--text); text-decoration:none; border-bottom:1px solid rgba(229,231,235,.18); padding-bottom:1px;
  transition: color .15s ease, border-color .15s ease, opacity .15s ease;
}
.grid-3 .mini a:hover,.grid-3 .mini a:focus-visible{ border-color:var(--ring); outline:none }
.grid-3 .mini a:active{ opacity:.85 }
.grid-3 .mini a:visited{ color:var(--text) }

/* Optional: pill variant */
.grid-3 .mini a.pill{
  border:1px solid rgba(255,255,255,.12); border-radius:999px; padding:6px 10px; border-bottom:none; background:rgba(255,255,255,.04)
}
.grid-3 .mini a.pill:hover,.grid-3 .mini a.pill:focus-visible{
  box-shadow:0 0 0 3px var(--ring); border-color:var(--ring)
}

/* Hide QR on very small screens */
@media (max-width:560px){ .qr-wrap{ display:none } }

/* Mobile hint visibility */
.qr-hint{ display:none; color:var(--muted) }
@media (max-width:560px){ .qr-hint{ display:block } }

/* Button hover/focus */
.btn:hover,.btn:focus-visible{ transform:translateY(-2px); border-color:rgba(255,255,255,.18); outline:none }
.btn:active{ transform:translateY(0) scale(.98) }
.btn.primary:hover,.btn.primary:focus-visible{ box-shadow:0 0 12px 3px var(--ring), 0 6px 18px rgba(0,0,0,.35) }

/* Respect reduced motion */
@media (prefers-reduced-motion:reduce){
  .btn{ transition:none }
  .btn:hover,.btn:focus-visible,.btn:active{ transform:none }
}

/* --- Contact form layout --- */
.contact{ display:grid; gap:14px }
.row-2{ display:grid; grid-template-columns:1fr 1fr; gap:12px }
.field{ display:grid; gap:6px }
.field label{ font-size:14px; color:var(--muted) }
.input{
  width:100%; box-sizing:border-box; background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08); color:var(--text);
  border-radius:12px; padding:10px 12px; outline:none;
}
.input:focus{ border-color:var(--ring); box-shadow:0 0 0 3px var(--ring) }
textarea.input{ min-height:120px; resize:vertical }
select.input{ appearance:none }

@media (max-width:560px){ .row-2{ grid-template-columns:1fr } }
