:root {
    --bg: #f8f4ef;
    --panel: #fffdfa;
    --line: #e4dace;
    --text: #3a2f26;
    --muted: #7a6b5d;
    --accent: #ad7d52;
    --color-go: #E8819B;
    --color-prepare: #9B7EBD;
    --color-wait: #7B95B5;
    --color-today-border: #5D2E5D;
    --color-today-bg: #FFF5F8;
    --color-dice-dot: #E8819B;
    --calendar-past-opacity: 0.55;
    --calendar-future-opacity: 0.25;
}

* {
    box-sizing: border-box;
}

body {
    margin: 0;
    font-family: "Yu Mincho", "Hiragino Mincho ProN", serif;
    font-size: 16px;
    line-height: 1.6;
    background: linear-gradient(180deg, #fcfaf7 0%, var(--bg) 100%);
    color: var(--text);
}

.members-shell {
    max-width: 960px;
    margin: 0 auto;
    padding: 20px 16px 40px;
}

.members-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 0;
    border-bottom: 1px solid var(--line);
}

.members-brand {
    display: flex;
    align-items: center;
    gap: 10px;
}

.members-brand img {
    width: 40px;
    height: 40px;
    border-radius: 8px;
    border: 1px solid var(--line);
}

.members-brand-name {
    font-size: 18px;
    letter-spacing: 0.04em;
}

.members-header-actions {
    display: flex;
    align-items: center;
    gap: 10px;
}

.members-main {
    margin-top: 22px;
}

.members-card {
    background: var(--panel);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 24px;
    box-shadow: 0 8px 20px rgba(122, 107, 93, 0.08);
}

.members-card h1 {
    margin: 0 0 10px;
    font-size: 24px;
    font-weight: 600;
}

.members-card p {
    margin: 0;
    line-height: 1.8;
    color: var(--muted);
}

.members-logout {
    margin: 0;
}

.members-logout button {
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #ffffff;
    color: var(--text);
    padding: 8px 14px;
    min-height: 44px;
    font-size: 16px;
    cursor: pointer;
}

.members-top-nav {
    display: flex;
    align-items: center;
    gap: 8px;
}

.members-top-nav a {
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #ffffff;
    color: #5f4a37;
    min-height: 44px;
    padding: 10px 14px;
    display: inline-flex;
    align-items: center;
    text-decoration: none;
    font-size: 16px;
}

.members-mobile-menu {
    display: none;
    position: relative;
}

.members-mobile-menu > summary {
    list-style: none;
    border: 1px solid var(--line);
    border-radius: 10px;
    min-height: 44px;
    padding: 10px 14px;
    background: #ffffff;
    color: var(--text);
    font-size: 16px;
    cursor: pointer;
}

.members-mobile-menu > summary::-webkit-details-marker {
    display: none;
}

.members-mobile-menu-panel {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    width: 220px;
    z-index: 10;
    background: var(--panel);
    border: 1px solid var(--line);
    border-radius: 12px;
    box-shadow: 0 8px 20px rgba(122, 107, 93, 0.12);
    padding: 8px;
    display: grid;
    gap: 6px;
}

.members-mobile-menu-panel a {
    min-height: 44px;
    border-radius: 8px;
    padding: 10px 12px;
    display: inline-flex;
    align-items: center;
    text-decoration: none;
    color: #5f4a37;
    border: 1px solid #efe4d8;
    background: #ffffff;
}

.members-login-card {
    background: var(--panel);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 20px 16px;
    max-width: 420px;
    margin: 0 auto;
    box-shadow: 0 8px 20px rgba(122, 107, 93, 0.08);
}

.members-login-title {
    margin: 0;
    font-size: 24px;
    line-height: 1.3;
}

.members-support-text {
    margin: 14px 0 0;
    color: var(--muted);
    font-size: 15px;
    line-height: 1.8;
}

.members-error-banner {
    margin-top: 16px;
    padding: 12px;
    border-radius: 10px;
    background: #fcebec;
    border: 1px solid #e07a7f;
    color: #8b1d23;
    font-size: 16px;
    line-height: 1.5;
}

.members-line-btn {
    margin-top: 18px;
    width: 100%;
    min-height: 48px;
    border: 1px solid #06a74f;
    border-radius: 10px;
    background: #06c755;
    color: #ffffff;
    font-size: 17px;
    font-weight: 700;
    cursor: pointer;
}

.members-line-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.members-divider {
    margin: 16px 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    color: var(--muted);
    font-size: 16px;
}

.members-divider::before,
.members-divider::after {
    content: "";
    height: 1px;
    flex: 1;
    background: var(--line);
}

.members-login-form {
    display: grid;
    gap: 10px;
}

.members-field-label {
    font-size: 16px;
    line-height: 1.4;
}

.members-login-form input {
    width: 100%;
    min-height: 44px;
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 10px 12px;
    font-size: 16px;
    color: var(--text);
    background: #ffffff;
}

.members-login-submit {
    margin-top: 8px;
    width: 100%;
    min-height: 48px;
    border: 1px solid #8a6340;
    border-radius: 10px;
    background: var(--accent);
    color: #ffffff;
    font-size: 17px;
    font-weight: 700;
    cursor: pointer;
}

.members-login-links {
    margin-top: 14px;
    display: grid;
    gap: 8px;
}

.members-login-links a {
    color: #6b4e34;
    font-size: 16px;
    line-height: 1.5;
    text-underline-offset: 2px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
}

.members-help-text {
    margin: 0;
    font-size: 14px;
    color: #b3473b;
}

.members-action-wrap {
    margin-top: 16px;
}

.members-button-link {
    width: 100%;
    min-height: 48px;
    border: 1px solid #8a6340;
    border-radius: 10px;
    background: var(--accent);
    color: #ffffff;
    font-size: 17px;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
}

.members-dashboard-greeting {
    margin-bottom: 18px;
    padding: 18px;
    border-radius: 14px;
    border: 1px solid var(--line);
    background: #fffdf9;
}

.members-dashboard-greeting h1 {
    margin: 0;
    font-size: 28px;
    line-height: 1.4;
}

.members-dashboard-greeting p {
    margin: 10px 0 0;
    font-size: 16px;
    color: var(--muted);
}

.members-dashboard-hero {
    margin-bottom: 16px;
    padding: 18px;
    border-radius: 14px;
    border: 1px solid var(--line);
    background: #fffdf9;
}

.members-dashboard-hero h1 {
    margin: 0;
    font-size: 28px;
    line-height: 1.4;
}

.members-dashboard-hero p {
    margin: 10px 0 0;
    font-size: 16px;
    color: #5f4a37;
    line-height: 1.6;
}

.members-dashboard-panel {
    border-radius: 14px;
    border: 1px solid var(--line);
    background: #ffffff;
    padding: 20px 18px;
    display: grid;
    gap: 12px;
}

.members-dashboard-message {
    margin: 0;
    font-size: 16px;
    line-height: 1.7;
    color: #2a2018;
}

.members-dashboard-action {
    margin-top: 4px;
    min-height: 48px;
    border: 1px solid #8a6340;
    border-radius: 10px;
    background: var(--accent);
    color: #ffffff;
    font-size: 17px;
    font-weight: 700;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
}

.members-feature-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.members-feature-card {
    min-height: 88px;
    border-radius: 14px;
    border: 1px solid var(--line);
    background: var(--panel);
    color: var(--text);
    text-decoration: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 18px;
    font-size: 17px;
    font-weight: 700;
    box-shadow: 0 8px 20px rgba(122, 107, 93, 0.08);
    width: 100%;
    font-family: inherit;
    cursor: pointer;
}

.members-feature-arrow {
    color: #9f7a55;
}

.members-feature-main-label {
    flex: 1;
    text-align: left;
}

.members-feature-card-disabled,
.members-feature-card-disabled:disabled {
    color: #6f6f6f;
    border-color: #d4d4d4;
    background: #f3f3f3;
    box-shadow: none;
    cursor: not-allowed;
}

.members-feature-badge {
    margin-left: 8px;
    min-height: 30px;
    padding: 6px 10px;
    border-radius: 999px;
    border: 1px solid #c7c7c7;
    background: #ffffff;
    color: #595959;
    font-size: 16px;
    display: inline-flex;
    align-items: center;
}

.members-dashboard-footer {
    margin-top: 18px;
    border-top: 1px solid var(--line);
    padding-top: 14px;
}

