/*
Theme Name: Cinemahouse Child
Theme URI: https://cinemahouse.fi
Description: Cinemahouse child theme for GeneratePress
Author: Cinemahouse
Template: generatepress
Version: 0.3.55
*/

@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@300;400;600&family=Source+Sans+3:wght@300;400;600&display=swap');

:root{
  --ch-red:#e31922;
  --ch-red-dark:#a70f16;
  --ch-black:#0b0b0d;
  --ch-ink:#111319;
  --ch-panel:#141821;
  --ch-panel-2:#181d27;
  --ch-border:#242b38;
  --ch-text:#eef1f6;
  --ch-muted:#a7b0bf;
  --ch-accent:#ff2b35;
  --ch-gold:#f2b233;
  --ch-glow:0 18px 40px rgba(0,0,0,.45);
}

/* Base typography */
body{
  font-family:'Source Sans 3', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  background: radial-gradient(1200px 600px at 15% -10%, rgba(227,25,34,.18), transparent 60%),
              radial-gradient(900px 520px at 90% 5%, rgba(255,43,53,.12), transparent 60%),
              var(--ch-black);
  color:var(--ch-text);
}

h1,h2,h3,h4,h5,h6{
  font-family:'Oswald', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  letter-spacing:.02em;
  color:#fff;
}

a{ color:var(--ch-accent); }

a:hover{ color:#fff; }

/* Layout + containers */
.separate-containers .inside-article,
.separate-containers .comments-area,
.separate-containers .page-header,
.one-container .container,
.separate-containers .paging-navigation,
.inside-page-header{
  background:transparent;
}

.inside-article,
.inside-page-header{
  padding:28px;
}

/* Cards */
.cr-card,
.entry-content .wp-block-group{
  background:linear-gradient(180deg, var(--ch-panel), var(--ch-panel-2));
  border:1px solid var(--ch-border);
  border-radius:18px;
  box-shadow:var(--ch-glow);
}

/* Buttons */
button,
html input[type="button"],
input[type="reset"],
input[type="submit"],
a.button,
.wp-block-button__link{
  background:var(--ch-red);
  border:none;
  color:#fff;
  font-weight:600;
  border-radius:999px;
  padding:.7rem 1.2rem;
}

button:hover,
html input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover,
a.button:hover,
.wp-block-button__link:hover{
  background:var(--ch-gold);
  color:#1a1304;
}

/* Header */
.site-header{
  background:linear-gradient(90deg, rgba(227,25,34,.28), rgba(0,0,0,.9) 55%), var(--ch-ink);
  border-bottom:1px solid var(--ch-border);
  backdrop-filter:saturate(120%) blur(6px);
  position:sticky;
  top:0;
  z-index:999;
}

.site-header .inside-header{
  max-width:1600px;
  margin:0 auto;
}

.main-title a,
.main-title a:hover{ color:#fff; }

.site-description{ color:var(--ch-muted); }

.site-branding{
  display:flex;
  align-items:center;
  gap:14px;
}

.site-branding .site-logo img{
  max-height:64px;
  width:auto;
  filter:drop-shadow(0 6px 14px rgba(0,0,0,.45));
}

.main-title{
  font-size:30px;
  letter-spacing:.18em;
  text-transform:uppercase;
  position:relative;
  padding-left:14px;
}

.main-title a{
  color:#fff;
  text-shadow:0 6px 18px rgba(0,0,0,.55);
}

.main-title a::first-letter{
  color:var(--ch-red);
}

.main-title::before{
  content:'';
  position:absolute;
  left:0;
  top:50%;
  transform:translateY(-50%);
  width:6px;
  height:26px;
  border-radius:6px;
  background:var(--ch-red);
  box-shadow:0 0 16px rgba(227,25,34,.6);
}

/* Navigation */
.main-navigation,
.main-navigation ul ul{
  background:transparent;
}

.main-navigation .main-nav ul li a,
.main-navigation .menu-toggle,
.main-navigation .menu-bar-items{
  color:#fff;
  font-weight:600;
  letter-spacing:.04em;
  text-transform:uppercase;
  font-size:14px;
}

.main-navigation .main-nav ul li:not([class*="current-menu-"]):hover > a,
.main-navigation .main-nav ul li:not([class*="current-menu-"]):focus > a,
.main-navigation .main-nav ul li.sfHover:not([class*="current-menu-"]) > a,
.main-navigation .menu-bar-item:hover > a,
.main-navigation .menu-bar-item.sfHover > a{
  color:var(--ch-accent);
}

.main-navigation .main-nav ul li a{
  padding:12px 18px;
  border-radius:10px;
  background:rgba(255,255,255,.02);
  border:1px solid rgba(255,255,255,.06);
}

.main-navigation .main-nav ul li.current-menu-item > a,
.main-navigation .main-nav ul li.current-menu-ancestor > a{
  background:rgba(227,25,34,.25);
  color:#fff;
  box-shadow:0 8px 20px rgba(0,0,0,.35);
}

.main-navigation .main-nav ul{
  gap:8px;
}

.main-navigation{
  margin-left:auto;
}

.main-navigation .inside-navigation{
  display:flex;
  justify-content:flex-end;
}

.main-navigation .main-nav{
  background:rgba(8,10,15,.6);
  border:1px solid rgba(255,255,255,.08);
  padding:6px 10px;
  border-radius:12px;
  box-shadow:0 10px 26px rgba(0,0,0,.35);
}

.menu-toggle{
  background:rgba(227,25,34,.18);
  border:1px solid rgba(255,255,255,.08);
  border-radius:12px;
}

.menu-toggle:hover{
  background:rgba(227,25,34,.32);
}

.inside-header{
  padding:22px 36px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  row-gap:10px;
}

/* Header info strip */
.ch-header-meta{
  width:100%;
  order:3;
  background:linear-gradient(90deg, rgba(0,0,0,.45), rgba(20,25,34,.32));
  border:1px solid rgba(255,255,255,.08);
  border-radius:12px;
}

.ch-header-meta__inner{
  max-width:none;
  margin:0;
  padding:7px 10px;
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}

.ch-meta-pill{
  display:inline-flex;
  align-items:center;
  gap:7px;
  text-decoration:none;
  color:#eef1f6;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.03);
  border-radius:10px;
  padding:7px 11px;
  font-size:13px;
  line-height:1;
}

.ch-meta-pill__icon{
  opacity:.92;
  width:15px;
  height:15px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}

.ch-meta-pill__icon svg{
  width:15px;
  height:15px;
  display:block;
  fill:currentColor;
}

.ch-meta-pill--cta{
  border-color:rgba(227,25,34,.45);
  background:linear-gradient(180deg, rgba(227,25,34,.30), rgba(167,15,22,.30));
  font-weight:700;
}

.ch-meta-pill:hover{
  color:#fff;
  border-color:rgba(255,255,255,.26);
}

@media (max-width: 900px){
  .main-title{ font-size:22px; letter-spacing:.12em; }
  .site-branding .site-logo img{ max-height:44px; }
}

@media (max-width: 600px){
  .inside-header{ padding:6px 12px; }
  .site-branding .site-logo img{ max-height:26px; }
  .main-title{ font-size:15px; letter-spacing:.06em; }
  .ch-header-meta__inner{ padding:7px 10px; gap:7px; }
  .ch-meta-pill{ font-size:12px; padding:6px 9px; }
}

/* Mobile nav buttons tighter */
@media (max-width: 900px){
  .main-navigation .main-nav ul li a{
    padding:8px 12px;
    font-size:12px;
  }
  .main-navigation .main-nav{
    padding:4px 8px;
  }
}

@media (max-width: 600px){
  .menu-toggle{
    padding:6px 8px;
    font-size:16px;
  }
  .menu-toggle .gp-icon svg{
    width:18px;
    height:18px;
  }
}

/* Footer (GeneratePress child override) */
.ch-site-footer{
  margin-top:52px;
  position:relative;
  border-top:1px solid rgba(255,255,255,.10);
  border-bottom:1px solid rgba(255,255,255,.14);
  background:
    radial-gradient(900px 280px at 50% -120px, rgba(227,25,34,.22), transparent 68%),
    linear-gradient(180deg, rgba(8,10,15,.90), rgba(6,8,12,.96));
}

.ch-site-footer::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(242,178,51,.6), transparent);
}

