/* ═══════════════════════════════════════════════════════════════
   TD Homepage — combined stylesheet
   Includes: slider · search-form · job section · job cards
═══════════════════════════════════════════════════════════════ */

/* ── Reset / container ── */
#td-homepage { background: #F4F4F5; }

.td-hp-container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 16px;
}

@media (min-width: 1280px) { .td-hp-container { padding: 0 20px; } }

/* ── Global SVG reset — override Flatsome's svg { margin-right:10px; max-width:50px } ── */
#td-homepage svg,
.ind-modal svg,
.td-geo-indicator svg {
    margin-right: 0 !important;
    max-width: none !important;
}

/* ─────────────────────────────────────────────────────────────
   HERO SLIDER  (from html/assets/css/slider.css)
───────────────────────────────────────────────────────────── */
#hero-slider { position:relative; width:100%; overflow:hidden; background:#fff; }

#sliderWrapper { position:relative; overflow:hidden; height:420px; }

#sliderTrack {
    display:flex; height:100%;
    transition:transform .5s ease-in-out; will-change:transform;
}

.slider-slide { flex-shrink:0; height:100%; }
.slider-slide:nth-child(1) { background:linear-gradient(135deg,#F97316 0%,#FBBF24 100%); }
.slider-slide:nth-child(2) { background:linear-gradient(135deg,#991B1B 0%,#DC2626 100%); }
.slider-slide:nth-child(3) { background:linear-gradient(135deg,#1E3A8A 0%,#1D4ED8 60%,#2563EB 100%); }

.slider-inner {
    display:flex; align-items:center; justify-content:space-between;
    height:100%; gap:24px; flex-wrap:wrap;
}
.slider-text { color:#fff; max-width:520px; text-shadow:0 1px 4px rgba(0,0,0,.4); }
.slider-tagline { font-size:14px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; opacity:.85; margin:0 0 8px; }
.slider-title  { font-size:clamp(26px,3.3vw,42px); font-weight:700; line-height:1.25; margin:0 0 16px; }
.slider-desc   { font-size:17px; opacity:.9; margin:0 0 24px; }
.slider-cta    { display:inline-block; background:#fff; font-weight:700; padding:12px 28px; border-radius:9999px; text-decoration:none; transition:opacity .2s; }
.slider-cta:hover { opacity:.9; }
.slider-slide:nth-child(1) .slider-cta { color:#EA580C; }
.slider-slide:nth-child(2) .slider-cta { color:#DC2626; }
.slider-slide:nth-child(3) .slider-cta { color:#1D4ED8; }
.slider-img { height:260px; object-fit:contain; border-radius:12px; }

.slider-btn {
    position:absolute; top:50%; transform:translateY(-50%); z-index:10;
    background:rgba(255,255,255,.85) !important; border:none !important; cursor:pointer;
    border-radius:9999px; width:40px; height:40px !important;
    display:flex !important; align-items:center; justify-content:center;
    box-shadow:0 2px 8px rgba(0,0,0,.15); transition:background .2s;
    padding:0 !important; color:#374151 !important; line-height:1 !important;
    text-transform:none !important;
}
.slider-btn:hover { background:#fff !important; }
.slider-btn svg { width:20px !important; height:20px !important; margin:0 !important; flex-shrink:0; }
.slider-btn svg path { fill:none !important; stroke:#374151; }
#sliderPrev { left:16px; }
#sliderNext { right:16px; }

#sliderDots {
    position:absolute; bottom:16px; left:50%; transform:translateX(-50%);
    display:flex; gap:8px; z-index:10;
}
.sdot { width:10px !important; height:10px !important; min-width:0 !important; min-height:0 !important; border-radius:9999px !important; background:#fff !important; border:none !important; cursor:pointer; padding:0 !important; opacity:.4; line-height:1 !important; transition:opacity .3s; }
.sdot.active { opacity:1; }

@media (max-width:768px) {
    #sliderWrapper { height:300px; }
    .slider-inner { justify-content:center; padding:0 16px; }
    .slider-img { display:none; }
    .slider-title { font-size:24px; }
}

/* ─────────────────────────────────────────────────────────────
   SEARCH SECTION
───────────────────────────────────────────────────────────── */
#td-home-search {
    background:#FFF7ED;
    padding:32px 0 28px;
    border-bottom:1px solid #FED7AA;
}

.td-hp-search-wrap {
    display:flex;
    gap:24px;
    align-items:flex-start;
}

.td-hp-search-left { flex:1; min-width:0; display:flex; flex-direction:column; gap:16px; }

.td-hp-search-heading {}
.td-hp-search-title { font-size:24px; font-weight:700; color:#1c1917; letter-spacing:-.5px; line-height:1.3; }
.td-hp-search-sub   { font-size:16px; color:#78716c; margin-top:4px; }

/* ── Search bar — full override chống Flatsome theme ── */
#td-home-search #search-form { position:relative; z-index:100; }

/* Bar pill */
#td-home-search .sf-bar {
    display:flex !important; flex-wrap:nowrap !important;
    align-items:center !important; justify-content:flex-start !important;
    background:#fff !important; border-radius:9999px !important;
    box-shadow:0 2px 16px rgba(0,0,0,.12) !important;
    padding:6px 6px 6px 16px !important;
    gap:0 !important; height:56px !important;
    border:none !important; margin:0 !important;
}

/* Fields */
#td-home-search .sf-field {
    position:relative !important; flex:1 !important;
    display:flex !important; align-items:center !important;
    height:100% !important; min-width:0 !important;
    padding:0 !important; margin:0 !important;
    border:none !important; background:transparent !important;
}
#td-home-search .sf-field + .sf-field {
    border-left:1px solid #E7E7E8 !important;
    margin-left:4px !important; padding-left:4px !important;
}

/* Icon */
#td-home-search .sf-icon {
    color:#939295; flex-shrink:0; display:block !important;
    margin:0 !important; padding:0 !important;
}

/* Keyword input — chỉ direct child, không ảnh hưởng input bên trong dropdown */
#td-home-search .sf-field > input[type="text"],
#td-home-search .sf-field > input[type="search"] {
    flex:1 !important; width:100% !important; height:100% !important;
    border:none !important; border-radius:0 !important;
    outline:none !important; box-shadow:none !important;
    background:transparent !important; color:#414045 !important;
    font-size:15px !important; font-weight:400 !important;
    padding:0 8px !important; margin:0 !important;
    line-height:normal !important;
    white-space:nowrap !important; overflow:hidden !important;
    text-overflow:ellipsis !important;
    display:block !important;
    -webkit-appearance:none !important; appearance:none !important;
    transition:none !important;
}
#td-home-search .sf-field > input[type="text"]::placeholder,
#td-home-search .sf-field > input[type="search"]::placeholder { color:#939295 !important; }
#td-home-search .sf-field > input[type="text"]:focus,
#td-home-search .sf-field > input[type="search"]:focus {
    border:none !important; box-shadow:none !important; outline:none !important;
}

/* Trigger (ngành nghề / địa điểm) */
#td-home-search .sf-field .sf-trigger {
    width:100% !important; height:100% !important;
    display:flex !important; align-items:center !important;
    justify-content:space-between !important;
    border:none !important; outline:none !important;
    background:transparent !important; cursor:pointer !important;
    padding:0 8px !important; margin:0 !important;
    font-size:15px !important; color:#414045 !important;
    user-select:none !important; white-space:nowrap !important;
    overflow:hidden !important; box-shadow:none !important;
}
.sf-trigger-label        { flex:1; overflow:hidden; text-overflow:ellipsis; }
.sf-trigger-label.placeholder { color:#939295; }
.sf-trigger-arrow        { color:#939295; transition:transform .2s; flex-shrink:0; margin-left:6px; }
.sf-field.open .sf-trigger-arrow { transform:rotate(180deg); }

/* Search button */
#td-home-search .sf-btn {
    flex-shrink:0 !important; display:inline-flex !important;
    align-items:center !important; align-self:center !important;
    justify-content:center !important; gap:6px !important;
    background:#F97316 !important; color:#fff !important;
    border:none !important; border-radius:9999px !important;
    padding:0 24px !important; height:44px !important;
    width:auto !important; min-height:0 !important; max-width:none !important;
    font-size:16px !important; font-weight:600 !important; line-height:1 !important;
    cursor:pointer !important; white-space:nowrap !important;
    margin:0 0 0 8px !important; box-shadow:none !important;
    text-transform:none !important; letter-spacing:0 !important;
    text-decoration:none !important;
    -webkit-appearance:none !important; appearance:none !important;
}
#td-home-search .sf-btn svg { flex-shrink:0; display:block !important; width:18px !important; height:18px !important; margin:0 !important; }
#td-home-search .sf-btn svg path { fill:currentColor !important; }
#td-home-search .sf-btn:hover,
#td-home-search .sf-btn:focus { background:#EA580C !important; color:#fff !important; }

/* ── Keyword suggestion dropdown ── */
#sf-keyword-dropdown {
    width:420px; max-height:440px; overflow-y:auto; padding:6px 0;
    left:0; right:auto;
}
.sf-kw-section { padding:8px 0 2px; }
.sf-kw-section-header {
    display:flex; align-items:center; justify-content:space-between;
    padding:4px 14px 6px;
}
.sf-kw-section-title {
    display:flex; align-items:center; gap:6px;
    font-size:12px; font-weight:700; text-transform:uppercase;
    letter-spacing:.05em; color:#939295;
}
.sf-kw-section-title svg { flex-shrink:0; }
.sf-kw-clear-all {
    font-size:12px; color:#F97316; cursor:pointer;
    border:none; background:none; padding:0; font-weight:500;
}
.sf-kw-clear-all:hover { text-decoration:underline; }
.sf-kw-item {
    display:flex; align-items:center; gap:10px;
    padding:8px 14px; cursor:pointer;
    font-size:14px; color:#414045; transition:background .12s;
}
.sf-kw-item:hover { background:#FFF7ED; color:#F97316; }
.sf-kw-item:hover .sf-kw-delete { opacity:1; }
.sf-kw-item-icon { color:#bbb; flex-shrink:0; }
.sf-kw-item:hover .sf-kw-item-icon { color:#F97316; }
.sf-kw-item-text { flex:1; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sf-kw-item-text em { font-style:normal; color:#F97316; font-weight:600; }
.sf-kw-delete {
    opacity:0; transition:opacity .15s; border:none; background:none;
    cursor:pointer; padding:2px 4px; color:#bbb;
    border-radius:4px; flex-shrink:0; font-size:15px; line-height:1;
}
.sf-kw-delete:hover { color:#DC2626; background:#FEE2E2; }
.sf-kw-divider { height:1px; background:#F3F3F3; margin:4px 0; }
.sf-kw-empty { padding:20px 14px; text-align:center; color:#bbb; font-size:14px; }

/* Dropdown shared */
.sf-dropdown {
    display:none; position:absolute; top:calc(100% + 8px); left:0;
    background:#fff; border-radius:12px; box-shadow:0 8px 32px rgba(0,0,0,.14);
    z-index:200; min-width:260px;
}
/* Default open = block; overridden to flex for specific dropdowns */
.sf-field.open .sf-dropdown { display:block; }

/* Category dropdown */
#sf-cat-dropdown {
    width:320px; max-height:420px; overflow-y:auto;
    flex-direction:column; overflow-x:hidden;
}
.sf-field.open #sf-cat-dropdown { display:flex; }

.sf-dd-header {
    display:flex; align-items:center; gap:7px;
    padding:11px 14px 10px; border-bottom:1px solid #F0F0F0;
    font-size:14px; font-weight:600; color:#414045;
    background:#FAFAFA; flex-shrink:0; position:sticky; top:0; z-index:1;
}
.sf-dd-header svg { color:#F97316; }

.sf-cat-list { padding:4px 0; }

/* Accordion group (flat — no subs for WP) */
.sf-ind-group { border-bottom:1px solid #F5F5F5; }
.sf-ind-group:last-child { border-bottom:none; }

.sf-ind-header {
    display:flex; align-items:center; gap:10px;
    padding:10px 14px; cursor:pointer; user-select:none;
    transition:background .15s;
}
.sf-ind-header:hover { background:#FFF7ED; }
.sf-ind-header.has-checked { background:#FFF7ED; }

.sf-ind-header input[type=checkbox] {
    accent-color:#F97316; width:15px; height:15px;
    flex-shrink:0; cursor:pointer; margin:0; pointer-events:none;
}

.sf-ind-label {
    flex:1; font-size:14px; font-weight:500; color:#414045;
}
.sf-ind-header.has-checked .sf-ind-label { color:#F97316; font-weight:600; }

/* Selected category tags row */
.sf-tags {
    display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; min-height:0;
}
.sf-tag {
    display:inline-flex; align-items:center; gap:4px;
    background:#FFF7ED; color:#EA580C; border:1px solid #FED7AA;
    border-radius:9999px; padding:2px 10px; font-size:13px; font-weight:500;
}
.sf-tag-remove {
    cursor:pointer; font-size:16px; line-height:1;
    margin-left:2px; color:#F97316; transition:color .15s;
}
.sf-tag-remove:hover { color:#DC2626; }

/* Location dropdown */
#sf-location-dropdown {
    width:320px; height:380px; flex-direction:column; overflow:hidden;
}
.sf-field.open #sf-location-dropdown { display:flex; }

/* Slide viewport (2 panels side-by-side) */
.sf-loc-viewport {
    flex:1; display:flex; width:200%; min-height:0;
    transform:translateX(0);
    transition:transform .3s cubic-bezier(.4,0,.2,1);
}
.sf-loc-viewport.show-districts { transform:translateX(-50%); }

.sf-loc-panel {
    width:50%; flex-shrink:0;
    display:flex; flex-direction:column; min-height:0;
}

/* Panel 1 — search + province list */
.sf-loc-search { padding:10px 12px; border-bottom:1px solid #F3F3F3; flex-shrink:0; }
#td-home-search .sf-loc-search input {
    width:100% !important; border:1px solid #E7E7E8 !important;
    border-radius:8px !important; padding:7px 10px !important;
    font-size:14px !important; outline:none !important; color:#414045 !important;
    background:#fff !important; height:auto !important; margin:0 !important;
    box-shadow:none !important; display:block !important;
}
#td-home-search .sf-loc-search input:focus {
    border-color:#F97316 !important; box-shadow:none !important;
}

.sf-loc-list { overflow-y:auto; flex:1; padding:6px 0; }

.sf-province-row {
    display:flex; align-items:center; padding:9px 14px;
    cursor:default; font-size:14px; color:#414045; gap:8px;
    transition:background .12s;
}
.sf-province-row:hover { background:#FFF7ED; }
.sf-province-row.selected { color:#F97316; font-weight:600; }

.sf-province-name { flex:1; cursor:pointer; }
.sf-province-name:hover { color:#F97316; }

.sf-province-arrow {
    display:flex; align-items:center; justify-content:center;
    width:26px; height:26px; border-radius:6px;
    color:#ccc; cursor:pointer; flex-shrink:0;
    transition:color .2s, background .15s;
}
.sf-province-arrow:hover { background:#FFF7ED; color:#F97316; }

/* Panel 2 — district list */
.sf-dist-header {
    display:flex; align-items:center; gap:8px;
    padding:10px 14px; border-bottom:1px solid #F3F3F3; flex-shrink:0;
}
.sf-dist-back {
    display:flex; align-items:center; justify-content:center;
    width:28px; height:28px; border-radius:6px;
    background:#F5F5F5; border:none; cursor:pointer;
    color:#555; flex-shrink:0; transition:background .15s, color .15s;
}
.sf-dist-back:hover { background:#FFF7ED; color:#F97316; }
.sf-dist-title { font-size:14px; font-weight:600; color:#414045; flex:1; }

.sf-dist-list { overflow-y:auto; flex:1; padding:6px 0; }

.sf-district-item {
    display:flex; align-items:center; gap:8px;
    padding:9px 16px; cursor:pointer;
    font-size:14px; color:#555;
    transition:background .15s, color .15s;
}
.sf-district-item:hover { background:#FFF7ED; color:#F97316; }
.sf-district-item.selected { color:#F97316; font-weight:600; }

/* Quick tags */
.td-hp-quick-tags { display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; }
.td-hp-quick-tag {
    display:inline-flex; align-items:center; gap:4px;
    background:#fff; border:1px solid #FED7AA; color:#EA580C;
    border-radius:9999px; padding:4px 12px; font-size:13px; font-weight:500;
    text-decoration:none; transition:background .15s, color .15s;
}
.td-hp-quick-tag:hover { background:#FFF7ED; color:#C2410C; text-decoration:none; }
.td-hp-quick-tag svg  { color:#EA580C; flex-shrink:0; }

/* Right CTA card */
.td-hp-search-right { width:360px; min-width:320px; flex-shrink:0; display:flex; }

.td-hp-cta-card {
    background:#fff; border-radius:16px; border:2px solid #FED7AA;
    padding:24px; display:flex; flex-direction:column; gap:12px;
}
.td-hp-cta-title { font-size:19px; font-weight:700; color:#1c1917; line-height:1.4; }
.td-hp-cta-desc  { font-size:15px; color:#78716c; line-height:1.6; }
.td-hp-cta-btn {
    display:block; text-align:center; background:#F97316; color:#fff;
    font-weight:700; font-size:16px; padding:12px 0; border-radius:9px;
    text-decoration:none; transition:background .2s;
}
.td-hp-cta-btn:hover { background:#EA580C; text-decoration:none; color:#fff; }
.td-hp-cta-login { text-align:center; font-size:14px; color:#EA580C; text-decoration:none; }
.td-hp-cta-login:hover { text-decoration:underline; }

@media (max-width: 900px) {
    .td-hp-search-right { display:none; }
}
@media (max-width: 640px) {
    #td-home-search .sf-bar { border-radius:16px !important; height:auto !important; flex-direction:column !important; padding:12px !important; gap:15px !important; }
    #td-home-search .sf-field { width:100% !important; height:auto !important; border-bottom:1px solid #EFEFEF !important; margin:0 !important; padding:0 4px !important; }
    /* Override higher-specificity sibling selector so stacked fields have no left border/indent */
    #td-home-search .sf-field + .sf-field { border-left:none !important; margin-left:0 !important; padding-left:4px !important; }
    #td-home-search .sf-field:last-of-type { border-bottom:none !important; }
    #td-home-search #sf-field-keyword { padding-top:10px !important; padding-bottom:10px !important; }
    #td-home-search #sf-field-category { padding-bottom:7px !important; }
    #td-home-search .sf-btn { width:100% !important; margin:10px 0 0 !important; align-self:stretch !important; justify-content:center !important; border-radius:10px !important; height:46px !important; }
    #sf-keyword-dropdown, #sf-cat-dropdown, #sf-location-dropdown { width:100% !important; left:0 !important; right:0 !important; }
}

/* ─────────────────────────────────────────────────────────────
   RECENT JOBS SECTION
───────────────────────────────────────────────────────────── */
#td-home-jobs { padding:32px 0 48px; }

/* Section header */
.td-hp-section-header {
    display:flex; align-items:center; justify-content:space-between;
    margin-bottom:20px; gap:12px;
}
.td-hp-section-title-wrap { display:flex; align-items:center; gap:8px; }
.td-hp-section-icon {
    display:flex; align-items:center; justify-content:center;
    width:32px; height:32px; min-width:32px; border-radius:9999px; flex-shrink:0;
}
.td-hp-section-icon--gradient { background:linear-gradient(135deg,#F7393C,#FF9152); }
.td-hp-section-title {
    font-size:24px; font-weight:700;
    background:linear-gradient(to right,#F7393C,#FF9152);
    -webkit-background-clip:text; -webkit-text-fill-color:transparent;
    background-clip:text; margin:0;
}
.td-hp-see-all {
    display:flex; align-items:center; gap:4px;
    font-size:15px; font-weight:500; color:#F97316;
    text-decoration:none; white-space:nowrap;
}
.td-hp-see-all:hover { color:#EA580C; text-decoration:none; }

/* Filter row */
.td-hp-filter-row {
    display:flex; align-items:center; gap:12px; margin-bottom:20px; flex-wrap:wrap;
}

/* Filter type anchor */
.td-hp-filter-wrap {
    position:relative; display:flex; align-items:center; justify-content:space-between;
    background:#fff; border:1px solid #C7E3FF; border-radius:8px;
    padding:0 10px 0 10px; height:40px; min-width:180px; cursor:pointer; flex-shrink:0;
    user-select:none;
}
.td-hp-filter-inner { display:flex; align-items:center; gap:6px; font-size:15px; color:#414045; }
.td-hp-filter-label { font-size:15px; }
#uj-filter-label { font-weight:600; color:#F97316; }
.td-hp-filter-arrow { color:#374151; flex-shrink:0; margin-left:4px; transition:transform .2s; }
.td-hp-filter-wrap.open .td-hp-filter-arrow { transform:rotate(180deg); }

/* Filter dropdown */
.uj-filter-dropdown {
    position:absolute; top:calc(100% + 6px); left:0;
    background:#fff; border-radius:10px; box-shadow:0 8px 32px rgba(0,0,0,.14);
    z-index:300; overflow:hidden; min-width:160px; display:none; border:1px solid #F0F0F0;
}
.uj-filter-dropdown.open { display:block; }
.uj-filter-item { padding:10px 16px; font-size:15px; color:#414045; cursor:pointer; transition:background .15s,color .15s; white-space:nowrap; }
.uj-filter-item:hover { background:#FFF7ED; color:#F97316; }
.uj-filter-item.active { color:#F97316; font-weight:600; background:#FFF7ED; }

/* Tab scroll */
.td-hp-tabs-wrap { display:flex; align-items:center; gap:8px; flex:1; min-width:0; }
.td-hp-tab-arrow {
    display:flex !important; align-items:center; justify-content:center;
    width:32px; height:32px !important; min-width:32px; border-radius:9999px;
    border:1px solid #E7E7E8 !important; background:#fff !important;
    cursor:pointer; color:#939295 !important;
    padding:0 !important; line-height:1 !important;
    transition:border-color .2s, color .2s;
    text-transform:none !important; font-size:inherit !important;
}
.td-hp-tab-arrow:hover { border-color:#F97316 !important; color:#F97316 !important; }
.td-hp-tab-arrow:disabled { opacity:.45; cursor:not-allowed; }
/* Override Flatsome's global svg rules for our button icons */
.td-hp-tab-arrow svg { width:14px !important; height:14px !important; margin:0 !important; flex-shrink:0; }
.td-hp-tab-arrow svg path { fill:none !important; }

.td-hp-tab-list {
    display:flex; align-items:center; gap:10px; overflow-x:auto;
    max-width:100%; flex:1; scroll-behavior:smooth;
    -ms-overflow-style:none; scrollbar-width:none;
}
.td-hp-tab-list::-webkit-scrollbar { display:none; }

.uj-tab-btn {
    padding:0 16px; height:40px; border-radius:9999px;
    border:1px solid #E7E7E8; display:inline-flex; justify-content:center; align-items:center;
    flex-shrink:0; transition:background .2s, border-color .2s;
    background:#fff; cursor:pointer; font-size:13px; color:#414045; white-space:nowrap;
}
.uj-tab-btn:hover { border-color:#F97316; color:#F97316; }
.uj-tab-btn.active { background:#F97316; border-color:#F97316; color:#fff; font-weight:500; }

/* Job cards grid */
.td-hp-job-grid {
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:12px;
    min-height:200px;
    position:relative;
}

.td-hp-no-jobs {
    grid-column:1/-1; text-align:center; padding:40px 0;
    color:#939295; font-size:16px;
}

/* Quick badge on "Việc đi làm ngay" cards */
.td-hp-quick-badge {
    display:inline-flex; align-items:center; justify-content:center;
    width:20px; height:20px; min-width:20px; border-radius:4px; flex-shrink:0;
    background:linear-gradient(135deg,#F7393C,#FF9152);
}
.td-hp-card--quick { border-color:#FFE4D6; }
.td-hp-card--quick:hover { border-color:#F97316; }

.td-hp-loading {
    display:flex; align-items:center; justify-content:center;
    grid-column:1/-1; padding:60px 0; color:#939295; font-size:15px; gap:8px;
}

/* Job card */
.td-hp-card {
    display:block; text-decoration:none; color:inherit;
    background:#fff; border-radius:8px; border:1px solid #E7E7E8;
    transition:border-color .2s, box-shadow .2s;
    overflow:hidden; min-width:0;
}
.td-hp-card:hover {
    border-color:#2C95FF;
    box-shadow:0 4px 16px rgba(44,149,255,.12);
    text-decoration:none; color:inherit;
}

.td-hp-card-inner { display:flex; flex-direction:column; padding:10px; gap:0; height:100%; }

.td-hp-card-top { margin-bottom:6px; }
.td-hp-card-title {
    font-size:16px; font-weight:600; color:#414045; line-height:1.4;
    margin:0; display:-webkit-box; -webkit-line-clamp:1;
    -webkit-box-orient:vertical; overflow:hidden;
}
.td-hp-card:hover .td-hp-card-title { color:#2C95FF; }

.td-hp-card-body { display:flex; gap:10px; flex:1; min-width:0; overflow:hidden; }

.td-hp-card-logo {
    width:64px; min-width:64px; height:64px; border-radius:6px;
    display:flex; align-items:center; justify-content:center;
    font-size:24px; font-weight:700; color:#fff; overflow:hidden;
    flex-shrink:0; margin:0;
}
.td-hp-card-logo img { width:100%; height:100%; object-fit:contain; }
.td-hp-card-logo--img { background:#f5f5f5; }

.td-hp-card-meta { display:flex; flex-direction:column; gap:3px; min-width:0; flex:1; }

.td-hp-card-company,
.td-hp-card-salary,
.td-hp-card-location {
    display:flex; align-items:center; gap:4px;
    font-size:14px; line-height:1.5;
    overflow:hidden; min-width:0;
}
.td-hp-card-company  { color:#939295; }
.td-hp-card-salary   { color:#2C95FF; font-weight:500; }
.td-hp-card-location { color:#6B7280; }
.td-hp-card-company svg,
.td-hp-card-salary svg,
.td-hp-card-location svg { flex-shrink:0; color:inherit; opacity:.7; }

.td-hp-card-footer {
    display:flex; align-items:center; justify-content:space-between;
    border-top:1px solid #F0F0F0; margin-top:8px; padding-top:6px;
}
.td-hp-card-badges { display:flex; gap:4px; align-items:center; }

.td-hp-badge {
    display:inline-flex; align-items:center; gap:2px;
    font-size:12px; font-weight:700; border-radius:4px;
    padding:2px 6px; line-height:1.4;
}
.td-hp-badge--hot { background:#FEF2F2; color:#EF4444; }

.td-hp-card-days {
    display:flex; align-items:center; gap:3px;
    font-size:14px; color:#939295; white-space:nowrap;
}
.td-hp-card-days svg { flex-shrink:0; }

/* Pagination */
.td-hp-pagination {
    display:flex; align-items:center; justify-content:flex-end;
    gap:12px; margin-top:20px;
}
.td-hp-page-btn {
    display:flex !important; align-items:center; justify-content:center;
    width:36px; height:36px !important; border-radius:9999px;
    border:1px solid #E7E7E8 !important; background:#fff !important; cursor:pointer;
    transition:border-color .2s; padding:0 !important;
    color:#414045 !important; line-height:1 !important; text-transform:none !important;
}
.td-hp-page-btn:hover:not(:disabled) { border-color:#F97316; }
.td-hp-page-btn:disabled { opacity:.45; cursor:not-allowed; }
.td-hp-page-btn svg { width:16px !important; height:16px !important; margin:0 !important; flex-shrink:0; }
.td-hp-page-btn svg path { fill:none !important; }
.td-hp-page-count { font-size:15px; color:#414045; font-weight:500; min-width:60px; text-align:center; }

/* ── Loading overlay ── */
.td-hp-job-grid.is-loading::after {
    content:''; position:absolute; inset:0;
    background:rgba(255,255,255,.65);
    border-radius:8px; z-index:5;
}

/* ─────────────────────────────────────────────────────────────
   RESPONSIVE
───────────────────────────────────────────────────────────── */
@media (max-width: 1024px) {
    .td-hp-job-grid { grid-template-columns:repeat(2,1fr); }
}

@media (max-width: 640px) {
    #td-home-search  { padding:20px 0 20px; }
    #td-home-jobs    { padding:20px 0 32px; }
    .td-hp-section-title { font-size:19px; }
    .td-hp-job-grid  { grid-template-columns:1fr; }
    .td-hp-filter-row { gap:8px; }
    .td-hp-filter-wrap { min-width:140px; }
    .td-hp-section-header { margin-bottom:14px; }
}

@media (max-width: 400px) {
    .td-hp-search-title { font-size:19px; }
    .td-hp-tab-arrow { display:none; }
}

/* ─────────────────────────────────────────────────────────────
   QUICK LINKS ROW  (Việc đi làm ngay / Việc không cần CV)
───────────────────────────────────────────────────────────── */
.td-hp-quick-links {
    display:flex; gap:12px; margin-top:12px;
}
.td-hp-quick-link {
    flex:1; display:flex; align-items:center; gap:10px;
    background:#fff; border-radius:9999px; padding:8px 16px;
    text-decoration:none; font-weight:600; font-size:15px;
    box-shadow:0 1px 4px rgba(0,0,0,.08);
    transition:background .15s;
    white-space:nowrap;
}
.td-hp-quick-link--orange { color:#F97316; }
.td-hp-quick-link--orange:hover { background:#FFF7ED; color:#F97316; }
.td-hp-quick-link--blue   { color:#1C6FC4; }
.td-hp-quick-link--blue:hover   { background:#F0F6FF; color:#1C6FC4; }
.td-hp-quick-link-icon {
    display:flex; align-items:center; justify-content:center;
    width:34px; height:34px; border-radius:9999px; flex-shrink:0;
}
.td-hp-quick-link-icon--orange { background:#FFF7ED; }
.td-hp-quick-link-icon--blue   { background:#F0F6FF; }

/* ─────────────────────────────────────────────────────────────
   PROMINENT LOGIN / DASHBOARD CARD  (right of search)
───────────────────────────────────────────────────────────── */
.td-hp-prominent-card {
    border:2px solid #E2D5FF;
    border-radius:20px;
    background:#fff center/cover no-repeat;
    padding:28px 12px 12px;
    flex:1;
    box-sizing:border-box;
}
.td-hp-prominent-inner {
    background:#fff;
    border-radius:12px;
    padding:16px;
    display:flex; flex-direction:column; gap:16px;
}
.td-hp-prominent-text { display:flex; flex-direction:column; gap:6px; }
.td-hp-prominent-title {
    font-size:18px; font-weight:700; line-height:1.45;
    color:#1a1a2e; letter-spacing:-.4px;
}
.td-hp-prominent-desc {
    font-size:14px; color:#6B7280; line-height:1.55;
}
.td-hp-prominent-actions { display:flex; flex-direction:column; gap:10px; }
.td-hp-prominent-btn {
    display:flex; align-items:center; justify-content:center; gap:8px;
    padding:10px 16px; border-radius:8px;
    font-size:15px; font-weight:500; text-decoration:none;
    cursor:pointer; border:none; transition:opacity .15s;
}
.td-hp-prominent-btn:hover { opacity:.88; }
.td-hp-prominent-btn--primary {
    background:#F97316; color:#fff;
}
.td-hp-prominent-btn--google {
    background:#fff; color:#374151;
    border:1px solid #EFEFF0;
}
.td-hp-prominent-btn--google:hover { background:#F9FAFB; opacity:1; }
.td-hp-prominent-link {
    text-align:center; font-size:14px; color:#6B7280;
    text-decoration:none;
}
.td-hp-prominent-link:hover { color:#F97316; }

/* ─────────────────────────────────────────────────────────────
   EMPLOYERS BANNER V2  (Category panel + Ad banner)
───────────────────────────────────────────────────────────── */
#td-employers-banner {
    background:#fff;
    padding:0 0 24px;
}
.td-hp-ebv2-wrap {
    display:flex; gap:20px; align-items:stretch;
    padding-top:16px;
}
/* Category panel */
.td-hp-cat-panel {
    display:flex; flex-direction:column;
    width:220px; min-width:200px;
    background:#fff; border-radius:12px;
    border:1px solid #F0F0F0;
    box-shadow:0 1px 4px rgba(0,0,0,.06);
    padding:4px; overflow:hidden;
}
.td-hp-cat-item {
    display:flex; align-items:center; gap:10px;
    padding:8px 10px; border-radius:6px;
    text-decoration:none; color:#374151;
    font-size:14px; font-weight:500;
    transition:background .12s;
    overflow:hidden;
}
.td-hp-cat-item:hover { background:#F0F6FF; color:#374151; }
.td-hp-cat-icon { flex-shrink:0; display:flex; align-items:center; }
.td-hp-cat-name {
    flex:1; overflow:hidden;
    display:-webkit-box; -webkit-line-clamp:1; -webkit-box-orient:vertical;
}
.td-hp-cat-all {
    display:flex; align-items:center; justify-content:center;
    padding:8px 10px; margin-top:auto;
    border-top:1px dashed #E7E7E8;
    font-size:14px; font-weight:500; color:#F97316;
    text-decoration:none; text-align:center;
    transition:color .12s;
}
.td-hp-cat-all:hover { color:#EA580C; }

/* Ad banner */
.td-hp-ad-banner {
    flex:1; min-width:0;
    border-radius:12px; overflow:hidden;
    height:241px;
    box-shadow:0 1px 4px rgba(0,0,0,.08);
}
.td-hp-ad-banner a { display:block; height:100%; }
.td-hp-ad-banner img {
    width:100%; height:100%;
    object-fit:cover; object-position:center;
    display:block;
}
.td-hp-ad-placeholder {
    height:241px; display:flex; flex-direction:column;
    align-items:center; justify-content:center; gap:8px;
    text-align:center;
    background:#F9FAFB; border:2px dashed #E5E7EB;
    border-radius:12px; color:#9CA3AF; font-size:14px;
}
.td-hp-ad-placeholder p { margin:0; }
.td-hp-ad-placeholder a { color:#F97316; text-decoration:none; font-size:13px; }
.td-hp-ad-placeholder a:hover { text-decoration:underline; }

@media (max-width: 1024px) {
    .td-hp-ebv2-wrap { gap:12px; }
    .td-hp-cat-panel { width:180px; min-width:160px; }
}
@media (max-width: 768px) {
    .td-hp-ebv2-wrap { flex-direction:column; }
    .td-hp-cat-panel { width:100%; flex-direction:row; flex-wrap:wrap; }
    .td-hp-cat-item { flex-basis:calc(50% - 5px); flex-grow:1; }
    .td-hp-cat-all  { flex-basis:100%; border-top:1px dashed #E7E7E8; border-left:none; }
    .td-hp-ad-banner { height:160px; }
    .td-hp-quick-links { flex-wrap:wrap; }
}

/* ─────────────────────────────────────────────────────────────
   SHARED SECTION UTILITIES
───────────────────────────────────────────────────────────── */
.td-hp-section { padding:40px 0; }
.td-hp-section--gray { background:#FAFAFA; }
.td-hp-section--blue { background:#F6F9FF; }
.td-hp-section-title--dark {
    font-size:24px; font-weight:600; color:#414045; margin:0;
    background:none; -webkit-background-clip:unset; -webkit-text-fill-color:#414045; background-clip:unset;
}

/* ─────────────────────────────────────────────────────────────
   CÔNG TY NỔI BẬT
───────────────────────────────────────────────────────────── */
.td-hp-employer-grid {
    display:grid;
    grid-template-columns:repeat(6, 1fr);
    gap:12px;
}
.td-hp-employer-card {
    display:flex; flex-direction:column; align-items:center; justify-content:center;
    height:112px; border-radius:10px; border:1.5px solid #E7E7E8;
    background:#fff; text-decoration:none; padding:8px;
    transition:border-color .15s, box-shadow .15s;
    gap:6px;
}
.td-hp-employer-card:hover { border-color:#F97316; box-shadow:0 4px 16px rgba(249,115,22,.12); text-decoration:none; }
.td-hp-employer-logo-wrap {
    width:64px; height:64px; display:flex; align-items:center; justify-content:center;
    border-radius:8px; overflow:hidden; flex-shrink:0;
}
.td-hp-employer-logo-wrap img { width:100%; height:100%; object-fit:contain; }
.td-hp-employer-initial {
    width:64px; height:64px; border-radius:8px;
    display:flex; align-items:center; justify-content:center;
    font-size:24px; font-weight:700; color:#fff;
    background:linear-gradient(135deg,#F97316,#FBBF24);
}
.td-hp-employer-jobs {
    display:flex; align-items:center; gap:4px;
    font-size:13px; font-weight:500; color:#6B7280; white-space:nowrap;
}
@media (max-width:1024px) { .td-hp-employer-grid { grid-template-columns:repeat(4, 1fr); } }
@media (max-width:640px)  { .td-hp-employer-grid { grid-template-columns:repeat(2, 1fr); } }

/* ─────────────────────────────────────────────────────────────
   VIỆC LÀM GỢI Ý
───────────────────────────────────────────────────────────── */
.td-hp-card--suggest:hover { border-color:#2C95FF; }

/* ─────────────────────────────────────────────────────────────
   CẨM NANG NGHỀ NGHIỆP
───────────────────────────────────────────────────────────── */
#td-blog { padding:48px 0 56px; }
.td-hp-blog-heading {
    font-size:30px; font-weight:700; text-align:center;
    color:#414045; margin:0 0 32px;
}
.td-hp-blog-grid {
    display:grid; grid-template-columns:repeat(3, 1fr);
    gap:28px; margin-bottom:32px;
}
.td-hp-blog-card { border-radius:10px; overflow:hidden; }
.td-hp-blog-card a { display:block; text-decoration:none; color:inherit; }
.td-hp-blog-card a:hover .td-hp-blog-post-title { color:#F97316; }
.td-hp-blog-thumb {
    width:100%; height:195px; object-fit:cover;
    border-radius:8px; display:block;
}
.td-hp-blog-thumb--placeholder {
    background:linear-gradient(135deg,#FFF7ED,#FFEDD5);
    border-radius:8px;
}
.td-hp-blog-post-title {
    font-size:18px; font-weight:600; line-height:1.5;
    color:#414045; margin:16px 0 8px;
    overflow:hidden; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;
    transition:color .15s;
}
.td-hp-blog-excerpt {
    font-size:15px; color:#6B7280; line-height:1.6; margin:0;
    overflow:hidden; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical;
}
.td-hp-blog-more-wrap { display:flex; justify-content:center; }
.td-hp-blog-more-btn {
    display:inline-block; padding:10px 24px;
    border:1.5px solid #2C95FF; border-radius:8px;
    font-size:15px; font-weight:600; color:#2C95FF; text-decoration:none;
    background:#F5F1FF; transition:border-color .15s, color .15s;
}
.td-hp-blog-more-btn:hover { border-color:#F97316; color:#F97316; text-decoration:none; }
@media (max-width:1024px) { .td-hp-blog-grid { grid-template-columns:repeat(2, 1fr); } }
@media (max-width:640px)  { .td-hp-blog-grid { grid-template-columns:1fr; } .td-hp-blog-heading { font-size:24px; } }

/* ─────────────────────────────────────────────────────────────
   INDUSTRIES MODAL
───────────────────────────────────────────────────────────── */
.ind-modal-overlay {
    position:fixed; inset:0;
    background:rgba(0,0,0,.45);
    z-index:99999;
    display:flex; align-items:center; justify-content:center;
    padding:16px;
    opacity:0; pointer-events:none;
    transition:opacity .25s ease;
}
.ind-modal-overlay.active { opacity:1; pointer-events:auto; }

.ind-modal {
    background:#fff; border-radius:16px;
    width:100%; max-width:860px; max-height:90vh;
    display:flex; flex-direction:column;
    box-shadow:0 24px 64px rgba(0,0,0,.18);
    transform:translateY(20px) scale(.98);
    transition:transform .25s ease;
    overflow:hidden;
}
.ind-modal-overlay.active .ind-modal { transform:translateY(0) scale(1); }

.ind-modal-header {
    display:flex; align-items:center; justify-content:space-between;
    padding:18px 24px 14px;
    border-bottom:1px solid #F0F0F0;
    flex-shrink:0;
}
.ind-modal-title-wrap { display:flex; align-items:center; gap:9px; }
.ind-modal-title { font-size:18px; font-weight:700; color:#1a1a2e; margin:0; }
.ind-modal-close {
    width:34px; height:34px !important; border-radius:8px;
    border:none !important; background:#F5F5F5 !important;
    cursor:pointer; display:flex !important; align-items:center; justify-content:center;
    color:#555 !important; flex-shrink:0; padding:0 !important; line-height:1 !important;
    transition:background .15s, color .15s;
}
.ind-modal-close:hover { background:#FFE8D6 !important; color:#F97316 !important; }
.ind-modal-close svg { width:16px !important; height:16px !important; margin:0 !important; flex-shrink:0; }
.ind-modal-close svg path { fill:currentColor !important; }

.ind-modal-search {
    display:flex; align-items:center; gap:10px;
    padding:12px 24px;
    border-bottom:1px solid #F0F0F0;
    flex-shrink:0;
}
.ind-modal-search input,
.ind-modal-search input[type="text"] {
    flex:1 !important; border:none !important; outline:none !important;
    box-shadow:none !important; border-radius:0 !important;
    padding:0 !important; margin:0 !important;
    font-size:15px !important; color:#414045 !important;
    background:transparent !important;
    height:auto !important; line-height:1.5 !important;
    width:100% !important;
}
.ind-modal-search input::placeholder { color:#bbb; }

.ind-modal-body { overflow-y:auto; flex:1; padding:20px 24px 24px; }

.ind-cat-group { margin-bottom:24px; }
.ind-cat-group:last-child { margin-bottom:0; }

.ind-cat-heading {
    display:flex; align-items:center; gap:8px;
    font-size:15px; font-weight:700; color:#F97316;
    margin-bottom:10px; padding-bottom:8px;
    border-bottom:2px solid #FFF7ED;
}
.ind-sub-grid { display:flex; flex-wrap:wrap; gap:8px; }

.ind-sub-chip {
    display:inline-flex; align-items:center; gap:6px;
    padding:6px 14px; border-radius:9999px;
    border:1px solid #E7E7E8; background:#FAFAFA;
    font-size:14px; color:#414045;
    cursor:pointer;
    transition:background .15s, border-color .15s, color .15s;
    user-select:none; white-space:nowrap;
}
.ind-sub-chip:hover { background:#FFF7ED; border-color:#F97316; color:#F97316; }
.ind-sub-chip.selected {
    background:#FFF7ED; border-color:#F97316;
    color:#F97316; font-weight:600;
}
.ind-sub-chip.selected::before { content:'✓ '; font-size:12px; font-weight:700; }

.ind-empty {
    text-align:center; padding:48px 0;
    color:#bbb; font-size:15px;
}
.ind-empty svg { margin:0 auto 12px; display:block; opacity:.4; }

.ind-modal-footer {
    display:flex; align-items:center; justify-content:space-between;
    padding:14px 24px;
    border-top:1px solid #F0F0F0;
    flex-shrink:0; background:#FAFAFA;
}
.ind-footer-count { font-size:14px; color:#939295; }
.ind-footer-count strong { color:#F97316; }
.ind-footer-actions { display:flex; gap:10px; }
.ind-btn {
    padding:8px 20px; border-radius:8px;
    font-size:14px; font-weight:600;
    border:none; cursor:pointer;
    transition:background .15s; text-decoration:none;
    display:inline-flex; align-items:center;
}
.ind-btn-clear { background:#F0F0F0; color:#414045; }
.ind-btn-clear:hover { background:#E5E5E5; color:#414045; }
.ind-btn-apply { background:#F97316; color:#fff; }
.ind-btn-apply:hover { background:#EA580C; color:#fff; }

/* btn-all-industries inside category panel */
button#btn-all-industries {
    background:none; border:none; width:100%;
    cursor:pointer; font-family:inherit;
}

@media (max-width:600px) {
    .ind-modal { border-radius:12px 12px 0 0; max-height:85vh; }
    .ind-modal-overlay { align-items:flex-end; padding:0; }
    .ind-modal-header { padding:14px 16px 12px; }
    .ind-modal-body { padding:16px; }
    .ind-modal-footer { padding:12px 16px; }
}

/* ═══════════════════════════════════════════════════════════
   GEO LOCATION INDICATOR
═══════════════════════════════════════════════════════════ */
.td-geo-indicator {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: #FFF7ED;
    border: 1px solid #FDBA74;
    color: #C2410C;
    border-radius: 999px;
    padding: 5px 8px 5px 10px;
    font-size: 14px;
    margin-bottom: 10px;
    line-height: 1;
}
.td-geo-indicator svg { flex-shrink: 0; width:14px !important; height:14px !important; margin:0 !important; }
.td-geo-indicator strong { font-weight: 700; color: #F97316; }
.td-geo-indicator button {
    display: flex !important;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px !important;
    background: rgba(249,115,22,.12) !important;
    border: none !important;
    border-radius: 50%;
    cursor: pointer;
    color: #F97316 !important;
    padding: 0 !important;
    flex-shrink: 0;
    line-height: 1 !important;
    transition: background .15s;
}
.td-geo-indicator button:hover { background: rgba(249,115,22,.25) !important; }
.td-geo-indicator button svg { width:10px !important; height:10px !important; margin:0 !important; }
.td-geo-indicator button svg path { fill:currentColor !important; }

/* ═══════════════════════════════════════════════════════════
   JOB LINKS SECTION — 3 boxes
═══════════════════════════════════════════════════════════ */
.td-hp-job-links-section {
    background: #F8F9FA;
    padding: 40px 0;
    border-top: 1px solid #E9ECEF;
}
.td-hp-job-links-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 24px;
}
.td-hp-jl-box {
    background: #fff;
    border: 1px solid #E9ECEF;
    border-radius: 10px;
    padding: 20px 22px 16px;
    display: flex;
    flex-direction: column;
    min-width: 0;
    overflow: hidden;
}
.td-hp-jl-heading {
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 700;
    font-size: 16px;
    color: #1a1a2e;
    margin-bottom: 14px;
    padding-bottom: 12px;
    border-bottom: 1px solid #F0F2F5;
}
.td-hp-jl-list {
    list-style: none;
    margin: 0 0 14px;
    padding: 0;
    flex: 1;
}
.td-hp-jl-list li {
    border-bottom: 1px solid #F5F5F5;
}
.td-hp-jl-list li:last-child { border-bottom: none; }
.td-hp-jl-list a {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 9px 0;
    color: #414045;
    text-decoration: none;
    transition: color .15s;
    gap: 3px;
    min-width: 0;
}
.td-hp-jl-list a:hover { color: #F97316; }
.td-hp-jl-title {
    font-size: 14px;
    font-weight: 600;
    color: inherit;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    width: 100%;
}
.td-hp-jl-count,
.td-hp-jl-company {
    font-size: 12px;
    color: #9ca3af;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    width: 100%;
}
.td-hp-jl-more {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 14px;
    font-weight: 600;
    color: #F97316;
    text-decoration: none;
    margin-top: auto;
    transition: gap .15s;
}
.td-hp-jl-more:hover { gap: 8px; color: #EA580C; }

@media (max-width:900px) {
    .td-hp-job-links-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .td-hp-jl-box:last-child { grid-column: 1 / -1; }
}
@media (max-width:600px) {
    .td-hp-job-links-grid { grid-template-columns: minmax(0, 1fr); }
    .td-hp-jl-box:last-child { grid-column: auto; }
}

/* ═══════════════════════════════════════════════════════════
   HOTLINE SECTION
═══════════════════════════════════════════════════════════ */
.td-hp-hotline-section {
    background: #fff;
    border-top: 1px solid #E9ECEF;
}
.td-hp-hotline-wrap {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0 96px;
    padding-top: 24px;
    padding-bottom: 32px;
    text-align: center;
}
.td-hp-hotline-wrap--single {
    justify-content: center;
}
.td-hp-hotline-wrap--single .td-hp-hl-numbers {
    justify-content: center;
    gap: 48px;
}
.td-hp-hotline-wrap--single .td-hp-hl-num {
    align-items: center;
}
.td-hp-hl-col {
    flex: 0 0 49%;
    width: 49%;
}
.td-hp-hl-col--single {
    flex: 0 0 auto;
    width: 100%;
    max-width: 720px;
}
.td-hp-hl-title {
    font-size: 21px;
    font-weight: 700;
    line-height: 2;
    margin: 0 0 16px;
}
.td-hp-hl-title--ntv { color: #414045; }
.td-hp-hl-title--ntd { color: #004F9F; }
.td-hp-hl-numbers {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 16px;
}
.td-hp-hl-num {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
    flex: 1;
}
.td-hp-hl-icon-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    line-height: 1;
}
.td-hp-hl-icon-row--purple { color: #8B5CF6; }
.td-hp-hl-icon-row--blue   { color: #2C95FF; }
.td-hp-hl-icon {
    flex-shrink: 0;
    display: flex;
    align-items: center;
}
.td-hp-hl-label {
    font-size: 15px;
    margin: 0;
}
.td-hp-hl-phone {
    display: block;
    font-size: 21px;
    font-weight: 600;
    text-decoration: none;
    user-select: text;
    margin-top: 4px;
    transition: opacity .15s;
}
.td-hp-hl-phone:hover { opacity: .8; }
.td-hp-hl-phone--orange { color: #F97316; }
.td-hp-hl-phone--blue   { color: #2C95FF; }
.td-hp-hl-divider {
    width: 1px;
    background: #DCDCDD;
    align-self: stretch;
    flex-shrink: 0;
    margin: 24px 0;
}
.td-hp-hl-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 24px;
    height: 40px;
    border-radius: 4px;
    font-size: 15px;
    font-weight: 600;
    text-decoration: none;
    transition: background .15s, color .15s;
    cursor: pointer;
    margin-top: 16px;
}
.td-hp-hl-btn--orange {
    color: #F97316;
    border: 1px solid #F97316;
    background: transparent;
}
.td-hp-hl-btn--orange:hover { background: #F97316; color: #fff; }
.td-hp-hl-btn--blue {
    color: #2C95FF;
    border: 1px solid #2C95FF;
    background: transparent;
}
.td-hp-hl-btn--blue:hover { background: #2C95FF; color: #fff; }

@media (max-width:768px) {
    .td-hp-hotline-wrap { flex-direction: column; gap: 0; }
    .td-hp-hl-col { flex: none; width: 100%; padding: 20px 0; }
    .td-hp-hl-divider { width: 100%; height: 1px; margin: 0; align-self: auto; }
    .td-hp-hl-num { align-items: center; }
}
@media (max-width:480px) {
    .td-hp-hl-numbers { flex-direction: column; align-items: center; }
    .td-hp-hl-phone { font-size: 19px; }
}
