/* Garaż Social — system panel style (matches out.garazkielce.pl) */
:root{
  --bg:#0e0e0e;--bg2:#161616;--bg3:#1e1e1e;--bg4:#242424;
  --border:#2a2a2a;--border2:#383838;--border3:#464646;
  --text:#e8e4dc;--muted:#666;--muted2:#3a3a3a;
  --accent:#e8533a;--accent2:#f0a500;
  --green:#4caf7d;--blue:#4a9eff;--purple:#9b6dff;
  --font-d:'Bebas Neue',sans-serif;
  --font-m:'DM Mono',monospace;
  --font-b:'DM Sans',sans-serif;
  --r:6px;
}
*{box-sizing:border-box;margin:0;padding:0;}
body{background:var(--bg);color:var(--text);font-family:var(--font-b);font-size:15px;min-height:100vh;}
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:998;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");opacity:.5;}
a{color:var(--text);text-decoration:none;}

/* ══ LAYOUT ════════════════════════════════════════════════════════════════ */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh;}

.sidebar{background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow:hidden;}
.logo{padding:22px 20px 15px;border-bottom:1px solid var(--border);flex-shrink:0;}
.logo-text{font-family:var(--font-d);font-size:28px;letter-spacing:2px;line-height:1;}
.logo-sub{font-size:9px;letter-spacing:4px;color:var(--muted);text-transform:uppercase;margin-top:3px;font-family:var(--font-m);}
.nav-side{padding:10px 8px;flex:1;overflow-y:auto;}
.nav-section{font-size:9px;letter-spacing:3px;color:var(--muted2);text-transform:uppercase;padding:12px 10px 5px;font-family:var(--font-m);}
.nav-item{display:flex;align-items:center;justify-content:space-between;padding:9px 10px;border-radius:var(--r);cursor:pointer;color:var(--muted);font-size:13px;transition:all .15s;margin-bottom:2px;border:1px solid transparent;text-decoration:none;}
.nav-item:hover{color:var(--text);background:var(--bg3);}
.nav-item.active{color:var(--text);background:var(--bg3);border-color:var(--border2);}
.sidebar-footer{padding:12px 14px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.sync-status{font-size:10px;color:var(--muted);font-family:var(--font-m);display:flex;align-items:center;gap:5px;}
.sync-dot{width:5px;height:5px;border-radius:50%;background:var(--green);box-shadow:0 0 5px var(--green);animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.logout-btn{font-size:10px;color:var(--muted);background:none;border:none;cursor:pointer;font-family:var(--font-m);padding:0;text-transform:uppercase;letter-spacing:1px;}
.logout-btn:hover{color:var(--accent);}

.main{overflow-y:auto;}
.topbar{position:sticky;top:0;z-index:10;background:rgba(14,14,14,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:11px 24px;display:flex;align-items:center;justify-content:space-between;gap:12px;}
.topbar-title{font-family:var(--font-d);font-size:19px;letter-spacing:1px;}
.topbar-sub{font-size:10px;letter-spacing:2px;color:var(--muted);font-family:var(--font-m);text-transform:uppercase;margin-top:2px;}
.topbar-actions{display:flex;gap:6px;}
.content{padding:18px 24px;}

/* ══ BUTTONS ════════════════════════════════════════════════════════════════ */
.btn{padding:8px 14px;border-radius:var(--r);font-size:12px;font-weight:500;cursor:pointer;border:1px solid var(--border2);background:var(--bg3);color:var(--text);font-family:var(--font-b);transition:all .15s;white-space:nowrap;display:inline-block;text-align:center;line-height:1.3;text-decoration:none;}
.btn:hover{border-color:var(--border3);background:#222;}
.btn-accent,.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff;}
.btn-accent:hover,.btn-primary:hover{background:#d44530;border-color:#d44530;}
.btn-ghost{background:transparent;border-color:transparent;color:var(--muted);}
.btn-ghost:hover{color:var(--text);background:var(--bg3);border-color:var(--border);}
.btn-green{background:rgba(76,175,125,.1);border-color:rgba(76,175,125,.25);color:var(--green);}
.btn-green:hover{background:rgba(76,175,125,.2);}
.btn-red{background:rgba(232,83,58,.1);border-color:rgba(232,83,58,.25);color:var(--accent);}
.btn-red:hover{background:rgba(232,83,58,.2);}
.btn-blue{background:rgba(74,158,255,.1);border-color:rgba(74,158,255,.25);color:var(--blue);}
.btn-blue:hover{background:rgba(74,158,255,.2);}
.btn-sm{padding:5px 10px;font-size:11px;}
.btn-xs{padding:3px 7px;font-size:10px;}

/* ══ FORMS ════════════════════════════════════════════════════════════════ */
.form{display:flex;flex-direction:column;gap:14px;}
.form label{display:flex;flex-direction:column;font-family:var(--font-m);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);gap:6px;}
.form input,.form textarea,.form select{background:var(--bg3);border:1px solid var(--border);color:var(--text);padding:9px 11px;font-family:var(--font-b);font-size:13px;border-radius:var(--r);outline:none;}
.form input:focus,.form textarea:focus,.form select:focus{border-color:var(--accent);}
.form textarea{resize:vertical;font-family:var(--font-b);}

/* ══ KPI ════════════════════════════════════════════════════════════════ */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin-bottom:18px;}
@media (max-width:900px){.kpi-grid{grid-template-columns:repeat(2,1fr);}}
.kpi-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:13px 14px;position:relative;overflow:hidden;}
.kpi-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);}
.kpi-card.kc-g::before{background:var(--green);}
.kpi-card.kc-p::before{background:var(--purple);}
.kpi-card.kc-a::before{background:var(--accent2);}
.kpi-card.kc-b::before{background:var(--blue);}
.kpi-label{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);font-family:var(--font-m);margin-bottom:7px;}
.kpi-value{font-family:var(--font-d);font-size:28px;letter-spacing:.5px;line-height:1;}