.ch-site-footer__inner{
  max-width:1600px;
  margin:0 auto;
  padding:34px 32px 30px;
}

.ch-site-footer__brandrow{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  padding-bottom:16px;
  margin-bottom:20px;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.ch-site-footer__brand .custom-logo-link img{
  max-height:40px;
  width:auto;
  filter:drop-shadow(0 6px 14px rgba(0,0,0,.45));
}

.ch-site-footer__brandname{
  font-family:'Oswald', system-ui, sans-serif;
  color:#fff;
  font-size:24px;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.ch-site-footer__contact{
  display:flex;
  align-items:center;
  gap:10px;
  color:rgba(238,241,246,.8);
  font-size:14px;
}

.ch-site-footer__contact a{
  color:rgba(238,241,246,.85);
  text-decoration:none;
}

.ch-site-footer__contact a:hover{
  color:#fff;
}

.ch-site-footer__grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:40px;
}

.ch-site-footer__col h3{
  margin:0 0 12px;
  color:var(--ch-gold);
  font-size:38px;
  line-height:1.06;
}

.ch-site-footer__links{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:10px;
}

.ch-site-footer__links a{
  color:rgba(238,241,246,.86);
  text-decoration:none;
  font-size:30px;
  line-height:1.2;
  display:inline-block;
  transition:transform .18s ease, color .18s ease;
}

.ch-site-footer__links a:hover{
  color:#fff;
  transform:translateX(4px);
}

.ch-site-footer__legal{
  margin-top:24px;
  padding-top:14px;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  align-items:center;
  justify-content:space-between;
}

.ch-site-footer__legaltext{
  color:rgba(238,241,246,.72);
  font-size:13px;
}

.ch-site-footer__legallinks{
  display:flex;
  align-items:center;
  gap:8px;
}

.ch-site-footer__legallinks a{
  color:rgba(238,241,246,.78);
  font-size:13px;
  text-decoration:none;
}

.ch-site-footer__legallinks a:hover{
  color:#fff;
}

@media (max-width: 1100px){
  .ch-site-footer__grid{ grid-template-columns:repeat(2,minmax(0,1fr)); gap:28px; }
  .ch-site-footer__col h3{ font-size:36px; }
  .ch-site-footer__links a{ font-size:28px; }
}

@media (max-width: 680px){
  .ch-site-footer__inner{ padding:26px 16px 20px; }
  .ch-site-footer__brandrow{ margin-bottom:14px; padding-bottom:12px; }
  .ch-site-footer__brand .custom-logo-link img{ max-height:28px; }
  .ch-site-footer__contact{ flex-wrap:wrap; gap:6px; font-size:12px; }
  .ch-site-footer__grid{ grid-template-columns:repeat(2,minmax(0,1fr)); gap:18px 14px; }
  .ch-site-footer__col h3{ font-size:26px; margin-bottom:8px; }
  .ch-site-footer__links{ gap:6px; }
  .ch-site-footer__links a{ font-size:19px; line-height:1.15; }
  .ch-site-footer__legal{ flex-direction:column; align-items:flex-start; gap:8px; }
}

@media (max-width: 460px){
  .ch-site-footer__brand{ display:none; }
  .ch-site-footer__brandrow{ justify-content:flex-start; }
  .ch-site-footer__contact{ font-size:11px; }
  .ch-site-footer__grid{ grid-template-columns:1fr; gap:14px; }
  .ch-site-footer__col h3{ font-size:22px; margin-bottom:6px; }
  .ch-site-footer__links a{ font-size:17px; }
}

/* === Mobile main menu compact hotfix (v0.3.54) === */
@media (max-width: 900px){
  .site-header .inside-header{
    position:relative !important;
    min-height:68px !important;
    height:auto !important;
    grid-template-columns:1fr auto !important;
    grid-template-areas:"brand nav" !important;
    align-items:center !important;
    overflow:visible !important;
  }

  .site-branding{
    max-width:70vw !important;
  }

  .main-navigation{
    position:relative !important;
    width:auto !important;
    margin-left:0 !important;
    align-self:center !important;
  }

  .main-navigation .inside-navigation{
    position:relative !important;
    overflow:visible !important;
  }

  /* Keep closed state compact */
  .main-navigation:not(.toggled) .main-nav{
    max-height:0 !important;
    overflow:hidden !important;
  }

  /* Open state as dropdown panel (not giant header block) */
  .main-navigation.toggled .main-nav{
    position:absolute !important;
    top:calc(100% + 8px) !important;
    right:0 !important;
    left:auto !important;
    width:min(88vw, 320px) !important;
    max-height:70vh !important;
    overflow:auto !important;
    background:linear-gradient(180deg, rgba(8,10,14,.98), rgba(10,12,18,.98)) !important;
    border:1px solid rgba(255,255,255,.12) !important;
    border-radius:14px !important;
    box-shadow:0 16px 38px rgba(0,0,0,.55) !important;
    padding:48px 10px 10px !important;
    z-index:9999 !important;
  }

  .main-navigation.toggled .main-nav ul{
    display:block !important;
    margin:0 !important;
    padding:0 !important;
  }

  .main-navigation.toggled .main-nav ul li{
    margin:0 !important;
  }

  .main-navigation.toggled .main-nav ul li a{
    display:block !important;
    padding:11px 10px !important;
    font-size:15px !important;
    border-radius:10px !important;
    border:none !important;
    background:transparent !important;
  }

  /* Close icon placement: top-right of dropdown, never over links */
  .main-navigation .menu-toggle{
    position:relative !important;
    z-index:10000 !important;
  }

  .main-navigation.toggled .menu-toggle{
    position:absolute !important;
    top:10px !important;
    right:10px !important;
    margin:0 !important;
    width:34px !important;
    height:34px !important;
    padding:0 !important;
    border-radius:10px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    background:rgba(255,255,255,.06) !important;
    border:1px solid rgba(255,255,255,.18) !important;
  }
}

/* Remove gap between header and hero on mobile */
@media (max-width: 700px){
  .home .ch-hero-slider{ margin-top:0; }
  .home .inside-article{ padding-top:0; }
}

/* Movie grid (Reservations plugin) */
.cr-movies-grid{
  gap:18px;
}

.cr-movie-tile{
  border-radius:18px;
  border:1px solid rgba(255,255,255,.06);
  overflow:hidden;
  background:linear-gradient(180deg, #1b0c0f, #0c0c0f 60%);
  box-shadow:var(--ch-glow);
}

.cr-movie-tile__poster{
  background:#0b0b0d;
}

.cr-movie-tile__overlay{
  background:linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.75) 65%);
}

