.tk-template-body {
    --accent-color-2: #aaf40f;
    --accent-color-6: #bcff02;
}
.background-accent {
    background: #aaf40f;;
}
.tk-logo-main { max-height: 46px; width: auto; }
.tk-footer-logo { max-height: 48px; width: auto; margin-bottom: 18px; }
.tk-footer-section {
    background: var(--accent-color);
    color: var(--secondary);
}
.tk-footer-cta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 28px;
    padding: 58px 0;
    border-bottom: 1px solid rgba(255,255,255,.14);
}
.tk-footer-kicker {
    display: inline-flex;
    width: fit-content;
    border-radius: 10px;
    padding: 8px 14px;
    background: var(--accent-color-2);
    color: var(--accent-color);
    font-weight: 900;
    margin-bottom: 16px;
}
.tk-footer-cta h2 {
    color: var(--secondary);
    margin: 0;
    max-width: 720px;
}
.tk-footer-cta-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    justify-content: flex-end;
}
.tk-footer-outline {
    border-color: rgba(255,255,255,.34) !important;
    color: var(--secondary) !important;
}
.tk-footer-content {
    display: grid;
    grid-template-columns: 1.4fr repeat(3, 1fr);
    gap: 32px;
    padding: 54px 0 38px;
}
.tk-footer-brand p, .tk-footer-bottom { color: rgba(255,255,255,.68); }
.tk-footer-social { display: flex; gap: 10px; margin-top: 18px; }
.tk-footer-social a {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(255,255,255,.09);
    color: var(--secondary);
    text-decoration: none;
}
.tk-footer-social a:hover {
    background: var(--accent-color-2);
    color: var(--accent-color);
}
.tk-footer-links { display: flex; flex-direction: column; gap: 10px; }
.tk-footer-links h5 { color: var(--secondary); margin-bottom: 8px; }
.tk-footer-links a { color: rgba(255,255,255,.7); text-decoration: none; font-weight: 400; }
.tk-footer-links a:hover { color: var(--accent-color-2); }
.tk-footer-legal {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    padding: 16px 0px 16px 0px;
    border-top: 1px solid rgba(255,255,255,.12);
    margin-bottom: -1px;
}
.tk-footer-legal a { color: rgba(255,255,255,.55); font-size:12px; text-decoration:none; }
.tk-footer-legal a:hover { color: #aaf40f; }
.tk-footer-legal span { color: rgba(255,255,255,.25); font-size:12px; }
.tk-footer-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    border-top: 1px solid rgba(255,255,255,.08);
    padding: 16px 0;
    flex-wrap: wrap;
}
.tk-hero-title { letter-spacing: -0.05em; /*text-transform: uppercase;*/ }
.tk-template-card {
    min-height: 100%;
    border-radius: 22px;
    padding: 28px;
    background: var(--secondary);
    border: 1px solid var(--accent-color-5);
}
.tk-template-card.dark {
    background: var(--accent-color);
    color: var(--secondary);
}
.tk-template-card.dark p { color: rgba(255,255,255,.72); }
.tk-grid-3 { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; }
.tk-grid-4 { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 20px; }
.tk-grid-2 { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 20px; }
.tk-page-hero {
    padding-top: 190px;
    padding-bottom: 90px;
    background: var(--accent-color);
}
.tk-giftcard-service .service-img {
    background: var(--accent-color-3);
}
.tk-giftcard-price {
    position: absolute;
    top: 22px;
    right: 22px;
    z-index: 4;
    background: var(--accent-color-2);
    color: var(--accent-color);
    border-radius: 10px;
    padding: 8px 14px;
    font-weight: 900;
    font-size: 13px;
    box-shadow: 0 12px 30px rgba(0,0,0,.18);
}
.tk-giftcard-category {
    display: inline-flex;
    margin-top: 8px;
    color: rgba(255,255,255,.72);
    font-size: 13px;
    font-weight: 700;
}
.tk-giftcard-service .service-detail {
    align-items: flex-end;
}
.tk-page-hero h1, .tk-page-hero p { color: var(--secondary); }
.tk-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border-radius: 10px;
    padding: 8px 14px;
    background: var(--accent-color-2);
    color: var(--accent-color);
    font-weight: 800;
    margin-bottom: 18px;
}
.tk-auth-page {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 1fr 1fr;
    background: var(--accent-color-4);
}
.tk-auth-shell {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 2fr 1fr;
    background: var(--accent-color-4);
    padding: 0;
}
.tk-auth-showcase {
    background: var(--accent-color) !important;
    color: var(--secondary);
    padding: 64px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.tk-auth-showcase h2, .tk-auth-showcase p { color: var(--secondary); }
.tk-auth-showcase__list { display: grid; gap: 16px; margin-top: 28px; }
.tk-auth-benefit {
    display: flex;
    gap: 14px;
    padding: 18px;
    border-radius: 18px;
    background: rgba(255,255,255,.08);
}
.tk-auth-benefit i { color: var(--accent-color-2); font-size: 24px; }
.tk-section-kicker {
    display: inline-flex;
    width: fit-content;
    align-items: center;
    gap: 8px;
    border-radius: 10px;
    padding: 8px 14px;
    background: var(--accent-color-2);
    color: var(--accent-color);
    font-weight: 800;
    margin-bottom: 16px;
}
.tk-auth-copy, .tk-inline-note, .tk-field small { color: var(--text-color); }
.tk-auth-header { margin-bottom: 24px; }
.tk-auth-visual {
    background: var(--accent-color);
    color: var(--secondary);
    padding: 60px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.tk-auth-visual h1, .tk-auth-visual p { color: var(--secondary); }
.tk-auth-panel {
    padding: 54px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.tk-auth-card {
    background: var(--secondary);
    border-radius: 26px;
    padding: 36px;
    box-shadow: 0 20px 70px rgba(0,0,0,.08);
}
.tk-auth-shell > .tk-auth-card {
    border-radius: 0;
    box-shadow: none;
    padding: 56px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    overflow-y: auto;
}
.tk-form-grid { display: grid; gap: 18px; }
.tk-form-grid--2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.tk-field label { font-weight: 800; margin-bottom: 8px; color: var(--primary); }
.tk-input-wrap {
    min-height: 56px;
    display: flex;
    align-items: center;
    gap: 12px;
    border: 1px solid var(--accent-color-5);
    border-radius: 10px;
    padding: 0 18px;
    background: var(--accent-color-4);
}
.tk-input-wrap input, .tk-input-wrap select {
    border: 0;
    outline: 0;
    background: transparent;
    width: 100%;
    font: inherit;
}
.tk-input-wrap button { border: 0; background: transparent; }
.tk-mobile-code {
    font-weight: 700;
    color: var(--accent-color);
    white-space: nowrap;
    font-size: .9rem;
    flex-shrink: 0;
}
/* Botones de carrusel reutilizables */
.tk-gc-arrow, .tb-gc-arrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,.25);
    background: rgba(255,255,255,.08);
    color: #fff;
    cursor: pointer;
    font-size: 15px;
    transition: background .2s, border-color .2s;
    flex-shrink: 0;
}
.tk-gc-arrow:hover, .tb-gc-arrow:hover {
    background: var(--accent-color-2);
    border-color: var(--accent-color-2);
    color: var(--accent-color);
}
.tk-public-link { color: var(--accent-color); font-weight: 800; }
.tk-back-site-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--text-color);
    font-size: 13px;
    font-weight: 700;
    text-decoration: none;
    margin-bottom: 20px;
    opacity: .7;
    transition: opacity .2s, color .2s;
}
.tk-back-site-link:hover { opacity: 1; color: var(--accent-color); }
.tk-public-btn {
    min-height: 54px;
    border: 0;
    border-radius: 10px;
    background: var(--accent-color-2) !important;
    color: var(--accent-color);
    font-weight: 900;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 0 24px;
    text-decoration: none;
}
.tk-social-buttons, .tk-inline-meta, .tk-check-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 14px;
}
.tk-social-btn {
    flex: 1;
    min-height: 50px;
    border-radius: 10px;
    border: 1px solid var(--accent-color-5);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    color: var(--primary);
    text-decoration: none;
    font-weight: 800;
}
.tk-feedback-success { color: #10966f; }
.tk-feedback-error { color: #de3b62; }
.tk-password-strength { display: flex; gap: 8px; }
.tk-password-strength span { height: 7px; flex: 1; border-radius: 10px; background: var(--accent-color-5); }
.tk-password-strength span.is-active { background: var(--accent-color-2); }
.plan-select-card {
    border: 2px solid var(--accent-color-5);
    border-radius: 18px;
    padding: 16px;
    cursor: pointer;
    position: relative;
}
.plan-select-card.selected {
    border-color: var(--accent-color-2);
    background: #fbffe9;
}
.plan-select-check { display:none; position:absolute; top:14px; right:14px; color: var(--accent-color); }
.plan-select-card.selected .plan-select-check { display:block; }
@media (max-width: 1025px) {
    .tk-footer-content, .tk-grid-3, .tk-grid-4, .tk-grid-2 { grid-template-columns: 1fr 1fr; }
    .tk-footer-cta { align-items: flex-start; flex-direction: column; }
    .tk-footer-cta-actions { justify-content: flex-start; }
    .tk-auth-page, .tk-auth-shell { grid-template-columns: 1fr; }
}
@media (max-width: 767px) {
    .tk-footer-content, .tk-grid-3, .tk-grid-4, .tk-grid-2, .tk-form-grid--2 { grid-template-columns: 1fr; }
    .tk-auth-visual, .tk-auth-panel { padding: 28px; }
    .tk-auth-showcase, .tk-auth-shell > .tk-auth-card { padding: 28px; }
    .tk-auth-card { padding: 24px; }
    .tk-page-hero { padding-top: 130px; padding-bottom: 50px; }
}

/* ── Mobile Bottom Nav ──────────────────────────────────────── */
.tk-bottom-nav {
    display: none;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    height: 60px;
    background: var(--accent-color);
    border-top: 1px solid rgba(255,255,255,.12);
    z-index: 9999;
    align-items: center;
    justify-content: space-around;
    padding-bottom: env(safe-area-inset-bottom, 0px);
}
.tk-bottom-nav__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: rgba(255,255,255,.55);
    text-decoration: none;
    font-size: 10px;
    font-weight: 700;
    gap: 2px;
    flex: 1;
    height: 60px;
    text-align: center;
    transition: color .2s;
}
.tk-bottom-nav__item i {
    font-size: 20px;
    line-height: 1;
    display: block;
}
.tk-bottom-nav__item span { white-space: nowrap; }
.tk-bottom-nav__item.is-active,
.tk-bottom-nav__item:hover { color: var(--accent-color-2); }

/* Botón central GiftCard — patrón flotante */
.tk-bottom-nav__item--gift {
    position: relative;
    top: -20px;
    flex: 0 0 72px;
    color: var(--accent-color);
    height: auto;
}
.tk-bottom-nav__item--gift i {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--accent-color-2);
    color: var(--accent-color);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    box-shadow: 0 6px 24px rgba(170,244,15,.45);
    margin: 0 auto 4px;
    line-height: 1;
    font-style: normal;
}
.tk-bottom-nav__item--gift span { color: rgba(255,255,255,.7); font-size: 9px; }
.tk-bottom-nav__item--gift:hover i,
.tk-bottom-nav__item--gift.is-active i { background: #c8ff2a; }

@media (max-width: 767px) {
    .tk-bottom-nav { display: flex; }
    body.tk-template-body { padding-bottom: 60px; }
    .tk-template-body footer { display: none; }
}
