/* ============================================================
 * Tecnel System — interior / page-layer CSS
 * (consolidated from the design's per-page <style> blocks;
 *  core.css already carries the homepage system: header, footer,
 *  .trust, .scene/.hotspot, .brand-grid, .cta-strip, .dm-modal, .btn*)
 * ============================================================ */

/* ---- Interior header: solid + visible from the top ---- */
.site-header.interior,
body.interior .site-header { opacity: 1; transform: none; pointer-events: auto; }
.site-nav a.is-active { color: #fff; position: relative; }
.site-nav a.is-active::after { content: ""; position: absolute; left: 0; right: 0; bottom: -6px; height: 2px; background: var(--ts-red); }

/* ---- Mobile menu (block-based chrome) ---- */
.ts-burger { display: none; flex-direction: column; gap: 5px; width: 30px; padding: 6px 0; background: 0; border: 0; cursor: pointer; }
.ts-burger span { height: 2px; background: #fff; display: block; }
.ts-burger span:first-child { width: 30px; } .ts-burger span:nth-child(2) { width: 22px; } .ts-burger span:last-child { width: 26px; }
.ts-mobile { position: fixed; inset: 0; z-index: 90; background: var(--ts-black); display: none; flex-direction: column; padding: 96px var(--gutter) 40px; }
.ts-mobile.open { display: flex; }
.ts-mobile a { font-family: var(--font-display); font-weight: 700; font-size: 1.4rem; text-transform: uppercase; letter-spacing: 0.02em; color: #fff; padding: 14px 0; border-bottom: 1px solid var(--ts-line-dim); }
.ts-mobile .ts-mobile__lang { margin-top: 20px; color: var(--ts-red); font-size: 1rem; }
.ts-mobile__close { position: absolute; top: 26px; right: var(--gutter); width: 40px; height: 40px; color: #fff; background: 0; border: 1px solid var(--ts-line-dark); }
@media (max-width: 900px) {
  .site-nav { display: none; }
  .ts-burger { display: inline-flex; }
}

/* ---- PAGE HERO (shared) ---- */
.page-hero { position: relative; min-height: 60vh; display: flex; align-items: flex-end; padding: 176px 0 64px; background: var(--ts-black); overflow: hidden; border-bottom: 1px solid var(--ts-line-dim); }
.page-hero.tall { min-height: 70vh; padding: 184px 0 72px; }
.page-hero.short { min-height: 50vh; padding: 184px 0 60px; }
.page-hero__bg { position: absolute; inset: 0; background-size: cover; background-position: 60% center; filter: saturate(1.02) contrast(1.04); }
/* CSS-built industrial canvas (non-photo heroes) */
.page-hero__bg.css-canvas {
  background:
    radial-gradient(ellipse 60% 55% at 78% 30%, rgba(216,31,42,0.20) 0%, rgba(216,31,42,0) 60%),
    radial-gradient(ellipse 50% 50% at 12% 90%, rgba(255,170,40,0.10) 0%, rgba(0,0,0,0) 60%),
    repeating-linear-gradient(90deg, rgba(255,255,255,0.035) 0 1px, transparent 1px 92px),
    repeating-linear-gradient(0deg, rgba(255,255,255,0.035) 0 1px, transparent 1px 92px),
    linear-gradient(180deg, #141417 0%, #060608 100%);
}
.page-hero__bg.photo::after {
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(96deg, rgba(5,5,6,0.92) 0%, rgba(5,5,6,0.66) 38%, rgba(5,5,6,0.30) 70%, rgba(5,5,6,0.55) 100%),
    linear-gradient(180deg, rgba(5,5,6,0.7) 0%, rgba(5,5,6,0) 26%, rgba(5,5,6,0) 60%, rgba(5,5,6,0.92) 100%);
}
.page-hero__bg.css-canvas::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(5,5,6,0.5) 0%, rgba(5,5,6,0) 30%, rgba(5,5,6,0) 62%, rgba(5,5,6,0.78) 100%);
}
.page-hero__inner { position: relative; z-index: 2; width: 100%; }
.breadcrumb { display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-mono); font-weight: 500; font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(255,255,255,0.55); margin-bottom: 30px; }
.breadcrumb a { color: rgba(255,255,255,0.55); transition: color var(--dur-fast) var(--ease-std); }
.breadcrumb a:hover { color: #fff; }
.breadcrumb .sep { color: var(--ts-red); }
.breadcrumb .here { color: #fff; }
.page-hero__eyebrow { display: inline-flex; align-items: center; gap: 14px; font-family: var(--font-mono); font-weight: 500; font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--ts-red); margin-bottom: 22px; }
.page-hero__eyebrow::before { content: ""; width: 32px; height: 2px; background: var(--ts-red); }
.page-hero h1 { font-family: var(--font-display); font-weight: 800; font-size: clamp(2.4rem, 5.4vw, 4.8rem); line-height: 0.98; letter-spacing: 0.012em; color: #fff; text-transform: uppercase; max-width: 20ch; }
.page-hero h1 .red, .page-hero h1 em { font-style: normal; color: var(--ts-red); }
.page-hero__sub { margin-top: 28px; max-width: 58ch; color: rgba(255,255,255,0.82); font-family: var(--font-body); font-weight: 300; font-size: clamp(1.02rem, 1.3vw, 1.18rem); line-height: 1.65; }
.page-hero__meta { margin-top: 42px; display: flex; flex-wrap: wrap; gap: 0; border-top: 1px solid var(--ts-line-dark); }
.page-hero__meta .m { padding: 20px 36px 0 0; margin-right: 36px; border-right: 1px solid var(--ts-line-dark); }
.page-hero__meta .m:last-child { border-right: 0; }
.page-hero__meta .k { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.3rem, 1.8vw, 1.7rem); color: #fff; line-height: 1; }
.page-hero__meta .k .plus { color: var(--ts-yellow); }
.page-hero__meta .l { margin-top: 8px; font-family: var(--font-mono); font-weight: 500; font-size: 9.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ts-fg-mute); }

/* ---- SECTION SCAFFOLD ---- */
.sec { padding: clamp(88px, 11vw, 150px) 0; }
.sec--dark { background: var(--ts-ink); color: var(--ts-fg-on-dark); border-top: 1px solid var(--ts-line-dim); }
.sec--paper { background: var(--ts-paper); color: var(--ts-ink); border-top: 1px solid var(--ts-paper-line); }
.sec-eyebrow { display: inline-flex; align-items: center; gap: 14px; font-family: var(--font-mono); font-weight: 500; font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--ts-red); margin-bottom: 22px; }
.sec-eyebrow::before { content: ""; width: 32px; height: 2px; background: var(--ts-red); }

/* ============================================================ SETTORE ============================================================ */
.scena-sec .scena__grid { display: grid; grid-template-columns: minmax(0,5fr) minmax(0,7fr); gap: clamp(40px, 6vw, 88px); align-items: start; }
.scena-sec h2 { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.7rem, 2.6vw, 2.4rem); line-height: 1.08; letter-spacing: 0.012em; text-transform: uppercase; color: var(--ts-ink); }
.scena-sec h2 em { font-style: normal; color: var(--ts-red); }
.scena-sec .scena__copy .body { color: #3A3A3C; margin-top: 26px; max-width: 48ch; font-size: 1rem; line-height: 1.75; }
.scena-sec .scena__steps { margin-top: 36px; display: flex; flex-direction: column; gap: 0; border-top: 1px solid var(--ts-paper-line); }
.scena__step { display: grid; grid-template-columns: 28px 1fr; gap: 16px; padding: 18px 0; border-bottom: 1px solid var(--ts-paper-line); }
.scena__step .n { font-family: var(--font-mono); font-weight: 600; font-size: 11px; letter-spacing: 0.1em; color: var(--ts-red); padding-top: 2px; }
.scena__step .t { font-family: var(--font-body); font-weight: 300; font-size: 0.95rem; line-height: 1.6; color: #3A3A3C; }
.scena__step .t b { font-family: var(--font-display); font-weight: 700; color: var(--ts-ink); text-transform: uppercase; font-size: 0.92rem; letter-spacing: 0.01em; }
.scena-sec .cta-row { margin-top: 36px; }
.scena-sec .scene { box-shadow: 0 40px 90px rgba(0,0,0,0.22), 0 0 0 1px var(--ts-paper-line); }
.scene__hud { position: absolute; top: 18px; left: 18px; z-index: 5; display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-mono); font-weight: 500; font-size: 9.5px; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(255,255,255,0.7); background: rgba(0,0,0,0.4); backdrop-filter: blur(6px); padding: 8px 12px; border: 1px solid rgba(255,255,255,0.12); }
.scene__hud .live { width: 6px; height: 6px; border-radius: 50%; background: var(--ts-red); box-shadow: 0 0 0 3px rgba(216,31,42,0.25); }
.hotspot__btn { cursor: pointer; }
.hotspot__tip { cursor: pointer; text-align: left; }
.hotspot__tip .t-name, .hotspot__tip .t-sect { display: block; }
.hotspot__tip .t-open { display: flex; align-items: center; gap: 6px; margin-top: 8px; font-family: var(--font-mono); font-weight: 600; font-size: 9px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ts-ink); border-top: 1px solid var(--ts-paper-line); padding-top: 8px; }
.hotspot__tip .t-open svg { width: 11px; height: 11px; }
.scene__legend { display: flex; flex-wrap: wrap; gap: 18px 26px; padding: 20px 22px; background: #0A0A0B; border-top: 1px solid rgba(255,255,255,0.08); }
.scene__legend .lg { display: inline-flex; align-items: center; gap: 9px; font-family: var(--font-mono); font-weight: 500; font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.62); cursor: pointer; transition: color var(--dur-fast) var(--ease-std); }
.scene__legend .lg:hover { color: #fff; }
.scene__legend .lg::before { content: ""; width: 9px; height: 9px; border-radius: 50%; background: var(--ts-red); flex: none; box-shadow: 0 0 0 3px rgba(216,31,42,0.2); }
.scene__legend .lg.alt::before { background: var(--ts-yellow); box-shadow: 0 0 0 3px rgba(245,197,24,0.2); }

.fam__head { display: grid; grid-template-columns: minmax(0,5fr) minmax(0,7fr); gap: 80px; align-items: end; margin-bottom: 56px; }
.fam__head h2 { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.7rem, 2.6vw, 2.4rem); color: #fff; margin-top: 22px; text-transform: uppercase; letter-spacing: 0.012em; line-height: 1.08; }
.fam__head h2 em { font-style: normal; color: var(--ts-red); }
.fam__head .body { color: rgba(255,255,255,0.7); max-width: 52ch; }
.fam-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--ts-line-dim); border: 1px solid var(--ts-line-dim); }
.fam-card { background: var(--ts-ink-2); padding: 30px 28px 28px; min-height: 244px; display: flex; flex-direction: column; text-align: left; transition: background var(--dur-base) var(--ease-std); position: relative; cursor: pointer; }
.fam-card:hover { background: var(--ts-ink-3); }
.fam-card__icon { width: 38px; height: 38px; color: var(--ts-red); }
.fam-card__icon svg { width: 38px; height: 38px; }
.fam-card__name { margin-top: 26px; font-family: var(--font-display); font-weight: 800; font-size: 1.05rem; color: #fff; text-transform: uppercase; letter-spacing: 0.008em; line-height: 1.15; }
.fam-card__desc { margin-top: 12px; font-family: var(--font-body); font-weight: 300; font-size: 0.88rem; line-height: 1.6; color: rgba(255,255,255,0.62); }
.fam-card__cta { margin-top: auto; padding-top: 22px; display: inline-flex; align-items: center; gap: 9px; font-family: var(--font-mono); font-weight: 600; font-size: 9.5px; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(255,255,255,0.85); }
.fam-card__cta svg { width: 13px; height: 13px; color: var(--ts-red); transition: transform var(--dur-base) var(--ease-std); }
.fam-card:hover .fam-card__cta svg { transform: translateX(4px); }
.fam-card__sup { position: absolute; top: 26px; right: 26px; font-family: var(--font-mono); font-weight: 500; font-size: 9px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ts-fg-mute); }

