/* ============================================
   CineStream – Fő stíluslap
   assets/css/main.css
============================================ */
:root {
  --bg:      #0a0a0f;
  --bg2:     #111118;
  --bg3:     #1a1a24;
  --bg4:     #222230;
  --accent:  #e63946;
  --accent2: #ff6b35;
  --gold:    #ffd60a;
  --green:   #22c55e;
  --blue:    #3b82f6;
  --text:    #f0f0f5;
  --muted:   #8888aa;
  --radius:  12px;
  --card-w:  180px;
  --card-h:  270px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--text);font-family:'Outfit',sans-serif;overflow-x:hidden;min-height:100vh;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}

/* ── NAVBAR ── */
.navbar{position:fixed;top:0;left:0;right:0;z-index:999;height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 32px;background:rgba(10,10,15,.97);border-bottom:1px solid rgba(255,255,255,.05);backdrop-filter:blur(8px);}
.nav-logo{font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:3px;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.nav-links{display:flex;gap:4px;align-items:center;}
.nav-links a{color:var(--muted);padding:7px 13px;border-radius:8px;font-size:14px;font-weight:500;transition:all .2s;}
.nav-links a:hover,.nav-links a.active{color:var(--text);background:rgba(255,255,255,.07);}
.dropdown{position:relative;}
.dropdown-menu{position:absolute;top:calc(100% + 8px);left:0;background:var(--bg2);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:8px;min-width:200px;display:none;z-index:200;box-shadow:0 16px 50px rgba(0,0,0,.6);}
.dropdown:hover .dropdown-menu{display:grid;grid-template-columns:1fr 1fr;}
.dropdown-menu a{padding:9px 12px;border-radius:8px;font-size:13px;color:var(--muted);transition:all .2s;white-space:nowrap;}
.dropdown-menu a:hover{color:var(--text);background:rgba(255,255,255,.06);}
.nav-right{display:flex;align-items:center;gap:10px;}
.search-form{display:flex;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:10px;overflow:hidden;transition:border-color .2s;}
.search-form:focus-within{border-color:var(--accent);}
.search-form input{background:none;border:none;outline:none;color:var(--text);font-family:'Outfit',sans-serif;font-size:13px;padding:8px 12px;width:180px;}
.search-form input::placeholder{color:var(--muted);}
.search-form button{background:none;border:none;cursor:pointer;padding:0 12px;color:var(--muted);font-size:15px;}
.btn-primary-sm{background:var(--accent);color:#fff;padding:8px 18px;border-radius:9px;font-weight:600;font-size:13px;transition:all .2s;}
.btn-primary-sm:hover{background:#c1121f;transform:translateY(-1px);box-shadow:0 4px 16px rgba(230,57,70,.4);}
.btn-ghost-sm{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:var(--text);padding:8px 18px;border-radius:9px;font-weight:600;font-size:13px;transition:all .2s;}
.btn-ghost-sm:hover{background:rgba(255,255,255,.12);}

/* User menu */
.user-menu{position:relative;}
.user-trigger{display:flex;align-items:center;gap:8px;cursor:pointer;padding:6px 10px;border-radius:9px;font-size:13px;font-weight:600;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);transition:background .2s;}
.user-trigger:hover{background:rgba(255,255,255,.11);}
.user-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;}
.user-initials{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;}
.user-dropdown{position:absolute;right:0;top:calc(100% + 8px);background:var(--bg2);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:8px;min-width:180px;display:none;box-shadow:0 16px 50px rgba(0,0,0,.6);}
.user-menu:hover .user-dropdown{display:block;}
.user-dropdown a{display:block;padding:10px 14px;border-radius:8px;font-size:13px;color:var(--muted);transition:all .2s;}
.user-dropdown a:hover{color:var(--text);background:rgba(255,255,255,.06);}
.user-dropdown hr{border:none;border-top:1px solid rgba(255,255,255,.06);margin:6px 0;}

/* ── MOBILE NAV ── */
.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:998;background:rgba(10,10,15,.97);border-top:1px solid rgba(255,255,255,.06);padding:8px 0 max(8px,env(safe-area-inset-bottom));backdrop-filter:blur(12px);}
.mobile-nav a{display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--muted);font-size:10px;font-weight:500;flex:1;transition:color .2s;}
.mobile-nav a span:first-child{font-size:20px;}
.mobile-nav a.active,.mobile-nav a:hover{color:var(--accent);}
.mobile-nav{display:none;justify-content:space-around;}

/* ── MAIN ── */
.main-content{padding-top:64px;}

