@charset "UTF-8";
/* ============================================================
   PromedQarax — self-contained widget design system
   Scope:   .ds-pmq-scope  (täysin eristetty; EI riippuvuutta editorialista)
   Käyttö:  PromedQarax ja muut warm human-tech -sivut
   Värit:   ACF site_color_* (--ds-color-*) + brändifallbackit
   HUOM:    Footerin (.ds-footalt) ja body-taustan tyylit pidetään
            sivukohtaisina (ACF site_custom_css), koska alternate-footer
            on jaettu teema-template eikä sitä saa värittää globaalisti.
   ============================================================ */

.ds-pmq-scope {
    /* Palette — ACF-vetoinen, brändifallbackit (Theme A: vihreä/minttu/kulta) */
    --ds-pmq-primary:      var(--ds-color-primary, #2F7A68);
    --ds-pmq-primary-dark: var(--ds-color-primary-dark, #16433A);
    --ds-pmq-primary-deep: #1E5247;          /* vihreän ramppi (gradientit, eyebrow) */
    --ds-pmq-accent:       var(--ds-color-accent, #E8A33D);
    --ds-pmq-accent-dark:  #cf8c28;
    --ds-pmq-ink:          #14201C;
    --ds-pmq-ink-soft:     #3C544C;
    --ds-pmq-mint:         #F4FBF8;
    --ds-pmq-mint-2:       #E2F4EC;
    --ds-pmq-mint-bright:  #7FE3C4;          /* kirkas korostusminttu */
    --ds-pmq-line:         rgba(20, 32, 28, .10);
    --ds-pmq-line-strong:  rgba(20, 66, 55, .20);
    --ds-pmq-bg:           #FFFFFF;
    --ds-pmq-on-primary:   #FFFFFF;

    /* Typography — warm sans, no serif */
    --ds-pmq-f-head: "Plus Jakarta Sans", -apple-system, "Segoe UI", "Helvetica Neue", Arial, sans-serif;
    --ds-pmq-f-body: "Inter", -apple-system, "Segoe UI", "Helvetica Neue", Arial, sans-serif;

    /* Spacing (8pt) */
    --ds-pmq-s-1: 8px;  --ds-pmq-s-2: 16px; --ds-pmq-s-3: 24px; --ds-pmq-s-4: 32px;
    --ds-pmq-s-5: 48px; --ds-pmq-s-6: 64px; --ds-pmq-s-7: 96px; --ds-pmq-s-8: 128px;

    --ds-pmq-container: 1280px;
    --ds-pmq-container-wide: 1340px;
    --ds-pmq-container-narrow: 860px;
    --ds-pmq-radius: 20px;
    --ds-pmq-radius-sm: 12px;

    color: var(--ds-pmq-ink);
    font-family: var(--ds-pmq-f-body);
    font-size: 17px;
    line-height: 1.65;
    -webkit-font-smoothing: antialiased;
    width: 100%;
}

/* Full-bleed: pmq-osiot levittyvät reunasta reunaan, sisältö .ds-pmq-container:issa
   keskitettynä. Korjaa Elementorin globaalin content-width (1140px) -kuristuksen,
   joka muuten jättäisi sisällön kapeaksi. Scoped .ds-pmq-scope:een → muut teeman
   sivut (editorial ym.) eivät muutu. Toimii kun osio on keskitetyssä sarakkeessa
   (PromedQaraxin kaikki pmq-widgetit ovat col-100-osioissa). */
.ds-pmq-scope .ds-pmq-section { margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); }

.ds-pmq-scope *,
.ds-pmq-scope *::before,
.ds-pmq-scope *::after { box-sizing: border-box; }

/* ---------- Typography ---------- */
.ds-pmq-scope .ds-pmq-h1,
.ds-pmq-scope .ds-pmq-h2,
.ds-pmq-scope .ds-pmq-h3 {
    font-family: var(--ds-pmq-f-head);
    font-weight: 600;
    letter-spacing: -0.02em;
    margin: 0;
    color: var(--ds-pmq-ink);
    line-height: 1.1;
}
.ds-pmq-scope .ds-pmq-h1 { font-size: clamp(38px, 6vw, 72px); line-height: 1.06; letter-spacing: -0.03em; }
.ds-pmq-scope .ds-pmq-h1 em {
    font-style: normal;
    background: linear-gradient(120deg, var(--ds-pmq-primary), var(--ds-pmq-primary-dark));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.ds-pmq-scope .ds-pmq-h2 { font-size: clamp(28px, 3.8vw, 46px); line-height: 1.12; }
.ds-pmq-scope .ds-pmq-h3 { font-size: 21px; line-height: 1.25; }

.ds-pmq-scope .ds-pmq-h1,
.ds-pmq-scope .ds-pmq-h2,
.ds-pmq-scope .ds-pmq-band__title,
.ds-pmq-scope .ds-pmq-quote__text { text-wrap: balance; }
.ds-pmq-scope p { text-wrap: pretty; }

.ds-pmq-scope .ds-pmq-eyebrow {
    font-family: var(--ds-pmq-f-body);
    font-size: 13px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--ds-pmq-primary-deep);
    font-weight: 600;
    margin: 0 0 var(--ds-pmq-s-2);
    display: inline-block;
    background: var(--ds-pmq-mint-2);
    padding: 7px 14px;
    border-radius: 999px;
}
.ds-pmq-scope .ds-pmq-lede {
    font-size: clamp(17px, 1.4vw, 20px);
    line-height: 1.55;
    color: var(--ds-pmq-ink-soft);
    margin: 0;
}
.ds-pmq-scope .ds-pmq-rule { width: 56px; height: 3px; background: var(--ds-pmq-accent); margin: var(--ds-pmq-s-3) 0; border: 0; border-radius: 3px; }

/* ---------- Layout primitives ---------- */
.ds-pmq-scope .ds-pmq-container { max-width: var(--ds-pmq-container); margin: 0 auto; padding: 0 var(--ds-pmq-s-3); }
.ds-pmq-scope .ds-pmq-container--narrow { max-width: var(--ds-pmq-container-narrow); }
.ds-pmq-scope .ds-pmq-section { padding: clamp(56px, 8vw, 120px) 0; }
.ds-pmq-scope .ds-pmq-section--mint { background: var(--ds-pmq-mint); }
.ds-pmq-scope .ds-pmq-section--white { background: var(--ds-pmq-bg); }
.ds-pmq-scope .ds-pmq-section--primary { background: linear-gradient(135deg, var(--ds-pmq-primary-deep) 0%, var(--ds-pmq-primary-dark) 55%, #123A33 100%); color: var(--ds-pmq-on-primary); }
.ds-pmq-scope .ds-pmq-section--primary .ds-pmq-h2,
.ds-pmq-scope .ds-pmq-section--primary .ds-pmq-h3 { color: var(--ds-pmq-on-primary); }
.ds-pmq-scope .ds-pmq-section--primary .ds-pmq-eyebrow { background: rgba(255, 255, 255, .12); color: #bff0df; }

/* ---------- Buttons ---------- */
.ds-pmq-scope .ds-pmq-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    padding: 15px 30px; border-radius: 999px;
    font-family: var(--ds-pmq-f-body); font-size: 16px; font-weight: 600; line-height: 1;
    text-decoration: none; cursor: pointer; border: 1.5px solid transparent;
    transition: transform .15s ease, background-color .15s ease, color .15s ease, border-color .15s ease, box-shadow .15s ease;
}
.ds-pmq-scope .ds-pmq-btn--primary { background: var(--ds-pmq-accent); color: #1f1604; border-color: var(--ds-pmq-accent); box-shadow: 0 14px 26px -10px rgba(232, 163, 61, .65); }
.ds-pmq-scope .ds-pmq-btn--primary:hover { transform: translateY(-3px); background: var(--ds-pmq-accent-dark); border-color: var(--ds-pmq-accent-dark); }
.ds-pmq-scope .ds-pmq-btn--ghost { background: transparent; color: var(--ds-pmq-primary); border-color: var(--ds-pmq-primary); }
.ds-pmq-scope .ds-pmq-btn--ghost:hover { background: var(--ds-pmq-primary); color: var(--ds-pmq-on-primary); }
.ds-pmq-scope .ds-pmq-btn:active { transform: scale(.97); }
.ds-pmq-scope .ds-pmq-section--primary .ds-pmq-btn--ghost { color: var(--ds-pmq-on-primary); border-color: rgba(255,255,255,.55); }
.ds-pmq-scope .ds-pmq-section--primary .ds-pmq-btn--ghost:hover { background: var(--ds-pmq-on-primary); color: var(--ds-pmq-primary); }

/* =========================================================
   HERO
   ========================================================= */
.ds-pmq-scope .ds-pmq-hero {
    padding: clamp(56px, 8vw, 120px) 0;
    position: relative; overflow: visible;
    background: radial-gradient(1500px 860px at 84% -22%, #E6F6EE 0%, rgba(230, 246, 238, 0) 72%), #fff;
}
.ds-pmq-scope .ds-pmq-hero .ds-pmq-container { max-width: var(--ds-pmq-container); }
.ds-pmq-scope .ds-pmq-hero__grid { display: grid; grid-template-columns: 1.15fr 1fr; gap: var(--ds-pmq-s-6); align-items: center; }
.ds-pmq-scope .ds-pmq-hero__grid:not(.ds-pmq-hero__grid--centered) { grid-template-columns: 1fr 1.18fr; gap: 48px; align-items: center; }
.ds-pmq-scope .ds-pmq-hero__grid--centered { grid-template-columns: 1fr; max-width: var(--ds-pmq-container-narrow); text-align: center; }
.ds-pmq-scope .ds-pmq-hero__grid--centered .ds-pmq-hero__ctas,
.ds-pmq-scope .ds-pmq-hero__grid--centered .ds-pmq-hero__trust { justify-content: center; }
.ds-pmq-scope .ds-pmq-hero__copy > * + * { margin-top: var(--ds-pmq-s-3); }
.ds-pmq-scope .ds-pmq-hero__ctas { display: flex; flex-wrap: wrap; gap: var(--ds-pmq-s-2); margin-top: var(--ds-pmq-s-4); }
.ds-pmq-scope .ds-pmq-hero__trust { display: flex; flex-wrap: wrap; gap: var(--ds-pmq-s-2); list-style: none; margin: var(--ds-pmq-s-4) 0 0; padding: 0; }
.ds-pmq-scope .ds-pmq-hero__trust li {
    font-size: 13px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase;
    color: var(--ds-pmq-primary-dark); background: #fff;
    border: 1px solid var(--ds-pmq-line-strong); border-radius: 999px; padding: 7px 16px;
    box-shadow: 0 5px 14px rgba(20, 66, 55, .12);
}
.ds-pmq-scope .ds-pmq-hero__media { position: relative; }
.ds-pmq-scope .ds-pmq-hero__media img {
    display: block; width: 100%; height: 100%; max-height: 680px; object-fit: cover;
    border-radius: 28px; box-shadow: 0 34px 70px -22px rgba(20, 66, 55, .40);
    outline: 1px solid rgba(20, 66, 55, .10); outline-offset: -1px;
}
.ds-pmq-scope .ds-pmq-hero__media::after {
    content: ''; position: absolute; right: -16px; bottom: -16px; width: 60%; height: 62%;
    background: linear-gradient(135deg, var(--ds-pmq-mint-bright), var(--ds-pmq-primary));
    border-radius: 28px; z-index: -1; opacity: .55;
}

/* =========================================================
   CREDIBILITY BAND
   ========================================================= */
.ds-pmq-scope .ds-pmq-band { padding: var(--ds-pmq-s-6) 0; }
.ds-pmq-scope .ds-pmq-band__head { text-align: center; max-width: var(--ds-pmq-container-narrow); margin: 0 auto var(--ds-pmq-s-5); }
.ds-pmq-scope .ds-pmq-band__title { font-family: var(--ds-pmq-f-head); font-weight: 600; font-size: clamp(22px, 3vw, 34px); line-height: 1.15; margin: var(--ds-pmq-s-1) 0 0; color: inherit; }
.ds-pmq-scope .ds-pmq-band__items { display: flex; flex-wrap: wrap; justify-content: center; gap: var(--ds-pmq-s-3) var(--ds-pmq-s-6); list-style: none; margin: 0; padding: 0; }
.ds-pmq-scope .ds-pmq-band__item { display: flex; align-items: center; gap: 12px; font-size: 17px; font-weight: 600; background: rgba(255, 255, 255, .08); padding: 14px 22px; border-radius: 14px; }
.ds-pmq-scope .ds-pmq-band__icon { display: inline-flex; font-size: 26px; line-height: 1; color: var(--ds-pmq-mint-bright); }
.ds-pmq-scope .ds-pmq-band__icon svg { width: 26px; height: 26px; fill: currentColor; }

/* =========================================================
   PILLARS (services / process / deliverables)
   ========================================================= */
.ds-pmq-scope .ds-pmq-pillars { padding: clamp(56px, 8vw, 120px) 0; }
.ds-pmq-scope .ds-pmq-pillars__head { max-width: var(--ds-pmq-container-narrow); margin: 0 0 var(--ds-pmq-s-5); }
.ds-pmq-scope .ds-pmq-pillars__head > * + * { margin-top: var(--ds-pmq-s-2); }
.ds-pmq-scope .ds-pmq-pillars__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--ds-pmq-s-3); }
.ds-pmq-scope .ds-pmq-pillars__grid--2 { grid-template-columns: repeat(2, 1fr); }
.ds-pmq-scope .ds-pmq-pillars__grid--4 { grid-template-columns: repeat(4, 1fr); }
.ds-pmq-scope .ds-pmq-pillar {
    background: var(--ds-pmq-bg); border: 1px solid var(--ds-pmq-line); border-radius: var(--ds-pmq-radius); padding: var(--ds-pmq-s-4);
    box-shadow: 0 16px 44px -26px rgba(20, 66, 55, .32);
    transition: transform .22s, box-shadow .22s, border-color .22s;
    position: relative; overflow: hidden;
}
.ds-pmq-scope .ds-pmq-section--mint .ds-pmq-pillar { background: var(--ds-pmq-bg); }
.ds-pmq-scope .ds-pmq-pillar:hover { transform: translateY(-6px); box-shadow: 0 28px 54px -24px rgba(20, 66, 55, .42); border-color: transparent; }
.ds-pmq-scope .ds-pmq-pillar::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px;
    background: linear-gradient(90deg, var(--ds-pmq-primary), var(--ds-pmq-mint-bright));
    transform: scaleX(0); transform-origin: left; transition: transform .25s;
}
.ds-pmq-scope .ds-pmq-pillar:hover::before { transform: scaleX(1); }
.ds-pmq-scope .ds-pmq-pillar__num {
    display: inline-flex; align-items: center; justify-content: center; min-width: 40px; height: 40px; padding: 0 13px;
    font-family: var(--ds-pmq-f-body); font-size: 13px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase;
    background: var(--ds-pmq-mint-2); color: var(--ds-pmq-primary-deep); border-radius: 999px; margin-bottom: 18px;
}
.ds-pmq-scope .ds-pmq-pillar h3 { margin: 0 0 var(--ds-pmq-s-1); }
.ds-pmq-scope .ds-pmq-pillar p { margin: 0; color: var(--ds-pmq-ink-soft); font-size: 16px; }

/* =========================================================
   STATEMENT (why us / manifesto)
   ========================================================= */
.ds-pmq-scope .ds-pmq-statement { padding: clamp(56px, 8vw, 120px) 0; }
.ds-pmq-scope .ds-pmq-statement__grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: var(--ds-pmq-s-6); align-items: center; }
.ds-pmq-scope .ds-pmq-statement__grid--art-left { grid-template-columns: .9fr 1.1fr; }
.ds-pmq-scope .ds-pmq-statement__big { font-family: var(--ds-pmq-f-head); font-weight: 600; font-size: clamp(26px, 3.4vw, 40px); line-height: 1.15; letter-spacing: -0.02em; margin: 0; color: var(--ds-pmq-ink); }
.ds-pmq-scope .ds-pmq-statement__body { margin-top: var(--ds-pmq-s-3); }
.ds-pmq-scope .ds-pmq-statement__body p { margin: 0 0 1em; }
.ds-pmq-scope .ds-pmq-statement__body p:last-child { margin-bottom: 0; }
.ds-pmq-scope .ds-pmq-statement__art { color: var(--ds-pmq-primary); max-width: none; }
.ds-pmq-scope .ds-pmq-statement__art svg,
.ds-pmq-scope .ds-pmq-statement__art img { width: 100%; height: auto; display: block; }
.ds-pmq-scope .ds-pmq-statement__art img {
    border-radius: 24px; box-shadow: 0 34px 64px -26px rgba(20, 66, 55, .40);
    outline: 1px solid rgba(20, 66, 55, .10); outline-offset: -1px;
}

/* =========================================================
   TEAM
   ========================================================= */
.ds-pmq-scope .ds-pmq-team { padding: clamp(56px, 8vw, 120px) 0; }
.ds-pmq-scope .ds-pmq-team__head { max-width: var(--ds-pmq-container-narrow); margin: 0 0 var(--ds-pmq-s-5); }
.ds-pmq-scope .ds-pmq-team__head > * + * { margin-top: var(--ds-pmq-s-2); }
.ds-pmq-scope .ds-pmq-team__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--ds-pmq-s-3); }
.ds-pmq-scope .ds-pmq-team__grid--3 { grid-template-columns: repeat(3, 1fr); }
.ds-pmq-scope .ds-pmq-team__grid--2 { grid-template-columns: repeat(2, 1fr); }
.ds-pmq-scope .ds-pmq-member {
    background: var(--ds-pmq-bg); border: 1px solid var(--ds-pmq-line); border-radius: var(--ds-pmq-radius); padding: var(--ds-pmq-s-4);
    box-shadow: 0 16px 44px -26px rgba(20, 66, 55, .32);
    transition: transform .22s, box-shadow .22s;
}
.ds-pmq-scope .ds-pmq-member:hover { transform: translateY(-6px); box-shadow: 0 28px 54px -24px rgba(20, 66, 55, .42); }
.ds-pmq-scope .ds-pmq-member__photo { width: 100%; aspect-ratio: 4 / 5; object-fit: cover; border-radius: var(--ds-pmq-radius-sm); margin-bottom: var(--ds-pmq-s-3); display: block; outline: 1px solid rgba(20, 66, 55, .10); outline-offset: -1px; }
.ds-pmq-scope .ds-pmq-member__ph { width: 100%; aspect-ratio: 4 / 5; border-radius: var(--ds-pmq-radius-sm); margin-bottom: var(--ds-pmq-s-3); background: linear-gradient(135deg, var(--ds-pmq-mint-2), var(--ds-pmq-mint-bright)); display: flex; align-items: center; justify-content: center; color: var(--ds-pmq-primary-dark); font-size: 40px; font-weight: 600; }
.ds-pmq-scope .ds-pmq-member__name { margin: 0; }
.ds-pmq-scope .ds-pmq-member__role { color: var(--ds-pmq-accent-dark); font-weight: 600; font-size: 14px; margin: 4px 0 var(--ds-pmq-s-2); }
.ds-pmq-scope .ds-pmq-member__bio { margin: 0; color: var(--ds-pmq-ink-soft); font-size: 15px; }

