/*
Theme Name: TelSearch Lite
Theme URI: https://telnum-search.com/
Author: TelSearch
Description: Minimal fast theme for TelSearch (with sidebar).
Version: 1.5.0
Text Domain: telsearch-lite
*/

:root{
  --ts-primary:#1ea7c6;
  --ts-primary-strong:#1489a3;
  --ts-primary-deep:#0d5f74;
  --ts-primary-soft:#e9f7fb;
  --ts-bg:#f5f8fb;
  --ts-surface:#ffffff;
  --ts-border:#dce3ea;
  --ts-text:#142130;
  --ts-muted:#5b6878;
  --ts-radius:14px;
  --ts-shadow:0 1px 10px rgba(16, 31, 48, .06);
  --ts-container:1120px;
  --ts-sidebar:336px;

  --ts-cat-landline:#45ab6b;
  --ts-cat-freedial:#e1b83c;
  --ts-cat-ip:#d66a8d;
  --ts-cat-mobile:#8f6bcf;
  --ts-cat-overseas:#9b6a49;
}

*{ box-sizing:border-box; }
html, body{ height:100%; }
.material-symbols-rounded{
  font-family:'Material Symbols Rounded';
  font-weight:normal;
  font-style:normal;
  font-size:1.05em;
  line-height:1;
  display:inline-flex;
  vertical-align:middle;
  letter-spacing:normal;
  text-transform:none;
  white-space:nowrap;
  word-wrap:normal;
  direction:ltr;
  -webkit-font-feature-settings:'liga';
  font-feature-settings:'liga';
  -webkit-font-smoothing:antialiased;
}
body{
  margin:0;
  color:var(--ts-text);
  background:linear-gradient(180deg, #f8fcff 0%, var(--ts-bg) 250px, var(--ts-bg) 100%);
  font-family:"Hiragino Kaku Gothic ProN", "Yu Gothic", "Meiryo", sans-serif;
  line-height:1.7;
  font-size:16px;
}

a{
  color:var(--ts-primary-strong);
  text-decoration:underline;
  text-underline-offset:2px;
  text-decoration-thickness:1px;
}
a:hover{ text-decoration-thickness:2px; }
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
summary:focus-visible{
  outline:3px solid rgba(30, 167, 198, .35);
  outline-offset:2px;
}

img{ max-width:100%; height:auto; }

.ts-container{
  max-width:var(--ts-container);
  margin:0 auto;
  padding:0 16px;
}

.ts-header{
  position:sticky;
  top:0;
  z-index:20;
  border-bottom:1px solid var(--ts-border);
  background:rgba(255, 255, 255, .94);
  backdrop-filter:blur(7px);
}

.ts-header-in{
  min-height:64px;
  display:flex;
  align-items:center;
  gap:14px;
}

.ts-brand{
  min-width:0;
  display:flex;
  align-items:center;
}

.ts-brand-link{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  color:var(--ts-text);
}

.ts-logo-img{
  width:42px;
  height:42px;
  object-fit:contain;
  border-radius:10px;
  box-shadow:var(--ts-shadow);
}

.ts-brand-text{
  display:flex;
  flex-direction:column;
  min-width:0;
}
.ts-brand-main{
  color:#0f6076;
  font-size:19px;
  font-weight:800;
  line-height:1.1;
}
.ts-brand-sub{
  color:#3d5e72;
  font-size:12px;
  line-height:1.2;
  white-space:nowrap;
}

.ts-header-search{
  display:none;
  margin-left:auto;
  width:min(320px, 100%);
  align-items:center;
  gap:8px;
}
.ts-header-search input[type="text"],
.ts-search input[type="text"],
.ts-form-stack input[type="text"],
.ts-form-stack input[type="email"],
.ts-form-stack select,
.ts-form-stack textarea{
  width:100%;
  border:1px solid var(--ts-border);
  border-radius:10px;
  padding:10px 11px;
  font-size:16px;
  background:#fff;
  color:var(--ts-text);
}
.ts-header-search input[type="text"]{ font-size:14px; padding:8px 10px; }

.ts-btn,
.ts-header-search button,
.ts-search button,
.ts-form-stack button{
  appearance:none;
  border:1px solid #0f7389;
  border-bottom-width:3px;
  border-radius:10px;
  background:linear-gradient(180deg, #43bfd8 0%, #1b9bb8 58%, #177f99 100%);
  color:#fff;
  font-weight:700;
  line-height:1.2;
  padding:10px 14px;
  cursor:pointer;
  text-decoration:none;
  text-shadow:0 -1px 0 rgba(0, 0, 0, .2);
  box-shadow:0 3px 0 rgba(8, 79, 96, .34), 0 6px 12px rgba(8, 79, 96, .2), inset 0 1px 0 rgba(255, 255, 255, .35);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:5px;
}
.ts-header-search button{
  width:42px;
  min-width:42px;
  padding:8px;
  font-size:14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  white-space:nowrap;
  writing-mode:horizontal-tb;
  text-orientation:mixed;
}
.ts-header-search button .material-symbols-rounded{
  font-size:20px;
}
.ts-input{
  width:100%;
  border:1px solid var(--ts-border);
  border-radius:10px;
  padding:10px 11px;
  font-size:16px;
  background:#fff;
  color:var(--ts-text);
}
.ts-btn:hover,
.ts-header-search button:hover,
.ts-search button:hover,
.ts-form-stack button:hover{
  filter:brightness(.99);
  box-shadow:0 2px 0 rgba(8, 79, 96, .34), 0 4px 9px rgba(8, 79, 96, .2), inset 0 1px 0 rgba(255, 255, 255, .35);
  transform:translateY(1px);
}
.ts-btn:active,
.ts-header-search button:active,
.ts-search button:active,
.ts-form-stack button:active{
  transform:translateY(2px);
  box-shadow:0 1px 0 rgba(8, 79, 96, .34), inset 0 1px 0 rgba(255, 255, 255, .28);
}

.ts-nav{
  margin-left:auto;
}
.ts-nav-toggle{
  appearance:none;
  border:1px solid var(--ts-border);
  border-radius:10px;
  background:#fff;
  color:#1a3a4c;
  padding:7px 10px;
  font-size:13px;
  font-weight:700;
  display:none;
  align-items:center;
  gap:5px;
}
.ts-nav-list{
  margin:0;
  padding:0;
  list-style:none;
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:6px;
}
.ts-nav-list a{
  display:inline-flex;
  align-items:center;
  border:1px solid var(--ts-border);
  border-radius:999px;
  background:#fff;
  color:var(--ts-text);
  font-size:13px;
  text-decoration:none;
  padding:6px 10px;
}
.ts-nav-list a:hover{
  background:var(--ts-primary-soft);
  border-color:#b9dce6;
}
.ts-nav-list a[href*='/landline/'],
.ts-nav-list .ts-cat-landline{
  border-color:rgba(69, 171, 107, .48);
  background:rgba(69, 171, 107, .14);
}
.ts-nav-list a[href*='/landline/']::before,
.ts-nav-list .ts-cat-landline::before{
  font-family:'Material Symbols Rounded';
  content:'home';
  font-size:16px;
  margin-right:4px;
}
.ts-nav-list a[href*='/freedial/'],
.ts-nav-list .ts-cat-freedial{
  border-color:rgba(225, 184, 60, .54);
  background:rgba(225, 184, 60, .16);
}
.ts-nav-list a[href*='/freedial/']::before,
.ts-nav-list .ts-cat-freedial::before{
  font-family:'Material Symbols Rounded';
  content:'support_agent';
  font-size:16px;
  margin-right:4px;
}
.ts-nav-list a[href*='/ip/'],
.ts-nav-list .ts-cat-ip{
  border-color:rgba(214, 106, 141, .50);
  background:rgba(214, 106, 141, .14);
}
.ts-nav-list a[href*='/ip/']::before,
.ts-nav-list .ts-cat-ip::before{
  font-family:'Material Symbols Rounded';
  content:'wifi_calling_3';
  font-size:16px;
  margin-right:4px;
}
.ts-nav-list a[href*='/mobile/'],
.ts-nav-list .ts-cat-mobile{
  border-color:rgba(143, 107, 207, .52);
  background:rgba(143, 107, 207, .14);
}
.ts-nav-list a[href*='/mobile/']::before,
.ts-nav-list .ts-cat-mobile::before{
  font-family:'Material Symbols Rounded';
  content:'smartphone';
  font-size:16px;
  margin-right:4px;
}
.ts-nav-list a[href*='/overseas/'],
.ts-nav-list .ts-cat-overseas{
  border-color:rgba(155, 106, 73, .52);
  background:rgba(155, 106, 73, .14);
}
.ts-nav-list a[href*='/overseas/']::before,
.ts-nav-list .ts-cat-overseas::before{
  font-family:'Material Symbols Rounded';
  content:'travel';
  font-size:16px;
  margin-right:4px;
}
.ts-nav-list a[href*='/landline/']:hover,
.ts-nav-list .ts-cat-landline:hover{ background:rgba(69, 171, 107, .22); }
.ts-nav-list a[href*='/freedial/']:hover,
.ts-nav-list .ts-cat-freedial:hover{ background:rgba(225, 184, 60, .24); }
.ts-nav-list a[href*='/ip/']:hover,
.ts-nav-list .ts-cat-ip:hover{ background:rgba(214, 106, 141, .22); }
.ts-nav-list a[href*='/mobile/']:hover,
.ts-nav-list .ts-cat-mobile:hover{ background:rgba(143, 107, 207, .22); }
.ts-nav-list a[href*='/overseas/']:hover,
.ts-nav-list .ts-cat-overseas:hover{ background:rgba(155, 106, 73, .22); }

.ts-main{ margin-top:16px; }
.ts-layout{
  display:grid;
  grid-template-columns:minmax(0, 1fr);
  gap:16px;
  align-items:start;
}
.ts-content,
.ts-sidebar{ min-width:0; }
.ts-aside{ min-width:0; }

.ts-card,
.ts-page{
  background:var(--ts-surface);
  border:1px solid var(--ts-border);
  border-radius:var(--ts-radius);
  box-shadow:var(--ts-shadow);
}
.ts-card{ padding:12px; }
.ts-card + .ts-card{ margin-top:12px; }
.ts-card-title{
  margin:0 0 8px;
  font-size:16px;
  color:var(--ts-primary-deep);
  line-height:1.45;
  font-weight:700;
  display:flex;
  align-items:center;
  gap:6px;
}

.ts-hero{
  padding:24px;
  border:2px solid #8ecadd;
  border-radius:var(--ts-radius);
  background:linear-gradient(155deg, #d8f0f7 0%, #ecf8fd 50%, #ffffff 100%);
  box-shadow:0 12px 28px rgba(20, 137, 163, .16), inset 0 1px 0 rgba(255, 255, 255, .9);
}
.ts-hero h1{
  color:var(--ts-primary-deep);
  margin-bottom:10px;
}
.ts-hero-subtitle{
  margin:0 0 8px;
  font-size:18px;
  font-weight:700;
  color:#1f6f85;
}
.ts-hero .ts-lead{
  color:#365266;
}
.ts-hero .ts-search{
  margin-top:14px;
  padding:14px;
  border:2px solid #a8d5e2;
  border-radius:12px;
  background:rgba(255, 255, 255, .92);
  box-shadow:0 3px 12px rgba(8, 79, 96, .1);
}
.ts-hero .ts-search input[type="text"]{
  border-color:#8fc7d5;
  box-shadow:inset 0 1px 2px rgba(13, 95, 116, .08), 0 0 0 2px rgba(255, 255, 255, .8);
  font-size:18px;
  font-weight:600;
}
.ts-hero .ts-search button{
  min-width:136px;
}

h1{
  font-size:28px;
  line-height:1.35;
  margin:0 0 8px;
  color:var(--ts-primary-deep);
}
h2{
  font-size:22px;
  line-height:1.4;
  margin:0 0 10px;
  color:#145f75;
}
h3{
  font-size:18px;
  line-height:1.4;
  margin:0 0 8px;
  color:#19667b;
}

.ts-lead{
  margin:0 0 12px;
  color:var(--ts-muted);
  font-size:16px;
}
.ts-meta{
  margin:0;
  color:var(--ts-muted);
  font-size:13px;
}
.ts-spacer-top{ margin-top:8px; }

.ts-search{
  display:flex;
  align-items:stretch;
  gap:8px;
  max-width:820px;
  margin:10px 0 0;
}
.ts-search.is-icon-only{
  max-width:none;
}
.ts-search.is-icon-only button{
  width:44px;
  min-width:44px;
  padding:8px;
}
.ts-search.is-icon-only button span:not(.material-symbols-rounded){
  display:none;
}

.ts-area-search{
  margin-top:8px;
  padding:14px;
  border:1px solid #b8dbe5;
  border-radius:12px;
  background:linear-gradient(180deg, rgba(233, 247, 251, .9) 0%, #ffffff 72%);
  box-shadow:0 3px 12px rgba(8, 79, 96, .1);
}
.ts-area-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:10px;
}
.ts-area-select{
  appearance:none;
  width:100%;
  border:1px solid #8fc7d5;
  border-radius:10px;
  padding:10px 11px;
  font-size:15px;
  background:linear-gradient(180deg, #ffffff 0%, #f6fcff 100%);
  color:var(--ts-text);
  box-shadow:inset 0 1px 2px rgba(13, 95, 116, .08);
}
.ts-area-select:focus-visible{
  outline:3px solid rgba(30, 167, 198, .35);
  outline-offset:1px;
  border-color:#4db7cf;
}
.ts-area-submit{
  width:100%;
  margin-top:10px;
  min-height:44px;
}
.ts-area-submit:disabled{
  opacity:.58;
  cursor:not-allowed;
  filter:grayscale(.2);
}
.ts-area-search-sidebar .ts-area-grid{
  grid-template-columns:1fr;
}

.ts-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}
.ts-cat-grid{
  grid-template-columns:repeat(2, minmax(0, 1fr));
}
.ts-cat-card-featured{
  grid-column:1 / -1;
}
.ts-section{ margin-top:18px; }

.ts-badge,
.ts-pill{
  display:inline-flex;
  align-items:center;
  gap:4px;
  border:1px solid #b8dbe5;
  border-radius:999px;
  background:var(--ts-primary-soft);
  color:#0d5f73;
  font-size:12px;
  line-height:1;
  padding:4px 8px;
}

.ts-breadcrumb{
  margin:0 0 12px;
  font-size:13px;
  color:var(--ts-muted);
}
.ts-breadcrumbs{
  margin:0 0 12px;
  font-size:13px;
  color:var(--ts-muted);
}
.ts-breadcrumb a{ color:var(--ts-muted); }
.ts-breadcrumb a:hover{ color:var(--ts-primary-strong); }
.ts-breadcrumbs a{ color:var(--ts-muted); }
.ts-breadcrumbs a:hover{ color:var(--ts-primary-strong); }

.ts-page{
  padding:16px;
}
.ts-page-head{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px;
}
.ts-page-title{
  margin:0;
  font-size:28px;
  color:var(--ts-primary-deep);
}
.ts-page-lead{
  margin:8px 0 0;
  color:var(--ts-muted);
}
.ts-page-meta{
  margin:10px 0 0;
  color:var(--ts-muted);
  font-size:13px;
}

.ts-stack > * + *{ margin-top:18px; }
.ts-section-title{
  margin:0 0 10px;
  font-size:22px;
  color:#0f6076;
  border-left:5px solid #49b7d2;
  border-bottom:1px solid #cfe6ee;
  padding:4px 0 6px 10px;
  line-height:1.35;
  background:linear-gradient(90deg, rgba(233, 247, 251, .95) 0%, rgba(233, 247, 251, 0) 78%);
  display:flex;
  align-items:center;
  gap:6px;
}

.ts-note{
  border:1px solid var(--ts-border);
  border-radius:10px;
  background:#f9fbfd;
  padding:10px 12px;
  color:var(--ts-muted);
  font-size:13px;
}
.ts-note.is-success{
  background:#f2fbf6;
  border-color:#b9e4c7;
  color:#255f35;
}
.ts-empty-state{
  border:1px solid #b6dae5;
  border-radius:12px;
  background:linear-gradient(180deg, #f7fcff, #edf8fc);
  padding:12px;
}
.ts-empty-state .ts-note{
  margin:0;
  background:transparent;
  border:0;
  padding:0;
}
.ts-cta-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:10px;
}

.ts-inline-list{
  margin:0;
  padding:0;
  list-style:none;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.ts-link-chip{
  display:inline-flex;
  align-items:center;
  border:1px solid var(--ts-border);
  border-radius:999px;
  background:#fff;
  color:var(--ts-text);
  text-decoration:none;
  padding:6px 10px;
  font-size:14px;
}
.ts-link-chip:hover{
  background:var(--ts-primary-soft);
  border-color:#b9dce6;
}
.ts-link-chip-emphasis{
  border-color:#dc8b58;
  background:linear-gradient(180deg, #ffb47a 0%, #f79355 100%);
  color:#fff;
  font-weight:700;
  box-shadow:0 2px 0 rgba(150, 74, 34, .35);
  display:inline-flex;
  align-items:center;
  gap:4px;
}
.ts-link-chip-emphasis:hover{
  color:#fff;
  background:linear-gradient(180deg, #ffae72 0%, #f08747 100%);
  border-color:#cf7b46;
}

.ts-number-list,
.ts-sidebar-list{
  margin:0;
  padding:0;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.ts-number-list li,
.ts-sidebar-list li{
  padding:0;
  border:0;
  background:transparent;
}
.ts-number-list a,
.ts-sidebar-list a{
  color:var(--ts-text);
  font-weight:700;
  text-decoration:none;
}
.ts-number-list a:hover,
.ts-sidebar-list a:hover{ color:var(--ts-primary-strong); }
.ts-box-link{
  display:block;
  border:1px solid var(--ts-border);
  border-radius:10px;
  background:#fff;
  padding:10px 12px;
  box-shadow:0 1px 2px rgba(16, 31, 48, .04);
  transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}
.ts-box-link:hover{
  border-color:#9acbda;
  box-shadow:0 6px 14px rgba(16, 31, 48, .08);
  transform:translateY(-1px);
}
.ts-box-link-split{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.ts-box-main{
  display:block;
  min-width:0;
  flex:1 1 auto;
}
.ts-box-side{
  display:flex;
  flex-direction:row-reverse;
  gap:10px;
  align-items:flex-start;
  justify-content:flex-end;
  min-width:250px;
  flex:0 0 auto;
}
.ts-metric-group{
  display:flex;
  flex-direction:column;
  gap:4px;
  min-width:106px;
  padding-left:10px;
  border-left:1px solid #d9e8ee;
}
.ts-metric-title{
  font-size:11px;
  color:#5a7585;
  font-weight:700;
  line-height:1.35;
}
.ts-metric-item{
  display:block;
  font-size:12px;
  line-height:1.35;
  color:var(--ts-muted);
  white-space:nowrap;
}
.ts-metric-empty{
  display:block;
  font-size:12px;
  color:#8ea0ad;
  white-space:nowrap;
}
.ts-metric-safe{ color:#2e9150; }
.ts-metric-neutral{ color:#cc7b21; }
.ts-metric-danger{ color:#cb3f3f; }
.ts-metric-topic-rank1{ color:#cb3f3f; }
.ts-metric-topic-rank2{ color:#cc7b21; }
.ts-metric-topic-rank3{ color:#8f5c2a; }
.ts-metric-mobile{ display:none; }
.ts-box-number{
  display:block;
  color:#133d4d;
  font-weight:700;
  font-size:16px;
}
.ts-subtext{
  display:block;
  margin-top:3px;
  color:var(--ts-muted);
  font-size:12px;
}

.ts-list{
  margin:0;
  padding:0;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.ts-list li{
  padding:0;
  border:0;
  background:transparent;
}
.ts-list-top{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:6px;
  color:var(--ts-muted);
  font-size:12px;
}

.ts-review-list{
  margin:0;
  padding:0;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.ts-review-list li{
  border:1px solid var(--ts-border);
  border-radius:10px;
  background:#fff;
  padding:12px;
}
.ts-review-list-compact li{ padding:10px; }
.ts-review-top{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  flex-wrap:wrap;
  gap:8px;
}
.ts-review-meta{
  color:var(--ts-muted);
  font-size:12px;
}
.ts-review-title,
.ts-review-author{
  margin-top:6px;
  font-weight:700;
}
.ts-review-company{
  margin-top:6px;
  font-size:13px;
  color:#1d5569;
  font-weight:700;
}
.ts-review-body{
  margin-top:6px;
  white-space:pre-wrap;
  word-break:break-word;
}
.ts-review-actions{
  margin-top:10px;
  display:flex;
  justify-content:flex-end;
}
.ts-helpful-btn{
  appearance:none;
  border:1px solid #b7d4df;
  border-radius:999px;
  background:#f3fbfe;
  color:#1f5f72;
  display:inline-flex;
  align-items:center;
  gap:5px;
  padding:5px 10px;
  font-size:12px;
  font-weight:700;
  line-height:1.2;
  cursor:pointer;
  transition:background .2s ease, border-color .2s ease, color .2s ease;
}
.ts-helpful-btn:hover{
  background:#e7f6fb;
  border-color:#8ec2d4;
}
.ts-helpful-btn.is-voted,
.ts-helpful-btn:disabled{
  cursor:default;
  background:#e8f4eb;
  border-color:#9dcfb0;
  color:#2f7750;
}
.ts-helpful-btn.is-error{
  border-color:#d77f7f;
  color:#9f2c2c;
  background:#fff1f1;
}
.ts-helpful-count{
  min-width:18px;
  text-align:center;
}
.ts-report-link{
  color:var(--ts-muted);
  font-size:12px;
}

.ts-faq details{
  border:1px solid var(--ts-border);
  border-radius:10px;
  background:#fff;
  padding:10px;
}
.ts-faq details + details{ margin-top:8px; }
.ts-faq summary{
  font-weight:700;
  cursor:pointer;
}
.ts-faq-body{ margin-top:8px; white-space:pre-wrap; }

.ts-form-stack{
  max-width:740px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
#post-review{
  scroll-margin-top:88px;
}
.ts-post-review-section{
  border:1px solid #efc7d6;
  background:linear-gradient(180deg, #fff8fc 0%, #fff1f7 100%);
  border-radius:14px;
  padding:14px;
  box-shadow:0 8px 18px rgba(179, 78, 115, .10);
}
.ts-post-review-section > .ts-section-title{
  color:#8e3155;
  border-left-color:#db6f9a;
  border-bottom-color:#f1ccdc;
  background:linear-gradient(90deg, rgba(255, 235, 245, .95) 0%, rgba(255, 235, 245, 0) 78%);
}
.ts-post-review-section .ts-form-stack{
  max-width:none;
}
.ts-post-review-section .ts-form-stack button{
  border:1px solid #a93f6c;
  border-bottom-width:3px;
  background:linear-gradient(180deg, #f58db7 0%, #e26698 58%, #c84d82 100%);
  box-shadow:0 3px 0 rgba(127, 37, 74, .34), 0 6px 12px rgba(127, 37, 74, .20), inset 0 1px 0 rgba(255, 255, 255, .30);
}
.ts-post-review-section .ts-form-stack button:hover{
  box-shadow:0 2px 0 rgba(127, 37, 74, .34), 0 4px 9px rgba(127, 37, 74, .20), inset 0 1px 0 rgba(255, 255, 255, .30);
}
.ts-post-review-section .ts-form-stack button:active{
  box-shadow:0 1px 0 rgba(127, 37, 74, .34), inset 0 1px 0 rgba(255, 255, 255, .24);
}
.ts-post-review-section .ts-form-help{
  color:#7d5a68;
}
.ts-field{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.ts-field-label{
  font-size:14px;
  font-weight:700;
}
.ts-form-help{
  margin:0;
  color:var(--ts-muted);
  font-size:12px;
}
.ts-review-feedback{
  margin:2px 0 0;
  border-color:#e0b5b5;
  background:#fff5f5;
  color:#8a2f2f;
}
.ts-review-feedback.is-success{
  border-color:#b9e4c7;
  background:#f2fbf6;
  color:#255f35;
}
.ts-call-response-vote-section{
  border:1px solid rgba(201, 213, 223, .82);
  border-radius:12px;
  background:rgba(248, 252, 255, .70);
  backdrop-filter:saturate(1.04) blur(1px);
  padding:12px;
}
.ts-call-response-vote-title{
  margin:0 0 10px;
  text-align:center;
  font-size:14px;
  font-weight:700;
  color:#7b8792;
}
.ts-call-response-vote-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:10px;
  margin:8px 0 0;
}
.ts-call-response-vote-btn{
  appearance:none;
  width:100%;
  min-height:64px;
  border-radius:12px;
  background:#fff;
  font-size:17px;
  font-weight:800;
  line-height:1.2;
  padding:10px 8px;
  text-align:center;
  cursor:pointer;
  transition:background .2s ease, color .2s ease, box-shadow .2s ease, transform .2s ease;
}
.ts-call-response-vote-btn.is-answered{
  border:2px solid #38a35f;
  color:#2f8f54;
}
.ts-call-response-vote-btn.is-ignored{
  border:2px solid #d45a73;
  color:#c64561;
}
.ts-call-response-vote-btn.is-answered.is-selected{
  background:#38a35f;
  color:#fff;
}
.ts-call-response-vote-btn.is-ignored.is-selected{
  background:#d45a73;
  color:#fff;
}
.ts-call-response-vote-btn:hover{
  box-shadow:0 5px 12px rgba(27, 48, 60, .10);
  transform:translateY(-1px);
}
.ts-call-response-vote-btn:active{
  transform:translateY(0);
}
.ts-call-response-vote-btn:disabled{
  cursor:default;
}
.ts-call-response-vote-feedback{
  margin:10px 0 0;
  text-align:center;
  font-size:12px;
  color:#8a949e;
}

.ts-chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.ts-chip{
  display:inline-flex;
  align-items:center;
  border:1px solid var(--ts-border);
  border-radius:999px;
  background:#fff;
  color:var(--ts-text);
  text-decoration:none;
  font-size:13px;
  padding:6px 10px;
}
.ts-chip:hover{
  background:var(--ts-primary-soft);
  border-color:#b9dce6;
}

.ts-cat-card{
  border-left:5px solid #9fcdd9;
}
.ts-cat-link{
  display:block;
  text-decoration:none;
  color:inherit;
  transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}
.ts-cat-link:hover{
  border-color:#9fcdd9;
  box-shadow:0 6px 14px rgba(16, 31, 48, .08);
  transform:translateY(-1px);
}

.ts-cat-card.ts-cat-landline{ border-left-color:var(--ts-cat-landline); background:linear-gradient(180deg, rgba(69, 171, 107, .10) 0%, #fff 68%); }
.ts-cat-card.ts-cat-freedial{ border-left-color:var(--ts-cat-freedial); background:linear-gradient(180deg, rgba(225, 184, 60, .13) 0%, #fff 68%); }
.ts-cat-card.ts-cat-ip{ border-left-color:var(--ts-cat-ip); background:linear-gradient(180deg, rgba(214, 106, 141, .10) 0%, #fff 68%); }
.ts-cat-card.ts-cat-mobile{ border-left-color:var(--ts-cat-mobile); background:linear-gradient(180deg, rgba(143, 107, 207, .10) 0%, #fff 68%); }
.ts-cat-card.ts-cat-overseas{ border-left-color:var(--ts-cat-overseas); background:linear-gradient(180deg, rgba(155, 106, 73, .10) 0%, #fff 68%); }

.ts-chip-cat{ border-width:1px; color:#213444; }
.ts-chip-cat.ts-cat-landline{ border-color:rgba(69, 171, 107, .48); background:rgba(69, 171, 107, .14); }
.ts-chip-cat.ts-cat-freedial{ border-color:rgba(225, 184, 60, .54); background:rgba(225, 184, 60, .16); }
.ts-chip-cat.ts-cat-ip{ border-color:rgba(214, 106, 141, .50); background:rgba(214, 106, 141, .14); }
.ts-chip-cat.ts-cat-mobile{ border-color:rgba(143, 107, 207, .52); background:rgba(143, 107, 207, .14); }
.ts-chip-cat.ts-cat-overseas{ border-color:rgba(155, 106, 73, .52); background:rgba(155, 106, 73, .14); }

.ts-chip-cat.ts-cat-landline:hover{ border-color:rgba(69, 171, 107, .68); background:rgba(69, 171, 107, .22); }
.ts-chip-cat.ts-cat-freedial:hover{ border-color:rgba(225, 184, 60, .72); background:rgba(225, 184, 60, .24); }
.ts-chip-cat.ts-cat-ip:hover{ border-color:rgba(214, 106, 141, .70); background:rgba(214, 106, 141, .22); }
.ts-chip-cat.ts-cat-mobile:hover{ border-color:rgba(143, 107, 207, .72); background:rgba(143, 107, 207, .22); }
.ts-chip-cat.ts-cat-overseas:hover{ border-color:rgba(155, 106, 73, .72); background:rgba(155, 106, 73, .22); }

.ts-home{
  padding:16px;
  border:1px solid var(--ts-border);
  border-radius:var(--ts-radius);
  background:#fff;
  box-shadow:var(--ts-shadow);
}
.ts-home-sections{ margin-top:18px; display:grid; gap:18px; }
.ts-home-page{
  display:block;
}
.ts-home-hero{
  margin-bottom:16px;
}
.ts-home-grid{
  display:grid;
  grid-template-columns:minmax(0, 1fr);
  gap:16px;
  align-items:start;
}
.ts-home-main,
.ts-home-aside{ min-width:0; }

.ts-summary-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
}
.ts-summary-card{
  padding:12px;
}
.ts-summary-label{
  color:var(--ts-muted);
  font-size:13px;
}
.ts-summary-value{
  margin-top:6px;
  font-size:24px;
  font-weight:700;
  color:var(--ts-primary-deep);
}
.ts-chart{
  min-height:320px;
  border:1px solid var(--ts-border);
  border-radius:12px;
  background:#fff;
  padding:8px;
}
.ts-phone-kpi-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
  margin-bottom:10px;
}
.ts-phone-kpi-card{
  border:1px solid var(--ts-border);
  border-radius:12px;
  background:#fff;
  padding:11px 12px;
}
.ts-phone-kpi-label{
  color:var(--ts-muted);
  font-size:12px;
}
.ts-phone-kpi-value{
  margin-top:5px;
  font-size:22px;
  line-height:1.25;
  color:var(--ts-primary-deep);
  font-weight:800;
}
.ts-phone-pie-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
  margin-top:10px;
}
.ts-ai-next-action-box{
  border:0;
  background:transparent;
  border-radius:0;
  padding:0;
}
.ts-ai-next-action-box .ts-review-body{
  margin:0;
  white-space:normal;
}
.ts-ai-next-action-note{
  margin:8px 2px 0 auto;
  font-size:11px;
  line-height:1.5;
  color:#7d838d;
  text-align:right;
  max-width:920px;
}
.ts-ai-next-action-title{
  display:flex;
  align-items:center;
  gap:8px;
  margin:0 0 10px;
  color:#8a6400;
  border:0;
  background:transparent;
  border-radius:0;
  padding:0;
}
.ts-ai-title-icon{
  width:22px;
  height:22px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:#ffe48a;
  border:1px solid #e0bd56;
  flex:0 0 22px;
}
.ts-ai-title-icon svg{
  width:14px;
  height:14px;
  fill:#8a6400;
}
.ts-ai-next-action{
  border:1px solid #ecd989;
  background:#fffbe8;
  border-radius:12px;
  padding:12px 14px;
}
.ts-review-floating-cta{
  position:fixed;
  left:auto;
  right:14px;
  bottom:calc(12px + env(safe-area-inset-bottom));
  z-index:70;
  padding:0;
  display:none;
  justify-content:flex-end;
  pointer-events:none;
  opacity:0;
  transform:translateY(16px);
  transition:opacity .2s ease, transform .2s ease;
}
.ts-review-floating-cta.is-ready{
  display:flex;
}
.ts-review-floating-cta.is-visible{
  opacity:1;
  transform:translateY(0);
}
.ts-review-floating-cta-btn{
  pointer-events:auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:90px;
  height:90px;
  border:1px solid #a93f6c;
  border-bottom-width:2px;
  border-radius:999px;
  background:linear-gradient(180deg, rgba(245, 141, 183, .82) 0%, rgba(226, 102, 152, .80) 58%, rgba(200, 77, 130, .78) 100%);
  backdrop-filter:saturate(1.1) blur(1px);
  box-shadow:0 2px 0 rgba(127, 37, 74, .28), 0 6px 12px rgba(127, 37, 74, .20), inset 0 1px 0 rgba(255, 255, 255, .30);
  color:#fff;
  font-size:13px;
  font-weight:800;
  line-height:1.2;
  text-align:center;
  text-decoration:none;
  text-shadow:0 -1px 0 rgba(0, 0, 0, .2);
  letter-spacing:.01em;
  white-space:nowrap;
}
.ts-review-floating-cta-btn:hover{
  filter:brightness(.99);
  box-shadow:0 1px 0 rgba(127, 37, 74, .28), 0 4px 8px rgba(127, 37, 74, .20), inset 0 1px 0 rgba(255, 255, 255, .30);
  transform:translateY(1px);
}
.ts-review-floating-cta-btn:active{
  transform:translateY(2px);
  box-shadow:0 1px 0 rgba(127, 37, 74, .28), inset 0 1px 0 rgba(255, 255, 255, .24);
}
.ts-phone-internal-blocks .ts-number-list{
  display:grid;
  grid-template-columns:1fr;
  gap:8px;
}
.ts-phone-search-wrap{
  margin:0 0 10px;
}
.ts-phone-search-accordion{
  border:1px solid var(--ts-border);
  border-radius:12px;
  background:#fff;
  overflow:hidden;
}
.ts-phone-search-accordion summary{
  list-style:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:6px;
  padding:10px 12px;
  font-weight:700;
  color:#135f74;
  background:linear-gradient(180deg, #f7fcff 0%, #eef8fc 100%);
}
.ts-phone-search-accordion summary::-webkit-details-marker{ display:none; }
.ts-phone-search-body{
  border-top:1px solid var(--ts-border);
  padding:10px 12px 12px;
}
.ts-phone-search-body .ts-search{ margin:0; max-width:none; }
.ts-detail-table-wrap{
  border:1px solid var(--ts-border);
  border-radius:10px;
  overflow:hidden;
  background:#fff;
}
.ts-detail-table{
  width:100%;
  border-collapse:collapse;
  font-size:14px;
}
.ts-detail-table th,
.ts-detail-table td{
  padding:10px 12px;
  border-top:1px solid var(--ts-border);
  vertical-align:top;
}
.ts-detail-table tr:first-child th,
.ts-detail-table tr:first-child td{
  border-top:0;
}
.ts-detail-table th{
  width:34%;
  background:#f2f9fc;
  color:#1f4f60;
  text-align:left;
  font-weight:700;
}
.ts-trust-links{
  margin:0;
  padding:0;
  list-style:none;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.ts-trust-links a{
  display:inline-flex;
  align-items:center;
  font-size:13px;
  text-decoration:none;
  color:#1f4254;
  border:1px solid #c5dce4;
  background:#f7fcff;
  border-radius:999px;
  padding:5px 10px;
}
.ts-trust-links a:hover{
  background:#e9f7fb;
  border-color:#9fcdd9;
}

.ts-footer{
  margin-top:22px;
  padding:16px 0 20px;
  border-top:1px solid var(--ts-border);
  background:#fff;
  color:var(--ts-muted);
  font-size:13px;
}
.ts-footer-links{
  margin:0 0 10px;
  padding:0;
  list-style:none;
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}
.ts-footer-links a{
  text-decoration:none;
  color:#2d4f62;
  border:1px solid #cbdce3;
  background:#f8fcff;
  border-radius:999px;
  padding:4px 10px;
  font-size:12px;
}
.ts-footer-links a:hover{
  background:#eaf7fb;
}
@media (min-width:1024px){
  .ts-header-in{ gap:10px; }
  .ts-header-search{
    display:flex;
    margin-left:10px;
    flex:0 1 300px;
  }
  .ts-nav-toggle{ display:none; }
  .ts-nav{
    display:block !important;
    margin-left:0;
    flex:1 1 auto;
    min-width:0;
  }
  .ts-nav-list{
    flex-wrap:nowrap;
    gap:4px;
  }
  .ts-nav-list a{
    font-size:12px;
    padding:5px 8px;
  }
  .ts-home-grid{ grid-template-columns:minmax(0, 1fr) var(--ts-sidebar); }
  .ts-home-aside{ position:sticky; top:78px; }
}

@media (min-width:768px){
  .ts-layout{ grid-template-columns:minmax(0, 1fr) var(--ts-sidebar); }
  .ts-sidebar{ position:sticky; top:78px; }
  .ts-front-page .ts-layout{ grid-template-columns:minmax(0, 1fr); }
  .ts-grid{ grid-template-columns:1fr 1fr; }
  .ts-top-popular-list{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:10px;
  }
  .ts-top-popular-list li{
    min-width:0;
  }
  .ts-top-popular-list .ts-box-link{
    height:100%;
  }
  .ts-summary-grid{ grid-template-columns:repeat(3, minmax(0, 1fr)); }
  .ts-phone-kpi-grid{ grid-template-columns:repeat(3, minmax(0, 1fr)); }
  .ts-phone-pie-grid{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
}

@media (max-width:767px){
  h1, .ts-page-title{ font-size:22px; }
  h2, .ts-section-title{ font-size:18px; }
  .ts-hero-subtitle{ font-size:16px; }
  .ts-brand-sub{ display:none; }
  .ts-logo-img{ width:36px; height:36px; }
  .ts-header-in{ flex-wrap:wrap; }
  .ts-nav-toggle{ display:inline-flex; margin-left:auto; }
  .ts-nav{
    width:100%;
    margin-left:0;
    display:none;
  }
  .ts-nav.is-open{ display:block; }
  .ts-nav-list{ justify-content:flex-start; }
  .ts-nav-list li{ width:100%; }
  .ts-nav-list a{ width:100%; justify-content:flex-start; }
  .ts-search{ flex-direction:column; }
  .ts-search button,
  .ts-form-stack button{ width:100%; }
  .ts-search.is-icon-only{
    flex-direction:row;
    align-items:stretch;
  }
  .ts-search.is-icon-only button{
    width:44px;
    min-width:44px;
  }
  .ts-box-link-split{
    display:grid;
    grid-template-columns:minmax(0, 1fr) minmax(126px, 42%);
    align-items:start;
    gap:8px;
  }
  .ts-box-side{
    min-width:0;
    width:100%;
    flex-direction:column;
    justify-content:flex-start;
    align-items:flex-end;
    gap:6px;
  }
  .ts-metric-group{
    min-width:0;
    width:100%;
    padding-left:0;
    border-left:0;
    border-top:1px solid #d9e8ee;
    padding-top:4px;
    align-items:flex-end;
  }
  .ts-box-side .ts-metric-group:first-child{
    border-top:0;
    padding-top:0;
  }
  .ts-metric-title,
  .ts-metric-item,
  .ts-metric-empty{
    text-align:right;
    white-space:normal;
  }
  .ts-area-grid{
    grid-template-columns:1fr;
  }
  .ts-phone-kpi-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
  .ts-phone-kpi-card.is-views{
    grid-column:1 / -1;
  }
  .ts-detail-table th{
    width:42%;
  }
  .ts-review-floating-cta{
    right:10px;
    bottom:calc(10px + env(safe-area-inset-bottom));
  }
  .ts-review-floating-cta-btn{
    width:76px;
    height:76px;
    font-size:12px;
  }
}

@media (min-width:768px){
  .ts-phone-internal-blocks .ts-number-list{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:10px;
  }
}

.ts-article-page{
  padding:16px;
}
.ts-post-search-wrap{
  margin-bottom:12px;
}
.ts-article-meta-row{
  margin-top:10px;
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:8px;
}
.ts-article-meta-item{
  border:1px solid var(--ts-border);
  border-radius:10px;
  background:#f8fcff;
  padding:8px 10px;
  min-width:0;
}
.ts-article-meta-label{
  display:block;
  font-size:12px;
  color:var(--ts-muted);
}
.ts-article-meta-value{
  display:block;
  margin-top:2px;
  font-size:14px;
  color:var(--ts-text);
  font-weight:700;
  overflow-wrap:anywhere;
}
.ts-article-content img{
  display:block;
  width:100%;
  height:auto;
  border:1px solid var(--ts-border);
  border-radius:12px;
  box-shadow:var(--ts-shadow);
}

.ts-share-x-wrap{
  margin-top:18px;
  display:flex;
  justify-content:center;
  align-items:center;
  width:100%;
  margin-left:auto;
  margin-right:auto;
  text-align:center;
}
.ts-share-x{
  width:44px;
  height:44px;
  border-radius:999px;
  border:1px solid #1f2f3f;
  background:#111b24;
  color:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  box-shadow:0 4px 10px rgba(17, 27, 36, .25);
}
.ts-share-x.has-label{
  width:auto;
  min-height:0;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  color:var(--ts-primary-strong);
  box-shadow:none;
  gap:0;
}
.ts-share-x:hover{
  background:#1d2a36;
}
.ts-share-x.has-label:hover{
  background:transparent;
  color:var(--ts-primary-deep);
}
.ts-share-x svg{
  width:20px;
  height:20px;
  fill:currentColor;
}
.ts-share-x-mark{
  font-size:18px;
  font-weight:800;
  line-height:1;
  letter-spacing:.01em;
}
.ts-share-x-label{
  font-size:14px;
  font-weight:700;
  line-height:1.2;
  white-space:nowrap;
  text-decoration:underline;
  text-underline-offset:2px;
}
.ts-share-x img{
  width:20px !important;
  height:20px !important;
  max-width:20px !important;
  max-height:20px !important;
  object-fit:contain;
  display:block;
}

.ts-home-post-slider{
  margin-top:20px;
}
.ts-post-slider{
  border:1px solid var(--ts-border);
  border-radius:12px;
  background:#fff;
  box-shadow:var(--ts-shadow);
  overflow:hidden;
  padding:12px;
}
.ts-post-slider-track{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:calc((100% - 24px) / 3);
  gap:12px;
  align-items:stretch;
  width:max-content;
  min-width:100%;
  animation:ts-post-slider-marquee 48s linear infinite;
}
.ts-post-slider:hover .ts-post-slider-track{
  animation-play-state:paused;
}
.ts-post-slide-card{
  display:flex;
  flex-direction:column;
  border:1px solid var(--ts-border);
  border-radius:10px;
  background:#fff;
  overflow:hidden;
  text-decoration:none;
  color:var(--ts-text);
  min-width:0;
}
.ts-post-slide-thumb{
  aspect-ratio:16 / 9;
  background:#eef6fa;
}
.ts-post-slide-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.ts-post-slide-meta{
  margin:8px 10px 0;
  color:var(--ts-muted);
  font-size:12px;
}
.ts-post-slide-title{
  margin:4px 10px 10px;
  font-size:14px;
  line-height:1.5;
  font-weight:700;
  overflow-wrap:anywhere;
}

@keyframes ts-post-slider-marquee{
  0%{ transform:translateX(0); }
  100%{ transform:translateX(-50%); }
}

@media (max-width:767px){
  .ts-article-meta-row{
    grid-template-columns:1fr;
  }
  .ts-post-slider-track{
    grid-auto-columns:calc((100% - 12px) / 2);
  }
}

@media (prefers-reduced-motion:reduce){
  .ts-post-slider-track{
    animation:none;
  }
}