.cr-movie-tile__title{
  font-family:'Oswald', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  letter-spacing:.03em;
}

/* Hero section helper */
.ch-hero{
  background:linear-gradient(110deg, rgba(227,25,34,.3), rgba(0,0,0,.7) 55%),
             radial-gradient(800px 420px at 90% -10%, rgba(255,43,53,.2), transparent 60%),
             var(--ch-panel);
  border:1px solid var(--ch-border);
  border-radius:22px;
  padding:36px;
}

.ch-hero .wp-block-heading{
  font-size:42px;
  line-height:1.05;
}

/* Footer */
.site-info{
  background:var(--ch-ink);
  color:var(--ch-muted);
  border-top:1px solid var(--ch-border);
}

/* Forms */
input[type="text"], input[type="email"], input[type="url"], input[type="password"],
input[type="search"], input[type="tel"], input[type="number"], textarea, select{
  background:#0d1119;
  color:#fff;
  border:1px solid var(--ch-border);
  border-radius:10px;
}

input[type="text"]:focus, input[type="email"]:focus, input[type="url"]:focus,
input[type="password"]:focus, input[type="search"]:focus, input[type="tel"]:focus,
input[type="number"]:focus, textarea:focus, select:focus{
  border-color:var(--ch-accent);
}

/* Hero slider */
.ch-hero-slider{
  position:relative;
  margin:0 auto 28px auto;
  border-radius:22px;
  overflow:hidden;
  border:1px solid var(--ch-border);
  box-shadow:var(--ch-glow);
}

.ch-hero-track{
  position:relative;
  height:80vh;
  min-height:560px;
  max-height:980px;
}

.ch-slide{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center center;
  opacity:0;
  transform:scale(1.02);
  transition:opacity .6s ease, transform 1.2s ease;
  animation: ch-kenburns 12s ease-in-out infinite;
}

