/* assets/css/styles.css
   Quizmas redesign — festive dark theme, mobile-first
   Updated: refine header/nav, product list, video sizing, pricing grid, mobile padding,
   button contrast and FAQ accordion.
*/

:root{
  --accent: #C0392B;          /* warm festive red */
  --accent-900: #8B2E24;     /* darker red for hover */
  --green: #15492f;          /* deep pine green */
  --gold: #F4D03F;           /* accent gold */
  --bg: #07120C;             /* dark green night */
  --bg-soft: #0b2218;
  --muted: #B3C7BE;
  --text: #F6F7F5;
  --max-w: 1100px;
  --radius: 14px;
  --container-pad: 1.25rem;  /* increased mobile padding */
  --transition: 220ms cubic-bezier(.2,.9,.3,1);
}

/* Reset & base */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  color:var(--text);
  background: radial-gradient(circle at top, #092b1a 0, var(--bg) 45%, #000 100%);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.45;
  font-size:16px;
}

/* Links */
a{color:var(--gold);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}
a:hover{color:var(--accent)}

/* Global container uses variable padding for better mobile spacing */
.container{max-width:var(--max-w);margin:0 auto;padding:0 var(--container-pad)}

/* Sections spacing */
section{padding:1.5rem 0;scroll-margin-top:88px}

/* Hero */
.hero{padding:2rem 0 1.2rem;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(circle at 20% -10%, rgba(255,255,255,0.06), transparent 55%),
  radial-gradient(circle at 90% 0%, rgba(244,208,63,0.03), transparent 60%);
  opacity:1;pointer-events:none}
.hero-grid{position:relative;z-index:1;display:flex;flex-direction:column;gap:1.5rem}
.hero-copy h1{font-size:1.9rem;margin:0 0 .75rem;color:var(--text);line-height:1.15}
.lede{color:var(--muted);margin:0 0 1rem;font-size:1.02rem}
.hero-ctas{display:flex;flex-wrap:wrap;gap:.85rem;margin-bottom:1rem}

/* Product list: stacked title/subtitle to avoid inline misplacement */
.product-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1rem}
.product-list li{
  background:linear-gradient(180deg, rgba(6,22,14,0.96), rgba(8,28,18,0.94));
  border-radius:12px;
  padding:1rem 1rem;
  border:1px solid rgba(255,255,255,0.04);
  display:grid;
  grid-template-columns:1fr 160px; /* main + image column */
  column-gap:1rem;
  row-gap:.35rem;
  align-items:center;
}
.product-list strong{display:block;font-size:1.05rem;margin:0 0 .18rem;color:var(--text);grid-column:1 / 2}
.product-list .muted{display:block;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);grid-column:1 / 2;margin:0 0 .35rem}
.product-list p{margin:.15rem 0 0;grid-column:1 / 2}
.product-list img{
  width:160px;
  height:auto;
  border-radius:10px;
  flex-shrink:0;
  grid-column:2 / 3;
  grid-row:1 / 4;
  justify-self:end;
}

/* Make product images even larger on wide screens */
@media (min-width:900px){
  .product-list li{grid-template-columns:1fr 220px}
  .product-list img{width:220px}
}

/* Hero media (video preview) */
.hero-media{order:-1;display:flex;justify-content:center}
.hero-media video{
  width:100%;
  max-width:880px;    /* prominent but within container */
  aspect-ratio:16/9;
  border-radius:var(--radius);
  box-shadow:0 28px 70px rgba(0,0,0,.7);
  border:1px solid rgba(255,255,255,0.12);
  background:#000;
  transform:translateZ(0);
}

/* Preview poster */
.preview-section{padding:1rem 0 1.5rem}
.preview-poster{width:100%;max-width:980px;height:0;padding-bottom:56.25%;background-size:cover;background-position:center;border-radius:calc(var(--radius) + 2px);position:relative;box-shadow:0 24px 60px rgba(0,0,0,0.55);cursor:pointer;border:1px solid rgba(255,255,255,0.06)}
.preview-poster:focus{box-shadow:0 24px 60px rgba(0,0,0,0.75),0 0 0 4px rgba(244,208,63,0.12)}
.play-btn{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:linear-gradient(90deg,var(--accent),var(--accent-900));color:#fff;padding:.6rem .85rem;border-radius:999px;font-weight:800;font-size:1.5rem;box-shadow:0 12px 30px rgba(0,0,0,0.35)}

/* Modal */
.video-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:9999}
.video-modal[aria-hidden="false"]{display:flex}
.video-modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,0.78)}
.video-modal__content{position:relative;z-index:2;width:100%;max-width:1100px;padding:1rem}
.video-modal__content video{width:100%;height:auto;border-radius:calc(var(--radius) + 4px);box-shadow:0 40px 100px rgba(0,0,0,0.8)}
.video-modal__close{position:absolute;right:8px;top:8px;z-index:3;background:transparent;border:0;color:#fff;font-size:2rem;padding:.2rem .5rem;cursor:pointer}

/* Header */
.header-wrap{position:sticky;top:0;z-index:60;background:linear-gradient(180deg, rgba(7,18,12,0.98), rgba(7,18,12,0.94));backdrop-filter:blur(8px);border-bottom:1px solid rgba(255,255,255,0.03)}
.site-header{position:relative;padding:.55rem 0}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:.75rem}
.brand{display:flex;align-items:center;gap:.6rem;color:var(--text);text-decoration:none}
.brand-logo{width:36px;height:auto;display:block}
.brand-title{font-weight:800;font-size:1.05rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gold)}
.brand-sub{font-size:.78rem;color:var(--muted)}

