:root{
  --primary:#1f6feb;--primary-dark:#1857bd;--accent:#f59e0b;
  --bg:#f4f6fa;--card:#fff;--text:#1c2333;--muted:#5b6478;--border:#e3e8f0;
  --green:#16a34a;--red:#dc2626;
  --gold:#d4a017;--silver:#8b9bb0;--bronze:#b07b3f;--diamond:#3aa7d9;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.55}
a{color:var(--primary);text-decoration:none}
.container{max-width:1140px;margin:0 auto;padding:0 18px}
main{min-height:70vh;padding:26px 18px}

/* topbar */
.topbar{background:#0d1b2e;position:sticky;top:0;z-index:50;box-shadow:0 2px 8px rgba(0,0,0,.25)}
.topbar-inner{display:flex;align-items:center;gap:26px;height:62px}
.logo{font-size:1.35rem;font-weight:800;color:#fff;letter-spacing:-.5px}
.logo span{color:var(--accent)}
.mainnav{display:flex;gap:18px;flex:1}
.mainnav a{color:#cdd6e4;font-weight:600;font-size:.95rem;padding:6px 4px}
.mainnav a:hover{color:#fff}
.topbar-actions{display:flex;gap:10px;align-items:center}
.topbar-actions .userchip{color:#fff;font-size:.88rem;display:flex;align-items:center;gap:8px}
.topbar-actions .userchip b{color:var(--accent)}

/* buttons */
.btn{display:inline-block;border:none;cursor:pointer;border-radius:8px;font-weight:700;font-size:.92rem;padding:10px 18px;transition:.15s;text-align:center}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-dark)}
.btn-accent{background:var(--accent);color:#1c1303}
.btn-accent:hover{filter:brightness(1.08)}
.btn-outline{background:transparent;color:var(--primary);border:2px solid var(--primary)}
.btn-outline:hover{background:var(--primary);color:#fff}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff}
.btn-sm{padding:6px 12px;font-size:.82rem}
.btn-danger{background:var(--red);color:#fff}
.btn[disabled]{opacity:.5;cursor:not-allowed}

/* hero */
.hero{background:linear-gradient(135deg,#0d1b2e 0%,#16365e 60%,#1f6feb 130%);color:#fff;border-radius:16px;padding:54px 44px;margin-bottom:30px}
.hero h1{font-size:2.4rem;line-height:1.15;margin-bottom:14px;max-width:640px}
.hero p{color:#bcd0ea;max-width:560px;margin-bottom:24px;font-size:1.05rem}
.hero .hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.hero-stats{display:flex;gap:38px;margin-top:34px;flex-wrap:wrap}
.hero-stats b{display:block;font-size:1.6rem;color:var(--accent)}
.hero-stats span{color:#9fb4d4;font-size:.85rem}

/* sections / cards */
.section{margin-bottom:38px}
.section-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:16px}
.section-head h2{font-size:1.45rem}
.grid{display:grid;gap:16px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:900px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}.grid-2{grid-template-columns:1fr}.hero h1{font-size:1.7rem}}
@media(max-width:560px){.grid-3,.grid-4{grid-template-columns:1fr}.mainnav{display:none}}
.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:18px;transition:.15s}
.card:hover{box-shadow:0 6px 18px rgba(20,40,80,.08)}
.card h3{font-size:1.05rem;margin-bottom:6px}
.card .muted{color:var(--muted);font-size:.87rem}

/* category cards */
.cat-card{display:flex;flex-direction:column;gap:6px;cursor:pointer}
.cat-card .cat-icon{font-size:1.9rem}
.cat-card .count{color:var(--muted);font-size:.83rem}

/* job card */
.job-card{display:flex;flex-direction:column;gap:8px}
.job-meta{display:flex;gap:10px;flex-wrap:wrap;font-size:.8rem;color:var(--muted)}
.badge{display:inline-block;padding:3px 10px;border-radius:99px;font-size:.74rem;font-weight:700}
.badge-cat{background:#e8f0fe;color:var(--primary)}
.badge-open{background:#e6f7ec;color:var(--green)}
.badge-progress{background:#fef4e0;color:#b07514}
.badge-done{background:#eceff4;color:var(--muted)}
.badge-urgent{background:#fde8e8;color:var(--red)}
.job-budget{font-weight:800;color:var(--text)}
.job-card .job-foot{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:8px;border-top:1px dashed var(--border)}

/* stars + reputation */
.stars{color:var(--accent);letter-spacing:1px;font-size:.95rem}
.stars .off{color:#d4dae4}
.rep-badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:99px;font-size:.76rem;font-weight:800;color:#fff}
.rep-Nowa{background:#9aa5b5}.rep-Brązowa{background:var(--bronze)}.rep-Srebrna{background:var(--silver)}
.rep-Złota{background:var(--gold)}.rep-Diamentowa{background:var(--diamond)}
.rep-score{font-weight:800}
.verified{color:var(--green);font-size:.78rem;font-weight:700}

/* company card */
.company-card{display:flex;flex-direction:column;gap:8px}
.company-head{display:flex;gap:12px;align-items:center}
.avatar{width:48px;height:48px;border-radius:10px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.2rem;flex-shrink:0}
.company-stats{display:flex;gap:14px;font-size:.8rem;color:var(--muted);flex-wrap:wrap}
.company-stats b{color:var(--text)}

/* tables / ranking */
.ranktable{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;border:1px solid var(--border)}
.ranktable th{background:#0d1b2e;color:#fff;text-align:left;padding:12px 14px;font-size:.82rem}
.ranktable td{padding:12px 14px;border-top:1px solid var(--border);font-size:.9rem;vertical-align:middle}
.ranktable tr:hover td{background:#f6f9ff}
.rank-pos{font-weight:800;font-size:1.05rem;color:var(--muted)}
.rank-pos.top{color:var(--accent)}

/* detail page */
.detail-grid{display:grid;grid-template-columns:2fr 1fr;gap:22px}
@media(max-width:900px){.detail-grid{grid-template-columns:1fr}}
.panel{background:#fff;border:1px solid var(--border);border-radius:12px;padding:22px;margin-bottom:18px}
.panel h2{margin-bottom:12px;font-size:1.25rem}
.panel h3{margin:16px 0 8px}
.kv{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px dashed var(--border);font-size:.9rem}
.kv span:first-child{color:var(--muted)}
.breadcrumbs{font-size:.83rem;color:var(--muted);margin-bottom:14px}

/* offers */
.offer{border:1px solid var(--border);border-radius:10px;padding:14px;margin-bottom:10px}
.offer-head{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}
.offer .price{font-weight:800;font-size:1.05rem}
.offer-msg{font-size:.88rem;color:var(--muted);margin-top:6px}
.offer.accepted{border-color:var(--green);background:#f3fbf6}

/* reviews */
.review{border-bottom:1px solid var(--border);padding:14px 0}
.review:last-child{border-bottom:none}
.review-head{display:flex;justify-content:space-between;flex-wrap:wrap;gap:6px}
.review .crit{display:flex;gap:14px;flex-wrap:wrap;font-size:.78rem;color:var(--muted);margin-top:6px}
.review p{margin-top:6px;font-size:.92rem}
.ratingbar{display:flex;align-items:center;gap:10px;font-size:.82rem;margin:4px 0}
.ratingbar .bar{flex:1;height:8px;background:#e8ecf3;border-radius:99px;overflow:hidden}
.ratingbar .bar i{display:block;height:100%;background:var(--accent)}
.bigscore{font-size:2.6rem;font-weight:800;line-height:1}

/* forms */
form .field{margin-bottom:14px}
label{display:block;font-weight:600;font-size:.86rem;margin-bottom:5px}
input,select,textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font:inherit;background:#fff}
input:focus,select:focus,textarea:focus{outline:2px solid var(--primary);border-color:transparent}
textarea{min-height:110px;resize:vertical}
.form-narrow{max-width:560px;margin:0 auto}
.star-input{display:flex;gap:4px;font-size:1.6rem;cursor:pointer;color:#d4dae4}
.star-input span.on{color:var(--accent)}
.hint{font-size:.8rem;color:var(--muted);margin-top:4px}

/* pricing */
.price-card{text-align:center;position:relative;display:flex;flex-direction:column}
.price-card .plan-name{font-weight:800;font-size:1.1rem}
.price-card .plan-price{font-size:2.2rem;font-weight:800;margin:10px 0}
.price-card .plan-price small{font-size:.85rem;color:var(--muted);font-weight:400}
.price-card ul{list-style:none;text-align:left;margin:14px 0;flex:1}
.price-card li{padding:6px 0;font-size:.88rem;border-bottom:1px dashed var(--border)}
.price-card li::before{content:"✓ ";color:var(--green);font-weight:800}
.price-card.featured{border:2px solid var(--accent);box-shadow:0 8px 24px rgba(245,158,11,.18)}
.ribbon{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--accent);color:#1c1303;font-size:.72rem;font-weight:800;padding:3px 14px;border-radius:99px}

/* dashboard */
.tabs{display:flex;gap:6px;margin-bottom:18px;flex-wrap:wrap}
.tabs button{border:1px solid var(--border);background:#fff;padding:8px 16px;border-radius:99px;cursor:pointer;font-weight:600;font-size:.86rem}
.tabs button.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.statgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}
@media(max-width:700px){.statgrid{grid-template-columns:repeat(2,1fr)}}
.stat{background:#fff;border:1px solid var(--border);border-radius:12px;padding:16px;text-align:center}
.stat b{display:block;font-size:1.6rem}
.stat span{font-size:.78rem;color:var(--muted)}
.quota{height:10px;background:#e8ecf3;border-radius:99px;overflow:hidden;margin-top:6px}
.quota i{display:block;height:100%;background:var(--primary)}

/* misc */
.empty{text-align:center;color:var(--muted);padding:40px 0}
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}
.filters select,.filters input{width:auto;min-width:170px}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);background:#0d1b2e;color:#fff;padding:12px 22px;border-radius:10px;font-weight:600;opacity:0;transition:.3s;z-index:99;box-shadow:0 8px 24px rgba(0,0,0,.3)}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}
.notice{background:#fff8e8;border:1px solid #f3dba6;color:#7a5b10;border-radius:10px;padding:12px 16px;font-size:.88rem;margin-bottom:16px}

/* footer */
.footer{background:#0d1b2e;color:#9fb0c8;margin-top:50px;padding:40px 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:26px;padding-bottom:26px}
@media(max-width:760px){.footer-grid{grid-template-columns:1fr 1fr}}
.footer h4{color:#fff;margin-bottom:10px;font-size:.92rem}
.footer a{display:block;color:#9fb0c8;font-size:.86rem;padding:3px 0}
.footer a:hover{color:#fff}
.footer p{font-size:.85rem;max-width:300px;margin-top:8px}
.footer-bottom{border-top:1px solid #1e3250;padding:16px 18px;font-size:.8rem;text-align:center}

/* promo */
.promo-pill{display:inline-block;background:#fff4e0;border:1px solid #f3d49a;color:#8a5a08;font-size:.85rem;font-weight:600;padding:8px 16px;border-radius:24px}
.hero .promo-pill{margin-top:16px}

/* ---------- BLOG ---------- */
.post-card{text-decoration:none;color:inherit}
.post-card:hover{box-shadow:0 8px 22px rgba(20,40,80,.10);transform:translateY(-3px);border-color:#cdd9ec}
.post-card h2{color:var(--text)}
.blog-hero{padding:34px 0 8px}
.blog-hero h1{font-size:2rem;margin-bottom:6px}
.blog-hero p{color:var(--muted);max-width:640px}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:24px 0 10px}
@media(max-width:900px){.blog-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.blog-grid{grid-template-columns:1fr}}
.post-card{display:flex;flex-direction:column;height:100%}
.post-card .tag{display:inline-block;background:#e8f0fe;color:var(--primary);font-size:.72rem;font-weight:700;padding:3px 9px;border-radius:20px;margin-bottom:10px;align-self:flex-start}
.post-card h2{font-size:1.08rem;line-height:1.35;margin-bottom:8px}
.post-card p{color:var(--muted);font-size:.88rem;flex-grow:1}
.post-card .post-meta{margin-top:12px;font-size:.78rem;color:var(--muted)}
/* artykuł */
.article{max-width:760px;margin:0 auto;padding:8px 0 10px}
.article .breadcrumbs{margin:18px 0}
.article h1{font-size:2rem;line-height:1.25;margin:6px 0 12px}
.article .post-meta{color:var(--muted);font-size:.85rem;margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid var(--border)}
.article h2{font-size:1.4rem;margin:30px 0 12px}
.article h3{font-size:1.12rem;margin:22px 0 8px}
.article p{margin:0 0 16px}
.article ul,.article ol{margin:0 0 16px;padding-left:22px}
.article li{margin-bottom:7px}
.article .lead{font-size:1.12rem;color:var(--text)}
.article .cta-box{background:#eef4ff;border:1px solid #d4e2fb;border-radius:12px;padding:20px 22px;margin:30px 0}
.article .cta-box h3{margin-top:0}
.article table{width:100%;border-collapse:collapse;margin:0 0 18px;font-size:.92rem}
.article th,.article td{border:1px solid var(--border);padding:9px 12px;text-align:left}
.article th{background:#f0f4fa}
