@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=Inter:wght@400;500;600;700&display=swap');

/* ---------------------------------------------------------------------
   1. DESIGN TOKENS
   --------------------------------------------------------------------- */
:root {
    --pa-indigo:        #393185;
    --pa-indigo-deep:   #2c256b;
    --pa-indigo-tint:   #ecebf4;
    --pa-ink:           #1c1a2c;
    --pa-slate:         #5b5970;
    --pa-slate-soft:    #87849a;
    --pa-paper:         #f8f6f0;
    --pa-surface:       #ffffff;
    --pa-line:          #e7e3d7;
    --pa-line-strong:   #d9d3c2;
    --pa-brass:         #b08d57;
    --pa-brass-deep:    #91723e;
    --pa-success:       #2e7d32;
    --pa-danger:        #c0392b;

    --pa-serif: 'DM Serif Display', Georgia, 'Times New Roman', serif;
    --pa-sans:  'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;

    --pa-shell:        1140px;
    --pa-shell-narrow: 780px;
    --pa-shell-wide:   1280px;
    --pa-gutter:       clamp(1.25rem, 5vw, 3rem);

    --pa-radius:      16px;
    --pa-radius-sm:   8px;
    --pa-radius-pill: 999px;

    --pa-shadow-soft: 0 1px 2px rgba(28,26,44,.05), 0 12px 30px -20px rgba(28,26,44,.4);
    --pa-shadow-card: 0 1px 2px rgba(28,26,44,.05), 0 26px 50px -28px rgba(28,26,44,.45);

    --pa-subnav-h:      62px;
    --pa-scroll-offset: 86px;

    --pa-ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------------------------------------------------------------------
   2. OPT-IN BASE
   Add the class `pa-scope` to a page/template wrapper to inherit the
   polished typography. (The trainings & events templates use their own
   `.pa-training` wrapper, which carries an equivalent base.)
   --------------------------------------------------------------------- */
.pa-scope {
    font-family: var(--pa-sans);
    font-size: 17px;
    line-height: 1.65;
    color: var(--pa-ink);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
.pa-scope *,
.pa-scope *::before,
.pa-scope *::after { box-sizing: border-box; }

.pa-scope h1,
.pa-scope h2,
.pa-scope h3,
.pa-scope h4 {
    font-family: var(--pa-serif);
    font-weight: 400;          /* DM Serif Display ships a single weight */
    line-height: 1.14;
    margin: 0;
    /* colour intentionally omitted: headings inherit --pa-ink from
       .pa-scope, so single-class component selectors (white hero / CTA
       titles, etc.) win without a specificity fight. */
}
.pa-scope p   { margin: 0; }
.pa-scope img { max-width: 100%; height: auto; }

.pa-scope a:focus-visible,
.pa-scope button:focus-visible,
.pa-scope input:focus-visible,
.pa-scope select:focus-visible,
.pa-scope textarea:focus-visible {
    outline: 2px solid var(--pa-brass);
    outline-offset: 2px;
}

html { scroll-behavior: smooth; }

/* ---------------------------------------------------------------------
   3. LAYOUT PRIMITIVES
   --------------------------------------------------------------------- */
.pa-section {
    padding-block: clamp(3.25rem, 7vw, 6rem);
    scroll-margin-top: calc(var(--pa-header-h, 100px) + var(--pa-subnav-h) + 1.25rem);
    background-color: var(--pa-paper);
    background-image:
        radial-gradient(42rem 34rem at 100% -12%, rgba(57,49,133,.06), transparent 70%),
        radial-gradient(38rem 32rem at 0% 112%, rgba(176,141,87,.05), transparent 72%);
    background-repeat: no-repeat;
}
.pa-section--surface { background-color: var(--pa-surface); }
.pa-section--tint    { background-color: var(--pa-indigo-tint); }

.pa-shell {
    width: 100%;
    max-width: var(--pa-shell);
    margin-inline: auto;
    padding-inline: var(--pa-gutter);
}
.pa-shell--narrow { max-width: var(--pa-shell-narrow); }
.pa-shell--wide   { max-width: var(--pa-shell-wide); }

/* ---------------------------------------------------------------------
   4. BUTTONS
   --------------------------------------------------------------------- */
.pa-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .55em;
    font-family: var(--pa-sans);
    font-size: .82rem;
    font-weight: 600;
    letter-spacing: .045em;
    text-transform: uppercase;
    text-decoration: none;
    line-height: 1;
    cursor: pointer;
    padding: 1em 1.9em;
    border-radius: var(--pa-radius-sm);
    border: 1px solid transparent;
    transition: transform .25s var(--pa-ease),
                background-color .25s var(--pa-ease),
                border-color .25s var(--pa-ease),
                color .25s var(--pa-ease),
                box-shadow .25s var(--pa-ease);
}
.pa-btn:hover  { transform: translateY(-2px); }
.pa-btn:active { transform: translateY(0); }

.pa-btn--primary {
    background: var(--pa-indigo);
    color: #fff;
    box-shadow: 0 12px 26px -16px rgba(57,49,133,.95);
}
.pa-btn--primary:hover { background: var(--pa-indigo-deep); color: #fff; }

.pa-btn--ghost {
    background: transparent;
    color: var(--pa-indigo);
    border-color: var(--pa-line-strong);
}
.pa-btn--ghost:hover {
    border-color: var(--pa-indigo);
    background: var(--pa-surface);
    color: var(--pa-indigo);
}

.pa-btn--on-ink { background: #fff; color: var(--pa-indigo); }
.pa-btn--on-ink:hover { background: var(--pa-brass); color: #fff; }

/* outline button that reads on a dark background */
.pa-btn--hero-line {
    background: transparent;
    color: #fff;
    border-color: rgba(255,255,255,.45);
}
.pa-btn--hero-line:hover {
    background: #fff;
    color: var(--pa-indigo);
    border-color: #fff;
}

.pa-btn--whatsapp { background: #25d366; color: #fff; }
.pa-btn--whatsapp:hover { background: #1eb858; color: #fff; }

.pa-btn--block { width: 100%; }

.pa-btn .gb-shape svg,
.pa-btn svg { width: 1.05em; height: 1.05em; }

@keyframes pa-pulse {
    0%   { box-shadow: 0 0 0 0 rgba(176,141,87,.7); }
    70%  { box-shadow: 0 0 0 12px rgba(176,141,87,0); }
    100% { box-shadow: 0 0 0 0 rgba(176,141,87,0); }
}
.pa-btn--pulse { animation: pa-pulse 2.4s infinite; }

/* ---------------------------------------------------------------------
   5. EYEBROW + SECTION HEAD
   --------------------------------------------------------------------- */
.pa-eyebrow {
    display: flex;
    align-items: center;
    gap: .6em;
    font-family: var(--pa-sans);
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--pa-brass-deep);
    margin: 0;
}
.pa-eyebrow::before {
    content: "";
    width: 1.7em;
    height: 1px;
    background: var(--pa-brass);
    flex: none;
}

.pa-section__head {
    max-width: 46rem;
    margin-bottom: clamp(1.75rem, 4vw, 3rem);
}
.pa-section__title {
    font-family: var(--pa-serif);
    font-weight: 400;
    color: var(--pa-ink);
    font-size: clamp(1.95rem, 4vw, 2.95rem);
    line-height: 1.14;
    letter-spacing: -.012em;
    margin: .55rem 0 0;
}
.pa-section__intro {
    margin-top: 1rem;
    font-size: 1.08rem;
    color: var(--pa-slate);
}

/* ---------------------------------------------------------------------
   6. PROSE + CHECKLISTS
   --------------------------------------------------------------------- */
.pa-prose {
    font-size: 1.06rem;
    line-height: 1.72;
    color: var(--pa-slate);
}
.pa-prose > :first-child { margin-top: 0; }
.pa-prose p { margin: 0 0 1.15rem; }
.pa-prose p:last-child { margin-bottom: 0; }
.pa-prose strong { color: var(--pa-ink); font-weight: 600; }
.pa-prose a {
    color: var(--pa-indigo);
    text-decoration: underline;
    text-underline-offset: 2px;
}
.pa-prose ul {
    list-style: none;
    margin: 1.3rem 0;
    padding: 0;
    display: grid;
    gap: .75rem;
}
.pa-prose ul li {
    position: relative;
    padding-left: 1.9rem;
    color: var(--pa-ink);
}
.pa-prose ul li::before {       /* brass diamond marker */
    content: "";
    position: absolute;
    left: .15rem;
    top: .55em;
    width: .5rem;
    height: .5rem;
    background: var(--pa-brass);
    transform: rotate(45deg);
}
/* check-mark variant — add `pa-prose--check` to the rich-text block */
.pa-prose--check ul li::before {
    content: "";
    left: 0;
    top: .28em;
    width: 1.1rem;
    height: 1.1rem;
    background: var(--pa-indigo-tint);
    border-radius: 50%;
    transform: none;
}
.pa-prose--check ul li::after {
    content: "";
    position: absolute;
    left: .34rem;
    top: .56em;
    width: .42rem;
    height: .22rem;
    border-left: 2px solid var(--pa-indigo);
    border-bottom: 2px solid var(--pa-indigo);
    transform: rotate(-45deg);
}
/* two-column list — add `pa-prose--cols` to the rich-text block */
.pa-prose--cols ul { grid-template-columns: repeat(2, 1fr); gap: .75rem 2.25rem; }

@media (max-width: 880px) {
    .pa-prose--cols ul { grid-template-columns: 1fr; }
}

/* ---------------------------------------------------------------------
   7. FAQ ACCORDION  (restyled GenerateBlocks Pro accordion)
   Wrap a `generateblocks-pro/accordion` in a `.pa-faq` element.
   --------------------------------------------------------------------- */
.pa-faq .gb-accordion { display: grid; gap: .65rem; }
.pa-faq .gb-accordion__item {
    margin: 0;
    padding: 0;
    background: var(--pa-surface);
    border: none;
    border-radius: var(--pa-radius-sm);
    box-shadow: var(--pa-shadow-soft);
    overflow: hidden;
    transition: box-shadow .2s var(--pa-ease);
}
.pa-faq .gb-accordion__item:hover { box-shadow: var(--pa-shadow-card); }
.pa-faq .gb-accordion__toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.1rem 1.4rem;
    cursor: pointer;
    font-family: var(--pa-sans);
    font-weight: 600;
    font-size: 1rem;
    color: var(--pa-ink);
    transition: color .2s var(--pa-ease);
}
.pa-faq .gb-accordion__toggle:hover { color: var(--pa-indigo); }
.pa-faq .gb-accordion__toggle-icon { flex: none; color: var(--pa-brass-deep); }
.pa-faq .gb-accordion__toggle-icon svg { width: 1.05rem; height: 1.05rem; }
.pa-faq .gb-accordion__content { padding: 0 1.4rem 1.3rem; }
.pa-faq .gb-accordion__content .pa-prose,
.pa-faq .gb-accordion__content .gb-text,
.pa-faq .gb-accordion__content p { color: var(--pa-slate); }
.pa-faq .gb-accordion__content p { margin: 0; }

/* ---------------------------------------------------------------------
   8. MOTION PREFERENCES
   --------------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
    .pa-scope *,
    .pa-scope *::before,
    .pa-scope *::after {
        transition-duration: .01ms !important;
        animation-duration: .01ms !important;
        animation-iteration-count: 1 !important;
    }
    .pa-btn--pulse { animation: none; }
}