.vant__head { max-width: 720px; margin-bottom: 64px; }
.vant__head h2 { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.7rem, 2.6vw, 2.4rem); color: var(--ts-ink); margin-top: 22px; text-transform: uppercase; letter-spacing: 0.012em; line-height: 1.1; }
.vant__head h2 em { font-style: normal; color: var(--ts-red); }
.vant-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--ts-paper-line); border: 1px solid var(--ts-paper-line); }
.vant-cell { background: #fff; padding: 44px 40px 48px; display: flex; flex-direction: column; }
.vant-cell__k { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.4rem, 1.9vw, 1.8rem); color: var(--ts-ink); line-height: 1; letter-spacing: 0.006em; }
.vant-cell__k .red { color: var(--ts-red); }
.vant-cell__t { margin-top: 18px; font-family: var(--font-display); font-weight: 700; font-size: 1.02rem; text-transform: uppercase; letter-spacing: 0.01em; color: var(--ts-ink); }
.vant-cell__b { margin-top: 12px; font-family: var(--font-body); font-weight: 300; font-size: 0.94rem; line-height: 1.7; color: #4A4A4C; }
.vant-cell__tag { margin-top: auto; padding-top: 24px; font-family: var(--font-mono); font-weight: 500; font-size: 9.5px; letter-spacing: 0.16em; text-transform: uppercase; color: #8A8A8E; }

.forn__head { display: grid; grid-template-columns: minmax(0,5fr) minmax(0,7fr); gap: 80px; align-items: end; margin-bottom: 48px; }
.forn__head h3 { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.4rem, 2vw, 1.9rem); color: #fff; margin-top: 22px; text-transform: uppercase; letter-spacing: 0.008em; max-width: 22ch; line-height: 1.1; }
.forn__head .body { color: rgba(255,255,255,0.7); max-width: 50ch; }
.brand-grid .b img { max-height: 42px; width: auto; opacity: 0.86; filter: grayscale(1) brightness(1.6); transition: opacity var(--dur-base), filter var(--dur-base); }
.brand-grid .b:hover img { opacity: 1; filter: grayscale(0) brightness(1); }

/* Product modal */
.prod-modal { position: fixed; inset: 0; z-index: 220; display: none; align-items: center; justify-content: center; padding: 24px; }
.prod-modal.open { display: flex; }
.prod-modal__overlay { position: absolute; inset: 0; background: rgba(5,5,5,0.84); backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); }
.prod-modal__panel { position: relative; z-index: 1; width: min(640px, 100%); background: var(--ts-ink-3); border: 1px solid var(--ts-line-dark); border-top: 3px solid var(--ts-red); max-height: calc(100vh - 48px); overflow-y: auto; }
.prod-modal__media { height: 168px; position: relative; overflow: hidden; background: radial-gradient(circle at 50% 40%, rgba(216,31,42,0.30) 0%, rgba(216,31,42,0) 55%), repeating-linear-gradient(90deg, rgba(255,255,255,0.05) 0 1px, transparent 1px 46px), linear-gradient(180deg, #1A1A1F 0%, #0A0A0C 100%); display: flex; align-items: center; justify-content: center; }
.prod-modal__media .pic { width: 72px; height: 72px; color: rgba(255,255,255,0.5); }
.prod-modal__media img { max-height: 100%; width: auto; }
.prod-modal__close { position: absolute; top: 16px; right: 16px; z-index: 3; width: 36px; height: 36px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid var(--ts-line-dark); color: #fff; background: rgba(5,5,6,0.5); transition: border-color var(--dur-fast), color var(--dur-fast); }
.prod-modal__close:hover { border-color: var(--ts-red); color: var(--ts-red); }
.prod-modal__close svg { width: 16px; height: 16px; }
.prod-modal__body { padding: 34px 40px 38px; }
.prod-modal__fam { font-family: var(--font-mono); font-weight: 500; font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ts-red); }
.prod-modal__name { font-family: var(--font-display); font-weight: 800; text-transform: uppercase; font-size: 1.7rem; color: #fff; margin: 12px 0 0; line-height: 1.05; letter-spacing: 0.01em; }
.prod-modal__desc { color: rgba(255,255,255,0.72); font-size: 0.96rem; line-height: 1.7; margin: 18px 0 0; }
.prod-modal__specs { margin: 28px 0 0; display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--ts-line-dark); border: 1px solid var(--ts-line-dark); }
.prod-modal__specs .sp { background: var(--ts-ink-2); padding: 16px 18px; }
.prod-modal__specs .sp .l { font-family: var(--font-mono); font-weight: 500; font-size: 9px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ts-fg-mute); }
.prod-modal__specs .sp .v { margin-top: 6px; font-family: var(--font-display); font-weight: 700; font-size: 0.98rem; color: #fff; letter-spacing: 0.01em; }
.prod-modal__certs { margin: 24px 0 0; display: flex; flex-wrap: wrap; gap: 8px; }
.prod-modal__certs span { font-family: var(--font-mono); font-weight: 500; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ts-yellow); padding: 6px 11px; border: 1px solid rgba(245,197,24,0.4); }
.prod-modal__actions { margin: 30px 0 0; display: flex; gap: 12px; flex-wrap: wrap; }
.prod-modal__actions .btn { cursor: pointer; }
.prod-modal__sup { margin: 22px 0 0; font-family: var(--font-mono); font-weight: 500; font-size: 9.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ts-fg-mute); }

/* ============================================================ CHI SIAMO ============================================================ */
.storia__head { display: grid; grid-template-columns: minmax(0,5fr) minmax(0,7fr); gap: 80px; align-items: end; margin-bottom: 72px; }
.storia__head h2 { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.7rem, 2.6vw, 2.4rem); line-height: 1.08; letter-spacing: 0.012em; text-transform: uppercase; color: var(--ts-ink); }
.storia__head h2 em { font-style: normal; color: var(--ts-red); }
.storia__head .body { color: #3A3A3C; max-width: 52ch; font-size: 1rem; line-height: 1.75; }
.timeline { position: relative; border-top: 1px solid var(--ts-paper-line); }
.tl-row { display: grid; grid-template-columns: 200px 1fr; gap: clamp(28px, 5vw, 72px); padding: 40px 0; border-bottom: 1px solid var(--ts-paper-line); position: relative; }
.tl-row__year { font-family: var(--font-mono); font-weight: 600; font-size: clamp(1.5rem, 2.4vw, 2.1rem); color: var(--ts-red); letter-spacing: 0.01em; line-height: 1; }
.tl-row__year .sub { display: block; margin-top: 10px; font-family: var(--font-mono); font-weight: 500; font-size: 9.5px; letter-spacing: 0.18em; text-transform: uppercase; color: #8A8A8E; }
.tl-row__body { max-width: 56ch; padding-left: 36px; border-left: 1px solid var(--ts-paper-line); position: relative; }
.tl-row__body::before { content: ""; position: absolute; left: -5px; top: 6px; width: 9px; height: 9px; border-radius: 50%; background: var(--ts-red); box-shadow: 0 0 0 4px rgba(216,31,42,0.14); }
.tl-row__t { font-family: var(--font-display); font-weight: 800; font-size: 1.15rem; text-transform: uppercase; letter-spacing: 0.01em; color: var(--ts-ink); line-height: 1.15; }
.tl-row__b { margin-top: 14px; font-family: var(--font-body); font-weight: 300; font-size: 0.97rem; line-height: 1.75; color: #4A4A4C; }

.val__head { display: grid; grid-template-columns: minmax(0,5fr) minmax(0,7fr); gap: 80px; align-items: end; margin-bottom: 56px; }
.val__head h2 { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.7rem, 2.6vw, 2.4rem); color: #fff; margin-top: 22px; text-transform: uppercase; letter-spacing: 0.012em; line-height: 1.08; }
.val__head h2 em { font-style: normal; color: var(--ts-red); }
.val__head .body { color: rgba(255,255,255,0.7); max-width: 52ch; }
.val-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--ts-line-dim); border: 1px solid var(--ts-line-dim); }
.val-cell { background: var(--ts-ink-2); padding: 36px 30px 38px; min-height: 280px; display: flex; flex-direction: column; }
.val-cell__n { font-family: var(--font-mono); font-weight: 600; font-size: 11px; letter-spacing: 0.18em; color: var(--ts-red); }
.val-cell__icon { width: 36px; height: 36px; color: var(--ts-red); margin-top: 26px; }
.val-cell__icon svg { width: 36px; height: 36px; }
.val-cell__t { margin-top: 26px; font-family: var(--font-display); font-weight: 800; font-size: 1.05rem; color: #fff; text-transform: uppercase; letter-spacing: 0.008em; line-height: 1.18; }
.val-cell__b { margin-top: 14px; font-family: var(--font-body); font-weight: 300; font-size: 0.9rem; line-height: 1.65; color: rgba(255,255,255,0.64); }

.cert__grid { display: grid; grid-template-columns: minmax(0,7fr) minmax(0,5fr); gap: clamp(40px, 6vw, 88px); align-items: center; }
.cert__copy h2 { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.7rem, 2.6vw, 2.4rem); color: var(--ts-ink); margin-top: 22px; text-transform: uppercase; letter-spacing: 0.012em; line-height: 1.1; }
.cert__copy h2 em { font-style: normal; color: var(--ts-red); }
.cert__copy .body { margin-top: 26px; color: #3A3A3C; max-width: 50ch; font-size: 1rem; line-height: 1.75; }
.cert__points { margin-top: 32px; display: flex; flex-direction: column; gap: 0; border-top: 1px solid var(--ts-paper-line); }
.cert__point { display: grid; grid-template-columns: 22px 1fr; gap: 16px; padding: 16px 0; border-bottom: 1px solid var(--ts-paper-line); font-family: var(--font-body); font-weight: 300; font-size: 0.95rem; color: #3A3A3C; line-height: 1.6; }
.cert__point svg { width: 18px; height: 18px; color: var(--ts-red); margin-top: 2px; }
.cert__point b { font-family: var(--font-display); font-weight: 700; color: var(--ts-ink); text-transform: uppercase; font-size: 0.9rem; letter-spacing: 0.01em; }
.cert-badge { background: #fff; border: 1px solid var(--ts-paper-line); border-top: 3px solid var(--ts-red); padding: 48px 40px 44px; text-align: center; }
.cert-badge__ring { width: 116px; height: 116px; margin: 0 auto; border-radius: 50%; border: 2px solid var(--ts-red); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 2px; }
.cert-badge__ring .iso { font-family: var(--font-display); font-weight: 800; font-size: 1.9rem; color: var(--ts-ink); line-height: 1; }
.cert-badge__ring .std { font-family: var(--font-mono); font-weight: 500; font-size: 9px; letter-spacing: 0.18em; color: var(--ts-red); }
.cert-badge__t { margin-top: 28px; font-family: var(--font-display); font-weight: 800; font-size: 1.15rem; text-transform: uppercase; letter-spacing: 0.01em; color: var(--ts-ink); }
.cert-badge__b { margin-top: 12px; font-family: var(--font-body); font-weight: 300; font-size: 0.92rem; line-height: 1.65; color: #4A4A4C; }
.cert-badge__meta { margin-top: 24px; padding-top: 20px; border-top: 1px solid var(--ts-paper-line); font-family: var(--font-mono); font-weight: 500; font-size: 9.5px; letter-spacing: 0.16em; text-transform: uppercase; color: #8A8A8E; }

.team__head { max-width: 720px; margin-bottom: 56px; }
.team__head h2 { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.7rem, 2.6vw, 2.4rem); color: #fff; margin-top: 22px; text-transform: uppercase; letter-spacing: 0.012em; line-height: 1.08; }
.team__head h2 em { font-style: normal; color: var(--ts-red); }
.team__head .body { margin-top: 22px; color: rgba(255,255,255,0.7); max-width: 56ch; }
.team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--ts-line-dim); border: 1px solid var(--ts-line-dim); }
.team-card { background: var(--ts-ink-2); padding: 0 0 30px; display: flex; flex-direction: column; }
.team-card__photo { aspect-ratio: 4 / 4; position: relative; overflow: hidden; background: radial-gradient(ellipse 70% 60% at 50% 28%, rgba(255,255,255,0.06) 0%, rgba(0,0,0,0) 60%), linear-gradient(180deg, #1C1C20 0%, #0C0C0E 100%); display: flex; align-items: center; justify-content: center; }
.team-card__photo img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.team-card__mono { font-family: var(--font-display); font-weight: 800; font-size: 3.2rem; color: rgba(255,255,255,0.14); letter-spacing: 0.02em; line-height: 1; }
.team-card__photo .ph { position: absolute; bottom: 14px; left: 16px; font-family: var(--font-mono); font-weight: 500; font-size: 8.5px; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(255,255,255,0.4); }
.team-card__body { padding: 26px 28px 0; }
.team-card__role { font-family: var(--font-mono); font-weight: 500; font-size: 9.5px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ts-red); }
.team-card__name { margin-top: 12px; font-family: var(--font-display); font-weight: 800; font-size: 1.2rem; color: #fff; text-transform: uppercase; letter-spacing: 0.008em; }
.team-card__b { margin-top: 12px; font-family: var(--font-body); font-weight: 300; font-size: 0.9rem; line-height: 1.65; color: rgba(255,255,255,0.62); }

/* ============================================================ RISORSE (collection list) ============================================================ */
.res-tools { background: var(--ts-paper); border-bottom: 1px solid var(--ts-paper-line); position: sticky; top: 0; z-index: 40; }
.res-tools__row { display: flex; align-items: center; justify-content: space-between; gap: 28px; flex-wrap: wrap; padding: 22px 0; }
.res-tabs { display: flex; flex-wrap: wrap; gap: 6px; }
.res-tab { font-family: var(--font-mono); font-weight: 500; font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: #6A6A6E; padding: 11px 16px; border: 1px solid transparent; cursor: pointer; background: transparent; transition: color var(--dur-fast), border-color var(--dur-fast), background var(--dur-fast); }
.res-tab:hover { color: var(--ts-ink); }
.res-tab[aria-selected="true"] { color: #fff; background: var(--ts-red); }
.res-subfilters { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.res-select { position: relative; }
.res-select select { appearance: none; -webkit-appearance: none; font-family: var(--font-mono); font-weight: 500; font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ts-ink); background: #fff; border: 1px solid var(--ts-paper-line); padding: 12px 38px 12px 15px; border-radius: 0; cursor: pointer; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%23D81F2A' stroke-width='2'><path d='M2 5l5 5 5-5'/></svg>"); background-repeat: no-repeat; background-position: right 14px center; }
.res-select select:focus { outline: none; border-color: var(--ts-red); }
.res-sec { background: var(--ts-paper); color: var(--ts-ink); padding: clamp(56px, 7vw, 88px) 0 clamp(88px, 11vw, 140px); }
.res-count { font-family: var(--font-mono); font-weight: 500; font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: #8A8A8E; margin-bottom: 36px; }
.res-count b { color: var(--ts-red); font-weight: 600; }
.res-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--ts-paper-line); border: 1px solid var(--ts-paper-line); }
.res-item { background: #fff; padding: 34px 30px 30px; display: flex; flex-direction: column; min-height: 320px; position: relative; text-align: left; transition: background var(--dur-base); color: inherit; }
.res-item:hover { background: #FBFAF7; }
.res-item__top { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; }
.res-item__type { font-family: var(--font-mono); font-weight: 600; font-size: 9.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ts-red); }
.res-item__fmt { font-family: var(--font-mono); font-weight: 500; font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; color: #9A9A9E; border: 1px solid var(--ts-paper-line); padding: 5px 9px; flex: none; }
.res-item__icon { width: 40px; height: 40px; color: var(--ts-ink); margin-top: 26px; }
.res-item__icon svg { width: 40px; height: 40px; }
.res-item__title { margin-top: 22px; font-family: var(--font-display); font-weight: 800; font-size: 1.12rem; color: var(--ts-ink); text-transform: uppercase; letter-spacing: 0.008em; line-height: 1.18; }
.res-item__desc { margin-top: 12px; font-family: var(--font-body); font-weight: 300; font-size: 0.88rem; line-height: 1.6; color: #5A5A5E; }
.res-item__tags { margin-top: 18px; display: flex; flex-wrap: wrap; gap: 7px; }
.res-item__tag { font-family: var(--font-mono); font-weight: 500; font-size: 8.5px; letter-spacing: 0.12em; text-transform: uppercase; color: #7A7A7E; border: 1px solid var(--ts-paper-line); padding: 5px 8px; }
.res-item__tag.brand { color: var(--ts-ink); border-color: #C9C5BD; }
.res-item__cta { margin-top: auto; padding-top: 24px; display: inline-flex; align-items: center; gap: 9px; font-family: var(--font-mono); font-weight: 600; font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ts-ink); cursor: pointer; background: 0; border: 0; align-self: flex-start; }
.res-item__cta svg { width: 14px; height: 14px; color: var(--ts-red); transition: transform var(--dur-base); }
.res-item:hover .res-item__cta svg { transform: translateY(2px); }
.res-item.is-video:hover .res-item__cta svg { transform: translateX(3px); }
.res-item__hide { display: none !important; }
.res-empty { display: none; text-align: center; padding: 80px 0; color: #6A6A6E; font-family: var(--font-body); font-weight: 300; }
.res-empty.show { display: block; }

/* ============================================================ CONTATTI ============================================================ */
.contact__grid { display: grid; grid-template-columns: minmax(0,6fr) minmax(0,5fr); gap: clamp(40px, 5vw, 80px); align-items: start; }
.contact__intro h2 { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.6rem, 2.4vw, 2.2rem); color: var(--ts-ink); text-transform: uppercase; letter-spacing: 0.012em; line-height: 1.1; }
.contact__intro h2 em { font-style: normal; color: var(--ts-red); }
.contact__intro .body { margin-top: 22px; color: #3A3A3C; max-width: 46ch; font-size: 1rem; line-height: 1.7; }
.cf { margin-top: 38px; }
.cf__row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.cf-field { display: flex; flex-direction: column; gap: 8px; margin-bottom: 18px; }
.cf-field label { font-family: var(--font-mono); font-weight: 500; font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: #6A6A6E; }
.cf-field label .req { color: var(--ts-red); }
.cf-field input, .cf-field select, .cf-field textarea { font-family: var(--font-body); font-size: 0.97rem; color: var(--ts-ink); background: #fff; border: 1px solid var(--ts-paper-line); border-radius: 0; padding: 14px 15px; transition: border-color var(--dur-fast); }
.cf-field input:focus, .cf-field select:focus, .cf-field textarea:focus { outline: none; border-color: var(--ts-red); }
.cf-field textarea { resize: vertical; min-height: 130px; }
.cf-field select { appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%23D81F2A' stroke-width='2'><path d='M2 5l5 5 5-5'/></svg>"); background-repeat: no-repeat; background-position: right 15px center; padding-right: 40px; }
.cf-check { display: flex; align-items: flex-start; gap: 12px; margin: 8px 0 26px; }
.cf-check input { width: 18px; height: 18px; flex: none; margin-top: 2px; accent-color: var(--ts-red); }
.cf-check label { font-family: var(--font-body); font-weight: 300; font-size: 0.86rem; line-height: 1.55; color: #5A5A5E; }
.cf-check a { color: var(--ts-red); border-bottom: 1px solid currentColor; }
.cf__submit { display: inline-flex; align-items: center; gap: 12px; cursor: pointer; background: var(--ts-red); color: #fff; font-family: var(--font-mono); font-weight: 600; font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; padding: 17px 30px; border: 0; box-shadow: 0 10px 30px var(--ts-red-glow); transition: background var(--dur-base), transform var(--dur-fast); }
.cf__submit:hover { background: var(--ts-red-deep); transform: translateY(-1px); }
.cf__submit svg { width: 15px; height: 15px; }
.cf__success { display: none; border: 1px solid var(--ts-paper-line); border-top: 3px solid var(--ts-red); background: #fff; padding: 36px 34px; }
.cf__success.show { display: block; }
.cf__success .ok { width: 50px; height: 50px; border-radius: 50%; border: 1px solid var(--ts-red); color: var(--ts-red); display: inline-flex; align-items: center; justify-content: center; margin-bottom: 18px; }
.cf__success .ok svg { width: 24px; height: 24px; }
.cf__success h3 { font-family: var(--font-display); font-weight: 800; font-size: 1.4rem; color: var(--ts-ink); text-transform: uppercase; letter-spacing: 0.01em; }
.cf__success p { margin-top: 12px; color: #4A4A4C; font-size: 0.95rem; line-height: 1.65; }
.coord { background: var(--ts-ink); color: #fff; padding: 0; border: 1px solid var(--ts-line-dark); position: sticky; top: 96px; }
.coord__body { padding: 38px 36px 8px; }
.coord__eyebrow { font-family: var(--font-mono); font-weight: 500; font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ts-red); }
.coord__name { margin-top: 14px; font-family: var(--font-display); font-weight: 800; font-size: 1.5rem; color: #fff; text-transform: uppercase; letter-spacing: 0.01em; }
.coord__list { margin: 28px 0 8px; display: flex; flex-direction: column; gap: 0; border-top: 1px solid var(--ts-line-dark); }
.coord__item { display: grid; grid-template-columns: 20px 1fr; gap: 16px; padding: 18px 0; border-bottom: 1px solid var(--ts-line-dark); }
.coord__item svg { width: 18px; height: 18px; color: var(--ts-red); margin-top: 2px; }
.coord__item .l { font-family: var(--font-mono); font-weight: 500; font-size: 9px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ts-fg-mute); }
.coord__item .v { margin-top: 5px; font-family: var(--font-body); font-weight: 300; font-size: 0.97rem; color: #fff; line-height: 1.55; }
.coord__item .v a { color: #fff; transition: color var(--dur-fast); }
.coord__item .v a:hover { color: var(--ts-red); }
.coord__map { width: 100%; height: 240px; border: 0; display: block; border-top: 1px solid var(--ts-line-dark); filter: grayscale(1) invert(0.92) contrast(0.92); }

/* ============================================================ NEWS ============================================================ */
.news-index { background: var(--ts-ink); color: var(--ts-fg-on-dark); padding: clamp(72px, 9vw, 120px) 0 clamp(96px, 12vw, 150px); }
.news-index__head { display: flex; align-items: flex-end; justify-content: space-between; gap: 40px; flex-wrap: wrap; margin-bottom: 56px; }
.news-index__head h2 { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.7rem, 2.6vw, 2.4rem); color: #fff; text-transform: uppercase; letter-spacing: 0.012em; line-height: 1.1; max-width: 18ch; }
.news-index__head h2 em { font-style: normal; color: var(--ts-red); }
.news-index__count { font-family: var(--font-mono); font-weight: 500; font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ts-fg-mute); padding-bottom: 6px; }
a.news-card { text-decoration: none; cursor: pointer; }
a.news-card .news-card__title { transition: color var(--dur-fast); }
a.news-card:hover .news-card__title { color: var(--ts-red); }
.news-card__more { margin-top: 20px; display: inline-flex; align-items: center; gap: 9px; font-family: var(--font-mono); font-weight: 600; font-size: 9.5px; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(255,255,255,0.85); }
.news-card__more svg { width: 13px; height: 13px; color: var(--ts-red); transition: transform var(--dur-base); }
a.news-card:hover .news-card__more svg { transform: translateX(4px); }
.news-card__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }

/* blog middleware-injected bits reuse .news-grid / .news-card look */
.blog-categories { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 40px; }
.blog-cat-pill { font-family: var(--font-mono); font-weight: 500; font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255,255,255,0.65); border: 1px solid var(--ts-line-dark); padding: 9px 14px; }
.blog-cat-pill.active { color: #fff; background: var(--ts-red); border-color: var(--ts-red); }
.blog-search-form { display: flex; gap: 8px; margin-bottom: 28px; }
.blog-search-input { flex: 1; background: var(--ts-ink-2); border: 1px solid var(--ts-line-dark); color: #fff; padding: 12px 14px; font-family: var(--font-body); }
.blog-search-btn { background: var(--ts-red); color: #fff; border: 0; padding: 0 20px; font-family: var(--font-mono); font-weight: 600; text-transform: uppercase; letter-spacing: 0.14em; font-size: 10px; cursor: pointer; }
.blog-card-cat { color: var(--ts-red); }

/* ---- ARTICLE ---- */
.art-hero { position: relative; min-height: 60vh; display: flex; align-items: flex-end; padding: 176px 0 56px; background: var(--ts-black); overflow: hidden; border-bottom: 1px solid var(--ts-line-dim); }
.art-hero__bg { position: absolute; inset: 0; background-size: cover; background-position: center; background-color: #0E0E10; }
.art-hero__bg.css-canvas { background: linear-gradient(180deg, transparent 0%, transparent 28%, rgba(255,255,255,0.06) 30%, rgba(255,255,255,0.06) 50%, transparent 50%, transparent 100%), repeating-linear-gradient(90deg, rgba(255,255,255,0.10) 0 14px, transparent 14px 24px), radial-gradient(ellipse at 35% 50%, rgba(255,180,40,0.12) 0%, rgba(0,0,0,0) 60%), linear-gradient(180deg, #161620 0%, #050507 100%); }
.art-hero__bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(5,5,6,0.6) 0%, rgba(5,5,6,0.15) 32%, rgba(5,5,6,0.2) 60%, rgba(5,5,6,0.9) 100%); }
.art-hero__inner { position: relative; z-index: 2; width: 100%; max-width: 880px; }
.art-hero__meta { display: inline-flex; align-items: center; gap: 14px; margin-bottom: 22px; }
.art-hero__cat { font-family: var(--font-mono); font-weight: 600; font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: #fff; background: var(--ts-red); padding: 7px 12px; }
.art-hero__date { font-family: var(--font-mono); font-weight: 500; font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(255,255,255,0.7); }
.art-hero h1 { font-family: var(--font-display); font-weight: 800; font-size: clamp(2rem, 4.4vw, 3.7rem); line-height: 1.02; letter-spacing: 0.012em; color: #fff; text-transform: uppercase; max-width: 20ch; }
.art-sec { background: var(--ts-paper); color: var(--ts-ink); padding: clamp(64px, 8vw, 104px) 0 clamp(80px, 10vw, 128px); }
.art-col { max-width: 760px; margin: 0 auto; }
.art-col > p:first-child, .art-lead { font-family: var(--font-body); font-weight: 400; font-size: clamp(1.2rem, 1.7vw, 1.5rem); line-height: 1.6; color: var(--ts-ink); }
.art-col p { font-family: var(--font-body); font-weight: 300; font-size: 1.08rem; line-height: 1.85; color: #3A3A3C; margin-top: 26px; }
.art-col h2 { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.45rem, 2.2vw, 1.95rem); text-transform: uppercase; letter-spacing: 0.012em; color: var(--ts-ink); line-height: 1.12; margin-top: 56px; }
.art-col h3 { font-family: var(--font-display); font-weight: 700; font-size: 1.18rem; text-transform: uppercase; letter-spacing: 0.01em; color: var(--ts-ink); margin-top: 40px; }
.art-col a { color: var(--ts-red); border-bottom: 1px solid currentColor; }
.art-col blockquote, .art-quote { margin: 52px 0; padding: 36px 0; border-top: 3px solid var(--ts-red); border-bottom: 1px solid var(--ts-paper-line); }
.art-col blockquote p, .art-quote p { font-family: var(--font-display); font-weight: 700; font-size: clamp(1.4rem, 2.4vw, 2rem); line-height: 1.22; letter-spacing: 0.008em; text-transform: uppercase; color: var(--ts-ink); margin: 0; }
.art-col img { margin: 48px 0; width: 100%; border: 1px solid var(--ts-paper-line); }
.art-share { max-width: 760px; margin: 56px auto 0; padding-top: 32px; border-top: 1px solid var(--ts-paper-line); display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.art-share__label { font-family: var(--font-mono); font-weight: 500; font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: #8A8A8E; }
.art-share a { display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-mono); font-weight: 600; font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: #fff; background: var(--ts-ink); padding: 13px 18px; text-decoration: none; transition: background var(--dur-fast); }
.art-share a:hover { background: var(--ts-red); }
.art-share a svg { width: 15px; height: 15px; }
.blog-related, .related { background: var(--ts-ink); color: var(--ts-fg-on-dark); padding: clamp(72px, 9vw, 116px) 0; border-top: 1px solid var(--ts-line-dim); }
.related__head, .blog-related-title { margin-bottom: 48px; }
.blog-related-title { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.6rem, 2.4vw, 2.2rem); color: #fff; text-transform: uppercase; letter-spacing: 0.012em; }

/* ============================================================ RESPONSIVE ============================================================ */
@media (max-width: 1100px) {
  .scena-sec .scena__grid { grid-template-columns: 1fr; gap: 44px; }
  .fam-grid { grid-template-columns: repeat(2, 1fr); }
  .fam__head, .forn__head, .storia__head, .val__head { grid-template-columns: 1fr; gap: 20px; }
  .val-grid { grid-template-columns: repeat(2, 1fr); }
  .cert__grid { grid-template-columns: 1fr; gap: 44px; }
  .team-grid { grid-template-columns: 1fr 1fr; }
  .contact__grid, .cat__grid { grid-template-columns: 1fr; gap: 44px; }
  .coord { position: static; }
}
@media (max-width: 1040px) { .news-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 1000px) { .res-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 720px) {
  .fam-grid, .vant-grid, .val-grid, .team-grid { grid-template-columns: 1fr; }
  .tl-row { grid-template-columns: 1fr; gap: 18px; }
  .tl-row__body { padding-left: 24px; }
  .prod-modal__specs { grid-template-columns: 1fr; }
  .page-hero__meta .m { border-right: 0; padding-right: 0; margin-right: 0; width: 46%; }
  .cf__row { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .news-grid, .res-grid { grid-template-columns: 1fr; }
  .res-tools__row { flex-direction: column; align-items: stretch; gap: 16px; }
  .res-tabs { overflow-x: auto; }
}

/* ---- Nav dropdown (Settori) ---- */
.ts-nav-group { position: relative; display: inline-flex; align-items: center; }
.ts-nav-trigger { display: inline-flex; align-items: center; gap: 6px; }
.ts-nav-trigger .chev { font-size: 9px; opacity: 0.7; transition: transform var(--dur-fast) var(--ease-std); }
.ts-nav-group:hover .ts-nav-trigger .chev, .ts-nav-group:focus-within .ts-nav-trigger .chev { transform: rotate(180deg); }
.ts-nav-dropdown {
  position: absolute; top: 100%; left: 0; z-index: 80;
  display: flex; flex-direction: column; min-width: 260px;
  background: rgba(5,5,5,0.96); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--ts-line-dark); border-top: 2px solid var(--ts-red);
  padding: 8px 0; margin-top: 14px;
  opacity: 0; visibility: hidden; transform: translateY(6px);
  transition: opacity var(--dur-base) var(--ease-std), transform var(--dur-base) var(--ease-std), visibility var(--dur-base);
  box-shadow: 0 24px 60px rgba(0,0,0,0.5);
}
/* hover bridge so it doesn't close crossing the gap */
.ts-nav-group::after { content: ""; position: absolute; top: 100%; left: 0; right: 0; height: 16px; }
.ts-nav-group:hover .ts-nav-dropdown, .ts-nav-group:focus-within .ts-nav-dropdown { opacity: 1; visibility: visible; transform: translateY(0); }
.ts-nav-dropdown a { display: flex; flex-direction: column; gap: 3px; padding: 12px 20px; text-transform: none; letter-spacing: 0; }
.ts-nav-dropdown a:hover { background: rgba(255,255,255,0.05); }
.ts-nav-dropdown .d-label { font-family: var(--font-display); font-weight: 700; font-size: 13px; letter-spacing: 0.02em; text-transform: uppercase; color: #fff; }
.ts-nav-dropdown .d-desc { font-family: var(--font-body); font-weight: 300; font-size: 11px; color: var(--ts-fg-mute); }

/* mobile submenu */
.ts-mobile__sub { display: flex; flex-direction: column; padding-left: 18px; margin: -6px 0 6px; border-left: 1px solid var(--ts-line-dim); }
.ts-mobile__sub a { font-size: 1rem !important; font-weight: 500 !important; padding: 10px 0 !important; color: rgba(255,255,255,0.7) !important; border: 0 !important; text-transform: none !important; }

/* ---- TsSectorNav (sector switcher) ---- */
.ts-secnav .secnav__head { margin-bottom: 40px; }
.secnav__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.secnav-card { position: relative; display: block; aspect-ratio: 4/5; overflow: hidden; background: #0E0E10; border: 1px solid rgba(255,255,255,0.08); transition: border-color var(--dur-base) var(--ease-std), transform var(--dur-base) var(--ease-std); }
.secnav-card:hover { border-color: var(--ts-red); transform: translateY(-3px); }
.secnav-card__bg { position: absolute; inset: 0; }
.secnav-card__veil { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(5,5,6,0.1) 0%, rgba(5,5,6,0.35) 45%, rgba(5,5,6,0.9) 100%); }
.secnav-card__foot { position: absolute; left: 0; right: 0; bottom: 0; z-index: 2; padding: 22px 20px; }
.secnav-card__row { display: flex; align-items: flex-end; justify-content: space-between; gap: 10px; }
.secnav-card h3 { font-family: var(--font-display); font-weight: 800; font-size: 1.02rem; line-height: 1.1; color: #fff; text-transform: uppercase; letter-spacing: 0.01em; max-width: 12ch; margin: 0; }
.secnav-card__arr { color: #fff; width: 26px; height: 20px; flex: none; transition: transform var(--dur-base) var(--ease-std), color var(--dur-base) var(--ease-std); }
.secnav-card__arr svg { width: 26px; height: 20px; }
.secnav-card:hover .secnav-card__arr { color: var(--ts-red); transform: translateX(4px); }
.secnav-card.is-current { border-color: var(--ts-red); cursor: default; }
.secnav-card.is-current .secnav-card__veil { background: linear-gradient(180deg, rgba(216,31,42,0.14) 0%, rgba(5,5,6,0.4) 50%, rgba(5,5,6,0.92) 100%); }
.secnav-card__here { display: inline-block; font-family: var(--font-mono); font-weight: 600; font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ts-red); margin-bottom: 8px; }
@media (max-width: 900px) { .secnav__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .secnav__grid { grid-template-columns: 1fr; } .secnav-card { aspect-ratio: 16/7; } }

/* ---- CTA strip PAPER variant ---- */
.cta-strip--paper { background: var(--ts-paper); border-top: 1px solid var(--ts-paper-line); }
.cta-strip--paper .cta-strip__row h2 { color: var(--ts-ink); }
.cta-strip--paper .cta-strip__row h2 .red, .cta-strip--paper .cta-strip__row h2 em { color: var(--ts-red); }
.cta-strip--paper .cta-strip__cta .btn { border-color: var(--ts-ink); color: var(--ts-ink); }
.cta-strip--paper .cta-strip__cta .btn:hover { background: var(--ts-ink); color: #fff; }
.cta-strip--paper .cta-strip__cta .btn .arr { color: var(--ts-red); }
.cta-strip--paper .cta-strip__cta .btn:hover .arr { color: #fff; }
.secnav-card__bg { background-size: cover; background-position: center; }

/* ---- TsVideo (corporate preview under hero) ---- */
.ts-video { background: var(--ts-black); padding: clamp(64px, 8vw, 110px) 0; border-top: 1px solid var(--ts-line-dim); }
.ts-video__head { max-width: 720px; margin: 0 0 40px; }
.ts-video__head h2 { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.7rem, 2.6vw, 2.4rem); color: #fff; text-transform: uppercase; letter-spacing: 0.012em; line-height: 1.1; margin-top: 8px; }
.ts-video__head h2 em { font-style: normal; color: var(--ts-red); }
.ts-video__sub { margin-top: 18px; color: rgba(255,255,255,0.72); font-family: var(--font-body); font-weight: 300; font-size: 1.05rem; line-height: 1.7; max-width: 60ch; }
.ts-video__stage { position: relative; aspect-ratio: 16/9; background: #0A0A0B; overflow: hidden; border: 1px solid var(--ts-line-dark); }
.ts-video__el { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.ts-video__play { position: absolute; inset: 0; z-index: 2; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 18px; cursor: pointer; background: linear-gradient(180deg, rgba(5,5,6,0.25), rgba(5,5,6,0.55)); border: 0; transition: background var(--dur-base) var(--ease-std); }
.ts-video__play:hover { background: linear-gradient(180deg, rgba(5,5,6,0.15), rgba(5,5,6,0.45)); }
.ts-video__stage.is-playing .ts-video__play { display: none; }
.ts-video__ring { width: clamp(72px, 8vw, 96px); height: clamp(72px, 8vw, 96px); border-radius: 50%; border: 2px solid rgba(255,255,255,0.7); display: inline-flex; align-items: center; justify-content: center; color: #fff; transition: border-color var(--dur-base) var(--ease-std), transform var(--dur-base) var(--ease-std), background var(--dur-base) var(--ease-std); }
.ts-video__play:hover .ts-video__ring { border-color: var(--ts-red); background: var(--ts-red); transform: scale(1.05); }
.ts-video__ring svg { width: 34px; height: 34px; margin-left: 4px; }
.ts-video__label { font-family: var(--font-mono); font-weight: 600; font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: #fff; }
