/* ACG CMS — Frontend Styles v1.3.3 */
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100vh}
a{color:var(--link-color,#6ea8fe);text-decoration:none}
a:hover{color:var(--link-hover,#93c5fd);text-decoration:underline}

/* ─── Header ─── */
.site-header{background:var(--bg-1);border-bottom:1px solid var(--border);padding:0 20px;height:56px;display:flex;align-items:center;gap:16px;position:sticky;top:0;z-index:100}
.site-header.boxed{max-width:1400px;margin:0 auto;border-left:1px solid var(--border);border-right:1px solid var(--border)}
.site-logo{font-size:1.2rem;font-weight:700;color:var(--primary);letter-spacing:1px;flex-shrink:0}
.site-logo:hover{text-decoration:none;color:var(--primary)}
.header-right{display:flex;align-items:center;gap:14px;flex:1;justify-content:flex-end}
.header-right.menu-left{flex-direction:row-reverse}
.site-nav{display:flex;align-items:center;gap:14px;flex-shrink:0}
.site-nav a{color:var(--text-1);font-size:.85rem;white-space:nowrap}
.site-nav a:hover{color:var(--text);text-decoration:none}
.hamburger{display:none;background:none;border:none;color:var(--text);font-size:1.4rem;cursor:pointer;padding:4px 8px;line-height:1}

/* Search */
.search-wrap{position:relative;flex-shrink:0}
.search-wrap.s-small{width:180px}.search-wrap.s-medium{width:260px}.search-wrap.s-large{width:380px}
.search-wrap.s-full{flex:1;min-width:180px;max-width:500px}
.search-input{width:100%;border-radius:20px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:.85rem;outline:none;transition:border-color .2s}
.search-input:focus{border-color:var(--primary)}
/* Padding controlled by CSS var from settings */
.search-input{padding:var(--search-pad,7px) 12px var(--search-pad,7px) 32px}
.search-wrap.icon-right .search-input{padding:var(--search-pad,7px) 32px var(--search-pad,7px) 12px}
.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-2);font-size:.85rem;pointer-events:none}
.search-wrap.icon-right .search-icon{left:auto;right:10px}
.search-suggestions{position:absolute;top:100%;left:0;right:0;background:var(--bg-1);border:1px solid var(--border);border-radius:0 0 10px 10px;display:none;z-index:200;max-height:300px;overflow-y:auto}
.search-suggestions.active{display:block}
.search-suggestion{padding:8px 14px;font-size:.84rem;color:var(--text-1);cursor:pointer;display:flex;align-items:center;gap:8px}
.search-suggestion:hover{background:var(--bg-2);color:var(--text)}
.search-suggestion .type{font-size:.65rem;padding:1px 5px;border-radius:3px;background:var(--bg-3);color:var(--text-2);text-transform:uppercase}

@media(max-width:768px){
  .hamburger{display:block}
  .site-nav{display:none;position:absolute;top:56px;left:0;right:0;background:var(--bg-1);border-bottom:1px solid var(--border);flex-direction:column;padding:8px 20px;gap:0;z-index:99}
  .site-nav.open{display:flex}
  .site-nav a{padding:10px 0;border-bottom:1px solid var(--border);width:100%;font-size:.9rem}
  .site-nav a:last-child{border-bottom:none}
  .search-wrap.s-small,.search-wrap.s-medium,.search-wrap.s-large{width:140px}
  .search-wrap.s-full{min-width:100px}
}

.container{max-width:1400px;margin:0 auto;padding:20px}

/* ─── Video Cards ─── */
.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(220px, calc(50% - 8px)),1fr));gap:14px}
.video-card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform .15s,border-color .15s,box-shadow .15s;cursor:pointer}
.video-card a{color:inherit;text-decoration:none}.video-card a:hover{text-decoration:none}
.video-card.hover-lift:hover{transform:translateY(-2px);border-color:var(--primary)}
.video-card.hover-glow:hover{box-shadow:0 0 12px var(--primary);border-color:var(--primary)}
.video-card.hover-zoom:hover .video-thumb img{transform:scale(1.05)}
.video-thumb{position:relative;width:100%;padding-top:56.25%;background:var(--bg-2);overflow:hidden}
.video-thumb.ratio-4-3{padding-top:75%}
.video-thumb img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform .3s}
.video-duration{position:absolute;bottom:6px;right:6px;background:rgba(0,0,0,.8);color:#fff;font-size:.7rem;padding:2px 6px;border-radius:3px;font-weight:600}
.video-info{padding:8px 10px}
.video-title{font-size:.82rem;font-weight:500;line-height:1.3;margin-bottom:4px;overflow:hidden;color:var(--text)}
.video-title.lines-1{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical}
.video-title.lines-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.video-meta{display:flex;align-items:center;justify-content:space-between;font-size:.68rem;color:var(--text-2);gap:4px;flex-wrap:nowrap;overflow:hidden}
.video-meta-left{display:flex;align-items:center;gap:6px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.video-meta .tube{color:var(--text-1)}.video-meta .rating{color:#ffc107}
.video-meta .when-added{color:var(--text-2);white-space:nowrap;flex-shrink:0}
@media(max-width:480px){.video-grid{gap:8px}.video-info{padding:6px 8px}.video-title{font-size:.76rem;margin-bottom:2px}.video-meta{font-size:.62rem}}

/* ─── 18+ Badge (colors via CSS vars) ─── */
.badge-18{display:inline-block;font-size:.58rem;font-weight:700;padding:1px 4px;border-radius:3px;background:var(--badge-bg,#ff5252);color:var(--badge-text,#fff);margin-left:4px;vertical-align:middle;letter-spacing:.3px;line-height:1.3}

/* ─── Category Grid ─── */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(180px, calc(50% - 8px)),1fr));gap:14px}
.cat-card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform .15s;position:relative}
.cat-card:hover{transform:translateY(-2px)}
.cat-card a{color:inherit;text-decoration:none;display:block}.cat-card a:hover{text-decoration:none}
.cat-thumb{position:relative;width:100%;padding-top:66%;background:var(--bg-2);overflow:hidden}
.cat-thumb img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}
.cat-overlay{position:absolute;bottom:0;left:0;right:0;padding:10px;background:linear-gradient(transparent,rgba(0,0,0,.85));text-align:center}
.cat-name{font-size:.88rem;font-weight:600;color:#fff}.cat-count{font-size:.7rem;color:rgba(255,255,255,.7);margin-top:2px}

/* ─── Category Page Header + Sort ─── */
.cat-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px;flex-wrap:nowrap}
.cat-header-left{display:flex;align-items:baseline;gap:12px;min-width:0;overflow:hidden}
.cat-header-left .section-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sort-wrap{display:flex;align-items:center;gap:6px;flex-shrink:0}
.sort-label{font-size:.8rem;color:var(--text-2);white-space:nowrap}
.sort-dropdown{font-size:.8rem;padding:5px 10px;border-radius:6px;border:1px solid var(--border);background:var(--bg-1);color:var(--text);outline:none;cursor:pointer}