/* ══ CARDS / SECTIONS ════════════════════════════════════════════════════ */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:16px;margin-bottom:14px;}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:11px;padding-bottom:11px;border-bottom:1px solid var(--border);}
.card-title{font-family:var(--font-m);font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);}
.card-h{font-family:var(--font-d);font-size:18px;letter-spacing:1px;}

.sec{padding:18px 0;border-top:1px solid var(--border);margin-top:18px;}
.sec:first-of-type{border-top:none;margin-top:0;padding-top:0;}
.sec h2{font-family:var(--font-d);font-size:18px;letter-spacing:1px;margin-bottom:12px;}

/* ══ TABLES / LISTS ════════════════════════════════════════════════════ */
.tbl,.health-tbl{width:100%;border-collapse:collapse;font-family:var(--font-b);}
.tbl th,.tbl td,.health-tbl th,.health-tbl td{text-align:left;padding:9px 12px;border-bottom:1px solid var(--border);font-size:13px;}
.tbl th,.health-tbl th{font-family:var(--font-m);text-transform:uppercase;letter-spacing:1.5px;font-size:10px;color:var(--muted);}
.tbl tr:hover td{background:rgba(255,255,255,.015);}

.list,.event-list{list-style:none;padding:0;}
.list li,.event-list li{padding:11px 14px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);margin-bottom:6px;display:flex;align-items:center;justify-content:space-between;gap:12px;}
.list li strong,.event-list li strong{font-size:13px;}
.muted{color:var(--muted);font-size:12px;}
.row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.row.gap{gap:10px;margin:10px 0;}

/* ══ POST CARD ══════════════════════════════════════════════════════════ */
.post-list{display:flex;flex-direction:column;gap:9px;}
.post-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:14px;display:grid;grid-template-columns:160px 1fr auto;gap:14px;align-items:center;}
.post-card__photo{width:100%;height:auto;border-radius:4px;}
.post-card__body .t-h3,.post-card__body strong{font-family:var(--font-d);font-size:18px;letter-spacing:.5px;display:block;margin:2px 0 4px;}
.post-card__body .meta{font-size:11px;color:var(--muted);font-family:var(--font-m);margin-top:4px;text-transform:uppercase;letter-spacing:1px;}
.num{font-family:var(--font-m);color:var(--accent);font-size:9px;letter-spacing:2px;display:block;}