.ch-slide.is-active{
  opacity:1;
  transform:scale(1);
  z-index:2;
}

@keyframes ch-kenburns{
  0%{ transform: scale(1.02); }
  50%{ transform: scale(1.06); }
  100%{ transform: scale(1.02); }
}

.ch-slide__overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(0,0,0,.75), rgba(0,0,0,.25) 55%, rgba(0,0,0,0) 100%);
}

.ch-slide__content{
  position:absolute;
  left:6%;
  bottom:14%;
  max-width:620px;
  z-index:3;
}

.ch-slide__content h2{
  font-size:52px;
  margin:0 0 8px 0;
}

.ch-slide__content p{
  color:var(--ch-muted);
  font-size:22px;
  line-height:1.5;
  margin:0 0 16px 0;
}

.ch-slide__btn{
  display:inline-block;
  background:var(--ch-red);
  color:#fff;
  padding:.7rem 1.2rem;
  border-radius:999px;
  text-decoration:none;
  font-weight:600;
}

.ch-slide__btn:hover{ background:var(--ch-gold); color:#1a1304; }

.ch-hero-dots{
  position:absolute;
  right:18px;
  bottom:16px;
  display:flex;
  gap:8px;
  z-index:4;
}

.ch-hero-dot{
  width:10px;
  height:10px;
  border-radius:50%;
  background:rgba(255,255,255,.35);
  border:none;
  cursor:pointer;
  flex: 0 0 10px;
  aspect-ratio: 1 / 1;
}

.ch-hero-dot.is-active{ background:var(--ch-gold); }

@media (max-width: 900px){
  .ch-hero-track{ height:60vh; min-height:380px; }
  .ch-slide__content{ left:5%; right:5%; bottom:10%; max-width:none; }
  .ch-slide__content h2{ font-size:40px; }
  .ch-slide__content p{ font-size:18px; }
  .ch-slide__overlay{ background:linear-gradient(0deg, rgba(0,0,0,.8), rgba(0,0,0,.25) 60%, rgba(0,0,0,0) 100%); }
}

@media (max-width: 600px){
  .ch-hero-track{ height:66vh; min-height:400px; }
  .ch-slide__content h2{ font-size:32px; }
  .ch-slide__content p{ font-size:16px; }
}

/* Wider layout on home page */
.home .inside-article,
.home .entry-content{
  max-width:1600px;
  margin-left:auto;
  margin-right:auto;
}

/* Full-bleed hero on home */
.home .ch-hero-slider{
  width:100vw;
  max-width:none;
  margin-top:0 !important;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  border-radius:0;
  border:none;
  box-shadow:none;
  position:relative;
  overflow:visible;
}

/* Soften top and bottom edges (no hard rectangle cut) */
.home .ch-hero-track{
  -webkit-mask-image: linear-gradient(to bottom, transparent 0%, #000 8%, #000 90%, transparent 100%);
  mask-image: linear-gradient(to bottom, transparent 0%, #000 8%, #000 90%, transparent 100%);
}

.home .ch-hero-slider::before,
.home .ch-hero-slider::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  height:90px;
  pointer-events:none;
  z-index:5;
}

.home .ch-hero-slider::before{
  top:0;
  background:linear-gradient(to bottom, rgba(11,11,13,.95), rgba(11,11,13,0));
}

.home .ch-hero-slider::after{
  bottom:0;
  background:linear-gradient(to top, rgba(11,11,13,.97), rgba(11,11,13,0));
}

/* Remove gap between header and hero */
.home .site-main,
.home .inside-article,
.home .entry-content{
  margin-top:0 !important;
  padding-top:0 !important;
}

/* Wider movie grid */
.home .cr-movies-grid{
  width:100vw;
  max-width:none;
  margin-left:calc(50% - 50vw + 22px);
  margin-right:calc(50% - 50vw + 22px);
  padding-left:0;
  padding-right:0;
  box-sizing:border-box;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:16px;
}

@media (max-width: 1400px){
  .home .cr-movies-grid{ grid-template-columns:repeat(4,minmax(0,1fr)); }
}

@media (max-width: 1050px){
  .home .cr-movies-grid{ grid-template-columns:repeat(3,minmax(0,1fr)); }
}

@media (max-width: 760px){
  .home .cr-movies-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    margin-left:0;
    margin-right:0;
    padding-left:8px;
    padding-right:8px;
    gap:10px;
  }
}

@media (max-width: 700px){
  .home .inside-article,
  .home .entry-content,
  .home .cr-movies-grid{
    max-width:100%;
    margin-left:0;
    margin-right:0;
    padding-left:2px;
    padding-right:2px;
  }
}

@media (max-width: 700px){
  .cr-movies-grid{
    gap:8px;
  }
  .cr-movie-tile{
    border-radius:12px;
  }
}

@media (max-width: 700px){
  .home .inside-article{
    padding:8px 2px 14px;
  }
  .kassa-app--movies{
    padding-left:2px;
    padding-right:2px;
  }
}

@media (max-width: 700px){
  body.home .site-main,
  body.home .content-area,
  body.home .inside-article,
  body.home .entry-content{
    padding-left:0 !important;
    padding-right:0 !important;
  }
  body.home .cr-movies-grid{
    padding-left:2px;
    padding-right:2px;
  }
}

@media (max-width: 700px){
  body.home .grid-container,
  body.home .site-content,
  body.home .inside-article,
  body.home .entry-content{
    padding-left:0 !important;
    padding-right:0 !important;
    max-width:100% !important;
  }
  body.home .cr-movies-grid{
    margin-left:-10px;
    margin-right:-10px;
    padding-left:10px;
    padding-right:10px;
  }
}

/* Smaller CTA button on mobile (single line) */
@media (max-width: 700px){
  .cr-movie-tile__cta{
    font-size:11px !important;
    letter-spacing:.4px !important;
    padding:8px 10px !important;
    min-height:32px !important;
    white-space:nowrap;
  }
}

/* Version badge for debugging */
.ch-version-badge{
  position:fixed;
  right:12px;
  bottom:12px;
  background:rgba(0,0,0,.7);
  border:1px solid rgba(255,255,255,.15);
  color:#fff;
  padding:6px 10px;
  font-size:12px;
  border-radius:10px;
  z-index:9999;
}

/* --- Cinema Reservations UI overrides (theme) --- */
.kassa-app--movies .kassa-page-title{ display:none !important; }

.cr-movies-filter-label{
  font-family:'Oswald', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  font-size:11px;
  letter-spacing:.12em;
  color: rgba(255,255,255,0.7);
  text-transform: uppercase;
}

.cr-movies-filter-select{
  font-family:'Oswald', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  font-size:12px;
  letter-spacing:.08em;
}

/* Single movie page alignment */
.single-cr_movie .inside-article,
.single-cr_movie .entry-content{
  max-width:1200px;
  margin-left:auto;
  margin-right:auto;
}

/* Force centered single movie layout (avoid theme/sidebar offsets) */
.single-cr_movie .site-content{
  max-width: 1440px;
  margin-left: auto;
  margin-right: auto;
}

.single-cr_movie .content-area{
  float: none !important;
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.single-cr_movie #left-sidebar,
.single-cr_movie #right-sidebar,
.single-cr_movie .is-left-sidebar,
.single-cr_movie .is-right-sidebar{
  display: none !important;
}

@media (max-width: 700px){
  .single-cr_movie .grid-container,
  .single-cr_movie .site-content,
  .single-cr_movie .content-area,
  .single-cr_movie .inside-article,
  .single-cr_movie .entry-content,
  .single-cr_movie .kassa-app--single-movie{
    max-width: 100% !important;
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}

@media (max-width:700px){
  .cr-movies-filter-label{ font-size:10px; }
  .cr-movies-filter-select{ font-size:11px; }
}

/* Emphasize filter label + toolbar */
.cr-movies-toolbar{
  padding: 10px 12px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.03);
}

.cr-movies-filter-label{
  font-size: 12px;
  letter-spacing: .14em;
  color: rgba(255,255,255,0.8);
}

@media (max-width:700px){
  .cr-movies-filter-label{ font-size: 11px; }
}

/* Toolbar emphasis + label */
.cr-movies-toolbar{
  padding: 12px 14px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.04);
}

.cr-movies-filter-label{
  font-size: 11px;
  letter-spacing: .14em;
  color: rgba(255,255,255,0.7);
  padding: 0 2px 4px;
  background: transparent;
  border: none;
  box-shadow: none;
}

@media (max-width:700px){
  .cr-movies-filter-label{ font-size: 10px; letter-spacing:.12em; }
}

/* Badges + CTA gold accent */
.cr-badge--age,
.cr-badge--runtime{
  border-color: var(--ch-gold) !important;
  color: #fff !important;
}

.cr-screening-cta{
  border-color: var(--ch-gold) !important;
  background: rgba(242,178,51,0.18) !important;
}

.cr-screening-cta:hover{
  background: var(--ch-gold) !important;
  color: #1a1304 !important;
}

/* Campaign cards on front page */
.ch-promos{
  margin:18px 0 30px;
  overflow:hidden;
}

.ch-promos__inner{
  max-width:1880px;
  margin:0 auto;
  padding:0 clamp(10px,1.8vw,28px);
}

.ch-promos__title{
  margin:0 0 10px;
  font-size:30px;
  letter-spacing:.03em;
}

.ch-promos__grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}