/* ─── Pagination ─── */
.pagination{display:flex;justify-content:center;gap:6px;margin-top:24px;flex-wrap:wrap}
.pagination a,.pagination span{padding:6px 12px;border-radius:6px;font-size:.8rem;border:1px solid var(--border);color:var(--text-1);background:var(--bg-1)}
.pagination a:hover{background:var(--bg-2);color:var(--text);text-decoration:none}
.pagination .active{background:var(--primary);color:#fff;border-color:var(--primary)}

.section-title{font-size:1.1rem;font-weight:700;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid var(--primary);display:inline-block}

/* All cats list */
.all-cats-list{column-count:4;column-gap:20px;margin-top:16px}
.all-cats-list a{display:block;padding:4px 0;font-size:.82rem;color:var(--text-1);break-inside:avoid}
.all-cats-list a:hover{color:var(--link-hover,#93c5fd)}
.all-cats-list .count{color:var(--text-2);font-size:.72rem;margin-left:4px}
@media(max-width:768px){.all-cats-list{column-count:2}.container{padding:12px}}
@media(max-width:480px){.all-cats-list{column-count:1}}

/* ─── Video Page ─── */
.video-player-wrap{position:relative;padding-top:56.25%;background:#000;border-radius:var(--radius);overflow:hidden;margin-bottom:16px}
.video-player-wrap iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0;overflow:hidden}
.video-page-title{font-size:1.2rem;font-weight:600;margin-bottom:12px;line-height:1.4}
.video-page-meta{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:16px;font-size:.84rem;color:var(--text-1);align-items:center}
.video-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:24px}
.video-tag{display:inline-block;padding:4px 10px;border-radius:16px;background:var(--bg-2);color:var(--text-1);font-size:.76rem;border:1px solid var(--border);transition:all .15s}
.video-tag:hover{border-color:var(--link-color,#6ea8fe);color:var(--link-color,#6ea8fe);background:var(--bg-3);text-decoration:none}

/* Thumbs up/down */
.vote-btns{display:inline-flex;gap:8px;margin-left:4px}
.vote-btn{background:none;border:1px solid var(--border);border-radius:6px;padding:3px 8px;cursor:pointer;font-size:.82rem;color:var(--text-2);transition:all .15s;display:inline-flex;align-items:center;gap:3px}
.vote-btn:hover{border-color:var(--primary);color:var(--text)}
.vote-btn.up:hover{color:var(--green,#00e676);border-color:var(--green,#00e676)}
.vote-btn.down:hover{color:var(--red,#ff5252);border-color:var(--red,#ff5252)}
.vote-thanks{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:rgba(0,0,0,.85);color:#fff;padding:12px 24px;border-radius:8px;font-size:.9rem;font-weight:600;z-index:999;opacity:0;transition:opacity .3s;pointer-events:none}
.vote-thanks.show{opacity:1}

/* ─── Static Pages ─── */
.page-content{max-width:800px;margin:0 auto;line-height:1.7;color:var(--text-1)}
.page-content h2{color:var(--text);margin:24px 0 12px;font-size:1.3rem}
.page-content h3{color:var(--text);margin:20px 0 8px;font-size:1.05rem}
.page-content p{margin-bottom:12px}
.page-content ol,.page-content ul{margin:0 0 12px 24px}
.page-content li{margin-bottom:6px}
.page-content a{color:var(--link-color,#6ea8fe)}.page-content a:hover{color:var(--link-hover,#93c5fd)}
.page-content strong{color:var(--text)}

/* ─── Footer (equal padding fix) ─── */
.site-footer{background:var(--bg-1);border-top:1px solid var(--border);padding:28px 20px;margin-top:40px;text-align:center}
.footer-links{display:flex;justify-content:center;flex-wrap:wrap;margin-bottom:14px;gap:0}
.footer-links a{color:var(--text-2);font-size:.78rem;padding:2px 12px}
.footer-links a:hover{color:var(--link-hover,#93c5fd)}
/* Equal separators between links */
.footer-sep{color:var(--border);font-size:.7rem;line-height:1;display:flex;align-items:center}
.footer-copy{color:var(--text-2);font-size:.72rem;margin-top:4px}

/* ─── New Video Badge ─── */
.badge-new{position:absolute;top:6px;left:6px;background:#00e676;color:#000;font-size:.6rem;font-weight:700;padding:2px 6px;border-radius:3px;letter-spacing:.5px;text-transform:uppercase;z-index:2}

/* ─── Thumbnail Fallback ─── */
.video-thumb img{background:var(--bg-2)}
.video-thumb img[src=""],.video-thumb img:not([src]),.video-thumb img.error{opacity:0}
.video-thumb{background:var(--bg-2) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='48' height='48' viewBox='0 0 24 24' fill='none' stroke='%23363752' stroke-width='1.5'%3E%3Cpolygon points='5 3 19 12 5 21 5 3'/%3E%3C/svg%3E") center/48px no-repeat}

/* ─── Narrow Your Search (Search Term Cloud) ─── */
.narrow-search{margin-top:32px;padding-top:24px;border-top:1px solid var(--border)}
.narrow-title{font-size:.92rem;font-weight:600;color:var(--text-1);margin-bottom:14px}
.narrow-cloud{display:flex;flex-wrap:wrap;gap:8px}
.narrow-pill{display:inline-block;padding:6px 14px;border-radius:20px;background:var(--bg-1);border:1px solid var(--border);color:var(--text-1);font-size:.78rem;transition:all .15s;white-space:nowrap}
.narrow-pill:hover{border-color:var(--link-color,#6ea8fe);color:var(--link-color,#6ea8fe);background:var(--bg-2);text-decoration:none}
