/* ============================================================
   Horoskopia — risoprint-almanak design system
   Surfaces: ingen shadows. Depth via hairlines og color shifts.
   ============================================================ */

:root {
    /* paper + ink */
    --paper:          #f5efe8;
    --paper-warm:     #efe6dc;
    --ink:            #2a1f14;
    --ink-soft:       #5a4634;
    --mole:           #9a7a5a;
    --mole-soft:      rgba(154, 122, 90, 0.45);
    --rule:           rgba(42, 31, 20, 0.10);
    --rule-soft:      rgba(42, 31, 20, 0.06);
    --rule-strong:    rgba(42, 31, 20, 0.22);

    /* gold ink */
    --gold:           #b8924a;
    --gold-dark:      #8d6e34;
    --gold-soft:      rgba(184, 146, 74, 0.18);
    --gold-hairline:  rgba(184, 146, 74, 0.55);

    /* type */
    --font-display:   "Playfair Display", "Times New Roman", serif;
    --font-body:      "Lora", Georgia, serif;
    --font-mark:      "Inter", -apple-system, system-ui, sans-serif;

    /* spacing — 8px base */
    --s-1: 4px;
    --s-2: 8px;
    --s-3: 12px;
    --s-4: 16px;
    --s-6: 24px;
    --s-8: 32px;
    --s-12: 48px;
    --s-18: 72px;
}

/* per-sign blob silhouettes — unique border-radius per tegn */
[data-sign-slug="vaedderen"]    .sign-card__blob { border-radius: 62% 38% 48% 52% / 54% 50% 50% 46%; }
[data-sign-slug="tyren"]        .sign-card__blob { border-radius: 54% 46% 60% 40% / 48% 58% 42% 52%; }
[data-sign-slug="tvillingerne"] .sign-card__blob { border-radius: 46% 54% 42% 58% / 60% 44% 56% 40%; }
[data-sign-slug="krebsen"]      .sign-card__blob { border-radius: 58% 42% 56% 44% / 42% 54% 46% 58%; }
[data-sign-slug="loeven"]       .sign-card__blob { border-radius: 50% 50% 38% 62% / 56% 44% 56% 44%; }
[data-sign-slug="jomfruen"]     .sign-card__blob { border-radius: 60% 40% 54% 46% / 48% 60% 40% 52%; }
[data-sign-slug="vaegten"]      .sign-card__blob { border-radius: 48% 52% 44% 56% / 58% 42% 58% 42%; }
[data-sign-slug="skorpionen"]   .sign-card__blob { border-radius: 42% 58% 60% 40% / 50% 46% 54% 50%; }
[data-sign-slug="skytten"]      .sign-card__blob { border-radius: 56% 44% 52% 48% / 46% 56% 44% 54%; }
[data-sign-slug="stenbukken"]   .sign-card__blob { border-radius: 38% 62% 46% 54% / 52% 48% 52% 48%; }
[data-sign-slug="vandmanden"]   .sign-card__blob { border-radius: 64% 36% 50% 50% / 44% 56% 44% 56%; }
[data-sign-slug="fisken"]       .sign-card__blob { border-radius: 50% 50% 60% 40% / 56% 44% 56% 44%; }

/* ----- reset + base ----- */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
    background: var(--paper);
    color: var(--ink);
    font-family: var(--font-body);
    font-size: 17px;
    line-height: 1.65;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}
a { color: var(--gold-dark); text-decoration: underline; text-decoration-color: var(--gold-hairline); text-underline-offset: 4px; text-decoration-thickness: 1px; transition: color .15s ease, text-decoration-color .15s ease; }
a:hover { color: var(--ink); text-decoration-color: var(--ink); }
img { max-width: 100%; height: auto; display: block; }
input { font: inherit; color: inherit; }

main { max-width: 920px; margin: 0 auto; padding: var(--s-12) var(--s-6) var(--s-18); }

/* ----- logo ----- */
.site-header { text-align: center; padding-top: var(--s-8); }
.logo {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: clamp(28px, 4vw, 40px);
    letter-spacing: -0.005em;
    margin: 0;
    color: var(--ink);
}
.logo__moon { color: var(--gold); margin: 0 var(--s-2); font-weight: 400; }
.logo__word { font-style: italic; }
.logo__sub {
    font-family: var(--font-mark);
    font-size: 10.5px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--gold);
    margin: var(--s-3) 0 var(--s-12);
}
.logo--small { font-size: 24px; }

