/* ===== catalog.css ===== */
/* ============ Catalog / product listing page ============ */
.crumb{font-size:13px;color:var(--muted);padding:18px 0 0;display:flex;align-items:center;gap:8px}
.crumb a{color:var(--muted)}.crumb a:hover{color:var(--teal-deep)}
.crumb .sep{color:var(--muted-2)}
.crumb b{color:var(--ink);font-weight:600}

.cat-hero{padding:14px 0 6px}
.cat-hero .overline{color:var(--teal-deep);-webkit-text-fill-color:initial;background:none}
.cat-hero h1{font-size:30px;font-weight:700;letter-spacing:-.01em;margin-top:6px}
.cat-hero p{color:var(--muted);font-size:15px;margin-top:6px;max-width:680px}

/* compact search/filter bar */
.searchbar{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 18px;
  box-shadow:var(--shadow-sm);margin:16px 0 26px;position:sticky;top:78px;z-index:40}
.sb-tags{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.sb-tags .sb-label{font-size:12.5px;font-weight:600;color:var(--muted);white-space:nowrap;margin-right:2px}
.sb-tag-row{display:flex;gap:8px;flex-wrap:wrap;flex:1}
.searchbar .cmp-tag{padding:7px 12px 7px 9px;border-radius:11px}
.searchbar .cmp-tag .ci{width:28px;height:28px}
.searchbar .cmp-tag .ct b{font-size:13px}
.searchbar .cmp-tag .ct i{font-size:10.5px}
/* cross-cutting attr tags (มือใหม่ / เกรดโปร) — blue accent to separate from type tags */
.searchbar .cmp-tag.attr .ci{color:var(--blue)}
.searchbar .cmp-tag.attr.active{border-color:var(--blue);background:var(--blue-soft);box-shadow:0 0 0 3px rgba(77,163,255,.16)}
.searchbar .cmp-tag.attr.active .ci{background:#fff;color:var(--blue)}
.sb-divider{height:1px;background:var(--border-soft);margin:14px 0}
.sb-controls{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.sb-controls .grow{flex:1}
.sb-count{font-size:13px;color:var(--muted)}
.sb-count b{font-family:'IBM Plex Mono';color:var(--ink)}

/* multiselect dropdown */
.ms{position:relative}
.ms-btn{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--border);
  border-radius:11px;padding:10px 14px;font-size:14px;font-weight:500;color:var(--ink);transition:.14s}
.ms-btn:hover{border-color:var(--teal)}
.ms-btn.on{border-color:var(--teal-deep);background:var(--teal-soft);color:var(--teal-deep);font-weight:600}
.ms-btn .car{width:8px;height:8px;border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);
  transform:rotate(45deg);transition:.2s;margin-left:2px}
.ms.open .ms-btn .car{transform:rotate(-135deg)}
.ms-menu{position:absolute;top:calc(100% + 8px);left:0;min-width:220px;background:#fff;border:1px solid var(--border);
  border-radius:var(--r);box-shadow:var(--shadow-lg);padding:8px;z-index:30;display:none;max-height:300px;overflow-y:auto}
.ms.open .ms-menu{display:block}
.ms-opt{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:9px;font-size:14px;cursor:pointer;transition:.12s}
.ms-opt:hover{background:var(--app)}
.ms-opt input{position:absolute;opacity:0;width:0;height:0}
.ms-box{width:19px;height:19px;border-radius:6px;border:1.5px solid var(--border);flex-shrink:0;position:relative;transition:.12s}
.ms-opt input:checked + .ms-box{background:var(--teal-deep);border-color:var(--teal-deep)}
.ms-opt input:checked + .ms-box::after{content:"";position:absolute;left:6px;top:2px;width:5px;height:10px;
  border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}

.sb-clear{font-size:13.5px;font-weight:600;color:var(--blue);padding:9px 12px;border-radius:10px;
  display:none;align-items:center;gap:6px;transition:.14s}
.sb-clear.show{display:inline-flex}
.sb-clear:hover{background:var(--blue-soft)}

.empty-grid{grid-column:1/-1;text-align:center;color:var(--muted);padding:50px 20px;font-size:15px;
  display:flex;flex-direction:column;align-items:center;gap:14px}


/* review with film line */
.rev-film{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--muted);margin-top:11px}
.rev-film b{color:var(--teal-deep);font-weight:600}
.rev-film svg{color:var(--line)}
.rev-head{text-align:center;margin-bottom:24px}
.rev-head .overline{display:inline-block}
.rev-head .ttl{font-size:24px;font-weight:700;margin-top:8px}
.rev-head .hint{font-size:14px;color:var(--muted);margin-top:6px}

