:root{
  --green:#07883f;
  --green-2:#0aa352;
  --green-3:#e9f8f0;
  --green-4:#f3fbf6;
  --ink:#101418;
  --muted:#667085;
  --soft:#f6f8f7;
  --line:#e5ebe8;
  --line-2:#dfe8e3;
  --card:#ffffff;
  --shadow:0 24px 60px rgba(16,24,40,.08);
  --shadow-soft:0 12px 32px rgba(16,24,40,.06);
  --radius-xl:28px;
  --radius-lg:22px;
  --radius-md:16px;
  --container:1200px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Hiragino Sans GB","Microsoft YaHei","Helvetica Neue",Arial,sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at 50% 0%, rgba(7,136,63,0.08), transparent 30%),
    linear-gradient(180deg, #ffffff 0%, #fbfdfc 100%);
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button,input{font:inherit}
.container{width:min(var(--container),calc(100% - 48px));margin:0 auto}
.site-header{
  position:sticky;top:0;z-index:50;
  border-bottom:1px solid rgba(229,235,232,.84);
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(18px);
}
.nav{
  height:76px;display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.brand{
  display:inline-flex;align-items:center;gap:12px;
  color:var(--green);font-size:26px;font-weight:850;letter-spacing:-.04em;
}
.brand img{width:28px;height:28px}
.nav-menu{display:flex;align-items:center;gap:34px;color:#26312b;font-size:15px}
.nav-menu a{position:relative;padding:10px 0}
.nav-menu a.active{color:var(--green);font-weight:700}
.nav-menu a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-18px;height:2px;border-radius:2px;background:var(--green);
}
.nav-user{display:flex;align-items:center;gap:14px}
.user-link,.ghost-pill{
  display:inline-flex;align-items:center;gap:10px;padding:10px 14px;border-radius:999px;border:1px solid var(--line);background:#fff;
  color:#34423b;font-size:14px;font-weight:600;
}
.user-avatar{width:28px;height:28px;border-radius:50%}
.page{padding:28px 0 70px}
.section{padding:26px 0}
.grid{display:grid;gap:24px}
.card{
  background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius-xl);box-shadow:var(--shadow-soft);
}
.page-hero{
  display:grid;grid-template-columns:1.05fr .95fr;gap:24px;align-items:stretch;
}
.hero-card{
  padding:46px 44px;background:linear-gradient(180deg,#ffffff 0%,#f7fbf8 100%);
}
.hero-card h1{
  margin:8px 0 14px;font-size:52px;line-height:1.05;letter-spacing:-.05em;
}
.hero-card h1 span{color:var(--green)}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;padding:10px 14px;border-radius:999px;
  background:var(--green-3);color:var(--green);font-size:13px;font-weight:800;letter-spacing:.01em;
}
.lead{
  margin:0 0 24px;color:#475467;font-size:18px;line-height:1.8;max-width:620px;
}
.hero-actions,.action-row{display:flex;flex-wrap:wrap;gap:14px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  min-height:50px;padding:0 20px;border-radius:14px;border:1px solid transparent;
  font-weight:800;transition:.2s ease;cursor:pointer;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{
  color:#fff;background:linear-gradient(180deg,var(--green-2) 0%, var(--green) 100%);
  box-shadow:0 12px 30px rgba(7,136,63,.18);
}
.btn-secondary{
  color:#26312b;background:#fff;border-color:var(--line);
}
.btn-link{
  color:var(--green);background:transparent;border:0;padding:0;min-height:auto;
}
.hero-metrics{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:30px;
}
.metric{
  padding:18px 18px 16px;border-radius:18px;background:#fff;border:1px solid var(--line);box-shadow:0 6px 18px rgba(16,24,40,.03);
}
.metric strong{display:block;font-size:22px;letter-spacing:-.03em;margin-bottom:4px}
.metric span{font-size:13px;color:var(--muted)}
.preview-card{
  padding:24px;background:
    radial-gradient(circle at right top, rgba(7,136,63,.08), transparent 34%),
    linear-gradient(180deg,#fff 0%,#f6fbf8 100%);
  overflow:hidden;
}
.preview-window{
  border-radius:24px;border:1px solid #dce9e2;background:#fff;box-shadow:0 20px 50px rgba(16,24,40,.08);
  overflow:hidden;height:100%;
}
.window-top{
  height:54px;display:flex;align-items:center;padding:0 18px;border-bottom:1px solid var(--line);gap:8px;background:#fcfefd;
}
.window-top span{width:10px;height:10px;border-radius:50%}
.window-top span:nth-child(1){background:#ff6b63}
.window-top span:nth-child(2){background:#ffc447}
.window-top span:nth-child(3){background:#41d17a}
.preview-body{
  padding:22px;display:grid;grid-template-columns:1.15fr .85fr;gap:18px;min-height:430px;
}
.preview-board{
  border:1px solid var(--line);border-radius:22px;background:linear-gradient(180deg,#f9fbfa 0%,#ffffff 100%);
  padding:18px;display:flex;flex-direction:column;gap:14px;
}
.preview-toolbar{display:flex;justify-content:space-between;align-items:center}
.preview-chip{display:inline-flex;align-items:center;padding:7px 12px;border-radius:999px;background:var(--green-3);color:var(--green);font-weight:800;font-size:12px}
.preview-title{display:flex;flex-direction:column;gap:6px}
.preview-title strong{font-size:26px;letter-spacing:-.04em}
.preview-title span{color:var(--muted);font-size:14px}
.preview-list{display:grid;gap:12px;margin-top:4px}
.issue-item{
  background:#fff;border:1px solid var(--line);border-radius:18px;padding:14px 14px 12px;
  display:grid;grid-template-columns:auto 1fr auto;align-items:flex-start;gap:12px;
}
.issue-num{
  width:28px;height:28px;border-radius:50%;background:var(--green-3);display:grid;place-items:center;color:var(--green);font-size:13px;font-weight:800;
}
.issue-item h4{margin:0 0 4px;font-size:14px}
.issue-item p{margin:0;color:var(--muted);font-size:13px;line-height:1.55}
.issue-tag{padding:6px 10px;border-radius:999px;background:#f4f6f5;color:#475467;font-size:12px;font-weight:700}
.preview-side{
  display:grid;grid-template-rows:1fr auto;gap:16px;
}
.export-box{
  border-radius:22px;background:linear-gradient(180deg,#0b8b43 0%,#067437 100%);color:#fff;padding:24px;display:flex;flex-direction:column;justify-content:space-between;
}
.export-box h3{margin:0 0 8px;font-size:24px;line-height:1.15}
.export-box p{margin:0;color:rgba(255,255,255,.78);line-height:1.7}
.export-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.export-pill{
  border-radius:18px;background:rgba(255,255,255,.12);padding:16px;border:1px solid rgba(255,255,255,.12);
}
.export-pill strong{display:block}
.sync-box{
  border:1px solid var(--line);border-radius:22px;padding:18px;background:#fff;display:grid;gap:12px;
}
.sync-head{display:flex;align-items:center;justify-content:space-between}
.sync-head strong{font-size:18px}
.sync-icons{display:flex;gap:10px;flex-wrap:wrap}
.sync-icons img{width:40px;height:40px}
.section-head{
  display:flex;align-items:end;justify-content:space-between;gap:18px;margin:10px 0 18px;
}
.section-head h2{margin:0;font-size:30px;letter-spacing:-.04em}
.section-head p{margin:8px 0 0;color:var(--muted)}
.plugin-grid{grid-template-columns:repeat(4,1fr)}
.plugin-card{
  padding:24px;display:flex;flex-direction:column;min-height:318px;position:relative;
}
.plugin-card.featured{
  grid-column:span 2;
  background:linear-gradient(180deg,#ffffff 0%,#f7fbf9 100%);
}
.pill{
  display:inline-flex;align-items:center;justify-content:center;padding:7px 12px;border-radius:999px;
  background:#eff8f2;color:var(--green);font-size:12px;font-weight:800;
}
.plugin-top{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px}
.plugin-icon{width:64px;height:64px}
.plugin-card h3{margin:0 0 6px;font-size:24px;letter-spacing:-.03em}
.plugin-card .sub{font-size:15px;color:#475467;margin-bottom:12px}
.plugin-card p{margin:0 0 16px;color:#667085;line-height:1.75}
.tag-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.tag{
  display:inline-flex;align-items:center;padding:8px 11px;border-radius:999px;background:#f3f6f4;color:#41534b;font-size:12px;font-weight:700;
}
.tool-links{display:flex;gap:10px;flex-wrap:wrap;margin-top:auto}
.tool-links .btn{flex:1}
.utility-grid{grid-template-columns:repeat(4,1fr)}
.utility-card{
  padding:22px;display:flex;gap:14px;align-items:flex-start;
}
.utility-card img{width:50px;height:50px}
.utility-card h4{margin:0 0 6px;font-size:18px}
.utility-card p{margin:0;color:var(--muted);line-height:1.65;font-size:14px}
.split-layout{display:grid;grid-template-columns:1.3fr .7fr;gap:24px}
.steps-grid{grid-template-columns:repeat(4,1fr)}
.step-card{padding:26px;text-align:left}
.step-card img{width:64px;height:64px;margin-bottom:18px}
.step-num{
  display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;
  background:var(--green);color:#fff;font-size:13px;font-weight:800;margin-bottom:14px;
}
.step-card h3{margin:0 0 8px;font-size:20px}
.step-card p{margin:0;color:var(--muted);line-height:1.7}
.side-card{padding:26px}
.side-card h3{margin:0 0 8px;font-size:22px}
.side-card p{margin:0 0 16px;color:var(--muted);line-height:1.75}
.side-list{display:grid;gap:12px}
.side-list a,.side-list div{
  display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-radius:16px;border:1px solid var(--line);background:#fff;
  color:#34423b;font-weight:700;
}
.tutorial-tabs{
  display:flex;gap:14px;flex-wrap:wrap;margin-bottom:24px;
}
.tutorial-tab{
  display:inline-flex;align-items:center;gap:10px;padding:12px 16px;border-radius:999px;background:#fff;border:1px solid var(--line);font-weight:700;color:#34423b;
}
.tutorial-tab.active{background:var(--green-3);border-color:#d4ebdd;color:var(--green)}
.tutorial-tab img{width:34px;height:34px}
.tutorial-layout{display:grid;grid-template-columns:1.1fr .9fr;gap:24px}
.tutorial-main{padding:28px}
.tutorial-main h2{margin:0 0 6px;font-size:30px}
.tutorial-main p{margin:0 0 18px;color:var(--muted);line-height:1.75}
.detail-steps{display:grid;gap:14px}
.detail-step{
  display:grid;grid-template-columns:auto 1fr;gap:14px;padding:18px;border:1px solid var(--line);border-radius:18px;background:#fff;
}
.detail-step strong{display:block;margin-bottom:6px}
.detail-step p{margin:0;color:#667085;line-height:1.65}
.tutorial-side{display:grid;gap:18px}
.mini-preview{
  padding:22px;border:1px solid var(--line);border-radius:22px;background:linear-gradient(180deg,#fff,#f8fbf9);
}
.mini-preview h4{margin:0 0 10px;font-size:18px}
.mini-preview .shot{
  height:170px;border-radius:18px;border:1px solid #dfe8e3;background:
    linear-gradient(180deg,#f3f8f5,#ffffff);
  position:relative;overflow:hidden;
}
.mini-preview .shot::before{
  content:"";position:absolute;left:26px;right:26px;top:24px;height:18px;border-radius:999px;background:#edf4f0;
}
.mini-preview .shot::after{
  content:"";position:absolute;left:26px;right:26px;top:56px;bottom:24px;border-radius:18px;background:
    linear-gradient(180deg,#ffffff 0%,#f3fbf6 100%);
  border:1px solid #e4ece7;
}
.search-bar{
  display:flex;gap:12px;max-width:720px;
}
.search-bar input{
  flex:1;min-height:52px;border:1px solid var(--line);border-radius:16px;padding:0 18px;background:#fff;outline:none;
}
.faq-grid{grid-template-columns:repeat(3,1fr)}
.faq-card{padding:24px}
.faq-card h3{display:flex;align-items:center;gap:12px;margin:0 0 18px;font-size:22px}
.faq-card img{width:46px;height:46px}
.q-item{padding-top:14px;border-top:1px solid var(--line)}
.q-item + .q-item{margin-top:14px}
.q-item strong{display:block;margin-bottom:6px;font-size:15px;color:#26312b}
.q-item p{margin:0;color:#667085;line-height:1.65}
.table-wrap{padding:18px 18px 10px}
.stats-grid{grid-template-columns:repeat(4,1fr)}
.stat-card{padding:22px;display:flex;gap:14px;align-items:center}
.stat-card img{width:54px;height:54px}
.stat-card p{margin:0;color:var(--muted);font-size:14px}
.stat-card strong{display:block;font-size:26px;letter-spacing:-.03em;margin-top:4px}
.data-table{width:100%;border-collapse:collapse}
.data-table th,.data-table td{padding:18px 14px;border-top:1px solid var(--line);text-align:left;vertical-align:top}
.data-table th{color:var(--muted);font-size:13px;font-weight:700}
.data-table td{font-size:14px;color:#34423b}
.data-table small{color:var(--muted)}
.status{
  display:inline-flex;align-items:center;padding:7px 12px;border-radius:999px;background:var(--green-3);color:var(--green);font-size:12px;font-weight:800;
}
.status.gray{background:#f1f3f2;color:#667085}
.upgrade-layout{display:grid;grid-template-columns:1fr 380px;gap:24px}
.price-grid{grid-template-columns:repeat(3,1fr)}
.price-card{padding:28px;display:flex;flex-direction:column;min-height:320px;position:relative}
.price-card.highlight{
  border-color:#bfe3cd;background:linear-gradient(180deg,#ffffff 0%,#f6fbf8 100%);box-shadow:0 18px 46px rgba(7,136,63,.11);
}
.price-card h3{margin:0 0 12px;font-size:24px}
.price{
  display:flex;align-items:end;gap:6px;font-size:48px;font-weight:900;letter-spacing:-.05em;margin-bottom:18px;
}
.price span{font-size:17px;font-weight:700;color:var(--muted);margin-bottom:8px}
.price-card ul{list-style:none;padding:0;margin:0 0 22px;display:grid;gap:12px}
.price-card li{display:flex;gap:10px;color:#34423b;line-height:1.6}
.price-card li::before{content:"✓";color:var(--green);font-weight:900}
.sticky-summary{padding:26px;position:sticky;top:100px}
.summary-row{
  display:flex;justify-content:space-between;gap:12px;padding:14px 0;border-bottom:1px solid var(--line);color:#34423b;
}
.summary-row.total{font-size:24px;font-weight:900;color:var(--green)}
.qr-box{
  width:210px;height:210px;margin:18px auto 14px;border-radius:22px;border:1px solid var(--line);background:
    linear-gradient(90deg,#111 9px,transparent 9px) 0 0/17px 17px,
    linear-gradient(#111 9px,transparent 9px) 0 0/17px 17px,#fff;
  position:relative;overflow:hidden;
}
.qr-box::after{
  content:"";position:absolute;inset:72px;border-radius:18px;background:var(--green);
  box-shadow:0 0 0 10px rgba(255,255,255,.95);
}
.footer{
  border-top:1px solid rgba(229,235,232,.9);padding:26px 0 34px;background:#fff;
}
.footer-inner{
  display:flex;align-items:center;justify-content:space-between;gap:18px;color:var(--muted);font-size:14px;
}
.footer-links{display:flex;gap:26px}
@media (max-width:1100px){
  .page-hero,.split-layout,.tutorial-layout,.upgrade-layout{grid-template-columns:1fr}
  .plugin-grid{grid-template-columns:repeat(2,1fr)}
  .plugin-card.featured{grid-column:span 2}
  .utility-grid,.stats-grid,.faq-grid,.steps-grid,.price-grid{grid-template-columns:repeat(2,1fr)}
  .preview-body{grid-template-columns:1fr}
}
@media (max-width:760px){
  .container{width:min(var(--container),calc(100% - 32px))}
  .nav-menu{display:none}
  .nav{height:70px}
  .brand{font-size:24px}
  .page{padding-top:18px}
  .hero-card{padding:32px 24px}
  .hero-card h1{font-size:38px}
  .hero-metrics,.plugin-grid,.utility-grid,.stats-grid,.faq-grid,.steps-grid,.price-grid{grid-template-columns:1fr}
  .plugin-card.featured{grid-column:span 1}
  .preview-body{padding:16px}
  .footer-inner{flex-direction:column}
}

.footer-record {
  display: grid;
  gap: 6px;
  text-align: center;
}

.footer-record a {
  color: #667085;
  font-size: 13px;
}

.footer-record a:hover {
  color: var(--green);
}

/* TinyKits marketing homepage */
.tk-home-header{position:sticky;top:0;z-index:50;border-bottom:1px solid rgba(229,235,232,.8);background:rgba(255,255,255,.84);backdrop-filter:blur(18px)}
.tk-home-nav{height:76px;display:flex;align-items:center;justify-content:space-between;gap:22px}
.tk-home-menu{display:flex;align-items:center;gap:34px;color:#26312b;font-size:15px}
.tk-home-menu a:not(.tk-nav-cta):hover{color:var(--green)}
.tk-nav-cta{color:#fff;font-weight:800;padding:12px 20px;border-radius:12px;background:linear-gradient(135deg,var(--green),var(--green-2));box-shadow:0 10px 22px rgba(7,136,63,.18)}
.tk-hero{padding:64px 0 82px}
.tk-hero-inner{text-align:center}
.tk-hero-copy{max-width:860px;margin:0 auto}
.tk-eyebrow{margin:0 0 14px;color:var(--green);font-weight:800;font-size:19px;letter-spacing:-.01em}
.tk-hero h1{margin:0 0 20px;font-size:clamp(38px,6vw,68px);line-height:1.08;letter-spacing:-.06em}
.tk-hero-desc{max-width:740px;margin:0 auto 32px;color:var(--muted);font-size:18px;line-height:1.9}
.tk-actions{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap}
.tk-actions .btn img{width:24px;height:24px}
.tk-play-dot{width:26px;height:26px;border:1px solid rgba(7,136,63,.3);border-radius:50%;position:relative;background:var(--green-3)}
.tk-play-dot::after{content:"";position:absolute;left:10px;top:7px;border-left:8px solid var(--green);border-top:5px solid transparent;border-bottom:5px solid transparent}
.tk-chips{margin:28px auto 44px;display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}
.tk-chips span{display:inline-flex;align-items:center;gap:8px;min-height:42px;padding:0 16px;color:#42504a;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.78);box-shadow:0 6px 18px rgba(16,24,40,.04)}
.tk-chips img{width:18px;height:18px}
.tk-product-stage{margin:0 auto;max-width:980px}
.tk-browser-window{overflow:hidden;border:1px solid #dfe8e3;border-radius:24px;background:#fff;box-shadow:var(--shadow)}
.tk-browser-top{height:52px;display:flex;align-items:center;gap:16px;padding:0 18px;border-bottom:1px solid #e9efec;background:linear-gradient(180deg,#fff,#fbfcfc)}
.tk-traffic{display:flex;gap:8px}.tk-traffic i{width:10px;height:10px;border-radius:50%}.tk-traffic i:nth-child(1){background:#ff6a5f}.tk-traffic i:nth-child(2){background:#ffbd4a}.tk-traffic i:nth-child(3){background:#2cc66d}
.tk-browser-title{display:flex;align-items:center;gap:8px;color:#34423b;font-weight:700;font-size:13px}.tk-browser-title img{width:18px;height:18px}.tk-browser-action{margin-left:auto;color:#98a7a0}
.tk-app-board{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:18px;padding:22px;background:linear-gradient(90deg,rgba(245,249,247,.3),#fff),radial-gradient(circle at 10% 0%,rgba(7,136,63,.06),transparent 26%)}
.tk-mock-page{min-height:430px;position:relative;overflow:hidden;border:1px solid #e6eeea;border-radius:16px;background:linear-gradient(90deg,#fff 0%,#fff 62%,#f8fbfa 62%,#f8fbfa 100%)}
.tk-mock-hero{position:absolute;left:48px;top:88px;text-align:left}.tk-tiny-label{color:#1e2c24;font-size:12px;font-weight:800}
.tk-mock-hero h2{margin:0 0 14px;font-size:clamp(30px,4vw,48px);line-height:1.12;letter-spacing:-.05em}.tk-mock-hero h2 span{color:var(--green)}
.tk-mock-hero p{max-width:300px;color:#8a9992;font-size:13px;line-height:1.6}
.tk-mock-buttons{display:flex;align-items:center;gap:12px;margin-top:22px}.tk-mock-buttons b,.tk-mock-buttons em{display:inline-flex;min-height:34px;align-items:center;padding:0 14px;border-radius:8px;font-size:12px;font-style:normal}.tk-mock-buttons b{color:#fff;background:var(--green)}.tk-mock-buttons em{color:#5b6862;background:#eef3f1}
.tk-annotation{position:absolute;display:flex;align-items:center;gap:8px}.tk-annotation strong{width:28px;height:28px;display:grid;place-items:center;color:#fff;border-radius:999px;font-size:14px}.tk-annotation span{min-height:34px;display:inline-flex;align-items:center;padding:0 12px;border-radius:8px;background:#fff;font-size:13px;font-weight:800}
.tk-annotation-red{top:78px;right:64px;color:#e3332b}.tk-annotation-red strong{background:#f04438}.tk-annotation-red span{border:2px solid #ff6b63}
.tk-annotation-orange{top:210px;right:104px;color:#dc8500}.tk-annotation-orange strong{background:#f59e0b}.tk-annotation-orange span{border:2px solid #f7b133}
.tk-annotation-blue{bottom:116px;right:82px;color:#2563eb}.tk-annotation-blue strong{background:#2f74ff}.tk-annotation-blue span{border:2px solid #4888ff}
.tk-issue-panel{display:flex;flex-direction:column;gap:13px}.tk-issue-head{display:flex;justify-content:space-between;align-items:center}.tk-issue-head strong{font-size:15px}.tk-issue-head button{border:1px solid #e1e9e5;border-radius:10px;background:#fff;color:#53615b;padding:7px 12px}
.tk-issue-card{position:relative;text-align:left;border:1px solid #e7eeeb;border-radius:14px;background:#fff;padding:18px 16px 16px;box-shadow:0 8px 22px rgba(16,24,40,.035)}.tk-issue-card::before{content:"";position:absolute;top:22px;left:0;width:4px;height:26px;border-radius:0 8px 8px 0;background:#ddd}.tk-issue-card b{display:block;margin-bottom:7px;font-size:14px}.tk-issue-card p{margin-bottom:10px;color:#7a8882;font-size:12px}.tk-issue-card small{display:inline-flex;padding:5px 9px;border-radius:8px;background:#f4f6f5;color:#75817c;font-size:12px}.tk-issue-card.is-red{border-color:#ffd3cf;background:#fffafa}.tk-issue-card.is-red::before{background:#f04438}.tk-issue-card.is-orange::before{background:#f59e0b}.tk-issue-card.is-blue::before{background:#2f74ff}
.tk-toolbar{min-height:70px;display:flex;align-items:center;gap:22px;padding:0 22px;border-top:1px solid #e9efec;color:#697871;font-size:13px;background:#fff}.tk-toolbar-actions{margin-left:auto;display:flex;gap:10px}.tk-toolbar button{height:40px;border-radius:10px;padding:0 14px;cursor:default}.tk-pdf-btn{border:1px solid #e5ebe8;background:#fff;color:#34423b;display:inline-flex;align-items:center;gap:8px}.tk-pdf-btn img{width:18px;height:18px}.tk-green-btn{color:#fff;border:0;background:var(--green);font-weight:800}
.tk-integration-row{width:fit-content;max-width:100%;margin:26px auto 0;padding:12px;display:flex;gap:12px;flex-wrap:wrap;justify-content:center;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.86);box-shadow:var(--shadow-soft)}.tk-integration-row span{min-height:38px;display:inline-flex;align-items:center;gap:8px;padding:0 13px;color:#53615b;font-size:14px;border-radius:999px;background:#fbfdfc}.tk-integration-row img{width:20px;height:20px}
.tk-section{padding:82px 0}.tk-soft-section{background:linear-gradient(180deg,rgba(246,248,247,.72),rgba(255,255,255,.75));border-top:1px solid rgba(229,235,232,.6);border-bottom:1px solid rgba(229,235,232,.6)}
.tk-section-title{margin:0 auto 36px;max-width:680px;text-align:center}.tk-section-title h2{margin:0 0 12px;font-size:clamp(28px,4vw,42px);line-height:1.18;letter-spacing:-.05em}.tk-section-title p{margin:0;color:var(--muted);font-size:16px;line-height:1.7}
.tk-feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}.tk-feature-card,.tk-step-card,.tk-tool-card{border:1px solid var(--line);border-radius:var(--radius-lg);background:rgba(255,255,255,.9);box-shadow:var(--shadow-soft)}.tk-feature-card{min-height:214px;padding:32px 24px;text-align:center}.tk-feature-card img{width:66px;height:66px;margin:0 auto 22px}.tk-feature-card h3,.tk-step-card h3{margin:0 0 9px;font-size:20px;letter-spacing:-.03em}.tk-feature-card p,.tk-step-card p,.tk-tool-card p{margin:0;color:var(--muted);line-height:1.7}
.tk-workflow{display:grid;grid-template-columns:1fr 28px 1fr 28px 1fr 28px 1fr;align-items:center;gap:16px}.tk-step-card{position:relative;min-height:214px;padding:30px 22px 24px;text-align:center}.tk-step-card b{position:absolute;top:18px;left:18px;width:28px;height:28px;display:grid;place-items:center;border-radius:999px;color:#fff;background:var(--green);font-size:13px}.tk-step-card img{width:68px;height:68px;margin:6px auto 18px}.tk-workflow i{font-size:28px;color:#6db98d;font-style:normal;text-align:center}
.tk-tool-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.tk-tool-card{min-height:120px;padding:22px;display:grid;grid-template-columns:58px 1fr 28px;align-items:center;gap:16px}.tk-tool-card img{width:58px;height:58px}.tk-tool-card h3{margin:0 0 6px;font-size:17px}.tk-tool-card span{width:28px;height:28px;display:grid;place-items:center;border:1px solid #b8ddc8;border-radius:999px;color:var(--green);font-weight:900}
.tk-cta-section{padding-top:36px}.tk-cta-box{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:28px;padding:42px 50px;border:1px solid #d8eee2;border-radius:var(--radius-xl);background:radial-gradient(circle at 12% 12%,rgba(10,163,82,.12),transparent 30%),linear-gradient(135deg,#effaf4,#fff 70%);box-shadow:var(--shadow-soft)}.tk-cta-box h2{margin:0 0 12px;font-size:clamp(28px,4vw,42px);line-height:1.16;letter-spacing:-.05em}.tk-cta-box p{margin:0;max-width:640px;color:#5b6862;line-height:1.8}
.tk-home-footer{padding:44px 0 52px;background:#fff;border-top:1px solid rgba(229,235,232,.9)}.tk-footer-inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px;color:#7a8882;font-size:14px}.tk-footer-inner .brand{font-size:22px}.tk-footer-inner .brand img{width:28px;height:28px}.tk-footer-inner nav{display:flex;justify-content:flex-end;gap:28px}
.footer-record{display:grid;gap:6px;text-align:center}.footer-record a{color:#667085;font-size:13px}.footer-record a:hover{color:var(--green)}
@media(max-width:1050px){.tk-app-board{grid-template-columns:1fr}.tk-issue-panel{display:grid;grid-template-columns:repeat(3,1fr)}.tk-issue-head{grid-column:1/-1}.tk-feature-grid{grid-template-columns:repeat(2,1fr)}.tk-workflow{grid-template-columns:repeat(2,1fr)}.tk-workflow i{display:none}.tk-tool-grid{grid-template-columns:1fr}.tk-cta-box{grid-template-columns:1fr;text-align:center}.tk-cta-box p{margin-left:auto;margin-right:auto}}
@media(max-width:780px){.tk-home-menu{display:none}.tk-hero{padding:48px 0 58px}.tk-hero-desc{font-size:16px}.tk-actions .btn{width:100%}.tk-app-board{padding:14px}.tk-mock-page{min-height:350px}.tk-mock-hero{left:22px;top:60px}.tk-mock-hero h2{font-size:31px}.tk-annotation span{max-width:145px;font-size:12px}.tk-annotation-red{right:18px;top:58px}.tk-annotation-orange{right:22px;top:175px}.tk-annotation-blue{right:22px;bottom:86px}.tk-issue-panel,.tk-feature-grid,.tk-workflow{grid-template-columns:1fr}.tk-toolbar{flex-wrap:wrap;height:auto;padding:14px;gap:12px}.tk-toolbar-actions{width:100%;margin-left:0}.tk-toolbar-actions button{flex:1}.tk-feature-card,.tk-step-card{min-height:auto}.tk-tool-card{grid-template-columns:52px 1fr}.tk-tool-card span{display:none}.tk-cta-box{padding:34px 22px}.tk-footer-inner{grid-template-columns:1fr;text-align:center}.tk-footer-inner nav{justify-content:center;flex-wrap:wrap}.tk-footer-inner .brand{justify-content:center}}



/* dashboard layout fix 2026-04-28 */
body:has(.page-hero) .page-hero {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}

body:has(#tools) .hero-card {
  text-align: left;
}

body:has(#tools) .hero-card .lead {
  max-width: 760px;
}

body:has(#tools) .hero-actions {
  justify-content: flex-start;
}

body:has(#tools) .hero-metrics {
  max-width: 760px;
}

body:has(#tools) .preview-card {
  padding: 22px;
}

body:has(#tools) .preview-window {
  max-width: 100%;
}

body:has(#tools) .plugin-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: stretch;
}

body:has(#tools) .plugin-card,
body:has(#tools) .plugin-card.featured {
  grid-column: auto;
  min-width: 0;
}

body:has(#tools) .plugin-card {
  min-height: 360px;
}

body:has(#tools) .tool-links {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  width: 100%;
  margin-top: auto;
}

body:has(#tools) .tool-links .btn {
  width: 100%;
  min-width: 0;
  padding-left: 8px;
  padding-right: 8px;
  white-space: nowrap;
  font-size: 14px;
}

body:has(#tools) .plugin-card:not(.featured) .tool-links {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

body:has(#tools) .plugin-card:not(.featured) .tool-links .btn:nth-child(3) {
  display: inline-flex;
}

@media (max-width: 1180px) {
  body:has(#tools) .plugin-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  body:has(#tools) .plugin-grid {
    grid-template-columns: 1fr;
  }

  body:has(#tools) .tool-links {
    grid-template-columns: 1fr;
  }

  body:has(#tools) .tool-links .btn {
    font-size: 15px;
  }
}


/* homepage wechat login modal */
body.tk-modal-open {
  overflow: hidden;
}

.tk-login-modal {
  position: fixed;
  inset: 0;
  z-index: 999;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.tk-login-modal.is-open {
  display: flex;
}

.tk-login-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(8, 16, 12, 0.48);
  backdrop-filter: blur(12px);
}

.tk-login-dialog {
  position: relative;
  z-index: 1;
  width: min(920px, 100%);
  min-height: 560px;
  display: grid;
  grid-template-columns: 1.02fr 0.98fr;
  overflow: hidden;
  border: 1px solid rgba(221, 235, 227, 0.95);
  border-radius: 30px;
  background: #fff;
  box-shadow: 0 34px 90px rgba(16, 24, 40, 0.24);
}

.tk-login-close {
  position: absolute;
  top: 18px;
  right: 18px;
  z-index: 2;
  width: 38px;
  height: 38px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: #53615b;
  background: rgba(255, 255, 255, 0.9);
  cursor: pointer;
  font-size: 24px;
  line-height: 1;
}

.tk-login-left {
  padding: 54px 50px;
  background:
    radial-gradient(circle at 8% 10%, rgba(10, 163, 82, 0.15), transparent 30%),
    linear-gradient(145deg, #f2fbf6 0%, #ffffff 72%);
}

.tk-login-left .brand {
  margin-bottom: 44px;
}

.tk-login-kicker {
  margin: 0 0 12px;
  color: var(--green);
  font-size: 15px;
  font-weight: 850;
}

.tk-login-left h2 {
  max-width: 430px;
  margin: 0 0 18px;
  font-size: clamp(30px, 4vw, 42px);
  line-height: 1.16;
  letter-spacing: -0.055em;
}

.tk-login-left p {
  max-width: 430px;
  margin: 0 0 28px;
  color: #5d6b65;
  font-size: 16px;
  line-height: 1.85;
}

.tk-login-points {
  display: grid;
  gap: 12px;
}

.tk-login-points span {
  position: relative;
  min-height: 44px;
  display: flex;
  align-items: center;
  padding: 0 14px 0 38px;
  border: 1px solid #d9eee3;
  border-radius: 14px;
  color: #26352d;
  background: rgba(255, 255, 255, 0.72);
  font-size: 14px;
  font-weight: 750;
}

.tk-login-points span::before {
  content: "";
  position: absolute;
  left: 16px;
  width: 11px;
  height: 11px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 0 4px rgba(7, 136, 63, 0.1);
}

.tk-login-right {
  padding: 58px 44px 42px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.tk-wechat-badge {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  margin-bottom: 22px;
  padding: 0 16px;
  border: 1px solid #d7eee1;
  border-radius: 999px;
  color: #163a26;
  background: #f2fbf6;
  font-size: 14px;
  font-weight: 850;
}

.tk-wechat-badge img {
  width: 22px;
  height: 22px;
}

.tk-login-frame-wrap {
  width: 300px;
  height: 400px;
  overflow: hidden;
  border: 1px solid #e1ebe6;
  border-radius: 24px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(16, 24, 40, 0.08);
}

.tk-login-frame-wrap iframe {
  width: 100%;
  height: 100%;
  border: 0;
}

.tk-login-right p {
  max-width: 320px;
  margin: 18px 0 0;
  color: var(--muted);
  line-height: 1.75;
}

@media (max-width: 860px) {
  .tk-login-modal {
    padding: 16px;
    align-items: flex-start;
    overflow-y: auto;
  }

  .tk-login-dialog {
    grid-template-columns: 1fr;
    min-height: 0;
    margin: 20px 0;
    border-radius: 24px;
  }

  .tk-login-left,
  .tk-login-right {
    padding: 36px 24px;
  }

  .tk-login-frame-wrap {
    width: min(300px, 100%);
  }
}


/* 全局标题行距优化：避免大字号标题上下行过挤 */
.hero-card h1,
.page-hero h1,
.tk-hero h1,
.install-hero h1 {
  line-height: 1.16;
  letter-spacing: -0.035em;
}

.hero-card h1 span,
.page-hero h1 span,
.tk-hero h1 span,
.install-hero h1 span {
  display: inline-block;
  margin-top: 8px;
  line-height: 1.18;
  letter-spacing: -0.025em;
}

@media (max-width: 720px) {
  .hero-card h1,
  .page-hero h1,
  .tk-hero h1,
  .install-hero h1 {
    line-height: 1.18;
    letter-spacing: -0.025em;
  }

  .hero-card h1 span,
  .page-hero h1 span,
  .tk-hero h1 span,
  .install-hero h1 span {
    margin-top: 6px;
    line-height: 1.2;
    letter-spacing: -0.018em;
  }
}

/* ===== TinyKits Home Tool Slider 2026-05 ===== */
.tk-hero-clean {
  padding: 92px 0 54px;
}

.tk-hero-clean-inner {
  max-width: 920px;
  margin: 0 auto;
  text-align: center;
}

.tk-hero-clean .tk-hero-desc {
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}

.tk-hero-clean .tk-actions,
.tk-hero-clean .tk-chips {
  justify-content: center;
}

.tk-hero-note {
  margin: 18px auto 0;
  max-width: 820px;
  color: #64748b;
  font-size: 14px;
  line-height: 1.8;
}

.tk-home-tool-slider-section {
  padding-top: 52px;
}

.tk-tool-slider {
  margin-top: 30px;
  padding: 18px;
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: 32px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbf9 100%);
  box-shadow: 0 24px 70px rgba(15, 23, 42, .08);
}

.tk-tool-tabs {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 18px;
}

.tk-tool-tab {
  appearance: none;
  border: 1px solid rgba(15, 23, 42, .08);
  background: rgba(255, 255, 255, .76);
  color: #334155;
  border-radius: 18px;
  padding: 13px 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  font: inherit;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: .22s ease;
  text-align: left;
  min-width: 0;
}

.tk-tool-tab img {
  width: 24px;
  height: 24px;
  flex: 0 0 auto;
}

.tk-tool-tab span {
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.tk-tool-tab:hover,
.tk-tool-tab.active {
  border-color: rgba(7, 136, 63, .28);
  background: #ffffff;
  color: #07883f;
  box-shadow: 0 10px 26px rgba(7, 136, 63, .1);
  transform: translateY(-1px);
}

.tk-tool-slides {
  position: relative;
  min-height: 520px;
  overflow: hidden;
  border-radius: 26px;
}

.tk-tool-slide {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(360px, 1.05fr);
  gap: 28px;
  align-items: stretch;
  padding: 34px;
  border: 1px solid rgba(15, 23, 42, .07);
  border-radius: 26px;
  background:
    radial-gradient(circle at top right, rgba(7, 136, 63, .08), transparent 34%),
    #ffffff;
  opacity: 0;
  transform: translateX(34px);
  pointer-events: none;
  transition: opacity .42s ease, transform .42s ease;
}

.tk-tool-slide.active {
  position: relative;
  opacity: 1;
  transform: translateX(0);
  pointer-events: auto;
}

.tk-tool-slide-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
}

.tk-slide-eyebrow {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  background: #eef8f1;
  color: #07883f;
  font-size: 13px;
  font-weight: 800;
  margin-bottom: 18px;
}

.tk-slide-eyebrow img {
  width: 20px;
  height: 20px;
}

.tk-tool-slide h3 {
  margin: 0;
  color: #0f172a;
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.15;
  letter-spacing: -.04em;
}

.tk-tool-slide-copy > p {
  margin: 18px 0 0;
  color: #475569;
  font-size: 16px;
  line-height: 1.85;
}

.tk-slide-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
}

.tk-slide-tags span {
  display: inline-flex;
  align-items: center;
  height: 30px;
  padding: 0 11px;
  border-radius: 999px;
  background: #f1f5f9;
  color: #475569;
  font-size: 12px;
  font-weight: 700;
}

.tk-tool-slide ul {
  margin: 20px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}

.tk-tool-slide li {
  position: relative;
  padding-left: 22px;
  color: #334155;
  font-size: 14px;
  line-height: 1.65;
}

.tk-tool-slide li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .65em;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #07883f;
  box-shadow: 0 0 0 4px rgba(7, 136, 63, .12);
}

.tk-tool-slide .tk-actions {
  margin-top: 26px;
}

.tk-tool-slide-visual {
  min-height: 430px;
  border-radius: 28px;
  padding: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.tk-tool-slide-visual.tone-purple {
  background: linear-gradient(135deg, #f7f2ff 0%, #effaf3 100%);
}

.tk-tool-slide-visual.tone-green {
  background: linear-gradient(135deg, #ecfdf3 0%, #f7fbf8 100%);
}

.tk-tool-slide-visual.tone-blue {
  background: linear-gradient(135deg, #eff6ff 0%, #f7fbf8 100%);
}

.tk-tool-slide-visual.tone-orange {
  background: linear-gradient(135deg, #fff7ed 0%, #f7fbf8 100%);
}

.tk-tool-window {
  width: min(100%, 520px);
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: 24px;
  background: rgba(255, 255, 255, .86);
  box-shadow: 0 30px 70px rgba(15, 23, 42, .14);
  overflow: hidden;
  backdrop-filter: blur(16px);
}

.tk-tool-window-top {
  height: 52px;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 18px;
  border-bottom: 1px solid rgba(15, 23, 42, .07);
  color: #0f172a;
  font-size: 13px;
}

.tk-tool-window-top i {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #ff6b6b;
}

.tk-tool-window-top i:nth-child(2) {
  background: #f59e0b;
}

.tk-tool-window-top i:nth-child(3) {
  background: #22c55e;
  margin-right: 8px;
}

.tk-feedback-preview {
  display: grid;
  grid-template-columns: 1fr 190px;
  gap: 16px;
  padding: 18px;
}

.tk-preview-page {
  position: relative;
  min-height: 300px;
  border-radius: 18px;
  background: linear-gradient(180deg, #ffffff 0%, #f1f5f9 100%);
  border: 1px solid rgba(15, 23, 42, .06);
  padding: 32px 24px;
}

.tk-preview-title {
  width: 72%;
  height: 28px;
  border-radius: 10px;
  background: #0f172a;
  margin-bottom: 20px;
}

.tk-preview-line {
  height: 10px;
  border-radius: 99px;
  background: #cbd5e1;
  margin-bottom: 10px;
}

.tk-preview-line.w80 {
  width: 80%;
}

.tk-preview-line.w60 {
  width: 60%;
}

.tk-preview-btn {
  width: 96px;
  height: 34px;
  border-radius: 10px;
  background: #07883f;
  margin-top: 28px;
}

.tk-mark {
  position: absolute;
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  color: #fff;
  font-weight: 900;
}

.tk-mark.mark-red {
  right: 48px;
  top: 84px;
  background: #ef4444;
}

.tk-mark.mark-orange {
  left: 58px;
  bottom: 74px;
  background: #f59e0b;
}

.tk-preview-panel {
  padding: 16px;
  border-radius: 18px;
  background: #fff;
  border: 1px solid rgba(15, 23, 42, .07);
}

.tk-preview-panel b {
  display: block;
  margin-bottom: 12px;
}

.tk-preview-panel p {
  margin: 0 0 10px;
  padding: 10px;
  border-radius: 12px;
  background: #f8fafc;
  color: #475569;
  font-size: 12px;
}

.tk-preview-panel em {
  display: inline-flex;
  margin-top: 6px;
  padding: 8px 12px;
  border-radius: 999px;
  background: #07883f;
  color: #fff;
  font-style: normal;
  font-size: 12px;
  font-weight: 800;
}

.tk-compress-preview,
.tk-style-preview,
.tk-guide-preview {
  padding: 22px;
}

.tk-compress-summary {
  padding: 18px;
  border-radius: 18px;
  background: #f0fdf4;
  border: 1px solid #bbf7d0;
}

.tk-compress-summary strong,
.tk-compress-summary span {
  display: block;
}

.tk-compress-summary span {
  margin-top: 6px;
  color: #07883f;
  font-size: 13px;
  font-weight: 800;
}

.tk-compress-list {
  display: grid;
  gap: 12px;
  margin-top: 16px;
}

.tk-compress-list p {
  margin: 0;
  display: grid;
  grid-template-columns: 42px 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 12px;
  border-radius: 16px;
  background: #f8fafc;
}

.tk-compress-list b {
  width: 42px;
  height: 42px;
  border-radius: 12px;
  background: #dbeafe;
}

.tk-compress-list span {
  height: 10px;
  border-radius: 99px;
  background: #cbd5e1;
}

.tk-compress-list em {
  font-style: normal;
  color: #07883f;
  font-size: 12px;
  font-weight: 800;
}

.tk-download-bar {
  margin-top: 18px;
  padding: 14px;
  border-radius: 16px;
  background: #07883f;
  color: #fff;
  text-align: center;
  font-weight: 900;
}

.tk-color-row {
  display: flex;
  gap: 10px;
  margin-bottom: 16px;
}

.tk-color-row i {
  width: 58px;
  height: 58px;
  border-radius: 16px;
  background: #07883f;
}

.tk-color-row i:nth-child(2) {
  background: #0f172a;
}

.tk-color-row i:nth-child(3) {
  background: #2563eb;
}

.tk-color-row i:nth-child(4) {
  background: #f59e0b;
}

.tk-style-card {
  padding: 16px;
  border-radius: 18px;
  background: #f8fafc;
  margin-bottom: 12px;
}

.tk-style-card b {
  display: block;
  margin-bottom: 12px;
}

.tk-style-card p {
  width: 80%;
  height: 10px;
  border-radius: 99px;
  background: #cbd5e1;
  margin: 0 0 8px;
}

.tk-style-card p.short {
  width: 55%;
}

.tk-style-score {
  padding: 16px;
  border-radius: 18px;
  background: #eff6ff;
  color: #2563eb;
  font-weight: 900;
  text-align: center;
}

.tk-guide-preview {
  display: grid;
  gap: 14px;
}

.tk-guide-step {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px;
  border-radius: 18px;
  background: #fff;
  border: 1px solid rgba(15, 23, 42, .07);
}

.tk-guide-step b {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: #07883f;
  color: #fff;
}

.tk-guide-step span {
  color: #334155;
  font-weight: 800;
}

.tk-tool-dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 18px;
}

.tk-tool-dots button {
  appearance: none;
  border: 0;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #cbd5e1;
  cursor: pointer;
  transition: .22s ease;
}

.tk-tool-dots button.active {
  width: 28px;
  background: #07883f;
}

@media (max-width: 980px) {
  .tk-tool-tabs {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .tk-tool-slides {
    min-height: 0;
  }

  .tk-tool-slide,
  .tk-tool-slide.active {
    grid-template-columns: 1fr;
    padding: 24px;
  }

  .tk-tool-slide {
    position: absolute;
  }

  .tk-tool-slide.active {
    position: relative;
  }

  .tk-tool-slide-visual {
    min-height: 360px;
  }
}

@media (max-width: 640px) {
  .tk-hero-clean {
    padding: 64px 0 34px;
  }

  .tk-tool-slider {
    padding: 12px;
    border-radius: 24px;
  }

  .tk-tool-tabs {
    display: flex;
    overflow-x: auto;
    padding-bottom: 4px;
  }

  .tk-tool-tab {
    min-width: 220px;
  }

  .tk-tool-slide,
  .tk-tool-slide.active {
    padding: 20px;
    border-radius: 20px;
  }

  .tk-tool-slide h3 {
    font-size: 28px;
  }

  .tk-feedback-preview {
    grid-template-columns: 1fr;
  }

  .tk-tool-slide-visual {
    padding: 12px;
    min-height: auto;
  }
}

/* ===== TinyKits Login Modal Fix 2026-05 ===== */
.tk-login-modal {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
  box-sizing: border-box;
}

.tk-login-modal[aria-hidden="false"],
.tk-login-modal.is-open {
  display: flex;
}

.tk-login-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, .42);
  backdrop-filter: blur(10px);
}

.tk-login-dialog {
  position: relative;
  z-index: 2;
  width: min(880px, calc(100vw - 32px));
  min-height: 460px;
  display: grid;
  grid-template-columns: 1fr 360px;
  overflow: hidden;
  border-radius: 30px;
  background: #fff;
  border: 1px solid rgba(15, 23, 42, .08);
  box-shadow: 0 34px 90px rgba(15, 23, 42, .24);
}

.tk-login-close {
  position: absolute;
  right: 18px;
  top: 16px;
  z-index: 4;
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: 999px;
  background: #f1f5f9;
  color: #475569;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
}

.tk-login-close:hover {
  background: #e2e8f0;
  color: #0f172a;
}

.tk-login-left {
  padding: 42px 42px 36px;
  background:
    radial-gradient(circle at 18% 18%, rgba(7, 136, 63, .12), transparent 34%),
    linear-gradient(180deg, #ffffff 0%, #f7fbf8 100%);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 28px;
}

.tk-login-left .brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: fit-content;
  text-decoration: none;
}

.tk-login-left .brand img {
  width: 34px;
  height: 34px;
}

.tk-login-left .brand span {
  color: #0f172a;
  font-size: 20px;
  font-weight: 900;
}

.tk-login-left h2 {
  margin: 8px 0 12px;
  color: #0f172a;
  font-size: 34px;
  line-height: 1.14;
  letter-spacing: -.04em;
}

.tk-login-left p {
  margin: 0;
  color: #475569;
  font-size: 15px;
  line-height: 1.85;
}

.tk-login-left ul {
  margin: 0;
  padding: 0;
  display: grid;
  gap: 12px;
  list-style: none;
}

.tk-login-left li {
  position: relative;
  padding-left: 24px;
  color: #334155;
  font-size: 14px;
  line-height: 1.6;
}

.tk-login-left li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .55em;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #07883f;
  box-shadow: 0 0 0 4px rgba(7, 136, 63, .12);
}

.tk-login-right {
  padding: 56px 34px 34px;
  background: #f8fafc;
  border-left: 1px solid rgba(15, 23, 42, .06);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.tk-qr-card {
  width: 240px;
  height: 240px;
  border-radius: 24px;
  background: #fff;
  border: 1px solid rgba(15, 23, 42, .08);
  box-shadow: 0 18px 46px rgba(15, 23, 42, .1);
  display: grid;
  place-items: center;
  overflow: hidden;
}

.tk-qr-card img {
  width: 212px;
  height: 212px;
  object-fit: contain;
  display: block;
}

.tk-qr-card iframe {
  width: 240px;
  height: 240px;
  border: 0;
  display: block;
  background: #fff;
}

.tk-qr-loading,
.tk-qr-error {
  width: 100%;
  padding: 20px;
  box-sizing: border-box;
  text-align: center;
  color: #64748b;
  font-size: 13px;
  line-height: 1.7;
}

.tk-qr-error button {
  margin-top: 12px;
  height: 34px;
  padding: 0 14px;
  border: 0;
  border-radius: 999px;
  background: #07883f;
  color: #fff;
  font-weight: 800;
  cursor: pointer;
}

.tk-login-tip {
  margin: 18px 0 6px;
  color: #0f172a;
  font-size: 16px;
  font-weight: 900;
}

.tk-login-subtip {
  margin: 0;
  color: #64748b;
  font-size: 13px;
  line-height: 1.7;
  text-align: center;
}

body.tk-login-open {
  overflow: hidden;
}

@media (max-width: 760px) {
  .tk-login-dialog {
    grid-template-columns: 1fr;
    width: min(420px, calc(100vw - 28px));
  }

  .tk-login-left {
    padding: 30px 24px 22px;
  }

  .tk-login-left h2 {
    font-size: 28px;
  }

  .tk-login-right {
    padding: 26px 24px 30px;
    border-left: 0;
    border-top: 1px solid rgba(15, 23, 42, .06);
  }
}

/* ===== TinyKits Simple WeChat Login Modal Override 2026-05 ===== */
.tk-simple-login-modal {
  position: fixed !important;
  inset: 0 !important;
  z-index: 999999 !important;
  display: none !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 22px !important;
  box-sizing: border-box !important;
}

.tk-simple-login-modal[aria-hidden="false"],
.tk-simple-login-modal.is-open {
  display: flex !important;
}

.tk-simple-login-modal .tk-login-backdrop {
  position: absolute !important;
  inset: 0 !important;
  background: rgba(15, 23, 42, .38) !important;
  backdrop-filter: blur(8px) !important;
}

.tk-simple-login-dialog {
  position: relative !important;
  z-index: 2 !important;
  width: min(360px, calc(100vw - 36px)) !important;
  padding: 26px 24px 24px !important;
  border-radius: 26px !important;
  background: #fff !important;
  border: 1px solid rgba(15, 23, 42, .08) !important;
  box-shadow: 0 28px 80px rgba(15, 23, 42, .22) !important;
  text-align: center !important;
  box-sizing: border-box !important;
}

.tk-simple-login-close {
  position: absolute !important;
  right: 14px !important;
  top: 14px !important;
  width: 30px !important;
  height: 30px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: #f1f5f9 !important;
  color: #64748b !important;
  font-size: 20px !important;
  line-height: 30px !important;
  cursor: pointer !important;
  padding: 0 !important;
}

.tk-simple-login-close:hover {
  background: #e2e8f0 !important;
  color: #0f172a !important;
}

.tk-simple-login-head {
  display: block !important;
  margin: 0 0 18px !important;
}

.tk-simple-login-head .brand {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  text-decoration: none !important;
  margin: 0 0 18px !important;
}

.tk-simple-login-head .brand img {
  width: 28px !important;
  height: 28px !important;
  display: block !important;
}

.tk-simple-login-head .brand span {
  color: #0f172a !important;
  font-size: 18px !important;
  font-weight: 900 !important;
}

.tk-simple-login-head h2 {
  margin: 0 0 8px !important;
  color: #0f172a !important;
  font-size: 24px !important;
  line-height: 1.2 !important;
  letter-spacing: -.02em !important;
}

.tk-simple-login-head p {
  margin: 0 !important;
  color: #64748b !important;
  font-size: 14px !important;
  line-height: 1.7 !important;
}

.tk-simple-qr-card {
  width: 236px !important;
  height: 236px !important;
  margin: 0 auto !important;
  padding: 12px !important;
  border-radius: 22px !important;
  background: #fff !important;
  border: 1px solid rgba(15, 23, 42, .08) !important;
  box-shadow: 0 14px 36px rgba(15, 23, 42, .08) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-sizing: border-box !important;
  overflow: visible !important;
}

.tk-simple-qr-card img,
.tk-simple-qr-card canvas,
.tk-simple-qr-card svg {
  width: 212px !important;
  height: 212px !important;
  max-width: 212px !important;
  max-height: 212px !important;
  object-fit: contain !important;
  display: block !important;
}

.tk-simple-qr-card iframe {
  display: none !important;
}

.tk-qr-loading,
.tk-qr-error {
  width: 100% !important;
  padding: 16px !important;
  box-sizing: border-box !important;
  color: #64748b !important;
  font-size: 13px !important;
  line-height: 1.7 !important;
  text-align: center !important;
}

.tk-qr-error button {
  margin-top: 12px !important;
  height: 34px !important;
  padding: 0 14px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: #07883f !important;
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  cursor: pointer !important;
}

.tk-simple-login-tip {
  margin: 16px 0 4px !important;
  color: #0f172a !important;
  font-size: 15px !important;
  line-height: 1.5 !important;
  font-weight: 800 !important;
}

.tk-simple-login-subtip {
  margin: 0 !important;
  color: #64748b !important;
  font-size: 12px !important;
  line-height: 1.6 !important;
}

body.tk-login-open {
  overflow: hidden !important;
}

@media (max-width: 480px) {
  .tk-simple-login-dialog {
    width: min(340px, calc(100vw - 28px)) !important;
    padding: 24px 20px 22px !important;
    border-radius: 24px !important;
  }

  .tk-simple-qr-card {
    width: 224px !important;
    height: 224px !important;
  }

  .tk-simple-qr-card img,
  .tk-simple-qr-card canvas,
  .tk-simple-qr-card svg {
    width: 200px !important;
    height: 200px !important;
    max-width: 200px !important;
    max-height: 200px !important;
  }
}

/* ===== TinyKits Simple Login QR Direct Fix 2026-05 ===== */
.tk-simple-qr-card iframe {
  display: block !important;
  width: 212px !important;
  height: 212px !important;
  max-width: 212px !important;
  max-height: 212px !important;
  border: 0 !important;
  background: #fff !important;
}

.tk-simple-qr-card .tk-wechat-frame-wrap {
  width: 212px !important;
  height: 212px !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* ===== TinyKits WeChat Official QR Direct Render 2026-05 ===== */
.tk-simple-qr-card {
  width: 260px !important;
  height: 300px !important;
  padding: 0 !important;
  overflow: hidden !important;
  background: #fff !important;
}

.tk-simple-qr-card #tkWxLoginContainer {
  width: 260px !important;
  height: 300px !important;
  overflow: hidden !important;
  background: #fff !important;
}

.tk-simple-qr-card #tkWxLoginContainer iframe {
  display: block !important;
  width: 300px !important;
  height: 400px !important;
  border: 0 !important;
  transform: scale(.86) !important;
  transform-origin: top center !important;
  margin-left: -20px !important;
  margin-top: -14px !important;
  background: #fff !important;
}

.tk-simple-login-dialog {
  width: min(380px, calc(100vw - 36px)) !important;
}

.tk-simple-login-head {
  margin-bottom: 14px !important;
}

.tk-simple-login-tip {
  margin-top: 12px !important;
}

/* ===== TinyKits QR Image Center Fix 2026-05 ===== */
.tk-simple-qr-card {
  width: 260px !important;
  height: 260px !important;
  padding: 12px !important;
  margin: 0 auto !important;
  border-radius: 22px !important;
  background: #fff !important;
  border: 1px solid rgba(15, 23, 42, .08) !important;
  box-shadow: 0 14px 36px rgba(15, 23, 42, .08) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: visible !important;
  box-sizing: border-box !important;
}

.tk-simple-qr-card img.tk-login-qr-img {
  display: block !important;
  width: 236px !important;
  height: 236px !important;
  max-width: 236px !important;
  max-height: 236px !important;
  object-fit: contain !important;
  margin: 0 auto !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: #fff !important;
}

.tk-simple-qr-card iframe,
.tk-simple-qr-card #tkWxLoginContainer,
.tk-simple-qr-card .tk-wechat-frame-wrap {
  display: none !important;
}

.tk-simple-login-dialog {
  width: min(380px, calc(100vw - 36px)) !important;
}

.tk-simple-login-tip {
  margin-top: 16px !important;
}

/* ===== TinyKits Final WeChat Login Modal Fix 2026-05 ===== */
.tk-simple-login-dialog {
  width: min(430px, calc(100vw - 36px)) !important;
  padding: 26px 24px 24px !important;
}

.tk-simple-qr-card {
  width: 310px !important;
  height: 360px !important;
  padding: 0 !important;
  margin: 0 auto !important;
  border-radius: 22px !important;
  background: #fff !important;
  border: 1px solid rgba(15, 23, 42, .08) !important;
  box-shadow: 0 14px 36px rgba(15, 23, 42, .08) !important;
  display: block !important;
  overflow: visible !important;
  box-sizing: border-box !important;
}

.tk-simple-qr-card #tkWxLoginContainer {
  width: 310px !important;
  height: 360px !important;
  display: block !important;
  overflow: visible !important;
  background: #fff !important;
}

.tk-simple-qr-card #tkWxLoginContainer iframe {
  display: block !important;
  width: 310px !important;
  height: 360px !important;
  max-width: none !important;
  max-height: none !important;
  border: 0 !important;
  margin: 0 !important;
  transform: none !important;
  transform-origin: initial !important;
  background: #fff !important;
}

.tk-simple-qr-card img.tk-login-qr-img,
.tk-simple-qr-card .tk-wechat-frame-wrap {
  display: none !important;
}

.tk-simple-login-head {
  margin-bottom: 14px !important;
}

.tk-simple-login-tip {
  margin-top: 14px !important;
}

@media (max-width: 480px) {
  .tk-simple-login-dialog {
    width: min(400px, calc(100vw - 28px)) !important;
    padding: 24px 18px 22px !important;
  }

  .tk-simple-qr-card,
  .tk-simple-qr-card #tkWxLoginContainer,
  .tk-simple-qr-card #tkWxLoginContainer iframe {
    width: 300px !important;
  }
}

/* ===== TinyKits Final Single Login Modal CSS 2026-05 ===== */
.tk-login-modal {
  position: fixed !important;
  inset: 0 !important;
  z-index: 999999 !important;
  display: none !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 24px !important;
  box-sizing: border-box !important;
}

.tk-login-modal[aria-hidden="false"],
.tk-login-modal.is-open {
  display: flex !important;
}

.tk-login-backdrop {
  position: absolute !important;
  inset: 0 !important;
  background: rgba(15, 23, 42, .38) !important;
  backdrop-filter: blur(8px) !important;
}

.tk-simple-login-dialog {
  position: relative !important;
  z-index: 2 !important;
  width: min(430px, calc(100vw - 36px)) !important;
  padding: 26px 24px 24px !important;
  border-radius: 28px !important;
  background: #fff !important;
  border: 1px solid rgba(15, 23, 42, .08) !important;
  box-shadow: 0 28px 80px rgba(15, 23, 42, .22) !important;
  text-align: center !important;
  box-sizing: border-box !important;
}

.tk-simple-login-close {
  position: absolute !important;
  right: 14px !important;
  top: 14px !important;
  width: 30px !important;
  height: 30px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: #f1f5f9 !important;
  color: #64748b !important;
  font-size: 20px !important;
  line-height: 30px !important;
  cursor: pointer !important;
  padding: 0 !important;
}

.tk-simple-login-head {
  margin: 0 0 14px !important;
}

.tk-simple-login-head .brand {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  margin: 0 0 16px !important;
  text-decoration: none !important;
}

.tk-simple-login-head .brand img {
  width: 28px !important;
  height: 28px !important;
}

.tk-simple-login-head .brand span {
  color: #0f172a !important;
  font-size: 18px !important;
  font-weight: 900 !important;
}

.tk-simple-login-head h2 {
  margin: 0 0 8px !important;
  color: #0f172a !important;
  font-size: 24px !important;
  line-height: 1.2 !important;
  letter-spacing: -.02em !important;
}

.tk-simple-login-head p {
  margin: 0 !important;
  color: #64748b !important;
  font-size: 14px !important;
  line-height: 1.7 !important;
}

.tk-simple-qr-card {
  width: 310px !important;
  height: 360px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  overflow: hidden !important;
  border-radius: 22px !important;
  background: #fff !important;
  border: 1px solid rgba(15, 23, 42, .08) !important;
  box-shadow: 0 14px 36px rgba(15, 23, 42, .08) !important;
  box-sizing: border-box !important;
}

.tk-simple-qr-card #tkWxLoginContainer {
  width: 310px !important;
  height: 360px !important;
  overflow: hidden !important;
  background: #fff !important;
}

.tk-simple-qr-card #tkWxLoginContainer iframe {
  display: block !important;
  width: 310px !important;
  height: 360px !important;
  border: 0 !important;
  margin: 0 !important;
  transform: none !important;
  max-width: none !important;
  max-height: none !important;
  background: #fff !important;
}

.tk-simple-login-tip {
  margin: 14px 0 4px !important;
  color: #0f172a !important;
  font-size: 15px !important;
  font-weight: 800 !important;
}

.tk-simple-login-subtip {
  margin: 0 !important;
  color: #64748b !important;
  font-size: 12px !important;
  line-height: 1.6 !important;
}

.tk-qr-loading,
.tk-qr-error {
  width: 100% !important;
  height: 100% !important;
  display: grid !important;
  place-items: center !important;
  padding: 20px !important;
  box-sizing: border-box !important;
  color: #64748b !important;
  font-size: 13px !important;
  line-height: 1.7 !important;
  text-align: center !important;
}

body.tk-login-open {
  overflow: hidden !important;
}

/* ===== TinyKits Restore Website WeChat Login 2026-05 ===== */
.tk-login-modal {
  position: fixed !important;
  inset: 0 !important;
  z-index: 999999 !important;
  display: none !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 24px !important;
  box-sizing: border-box !important;
}

.tk-login-modal.is-open,
.tk-login-modal[aria-hidden="false"] {
  display: flex !important;
}

.tk-login-backdrop {
  position: absolute !important;
  inset: 0 !important;
  background: rgba(15, 23, 42, .38) !important;
  backdrop-filter: blur(8px) !important;
}

.tk-web-login-dialog {
  position: relative !important;
  z-index: 2 !important;
  width: min(390px, calc(100vw - 36px)) !important;
  padding: 24px 22px 22px !important;
  border-radius: 26px !important;
  background: #fff !important;
  border: 1px solid rgba(15, 23, 42, .08) !important;
  box-shadow: 0 28px 80px rgba(15, 23, 42, .22) !important;
  text-align: center !important;
  box-sizing: border-box !important;
  overflow: visible !important;
}

.tk-login-close {
  position: absolute !important;
  right: 14px !important;
  top: 14px !important;
  width: 30px !important;
  height: 30px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: #f1f5f9 !important;
  color: #64748b !important;
  font-size: 20px !important;
  line-height: 30px !important;
  cursor: pointer !important;
  padding: 0 !important;
}

.tk-web-login-head {
  margin: 0 0 14px !important;
}

.tk-web-login-head .brand {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  margin: 0 0 14px !important;
  text-decoration: none !important;
}

.tk-web-login-head .brand img {
  width: 28px !important;
  height: 28px !important;
  display: block !important;
}

.tk-web-login-head .brand span {
  color: #0f172a !important;
  font-size: 18px !important;
  font-weight: 900 !important;
}

.tk-web-login-head h2 {
  margin: 0 0 8px !important;
  color: #0f172a !important;
  font-size: 24px !important;
  line-height: 1.2 !important;
  letter-spacing: -.02em !important;
}

.tk-web-login-head p {
  margin: 0 !important;
  color: #64748b !important;
  font-size: 14px !important;
  line-height: 1.7 !important;
}

.tk-web-login-frame-card {
  width: 250px !important;
  height: 275px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  overflow: hidden !important;
  border-radius: 20px !important;
  background: #fff !important;
  border: 1px solid rgba(15, 23, 42, .08) !important;
  box-shadow: 0 14px 36px rgba(15, 23, 42, .08) !important;
  box-sizing: border-box !important;
}

.tk-web-login-frame-card iframe {
  display: block !important;
  width: 250px !important;
  height: 275px !important;
  border: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  background: #fff !important;
}

.tk-web-login-tip {
  margin: 14px 0 0 !important;
  color: #64748b !important;
  font-size: 12px !important;
  line-height: 1.6 !important;
}

body.tk-modal-open,
body.tk-login-open {
  overflow: hidden !important;
}

/* ===== TinyKits Web Login Modal Layout Final Override 2026-05 ===== */
.tk-login-modal {
  position: fixed !important;
  inset: 0 !important;
  z-index: 999999 !important;
  display: none !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 24px !important;
  box-sizing: border-box !important;
}

.tk-login-modal.is-open,
.tk-login-modal[aria-hidden="false"] {
  display: flex !important;
}

.tk-login-backdrop {
  position: absolute !important;
  inset: 0 !important;
  background: rgba(15, 23, 42, .38) !important;
  backdrop-filter: blur(8px) !important;
}

.tk-login-dialog.tk-web-login-dialog,
.tk-web-login-dialog {
  position: relative !important;
  z-index: 2 !important;
  display: block !important;
  grid-template-columns: none !important;
  width: min(430px, calc(100vw - 36px)) !important;
  min-height: 0 !important;
  height: auto !important;
  padding: 26px 24px 24px !important;
  border-radius: 28px !important;
  background: #fff !important;
  border: 1px solid rgba(15, 23, 42, .08) !important;
  box-shadow: 0 28px 80px rgba(15, 23, 42, .22) !important;
  text-align: center !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
}

.tk-login-close {
  position: absolute !important;
  right: 14px !important;
  top: 14px !important;
  z-index: 5 !important;
  width: 30px !important;
  height: 30px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: #f1f5f9 !important;
  color: #64748b !important;
  font-size: 20px !important;
  line-height: 30px !important;
  cursor: pointer !important;
  padding: 0 !important;
}

.tk-web-login-head {
  display: block !important;
  margin: 0 0 14px !important;
  padding: 0 !important;
  text-align: center !important;
}

.tk-web-login-head .brand {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  margin: 0 0 14px !important;
  text-decoration: none !important;
}

.tk-web-login-head .brand img {
  width: 28px !important;
  height: 28px !important;
}

.tk-web-login-head .brand span {
  color: #0f172a !important;
  font-size: 18px !important;
  font-weight: 900 !important;
}

.tk-web-login-head h2 {
  margin: 0 0 8px !important;
  color: #0f172a !important;
  font-size: 24px !important;
  line-height: 1.2 !important;
  letter-spacing: -.02em !important;
  white-space: normal !important;
}

.tk-web-login-head p {
  max-width: 300px !important;
  margin: 0 auto !important;
  color: #64748b !important;
  font-size: 14px !important;
  line-height: 1.7 !important;
}

.tk-web-login-frame-card {
  width: 320px !important;
  height: 360px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  overflow: hidden !important;
  border-radius: 22px !important;
  background: #fff !important;
  border: 1px solid rgba(15, 23, 42, .08) !important;
  box-shadow: 0 14px 36px rgba(15, 23, 42, .08) !important;
  box-sizing: border-box !important;
}

.tk-web-login-frame-card iframe,
#tkWechatFrame {
  display: block !important;
  width: 320px !important;
  height: 360px !important;
  min-width: 320px !important;
  min-height: 360px !important;
  max-width: none !important;
  max-height: none !important;
  border: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  background: #fff !important;
}

.tk-web-login-tip {
  margin: 14px 0 0 !important;
  color: #64748b !important;
  font-size: 12px !important;
  line-height: 1.6 !important;
  text-align: center !important;
}

body.tk-modal-open,
body.tk-login-open {
  overflow: hidden !important;
}

@media (max-width: 480px) {
  .tk-login-dialog.tk-web-login-dialog,
  .tk-web-login-dialog {
    width: min(390px, calc(100vw - 28px)) !important;
    padding: 24px 18px 22px !important;
  }

  .tk-web-login-frame-card,
  .tk-web-login-frame-card iframe,
  #tkWechatFrame {
    width: 300px !important;
    min-width: 300px !important;
  }
}

/* ===== TinyKits Two-Column Login Modal 2026-05 ===== */
.tk-login-modal {
  position: fixed !important;
  inset: 0 !important;
  z-index: 999999 !important;
  display: none !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 24px !important;
  box-sizing: border-box !important;
}

.tk-login-modal.is-open,
.tk-login-modal[aria-hidden="false"] {
  display: flex !important;
}

.tk-login-backdrop {
  position: absolute !important;
  inset: 0 !important;
  background: rgba(15, 23, 42, .40) !important;
  backdrop-filter: blur(8px) !important;
}

.tk-login-dialog.tk-brand-login-dialog,
.tk-brand-login-dialog {
  position: relative !important;
  z-index: 2 !important;
  width: min(900px, calc(100vw - 36px)) !important;
  min-height: 0 !important;
  display: grid !important;
  grid-template-columns: 1.02fr 0.98fr !important;
  padding: 0 !important;
  border-radius: 28px !important;
  overflow: hidden !important;
  background: #ffffff !important;
  border: 1px solid rgba(15, 23, 42, .08) !important;
  box-shadow: 0 32px 90px rgba(15, 23, 42, .22) !important;
}

.tk-login-close {
  position: absolute !important;
  top: 16px !important;
  right: 16px !important;
  z-index: 10 !important;
  width: 34px !important;
  height: 34px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.78) !important;
  color: #64748b !important;
  font-size: 22px !important;
  line-height: 34px !important;
  padding: 0 !important;
  cursor: pointer !important;
  box-shadow: 0 4px 14px rgba(15,23,42,.08) !important;
}

.tk-login-close:hover {
  color: #0f172a !important;
  background: #ffffff !important;
}

.tk-brand-login-left {
  position: relative !important;
  padding: 34px 34px 32px !important;
  background:
    radial-gradient(circle at 22% 18%, rgba(255,255,255,.14), transparent 30%),
    radial-gradient(circle at 75% 28%, rgba(255,255,255,.10), transparent 24%),
    linear-gradient(135deg, #0b8b45 0%, #14a857 100%) !important;
  color: #ffffff !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  gap: 24px !important;
}

.tk-brand-login-left .brand {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  width: fit-content !important;
  text-decoration: none !important;
}

.tk-brand-login-left .brand img {
  width: 30px !important;
  height: 30px !important;
}

.tk-brand-login-left .brand span {
  color: #ffffff !important;
  font-size: 22px !important;
  font-weight: 900 !important;
  letter-spacing: -.02em !important;
}

.tk-brand-login-eyebrow {
  margin: 0 0 10px !important;
  color: rgba(255,255,255,.86) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
}

.tk-brand-login-copy h2 {
  margin: 0 0 12px !important;
  color: #ffffff !important;
  font-size: 34px !important;
  line-height: 1.18 !important;
  letter-spacing: -.04em !important;
}

.tk-brand-login-desc {
  margin: 0 !important;
  color: rgba(255,255,255,.92) !important;
  font-size: 15px !important;
  line-height: 1.85 !important;
}

.tk-brand-login-points {
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
  display: grid !important;
  gap: 13px !important;
}

.tk-brand-login-points li {
  position: relative !important;
  padding-left: 26px !important;
  color: #ffffff !important;
  font-size: 14px !important;
  line-height: 1.7 !important;
}

.tk-brand-login-points li::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  top: .55em !important;
  width: 10px !important;
  height: 10px !important;
  border-radius: 50% !important;
  background: #ffffff !important;
  box-shadow: 0 0 0 4px rgba(255,255,255,.18) !important;
}

.tk-brand-login-right {
  background: #ffffff !important;
  padding: 38px 32px 28px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
}

.tk-brand-login-right-head h3 {
  margin: 0 0 10px !important;
  color: #0f172a !important;
  font-size: 28px !important;
  line-height: 1.2 !important;
  letter-spacing: -.03em !important;
}

.tk-brand-login-right-head p {
  margin: 0 auto 18px !important;
  max-width: 300px !important;
  color: #64748b !important;
  font-size: 14px !important;
  line-height: 1.75 !important;
}

.tk-brand-login-frame-card {
  width: 300px !important;
  height: 330px !important;
  margin: 0 auto !important;
  border-radius: 22px !important;
  overflow: hidden !important;
  border: 1px solid rgba(15, 23, 42, .08) !important;
  background: #ffffff !important;
  box-shadow: 0 14px 36px rgba(15, 23, 42, .08) !important;
}

.tk-brand-login-frame-card iframe,
#tkWechatFrame {
  display: block !important;
  width: 300px !important;
  height: 330px !important;
  border: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  background: #ffffff !important;
  overflow: hidden !important;
}

.tk-brand-login-tip {
  margin: 16px 0 0 !important;
  color: #64748b !important;
  font-size: 12px !important;
  line-height: 1.6 !important;
}

body.tk-modal-open,
body.tk-login-open {
  overflow: hidden !important;
}

@media (max-width: 820px) {
  .tk-login-dialog.tk-brand-login-dialog,
  .tk-brand-login-dialog {
    width: min(430px, calc(100vw - 28px)) !important;
    grid-template-columns: 1fr !important;
  }

  .tk-brand-login-left {
    padding: 28px 24px 22px !important;
    gap: 18px !important;
  }

  .tk-brand-login-copy h2 {
    font-size: 28px !important;
  }

  .tk-brand-login-right {
    padding: 26px 22px 24px !important;
  }

  .tk-brand-login-frame-card,
  .tk-brand-login-frame-card iframe,
  #tkWechatFrame {
    width: 300px !important;
    height: 330px !important;
  }
}

@media (max-width: 420px) {
  .tk-brand-login-frame-card,
  .tk-brand-login-frame-card iframe,
  #tkWechatFrame {
    width: 280px !important;
    height: 320px !important;
  }
}

/* ===== TinyKits Login Modal Refine 2026-05 ===== */
.tk-login-modal {
  position: fixed !important;
  inset: 0 !important;
  z-index: 999999 !important;
  display: none !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 24px !important;
  box-sizing: border-box !important;
}

.tk-login-modal.is-open,
.tk-login-modal[aria-hidden="false"] {
  display: flex !important;
}

.tk-login-backdrop {
  position: absolute !important;
  inset: 0 !important;
  background: rgba(15, 23, 42, .36) !important;
  backdrop-filter: blur(8px) !important;
}

.tk-login-dialog.tk-brand-login-dialog,
.tk-brand-login-dialog {
  position: relative !important;
  z-index: 2 !important;
  width: min(900px, calc(100vw - 36px)) !important;
  display: grid !important;
  grid-template-columns: 1.02fr .98fr !important;
  padding: 0 !important;
  border-radius: 30px !important;
  overflow: hidden !important;
  background: #f8fbf9 !important;
  border: 1px solid rgba(15, 23, 42, .06) !important;
  box-shadow: 0 28px 80px rgba(15, 23, 42, .16) !important;
}

.tk-login-close {
  position: absolute !important;
  top: 18px !important;
  right: 18px !important;
  z-index: 10 !important;
  width: 34px !important;
  height: 34px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.88) !important;
  color: #64748b !important;
  font-size: 22px !important;
  line-height: 34px !important;
  padding: 0 !important;
  cursor: pointer !important;
  box-shadow: 0 6px 18px rgba(15,23,42,.08) !important;
}

.tk-login-close:hover {
  background: #ffffff !important;
  color: #0f172a !important;
}

.tk-brand-login-left {
  padding: 36px 38px 34px !important;
  background:
    radial-gradient(circle at 14% 12%, rgba(7,136,63,.06), transparent 25%),
    linear-gradient(180deg, #f8fbf9 0%, #f4f8f6 100%) !important;
  border-right: 1px solid rgba(15, 23, 42, .06) !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  gap: 24px !important;
}

.tk-brand-login-left .brand {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  width: fit-content !important;
  text-decoration: none !important;
}

.tk-brand-login-left .brand img {
  width: 30px !important;
  height: 30px !important;
}

.tk-brand-login-left .brand span {
  color: #0f172a !important;
  font-size: 22px !important;
  font-weight: 900 !important;
  letter-spacing: -.02em !important;
}

.tk-brand-login-badge {
  display: inline-flex !important;
  align-items: center !important;
  width: fit-content !important;
  margin: 0 0 16px !important;
  padding: 8px 14px !important;
  border-radius: 999px !important;
  background: #eaf7ef !important;
  color: #0b8b45 !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
}

.tk-brand-login-copy h2 {
  margin: 0 0 14px !important;
  color: #0f172a !important;
  font-size: 46px !important;
  line-height: 1.12 !important;
  letter-spacing: -.05em !important;
}

.tk-brand-login-copy h2 span {
  color: #0b8b45 !important;
}

.tk-brand-login-desc {
  max-width: 470px !important;
  margin: 0 !important;
  color: #475569 !important;
  font-size: 17px !important;
  line-height: 1.9 !important;
}

.tk-brand-login-points {
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
  display: grid !important;
  gap: 14px !important;
}

.tk-brand-login-points li {
  position: relative !important;
  padding-left: 28px !important;
  color: #334155 !important;
  font-size: 15px !important;
  line-height: 1.7 !important;
}

.tk-brand-login-points li::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  top: .55em !important;
  width: 10px !important;
  height: 10px !important;
  border-radius: 50% !important;
  background: #0b8b45 !important;
  box-shadow: 0 0 0 5px rgba(11,139,69,.12) !important;
}

.tk-brand-login-right {
  background: #ffffff !important;
  padding: 34px 30px 28px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
}

.tk-brand-login-right-head {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 12px !important;
  margin-bottom: 18px !important;
}

.tk-wechat-icon {
  width: 54px !important;
  height: 54px !important;
  border-radius: 16px !important;
  display: grid !important;
  place-items: center !important;
  background: #ecf9f0 !important;
  color: #0b8b45 !important;
  border: 1px solid rgba(11,139,69,.10) !important;
}

.tk-wechat-icon svg {
  width: 30px !important;
  height: 30px !important;
  display: block !important;
}

.tk-brand-login-right-head p {
  max-width: 300px !important;
  margin: 0 !important;
  color: #64748b !important;
  font-size: 14px !important;
  line-height: 1.75 !important;
}

.tk-brand-login-frame-shell {
  width: 100% !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
}

.tk-brand-login-frame-card {
  width: 308px !important;
  height: 344px !important;
  padding: 0 !important;
  overflow: hidden !important;
  border-radius: 22px !important;
  background: #ffffff !important;
  border: 1px solid rgba(15, 23, 42, .05) !important;
  box-shadow: 0 12px 30px rgba(15, 23, 42, .06) !important;
}

.tk-brand-login-frame-card iframe,
#tkWechatFrame {
  display: block !important;
  width: 326px !important;
  height: 362px !important;
  border: 0 !important;
  margin: -9px 0 0 -9px !important;
  padding: 0 !important;
  background: #ffffff !important;
  overflow: hidden !important;
}

.tk-brand-login-tip {
  margin: 16px 0 0 !important;
  color: #64748b !important;
  font-size: 12px !important;
  line-height: 1.6 !important;
}

body.tk-modal-open,
body.tk-login-open {
  overflow: hidden !important;
}

@media (max-width: 820px) {
  .tk-login-dialog.tk-brand-login-dialog,
  .tk-brand-login-dialog {
    width: min(430px, calc(100vw - 28px)) !important;
    grid-template-columns: 1fr !important;
  }

  .tk-brand-login-left {
    padding: 28px 24px 22px !important;
    gap: 18px !important;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(15, 23, 42, .06) !important;
  }

  .tk-brand-login-copy h2 {
    font-size: 34px !important;
  }

  .tk-brand-login-desc {
    font-size: 15px !important;
  }

  .tk-brand-login-points li {
    font-size: 14px !important;
  }

  .tk-brand-login-right {
    padding: 24px 20px 24px !important;
  }
}

@media (max-width: 420px) {
  .tk-brand-login-frame-card {
    width: 292px !important;
    height: 336px !important;
  }

  .tk-brand-login-frame-card iframe,
  #tkWechatFrame {
    width: 312px !important;
    height: 356px !important;
    margin: -10px 0 0 -10px !important;
  }
}

/* ===== TinyKits Login Modal Fine Tune 2026-05 ===== */
.tk-brand-login-right-head {
  gap: 10px !important;
  margin-bottom: 14px !important;
}

.tk-wechat-icon {
  width: auto !important;
  height: auto !important;
  display: block !important;
  border-radius: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  color: #07c160 !important; /* 更接近微信官方绿色 */
}

.tk-wechat-icon svg {
  width: 32px !important;
  height: 32px !important;
  display: block !important;
}

.tk-brand-login-right-head p {
  max-width: 300px !important;
  margin: 0 !important;
  color: #64748b !important;
  font-size: 14px !important;
  line-height: 1.7 !important;
}

/* 外层壳子更轻一点 */
.tk-brand-login-frame-shell {
  width: 100% !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
}

.tk-brand-login-frame-card {
  width: 308px !important;
  height: 350px !important;
  padding: 0 !important;
  overflow: hidden !important;
  border-radius: 22px !important;
  background: #ffffff !important;
  border: 1px solid rgba(15, 23, 42, .04) !important;
  box-shadow: 0 10px 24px rgba(15, 23, 42, .05) !important;
}

/* 关键：减少裁切，往下放一点，让“微信登录”尽量露出来 */
.tk-brand-login-frame-card iframe,
#tkWechatFrame {
  display: block !important;
  width: 324px !important;
  height: 372px !important;
  border: 0 !important;
  padding: 0 !important;
  background: #ffffff !important;
  overflow: hidden !important;

  /* 原来是更激进的负 margin，这里收一点 */
  margin-top: -1px !important;
  margin-left: -8px !important;
  margin-right: 0 !important;
  margin-bottom: 0 !important;
}

/* 右下提示和二维码拉开一点距离 */
.tk-brand-login-tip {
  margin: 14px 0 0 !important;
  color: #64748b !important;
  font-size: 12px !important;
  line-height: 1.6 !important;
}

/* 手机端同步微调 */
@media (max-width: 420px) {
  .tk-brand-login-frame-card {
    width: 292px !important;
    height: 342px !important;
  }

  .tk-brand-login-frame-card iframe,
  #tkWechatFrame {
    width: 308px !important;
    height: 362px !important;
    margin-top: 0 !important;
    margin-left: -8px !important;
  }
}

/* ===== TinyKits Login Modal iframe down-tune 2026-05 ===== */
.tk-brand-login-frame-card {
  height: 346px !important;
}

.tk-brand-login-frame-card iframe,
#tkWechatFrame {
  width: 324px !important;
  height: 372px !important;

  /* 往下放一点 */
  margin-top: 8px !important;
  margin-left: -8px !important;
  margin-right: 0 !important;
  margin-bottom: 0 !important;
}

@media (max-width: 420px) {
  .tk-brand-login-frame-card {
    height: 338px !important;
  }

  .tk-brand-login-frame-card iframe,
  #tkWechatFrame {
    width: 308px !important;
    height: 362px !important;
    margin-top: 8px !important;
    margin-left: -8px !important;
  }
}

/* ===== TinyKits Direct Website WeChat Login CSS 2026-05 ===== */
.tk-brand-login-frame-card {
  width: 308px !important;
  height: 344px !important;
  padding: 0 !important;
  overflow: hidden !important;
  border-radius: 22px !important;
  background: #ffffff !important;
  border: 1px solid rgba(15, 23, 42, .05) !important;
  box-shadow: 0 12px 30px rgba(15, 23, 42, .06) !important;
}

.tk-web-wx-login-container,
#tkWebWxLoginContainer {
  width: 308px !important;
  height: 344px !important;
  overflow: hidden !important;
  background: #ffffff !important;
}

#tkWebWxLoginBox {
  width: 324px !important;
  height: 362px !important;
  margin: 8px 0 0 -8px !important;
  overflow: hidden !important;
  background: #ffffff !important;
}

#tkWebWxLoginBox iframe {
  display: block !important;
  width: 324px !important;
  height: 362px !important;
  border: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  background: #ffffff !important;
}

.tk-qr-loading,
.tk-qr-error {
  width: 100% !important;
  height: 100% !important;
  display: grid !important;
  place-items: center !important;
  padding: 20px !important;
  box-sizing: border-box !important;
  color: #64748b !important;
  font-size: 13px !important;
  line-height: 1.7 !important;
  text-align: center !important;
}

.tk-qr-error button {
  margin-top: 12px !important;
  height: 34px !important;
  padding: 0 14px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: #07883f !important;
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  cursor: pointer !important;
}

@media (max-width: 420px) {
  .tk-brand-login-frame-card,
  .tk-web-wx-login-container,
  #tkWebWxLoginContainer {
    width: 292px !important;
    height: 336px !important;
  }

  #tkWebWxLoginBox,
  #tkWebWxLoginBox iframe {
    width: 308px !important;
    height: 356px !important;
  }

  #tkWebWxLoginBox {
    margin: 8px 0 0 -8px !important;
  }
}

/* ===== TinyKits Recover Working iframe Login 2026-05 ===== */
.tk-brand-login-frame-card {
  width: 308px !important;
  height: 344px !important;
  padding: 0 !important;
  overflow: hidden !important;
  border-radius: 22px !important;
  background: #ffffff !important;
  border: 1px solid rgba(15, 23, 42, .05) !important;
  box-shadow: 0 12px 30px rgba(15, 23, 42, .06) !important;
}

.tk-brand-login-frame-card iframe,
#tkWechatFrame {
  display: block !important;
  width: 324px !important;
  height: 372px !important;
  border: 0 !important;
  padding: 0 !important;
  background: #ffffff !important;
  overflow: hidden !important;
  margin-top: 8px !important;
  margin-left: -8px !important;
}

.tk-web-wx-login-container,
#tkWebWxLoginContainer,
#tkWebWxLoginBox {
  display: none !important;
}

/* ===== TinyKits Login iframe Loading Overlay 2026-05 ===== */
.tk-brand-login-frame-card {
  position: relative !important;
}

.tk-login-frame-loading {
  position: absolute !important;
  inset: 0 !important;
  z-index: 3 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-direction: column !important;
  gap: 12px !important;
  background: rgba(255, 255, 255, .96) !important;
  color: #64748b !important;
  font-size: 13px !important;
  line-height: 1.6 !important;
  text-align: center !important;
  transition: opacity .22s ease, visibility .22s ease !important;
}

.tk-login-frame-loading.is-hidden {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

.tk-login-frame-spinner {
  width: 28px !important;
  height: 28px !important;
  border-radius: 50% !important;
  border: 3px solid #e5e7eb !important;
  border-top-color: #07883f !important;
  animation: tk-login-spin .8s linear infinite !important;
}

.tk-login-frame-loading strong {
  color: #0f172a !important;
  font-size: 14px !important;
  font-weight: 800 !important;
}

.tk-login-frame-loading span {
  color: #64748b !important;
  font-size: 12px !important;
}

@keyframes tk-login-spin {
  to {
    transform: rotate(360deg);
  }
}

/* ===== TinyKits Home Hero-to-Tools Gap Reduce 2026-05 ===== */
.tk-hero-clean {
  padding-bottom: 24px !important;
}

.tk-home-tool-slider-section {
  padding-top: 20px !important;
}

/* ===== TinyKits Home Slider Height Compact 2026-05 ===== */
.tk-tool-slider {
  margin-top: 0 !important;
  padding: 14px !important;
  border-radius: 28px !important;
}

.tk-tool-tabs {
  margin-bottom: 12px !important;
  gap: 8px !important;
}

.tk-tool-tab {
  padding: 10px 12px !important;
  border-radius: 16px !important;
  font-size: 13px !important;
}

.tk-tool-tab img {
  width: 22px !important;
  height: 22px !important;
}

.tk-tool-slides {
  min-height: 430px !important;
  border-radius: 24px !important;
}

.tk-tool-slide {
  padding: 24px 28px !important;
  gap: 22px !important;
  border-radius: 24px !important;
}

.tk-slide-eyebrow {
  margin-bottom: 12px !important;
  padding: 7px 11px !important;
}

.tk-tool-slide h3 {
  font-size: clamp(25px, 2.5vw, 34px) !important;
  line-height: 1.16 !important;
}

.tk-tool-slide-copy > p {
  margin-top: 12px !important;
  font-size: 15px !important;
  line-height: 1.72 !important;
}

.tk-slide-tags {
  margin-top: 12px !important;
}

.tk-tool-slide ul {
  margin-top: 14px !important;
  gap: 7px !important;
}

.tk-tool-slide li {
  font-size: 13px !important;
  line-height: 1.55 !important;
}

.tk-tool-slide .tk-actions {
  margin-top: 18px !important;
}

.tk-tool-slide-visual {
  min-height: 340px !important;
  padding: 16px !important;
  border-radius: 24px !important;
}

.tk-tool-window {
  width: min(100%, 480px) !important;
  border-radius: 22px !important;
}

.tk-tool-window-top {
  height: 44px !important;
}

.tk-feedback-preview {
  padding: 14px !important;
  gap: 12px !important;
}

.tk-preview-page {
  min-height: 245px !important;
  padding: 24px 20px !important;
}

.tk-compress-preview,
.tk-style-preview,
.tk-guide-preview {
  padding: 18px !important;
}

.tk-tool-dots {
  margin-top: 12px !important;
}

@media (max-width: 980px) {
  .tk-tool-slides {
    min-height: 0 !important;
  }

  .tk-tool-slide,
  .tk-tool-slide.active {
    padding: 22px !important;
  }

  .tk-tool-slide-visual {
    min-height: 320px !important;
  }
}

/* ===== TinyKits Home Slider Equal Height 2026-05 ===== */
.tk-tool-slides {
  height: 430px !important;
  min-height: 430px !important;
  position: relative !important;
  overflow: hidden !important;
}

.tk-tool-slide,
.tk-tool-slide.active {
  position: absolute !important;
  inset: 0 !important;
  height: 430px !important;
  box-sizing: border-box !important;
}

.tk-tool-slide {
  display: grid !important;
  grid-template-columns: minmax(0, .95fr) minmax(360px, 1.05fr) !important;
  align-items: stretch !important;
}

.tk-tool-slide-copy {
  min-height: 0 !important;
  justify-content: center !important;
}

.tk-tool-slide h3 {
  min-height: 78px !important;
  display: flex !important;
  align-items: flex-end !important;
}

.tk-tool-slide-copy > p {
  min-height: 78px !important;
  max-height: 78px !important;
  overflow: hidden !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 3 !important;
  -webkit-box-orient: vertical !important;
}

.tk-slide-tags {
  min-height: 30px !important;
}

.tk-tool-slide ul {
  min-height: 74px !important;
  max-height: 74px !important;
  overflow: hidden !important;
}

.tk-tool-slide .tk-actions {
  min-height: 44px !important;
}

.tk-tool-slide-visual {
  height: 340px !important;
  min-height: 340px !important;
  max-height: 340px !important;
}

.tk-tool-window {
  max-height: 310px !important;
}

.tk-feedback-preview,
.tk-compress-preview,
.tk-style-preview,
.tk-guide-preview {
  max-height: 300px !important;
  overflow: hidden !important;
}

.tk-tool-dots {
  height: 18px !important;
}

/* 手机端不要强行固定太死，避免内容被裁 */
@media (max-width: 980px) {
  .tk-tool-slides {
    height: auto !important;
    min-height: 0 !important;
  }

  .tk-tool-slide,
  .tk-tool-slide.active {
    position: relative !important;
    height: auto !important;
    min-height: 0 !important;
  }

  .tk-tool-slide h3,
  .tk-tool-slide-copy > p,
  .tk-tool-slide ul,
  .tk-tool-slide .tk-actions {
    min-height: 0 !important;
    max-height: none !important;
  }

  .tk-tool-slide-copy > p {
    display: block !important;
    overflow: visible !important;
  }

  .tk-tool-slide-visual {
    height: auto !important;
    max-height: none !important;
  }
}

/* ===== TinyKits Home Slider Real Dashboard Images 2026-05 ===== */
.tk-tool-slide-visual.tk-tool-image-visual {
  height: 340px !important;
  min-height: 340px !important;
  max-height: 340px !important;
  padding: 18px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}

.tk-tool-slide-visual.tk-tool-image-visual img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  object-position: center !important;
  border-radius: 22px !important;
  background: #ffffff !important;
  box-shadow: 0 20px 46px rgba(15, 23, 42, .12) !important;
}

@media (max-width: 980px) {
  .tk-tool-slide-visual.tk-tool-image-visual {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
  }

  .tk-tool-slide-visual.tk-tool-image-visual img {
    height: auto !important;
    max-height: 360px !important;
  }
}

/* ===== TinyKits Home Slider Tab Refine 2026-05 ===== */

/* 去掉卡片内容左上角的小标签 */
.tk-tool-slide .tk-slide-eyebrow {
  display: none !important;
}

/* 左侧内容去掉标签后，整体稍微上提一点 */
.tk-tool-slide-copy {
  justify-content: center !important;
}

/* 默认 Tab 保持干净 */
.tk-tool-tab {
  position: relative !important;
  background: #ffffff !important;
  border: 1px solid rgba(15, 23, 42, .08) !important;
  color: #0f172a !important;
}

/* 选中 Tab 更明显 */
.tk-tool-tab.active {
  background: linear-gradient(180deg, #f0fbf4 0%, #ffffff 100%) !important;
  border: 2px solid #0b8b45 !important;
  color: #0b8b45 !important;
  box-shadow: 0 12px 28px rgba(11, 139, 69, .14) !important;
  transform: translateY(-1px) !important;
}

/* 选中态底部加一条品牌绿强调线 */
.tk-tool-tab.active::after {
  content: "" !important;
  position: absolute !important;
  left: 16px !important;
  right: 16px !important;
  bottom: -2px !important;
  height: 3px !important;
  border-radius: 999px !important;
  background: #0b8b45 !important;
}

/* 选中态 icon 更突出 */
.tk-tool-tab.active img {
  transform: scale(1.08) !important;
  filter: saturate(1.15) !important;
}

/* hover 不要抢 active 的视觉层级 */
.tk-tool-tab:hover:not(.active) {
  border-color: rgba(11, 139, 69, .22) !important;
  color: #0b8b45 !important;
  box-shadow: 0 8px 20px rgba(15, 23, 42, .06) !important;
}

/* ===== TinyKits Home Tab Underline Remove 2026-05 ===== */
.tk-tool-tab.active::after {
  display: none !important;
  content: none !important;
}

/* ===== TinyKits Slider Image Visual Single Layer 2026-05 ===== */
.tk-tool-slide-visual.tk-tool-image-visual {
  height: 340px !important;
  min-height: 340px !important;
  max-height: 340px !important;

  /* 只保留这一层 */
  padding: 10px !important;
  border-radius: 26px !important;
  background: #f7faf8 !important;
  border: 1px solid rgba(15, 23, 42, .05) !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.5) !important;
  overflow: hidden !important;
}

/* 去掉图片自身第二层卡片感，顺便放大 */
.tk-tool-slide-visual.tk-tool-image-visual img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  object-position: center !important;

  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
}

/* 如果 tone 颜色层还在，统一压掉，避免两层背景 */
.tk-tool-slide-visual.tk-tool-image-visual.tone-purple,
.tk-tool-slide-visual.tk-tool-image-visual.tone-green,
.tk-tool-slide-visual.tk-tool-image-visual.tone-blue,
.tk-tool-slide-visual.tk-tool-image-visual.tone-orange {
  background: #f7faf8 !important;
}

@media (max-width: 980px) {
  .tk-tool-slide-visual.tk-tool-image-visual {
    height: 320px !important;
    min-height: 320px !important;
    max-height: 320px !important;
    padding: 8px !important;
  }
}

/* ===== TinyKits Slider Image Right Align 2026-05 ===== */

/* 右侧图片区域：去掉背景框，只负责承载图片 */
.tk-tool-slide-visual.tk-tool-image-visual {
  height: 340px !important;
  min-height: 340px !important;
  max-height: 340px !important;
  padding: 0 !important;
  border: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
  overflow: hidden !important;

  display: flex !important;
  align-items: flex-start !important;
  justify-content: flex-end !important;
  border-radius: 0 24px 24px 0 !important;
}

/* 压掉 tone 背景色，避免还有一层浅绿框 */
.tk-tool-slide-visual.tk-tool-image-visual.tone-purple,
.tk-tool-slide-visual.tk-tool-image-visual.tone-green,
.tk-tool-slide-visual.tk-tool-image-visual.tone-blue,
.tk-tool-slide-visual.tk-tool-image-visual.tone-orange {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* 图片等比例放大到接近区域高度，右上/右下圆角 */
.tk-tool-slide-visual.tk-tool-image-visual img {
  display: block !important;
  width: auto !important;
  height: 100% !important;
  max-width: none !important;
  max-height: 100% !important;
  object-fit: contain !important;
  object-position: right top !important;

  margin: 0 0 0 auto !important;
  border: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
  border-radius: 0 22px 22px 0 !important;
}

/* 确保 slide 自身不要裁掉右侧圆角 */
.tk-tool-slide {
  overflow: hidden !important;
}

@media (max-width: 980px) {
  .tk-tool-slide-visual.tk-tool-image-visual {
    height: 320px !important;
    min-height: 320px !important;
    max-height: 320px !important;
    border-radius: 0 20px 20px 0 !important;
  }

  .tk-tool-slide-visual.tk-tool-image-visual img {
    height: 100% !important;
    border-radius: 0 18px 18px 0 !important;
  }
}

/* ===== TinyKits Home Second Screen More Compact 2026-05 ===== */

/* 二屏整体高度压缩 */
.tk-tool-slides {
  height: 380px !important;
  min-height: 380px !important;
}

.tk-tool-slide,
.tk-tool-slide.active {
  height: 380px !important;
  padding: 20px 24px !important;
  gap: 20px !important;
}

/* 左侧文字区压缩一点 */
.tk-tool-slide h3 {
  min-height: 62px !important;
  font-size: clamp(24px, 2.3vw, 32px) !important;
  line-height: 1.15 !important;
}

.tk-tool-slide-copy > p {
  min-height: 68px !important;
  max-height: 68px !important;
  margin-top: 10px !important;
  line-height: 1.62 !important;
}

.tk-slide-tags {
  margin-top: 10px !important;
  min-height: 28px !important;
}

.tk-slide-tags span {
  height: 28px !important;
  font-size: 12px !important;
}

.tk-tool-slide ul {
  margin-top: 12px !important;
  min-height: 64px !important;
  max-height: 64px !important;
  gap: 6px !important;
}

.tk-tool-slide li {
  line-height: 1.45 !important;
}

/* 右侧图片区跟随二屏压缩 */
.tk-tool-slide-visual.tk-tool-image-visual {
  height: 320px !important;
  min-height: 320px !important;
  max-height: 320px !important;
}

.tk-tool-slide-visual.tk-tool-image-visual img {
  height: 100% !important;
}

/* tab 和底部点也稍微收紧 */
.tk-tool-tabs {
  margin-bottom: 10px !important;
}

.tk-tool-dots {
  margin-top: 8px !important;
  height: 14px !important;
}

/* ===== TinyKits Slider Image Flush Right 2026-05 ===== */

/* 让 slide 本身成为裁切容器，右侧图片可以贴边 */
.tk-tool-slide {
  overflow: hidden !important;
}

/* 右侧图片区不再有自己的背景、边框、内边距 */
.tk-tool-slide-visual.tk-tool-image-visual {
  height: 100% !important;
  min-height: 100% !important;
  max-height: none !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
  overflow: hidden !important;

  display: flex !important;
  align-items: stretch !important;
  justify-content: flex-end !important;

  border-radius: 0 24px 24px 0 !important;
}

/* 去掉 tone 背景 */
.tk-tool-slide-visual.tk-tool-image-visual.tone-purple,
.tk-tool-slide-visual.tk-tool-image-visual.tone-green,
.tk-tool-slide-visual.tk-tool-image-visual.tone-blue,
.tk-tool-slide-visual.tk-tool-image-visual.tone-orange {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* 图片高度跟外层框齐平，等比例放大，右上右下圆角 */
.tk-tool-slide-visual.tk-tool-image-visual img {
  display: block !important;

  height: 100% !important;
  width: auto !important;
  min-width: 100% !important;

  max-width: none !important;
  max-height: none !important;

  object-fit: cover !important;
  object-position: right top !important;

  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  box-shadow: none !important;
  background: transparent !important;

  border-radius: 0 24px 24px 0 !important;
}

/* 右侧列贴到 slide 的右边和上边 */
.tk-tool-slide {
  padding-right: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

/* 左侧文字保留内边距，不跟着贴边 */
.tk-tool-slide-copy {
  padding-top: 20px !important;
  padding-bottom: 20px !important;
  padding-left: 0 !important;
  padding-right: 8px !important;
}

/* 手机端不要强行裁切 */
@media (max-width: 980px) {
  .tk-tool-slide {
    padding: 22px !important;
  }

  .tk-tool-slide-visual.tk-tool-image-visual {
    height: auto !important;
    min-height: 0 !important;
    border-radius: 20px !important;
  }

  .tk-tool-slide-visual.tk-tool-image-visual img {
    width: 100% !important;
    height: auto !important;
    min-width: 0 !important;
    object-fit: contain !important;
    border-radius: 20px !important;
  }
}

/* ===== TinyKits Slider Image Full Height No Crop 2026-05 ===== */

/* slide 右侧保持贴边，但不裁图片 */
.tk-tool-slide {
  overflow: hidden !important;
  padding-top: 0 !important;
  padding-right: 0 !important;
  padding-bottom: 0 !important;
}

/* 右侧图片容器高度完全跟随外层卡片 */
.tk-tool-slide-visual.tk-tool-image-visual {
  height: 100% !important;
  min-height: 100% !important;
  max-height: none !important;

  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: visible !important;

  display: flex !important;
  align-items: stretch !important;
  justify-content: flex-end !important;

  border-radius: 0 24px 24px 0 !important;
}

/* 清掉之前 tone 背景 */
.tk-tool-slide-visual.tk-tool-image-visual.tone-purple,
.tk-tool-slide-visual.tk-tool-image-visual.tone-green,
.tk-tool-slide-visual.tk-tool-image-visual.tone-blue,
.tk-tool-slide-visual.tk-tool-image-visual.tone-orange {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* 核心：图片不裁切，按高度等比例放大，右上右下贴边 */
.tk-tool-slide-visual.tk-tool-image-visual img {
  display: block !important;

  height: 100% !important;
  width: auto !important;

  min-width: 0 !important;
  max-width: none !important;
  max-height: none !important;

  object-fit: contain !important;
  object-position: right top !important;

  margin: 0 0 0 auto !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;

  border-radius: 0 24px 24px 0 !important;
}

/* 左侧内容保留舒适内边距 */
.tk-tool-slide-copy {
  padding-top: 20px !important;
  padding-bottom: 20px !important;
  padding-right: 20px !important;
}

/* 移动端恢复普通显示 */
@media (max-width: 980px) {
  .tk-tool-slide {
    padding: 22px !important;
  }

  .tk-tool-slide-visual.tk-tool-image-visual {
    height: auto !important;
    min-height: 0 !important;
    overflow: hidden !important;
    border-radius: 20px !important;
  }

  .tk-tool-slide-visual.tk-tool-image-visual img {
    width: 100% !important;
    height: auto !important;
    object-fit: contain !important;
    border-radius: 20px !important;
  }
}

/* ===== TinyKits Slider Image Scale Up To Visual Height 2026-05 ===== */

/* 右侧图片区保持为整块视觉区域 */
.tk-tool-slide-visual.tk-tool-image-visual {
  height: 100% !important;
  min-height: 100% !important;
  max-height: none !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: hidden !important;

  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  border-radius: 0 24px 24px 0 !important;
}

/* 图片放大到接近右侧框高度，右对齐，不再留那么多空白 */
.tk-tool-slide-visual.tk-tool-image-visual img {
  display: block !important;

  width: auto !important;
  height: 118% !important;
  max-width: none !important;
  max-height: none !important;

  object-fit: contain !important;
  object-position: right center !important;

  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;

  transform: translateX(0) !important;
  border-radius: 0 24px 24px 0 !important;
}

/* 如果某张图还是显小，可以整体继续放大 */
.tk-tool-slide[data-tool-slide="3"] .tk-tool-slide-visual.tk-tool-image-visual img {
  height: 126% !important;
}

@media (max-width: 980px) {
  .tk-tool-slide-visual.tk-tool-image-visual img {
    width: 100% !important;
    height: auto !important;
    max-width: 100% !important;
  }
}

/* ===== TinyKits Third Screen Title Accent 2026-05 ===== */
.tk-title-accent {
  color: #0b8b45 !important;
  display: inline-block !important;
}

/* ===== TinyKits Home Hero Note Remove + Tools Up 2026-05 ===== */
.tk-hero-note {
  display: none !important;
}

.tk-hero-clean {
  padding-bottom: 8px !important;
}

.tk-home-tool-slider-section {
  padding-top: 0 !important;
}

.tk-hero-clean .tk-chips {
  margin-bottom: 0 !important;
}

/* ===== TinyKits Home Tools Slightly Down 2026-05 ===== */
.tk-hero-clean {
  padding-bottom: 22px !important;
}

.tk-home-tool-slider-section {
  padding-top: 12px !important;
}

/* ===== TinyKits Slider Image Full Height Right Align 2026-05 ===== */

/* 右侧图片区：上下撑满，右侧贴边 */
.tk-tool-slide-visual.tk-tool-image-visual {
  height: 100% !important;
  min-height: 100% !important;
  max-height: none !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: hidden !important;

  display: flex !important;
  align-items: stretch !important;
  justify-content: flex-end !important;

  border-radius: 0 24px 24px 0 !important;
}

/* 核心：按高度撑满，等比例，右侧不留空 */
.tk-tool-slide-visual.tk-tool-image-visual img {
  display: block !important;

  height: 100% !important;
  width: auto !important;

  max-height: none !important;
  max-width: none !important;
  min-width: 0 !important;

  object-fit: contain !important;
  object-position: right center !important;

  margin: 0 0 0 auto !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;

  border-radius: 0 24px 24px 0 !important;
}

/* 压掉之前 width:100% 的覆盖 */
.tk-tool-slide[data-tool-slide="3"] .tk-tool-slide-visual.tk-tool-image-visual img {
  height: 100% !important;
  width: auto !important;
  max-width: none !important;
  object-fit: contain !important;
}

/* 右侧列不要居中，始终靠右 */
.tk-tool-slide {
  overflow: hidden !important;
}

/* ===== TinyKits Slider Image Fill No Gap 2026-05 ===== */

/* 右侧视觉区作为裁切容器，去掉所有背景和内边距 */
.tk-tool-slide-visual.tk-tool-image-visual {
  height: 100% !important;
  min-height: 100% !important;
  max-height: none !important;
  width: 100% !important;

  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;

  overflow: hidden !important;
  display: flex !important;
  align-items: stretch !important;
  justify-content: flex-end !important;

  border-radius: 0 24px 24px 0 !important;
}

/* 压掉所有 tone 背景，避免图片后面还有一层浅色框 */
.tk-tool-slide-visual.tk-tool-image-visual.tone-purple,
.tk-tool-slide-visual.tk-tool-image-visual.tone-green,
.tk-tool-slide-visual.tk-tool-image-visual.tone-blue,
.tk-tool-slide-visual.tk-tool-image-visual.tone-orange {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* 图片放大铺满右侧区域，不留上边和右边缝隙 */
.tk-tool-slide-visual.tk-tool-image-visual img {
  display: block !important;

  width: 100% !important;
  height: 100% !important;
  min-width: 100% !important;
  min-height: 100% !important;
  max-width: none !important;
  max-height: none !important;

  object-fit: cover !important;
  object-position: right center !important;

  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;

  border-radius: 0 24px 24px 0 !important;
}

/* 图片本身如果还有内置留白，再轻微放大一点 */
.tk-tool-slide[data-tool-slide="0"] .tk-tool-slide-visual.tk-tool-image-visual img,
.tk-tool-slide[data-tool-slide="1"] .tk-tool-slide-visual.tk-tool-image-visual img,
.tk-tool-slide[data-tool-slide="2"] .tk-tool-slide-visual.tk-tool-image-visual img,
.tk-tool-slide[data-tool-slide="3"] .tk-tool-slide-visual.tk-tool-image-visual img {
  transform: scale(1.08) !important;
  transform-origin: right center !important;
}

/* ===== TinyKits Slider Image Final Height Fit 2026-05 ===== */

/* 右侧图片区域：完全去掉背景框、内边距和阴影 */
.tk-tool-slider .tk-tool-slide .tk-tool-slide-visual.tk-tool-image-visual {
  height: 100% !important;
  min-height: 100% !important;
  max-height: none !important;

  width: 100% !important;
  min-width: 0 !important;

  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: hidden !important;

  display: flex !important;
  align-items: stretch !important;
  justify-content: flex-end !important;

  border-radius: 0 24px 24px 0 !important;
}

/* 压掉 tone 背景 */
.tk-tool-slider .tk-tool-slide .tk-tool-slide-visual.tk-tool-image-visual.tone-purple,
.tk-tool-slider .tk-tool-slide .tk-tool-slide-visual.tk-tool-image-visual.tone-green,
.tk-tool-slider .tk-tool-slide .tk-tool-slide-visual.tk-tool-image-visual.tone-blue,
.tk-tool-slider .tk-tool-slide .tk-tool-slide-visual.tk-tool-image-visual.tone-orange {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* 图片：按高度撑满，等比例，不裁切，右对齐 */
.tk-tool-slider .tk-tool-slide .tk-tool-slide-visual.tk-tool-image-visual > img {
  display: block !important;

  height: 100% !important;
  width: auto !important;

  max-height: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  min-height: 0 !important;

  object-fit: contain !important;
  object-position: right center !important;

  margin: 0 0 0 auto !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;

  transform: none !important;
  border-radius: 0 24px 24px 0 !important;
}

/* 压掉之前每张图单独 scale / cover / width:100% 的旧规则 */
.tk-tool-slider .tk-tool-slide[data-tool-slide="0"] .tk-tool-slide-visual.tk-tool-image-visual > img,
.tk-tool-slider .tk-tool-slide[data-tool-slide="1"] .tk-tool-slide-visual.tk-tool-image-visual > img,
.tk-tool-slider .tk-tool-slide[data-tool-slide="2"] .tk-tool-slide-visual.tk-tool-image-visual > img,
.tk-tool-slider .tk-tool-slide[data-tool-slide="3"] .tk-tool-slide-visual.tk-tool-image-visual > img {
  height: 100% !important;
  width: auto !important;
  max-width: none !important;
  object-fit: contain !important;
  object-position: right center !important;
  transform: none !important;
}

/* 确保右侧列有足够宽度承接等比例图片，不被压缩 */
.tk-tool-slider .tk-tool-slide {
  grid-template-columns: minmax(0, .9fr) minmax(500px, 1.1fr) !important;
}

/* 移动端恢复普通适配 */
@media (max-width: 980px) {
  .tk-tool-slider .tk-tool-slide {
    grid-template-columns: 1fr !important;
  }

  .tk-tool-slider .tk-tool-slide .tk-tool-slide-visual.tk-tool-image-visual {
    height: auto !important;
    min-height: 0 !important;
    border-radius: 20px !important;
  }

  .tk-tool-slider .tk-tool-slide .tk-tool-slide-visual.tk-tool-image-visual > img {
    width: 100% !important;
    height: auto !important;
    max-width: 100% !important;
    object-fit: contain !important;
    border-radius: 20px !important;
  }
}

/* ===== TinyKits Slider Image Force Full Height 2026-05 ===== */

/* 当前二屏卡片固定高度 */
.tk-tool-slides {
  height: 380px !important;
  min-height: 380px !important;
}

.tk-tool-slide,
.tk-tool-slide.active {
  height: 380px !important;
  min-height: 380px !important;
  max-height: 380px !important;

  /* 关键：右侧图片要顶到外框，上下不能有 padding */
  padding-top: 0 !important;
  padding-right: 0 !important;
  padding-bottom: 0 !important;
  padding-left: 24px !important;

  overflow: hidden !important;
  align-items: stretch !important;
}

/* 左侧文字区自己保留内边距 */
.tk-tool-slide-copy {
  padding-top: 24px !important;
  padding-bottom: 24px !important;
  padding-right: 20px !important;
  box-sizing: border-box !important;
}

/* 右侧图片区域高度直接等于外层卡片高度 */
.tk-tool-slide-visual.tk-tool-image-visual {
  height: 380px !important;
  min-height: 380px !important;
  max-height: 380px !important;

  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: hidden !important;

  display: flex !important;
  align-items: stretch !important;
  justify-content: flex-end !important;

  border-radius: 0 24px 24px 0 !important;
}

/* 图片高度直接等于外层卡片高度，不裁切，右对齐 */
.tk-tool-slide-visual.tk-tool-image-visual > img {
  height: 380px !important;
  width: auto !important;

  max-height: none !important;
  max-width: none !important;

  object-fit: contain !important;
  object-position: right center !important;

  margin: 0 0 0 auto !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  transform: none !important;

  border-radius: 0 24px 24px 0 !important;
}

/* 压掉之前所有单图 scale / cover 规则 */
.tk-tool-slide[data-tool-slide="0"] .tk-tool-slide-visual.tk-tool-image-visual > img,
.tk-tool-slide[data-tool-slide="1"] .tk-tool-slide-visual.tk-tool-image-visual > img,
.tk-tool-slide[data-tool-slide="2"] .tk-tool-slide-visual.tk-tool-image-visual > img,
.tk-tool-slide[data-tool-slide="3"] .tk-tool-slide-visual.tk-tool-image-visual > img {
  height: 380px !important;
  width: auto !important;
  object-fit: contain !important;
  transform: none !important;
}

/* 移动端恢复正常流式展示 */
@media (max-width: 980px) {
  .tk-tool-slides {
    height: auto !important;
    min-height: 0 !important;
  }

  .tk-tool-slide,
  .tk-tool-slide.active {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    padding: 22px !important;
  }

  .tk-tool-slide-visual.tk-tool-image-visual {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    border-radius: 20px !important;
  }

  .tk-tool-slide-visual.tk-tool-image-visual > img {
    width: 100% !important;
    height: auto !important;
    max-width: 100% !important;
    object-fit: contain !important;
    border-radius: 20px !important;
  }
}

/* ===== TinyKits Slider Left Tags Above Title 2026-05 ===== */

/* 左侧内容区改成纵向排列，方便调整顺序 */
.tk-tool-slide-copy {
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
  padding-top: 14px !important;
  padding-bottom: 18px !important;
}

/* 小标签放到最前面 */
.tk-slide-tags {
  order: 1 !important;
  margin-top: 0 !important;
  margin-bottom: 14px !important;
  min-height: auto !important;
}

/* 标题放到标签下面 */
.tk-tool-slide h3 {
  order: 2 !important;
  margin-top: 0 !important;
  min-height: auto !important;
}

/* 描述紧跟标题 */
.tk-tool-slide-copy > p {
  order: 3 !important;
  margin-top: 10px !important;
}

/* 列表放后面 */
.tk-tool-slide ul {
  order: 4 !important;
  margin-top: 12px !important;
}

/* 如果 actions 还在，放最后 */
.tk-tool-slide .tk-actions {
  order: 5 !important;
}

/* 整体内容再往上提一点 */
.tk-tool-slide,
.tk-tool-slide.active {
  padding-top: 10px !important;
}

@media (max-width: 980px) {
  .tk-tool-slide-copy {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
}

/* ===== TinyKits Slider Text Unclip 2026-05 ===== */

/* 取消左侧文字裁切，保证描述和列表完整展示 */
.tk-tool-slide-copy {
  overflow: visible !important;
  min-height: 0 !important;
}

.tk-tool-slide-copy > p {
  min-height: 0 !important;
  max-height: none !important;
  height: auto !important;
  overflow: visible !important;
  display: block !important;
  -webkit-line-clamp: unset !important;
  -webkit-box-orient: unset !important;
}

.tk-tool-slide ul {
  min-height: 0 !important;
  max-height: none !important;
  height: auto !important;
  overflow: visible !important;
}

.tk-tool-slide li {
  overflow: visible !important;
}

/* 左侧内容整体稍微紧凑一点，避免撑出太高 */
.tk-tool-slide-copy > p {
  font-size: 14px !important;
  line-height: 1.62 !important;
  margin-top: 8px !important;
}

.tk-tool-slide ul {
  margin-top: 10px !important;
  gap: 5px !important;
}

.tk-tool-slide li {
  font-size: 13px !important;
  line-height: 1.48 !important;
}

/* 标签、标题、正文之间的距离收紧 */
.tk-slide-tags {
  margin-bottom: 10px !important;
}

.tk-tool-slide h3 {
  margin-bottom: 0 !important;
}

/* ===== TinyKits Slider Text Spacing 2026-05 ===== */

/* 左侧内容区整体保持靠上，但内部更舒展 */
.tk-tool-slide-copy {
  padding-top: 18px !important;
}

/* 标签和标题之间增加间距 */
.tk-slide-tags {
  margin-bottom: 16px !important;
  gap: 9px !important;
}

/* 标题和正文之间增加间距 */
.tk-tool-slide h3 {
  margin-bottom: 0 !important;
  line-height: 1.18 !important;
}

/* 正文说明稍微下移，行距更舒服 */
.tk-tool-slide-copy > p {
  margin-top: 14px !important;
  font-size: 14px !important;
  line-height: 1.72 !important;
}

/* 正文和列表之间增加间距 */
.tk-tool-slide ul {
  margin-top: 18px !important;
  gap: 9px !important;
}

/* 列表行距更舒展 */
.tk-tool-slide li {
  font-size: 13px !important;
  line-height: 1.58 !important;
}

/* 绿色圆点位置跟随行距微调 */
.tk-tool-slide li::before {
  top: .62em !important;
}

/* ===== TinyKits Slider Support Info 2026-05 ===== */
.tk-slider-support {
  margin-top: 22px !important;
  display: grid !important;
  gap: 10px !important;
  max-width: 420px !important;
}

.tk-slider-support-row {
  min-height: 38px !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 8px 10px !important;
  border-radius: 16px !important;
  background: rgba(248, 250, 252, .88) !important;
  border: 1px solid rgba(15, 23, 42, .06) !important;
  box-shadow: 0 8px 18px rgba(15, 23, 42, .035) !important;
  width: fit-content !important;
}

.tk-support-icon {
  width: 24px !important;
  height: 24px !important;
  display: inline-grid !important;
  place-items: center !important;
  border-radius: 999px !important;
  background: #ecfdf3 !important;
  color: #07883f !important;
  font-size: 13px !important;
  flex: 0 0 auto !important;
}

.tk-slider-support-row strong {
  color: #0f172a !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  margin-right: 2px !important;
  white-space: nowrap !important;
}

.tk-slider-support-row em {
  height: 22px !important;
  display: inline-flex !important;
  align-items: center !important;
  padding: 0 9px !important;
  border-radius: 999px !important;
  background: #ffffff !important;
  border: 1px solid rgba(15, 23, 42, .06) !important;
  color: #475569 !important;
  font-size: 12px !important;
  font-style: normal !important;
  font-weight: 700 !important;
  white-space: nowrap !important;
}

@media (max-width: 980px) {
  .tk-slider-support {
    margin-top: 16px !important;
  }

  .tk-slider-support-row {
    flex-wrap: wrap !important;
    width: 100% !important;
  }
}

/* ===== TinyKits Slider Support Info 2026-05 ===== */
.tk-slider-support {
  margin-top: 22px !important;
  display: grid !important;
  gap: 10px !important;
  max-width: 420px !important;
}

.tk-slider-support-row {
  min-height: 38px !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 8px 10px !important;
  border-radius: 16px !important;
  background: rgba(248, 250, 252, .88) !important;
  border: 1px solid rgba(15, 23, 42, .06) !important;
  box-shadow: 0 8px 18px rgba(15, 23, 42, .035) !important;
  width: fit-content !important;
}

.tk-support-icon {
  width: 24px !important;
  height: 24px !important;
  display: inline-grid !important;
  place-items: center !important;
  border-radius: 999px !important;
  background: #ecfdf3 !important;
  color: #07883f !important;
  font-size: 13px !important;
  flex: 0 0 auto !important;
}

.tk-slider-support-row strong {
  color: #0f172a !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  margin-right: 2px !important;
  white-space: nowrap !important;
}

.tk-slider-support-row em {
  height: 22px !important;
  display: inline-flex !important;
  align-items: center !important;
  padding: 0 9px !important;
  border-radius: 999px !important;
  background: #ffffff !important;
  border: 1px solid rgba(15, 23, 42, .06) !important;
  color: #475569 !important;
  font-size: 12px !important;
  font-style: normal !important;
  font-weight: 700 !important;
  white-space: nowrap !important;
}

@media (max-width: 980px) {
  .tk-slider-support {
    margin-top: 16px !important;
  }

  .tk-slider-support-row {
    flex-wrap: wrap !important;
    width: 100% !important;
  }
}

/* ===== TinyKits Slider Support Position Fix 2026-05 ===== */

/* 支持信息放到列表下面的空白区域 */
.tk-slider-support {
  order: 5 !important;
  margin-top: 24px !important;
}

/* 确保列表仍在正文下面 */
.tk-tool-slide ul {
  order: 4 !important;
}

/* ===== TinyKits Remove Slider Support Info 2026-05 ===== */
.tk-slider-support {
  display: none !important;
}

/* ===== TinyKits Slider Text Spacing More 2026-05 ===== */

/* 小标签和标题之间 */
.tk-slide-tags {
  margin-bottom: 18px !important;
}

/* 标题和正文之间 */
.tk-tool-slide-copy > p {
  margin-top: 16px !important;
  line-height: 1.76 !important;
}

/* 正文和列表之间 */
.tk-tool-slide ul {
  margin-top: 20px !important;
  gap: 10px !important;
}

/* 列表行距 */
.tk-tool-slide li {
  line-height: 1.62 !important;
}

/* ===== TinyKits Slider Capability Cards 2026-05 ===== */

.tk-tool-slide-copy {
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
  padding-top: 26px !important;
  padding-bottom: 24px !important;
  padding-right: 24px !important;
  box-sizing: border-box !important;
}

.tk-tool-slide-copy .tk-slide-tags {
  order: 1 !important;
  margin: 0 0 18px !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 9px !important;
}

.tk-tool-slide-copy h3 {
  order: 2 !important;
  min-height: 0 !important;
  margin: 0 !important;
  font-size: clamp(28px, 2.6vw, 38px) !important;
  line-height: 1.16 !important;
  letter-spacing: -.04em !important;
}

.tk-tool-slide-copy > p {
  order: 3 !important;
  margin: 14px 0 0 !important;
  max-width: 520px !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: visible !important;
  display: block !important;
  color: #475569 !important;
  font-size: 15px !important;
  line-height: 1.75 !important;
}

.tk-capability-grid {
  order: 4 !important;
  margin-top: 24px !important;
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 10px !important;
  max-width: 560px !important;
}

.tk-capability-card {
  min-height: 92px !important;
  padding: 14px 14px 13px !important;
  border-radius: 18px !important;
  background: rgba(248, 250, 252, .92) !important;
  border: 1px solid rgba(15, 23, 42, .06) !important;
  box-shadow: 0 10px 24px rgba(15, 23, 42, .035) !important;
  box-sizing: border-box !important;
}

.tk-capability-card strong {
  display: block !important;
  margin-bottom: 8px !important;
  color: #0f172a !important;
  font-size: 14px !important;
  line-height: 1.3 !important;
  font-weight: 900 !important;
}

.tk-capability-card span {
  display: block !important;
  color: #64748b !important;
  font-size: 12px !important;
  line-height: 1.55 !important;
}

/* 新结构不再显示旧 ul 的空间 */
.tk-tool-slide-copy > ul {
  display: none !important;
}

/* 让新内容区更有呼吸感，但不撑爆二屏 */
.tk-tool-slide,
.tk-tool-slide.active {
  align-items: stretch !important;
}

/* 小屏下改为单列 */
@media (max-width: 980px) {
  .tk-capability-grid {
    grid-template-columns: 1fr !important;
    max-width: none !important;
  }

  .tk-capability-card {
    min-height: 0 !important;
  }

  .tk-tool-slide-copy {
    padding: 0 !important;
  }
}

/* ===== TinyKits Capability Cards Color + Icon 2026-05 ===== */

/* 标签颜色更丰富一点 */
.tk-tool-slide-copy .tk-slide-tags span {
  border: 1px solid rgba(15, 23, 42, .05) !important;
  font-weight: 800 !important;
}

.tk-tool-slide-copy .tk-slide-tags span:nth-child(1) {
  background: #ecfdf3 !important;
  color: #07883f !important;
}

.tk-tool-slide-copy .tk-slide-tags span:nth-child(2) {
  background: #eff6ff !important;
  color: #2563eb !important;
}

.tk-tool-slide-copy .tk-slide-tags span:nth-child(3) {
  background: #fff7ed !important;
  color: #ea580c !important;
}

/* 能力点卡片：改成带 icon 的轻量信息块 */
.tk-capability-card {
  position: relative !important;
  padding: 16px 14px 14px 46px !important;
  overflow: hidden !important;
  transition: transform .2s ease, box-shadow .2s ease !important;
}

.tk-capability-card::before {
  content: "" !important;
  position: absolute !important;
  left: 14px !important;
  top: 16px !important;
  width: 24px !important;
  height: 24px !important;
  border-radius: 9px !important;
  display: grid !important;
  place-items: center !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
}

/* 第一个能力点：绿色 */
.tk-capability-card:nth-child(1) {
  background: linear-gradient(180deg, #f0fdf4 0%, #ffffff 100%) !important;
  border-color: rgba(7, 136, 63, .12) !important;
}

.tk-capability-card:nth-child(1)::before {
  content: "✓" !important;
  background: #dcfce7 !important;
  color: #07883f !important;
}

/* 第二个能力点：蓝色 */
.tk-capability-card:nth-child(2) {
  background: linear-gradient(180deg, #eff6ff 0%, #ffffff 100%) !important;
  border-color: rgba(37, 99, 235, .12) !important;
}

.tk-capability-card:nth-child(2)::before {
  content: "↗" !important;
  background: #dbeafe !important;
  color: #2563eb !important;
}

/* 第三个能力点：橙色 */
.tk-capability-card:nth-child(3) {
  background: linear-gradient(180deg, #fff7ed 0%, #ffffff 100%) !important;
  border-color: rgba(234, 88, 12, .12) !important;
}

.tk-capability-card:nth-child(3)::before {
  content: "●" !important;
  background: #ffedd5 !important;
  color: #ea580c !important;
}

/* hover 时轻微浮起 */
.tk-capability-card:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 14px 30px rgba(15, 23, 42, .08) !important;
}

.tk-capability-card strong {
  margin-bottom: 7px !important;
}

.tk-capability-card span {
  color: #5f6f83 !important;
}

/* 不同 slide 的小 icon 再做一点区分 */
.tk-tool-slide[data-tool-slide="0"] .tk-capability-card:nth-child(1)::before {
  content: "✎" !important;
}

.tk-tool-slide[data-tool-slide="0"] .tk-capability-card:nth-child(2)::before {
  content: "⌘" !important;
}

.tk-tool-slide[data-tool-slide="0"] .tk-capability-card:nth-child(3)::before {
  content: "↓" !important;
}

.tk-tool-slide[data-tool-slide="1"] .tk-capability-card:nth-child(1)::before {
  content: "⌕" !important;
}

.tk-tool-slide[data-tool-slide="1"] .tk-capability-card:nth-child(2)::before {
  content: "↘" !important;
}

.tk-tool-slide[data-tool-slide="1"] .tk-capability-card:nth-child(3)::before {
  content: "ZIP" !important;
  font-size: 9px !important;
}

.tk-tool-slide[data-tool-slide="2"] .tk-capability-card:nth-child(1)::before {
  content: "◐" !important;
}

.tk-tool-slide[data-tool-slide="2"] .tk-capability-card:nth-child(2)::before {
  content: "▦" !important;
}

.tk-tool-slide[data-tool-slide="2"] .tk-capability-card:nth-child(3)::before {
  content: "Doc" !important;
  font-size: 9px !important;
}

.tk-tool-slide[data-tool-slide="3"] .tk-capability-card:nth-child(1)::before {
  content: "1" !important;
}

.tk-tool-slide[data-tool-slide="3"] .tk-capability-card:nth-child(2)::before {
  content: "▣" !important;
}

.tk-tool-slide[data-tool-slide="3"] .tk-capability-card:nth-child(3)::before {
  content: "↗" !important;
}

/* ===== TinyKits Free Trial Between Tools And Scenes 2026-05 ===== */
.tk-tool-free-trial {
  display: flex !important;
  justify-content: center !important;
}

.tk-tool-free-trial-outside {
  margin-top: -6px !important;
  margin-bottom: 46px !important;
}

.tk-tool-free-trial-outside .btn {
  height: 48px !important;
  padding: 0 36px !important;
  border-radius: 16px !important;
  font-size: 15px !important;
  font-weight: 900 !important;
  box-shadow: 0 14px 34px rgba(7, 136, 63, .18) !important;
}

/* ===== TinyKits CTA Gap Reduce 2026-05 ===== */

/* 二屏轮播结束后，CTA 往上提一点 */
.tk-home-tool-slider-section + .tk-section.tk-cta-section {
  padding-top: 8px !important;
  padding-bottom: 32px !important;
}

/* 如果中间还有空白按钮残留样式影响，压掉 */
.tk-tool-free-trial,
.tk-tool-free-trial-outside {
  display: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* CTA 卡片自身不要额外往下掉 */
.tk-home-tool-slider-section + .tk-section.tk-cta-section .tk-cta-box {
  margin-top: 0 !important;
}

/* ===== TinyKits Scene Card Icon Size 2026-05 ===== */
#scenes .tk-feature-card img {
  width: 88px !important;
  height: 88px !important;
  object-fit: contain !important;
  margin-bottom: 18px !important;
}

/* 第三屏卡片内容稍微给 icon 多一点空间 */
#scenes .tk-feature-card {
  padding-top: 30px !important;
}

/* ===== TinyKits Mobile Second Screen Gap Fix 2026-05 ===== */
@media (max-width: 768px) {
  /* 二屏整体上下间距收紧 */
  .tk-home-tool-slider-section {
    padding-top: 8px !important;
    padding-bottom: 24px !important;
  }

  .tk-tool-slider {
    padding: 12px !important;
    border-radius: 24px !important;
  }

  /* Tab 横向滚动，避免挤高 */
  .tk-tool-tabs {
    display: flex !important;
    overflow-x: auto !important;
    gap: 8px !important;
    margin-bottom: 10px !important;
    padding-bottom: 4px !important;
    scrollbar-width: none !important;
  }

  .tk-tool-tabs::-webkit-scrollbar {
    display: none !important;
  }

  .tk-tool-tab {
    flex: 0 0 auto !important;
    min-width: 190px !important;
    height: 42px !important;
    padding: 8px 12px !important;
    font-size: 12px !important;
    border-radius: 14px !important;
  }

  .tk-tool-tab img {
    width: 20px !important;
    height: 20px !important;
  }

  /* 关键：移动端取消桌面固定高度 */
  .tk-tool-slides {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
    border-radius: 22px !important;
  }

  /* 只显示 active 当前卡片，其余隐藏，避免叠层造成空白 */
  .tk-tool-slide {
    position: relative !important;
    inset: auto !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    padding: 22px 18px !important;
    display: none !important;
    grid-template-columns: 1fr !important;
    gap: 18px !important;
    overflow: visible !important;
  }

  .tk-tool-slide.active {
    display: grid !important;
    position: relative !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
  }

  /* 左侧内容自然高度，不裁切、不留固定空白 */
  .tk-tool-slide-copy {
    padding: 0 !important;
    min-height: 0 !important;
    max-height: none !important;
    justify-content: flex-start !important;
  }

  .tk-tool-slide-copy .tk-slide-tags {
    margin-bottom: 12px !important;
    gap: 7px !important;
  }

  .tk-tool-slide-copy .tk-slide-tags span {
    height: 26px !important;
    padding: 0 9px !important;
    font-size: 11px !important;
  }

  .tk-tool-slide-copy h3 {
    font-size: 25px !important;
    line-height: 1.18 !important;
    min-height: 0 !important;
    max-height: none !important;
  }

  .tk-tool-slide-copy > p {
    margin-top: 10px !important;
    font-size: 14px !important;
    line-height: 1.65 !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
    display: block !important;
  }

  /* 能力点移动端改成单列，避免撑出大高度 */
  .tk-capability-grid {
    margin-top: 16px !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
    max-width: none !important;
  }

  .tk-capability-card {
    min-height: 0 !important;
    padding: 12px 12px 12px 42px !important;
    border-radius: 16px !important;
  }

  .tk-capability-card::before {
    left: 12px !important;
    top: 12px !important;
  }

  .tk-capability-card strong {
    font-size: 13px !important;
    margin-bottom: 4px !important;
  }

  .tk-capability-card span {
    font-size: 12px !important;
    line-height: 1.5 !important;
  }

  /* 右侧图片移动端不要固定 380px，避免上下空白 */
  .tk-tool-slide-visual.tk-tool-image-visual {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    width: 100% !important;
    border-radius: 18px !important;
    overflow: hidden !important;
  }

  .tk-tool-slide-visual.tk-tool-image-visual img {
    width: 100% !important;
    height: auto !important;
    max-width: 100% !important;
    max-height: 260px !important;
    object-fit: contain !important;
    object-position: center center !important;
    border-radius: 18px !important;
  }

  .tk-tool-dots {
    margin-top: 10px !important;
    height: 12px !important;
  }
}

/* ===== TinyKits Principles Section Redesign 2026-05 ===== */
.tk-principles-section {
  padding-top: 10px !important;
  padding-bottom: 52px !important;
}

.tk-principles-layout {
  display: grid !important;
  grid-template-columns: minmax(280px, .9fr) minmax(0, 1.25fr) !important;
  gap: 22px !important;
  align-items: stretch !important;
}

.tk-principles-intro {
  padding: 34px 30px !important;
  border-radius: 28px !important;
  background: linear-gradient(180deg, #f4fbf6 0%, #eef8f2 100%) !important;
  border: 1px solid rgba(7, 136, 63, .08) !important;
  box-shadow: 0 16px 36px rgba(15, 23, 42, .05) !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
}

.tk-principles-eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  width: fit-content !important;
  height: 30px !important;
  padding: 0 12px !important;
  border-radius: 999px !important;
  background: #ffffff !important;
  border: 1px solid rgba(7, 136, 63, .10) !important;
  color: #07883f !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
  margin-bottom: 18px !important;
}

.tk-principles-intro h2 {
  margin: 0 !important;
  font-size: clamp(28px, 2.6vw, 40px) !important;
  line-height: 1.14 !important;
  letter-spacing: -.04em !important;
  color: #0f172a !important;
}

.tk-principles-intro p {
  margin: 16px 0 0 !important;
  color: #475569 !important;
  font-size: 15px !important;
  line-height: 1.8 !important;
  max-width: 34em !important;
}

.tk-principles-tags {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  margin-top: 26px !important;
}

.tk-principles-tags span {
  height: 30px !important;
  display: inline-flex !important;
  align-items: center !important;
  padding: 0 12px !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.84) !important;
  border: 1px solid rgba(15, 23, 42, .06) !important;
  color: #334155 !important;
  font-size: 12px !important;
  font-weight: 800 !important;
}

.tk-principles-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 16px !important;
}

.tk-principle-card {
  min-height: 170px !important;
  padding: 24px 22px 20px !important;
  border-radius: 24px !important;
  background: #ffffff !important;
  border: 1px solid rgba(15, 23, 42, .06) !important;
  box-shadow: 0 16px 34px rgba(15, 23, 42, .05) !important;
  position: relative !important;
  overflow: hidden !important;
}

.tk-principle-card::after {
  content: "" !important;
  position: absolute !important;
  left: 22px !important;
  right: 22px !important;
  top: 0 !important;
  height: 3px !important;
  border-radius: 999px !important;
  background: linear-gradient(90deg, #22c55e 0%, #7dd3fc 100%) !important;
  opacity: .85 !important;
}

.tk-principle-no {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 38px !important;
  height: 38px !important;
  border-radius: 12px !important;
  background: #ecfdf3 !important;
  color: #07883f !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  margin-bottom: 16px !important;
}

.tk-principle-card h3 {
  margin: 0 !important;
  color: #0f172a !important;
  font-size: 20px !important;
  line-height: 1.3 !important;
  font-weight: 900 !important;
}

.tk-principle-card p {
  margin: 12px 0 0 !important;
  color: #64748b !important;
  font-size: 14px !important;
  line-height: 1.75 !important;
}

@media (max-width: 980px) {
  .tk-principles-layout {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  .tk-principles-grid {
    grid-template-columns: 1fr !important;
  }

  .tk-principles-intro {
    padding: 26px 22px !important;
    border-radius: 24px !important;
  }

  .tk-principle-card {
    min-height: 0 !important;
    padding: 22px 18px 18px !important;
    border-radius: 20px !important;
  }
}

/* ===== TinyKits Principles Visual Enhance 2026-05 ===== */

.tk-principles-section {
  position: relative !important;
  overflow: hidden !important;
  background:
    radial-gradient(circle at 8% 18%, rgba(34, 197, 94, .08) 0, transparent 26%),
    radial-gradient(circle at 92% 84%, rgba(59, 130, 246, .08) 0, transparent 24%),
    linear-gradient(180deg, #fcfefd 0%, #f7fbf9 100%) !important;
}

/* 左侧大卡更有层次 */
.tk-principles-intro {
  position: relative !important;
  overflow: hidden !important;
  background:
    radial-gradient(circle at top right, rgba(59,130,246,.10) 0, transparent 34%),
    radial-gradient(circle at bottom left, rgba(34,197,94,.10) 0, transparent 30%),
    linear-gradient(180deg, #f7fcf8 0%, #edf8f1 100%) !important;
  border: 1px solid rgba(15, 23, 42, .05) !important;
  box-shadow: 0 18px 40px rgba(15, 23, 42, .06) !important;
}

.tk-principles-intro::before {
  content: "" !important;
  position: absolute !important;
  right: -26px !important;
  top: -26px !important;
  width: 120px !important;
  height: 120px !important;
  border-radius: 28px !important;
  background: linear-gradient(135deg, rgba(34,197,94,.12), rgba(59,130,246,.10)) !important;
  transform: rotate(18deg) !important;
}

.tk-principles-intro::after {
  content: "" !important;
  position: absolute !important;
  left: 24px !important;
  bottom: 22px !important;
  width: 72px !important;
  height: 72px !important;
  border-radius: 999px !important;
  border: 1px dashed rgba(34,197,94,.24) !important;
  opacity: .8 !important;
}

.tk-principles-eyebrow {
  background: linear-gradient(180deg, #ffffff 0%, #f3fbf6 100%) !important;
  box-shadow: 0 8px 18px rgba(7, 136, 63, .08) !important;
}

.tk-principles-intro h2 {
  max-width: 10em !important;
}

.tk-principles-intro p {
  color: #526173 !important;
}

.tk-principles-tags span {
  box-shadow: 0 8px 18px rgba(15, 23, 42, .04) !important;
  border: 0 !important;
}

.tk-principles-tags span:nth-child(1) {
  background: #ecfdf3 !important;
  color: #07883f !important;
}

.tk-principles-tags span:nth-child(2) {
  background: #eff6ff !important;
  color: #2563eb !important;
}

.tk-principles-tags span:nth-child(3) {
  background: #fff7ed !important;
  color: #ea580c !important;
}

.tk-principles-tags span:nth-child(4) {
  background: #f5f3ff !important;
  color: #7c3aed !important;
}

/* 原则卡整体更丰富 */
.tk-principles-grid {
  gap: 18px !important;
}

.tk-principle-card {
  position: relative !important;
  padding: 28px 22px 22px !important;
  border: 0 !important;
  box-shadow: 0 16px 32px rgba(15, 23, 42, .05) !important;
  transition: transform .2s ease, box-shadow .2s ease !important;
}

.tk-principle-card:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 20px 36px rgba(15, 23, 42, .08) !important;
}

/* 顶部彩条更明显 */
.tk-principle-card::after {
  left: 18px !important;
  right: 18px !important;
  height: 4px !important;
}

/* 增加 icon badge */
.tk-principle-card::before {
  position: absolute !important;
  top: 22px !important;
  right: 22px !important;
  width: 42px !important;
  height: 42px !important;
  border-radius: 14px !important;
  display: grid !important;
  place-items: center !important;
  font-size: 18px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  box-shadow: 0 10px 22px rgba(15, 23, 42, .08) !important;
}

/* 四张卡不同配色 */
.tk-principle-card:nth-child(1) {
  background: linear-gradient(180deg, #f6fdf8 0%, #ffffff 100%) !important;
}

.tk-principle-card:nth-child(1)::after {
  background: linear-gradient(90deg, #22c55e 0%, #86efac 100%) !important;
}

.tk-principle-card:nth-child(1)::before {
  content: "✦" !important;
  background: #dcfce7 !important;
  color: #07883f !important;
}

.tk-principle-card:nth-child(1) .tk-principle-no {
  background: #ecfdf3 !important;
  color: #07883f !important;
}

.tk-principle-card:nth-child(2) {
  background: linear-gradient(180deg, #f7fbff 0%, #ffffff 100%) !important;
}

.tk-principle-card:nth-child(2)::after {
  background: linear-gradient(90deg, #3b82f6 0%, #93c5fd 100%) !important;
}

.tk-principle-card:nth-child(2)::before {
  content: "🔒" !important;
  background: #dbeafe !important;
  color: #2563eb !important;
  font-size: 16px !important;
}

.tk-principle-card:nth-child(2) .tk-principle-no {
  background: #eff6ff !important;
  color: #2563eb !important;
}

.tk-principle-card:nth-child(3) {
  background: linear-gradient(180deg, #fffaf5 0%, #ffffff 100%) !important;
}

.tk-principle-card:nth-child(3)::after {
  background: linear-gradient(90deg, #f59e0b 0%, #fdba74 100%) !important;
}

.tk-principle-card:nth-child(3)::before {
  content: "▣" !important;
  background: #ffedd5 !important;
  color: #ea580c !important;
}

.tk-principle-card:nth-child(3) .tk-principle-no {
  background: #fff7ed !important;
  color: #ea580c !important;
}

.tk-principle-card:nth-child(4) {
  background: linear-gradient(180deg, #faf8ff 0%, #ffffff 100%) !important;
}

.tk-principle-card:nth-child(4)::after {
  background: linear-gradient(90deg, #8b5cf6 0%, #c4b5fd 100%) !important;
}

.tk-principle-card:nth-child(4)::before {
  content: "↻" !important;
  background: #ede9fe !important;
  color: #7c3aed !important;
}

.tk-principle-card:nth-child(4) .tk-principle-no {
  background: #f5f3ff !important;
  color: #7c3aed !important;
}

.tk-principle-no {
  margin-bottom: 18px !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.6) !important;
}

.tk-principle-card h3 {
  max-width: calc(100% - 56px) !important;
}

.tk-principle-card p {
  color: #5f6f83 !important;
}

/* 移动端收敛一点 */
@media (max-width: 980px) {
  .tk-principles-intro::before,
  .tk-principles-intro::after {
    display: none !important;
  }

  .tk-principle-card::before {
    width: 38px !important;
    height: 38px !important;
    top: 18px !important;
    right: 18px !important;
    border-radius: 12px !important;
  }
}

/* ===== TinyKits Global Background Soften 2026-05 ===== */

/* 统一整站底色，减少一屏一块的割裂感 */
body {
  background:
    radial-gradient(circle at 12% 4%, rgba(7, 136, 63, .045) 0, transparent 24%),
    radial-gradient(circle at 88% 28%, rgba(37, 99, 235, .035) 0, transparent 22%),
    linear-gradient(180deg, #fbfdfb 0%, #f8fbf9 48%, #fbfdfb 100%) !important;
}

/* main 本身不要再制造强背景块 */
main,
.tk-home-main {
  background: transparent !important;
}

/* 每个 section 保持透明，让页面底色连续 */
.tk-section,
.tk-soft-section,
.tk-home-tool-slider-section,
.tk-principles-section,
.tk-cta-section {
  background: transparent !important;
}

/* 弱化 soft section 的分块感 */
.tk-soft-section {
  box-shadow: none !important;
}

/* 原本原则屏背景比较明显，收敛成透明，只保留内部卡片层次 */
.tk-principles-section {
  background: transparent !important;
}

/* 让 section 之间过渡更自然 */
.tk-section {
  position: relative !important;
}

/* 如果某些 section 之前有强背景伪元素，也压弱 */
.tk-section::before,
.tk-section::after,
.tk-soft-section::before,
.tk-soft-section::after,
.tk-principles-section::before,
.tk-principles-section::after {
  opacity: .55 !important;
}

/* 首页首屏和二屏之间更自然，不要像两个独立色块 */
.tk-hero-clean {
  background: transparent !important;
}

.tk-tool-slider {
  background: rgba(255, 255, 255, .78) !important;
  backdrop-filter: blur(12px) !important;
  border-color: rgba(15, 23, 42, .06) !important;
}

/* CTA 卡片保持白底，但不要太重 */
.tk-cta-box {
  background:
    linear-gradient(180deg, rgba(255,255,255,.94) 0%, rgba(248,251,249,.94) 100%) !important;
  border: 1px solid rgba(15, 23, 42, .06) !important;
  box-shadow: 0 18px 46px rgba(15, 23, 42, .055) !important;
}

/* 普通功能卡片也统一到轻白底 */
.tk-feature-card,
.tk-principle-card {
  background: rgba(255,255,255,.88) !important;
  border-color: rgba(15, 23, 42, .06) !important;
}

/* 左侧原则大卡不要再像独立色块太重 */
.tk-principles-intro {
  background:
    radial-gradient(circle at 88% 12%, rgba(7,136,63,.055), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.86) 0%, rgba(244,250,246,.86) 100%) !important;
}

/* FAQ 区如果背景断层明显，也统一 */
#faq,
#why,
#scenes {
  background: transparent !important;
}

/* 移动端进一步减少复杂背景，避免一段一段明显 */
@media (max-width: 768px) {
  body {
    background: linear-gradient(180deg, #fbfdfb 0%, #f8fbf9 50%, #fbfdfb 100%) !important;
  }

  .tk-tool-slider,
  .tk-cta-box,
  .tk-feature-card,
  .tk-principles-intro,
  .tk-principle-card {
    backdrop-filter: none !important;
  }
}

/* ===== TinyKits Account Access Section 2026-05 ===== */
.tk-account-section {
  padding-top: 34px !important;
  padding-bottom: 56px !important;
  background: transparent !important;
}

.tk-account-panel {
  display: grid !important;
  grid-template-columns: minmax(0, 1.05fr) minmax(360px, .95fr) !important;
  gap: 22px !important;
  align-items: stretch !important;
  padding: 28px !important;
  border-radius: 32px !important;
  background:
    radial-gradient(circle at 8% 16%, rgba(7,136,63,.08), transparent 24%),
    linear-gradient(180deg, rgba(255,255,255,.92) 0%, rgba(248,251,249,.9) 100%) !important;
  border: 1px solid rgba(15, 23, 42, .06) !important;
  box-shadow: 0 18px 46px rgba(15, 23, 42, .055) !important;
}

.tk-account-copy {
  padding: 16px 18px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
}

.tk-account-eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  width: fit-content !important;
  height: 30px !important;
  padding: 0 12px !important;
  border-radius: 999px !important;
  background: #ecfdf3 !important;
  color: #07883f !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: .02em !important;
  margin-bottom: 16px !important;
}

.tk-account-copy h2 {
  margin: 0 !important;
  color: #0f172a !important;
  font-size: clamp(30px, 3vw, 44px) !important;
  line-height: 1.14 !important;
  letter-spacing: -.05em !important;
}

.tk-account-copy p {
  max-width: 560px !important;
  margin: 16px 0 0 !important;
  color: #526173 !important;
  font-size: 15px !important;
  line-height: 1.85 !important;
}

.tk-account-cards {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 14px !important;
}

.tk-account-mini-card {
  position: relative !important;
  min-height: 138px !important;
  padding: 22px 22px 20px 84px !important;
  border-radius: 24px !important;
  background: #ffffff !important;
  border: 1px solid rgba(15, 23, 42, .06) !important;
  box-shadow: 0 12px 28px rgba(15, 23, 42, .045) !important;
  overflow: hidden !important;
}

.tk-account-mini-card.accent {
  background: linear-gradient(180deg, #f0fdf4 0%, #ffffff 100%) !important;
  border-color: rgba(7, 136, 63, .12) !important;
}

.tk-account-icon {
  position: absolute !important;
  left: 22px !important;
  top: 24px !important;
  width: 42px !important;
  height: 42px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 16px !important;
  background: #ecfdf3 !important;
  color: #07883f !important;
  font-size: 20px !important;
  font-weight: 900 !important;
  box-shadow: 0 10px 22px rgba(7, 136, 63, .10) !important;
}

.tk-account-mini-card h3 {
  margin: 0 !important;
  color: #0f172a !important;
  font-size: 20px !important;
  line-height: 1.3 !important;
  font-weight: 900 !important;
}

.tk-account-mini-card p {
  margin: 10px 0 0 !important;
  color: #64748b !important;
  font-size: 14px !important;
  line-height: 1.72 !important;
}

@media (max-width: 900px) {
  .tk-account-panel {
    grid-template-columns: 1fr !important;
    padding: 22px !important;
  }

  .tk-account-copy {
    padding: 4px !important;
  }

  .tk-account-mini-card {
    min-height: 0 !important;
    padding: 20px 18px 18px 72px !important;
  }

  .tk-account-icon {
    left: 18px !important;
    top: 20px !important;
  }
}

/* ===== TinyKits Account Flow Section 2026-05 ===== */
.tk-account-flow-section {
  padding-top: 30px !important;
  padding-bottom: 56px !important;
}

.tk-account-flow-wrap {
  padding: 28px !important;
  border-radius: 32px !important;
  background:
    radial-gradient(circle at 10% 12%, rgba(7,136,63,.07), transparent 24%),
    linear-gradient(180deg, rgba(255,255,255,.94) 0%, rgba(248,251,249,.92) 100%) !important;
  border: 1px solid rgba(15, 23, 42, .06) !important;
  box-shadow: 0 18px 46px rgba(15, 23, 42, .05) !important;
}

.tk-account-flow-head {
  display: grid !important;
  grid-template-columns: minmax(0, 1.15fr) minmax(320px, .85fr) !important;
  gap: 22px !important;
  align-items: stretch !important;
}

.tk-account-flow-copy {
  padding: 12px 6px 8px !important;
}

.tk-account-flow-eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  height: 30px !important;
  padding: 0 12px !important;
  border-radius: 999px !important;
  background: #ecfdf3 !important;
  color: #07883f !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  margin-bottom: 16px !important;
}

.tk-account-flow-copy h2 {
  margin: 0 !important;
  color: #0f172a !important;
  font-size: clamp(30px, 3vw, 44px) !important;
  line-height: 1.14 !important;
  letter-spacing: -.05em !important;
  max-width: 11em !important;
}

.tk-account-flow-copy p {
  margin: 16px 0 0 !important;
  max-width: 42em !important;
  color: #526173 !important;
  font-size: 15px !important;
  line-height: 1.82 !important;
}

.tk-account-flow-highlight {
  padding: 18px !important;
  border-radius: 24px !important;
  background: linear-gradient(180deg, #f3fbf6 0%, #ffffff 100%) !important;
  border: 1px solid rgba(7, 136, 63, .10) !important;
  box-shadow: 0 12px 28px rgba(7, 136, 63, .06) !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
}

.tk-account-highlight-main {
  display: flex !important;
  gap: 14px !important;
  align-items: flex-start !important;
}

.tk-account-highlight-icon {
  width: 46px !important;
  height: 46px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 16px !important;
  background: #dcfce7 !important;
  color: #07883f !important;
  font-size: 22px !important;
  font-weight: 900 !important;
  flex: 0 0 auto !important;
}

.tk-account-highlight-main strong {
  display: block !important;
  color: #0f172a !important;
  font-size: 20px !important;
  line-height: 1.3 !important;
  font-weight: 900 !important;
}

.tk-account-highlight-main p {
  margin: 8px 0 0 !important;
  color: #64748b !important;
  font-size: 14px !important;
  line-height: 1.65 !important;
}

.tk-account-highlight-tags {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  margin-top: 18px !important;
}

.tk-account-highlight-tags span {
  height: 30px !important;
  display: inline-flex !important;
  align-items: center !important;
  padding: 0 12px !important;
  border-radius: 999px !important;
  background: #ffffff !important;
  border: 1px solid rgba(15,23,42,.06) !important;
  color: #334155 !important;
  font-size: 12px !important;
  font-weight: 800 !important;
}

.tk-account-steps {
  margin-top: 22px !important;
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 16px !important;
}

.tk-account-step {
  position: relative !important;
  min-height: 170px !important;
  padding: 22px 20px 20px !important;
  border-radius: 24px !important;
  background: rgba(255,255,255,.9) !important;
  border: 1px solid rgba(15, 23, 42, .06) !important;
  box-shadow: 0 14px 30px rgba(15,23,42,.04) !important;
}

.tk-account-step::before {
  content: "" !important;
  position: absolute !important;
  left: 20px !important;
  right: 20px !important;
  top: 0 !important;
  height: 4px !important;
  border-radius: 999px !important;
  background: linear-gradient(90deg, #22c55e 0%, #86efac 100%) !important;
}

.tk-account-step:nth-child(2)::before {
  background: linear-gradient(90deg, #3b82f6 0%, #93c5fd 100%) !important;
}

.tk-account-step:nth-child(3)::before {
  background: linear-gradient(90deg, #8b5cf6 0%, #c4b5fd 100%) !important;
}

.tk-account-step.accent {
  background: linear-gradient(180deg, #f5f3ff 0%, #ffffff 100%) !important;
}

.tk-account-step-no {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 42px !important;
  height: 42px !important;
  border-radius: 14px !important;
  background: #ecfdf3 !important;
  color: #07883f !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  margin-bottom: 16px !important;
}

.tk-account-step:nth-child(2) .tk-account-step-no {
  background: #eff6ff !important;
  color: #2563eb !important;
}

.tk-account-step:nth-child(3) .tk-account-step-no {
  background: #f5f3ff !important;
  color: #7c3aed !important;
}

.tk-account-step h3 {
  margin: 0 !important;
  color: #0f172a !important;
  font-size: 20px !important;
  line-height: 1.3 !important;
  font-weight: 900 !important;
}

.tk-account-step p {
  margin: 10px 0 0 !important;
  color: #64748b !important;
  font-size: 14px !important;
  line-height: 1.72 !important;
}

@media (max-width: 980px) {
  .tk-account-flow-wrap {
    padding: 22px !important;
    border-radius: 26px !important;
  }

  .tk-account-flow-head {
    grid-template-columns: 1fr !important;
  }

  .tk-account-steps {
    grid-template-columns: 1fr !important;
  }

  .tk-account-step {
    min-height: 0 !important;
  }
}

/* ===== TinyKits Account Highlight Remove 2026-05 ===== */
.tk-account-flow-head {
  display: block !important;
}

.tk-account-flow-copy {
  max-width: 860px !important;
  padding: 8px 6px 4px !important;
}

.tk-account-flow-copy h2 {
  max-width: none !important;
}

.tk-account-flow-copy p {
  max-width: 760px !important;
}

.tk-account-flow-highlight {
  display: none !important;
}

/* ===== TinyKits FAQ Section Up 2026-05 ===== */
#faq {
  padding-top: 18px !important;
}

.tk-account-flow-section + #faq,
.tk-account-section + #faq,
#account + #faq {
  margin-top: -18px !important;
}

/* ===== TinyKits FAQ QA Style 2026-05 ===== */
.tk-faq-section {
  padding-top: 18px !important;
  padding-bottom: 64px !important;
  background: transparent !important;
}

.tk-faq-layout {
  display: grid !important;
  grid-template-columns: minmax(260px, .8fr) minmax(0, 1.2fr) !important;
  gap: 42px !important;
  align-items: start !important;
}

.tk-faq-head {
  position: sticky !important;
  top: 96px !important;
}

.tk-faq-eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  height: 30px !important;
  padding: 0 12px !important;
  border-radius: 999px !important;
  background: #ecfdf3 !important;
  color: #07883f !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  margin-bottom: 16px !important;
}

.tk-faq-head h2 {
  margin: 0 !important;
  color: #0f172a !important;
  font-size: clamp(32px, 3vw, 46px) !important;
  line-height: 1.12 !important;
  letter-spacing: -.05em !important;
}

.tk-faq-head p {
  margin: 16px 0 0 !important;
  max-width: 360px !important;
  color: #64748b !important;
  font-size: 15px !important;
  line-height: 1.8 !important;
}

.tk-faq-list {
  border-top: 1px solid rgba(15, 23, 42, .10) !important;
}

.tk-faq-item {
  padding: 26px 0 !important;
  border-bottom: 1px solid rgba(15, 23, 42, .10) !important;
}

.tk-faq-item h3 {
  margin: 0 !important;
  color: #0f172a !important;
  font-size: 20px !important;
  line-height: 1.45 !important;
  font-weight: 900 !important;
  letter-spacing: -.01em !important;
}

.tk-faq-item p {
  margin: 12px 0 0 !important;
  color: #526173 !important;
  font-size: 15px !important;
  line-height: 1.85 !important;
}

@media (max-width: 900px) {
  .tk-faq-layout {
    grid-template-columns: 1fr !important;
    gap: 22px !important;
  }

  .tk-faq-head {
    position: static !important;
  }

  .tk-faq-head p {
    max-width: none !important;
  }

  .tk-faq-item {
    padding: 22px 0 !important;
  }
}

/* ===== TinyKits Scroll Reveal Motion 2026-05 ===== */
.tk-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition:
    opacity .72s cubic-bezier(.2, .8, .2, 1),
    transform .72s cubic-bezier(.2, .8, .2, 1);
  will-change: opacity, transform;
}

.tk-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.tk-reveal-soft {
  opacity: 0;
  transform: translateY(14px);
  transition:
    opacity .64s cubic-bezier(.2, .8, .2, 1),
    transform .64s cubic-bezier(.2, .8, .2, 1);
  will-change: opacity, transform;
}

.tk-reveal-soft.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.tk-reveal-scale {
  opacity: 0;
  transform: translateY(18px) scale(.985);
  transition:
    opacity .76s cubic-bezier(.2, .8, .2, 1),
    transform .76s cubic-bezier(.2, .8, .2, 1);
  will-change: opacity, transform;
}

.tk-reveal-scale.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}

/* 分组卡片做轻微错落 */
.tk-reveal-group > * {
  opacity: 0;
  transform: translateY(18px);
  transition:
    opacity .66s cubic-bezier(.2, .8, .2, 1),
    transform .66s cubic-bezier(.2, .8, .2, 1);
}

.tk-reveal-group.is-visible > * {
  opacity: 1;
  transform: translateY(0);
}

.tk-reveal-group.is-visible > *:nth-child(1) { transition-delay: .02s; }
.tk-reveal-group.is-visible > *:nth-child(2) { transition-delay: .08s; }
.tk-reveal-group.is-visible > *:nth-child(3) { transition-delay: .14s; }
.tk-reveal-group.is-visible > *:nth-child(4) { transition-delay: .20s; }
.tk-reveal-group.is-visible > *:nth-child(5) { transition-delay: .26s; }
.tk-reveal-group.is-visible > *:nth-child(6) { transition-delay: .32s; }

/* 二屏切换时，让当前 slide 内容更顺滑 */
.tk-tool-slide.active .tk-tool-slide-copy,
.tk-tool-slide.active .tk-tool-slide-visual {
  animation: tk-slide-in .52s cubic-bezier(.2, .8, .2, 1) both;
}

.tk-tool-slide.active .tk-tool-slide-visual {
  animation-delay: .06s;
}

@keyframes tk-slide-in {
  from {
    opacity: 0;
    transform: translateY(12px) scale(.992);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* hover 微动效：轻，不抢视觉 */
.tk-feature-card,
.tk-principle-card,
.tk-account-step,
.tk-capability-card,
.tk-faq-item {
  transition:
    transform .22s ease,
    box-shadow .22s ease,
    border-color .22s ease,
    background .22s ease;
}

.tk-feature-card:hover,
.tk-principle-card:hover,
.tk-account-step:hover,
.tk-capability-card:hover {
  transform: translateY(-3px);
}

/* FAQ 不做卡片浮起，只做轻微文字反馈 */
.tk-faq-item:hover h3 {
  color: #07883f !important;
}

/* 用户系统设置减少动态时，关闭动画 */
@media (prefers-reduced-motion: reduce) {
  .tk-reveal,
  .tk-reveal-soft,
  .tk-reveal-scale,
  .tk-reveal-group > *,
  .tk-tool-slide.active .tk-tool-slide-copy,
  .tk-tool-slide.active .tk-tool-slide-visual {
    opacity: 1 !important;
    transform: none !important;
    animation: none !important;
    transition: none !important;
  }
}

/* ===== TinyKits Footer Contact QR 2026-05 ===== */
.footer-contact-hover {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  cursor: default !important;
  color: inherit !important;
  font-size: inherit !important;
  line-height: inherit !important;
}

.footer-contact-qr {
  position: absolute !important;
  right: 0 !important;
  bottom: calc(100% + 14px) !important;
  width: 176px !important;
  padding: 12px !important;
  border-radius: 18px !important;
  background: #ffffff !important;
  border: 1px solid rgba(15, 23, 42, .08) !important;
  box-shadow: 0 18px 44px rgba(15, 23, 42, .14) !important;
  opacity: 0 !important;
  transform: translateY(8px) scale(.98) !important;
  pointer-events: none !important;
  transition: opacity .18s ease, transform .18s ease !important;
  z-index: 50 !important;
  text-align: center !important;
}

.footer-contact-qr::after {
  content: "" !important;
  position: absolute !important;
  right: 22px !important;
  bottom: -7px !important;
  width: 14px !important;
  height: 14px !important;
  background: #ffffff !important;
  border-right: 1px solid rgba(15, 23, 42, .08) !important;
  border-bottom: 1px solid rgba(15, 23, 42, .08) !important;
  transform: rotate(45deg) !important;
}

.footer-contact-qr img {
  display: block !important;
  width: 152px !important;
  height: 152px !important;
  object-fit: cover !important;
  border-radius: 12px !important;
  margin: 0 auto !important;
}

.footer-contact-qr b {
  display: block !important;
  margin-top: 8px !important;
  color: #0f172a !important;
  font-size: 13px !important;
  line-height: 1.2 !important;
  font-weight: 900 !important;
}

.footer-contact-hover:hover .footer-contact-qr {
  opacity: 1 !important;
  transform: translateY(0) scale(1) !important;
  pointer-events: auto !important;
}

.footer-links,
.tk-home-footer nav {
  overflow: visible !important;
}

@media (max-width: 768px) {
  .footer-contact-qr {
    right: 50% !important;
    transform: translate(50%, 8px) scale(.98) !important;
  }

  .footer-contact-hover:hover .footer-contact-qr {
    transform: translate(50%, 0) scale(1) !important;
  }
}

/* ===== TinyKits Login Benefit List 2026-05 ===== */
.tk-brand-login-points li {
  align-items: flex-start !important;
  flex-direction: column !important;
  gap: 4px !important;
  line-height: 1.45 !important;
}

.tk-brand-login-points li strong {
  display: block !important;
  color: #0f172a !important;
  font-size: 14px !important;
  font-weight: 900 !important;
}

.tk-brand-login-points li span {
  display: block !important;
  color: #526173 !important;
  font-size: 13px !important;
  line-height: 1.55 !important;
  font-weight: 500 !important;
}

/* ===== TinyKits Scene Card Icon 120px 2026-05 ===== */
#scenes .tk-feature-card img {
  width: 120px !important;
  height: 120px !important;
  object-fit: contain !important;
  margin-bottom: 16px !important;
}

#scenes .tk-feature-card {
  padding-top: 28px !important;
}

/* ===== TinyKits Login Terms Tip 2026-05 ===== */
.tk-brand-login-terms {
  margin: 8px 0 0 !important;
  text-align: center !important;
  color: #94a3b8 !important;
  font-size: 12px !important;
  line-height: 1.6 !important;
}

.tk-brand-login-terms a {
  color: #07883f !important;
  font-weight: 800 !important;
  text-decoration: none !important;
}

.tk-brand-login-terms a:hover {
  text-decoration: underline !important;
}

/* ================================
   Web Image Compressor Landing Page
   ================================ */

.tk-tool-page {
  background:
    radial-gradient(circle at 10% 2%, rgba(10, 163, 82, .09), transparent 28%),
    radial-gradient(circle at 88% 0%, rgba(41, 121, 255, .07), transparent 25%),
    linear-gradient(180deg, #fff 0%, #f7faf8 46%, #fff 100%);
}

.tk-tool-hero {
  padding: 84px 0 62px;
  overflow: hidden;
  position: relative;
}

.tk-tool-hero::before {
  content: "";
  position: absolute;
  width: 720px;
  height: 720px;
  right: -260px;
  top: -120px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(10, 163, 82, .12), transparent 62%);
  pointer-events: none;
}

.tk-tool-hero-inner {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, .86fr) minmax(460px, 1.14fr);
  gap: 58px;
  align-items: center;
}

.tk-tool-eyebrow {
  margin: 0 0 16px;
  color: var(--green);
  font-size: 18px;
  font-weight: 900;
  letter-spacing: -.02em;
}

.tk-tool-hero h1 {
  margin: 0 0 22px;
  max-width: 680px;
  font-size: clamp(38px, 4.8vw, 64px);
  line-height: 1.07;
  letter-spacing: -.068em;
  color: #102017;
}

.tk-tool-hero-desc {
  max-width: 680px;
  margin: 0;
  color: var(--muted);
  font-size: 19px;
  line-height: 1.9;
}

.tk-tool-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 34px;
}

.tk-tool-trust-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 24px;
}

.tk-tool-trust-row span {
  padding: 9px 12px;
  border: 1px solid rgba(10, 163, 82, .13);
  border-radius: 999px;
  background: rgba(255, 255, 255, .72);
  color: #50625a;
  font-size: 13px;
  font-weight: 800;
}

.tk-tool-hero-visual {
  padding: 0;
  border-radius: 34px;
  filter: drop-shadow(0 28px 80px rgba(15, 23, 42, .10));
}

.tk-tool-hero-visual img {
  width: 100%;
  border-radius: 30px;
  display: block;
}

.tk-tool-section {
  padding: 78px 0;
}

.tk-tool-section-title {
  max-width: 760px;
  margin: 0 auto 38px;
  text-align: center;
}

.tk-tool-section-title .kicker {
  margin: 0 0 8px;
  color: var(--green);
  font-weight: 900;
  letter-spacing: -.02em;
}

.tk-tool-section-title h2 {
  margin: 0 0 14px;
  font-size: clamp(30px, 4vw, 46px);
  line-height: 1.16;
  letter-spacing: -.06em;
  color: #102017;
}

.tk-tool-section-title p {
  margin: 0;
  color: var(--muted);
  font-size: 17px;
  line-height: 1.8;
}

.tk-tool-feature-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 18px;
}

.tk-tool-feature-card,
.tk-tool-compare-card,
.tk-tool-flow-card,
.tk-tool-report-copy,
.tk-tool-scenario-card,
.tk-tool-faq-card,
.tk-tool-quote-card {
  background: rgba(255, 255, 255, .92);
  border: 1px solid rgba(16, 32, 23, .09);
  border-radius: 28px;
  box-shadow: 0 14px 44px rgba(16, 32, 23, .06);
}

.tk-tool-feature-card {
  min-height: 220px;
  padding: 24px;
}

.tk-tool-feature-icon {
  width: 58px;
  height: 58px;
  display: grid;
  place-items: center;
  margin-bottom: 18px;
  border-radius: 20px;
  background: #eaf8ef;
}

.tk-tool-feature-icon img {
  width: 36px;
  height: 36px;
}

.tk-tool-feature-card h3 {
  margin: 0 0 10px;
  font-size: 19px;
  line-height: 1.25;
  letter-spacing: -.04em;
  color: #102017;
}

.tk-tool-feature-card p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.7;
}

.tk-tool-compare-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}

.tk-tool-compare-card {
  padding: 30px;
  min-height: 280px;
}

.tk-tool-compare-card.before {
  background: linear-gradient(180deg, #fff, #fff8f5);
}

.tk-tool-compare-card.after {
  background: linear-gradient(180deg, #fff, #effaf4);
}

.tk-tool-compare-card h3 {
  margin: 0 0 18px;
  font-size: 26px;
  letter-spacing: -.05em;
}

.tk-tool-timeline {
  display: grid;
  gap: 12px;
}

.tk-tool-timeline div {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px;
  border: 1px solid rgba(15, 23, 42, .06);
  border-radius: 18px;
  background: #fff;
}

.tk-tool-timeline i {
  flex: 0 0 28px;
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  color: #fff;
  font-style: normal;
  font-size: 12px;
  font-weight: 900;
  background: #98a2b3;
}

.tk-tool-compare-card.after .tk-tool-timeline i {
  background: var(--green);
}

.tk-tool-timeline p {
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
}

.tk-tool-flow-wrap {
  padding: 28px;
  border: 1px solid rgba(16, 32, 23, .09);
  border-radius: 34px;
  background: linear-gradient(180deg, #fff, #f8fbf9);
  box-shadow: 0 24px 70px rgba(16, 32, 23, .08);
}

.tk-tool-flow-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.tk-tool-flow-card {
  padding: 24px;
}

.tk-tool-flow-card figure {
  margin: 0 0 16px;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(15, 23, 42, .06);
  background: #fff;
}

.tk-tool-flow-card figure img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  object-position: center;
}

.tk-tool-flow-card b {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  margin-bottom: 14px;
  border-radius: 999px;
  color: #fff;
  background: linear-gradient(135deg, var(--green), #087f41);
}

.tk-tool-flow-card strong {
  display: block;
  margin-bottom: 8px;
  font-size: 18px;
  letter-spacing: -.03em;
}

.tk-tool-flow-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.7;
  font-size: 15px;
}

.tk-tool-report-section {
  padding: 78px 0;
}

.tk-tool-report-grid {
  display: grid;
  grid-template-columns: .86fr 1.14fr;
  gap: 28px;
  align-items: center;
}

.tk-tool-report-copy {
  padding: 34px;
  background: linear-gradient(135deg, #effaf4, #fff 74%);
}

.tk-tool-report-copy h2 {
  margin: 0 0 14px;
  font-size: clamp(30px, 4vw, 46px);
  line-height: 1.16;
  letter-spacing: -.06em;
}

.tk-tool-report-copy p {
  margin: 0;
  color: var(--muted);
  line-height: 1.82;
  font-size: 16px;
}

.tk-tool-report-list {
  display: grid;
  gap: 14px;
  margin-top: 20px;
}

.tk-tool-report-item {
  display: grid;
  grid-template-columns: 46px 1fr;
  gap: 14px;
  padding: 14px;
  border-radius: 18px;
  background: #fff;
  border: 1px solid rgba(15, 23, 42, .07);
}

.tk-tool-report-item span {
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  border-radius: 17px;
  background: #eaf8ef;
  font-size: 22px;
}

.tk-tool-report-item strong {
  display: block;
  margin-bottom: 4px;
  font-size: 16px;
}

.tk-tool-report-item p {
  font-size: 14px;
  line-height: 1.6;
}

.tk-tool-report-image {
  border-radius: 28px;
  overflow: hidden;
  filter: drop-shadow(0 28px 80px rgba(15, 23, 42, .10));
}

.tk-tool-report-image img {
  width: 100%;
  border-radius: 28px;
  display: block;
}

.tk-tool-scenario-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.tk-tool-scenario-card {
  padding: 26px;
  min-height: 190px;
}

.tk-tool-scenario-card span {
  width: 48px;
  height: 48px;
  display: inline-grid;
  place-items: center;
  margin-bottom: 18px;
  border-radius: 18px;
  background: #eaf8ef;
  font-size: 24px;
}

.tk-tool-scenario-card strong {
  display: block;
  margin-bottom: 8px;
  font-size: 19px;
}

.tk-tool-scenario-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.72;
}

.tk-tool-quote-card {
  padding: 34px;
  background: linear-gradient(180deg, #fff, #f8fbf9);
}

.tk-tool-quote-card p {
  margin: 0;
  color: #31413a;
  font-size: 18px;
  line-height: 1.9;
}

.tk-tool-quote-card strong {
  display: block;
  margin-top: 16px;
  color: var(--green);
  font-size: 14px;
}

.tk-tool-faq-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
}

.tk-tool-faq-card {
  padding: 24px;
}

.tk-tool-faq-card strong {
  display: block;
  margin-bottom: 8px;
  font-size: 18px;
}

.tk-tool-faq-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.72;
}

.tk-tool-final-cta {
  padding: 72px 0 88px;
}

.tk-tool-cta-box {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 28px;
  padding: 46px 54px;
  border: 1px solid #d8eee2;
  border-radius: 36px;
  background:
    radial-gradient(circle at 12% 12%, rgba(10, 163, 82, .16), transparent 30%),
    linear-gradient(135deg, #effaf4, #fff 70%);
  box-shadow: 0 24px 70px rgba(16, 32, 23, .08);
}

.tk-tool-cta-box h2 {
  margin: 0 0 12px;
  font-size: clamp(30px, 4vw, 46px);
  line-height: 1.16;
  letter-spacing: -.06em;
}

.tk-tool-cta-box p {
  margin: 0;
  max-width: 720px;
  color: #5b6862;
  line-height: 1.8;
}

@media (max-width: 1180px) {
  .tk-tool-feature-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 1050px) {
  .tk-tool-hero-inner,
  .tk-tool-report-grid,
  .tk-tool-compare-grid,
  .tk-tool-cta-box {
    grid-template-columns: 1fr;
  }

  .tk-tool-flow-grid,
  .tk-tool-scenario-grid,
  .tk-tool-faq-grid {
    grid-template-columns: 1fr;
  }

  .tk-tool-feature-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 780px) {
  .tk-tool-hero {
    padding: 56px 0 36px;
  }

  .tk-tool-hero h1 {
    font-size: 40px;
  }

  .tk-tool-hero-desc {
    font-size: 16px;
  }

  .tk-tool-actions .btn {
    width: 100%;
  }

  .tk-tool-feature-grid {
    grid-template-columns: 1fr;
  }

  .tk-tool-compare-card,
  .tk-tool-flow-wrap,
  .tk-tool-report-copy,
  .tk-tool-quote-card,
  .tk-tool-cta-box {
    padding: 24px;
  }

  .tk-tool-final-cta {
    padding: 48px 0 64px;
  }
}

/* === compressor hero stack tweak start === */
.tk-tool-hero {
  padding: 72px 0 32px;
}

.tk-tool-hero-inner {
  grid-template-columns: 1fr;
  gap: 18px;
  align-items: start;
  justify-items: center;
  text-align: center;
}

.tk-tool-eyebrow {
  text-align: center;
}

.tk-tool-hero h1 {
  max-width: 860px;
  margin: 0 auto 18px;
  font-size: clamp(32px, 4.1vw, 58px);
  line-height: 1.08;
  letter-spacing: -0.025em;
}

.tk-tool-hero-desc {
  max-width: 980px;
  margin-left: auto;
  margin-right: auto;
}

.tk-tool-actions {
  margin-top: 24px;
  justify-content: center;
}

.tk-tool-hero-visual {
  position: relative;
  width: min(100%, 1060px);
  margin: -8px auto 0;
}

.tk-tool-hero-visual img {
  width: 100%;
  border-radius: 30px;
  display: block;
}

.tk-tool-hero-pills {
  position: static;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 18px;
  pointer-events: auto;
}

.tk-tool-hero-pills span {
  position: static;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 10px 16px;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0;
  white-space: nowrap;
  box-shadow: 0 10px 22px rgba(16, 32, 23, .08);
}

.tk-tool-hero-pills span:nth-child(1) {
  background: #eef8f1;
  border: 1px solid rgba(10, 163, 82, .18);
  color: #1d4e36;
}

.tk-tool-hero-pills span:nth-child(2) {
  background: #0aa352;
  border: 1px solid rgba(10, 163, 82, .3);
  color: #fff;
}

.tk-tool-hero-pills span:nth-child(3) {
  background: #f4f8f5;
  border: 1px solid rgba(10, 163, 82, .16);
  color: #204533;
}

@media (max-width: 780px) {
  .tk-tool-hero {
    padding: 52px 0 28px;
  }

  .tk-tool-hero h1 {
    font-size: 38px;
    letter-spacing: -0.015em;
  }

  .tk-tool-hero-desc {
    font-size: 16px;
  }

  .tk-tool-hero-visual {
    margin-top: 0;
  }

  .tk-tool-hero-pills {
    gap: 8px;
    margin-top: 14px;
  }

  .tk-tool-hero-pills span {
    min-height: 40px;
    padding: 9px 12px;
    font-size: 12px;
    white-space: normal;
  }
}
/* === compressor hero stack tweak end === */

/* === compressor flow image zoom start === */
.tk-tool-flow-card figure {
  height: 280px;
  background: #f8fbf9;
}

.tk-tool-flow-card figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.42);
  transition: transform .2s ease;
}

/* 第 1 步：突出质量设置与开始压缩按钮 */
.tk-tool-flow-card:nth-child(1) figure img {
  object-position: 72% 50%;
  transform-origin: 72% 50%;
}

/* 第 2 步：突出处理中卡片和进度条 */
.tk-tool-flow-card:nth-child(2) figure img {
  object-position: 76% 52%;
  transform-origin: 76% 52%;
}

/* 第 3 步：突出统计结果和打包导出 */
.tk-tool-flow-card:nth-child(3) figure img {
  object-position: 78% 52%;
  transform-origin: 78% 52%;
}

@media (max-width: 1050px) {
  .tk-tool-flow-card figure {
    height: 360px;
  }

  .tk-tool-flow-card figure img {
    transform: scale(1.22);
  }
}

@media (max-width: 780px) {
  .tk-tool-flow-card figure {
    height: 260px;
  }

  .tk-tool-flow-card figure img {
    transform: scale(1.34);
  }
}
/* === compressor flow image zoom end === */

/* === compressor report stack start === */
.tk-tool-report-stack {
  display: block;
}

.tk-tool-report-stack .tk-tool-report-copy {
  max-width: 1040px;
  margin: 0 auto;
}

.tk-tool-report-stack .tk-tool-report-copy > h2,
.tk-tool-report-stack .tk-tool-report-copy > p {
  max-width: 760px;
}

.tk-tool-report-stack .tk-tool-report-image {
  margin: 28px 0 26px;
  border-radius: 28px;
}

.tk-tool-report-stack .tk-tool-report-image img {
  width: 100%;
  border-radius: 28px;
}

.tk-tool-report-stack .tk-tool-report-list {
  grid-template-columns: repeat(3, 1fr);
  align-items: stretch;
}

.tk-tool-report-stack .tk-tool-report-item {
  align-content: start;
}

@media (max-width: 1050px) {
  .tk-tool-report-stack .tk-tool-report-list {
    grid-template-columns: 1fr;
  }
}
/* === compressor report stack end === */

/* === compressor report width center start === */
.tk-tool-report-stack .tk-tool-report-copy {
  max-width: 1120px;
  width: 100%;
  margin: 0 auto;
}

.tk-tool-report-stack .tk-tool-report-copy > h2,
.tk-tool-report-stack .tk-tool-report-copy > p {
  max-width: 780px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.tk-tool-report-stack .tk-tool-report-copy > h2 {
  margin-bottom: 14px;
}

.tk-tool-report-stack .tk-tool-report-image {
  max-width: 1040px;
  margin-left: auto;
  margin-right: auto;
}

.tk-tool-report-stack .tk-tool-report-list {
  max-width: 1040px;
  margin-left: auto;
  margin-right: auto;
}
/* === compressor report width center end === */

/* === compressor report gap and width final tweak start === */

/* 缩小“真实流程”与“压缩报告”之间的空白 */
#workflow.tk-tool-section {
  padding-bottom: 32px;
}

.tk-tool-report-section {
  padding-top: 26px;
}

/* 报告区卡片拉满到和其他大区块接近的宽度 */
.tk-tool-report-stack .tk-tool-report-copy {
  width: 100%;
  max-width: none;
  margin-left: auto;
  margin-right: auto;
  padding: 42px 44px;
}

/* 标题和说明继续居中，但不要限制整个卡片宽度 */
.tk-tool-report-stack .tk-tool-report-copy > h2,
.tk-tool-report-stack .tk-tool-report-copy > p {
  max-width: 780px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

/* 报告图片和下方说明卡片也跟着放宽 */
.tk-tool-report-stack .tk-tool-report-image,
.tk-tool-report-stack .tk-tool-report-list {
  max-width: 1080px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

.tk-tool-report-stack .tk-tool-report-image {
  margin-top: 28px;
  margin-bottom: 26px;
}

/* === compressor report gap and width final tweak end === */\n\n/* === compressor testimonials start === */
.tk-tool-testimonials-section {
  padding-top: 42px;
}

.tk-tool-testimonial-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

.tk-tool-testimonial-card {
  position: relative;
  min-height: 260px;
  padding: 30px;
  border: 1px solid rgba(16, 32, 23, .09);
  border-radius: 28px;
  background:
    radial-gradient(circle at 12% 12%, rgba(10, 163, 82, .10), transparent 34%),
    rgba(255, 255, 255, .94);
  box-shadow: 0 14px 44px rgba(16, 32, 23, .06);
}

.tk-tool-testimonial-card::before {
  content: "“";
  position: absolute;
  right: 26px;
  top: 8px;
  color: rgba(10, 163, 82, .13);
  font-size: 88px;
  font-weight: 900;
  line-height: 1;
}

.tk-tool-testimonial-card p {
  position: relative;
  z-index: 1;
  margin: 0;
  color: #31413a;
  font-size: 16px;
  line-height: 1.9;
}

.tk-tool-testimonial-card div {
  position: relative;
  z-index: 1;
  margin-top: 24px;
  padding-top: 18px;
  border-top: 1px solid rgba(16, 32, 23, .08);
}

.tk-tool-testimonial-card strong {
  display: block;
  margin-bottom: 4px;
  color: #102017;
  font-size: 16px;
}

.tk-tool-testimonial-card span {
  color: #6b7c74;
  font-size: 14px;
}

@media (max-width: 1050px) {
  .tk-tool-testimonial-grid {
    grid-template-columns: 1fr;
  }

  .tk-tool-testimonial-card {
    min-height: auto;
  }
}
/* === compressor testimonials end === */\n
/* === compressor interaction motion start === */

/* 初始进入动画 */
.tk-tool-page .tk-tool-hero h1,
.tk-tool-page .tk-tool-eyebrow,
.tk-tool-page .tk-tool-hero-desc,
.tk-tool-page .tk-tool-actions,
.tk-tool-page .tk-tool-hero-pills,
.tk-tool-page .tk-tool-hero-visual {
  animation: tkToolFadeUp .72s ease both;
}

.tk-tool-page .tk-tool-eyebrow { animation-delay: .02s; }
.tk-tool-page .tk-tool-hero h1 { animation-delay: .08s; }
.tk-tool-page .tk-tool-hero-desc { animation-delay: .14s; }
.tk-tool-page .tk-tool-actions { animation-delay: .20s; }
.tk-tool-page .tk-tool-hero-visual { animation-delay: .26s; }
.tk-tool-page .tk-tool-hero-pills { animation-delay: .32s; }

@keyframes tkToolFadeUp {
  from {
    opacity: 0;
    transform: translateY(18px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.tk-tool-hero-visual {
  animation: tkToolHeroFloat 5.8s ease-in-out infinite;
}

@keyframes tkToolHeroFloat {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-8px);
  }
}

/* 滚动进入视口动画 */
.tk-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition:
    opacity .72s ease,
    transform .72s ease;
}

.tk-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* 卡片 hover 动态 */
.tk-tool-feature-card,
.tk-tool-compare-card,
.tk-tool-flow-card,
.tk-tool-scenario-card,
.tk-tool-faq-card,
.tk-tool-testimonial-card,
.tk-tool-report-item,
.tk-tool-quote-card {
  transition:
    transform .22s ease,
    box-shadow .22s ease,
    border-color .22s ease,
    background .22s ease;
}

.tk-tool-feature-card:hover,
.tk-tool-compare-card:hover,
.tk-tool-flow-card:hover,
.tk-tool-scenario-card:hover,
.tk-tool-faq-card:hover,
.tk-tool-testimonial-card:hover,
.tk-tool-report-item:hover,
.tk-tool-quote-card:hover {
  transform: translateY(-5px);
  border-color: rgba(10, 163, 82, .22);
  box-shadow: 0 20px 58px rgba(16, 32, 23, .10);
}

/* 三步流程图片 hover 放大一点 */
.tk-tool-flow-card figure img,
.tk-tool-report-image img,
.tk-tool-hero-visual img {
  transition:
    transform .35s ease,
    filter .35s ease;
}

.tk-tool-flow-card:hover figure img {
  transform: scale(1.04);
}

.tk-tool-report-image:hover img {
  transform: scale(1.015);
}

/* 小胶囊 hover */
.tk-tool-hero-pills span {
  transition:
    transform .2s ease,
    box-shadow .2s ease,
    border-color .2s ease;
}

.tk-tool-hero-pills span:hover {
  transform: translateY(-3px);
  border-color: rgba(10, 163, 82, .32);
  box-shadow: 0 16px 34px rgba(16, 32, 23, .12);
}

/* CTA 呼吸光 */
.tk-tool-page .btn-primary,
.tk-tool-page .tk-nav-cta {
  position: relative;
  overflow: hidden;
}

.tk-tool-page .btn-primary::after,
.tk-tool-page .tk-nav-cta::after {
  content: "";
  position: absolute;
  top: -40%;
  bottom: -40%;
  width: 42px;
  left: -70px;
  transform: rotate(18deg);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.48), transparent);
  animation: tkToolButtonShine 3.6s ease-in-out infinite;
}

@keyframes tkToolButtonShine {
  0% {
    left: -70px;
  }
  48%, 100% {
    left: calc(100% + 70px);
  }
}

/* 用户评价卡片更有反馈感 */
.tk-tool-testimonial-card:hover::before {
  color: rgba(10, 163, 82, .22);
}

/* 减少动画偏好适配 */
@media (prefers-reduced-motion: reduce) {
  .tk-tool-page *,
  .tk-tool-page *::before,
  .tk-tool-page *::after {
    animation: none !important;
    transition: none !important;
  }

  .tk-reveal {
    opacity: 1;
    transform: none;
  }
}

/* === compressor interaction motion end === */

/* === compressor seo intent section start === */
.tk-tool-seo-intent-section {
  padding-top: 38px;
  padding-bottom: 58px;
}

.tk-tool-seo-intent-card {
  padding: 42px 46px;
  border: 1px solid rgba(16, 32, 23, .09);
  border-radius: 34px;
  background:
    radial-gradient(circle at 12% 12%, rgba(10, 163, 82, .12), transparent 32%),
    linear-gradient(135deg, #f2fbf5, #fff 72%);
  box-shadow: 0 24px 70px rgba(16, 32, 23, .08);
}

.tk-tool-seo-intent-card .tk-tool-section-title {
  margin-bottom: 22px;
}

.tk-tool-seo-intent-body {
  max-width: 860px;
  margin: 0 auto;
  text-align: center;
}

.tk-tool-seo-intent-body p {
  margin: 0;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.9;
}

.tk-tool-seo-keywords {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin-top: 22px;
}

.tk-tool-seo-keywords span {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 14px;
  border: 1px solid rgba(10, 163, 82, .16);
  border-radius: 999px;
  background: rgba(255, 255, 255, .84);
  color: #315a43;
  font-size: 13px;
  font-weight: 800;
}

@media (max-width: 780px) {
  .tk-tool-seo-intent-card {
    padding: 28px 22px;
    border-radius: 26px;
  }
}
/* === compressor seo intent section end === */

/* Page Feedback Helper report highlight */
.tk-tool-report-highlight {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.25fr);
  gap: 36px;
  align-items: center;
  padding: 42px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 28px;
  background:
    radial-gradient(circle at 12% 10%, rgba(0, 153, 87, 0.08), transparent 34%),
    linear-gradient(135deg, #ffffff 0%, #f7fbf8 100%);
  box-shadow: 0 24px 70px rgba(15, 23, 42, 0.08);
  overflow: hidden;
}

.tk-tool-report-highlight .kicker {
  margin: 0 0 12px;
  color: #0f8f55;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.tk-tool-report-highlight h2 {
  margin: 0 0 16px;
  color: #0f172a;
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.15;
  letter-spacing: -0.04em;
}

.tk-tool-report-highlight p {
  margin: 0 0 18px;
  color: #526070;
  font-size: 16px;
  line-height: 1.85;
}

.tk-tool-report-highlight ul {
  display: grid;
  gap: 10px;
  margin: 22px 0 0;
  padding: 0;
  list-style: none;
}

.tk-tool-report-highlight li {
  position: relative;
  padding-left: 28px;
  color: #273244;
  font-size: 15px;
  line-height: 1.7;
}

.tk-tool-report-highlight li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 9px;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #079455;
  box-shadow: 0 0 0 5px rgba(7, 148, 85, 0.12);
}

.tk-tool-report-highlight img {
  display: block;
  width: 100%;
  max-height: 520px;
  object-fit: contain;
  border-radius: 22px;
  background: #fff;
  box-shadow: 0 18px 50px rgba(15, 23, 42, 0.12);
}

@media (max-width: 900px) {
  .tk-tool-report-highlight {
    grid-template-columns: 1fr;
    padding: 26px;
    gap: 24px;
  }

  .tk-tool-report-highlight img {
    max-height: none;
  }
}


/* Page Feedback Helper use cases */
.tk-tool-usecase-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 34px;
}

.tk-tool-usecase-grid article {
  position: relative;
  padding: 26px 24px 24px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 24px;
  background:
    radial-gradient(circle at 14% 10%, rgba(0, 153, 87, 0.08), transparent 34%),
    #ffffff;
  box-shadow: 0 18px 46px rgba(15, 23, 42, 0.06);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.tk-tool-usecase-grid article:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 60px rgba(15, 23, 42, 0.1);
}

.tk-tool-usecase-grid span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  margin-bottom: 18px;
  border-radius: 16px;
  background: rgba(7, 148, 85, 0.1);
  font-size: 22px;
}

.tk-tool-usecase-grid h3 {
  margin: 0 0 10px;
  color: #0f172a;
  font-size: 19px;
  line-height: 1.35;
  letter-spacing: -0.02em;
}

.tk-tool-usecase-grid p {
  margin: 0;
  color: #526070;
  font-size: 15px;
  line-height: 1.75;
}

@media (max-width: 980px) {
  .tk-tool-usecase-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .tk-tool-usecase-grid {
    grid-template-columns: 1fr;
  }
}


/* Page Feedback Helper workflow: 4 steps as 2x2 */
.tk-tool-flow-grid:has(.tk-tool-flow-card:nth-child(4)) {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 26px !important;
  align-items: stretch !important;
}

.tk-tool-flow-grid:has(.tk-tool-flow-card:nth-child(4)) .tk-tool-flow-card {
  height: 100% !important;
  min-height: 520px;
  display: flex !important;
  flex-direction: column !important;
}

.tk-tool-flow-grid:has(.tk-tool-flow-card:nth-child(4)) .tk-tool-flow-card figure {
  height: 300px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  border-radius: 22px !important;
  background: #f7fbf8 !important;
}

.tk-tool-flow-grid:has(.tk-tool-flow-card:nth-child(4)) .tk-tool-flow-card figure img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
}

.tk-tool-flow-grid:has(.tk-tool-flow-card:nth-child(4)) .tk-tool-flow-card strong {
  min-height: 32px;
}

.tk-tool-flow-grid:has(.tk-tool-flow-card:nth-child(4)) .tk-tool-flow-card p {
  margin-bottom: 0 !important;
}

@media (max-width: 760px) {
  .tk-tool-flow-grid:has(.tk-tool-flow-card:nth-child(4)) {
    grid-template-columns: 1fr !important;
  }

  .tk-tool-flow-grid:has(.tk-tool-flow-card:nth-child(4)) .tk-tool-flow-card {
    min-height: auto;
  }

  .tk-tool-flow-grid:has(.tk-tool-flow-card:nth-child(4)) .tk-tool-flow-card figure {
    height: auto !important;
  }
}


/* Page Feedback Helper workflow: desktop 4 columns */
.tk-tool-flow-grid:has(.tk-tool-flow-card:nth-child(4)) {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 20px !important;
  align-items: stretch !important;
}

.tk-tool-flow-grid:has(.tk-tool-flow-card:nth-child(4)) .tk-tool-flow-card {
  height: 100% !important;
  min-height: 0 !important;
  display: flex !important;
  flex-direction: column !important;
}

.tk-tool-flow-grid:has(.tk-tool-flow-card:nth-child(4)) .tk-tool-flow-card figure {
  height: 190px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  border-radius: 20px !important;
  background: #f7fbf8 !important;
  margin-bottom: 18px !important;
}

.tk-tool-flow-grid:has(.tk-tool-flow-card:nth-child(4)) .tk-tool-flow-card figure img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
}

.tk-tool-flow-grid:has(.tk-tool-flow-card:nth-child(4)) .tk-tool-flow-card b {
  margin-bottom: 8px !important;
}

.tk-tool-flow-grid:has(.tk-tool-flow-card:nth-child(4)) .tk-tool-flow-card strong {
  display: block !important;
  min-height: 44px !important;
  margin-bottom: 10px !important;
  font-size: 18px !important;
  line-height: 1.4 !important;
}

.tk-tool-flow-grid:has(.tk-tool-flow-card:nth-child(4)) .tk-tool-flow-card p {
  margin: 0 !important;
  font-size: 14px !important;
  line-height: 1.72 !important;
}

@media (max-width: 1200px) {
  .tk-tool-flow-grid:has(.tk-tool-flow-card:nth-child(4)) {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .tk-tool-flow-grid:has(.tk-tool-flow-card:nth-child(4)) .tk-tool-flow-card figure {
    height: 240px !important;
  }
}

@media (max-width: 760px) {
  .tk-tool-flow-grid:has(.tk-tool-flow-card:nth-child(4)) {
    grid-template-columns: 1fr !important;
  }

  .tk-tool-flow-grid:has(.tk-tool-flow-card:nth-child(4)) .tk-tool-flow-card figure {
    height: auto !important;
  }
}


/* Page Feedback Helper report highlight: vertical layout */
.tk-tool-report-highlight {
  display: block !important;
  padding: 42px !important;
  text-align: center !important;
}

.tk-tool-report-highlight > div {
  max-width: 820px !important;
  margin: 0 auto 30px !important;
}

.tk-tool-report-highlight .kicker {
  text-align: center !important;
}

.tk-tool-report-highlight h2 {
  max-width: 820px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.tk-tool-report-highlight p {
  max-width: 760px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.tk-tool-report-highlight ul {
  max-width: 760px !important;
  margin: 22px auto 0 !important;
  text-align: left !important;
}

.tk-tool-report-highlight img {
  width: 100% !important;
  max-width: 980px !important;
  max-height: none !important;
  margin: 0 auto !important;
  object-fit: contain !important;
}

@media (max-width: 760px) {
  .tk-tool-report-highlight {
    padding: 26px !important;
    text-align: left !important;
  }

  .tk-tool-report-highlight .kicker,
  .tk-tool-report-highlight h2,
  .tk-tool-report-highlight p {
    text-align: left !important;
  }

  .tk-tool-report-highlight > div {
    margin-bottom: 22px !important;
  }
}


/* Page Feedback Helper report section - compressor style */
.tk-feedback-report-section {
  overflow: hidden;
}

.tk-feedback-report-showcase {
  margin-top: 34px;
}

.tk-feedback-report-showcase > img {
  display: block;
  width: min(100%, 1080px);
  margin: 0 auto;
  border-radius: 28px;
  background: #ffffff;
  box-shadow: 0 24px 70px rgba(15, 23, 42, 0.12);
}

.tk-feedback-report-points {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 28px;
}

.tk-feedback-report-points article {
  padding: 24px 24px 22px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 22px;
  background:
    radial-gradient(circle at 12% 10%, rgba(7, 148, 85, 0.08), transparent 34%),
    #ffffff;
  box-shadow: 0 16px 42px rgba(15, 23, 42, 0.06);
}

.tk-feedback-report-points h3 {
  margin: 0 0 10px;
  color: #0f172a;
  font-size: 18px;
  line-height: 1.35;
  letter-spacing: -0.02em;
}

.tk-feedback-report-points p {
  margin: 0;
  color: #526070;
  font-size: 15px;
  line-height: 1.75;
}

@media (max-width: 900px) {
  .tk-feedback-report-points {
    grid-template-columns: 1fr;
  }

  .tk-feedback-report-showcase > img {
    border-radius: 20px;
  }
}

