html.ls-home-b-page,
body.ls-home-b-page {
    margin-top: 0 !important;
    padding-top: 0 !important;
    overflow-x: hidden !important;
    background: #f5faf7 !important;
}

body.ls-home-b-page > .ls-header {
    display: none !important;
}

body.ls-home-b-page > .ls-main,
body.ls-home-b-page > .ls-page {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

.LS-home-b {
    --home-b-page-width: var(--ls-width, 1200px);
    --home-b-component-gap: 10px;
    --home-b-hero-height: 600px;
    --home-b-logo-width: 48px;
    --home-b-logo-height: 48px;
    --home-b-bleed-left: 0px;
    --home-b-bleed-width: 100vw;
    --home-b-wide-width: min(1400px, calc(100vw - 32px));
    --home-b-shell-pad: max(18px, calc((100% - var(--home-b-page-width)) / 2 + 18px));
    min-height: 900px;
    color: #121826;
    background:
        radial-gradient(circle at 86% 5%, rgb(199 231 255 / 38%), transparent 29%),
        radial-gradient(circle at 9% 48%, rgb(220 244 232 / 34%), transparent 26%),
        linear-gradient(180deg, #f7fbff 0%, #ffffff 36%, #f5faf7 100%);
    font-family: "PingFang SC", -apple-system, BlinkMacSystemFont, "Microsoft YaHei", sans-serif;
    overflow: visible;
}

.LS-home-b *,
.LS-home-b *::before,
.LS-home-b *::after {
    box-sizing: border-box;
}

.LS-home-b a {
    color: inherit;
    text-decoration: none;
}

.LS-home-b-header {
    position: absolute;
    top: 16px;
    left: var(--home-b-shell-pad);
    right: var(--home-b-shell-pad);
    z-index: 8;
    display: grid;
    grid-template-columns: 200px minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
    min-height: 58px;
}

.LS-home-b-brand {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
}

.LS-home-b-brand img,
.LS-home-b-brand-mark {
    width: var(--home-b-logo-width);
    height: var(--home-b-logo-height);
    flex: 0 0 var(--home-b-logo-width);
    border-radius: 13px;
    object-fit: contain;
}

.LS-home-b-brand-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    background: linear-gradient(135deg, #22c55e, #0ea5e9);
    font-weight: 900;
}

.LS-home-b-brand span,
.LS-home-b-nav-item span {
    display: grid;
    min-width: 0;
}

.LS-home-b-brand strong {
    color: #111827;
    font-size: 22px;
    line-height: 1;
    font-weight: 900;
}

.LS-home-b-brand small {
    margin-top: 4px;
    color: #111827;
    font-size: 13px;
    line-height: 1;
    font-weight: 800;
}

.LS-home-b-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: clamp(12px, 1.5vw, 24px);
    min-width: 0;
    overflow: hidden;
}

.LS-home-b-nav-item {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    min-width: 42px;
    padding: 6px 0 11px;
    color: #111827;
    text-align: center;
    white-space: nowrap;
}

.LS-home-b-nav-item i {
    display: none;
    font-size: 17px;
}

.LS-home-b-nav-item strong {
    font-size: 14px;
    line-height: 1.1;
    font-weight: 500;
}

.LS-home-b-nav-item small {
    margin-top: 5px;
    color: #111827;
    font-size: 10px;
    line-height: 1;
    font-weight: 400;
    text-transform: uppercase;
    opacity: .72;
}

.LS-home-b-nav-item:visited {
    color: #111827;
}

.LS-home-b-nav-item.is-active,
.LS-home-b-nav-item.is-active:visited {
    color: #22a447;
}

.LS-home-b-nav-item.is-active small {
    color: #22a447;
    opacity: 1;
}

.LS-home-b-nav-item.is-active::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: 0;
    width: 22px;
    height: 3px;
    border-radius: 999px;
    background: #22a447;
    transform: translateX(-50%);
}

.LS-home-b-header-actions {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    min-width: 0;
}

.LS-home-b-header-actions-skeleton {
    width: 190px;
    height: 40px;
    display: none;
    border-radius: 999px;
    background: linear-gradient(100deg, rgb(255 255 255 / 40%) 30%, rgb(255 255 255 / 76%) 45%, rgb(255 255 255 / 40%) 60%);
    background-size: 220% 100%;
    animation: home-b-header-shimmer 1.4s ease-in-out infinite;
}

.LS-home-b-header-actions[data-state="pending"] .LS-home-b-header-actions-skeleton { display: block; }
.LS-home-b-header-actions[data-state="ready"] .LS-home-b-header-actions-skeleton { display: none; }
@keyframes home-b-header-shimmer { to { background-position: -120% 0; } }

.LS-home-b-header-actions .ls-header-right {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: max-content;
}

