/* ─── Public site tokens ─────────────────────────────────────────────────── */
.public-site {
    --pub-deep:     #063b44;
    --pub-deep-2:   #0a5260;
    --pub-green:    #0d9488;
    --pub-green-mid:#0f766e;
    --pub-mint:     #e6f7f5;
    --pub-mint-2:   #ccf0ec;
    --pub-amber:    #e89832;
    --pub-ink:      #0f2b30;
    --pub-ink-soft: #2a4a50;
    --pub-muted:    #56767c;
    --pub-line:     #d4e6e3;
    --pub-surface:  #f5faf9;
    --pub-shadow-sm: 0 1px 4px rgba(6,59,68,.07), 0 1px 2px rgba(6,59,68,.04);
    --pub-shadow:    0 4px 20px rgba(6,59,68,.10), 0 2px 6px rgba(6,59,68,.06);
    --pub-shadow-lg: 0 12px 40px rgba(6,59,68,.14), 0 4px 12px rgba(6,59,68,.07);
    --pub-radius:    10px;
    --pub-radius-sm: 7px;
    --pub-transition: 160ms ease;
    background: #fff;
    color: var(--pub-ink);
    -webkit-font-smoothing: antialiased;
}

.public-site .container {
    max-width: min(1680px, calc(100% - 4rem));
    padding-left: 0;
    padding-right: 0;
}

.public-site .container.narrow-copy {
    max-width: min(920px, calc(100% - 4rem));
}

/* ─── Navbar ─────────────────────────────────────────────────────────────── */
.public-site .navbar {
    box-shadow: 0 1px 0 rgba(6,59,68,.08);
    min-height: 72px;
    padding: 0;
}

.public-site .navbar-nav { gap: 0.15rem; }

.public-site .nav-link {
    border-radius: 6px;
    color: var(--pub-ink-soft);
    font-size: 0.9rem;
    font-weight: 600;
    padding: 0.45rem 0.75rem;
    transition: background var(--pub-transition), color var(--pub-transition);
}

.public-site .nav-link:hover,
.public-site .nav-link.active {
    background: var(--pub-mint);
    color: var(--pub-green-mid);
}

/* Brand mark */
.public-brand {
    align-items: center;
    color: var(--pub-deep);
    display: inline-flex;
    gap: 0.65rem;
    text-decoration: none;
    transition: opacity var(--pub-transition);
}

.public-brand:hover { opacity: 0.85; }
.public-brand span:last-child { display: grid; line-height: 1.05; }
.public-brand strong { font-size: 1.02rem; font-weight: 800; }
.public-brand small {
    color: var(--pub-muted);
    font-size: 0.62rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    margin-top: 0.2rem;
    text-transform: uppercase;
}

.public-brand-logo-wrap {
    align-items: center;
    background: #fff;
    border: 1px solid rgba(20, 87, 89, 0.14);
    border-radius: 8px;
    display: inline-flex;
    flex: 0 0 auto;
    height: 44px;
    justify-content: center;
    overflow: hidden;
    padding: 0.25rem;
    width: 58px;
}

.public-brand-logo {
    display: block;
    height: 100%;
    object-fit: contain;
    width: 100%;
}

.public-brand-mark {
    align-items: center;
    background: linear-gradient(135deg, var(--pub-deep) 0%, var(--pub-deep-2) 100%);
    border-radius: 8px;
    color: #fff;
    display: inline-flex;
    font-size: 0.7rem;
    font-weight: 850;
    height: 38px;
    justify-content: center;
    letter-spacing: 0.04em;
    width: 44px;
}

/* ─── Hero ───────────────────────────────────────────────────────────────── */
.public-site .public-hero { min-height: 700px; }
.public-site .hero-copy { max-width: 920px; padding: 7.5rem 0 6rem; }
.public-site .hero-copy h1 {
    font-size: 4.5rem;
    font-weight: 850;
    letter-spacing: -0.02em;
    line-height: 1.04;
    max-width: 860px;
}
.public-site .hero-copy .lead { color: rgba(255,255,255,.92); max-width: 780px; }
.hero-support { color: rgba(255,255,255,.76); font-size: 1rem; line-height: 1.75; max-width: 760px; }