/* ── HERO ── */
.hero{position:relative;height:90vh;min-height:580px;display:flex;align-items:flex-end;padding:0 60px 80px;overflow:hidden;}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 70% 40%,rgba(230,57,70,.1) 0%,transparent 60%),linear-gradient(135deg,#0d0d18,#1a0a14,#0d0d18);}
.hero-backdrop{position:absolute;right:0;top:0;bottom:0;width:65%;background-size:cover;background-position:center;mask-image:linear-gradient(to left,rgba(0,0,0,.7) 0%,transparent 100%),linear-gradient(to bottom,rgba(0,0,0,.8) 0%,transparent 100%);opacity:.55;}
.hero-content{position:relative;z-index:2;max-width:560px;}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(230,57,70,.15);border:1px solid rgba(230,57,70,.3);color:var(--accent);border-radius:20px;padding:5px 14px;font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;margin-bottom:18px;}
.hero-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(50px,7vw,88px);line-height:.95;letter-spacing:2px;margin-bottom:18px;text-shadow:0 4px 40px rgba(0,0,0,.8);}
.hero-title span{background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.hero-meta{display:flex;align-items:center;gap:12px;margin-bottom:14px;flex-wrap:wrap;}
.hero-meta .rating{display:flex;align-items:center;gap:5px;background:rgba(255,214,10,.12);border:1px solid rgba(255,214,10,.3);color:var(--gold);border-radius:6px;padding:4px 10px;font-weight:700;font-size:14px;}
.hero-meta .sep{color:rgba(255,255,255,.15);}
.hero-meta span{color:var(--muted);font-size:14px;}
.hero-desc{color:rgba(240,240,245,.7);font-size:15px;line-height:1.7;margin-bottom:28px;max-width:460px;}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;}
.btn-play{display:inline-flex;align-items:center;gap:10px;background:var(--accent);color:#fff;padding:13px 26px;border-radius:11px;font-weight:700;font-size:15px;transition:all .25s;border:none;cursor:pointer;}
.btn-play:hover{background:#c1121f;transform:translateY(-2px);box-shadow:0 8px 30px rgba(230,57,70,.5);}
.btn-info{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);color:var(--text);padding:13px 26px;border-radius:11px;font-weight:600;font-size:15px;transition:all .25s;cursor:pointer;}
.btn-info:hover{background:rgba(255,255,255,.16);transform:translateY(-2px);}

/* ── SECTIONS ── */
.section{padding:44px 40px 12px;}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;}
.section-title{font-family:'Bebas Neue',sans-serif;font-size:24px;letter-spacing:2px;display:flex;align-items:center;gap:10px;}
.section-icon{width:30px;height:30px;background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:15px;}
.section-more{color:var(--accent);font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;opacity:.8;transition:opacity .2s;}
.section-more:hover{opacity:1;}

/* ── CARD SCROLL ── */
.cards-scroll{display:flex;gap:14px;overflow-x:auto;padding-bottom:14px;scrollbar-width:thin;scrollbar-color:rgba(230,57,70,.3) transparent;}
.cards-scroll::-webkit-scrollbar{height:4px;}
.cards-scroll::-webkit-scrollbar-thumb{background:rgba(230,57,70,.3);border-radius:2px;}

/* ── CARD ── */
.card{flex:0 0 var(--card-w);cursor:pointer;transition:transform .3s cubic-bezier(.34,1.56,.64,1);position:relative;}
.card:hover{transform:scale(1.07) translateY(-6px);z-index:10;}
.card-poster{width:100%;height:var(--card-h);border-radius:11px;overflow:hidden;position:relative;background:var(--bg3);box-shadow:0 4px 20px rgba(0,0,0,.5);}
.card-poster img{width:100%;height:100%;object-fit:cover;transition:transform .4s;}
.card:hover .card-poster img{transform:scale(1.06);}
.card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.9) 0%,transparent 55%);border-radius:11px;opacity:0;transition:opacity .3s;display:flex;align-items:flex-end;padding:12px;}
.card:hover .card-overlay{opacity:1;}
.play-circle{width:36px;height:36px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;margin-left:auto;box-shadow:0 4px 15px rgba(230,57,70,.5);}
.card-badge{position:absolute;top:9px;left:9px;background:rgba(0,0,0,.75);border:1px solid rgba(255,255,255,.1);border-radius:5px;padding:3px 8px;font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;backdrop-filter:blur(4px);color:var(--muted);}
.card-badge.film{color:#34d399;border-color:rgba(52,211,153,.3);}
.card-badge.sorozat{color:#60a5fa;border-color:rgba(96,165,250,.3);}
.card-rating{position:absolute;top:9px;right:9px;background:rgba(0,0,0,.75);border-radius:6px;padding:3px 7px;font-size:12px;font-weight:700;color:var(--gold);backdrop-filter:blur(4px);}
.card-info{padding:9px 3px 3px;}
.card-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.card-year{font-size:11px;color:var(--muted);margin-top:3px;}

/* ── CATEGORY PILLS ── */
.cat-pills{display:flex;gap:8px;flex-wrap:wrap;padding:0 40px 32px;}
.cat-pill{background:var(--bg3);border:1px solid rgba(255,255,255,.07);color:var(--muted);border-radius:20px;padding:7px 16px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;}
.cat-pill:hover,.cat-pill.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 4px 16px rgba(230,57,70,.3);}

/* ── BROWSE GRID ── */
.browse-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:18px;padding:28px 40px;}

