/* tpl/astrology-compatibility-05b8bae4.css — page CSS shared by 1 page(s) of this template.
   Auto-extracted from inline <style> by scripts/refactor_css.py.
   Loaded after components.css; per-page :root{} stays inline. */

body { background: var(--color-base-bg); }
.pg { --r2xl: 24px; --r3xl: 32px; }
.v3-nav { position: sticky; top: 0; z-index: var(--z-header); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); background: color-mix(in srgb, var(--color-base-bg) 80%, transparent); }
.v3-nav__inner { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: var(--space-5); height: 72px; }
.v3-logo { display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-body); font-weight: 700; font-size: 19px; letter-spacing: -0.02em; }
.v3-logo svg { width: 24px; height: 24px; }
.v3-pillnav { display: flex; gap: 2px; justify-self: center; background: var(--color-base-surface); border: 1px solid var(--color-base-border); padding: 4px; border-radius: var(--radius-full); }
.v3-pillnav > a { padding: 8px 16px; border-radius: var(--radius-full); font-size: 13px; font-weight: 500; color: var(--color-text-secondary); transition: background var(--dur-fast), color var(--dur-fast); }
.v3-pillnav > a:hover { color: var(--color-text-primary); background: var(--color-base-bg); }
.v3-pillnav > a[aria-current] { background: var(--section-accent); color: #fff; }
@media (max-width: 1024px) { .v3-pillnav { display: none; } }
.v3-pill { display: inline-flex; align-items: center; gap: 8px; height: 42px; padding: 0 18px; border-radius: var(--radius-full); font-size: 13px; font-weight: 600; transition: transform var(--dur-fast), filter var(--dur-fast); }
.v3-pill:active { transform: scale(0.97); }
.v3-pill--solid { background: var(--section-accent); color: #fff; }
.v3-pill--solid:hover { filter: brightness(0.94); }
.v3-pill--ghost { background: transparent; border: 1px solid var(--color-base-border-strong); color: var(--color-text-primary); }
.v3-nav__cta { display: flex; align-items: center; gap: var(--space-2); }
.h-hero { padding: var(--space-8) 0 var(--space-5); text-align:center; max-width: 720px; margin: 0 auto; }
.h-hero__title { font-family: var(--font-display); font-weight: 500; font-size: clamp(40px, 6vw, 64px); line-height: 1.02; letter-spacing: -0.02em; margin-top: var(--space-3); }
.h-hero__sub { margin-top: var(--space-4); font-size: 18px; line-height: 1.5; color: var(--color-text-secondary); }
.matrix-wrap { overflow-x: auto; padding-bottom: var(--space-9); }
table.matrix { border-collapse: separate; border-spacing: 4px; margin: var(--space-6) auto 0; }
table.matrix th { font-family: "Cormorant Garamond", serif; font-size: 22px; color: var(--section-accent); font-weight: 600; width: 40px; height: 40px; text-align: center; }
table.matrix th.corner { font-size: 11px; font-family: var(--font-body); color: var(--color-text-tertiary); text-transform: uppercase; letter-spacing: 0.06em; }
table.matrix td { padding: 0; }
table.matrix a {
      --c: #C9A53C;
      display: grid; place-items: center; width: 40px; height: 40px; border-radius: 10px;
      font-size: 12px; font-weight: 700; color: #fff; text-decoration: none;
      background:
        radial-gradient(120% 115% at 30% 18%, rgba(255,255,255,0.5), rgba(255,255,255,0) 48%),
        linear-gradient(155deg, color-mix(in srgb, var(--c) 78%, #fff), var(--c) 55%, color-mix(in srgb, var(--c) 72%, #000) 100%);
      box-shadow:
        0 1px 0 rgba(255,255,255,0.55) inset,
        0 -6px 10px color-mix(in srgb, var(--c) 50%, #000 8%) inset,
        0 4px 10px color-mix(in srgb, var(--c) 32%, transparent);
      text-shadow: 0 1px 2px color-mix(in srgb, var(--c) 55%, #000 35%);
      transition: transform var(--dur-fast), box-shadow var(--dur-fast);
    }
table.matrix a:hover {
      transform: scale(1.16) translateY(-1px);
      box-shadow:
        0 1px 0 rgba(255,255,255,0.6) inset,
        0 -6px 10px color-mix(in srgb, var(--c) 50%, #000 8%) inset,
        0 8px 18px color-mix(in srgb, var(--c) 45%, transparent);
      z-index: 2; position: relative;
    }
table.matrix a.sc5 { --c:#2F8C57; }
table.matrix a.sc4 { --c:#6FA756; }
table.matrix a.sc3 { --c:#C9A53C; }
table.matrix a.sc2 { --c:#CB7A3A; }
table.matrix a.sc1 { --c:#C0485A; }
.legend { display:flex; flex-wrap:wrap; gap: var(--space-3); justify-content:center; margin-top: var(--space-6); font-size: 13px; color: var(--color-text-secondary); }
.legend span { display:inline-flex; align-items:center; gap:7px; }
.legend i { width:14px; height:14px; border-radius:4px; }
.sign-jump { display:flex; flex-wrap:wrap; gap: var(--space-2); justify-content:center; margin-top: var(--space-6); }
.sign-jump a { display:inline-flex; align-items:center; gap:6px; padding: 6px 14px; border-radius: var(--radius-full); border:1px solid var(--color-base-border); font-size: 13px; font-weight:600; color: var(--color-text-primary); }
.sign-jump a:hover { border-color: var(--section-accent); color: var(--section-accent); }
.matrix-layout { display: flex; gap: var(--space-7); align-items: flex-start; justify-content: center; flex-wrap: wrap; }
.matrix-layout .matrix-wrap { padding-bottom: 0; }
.sign-key { display: grid; gap: 6px; align-content: start; min-width: 248px; max-width: 300px; margin-top: var(--space-6); }
.sign-key__head { font-family: var(--font-body); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--color-text-tertiary); margin-bottom: 2px; }
.sign-key a {
      display: grid; grid-template-columns: 34px 1fr auto; align-items: center; gap: 11px;
      padding: 7px 12px 7px 7px; border-radius: 12px; border: 1px solid var(--color-base-border);
      background: var(--color-base-surface); text-decoration: none; transition: border-color var(--dur-fast), transform var(--dur-fast), box-shadow var(--dur-fast);
    }
.sign-key a:hover { border-color: color-mix(in srgb, var(--section-accent) 50%, var(--color-base-border)); transform: translateX(2px); box-shadow: 0 4px 12px color-mix(in srgb, var(--section-accent) 12%, transparent); }
.sign-key__glyph {
      --c: var(--section-accent);
      width: 34px; height: 34px; border-radius: 10px; display: grid; place-items: center;
      font-size: 19px; color: #fff;
      background:
        radial-gradient(120% 115% at 30% 18%, rgba(255,255,255,0.5), rgba(255,255,255,0) 48%),
        linear-gradient(155deg, color-mix(in srgb, var(--c) 78%, #fff), var(--c) 55%, color-mix(in srgb, var(--c) 72%, #000) 100%);
      box-shadow: 0 1px 0 rgba(255,255,255,0.55) inset, 0 -5px 9px color-mix(in srgb, var(--c) 50%, #000 8%) inset, 0 3px 8px color-mix(in srgb, var(--c) 30%, transparent);
      text-shadow: 0 1px 2px color-mix(in srgb, var(--c) 55%, #000 35%);
    }
.sign-key__name { font-family: var(--font-body); font-weight: 600; font-size: 14px; color: var(--color-text-primary); line-height: 1.2; }
.sign-key__name small { display: block; font-weight: 500; font-size: 11px; color: var(--color-text-tertiary); margin-top: 1px; }
.sign-key__el { font-size: 11px; font-weight: 600; letter-spacing: 0.03em; text-transform: uppercase; padding: 3px 8px; border-radius: var(--radius-full); }
.sign-key__el.fire  { color:#B5532B; background: color-mix(in srgb,#B5532B 12%, transparent); }
.sign-key__el.earth { color:#6B6027; background: color-mix(in srgb,#8A7B2E 14%, transparent); }
.sign-key__el.air   { color:#3F6F88; background: color-mix(in srgb,#3F6F88 12%, transparent); }
.sign-key__el.water { color:#2F7A66; background: color-mix(in srgb,#2F7A66 12%, transparent); }
@media (max-width: 980px) { .sign-key { margin-top: var(--space-4); grid-template-columns: 1fr 1fr; gap: 8px; max-width: 560px; }
      .sign-key__head { grid-column: 1 / -1; } }
@media (max-width: 560px) { .sign-key { grid-template-columns: 1fr; } }