/* ----- birthday finder ----- */
.birthday-finder {
    display: flex;
    flex-wrap: wrap;
    gap: var(--s-4);
    align-items: baseline;
    justify-content: center;
    margin: 0 auto var(--s-12);
    padding: 0 var(--s-4);
}
.birthday-finder__label {
    display: inline-flex;
    align-items: baseline;
    gap: var(--s-4);
    font-family: var(--font-mark);
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--ink-soft);
}
.birthday-finder__inputs {
    display: inline-flex;
    align-items: baseline;
    gap: var(--s-2);
    font-family: var(--font-body);
    font-style: italic;
    font-size: 22px;
    color: var(--ink);
}
.birthday-finder__inputs::after {
    content: "";
}
.birthday-finder input {
    width: 56px;
    padding: 2px 0 6px;
    border: 0;
    border-bottom: 1px solid var(--rule-strong);
    background: transparent;
    text-align: center;
    font-family: var(--font-body);
    font-style: italic;
    font-size: 22px;
    color: var(--ink);
    letter-spacing: 0.04em;
    -moz-appearance: textfield;
    transition: border-color .2s ease;
}
.birthday-finder input::-webkit-inner-spin-button,
.birthday-finder input::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
.birthday-finder input::placeholder { color: var(--mole-soft); font-style: italic; }
.birthday-finder input:focus { outline: none; border-bottom-color: var(--gold); }
.birthday-finder input[data-bf-year] { width: 84px; }
.birthday-finder input[data-bf-hour],
.birthday-finder input[data-bf-minute] { width: 48px; }
.birthday-finder__sep {
    color: var(--gold);
    font-family: var(--font-body);
    font-style: italic;
}
.birthday-finder__result {
    font-family: var(--font-display);
    font-style: italic;
    font-size: 18px;
    color: var(--gold-dark);
    min-height: 1.3em;
    opacity: 0;
    transform: translateY(2px);
    transition: opacity .25s ease, transform .25s ease;
}
.birthday-finder__result:not(:empty) { opacity: 1; transform: none; }

.birthday-finder__cusp {
    flex-basis: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--s-3);
    margin-top: var(--s-4);
    padding-top: var(--s-4);
    border-top: 1px dashed var(--gold-hairline);
    max-width: 520px;
    margin-left: auto;
    margin-right: auto;
}
.birthday-finder__cusp[hidden] { display: none; }
.birthday-finder__cusp-intro {
    margin: 0;
    font-family: var(--font-mark);
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--ink-soft);
    text-align: center;
}
.birthday-finder__cusp-fields {
    display: inline-flex;
    align-items: baseline;
    gap: var(--s-2);
    font-family: var(--font-body);
    font-style: italic;
    font-size: 22px;
    color: var(--ink);
    flex-wrap: wrap;
    justify-content: center;
}
.birthday-finder__cusp-tz {
    margin-left: var(--s-2);
    font-family: var(--font-mark);
    font-style: normal;
    font-size: 10px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--mole);
    align-self: center;
}
.birthday-finder__cusp-precise {
    margin: 0;
    font-family: var(--font-display);
    font-style: italic;
    font-size: 15px;
    line-height: 1.55;
    color: var(--ink);
    text-align: center;
    min-height: 1.55em;
}

/* ----- sign grid ----- */
.sign-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: var(--s-8) var(--s-4);
    margin-top: var(--s-6);
}
@media (max-width: 768px) {
    .sign-grid { grid-template-columns: repeat(3, 1fr); gap: var(--s-6) var(--s-3); }
}

.sign-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--s-2);
    padding: var(--s-3) var(--s-2) var(--s-4);
    color: var(--ink);
    text-decoration: none;
    position: relative;
    transition: transform .35s cubic-bezier(.2,.7,.2,1);
}
.sign-card:hover {
    transform: translateY(-2px);
    text-decoration: none;
}
.sign-card:hover .sign-card__blob {
    filter: saturate(1.12) contrast(1.04);
}
.sign-card.is-highlighted .sign-card__blob {
    box-shadow:
        0 0 0 4px var(--paper),
        0 0 0 5px var(--gold-hairline);
    animation: ring-in .35s ease both;
}
@keyframes ring-in {
    from { box-shadow: 0 0 0 0 var(--paper), 0 0 0 0 rgba(184, 146, 74, 0); }
    to   { box-shadow: 0 0 0 4px var(--paper), 0 0 0 5px var(--gold-hairline); }
}

