/* =================================================================
   Polskie Sloty — premium dark-gold
   ================================================================= */

:root{
	--bg:        #0E0E12;
	--bg-2:      #121218;
	--bg-3:      #14141A;
	--surface:   #16161D;
	--surface-2: #1A1A22;
	--line:      #23232C;
	--line-2:    #2A2A35;

	--gold:      #D4AF37;
	--gold-soft: #E5C76B;
	--gold-line: #3A3320;

	--text:      #F5F0E6;
	--text-2:    #C4BFB2;
	--text-3:    #A09B8E;
	--text-4:    #6F6A5E;

	--green:     #7BC47B;
	--red:       #DD8888;

	--radius:    12px;
	--radius-sm: 8px;
	--maxw:      1080px;

	--font:      "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
	--font-head: "Sora", var(--font);
}

*,*::before,*::after{ box-sizing:border-box; }

html{ -webkit-text-size-adjust:100%; }
body{
	margin:0;
	background:var(--bg);
	color:var(--text);
	font-family:var(--font);
	font-size:16px;
	line-height:1.6;
	-webkit-font-smoothing:antialiased;
}

a{ color:inherit; text-decoration:none; }
img{ max-width:100%; height:auto; display:block; }

h1,h2,h3{ font-family:var(--font-head); font-weight:600; line-height:1.2; margin:0; }

.ps-container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:20px; }

