/*
 * trust-centre.css — Trust Centre page styles.
 * Depends on: base.css, layout.css, components.css
 * Loaded via $page_meta['extra_css'] on all trust-centre/* pages.
 */

/* ── Hero ─────────────────────────────────────────────────────────────────── */

.trust-centre-hero {
    padding-block: clamp(var(--space-16), 10vw, var(--space-24));
    position:      relative;
    overflow:      hidden;
    text-align:    center;
}

.trust-centre-hero::before {
    content:          '';
    position:         absolute;
    inset:            0;
    background-image:
        linear-gradient(rgba(16, 185, 129, 0.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(16, 185, 129, 0.04) 1px, transparent 1px);
    background-size:  60px 60px;
    pointer-events:   none;
}

.trust-centre-hero::after {
    content:        '';
    position:       absolute;
    inset:          0;
    background:     radial-gradient(
        ellipse 60% 50% at 50% 0%,
        rgba(16, 185, 129, 0.10) 0%,
        transparent 70%
    );
    pointer-events: none;
}

.trust-centre-hero__inner {
    position:   relative;
    z-index:    var(--z-base);
    max-width:  760px;
    margin-inline: auto;
}

.trust-centre-hero__badge {
    display:         inline-flex;
    align-items:     center;
    gap:             var(--space-2);
    padding:         var(--space-1) var(--space-3);
    border-radius:   var(--radius-full);
    background:      rgba(16, 185, 129, 0.12);
    border:          1px solid rgba(16, 185, 129, 0.30);
    color:           var(--color-accent);
    font-size:       var(--text-xs);
    font-weight:     var(--font-semibold);
    letter-spacing:  var(--tracking-wider);
    text-transform:  uppercase;
    margin-bottom:   var(--space-6);
}

.trust-centre-hero__heading {
    font-size:       var(--text-5xl);
    font-weight:     var(--font-extrabold);
    line-height:     var(--leading-tight);
    letter-spacing:  var(--tracking-tight);
    color:           var(--color-text-primary);
    margin-bottom:   var(--space-4);
}

.trust-centre-hero__sub {
    font-size:    var(--text-xl);
    color:        var(--color-text-secondary);
    line-height:  var(--leading-relaxed);
    margin-bottom:var(--space-8);
    margin-inline:auto;
}

.trust-centre-hero__actions {
    display:         flex;
    gap:             var(--space-4);
    justify-content: center;
    flex-wrap:       wrap;
}

/* ── Overview grid cards ──────────────────────────────────────────────────── */

.trust-overview-grid {
    display:               grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap:                   var(--space-6);
}

.trust-overview-card {
    background:    var(--color-bg-card);
    border:        1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding:       var(--space-6);
    text-decoration: none;
    transition:    border-color var(--transition-fast),
                   box-shadow var(--transition-fast),
                   background var(--transition-fast);
    display:       flex;
    flex-direction:column;
    gap:           var(--space-3);
}

.trust-overview-card:hover {
    border-color: var(--color-border-brand);
    background:   var(--color-bg-elevated);
    box-shadow:   0 0 0 1px rgba(14, 165, 233, 0.15);
}

.trust-overview-card__icon {
    width:           44px;
    height:          44px;
    border-radius:   var(--radius-md);
    background:      rgba(16, 185, 129, 0.12);
    border:          1px solid rgba(16, 185, 129, 0.20);
    display:         flex;
    align-items:     center;
    justify-content: center;
    font-size:       var(--text-lg);
    color:           var(--color-accent);
    flex-shrink:     0;
}

.trust-overview-card__title {
    font-size:   var(--text-base);
    font-weight: var(--font-semibold);
    color:       var(--color-text-primary);
}

.trust-overview-card__desc {
    font-size:   var(--text-sm);
    color:       var(--color-text-secondary);
    line-height: var(--leading-relaxed);
    flex:        1;
}

.trust-overview-card__link {
    font-size:   var(--text-sm);
    font-weight: var(--font-medium);
    color:       var(--color-text-brand);
    display:     flex;
    align-items: center;
    gap:         var(--space-1);
}

/* ── Compliance matrix table ──────────────────────────────────────────────── */

.compliance-matrix-wrap {
    overflow-x: auto;
    border-radius: var(--radius-lg);
    border:        1px solid var(--color-border);
}

.compliance-matrix-table {
    width:           100%;
    border-collapse: collapse;
    font-size:       var(--text-sm);
    color:           var(--color-text-primary);
}

.compliance-matrix-table thead {
    background: var(--color-bg-elevated);
}

.compliance-matrix-table thead th {
    padding:        var(--space-3) var(--space-5);
    text-align:     left;
    font-weight:    var(--font-semibold);
    font-size:      var(--text-xs);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wider);
    color:          var(--color-text-secondary);
    border-bottom:  1px solid var(--color-border);
    white-space:    nowrap;
}

