/* Dieters Boardgames — style.css */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --cream:#f5f0e8;--cream2:#ede7d9;--ink:#1a1510;--ink2:#3d3228;
  --amber:#c8893a;--amber2:#e8b96a;
  --g100:#f0ebe2;--g200:#e0d9cc;--g300:#c8bfb0;--g400:#9a8f80;--g500:#6b5f52;
  --green:#2d5a3d;--green2:#4a8f63;--red:#8b2a2a;--blue:#2a4a7a;
  --r:8px;--r2:5px;
}
html,body{height:100%;font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--ink);font-size:14px;line-height:1.5}
header{position:sticky;top:0;z-index:100;display:flex;align-items:center;gap:16px;padding:0 24px;height:58px;background:var(--ink);box-shadow:0 2px 8px rgba(0,0,0,.3)}
.header-brand{display:flex;align-items:center;gap:10px;flex-shrink:0}
.brand-icon{font-size:22px;color:var(--amber2)}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-title{font-family:'Playfair Display',serif;font-size:16px;font-weight:700;color:#fff}
.brand-sub{font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--amber2)}
.search-wrap{flex:1;max-width:480px;margin:0 auto;position:relative}
.search-wrap svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:rgba(255,255,255,.4);pointer-events:none}
.search-wrap input{width:100%;padding:8px 12px 8px 32px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:var(--r2);color:#fff;font-family:inherit;font-size:13px;outline:none}
.search-wrap input::placeholder{color:rgba(255,255,255,.35)}
.search-wrap input:focus{border-color:var(--amber2)}
.header-right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.stat-pill{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.7);font-size:12px;padding:3px 10px;border-radius:20px}
.btn{display:inline-flex;align-items:center;gap:5px;padding:6px 13px;border:1px solid var(--g300);border-radius:var(--r2);background:#fff;color:var(--ink2);font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:all .13s;white-space:nowrap}
.btn:hover{background:var(--cream2)}
.btn.primary{background:var(--amber);border-color:var(--amber);color:#fff}
.btn.primary:hover{background:#b07830}
.btn.danger{background:#fff5f5;border-color:#fca5a5;color:var(--red)}
.layout{display:flex;height:calc(100vh - 58px);overflow:hidden}
.sidebar{width:200px;flex-shrink:0;background:#fff;border-right:1px solid var(--g200);overflow-y:auto;padding:14px 10px}
.sidebar::-webkit-scrollbar{width:3px}
.sidebar::-webkit-scrollbar-thumb{background:var(--g200)}
.sidebar-section{margin-bottom:18px}
.sidebar-section h4{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--g400);padding:0 6px;margin-bottom:5px}
.filter-group{display:flex;flex-direction:column;gap:1px}
.filter-btn{display:flex;align-items:center;justify-content:space-between;padding:5px 7px;border:none;border-radius:var(--r2);background:transparent;color:var(--ink2);font-family:inherit;font-size:12.5px;cursor:pointer;text-align:left;transition:background .1s}
.filter-btn:hover{background:var(--g100)}
.filter-btn.active{background:var(--ink);color:#fff;font-weight:500}
.filter-btn .count{font-size:11px;background:var(--g100);color:var(--g400);padding:1px 6px;border-radius:10px}
.filter-btn.active .count{background:rgba(255,255,255,.2);color:rgba(255,255,255,.8)}
.main{flex:1;overflow-y:auto;padding:18px 22px}
.main::-webkit-scrollbar{width:8px}
.main::-webkit-scrollbar-thumb{background:var(--g400);border-radius:4px}
.main::-webkit-scrollbar-thumb:hover{background:var(--g500)}
.main::-webkit-scrollbar-track{background:var(--g100)}
.view-bar{display:flex;align-items:center;gap:10px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--g200)}
.view-label{flex:1;font-size:13px;color:var(--g500);font-weight:500}
.sort-select{padding:6px 10px;border:1px solid var(--g200);border-radius:var(--r2);background:#fff;font-family:inherit;font-size:13px;outline:none;cursor:pointer}
.view-tabs{display:flex;gap:3px;background:var(--g100);padding:3px;border-radius:var(--r2)}
.view-tab{display:flex;align-items:center;gap:4px;padding:5px 10px;border:none;border-radius:calc(var(--r2) - 1px);background:transparent;color:var(--g500);font-family:inherit;font-size:12px;font-weight:500;cursor:pointer;transition:all .13s}
.view-tab:hover{color:var(--ink)}
.view-tab.active{background:#fff;color:var(--ink);box-shadow:0 1px 4px rgba(0,0,0,.1)}
.game-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
.game-card{background:#fff;border:1px solid var(--g200);border-radius:var(--r);overflow:hidden;cursor:pointer;position:relative;transition:transform .16s,box-shadow .16s}
.game-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.12)}
.game-card.favorit{border-color:var(--amber)}
.card-cover{width:100%;aspect-ratio:3/2;background:var(--g100);border-bottom:1px solid var(--g200);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.card-cover::before{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 19px,var(--g200) 19px,var(--g200) 20px),repeating-linear-gradient(90deg,transparent,transparent 19px,var(--g200) 19px,var(--g200) 20px);opacity:.6}
.card-icon{font-size:26px;color:var(--g300);position:relative;z-index:1;opacity:.7}
.card-btns{position:absolute;top:6px;right:6px;display:flex;gap:3px;z-index:2}
.card-body{padding:9px 11px 11px}
.card-title{font-size:15px;font-weight:600;color:var(--ink);line-height:1.3;margin-bottom:5px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-tags{display:flex;flex-wrap:wrap;gap:3px;margin-bottom:4px}
.card-sub{font-size:11px;color:var(--g400);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.card-bgg{font-size:11px;font-weight:600;color:var(--amber);margin-top:3px}
.card-sdj{font-size:13px;margin-top:3px}
.game-list{display:flex;flex-direction:column;gap:2px}
.game-row{display:flex;align-items:center;gap:10px;padding:9px 12px;background:#fff;border:1px solid var(--g200);border-radius:var(--r2);cursor:pointer;transition:background .1s}
.game-row:hover{background:var(--cream)}
.game-row.favorit{border-left:3px solid var(--amber)}
.row-icon{font-size:18px;color:var(--g300);width:32px;text-align:center;flex-shrink:0}
.row-info{flex:1;min-width:0}
.row-title{font-size:13px;font-weight:600;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.row-sub{font-size:11.5px;color:var(--g400);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.row-tags{display:flex;gap:4px;flex-shrink:0}
.row-bgg{font-size:12px;font-weight:600;color:var(--amber);flex-shrink:0}
.row-btns{display:flex;gap:3px;flex-shrink:0}
.icon-btn{width:26px;height:26px;border:1px solid var(--g200);border-radius:var(--r2);background:#fff;color:var(--g400);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s}
.icon-btn:hover{border-color:var(--amber);color:var(--amber)}
.icon-btn.fav{background:#fff7ed;border-color:var(--amber);color:var(--amber)}
.icon-btn.played{background:#f0fdf4;border-color:var(--green2);color:var(--green)}
.tag{font-size:10.5px;font-weight:500;padding:2px 7px;border-radius:10px;white-space:nowrap}
.tag-genre{background:#eff6ff;color:var(--blue)}
.tag-kind{background:#f0fdf4;color:var(--green)}
.tag-expert{background:#fdf4ff;color:#7e22ce}
.tag-party{background:#fdf2f8;color:#be185d}
.tag-erw{background:var(--g100);color:var(--g500)}
.tag-sdj{background:#fff7ed;color:var(--amber);border:1px solid #fed7aa}
.group-block{margin-bottom:22px}
.group-title{font-family:'Playfair Display',serif;font-size:15px;font-weight:700;color:var(--ink);margin-bottom:7px;padding-bottom:5px;border-bottom:2px solid var(--amber);display:flex;align-items:baseline;gap:8px}
.group-count{font-family:'DM Sans',sans-serif;font-size:11px;color:var(--g400);font-weight:400}
.panel-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:200;opacity:0;pointer-events:none;transition:opacity .2s}
.panel-overlay.open{opacity:1;pointer-events:all}
.detail-panel{position:fixed;top:0;right:-400px;width:370px;height:100vh;background:#fff;z-index:201;overflow-y:auto;transition:right .25s cubic-bezier(.4,0,.2,1);box-shadow:-6px 0 24px rgba(0,0,0,.15)}
.detail-panel.open{right:0}
.panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:16px 18px 12px;border-bottom:1px solid var(--g200)}
.panel-title{font-family:'Playfair Display',serif;font-size:17px;font-weight:700;color:var(--ink);line-height:1.3;flex:1}
.panel-close{width:28px;height:28px;border:1px solid var(--g200);border-radius:var(--r2);background:#fff;color:var(--g500);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.panel-close:hover{background:var(--cream)}
.panel-body{padding:14px 18px}
.panel-actions{display:flex;gap:7px;margin-bottom:14px;flex-wrap:wrap}
.panel-row{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;padding:7px 0;border-bottom:1px solid var(--g100);font-size:13px}
.pr-label{color:var(--g400);font-weight:500;flex-shrink:0}
.pr-val{color:var(--ink2);text-align:right;word-break:break-word}
.panel-notes{margin-top:14px}
.panel-notes label{display:block;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--g400);margin-bottom:5px}
.bgg-row{display:flex;align-items:center;gap:7px}
.bgg-input{width:80px;padding:6px 9px;border:1px solid var(--g200);border-radius:var(--r2);font-family:inherit;font-size:13px;outline:none}
.bgg-input:focus{border-color:var(--amber)}
textarea{width:100%;padding:8px 10px;border:1px solid var(--g200);border-radius:var(--r2);font-family:inherit;font-size:13px;color:var(--ink);resize:vertical;outline:none}
textarea:focus{border-color:var(--amber)}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:300;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{background:#fff;border-radius:var(--r);width:510px;max-width:calc(100vw - 32px);max-height:calc(100vh - 48px);overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 12px;border-bottom:1px solid var(--g200)}
.modal-head h2{font-family:'Playfair Display',serif;font-size:17px;font-weight:700;color:var(--ink)}
.modal-body{padding:14px 18px;display:flex;flex-direction:column;gap:11px}
.field{display:flex;flex-direction:column;gap:4px}
.field label{font-size:12px;font-weight:600;color:var(--g500);letter-spacing:.04em}
.field input,.field select,.field textarea{padding:7px 9px;border:1px solid var(--g200);border-radius:var(--r2);font-family:inherit;font-size:13px;color:var(--ink);outline:none;background:#fff}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--amber)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.modal-footer{display:flex;align-items:center;gap:8px;padding:12px 18px;border-top:1px solid var(--g200)}
.delete-area{flex:1}
.empty{text-align:center;padding:60px 20px;color:var(--g400)}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(16px);background:var(--ink);color:#fff;font-size:13px;padding:8px 18px;border-radius:20px;box-shadow:0 8px 24px rgba(0,0,0,.2);opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;white-space:nowrap;z-index:500}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.error{background:var(--red)}
@media(max-width:720px){.sidebar{display:none}.main{padding:12px 14px}.game-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}}
