/* ─── Variables ──────────────────────────────────────────────────────────── */
:root {
  --bg:          #0a0a0a;
  --bg2:         #141414;
  --bg3:         #1e1e1e;
  --bg4:         #282828;
  --border:      #2c2c2c;
  --text:        #f2f2f2;
  --text-muted:  #a0a0a0;
  --text-dim:    #606060;
  --accent:      #e63946;
  --accent-h:    #c1121f;
  --accent2:     #3a8fd1;
  --accent2-h:   #2a6fa8;
  --radius:      10px;
  --radius-sm:   6px;
  --shadow:      0 6px 28px rgba(0,0,0,0.6);
  --shadow-sm:   0 2px 12px rgba(0,0,0,0.4);
  --header-h:    72px;
  --font:        -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --tr:          .18s ease;
}
body.light-mode {
  --bg:         #f0f2f5;
  --bg2:        #ffffff;
  --bg3:        #e8eaed;
  --bg4:        #d8dadd;
  --border:     #cacdd2;
  --text:       #0d0d0d;
  --text-muted: #4a4a4a;
  --text-dim:   #888;
  --shadow:     0 6px 28px rgba(0,0,0,0.13);
  --shadow-sm:  0 2px 10px rgba(0,0,0,0.09);
}

/* ─── Reset ──────────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:17px}
body{background:var(--bg);color:var(--text);font-family:var(--font);line-height:1.65;min-height:100vh;display:flex;flex-direction:column;transition:background var(--tr),color var(--tr)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{cursor:pointer;font-family:var(--font)}
svg{display:inline-block;vertical-align:middle;fill:currentColor;flex-shrink:0}
/* ─── Global link & underline reset ─────────────────────── */
/* Hard reset: no underlines anywhere by default */
a { text-decoration: none !important; }
/* Only allow underlines where explicitly set */
.page-content a,
.faq-answer a,
.banner-text a,
.banner-headline a,
.comment-text a,
.quote-source a { text-decoration: underline !important; }
/* <u> tag only works inside content areas */
u { text-decoration: none; }
.page-content u,
.faq-answer u,
.banner-text u,
.comment-text u,
.quote-source u { text-decoration: underline; }



