*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { height: 100%; }

:root {
  --bg:        #f8f3ea;   /* varm cream/ivory som lugn bas */
  --bg2:       #f1e8da;
  --ink:       #4a4038;   /* varm brun-grå text */
  --ink-soft:  #8b7e73;
  --ink-faint: #bbac9d;
  --purple:    #8e72b0;
  --purple-dk: #6f5396;
  --pink:      #cf93ab;   /* dovare, dammig rosé */
  --pink-dk:   #b6748f;
  --gold:      #c9a877;   /* sparsam guldaccent */
  --line:      rgba(74,64,56,0.10);
}

body {
  min-height: 100%;
  background: var(--bg);
  font-family: 'Nunito Sans', -apple-system, sans-serif;
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  padding-bottom: max(env(safe-area-inset-bottom), 56px);
}

/* ── Mjukt, drömskt ljus — rosa, lila & en gnutta guld ── */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background:
    radial-gradient(540px 380px at 14% -8%, rgba(207,147,171,0.12) 0%, transparent 58%),
    radial-gradient(560px 460px at 94% 2%, rgba(142,114,176,0.13) 0%, transparent 60%),
    radial-gradient(620px 520px at 50% 40%, rgba(201,168,119,0.08) 0%, transparent 64%),
    linear-gradient(180deg, var(--bg) 0%, var(--bg2) 100%);
  pointer-events: none;
  z-index: 0;
}

.shell { position: relative; z-index: 1; max-width: 460px; margin: 0 auto; }

/* ── Header ── */
.header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 22px 26px 0;
  opacity: 0; animation: fadeUp .5s .05s forwards;
}
.wordmark {
  font-size: 10px; font-weight: 700; letter-spacing: 0.28em;
  color: var(--ink-faint); text-transform: uppercase;
}
.lang-btn {
  font-size: 10px; font-weight: 700; letter-spacing: 0.12em;
  color: var(--ink-soft); background: rgba(255,255,255,0.45);
  border: 1px solid var(--line); border-radius: 6px;
  padding: 4px 9px; cursor: pointer; transition: all .15s;
}
.lang-btn:hover { color: var(--purple-dk); border-color: rgba(138,107,176,0.4); }

/* ── Hero ── */
.hero {
  padding: 44px 26px 30px; text-align: center;
  opacity: 0; animation: fadeUp .55s .12s forwards;
}
.glyph {
  font-size: 24px; margin-bottom: 16px; letter-spacing: 0.3em;
  background: linear-gradient(120deg, var(--pink), var(--purple));
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.hero-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 47px; font-weight: 500; letter-spacing: 0.005em;
  line-height: 1.04; margin-bottom: 14px; color: var(--ink);
}
.hero-role {
  font-size: 13.5px; font-weight: 500; color: var(--ink-soft);
  letter-spacing: 0.02em; line-height: 1.6;
}
.tags {
  display: flex; flex-wrap: wrap; justify-content: center; gap: 7px;
  margin-top: 18px;
}
.tag {
  font-size: 10.5px; font-weight: 600; letter-spacing: 0.05em;
  color: var(--purple-dk); background: rgba(138,107,176,0.10);
  border: 1px solid rgba(138,107,176,0.22);
  padding: 5px 11px; border-radius: 999px;
}
.tag:nth-child(even) {
  color: var(--pink-dk); background: rgba(217,127,166,0.10);
  border-color: rgba(217,127,166,0.24);
}

/* ── Spara kontakt ── */
.save-wrap { padding: 6px 26px 36px; opacity: 0; animation: fadeUp .55s .2s forwards; }
.save-btn {
  display: flex; align-items: center; justify-content: center; gap: 9px;
  width: 100%; padding: 16px 20px;
  background: linear-gradient(120deg, var(--pink) 0%, var(--purple) 100%);
  border: 1px solid rgba(255,255,255,0.35);
  box-shadow: 0 1px 0 rgba(255,255,255,0.4) inset, 0 6px 22px rgba(138,107,176,0.38);
  color: #fff; border-radius: 14px; text-decoration: none;
  font-size: 16px; font-weight: 700; letter-spacing: 0.01em;
  cursor: pointer; position: relative; overflow: hidden;
  transition: transform .15s, opacity .15s;
}
.save-btn::before {
  content: ''; position: absolute; top: 0; left: 10%; right: 10%; height: 1px;
  background: linear-gradient(to right, transparent, rgba(255,255,255,0.65), transparent);
}
.save-btn:active { transform: scale(0.975); opacity: .9; }
.save-btn svg { width: 18px; height: 18px; fill: none; stroke: #fff; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }

/* ── Avdelare ── */
.sep {
  display: flex; align-items: center; gap: 14px;
  margin: 0 26px 28px; opacity: 0.8;
}
.sep::before, .sep::after {
  content: ''; flex: 1; height: 1px;
  background: linear-gradient(to right, transparent, var(--line), transparent);
}
.sep span {
  font-size: 13px;
  background: linear-gradient(120deg, var(--pink), var(--purple));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}

/* ── Kontaktlista ── */
.contact-wrap { padding: 0 26px; opacity: 0; animation: fadeUp .55s .28s forwards; }
.c-section { margin-bottom: 34px; }
.c-label {
  font-size: 9.5px; font-weight: 700; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--ink-faint); margin-bottom: 10px;
}
.c-item {
  display: flex; align-items: center; padding: 13px 0; gap: 15px;
  text-decoration: none; color: var(--ink);
  border-bottom: 1px solid var(--line);
  -webkit-tap-highlight-color: transparent; transition: opacity .12s;
}
.c-item:first-of-type { border-top: 1px solid var(--line); }
.c-item:active { opacity: .5; }
.c-icon {
  width: 38px; height: 38px; border-radius: 11px; flex-shrink: 0;
  background: linear-gradient(150deg, rgba(255,255,255,0.75), rgba(255,255,255,0.3));
  border: 1px solid rgba(255,255,255,0.65);
  box-shadow: 0 2px 8px rgba(72,61,74,0.06), inset 0 1px 0 rgba(255,255,255,0.85);
  display: flex; align-items: center; justify-content: center;
}
.c-icon svg { width: 17px; height: 17px; fill: none; stroke: var(--purple-dk); stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; }
.c-item:nth-child(even) .c-icon svg { stroke: var(--pink-dk); }
.c-text { flex: 1; min-width: 0; }
.c-primary {
  font-size: 15.5px; font-weight: 600; color: var(--ink);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.c-sub { font-size: 12px; color: var(--ink-faint); margin-top: 2px; font-weight: 500; }
.c-arrow { font-size: 18px; color: var(--ink-faint); flex-shrink: 0; font-family: 'Cormorant Garamond', serif; }

.footer {
  text-align: center; padding: 14px 26px 0;
  font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-faint); opacity: 0; animation: fadeUp .55s .36s forwards;
}

@keyframes fadeUp { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: translateY(0); } }
