:root {
      --bg:        #f8f9fc;
      --surface:   #ffffff;
      --surface2:  #f1f3f8;
      --border:    #e5e8f0;
      --border2:   #d0d5e8;
      --ink:       #0f1117;
      --ink2:      #2d3148;
      --ink3:      #5a6080;
      --ink4:      #9098b8;
      --accent:    #4f46e5;
      --accent-s:  #ede9fe;
      --accent-b:  #c4b5fd;
      --green:     #059669;
      --green-s:   #ecfdf5;
      --green-b:   #6ee7b7;
      --red:       #dc2626;
      --red-s:     #fef2f2;
      --red-b:     #fca5a5;
      --amber:     #d97706;
      --amber-s:   #fffbeb;
      --amber-b:   #fcd34d;
      --blue:      #2563eb;
      --blue-s:    #eff6ff;
      --blue-b:    #93c5fd;
      --r:         10px;
      --r-lg:      16px;
      --r-xl:      22px;
      --shadow-sm: 0 1px 3px rgba(15,17,23,.06), 0 1px 2px rgba(15,17,23,.04);
      --shadow:    0 4px 16px rgba(15,17,23,.08), 0 1px 4px rgba(15,17,23,.04);
      --shadow-lg: 0 12px 40px rgba(15,17,23,.12), 0 4px 12px rgba(15,17,23,.06);
    }

    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; }
    body {
      font-family: 'Plus Jakarta Sans', sans-serif;
      background: var(--bg); color: var(--ink);
      font-size: 15px; line-height: 1.7;
      -webkit-font-smoothing: antialiased;
    }
    h1,h2,h3,h4 { font-family: 'Outfit', sans-serif; line-height: 1.2; }
    a { color: var(--accent); text-decoration: none; }
    a:hover { text-decoration: underline; }
    img { max-width: 100%; }

    /* ══ HERO ══ */
    .hero-new { background: transparent; }
    .hero-grid {
      display: grid;
      grid-template-columns: 1fr 480px;
      gap: 32px; align-items: start;
    }
    .hero-grid.no-yt { grid-template-columns: 1fr; }
    .hero-id {
      display: flex; align-items: flex-start;
      gap: 16px; margin-bottom: 14px;
    }
    .hero-logo-wrap { flex-shrink: 0; position: relative; }
    .hero-logo-img {
      width: 64px; height: 64px; border-radius: 14px;
      object-fit: contain; background: var(--surface2);
      border: 1px solid var(--border); display: block;
    }
    .hero-logo-fb {
      width: 64px; height: 64px; border-radius: 14px;
      background: var(--accent-s); border: 1px solid var(--accent-b);
      display: flex; align-items: center; justify-content: center;
      font-family: 'Outfit', sans-serif; font-size: 26px;
      font-weight: 800; color: var(--accent);
    }
    .hero-v-dot {
      position: absolute; bottom: -3px; right: -3px;
      width: 18px; height: 18px; border-radius: 50%;
      background: var(--green); border: 2px solid var(--bg);
      display: flex; align-items: center; justify-content: center;
      font-size: 9px; font-weight: 800; color: #fff;
    }
    .hero-name-block { flex: 1; min-width: 0; padding-top: 2px; }
    .hero-tool-name {
      font-family: 'Outfit', sans-serif;
      font-size: clamp(22px, 3vw, 30px);
      font-weight: 800; color: var(--ink);
      letter-spacing: -.4px; line-height: 1.15;
      margin: 0 0 6px 0;
    }
    .hero-rating-row { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
    .h-stars { display: flex; gap: 1px; }
    .h-star  { font-size: 16px; color: #f59e0b; }
    .h-star.empty { color: #d1d5db; }
    .v-chip {
      display: inline-flex; align-items: center; gap: 3px;
      color: #2563eb; font-size: 12.5px; font-weight: 600;
    }
    .feat-chip {
      display: inline-flex; align-items: center; gap: 3px;
      background: var(--amber-s); color: var(--amber);
      border: 1px solid var(--amber-b);
      font-size: 11px; font-weight: 700;
      padding: 2px 8px; border-radius: 100px;
    }
    .hero-desc { font-size: 15px; color: var(--ink2); line-height: 1.7; margin: 16px 0; }
    .hero-meta { display: flex; flex-direction: column; gap: 8px; margin-bottom: 20px; }
    .hm-row { display: flex; align-items: flex-start; gap: 6px; flex-wrap: wrap; }
    .hm-key {
      font-size: 13.5px; font-weight: 700; color: var(--ink);
      flex-shrink: 0; min-width: fit-content;
    }
    .hm-key::after { content: ':'; }
    .hm-val {
      display: flex; flex-wrap: wrap; gap: 5px; align-items: center;
      font-size: 13.5px; color: var(--ink3);
    }
    .hm-link {
      color: #2563eb; font-size: 13.5px; font-weight: 500;
      text-decoration: none; transition: text-decoration .1s;
    }
    .hm-link:hover { text-decoration: underline; }
    .pricing-chip { display: inline-flex; align-items: center; gap: 5px; font-size: 13.5px; color: var(--ink3); }
    .pricing-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
    .pricing-dot.free     { background: var(--green); }
    .pricing-dot.freemium { background: var(--accent); }
    .pricing-dot.paid     { background: var(--amber); }
    .pricing-dot.unknown  { background: var(--ink4); }
    .pill-tag {
      display: inline-flex; align-items: center;
      background: var(--surface2); color: var(--ink3);
      border: 1px solid var(--border2);
      font-size: 12px; font-weight: 500;
      padding: 3px 10px; border-radius: 100px; transition: all .15s;
    }
    .pill-tag:hover { background: var(--accent-s); color: var(--accent); border-color: var(--accent-b); text-decoration: none; }
    .follow-icons { display: flex; flex-wrap: wrap; gap: 5px; }
    .follow-icon {
      width: 28px; height: 28px; border-radius: 6px;
      display: flex; align-items: center; justify-content: center;
      border: 1px solid var(--border2); background: var(--surface2);
      color: var(--ink3); transition: all .12s; text-decoration: none;
    }
    .follow-icon:hover { transform: translateY(-1px); }
    .follow-icon.twitter:hover, .follow-icon.x:hover { background:#000;color:#fff;border-color:#000; }
    .follow-icon.linkedin:hover  { background:#0a66c2;color:#fff;border-color:#0a66c2; }
    .follow-icon.youtube:hover   { background:#ff0000;color:#fff;border-color:#ff0000; }
    .follow-icon.instagram:hover { background:#e1306c;color:#fff;border-color:#e1306c; }
    .follow-icon.facebook:hover  { background:#1877f2;color:#fff;border-color:#1877f2; }
    .follow-icon.tiktok:hover    { background:#000;color:#fff;border-color:#000; }
    .follow-icon.github:hover    { background:#333;color:#fff;border-color:#333; }
    .hero-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
    .hero-yt-col {}
    .hero-yt-box { border-radius: 12px; overflow: hidden; border: 1px solid var(--border); background: #000; }
    .hero-yt-wrap { position: relative; width: 100%; padding-bottom: 56.25%; height: 0; overflow: hidden; }
    .hero-yt-wrap iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: none; }

    /* ══ BREADCRUMB ══ */
    .breadcrumb {
      max-width: 1280px; margin: 0 auto;
      padding: 14px 28px 0;
      display: flex; align-items: center; gap: 5px;
      font-size: 12px; color: var(--ink4);
    }
    .breadcrumb a { color: var(--ink3); transition: color .15s; }
    .breadcrumb a:hover { color: var(--ink); text-decoration: none; }
    .breadcrumb .sep { color: var(--border2); }
    .breadcrumb .cur { color: var(--ink2); font-weight: 600; }

    /* ══ PAGE LAYOUT ══ */
    .page {
      max-width: 1280px; margin: 0 auto;
      padding: 20px 28px 80px;
      display: grid;
      grid-template-columns: 1fr 300px;
      gap: 24px; align-items: start;
    }
    .main { display: flex; flex-direction: column; gap: 20px; min-width: 0; }
    .side { display: flex; flex-direction: column; gap: 16px; position: sticky; top: 20px; align-self: start; }

    /* ══ STAT STRIP ══ */
    .stat-strip {
      display: grid; grid-template-columns: repeat(4, 1fr);
      background: var(--surface); border: 1px solid var(--border);
      border-radius: var(--r-lg); box-shadow: var(--shadow-sm); overflow: hidden;
    }
    .stat-item { padding: 16px 18px; text-align: center; border-right: 1px solid var(--border); }
    .stat-item:last-child { border-right: none; }
    .stat-val { font-family: 'Outfit', sans-serif; font-size: 22px; font-weight: 800; color: var(--accent); line-height: 1; }
    .stat-lbl { font-size: 11.5px; color: var(--ink4); margin-top: 3px; }

    /* ══ TABS ══ */
    .tabs {
      background: var(--surface); border: 1px solid var(--border);
      border-radius: var(--r-lg); box-shadow: var(--shadow-sm);
      display: flex; overflow-x: auto; scrollbar-width: none;
    }
    .tabs::-webkit-scrollbar { display: none; }
    .tab {
      padding: 13px 20px; font-size: 13px; font-weight: 600;
      color: var(--ink3); cursor: pointer; white-space: nowrap;
      border-bottom: 2px solid transparent; transition: color .15s, border-color .15s;
    }
    .tab:hover { color: var(--ink); }
    .tab.active { color: var(--accent); border-bottom-color: var(--accent); }

    /* ══ CONTENT CARD ══ */
    .card {
      background: var(--surface); border: 1px solid var(--border);
      border-radius: var(--r-xl); box-shadow: var(--shadow-sm); overflow: hidden;
    }
    .section { padding: 26px 28px; border-bottom: 1px solid var(--border); }
    .section:last-child { border-bottom: none; }
    .sec-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
    .sec-title {
      font-family: 'Outfit', sans-serif;
      font-size: 16px; font-weight: 700; color: var(--ink);
      display: flex; align-items: center; gap: 8px;
    }
    .sec-icon {
      width: 30px; height: 30px; border-radius: 8px;
      background: var(--accent-s); border: 1px solid var(--accent-b);
      display: flex; align-items: center; justify-content: center;
      font-size: 15px; flex-shrink: 0;
    }
    .updated-pill {
      display: inline-flex; align-items: center; gap: 5px;
      font-size: 11px; color: var(--ink4);
      background: var(--surface2); border: 1px solid var(--border);
      border-radius: 100px; padding: 3px 10px;
    }
    .body-text { font-size: 14.5px; color: var(--ink3); line-height: 1.8; }

    /* ══ FEATURES ══ */
    .feat-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
    .feat-item {
      padding: 14px 16px; background: var(--bg);
      border: 1px solid var(--border); border-radius: var(--r); transition: all .15s;
    }
    .feat-item:hover { border-color: var(--accent-b); background: var(--accent-s); }
    .feat-num {
      width: 22px; height: 22px; border-radius: 6px;
      background: var(--accent); color: #fff;
      font-size: 11px; font-weight: 700;
      display: inline-flex; align-items: center; justify-content: center; margin-bottom: 8px;
    }
    .feat-title { font-size: 13px; font-weight: 700; color: var(--ink2); margin-bottom: 4px; }
    .feat-desc  { font-size: 12.5px; color: var(--ink4); line-height: 1.55; }

    /* ══ PROS CONS ══ */
    .pc-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
    .pc-col  { border-radius: var(--r); overflow: hidden; }
    .pc-head {
      padding: 10px 14px; font-size: 12px; font-weight: 700;
      text-transform: uppercase; letter-spacing: .06em;
      display: flex; align-items: center; gap: 6px;
    }
    .pc-head.pro { background: var(--green-s); color: var(--green); border-bottom: 1px solid var(--green-b); }
    .pc-head.con { background: var(--red-s);   color: var(--red);   border-bottom: 1px solid var(--red-b); }
    .pc-list { display: flex; flex-direction: column; }
    .pc-item {
      display: flex; align-items: flex-start; gap: 10px;
      padding: 10px 14px; border-bottom: 1px solid var(--border);
      font-size: 13.5px; line-height: 1.5;
    }
    .pc-item:last-child { border-bottom: none; }
    .pc-item.pro { background: var(--green-s); color: #064e3b; }
    .pc-item.con { background: var(--red-s);   color: #7f1d1d; }
    .pc-dot {
      width: 18px; height: 18px; border-radius: 50%; flex-shrink: 0; margin-top: 1px;
      display: flex; align-items: center; justify-content: center;
      font-size: 10px; font-weight: 800; color: #fff;
    }
    .pc-dot.pro { background: var(--green); }
    .pc-dot.con { background: var(--red); }

    /* ══ WHO IS USING ══ */
    .who-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 10px; }
    .who-item {
      padding: 14px; background: var(--bg); border: 1px solid var(--border);
      border-radius: var(--r); transition: all .15s; text-align: center;
    }
    .who-item:hover { border-color: var(--blue-b); background: var(--blue-s); }
    .who-icon  { font-size: 22px; margin-bottom: 6px; }
    .who-title { font-size: 13px; font-weight: 700; color: var(--ink2); margin-bottom: 3px; }
    .who-desc  { font-size: 11.5px; color: var(--ink4); line-height: 1.4; }

    /* ══ RATINGS ══ */
    .ratings-wrap { display: flex; flex-direction: column; gap: 11px; }
    .rating-line  { display: flex; align-items: center; gap: 12px; }
    .rating-lbl   { flex: 0 0 190px; font-size: 13px; color: var(--ink3); }
    .rating-bar   { flex: 1; height: 7px; background: var(--surface2); border-radius: 10px; overflow: hidden; }
    .rating-fill  {
      height: 100%; background: linear-gradient(90deg, var(--accent) 0%, #818cf8 100%);
      border-radius: 10px; transition: width 1.2s cubic-bezier(.4,0,.2,1);
    }
    .rating-score { flex: 0 0 36px; text-align: right; font-size: 13px; font-weight: 700; color: var(--accent); }

    /* ══ PRICING ══ */
    .pricing-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
    .plan {
      border: 1.5px solid var(--border); border-radius: var(--r-lg); padding: 20px;
      transition: all .15s; position: relative; overflow: hidden;
    }
    .plan:hover { border-color: var(--accent-b); box-shadow: 0 4px 20px rgba(79,70,229,.1); }
    .plan.popular { border-color: var(--accent); }
    .plan-badge {
      position: absolute; top: 12px; right: 12px;
      background: var(--accent); color: #fff;
      font-size: 10px; font-weight: 700; padding: 3px 8px; border-radius: 100px;
      text-transform: uppercase; letter-spacing: .05em;
    }
    .plan-name  { font-family: 'Outfit', sans-serif; font-size: 16px; font-weight: 700; color: var(--ink); margin-bottom: 4px; }
    .plan-price { font-family: 'Outfit', sans-serif; font-size: 28px; font-weight: 800; color: var(--accent); margin-bottom: 8px; line-height: 1; }
    .plan-desc  { font-size: 13px; color: var(--ink3); line-height: 1.6; }

    /* ══ TAG CLOUDS ══ */
    .tag-wrap { display: flex; flex-wrap: wrap; gap: 7px; }
    .tag-use {
      background: var(--accent-s); color: var(--accent);
      border: 1px solid var(--accent-b);
      font-size: 12.5px; font-weight: 600; padding: 4px 12px; border-radius: 100px;
    }
    .tag-ind {
      background: var(--green-s); color: var(--green);
      border: 1px solid var(--green-b);
      font-size: 12.5px; font-weight: 600; padding: 4px 12px; border-radius: 100px;
    }

    /* ══ FAQ ══ */
    .faq-wrap { display: flex; flex-direction: column; gap: 6px; }
    .faq-item { border: 1px solid var(--border); border-radius: var(--r); overflow: hidden; transition: border-color .15s; }
    .faq-item:hover { border-color: var(--accent-b); }
    .faq-item.open  { border-color: var(--accent); }
    .faq-q {
      padding: 14px 16px; cursor: pointer;
      font-family: 'Outfit', sans-serif; font-size: 14px; font-weight: 700; color: var(--ink);
      display: flex; justify-content: space-between; align-items: center; gap: 10px;
      background: var(--surface); transition: background .15s;
    }
    .faq-item.open .faq-q { background: var(--accent-s); color: var(--accent); }
    .faq-arrow {
      flex-shrink: 0; width: 22px; height: 22px; border-radius: 50%;
      background: var(--surface2); border: 1px solid var(--border);
      display: flex; align-items: center; justify-content: center;
      font-size: 12px; color: var(--ink3); transition: all .2s;
    }
    .faq-item.open .faq-arrow { background: var(--accent); color: #fff; border-color: var(--accent); transform: rotate(45deg); }
    .faq-a {
      display: none; padding: 14px 16px;
      font-size: 13.5px; color: var(--ink3); line-height: 1.75;
      border-top: 1px solid var(--border); background: var(--bg);
    }
    .faq-item.open .faq-a { display: block; }

    /* ══ VERDICT ══ */
    .verdict {
      background: linear-gradient(135deg, var(--accent) 0%, #7c3aed 100%);
      border-radius: var(--r-lg); padding: 24px; position: relative; overflow: hidden;
    }
    .verdict::before {
      content: '\201C'; position: absolute; top: -16px; left: 14px;
      font-family: 'Outfit', sans-serif; font-size: 90px;
      color: rgba(255,255,255,.1); line-height: 1; pointer-events: none;
    }
    .verdict-tag {
      font-size: 10px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
      color: rgba(255,255,255,.65); display: flex; align-items: center; gap: 6px; margin-bottom: 10px;
    }
    .verdict-tag::before { content: ''; width: 14px; height: 2px; background: rgba(255,255,255,.65); display: block; }
    .verdict-text { font-family: 'Outfit', sans-serif; font-size: 16px; font-style: italic; color: #fff; line-height: 1.7; position: relative; }
    .verdict-author { margin-top: 10px; font-size: 12px; color: rgba(255,255,255,.55); }

    /* ══ REVIEWS ══ */
    .review-summary { display: flex; gap: 24px; align-items: center; margin-bottom: 20px; }
    .review-big { text-align: center; flex-shrink: 0; }
    .review-num { font-family: 'Outfit', sans-serif; font-size: 52px; font-weight: 800; color: var(--ink); line-height: 1; }
    .review-sub { font-size: 12px; color: var(--ink4); margin-top: 3px; }
    .review-bars { flex: 1; display: flex; flex-direction: column; gap: 6px; }
    .rbar-row { display: flex; align-items: center; gap: 8px; font-size: 12px; }
    .rbar-lbl  { color: var(--amber); font-size: 11px; width: 40px; text-align: right; flex-shrink: 0; }
    .rbar-bg   { flex: 1; height: 6px; background: var(--surface2); border-radius: 3px; overflow: hidden; }
    .rbar-fill { height: 100%; background: var(--amber); border-radius: 3px; }
    .rbar-cnt  { color: var(--ink4); width: 24px; text-align: right; flex-shrink: 0; }
    .review-cards { display: flex; flex-direction: column; gap: 12px; }
    .review-card { padding: 16px; background: var(--bg); border: 1px solid var(--border); border-radius: var(--r); }
    .rc-top    { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
    .rc-avatar {
      width: 36px; height: 36px; border-radius: 50%;
      background: var(--accent-s); border: 1px solid var(--accent-b);
      display: flex; align-items: center; justify-content: center;
      font-size: 14px; font-weight: 700; color: var(--accent); flex-shrink: 0;
    }
    .rc-name  { font-size: 13.5px; font-weight: 700; color: var(--ink2); }
    .rc-meta  { font-size: 11.5px; color: var(--ink4); }
    .rc-stars { color: var(--amber); font-size: 12px; letter-spacing: 1px; }
    .rc-text  { font-size: 13.5px; color: var(--ink3); line-height: 1.65; }

    /* ══ REVIEW FORM ══ */
    .review-form-wrap {
      background: var(--bg); border: 1.5px solid var(--accent-b);
      border-radius: var(--r-lg); padding: 20px; margin-bottom: 20px;
    }
    .review-form-title { font-family: 'Outfit', sans-serif; font-size: 15px; font-weight: 700; color: var(--ink); margin-bottom: 14px; }
    .star-picker { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; flex-wrap: wrap; }
    .sp-label { font-size: 13px; font-weight: 600; color: var(--ink3); }
    .sp-stars  { display: flex; gap: 4px; }
    .sp-star {
      font-size: 24px; color: var(--border2); cursor: pointer;
      transition: color .1s, transform .1s; line-height: 1;
    }
    .sp-star.active, .sp-star.hover { color: var(--amber); transform: scale(1.15); }
    .sp-txt { font-size: 12px; color: var(--ink4); }
    .rf-fields { display: flex; gap: 12px; margin-bottom: 14px; flex-wrap: wrap; }
    .rf-field  { display: flex; flex-direction: column; gap: 5px; flex: 1; min-width: 160px; }
    .rf-label  { font-size: 12px; font-weight: 600; color: var(--ink3); }
    .rf-input, .rf-textarea {
      border: 1.5px solid var(--border2); border-radius: var(--r);
      padding: 9px 12px; font-size: 13.5px; font-family: inherit;
      color: var(--ink); background: var(--surface);
      transition: border-color .15s; outline: none; resize: vertical;
    }
    .rf-input:focus, .rf-textarea:focus { border-color: var(--accent); }
    .rf-submit {
      display: inline-flex; align-items: center; gap: 7px;
      background: var(--accent); color: #fff;
      padding: 10px 20px; border-radius: var(--r);
      font-size: 13.5px; font-weight: 700; border: none; cursor: pointer;
      transition: opacity .15s, transform .12s;
      box-shadow: 0 2px 10px rgba(79,70,229,.3);
    }
    .rf-submit:hover { opacity: .88; transform: translateY(-1px); }
    .rf-submit:disabled { opacity: .5; cursor: not-allowed; transform: none; }
    .rf-note { font-size: 11.5px; color: var(--ink4); }
    .rf-msg { margin-top: 12px; padding: 10px 14px; border-radius: var(--r); font-size: 13px; font-weight: 600; }
    .rf-msg.success { background: var(--green-s); color: var(--green); border: 1px solid var(--green-b); }
    .rf-msg.error   { background: var(--red-s);   color: var(--red);   border: 1px solid var(--red-b); }

    /* ══ ALTERNATIVES ══ */
    .alt-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 10px; }
    .alt-card {
      padding: 14px; background: var(--bg); border: 1px solid var(--border);
      border-radius: var(--r); display: flex; flex-direction: column; gap: 8px; transition: all .15s;
    }
    .alt-card:hover { border-color: var(--accent-b); box-shadow: var(--shadow-sm); text-decoration: none; }
    .alt-top   { display: flex; align-items: center; gap: 10px; }
    .alt-logo  {
      width: 36px; height: 36px; border-radius: 9px;
      object-fit: contain; background: var(--surface);
      border: 1px solid var(--border); flex-shrink: 0;
    }
    .alt-logo-fb {
      width: 36px; height: 36px; border-radius: 9px;
      background: var(--accent-s); border: 1px solid var(--accent-b);
      display: flex; align-items: center; justify-content: center;
      font-family: 'Outfit', sans-serif; font-size: 15px;
      font-weight: 800; color: var(--accent); flex-shrink: 0;
    }
    .alt-name  { font-size: 13.5px; font-weight: 700; color: var(--ink2); }
    .alt-cat   { font-size: 11px; color: var(--ink4); }
    .alt-desc  { font-size: 12px; color: var(--ink3); line-height: 1.5; }
    .alt-badge { align-self: flex-start; }

    /* ══ BADGES ══ */
    .badge {
      display: inline-flex; align-items: center; gap: 4px;
      font-size: 11.5px; font-weight: 700; padding: 3px 10px;
      border-radius: 100px; letter-spacing: .02em;
    }
    .b-purple { background: var(--accent-s); color: var(--accent);  border: 1px solid var(--accent-b); }
    .b-green  { background: var(--green-s);  color: var(--green);   border: 1px solid var(--green-b); }
    .b-amber  { background: var(--amber-s);  color: var(--amber);   border: 1px solid var(--amber-b); }
    .b-blue   { background: var(--blue-s);   color: var(--blue);    border: 1px solid var(--blue-b); }
    .b-gray   { background: var(--surface2); color: var(--ink3);    border: 1px solid var(--border2); }
    .b-red    { background: var(--red-s);    color: var(--red);     border: 1px solid var(--red-b); }

    /* ══ SIDEBAR ══ */
    .sb-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); box-shadow: var(--shadow-sm); overflow: hidden; }
    .sb-head {
      padding: 11px 16px; background: var(--surface2); border-bottom: 1px solid var(--border);
      font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--ink4);
    }
    .sb-body { padding: 14px 16px; }
    .meta-list { display: flex; flex-direction: column; }
    .meta-row {
      display: flex; justify-content: space-between; align-items: center;
      padding: 8px 0; border-bottom: 1px solid var(--border); font-size: 13px;
    }
    .meta-row:last-child { border-bottom: none; }
    .meta-row .k { color: var(--ink4); font-size: 12px; }
    .meta-row .v { font-weight: 700; color: var(--ink); font-size: 12.5px; text-align: right; max-width: 55%; }
    .sb-ratings { display: flex; flex-direction: column; gap: 9px; }
    .sb-rrow    { display: flex; align-items: center; gap: 8px; }
    .sb-rlbl    { flex: 1; font-size: 12px; color: var(--ink3); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .sb-rbar    { width: 56px; height: 4px; background: var(--surface2); border-radius: 2px; flex-shrink: 0; }
    .sb-rfill   { height: 100%; border-radius: 2px; background: linear-gradient(90deg, var(--accent), #818cf8); transition: width .8s ease; }
    .sb-rval    { font-size: 12px; font-weight: 700; color: var(--accent); width: 26px; text-align: right; flex-shrink: 0; }
    .overall-wrap { margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--border); text-align: center; }
    .overall-big  { font-family: 'Outfit', sans-serif; font-size: 42px; font-weight: 800; color: var(--accent); line-height: 1; }
    .overall-denom { font-size: 16px; font-weight: 400; color: var(--ink4); }
    .overall-lbl   { font-size: 11px; color: var(--ink4); margin-top: 2px; text-transform: uppercase; letter-spacing: .06em; }
    .sb-tags { display: flex; flex-wrap: wrap; gap: 6px; }
    .sb-tag {
      background: var(--surface2); border: 1px solid var(--border2);
      color: var(--ink3); font-size: 11.5px; font-weight: 600;
      padding: 3px 10px; border-radius: 100px; transition: all .15s;
    }
    .sb-tag:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-s); text-decoration: none; }
    .sb-tool-list { display: flex; flex-direction: column; gap: 10px; }
    .sb-tool {
      display: flex; align-items: center; gap: 10px;
      padding: 10px; border: 1px solid var(--border); border-radius: var(--r);
      background: var(--bg); transition: all .15s;
    }
    .sb-tool:hover { border-color: var(--accent-b); background: var(--accent-s); text-decoration: none; }
    .sb-tool-logo {
      width: 36px; height: 36px; border-radius: 9px;
      object-fit: contain; background: var(--surface);
      border: 1px solid var(--border); flex-shrink: 0;
    }
    .sb-tool-logo-fb {
      width: 36px; height: 36px; border-radius: 9px;
      background: var(--accent-s); border: 1px solid var(--accent-b);
      display: flex; align-items: center; justify-content: center;
      font-family: 'Outfit', sans-serif; font-size: 14px;
      font-weight: 800; color: var(--accent); flex-shrink: 0;
    }
    .sb-tool-info { flex: 1; min-width: 0; }
    .sb-tool-name { font-size: 13px; font-weight: 700; color: var(--ink2); display: block; }
    .sb-tool-meta { font-size: 11px; color: var(--ink4); }
    .sb-cta {
      background: linear-gradient(135deg, var(--accent) 0%, #7c3aed 100%);
      border-radius: var(--r-lg); overflow: hidden; position: relative;
      box-shadow: 0 4px 20px rgba(79,70,229,.25);
    }
    .sb-cta::before {
      content: ''; position: absolute; inset: 0;
      background-image: radial-gradient(rgba(255,255,255,.1) 1px, transparent 1px);
      background-size: 18px 18px;
    }
    .sb-cta-inner  { padding: 20px 18px; position: relative; z-index: 1; }
    .sb-cta-title  { font-family: 'Outfit', sans-serif; font-size: 16px; font-weight: 700; color: #fff; margin-bottom: 6px; }
    .sb-cta-sub    { font-size: 12.5px; color: rgba(255,255,255,.6); line-height: 1.5; margin-bottom: 14px; }
    .sb-cta-btn {
      display: block; text-align: center; background: #fff; color: var(--accent);
      padding: 10px; border-radius: var(--r);
      font-size: 13px; font-weight: 700; transition: opacity .15s;
    }
    .sb-cta-btn:hover { opacity: .92; text-decoration: none; }

    /* ══ MISC ══ */
    .helpful-bar { display: flex; align-items: center; gap: 12px; padding: 16px 0; flex-wrap: wrap; }
    .helpful-label { font-size: 13.5px; color: var(--ink3); }
    .vote-btn {
      display: inline-flex; align-items: center; gap: 6px;
      padding: 7px 16px; border-radius: var(--r); font-size: 13px; font-weight: 600;
      cursor: pointer; border: 1.5px solid var(--border2); background: var(--surface);
      color: var(--ink2); transition: all .15s;
    }
    .vote-btn.yes:hover { background: var(--green-s); border-color: var(--green-b); color: var(--green); }
    .vote-btn.no:hover  { background: var(--red-s);   border-color: var(--red-b);   color: var(--red); }
    .btn-main {
      display: inline-flex; align-items: center; gap: 7px;
      background: var(--accent); color: #fff;
      padding: 10px 22px; border-radius: var(--r);
      font-size: 13.5px; font-weight: 700;
      box-shadow: 0 2px 12px rgba(79,70,229,.35);
      transition: transform .12s, box-shadow .12s;
    }
    .btn-main:hover { transform: translateY(-1px); box-shadow: 0 4px 20px rgba(79,70,229,.4); text-decoration: none; }
    .btn-ghost {
      display: inline-flex; align-items: center; gap: 7px;
      background: var(--surface); color: var(--ink2);
      padding: 10px 18px; border-radius: var(--r);
      font-size: 13.5px; font-weight: 600;
      border: 1.5px solid var(--border2); cursor: pointer; transition: border-color .15s, color .15s;
    }
    .btn-ghost:hover { border-color: var(--accent); color: var(--accent); }
    .share-btn {
      display: inline-flex; align-items: center; gap: 5px;
      padding: 8px 14px; border-radius: var(--r);
      font-size: 12px; font-weight: 600;
      border: 1px solid var(--border2); background: var(--surface);
      color: var(--ink3); cursor: pointer; transition: all .15s;
    }
    .share-btn:hover { border-color: var(--accent); color: var(--accent); }
    .stars-visual { display: flex; gap: 2px; }
    .star { font-size: 14px; color: var(--amber); }
    .star.empty { color: var(--border2); }

    /* ══ ANIMATIONS ══ */
    @keyframes fadeUp { from { opacity:0; transform:translateY(16px); } to { opacity:1; transform:translateY(0); } }
    .fade { animation: fadeUp .45s ease both; }
    .d1 { animation-delay: .06s; }
    .d2 { animation-delay: .12s; }
    .d3 { animation-delay: .18s; }

    /* ══ RESPONSIVE ══ */
    @media (max-width: 1024px) {
      .page { grid-template-columns: 1fr; }
      .side { position: static; }
      .stat-strip { grid-template-columns: repeat(2, 1fr); }
    }
    @media (max-width: 900px)  { .hero-grid { grid-template-columns: 1fr; gap: 20px; } .hero-yt-col { order: -1; } }
    @media (max-width: 768px)  {
      .page { padding: 14px 16px 56px; }
      .breadcrumb { padding: 12px 16px 0; }
      .pc-wrap, .feat-grid, .pricing-wrap { grid-template-columns: 1fr; }
      .hero-body { padding: 0 16px 20px; }
      .section { padding: 20px 16px; }
    }
    @media (max-width: 600px)  { .hero-tool-name { font-size: 20px; } .hero-logo-img, .hero-logo-fb { width: 54px; height: 54px; } }
    @media (max-width: 480px)  { .stat-strip { grid-template-columns: repeat(2, 1fr); } .review-summary { flex-direction: column; align-items: flex-start; } }
    @media (max-width: 400px)  { .hero-id { gap: 12px; } .hero-logo-img, .hero-logo-fb { width: 48px; height: 48px; } }