/* Tates PC — signup.css
 * Tames the legacy Atmosphere CSS used by signup.php so the form
 * matches the rest of the site. Layout/markup of the form is unchanged;
 * only presentation is overridden.
 */

body.signup-page {
    background: var(--bg-soft);
    color: var(--ink);
    font-family: var(--font);
    font-size: 16px;
    line-height: 1.55;
    -webkit-text-size-adjust: 100%;
}

body.signup-page main.site-main input,
body.signup-page main.site-main select,
body.signup-page main.site-main textarea,
body.signup-page main.site-main button {
    font-family: var(--font);
    font-size: 1rem;
    line-height: 1.4;
    color: var(--ink);
}

body.signup-page main.site-main a {
    color: var(--brand);
    text-decoration-color: rgba(11, 59, 111, 0.3);
    text-underline-offset: 2px;
}
body.signup-page main.site-main a:hover { color: var(--brand-strong); text-decoration-color: var(--brand); }

body.signup-page main.site-main h1,
body.signup-page main.site-main h2,
body.signup-page main.site-main h3,
body.signup-page main.site-main h4 {
    font-family: var(--font);
    color: var(--brand-strong);
    line-height: 1.25;
    margin: 1.5rem 0 0.75rem;
    letter-spacing: 0;
    text-transform: none;
}
body.signup-page main.site-main h2 {
    font-size: clamp(1.15rem, 1.8vw + 0.7rem, 1.5rem);
    border-bottom: 1px solid var(--rule);
    padding-bottom: 0.45rem;
}
body.signup-page main.site-main h3 {
    font-size: clamp(1.02rem, 1.4vw + 0.65rem, 1.18rem);
    color: var(--ink);
}

/* Page wrapper */
body.signup-page .signup-page-main {
    padding: 1.25rem 0 3rem;
    background: var(--bg-soft);
    min-height: 60vh;
}
body.signup-page .tmf-signup-shell {
    max-width: var(--container);
}

/* Card around the form */
body.signup-page .tmf-signup-section {
    background: var(--bg);
    border: 1px solid var(--rule);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 0;
    margin: 0;
}
/* Neutralize Atmosphere torn-paper pseudo-elements */
body.signup-page .tmf-signup-section.wrapper:before,
body.signup-page .tmf-signup-section.wrapper:after,
body.signup-page .tmf-signup-section.wrapper.alt:after {
    content: none !important;
    background: none !important;
    display: none !important;
}
body.signup-page .tmf-signup-section .inner.tmf-signup-inner {
    max-width: none;
    width: auto;
    padding: 1.5rem clamp(1rem, 2vw + 0.5rem, 2rem) 2rem;
}

/* Hero */
body.signup-page .signup-hero {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: center;
    padding: 0 0 1rem;
    margin: 0 0 1rem;
    border-bottom: 1px solid var(--rule);
}
body.signup-page .signup-hero__mark {
    width: 56px;
    height: 56px;
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    flex-shrink: 0;
}
body.signup-page .signup-hero__eyebrow {
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: var(--brand);
    font-weight: 600;
    margin: 0 0 0.15rem;
}
body.signup-page .signup-hero__title {
    font-size: clamp(1.25rem, 2.4vw, 1.6rem);
    margin: 0 0 0.3rem;
    line-height: 1.2;
    color: var(--brand-strong);
    border: 0;
    padding: 0;
}
body.signup-page .signup-hero__sub {
    margin: 0;
    color: var(--ink-soft);
    font-size: 0.95rem;
    line-height: 1.5;
    max-width: 52rem;
}

/* Tables — keep legacy semantics but modernize the look. */
body.signup-page main.site-main table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    margin: 0.5rem 0 1rem;
    background: transparent;
}
body.signup-page main.site-main table.alt {
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    overflow: visible;
}
body.signup-page main.site-main table.alt tr {
    border: 0;
}
body.signup-page main.site-main table.alt td,
body.signup-page main.site-main table.alt th {
    padding: 0.55rem 0.65rem;
    border: 0;
    border-bottom: 1px solid var(--rule);
    background: transparent;
    vertical-align: middle;
    font-size: 0.95rem;
    line-height: 1.4;
    color: var(--ink);
}
body.signup-page main.site-main table.alt tr:last-child td,
body.signup-page main.site-main table.alt tr:last-child th {
    border-bottom: 0;
}
body.signup-page main.site-main table.alt tr:nth-child(even) td {
    background: rgba(15, 23, 42, 0.02);
}
body.signup-page main.site-main table.alt td[colspan] {
    background: rgba(11, 59, 111, 0.025);
}
body.signup-page main.site-main table.alt td.alignr {
    text-align: right;
}