.LS-home-b-header-actions .ls-auth-btns { gap: 8px; }
.LS-home-b-header-actions .ls-search-trigger { height: 42px; padding: 0 15px; }
.LS-home-b-header-actions .ls-register-btn { height: 42px; padding: 0 18px; }
.LS-home-b-header-actions .ls-create-btn {
    background: linear-gradient(135deg, #2bc255, #17913b);
}

.LS-home-b-header-actions .ls-icon-btn,
.LS-home-b-header-actions .ls-search-trigger {
    background: rgb(255 255 255 / 72%);
    backdrop-filter: blur(10px);
}

.LS-home-b-search {
    width: 42px;
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    padding: 0;
    border: 1px solid rgb(226 232 240 / 58%);
    border-radius: 999px;
    background: rgb(255 255 255 / 72%);
    box-shadow: 0 10px 24px rgb(15 23 42 / 7%);
    backdrop-filter: blur(10px);
}

.LS-home-b-search i {
    color: #111827;
    font-size: 18px;
}

.LS-home-b-search input {
    position: absolute;
    width: 1px;
    height: 1px;
    min-width: 1px;
    opacity: 0;
    pointer-events: none;
    border: 0;
    outline: 0;
    color: #111827;
    background: transparent;
    font-size: 14px;
    font-weight: 700;
}

.LS-home-b-search input::placeholder {
    color: #64748b;
}

.LS-home-b-login,
.LS-home-b-register,
.LS-home-b-auth-user {
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 0;
    border-radius: 999px;
    font-size: 14px;
    font-weight: 900;
    white-space: nowrap;
    cursor: pointer;
}

.LS-home-b-auth-user {
    max-width: 184px;
    justify-content: flex-start;
    gap: 9px;
    padding: 0 12px 0 8px;
    color: #111827;
    background: rgb(255 255 255 / 78%);
    box-shadow: 0 10px 24px rgb(15 23 42 / 8%);
    backdrop-filter: blur(10px);
}

.LS-home-b-auth-user img,
.LS-home-b-auth-user > i {
    width: 30px;
    height: 30px;
    flex: 0 0 30px;
    border-radius: 50%;
}

.LS-home-b-auth-user img {
    object-fit: cover;
}

.LS-home-b-auth-user > i {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #16a34a;
    background: #e8f8ed;
    font-size: 18px;
}

.LS-home-b-auth-user span {
    display: grid;
    min-width: 0;
}

.LS-home-b-auth-user strong,
.LS-home-b-auth-user small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.LS-home-b-auth-user strong {
    font-size: 13px;
    line-height: 1.15;
    font-weight: 900;
}

.LS-home-b-auth-user small {
    margin-top: 3px;
    color: #64748b;
    font-size: 10px;
    line-height: 1;
    font-weight: 700;
}

.LS-home-b-login {
    min-width: 76px;
    padding: 0 18px;
    color: #111827;
    background: rgb(255 255 255 / 78%);
    box-shadow: 0 10px 24px rgb(15 23 42 / 8%);
    backdrop-filter: blur(10px);
}

.LS-home-b-register {
    min-width: 94px;
    padding: 0 18px;
    color: #fff;
    background: linear-gradient(135deg, #3ac95a, #159b3c);
    box-shadow: 0 12px 26px rgb(35 155 54 / 24%);
}

.LS-home-b-login:hover,
.LS-home-b-register:hover,
.LS-home-b-auth-user:hover,
.LS-home-b-nav-item:hover {
    transform: translateY(-1px);
}

.LS-home-b-board,
.LS-home-b-section,
.LS-home-b-tools {
    width: min(var(--home-b-page-width), calc(100% - 32px));
    margin: 0 auto;
}

.LS-home-b-hero {
    width: var(--home-b-wide-width);
    max-width: none;
    margin-left: calc((100% - var(--home-b-wide-width)) / 2);
    min-height: 500px;
    display: grid;
    grid-template-columns: 440px 1fr;
    align-items: center;
    gap: 14px;
    padding: 40px var(--home-b-shell-pad) 18px;
    position: relative;
    overflow: hidden;
}

.LS-home-b.is-hero-viewport .LS-home-b-hero {
    width: var(--home-b-bleed-width);
    margin-left: calc(-1 * var(--home-b-bleed-left));
}

.LS-home-b.is-hero-contained .LS-home-b-hero {
    width: min(var(--home-b-page-width), calc(100% - 32px));
    margin: 0 auto;
    padding-left: 18px;
    padding-right: 18px;
}

.LS-home-b.is-hero-contained .LS-home-b-header,
.LS-home-b.is-hero-contained .LS-home-b-hero-dock {
    left: 18px;
    right: 18px;
}

.LS-home-b-hero.has-header {
    padding-top: 104px;
}

.LS-home-b-hero-dock {
    position: absolute;
    left: var(--home-b-shell-pad);
    right: var(--home-b-shell-pad);
    bottom: 10px;
    z-index: 7;
    display: grid;
    grid-template-columns: 250px minmax(0, 1fr);
    align-items: end;
    gap: var(--home-b-component-gap);
}

.LS-home-b-hero-dock.no-user {
    grid-template-columns: minmax(0, 1fr);
}

.LS-home-b-hero-dock.no-features {
    grid-template-columns: minmax(230px, 250px);
    justify-content: start;
}

.LS-home-b-hero-user-card {
    height: 100%;
    min-height: 0;
    box-shadow: 0 12px 30px rgb(15 23 42 / 10%);
}

.LS-home-b-hero-features {
    min-height: 0;
    align-content: center;
    margin: 0;
}

.LS-home-b-hero.has-bg {
    min-height: 0;
    height: clamp(460px, 50vw, var(--home-b-hero-height));
    aspect-ratio: auto;
}

.LS-home-b-hero-bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    object-position: var(--hero-position, center center);
}

.LS-home-b-hero.has-bg::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    background:
        radial-gradient(ellipse at 18% 58%, rgb(242 251 255 / 82%) 0 220px, rgb(242 251 255 / 34%) 360px, transparent 560px),
        linear-gradient(90deg, rgb(242 251 255 / 96%) 0%, rgb(242 251 255 / 84%) 34%, rgb(242 251 255 / 26%) 58%, rgb(242 251 255 / 0%) 100%);
    pointer-events: none;
}

.LS-home-b-hero.has-bg .LS-home-b-hero-art {
    position: absolute;
    inset: 0;
    z-index: 3;
    min-height: 0;
    pointer-events: none;
}

.LS-home-b-hero-copy {
    position: relative;
    z-index: 5;
    max-width: 520px;
}

.LS-home-b-hero h1 {
    max-width: 520px;
    margin: 0;
    color: #0f172a;
    font-size: 46px;
    line-height: 1.18;
    font-weight: 900;
    letter-spacing: 0;
}

.LS-home-b-hero h1 em {
    color: #22a447;
    font-style: normal;
    margin: 0 4px;
}

.LS-home-b-hero p {
    margin: 16px 0 0;
    color: #374151;
    font-size: 16px;
    line-height: 1.7;
}

.LS-home-b-hero-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 20px;
}

.LS-home-b-btn {
    min-width: 132px;
    min-height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border-radius: 999px;
    font-size: 14px;
    font-weight: 800;
    transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}

.LS-home-b-btn:hover {
    transform: translateY(-2px);
}