/* =========================================================
   QUOTE
   ========================================================= */
.ds-pmq-scope .ds-pmq-quote { padding: clamp(56px, 8vw, 120px) 0; position: relative; overflow: hidden; }
.ds-pmq-scope .ds-pmq-quote__inner { max-width: var(--ds-pmq-container-narrow); margin: 0 auto; text-align: center; position: relative; }
.ds-pmq-scope .ds-pmq-quote__inner::before {
    content: '\201C'; position: absolute; top: -46px; left: 50%; transform: translateX(-50%);
    font-size: 150px; line-height: 1; color: rgba(127, 227, 196, .20); font-family: Georgia, serif;
}
.ds-pmq-scope .ds-pmq-quote__text { font-family: var(--ds-pmq-f-head); font-weight: 600; font-size: clamp(26px, 3.6vw, 44px); line-height: 1.25; letter-spacing: -0.02em; margin: 0; }
.ds-pmq-scope .ds-pmq-quote__attr { margin: var(--ds-pmq-s-3) 0 0; font-size: 15px; font-weight: 600; letter-spacing: .04em; opacity: .85; }

/* =========================================================
   FAQ
   ========================================================= */
.ds-pmq-scope .ds-pmq-faq { padding: clamp(56px, 8vw, 120px) 0; }
.ds-pmq-scope .ds-pmq-faq__inner { max-width: var(--ds-pmq-container-narrow); margin: 0 auto; }
.ds-pmq-scope .ds-pmq-faq__head { margin: 0 0 var(--ds-pmq-s-4); }
.ds-pmq-scope .ds-pmq-faq__item { border-top: 1px solid var(--ds-pmq-line); }
.ds-pmq-scope .ds-pmq-faq__item:last-child { border-bottom: 1px solid var(--ds-pmq-line); }
.ds-pmq-scope .ds-pmq-faq__q { font-family: var(--ds-pmq-f-head); font-weight: 600; font-size: 20px; color: var(--ds-pmq-ink); cursor: pointer; list-style: none; padding: var(--ds-pmq-s-3) 36px var(--ds-pmq-s-3) 0; position: relative; }
.ds-pmq-scope .ds-pmq-faq__q::-webkit-details-marker { display: none; }
.ds-pmq-scope .ds-pmq-faq__q::after { content: "+"; position: absolute; right: 4px; top: 50%; transform: translateY(-50%); font-size: 26px; font-weight: 400; color: var(--ds-pmq-accent-dark); line-height: 1; }
.ds-pmq-scope details[open] .ds-pmq-faq__q::after { content: "–"; }
.ds-pmq-scope .ds-pmq-faq__a { padding: 0 0 var(--ds-pmq-s-3); color: var(--ds-pmq-ink-soft); }
.ds-pmq-scope .ds-pmq-faq__a p { margin: 0 0 .8em; }
.ds-pmq-scope .ds-pmq-faq__a p:last-child { margin-bottom: 0; }