.compliance-matrix-table tbody tr {
    border-bottom: 1px solid var(--color-border);
    transition:    background var(--transition-fast);
}

.compliance-matrix-table tbody tr:last-child {
    border-bottom: none;
}

.compliance-matrix-table tbody tr:hover {
    background: var(--color-bg-elevated);
}

.compliance-matrix-table td {
    padding:     var(--space-4) var(--space-5);
    vertical-align: middle;
    line-height: var(--leading-normal);
}

.compliance-matrix-table td:first-child {
    font-weight: var(--font-semibold);
    white-space: nowrap;
}

/* ── Status badges ────────────────────────────────────────────────────────── */

.status-badge {
    display:        inline-flex;
    align-items:    center;
    gap:            var(--space-1-5, 0.375rem);
    padding:        0.25rem 0.625rem;
    border-radius:  var(--radius-full);
    font-size:      var(--text-xs);
    font-weight:    var(--font-semibold);
    white-space:    nowrap;
}

.status-badge--active {
    background: rgba(34, 197, 94, 0.12);
    border:     1px solid rgba(34, 197, 94, 0.25);
    color:      var(--color-success);
}

.status-badge--in-progress {
    background: rgba(245, 158, 11, 0.12);
    border:     1px solid rgba(245, 158, 11, 0.25);
    color:      var(--color-warning);
}

.status-badge--planned {
    background: rgba(100, 116, 139, 0.12);
    border:     1px solid rgba(100, 116, 139, 0.25);
    color:      var(--color-text-muted);
}

/* ── Sub-processor table ──────────────────────────────────────────────────── */

.sub-processor-table {
    width:           100%;
    border-collapse: collapse;
    font-size:       var(--text-sm);
    color:           var(--color-text-primary);
}

.sub-processor-table thead {
    background: var(--color-bg-elevated);
}

.sub-processor-table thead th {
    padding:        var(--space-3) var(--space-5);
    text-align:     left;
    font-weight:    var(--font-semibold);
    font-size:      var(--text-xs);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wider);
    color:          var(--color-text-secondary);
    border-bottom:  1px solid var(--color-border);
    white-space:    nowrap;
}

.sub-processor-table tbody tr {
    border-bottom: 1px solid var(--color-border);
    transition:    background var(--transition-fast);
}

.sub-processor-table tbody tr:last-child {
    border-bottom: none;
}

.sub-processor-table tbody tr:hover {
    background: var(--color-bg-elevated);
}

.sub-processor-table td {
    padding:        var(--space-4) var(--space-5);
    vertical-align: top;
    line-height:    var(--leading-relaxed);
}

.sub-processor-table td:first-child {
    font-weight: var(--font-semibold);
    white-space: nowrap;
    color:       var(--color-text-primary);
}

/* ── Download / DPA card ──────────────────────────────────────────────────── */

.trust-download-card {
    background:    var(--color-bg-elevated);
    border:        1px solid var(--color-border-brand);
    border-radius: var(--radius-lg);
    padding:       var(--space-8);
    display:       flex;
    align-items:   center;
    gap:           var(--space-6);
    flex-wrap:     wrap;
}

.trust-download-card__icon {
    width:           64px;
    height:          64px;
    border-radius:   var(--radius-lg);
    background:      rgba(14, 165, 233, 0.12);
    border:          1px solid rgba(14, 165, 233, 0.20);
    display:         flex;
    align-items:     center;
    justify-content: center;
    font-size:       1.75rem;
    color:           var(--color-brand);
    flex-shrink:     0;
}