/* ---------- Przyciski ---------- */
.ps-btn{
	display:inline-flex; align-items:center; justify-content:center; gap:6px;
	font-family:var(--font); font-weight:600; font-size:14px; line-height:1;
	padding:11px 22px; border-radius:var(--radius-sm); border:1px solid transparent;
	cursor:pointer; transition:transform .12s ease, background .15s ease, opacity .15s ease; white-space:nowrap;
}
.ps-btn:active{ transform:scale(.97); }
.ps-btn--gold{ background:var(--gold); color:#0E0E12; }
.ps-btn--gold:hover{ background:var(--gold-soft); }
.ps-btn--ghost{ background:transparent; border-color:var(--line-2); color:var(--text-3); font-size:12px; padding:6px 14px; }
.ps-btn--ghost:hover{ border-color:var(--gold-line); color:var(--gold); }
.ps-btn--sm{ padding:8px 16px; font-size:13px; }
.ps-btn--lg{ padding:13px 28px; font-size:15px; }
.ps-btn--block{ display:flex; width:100%; }

/* ---------- Header ---------- */
.ps-header{
	position:sticky; top:0; z-index:50;
	background:rgba(18,18,24,.92); backdrop-filter:blur(8px);
	border-bottom:1px solid var(--line-2);
}
.ps-header.is-scrolled{ border-bottom-color:var(--gold-line); }
.ps-header__inner{ display:flex; align-items:center; gap:24px; height:64px; }

.ps-brand{ display:flex; align-items:center; gap:10px; }
.ps-brand svg{ flex:none; }
.ps-brand__text{ font-family:var(--font-head); font-weight:600; font-size:18px; letter-spacing:.4px; color:var(--text); }
.ps-brand__accent{ color:var(--gold); }

.ps-nav{ margin-right:auto; }
.ps-nav__list{ display:flex; gap:22px; list-style:none; margin:0; padding:0; }
.ps-nav__list a{ font-size:14px; color:var(--text-3); transition:color .15s; }
.ps-nav__list a:hover{ color:var(--gold); }

.ps-search-toggle{
	display:flex; align-items:center; gap:8px;
	background:transparent; border:1px solid var(--line-2); color:var(--text-4);
	border-radius:var(--radius-sm); padding:7px 14px; font-size:13px; font-family:var(--font); cursor:pointer;
}
.ps-search-toggle:hover{ border-color:var(--gold-line); color:var(--gold); }

/* Panel wyszukiwania */
.ps-search{ position:relative; }
.ps-search-form{
	position:absolute; top:calc(100% + 10px); right:0; z-index:60;
	display:flex; align-items:center; gap:6px;
	background:var(--bg-2); border:1px solid var(--line-2); border-radius:var(--radius-sm);
	padding:6px; width:320px; max-width:80vw;
	opacity:0; visibility:hidden; transform:translateY(-6px); transition:.15s ease;
	box-shadow:0 12px 40px rgba(0,0,0,.45);
}
.ps-search.is-open .ps-search-form{ opacity:1; visibility:visible; transform:translateY(0); }
.ps-search-form input[type="search"]{
	flex:1; background:transparent; border:0; outline:0; color:var(--text);
	font-family:var(--font); font-size:14px; padding:8px 10px;
}
.ps-search-form input::placeholder{ color:var(--text-4); }
.ps-search-form button{
	flex:none; background:var(--gold); color:#0E0E12; border:0; border-radius:6px;
	padding:8px 10px; cursor:pointer; display:flex; align-items:center;
}

/* Klikalna karta kasyna → recenzja */
.ps-casino-row__cover{ position:absolute; inset:0; z-index:1; border-radius:inherit; }
.ps-casino-row__logo,
.ps-casino-row__name,
.ps-casino-row__cta{ position:relative; z-index:2; }
.ps-casino-row__rank{ position:relative; z-index:2; }
.ps-badge{ z-index:2; }

.ps-burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; padding:6px; cursor:pointer; }
.ps-burger span{ width:22px; height:2px; background:var(--text); border-radius:2px; transition:.2s; }
.ps-burger.is-open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.ps-burger.is-open span:nth-child(2){ opacity:0; }
.ps-burger.is-open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ---------- Hero ---------- */
.ps-hero{ text-align:center; padding:48px 0 28px; border-bottom:1px solid #1F1F28; }
.ps-hero__eyebrow{
	display:inline-block; font-size:11px; letter-spacing:2px; text-transform:uppercase;
	color:var(--gold); border:1px solid var(--gold-line); border-radius:20px; padding:5px 14px; margin-bottom:16px;
}
.ps-hero__title{ font-size:34px; color:var(--text); margin-bottom:10px; }
.ps-hero__sub{ color:var(--text-3); font-size:15px; margin:0; }

/* ---------- Chipsy kategorii ---------- */
.ps-chips{ display:flex; flex-wrap:wrap; gap:8px; padding-top:18px; padding-bottom:6px; }
.ps-chip{
	font-size:12px; padding:7px 14px; border-radius:20px;
	border:1px solid var(--line-2); color:var(--text-3); transition:.15s;
}
.ps-chip:hover{ border-color:var(--gold-line); color:var(--gold); }
.ps-chip.is-active{ background:var(--gold); border-color:var(--gold); color:#0E0E12; font-weight:600; }

/* ---------- Listing kasyn ---------- */
.ps-listing{ display:flex; flex-direction:column; gap:12px; padding-top:18px; padding-bottom:40px; }

.ps-casino-row{
	display:flex; align-items:center; gap:16px;
	background:var(--bg-3); border:1px solid var(--line); border-radius:var(--radius); padding:16px 18px;
	position:relative; transition:border-color .15s;
}
.ps-casino-row:hover{ border-color:var(--line-2); }
.ps-casino-row.is-featured{ background:var(--surface); border-color:var(--gold); }

.ps-badge{ position:absolute; top:-9px; left:18px; font-size:10px; letter-spacing:1px; text-transform:uppercase; padding:3px 10px; border-radius:10px; font-weight:600; }
.ps-badge--editor{ background:var(--gold); color:#0E0E12; }

.ps-casino-row__rank{ font-family:var(--font-head); font-size:20px; font-weight:700; color:var(--text-4); width:26px; text-align:center; flex:none; }
.ps-casino-row__rank.is-first{ font-size:22px; color:var(--gold); }

.ps-casino-row__logo{ width:78px; height:52px; border-radius:var(--radius-sm); background:var(--line); display:flex; align-items:center; justify-content:center; flex:none; overflow:hidden; }
.ps-casino-row__main{ flex:1; min-width:0; }
.ps-casino-row__name{ font-family:var(--font-head); font-size:16px; font-weight:600; color:var(--text); }
.ps-casino-row__name:hover{ color:var(--gold); }
.ps-casino-row__meta{ display:flex; align-items:center; gap:8px; margin-top:4px; }

.ps-casino-row__bonus{ text-align:center; padding:0 8px; flex:none; }
.ps-casino-row__bonus-label{ display:block; font-size:11px; color:var(--text-4); }
.ps-casino-row__bonus-value{ display:block; font-size:14px; font-weight:600; color:var(--text); }

.ps-casino-row__cta{ display:flex; flex-direction:column; gap:6px; flex:none; }

/* Gwiazdki + ocena */
.ps-stars{ display:inline-flex; gap:1px; }
.ps-star{ fill:var(--gold); }
.ps-star.is-off{ fill:var(--line-2); }
.ps-score{ font-size:12px; color:var(--text-3); }

/* ---------- Nagłówek strony / archiwum ---------- */
.ps-page-head{ padding:40px 0 8px; border-bottom:1px solid #1F1F28; }
.ps-page-head__eyebrow{ font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--gold); }
.ps-page-head__title{ font-size:28px; color:var(--text); margin:6px 0 6px; }
.ps-page-head__sub{ color:var(--text-3); font-size:14px; margin:0; }

/* ---------- Pojedyncze kasyno ---------- */
.ps-casino-hero{ background:var(--bg-2); border-bottom:1px solid var(--line-2); }
.ps-casino-hero__inner{ display:flex; align-items:center; gap:20px; padding:26px 20px; }
.ps-casino-hero__logo{ width:104px; height:70px; border-radius:10px; background:var(--line); display:flex; align-items:center; justify-content:center; flex:none; overflow:hidden; }
.ps-casino-hero__head{ flex:1; min-width:0; }
.ps-casino-hero__titlerow{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.ps-casino-hero__titlerow h1{ font-size:24px; color:var(--text); }
.ps-casino-hero__meta{ display:flex; align-items:center; gap:8px; margin-top:6px; }
.ps-casino-hero__cta{ display:flex; flex-direction:column; gap:7px; align-items:stretch; flex:none; }
.ps-cta-note{ font-size:11px; color:var(--text-4); text-align:center; }

.ps-verified{ display:inline-flex; align-items:center; gap:5px; font-size:11px; color:var(--green); border:1px solid #2E4A2E; background:#16221A; padding:3px 9px; border-radius:12px; }

.ps-casino-grid{ display:grid; grid-template-columns:1fr 248px; gap:28px; padding-top:26px; padding-bottom:48px; align-items:start; }

.ps-block{ margin-bottom:28px; }
.ps-block__title{ font-size:13px; letter-spacing:1.5px; text-transform:uppercase; color:var(--gold); margin-bottom:14px; }
.ps-block__hint{ font-size:12px; color:var(--text-4); margin:-8px 0 14px; }

.ps-bonus-list{ display:flex; flex-direction:column; gap:10px; }

/* Karta bonusu */
.ps-bonus-card{ display:flex; align-items:center; gap:14px; background:var(--surface); border:1px solid var(--line); border-radius:11px; padding:14px; }
.ps-bonus-card__logo{ width:54px; height:40px; border-radius:7px; background:var(--line); display:flex; align-items:center; justify-content:center; flex:none; overflow:hidden; }
.ps-bonus-card__body{ flex:1; min-width:0; }
.ps-bonus-card__name{ font-family:var(--font-head); font-size:14px; font-weight:600; color:var(--text); }
.ps-bonus-card__value{ font-size:12px; color:var(--text-3); margin:2px 0 0; }
.ps-bonus-card__tags{ display:flex; flex-wrap:wrap; gap:6px; margin-top:7px; }

.ps-tag{ font-size:10px; color:var(--text-3); border:1px solid var(--line-2); border-radius:5px; padding:2px 7px; }
.ps-tag--code{ color:var(--gold); border-color:var(--gold-line); }
.ps-tag--muted{ color:var(--text-4); }

/* Recenzja / proza */
.ps-prose{ color:var(--text-2); font-size:14px; line-height:1.75; }
.ps-prose p{ margin:0 0 14px; }
.ps-prose a{ color:var(--gold); }
.ps-prose h2,.ps-prose h3{ color:var(--text); margin:22px 0 10px; }

/* Zalety / wady */
.ps-proscons{ display:flex; gap:24px; flex-wrap:wrap; }
.ps-proscons__col{ flex:1; min-width:180px; }
.ps-proscons__col h3{ font-size:13px; margin-bottom:8px; font-family:var(--font); font-weight:600; }
.ps-proscons__col--pros h3{ color:var(--green); }
.ps-proscons__col--cons h3{ color:var(--red); }
.ps-proscons__col ul{ list-style:none; margin:0; padding:0; }
.ps-proscons__col li{ font-size:13px; color:var(--text-2); padding:4px 0 4px 20px; position:relative; }
.ps-proscons__col--pros li::before{ content:"+"; position:absolute; left:0; color:var(--green); font-weight:700; }
.ps-proscons__col--cons li::before{ content:"−"; position:absolute; left:0; color:var(--red); font-weight:700; }

/* Sidebar fakty */
.ps-casino-aside{ position:sticky; top:84px; }
.ps-facts{ background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius); padding:20px 18px; }
.ps-facts__title{ font-size:11px; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-4); margin-bottom:14px; font-family:var(--font); }
.ps-facts dl{ margin:0 0 16px; }
.ps-facts dl > div{ display:flex; justify-content:space-between; gap:12px; padding:7px 0; border-bottom:1px solid var(--line); }
.ps-facts dl > div:last-child{ border-bottom:0; }
.ps-facts dt{ font-size:12px; color:var(--text-4); }
.ps-facts dd{ font-size:12px; color:var(--text); margin:0; text-align:right; }

/* ---------- Pojedyncza gra ---------- */
.ps-game-hero{ background:var(--bg-2); border-bottom:1px solid var(--line-2); }
.ps-game-hero__inner{ display:flex; gap:22px; padding:28px 20px; align-items:center; }
.ps-game-hero__head{ flex:1; min-width:0; }
.ps-game-hero__cta{ display:flex; flex-direction:column; gap:7px; align-items:stretch; flex:none; }
.ps-game-hero__thumb{ width:160px; height:110px; border-radius:10px; background:var(--line); overflow:hidden; flex:none; display:flex; align-items:center; justify-content:center; }
.ps-game-hero__thumb img{ width:100%; height:100%; object-fit:cover; }
.ps-game-hero__head h1{ font-size:26px; color:var(--text); }
.ps-game-hero__provider{ color:var(--gold); font-size:14px; margin:6px 0 0; }
.ps-game-hero__short{ color:var(--text-2); font-size:14px; line-height:1.6; margin:10px 0 0; max-width:560px; }
.ps-game-stats{ display:flex; gap:10px; margin-top:16px; flex-wrap:wrap; }

/* Click-to-play iframe — pełna szerokość strony */
.ps-play-full{ width:100%; margin:22px 0; }
.ps-play__frame{
	position:relative; width:100%; height:min(72vh, 56.25vw); min-height:300px;
	background:var(--bg-3) center/cover no-repeat; overflow:hidden; cursor:pointer;
	border-top:1px solid var(--line-2); border-bottom:1px solid var(--line-2); display:flex;
}
.ps-play__overlay{
	position:absolute; inset:0; z-index:1; display:flex; flex-direction:column;
	align-items:center; justify-content:center; gap:12px;
	background:linear-gradient(180deg, rgba(8,8,12,.5), rgba(8,8,12,.72)); transition:background .15s;
}
.ps-play__frame:hover .ps-play__overlay{ background:linear-gradient(180deg, rgba(8,8,12,.4), rgba(8,8,12,.6)); }
.ps-play__btn{
	display:inline-flex; align-items:center; gap:10px;
	background:var(--gold); color:#0E0E12; border:0; border-radius:40px;
	font-family:var(--font); font-weight:600; font-size:16px; padding:15px 30px; cursor:pointer;
	transition:transform .12s; box-shadow:0 8px 30px rgba(0,0,0,.4);
}
.ps-play__frame:hover .ps-play__btn{ transform:scale(1.05); }
.ps-play__icon{ display:inline-flex; }
.ps-play__note{ font-size:13px; color:#E8E2D4; }
.ps-play__frame:focus-visible{ outline:2px solid var(--gold); outline-offset:-2px; }
.ps-play__frame.is-playing{ cursor:default; height:min(82vh, 56.25vw); }
.ps-play__iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }

/* Sub-rząd chipsów (np. dostawcy w lobby gier) */
.ps-chips--sub{ padding-top:6px; }
.ps-chip--ghost{ font-size:11px; opacity:.85; }

/* Treść strony / lobby / SEO */
.ps-page-content{ padding-top:24px; padding-bottom:8px; }
.ps-page-content.ps-prose{ font-size:15px; }
.ps-page-content :is(.ps-listing,.ps-game-grid,.ps-bonus-list){ margin:18px 0; }

/* Typy bonusu na stronie bonusu */
.ps-bonus-detail__types{ display:flex; gap:6px; justify-content:center; flex-wrap:wrap; margin-bottom:6px; }
.ps-stat{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-sm); padding:10px 16px; }
.ps-stat__label{ display:block; font-size:11px; color:var(--text-4); }
.ps-stat__value{ display:block; font-size:15px; font-weight:600; color:var(--text); margin-top:2px; }
.ps-game-body{ padding-top:26px; padding-bottom:48px; }

/* Siatka gier */
.ps-game-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(180px,1fr)); gap:14px; padding:18px 0 40px; }
.ps-game-card{ background:var(--bg-3); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; transition:border-color .15s; }
.ps-game-card:hover{ border-color:var(--gold-line); }
.ps-game-card__thumb{ aspect-ratio:16/10; background:var(--line); display:flex; align-items:center; justify-content:center; overflow:hidden; }
.ps-game-card__thumb img{ width:100%; height:100%; object-fit:cover; }
.ps-game-card__body{ padding:12px 14px; }
.ps-game-card__name{ font-size:14px; font-weight:600; color:var(--text); font-family:var(--font-head); }
.ps-game-card__provider{ display:block; font-size:12px; color:var(--text-3); margin-top:3px; }
.ps-game-card__stats{ display:flex; gap:10px; margin-top:8px; font-size:11px; color:var(--text-4); }

