:root {
  --bg: #fff8ee;
  --ink: #221a12;
  --muted: #75604a;
  --card: rgba(255,255,255,.78);
  --line: rgba(97, 66, 35, .16);
  --gold: #b67b2f;
  --gold-dark: #80501d;
  --cream: #fffdf8;
  --shadow: 0 24px 70px rgba(78, 48, 14, .18);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body::before {
  content: "";
  position: fixed;
  inset: -28px;
  background: linear-gradient(rgba(255,248,238,.88), rgba(244,223,191,.94)), url("assets/profile-640.webp") center 38% / cover no-repeat;
  filter: blur(34px);
  transform: scale(1.05);
  opacity: .48;
  z-index: -1;
  pointer-events: none;
}
body {
  margin: 0;
  min-height: 100vh;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background: radial-gradient(circle at top, #fff 0%, var(--bg) 45%, #f4dfbf 100%);
  overflow-x: hidden;
}
.ambient { position: fixed; border-radius: 999px; filter: blur(10px); opacity: .45; pointer-events: none; z-index: 0; }
.ambient-one { width: 420px; height: 420px; background: #ffd28a; top: -180px; left: -120px; }
.ambient-two { width: 360px; height: 360px; background: #fff; right: -110px; bottom: 80px; }
.shell {
  position: relative;
  z-index: 1;
  width: min(680px, calc(100% - 32px));
  margin: 0 auto;
  padding: 42px 0 24px;
}
.hero { text-align: center; }
.avatar {
  width: 140px; height: 140px; margin: 0 auto 18px;
  display: block;
  border-radius: 50%;
  object-fit: cover;
  object-position: 50% 42%;
  border: 3px solid rgba(255,255,255,.92);
  box-shadow: var(--shadow);
  background: #fff8ee;
}
.eyebrow { margin: 0 0 8px; color: var(--gold-dark); font-size: 13px; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }
h1 { margin: 0; font-family: Georgia, "Times New Roman", serif; font-size: clamp(46px, 12vw, 74px); line-height: .95; }
.tagline { margin: 14px auto 8px; font-size: clamp(19px, 4vw, 24px); font-weight: 800; max-width: 560px; }
.bio { margin: 0 auto 24px; color: var(--muted); line-height: 1.6; max-width: 560px; }
.featured-card, .link-card, .socials, .share-box {
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  background: var(--card);
  border: 1px solid var(--line);
  box-shadow: 0 16px 48px rgba(88, 55, 16, .12);
}
.featured-card { border-radius: 28px; padding: 22px; margin: 0 0 18px; text-align: left; }
.spotify-feature { background: linear-gradient(135deg, rgba(255,255,255,.96), rgba(255,236,203,.88)); border-color: rgba(182,123,47,.32); }
.featured-label { display: inline-flex; margin-bottom: 10px; color: var(--gold-dark); font-weight: 900; font-size: 12px; text-transform: uppercase; letter-spacing: .12em; }
.featured-card strong { display:block; font-size: 24px; font-family: Georgia, serif; }
.featured-card p { color: var(--muted); margin: 8px 0 18px; line-height: 1.55; }
.primary-action, button {
  display: inline-flex; align-items: center; justify-content: center;
  min-height: 46px; border-radius: 999px; padding: 0 20px;
  border: 0; cursor: pointer; text-decoration: none;
  background: linear-gradient(135deg, #d39843, #7e4b18);
  color: #fff; font-weight: 900;
  box-shadow: 0 14px 30px rgba(128, 80, 29, .25);
}
.links { display: grid; gap: 12px; }
.link-card {
  position: relative; display: grid; grid-template-columns: 48px 1fr auto; gap: 14px; align-items: center;
  padding: 16px; border-radius: 22px; text-decoration: none; color: inherit;
  transform: translateY(0); transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.link-card:hover, .link-card:focus-visible { transform: translateY(-3px); border-color: rgba(182, 123, 47, .45); box-shadow: 0 22px 54px rgba(88, 55, 16, .18); outline: none; }
.link-main { background: linear-gradient(135deg, rgba(255,255,255,.94), rgba(255,232,195,.76)); }
.icon { display: grid; place-items: center; width: 48px; height: 48px; border-radius: 17px; background: var(--cream); color: var(--gold-dark); font-weight: 950; font-size: 20px; border: 1px solid var(--line); }
.link-card strong { display: block; font-size: 16px; }
.link-card small { color: var(--muted); display: block; margin-top: 3px; line-height: 1.35; }
.link-card em { color: var(--gold-dark); font-style: normal; font-weight: 900; font-size: 13px; }
.muted { opacity: .9; }
.socials, .share-box { margin-top: 18px; border-radius: 26px; padding: 20px; text-align: center; }
.socials p, .share-box p { margin: 0 0 14px; color: var(--muted); }
.socials div { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; }
.socials a { color: var(--ink); text-decoration: none; border: 1px solid var(--line); background: rgba(255,255,255,.55); border-radius: 999px; padding: 10px 14px; font-weight: 800; }
footer { position: relative; z-index: 1; text-align: center; color: var(--muted); padding: 10px 16px 32px; font-size: 13px; }
@media (max-width: 460px) {
  .shell { width: min(100% - 22px, 680px); padding-top: 26px; }
  .link-card { grid-template-columns: 42px 1fr; padding: 14px; }
  .link-card em { display: none; }
  .icon { width: 42px; height: 42px; border-radius: 15px; }
  .featured-card { padding: 18px; }
}