.trust-download-card__body {
    flex: 1;
    min-width: 220px;
}

.trust-download-card__title {
    font-size:   var(--text-lg);
    font-weight: var(--font-semibold);
    color:       var(--color-text-primary);
    margin-bottom: var(--space-1);
}

.trust-download-card__desc {
    font-size:  var(--text-sm);
    color:      var(--color-text-secondary);
    line-height:var(--leading-relaxed);
}

.trust-download-card__actions {
    display:  flex;
    gap:      var(--space-3);
    flex-wrap:wrap;
    flex-shrink: 0;
}

/* ── Info/detail blocks ───────────────────────────────────────────────────── */

.trust-detail-grid {
    display:               grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap:                   var(--space-6);
}

.trust-detail-block {
    background:    var(--color-bg-card);
    border:        1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding:       var(--space-6);
}

.trust-detail-block__heading {
    font-size:     var(--text-base);
    font-weight:   var(--font-semibold);
    color:         var(--color-text-primary);
    margin-bottom: var(--space-4);
    display:       flex;
    align-items:   center;
    gap:           var(--space-2);
}

.trust-detail-block__heading i {
    color: var(--color-accent);
}

.trust-detail-block ul {
    list-style:     none;
    padding:        0;
    margin:         0;
    display:        flex;
    flex-direction: column;
    gap:            var(--space-2);
}

.trust-detail-block li {
    font-size:   var(--text-sm);
    color:       var(--color-text-secondary);
    line-height: var(--leading-relaxed);
    display:     flex;
    gap:         var(--space-2);
}

.trust-detail-block li::before {
    content:     '\2713'; /* checkmark */
    color:       var(--color-accent);
    font-weight: var(--font-bold);
    flex-shrink: 0;
    margin-top:  1px;
}

/* ── Contact / disclosure panel ──────────────────────────────────────────── */

.trust-contact-panel {
    background:    var(--color-bg-card);
    border:        1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding:       var(--space-8);
    display:       flex;
    gap:           var(--space-8);
    flex-wrap:     wrap;
    align-items:   flex-start;
}

.trust-contact-item {
    flex:     1;
    min-width:200px;
}

.trust-contact-item__label {
    font-size:     var(--text-xs);
    font-weight:   var(--font-semibold);
    text-transform:uppercase;
    letter-spacing:var(--tracking-wider);
    color:         var(--color-text-muted);
    margin-bottom: var(--space-2);
}

.trust-contact-item__value {
    font-size:   var(--text-base);
    font-weight: var(--font-semibold);
    color:       var(--color-text-primary);
}

.trust-contact-item__value a {
    color:           var(--color-text-brand);
    text-decoration: none;
}

.trust-contact-item__value a:hover {
    text-decoration: underline;
}

.trust-contact-item__note {
    font-size:   var(--text-xs);
    color:       var(--color-text-muted);
    margin-top:  var(--space-1);
    line-height: var(--leading-relaxed);
}

/* ── SLA table ───────────────────────────────────────────────────────────── */

.sla-table {
    width:           100%;
    border-collapse: collapse;
    font-size:       var(--text-sm);
}

.sla-table th,
.sla-table td {
    padding:       var(--space-3) var(--space-4);
    text-align:    left;
    border-bottom: 1px solid var(--color-border);
}

.sla-table thead th {
    font-size:      var(--text-xs);
    font-weight:    var(--font-semibold);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wider);
    color:          var(--color-text-muted);
    background:     var(--color-bg-elevated);
}

.sla-table tbody tr:last-child td {
    border-bottom: none;
}

.sla-table tbody td:first-child {
    font-weight: var(--font-medium);
    color:       var(--color-text-primary);
}

/* ── Rights table ────────────────────────────────────────────────────────── */

.rights-table {
    width:           100%;
    border-collapse: collapse;
    font-size:       var(--text-sm);
}