/* =========================================================
   LEAD CAPTURE
   ========================================================= */
.ds-pmq-scope .ds-pmq-lead { padding: clamp(56px, 8vw, 120px) 0; }
.ds-pmq-scope .ds-pmq-lead__grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: var(--ds-pmq-s-6); align-items: start; }
.ds-pmq-scope .ds-pmq-lead__intro > * + * { margin-top: var(--ds-pmq-s-3); }
.ds-pmq-scope .ds-pmq-lead__contact { list-style: none; margin: var(--ds-pmq-s-4) 0 0; padding: 0; }
.ds-pmq-scope .ds-pmq-lead__contact li { display: flex; flex-direction: column; gap: 2px; padding: var(--ds-pmq-s-2) 0; border-top: 1px solid var(--ds-pmq-line); }
.ds-pmq-scope .ds-pmq-lead__ck { font-size: 13px; letter-spacing: .12em; text-transform: uppercase; color: var(--ds-pmq-accent-dark); font-weight: 600; }
.ds-pmq-scope .ds-pmq-lead__contact a { color: var(--ds-pmq-ink); text-decoration: none; font-size: 18px; }
.ds-pmq-scope .ds-pmq-lead__contact a:hover { color: var(--ds-pmq-primary); }
.ds-pmq-scope .ds-pmq-lead__form-wrap { background: var(--ds-pmq-bg); border: 1px solid var(--ds-pmq-line); border-radius: var(--ds-pmq-radius); padding: var(--ds-pmq-s-4); box-shadow: 0 34px 64px -32px rgba(20, 66, 55, .38); }
.ds-pmq-scope .ds-pmq-field { margin-bottom: var(--ds-pmq-s-3); }
.ds-pmq-scope .ds-pmq-field label { display: block; font-size: 14px; font-weight: 600; margin-bottom: 6px; color: var(--ds-pmq-ink-soft); }
.ds-pmq-scope .ds-pmq-field input,
.ds-pmq-scope .ds-pmq-field select,
.ds-pmq-scope .ds-pmq-field textarea {
    width: 100%; font-family: var(--ds-pmq-f-body); font-size: 16px; color: var(--ds-pmq-ink);
    background: var(--ds-pmq-mint); border: 1px solid var(--ds-pmq-line); border-radius: var(--ds-pmq-radius-sm); padding: 12px 14px;
}
.ds-pmq-scope .ds-pmq-field input:focus,
.ds-pmq-scope .ds-pmq-field select:focus,
.ds-pmq-scope .ds-pmq-field textarea:focus { outline: none; border-color: var(--ds-pmq-primary); box-shadow: 0 0 0 3px rgba(47, 122, 104, .14); }
.ds-pmq-scope .ds-pmq-lead__form .ds-pmq-btn { width: 100%; margin-top: var(--ds-pmq-s-1); }
.ds-pmq-scope .ds-pmq-note { font-size: 14px; padding: 10px 0; }
.ds-pmq-scope .ds-pmq-note--ok { color: var(--ds-pmq-primary); font-weight: 600; }
.ds-pmq-scope .ds-pmq-note--err { color: #a32121; font-weight: 600; }

/* =========================================================
   SCROLL-IN ANIMATION
   Aktivoituu vain kun <body> saa luokan .pmq-anim (JS lisää sen,
   ja IntersectionObserver lisää .pmq-in näkyviin tuleviin osioihin).
   Ilman JS:ää osiot näkyvät normaalisti (mitään ei jää piiloon).
   ========================================================= */
.pmq-anim .ds-pmq-scope .ds-pmq-section { opacity: 0; transform: translateY(26px); transition: opacity .7s cubic-bezier(.2, 0, 0, 1), transform .7s cubic-bezier(.2, 0, 0, 1); }
.pmq-anim .ds-pmq-scope .ds-pmq-section.pmq-in { opacity: 1; transform: none; }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 980px) {
    .ds-pmq-scope .ds-pmq-pillars__grid--4 { grid-template-columns: repeat(2, 1fr); }
    .ds-pmq-scope .ds-pmq-team__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 860px) {
    .ds-pmq-scope .ds-pmq-hero__grid,
    .ds-pmq-scope .ds-pmq-hero__grid:not(.ds-pmq-hero__grid--centered),
    .ds-pmq-scope .ds-pmq-lead__grid,
    .ds-pmq-scope .ds-pmq-statement__grid,
    .ds-pmq-scope .ds-pmq-statement__grid--art-left { grid-template-columns: 1fr; gap: var(--ds-pmq-s-4); }
    .ds-pmq-scope .ds-pmq-hero__media { order: -1; }
    .ds-pmq-scope .ds-pmq-statement__art { order: -1; max-width: 360px; }
    .ds-pmq-scope .ds-pmq-pillars__grid,
    .ds-pmq-scope .ds-pmq-pillars__grid--4,
    .ds-pmq-scope .ds-pmq-pillars__grid--2 { grid-template-columns: 1fr; }
    .ds-pmq-scope .ds-pmq-band__items { gap: var(--ds-pmq-s-3) var(--ds-pmq-s-4); }
}
@media (max-width: 560px) {
    .ds-pmq-scope .ds-pmq-team__grid,
    .ds-pmq-scope .ds-pmq-team__grid--3 { grid-template-columns: 1fr; }
}