/* ══ STATUS BADGES ════════════════════════════════════════════════════ */
.status-badge,.sb{font-size:10px;letter-spacing:1px;text-transform:uppercase;padding:3px 8px;border-radius:3px;font-family:var(--font-m);}
.sb-pending{background:rgba(240,165,0,.12);color:var(--accent2);}
.sb-approved{background:rgba(76,175,125,.12);color:var(--green);}
.sb-published{background:rgba(76,175,125,.18);color:var(--green);}
.sb-rejected,.sb-failed{background:rgba(232,83,58,.12);color:var(--accent);}
.sb-skipped{background:rgba(102,102,102,.18);color:var(--muted);}

/* ══ STAT TILES (legacy alias) ═══════════════════════════════════════════ */
.grid.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin-bottom:18px;}
@media (max-width:900px){.grid.stats{grid-template-columns:repeat(2,1fr);}}
.stat-tile{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:13px 14px;position:relative;overflow:hidden;}
.stat-tile::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);}
.stat-tile__value{font-family:var(--font-d);font-size:28px;letter-spacing:.5px;line-height:1;color:var(--text);margin:0;}
.stat-tile__label{font-family:var(--font-m);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin:7px 0 0;}

/* ══ HEADINGS ═══════════════════════════════════════════════════════════ */
.eyebrow{display:none;}
.t-display{font-family:var(--font-d);font-size:24px;letter-spacing:1px;margin-bottom:14px;line-height:1;}
.t-display .o{color:var(--accent);}
.t-h2{font-family:var(--font-d);font-size:18px;letter-spacing:1px;margin:0 0 12px;}
.t-h3{font-family:var(--font-d);font-size:16px;letter-spacing:.5px;margin:0 0 6px;}

/* ══ LOGIN ════════════════════════════════════════════════════════════ */
.login-shell{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;}
.login-box{background:var(--bg2);border:1px solid var(--border2);border-radius:12px;padding:38px 34px;width:340px;text-align:center;box-shadow:0 24px 64px rgba(0,0,0,.6);}
.login-logo{font-family:var(--font-d);font-size:46px;letter-spacing:3px;margin-bottom:4px;}
.login-sub{font-size:9px;letter-spacing:4px;color:var(--muted);font-family:var(--font-m);text-transform:uppercase;margin-bottom:30px;}
.login-shell .form{text-align:left;}
.login-shell .btn-primary{width:100%;padding:11px;}
.alert{background:rgba(232,83,58,.08);border:1px solid rgba(232,83,58,.3);color:var(--accent);padding:9px 12px;font-family:var(--font-m);font-size:11px;margin-bottom:14px;border-radius:var(--r);}

