/* ═══════════════════════════════════════════════════════════
   Altura — company.css
   ═══════════════════════════════════════════════════════════ */

.altura-about-page {
    background: var(--altura-primary);
    color: var(--altura-white);
    font-family: 'TikTokSans', sans-serif;
    overflow: hidden;
	padding-top: 140px;
}
.altura-about-page * { box-sizing: border-box; }
.altura-about-page a { color: inherit; text-decoration: none; }

.about-container {
    width: min(1130px, calc(100% - 45px));
    margin: 0 auto;
}

/* ── Hero ── */

.about-hero h1 {
    font-family: 'Cousine', monospace;
    font-size: clamp(40px, 7vw, 90px);
    line-height: 1;
    font-weight: 400;
    text-align: center;
    margin: 0 0 58px;
}

.about-image-block {
    height: 480px;
    position: relative;
    margin-bottom: 55px;
}
.about-image-bg {
    position: absolute;
    left: 185px;
    top: 0;
    width: 760px;
    height: 245px;
    background: var(--altura-gray);
    opacity: .55;
    z-index: 1;
}
.about-image-block h2 {
    position: absolute;
    left: 0;
    top: 92px;
    font-family: 'Cousine', monospace;
    font-size: clamp(28px, 5vw, 63px);
    line-height: 1;
    font-weight: 400;
    letter-spacing: .01em;
    margin: 0;
    z-index: 3;
}
.about-image-block img {
    position: absolute;
    left: 421px;
    top: 83px;
    width: 900px;
    height: 392px;
    object-fit: cover;
    object-position: center top;
    filter: grayscale(1);
    display: block;
    z-index: 2;
}

.about-text { max-width: 1065px; }
.about-text p {
    font-size: clamp(14px, 1.6vw, 17px);
    line-height: 1.6;
    margin: 0 0 18px;
}

/* ── Philosophy ── */
.about-philosophy { padding: 48px 0; }

.about-title-line {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 75px;
    align-items: center;
    margin: 0 0 65px;
}
.about-title-line::after {
    content: '';
    padding: 27px 22px;
    background: var(--altura-brown-soft);
    display: block;
}
.about-title-line span {
    display: flex;
    align-items: center;
    background: var(--altura-brown-soft);
    font-family: 'Cousine', monospace;
    font-size: clamp(16px, 2.5vw, 30px);
    line-height: 1;
	padding: 12px 50px;
}

.luxury-image {
    height: clamp(200px, 30vw, 420px);
    position: relative;
    margin-top: 58px;
    overflow: hidden;
}
.luxury-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}
.luxury-image::after {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(255,255,255,.15);
}
.luxury-image span {
    position: absolute;
    right: 36px;
    bottom: 42px;
    z-index: 2;
    font-family: 'Cousine', monospace;
    font-size: clamp(28px, 5vw, 63px);
    line-height: 1;
}

/* ── Values ── */
.about-values { padding: 0 0 86px; }

.trust-list {
    display: grid;
    gap: 24px;
    padding-left: 20px;
    margin-top: 80px;
}

.trust-list button {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: none;
    border: 0;
    border-bottom: 1px solid rgba(255,255,255,.2);
    padding: 0 25px 16px 0;
    color: var(--altura-white);
    font-family: 'TikTokSans', sans-serif;
    font-size: clamp(24px, 4vw, 48px);
    line-height: 1.2;
    font-weight: 500;
    text-align: left;
    cursor: pointer;
    transition: opacity var(--altura-transition);
}

.trust-list button:hover {
    opacity: .7;
}

.trust-list span {
    font-size: clamp(26px, 4vw, 50px);
    line-height: 1;
    font-weight: 400;
    flex-shrink: 0;
    transition: transform var(--altura-transition);
}

.trust-list button.open span {
    transform: rotate(45deg);
}

.trust-panel {
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    color: var(--altura-white);
    font-family: 'Cousine', monospace;
    font-size: clamp(14px, 1.6vw, 18px);
    line-height: 1.6;
    padding: 0 25px 0 0;
    transition: max-height 300ms ease-out, opacity 250ms ease-out, padding 250ms ease-out;
}

.trust-panel.open {
    max-height: 180px;
    opacity: 1;
    padding: 15px 25px 0 0;
}

/* ── Responsive 768px ── */
@media (max-width: 768px) {
    .trust-list { margin-top: 40px; padding-left: 0; gap: 16px; }
    .trust-list button { padding: 0 16px 12px 0; }
	.trust-panel.open { padding: 15px 0px 0 0; }
}


/* ── Contact ── */
.about-contact {
    position: relative;
    background: var(--altura-primary);
    padding-bottom: 70px;
}
.about-contact img {
    width: 100%;
    height: clamp(180px, 35vw, 470px);
    object-fit: cover;
    object-position: center top;
    filter: grayscale(1);
    display: block;
}
.about-contact::after {
    content: '';
    position: absolute;
    left: 295px;
    top: 470px;
    width: 100%;
    height: 140px;
    background: rgba(181,181,181,.82);
    z-index: 1;
}
.about-contact .about-container {
    position: relative;
    z-index: 2;
    margin-top: 40px;
}
.about-contact a {
    font-family: 'TikTokSans', sans-serif;
    font-size: clamp(36px, 6vw, 76px);
    line-height: 1;
    font-weight: 400;
    color: var(--altura-white);
    transition: color 200ms ease-out;
    display: block;
}
.about-contact a:hover { color: var(--altura-brown); }

/* ── Responsive 1024px ── */
@media (max-width: 1024px) {
    .about-image-block img { left: 260px; width: 760px; }
    .about-title-line { gap: 40px; }
}

/* ── Responsive 767px ── */
@media (max-width: 767px) {
    .about-container { width: calc(100% - 45px); }

    .about-hero { padding: 42px 0 15px; }
    .about-hero h1 { margin-bottom: 28px; }

    .about-image-block { height: 240px; margin-bottom: 26px; }
    .about-image-bg { left: 74px; width: 260px; height: 120px; }
    .about-image-block h2 { top: 38px; }
    .about-image-block img { left: 145px; top: 34px; width: 405px; height: 165px; }

    .about-title-line { grid-template-columns: 1fr; gap: 20px; margin-bottom: 30px; }
	.about-title-line::after { content: none; }
    .about-title-line span { padding-left: 22px; }

    .about-philosophy { padding-bottom: 28px; }

    .luxury-image { margin-top: 27px; }
    .luxury-image span { right: 18px; bottom: 20px; }

    .about-values { padding-bottom: 52px; }
    .values-list { gap: 12px; }
    .values-list button { padding-right: 22px; padding-bottom: 12px; }

    .about-contact { padding-bottom: 42px; }
    .about-contact::after { left: 126px; top: 180px; height: 66px; }
    .about-contact .about-container { margin-top: 20px; }
}