/**
 * Nova Blocks — Frontend CSS
 * Dark/Editorial Aesthetic
 */
@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display&family=IBM+Plex+Sans:wght@400;500;600&family=Space+Mono&display=swap');

:root {
  --nb-accent:    #6c63ff;
  --nb-accent2:   #ff6584;
  --nb-text:      #e8e8f0;
  --nb-muted:     #9999bb;
  --nb-surface:   #111118;
  --nb-border:    rgba(255,255,255,0.08);
}

/* ─── RESPONSIVE VISIBILITY ─── */
@media (max-width: 767px)  { .nb-hide-mobile  { display: none !important; } }
@media (max-width: 1024px) { .nb-hide-tablet  { display: none !important; } }
@media (min-width: 1025px) { .nb-hide-desktop { display: none !important; } }

/* ─── ANIMATIONS ─── */
.nb-animate {
  opacity: 0;
  transition: opacity var(--nb-duration, 600ms) var(--nb-easing, ease),
              transform var(--nb-duration, 600ms) var(--nb-easing, ease);
  transition-delay: var(--nb-delay, 0ms);
}
.nb-animate.nb-visible { opacity: 1; transform: none !important; }

.nb-anim-fadeIn    { }
.nb-anim-slideUp   { transform: translateY(40px); }
.nb-anim-slideDown { transform: translateY(-40px); }
.nb-anim-slideLeft { transform: translateX(60px); }
.nb-anim-slideRight{ transform: translateX(-60px); }
.nb-anim-zoomIn    { transform: scale(0.85); }
.nb-anim-zoomOut   { transform: scale(1.1); }
.nb-anim-flipX     { transform: rotateX(30deg); perspective: 800px; }
.nb-anim-flipY     { transform: rotateY(30deg); perspective: 800px; }
.nb-anim-bounce    { transform: translateY(60px); transition-timing-function: cubic-bezier(.68,-.55,.265,1.55) !important; }
.nb-anim-rotateIn  { transform: rotate(-10deg) scale(0.9); }
.nb-anim-lightSpeed{ transform: translateX(100px) skewX(-20deg); }
.nb-anim-rollIn    { transform: translateX(-100px) rotate(-30deg); }
.nb-anim-pulse     { animation: nbPulse 1s ease infinite; opacity: 1; }
@keyframes nbPulse { 0%,100% { transform: scale(1); } 50% { transform: scale(1.04); } }

/* ─── CONTAINER ─── */
.nb-container { position: relative; }

/* ─── HEADING ─── */
.nb-heading-wrap { display: block; }