.ch-promo-card{
  position:relative;
  width:100%;
  max-width:100%;
  height:clamp(230px, 18vw, 320px);
  min-height:230px;
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(900px 320px at 10% -20%, rgba(227,25,34,.28), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(0,0,0,.30)),
    #12161f;
  background-size:cover;
  background-position:center;
  box-shadow:none;
}

.ch-promo-card__overlay{
  display:none;
}

.ch-promo-card__content{
  position:relative;
  z-index:2;
  padding:14px;
}

.ch-promo-card__badge{
  display:inline-block;
  margin-bottom:8px;
  font-size:12px;
  font-weight:800;
  letter-spacing:.06em;
  padding:4px 8px;
  border-radius:999px;
  color:#fff;
  background:rgba(227,25,34,.85);
}

.ch-promo-card h3{
  margin:0 0 6px;
  font-size:24px;
  line-height:1.05;
}

.ch-promo-card p{
  margin:0 0 8px;
  color:var(--ch-muted);
  font-size:16px;
  line-height:1.35;
}

.ch-promo-card__dates{
  margin-bottom:10px;
  font-size:13px;
  color:#d8dde7;
}

.ch-promo-card__cta{
  display:inline-block;
  text-decoration:none;
  font-weight:700;
  color:#fff;
  border:1px solid rgba(255,255,255,.25);
  border-radius:9px;
  padding:6px 10px;
  background:rgba(0,0,0,.24);
}

.ch-promo-card__cta:hover{
  border-color:rgba(227,25,34,.7);
  background:rgba(227,25,34,.20);
}