/* ── CONTENT PAGE ── */
.content-hero{display:flex;gap:40px;padding:40px;align-items:flex-start;flex-wrap:wrap;}
.content-poster{width:240px;flex-shrink:0;border-radius:14px;overflow:hidden;box-shadow:0 12px 50px rgba(0,0,0,.7);}
.content-poster img{width:100%;display:block;}
.content-info{flex:1;min-width:280px;}
.content-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(36px,5vw,64px);letter-spacing:2px;line-height:1;margin-bottom:16px;}
.content-meta-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-bottom:16px;}
.meta-pill{background:var(--bg3);border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:4px 12px;font-size:13px;}
.rating-pill{background:rgba(255,214,10,.12);border:1px solid rgba(255,214,10,.25);color:var(--gold);font-weight:700;}
.content-desc{color:rgba(240,240,245,.75);font-size:15px;line-height:1.75;margin-bottom:24px;max-width:620px;}
.content-actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:28px;}

/* ── PLAYER AREA ── */
.player-section{padding:0 40px 32px;}
.source-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;}
.source-tab{background:var(--bg3);border:1px solid rgba(255,255,255,.08);color:var(--muted);padding:9px 18px;border-radius:9px;cursor:pointer;font-weight:600;font-size:13px;transition:all .2s;}
.source-tab.active,.source-tab:hover{background:var(--accent);border-color:var(--accent);color:#fff;}
.player-wrapper{position:relative;padding-bottom:56.25%;background:var(--bg3);border-radius:14px;overflow:hidden;box-shadow:0 8px 40px rgba(0,0,0,.6);}
.player-wrapper iframe{position:absolute;inset:0;width:100%;height:100%;border:none;}
.no-source{display:flex;flex-direction:column;align-items:center;justify-content:center;height:360px;background:var(--bg3);border-radius:14px;color:var(--muted);gap:12px;font-size:15px;}

/* ── SEASONS ── */
.seasons-section{padding:0 40px 32px;}
.seasons-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;}
.season-tab{background:var(--bg3);border:1px solid rgba(255,255,255,.08);color:var(--muted);padding:8px 18px;border-radius:9px;cursor:pointer;font-size:13px;font-weight:700;transition:all .2s;}
.season-tab.active{background:var(--accent);border-color:var(--accent);color:#fff;}
.episodes-grid{display:flex;gap:8px;flex-wrap:wrap;}
.ep-btn{width:48px;height:48px;background:var(--bg3);border:1px solid rgba(255,255,255,.08);color:var(--text);border-radius:9px;cursor:pointer;font-weight:700;font-size:14px;transition:all .2s;display:flex;align-items:center;justify-content:center;}
.ep-btn:hover{background:var(--accent);border-color:var(--accent);}
.ep-btn.active{background:var(--accent);border-color:var(--accent);box-shadow:0 4px 16px rgba(230,57,70,.4);}

/* ── RATING ── */
.rating-section{background:var(--bg2);border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:24px 28px;margin:0 40px 28px;}
.rating-section h3{font-size:16px;font-weight:700;margin-bottom:16px;}
.stars{display:flex;gap:6px;}
.star{font-size:28px;cursor:pointer;color:var(--bg4);transition:color .15s,transform .15s;}
.star.filled,.star:hover{color:var(--gold);}
.star:hover{transform:scale(1.2);}
.rating-msg{font-size:13px;color:var(--muted);margin-top:10px;}

/* ── COMMENTS ── */
.comments-section{padding:0 40px 40px;}
.comments-section h3{font-size:20px;font-weight:700;margin-bottom:20px;}
.comment-form textarea{width:100%;background:var(--bg3);border:1px solid rgba(255,255,255,.08);border-radius:11px;padding:14px;color:var(--text);font-family:'Outfit',sans-serif;font-size:14px;resize:vertical;min-height:90px;outline:none;transition:border-color .2s;}
.comment-form textarea:focus{border-color:var(--accent);}
.comment-form .form-footer{display:flex;justify-content:flex-end;margin-top:10px;}
.comment-list{margin-top:28px;display:flex;flex-direction:column;gap:16px;}
.comment{background:var(--bg2);border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:18px 20px;}
.comment-header{display:flex;align-items:center;gap:10px;margin-bottom:10px;}
.comment-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;}
.comment-user{font-weight:700;font-size:14px;}
.comment-time{font-size:11px;color:var(--muted);margin-left:auto;}
.comment-body{color:rgba(240,240,245,.8);font-size:14px;line-height:1.65;}

