.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: #0c0d0c;
    border-top: 1px solid rgba(255,255,255,.12);
    z-index: 9999;
    align-items: stretch;
    justify-content: space-around;
    padding-bottom: env(safe-area-inset-bottom, 0px);
    overflow: hidden; /* evita scroll horizontal */
}
.tk-bottom-nav__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: rgba(255,255,255,.5);
    text-decoration: none;
    font-size: 10px;
    font-weight: 700;
    gap: 3px;
    flex: 1;
    min-width: 0;   /* permite que flex shrinkee por debajo del contenido */
    text-align: center;
    transition: color .18s;
    padding: 8px 2px;
}
.tk-bottom-nav__item i {
    font-size: 22px;
    line-height: 1;
    display: block;
    flex-shrink: 0;
}
.tk-bottom-nav__item span {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
}
.tk-bottom-nav__item.is-active { color: var(--accent-color-2); }
.tk-bottom-nav__item:hover    { color: rgba(170,244,15,.85); }
.tk-bn-avatar {
    width: 26px; height: 26px; border-radius: 50%;
    object-fit: cover; flex-shrink: 0;
    border: 2px solid rgba(255,255,255,.25);
    display: block;
}
.tk-bn-avatar--initials {
    background: #02c062; color: #fff;
    font-size: .65rem; font-weight: 800;
    display: flex; align-items: center; justify-content: center;
}
.tk-bottom-nav__item.is-active .tk-bn-avatar { border-color: #aaf40f; }

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

/* ══════════════════════════════════════════════════════════════
   PedidosYa-style Header  —  tk-py-*
   Brand: #02c062 green  /  #aaf40f lime accent
══════════════════════════════════════════════════════════════ */

/* ── Sticky shell ───────────────────────────────────────────── */
.tk-py-header {
    position: sticky;
    top: 0;
    z-index: 999;
}

/* ── Main bar ───────────────────────────────────────────────── */
.tk-py-bar {
    background: #0c0d0c;
    padding: 0 28px;
    height: 72px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, .14);
}

.tk-py-bar__inner {
    max-width: 1320px;
    margin: 0 auto;
    height: 100%;
    display: flex;
    align-items: center;
    gap: 14px;
}

/* ── Logo ───────────────────────────────────────────────────── */
.tk-py-logo {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    text-decoration: none;
}

.tk-py-logo__img {
    height: 42px;
    width: auto;
    /*filter: brightness(0) invert(1);*/
    display: block;
}

/* ── Location selector ──────────────────────────────────────── */
.tk-py-location {
    position: relative;
    flex-shrink: 0;
}

.tk-py-location__btn {
    display: flex;
    align-items: center;
    gap: 6px;
    background: rgba(255, 255, 255, .18);
    border: 1.5px solid rgba(170, 244, 15, .45);
    border-radius: 999px;
    padding: 8px 14px;
    color: #aaf40f;
    cursor: pointer;
    font-weight: 700;
    font-size: 14px;
    white-space: nowrap;
    transition: background .18s;
    line-height: 1;
}

.tk-py-location__btn:hover {
    background: rgba(255, 255, 255, .28);
}

.tk-py-location__btn i:first-child { font-size: 13px; }

.tk-py-location__text {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    line-height: 1.2;
}
.tk-py-location__kicker {
    font-size: 10px;
    font-weight: 500;
    opacity: .65;
    line-height: 1;
}
#tkCityLabel {
    font-size: 13px;
    font-weight: 700;
    max-width: 160px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.tk-py-location__arrow {
    font-size: 10px;
    transition: transform .2s;
    margin-left: 2px;
}

/* Dropdown */
.tk-py-location__dropdown {
    display: none;
    position: absolute;
    top: calc(100% + 10px);
    left: 0;
    width: 258px;
    background: #fff;
    border-radius: 18px;
    box-shadow: 0 12px 40px rgba(0, 0, 0, .16);
    padding: 18px;
    z-index: 1001;
}

.tk-py-location__dropdown.is-open { display: block; }

.tk-py-location__prompt {
    font-size: 12px;
    font-weight: 700;
    color: #6b7280;
    margin: 0 0 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid #f0f0f0;
    text-transform: uppercase;
    letter-spacing: .04em;
}

.tk-py-city-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 2px;
}

.tk-py-city-btn {
    width: 100%;
    text-align: left;
    padding: 10px 12px;
    border: 0;
    background: transparent;
    border-radius: 10px;
    cursor: pointer;
    font-size: 14px;
    font-weight: 600;
    color: #181818;
    transition: background .15s, color .15s;
    font-family: inherit;
}

.tk-py-city-btn:hover {
    background: #f0fff7;
    color: #02c062;
}