@media (max-width: 1200px){
  .ch-promos__grid{ grid-template-columns:repeat(2,minmax(0,1fr)); }
}

@media (max-width: 700px){
  .ch-promos__grid{
    display:flex;
    gap:12px;
    overflow-x:auto;
    overflow-y:hidden;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    padding-bottom:4px;
  }
  .ch-promo-card{
    flex:0 0 min(92vw, 520px);
    scroll-snap-align:start;
  }
  .ch-promos__title{ font-size:24px; }
}

.ch-promos__dots{
  display:none;
  justify-content:center;
  align-items:center;
  gap:8px;
  margin:10px 0 0;
}

.ch-promos__dot{
  width:5px;
  height:5px;
  border-radius:50%;
  border:none;
  background:rgba(255,255,255,.42);
  cursor:pointer;
}

.ch-promos__dot.is-active{
  width:6px;
  height:6px;
  background:rgba(255,255,255,.82);
}

@media (max-width: 700px){
  .ch-promos__dots{
    display:flex;
    position:relative;
    z-index:4;
    margin-top:-24px;
    margin-bottom:6px;
    gap:5px;
    padding:4px 8px;
    width:max-content;
    margin-left:auto;
    margin-right:auto;
    border-radius:999px;
    background:rgba(0,0,0,.26);
    backdrop-filter:blur(3px);
  }
}

/* === Header v4: single-row desktop (v0.3.23) === */
.site-header .inside-header{
  padding:4px 18px;
  display:grid;
  grid-template-columns:auto auto 1fr;
  grid-template-areas:"brand nav meta";
  align-items:center;
  column-gap:10px;
}

.site-branding{ grid-area:brand; }
.main-navigation{
  grid-area:nav;
  justify-self:start;
  margin-left:0;
}
.ch-header-meta{
  grid-area:meta;
  justify-self:end;
}

.main-navigation .main-nav{
  background:transparent;
  border:none;
  box-shadow:none;
  padding:0;
}

.main-navigation .main-nav ul{
  gap:4px;
}

.main-navigation .main-nav ul li a{
  background:transparent;
  border:none;
  border-radius:0;
  padding:6px 10px 8px;
  position:relative;
}

.main-navigation .main-nav ul li a:hover{
  color:#fff;
}

.main-navigation .main-nav ul li.current-menu-item > a,
.main-navigation .main-nav ul li.current-menu-ancestor > a{
  background:transparent;
  box-shadow:none;
  color:#fff;
}

.main-navigation .main-nav ul li.current-menu-item > a::after,
.main-navigation .main-nav ul li.current-menu-ancestor > a::after{
  content:"";
  position:absolute;
  left:8px;
  right:8px;
  bottom:1px;
  height:2px;
  border-radius:2px;
  background:var(--ch-red);
}

.ch-header-meta{
  background:transparent;
  border:none;
  border-radius:0;
}

.ch-header-meta__inner{
  padding:0;
  gap:8px;
  flex-wrap:nowrap;
}

.ch-meta-pill{
  background:transparent;
  border:none;
  border-radius:0;
  padding:0 2px;
  font-size:11px;
  color:rgba(242,244,247,.92);
  letter-spacing:.01em;
  white-space:nowrap;
}

.ch-meta-pill--cta{
  color:#fff;
  font-weight:700;
}

.ch-meta-pill + .ch-meta-pill{
  position:relative;
  margin-left:8px;
  padding-left:11px;
}

.ch-meta-pill + .ch-meta-pill::before{
  content:"";
  position:absolute;
  left:0;
  top:50%;
  transform:translateY(-50%);
  width:3px;
  height:3px;
  border-radius:50%;
  background:rgba(255,255,255,.45);
}

/* Remove extra movie heading before grid */
.kassa-app--movies > h1,
.kassa-app--movies > h2,
.kassa-app--movies .kassa-page-title{
  display:none !important;
}

/* Hide theme entry titles globally (all pages/views) */
.entry-header{
  display:none !important;
}

/* Flatten movie filter bar (no heavy container box) */
.cr-movies-filters,
.cr-movies-toolbar{
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
  border-radius:0 !important;
  padding:0 !important;
}

.cr-movies-toolbar{
  display:flex;
  align-items:center;
  gap:10px;
  margin:0 0 12px 0;
}

.cr-movies-filter-label{
  font-size:10px;
  letter-spacing:.16em;
  color:rgba(255,255,255,.62);
  padding:0;
}

@media (max-width: 900px){
  .site-header .inside-header{
    padding:6px 10px;
    row-gap:5px;
    grid-template-columns:1fr;
    grid-template-areas:
      "brand"
      "nav"
      "meta";
  }
  .main-navigation{ justify-self:start; }
  .ch-header-meta{
    display:none !important;
    justify-self:start;
  }
  .ch-header-meta__inner{ flex-wrap:wrap; }
  .main-navigation .main-nav ul li a{
    padding:7px 8px;
    font-size:12px;
  }
  .ch-meta-pill{
    padding:0 1px;
    font-size:12px;
  }
}

/* Movies grid: max 6 posters/row with safer side margins */
.home .cr-movies-grid{
  width:auto !important;
  max-width:1880px !important;
  margin-left:auto !important;
  margin-right:auto !important;
  padding-left:clamp(10px,1.8vw,28px) !important;
  padding-right:clamp(10px,1.8vw,28px) !important;
  box-sizing:border-box;
  grid-template-columns:repeat(6,minmax(0,1fr)) !important;
  gap:16px;
}