/* ── AUTH FORMS ── */
.auth-page{min-height:calc(100vh - 64px);display:flex;align-items:center;justify-content:center;padding:40px 16px;}
.auth-box{background:var(--bg2);border:1px solid rgba(255,255,255,.07);border-radius:20px;padding:40px;width:100%;max-width:420px;box-shadow:0 24px 80px rgba(0,0,0,.6);}
.auth-box h1{font-family:'Bebas Neue',sans-serif;font-size:32px;letter-spacing:2px;margin-bottom:8px;}
.auth-box .subtitle{color:var(--muted);font-size:14px;margin-bottom:28px;}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;}
.form-group label{font-size:12px;font-weight:700;color:var(--muted);letter-spacing:.5px;text-transform:uppercase;}
.form-group input{background:var(--bg3);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:12px 14px;color:var(--text);font-family:'Outfit',sans-serif;font-size:14px;outline:none;transition:border-color .2s;}
.form-group input:focus{border-color:var(--accent);}
.btn-full{width:100%;padding:13px;border-radius:11px;background:var(--accent);color:#fff;border:none;cursor:pointer;font-family:'Outfit',sans-serif;font-weight:700;font-size:15px;transition:all .2s;margin-top:4px;}
.btn-full:hover{background:#c1121f;transform:translateY(-1px);box-shadow:0 6px 24px rgba(230,57,70,.4);}
.auth-switch{text-align:center;margin-top:20px;font-size:13px;color:var(--muted);}
.auth-switch a{color:var(--accent);font-weight:600;}
.alert{padding:12px 16px;border-radius:10px;font-size:13px;margin-bottom:16px;}
.alert-error{background:rgba(230,57,70,.12);border:1px solid rgba(230,57,70,.3);color:#ff6b6b;}
.alert-success{background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.3);color:#4ade80;}

/* ── FAVORITES / PROFILE ── */
.page-header{padding:40px 40px 24px;}
.page-header h1{font-family:'Bebas Neue',sans-serif;font-size:40px;letter-spacing:2px;}
.page-header p{color:var(--muted);font-size:14px;margin-top:8px;}
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;color:var(--muted);gap:16px;text-align:center;}
.empty-state .icon{font-size:56px;opacity:.4;}
.empty-state h3{font-size:20px;font-weight:700;color:var(--text);}

/* ── SEARCH ── */
.search-header{padding:40px 40px 20px;}
.search-results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:18px;padding:0 40px 40px;}

/* ── PAGINATION ── */
.pagination{display:flex;gap:6px;justify-content:center;padding:28px 0;}
.pag-btn{width:40px;height:40px;border-radius:9px;background:var(--bg3);border:1px solid rgba(255,255,255,.08);color:var(--muted);cursor:pointer;font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .2s;}
.pag-btn:hover,.pag-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;}

/* ── FOOTER ── */
.site-footer{background:var(--bg2);border-top:1px solid rgba(255,255,255,.05);padding:48px 60px 28px;margin-top:40px;}
.footer-inner{display:flex;gap:60px;flex-wrap:wrap;margin-bottom:36px;}
.footer-logo{font-family:'Bebas Neue',sans-serif;font-size:28px;letter-spacing:3px;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;display:block;margin-bottom:10px;}
.footer-brand p{color:var(--muted);font-size:13px;line-height:1.6;max-width:220px;}
.footer-col h4{font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:14px;}
.footer-col a{display:block;color:var(--muted);font-size:13px;margin-bottom:9px;transition:color .2s;}
.footer-col a:hover{color:var(--accent);}
.footer-bottom{border-top:1px solid rgba(255,255,255,.04);padding-top:20px;color:var(--muted);font-size:12px;}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .navbar{padding:0 16px;}
  .nav-links,.search-form{display:none;}
  .hero{padding:0 20px 60px;}
  .content-hero{padding:20px;}
  .section,.player-section,.seasons-section,.comments-section{padding-left:16px;padding-right:16px;}
  .browse-grid,.search-results-grid{padding:16px;}
  .cat-pills{padding:0 16px 20px;}
  .rating-section{margin-left:16px;margin-right:16px;}
  .page-header{padding:24px 16px 16px;}
  .site-footer{padding:32px 20px 80px;}
  .footer-inner{gap:28px;}
  .mobile-nav{display:flex;}
  :root{--card-w:140px;--card-h:210px;}
}