/* ---------- Pojedynczy bonus ---------- */
.ps-bonus-wrap{ padding:40px 20px; display:flex; justify-content:center; }
.ps-bonus-detail{ max-width:520px; width:100%; text-align:center; background:var(--bg-2); border:1px solid var(--line); border-radius:16px; padding:32px 28px; }
.ps-bonus-detail__logo{ width:110px; height:70px; margin:0 auto 16px; border-radius:10px; background:var(--line); display:flex; align-items:center; justify-content:center; overflow:hidden; }
.ps-bonus-detail h1{ font-size:24px; color:var(--text); margin:12px 0 8px; }
.ps-bonus-detail__value{ font-size:18px; color:var(--gold); font-weight:600; margin:0 0 18px; }
.ps-bonus-detail__facts{ text-align:left; max-width:320px; margin:0 auto 22px; }
.ps-bonus-detail__facts > div{ display:flex; justify-content:space-between; gap:12px; padding:8px 0; border-bottom:1px solid var(--line); }
.ps-bonus-detail__facts dt{ font-size:13px; color:var(--text-4); }
.ps-bonus-detail__facts dd{ font-size:13px; color:var(--text); margin:0; }
.ps-bonus-detail__facts a{ color:var(--gold); }
.ps-code{ font-family:ui-monospace,monospace; color:var(--gold); border:1px dashed var(--gold-line); border-radius:5px; padding:1px 8px; }
.ps-bonus-detail__terms{ font-size:12px; color:var(--text-4); margin-top:18px; line-height:1.6; }
.ps-bonus-detail__content{ text-align:left; margin-top:20px; }