.rights-table th,
.rights-table td {
    padding:       var(--space-3) var(--space-4);
    text-align:    left;
    border-bottom: 1px solid var(--color-border);
    vertical-align: top;
    line-height:   var(--leading-relaxed);
}

.rights-table thead th {
    font-size:      var(--text-xs);
    font-weight:    var(--font-semibold);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wider);
    color:          var(--color-text-muted);
    background:     var(--color-bg-elevated);
}

.rights-table tbody tr:last-child td {
    border-bottom: none;
}

.rights-table tbody td:first-child {
    font-weight: var(--font-semibold);
    color:       var(--color-text-primary);
    white-space: nowrap;
}

/* ── DPA clause list ─────────────────────────────────────────────────────── */

.dpa-clause-list {
    display:        flex;
    flex-direction: column;
    gap:            var(--space-4);
    list-style:     none;
    padding:        0;
    margin:         0;
}

.dpa-clause {
    background:    var(--color-bg-card);
    border:        1px solid var(--color-border);
    border-left:   3px solid var(--color-brand);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    padding:       var(--space-4) var(--space-5);
}

.dpa-clause__term {
    font-size:     var(--text-sm);
    font-weight:   var(--font-semibold);
    color:         var(--color-text-primary);
    margin-bottom: var(--space-1);
}

.dpa-clause__detail {
    font-size:   var(--text-sm);
    color:       var(--color-text-secondary);
    line-height: var(--leading-relaxed);
}

/* ── Breadcrumb ──────────────────────────────────────────────────────────── */

.trust-breadcrumb {
    display:     flex;
    align-items: center;
    gap:         var(--space-2);
    font-size:   var(--text-sm);
    color:       var(--color-text-muted);
    margin-bottom: var(--space-6);
    flex-wrap:   wrap;
}

.trust-breadcrumb a {
    color:           var(--color-text-secondary);
    text-decoration: none;
}

.trust-breadcrumb a:hover {
    color:           var(--color-text-primary);
    text-decoration: underline;
}

.trust-breadcrumb__sep {
    color: var(--color-text-muted);
    font-size: var(--text-xs);
}

.trust-breadcrumb__current {
    color: var(--color-text-primary);
}

/* ── Certification cards grid ────────────────────────────────────────────── */

.trust-certs-grid {
    display:               grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap:                   var(--space-6);
    margin-bottom:         var(--space-6);
}

.trust-cert-card {
    background:     var(--color-bg-card);
    border:         1px solid var(--color-border);
    border-radius:  var(--radius-lg);
    padding:        var(--space-6);
    display:        flex;
    gap:            var(--space-4);
    align-items:    flex-start;
    transition:     border-color var(--transition-fast),
                    box-shadow var(--transition-fast);
}

.trust-cert-card:hover {
    border-color: var(--color-border-brand);
    box-shadow:   0 0 0 1px rgba(14, 165, 233, 0.12);
}

.trust-cert-card__icon {
    width:           44px;
    height:          44px;
    flex-shrink:     0;
    border-radius:   var(--radius-md);
    background:      rgba(14, 165, 233, 0.10);
    border:          1px solid rgba(14, 165, 233, 0.20);
    display:         flex;
    align-items:     center;
    justify-content: center;
    font-size:       var(--text-lg);
    color:           var(--color-brand);
}

.trust-cert-card__icon--success {
    background: rgba(34, 197, 94, 0.10);
    border-color: rgba(34, 197, 94, 0.20);
    color:        var(--color-success);
}

.trust-cert-card__body {
    flex:           1;
    display:        flex;
    flex-direction: column;
    gap:            var(--space-2);
}

.trust-cert-card__name {
    font-size:   var(--text-base);
    font-weight: var(--font-semibold);
    color:       var(--color-text-primary);
}

.trust-cert-card__note {
    font-size:   var(--text-xs);
    color:       var(--color-text-muted);
    line-height: var(--leading-relaxed);
    margin-top:  var(--space-1);
}

.trust-certs-footer {
    font-size:  var(--text-sm);
    color:      var(--color-text-muted);
    text-align: center;
}

.trust-certs-footer a {
    color:           var(--color-text-brand);
    text-decoration: none;
}

