/* DR020 - Soft Purple Light Theme
 * Namespace: hh-
 * Layout: max-width 960px centered
 */

/* === CSS Variables === */
:root{
    --bg:#e2d8f4;
    --bg2:#eee5fb;
    --bg3:#c9b3ee;
    --text:#351f66;
    --text2:#6d45aa;
    --accent:#9a74e8;
    --accent2:#875de1;
    --accent-light:#e7dbff;
    --info:#9a74e8;
    --white:#fff;
    --radius:10px;
    --shadow:0 2px 4px rgba(91,33,182,.06),0 0 0 1px rgba(91,33,182,.04);
}

/* === Reset & Base === */
*{box-sizing:border-box}
body{color:var(--text);background:var(--bg);font-size:14px;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','PingFang SC','Microsoft YaHei',system-ui,sans-serif;margin:0;-webkit-font-smoothing:antialiased}
ul,li,h1,h2,h3,p,form{margin:0;padding:0;list-style:none}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
button{cursor:pointer;font-family:inherit}

/* === Layout === */
.hh-wrap{max-width:960px;margin:0 auto;padding:0 12px}

/* === Header === */
.hh-header{background:var(--bg2);box-shadow:0 1px 3px rgba(124,58,237,.08),0 0 0 1px rgba(124,58,237,.04)}
.hh-header-inner{max-width:960px;margin:0 auto;padding:12px 12px;display:flex;justify-content:space-between;align-items:center}
.hh-logo{font-size:18px;font-weight:700;color:var(--accent)}
.hh-header-right{display:flex;align-items:center;gap:8px}
.hh-header-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;background:var(--accent);color:var(--white);border-radius:var(--radius);font-size:12px;font-weight:700;border:2px solid var(--accent);transition:all .2s}
.hh-header-btn:hover{background:var(--accent2)}
.hh-header-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;color:var(--text2);transition:color .2s}
.hh-header-icon:hover{color:var(--accent)}
.hh-header-icon svg{width:20px;height:20px;fill:currentColor}

/* === Search Box === */
.hh-search-box{padding:12px}
.hh-search{display:flex;max-width:600px;margin:0 auto}
.hh-search-select{padding:8px 12px;border:2px solid var(--bg3);border-right:none;border-radius:var(--radius) 0 0 var(--radius);background:var(--bg2);color:var(--text);font-size:13px;outline:none}
.hh-search-input{flex:1;padding:8px 12px;border:2px solid var(--bg3);border-left:1px solid var(--bg3);background:var(--bg2);font-size:14px;outline:none}
.hh-search-input:focus{border-color:var(--accent)}
.hh-search-btn{padding:8px 16px;background:var(--bg2);border:2px solid var(--bg3);border-left:1px solid var(--bg3);border-radius:0 var(--radius) var(--radius) 0;color:var(--text2);font-weight:700;font-size:13px;transition:all .2s}
.hh-search-btn:hover{background:var(--accent);color:var(--white);border-color:var(--accent)}

/* === Announcement === */
.hh-announce{background:var(--accent-light);padding:10px 12px;border-radius:var(--radius);margin-top:10px;border:1px solid rgba(124,58,237,.1)}
.hh-announce-item{display:flex;align-items:center;gap:8px;font-size:13px;padding:4px 0}

/* === Ad Slots === */
.ad-slot{padding:6px 0;text-align:center}
.ad-slot img{margin:0 auto;border-radius:var(--radius)}
.ad-banner{display:flex;flex-direction:column;gap:0;padding:0;line-height:0}
.ad-banner img{width:100%;height:65px;object-fit:fill;display:block;vertical-align:top}
@media(max-width:768px){.ad-banner img{height:auto}}

/* === Navigation === */
.hh-nav{display:flex;flex-wrap:wrap;gap:8px;padding:12px 0}
.hh-nav-item{display:inline-flex;align-items:center;gap:4px;padding:8px 14px;background:transparent;border:1.5px solid rgba(124,58,237,.4);color:var(--accent);border-radius:var(--radius);font-size:13px;font-weight:600;white-space:nowrap;transition:all .25s}
.hh-nav-item:hover,.hh-nav-item.active{background:var(--accent);color:var(--white);border-color:var(--accent);box-shadow:0 2px 8px rgba(124,58,237,.15)}
.hh-nav-item svg{width:14px;height:14px;fill:currentColor}
@media(max-width:768px){.hh-nav{gap:6px}.hh-nav-item{padding:6px 10px;font-size:12px}}