.sign-card__blob {
    --blob-w: 104px;
    --blob-h: 118px;
    width: var(--blob-w);
    height: var(--blob-h);
    background: var(--blob, #ccc);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: filter .25s ease, transform .35s cubic-bezier(.2,.7,.2,1);
    overflow: hidden;
}
.sign-card__img { width: 90%; height: 90%; object-fit: contain; display: block; }
.sign-card__name {
    font-family: var(--font-mark);
    font-size: 10.5px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--ink-soft);
    margin-top: var(--s-1);
}
.sign-card__dates {
    font-family: var(--font-body);
    font-style: italic;
    font-size: 13px;
    color: var(--mole);
    margin-top: var(--s-1);
}

.sign-card--hero { padding: var(--s-6) 0 var(--s-4); }
.sign-card--hero .sign-card__blob { --blob-w: 176px; --blob-h: 198px; }
.sign-card--hero .sign-card__name {
    font-family: var(--font-display);
    font-style: italic;
    font-size: 28px;
    letter-spacing: 0;
    text-transform: none;
    color: var(--ink);
    margin-top: var(--s-3);
}

/* ----- sign page ----- */
.sign-page { max-width: 720px; margin: 0 auto; }
.back-link {
    display: inline-block;
    font-family: var(--font-mark);
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--gold-dark);
    text-decoration: none;
    margin-bottom: var(--s-4);
}
.back-link:hover { color: var(--ink); }

.sign-hero { text-align: center; }

.date-label {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--s-4);
    font-family: var(--font-body);
    font-style: italic;
    font-size: 14px;
    color: var(--ink-soft);
    margin: var(--s-2) 0 var(--s-8);
}
.date-label::before, .date-label::after {
    content: "";
    flex: 0 0 64px;
    height: 1px;
    background: var(--rule-strong);
}

.horoscope {
    font-family: var(--font-body);
    font-size: 17px;
    line-height: 1.85;
    color: var(--ink);
    max-width: 540px;
    margin: 0 auto;
}
.horoscope p { margin: 0; }
.horoscope--loading .horoscope__loading-text {
    font-style: italic;
    color: var(--mole);
    text-align: center;
    margin: 0 0 var(--s-4);
}
.horoscope__skeleton {
    display: flex;
    flex-direction: column;
    gap: var(--s-3);
    max-width: 480px;
    margin: 0 auto;
}
.horoscope__skeleton span {
    display: block;
    height: 1px;
    background: var(--rule-strong);
    animation: pulse 1.6s ease-in-out infinite;
}
.horoscope__skeleton span:nth-child(1) { width: 92%; animation-delay: 0s; }
.horoscope__skeleton span:nth-child(2) { width: 80%; animation-delay: .2s; }
.horoscope__skeleton span:nth-child(3) { width: 96%; animation-delay: .4s; }
.horoscope__skeleton span:nth-child(4) { width: 56%; animation-delay: .6s; }
@keyframes pulse {
    0%, 100% { opacity: 0.35; }
    50%      { opacity: 0.85; }
}
.horoscope__error {
    color: var(--ink);
    text-align: center;
    font-style: italic;
}

.tags {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: var(--s-3);
    margin: var(--s-8) auto 0;
    font-family: var(--font-mark);
    font-size: 10.5px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--ink-soft);
}
.tag-pill {
    display: inline-flex;
    align-items: center;
    gap: var(--s-3);
    background: none;
    padding: 0;
    border-radius: 0;
}
.tag-pill + .tag-pill::before {
    content: "·";
    color: var(--gold);
    font-size: 18px;
    line-height: 1;
    margin-right: var(--s-2);
}

.save-line {
    text-align: center;
    margin-top: var(--s-12);
    font-family: var(--font-mark);
    font-size: 12px;
    letter-spacing: 0.06em;
    color: var(--mole);
}
.save-line a { color: var(--gold-dark); }
.save-line a.is-saved { color: var(--ink); text-decoration: none; }

/* ----- saved-sign banner ----- */
.saved-sign-banner {
    margin-bottom: var(--s-8);
    padding: var(--s-3) var(--s-6);
    background: transparent;
    border-top: 1px solid var(--rule-strong);
    border-bottom: 1px solid var(--rule-strong);
    text-align: center;
    font-family: var(--font-mark);
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--ink-soft);
    animation: fade-in .4s ease both;
}
.saved-sign-banner a {
    color: var(--gold-dark);
    text-decoration: none;
    border-bottom: 1px solid var(--gold-hairline);
    padding-bottom: 1px;
}
@keyframes fade-in {
    from { opacity: 0; transform: translateY(-4px); }
    to   { opacity: 1; transform: none; }
}