/* Desktop: left-align narrative / section cells that were centered in the legacy theme */
body.signup-page .tmf-signup-inner table.alt.tmf-signup-matrix > tbody > tr > td[colspan="6"]:not(.tmf-form-err):not(.alignr) {
    text-align: left !important;
}
body.signup-page .tmf-signup-inner table.alt.tmf-signup-matrix > tbody > tr > td[colspan="3"] {
    text-align: left !important;
}
body.signup-page .tmf-signup-inner table.alt.tmf-signup-matrix > tbody > tr > td[colspan="2"] {
    text-align: left !important;
}
body.signup-page .tmf-signup-inner table.alt.tmf-signup-matrix td.alignr,
body.signup-page .tmf-signup-inner table.alt.tmf-signup-matrix td[style*="text-align: right"] {
    text-align: right !important;
}

/* Form fields */
body.signup-page main.site-main input[type="text"],
body.signup-page main.site-main input[type="email"],
body.signup-page main.site-main input[type="tel"],
body.signup-page main.site-main input[type="number"],
body.signup-page main.site-main input[type="password"],
body.signup-page main.site-main select,
body.signup-page main.site-main textarea {
    appearance: none;
    -webkit-appearance: none;
    background: var(--bg);
    border: 1px solid var(--rule);
    border-radius: 8px;
    padding: 0.55rem 0.7rem;
    line-height: 1.3;
    min-height: 40px;
    width: 100%;
    max-width: 100%;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04) inset;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
body.signup-page main.site-main input[type="text"]:focus,
body.signup-page main.site-main input[type="email"]:focus,
body.signup-page main.site-main input[type="tel"]:focus,
body.signup-page main.site-main input[type="number"]:focus,
body.signup-page main.site-main input[type="password"]:focus,
body.signup-page main.site-main select:focus,
body.signup-page main.site-main textarea:focus {
    outline: 0;
    border-color: var(--brand);
    box-shadow: 0 0 0 3px rgba(11, 59, 111, 0.18);
}
body.signup-page main.site-main input[readonly] {
    background: rgba(15, 23, 42, 0.04);
    color: var(--ink-soft);
    cursor: not-allowed;
}
body.signup-page main.site-main input[type="checkbox"],
body.signup-page main.site-main input[type="radio"] {
    width: 1.05rem;
    height: 1.05rem;
    margin-right: 0.4rem;
    accent-color: var(--brand);
    vertical-align: middle;
}

/* Buttons */
body.signup-page main.site-main .button,
body.signup-page main.site-main input[type="submit"],
body.signup-page main.site-main input[type="reset"],
body.signup-page main.site-main button {
    appearance: none;
    -webkit-appearance: none;
    display: inline-block;
    background: var(--brand);
    color: #fff;
    border: 1px solid var(--brand);
    border-radius: 8px;
    padding: 0.65rem 1.1rem;
    font-weight: 600;
    font-size: 0.98rem;
    line-height: 1.2;
    text-decoration: none;
    cursor: pointer;
    min-height: 42px;
    box-shadow: 0 1px 2px rgba(11, 59, 111, 0.18);
    transition: background-color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease, transform 0.05s ease;
}
body.signup-page main.site-main .button:hover,
body.signup-page main.site-main input[type="submit"]:hover,
body.signup-page main.site-main input[type="reset"]:hover,
body.signup-page main.site-main button:hover {
    background: var(--brand-strong);
    border-color: var(--brand-strong);
    color: #fff;
    text-decoration: none;
}
body.signup-page main.site-main .button:active,
body.signup-page main.site-main input[type="submit"]:active,
body.signup-page main.site-main input[type="reset"]:active,
body.signup-page main.site-main button:active {
    transform: translateY(1px);
}
body.signup-page main.site-main .button:focus-visible,
body.signup-page main.site-main input[type="submit"]:focus-visible,
body.signup-page main.site-main input[type="reset"]:focus-visible,
body.signup-page main.site-main button:focus-visible {
    outline: 3px solid var(--accent);
    outline-offset: 2px;
}
body.signup-page main.site-main .button.special {
    background: var(--accent);
    border-color: var(--accent);
    color: #fff;
}
body.signup-page main.site-main .button.special:hover {
    background: var(--accent-strong);
    border-color: var(--accent-strong);
}
body.signup-page main.site-main input[type="reset"] {
    background: var(--bg);
    color: var(--brand);
    border: 1px solid var(--brand);
    box-shadow: none;
}
body.signup-page main.site-main input[type="reset"]:hover {
    background: var(--brand-soft);
    color: var(--brand-strong);
}

