
:root {
  --green:#0f6b3c;
  --green-2:#16a34a;
  --lime:#a3e635;
  --dark:#03140d;
  --deep:#052e1b;
  --text:#111827;
  --muted:#64748b;
  --line:#dbe7df;
  --soft:#f3fbf6;
  --white:#ffffff;
  --gold:#f5b700;
  --shadow:0 18px 45px rgba(15,23,42,.08);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,Arial,system-ui,sans-serif;color:var(--text);background:linear-gradient(180deg,#fff,#f7fff9 55%,#fff)}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button,input,select{font:inherit}

.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:18px 5%;background:linear-gradient(135deg,#02150d,#05391f);color:#fff;border-bottom:1px solid rgba(255,255,255,.12)}
.brand{display:flex;align-items:center;gap:10px;font-size:26px;font-weight:900;letter-spacing:-.04em}
.brand-mark{display:grid;place-items:center;width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,#86efac,#22c55e);color:#032012;font-weight:900}
.brand em{font-style:normal;color:var(--lime)}
.nav{display:flex;gap:34px;font-weight:800}
.nav a{opacity:.95;padding:8px 0;border-bottom:3px solid transparent}
.nav a:hover,.nav a.active{color:var(--lime);border-bottom-color:var(--lime)}
.search-shell{display:flex;align-items:center;gap:8px;border:1px solid rgba(255,255,255,.35);border-radius:12px;padding:10px 14px;min-width:260px;color:#d1fae5}
.search-shell input{background:transparent;border:0;outline:0;color:#fff;width:100%}
.search-shell input::placeholder{color:#b7d4c3}
.menu-toggle{display:none;background:#fff;color:#063;border:0;border-radius:10px;padding:9px 12px;font-weight:900}

.hero{position:relative;overflow:hidden;padding:82px 5%;background:radial-gradient(circle at 80% 20%,rgba(34,197,94,.35),transparent 26%),linear-gradient(135deg,#032014,#075530);color:#fff;text-align:center}
.hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.15),rgba(255,255,255,.03));opacity:.8}
.hero-inner{position:relative;max-width:960px;margin:auto}
.eyebrow{display:inline-flex;margin-bottom:16px;padding:8px 13px;border-radius:999px;background:rgba(163,230,53,.14);color:#d9f99d;font-weight:900;text-transform:uppercase;letter-spacing:.08em}
.hero h1{font-size:clamp(38px,5vw,70px);line-height:.96;margin:0 0 16px;letter-spacing:-.06em}
.hero h1 span,.page-hero h1 span{color:var(--lime)}
.hero p{font-size:20px;color:#e8fff0;margin:0 auto 26px;max-width:720px;line-height:1.55}
.hero-actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;border-radius:999px;padding:13px 18px;font-weight:900;border:1px solid var(--line);background:#fff;color:#063;cursor:pointer}
.btn.primary{background:linear-gradient(135deg,var(--green-2),var(--green));color:#fff;border:0;box-shadow:0 16px 35px rgba(22,163,74,.28)}

.section{max-width:1340px;margin:auto;padding:42px 5%}
.section-head{display:flex;justify-content:space-between;align-items:end;margin-bottom:20px;gap:18px}
.section-head h2{margin:0;font-size:32px;letter-spacing:-.04em}
.section-head p{margin:5px 0 0;color:var(--muted)}
.view-link{color:var(--green);font-weight:900}
.card-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.movie-card,.review-card,.restaurant-card{background:#fff;border:1px solid var(--line);border-radius:22px;overflow:hidden;box-shadow:var(--shadow);transition:.2s}
.movie-card:hover,.review-card:hover,.restaurant-card:hover{transform:translateY(-4px)}
.movie-card img{height:245px;width:100%;object-fit:cover}
.movie-body{padding:14px}
.movie-body h3{margin:0 0 6px;font-size:18px}
.meta{color:var(--muted);font-weight:700;font-size:14px}
.rating{color:var(--gold);font-weight:900}
.badge{display:inline-flex;border-radius:999px;padding:5px 9px;background:#e8f8ed;color:#075c34;font-weight:900;font-size:12px}

.trailer-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.trailer-card{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow)}
.trailer-card iframe{width:100%;aspect-ratio:16/9;border:0;display:block}
.trailer-card h3{font-size:15px;margin:10px 12px 14px}

.page-hero{padding:62px 5%;background:radial-gradient(circle at 85% 30%,rgba(132,204,22,.28),transparent 25%),linear-gradient(135deg,#03140d,#075530);color:#fff;text-align:center}
.page-hero h1{font-size:clamp(36px,5vw,62px);margin:0 0 10px;letter-spacing:-.05em}
.page-hero p{font-size:18px;color:#e7fff0;margin:0}
.search-card{max-width:1060px;margin:-30px auto 24px;padding:18px;border:1px solid var(--line);background:#fff;border-radius:20px;box-shadow:var(--shadow)}
.search-card input{width:100%;border:0;outline:0;font-size:18px}
.tabs{display:flex;gap:12px;flex-wrap:wrap;margin:0 0 20px}
.tab{border:1px solid var(--line);background:#fff;border-radius:10px;padding:11px 18px;font-weight:900;color:#06492b;cursor:pointer}
.tab.active{background:var(--green);color:#fff}
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.review-card{display:grid;grid-template-columns:130px 1fr;gap:16px;padding:16px}
.review-card img{height:190px;width:130px;object-fit:cover;border-radius:16px}
.review-card h3{margin:3px 0 5px}
.review-card p{color:#475569;line-height:1.5;margin:10px 0}
.table-panel{background:#fff;border:1px solid var(--line);border-radius:22px;padding:24px;box-shadow:var(--shadow)}
.data-table{width:100%;border-collapse:collapse;overflow:hidden;border-radius:14px}
.data-table th{background:#f1f8f2;color:#06492b;text-align:left}
.data-table th,.data-table td{padding:14px 16px;border-bottom:1px solid #e5eee8;font-size:14px}
.data-table tr:hover td{background:#fbfffc}
.verdict{font-weight:900;border-radius:999px;padding:5px 10px;background:#e8f8ed;color:#075c34;display:inline-block}
.verdict.average{background:#fff7ed;color:#9a3412}
.verdict.hit{background:#eff6ff;color:#1d4ed8}
.note{margin-top:18px;background:#eef9ef;border:1px solid #cdebd1;border-radius:12px;padding:14px;color:#155b32;font-weight:700}
.stock-panel,.restaurant-panel{background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);padding:26px;margin-bottom:28px}
.stock-top{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:18px}
.updated{color:#166534;background:#eef9ef;border-radius:999px;padding:7px 11px;font-weight:900;font-size:13px}
.restaurant-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.restaurant-card img{height:120px;width:100%;object-fit:cover;background:#eaf5ec}
.restaurant-body{padding:12px}
.restaurant-body h3{margin:0 0 5px;font-size:16px}

.footer{margin-top:40px;background:linear-gradient(135deg,#03140d,#075530);color:#dcfce7;padding:42px 5% 18px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:28px;max-width:1340px;margin:auto}
.footer h3,.footer h4{color:#fff;margin-top:0}
.footer a{display:block;color:#dcfce7;margin:8px 0;cursor:pointer}
.socials{display:flex;gap:12px}
.socials a{display:grid;place-items:center;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.12);font-weight:900}
.legal-note{max-width:1340px;margin:24px auto 0;padding-top:16px;border-top:1px solid rgba(255,255,255,.18);font-size:13px;color:#cdebd1}

.modal{display:none;position:fixed;inset:0;background:rgba(3,20,13,.72);z-index:100;place-items:center;padding:20px}
.modal.open{display:grid}
.modal-card{width:min(760px,100%);max-height:86vh;overflow:auto;background:#fff;border-radius:22px;padding:28px;box-shadow:0 28px 80px rgba(0,0,0,.3)}
.modal-head{display:flex;justify-content:space-between;gap:20px;align-items:center}
.modal-head h2{margin:0;color:#06492b}
.close{border:0;background:#eff6f1;border-radius:50%;width:36px;height:36px;font-size:22px;cursor:pointer}
.modal-card p,.modal-card li{line-height:1.65;color:#475569}
.modal-card ul{padding-left:22px}

@media(max-width:1000px){
  .card-grid{grid-template-columns:repeat(2,1fr)}
  .trailer-row{grid-template-columns:repeat(2,1fr)}
  .review-grid{grid-template-columns:1fr}
  .restaurant-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .search-shell{display:none}
}
@media(max-width:720px){
  .nav{display:none;position:absolute;left:5%;right:5%;top:76px;background:#052e1b;padding:16px;border-radius:16px;box-shadow:var(--shadow);flex-direction:column;gap:10px}
  .nav.open{display:flex}
  .menu-toggle{display:block}
  .hero{text-align:left}
  .hero-actions{justify-content:flex-start}
  .card-grid,.trailer-row,.restaurant-grid{display:flex;overflow:auto;scroll-snap-type:x mandatory;padding-bottom:8px}
  .movie-card,.trailer-card,.restaurant-card{min-width:230px;scroll-snap-align:start}
  .review-card{grid-template-columns:105px 1fr}
  .review-card img{width:105px;height:160px}
  .data-table{min-width:720px}
  .table-scroll{overflow:auto}
  .footer-grid{grid-template-columns:1fr}
  .topbar{padding:15px 4%}
  .brand{font-size:22px}
}

/* Corrections */
.search-shell {
  gap: 0;
}
.stars .on {
  color: var(--gold);
}
.stars .off {
  color: #cbd5e1;
}

/* V3 corrections */
.search-shell::before,
.search-shell::after {
  content: none !important;
}
.search-shell {
  gap: 0 !important;
}
.search-shell input {
  padding-left: 0;
}
.stars .on {
  color: var(--gold);
}
.stars .half {
  color: var(--gold);
  position: relative;
  display: inline-block;
  width: 0.62em;
  overflow: hidden;
  vertical-align: bottom;
}
.stars .off {
  color: #cbd5e1;
}
.negative {
  color: #b91c1c;
  font-weight: 900;
}
.positive {
  color: #047857;
  font-weight: 900;
}

/* Working YouTube trailer grid */
.video-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.video-box {
  background: #ffffff;
  border: 1px solid var(--line);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: var(--shadow);
}

.video-box iframe {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  border: 0;
}

@media (max-width: 1000px) {
  .video-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .video-grid {
    grid-template-columns: 1fr;
  }
}




/* Reviews page update: three cards per row with box office data */
.review-grid {
  grid-template-columns: repeat(3, 1fr);
}

.bo-line {
  margin: 10px 0 12px;
  padding: 9px 10px;
  border-radius: 10px;
  background: #f1f8f2;
  color: #06492b;
  font-size: 13px;
  line-height: 1.45;
}

.stars .on {
  color: var(--gold);
}

.stars .half {
  color: var(--gold);
  position: relative;
  display: inline-block;
  width: 0.62em;
  overflow: hidden;
  vertical-align: bottom;
}

.stars .off {
  color: #cbd5e1;
}

@media(max-width:1100px) {
  .review-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media(max-width:760px) {
  .review-grid {
    grid-template-columns: 1fr;
  }
}


/* Latest news list */
.news-list{display:flex;flex-direction:column;gap:12px}
.news-row{display:flex;align-items:flex-start;gap:14px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px 18px;box-shadow:var(--shadow)}
.news-row p{color:var(--muted);font-size:15px;line-height:1.6;margin:0}
.news-row strong{color:var(--ink)}
.news-tag{flex:0 0 auto;display:inline-flex;align-items:center;border-radius:999px;background:#ecfdf5;color:#047857;font-size:12px;font-weight:900;padding:6px 10px;white-space:nowrap}
@media (max-width: 640px){.news-row{display:block}.news-row .news-tag{margin-bottom:10px}.news-row p{font-size:14px}}


/* API-driven homepage content */
.loading-card{padding:26px;color:var(--muted);font-weight:800}
#latestMoviesGrid .movie-card img{background:#eef9ef}
.news-row a{margin-left:6px}