/* ----- profile-strip på forside ----- */
.profile-strip {
    margin: var(--s-2) auto var(--s-8);
    font-family: var(--font-body);
    font-style: italic;
    font-size: 14px;
    color: var(--ink-soft);
    text-align: center;
}
.profile-strip a { color: var(--ink); text-decoration-color: var(--gold-hairline); }
.profile-strip a:hover { color: var(--gold-dark); }
.profile-strip__edit {
    margin-left: var(--s-3);
    font-family: var(--font-mark);
    font-style: normal;
    font-size: 10px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--mole);
}

.profile-invite-block {
    margin: var(--s-18) auto 0;
    max-width: 560px;
    text-align: center;
    padding: var(--s-8) var(--s-6);
    border-top: 1px solid var(--rule-strong);
    border-bottom: 1px solid var(--rule-strong);
}
.profile-invite-eyebrow {
    font-family: var(--font-mark);
    font-size: 10.5px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--gold);
    margin: 0 0 var(--s-3);
}
.profile-invite-title {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 500;
    font-size: 26px;
    margin: 0 0 var(--s-4);
    color: var(--ink);
}
.profile-invite-text {
    font-family: var(--font-body);
    font-size: 15px;
    line-height: 1.75;
    color: var(--ink-soft);
    margin: 0 0 var(--s-6);
}
.profile-invite-cta {
    display: inline-block;
    font-family: var(--font-mark);
    font-size: 11px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--gold-dark);
    text-decoration: none;
    border-bottom: 1px solid var(--gold-hairline);
    padding: var(--s-1) 0 var(--s-2);
}
.profile-invite-cta:hover { color: var(--ink); border-bottom-color: var(--ink); }

/* ----- profile page ----- */
.profile {
    max-width: 620px;
    margin: 0 auto;
    padding: var(--s-8) var(--s-6) var(--s-18);
}
.profile-header { text-align: center; margin-bottom: var(--s-12); }
.profile-eyebrow {
    font-family: var(--font-mark);
    font-size: 10.5px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--gold);
    margin: 0 0 var(--s-4);
}
.profile-title {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 500;
    font-size: 36px;
    margin: 0 0 var(--s-6);
    color: var(--ink);
    line-height: 1.15;
}
.profile-intro {
    font-family: var(--font-body);
    font-size: 16px;
    line-height: 1.8;
    color: var(--ink-soft);
    max-width: 520px;
    margin: 0 auto var(--s-4);
}
.profile-intro em { color: var(--ink); font-style: italic; }

.big-three {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--s-4);
    margin: 0 auto var(--s-12);
    padding: var(--s-8) 0;
    border-top: 1px solid var(--rule-strong);
    border-bottom: 1px solid var(--rule-strong);
}
@media (max-width: 600px) { .big-three { grid-template-columns: 1fr; gap: var(--s-6); } }
.big-three__card { text-align: center; padding: 0 var(--s-2); }
.big-three__glyph {
    display: block;
    font-family: var(--font-display);
    font-size: 28px;
    color: var(--gold);
    line-height: 1;
    margin-bottom: var(--s-3);
}
.big-three__title {
    font-family: var(--font-mark);
    font-size: 10.5px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    font-weight: 500;
    color: var(--ink);
    margin: 0 0 var(--s-2);
}
.big-three__line {
    font-family: var(--font-display);
    font-style: italic;
    font-size: 18px;
    color: var(--ink);
    margin: 0 0 var(--s-3);
}
.big-three__detail {
    font-family: var(--font-body);
    font-size: 13px;
    line-height: 1.65;
    color: var(--mole);
    margin: 0;
}

.profile-cta-line {
    text-align: center;
    font-family: var(--font-body);
    font-style: italic;
    font-size: 14px;
    color: var(--mole);
    margin: 0 0 var(--s-8);
}

.profile-card__hint {
    display: block;
    font-family: var(--font-body);
    font-style: italic;
    font-size: 12px;
    color: var(--mole);
    margin-top: -2px;
    margin-bottom: var(--s-3);
}
.profile-card__cta {
    display: block;
    font-family: var(--font-mark);
    font-size: 9.5px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--gold);
    margin-top: var(--s-3);
}

.profile-result-hint {
    text-align: center;
    font-family: var(--font-body);
    font-style: italic;
    font-size: 14px;
    line-height: 1.75;
    color: var(--ink-soft);
    max-width: 480px;
    margin: var(--s-6) auto 0;
}