.trust-certs-footer a:hover {
    text-decoration: underline;
}

/* ── Security architecture cards ─────────────────────────────────────────── */

.trust-arch-grid {
    display:               grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap:                   var(--space-6);
}

.trust-arch-card {
    background:    var(--color-bg-card);
    border:        1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding:       var(--space-7);
    display:       flex;
    flex-direction:column;
    gap:           var(--space-4);
    transition:    border-color var(--transition-fast),
                   background var(--transition-fast);
}

.trust-arch-card:hover {
    border-color: var(--color-border-brand);
    background:   var(--color-bg-elevated);
}

.trust-arch-card__icon {
    width:           48px;
    height:          48px;
    border-radius:   var(--radius-md);
    background:      rgba(16, 185, 129, 0.12);
    border:          1px solid rgba(16, 185, 129, 0.20);
    display:         flex;
    align-items:     center;
    justify-content: center;
    font-size:       var(--text-xl);
    color:           var(--color-accent);
    flex-shrink:     0;
}

.trust-arch-card__heading {
    font-size:   var(--text-lg);
    font-weight: var(--font-semibold);
    color:       var(--color-text-primary);
    line-height: var(--leading-snug);
}

.trust-arch-card__body {
    font-size:   var(--text-sm);
    color:       var(--color-text-secondary);
    line-height: var(--leading-relaxed);
    flex:        1;
}

.trust-arch-card__link {
    display:     inline-flex;
    align-items: center;
    gap:         var(--space-1);
    font-size:   var(--text-sm);
    font-weight: var(--font-medium);
    color:       var(--color-text-brand);
    text-decoration: none;
    margin-top:  auto;
}

.trust-arch-card__link:hover {
    text-decoration: underline;
}

/* ── Live trust posture panel ─────────────────────────────────────────────── */

.trust-posture-live {
    background:    var(--color-bg-elevated);
    border:        1px solid var(--color-border-brand);
    border-radius: var(--radius-lg);
    padding:       var(--space-8);
    display:       flex;
    flex-direction:column;
    gap:           var(--space-6);
}

.trust-posture-status {
    display:     flex;
    align-items: center;
    gap:         var(--space-4);
    flex-wrap:   wrap;
}

.trust-posture-timestamp {
    font-size:  var(--text-sm);
    color:      var(--color-text-muted);
}

.trust-posture-metrics {
    display:               grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap:                   var(--space-4);
}

.trust-posture-metric {
    background:    var(--color-bg-card);
    border:        1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding:       var(--space-4) var(--space-5);
    display:       flex;
    flex-direction:column;
    gap:           var(--space-1);
}

.trust-posture-metric__value {
    font-size:   var(--text-2xl);
    font-weight: var(--font-bold);
    color:       var(--color-text-primary);
    line-height: var(--leading-none);
}

.trust-posture-metric__label {
    font-size:  var(--text-xs);
    color:      var(--color-text-muted);
    line-height:var(--leading-normal);
}

.trust-posture-attestations {
    list-style: none;
    padding:    0;
    margin:     0;
    display:    flex;
    flex-wrap:  wrap;
    gap:        var(--space-3) var(--space-6);
}

.trust-posture-attestation {
    display:     flex;
    align-items: center;
    gap:         var(--space-2);
    font-size:   var(--text-sm);
    color:       var(--color-text-secondary);
}

/* ── download-card success icon variant ──────────────────────────────────── */

.trust-download-card__icon--success {
    background:   rgba(34, 197, 94, 0.12);
    border-color: rgba(34, 197, 94, 0.20);
    color:        var(--color-success);
}

/* ── Responsive ──────────────────────────────────────────────────────────── */

@media (max-width: 640px) {
    .trust-centre-hero__heading {
        font-size: var(--text-4xl);
    }

    .trust-download-card {
        flex-direction: column;
    }

    .trust-download-card__icon {
        width:  48px;
        height: 48px;
    }

    .trust-contact-panel {
        flex-direction: column;
        gap:            var(--space-5);
    }

    .compliance-matrix-table td,
    .sub-processor-table td {
        font-size: var(--text-xs);
    }
}