.hero-badge {
    align-items: center;
    background: rgba(255,255,255,.14);
    border: 1px solid rgba(255,255,255,.22);
    border-radius: 999px;
    color: rgba(255,255,255,.9);
    display: inline-flex;
    font-size: 0.78rem;
    font-weight: 700;
    gap: 0.4rem;
    letter-spacing: 0.04em;
    margin-bottom: 1.25rem;
    padding: 0.32rem 0.75rem;
    text-transform: uppercase;
}

.hero-badge i { font-size: 0.75rem; color: var(--pub-amber); }

/* ─── Trust strip ────────────────────────────────────────────────────────── */
.public-trust-strip {
    background: var(--pub-deep);
    color: #fff;
}

.public-trust-strip .container {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
}

.public-trust-strip div {
    align-items: start;
    border-right: 1px solid rgba(255,255,255,.12);
    display: grid;
    gap: 0.15rem;
    grid-template-columns: auto 1fr;
    padding: 1.4rem 1.6rem;
    column-gap: 0.75rem;
}

.public-trust-strip div:first-child { border-left: 1px solid rgba(255,255,255,.12); }

.public-trust-strip i {
    color: var(--pub-amber);
    font-size: 1.25rem;
    grid-row: 1 / span 2;
    margin-top: 0.15rem;
}

.public-trust-strip strong { font-size: 0.92rem; font-weight: 700; }
.public-trust-strip span { color: rgba(255,255,255,.6); font-size: 0.8rem; grid-column: 2; }

/* ─── Section headings ───────────────────────────────────────────────────── */
.public-section-heading { margin-bottom: 2.25rem; max-width: 760px; }

.public-section-heading h2,
.public-copy-layout h2,
.public-cta h2 {
    font-size: 2.3rem;
    font-weight: 850;
    letter-spacing: -0.02em;
    line-height: 1.1;
}

.public-section-heading p,
.public-copy-layout div > p { color: var(--pub-muted); line-height: 1.75; }

/* ─── Feature grid ───────────────────────────────────────────────────────── */
.public-feature-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.public-feature-grid.three { grid-template-columns: repeat(3, 1fr); }

.public-feature-grid article {
    background: #fff;
    border: 1px solid var(--pub-line);
    border-radius: var(--pub-radius);
    border-top: 3px solid var(--pub-green);
    padding: 1.35rem;
    transition: box-shadow var(--pub-transition), transform var(--pub-transition);
}

.public-feature-grid article:hover {
    box-shadow: var(--pub-shadow);
    transform: translateY(-2px);
}

.public-feature-grid i {
    color: var(--pub-green);
    display: block;
    font-size: 1.5rem;
    margin-bottom: 1rem;
}

.public-feature-grid h3 {
    font-size: 1rem;
    font-weight: 800;
    letter-spacing: -0.01em;
    margin-bottom: 0.5rem;
}

.public-feature-grid p { color: var(--pub-muted); font-size: 0.875rem; line-height: 1.65; margin-bottom: 0; }

/* ─── Media band ─────────────────────────────────────────────────────────── */
.public-media-band { background: var(--pub-mint); padding: 0; }
.public-media-band .container { display: grid; grid-template-columns: 1fr 1fr; max-width: min(1680px, calc(100% - 4rem)); padding: 0; }
.public-media-copy { padding: 4.5rem; }
.public-media-copy h2 { font-size: 2.35rem; font-weight: 850; letter-spacing: -0.02em; line-height: 1.1; }
.public-media-copy p { color: var(--pub-muted); line-height: 1.75; }
.public-media-band img { height: 100%; max-height: 520px; min-height: 420px; object-fit: cover; width: 100%; }

