/* Viewer-specific styles — loaded only on NFT viewer pages */

/* Policy/stats info */
.page-viewer .viewer-policy{font-size:0.85rem;color:rgba(0,0,0,0.55);word-break:break-all;margin-bottom:8px}
.page-viewer .viewer-policy a{color:#222}
.page-viewer .viewer-stats{font-size:0.9rem;color:rgba(0,0,0,0.55);margin-bottom:0}
.page-viewer .viewer-cached{font-size:0.75rem;color:rgba(0,0,0,0.35);margin-top:4px}

/* Section headings */
.page-viewer h2{margin-bottom:0.75em}

/* Grid */
.page-viewer .nft-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;margin-bottom:1.5em}
.page-viewer .nft-card{
  background:rgba(255,255,255,0.85);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(0,0,0,0.1);
  border-radius:12px;overflow:hidden;cursor:pointer;
  transition:border-color .2s,box-shadow .2s;
}
.page-viewer .nft-card:hover{border-color:#bbb;box-shadow:0 2px 12px rgba(0,0,0,0.08)}
.page-viewer .nft-card.selected{border-color:#222;box-shadow:0 2px 12px rgba(0,0,0,0.12)}
.page-viewer .card-preview{display:flex;gap:12px;padding:12px;position:relative}
.page-viewer .card-preview img{width:80px;height:80px;object-fit:cover;border-radius:8px;flex-shrink:0}
.page-viewer .card-info{min-width:0}
.page-viewer .card-info h3{font-size:0.9rem;color:#222;margin-bottom:3px;margin-top:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.page-viewer .card-info p{font-size:0.78rem;color:rgba(0,0,0,0.55)}
.page-viewer .token-name{font-family:monospace;color:#222!important;font-size:0.72rem!important}
.page-viewer .badge{display:inline-block;background:#222;color:#fff;font-size:0.68rem;padding:2px 8px;border-radius:10px;margin-top:3px}

/* Modal overlay */
.page-viewer .modal-backdrop{display:none;position:fixed;inset:0;z-index:200;background:rgba(255,255,255,0.4);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);align-items:flex-start;justify-content:center;overflow-y:auto;padding:40px 20px}
.page-viewer .modal-backdrop.open{display:flex}
.page-viewer .modal{
  background:rgba(255,255,255,0.98);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-radius:3px;
  box-shadow:0 8px 30px rgba(0,0,0,0.12);
  max-width:570px;width:100%;padding:24px;position:relative;
  margin:auto;
}
.page-viewer .detail-close{
  position:absolute;top:8px;right:6px;
  background:#fff;border:none;color:rgba(0,0,0,0.4);
  padding:0 6px;cursor:pointer;font-size:1.6rem;line-height:1;font-weight:300;
}
.page-viewer .detail-close:hover{color:#222}
.page-viewer .detail-hero{text-align:center;margin-bottom:20px}
.page-viewer .detail-hero img{max-width:100%;max-height:520px;border-radius:3px;object-fit:contain;cursor:zoom-in}
.page-viewer .detail-title{font-size:1.3rem;color:#222;margin:12px 0 4px;font-weight:600}
.page-viewer .detail-subtitle{font-size:0.85rem;color:rgba(0,0,0,0.55);font-family:monospace;margin-bottom:16px}
.page-viewer .detail-badge{display:inline-block;background:#222;color:#fff;font-size:0.75rem;padding:3px 10px;border-radius:10px;margin-bottom:16px}
.page-viewer .detail-section{margin-bottom:16px}
.page-viewer .detail-section h4{font-size:0.85rem;color:rgba(0,0,0,0.55);margin-bottom:8px;font-weight:600;padding-top:0;margin-top:0.6rem}
.page-viewer .detail-table{width:100%;font-size:0.82rem;border-collapse:collapse}
.page-viewer .detail-table td{padding:5px 8px;border-bottom:1px solid rgba(0,0,0,0.1)}
.page-viewer .detail-table td:first-child{color:rgba(0,0,0,0.55);white-space:nowrap;width:140px;font-weight:600}
.page-viewer .photo-history{margin:16px 0}
.page-viewer .photo-entry{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.page-viewer .photo-entry img{width:80px;min-width:80px;height:80px;object-fit:cover;border-radius:6px;flex-shrink:0}
.page-viewer .photo-entry span{font-size:0.75rem;color:rgba(0,0,0,0.55)}
.page-viewer .detail-actions{display:flex;gap:10px;margin:16px 0 8px;flex-wrap:wrap}
.page-viewer .detail-actions a,.page-viewer .detail-actions button{
  font-size:0.8rem;padding:7px 16px;border-radius:3px;text-decoration:none;cursor:pointer;
  border:1px solid rgba(0,0,0,0.15);background:transparent;color:#222;font-weight:600;
  transition:border-color .15s;
}
.page-viewer .detail-actions a:hover,.page-viewer .detail-actions button:hover{border-color:rgba(0,0,0,0.35)}
.page-viewer .json-block{background:rgba(135,131,120,0.15);border:none;border-radius:3px;padding:12px;margin-top:8px;overflow-x:auto;font-size:0.72rem;max-height:350px;overflow-y:auto}
.page-viewer .json-block code{color:#222;white-space:pre}

/* Modal navigation arrows */
.page-viewer .modal-arrow{position:fixed;top:50%;transform:translateY(-50%);background:rgba(255,255,255,0.8);border:1px solid rgba(0,0,0,0.15);color:#222;width:52px;height:52px;border-radius:50%;cursor:pointer;display:none;align-items:center;justify-content:center;transition:background .15s,border-color .15s;z-index:201;padding:0}
.page-viewer .modal-arrow:hover{background:rgba(255,255,255,1);border-color:rgba(0,0,0,0.35)}
.page-viewer .modal-prev{left:20px}
.page-viewer .modal-next{right:20px}

/* Lightbox — fullscreen image zoom, blur-only background */
.page-viewer .lightbox{display:none;position:fixed;inset:0;z-index:1000;background:rgba(255,255,255,0.05);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);align-items:center;justify-content:center;cursor:zoom-out}
.page-viewer .lightbox.open{display:flex}
.page-viewer .lightbox img{max-width:calc(100vw - 48px);max-height:calc(100vh - 48px);object-fit:contain;border-radius:3px;cursor:zoom-out}

/* Error states */
.page-viewer .viewer-error{background:rgba(239,68,68,0.1);border:1px solid rgba(239,68,68,0.3);border-radius:8px;padding:16px 20px;margin:16px 0;color:#991b1b;font-size:0.9rem}
.page-viewer .viewer-error strong{display:block;margin-bottom:4px}

/* Wallet connection header */
.page-viewer-dapp .header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}
.page-viewer-dapp .header-left{flex:1;min-width:0}
.page-viewer-dapp .wallet-area{flex-shrink:0;display:flex;align-items:center;gap:10px;margin-top:0.5rem}
.page-viewer-dapp .connect-btn{background:#222;color:#fff;border:none;border-radius:3px;padding:8px 18px;font-size:0.85rem;cursor:pointer;font-weight:600;transition:opacity .15s}
.page-viewer-dapp .connect-btn:hover{opacity:0.8}
.page-viewer-dapp .connect-btn:disabled{opacity:0.4;cursor:not-allowed}
.page-viewer-dapp .wallet-select{background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23222'/%3E%3C/svg%3E") no-repeat right 10px center;color:#222;border:1px solid rgba(0,0,0,0.15);border-radius:3px;padding:8px 28px 8px 10px;font-size:0.82rem;cursor:pointer;text-transform:capitalize;-webkit-appearance:none;-moz-appearance:none;appearance:none}
.page-viewer-dapp .wallet-info{display:flex;align-items:center;gap:10px;font-size:0.82rem;color:#222}
.page-viewer-dapp .disconnect-btn{background:#fff;border:1px solid rgba(0,0,0,0.15);color:#222;border-radius:3px;padding:8px 18px;cursor:pointer;font-size:0.85rem;font-weight:600}
.page-viewer-dapp .disconnect-btn:hover{background:#f5f5f5;border-color:rgba(0,0,0,0.35)}

/* Network badge */
.page-viewer-dapp .network-badge{display:inline-block;font-size:0.85rem;padding:6px 17px;border-radius:19px;font-weight:400;margin-left:4px;vertical-align:middle}
.page-viewer-dapp .network-badge.preprod{background:#1f6feb;color:#fff}
.page-viewer-dapp .network-badge.mainnet{background:#16a359;color:#fff}
.page-viewer-dapp .network-warn{background:#f59e0b;color:#222;font-size:0.78rem;padding:6px 16px;border-radius:3px;margin-top:8px;display:none;font-weight:600}

/* Owned NFT highlighting */
.page-viewer-dapp .nft-card.owned{border-color:#16a359;box-shadow:0 0 8px rgba(22,163,74,0.3)}
.page-viewer-dapp .nft-card.owned .card-preview::after{content:"Your NFT";position:absolute;top:6px;right:6px;background:#16a359;color:#fff;font-size:0.62rem;padding:2px 7px;border-radius:8px;font-weight:600}
.page-viewer-dapp .detail-hero{display:flex;flex-direction:column;align-items:center}
.page-viewer-dapp .detail-hero .owned-banner-wrap{display:inline-flex;flex-direction:column;align-items:stretch}
.page-viewer-dapp .owned-banner{background:#16a359;color:#fff;font-size:0.8rem;padding:6px 12px;border-radius:3px;margin-top:8px;text-align:center;font-weight:600}

/* Responsive */
@media(max-width:860px){
  .page-viewer .modal-prev{left:8px}
  .page-viewer .modal-next{right:8px}
}
@media(max-width:600px){
  .page-viewer .nft-grid{grid-template-columns:1fr}
  .page-viewer .modal{padding:16px}
  .page-viewer .modal-arrow{width:36px;height:36px;font-size:1.5rem}
  .page-viewer-dapp .header-row{flex-direction:column}
}