/* ══ POST EDIT ════════════════════════════════════════════════════════ */
.grid.post-edit{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
@media (max-width:900px){.grid.post-edit{grid-template-columns:1fr;}}
.preview{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:11px;}
.preview img{width:100%;height:auto;border-radius:4px;}

/* ══ MEDIA LIBRARY ══════════════════════════════════════════════════════ */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:9px;}
.tile{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:8px;}
.tile img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:4px;}
.tile-meta{display:flex;justify-content:space-between;padding:8px 4px 4px;font-family:var(--font-m);font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);}
.tile-meta strong{color:var(--text);font-weight:500;}
.badge{background:var(--accent);color:#fff;padding:2px 7px;font-family:var(--font-m);font-size:9px;letter-spacing:1px;border-radius:3px;}
.tile-edit{padding:11px 4px;}
details>summary{cursor:pointer;list-style:none;display:inline-block;}
details>summary::-webkit-details-marker{display:none;}
.upload{display:grid;grid-template-columns:1fr 2fr auto;gap:11px;align-items:end;margin-bottom:18px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:14px;}
@media (max-width:900px){.upload{grid-template-columns:1fr;}}
.filter{margin-bottom:14px;}

/* ══ PAGER ═══════════════════════════════════════════════════════════ */
.pager{margin-top:14px;display:flex;align-items:center;gap:14px;}
.pager .muted{font-family:var(--font-m);font-size:11px;text-transform:uppercase;letter-spacing:1px;}

/* Caption preview na dashboard */
.caption-preview{margin-top:10px;padding:10px 12px;background:var(--bg3);border:1px solid var(--border);border-radius:4px;font-family:var(--font-b);font-size:12px;color:var(--text);white-space:pre-wrap;line-height:1.5;max-height:240px;overflow-y:auto;}
.next-post{display:grid;grid-template-columns:200px 1fr auto;align-items:start;}

/* Tags w media library */
.tile-tags{display:flex;flex-wrap:wrap;gap:3px;padding:0 4px 4px;}
.tag{font-family:var(--font-m);font-size:9px;letter-spacing:.5px;padding:2px 5px;border-radius:3px;}
.tag-ai{background:rgba(74,158,255,.1);color:var(--blue);border:1px solid rgba(74,158,255,.2);}
.tag-custom{background:rgba(155,109,255,.1);color:var(--purple);border:1px solid rgba(155,109,255,.2);}

/* Modal — photo gallery picker */
.modal-bg{position:fixed;inset:0;z-index:100;background:rgba(0,0,0,.7);display:none;align-items:center;justify-content:center;padding:20px;}
.modal-bg.open{display:flex;}
.modal-box{background:var(--bg);border:1px solid var(--border2);border-radius:var(--r);width:100%;max-width:1100px;max-height:88vh;display:flex;flex-direction:column;overflow:hidden;}
.modal-header{display:flex;align-items:center;padding:14px 18px;border-bottom:1px solid var(--border);}
.modal-header h3{flex-shrink:0;}
.modal-header .btn-ghost{font-size:24px;line-height:1;padding:4px 12px;}
.modal-body{padding:14px 18px;overflow-y:auto;}
.photo-pick{cursor:pointer;transition:border-color .15s,transform .12s;}
.photo-pick:hover{border-color:var(--accent);}
.photo-pick:active{transform:scale(.98);}

/* Calendar */
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;}
@media (max-width:1100px){.calendar-grid{grid-template-columns:repeat(4,1fr);}}
@media (max-width:700px){.calendar-grid{grid-template-columns:repeat(2,1fr);}}
.cal-day{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:11px;display:flex;flex-direction:column;min-height:200px;}
.cal-day.has-post{border-color:var(--border2);}
.cal-day.is-approved{border-left:3px solid var(--green);}
.cal-day.is-published{border-left:3px solid var(--green);opacity:.85;}
.cal-day-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px;}
.cal-wd{font-family:var(--font-m);font-size:9px;letter-spacing:1.5px;color:var(--muted);text-transform:uppercase;}
.cal-date{font-family:var(--font-d);font-size:18px;letter-spacing:.5px;}
.cal-theme{font-family:var(--font-m);font-size:9px;letter-spacing:1px;color:var(--accent2);text-transform:uppercase;margin-bottom:8px;}
.cal-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--muted2);font-family:var(--font-m);font-size:10px;text-transform:uppercase;letter-spacing:1px;}
.cal-post{display:flex;flex-direction:column;gap:6px;flex:1;}
.cal-post-status{align-self:flex-start;}
.cal-post-thumb{width:100%;height:80px;object-fit:cover;border-radius:3px;}
.cal-post-headline{font-family:var(--font-d);font-size:13px;letter-spacing:.3px;line-height:1.15;}
.cal-post-time{font-family:var(--font-m);font-size:10px;color:var(--muted);}

