*{box-sizing:border-box}html,body{margin:0;min-height:100%}body{font-family:"Segoe UI","Noto Sans",sans-serif;background:var(--bg);color:var(--text)}a{text-decoration:none;color:inherit}body.no-scroll{overflow:hidden}
.layout{display:grid;grid-template-columns:320px 1fr;min-height:100vh}.sidebar{border-right:1px solid var(--line);background:var(--bg-soft);padding:20px 14px;position:sticky;top:0;height:100vh;overflow-y:auto}
.sidebar-header h1{margin:0;font-size:1.3rem}.sidebar-header p{margin:6px 0 0;color:var(--muted);font-size:.9rem}.search-form{margin:20px 0;display:grid;grid-template-columns:1fr auto;gap:10px}
.search-form input,.admin-form input,.admin-form textarea,.admin-form select,.rating-form select{width:100%;border:1px solid var(--line);background:#0f1722;color:var(--text);border-radius:8px;padding:10px}
.search-form button,.admin-form button,.rating-form button,.admin-btn{border:0;border-radius:8px;padding:10px 14px;background:var(--accent);color:#111;font-weight:700;cursor:pointer;display:inline-block}
.category-nav{display:grid;gap:6px}.category-nav .category-tree{list-style:none;margin:4px 0 4px 10px;padding:0 0 0 14px;border-left:1px dashed var(--line)}.category-nav .category-item{display:block;border:0;background:transparent;border-radius:0;padding:0;min-width:0}.category-nav .category-row{display:grid;grid-template-columns:18px minmax(0,1fr);align-items:center;gap:6px}.category-nav .category-toggle,.category-nav .category-spacer{width:18px;height:18px;flex:0 0 18px}.category-nav .category-toggle{border:0;background:transparent;padding:0;cursor:pointer;position:relative;border-radius:4px;appearance:none}.category-nav .category-toggle::before{content:"";position:absolute;top:50%;left:50%;width:7px;height:7px;border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);transform:translate(-60%,-50%) rotate(-45deg);transition:transform .16s ease,border-color .16s ease}.category-nav .category-toggle:hover::before,.category-nav .category-toggle:focus-visible::before{border-color:var(--text)}.category-nav .category-toggle:focus-visible{outline:1px solid var(--accent);outline-offset:2px}.category-nav .category-item.is-open>.category-row .category-toggle::before{transform:translate(-50%,-65%) rotate(45deg)}.category-nav .category-item.has-children:not(.is-open)>ul{display:none}.category-nav .category-link{display:block;padding:9px 10px;border-radius:8px;color:var(--muted)}.category-nav .category-link:hover,.category-nav .category-link.active{background:var(--hover);color:var(--text)}
.admin-box{margin-top:20px;border:1px solid var(--line);border-radius:10px;padding:10px;color:var(--muted);display:grid;gap:6px;font-size:.85rem}.admin-box.admin{border-color:var(--accent)}.admin-actions{display:grid;gap:8px}.edit-state{color:var(--text);font-weight:700}
.content{padding:24px}.content-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}.content-header h2{margin:0}.content-header p{margin:4px 0 0;color:var(--muted)}.sidebar-toggle{display:none}
.app-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(132px,1fr));gap:14px}.app-card{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:space-between;gap:8px;padding:13px;border-radius:2px;border:1px solid var(--line);background:var(--card);aspect-ratio:1/1.12;min-height:0;box-shadow:var(--shadow)}.app-card:hover{transform:translateY(-2px)}
.app-card img{width:calc(100% - 22px);max-width:119px;aspect-ratio:1/1;height:auto;object-fit:contain}.app-card h3{margin:0 0 2px 0;text-align:center;font-size:1rem;font-weight:400;line-height:1.2;min-height:2.4em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;word-break:break-word}.app-card.edit-mode{border:2px dashed var(--accent)}.edit-badge{position:absolute;top:10px;right:10px;background:var(--hover);border:1px solid var(--accent);border-radius:999px;padding:2px 8px;font-size:.72rem}
.empty-state{border:1px dashed var(--line);border-radius:8px;padding:28px;background:var(--card)}
.detail-body{padding:26px;min-height:100vh}.detail-wrapper{max-width:1000px;margin:0 auto;min-height:calc(100vh - 52px);display:flex;flex-direction:column}.back-link{display:inline-block;margin-bottom:16px;color:var(--muted)}
.detail-card{border:1px solid var(--line);border-radius:10px;background:var(--card);padding:24px;box-shadow:var(--shadow);display:flex;flex-direction:column;flex:1}.detail-header{display:flex;align-items:center;gap:16px;margin-bottom:16px}.detail-header img{width:84px;height:84px;border-radius:10px;object-fit:contain;background:#0d151e;border:1px solid var(--line);padding:10px}
.short{margin:8px 0 0;color:var(--muted)}.version{margin:8px 0 0;color:var(--accent)}
.rating-panel{border:1px solid var(--line);border-radius:8px;padding:14px;background:#0e1620;margin:16px 0}.stars{font-size:1.4rem;letter-spacing:.15em}.star{color:#55667a}.star.filled{color:#f7b84a}.rating-meta{color:var(--muted)}.rating-form{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.admin-note{margin-top:10px;border-left:3px solid var(--accent);padding-left:10px}.rating-picker{display:flex;gap:6px;align-items:center}.admin-form .rating-star-btn{border:0;background:transparent;color:#55667a;font-size:1.9rem;line-height:1;padding:2px 4px;cursor:pointer}.admin-form .rating-star-btn:hover,.admin-form .rating-star-btn:focus-visible{color:#f7b84a;outline:0}.admin-form .rating-star-btn.active{color:#f7b84a}.rating-editor-preview{display:flex;align-items:center;gap:8px}
.detail-content{line-height:1.6}.screenshot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.screenshot-grid img{width:100%;aspect-ratio:16/9;object-fit:cover;object-position:center;display:block;border-radius:8px;border:1px solid var(--line);background:#0b121a;cursor:zoom-in}
.download-actions{display:flex;justify-content:center;align-items:center;gap:22px;flex-wrap:wrap;margin-top:auto;padding-top:20px}.download-btn{display:inline-flex;justify-content:center;align-items:center;min-width:180px;margin-top:0;background:var(--accent);color:#111;font-weight:700;padding:11px 16px;border-radius:8px}
.lightbox{position:fixed;inset:0;background:rgba(2,6,10,.92);display:none;align-items:center;justify-content:center;z-index:99}.lightbox.open{display:flex}.lightbox img{max-width:min(94vw,1400px);max-height:88vh;border-radius:8px;border:1px solid var(--line)}
.lb-close,.lb-nav{position:absolute;border:1px solid var(--line);background:#0d151f;color:var(--text);border-radius:8px;cursor:pointer}.lb-close{top:20px;right:20px;font-size:1.8rem;width:48px;height:48px}.lb-nav{top:50%;transform:translateY(-50%);width:52px;height:68px;font-size:2rem}.lb-nav.prev{left:18px}.lb-nav.next{right:18px}
.admin-page{display:grid;gap:16px}.admin-form{display:grid;gap:12px}.admin-form label{display:grid;gap:6px}.form-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.form-alert{border-radius:8px;padding:10px;margin-bottom:12px}.form-alert.error{background:#3a1616;border:1px solid #a83e3e}.form-alert.success{background:#103329;border:1px solid #2f8a72}button.danger{background:var(--danger);color:#fff}
.admin-access-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin:4px 0 18px}.admin-access-card,.admin-access-host-card{border:1px solid var(--line);background:#0f1722;border-radius:10px;padding:12px;display:grid;gap:8px}.admin-access-card strong,.admin-access-host-card strong{font-size:.92rem}.admin-access-columns{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}.admin-access-list{display:flex;flex-wrap:wrap;gap:8px}.admin-access-badge{display:inline-flex;align-items:center;padding:7px 10px;border-radius:999px;border:1px solid var(--line);background:#101926;color:var(--text);font-size:.9rem}.admin-access-badge.custom{border-color:var(--accent)}.admin-access-badge.resolved{border-color:#2f8a72}.admin-access-empty,.admin-access-note{color:var(--muted)}.admin-access-hosts{display:grid;gap:12px;margin-top:16px}
.existing-shots{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.existing-shots img{width:100%;border:1px solid var(--line);border-radius:8px}.screenshot-card{display:grid;gap:8px;padding:8px;border:1px solid var(--line);border-radius:10px;background:#0f1722}.screenshot-card img{aspect-ratio:16/9;object-fit:cover;background:#0b121a}.screenshot-card.is-removed{opacity:.45}.screenshot-remove-btn{width:100%;border:1px solid var(--danger);border-radius:8px;padding:9px 10px;background:transparent;color:#ffb3b3;cursor:pointer;font-weight:700}.screenshot-remove-btn.restore{border-color:#2f8a72;color:#8fe0c4}
.category-list{display:grid;gap:8px}.category-item{display:flex;justify-content:space-between;align-items:center;border:1px solid var(--line);border-radius:8px;padding:10px 12px;background:#0f1722}.category-item small{color:var(--muted)}
.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.65);z-index:120}.modal.open{display:flex}.modal-card{width:min(640px,92vw);background:var(--card);border:1px solid var(--line);border-radius:10px;padding:18px}
@media (max-width:900px){.layout{grid-template-columns:1fr}.sidebar{position:fixed;z-index:20;width:min(85vw,320px);transform:translateX(-100%);transition:transform .2s;height:100vh}.sidebar.open{transform:translateX(0)}.sidebar-toggle{display:inline-block;border:1px solid var(--line);color:var(--text);background:var(--bg-soft);border-radius:8px;padding:9px 12px}.content{padding:18px}}
.admin-theme-form{display:grid;gap:6px;margin-top:10px}.admin-theme-form label{font-size:.82rem;color:var(--muted)}.admin-theme-form select{width:100%;border:1px solid var(--line);background:#0f1722;color:var(--text);border-radius:8px;padding:8px 10px}
.sidebar-logo{display:block;width:100%;max-width:180px;height:auto;border-radius:10px;border:1px solid var(--line);box-shadow:var(--shadow);margin-bottom:10px}
/* Layout overrides for wider sidebar and one-line branding */
.layout{grid-template-columns:300px 1fr}
.sidebar-header-row{display:flex;align-items:center;gap:8px}
.sidebar-header-row h1{margin:0;font-size:1.02rem;line-height:1.1;white-space:nowrap}
.sidebar-logo{width:44px;height:44px;max-width:none;object-fit:cover;margin:0;border-radius:10px}

.search-live{margin:14px 0;display:block}
.search-live input{width:100%;border:1px solid var(--line);background:#0f1722;color:var(--text);border-radius:8px;padding:11px 12px}

.portal-stats{display:grid;grid-template-columns:repeat(3,minmax(120px,1fr));gap:12px;margin-bottom:16px}
.stat-card{border:1px solid var(--line);background:var(--card);border-radius:8px;padding:12px;display:grid;gap:4px;box-shadow:var(--shadow)}
.stat-label{font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.stat-card strong{font-size:1.35rem;line-height:1}

@media (max-width:900px){
  .sidebar{width:min(88vw,300px)}
  .portal-stats{grid-template-columns:1fr}
  .sidebar-header-row h1{white-space:normal}
}

@media (max-width:700px){
  .content{padding:14px}
  .content-header{align-items:flex-start;gap:12px;flex-wrap:wrap}
  .content-header h2{font-size:1.35rem}
  .app-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
  .app-card{padding:12px;aspect-ratio:auto;min-height:170px}
  .app-card img{width:calc(100% - 12px);max-width:92px}
  .app-card h3{font-size:.92rem;min-height:auto}
  .detail-body{padding:14px}
  .detail-wrapper{min-height:auto}
  .detail-card{padding:18px}
  .detail-header{align-items:flex-start;gap:12px}
  .detail-header img{width:68px;height:68px;padding:8px}
  .download-actions{gap:12px}
  .download-btn{width:100%;min-width:0}
  .rating-form,.form-actions{flex-direction:column;align-items:stretch}
  .form-actions > *{width:100%}
  .form-actions .admin-btn,.form-actions button{text-align:center;justify-content:center}
  .category-item{align-items:flex-start;gap:8px;flex-direction:column}
  .admin-access-summary,.admin-access-columns{grid-template-columns:1fr}
  .modal-card{width:min(92vw,92vw);padding:16px}
  .lb-nav{width:44px;height:56px;font-size:1.7rem}
  .lb-nav.prev{left:8px}
  .lb-nav.next{right:8px}
  .lb-close{top:10px;right:10px;width:42px;height:42px;font-size:1.5rem}
}

@media (max-width:480px){
  .sidebar{width:min(92vw,320px);padding:16px 12px}
  .sidebar-header-row{align-items:center}
  .search-live input,.search-form input,.admin-form input,.admin-form textarea,.admin-form select,.rating-form select{padding:12px}
  .search-form button,.admin-form button,.rating-form button,.admin-btn{padding:12px 14px}
  .content{padding:12px}
  .content-header{margin-bottom:16px}
  .app-grid{grid-template-columns:1fr}
  .app-card{min-height:156px}
  .portal-stats{gap:10px}
  .stat-card{padding:10px}
  .detail-body{padding:10px}
  .detail-card{padding:14px;border-radius:8px}
  .detail-header{flex-direction:column}
  .detail-header img{width:72px;height:72px}
  .screenshot-grid{grid-template-columns:1fr}
  .rating-picker{gap:2px;justify-content:space-between}
  .admin-form .rating-star-btn{font-size:1.65rem;padding:4px 2px}
  .existing-shots{grid-template-columns:1fr 1fr}
  .back-link{margin-bottom:12px}
}