/* === Tags === */
.hh-tags{padding:12px;text-align:center}
.hh-tags .hh-tag{display:inline-block;padding:4px 10px;margin:2px;background:var(--accent);color:var(--white);border-radius:4px;font-size:12px;transition:background .2s}
.hh-tags .hh-tag:hover{background:var(--accent2)}
.hh-tags .hh-tag-label{background:var(--accent2)}

/* === Section Title === */
.hh-section{padding:12px}
.hh-section-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:12px;display:flex;justify-content:space-between;align-items:baseline;padding-bottom:10px;border-bottom:2px solid rgba(124,58,237,.1);letter-spacing:.3px}
.hh-section-title small{font-size:12px;color:var(--text2);font-weight:400}

/* === Video Grid === */
.hh-grid{display:grid;grid-template-columns:repeat(var(--cols,4),minmax(0,1fr));gap:12px}
.hh-card{background:var(--bg2);border-radius:var(--radius);overflow:hidden;border:1px solid rgba(124,58,237,.06);transition:transform .25s,box-shadow .25s,border-color .25s}
.hh-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px rgba(124,58,237,.1);border-color:rgba(124,58,237,.12)}
.hh-card-thumb{position:relative;padding-bottom:56.25%;overflow:hidden;background:var(--bg3)}
.hh-card-thumb img{position:absolute;width:100%;height:100%;object-fit:cover;transition:transform .3s}
.hh-thumb-video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;display:none;z-index:1}
.hh-card.previewing .hh-thumb-video{display:block}
.hh-card.previewing .hh-card-thumb img{opacity:0}
.hh-card:hover .hh-card-thumb img{transform:scale(1.05)}
.hh-card-badge{position:absolute;right:5px;bottom:5px;padding:2px 6px;background:rgba(0,0,0,.6);color:var(--white);font-size:10px;border-radius:5px}
.hh-card-info{padding:10px}
.hh-card-title{font-size:13px;font-weight:600;color:var(--text);line-height:1.4;display:-webkit-box;line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:5px}
.hh-card-meta{font-size:11px;color:var(--text2)}
.hh-card-thumb.portrait{padding-bottom:150%}

/* === Category Filter === */
.hh-filter{padding:0 12px 12px}
.hh-filter-scroll{display:flex;flex-wrap:wrap;gap:6px}
.hh-filter-btn{padding:6px 12px;background:transparent;border:1.5px solid rgba(124,58,237,.35);color:var(--accent);border-radius:var(--radius);font-size:12px;font-weight:700;white-space:nowrap;transition:all .25s}
.hh-filter-btn:hover,.hh-filter-btn.active{background:var(--accent);color:var(--white);border-color:var(--accent)}
.hh-filter-label{padding:6px 12px;background:var(--accent);color:var(--white);border-radius:var(--radius);font-size:12px;font-weight:700}

/* === Pagination === */
.hh-pager{padding:20px 12px;text-align:center}
.hh-pager-btn{display:inline-block;padding:8px 14px;margin:2px;background:var(--bg2);border:1.5px solid rgba(124,58,237,.3);color:var(--accent);border-radius:var(--radius);font-size:13px;font-weight:700;transition:all .25s}
.hh-pager-btn:hover{background:rgba(124,58,237,.06);border-color:var(--accent)}
.hh-pager-btn.active{background:var(--accent);color:var(--white);border-color:var(--accent);box-shadow:0 2px 8px rgba(124,58,237,.2)}
.hh-pager-info{margin-top:8px;font-size:12px;color:var(--text2)}

/* === Player === */
.hh-player-box{padding:0 12px}
.hh-player{position:relative;height:50vh;min-height:280px;background:#000;border-radius:var(--radius);overflow:hidden}
@media(min-width:768px){.hh-player{height:70vh;min-height:450px}}
.hh-player iframe,.hh-player video,.hh-player #dplayer{position:absolute;top:0;left:0;width:100%;height:100%}
.hh-video-info{padding:12px}
.hh-video-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:4px}
.hh-video-meta{font-size:13px;color:var(--text2)}
.hh-video-meta a{color:var(--accent)}
.hh-video-meta a:hover{text-decoration:underline}