/* ─── Industry grid ──────────────────────────────────────────────────────── */
.public-industry-grid {
    display: grid;
    gap: 0.65rem;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.public-industry-grid a {
    align-items: center;
    background: #fff;
    border: 1px solid var(--pub-line);
    border-radius: var(--pub-radius-sm);
    color: var(--pub-ink);
    display: flex;
    font-size: 0.88rem;
    font-weight: 650;
    gap: 0.6rem;
    padding: 0.85rem 1rem;
    text-decoration: none;
    transition: all var(--pub-transition);
}

.public-industry-grid a:hover {
    background: var(--pub-mint);
    border-color: var(--pub-green);
    color: var(--pub-green-mid);
    transform: translateY(-1px);
    box-shadow: var(--pub-shadow-sm);
}

.public-industry-grid i { color: var(--pub-green); font-size: 1rem; flex-shrink: 0; }

/* ─── Cards ──────────────────────────────────────────────────────────────── */
.public-card-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.public-card-grid.services { grid-template-columns: repeat(3, minmax(0, 1fr)); }

.public-card {
    background: #fff;
    border: 1px solid var(--pub-line);
    border-radius: var(--pub-radius);
    display: flex;
    flex-direction: column;
    padding: 1.35rem;
    transition: box-shadow var(--pub-transition), transform var(--pub-transition), border-color var(--pub-transition);
}

.public-card:hover {
    border-color: var(--pub-green);
    box-shadow: var(--pub-shadow);
    transform: translateY(-2px);
}

.public-card > i {
    color: var(--pub-green);
    display: block;
    font-size: 1.5rem;
    margin-bottom: 1rem;
}

.public-card h2,
.public-card h3 {
    font-size: 1rem;
    font-weight: 800;
    letter-spacing: -0.01em;
    margin-bottom: 0.5rem;
}

.public-card p {
    color: var(--pub-muted);
    flex: 1;
    font-size: 0.875rem;
    line-height: 1.65;
    margin-bottom: 0;
}

.public-card a { color: var(--pub-ink); text-decoration: none; }
.public-card a:hover { color: var(--pub-green-mid); }

.public-card-kicker {
    color: var(--pub-green);
    display: block;
    font-size: 0.67rem;
    font-weight: 800;
    letter-spacing: 0.07em;
    margin-bottom: 0.6rem;
    text-transform: uppercase;
}

.public-text-link {
    align-items: center;
    color: var(--pub-green-mid) !important;
    display: inline-flex;
    font-size: 0.85rem;
    font-weight: 700;
    gap: 0.3rem;
    margin-top: auto;
    padding-top: 1rem;
    transition: gap var(--pub-transition);
}

.public-text-link:hover { gap: 0.55rem; }

.public-card img,
.public-card-image-placeholder {
    aspect-ratio: 16 / 9;
    border-radius: 6px;
    margin-bottom: 1rem;
    object-fit: cover;
    width: 100%;
}

.public-card-image-placeholder {
    align-items: center;
    background: var(--pub-mint);
    display: flex;
    justify-content: center;
}

.public-card-image-placeholder i { color: var(--pub-green); font-size: 2rem; }

/* Product category card */
.product-category-card { overflow: hidden; }

/* ─── Country links & grid ───────────────────────────────────────────────── */
.public-country-links { display: flex; flex-wrap: wrap; gap: 0.55rem; }

.public-country-links a {
    border: 1px solid var(--pub-line);
    border-radius: 6px;
    color: var(--pub-ink);
    font-size: 0.88rem;
    font-weight: 650;
    padding: 0.6rem 0.85rem;
    text-decoration: none;
    transition: all var(--pub-transition);
}

.public-country-links a:hover,
.public-country-grid a:hover {
    border-color: var(--pub-green);
    color: var(--pub-green-mid);
    background: var(--pub-mint);
}

.public-country-grid {
    display: grid;
    gap: 0.75rem;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.public-country-grid a {
    background: #fff;
    border: 1px solid var(--pub-line);
    border-radius: var(--pub-radius-sm);
    color: var(--pub-ink);
    display: grid;
    gap: 0.15rem;
    grid-template-columns: 1fr auto;
    padding: 1rem 1.1rem;
    text-decoration: none;
    transition: all var(--pub-transition);
}

.public-country-grid small { color: var(--pub-muted); font-size: 0.78rem; grid-column: 1; }
.public-country-grid i { color: var(--pub-green); grid-column: 2; grid-row: 1 / span 2; align-self: center; }

/* ─── Page heroes (inner pages) ──────────────────────────────────────────── */
.public-page-hero {
    background-position: center;
    background-size: cover;
    color: #fff;
    padding: 7rem 0;
}

.public-page-hero .container { max-width: min(1320px, calc(100% - 4rem)); }

.public-page-hero h1 {
    font-size: 3.65rem;
    font-weight: 850;
    letter-spacing: -0.02em;
    line-height: 1.06;
    max-width: 880px;
}

.public-page-hero p { color: rgba(255,255,255,.82); font-size: 1.06rem; line-height: 1.72; max-width: 760px; }
.public-page-hero .btn { margin-top: 0.5rem; }

.about-hero    { background-image: linear-gradient(105deg, rgba(5,40,50,.94), rgba(5,40,50,.45)), url("https://images.unsplash.com/photo-1497366754035-f200968a6e72?auto=format&fit=crop&w=1800&q=85"); }
.services-hero { background-image: linear-gradient(105deg, rgba(5,40,50,.96), rgba(5,40,50,.42)), url("https://images.unsplash.com/photo-1586528116311-ad8dd3c8310d?auto=format&fit=crop&w=1800&q=85"); }
.industries-hero { background-image: linear-gradient(105deg, rgba(5,40,50,.96), rgba(5,40,50,.45)), url("https://images.unsplash.com/photo-1504917595217-d4dc5ebe6122?auto=format&fit=crop&w=1800&q=85"); }
.countries-hero { background-image: linear-gradient(105deg, rgba(5,40,50,.96), rgba(5,40,50,.45)), url("https://images.unsplash.com/photo-1524661135-423995f22d0b?auto=format&fit=crop&w=1800&q=85"); }
.products-hero  { background-image: linear-gradient(105deg, rgba(5,40,50,.96), rgba(5,40,50,.45)), url("https://images.unsplash.com/photo-1556742049-0cfed4f6a45d?auto=format&fit=crop&w=1800&q=85"); }
.blog-hero      { background-image: linear-gradient(105deg, rgba(5,40,50,.96), rgba(5,40,50,.45)), url("https://images.unsplash.com/photo-1456324504439-367cee3b3c32?auto=format&fit=crop&w=1800&q=85"); }

/* ─── Copy layout ────────────────────────────────────────────────────────── */
.public-copy-layout { display: grid; gap: 3rem; grid-template-columns: 0.75fr 1.25fr; }

.public-rich-layout,
.public-two-column {
    align-items: start;
    display: grid;
    gap: 2rem;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 0.52fr);
}

.public-two-column { grid-template-columns: repeat(2, minmax(0, 1fr)); }

.public-rich-layout h2,
.public-info-block h2 {
    font-size: 2.15rem;
    font-weight: 850;
    letter-spacing: -0.02em;
    line-height: 1.12;
}

.public-rich-layout p,
.public-info-block p,
.public-clean-list {
    color: var(--pub-muted);
    line-height: 1.75;
}

.public-info-block {
    background: #fff;
    border: 1px solid var(--pub-line);
    border-radius: var(--pub-radius);
    padding: 1.5rem;
}

.public-info-block h3 {
    font-size: 1.05rem;
    font-weight: 800;
    margin-bottom: 0.75rem;
}

.public-visual-panel {
    background: #fff;
    border: 1px solid var(--pub-line);
    border-radius: var(--pub-radius);
    box-shadow: var(--pub-shadow-sm);
    overflow: hidden;
}

.public-visual-panel img {
    aspect-ratio: 4 / 3;
    display: block;
    object-fit: cover;
    width: 100%;
}

.public-visual-caption {
    border-top: 1px solid var(--pub-line);
    display: grid;
    gap: 0.35rem;
    padding: 1.1rem;
}

.public-visual-caption strong {
    color: var(--pub-ink);
    font-size: 0.98rem;
    font-weight: 800;
}

.public-visual-caption span {
    color: var(--pub-muted);
    font-size: 0.88rem;
    line-height: 1.55;
}

.public-checklist {
    display: grid;
    gap: 0.7rem;
    margin-top: 1.25rem;
}

.public-checklist div {
    align-items: start;
    display: grid;
    gap: 0.55rem;
    grid-template-columns: auto 1fr;
}

.public-checklist i {
    color: var(--pub-green);
    margin-top: 0.12rem;
}

.public-checklist span {
    color: var(--pub-ink-soft);
    line-height: 1.55;
}

.public-process-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.public-process-grid article {
    background: #fff;
    border: 1px solid var(--pub-line);
    border-radius: var(--pub-radius);
    padding: 1.25rem;
}

.public-process-grid span {
    color: var(--pub-green);
    display: block;
    font-size: 0.78rem;
    font-weight: 850;
    letter-spacing: 0.08em;
    margin-bottom: 0.8rem;
}

.public-process-grid h3 {
    font-size: 1rem;
    font-weight: 800;
    margin-bottom: 0.5rem;
}

.public-process-grid p {
    color: var(--pub-muted);
    font-size: 0.875rem;
    line-height: 1.65;
    margin-bottom: 0;
}

.public-clean-list {
    margin-bottom: 0;
    padding-left: 1.1rem;
}

.public-clean-list li + li { margin-top: 0.45rem; }

.public-site .product-detail-layout {
    align-items: start;
    display: grid;
    gap: 2rem;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 0.48fr);
}

