/* Neobrutalism Theme for SUNDEVS legal pages */
:root {
  --nb-bg: #FFFBE6; /* warm cream */
  --nb-ink: #111111; /* heavy ink */
  --nb-card: #ffffff; /* paper */
  --nb-primary: #FF6B00; /* SUNDEVS orange */
  --nb-accent: #22D3EE; /* cyan accent */
}

.nb-theme {
  background: var(--nb-bg);
  color: var(--nb-ink);
}

.nb-header {
  position: sticky;
  top: 0.75rem;
  z-index: 50;
  margin: 1rem auto 0;
  padding: 0.75rem 1rem;
  background: var(--nb-card);
  border: 4px solid var(--nb-ink);
  box-shadow: 10px 10px 0 var(--nb-ink);
  border-radius: 16px;
}
.nb-header a { color: var(--nb-ink); text-decoration: none; }
.nb-header a:hover { text-decoration: underline; }

/* Brand in header */
.nb-brand { display:inline-flex; align-items:center; gap:.5rem; font-weight:900; font-size:1.15rem; color:var(--nb-ink); text-decoration:none; }
.nb-brand img { height:28px; width:auto; border-radius:8px; border:2px solid var(--nb-ink); box-shadow:4px 4px 0 var(--nb-ink); background:#fff; }
@media (min-width:768px){ .nb-brand img { height:32px; } .nb-brand { font-size:1.25rem; } }

/* Nav + Dropdowns */
.nb-nav { list-style: none; display: flex; align-items: center; gap: 1rem; margin: 0; padding: 0; flex-wrap: wrap; }
.nb-nav > li { position: relative; }
.nb-dd-btn { background: transparent; border: 3px solid var(--nb-ink); border-radius: 9999px; padding: 0.25rem 0.75rem; font-weight: 800; cursor: pointer; box-shadow: 6px 6px 0 var(--nb-ink); }
.nb-dd-btn:hover { background: #111; color: #fff; }

.nb-has-dropdown > a,
.nb-nav > li > a { display: inline-block; font-weight: 800; padding: 0.25rem 0.5rem; }

.nb-dropdown { position: absolute; top: 100%; left: 0; min-width: 220px; background: #fff; border: 3px solid var(--nb-ink); box-shadow: 8px 8px 0 var(--nb-ink); border-radius: 16px; padding: 0.5rem; display: none; z-index: 60; }
.nb-dropdown li { list-style: none; }
.nb-dropdown a { display: block; padding: 0.5rem 0.75rem; border-radius: 10px; font-weight: 800; color: var(--nb-ink); text-decoration: none; }
.nb-dropdown a:hover { background: #111; color: #fff; }

/* Hover buffer to prevent flicker when moving mouse from trigger to menu */
.nb-dropdown::before { content: ""; position: absolute; top: -10px; left: 0; right: 0; height: 12px; }

.nb-has-dropdown:hover > .nb-dropdown, .nb-has-dropdown.open > .nb-dropdown, .nb-has-dropdown:focus-within > .nb-dropdown { display: block; }

/* Hero */
.nb-hero {
  position: relative;
  margin: 1.25rem auto 0;
  padding: 2rem 1.25rem;
  background: var(--nb-primary);
  color: #111;
  border: 4px solid var(--nb-ink);
  box-shadow: 12px 12px 0 var(--nb-ink);
  border-radius: 20px;
}

.nb-hero h1 {
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.02em;
}

.nb-meta { display: flex; flex-wrap: wrap; gap: 0.75rem 1rem; margin-top: 0.75rem; }

.nb-chip {
  display: inline-flex; align-items: center; gap: 0.5rem;
  background: #fff;
  color: #111;
  border: 3px solid var(--nb-ink);
  box-shadow: 6px 6px 0 var(--nb-ink);
  border-radius: 9999px;
  padding: 0.4rem 0.85rem;
  font-weight: 700;
}

.nb-card {
  margin: 1.25rem auto 0;
  background: var(--nb-card);
  border: 4px solid var(--nb-ink);
  box-shadow: 12px 12px 0 var(--nb-ink);
  border-radius: 20px;
  padding: 1.25rem;
}

@media (min-width: 768px) {
  .nb-card { padding: 2rem; }
  .nb-nav { gap: 1.25rem; }
}

/* Larger hero and layering */
.nb-hero { min-height: 65vh; padding: 2.75rem 1.5rem; }
@media (min-width: 768px) { .nb-hero { min-height: 80vh; padding: 4.5rem 2rem; } }
.nb-hero .nb-hero-content { position: relative; z-index: 1; }
.nb-hero-decor { z-index: 0; }

.nb-section + .nb-section { margin-top: 1.5rem; padding-top: 1.5rem; border-top: 3px dashed var(--nb-ink); }

.nb-section h2 {
  font-size: 1.375rem; /* text-2xl */
  font-weight: 800; /* heavy */
  margin-bottom: 0.5rem;
}

.nb-list { padding-left: 1.25rem; }
.nb-list li { margin-bottom: 0.4rem; }

.nb-inline { display: inline-flex; align-items: center; gap: 0.5rem; }

.nb-footer {
  margin: 2rem auto 2.5rem;
  padding: 1.25rem;
  background: var(--nb-card);
  border: 4px solid var(--nb-ink);
  box-shadow: 10px 10px 0 var(--nb-ink);
  border-radius: 16px;
}

/* Compact horizontal footer links */
.nb-footer .nb-footer-links { display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:.5rem .6rem; margin-bottom:.75rem; }
.nb-chip-link { display:inline-flex; align-items:center; justify-content:center; padding:.25rem .6rem; border:3px solid var(--nb-ink); border-radius:9999px; box-shadow:6px 6px 0 var(--nb-ink); background:#fff; color:var(--nb-ink); font-weight:900; font-size:.85rem; text-decoration:none; }
.nb-chip-link:hover { background:#111; color:#fff; }

.nb-footer .nb-footer-meta { display:grid; gap:.35rem; text-align:center; font-size:.82rem; font-weight:800; }
.nb-footer .nb-footer-meta a { text-decoration: underline; text-decoration-thickness: 2px; text-underline-offset: 2px; color: var(--nb-ink); }
.nb-footer .nb-footer-meta a:hover { background:#111; color:#fff; }

/* Footer column groups */
.nb-footer-cols { display:grid; gap:1rem; }
@media (min-width:768px){ .nb-footer-cols { grid-template-columns: repeat(4, minmax(0,1fr)); gap:1.25rem; } }
.nb-footer-col h4 { font-weight:900; font-size:.95rem; margin-bottom:.35rem; }
.nb-links-list { list-style:none; padding:0; margin:0; display:grid; gap:.25rem; font-size:.9rem; font-weight:800; }
.nb-links-list a { color: var(--nb-ink); text-decoration: underline; text-decoration-thickness: 2px; text-underline-offset: 2px; }
.nb-links-list a:hover { background:#111; color:#fff; }

/* Utility helpers that complement Tailwind */
.nb-divider { border-top: 3px solid var(--nb-ink); margin: 1rem 0; }
.nb-shadow-sm { box-shadow: 6px 6px 0 var(--nb-ink); }

/* Link accent */
.nb-link { color: var(--nb-ink); text-decoration: underline; text-decoration-thickness: 3px; text-underline-offset: 3px; }
.nb-link:hover { background: #111; color: #fff; }

/* Mobile nav */
.nb-burger {
  display: inline-flex; align-items: center; justify-content: center;
  width: 42px; height: 42px; font-size: 1.25rem; line-height: 1;
  background: #fff; color: var(--nb-ink);
  border: 3px solid var(--nb-ink); border-radius: 12px;
  box-shadow: 6px 6px 0 var(--nb-ink); cursor: pointer;
}

@media (min-width: 768px) {
  .nb-burger { display: none; }
}

@media (max-width: 767.98px) {
  .nb-nav { display: none; width: 100%; flex-direction: column; align-items: stretch; gap: 0.75rem; margin-top: 0.75rem; }
  .nb-header.open .nb-nav { display: flex; }
  .nb-nav > li { width: 100%; }
  .nb-has-dropdown > .nb-dd-btn, .nb-nav > li > a { width: 100%; text-align: left; }
  .nb-dropdown { position: static; min-width: 0; margin-top: 0.25rem; }
  .nb-has-dropdown:hover > .nb-dropdown { display: none; }
  .nb-has-dropdown.open > .nb-dropdown { display: block; }
}

/* Mobile popup menu (drawer) */
.nb-mobile-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.25);
  backdrop-filter: blur(1px);
  display: none;
  z-index: 1000;
}
.nb-mobile-panel {
  position: fixed;
  right: 0;
  top: 0;
  bottom: 0;
  width: 85vw;
  max-width: 420px;
  background: var(--nb-card);
  border-left: 4px solid var(--nb-ink);
  border-top: 4px solid var(--nb-ink);
  border-bottom: 4px solid var(--nb-ink);
  box-shadow: -12px 12px 0 var(--nb-ink);
  transform: translateX(120%);
  transition: transform .2s ease-out;
  border-top-left-radius: 20px;
  border-bottom-left-radius: 20px;
  padding: 1rem;
  z-index: 1001;
}
.nb-mobile-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: .75rem; }
.nb-mobile-close { background: #fff; border: 3px solid var(--nb-ink); border-radius: 10px; width: 40px; height: 40px; font-size: 1.25rem; line-height: 1; box-shadow: 6px 6px 0 var(--nb-ink); cursor: pointer; }
.nb-mobile-list { list-style: none; padding: 0; margin: 0; display: grid; gap: .5rem; }
.nb-mobile-list > li > a { display: block; font-weight: 800; padding: .5rem .75rem; border: 3px solid var(--nb-ink); border-radius: 12px; box-shadow: 6px 6px 0 var(--nb-ink); background: #fff; text-decoration: none; color: var(--nb-ink); }
.nb-mobile-list > li > a:hover { background: #111; color: #fff; }

.nb-mobile-acc { border: 3px solid var(--nb-ink); border-radius: 12px; box-shadow: 6px 6px 0 var(--nb-ink); background: #fff; }
.nb-mobile-acc-btn { width: 100%; text-align: left; padding: .5rem .75rem; background: transparent; border: 0; font-weight: 800; cursor: pointer; }
.nb-mobile-acc-body { display: none; padding: .5rem .75rem 1rem; }
.nb-mobile-acc.open .nb-mobile-acc-body { display: block; }
.nb-mobile-acc-body a { display: block; padding: .4rem .5rem; border-radius: 8px; text-decoration: underline; text-decoration-thickness: 3px; text-underline-offset: 3px; color: var(--nb-ink); }
.nb-mobile-acc-body a:hover { background: #111; color: #fff; }

/* Hero CTAs */
.nb-cta { display: inline-flex; align-items: center; gap: .5rem; text-decoration: none; font-weight: 800; padding: .6rem 1rem; background: #fff; color: var(--nb-ink); border: 4px solid var(--nb-ink); border-radius: 14px; box-shadow: 8px 8px 0 var(--nb-ink); transition: transform .12s ease; }
.nb-cta:hover { transform: translate(-2px,-2px); }
.nb-cta.secondary { background: var(--nb-accent); }

/* Hero decorative shapes */
.nb-hero { overflow: hidden; }
.nb-hero-decor { position: absolute; inset: 0; pointer-events: none; }

.nb-star, .nb-blob { position: absolute; }
.nb-star { display: grid; place-items: center; background: #fff; color: var(--nb-ink); border: 3px solid var(--nb-ink); border-radius: 9999px; box-shadow: 6px 6px 0 var(--nb-ink); }
.nb-star span { font-size: 1.25rem; line-height: 1; }
.nb-star.s { width: 34px; height: 34px; }
.nb-star.m { width: 46px; height: 46px; }
.nb-star.l { width: 60px; height: 60px; }

.nb-blob { background: var(--nb-accent); border: 3px solid var(--nb-ink); border-radius: 9999px; box-shadow: 6px 6px 0 var(--nb-ink); opacity: .9; }
.nb-blob.s { width: 26px; height: 26px; }
.nb-blob.m { width: 42px; height: 42px; }
.nb-blob.l { width: 70px; height: 70px; }

/* Additional decor shapes */
.nb-square { background:#fff; border:3px solid var(--nb-ink); box-shadow:6px 6px 0 var(--nb-ink); border-radius:12px; }
.nb-square.s { width:30px; height:30px; }
.nb-square.m { width:46px; height:46px; }
.nb-square.l { width:66px; height:66px; }

.nb-diamond { background: var(--nb-accent); border:3px solid var(--nb-ink); box-shadow:6px 6px 0 var(--nb-ink); width:44px; height:44px; transform: rotate(45deg); border-radius:10px; }

.nb-decor-svg { position:absolute; pointer-events:none; }

/* Stats and tiny chart */
.nb-stat { background:#fff; border:3px solid var(--nb-ink); box-shadow:6px 6px 0 var(--nb-ink); border-radius:14px; padding:.75rem 1rem; min-width:160px; }
.nb-stat-num { font-size:1.75rem; font-weight:900; line-height:1; }
.nb-stat-label { margin-top:.15rem; font-weight:800; }

.nb-chart { background:#fff; border:3px solid var(--nb-ink); box-shadow:6px 6px 0 var(--nb-ink); border-radius:16px; padding:.75rem; max-width:360px; }
.nb-chart-title { font-weight:900; margin-bottom:.25rem; }

/* Float animation */
@keyframes nb-float-y { 0% { transform: translateY(0); } 50% { transform: translateY(-6px); } 100% { transform: translateY(0); } }
.nb-float { animation: nb-float-y 3s ease-in-out infinite; }

/* Open state */
.nb-theme.nb-mobile-open { overflow: hidden; }
.nb-theme.nb-mobile-open .nb-mobile-overlay { display: block; }
.nb-theme.nb-mobile-open .nb-mobile-panel { transform: translateX(0); }

/* Hide overlay on desktop */
@media (min-width: 768px) {
  .nb-mobile-panel { display: none !important; }
}

/* Hero responsive safe area and grid */
.nb-hero { --hero-safe-left: clamp(320px, 54vw, 720px); }
.nb-hero-grid { display: grid; grid-template-columns: 1fr; gap: 1.75rem; min-height: 100%; align-items: center; }
@media (min-width: 768px) { .nb-hero-grid { grid-template-columns: 1.2fr 1fr; gap: 2rem; } }

.nb-hero-decor-right { position: absolute; top: 0; bottom: 0; left: var(--hero-safe-left); right: 0; pointer-events: none; }
.nb-hero-mask-left { width: var(--hero-safe-left); }

@media (max-width: 767.98px) {
  /* reduce clutter on small screens */
  .nb-hero-decor-right .nb-blob.l, .nb-hero-decor-right .nb-star.l { display: none; }
}

/* Hero 2x2 areas layout */
.nb-hero-areas { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
.nb-hero-lt, .nb-hero-lb, .nb-hero-rt, .nb-hero-rb { min-width: 0; }
@media (min-width: 768px) {
  .nb-hero-areas {
    grid-template-columns: 1.1fr 1fr;
    grid-template-areas: "lt rt" "lb rb";
    align-items: start;
    gap: 1.5rem 2rem;
  }
  .nb-hero-lt { grid-area: lt; }
  .nb-hero-lb { grid-area: lb; }
  .nb-hero-rt { grid-area: rt; }
  .nb-hero-rb { grid-area: rb; }
}

/* Scale inner components on large screens */
@media (min-width: 1024px) {
  .nb-hero h1 { font-size: clamp(2.25rem, 3.2vw, 3.75rem); }
  .nb-cta { padding: .75rem 1.25rem; font-size: 1.05rem; }
  .nb-stat { min-width: 190px; padding: 1rem 1.25rem; }
  .nb-stat-num { font-size: 2rem; }
  .nb-chart { max-width: 460px; padding: 1rem; }
  .nb-chart-svg { height: 200px !important; }
}

@media (min-width: 768px) {
  /* Increase hero height and padding */
  .nb-hero { min-height: 65vh; padding: 2.75rem 1.5rem; }
  @media (min-width: 768px) { .nb-hero { min-height: 70vh; padding: 4.5rem 2rem; } }

  /* Enhance base sizes */
  .nb-cta { padding: .7rem 1.1rem; font-size: 1rem; }
  .nb-stat { min-width: 180px; padding: .9rem 1.1rem; }
  .nb-stat-num { font-size: 1.9rem; }
  .nb-chart { max-width: 420px; }

  /* 2x2 grid: make bottom row fill remaining height */
  .nb-hero-areas { grid-template-rows: auto 1fr; }
}

/* Scale up on medium/large screens */
@media (min-width: 768px) {
  .nb-cta { padding: .85rem 1.35rem; font-size: 1.05rem; }
  .nb-chart { max-width: 520px; }
  .nb-chart-svg { height: 220px !important; }
}

@media (min-width: 1280px) {
  .nb-hero h1 { font-size: clamp(2.5rem, 3.6vw, 4.25rem); }
  .nb-cta { padding: 1rem 1.5rem; font-size: 1.125rem; }
  .nb-stat { min-width: 220px; padding: 1.2rem 1.4rem; }
  .nb-stat-num { font-size: 2.25rem; }
  .nb-chart { max-width: 640px; }
  .nb-chart-svg { height: 260px !important; }
}

/* Simplified hero grid and overrides for scalable layout */
.nb-hero { min-height: clamp(320px, 30vh, 860px); }

.nb-hero-grid2 { display: grid; grid-template-columns: 1fr; gap: 1.25rem; align-items: start; }
@media (min-width: 768px) {
  .nb-hero-grid2 { grid-template-columns: 1.15fr 1fr; column-gap: 2rem; row-gap: 1.5rem; }
}

.nb-hero-left { display: grid; gap: 1rem; }
.nb-hero-left .nb-cta { align-self: start; }

.nb-hero-right { display: grid; grid-template-rows: auto 1fr; gap: 1rem; }
.nb-hero-stats { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: flex-start; }
@media (min-width: 768px) { .nb-hero-stats { justify-content: flex-end; } }

.nb-hero-chart { display: grid; align-content: start; }
.nb-hero-chart .nb-chart { width: 100%; max-width: none; }
.nb-hero-chart .nb-chart-svg { width: 100% !important; height: 220px !important; }
@media (min-width: 1024px) { .nb-hero-chart .nb-chart-svg { height: 260px !important; } }

/* Larger CTAs and stats for better fill */
.nb-hero .nb-cta { padding: .9rem 1.25rem; font-size: 1.07rem; }
.nb-hero .nb-stat { min-width: 210px; padding: 1.05rem 1.25rem; }
.nb-hero .nb-stat-num { font-size: 2.1rem; }
@media (min-width: 1280px) {
  .nb-hero .nb-cta { padding: 1rem 1.6rem; font-size: 1.15rem; }
  .nb-hero .nb-stat { min-width: 240px; padding: 1.2rem 1.5rem; }
  .nb-hero .nb-stat-num { font-size: 2.4rem; }
}

/* Inner tiles for content grids (Values, etc.) */
.nb-tile { background:#fff; border:4px solid var(--nb-ink); box-shadow: 10px 10px 0 var(--nb-ink); border-radius: 16px; padding: 1rem; }
@media (min-width: 768px) { .nb-tile { padding: 1.25rem; } }
.nb-tile h3 { font-weight: 900; font-size: 1.125rem; margin-bottom: .35rem; }
.nb-tile p { margin-top: .25rem; }
.nb-tile .nb-cta { margin-top: .75rem; }

/* Values section decorators */
.nb-values { position: relative; overflow: hidden; }
.nb-values-content { position: relative; z-index: 1; }
.nb-values-decor { position: absolute; inset: 0; pointer-events: none; }
@media (max-width: 767.98px) {
  .nb-values-decor .nb-star.l, .nb-values-decor .nb-blob.l { display: none; }
}

/* Hide previous jumbo background words */
.nb-values-word { display:none !important; }

/* Values badges */
.nb-values-badges { display:flex; flex-wrap:wrap; gap:1rem; margin-bottom:1.5rem; }
.nb-values-badge { font-weight:900; font-size:clamp(1.85rem,5vw,3.4rem); padding:.45rem 1.15rem; border:5px solid var(--nb-ink); box-shadow:9px 9px 0 var(--nb-ink); border-radius:28px; background:var(--nb-card); position:relative; line-height:1; letter-spacing:-.02em; }
.nb-values-badge span { display:block; }
.nb-values-badge.ownership { background:linear-gradient(135deg,#fff 0%, #FFE3C4 100%); }
.nb-values-badge.service { background:linear-gradient(135deg,#fff 0%, #CFF7FF 100%); }
.nb-values-badge.freedom { background:linear-gradient(135deg,#fff 0%, #FFD9A8 100%); }
.nb-values-badge:after { content:""; position:absolute; inset:0; border:5px solid var(--nb-ink); border-radius:28px; pointer-events:none; mix-blend-mode:normal; }
@media (max-width: 767.98px){ .nb-values-badge { font-size:clamp(1.6rem,8vw,2.6rem); padding:.4rem .9rem; box-shadow:6px 6px 0 var(--nb-ink); } }

/* Purchase buttons grid */
.nb-buy-grid { display:grid; grid-template-columns:1fr; gap:.75rem; }
@media (min-width: 768px){ .nb-buy-grid { grid-template-columns:repeat(3,1fr); gap:.9rem; } }

.nb-btn { display:inline-flex; align-items:center; justify-content:center; gap:.5rem; width:100%; padding:.7rem 1rem; font-weight:900; border:4px solid var(--nb-ink); border-radius:14px; box-shadow:8px 8px 0 var(--nb-ink); color:#111; text-decoration:none; transition:transform .12s ease; }
.nb-btn:hover { transform: translate(-2px,-2px); }
.nb-btn.orange { background: var(--nb-primary); }
.nb-btn.cyan { background: var(--nb-accent); }
.nb-btn.dark { background:#111; color:#fff; }
.nb-btn.small { padding:.55rem .85rem; font-weight:800; }

/* Enhanced vibrant gradients for store buttons */
.nb-btn-store { background:linear-gradient(135deg,#FF9E2C 0%,#FF6B00 45%,#FF3000 90%); color:#111; }
.nb-btn-store:hover { background:linear-gradient(135deg,#FFB862 0%,#FF8222 45%,#FF4A1E 90%); }
.nb-btn-bbb { background:linear-gradient(135deg,#05E2FF 0%,#22D3EE 50%,#0AB1CB 95%); }
.nb-btn-bbb:hover { background:linear-gradient(135deg,#3BEFFF 0%,#55E4F9 50%,#18C5DE 95%); }
.nb-btn-sx { background:linear-gradient(135deg,#C8B6FF 0%,#A678FF 50%,#6A3DFF 95%); }
.nb-btn-sx:hover { background:linear-gradient(135deg,#D9C8FF 0%,#B68DFF 50%,#7E54FF 95%); }

/* Default channel badge */
.nb-btn-store.default::before { content:"DEFAULT"; position:absolute; top:-10px; left:12px; background:#111; color:#fff; font-size:.55rem; font-weight:800; padding:4px 6px 3px; border:2px solid #111; border-radius:10px; box-shadow:4px 4px 0 #111; letter-spacing:.05em; }
.nb-btn-store.default { position:relative; overflow:visible; }
@media (max-width: 480px){ .nb-btn-store.default::before { display:none; } }

/* Product section structured layout */
.nb-product { background:#fff; border:4px solid var(--nb-ink); box-shadow:12px 12px 0 var(--nb-ink); border-radius:20px; padding:1rem; display:grid; gap:1rem; }
@media (min-width:768px){ .nb-product { padding:1.5rem; } }
.nb-product-head { display:flex; align-items:center; gap:.9rem; }
.nb-product-head img { width:56px; height:56px; border:3px solid var(--nb-ink); border-radius:16px; box-shadow:6px 6px 0 var(--nb-ink); background:#fff; }
@media (min-width:768px){ .nb-product-head img { width:64px; height:64px; } }
.nb-product-grid { display:grid; gap:1rem; }
@media (min-width:768px){ .nb-product-grid { grid-template-columns:1.1fr .9fr; gap:1.25rem; } }
.nb-product-features { background:#FFFBEF; border:3px dashed var(--nb-ink); border-radius:16px; padding:.85rem 1rem; }
.nb-product-actions { display:grid; gap:.75rem; align-content:start; }
.nb-product-actions .nb-buy-grid { margin-top:.25rem; }
.nb-tagline { font-weight:700; font-size:.85rem; letter-spacing:.02em; padding:.35rem .65rem; border:3px solid var(--nb-ink); border-radius:12px; background:var(--nb-accent); box-shadow:5px 5px 0 var(--nb-ink); }
.nb-product h3 { margin:0; }

/* Fix nb-btn-info:hover gradient syntax */
.nb-btn-info:hover { background:linear-gradient(135deg,#6EDAE9 0%,#78E4F3 55%,#A5EFFB 95%); }

/* Testimonials styling to match theme */
.nb-testimonials-grid { display:grid; gap:1rem; }
@media (min-width:768px){ .nb-testimonials-grid { grid-template-columns:repeat(3,1fr); gap:1.25rem; } }
.nb-testimonial { background:#fff; border:4px solid var(--nb-ink); box-shadow:10px 10px 0 var(--nb-ink); border-radius:16px; padding:1rem; position:relative; }
.nb-testimonial .nb-quote { font-weight:800; line-height:1.3; }
.nb-t-author { display:flex; align-items:center; gap:.6rem; margin-top:.75rem; font-weight:800; }
.nb-t-avatar { width:40px; height:40px; border-radius:12px; overflow:hidden; border:3px solid var(--nb-ink); box-shadow:6px 6px 0 var(--nb-ink); background:#fff; }
.nb-t-avatar img { width:100%; height:100%; object-fit:cover; }
.nb-t-stars { font-weight:900; letter-spacing:.05em; margin-top:.5rem; }

/* Contact actions grid */
.nb-actions-grid { display:grid; grid-template-columns:1fr; gap:.75rem; }
@media (min-width:768px){ .nb-actions-grid { grid-template-columns:repeat(4,1fr); gap:.9rem; } }

/* Pricing table */
.nb-pricing .nb-section p { margin-top:.25rem; }
.nb-pricing-grid { display:grid; grid-template-columns:1fr; gap:1rem; }
@media (min-width: 768px){ .nb-pricing-grid { grid-template-columns: repeat(3,1fr); gap:1.25rem; } }

.nb-price { background:#fff; border:4px solid var(--nb-ink); box-shadow:10px 10px 0 var(--nb-ink); border-radius:16px; display:flex; flex-direction:column; min-height:100%; }
.nb-price-head { padding:1rem 1rem .75rem; border-bottom:3px dashed var(--nb-ink); }
.nb-price-name { font-weight:900; font-size:1.25rem; }
.nb-price-note { font-weight:800; font-size:.8rem; opacity:.9; margin-top:.15rem; }
.nb-price-tag { padding: .85rem 1rem; display:flex; align-items:baseline; gap:.4rem; }
.nb-price .amount { font-weight:900; font-size:1.9rem; }
.nb-price .per { font-weight:800; opacity:.85; }

.nb-price-body { padding: .9rem 1rem 1rem; display:flex; flex-direction:column; gap:.75rem; }
.nb-feats { list-style:none; padding:0; margin:0; display:grid; gap:.45rem; }
.nb-feats li { display:flex; align-items:flex-start; gap:.5rem; font-weight:800; }
.nb-feats .ok::before { content:"✔"; display:inline-grid; place-items:center; width:24px; height:24px; border:3px solid var(--nb-ink); border-radius:9999px; background:#CFF7FF; box-shadow:4px 4px 0 var(--nb-ink); font-weight:900; line-height:1; }
.nb-feats .no::before { content:"✕"; display:inline-grid; place-items:center; width:24px; height:24px; border:3px solid var(--nb-ink); border-radius:9999px; background:#FFD9A8; box-shadow:4px 4px 0 var(--nb-ink); font-weight:900; line-height:1; }

.nb-plan-actions { margin-top:auto; padding-top:.75rem; display:grid; grid-template-columns:1fr; gap:.6rem; }
@media (min-width: 420px){ .nb-plan-actions { grid-template-columns:repeat(2,1fr); } }

/* Plan color accents */
.nb-price.self .nb-price-head { background:linear-gradient(135deg,#fff 0%,#FFE8CC 100%); }
.nb-price.managed .nb-price-head { background:linear-gradient(135deg,#fff 0%,#CFF7FF 100%); }
.nb-price.plus .nb-price-head { background:linear-gradient(135deg,#fff 0%,#FFD3B8 100%); }

/* Self Hosted box size tweak */
.nb-price.self { box-shadow:8px 8px 0 var(--nb-ink); }
.nb-price.self .nb-price-head { padding:.65rem .7rem .45rem; }
.nb-price.self .nb-price-tag { padding:.6rem .7rem; }
.nb-price.self .nb-price-body { padding:.55rem .7rem .65rem; }
.nb-price.self .nb-price-name { font-size:1.1rem; }
.nb-price.self .nb-footnote, .nb-price.self .nb-price-note { font-size:.68rem; }

/* Popular ribbon */
.nb-ribbon { position:relative; }
.nb-ribbon .nb-popular { position:absolute; top:-12px; right:12px; background:#111; color:#fff; border:3px solid var(--nb-ink); border-radius:12px; padding:.25rem .5rem; font-weight:900; box-shadow:6px 6px 0 var(--nb-ink); }

/* Subtle footnote */
.nb-footnote { font-size:.85rem; opacity:.9; }

/* Inline controls for selects + buttons */
.nb-inline-controls { display:grid; grid-template-columns: 1fr; gap:.5rem; }
@media (min-width: 420px){ .nb-inline-controls { grid-template-columns: 1fr auto; align-items: center; } }

.nb-select { appearance:none; -webkit-appearance:none; background:#fff; color:#111; font-weight:800; padding:.6rem .9rem; border:4px solid var(--nb-ink); border-radius:14px; box-shadow:8px 8px 0 var(--nb-ink); background-image: linear-gradient(45deg, transparent 50%, #111 50%), linear-gradient(135deg, #111 50%, transparent 50%); background-position: calc(100% - 22px) calc(1.05rem), calc(100% - 14px) calc(1.05rem); background-size: 8px 8px, 8px 8px; background-repeat: no-repeat; }
.nb-select:focus { outline: none; box-shadow: 10px 10px 0 var(--nb-ink); }

/* Modal (product chooser) */
.nb-modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.35); backdrop-filter: blur(1px); display:none; z-index:1200; }
.nb-modal { position:fixed; top:50%; left:50%; transform:translate(-50%,-50%); width:min(92vw,560px); background:var(--nb-card); border:4px solid var(--nb-ink); box-shadow:12px 12px 0 var(--nb-ink); border-radius:16px; padding:1rem; display:none; z-index:1201; }
.nb-modal.open { display:block; }
.nb-modal-overlay.open { display:block; }
.nb-modal h3 { font-weight:900; }
.nb-modal .nb-modal-actions { display:grid; grid-template-columns:1fr; gap:.6rem; }
@media (min-width:768px){ .nb-modal .nb-modal-actions { grid-template-columns:repeat(2,1fr); gap:.75rem; } }

/* Hero overflow variant for showcasing large screenshots */
.nb-hero--spill { overflow: visible; }

/* Themed screenshot card */
.nb-screenshot { position: relative; background:#fff; border:4px solid var(--nb-ink); border-radius:18px; box-shadow:12px 12px 0 var(--nb-ink); overflow:hidden; }
.nb-screenshot img { display:block; width:100%; height:auto; }

/* Larger, slightly rotated screenshot that can extend beyond hero border on desktop */
.nb-screenshot.is-large { width:112%; max-width:none; transform: translate(6%, 6%) rotate(-2deg); }
@media (max-width: 767.98px){
  .nb-screenshot.is-large { width:100%; transform:none; }
}

/* Optional accent behind the screenshot for depth */
.nb-screenshot.is-large::after { content:""; position:absolute; inset:auto -12px -12px auto; width:120px; height:120px; background:var(--nb-accent); border:4px solid var(--nb-ink); box-shadow:8px 8px 0 var(--nb-ink); border-radius:20px; transform: rotate(8deg); opacity:.85; }
@media (max-width: 767.98px){ .nb-screenshot.is-large::after { display:none; } }