/* category switch bar (preview) */
.catbar{position:fixed;left:50%;bottom:20px;transform:translateX(-50%);z-index:80;background:var(--ink);
  color:#fff;border-radius:999px;padding:7px 8px 7px 16px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-lg)}
.catbar .lb{font-size:12px;color:var(--muted-2);font-weight:600;display:flex;align-items:center;gap:7px}
.catbar .lb::before{content:"";width:7px;height:7px;border-radius:999px;background:var(--teal)}
.catbar .opts{display:flex;gap:3px;background:rgba(255,255,255,.08);border-radius:999px;padding:3px}
.catbar button{font-size:12.5px;font-weight:600;color:var(--muted-2);padding:7px 14px;border-radius:999px;transition:.15s}
.catbar button.on{background:#fff;color:var(--ink)}

.nav-links a.active{background:var(--teal-soft);color:var(--teal-deep);font-weight:600}

@media(max-width:760px){
  .searchbar{position:static;padding:14px}
  .cat-hero h1{font-size:23px}
  .sb-controls{align-items:stretch}
  .ms,.ms-btn{width:100%}
  .catbar{padding:6px;left:12px;right:12px;transform:none;bottom:12px;justify-content:center}
  .catbar .lb{display:none}
}


/* ===== compare.css ===== */
/* ============ Compare (full) page ============ */
.cmp-page-head{padding:18px 0 4px}
.cmp-page-head .overline{color:var(--teal-deep);-webkit-text-fill-color:initial;background:none}
.cmp-page-head h1{font-size:30px;font-weight:700;letter-spacing:-.01em;margin-top:6px}
.cmp-page-head p{color:var(--muted);font-size:15px;margin-top:6px;max-width:640px}

.cmp-controls{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;
  box-shadow:var(--shadow-sm);margin:18px 0 24px}
.cmp-controls .cmp-pick-label{font-size:13px;color:var(--muted);font-weight:600;margin-bottom:11px}
.cmp-controls .cmp-tag-row{margin-bottom:18px}
.cmp-controls .cmp-pick-row{margin-top:0}

/* ---- full comparison table ---- */
.ctable-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:8px}
.ctable{display:grid;gap:0;min-width:680px;background:#fff;border:1px solid var(--border);
  border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm)}
/* columns set inline by JS via --cols */
.ct-row{display:grid;grid-template-columns:var(--cols);border-bottom:1px solid var(--border-soft)}
.ct-row:last-child{border-bottom:none}
.ct-row.head{border-bottom:1px solid var(--border)}
.ct-cell{padding:14px 16px;display:flex;flex-direction:column;justify-content:center;border-left:1px solid var(--border-soft)}
.ct-cell:first-child{border-left:none}
.ct-rowlabel{background:var(--app);font-size:13px;color:var(--muted);font-weight:600;gap:2px}
.ct-rowlabel small{font-size:11px;color:var(--muted-2);font-weight:400}

/* header cells (films) */
.ct-head-cell{background:#fff;align-items:stretch;gap:0;padding:0}
.ct-head-cell .inner{padding:16px;display:flex;flex-direction:column;height:100%;position:relative}
.ct-head-empty{align-items:center;justify-content:center;text-align:center;color:var(--muted-2);cursor:pointer;min-height:150px;
  border:1.5px dashed var(--border);border-radius:var(--r);margin:10px}
.ct-head-empty:hover{border-color:var(--teal);color:var(--teal-deep)}
.ct-head-empty .plus{width:38px;height:38px;border-radius:999px;background:var(--app);display:flex;align-items:center;justify-content:center;font-size:22px;margin:0 auto 8px;color:var(--teal-deep)}
.ct-head-empty span{font-size:13px}
.ch-sw{width:46px;height:46px;border-radius:11px;margin-bottom:10px}
.ch-brand{font-size:11.5px;color:var(--muted);font-weight:500}
.ch-name{font-size:17px;font-weight:700;letter-spacing:-.01em;line-height:1.2}
.ch-x{position:absolute;top:12px;right:12px;width:24px;height:24px;border-radius:999px;background:var(--app);
  color:var(--muted);font-size:13px;display:flex;align-items:center;justify-content:center}
.ch-x:hover{background:#fde8e8;color:#d64545}

/* value cells */
.ct-val{font-family:'IBM Plex Mono';font-weight:600;font-size:15px;color:var(--ink)}
.ct-val small{font-size:11px;color:var(--muted);font-weight:400;font-family:'IBM Plex Sans Thai'}
.ct-bar{height:6px;background:#EEF2F7;border-radius:999px;overflow:hidden;margin-top:7px}
.ct-bar > i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--teal-deep),var(--teal))}
.ct-text{font-size:13.5px;color:var(--ink);font-weight:500}
.ct-best{position:relative}
.ct-best .ct-val{color:var(--teal-deep)}
.ct-best .ct-bar > i{background:linear-gradient(90deg,var(--teal-deep),var(--teal))}
.ct-best-badge{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;font-weight:600;color:var(--teal-deep);
  background:var(--teal-soft);padding:2px 7px;border-radius:999px;margin-top:6px;align-self:flex-start;font-family:'IBM Plex Sans Thai'}
