.features{padding:30px 0 60px;background:#fff}
.f-card{padding:28px 24px;border-radius:16px;border:1px solid var(--border);background:#fff;height:100%;transition:all .3s}
.f-card:hover{border-color:rgba(30,177,180,.3);box-shadow:0 8px 32px rgba(30,177,180,.08);transform:translateY(-4px)}
.f-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin-bottom:16px}
.f-icon.t{background:rgba(30,177,180,.1);color:var(--accent)}
.f-icon.b{background:rgba(59,130,246,.1);color:var(--blue)}
.f-icon.p{background:rgba(139,92,246,.1);color:var(--purple)}
.f-icon.o{background:rgba(251,146,60,.1);color:#fb923c}
.f-card h5{font-size:1rem;font-weight:600;margin-bottom:8px}
.f-card p{font-size:.88rem;color:var(--txt-body);line-height:1.6;margin-bottom:0}
.f-crossell{margin-top:14px!important;font-size:.78rem!important;color:var(--txt-muted)!important;border-top:1px solid var(--border);padding-top:12px}
.f-crossell a{color:var(--accent);text-decoration:none;font-weight:600}
.f-crossell a:hover{text-decoration:underline}
.f-link{color:var(--accent);font-size:.88rem;font-weight:600;text-decoration:none;display:inline-block;margin-top:16px;transition:all .2s}
.f-link:hover{color:var(--accent-dark);transform:translateX(4px)}
.f-panel-mock{background:#fff;border-radius:16px;overflow:hidden;border:1px solid var(--border);height:100%;box-shadow:var(--shadow)}
.f-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);background:#f8fafc}
.f-panel-dots{display:flex;gap:6px}
.f-panel-dots .dot{width:10px;height:10px;border-radius:50%}
.f-panel-dots .dot.red{background:#ef4444}
.f-panel-dots .dot.yellow{background:#f59e0b}
.f-panel-dots .dot.green{background:#22c55e}
.f-panel-url{font-family:'Courier New',monospace;font-size:.75rem;color:var(--txt-muted)}
.f-panel-body{padding:16px}
.f-panel-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.f-panel-title{color:var(--txt-dark);font-weight:600;font-size:.95rem}
.f-panel-btn{background:var(--accent);color:#fff;font-size:.75rem;font-weight:600;padding:4px 12px;border-radius:6px}
.f-panel-site{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid var(--border);border-radius:10px;margin-bottom:8px;background:#fafbfc}
.f-panel-site-icon{font-size:1.2rem}
.f-panel-site-name{color:var(--txt-dark);font-size:.85rem;font-weight:500}
.f-panel-site-php{color:var(--txt-muted);font-size:.75rem}
.f-panel-site-dot{width:10px;height:10px;border-radius:50%;margin-left:auto;flex-shrink:0}
.f-panel-site-dot.online{background:#22c55e}
.f-img{border-radius:16px;overflow:hidden;border:1px solid var(--border);background:var(--bg-alt);height:100%;min-height:200px;display:flex;align-items:center;justify-content:center}
.f-img-inner{width:100%;height:100%;min-height:200px;background:linear-gradient(135deg,#e2e8f0,#f1f5f9);display:flex;align-items:center;justify-content:center;color:var(--txt-muted)}

/* ── PANEL CARD LAYOUT ─────────────────────────────────────────── */
.f-card-panel{display:flex;gap:32px;align-items:stretch;padding:32px}
.f-card-left{flex:1;display:flex;flex-direction:column;justify-content:flex-start}
.f-card-left .f-img{margin:0}
.f-card-right{flex:1;display:flex;align-items:center;justify-content:center;min-height:0}
.f-card-right .f-panel-mock{max-width:100%;height:auto;box-shadow:0 4px 16px rgba(0,0,0,.08)}
.f-card-right .f-card-text{display:flex;flex-direction:column;justify-content:flex-start}
.f-card-text h5{font-size:1rem;font-weight:600;margin-bottom:8px}
.f-card-text p{font-size:.88rem;color:var(--txt-body);line-height:1.6;margin-bottom:0}

/* Accent variant — teal bg, white text */
.f-card--accent{background:var(--accent,#1eb1b4);border-color:var(--accent,#1eb1b4)}
.f-card--accent h5{color:#fff}
.f-card--accent p{color:rgba(255,255,255,.85)}
.f-card--accent .f-icon{background:rgba(255,255,255,.2);color:#fff}
.f-card--accent .f-link{color:#fff;text-decoration:underline}
.f-card--accent .f-link:hover{color:rgba(255,255,255,.8)}
.f-card--accent:hover{border-color:var(--accent-dark,#199a9d);box-shadow:0 8px 32px rgba(30,177,180,.25)}
/* Panel mock keeps original colors inside accent card */
.f-card--accent .f-panel-mock{background:#fff;border-color:var(--border,#e2e8f0)}
.f-card--accent .f-panel-header{background:#f8fafc;border-color:var(--border,#e2e8f0)}
.f-card--accent .f-panel-url{color:var(--txt-muted,#8892a5)}
.f-card--accent .f-panel-title{color:var(--txt-dark,#1a1a2e)}
.f-card--accent .f-panel-site{background:#fafbfc;border-color:var(--border,#e2e8f0)}
.f-card--accent .f-panel-site-name{color:var(--txt-dark,#1a1a2e)}
.f-card--accent .f-panel-site-php{color:var(--txt-muted,#8892a5)}

@media(max-width:768px){
  .f-card-panel{flex-direction:column;gap:20px;padding:24px}
  .f-card-right{min-height:auto;margin-top:20px}
}

/* ═══════════════════════════════════════════════════════════════
   Ujednolicony layout kafelków — ikona TOP-LEFT, tytuł + opis po
   prawej. Wspólne dla desktop + mobile. Różnią się tylko kolory
   (przez klasy modyfikatory), layout jest ten sam (CSS grid).
   ═══════════════════════════════════════════════════════════════ */

/* ── WSPÓLNY GRID: ikona po lewej spanuje pionowo, tekst po prawej ── */
.features .f-card:not(.f-card-panel),
.features .sf-card,
.stress-free .f-card{
  display:grid;
  grid-template-columns:auto 1fr;
  grid-auto-rows:min-content;
  column-gap:18px;
  row-gap:4px;
  align-items:start;
  align-content:start;
  text-align:left!important;
  padding:22px 24px;
}

/* Ikona (wszystkie warianty) — top-aligned, span obu wierszy tekstu */
.features .f-card:not(.f-card-panel) .f-icon,
.features .sf-card .sf-card-icon,
.stress-free .f-card .f-icon{
  grid-row:span 2;
  grid-column:1;
  align-self:start;
  margin:0;
  flex-shrink:0;
}

/* Tytuł */
.features .f-card:not(.f-card-panel) h5,
.features .sf-card .sf-card-title,
.stress-free .f-card h5{
  grid-column:2;
  align-self:start;
  margin:0 0 4px;
  line-height:1.25;
}

/* Opis */
.features .f-card:not(.f-card-panel) p,
.features .sf-card .sf-card-desc,
.stress-free .f-card p{
  grid-column:2;
  align-self:start;
  margin:0;
  line-height:1.5;
}

/* .f-card-panel — lewa strona (z tekstem + linkiem) też grid, prawa obok/pod */
.features .f-card-panel .f-card-left{
  display:grid;
  grid-template-columns:auto 1fr;
  column-gap:18px;
  row-gap:4px;
  align-items:start;
  text-align:left;
}
.features .f-card-panel .f-card-left .f-icon{grid-row:span 3;align-self:start;margin:0;flex-shrink:0}
.features .f-card-panel .f-card-left h5{grid-column:2;margin:0;line-height:1.25}
.features .f-card-panel .f-card-left p{grid-column:2;margin:4px 0 0;line-height:1.5}
.features .f-card-panel .f-card-left .f-link{grid-column:2;margin-top:10px;display:inline-block}

/* Mobile — kompaktowe wersje (mniejsze paddingi i fonty) */
@media (max-width:768px){
  .features .row.g-4,
  .stress-free .row.g-4{--bs-gutter-y:0.75rem}
  .features .f-card:not(.f-card-panel),
  .features .sf-card,
  .stress-free .f-card{column-gap:14px;padding:14px 16px}
  .features .f-card:not(.f-card-panel) h5,
  .features .sf-card .sf-card-title,
  .stress-free .f-card h5{font-size:.95rem}
  .features .f-card:not(.f-card-panel) p,
  .features .sf-card .sf-card-desc,
  .stress-free .f-card p{font-size:.82rem;line-height:1.45}
  .features .f-card-panel{padding:16px!important;gap:14px}
  .features .f-card-panel .f-card-left{column-gap:14px}
  .features .f-card-panel .f-card-left h5{font-size:.98rem}
  .features .f-card-panel .f-card-left p{font-size:.84rem}
}