/* Align filter row with first movie card */
.home .cr-movies-filters,
.home .cr-movies-toolbar{
  width:auto !important;
  max-width:1880px !important;
  margin-left:auto !important;
  margin-right:auto !important;
  padding-left:clamp(10px,1.8vw,28px) !important;
  padding-right:clamp(10px,1.8vw,28px) !important;
  box-sizing:border-box;
}

.ch-movies-heading-wrap{
  width:auto;
  max-width:1880px;
  margin:0 auto 8px;
  padding-top:8px;
  padding-left:clamp(10px,1.8vw,28px);
  padding-right:clamp(10px,1.8vw,28px);
  box-sizing:border-box;
  border-top:none;
}

.ch-movies-heading{
  margin:0;
  font-size:30px;
  letter-spacing:.03em;
  line-height:1;
}

.home .cr-movies-toolbar{
  margin:0 0 22px 0 !important;
}

@media (max-width: 1640px){
  .home .cr-movies-grid{ grid-template-columns:repeat(5,minmax(0,1fr)) !important; }
}

@media (max-width: 1280px){
  .home .cr-movies-grid{ grid-template-columns:repeat(4,minmax(0,1fr)) !important; }
}

@media (max-width: 980px){
  .home .cr-movies-grid{ grid-template-columns:repeat(3,minmax(0,1fr)) !important; }
}

@media (max-width: 700px){
  .home .cr-movies-filters,
  .home .cr-movies-toolbar{
    display:flex;
    flex-wrap:nowrap !important;
    align-items:center;
    gap:8px;
    overflow-x:auto;
    overflow-y:hidden;
    white-space:nowrap;
    -webkit-overflow-scrolling:touch;
  }
  .home .cr-movies-toolbar{
    margin:0 0 14px 0 !important;
  }
  .home .cr-movies-grid{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    padding-left:10px !important;
    padding-right:10px !important;
    gap:10px;
  }
}

/* === Header + filters spacing polish (v0.3.37) === */
.site-header .inside-header{
  column-gap:18px;
}

.main-navigation{
  margin-left:30px;
}

.ch-header-meta{
  margin-left:34px;
}

/* Desktop/tablet: keep buttons + select on same visual row */
.home .cr-movies-filters,
.home .cr-movies-toolbar{
  display:inline-flex !important;
  vertical-align:middle;
  width:auto !important;
  max-width:none !important;
}

.home .cr-movies-toolbar{
  margin:0 0 22px 10px !important;
}

.home .cr-movies-toolbar select{
  width:220px !important;
  min-width:220px !important;
  max-width:220px !important;
  flex:0 0 220px;
}

@media (max-width: 700px){
  .site-header .inside-header{
    column-gap:6px;
  }

  .home .cr-movies-filters,
  .home .cr-movies-toolbar{
    display:inline-flex !important;
    margin:0 0 12px 0 !important;
    gap:8px;
  }

  .home .cr-movies-toolbar select{
    width:140px !important;
    min-width:140px !important;
    max-width:140px !important;
    flex:0 0 140px;
  }
}

/* === Header + filters alignment cleanup (v0.3.36) === */
.site-header .inside-header{
  grid-template-columns:auto auto 1fr;
  column-gap:14px;
}

.main-navigation{
  justify-self:start;
  margin-left:14px;
}

.ch-header-meta{
  margin-left:22px;
}

.home .cr-movies-filters,
.home .cr-movies-toolbar{
  display:flex;
  flex-wrap:nowrap !important;
  align-items:center;
  justify-content:flex-start;
  gap:10px;
}

.home .cr-movies-filters > *,
.home .cr-movies-toolbar > *{
  margin-left:0 !important;
  margin-right:0 !important;
}

.home .cr-movies-filters select,
.home .cr-movies-toolbar select{
  margin:0 !important;
}

@media (max-width: 900px){
  .site-header .inside-header{
    padding:6px 10px;
    grid-template-columns:1fr auto;
    grid-template-areas:"brand nav";
    align-items:center;
    column-gap:8px;
    row-gap:0;
  }

  .site-branding{ grid-area:brand; }
  .main-navigation{
    grid-area:nav;
    justify-self:end;
    margin-left:0;
    width:auto;
  }

  .main-navigation .inside-navigation{
    justify-content:flex-end;
  }

  .main-navigation .menu-toggle{
    margin-left:auto;
  }

  .ch-header-meta{
    display:none !important;
    margin-left:0;
  }
}

@media (max-width: 700px){
  .home .cr-movies-filters,
  .home .cr-movies-toolbar{
    overflow-x:auto;
    overflow-y:hidden;
    white-space:nowrap;
    -webkit-overflow-scrolling:touch;
    gap:8px;
  }

  .home .cr-movies-filters .cr-movies-filter-label,
  .home .cr-movies-toolbar .cr-movies-filter-label,
  .home .cr-movies-filters label,
  .home .cr-movies-toolbar label{
    display:none !important;
  }
}

/* === Filter dropdown hard fix (v0.3.38) === */
.home .cr-movies-toolbar .cr-movies-filter-select,
.home .cr-movies-toolbar select{
  -webkit-appearance:none !important;
  appearance:none !important;
  display:inline-flex !important;
  align-items:center !important;
  width:220px !important;
  min-width:220px !important;
  max-width:220px !important;
  height:52px !important;
  min-height:52px !important;
  max-height:52px !important;
  line-height:1.2 !important;
  padding:0 40px 0 16px !important;
  border-radius:14px !important;
  border:1px solid rgba(255,255,255,.16) !important;
  background-color:rgba(255,255,255,.05) !important;
  color:#eef1f6 !important;
  transform:none !important;
  aspect-ratio:auto !important;
}

