/* IRANSans (self-hosted) */
@font-face{font-family:'IRANSans';font-style:normal;font-weight:300;font-display:swap;
    src:url('../fonts/IRANSansWeb_Light.woff2') format('woff2')}
@font-face{font-family:'IRANSans';font-style:normal;font-weight:400;font-display:swap;
    src:url('../fonts/IRANSansWeb.woff2') format('woff2')}
@font-face{font-family:'IRANSans';font-style:normal;font-weight:500;font-display:swap;
    src:url('../fonts/IRANSansWeb_Medium.woff2') format('woff2')}
@font-face{font-family:'IRANSans';font-style:normal;font-weight:700;font-display:swap;
    src:url('../fonts/IRANSansWeb_Bold.woff2') format('woff2')}
@font-face{font-family:'IRANSans';font-style:normal;font-weight:800;font-display:swap;
    src:url('../fonts/IRANSansWeb_Black.woff2') format('woff2')}
@font-face{font-family:'IRANSans';font-style:normal;font-weight:900;font-display:swap;
    src:url('../fonts/IRANSansWeb_Black.woff2') format('woff2')}

:root{
    --bg:#0f1115; --surface:#171a21; --surface-2:#1f242e; --line:#2a3140;
    --text:#e8eaed; --muted:#9aa3b0; --accent:#e63946; --accent-2:#f1a208;
    --radius:14px; --maxw:1160px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
    background:var(--bg); color:var(--text);
    font-family:'IRANSans',Vazirmatn,Tahoma,"Segoe UI",sans-serif;
    line-height:1.7; font-size:16px;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 18px}

/* Header */
.site-header{position:sticky;top:0;z-index:20;background:rgba(15,17,21,.92);
    backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;gap:24px;height:64px}
.brand{display:flex;align-items:center;order:1}
.brand-logo{height:42px;width:auto;display:block}
.main-nav{display:flex;gap:18px;flex-wrap:wrap;align-items:center;order:2}
.main-nav a{color:var(--muted);font-size:.95rem;padding:6px 2px;border-bottom:2px solid transparent;white-space:nowrap}
.main-nav a:hover{color:var(--text);border-color:var(--accent)}
/* Hamburger toggle — hidden on desktop, shown when nav collapses */
.nav-toggle{display:none;order:4;margin-inline-start:12px;width:42px;height:42px;padding:10px;
    background:transparent;border:1px solid var(--line);border-radius:10px;cursor:pointer;
    flex-direction:column;justify-content:space-between}
.nav-toggle span{display:block;height:2px;width:100%;background:var(--text);border-radius:2px;transition:.2s}
.site-header.nav-open .nav-toggle span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.site-header.nav-open .nav-toggle span:nth-child(2){opacity:0}
.site-header.nav-open .nav-toggle span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* Header search */
.header-search{order:3;display:flex;align-items:center;margin-inline-start:auto;
    background:var(--surface-2);border:1px solid var(--line);border-radius:999px;
    padding:0 6px 0 14px;max-width:280px;flex:0 1 280px}
.header-search input{flex:1;min-width:0;background:transparent;border:0;outline:none;
    color:var(--text);font:inherit;font-size:.9rem;padding:9px 6px}
.header-search input::placeholder{color:var(--muted)}
.header-search button{background:transparent;border:0;cursor:pointer;font-size:1rem;
    color:var(--muted);padding:6px;line-height:1}
.header-search button:hover{color:var(--text)}

/* Categories dropdown */
.nav-dropdown{position:relative}
.nav-dropdown-toggle{display:inline-flex;align-items:center;gap:5px;background:transparent;
    border:0;cursor:pointer;color:var(--muted);font:inherit;font-size:.95rem;
    padding:6px 2px;border-bottom:2px solid transparent}
.nav-dropdown-toggle:hover{color:var(--text)}
.nav-dropdown .caret{font-size:.75rem;transition:transform .2s}
.nav-dropdown:hover .caret,.nav-dropdown.open .caret{transform:rotate(180deg)}
.nav-dropdown-menu{position:absolute;top:calc(100% + 8px);inset-inline-end:0;min-width:200px;
    max-height:60vh;overflow-y:auto;display:none;flex-direction:column;
    background:var(--surface);border:1px solid var(--line);border-radius:12px;
    padding:8px;box-shadow:0 12px 28px rgba(0,0,0,.45);z-index:30}