/* === Tips/Warning Box === */
.hh-tips{margin:12px;padding:12px;background:var(--bg2);border-radius:var(--radius)}

/* === Footer === */
.hh-footer{padding:40px 12px;text-align:center;color:var(--text2);font-size:13px;margin-bottom:60px;border-top:1px solid rgba(124,58,237,.08)}
.hh-footer p{margin-bottom:8px}

/* === Actors === */
.hh-actor-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.hh-actor-card{text-align:center}
.hh-actor-card img{width:100%;aspect-ratio:3/4;object-fit:cover;border-radius:var(--radius)}
.hh-actor-card p{font-size:13px;color:var(--text);margin-top:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* === Forms === */
.hh-form{max-width:400px;margin:0 auto;padding:20px}
.hh-form-group{margin-bottom:16px}
.hh-form-label{display:block;font-size:13px;font-weight:700;color:var(--text);margin-bottom:6px}
.hh-form-input{width:100%;padding:10px 12px;border:2px solid var(--bg3);border-radius:var(--radius);font-size:14px;outline:none;transition:border-color .2s}
.hh-form-input:focus{border-color:var(--accent)}
.hh-form-btn{width:100%;padding:12px;background:var(--accent);color:var(--white);border:none;border-radius:var(--radius);font-size:14px;font-weight:700;transition:background .2s}
.hh-form-btn:hover{background:var(--accent2)}

/* === Favorites === */
.hh-fav-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--bg2);border:2px solid var(--bg3);border-radius:var(--radius);color:var(--text);font-size:13px;transition:all .2s}
.hh-fav-btn:hover{border-color:var(--accent);color:var(--accent)}
.hh-fav-btn.favorited{background:var(--accent);border-color:var(--accent);color:var(--white)}
.hh-fav-btn svg{width:16px;height:16px;fill:currentColor}

/* === Searchall Progress === */
.hh-progress{background:var(--bg3);height:6px;border-radius:3px;overflow:hidden;margin-bottom:12px}
.hh-progress-bar{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));width:0;transition:width .3s}
.hh-searchall-section{margin-bottom:24px}
.hh-searchall-section h3{font-size:15px;font-weight:700;color:var(--text);margin-bottom:10px;display:flex;align-items:center;gap:8px}
.hh-searchall-section h3 small{font-size:12px;color:var(--text2);font-weight:400}
.hh-searchall-section h3 .more-link{margin-left:auto;font-size:12px;color:var(--accent)}

/* === Back to Top === */
.hh-back-top{position:fixed;right:16px;bottom:80px;width:44px;height:44px;background:var(--accent);color:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(124,58,237,.3);opacity:0;visibility:hidden;transition:all .3s;z-index:999}
.hh-back-top.show{opacity:1;visibility:visible}
.hh-back-top:hover{transform:translateY(-4px)}
.hh-back-top svg{width:20px;height:20px;fill:currentColor}

/* === No Data === */
.hh-no-data{padding:60px 20px;text-align:center;color:var(--text2)}

/* === Responsive === */
@media(max-width:768px){
    .hh-grid{gap:8px}
    .hh-actor-grid{grid-template-columns:repeat(4,1fr)}
    .hh-header-inner{padding:8px 12px}
    .hh-search-box{padding:8px}
    .hh-search-select{padding:6px 8px;font-size:12px}
    .hh-search-input{padding:6px 10px;font-size:13px}
    .hh-search-btn{padding:6px 12px;font-size:12px}
    .hh-section-title{font-size:15px}
    .hh-card-title{font-size:12px}
    .hh-card-info{padding:6px}
    .hh-pager-btn{padding:6px 10px;font-size:12px}
}

@media(max-width:480px){
    .hh-actor-grid{grid-template-columns:repeat(3,1fr)}
    .hh-card-badge{font-size:9px;padding:2px 4px}
    .hh-back-top{right:12px;bottom:70px;width:40px;height:40px}
}

/* === DPlayer Override === */
.dplayer{border-radius:var(--radius)!important}