/* ─── Banner ─────────────────────────────────────────────────────────────── */
.site-banner{width:100%;padding:14px 0;border-bottom:1px solid transparent;transition:all .3s}
.banner-inner{max-width:1600px;margin:0 auto;padding:0 32px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.banner-body{flex:1}
.banner-headline{font-size:1rem;font-weight:800;margin-bottom:3px;letter-spacing:-.01em}
.banner-text{font-size:0.95rem;line-height:1.5}
.banner-link{font-weight:700;text-decoration:underline;margin-left:8px}
.banner-close{background:none;border:none;cursor:pointer;padding:2px;opacity:.7;transition:opacity .15s;color:inherit;margin-top:2px}
.banner-close:hover{opacity:1}
.banner-info   {background:#1a3a5c;border-color:#2a5a8c;color:#90caf9}
.banner-warning{background:#3a2e00;border-color:#6b5300;color:#ffd54f}
.banner-success{background:#0d3320;border-color:#1a5c38;color:#69f0ae}
.banner-error  {background:#3a0d0d;border-color:#6b1a1a;color:#ef9a9a}
body.light-mode .banner-info   {background:#dbeeff;border-color:#90caf9;color:#1a3a5c}
body.light-mode .banner-warning{background:#fff8db;border-color:#f0c040;color:#5a4000}
body.light-mode .banner-success{background:#dbf5e9;border-color:#69f0ae;color:#0d3320}
body.light-mode .banner-error  {background:#ffeaea;border-color:#ef9a9a;color:#5a0d0d}

/* ─── Header ─────────────────────────────────────────────────────────────── */
.site-header{position:sticky;top:0;z-index:100;background:var(--bg2);border-bottom:1px solid var(--border);height:var(--header-h);transition:background var(--tr)}
.header-inner{max-width:1600px;margin:0 auto;padding:0 32px;height:100%;display:flex;align-items:center;gap:24px}
.site-logo img{height:52px;width:auto}
.logo-text{font-size:1.45rem;font-weight:900;color:var(--accent);letter-spacing:-.03em}

/* Search bar in header */

.main-nav{display:flex;gap:2px;align-items:center;margin-left:auto}
.main-nav a{padding:9px 16px;border-radius:var(--radius-sm);color:var(--text-muted);font-size:1rem;font-weight:500;transition:all var(--tr);white-space:nowrap}
.main-nav a:hover{background:var(--bg3);color:var(--text)}
.nav-admin{color:var(--accent)!important}
.nav-admin:hover{background:rgba(230,57,70,.1)!important}

.theme-toggle{background:var(--bg3);border:1px solid var(--border);width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-left:8px;transition:all var(--tr);flex-shrink:0;color:var(--text-muted)}
.theme-toggle:hover{border-color:var(--accent2);color:var(--accent2)}
.nav-toggle{display:none;background:none;border:1px solid var(--border);color:var(--text);padding:8px 13px;border-radius:var(--radius-sm);margin-left:auto}

/* ─── Main ───────────────────────────────────────────────────────────────── */
.site-main{flex:1;max-width:1600px;width:100%;margin:0 auto;padding:40px 32px}

/* ─── Footer ─────────────────────────────────────────────────────────────── */
.site-footer{background:var(--bg2);border-top:2px solid var(--border);margin-top:72px}
.footer-inner{max-width:1600px;margin:0 auto;padding:32px;display:flex;flex-wrap:wrap;align-items:center;gap:24px;justify-content:space-between}
.footer-brand{font-weight:800;font-size:1.05rem;color:var(--accent)}
.footer-nav{display:flex;gap:24px;flex-wrap:wrap}
.footer-nav a{color:var(--text-muted);font-size:0.95rem;font-weight:500;transition:color var(--tr)}
.footer-nav a:hover{color:var(--accent)}
.footer-copy{color:var(--text-dim);font-size:0.88rem}

/* ─── Section headers ────────────────────────────────────────────────────── */
.hero-carousel-section,.top-videos-section,.creators-overview-section{margin-bottom:60px}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;padding-bottom:12px;border-bottom:2px solid var(--border)}
.section-header h2{font-size:1.4rem;font-weight:800;letter-spacing:-.02em;display:flex;align-items:center;gap:10px}
.section-header h2 svg{color:var(--accent);width:22px;height:22px}
.section-link{color:var(--accent2);font-size:0.95rem;font-weight:600;display:flex;align-items:center;gap:5px;transition:opacity var(--tr)}
.section-link:hover{opacity:.8}

/* ─── Carousel ───────────────────────────────────────────────────────────── */
.carousel-wrapper{position:relative;padding:0 6px}
.carousel{display:flex;gap:20px;overflow-x:auto;scroll-behavior:smooth;padding-bottom:10px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.carousel::-webkit-scrollbar{height:5px}
.carousel::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
.carousel .video-card{min-width:280px;max-width:280px}
.carousel-btn{position:absolute;top:38%;transform:translateY(-50%);background:var(--bg2);border:1px solid var(--border);color:var(--text);width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:2;transition:all var(--tr);box-shadow:var(--shadow-sm)}
.carousel-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.carousel-btn.prev{left:-24px}
.carousel-btn.next{right:-24px}

/* ─── Video Grid ─────────────────────────────────────────────────────────── */
.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}

/* ─── Video Card ─────────────────────────────────────────────────────────── */
.video-card{background:var(--bg2);border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);transition:transform var(--tr),box-shadow var(--tr),border-color var(--tr)}
.video-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--accent2)}
.video-card-thumb{display:block;position:relative;aspect-ratio:16/9;background:var(--bg3);overflow:hidden}
.video-card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .28s}
.video-card:hover .video-card-thumb img{transform:scale(1.05)}
.video-play-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0);color:rgba(255,255,255,0);transition:all .22s;pointer-events:none}
.video-play-overlay svg{width:52px;height:52px;filter:drop-shadow(0 2px 8px rgba(0,0,0,.5))}
.video-card:hover .video-play-overlay{background:rgba(0,0,0,.4);color:rgba(255,255,255,.95)}
.video-duration{position:absolute;bottom:9px;right:9px;background:rgba(0,0,0,.85);color:#fff;font-size:0.8rem;padding:3px 8px;border-radius:4px;font-weight:700;letter-spacing:.02em}
.video-card-info{padding:14px 16px 16px}
.video-card-title{display:block;font-weight:700;font-size:1rem;line-height:1.35;margin-bottom:7px;color:var(--text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.video-card-title:hover{color:var(--accent)}
.video-card-creator{display:block;font-size:0.93rem;color:var(--text-muted);margin-bottom:4px;font-weight:600;transition:color var(--tr)}
.video-card-creator:hover{color:var(--accent2)}
.video-card-meta{font-size:0.87rem;color:var(--text-muted)}

/* Accent stripe on cards */
.video-card::after{content:'';display:block;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent2));transform:scaleX(0);transform-origin:left;transition:transform .25s;margin-top:-2px}
.video-card:hover::after{transform:scaleX(1)}

/* ─── Creator chips ──────────────────────────────────────────────────────── */
.creator-chips{display:flex;flex-wrap:wrap;gap:12px}
.creator-chip{display:flex;align-items:center;gap:11px;background:var(--bg2);border:1px solid var(--border);padding:11px 20px;border-radius:999px;transition:all var(--tr)}
.creator-chip:hover{border-color:var(--accent2);background:var(--bg3);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.creator-chip img{width:34px;height:34px;border-radius:50%;object-fit:cover}
.creator-chip-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-weight:800;font-size:0.95rem;color:#fff}
.creator-chip-name{font-weight:700;font-size:1rem}
.creator-chip-count{font-size:0.8rem;color:var(--text-muted);background:var(--bg3);padding:3px 9px;border-radius:999px;font-weight:600}

/* ─── Creators grid ──────────────────────────────────────────────────────── */
.creators-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:24px}
.creator-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:28px 22px;text-align:center;transition:all var(--tr)}
.creator-card:hover{border-color:var(--accent2);transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.creator-card-avatar{width:84px;height:84px;border-radius:50%;margin:0 auto 16px;overflow:hidden;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center}
.creator-card-avatar img{width:100%;height:100%;object-fit:cover}
.creator-card-initial{font-size:2.2rem;font-weight:800;color:#fff}
.creator-card-name{font-weight:800;font-size:1.1rem;margin-bottom:5px}
.creator-card-count{font-size:0.88rem;color:var(--text-muted)}
.creator-card-desc{font-size:0.85rem;color:var(--text-muted);margin-top:9px}

/* ─── Creator page ───────────────────────────────────────────────────────── */
.creator-header-banner{background:linear-gradient(135deg,var(--bg2) 0%,var(--bg3) 100%);border-bottom:1px solid var(--border);padding:44px 0;margin-bottom:40px}
.creator-header-inner{max-width:1600px;margin:0 auto;padding:0 32px;display:flex;align-items:center;gap:28px}
.creator-avatar-large{width:100px;height:100px;border-radius:50%;overflow:hidden;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--shadow-sm)}
.creator-avatar-large img{width:100%;height:100%;object-fit:cover}
.creator-avatar-initial{font-size:3rem;font-weight:800;color:#fff}
.creator-header-info h1{font-size:2.2rem;font-weight:900;margin-bottom:5px;letter-spacing:-.03em}
.creator-video-count{color:var(--text-muted);font-size:1rem}
.creator-description{color:var(--text-muted);margin-top:9px;font-size:0.95rem}
.creator-videos-section{max-width:1600px;margin:0 auto;padding:0 32px 48px}

/* ─── Video page ─────────────────────────────────────────────────────────── */
.video-page-layout{display:grid;grid-template-columns:1fr 380px;gap:40px;align-items:start}
.video-player-wrap{background:#000;border-radius:var(--radius);overflow:hidden}
.video-player-wrap video{width:100%;display:block}
.video-info{padding:20px 0 0}
.video-title{font-size:1.75rem;font-weight:700;margin-bottom:16px;line-height:1.3;letter-spacing:-.02em}
.video-meta-row{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border)}
.creator-badge-link{display:flex;align-items:center;gap:10px}
.creator-badge-img{width:52px;height:52px;border-radius:50%;object-fit:cover}
.creator-badge-initial{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.2rem;color:#fff;flex-shrink:0}
.creator-badge-info{display:flex;flex-direction:column}
.creator-badge-name{font-weight:700;font-size:1.12rem}
.creator-badge-sub{font-size:0.82rem;color:var(--text-muted);margin-top:-2px}
.video-actions{display:flex;align-items:center;gap:14px}
.like-btn{display:flex;align-items:center;gap:8px;background:var(--bg3);border:1px solid var(--border);color:var(--text);padding:9px 20px;border-radius:999px;font-size:1rem;font-weight:600;transition:all var(--tr)}
.like-btn:hover{border-color:var(--accent)}
.like-btn.liked{background:rgba(230,57,70,.15);border-color:var(--accent);color:var(--accent)}
.like-btn svg{width:18px;height:18px}
.view-count,.video-date{font-size:1rem;color:var(--text-muted);display:flex;align-items:center;gap:5px}
.view-count svg,.video-date svg{width:17px;height:17px;opacity:.7}
.video-description{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;margin-bottom:16px;font-size:0.97rem;color:var(--text-muted);line-height:1.75}
.video-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.tag{background:var(--bg3);border:1px solid var(--border);padding:5px 13px;border-radius:999px;font-size:0.84rem;color:var(--text-muted);transition:all var(--tr)}
.tag:hover{border-color:var(--accent2);color:var(--accent2)}
.admin-bar{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}

/* Sidebar */
.video-sidebar{position:sticky;top:calc(var(--header-h) + 20px)}
.video-sidebar h3{font-size:0.92rem;font-weight:700;margin-bottom:16px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}
.sidebar-video-item{display:flex;gap:13px;padding:11px 0;border-bottom:1px solid var(--border);transition:opacity var(--tr)}
.sidebar-video-item:hover{opacity:.8}
.sidebar-video-item:hover .sidebar-title{color:var(--accent)}
.sidebar-thumb{width:120px;flex-shrink:0;position:relative;aspect-ratio:16/9;background:var(--bg3);border-radius:var(--radius-sm);overflow:hidden}
.sidebar-thumb img{width:100%;height:100%;object-fit:cover}
.sidebar-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-dim)}
.sidebar-duration{position:absolute;bottom:4px;right:5px;background:rgba(0,0,0,.85);color:#fff;font-size:0.74rem;padding:2px 6px;border-radius:3px;font-weight:700}
.sidebar-info{display:flex;flex-direction:column;justify-content:center;gap:4px;min-width:0}
.sidebar-title{font-size:0.92rem;font-weight:600;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.sidebar-meta{font-size:0.8rem;color:var(--text-muted)}
.sidebar-more{display:block;margin-top:16px;text-align:center}
.sidebar-empty{font-size:0.92rem;color:var(--text-dim)}

/* Comments */
.comments-section{margin-top:36px;padding-top:30px;border-top:2px solid var(--border)}
.comments-section h3{font-size:1.15rem;font-weight:800;margin-bottom:20px}
.comment-form{background:var(--bg2);border:1px solid var(--border);padding:20px;border-radius:var(--radius);margin-bottom:30px}
.comment-form .form-row{margin-bottom:13px}
.no-comments{color:var(--text-dim);font-size:1rem;padding:20px 0}
.comment{display:flex;gap:14px;padding:15px 0;border-bottom:1px solid var(--border)}
.comment-avatar{width:42px;height:42px;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-weight:800;flex-shrink:0;font-size:1rem;color:var(--text-muted);border:1px solid var(--border)}
.comment-header{display:flex;align-items:baseline;gap:10px;margin-bottom:5px}
.comment-author{font-size:0.95rem;font-weight:700}
.comment-date{font-size:0.8rem;color:var(--text-dim)}
.comment-text{font-size:0.93rem;color:var(--text-muted);white-space:pre-wrap;word-break:break-word;line-height:1.65}

/* ─── Forms ──────────────────────────────────────────────────────────────── */
.form-input{width:100%;background:var(--bg3);border:1px solid var(--border);color:var(--text);padding:12px 16px;border-radius:var(--radius-sm);font-family:var(--font);font-size:1rem;transition:border-color var(--tr),box-shadow var(--tr)}
.form-input:focus{outline:none;border-color:var(--accent2);box-shadow:0 0 0 3px rgba(58,143,209,.16)}
textarea.form-input{resize:vertical}
.form-group{margin-bottom:22px}
.form-label{display:block;margin-bottom:8px;font-size:0.93rem;font-weight:700;color:var(--text-muted)}
.label-hint{font-weight:400;color:var(--text-dim);font-size:0.87rem}
.required{color:var(--accent);font-weight:800}
.optional{color:var(--text-dim);font-size:0.85rem;font-weight:400}
.submit-legend{font-size:0.87rem;color:var(--text-dim);margin-bottom:24px}
.submit-form{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:30px}

/* ─── Buttons ────────────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--bg3);border:1px solid var(--border);color:var(--text);padding:11px 22px;border-radius:var(--radius-sm);font-size:0.97rem;font-weight:600;transition:all var(--tr);font-family:var(--font);cursor:pointer}
.btn:hover{background:var(--bg4);border-color:var(--text-dim)}
.btn svg{width:17px;height:17px}
.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-h);border-color:var(--accent-h)}
.btn-blue{background:var(--accent2);border-color:var(--accent2);color:#fff}
.btn-blue:hover{background:var(--accent2-h);border-color:var(--accent2-h)}
.btn-outline{background:transparent}
.btn-outline:hover{border-color:var(--accent2);color:var(--accent2)}
.btn-sm{padding:7px 14px;font-size:0.87rem}
.btn-large{padding:15px 36px;font-size:1.08rem}
.btn-success{background:#2d6a4f;border-color:#2d6a4f;color:#fff}
.btn-danger{background:#7b1a1a;border-color:#7b1a1a;color:#fff}

/* ─── Alerts ─────────────────────────────────────────────────────────────── */
.alert{padding:15px 20px;border-radius:var(--radius-sm);margin-bottom:20px;font-size:0.97rem;line-height:1.55}
.alert-success{background:rgba(45,106,79,.2);border:1px solid #2d6a4f;color:#74c69d}
.alert-error{background:rgba(123,26,26,.2);border:1px solid #7b1a1a;color:#f08080}
body.light-mode .alert-success{background:#dbf5e9;color:#0d3320}
body.light-mode .alert-error{background:#ffeaea;color:#5a0d0d}

/* ─── Misc ───────────────────────────────────────────────────────────────── */
.page-container{max-width:1200px;margin:0 auto}
.page-container.narrow{max-width:780px}
.page-title{font-size:2rem;font-weight:900;margin-bottom:30px;letter-spacing:-.03em}
.page-content{font-size:1rem;line-height:1.85;color:var(--text-muted)}
.page-content h2{color:var(--text);margin:30px 0 10px;font-size:1.25rem;font-weight:800}
.page-content p{margin-bottom:14px}
.empty-state{color:var(--text-dim);padding:56px;text-align:center;font-size:1.05rem}
.hint{font-size:0.9rem;color:var(--text-dim)}
code{background:var(--bg3);padding:2px 8px;border-radius:4px;font-size:0.87em}

/* Pagination */
.pagination{display:flex;align-items:center;justify-content:center;gap:20px;margin-top:40px}
.page-btn{background:var(--bg2);border:1px solid var(--border);padding:11px 22px;border-radius:var(--radius-sm);color:var(--text);font-size:0.97rem;font-weight:600;transition:all var(--tr)}
.page-btn:hover{border-color:var(--accent2);color:var(--accent2)}
.page-info{color:var(--text-muted);font-size:0.93rem}

/* ─── Upload boxes ───────────────────────────────────────────────────────── */
.upload-box{position:relative;background:var(--bg3);border:2px dashed var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color var(--tr),background var(--tr);overflow:hidden}
.upload-box:hover,.upload-box.has-file{border-color:var(--accent2)}
.upload-box.has-file{background:rgba(58,143,209,.07)}
.upload-box input[type="file"]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;z-index:2}
.upload-box-inner{display:flex;align-items:center;gap:18px;padding:24px;pointer-events:none}
.upload-box-sm .upload-box-inner{padding:16px 24px}
.upload-icon{color:var(--text-dim);flex-shrink:0}
.upload-icon svg{width:32px;height:32px}
.upload-box-text{display:flex;flex-direction:column;gap:4px}
.upload-box-text span{font-size:0.97rem;color:var(--text-muted);font-weight:500}
.upload-box-text small{font-size:0.82rem;color:var(--text-dim)}
.thumb-preview-wrap{display:flex;align-items:center;gap:15px;margin-top:12px}
.thumb-preview-wrap img{height:92px;border-radius:var(--radius-sm);border:1px solid var(--border);object-fit:cover}
.thumb-remove{background:var(--bg3);border:1px solid var(--border);color:var(--text-muted);padding:6px 13px;border-radius:var(--radius-sm);font-size:0.87rem;cursor:pointer;display:flex;align-items:center;gap:6px}
.thumb-remove:hover{border-color:var(--accent);color:var(--accent)}
.upload-progress{margin-top:15px}
.progress-bar{background:var(--bg3);border-radius:999px;height:7px;overflow:hidden;margin-bottom:7px}
.progress-fill{background:linear-gradient(90deg,var(--accent2),var(--accent));height:100%;width:0;transition:width .3s;border-radius:999px}

/* ─── Combobox ───────────────────────────────────────────────────────────── */
.combobox{position:relative}
.combobox-input-wrap{position:relative}
.combobox-input{padding-right:40px!important}
.combobox-arrow{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--text-dim);pointer-events:none;transition:transform .15s;display:flex}
.combobox-arrow svg{width:16px;height:16px}
.combobox:focus-within .combobox-arrow{transform:translateY(-50%) rotate(180deg)}
.combobox-list{position:absolute;top:calc(100% + 5px);left:0;right:0;z-index:50;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 12px 32px rgba(0,0,0,.5);max-height:290px;overflow-y:auto;padding:5px 0;list-style:none;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.combobox-option{padding:11px 18px;cursor:pointer;font-size:0.97rem;transition:background .1s}
.combobox-option:hover,.combobox-option.active{background:var(--bg3)}
.combobox-option mark{background:rgba(230,57,70,.2);color:var(--accent);border-radius:2px;padding:0 2px}
.combobox-new{color:var(--accent2);border-top:1px solid var(--border);margin-top:4px;padding-top:12px;font-weight:600}
.combobox-hint{font-size:0.82rem;color:var(--accent2);margin-top:6px;min-height:1.1rem;display:flex;align-items:center;gap:5px}

/* ─── FAQ accordion ──────────────────────────────────────────────────────── */
.faq-list{display:flex;flex-direction:column;margin-top:10px}
.faq-item{border-bottom:1px solid var(--border)}
.faq-item:first-child{border-top:1px solid var(--border)}
.faq-question{width:100%;background:none;border:none;color:var(--text);text-align:left;padding:20px 8px;font-size:1.05rem;font-weight:700;display:flex;justify-content:space-between;align-items:center;gap:16px;cursor:pointer;transition:color var(--tr)}
.faq-question:hover{color:var(--accent2)}
.faq-icon{flex-shrink:0;color:var(--text-muted);transition:transform .28s;display:flex}
.faq-icon svg{width:22px;height:22px}
.faq-item.open .faq-icon{transform:rotate(45deg);color:var(--accent)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .38s ease,padding .25s ease;padding:0 8px;font-size:0.97rem;color:var(--text-muted);line-height:1.8}
.faq-item.open .faq-answer{max-height:800px;padding:0 8px 20px}
.faq-intro{color:var(--text-muted);margin-bottom:30px;font-size:1rem;line-height:1.75}

/* ─── Search page ────────────────────────────────────────────────────────── */
.search-header{margin-bottom:32px}
.search-bar-large{display:flex;gap:12px;margin-bottom:10px}
.search-bar-large input{flex:1;background:var(--bg2);border:2px solid var(--border);color:var(--text);padding:14px 20px;border-radius:var(--radius);font-size:1.05rem;font-family:var(--font);transition:border-color var(--tr)}
.search-bar-large input:focus{outline:none;border-color:var(--accent2)}
.search-meta{color:var(--text-muted);font-size:0.95rem}
.search-section{margin-bottom:48px}
.search-section h2{font-size:1.2rem;font-weight:800;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid var(--border)}

/* ─── Admin login ────────────────────────────────────────────────────────── */
body.admin-login-page{display:flex;align-items:center;justify-content:center;min-height:100vh}
.admin-login-wrap{width:100%;max-width:440px;padding:20px}
.admin-login-box{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:40px}
.admin-login-box h1{margin-bottom:5px;font-size:1.7rem;font-weight:900}
.admin-login-box>.login-sub{color:var(--text-muted);margin-bottom:28px;font-size:1rem}

/* ─── Responsive ─────────────────────────────────────────────────────────── */
@media(max-width:1200px){
  .video-page-layout{grid-template-columns:1fr 320px;gap:28px}
  .header-search-wrap{max-width:340px}
}
@media(max-width:960px){
  .video-page-layout{grid-template-columns:1fr}
  .video-sidebar{position:static}
  .header-search-wrap{max-width:240px}
}
@media(max-width:720px){
  html{font-size:15px}
  :root{--header-h:58px}
  .site-main{padding:18px 14px}
  .header-inner{padding:0 14px;gap:8px}
  .site-logo img{height:38px}

  /* Hide desktop-only elements */
  .header-search-wrap{display:none}
  .btn-submit-nav{display:none!important}
  .main-nav{display:none}

  /* Show toggle button */
  .nav-toggle{display:flex;align-items:center}
  .site-header{position:relative}

  /* Carousel */
  .carousel .video-card{min-width:200px;max-width:200px}
  .carousel-btn{display:none}

  /* Grids */
  .video-grid{grid-template-columns:1fr 1fr;gap:12px}
  .creator-header-inner{flex-direction:column;text-align:center}
  .video-meta-row{flex-direction:column;align-items:flex-start;gap:10px}
  .footer-inner{flex-direction:column;gap:12px;text-align:center}
  .footer-nav{flex-wrap:wrap;justify-content:center}
  .video-title{font-size:1.2rem}
  .page-title{font-size:1.4rem}
  .submit-form{padding:16px}
  .banner-inner{padding:0 14px}
  .banner-text{font-size:0.9rem}
}
@media(max-width:480px){
  .video-grid{grid-template-columns:1fr 1fr;gap:10px}
  .creators-grid{grid-template-columns:1fr 1fr}
  .admin-stats-grid{grid-template-columns:1fr 1fr}
  .videos-toolbar{flex-wrap:wrap;gap:8px}
}

/* ─── Submit nav button ──────────────────────────────────── */
.btn-submit-nav {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--accent); color: #fff; border: none;
  padding: 10px 18px; border-radius: var(--radius-sm);
  font-size: 0.95rem; font-weight: 700; white-space: nowrap;
  transition: background var(--tr); flex-shrink: 0;
}
.btn-submit-nav:hover { background: var(--accent-h); }
.btn-submit-nav svg { flex-shrink: 0; }

/* ─── Live search dropdown ───────────────────────────────── */
.header-search-wrap{position:relative;flex:1;max-width:480px;margin:0 12px}
.header-search{display:flex;width:100%}
.header-search input{width:100%;background:var(--bg3);border:1px solid var(--border);color:var(--text);padding:10px 42px 10px 16px;border-radius:999px;font-size:0.95rem;font-family:var(--font);transition:border-color var(--tr),box-shadow var(--tr)}
.header-search input:focus{outline:none;border-color:var(--accent2);box-shadow:0 0 0 3px rgba(58,143,209,.18)}
.header-search input::placeholder{color:var(--text-dim)}
.header-search-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);padding:4px;cursor:pointer;transition:color var(--tr)}
.header-search-btn:hover{color:var(--accent2)}
.live-search-dropdown {
  position: absolute; top: calc(100% + 6px); left: 0; right: 0; z-index: 200;
  background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius);
  box-shadow: 0 12px 36px rgba(0,0,0,.55); overflow: hidden;
}
.live-search-group { padding: 8px 0; }
.live-search-group-label {
  padding: 6px 16px; font-size: 0.75rem; font-weight: 700;
  color: var(--text-dim); text-transform: uppercase; letter-spacing: .06em;
}
.live-search-item {
  display: flex; align-items: center; gap: 12px;
  padding: 9px 16px; cursor: pointer; transition: background .1s;
  text-decoration: none; color: var(--text);
}
.live-search-item:hover { background: var(--bg3); }
.live-search-thumb {
  width: 56px; height: 32px; border-radius: 4px; overflow: hidden;
  background: var(--bg3); flex-shrink: 0;
}
.live-search-thumb img { width: 100%; height: 100%; object-fit: cover; }
.live-search-avatar {
  width: 32px; height: 32px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 0.85rem; color: #fff;
}
.live-search-info { display: flex; flex-direction: column; min-width: 0; }
.live-search-title { font-size: 0.92rem; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.live-search-sub { font-size: 0.78rem; color: var(--text-muted); }
.live-search-all { display: block; padding: 10px 16px; font-size: 0.88rem; color: var(--accent2); font-weight: 600; border-top: 1px solid var(--border); text-align: center; }
.live-search-all:hover { background: var(--bg3); }
.live-search-empty { padding: 14px 16px; color: var(--text-dim); font-size: 0.92rem; }

/* ─── Search page – fix icon sizes ──────────────────────── */
.search-section h2 svg { width: 20px !important; height: 20px !important; vertical-align: middle; }
.search-section h2 { display: flex; align-items: center; gap: 10px; }

/* ─── Submitted by ───────────────────────────────────────── */
.submitted-by { font-size: 0.88rem; color: var(--text-dim); margin-top: 12px; }
.submitted-by strong { color: var(--text-muted); }

/* ─── Logo bigger ────────────────────────────────────────── */
.site-logo img { height: 58px; }

/* Field descriptions */
.field-desc {
  font-size: 0.84rem;
  color: var(--text-dim);
  margin-top: 5px;
  line-height: 1.5;
}

/* ─── Tag links ──────────────────────────────────────────── */
a.tag {
  display: inline-block;
  cursor: pointer;
  transition: all var(--tr);
}
a.tag:hover {
  background: var(--accent2);
  border-color: var(--accent2);
  color: #fff;
}

/* Tag chips on search page */
.tag-chips {
  display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 8px;
}
.tag-chip {
  padding: 7px 16px !important;
  font-size: 0.92rem !important;
  font-weight: 600;
}

/* Tag page header */
.tag-page-header { margin-bottom: 28px; }
.tag-page-count { color: var(--text-muted); font-size: 1rem; margin-top: 4px; }

/* ─── Tag cloud (homepage) ───────────────────────────────── */
.tag-cloud-section { margin-bottom: 60px; }
.tag-cloud {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 22px 26px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  align-items: baseline;
}
.tag-cloud-item {
  color: var(--text-muted);
  transition: color var(--tr);
  line-height: 1.4;
}
.tag-cloud-item:hover { color: var(--accent2); }

/* ─── Live search tags ───────────────────────────────────── */
.live-search-tags {
  display: flex; flex-wrap: wrap; gap: 6px;
  padding: 6px 16px 10px;
}
.live-search-tag {
  background: var(--bg3); border: 1px solid var(--border);
  color: var(--text-muted); padding: 4px 11px;
  border-radius: 999px; font-size: 0.85rem; font-weight: 600;
  transition: all var(--tr);
}
.live-search-tag:hover {
  background: var(--accent2); border-color: var(--accent2); color: #fff;
}



/* ─── All Videos page ────────────────────────────────────── */
.videos-page-header { margin-bottom: 20px; }
.videos-total { color: var(--text-muted); font-size: 1rem; margin-top: 4px; }
.videos-toolbar {
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 24px; flex-wrap: wrap;
}
.sort-label { font-size: 0.9rem; color: var(--text-muted); font-weight: 600; }
.sort-buttons { display: flex; gap: 6px; flex-wrap: wrap; }
.sort-btn {
  padding: 7px 15px; border-radius: var(--radius-sm);
  background: var(--bg2); border: 1px solid var(--border);
  color: var(--text-muted); font-size: 0.88rem; font-weight: 500;
  transition: all var(--tr);
}
.sort-btn:hover { border-color: var(--accent2); color: var(--accent2); }
.sort-btn.active { background: var(--accent2); border-color: var(--accent2); color: #fff; font-weight: 700; }

/* ─── Mobile menu panel ──────────────────────────────────── */
.mobile-menu {
  display: none;  /* shown via JS, not CSS display toggle */
  position: fixed;
  top: var(--header-h);
  left: 0; right: 0; bottom: 0;
  background: var(--bg2);
  border-top: 3px solid var(--accent);
  z-index: 998;
  overflow-y: auto;
  padding: 16px 16px 48px;
  flex-direction: column;
  gap: 0;
}
.mobile-menu.open { display: flex; }

.mobile-menu-search {
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 8px;
}
.mobile-search-wrap {
  display: flex;
  background: var(--bg3);
  border: 2px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.mobile-search-wrap input {
  flex: 1; background: none; border: none;
  padding: 14px 16px; font-size: 1.05rem;
  color: var(--text); font-family: var(--font);
}
.mobile-search-wrap input:focus { outline: none; }
.mobile-search-wrap button {
  background: none; border: none;
  padding: 0 18px; color: var(--text-muted); cursor: pointer;
}

.mobile-menu-nav { display: flex; flex-direction: column; }
.mobile-menu-nav a {
  padding: 17px 8px;
  font-size: 1.1rem; font-weight: 600;
  color: var(--text-muted);
  border-bottom: 1px solid var(--border);
  transition: color var(--tr);
}
.mobile-menu-nav a:hover,
.mobile-menu-nav a:active { color: var(--text); background: var(--bg3); border-radius: var(--radius-sm); }
.mobile-menu-nav .nav-admin { color: var(--accent) !important; }

.mobile-menu-submit {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  margin-top: 16px;
  background: var(--accent); color: #fff;
  padding: 16px; border-radius: var(--radius);
  font-size: 1.05rem; font-weight: 700;
  transition: background var(--tr);
}
.mobile-menu-submit:hover { background: var(--accent-h); }

/* ─── Quote of the Day ───────────────────────────────────── */
.quote-section { margin-bottom: 60px; }
.quote-card {
  background: linear-gradient(135deg, var(--bg2) 0%, var(--bg3) 100%);
  border: 1px solid var(--border);
  border-left: 4px solid var(--accent2);
  border-radius: var(--radius);
  padding: 36px 40px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.quote-label {
  font-family: 'Caveat', cursive;
  font-size: 2.4rem;
  font-weight: 700;
  color: var(--accent2);
  margin-bottom: 6px;
  letter-spacing: 0.02em;
  transform: rotate(-2deg);
}
.quote-text {
  font-size: 1.85rem;
  font-weight: 600;
  line-height: 1.5;
  color: var(--text);
  margin: 0 0 4px;
  max-width: 820px;
  margin-left: auto;
  margin-right: auto;
}
.quote-mark {
  font-family: Georgia, serif;
  font-size: 4rem;
  font-weight: 800;
  color: var(--accent2);
  opacity: 0.75;
  line-height: 0;
  display: inline-block;
}
.quote-mark-open {
  margin-right: 6px;
  margin-left: -8px;
  vertical-align: -0.15em;
}
.quote-mark-close {
  margin-left: 6px;
  vertical-align: -0.75em;
}
.quote-source {
  font-size: 1.2rem;
  color: var(--text-muted);
  font-weight: 600;
  margin: 0;
}

@media(max-width:720px){
  .quote-card { padding: 26px 20px; }
  .quote-label { font-size: 1.5rem; }
  .quote-text { font-size: 1.2rem; }
  .quote-mark { font-size: 2rem; }
}