.ct-cell.is-best{background:linear-gradient(180deg,rgba(68,215,197,.07),rgba(68,215,197,.02))}

/* action row */
.ct-act{padding:14px 12px;display:flex;flex-direction:column;gap:8px}
.ct-act .btn{width:100%;font-size:13.5px}

/* ---- verdict cards ---- */
.verdicts{margin:26px 0 6px}
.verdicts-head{font-size:15px;font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:9px}
.verdicts-head .overline{display:inline-block}
.verdict-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.verdict{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:16px 17px;box-shadow:var(--shadow-sm)}
.verdict .vic{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:10px}
.verdict .vtitle{font-size:12.5px;color:var(--muted);font-weight:600}
.verdict .vfilm{font-size:15.5px;font-weight:700;margin-top:3px;line-height:1.25}
.verdict .vnote{font-size:12px;color:var(--muted);margin-top:6px}

/* empty state */
.cmp-empty{background:#fff;border:1px dashed var(--border);border-radius:var(--r-lg);padding:48px 24px;text-align:center;color:var(--muted)}
.cmp-empty .ic{width:60px;height:60px;border-radius:16px;background:var(--teal-soft);color:var(--teal-deep);
  display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.cmp-empty h3{font-size:18px;font-weight:700;color:var(--ink)}
.cmp-empty p{font-size:14px;margin-top:6px}

/* find installer banner */
.find-inst{margin:14px 0}
.find-inst-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-xl);padding:30px 34px;
  display:flex;align-items:center;justify-content:space-between;gap:28px;box-shadow:var(--shadow-sm);overflow:hidden;position:relative}
.find-inst-card .tx h2{font-size:23px;font-weight:700;letter-spacing:-.01em}
.find-inst-card .tx p{color:var(--muted);font-size:14.5px;margin-top:6px;max-width:520px}
.find-inst-card .map{display:flex;align-items:center;gap:-10px}
.find-inst-card .btn{white-space:nowrap}

@media(max-width:760px){
  .cmp-page-head h1{font-size:23px}
  .verdict-grid{grid-template-columns:1fr 1fr}
  .find-inst-card{flex-direction:column;align-items:flex-start}
}
@media(max-width:520px){ .verdict-grid{grid-template-columns:1fr} }


/* ===== installers.css ===== */
/* ============ Find Installer page ============ */
.fi-head{padding:18px 0 4px}
.fi-head .overline{color:var(--teal-deep);-webkit-text-fill-color:initial;background:none}
.fi-head h1{font-size:30px;font-weight:700;letter-spacing:-.01em;margin-top:6px}
.fi-head p{color:var(--muted);font-size:15px;margin-top:6px;max-width:680px}

/* filter bar */
.fi-filters{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;
  box-shadow:var(--shadow-sm);margin:16px 0 16px;position:sticky;top:78px;z-index:40}
.fi-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.fi-row + .fi-row{margin-top:12px}
.fi-search{flex:1;min-width:200px;position:relative}
.fi-search input{width:100%;border:1px solid var(--border);border-radius:11px;padding:11px 13px 11px 40px;
  font-family:inherit;font-size:14.5px;background:var(--app);transition:.14s}
.fi-search input:focus{outline:none;border-color:var(--teal);background:#fff;box-shadow:0 0 0 3px rgba(68,215,197,.14)}
.fi-search svg{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--muted-2)}

/* native styled select */
.fi-sel{position:relative;display:inline-flex;align-items:center}
.fi-sel select{appearance:none;-webkit-appearance:none;background:#fff;border:1px solid var(--border);border-radius:11px;
  padding:10px 36px 10px 14px;font-family:inherit;font-size:14px;font-weight:500;color:var(--ink);cursor:pointer;transition:.14s}
.fi-sel select:hover{border-color:var(--teal)}
.fi-sel.set select{border-color:var(--teal-deep);background:var(--teal-soft);color:var(--teal-deep);font-weight:600}
.fi-sel::after{content:"";position:absolute;right:14px;width:8px;height:8px;border-right:2px solid var(--muted);
  border-bottom:2px solid var(--muted);transform:translateY(-2px) rotate(45deg);pointer-events:none}

.fi-divider{height:1px;background:var(--border-soft);margin:14px 0}
.fi-label{font-size:12.5px;font-weight:600;color:var(--muted);white-space:nowrap}

