/* Oceniamy.to — pełna warstwa kompatybilności
   Mapuje krótkie aliasy klas i zmiennych CSS z views.js
   na design system z styles.css i dodaje brakujące komponenty */

:root{
  /* Aliasy zmiennych */
  --p:   var(--primary);
  --p2:  var(--primary-2);
  --mu:  var(--muted);
  --bd:  var(--border);
  --tx:  var(--text);
  --sf:  var(--soft);
  --ac:  var(--accent);
  --gd:  var(--good);
  --ok:  var(--good);
  --er:  var(--bad);
  --pl:  #f1f5f9;
  --rd:  var(--radius);
  --rds: var(--radius-sm);
  --sh:  var(--shadow);
}

/* ============ LAYOUT ============ */
.ctr{max-width:1280px;margin:0 auto;padding:0 20px}
.ly{display:grid;grid-template-columns:1fr 320px;gap:28px;align-items:start;margin:24px 0}
@media (max-width:920px){.ly{grid-template-columns:1fr}}

/* ============ GRIDS ============ */
.gr{display:grid;gap:18px}
.gr-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.gr-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.gr-4{grid-template-columns:repeat(4,minmax(0,1fr))}
@media (max-width:920px){.gr-3,.gr-4{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:620px){.gr-2,.gr-3,.gr-4{grid-template-columns:1fr}}

/* ============ CARDS ============ */
.cd{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:16px;transition:transform .15s,box-shadow .15s;cursor:pointer;text-decoration:none;color:inherit;display:block;overflow:hidden}
.cd:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.cd-im{margin:-16px -16px 12px;border-radius:0;overflow:hidden}
.cd .photo{border-radius:var(--radius-sm)}

/* ============ BUTTONS (krótkie aliasy) ============ */
.btn-p{background:var(--primary);color:#fff !important;border:1px solid var(--primary)}
.btn-p:hover{background:var(--primary-2);border-color:var(--primary-2)}
.btn-o{background:#fff;color:var(--text) !important;border:1px solid var(--border)}
.btn-o:hover{border-color:var(--primary);color:var(--primary) !important}
.btn-g{background:var(--good);color:#fff !important;border:1px solid var(--good)}

/* ============ HERO (rozbudowany) ============ */
.hero-in{max-width:760px}
.hero-in h1{font-size:28px;line-height:1.2;margin:0 0 8px;color:#fff}
.hero-in p,.hero .ld{font-size:15px;opacity:.92;margin:8px 0 16px;color:#fff}
.hs{display:flex;gap:8px;background:#fff;padding:6px;border-radius:var(--radius);max-width:560px;margin-top:14px;box-shadow:var(--shadow-lg)}
.hs input{flex:1;border:0;outline:none;padding:10px 14px;font-size:14px;background:transparent;color:var(--text);border-radius:var(--radius-sm)}
.hs button{background:var(--primary);color:#fff;border:0;padding:10px 22px;border-radius:var(--radius-sm);font-weight:700;cursor:pointer;font-size:14px}
.hs button:hover{background:var(--primary-2)}

/* ============ SIDEBAR / WIDGETS ============ */
.sd{display:flex;flex-direction:column;gap:16px;position:sticky;top:80px}
.wg{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:18px}
.wg h3{margin:0 0 12px;font-size:15px}
.wg a{display:block;padding:6px 0;font-size:13px;color:var(--text)}
.wg a:hover{color:var(--primary)}

/* ============ ALERTY ============ */
.al{padding:12px 16px;border-radius:var(--radius-sm);margin:14px 0;font-size:13px;border-left:3px solid}
.al-i{background:#dbeafe;color:#1e40af;border-color:#3b82f6}
.al-s{background:#d1fae5;color:#065f46;border-color:#10b981}
.al-w{background:#fef3c7;color:#92400e;border-color:#f59e0b}
.al-e{background:#fee2e2;color:#991b1b;border-color:#ef4444}
.al a{color:inherit;text-decoration:underline;cursor:pointer}

/* ============ CHIPY ============ */
.ch{display:inline-block;background:var(--soft);color:#475569;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;margin-right:4px}
.ch-ok{background:#d1fae5;color:#065f46}
.ch-er{background:#fee2e2;color:#991b1b}
.ch-vr{background:#dbeafe;color:#1e40af}
.ch-wn{background:#fef3c7;color:#92400e}

/* ============ FILTRY ============ */
.fl{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 16px;align-items:center}
.fc{padding:8px 14px;border:1px solid var(--border);background:#fff;border-radius:20px;font-size:13px;cursor:pointer;color:var(--text);font-family:inherit}
.fc.act,.fc:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
select.fc{background:#fff;color:var(--text);padding-right:32px}
select.fc.act{background:var(--primary);color:#fff}

/* ============ FORMULARZE ============ */
.fk{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:28px;max-width:480px;margin:32px auto}
.fk h2{text-align:center;margin-bottom:6px}
.fk p{text-align:center;margin-bottom:18px;color:var(--muted)}
.fg{margin:0 0 14px}
.fg label{display:block;font-size:13px;font-weight:600;margin:0 0 6px;color:var(--text)}
.fm{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;background:#fff;outline:none;color:var(--text)}
.fm:focus{border-color:var(--primary)}
textarea.fm{min-height:100px;resize:vertical}
select.fm{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:calc(100% - 16px) calc(50% - 2px),calc(100% - 11px) calc(50% - 2px);background-size:5px 5px,5px 5px;background-repeat:no-repeat}

/* ============ STEPS (wizard) ============ */
.sp{display:flex;gap:8px;justify-content:center;margin:14px 0 20px;align-items:center}
.stp{width:32px;height:32px;border-radius:50%;background:var(--soft);color:var(--muted);display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;border:2px solid transparent}
.stp.ac{background:var(--primary);color:#fff;border-color:var(--primary)}

/* ============ NAGŁÓWEK SEKCJI ============ */
.st{display:flex;justify-content:space-between;align-items:end;margin:28px 0 14px;gap:12px;flex-wrap:wrap}
.st h2{margin:0}
.st > a{font-size:13px;color:var(--primary);font-weight:600;white-space:nowrap}
.sb{color:var(--muted);font-size:13px;margin-top:2px}

/* ============ GWIAZDKI / REVIEWS ============ */
.sts{color:var(--accent);font-weight:700;font-size:13px;white-space:nowrap}
.rv{padding:16px 0;border-bottom:1px solid var(--border)}
.rv:last-child{border:0}
.rv-h{display:flex;justify-content:space-between;align-items:start;gap:12px;margin-bottom:8px;flex-wrap:wrap}
.rv-m{color:var(--muted);font-size:12px}

/* ============ SUGGESTIONS ============ */
.sug{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0}
.sug a{padding:6px 14px;background:#fff;border:1px solid var(--border);border-radius:20px;font-size:13px;color:var(--text);cursor:pointer}
.sug a:hover{border-color:var(--primary);color:var(--primary)}

/* ============ PAGINACJA ============ */
.pg{display:flex;gap:4px;justify-content:center;margin:24px 0;flex-wrap:wrap}
.pg a{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;color:var(--text);cursor:pointer;background:#fff;min-width:36px;text-align:center}
.pg a.act,.pg a:hover{background:var(--primary);color:#fff;border-color:var(--primary)}

/* ============ TRUST RIBBON ============ */
.tr{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin:20px 0;padding:18px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);text-align:center}
@media (max-width:780px){.tr{grid-template-columns:repeat(2,1fr)}}
.tri{display:flex;flex-direction:column;gap:2px;font-size:12px;color:var(--muted)}
.tri strong{font-size:18px;color:var(--text);display:block;margin-bottom:2px}

/* ============ PROFILE HEADER (encje) ============ */
.ph{display:flex;gap:24px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin:18px 0 24px;align-items:flex-start;flex-wrap:wrap}
.pa{width:96px;height:96px;border-radius:var(--radius);background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;display:flex;align-items:center;justify-content:center;font-size:40px;font-weight:800;flex-shrink:0;text-transform:uppercase}
.pi{flex:1;min-width:240px}
.pi h1{margin:0 0 4px;font-size:24px}
.pm{margin:10px 0;display:flex;flex-wrap:wrap;gap:6px}
.pc{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}
.ps{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:14px;margin-top:16px;padding-top:16px;border-top:1px dashed var(--border)}

/* ============ STAT BLOCK ============ */
.s1{display:flex;flex-direction:column;gap:2px}
.s1 .n{font-size:18px;font-weight:800;color:var(--text)}
.s1 .l{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}

/* ============ KOMPONENTY POMOCNICZE ============ */
.act{font-weight:700}
.sp-sep{color:var(--muted);margin:0 4px}
.em{color:var(--primary);font-weight:700}
.mu{color:var(--muted)}
.ic{display:inline-flex;align-items:center;gap:4px}
.mt{color:var(--muted);font-size:12px}
.n{font-weight:700}
.nb{font-weight:800;font-size:22px;color:var(--text)}
.nm{font-size:14px}
.np{color:var(--muted);font-size:12px}
.l{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}

/* ============ TABS ============ */
.tb{display:flex;gap:6px;flex-wrap:wrap;border-bottom:2px solid var(--border);margin:20px 0 16px}
.tb a{padding:10px 16px;color:var(--muted);font-weight:500;border-bottom:3px solid transparent;margin-bottom:-2px;font-size:14px;cursor:pointer}
.tb a.act{color:var(--text);font-weight:700;border-bottom-color:var(--text)}

/* ============ VOTING BARS ============ */
.vc{padding:14px 0}
.vop{margin:12px 0}
.vop > div:first-child{display:flex;justify-content:space-between;font-size:13px;margin-bottom:6px}
.vbar{height:10px;background:var(--soft);border-radius:5px;overflow:hidden;margin:6px 0}
.vbf{height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-2));border-radius:5px;transition:width .5s}

/* ============ MAPA ============ */
.mp{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--primary);min-height:120px}

/* ============ MOBILE MENU ============ */
.op{display:block !important}

/* ============ TYPOGRAFIA SEKCJI ============ */
h1{font-size:32px;line-height:1.15;margin:0 0 8px}
h2{font-size:22px;margin:0 0 14px}
h3{font-size:16px;margin:0 0 6px}
@media (max-width:620px){
  h1{font-size:24px}
  h2{font-size:18px}
  .hero{padding:20px !important}
  .hero-in h1{font-size:22px}
}

/* ============ DROBNE ============ */
strong{font-weight:700}
input,button,select,textarea{font-family:inherit}
.cd p{margin:0}
.cd > p{color:var(--muted);font-size:13px;margin:6px 0 0}

/* ============ STOPKA — BLOK GK HOLDING ============ */
.gk-block{display:flex;align-items:center;gap:12px;margin-top:18px;padding-top:16px;border-top:1px solid #334155}
.gk-block img{flex-shrink:0}
.gk-block-text{font-size:12px;line-height:1.4;color:#cbd5e1}
.gk-block-text strong{color:#fff;font-size:14px}
.footer .footer-company{color:#e2e8f0;font-size:12.5px;line-height:1.7}

/* ============ HUB KATEGORII (strona główna) ============ */
.hub-hero{background:linear-gradient(135deg,#0f172a 0%,#6d28d9 100%);color:#fff;padding:54px 0 48px;text-align:center;margin-bottom:8px}
.hub-hero h1{font-size:36px;margin:0 0 12px;color:#fff}
.hub-hero p{max-width:620px;margin:0 auto 24px;font-size:16px;line-height:1.6;color:rgba(255,255,255,.85)}
.hub-hero-sub{padding:64px 0 56px;background-size:cover !important;background-position:center !important}
.hub-hero-kicker{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:rgba(255,255,255,.15);padding:5px 14px;border-radius:20px;margin-bottom:14px;backdrop-filter:blur(4px)}
.hub-hero p strong{color:#fff}
.hub-search{display:flex;max-width:620px;margin:0 auto;gap:0;box-shadow:0 10px 30px rgba(0,0,0,.2);border-radius:12px;overflow:hidden}
.hub-search input{flex:1;border:none;padding:15px 18px;font-size:15px;outline:none}
.hub-search button{border:none;background:#f59e0b;color:#1f2937;font-weight:700;padding:0 26px;cursor:pointer;font-size:15px}
.hub-search button:hover{background:#d97706}
.hub-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px;margin:18px 0 48px}
.hub-tile{position:relative;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-end;min-height:170px;padding:18px;background-size:cover;background-position:center;border-radius:16px;text-decoration:none;color:#fff;overflow:hidden;transition:transform .14s,box-shadow .14s;box-shadow:0 4px 14px rgba(15,23,42,.12)}
.hub-tile:hover{transform:translateY(-4px);box-shadow:0 14px 32px rgba(15,23,42,.22)}
.hub-name{font-size:19px;font-weight:800;line-height:1.2;color:#fff;text-shadow:0 1px 8px rgba(0,0,0,.55);z-index:1}

/* Katalog firm — banner nad kategoriami */
.hub-catalog{display:flex;align-items:center;justify-content:space-between;gap:20px;margin:24px 0 8px;padding:26px 28px;border-radius:16px;text-decoration:none;color:#fff;background:linear-gradient(135deg,#1d4ed8 0%,#6d28d9 100%);box-shadow:0 8px 24px rgba(29,78,216,.25);transition:transform .14s,box-shadow .14s;flex-wrap:wrap}
.hub-catalog:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(29,78,216,.35)}
.hub-catalog-kicker{font-size:13px;font-weight:600;opacity:.9;display:block;margin-bottom:4px}
.hub-catalog h2{margin:0 0 6px;color:#fff;font-size:24px}
.hub-catalog p{margin:0;font-size:14px;opacity:.92;max-width:560px;line-height:1.5}
.hub-catalog-btn{flex-shrink:0;background:#fff;color:#1d4ed8;font-weight:700;padding:12px 22px;border-radius:10px;font-size:15px;white-space:nowrap}
@media(max-width:620px){.hub-hero h1{font-size:26px}.hub-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.hub-tile{min-height:130px}.hub-name{font-size:16px}.hub-catalog{padding:20px}.hub-catalog-btn{width:100%;text-align:center}}

/* ============ NOWOCZESNA KARTA FIRMY (.fc-*) ============ */
.fc-cover{height:200px;width:100%;background-size:cover;background-position:center}
.fc-card{max-width:1240px;margin:-72px auto 0;position:relative;background:#fff;border:1px solid var(--border);border-radius:18px;box-shadow:0 12px 40px rgba(15,23,42,.12);padding:24px 28px;z-index:2}
@media(max-width:1280px){.fc-card{margin-left:20px;margin-right:20px}}
.fc-card-top{display:flex;align-items:flex-start;gap:22px;flex-wrap:wrap}
.fc-avatar{width:104px;height:104px;flex-shrink:0;margin-top:-66px;border-radius:24px;background:linear-gradient(135deg,#6d28d9,#2563eb);color:#fff;display:flex;align-items:center;justify-content:center;font-size:46px;font-weight:800;border:4px solid #fff;box-shadow:0 8px 22px rgba(109,40,217,.32)}
.fc-id{flex:1;min-width:200px}
.fc-name{font-size:27px;line-height:1.15;margin:0 0 6px;color:var(--text)}
.fc-loc{color:var(--muted);font-size:14px;margin-bottom:10px}
.fc-badges{display:flex;gap:8px;flex-wrap:wrap}
.fc-badge{display:inline-flex;align-items:center;font-size:12px;font-weight:600;padding:5px 12px;border-radius:20px;text-decoration:none}
.fc-badge-vr{background:#dbeafe;color:#1d4ed8}
.fc-badge-cat{background:var(--soft);color:#475569}
.fc-badge-cat:hover{background:#e0e7ff;color:#4338ca}
.fc-rate-box{flex-shrink:0;text-align:center;min-width:120px;padding:14px 18px;background:var(--soft);border-radius:14px}
.fc-rate-num{font-size:34px;font-weight:800;line-height:1;color:var(--text)}
.fc-rate-empty{color:var(--muted)}
.fc-rate-stars{color:var(--accent);font-size:16px;margin:4px 0}
.fc-rate-cnt{font-size:12px;color:var(--muted)}
.fc-stats{display:flex;gap:8px;flex-wrap:wrap;margin:18px 0 0;padding-top:16px;border-top:1px solid var(--border)}
.fc-stat{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:#475569;background:var(--soft);padding:6px 12px;border-radius:8px}
.fc-stat-dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.fc-desc{color:#374151;line-height:1.65;margin:14px 0 0;font-size:14px}
.fc-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px;padding-top:18px;border-top:1px solid var(--border)}
.fc-act-main{font-weight:700}
@media(max-width:620px){.fc-cover{height:130px}.fc-card{margin-top:-56px;padding:18px}.fc-avatar{width:84px;height:84px;margin-top:-52px;font-size:36px}.fc-name{font-size:22px}.fc-rate-box{margin-top:10px}}

/* Taby — pill style */
.od-tabwrap .tb{display:flex;gap:6px;border-bottom:1px solid var(--border);margin-bottom:18px;flex-wrap:wrap}
.od-tabwrap .tb a{padding:10px 18px;font-size:14px;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .12s,border-color .12s}
.od-tabwrap .tb a:hover{color:var(--text)}
.od-tabwrap .tb a.act{color:var(--primary);border-bottom-color:var(--primary)}

/* Kontakt — blokada anty-bot */
.od-lock{color:#94a3b8;font-style:italic;font-size:12px}
.od-klock{opacity:.85}

/* Karta firmy — taby pełna szerokość, bez poziomego scrolla */
.frm-tabs{overflow:visible !important;flex-wrap:wrap;gap:2px}
.frm-tab{flex:1 1 0 !important;justify-content:center !important;min-width:90px;text-align:center}
.frm-claim-card{background:linear-gradient(135deg,#f5f3ff,#ede9fe) !important;border:1px solid #ddd6fe !important;border-radius:14px}
.frm-claim-inner{display:block !important}
.frm-claim-inner h3{font-size:16px;margin:0 0 6px;color:#2f2559}
/* Nowoczesny przycisk claim */
.od-claim-btn{display:flex !important;align-items:center;justify-content:center;gap:8px;width:100%;padding:13px 18px;margin-top:6px;background:#6d28d9;color:#fff !important;border:none;border-radius:12px;font-size:14px;font-weight:700;line-height:1;text-decoration:none;box-shadow:0 6px 16px rgba(109,40,217,.32);transition:background .15s,box-shadow .15s,transform .15s;cursor:pointer}
.od-claim-btn:hover{background:#5b21b6;box-shadow:0 8px 22px rgba(109,40,217,.42);transform:translateY(-1px);color:#fff !important}
.od-claim-btn svg{flex-shrink:0}
.frm-claim-remove{display:block;text-align:center;margin-top:12px;font-size:12px;color:#7c6fae;text-decoration:underline}
.frm-claim-remove:hover{color:#6d28d9}
/* Gwiazdki fioletowe (jak logo) */
.sts,.fc-rate-stars,.frm-rating-stars-big,.frm-star-big.filled,.frm-stars .star.filled,.frm-opinia-star.filled,.firma-stars .star.filled,.frm-rating-number{color:#6d28d9 !important}