/* ─── BUTTONS ─── */
.nb-btn {
  display: inline-flex; align-items: center; gap: 8px;
  text-decoration: none; cursor: pointer; transition: all .2s;
  font-weight: 600; letter-spacing: .3px;
}
.nb-btn-filled { background: var(--nb-accent); color: #fff; }
.nb-btn-outline { background: transparent; border: 2px solid var(--nb-accent); color: var(--nb-accent); }
.nb-btn-text { background: transparent; }

.nb-hover-lift:hover    { transform: translateY(-3px); box-shadow: 0 10px 30px rgba(0,0,0,.3); }
.nb-hover-glow:hover    { box-shadow: 0 0 30px rgba(108,99,255,.5); }
.nb-hover-scale:hover   { transform: scale(1.05); }

/* ─── INFO BOX ─── */
.nb-info-box { transition: all .25s; }
.nb-info-box .nb-hover-lift:hover { transform: translateY(-4px); box-shadow: 0 16px 50px rgba(0,0,0,.4); }
.nb-info-box .nb-hover-glow:hover { box-shadow: 0 0 40px rgba(108,99,255,.25); }
.nb-info-box .nb-hover-border:hover { border-color: var(--nb-accent) !important; }

/* ─── TESTIMONIAL ─── */
.nb-testimonial { transition: transform .25s; }
.nb-testimonial:hover { transform: translateY(-3px); }
.nb-testimonial blockquote { border-left: none; padding: 0; margin: 0 0 20px; font-style: italic; }
.nb-testimonial-author { display: flex; align-items: center; gap: 14px; }
.nb-avatar { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; }
.nb-stars { display: flex; gap: 3px; margin-bottom: 16px; font-size: 18px; }

/* ─── CTA ─── */
.nb-cta { position: relative; overflow: hidden; }
.nb-cta-buttons { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 28px; }
.nb-cta-centered .nb-cta-buttons { justify-content: center; }

/* ─── DIVIDER ─── */
.nb-divider { display: block; }
.nb-divider hr { display: block; border: none; }
.nb-divider-icon-wrap { display: flex; align-items: center; gap: 16px; }

/* ─── COUNTDOWN ─── */
.nb-countdown-units { display: inline-flex; gap: 12px; flex-wrap: wrap; justify-content: center; }
.nb-countdown-unit {
  text-align: center; border: 1px solid var(--nb-border);
  min-width: 80px; padding: 20px 24px;
  display: flex; flex-direction: column; align-items: center;
}
.nb-cd-days, .nb-cd-hours, .nb-cd-mins, .nb-cd-secs {
  font-size: 36px; font-weight: 700; line-height: 1; display: block;
}
.nb-cd-label { font-size: 11px; text-transform: uppercase; letter-spacing: .5px; margin-top: 6px; display: block; }
.nb-countdown-label { font-size: 14px; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 16px; }

.nb-countdown-circle .nb-countdown-unit {
  border-radius: 50%; width: 90px; height: 90px; justify-content: center;
  padding: 0; min-width: unset;
}

/* ─── ICON LIST ─── */
.nb-icon-list { list-style: none; padding: 0; margin: 0; }
.nb-icon-list li { display: flex; align-items: flex-start; gap: 10px; }
.nb-list-icon { flex-shrink: 0; line-height: 1.5; }

/* ─── IMAGE BOX ─── */
.nb-image-box { position: relative; overflow: hidden; }
.nb-image-box-img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s; }
.nb-img-hover-zoom:hover .nb-image-box-img { transform: scale(1.06); }
.nb-image-box-caption {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 16px 20px; transition: opacity .3s;
}
.nb-img-hover-fade .nb-image-box-caption { opacity: 0; }
.nb-img-hover-fade:hover .nb-image-box-caption { opacity: 1; }
.nb-img-hover-slide .nb-image-box-caption { transform: translateY(100%); transition: transform .3s; }
.nb-img-hover-slide:hover .nb-image-box-caption { transform: translateY(0); }

/* ─── ACCORDION ─── */
.nb-accordion { display: flex; flex-direction: column; gap: 8px; }
.nb-accordion-item { overflow: hidden; }
.nb-accordion-header {
  padding: 16px 20px; display: flex; justify-content: space-between; align-items: center;
  cursor: pointer; user-select: none; transition: background .2s;
}
.nb-accordion-header:hover { background: rgba(255,255,255,.03); }
.nb-accordion-title { font-weight: 600; font-size: 15px; }
.nb-accordion-icon { font-size: 20px; font-weight: 700; transition: transform .3s; }
.nb-accordion-content {
  padding: 0 20px; max-height: 0; overflow: hidden;
  transition: max-height .35s ease, padding .35s ease;
  font-size: 14px; line-height: 1.7;
}
.nb-accordion-item.nb-open .nb-accordion-content { max-height: 600px; padding: 0 20px 16px; }
.nb-accordion-item.nb-open .nb-accordion-icon { transform: rotate(45deg); }

/* ─── TABS ─── */
.nb-tab-nav { display: flex; border-bottom: 1px solid var(--nb-border); flex-wrap: wrap; }
.nb-tab-btn {
  padding: 14px 24px; background: transparent; border: none; border-bottom: 2px solid transparent;
  cursor: pointer; font-weight: 600; font-size: 14px; transition: all .2s;
}
.nb-tab-btn.nb-active { border-bottom-color: var(--nb-accent); }
.nb-tab-panels { }
.nb-tab-panel { display: none; padding: 24px; font-size: 15px; line-height: 1.7; }
.nb-tab-panel.nb-active { display: block; }
.nb-tabs-pill .nb-tab-nav { padding: 10px; gap: 6px; border-bottom: none; }
.nb-tabs-pill .nb-tab-btn { border-radius: 30px; border: none; padding: 8px 20px; }
.nb-tabs-pill .nb-tab-btn.nb-active { background: var(--nb-accent); color: #fff; }
.nb-tabs-filled .nb-tab-btn.nb-active { background: var(--nb-accent); color: #fff; }

/* ─── RESPONSIVE GRIDS ─── */
@media (max-width: 767px) {
  .nb-cta-buttons { flex-direction: column; }
  .nb-countdown-units { gap: 8px; }
  .nb-countdown-unit { min-width: 64px; padding: 14px 16px; }
  .nb-cd-days, .nb-cd-hours, .nb-cd-mins, .nb-cd-secs { font-size: 26px; }
}