/* multiselect dropdown (self-contained — also used on catalog page) */
.ms{position:relative}
.ms-btn{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--border);
  border-radius:11px;padding:10px 14px;font-size:14px;font-weight:500;color:var(--ink);transition:.14s;cursor:pointer}
.ms-btn:hover{border-color:var(--teal)}
.ms-btn.on{border-color:var(--teal-deep);background:var(--teal-soft);color:var(--teal-deep);font-weight:600}
.ms-btn .car{width:8px;height:8px;border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);
  transform:rotate(45deg);transition:.2s;margin-left:2px}
.ms.open .ms-btn .car{transform:rotate(-135deg)}
.ms-menu{position:absolute;top:calc(100% + 8px);left:0;min-width:220px;background:#fff;border:1px solid var(--border);
  border-radius:var(--r);box-shadow:var(--shadow-lg);padding:8px;z-index:30;display:none;max-height:300px;overflow-y:auto}
.ms.open .ms-menu{display:block}
.ms-opt{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:9px;font-size:14px;cursor:pointer;transition:.12s}
.ms-opt:hover{background:var(--app)}
.ms-opt input{position:absolute;opacity:0;width:0;height:0}
.ms-box{width:19px;height:19px;border-radius:6px;border:1.5px solid var(--border);flex-shrink:0;position:relative;transition:.12s}
.ms-opt input:checked + .ms-box{background:var(--teal-deep);border-color:var(--teal-deep)}
.ms-opt input:checked + .ms-box::after{content:"";position:absolute;left:6px;top:2px;width:5px;height:10px;
  border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}
.fi-clear{font-size:13.5px;font-weight:600;color:var(--blue);padding:9px 12px;border-radius:10px;
  display:none;align-items:center;gap:6px}
.fi-clear.show{display:inline-flex}
.fi-clear:hover{background:var(--blue-soft)}
.fi-count{font-size:13.5px;color:var(--muted)}
.fi-count b{font-family:'IBM Plex Mono';color:var(--ink)}

/* disclaimer */
.disclaimer{display:flex;gap:13px;background:#FFFBEB;border:1px solid #FCE8B2;border-radius:var(--r);
  padding:14px 16px;margin-bottom:24px}
.disclaimer .di{width:26px;height:26px;border-radius:7px;background:#F6C453;color:#7a5a12;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px}
.disclaimer .dx{font-size:12.8px;color:#8a6d2a;line-height:1.55}
.disclaimer .dx b{color:#6b531c}

/* installer cards (extend .inst) */
.fi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:10px}
.fi-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow-sm);
  transition:.2s;display:flex;flex-direction:column}