/* === Safe Area (iPhone notch) === */
@supports(padding:max(0px)){
    body{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);padding-bottom:env(safe-area-inset-bottom)}
    .hh-header{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}
    .hh-back-top{right:max(16px,env(safe-area-inset-right));bottom:max(80px,calc(env(safe-area-inset-bottom)+20px))}
}

/* === Skeleton Loading === */
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
.hh-skeleton{background:linear-gradient(90deg,var(--bg3) 25%,#ede9fe 50%,var(--bg3) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}

/* === Touch Optimization === */
@media(hover:none){
    .hh-card:hover{transform:none;box-shadow:none}
    .hh-card:active{transform:scale(.98)}
    .hh-nav-item:hover,.hh-pager-btn:hover,.hh-filter-btn:hover{background:inherit;color:inherit;border-color:inherit}
    .hh-nav-item:active,.hh-pager-btn:active,.hh-filter-btn:active{opacity:.7}
}

/* === Performance === */
.hh-card,.hh-back-top{will-change:transform}
img{content-visibility:auto}

/* === Print === */
@media print{.hh-header,.hh-back-top,.hh-search-box,.hh-nav,.hh-pager,.hh-footer{display:none}body{padding-top:0}}
/* === DR020 Enhancement === */
/* Light Lavender theme harmonization */
.hh-header{background:#f2ebff;box-shadow:0 2px 6px rgba(91,33,182,.06)}
.hh-header-btn{background:#9a74e8;border-color:#9a74e8;color:#fff}
.hh-header-btn:hover{background:#8b5cf6}
.hh-nav-item{color:#6b21a8;border-color:rgba(124,58,237,.3)}
.hh-nav-item:hover,.hh-nav-item.active{background:#9a74e8;color:#fff;border-color:#9a74e8;box-shadow:0 2px 10px rgba(124,58,237,.2)}
.hh-tags .hh-tag{background:#9a74e8;color:#fff}
.hh-tags .hh-tag:hover{background:#8b5cf6}
.hh-tags .hh-tag-label{background:#8b5cf6;color:#fff}
.hh-filter-btn{color:#6b21a8;border-color:rgba(124,58,237,.3)}
.hh-filter-btn:hover,.hh-filter-btn.active{background:#9a74e8;color:#fff;border-color:#9a74e8}
.hh-filter-label{background:#8b5cf6;color:#fff}
.hh-card{border-color:rgba(124,58,237,.06)}
.hh-card:hover{box-shadow:0 8px 24px rgba(91,33,182,.08);border-color:rgba(124,58,237,.15)}
.hh-section-title{color:#2e1065;border-bottom-color:rgba(124,58,237,.15)}
.hh-pager-btn{color:#6b21a8;border-color:rgba(124,58,237,.25);background:#f2ebff}
.hh-pager-btn:hover{background:rgba(124,58,237,.08);border-color:#9a74e8}
.hh-pager-btn.active{background:#9a74e8;color:#fff;border-color:#9a74e8;box-shadow:0 2px 10px rgba(124,58,237,.25)}
.hh-announce{background:#f0eaff;border-color:rgba(124,58,237,.15)}
.hh-search-select{border-color:#9a74e8}
.hh-search-input{border-color:#9a74e8}
.hh-search-input:focus{border-color:#9a74e8}
.hh-search-btn{border-color:#9a74e8}
.hh-search-btn:hover{background:#9a74e8;border-color:#9a74e8;color:#fff}
.hh-back-top{background:#9a74e8;box-shadow:0 4px 12px rgba(124,58,237,.3)}
.hh-footer{color:#5c3a95;border-top-color:rgba(124,58,237,.14);background:#e8ddfb}
.hh-fav-btn{border-color:rgba(124,58,237,.2)}
.hh-fav-btn:hover{border-color:#9a74e8;color:#9a74e8}
.hh-fav-btn.favorited{background:#9a74e8;border-color:#9a74e8;color:#fff}
.hh-logo{color:#9a74e8}
.hh-form-btn{background:#9a74e8}
.hh-form-btn:hover{background:#8b5cf6}
.hh-form-input:focus{border-color:#9a74e8}
.hh-progress-bar{background:linear-gradient(90deg,#9a74e8,#a78bfa)}