.tk-py-city-btn.is-selected {
    background: #e6fff3;
    color: #02c062;
    font-weight: 800;
}

/* ── Search bar ─────────────────────────────────────────────── */
.tk-py-search {
    flex: 1;
    min-width: 0;
    display: flex;
    align-items: center;
    background: #fff;
    border-radius: 999px;
    height: 48px;
    padding: 4px 4px 4px 18px;
    box-shadow: 0 2px 14px rgba(0, 0, 0, .10);
    overflow: hidden;
}

.tk-py-search__input {
    flex: 1;
    min-width: 0;
    border: 0;
    outline: 0;
    background: transparent;
    font-size: 14px;
    color: #181818;
    font-family: inherit;
}

.tk-py-search__input::placeholder { color: #9ca3af; }

.tk-py-search__btn {
    flex-shrink: 0;
    background: #0c0d0c;
    border: 0;
    border-radius: 999px;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #aaf40f;
    cursor: pointer;
    font-size: 15px;
    transition: background .18s;
}

.tk-py-search__btn:hover { background: #019f51; }

/* ── Wizard button ──────────────────────────────────────────── */
.tk-py-wizard-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 9px 18px;
    border-radius: 999px;
    background: #aaf40f;
    color: #0c0d0c;
    text-decoration: none;
    font-size: 13px;
    font-weight: 800;
    white-space: nowrap;
    flex-shrink: 0;
    transition: background .18s, transform .15s;
}
.tk-py-wizard-btn:hover {
    background: #c4ff2e;
    color: #0c0d0c;
    transform: translateY(-1px);
}
.tk-py-wizard-btn i { font-size: 14px; }

/* ── Auth buttons ───────────────────────────────────────────── */
.tk-py-auth {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}

.tk-py-auth__login {
    padding: 9px 20px;
    border-radius: 999px;
    border: 2px solid rgb(170 244 15 / 65%);
    color: #aaf40f;
    text-decoration: none;
    font-weight: 700;
    font-size: 14px;
    white-space: nowrap;
    transition: background .18s;
    line-height: 1;
}

.tk-py-auth__login:hover {
    background: rgba(170, 244, 15, .18);
    color: #aaf40f;
}

.tk-py-auth__register {
    padding: 9px 20px;
    border-radius: 999px;
    background: #aaf40f;
    color: #0c0d0c;
    text-decoration: none;
    font-weight: 800;
    font-size: 14px;
    white-space: nowrap;
    border: 2px solid #aaf40f;
    transition: opacity .18s;
    line-height: 1;
}

.tk-py-auth__register:hover {
    opacity: .9;
    color: #181818;
}

/* ── Mobile hamburger ───────────────────────────────────────── */
.tk-py-mobile-toggle {
    display: none;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    background: rgba(255, 255, 255, .18);
    border: 1.5px solid rgba(170, 244, 15, .45);
    border-radius: 12px;
    color: #aaf40f;
    cursor: pointer;
    font-size: 17px;
    flex-shrink: 0;
    transition: background .18s;
    margin-left: auto;
}

.tk-py-mobile-toggle:hover { background: rgba(255, 255, 255, .28); }

/* ── Mobile search row ──────────────────────────────────────── */
.tk-py-mobile-search {
    display: none;
    background: #0c0d0c;
    padding: 0 16px 14px;
}

.tk-py-mobile-search__wrap {
    display: flex;
    align-items: center;
    gap: 10px;
    background: #fff;
    border-radius: 999px;
    height: 46px;
    padding: 0 18px;
}

.tk-py-mobile-search__wrap i { color: #9ca3af; font-size: 15px; flex-shrink: 0; }

.tk-py-mobile-search__wrap input {
    flex: 1;
    border: 0;
    outline: 0;
    background: transparent;
    font-size: 14px;
    font-family: inherit;
    color: #181818;
    min-width: 0;
}

.tk-py-mobile-search__wrap input::placeholder { color: #9ca3af; }

/* ── Hero section offset ────────────────────────────────────── */
/* Remove old absolute-navbar (new header is sticky, in normal flow) */
.tk-template-body .navbar-container { display: none !important; }
/* Reduce hero top padding — navbar no longer overlaps it */
.tk-template-body .banner-home-container { padding-top: 90px; }

/* ── Responsive ─────────────────────────────────────────────── */

/* Tablet: hide auth text, keep icons */
@media (max-width: 1100px) {
    .tk-py-auth__login { display: none; }
    .tk-py-auth__register { padding: 9px 16px; font-size: 13px; }
}

/* Tablet/Mobile breakpoint */
@media (max-width: 800px) {
    .tk-py-bar { padding: 0 16px; height: 64px; }
    .tk-py-bar__inner { gap: 10px; }

    /* Hide desktop search + auth on small screens */
    .tk-py-search { display: none; }
    .tk-py-auth   { display: none; }

    /* Wizard: solo ícono antes del toggle */
    .tk-py-wizard-btn {
        display: flex;
        padding: 0;
        width: 38px;
        height: 38px;
        border-radius: 50%;
        justify-content: center;
        gap: 0;
    }
    .tk-py-wizard-btn span { display: none; }
    .tk-py-wizard-btn i { font-size: 18px; }

    /* Show mobile toggles */
    .tk-py-mobile-toggle { display: flex; }
    .tk-py-mobile-search { display: block; }

    /* Location btn shrinks */
    .tk-py-location__btn { padding: 7px 12px; font-size: 13px; }

    /* Dropdown position fix for small screens */
    .tk-py-location__dropdown {
        left: 0;
        right: auto;
        width: calc(100vw - 32px);
        max-width: 300px;
    }
}

@media (max-width: 420px) {
    .tk-py-logo__img { height: 20px; }
    .tk-py-mobile-search { padding: 0 12px 12px; border-radius: 0px 00px 20px 20px; }
}

/* ══════════════════════════════════════════════════════════════
   HOME PAGE  —  hm-*
   Background: #fefefe  |  Titles: #0c0d0c  |  Accent: #02c062
══════════════════════════════════════════════════════════════ */

/* ── Shell & containers ─────────────────────────────────────── */
.hm-shell {
    background: #fefefe;
    min-height: 100vh;
}

.hm-container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 24px;
}

/* ── Sections ───────────────────────────────────────────────── */
.hm-section {
    padding: 48px 0;
}

.hm-section--alt {
    background: #f7f8f9;
}

.hm-section-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 28px;
    flex-wrap: wrap;
}

.hm-section-title {
    font-size: clamp(20px, 3vw, 26px);
    font-weight: 800;
    color: #0c0d0c;
    margin: 0 0 4px;
    letter-spacing: -.02em;
    line-height: 1.2;
}

.hm-section-sub {
    font-size: 14px;
    color: #6b7280;
    margin: 0;
}

.hm-see-all {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 14px;
    font-weight: 700;
    color: #02c062;
    text-decoration: none;
    white-space: nowrap;
    flex-shrink: 0;
}

.hm-see-all:hover { color: #019f51; text-decoration: underline; }

/* ── Buttons ────────────────────────────────────────────────── */
.hm-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 24px;
    border-radius: 999px;
    font-weight: 700;
    font-size: 15px;
    text-decoration: none;
    transition: opacity .18s, transform .15s;
    cursor: pointer;
    border: 0;
}
.hm-btn:hover { opacity: .88; transform: translateY(-1px); }
.hm-btn--green { background: #02c062; color: #fff; }
.hm-btn--white { background: #fff; color: #0c0d0c; }

/* ── CATEGORIES ROW  (PedidosYa style) ──────────────────────── */
.hm-cats { background: #fff; padding: 0; }

.hm-cats__wrapper {
    position: relative;
    max-width: 1280px;
    margin: 0 auto;
}

.hm-cats__track {
    display: flex;
    align-items: flex-start;
    overflow-x: auto;
    flex-wrap: nowrap;
    gap: 12px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
    padding: 24px 52px 16px;
    cursor: grab;
    user-select: none;
}
.hm-cats__track.is-dragging { cursor: grabbing; }
.hm-cats__track::-webkit-scrollbar { display: none; }

/* ── Arrow buttons ───────────────────────────────────────────── */
.hm-cats__btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    border: none;
    background: #ffffff00;
    /*box-shadow: 0 2px 8px rgba(0,0,0,.16);*/  
    color: #02c062;
    font-size: 24px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 150ms, opacity 150ms;
}
.hm-cats__btn:hover { color: #02c062; }
.hm-cats__btn--prev { left: 6px; }
.hm-cats__btn--next { right: 6px; }
.hm-cats__btn[disabled] { opacity: 0.3; pointer-events: none; }

/* ── Each item ───────────────────────────────────────────────── */
.hm-cat-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    width: 132px;
    flex-shrink: 0;
    text-decoration: none;
    cursor: pointer;
    background: #F3F2F4;
    border-radius: 16px;
    overflow: hidden;
    transition: background 150ms cubic-bezier(0.42,0,0.58,1);
    box-sizing: border-box;
}
.hm-cat-item:hover  { background: #E7E6E9; }
.hm-cat-item:active { background: #DBDADE; }

/* Imagen — proporción original, sin recorte */
.hm-cat-item__circle {
    width: 100%;
    display: block;
    overflow: hidden;
}
.hm-cat-item__img {
    width: 100%;
    height: auto;
    display: block;
}

/* Ícono FA */
.hm-cat-item__icon {
    font-size: 30px;
    line-height: 1;
    color: #100423;
}

/* Label */
.hm-cat-item__label {
    height: 36px;
    padding: 10px 8px 12px 0px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    font-size: 11px;
    font-weight: 800;
    line-height: 16px;
    color: #0c0d0c;
    text-align: center;
    box-sizing: border-box;
    width: 100%;
}

/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width: 640px) {
    .hm-cats__track { padding: 16px 12px; gap: 8px; }
    .hm-cats__btn   { display: none; }
    .hm-cat-item    { width: 88px; }
    .hm-cat-item__icon { font-size: 24px; }
    .hm-cat-item__label { font-size: 11px; }
}

/* ── PROMO BANNERS ──────────────────────────────────────────── */
.hm-banners { padding-top: 28px; padding-bottom: 12px; }

.hm-banners .hm-container {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.hm-banner-card {
    display: block;
    border-radius: 20px;
    overflow: hidden;
    text-decoration: none;
    position: relative;
    min-height: 180px;
    transition: transform .2s, box-shadow .2s;
}

.hm-banner-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 40px rgba(0,0,0,.12);
}

.hm-banner-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    min-height: 180px;
}

/* Styled fallback banners */
.hm-banner-card--green {
    background: linear-gradient(135deg, #02c062 0%, #019f51 100%);
    display: flex;
    align-items: stretch;
    min-height: 180px;
}

.hm-banner-card--dark {
    background: linear-gradient(135deg, #0c0d0c 0%, #1e2019 100%);
    display: flex;
    align-items: stretch;
    min-height: 180px;
}

.hm-banner-card__body {
    padding: 32px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    flex: 1;
    z-index: 1;
}

.hm-banner-card__kicker {
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: rgba(255,255,255,.7);
}

.hm-banner-card__title {
    font-size: clamp(18px, 2.5vw, 24px);
    font-weight: 800;
    color: #fff;
    line-height: 1.25;
    margin: 0;
}

.hm-banner-card__cta {
    margin-top: auto;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: rgba(255,255,255,.18);
    border: 1px solid rgba(255,255,255,.35);
    color: #fff;
    font-size: 13px;
    font-weight: 700;
    padding: 8px 16px;
    border-radius: 999px;
    width: fit-content;
    transition: background .18s;
}

.hm-banner-card:hover .hm-banner-card__cta {
    background: rgba(255,255,255,.3);
}

.hm-banner-card__deco {
    position: absolute;
    right: 24px;
    bottom: 16px;
    font-size: 72px;
    opacity: .25;
    pointer-events: none;
    line-height: 1;
}

/* Small extra banners */
.hm-banner-card--sm {
    min-height: 120px;
}

/* ── Banner slider — solo mobile ────────────────────────────── */
.hm-banner-dots { display: none; }

@media (max-width: 640px) {
    .hm-banners { padding-bottom: 0; }
    .hm-banner-slider {
        display: flex !important;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        gap: 0;
        padding: 0 16px;
    }
    .hm-banner-slider::-webkit-scrollbar { display: none; }
    .hm-banner-slider .hm-banner-card {
        flex: 0 0 calc(100vw - 48px);
        scroll-snap-align: center;
        min-height: 160px;
        margin: 0 6px;
    }
    .hm-banner-dots {
        display: flex;
        justify-content: center;
        gap: 6px;
        padding: 10px 0 4px;
    }
    .hm-banner-dot {
        width: 6px; height: 6px;
        border-radius: 50%;
        background: #ccc;
        border: none;
        padding: 0;
        cursor: pointer;
        transition: background .2s, transform .2s;
    }
    .hm-banner-dot.is-active {
        background: #02c062;
        transform: scale(1.4);
    }
}

/* ── HORIZONTAL CARD SCROLL ─────────────────────────────────── */
.hm-cards-scroll {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    padding-bottom: 4px;
    scrollbar-width: none;
    -ms-overflow-style: none;
    -webkit-overflow-scrolling: touch;
    cursor: grab;
    user-select: none;
}
.hm-cards-scroll.is-dragging { cursor: grabbing; }
.hm-cards-scroll::-webkit-scrollbar { display: none; }

/* ── GC CARD ────────────────────────────────────────────────── */
.hm-card {
    flex: 0 0 220px;
    background: #fff;
    border-radius: 18px;
    overflow: hidden;
    border: 1px solid #f0f0f0;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    display: flex;
    flex-direction: column;
    transition: transform .25s, box-shadow .25s;
}

.hm-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 16px 40px rgba(0,0,0,.10);
}

.hm-card__img-wrap {
    position: relative;
    display: block;
    height: 160px;
    overflow: hidden;
    background: #f4f4f4;
    flex-shrink: 0;
}

.hm-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .35s;
}

.hm-card:hover .hm-card__img { transform: scale(1.05); }

.hm-card__placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 52px;
    background: #f0f0f0;
}

.hm-card__cat-badge {
    position: absolute;
    bottom: 8px;
    left: 8px;
    background: rgba(0,0,0,.65);
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    padding: 4px 8px;
    border-radius: 999px;
    backdrop-filter: blur(4px);
}

.hm-card__featured-badge {
    position: absolute;
    top: 8px;
    left: 8px;
    background: #aaf40f;
    color: #0c0d0c;
    font-size: 10px;
    font-weight: 800;
    padding: 4px 8px;
    border-radius: 999px;
}

/* Logo inline (20/80 row) */
.hm-card__info-row {
    display: flex;
    align-items: center;
    gap: 7px;
}
.hm-card__logo-inline {
    flex: 0 0 52px;
    width: 52px;
    height: 52px;
    background: #fff;
    border-radius: 10px;
    padding: 3px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0,0,0,.10);
    border: 1px solid #f0f0f0;
}
.hm-card__logo-inline img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.hm-card__info-text { flex: 1; min-width: 0; }

/* Carousel controls */
.hm-carousel-controls {
    display: flex;
    align-items: center;
    gap: 8px;
}
.hm-carousel-btn {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 1.5px solid #e5e7eb;
    background: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    color: #0c0d0c;
    transition: background .18s, border-color .18s, color .18s;
    flex-shrink: 0;
}
.hm-carousel-btn:hover {
    background: #0c0d0c;
    color: #fff;
    border-color: #0c0d0c;
}
.hm-carousel-btn:disabled {
    opacity: .35;
    pointer-events: none;
}

.hm-card__body {
    padding: 10px;
    display: flex;
    flex-direction: column;
    gap: 7px;
    flex: 1;
}

.hm-card__brand {
    font-size: 10px;
    font-weight: 900;
    color: #02c062;
    text-transform: uppercase;
    letter-spacing: .06em;
    line-height: 1.4;
    height: calc(2 * 1.4em);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.hm-card__brand--link {
    text-decoration: none;
    cursor: pointer;
}
.hm-card__brand--link:hover {
    color: #aaf40f;
    text-decoration: underline;
}

.hm-card__name {
    font-size: 12px;
    font-weight: 800;
    color: #0c0d0c;
    margin: 10px 0px 0px 0px;
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.hm-card__name a { color: inherit; text-decoration: none; font-size: 12px; font-weight: 800;}
.hm-card__name a:hover { color: #181818; }

/* Descuento en card */
.hm-card__discount-row {
    display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
}
.hm-card__price-original {
    font-size: 11px; color: #9ca3af;
    text-decoration: line-through; font-weight: 600;
}
.hm-card__price-final {
    font-size: 15px; font-weight: 900; color: #02c062;
}
.hm-card__discount-badge {
    background: #ef4444; color: #fff;
    font-size: 10px; font-weight: 900;
    padding: 2px 6px; border-radius: 999px;
    letter-spacing: .3px;
}

.hm-card__dens-wrap {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.hm-card__desde {
    font-size: 9px;
    font-weight: 800;
    color: #9ca3af;
    letter-spacing: .4px;
}

.hm-card__dens {
    display: flex;
    flex-wrap: nowrap;
    gap: 4px;
    overflow-x: auto;
    scrollbar-width: none;
    cursor: grab;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 2px;
}
.hm-card__dens::-webkit-scrollbar { display: none; }
.hm-card__dens.is-dragging { cursor: grabbing; }

.hm-card__den-chip {
    background: #f4f4f4;
    color: #444;
    font-size: 10px;
    font-weight: 700;
    padding: 3px 8px;
    border-radius: 999px;
    flex-shrink: 0;
    white-space: nowrap;
}

.hm-card__cta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    padding: 10px;
    border-radius: 12px;
    background: #0c0d0c;
    color: #aaf40f;
    text-decoration: none;
    font-size: 13px;
    font-weight: 800;
    margin-top: 4px;
    transition: background .18s, color .18s;
}

.hm-card__cta:hover {
    background: #aaf40f;
    color: #0c0d0c;
}

/* ── BRANDS STRIP ───────────────────────────────────────────── */
.hm-brands { background: #fff; }

.hm-brands__viewport {
    overflow: hidden;
    margin-top: 24px;
}
.hm-brands__carousel {
    display: flex;
    gap: 14px;
    width: max-content;
    animation: hmBrandsScroll 28s linear infinite;
}
.hm-brands__carousel:hover { animation-play-state: paused; }

@keyframes hmBrandsScroll {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

.hm-brand-logo {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 80px;
    height: 80px;
    border-radius: 16px;
    border: 1px solid #f0f0f0;
    background: #fafafa;
    overflow: hidden;
    padding: 0px;
    text-decoration: none;
    transition: border-color .18s, transform .18s, box-shadow .18s;
    flex-shrink: 0;
}

.hm-brand-logo:hover {
    border-color: #02c062;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(2,192,98,.15);
}

.hm-brand-logo img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.hm-brand-logo__initials {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    font-weight: 900;
    color: #fff;
    border-radius: inherit;
    letter-spacing: .5px;
}

/* ── ZONA SECTION ───────────────────────────────────────────── */
.hm-zone { background: #fff; }

.hm-zone__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    align-items: center;
}

.hm-zone__badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: #e0faea;
    color: #02c062;
    font-size: 13px;
    font-weight: 700;
    padding: 6px 14px;
    border-radius: 999px;
    margin-bottom: 14px;
}

.hm-zone__text .hm-section-title { margin-bottom: 8px; }
.hm-zone__text .hm-section-sub   { margin-bottom: 24px; }

.hm-zone__cards {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.hm-zone-card {
    flex: 1 1 120px;
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid #f0f0f0;
    text-decoration: none;
    background: #fff;
    transition: transform .2s, box-shadow .2s;
}

.hm-zone-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 28px rgba(0,0,0,.10);
}

.hm-zone-card img {
    width: 100%;
    height: 90px;
    object-fit: cover;
    display: block;
}

.hm-zone-card__placeholder {
    width: 100%;
    height: 90px;
    background: #f4f4f4;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 36px;
}

.hm-zone-card__info {
    padding: 10px;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.hm-zone-card__info span {
    font-size: 12px;
    font-weight: 600;
    color: #0c0d0c;
}

.hm-zone-card__info strong {
    font-size: 14px;
    font-weight: 900;
    color: #02c062;
}

/* ── OCCASIONS GRID ─────────────────────────────────────────── */
.hm-occasions__grid {
    display: grid;
    grid-template-columns: repeat(8, 1fr);
    gap: 12px;
    margin-top: 24px;
}

.hm-occ-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    padding: 20px 10px;
    border-radius: 18px;
    background: var(--occ-bg, #f0f0f0);
    text-decoration: none;
    transition: transform .2s, box-shadow .2s;
}

.hm-occ-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 28px rgba(0,0,0,.10);
}

.hm-occ-card__icon {
    width: 52px;
    height: 52px;
    background: var(--occ-icon-bg, #999);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
    line-height: 1;
}

.hm-occ-card__label {
    font-size: 12px;
    font-weight: 700;
    color: #0c0d0c;
    text-align: center;
    line-height: 1.3;
}

/* ── CTA STRIP ──────────────────────────────────────────────── */
.hm-cta-strip {
    background: #0c0d0c;
    padding: 48px 0;
}

.hm-cta-strip__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
    flex-wrap: wrap;
}

.hm-cta-strip__text h3 {
    font-size: 24px;
    font-weight: 800;
    color: #fff;
    margin: 0 0 6px;
}

.hm-cta-strip__text p {
    color: rgba(255,255,255,.65);
    margin: 0;
    font-size: 15px;
}

/* ── RESPONSIVE ─────────────────────────────────────────────── */

@media (max-width: 1100px) {
    .hm-occasions__grid { grid-template-columns: repeat(4, 1fr); }
}

@media (max-width: 900px) {
    .hm-banners .hm-container { grid-template-columns: 1fr; }
    .hm-zone__inner { grid-template-columns: 1fr; gap: 32px; }
    .hm-occasions__grid { grid-template-columns: repeat(4, 1fr); }
}

@media (max-width: 640px) {
    .hm-section        { padding: 20px 0; }
    .hm-section-sub    { font-size: 13px; margin-top: 2px; }
    .hm-section-head   { margin-bottom: 12px; }
    .hm-banners        { padding-top: 12px; padding-bottom: 0; }
    .hm-container      { padding: 0 16px; }
    .hm-cats__track    { padding: 12px 16px; }
    .hm-occasions__grid { grid-template-columns: repeat(4, 1fr); gap: 8px; }
    .hm-occ-card       { padding: 14px 8px; }
    .hm-occ-card__icon { width: 44px; height: 44px; font-size: 22px; }
    .hm-occ-card__label { font-size: 11px; }
    .hm-brands__grid   { gap: 8px; }
    .hm-brand-logo     { width: 66px; height: 66px; }
    .hm-card           { flex: 0 0 180px; }
    .hm-card__img-wrap { height: 130px; }
    .hm-cta-strip      { padding: 28px 0; }
    .hm-cta-strip__inner { flex-direction: column; text-align: center; }
    .hm-zone__cards    { display: none; }
    .hm-banner-card__body  { padding: 22px; }
    .hm-banner-card__title { font-size: 18px; }
}

@media (max-width: 420px) {
    .hm-occasions__grid { grid-template-columns: repeat(4, 1fr); gap: 6px; }
    .hm-card { flex: 0 0 160px; }
}


/* ══════════════════════════════════════════════════════════════
   LOCATION MODAL  —  tkloc-*
   Geolocation + Leaflet/OSM + Nominatim search
══════════════════════════════════════════════════════════════ */

/* ── Overlay ─────────────────────────────────────────────────── */
.tkloc-overlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(0,0,0,.55);
    backdrop-filter: blur(3px);
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 60px 16px 16px;
    opacity: 0;
    pointer-events: none;
    transition: opacity .22s;
}

.tkloc-overlay.is-open {
    opacity: 1;
    pointer-events: all;
}

/* ── Modal box ───────────────────────────────────────────────── */
.tkloc-modal {
    background: #fff;
    border-radius: 24px;
    width: 100%;
    max-width: 540px;
    overflow-y: auto;
    overflow-x: hidden;
    display: flex;
    flex-direction: column;
    max-height: calc(100vh - 76px);
    box-shadow: 0 24px 60px rgba(0,0,0,.22);
    transform: translateY(-12px);
    transition: transform .22s;
}

.tkloc-overlay.is-open .tkloc-modal {
    transform: translateY(0);
}

/* ── Modal header ────────────────────────────────────────────── */
.tkloc-modal__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 22px 24px 18px;
    border-bottom: 1px solid #f0f0f0;
    flex-shrink: 0;
}

.tkloc-modal__head-text {
    display: flex;
    align-items: center;
    gap: 14px;
}

.tkloc-modal__head-icon {
    width: 40px;
    height: 40px;
    background: #e0faea;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #02c062;
    font-size: 16px;
    flex-shrink: 0;
}

.tkloc-modal__title {
    font-size: 17px;
    font-weight: 800;
    color: #0c0d0c;
    margin: 0 0 2px;
}

.tkloc-modal__sub {
    font-size: 12px;
    color: #6b7280;
    margin: 0;
}

.tkloc-modal__close {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 0;
    background: #f4f4f4;
    color: #555;
    font-size: 14px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: background .15s;
}

.tkloc-modal__close:hover { background: #e5e5e5; }

/* ── Geo strip ───────────────────────────────────────────────── */
.tkloc-geo-strip {
    padding: 14px 24px;
    background: #f9fafb;
    border-bottom: 1px solid #f0f0f0;
    flex-shrink: 0;
}

/* idle / loading / result rows */
#tkLocGeoIdle,
#tkLocGeoLoading,
#tkLocGeoResult {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 13px;
    color: #444;
}

/* "Usar mi ubicación actual" button */
.tkloc-geo-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 18px;
    border-radius: 999px;
    border: 1.5px solid #02c062;
    background: #f0fff7;
    color: #02c062;
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    font-family: inherit;
    transition: background .15s, color .15s;
}
.tkloc-geo-btn:hover { background: #02c062; color: #fff; }
.tkloc-geo-btn i { font-size: 14px; }

.tkloc-geo-btn--retry {
    margin-top: 10px;
    padding: 8px 16px;
    font-size: 12px;
}

/* spinner */
.tkloc-spin {
    width: 16px;
    height: 16px;
    border: 2px solid #d1fae5;
    border-top-color: #02c062;
    border-radius: 50%;
    animation: tkLocSpin .7s linear infinite;
    flex-shrink: 0;
}
@keyframes tkLocSpin { to { transform: rotate(360deg); } }

/* "Usar esta" button */
.tkloc-detected__use {
    margin-left: auto;
    padding: 5px 14px;
    border-radius: 999px;
    border: 1.5px solid #02c062;
    background: transparent;
    color: #02c062;
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
    white-space: nowrap;
    font-family: inherit;
    transition: background .15s, color .15s;
    flex-shrink: 0;
}
.tkloc-detected__use:hover { background: #02c062; color: #fff; }

/* denied box */
.tkloc-denied-box {
    background: #fff5f5;
    border: 1px solid #fecaca;
    border-radius: 12px;
    padding: 14px 16px;
    display: flex;
    align-items: flex-start;
    gap: 12px;
    flex-wrap: wrap;
}
.tkloc-denied-icon {
    color: #ef4444;
    font-size: 18px;
    flex-shrink: 0;
    margin-top: 2px;
}
.tkloc-denied-box > div {
    flex: 1;
    min-width: 180px;
}
.tkloc-denied-box strong {
    display: block;
    font-size: 13px;
    font-weight: 800;
    color: #b91c1c;
    margin-bottom: 4px;
}
.tkloc-denied-box p {
    font-size: 12px;
    color: #6b7280;
    margin: 0;
    line-height: 1.5;
}
.tkloc-denied-box em { font-style: normal; font-weight: 700; color: #374151; }

/* ── "o buscá tu ubicación" divider ─────────────────────────── */
.tkloc-or {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 24px 0;
    flex-shrink: 0;
}
.tkloc-or::before,
.tkloc-or::after {
    content: '';
    flex: 1;
    height: 1px;
    background: #e5e7eb;
}
.tkloc-or span {
    font-size: 12px;
    color: #9ca3af;
    white-space: nowrap;
    font-weight: 500;
}

/* ── Search ──────────────────────────────────────────────────── */
.tkloc-search-wrap {
    position: relative;
    padding: 14px 24px 0;
    flex-shrink: 0;
}

.tkloc-search-icon {
    position: absolute;
    left: 38px;
    top: 50%;
    transform: translateY(-30%);
    color: #9ca3af;
    font-size: 14px;
    pointer-events: none;
}

.tkloc-search-input {
    width: 100%;
    height: 46px;
    border: 1.5px solid #e5e7eb;
    border-radius: 12px;
    padding: 0 16px 0 40px;
    font-size: 14px;
    color: #0c0d0c;
    background: #fff;
    outline: none;
    font-family: inherit;
    transition: border-color .15s;
}

.tkloc-search-input:focus { border-color: #02c062; }

.tkloc-suggestions {
    display: none;
    position: absolute;
    left: 24px;
    right: 24px;
    top: calc(100% - 2px);
    background: #fff;
    border: 1.5px solid #e5e7eb;
    border-top: 0;
    border-radius: 0 0 12px 12px;
    box-shadow: 0 8px 24px rgba(0,0,0,.10);
    z-index: 10;
    max-height: 220px;
    overflow-y: auto;
}

.tkloc-sug-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    width: 100%;
    text-align: left;
    border: 0;
    background: transparent;
    padding: 11px 16px;
    cursor: pointer;
    font-size: 13px;
    color: #181818;
    font-family: inherit;
    transition: background .12s;
    border-bottom: 1px solid #f5f5f5;
}

.tkloc-sug-item:last-child { border-bottom: 0; }
.tkloc-sug-item:hover { background: #f0fff7; }

.tkloc-sug-icon {
    color: #02c062;
    font-size: 13px;
    margin-top: 1px;
    flex-shrink: 0;
}

.tkloc-sug-name { line-height: 1.4; }

.tkloc-sug-empty {
    padding: 14px 16px;
    font-size: 13px;
    color: #9ca3af;
    text-align: center;
}

/* ── Map ─────────────────────────────────────────────────────── */
.tkloc-map {
    height: 260px;
    flex-shrink: 0;
    margin: 12px 24px 0;
    border-radius: 14px;
    overflow: hidden;
    border: 1px solid #e5e7eb;
    z-index: 1;
    background: #f0f0f0;
}

/* ── Selected label ──────────────────────────────────────────── */
.tkloc-selected-row {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 24px 0;
    font-size: 13px;
    color: #444;
    flex-shrink: 0;
}

/* ── Accept button ───────────────────────────────────────────── */
.tkloc-accept {
    margin: 14px 24px 20px;
    height: 52px;
    border-radius: 14px;
    border: 0;
    background: #02c062;
    color: #fff;
    font-size: 15px;
    font-weight: 800;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    transition: background .18s, transform .15s;
    flex-shrink: 0;
    font-family: inherit;
}

.tkloc-accept:hover {
    background: #019f51;
    transform: translateY(-1px);
}

/* ── Custom map marker (CSS pin, no FontAwesome) ─────────────── */
.tkloc-marker-wrap { background: transparent; border: none; }

.tkloc-marker-pin {
    width: 22px;
    height: 22px;
    background: #02c062;
    border: 3px solid #fff;
    border-radius: 50% 50% 50% 0;
    transform: rotate(-45deg);
    box-shadow: 0 3px 10px rgba(0,0,0,.35);
    position: relative;
}
.tkloc-marker-pin::after {
    content: '';
    position: absolute;
    inset: 4px;
    background: #fff;
    border-radius: 50%;
}

/* ── Leaflet attribution fix ─────────────────────────────────── */
.tkloc-map .leaflet-control-attribution {
    font-size: 9px;
    opacity: .7;
}

/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width: 600px) {
    .tkloc-overlay { padding: 0; align-items: flex-end; }
    .tkloc-modal {
        border-radius: 24px 24px 0 0;
        max-height: 92vh;
    }
    .tkloc-map { height: 200px; }
    .hm-card__cta {
        font-size: 11px;
    }
}