.fi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.fi-card .top{display:flex;gap:13px;align-items:flex-start}
.fi-av{width:54px;height:54px;border-radius:14px;display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:700;font-size:20px;flex-shrink:0}
.fi-card .nm{font-size:16px;font-weight:700;line-height:1.25;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.fi-verified{color:var(--teal-deep);display:inline-flex}
.fi-type{font-size:10.5px;font-weight:600;padding:2px 8px;border-radius:999px;white-space:nowrap}
.fi-type.shop{background:var(--teal-soft);color:var(--teal-deep)}
.fi-type.pro{background:var(--blue-soft);color:#2b6fc4}
.fi-loc{font-size:12.5px;color:var(--muted);display:flex;align-items:center;gap:5px;margin-top:3px}
.fi-rate{display:flex;align-items:center;gap:7px;margin-top:13px;font-size:13px}
.fi-rate .stars{color:var(--star);letter-spacing:1px}
.fi-rate b{font-family:'IBM Plex Mono';font-weight:600}
.fi-rate span{color:var(--muted)}
.fi-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px}
.fi-tag{font-size:11px;color:var(--muted);background:var(--app);border:1px solid var(--border);padding:3px 9px;border-radius:7px}
.fi-brands{font-size:11.5px;color:var(--muted-2);margin-top:11px}
.fi-brands b{color:var(--muted);font-weight:600}
.fi-actions{display:flex;gap:8px;margin-top:15px}
.fi-actions .btn{flex:1}
.fi-empty{grid-column:1/-1;text-align:center;color:var(--muted);padding:50px 20px;display:flex;flex-direction:column;align-items:center;gap:14px}

/* partner CTA banner */
.partner-cta{margin:30px 0 14px}
.partner-card{background:var(--ink);border-radius:var(--r-xl);padding:42px 48px;position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:space-between;gap:32px}
.partner-card .glow{position:absolute;border-radius:999px;filter:blur(60px);opacity:.45}
.partner-card .tx{position:relative;z-index:2;max-width:560px}
.partner-card .overline{color:var(--teal)}
.partner-card h2{color:#fff;font-size:27px;font-weight:700;margin-top:10px;letter-spacing:-.01em}
.partner-card p{color:var(--muted-2);font-size:15px;margin-top:10px}
.partner-card .act{position:relative;z-index:2}
.partner-card .act .btn{font-size:16px;padding:15px 26px}

/* partner form modal fields reuse .field/.modal */
.pf-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.chip-pick{display:flex;gap:8px;flex-wrap:wrap}
.chip-opt{font-size:13px;border:1.5px solid var(--border);border-radius:999px;padding:7px 13px;transition:.14s;cursor:pointer}
.chip-opt:hover{border-color:var(--teal)}
.chip-opt.on{border-color:var(--teal-deep);background:var(--teal-soft);color:var(--teal-deep);font-weight:600}

@media(max-width:900px){ .fi-grid{grid-template-columns:1fr 1fr} }
@media(max-width:760px){
  .fi-filters{position:static}
  .fi-head h1{font-size:23px}
  .partner-card{flex-direction:column;align-items:flex-start;padding:30px 24px}
  .partner-card h2{font-size:21px}
}
@media(max-width:560px){ .fi-grid{grid-template-columns:1fr} .pf-grid{grid-template-columns:1fr} }

/* ============ Installer profile page ============ */
.ip-hero{background:#fff;border:1px solid var(--border);border-radius:var(--r-xl);padding:28px;margin:18px 0 22px;
  box-shadow:var(--shadow-sm);display:flex;gap:22px;align-items:flex-start;flex-wrap:wrap}
.ip-av{width:84px;height:84px;border-radius:20px;display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:700;font-size:30px;flex-shrink:0}
.ip-hd{flex:1;min-width:240px}
.ip-hd .nm{font-size:26px;font-weight:700;letter-spacing:-.01em;display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.ip-hd .loc{font-size:14px;color:var(--muted);display:flex;align-items:center;gap:6px;margin-top:6px}
.ip-hd .rate{display:flex;align-items:center;gap:9px;margin-top:12px;font-size:15px}
.ip-hd .rate .stars{color:var(--star);font-size:16px;letter-spacing:1.5px}
.ip-hd .rate b{font-family:'IBM Plex Mono';font-size:18px}
.ip-hd .rate span{color:var(--muted);font-size:13px}
.ip-cta{display:flex;flex-direction:column;gap:9px;min-width:200px}
.ip-cta .btn{width:100%}
.ip-cta .note{font-size:11.5px;color:var(--muted);text-align:center}
.ip-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:22px}
.ip-block{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:24px;box-shadow:var(--shadow-sm);margin-bottom:18px}
.ip-block h3{font-size:16px;font-weight:700;margin-bottom:12px}
.ip-block p{font-size:14.5px;color:var(--ink);line-height:1.7}
.ip-meta{display:flex;flex-direction:column;gap:0}
.ip-meta .mrow{display:flex;justify-content:space-between;gap:14px;padding:11px 0;border-bottom:1px solid var(--border-soft);font-size:13.5px}
.ip-meta .mrow:last-child{border-bottom:none}
.ip-meta .mrow .k{color:var(--muted)}
.ip-meta .mrow .v{font-weight:600;text-align:right}
.ip-maplink{color:var(--blue);font-weight:600;display:inline-flex;align-items:center;gap:5px}
.ip-maplink:hover{color:#2b86ea;text-decoration:underline}
.ip-stat{display:flex;gap:10px;margin-top:14px}
.ip-stat .s{flex:1;background:var(--app);border-radius:var(--r);padding:13px;text-align:center}
.ip-stat .s b{font-family:'IBM Plex Mono';font-size:20px;font-weight:600;display:block}
.ip-stat .s span{font-size:11.5px;color:var(--muted)}
.ip-rev{border-bottom:1px solid var(--border-soft);padding:15px 0}
.ip-rev:last-child{border-bottom:none}
.ip-rev .rh{display:flex;justify-content:space-between;align-items:center}
.ip-rev .stars{color:var(--star);font-size:14px;letter-spacing:1px}
.ip-rev .dt{font-size:12px;color:var(--muted-2)}
.ip-rev .tx{font-size:14px;color:var(--ink);margin:7px 0}
.ip-rev .by{font-size:12.5px;color:var(--muted);font-weight:600}
@media(max-width:820px){ .ip-grid{grid-template-columns:1fr} }


/* ===== blog.css ===== */
/* ============ Blog archive ============ */
.blog-head{padding:20px 0 6px}
.blog-head .overline{color:var(--teal-deep);-webkit-text-fill-color:initial;background:none}
.blog-head h1{font-size:30px;font-weight:700;letter-spacing:-.01em;margin-top:6px}
.blog-head p{color:var(--muted);font-size:15px;margin-top:6px;max-width:640px}

/* category chips */
.blog-cats{display:flex;gap:9px;flex-wrap:wrap;margin:18px 0 8px}
.blog-cat{font-size:13.5px;font-weight:600;color:var(--muted);background:#fff;border:1px solid var(--border);
  padding:8px 15px;border-radius:999px;transition:.14s;white-space:nowrap}
.blog-cat:hover{border-color:var(--teal);color:var(--teal-deep)}
.blog-cat.active{background:var(--teal-soft);border-color:var(--teal-deep);color:var(--teal-deep)}

/* featured post */
.blog-featured{background:#fff;border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;
  box-shadow:var(--shadow-sm);display:grid;grid-template-columns:0.8fr 1fr;margin:14px 0 30px;transition:.2s}
.blog-featured:hover{box-shadow:var(--shadow-md)}
.blog-featured .fthumb{position:relative;min-height:300px}
.blog-featured .fthumb .ph{position:absolute;inset:0}
.blog-featured .fbadge{position:absolute;top:16px;left:16px;font-size:11.5px;font-weight:700;color:var(--ink);
  background:var(--teal);padding:5px 12px;border-radius:999px;letter-spacing:.02em}
.blog-featured .fbody{padding:34px 38px;display:flex;flex-direction:column;justify-content:center}
.blog-featured .fcat{font-size:12.5px;font-weight:600;color:var(--teal-deep)}
.blog-featured h2{font-size:26px;font-weight:700;line-height:1.3;letter-spacing:-.01em;margin-top:8px}
.blog-featured p{font-size:15px;color:var(--muted);margin-top:12px;line-height:1.65}
.blog-featured .fmeta{display:flex;align-items:center;gap:10px;margin-top:18px;font-size:12.5px;color:var(--muted-2)}
.blog-featured .fmeta .dot{width:3px;height:3px;border-radius:999px;background:var(--muted-2)}
.blog-featured .fread{margin-top:20px;display:inline-flex;align-items:center;gap:6px;font-size:14.5px;font-weight:600;color:var(--teal-deep)}
.blog-featured:hover .fread{gap:10px}

/* layout: main + sidebar */
.blog-layout{display:grid;grid-template-columns:1fr 300px;gap:34px;align-items:start}
.blog-main .blog-grid{grid-template-columns:1fr 1fr;gap:22px}
.blog-empty{grid-column:1/-1;text-align:center;color:var(--muted);padding:50px 20px}

/* pagination */
.pagination{display:flex;gap:8px;justify-content:center;margin-top:34px}
.page-btn{min-width:40px;height:40px;border-radius:10px;border:1px solid var(--border);background:#fff;
  display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:var(--ink);transition:.14s;padding:0 6px}
.page-btn:hover{border-color:var(--teal);color:var(--teal-deep)}
.page-btn.active{background:var(--teal-deep);border-color:var(--teal-deep);color:#fff}
.page-btn:disabled{opacity:.4;cursor:not-allowed}

/* sidebar */
.blog-side{position:sticky;top:84px;display:flex;flex-direction:column;gap:18px}
.widget{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow-sm)}
.widget h3{font-size:14px;font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.widget h3::before{content:"";width:4px;height:15px;border-radius:2px;background:linear-gradient(var(--teal),var(--blue))}
.w-search{position:relative}
.w-search input{width:100%;border:1px solid var(--border);border-radius:10px;padding:10px 12px 10px 38px;
  font-family:inherit;font-size:14px;background:var(--app);transition:.14s}
.w-search input:focus{outline:none;border-color:var(--teal);background:#fff;box-shadow:0 0 0 3px rgba(68,215,197,.14)}
.w-search svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted-2)}
.w-catlist{display:flex;flex-direction:column}
.w-cat{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--border-soft);
  font-size:14px;color:var(--ink);transition:.12s;cursor:pointer}
.w-cat:last-child{border-bottom:none}
.w-cat:hover{color:var(--teal-deep);padding-left:4px}
.w-cat.active{color:var(--teal-deep);font-weight:600}
.w-cat .cnt{font-family:'IBM Plex Mono';font-size:12px;color:var(--muted);background:var(--app);border-radius:6px;padding:1px 8px}
.w-recent{display:flex;flex-direction:column;gap:14px}
.w-post{display:flex;gap:12px;align-items:center}
.w-post .wt{width:54px;height:67px;border-radius:9px;flex-shrink:0;position:relative;overflow:hidden}
.w-post .wt .ph{position:absolute;inset:0}
.w-post .wx h4{font-size:13px;font-weight:600;line-height:1.4;color:var(--ink);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.w-post .wx span{font-size:11.5px;color:var(--muted-2)}
.w-tags{display:flex;gap:8px;flex-wrap:wrap}
.w-tag{font-size:12px;color:var(--muted);background:var(--app);border:1px solid var(--border);padding:5px 11px;border-radius:999px;transition:.14s}
.w-tag:hover{border-color:var(--teal);color:var(--teal-deep)}

@media(max-width:900px){
  .blog-layout{grid-template-columns:1fr}
  .blog-side{position:static;flex-direction:row;flex-wrap:wrap}
  .blog-side .widget{flex:1;min-width:240px}
}
@media(max-width:760px){
  .blog-head h1{font-size:23px}
  .blog-featured{grid-template-columns:1fr}
  .blog-featured .fthumb{min-height:200px;aspect-ratio:16/10}
  .blog-featured .fbody{padding:24px}
  .blog-featured h2{font-size:21px}
  .blog-main .blog-grid{grid-template-columns:1fr 1fr;gap:14px}
}
@media(max-width:520px){ .blog-main .blog-grid{grid-template-columns:1fr} .blog-side{flex-direction:column} }

/* ============ Single post ============ */
.post-hero{position:relative;border-radius:var(--r-xl);overflow:hidden;margin:18px 0 0;aspect-ratio:21/9;box-shadow:var(--shadow-md)}
.post-hero .ph{position:absolute;inset:0}
.post-hero .grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(8,18,38,.6),transparent 60%)}
.post-article{max-width:760px;margin:0 auto;padding:0 var(--gut)}
.post-head{padding:28px 0 10px}
.post-head .pcat{font-size:13px;font-weight:600;color:var(--teal-deep)}
.post-head h1{font-size:33px;font-weight:700;line-height:1.25;letter-spacing:-.015em;margin-top:10px}
.post-head .pmeta{display:flex;align-items:center;gap:11px;margin-top:16px;font-size:13.5px;color:var(--muted);padding-bottom:20px;border-bottom:1px solid var(--border)}
.post-head .pmeta .av{width:34px;height:34px;border-radius:999px;background:linear-gradient(135deg,var(--teal),var(--blue));
  color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px}
.post-head .pmeta .dot{width:3px;height:3px;border-radius:999px;background:var(--muted-2)}
.post-content{padding:24px 0 10px;font-size:16px;line-height:1.85;color:var(--ink)}
.post-content p{margin-bottom:18px}
.post-content h3{font-size:20px;font-weight:700;margin:28px 0 10px;letter-spacing:-.01em}
.post-share{display:flex;align-items:center;gap:12px;padding:22px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin:16px 0 30px}
.post-share span{font-size:13.5px;font-weight:600;color:var(--muted)}
.post-share a{width:38px;height:38px;border-radius:10px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--muted);transition:.14s}
.post-share a:hover{border-color:var(--teal);color:var(--teal-deep);background:var(--teal-soft)}
.related h2{font-size:20px;font-weight:700;margin-bottom:18px}
.related .blog-grid{grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:760px){
  .post-head h1{font-size:25px}
  .post-content{font-size:15px}
  .post-hero{aspect-ratio:16/9}
  .related .blog-grid{grid-template-columns:1fr 1fr;gap:14px}
}
@media(max-width:520px){ .related .blog-grid{grid-template-columns:1fr} }


