/* ============================================================
       NATUREJAB - BRAND RESOURCES DOWNLOAD GATE
       Webflow embed: drop into /brand-resources page
       Scoped to .nj-brg to avoid all Webflow conflicts
       ============================================================ */

    .nj-brg, .nj-brg * { box-sizing: border-box; }
    .nj-brg {
      font-family: "Bitter", Georgia, serif;
      -webkit-font-smoothing: antialiased;
      color: #F3EFE3;
    }

    /* ══════════════════════════════════════
       GATE SECTION - shown before consent
    ══════════════════════════════════════ */
    .nj-brg-gate {
      width: 100%;
      background: #0D0E0A;
      position: relative;
      overflow: hidden;
      padding: clamp(80px, 10vh, 120px) 32px clamp(80px, 10vh, 120px);
    }

    /* Ambient glows */
    .nj-brg-gate::before {
      content: "";
      position: absolute;
      width: 800px; height: 600px;
      left: -200px; top: -120px;
      background: radial-gradient(ellipse at center, rgba(93,186,99,0.07) 0%, transparent 62%);
      pointer-events: none;
    }
    .nj-brg-gate::after {
      content: "";
      position: absolute;
      width: 600px; height: 500px;
      right: -100px; bottom: -100px;
      background: radial-gradient(ellipse at center, rgba(255,91,31,0.06) 0%, transparent 62%);
      pointer-events: none;
    }

    /* Grain overlay */
    .nj-brg-grain {
      position: absolute;
      inset: 0;
      pointer-events: none;
      opacity: 0.028;
      background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
      background-size: 200px 200px;
      z-index: 0;
    }

    .nj-brg-inner {
      position: relative;
      z-index: 1;
      max-width: 680px;
      margin: 0 auto;
    }

    /* ── Eyebrow ── */
    .nj-brg-eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 12px;
      padding: 6px 14px;
      border: 1px solid #2A2B24;
      background: rgba(93,186,99,0.06);
      font-family: "JetBrains Mono", monospace;
      font-size: 11px;
      letter-spacing: 3px;
      text-transform: uppercase;
      font-weight: 700;
      color: #5DBA63;
      margin-bottom: 32px;
    }
    .nj-brg-eyebrow .sep { color: #54524A; }

    /* ── Headline ── */
    .nj-brg-headline {
      font-family: "Archivo Black", sans-serif;
      font-weight: 900;
      font-size: clamp(38px, 5vw, 62px);
      letter-spacing: -2px;
      line-height: 0.96;
      text-transform: uppercase;
      color: #F3EFE3;
      margin: 0 0 24px;
    }
    .nj-brg-headline .accent { color: #5DBA63; }

    /* ── Subhead ── */
    .nj-brg-sub {
      font-family: "Bitter", serif;
      font-size: 17px;
      line-height: 1.68;
      color: #A8A393;
      margin: 0 0 48px;
      max-width: 540px;
    }
    .nj-brg-sub strong { color: #F3EFE3; font-weight: 600; }

    /* ── Panel (form card) ── */
    .nj-brg-panel {
      background: #14150F;
      border: 1px solid #2A2B24;
      padding: 48px 44px 44px;
    }

    .nj-brg-panel-eyebrow {
      font-family: "JetBrains Mono", monospace;
      font-size: 10px;
      letter-spacing: 3px;
      text-transform: uppercase;
      font-weight: 700;
      color: #5DBA63;
      margin-bottom: 28px;
      display: flex;
      align-items: center;
      gap: 10px;
    }
    .nj-brg-panel-eyebrow::after {
      content: "";
      flex: 1;
      height: 1px;
      background: #2A2B24;
    }

    /* ── Form fields ── */
    .nj-brg-field {
      display: flex;
      flex-direction: column;
      gap: 8px;
      margin-bottom: 24px;
    }

    .nj-brg-label {
      font-family: "JetBrains Mono", monospace;
      font-size: 11px;
      letter-spacing: 2px;
      text-transform: uppercase;
      font-weight: 700;
      color: #A8A393;
    }
    .nj-brg-label .req { color: #FF5B1F; margin-left: 2px; }

    .nj-brg-input {
      width: 100%;
      background: #1A1B15;
      border: 1px solid #2A2B24;
      color: #F3EFE3;
      font-family: "JetBrains Mono", monospace;
      font-size: 16px;
      letter-spacing: 0.4px;
      padding: 14px 16px;
      border-radius: 0;
      outline: none;
      transition: border-color 0.2s;
      -webkit-appearance: none;
    }
    .nj-brg-input:focus {
      border-color: #5DBA63;
    }
    .nj-brg-input::placeholder {
      color: #54524A;
    }

    /* ── Consent block ── */
    .nj-brg-consent-wrap {
      background: rgba(93,186,99,0.04);
      border: 1px solid #2A2B24;
      padding: 20px 20px;
      margin-bottom: 8px;
    }
    .nj-brg-consent-row {
      display: flex;
      gap: 14px;
      align-items: flex-start;
    }

    .nj-brg-checkbox {
      width: 20px;
      height: 20px;
      border: 1px solid #2A2B24;
      flex-shrink: 0;
      margin-top: 1px;
      cursor: pointer;
      appearance: none;
      -webkit-appearance: none;
      background: #1A1B15;
      position: relative;
      border-radius: 0;
      transition: background 0.15s, border-color 0.15s;
    }
    .nj-brg-checkbox:focus {
      outline: 2px solid #5DBA63;
      outline-offset: 2px;
    }
    .nj-brg-checkbox:checked {
      background: #5DBA63;
      border-color: #5DBA63;
    }
    .nj-brg-checkbox:checked::after {
      content: "";
      position: absolute;
      top: 3px;
      left: 6px;
      width: 5px;
      height: 9px;
      border-right: 2px solid #0D0E0A;
      border-bottom: 2px solid #0D0E0A;
      transform: rotate(45deg);
    }

    .nj-brg-consent-text {
      font-family: "Bitter", serif;
      font-size: 13.5px;
      line-height: 1.6;
      color: #A8A393;
      cursor: pointer;
    }
    .nj-brg-consent-text strong {
      color: #F3EFE3;
      font-weight: 600;
    }

    /* ── Error message ── */
    .nj-brg-error {
      display: none;
      font-family: "JetBrains Mono", monospace;
      font-size: 11px;
      letter-spacing: 1px;
      text-transform: uppercase;
      color: #FF5B1F;
      padding: 10px 14px;
      background: rgba(255,91,31,0.06);
      border: 1px solid rgba(255,91,31,0.2);
      margin-top: 12px;
    }
    .nj-brg-error.is-visible { display: block; }

    /* ── Submit button ── */
    .nj-brg-actions {
      margin-top: 32px;
    }

    .nj-brg-btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 12px;
      width: 100%;
      padding: 16px 28px;
      background: #5DBA63;
      color: #0D0E0A;
      font-family: "JetBrains Mono", monospace;
      font-size: 13px;
      font-weight: 700;
      letter-spacing: 1.5px;
      text-transform: uppercase;
      border: 1px solid #5DBA63;
      border-radius: 0;
      cursor: pointer;
      transition: opacity 0.15s ease;
    }
    .nj-brg-btn:hover:not(:disabled) { opacity: 0.85; }
    .nj-brg-btn:disabled {
      opacity: 0.5;
      cursor: not-allowed;
    }
    .nj-brg-btn-arrow {
      display: inline-block;
      transition: transform 0.15s ease;
    }
    .nj-brg-btn:hover:not(:disabled) .nj-brg-btn-arrow {
      transform: translateX(2px);
    }

    .nj-brg-foot {
      text-align: center;
      font-family: "JetBrains Mono", monospace;
      font-size: 10px;
      letter-spacing: 2px;
      text-transform: uppercase;
      color: #54524A;
      margin-top: 16px;
    }

    /* ══════════════════════════════════════
       ASSET GRID - hidden until gate passes
    ══════════════════════════════════════ */
    .nj-brg-assets {
      display: none;
      width: 100%;
      background: #0D0E0A;
      padding: clamp(72px, 9vh, 104px) 32px clamp(72px, 9vh, 104px);
      position: relative;
      overflow: hidden;
    }
    .nj-brg-assets.is-unlocked { display: block; }

    .nj-brg-assets::before {
      content: "";
      position: absolute;
      inset: 0;
      background: radial-gradient(ellipse 50% 40% at 50% 20%, rgba(93,186,99,0.055) 0%, transparent 65%);
      pointer-events: none;
    }

    .nj-brg-assets-inner {
      position: relative;
      z-index: 1;
      max-width: 1216px;
      margin: 0 auto;
    }

    /* ── Assets header ── */
    .nj-brg-assets-header {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      flex-wrap: wrap;
      gap: 24px;
      margin-bottom: 48px;
      padding-bottom: 32px;
      border-bottom: 1px solid #2A2B24;
    }

    .nj-brg-assets-title-group {}

    .nj-brg-assets-eyebrow {
      font-family: "JetBrains Mono", monospace;
      font-size: 10px;
      letter-spacing: 3px;
      text-transform: uppercase;
      font-weight: 700;
      color: #5DBA63;
      margin-bottom: 12px;
      display: flex;
      align-items: center;
      gap: 10px;
    }

    /* Green dot indicator */
    .nj-brg-dot {
      width: 8px;
      height: 8px;
      background: #5DBA63;
      border-radius: 50%;
      flex-shrink: 0;
      animation: njBrgPulse 2s ease infinite;
    }
    @keyframes njBrgPulse {
      0%, 100% { opacity: 1; }
      50% { opacity: 0.4; }
    }

    .nj-brg-assets-title {
      font-family: "Archivo Black", sans-serif;
      font-weight: 900;
      font-size: clamp(30px, 3.8vw, 48px);
      letter-spacing: -1.4px;
      line-height: 1;
      text-transform: uppercase;
      color: #F3EFE3;
      margin: 0;
    }

    .nj-brg-access-tag {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 8px 16px;
      background: rgba(93,186,99,0.08);
      border: 1px solid rgba(93,186,99,0.3);
      font-family: "JetBrains Mono", monospace;
      font-size: 11px;
      letter-spacing: 2px;
      text-transform: uppercase;
      font-weight: 700;
      color: #5DBA63;
      flex-shrink: 0;
    }

    /* ── Download grid ── */
    .nj-brg-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 20px;
      margin-bottom: 48px;
    }

    .nj-brg-card {
      background: #14150F;
      border: 1px solid #2A2B24;
      padding: 36px 28px 28px;
      display: flex;
      flex-direction: column;
      gap: 0;
      transition: border-color 0.2s;
    }
    .nj-brg-card:hover { border-color: rgba(93,186,99,0.5); }

    .nj-brg-card-icon {
      width: 48px;
      height: 48px;
      display: flex;
      align-items: center;
      justify-content: center;
      background: rgba(93,186,99,0.08);
      border: 1px solid #2A2B24;
      margin-bottom: 20px;
      flex-shrink: 0;
    }
    .nj-brg-card-icon svg {
      width: 22px;
      height: 22px;
    }

    .nj-brg-card-tag {
      font-family: "JetBrains Mono", monospace;
      font-size: 10px;
      letter-spacing: 2.5px;
      text-transform: uppercase;
      font-weight: 700;
      color: #5DBA63;
      margin-bottom: 8px;
    }

    .nj-brg-card-title {
      font-family: "Archivo Black", sans-serif;
      font-weight: 900;
      font-size: 19px;
      letter-spacing: -0.4px;
      line-height: 1.1;
      text-transform: uppercase;
      color: #F3EFE3;
      margin: 0 0 10px;
    }

    .nj-brg-card-desc {
      font-family: "Bitter", serif;
      font-size: 13.5px;
      line-height: 1.6;
      color: #A8A393;
      margin: 0 0 24px;
      flex: 1;
    }

    .nj-brg-card-meta {
      display: flex;
      align-items: center;
      gap: 10px;
      padding-top: 16px;
      border-top: 1px solid #2A2B24;
      margin-bottom: 18px;
    }
    .nj-brg-card-size {
      font-family: "JetBrains Mono", monospace;
      font-size: 10px;
      letter-spacing: 1.5px;
      text-transform: uppercase;
      color: #54524A;
      font-weight: 600;
    }
    .nj-brg-card-format {
      font-family: "JetBrains Mono", monospace;
      font-size: 10px;
      letter-spacing: 1.5px;
      text-transform: uppercase;
      color: #54524A;
      font-weight: 600;
    }
    .nj-brg-card-divider {
      width: 1px;
      height: 12px;
      background: #2A2B24;
    }

    .nj-brg-download-btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      width: 100%;
      padding: 13px 20px;
      background: transparent;
      border: 1px solid #2A2B24;
      color: #A8A393;
      font-family: "JetBrains Mono", monospace;
      font-size: 11.5px;
      font-weight: 700;
      letter-spacing: 1.5px;
      text-transform: uppercase;
      text-decoration: none;
      border-radius: 0;
      cursor: pointer;
      transition: border-color 0.2s, color 0.2s, background 0.2s;
    }
    .nj-brg-download-btn:hover {
      border-color: #5DBA63;
      color: #5DBA63;
      background: rgba(93,186,99,0.06);
    }
    .nj-brg-download-btn svg {
      width: 14px;
      height: 14px;
      flex-shrink: 0;
    }

    /* ── Usage terms notice ── */
    .nj-brg-terms-notice {
      background: #14150F;
      border: 1px solid #2A2B24;
      padding: 28px 32px;
      display: flex;
      gap: 20px;
      align-items: flex-start;
    }
    .nj-brg-terms-icon {
      flex-shrink: 0;
      width: 36px;
      height: 36px;
      display: flex;
      align-items: center;
      justify-content: center;
      background: rgba(255,91,31,0.08);
      border: 1px solid rgba(255,91,31,0.2);
    }
    .nj-brg-terms-icon svg {
      width: 16px;
      height: 16px;
    }
    .nj-brg-terms-text {
      font-family: "JetBrains Mono", monospace;
      font-size: 11px;
      letter-spacing: 0.8px;
      line-height: 1.7;
      color: #54524A;
      text-transform: uppercase;
    }
    .nj-brg-terms-text strong {
      color: #A8A393;
      font-weight: 700;
    }

    /* ══════════════════════════════════════
       RETURNING USER - Already consented
    ══════════════════════════════════════ */
    .nj-brg-returning {
      display: none;
      text-align: center;
      padding: 32px;
      background: rgba(93,186,99,0.05);
      border: 1px solid rgba(93,186,99,0.2);
      margin-bottom: 32px;
    }
    .nj-brg-returning.is-visible { display: block; }
    .nj-brg-returning-text {
      font-family: "JetBrains Mono", monospace;
      font-size: 11px;
      letter-spacing: 2px;
      text-transform: uppercase;
      color: #5DBA63;
      font-weight: 700;
    }

    /* ══════════════════════════════════════
       RESPONSIVE
    ══════════════════════════════════════ */
    @media (max-width: 960px) {
      .nj-brg-grid { grid-template-columns: 1fr 1fr; }
    }
    @media (max-width: 640px) {
      .nj-brg-gate { padding: 72px 22px; }
      .nj-brg-panel { padding: 36px 24px 32px; }
      .nj-brg-assets { padding: 64px 22px; }
      .nj-brg-grid { grid-template-columns: 1fr; gap: 16px; }
      .nj-brg-assets-header { flex-direction: column; gap: 16px; }
    }
    @media (max-width: 380px) {
      .nj-brg-headline { font-size: 34px; }
    }