/* Nav styling: larger touch targets */
.nav-list{list-style:none;margin:0;padding:0;display:flex;gap:.5rem}
.nav-list a{color:var(--muted);text-decoration:none;padding:.55rem .85rem;border-radius:999px;font-size:.95rem;white-space:nowrap;display:inline-block}
.nav-list a:hover{background:rgba(255,255,255,0.04);color:var(--text)}

/* Primary CTA in header */
.header-inner .btn-primary{padding:.55rem 1rem;font-size:.95rem}

/* Mobile header layout improvements */
@media (max-width:599px){
  .container{padding:0 1.6rem}
  .header-inner{flex-direction:column;align-items:stretch;gap:.6rem}
  .brand{justify-content:flex-start}
  .nav-list{width:100%;justify-content:flex-start;flex-wrap:wrap;background:transparent;padding:.3rem 0}
  .nav-list a{flex:0 0 auto;padding:.6rem .9rem}
  .header-inner .btn-primary{align-self:flex-end}
  /* Ensure main sections have extra side padding on mobile */
  .container{padding-left:1.6rem;padding-right:1.6rem}
  /* More breathing room on mobile sections */
  section{padding:1.9rem 0}
  .hero{padding:2.4rem 0 1.6rem}
  .product-list{gap:1.25rem}
  .pricing-card{padding:1rem 1.1rem}
}

/* Tablet / Desktop layout */
@media (min-width:600px){
  .container{padding:0 1.75rem}
  .hero-grid{flex-direction:row;align-items:flex-start;gap:2rem}
  .hero-media{order:0;justify-content:flex-end}
}
@media (min-width:900px){
  .container{padding:0 2rem}
  .hero-copy h1{font-size:2.6rem}
  .hero-grid{gap:2.2rem}
  .hero-copy{flex:1 1 42%;min-width:320px}
  .hero-media{flex:1 1 58%;display:flex;justify-content:center}
  .hero-media video{max-width:1100px}
  .features-grid{flex-direction:row}
  .footer-inner{flex-direction:row;align-items:center;justify-content:space-between}
}

/* Features */
.features{padding:1.8rem 0}
.features h2,.package h2,.how h2,.faq h2{font-size:1.25rem;margin-bottom:1rem}
.features-grid{display:flex;flex-direction:column;gap:1rem}
.feature-card{background:linear-gradient(180deg, rgba(6,24,16,0.98), rgba(8,30,18,0.95));border-radius:var(--radius);padding:1rem;border:1px solid rgba(255,255,255,0.04);box-shadow:0 10px 30px rgba(0,0,0,.4)}
.feature-card h3{margin:0 0 .35rem;font-size:1.03rem}
.feature-card p{margin:0;color:var(--muted);font-size:.95rem}

.package,.how,.faq{padding:1.75rem 0}
.package .lead{color:var(--muted);font-size:.98rem}
.package ul, .package ol{padding-left:1.1rem}
.package li{margin-bottom:.4rem}

/* Pricing grid responsive */
.pricing-grid{
  display:grid;
  gap:0.85rem;
  margin:1rem 0 1.25rem;
  grid-template-columns:1fr;
}
.pricing-card{
  background:linear-gradient(180deg, rgba(6,24,18,0.96), rgba(8,28,18,0.94));
  border-radius:12px;
  padding:.9rem 1rem;
  border:1px solid rgba(255,255,255,0.06);
  display:flex;align-items:center;justify-content:space-between;gap:1rem
}
.pricing-card-inner{display:flex;flex-direction:column;gap:.28rem}
.pricing-label{margin:0;color:var(--muted);font-size:.95rem}
.pricing-price{margin:0;font-weight:800;color:var(--text);font-size:1.25rem}
.pricing-desc{margin:0;color:var(--muted);font-size:.92rem}
.pricing-btn{margin-top:.4rem}

/* multi-column for pricing on wider screens */
@media (min-width:600px){
  .pricing-grid{grid-template-columns:repeat(2, 1fr)}
}
@media (min-width:1100px){
  .pricing-grid{grid-template-columns:repeat(4, 1fr)}
}