.LS-home-b-btn-primary {
    color: #fff;
    background: linear-gradient(135deg, #38c957, #1e9b38);
    box-shadow: 0 14px 28px rgb(35 155 54 / 24%);
}

.LS-home-b-btn-ghost {
    color: #172033;
    background: #fff;
    box-shadow: 0 10px 24px rgb(15 23 42 / 10%);
}

.LS-home-b-people {
    max-width: 430px;
    display: flex;
    align-items: center;
    gap: 9px;
    margin-top: 20px;
    color: #334155;
    font-size: 13px;
    position: relative;
    z-index: 5;
}

.LS-home-b-people strong {
    min-width: 0;
    margin-left: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-weight: 700;
}

.LS-home-b-people-label {
    flex: 0 0 100%;
    color: #475569;
    font-size: 12px;
    font-weight: 800;
}

.LS-home-b-active-avatars {
    display: inline-flex;
    align-items: center;
}

.LS-home-b-active-avatar {
    width: 32px;
    height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-left: -8px;
    padding: 2px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 4px 12px rgb(15 23 42 / 12%);
}

.LS-home-b-active-avatar:first-child { margin-left: 0; }
.LS-home-b-active-avatar .lsaf-avatar-hook { display: inline-flex; }
.LS-home-b-active-avatar img.avatar,
.LS-home-b-active-avatar img {
    width: 28px !important;
    height: 28px !important;
    display: block;
    border-radius: 50%;
    object-fit: cover;
}

.LS-home-b-people strong b {
    color: #16933c;
    font-size: 16px;
}

.LS-home-b-avatar {
    width: 34px;
    height: 34px;
    display: inline-block;
    margin-left: -8px;
    border: 3px solid #fff;
    border-radius: 50%;
    background: linear-gradient(135deg, #ff8a34, #ffd166);
    box-shadow: 0 6px 16px rgb(15 23 42 / 12%);
}

.LS-home-b-avatar:first-child {
    margin-left: 0;
}

.LS-home-b-avatar.a2 { background: linear-gradient(135deg, #48c6ef, #6f86d6); }
.LS-home-b-avatar.a3 { background: linear-gradient(135deg, #f857a6, #ff5858); }
.LS-home-b-avatar.a4 { background: linear-gradient(135deg, #43e97b, #38f9d7); }

.LS-home-b-hero-art {
    min-height: 500px;
    position: relative;
    overflow: visible;
}

.LS-home-b-hero-art.has-image > img {
    display: none;
}

.LS-home-b-hero-art.has-image .LS-home-b-scene {
    display: none;
}

.LS-home-b-scene {
    width: 620px;
    height: 430px;
    position: absolute;
    right: 0;
    bottom: 10px;
    border-radius: 46% 54% 48% 52%;
    background:
        radial-gradient(circle at 44% 36%, #ffffff 0 8px, transparent 9px),
        linear-gradient(160deg, #8be05b 0 36%, #55b846 37% 72%, #b87942 73% 100%);
    box-shadow: 0 34px 60px rgb(96 79 37 / 20%);
    transform: perspective(900px) rotateX(9deg) rotateZ(-2deg);
}

.LS-home-b-scene::before {
    content: "";
    position: absolute;
    inset: 56% 7% 8% 13%;
    border: 5px solid #a06732;
    border-radius: 42% 30% 40% 28%;
}

.LS-home-b-tree {
    width: 170px;
    height: 190px;
    position: absolute;
    left: 86px;
    top: 58px;
}

.LS-home-b-tree::before {
    content: "";
    width: 142px;
    height: 126px;
    position: absolute;
    left: 8px;
    top: 0;
    border-radius: 52% 48% 56% 44%;
    background:
        radial-gradient(circle at 25% 24%, #b6e65d 0 18px, transparent 19px),
        radial-gradient(circle at 64% 20%, #8acb35 0 27px, transparent 28px),
        radial-gradient(circle at 46% 48%, #58a92d 0 44px, transparent 45px),
        #77bd37;
    box-shadow: 0 10px 20px rgb(40 91 30 / 18%);
}

.LS-home-b-tree::after {
    content: "";
    width: 36px;
    height: 118px;
    position: absolute;
    left: 62px;
    top: 84px;
    border-radius: 20px;
    background: linear-gradient(90deg, #8a542b, #b57333);
}

.LS-home-b-house {
    width: 244px;
    height: 224px;
    position: absolute;
    right: 100px;
    top: 80px;
}

.LS-home-b-house .roof {
    width: 250px;
    height: 126px;
    position: absolute;
    left: 0;
    top: 0;
    border-radius: 50px 50px 18px 18px;
    background:
        repeating-linear-gradient(90deg, rgb(188 84 19 / 34%) 0 12px, transparent 13px 34px),
        linear-gradient(135deg, #ffb04c, #e5671e);
    box-shadow: inset 0 -10px 0 rgb(160 66 18 / 24%), 0 14px 26px rgb(155 72 19 / 18%);
    transform: skewX(-8deg);
}

.LS-home-b-house .body {
    width: 196px;
    height: 138px;
    position: absolute;
    left: 28px;
    bottom: 0;
    border: 6px solid #b56d31;
    border-radius: 20px;
    background: linear-gradient(135deg, #fff1c8, #ffd28a);
}

.LS-home-b-house .door {
    width: 68px;
    height: 86px;
    position: absolute;
    left: 86px;
    bottom: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 5px solid #8e4b20;
    border-radius: 18px 18px 6px 6px;
    color: #7b3f17;
    background: linear-gradient(180deg, #e9852d, #b65a22);
    font-weight: 900;
}

.LS-home-b-mascot {
    width: 46px;
    height: 42px;
    position: absolute;
    border-radius: 50% 50% 45% 45%;
    background: #fff;
    border: 4px solid #f28c22;
    box-shadow: inset 0 -9px 0 #ffe0a6, 0 8px 14px rgb(136 82 23 / 20%);
}

.LS-home-b-mascot::before,
.LS-home-b-mascot::after {
    content: "";
    width: 10px;
    height: 10px;
    position: absolute;
    top: 14px;
    border-radius: 50%;
    background: #30343b;
}

.LS-home-b-mascot::before { left: 11px; }
.LS-home-b-mascot::after { right: 11px; }
.LS-home-b-mascot.m1 { left: 230px; top: 252px; }
.LS-home-b-mascot.m2 { right: 190px; bottom: 72px; transform: scale(.82); }
.LS-home-b-mascot.m3 { right: 50px; top: 238px; transform: scale(.72); }

.LS-home-b-float-badge {
    min-width: 74px;
    min-height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    z-index: 5;
    padding: 0 13px;
    border-radius: 999px;
    color: #fff;
    font-size: 13px;
    font-weight: 800;
    box-shadow: 0 12px 26px rgb(15 23 42 / 14%);
}

.LS-home-b-float-badge.badge-0 { left: 130px; top: 118px; }
.LS-home-b-float-badge.badge-1 { right: 32px; top: 246px; }
.LS-home-b-float-badge.badge-2 { right: 180px; bottom: 134px; }
.LS-home-b-float-badge.badge-3 { left: 186px; bottom: 110px; }
.LS-home-b-hero.has-bg .LS-home-b-float-badge.badge-0 { left: 52%; top: 23%; }
.LS-home-b-hero.has-bg .LS-home-b-float-badge.badge-1 { right: 5%; top: 39%; }
.LS-home-b-hero.has-bg .LS-home-b-float-badge.badge-2 { right: 13%; bottom: 35%; }
.LS-home-b-hero.has-bg .LS-home-b-float-badge.badge-3 { left: 48%; bottom: 40%; }
.LS-home-b-float-badge.tone-green { background: linear-gradient(135deg, #46c75c, #199a39); }
.LS-home-b-float-badge.tone-purple { background: linear-gradient(135deg, #a78bfa, #7c3aed); }
.LS-home-b-float-badge.tone-orange { background: linear-gradient(135deg, #ffb340, #f97316); }
.LS-home-b-float-badge.tone-blue { background: linear-gradient(135deg, #60a5fa, #2563eb); }
.LS-home-b-float-badge.tone-red { background: linear-gradient(135deg, #fb7185, #e11d48); }
.LS-home-b-float-badge.tone-pink { background: linear-gradient(135deg, #f472b6, #db2777); }

.LS-home-b-features {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 4px;
    margin: 0;
    padding: 10px 12px;
    border: 1px solid rgb(226 232 240 / 84%);
    border-radius: 14px;
    background: rgb(255 255 255 / 92%);
    box-shadow: 0 10px 28px rgb(15 23 42 / 7%);
    backdrop-filter: blur(14px);
}

.LS-home-b-feature {
    min-height: 58px;
    display: flex;
    align-items: center;
    gap: 9px;
    padding: 7px 6px;
    border-radius: 10px;
    transition: background .2s ease, transform .2s ease;
}

.LS-home-b-feature:hover {
    background: #f8fafc;
    transform: translateY(-2px);
}

.LS-home-b-feature > i {
    width: 38px;
    height: 38px;
    flex: 0 0 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    font-size: 20px;
}

.LS-home-b-feature strong,
.LS-home-b-feature small {
    display: block;
}

.LS-home-b-feature strong {
    color: #182235;
    font-size: 14px;
    line-height: 20px;
}

.LS-home-b-feature small {
    margin-top: 1px;
    color: #64748b;
    font-size: 12px;
    line-height: 17px;
}

.LS-home-b-feature.tone-orange > i { color: #f97316; background: #fff2df; }
.LS-home-b-feature.tone-purple > i { color: #7c3aed; background: #f1edff; }
.LS-home-b-feature.tone-blue > i { color: #2563eb; background: #eaf2ff; }
.LS-home-b-feature.tone-green > i { color: #16a34a; background: #e8f8ed; }
.LS-home-b-feature.tone-red > i { color: #e11d48; background: #ffe8ee; }
.LS-home-b-feature.tone-pink > i { color: #db2777; background: #fce7f3; }

.LS-home-b-board {
    display: grid;
    grid-template-columns: 260px minmax(0, 1fr) 300px;
    align-items: start;
    gap: var(--home-b-component-gap);
    margin-top: var(--home-b-component-gap);
}

.LS-home-b-board.is-no-sidebar {
    grid-template-columns: 260px minmax(0, 1fr);
}

.LS-home-b-board.no-stats {
    grid-template-columns: minmax(0, 1fr) 300px;
}

.LS-home-b-board.no-stats.is-no-sidebar {
    grid-template-columns: minmax(0, 1fr);
}

.LS-home-b-stats,
.LS-home-b-feed,
.LS-home-b-section,
.LS-home-b-tools {
    border: 1px solid rgb(226 232 240 / 82%);
    border-radius: 14px;
    background: rgb(255 255 255 / 94%);
    box-shadow: 0 14px 36px rgb(15 23 42 / 6%);
}

.LS-home-b-left {
    display: flex;
    flex-direction: column;
    gap: var(--home-b-component-gap);
    position: sticky;
    top: var(--home-b-component-gap);
}

.LS-home-b-user-card {
    position: relative;
    overflow: hidden;
    padding: 14px 14px 13px;
    border: 1px solid rgb(255 255 255 / 42%);
    border-radius: 16px;
    color: #fff;
    background:
        radial-gradient(circle at 10% 88%, rgb(169 238 111 / 44%) 0 58px, transparent 59px),
        radial-gradient(circle at 92% 8%, rgb(255 255 255 / 18%) 0 46px, transparent 47px),
        linear-gradient(135deg, #55bd9a 0%, #16818a 100%);
    box-shadow: 0 18px 36px rgb(15 93 84 / 20%);
}

.LS-home-b-user-card::after {
    content: "";
    width: 130px;
    height: 70px;
    position: absolute;
    left: -28px;
    bottom: -18px;
    border-radius: 50%;
    background: rgb(127 219 117 / 28%);
    pointer-events: none;
}

.LS-home-b-user-head {
    display: grid;
    grid-template-columns: 50px minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
    position: relative;
    z-index: 1;
}

.LS-home-b-user-head img {
    width: 50px;
    height: 50px;
    display: block;
    border: 3px solid rgb(255 255 255 / 72%);
    border-radius: 50%;
    background: #fff;
    object-fit: cover;
    box-shadow: 0 10px 20px rgb(15 23 42 / 16%);
}

.LS-home-b-paiii-avatar {
    width: 50px;
    height: 50px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 3px solid rgb(255 255 255 / 72%);
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 10px 20px rgb(15 23 42 / 16%);
}

.LS-home-b-paiii-avatar .lsaf-avatar-hook { display: inline-flex; }
.LS-home-b-paiii-avatar img.avatar,
.LS-home-b-paiii-avatar img {
    width: 44px !important;
    height: 44px !important;
    border: 0;
    border-radius: 50%;
    object-fit: cover;
    box-shadow: none;
}

.LS-home-b-user-head strong .nickname,
.LS-home-b-user-head strong font { color: #fff !important; }
.LS-home-b-user-head small .ls-mark,
.LS-home-b-user-head small img { max-height: 17px; width: auto; vertical-align: middle; }

.LS-home-b-user-head span {
    min-width: 0;
}

.LS-home-b-user-head strong,
.LS-home-b-user-head small {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.LS-home-b-user-head strong {
    font-size: 17px;
    line-height: 23px;
    font-weight: 900;
}

.LS-home-b-user-head small {
    margin-top: 2px;
    color: rgb(255 255 255 / 82%);
    font-size: 13px;
    line-height: 18px;
}

.LS-home-b-user-head em {
    min-width: 42px;
    height: 20px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    align-self: start;
    margin-top: 5px;
    padding: 0 8px;
    border-radius: 999px;
    color: #fff;
    background: #f5a400;
    font-size: 11px;
    line-height: 20px;
    font-style: normal;
    font-weight: 900;
}

.LS-home-b-user-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
    margin-top: 9px;
    position: relative;
    z-index: 1;
    text-align: center;
}

.LS-home-b-user-metrics strong,
.LS-home-b-user-metrics small {
    display: block;
}

.LS-home-b-user-metrics strong {
    font-size: 20px;
    line-height: 24px;
    font-weight: 900;
}

.LS-home-b-user-metrics small {
    margin-top: 2px;
    color: rgb(255 255 255 / 82%);
    font-size: 12px;
}

.LS-home-b-sign-card {
    min-height: 50px;
    display: grid;
    grid-template-columns: 32px minmax(0, 1fr) 58px;
    align-items: center;
    gap: 7px;
    margin-top: 9px;
    padding: 7px 9px;
    position: relative;
    z-index: 1;
    border-radius: 14px;
    color: #315b1d;
    background: linear-gradient(135deg, #dff7a7, #b9ed8b);
    box-shadow: inset 0 1px 0 rgb(255 255 255 / 62%), 0 10px 18px rgb(34 89 45 / 18%);
}

.LS-home-b-sign-card > i {
    width: 30px;
    height: 30px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    color: #78b326;
    background: #f9ffe9;
    font-size: 18px;
}

.LS-home-b-sign-card span {
    min-width: 0;
}

.LS-home-b-sign-card strong,
.LS-home-b-sign-card small {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.LS-home-b-sign-card strong {
    color: #27551b;
    font-size: 13px;
    line-height: 18px;
    font-weight: 900;
}

.LS-home-b-sign-card small {
    margin-top: 2px;
    color: #5b7c37;
    font-size: 11px;
}

.LS-home-b-sign-card b {
    min-height: 30px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    color: #30a23b;
    background: #fff;
    font-size: 13px;
    font-weight: 900;
    box-shadow: 0 6px 12px rgb(72 143 45 / 14%);
}

.LS-home-b-side-panel {
    padding: 13px;
    border: 1px solid rgb(226 232 240 / 82%);
    border-radius: 14px;
    background: rgb(255 255 255 / 94%);
    box-shadow: 0 14px 36px rgb(15 23 42 / 6%);
}

.LS-home-b-side-panel h3 {
    min-height: 22px;
    display: flex;
    align-items: center;
    gap: 7px;
    margin: 0 0 12px;
    color: #111827;
    font-size: 14px;
    line-height: 22px;
    font-weight: 900;
}

.LS-home-b-side-panel h3 > i {
    color: #16a34a;
    font-size: 17px;
}

.LS-home-b-side-panel h3 > a {
    display: inline-flex;
    align-items: center;
    gap: 1px;
    margin-left: auto;
    color: #94a3b8;
    font-size: 11px;
    font-weight: 800;
}

/* Paiii 左栏：LightSNS 真实成就与社区导航 */
.LS-home-b-achievement h3,
.LS-home-b-community-nav h3 {
    margin-bottom: 12px;
}

.LS-home-b-achievement h3 > em {
    margin-left: auto;
    padding: 3px 9px;
    border-radius: 999px;
    color: #168c3c;
    background: #e9f8ee;
    font-size: 12px;
    font-style: normal;
}

.LS-home-b-achievement-bar {
    height: 7px;
    overflow: hidden;
    border-radius: 999px;
    background: #eef3ef;
}

.LS-home-b-achievement-bar span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #ffad32, #32b957);
}

.LS-home-b-achievement-exp {
    display: flex;
    justify-content: space-between;
    margin-top: 7px;
    color: #8b9590;
    font-size: 12px;
}

.LS-home-b-achievement-medals {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 7px;
    margin-top: 12px;
}

.LS-home-b-achievement-medals span {
    height: 38px;
    display: grid;
    place-items: center;
    border: 1px solid #f2ddb1;
    border-radius: 12px;
    color: #c6aa6d;
    background: #fff8e8;
}

.LS-home-b-achievement-medals span.is-on {
    border-color: transparent;
    color: #fff;
    background: linear-gradient(135deg, #ffba30, #f4a51f);
}

.LS-home-b-achievement-medals i { font-size: 18px; }

.LS-home-b-achievement-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 12px;
}

.LS-home-b-achievement-tags > span {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 5px 9px;
    border-radius: 999px;
    color: #53615a;
    background: #f1f6f2;
    font-size: 12px;
    font-weight: 700;
}

.LS-home-b-achievement-tags .kind-lv { color: #168c3c; background: #e9f8ee; }
.LS-home-b-achievement-tags .kind-vip { color: #a86413; background: #fdf1dc; }
.LS-home-b-achievement-tags .kind-verify { color: #2f6fe0; background: #e9f1ff; }
.LS-home-b-achievement-tags .kind-sign { color: #d9612f; background: #ffefe4; }

.LS-home-b-achievement-links {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
    margin-top: 12px;
}

.LS-home-b-achievement-links a {
    min-height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    border-radius: 10px;
    color: #26332d;
    background: #f1f6f2;
    font-size: 13px;
    font-weight: 700;
}

.LS-home-b-achievement-guest {
    display: grid;
    justify-items: center;
    gap: 8px;
    padding: 12px 4px 4px;
    color: #718078;
    text-align: center;
    font-size: 12px;
}

.LS-home-b-achievement-guest > i { color: #25ad50; font-size: 26px; }
.LS-home-b-achievement-guest button {
    min-height: 34px;
    padding: 0 18px;
    border: 0;
    border-radius: 999px;
    color: #fff;
    background: #24ad4e;
    cursor: pointer;
}

.LS-home-b-community-item {
    width: 100%;
    min-height: 48px;
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr);
    align-items: center;
    gap: 9px;
    padding: 6px 8px;
    border: 0;
    border-radius: 11px;
    color: #5d6862;
    background: transparent;
    text-align: left;
    cursor: pointer;
}

.LS-home-b-community-item + .LS-home-b-community-item { margin-top: 3px; }
.LS-home-b-community-item > i {
    width: 34px;
    height: 34px;
    display: grid;
    place-items: center;
    border-radius: 10px;
    color: #25ad50;
    background: #f0f6f1;
    font-size: 18px;
}

.LS-home-b-community-item span { min-width: 0; display: grid; gap: 2px; }
.LS-home-b-community-item strong { color: inherit; font-size: 13.5px; }
.LS-home-b-community-item small { color: #9aa39e; font-size: 11.5px; }
.LS-home-b-community-item:hover,
.LS-home-b-community-item.is-active { color: #15913b; background: #eaf8ef; }
.LS-home-b-community-item.is-active > i { background: #fff; box-shadow: inset 0 0 0 1px rgb(37 173 80 / 16%); }

.LS-home-b-shortcut-list,
.LS-home-b-calendar-list {
    display: flex;
    flex-direction: column;
}

.LS-home-b-shortcut {
    min-height: 28px;
    display: grid;
    grid-template-columns: 18px minmax(0, 1fr) auto;
    align-items: center;
    gap: 8px;
    color: #334155;
    font-size: 13px;
    font-weight: 800;
}

.LS-home-b-shortcut + .LS-home-b-shortcut {
    margin-top: 6px;
}

.LS-home-b-shortcut > i {
    width: 18px;
    text-align: center;
    color: #16a34a;
    font-size: 15px;
}

.LS-home-b-shortcut span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.LS-home-b-shortcut b {
    color: #cbd5e1;
    font-weight: 400;
}

.LS-home-b-shortcut em {
    min-width: 22px;
    height: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 6px;
    border-radius: 999px;
    color: #fff;
    background: #22c55e;
    font-size: 10px;
    line-height: 18px;
    font-style: normal;
    font-weight: 900;
}

.LS-home-b-shortcut.tone-orange > i { color: #f97316; }
.LS-home-b-shortcut.tone-blue > i { color: #3b82f6; }
.LS-home-b-shortcut.tone-purple > i { color: #8b5cf6; }
.LS-home-b-shortcut.tone-red > i { color: #ef4444; }
.LS-home-b-shortcut.tone-pink > i { color: #ec4899; }
.LS-home-b-shortcut.tone-yellow > i { color: #eab308; }
.LS-home-b-shortcut.tone-cyan > i { color: #06b6d4; }

.LS-home-b-calendar-item {
    min-height: 45px;
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr) auto;
    grid-template-areas:
        "cover title status"
        "cover time status";
    align-items: center;
    column-gap: 9px;
}

.LS-home-b-calendar-item + .LS-home-b-calendar-item {
    margin-top: 10px;
}

.LS-home-b-calendar-item img,
.LS-home-b-calendar-cover {
    grid-area: cover;
    width: 42px;
    height: 42px;
    display: block;
    border-radius: 8px;
    object-fit: cover;
}

.LS-home-b-calendar-cover {
    background:
        radial-gradient(circle at 28% 28%, rgb(255 255 255 / 48%) 0 7px, transparent 8px),
        linear-gradient(135deg, #8b5cf6, #f59e0b);
}

.LS-home-b-calendar-cover.cover-1 { background: linear-gradient(135deg, #93c5fd, #22c55e); }
.LS-home-b-calendar-cover.cover-2 { background: linear-gradient(135deg, #111827, #f97316); }
.LS-home-b-calendar-cover.cover-3 { background: linear-gradient(135deg, #fb7185, #7c3aed); }

.LS-home-b-calendar-item strong {
    grid-area: title;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: #111827;
    font-size: 12px;
    line-height: 17px;
    font-weight: 900;
}

.LS-home-b-calendar-item small {
    grid-area: time;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: #64748b;
    font-size: 11px;
    line-height: 16px;
}

.LS-home-b-calendar-item em {
    grid-area: status;
    min-width: 44px;
    min-height: 22px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 8px;
    border-radius: 999px;
    color: #16a34a;
    background: #dcfce7;
    font-size: 11px;
    line-height: 22px;
    font-style: normal;
    font-weight: 900;
}

.LS-home-b-stats {
    padding: 15px 14px;
}

.LS-home-b-left .LS-home-b-stats {
    position: static;
    top: auto;
}

.LS-home-b h2 {
    margin: 0;
    color: #111827;
    font-size: 18px;
    line-height: 26px;
    font-weight: 900;
    letter-spacing: 0;
}

.LS-home-b-stats h2 {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 10px;
}

.LS-home-b-stats h2 i { color: #16a34a; }

.LS-home-b-stat {
    display: flex;
    align-items: center;
    gap: var(--home-b-component-gap);
    padding: 10px 0;
}

.LS-home-b-stat i {
    width: 26px;
    flex: 0 0 26px;
    text-align: center;
    font-size: 20px;
}

.LS-home-b-stat strong,
.LS-home-b-stat small {
    display: block;
}

.LS-home-b-stat strong {
    font-size: 21px;
    line-height: 26px;
    color: #16a34a;
}

.LS-home-b-stat small {
    margin-top: 4px;
    color: #64748b;
    font-size: 12px;
}

.LS-home-b-stat.tone-orange strong,
.LS-home-b-stat.tone-orange i { color: #f59e0b; }
.LS-home-b-stat.tone-red strong,
.LS-home-b-stat.tone-red i { color: #ef4444; }
.LS-home-b-stat.tone-pink strong,
.LS-home-b-stat.tone-pink i { color: #f472b6; }
.LS-home-b-stat.tone-blue strong,
.LS-home-b-stat.tone-blue i { color: #2563eb; }
.LS-home-b-stat.tone-green strong,
.LS-home-b-stat.tone-green i { color: #16a34a; }

.LS-home-b-soft-link {
    min-height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 10px;
    border-radius: 9px;
    color: #199a39;
    background: #edf8ed;
    font-size: 13px;
    font-weight: 800;
}

.LS-home-b-feed {
    min-width: 0;
    padding: 0 16px 16px;
}

.LS-home-b-feed-tabs {
    min-height: 50px;
    display: flex;
    align-items: center;
    gap: 14px;
    border-bottom: 1px solid #eef2f6;
}

.LS-home-b-menu-item {
    height: 50px;
    border: 0;
    border-bottom: 3px solid transparent;
    background: transparent;
    color: #334155;
    font-size: 15px;
    line-height: 20px;
    font-weight: 800;
    cursor: pointer;
    transition: color .2s ease, border-color .2s ease;
}

.LS-home-b-menu-item:hover,
.LS-home-b-menu-item.is-active {
    color: #16a34a;
    border-bottom-color: #16a34a;
}

.LS-home-b-post-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding-top: 10px;
}

.LS-home-b .ls-post-item {
    overflow: visible;
    border: 1px solid #eef2f6;
    border-radius: 12px;
    box-shadow: none;
}

.LS-home-b .LS-home-b-has-mark {
    margin-top: 16px;
}

.LS-home-b-post-markx {
    position: absolute;
    right: 12px;
    top: -10px;
    display: flex;
    align-items: center;
    z-index: 9;
}

.LS-home-b-post-mark {
    min-width: 8px;
    display: inline-block;
    position: relative;
    margin: 0 8px 0 0;
    padding: 5px 10px;
    border-radius: 0 6px 6px 6px;
    color: #fff;
    font-size: 12px;
    line-height: 18px;
    border-color: #f44336;
}

.LS-home-b-post-mark-top {
    background: #2563eb;
    border-color: #2563eb;
}

.LS-home-b-post-mark-top::before {
    content: "置顶";
}

.LS-home-b-post-mark-commend {
    background: #f97316;
    border-color: #f97316;
}

.LS-home-b-post-mark-commend::before {
    content: "推荐";
}

.LS-home-b-post-mark::after {
    content: "";
    position: absolute;
    top: 2px;
    left: -5px;
    width: 0;
    height: 0;
    border-right: 4px solid transparent;
    border-left: 4px solid transparent;
    border-bottom: 4px solid;
    border-bottom-color: inherit;
    transform: rotate(135deg);
}

.LS-home-b-empty {
    min-height: 180px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    background: #f8fafc;
    color: #94a3b8;
    font-size: 14px;
}

.LS-home-b-empty i {
    font-size: 30px;
}

.LS-home-b-more {
    width: 100%;
    min-height: 42px;
    margin-top: 10px;
    border: 0;
    border-radius: 10px;
    background: #f0f9f1;
    color: #199a39;
    font-size: 14px;
    font-weight: 800;
    cursor: pointer;
    transition: transform .2s ease, background .2s ease;
}

.LS-home-b-more:hover {
    background: #dcf5df;
    transform: translateY(-1px);
}

.LS-home-b-more:disabled {
    cursor: default;
    opacity: .65;
    transform: none;
}

.LS-home-b-more.is-auto-hidden {
    min-height: 2px;
    height: 2px;
    margin-top: 2px;
    padding: 0;
    overflow: hidden;
    opacity: 0;
    pointer-events: none;
}

.LS-home-b-right {
    display: flex;
    flex-direction: column;
    gap: var(--home-b-component-gap);
    position: sticky;
    top: var(--home-b-component-gap);
}

.LS-home-b-widget-panel {
    width: 100%;
}

.LS-home-b-section,
.LS-home-b-tools {
    margin-top: var(--home-b-component-gap);
    padding: 14px 16px 16px;
}

.LS-home-b-section-head {
    display: flex;
    align-items: center;
    gap: 14px;
    min-height: 40px;
    margin-bottom: 10px;
}

.LS-home-b-section-head h2 {
    font-size: 22px;
}

.LS-home-b-section-head > a {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin-left: auto;
    color: #64748b;
    font-size: 13px;
    font-weight: 700;
}

.LS-home-b-pills {
    display: flex;
    align-items: center;
    gap: 12px;
    color: #475569;
    font-size: 13px;
    font-weight: 700;
}

.LS-home-b-pills span:first-child {
    min-width: 48px;
    min-height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    color: #16a34a;
    background: #e9f9ed;
}

.LS-home-b-content-wrap {
    position: relative;
}

.LS-home-b-card-track {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: calc((100% - 40px) / 5);
    gap: var(--home-b-component-gap);
    overflow-x: auto;
    scroll-behavior: smooth;
    scrollbar-width: none;
}

.LS-home-b-card-track::-webkit-scrollbar {
    display: none;
}

.LS-home-b-card {
    min-width: 0;
    position: relative;
    overflow: hidden;
    border: 1px solid #eef2f6;
    border-radius: 12px;
    background: #fff;
    transition: transform .2s ease, box-shadow .2s ease;
}

.LS-home-b-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 14px 24px rgb(15 23 42 / 8%);
}

.LS-home-b-card img,
.LS-home-b-cover {
    width: 100%;
    aspect-ratio: 1.55;
    display: block;
    object-fit: cover;
}

.LS-home-b-cover {
    background:
        radial-gradient(circle at 20% 22%, rgb(255 255 255 / 46%) 0 18px, transparent 19px),
        linear-gradient(135deg, #111827, #fb923c);
}

.LS-home-b-cover.cover-1 { background: linear-gradient(135deg, #bae6fd, #65a30d); }
.LS-home-b-cover.cover-2 { background: linear-gradient(135deg, #581c87, #0f172a); }
.LS-home-b-cover.cover-3 { background: linear-gradient(135deg, #9ca3af, #111827); }
.LS-home-b-cover.cover-4 { background: linear-gradient(135deg, #111827, #f59e0b); }

.LS-home-b-card em {
    position: absolute;
    left: 10px;
    top: 10px;
    min-height: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 9px;
    border-radius: 999px;
    color: #fff;
    background: #f97316;
    font-size: 12px;
    font-style: normal;
    font-weight: 800;
}

.LS-home-b-card strong {
    display: block;
    margin: 11px 12px 5px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: #111827;
    font-size: 15px;
    line-height: 22px;
}

.LS-home-b-card small {
    display: flex;
    align-items: center;
    gap: var(--home-b-component-gap);
    margin: 0 12px 12px;
    overflow: hidden;
    color: #64748b;
    font-size: 12px;
}

.LS-home-b-card small span {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    white-space: nowrap;
}

.LS-home-b-card-arrow {
    width: 38px;
    height: 38px;
    position: absolute;
    top: 44%;
    z-index: 2;
    border: 1px solid #e2e8f0;
    border-radius: 50%;
    background: #fff;
    color: #0f172a;
    box-shadow: 0 8px 18px rgb(15 23 42 / 12%);
    cursor: pointer;
}

.LS-home-b-card-arrow.prev { left: -18px; }
.LS-home-b-card-arrow.next { right: -18px; }
.LS-home-b-card-arrow i { font-size: 24px; }

.LS-home-b-section-head.compact {
    display: block;
    margin-bottom: 10px;
}

.LS-home-b-section-head.compact p {
    margin: 3px 0 0;
    color: #64748b;
    font-size: 14px;
}

.LS-home-b-tool-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(200px, 1fr)) minmax(300px, 1.45fr);
    gap: var(--home-b-component-gap);
    overflow-x: auto;
    scrollbar-width: none;
}

.LS-home-b-tool-grid::-webkit-scrollbar {
    display: none;
}

.LS-home-b-tool,
.LS-home-b-tool-more {
    min-height: 112px;
    display: grid;
    align-items: center;
    gap: 10px;
    padding: 14px;
    border: 1px solid #eef2f6;
    border-radius: 12px;
    background: #fff;
}

.LS-home-b-tool {
    grid-template-columns: 54px minmax(0, 1fr);
}

.LS-home-b-tool > i,
.LS-home-b-tool-icon {
    width: 54px;
    height: 54px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 18px;
    color: #f97316;
    background: #fff2df;
    font-size: 28px;
}

.LS-home-b-tool-icon {
    display: block;
    object-fit: cover;
}

.LS-home-b-tool span {
    min-width: 0;
}

.LS-home-b-tool strong,
.LS-home-b-tool small,
.LS-home-b-tool b {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.LS-home-b-tool strong {
    color: #111827;
    font-size: 16px;
    line-height: 24px;
}

.LS-home-b-tool small {
    margin-top: 3px;
    color: #64748b;
    font-size: 13px;
    line-height: 18px;
}

.LS-home-b-tool b {
    margin-top: 13px;
    color: #16a34a;
    font-size: 13px;
}

.LS-home-b-tool-more {
    grid-template-columns: minmax(0, 1fr) 86px;
    grid-template-areas:
        "title icon"
        "desc icon"
        "button icon";
    align-items: flex-start;
    justify-content: center;
    position: relative;
    overflow: hidden;
    border-color: #fee7be;
    background:
        radial-gradient(circle at 88% 66%, rgb(255 255 255 / 88%) 0 36px, transparent 37px),
        radial-gradient(circle at 82% 14%, rgb(255 196 80 / 46%) 0 18px, transparent 19px),
        linear-gradient(135deg, #fff7eb, #ffe1b6 62%, #fff1d7);
}

.LS-home-b-tool-more::before,
.LS-home-b-tool-more::after {
    content: "";
    position: absolute;
    pointer-events: none;
}

.LS-home-b-tool-more::before {
    width: 28px;
    height: 28px;
    right: 18px;
    top: 16px;
    border-radius: 8px;
    background: linear-gradient(135deg, #ffd166, #f97316);
    transform: rotate(28deg);
}

.LS-home-b-tool-more::after {
    grid-area: icon;
    width: 74px;
    height: 74px;
    right: 16px;
    bottom: 12px;
    border-radius: 50%;
    background:
        radial-gradient(circle at 50% 42%, #f97316 0 5px, transparent 6px),
        radial-gradient(circle at 33% 38%, #111827 0 4px, transparent 5px),
        radial-gradient(circle at 67% 38%, #111827 0 4px, transparent 5px),
        radial-gradient(circle at 50% 62%, #fff 0 22px, transparent 23px),
        linear-gradient(135deg, #ffb84d, #f97316);
    box-shadow: inset 0 -8px 0 rgb(255 255 255 / 36%);
}

.LS-home-b-tool-more.has-image::after {
    display: none;
}

.LS-home-b-tool-more > img {
    grid-area: icon;
    width: 86px;
    height: 86px;
    position: relative;
    z-index: 1;
    align-self: center;
    justify-self: end;
    object-fit: contain;
}

.LS-home-b-tool-more span {
    grid-area: title;
    position: relative;
    z-index: 1;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: #111827;
    font-size: 18px;
    line-height: 26px;
    font-weight: 900;
}

.LS-home-b-tool-more small {
    grid-area: desc;
    position: relative;
    z-index: 1;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: #64748b;
    font-size: 13px;
}

.LS-home-b-tool-more b {
    grid-area: button;
    position: relative;
    z-index: 1;
    min-height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 4px;
    padding: 0 14px;
    border-radius: 999px;
    color: #fff;
    background: #16a34a;
    font-size: 13px;
    white-space: nowrap;
}

.LS-home-b-sidebar-hint {
    padding: 16px;
    border: 1px dashed #d9e2ef;
    border-radius: 12px;
    color: #64748b;
    background: rgb(255 255 255 / 80%);
    font-size: 13px;
    line-height: 1.7;
}

@media (max-width: 1280px) {
    .LS-home-b-header {
        grid-template-columns: 190px minmax(0, 1fr) auto;
        gap: 12px;
    }

    .LS-home-b-brand img,
    .LS-home-b-brand-mark {
        width: var(--home-b-logo-width);
        height: var(--home-b-logo-height);
        flex-basis: var(--home-b-logo-width);
        border-radius: 14px;
    }

    .LS-home-b-brand strong {
        font-size: 22px;
    }

    .LS-home-b-brand small {
        font-size: 12px;
    }

    .LS-home-b-nav {
        gap: 14px;
    }

    .LS-home-b-nav-item strong {
        font-size: 13px;
    }

    .LS-home-b-nav-item small {
        display: none;
    }

    .LS-home-b-login,
    .LS-home-b-register {
        min-width: 0;
        padding: 0 13px;
    }

    .LS-home-b-auth-user {
        max-width: 164px;
    }

    .LS-home-b-hero {
        grid-template-columns: 1fr;
        min-height: auto;
    }

    .LS-home-b-hero.has-bg {
        height: clamp(460px, 50vw, var(--home-b-hero-height));
        aspect-ratio: auto;
    }

    .LS-home-b-hero.has-bg .LS-home-b-hero-copy {
        max-width: 46%;
    }

    .LS-home-b-hero-dock {
        grid-template-columns: 230px minmax(0, 1fr);
        gap: var(--home-b-component-gap);
    }

    .LS-home-b-hero-features {
        padding: 9px 10px;
    }

    .LS-home-b-hero-features .LS-home-b-feature {
        gap: 10px;
        padding-inline: 4px;
    }

    .LS-home-b-hero.has-bg .LS-home-b-float-badge.badge-0 {
        left: auto;
        right: 31%;
        top: 18%;
    }

    .LS-home-b-hero.has-bg .LS-home-b-float-badge.badge-3 {
        left: auto;
        right: 34%;
        bottom: 20%;
    }

    .LS-home-b-hero-art {
        min-height: 390px;
    }

    .LS-home-b-hero.has-bg .LS-home-b-hero-art {
        min-height: 0;
    }

    .LS-home-b-scene {
        left: 50%;
        right: auto;
        transform: translateX(-50%) perspective(900px) rotateX(9deg) rotateZ(-2deg) scale(.84);
        transform-origin: center bottom;
    }

    .LS-home-b-board {
        grid-template-columns: 240px minmax(0, 1fr);
    }

    .LS-home-b-board.no-stats {
        grid-template-columns: minmax(0, 1fr);
    }

    .LS-home-b-right {
        grid-column: 1 / -1;
        position: static;
    }

    .LS-home-b-tool-grid {
        grid-template-columns: repeat(4, minmax(200px, 1fr)) minmax(300px, 1.45fr);
    }
}

@media (max-width: 820px) {
    .LS-home-b-header {
        top: 14px;
        left: 14px;
        right: 14px;
        grid-template-columns: minmax(0, 1fr) auto;
        gap: 10px 12px;
        min-height: 0;
    }

    .LS-home-b-brand {
        gap: 8px;
    }

    .LS-home-b-brand img,
    .LS-home-b-brand-mark {
        width: var(--home-b-logo-width);
        height: var(--home-b-logo-height);
        flex-basis: var(--home-b-logo-width);
        border-radius: 12px;
    }

    .LS-home-b-brand strong {
        font-size: 20px;
    }

    .LS-home-b-brand small {
        font-size: 11px;
    }

    .LS-home-b-header-actions {
        gap: 8px;
    }

    .LS-home-b-search {
        width: 42px;
        padding: 0;
        justify-content: center;
    }

    .LS-home-b-search input {
        position: absolute;
        width: 1px;
        height: 1px;
        opacity: 0;
        pointer-events: none;
    }

    .LS-home-b-login {
        min-width: 58px;
        padding: 0 12px;
    }

    .LS-home-b-register {
        min-width: 76px;
        padding: 0 12px;
    }

    .LS-home-b-auth-user {
        width: 42px;
        max-width: 42px;
        padding: 0;
        justify-content: center;
    }

    .LS-home-b-auth-user span {
        display: none;
    }

    .LS-home-b-nav {
        grid-column: 1 / -1;
        justify-content: flex-start;
        gap: 18px;
        overflow-x: auto;
        padding: 2px 0 4px;
        scrollbar-width: none;
    }

    .LS-home-b-nav::-webkit-scrollbar {
        display: none;
    }

    .LS-home-b-nav-item {
        gap: 4px;
        padding-bottom: 10px;
    }

    .LS-home-b-nav-item i {
        display: inline-block;
    }

    .LS-home-b-nav-item strong {
        font-size: 13px;
    }

    .LS-home-b-board,
    .LS-home-b-section,
    .LS-home-b-tools {
        width: min(100% - 20px, 720px);
    }

    .LS-home-b-hero {
        width: 100%;
        margin-left: 0;
        padding-top: 28px;
        padding-left: 10px;
        padding-right: 10px;
    }

    .LS-home-b-hero.has-header {
        padding-top: 126px;
    }

    .LS-home-b-hero.has-bg {
        min-height: 430px;
    }

    .LS-home-b-hero.has-bg {
        aspect-ratio: auto;
        height: auto;
        min-height: 0;
    }

    .LS-home-b-hero.has-bg .LS-home-b-hero-bg {
        height: 100%;
    }

    .LS-home-b-hero-dock {
        position: relative;
        left: auto;
        right: auto;
        bottom: auto;
        width: 100%;
        grid-template-columns: 1fr;
        margin-top: 24px;
    }

    .LS-home-b-hero-dock.no-features {
        grid-template-columns: 1fr;
    }

    .LS-home-b-hero-user-card,
    .LS-home-b-hero-features {
        min-height: 0;
    }

    .LS-home-b-hero.has-bg .LS-home-b-hero-copy {
        max-width: min(420px, 78%);
    }

    .LS-home-b-hero.has-bg .LS-home-b-float-badge {
        display: none;
    }

    .LS-home-b-hero h1 {
        font-size: 38px;
    }

    .LS-home-b-features,
    .LS-home-b-board,
    .LS-home-b-left,
    .LS-home-b-right {
        grid-template-columns: 1fr;
    }

    .LS-home-b-board.no-stats {
        grid-template-columns: 1fr;
    }

    .LS-home-b-stats,
    .LS-home-b-left,
    .LS-home-b-right {
        position: static;
    }

    .LS-home-b-features {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .LS-home-b-feed-tabs,
    .LS-home-b-pills {
        overflow-x: auto;
        white-space: nowrap;
    }

    .LS-home-b-card-track {
        grid-auto-columns: min(260px, 78vw);
    }

    .LS-home-b-tool-grid {
        grid-template-columns: repeat(4, minmax(200px, 1fr)) minmax(300px, 1.45fr);
    }
}