.profile-form { display: grid; gap: var(--s-6); }
.form-line { display: grid; gap: var(--s-2); }
.form-line__label {
    font-family: var(--font-mark);
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--ink-soft);
}
.form-line__hint {
    display: block;
    font-family: var(--font-body);
    font-style: italic;
    font-size: 12px;
    letter-spacing: 0;
    text-transform: none;
    color: var(--mole);
    margin-top: 2px;
}
.profile-form input[type="date"],
.profile-form input[type="time"],
.profile-form input[type="text"],
.profile-form select {
    border: 0;
    border-bottom: 1px solid var(--rule-strong);
    background: transparent;
    padding: var(--s-2) 0 var(--s-3);
    font-family: var(--font-body);
    font-size: 17px;
    color: var(--ink);
    border-radius: 0;
}
.profile-form input:focus, .profile-form select:focus { outline: none; border-bottom-color: var(--gold); }
.profile-form select { background-image: linear-gradient(45deg, transparent 50%, var(--mole) 50%), linear-gradient(135deg, var(--mole) 50%, transparent 50%); background-position: calc(100% - 14px) 50%, calc(100% - 9px) 50%; background-size: 5px 5px; background-repeat: no-repeat; appearance: none; padding-right: 28px; }

.profile-submit {
    appearance: none;
    background: var(--ink);
    color: var(--paper);
    border: 0;
    padding: var(--s-4) var(--s-8);
    font-family: var(--font-mark);
    font-size: 11px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    cursor: pointer;
    transition: background .2s ease, opacity .2s ease;
    justify-self: start;
    margin-top: var(--s-4);
}
.profile-submit:hover { background: #000; }
.profile-submit:disabled { opacity: 0.6; cursor: wait; }

.profile-privacy {
    font-family: var(--font-body);
    font-style: italic;
    font-size: 12px;
    color: var(--mole);
    margin-top: var(--s-2);
}

.profile-result { margin-top: var(--s-12); }
.profile-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--s-6);
    margin: var(--s-4) 0 var(--s-6);
}
@media (max-width: 540px) { .profile-cards { grid-template-columns: 1fr; } }
.profile-card {
    text-align: center;
    padding: var(--s-6) var(--s-3);
    border-top: 1px solid var(--rule-strong);
    border-bottom: 1px solid var(--rule-strong);
}
.profile-card__label {
    display: block;
    font-family: var(--font-mark);
    font-size: 10.5px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--gold);
    margin-bottom: var(--s-3);
}
.profile-card__link {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--s-1);
    text-decoration: none;
    color: var(--ink);
}
.profile-card__name { font-family: var(--font-display); font-style: italic; font-size: 22px; }
.profile-card__symbol { color: var(--gold); font-size: 22px; }

.profile-place {
    text-align: center;
    font-family: var(--font-body);
    font-style: italic;
    font-size: 13px;
    color: var(--mole);
    margin: var(--s-6) 0 0;
}

.about-facts {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--s-3);
    max-width: 540px;
    margin: var(--s-8) auto 0;
    padding: var(--s-4) 0;
    border-top: 1px solid var(--rule-strong);
    border-bottom: 1px solid var(--rule-strong);
    text-align: center;
}
@media (max-width: 540px) { .about-facts { grid-template-columns: repeat(2, 1fr); } }
.about-facts > div { display: flex; flex-direction: column; gap: var(--s-1); }
.about-facts dt {
    font-family: var(--font-mark);
    font-size: 10px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--gold);
}
.about-facts dd {
    margin: 0;
    font-family: var(--font-body);
    font-style: italic;
    font-size: 15px;
    color: var(--ink);
}
.about-section-title {
    font-family: var(--font-mark);
    font-size: 11px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--gold);
    text-align: center;
    margin: 0 0 var(--s-4);
}

.profile-error {
    margin-top: var(--s-6);
    padding: var(--s-3) var(--s-4);
    border-top: 1px solid rgba(176, 58, 46, 0.35);
    border-bottom: 1px solid rgba(176, 58, 46, 0.35);
    color: #8a3024;
    font-family: var(--font-body);
    font-style: italic;
    text-align: center;
}

/* ----- 404 ----- */
.not-found {
    text-align: center;
    padding-top: var(--s-18);
}
.not-found__title {
    font-family: var(--font-display);
    font-style: italic;
    font-size: 26px;
    margin: var(--s-8) 0 var(--s-3);
    color: var(--ink);
}
.not-found__sub {
    color: var(--mole);
    font-style: italic;
    margin-bottom: var(--s-8);
}
