:root {
  --ipra-blue-950: #07162e;
  --ipra-blue-900: #0a1f42;
  --ipra-blue-800: #0e3474;
  --ipra-blue-700: #0a56c2;
  --ipra-blue-600: #1168e8;
  --ipra-teal-600: #07866f;
  --ipra-teal-50: #effcf8;
  --ipra-gray-950: #101828;
  --ipra-gray-800: #1d2939;
  --ipra-gray-700: #344054;
  --ipra-gray-600: #475467;
  --ipra-gray-500: #667085;
  --ipra-gray-300: #d0d5dd;
  --ipra-gray-200: #eaecf0;
  --ipra-gray-100: #f2f4f7;
  --ipra-gray-50: #f9fafb;
  --ipra-white: #ffffff;
  --ipra-warning-bg: #fff8e7;
  --ipra-warning-border: #f1c96b;
  --ipra-success-bg: #ecfdf3;
  --ipra-success-text: #067647;
  --ipra-error-bg: #fef3f2;
  --ipra-error-text: #b42318;
  --ipra-radius-sm: 10px;
  --ipra-radius-md: 16px;
  --ipra-radius-lg: 24px;
  --ipra-shadow-sm: 0 6px 16px rgba(16, 24, 40, 0.08);
  --ipra-shadow-md: 0 16px 40px rgba(16, 24, 40, 0.12);
  --ipra-container: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ipra-gray-800);
  background: var(--ipra-white);
  font-size: 16px;
  line-height: 1.65;
  text-rendering: optimizeLegibility;
}
img, svg { max-width: 100%; height: auto; }
a { color: var(--ipra-blue-700); text-decoration-thickness: 0.08em; text-underline-offset: 0.18em; }
a:hover { color: var(--ipra-blue-800); }
h1, h2, h3, h4, h5, h6 { color: var(--ipra-gray-950); line-height: 1.12; margin: 0 0 0.75rem; font-weight: 800; letter-spacing: -0.025em; }
h1 { font-size: clamp(2.35rem, 5vw, 4.7rem); }
h2 { font-size: clamp(1.85rem, 3.2vw, 3rem); }
h3 { font-size: clamp(1.2rem, 2vw, 1.55rem); }
p { margin: 0 0 1rem; }
ul, ol { margin-top: 0; }

