:root {
  --navy-950: #06152d;
  --navy-900: #092044;
  --navy-800: #0d2c58;
  --blue: #1d64b7;
  --gold: #d7b06a;
  --ink: #10213b;
  --muted: #66758b;
  --line: #e8edf4;
  --surface: #f4f7fb;
  --white: #fff;
  --shadow: 0 28px 80px rgba(5, 23, 52, 0.18);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background:
    radial-gradient(circle at 10% 10%, rgba(50, 105, 168, .2), transparent 25%),
    #e8eef6;
  font-family: "DM Sans", sans-serif;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
button { color: inherit; font: inherit; }
.business-card {
  width: min(100%, 540px);
  min-height: 100vh;
  margin: 0 auto;
  overflow: hidden;
  background: var(--white);
  box-shadow: var(--shadow);
}
.section-pad { padding: 32px 28px; }

.hero {
  position: relative;
  min-height: 430px;
  display: grid;
  place-items: center;
  overflow: hidden;
  color: white;
  isolation: isolate;
  background:
    linear-gradient(180deg, rgba(5, 18, 40, .1), rgba(4, 17, 38, .88)),
    radial-gradient(circle at 75% 15%, #1b4c82 0, transparent 36%),
    linear-gradient(145deg, #0d3062, #06152d 70%);
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  opacity: .25;
  background-image: linear-gradient(rgba(255,255,255,.08) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: linear-gradient(to bottom, black, transparent 75%);
}
.hero::after {
  content: "";
  position: absolute;
  width: 450px;
  height: 450px;
  left: 55%;
  top: -280px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 50%;
  box-shadow: 0 0 0 65px rgba(255,255,255,.025), 0 0 0 130px rgba(255,255,255,.018);
}
.skyline {
  position: absolute;
  inset: auto 0 0;
  height: 110px;
  opacity: .2;
  background: linear-gradient(90deg, transparent 3%, #7da2ca 3% 10%, transparent 10% 13%, #7da2ca 13% 22%, transparent 22% 24%, #7da2ca 24% 36%, transparent 36% 39%, #7da2ca 39% 44%, transparent 44% 47%, #7da2ca 47% 62%, transparent 62% 65%, #7da2ca 65% 76%, transparent 76% 80%, #7da2ca 80% 96%, transparent 96%);
  clip-path: polygon(0 100%,0 60%,3% 60%,3% 20%,10% 20%,10% 65%,13% 65%,13% 38%,22% 38%,22% 70%,24% 70%,24% 0,36% 0,36% 62%,39% 62%,39% 43%,44% 43%,44% 72%,47% 72%,47% 25%,62% 25%,62% 67%,65% 67%,65% 8%,76% 8%,76% 58%,80% 58%,80% 35%,96% 35%,96% 73%,100% 73%,100% 100%);
}
.hero-content { position: relative; z-index: 2; text-align: center; transform: translateY(-4px); }
.brand-mark {
  width: min(360px, 86vw);
  height: 116px;
  display: grid;
  place-items: center;
  margin: 0 auto 24px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 22px;
  background: rgba(3, 17, 39, .72);
  box-shadow: 0 20px 45px rgba(0,0,0,.25), inset 0 1px rgba(255,255,255,.25);
  backdrop-filter: blur(12px);
  animation: logo-in 1s cubic-bezier(.2,.8,.2,1) both;
}
.brand-mark img {
  display: block;
  width: 94%;
  height: auto;
  max-height: 96px;
  object-fit: contain;
}
.eyebrow, .mini-label {
  margin: 0 0 8px;
  color: var(--gold);
  font: 700 10px/1.2 "Manrope", sans-serif;
  text-transform: uppercase;
  letter-spacing: .18em;
}
.brand-subtitle { margin: 10px 0 24px; color: #cad6e5; font: 500 14px/1.4 "Manrope", sans-serif; letter-spacing: .08em; }
.slogan { display: flex; align-items: center; gap: 10px; color: rgba(255,255,255,.72); font-size: 11px; letter-spacing: .08em; }
.slogan span { width: 24px; height: 1px; background: var(--gold); }

.profile { position: relative; display: flex; align-items: center; gap: 20px; border-bottom: 1px solid var(--line); }
.avatar {
  position: relative;
  flex: 0 0 92px;
  width: 92px;
  height: 92px;
  display: grid;
  place-items: center;
  margin-top: -68px;
  color: white;
  border: 5px solid white;
  border-radius: 50%;
  background: linear-gradient(145deg, #315f91, var(--navy-950));
  box-shadow: 0 12px 30px rgba(4, 25, 57, .22);
  font: 700 24px/1 "Manrope", sans-serif;
  overflow: visible;
}
.avatar img { width: 100%; height: 100%; border-radius: 50%; object-fit: cover; object-position: center 24%; }
.online-dot { position: absolute; right: 2px; bottom: 5px; width: 17px; height: 17px; border: 3px solid white; border-radius: 50%; background: #35b979; }
.profile-copy { flex: 1; min-width: 0; }
.profile-copy h2, .section-heading h2, .about h2 { margin: 0; font: 800 23px/1.2 "Manrope", sans-serif; letter-spacing: -.03em; }
.profile-copy > p:not(.mini-label) { margin: 4px 0 13px; color: var(--muted); font-size: 13px; }
.contact-inline { display: flex; flex-wrap: wrap; gap: 6px 13px; }
.contact-inline a { display: flex; align-items: center; gap: 6px; color: #42536a; font-size: 11px; font-weight: 600; }
.contact-inline svg { width: 13px; height: 13px; fill: none; stroke: var(--blue); stroke-width: 1.8; }

.actions { background: var(--surface); }
.section-heading { display: flex; align-items: end; justify-content: space-between; margin-bottom: 20px; }
.availability { padding: 7px 10px; color: #137049; border: 1px solid #ccebdc; border-radius: 999px; background: #eefaf4; font-size: 10px; font-weight: 700; }
.action-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.action-button {
  min-width: 0;
  min-height: 105px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 12px 5px;
  border: 1px solid rgba(255,255,255,.9);
  border-radius: 18px;
  background: rgba(255,255,255,.68);
  box-shadow: 0 10px 30px rgba(27, 54, 91, .08), inset 0 1px rgba(255,255,255,.8);
  backdrop-filter: blur(14px);
  cursor: pointer;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.action-button:hover { transform: translateY(-4px); border-color: #cddced; box-shadow: 0 16px 30px rgba(27, 54, 91, .14); }
.action-button:active { transform: translateY(-1px); }
.action-button > span:last-child { font-size: 10px; font-weight: 700; white-space: nowrap; }
.action-icon { width: 44px; height: 44px; display: grid; place-items: center; color: white; border-radius: 14px; background: linear-gradient(145deg, #17477f, var(--navy-950)); box-shadow: 0 8px 18px rgba(8, 35, 71, .25); }
.action-icon svg { width: 20px; height: 20px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.whatsapp .action-icon { background: linear-gradient(145deg, #38c97b, #159854); }
.instagram .action-icon { background: linear-gradient(135deg, #6b4acb, #df476e, #e39b3c); }
.social-glyph { font: 800 14px/1 "Manrope", sans-serif; }

.about { border-bottom: 1px solid var(--line); }
.about h2 { margin-bottom: 14px; }
.about > p { margin: 0; color: var(--muted); font-size: 14px; line-height: 1.75; }
.expertise { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 20px; }
.expertise span { padding: 7px 11px; color: var(--navy-800); border-radius: 8px; background: #edf3fa; font-size: 10px; font-weight: 700; }

.social { padding-bottom: 28px; }
.social-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
.social-row a { display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 13px 3px; border: 1px solid var(--line); border-radius: 15px; transition: border-color .2s ease, background .2s ease; }
.social-row a:hover { border-color: #c7d5e7; background: var(--surface); }
.social-row strong { width: 34px; height: 34px; display: grid; place-items: center; color: white; border-radius: 11px; background: var(--navy-900); font: 700 15px/1 "Manrope", sans-serif; }
.social-row a:first-child strong { background: linear-gradient(135deg, #6b4acb, #df476e, #e39b3c); }
.social-row a:nth-child(2) strong { background: #1877f2; font-size: 20px; }
.social-row a:nth-child(3) strong { background: #111; }
.social-row a:nth-child(4) strong { background: #e62117; font-size: 11px; }
.social-row span { color: var(--muted); font-size: 9px; font-weight: 600; }

.details { color: white; background: var(--navy-950); }
.detail-card { overflow: hidden; border: 1px solid rgba(255,255,255,.1); border-radius: 20px; background: rgba(255,255,255,.06); }
.detail-card > a, .detail-card > div { display: flex; align-items: center; gap: 13px; min-height: 75px; padding: 13px 16px; border-bottom: 1px solid rgba(255,255,255,.08); }
.detail-card > :last-child { border-bottom: 0; }
.detail-icon { flex: 0 0 39px; width: 39px; height: 39px; display: grid; place-items: center; color: var(--gold); border-radius: 12px; background: rgba(255,255,255,.08); }
.detail-icon svg, .chevron { width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; }
.detail-card a > span:nth-child(2), .detail-card div > span:nth-child(2) { display: flex; flex: 1; flex-direction: column; gap: 4px; }
.detail-card small { color: #91a0b5; font-size: 9px; text-transform: uppercase; letter-spacing: .13em; }
.detail-card strong { font-size: 12px; font-weight: 600; }
.chevron { width: 16px; color: #6f7f95; }
.copyright { margin: 20px 0 0; color: #65758c; text-align: center; font-size: 9px; }

.toast { position: fixed; z-index: 10; left: 50%; bottom: 24px; padding: 12px 18px; color: white; border-radius: 10px; background: #0d243f; box-shadow: 0 10px 30px rgba(0,0,0,.25); opacity: 0; pointer-events: none; transform: translate(-50%, 20px); transition: .3s ease; font-size: 12px; font-weight: 600; }
.toast.show { opacity: 1; transform: translate(-50%, 0); }
.svg-defs { position: absolute; width: 0; height: 0; overflow: hidden; }

@keyframes logo-in { from { opacity: 0; transform: translateY(15px) scale(.92); } to { opacity: 1; transform: translateY(0) scale(1); } }
@media (min-width: 700px) { body { padding: 42px 0; } .business-card { min-height: auto; border-radius: 28px; } }
@media (max-width: 390px) {
  .section-pad { padding-left: 20px; padding-right: 20px; }
  .hero { min-height: 400px; }
  .action-grid { grid-template-columns: repeat(2, 1fr); }
  .action-button { min-height: 95px; }
  .action-button > span:last-child { font-size: 11px; }
  .profile { align-items: flex-start; }
  .avatar { flex-basis: 80px; width: 80px; height: 80px; }
}
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { scroll-behavior: auto !important; animation-duration: .01ms !important; transition-duration: .01ms !important; } }