/* ---------- Footer ---------- */
.ps-footer{ background:var(--bg-2); border-top:1px solid var(--line-2); margin-top:auto; }
.ps-footer .ps-container{ padding-top:32px; padding-bottom:28px; }
.ps-footer__top{ display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; padding-bottom:18px; border-bottom:1px solid var(--line); }
.ps-footer__nav{ display:flex; gap:20px; list-style:none; margin:0; padding:0; }
.ps-footer__nav a{ font-size:13px; color:var(--text-3); }
.ps-footer__nav a:hover{ color:var(--gold); }
.ps-footer__disclaimer{ font-size:12px; color:var(--text-4); margin:16px 0 8px; line-height:1.6; }
.ps-footer__disclaimer a{ color:var(--text-3); text-decoration:underline; }
.ps-footer__copy{ font-size:12px; color:var(--text-4); margin:0; }

/* ---------- Logo placeholder ---------- */
.ps-logo{ max-width:100%; max-height:100%; object-fit:contain; }
.ps-logo--empty{ font-size:11px; color:var(--text-4); letter-spacing:1px; }

/* ---------- Paginacja ---------- */
.pagination,.nav-links{ display:flex; gap:6px; justify-content:center; margin-top:24px; flex-wrap:wrap; }
.pagination .page-numbers{ display:inline-flex; min-width:36px; height:36px; align-items:center; justify-content:center; border:1px solid var(--line-2); border-radius:var(--radius-sm); color:var(--text-3); font-size:14px; }
.pagination .page-numbers.current{ background:var(--gold); border-color:var(--gold); color:#0E0E12; }
.pagination a.page-numbers:hover{ border-color:var(--gold); color:var(--gold); }

.ps-empty{ color:var(--text-3); text-align:center; padding:40px 0; }
.ps-post-row{ padding:16px 0; border-bottom:1px solid var(--line); }
.ps-post-row h2{ font-size:18px; color:var(--text); }
.ps-post-row h2:hover{ color:var(--gold); }

/* ---------- Responsywność ---------- */
@media (max-width:880px){
	.ps-casino-grid{ grid-template-columns:1fr; }
	.ps-casino-aside{ position:static; }
}
@media (max-width:760px){
	.ps-nav{ position:absolute; top:64px; left:0; right:0; background:var(--bg-2); border-bottom:1px solid var(--line-2); padding:0; max-height:0; overflow:hidden; transition:max-height .25s ease; }
	.ps-nav.is-open{ max-height:320px; }
	.ps-nav__list{ flex-direction:column; gap:0; padding:8px 20px; }
	.ps-nav__list li{ border-bottom:1px solid var(--line); }
	.ps-nav__list a{ display:block; padding:12px 0; }
	.ps-burger{ display:flex; }
	.ps-search-toggle span{ display:none; }
	.ps-search-toggle{ padding:8px; }

	.ps-hero__title{ font-size:26px; }

	.ps-casino-row{ flex-wrap:wrap; gap:12px; }
	.ps-casino-row__main{ flex-basis:calc(100% - 120px); }
	.ps-casino-row__bonus{ order:4; text-align:left; padding:0; flex-basis:100%; display:flex; gap:8px; align-items:baseline; }
	.ps-casino-row__cta{ order:5; flex-direction:row; flex-basis:100%; }
	.ps-casino-row__cta .ps-btn{ flex:1; }

	.ps-casino-hero__inner{ flex-wrap:wrap; }
	.ps-casino-hero__cta{ flex-basis:100%; }
	.ps-game-hero__inner{ flex-direction:column; align-items:flex-start; }
	.ps-game-hero__cta{ flex-basis:100%; width:100%; }
}