/* Tip icons */
body.signup-page main.site-main a.tmf-tip {
    border: 0;
    text-decoration: none;
    display: inline-block;
    vertical-align: middle;
    line-height: 0;
}
body.signup-page main.site-main img.tmf-tip-icon {
    width: 16px;
    height: 16px;
    vertical-align: text-bottom;
    display: inline-block;
}
body.signup-page #tooltip.tmf-tooltip--compact {
    min-width: 0;
    max-width: 260px;
    width: auto;
    padding: 8px 10px;
    font-size: 0.82rem;
    line-height: 1.35;
    text-align: left;
}

/* Discount referral row */
body.signup-page main.site-main form[name="discount"] {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    align-items: center;
    background: var(--brand-soft);
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    padding: 0.85rem 1rem;
    margin: 1.5rem 0 1rem;
}
body.signup-page main.site-main form[name="discount"] > div {
    flex: 1 1 220px;
    margin: 0 !important;
    padding: 0;
    width: auto !important;
    max-width: none !important;
    float: none !important;
    text-align: left !important;
}
body.signup-page main.site-main form[name="discount"] > div.alignr {
    text-align: right !important;
}
body.signup-page main.site-main form[name="discount"] > div.alignc {
    text-align: center !important;
}
body.signup-page main.site-main form[name="discount"] input[type="text"] {
    width: 100%;
    max-width: 22rem;
}

/* Info / tips section */
body.signup-page .tmf-signup-more-info {
    margin-top: 2rem;
    padding-top: 1rem;
    border-top: 1px solid var(--rule);
    font-size: 0.95rem;
}
body.signup-page .tmf-signup-more-info p[id^="tips-"],
body.signup-page .tmf-info-anchor {
    scroll-margin-top: 7.5rem;
}
body.signup-page .tmf-signup-more-info hr {
    border: 0;
    border-top: 1px solid var(--rule);
    margin: 1.2rem 0;
}
body.signup-page .tmf-signup-more-info img {
    max-width: 100%;
    height: auto;
}

/* Update banner */
body.signup-page .tmf-update-banner {
    background: rgba(217, 119, 6, 0.08) !important;
    border: 1px solid rgba(217, 119, 6, 0.35) !important;
    color: var(--ink) !important;
    border-radius: var(--radius);
    padding: 0.85rem 1rem;
}

/* Error banner — preserve subscribe step 2 colors */
body.signup-page .tmf-form-err {
    background: #fff4f4 !important;
    border: 1px solid #e0b4b4 !important;
    color: #6a0d0d !important;
    border-radius: var(--radius);
}

/* The main hero image inside .image.main from legacy code — we replaced with our own hero block.
   Hide any legacy hero image just in case. */
body.signup-page a.image.main,
body.signup-page .image.main {
    display: none !important;
}

/* Mobile */
@media (max-width: 800px) {
    body.signup-page .signup-hero {
        flex-direction: column;
        text-align: center;
    }
    body.signup-page .signup-hero__mark { margin: 0 auto; }
    body.signup-page .tmf-signup-section .inner.tmf-signup-inner {
        padding-left: 1rem;
        padding-right: 1rem;
    }
}

@media (max-width: 720px) {
    body.signup-page main.site-main table.alt {
        display: block;
        border: 0;
    }
    body.signup-page main.site-main table.alt > tbody {
        display: block;
    }
    body.signup-page main.site-main table.alt > tbody > tr {
        display: block;
        border: 1px solid var(--rule);
        border-radius: var(--radius);
        margin-bottom: 0.6rem;
        padding: 0.25rem 0.4rem;
        background: var(--bg);
    }
    body.signup-page main.site-main table.alt > tbody > tr:nth-child(even) td {
        background: transparent;
    }
    body.signup-page main.site-main table.alt > tbody > tr > td,
    body.signup-page main.site-main table.alt > tbody > tr > th {
        display: block;
        width: 100% !important;
        max-width: 100%;
        text-align: left !important;
        padding: 0.4rem 0.3rem;
        border-bottom: 1px dashed var(--rule);
    }
    body.signup-page main.site-main table.alt > tbody > tr > td:last-child,
    body.signup-page main.site-main table.alt > tbody > tr > th:last-child {
        border-bottom: 0;
    }
    body.signup-page main.site-main table.alt td[colspan] {
        background: transparent;
    }
    body.signup-page main.site-main table.alt td.alignr,
    body.signup-page main.site-main table.alt td[align="right"] {
        text-align: center !important;
    }
}