.public-site .product-detail-layout h1 {
    font-size: 3.35rem;
    font-weight: 850;
    letter-spacing: -0.02em;
    line-height: 1.05;
}

.public-site .product-facts {
    display: grid;
    gap: 0.75rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin: 1.5rem 0 0;
}

.public-site .product-facts div {
    background: var(--pub-surface);
    border: 1px solid var(--pub-line);
    border-radius: var(--pub-radius-sm);
    border-top: 3px solid var(--pub-green);
    padding: 0.9rem;
}

.public-site .product-facts dt {
    color: var(--pub-muted);
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.public-site .product-facts dd {
    color: var(--pub-ink);
    font-weight: 700;
    margin-bottom: 0;
}

.product-visual-panel { position: sticky; top: 96px; }

/* ─── Category summary ───────────────────────────────────────────────────── */
.public-category-summary {
    display: grid;
    gap: 0.8rem;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.public-category-summary div {
    background: var(--pub-surface);
    border: 1px solid var(--pub-line);
    border-radius: var(--pub-radius-sm);
    border-top: 3px solid var(--pub-green);
    padding: 1rem;
}

.public-category-summary span { color: var(--pub-muted); display: block; font-size: 0.74rem; margin-bottom: 0.3rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; }
.public-category-summary strong { font-size: 0.92rem; font-weight: 700; }

/* ─── Product list ───────────────────────────────────────────────────────── */
.public-product-list { border-top: 1px solid var(--pub-line); }

.public-product-list a {
    align-items: center;
    border-bottom: 1px solid var(--pub-line);
    color: var(--pub-ink);
    display: grid;
    gap: 0.2rem;
    grid-template-columns: 1fr auto;
    padding: 1rem 0.25rem;
    text-decoration: none;
    transition: background var(--pub-transition), padding var(--pub-transition);
}

.public-product-list a:hover { background: var(--pub-surface); color: var(--pub-green-mid); padding-left: 0.75rem; padding-right: 0.75rem; }
.public-product-list a:hover i { color: var(--pub-green); }
.public-product-list span { color: var(--pub-muted); font-size: 0.8rem; grid-column: 1; }
.public-product-list i { color: var(--pub-line); grid-column: 2; grid-row: 1 / span 2; transition: color var(--pub-transition); }

/* ─── Filter links ───────────────────────────────────────────────────────── */
.public-filter-links { display: flex; flex-wrap: wrap; gap: 0.45rem; }

.public-filter-links a {
    border: 1px solid var(--pub-line);
    border-radius: 999px;
    color: var(--pub-ink-soft);
    font-size: 0.84rem;
    font-weight: 650;
    padding: 0.48rem 0.85rem;
    text-decoration: none;
    transition: all var(--pub-transition);
}

.public-filter-links a:hover,
.public-filter-links a.active {
    background: var(--pub-deep);
    border-color: var(--pub-deep);
    color: #fff;
}

/* ─── Contact page ───────────────────────────────────────────────────────── */
.public-contact-points { display: grid; gap: 0.55rem; margin-top: 1.4rem; }

.public-contact-points span {
    align-items: center;
    color: var(--pub-ink-soft);
    display: flex;
    font-size: 0.9rem;
    gap: 0.5rem;
}

.public-contact-points i { color: var(--pub-green); flex-shrink: 0; }

/* ─── CTA section ────────────────────────────────────────────────────────── */
.public-cta {
    background: linear-gradient(135deg, var(--pub-deep) 0%, var(--pub-deep-2) 60%, #0f6b5e 100%);
    color: #fff;
    padding: 4.5rem 0;
    position: relative;
    overflow: hidden;
}

.public-cta::before {
    background: radial-gradient(circle at 80% 50%, rgba(255,255,255,.04) 0%, transparent 60%);
    content: "";
    inset: 0;
    position: absolute;
}

.public-cta .container {
    align-items: end;
    display: grid;
    gap: 2rem;
    grid-template-columns: 1fr auto;
    position: relative;
}

.public-cta h2 { color: #fff; }
.public-cta p { color: rgba(255,255,255,.72); line-height: 1.75; margin: 0.65rem 0 0; max-width: 760px; }

.public-cta-actions {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    min-width: 240px;
}

.public-cta-actions .btn { justify-content: center; text-align: center; white-space: nowrap; }

/* ─── Footer ─────────────────────────────────────────────────────────────── */
.public-footer {
    background: var(--pub-deep);
    border-top: none;
    color: rgba(255,255,255,.72);
}

.public-footer .container { padding-top: 3.5rem; padding-bottom: 3.5rem; }

.public-footer .footer-brand strong { color: #fff; }
.public-footer .footer-brand small { color: rgba(255,255,255,.45); }
.public-footer .footer-brand .public-brand-mark {
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.15);
}

.public-footer .footer-brand .public-brand-logo-wrap {
    background: rgba(255,255,255,.95);
    border-color: rgba(255,255,255,.18);
}

.public-footer p { color: rgba(255,255,255,.55); font-size: 0.875rem; line-height: 1.7; }

.public-footer .col-6,
.public-footer .col-lg-3 { display: grid; gap: 0.5rem; align-content: start; }

.public-footer strong { color: rgba(255,255,255,.9); font-size: 0.78rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 0.35rem; }

.public-footer a:not(.public-brand) {
    color: rgba(255,255,255,.55);
    font-size: 0.875rem;
    text-decoration: none;
    transition: color var(--pub-transition);
}

.public-footer a:not(.public-brand):hover { color: rgba(255,255,255,.9); }

.footer-bottom {
    border-top: 1px solid rgba(255,255,255,.1);
    color: rgba(255,255,255,.38);
    display: flex;
    font-size: 0.78rem;
    justify-content: space-between;
    margin-top: 2.5rem;
    padding-top: 1.25rem;
}

.footer-bottom a { color: rgba(255,255,255,.45); text-decoration: none; }
.footer-bottom a:hover { color: rgba(255,255,255,.75); }

/* ─── Contact form success ───────────────────────────────────────────────── */
.success-panel {
    background: linear-gradient(135deg, #f0fdf9, #e6f7f5) !important;
    border-left: 3px solid var(--pub-green) !important;
    text-align: center;
    padding: 2.5rem !important;
}

.success-panel h2 { color: var(--pub-deep); font-weight: 800; }

/* ─── Blog ───────────────────────────────────────────────────────────────── */
.blog-card { overflow: hidden; }
.blog-card img { aspect-ratio: 16/9; border-radius: 7px; display: block; margin-bottom: 1rem; object-fit: cover; width: 100%; transition: transform 0.3s ease; }
.blog-card:hover img { transform: scale(1.03); }

/* ─── Responsive ─────────────────────────────────────────────────────────── */
@media (min-width: 1500px) {
    .public-card-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
    .public-card-grid.services { grid-template-columns: repeat(4, minmax(0, 1fr)); }
    .public-country-grid { grid-template-columns: repeat(6, minmax(0, 1fr)); }
}

@media (max-width: 1199.98px) {
    .public-card-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .public-feature-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .public-process-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 991.98px) {
    .public-site .hero-copy h1 { font-size: 3.2rem; }
    .public-feature-grid, .public-feature-grid.three { grid-template-columns: repeat(2, 1fr); }
    .public-card-grid, .public-card-grid.services { grid-template-columns: repeat(2, 1fr); }
    .public-industry-grid { grid-template-columns: repeat(3, 1fr); }
    .public-country-grid { grid-template-columns: repeat(3, 1fr); }
    .public-media-copy { padding: 3rem; }
    .public-cta .container { align-items: start; grid-template-columns: 1fr; }
    .public-cta-actions { flex-direction: row; flex-wrap: wrap; min-width: 0; }
    .public-copy-layout { grid-template-columns: 1fr; gap: 1.5rem; }
    .public-rich-layout,
    .public-two-column,
    .public-site .product-detail-layout { grid-template-columns: 1fr; }
    .product-visual-panel { position: static; }
}

@media (max-width: 575.98px) {
    .public-site .container,
    .public-site .container.narrow-copy,
    .public-media-band .container,
    .public-page-hero .container {
        max-width: calc(100% - 2rem);
    }

    .public-site .public-hero { min-height: 640px; }
    .public-site .hero-copy { padding: 5rem 0 4rem; }
    .public-site .hero-copy h1,
    .public-page-hero h1 { font-size: 2.5rem; }
    .public-page-hero { padding: 5rem 0; }
    .public-trust-strip .container,
    .public-feature-grid, .public-feature-grid.three,
    .public-card-grid, .public-card-grid.services,
    .public-country-grid,
    .public-category-summary,
    .public-process-grid,
    .public-site .product-facts { grid-template-columns: 1fr; }
    .public-trust-strip div,
    .public-trust-strip div:first-child {
        border-left: 0;
        border-right: 0;
        border-top: 1px solid rgba(255,255,255,.1);
        padding-left: 0;
    }
    .public-media-band .container { grid-template-columns: 1fr; }
    .public-media-copy { padding: 2.25rem 0.75rem; }
    .public-media-band img { min-height: 240px; }
    .public-industry-grid { grid-template-columns: repeat(2, 1fr); }
    .public-section-heading h2,
    .public-rich-layout h2,
    .public-info-block h2,
    .public-copy-layout h2,
    .public-cta h2 { font-size: 1.9rem; }
    .public-site .product-detail-layout h1 { font-size: 2.35rem; }
    .public-footer .container { padding-top: 2.5rem; }
}