.pricing-card.most-chosen-card{border-color:rgba(244,208,63,0.14);box-shadow:0 18px 44px rgba(244,208,63,0.06);background:linear-gradient(180deg, rgba(8,30,18,0.98), rgba(10,36,22,0.95))}
.pricing-card.most-chosen-card .pricing-label{color:var(--text);font-weight:700}
.most-chosen{display:inline-block;background:linear-gradient(90deg,var(--gold),#f7e49a);color:#08120A;padding:.12rem .5rem;border-radius:999px;font-size:.78rem;font-weight:800;margin-left:0;box-shadow:0 6px 12px rgba(0,0,0,0.12)}

/* How steps */
.how .steps{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.75rem}
.how .steps li{background:linear-gradient(180deg, rgba(6,24,18,0.96), rgba(8,28,18,0.94));border-radius:12px;padding:.9rem;border:1px solid rgba(255,255,255,0.05)}

/* FAQ */
.faq .accordion{display:flex;flex-direction:column;gap:.6rem}
.faq-q{width:100%;text-align:left;padding:.75rem 1rem;border-radius:12px;background:linear-gradient(180deg, rgba(6,24,18,0.96), rgba(8,28,18,0.94));border:1px solid rgba(255,255,255,0.06);color:inherit;cursor:pointer;font-weight:700;font-size:1rem}
.faq-q[aria-expanded="true"]{border-color:var(--accent);}
.faq-q::after{content:'\25BE';float:right;opacity:.75;transform-origin:center;transition:transform .18s ease}
.faq-q[aria-expanded="true"]::after{transform:rotate(180deg)}
.faq-a{border-left:2px solid rgba(231,76,60,0.28);padding-left:.9rem;background:transparent;color:var(--muted);overflow:hidden;max-height:0;transition:max-height .28s ease,padding .18s ease}
.faq-a.open{padding-top:.6rem;padding-bottom:.7rem;max-height:800px}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:.65rem 1.05rem;border-radius:999px;border:0;font-weight:800;font-size:.95rem;cursor:pointer;text-decoration:none;transition:transform var(--transition),box-shadow var(--transition),background var(--transition),color var(--transition)}
.btn-primary{background:linear-gradient(90deg,var(--accent),var(--accent-900));color:#fff;box-shadow:0 14px 40px rgba(192,57,43,0.35)}
/* Make hover slightly darker to preserve contrast */
.btn-primary:hover{background:linear-gradient(90deg,var(--accent-900),#6e251f);color:#fff;transform:translateY(-1px) scale(1.02);box-shadow:0 18px 48px rgba(0,0,0,0.45)}
.btn-secondary{background:transparent;border:1px solid rgba(255,255,255,0.18);color:var(--text)}
.btn-secondary:hover{background:rgba(255,255,255,0.04)}
.btn:focus{outline:3px solid rgba(244,208,63,.85);outline-offset:3px}

/* Footer */
.site-footer{border-top:1px solid rgba(255,255,255,0.04);padding:1.5rem 0 2rem;margin-top:2rem;background:radial-gradient(circle at top,#072819 0,#02100a 55%)}
.footer-inner{display:flex;flex-direction:column;align-items:flex-start;gap:.85rem}
.footer-links a{color:var(--muted);text-decoration:none;font-size:.92rem}
.footer-links a:hover{color:var(--text)}
.footer-bottom{text-align:left;color:var(--muted);font-size:.9rem;margin-top:1rem}
.socials{display:flex;gap:.75rem}
.socials img{width:30px;opacity:.98;transition:transform .18s ease,filter .18s ease}
.socials img:hover{transform:translateY(-2px);filter:drop-shadow(0 0 10px rgba(255,255,255,.25))}

/* Utilities */
.text-center{text-align:center}
.muted{color:var(--muted)}

/* Reveal animations */
.reveal{opacity:0;transform:translateY(8px);transition:opacity .52s var(--transition),transform .52s var(--transition)}
.reveal.visible{opacity:1;transform:none}

/* Snow effect (only when body.snowing) - subtle and performant */
body.snowing::before, body.snowing::after{content:"";position:fixed;left:0;right:0;top:-10%;height:110%;pointer-events:none;z-index:9999;opacity:.6}
body.snowing::before{background:transparent;filter:blur(.4px);box-shadow:10px 10px 0 0 rgba(255,255,255,.9),60px 20px 0 0 rgba(255,255,255,.7),120px 40px 0 0 rgba(255,255,255,.7),200px 60px 0 0 rgba(255,255,255,.5)}
body.snowing::after{background:transparent;box-shadow:30px 0 0 0 rgba(255,255,255,.7),90px 40px 0 0 rgba(255,255,255,.6),150px 20px 0 0 rgba(255,255,255,.8)}
@keyframes fall1{from{transform:translateY(-10%)}to{transform:translateY(110%)}}
@keyframes fall2{from{transform:translateY(-5%)}to{transform:translateY(120%)}}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .reveal{transition:none}
  body.snowing::before,body.snowing::after{animation:none;opacity:.4}
}
