/*
 * Insurance HUB — Claude Design system (mirror styles.css ze wzoru statycznego).
 *
 * Wszystkie reguły używają selektora `.ds` jako root design-system-u.
 * Kolory partnera (--ds-accent, --ds-font-head itd.) ustawia inline `<style>`
 * generowany przez PHP per-partner — selektor `.ihp-{slug}-root`. Dzięki temu
 * wartości zmiennych CSS są dziedziczone do dzieci (.ds), a reguły bazowe
 * pozostają wspólne — bez ryzyka kolizji per-partner.
 *
 * Źródło: `Wzór strony statycznej/insurance-hub-static/src/styles.css`.
 * Zmiany w designie aplikuj NAJPIERW w wzorze statycznym, potem syncuj tutaj.
 */

.ds {
  --bg: #fefcf7;
  --bg-2: #f6f1e7;
  --ink: #1a1816;
  --ink-2: #4a4641;
  --ink-3: #8a857e;
  --line: #e8e2d4;
  --accent: var(--ds-accent, #d2691e);
  --accent-soft: color-mix(in oklab, var(--accent) 14%, white);
  --accent-deep: color-mix(in oklab, var(--accent) 80%, black);
  --font-head: var(--ds-font-head, 'Manrope'), system-ui, sans-serif;
  --font-body: var(--ds-font-body, 'Inter'), system-ui, sans-serif;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.55;
  width: 100%;
  max-width: 100%;
  min-height: 100vh;
  box-sizing: border-box;
}
.ds *, .ds *::before, .ds *::after { box-sizing: border-box; }
.ds h1, .ds h2, .ds h3, .ds h4 { font-family: var(--font-head); margin: 0; letter-spacing: -0.02em; line-height: 1.1; }
.ds a { color: inherit; text-decoration: none; }

.ds .container { max-width: 1180px; margin: 0 auto; padding: 0 32px; }
.ds section { padding: 80px 0; }

/* Buttons */
.ds .btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 13px 22px; background: var(--accent); color: white; border-radius: 10px; font-weight: 600; font-size: 15px; border: none; cursor: pointer; font-family: var(--font-body); transition: transform .15s, box-shadow .15s; box-shadow: 0 1px 0 rgba(255,255,255,.3) inset, 0 4px 14px color-mix(in oklab, var(--accent) 40%, transparent); text-decoration: none; }
.ds .btn:hover { transform: translateY(-1px); }
.ds .btn:disabled { opacity: 0.6; cursor: wait; transform: none; }
.ds .btn-ghost { background: transparent; color: var(--ink); border: 1px solid var(--line); box-shadow: none; }
.ds .btn-sm { padding: 9px 16px; font-size: 13px; border-radius: 8px; }

/* Pills */
.ds .pill { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; border: 1px solid var(--line); border-radius: 999px; font-size: 12px; font-weight: 500; background: var(--bg); color: var(--ink-2); }
.ds .pill-accent { background: var(--accent-soft); border-color: color-mix(in oklab, var(--accent) 30%, white); color: var(--accent-deep); }
.ds .pill-dot::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--accent); display: inline-block; }

/* Image placeholder */
.ds .img-ph { background: var(--bg-2); border-radius: 16px; display: flex; align-items: center; justify-content: center; color: var(--ink-3); font-family: ui-monospace, monospace; font-size: 11px; text-align: center; padding: 12px; position: relative; overflow: hidden; }
.ds .img-ph::after { content: ''; position: absolute; inset: 0; background: repeating-linear-gradient(135deg, transparent 0 14px, rgba(0,0,0,.03) 14px 15px); pointer-events: none; }
.ds .img-ph img { position: relative; z-index: 1; }

/* Card */
.ds .card { background: var(--bg); border: 1px solid var(--line); border-radius: 16px; padding: 24px; }

/* Form */
.ds .field { width: 100%; height: 48px; padding: 0 14px; border: 1px solid var(--line); border-radius: 10px; background: var(--bg); font: inherit; color: var(--ink); outline: none; transition: border-color .15s; }
.ds .field:focus { border-color: var(--accent); }
.ds .field[aria-invalid="true"] { border-color: #d33; }
.ds .label { font-size: 13px; font-weight: 600; color: var(--ink); display: block; margin-bottom: 6px; }
.ds .label .req { color: var(--accent); }

/* Eyebrow */
.ds .eyebrow { font-size: 13px; font-weight: 600; color: var(--accent); letter-spacing: 0.02em; text-transform: uppercase; }

/* Headlines */
.ds .h-display { font-size: 64px; font-weight: 800; line-height: 1.02; letter-spacing: -0.03em; }
.ds .h-1 { font-size: 44px; font-weight: 700; }
.ds .h-2 { font-size: 32px; font-weight: 700; }
.ds .h-3 { font-size: 22px; font-weight: 600; }
.ds .lead { font-size: 18px; color: var(--ink-2); line-height: 1.55; }

/* Grids */
.ds .grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
.ds .grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.ds .grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }

/* Marquee logos */
.ds .marquee { padding: 18px 0; background: var(--bg-2); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.ds .marquee-row { display: flex; align-items: center; gap: 48px; opacity: 0.7; }
.ds .marquee-logo { font-weight: 700; font-size: 18px; letter-spacing: 1px; color: var(--ink-3); white-space: nowrap; font-family: var(--font-head); }

/* Icons */
.ds .ico-circle { width: 48px; height: 48px; border-radius: 12px; background: var(--accent-soft); color: var(--accent-deep); display: flex; align-items: center; justify-content: center; }

/* FAQ accordion (uses native <details>/<summary>) */
.ds .faq-item { border-bottom: 1px solid var(--line); padding: 22px 0; }
.ds .faq-item > .faq-q { list-style: none; cursor: pointer; font-size: 17px; font-weight: 600; display: flex; justify-content: space-between; align-items: center; user-select: none; }
.ds .faq-item > .faq-q::-webkit-details-marker { display: none; }
.ds .faq-item .faq-toggle { font-size: 22px; color: var(--accent); font-weight: 300; transition: transform .2s; }
.ds .faq-item[open] .faq-toggle { transform: rotate(45deg); }
.ds .faq-a { font-size: 15px; color: var(--ink-2); padding-top: 12px; max-width: 720px; line-height: 1.65; }

/* Star row */
.ds .stars { color: var(--accent); letter-spacing: 3px; font-size: 16px; }

/* Form messages */
.ds .ihp-form-msg.is-success { color: #166534; padding: 10px 12px; background: #dcfce7; border-radius: 8px; }
.ds .ihp-form-msg.is-error   { color: #991b1b; padding: 10px 12px; background: #fee2e2; border-radius: 8px; }

/* Responsive */
@media (max-width: 900px) {
  .ds .container { padding: 0 20px; }
  .ds section { padding: 56px 0; }
  .ds .grid-2, .ds .grid-3, .ds .grid-4 { grid-template-columns: 1fr; }
  .ds .h-display { font-size: 40px; }
  .ds .h-1 { font-size: 32px; }
  .ds .h-2 { font-size: 24px; }
  .ds .marquee-row { gap: 28px; }
  .ds .marquee-logo { font-size: 14px; }
}