.members-footer-links {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.members-footer-links form {
    margin: 0;
}

.members-footer-link,
.members-footer-links button {
    min-height: 44px;
    padding: 10px 14px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #ffffff;
    color: #5f4a37;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    font-size: 16px;
    cursor: pointer;
}

.members-powered {
    margin: 12px 0 0;
    color: var(--muted);
    font-size: 16px;
}

.members-signup-card {
    background: var(--panel);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 20px 18px;
    box-shadow: 0 8px 20px rgba(122, 107, 93, 0.08);
    max-width: 560px;
    margin: 0 auto;
}

.members-signup-title {
    margin: 0;
    font-size: 28px;
    line-height: 1.35;
}

.members-signup-subtitle {
    margin: 12px 0 0;
    font-size: 17px;
    color: var(--muted);
}

.members-offer {
    margin-top: 16px;
    border-radius: 12px;
    border: 1px solid #ecd8c4;
    background: #fff7ed;
    padding: 14px;
}

.members-offer-label {
    margin: 0;
    font-size: 16px;
    color: #7c5d3e;
}

.members-offer-price {
    margin: 6px 0 0;
    font-size: 34px;
    font-weight: 700;
    line-height: 1.2;
    color: #7b4f2b;
}

.members-signup-list {
    margin: 18px 0 0;
    padding-left: 20px;
    color: #5f4a37;
    font-size: 16px;
    line-height: 1.8;
}

.members-signup-cta {
    margin-top: 18px;
    width: 100%;
    min-height: 48px;
    border: 1px solid #8a6340;
    border-radius: 10px;
    background: var(--accent);
    color: #ffffff;
    font-size: 17px;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
}

.members-signup-links {
    margin-top: 14px;
    display: grid;
    gap: 8px;
}

.members-signup-links a {
    color: #6b4e34;
    font-size: 16px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
}

.lp-body {
    min-height: 100vh;
    background:
        radial-gradient(circle at top right, #fff2d9 0%, rgba(255, 242, 217, 0) 48%),
        linear-gradient(180deg, #fff8ee 0%, #f6ede3 100%);
}

.lp-shell {
    max-width: 980px;
    margin: 0 auto;
    padding: 20px 16px 36px;
}

.lp-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 0 18px;
}

.lp-brand-wrap {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}

.lp-logo {
    width: 42px;
    height: 42px;
    border-radius: 10px;
    border: 1px solid #e7d4bd;
    object-fit: cover;
}

.lp-brand {
    margin: 0;
    font-size: 18px;
    color: #5f4a37;
}

.lp-main {
    display: grid;
    gap: 16px;
}

.lp-hero {
    border: 1px solid #e8d6c1;
    border-radius: 16px;
    background: #fffdf9;
    box-shadow: 0 12px 24px rgba(122, 107, 93, 0.1);
    padding: 22px 20px;
    display: grid;
    gap: 16px;
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr);
    align-items: center;
}

.lp-title {
    margin: 0;
    font-size: 38px;
    line-height: 1.25;
}

.lp-subtitle {
    margin: 10px 0 0;
    font-size: 20px;
    color: #6a5847;
    line-height: 1.6;
}

.lp-offer {
    margin-top: 14px;
    border-radius: 12px;
    border: 1px solid #e4c59f;
    background: #fff0d9;
    padding: 10px 12px;
    font-size: 20px;
    line-height: 1.5;
    color: #6d4624;
    font-weight: 700;
}

.lp-cta-form {
    margin-top: 14px;
}

.lp-cta-button {
    width: 100%;
    min-height: 52px;
    border: 1px solid #85471f;
    border-radius: 12px;
    background: linear-gradient(180deg, #d28239 0%, #b6651d 100%);
    color: #ffffff;
    font-size: 20px;
    font-weight: 700;
    cursor: pointer;
}

.lp-hero-visual {
    min-height: 220px;
    border: 2px dashed #d9c2a7;
    border-radius: 12px;
    background: repeating-linear-gradient(
        -45deg,
        #fcf2e7,
        #fcf2e7 12px,
        #fff9f1 12px,
        #fff9f1 24px
    );
    color: #846a52;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    line-height: 1.5;
}

.lp-hero-visual small {
    font-size: 16px;
}

.lp-features {
    border: 1px solid #e8d6c1;
    border-radius: 14px;
    background: #fffdf9;
    padding: 18px;
}

.lp-features h2 {
    margin: 0;
    font-size: 26px;
}

.lp-feature-list {
    list-style: none;
    padding: 0;
    margin: 14px 0 0;
    display: grid;
    gap: 10px;
}

.lp-feature-card {
    border: 1px solid #eadccc;
    border-radius: 10px;
    background: #ffffff;
    min-height: 56px;
    padding: 12px;
    display: flex;
    align-items: center;
    font-size: 18px;
    color: #493727;
}

.lp-footer {
    margin-top: 16px;
    border-top: 1px solid #ddccb9;
    padding-top: 12px;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.lp-footer a {
    color: #6d5238;
    font-size: 16px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
}

.members-onboarding-card {
    background: var(--panel);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 20px 18px;
    box-shadow: 0 8px 20px rgba(122, 107, 93, 0.08);
    max-width: 640px;
    margin: 0 auto;
}

.members-onboarding-step {
    margin: 0;
    font-size: 16px;
    font-weight: 700;
    color: #7a5c3f;
}

.members-onboarding-title {
    margin: 6px 0 0;
    font-size: 30px;
    line-height: 1.35;
}

.members-onboarding-description {
    margin: 10px 0 0;
    font-size: 17px;
    line-height: 1.7;
    color: var(--muted);
}

.members-onboarding-form {
    margin-top: 16px;
    display: grid;
    gap: 14px;
}

.members-onboarding-fieldset {
    border: 1px solid #e8d9c8;
    border-radius: 12px;
    padding: 12px;
    margin: 0;
}

.members-onboarding-fieldset legend {
    font-size: 18px;
    font-weight: 700;
    color: #5b4531;
    padding: 0 4px;
}

.members-onboarding-select-row {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.members-onboarding-time-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.members-onboarding-select-row label {
    display: grid;
    gap: 6px;
}

.members-onboarding-select {
    width: 100%;
    min-height: 50px;
    border: 1px solid #d8c5af;
    border-radius: 10px;
    padding: 10px 12px;
    font-size: 18px;
    color: var(--text);
    background: #ffffff;
}

.members-onboarding-select:disabled {
    color: #8a8a8a;
    background: #f0f0f0;
}

.members-onboarding-check {
    margin-top: 10px;
    border: 1px solid #e2d2bf;
    border-radius: 10px;
    padding: 10px 12px;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: #fffaf4;
    font-size: 18px;
}

.members-onboarding-check input {
    width: 22px;
    height: 22px;
    margin: 0;
    accent-color: #9f6840;
}

.members-onboarding-submit {
    margin-top: 2px;
    width: 100%;
    min-height: 52px;
    border: 1px solid #8a6340;
    border-radius: 10px;
    background: var(--accent);
    color: #ffffff;
    font-size: 20px;
    font-weight: 700;
    cursor: pointer;
}

.members-partner-setup-card {
    background: var(--panel);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 20px 18px;
    box-shadow: 0 8px 20px rgba(122, 107, 93, 0.08);
    max-width: 680px;
    margin: 0 auto;
}

.members-partner-setup-step {
    margin: 0;
    font-size: 16px;
    font-weight: 700;
    color: #7a5c3f;
}

.members-partner-setup-title {
    margin: 6px 0 0;
    font-size: 30px;
    line-height: 1.35;
}

.members-partner-setup-description {
    margin: 10px 0 0;
    font-size: 17px;
    line-height: 1.7;
    color: var(--muted);
}

.members-partner-setup-form {
    margin-top: 16px;
    display: grid;
    gap: 14px;
}

.members-partner-setup-fieldset {
    border: 1px solid #e8d9c8;
    border-radius: 12px;
    padding: 12px;
    margin: 0;
}

.members-partner-setup-fieldset legend {
    font-size: 18px;
    font-weight: 700;
    color: #5b4531;
    padding: 0 4px;
}

.members-partner-setup-inline-fields {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.members-partner-setup-inline-fields label,
.members-partner-setup-time-wrap label {
    display: grid;
    gap: 6px;
}

.members-partner-setup-input {
    width: 100%;
    min-height: 50px;
    border: 1px solid #d8c5af;
    border-radius: 10px;
    padding: 10px 12px;
    font-size: 18px;
    color: var(--text);
    background: #ffffff;
}

.members-partner-setup-input:disabled {
    color: #8a8a8a;
    background: #f0f0f0;
}

.members-partner-setup-radio-row {
    display: grid;
    gap: 10px;
}

.members-partner-setup-radio-item {
    min-height: 48px;
    border: 1px solid #e2d2bf;
    border-radius: 10px;
    padding: 10px 12px;
    display: flex;
    align-items: center;
    gap: 10px;
    background: #fffaf4;
    font-size: 18px;
    line-height: 1.4;
}

.members-partner-setup-radio-item input {
    width: 22px;
    height: 22px;
    margin: 0;
    accent-color: #9f6840;
}

.members-partner-setup-check {
    min-height: 48px;
    margin-top: 2px;
    border: 1px solid #e2d2bf;
    border-radius: 10px;
    padding: 10px 12px;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: #fffaf4;
    font-size: 18px;
}

.members-partner-setup-check input {
    width: 22px;
    height: 22px;
    margin: 0;
    accent-color: #9f6840;
}

.members-partner-setup-time-wrap {
    margin-top: 10px;
}

.members-partner-setup-submit {
    margin-top: 2px;
    width: 100%;
    min-height: 52px;
    border: 1px solid #8a6340;
    border-radius: 10px;
    background: var(--accent);
    color: #ffffff;
    font-size: 20px;
    font-weight: 700;
    cursor: pointer;
}

.members-partner-setup-submit:disabled {
    opacity: 0.75;
    cursor: not-allowed;
}

.members-partner-setup-loading {
    margin: 0;
    font-size: 16px;
    color: #5f4a37;
}

.members-access-card {
    background: var(--panel);
    border: 1px solid #dfc7c8;
    border-radius: 14px;
    padding: 20px 18px;
    max-width: 560px;
    margin: 0 auto;
    box-shadow: 0 8px 20px rgba(122, 107, 93, 0.08);
}

.members-access-card h1 {
    margin: 0;
    font-size: 24px;
}

.members-access-card p {
    margin: 12px 0 0;
    font-size: 16px;
    color: #6d4a4d;
    line-height: 1.8;
}

.members-access-actions {
    margin-top: 18px;
    display: grid;
    gap: 8px;
}

.members-access-actions a {
    min-height: 44px;
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 10px 14px;
    text-decoration: none;
    color: #5f4a37;
    display: inline-flex;
    align-items: center;
    background: #ffffff;
    font-size: 16px;
}

.members-contact-card,
.members-contact-history,
.members-contact-detail {
    background: var(--panel);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 18px;
    box-shadow: 0 8px 20px rgba(122, 107, 93, 0.08);
}

.members-contact-history,
.members-contact-detail {
    margin-top: 14px;
}

.members-contact-title {
    margin: 0;
    font-size: 24px;
    line-height: 1.4;
}

.members-contact-form {
    margin-top: 14px;
    display: grid;
    gap: 10px;
}

.members-contact-form input,
.members-contact-form textarea {
    width: 100%;
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 10px 12px;
    font-size: 16px;
    color: var(--text);
    background: #ffffff;
    min-height: 44px;
}

.members-contact-form textarea {
    min-height: 150px;
    resize: vertical;
}

.members-contact-submit {
    margin-top: 6px;
    width: 100%;
    min-height: 48px;
    border: 1px solid #8a6340;
    border-radius: 10px;
    background: var(--accent);
    color: #ffffff;
    font-size: 17px;
    font-weight: 700;
    cursor: pointer;
}

.members-contact-history h2 {
    margin: 0;
    font-size: 20px;
}

.members-contact-history-list {
    margin: 14px 0 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 8px;
}

.members-contact-history-list li a {
    text-decoration: none;
    border: 1px solid #efe4d8;
    border-radius: 10px;
    background: #ffffff;
    padding: 10px 12px;
    display: grid;
    gap: 4px;
    min-height: 44px;
}

.members-contact-history-subject {
    color: var(--text);
    font-size: 16px;
    line-height: 1.4;
}

.members-contact-history-meta {
    color: var(--muted);
    font-size: 14px;
}

.members-contact-empty {
    margin: 12px 0 0;
    color: var(--muted);
    font-size: 16px;
}

.members-contact-detail-summary {
    margin-top: 12px;
    border: 1px solid #efe4d8;
    border-radius: 10px;
    padding: 10px 12px;
    background: #fffdfa;
}

.members-contact-detail-subject {
    margin: 0;
    font-size: 18px;
}

.members-contact-detail-meta {
    margin: 6px 0 0;
    color: var(--muted);
    font-size: 14px;
}

.members-contact-thread {
    margin: 14px 0 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 8px;
}

.members-contact-thread-item {
    border: 1px solid #efe4d8;
    border-radius: 10px;
    padding: 10px 12px;
    background: #ffffff;
}

.members-contact-thread-meta {
    margin: 0;
    color: var(--muted);
    font-size: 14px;
}

.members-contact-thread-body {
    margin: 8px 0 0;
    color: var(--text);
    font-size: 16px;
    line-height: 1.7;
}

.members-calendar-page {
    display: grid;
    gap: 14px;
}

.members-calendar-header {
    border: 1px solid var(--line);
    border-radius: 14px;
    background: #fffdf9;
    padding: 16px;
}

.members-calendar-header h1 {
    margin: 0;
    font-size: 28px;
    line-height: 1.4;
}

.members-calendar-header p {
    margin: 8px 0 0;
    font-size: 16px;
    color: var(--muted);
}

.members-calendar-board {
    background: var(--panel);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 14px;
    box-shadow: 0 8px 20px rgba(122, 107, 93, 0.08);
}

.members-calendar-swipe-help {
    margin: 10px 0 0;
    font-size: 16px;
    color: #4c3b2f;
}

.members-calendar-controls {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    align-items: center;
    gap: 8px;
}

.members-calendar-nav-btn {
    min-height: 48px;
    border-radius: 10px;
    border: 1px solid #9a7a58;
    background: #fff8f0;
    color: #4e3722;
    font-size: 16px;
    font-family: inherit;
    font-weight: 700;
    cursor: pointer;
}

.members-calendar-nav-btn:last-child {
    justify-self: end;
}

.members-calendar-month-label {
    margin: 0;
    font-size: 22px;
    font-weight: 700;
}

.members-calendar-legend {
    margin: 12px 0 0;
    padding: 0;
    list-style: none;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    font-size: 16px;
}

.members-calendar-legend li {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: #4e3e2e;
}

.members-calendar-legend-dot {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    border: 1px solid rgba(0, 0, 0, 0.15);
}

.members-calendar-legend-dot.members-calendar-status-go {
    background: var(--color-go);
}

.members-calendar-legend-dot.members-calendar-status-prepare {
    background: var(--color-prepare);
}

.members-calendar-legend-dot.members-calendar-status-wait {
    background: var(--color-wait);
}

.members-calendar-weekdays {
    margin-top: 12px;
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 6px;
    font-size: 16px;
    font-weight: 700;
    color: #4f3d2a;
}

.members-calendar-weekdays span {
    text-align: center;
    line-height: 1.4;
}

.members-calendar-grid {
    margin-top: 8px;
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 6px;
}

.members-calendar-error {
    margin-top: 12px;
    border-radius: 10px;
    border: 1px solid #d78289;
    background: #fbeaed;
    color: #7f2128;
    font-size: 16px;
    line-height: 1.5;
    padding: 10px 12px;
}

.members-calendar-cell {
    min-height: 120px;
    border-radius: 10px;
    border: 1px solid #d8d2c8;
    background: #ffffff;
    color: #2f2f2f;
    padding: 8px 6px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    text-align: left;
    font-family: inherit;
    font-size: 16px;
    line-height: 1.2;
    cursor: pointer;
}

.members-calendar-cell:focus-visible,
.members-calendar-nav-btn:focus-visible,
.members-calendar-modal-close:focus-visible,
.members-calendar-detail-dice-button:focus-visible {
    outline: 3px solid #6f4a2f;
    outline-offset: 2px;
}

.members-calendar-cell-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 4px;
}

.members-calendar-marker-wrap {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 4px;
    min-height: 12px;
}

.members-calendar-day-number {
    font-weight: 700;
    color: #3c2f24;
}

.members-calendar-dice-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--color-dice-dot);
}

.members-calendar-forecast-marker {
    min-width: 16px;
    min-height: 16px;
    border-radius: 999px;
    border: 1px solid #8768ab;
    background: #f3ecfb;
    color: #4d3370;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.members-calendar-cell-score,
.members-calendar-cell-label {
    margin: 0;
    font-size: 16px;
    color: #3f3125;
}

.members-calendar-cell-label {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.members-calendar-status-pill {
    min-height: 24px;
    border-radius: 999px;
    border: 1px solid transparent;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    padding: 2px 8px;
    font-size: 16px;
    font-weight: 700;
    color: #ffffff;
    background: #eceff2;
}

.members-calendar-cell.members-calendar-status-go {
    background: #fce8ee;
    border-color: #efb5c5;
}

.members-calendar-cell.members-calendar-status-prepare {
    background: #f1ecf7;
    border-color: #cab6e0;
}

.members-calendar-cell.members-calendar-status-wait {
    background: #eaf0f6;
    border-color: #bfd0e2;
}

.members-calendar-status-pill.members-calendar-status-go {
    background: var(--color-go);
    border-color: #cf6e88;
}

.members-calendar-status-pill.members-calendar-status-prepare {
    background: var(--color-prepare);
    border-color: #7f64a0;
}

.members-calendar-status-pill.members-calendar-status-wait {
    background: var(--color-wait);
    border-color: #637c9a;
}

.members-calendar-cell.is-today {
    border-width: 2px;
    border-color: var(--color-today-border);
    box-shadow: inset 0 0 0 2px rgba(93, 46, 93, 0.22);
    background: var(--color-today-bg);
}

.members-calendar-cell.is-past {
    opacity: var(--calendar-past-opacity);
}

.members-calendar-cell.is-outside-month {
    opacity: 0.52;
}

.members-calendar-cell.is-future-locked,
.members-calendar-cell.is-future-locked:disabled {
    opacity: var(--calendar-future-opacity);
    border-color: #d4d6dd;
    background: #eceef2;
    color: #6f7580;
    filter: grayscale(1);
    cursor: not-allowed;
}

.members-calendar-cell-skeleton {
    pointer-events: none;
    border-color: #e6dfd4;
    background:
        linear-gradient(90deg, #f7f3ee 0%, #fffaf3 45%, #f7f3ee 100%);
    background-size: 200% 100%;
    animation: members-calendar-shimmer 1.1s infinite linear;
}

.members-calendar-modal[hidden] {
    display: none;
}

.members-calendar-modal {
    position: fixed;
    inset: 0;
    z-index: 100;
}

.members-calendar-modal-backdrop {
    position: absolute;
    inset: 0;
    width: 100%;
    border: 0;
    padding: 0;
    margin: 0;
    background: rgba(40, 31, 23, 0.5);
    cursor: pointer;
}

.members-calendar-modal-panel {
    position: relative;
    margin: 40px auto 0;
    max-width: 560px;
    width: calc(100% - 24px);
    max-height: calc(100vh - 80px);
    overflow-y: auto;
    background: #fffdfa;
    border: 1px solid #ddcfbf;
    border-radius: 14px;
    box-shadow: 0 20px 42px rgba(0, 0, 0, 0.22);
    z-index: 1;
}

.members-calendar-modal-header {
    padding: 12px 14px;
    border-bottom: 1px solid #eadfcf;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.members-calendar-modal-header h2 {
    margin: 0;
    font-size: 22px;
}

.members-calendar-modal-close {
    min-width: 48px;
    min-height: 48px;
    border: 1px solid #ccb89f;
    border-radius: 10px;
    background: #fff8ef;
    color: #4a3422;
    font-size: 26px;
    line-height: 1;
    cursor: pointer;
}

.members-calendar-detail-body {
    padding: 14px;
}

.members-calendar-detail-body.is-loading {
    opacity: 0.65;
}

.members-calendar-detail-heading {
    margin: 0;
    font-size: 24px;
    font-weight: 700;
    color: #3f2c1c;
    line-height: 1.45;
}

.members-calendar-detail-score {
    margin: 10px 0 0;
    font-size: 16px;
    color: #2f2641;
    font-weight: 700;
}

.members-calendar-detail-main {
    margin-top: 14px;
    border-radius: 10px;
    border: 1px solid #eadfcf;
    background: #fffdf8;
    padding: 12px;
}

.members-calendar-detail-main p {
    margin: 0;
    font-size: 16px;
    color: #3f3125;
    line-height: 1.8;
}

.members-calendar-detail-separator {
    margin: 14px 0;
    border: 0;
    border-top: 1px solid #e7dbca;
}

.members-calendar-detail-block {
    margin-top: 12px;
    border: 1px solid #eadfcf;
    border-radius: 10px;
    padding: 10px;
    background: #fffdf8;
}

.members-calendar-detail-block h3 {
    margin: 0;
    font-size: 18px;
    color: #493725;
}

.members-calendar-detail-block p {
    margin: 8px 0 0;
    font-size: 16px;
    color: #3f3125;
    line-height: 1.6;
}

.members-calendar-detail-closing {
    margin: 14px 0 0;
    font-size: 17px;
    line-height: 1.7;
    color: #3f2a43;
    font-weight: 700;
}

.members-calendar-detail-dice-cta,
.members-calendar-detail-dice-logs {
    margin-top: 14px;
    border: 1px solid #dbcde7;
    border-radius: 10px;
    background: #faf6ff;
    padding: 12px;
}

.members-calendar-detail-dice-remaining {
    margin: 0;
    font-size: 16px;
    line-height: 1.6;
    color: #402f57;
    font-weight: 700;
}

.members-calendar-detail-dice-button {
    margin-top: 10px;
    width: 100%;
    min-height: 48px;
    border: 1px solid #d76f8b;
    border-radius: 10px;
    background: linear-gradient(180deg, #f9dbe4 0%, #f1c8d6 100%);
    color: #572f3f;
    font-size: 16px;
    font-family: inherit;
    font-weight: 700;
    cursor: pointer;
}

.members-calendar-detail-dice-button:disabled {
    opacity: 0.56;
    cursor: not-allowed;
}

.members-calendar-detail-dice-flow {
    margin-top: 12px;
    border-top: 1px dashed #dccde8;
    padding-top: 12px;
    display: grid;
    gap: 10px;
}

.members-calendar-detail-dice-flow-title {
    margin: 0;
    font-size: 17px;
    color: #402f57;
}

.members-calendar-detail-dice-category-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.members-calendar-detail-dice-category {
    min-height: 48px;
    border: 1px solid #c6b2de;
    border-radius: 10px;
    background: #ffffff;
    color: #443055;
    font-size: 15px;
    font-family: inherit;
    font-weight: 700;
    line-height: 1.4;
    padding: 8px;
    cursor: pointer;
}

.members-calendar-detail-dice-category.is-active {
    border-color: #6c4e95;
    background: #efe6fb;
}

.members-calendar-detail-dice-question-wrap {
    display: grid;
    gap: 6px;
}

.members-calendar-detail-dice-question-wrap label {
    font-size: 15px;
    color: #4a3760;
    line-height: 1.5;
}

.members-calendar-detail-dice-question {
    width: 100%;
    min-height: 88px;
    border: 1px solid #ccb6e1;
    border-radius: 10px;
    padding: 10px;
    font-size: 16px;
    font-family: inherit;
    color: #3f2f56;
    background: #ffffff;
    resize: vertical;
}

.members-calendar-detail-dice-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.members-calendar-detail-dice-back,
.members-calendar-detail-dice-roll {
    min-height: 48px;
    border-radius: 10px;
    font-size: 16px;
    font-family: inherit;
    font-weight: 700;
    cursor: pointer;
}

.members-calendar-detail-dice-back {
    border: 1px solid #cab7dd;
    background: #ffffff;
    color: #4a3760;
}

.members-calendar-detail-dice-roll {
    border: 1px solid #d76f8b;
    background: linear-gradient(180deg, #f9dbe4 0%, #f1c8d6 100%);
    color: #572f3f;
}

.members-calendar-detail-dice-roll:disabled,
.members-calendar-detail-dice-back:disabled,
.members-calendar-detail-dice-category:disabled,
.members-calendar-detail-dice-question:disabled {
    opacity: 0.56;
    cursor: not-allowed;
}

.members-calendar-detail-dice-result {
    margin-top: 12px;
    border: 1px solid #dccde8;
    border-radius: 10px;
    background: #ffffff;
    padding: 10px;
    display: grid;
    gap: 8px;
}

.members-calendar-detail-dice-animation {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}

.members-calendar-detail-die {
    min-height: 56px;
    border: 1px solid #d5c1ea;
    border-radius: 10px;
    background: #f9f4ff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    color: #47345a;
    font-weight: 700;
    text-align: center;
    padding: 4px;
}

.members-calendar-detail-dice-animation.is-rolling .members-calendar-detail-die {
    animation: members-detail-dice-roll 0.18s linear infinite;
}

.members-calendar-detail-dice-result-line,
.members-calendar-detail-dice-result-keyword,
.members-calendar-detail-dice-result-answer,
.members-calendar-detail-dice-result-remaining {
    margin: 0;
    font-size: 16px;
    line-height: 1.65;
    color: #3f3125;
}

.members-calendar-detail-dice-result-line {
    color: #47345a;
    font-weight: 700;
}

.members-calendar-detail-dice-result-keyword {
    color: #47345a;
    font-weight: 700;
}

.members-calendar-detail-dice-result-answer {
    white-space: pre-wrap;
}

.members-calendar-detail-dice-result-remaining {
    color: #402f57;
    font-weight: 700;
}

.members-calendar-detail-dice-error {
    margin: 10px 0 0;
    font-size: 15px;
    line-height: 1.55;
    color: #8b1d23;
}

.members-calendar-detail-dice-logs h3 {
    margin: 0;
    font-size: 18px;
    color: #493725;
}

.members-calendar-detail-dice-log-list {
    margin-top: 10px;
    display: grid;
    gap: 10px;
}

.members-calendar-detail-dice-log-item {
    border: 1px solid #dccde8;
    border-radius: 8px;
    background: #ffffff;
    padding: 10px;
}

.members-calendar-detail-dice-log-item p {
    margin: 0;
    font-size: 16px;
    line-height: 1.6;
    color: #3f3125;
}

.members-calendar-detail-dice-log-item p + p {
    margin-top: 6px;
}

.members-calendar-detail-dice-log-item strong {
    color: #3a274f;
}

.members-calendar-detail-dice-empty {
    margin: 0;
    font-size: 16px;
    line-height: 1.6;
    color: #4b3a5f;
}

.members-calendar-detail-error {
    margin: 14px 0 0;
    border-radius: 10px;
    border: 1px solid #d78289;
    background: #fbeaed;
    color: #7f2128;
    font-size: 16px;
    line-height: 1.55;
    padding: 10px 12px;
}

.members-calendar-modal.is-dice-locked .members-calendar-modal-backdrop,
.members-calendar-modal.is-dice-locked .members-calendar-modal-close {
    pointer-events: none;
    opacity: 0.72;
}

@keyframes members-detail-dice-roll {
    0% {
        transform: translateY(0) rotate(0deg);
    }
    50% {
        transform: translateY(-4px) rotate(8deg);
    }
    100% {
        transform: translateY(0) rotate(-8deg);
    }
}

.members-calendar-modal-open {
    overflow: hidden;
}

.members-dice-page {
    display: grid;
    gap: 14px;
}

.members-dice-header {
    border: 1px solid var(--line);
    border-radius: 14px;
    background: #fffdf9;
    padding: 16px;
}

.members-dice-header h1 {
    margin: 0;
    font-size: 28px;
    line-height: 1.35;
}

.members-dice-header p {
    margin: 8px 0 0;
    color: var(--muted);
    font-size: 16px;
}

.members-dice-panel,
.members-dice-result,
.members-dice-history {
    border: 1px solid var(--line);
    border-radius: 14px;
    background: var(--panel);
    padding: 14px;
    box-shadow: 0 8px 20px rgba(122, 107, 93, 0.08);
}

.members-dice-remaining {
    margin: 0;
    min-height: 40px;
    border-radius: 999px;
    border: 1px solid #e2d2bf;
    background: #fff8ef;
    color: #6b4b2f;
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    font-size: 16px;
    font-weight: 700;
}

.members-dice-banner {
    margin-top: 10px;
    border-radius: 10px;
    border: 1px solid;
    padding: 10px 12px;
    font-size: 16px;
    line-height: 1.5;
}

.members-dice-limit-banner {
    border-color: #c37653;
    background: #fff1e9;
    color: #7b3d22;
}

.members-dice-error-banner {
    border-color: #d78289;
    background: #fbeaed;
    color: #7f2128;
}

.members-dice-form {
    margin-top: 12px;
    display: grid;
    gap: 10px;
}

.members-dice-category-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.members-dice-category-btn {
    min-height: 56px;
    border-radius: 10px;
    border: 1px solid #d9c2a7;
    background: #fffdfa;
    color: #4d3827;
    font-family: inherit;
    font-size: 17px;
    font-weight: 700;
    cursor: pointer;
}

.members-dice-category-btn.is-active {
    border-color: #8a6340;
    background: #f0e0ce;
    color: #4d3827;
}

.members-dice-category-btn:disabled {
    cursor: not-allowed;
    opacity: 0.68;
}

.members-dice-free-wrap {
    display: grid;
    gap: 6px;
}

.members-dice-question {
    width: 100%;
    min-height: 120px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: #ffffff;
    color: var(--text);
    padding: 10px 12px;
    font-size: 16px;
    font-family: inherit;
    resize: vertical;
}

.members-dice-submit {
    min-height: 52px;
    border: 1px solid #8a6340;
    border-radius: 10px;
    background: var(--accent);
    color: #ffffff;
    font-size: 18px;
    font-weight: 700;
    font-family: inherit;
    cursor: pointer;
}

.members-dice-submit:disabled {
    opacity: 0.72;
    cursor: not-allowed;
}

.members-dice-page.is-loading .members-dice-submit {
    cursor: progress;
}

.members-dice-result h2,
.members-dice-history h2 {
    margin: 0;
    font-size: 22px;
}

.members-dice-result-cards {
    margin-top: 10px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.members-dice-result-card {
    flex: 1 1 150px;
    min-width: 120px;
    border: 1px solid #ead9c6;
    border-radius: 12px;
    background: #fffdf8;
    padding: 10px;
}

.members-dice-result-card h3 {
    margin: 0;
    font-size: 16px;
    color: #7a5c3f;
}

.members-dice-result-card p {
    margin: 6px 0 0;
    font-size: 24px;
    line-height: 1.25;
    font-weight: 700;
    color: #412f20;
}

.members-dice-keyword {
    margin: 12px 0 0;
    border-left: 4px solid #c58b58;
    padding: 2px 0 2px 10px;
    font-size: 18px;
    line-height: 1.6;
    color: #4b3725;
}

.members-dice-answer {
    margin-top: 10px;
    border: 1px solid #eadfcf;
    border-radius: 10px;
    background: #fffefb;
    padding: 12px;
    font-size: 16px;
    line-height: 1.85;
    color: #3f3125;
    white-space: pre-wrap;
    word-break: break-word;
}

.members-dice-remaining-after {
    margin: 12px 0 0;
    font-size: 15px;
    color: #6f5e4f;
}

.members-dice-remaining-label {
    margin-right: 6px;
}

.members-dice-history-list {
    margin: 10px 0 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 8px;
}

.members-dice-history-item {
    border: 1px solid #efe4d8;
    border-radius: 10px;
    background: #ffffff;
    padding: 10px;
}

.members-dice-history-meta {
    margin: 0;
    color: var(--muted);
    font-size: 14px;
}

.members-dice-history-summary {
    margin: 4px 0 0;
    color: #4a3726;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.6;
}

.members-dice-history-answer {
    margin: 6px 0 0;
    color: #544230;
    font-size: 15px;
    line-height: 1.75;
    white-space: pre-wrap;
    word-break: break-word;
}

.members-dice-category-btn:focus-visible,
.members-dice-question:focus-visible,
.members-dice-submit:focus-visible {
    outline: 3px solid #6f4a2f;
    outline-offset: 2px;
}

.members-consult-page,
.members-consult-session-page {
    display: grid;
    gap: 14px;
}

.members-consult-header {
    border: 1px solid var(--line);
    border-radius: 14px;
    background: #fffdf9;
    padding: 16px;
}

.members-consult-header h1 {
    margin: 0;
    font-size: 30px;
    line-height: 1.35;
}

.members-consult-header p {
    margin: 8px 0 0;
    color: var(--muted);
    font-size: 17px;
    line-height: 1.8;
}

.members-consult-panel,
.members-consult-session-list-panel,
.members-consult-thread-panel {
    border: 1px solid var(--line);
    border-radius: 14px;
    background: var(--panel);
    padding: 16px;
    box-shadow: 0 8px 20px rgba(122, 107, 93, 0.08);
}

.members-consult-remaining-pill {
    margin: 0;
    min-height: 42px;
    border-radius: 999px;
    border: 1px solid #dcc7b0;
    background: #fff8ef;
    color: #5f4228;
    display: inline-flex;
    align-items: center;
    padding: 6px 14px;
    font-size: 18px;
    font-weight: 700;
    line-height: 1.5;
}

.members-consult-banner {
    margin-top: 10px;
    border-radius: 10px;
    border: 1px solid;
    padding: 10px 12px;
    font-size: 16px;
    line-height: 1.6;
}

.members-consult-limit-banner {
    border-color: #c37653;
    background: #fff1e9;
    color: #7b3d22;
}

.members-consult-error-banner {
    border-color: #d78289;
    background: #fbeaed;
    color: #7f2128;
}

.members-consult-session-list-panel h2,
.members-consult-panel h2,
.members-consult-thread-panel h2 {
    margin: 0;
    font-size: 24px;
    line-height: 1.4;
}

.members-consult-empty {
    margin: 10px 0 0;
    color: var(--muted);
    font-size: 17px;
    line-height: 1.8;
}

.members-consult-session-list {
    margin: 12px 0 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 8px;
}

.members-consult-session-link {
    text-decoration: none;
    border: 1px solid #eadac7;
    border-radius: 10px;
    background: #fffdfa;
    display: grid;
    gap: 6px;
    padding: 12px;
    min-height: 44px;
}

.members-consult-session-top {
    margin: 0;
    color: #4b3726;
    font-size: 16px;
    line-height: 1.6;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    flex-wrap: wrap;
}

.members-consult-session-badge {
    border: 1px solid #c9a885;
    border-radius: 999px;
    background: #f7e7d4;
    color: #6f4929;
    font-size: 14px;
    font-weight: 700;
    padding: 3px 10px;
    line-height: 1.4;
}

.members-consult-session-meta {
    margin: 0;
    color: var(--muted);
    font-size: 14px;
    line-height: 1.5;
}

.members-consult-session-preview {
    margin: 0;
    color: #4f3c2b;
    font-size: 16px;
    line-height: 1.75;
    white-space: pre-wrap;
    word-break: break-word;
}

.members-consult-form {
    margin-top: 12px;
    display: grid;
    gap: 8px;
}

.members-consult-category-select {
    width: 100%;
    min-height: 54px;
    border: 1px solid #d6bea3;
    border-radius: 10px;
    background: #ffffff;
    color: var(--text);
    padding: 10px 12px;
    font-size: 18px;
    font-family: inherit;
}

.members-consult-message {
    width: 100%;
    min-height: 180px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: #ffffff;
    color: var(--text);
    padding: 12px;
    font-size: 17px;
    line-height: 1.85;
    font-family: inherit;
    resize: vertical;
}

.members-consult-help-text {
    margin: 0;
    color: var(--muted);
    font-size: 15px;
    line-height: 1.5;
}

.members-consult-submit {
    margin-top: 4px;
    min-height: 52px;
    border: 1px solid #8a6340;
    border-radius: 10px;
    background: var(--accent);
    color: #ffffff;
    font-size: 18px;
    font-weight: 700;
    font-family: inherit;
    cursor: pointer;
}

.members-consult-submit:disabled {
    opacity: 0.72;
    cursor: not-allowed;
}

.members-consult-exhausted-note {
    margin: 12px 0 0;
    color: #7a4933;
    font-size: 16px;
    line-height: 1.75;
}

.members-consult-meta-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}

.members-consult-session-meta-card {
    border: 1px solid #eadac7;
    border-radius: 10px;
    background: #fffdf8;
    padding: 10px;
}

.members-consult-session-meta-label {
    margin: 0;
    color: #745a42;
    font-size: 15px;
    line-height: 1.4;
}

.members-consult-session-meta-value {
    margin: 6px 0 0;
    color: #3f3023;
    font-size: 20px;
    line-height: 1.4;
    font-weight: 700;
}

.members-consult-thread {
    margin: 12px 0 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 10px;
}

.members-consult-thread-item {
    display: flex;
    flex-direction: column;
    max-width: 88%;
    gap: 4px;
}

.members-consult-thread-item.is-user {
    margin-left: auto;
    align-items: flex-end;
}

.members-consult-thread-item.is-assistant {
    margin-right: auto;
    align-items: flex-start;
}

.members-consult-thread-bubble {
    margin: 0;
    border-radius: 16px;
    padding: 12px 14px;
    font-size: 16px;
    line-height: 1.85;
    white-space: pre-wrap;
    word-break: break-word;
}

.members-consult-thread-item.is-user .members-consult-thread-bubble {
    background: #9a6842;
    color: #fffaf5;
    border: 1px solid #8a5b39;
}

.members-consult-thread-item.is-assistant .members-consult-thread-bubble {
    background: #fff4e4;
    color: #3d2f23;
    border: 1px solid #e6d3be;
}

.members-consult-thread-meta {
    margin: 0;
    color: var(--muted);
    font-size: 14px;
    line-height: 1.5;
}

.members-consult-form-wrap {
    margin-top: 12px;
}

.members-consult-closed-wrap {
    margin-top: 12px;
    border: 1px solid #d9b998;
    border-radius: 10px;
    background: #fff6ea;
    padding: 12px;
    display: grid;
    gap: 10px;
}

.members-consult-closed-text {
    margin: 0;
    color: #5c4028;
    font-size: 17px;
    line-height: 1.7;
}

.members-consult-new-button {
    min-height: 48px;
    border: 1px solid #8a6340;
    border-radius: 10px;
    background: #e8d1b9;
    color: #4d3928;
    text-decoration: none;
    font-size: 17px;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
}

.members-consult-session-link:focus-visible,
.members-consult-category-select:focus-visible,
.members-consult-message:focus-visible,
.members-consult-submit:focus-visible,
.members-consult-new-button:focus-visible {
    outline: 3px solid #6f4a2f;
    outline-offset: 2px;
}

.members-synastry-page {
    display: grid;
    gap: 14px;
}

.members-synastry-header {
    border: 1px solid var(--line);
    border-radius: 14px;
    background: #fffdf9;
    padding: 16px;
}

.members-synastry-header h1 {
    margin: 0;
    font-size: 30px;
    line-height: 1.35;
}

.members-synastry-header p {
    margin: 8px 0 0;
    color: var(--muted);
    font-size: 17px;
    line-height: 1.8;
}

.members-synastry-banner {
    border-radius: 10px;
    border: 1px solid;
    padding: 10px 12px;
    font-size: 16px;
    line-height: 1.6;
}

.members-synastry-success-banner {
    border-color: #77b38d;
    background: #edf9f1;
    color: #1f6b3c;
}

.members-synastry-error-banner {
    border-color: #d78289;
    background: #fbeaed;
    color: #7f2128;
}

.members-synastry-card {
    border: 1px solid var(--line);
    border-radius: 14px;
    background: var(--panel);
    padding: 16px;
    box-shadow: 0 8px 20px rgba(122, 107, 93, 0.08);
}

.members-synastry-card h2 {
    margin: 0;
    font-size: 24px;
    line-height: 1.4;
}

.members-synastry-target-grid {
    margin: 12px 0 0;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.members-synastry-target-grid div {
    border: 1px solid #eadac7;
    border-radius: 10px;
    background: #fffdf8;
    padding: 10px 12px;
    min-height: 74px;
}

.members-synastry-target-grid dt {
    font-size: 15px;
    color: #785f47;
}

.members-synastry-target-grid dd {
    margin: 6px 0 0;
    font-size: 19px;
    line-height: 1.45;
    color: #3f3023;
    word-break: break-word;
}

.members-synastry-inline-actions {
    margin-top: 12px;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.members-synastry-light-button,
.members-synastry-danger-button,
.members-synastry-register-cta {
    min-height: 48px;
    border-radius: 10px;
    font-size: 17px;
    font-family: inherit;
    font-weight: 700;
    cursor: pointer;
}

.members-synastry-light-button {
    border: 1px solid #bea588;
    background: #f6e6d4;
    color: #5b3f28;
}

.members-synastry-danger-button {
    border: 1px solid #b77a7f;
    background: #fbe9eb;
    color: #7e252f;
}

.members-synastry-register-cta {
    width: 100%;
    border: 1px solid #8a6340;
    background: var(--accent);
    color: #ffffff;
}

.members-synastry-empty-text {
    margin: 0 0 12px;
    color: var(--muted);
    font-size: 18px;
}

.members-synastry-form {
    margin-top: 12px;
    display: grid;
    gap: 10px;
}

.members-synastry-text-input {
    width: 100%;
    min-height: 54px;
    border: 1px solid #d6bea3;
    border-radius: 10px;
    background: #ffffff;
    color: var(--text);
    padding: 10px 12px;
    font-size: 19px;
    font-family: inherit;
}

.members-synastry-fieldset {
    border: 1px solid #e8d9c8;
    border-radius: 12px;
    padding: 12px;
    margin: 0;
}

.members-synastry-fieldset legend {
    padding: 0 4px;
    color: #5b4531;
    font-size: 19px;
    font-weight: 700;
}

.members-synastry-select-row {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.members-synastry-time-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.members-synastry-select-row label {
    display: grid;
    gap: 6px;
}

.members-synastry-select {
    width: 100%;
    min-height: 56px;
    border: 1px solid #d6bea3;
    border-radius: 10px;
    background: #ffffff;
    color: var(--text);
    padding: 10px 12px;
    font-size: 19px;
    font-family: inherit;
}

.members-synastry-select:disabled {
    color: #8a8a8a;
    background: #f0f0f0;
}

.members-synastry-check {
    margin-top: 10px;
    border: 1px solid #e2d2bf;
    border-radius: 10px;
    padding: 10px 12px;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: #fffaf4;
    font-size: 18px;
}

.members-synastry-check input {
    width: 22px;
    height: 22px;
    margin: 0;
    accent-color: #9f6840;
}

.members-synastry-submit {
    min-height: 52px;
    border: 1px solid #8a6340;
    border-radius: 10px;
    background: var(--accent);
    color: #ffffff;
    font-size: 20px;
    font-weight: 700;
    font-family: inherit;
    cursor: pointer;
}

.members-synastry-submit:disabled,
.members-synastry-light-button:disabled,
.members-synastry-danger-button:disabled,
.members-synastry-register-cta:disabled {
    opacity: 0.72;
    cursor: not-allowed;
}

.members-synastry-result-card h3 {
    margin: 0;
    font-size: 20px;
    line-height: 1.4;
}

.members-synastry-score-card {
    margin-top: 12px;
    border: 1px solid #e9d8c6;
    border-radius: 12px;
    background: #fffdf8;
    padding: 12px;
}

.members-synastry-score-label {
    margin: 0;
    color: #7a5c3f;
    font-size: 16px;
    line-height: 1.5;
}

.members-synastry-score-main {
    margin-top: 8px;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.members-synastry-heart {
    color: #c42548;
    font-size: 28px;
    line-height: 1;
}

.members-synastry-stars {
    color: #9f6c3b;
    font-size: 28px;
    letter-spacing: 0.04em;
    line-height: 1.2;
}

.members-synastry-score-text {
    color: #4b3725;
    font-size: 22px;
    font-weight: 700;
}

.members-synastry-category-block {
    margin-top: 12px;
}

.members-synastry-category-list {
    margin: 10px 0 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 8px;
}

.members-synastry-category-item {
    border: 1px solid #efe4d8;
    border-radius: 10px;
    background: #ffffff;
    padding: 10px 12px;
    display: grid;
    grid-template-columns: minmax(0, 140px) minmax(0, 1fr) auto;
    align-items: center;
    gap: 8px;
}

.members-synastry-category-label {
    color: #4b3726;
    font-size: 16px;
    font-weight: 700;
}

.members-synastry-category-stars {
    color: #9f6c3b;
    font-size: 22px;
    letter-spacing: 0.04em;
}

.members-synastry-category-score {
    color: #4b3725;
    font-size: 18px;
    font-weight: 700;
}

.members-synastry-diagnosis {
    margin-top: 12px;
    border: 1px solid #eadfcf;
    border-radius: 10px;
    background: #fffefb;
    padding: 12px;
}

.members-synastry-diagnosis p {
    margin: 8px 0 0;
    color: #3f3125;
    font-size: 16px;
    line-height: 1.85;
    white-space: pre-wrap;
    word-break: break-word;
}

.members-synastry-text-input:focus-visible,
.members-synastry-select:focus-visible,
.members-synastry-submit:focus-visible,
.members-synastry-light-button:focus-visible,
.members-synastry-danger-button:focus-visible,
.members-synastry-register-cta:focus-visible {
    outline: 3px solid #6f4a2f;
    outline-offset: 2px;
}

.members-month-report-page {
    display: grid;
    gap: 14px;
}

.members-month-report-header {
    display: grid;
    gap: 8px;
}

.members-month-report-header h1 {
    margin: 0;
    font-size: 30px;
    line-height: 1.4;
}

.members-month-report-header p {
    margin: 0;
    font-size: 16px;
    line-height: 1.8;
    color: var(--muted);
}

.members-month-report-toolbar {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}

.members-month-report-select-wrap {
    display: grid;
    gap: 6px;
    font-size: 16px;
}

.members-month-report-select {
    min-width: 220px;
    min-height: 48px;
    border: 1px solid #d7c7b5;
    border-radius: 10px;
    padding: 10px 12px;
    font-size: 17px;
    color: var(--text);
    background: #ffffff;
}

.members-month-report-loading {
    margin: 0;
    color: #745739;
    font-size: 15px;
}

.members-month-report-error {
    margin: 0;
    padding: 12px;
    border-radius: 10px;
    border: 1px solid #df7a80;
    background: #fbecef;
    color: #8a1f25;
    font-size: 16px;
    line-height: 1.6;
}

.members-month-report-article {
    background: #fffdfa;
    border: 1px solid #e5d9cc;
    border-radius: 14px;
    padding: 24px 22px;
    box-shadow: 0 8px 20px rgba(122, 107, 93, 0.08);
}

.members-month-report-article-title {
    margin: 0;
    font-size: 28px;
    line-height: 1.45;
}

.members-month-report-body {
    margin-top: 16px;
}

.members-month-report-body p {
    margin: 0 0 16px;
    font-size: 17px;
    line-height: 1.8;
    white-space: pre-line;
}

.members-month-report-body p:last-child {
    margin-bottom: 0;
}

.members-month-report-summary {
    margin-top: 18px;
    padding-top: 16px;
    border-top: 1px solid #ebdfd2;
}

.members-month-report-summary h3,
.members-month-report-topics h3 {
    margin: 0;
    font-size: 20px;
    line-height: 1.5;
}

.members-month-report-summary-list {
    margin: 12px 0 0;
    padding: 0;
    list-style: none;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.members-month-report-summary-list li {
    border: 1px solid #ebdfd2;
    border-radius: 10px;
    background: #fffefc;
    min-height: 72px;
    padding: 10px 12px;
    display: flex;
    align-items: baseline;
    justify-content: center;
    gap: 4px;
    font-size: 16px;
}

.members-month-report-summary-label {
    color: #6e543c;
}

.members-month-report-summary-list strong {
    font-size: 28px;
    line-height: 1.2;
    color: #664528;
}

.members-month-report-topics {
    margin-top: 18px;
    padding-top: 16px;
    border-top: 1px solid #ebdfd2;
}

.members-month-report-topics-list {
    margin: 10px 0 0;
    padding-left: 22px;
    display: grid;
    gap: 8px;
    font-size: 17px;
    line-height: 1.85;
    color: #4b392a;
}

.members-month-report-empty {
    padding: 16px;
    border-radius: 12px;
    border: 1px solid #e6d6c3;
    background: #fff7ed;
    color: #6f5238;
    font-size: 17px;
    line-height: 1.85;
}

.members-month-report-select:focus-visible {
    outline: 3px solid #6f4a2f;
    outline-offset: 2px;
}

.members-news-page {
    display: grid;
    gap: 14px;
}

.members-news-header {
    border: 1px solid var(--line);
    border-radius: 14px;
    background: #fffdf9;
    padding: 16px;
}

.members-news-header h1 {
    margin: 0;
    font-size: 30px;
    line-height: 1.35;
}

.members-news-header p {
    margin: 8px 0 0;
    color: var(--muted);
    font-size: 16px;
    line-height: 1.8;
}

.members-news-error {
    border-radius: 10px;
    border: 1px solid #d78289;
    background: #fbeaed;
    color: #7f2128;
    font-size: 16px;
    line-height: 1.6;
    padding: 10px 12px;
}

.members-news-list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 10px;
}

.members-news-card {
    border: 1px solid #e4d8ca;
    border-radius: 14px;
    background: #fffdfa;
    padding: 14px;
    box-shadow: 0 8px 20px rgba(122, 107, 93, 0.08);
    display: grid;
    gap: 10px;
}

.members-news-meta {
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    flex-wrap: wrap;
    font-size: 14px;
    color: var(--muted);
}

.members-news-type-badge {
    min-height: 28px;
    border-radius: 999px;
    border: 1px solid #d8c7b4;
    background: #f8eee2;
    color: #6b4a2e;
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.3;
}

.members-news-type-full_moon {
    border-color: #a2aebd;
    background: #edf2f9;
    color: #2f4667;
}

.members-news-card-title {
    margin: 0;
    font-size: 22px;
    line-height: 1.5;
}

.members-news-audio {
    width: 100%;
    min-height: 48px;
}

.members-news-excerpt {
    margin: 0;
    color: #453627;
    font-size: 16px;
    line-height: 1.85;
    white-space: pre-wrap;
    word-break: break-word;
}

.members-news-muted {
    margin: 0;
    color: var(--muted);
    font-size: 16px;
    line-height: 1.7;
}

.members-news-detail-wrap {
    margin: 0;
}

.members-news-detail-link,
.members-news-back-link {
    min-height: 44px;
    border: 1px solid #c8b59f;
    border-radius: 999px;
    background: #ffffff;
    color: #5f4a37;
    display: inline-flex;
    align-items: center;
    text-decoration: none;
    padding: 8px 14px;
    font-size: 16px;
}

.members-news-empty {
    margin: 0;
    border: 1px solid #e6d6c3;
    border-radius: 12px;
    background: #fff7ed;
    color: #6f5238;
    font-size: 16px;
    line-height: 1.8;
    padding: 14px;
}

.members-news-detail-page {
    display: grid;
    gap: 14px;
}

.members-news-detail-header {
    border: 1px solid var(--line);
    border-radius: 14px;
    background: #fffdf9;
    padding: 16px;
}

.members-news-detail-header h1 {
    margin: 0;
    font-size: 30px;
    line-height: 1.4;
}

.members-news-detail-date {
    margin: 10px 0 0;
    color: var(--muted);
    font-size: 16px;
    line-height: 1.6;
}

.members-news-detail-panel {
    border: 1px solid #eadfce;
    border-radius: 14px;
    background: #fffdfa;
    box-shadow: 0 8px 20px rgba(122, 107, 93, 0.08);
    padding: 16px;
}

.members-news-reading {
    border: 1px solid #e4d8ca;
    border-radius: 14px;
    background: #fffdfa;
    box-shadow: 0 8px 20px rgba(122, 107, 93, 0.08);
    padding: 22px 20px;
}

.members-news-reading p {
    margin: 0;
    color: #3f3023;
    font-size: 17px;
    line-height: 1.95;
    white-space: pre-wrap;
    word-break: break-word;
}

.members-news-back-wrap {
    margin: 0;
}

.members-news-detail-link:focus-visible,
.members-news-back-link:focus-visible {
    outline: 3px solid #6f4a2f;
    outline-offset: 2px;
}

@keyframes members-calendar-shimmer {
    0% {
        background-position: 200% 0;
    }
    100% {
        background-position: -200% 0;
    }
}

@media (max-width: 640px) {
    .lp-shell {
        padding: 16px 12px 28px;
    }

    .lp-hero {
        grid-template-columns: 1fr;
        padding: 16px 14px;
    }

    .lp-title {
        font-size: 30px;
    }

    .lp-subtitle {
        font-size: 18px;
    }

    .lp-offer {
        font-size: 18px;
    }

    .lp-hero-visual {
        min-height: 180px;
    }

    .lp-features h2 {
        font-size: 22px;
    }

    .lp-feature-card {
        font-size: 17px;
    }

    .members-shell {
        padding: 16px 12px 28px;
    }

    .members-card {
        padding: 18px;
    }

    .members-card h1 {
        font-size: 20px;
    }

    .members-login-title {
        font-size: 22px;
    }

    .members-brand-name {
        font-size: 16px;
    }

    .members-top-nav {
        display: none;
    }

    .members-mobile-menu {
        display: block;
    }

    .members-dashboard-greeting h1 {
        font-size: 24px;
    }

    .members-dashboard-hero h1 {
        font-size: 24px;
    }

    .members-feature-grid {
        grid-template-columns: 1fr;
    }

    .members-feature-card {
        min-height: 76px;
        font-size: 17px;
    }

    .members-onboarding-card {
        padding: 16px 12px;
    }

    .members-onboarding-title {
        font-size: 26px;
    }

    .members-onboarding-description {
        font-size: 16px;
    }

    .members-onboarding-fieldset legend {
        font-size: 17px;
    }

    .members-onboarding-select {
        min-height: 48px;
        font-size: 16px;
    }

    .members-onboarding-check {
        font-size: 16px;
    }

    .members-onboarding-submit {
        min-height: 50px;
        font-size: 18px;
    }

    .members-partner-setup-card {
        padding: 16px 12px;
    }

    .members-partner-setup-title {
        font-size: 26px;
    }

    .members-partner-setup-description {
        font-size: 16px;
    }

    .members-partner-setup-fieldset legend {
        font-size: 17px;
    }

    .members-partner-setup-inline-fields {
        grid-template-columns: 1fr;
    }

    .members-partner-setup-input,
    .members-partner-setup-radio-item,
    .members-partner-setup-check {
        font-size: 16px;
    }

    .members-partner-setup-submit {
        min-height: 50px;
        font-size: 18px;
    }

    .members-signup-title {
        font-size: 24px;
    }

    .members-offer-price {
        font-size: 32px;
    }

    .members-contact-title {
        font-size: 22px;
    }

    .members-contact-history h2 {
        font-size: 18px;
    }

    .members-feature-badge {
        font-size: 16px;
    }

    .members-calendar-header h1 {
        font-size: 24px;
    }

    .members-calendar-controls {
        grid-template-columns: 1fr;
    }

    .members-calendar-nav-btn,
    .members-calendar-month-label {
        justify-self: stretch;
        text-align: center;
    }

    .members-calendar-grid {
        gap: 4px;
    }

    .members-calendar-cell {
        min-height: 112px;
        padding: 8px 4px;
    }

    .members-calendar-detail-heading {
        font-size: 22px;
    }

    .members-calendar-modal-panel {
        width: calc(100% - 12px);
        margin-top: 12px;
        max-height: calc(100vh - 24px);
    }

    .members-dice-header h1 {
        font-size: 24px;
    }

    .members-dice-category-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .members-dice-result-card {
        flex: 1 1 calc(50% - 6px);
    }

    .members-dice-keyword {
        font-size: 17px;
    }

    .members-consult-header h1 {
        font-size: 25px;
    }

    .members-consult-header p {
        font-size: 16px;
    }

    .members-consult-session-list-panel h2,
    .members-consult-panel h2,
    .members-consult-thread-panel h2 {
        font-size: 21px;
    }

    .members-consult-meta-grid {
        grid-template-columns: 1fr;
    }

    .members-consult-message {
        min-height: 160px;
        font-size: 16px;
    }

    .members-consult-category-select,
    .members-consult-submit {
        font-size: 17px;
    }

    .members-consult-thread-item {
        max-width: 96%;
    }

    .members-synastry-header h1 {
        font-size: 25px;
    }

    .members-synastry-header p {
        font-size: 16px;
    }

    .members-synastry-card h2 {
        font-size: 21px;
    }

    .members-synastry-target-grid {
        grid-template-columns: 1fr;
    }

    .members-synastry-target-grid dd {
        font-size: 18px;
    }

    .members-synastry-inline-actions {
        grid-template-columns: 1fr;
    }

    .members-synastry-select-row {
        grid-template-columns: 1fr;
    }

    .members-synastry-time-row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .members-synastry-text-input,
    .members-synastry-select,
    .members-synastry-submit {
        font-size: 17px;
    }

    .members-synastry-stars {
        font-size: 24px;
    }

    .members-synastry-score-text {
        font-size: 20px;
    }

    .members-synastry-category-item {
        grid-template-columns: 1fr;
        align-items: start;
    }

    .members-synastry-category-stars {
        font-size: 20px;
    }

    .members-month-report-header h1 {
        font-size: 25px;
    }

    .members-month-report-header p {
        font-size: 16px;
    }

    .members-month-report-toolbar {
        display: grid;
        justify-content: stretch;
        gap: 8px;
    }

    .members-month-report-select {
        min-width: 0;
        width: 100%;
        font-size: 17px;
    }

    .members-month-report-article {
        padding: 18px 14px;
    }

    .members-month-report-article-title {
        font-size: 24px;
    }

    .members-month-report-body p {
        font-size: 16px;
    }

    .members-month-report-summary h3,
    .members-month-report-topics h3 {
        font-size: 19px;
    }

    .members-month-report-summary-list {
        grid-template-columns: 1fr;
    }

    .members-month-report-topics-list {
        font-size: 16px;
    }

    .members-news-header h1,
    .members-news-detail-header h1 {
        font-size: 25px;
    }

    .members-news-card {
        padding: 12px;
    }

    .members-news-card-title {
        font-size: 20px;
    }

    .members-news-reading {
        padding: 16px 14px;
    }

    .members-news-reading p {
        font-size: 16px;
    }
}

[hidden] { display: none !important; }

/* ============================================================
 * アストロダイス: 3ダイス（惑星 / 星座 / ハウス）+ スピカさん GIF コンパニオン
 * ============================================================ */
.spica-dice-stage[hidden],
.spica-dice-stage [hidden] {
    display: none !important;
}

.spica-dice-rolling {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 24px;
    perspective: 900px;
    min-height: 260px;
    margin: 12px auto 0;
    padding: 8px 0;
}

.spica-dice-loading {
    display: none;
    align-items: center;
    justify-content: center;
    min-height: 180px;
    text-align: center;
    color: #5b4450;
    font-size: 16px;
    line-height: 1.7;
}

.spica-dice-loading.is-visible {
    display: flex;
}

.spica-dice-hero {
    display: none;
    margin: 10px auto 0;
    max-width: 220px;
}

.spica-dice-hero.is-visible {
    display: block;
}

.spica-dice-hero img {
    width: 100%;
    height: auto;
    display: block;
}

.spica-dice-badges {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 10px;
}

.spica-dice-badge {
    display: none;
    border-radius: 999px;
    border: 1px solid #d9b7c1;
    background: #fff6f9;
    color: #6f4352;
    padding: 4px 10px;
    font-size: 13px;
    font-weight: 700;
    line-height: 1.4;
}

.spica-dice-badge.is-visible {
    display: inline-flex;
}

.spica-dice-trio {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}

.spica-mini-die {
    width: 78px;
    height: 78px;
    border-radius: 18px;
    background: linear-gradient(160deg, #fff6f9 0%, #f7d4dd 55%, #e8a5b6 100%);
    border: 2px solid #d76f8b;
    box-shadow: 0 8px 18px rgba(120, 40, 80, 0.22);
    color: #6b3a4a;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 2px;
    text-align: center;
    transform: translateZ(0) rotate(0deg);
}

.spica-mini-die-icon {
    display: block;
    font-size: 30px;
    line-height: 1;
}

.spica-mini-die-label {
    display: block;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.04em;
}

.spica-dice-stage.is-shuffling .spica-mini-die-planet {
    animation: spica-mini-die-roll-planet 1.2s ease-in-out;
}

.spica-dice-stage.is-shuffling .spica-mini-die-sign {
    animation: spica-mini-die-roll-sign 1.2s ease-in-out;
}

.spica-dice-stage.is-shuffling .spica-mini-die-house {
    animation: spica-mini-die-roll-house 1.2s ease-in-out;
}

@keyframes spica-mini-die-roll-planet {
    0% { transform: translateY(0) rotate(0deg); }
    40% { transform: translateY(-8px) rotate(210deg); }
    100% { transform: translateY(0) rotate(360deg); }
}

@keyframes spica-mini-die-roll-sign {
    0% { transform: translateY(0) rotate(0deg); }
    50% { transform: translateY(-10px) rotate(-250deg); }
    100% { transform: translateY(0) rotate(-360deg); }
}

@keyframes spica-mini-die-roll-house {
    0% { transform: translateY(0) rotate(0deg); }
    45% { transform: translateY(-6px) rotate(180deg); }
    100% { transform: translateY(0) rotate(360deg); }
}

.spica-die-companion {
    flex-shrink: 0;
    width: 110px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.spica-die-companion img {
    width: 100%;
    height: auto;
    max-height: 200px;
    object-fit: contain;
    display: block;
}

@media (max-width: 480px) {
    .spica-dice-rolling {
        gap: 14px;
        min-height: 220px;
    }
    .spica-dice-trio {
        gap: 8px;
    }
    .spica-mini-die {
        width: 62px;
        height: 62px;
        border-radius: 14px;
    }
    .spica-mini-die-icon {
        font-size: 24px;
    }
    .spica-mini-die-label {
        font-size: 10px;
    }
    .spica-die-companion {
        width: 90px;
    }
    .spica-die-companion img {
        max-height: 160px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .spica-dice-stage.is-shuffling .spica-mini-die-planet,
    .spica-dice-stage.is-shuffling .spica-mini-die-sign,
    .spica-dice-stage.is-shuffling .spica-mini-die-house {
        animation: none;
    }
}