.screen-reader-text, .skip-link:not(:focus) { position: absolute; width: 1px; height: 1px; padding: 0; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.skip-link:focus { position: fixed; z-index: 9999; top: 12px; left: 12px; background: var(--ipra-white); padding: .75rem 1rem; border-radius: var(--ipra-radius-sm); box-shadow: var(--ipra-shadow-md); }
:focus-visible { outline: 3px solid rgba(17, 104, 232, .35); outline-offset: 3px; }

.container { width: min(100% - 40px, var(--ipra-container)); margin-inline: auto; }
.container.narrow { width: min(100% - 40px, 880px); }
.section { padding: clamp(64px, 8vw, 108px) 0; }
.section-muted { background: linear-gradient(180deg, var(--ipra-gray-50), #eef5ff); }
.section-heading { max-width: 760px; margin-bottom: 38px; }
.section-heading p:last-child { color: var(--ipra-gray-600); font-size: 1.08rem; }
.eyebrow { color: var(--ipra-blue-700); text-transform: uppercase; letter-spacing: .12em; font-size: .78rem; font-weight: 800; margin-bottom: .7rem; }
.lead { color: var(--ipra-gray-600); font-size: clamp(1.08rem, 2vw, 1.25rem); max-width: 780px; }

.topbar { background: var(--ipra-blue-950); color: #d9e7ff; font-size: .9rem; }
.topbar-inner { display: flex; justify-content: space-between; gap: 1rem; padding: 9px 0; align-items: center; }
.topbar a { color: #fff; text-decoration: none; font-weight: 700; }
.topbar-contact { display: inline-flex; gap: 1rem; flex-wrap: wrap; justify-content: flex-end; }

.site-header { position: sticky; top: 0; z-index: 100; background: rgba(255,255,255,.95); backdrop-filter: blur(14px); border-bottom: 1px solid rgba(208,213,221,.76); }
.admin-bar .site-header { top: 32px; }
.header-inner { min-height: 76px; display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 24px; }
.site-branding { min-width: 0; }
.site-title { display: inline-flex; align-items: center; gap: 12px; color: var(--ipra-gray-950); text-decoration: none; font-weight: 900; letter-spacing: -.03em; }
.brand-mark { display: inline-grid; place-items: center; width: 42px; height: 42px; border-radius: 13px; background: linear-gradient(135deg, var(--ipra-blue-700), var(--ipra-teal-600)); color: #fff; font-weight: 900; }
.custom-logo-link img { max-height: 56px; width: auto; }
.main-navigation ul { display: flex; align-items: center; gap: 5px; padding: 0; margin: 0; list-style: none; justify-content: flex-end; }
.main-navigation a { display: block; padding: 10px 12px; color: var(--ipra-gray-700); text-decoration: none; font-weight: 750; border-radius: 999px; }
.main-navigation a:hover, .main-navigation .current-menu-item > a { color: var(--ipra-blue-800); background: #edf4ff; }
.menu-toggle { display: none; background: transparent; border: 0; padding: 8px; }
.menu-toggle span:not(.screen-reader-text) { display: block; width: 26px; height: 2px; background: var(--ipra-gray-800); margin: 5px 0; border-radius: 99px; }

.button, button.button, input[type="submit"] { display: inline-flex; align-items: center; justify-content: center; gap: .5rem; border: 0; border-radius: 999px; padding: 13px 20px; font-weight: 850; text-decoration: none; cursor: pointer; min-height: 48px; transition: transform .2s ease, box-shadow .2s ease, background .2s ease; }
.button:hover { transform: translateY(-1px); }
.button-primary { background: linear-gradient(135deg, var(--ipra-blue-700), var(--ipra-blue-600)); color: #fff; box-shadow: 0 12px 26px rgba(17,104,232,.28); }
.button-primary:hover { color: #fff; background: linear-gradient(135deg, var(--ipra-blue-800), var(--ipra-blue-700)); }
.button-secondary { background: var(--ipra-white); color: var(--ipra-blue-800); border: 1px solid var(--ipra-gray-300); box-shadow: var(--ipra-shadow-sm); }
.button-small { min-height: 42px; padding: 10px 16px; font-size: .94rem; }
.text-link { font-weight: 850; text-decoration: none; }

.hero { position: relative; overflow: hidden; background: radial-gradient(circle at 12% 10%, rgba(17,104,232,.2), transparent 34%), radial-gradient(circle at 90% 0%, rgba(7,134,111,.17), transparent 30%), linear-gradient(180deg, #f7fbff 0%, #fff 100%); padding: clamp(72px, 9vw, 132px) 0; }
.hero-grid { display: grid; grid-template-columns: minmax(0, 1.25fr) minmax(320px, .75fr); gap: clamp(32px, 6vw, 72px); align-items: center; }
.hero-copy h1 { max-width: 920px; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin: 30px 0 28px; }
.mini-trust { display: flex; gap: 12px; flex-wrap: wrap; color: var(--ipra-gray-700); }
.mini-trust span { display: inline-flex; align-items: center; gap: 8px; background: var(--ipra-white); border: 1px solid var(--ipra-gray-200); padding: 9px 12px; border-radius: 999px; box-shadow: var(--ipra-shadow-sm); font-weight: 700; }
.mini-trust svg, .service-icon svg, .check-list svg, .trust-stack svg, .compliance-strip svg { width: 18px; height: 18px; fill: currentColor; flex: 0 0 auto; }
.hero-card, .sticky-card, .contact-card, .content-card, .info-card, .compliance-panel { background: rgba(255,255,255,.92); border: 1px solid rgba(208,213,221,.9); border-radius: var(--ipra-radius-lg); padding: clamp(24px, 3vw, 34px); box-shadow: var(--ipra-shadow-md); }
.hero-card { position: relative; }
.hero-card:before { content: ''; position: absolute; inset: -1px; border-radius: inherit; pointer-events: none; background: linear-gradient(135deg, rgba(17,104,232,.22), rgba(7,134,111,.18), transparent); mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); padding: 1px; -webkit-mask-composite: xor; mask-composite: exclude; }

.check-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; }
.check-list li { display: flex; align-items: flex-start; gap: 10px; color: var(--ipra-gray-700); font-weight: 700; }
.check-list svg { margin-top: 4px; color: var(--ipra-teal-600); }

.card-grid { display: grid; gap: 22px; }
.card-grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.service-card, .info-card { background: #fff; border: 1px solid var(--ipra-gray-200); border-radius: var(--ipra-radius-lg); padding: 28px; box-shadow: var(--ipra-shadow-sm); transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease; }
.service-card:hover, .info-card:hover { transform: translateY(-3px); box-shadow: var(--ipra-shadow-md); border-color: #bcd5ff; }
.service-icon { width: 52px; height: 52px; border-radius: 16px; display: grid; place-items: center; color: var(--ipra-blue-700); background: #edf4ff; margin-bottom: 18px; }
.service-icon svg { width: 26px; height: 26px; }
.service-card p, .info-card p { color: var(--ipra-gray-600); }

.split-grid { display: grid; grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr); gap: clamp(30px, 5vw, 64px); }
.align-center { align-items: center; }
.steps { counter-reset: steps; list-style: none; margin: 0; padding: 0; display: grid; gap: 16px; }
.steps li { counter-increment: steps; position: relative; background: #fff; border: 1px solid var(--ipra-gray-200); border-radius: var(--ipra-radius-md); padding: 22px 22px 22px 78px; box-shadow: var(--ipra-shadow-sm); }
.steps li:before { content: counter(steps); position: absolute; left: 22px; top: 20px; width: 38px; height: 38px; display: grid; place-items: center; border-radius: 13px; background: var(--ipra-blue-700); color: #fff; font-weight: 900; }
.steps strong { display: block; color: var(--ipra-gray-950); font-size: 1.1rem; margin-bottom: 4px; }
.steps span { color: var(--ipra-gray-600); }
.steps-wide { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.steps-wide li { padding: 78px 20px 22px; }
.steps-wide li:before { top: 20px; }

.trust-stack { display: grid; gap: 16px; }
.trust-stack > div { display: grid; grid-template-columns: 42px 1fr; gap: 8px 14px; align-items: start; background: #fff; border: 1px solid var(--ipra-gray-200); border-radius: var(--ipra-radius-md); padding: 20px; box-shadow: var(--ipra-shadow-sm); }
.trust-stack svg { grid-row: span 2; width: 34px; height: 34px; color: var(--ipra-blue-700); background: #edf4ff; border-radius: 12px; padding: 8px; box-sizing: content-box; }
.trust-stack strong { color: var(--ipra-gray-950); }
.trust-stack span { color: var(--ipra-gray-600); }

.ipra-notice { border: 1px solid var(--ipra-warning-border); border-left-width: 5px; background: var(--ipra-warning-bg); color: #5c4200; border-radius: var(--ipra-radius-md); padding: 15px 17px; margin: 18px 0; }
.ipra-notice--soft { background: #f7fbff; border-color: #bcd5ff; color: var(--ipra-blue-900); }
.ipra-notice--info { background: #eef5ff; border-color: #a6c8ff; color: var(--ipra-blue-900); }
.compliance-strip { background: var(--ipra-blue-950); color: #e6efff; }
.compliance-strip-inner { display: flex; gap: 18px; justify-content: space-between; align-items: center; padding: 14px 0; font-size: .95rem; }
.compliance-strip span { display: inline-flex; align-items: flex-start; gap: 10px; }
.compliance-strip a { color: #fff; font-weight: 800; white-space: nowrap; }

.page-hero { background: linear-gradient(180deg, #f5f9ff, #fff); padding: clamp(64px, 8vw, 110px) 0; text-align: left; }
.page-main .content-area, .landing-content { font-size: 1.05rem; }
.content-area > .content-card { box-shadow: none; border: 0; padding: 0; background: transparent; }
.content-card .entry-title a { color: inherit; text-decoration: none; }
.entry-meta { color: var(--ipra-gray-500); font-size: .92rem; }
.content-list { display: grid; gap: 24px; }
.content-card { max-width: 100%; }
.post-thumbnail img { width: 100%; border-radius: var(--ipra-radius-md); margin-bottom: 24px; }

.faq-list { display: grid; gap: 12px; }
.faq-item { background: #fff; border: 1px solid var(--ipra-gray-200); border-radius: var(--ipra-radius-md); overflow: hidden; box-shadow: var(--ipra-shadow-sm); }
.faq-item summary { cursor: pointer; padding: 18px 22px; font-weight: 850; color: var(--ipra-gray-950); list-style: none; display: flex; justify-content: space-between; gap: 20px; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary:after { content: '+'; color: var(--ipra-blue-700); font-size: 1.5rem; line-height: 1; }
.faq-item[open] summary:after { content: '–'; }
.faq-answer { padding: 0 22px 20px; color: var(--ipra-gray-600); }
.faq-answer p { margin: 0; }

.pricing-table-wrap { display: grid; gap: 18px; }
.pricing-table { width: 100%; border-collapse: collapse; background: #fff; border-radius: var(--ipra-radius-lg); overflow: hidden; box-shadow: var(--ipra-shadow-sm); border: 1px solid var(--ipra-gray-200); }
.pricing-table th, .pricing-table td { text-align: left; padding: 16px 18px; border-bottom: 1px solid var(--ipra-gray-200); }
.pricing-table th { background: var(--ipra-blue-950); color: #fff; }
.pricing-table tr:last-child td { border-bottom: 0; }

.ipra-form { display: grid; gap: 18px; background: #fff; border: 1px solid var(--ipra-gray-200); border-radius: var(--ipra-radius-lg); padding: clamp(22px, 4vw, 34px); box-shadow: var(--ipra-shadow-md); }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.ipra-form label { display: grid; gap: 7px; font-weight: 800; color: var(--ipra-gray-950); }
.ipra-form input, .ipra-form select, .ipra-form textarea { width: 100%; min-height: 48px; padding: 11px 13px; border: 1px solid var(--ipra-gray-300); border-radius: 12px; font: inherit; color: var(--ipra-gray-800); background: #fff; }
.ipra-form textarea { min-height: 120px; resize: vertical; }
.ipra-form input:focus, .ipra-form select:focus, .ipra-form textarea:focus { outline: 3px solid rgba(17,104,232,.18); border-color: var(--ipra-blue-600); }
.form-help { color: var(--ipra-gray-600); font-size: .95rem; margin: 0; }
.form-disclosure { background: #f7fbff; border: 1px solid #bcd5ff; border-radius: var(--ipra-radius-md); padding: 14px; color: var(--ipra-blue-900); font-weight: 650; }
.checkbox-line { grid-template-columns: auto 1fr !important; align-items: start; gap: 10px !important; font-weight: 650 !important; color: var(--ipra-gray-700) !important; }
.checkbox-line input { width: 20px; min-height: 20px; margin-top: 2px; }
.ipra-honeypot { position: absolute; left: -9999px; opacity: 0; }
.ipra-form-status { padding: 14px 16px; border-radius: var(--ipra-radius-md); font-weight: 800; }
.ipra-form-status--success { background: var(--ipra-success-bg); color: var(--ipra-success-text); border: 1px solid #75e0a7; }
.ipra-form-status--error { background: var(--ipra-error-bg); color: var(--ipra-error-text); border: 1px solid #fda29b; }

.sticky-card { position: sticky; top: 112px; align-self: start; }
.disclosure-list { display: grid; gap: 16px; }
.disclosure-list div { border-bottom: 1px solid var(--ipra-gray-200); padding-bottom: 14px; }
.disclosure-list div:last-child { border-bottom: 0; padding-bottom: 0; }
.disclosure-list p { color: var(--ipra-gray-600); margin: 4px 0 0; }
.service-meta-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; margin-bottom: 30px; }
.service-meta-grid div { background: #f7fbff; border: 1px solid #bcd5ff; border-radius: var(--ipra-radius-md); padding: 18px; }
.service-meta-grid strong { display: block; color: var(--ipra-blue-900); }
.service-meta-grid span { color: var(--ipra-gray-700); }

.tab-actions { display: flex; gap: 14px; flex-wrap: wrap; }
.legal-inline { text-align: center; color: var(--ipra-gray-600); font-weight: 700; }
.legal-content h2, .legal-content h3 { margin-top: 2rem; }
.contact-card { align-self: start; }

.site-footer { background: var(--ipra-blue-950); color: #d9e7ff; }
.site-footer a { color: #fff; }
.footer-cta { display: flex; justify-content: space-between; gap: 26px; align-items: center; padding-top: 58px; padding-bottom: 44px; border-bottom: 1px solid rgba(255,255,255,.14); }
.footer-cta h2, .site-footer h2, .site-footer h3 { color: #fff; }
.footer-cta p { max-width: 760px; }
.footer-cta-actions { display: flex; gap: 12px; flex-wrap: wrap; justify-content: flex-end; }
.footer-grid { display: grid; grid-template-columns: 1.4fr .8fr .8fr; gap: 42px; padding: 42px 0; }
.footer-logo { font-size: 1.35rem; }
.footer-links { list-style: none; padding: 0; margin: 0; display: grid; gap: 9px; }
.footer-links a { text-decoration: none; }
.footer-disclaimer { border-top: 1px solid rgba(255,255,255,.14); padding: 22px 0 34px; font-size: .92rem; color: #b8c7df; }
.footer-disclaimer p:last-child { margin-bottom: 0; }

.nav-links { display: flex; justify-content: space-between; gap: 20px; margin-top: 32px; }

@media (max-width: 1024px) {
  .hero-grid, .split-grid { grid-template-columns: 1fr; }
  .card-grid.three { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .steps-wide { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .sticky-card { position: static; }
  .header-inner { grid-template-columns: auto auto; }
  .header-actions { display: none; }
  .menu-toggle { display: inline-block; justify-self: end; }
  .main-navigation { grid-column: 1 / -1; display: none; border-top: 1px solid var(--ipra-gray-200); padding: 12px 0 18px; }
  .main-navigation.is-open { display: block; }
  .main-navigation ul { display: grid; justify-content: stretch; }
  .main-navigation a { border-radius: var(--ipra-radius-sm); padding: 12px; }
}
@media (max-width: 782px) {
  .admin-bar .site-header { top: 46px; }
}
@media (max-width: 720px) {
  .container, .container.narrow { width: min(100% - 28px, var(--ipra-container)); }
  .topbar-inner, .footer-cta { flex-direction: column; align-items: flex-start; }
  .topbar-contact, .footer-cta-actions { justify-content: flex-start; }
  .card-grid.three, .form-grid, .service-meta-grid, .footer-grid, .steps-wide { grid-template-columns: 1fr; }
  .hero { padding-top: 58px; }
  .site-title span:last-child { font-size: .95rem; }
  .footer-grid { gap: 26px; }
  .hero-actions .button, .tab-actions .button, .footer-cta-actions .button { width: 100%; }
}
@media (prefers-reduced-motion: reduce) {
  *, *:before, *:after { transition: none !important; scroll-behavior: auto !important; }
}

/* v1.1 cinematic launch visuals */
:root {
  --ipra-cinema-red: #e91b39;
  --ipra-cinema-red-dark: #9f1029;
  --ipra-cinema-purple: #9458ff;
  --ipra-cinema-black: #050812;
}

.hero,
.page-hero--cinema,
.landing-hero {
  background:
    radial-gradient(circle at 14% 14%, rgba(233, 27, 57, .28), transparent 33%),
    radial-gradient(circle at 90% 2%, rgba(17, 104, 232, .26), transparent 28%),
    radial-gradient(circle at 72% 82%, rgba(7, 134, 111, .18), transparent 33%),
    linear-gradient(135deg, #050812 0%, #091328 50%, #1d0816 100%);
  color: #dce8ff;
}
.hero h1,
.hero h2,
.page-hero--cinema h1,
.page-hero--cinema h2,
.landing-hero h1,
.landing-hero h2 { color: #fff; }
.hero .lead,
.page-hero--cinema .lead,
.landing-hero .lead { color: #c8d7f4; }
.hero .eyebrow,
.page-hero--cinema .eyebrow,
.landing-hero .eyebrow { color: #ff6076; }
.hero:after,
.page-hero--cinema:after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 90px;
  background: linear-gradient(180deg, transparent, rgba(255,255,255,.08));
  pointer-events: none;
}

.button-primary {
  background: linear-gradient(135deg, var(--ipra-cinema-red), var(--ipra-blue-600));
  box-shadow: 0 16px 34px rgba(233, 27, 57, .28), 0 10px 24px rgba(17,104,232,.22);
}
.button-primary:hover {
  background: linear-gradient(135deg, #ff3350, var(--ipra-blue-700));
}

.hero-media-stack { position: relative; min-width: 0; }
.hero-media,
.cinema-visual {
  position: relative;
  margin: 0;
  border-radius: 30px;
  overflow: hidden;
  background: #050812;
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 26px 70px rgba(0,0,0,.38), 0 0 0 1px rgba(255,255,255,.05) inset;
}
.hero-media img,
.cinema-visual img { display: block; width: 100%; aspect-ratio: 1.35 / 1; object-fit: cover; transform: scale(1.01); }
.hero-media:before,
.cinema-visual:before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 46%, rgba(0,0,0,.72));
  z-index: 1;
  pointer-events: none;
}
.hero-media figcaption,
.cinema-visual figcaption {
  position: absolute;
  z-index: 2;
  left: 18px;
  right: 18px;
  bottom: 16px;
  color: #fff;
  font-weight: 850;
  line-height: 1.25;
  text-shadow: 0 2px 16px rgba(0,0,0,.6);
}
.hero-card--floating {
  margin: -78px 22px 0;
  position: relative;
  z-index: 3;
  backdrop-filter: blur(16px);
}

.cinema-split {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, .95fr);
  gap: clamp(30px, 5vw, 66px);
  align-items: center;
}
.content-area--wide { max-width: none; }
.content-area--wide > .cinema-split:first-child { margin-top: -10px; }
.section-tight { padding-top: clamp(34px, 5vw, 56px); padding-bottom: 0; }
.section-tight-top { margin-top: clamp(30px, 5vw, 54px); }

.cinema-split .lead { max-width: 680px; }
.cinema-split .ipra-notice { margin-top: 20px; }
.cinema-visual { min-height: 320px; }
.cinema-visual img { aspect-ratio: 1.5 / 1; min-height: 320px; }

.ipra-notice--soft {
  background: rgba(255,255,255,.72);
  border-color: rgba(255,255,255,.78);
}
.hero .ipra-notice--soft,
.landing-hero .ipra-notice--soft {
  background: rgba(255,255,255,.9);
  color: var(--ipra-gray-800);
}
.hero .mini-trust span {
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.18);
  color: #fff;
  backdrop-filter: blur(12px);
}

.page-main .compliance-strip + .section { padding-top: clamp(48px, 6vw, 82px); }
.service-meta-grid div {
  background: linear-gradient(180deg, #fff, #f7fbff);
}
.info-card h3,
.service-card h3 { margin-bottom: .5rem; }

@media (max-width: 1024px) {
  .cinema-split { grid-template-columns: 1fr; }
  .hero-card--floating { margin: -52px 14px 0; }
}
@media (max-width: 720px) {
  .hero-media figcaption,
  .cinema-visual figcaption { position: static; background: #050812; padding: 14px 16px; }
  .hero-media:before,
  .cinema-visual:before { display: none; }
  .hero-card--floating { margin: 16px 0 0; }
  .cinema-visual img { min-height: 230px; }
}
.page-hero--cinema { position: relative; overflow: hidden; }

/* v1.2 launch refresh: unified cinematic color system */
body.ipra-theme {
  background:
    radial-gradient(circle at top left, rgba(233,27,57,.18), transparent 28%),
    radial-gradient(circle at top right, rgba(17,104,232,.18), transparent 26%),
    linear-gradient(180deg, #050812 0%, #091224 22%, #0b1221 52%, #07101d 100%);
  color: #d8e3f8;
}
body.ipra-theme p,
body.ipra-theme li,
body.ipra-theme .lead,
body.ipra-theme .section-heading p:last-child,
body.ipra-theme .service-card p,
body.ipra-theme .info-card p,
body.ipra-theme .steps span,
body.ipra-theme .faq-answer,
body.ipra-theme .disclosure-list p,
body.ipra-theme .service-meta-grid span,
body.ipra-theme .entry-meta,
body.ipra-theme .footer-help,
body.ipra-theme .policy-card p,
body.ipra-theme .product-card p { color: #c6d3ea; }
body.ipra-theme h1,
body.ipra-theme h2,
body.ipra-theme h3,
body.ipra-theme h4,
body.ipra-theme h5,
body.ipra-theme h6 { color: #fff; }
body.ipra-theme a { color: #9ec4ff; }
body.ipra-theme a:hover { color: #c8dcff; }
body.ipra-theme .section-muted {
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
}
body.ipra-theme .site-header {
  background: rgba(5,8,18,.78);
  border-bottom-color: rgba(255,255,255,.08);
}
body.ipra-theme .site-title,
body.ipra-theme .main-navigation a,
body.ipra-theme .menu-toggle span:not(.screen-reader-text) { color: #fff; }
body.ipra-theme .main-navigation a:hover,
body.ipra-theme .main-navigation .current-menu-item > a {
  color: #fff;
  background: rgba(255,255,255,.08);
}
body.ipra-theme .brand-mark {
  background: linear-gradient(135deg, #ff3350, #155ddf 70%, #9458ff);
  box-shadow: 0 12px 28px rgba(233,27,57,.26);
}
body.ipra-theme .topbar {
  background: rgba(5,8,18,.92);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
body.ipra-theme .hero,
body.ipra-theme .page-hero,
body.ipra-theme .page-hero--cinema,
body.ipra-theme .landing-hero {
  background:
    radial-gradient(circle at 14% 14%, rgba(233, 27, 57, .28), transparent 33%),
    radial-gradient(circle at 90% 2%, rgba(17, 104, 232, .26), transparent 28%),
    radial-gradient(circle at 72% 82%, rgba(148, 88, 255, .16), transparent 33%),
    linear-gradient(135deg, #050812 0%, #091328 50%, #1d0816 100%);
}
.hero-grid--media { align-items: start; }
.hero-copy h1 { max-width: 880px; }
.hero-card,
.sticky-card,
.contact-card,
.content-card,
.info-card,
.compliance-panel,
.product-card,
.policy-card,
.service-card,
.faq-item,
.steps li,
.trust-stack > div,
.ipra-form,
.service-meta-grid div,
.pricing-table,
.quick-call-band__inner {
  background: rgba(10,18,34,.72);
  border: 1px solid rgba(255,255,255,.1);
  box-shadow: 0 24px 60px rgba(0,0,0,.28);
  backdrop-filter: blur(18px);
}
.hero-card:before {
  background: linear-gradient(135deg, rgba(233,27,57,.3), rgba(17,104,232,.22), rgba(148,88,255,.18));
}
.hero .mini-trust span,
.quick-call-band__inner,
.catalog-count,
.product-chip {
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  color: #fff;
}
.quick-call-band { padding-top: 26px; padding-bottom: 0; }
.quick-call-band__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  border-radius: 28px;
  padding: 28px 34px;
  position: relative;
  overflow: hidden;
}
.quick-call-band__inner:before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(233,27,57,.16), transparent 42%, rgba(17,104,232,.16));
  pointer-events: none;
}
.quick-call-band__actions { display: flex; flex-wrap: wrap; gap: 12px; justify-content: flex-end; position: relative; z-index: 1; }
.catalog-link-row { margin-top: 26px; display: flex; justify-content: center; }
.use-case-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.use-case-grid h3 { display: flex; align-items: center; gap: 10px; }
.use-case-grid svg { width: 22px; height: 22px; fill: currentColor; color: #ff6076; flex: 0 0 auto; }
.catalog-sections { display: grid; gap: 34px; }
.catalog-section { display: grid; gap: 20px; }
.catalog-heading { display: flex; justify-content: space-between; align-items: flex-end; gap: 24px; }
.catalog-count {
  border-radius: 999px;
  padding: 10px 16px;
  font-weight: 800;
  white-space: nowrap;
}
.product-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 22px; }
.product-grid--featured { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.product-card {
  overflow: hidden;
  border-radius: 24px;
  display: grid;
}
.product-card-media {
  margin: 0;
  position: relative;
  overflow: hidden;
  background: #050812;
}
.product-card-media img {
  display: block;
  width: 100%;
  aspect-ratio: 1.45 / 1;
  object-fit: cover;
}
.product-card-media:before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 46%, rgba(0,0,0,.82));
}
.product-card-media figcaption {
  position: absolute;
  left: 16px;
  right: 16px;
  bottom: 14px;
  z-index: 2;
  color: #fff;
  font-weight: 800;
  text-shadow: 0 2px 16px rgba(0,0,0,.5);
}
.product-card-body { padding: 22px; }
.product-card-topline { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 12px; }
.product-chip {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 6px 12px;
  border-radius: 999px;
  font-size: .85rem;
  font-weight: 800;
}
.product-price {
  color: #fff;
  font-size: 1.2rem;
}
.feature-pills {
  list-style: none;
  padding: 0;
  margin: 18px 0 0;
  display: grid;
  gap: 10px;
}
.feature-pills li {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  color: #d8e3f8;
  font-weight: 700;
}
.feature-pills svg { width: 18px; height: 18px; color: #67d8c0; fill: currentColor; margin-top: 2px; flex: 0 0 auto; }
.product-card-actions { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 20px; }
.product-card-actions .text-link { color: #fff; }
.policy-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 20px; margin-top: 32px; }
.policy-card { border-radius: 22px; padding: 24px; }
.policy-card h3 { display: flex; align-items: center; gap: 10px; font-size: 1.08rem; }
.policy-card svg { width: 20px; height: 20px; fill: currentColor; color: #ff6076; }
.button-secondary {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.14);
  color: #fff;
}
.button-secondary:hover { color: #fff; background: rgba(255,255,255,.14); }
.pricing-table th { background: rgba(255,255,255,.08); color: #fff; }
.pricing-table td, .pricing-table th { border-bottom-color: rgba(255,255,255,.08); }
.ipra-form input,
.ipra-form select,
.ipra-form textarea {
  background: rgba(255,255,255,.96);
}
.form-disclosure,
.ipra-notice--soft,
.ipra-notice--info {
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.16);
  color: #fff;
}
.ipra-notice { color: #ffeab0; border-color: rgba(255,214,102,.45); background: rgba(255,214,102,.08); }
.footer-disclaimer { color: #9db0cd; }
.floating-call {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 110;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  background: linear-gradient(135deg, #ff3350, #155ddf);
  color: #fff;
  text-decoration: none;
  border-radius: 999px;
  padding: 12px 18px 12px 14px;
  box-shadow: 0 20px 44px rgba(0,0,0,.3), 0 10px 24px rgba(233,27,57,.28);
}
.floating-call__icon { display: inline-grid; place-items: center; width: 36px; height: 36px; border-radius: 50%; background: rgba(255,255,255,.14); }
.floating-call__icon svg { width: 18px; height: 18px; fill: currentColor; color: #fff; }
.floating-call__text { display: grid; gap: 2px; font-size: .9rem; line-height: 1.2; }
.footer-logo { color: #fff; }
.footer-links a:hover { text-decoration: underline; }

@media (max-width: 1120px) {
  .product-grid,
  .product-grid--featured,
  .use-case-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 1024px) {
  .header-actions { display: none; }
  .quick-call-band__inner,
  .catalog-heading { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 720px) {
  .product-grid,
  .product-grid--featured,
  .policy-grid,
  .use-case-grid { grid-template-columns: 1fr; }
  .product-card-actions,
  .quick-call-band__actions { flex-direction: column; align-items: stretch; }
  .floating-call {
    left: 14px;
    right: 14px;
    bottom: 14px;
    justify-content: center;
  }
  .floating-call__text { font-size: .84rem; }
}

/* v1.3 WooCommerce journey and policy-page refinements */
.product-card-actions--stacked {
  align-items: stretch;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.product-card-actions--stacked .text-link {
  grid-column: 1 / -1;
  justify-self: start;
}
.product-journey-note {
  margin: 12px 0 0;
  font-size: .88rem;
  color: #aebed8 !important;
}
.woocommerce-page .site-main,
.woocommerce .site-main,
.woocommerce-cart .site-main,
.woocommerce-checkout .site-main {
  padding: clamp(48px, 7vw, 90px) 0;
}
.woocommerce div.product,
.woocommerce-cart-form,
.woocommerce-checkout form.checkout,
.woocommerce-order,
.woocommerce-account .woocommerce-MyAccount-content,
.woocommerce-account .woocommerce-MyAccount-navigation,
.woocommerce .woocommerce-notices-wrapper .woocommerce-message,
.woocommerce .woocommerce-notices-wrapper .woocommerce-info,
.woocommerce .woocommerce-error,
.woocommerce table.shop_table,
.woocommerce form.checkout_coupon,
.woocommerce form.login,
.woocommerce form.register {
  background: rgba(10,18,34,.72);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 24px;
  padding: 22px;
  color: #d8e3f8;
  box-shadow: 0 24px 60px rgba(0,0,0,.28);
}
.woocommerce table.shop_table th,
.woocommerce table.shop_table td { border-color: rgba(255,255,255,.1); color: #d8e3f8; }
.woocommerce-page input.input-text,
.woocommerce-page textarea,
.woocommerce-page select,
.woocommerce-checkout input.input-text,
.woocommerce-checkout textarea,
.woocommerce-checkout select {
  background: rgba(255,255,255,.96);
  color: #101828;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.25);
  min-height: 46px;
  padding: 10px 12px;
}
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce a.checkout-button {
  background: linear-gradient(135deg, #ff3350, #155ddf) !important;
  color: #fff !important;
  border-radius: 999px !important;
  font-weight: 850 !important;
  padding: 13px 20px !important;
}
.woocommerce a.remove { color: #ff6076 !important; }
.woocommerce .quantity .qty { width: 5em; }
.legal-content, .page-main .content-area { line-height: 1.75; }
.legal-content h2, .legal-content h3, .page-main .content-area h2, .page-main .content-area h3 { margin-top: 1.5em; }
@media (max-width: 720px) {
  .product-card-actions--stacked { grid-template-columns: 1fr; }
}
.checkout-journey-panel {
  background: rgba(10,18,34,.72);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 28px;
  padding: clamp(24px, 4vw, 36px);
  margin-bottom: 34px;
  box-shadow: 0 24px 60px rgba(0,0,0,.28);
  position: relative;
  overflow: hidden;
}
.checkout-journey-panel:before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(233,27,57,.14), transparent 45%, rgba(17,104,232,.15));
  pointer-events: none;
}
.checkout-journey-panel > * { position: relative; z-index: 1; }
.footer-extra-policy { margin-top: 10px; font-weight: 800; }

/* v1.4 visible commerce journey + tabbed product catalog */
.commerce-journey-steps {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin: 22px 0;
}
.commerce-journey-step {
  display: grid;
  gap: 8px;
  min-height: 154px;
  padding: 18px;
  border-radius: 20px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
  color: #fff;
  text-decoration: none;
  position: relative;
  overflow: hidden;
}
.commerce-journey-step:after {
  content: '→';
  position: absolute;
  right: 14px;
  top: 14px;
  color: rgba(255,255,255,.52);
  font-weight: 900;
}
.commerce-journey-step:last-child:after { content: ''; }
.commerce-journey-step:hover {
  color: #fff;
  background: rgba(255,255,255,.12);
  transform: translateY(-1px);
}
.journey-step-number {
  width: 34px;
  height: 34px;
  border-radius: 12px;
  display: inline-grid;
  place-items: center;
  color: #fff;
  font-weight: 900;
  background: linear-gradient(135deg, #ff3350, #155ddf);
  box-shadow: 0 10px 20px rgba(0,0,0,.22);
}
.commerce-journey-step strong { color: #fff; font-size: 1.05rem; }
.commerce-journey-step small { color: #c6d3ea; line-height: 1.45; }
.journey-policy-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}
.journey-policy-links a {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 7px 13px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  color: #fff;
  font-weight: 800;
  text-decoration: none;
}
.product-tabs { display: grid; gap: 24px; }
.product-tab-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 12px;
  border-radius: 24px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  margin-bottom: 4px;
}
.product-tab-button {
  appearance: none;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.07);
  color: #fff;
  border-radius: 999px;
  padding: 11px 15px;
  font: inherit;
  font-weight: 850;
  cursor: pointer;
  display: inline-flex;
  gap: 9px;
  align-items: center;
  transition: background .2s ease, transform .2s ease, border-color .2s ease;
}
.product-tab-button span {
  display: inline-grid;
  place-items: center;
  min-width: 26px;
  min-height: 26px;
  padding: 0 7px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  color: #d8e3f8;
  font-size: .82rem;
}
.product-tab-button:hover,
.product-tab-button.is-active {
  background: linear-gradient(135deg, rgba(255,51,80,.95), rgba(21,93,223,.95));
  border-color: rgba(255,255,255,.32);
  transform: translateY(-1px);
}
.product-tab-button.is-active span { background: rgba(255,255,255,.22); color: #fff; }
.catalog-sections--tabs .product-tab-panel { display: none; }
.catalog-sections--tabs .product-tab-panel.is-active { display: grid; }
.product-journey-links {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  align-items: center;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,.1);
  color: #9db0cd;
  font-size: .88rem;
  font-weight: 800;
}
.product-journey-links a {
  color: #fff;
  text-decoration: none;
}
.product-journey-links a:hover { text-decoration: underline; }
.checkout-journey-panel h2 { max-width: 980px; }
@media (max-width: 1024px) {
  .commerce-journey-steps { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 720px) {
  .commerce-journey-steps { grid-template-columns: 1fr; }
  .commerce-journey-step { min-height: 0; }
  .commerce-journey-step:after { content: ''; }
  .product-tab-list { display: grid; }
  .product-tab-button { justify-content: space-between; }
}

/* v1.5 product action buttons */
.product-card-actions--three {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  align-items: stretch;
}
.product-card-actions--three .button {
  width: 100%;
  text-align: center;
  white-space: normal;
  line-height: 1.2;
  padding-inline: 12px;
}
.ipra-single-product-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}
.ipra-single-product-buttons .button {
  min-height: 48px;
}
@media (max-width: 960px) {
  .product-card-actions--three { grid-template-columns: 1fr; }
}


/* v1.6 product-card click behavior and product-page action alignment */
.product-card--clickable { position: relative; }
.product-card-overlay-link {
  position: absolute;
  inset: 0;
  z-index: 1;
  border-radius: inherit;
  text-indent: -9999px;
  overflow: hidden;
}
.product-card-media,
.product-card-body,
.product-card-actions,
.product-card-actions .button { position: relative; }
.product-card-media,
.product-card-body { z-index: 2; pointer-events: none; }
.product-card-actions { z-index: 4; pointer-events: auto; }
.product-card-actions .button { pointer-events: auto; }
.product-card--clickable:hover .product-card-media img { transform: scale(1.04); }
.product-card--clickable:hover { border-color: rgba(255,255,255,.24); }

.woocommerce div.product form.cart {
  display: flex;
  align-items: stretch;
  flex-wrap: wrap;
  gap: 10px;
}
.woocommerce div.product form.cart .quantity { margin: 0 6px 0 0; }
.woocommerce div.product form.cart .single_add_to_cart_button,
.woocommerce div.product form.cart .ipra-single-product-buttons .button {
  min-height: 48px;
  margin: 0 !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.ipra-single-product-buttons {
  display: flex;
  align-items: stretch;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 0;
}
.ipra-single-product-buttons .button { white-space: nowrap; }
.woocommerce-page #secondary,
.woocommerce-page .widget-area,
.single-product #secondary,
.single-product .widget-area,
.post-type-archive-product #secondary,
.post-type-archive-product .widget-area {
  display: none !important;
}
.woocommerce-page #primary,
.single-product #primary,
.post-type-archive-product #primary {
  width: 100% !important;
  max-width: none !important;
}
@media (max-width: 720px) {
  .woocommerce div.product form.cart,
  .ipra-single-product-buttons { display: grid; grid-template-columns: 1fr; width: 100%; }
  .woocommerce div.product form.cart .single_add_to_cart_button,
  .ipra-single-product-buttons .button { width: 100%; }
}