@media (max-width: 700px){
  .home .cr-movies-toolbar .cr-movies-filter-select,
  .home .cr-movies-toolbar select{
    width:132px !important;
    min-width:132px !important;
    max-width:132px !important;
    height:46px !important;
    min-height:46px !important;
    max-height:46px !important;
    padding:0 30px 0 12px !important;
    border-radius:12px !important;
  }
}

/* === Movies filter row cleanup (v0.3.39) === */
.home .cr-movies-toolbar{
  display:flex !important;
  flex-direction:row !important;
  flex-wrap:nowrap !important;
  align-items:center !important;
  gap:10px !important;
  overflow-x:auto;
  overflow-y:hidden;
  white-space:nowrap;
}

.home .cr-movies-tabs{
  margin:0 !important;
  flex:0 0 auto;
}

.home .cr-tab-btn{
  height:48px !important;
  min-height:48px !important;
  padding:0 12px !important;
  border-radius:999px !important;
  font-size:11px !important;
  letter-spacing:.04em !important;
}

.home .cr-movies-filters{
  display:flex !important;
  align-items:center !important;
  flex-wrap:nowrap !important;
  gap:8px !important;
  margin:0 !important;
  flex:0 0 auto;
}

.home .cr-movies-filter-label{
  display:none !important;
}

.home .cr-movies-filter-form{
  position:relative;
  width:auto !important;
  min-width:0 !important;
  max-width:220px !important;
  flex:0 0 220px;
}

.home .cr-movies-filter-form::after{
  display:none !important;
  content:none !important;
}
.home .cr-movies-filter-form:after{
  display:none !important;
  content:none !important;
}

.home .cr-movies-toolbar .cr-movies-filter-select,
.home .cr-movies-toolbar select{
  width:100% !important;
  min-width:0 !important;
  max-width:none !important;
  height:52px !important;
  min-height:52px !important;
  border-radius:999px !important;
  border:1px solid rgba(255,255,255,.14) !important;
  background:rgba(255,255,255,.06) !important;
  color:rgba(255,255,255,.92) !important;
  font-weight:900 !important;
  letter-spacing:.4px !important;
  text-transform:uppercase;
  padding:0 16px !important;
  box-sizing:border-box !important;
  line-height:1 !important;
  vertical-align:middle !important;
}

@media (max-width: 700px){
  .home .cr-movies-toolbar{
    gap:4px !important;
    overflow:visible !important;
  }

  .home .cr-movies-tabs{
    gap:4px !important;
  }

  .home .cr-tab-btn{
    height:40px !important;
    min-height:40px !important;
    padding:0 8px !important;
    font-size:9px !important;
  }

  .home .cr-movies-filter-form{
    max-width:112px !important;
    flex:0 0 112px !important;
    overflow:visible !important;
  }
  .home .cr-movies-filter-label{
    display:none !important;
  }
  .home .cr-movies-toolbar .cr-movies-filter-select,
  .home .cr-movies-toolbar select{
    height:40px !important;
    min-height:40px !important;
    font-size:10px !important;
    padding:0 10px !important;
  }
}

/* === Final mobile filter layout lock (v0.3.43) === */
@media (max-width: 700px){
  body.home .cr-movies-toolbar{
    display:grid !important;
    grid-template-columns:minmax(0,1fr) minmax(0,1fr) 92px !important;
    align-items:center !important;
    gap:4px !important;
    width:100% !important;
    overflow:hidden !important;
    white-space:normal !important;
    position:relative;
  }

  body.home .cr-movies-tabs{
    display:grid !important;
    grid-template-columns:1fr 1fr !important;
    gap:4px !important;
    min-width:0 !important;
    width:100% !important;
    margin:0 !important;
    grid-column:1 / 3 !important;
  }

  body.home .cr-tab-btn{
    width:100% !important;
    height:40px !important;
    min-height:40px !important;
    max-height:40px !important;
    padding:0 6px !important;
    font-size:8px !important;
    letter-spacing:.02em !important;
    box-sizing:border-box !important;
    line-height:1 !important;
  }

  body.home .cr-movies-filters{
    min-width:0 !important;
    width:92px !important;
    max-width:92px !important;
    margin:0 0 0 9px !important;
    justify-content:flex-end !important;
    overflow:visible !important;
    position:relative;
    z-index:2;
    grid-column:3 !important;
  }

  body.home .cr-movies-filter-form{
    width:92px !important;
    min-width:92px !important;
    max-width:92px !important;
    flex:0 0 92px !important;
    margin:0 !important;
    padding:0 !important;
    border:0 !important;
    background:transparent !important;
    box-shadow:none !important;
  }

  body.home .cr-movies-filter-form::after,
  body.home .cr-movies-filter-form:after{
    display:none !important;
    content:none !important;
  }

  body.home .cr-movies-toolbar .cr-movies-filter-select,
  body.home .cr-movies-toolbar select{
    width:92px !important;
    min-width:92px !important;
    max-width:92px !important;
    height:40px !important;
    min-height:40px !important;
    max-height:40px !important;
    padding:0 8px !important;
    font-size:9px !important;
    border-radius:999px !important;
    box-sizing:border-box !important;
    line-height:1 !important;
    text-align:center !important;
    text-align-last:center !important;
    -moz-text-align-last:center !important;
  }

  body.home .cr-movies-toolbar select option{
    text-align:center !important;
  }
}

/* Mobile header: keep logo away from left edge */
@media (max-width: 700px){
  body .site-header .inside-header{
    padding-left:14px !important;
    padding-right:10px !important;
  }
  body .site-branding{
    margin-left:2px !important;
  }
}