/* Template picker thumbnails */
.tpl-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin-top:6px;}
@media (max-width:900px){.tpl-grid{grid-template-columns:repeat(2,1fr);}}
.tpl-pick{position:relative;cursor:pointer;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:6px;display:flex;flex-direction:column;gap:6px;transition:border-color .15s;text-transform:none;letter-spacing:0;color:var(--text);font-size:11px;}
.tpl-pick input{position:absolute;opacity:0;pointer-events:none;}
.tpl-pick img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:4px;}
.tpl-label{font-family:var(--font-m);font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);text-align:center;}
.tpl-pick:hover{border-color:var(--border3);}
.tpl-pick.selected{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent);}
.tpl-pick.selected .tpl-label{color:var(--accent);}

/* Calendar actions in cell */
.cal-actions{display:flex;gap:6px;margin-top:auto;justify-content:center;flex-wrap:wrap;padding-top:10px;}
.cal-actions form{margin:0;}

/* Range slider */
input[type="range"]{-webkit-appearance:none;appearance:none;background:var(--bg3);border:1px solid var(--border);height:6px;border-radius:3px;outline:none;}
input[type="range"]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:var(--accent);border-radius:50%;cursor:pointer;border:2px solid var(--bg);}
input[type="range"]::-moz-range-thumb{width:18px;height:18px;background:var(--accent);border-radius:50%;cursor:pointer;border:2px solid var(--bg);}

/* Emoji picker (caption) */
.emoji-picker{position:absolute;top:36px;left:0;z-index:50;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);box-shadow:0 8px 24px rgba(0,0,0,.5);padding:10px;width:380px;max-height:340px;overflow-y:auto;}
.emoji-group{margin-bottom:8px;}
.emoji-group:last-child{margin-bottom:0;}
.emoji-group-title{font-family:var(--font-m);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:4px;}
.emoji-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:2px;}
.emoji-btn{background:transparent;border:1px solid transparent;border-radius:4px;padding:4px;font-size:20px;cursor:pointer;line-height:1;transition:background .12s,border-color .12s;}
.emoji-btn:hover{background:var(--bg3);border-color:var(--border);}

/* Media library — bulk toolbar */
.bulk-toolbar{position:sticky;top:0;z-index:30;display:flex;gap:14px;align-items:center;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:10px 14px;margin:14px 0;}
.bulk-toolbar input[type="checkbox"]{width:18px;height:18px;cursor:pointer;accent-color:var(--accent);}
.btn-red{background:#7a1f1f;color:#f2ece2;border:1px solid #9a3030;}
.btn-red:hover:not(:disabled){background:#9a2828;}
button:disabled{opacity:.4;cursor:not-allowed;}

/* Tile — checkbox in corner + edit button */
.tile{position:relative;}
.tile-check{position:absolute;top:8px;left:8px;z-index:5;background:rgba(10,9,8,.78);padding:6px;border-radius:4px;cursor:pointer;display:flex;align-items:center;}
.tile-check input{width:18px;height:18px;cursor:pointer;accent-color:var(--accent);margin:0;}
.tile-edit-btn{margin-top:8px;width:100%;}

/* Pagination */
.pagination{display:flex;gap:14px;align-items:center;justify-content:center;margin:24px 0;padding:14px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);}

/* Offcanvas drawer (right slide) */
.drawer{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.5);display:none;}
.drawer.open{display:block;}
.drawer-box{position:absolute;top:0;right:0;height:100vh;width:min(480px,90vw);background:var(--bg2);border-left:1px solid var(--border);box-shadow:-8px 0 24px rgba(0,0,0,.5);overflow-y:auto;animation:drawerIn .2s ease-out;}
@keyframes drawerIn{from{transform:translateX(40px);opacity:0;}to{transform:translateX(0);opacity:1;}}
.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg2);z-index:1;}
.drawer-body{padding:18px;}
.drawer-photo img{width:100%;border-radius:var(--r);background:var(--bg);}

/* Body lock — gdy drawer/modal otwarty (zapobiega scrollowi pod spodem) */
body.no-scroll{overflow:hidden;}