/* ===== about.css ===== */
/* ============ About page ============ */
.about-hero{padding:46px 0 30px;text-align:center;max-width:760px;margin:0 auto}
.about-hero .overline{color:var(--teal-deep);-webkit-text-fill-color:initial;background:none}
.about-hero h1{font-size:38px;font-weight:700;letter-spacing:-.015em;line-height:1.2;margin-top:12px}
.about-hero h1 .grad{background:linear-gradient(90deg,var(--teal-deep),var(--blue));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.about-hero p{font-size:16.5px;color:var(--muted);margin-top:18px;line-height:1.7}
.about-logo{width:64px;height:64px;border-radius:18px;background:linear-gradient(135deg,var(--teal),var(--blue));
  display:flex;align-items:center;justify-content:center;margin:0 auto 6px;box-shadow:0 10px 28px -10px rgba(68,215,197,.6);overflow:hidden}
.about-logo img{width:78%}

/* values */
.values{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin:14px 0 6px}
.value{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:24px 22px;box-shadow:var(--shadow-sm);transition:.2s}
.value:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.value .vic{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;
  background:var(--teal-soft);color:var(--teal-deep);margin-bottom:15px}
.value h3{font-size:17px;font-weight:700;letter-spacing:-.01em}
.value p{font-size:13.5px;color:var(--muted);margin-top:8px;line-height:1.6}

/* story */
.story{background:#fff;border:1px solid var(--border);border-radius:var(--r-xl);padding:40px 44px;box-shadow:var(--shadow-sm);margin:14px 0}
.story h2{font-size:22px;font-weight:700;letter-spacing:-.01em}
.story p{font-size:15px;color:var(--ink);line-height:1.8;margin-top:14px}
.story p .hl{color:var(--teal-deep);font-weight:600}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;background:var(--ink);border-radius:var(--r-xl);
  overflow:hidden;margin:14px 0}
.stat{padding:32px 20px;text-align:center;border-left:1px solid rgba(255,255,255,.08)}
.stat:first-child{border-left:none}
.stat b{font-family:'IBM Plex Mono';font-size:34px;font-weight:600;color:#fff;display:block;line-height:1}
.stat b .u{font-size:18px;color:var(--teal)}
.stat span{font-size:13px;color:var(--muted-2);margin-top:8px;display:block}

.section-label{text-align:center;margin-bottom:24px}
.section-label .overline{display:inline-block}
.section-label h2{font-size:24px;font-weight:700;margin-top:8px;letter-spacing:-.01em}

@media(max-width:900px){ .values{grid-template-columns:1fr 1fr} .stats{grid-template-columns:1fr 1fr} .stat:nth-child(3){border-left:none} }
@media(max-width:760px){
  .about-hero h1{font-size:28px}
  .story{padding:28px 22px}
}
@media(max-width:520px){ .values{grid-template-columns:1fr} .stats{grid-template-columns:1fr 1fr} }


/* ===== legal.css ===== */
/* ============ Legal pages ============ */
.legal-wrap{max-width:1080px;margin:0 auto;padding:0 var(--gut)}
.legal-head{padding:22px 0 10px}
.legal-head .overline{color:var(--teal-deep);-webkit-text-fill-color:initial;background:none}
.legal-head h1{font-size:30px;font-weight:700;letter-spacing:-.01em;margin-top:6px}
.legal-head .updated{font-size:13px;color:var(--muted-2);margin-top:8px;font-family:'IBM Plex Mono'}

.legal-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0 24px;border-bottom:1px solid var(--border);padding-bottom:0}
.legal-tab{font-size:14px;font-weight:600;color:var(--muted);padding:11px 16px;border-radius:10px 10px 0 0;
  border-bottom:2px solid transparent;transition:.14s;white-space:nowrap}
.legal-tab:hover{color:var(--teal-deep);background:var(--app)}
.legal-tab.active{color:var(--teal-deep);border-bottom-color:var(--teal-deep)}

.legal-doc{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:38px 44px;
  box-shadow:var(--shadow-sm);margin-bottom:24px}
.legal-lang{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;color:var(--teal-deep);background:var(--teal-soft);padding:6px 13px;border-radius:999px;margin-bottom:18px}
.legal-section + .legal-section{margin-top:36px;padding-top:36px;border-top:1px dashed var(--border)}
.legal-body{color:var(--ink);line-height:1.75}
.legal-body p{font-size:14.5px;color:var(--ink);margin-bottom:14px}
.legal-body h3{font-size:16px;font-weight:700;margin:24px 0 9px;letter-spacing:-.005em}
.legal-body h3:first-child{margin-top:0}
.legal-body ul{margin:0 0 14px;padding-left:4px;list-style:none}
.legal-body li{font-size:14.5px;color:var(--ink);padding-left:22px;position:relative;margin-bottom:8px;line-height:1.65}
.legal-body li::before{content:"";position:absolute;left:4px;top:10px;width:6px;height:6px;border-radius:999px;background:var(--teal)}
.legal-body strong{color:var(--ink);font-weight:700}
.legal-anchor{font-size:13px;color:var(--blue);font-weight:600;margin-bottom:18px;display:inline-flex;align-items:center;gap:6px}
.legal-anchor:hover{text-decoration:underline}

.legal-foot-note{background:var(--app);border:1px solid var(--border);border-radius:var(--r);padding:16px 18px;
  font-size:13px;color:var(--muted);display:flex;gap:11px;align-items:flex-start}
.legal-foot-note svg{color:var(--teal-deep);flex-shrink:0;margin-top:1px}

@media(max-width:760px){
  .legal-head h1{font-size:23px}
  .legal-doc{padding:24px 20px}
  .legal-section + .legal-section{margin-top:28px;padding-top:28px}
}
/* footer legal links (added to all pages) */
.foot-legal{display:flex;gap:18px;flex-wrap:wrap}
.foot-legal a{color:var(--muted-2);font-size:12.5px;transition:.14s}
.foot-legal a:hover{color:var(--teal-deep)}

/* crisp logo sizing (override base) */
.nav-logo img{height:46px !important;width:auto !important;max-width:230px !important;object-fit:contain}
.foot-logo img{height:44px !important;width:auto !important;max-width:220px !important;object-fit:contain}