.nav-dropdown:hover .nav-dropdown-menu,.nav-dropdown.open .nav-dropdown-menu{display:flex}
.nav-dropdown-menu a{color:var(--muted);font-size:.9rem;padding:8px 10px;border-radius:8px;
    white-space:nowrap;border:0}
.nav-dropdown-menu a:hover{color:var(--text);background:var(--surface-2)}
.nav-dropdown-empty{color:var(--muted);font-size:.85rem;padding:8px 10px}

/* Messages */
.messages{list-style:none;padding:0;margin:16px 0}
.msg{padding:10px 14px;border-radius:10px;margin-bottom:8px;border:1px solid var(--line)}
.msg.success{background:#10331f;border-color:#1c6b3c;color:#bdf0cf}
.msg.error{background:#3a1518;border-color:#7a2730;color:#f7c4c9}

/* Hero */
/* Full-width featured hero banner — one item at a time, auto + manual, circular.
   Sized to the source asset ratio (3840×1848) so 4K banners show with no crop or
   distortion; cover keeps non-matching fallbacks filling the frame. */
.hero-banner{position:relative;width:100%;aspect-ratio:3840/1848;overflow:hidden;
    background:var(--surface);margin-bottom:8px}
.hero-slides{position:absolute;inset:0}
.hero-slide{position:absolute;inset:0;display:block;opacity:0;visibility:hidden;
    transition:opacity .6s ease;pointer-events:none}
.hero-slide.active{opacity:1;visibility:visible;pointer-events:auto}
.hero-slide img{width:100%;height:100%;object-fit:cover;display:block}
.hero-caption{position:absolute;inset-block-end:0;inset-inline:0;
    display:flex;flex-direction:column;align-items:flex-start;gap:2px;
    padding-block:clamp(18px,4vw,52px);
    padding-inline:max(24px,calc((100% - var(--maxw))/2 + 24px));
    background:linear-gradient(to top,rgba(0,0,0,.88),rgba(0,0,0,.05) 70%)}
.hero-caption .hero-title{margin:.3rem 0;font-size:clamp(1.4rem,2.8vw,2.6rem);line-height:1.3;
    color:#fff;font-weight:800}
.hero-caption p{color:#d6dae0;margin:0;max-width:60ch;font-size:clamp(.9rem,1.3vw,1.1rem)}
.hero-caption .card-kind{position:static;display:inline-block}
.hero-badge{align-self:flex-start;background:var(--accent-2);color:#1a1206;font-weight:800;
    font-size:.72rem;padding:3px 10px;border-radius:999px;margin-bottom:6px}
/* Controls (only rendered when >1 item) */
.hero-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:3;
    width:48px;height:48px;border-radius:999px;border:0;cursor:pointer;color:#fff;
    background:rgba(0,0,0,.45);font-size:1.9rem;line-height:1;
    display:flex;align-items:center;justify-content:center;transition:background .2s}
.hero-nav:hover{background:rgba(0,0,0,.78)}
/* › next button on the right (data-dir=1, forward), ‹ prev on the left
   (data-dir=-1, back) — arrows point outward and advance in the natural sense. */
/* visual positions swapped: next(›) sits on the left, prev(‹) on the right —
   logic untouched, navigation still keys off data-dir */
.hero-nav.right{left:18px}
.hero-nav.left{right:18px}
.hero-dots{position:absolute;inset-block-end:14px;inset-inline:0;z-index:3;
    display:flex;justify-content:center;gap:8px}
.hero-dot{width:10px;height:10px;border-radius:999px;border:0;cursor:pointer;padding:0;
    background:rgba(255,255,255,.45);transition:background .2s,transform .2s}
.hero-dot.active{background:#fff;transform:scale(1.25)}

/* Blocks & grid */
.block{margin:40px 0}
.block-head{display:flex;align-items:baseline;gap:12px;margin-bottom:18px;
    border-bottom:1px solid var(--line);padding-bottom:10px}
.block-head h1,.block-head h2{margin:0;font-size:1.35rem}
.block-head h2::before{content:"";display:inline-block;width:6px;height:18px;background:var(--accent);
    border-radius:3px;margin-left:10px;vertical-align:-3px}
.block-desc{color:var(--muted)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:18px}

/* Card */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
    overflow:hidden;display:flex;flex-direction:column;transition:transform .15s,border-color .15s}
.card:hover{transform:translateY(-3px);border-color:#3a4252}
.card-media{position:relative;aspect-ratio:16/10;background:var(--surface-2);display:block}
.card-media img{width:100%;height:100%;object-fit:cover}
.card-media-empty{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.85rem}
.card-kind{position:absolute;top:10px;right:10px;font-size:.72rem;font-weight:700;
    padding:3px 9px;border-radius:999px;background:var(--accent);color:#fff}
.kind-news{background:var(--accent)}
.kind-announcement{background:#e76f51}
.kind-review{background:#2a9d8f}
.kind-editorial{background:#577590}
.kind-blog{background:var(--accent-2);color:#1a1206}
.card-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
    width:46px;height:46px;display:flex;align-items:center;justify-content:center;
    border-radius:999px;background:rgba(0,0,0,.55);color:#fff;font-size:1rem;padding-right:3px}
.card-body{padding:14px;display:flex;flex-direction:column;gap:8px;flex:1}
.card-title{margin:0;font-size:1.02rem;line-height:1.5}
.card-title a:hover{color:var(--accent)}
.card-excerpt{margin:0;color:var(--muted);font-size:.88rem}
.card-meta{margin-top:auto;display:flex;gap:12px;align-items:center;color:var(--muted);font-size:.8rem;flex-wrap:wrap}
.card-meta .star{color:var(--accent-2)}
.card-date{margin-right:auto}

/* Post detail */
.post{max-width:820px;margin:28px auto;background:var(--surface);border:1px solid var(--line);
    border-radius:var(--radius);padding:26px}
.post-head h1{margin:.4rem 0;font-size:2rem;line-height:1.4}
.post-meta{display:flex;gap:16px;color:var(--muted);font-size:.85rem;flex-wrap:wrap}
.post-meta .star{color:var(--accent-2)}
.static-page .post-body{font-size:1.02rem;line-height:2}
.static-page .post-body p{margin:0 0 14px}
.contact-list{list-style:none;padding:0;margin:0 0 16px;display:flex;flex-direction:column;gap:10px}
.contact-list li{padding:10px 14px;background:var(--surface-2);border:1px solid var(--line);border-radius:10px}
.contact-list a{color:var(--accent-2)}
.contact-icon{margin-inline-end:6px}
.post-cover{margin:20px 0;border-radius:var(--radius);overflow:hidden}
.post-video{display:block;width:100%;background:#000}
.post-lead{font-size:1.1rem;color:#cdd2da}
.post-body{margin-top:14px}
.post-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px}
.post-tags .tag{font-size:.82rem;padding:4px 11px;border-radius:999px;
    background:var(--surface-2);color:var(--muted);border:1px solid var(--line)}
.post-tags .tag:hover{color:var(--accent);border-color:var(--accent)}
.kind-news,.card-kind{letter-spacing:.2px}
.post .card-kind{position:static;display:inline-block}

/* Meta table */
.meta-table{margin:26px 0;border-top:1px solid var(--line);padding-top:18px}
.meta-table h2{font-size:1.1rem;margin:0 0 12px}
.meta-table dl{display:grid;grid-template-columns:120px 1fr;gap:8px 16px;margin:0}
.meta-table dt{color:var(--muted)}
.meta-table dd{margin:0}

/* Engagement */
.engage{margin-top:30px;border-top:1px solid var(--line);padding-top:22px}
.rate-box{margin-bottom:28px}
.rate-box h2,.comments h2{font-size:1.15rem;margin:0 0 12px}
.stars{display:inline-flex;flex-direction:row-reverse;gap:4px}
.star-btn{background:none;border:none;cursor:pointer;font-size:2rem;color:#3a4252;padding:0 2px;transition:color .12s}
.star-btn:hover,.star-btn:hover ~ .star-btn{color:var(--accent-2)}
.comment-form{display:flex;flex-direction:column;gap:10px;margin-bottom:24px;
    background:var(--surface-2);padding:16px;border-radius:12px}
.comment-form input,.comment-form textarea{width:100%;background:var(--bg);border:1px solid var(--line);
    border-radius:10px;color:var(--text);padding:10px 12px;font-family:inherit;font-size:.95rem}
.comment-form textarea{resize:vertical}
.btn{align-self:flex-start;background:var(--accent);color:#fff;border:none;border-radius:10px;
    padding:10px 20px;font-family:inherit;font-weight:700;cursor:pointer}
.btn:hover{filter:brightness(1.08)}
.form-errors{color:#f7c4c9;margin:0;padding-right:18px;font-size:.85rem}
.comment-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
.comment{background:var(--surface-2);border-radius:12px;padding:14px 16px}
.comment-author{font-weight:700}
.comment-date{color:var(--muted);font-size:.78rem;margin-bottom:6px}
.comment-text{margin:0}
.comment-empty,.comment-list .comment-empty{color:var(--muted);list-style:none}

/* Empty / footer */
.empty-state{text-align:center;padding:60px 20px;color:var(--muted)}
.empty-state code{background:var(--surface-2);padding:3px 8px;border-radius:6px;color:var(--accent-2)}
.site-footer{border-top:1px solid var(--line);margin-top:50px;padding:30px 0;color:var(--muted)}
.footer-brand{font-weight:800;color:var(--text);font-size:1.1rem}
.footer-note{margin:.4rem 0}
.footer-copy{font-size:.8rem}

/* Metadata catalogue — posters */
.block-head .more-link{margin-right:auto;color:var(--muted);font-size:.85rem}
.block-head .more-link:hover{color:var(--accent)}
.grid.posters{grid-template-columns:repeat(auto-fill,minmax(170px,1fr))}
.card-media.poster{aspect-ratio:2/3}
.card-rating{position:absolute;top:10px;right:10px;font-size:.78rem;font-weight:700;
    padding:3px 9px;border-radius:999px;background:rgba(0,0,0,.7);color:var(--accent-2)}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0}
.chip{display:inline-block;font-size:.8rem;padding:4px 12px;border-radius:999px;
    background:var(--surface-2);border:1px solid var(--line);color:var(--muted)}
.chip:hover{border-color:var(--accent);color:var(--text)}
.meta-table dd .chip{margin-left:6px}

/* Series detail hero */
.series-detail{max-width:880px}
.series-hero{display:flex;gap:22px;align-items:flex-start}
.series-poster{flex:0 0 200px;border-radius:12px;overflow:hidden;background:var(--surface-2)}
.series-poster img{width:100%;display:block}
.series-headinfo h1{margin:.2rem 0 .6rem;font-size:1.9rem}
.btn.ghost{display:inline-block;margin-top:12px;background:transparent;border:1px solid var(--accent);color:var(--accent);text-decoration:none}
.btn.ghost:hover{background:var(--accent);color:#fff}
.source-link{color:var(--muted);font-size:.9rem;margin-top:18px}
.source-link a{color:var(--accent)}

/* Embedded trailer player */
.trailer{margin:22px 0}
.trailer h2{font-size:1.1rem;margin:0 0 12px}
.trailer-player{width:100%;aspect-ratio:16/9;max-height:72vh;display:block;
    background:#000;border-radius:var(--radius);object-fit:contain}

/* Posts section — visually distinct from the metadata catalogue */
.section-posts{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
    padding:22px;margin-top:48px}
.section-posts .block-head{margin-top:0}

/* Themed infinite carousel — one row, items cycle endlessly via JS rotation */
.carousel{position:relative}
.carousel-viewport{overflow:hidden}
.carousel-track{display:flex;gap:18px;padding:2px 2px 8px;will-change:transform}
.carousel-track > .card{flex:0 0 175px;width:175px}
.carousel--wide .carousel-track > .card{flex-basis:265px;width:265px}
.carousel-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:5;
    width:40px;height:40px;border-radius:50%;border:1px solid var(--line);cursor:pointer;
    background:rgba(15,17,21,.86);color:var(--text);
    display:flex;align-items:center;justify-content:center;transition:background .15s,opacity .15s;
    box-shadow:0 4px 14px rgba(0,0,0,.4)}
.carousel-nav:hover{background:var(--accent)}
/* Chevrons drawn with borders — direction-proof in RTL (no glyph mirroring) */
.carousel-nav::before{content:'';width:9px;height:9px;
    border-top:2px solid currentColor;border-right:2px solid currentColor}
.carousel-nav.right::before{transform:rotate(45deg);margin-right:3px}
.carousel-nav.left::before{transform:rotate(-135deg);margin-left:3px}
.carousel-nav.right{right:-8px}
.carousel-nav.left{left:-8px}
.carousel.no-scroll .carousel-nav{display:none}

/* ── Tablet & below: collapse nav into the hamburger menu ── */
@media(max-width:1023px){
    .nav-toggle{display:flex}
    .header-search{order:2;flex:1 1 auto;max-width:none}
    .main-nav{display:none;order:5;position:absolute;top:100%;left:0;right:0;
        flex-direction:column;align-items:stretch;gap:0;
        background:var(--surface);border-bottom:1px solid var(--line);
        padding:6px 18px 14px;box-shadow:0 12px 24px rgba(0,0,0,.4)}
    .site-header.nav-open .main-nav{display:flex}
    .main-nav>a,.nav-dropdown-toggle{font-size:1rem;padding:12px 4px;border-bottom:1px solid var(--line)}
    .main-nav>a:last-child{border-bottom:none}
    /* Dropdown becomes an inline expanding sub-list inside the mobile panel */
    .nav-dropdown{width:100%}
    .nav-dropdown-toggle{width:100%;justify-content:space-between}
    .nav-dropdown-menu{position:static;display:none;box-shadow:none;border:0;
        max-height:none;padding:0 0 6px;background:transparent;min-width:0}
    .nav-dropdown.open .nav-dropdown-menu{display:flex}
    .nav-dropdown:hover .nav-dropdown-menu{display:none}
    .nav-dropdown.open .nav-dropdown-menu{display:flex}
    .nav-dropdown-menu a{padding:10px 14px}
}

/* ── Tablet portrait ── */
@media(max-width:820px){
    .block{margin:30px 0}
    .post{padding:20px}
    .section-posts{padding:18px}
    .meta-table dl{grid-template-columns:1fr}
    .meta-table dt{font-weight:700}
    .series-hero{flex-direction:column}
    .series-poster{flex-basis:auto;max-width:200px}
}

/* ── Phones ── */
@media(max-width:560px){
    .container{padding:0 14px}
    /* Keep the source ratio (no crop) — just shrink the controls on phones */
    .hero-nav{width:38px;height:38px;font-size:1.4rem}
    .hero-nav.left{right:8px}
    .hero-nav.right{left:8px}
    .post-head h1{font-size:1.5rem}
    .series-headinfo h1{font-size:1.5rem}
    .post{padding:16px}
    .block{margin:26px 0}
    .block-head h1,.block-head h2{font-size:1.15rem}
    .grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}
    .grid.posters{grid-template-columns:repeat(auto-fill,minmax(118px,1fr));gap:12px}
    /* Carousels stay usable on touch: smaller arrows + native swipe (JS) */
    .carousel-track{gap:12px}
    .carousel-track > .card{flex-basis:142px;width:142px}
    .carousel--wide .carousel-track > .card{flex-basis:210px;width:210px}
    .carousel-nav{width:34px;height:34px;background:rgba(15,17,21,.7)}
    .carousel-nav.right{right:-4px}
    .carousel-nav.left{left:-4px}
}

/* ── SEO/a11y helpers & added components ─────────────────────────────── */
/* Visually-hidden but available to screen readers & crawlers (e.g. the
   homepage H1, which is conveyed visually by the hero). */
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;
    overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* Breadcrumbs */
.breadcrumbs{margin:14px 0 4px;font-size:.85rem;color:var(--muted)}
.breadcrumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:6px;padding:0;margin:0}
.breadcrumbs li{display:flex;align-items:center;gap:6px}
.breadcrumbs li+li::before{content:'‹';color:var(--line)}
.breadcrumbs a{color:var(--muted)}
.breadcrumbs a:hover{color:var(--text)}
.breadcrumbs li[aria-current="page"]{color:var(--text)}

/* Pagination */
.pagination{display:flex;align-items:center;justify-content:center;gap:14px;margin:28px 0 6px}
.page-link{padding:8px 16px;border:1px solid var(--line);border-radius:999px;
    background:var(--surface-2);color:var(--text);font-size:.9rem}
.page-link:hover{border-color:var(--accent);color:var(--text)}
.page-link.disabled{opacity:.4;pointer-events:none}
.page-status{color:var(--muted);font-size:.9rem}
